UNPKG

react-bootstrap-table2-editor

Version:
137 lines (110 loc) 5.43 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } /* eslint no-return-assign: 0 */ var DropDownEditor = function (_Component) { _inherits(DropDownEditor, _Component); function DropDownEditor(props) { _classCallCheck(this, DropDownEditor); var _this = _possibleConstructorReturn(this, (DropDownEditor.__proto__ || Object.getPrototypeOf(DropDownEditor)).call(this, props)); var options = props.options; if (props.getOptions) { options = props.getOptions(_this.setOptions.bind(_this), { row: props.row, column: props.column }) || []; } _this.state = { options: options }; return _this; } _createClass(DropDownEditor, [{ key: 'componentDidMount', value: function componentDidMount() { var _props = this.props, defaultValue = _props.defaultValue, didMount = _props.didMount; this.select.value = defaultValue; this.select.focus(); if (didMount) didMount(); } }, { key: 'setOptions', value: function setOptions(options) { this.setState({ options: options }); } }, { key: 'getValue', value: function getValue() { return this.select.value; } }, { key: 'render', value: function render() { var _this2 = this; var _props2 = this.props, defaultValue = _props2.defaultValue, didMount = _props2.didMount, getOptions = _props2.getOptions, className = _props2.className, rest = _objectWithoutProperties(_props2, ['defaultValue', 'didMount', 'getOptions', 'className']); var editorClass = (0, _classnames2.default)('form-control editor edit-select', className); var attr = _extends({}, rest, { className: editorClass }); return _react2.default.createElement( 'select', _extends({}, attr, { ref: function ref(node) { return _this2.select = node; }, defaultValue: defaultValue }), this.state.options.map(function (_ref) { var label = _ref.label, value = _ref.value; return _react2.default.createElement( 'option', { key: value, value: value }, label ); }) ); } }]); return DropDownEditor; }(_react.Component); DropDownEditor.propTypes = { row: _propTypes2.default.object.isRequired, column: _propTypes2.default.object.isRequired, defaultValue: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.number]), className: _propTypes2.default.string, style: _propTypes2.default.object, options: _propTypes2.default.oneOfType([_propTypes2.default.arrayOf(_propTypes2.default.shape({ label: _propTypes2.default.string, value: _propTypes2.default.any }))]), didMount: _propTypes2.default.func, getOptions: _propTypes2.default.func }; DropDownEditor.defaultProps = { className: '', defaultValue: '', style: {}, options: [], didMount: undefined, getOptions: undefined }; exports.default = DropDownEditor;