hexabot/frontend/src/contexts/setting.context.tsx
2024-10-18 18:33:05 +01:00

46 lines
1.4 KiB
TypeScript

/*
* Copyright © 2024 Hexastack. All rights reserved.
*
* Licensed under the GNU Affero General Public License v3.0 (AGPLv3) with the following additional terms:
* 1. The name "Hexabot" is a trademark of Hexastack. You may not use this name in derivative works without express written permission.
* 2. All derivative works must include clear attribution to the original creator and software, Hexastack and Hexabot, in a prominent location (e.g., in the software's "About" section, documentation, and README file).
*/
import { createContext, ReactNode } from "react";
import { Progress } from "@/app-components/displays/Progress";
import { useLoadSettings } from "@/hooks/entities/auth-hooks";
import { useRemoteI18n } from "@/hooks/useRemoteI18n";
import { ISetting } from "@/types/setting.types";
export const SettingsContext = createContext<{
settings: { [key: string]: ISetting[] } | undefined;
}>({ settings: undefined });
SettingsContext.displayName = "SettingsContext";
interface SettingsProviderProps {
children: ReactNode;
}
export const SettingsProvider = ({
children,
}: SettingsProviderProps): JSX.Element => {
const { data, isLoading } = useLoadSettings();
// Load API i18n Translations (extensions, ...)
useRemoteI18n();
if (isLoading) return <Progress />;
return (
<SettingsContext.Provider
value={{
settings: data,
}}
>
{children}
</SettingsContext.Provider>
);
};