UNPKG

cspace-ui

Version:
175 lines (171 loc) 6.2 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 _qs = _interopRequireDefault(require("qs")); var _get = _interopRequireDefault(require("lodash/get")); var _immutable = _interopRequireDefault(require("immutable")); var _RecordBrowserNavBarContainer = _interopRequireDefault(require("../../containers/record/RecordBrowserNavBarContainer")); var _RecordEditorContainer = _interopRequireDefault(require("../../containers/record/RecordEditorContainer")); var _RelatedRecordBrowserContainer = _interopRequireDefault(require("../../containers/record/RelatedRecordBrowserContainer")); var _searchHelpers = require("../../helpers/searchHelpers"); var _RecordBrowser = _interopRequireDefault(require("../../../styles/cspace-ui/RecordBrowser.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 propTypes = { cloneCsid: _propTypes.default.string, config: _propTypes.default.shape({ recordTypes: _propTypes.default.object }), csid: _propTypes.default.string, dockTop: _propTypes.default.number, history: _propTypes.default.shape({ push: _propTypes.default.func, replace: _propTypes.default.func }), location: _propTypes.default.shape({ state: _propTypes.default.object }), recordType: _propTypes.default.string, relatedCsid: _propTypes.default.string, relatedRecordType: _propTypes.default.string, vocabulary: _propTypes.default.string, workflowState: _propTypes.default.string, clearPreferredRelatedCsid: _propTypes.default.func, onShowRelated: _propTypes.default.func }; class RecordBrowser extends _react.Component { constructor() { super(); this.cloneRecord = this.cloneRecord.bind(this); this.handleRecordCreated = this.handleRecordCreated.bind(this); this.handleRecordTransitioned = this.handleRecordTransitioned.bind(this); } componentDidUpdate(prevProps) { const { csid } = this.props; const { csid: prevCsid } = prevProps; if (csid !== prevCsid) { this.clearPreferredRelatedCsid(); } } componentWillUnmount() { this.clearPreferredRelatedCsid(); } handleRecordCreated(newRecordCsid, isNavigating) { if (!isNavigating) { const { history, recordType, vocabulary } = this.props; const path = [recordType, vocabulary, newRecordCsid].filter(part => !!part).join('/'); history.replace(`/record/${path}`); } } handleRecordTransitioned(transitionName) { const { history, location } = this.props; if (transitionName === 'delete') { // The record was soft-deleted. const searchDescriptor = (0, _get.default)(location, ['state', 'searchDescriptor']); let newLocation; if (searchDescriptor) { // We came from a search. Return to the search result page. newLocation = (0, _searchHelpers.searchDescriptorToLocation)(_immutable.default.fromJS(searchDescriptor)); } else { // Go to the index page. newLocation = '/'; } history.replace(newLocation); } } clearPreferredRelatedCsid() { const { clearPreferredRelatedCsid } = this.props; if (clearPreferredRelatedCsid) { clearPreferredRelatedCsid(); } } cloneRecord() { const { csid, recordType, vocabulary, history } = this.props; const path = [recordType, vocabulary].filter(part => !!part).join('/'); const query = { clone: csid }; const queryString = _qs.default.stringify(query); history.push({ pathname: `/record/${path}`, search: `?${queryString}` }); } render() { const { cloneCsid, config, csid, dockTop, history, location, recordType, relatedCsid, relatedRecordType, vocabulary, workflowState, onShowRelated } = this.props; let content; if (relatedRecordType) { content = /*#__PURE__*/_react.default.createElement(_RelatedRecordBrowserContainer.default, { cloneCsid: cloneCsid, config: config, history: history, location: location, recordType: recordType, csid: csid, relatedRecordType: relatedRecordType, relatedCsid: relatedCsid, workflowState: workflowState, onShowRelated: onShowRelated }); } else { content = /*#__PURE__*/_react.default.createElement(_RecordEditorContainer.default, { cloneCsid: cloneCsid, config: config, csid: csid, dockTop: dockTop, recordType: recordType, vocabulary: vocabulary, clone: this.cloneRecord, onRecordCreated: this.handleRecordCreated, onRecordTransitioned: this.handleRecordTransitioned }); } return /*#__PURE__*/_react.default.createElement("div", { className: _RecordBrowser.default.common }, /*#__PURE__*/_react.default.createElement(_RecordBrowserNavBarContainer.default, { config: config, csid: csid, recordType: recordType, relatedRecordType: relatedRecordType, onSelect: onShowRelated }), content); } } exports.default = RecordBrowser; RecordBrowser.propTypes = propTypes;