|
1 | | -import { create } from 'zustand'; |
| 1 | +import { create } from 'zustand' |
2 | 2 |
|
3 | | -import { persist } from 'zustand/middleware'; |
4 | | -import { RemoteConfig, Tag } from "../types"; |
| 3 | +import { persist } from 'zustand/middleware' |
| 4 | +import { RemoteConfig, Tag } from '../types' |
5 | 5 |
|
6 | 6 | type RemoteConfigStore = { |
7 | | - supportedTags: Tag[]; |
8 | | - marketingBannerConfig?: any; |
9 | | - setRemoteConfig: (remoteConfig: RemoteConfig) => void; |
10 | | -}; |
| 7 | + supportedTags: Tag[] |
| 8 | + marketingBannerConfig?: any |
| 9 | + adsConfig: { |
| 10 | + rowPosition: number |
| 11 | + columnPosition: number |
| 12 | + enabled: boolean |
| 13 | + } |
| 14 | + setRemoteConfig: (remoteConfig: RemoteConfig) => void |
| 15 | +} |
11 | 16 |
|
12 | | -export const useRemoteConfigStore = create(persist<RemoteConfigStore>((set) => ({ |
13 | | - marketingBannerConfig: undefined, |
14 | | - supportedTags: [ |
15 | | - { |
16 | | - value: 'javascript', |
17 | | - label: 'Javascript', |
18 | | - githubValues: ['javascript'], |
19 | | - confsValues: ['javascript'], |
20 | | - devtoValues: ['javascript'], |
21 | | - hashnodeValues: ['javascript'], |
22 | | - mediumValues: ['javascript'], |
23 | | - redditValues: ['javascript'], |
24 | | - freecodecampValues: ['javascript'] |
25 | | - }, |
26 | | - ], |
27 | | - setRemoteConfig: (remoteConfig: RemoteConfig) => |
28 | | - set(() => { |
29 | | - const { marketingBannerConfig, ...otherConfigs } = remoteConfig |
30 | | - return { ...otherConfigs } |
| 17 | +export const useRemoteConfigStore = create( |
| 18 | + persist<RemoteConfigStore>( |
| 19 | + (set) => ({ |
| 20 | + marketingBannerConfig: undefined, |
| 21 | + adsConfig: { |
| 22 | + rowPosition: 0, |
| 23 | + columnPosition: 0, |
| 24 | + enabled: false, |
| 25 | + }, |
| 26 | + supportedTags: [ |
| 27 | + { |
| 28 | + value: 'javascript', |
| 29 | + label: 'Javascript', |
| 30 | + githubValues: ['javascript'], |
| 31 | + confsValues: ['javascript'], |
| 32 | + devtoValues: ['javascript'], |
| 33 | + hashnodeValues: ['javascript'], |
| 34 | + mediumValues: ['javascript'], |
| 35 | + redditValues: ['javascript'], |
| 36 | + freecodecampValues: ['javascript'], |
| 37 | + }, |
| 38 | + ], |
| 39 | + setRemoteConfig: (remoteConfig: RemoteConfig) => |
| 40 | + set(() => { |
| 41 | + const { marketingBannerConfig, ...otherConfigs } = remoteConfig |
| 42 | + return { ...otherConfigs } |
| 43 | + }), |
31 | 44 | }), |
32 | | -}), { |
33 | | - name: 'remote_config_storage', |
34 | | - version: 1, |
35 | | - migrate(persistedState, version) { |
36 | | - const newState = persistedState as RemoteConfigStore; |
37 | | - if (version === 0) { |
38 | | - delete newState.marketingBannerConfig |
| 45 | + { |
| 46 | + name: 'remote_config_storage', |
| 47 | + version: 1, |
| 48 | + migrate(persistedState, version) { |
| 49 | + const newState = persistedState as RemoteConfigStore |
| 50 | + if (version === 0) { |
| 51 | + delete newState.marketingBannerConfig |
| 52 | + } |
| 53 | + return newState |
| 54 | + }, |
39 | 55 | } |
40 | | - return newState; |
41 | | - }, |
42 | | -})); |
| 56 | + ) |
| 57 | +) |
0 commit comments