fluentglass 0.2.6

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 (414) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +169 -0
  3. package/lib/commonjs/assets/fonts/Inter-Black.ttf +0 -0
  4. package/lib/commonjs/assets/fonts/Inter-Bold.ttf +0 -0
  5. package/lib/commonjs/assets/fonts/Inter-ExtraBold.ttf +0 -0
  6. package/lib/commonjs/assets/fonts/Inter-Medium.ttf +0 -0
  7. package/lib/commonjs/assets/fonts/Inter-Regular.ttf +0 -0
  8. package/lib/commonjs/assets/fonts/Inter-SemiBold.ttf +0 -0
  9. package/lib/commonjs/components/FluentGlass.js +94 -0
  10. package/lib/commonjs/components/FluentGlass.js.map +1 -0
  11. package/lib/commonjs/components/FluentGlassAlert.js +126 -0
  12. package/lib/commonjs/components/FluentGlassAlert.js.map +1 -0
  13. package/lib/commonjs/components/FluentGlassBadge.js +124 -0
  14. package/lib/commonjs/components/FluentGlassBadge.js.map +1 -0
  15. package/lib/commonjs/components/FluentGlassBarChart.js +287 -0
  16. package/lib/commonjs/components/FluentGlassBarChart.js.map +1 -0
  17. package/lib/commonjs/components/FluentGlassBreadcrumb.js +155 -0
  18. package/lib/commonjs/components/FluentGlassBreadcrumb.js.map +1 -0
  19. package/lib/commonjs/components/FluentGlassButton.js +175 -0
  20. package/lib/commonjs/components/FluentGlassButton.js.map +1 -0
  21. package/lib/commonjs/components/FluentGlassCalendarWidget.js +73 -0
  22. package/lib/commonjs/components/FluentGlassCalendarWidget.js.map +1 -0
  23. package/lib/commonjs/components/FluentGlassCard.js +195 -0
  24. package/lib/commonjs/components/FluentGlassCard.js.map +1 -0
  25. package/lib/commonjs/components/FluentGlassCheckbox.js +121 -0
  26. package/lib/commonjs/components/FluentGlassCheckbox.js.map +1 -0
  27. package/lib/commonjs/components/FluentGlassClockWidget.js +80 -0
  28. package/lib/commonjs/components/FluentGlassClockWidget.js.map +1 -0
  29. package/lib/commonjs/components/FluentGlassCodeBlock.js +239 -0
  30. package/lib/commonjs/components/FluentGlassCodeBlock.js.map +1 -0
  31. package/lib/commonjs/components/FluentGlassContainer.js +52 -0
  32. package/lib/commonjs/components/FluentGlassContainer.js.map +1 -0
  33. package/lib/commonjs/components/FluentGlassCrossfade.js +118 -0
  34. package/lib/commonjs/components/FluentGlassCrossfade.js.map +1 -0
  35. package/lib/commonjs/components/FluentGlassDateInput.js +176 -0
  36. package/lib/commonjs/components/FluentGlassDateInput.js.map +1 -0
  37. package/lib/commonjs/components/FluentGlassDatePicker.js +271 -0
  38. package/lib/commonjs/components/FluentGlassDatePicker.js.map +1 -0
  39. package/lib/commonjs/components/FluentGlassDialog.js +169 -0
  40. package/lib/commonjs/components/FluentGlassDialog.js.map +1 -0
  41. package/lib/commonjs/components/FluentGlassDock.js +187 -0
  42. package/lib/commonjs/components/FluentGlassDock.js.map +1 -0
  43. package/lib/commonjs/components/FluentGlassDropdown.js +349 -0
  44. package/lib/commonjs/components/FluentGlassDropdown.js.map +1 -0
  45. package/lib/commonjs/components/FluentGlassEmailInput.js +43 -0
  46. package/lib/commonjs/components/FluentGlassEmailInput.js.map +1 -0
  47. package/lib/commonjs/components/FluentGlassInput.js +83 -0
  48. package/lib/commonjs/components/FluentGlassInput.js.map +1 -0
  49. package/lib/commonjs/components/FluentGlassLabeledInput.js +64 -0
  50. package/lib/commonjs/components/FluentGlassLabeledInput.js.map +1 -0
  51. package/lib/commonjs/components/FluentGlassLayout.js +106 -0
  52. package/lib/commonjs/components/FluentGlassLayout.js.map +1 -0
  53. package/lib/commonjs/components/FluentGlassPasswordInput.js +60 -0
  54. package/lib/commonjs/components/FluentGlassPasswordInput.js.map +1 -0
  55. package/lib/commonjs/components/FluentGlassPopover.js +75 -0
  56. package/lib/commonjs/components/FluentGlassPopover.js.map +1 -0
  57. package/lib/commonjs/components/FluentGlassResponsiveRow.js +74 -0
  58. package/lib/commonjs/components/FluentGlassResponsiveRow.js.map +1 -0
  59. package/lib/commonjs/components/FluentGlassScrollArea.js +101 -0
  60. package/lib/commonjs/components/FluentGlassScrollArea.js.map +1 -0
  61. package/lib/commonjs/components/FluentGlassSegmentedControl.js +126 -0
  62. package/lib/commonjs/components/FluentGlassSegmentedControl.js.map +1 -0
  63. package/lib/commonjs/components/FluentGlassSelect.js +155 -0
  64. package/lib/commonjs/components/FluentGlassSelect.js.map +1 -0
  65. package/lib/commonjs/components/FluentGlassSeparator.js +62 -0
  66. package/lib/commonjs/components/FluentGlassSeparator.js.map +1 -0
  67. package/lib/commonjs/components/FluentGlassSheet.js +189 -0
  68. package/lib/commonjs/components/FluentGlassSheet.js.map +1 -0
  69. package/lib/commonjs/components/FluentGlassSidebar.js +358 -0
  70. package/lib/commonjs/components/FluentGlassSidebar.js.map +1 -0
  71. package/lib/commonjs/components/FluentGlassSimpleCard.js +56 -0
  72. package/lib/commonjs/components/FluentGlassSimpleCard.js.map +1 -0
  73. package/lib/commonjs/components/FluentGlassSkeleton.js +52 -0
  74. package/lib/commonjs/components/FluentGlassSkeleton.js.map +1 -0
  75. package/lib/commonjs/components/FluentGlassSlider.js +197 -0
  76. package/lib/commonjs/components/FluentGlassSlider.js.map +1 -0
  77. package/lib/commonjs/components/FluentGlassStatWidget.js +133 -0
  78. package/lib/commonjs/components/FluentGlassStatWidget.js.map +1 -0
  79. package/lib/commonjs/components/FluentGlassStatusIndicator.js +89 -0
  80. package/lib/commonjs/components/FluentGlassStatusIndicator.js.map +1 -0
  81. package/lib/commonjs/components/FluentGlassSwitch.js +126 -0
  82. package/lib/commonjs/components/FluentGlassSwitch.js.map +1 -0
  83. package/lib/commonjs/components/FluentGlassTable.js +163 -0
  84. package/lib/commonjs/components/FluentGlassTable.js.map +1 -0
  85. package/lib/commonjs/components/FluentGlassTag.js +109 -0
  86. package/lib/commonjs/components/FluentGlassTag.js.map +1 -0
  87. package/lib/commonjs/components/FluentGlassTextInput.js +90 -0
  88. package/lib/commonjs/components/FluentGlassTextInput.js.map +1 -0
  89. package/lib/commonjs/components/FluentGlassTimeline.js +334 -0
  90. package/lib/commonjs/components/FluentGlassTimeline.js.map +1 -0
  91. package/lib/commonjs/components/FluentGlassWeatherWidget.js +72 -0
  92. package/lib/commonjs/components/FluentGlassWeatherWidget.js.map +1 -0
  93. package/lib/commonjs/components/index.js +308 -0
  94. package/lib/commonjs/components/index.js.map +1 -0
  95. package/lib/commonjs/fonts.js +33 -0
  96. package/lib/commonjs/fonts.js.map +1 -0
  97. package/lib/commonjs/hooks/useBreakpoint.js +57 -0
  98. package/lib/commonjs/hooks/useBreakpoint.js.map +1 -0
  99. package/lib/commonjs/index.js +462 -0
  100. package/lib/commonjs/index.js.map +1 -0
  101. package/lib/commonjs/package.json +1 -0
  102. package/lib/commonjs/theme/FluentGlassProvider.js +84 -0
  103. package/lib/commonjs/theme/FluentGlassProvider.js.map +1 -0
  104. package/lib/commonjs/theme/defaultTheme.js +55 -0
  105. package/lib/commonjs/theme/defaultTheme.js.map +1 -0
  106. package/lib/commonjs/theme/resolvers.js +118 -0
  107. package/lib/commonjs/theme/resolvers.js.map +1 -0
  108. package/lib/commonjs/theme/tokens.js +239 -0
  109. package/lib/commonjs/theme/tokens.js.map +1 -0
  110. package/lib/commonjs/theme/typography.js +50 -0
  111. package/lib/commonjs/theme/typography.js.map +1 -0
  112. package/lib/commonjs/theme/useTheme.js +22 -0
  113. package/lib/commonjs/theme/useTheme.js.map +1 -0
  114. package/lib/commonjs/types/components.js +6 -0
  115. package/lib/commonjs/types/components.js.map +1 -0
  116. package/lib/commonjs/types/theme.js +6 -0
  117. package/lib/commonjs/types/theme.js.map +1 -0
  118. package/lib/commonjs/utils/colors.js +59 -0
  119. package/lib/commonjs/utils/colors.js.map +1 -0
  120. package/lib/commonjs/utils/responsive.js +126 -0
  121. package/lib/commonjs/utils/responsive.js.map +1 -0
  122. package/lib/module/assets/fonts/Inter-Black.ttf +0 -0
  123. package/lib/module/assets/fonts/Inter-Bold.ttf +0 -0
  124. package/lib/module/assets/fonts/Inter-ExtraBold.ttf +0 -0
  125. package/lib/module/assets/fonts/Inter-Medium.ttf +0 -0
  126. package/lib/module/assets/fonts/Inter-Regular.ttf +0 -0
  127. package/lib/module/assets/fonts/Inter-SemiBold.ttf +0 -0
  128. package/lib/module/components/FluentGlass.js +89 -0
  129. package/lib/module/components/FluentGlass.js.map +1 -0
  130. package/lib/module/components/FluentGlassAlert.js +121 -0
  131. package/lib/module/components/FluentGlassAlert.js.map +1 -0
  132. package/lib/module/components/FluentGlassBadge.js +119 -0
  133. package/lib/module/components/FluentGlassBadge.js.map +1 -0
  134. package/lib/module/components/FluentGlassBarChart.js +281 -0
  135. package/lib/module/components/FluentGlassBarChart.js.map +1 -0
  136. package/lib/module/components/FluentGlassBreadcrumb.js +150 -0
  137. package/lib/module/components/FluentGlassBreadcrumb.js.map +1 -0
  138. package/lib/module/components/FluentGlassButton.js +169 -0
  139. package/lib/module/components/FluentGlassButton.js.map +1 -0
  140. package/lib/module/components/FluentGlassCalendarWidget.js +68 -0
  141. package/lib/module/components/FluentGlassCalendarWidget.js.map +1 -0
  142. package/lib/module/components/FluentGlassCard.js +190 -0
  143. package/lib/module/components/FluentGlassCard.js.map +1 -0
  144. package/lib/module/components/FluentGlassCheckbox.js +115 -0
  145. package/lib/module/components/FluentGlassCheckbox.js.map +1 -0
  146. package/lib/module/components/FluentGlassClockWidget.js +74 -0
  147. package/lib/module/components/FluentGlassClockWidget.js.map +1 -0
  148. package/lib/module/components/FluentGlassCodeBlock.js +233 -0
  149. package/lib/module/components/FluentGlassCodeBlock.js.map +1 -0
  150. package/lib/module/components/FluentGlassContainer.js +47 -0
  151. package/lib/module/components/FluentGlassContainer.js.map +1 -0
  152. package/lib/module/components/FluentGlassCrossfade.js +112 -0
  153. package/lib/module/components/FluentGlassCrossfade.js.map +1 -0
  154. package/lib/module/components/FluentGlassDateInput.js +170 -0
  155. package/lib/module/components/FluentGlassDateInput.js.map +1 -0
  156. package/lib/module/components/FluentGlassDatePicker.js +265 -0
  157. package/lib/module/components/FluentGlassDatePicker.js.map +1 -0
  158. package/lib/module/components/FluentGlassDialog.js +163 -0
  159. package/lib/module/components/FluentGlassDialog.js.map +1 -0
  160. package/lib/module/components/FluentGlassDock.js +181 -0
  161. package/lib/module/components/FluentGlassDock.js.map +1 -0
  162. package/lib/module/components/FluentGlassDropdown.js +343 -0
  163. package/lib/module/components/FluentGlassDropdown.js.map +1 -0
  164. package/lib/module/components/FluentGlassEmailInput.js +38 -0
  165. package/lib/module/components/FluentGlassEmailInput.js.map +1 -0
  166. package/lib/module/components/FluentGlassInput.js +78 -0
  167. package/lib/module/components/FluentGlassInput.js.map +1 -0
  168. package/lib/module/components/FluentGlassLabeledInput.js +59 -0
  169. package/lib/module/components/FluentGlassLabeledInput.js.map +1 -0
  170. package/lib/module/components/FluentGlassLayout.js +101 -0
  171. package/lib/module/components/FluentGlassLayout.js.map +1 -0
  172. package/lib/module/components/FluentGlassPasswordInput.js +54 -0
  173. package/lib/module/components/FluentGlassPasswordInput.js.map +1 -0
  174. package/lib/module/components/FluentGlassPopover.js +70 -0
  175. package/lib/module/components/FluentGlassPopover.js.map +1 -0
  176. package/lib/module/components/FluentGlassResponsiveRow.js +71 -0
  177. package/lib/module/components/FluentGlassResponsiveRow.js.map +1 -0
  178. package/lib/module/components/FluentGlassScrollArea.js +95 -0
  179. package/lib/module/components/FluentGlassScrollArea.js.map +1 -0
  180. package/lib/module/components/FluentGlassSegmentedControl.js +120 -0
  181. package/lib/module/components/FluentGlassSegmentedControl.js.map +1 -0
  182. package/lib/module/components/FluentGlassSelect.js +149 -0
  183. package/lib/module/components/FluentGlassSelect.js.map +1 -0
  184. package/lib/module/components/FluentGlassSeparator.js +57 -0
  185. package/lib/module/components/FluentGlassSeparator.js.map +1 -0
  186. package/lib/module/components/FluentGlassSheet.js +183 -0
  187. package/lib/module/components/FluentGlassSheet.js.map +1 -0
  188. package/lib/module/components/FluentGlassSidebar.js +351 -0
  189. package/lib/module/components/FluentGlassSidebar.js.map +1 -0
  190. package/lib/module/components/FluentGlassSimpleCard.js +51 -0
  191. package/lib/module/components/FluentGlassSimpleCard.js.map +1 -0
  192. package/lib/module/components/FluentGlassSkeleton.js +46 -0
  193. package/lib/module/components/FluentGlassSkeleton.js.map +1 -0
  194. package/lib/module/components/FluentGlassSlider.js +191 -0
  195. package/lib/module/components/FluentGlassSlider.js.map +1 -0
  196. package/lib/module/components/FluentGlassStatWidget.js +128 -0
  197. package/lib/module/components/FluentGlassStatWidget.js.map +1 -0
  198. package/lib/module/components/FluentGlassStatusIndicator.js +84 -0
  199. package/lib/module/components/FluentGlassStatusIndicator.js.map +1 -0
  200. package/lib/module/components/FluentGlassSwitch.js +122 -0
  201. package/lib/module/components/FluentGlassSwitch.js.map +1 -0
  202. package/lib/module/components/FluentGlassTable.js +158 -0
  203. package/lib/module/components/FluentGlassTable.js.map +1 -0
  204. package/lib/module/components/FluentGlassTag.js +103 -0
  205. package/lib/module/components/FluentGlassTag.js.map +1 -0
  206. package/lib/module/components/FluentGlassTextInput.js +85 -0
  207. package/lib/module/components/FluentGlassTextInput.js.map +1 -0
  208. package/lib/module/components/FluentGlassTimeline.js +327 -0
  209. package/lib/module/components/FluentGlassTimeline.js.map +1 -0
  210. package/lib/module/components/FluentGlassWeatherWidget.js +67 -0
  211. package/lib/module/components/FluentGlassWeatherWidget.js.map +1 -0
  212. package/lib/module/components/index.js +45 -0
  213. package/lib/module/components/index.js.map +1 -0
  214. package/lib/module/fonts.js +26 -0
  215. package/lib/module/fonts.js.map +1 -0
  216. package/lib/module/hooks/useBreakpoint.js +54 -0
  217. package/lib/module/hooks/useBreakpoint.js.map +1 -0
  218. package/lib/module/index.js +30 -0
  219. package/lib/module/index.js.map +1 -0
  220. package/lib/module/theme/FluentGlassProvider.js +77 -0
  221. package/lib/module/theme/FluentGlassProvider.js.map +1 -0
  222. package/lib/module/theme/defaultTheme.js +51 -0
  223. package/lib/module/theme/defaultTheme.js.map +1 -0
  224. package/lib/module/theme/resolvers.js +110 -0
  225. package/lib/module/theme/resolvers.js.map +1 -0
  226. package/lib/module/theme/tokens.js +235 -0
  227. package/lib/module/theme/tokens.js.map +1 -0
  228. package/lib/module/theme/typography.js +45 -0
  229. package/lib/module/theme/typography.js.map +1 -0
  230. package/lib/module/theme/useTheme.js +18 -0
  231. package/lib/module/theme/useTheme.js.map +1 -0
  232. package/lib/module/types/components.js +4 -0
  233. package/lib/module/types/components.js.map +1 -0
  234. package/lib/module/types/theme.js +4 -0
  235. package/lib/module/types/theme.js.map +1 -0
  236. package/lib/module/utils/colors.js +55 -0
  237. package/lib/module/utils/colors.js.map +1 -0
  238. package/lib/module/utils/responsive.js +116 -0
  239. package/lib/module/utils/responsive.js.map +1 -0
  240. package/lib/typescript/components/FluentGlass.d.ts +25 -0
  241. package/lib/typescript/components/FluentGlass.d.ts.map +1 -0
  242. package/lib/typescript/components/FluentGlassAlert.d.ts +13 -0
  243. package/lib/typescript/components/FluentGlassAlert.d.ts.map +1 -0
  244. package/lib/typescript/components/FluentGlassBadge.d.ts +22 -0
  245. package/lib/typescript/components/FluentGlassBadge.d.ts.map +1 -0
  246. package/lib/typescript/components/FluentGlassBarChart.d.ts +30 -0
  247. package/lib/typescript/components/FluentGlassBarChart.d.ts.map +1 -0
  248. package/lib/typescript/components/FluentGlassBreadcrumb.d.ts +22 -0
  249. package/lib/typescript/components/FluentGlassBreadcrumb.d.ts.map +1 -0
  250. package/lib/typescript/components/FluentGlassButton.d.ts +27 -0
  251. package/lib/typescript/components/FluentGlassButton.d.ts.map +1 -0
  252. package/lib/typescript/components/FluentGlassCalendarWidget.d.ts +13 -0
  253. package/lib/typescript/components/FluentGlassCalendarWidget.d.ts.map +1 -0
  254. package/lib/typescript/components/FluentGlassCard.d.ts +30 -0
  255. package/lib/typescript/components/FluentGlassCard.d.ts.map +1 -0
  256. package/lib/typescript/components/FluentGlassCheckbox.d.ts +14 -0
  257. package/lib/typescript/components/FluentGlassCheckbox.d.ts.map +1 -0
  258. package/lib/typescript/components/FluentGlassClockWidget.d.ts +11 -0
  259. package/lib/typescript/components/FluentGlassClockWidget.d.ts.map +1 -0
  260. package/lib/typescript/components/FluentGlassCodeBlock.d.ts +11 -0
  261. package/lib/typescript/components/FluentGlassCodeBlock.d.ts.map +1 -0
  262. package/lib/typescript/components/FluentGlassContainer.d.ts +22 -0
  263. package/lib/typescript/components/FluentGlassContainer.d.ts.map +1 -0
  264. package/lib/typescript/components/FluentGlassCrossfade.d.ts +24 -0
  265. package/lib/typescript/components/FluentGlassCrossfade.d.ts.map +1 -0
  266. package/lib/typescript/components/FluentGlassDateInput.d.ts +18 -0
  267. package/lib/typescript/components/FluentGlassDateInput.d.ts.map +1 -0
  268. package/lib/typescript/components/FluentGlassDatePicker.d.ts +9 -0
  269. package/lib/typescript/components/FluentGlassDatePicker.d.ts.map +1 -0
  270. package/lib/typescript/components/FluentGlassDialog.d.ts +18 -0
  271. package/lib/typescript/components/FluentGlassDialog.d.ts.map +1 -0
  272. package/lib/typescript/components/FluentGlassDock.d.ts +19 -0
  273. package/lib/typescript/components/FluentGlassDock.d.ts.map +1 -0
  274. package/lib/typescript/components/FluentGlassDropdown.d.ts +23 -0
  275. package/lib/typescript/components/FluentGlassDropdown.d.ts.map +1 -0
  276. package/lib/typescript/components/FluentGlassEmailInput.d.ts +17 -0
  277. package/lib/typescript/components/FluentGlassEmailInput.d.ts.map +1 -0
  278. package/lib/typescript/components/FluentGlassInput.d.ts +12 -0
  279. package/lib/typescript/components/FluentGlassInput.d.ts.map +1 -0
  280. package/lib/typescript/components/FluentGlassLabeledInput.d.ts +19 -0
  281. package/lib/typescript/components/FluentGlassLabeledInput.d.ts.map +1 -0
  282. package/lib/typescript/components/FluentGlassLayout.d.ts +11 -0
  283. package/lib/typescript/components/FluentGlassLayout.d.ts.map +1 -0
  284. package/lib/typescript/components/FluentGlassPasswordInput.d.ts +15 -0
  285. package/lib/typescript/components/FluentGlassPasswordInput.d.ts.map +1 -0
  286. package/lib/typescript/components/FluentGlassPopover.d.ts +17 -0
  287. package/lib/typescript/components/FluentGlassPopover.d.ts.map +1 -0
  288. package/lib/typescript/components/FluentGlassResponsiveRow.d.ts +25 -0
  289. package/lib/typescript/components/FluentGlassResponsiveRow.d.ts.map +1 -0
  290. package/lib/typescript/components/FluentGlassScrollArea.d.ts +16 -0
  291. package/lib/typescript/components/FluentGlassScrollArea.d.ts.map +1 -0
  292. package/lib/typescript/components/FluentGlassSegmentedControl.d.ts +15 -0
  293. package/lib/typescript/components/FluentGlassSegmentedControl.d.ts.map +1 -0
  294. package/lib/typescript/components/FluentGlassSelect.d.ts +23 -0
  295. package/lib/typescript/components/FluentGlassSelect.d.ts.map +1 -0
  296. package/lib/typescript/components/FluentGlassSeparator.d.ts +13 -0
  297. package/lib/typescript/components/FluentGlassSeparator.d.ts.map +1 -0
  298. package/lib/typescript/components/FluentGlassSheet.d.ts +11 -0
  299. package/lib/typescript/components/FluentGlassSheet.d.ts.map +1 -0
  300. package/lib/typescript/components/FluentGlassSidebar.d.ts +44 -0
  301. package/lib/typescript/components/FluentGlassSidebar.d.ts.map +1 -0
  302. package/lib/typescript/components/FluentGlassSimpleCard.d.ts +19 -0
  303. package/lib/typescript/components/FluentGlassSimpleCard.d.ts.map +1 -0
  304. package/lib/typescript/components/FluentGlassSkeleton.d.ts +14 -0
  305. package/lib/typescript/components/FluentGlassSkeleton.d.ts.map +1 -0
  306. package/lib/typescript/components/FluentGlassSlider.d.ts +31 -0
  307. package/lib/typescript/components/FluentGlassSlider.d.ts.map +1 -0
  308. package/lib/typescript/components/FluentGlassStatWidget.d.ts +17 -0
  309. package/lib/typescript/components/FluentGlassStatWidget.d.ts.map +1 -0
  310. package/lib/typescript/components/FluentGlassStatusIndicator.d.ts +16 -0
  311. package/lib/typescript/components/FluentGlassStatusIndicator.d.ts.map +1 -0
  312. package/lib/typescript/components/FluentGlassSwitch.d.ts +13 -0
  313. package/lib/typescript/components/FluentGlassSwitch.d.ts.map +1 -0
  314. package/lib/typescript/components/FluentGlassTable.d.ts +50 -0
  315. package/lib/typescript/components/FluentGlassTable.d.ts.map +1 -0
  316. package/lib/typescript/components/FluentGlassTag.d.ts +18 -0
  317. package/lib/typescript/components/FluentGlassTag.d.ts.map +1 -0
  318. package/lib/typescript/components/FluentGlassTextInput.d.ts +21 -0
  319. package/lib/typescript/components/FluentGlassTextInput.d.ts.map +1 -0
  320. package/lib/typescript/components/FluentGlassTimeline.d.ts +27 -0
  321. package/lib/typescript/components/FluentGlassTimeline.d.ts.map +1 -0
  322. package/lib/typescript/components/FluentGlassWeatherWidget.d.ts +13 -0
  323. package/lib/typescript/components/FluentGlassWeatherWidget.d.ts.map +1 -0
  324. package/lib/typescript/components/index.d.ts +43 -0
  325. package/lib/typescript/components/index.d.ts.map +1 -0
  326. package/lib/typescript/fonts.d.ts +13 -0
  327. package/lib/typescript/fonts.d.ts.map +1 -0
  328. package/lib/typescript/hooks/useBreakpoint.d.ts +26 -0
  329. package/lib/typescript/hooks/useBreakpoint.d.ts.map +1 -0
  330. package/lib/typescript/index.d.ts +18 -0
  331. package/lib/typescript/index.d.ts.map +1 -0
  332. package/lib/typescript/theme/FluentGlassProvider.d.ts +21 -0
  333. package/lib/typescript/theme/FluentGlassProvider.d.ts.map +1 -0
  334. package/lib/typescript/theme/defaultTheme.d.ts +10 -0
  335. package/lib/typescript/theme/defaultTheme.d.ts.map +1 -0
  336. package/lib/typescript/theme/resolvers.d.ts +55 -0
  337. package/lib/typescript/theme/resolvers.d.ts.map +1 -0
  338. package/lib/typescript/theme/tokens.d.ts +27 -0
  339. package/lib/typescript/theme/tokens.d.ts.map +1 -0
  340. package/lib/typescript/theme/typography.d.ts +27 -0
  341. package/lib/typescript/theme/typography.d.ts.map +1 -0
  342. package/lib/typescript/theme/useTheme.d.ts +12 -0
  343. package/lib/typescript/theme/useTheme.d.ts.map +1 -0
  344. package/lib/typescript/types/components.d.ts +32 -0
  345. package/lib/typescript/types/components.d.ts.map +1 -0
  346. package/lib/typescript/types/theme.d.ts +79 -0
  347. package/lib/typescript/types/theme.d.ts.map +1 -0
  348. package/lib/typescript/utils/colors.d.ts +3 -0
  349. package/lib/typescript/utils/colors.d.ts.map +1 -0
  350. package/lib/typescript/utils/responsive.d.ts +62 -0
  351. package/lib/typescript/utils/responsive.d.ts.map +1 -0
  352. package/package.json +90 -0
  353. package/src/assets/fonts/Inter-Black.ttf +0 -0
  354. package/src/assets/fonts/Inter-Bold.ttf +0 -0
  355. package/src/assets/fonts/Inter-ExtraBold.ttf +0 -0
  356. package/src/assets/fonts/Inter-Medium.ttf +0 -0
  357. package/src/assets/fonts/Inter-Regular.ttf +0 -0
  358. package/src/assets/fonts/Inter-SemiBold.ttf +0 -0
  359. package/src/components/FluentGlass.tsx +103 -0
  360. package/src/components/FluentGlassAlert.tsx +126 -0
  361. package/src/components/FluentGlassBadge.tsx +109 -0
  362. package/src/components/FluentGlassBarChart.tsx +295 -0
  363. package/src/components/FluentGlassBreadcrumb.tsx +173 -0
  364. package/src/components/FluentGlassButton.tsx +169 -0
  365. package/src/components/FluentGlassCalendarWidget.tsx +55 -0
  366. package/src/components/FluentGlassCard.tsx +186 -0
  367. package/src/components/FluentGlassCheckbox.tsx +138 -0
  368. package/src/components/FluentGlassClockWidget.tsx +61 -0
  369. package/src/components/FluentGlassCodeBlock.tsx +241 -0
  370. package/src/components/FluentGlassContainer.tsx +63 -0
  371. package/src/components/FluentGlassCrossfade.tsx +122 -0
  372. package/src/components/FluentGlassDateInput.tsx +182 -0
  373. package/src/components/FluentGlassDatePicker.tsx +224 -0
  374. package/src/components/FluentGlassDialog.tsx +153 -0
  375. package/src/components/FluentGlassDock.tsx +194 -0
  376. package/src/components/FluentGlassDropdown.tsx +382 -0
  377. package/src/components/FluentGlassEmailInput.tsx +46 -0
  378. package/src/components/FluentGlassInput.tsx +77 -0
  379. package/src/components/FluentGlassLabeledInput.tsx +63 -0
  380. package/src/components/FluentGlassLayout.tsx +89 -0
  381. package/src/components/FluentGlassPasswordInput.tsx +59 -0
  382. package/src/components/FluentGlassPopover.tsx +74 -0
  383. package/src/components/FluentGlassResponsiveRow.tsx +76 -0
  384. package/src/components/FluentGlassScrollArea.tsx +110 -0
  385. package/src/components/FluentGlassSegmentedControl.tsx +140 -0
  386. package/src/components/FluentGlassSelect.tsx +139 -0
  387. package/src/components/FluentGlassSeparator.tsx +54 -0
  388. package/src/components/FluentGlassSheet.tsx +183 -0
  389. package/src/components/FluentGlassSidebar.tsx +349 -0
  390. package/src/components/FluentGlassSimpleCard.tsx +59 -0
  391. package/src/components/FluentGlassSkeleton.tsx +69 -0
  392. package/src/components/FluentGlassSlider.tsx +202 -0
  393. package/src/components/FluentGlassStatWidget.tsx +107 -0
  394. package/src/components/FluentGlassStatusIndicator.tsx +82 -0
  395. package/src/components/FluentGlassSwitch.tsx +130 -0
  396. package/src/components/FluentGlassTable.tsx +145 -0
  397. package/src/components/FluentGlassTag.tsx +98 -0
  398. package/src/components/FluentGlassTextInput.tsx +87 -0
  399. package/src/components/FluentGlassTimeline.tsx +335 -0
  400. package/src/components/FluentGlassWeatherWidget.tsx +54 -0
  401. package/src/components/index.ts +42 -0
  402. package/src/fonts.ts +24 -0
  403. package/src/hooks/useBreakpoint.ts +55 -0
  404. package/src/index.ts +97 -0
  405. package/src/theme/FluentGlassProvider.tsx +82 -0
  406. package/src/theme/defaultTheme.ts +44 -0
  407. package/src/theme/resolvers.ts +115 -0
  408. package/src/theme/tokens.ts +200 -0
  409. package/src/theme/typography.ts +41 -0
  410. package/src/theme/useTheme.ts +17 -0
  411. package/src/types/components.ts +47 -0
  412. package/src/types/theme.ts +82 -0
  413. package/src/utils/colors.ts +55 -0
  414. package/src/utils/responsive.ts +110 -0
