@umituz/react-native-design-system 4.23.111 → 4.23.112

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@umituz/react-native-design-system",
3
- "version": "4.23.111",
3
+ "version": "4.23.112",
4
4
  "description": "Universal design system for React Native apps - Consolidated package with atoms, molecules, organisms, theme, typography, responsive, safe area, exception, infinite scroll, UUID, image, timezone, offline, onboarding, and loading utilities",
5
5
  "main": "./src/index.ts",
6
6
  "types": "./src/index.ts",
@@ -49,6 +49,7 @@ export const DesignSystemProvider: React.FC<DesignSystemProviderProps> = ({
49
49
  const initialize = useTheme((state) => state.initialize);
50
50
  const setCustomColors = useTheme((state) => state.setCustomColors);
51
51
  const setDefaultColors = useTheme((state) => state.setDefaultColors);
52
+ const setDefaultThemeMode = useTheme((state) => state.setDefaultThemeMode);
52
53
  const setGlobalCustomColors = useDesignSystemTheme((state) => state.setCustomColors);
53
54
  const setGlobalThemeMode = useDesignSystemTheme((state) => state.setThemeMode);
54
55
 
@@ -68,6 +69,8 @@ export const DesignSystemProvider: React.FC<DesignSystemProviderProps> = ({
68
69
  setGlobalCustomColors(customColors);
69
70
  }
70
71
 
72
+ // Set default theme mode BEFORE initialize
73
+ setDefaultThemeMode(initialThemeMode);
71
74
  setGlobalThemeMode(initialThemeMode);
72
75
 
73
76
  initialize()
@@ -17,6 +17,7 @@ interface ThemeState {
17
17
  themeMode: ThemeMode;
18
18
  customColors?: CustomThemeColors;
19
19
  defaultColors?: CustomThemeColors;
20
+ defaultThemeMode: ThemeMode;
20
21
  isDark: boolean;
21
22
  isInitialized: boolean;
22
23
  }
@@ -25,6 +26,7 @@ interface ThemeActions {
25
26
  setThemeMode: (mode: ThemeMode) => Promise<void>;
26
27
  setCustomColors: (colors?: CustomThemeColors) => Promise<void>;
27
28
  setDefaultColors: (colors: CustomThemeColors) => void;
29
+ setDefaultThemeMode: (mode: ThemeMode) => void;
28
30
  resetToDefaults: () => Promise<void>;
29
31
  toggleTheme: () => Promise<void>;
30
32
  initialize: () => Promise<void>;
@@ -36,17 +38,18 @@ let themeInitInProgress = false;
36
38
  export const useTheme = createStore<ThemeState, ThemeActions>({
37
39
  name: 'theme-store',
38
40
  initialState: {
39
- theme: lightTheme,
40
- themeMode: 'light',
41
+ theme: darkTheme,
42
+ themeMode: 'dark',
41
43
  customColors: undefined,
42
44
  defaultColors: undefined,
43
- isDark: false,
45
+ defaultThemeMode: 'dark',
46
+ isDark: true,
44
47
  isInitialized: false,
45
48
  },
46
49
  persist: false,
47
50
  actions: (set, get) => ({
48
51
  initialize: async () => {
49
- const { isInitialized, customColors: currentColors } = get();
52
+ const { isInitialized, customColors: currentColors, defaultThemeMode } = get();
50
53
  if (isInitialized || themeInitInProgress) return;
51
54
 
52
55
  themeInitInProgress = true;
@@ -57,7 +60,7 @@ export const useTheme = createStore<ThemeState, ThemeActions>({
57
60
  ThemeStorage.getCustomColors(),
58
61
  ]);
59
62
 
60
- const mode = savedMode || 'light';
63
+ const mode = savedMode || defaultThemeMode;
61
64
  const theme = mode === 'light' ? lightTheme : darkTheme;
62
65
  // Only use savedColors if they exist, otherwise keep current (prop-based) colors
63
66
  const colors = savedColors !== undefined ? savedColors : currentColors;
@@ -75,7 +78,7 @@ export const useTheme = createStore<ThemeState, ThemeActions>({
75
78
  dsTheme.setCustomColors(colors);
76
79
  } catch {
77
80
  set({ isInitialized: true });
78
- useDesignSystemTheme.getState().setThemeMode('light');
81
+ useDesignSystemTheme.getState().setThemeMode(defaultThemeMode);
79
82
  } finally {
80
83
  themeInitInProgress = false;
81
84
  }
@@ -107,13 +110,18 @@ export const useTheme = createStore<ThemeState, ThemeActions>({
107
110
  set({ defaultColors: colors });
108
111
  },
109
112
 
113
+ setDefaultThemeMode: (mode: ThemeMode) => {
114
+ set({ defaultThemeMode: mode });
115
+ },
116
+
110
117
  resetToDefaults: async () => {
111
- const { defaultColors } = get();
112
- set({ themeMode: 'light', theme: lightTheme, isDark: false, customColors: defaultColors });
118
+ const { defaultColors, defaultThemeMode } = get();
119
+ const theme = defaultThemeMode === 'light' ? lightTheme : darkTheme;
120
+ set({ themeMode: defaultThemeMode, theme, isDark: defaultThemeMode === 'dark', customColors: defaultColors });
113
121
  await ThemeStorage.clearThemeMode();
114
122
  await ThemeStorage.clearCustomColors();
115
123
  const dsTheme = useDesignSystemTheme.getState();
116
- dsTheme.setThemeMode('light');
124
+ dsTheme.setThemeMode(defaultThemeMode);
117
125
  dsTheme.setCustomColors(defaultColors);
118
126
  },
119
127