one-click-accessibility/modules/scanner/assets/js/hooks/use-manage-actions.js
VasylD 81c6e40db6
[APP-1512] add FE remediation management (#300)
* [APP-1512] add backend logic for remediation management

* [APP-1512] add backend logic for remediation management

* Update modules/remediation/database/remediation-entry.php

Co-authored-by: gitstream-cm[bot] <111687743+gitstream-cm[bot]@users.noreply.github.com>

* Update modules/remediation/rest/items.php

Co-authored-by: gitstream-cm[bot] <111687743+gitstream-cm[bot]@users.noreply.github.com>

* [APP-1512] add backend logic for remediation management

* [APP-1512] add FE remediation management

* [APP-1512] add FE remediation management

* [APP-1512] add FE remediation management

* [APP-1512] add FE remediation management

* [APP-1512] add FE remediation management

* [APP-1512] add FE remediation management

* [APP-1512] add FE remediation management

* [APP-1512] add FE remediation management

---------

Co-authored-by: gitstream-cm[bot] <111687743+gitstream-cm[bot]@users.noreply.github.com>
2025-06-23 16:31:51 +02:00

132 lines
3.3 KiB
JavaScript

import { useToastNotification } from '@ea11y-apps/global/hooks';
import { APIScanner } from '@ea11y-apps/scanner/api/APIScanner';
import { useScannerWizardContext } from '@ea11y-apps/scanner/context/scanner-wizard-context';
import { useState } from '@wordpress/element';
import { __ } from '@wordpress/i18n';
export const useManageActions = (id = null) => {
const { error } = useToastNotification();
const {
sortedRemediation,
openedBlock,
setSortedRemediation,
setLoading,
updateRemediationList,
} = useScannerWizardContext();
const [activeRequest, setActiveRequest] = useState(false);
const updateAllRemediationForPage = (active) => async () => {
try {
setLoading(true);
await APIScanner.updateRemediationStatusForPage({
url: window?.ea11yScannerData?.pageData?.url,
active,
});
await updateRemediationList();
} catch (e) {
console.error(e);
error(__('An error occurred.', 'pojo-accessibility'));
} finally {
setLoading(false);
}
};
const deleteAllRemediationForPage = async () => {
try {
setLoading(true);
await APIScanner.deleteRemediationForPage({
url: window?.ea11yScannerData?.pageData?.url,
});
const url = new URL(window.location.href);
url.searchParams.delete('open-ea11y-assistant');
url.searchParams.delete('open-ea11y-assistant-src');
url.searchParams.append('open-ea11y-assistant', '1');
window.location.assign(url);
} catch (e) {
console.error(e);
error(__('An error occurred.', 'pojo-accessibility'));
} finally {
setLoading(false);
}
};
const updateRemediation = (active) => async () => {
try {
setActiveRequest(true);
await APIScanner.updateRemediation({
url: window?.ea11yScannerData?.pageData?.url,
active,
id,
});
const updated = sortedRemediation[openedBlock].map((item) =>
item.id === id ? { ...item, active } : item,
);
setSortedRemediation({
...sortedRemediation,
[openedBlock]: updated,
});
} catch (e) {
console.error(e);
error(__('An error occurred.', 'pojo-accessibility'));
} finally {
setActiveRequest(false);
}
};
const deleteRemediation = async () => {
try {
setActiveRequest(true);
await APIScanner.deleteRemediation({
url: window?.ea11yScannerData?.pageData?.url,
id,
});
const updated = sortedRemediation[openedBlock].flatMap((item) =>
item.id !== id ? item : [],
);
setSortedRemediation({
...sortedRemediation,
[openedBlock]: updated,
});
} catch (e) {
console.error(e);
error(__('An error occurred.', 'pojo-accessibility'));
} finally {
setActiveRequest(false);
}
};
const editRemediation = async (content) => {
try {
setActiveRequest(true);
const strContent = JSON.stringify(content);
await APIScanner.updateRemediationContent({
url: window?.ea11yScannerData?.pageData?.url,
id,
content: strContent,
});
const updated = sortedRemediation[openedBlock].map((item) =>
item.id === id ? { ...item, content: strContent } : item,
);
setSortedRemediation({
...sortedRemediation,
[openedBlock]: updated,
});
} catch (e) {
console.error(e);
error(__('An error occurred.', 'pojo-accessibility'));
} finally {
setActiveRequest(false);
}
};
return {
activeRequest,
updateAllRemediationForPage,
deleteAllRemediationForPage,
updateRemediation,
deleteRemediation,
editRemediation,
};
};