From 7642a0f2fc099043e9d7e3cba89e6050bea2ae68 Mon Sep 17 00:00:00 2001 From: Fraser Tweedale Date: Tue, 17 Oct 2023 22:58:54 +1000 Subject: [PATCH] HMS-2786 implement delete action in list view Implement the delete action in the list view kebab menu. There is no confirmation dialog yet (to be implemented later; see HMS-2787). --- src/Components/DomainList/DomainList.tsx | 32 +++++++++++++++++++++++- 1 file changed, 31 insertions(+), 1 deletion(-) diff --git a/src/Components/DomainList/DomainList.tsx b/src/Components/DomainList/DomainList.tsx index ded5e84..67a19f2 100644 --- a/src/Components/DomainList/DomainList.tsx +++ b/src/Components/DomainList/DomainList.tsx @@ -130,6 +130,17 @@ export const DomainList = () => { setDomains(newDomains); }; + // remove domain(s) matching the given uuid from the `domains` state + const removeDomain = (uuid: string): void => { + const newDomains: Domain[] = []; + for (const domain of domains) { + if (domain.domain_id !== uuid) { + newDomains.push(domain); + } + } + setDomains(newDomains); + }; + const onEnableDisable = (domain: Domain) => { console.log(`clicked on Enable/Disable, on row ${domain.title}`); if (domain.domain_id) { @@ -151,6 +162,25 @@ export const DomainList = () => { } }; + const onDelete = (domain: Domain) => { + if (domain.domain_id !== undefined) { + const domainId = domain.domain_id; + resources_api + .deleteDomain(domainId) + .then((response) => { + if (response.status == 204) { + removeDomain(domainId); + } else { + // TODO show-up notification with error message + } + }) + .catch((error) => { + // TODO show-up notification with error message + console.log('error onClose: ' + error); + }); + } + }; + const defaultActions = (domain: Domain): IAction[] => [ { title: 'Enable/Disable', @@ -162,7 +192,7 @@ export const DomainList = () => { }, { title: 'Delete', - onClick: () => console.log(`clicked on Delete, on row ${domain.title}`), + onClick: () => onDelete(domain), }, ];