@idealyst/components 1.0.83 → 1.0.84

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 (316) hide show
  1. package/CLAUDE.md +199 -232
  2. package/README.md +5 -5
  3. package/package.json +20 -2
  4. package/plugin/README.md +272 -0
  5. package/plugin/test-cases.jsx +112 -0
  6. package/plugin/web-legacy.js +320 -0
  7. package/plugin/web.js +422 -124
  8. package/src/Accordion/Accordion.native.tsx +182 -0
  9. package/src/Accordion/Accordion.styles.tsx +260 -0
  10. package/src/Accordion/Accordion.web.tsx +147 -0
  11. package/src/Accordion/index.native.tsx +3 -0
  12. package/src/Accordion/index.ts +3 -0
  13. package/src/Accordion/index.web.tsx +3 -0
  14. package/src/Accordion/types.ts +23 -0
  15. package/src/ActivityIndicator/ActivityIndicator.native.tsx +17 -12
  16. package/src/ActivityIndicator/ActivityIndicator.styles.tsx +83 -109
  17. package/src/ActivityIndicator/ActivityIndicator.web.tsx +23 -17
  18. package/src/ActivityIndicator/index.ts +5 -2
  19. package/src/ActivityIndicator/index.web.ts +5 -2
  20. package/src/ActivityIndicator/types.ts +15 -10
  21. package/src/Alert/Alert.native.tsx +113 -0
  22. package/src/Alert/Alert.styles.tsx +304 -0
  23. package/src/Alert/Alert.web.tsx +123 -0
  24. package/src/Alert/index.native.ts +5 -0
  25. package/src/Alert/index.ts +5 -0
  26. package/src/Alert/index.web.ts +5 -0
  27. package/src/Alert/types.ts +21 -0
  28. package/src/Avatar/Avatar.native.tsx +8 -6
  29. package/src/Avatar/Avatar.styles.tsx +64 -58
  30. package/src/Avatar/Avatar.web.tsx +13 -8
  31. package/src/Avatar/index.ts +5 -2
  32. package/src/Avatar/index.web.ts +5 -2
  33. package/src/Avatar/types.ts +19 -13
  34. package/src/Badge/Badge.native.tsx +59 -14
  35. package/src/Badge/Badge.styles.tsx +125 -139
  36. package/src/Badge/Badge.web.tsx +72 -16
  37. package/src/Badge/index.ts +5 -2
  38. package/src/Badge/index.web.ts +5 -2
  39. package/src/Badge/types.ts +23 -11
  40. package/src/Breadcrumb/Breadcrumb.native.tsx +225 -0
  41. package/src/Breadcrumb/Breadcrumb.styles.tsx +234 -0
  42. package/src/Breadcrumb/Breadcrumb.web.tsx +268 -0
  43. package/src/Breadcrumb/index.native.ts +5 -0
  44. package/src/Breadcrumb/index.ts +5 -0
  45. package/src/Breadcrumb/index.web.ts +5 -0
  46. package/src/Breadcrumb/types.ts +56 -0
  47. package/src/Button/Button.native.tsx +75 -24
  48. package/src/Button/Button.styles.tsx +248 -205
  49. package/src/Button/Button.web.tsx +82 -25
  50. package/src/Button/index.ts +5 -5
  51. package/src/Button/index.web.ts +5 -3
  52. package/src/Button/types.ts +32 -15
  53. package/src/Card/Card.native.tsx +14 -11
  54. package/src/Card/Card.styles.tsx +146 -220
  55. package/src/Card/Card.web.tsx +20 -21
  56. package/src/Card/index.ts +5 -5
  57. package/src/Card/index.web.ts +5 -3
  58. package/src/Card/types.ts +24 -17
  59. package/src/Checkbox/Checkbox.native.tsx +24 -34
  60. package/src/Checkbox/Checkbox.styles.tsx +223 -275
  61. package/src/Checkbox/Checkbox.web.tsx +30 -37
  62. package/src/Checkbox/index.ts +5 -5
  63. package/src/Checkbox/index.web.ts +5 -3
  64. package/src/Checkbox/types.ts +26 -20
  65. package/src/Chip/Chip.native.tsx +126 -0
  66. package/src/Chip/Chip.styles.tsx +138 -0
  67. package/src/Chip/Chip.web.tsx +154 -0
  68. package/src/Chip/index.native.ts +5 -0
  69. package/src/Chip/index.ts +5 -0
  70. package/src/Chip/index.web.ts +5 -0
  71. package/src/Chip/types.ts +51 -0
  72. package/src/Dialog/Dialog.native.tsx +65 -12
  73. package/src/Dialog/Dialog.styles.tsx +154 -136
  74. package/src/Dialog/Dialog.web.tsx +16 -11
  75. package/src/Dialog/index.ts +5 -2
  76. package/src/Dialog/index.web.ts +5 -2
  77. package/src/Dialog/types.ts +22 -16
  78. package/src/Divider/Divider.native.tsx +19 -14
  79. package/src/Divider/Divider.styles.tsx +273 -595
  80. package/src/Divider/Divider.web.tsx +19 -12
  81. package/src/Divider/index.ts +5 -5
  82. package/src/Divider/index.web.ts +5 -3
  83. package/src/Divider/types.ts +28 -19
  84. package/src/Icon/Icon.native.tsx +17 -24
  85. package/src/Icon/Icon.styles.tsx +64 -48
  86. package/src/Icon/Icon.web.tsx +14 -11
  87. package/src/Icon/IconSvg/IconSvg.native.tsx +42 -0
  88. package/src/Icon/IconSvg/IconSvg.web.tsx +40 -0
  89. package/src/Icon/IconSvg/index.native.ts +1 -0
  90. package/src/Icon/IconSvg/index.ts +1 -0
  91. package/src/Icon/icon-resolver.native.ts +27 -0
  92. package/src/Icon/icon-resolver.ts +70 -0
  93. package/src/Icon/index.ts +5 -5
  94. package/src/Icon/index.web.ts +5 -3
  95. package/src/Icon/types.ts +17 -11
  96. package/src/Image/Image.native.tsx +86 -0
  97. package/src/Image/Image.styles.tsx +57 -0
  98. package/src/Image/Image.web.tsx +92 -0
  99. package/src/Image/index.native.ts +5 -0
  100. package/src/Image/index.ts +5 -0
  101. package/src/Image/types.ts +21 -0
  102. package/src/Input/Input.native.tsx +103 -26
  103. package/src/Input/Input.styles.tsx +240 -177
  104. package/src/Input/Input.web.tsx +141 -38
  105. package/src/Input/index.ts +5 -5
  106. package/src/Input/index.web.ts +5 -3
  107. package/src/Input/types.ts +43 -20
  108. package/src/List/List.native.tsx +56 -0
  109. package/src/List/List.styles.tsx +257 -0
  110. package/src/List/List.web.tsx +43 -0
  111. package/src/List/ListContext.tsx +16 -0
  112. package/src/List/ListItem.native.tsx +111 -0
  113. package/src/List/ListItem.web.tsx +110 -0
  114. package/src/List/ListSection.native.tsx +31 -0
  115. package/src/List/ListSection.web.tsx +33 -0
  116. package/src/List/index.native.tsx +5 -0
  117. package/src/List/index.ts +5 -0
  118. package/src/List/index.web.tsx +5 -0
  119. package/src/List/types.ts +42 -0
  120. package/src/Menu/Menu.native.tsx +150 -0
  121. package/src/Menu/Menu.styles.tsx +185 -0
  122. package/src/Menu/Menu.web.tsx +99 -0
  123. package/src/Menu/MenuItem.native.tsx +66 -0
  124. package/src/Menu/MenuItem.styles.tsx +119 -0
  125. package/src/Menu/MenuItem.web.tsx +67 -0
  126. package/src/Menu/index.native.ts +3 -0
  127. package/src/Menu/index.ts +3 -0
  128. package/src/Menu/index.web.ts +3 -0
  129. package/src/Menu/types.ts +30 -0
  130. package/src/Popover/Popover.native.tsx +102 -32
  131. package/src/Popover/Popover.styles.tsx +100 -67
  132. package/src/Popover/Popover.web.tsx +36 -260
  133. package/src/Popover/index.ts +5 -2
  134. package/src/Popover/index.web.ts +5 -2
  135. package/src/Popover/types.ts +14 -13
  136. package/src/Pressable/Pressable.native.tsx +7 -6
  137. package/src/Pressable/Pressable.web.tsx +8 -6
  138. package/src/Pressable/index.ts +5 -2
  139. package/src/Pressable/index.web.ts +5 -2
  140. package/src/Pressable/types.ts +11 -10
  141. package/src/Progress/Progress.native.tsx +179 -0
  142. package/src/Progress/Progress.styles.tsx +164 -0
  143. package/src/Progress/Progress.web.tsx +144 -0
  144. package/src/Progress/index.native.ts +1 -0
  145. package/src/Progress/index.ts +5 -0
  146. package/src/Progress/index.web.ts +5 -0
  147. package/src/Progress/types.ts +21 -0
  148. package/src/RadioButton/RadioButton.native.tsx +88 -0
  149. package/src/RadioButton/RadioButton.styles.tsx +163 -0
  150. package/src/RadioButton/RadioButton.web.tsx +85 -0
  151. package/src/RadioButton/RadioGroup.native.tsx +43 -0
  152. package/src/RadioButton/RadioGroup.web.tsx +49 -0
  153. package/src/RadioButton/index.native.ts +2 -0
  154. package/src/RadioButton/index.ts +2 -0
  155. package/src/RadioButton/index.web.ts +2 -0
  156. package/src/RadioButton/types.ts +29 -0
  157. package/src/SVGImage/SVGImage.native.tsx +9 -7
  158. package/src/SVGImage/SVGImage.styles.tsx +63 -55
  159. package/src/SVGImage/SVGImage.web.tsx +16 -13
  160. package/src/SVGImage/index.ts +5 -5
  161. package/src/SVGImage/index.web.ts +5 -2
  162. package/src/SVGImage/types.ts +7 -3
  163. package/src/Screen/Screen.native.tsx +43 -17
  164. package/src/Screen/Screen.styles.tsx +58 -54
  165. package/src/Screen/Screen.web.tsx +11 -5
  166. package/src/Screen/index.ts +5 -2
  167. package/src/Screen/index.web.ts +5 -2
  168. package/src/Screen/types.ts +23 -9
  169. package/src/Select/Select.native.tsx +140 -63
  170. package/src/Select/Select.styles.tsx +312 -302
  171. package/src/Select/Select.web.tsx +156 -316
  172. package/src/Select/index.ts +5 -2
  173. package/src/Select/index.web.ts +5 -2
  174. package/src/Select/types.ts +13 -7
  175. package/src/Skeleton/Skeleton.native.tsx +139 -0
  176. package/src/Skeleton/Skeleton.styles.tsx +59 -0
  177. package/src/Skeleton/Skeleton.web.tsx +112 -0
  178. package/src/Skeleton/index.native.ts +4 -0
  179. package/src/Skeleton/index.ts +5 -0
  180. package/src/Skeleton/index.web.ts +5 -0
  181. package/src/Skeleton/types.ts +75 -0
  182. package/src/Slider/Slider.native.tsx +248 -0
  183. package/src/Slider/Slider.styles.tsx +241 -0
  184. package/src/Slider/Slider.web.tsx +226 -0
  185. package/src/Slider/index.native.ts +3 -0
  186. package/src/Slider/index.ts +5 -0
  187. package/src/Slider/index.web.ts +5 -0
  188. package/src/Slider/types.ts +31 -0
  189. package/src/Switch/Switch.native.tsx +131 -0
  190. package/src/Switch/Switch.styles.tsx +169 -0
  191. package/src/Switch/Switch.web.tsx +121 -0
  192. package/src/Switch/index.native.ts +3 -0
  193. package/src/Switch/index.ts +5 -0
  194. package/src/Switch/index.web.ts +5 -0
  195. package/src/Switch/types.ts +21 -0
  196. package/src/TabBar/TabBar.native.tsx +142 -0
  197. package/src/TabBar/TabBar.styles.tsx +399 -0
  198. package/src/TabBar/TabBar.web.tsx +205 -0
  199. package/src/TabBar/index.native.tsx +3 -0
  200. package/src/TabBar/index.ts +3 -0
  201. package/src/TabBar/index.web.tsx +3 -0
  202. package/src/TabBar/types.ts +26 -0
  203. package/src/Table/Table.native.tsx +122 -0
  204. package/src/Table/Table.styles.tsx +283 -0
  205. package/src/Table/Table.web.tsx +112 -0
  206. package/src/Table/index.native.tsx +3 -0
  207. package/src/Table/index.ts +3 -0
  208. package/src/Table/index.web.tsx +3 -0
  209. package/src/Table/types.ts +28 -0
  210. package/src/Text/Text.native.tsx +12 -11
  211. package/src/Text/Text.styles.tsx +76 -64
  212. package/src/Text/Text.web.tsx +14 -9
  213. package/src/Text/index.ts +5 -5
  214. package/src/Text/index.web.ts +5 -3
  215. package/src/Text/types.ts +20 -13
  216. package/src/TextArea/TextArea.native.tsx +134 -0
  217. package/src/TextArea/TextArea.styles.tsx +175 -0
  218. package/src/TextArea/TextArea.web.tsx +156 -0
  219. package/src/TextArea/index.native.ts +3 -0
  220. package/src/TextArea/index.ts +3 -0
  221. package/src/TextArea/index.web.ts +3 -0
  222. package/src/TextArea/types.ts +30 -0
  223. package/src/Tooltip/Tooltip.native.tsx +165 -0
  224. package/src/Tooltip/Tooltip.styles.tsx +73 -0
  225. package/src/Tooltip/Tooltip.web.tsx +87 -0
  226. package/src/Tooltip/index.native.ts +3 -0
  227. package/src/Tooltip/index.ts +3 -0
  228. package/src/Tooltip/types.ts +18 -0
  229. package/src/Video/Video.native.tsx +105 -0
  230. package/src/Video/Video.styles.tsx +39 -0
  231. package/src/Video/Video.web.tsx +115 -0
  232. package/src/Video/index.native.ts +5 -0
  233. package/src/Video/index.ts +5 -0
  234. package/src/Video/types.ts +29 -0
  235. package/src/View/View.native.tsx +9 -14
  236. package/src/View/View.styles.tsx +101 -93
  237. package/src/View/View.web.tsx +16 -17
  238. package/src/View/index.ts +5 -5
  239. package/src/View/index.web.ts +5 -3
  240. package/src/View/types.ts +29 -21
  241. package/src/examples/AccordionExamples.tsx +126 -0
  242. package/src/examples/AlertExamples.tsx +280 -0
  243. package/src/examples/AvatarExamples.tsx +23 -23
  244. package/src/examples/BadgeExamples.tsx +109 -41
  245. package/src/examples/BreadcrumbExamples.tsx +312 -0
  246. package/src/examples/ButtonExamples.tsx +160 -33
  247. package/src/examples/CardExamples.tsx +40 -40
  248. package/src/examples/CheckboxExamples.tsx +12 -12
  249. package/src/examples/ChipExamples.tsx +197 -0
  250. package/src/examples/DialogExamples.tsx +22 -22
  251. package/src/examples/DividerExamples.tsx +49 -49
  252. package/src/examples/IconExamples.tsx +270 -54
  253. package/src/examples/ImageExamples.tsx +174 -0
  254. package/src/examples/InputExamples.tsx +75 -17
  255. package/src/examples/ListExamples.tsx +288 -0
  256. package/src/examples/MenuExamples.tsx +144 -0
  257. package/src/examples/PopoverExamples.tsx +69 -73
  258. package/src/examples/ProgressExamples.tsx +137 -0
  259. package/src/examples/RadioButtonExamples.tsx +161 -0
  260. package/src/examples/SVGImageExamples.tsx +19 -17
  261. package/src/examples/ScreenExamples.tsx +31 -31
  262. package/src/examples/SelectExamples.tsx +67 -67
  263. package/src/examples/SkeletonExamples.tsx +206 -0
  264. package/src/examples/SliderExamples.tsx +200 -0
  265. package/src/examples/SwitchExamples.tsx +182 -0
  266. package/src/examples/TabBarExamples.tsx +143 -0
  267. package/src/examples/TableExamples.tsx +280 -0
  268. package/src/examples/TextAreaExamples.tsx +173 -0
  269. package/src/examples/TextExamples.tsx +28 -32
  270. package/src/examples/ThemeExtensionExamples.tsx +10 -10
  271. package/src/examples/TooltipExamples.tsx +126 -0
  272. package/src/examples/VideoExamples.tsx +144 -0
  273. package/src/examples/ViewExamples.tsx +64 -56
  274. package/src/examples/index.ts +17 -3
  275. package/src/hooks/useMergeRefs.ts +16 -0
  276. package/src/hooks/useSmartPosition.native.ts +169 -0
  277. package/src/index.native.ts +80 -9
  278. package/src/index.ts +71 -1
  279. package/src/internal/BoundedModalContent.native.tsx +58 -0
  280. package/src/internal/PositionedPortal.tsx +254 -0
  281. package/src/internal/SafeAreaDebugOverlay.native.tsx +173 -0
  282. package/src/unistyles.d.ts +6 -0
  283. package/src/utils/buildSizeVariants.ts +16 -0
  284. package/src/utils/deepMerge.ts +43 -0
  285. package/src/utils/positionUtils.native.ts +280 -0
  286. package/src/utils/styleHelpers.ts +48 -0
  287. package/LLM-ACCESS-GUIDE.md +0 -143
  288. package/src/ActivityIndicator/README.md +0 -132
  289. package/src/Avatar/README.md +0 -139
  290. package/src/Badge/README.md +0 -170
  291. package/src/Button/Button.types.ts +0 -12
  292. package/src/Button/README.md +0 -262
  293. package/src/Card/README.md +0 -258
  294. package/src/Checkbox/README.md +0 -102
  295. package/src/Dialog/README.md +0 -210
  296. package/src/Divider/README.md +0 -108
  297. package/src/Icon/README.md +0 -81
  298. package/src/Input/README.md +0 -100
  299. package/src/SVGImage/README.md +0 -209
  300. package/src/Screen/README.md +0 -86
  301. package/src/Select/README.md +0 -166
  302. package/src/Text/README.md +0 -94
  303. package/src/View/README.md +0 -107
  304. package/src/examples/AllExamples.tsx +0 -88
  305. package/src/examples/README.md +0 -136
  306. package/src/examples/ValidationExamples.tsx +0 -95
  307. package/src/examples/extendedTheme.ts +0 -329
  308. package/src/theme/breakpoints.ts +0 -8
  309. package/src/theme/colorResolver.ts +0 -218
  310. package/src/theme/colors.ts +0 -315
  311. package/src/theme/defaultThemes.ts +0 -326
  312. package/src/theme/index.ts +0 -188
  313. package/src/theme/themeBuilder.ts +0 -602
  314. package/src/theme/unistyles.d.ts +0 -6
  315. package/src/theme/variantHelpers.ts +0 -584
  316. package/src/theme/variants.ts +0 -56
