apeman-react-head
Version:
apeman react package for head component.
229 lines (208 loc) • 22.7 kB
JavaScript
/**
* 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"]}