UNPKG

patternplate-client

Version:

Universal javascript client application for patternplate

216 lines (186 loc) 18.4 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 = PatternHeader; var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _reactRouter = require('@marionebl/react-router'); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _lodash = require('lodash'); var _breadCrumbs = require('../bread-crumbs'); var _breadCrumbs2 = _interopRequireDefault(_breadCrumbs); var _headline = require('../common/headline'); var _headline2 = _interopRequireDefault(_headline); var _icon = require('../common/icon'); var _icon2 = _interopRequireDefault(_icon); var _urlQuery = require('../../utils/url-query'); var _urlQuery2 = _interopRequireDefault(_urlQuery); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var autoMount = 'https://github.com/sinnerschrader/patternplate-transform-react-to-markup#component-auto-mounting'; function PatternHeader(props) { var flagClassName = (0, _classnames2.default)('pattern__flag', (0, _defineProperty3.default)({}, 'pattern__flag--' + props.flag, props.flag)); var fullscreen = _urlQuery2.default.format({ pathname: props.base + 'demo/' + props.id + '/index.html', query: { environment: props.environment } }); var fullscreenTitle = 'Open "' + props.name + '" in fullscreen [ctrl+f]'; var reloadTitle = 'Reload demo for "' + props.name + '" [ctrl+r]'; var reloadClassName = (0, _classnames2.default)('button', 'button--reload', { 'reload--reloading': props.loading, 'button--is-active': props.loading, 'reload--error': props.errored }); var rulersTitle = props.rulers ? 'Disable rulers [ctrl+l]' : 'Enable rulers [ctrl+l]'; var rulersClassName = (0, _classnames2.default)('button button--rulers', { 'button--is-active': props.rulers }); var opacityClassName = (0, _classnames2.default)('button button--opacity', { 'button--is-active': props.opacity }); var opacitySymbol = props.opacity ? 'checkers' : 'checkers-inverted'; var opacityTitle = props.opacity ? 'Hide opacity [ctrl+o]' : 'Show opacity [ctrl+o]'; return _react2.default.createElement( 'div', { className: 'pattern-header-container' }, _react2.default.createElement(_breadCrumbs2.default, { base: props.base, crumbs: props.breadcrumbs, location: props.location, className: 'pattern-path' }), _react2.default.createElement( _headline2.default, { className: 'pattern-header', order: 2 }, _react2.default.createElement( 'span', { className: 'pattern-name' }, props.name ), _react2.default.createElement( 'small', { className: 'pattern-version' }, props.version ? 'v' + props.version : '' ), props.flag ? _react2.default.createElement( 'small', { className: flagClassName }, _react2.default.createElement( _reactRouter.Link, { title: 'Search patterns with flag ' + props.flag, to: { pathname: props.location.pathname, query: (0, _extends3.default)({}, props.location.query, { search: 'flag:' + props.flag }) } }, props.flag ) ) : null, props.tags.map(function (tag, key) { return _react2.default.createElement( 'small', { key: key, className: 'pattern-tag' }, _react2.default.createElement( _reactRouter.Link, { title: 'Search patterns with tag ' + tag, to: { pathname: props.location.pathname, query: (0, _extends3.default)({}, props.location.query, { search: 'tag:' + tag }) }, key: key }, tag ) ); }), props.automount && _react2.default.createElement( 'small', { className: 'pattern-option' }, _react2.default.createElement( 'a', { href: autoMount, target: '_blank', title: 'Learn about component auto mounting on Github', rel: 'noopener' }, 'auto-mount' ) ) ), _react2.default.createElement( 'div', { className: 'pattern-header__actions' }, _react2.default.createElement( _reactRouter.Link, { className: reloadClassName, title: reloadTitle, disabled: props.loading, onClick: props.loading ? _lodash.noop : props.onReloadClick, to: { pathname: props.location.pathname, query: (0, _extends3.default)({}, props.location.query, { reload: props.reloadTime }) } }, _react2.default.createElement(_icon2.default, { symbol: 'reload' }) ), _react2.default.createElement( _reactRouter.Link, { className: rulersClassName, title: rulersTitle, to: { pathname: props.location.pathname, query: (0, _extends3.default)({}, props.location.query, { rulers: !props.rulers }) } }, _react2.default.createElement(_icon2.default, { symbol: 'rulers' }) ), _react2.default.createElement( _reactRouter.Link, { className: opacityClassName, title: opacityTitle, to: { pathname: props.location.pathname, query: (0, _extends3.default)({}, props.location.query, { opacity: !props.opacity }) } }, _react2.default.createElement(_icon2.default, { symbol: opacitySymbol }) ), _react2.default.createElement( 'a', { className: 'button fullscreen', target: '_blank', rel: 'noopener', href: fullscreen, title: fullscreenTitle }, _react2.default.createElement(_icon2.default, { symbol: 'fullscreen' }) ) ) ); } PatternHeader.defaultProps = { tags: [], onReloadClick: _lodash.noop }; module.exports = exports['default']; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../source/application/components/pattern/pattern-header.js"],"names":["PatternHeader","autoMount","props","flagClassName","flag","fullscreen","format","pathname","base","id","query","environment","fullscreenTitle","name","reloadTitle","reloadClassName","loading","errored","rulersTitle","rulers","rulersClassName","opacityClassName","opacity","opacitySymbol","opacityTitle","breadcrumbs","location","version","search","tags","map","tag","key","automount","onReloadClick","reload","reloadTime","defaultProps"],"mappings":"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","file":"pattern-header.js","sourcesContent":["import React, {PropTypes as t} from 'react';\nimport {Link} from '@marionebl/react-router';\nimport join from 'classnames';\nimport {noop} from 'lodash';\n\nimport BreadCrumbs from '../bread-crumbs';\nimport Headline from '../common/headline';\nimport Icon from '../common/icon';\nimport urlQuery from '../../utils/url-query';\n\nconst autoMount = 'https://github.com/sinnerschrader/patternplate-transform-react-to-markup#component-auto-mounting';\n\nexport default function PatternHeader(props) {\n\tconst flagClassName = join(`pattern__flag`, {\n\t\t[`pattern__flag--${props.flag}`]: props.flag\n\t});\n\n\tconst fullscreen = urlQuery.format({\n\t\tpathname: `${props.base}demo/${props.id}/index.html`,\n\t\tquery: {\n\t\t\tenvironment: props.environment\n\t\t}\n\t});\n\tconst fullscreenTitle = `Open \"${props.name}\" in fullscreen [ctrl+f]`;\n\n\tconst reloadTitle = `Reload demo for \"${props.name}\" [ctrl+r]`;\n\tconst reloadClassName = join(\n\t\t'button',\n\t\t'button--reload',\n\t\t{\n\t\t\t'reload--reloading': props.loading,\n\t\t\t'button--is-active': props.loading,\n\t\t\t'reload--error': props.errored\n\t\t}\n\t);\n\n\tconst rulersTitle = props.rulers ?\n\t\t`Disable rulers [ctrl+l]` :\n\t\t`Enable rulers [ctrl+l]`;\n\n\tconst rulersClassName = join(\n\t\t`button button--rulers`,\n\t\t{\n\t\t\t'button--is-active': props.rulers\n\t\t}\n\t);\n\n\tconst opacityClassName = join(\n\t\t'button button--opacity',\n\t\t{\n\t\t\t'button--is-active': props.opacity\n\t\t}\n\t);\n\tconst opacitySymbol = props.opacity ? 'checkers' : 'checkers-inverted';\n\tconst opacityTitle = props.opacity ?\n\t\t'Hide opacity [ctrl+o]':\n\t\t'Show opacity [ctrl+o]';\n\n\treturn (\n\t\t<div className=\"pattern-header-container\">\n\t\t\t<BreadCrumbs\n\t\t\t\tbase={props.base}\n\t\t\t\tcrumbs={props.breadcrumbs}\n\t\t\t\tlocation={props.location}\n\t\t\t\tclassName=\"pattern-path\"\n\t\t\t\t/>\n\t\t\t<Headline className=\"pattern-header\" order={2}>\n\t\t\t\t<span className=\"pattern-name\">\n\t\t\t\t\t{props.name}\n\t\t\t\t</span>\n\t\t\t\t<small className=\"pattern-version\">\n\t\t\t\t\t{props.version ? `v${props.version}` : ''}\n\t\t\t\t</small>\n\t\t\t\t{\n\t\t\t\t\tprops.flag ?\n\t\t\t\t\t\t<small className={flagClassName}>\n\t\t\t\t\t\t\t<Link\n\t\t\t\t\t\t\t\ttitle={`Search patterns with flag ${props.flag}`}\n\t\t\t\t\t\t\t\tto={{\n\t\t\t\t\t\t\t\t\tpathname: props.location.pathname,\n\t\t\t\t\t\t\t\t\tquery: {...props.location.query, search: `flag:${props.flag}`}\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t{props.flag}\n\t\t\t\t\t\t\t</Link>\n\t\t\t\t\t\t</small> :\n\t\t\t\t\t\tnull\n\t\t\t\t}\n\t\t\t\t{props.tags.map((tag, key) =>\n\t\t\t\t\t<small key={key} className=\"pattern-tag\">\n\t\t\t\t\t\t<Link\n\t\t\t\t\t\t\ttitle={`Search patterns with tag ${tag}`}\n\t\t\t\t\t\t\tto={{\n\t\t\t\t\t\t\t\tpathname: props.location.pathname,\n\t\t\t\t\t\t\t\tquery: {...props.location.query, search: `tag:${tag}`}\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\tkey={key}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{tag}\n\t\t\t\t\t\t</Link>\n\t\t\t\t\t</small>\n\t\t\t\t)}\n\t\t\t\t{\n\t\t\t\t\tprops.automount &&\n\t\t\t\t\t\t<small className=\"pattern-option\">\n\t\t\t\t\t\t\t<a\n\t\t\t\t\t\t\t\thref={autoMount}\n\t\t\t\t\t\t\t\ttarget=\"_blank\"\n\t\t\t\t\t\t\t\ttitle=\"Learn about component auto mounting on Github\"\n\t\t\t\t\t\t\t\trel=\"noopener\"\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\tauto-mount\n\t\t\t\t\t\t\t</a>\n\t\t\t\t\t\t</small>\n\t\t\t\t}\n\t\t\t</Headline>\n\t\t\t<div className=\"pattern-header__actions\">\n\t\t\t\t<Link\n\t\t\t\t\tclassName={reloadClassName}\n\t\t\t\t\ttitle={reloadTitle}\n\t\t\t\t\tdisabled={props.loading}\n\t\t\t\t\tonClick={props.loading ? noop : props.onReloadClick}\n\t\t\t\t\tto={{\n\t\t\t\t\t\tpathname: props.location.pathname,\n\t\t\t\t\t\tquery: {\n\t\t\t\t\t\t\t...props.location.query,\n\t\t\t\t\t\t\treload: props.reloadTime\n\t\t\t\t\t\t}\n\t\t\t\t\t}}\n\t\t\t\t\t>\n\t\t\t\t\t<Icon symbol=\"reload\"/>\n\t\t\t\t</Link>\n\t\t\t\t<Link\n\t\t\t\t\tclassName={rulersClassName}\n\t\t\t\t\ttitle={rulersTitle}\n\t\t\t\t\tto={{\n\t\t\t\t\t\tpathname: props.location.pathname,\n\t\t\t\t\t\tquery: {\n\t\t\t\t\t\t\t...props.location.query,\n\t\t\t\t\t\t\trulers: !props.rulers\n\t\t\t\t\t\t}\n\t\t\t\t\t}}\n\t\t\t\t\t>\n\t\t\t\t\t<Icon symbol=\"rulers\"/>\n\t\t\t\t</Link>\n\t\t\t\t<Link\n\t\t\t\t\tclassName={opacityClassName}\n\t\t\t\t\ttitle={opacityTitle}\n\t\t\t\t\tto={{\n\t\t\t\t\t\tpathname: props.location.pathname,\n\t\t\t\t\t\tquery: {\n\t\t\t\t\t\t\t...props.location.query,\n\t\t\t\t\t\t\topacity: !props.opacity\n\t\t\t\t\t\t}\n\t\t\t\t\t}}\n\t\t\t\t\t>\n\t\t\t\t\t<Icon symbol={opacitySymbol}/>\n\t\t\t\t</Link>\n\t\t\t\t<a\n\t\t\t\t\tclassName=\"button fullscreen\"\n\t\t\t\t\ttarget=\"_blank\"\n\t\t\t\t\trel=\"noopener\"\n\t\t\t\t\thref={fullscreen}\n\t\t\t\t\ttitle={fullscreenTitle}\n\t\t\t\t\t>\n\t\t\t\t\t<Icon symbol=\"fullscreen\"/>\n\t\t\t\t</a>\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n\nPatternHeader.propTypes = {\n\tautomount: t.bool.isRequired,\n\tbase: t.string.isRequired,\n\tbreadcrumbs: t.arrayOf(t.shape({\n\t\tid: t.string.isRequired,\n\t\tname: t.string.isRequired,\n\t\ttarget: t.shape({\n\t\t\tpathname: t.string.isRequired,\n\t\t\tquery: t.object.isRequired\n\t\t}).isRequired\n\t})).isRequired,\n\tenvironment: t.string.isRequired,\n\terrored: t.bool.isRequired,\n\tflag: t.string,\n\tid: t.string.isRequired,\n\tloading: t.bool.isRequired,\n\tlocation: t.shape({\n\t\tpathname: t.string.isRequired,\n\t\tquery: t.object.isRequired\n\t}),\n\tname: t.string.isRequired,\n\tonReloadClick: t.func.isRequired,\n\topacity: t.bool.isRequired,\n\treloadTime: t.number,\n\treloadedTime: t.number,\n\trulers: t.bool.isRequired,\n\ttags: t.arrayOf(t.string),\n\tversion: t.string.isRequired\n};\n\nPatternHeader.defaultProps = {\n\ttags: [],\n\tonReloadClick: noop\n};\n"]}