UNPKG

cspace-ui

Version:
140 lines (138 loc) 5.77 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _immutable = _interopRequireDefault(require("immutable")); var _SearchToSelectModalContainer = _interopRequireDefault(require("../../containers/search/SearchToSelectModalContainer")); var _InvocationTargetInput = _interopRequireDefault(require("./InvocationTargetInput")); var _ModePickerInput = _interopRequireDefault(require("./ModePickerInput")); var _InvocationDescriptorEditor = _interopRequireDefault(require("../../../styles/cspace-ui/InvocationDescriptorEditor.css")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } const initMode = props => { const { invocationDescriptor, modes, onCommit } = props; const mode = invocationDescriptor && invocationDescriptor.get('mode'); if ((!mode || !modes.includes(mode)) && modes.length > 0 && onCommit) { onCommit(invocationDescriptor.set('mode', modes[0])); } }; const propTypes = { config: _propTypes.default.shape({ recordTypes: _propTypes.default.object }), invocationDescriptor: _propTypes.default.instanceOf(_immutable.default.Map), modes: _propTypes.default.arrayOf(_propTypes.default.string), modeReadOnly: _propTypes.default.bool, invocationTargetReadOnly: _propTypes.default.bool, recordTypes: _propTypes.default.arrayOf(_propTypes.default.string), onCommit: _propTypes.default.func }; const defaultProps = { invocationDescriptor: _immutable.default.Map(), modes: [] }; class InvocationDescriptorEditor extends _react.Component { constructor(props) { super(props); this.handleModePickerCommit = this.handleModePickerCommit.bind(this); this.handleSearchModalAccept = this.handleSearchModalAccept.bind(this); this.handleSearchModalCancelButtonClick = this.handleSearchModalCancelButtonClick.bind(this); this.openSearchModal = this.openSearchModal.bind(this); this.state = { isSearchModalOpen: false }; } componentDidMount() { initMode(this.props); } // eslint-disable-next-line camelcase UNSAFE_componentWillReceiveProps(nextProps) { initMode(nextProps); } handleSearchModalAccept(selectedItems, searchDescriptor) { const { invocationDescriptor, onCommit } = this.props; if (onCommit) { onCommit(invocationDescriptor.set('recordType', searchDescriptor.get('recordType')).set('items', selectedItems)); } this.setState({ isSearchModalOpen: false }); } handleSearchModalCancelButtonClick() { this.setState({ isSearchModalOpen: false }); } handleModePickerCommit(path, value) { const { invocationDescriptor, invocationTargetReadOnly, onCommit } = this.props; if (onCommit) { let nextInvocationDescriptor = invocationDescriptor.set('mode', value); if (!invocationTargetReadOnly) { nextInvocationDescriptor = nextInvocationDescriptor.delete('csid').delete('recordType').delete('items'); } onCommit(nextInvocationDescriptor); } } openSearchModal() { this.setState({ isSearchModalOpen: true }); } render() { const { config, invocationDescriptor, modes, modeReadOnly, invocationTargetReadOnly, recordTypes } = this.props; const { isSearchModalOpen } = this.state; const mode = invocationDescriptor.get('mode'); const recordType = invocationDescriptor.get('recordType'); const allowedRecordTypes = mode === 'group' ? ['group'] : recordTypes; return /*#__PURE__*/_react.default.createElement("div", { className: _InvocationDescriptorEditor.default.common }, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_ModePickerInput.default, { modes: modes, readOnly: modeReadOnly || modes.length < 2, value: mode, onCommit: this.handleModePickerCommit }), /*#__PURE__*/_react.default.createElement(_InvocationTargetInput.default, { config: config, mode: mode, readOnly: invocationTargetReadOnly, openSearchModal: this.openSearchModal, value: invocationDescriptor.get('items') })), /*#__PURE__*/_react.default.createElement(_SearchToSelectModalContainer.default, { allowedRecordTypes: allowedRecordTypes, config: config, isOpen: isSearchModalOpen, recordTypeValue: recordType, singleSelect: mode === 'single' || mode === 'group', onAccept: this.handleSearchModalAccept, onCancelButtonClick: this.handleSearchModalCancelButtonClick, onCloseButtonClick: this.handleSearchModalCancelButtonClick })); } } exports.default = InvocationDescriptorEditor; InvocationDescriptorEditor.propTypes = propTypes; InvocationDescriptorEditor.defaultProps = defaultProps;