one-click-accessibility/modules/scanner/assets/js/app.js

61 lines
1.7 KiB
JavaScript

import ErrorBoundary from '@elementor/ui/ErrorBoundary';
import Paper from '@elementor/ui/Paper';
import { styled } from '@elementor/ui/styles';
import { Notifications } from '@ea11y/components';
import { useNotificationSettings } from '@ea11y-apps/global/hooks/use-notifications';
import { ErrorMessage } from '@ea11y-apps/scanner/components/error-message';
import { Header } from '@ea11y-apps/scanner/components/header';
import { Loader } from '@ea11y-apps/scanner/components/main-list/loader';
import { ResolvedMessage } from '@ea11y-apps/scanner/components/resolved-message';
import { BLOCKS } from '@ea11y-apps/scanner/constants';
import { useScannerWizardContext } from '@ea11y-apps/scanner/context/scanner-wizard-context';
import {
AltTextLayout,
MainLayout,
ManualLayout,
} from '@ea11y-apps/scanner/layouts';
const App = () => {
const { notificationMessage, notificationType } = useNotificationSettings();
const { violation, resolved, openedBlock, isError, loading } =
useScannerWizardContext();
const getBlock = () => {
if (isError) {
return <ErrorMessage />;
}
if (loading) {
return <Loader />;
}
switch (openedBlock) {
case BLOCKS.main:
return <MainLayout />;
case BLOCKS.altText:
return <AltTextLayout />;
default:
return <ManualLayout />;
}
};
return (
<StyledPaper>
<ErrorBoundary fallback={<ErrorMessage />}>
<Header />
{violation !== resolved ? getBlock() : <ResolvedMessage isMain />}
<Notifications message={notificationMessage} type={notificationType} />
</ErrorBoundary>
</StyledPaper>
);
};
const StyledPaper = styled(Paper)`
position: fixed;
top: 0;
/* @noflip */
right: 0;
width: 420px;
height: 100vh;
overflow-y: auto;
z-index: 99999;
`;
export default App;