UNPKG

@yeutech-lab/rollup-umd-documentation

Version:

Quickly build awesome documentation for your rollup-umd project.

185 lines (152 loc) 10.1 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.propTypes = exports.defaultProps = undefined; var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var _templateObject = _taggedTemplateLiteral([' \n ', '\n'], [' \n ', '\n']); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _A = require('@bootstrap-styled/v4/lib/A'); var _A2 = _interopRequireDefault(_A); var _Fa = require('@bootstrap-styled/v4/lib/Fa'); var _Fa2 = _interopRequireDefault(_Fa); var _hover = require('@bootstrap-styled/css-mixins/lib/hover'); var _styledComponents = require('styled-components'); var _styledComponents2 = _interopRequireDefault(_styledComponents); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _lodash = require('lodash.omit'); var _lodash2 = _interopRequireDefault(_lodash); var _lib = require('map-to-css-modules/lib'); var _lib2 = _interopRequireDefault(_lib); var _Heading = require('rsg-components/Heading'); var _Heading2 = _interopRequireDefault(_Heading); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _taggedTemplateLiteral(strings, raw) { return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); } function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } var defaultProps = exports.defaultProps = { theme: { styleguide: { '$rsg-section-heading-display': 'flex', '$rsg-section-heading-flex-direction': 'row', '$rsg-section-heading-align-items': 'center', '$rsg-section-heading-margin-bottom': '8px', '$rsg-section-heading-section-name-isolation': 'false', '$rsg-section-heading-section-name-text-decoration': 'underline', '$rsg-section-heading-section-name-cursor': 'pointer', '$rsg-section-heading-section-name-color': '#B31255', '$rsg-section-heading-anchor-font-size': '15px', '$rsg-section-heading-anchor-font-weight': 'normal', '$rsg-section-heading-anchor-transform': 'rotate(-5deg)', '$rsg-section-heading-anchor-color': '#CCCCCC', '$rsg-section-heading-anchor-padding': '6px 5px 0 0', '$rsg-section-heading-anchor-display': 'table-cell', '$rsg-section-heading-anchor-vertical-align': 'middle', '$rsg-section-heading-deprecated-text-decoration': 'line-through', '$rsg-section-heading-deprecated-cursor': '#767676', '$rsg-section-heading-toolbar-margin-left': 'auto', '$rsg-section-heading-1-link-color': '#292b2c', '$rsg-section-heading-2-link-color': '#767676' } } }; var propTypes = exports.propTypes = { /** * @ignore */ className: _propTypes2.default.string, // eslint-disable-line react/require-default-props /** Specified node element will be passed as children of `<SectionHeadingRenderer />` component. */ children: _propTypes2.default.node, // eslint-disable-line react/require-default-props /** Toolbar element to be rendered. */ toolbar: _propTypes2.default.node, // eslint-disable-line react/require-default-props /** Set id used by `<Heading />` component. */ id: _propTypes2.default.string.isRequired, /** Set anchor link href used by `<A />` component. */ href: _propTypes2.default.string.isRequired, /** Set level used in `<Heading />` component. */ depth: _propTypes2.default.number.isRequired, /** Toggle deprecated style. */ deprecated: _propTypes2.default.bool, // eslint-disable-line react/require-default-props /** Theme variables. Can be: */ theme: _propTypes2.default.shape({ styleguide: _propTypes2.default.shape({ '$rsg-section-heading-display': _propTypes2.default.string, '$rsg-section-heading-flex-direction': _propTypes2.default.string, '$rsg-section-heading-align-items': _propTypes2.default.string, '$rsg-section-heading-margin-bottom': _propTypes2.default.string, '$rsg-section-heading-section-name-isolation': _propTypes2.default.string, '$rsg-section-heading-section-name-text-decoration': _propTypes2.default.string, '$rsg-section-heading-section-name-cursor': _propTypes2.default.string, '$rsg-section-heading-section-name-color': _propTypes2.default.string, '$rsg-section-heading-anchor-font-size': _propTypes2.default.string, '$rsg-section-heading-anchor-font-weight': _propTypes2.default.string, '$rsg-section-heading-anchor-transform': _propTypes2.default.string, '$rsg-section-heading-anchor-color': _propTypes2.default.string, '$rsg-section-heading-anchor-padding': _propTypes2.default.string, '$rsg-section-heading-anchor-display': _propTypes2.default.string, '$rsg-section-heading-anchor-vertical-align': _propTypes2.default.string, '$rsg-section-heading-deprecated-text-decoration': _propTypes2.default.string, '$rsg-section-heading-deprecated-cursor': _propTypes2.default.string, '$rsg-section-heading-toolbar-margin-left': _propTypes2.default.string, '$rsg-section-heading-1-link-color': _propTypes2.default.string, '$rsg-section-heading-2-link-color': _propTypes2.default.string }) }), /** * Replace or remove a className from the component. * See example <a href="https://www.npmjs.com/package/map-to-css-modules" target="_blank">here</a>. */ cssModule: _propTypes2.default.object // eslint-disable-line react/require-default-props }; var SectionHeadingRendererUnstyled = function SectionHeadingRendererUnstyled(props) { var _omit = (0, _lodash2.default)(props, ['theme']), className = _omit.className, cssModule = _omit.cssModule, children = _omit.children, toolbar = _omit.toolbar, id = _omit.id, href = _omit.href, depth = _omit.depth, deprecated = _omit.deprecated, attributes = _objectWithoutProperties(_omit, ['className', 'cssModule', 'children', 'toolbar', 'id', 'href', 'depth', 'deprecated']); var headingLevel = Math.min(6, depth); return _react2.default.createElement( 'div', _extends({ className: (0, _lib2.default)((0, _classnames2.default)(className, 'rsg-section-heading'), cssModule) }, attributes), _react2.default.createElement( _Heading2.default, { level: headingLevel, id: id }, _react2.default.createElement( _A2.default, { className: 'section-name level-' + headingLevel + ' ' + (deprecated ? 'deprecated' : '') + ' d-flex justify-content-between', href: href }, _react2.default.createElement( 'div', { className: 'no-print' }, _react2.default.createElement(_Fa2.default, { className: 'anchor', link: true }) ), children ) ), _react2.default.createElement( 'div', { className: 'toolbar' }, toolbar ) ); }; SectionHeadingRendererUnstyled.defaultProps = defaultProps; SectionHeadingRendererUnstyled.propTypes = propTypes; var SectionHeadingRenderer = (0, _styledComponents2.default)(SectionHeadingRendererUnstyled)(_templateObject, function (props) { return '\n &.rsg-section-heading {\n display: ' + props.theme.styleguide['$rsg-section-heading-display'] + ';\n flex-direction: ' + props.theme.styleguide['$rsg-section-heading-flex-direction'] + ';\n align-items: ' + props.theme.styleguide['$rsg-section-heading-align-items'] + ';\n margin-bottom: ' + props.theme.styleguide['$rsg-section-heading-margin-bottom'] + ';\n & .section-name {\n ' + (0, _hover.hoverFocusActive)(props.theme['$enable-hover-media-query'], '\n isolation: ' + props.theme.styleguide['$rsg-section-heading-section-name-isolation'] + ';\n text-decoration: ' + props.theme.styleguide['$rsg-section-heading-section-name-text-decoration'] + ';\n cursor: ' + props.theme.styleguide['$rsg-section-heading-section-name-cursor'] + ';\n color: ' + props.theme.styleguide['$rsg-section-heading-section-name-color'] + ';\n .anchor {\n color: ' + props.theme.styleguide['$rsg-section-heading-section-name-color'] + ';\n }\n ') + '\n .anchor {\n font-size: ' + props.theme.styleguide['$rsg-section-heading-anchor-font-size'] + ';\n font-weight: ' + props.theme.styleguide['$rsg-section-heading-anchor-font-weight'] + ';\n transform: ' + props.theme.styleguide['$rsg-section-heading-anchor-transform'] + ';\n color: ' + props.theme.styleguide['$rsg-section-heading-anchor-color'] + ';\n padding: ' + props.theme.styleguide['$rsg-section-heading-anchor-padding'] + ';\n display: ' + props.theme.styleguide['$rsg-section-heading-anchor-display'] + ';\n vertical-align: ' + props.theme.styleguide['$rsg-section-heading-anchor-vertical-align'] + ';\n }\n }\n & .deprecated {\n cursor: ' + props.theme.styleguide['$rsg-section-heading-deprecated-cursor'] + ';\n &, &:hover {\n text-decoration: ' + props.theme.styleguide['$rsg-section-heading-deprecated-text-decoration'] + ';\n\n }\n }\n & .toolbar {\n margin-left: ' + props.theme.styleguide['$rsg-section-heading-toolbar-margin-left'] + ';\n }\n & .level-1 {\n color: ' + props.theme.styleguide['$rsg-section-heading-1-color'] + ';\n }\n & .level-2 {\n color: ' + props.theme.styleguide['$rsg-section-heading-2-color'] + ';\n }\n }\n '; }); SectionHeadingRenderer.defaultProps = defaultProps; SectionHeadingRenderer.propTypes = propTypes; exports.default = SectionHeadingRenderer;