tooot/src/utils/slices/settingsSlice.ts

70 lines
1.9 KiB
TypeScript
Raw Normal View History

import { createAsyncThunk, createSlice, PayloadAction } from '@reduxjs/toolkit'
2020-12-13 14:04:25 +01:00
import { RootState } from '@root/store'
2020-12-29 16:19:04 +01:00
import * as Analytics from 'expo-firebase-analytics'
2021-01-17 22:37:05 +01:00
import * as Localization from 'expo-localization'
export type SettingsState = {
2021-01-17 22:37:05 +01:00
language: 'zh-Hans' | 'en'
2020-11-29 18:08:31 +01:00
theme: 'light' | 'dark' | 'auto'
2020-12-20 18:41:28 +01:00
browser: 'internal' | 'external'
2020-12-29 16:19:04 +01:00
analytics: boolean
}
2021-01-07 19:13:09 +01:00
export const settingsInitialState = {
2021-01-17 22:37:05 +01:00
language: Localization.locale,
2020-12-20 18:41:28 +01:00
theme: 'auto',
2020-12-29 16:19:04 +01:00
browser: 'internal',
2020-12-30 14:33:33 +01:00
analytics: true
}
2020-12-29 16:19:04 +01:00
export const changeAnalytics = createAsyncThunk(
'settings/changeAnalytics',
async (newValue: SettingsState['analytics']) => {
await Analytics.setAnalyticsCollectionEnabled(newValue)
return newValue
}
)
const settingsSlice = createSlice({
name: 'settings',
2021-01-07 19:13:09 +01:00
initialState: settingsInitialState as SettingsState,
reducers: {
changeLanguage: (
state,
action: PayloadAction<NonNullable<SettingsState['language']>>
) => {
state.language = action.payload
2020-11-29 18:08:31 +01:00
},
changeTheme: (
state,
action: PayloadAction<NonNullable<SettingsState['theme']>>
) => {
state.theme = action.payload
2020-12-20 18:41:28 +01:00
},
changeBrowser: (
state,
action: PayloadAction<NonNullable<SettingsState['browser']>>
) => {
state.browser = action.payload
}
2020-12-29 16:19:04 +01:00
},
extraReducers: builder => {
builder.addCase(changeAnalytics.fulfilled, (state, action) => {
state.analytics = action.payload
})
}
})
export const getSettingsLanguage = (state: RootState) => state.settings.language
2020-11-29 18:08:31 +01:00
export const getSettingsTheme = (state: RootState) => state.settings.theme
2020-12-20 18:41:28 +01:00
export const getSettingsBrowser = (state: RootState) => state.settings.browser
2020-12-29 16:19:04 +01:00
export const getSettingsAnalytics = (state: RootState) =>
state.settings.analytics
2020-12-20 18:41:28 +01:00
export const {
changeLanguage,
changeTheme,
changeBrowser
} = settingsSlice.actions
export default settingsSlice.reducer