patternplate-client
Version:
Universal javascript client application for patternplate
181 lines (143 loc) • 14.4 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of');
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _class, _class2, _temp;
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _reactRedux = require('react-redux');
var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
var _autobindDecorator = require('autobind-decorator');
var _autobindDecorator2 = _interopRequireDefault(_autobindDecorator);
var _markBlock = require('../../actions/mark-block');
var _markBlock2 = _interopRequireDefault(_markBlock);
var _block = require('./block');
var _block2 = _interopRequireDefault(_block);
var _blockColumn = require('./block-column');
var _blockColumn2 = _interopRequireDefault(_blockColumn);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var PatternDependencies = (0, _autobindDecorator2.default)(_class = (_temp = _class2 = function (_Component) {
(0, _inherits3.default)(PatternDependencies, _Component);
function PatternDependencies() {
(0, _classCallCheck3.default)(this, PatternDependencies);
return (0, _possibleConstructorReturn3.default)(this, (PatternDependencies.__proto__ || (0, _getPrototypeOf2.default)(PatternDependencies)).apply(this, arguments));
}
(0, _createClass3.default)(PatternDependencies, [{
key: 'handleClick',
value: function handleClick(props) {
var id = props.id,
base = props.base;
var location = this.props.location;
var router = this.context.router;
router.push({
pathname: base + 'pattern/' + id,
query: location.query
});
}
}, {
key: 'handleMouseEnter',
value: function handleMouseEnter(id) {
var dispatch = this.props.dispatch;
dispatch((0, _markBlock2.default)({ id: id, active: true }));
}
}, {
key: 'handleMouseLeave',
value: function handleMouseLeave(id) {
var dispatch = this.props.dispatch;
dispatch((0, _markBlock2.default)({ id: id, active: false }));
}
}, {
key: 'render',
value: function render() {
var _props = this.props,
activeBlock = _props.activeBlock,
passedClassName = _props.className,
dependencies = _props.dependencies,
dependents = _props.dependents,
id = _props.id,
base = _props.base,
name = _props.name,
location = _props.location;
var className = (0, _classnames2.default)('pattern-dependencies', passedClassName);
var blockHeight = 4;
var center = 50;
var rootWidth = Math.max(5, name.length * 1.25);
var paddingX = 1;
var rootY = 1;
var columnY = 2;
var offsetY = Math.max(rootY, columnY);
var rootHeight = blockHeight;
var rootYCenter = rootY + rootHeight / 2;
var blockSpace = blockHeight + 1;
var viewBoxHeight = Math.max(Math.max(dependencies.length, dependents.length) * blockSpace + offsetY + 2, blockSpace + offsetY + 2);
return _react2.default.createElement(
'div',
{ className: className },
_react2.default.createElement(
'svg',
{ viewBox: '0 0 100 ' + viewBoxHeight, className: 'pattern-dependencies__stage' },
_react2.default.createElement(_blockColumn2.default, {
activeBlock: activeBlock,
items: dependencies,
base: base,
y: columnY,
x: paddingX,
height: blockHeight,
onClick: this.handleClick,
onMouseEnter: this.handleMouseEnter,
onMouseLeave: this.handleMouseLeave,
description: 'provides for',
location: location,
connect: { x: center - rootWidth / 2, y: rootYCenter }
}),
_react2.default.createElement(_blockColumn2.default, {
activeBlock: activeBlock,
items: dependents,
base: base,
y: columnY,
x: 100,
height: blockHeight,
onClick: this.handleClick,
onMouseEnter: this.handleMouseEnter,
onMouseLeave: this.handleMouseLeave,
align: 'right',
description: 'provides for',
location: location,
connect: { x: center + rootWidth / 2, y: rootYCenter }
}),
_react2.default.createElement(_block2.default, {
type: 'root',
name: name,
id: id,
x: 50 - rootWidth / 2,
y: rootY,
height: rootHeight,
width: rootWidth,
location: location,
base: base
})
)
);
}
}]);
return PatternDependencies;
}(_react.Component), _class2.contextTypes = {
router: _react.PropTypes.any
}, _temp)) || _class;
exports.default = (0, _reactRedux.connect)(function (_ref) {
var activeBlock = _ref.activeBlock;
return { activeBlock: activeBlock };
})(PatternDependencies);
module.exports = exports['default'];
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../source/application/components/pattern/pattern-dependencies.js"],"names":["PatternDependencies","props","id","base","location","router","context","push","pathname","query","dispatch","active","activeBlock","passedClassName","className","dependencies","dependents","name","blockHeight","center","rootWidth","Math","max","length","paddingX","rootY","columnY","offsetY","rootHeight","rootYCenter","blockSpace","viewBoxHeight","handleClick","handleMouseEnter","handleMouseLeave","x","y","contextTypes","any"],"mappings":"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","file":"pattern-dependencies.js","sourcesContent":["import React, {PropTypes as t, Component} from 'react';\nimport {connect} from 'react-redux';\nimport join from 'classnames';\nimport autobind from 'autobind-decorator';\n\nimport markBlock from '../../actions/mark-block';\nimport Block from './block';\nimport BlockColumn from './block-column';\n\n@autobind\nclass PatternDependencies extends Component {\n\tstatic propTypes = {\n\t\tactiveBlock: t.string,\n\t\tbase: t.string.isRequired,\n\t\tclassName: t.string,\n\t\tid: t.string.isRequired,\n\t\tname: t.string.isRequired,\n\t\tdependencies: t.arrayOf(t.shape({\n\t\t\tname: t.string.isRequired,\n\t\t\tid: t.string.isRequired\n\t\t})).isRequired,\n\t\tdependents: t.arrayOf(t.shape({\n\t\t\tname: t.string.isRequired,\n\t\t\tid: t.string.isRequired\n\t\t})).isRequired,\n\t\tlocation: t.shape({\n\t\t\tpathname: t.string,\n\t\t\tquery: t.any\n\t\t})\n\t};\n\n\tstatic contextTypes = {\n\t\trouter: t.any\n\t};\n\n\thandleClick(props) {\n\t\tconst {id, base} = props;\n\t\tconst {location} = this.props;\n\t\tconst {router} = this.context;\n\t\trouter.push({\n\t\t\tpathname: `${base}pattern/${id}`,\n\t\t\tquery: location.query\n\t\t});\n\t}\n\n\thandleMouseEnter(id) {\n\t\tconst {dispatch} = this.props;\n\t\tdispatch(markBlock({id, active: true}));\n\t}\n\n\thandleMouseLeave(id) {\n\t\tconst {dispatch} = this.props;\n\t\tdispatch(markBlock({id, active: false}));\n\t}\n\n\trender() {\n\t\tconst {\n\t\t\tactiveBlock,\n\t\t\tclassName: passedClassName,\n\t\t\tdependencies,\n\t\t\tdependents,\n\t\t\tid,\n\t\t\tbase,\n\t\t\tname,\n\t\t\tlocation\n\t\t} = this.props;\n\n\t\tconst className = join('pattern-dependencies', passedClassName);\n\n\t\tconst blockHeight = 4;\n\t\tconst center = 50;\n\t\tconst rootWidth = Math.max(5, name.length * 1.25);\n\t\tconst paddingX = 1;\n\t\tconst rootY = 1;\n\t\tconst columnY = 2;\n\t\tconst offsetY = Math.max(rootY, columnY);\n\t\tconst rootHeight = blockHeight;\n\t\tconst rootYCenter = rootY + rootHeight / 2;\n\t\tconst blockSpace = blockHeight + 1;\n\t\tconst viewBoxHeight = Math.max(Math.max(dependencies.length, dependents.length) * blockSpace + offsetY + 2, blockSpace + offsetY + 2);\n\n\t\treturn (\n\t\t\t<div className={className}>\n\t\t\t\t<svg viewBox={`0 0 100 ${viewBoxHeight}`} className=\"pattern-dependencies__stage\">\n\t\t\t\t\t<BlockColumn\n\t\t\t\t\t\tactiveBlock={activeBlock}\n\t\t\t\t\t\titems={dependencies}\n\t\t\t\t\t\tbase={base}\n\t\t\t\t\t\ty={columnY}\n\t\t\t\t\t\tx={paddingX}\n\t\t\t\t\t\theight={blockHeight}\n\t\t\t\t\t\tonClick={this.handleClick}\n\t\t\t\t\t\tonMouseEnter={this.handleMouseEnter}\n\t\t\t\t\t\tonMouseLeave={this.handleMouseLeave}\n\t\t\t\t\t\tdescription=\"provides for\"\n\t\t\t\t\t\tlocation={location}\n\t\t\t\t\t\tconnect={{x: center - rootWidth / 2, y: rootYCenter}}\n\t\t\t\t\t\t/>\n\t\t\t\t\t<BlockColumn\n\t\t\t\t\t\tactiveBlock={activeBlock}\n\t\t\t\t\t\titems={dependents}\n\t\t\t\t\t\tbase={base}\n\t\t\t\t\t\ty={columnY}\n\t\t\t\t\t\tx={100}\n\t\t\t\t\t\theight={blockHeight}\n\t\t\t\t\t\tonClick={this.handleClick}\n\t\t\t\t\t\tonMouseEnter={this.handleMouseEnter}\n\t\t\t\t\t\tonMouseLeave={this.handleMouseLeave}\n\t\t\t\t\t\talign=\"right\"\n\t\t\t\t\t\tdescription=\"provides for\"\n\t\t\t\t\t\tlocation={location}\n\t\t\t\t\t\tconnect={{x: center + rootWidth / 2, y: rootYCenter}}\n\t\t\t\t\t\t/>\n\t\t\t\t\t<Block\n\t\t\t\t\t\ttype=\"root\"\n\t\t\t\t\t\tname={name}\n\t\t\t\t\t\tid={id}\n\t\t\t\t\t\tx={50 - rootWidth / 2}\n\t\t\t\t\t\ty={rootY}\n\t\t\t\t\t\theight={rootHeight}\n\t\t\t\t\t\twidth={rootWidth}\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\t</svg>\n\t\t\t</div>\n\t\t);\n\t}\n}\n\nexport default connect(({activeBlock}) => {\n\treturn {activeBlock};\n})(PatternDependencies);\n"]}