@gv-tech/ui-native 2.21.0 → 2.22.0

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.
Files changed (179) hide show
  1. package/dist/accordion.d.ts +13 -0
  2. package/dist/accordion.d.ts.map +1 -0
  3. package/dist/accordion.test.d.ts +2 -0
  4. package/dist/accordion.test.d.ts.map +1 -0
  5. package/dist/alert-dialog.d.ts +51 -0
  6. package/dist/alert-dialog.d.ts.map +1 -0
  7. package/dist/alert.d.ts +10 -0
  8. package/dist/alert.d.ts.map +1 -0
  9. package/dist/alert.test.d.ts +2 -0
  10. package/dist/alert.test.d.ts.map +1 -0
  11. package/dist/aspect-ratio.d.ts +4 -0
  12. package/dist/aspect-ratio.d.ts.map +1 -0
  13. package/dist/avatar.d.ts +10 -0
  14. package/dist/avatar.d.ts.map +1 -0
  15. package/dist/avatar.test.d.ts +2 -0
  16. package/dist/avatar.test.d.ts.map +1 -0
  17. package/dist/badge.d.ts +12 -0
  18. package/dist/badge.d.ts.map +1 -0
  19. package/dist/badge.test.d.ts +2 -0
  20. package/dist/badge.test.d.ts.map +1 -0
  21. package/dist/breadcrumb.d.ts +24 -0
  22. package/dist/breadcrumb.d.ts.map +1 -0
  23. package/dist/button.d.ts +14 -0
  24. package/dist/button.d.ts.map +1 -0
  25. package/dist/button.test.d.ts +2 -0
  26. package/dist/button.test.d.ts.map +1 -0
  27. package/dist/calendar.d.ts +4 -0
  28. package/dist/calendar.d.ts.map +1 -0
  29. package/dist/card.d.ts +13 -0
  30. package/dist/card.d.ts.map +1 -0
  31. package/dist/card.test.d.ts +2 -0
  32. package/dist/card.test.d.ts.map +1 -0
  33. package/dist/carousel.d.ts +8 -0
  34. package/dist/carousel.d.ts.map +1 -0
  35. package/dist/chart.d.ts +13 -0
  36. package/dist/chart.d.ts.map +1 -0
  37. package/dist/checkbox.d.ts +15 -0
  38. package/dist/checkbox.d.ts.map +1 -0
  39. package/dist/checkbox.test.d.ts +2 -0
  40. package/dist/checkbox.test.d.ts.map +1 -0
  41. package/dist/collapsible.d.ts +8 -0
  42. package/dist/collapsible.d.ts.map +1 -0
  43. package/dist/collapsible.test.d.ts +2 -0
  44. package/dist/collapsible.test.d.ts.map +1 -0
  45. package/dist/command.d.ts +14 -0
  46. package/dist/command.d.ts.map +1 -0
  47. package/dist/context-menu.d.ts +61 -0
  48. package/dist/context-menu.d.ts.map +1 -0
  49. package/dist/dialog.d.ts +61 -0
  50. package/dist/dialog.d.ts.map +1 -0
  51. package/dist/dialog.test.d.ts +2 -0
  52. package/dist/dialog.test.d.ts.map +1 -0
  53. package/dist/drawer.d.ts +31 -0
  54. package/dist/drawer.d.ts.map +1 -0
  55. package/dist/dropdown-menu.d.ts +60 -0
  56. package/dist/dropdown-menu.d.ts.map +1 -0
  57. package/dist/form.d.ts +2 -0
  58. package/dist/form.d.ts.map +1 -0
  59. package/dist/hooks/use-toast.d.ts +46 -0
  60. package/dist/hooks/use-toast.d.ts.map +1 -0
  61. package/dist/hover-card.d.ts +23 -0
  62. package/dist/hover-card.d.ts.map +1 -0
  63. package/dist/index.d.ts +67 -1199
  64. package/dist/index.d.ts.map +1 -0
  65. package/dist/input.d.ts +8 -0
  66. package/dist/input.d.ts.map +1 -0
  67. package/dist/input.test.d.ts +2 -0
  68. package/dist/input.test.d.ts.map +1 -0
  69. package/dist/label.d.ts +9 -0
  70. package/dist/label.d.ts.map +1 -0
  71. package/dist/label.test.d.ts +2 -0
  72. package/dist/label.test.d.ts.map +1 -0
  73. package/dist/lib/render-native.d.ts +4 -0
  74. package/dist/lib/render-native.d.ts.map +1 -0
  75. package/dist/lib/utils.d.ts +4 -0
  76. package/dist/lib/utils.d.ts.map +1 -0
  77. package/dist/menubar.d.ts +53 -0
  78. package/dist/menubar.d.ts.map +1 -0
  79. package/dist/navigation-menu.d.ts +14 -0
  80. package/dist/navigation-menu.d.ts.map +1 -0
  81. package/dist/pagination.d.ts +33 -0
  82. package/dist/pagination.d.ts.map +1 -0
  83. package/dist/popover.d.ts +9 -0
  84. package/dist/popover.d.ts.map +1 -0
  85. package/dist/popover.test.d.ts +2 -0
  86. package/dist/popover.test.d.ts.map +1 -0
  87. package/dist/progress.d.ts +6 -0
  88. package/dist/progress.d.ts.map +1 -0
  89. package/dist/progress.test.d.ts +2 -0
  90. package/dist/progress.test.d.ts.map +1 -0
  91. package/dist/radio-group.d.ts +11 -0
  92. package/dist/radio-group.d.ts.map +1 -0
  93. package/dist/radio-group.test.d.ts +2 -0
  94. package/dist/radio-group.test.d.ts.map +1 -0
  95. package/dist/resizable.d.ts +6 -0
  96. package/dist/resizable.d.ts.map +1 -0
  97. package/dist/scroll-area.d.ts +6 -0
  98. package/dist/scroll-area.d.ts.map +1 -0
  99. package/dist/scroll-to-top.d.ts +29 -0
  100. package/dist/scroll-to-top.d.ts.map +1 -0
  101. package/dist/search.d.ts +3 -0
  102. package/dist/search.d.ts.map +1 -0
  103. package/dist/search.test.d.ts +2 -0
  104. package/dist/search.test.d.ts.map +1 -0
  105. package/dist/select.d.ts +66 -0
  106. package/dist/select.d.ts.map +1 -0
  107. package/dist/select.test.d.ts +2 -0
  108. package/dist/select.test.d.ts.map +1 -0
  109. package/dist/separator.d.ts +9 -0
  110. package/dist/separator.d.ts.map +1 -0
  111. package/dist/separator.test.d.ts +2 -0
  112. package/dist/separator.test.d.ts.map +1 -0
  113. package/dist/sheet.d.ts +59 -0
  114. package/dist/sheet.d.ts.map +1 -0
  115. package/dist/sheet.test.d.ts +2 -0
  116. package/dist/sheet.test.d.ts.map +1 -0
  117. package/dist/skeleton.d.ts +5 -0
  118. package/dist/skeleton.d.ts.map +1 -0
  119. package/dist/skeleton.test.d.ts +2 -0
  120. package/dist/skeleton.test.d.ts.map +1 -0
  121. package/dist/slider.d.ts +4 -0
  122. package/dist/slider.d.ts.map +1 -0
  123. package/dist/sonner.d.ts +4 -0
  124. package/dist/sonner.d.ts.map +1 -0
  125. package/dist/support-fab.d.ts +18 -0
  126. package/dist/support-fab.d.ts.map +1 -0
  127. package/dist/switch.d.ts +8 -0
  128. package/dist/switch.d.ts.map +1 -0
  129. package/dist/switch.test.d.ts +2 -0
  130. package/dist/switch.test.d.ts.map +1 -0
  131. package/dist/table-of-contents.d.ts +47 -0
  132. package/dist/table-of-contents.d.ts.map +1 -0
  133. package/dist/table-of-contents.test.d.ts +2 -0
  134. package/dist/table-of-contents.test.d.ts.map +1 -0
  135. package/dist/table.d.ts +12 -0
  136. package/dist/table.d.ts.map +1 -0
  137. package/dist/table.test.d.ts +2 -0
  138. package/dist/table.test.d.ts.map +1 -0
  139. package/dist/tabs.d.ts +30 -0
  140. package/dist/tabs.d.ts.map +1 -0
  141. package/dist/tabs.test.d.ts +2 -0
  142. package/dist/tabs.test.d.ts.map +1 -0
  143. package/dist/text.d.ts +13 -0
  144. package/dist/text.d.ts.map +1 -0
  145. package/dist/text.test.d.ts +2 -0
  146. package/dist/text.test.d.ts.map +1 -0
  147. package/dist/textarea.d.ts +6 -0
  148. package/dist/textarea.d.ts.map +1 -0
  149. package/dist/textarea.test.d.ts +2 -0
  150. package/dist/textarea.test.d.ts.map +1 -0
  151. package/dist/theme-provider.d.ts +6 -0
  152. package/dist/theme-provider.d.ts.map +1 -0
  153. package/dist/theme-toggle.d.ts +4 -0
  154. package/dist/theme-toggle.d.ts.map +1 -0
  155. package/dist/theme-toggle.test.d.ts +2 -0
  156. package/dist/theme-toggle.test.d.ts.map +1 -0
  157. package/dist/toast.d.ts +35 -0
  158. package/dist/toast.d.ts.map +1 -0
  159. package/dist/toast.test.d.ts +2 -0
  160. package/dist/toast.test.d.ts.map +1 -0
  161. package/dist/toaster.d.ts +5 -0
  162. package/dist/toaster.d.ts.map +1 -0
  163. package/dist/toggle-group.d.ts +11 -0
  164. package/dist/toggle-group.d.ts.map +1 -0
  165. package/dist/toggle-group.test.d.ts +2 -0
  166. package/dist/toggle-group.test.d.ts.map +1 -0
  167. package/dist/toggle.d.ts +8 -0
  168. package/dist/toggle.d.ts.map +1 -0
  169. package/dist/toggle.test.d.ts +2 -0
  170. package/dist/toggle.test.d.ts.map +1 -0
  171. package/dist/tooltip.d.ts +30 -0
  172. package/dist/tooltip.d.ts.map +1 -0
  173. package/dist/tooltip.test.d.ts +2 -0
  174. package/dist/tooltip.test.d.ts.map +1 -0
  175. package/dist/ui-native.cjs +2 -2
  176. package/dist/ui-native.mjs +484 -434
  177. package/package.json +2 -1
  178. package/src/theme-provider.tsx +5 -2
  179. package/src/theme-toggle.tsx +87 -7
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@gv-tech/ui-native",
3
- "version": "2.21.0",
3
+ "version": "2.22.0",
4
4
  "description": "React Native implementations of the GV Tech design system components",
