UNPKG

apeman-react-head

Version:
229 lines (208 loc) 22.7 kB
/** * apeman react package for head component. * @class ApHead */ 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _stringify2 = require('babel-runtime/core-js/json/stringify'); var _stringify3 = _interopRequireDefault(_stringify2); var _keys = require('babel-runtime/core-js/object/keys'); var _keys2 = _interopRequireDefault(_keys); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _stringcase = require('stringcase'); var _stringcase2 = _interopRequireDefault(_stringcase); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } /** @lends ApHead */ var ApHead = _react2.default.createClass({ displayName: 'ApHead', // -------------------- // Specs // -------------------- propTypes: { /** CharSet */ charSet: _react.PropTypes.string, /** Document Title */ title: _react.PropTypes.string, /** Favicon */ icon: _react.PropTypes.string, /** Meta data */ meta: _react.PropTypes.oneOfType([_react.PropTypes.arrayOf(_react.PropTypes.object), _react.PropTypes.object]), /** Micro data settings */ itemProps: _react.PropTypes.oneOfType([_react.PropTypes.arrayOf(_react.PropTypes.object), _react.PropTypes.object]), /** CSS file urls */ css: _react.PropTypes.array, /** JS file urls */ js: _react.PropTypes.array, /** Version string */ version: _react.PropTypes.string, /** Query string key for version */ versionKey: _react.PropTypes.string, /** Global variables */ globals: _react.PropTypes.object, /** View port settings */ viewPort: _react.PropTypes.object, /** Base url */ base: _react.PropTypes.string, /** Target of base url. '_blank', '_parent', '_self', '_top' or frame name */ baseTarget: _react.PropTypes.string, /** Path of manifest.json */ manifest: _react.PropTypes.string, /** Theme color */ color: _react.PropTypes.string }, mixins: [], statics: { renderBase: function renderBase(base, target) { if (!base) { return null; } return _react2.default.createElement('base', { href: base, target: target }); }, renderCharset: function renderCharset(charSet) { if (!charSet) { return null; } return _react2.default.createElement('meta', { className: 'ap-head-meta', charSet: charSet }); }, renderTitle: function renderTitle(title) { if (!title) { return null; } return _react2.default.createElement( 'title', { className: 'ap-head-title' }, title ); }, renderIcon: function renderIcon(url, query) { if (!url) { return null; } return _react2.default.createElement('link', { rel: 'icon', href: ApHead._addQuery(url, query) }); }, renderMetaValues: function renderMetaValues(values) { if (!values) { return null; } return [].concat(values).map(function (values, i) { return (0, _keys2.default)(values).map(function (name, j) { return _react2.default.createElement('meta', { name: name, content: values[name], key: 'meta-' + i + '-' + j }); }); }).reduce(function (a, b) { return [].concat(a, b); }, []); }, renderItemProps: function renderItemProps(values) { if (!values) { return null; } return [].concat(values).map(function (values, i) { return (0, _keys2.default)(values).map(function (name, j) { return _react2.default.createElement('meta', { itemProp: name, content: values[name], key: 'item-prop' + i + '-' + j }); }); }).reduce(function (a, b) { return [].concat(a, b); }, []); }, renderCss: function renderCss(urls, query) { if (!urls) { return null; } return [].concat(urls).map(function (url, i) { return _react2.default.createElement('link', { rel: 'stylesheet', type: 'text/css', key: 'css-' + i + '-' + url, href: ApHead._addQuery(url, query) }); }); }, renderJs: function renderJs(urls, query) { if (!urls) { return null; } return [].concat(urls).map(function (url, i) { return _react2.default.createElement('script', { type: 'text/javascript', key: 'js-' + i + '-' + url, src: ApHead._addQuery(url, query) }); }); }, renderGlobals: function renderGlobals(values) { var _stringify = function _stringify(data) { return data ? (0, _stringify3.default)(data || {}) : 'null'; }; return (0, _keys2.default)(values || {}).map(function (key, i) { return _react2.default.createElement('script', { type: 'text/javascript', key: 'global-' + i + '-' + key, dangerouslySetInnerHTML: { __html: 'window.' + key + '=' + _stringify(values[key]) } }); }); }, renderViewPort: function renderViewPort(values) { var content = (0, _keys2.default)(values || {}).map(function (key) { return [_stringcase2.default.spinalcase(key), values[key]].join('='); }).join(','); return _react2.default.createElement('meta', { name: 'viewport', content: content }); }, renderManifest: function renderManifest(value) { if (!value) { return null; } return _react2.default.createElement('link', { rel: 'manifest', href: value }); }, renderThemeColor: function renderThemeColor(value) { if (!value) { return null; } return _react2.default.createElement('meta', { name: 'theme-color', content: value }); }, _addQuery: function _addQuery(url, query) { var joiner = /\?/.test(url) ? '&' : '?'; return [url, query].join(joiner); } }, getInitialState: function getInitialState() { return {}; }, getDefaultProps: function getDefaultProps() { return { charSet: 'utf-8', version: 'unknown', versionKey: 'v', viewPort: { width: 'device-width', initialScale: '1.0' }, base: null, baseTarget: undefined }; }, render: function render() { var s = this; var props = s.props; var query = [props.versionKey, props.version].join('='); return _react2.default.createElement( 'head', { className: 'ap-head' }, ApHead.renderBase(props.base, props.baseTarget), ApHead.renderCharset(props.charSet), ApHead.renderTitle(props.title), ApHead.renderMetaValues(props.meta), ApHead.renderItemProps(props.itemProps), ApHead.renderIcon(props.icon, query), ApHead.renderGlobals(props.globals), ApHead.renderCss(props.css, query), ApHead.renderViewPort(props.viewPort), ApHead.renderManifest(props.manifest), ApHead.renderThemeColor(props.color), ApHead.renderJs(props.js, query), props.children ); } }); exports.default = ApHead; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["ap_head.jsx"],"names":["ApHead","createClass","propTypes","charSet","string","title","icon","meta","oneOfType","arrayOf","object","itemProps","css","array","js","version","versionKey","globals","viewPort","base","baseTarget","manifest","color","mixins","statics","renderBase","target","renderCharset","renderTitle","renderIcon","url","query","_addQuery","renderMetaValues","values","concat","map","i","name","j","reduce","a","b","renderItemProps","renderCss","urls","renderJs","renderGlobals","_stringify","data","key","__html","renderViewPort","content","spinalcase","join","renderManifest","value","renderThemeColor","joiner","test","getInitialState","getDefaultProps","width","initialScale","undefined","render","s","props","children"],"mappings":"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","file":"ap_head.jsx","sourceRoot":"lib","sourcesContent":["/**\n * apeman react package for head component.\n * @class ApHead\n */\n\n'use strict'\n\nimport React, { PropTypes as types } from 'react'\nimport stringcase from 'stringcase'\n\n/** @lends ApHead */\nconst ApHead = React.createClass({\n  // --------------------\n  // Specs\n  // --------------------\n\n  propTypes: {\n    /** CharSet */\n    charSet: types.string,\n    /** Document Title */\n    title: types.string,\n    /** Favicon */\n    icon: types.string,\n    /** Meta data */\n    meta: types.oneOfType([\n      types.arrayOf(types.object),\n      types.object\n    ]),\n    /** Micro data settings */\n    itemProps: types.oneOfType([\n      types.arrayOf(types.object),\n      types.object\n    ]),\n    /** CSS file urls */\n    css: types.array,\n    /** JS file urls */\n    js: types.array,\n    /** Version string */\n    version: types.string,\n    /** Query string key for version */\n    versionKey: types.string,\n    /** Global variables */\n    globals: types.object,\n    /** View port settings */\n    viewPort: types.object,\n    /** Base url */\n    base: types.string,\n    /** Target of base url. '_blank', '_parent', '_self', '_top' or frame name */\n    baseTarget: types.string,\n    /** Path of manifest.json */\n    manifest: types.string,\n    /** Theme color */\n    color: types.string\n  },\n\n  mixins: [],\n\n  statics: {\n    renderBase (base, target) {\n      if (!base) {\n        return null\n      }\n      return (\n        <base href={ base } target={ target }/>\n      )\n    },\n    renderCharset (charSet) {\n      if (!charSet) {\n        return null\n      }\n      return (\n        <meta className='ap-head-meta' charSet={ charSet }/>\n      )\n    },\n    renderTitle (title) {\n      if (!title) {\n        return null\n      }\n      return (\n        <title className='ap-head-title'>{ title }</title>\n      )\n    },\n    renderIcon (url, query) {\n      if (!url) {\n        return null\n      }\n      return (\n        <link rel='icon' href={ ApHead._addQuery(url, query) }/>\n      )\n    },\n    renderMetaValues (values) {\n      if (!values) {\n        return null\n      }\n      return [].concat(values).map((values, i) =>\n        Object.keys(values).map((name, j) =>\n          <meta name={ name }\n                content={ values[ name ] }\n                key={ `meta-${i}-${j}` }/>\n        )\n      ).reduce((a, b) => [].concat(a, b), [])\n    },\n    renderItemProps (values) {\n      if (!values) {\n        return null\n      }\n      return [].concat(values).map((values, i) =>\n        Object.keys(values).map((name, j) =>\n          <meta itemProp={ name }\n                content={ values[ name ] }\n                key={ `item-prop${i}-${j}` }/>\n        )\n      ).reduce((a, b) => [].concat(a, b), [])\n    },\n    renderCss (urls, query) {\n      if (!urls) {\n        return null\n      }\n      return [].concat(urls).map((url, i) =>\n        <link rel='stylesheet'\n              type='text/css'\n              key={ `css-${i}-${url}` }\n              href={ ApHead._addQuery(url, query) }/>\n      )\n    },\n    renderJs (urls, query) {\n      if (!urls) {\n        return null\n      }\n      return [].concat(urls).map((url, i) =>\n        <script type='text/javascript'\n                key={ `js-${i}-${url}` }\n                src={ ApHead._addQuery(url, query)}></script>\n      )\n    },\n    renderGlobals (values) {\n      let _stringify = (data) => data ? JSON.stringify(data || {}) : 'null'\n\n      return Object.keys(values || {}).map((key, i) =>\n        <script type='text/javascript'\n                key={ `global-${i}-${key}` }\n                dangerouslySetInnerHTML={\n                  { __html: `window.${key}=${_stringify(values[ key ])}` }\n                }></script>\n      )\n    },\n    renderViewPort (values) {\n      let content = Object.keys(values || {}).map((key) =>\n        [ stringcase.spinalcase(key), values[ key ] ].join('=')\n      ).join(',')\n      return <meta name='viewport' content={ content }/>\n    },\n    renderManifest (value) {\n      if (!value) {\n        return null\n      }\n      return <link rel='manifest' href={ value }/>\n    },\n    renderThemeColor (value) {\n      if (!value) {\n        return null\n      }\n      return <meta name='theme-color' content={ value }/>\n    },\n    _addQuery (url, query) {\n      let joiner = /\\?/.test(url) ? '&' : '?'\n      return [ url, query ].join(joiner)\n    }\n  },\n\n  getInitialState () {\n    return {}\n  },\n\n  getDefaultProps () {\n    return {\n      charSet: 'utf-8',\n      version: 'unknown',\n      versionKey: 'v',\n      viewPort: {\n        width: 'device-width',\n        initialScale: '1.0'\n      },\n      base: null,\n      baseTarget: undefined\n    }\n  },\n\n  render () {\n    const s = this\n    let { props } = s\n\n    let query = [ props.versionKey, props.version ].join('=')\n    return (\n      <head className='ap-head'>\n        { ApHead.renderBase(props.base, props.baseTarget) }\n        { ApHead.renderCharset(props.charSet) }\n        { ApHead.renderTitle(props.title) }\n        { ApHead.renderMetaValues(props.meta) }\n        { ApHead.renderItemProps(props.itemProps) }\n        { ApHead.renderIcon(props.icon, query) }\n        { ApHead.renderGlobals(props.globals) }\n        { ApHead.renderCss(props.css, query) }\n        { ApHead.renderViewPort(props.viewPort) }\n        { ApHead.renderManifest(props.manifest) }\n        { ApHead.renderThemeColor(props.color) }\n        { ApHead.renderJs(props.js, query) }\n        { props.children }\n      </head>\n    )\n  }\n})\n\nexport default ApHead\n"]}