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,173 @@
1
+ import React from 'react';
2
+
3
+ import { StyleSheet, Text, View, Pressable, ViewStyle } from 'react-native';
4
+ import FluentGlass from './FluentGlass';
5
+ import useTheme from '../theme/useTheme';
6
+
7
+ export interface BreadcrumbItem {
8
+ label: string;
9
+ icon?: string;
10
+ onPress?: () => void;
11
+ }
12
+
13
+ interface EnrichedBreadcrumbItem extends BreadcrumbItem {
14
+ isActive?: boolean;
15
+ isEllipsis?: boolean;
16
+ }
17
+
18
+ export interface FluentGlassBreadcrumbProps {
19
+ items?: BreadcrumbItem[];
20
+ variant?: 'standard' | 'collapsed';
21
+ separator?: string;
22
+ onExpandCollapsed?: () => void;
23
+ style?: ViewStyle;
24
+ }
25
+
26
+ /**
27
+ * FluentGlassBreadcrumb (Molecule)
28
+ * Glassmorphism breadcrumb navigation with two variants:
29
+ * - 'standard': All items visible, last one bold
30
+ * - 'collapsed': Middle items replaced with "..." ellipsis button
31
+ */
32
+ export default function FluentGlassBreadcrumb({
33
+ items = [],
34
+ variant = 'standard',
35
+ separator = '›',
36
+ onExpandCollapsed,
37
+ style,
38
+ }: FluentGlassBreadcrumbProps) {
39
+ const theme = useTheme();
40
+ const COLORS = theme.colors;
41
+ const typography = theme.typography;
42
+
43
+ const visibleItems = getVisibleItems(items, variant);
44
+
45
+ return (
46
+ <FluentGlass
47
+ style={[styles.container, style]}
48
+ intensity={15}
49
+ tint="dark"
50
+ borderRadius={16}
51
+ borderOpacity={0.2}
52
+ >
53
+ <View style={styles.content}>
54
+ {visibleItems.map((item: EnrichedBreadcrumbItem, index: number) => (
55
+ <View key={index} style={styles.itemRow}>
56
+ {/* Separator */}
57
+ {index > 0 ? (
58
+ <Text style={[styles.separator, { color: COLORS.textSecondary, fontFamily: typography.regular }]}>{separator}</Text>
59
+ ) : null}
60
+
61
+ {/* Ellipsis button */}
62
+ {item.isEllipsis ? (
63
+ <Pressable
64
+ onPress={onExpandCollapsed}
65
+ style={[styles.ellipsisBtn, { backgroundColor: COLORS.borderSubtle }]}
66
+ hitSlop={6}
67
+ >
68
+ <Text style={[styles.ellipsisText, { color: COLORS.textSecondary, fontFamily: typography.bold }]}>···</Text>
69
+ </Pressable>
70
+ ) : (
71
+ <Pressable
72
+ onPress={item.onPress}
73
+ disabled={!item.onPress}
74
+ hitSlop={4}
75
+ >
76
+ <View style={styles.labelRow}>
77
+ {item.icon ? (
78
+ <Text style={styles.icon}>{item.icon}</Text>
79
+ ) : null}
80
+ <Text
81
+ style={[
82
+ styles.label,
83
+ { color: COLORS.textSecondary, fontFamily: typography.regular },
84
+ item.isActive && [styles.activeLabel, { color: COLORS.textPrimary, fontFamily: typography.bold }],
85
+ item.onPress && { color: COLORS.textSecondary },
86
+ ]}
87
+ numberOfLines={1}
88
+ >
89
+ {item.label}
90
+ </Text>
91
+ </View>
92
+ </Pressable>
93
+ )}
94
+ </View>
95
+ ))}
96
+ </View>
97
+ </FluentGlass>
98
+ );
99
+ }
100
+
101
+ /**
102
+ * Determines which items to show based on variant.
103
+ * 'collapsed' shows first, ellipsis, last two.
104
+ */
105
+ function getVisibleItems(items: BreadcrumbItem[], variant: string): EnrichedBreadcrumbItem[] {
106
+ if (!items.length) return [];
107
+
108
+ // Mark the last item as "active" (current page)
109
+ const withActive: EnrichedBreadcrumbItem[] = items.map((item, i) => ({
110
+ ...item,
111
+ isActive: i === items.length - 1,
112
+ }));
113
+
114
+ if (variant === 'collapsed' && items.length > 3) {
115
+ return [
116
+ withActive[0],
117
+ { label: '', isEllipsis: true },
118
+ withActive[items.length - 2],
119
+ withActive[items.length - 1],
120
+ ];
121
+ }
122
+
123
+ return withActive;
124
+ }
125
+
126
+ const styles = StyleSheet.create({
127
+ container: {
128
+ height: 40,
129
+ alignSelf: 'flex-start',
130
+ },
131
+ content: {
132
+ flex: 1,
133
+ flexDirection: 'row',
134
+ alignItems: 'center',
135
+ paddingHorizontal: 16,
136
+ },
137
+ itemRow: {
138
+ flexDirection: 'row',
139
+ alignItems: 'center',
140
+ },
141
+ separator: {
142
+ fontSize: 14,
143
+ marginHorizontal: 8,
144
+ fontWeight: '400',
145
+ },
146
+ labelRow: {
147
+ flexDirection: 'row',
148
+ alignItems: 'center',
149
+ },
150
+ icon: {
151
+ fontSize: 14,
152
+ marginRight: 4,
153
+ },
154
+ label: {
155
+ fontSize: 14,
156
+ fontWeight: '400',
157
+ },
158
+ activeLabel: {
159
+ fontWeight: '700',
160
+ },
161
+ pressableLabel: {
162
+ },
163
+ ellipsisBtn: {
164
+ borderRadius: 6,
165
+ paddingHorizontal: 8,
166
+ paddingVertical: 2,
167
+ },
168
+ ellipsisText: {
169
+ fontSize: 14,
170
+ fontWeight: '700',
171
+ letterSpacing: 1,
172
+ },
173
+ });
@@ -0,0 +1,169 @@
1
+ import React from 'react';
2
+ import { StyleSheet, Text, Pressable, View } from 'react-native';
3
+ import Animated, { useSharedValue, useAnimatedStyle, withSpring } from 'react-native-reanimated';
4
+ import FluentGlass from './FluentGlass';
5
+ import useTheme from '../theme/useTheme';
6
+ import { resolveSize, resolveColorScheme, resolveBackwardCompat } from '../theme/resolvers';
7
+
8
+ const AnimatedPressable = Animated.createAnimatedComponent(Pressable);
9
+
10
+ /**
11
+ * FluentGlassButton (Component)
12
+ * Interactive glass button with scale animation and variants.
13
+ *
14
+ * @param {string} size - 'xs' | 'sm' | 'md' | 'lg' | 'xl'
15
+ * @param {string} colorScheme - 'default' | 'dark' | 'info' | 'success' | 'error' | 'warning'
16
+ * @param {string} blur - 'none' | 'subtle' | 'medium' | 'strong' | 'max'
17
+ * @param {string} radius - 'none' | 'sm' | 'md' | 'lg' | 'pill'
18
+ *
19
+ * Legacy props: variant ('primary' | 'secondary' | 'ghost'), intensity, tint
20
+ */
21
+ import { ViewStyle, TextStyle, StyleProp } from 'react-native';
22
+ import { FluentGlassBaseProps } from '../types/components';
23
+
24
+ export interface FluentGlassButtonProps extends FluentGlassBaseProps {
25
+ title: string;
26
+ onPress?: () => void;
27
+ variant?: 'primary' | 'secondary' | 'ghost' | 'destructive' | 'outline' | string;
28
+ style?: StyleProp<ViewStyle>;
29
+ textStyle?: StyleProp<TextStyle>;
30
+ icon?: React.ReactNode;
31
+ disabled?: boolean;
32
+ intensity?: number;
33
+ tint?: string;
34
+ }
35
+
36
+ export default function FluentGlassButton({
37
+ title,
38
+ onPress,
39
+ // New standardized props
40
+ size,
41
+ colorScheme,
42
+ blur,
43
+ radius,
44
+ // Legacy props
45
+ variant = 'primary',
46
+ style,
47
+ textStyle,
48
+ icon,
49
+ disabled = false,
50
+ intensity,
51
+ tint,
52
+ accessibilityLabel,
53
+ accessibilityHint,
54
+ }: FluentGlassButtonProps) {
55
+ const theme = useTheme();
56
+
57
+ // Resolve props
58
+ const sizeConfig = resolveSize(theme, size || theme.defaults.size);
59
+ const compat = resolveBackwardCompat({ variant, intensity, tint, colorScheme, blur });
60
+ const resolvedScheme = compat.colorScheme || theme.defaults.colorScheme;
61
+ const resolvedBlur = compat.blur || theme.defaults.blur;
62
+
63
+ const scaleAnim = useSharedValue(1);
64
+
65
+ const animatedStyle = useAnimatedStyle(() => ({
66
+ transform: [{ scale: scaleAnim.value }],
67
+ }));
68
+
69
+ const handlePressIn = () => {
70
+ if (disabled) return;
71
+ scaleAnim.value = withSpring(0.96);
72
+ };
73
+
74
+ const handlePressOut = () => {
75
+ if (disabled) return;
76
+ scaleAnim.value = withSpring(1);
77
+ };
78
+
79
+ // Resolve visual styles from colorScheme
80
+ const isGhost = variant === 'ghost' && !colorScheme;
81
+ const colorConfig = resolveColorScheme(theme, resolvedScheme);
82
+
83
+ const getButtonStyles = () => {
84
+ if (isGhost) {
85
+ return {
86
+ backgroundColor: 'transparent',
87
+ borderOpacity: 0,
88
+ textColor: theme.colors.textSecondary,
89
+ };
90
+ }
91
+
92
+ // For semantic colors (success, error, warning, info), use solid color
93
+ const isSemanticColor = ['success', 'error', 'warning', 'info'].includes(resolvedScheme);
94
+ return {
95
+ backgroundColor: isSemanticColor ? colorConfig.solid : colorConfig.bg,
96
+ borderOpacity: isSemanticColor ? 0.5 : 0.3,
97
+ textColor: isSemanticColor ? theme.colors.white : theme.colors.textPrimary,
98
+ };
99
+ };
100
+
101
+ const btnStyle = getButtonStyles();
102
+
103
+ return (
104
+ <AnimatedPressable
105
+ onPress={onPress}
106
+ onPressIn={handlePressIn}
107
+ onPressOut={handlePressOut}
108
+ disabled={disabled}
109
+ style={[styles.wrapper, animatedStyle, style]}
110
+ accessibilityRole="button"
111
+ accessibilityLabel={accessibilityLabel ?? title}
112
+ accessibilityHint={accessibilityHint}
113
+ accessibilityState={{ disabled: !!disabled }}
114
+ >
115
+ {isGhost ? (
116
+ <View style={[styles.content, { paddingHorizontal: sizeConfig.paddingHorizontal }]}>
117
+ {icon && <View style={styles.iconContainer}>{icon}</View>}
118
+ <Text style={[styles.text, { color: btnStyle.textColor, fontSize: sizeConfig.fontSize, fontFamily: theme.typography.semiBold }, textStyle]}>
119
+ {title}
120
+ </Text>
121
+ </View>
122
+ ) : (
123
+ <FluentGlass
124
+ style={[
125
+ styles.container,
126
+ {
127
+ backgroundColor: btnStyle.backgroundColor,
128
+ minHeight: sizeConfig.minHeight,
129
+ borderRadius: sizeConfig.borderRadius,
130
+ },
131
+ ]}
132
+ colorScheme={resolvedScheme}
133
+ blur={resolvedBlur}
134
+ radius={radius}
135
+ borderOpacity={btnStyle.borderOpacity}
136
+ borderRadius={sizeConfig.borderRadius}
137
+ >
138
+ <View style={[styles.content, { paddingHorizontal: sizeConfig.paddingHorizontal }]}>
139
+ {icon && <View style={styles.iconContainer}>{icon}</View>}
140
+ <Text style={[styles.text, { color: btnStyle.textColor, fontSize: sizeConfig.fontSize, fontFamily: theme.typography.semiBold }, textStyle]}>
141
+ {title}
142
+ </Text>
143
+ </View>
144
+ </FluentGlass>
145
+ )}
146
+ </AnimatedPressable>
147
+ );
148
+ }
149
+
150
+ const styles = StyleSheet.create({
151
+ wrapper: {
152
+ marginVertical: 4,
153
+ },
154
+ container: {
155
+ borderRadius: 12,
156
+ },
157
+ content: {
158
+ flex: 1,
159
+ flexDirection: 'row',
160
+ alignItems: 'center',
161
+ justifyContent: 'center',
162
+ },
163
+ text: {
164
+ fontWeight: '600',
165
+ },
166
+ iconContainer: {
167
+ marginRight: 8,
168
+ },
169
+ });
@@ -0,0 +1,55 @@
1
+ import React from 'react';
2
+
3
+ import { StyleSheet, View, Text, StyleProp, ViewStyle } from 'react-native';
4
+ import FluentGlass from './FluentGlass';
5
+ import useTheme from '../theme/useTheme';
6
+ import { moderateScale } from '../utils/responsive';
7
+
8
+ export interface FluentGlassCalendarWidgetProps {
9
+ day?: string;
10
+ month?: string;
11
+ style?: StyleProp<ViewStyle>;
12
+ }
13
+
14
+ /**
15
+ * FluentGlassCalendarWidget (Atom/Molecule)
16
+ * Dashboard widget displaying month and day.
17
+ */
18
+ export default function FluentGlassCalendarWidget({ day = '18', month = 'FEB', style }: FluentGlassCalendarWidgetProps) {
19
+ const theme = useTheme();
20
+ const COLORS = theme.colors;
21
+ const typography = theme.typography;
22
+
23
+ return (
24
+ <FluentGlass accessible={true} accessibilityLabel={`${month} ${day}`} style={[styles.card, style]} intensity={25} borderRadius={20}>
25
+ <View style={styles.content}>
26
+ <Text style={[styles.redHeader, { color: COLORS.negative, fontFamily: typography.bold }]}>{month}</Text>
27
+ <Text style={[styles.bigValue, { color: COLORS.textPrimary, fontFamily: typography.regular }]}>{day}</Text>
28
+ </View>
29
+ </FluentGlass>
30
+ );
31
+ }
32
+
33
+ const styles = StyleSheet.create({
34
+ card: {
35
+ flex: 1,
36
+ minWidth: 100,
37
+ maxWidth: 140,
38
+ aspectRatio: 1,
39
+ },
40
+ content: {
41
+ flex: 1,
42
+ justifyContent: 'center',
43
+ alignItems: 'center',
44
+ },
45
+ redHeader: {
46
+ fontSize: 12,
47
+ fontWeight: 'bold',
48
+ textTransform: 'uppercase',
49
+ marginBottom: 4,
50
+ },
51
+ bigValue: {
52
+ fontSize: moderateScale(28),
53
+ fontWeight: '300',
54
+ },
55
+ });
@@ -0,0 +1,186 @@
1
+ import React from 'react';
2
+ import { StyleSheet, Text, View } from 'react-native';
3
+ import FluentGlass from './FluentGlass';
4
+ import FluentGlassButton from './FluentGlassButton';
5
+ import useTheme from '../theme/useTheme';
6
+ import { resolveSize, resolveColorScheme, resolveRadius, resolveBackwardCompat } from '../theme/resolvers';
7
+
8
+ /**
9
+ * FluentGlassCard (Organism)
10
+ * Structured glass card with two variants:
11
+ * - 'standard': Title + description + content + optional action
12
+ * - 'featured': Colored header area + icon + title + description + optional action
13
+ *
14
+ * @param {string} size - 'xs' | 'sm' | 'md' | 'lg' | 'xl'
15
+ * @param {string} colorScheme - 'default' | 'dark' | 'info' | 'success' | 'error' | 'warning'
16
+ * @param {string} blur - blur intensity
17
+ * @param {string} radius - border radius
18
+ */
19
+ import { ViewStyle, StyleProp } from 'react-native';
20
+ import { FluentGlassBaseProps } from '../types/components';
21
+
22
+ export interface FluentGlassCardProps extends FluentGlassBaseProps {
23
+ variant?: 'standard' | 'featured' | string;
24
+ title?: string;
25
+ description?: string;
26
+ children?: React.ReactNode;
27
+ actionLabel?: string;
28
+ onAction?: () => void;
29
+ icon?: string | React.ReactNode;
30
+ headerColor?: string;
31
+ style?: StyleProp<ViewStyle>;
32
+ }
33
+
34
+ export default function FluentGlassCard({
35
+ variant = 'standard', // 'standard' | 'featured'
36
+ title,
37
+ description,
38
+ children,
39
+ actionLabel,
40
+ onAction,
41
+ icon, // String emoji or React node for featured header
42
+ headerColor, // Override header bg color (featured variant)
43
+ style,
44
+ // New standardized props
45
+ size,
46
+ colorScheme,
47
+ blur,
48
+ radius,
49
+ }: FluentGlassCardProps) {
50
+ const theme = useTheme();
51
+ const sizeConfig = resolveSize(theme, size || theme.defaults.size);
52
+ const compat = resolveBackwardCompat({ colorScheme, blur });
53
+ const resolvedScheme = compat.colorScheme || theme.defaults.colorScheme;
54
+ const colorConfig = resolveColorScheme(theme, resolvedScheme);
55
+ const resolvedRadius = resolveRadius(theme, radius || 'lg');
56
+
57
+ if (variant === 'featured') {
58
+ return (
59
+ <FluentGlass
60
+ style={[styles.container, style]}
61
+ colorScheme={resolvedScheme}
62
+ blur={compat.blur || 'subtle'}
63
+ radius={radius}
64
+ borderRadius={resolvedRadius}
65
+ borderOpacity={0.2}
66
+ >
67
+ <View style={styles.inner}>
68
+ {/* Featured Header */}
69
+ <View
70
+ style={[
71
+ styles.featuredHeader,
72
+ headerColor ? { backgroundColor: headerColor } : { backgroundColor: `${colorConfig.solid}40` },
73
+ { borderTopLeftRadius: resolvedRadius - 1, borderTopRightRadius: resolvedRadius - 1 }
74
+ ]}
75
+ />
76
+
77
+ {/* Body */}
78
+ <View style={[styles.body, { padding: sizeConfig.paddingHorizontal }]}>
79
+ {(icon || title) ? (
80
+ <View style={styles.titleRow}>
81
+ {icon ? (
82
+ <Text style={[styles.icon, { fontSize: sizeConfig.fontSize + 2 }]}>{icon}</Text>
83
+ ) : null}
84
+ {title ? (
85
+ <Text style={[styles.title, { color: theme.colors.textPrimary, fontSize: sizeConfig.fontSize + 2, fontFamily: theme.typography.bold }]}>{title}</Text>
86
+ ) : null}
87
+ </View>
88
+ ) : null}
89
+
90
+ {description ? (
91
+ <Text style={[styles.description, { color: theme.colors.textSecondary, fontSize: sizeConfig.fontSize - 1, fontFamily: theme.typography.regular }]}>{description}</Text>
92
+ ) : null}
93
+
94
+ {children ? (
95
+ <View style={[styles.content, { marginTop: (sizeConfig.gap || 0) * 2 }]}>{children}</View>
96
+ ) : null}
97
+
98
+ {actionLabel ? (
99
+ <FluentGlassButton
100
+ title={actionLabel}
101
+ onPress={onAction}
102
+ style={styles.actionBtn}
103
+ size={size}
104
+ colorScheme={resolvedScheme === 'default' ? 'info' : resolvedScheme}
105
+ />
106
+ ) : null}
107
+ </View>
108
+ </View>
109
+ </FluentGlass>
110
+ );
111
+ }
112
+
113
+ // Standard variant
114
+ return (
115
+ <FluentGlass
116
+ style={[styles.container, style]}
117
+ colorScheme={resolvedScheme}
118
+ blur={compat.blur || 'subtle'}
119
+ radius={radius}
120
+ borderRadius={resolvedRadius}
121
+ borderOpacity={0.2}
122
+ >
123
+ <View style={[styles.inner, styles.body, { padding: sizeConfig.paddingHorizontal }]}>
124
+ {title ? (
125
+ <Text style={[styles.title, { color: theme.colors.textPrimary, fontSize: sizeConfig.fontSize + 2, fontFamily: theme.typography.bold }]}>{title}</Text>
126
+ ) : null}
127
+
128
+ {description ? (
129
+ <Text style={[styles.description, { color: theme.colors.textSecondary, fontSize: sizeConfig.fontSize - 1, fontFamily: theme.typography.regular }]}>{description}</Text>
130
+ ) : null}
131
+
132
+ {children ? (
133
+ <View style={[styles.content, { marginTop: (sizeConfig.gap || 0) * 2 }]}>{children}</View>
134
+ ) : null}
135
+
136
+ {actionLabel ? (
137
+ <FluentGlassButton
138
+ title={actionLabel}
139
+ onPress={onAction}
140
+ variant="secondary"
141
+ style={styles.actionBtn}
142
+ size={size}
143
+ />
144
+ ) : null}
145
+ </View>
146
+ </FluentGlass>
147
+ );
148
+ }
149
+
150
+ const styles = StyleSheet.create({
151
+ container: {
152
+ minHeight: 80,
153
+ },
154
+ inner: {
155
+ flex: 1,
156
+ },
157
+ featuredHeader: {
158
+ height: 100,
159
+ },
160
+ body: {
161
+ padding: 16,
162
+ },
163
+ titleRow: {
164
+ flexDirection: 'row',
165
+ alignItems: 'center',
166
+ marginBottom: 6,
167
+ },
168
+ icon: {
169
+ marginRight: 8,
170
+ },
171
+ title: {
172
+ fontWeight: '700',
173
+ },
174
+ description: {
175
+ fontWeight: '400',
176
+ marginTop: 4,
177
+ lineHeight: 20,
178
+ },
179
+ content: {
180
+ marginTop: 12,
181
+ },
182
+ actionBtn: {
183
+ marginTop: 16,
184
+ alignSelf: 'flex-start',
185
+ },
186
+ });