UNPKG

patternplate-client

Version:

Universal javascript client application for patternplate

213 lines (171 loc) 15.3 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = undefined; var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); 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, _temp2; var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _prettyData = require('pretty-data'); var _autobindDecorator = require('autobind-decorator'); var _autobindDecorator2 = _interopRequireDefault(_autobindDecorator); var _pureRenderDecorator = require('pure-render-decorator'); var _pureRenderDecorator2 = _interopRequireDefault(_pureRenderDecorator); var _code = require('../common/code'); var _code2 = _interopRequireDefault(_code); var _select = require('../common/select'); var _select2 = _interopRequireDefault(_select); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var PatternCode = (0, _pureRenderDecorator2.default)(_class = (0, _autobindDecorator2.default)(_class = (_temp2 = _class2 = function (_React$Component) { (0, _inherits3.default)(PatternCode, _React$Component); function PatternCode() { var _ref; var _temp, _this, _ret; (0, _classCallCheck3.default)(this, PatternCode); for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = PatternCode.__proto__ || (0, _getPrototypeOf2.default)(PatternCode)).call.apply(_ref, [this].concat(args))), _this), _this.state = { copying: false }, _this.timeout = null, _this.idle = null, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); } (0, _createClass3.default)(PatternCode, [{ key: 'componentWillUnmount', value: function componentWillUnmount() { if (this.timeout) { global.clearTimeout(this.timeout); } } }, { key: 'saveReference', value: function saveReference(ref) { this.ref = ref; } }, { key: 'handleCopyClick', value: function handleCopyClick() { var _this2 = this; if (this.ref && !this.state.copying) { this.ref.focus(); this.ref.select(); global.document.execCommand('copy'); this.setState((0, _extends3.default)({}, this.state, { copying: true })); this.timeout = setTimeout(function () { _this2.setState((0, _extends3.default)({}, _this2.state, { copying: false })); }, 3000); } } }, { key: 'render', value: function render() { var props = this.props; var prettify = props.highlight && props.format === 'html'; var source = prettify ? _prettyData.pd.xml(props.source) : props.source; var copying = this.state.copying; var concern = { value: props.concern, name: '' + props.concern + props.extname }; var concerns = this.props.concerns.map(function (concern) { return { name: '' + concern + props.extname, value: concern }; }); var type = { value: this.props.type, name: this.props.type }; var types = this.props.types.map(function (type) { return { name: type, value: type }; }); return _react2.default.createElement( 'div', { className: 'pattern-code' }, _react2.default.createElement( 'div', { className: 'pattern-code__toolbar' }, _react2.default.createElement( 'div', { className: 'pattern-code__name' }, concerns.length > 1 ? _react2.default.createElement(_select2.default, { base: props.base, className: 'pattern-code__concern', options: concerns, onChange: props.onConcernChange, value: concern }) : _react2.default.createElement( 'span', { className: 'pattern-code__concern' }, concern.name ), types.length > 1 ? _react2.default.createElement(_select2.default, { base: props.base, className: 'pattern-code__type', options: types, onChange: props.onTypeChange, value: type }) : _react2.default.createElement( 'span', { className: 'pattern-code__type' }, type.name ) ), _react2.default.createElement( 'div', { className: 'pattern-code__tools' }, props.copy && _react2.default.createElement( 'button', { type: 'button', onClick: this.handleCopyClick }, copying ? 'Copied!' : 'Copy to clipboard' ) ) ), _react2.default.createElement( 'div', { className: 'pattern-code__content' }, _react2.default.createElement( 'pre', null, _react2.default.createElement( _code2.default, { highlights: props.highlights, highlight: props.requestHighlight, language: props.format }, source ) ), _react2.default.createElement('textarea', { className: 'clipboard', value: source, ref: this.saveReference, readOnly: true }) ) ); } }]); return PatternCode; }(_react2.default.Component), _class2.defaultProps = { // format: 'html', highlight: true, copy: true }, _temp2)) || _class) || _class; exports.default = PatternCode; module.exports = exports['default']; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../source/application/components/pattern/pattern-code.js"],"names":["PatternCode","state","copying","timeout","idle","global","clearTimeout","ref","focus","select","document","execCommand","setState","setTimeout","props","prettify","highlight","format","source","xml","concern","value","name","extname","concerns","map","type","types","length","base","onConcernChange","onTypeChange","copy","handleCopyClick","highlights","requestHighlight","saveReference","Component","defaultProps"],"mappings":"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","file":"pattern-code.js","sourcesContent":["import React, {PropTypes as types} from 'react';\nimport {pd as pretty} from 'pretty-data';\nimport autobind from 'autobind-decorator';\nimport pure from 'pure-render-decorator';\n\nimport Code from '../common/code';\nimport Select from '../common/select';\n\n@pure\n@autobind\nexport default class PatternCode extends React.Component {\n\tstatic propTypes = {\n\t\tbase: types.string.isRequired,\n\t\tconcern: types.string.isRequired,\n\t\tconcerns: types.arrayOf(types.string).isRequired,\n\t\tcopy: types.bool,\n\t\textname: types.string.isRequired,\n\t\tformat: types.string.isRequired,\n\t\tid: types.string,\n\t\tname: types.string.isRequired,\n\t\tonConcernChange: types.func.isRequired,\n\t\tonTypeChange: types.func.isRequired,\n\t\tsource: types.string.isRequired,\n\t\ttype: types.string.isRequired,\n\t\ttypes: types.arrayOf(types.string).isRequired\n\t};\n\n\tstatic defaultProps = {\n\t\t// format: 'html',\n\t\thighlight: true,\n\t\tcopy: true\n\t};\n\n\tstate = {\n\t\tcopying: false\n\t};\n\n\ttimeout = null;\n\tidle = null;\n\n\tcomponentWillUnmount() {\n\t\tif (this.timeout) {\n\t\t\tglobal.clearTimeout(this.timeout);\n\t\t}\n\t}\n\n\tsaveReference(ref) {\n\t\tthis.ref = ref;\n\t}\n\n\thandleCopyClick() {\n\t\tif (this.ref && !this.state.copying) {\n\t\t\tthis.ref.focus();\n\t\t\tthis.ref.select();\n\t\t\tglobal.document.execCommand('copy');\n\t\t\tthis.setState({\n\t\t\t\t...this.state,\n\t\t\t\tcopying: true\n\t\t\t});\n\t\t\tthis.timeout = setTimeout(() => {\n\t\t\t\tthis.setState({\n\t\t\t\t\t...this.state,\n\t\t\t\t\tcopying: false\n\t\t\t\t});\n\t\t\t}, 3000);\n\t\t}\n\t}\n\n\trender() {\n\t\tconst {props} = this;\n\t\tconst prettify = props.highlight && props.format === 'html';\n\t\tconst source = prettify ? pretty.xml(props.source) : props.source;\n\t\tconst {copying} = this.state;\n\n\t\tconst concern = {\n\t\t\tvalue: props.concern,\n\t\t\tname: `${props.concern}${props.extname}`\n\t\t};\n\n\t\tconst concerns = this.props.concerns.map(concern => {\n\t\t\treturn {name: `${concern}${props.extname}`, value: concern};\n\t\t});\n\n\t\tconst type = {\n\t\t\tvalue: this.props.type,\n\t\t\tname: this.props.type\n\t\t};\n\n\t\tconst types = this.props.types.map(type => {\n\t\t\treturn {name: type, value: type};\n\t\t});\n\n\t\treturn (\n\t\t\t<div className=\"pattern-code\">\n\t\t\t\t<div className=\"pattern-code__toolbar\">\n\t\t\t\t\t<div className=\"pattern-code__name\">\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tconcerns.length > 1 ?\n\t\t\t\t\t\t\t\t<Select\n\t\t\t\t\t\t\t\t\tbase={props.base}\n\t\t\t\t\t\t\t\t\tclassName=\"pattern-code__concern\"\n\t\t\t\t\t\t\t\t\toptions={concerns}\n\t\t\t\t\t\t\t\t\tonChange={props.onConcernChange}\n\t\t\t\t\t\t\t\t\tvalue={concern}\n\t\t\t\t\t\t\t\t\t/> :\n\t\t\t\t\t\t\t\t<span className=\"pattern-code__concern\">\n\t\t\t\t\t\t\t\t\t{concern.name}\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t}\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttypes.length > 1 ?\n\t\t\t\t\t\t\t\t<Select\n\t\t\t\t\t\t\t\t\tbase={props.base}\n\t\t\t\t\t\t\t\t\tclassName=\"pattern-code__type\"\n\t\t\t\t\t\t\t\t\toptions={types}\n\t\t\t\t\t\t\t\t\tonChange={props.onTypeChange}\n\t\t\t\t\t\t\t\t\tvalue={type}\n\t\t\t\t\t\t\t\t\t/> :\n\t\t\t\t\t\t\t\t<span className=\"pattern-code__type\">\n\t\t\t\t\t\t\t\t\t{type.name}\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t}\n\t\t\t\t\t</div>\n\t\t\t\t\t<div className=\"pattern-code__tools\">\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tprops.copy &&\n\t\t\t\t\t\t\t\t<button type=\"button\" onClick={this.handleCopyClick}>\n\t\t\t\t\t\t\t\t\t{copying ? 'Copied!' : 'Copy to clipboard'}\n\t\t\t\t\t\t\t\t</button>\n\t\t\t\t\t\t}\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"pattern-code__content\">\n\t\t\t\t\t<pre>\n\t\t\t\t\t\t<Code\n\t\t\t\t\t\t\thighlights={props.highlights}\n\t\t\t\t\t\t\thighlight={props.requestHighlight}\n\t\t\t\t\t\t\tlanguage={props.format}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{source}\n\t\t\t\t\t\t</Code>\n\t\t\t\t\t</pre>\n\t\t\t\t\t<textarea\n\t\t\t\t\t\tclassName=\"clipboard\"\n\t\t\t\t\t\tvalue={source}\n\t\t\t\t\t\tref={this.saveReference}\n\t\t\t\t\t\treadOnly\n\t\t\t\t\t\t/>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n}\n"]}