1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-01 00:08:27 +01:00
unleash.unleash/frontend/src/hooks/useHiddenEnvironments.ts

57 lines
1.8 KiB
TypeScript
Raw Normal View History

import { useGlobalLocalStorage } from './useGlobalLocalStorage';
import { useState } from 'react';
import { usePlausibleTracker } from 'hooks/usePlausibleTracker';
export const useHiddenEnvironments = () => {
const { trackEvent } = usePlausibleTracker();
2024-01-26 17:03:10 +01:00
const { value: globalStore, setValue: setGlobalStore } =
useGlobalLocalStorage();
const [hiddenEnvironments, setStoredHiddenEnvironments] = useState<
Set<string>
2024-01-26 17:03:10 +01:00
>(
new Set(
Array.isArray(globalStore.hiddenEnvironments)
? globalStore.hiddenEnvironments
: [],
),
);
const setHiddenEnvironments = (environment: string) => {
// @ts-expect-error
setGlobalStore((params) => {
2024-01-26 17:03:10 +01:00
const hiddenEnvironments = new Set(
Array.isArray(globalStore.hiddenEnvironments)
? globalStore.hiddenEnvironments
: [],
);
if (hiddenEnvironments.has(environment)) {
hiddenEnvironments.delete(environment);
trackEvent('hidden_environment', {
props: {
eventType: `environment unhidden`,
},
});
} else {
hiddenEnvironments.add(environment);
trackEvent('hidden_environment', {
props: {
eventType: `environment hidden`,
},
});
}
setStoredHiddenEnvironments(hiddenEnvironments);
2024-01-26 17:03:10 +01:00
return {
...globalStore,
2024-01-26 17:03:10 +01:00
hiddenEnvironments: [...hiddenEnvironments],
};
});
};
return {
hiddenEnvironments,
setHiddenEnvironments,
};
};