UNPKG

cspace-ui

Version:
95 lines (94 loc) 3.82 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 _reactRouterDom = require("react-router-dom"); var _cspaceRefname = require("cspace-refname"); var _refNameHelpers = require("../../helpers/refNameHelpers"); var _HierarchySiblingList = _interopRequireDefault(require("../../../styles/cspace-ui/HierarchySiblingList.css")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); } const propTypes = { config: _propTypes.default.shape({ recordTypes: _propTypes.default.object }), csid: _propTypes.default.string, parentCsid: _propTypes.default.string, recordType: _propTypes.default.string, title: _propTypes.default.node, findResult: _propTypes.default.instanceOf(_immutable.default.Map), findRelations: _propTypes.default.func }; class HierarchySiblingList extends _react.Component { componentDidMount() { this.findRelations(); } componentDidUpdate(prevProps) { const { parentCsid } = this.props; const { parentCsid: prevParentCsid } = prevProps; if (parentCsid !== prevParentCsid) { this.findRelations(); } } findRelations() { const { config, parentCsid, recordType, findRelations } = this.props; if (parentCsid && findRelations) { const subject = { recordType }; const object = { recordType, csid: parentCsid }; findRelations(config, subject, object, 'hasBroader'); } } render() { const { config, csid, findResult, title } = this.props; let siblings; if (findResult) { const list = findResult.get('rel:relations-common-list'); let items = list.get('relation-list-item'); if (items) { if (!_immutable.default.List.isList(items)) { items = _immutable.default.List.of(items); } items = items.filter(item => item.getIn(['subject', 'csid']) !== csid).sort((itemA, itemB) => (itemA.getIn(['subject', 'number']) || '').localeCompare(itemB.getIn(['subject', 'number']) || '')); siblings = items.map(item => { const subject = item.get('subject'); const refName = subject.get('refName'); const displayName = (0, _cspaceRefname.getDisplayName)(refName); const url = (0, _refNameHelpers.refNameToUrl)(config, refName); return /*#__PURE__*/_react.default.createElement("li", { key: subject.get('csid') }, /*#__PURE__*/_react.default.createElement(_reactRouterDom.Link, { to: url }, displayName)); }).toJS(); } } return /*#__PURE__*/_react.default.createElement("div", { className: _HierarchySiblingList.default.common }, /*#__PURE__*/_react.default.createElement("header", null, title), /*#__PURE__*/_react.default.createElement("ul", null, siblings)); } } exports.default = HierarchySiblingList; HierarchySiblingList.propTypes = propTypes;