patternplate-client
Version:
Universal javascript client application for patternplate
216 lines (186 loc) • 18.4 kB
JavaScript
'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"]}