UNPKG

patternplate-client

Version:

Universal javascript client application for patternplate

254 lines (191 loc) 17.8 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _slicedToArray2 = require('babel-runtime/helpers/slicedToArray'); var _slicedToArray3 = _interopRequireDefault(_slicedToArray2); var _regenerator = require('babel-runtime/regenerator'); var _regenerator2 = _interopRequireDefault(_regenerator); var _stringify = require('babel-runtime/core-js/json/stringify'); var _stringify2 = _interopRequireDefault(_stringify); var _asyncToGenerator2 = require('babel-runtime/helpers/asyncToGenerator'); var _asyncToGenerator3 = _interopRequireDefault(_asyncToGenerator2); var _url = require('url'); var _url2 = _interopRequireDefault(_url); var _os = require('os'); var _os2 = _interopRequireDefault(_os); var _lodash = require('lodash'); var _reactHelmet = require('react-helmet'); var _reactHelmet2 = _interopRequireDefault(_reactHelmet); var _resolve = require('resolve'); var _queryString = require('query-string'); var _queryString2 = _interopRequireDefault(_queryString); var _platform = require('platform'); var _platform2 = _interopRequireDefault(_platform); var _server = require('../application/react-routes/server'); var _server2 = _interopRequireDefault(_server); var _layouts = require('../application/layouts'); var _layouts2 = _interopRequireDefault(_layouts); var _getIdByPathname = require('../application/utils/get-id-by-pathname'); var _getIdByPathname2 = _interopRequireDefault(_getIdByPathname); var _navigate = require('../application/utils/navigate'); var _navigate2 = _interopRequireDefault(_navigate); var _icon = require('../application/components/common/icon'); var _icon2 = _interopRequireDefault(_icon); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var cwd = process.cwd(); var resolve = function resolve(id) { return (0, _resolve.sync)(id, { basedir: cwd }); }; var getSchema = require(resolve('patternplate-server/library/get-schema')); var getNavigation = require(resolve('patternplate-server/library/get-navigation')); var getPatternMetaData = require(resolve('patternplate-server/library/get-pattern-meta-data')); var defaultData = { schema: {}, navigation: {}, patterns: null, messages: [] }; exports.default = function () { var _ref = (0, _asyncToGenerator3.default)( /*#__PURE__*/_regenerator2.default.mark(function _callee(application, pageUrl) { var filters = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; var app, client, server, filter, parsed, depth, query, base, id, schema, navigation, filteredNavigation, pattern, isPattern, patternData, config, options, serverData, data, content, head, icons; return _regenerator2.default.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: app = application.parent; client = application; server = app.server; filter = getFilter(filters); parsed = _url2.default.parse(pageUrl); depth = parsed.pathname.split('/').filter(Boolean).length; query = _queryString2.default.parse(parsed.query); base = depth > 0 ? (0, _lodash.fill)(Array(depth), '..').join('/') : '.'; id = (0, _getIdByPathname2.default)(parsed.pathname); if (!app) { _context.next = 15; break; } _context.next = 12; return getSchema(app, client, server); case 12: _context.t0 = _context.sent; _context.next = 16; break; case 15: _context.t0 = {}; case 16: schema = _context.t0; if (!app) { _context.next = 23; break; } _context.next = 20; return getNavigation(app, client, server); case 20: _context.t1 = _context.sent; _context.next = 24; break; case 23: _context.t1 = {}; case 24: navigation = _context.t1; filteredNavigation = applyFilters(navigation, filter); pattern = (0, _lodash.merge)({}, (0, _navigate2.default)(id, filteredNavigation)); isPattern = pattern && pattern.type === 'pattern'; if (!isPattern) { _context.next = 39; break; } _context.prev = 29; _context.next = 32; return getPatternMetaData(server, id); case 32: patternData = _context.sent; (0, _lodash.merge)(pattern, patternData); _context.next = 39; break; case 36: _context.prev = 36; _context.t2 = _context['catch'](29); application.log.error(_context.t2); case 39: config = application.configuration.ui; options = { url: pageUrl, title: application.configuration.ui.title || schema.name, theme: query.theme || application.configuration.ui.theme, config: config }; serverData = { schema: schema, navigation: filteredNavigation, pattern: pattern }; data = (0, _lodash.merge)({}, defaultData, options.data, serverData, { config: config }, { schema: { serverOsName: _os2.default.type(), serverOsVersion: _os2.default.release(), serverRuntimeName: _platform2.default.name, serverRuntimeVersion: _platform2.default.version }, startPathname: pageUrl, startBase: base }); _context.next = 45; return (0, _server2.default)(options.url, data); case 45: content = _context.sent; head = _reactHelmet2.default.rewind(); icons = _icon2.default.rewind(); return _context.abrupt('return', (0, _layouts2.default)({ attributes: head.htmlAttributes, base: base, content: content, icons: icons, data: (0, _stringify2.default)(data), link: head.link, meta: head.meta, style: head.style, title: head.title, scripts: [base + '/script/vendors.bundle.js', base + '/script/index.bundle.js'] })); case 49: case 'end': return _context.stop(); } } }, _callee, this, [[29, 36]]); })); function renderPage(_x, _x2) { return _ref.apply(this, arguments); } return renderPage; }(); var pass = function pass() { return true; }; function applyFilters(raw, filter) { return (0, _lodash.entries)(raw).reduce(function (results, entry) { var _entry = (0, _slicedToArray3.default)(entry, 2), key = _entry[0], item = _entry[1]; if (item.type !== 'pattern') { results[key] = item; item.children = applyFilters(item.children, filter); return results; } if (filter(item.manifest)) { results[key] = item; } return results; }, {}); } function getFilter(filters) { var flags = filters.flags || []; if (flags.length === 0) { return pass; } return function (item) { return flags.includes(item.flag); }; } module.exports = exports['default']; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../source/library/render-page.js"],"names":["cwd","process","resolve","id","basedir","getSchema","require","getNavigation","getPatternMetaData","defaultData","schema","navigation","patterns","messages","application","pageUrl","filters","app","parent","client","server","filter","getFilter","parsed","parse","depth","pathname","split","Boolean","length","query","base","Array","join","filteredNavigation","applyFilters","pattern","isPattern","type","patternData","log","error","config","configuration","ui","options","url","title","name","theme","serverData","data","serverOsName","serverOsVersion","release","serverRuntimeName","serverRuntimeVersion","version","startPathname","startBase","content","head","rewind","icons","attributes","htmlAttributes","link","meta","style","scripts","renderPage","pass","raw","reduce","results","entry","key","item","children","manifest","flags","includes","flag"],"mappings":"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","file":"render-page.js","sourcesContent":["import url from 'url';\nimport os from 'os';\n\nimport {fill, merge, entries} from 'lodash';\nimport Helmet from 'react-helmet';\nimport {sync as resolveSync} from 'resolve';\nimport queryString from 'query-string';\nimport platform from 'platform';\n\nimport router from '../application/react-routes/server';\nimport layout from '../application/layouts';\nimport getIdByPathname from '../application/utils/get-id-by-pathname';\nimport navigate from '../application/utils/navigate';\nimport Icon from '../application/components/common/icon';\n\nconst cwd = process.cwd();\nconst resolve = id => resolveSync(id, {basedir: cwd});\n\nconst getSchema = require(resolve('patternplate-server/library/get-schema'));\nconst getNavigation = require(resolve('patternplate-server/library/get-navigation'));\nconst getPatternMetaData = require(resolve('patternplate-server/library/get-pattern-meta-data'));\n\nconst defaultData = {\n\tschema: {},\n\tnavigation: {},\n\tpatterns: null,\n\tmessages: []\n};\n\nexport default async function renderPage(application, pageUrl, filters = {}) {\n\tconst app = application.parent;\n\tconst client = application;\n\tconst server = app.server;\n\tconst filter = getFilter(filters);\n\n\tconst parsed = url.parse(pageUrl);\n\tconst depth = parsed.pathname.split('/').filter(Boolean).length;\n\tconst query = queryString.parse(parsed.query);\n\tconst base = depth > 0 ? fill(Array(depth), '..').join('/') : '.';\n\n\tconst id = getIdByPathname(parsed.pathname);\n\n\tconst schema = app ? await getSchema(app, client, server) : {};\n\tconst navigation = app ? await getNavigation(app, client, server) : {};\n\tconst filteredNavigation = applyFilters(navigation, filter);\n\n\tconst pattern = merge({}, navigate(id, filteredNavigation));\n\tconst isPattern = pattern && pattern.type === 'pattern';\n\n\tif (isPattern) {\n\t\ttry {\n\t\t\tconst patternData = await getPatternMetaData(server, id);\n\t\t\tmerge(pattern, patternData);\n\t\t} catch (error) {\n\t\t\tapplication.log.error(error);\n\t\t}\n\t}\n\n\tconst config = application.configuration.ui;\n\tconst options = {\n\t\turl: pageUrl,\n\t\ttitle: application.configuration.ui.title || schema.name,\n\t\ttheme: query.theme || application.configuration.ui.theme,\n\t\tconfig\n\t};\n\n\tconst serverData = {schema, navigation: filteredNavigation, pattern};\n\tconst data = merge({}, defaultData, options.data, serverData, {config}, {\n\t\tschema: {\n\t\t\tserverOsName: os.type(),\n\t\t\tserverOsVersion: os.release(),\n\t\t\tserverRuntimeName: platform.name,\n\t\t\tserverRuntimeVersion: platform.version\n\t\t},\n\t\tstartPathname: pageUrl,\n\t\tstartBase: base\n\t});\n\n\tconst content = await router(options.url, data);\n\tconst head = Helmet.rewind();\n\tconst icons = Icon.rewind();\n\n\treturn layout({\n\t\tattributes: head.htmlAttributes,\n\t\tbase,\n\t\tcontent,\n\t\ticons,\n\t\tdata: JSON.stringify(data),\n\t\tlink: head.link,\n\t\tmeta: head.meta,\n\t\tstyle: head.style,\n\t\ttitle: head.title,\n\t\tscripts: [\n\t\t\t`${base}/script/vendors.bundle.js`,\n\t\t\t`${base}/script/index.bundle.js`\n\t\t]\n\t});\n}\n\nconst pass = () => true;\n\nfunction applyFilters(raw, filter) {\n\treturn entries(raw).reduce((results, entry) => {\n\t\tconst [key, item] = entry;\n\t\tif (item.type !== 'pattern') {\n\t\t\tresults[key] = item;\n\t\t\titem.children = applyFilters(item.children, filter);\n\t\t\treturn results;\n\t\t}\n\t\tif (filter(item.manifest)) {\n\t\t\tresults[key] = item;\n\t\t}\n\t\treturn results;\n\t}, {});\n}\n\nfunction getFilter(filters) {\n\tconst flags = filters.flags || [];\n\n\tif (flags.length === 0) {\n\t\treturn pass;\n\t}\n\n\treturn item => {\n\t\treturn flags.includes(item.flag);\n\t};\n}\n"]}