From 57a05f833d9086f0ec180deefb8c95f5cc391c81 Mon Sep 17 00:00:00 2001
From: Oleksandr Hladchenko
<85172747+OleksandrHladchenko1@users.noreply.github.com>
Date: Tue, 7 Jan 2025 14:44:05 +0100
Subject: [PATCH] UIIN-3167: Fix errors after cancel edit/duplicate or 'Save &
Close' consortial holdings/items (#2705)
* UIIN-3167: Fix infinite loading animation after cancel edit/duplicate or 'Save & Close' consortial holdings/items
* UIIN-3167: Fix tests
---
CHANGELOG.md | 1 +
.../DuplicateHolding/DuplicateHolding.js | 6 ++++--
src/Holding/EditHolding/EditHolding.js | 20 +++++++------------
src/Instance/ItemsList/ItemBarcode.js | 2 +-
src/Instance/utils.js | 1 +
src/Item/DuplicateItem/DuplicateItem.js | 5 ++++-
src/Item/EditItem/EditItem.js | 20 +++++++++----------
src/ViewHoldingsRecord.js | 19 ++++++++----------
src/ViewHoldingsRecord.test.js | 6 ++++--
src/routes/ItemRoute.js | 2 +-
src/routes/ViewHoldingRoute.js | 1 +
src/views/ItemView.js | 18 ++++++++++++-----
12 files changed, 54 insertions(+), 47 deletions(-)
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 1b60fe2e5..1beb1e1ce 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -10,6 +10,7 @@
* React 19: refactor away from react-dom/test-utils. Refs UIIN-2888.
* Add call number browse settings. Refs UIIN-3116.
* Add "linked-data 1.0" interface to "optionalOkapiInterfaces". Refs UIIN-3166.
+* Fix infinite loading animation after cancel edit/duplicate or 'Save & Close' consortial holdings/items. Fixes UIIN-3167.
## [12.0.8](https://github.com/folio-org/ui-inventory/tree/v12.0.8) (2024-12-24)
[Full Changelog](https://github.com/folio-org/ui-inventory/compare/v12.0.7...v12.0.8)
diff --git a/src/Holding/DuplicateHolding/DuplicateHolding.js b/src/Holding/DuplicateHolding/DuplicateHolding.js
index 9de3470a5..31835bc4c 100644
--- a/src/Holding/DuplicateHolding/DuplicateHolding.js
+++ b/src/Holding/DuplicateHolding/DuplicateHolding.js
@@ -28,6 +28,7 @@ const DuplicateHolding = ({
state: {
backPathname: locationState,
tenantFrom,
+ initialTenantId,
} = {},
},
referenceTables,
@@ -72,12 +73,13 @@ const DuplicateHolding = ({
history.push({
pathname: locationState?.backPathname ?? `/inventory/view/${instanceId}`,
search,
+ state: { initialTenantId },
});
}, [search, instanceId]);
const onCancel = useCallback(async () => {
- await switchAffiliation(stripes, tenantFrom, goBack);
- }, [stripes, tenantFrom, goBack]);
+ await switchAffiliation(stripes, initialTenantId, goBack);
+ }, [stripes, initialTenantId, goBack]);
const onSubmit = useCallback(holdingValues => (
mutateHolding(holdingValues)
diff --git a/src/Holding/EditHolding/EditHolding.js b/src/Holding/EditHolding/EditHolding.js
index d24841afd..eeafe7e95 100644
--- a/src/Holding/EditHolding/EditHolding.js
+++ b/src/Holding/EditHolding/EditHolding.js
@@ -17,10 +17,7 @@ import {
} from '../../hooks';
import HoldingsForm from '../../edit/holdings/HoldingsForm';
import withLocation from '../../withLocation';
-import {
- parseHttpError,
- switchAffiliation,
-} from '../../utils';
+import { parseHttpError } from '../../utils';
const EditHolding = ({
goTo,
@@ -35,7 +32,7 @@ const EditHolding = ({
search,
state: {
backPathname: locationState,
- tenantFrom,
+ initialTenantId,
} = {},
} = location;
const stripes = useStripes();
@@ -59,16 +56,13 @@ const EditHolding = ({
history.push({
pathname: locationState?.backPathname ?? `/inventory/view/${instanceId}/${holdingId}`,
search,
+ state: { initialTenantId },
});
}, [search, instanceId, holdingId]);
- const onCancel = useCallback(async () => {
- await switchAffiliation(stripes, tenantFrom, goBack);
- }, [stripes, tenantFrom, goBack]);
-
- const onSuccess = useCallback(async () => {
+ const onSuccess = useCallback(() => {
if (!keepEditing.current) {
- await switchAffiliation(stripes, tenantFrom, goBack);
+ goBack();
} else {
refetchHolding();
}
@@ -80,7 +74,7 @@ const EditHolding = ({
values={{ hrid: holding?.hrid }}
/>,
});
- }, [switchAffiliation, stripes, tenantFrom, goBack, refetchHolding, holding, callout]);
+ }, [goBack, refetchHolding, holding, callout]);
const onError = async error => {
const parsedError = await parseHttpError(error.response);
@@ -107,7 +101,7 @@ const EditHolding = ({
location={location}
initialValues={holding}
onSubmit={onSubmit}
- onCancel={onCancel}
+ onCancel={goBack}
okapi={stripes.okapi}
instance={instance}
referenceTables={referenceTables}
diff --git a/src/Instance/ItemsList/ItemBarcode.js b/src/Instance/ItemsList/ItemBarcode.js
index a040eaa47..1ac4e86fd 100644
--- a/src/Instance/ItemsList/ItemBarcode.js
+++ b/src/Instance/ItemsList/ItemBarcode.js
@@ -52,7 +52,7 @@ const ItemBarcode = ({
search,
state: {
tenantTo: tenantId,
- tenantFrom: stripes.okapi.tenant,
+ initialTenantId: stripes.okapi.tenant,
},
});
diff --git a/src/Instance/utils.js b/src/Instance/utils.js
index f8e0f2965..4184d67a8 100644
--- a/src/Instance/utils.js
+++ b/src/Instance/utils.js
@@ -56,6 +56,7 @@ export const navigateToHoldingsViewPage = (history, location, instance, holding,
state: {
tenantTo,
tenantFrom,
+ initialTenantId: tenantFrom,
},
});
};
diff --git a/src/Item/DuplicateItem/DuplicateItem.js b/src/Item/DuplicateItem/DuplicateItem.js
index caa2664ad..ea10999db 100644
--- a/src/Item/DuplicateItem/DuplicateItem.js
+++ b/src/Item/DuplicateItem/DuplicateItem.js
@@ -82,7 +82,10 @@ const DuplicateItem = ({
history.push({
pathname: `/inventory/view/${instanceId}/${holdingId}/${itemId}`,
search: location.search,
- state: { tenantTo: stripes.okapi.tenant },
+ state: {
+ tenantTo: stripes.okapi.tenant,
+ initialTenantId: location?.state?.initialTenantId,
+ },
});
}, [location.search, instanceId, holdingId, itemId]);
diff --git a/src/Item/EditItem/EditItem.js b/src/Item/EditItem/EditItem.js
index 149b26f8e..bf6f3cee3 100644
--- a/src/Item/EditItem/EditItem.js
+++ b/src/Item/EditItem/EditItem.js
@@ -18,7 +18,7 @@ import {
} from '../../common';
import ItemForm from '../../edit/items/ItemForm';
import useCallout from '../../hooks/useCallout';
-import { parseHttpError, switchAffiliation } from '../../utils';
+import { parseHttpError } from '../../utils';
import {
useItem,
useItemMutation,
@@ -49,18 +49,16 @@ const EditItem = ({
history.push({
pathname: `/inventory/view/${instanceId}/${holdingId}/${itemId}`,
search: location.search,
- state: { tenantTo: stripes.okapi.tenant },
+ state: {
+ tenantTo: stripes.okapi.tenant,
+ initialTenantId: location?.state?.initialTenantId,
+ },
});
}, [location.search, instanceId, holdingId, itemId]);
- const onCancel = useCallback(async () => {
- await switchAffiliation(stripes, location?.state?.tenantFrom, goBack);
- }, [stripes, location?.state?.tenantFrom, goBack]);
-
-
- const onSuccess = useCallback(async () => {
+ const onSuccess = useCallback(() => {
if (!keepEditing.current) {
- await switchAffiliation(stripes, location?.state?.tenantFrom, goBack);
+ goBack();
} else {
refetchItem();
}
@@ -72,7 +70,7 @@ const EditItem = ({
values={{ hrid: item.hrid }}
/>,
});
- }, [switchAffiliation, stripes, location, goBack, refetchItem, callout, item]);
+ }, [goBack, refetchItem, callout, item]);
const onError = async error => {
const parsedError = await parseHttpError(error.response);
@@ -129,7 +127,7 @@ const EditItem = ({
key={holding.id}
initialValues={item}
onSubmit={onSubmit}
- onCancel={onCancel}
+ onCancel={goBack}
okapi={stripes.okapi}
instance={instance}
holdingsRecord={holding}
diff --git a/src/ViewHoldingsRecord.js b/src/ViewHoldingsRecord.js
index c722e6973..132d3611a 100644
--- a/src/ViewHoldingsRecord.js
+++ b/src/ViewHoldingsRecord.js
@@ -250,7 +250,7 @@ class ViewHoldingsRecord extends React.Component {
stripes,
location,
} = this.props;
- const tenantFrom = location?.state?.tenantFrom || stripes.okapi.tenant;
+ const tenantFrom = location?.state?.initialTenantId || stripes.okapi.tenant;
await switchAffiliation(stripes, tenantFrom, this.goToInstanceView);
}
@@ -264,17 +264,15 @@ class ViewHoldingsRecord extends React.Component {
location,
id,
holdingsrecordid,
- stripes,
+ initialTenantId,
} = this.props;
- const tenantFrom = location?.state?.tenantFrom || stripes.okapi.tenant;
-
history.push({
pathname: `/inventory/edit/${id}/${holdingsrecordid}`,
search: location.search,
state: {
backPathname: location.pathname,
- tenantFrom,
+ initialTenantId,
},
});
}
@@ -288,9 +286,10 @@ class ViewHoldingsRecord extends React.Component {
id,
holdingsrecordid,
stripes,
+ initialTenantId,
} = this.props;
- const tenantFrom = location?.state?.tenantFrom || stripes.okapi.tenant;
+ const tenantFrom = stripes.okapi.tenant;
history.push({
pathname: `/inventory/copy/${id}/${holdingsrecordid}`,
@@ -298,6 +297,7 @@ class ViewHoldingsRecord extends React.Component {
state: {
backPathname: location.pathname,
tenantFrom,
+ initialTenantId,
},
});
}
@@ -641,10 +641,8 @@ class ViewHoldingsRecord extends React.Component {
referenceTables,
goTo,
stripes,
- location,
} = this.props;
const { instance } = this.state;
- const tenantFrom = location?.state?.tenantFrom || stripes.okapi.tenant;
if (this.isAwaitingResource()) return ;
@@ -957,9 +955,7 @@ class ViewHoldingsRecord extends React.Component {
updatedDate: getDate(holdingsRecord?.metadata?.updatedDate),
})}
dismissible
- onClose={async () => {
- await switchAffiliation(stripes, tenantFrom, this.onClose);
- }}
+ onClose={this.onClose}
actionMenu={this.getPaneHeaderActionMenu}
>
@@ -1390,6 +1386,7 @@ ViewHoldingsRecord.propTypes = {
goTo: PropTypes.func.isRequired,
isInstanceShared: PropTypes.bool,
onUpdateOwnership: PropTypes.func,
+ initialTenantId: PropTypes.string,
};
export default flowRight(
diff --git a/src/ViewHoldingsRecord.test.js b/src/ViewHoldingsRecord.test.js
index 4558d8375..44633e6f4 100644
--- a/src/ViewHoldingsRecord.test.js
+++ b/src/ViewHoldingsRecord.test.js
@@ -132,6 +132,7 @@ const defaultProps = {
tenantFrom: 'testTenantFromId',
}
},
+ initialTenantId: 'initialTenantId',
};
const queryClient = new QueryClient();
@@ -246,7 +247,7 @@ describe('ViewHoldingsRecord actions', () => {
search: defaultProps.location.search,
state: {
backPathname: defaultProps.location.pathname,
- tenantFrom: 'testTenantFromId',
+ initialTenantId: 'initialTenantId',
},
};
renderViewHoldingsRecord();
@@ -274,7 +275,8 @@ describe('ViewHoldingsRecord actions', () => {
search: defaultProps.location.search,
state: {
backPathname: defaultProps.location.pathname,
- tenantFrom: 'testTenantFromId',
+ tenantFrom: 'diku',
+ initialTenantId: 'initialTenantId',
},
};
diff --git a/src/routes/ItemRoute.js b/src/routes/ItemRoute.js
index 12362422e..b70938e07 100644
--- a/src/routes/ItemRoute.js
+++ b/src/routes/ItemRoute.js
@@ -26,6 +26,7 @@ const ItemRoute = props => {
{...props}
isInstanceShared={instance?.shared}
tenantTo={state?.tenantTo || okapi.tenant}
+ initialTenantId={state?.initialTenantId || okapi.tenant}
referenceTables={data}
/>
)}
@@ -39,7 +40,6 @@ ItemRoute.propTypes = {
location: PropTypes.object,
resources: PropTypes.object,
stripes: PropTypes.object,
- tenantFrom: PropTypes.string,
history: PropTypes.object,
};
diff --git a/src/routes/ViewHoldingRoute.js b/src/routes/ViewHoldingRoute.js
index dcaaa3589..e8eaf0693 100644
--- a/src/routes/ViewHoldingRoute.js
+++ b/src/routes/ViewHoldingRoute.js
@@ -25,6 +25,7 @@ const ViewHoldingRoute = () => {
id={instanceId}
isInstanceShared={instance?.shared}
tenantTo={state?.tenantTo || okapi.tenant}
+ initialTenantId={state?.initialTenantId || okapi.tenant}
referenceTables={referenceTables}
holdingsrecordid={holdingsrecordid}
onUpdateOwnership={updateOwnership}
diff --git a/src/views/ItemView.js b/src/views/ItemView.js
index b023b083c..b99475ce8 100644
--- a/src/views/ItemView.js
+++ b/src/views/ItemView.js
@@ -144,6 +144,7 @@ const ItemView = props => {
},
goTo,
isInstanceShared,
+ initialTenantId,
} = props;
const ky = useOkapiKy();
@@ -176,13 +177,16 @@ const ItemView = props => {
const onClickEditItem = e => {
if (e) e.preventDefault();
- const tenantFrom = location?.state?.tenantFrom || stripes.okapi.tenant;
+ const tenantFrom = stripes.okapi.tenant;
const { id, holdingsrecordid, itemid } = match.params;
history.push({
pathname: `/inventory/edit/${id}/${holdingsrecordid}/${itemid}`,
search: location.search,
- state: { tenantFrom }
+ state: {
+ tenantFrom,
+ initialTenantId,
+ }
});
};
@@ -200,7 +204,7 @@ const ItemView = props => {
};
const onCloseViewItem = async () => {
- const tenantFrom = location?.state?.tenantFrom || stripes.okapi.tenant;
+ const tenantFrom = location?.state?.initialTenantId || stripes.okapi.tenant;
await switchAffiliation(stripes, tenantFrom, () => goBack(tenantFrom));
};
@@ -212,12 +216,15 @@ const ItemView = props => {
const onCopy = () => {
const { itemid, id, holdingsrecordid } = match.params;
- const tenantFrom = location?.state?.tenantFrom || stripes.okapi.tenant;
+ const tenantFrom = stripes.okapi.tenant;
history.push({
pathname: `/inventory/copy/${id}/${holdingsrecordid}/${itemid}`,
search: location.search,
- state: { tenantFrom },
+ state: {
+ tenantFrom,
+ initialTenantId,
+ },
});
};
@@ -1938,6 +1945,7 @@ ItemView.propTypes = {
match: PropTypes.object.isRequired,
history: PropTypes.object.isRequired,
isInstanceShared: PropTypes.bool,
+ initialTenantId: PropTypes.string,
};
export default flowRight(