store client in state, populate with active server

This commit is contained in:
austinried
2021-08-02 10:18:56 +09:00
parent 8b17ebe9c2
commit 6d30168ea0
4 changed files with 61 additions and 35 deletions

View File

@@ -1,35 +1,55 @@
import { AppSettings, Server } from '@app/models/settings'
import { Store } from '@app/state/store'
import { SubsonicApiClient } from '@app/subsonic/api'
import produce from 'immer'
import { GetState, SetState } from 'zustand'
export type SettingsSlice = {
settings: AppSettings
client?: SubsonicApiClient
createClient: () => void
setActiveServer: (id?: string) => void
setServers: (servers: Server[]) => void
}
export const createSettingsSlice = (set: SetState<Store>, _get: GetState<Store>): SettingsSlice => ({
export const createSettingsSlice = (set: SetState<Store>, get: GetState<Store>): SettingsSlice => ({
settings: {
servers: [],
home: {
lists: ['recent', 'random', 'frequent', 'starred'],
},
},
setActiveServer: id =>
createClient: () => {
const server = get().settings.servers.find(s => s.id === get().settings.activeServer)
if (!server) {
return
}
set(
produce<Store>(state => {
state.client = new SubsonicApiClient(server)
}),
)
},
setActiveServer: id => {
const servers = get().settings.servers
const currentActiveServerId = get().settings.activeServer
if (!servers.find(s => s.id === id)) {
return
}
if (currentActiveServerId === id) {
return
}
set(
produce<Store>(state => {
if (!state.settings.servers.find(s => s.id === id)) {
console.log('could not find')
return
}
if (state.settings.activeServer === id) {
console.log('already active')
return
}
state.settings.activeServer = id
}),
),
)
get().createClient()
},
setServers: servers =>
set(
produce<Store>(state => {