2024-01-12 21:05:15 +00:00
|
|
|
import React, {
|
|
|
|
createContext,
|
|
|
|
type Dispatch,
|
|
|
|
useState,
|
|
|
|
type SetStateAction,
|
|
|
|
useEffect,
|
2024-01-15 09:33:47 +00:00
|
|
|
type ReactNode,
|
2024-01-12 21:05:15 +00:00
|
|
|
} from 'react';
|
2023-10-27 10:01:59 +00:00
|
|
|
|
|
|
|
import { defaultMaker, type Maker, Garage } from '../models';
|
2023-11-26 18:00:50 +00:00
|
|
|
import { systemClient } from '../services/System';
|
2023-10-27 10:01:59 +00:00
|
|
|
|
2024-01-12 21:05:15 +00:00
|
|
|
export interface GarageContextProviderProps {
|
|
|
|
children: ReactNode;
|
|
|
|
}
|
|
|
|
|
2023-10-27 10:01:59 +00:00
|
|
|
export interface UseGarageStoreType {
|
|
|
|
garage: Garage;
|
|
|
|
maker: Maker;
|
|
|
|
setMaker: Dispatch<SetStateAction<Maker>>;
|
|
|
|
badOrder?: string;
|
|
|
|
setBadOrder: Dispatch<SetStateAction<string | undefined>>;
|
|
|
|
robotUpdatedAt: string;
|
|
|
|
orderUpdatedAt: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const initialGarageContext: UseGarageStoreType = {
|
|
|
|
garage: new Garage(),
|
|
|
|
maker: defaultMaker,
|
|
|
|
setMaker: () => {},
|
|
|
|
badOrder: undefined,
|
|
|
|
setBadOrder: () => {},
|
|
|
|
robotUpdatedAt: '',
|
|
|
|
orderUpdatedAt: '',
|
|
|
|
};
|
|
|
|
|
|
|
|
export const GarageContext = createContext<UseGarageStoreType>(initialGarageContext);
|
|
|
|
|
2024-01-12 21:05:15 +00:00
|
|
|
export const GarageContextProvider = ({ children }: GarageContextProviderProps): JSX.Element => {
|
2023-10-27 10:01:59 +00:00
|
|
|
// All garage data structured
|
|
|
|
const [garage] = useState<Garage>(initialGarageContext.garage);
|
|
|
|
const [maker, setMaker] = useState<Maker>(initialGarageContext.maker);
|
|
|
|
const [badOrder, setBadOrder] = useState<string>();
|
|
|
|
const [robotUpdatedAt, setRobotUpdatedAt] = useState<string>(new Date().toISOString());
|
|
|
|
const [orderUpdatedAt, setOrderUpdatedAt] = useState<string>(new Date().toISOString());
|
|
|
|
|
|
|
|
const onRobotUpdated = (): void => {
|
|
|
|
setRobotUpdatedAt(new Date().toISOString());
|
|
|
|
};
|
|
|
|
|
|
|
|
const onOrderUpdate = (): void => {
|
|
|
|
setOrderUpdatedAt(new Date().toISOString());
|
|
|
|
};
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
garage.registerHook('onRobotUpdate', onRobotUpdated);
|
|
|
|
garage.registerHook('onOrderUpdate', onOrderUpdate);
|
|
|
|
}, []);
|
|
|
|
|
2023-11-26 18:00:50 +00:00
|
|
|
useEffect(() => {
|
|
|
|
if (window.NativeRobosats !== undefined && !systemClient.loading) {
|
|
|
|
garage.loadSlots();
|
|
|
|
}
|
|
|
|
}, [systemClient.loading]);
|
|
|
|
|
2024-01-12 21:05:15 +00:00
|
|
|
return (
|
|
|
|
<GarageContext.Provider
|
|
|
|
value={{
|
|
|
|
garage,
|
|
|
|
maker,
|
|
|
|
setMaker,
|
|
|
|
badOrder,
|
|
|
|
setBadOrder,
|
|
|
|
robotUpdatedAt,
|
|
|
|
orderUpdatedAt,
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</GarageContext.Provider>
|
|
|
|
);
|
2023-10-27 10:01:59 +00:00
|
|
|
};
|