cspace-ui
Version:
CollectionSpace user interface for browsers
336 lines (333 loc) • 12.6 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.confirmUnrelateModalName = void 0;
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _immutable = _interopRequireDefault(require("immutable"));
var _reactIntl = require("react-intl");
var _get = _interopRequireDefault(require("lodash/get"));
var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
var _RelationButtonBar = _interopRequireDefault(require("./RelationButtonBar"));
var _WorkflowStateIcon = _interopRequireDefault(require("./WorkflowStateIcon"));
var _RecordEditorContainer = _interopRequireDefault(require("../../containers/record/RecordEditorContainer"));
var _ConfirmRecordUnrelateModal = _interopRequireDefault(require("./ConfirmRecordUnrelateModal"));
var _modalNames = require("../../constants/modalNames");
var _permissionHelpers = require("../../helpers/permissionHelpers");
var _recordDataHelpers = require("../../helpers/recordDataHelpers");
var _RelationEditor = _interopRequireDefault(require("../../../styles/cspace-ui/RelationEditor.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; }
function _extends() { _extends = Object.assign ? Object.assign.bind() : 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; }; return _extends.apply(this, arguments); }
const confirmUnrelateModalName = exports.confirmUnrelateModalName = `RelationEditor-${_modalNames.MODAL_CONFIRM_RECORD_UNRELATE}`;
const messages = (0, _reactIntl.defineMessages)({
editTitle: {
"id": "relationEditor.editTitle",
"defaultMessage": "Related {recordTypeName}"
},
newTitle: {
"id": "relationEditor.newTitle",
"defaultMessage": "New Related {recordTypeName}"
},
notFound: {
"id": "relationEditor.notFound",
"defaultMessage": "Not Found"
},
noRelation: {
"id": "relationEditor.noRelation",
"defaultMessage": "There is no related record with CSID \"{csid}\" and type \"{recordType}\"."
}
});
const propTypes = {
cloneCsid: _propTypes.default.string,
config: _propTypes.default.shape({
recordTypes: _propTypes.default.object
}),
perms: _propTypes.default.instanceOf(_immutable.default.Map),
// TODO: These uses aren't properly detected. Try updating eslint-plugin-react.
/* eslint-disable react/no-unused-prop-types */
subject: _propTypes.default.shape({
csid: _propTypes.default.string,
recordType: _propTypes.default.string
}),
subjectWorkflowState: _propTypes.default.string,
object: _propTypes.default.shape({
csid: _propTypes.default.string,
recordType: _propTypes.default.string
}),
/* eslint-enable react/no-unused-prop-types */
objectData: _propTypes.default.instanceOf(_immutable.default.Map),
objectError: _propTypes.default.instanceOf(_immutable.default.Map),
openModalName: _propTypes.default.string,
predicate: _propTypes.default.string,
findResult: _propTypes.default.instanceOf(_immutable.default.Map),
cloneRecord: _propTypes.default.func,
createRelation: _propTypes.default.func,
findRelation: _propTypes.default.func,
closeModal: _propTypes.default.func,
openModal: _propTypes.default.func,
unrelate: _propTypes.default.func,
onClose: _propTypes.default.func,
onRecordCreated: _propTypes.default.func,
onRecordTransitioned: _propTypes.default.func,
onUnmount: _propTypes.default.func,
onUnrelated: _propTypes.default.func
};
const contextTypes = {
intl: _reactIntl.intlShape
};
class RelationEditor extends _react.Component {
constructor() {
super();
this.handleCancelButtonClick = this.handleCancelButtonClick.bind(this);
this.handleCloseButtonClick = this.handleCloseButtonClick.bind(this);
this.handleConfirmUnrelateButtonClick = this.handleConfirmUnrelateButtonClick.bind(this);
this.handleUnrelateButtonClick = this.handleUnrelateButtonClick.bind(this);
this.handleModalCancelButtonClick = this.handleModalCancelButtonClick.bind(this);
this.handleRecordCreated = this.handleRecordCreated.bind(this);
this.handleRecordTransitioned = this.handleRecordTransitioned.bind(this);
this.handleSaveCancelled = this.handleSaveCancelled.bind(this);
}
componentDidMount() {
this.initRelation();
}
componentDidUpdate(prevProps) {
const {
subject,
object,
predicate,
findResult
} = this.props;
const {
subject: prevSubject,
object: prevObject,
predicate: prevPredicate,
findResult: prevFindResult
} = prevProps;
if (!(0, _isEqual.default)(subject, prevSubject) || !(0, _isEqual.default)(object, prevObject) || predicate !== prevPredicate || !findResult && prevFindResult) {
this.initRelation();
}
}
componentWillUnmount() {
const {
onUnmount
} = this.props;
if (this.unrelateWhenUnmounted) {
this.unrelate();
}
if (onUnmount) {
onUnmount();
}
}
handleCancelButtonClick() {
this.close();
}
handleCloseButtonClick() {
this.close();
}
handleConfirmUnrelateButtonClick() {
const {
closeModal
} = this.props;
if (closeModal) {
closeModal(false);
}
this.unrelateWhenUnmounted = true;
this.close();
}
handleModalCancelButtonClick() {
const {
closeModal
} = this.props;
if (closeModal) {
closeModal(false);
}
}
handleUnrelateButtonClick() {
const {
openModal
} = this.props;
if (openModal) {
openModal(confirmUnrelateModalName);
}
}
handleRecordCreated(newRecordCsid, isNavigating) {
const {
subject,
predicate,
createRelation,
onRecordCreated
} = this.props;
if (createRelation) {
const object = {
csid: newRecordCsid
};
return createRelation(subject, object, predicate).then(() => onRecordCreated ? onRecordCreated(newRecordCsid, isNavigating) : null);
}
return null;
}
handleRecordTransitioned(transitionName) {
const {
onRecordTransitioned
} = this.props;
if (transitionName === 'delete') {
this.close();
}
if (onRecordTransitioned) {
onRecordTransitioned(transitionName);
}
}
handleSaveCancelled() {
// This handles unrelating an unsaved record. The confirm navigation dialog will be shown, and
// if it's cancelled, we shouldn't unrelate.
this.unrelateWhenUnmounted = false;
}
close() {
const {
onClose
} = this.props;
if (onClose) {
onClose();
}
}
initRelation() {
const {
config,
subject,
object,
predicate,
findRelation
} = this.props;
if (findRelation && object.csid) {
findRelation(config, subject, object, predicate);
}
}
unrelate() {
const {
config,
subject,
object,
predicate,
unrelate,
onUnrelated
} = this.props;
if (unrelate) {
unrelate(config, subject, object, predicate).then(() => {
if (onUnrelated) {
onUnrelated(subject, object, predicate);
}
});
}
}
renderHeader() {
const {
config,
perms,
subject,
subjectWorkflowState,
object,
objectData
} = this.props;
const {
intl
} = this.context;
const recordTypeConfig = config.recordTypes[object.recordType];
const recordTitle = recordTypeConfig.title(objectData, {
config,
intl
});
const recordTypeName = /*#__PURE__*/_react.default.createElement(_reactIntl.FormattedMessage, (0, _get.default)(recordTypeConfig, ['messages', 'record', 'name']));
const values = {
recordTypeName
};
const title = object.csid ? /*#__PURE__*/_react.default.createElement(_reactIntl.FormattedMessage, _extends({}, messages.editTitle, {
values: values
})) : /*#__PURE__*/_react.default.createElement(_reactIntl.FormattedMessage, _extends({}, messages.newTitle, {
values: values
}));
const objectWorkflowState = (0, _recordDataHelpers.getWorkflowState)(objectData);
const objectWorkflowStateIcon = /*#__PURE__*/_react.default.createElement(_WorkflowStateIcon.default, {
value: objectWorkflowState
});
const isUnrelatable = subjectWorkflowState !== 'locked' && objectWorkflowState !== 'locked' && (0, _permissionHelpers.canUnrelate)(subject.recordType, perms, config) && (0, _permissionHelpers.canUnrelate)(object.recordType, perms, config);
return /*#__PURE__*/_react.default.createElement("header", null, /*#__PURE__*/_react.default.createElement("h3", null, title), /*#__PURE__*/_react.default.createElement("div", null, objectWorkflowStateIcon, /*#__PURE__*/_react.default.createElement("h1", null, recordTitle), /*#__PURE__*/_react.default.createElement(_RelationButtonBar.default, {
isUnrelatable: isUnrelatable,
object: object,
onCancelButtonClick: this.handleCancelButtonClick,
onCloseButtonClick: this.handleCloseButtonClick,
onUnrelateButtonClick: this.handleUnrelateButtonClick
})));
}
renderConfirmRecordUnrelateModal() {
const {
config,
object,
objectData,
openModalName
} = this.props;
return /*#__PURE__*/_react.default.createElement(_ConfirmRecordUnrelateModal.default, {
config: config,
recordType: object.recordType,
data: objectData,
isOpen: openModalName === confirmUnrelateModalName,
onCancelButtonClick: this.handleModalCancelButtonClick,
onCloseButtonClick: this.handleModalCancelButtonClick,
onUnrelateButtonClick: this.handleConfirmUnrelateButtonClick
});
}
render() {
const {
cloneRecord,
cloneCsid,
config,
subject,
subjectWorkflowState,
object,
objectError,
findResult
} = this.props;
if (object.csid) {
if (!findResult) {
return null;
}
let isObjectFound = true;
if (objectError) {
isObjectFound = false;
} else {
const list = findResult.get('rel:relations-common-list');
const count = parseInt(list.get('totalItems'), 10);
if (Number.isNaN(count) || count < 1) {
isObjectFound = false;
}
}
if (!isObjectFound) {
// There is no related object record.
return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("h1", null, /*#__PURE__*/_react.default.createElement(_reactIntl.FormattedMessage, messages.notFound)), /*#__PURE__*/_react.default.createElement("p", null, /*#__PURE__*/_react.default.createElement(_reactIntl.FormattedMessage, _extends({}, messages.noRelation, {
values: {
csid: object.csid,
recordType: object.recordType
}
}))));
}
}
return /*#__PURE__*/_react.default.createElement("div", {
className: _RelationEditor.default.common
}, this.renderHeader(), /*#__PURE__*/_react.default.createElement(_RecordEditorContainer.default, {
cloneCsid: cloneCsid,
config: config,
csid: object.csid,
recordType: object.recordType,
relatedSubjectCsid: subject.csid,
relatedSubjectWorkflowState: subjectWorkflowState,
clone: cloneRecord,
onRecordCreated: this.handleRecordCreated,
onRecordTransitioned: this.handleRecordTransitioned,
onSaveCancelled: this.handleSaveCancelled
}), this.renderConfirmRecordUnrelateModal());
}
}
exports.default = RelationEditor;
RelationEditor.propTypes = propTypes;
RelationEditor.contextTypes = contextTypes;