cspace-ui
Version:
CollectionSpace user interface for browsers
140 lines (138 loc) • 5.77 kB
JavaScript
"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;