Add kawaii mode (#3773)
This commit is contained in:
parent
181e61bedb
commit
81ae7e425d
17 changed files with 152 additions and 30 deletions
|
@ -7,6 +7,7 @@ import {Provider as DisableHapticsProvider} from './disable-haptics'
|
|||
import {Provider as ExternalEmbedsProvider} from './external-embeds-prefs'
|
||||
import {Provider as HiddenPostsProvider} from './hidden-posts'
|
||||
import {Provider as InAppBrowserProvider} from './in-app-browser'
|
||||
import {Provider as KawaiiProvider} from './kawaii'
|
||||
import {Provider as LanguagesProvider} from './languages'
|
||||
|
||||
export {
|
||||
|
@ -32,7 +33,9 @@ export function Provider({children}: React.PropsWithChildren<{}>) {
|
|||
<InAppBrowserProvider>
|
||||
<DisableHapticsProvider>
|
||||
<AutoplayProvider>
|
||||
<DmServiceUrlProvider>{children}</DmServiceUrlProvider>
|
||||
<DmServiceUrlProvider>
|
||||
<KawaiiProvider>{children}</KawaiiProvider>
|
||||
</DmServiceUrlProvider>
|
||||
</AutoplayProvider>
|
||||
</DisableHapticsProvider>
|
||||
</InAppBrowserProvider>
|
||||
|
|
50
src/state/preferences/kawaii.tsx
Normal file
50
src/state/preferences/kawaii.tsx
Normal file
|
@ -0,0 +1,50 @@
|
|||
import React from 'react'
|
||||
|
||||
import {isWeb} from '#/platform/detection'
|
||||
import * as persisted from '#/state/persisted'
|
||||
|
||||
type StateContext = persisted.Schema['kawaii']
|
||||
|
||||
const stateContext = React.createContext<StateContext>(
|
||||
persisted.defaults.kawaii,
|
||||
)
|
||||
|
||||
export function Provider({children}: React.PropsWithChildren<{}>) {
|
||||
const [state, setState] = React.useState(persisted.get('kawaii'))
|
||||
|
||||
const setStateWrapped = React.useCallback(
|
||||
(kawaii: persisted.Schema['kawaii']) => {
|
||||
setState(kawaii)
|
||||
persisted.write('kawaii', kawaii)
|
||||
},
|
||||
[setState],
|
||||
)
|
||||
|
||||
React.useEffect(() => {
|
||||
return persisted.onUpdate(() => {
|
||||
setState(persisted.get('kawaii'))
|
||||
})
|
||||
}, [setStateWrapped])
|
||||
|
||||
React.useEffect(() => {
|
||||
// dumb and stupid but it's web only so just refresh the page if you want to change it
|
||||
|
||||
if (isWeb) {
|
||||
const kawaii = new URLSearchParams(window.location.search).get('kawaii')
|
||||
switch (kawaii) {
|
||||
case 'true':
|
||||
setStateWrapped(true)
|
||||
break
|
||||
case 'false':
|
||||
setStateWrapped(false)
|
||||
break
|
||||
}
|
||||
}
|
||||
}, [setStateWrapped])
|
||||
|
||||
return <stateContext.Provider value={state}>{children}</stateContext.Provider>
|
||||
}
|
||||
|
||||
export function useKawaiiMode() {
|
||||
return React.useContext(stateContext)
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue