aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastian <sebasjm@gmail.com>2023-06-02 14:11:57 -0300
committerSebastian <sebasjm@gmail.com>2023-06-02 14:12:15 -0300
commite3ec395b35b8fcff9a6423bb118f14c9649ddcd8 (patch)
tree451d448c840f464b7462fecbd0cd29ca74abf04f
parentc41d7e043798616a39c6c0a41b886ead3fa2eb9c (diff)
memory key should be string
-rw-r--r--packages/exchange-backoffice-ui/src/hooks/useOfficer.ts4
-rw-r--r--packages/web-util/src/hooks/useMemoryStorage.ts20
2 files changed, 12 insertions, 12 deletions
diff --git a/packages/exchange-backoffice-ui/src/hooks/useOfficer.ts b/packages/exchange-backoffice-ui/src/hooks/useOfficer.ts
index 2ed375846..4ec43569b 100644
--- a/packages/exchange-backoffice-ui/src/hooks/useOfficer.ts
+++ b/packages/exchange-backoffice-ui/src/hooks/useOfficer.ts
@@ -49,10 +49,10 @@ interface OfficerReady {
}
const OFFICER_KEY = buildStorageKey("officer", codecForOfficer());
-const ACCOUNT_KEY = buildStorageKey<Account>("account");
+const ACCOUNT_KEY = "account";
export function useOfficer(): OfficerState {
- const accountStorage = useMemoryStorage(ACCOUNT_KEY);
+ const accountStorage = useMemoryStorage<Account>(ACCOUNT_KEY);
const officerStorage = useLocalStorage(OFFICER_KEY);
const officer = officerStorage.value;
diff --git a/packages/web-util/src/hooks/useMemoryStorage.ts b/packages/web-util/src/hooks/useMemoryStorage.ts
index d8be24c1e..1dd263797 100644
--- a/packages/web-util/src/hooks/useMemoryStorage.ts
+++ b/packages/web-util/src/hooks/useMemoryStorage.ts
@@ -27,37 +27,37 @@ const storage: ObservableMap<string, any> = memoryMap<any>();
//with initial value
export function useMemoryStorage<Type = string>(
- key: StorageKey<Type>,
+ key: string,
defaultValue: Type,
): Required<StorageState<Type>>;
//with initial value
export function useMemoryStorage<Type = string>(
- key: StorageKey<Type>,
+ key: string,
): StorageState<Type>;
// impl
export function useMemoryStorage<Type = string>(
- key: StorageKey<Type>,
+ key: string,
defaultValue?: Type,
): StorageState<Type> {
const [storedValue, setStoredValue] = useState<Type | undefined>(
(): Type | undefined => {
- const prev = storage.get(key.id);
- return prev;
+ const prev = storage.get(key);
+ return prev === undefined ? defaultValue : prev;
},
);
useEffect(() => {
- return storage.onUpdate(key.id, () => {
- const newValue = storage.get(key.id);
- setStoredValue(newValue);
+ return storage.onUpdate(key, () => {
+ const newValue = storage.get(key);
+ setStoredValue(newValue === undefined ? defaultValue : newValue);
});
}, []);
const setValue = (value?: Type): void => {
if (value === undefined) {
- storage.delete(key.id);
+ storage.delete(key);
} else {
- storage.set(key.id, value);
+ storage.set(key, value);
}
};