one-click-accessibility/modules/scanner/assets/js/components/header/breadcrumbs.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

94 lines
2.4 KiB
JavaScript

import ArrowLeftIcon from '@elementor/icons/ArrowLeftIcon';
import InfoCircleIcon from '@elementor/icons/InfoCircleIcon';
import Box from '@elementor/ui/Box';
import Chip from '@elementor/ui/Chip';
import IconButton from '@elementor/ui/IconButton';
import Infotip from '@elementor/ui/Infotip';
import Typography from '@elementor/ui/Typography';
import { styled } from '@elementor/ui/styles';
import {
BLOCK_INFO,
BLOCK_TITLES,
BLOCKS,
} from '@ea11y-apps/scanner/constants';
import { useScannerWizardContext } from '@ea11y-apps/scanner/context/scanner-wizard-context';
import { removeExistingFocus } from '@ea11y-apps/scanner/utils/focus-on-element';
import { __ } from '@wordpress/i18n';
export const Breadcrumbs = () => {
const {
openedBlock,
sortedViolations,
sortedRemediation,
setOpenedBlock,
altTextData,
manualData,
isManage,
} = useScannerWizardContext();
const handleClick = () => {
removeExistingFocus();
setOpenedBlock(isManage ? BLOCKS.management : BLOCKS.main);
};
const itemsData =
openedBlock === BLOCKS.altText ? altTextData : manualData[openedBlock];
const resolved =
itemsData?.filter((item) => item?.resolved === true).length || 0;
const items = isManage ? sortedRemediation : sortedViolations;
const count = isManage
? items[openedBlock].length
: items[openedBlock].length - resolved;
return (
<Box>
<BreadcrumbsBox>
<IconButton
color="secondary"
onClick={handleClick}
sx={{ whiteSpace: 'nowrap' }}
aria-label={__('All issues', 'pojo-accessibility')}
size="small"
>
<ArrowLeftIcon />
</IconButton>
<Box display="flex" alignItems="center" gap={1}>
<Typography variant="subtitle2" sx={{ maxWidth: '180px' }}>
{BLOCK_TITLES[openedBlock]}
</Typography>
{BLOCK_INFO[openedBlock] && (
<Infotip
PopperProps={{
disablePortal: true,
}}
content={
<Typography variant="body2" sx={{ p: 2, maxWidth: '300px' }}>
{BLOCK_INFO[openedBlock]}
</Typography>
}
>
<InfoCircleIcon fontSize="small" />
</Infotip>
)}
{items[openedBlock].length > 0 && (
<Chip
label={count}
color={isManage ? 'info' : 'error'}
variant="standard"
size="small"
sx={{ fontWeight: 500 }}
/>
)}
</Box>
</BreadcrumbsBox>
</Box>
);
};
const BreadcrumbsBox = styled(Box)`
display: flex;
align-items: center;
gap: ${({ theme }) => theme.spacing(1)};
`;