UNPKG

patternplate-client

Version:

Universal javascript client application for patternplate

163 lines (139 loc) 12.8 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _defineProperty2 = require('babel-runtime/helpers/defineProperty'); var _defineProperty3 = _interopRequireDefault(_defineProperty2); exports.default = PatternFolder; var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _reactRouter = require('@marionebl/react-router'); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _icon = require('../common/icon'); var _icon2 = _interopRequireDefault(_icon); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function ItemField(props) { var Component = props.component; var className = (0, _classnames2.default)('pattern-field', props.className, (0, _defineProperty3.default)({}, 'pattern-field--' + props.valueKey, props.value)); var children = props.children || props.value; return _react2.default.createElement( Component, { className: className }, Array.isArray(children) ? children.map(function (c, i) { return _react2.default.createElement( 'span', { key: i }, c ); }) : children ); } ItemField.defaultProps = { component: 'div' }; function PatternFolderItem(props) { var name = props.name, type = props.type, id = props.id, location = props.location, base = props.base; var to = { pathname: base + 'pattern/' + id, query: location.query }; var title = 'Navigate to ' + type + ' "' + name + '" at ' + id; var href = base + 'demo/' + id; return _react2.default.createElement( 'li', { className: 'pattern-item' }, _react2.default.createElement( ItemField, { valueKey: 'name', value: props.name }, _react2.default.createElement( _reactRouter.Link, { to: to, title: title }, _react2.default.createElement( _icon2.default, { base: base, symbol: type }, name ), _react2.default.createElement( 'span', null, props.name ) ) ), _react2.default.createElement(ItemField, { valueKey: 'version', value: props.version }), _react2.default.createElement(ItemField, { valueKey: 'tags', value: props.tags }), _react2.default.createElement(ItemField, { valueKey: 'flag', value: props.flag }), props.type === 'pattern' ? _react2.default.createElement( 'a', { href: href, target: '_blank', rel: 'nofollow', className: 'pattern-field', title: 'Open ' + type + ' "' + name + '" at ' + id + ' in fullscreen' }, _react2.default.createElement( _icon2.default, { base: base, symbol: 'fullscreen', description: 'Fullscreen' }, id + ' in fullscreen' ) ) : _react2.default.createElement('div', { className: 'pattern-field' }) ); } function PatternFolder(_ref) { var items = _ref.items, location = _ref.location, up = _ref.up, base = _ref.base; return _react2.default.createElement( 'ul', { className: 'pattern-folder' }, _react2.default.createElement( 'li', { className: 'pattern-folder-head' }, _react2.default.createElement('div', { className: 'pattern-folder-head__cell' }), _react2.default.createElement( 'div', { className: 'pattern-folder-head__cell' }, 'Version' ), _react2.default.createElement( 'div', { className: 'pattern-folder-head__cell' }, 'Tags' ), _react2.default.createElement( 'div', { className: 'pattern-folder-head__cell' }, 'Flag' ), _react2.default.createElement('div', { className: 'pattern-folder-head__cell' }) ), up && _react2.default.createElement(PatternFolderItem, { id: up, name: '..', type: 'folder', location: location, base: base }), items.map(function (item) { return _react2.default.createElement(PatternFolderItem, (0, _extends3.default)({}, item, { location: location, key: item.id, base: base })); }) ); } PatternFolder.defaultProps = { items: [] }; module.exports = exports['default']; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../source/application/components/pattern/pattern-folder.js"],"names":["PatternFolder","ItemField","props","Component","component","className","valueKey","value","children","Array","isArray","map","c","i","defaultProps","PatternFolderItem","name","type","id","location","base","to","pathname","query","title","href","version","tags","flag","items","up","item"],"mappings":"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","file":"pattern-folder.js","sourcesContent":["import React, {PropTypes as t} from 'react';\nimport {Link} from '@marionebl/react-router';\nimport join from 'classnames';\n\nimport Icon from '../common/icon';\n\nfunction ItemField(props) {\n\tconst Component = props.component;\n\tconst className = join('pattern-field', props.className, {\n\t\t[`pattern-field--${props.valueKey}`]: props.value\n\t});\n\tconst children = props.children || props.value;\n\n\treturn (\n\t\t<Component className={className}>\n\t\t\t{\n\t\t\t\tArray.isArray(children) ?\n\t\t\t\t\tchildren.map((c, i) => {\n\t\t\t\t\t\treturn <span key={i}>{c}</span>;\n\t\t\t\t\t}) :\n\t\t\t\t\tchildren\n\t\t\t}\n\t\t</Component>\n\t);\n}\n\nItemField.propTypes = {\n\tcomponent: t.string.isRequired,\n\tvalueKey: t.string.isRequired,\n\tvalue: t.any,\n\tclassName: t.string,\n\tchildren: t.any\n};\n\nItemField.defaultProps = {\n\tcomponent: 'div'\n};\n\nfunction PatternFolderItem(props) {\n\tconst {name, type, id, location, base} = props;\n\tconst to = {\n\t\tpathname: `${base}pattern/${id}`,\n\t\tquery: location.query\n\t};\n\n\tconst title = `Navigate to ${type} \"${name}\" at ${id}`;\n\tconst href = `${base}demo/${id}`;\n\n\treturn (\n\t\t<li className=\"pattern-item\">\n\t\t\t<ItemField valueKey=\"name\" value={props.name}>\n\t\t\t\t<Link to={to} title={title}>\n\t\t\t\t\t<Icon base={base} symbol={type}>{name}</Icon>\n\t\t\t\t\t<span>{props.name}</span>\n\t\t\t\t</Link>\n\t\t\t</ItemField>\n\t\t\t<ItemField valueKey=\"version\" value={props.version}/>\n\t\t\t<ItemField valueKey=\"tags\" value={props.tags}/>\n\t\t\t<ItemField valueKey=\"flag\" value={props.flag}/>\n\t\t\t{\n\t\t\t\tprops.type === 'pattern' ?\n\t\t\t\t\t<a\n\t\t\t\t\t\thref={href}\n\t\t\t\t\t\ttarget=\"_blank\"\n\t\t\t\t\t\trel=\"nofollow\"\n\t\t\t\t\t\tclassName=\"pattern-field\"\n\t\t\t\t\t\ttitle={`Open ${type} \"${name}\" at ${id} in fullscreen`}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t<Icon base={base} symbol=\"fullscreen\" description=\"Fullscreen\">\n\t\t\t\t\t\t\t{`${id} in fullscreen`}\n\t\t\t\t\t\t</Icon>\n\t\t\t\t\t</a> :\n\t\t\t\t\t<div className=\"pattern-field\"/>\n\t\t\t}\n\t\t</li>\n\t);\n}\n\nPatternFolderItem.propTypes = {\n\tbase: t.string.isRequired,\n\tid: t.string.isRequired,\n\tname: t.string.isRequired,\n\ttype: t.string.isRequired,\n\tversion: t.string,\n\ttags: t.array,\n\tflag: t.string,\n\tlocation: t.shape({\n\t\tpathname: t.string.isRequired,\n\t\tquery: t.object.isRequired\n\t}).isRequired\n};\n\nexport default function PatternFolder({items, location, up, base}) {\n\treturn (\n\t\t<ul className=\"pattern-folder\">\n\t\t\t<li className=\"pattern-folder-head\">\n\t\t\t\t<div className=\"pattern-folder-head__cell\"/>\n\t\t\t\t<div className=\"pattern-folder-head__cell\">Version</div>\n\t\t\t\t<div className=\"pattern-folder-head__cell\">Tags</div>\n\t\t\t\t<div className=\"pattern-folder-head__cell\">Flag</div>\n\t\t\t\t<div className=\"pattern-folder-head__cell\"/>\n\t\t\t</li>\n\t\t\t{\n\t\t\t\tup &&\n\t\t\t\t\t<PatternFolderItem\n\t\t\t\t\t\tid={up}\n\t\t\t\t\t\tname=\"..\"\n\t\t\t\t\t\ttype=\"folder\"\n\t\t\t\t\t\tlocation={location}\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\titems.map(item => (\n\t\t\t\t\t<PatternFolderItem\n\t\t\t\t\t\t{...item}\n\t\t\t\t\t\tlocation={location}\n\t\t\t\t\t\tkey={item.id}\n\t\t\t\t\t\tbase={base}\n\t\t\t\t\t\t/>\n\t\t\t\t))\n\t\t\t}\n\t\t</ul>\n\t);\n}\n\nPatternFolder.propTypes = {\n\tbase: t.string.isRequired,\n\titems: t.arrayOf(t.shape(PatternFolderItem.propTypes)).isRequired,\n\tlocation: t.shape({\n\t\tpathname: t.string.isRequired,\n\t\tquery: t.object.isRequired\n\t}).isRequired,\n\tup: t.string\n};\n\nPatternFolder.defaultProps = {\n\titems: []\n};\n"]}