5
5
  "repository": {
6
6
  "type": "git",
@@ -19,6 +19,7 @@
19
19
  },
20
20
  "main": "./dist/ui-native.cjs",
21
21
  "module": "./dist/ui-native.mjs",
22
+ "react-native": "./src/index.ts",
22
23
  "types": "./dist/index.d.ts",
23
24
  "files": [
24
25
  "dist",
@@ -1,6 +1,9 @@
1
+ import { useColorScheme } from 'nativewind';
1
2
  import * as React from 'react';
2
3
  import { View } from 'react-native';
4
+ import { cn } from './lib/utils';
3
5
 
4
- export function ThemeProvider({ children }: { children: React.ReactNode }) {
5
- return <View style={{ flex: 1 }}>{children}</View>;
6
+ export function ThemeProvider({ children, className }: { children: React.ReactNode; className?: string }) {
7
+ const { colorScheme } = useColorScheme();
8
+ return <View className={cn('flex-1', colorScheme === 'dark' ? 'dark' : '', className)}>{children}</View>;
6
9
  }
@@ -1,11 +1,91 @@
1
- import { Text, TouchableOpacity, View } from 'react-native';
1
+ import { ThemeToggleBaseProps } from '@gv-tech/ui-core';
2
+ import { Moon, Sun, SunMoon } from 'lucide-react-native';
3
+ import { useColorScheme } from 'nativewind';
4
+ import { View } from 'react-native';
5
+ import { Button } from './button';
6
+ import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger } from './dropdown-menu';
7
+ import { cn } from './lib/utils';
8
+ import { Text } from './text';
9
+
10
+ export type ThemeToggleProps = ThemeToggleBaseProps;
11
+
12
+ export function ThemeToggle({ variant = 'binary', onThemeChange, customTheme, className }: ThemeToggleProps) {
13
+ const { colorScheme, setColorScheme } = useColorScheme();
14
+
15
+ const currentTheme = (customTheme ?? colorScheme) as 'light' | 'dark' | 'system';
16
+
17
+ // Determine if dark based on currentTheme
18
+ const isDark = currentTheme === 'dark';
19
+ const isSystem = currentTheme === 'system';
20
+
21
+ const handleThemeChange = (newTheme: 'light' | 'dark' | 'system') => {
22
+ if (onThemeChange) {
23
+ onThemeChange(newTheme);
24
+ } else {
25
+ setColorScheme(newTheme);
26
+ }
27
+ };
28
+
29
+ const IconToggle = () => (
30
+ <View className="flex items-center justify-center">
31
+ <Sun
32
+ size={18}
33
+ className={cn(
34
+ 'text-foreground transition-all',
35
+ !isSystem && !isDark ? 'scale-100 rotate-0 opacity-100' : 'absolute scale-0 -rotate-90 opacity-0',
36
+ )}
37
+ />
38
+ <Moon
39
+ size={18}
40
+ className={cn(
41
+ 'text-foreground transition-all',
42
+ !isSystem && isDark ? 'scale-100 rotate-0 opacity-100' : 'absolute scale-0 rotate-90 opacity-0',
43
+ )}
44
+ />
45
+ <SunMoon
46
+ size={18}
47
+ className={cn(
48
+ 'text-foreground transition-all',
49
+ isSystem ? 'scale-100 rotate-0 opacity-100' : 'absolute scale-0 rotate-90 opacity-0',
50
+ )}
51
+ />
52
+ </View>
53
+ );
54
+
55
+ if (variant === 'ternary') {
56
+ return (
57
+ <DropdownMenu>
58
+ <DropdownMenuTrigger asChild>
59
+ <Button variant="ghost" size="icon" className={cn('relative h-9 w-9', className)}>
60
+ <IconToggle />
61
+ </Button>
62
+ </DropdownMenuTrigger>
63
+ <DropdownMenuContent align="end">
64
+ <DropdownMenuItem onPress={() => handleThemeChange('light')}>
65
+ <Sun size={14} className="text-foreground mr-2" />
66
+ <Text>Light</Text>
67
+ </DropdownMenuItem>
68
+ <DropdownMenuItem onPress={() => handleThemeChange('dark')}>
69
+ <Moon size={14} className="text-foreground mr-2" />
70
+ <Text>Dark</Text>
71
+ </DropdownMenuItem>
72
+ <DropdownMenuItem onPress={() => handleThemeChange('system')}>
73
+ <SunMoon size={14} className="text-foreground mr-2" />
74
+ <Text>System</Text>
75
+ </DropdownMenuItem>
76
+ </DropdownMenuContent>
77
+ </DropdownMenu>
78
+ );
79
+ }
2
80
 
3
- export function ThemeToggle() {
4
81
  return (
5
- <TouchableOpacity onPress={() => {}}>
6
- <View style={{ padding: 10, backgroundColor: '#eee', borderRadius: 5 }}>
7
- <Text>Toggle Theme</Text>
8
- </View>
9
- </TouchableOpacity>
82
+ <Button
83
+ variant="ghost"
84
+ size="icon"
85
+ className={cn('relative h-9 w-9', className)}
86
+ onPress={() => handleThemeChange(currentTheme === 'dark' ? 'light' : 'dark')}
87
+ >
88
+ <IconToggle />
89
+ </Button>
10
90
  );
11
91
  }