@@ -0,0 +1,194 @@
1
+ import React from 'react';
2
+ import { StyleSheet, View, Pressable, ViewStyle } from 'react-native';
3
+ import Animated, {
4
+ useSharedValue,
5
+ useAnimatedStyle,
6
+ withSpring,
7
+ } from 'react-native-reanimated';
8
+ import FluentGlass from './FluentGlass';
9
+ import useTheme from '../theme/useTheme';
10
+
11
+ const ITEM_SIZE = 56;
12
+ const ITEM_GAP = 16;
13
+ const PAD_H = 24;
14
+
15
+ const SPRING_CONFIG = {
16
+ mass: 0.8,
17
+ damping: 14,
18
+ stiffness: 100,
19
+ overshootClamping: false,
20
+ };
21
+
22
+ export interface DockItemConfig {
23
+ icon: React.ReactNode;
24
+ label?: string;
25
+ }
26
+
27
+ interface DockItemProps {
28
+ icon: React.ReactNode;
29
+ label?: string;
30
+ onPress: () => void;
31
+ isActive: boolean;
32
+ accentColor: string;
33
+ }
34
+
35
+ // Internal Dock Item Component
36
+ function DockItem({ icon, label, onPress, isActive, accentColor }: DockItemProps) {
37
+ const progress = useSharedValue(isActive ? 1 : 0);
38
+
39
+ React.useEffect(() => {
40
+ progress.value = withSpring(isActive ? 1 : 0, SPRING_CONFIG);
41
+ }, [isActive]);
42
+
43
+ // Icon Scale
44
+ const iconStyle = useAnimatedStyle(() => ({
45
+ transform: [{ scale: 1 + (progress.value * 0.15) }],
46
+ }));
47
+
48
+ // Dot Appearance
49
+ const dotStyle = useAnimatedStyle(() => ({
50
+ opacity: progress.value,
51
+ transform: [{ scale: progress.value }],
52
+ }));
53
+
54
+ return (
55
+ <Pressable onPress={onPress} accessibilityRole="tab" accessibilityLabel={label ?? 'Dock item'} accessibilityState={{ selected: isActive }}>
56
+ <Animated.View style={styles.itemWrapper}>
57
+ <FluentGlass
58
+ style={styles.itemContainer}
59
+ intensity={25}
60
+ borderRadius={16}
61
+ borderOpacity={0.2}
62
+ tint="dark"
63
+ >
64
+ {/* Icon Content */}
65
+ <Animated.View style={[styles.centeredContent, iconStyle]}>
66
+ {icon}
67
+ </Animated.View>
68
+ </FluentGlass>
69
+
70
+ {/* Indicator Dot */}
71
+ <Animated.View style={[styles.dot, dotStyle, { backgroundColor: accentColor }]} />
72
+ </Animated.View>
73
+ </Pressable>
74
+ );
75
+ }
76
+
77
+ export interface FluentGlassDockProps {
78
+ items: DockItemConfig[];
79
+ activeIndex: number;
80
+ onSelect: (index: number) => void;
81
+ floating?: boolean;
82
+ style?: ViewStyle;
83
+ }
84
+
85
+ /**
86
+ * FluentGlassDock (Component)
87
+ * Floating bottom navigation bar with sliding glow indicator.
88
+ */
89
+ export default function FluentGlassDock({ items, activeIndex, onSelect, floating = true, style }: FluentGlassDockProps) {
90
+ const theme = useTheme();
91
+ const themeColors = theme.colors;
92
+
93
+ // Sliding indicator position
94
+ const translateX = useSharedValue(activeIndex * (ITEM_SIZE + ITEM_GAP));
95
+
96
+ React.useEffect(() => {
97
+ translateX.value = withSpring(activeIndex * (ITEM_SIZE + ITEM_GAP), {
98
+ mass: 0.4,
99
+ damping: 18,
100
+ stiffness: 200,
101
+ overshootClamping: false,
102
+ });
103
+ }, [activeIndex]);
104
+
105
+ const slidingStyle = useAnimatedStyle(() => ({
106
+ transform: [{ translateX: translateX.value }],
107
+ }));
108
+
109
+ return (
110
+ <View style={[
111
+ floating ? styles.dockWrapperFloating : styles.dockWrapperRelative,
112
+ style
113
+ ]} accessibilityRole="toolbar">
114
+ {/* Dock Background Pill */}
115
+ <FluentGlass
116
+ style={styles.dockPill}
117
+ intensity={20}
118
+ borderRadius={32}
119
+ borderOpacity={0.1}
120
+ tint="dark"
121
+ >
122
+ <View style={styles.itemsRow}>
123
+ {/* Sliding Glow Indicator */}
124
+ <Animated.View style={[styles.slidingIndicator, slidingStyle, { backgroundColor: themeColors.accent + '20', borderColor: themeColors.accent + '60' }]} />
125
+
126
+ {items.map((item: DockItemConfig, index: number) => (
127
+ <DockItem
128
+ key={index}
129
+ icon={item.icon}
130
+ label={item.label}
131
+ isActive={activeIndex === index}
132
+ onPress={() => onSelect(index)}
133
+ accentColor={themeColors.accent}
134
+ />
135
+ ))}
136
+ </View>
137
+ </FluentGlass>
138
+ </View>
139
+ );
140
+ }
141
+
142
+ const styles = StyleSheet.create({
143
+ dockWrapperFloating: {
144
+ position: 'absolute',
145
+ bottom: 34,
146
+ width: '100%',
147
+ alignItems: 'center',
148
+ paddingHorizontal: 20,
149
+ zIndex: 100,
150
+ },
151
+ dockWrapperRelative: {
152
+ width: '100%',
153
+ alignItems: 'center',
154
+ paddingVertical: 20,
155
+ },
156
+ dockPill: {
157
+ // Auto width based on content
158
+ },
159
+ itemsRow: {
160
+ flexDirection: 'row',
161
+ alignItems: 'flex-end',
162
+ gap: ITEM_GAP,
163
+ paddingVertical: 12,
164
+ paddingHorizontal: PAD_H,
165
+ },
166
+ slidingIndicator: {
167
+ position: 'absolute',
168
+ top: 12,
169
+ left: PAD_H,
170
+ width: ITEM_SIZE,
171
+ height: ITEM_SIZE,
172
+ borderRadius: 16,
173
+ borderWidth: 1,
174
+ },
175
+ itemWrapper: {
176
+ alignItems: 'center',
177
+ marginBottom: 4,
178
+ },
179
+ itemContainer: {
180
+ width: ITEM_SIZE,
181
+ height: ITEM_SIZE,
182
+ },
183
+ centeredContent: {
184
+ flex: 1,
185
+ alignItems: 'center',
186
+ justifyContent: 'center',
187
+ },
188
+ dot: {
189
+ width: 4,
190
+ height: 4,
191
+ borderRadius: 2,
192
+ marginTop: 6,
193
+ },
194
+ });
@@ -0,0 +1,382 @@
1
+ import React, { useState, useRef, useCallback, useEffect } from 'react';
2
+ import {
3
+ StyleSheet,
4
+ Text,
5
+ View,
6
+ Pressable,
7
+ Dimensions,
8
+ ScrollView,
9
+ Modal,
10
+ StyleProp,
11
+ ViewStyle,
12
+ } from 'react-native';
13
+ import Animated, {
14
+ useSharedValue,
15
+ useAnimatedStyle,
16
+ withTiming,
17
+ withSpring,
18
+ Easing,
19
+ } from 'react-native-reanimated';
20
+ import FluentGlass from './FluentGlass';
21
+ import useTheme from '../theme/useTheme';
22
+ import { ThemeColors, ThemeTypography } from '../types/theme';
23
+
24
+ /**
25
+ * FluentGlassDropdown (Molecule)
26
+ * Inline glass dropdown with auto-direction (opens up or down based on space).
27
+ * Animations fully driven by SharedValues on the UI thread.
28
+ *
29
+ * @level Molecule
30
+ * @composition FluentGlass (Atom), Text, Pressable
31
+ *
32
+ * Two data formats:
33
+ * Flat: options={[{ label, value }]}
34
+ * Grouped: sections={[{ title, data: [{ label, value }] }]}
35
+ */
36
+ const SCREEN_HEIGHT = Dimensions.get('window').height;
37
+ const MAX_DROPDOWN_HEIGHT = 260;
38
+
39
+ const SPRING_CONFIG = { damping: 18, stiffness: 300, mass: 0.8 };
40
+ const TIMING_CONFIG = { duration: 180, easing: Easing.out(Easing.cubic) };
41
+
42
+ interface DropdownOption {
43
+ label: string;
44
+ value: any;
45
+ }
46
+
47
+ interface DropdownSection {
48
+ title: string;
49
+ data: DropdownOption[];
50
+ }
51
+
52
+ interface TriggerLayout {
53
+ x: number;
54
+ y: number;
55
+ width: number;
56
+ height: number;
57
+ }
58
+
59
+ export interface FluentGlassDropdownProps {
60
+ value?: any;
61
+ onValueChange?: (val: any) => void;
62
+ options?: DropdownOption[];
63
+ sections?: DropdownSection[];
64
+ placeholder?: string;
65
+ label?: string;
66
+ style?: StyleProp<ViewStyle>;
67
+ accessibilityLabel?: string;
68
+ }
69
+
70
+ export default function FluentGlassDropdown({
71
+ value,
72
+ onValueChange,
73
+ options,
74
+ sections,
75
+ placeholder = 'Select option',
76
+ label,
77
+ style,
78
+ accessibilityLabel,
79
+ }: FluentGlassDropdownProps) {
80
+ const theme = useTheme();
81
+ const COLORS = theme.colors;
82
+
83
+ const [isOpen, setIsOpen] = useState(false);
84
+ const [triggerLayout, setTriggerLayout] = useState<TriggerLayout | null>(null);
85
+ const [openDirection, setOpenDirection] = useState<'up' | 'down'>('down');
86
+ const triggerRef = useRef<View>(null);
87
+
88
+ // Animation shared values — runs on UI thread
89
+ const opacity = useSharedValue(0);
90
+ const scale = useSharedValue(0.92);
91
+
92
+ const isGrouped = Boolean(sections);
93
+
94
+ // Animate in when opened
95
+ useEffect(() => {
96
+ if (isOpen) {
97
+ opacity.value = withTiming(1, TIMING_CONFIG);
98
+ scale.value = withSpring(1, SPRING_CONFIG);
99
+ }
100
+ }, [isOpen, opacity, scale]);
101
+
102
+ const panelAnimStyle = useAnimatedStyle(() => ({
103
+ opacity: opacity.value,
104
+ transform: [{ scale: scale.value }],
105
+ }));
106
+
107
+ // Find selected label
108
+ const findSelectedLabel = (): string | null => {
109
+ if (isGrouped && sections) {
110
+ for (const section of sections) {
111
+ const found = section.data.find((item) => item.value === value);
112
+ if (found) return found.label;
113
+ }
114
+ return null;
115
+ }
116
+ if (options) {
117
+ const found = options.find((item) => item.value === value);
118
+ return found ? found.label : null;
119
+ }
120
+ return null;
121
+ };
122
+
123
+ const selectedLabel = findSelectedLabel();
124
+
125
+ const handleOpen = useCallback(() => {
126
+ if (triggerRef.current) {
127
+ (triggerRef.current as any).measureInWindow((x: number, y: number, width: number, height: number) => {
128
+ const spaceBelow = SCREEN_HEIGHT - (y + height);
129
+ const spaceAbove = y;
130
+ const direction: 'up' | 'down' = spaceBelow >= MAX_DROPDOWN_HEIGHT || spaceBelow >= spaceAbove
131
+ ? 'down'
132
+ : 'up';
133
+
134
+ // Reset animation values before opening
135
+ opacity.value = 0;
136
+ scale.value = 0.92;
137
+
138
+ setTriggerLayout({ x, y, width, height });
139
+ setOpenDirection(direction);
140
+ setIsOpen(true);
141
+ });
142
+ }
143
+ }, [opacity, scale]);
144
+
145
+ const handleSelect = useCallback((itemValue: any) => {
146
+ onValueChange?.(itemValue);
147
+ // Animate out then close
148
+ opacity.value = withTiming(0, { duration: 120 });
149
+ scale.value = withTiming(0.95, { duration: 120 });
150
+ setTimeout(() => setIsOpen(false), 130);
151
+ }, [onValueChange, opacity, scale]);
152
+
153
+ const handleClose = useCallback(() => {
154
+ opacity.value = withTiming(0, { duration: 120 });
155
+ scale.value = withTiming(0.95, { duration: 120 });
156
+ setTimeout(() => setIsOpen(false), 130);
157
+ }, [opacity, scale]);
158
+
159
+ // Compute dropdown position
160
+ const dropdownPositionStyle: ViewStyle = triggerLayout ? {
161
+ position: 'absolute' as const,
162
+ left: triggerLayout.x,
163
+ width: triggerLayout.width,
164
+ maxHeight: MAX_DROPDOWN_HEIGHT,
165
+ ...(openDirection === 'down'
166
+ ? { top: triggerLayout.y + triggerLayout.height + 4 }
167
+ : { top: triggerLayout.y - MAX_DROPDOWN_HEIGHT - 4 }
168
+ ),
169
+ } : {};
170
+
171
+ return (
172
+ <View style={[styles.wrapper, style]}>
173
+ {/* Label */}
174
+ {label ? <Text style={[styles.label, { color: COLORS.textSecondary, fontFamily: theme.typography.medium }]}>{label}</Text> : null}
175
+
176
+ {/* Trigger */}
177
+ <Pressable ref={triggerRef as any} onPress={handleOpen} accessibilityRole="button" accessibilityLabel={accessibilityLabel ?? label ?? placeholder ?? 'Dropdown'} accessibilityState={{ expanded: isOpen }}>
178
+ <FluentGlass
179
+ style={[styles.trigger, { backgroundColor: COLORS.inputBg }]}
180
+ intensity={10}
181
+ tint="dark"
182
+ borderRadius={12}
183
+ borderOpacity={0.25}
184
+ >
185
+ <View style={styles.triggerContent}>
186
+ <Text style={[
187
+ styles.triggerText,
188
+ { color: COLORS.textPrimary, fontFamily: theme.typography.medium },
189
+ !selectedLabel && { color: COLORS.textSecondary },
190
+ ]}>
191
+ {selectedLabel || placeholder}
192
+ </Text>
193
+ <Text style={[styles.chevron, { color: COLORS.textSecondary }]}>
194
+ {isOpen
195
+ ? (openDirection === 'down' ? '▴' : '▾')
196
+ : '▾'}
197
+ </Text>
198
+ </View>
199
+ </FluentGlass>
200
+ </Pressable>
201
+
202
+ {/* Dropdown overlay */}
203
+ {isOpen ? (
204
+ <Modal
205
+ visible
206
+ transparent
207
+ animationType="none"
208
+ onRequestClose={handleClose}
209
+ >
210
+ {/* Backdrop */}
211
+ <Pressable style={styles.backdrop} onPress={handleClose}>
212
+ {/* Animated dropdown panel */}
213
+ <Animated.View style={[dropdownPositionStyle, panelAnimStyle]}>
214
+ <Pressable onPress={(e) => e.stopPropagation()}>
215
+ <FluentGlass
216
+ style={styles.dropdownGlass}
217
+ intensity={25}
218
+ tint="dark"
219
+ borderRadius={16}
220
+ borderOpacity={0.25}
221
+ >
222
+ <ScrollView
223
+ style={styles.scrollInner}
224
+ bounces={false}
225
+ showsVerticalScrollIndicator={false}
226
+ >
227
+ {isGrouped
228
+ ? renderGrouped(sections!, value, handleSelect, COLORS, theme.typography)
229
+ : renderFlat(options, value, handleSelect, COLORS, theme.typography)
230
+ }
231
+ </ScrollView>
232
+ </FluentGlass>
233
+ </Pressable>
234
+ </Animated.View>
235
+ </Pressable>
236
+ </Modal>
237
+ ) : null}
238
+ </View>
239
+ );
240
+ }
241
+
242
+ /* ─── Render helpers ─── */
243
+
244
+ function renderFlat(
245
+ options: DropdownOption[] | undefined,
246
+ selectedValue: any,
247
+ onSelect: (val: any) => void,
248
+ COLORS: ThemeColors,
249
+ typography: ThemeTypography,
250
+ ): React.ReactNode {
251
+ if (!options) return null;
252
+ return options.map((item, i) => (
253
+ <Pressable
254
+ key={String(item.value)}
255
+ style={[
256
+ styles.option,
257
+ i < options.length - 1 && [styles.optionBorder, { borderBottomColor: COLORS.borderSubtle }],
258
+ ]}
259
+ onPress={() => onSelect(item.value)}
260
+ accessibilityLabel={item.label}
261
+ accessibilityState={{ selected: item.value === selectedValue }}
262
+ >
263
+ <Text style={[
264
+ styles.optionText,
265
+ { color: COLORS.textPrimary, fontFamily: typography.medium },
266
+ item.value === selectedValue && { color: COLORS.accent, fontWeight: '600' as const, fontFamily: typography.semiBold },
267
+ ]}>
268
+ {item.label}
269
+ </Text>
270
+ </Pressable>
271
+ ));
272
+ }
273
+
274
+ function renderGrouped(
275
+ sections: DropdownSection[],
276
+ selectedValue: any,
277
+ onSelect: (val: any) => void,
278
+ COLORS: ThemeColors,
279
+ typography: ThemeTypography,
280
+ ): React.ReactNode {
281
+ return sections.map((section, sectionIdx) => (
282
+ <View key={section.title}>
283
+ {/* Section separator (between groups) */}
284
+ {sectionIdx > 0 ? <View style={[styles.sectionSeparator, { backgroundColor: COLORS.border }]} /> : null}
285
+
286
+ {/* Section header */}
287
+ <View style={styles.sectionHeader}>
288
+ <Text style={[styles.sectionTitle, { color: COLORS.textPrimary, fontFamily: typography.bold }]}>{section.title}</Text>
289
+ </View>
290
+
291
+ {/* Section items */}
292
+ {section.data.map((item) => (
293
+ <Pressable
294
+ key={String(item.value)}
295
+ style={styles.option}
296
+ onPress={() => onSelect(item.value)}
297
+ accessibilityLabel={item.label}
298
+ accessibilityState={{ selected: item.value === selectedValue }}
299
+ >
300
+ <Text style={[
301
+ styles.optionText,
302
+ styles.optionTextIndented,
303
+ { color: COLORS.textPrimary, fontFamily: typography.medium },
304
+ item.value === selectedValue && { color: COLORS.accent, fontWeight: '600' as const, fontFamily: typography.semiBold },
305
+ ]}>
306
+ {item.label}
307
+ </Text>
308
+ </Pressable>
309
+ ))}
310
+ </View>
311
+ ));
312
+ }
313
+
314
+ const styles = StyleSheet.create({
315
+ wrapper: {
316
+ width: '100%',
317
+ zIndex: 10,
318
+ },
319
+ label: {
320
+ marginBottom: 8,
321
+ fontSize: 14,
322
+ marginLeft: 4,
323
+ fontWeight: '500',
324
+ },
325
+ trigger: {
326
+ height: 48,
327
+ },
328
+ triggerContent: {
329
+ flex: 1,
330
+ flexDirection: 'row',
331
+ alignItems: 'center',
332
+ justifyContent: 'space-between',
333
+ paddingHorizontal: 16,
334
+ },
335
+ triggerText: {
336
+ fontSize: 15,
337
+ fontWeight: '500',
338
+ flex: 1,
339
+ },
340
+ chevron: {
341
+ fontSize: 12,
342
+ marginLeft: 8,
343
+ },
344
+ backdrop: {
345
+ flex: 1,
346
+ },
347
+ dropdownGlass: {
348
+ overflow: 'hidden',
349
+ },
350
+ scrollInner: {
351
+ maxHeight: MAX_DROPDOWN_HEIGHT - 2,
352
+ },
353
+ option: {
354
+ paddingVertical: 12,
355
+ paddingHorizontal: 16,
356
+ },
357
+ optionBorder: {
358
+ borderBottomWidth: StyleSheet.hairlineWidth,
359
+ },
360
+ optionText: {
361
+ fontSize: 15,
362
+ fontWeight: '500',
363
+ },
364
+ optionTextIndented: {
365
+ paddingLeft: 12,
366
+ },
367
+ sectionSeparator: {
368
+ height: 1,
369
+ marginHorizontal: 12,
370
+ },
371
+ sectionHeader: {
372
+ paddingHorizontal: 16,
373
+ paddingTop: 12,
374
+ paddingBottom: 6,
375
+ },
376
+ sectionTitle: {
377
+ fontSize: 14,
378
+ fontWeight: '700',
379
+ textTransform: 'uppercase',
380
+ letterSpacing: 0.5,
381
+ },
382
+ });
@@ -0,0 +1,46 @@
1
+ import React from 'react';
2
+ import { StyleProp, ViewStyle } from 'react-native';
3
+ import FluentGlassTextInput from './FluentGlassTextInput';
4
+ import { FluentGlassBaseProps } from '../types/components';
5
+
6
+ export interface FluentGlassEmailInputProps extends FluentGlassBaseProps {
7
+ value?: string;
8
+ onChangeText?: (text: string) => void;
9
+ placeholder?: string;
10
+ style?: StyleProp<ViewStyle>;
11
+ accessibilityLabel?: string;
12
+ [key: string]: unknown;
13
+ }
14
+
15
+ /**
16
+ * FluentGlassEmailInput (Molécula)
17
+ * Input configurado específicamente para correos electrónicos.
18
+ */
19
+ export default function FluentGlassEmailInput({ value,
20
+ onChangeText,
21
+ placeholder = 'Enter your email',
22
+ style,
23
+ size,
24
+ colorScheme,
25
+ blur,
26
+ radius,
27
+ accessibilityLabel,
28
+ ...props }: FluentGlassEmailInputProps) {
29
+ return (
30
+ <FluentGlassTextInput
31
+ value={value}
32
+ onChangeText={onChangeText}
33
+ placeholder={placeholder}
34
+ keyboardType="email-address"
35
+ autoCapitalize="none"
36
+ autoComplete="email"
37
+ size={size}
38
+ colorScheme={colorScheme}
39
+ blur={blur}
40
+ radius={radius}
41
+ style={style}
42
+ accessibilityLabel={accessibilityLabel ?? 'Email address'}
43
+ {...props}
44
+ />
45
+ );
46
+ }
@@ -0,0 +1,77 @@
1
+ import React from 'react';
2
+ import { StyleSheet, TextInput, View, Text } from 'react-native';
3
+ import FluentGlass from './FluentGlass';
4
+ import useTheme from '../theme/useTheme';
5
+
6
+ /**
7
+ * FluentGlassInput (Component)
8
+ * Text input with "carved" glass effect.
9
+ */
10
+ import { ViewStyle, StyleProp, TextInputProps } from 'react-native';
11
+
12
+ export interface FluentGlassInputProps extends TextInputProps {
13
+ label?: string;
14
+ style?: StyleProp<ViewStyle>;
15
+ }
16
+
17
+ export default function FluentGlassInput({
18
+ value,
19
+ onChangeText,
20
+ placeholder,
21
+ label,
22
+ style,
23
+ keyboardType,
24
+ secureTextEntry,
25
+ accessibilityLabel,
26
+ accessibilityHint,
27
+ }: FluentGlassInputProps) {
28
+ const theme = useTheme();
29
+ const COLORS = theme.colors;
30
+
31
+ return (
32
+ <View style={[styles.wrapper, style]}>
33
+ {label && <Text style={[styles.label, { color: COLORS.textSecondary, fontFamily: theme.typography.medium }]}>{label}</Text>}
34
+
35
+ <FluentGlass
36
+ style={[styles.container, { backgroundColor: COLORS.inputBg }]}
37
+ intensity={10}
38
+ borderRadius={12}
39
+ borderOpacity={0.1}
40
+ >
41
+ <TextInput
42
+ style={[styles.input, { color: COLORS.textPrimary }]}
43
+ value={value}
44
+ onChangeText={onChangeText}
45
+ placeholder={placeholder}
46
+ placeholderTextColor={COLORS.textSecondary}
47
+ keyboardType={keyboardType}
48
+ secureTextEntry={secureTextEntry}
49
+ accessibilityLabel={accessibilityLabel ?? label ?? placeholder}
50
+ accessibilityHint={accessibilityHint}
51
+ />
52
+ </FluentGlass>
53
+ </View>
54
+ );
55
+ }
56
+
57
+ const styles = StyleSheet.create({
58
+ wrapper: {
59
+ marginBottom: 16,
60
+ width: '100%',
61
+ },
62
+ label: {
63
+ marginBottom: 8,
64
+ fontSize: 14,
65
+ marginLeft: 4,
66
+ fontWeight: '500',
67
+ },
68
+ container: {
69
+ height: undefined,
70
+ minHeight: 50,
71
+ },
72
+ input: {
73
+ flex: 1,
74
+ paddingHorizontal: 16,
75
+ fontSize: 16,
76
+ },
77
+ });