Browse Source

feat: store last feed type

imwald
codytseng 1 year ago
parent
commit
92e338ea1e
  1. 1
      src/constants.ts
  2. 9
      src/providers/FeedProvider.tsx
  3. 14
      src/services/storage.service.ts

1
src/constants.ts

@ -2,6 +2,7 @@ export const StorageKey = { @@ -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'

9
src/providers/FeedProvider.tsx

@ -30,12 +30,12 @@ export const useFeed = () => { @@ -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 }) { @@ -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 }) { @@ -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 }) { @@ -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') {

14
src/services/storage.service.ts

@ -1,7 +1,7 @@ @@ -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 { @@ -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 { @@ -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 { @@ -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
}

Loading…
Cancel
Save