feat: store last feed type

This commit is contained in:
codytseng
2025-01-09 21:59:26 +08:00
parent be7712948a
commit 92e338ea1e
3 changed files with 21 additions and 3 deletions

View File

@@ -2,6 +2,7 @@ export const StorageKey = {
THEME_SETTING: 'themeSetting',
RELAY_SETS: 'relaySets',
ACTIVE_RELAY_SET_ID: 'activeRelaySetId',
FEED_TYPE: 'feedType',
ACCOUNTS: 'accounts',
CURRENT_ACCOUNT: 'currentAccount',
ADD_CLIENT_TAG: 'addClientTag'

View File

@@ -30,12 +30,12 @@ export const useFeed = () => {
export function FeedProvider({ children }: { children: React.ReactNode }) {
const { pubkey } = useNostr()
const { relaySets } = useRelaySets()
const [feedType, setFeedType] = useState<TFeedType>('relays')
const [feedType, setFeedType] = useState<TFeedType>(storage.getFeedType())
const [relayUrls, setRelayUrls] = useState<string[]>([])
const [temporaryRelayUrls, setTemporaryRelayUrls] = useState<string[]>([])
const [filter, setFilter] = useState<Filter>({})
const [isReady, setIsReady] = useState(false)
const [activeRelaySetId, setActiveRelaySetId] = useState<string | null>(() =>
const [activeRelaySetId, setActiveRelaySetId] = useState<string | null>(
storage.getActiveRelaySetId()
)
@@ -55,6 +55,9 @@ export function FeedProvider({ children }: { children: React.ReactNode }) {
return await switchFeed('temporary')
}
if (feedType === 'following') {
return await switchFeed('following')
}
await switchFeed('relays', { activeRelaySetId })
}
@@ -95,6 +98,7 @@ export function FeedProvider({ children }: { children: React.ReactNode }) {
setFilter({})
setIsReady(true)
storage.setActiveRelaySetId(relaySet.id)
storage.setFeedType(feedType)
}
return
}
@@ -109,6 +113,7 @@ export function FeedProvider({ children }: { children: React.ReactNode }) {
setRelayUrls(relayList.read.slice(0, 4))
setFilter({ authors: followings.includes(pubkey) ? followings : [...followings, pubkey] })
setIsReady(true)
storage.setFeedType(feedType)
return
}
if (feedType === 'temporary') {

View File

@@ -1,7 +1,7 @@
import { StorageKey } from '@/constants'
import { isSameAccount } from '@/lib/account'
import { randomString } from '@/lib/random'
import { TAccount, TAccountPointer, TRelaySet, TThemeSetting } from '@/types'
import { TAccount, TAccountPointer, TFeedType, TRelaySet, TThemeSetting } from '@/types'
const DEFAULT_RELAY_SETS: TRelaySet[] = [
{
@@ -21,6 +21,7 @@ class StorageService {
private relaySets: TRelaySet[] = []
private activeRelaySetId: string | null = null
private feedType: TFeedType = 'relays'
private themeSetting: TThemeSetting = 'system'
private accounts: TAccount[] = []
private currentAccount: TAccount | null = null
@@ -40,6 +41,8 @@ class StorageService {
this.accounts = accountsStr ? JSON.parse(accountsStr) : []
const currentAccountStr = window.localStorage.getItem(StorageKey.CURRENT_ACCOUNT)
this.currentAccount = currentAccountStr ? JSON.parse(currentAccountStr) : null
const feedTypeStr = window.localStorage.getItem(StorageKey.FEED_TYPE)
this.feedType = feedTypeStr ? JSON.parse(feedTypeStr) : 'relays'
const relaySetsStr = window.localStorage.getItem(StorageKey.RELAY_SETS)
if (!relaySetsStr) {
@@ -94,6 +97,15 @@ class StorageService {
}
}
getFeedType() {
return this.feedType
}
setFeedType(feedType: TFeedType) {
this.feedType = feedType
window.localStorage.setItem(StorageKey.FEED_TYPE, JSON.stringify(this.feedType))
}
getThemeSetting() {
return this.themeSetting
}