From f03c1eba10f78e09a4ed786e2c81bcef7a0183b9 Mon Sep 17 00:00:00 2001 From: Denys Bohdan Date: Mon, 6 Nov 2023 15:48:44 +0100 Subject: [PATCH 1/2] UIIN-2497 Show Instance record after creating with Fast add option --- CHANGELOG.md | 1 + src/components/InstancesList/InstancesList.js | 13 ++++++++++++- 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 6ff4e1896..1e50ca239 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,6 +6,7 @@ * Make Inventory search and browse query boxes expandable. Refs UIIN-2493. * Added support for `containsAny` match option in Advanced search. Refs UIIN-2486. * Inventory search/browse: Do not retain checkbox selections when toggling search segment. Refs UIIN-2477. +* Show Instance record after creating with Fast add option. Refs UIIN-2497. ## [10.0.2] IN PROGRESS diff --git a/src/components/InstancesList/InstancesList.js b/src/components/InstancesList/InstancesList.js index 83dce4f6b..1e368095b 100644 --- a/src/components/InstancesList/InstancesList.js +++ b/src/components/InstancesList/InstancesList.js @@ -544,7 +544,18 @@ class InstancesList extends React.Component { } } - toggleNewFastAddModal = () => { + toggleNewFastAddModal = ({ instanceRecord }) => { + const { + history, + location, + } = this.props; + + if (instanceRecord?.id) { + history.push({ + pathname: `/inventory/view/${instanceRecord.id}`, + search: location.search, + }); + } this.setState((state) => { return { showNewFastAddModal: !state.showNewFastAddModal }; }); From a4dc05bab2cb3d65de69f9bda0b8020f4398a0ed Mon Sep 17 00:00:00 2001 From: Denys Bohdan Date: Tue, 7 Nov 2023 12:47:04 +0100 Subject: [PATCH 2/2] UIIN-2497 Added tests for fast add record redirect --- src/components/InstancesList/InstancesList.js | 1 + .../InstancesList/InstancesList.test.js | 37 +++++++++++++++++++ 2 files changed, 38 insertions(+) diff --git a/src/components/InstancesList/InstancesList.js b/src/components/InstancesList/InstancesList.js index 1e368095b..7d0e67f4a 100644 --- a/src/components/InstancesList/InstancesList.js +++ b/src/components/InstancesList/InstancesList.js @@ -556,6 +556,7 @@ class InstancesList extends React.Component { search: location.search, }); } + this.setState((state) => { return { showNewFastAddModal: !state.showNewFastAddModal }; }); diff --git a/src/components/InstancesList/InstancesList.test.js b/src/components/InstancesList/InstancesList.test.js index cb1324a32..fc4d6ffc2 100644 --- a/src/components/InstancesList/InstancesList.test.js +++ b/src/components/InstancesList/InstancesList.test.js @@ -47,6 +47,16 @@ jest.mock('../../hooks', () => ({ }), })); +jest.mock('@folio/stripes/core', () => ({ + ...jest.requireActual('@folio/stripes/core'), + Pluggable: ({ renderTrigger, onClose }) => ( + <> + {renderTrigger()} + + + ), +})); + const data = { contributorTypes: [], contributorNameTypes: [], @@ -331,6 +341,33 @@ describe('InstancesList', () => { }); }); + describe('"New Fast Add record" button', () => { + it('should render', () => { + renderInstancesList({ segment: 'instances' }); + openActionMenu(); + + expect(screen.getByRole('button', { name: 'New Fast Add Record' })).toBeInTheDocument(); + }); + + describe('when saving the record', () => { + it('should redirect to new Instance record', async () => { + jest.spyOn(history, 'push'); + renderInstancesList({ segment: 'instances' }); + openActionMenu(); + + const button = screen.getByRole('button', { name: 'New Fast Add Record' }); + + fireEvent.click(button); + fireEvent.click(screen.getByText('Save & close')); + + expect(history.push).toHaveBeenCalledWith({ + pathname: '/inventory/view/fast-add-record-id', + search: '', + }); + }); + }); + }); + describe('"New MARC Bib Record" button', () => { it('should render', () => { renderInstancesList({ segment: 'instances' });