Files
BrowserOS/apps/agent/lib/personalization/personalizationStorage.ts
Dani Akash 3b2b89b98a feat: chat personalization via system prompt (#158)
* chore: enable biome check pre-commit hook

* feat: created personalization screen

* feat: newtab layout component

* chore: refactor styles to use shadcn ui elements

* feat: fix personalization layout

* feat: write personalization to wxt storage

* fix: editing sync problem with localstorage

* feat: pass personalization info to the conversation

* fix: personalize screen transition
2026-01-05 11:33:56 -08:00

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 }
}