fix: rollback h-fill-available

This commit is contained in:
Shusui MOYATANI
2023-03-18 12:11:03 +09:00
parent 066589519d
commit fd7da8ad7c
4 changed files with 60 additions and 47 deletions

View File

@@ -1,40 +0,0 @@
import { Accessor } from 'solid-js';
import {
createSignalWithStorage,
createStorageWithSerializer,
} from '@/hooks/createSignalWithStorage';
type LoginStatus = {
loggedIn: boolean;
};
type UseLoginStatus = {
loginStatus: Accessor<LoginStatus>;
loggedIn: () => void;
};
const InitialLoginStatus = {
loggedIn: false,
};
const serializer = (loginStatus: LoginStatus): string => JSON.stringify(loginStatus);
// TODO zod使う
const deserializer = (json: string): LoginStatus => JSON.parse(json) as LoginStatus;
const storage = createStorageWithSerializer(() => window.localStorage, serializer, deserializer);
const [loginStatus, setLoginStatus] = createSignalWithStorage(
'RabbitLoginStatus',
InitialLoginStatus,
storage,
);
const useLoginStatus = (): UseLoginStatus => {
const loggedIn = () => {
setLoginStatus((current) => ({ ...current, loggedIn: true }));
};
return { loginStatus, loggedIn };
};
export default useLoginStatus;

View File

@@ -0,0 +1,52 @@
import { Accessor } from 'solid-js';
import {
createSignalWithStorage,
createStorageWithSerializer,
} from '@/hooks/createSignalWithStorage';
type PersistStatus = {
loggedIn: boolean;
agreeWithNostrBuild: boolean;
};
type UsePersistStatus = {
persistStatus: Accessor<PersistStatus>;
loggedIn: () => void;
};
const InitialLoginStatus = {
loggedIn: false,
agreeWithNostrBuild: false,
};
const serializer = (persistStatus: PersistStatus): string => JSON.stringify(persistStatus);
// TODO zod使う
const deserializer = (json: string): PersistStatus => JSON.parse(json) as PersistStatus;
const storage = createStorageWithSerializer(() => window.localStorage, serializer, deserializer);
const [persistStatus, setLoginStatus] = createSignalWithStorage(
'RabbitLoginStatus',
InitialLoginStatus,
storage,
);
const usePersistStatus = (): UsePersistStatus => {
const loggedIn = () => {
setLoginStatus((current) => ({ ...current, loggedIn: true }));
};
return {
persistStatus: () => ({
get loggedIn() {
return persistStatus().loggedIn ?? false;
},
get agreeWithNostrBuild() {
return persistStatus().agreeWithNostrBuild ?? false;
},
}),
loggedIn,
};
};
export default usePersistStatus;