apeman-react-head
Version:
apeman react package for head component.
189 lines (172 loc) • 17.7 kB
JavaScript
/**
* 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":";;;;;AAKA;;;;;;AAEA;;;;AACA;;;;;;;AAGA,IAAM,SAAS,gBAAM,WAAN,CAAkB;AAAA;;;;;;AAK/B,aAAW;;AAET,aAAS,iBAAM,MAFN;;AAIT,WAAO,iBAAM,MAJJ;;AAMT,UAAM,iBAAM,MANH;;AAQT,UAAM,iBAAM,SAAN,CAAgB,CACpB,iBAAM,OAAN,CAAc,iBAAM,MAApB,CADoB,EAEpB,iBAAM,MAFc,CAAhB,CARG;;AAaT,eAAW,iBAAM,SAAN,CAAgB,CACzB,iBAAM,OAAN,CAAc,iBAAM,MAApB,CADyB,EAEzB,iBAAM,MAFmB,CAAhB,CAbF;;AAkBT,SAAK,iBAAM,KAlBF;;AAoBT,QAAI,iBAAM,KApBD;;AAsBT,aAAS,iBAAM,MAtBN;;AAwBT,gBAAY,iBAAM,MAxBT;;AA0BT,aAAS,iBAAM,MA1BN;;AA4BT,cAAU,iBAAM;AA5BP,GALoB;;AAoC/B,UAAQ,EApCuB;;AAsC/B,WAAS;AACP,iBADO,yBACQ,OADR,EACiB;AACtB,UAAI,CAAC,OAAL,EAAc;AACZ,eAAO,IAAP;AACD;AACD,aACE,wCAAM,WAAU,cAAhB,EAA+B,SAAS,OAAxC,GADF;AAGD,KARM;AASP,eATO,uBASM,KATN,EASa;AAClB,UAAI,CAAC,KAAL,EAAY;AACV,eAAO,IAAP;AACD;AACD,aACE;AAAA;QAAA,EAAO,WAAU,eAAjB;QAAkC;AAAlC,OADF;AAGD,KAhBM;AAiBP,cAjBO,sBAiBK,GAjBL,EAiBU,KAjBV,EAiBiB;AACtB,UAAI,CAAC,GAAL,EAAU;AACR,eAAO,IAAP;AACD;AACD,aACE,wCAAM,KAAI,MAAV,EAAiB,MAAO,OAAO,SAAP,CAAiB,GAAjB,EAAsB,KAAtB,CAAxB,GADF;AAGD,KAxBM;AAyBP,oBAzBO,4BAyBW,MAzBX,EAyBmB;AACxB,UAAI,CAAC,MAAL,EAAa;AACX,eAAO,IAAP;AACD;AACD,aAAO,GAAG,MAAH,CAAU,MAAV,EAAkB,GAAlB,CAAsB,UAAC,MAAD,EAAS,CAAT;AAAA,eAC3B,OAAO,IAAP,CAAY,MAAZ,EAAoB,GAApB,CAAwB,UAAC,IAAD,EAAO,CAAP;AAAA,iBACtB,wCAAM,MAAO,IAAb;AACM,qBAAU,OAAO,IAAP,CADhB;AAEM,2BAAc,CAAd,SAAmB,CAFzB,GADsB;AAAA,SAAxB,CAD2B;AAAA,OAAtB,EAML,MANK,CAME,UAAC,CAAD,EAAI,CAAJ;AAAA,eAAU,GAAG,MAAH,CAAU,CAAV,EAAa,CAAb,CAAV;AAAA,OANF,EAM6B,EAN7B,CAAP;AAOD,KApCM;AAqCP,mBArCO,2BAqCU,MArCV,EAqCkB;AACvB,UAAI,CAAC,MAAL,EAAa;AACX,eAAO,IAAP;AACD;AACD,aAAO,GAAG,MAAH,CAAU,MAAV,EAAkB,GAAlB,CAAsB,UAAC,MAAD,EAAS,CAAT;AAAA,eAC3B,OAAO,IAAP,CAAY,MAAZ,EAAoB,GAApB,CAAwB,UAAC,IAAD,EAAO,CAAP;AAAA,iBACtB,wCAAM,UAAW,IAAjB;AACM,qBAAU,OAAO,IAAP,CADhB;AAEM,+BAAkB,CAAlB,SAAuB,CAF7B,GADsB;AAAA,SAAxB,CAD2B;AAAA,OAAtB,EAML,MANK,CAME,UAAC,CAAD,EAAI,CAAJ;AAAA,eAAU,GAAG,MAAH,CAAU,CAAV,EAAa,CAAb,CAAV;AAAA,OANF,EAM6B,EAN7B,CAAP;AAOD,KAhDM;AAiDP,aAjDO,qBAiDI,IAjDJ,EAiDU,KAjDV,EAiDiB;AACtB,UAAI,CAAC,IAAL,EAAW;AACT,eAAO,IAAP;AACD;AACD,aAAO,GAAG,MAAH,CAAU,IAAV,EAAgB,GAAhB,CAAoB,UAAC,GAAD,EAAM,CAAN;AAAA,eACzB,wCAAM,KAAI,YAAV;AACM,gBAAK,UADX;AAEM,wBAAa,CAAb,SAAkB,GAFxB;AAGM,gBAAO,OAAO,SAAP,CAAiB,GAAjB,EAAsB,KAAtB,CAHb,GADyB;AAAA,OAApB,CAAP;AAMD,KA3DM;AA4DP,YA5DO,oBA4DG,IA5DH,EA4DS,KA5DT,EA4DgB;AACrB,UAAI,CAAC,IAAL,EAAW;AACT,eAAO,IAAP;AACD;AACD,aAAO,GAAG,MAAH,CAAU,IAAV,EAAgB,GAAhB,CAAoB,UAAC,GAAD,EAAM,CAAN;AAAA,eACzB,0CAAQ,MAAK,iBAAb;AACQ,uBAAY,CAAZ,SAAiB,GADzB;AAEQ,eAAM,OAAO,SAAP,CAAiB,GAAjB,EAAqB,KAArB,CAFd,GADyB;AAAA,OAApB,CAAP;AAKD,KArEM;AAsEP,iBAtEO,yBAsEQ,MAtER,EAsEgB;AACrB,UAAI,aAAa,SAAb,UAAa,CAAC,IAAD;AAAA,eAAU,OAAO,KAAK,SAAL,CAAe,QAAQ,EAAvB,CAAP,GAAoC,MAA9C;AAAA,OAAjB;;AAEA,aAAO,OAAO,IAAP,CAAY,UAAU,EAAtB,EAA0B,GAA1B,CAA8B,UAAC,GAAD,EAAM,CAAN;AAAA,eACnC,0CAAQ,MAAK,iBAAb;AACQ,2BAAgB,CAAhB,SAAqB,GAD7B;AAEQ,mCACI,EAAC,oBAAkB,GAAlB,SAAyB,WAAW,OAAO,GAAP,CAAX,CAA1B,EAHZ,GADmC;AAAA,OAA9B,CAAP;AAOD,KAhFM;AAiFP,kBAjFO,0BAiFS,MAjFT,EAiFiB;AACtB,UAAI,UAAU,OAAO,IAAP,CAAY,UAAU,EAAtB,EAA0B,GAA1B,CAA8B,UAAC,GAAD;AAAA,eAC1C,CAAE,qBAAW,UAAX,CAAsB,GAAtB,CAAF,EAA8B,OAAQ,GAAR,CAA9B,EAA8C,IAA9C,CAAmD,GAAnD,CAD0C;AAAA,OAA9B,EAEZ,IAFY,CAEP,GAFO,CAAd;AAGA,aAAO,wCAAM,MAAK,UAAX,EAAsB,SAAU,OAAhC,GAAP;AACD,KAtFM;AAuFP,aAvFO,qBAuFI,GAvFJ,EAuFS,KAvFT,EAuFgB;AACrB,UAAI,SAAS,KAAK,IAAL,CAAU,GAAV,IAAiB,GAAjB,GAAuB,GAApC;AACA,aAAO,CAAE,GAAF,EAAO,KAAP,EAAe,IAAf,CAAoB,MAApB,CAAP;AACD;AA1FM,GAtCsB;;AAmI/B,iBAnI+B,6BAmIZ;AACjB,WAAO,EAAP;AACD,GArI8B;AAuI/B,iBAvI+B,6BAuIZ;AACjB,WAAO;AACL,eAAS,SADJ;AAEL,kBAAY,GAFP;AAGL,gBAAU;AACR,eAAO,cADC;AAER,sBAAc;AAFN;AAHL,KAAP;AAQD,GAhJ8B;AAkJ/B,QAlJ+B,oBAkJrB;AACR,QAAM,IAAI,IAAV;AADQ,QAEF,KAFE,GAEQ,CAFR,CAEF,KAFE;;;AAIR,QAAI,QAAQ,CAAE,MAAM,UAAR,EAAoB,MAAM,OAA1B,EAAoC,IAApC,CAAyC,GAAzC,CAAZ;AACA,WACE;AAAA;MAAA,EAAM,WAAU,SAAhB;MACI,OAAO,aAAP,CAAqB,MAAM,OAA3B,CADJ;MAEI,OAAO,WAAP,CAAmB,MAAM,KAAzB,CAFJ;MAGI,OAAO,gBAAP,CAAwB,MAAM,IAA9B,CAHJ;MAII,OAAO,eAAP,CAAuB,MAAM,SAA7B,CAJJ;MAKI,OAAO,UAAP,CAAkB,MAAM,IAAxB,EAA8B,KAA9B,CALJ;MAMI,OAAO,QAAP,CAAgB,MAAM,EAAtB,EAA0B,KAA1B,CANJ;MAOI,OAAO,SAAP,CAAiB,MAAM,GAAvB,EAA4B,KAA5B,CAPJ;MAQI,OAAO,aAAP,CAAqB,MAAM,OAA3B,CARJ;MASI,OAAO,cAAP,CAAsB,MAAM,QAA5B,CATJ;MAUI,MAAM;AAVV,KADF;AAcD;AArK8B,CAAlB,CAAf;;kBAwKe,M","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"]}