Files
BrowserOS/packages/browseros-agent/apps/agent/lib/personalization/personalizationStorage.ts
Dani Akash 290ee91a8b Add 'packages/browseros-agent/' from commit '90bd4be3008285bf3825aad3702aff98f872671a'
git-subtree-dir: packages/browseros-agent
git-subtree-mainline: 8f148d0918
git-subtree-split: 90bd4be300
2026-03-13 21:22:09 +05:30

55 lines
1.5 KiB
TypeScript

import { storage } from '@wxt-dev/storage'
import { useCallback, useEffect, useRef, useState } from 'react'
export const personalizationStorage = storage.defineItem<string>(
'local:personalization',
{
fallback: '',
},
)
export function usePersonalization() {
const [personalization, setPersonalizationState] = useState('')
const isLocalUpdate = useRef(false)
const debounceTimer = useRef<ReturnType<typeof setTimeout> | null>(null)
useEffect(() => {
personalizationStorage.getValue().then(setPersonalizationState)
const unwatch = personalizationStorage.watch((newValue) => {
if (!isLocalUpdate.current) {
setPersonalizationState(newValue ?? '')
}
isLocalUpdate.current = false
})
return unwatch
}, [])
const setPersonalization = useCallback((value: string) => {
setPersonalizationState(value)
isLocalUpdate.current = true
if (debounceTimer.current) {
clearTimeout(debounceTimer.current)
}
debounceTimer.current = setTimeout(() => {
personalizationStorage.setValue(value)
}, 300)
}, [])
const clearPersonalization = useCallback(async () => {
setPersonalizationState('')
isLocalUpdate.current = true
await personalizationStorage.setValue('')
}, [])
useEffect(() => {
return () => {
if (debounceTimer.current) {
clearTimeout(debounceTimer.current)
}
}
}, [])
return { personalization, setPersonalization, clearPersonalization }
}