UNPKG

react-static

Version:

A progressive static site generator for React

155 lines (129 loc) 16.9 kB
"use strict"; 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":"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","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"]}