VMS-frontend/src/pages/404.tsx
2024-02-28 17:22:41 +07:00

36 lines
1.2 KiB
TypeScript

import { Button, Flex, Text } from '@mantine/core';
import React, { useContext, useEffect, useRef } from 'react';
import CogWheelWithText from '../shared/components/loaders/CogWheelWithText';
import { strings } from '../shared/strings/strings';
import { routesPath } from '../router/routes.path';
import { Context } from '..';
import { observer } from 'mobx-react-lite';
const NotFound = () => {
const executed = useRef(false)
const { sideBarsStore } = useContext(Context)
useEffect(() => {
if (!executed.current) {
sideBarsStore.rightVisible = false
sideBarsStore.setLeftChildren(null)
sideBarsStore.setRightChildren(null)
executed.current = true
}
}, [sideBarsStore])
const handleGoToMain = () => {
window.location.replace(routesPath.MAIN_PATH)
}
return (
<Flex h='100%' direction='column' justify='center' align='center' gap='1rem'>
<Text fz='lg' fw={700}>{strings.errors[404]}</Text>
<CogWheelWithText text='404' />
<Button onClick={handleGoToMain}>{strings.goToMainPage}</Button>
</Flex>
);
};
export default observer(NotFound);