From 020cb7ae943c576de51045d0d5ffb393429734a5 Mon Sep 17 00:00:00 2001 From: Michael Ritter Date: Mon, 30 Sep 2024 16:09:09 -0600 Subject: [PATCH] DRYD-1393: Support Multiple Related Record Sidebars (#239) --- src/actions/search.js | 1 + src/components/record/RecordSidebar.jsx | 10 ++++++++-- src/components/record/RelatedRecordPanel.jsx | 11 ++++++++++- .../components/record/RelatedRecordPanel.spec.jsx | 3 +++ 4 files changed, 22 insertions(+), 3 deletions(-) diff --git a/src/actions/search.js b/src/actions/search.js index 6786cb0cf..57b7f67ab 100644 --- a/src/actions/search.js +++ b/src/actions/search.js @@ -186,6 +186,7 @@ export const search = (config, searchName, searchDescriptor, listType = 'common' pgSz: searchQuery.get('size'), rtSbj: searchQuery.get('rel'), rtPredicate: searchQuery.get('relType'), + servicetag: searchQuery.get('serviceTag'), sn: searchQuery.get('sn'), // accounts screen name dn: searchQuery.get('dn'), // role display name wf_deleted: false, diff --git a/src/components/record/RecordSidebar.jsx b/src/components/record/RecordSidebar.jsx index 4ca5879d9..ec88af34e 100644 --- a/src/components/record/RecordSidebar.jsx +++ b/src/components/record/RecordSidebar.jsx @@ -123,11 +123,15 @@ export default function RecordSidebar(props) { relatedRecords = relatedRecordDescriptors.map((relatedRecordDescriptor) => { const { + id, sort, + serviceTag, recordType: relatedRecordType, columnSet = 'narrow', } = relatedRecordDescriptor; + const panelName = id ? `related${upperFirst(id)}Panel` : `related${upperFirst(relatedRecordType)}Panel`; + return ( ); }); diff --git a/src/components/record/RelatedRecordPanel.jsx b/src/components/record/RelatedRecordPanel.jsx index 5cfea8603..91c571cfb 100644 --- a/src/components/record/RelatedRecordPanel.jsx +++ b/src/components/record/RelatedRecordPanel.jsx @@ -29,6 +29,7 @@ const getSearchDescriptor = (props) => { initialSort, recordRelationUpdatedTimestamp, relatedRecordType, + serviceTag, } = props; return Immutable.fromJS({ @@ -39,6 +40,7 @@ const getSearchDescriptor = (props) => { p: 0, size: config.defaultSearchPanelSize || 5, sort: initialSort, + serviceTag, }, seqID: recordRelationUpdatedTimestamp, }); @@ -69,9 +71,11 @@ const propTypes = { recordType: PropTypes.string, relatedRecordType: PropTypes.string, selectedItems: PropTypes.instanceOf(Immutable.Map), + serviceTag: PropTypes.string, showCheckboxColumn: PropTypes.bool, showSearchButton: PropTypes.bool, showAddButton: PropTypes.bool, + panelId: PropTypes.string, // not set on this prop name yet openModalName: PropTypes.string, closeModal: PropTypes.func, openModal: PropTypes.func, @@ -360,12 +364,17 @@ export default class RelatedRecordPanel extends Component { renderTitle() { const { config, + recordType, relatedRecordType, + panelId, } = this.props; + const sidebarMessage = get(config, ['recordTypes', recordType, 'messages', 'sidebar', panelId]); const collectionNameMessage = get(config, ['recordTypes', relatedRecordType, 'messages', 'record', 'collectionName']); - const collectionName = ; + const collectionName = sidebarMessage != null + ? + : ; return ; } diff --git a/test/specs/components/record/RelatedRecordPanel.spec.jsx b/test/specs/components/record/RelatedRecordPanel.spec.jsx index 7e757c0a2..1bd241c45 100644 --- a/test/specs/components/record/RelatedRecordPanel.spec.jsx +++ b/test/specs/components/record/RelatedRecordPanel.spec.jsx @@ -81,6 +81,7 @@ describe('RelatedRecordPanel', () => { const relatedRecordType = 'group'; const recordRelationUpdatedTimestamp = '2017-03-06T12:05:34.000Z'; const sort = 'objectNumber'; + const serviceTag = 'ownership'; const shallowRenderer = createRenderer(); @@ -93,6 +94,7 @@ describe('RelatedRecordPanel', () => { relatedRecordType={relatedRecordType} recordRelationUpdatedTimestamp={recordRelationUpdatedTimestamp} initialSort={sort} + serviceTag={serviceTag} />, ); @@ -111,6 +113,7 @@ describe('RelatedRecordPanel', () => { relType: 'affects', p: 0, size: 5, + serviceTag, }, seqID: recordRelationUpdatedTimestamp, }));