UNPKG

patternplate-client

Version:

Universal javascript client application for patternplate

183 lines (143 loc) 17 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _values = require('babel-runtime/core-js/object/values'); var _values2 = _interopRequireDefault(_values); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _lodash = require('lodash'); var _CSSTransitionGroup = require('react-transition-group/CSSTransitionGroup'); var _CSSTransitionGroup2 = _interopRequireDefault(_CSSTransitionGroup); var _markdown = require('../common/markdown'); var _markdown2 = _interopRequireDefault(_markdown); var _message = require('../common/message'); var _message2 = _interopRequireDefault(_message); var _urlQuery = require('../../utils/url-query'); var _urlQuery2 = _interopRequireDefault(_urlQuery); var _getIdByPathname = require('../../utils/get-id-by-pathname'); var _getIdByPathname2 = _interopRequireDefault(_getIdByPathname); var _patternFolder = require('../pattern/pattern-folder'); var _patternFolder2 = _interopRequireDefault(_patternFolder); var _patternSection = require('../pattern/pattern-section'); var _patternSection2 = _interopRequireDefault(_patternSection); var _navigate = require('../../utils/navigate'); var _navigate2 = _interopRequireDefault(_navigate); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } exports.default = Content; var sortTypes = ['folder', 'pattern']; var rateType = function rateType(item) { return sortTypes.indexOf(item.type); }; function Content(props) { var base = props.base, config = props.config, location = props.location; var hierarchy = config.hierarchy; var _urlQuery$parse = _urlQuery2.default.parse(location.pathname), pathname = _urlQuery$parse.pathname; var id = (0, _getIdByPathname2.default)(pathname, props.base); var fragments = id.split('/'); var depth = fragments.length - 1; var up = depth > 0 ? fragments.slice(0, fragments.length - 1).join('/') : ''; var item = (0, _navigate2.default)(id, props.navigation); if (!item) { return _react2.default.createElement( 'div', { className: 'application-container application-container--pattern' }, _react2.default.createElement( 'div', { className: 'not-found-section' }, _react2.default.createElement(_markdown2.default, { source: getNotFoundSource(id) }) ) ); } var itemDefaults = { base: base, location: location }; var items = (0, _lodash.sortBy)((0, _lodash.sortBy)(getItems(item, hierarchy, itemDefaults, props.hide), 'name'), rateType); return _react2.default.createElement( 'div', { className: 'application-container application-container--pattern' }, item.type === 'folder' && _react2.default.createElement(_patternFolder2.default, { id: id, location: location, items: items, up: up, base: base }), item.type === 'pattern' && _react2.default.createElement(_patternSection2.default, { id: id, data: props.pattern, navigation: props.navigation, config: props.config, location: location, type: item.type, onDataRequest: props.onLoad, base: base }), _react2.default.createElement( _CSSTransitionGroup2.default, { component: 'aside', transitionName: 'pattern-content-transition', className: 'messages', transitionEnterTimeout: 300, transitionLeaveTimeout: 300 }, props.messages.map(function (message) { return _react2.default.createElement(_message2.default, { id: message.id, key: message.id, type: message.type, title: message.subject, body: message.body || message.stack, pattern: String(message.pattern).trim(), payload: message.payload, retry: message.retry, file: message.file, timestamp: message.timestamp, onDismiss: props.onDismiss, onRetry: props.onRetry, location: location, base: base }); }) ) ); } function getItemName(item, hierarchy) { if (item.type === 'pattern') { return item.manifest.displayName || item.manifest.name || item.id; } var configured = hierarchy[item.id] || {}; return configured.displayName || item.id; } function getNotFoundSource(id) { return '\n# Pattern not found\n\nWe looked everywhere and could not find pattern `' + id + '`.\n\nYou might want to navigate back to [Home](/) or use the search.\n\n---\n\nHelp us to make this message more helpful on [GitHub](https://github.com/sinnerschrader/patternplate)\n'; } function getItems(root, hierarchy, defaults, hide) { if (root.type !== 'folder') { return []; } return (0, _values2.default)(root.children).map(selectPatternData(hierarchy, defaults, hide)).filter(function (item) { return item.type !== 'pattern' || item.display; }); } function selectPatternData(hierarchy, defaults, hide) { return function (child) { var amend = child.type === 'pattern' ? { version: child.manifest.version, flag: child.manifest.flag, tags: child.manifest.tags, display: hide ? child.manifest.display !== false : true } : {}; return (0, _extends3.default)({}, defaults, { id: child.id, name: getItemName(child, hierarchy), type: child.type }, amend); }; } module.exports = exports['default']; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../source/application/components/content/index.js"],"names":["Content","sortTypes","rateType","indexOf","item","type","props","base","config","location","hierarchy","parse","pathname","id","fragments","split","depth","length","up","slice","join","navigation","getNotFoundSource","itemDefaults","items","getItems","hide","pattern","onLoad","messages","map","message","subject","body","stack","String","trim","payload","retry","file","timestamp","onDismiss","onRetry","getItemName","manifest","displayName","name","configured","root","defaults","children","selectPatternData","filter","display","amend","child","version","flag","tags"],"mappings":"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","file":"index.js","sourcesContent":["import React, {PropTypes as t} from 'react';\nimport {sortBy} from 'lodash';\nimport CSSTransitionGroup from 'react-transition-group/CSSTransitionGroup';\n\nimport Markdown from '../common/markdown';\nimport Message from '../common/message';\nimport urlQuery from '../../utils/url-query';\nimport getIdByPathname from '../../utils/get-id-by-pathname';\nimport PatternFolder from '../pattern/pattern-folder';\nimport PatternSection from '../pattern/pattern-section';\nimport navigate from '../../utils/navigate';\n\nexport default Content;\n\nconst sortTypes = ['folder', 'pattern'];\nconst rateType = item => sortTypes.indexOf(item.type);\n\nfunction Content(props) {\n\tconst {base, config, location} = props;\n\tconst {hierarchy} = config;\n\n\tconst {pathname} = urlQuery.parse(location.pathname);\n\tconst id = getIdByPathname(pathname, props.base);\n\n\tconst fragments = id.split('/');\n\tconst depth = fragments.length - 1;\n\tconst up = depth > 0 ? fragments.slice(0, fragments.length - 1).join('/') : '';\n\tconst item = navigate(id, props.navigation);\n\n\tif (!item) {\n\t\treturn (\n\t\t\t<div className=\"application-container application-container--pattern\">\n\t\t\t\t<div className=\"not-found-section\">\n\t\t\t\t\t<Markdown source={getNotFoundSource(id)}/>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n\n\tconst itemDefaults = {base, location};\n\tconst items = sortBy(sortBy(getItems(item, hierarchy, itemDefaults, props.hide), 'name'), rateType);\n\n\treturn (\n\t\t<div className=\"application-container application-container--pattern\">\n\t\t\t{\n\t\t\t\titem.type === 'folder' &&\n\t\t\t\t\t<PatternFolder\n\t\t\t\t\t\tid={id}\n\t\t\t\t\t\tlocation={location}\n\t\t\t\t\t\titems={items}\n\t\t\t\t\t\tup={up}\n\t\t\t\t\t\tbase={base}\n\t\t\t\t\t\t/>\n\t\t\t}\n\t\t\t{\n\t\t\t\titem.type === 'pattern' &&\n\t\t\t\t\t<PatternSection\n\t\t\t\t\t\tid={id}\n\t\t\t\t\t\tdata={props.pattern}\n\t\t\t\t\t\tnavigation={props.navigation}\n\t\t\t\t\t\tconfig={props.config}\n\t\t\t\t\t\tlocation={location}\n\t\t\t\t\t\ttype={item.type}\n\t\t\t\t\t\tonDataRequest={props.onLoad}\n\t\t\t\t\t\tbase={base}\n\t\t\t\t\t\t/>\n\t\t\t}\n\t\t\t<CSSTransitionGroup\n\t\t\t\tcomponent=\"aside\"\n\t\t\t\ttransitionName=\"pattern-content-transition\"\n\t\t\t\tclassName=\"messages\"\n\t\t\t\ttransitionEnterTimeout={300}\n\t\t\t\ttransitionLeaveTimeout={300}\n\t\t\t\t>\n\t\t\t\t{\n\t\t\t\t\tprops.messages.map(message => {\n\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t<Message\n\t\t\t\t\t\t\t\tid={message.id}\n\t\t\t\t\t\t\t\tkey={message.id}\n\t\t\t\t\t\t\t\ttype={message.type}\n\t\t\t\t\t\t\t\ttitle={message.subject}\n\t\t\t\t\t\t\t\tbody={message.body || message.stack}\n\t\t\t\t\t\t\t\tpattern={String(message.pattern).trim()}\n\t\t\t\t\t\t\t\tpayload={message.payload}\n\t\t\t\t\t\t\t\tretry={message.retry}\n\t\t\t\t\t\t\t\tfile={message.file}\n\t\t\t\t\t\t\t\ttimestamp={message.timestamp}\n\t\t\t\t\t\t\t\tonDismiss={props.onDismiss}\n\t\t\t\t\t\t\t\tonRetry={props.onRetry}\n\t\t\t\t\t\t\t\tlocation={location}\n\t\t\t\t\t\t\t\tbase={base}\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t);\n\t\t\t\t\t})\n\t\t\t\t}\n\t\t\t</CSSTransitionGroup>\n\t\t</div>\n\t);\n}\n\nContent.propTypes = {\n\tbase: t.string.isRequired,\n\tconfig: t.object.isRequired,\n\thide: t.bool.isRequired,\n\tlocation: t.shape({\n\t\tpathname: t.string.isRequired\n\t}).isRequired,\n\tnavigation: t.object.isRequired,\n\tonDismiss: t.func.isRequired,\n\tonLoad: t.func.isRequired,\n\tonRetry: t.func.isRequired,\n\tpattern: t.object.isRequired,\n\tmessages: t.array.isRequired\n};\n\nfunction getItemName(item, hierarchy) {\n\tif (item.type === 'pattern') {\n\t\treturn item.manifest.displayName || item.manifest.name || item.id;\n\t}\n\tconst configured = hierarchy[item.id] || {};\n\treturn configured.displayName || item.id;\n}\n\nfunction getNotFoundSource(id) {\n\treturn `\n# Pattern not found\n\nWe looked everywhere and could not find pattern \\`${id}\\`.\n\nYou might want to navigate back to [Home](/) or use the search.\n\n---\n\nHelp us to make this message more helpful on [GitHub](https://github.com/sinnerschrader/patternplate)\n`;\n}\n\nfunction getItems(root, hierarchy, defaults, hide) {\n\tif (root.type !== 'folder') {\n\t\treturn [];\n\t}\n\treturn Object.values(root.children)\n\t\t.map(selectPatternData(hierarchy, defaults, hide))\n\t\t.filter(item => item.type !== 'pattern' || item.display);\n}\n\nfunction selectPatternData(hierarchy, defaults, hide) {\n\treturn child => {\n\t\tconst amend = child.type === 'pattern' ?\n\t\t{\n\t\t\tversion: child.manifest.version,\n\t\t\tflag: child.manifest.flag,\n\t\t\ttags: child.manifest.tags,\n\t\t\tdisplay: hide ? child.manifest.display !== false : true\n\t\t} :\n\t\t{};\n\n\t\treturn {\n\t\t\t...defaults,\n\t\t\tid: child.id,\n\t\t\tname: getItemName(child, hierarchy),\n\t\t\ttype: child.type,\n\t\t\t...amend\n\t\t};\n\t};\n}\n"]}