instantjob-recruiter-client
Version:
a set of tools for creating an instantjob recruiter react client
96 lines (69 loc) • 2.73 kB
JavaScript
;
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 _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _reactCodemirror = require('react-codemirror');
var _reactCodemirror2 = _interopRequireDefault(_reactCodemirror);
var _auto_bind = require('common/auto_bind');
var _auto_bind2 = _interopRequireDefault(_auto_bind);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
require('codemirror/lib/codemirror.css');
require('codemirror/mode/javascript/javascript');
require('codemirror/keymap/sublime');
require('codemirror/theme/base16-light.css');
var CodeEditor = function (_Component) {
(0, _inherits3.default)(CodeEditor, _Component);
function CodeEditor(props) {
(0, _classCallCheck3.default)(this, CodeEditor);
var _this = (0, _possibleConstructorReturn3.default)(this, (CodeEditor.__proto__ || (0, _getPrototypeOf2.default)(CodeEditor)).call(this, props));
_this.state = {
value: props.value || default_input
};
(0, _auto_bind2.default)(_this);
return _this;
}
(0, _createClass3.default)(CodeEditor, [{
key: 'on_change',
value: function on_change(value) {
this.setState({ value: value });
}
}, {
key: 'on_focus_change',
value: function on_focus_change() {
if (this.state.value != this.props.value) {
this.props.on_change(this.state.value);
}
}
}, {
key: 'render',
value: function render() {
return _react2.default.createElement(_reactCodemirror2.default, {
value: this.state.value || "",
onChange: this.on_change,
onFocusChange: this.on_focus_change,
options: {
lineNumbers: true,
mode: 'javascript',
theme: 'base16-light',
keyMap: 'sublime',
tabSize: 2
}
});
}
}]);
return CodeEditor;
}(_react.Component);
exports.default = CodeEditor;
var default_input = 'function (o) {\n return ""\n}';