react-static
Version:
A progressive static site generator for React
155 lines (129 loc) • 16.9 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = makeHeadWithMeta;
exports.InlineStyle = void 0;
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _react = _interopRequireDefault(require("react"));
var _utils = require("../../utils");
var _plugins = _interopRequireDefault(require("../plugins"));
//
// import packagejson from '../../../package.json'
// const { version } = packagejson
var REGEX_FOR_STYLE_TAG = /<style>|<\/style>/gi;
var InlineStyle = function InlineStyle(_ref) {
var clientCss = _ref.clientCss;
return /*#__PURE__*/_react["default"].createElement("style", {
key: "clientCss",
type: "text/css",
dangerouslySetInnerHTML: {
__html: clientCss.toString().replace(REGEX_FOR_STYLE_TAG, '')
}
});
};
exports.InlineStyle = InlineStyle;
function makeHeadWithMeta(_x) {
return _makeHeadWithMeta.apply(this, arguments);
}
function _makeHeadWithMeta() {
_makeHeadWithMeta = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(state) {
var head, route, clientScripts, config, clientStyleSheets, clientCss, pluginHeads;
return _regenerator["default"].wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
head = state.head, route = state.route, clientScripts = state.clientScripts, config = state.config, clientStyleSheets = state.clientStyleSheets, clientCss = state.clientCss;
_context.next = 3;
return _plugins["default"].headElements([], state);
case 3:
pluginHeads = _context.sent;
return _context.abrupt("return", function (_ref2) {
var children = _ref2.children,
rest = (0, _objectWithoutProperties2["default"])(_ref2, ["children"]);
var renderLinkCSS = !route.redirect && !config.inlineCss;
var useHelmetTitle = head.title && head.title[0] && head.title[0].props.children !== '';
var childrenArray = _react["default"].Children.toArray(children);
if (useHelmetTitle) {
head.title[0] = /*#__PURE__*/_react["default"].cloneElement(head.title[0], {
key: 'title'
});
childrenArray = childrenArray.filter(function (child) {
if (child.type === 'title') {
// Filter out the title of the Document in static.config.js
// if there is a helmet title on this route
return false;
}
return true;
});
}
var childrenCSS = childrenArray.filter(function (child) {
if (child.type === 'link' && child.props && child.props.rel === 'stylesheet') {
return true;
}
if (child.type === 'style') {
return true;
}
return false;
});
var childrenMeta = childrenArray.filter(function (child) {
return child.type === 'meta';
});
var childrenJS = childrenArray.filter(function (child) {
return child.type === 'script';
});
childrenArray = childrenArray.filter(function (child) {
if (child.type === 'link' && child.props && child.props.rel === 'stylesheet') {
return false;
}
if (child.type === 'style') {
return false;
}
if (child.type === 'script') {
return false;
}
if (child.type === 'meta') {
return false;
}
return true;
});
return /*#__PURE__*/_react["default"].createElement("head", rest, /*#__PURE__*/_react["default"].createElement("meta", {
name: "generator",
content: "React Static"
}), head.base, useHelmetTitle && head.title, childrenMeta, head.meta, childrenJS, !route.redirect && clientScripts.map(function (script) {
return /*#__PURE__*/_react["default"].createElement("link", {
key: "clientScript_".concat(script),
rel: "preload",
as: "script",
href: (0, _utils.makePathAbsolute)((0, _utils.pathJoin)(process.env.REACT_STATIC_ASSETS_PATH, script))
});
}), childrenCSS, renderLinkCSS && clientStyleSheets.reduce(function (memo, styleSheet) {
var href = (0, _utils.makePathAbsolute)((0, _utils.pathJoin)(process.env.REACT_STATIC_ASSETS_PATH, styleSheet));
return [].concat((0, _toConsumableArray2["default"])(memo), [/*#__PURE__*/_react["default"].createElement("link", {
key: "clientStyleSheetPreload_".concat(styleSheet),
rel: "preload",
as: "style",
href: href
}), /*#__PURE__*/_react["default"].createElement("link", {
key: "clientStyleSheet_".concat(styleSheet),
rel: "stylesheet",
href: href
})]);
}, []), head.link, head.noscript, head.script, config.inlineCss && /*#__PURE__*/_react["default"].createElement(InlineStyle, {
clientCss: clientCss
}), head.style, pluginHeads, childrenArray);
});
case 5:
case "end":
return _context.stop();
}
}
}, _callee);
}));
return _makeHeadWithMeta.apply(this, arguments);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/static/components/HeadWithMeta.js"],"names":["REGEX_FOR_STYLE_TAG","InlineStyle","clientCss","__html","toString","replace","makeHeadWithMeta","state","head","route","clientScripts","config","clientStyleSheets","plugins","headElements","pluginHeads","children","rest","renderLinkCSS","redirect","inlineCss","useHelmetTitle","title","props","childrenArray","React","Children","toArray","cloneElement","key","filter","child","type","childrenCSS","rel","childrenMeta","childrenJS","base","meta","map","script","process","env","REACT_STATIC_ASSETS_PATH","reduce","memo","styleSheet","href","link","noscript","style"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;;AAEA;;AACA;;AAFA;AAGA;AAEA;AAEA,IAAMA,mBAAmB,GAAG,qBAA5B;;AAEO,IAAMC,WAAW,GAAG,SAAdA,WAAc;AAAA,MAAGC,SAAH,QAAGA,SAAH;AAAA,sBACzB;AACE,IAAA,GAAG,EAAC,WADN;AAEE,IAAA,IAAI,EAAC,UAFP;AAGE,IAAA,uBAAuB,EAAE;AACvBC,MAAAA,MAAM,EAAED,SAAS,CAACE,QAAV,GAAqBC,OAArB,CAA6BL,mBAA7B,EAAkD,EAAlD;AADe;AAH3B,IADyB;AAAA,CAApB;;;;SAUuBM,gB;;;;;oGAAf,iBAAgCC,KAAhC;AAAA;AAAA;AAAA;AAAA;AAAA;AAEXC,YAAAA,IAFW,GAQTD,KARS,CAEXC,IAFW,EAGXC,KAHW,GAQTF,KARS,CAGXE,KAHW,EAIXC,aAJW,GAQTH,KARS,CAIXG,aAJW,EAKXC,MALW,GAQTJ,KARS,CAKXI,MALW,EAMXC,iBANW,GAQTL,KARS,CAMXK,iBANW,EAOXV,SAPW,GAQTK,KARS,CAOXL,SAPW;AAAA;AAAA,mBAUaW,oBAAQC,YAAR,CAAqB,EAArB,EAAyBP,KAAzB,CAVb;;AAAA;AAUPQ,YAAAA,WAVO;AAAA,6CAYN,iBAA2B;AAAA,kBAAxBC,QAAwB,SAAxBA,QAAwB;AAAA,kBAAXC,IAAW;AAChC,kBAAMC,aAAa,GAAG,CAACT,KAAK,CAACU,QAAP,IAAmB,CAACR,MAAM,CAACS,SAAjD;AAEA,kBAAMC,cAAc,GAClBb,IAAI,CAACc,KAAL,IAAcd,IAAI,CAACc,KAAL,CAAW,CAAX,CAAd,IAA+Bd,IAAI,CAACc,KAAL,CAAW,CAAX,EAAcC,KAAd,CAAoBP,QAApB,KAAiC,EADlE;;AAGA,kBAAIQ,aAAa,GAAGC,kBAAMC,QAAN,CAAeC,OAAf,CAAuBX,QAAvB,CAApB;;AAEA,kBAAIK,cAAJ,EAAoB;AAClBb,gBAAAA,IAAI,CAACc,KAAL,CAAW,CAAX,iBAAgBG,kBAAMG,YAAN,CAAmBpB,IAAI,CAACc,KAAL,CAAW,CAAX,CAAnB,EAAkC;AAAEO,kBAAAA,GAAG,EAAE;AAAP,iBAAlC,CAAhB;AACAL,gBAAAA,aAAa,GAAGA,aAAa,CAACM,MAAd,CAAqB,UAAAC,KAAK,EAAI;AAC5C,sBAAIA,KAAK,CAACC,IAAN,KAAe,OAAnB,EAA4B;AAC1B;AACA;AACA,2BAAO,KAAP;AACD;;AACD,yBAAO,IAAP;AACD,iBAPe,CAAhB;AAQD;;AAED,kBAAMC,WAAW,GAAGT,aAAa,CAACM,MAAd,CAAqB,UAAAC,KAAK,EAAI;AAChD,oBACEA,KAAK,CAACC,IAAN,KAAe,MAAf,IACAD,KAAK,CAACR,KADN,IAEAQ,KAAK,CAACR,KAAN,CAAYW,GAAZ,KAAoB,YAHtB,EAIE;AACA,yBAAO,IAAP;AACD;;AACD,oBAAIH,KAAK,CAACC,IAAN,KAAe,OAAnB,EAA4B;AAC1B,yBAAO,IAAP;AACD;;AACD,uBAAO,KAAP;AACD,eAZmB,CAApB;AAcA,kBAAMG,YAAY,GAAGX,aAAa,CAACM,MAAd,CAAqB,UAAAC,KAAK;AAAA,uBAAIA,KAAK,CAACC,IAAN,KAAe,MAAnB;AAAA,eAA1B,CAArB;AACA,kBAAMI,UAAU,GAAGZ,aAAa,CAACM,MAAd,CAAqB,UAAAC,KAAK;AAAA,uBAAIA,KAAK,CAACC,IAAN,KAAe,QAAnB;AAAA,eAA1B,CAAnB;AACAR,cAAAA,aAAa,GAAGA,aAAa,CAACM,MAAd,CAAqB,UAAAC,KAAK,EAAI;AAC5C,oBACEA,KAAK,CAACC,IAAN,KAAe,MAAf,IACAD,KAAK,CAACR,KADN,IAEAQ,KAAK,CAACR,KAAN,CAAYW,GAAZ,KAAoB,YAHtB,EAIE;AACA,yBAAO,KAAP;AACD;;AACD,oBAAIH,KAAK,CAACC,IAAN,KAAe,OAAnB,EAA4B;AAC1B,yBAAO,KAAP;AACD;;AACD,oBAAID,KAAK,CAACC,IAAN,KAAe,QAAnB,EAA6B;AAC3B,yBAAO,KAAP;AACD;;AACD,oBAAID,KAAK,CAACC,IAAN,KAAe,MAAnB,EAA2B;AACzB,yBAAO,KAAP;AACD;;AACD,uBAAO,IAAP;AACD,eAlBe,CAAhB;AAoBA,kCACE,wCAAUf,IAAV,eACE;AAAM,gBAAA,IAAI,EAAC,WAAX;AAAuB,gBAAA,OAAO,EAAC;AAA/B,gBADF,EAEGT,IAAI,CAAC6B,IAFR,EAGGhB,cAAc,IAAIb,IAAI,CAACc,KAH1B,EAIGa,YAJH,EAKG3B,IAAI,CAAC8B,IALR,EAMGF,UANH,EAOG,CAAC3B,KAAK,CAACU,QAAP,IACCT,aAAa,CAAC6B,GAAd,CAAkB,UAAAC,MAAM;AAAA,oCACtB;AACE,kBAAA,GAAG,yBAAkBA,MAAlB,CADL;AAEE,kBAAA,GAAG,EAAC,SAFN;AAGE,kBAAA,EAAE,EAAC,QAHL;AAIE,kBAAA,IAAI,EAAE,6BACJ,qBAASC,OAAO,CAACC,GAAR,CAAYC,wBAArB,EAA+CH,MAA/C,CADI;AAJR,kBADsB;AAAA,eAAxB,CARJ,EAkBGP,WAlBH,EAmBGf,aAAa,IACZN,iBAAiB,CAACgC,MAAlB,CAAyB,UAACC,IAAD,EAAOC,UAAP,EAAsB;AAC7C,oBAAMC,IAAI,GAAG,6BACX,qBAASN,OAAO,CAACC,GAAR,CAAYC,wBAArB,EAA+CG,UAA/C,CADW,CAAb;AAIA,qEACKD,IADL,iBAEE;AACE,kBAAA,GAAG,oCAA6BC,UAA7B,CADL;AAEE,kBAAA,GAAG,EAAC,SAFN;AAGE,kBAAA,EAAE,EAAC,OAHL;AAIE,kBAAA,IAAI,EAAEC;AAJR,kBAFF,eAQE;AACE,kBAAA,GAAG,6BAAsBD,UAAtB,CADL;AAEE,kBAAA,GAAG,EAAC,YAFN;AAGE,kBAAA,IAAI,EAAEC;AAHR,kBARF;AAcD,eAnBD,EAmBG,EAnBH,CApBJ,EAwCGvC,IAAI,CAACwC,IAxCR,EAyCGxC,IAAI,CAACyC,QAzCR,EA0CGzC,IAAI,CAACgC,MA1CR,EA2CG7B,MAAM,CAACS,SAAP,iBAAoB,gCAAC,WAAD;AAAa,gBAAA,SAAS,EAAElB;AAAxB,gBA3CvB,EA4CGM,IAAI,CAAC0C,KA5CR,EA6CGnC,WA7CH,EA8CGS,aA9CH,CADF;AAkDD,aAtHY;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G","sourcesContent":["import React from 'react'\n//\nimport { pathJoin, makePathAbsolute } from '../../utils'\nimport plugins from '../plugins'\n// import packagejson from '../../../package.json'\n\n// const { version } = packagejson\n\nconst REGEX_FOR_STYLE_TAG = /<style>|<\\/style>/gi\n\nexport const InlineStyle = ({ clientCss }) => (\n  <style\n    key=\"clientCss\"\n    type=\"text/css\"\n    dangerouslySetInnerHTML={{\n      __html: clientCss.toString().replace(REGEX_FOR_STYLE_TAG, ''),\n    }}\n  />\n)\n\nexport default async function makeHeadWithMeta(state) {\n  const {\n    head,\n    route,\n    clientScripts,\n    config,\n    clientStyleSheets,\n    clientCss,\n  } = state\n\n  const pluginHeads = await plugins.headElements([], state)\n\n  return ({ children, ...rest }) => {\n    const renderLinkCSS = !route.redirect && !config.inlineCss\n\n    const useHelmetTitle =\n      head.title && head.title[0] && head.title[0].props.children !== ''\n\n    let childrenArray = React.Children.toArray(children)\n\n    if (useHelmetTitle) {\n      head.title[0] = React.cloneElement(head.title[0], { key: 'title' })\n      childrenArray = childrenArray.filter(child => {\n        if (child.type === 'title') {\n          // Filter out the title of the Document in static.config.js\n          // if there is a helmet title on this route\n          return false\n        }\n        return true\n      })\n    }\n\n    const childrenCSS = childrenArray.filter(child => {\n      if (\n        child.type === 'link' &&\n        child.props &&\n        child.props.rel === 'stylesheet'\n      ) {\n        return true\n      }\n      if (child.type === 'style') {\n        return true\n      }\n      return false\n    })\n\n    const childrenMeta = childrenArray.filter(child => child.type === 'meta')\n    const childrenJS = childrenArray.filter(child => child.type === 'script')\n    childrenArray = childrenArray.filter(child => {\n      if (\n        child.type === 'link' &&\n        child.props &&\n        child.props.rel === 'stylesheet'\n      ) {\n        return false\n      }\n      if (child.type === 'style') {\n        return false\n      }\n      if (child.type === 'script') {\n        return false\n      }\n      if (child.type === 'meta') {\n        return false\n      }\n      return true\n    })\n\n    return (\n      <head {...rest}>\n        <meta name=\"generator\" content=\"React Static\" />\n        {head.base}\n        {useHelmetTitle && head.title}\n        {childrenMeta}\n        {head.meta}\n        {childrenJS}\n        {!route.redirect &&\n          clientScripts.map(script => (\n            <link\n              key={`clientScript_${script}`}\n              rel=\"preload\"\n              as=\"script\"\n              href={makePathAbsolute(\n                pathJoin(process.env.REACT_STATIC_ASSETS_PATH, script)\n              )}\n            />\n          ))}\n        {childrenCSS}\n        {renderLinkCSS &&\n          clientStyleSheets.reduce((memo, styleSheet) => {\n            const href = makePathAbsolute(\n              pathJoin(process.env.REACT_STATIC_ASSETS_PATH, styleSheet)\n            )\n\n            return [\n              ...memo,\n              <link\n                key={`clientStyleSheetPreload_${styleSheet}`}\n                rel=\"preload\"\n                as=\"style\"\n                href={href}\n              />,\n              <link\n                key={`clientStyleSheet_${styleSheet}`}\n                rel=\"stylesheet\"\n                href={href}\n              />,\n            ]\n          }, [])}\n        {head.link}\n        {head.noscript}\n        {head.script}\n        {config.inlineCss && <InlineStyle clientCss={clientCss} />}\n        {head.style}\n        {pluginHeads}\n        {childrenArray}\n      </head>\n    )\n  }\n}\n"]}