@@ -1,325 +1,335 @@
1
1
  import { StyleSheet } from 'react-native-unistyles';
2
+ import { Theme, StylesheetStyles, Intent, Size } from '@idealyst/theme';
3
+ import { buildSizeVariants } from '../utils/buildSizeVariants';
4
+ import { SelectIntentVariant } from './types';
2
5
 
3
- export const selectStyles = StyleSheet.create((theme) => ({
4
- container: {
5
- position: 'relative',
6
- },
6
+ // Type definitions
7
+ type SelectSize = Size;
8
+ type SelectType = 'outlined' | 'filled';
7
9
 
8
- label: {
9
- fontSize: theme.typography?.sm?.fontSize || 14,
10
- fontWeight: theme.typography?.sm?.fontWeight || '500',
11
- color: theme.colors?.text?.primary || theme.palettes?.gray?.[700] || '#374151',
12
- marginBottom: theme.spacing?.xs || 4,
13
- },
10
+ type SelectTriggerVariants = {
11
+ type: SelectType;
12
+ size: SelectSize;
13
+ intent: SelectIntentVariant;
14
+ disabled: boolean;
15
+ error: boolean;
16
+ focused: boolean;
17
+ }
14
18
 
15
- trigger: {
16
- position: 'relative',
17
- flexDirection: 'row',
18
- alignItems: 'center',
19
- justifyContent: 'space-between',
20
- paddingHorizontal: theme.spacing?.sm || 12,
21
- borderRadius: theme.borderRadius?.md || 8,
22
- borderWidth: 1,
23
- minHeight: 44,
24
- cursor: 'pointer',
25
19
 
26
- variants: {
27
- variant: {
20
+ export type ExpandedSelectTriggerStyles = StylesheetStyles<keyof SelectTriggerVariants>;
21
+ export type ExpandedSelectStyles = StylesheetStyles<never>;
22
+
23
+ function createTriggerTypeVariants(theme: Theme) {
24
+ return {
28
25
  outlined: {
29
- backgroundColor: 'transparent',
30
- borderColor: theme.colors?.border?.primary || theme.palettes?.gray?.[300] || '#d1d5db',
31
- _web: {
32
- border: `1px solid ${theme.colors?.border?.primary || theme.palettes?.gray?.[300] || '#d1d5db'}`,
33
- },
26
+ backgroundColor: theme.colors.surface.primary,
27
+ borderColor: theme.colors.border.primary,
28
+ _web: {
29
+ border: `1px solid ${theme.colors.border.primary}`,
30
+ },
34
31
  },
35
32
  filled: {
36
- backgroundColor: theme.colors?.surface?.secondary || theme.palettes?.gray?.[50] || '#f9fafb',
37
- borderColor: 'transparent',
38
- _web: {
39
- border: '1px solid transparent',
40
- },
33
+ backgroundColor: theme.colors.surface.secondary,
34
+ borderColor: 'transparent',
35
+ _web: {
36
+ border: '1px solid transparent',
37
+ },
41
38
  },
42
- },
43
- size: {
44
- small: {
45
- paddingHorizontal: theme.spacing?.xs || 8,
46
- minHeight: 36,
39
+ } as const;
40
+ }
41
+
42
+ function createTriggerSizeVariants(theme: Theme) {
43
+ return buildSizeVariants(theme, 'select', (size) => ({
44
+ paddingHorizontal: size.paddingHorizontal,
45
+ minHeight: size.minHeight,
46
+ }));
47
+ }
48
+
49
+ function createIntentVariants(theme: Theme, type: SelectType, intent: SelectIntentVariant) {
50
+ if (intent === 'neutral') {
51
+ return {};
52
+ }
53
+
54
+ const intentValue = (theme.intents as any)[intent];
55
+
56
+ if (type === 'outlined') {
57
+ return {
58
+ borderColor: intentValue.primary,
59
+ _web: {
60
+ border: `1px solid ${intentValue.primary}`,
61
+ },
62
+ } as const;
63
+ }
64
+
65
+ return {} as const;
66
+ }
67
+
68
+ function buildDynamicTriggerStyles(theme: Theme) {
69
+ return ({ type, intent }: Partial<SelectTriggerVariants>) => {
70
+ const intentStyles = createIntentVariants(theme, type, intent);
71
+
72
+ return {
73
+ position: 'relative',
74
+ flexDirection: 'row',
75
+ alignItems: 'center',
76
+ justifyContent: 'space-between',
77
+ borderRadius: 8,
78
+ borderWidth: 1,
79
+ borderStyle: 'solid',
80
+ ...intentStyles,
81
+ variants: {
82
+ type: createTriggerTypeVariants(theme),
83
+ size: createTriggerSizeVariants(theme),
84
+ disabled: {
85
+ true: {
86
+ opacity: 0.6,
87
+ _web: {
88
+ cursor: 'not-allowed',
89
+ },
90
+ },
91
+ false: {
92
+ _web: {
93
+ cursor: 'pointer',
94
+ _hover: {
95
+ opacity: 0.9,
96
+ },
97
+ _active: {
98
+ opacity: 0.8,
99
+ },
100
+ },
101
+ },
102
+ },
103
+ error: {
104
+ true: {
105
+ borderColor: theme.intents.error.primary,
106
+ _web: {
107
+ border: `1px solid ${theme.intents.error.primary}`,
108
+ },
109
+ },
110
+ false: {},
111
+ },
112
+ focused: {
113
+ true: {
114
+ borderColor: theme.intents.primary.primary,
115
+ _web: {
116
+ border: `2px solid ${theme.intents.primary.primary}`,
117
+ outline: 'none',
118
+ },
119
+ },
120
+ false: {},
121
+ },
122
+ },
123
+ _web: {
124
+ display: 'flex',
125
+ boxSizing: 'border-box',
126
+ _focus: {
127
+ outline: 'none',
128
+ },
129
+ },
130
+ } as const;
131
+ }
132
+ }
133
+
134
+ // Styles are inlined here instead of in @idealyst/theme because Unistyles' Babel
135
+ // transform on native cannot resolve function calls to extract variant structures.
136
+ export const selectStyles = StyleSheet.create((theme: Theme) => {
137
+ return {
138
+ container: {
139
+ position: 'relative',
140
+ backgroundColor: theme.colors.surface.primary,
47
141
  },
48
- medium: {
49
- paddingHorizontal: theme.spacing?.sm || 12,
50
- minHeight: 44,
142
+ label: {
143
+ fontSize: 14,
144
+ fontWeight: '500',
145
+ color: theme.colors.text.primary,
146
+ marginBottom: 4,
51
147
  },
52
- large: {
53
- paddingHorizontal: theme.spacing?.md || 16,
54
- minHeight: 52,
148
+ trigger: buildDynamicTriggerStyles(theme),
149
+ triggerContent: {
150
+ flex: 1,
151
+ flexDirection: 'row',
152
+ alignItems: 'center',
55
153
  },
56
- },
57
- intent: {
58
- neutral: {},
59
- primary: {},
60
- success: {},
61
- error: {},
62
- warning: {},
63
- info: {},
64
- },
65
- disabled: {
66
- true: {
67
- opacity: 0.6,
68
- cursor: 'not-allowed',
154
+ triggerText: {
155
+ color: theme.colors.text.primary,
156
+ flex: 1,
157
+ variants: {
158
+ size: buildSizeVariants(theme, 'select', (size: any) => ({
159
+ fontSize: size.fontSize,
160
+ })),
161
+ },
69
162
  },
70
- false: {},
71
- },
72
- error: {
73
- true: {
74
- borderColor: theme.intents?.error?.main || '#ef4444',
75
- _web: {
76
- border: `1px solid ${theme.intents?.error?.main || '#ef4444'}`,
77
- },
163
+ placeholder: {
164
+ color: theme.colors.text.secondary,
165
+ variants: {
166
+ size: buildSizeVariants(theme, 'select', (size: any) => ({
167
+ fontSize: size.fontSize,
168
+ })),
169
+ },
78
170
  },
79
- false: {},
80
- },
81
- focused: {
82
- true: {
83
- borderColor: theme.intents?.primary?.main || '#3b82f6',
84
- _web: {
85
- border: `2px solid ${theme.intents?.primary?.main || '#3b82f6'}`,
86
- outline: 'none',
87
- },
171
+ icon: {
172
+ marginLeft: 4,
173
+ color: theme.colors.text.secondary,
88
174
  },
89
- false: {},
90
- },
91
- },
92
-
93
- compoundVariants: [
94
- {
95
- variant: 'outlined',
96
- intent: 'primary',
97
- styles: {
98
- borderColor: theme.intents?.primary?.main || '#3b82f6',
99
- _web: {
100
- border: `1px solid ${theme.intents?.primary?.main || '#3b82f6'}`,
101
- },
175
+ chevron: {
176
+ display: 'flex',
177
+ alignItems: 'center',
178
+ justifyContent: 'center',
179
+ marginLeft: 4,
180
+ color: theme.colors.text.secondary,
181
+ variants: {
182
+ size: buildSizeVariants(theme, 'select', (size: any) => ({
183
+ width: size.iconSize,
184
+ height: size.iconSize,
185
+ })),
186
+ },
187
+ _web: {
188
+ transition: 'transform 0.2s ease',
189
+ },
102
190
  },
103
- },
104
- {
105
- variant: 'outlined',
106
- intent: 'success',
107
- styles: {
108
- borderColor: theme.intents?.success?.main || '#22c55e',
109
- _web: {
110
- border: `1px solid ${theme.intents?.success?.main || '#22c55e'}`,
111
- },
191
+ chevronOpen: {
192
+ _web: {
193
+ transform: 'rotate(180deg)',
194
+ }
112
195
  },
113
- },
114
- {
115
- variant: 'outlined',
116
- intent: 'error',
117
- styles: {
118
- borderColor: theme.intents?.error?.main || '#ef4444',
119
- _web: {
120
- border: `1px solid ${theme.intents?.error?.main || '#ef4444'}`,
121
- },
196
+ dropdown: {
197
+ position: 'absolute',
198
+ top: '100%',
199
+ left: 0,
200
+ right: 0,
201
+ backgroundColor: theme.colors.surface.primary,
202
+ borderRadius: 8,
203
+ borderWidth: 1,
204
+ borderStyle: 'solid',
205
+ borderColor: theme.colors.border.primary,
206
+ shadowColor: '#000',
207
+ shadowOffset: { width: 0, height: 8 },
208
+ shadowOpacity: 0.1,
209
+ shadowRadius: 24,
210
+ elevation: 8,
211
+ zIndex: 9999,
212
+ maxHeight: 240,
213
+ minWidth: 200,
214
+ overflow: 'hidden',
215
+ _web: {
216
+ border: `1px solid ${theme.colors.border.primary}`,
217
+ boxShadow: '0 8px 24px rgba(0, 0, 0, 0.1), 0 4px 8px rgba(0, 0, 0, 0.06)',
218
+ overflowY: 'auto',
219
+ },
122
220
  },
123
- },
124
- {
125
- variant: 'outlined',
126
- intent: 'warning',
127
- styles: {
128
- borderColor: theme.intents?.warning?.main || '#f59e0b',
129
- _web: {
130
- border: `1px solid ${theme.intents?.warning?.main || '#f59e0b'}`,
131
- },
221
+ searchContainer: {
222
+ padding: 8,
223
+ borderBottomWidth: 1,
224
+ borderBottomStyle: 'solid',
225
+ borderBottomColor: theme.colors.border.primary,
226
+ _web: {
227
+ borderBottom: `1px solid ${theme.colors.border.primary}`,
228
+ },
132
229
  },
133
- },
134
- {
135
- variant: 'outlined',
136
- intent: 'info',
137
- styles: {
138
- borderColor: theme.intents?.info?.main || '#06b6d4',
139
- _web: {
140
- border: `1px solid ${theme.intents?.info?.main || '#06b6d4'}`,
141
- },
230
+ searchInput: {
231
+ padding: 4,
232
+ borderRadius: 4,
233
+ borderWidth: 1,
234
+ borderStyle: 'solid',
235
+ borderColor: theme.colors.border.primary,
236
+ backgroundColor: theme.colors.surface.primary,
237
+ variants: {
238
+ size: buildSizeVariants(theme, 'select', (size: any) => ({
239
+ fontSize: size.fontSize,
240
+ })),
241
+ },
242
+ _web: {
243
+ border: `1px solid ${theme.colors.border.primary}`,
244
+ outline: 'none',
245
+ _focus: {
246
+ borderColor: theme.intents.primary.primary,
247
+ },
248
+ },
142
249
  },
143
- },
144
- ],
145
-
146
- _web: {
147
- display: 'flex',
148
- boxSizing: 'border-box',
149
- _focus: {
150
- outline: 'none',
151
- },
152
- _hover: {
153
- borderColor: theme.intents?.primary?.main || '#3b82f6',
154
- },
155
- },
156
- },
157
-
158
- triggerContent: {
159
- flex: 1,
160
- flexDirection: 'row',
161
- alignItems: 'center',
162
- },
163
-
164
- triggerText: {
165
- fontSize: theme.typography?.base?.fontSize || 16,
166
- color: theme.colors?.text?.primary || theme.palettes?.gray?.[900] || '#111827',
167
- flex: 1,
168
- },
169
-
170
- placeholder: {
171
- fontSize: theme.typography?.base?.fontSize || 16,
172
- color: theme.colors?.text?.disabled || theme.palettes?.gray?.[500] || '#6b7280',
173
- },
174
-
175
- icon: {
176
- marginLeft: theme.spacing?.xs || 4,
177
- color: theme.colors?.text?.secondary || theme.palettes?.gray?.[600] || '#4b5563',
178
- },
179
-
180
- chevron: {
181
- marginLeft: theme.spacing?.xs || 4,
182
- color: theme.colors?.text?.secondary || theme.palettes?.gray?.[600] || '#4b5563',
183
- transition: 'transform 0.2s ease',
184
- },
185
-
186
- chevronOpen: {
187
- transform: 'rotate(180deg)',
188
- },
189
-
190
- dropdown: {
191
- position: 'absolute',
192
- top: '100%',
193
- left: 0,
194
- right: 0,
195
- backgroundColor: theme.colors?.surface?.primary || '#ffffff',
196
- borderRadius: theme.borderRadius?.md || 8,
197
- borderWidth: 1,
198
- borderColor: theme.colors?.border?.primary || theme.palettes?.gray?.[200] || '#e5e7eb',
199
- shadowColor: theme.shadows?.lg?.shadowColor || '#000',
200
- shadowOffset: theme.shadows?.lg?.shadowOffset || { width: 0, height: 8 },
201
- shadowOpacity: theme.shadows?.lg?.shadowOpacity || 0.15,
202
- shadowRadius: theme.shadows?.lg?.shadowRadius || 12,
203
- elevation: theme.shadows?.lg?.elevation || 8,
204
- zIndex: 9999, // Higher z-index to float above other content
205
- maxHeight: 240,
206
- overflow: 'hidden',
207
-
208
- _web: {
209
- border: `1px solid ${theme.colors?.border?.primary || theme.palettes?.gray?.[200] || '#e5e7eb'}`,
210
- boxShadow: '0 8px 24px rgba(0, 0, 0, 0.1), 0 4px 8px rgba(0, 0, 0, 0.06)',
211
- overflowY: 'auto',
212
- },
213
- },
214
-
215
- searchContainer: {
216
- padding: theme.spacing?.sm || 12,
217
- borderBottomWidth: 1,
218
- borderBottomColor: theme.colors?.border?.primary || theme.palettes?.gray?.[200] || '#e5e7eb',
219
-
220
- _web: {
221
- borderBottom: `1px solid ${theme.colors?.border?.primary || theme.palettes?.gray?.[200] || '#e5e7eb'}`,
222
- },
223
- },
224
-
225
- searchInput: {
226
- padding: theme.spacing?.xs || 8,
227
- borderRadius: theme.borderRadius?.sm || 4,
228
- borderWidth: 1,
229
- borderColor: theme.colors?.border?.primary || theme.palettes?.gray?.[300] || '#d1d5db',
230
- fontSize: theme.typography?.sm?.fontSize || 14,
231
- backgroundColor: theme.colors?.surface?.primary || '#ffffff',
232
-
233
- _web: {
234
- border: `1px solid ${theme.colors?.border?.primary || theme.palettes?.gray?.[300] || '#d1d5db'}`,
235
- outline: 'none',
236
- _focus: {
237
- borderColor: theme.intents?.primary?.main || '#3b82f6',
238
- },
239
- },
240
- },
241
-
242
- optionsList: {
243
- paddingVertical: theme.spacing?.xs || 4,
244
- },
245
-
246
- option: {
247
- paddingHorizontal: theme.spacing?.sm || 12,
248
- paddingVertical: theme.spacing?.sm || 12,
249
- flexDirection: 'row',
250
- alignItems: 'center',
251
- cursor: 'pointer',
252
- minHeight: 44,
253
-
254
- variants: {
255
- selected: {
256
- true: {
257
- backgroundColor: theme.intents?.primary?.container || theme.palettes?.blue?.[50] || '#eff6ff',
250
+ optionsList: {
251
+ paddingVertical: 4,
258
252
  },
259
- false: {},
260
- },
261
- disabled: {
262
- true: {
263
- opacity: 0.5,
264
- cursor: 'not-allowed',
253
+ option: {
254
+ paddingHorizontal: 8,
255
+ paddingVertical: 4,
256
+ flexDirection: 'row',
257
+ alignItems: 'center',
258
+ minHeight: 36,
259
+ variants: {
260
+ selected: {
261
+ true: {
262
+ backgroundColor: theme.intents.primary.light,
263
+ },
264
+ false: {},
265
+ },
266
+ disabled: {
267
+ true: {
268
+ opacity: 0.5,
269
+ _web: {
270
+ cursor: 'not-allowed',
271
+ },
272
+ },
273
+ false: {
274
+ _web: {
275
+ cursor: 'pointer',
276
+ _hover: {
277
+ backgroundColor: theme.colors.surface.secondary,
278
+ },
279
+ _active: {
280
+ opacity: 0.8,
281
+ },
282
+ },
283
+ },
284
+ },
285
+ },
286
+ _web: {
287
+ display: 'flex',
288
+ },
265
289
  },
266
- false: {},
267
- },
268
- },
269
-
270
- _web: {
271
- display: 'flex',
272
- _hover: {
273
- backgroundColor: theme.colors?.surface?.secondary || theme.palettes?.gray?.[50] || '#f9fafb',
274
- },
275
- },
276
- },
277
-
278
- optionContent: {
279
- flexDirection: 'row',
280
- alignItems: 'center',
281
- flex: 1,
282
- },
283
-
284
- optionIcon: {
285
- marginRight: theme.spacing?.xs || 8,
286
- },
287
-
288
- optionText: {
289
- fontSize: theme.typography?.base?.fontSize || 16,
290
- color: theme.colors?.text?.primary || theme.palettes?.gray?.[900] || '#111827',
291
- flex: 1,
292
- },
293
-
294
- optionTextDisabled: {
295
- color: theme.colors?.text?.disabled || theme.palettes?.gray?.[500] || '#6b7280',
296
- },
297
-
298
- helperText: {
299
- fontSize: theme.typography?.xs?.fontSize || 12,
300
- marginTop: theme.spacing?.xs || 4,
301
- color: theme.colors?.text?.secondary || theme.palettes?.gray?.[600] || '#4b5563',
302
-
303
- variants: {
304
- error: {
305
- true: {
306
- color: theme.intents?.error?.main || '#ef4444',
290
+ optionContent: {
291
+ flexDirection: 'row',
292
+ alignItems: 'center',
293
+ flex: 1,
307
294
  },
308
- false: {},
309
- },
310
- },
311
- },
312
-
313
- overlay: {
314
- position: 'absolute',
315
- top: 0,
316
- left: 0,
317
- right: 0,
318
- bottom: 0,
319
- zIndex: 999,
320
-
321
- _web: {
322
- position: 'fixed',
323
- },
324
- },
325
- }));
295
+ optionIcon: {
296
+ marginRight: 4,
297
+ },
298
+ optionText: {
299
+ color: theme.colors.text.primary,
300
+ flex: 1,
301
+ variants: {
302
+ size: buildSizeVariants(theme, 'select', (size: any) => ({
303
+ fontSize: size.fontSize,
304
+ })),
305
+ },
306
+ },
307
+ optionTextDisabled: {
308
+ color: theme.colors.text.secondary,
309
+ },
310
+ helperText: {
311
+ fontSize: 12,
312
+ marginTop: 4,
313
+ color: theme.colors.text.secondary,
314
+ variants: {
315
+ error: {
316
+ true: {
317
+ color: theme.intents.error.primary,
318
+ },
319
+ false: {},
320
+ },
321
+ },
322
+ },
323
+ overlay: {
324
+ position: 'absolute',
325
+ top: 0,
326
+ left: 0,
327
+ right: 0,
328
+ bottom: 0,
329
+ zIndex: 999,
330
+ _web: {
331
+ position: 'fixed',
332
+ },
333
+ },
334
+ } as const;
335
+ });