UNPKG

apeman-react-head

Version:
189 lines (172 loc) 17.7 kB
/** * apeman react package for head component. * @class ApHead */ 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); 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, /** Querystring key for version */ versionKey: _react.PropTypes.string, /** Global variables */ globals: _react.PropTypes.object, /** View port settings */ viewport: _react.PropTypes.object }, mixins: [], statics: { 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 Object.keys(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 Object.keys(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 ? JSON.stringify(data || {}) : "null"; }; return Object.keys(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 = Object.keys(values || {}).map(function (key) { return [_stringcase2.default.spinalcase(key), values[key]].join('='); }).join(','); return _react2.default.createElement('meta', { name: 'viewport', content: content }); }, _addQuery: function _addQuery(url, query) { var joiner = /\?/.test(url) ? '&' : '?'; return [url, query].join(joiner); } }, getInitialState: function getInitialState() { return {}; }, getDefaultProps: function getDefaultProps() { return { version: 'unknown', versionKey: 'v', viewport: { width: 'device-width', initialScale: '1.0' } }; }, 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.renderCharset(props.charset), ApHead.renderTitle(props.title), ApHead.renderMetaValues(props.meta), ApHead.renderItemProps(props.itemProps), ApHead.renderIcon(props.icon, query), ApHead.renderJs(props.js, query), ApHead.renderCss(props.css, query), ApHead.renderGlobals(props.globals), ApHead.renderViewPort(props.viewport), props.children ); } }); exports.default = ApHead; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["ap_head.jsx"],"names":[],"mappings":"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","file":"ap_head.js","sourceRoot":"/Users/okunishinishi/Projects/apeman-projects/apeman-react-head/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    /** Querystring key for version */\n    versionKey: types.string,\n    /** Global variables */\n    globals: types.object,\n    /** View port settings */\n    viewport: types.object\n  },\n\n  mixins: [],\n\n  statics: {\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    _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      version: 'unknown',\n      versionKey: 'v',\n      viewport: {\n        width: 'device-width',\n        initialScale: '1.0'\n      }\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.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.renderJs(props.js, query) }\n        { ApHead.renderCss(props.css, query) }\n        { ApHead.renderGlobals(props.globals) }\n        { ApHead.renderViewPort(props.viewport) }\n        { props.children }\n      </head>\n    )\n  }\n})\n\nexport default ApHead\n"]}