patternplate-client
Version:
Universal javascript client application for patternplate
213 lines (171 loc) • 15.3 kB
JavaScript
'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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;AACA;;AACA;;;;AACA;;;;AAEA;;;;AACA;;;;;;IAIqBA,W;;;;;;;;;;;;;;oNAuBpBC,K,GAAQ;AACPC,YAAS;AADF,G,QAIRC,O,GAAU,I,QACVC,I,GAAO,I;;;;;yCAEgB;AACtB,OAAI,KAAKD,OAAT,EAAkB;AACjBE,WAAOC,YAAP,CAAoB,KAAKH,OAAzB;AACA;AACD;;;gCAEaI,G,EAAK;AAClB,QAAKA,GAAL,GAAWA,GAAX;AACA;;;oCAEiB;AAAA;;AACjB,OAAI,KAAKA,GAAL,IAAY,CAAC,KAAKN,KAAL,CAAWC,OAA5B,EAAqC;AACpC,SAAKK,GAAL,CAASC,KAAT;AACA,SAAKD,GAAL,CAASE,MAAT;AACAJ,WAAOK,QAAP,CAAgBC,WAAhB,CAA4B,MAA5B;AACA,SAAKC,QAAL,4BACI,KAAKX,KADT;AAECC,cAAS;AAFV;AAIA,SAAKC,OAAL,GAAeU,WAAW,YAAM;AAC/B,YAAKD,QAAL,4BACI,OAAKX,KADT;AAECC,eAAS;AAFV;AAIA,KALc,EAKZ,IALY,CAAf;AAMA;AACD;;;2BAEQ;AAAA,OACDY,KADC,GACQ,IADR,CACDA,KADC;;AAER,OAAMC,WAAWD,MAAME,SAAN,IAAmBF,MAAMG,MAAN,KAAiB,MAArD;AACA,OAAMC,SAASH,WAAW,eAAOI,GAAP,CAAWL,MAAMI,MAAjB,CAAX,GAAsCJ,MAAMI,MAA3D;AAHQ,OAIDhB,OAJC,GAIU,KAAKD,KAJf,CAIDC,OAJC;;;AAMR,OAAMkB,UAAU;AACfC,WAAOP,MAAMM,OADE;AAEfE,eAASR,MAAMM,OAAf,GAAyBN,MAAMS;AAFhB,IAAhB;;AAKA,OAAMC,WAAW,KAAKV,KAAL,CAAWU,QAAX,CAAoBC,GAApB,CAAwB,mBAAW;AACnD,WAAO,EAACH,WAASF,OAAT,GAAmBN,MAAMS,OAA1B,EAAqCF,OAAOD,OAA5C,EAAP;AACA,IAFgB,CAAjB;;AAIA,OAAMM,OAAO;AACZL,WAAO,KAAKP,KAAL,CAAWY,IADN;AAEZJ,UAAM,KAAKR,KAAL,CAAWY;AAFL,IAAb;;AAKA,OAAMC,QAAQ,KAAKb,KAAL,CAAWa,KAAX,CAAiBF,GAAjB,CAAqB,gBAAQ;AAC1C,WAAO,EAACH,MAAMI,IAAP,EAAaL,OAAOK,IAApB,EAAP;AACA,IAFa,CAAd;;AAIA,UACC;AAAA;AAAA,MAAK,WAAU,cAAf;AACC;AAAA;AAAA,OAAK,WAAU,uBAAf;AACC;AAAA;AAAA,QAAK,WAAU,oBAAf;AAEEF,eAASI,MAAT,GAAkB,CAAlB,GACC;AACC,aAAMd,MAAMe,IADb;AAEC,kBAAU,uBAFX;AAGC,gBAASL,QAHV;AAIC,iBAAUV,MAAMgB,eAJjB;AAKC,cAAOV;AALR,QADD,GAQC;AAAA;AAAA,SAAM,WAAU,uBAAhB;AACEA,eAAQE;AADV,OAVH;AAeEK,YAAMC,MAAN,GAAe,CAAf,GACC;AACC,aAAMd,MAAMe,IADb;AAEC,kBAAU,oBAFX;AAGC,gBAASF,KAHV;AAIC,iBAAUb,MAAMiB,YAJjB;AAKC,cAAOL;AALR,QADD,GAQC;AAAA;AAAA,SAAM,WAAU,oBAAhB;AACEA,YAAKJ;AADP;AAvBH,MADD;AA6BC;AAAA;AAAA,QAAK,WAAU,qBAAf;AAEER,YAAMkB,IAAN,IACC;AAAA;AAAA,SAAQ,MAAK,QAAb,EAAsB,SAAS,KAAKC,eAApC;AACE/B,iBAAU,SAAV,GAAsB;AADxB;AAHH;AA7BD,KADD;AAuCC;AAAA;AAAA,OAAK,WAAU,uBAAf;AACC;AAAA;AAAA;AACC;AAAA;AAAA;AACC,oBAAYY,MAAMoB,UADnB;AAEC,mBAAWpB,MAAMqB,gBAFlB;AAGC,kBAAUrB,MAAMG;AAHjB;AAKEC;AALF;AADD,MADD;AAUC;AACC,iBAAU,WADX;AAEC,aAAOA,MAFR;AAGC,WAAK,KAAKkB,aAHX;AAIC;AAJD;AAVD;AAvCD,IADD;AA2DA;;;EA7IuC,gBAAMC,S,WAiBvCC,Y,GAAe;AACrB;AACAtB,YAAW,IAFU;AAGrBgB,OAAM;AAHe,C;;kBAjBFhC,W","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"]}