UNPKG

patternplate-client

Version:

Universal javascript client application for patternplate

161 lines (123 loc) 12.5 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _objectWithoutProperties2 = require('babel-runtime/helpers/objectWithoutProperties'); var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2); var _keys = require('babel-runtime/core-js/object/keys'); var _keys2 = _interopRequireDefault(_keys); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _lodash = require('lodash'); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _reactDom = require('react-dom'); var _reactDom2 = _interopRequireDefault(_reactDom); var _reactSideEffect = require('react-side-effect'); var _reactSideEffect2 = _interopRequireDefault(_reactSideEffect); var _icons = require('./icons'); var _icons2 = _interopRequireDefault(_icons); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var iconNames = (0, _keys2.default)(_icons2.default); exports.default = (0, _reactSideEffect2.default)(toState, onChange)(Icon); function toState(propsList) { var list = propsList.map(function (item) { return item.symbol; }).sort(); var symbols = (0, _lodash.uniq)(list); return _react2.default.createElement(IconRegistry, { symbols: symbols }); } function onChange(registry) { var element = getRegistryMountPoint(); _reactDom2.default.render(registry, element); } function getRegistryMountPoint() { var _global = global, document = _global.document; var found = document.querySelector('[data-icon-registry]'); if (found) { return found; } var created = document.createElement('div'); created.setAttribute('data-icon-registry', true); document.body.appendChild(created); return created; } function Icon(props) { var className = (0, _classnames2.default)('icon', props.className, { 'icon--has-description': props.description }); var textStyle = { display: props.fallback ? 'none' : null }; var xlinkHref = '#' + props.symbol; return _react2.default.createElement( 'div', { className: className, style: props.style }, _react2.default.createElement( 'div', { className: 'svg-icon' }, _react2.default.createElement( 'svg', { className: 'svg' }, _react2.default.createElement('use', { xlinkHref: xlinkHref }) ) ), _react2.default.createElement( 'div', { className: 'svg-text', style: textStyle }, props.children ), props.description && _react2.default.createElement( 'small', { className: 'icon__description' }, props.description ) ); } Icon.defaultProps = { fallback: true }; var hiddenStyles = { position: 'fixed', height: 0, width: 0, overflow: 'hidden', padding: 0, visibility: 'hidden' }; function IconRegistry(props) { return _react2.default.createElement( 'svg', { style: hiddenStyles }, props.symbols.map(function (symbol) { var creator = _icons2.default[symbol] || _lodash.noop; var paths = creator() || []; return _react2.default.createElement(_Symbol, { id: symbol, key: symbol, definition: paths }); }) ); } IconRegistry.defaultProps = { symbols: [] }; function _Symbol(props) { var paths = Array.isArray(props.definition) ? props.definition : [props.definition]; return _react2.default.createElement( 'symbol', { id: props.id, viewBox: '0 0 24 24' }, paths.map(function (path) { return _react2.default.createElement(Path, { definition: path, key: path }); }) ); } function Path(props) { var definition = props.definition; var def = typeof definition === 'string' ? { d: definition } : definition; var tagName = def.tagName, p = (0, _objectWithoutProperties3.default)(def, ['tagName']); var Component = tagName || 'path'; return _react2.default.createElement(Component, p); } module.exports = exports['default']; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../source/application/components/common/icon.js"],"names":["iconNames","toState","onChange","Icon","propsList","list","map","item","symbol","sort","symbols","registry","element","getRegistryMountPoint","render","global","document","found","querySelector","created","createElement","setAttribute","body","appendChild","props","className","description","textStyle","display","fallback","xlinkHref","style","children","defaultProps","hiddenStyles","position","height","width","overflow","padding","visibility","IconRegistry","creator","paths","Symbol","Array","isArray","definition","id","path","Path","def","d","tagName","p","Component"],"mappings":"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","file":"icon.js","sourcesContent":["import join from 'classnames';\nimport {noop, uniq} from 'lodash';\nimport React, {PropTypes as t} from 'react';\nimport ReactDOM from 'react-dom';\nimport withSideEffect from 'react-side-effect';\nimport icons from './icons';\n\nconst iconNames = Object.keys(icons);\n\nexport default withSideEffect(toState, onChange)(Icon);\n\nfunction toState(propsList) {\n\tconst list = propsList\n\t\t.map(item => item.symbol)\n\t\t.sort();\n\tconst symbols = uniq(list);\n\treturn <IconRegistry symbols={symbols}/>;\n}\n\nfunction onChange(registry) {\n\tconst element = getRegistryMountPoint();\n\tReactDOM.render(registry, element);\n}\n\nfunction getRegistryMountPoint() {\n\tconst {document} = global;\n\tconst found = document.querySelector('[data-icon-registry]');\n\tif (found) {\n\t\treturn found;\n\t}\n\n\tconst created = document.createElement('div');\n\tcreated.setAttribute('data-icon-registry', true);\n\tdocument.body.appendChild(created);\n\treturn created;\n}\n\nfunction Icon(props) {\n\tconst className = join('icon', props.className, {\n\t\t'icon--has-description': props.description\n\t});\n\n\tconst textStyle = {display: props.fallback ? 'none' : null};\n\tconst xlinkHref = `#${props.symbol}`;\n\n\treturn (\n\t\t<div className={className} style={props.style}>\n\t\t\t<div className=\"svg-icon\">\n\t\t\t{\n\t\t\t\t<svg className=\"svg\">\n\t\t\t\t\t<use xlinkHref={xlinkHref}/>\n\t\t\t\t</svg>\n\t\t\t}\n\t\t\t</div>\n\t\t\t<div className=\"svg-text\" style={textStyle}>\n\t\t\t\t{props.children}\n\t\t\t</div>\n\t\t\t{\n\t\t\t\tprops.description &&\n\t\t\t\t\t<small className=\"icon__description\">\n\t\t\t\t\t\t{props.description}\n\t\t\t\t\t</small>\n\t\t\t}\n\t\t</div>\n\t);\n}\n\nIcon.propTypes = {\n\tsymbol: t.oneOf(iconNames).isRequired,\n\tclassName: t.string,\n\tfallback: t.bool.isRequired,\n\tchildren: t.any,\n\tdescription: t.string,\n\tstyle: t.object\n};\n\nIcon.defaultProps = {\n\tfallback: true\n};\n\nconst hiddenStyles = {\n\tposition: 'fixed',\n\theight: 0,\n\twidth: 0,\n\toverflow: 'hidden',\n\tpadding: 0,\n\tvisibility: 'hidden'\n};\n\nfunction IconRegistry(props) {\n\treturn (\n\t\t<svg style={hiddenStyles}>\n\t\t\t{\n\t\t\t\tprops.symbols\n\t\t\t\t\t.map(symbol => {\n\t\t\t\t\t\tconst creator = icons[symbol] || noop;\n\t\t\t\t\t\tconst paths = creator() || [];\n\t\t\t\t\t\treturn <Symbol id={symbol} key={symbol} definition={paths}/>;\n\t\t\t\t\t})\n\t\t\t}\n\t\t</svg>\n\t);\n}\n\nIconRegistry.propTypes = {\n\tsymbols: t.arrayOf(t.oneOf(iconNames)).isRequired\n};\n\nIconRegistry.defaultProps = {\n\tsymbols: []\n};\n\nfunction Symbol(props) {\n\tconst paths = Array.isArray(props.definition) ?\n\t\tprops.definition :\n\t\t[props.definition];\n\n\treturn (\n\t\t<symbol\n\t\t\tid={props.id}\n\t\t\tviewBox=\"0 0 24 24\"\n\t\t\t>\n\t\t\t{\n\t\t\t\tpaths.map(path => <Path definition={path} key={path}/>)\n\t\t\t}\n\t\t</symbol>\n\t);\n}\n\nSymbol.propTypes = {\n\tdefinition: t.oneOfType([t.string, t.object, t.array]).isRequired,\n\tid: t.string.isRequired\n};\n\nfunction Path(props) {\n\tconst {definition} = props;\n\tconst def = typeof definition === 'string' ? {d: definition} : definition;\n\tconst {tagName, ...p} = def;\n\tconst Component = tagName || 'path';\n\treturn <Component {...p}/>;\n}\n\nPath.propTypes = {\n\tdefinition: t.oneOfType([t.string, t.object]).isRequired\n};\n"]}