mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-01 00:08:27 +01:00
4167a60588
Follows up on https://github.com/Unleash/unleash/pull/4853 to add Biome to the frontend as well. ![image](https://github.com/Unleash/unleash/assets/14320932/1906faf1-fc29-4172-a4d4-b2716d72cd65) Added a few `biome-ignore` to speed up the process but we may want to check and fix them in the future.
30 lines
837 B
TypeScript
30 lines
837 B
TypeScript
import { basePath } from 'utils/formatPath';
|
|
import { createPersistentGlobalStateHook } from './usePersistentGlobalState';
|
|
import React from 'react';
|
|
|
|
export interface ILocationSettings {
|
|
locale: string;
|
|
}
|
|
|
|
interface IUseLocationSettingsOutput {
|
|
locationSettings: ILocationSettings;
|
|
setLocationSettings: React.Dispatch<
|
|
React.SetStateAction<ILocationSettings>
|
|
>;
|
|
}
|
|
|
|
export const useLocationSettings = (): IUseLocationSettingsOutput => {
|
|
const [locationSettings, setLocationSettings] = useGlobalState();
|
|
|
|
return { locationSettings, setLocationSettings };
|
|
};
|
|
|
|
const createInitialValue = (): ILocationSettings => {
|
|
return { locale: navigator.language };
|
|
};
|
|
|
|
const useGlobalState = createPersistentGlobalStateHook<ILocationSettings>(
|
|
`${basePath}:useLocationSettings:v1`,
|
|
createInitialValue(),
|
|
);
|