@smart-coder-labs/apple-design-system 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (664) hide show
  1. package/README.md +442 -0
  2. package/dist/cli/commands/add.d.ts +2 -0
  3. package/dist/cli/commands/add.d.ts.map +1 -0
  4. package/dist/cli/commands/add.js +102 -0
  5. package/dist/cli/commands/add.js.map +1 -0
  6. package/dist/cli/commands/init.d.ts +2 -0
  7. package/dist/cli/commands/init.d.ts.map +1 -0
  8. package/dist/cli/commands/init.js +73 -0
  9. package/dist/cli/commands/init.js.map +1 -0
  10. package/dist/cli/index.d.ts +3 -0
  11. package/dist/cli/index.d.ts.map +1 -0
  12. package/dist/cli/index.js +20 -0
  13. package/dist/cli/index.js.map +1 -0
  14. package/dist/cli/utils/registry.d.ts +4 -0
  15. package/dist/cli/utils/registry.d.ts.map +1 -0
  16. package/dist/cli/utils/registry.js +52 -0
  17. package/dist/cli/utils/registry.js.map +1 -0
  18. package/dist/components/AIThinkingIndicator.d.ts +10 -0
  19. package/dist/components/AIThinkingIndicator.d.ts.map +1 -0
  20. package/dist/components/AIThinkingIndicator.js +60 -0
  21. package/dist/components/AIThinkingIndicator.js.map +1 -0
  22. package/dist/components/Accordion.d.ts +27 -0
  23. package/dist/components/Accordion.d.ts.map +1 -0
  24. package/dist/components/Accordion.js +123 -0
  25. package/dist/components/Accordion.js.map +1 -0
  26. package/dist/components/ActivityFeed.d.ts +26 -0
  27. package/dist/components/ActivityFeed.d.ts.map +1 -0
  28. package/dist/components/ActivityFeed.js +55 -0
  29. package/dist/components/ActivityFeed.js.map +1 -0
  30. package/dist/components/ActivityMonitor.d.ts +38 -0
  31. package/dist/components/ActivityMonitor.d.ts.map +1 -0
  32. package/dist/components/ActivityMonitor.js +164 -0
  33. package/dist/components/ActivityMonitor.js.map +1 -0
  34. package/dist/components/AddressSelector.d.ts +23 -0
  35. package/dist/components/AddressSelector.d.ts.map +1 -0
  36. package/dist/components/AddressSelector.js +145 -0
  37. package/dist/components/AddressSelector.js.map +1 -0
  38. package/dist/components/AgendaView.d.ts +11 -0
  39. package/dist/components/AgendaView.d.ts.map +1 -0
  40. package/dist/components/AgendaView.js +47 -0
  41. package/dist/components/AgendaView.js.map +1 -0
  42. package/dist/components/Alert.d.ts +9 -0
  43. package/dist/components/Alert.d.ts.map +1 -0
  44. package/dist/components/Alert.js +38 -0
  45. package/dist/components/Alert.js.map +1 -0
  46. package/dist/components/AudioPlayer.d.ts +11 -0
  47. package/dist/components/AudioPlayer.d.ts.map +1 -0
  48. package/dist/components/AudioPlayer.js +116 -0
  49. package/dist/components/AudioPlayer.js.map +1 -0
  50. package/dist/components/Avatar.d.ts +17 -0
  51. package/dist/components/Avatar.d.ts.map +1 -0
  52. package/dist/components/Avatar.js +74 -0
  53. package/dist/components/Avatar.js.map +1 -0
  54. package/dist/components/AvatarGroup.d.ts +15 -0
  55. package/dist/components/AvatarGroup.d.ts.map +1 -0
  56. package/dist/components/AvatarGroup.js +28 -0
  57. package/dist/components/AvatarGroup.js.map +1 -0
  58. package/dist/components/Badge.d.ts +21 -0
  59. package/dist/components/Badge.d.ts.map +1 -0
  60. package/dist/components/Badge.js +103 -0
  61. package/dist/components/Badge.js.map +1 -0
  62. package/dist/components/BarcodeGenerator.d.ts +18 -0
  63. package/dist/components/BarcodeGenerator.d.ts.map +1 -0
  64. package/dist/components/BarcodeGenerator.js +64 -0
  65. package/dist/components/BarcodeGenerator.js.map +1 -0
  66. package/dist/components/Blockquote.d.ts +9 -0
  67. package/dist/components/Blockquote.d.ts.map +1 -0
  68. package/dist/components/Blockquote.js +8 -0
  69. package/dist/components/Blockquote.js.map +1 -0
  70. package/dist/components/BottomNavigation.d.ts +21 -0
  71. package/dist/components/BottomNavigation.d.ts.map +1 -0
  72. package/dist/components/BottomNavigation.js +77 -0
  73. package/dist/components/BottomNavigation.js.map +1 -0
  74. package/dist/components/Breadcrumb.d.ts +20 -0
  75. package/dist/components/Breadcrumb.d.ts.map +1 -0
  76. package/dist/components/Breadcrumb.js +24 -0
  77. package/dist/components/Breadcrumb.js.map +1 -0
  78. package/dist/components/BreadcrumbTabsHybrid.d.ts +25 -0
  79. package/dist/components/BreadcrumbTabsHybrid.d.ts.map +1 -0
  80. package/dist/components/BreadcrumbTabsHybrid.js +58 -0
  81. package/dist/components/BreadcrumbTabsHybrid.js.map +1 -0
  82. package/dist/components/Button.d.ts +14 -0
  83. package/dist/components/Button.d.ts.map +1 -0
  84. package/dist/components/Button.js +91 -0
  85. package/dist/components/Button.js.map +1 -0
  86. package/dist/components/ButtonWithDropdown.d.ts +19 -0
  87. package/dist/components/ButtonWithDropdown.d.ts.map +1 -0
  88. package/dist/components/ButtonWithDropdown.js +33 -0
  89. package/dist/components/ButtonWithDropdown.js.map +1 -0
  90. package/dist/components/Calendar.d.ts +28 -0
  91. package/dist/components/Calendar.d.ts.map +1 -0
  92. package/dist/components/Calendar.js +365 -0
  93. package/dist/components/Calendar.js.map +1 -0
  94. package/dist/components/Callout.d.ts +11 -0
  95. package/dist/components/Callout.d.ts.map +1 -0
  96. package/dist/components/Callout.js +35 -0
  97. package/dist/components/Callout.js.map +1 -0
  98. package/dist/components/Caption.d.ts +6 -0
  99. package/dist/components/Caption.d.ts.map +1 -0
  100. package/dist/components/Caption.js +7 -0
  101. package/dist/components/Caption.js.map +1 -0
  102. package/dist/components/Card.d.ts +30 -0
  103. package/dist/components/Card.d.ts.map +1 -0
  104. package/dist/components/Card.js +72 -0
  105. package/dist/components/Card.js.map +1 -0
  106. package/dist/components/CartPreview.d.ts +28 -0
  107. package/dist/components/CartPreview.d.ts.map +1 -0
  108. package/dist/components/CartPreview.js +80 -0
  109. package/dist/components/CartPreview.js.map +1 -0
  110. package/dist/components/Chart.d.ts +19 -0
  111. package/dist/components/Chart.d.ts.map +1 -0
  112. package/dist/components/Chart.js +46 -0
  113. package/dist/components/Chart.js.map +1 -0
  114. package/dist/components/ChatBubble.d.ts +19 -0
  115. package/dist/components/ChatBubble.d.ts.map +1 -0
  116. package/dist/components/ChatBubble.js +27 -0
  117. package/dist/components/ChatBubble.js.map +1 -0
  118. package/dist/components/ChatInput.d.ts +22 -0
  119. package/dist/components/ChatInput.d.ts.map +1 -0
  120. package/dist/components/ChatInput.js +115 -0
  121. package/dist/components/ChatInput.js.map +1 -0
  122. package/dist/components/Checkbox.d.ts +10 -0
  123. package/dist/components/Checkbox.d.ts.map +1 -0
  124. package/dist/components/Checkbox.js +35 -0
  125. package/dist/components/Checkbox.js.map +1 -0
  126. package/dist/components/Chip.d.ts +14 -0
  127. package/dist/components/Chip.d.ts.map +1 -0
  128. package/dist/components/Chip.js +43 -0
  129. package/dist/components/Chip.js.map +1 -0
  130. package/dist/components/CodeBlock.d.ts +9 -0
  131. package/dist/components/CodeBlock.d.ts.map +1 -0
  132. package/dist/components/CodeBlock.js +16 -0
  133. package/dist/components/CodeBlock.js.map +1 -0
  134. package/dist/components/Collapsible.d.ts +19 -0
  135. package/dist/components/Collapsible.d.ts.map +1 -0
  136. package/dist/components/Collapsible.js +42 -0
  137. package/dist/components/Collapsible.js.map +1 -0
  138. package/dist/components/Combobox.d.ts +17 -0
  139. package/dist/components/Combobox.d.ts.map +1 -0
  140. package/dist/components/Combobox.js +114 -0
  141. package/dist/components/Combobox.js.map +1 -0
  142. package/dist/components/CommandMenu.d.ts +36 -0
  143. package/dist/components/CommandMenu.d.ts.map +1 -0
  144. package/dist/components/CommandMenu.js +102 -0
  145. package/dist/components/CommandMenu.js.map +1 -0
  146. package/dist/components/CommentThread.d.ts +28 -0
  147. package/dist/components/CommentThread.d.ts.map +1 -0
  148. package/dist/components/CommentThread.js +66 -0
  149. package/dist/components/CommentThread.js.map +1 -0
  150. package/dist/components/ConfirmDialog.d.ts +27 -0
  151. package/dist/components/ConfirmDialog.d.ts.map +1 -0
  152. package/dist/components/ConfirmDialog.js +62 -0
  153. package/dist/components/ConfirmDialog.js.map +1 -0
  154. package/dist/components/ContextMenu.d.ts +85 -0
  155. package/dist/components/ContextMenu.d.ts.map +1 -0
  156. package/dist/components/ContextMenu.js +191 -0
  157. package/dist/components/ContextMenu.js.map +1 -0
  158. package/dist/components/ControlCenterToggles.d.ts +18 -0
  159. package/dist/components/ControlCenterToggles.d.ts.map +1 -0
  160. package/dist/components/ControlCenterToggles.js +14 -0
  161. package/dist/components/ControlCenterToggles.js.map +1 -0
  162. package/dist/components/Counters.d.ts +16 -0
  163. package/dist/components/Counters.d.ts.map +1 -0
  164. package/dist/components/Counters.js +9 -0
  165. package/dist/components/Counters.js.map +1 -0
  166. package/dist/components/CountersListWithChart.d.ts +15 -0
  167. package/dist/components/CountersListWithChart.d.ts.map +1 -0
  168. package/dist/components/CountersListWithChart.js +22 -0
  169. package/dist/components/CountersListWithChart.js.map +1 -0
  170. package/dist/components/DataGrid.d.ts +38 -0
  171. package/dist/components/DataGrid.d.ts.map +1 -0
  172. package/dist/components/DataGrid.js +271 -0
  173. package/dist/components/DataGrid.js.map +1 -0
  174. package/dist/components/DatePicker.d.ts +17 -0
  175. package/dist/components/DatePicker.d.ts.map +1 -0
  176. package/dist/components/DatePicker.js +248 -0
  177. package/dist/components/DatePicker.js.map +1 -0
  178. package/dist/components/DateRangePicker.d.ts +21 -0
  179. package/dist/components/DateRangePicker.d.ts.map +1 -0
  180. package/dist/components/DateRangePicker.js +213 -0
  181. package/dist/components/DateRangePicker.js.map +1 -0
  182. package/dist/components/DefinitionList.d.ts +21 -0
  183. package/dist/components/DefinitionList.d.ts.map +1 -0
  184. package/dist/components/DefinitionList.js +44 -0
  185. package/dist/components/DefinitionList.js.map +1 -0
  186. package/dist/components/DescriptionBlock.d.ts +36 -0
  187. package/dist/components/DescriptionBlock.d.ts.map +1 -0
  188. package/dist/components/DescriptionBlock.js +27 -0
  189. package/dist/components/DescriptionBlock.js.map +1 -0
  190. package/dist/components/DeviceList.d.ts +24 -0
  191. package/dist/components/DeviceList.d.ts.map +1 -0
  192. package/dist/components/DeviceList.js +46 -0
  193. package/dist/components/DeviceList.js.map +1 -0
  194. package/dist/components/DiffViewer.d.ts +13 -0
  195. package/dist/components/DiffViewer.d.ts.map +1 -0
  196. package/dist/components/DiffViewer.js +93 -0
  197. package/dist/components/DiffViewer.js.map +1 -0
  198. package/dist/components/Divider.d.ts +28 -0
  199. package/dist/components/Divider.d.ts.map +1 -0
  200. package/dist/components/Divider.js +16 -0
  201. package/dist/components/Divider.js.map +1 -0
  202. package/dist/components/DockBar.d.ts +29 -0
  203. package/dist/components/DockBar.d.ts.map +1 -0
  204. package/dist/components/DockBar.js +64 -0
  205. package/dist/components/DockBar.js.map +1 -0
  206. package/dist/components/EmptyState.d.ts +25 -0
  207. package/dist/components/EmptyState.d.ts.map +1 -0
  208. package/dist/components/EmptyState.js +20 -0
  209. package/dist/components/EmptyState.js.map +1 -0
  210. package/dist/components/ErrorBoundary.d.ts +24 -0
  211. package/dist/components/ErrorBoundary.d.ts.map +1 -0
  212. package/dist/components/ErrorBoundary.js +55 -0
  213. package/dist/components/ErrorBoundary.js.map +1 -0
  214. package/dist/components/FAB.d.ts +15 -0
  215. package/dist/components/FAB.d.ts.map +1 -0
  216. package/dist/components/FAB.js +46 -0
  217. package/dist/components/FAB.js.map +1 -0
  218. package/dist/components/FABGroup.d.ts +15 -0
  219. package/dist/components/FABGroup.d.ts.map +1 -0
  220. package/dist/components/FABGroup.js +47 -0
  221. package/dist/components/FABGroup.js.map +1 -0
  222. package/dist/components/FileIntelligencePreview.d.ts +25 -0
  223. package/dist/components/FileIntelligencePreview.d.ts.map +1 -0
  224. package/dist/components/FileIntelligencePreview.js +66 -0
  225. package/dist/components/FileIntelligencePreview.js.map +1 -0
  226. package/dist/components/FileUpload.d.ts +13 -0
  227. package/dist/components/FileUpload.d.ts.map +1 -0
  228. package/dist/components/FileUpload.js +107 -0
  229. package/dist/components/FileUpload.js.map +1 -0
  230. package/dist/components/FilterBar.d.ts +35 -0
  231. package/dist/components/FilterBar.d.ts.map +1 -0
  232. package/dist/components/FilterBar.js +79 -0
  233. package/dist/components/FilterBar.js.map +1 -0
  234. package/dist/components/FloatingToolbar.d.ts +24 -0
  235. package/dist/components/FloatingToolbar.d.ts.map +1 -0
  236. package/dist/components/FloatingToolbar.js +180 -0
  237. package/dist/components/FloatingToolbar.js.map +1 -0
  238. package/dist/components/Footer.d.ts +32 -0
  239. package/dist/components/Footer.d.ts.map +1 -0
  240. package/dist/components/Footer.js +31 -0
  241. package/dist/components/Footer.js.map +1 -0
  242. package/dist/components/Gallery.d.ts +11 -0
  243. package/dist/components/Gallery.d.ts.map +1 -0
  244. package/dist/components/Gallery.js +32 -0
  245. package/dist/components/Gallery.js.map +1 -0
  246. package/dist/components/GestureCard.d.ts +12 -0
  247. package/dist/components/GestureCard.d.ts.map +1 -0
  248. package/dist/components/GestureCard.js +58 -0
  249. package/dist/components/GestureCard.js.map +1 -0
  250. package/dist/components/GridSystem.d.ts +72 -0
  251. package/dist/components/GridSystem.d.ts.map +1 -0
  252. package/dist/components/GridSystem.js +65 -0
  253. package/dist/components/GridSystem.js.map +1 -0
  254. package/dist/components/HamburgerMenuIcon.d.ts +24 -0
  255. package/dist/components/HamburgerMenuIcon.d.ts.map +1 -0
  256. package/dist/components/HamburgerMenuIcon.js +44 -0
  257. package/dist/components/HamburgerMenuIcon.js.map +1 -0
  258. package/dist/components/HapticButton.d.ts +23 -0
  259. package/dist/components/HapticButton.d.ts.map +1 -0
  260. package/dist/components/HapticButton.js +104 -0
  261. package/dist/components/HapticButton.js.map +1 -0
  262. package/dist/components/Heading.d.ts +6 -0
  263. package/dist/components/Heading.d.ts.map +1 -0
  264. package/dist/components/Heading.js +7 -0
  265. package/dist/components/Heading.js.map +1 -0
  266. package/dist/components/IconButton.d.ts +14 -0
  267. package/dist/components/IconButton.d.ts.map +1 -0
  268. package/dist/components/IconButton.js +39 -0
  269. package/dist/components/IconButton.js.map +1 -0
  270. package/dist/components/ImageCarousel.d.ts +18 -0
  271. package/dist/components/ImageCarousel.d.ts.map +1 -0
  272. package/dist/components/ImageCarousel.js +74 -0
  273. package/dist/components/ImageCarousel.js.map +1 -0
  274. package/dist/components/ImageCropper.d.ts +10 -0
  275. package/dist/components/ImageCropper.d.ts.map +1 -0
  276. package/dist/components/ImageCropper.js +138 -0
  277. package/dist/components/ImageCropper.js.map +1 -0
  278. package/dist/components/Input.d.ts +18 -0
  279. package/dist/components/Input.d.ts.map +1 -0
  280. package/dist/components/Input.js +117 -0
  281. package/dist/components/Input.js.map +1 -0
  282. package/dist/components/InspectorPanel.d.ts +18 -0
  283. package/dist/components/InspectorPanel.d.ts.map +1 -0
  284. package/dist/components/InspectorPanel.js +33 -0
  285. package/dist/components/InspectorPanel.js.map +1 -0
  286. package/dist/components/InvoicePreview.d.ts +41 -0
  287. package/dist/components/InvoicePreview.d.ts.map +1 -0
  288. package/dist/components/InvoicePreview.js +106 -0
  289. package/dist/components/InvoicePreview.js.map +1 -0
  290. package/dist/components/JsonViewer.d.ts +17 -0
  291. package/dist/components/JsonViewer.d.ts.map +1 -0
  292. package/dist/components/JsonViewer.js +58 -0
  293. package/dist/components/JsonViewer.js.map +1 -0
  294. package/dist/components/KPIBlock.d.ts +23 -0
  295. package/dist/components/KPIBlock.d.ts.map +1 -0
  296. package/dist/components/KPIBlock.js +82 -0
  297. package/dist/components/KPIBlock.js.map +1 -0
  298. package/dist/components/KanbanBoard.d.ts +34 -0
  299. package/dist/components/KanbanBoard.d.ts.map +1 -0
  300. package/dist/components/KanbanBoard.js +296 -0
  301. package/dist/components/KanbanBoard.js.map +1 -0
  302. package/dist/components/KeyValueInfo.d.ts +28 -0
  303. package/dist/components/KeyValueInfo.d.ts.map +1 -0
  304. package/dist/components/KeyValueInfo.js +80 -0
  305. package/dist/components/KeyValueInfo.js.map +1 -0
  306. package/dist/components/Label.d.ts +8 -0
  307. package/dist/components/Label.d.ts.map +1 -0
  308. package/dist/components/Label.js +9 -0
  309. package/dist/components/Label.js.map +1 -0
  310. package/dist/components/Layout.d.ts +16 -0
  311. package/dist/components/Layout.d.ts.map +1 -0
  312. package/dist/components/Layout.js +26 -0
  313. package/dist/components/Layout.js.map +1 -0
  314. package/dist/components/Lightbox.d.ts +18 -0
  315. package/dist/components/Lightbox.d.ts.map +1 -0
  316. package/dist/components/Lightbox.js +60 -0
  317. package/dist/components/Lightbox.js.map +1 -0
  318. package/dist/components/LoadingOverlay.d.ts +32 -0
  319. package/dist/components/LoadingOverlay.d.ts.map +1 -0
  320. package/dist/components/LoadingOverlay.js +10 -0
  321. package/dist/components/LoadingOverlay.js.map +1 -0
  322. package/dist/components/LoginForm.d.ts +14 -0
  323. package/dist/components/LoginForm.d.ts.map +1 -0
  324. package/dist/components/LoginForm.js +36 -0
  325. package/dist/components/LoginForm.js.map +1 -0
  326. package/dist/components/MaintenanceMode.d.ts +41 -0
  327. package/dist/components/MaintenanceMode.d.ts.map +1 -0
  328. package/dist/components/MaintenanceMode.js +21 -0
  329. package/dist/components/MaintenanceMode.js.map +1 -0
  330. package/dist/components/MarkdownEditor.d.ts +14 -0
  331. package/dist/components/MarkdownEditor.d.ts.map +1 -0
  332. package/dist/components/MarkdownEditor.js +55 -0
  333. package/dist/components/MarkdownEditor.js.map +1 -0
  334. package/dist/components/MasonryLayout.d.ts +31 -0
  335. package/dist/components/MasonryLayout.d.ts.map +1 -0
  336. package/dist/components/MasonryLayout.js +17 -0
  337. package/dist/components/MasonryLayout.js.map +1 -0
  338. package/dist/components/MenuBar.d.ts +34 -0
  339. package/dist/components/MenuBar.d.ts.map +1 -0
  340. package/dist/components/MenuBar.js +66 -0
  341. package/dist/components/MenuBar.js.map +1 -0
  342. package/dist/components/MessageReactions.d.ts +22 -0
  343. package/dist/components/MessageReactions.d.ts.map +1 -0
  344. package/dist/components/MessageReactions.js +37 -0
  345. package/dist/components/MessageReactions.js.map +1 -0
  346. package/dist/components/Modal.d.ts +37 -0
  347. package/dist/components/Modal.d.ts.map +1 -0
  348. package/dist/components/Modal.js +93 -0
  349. package/dist/components/Modal.js.map +1 -0
  350. package/dist/components/ModalStackManager.d.ts +34 -0
  351. package/dist/components/ModalStackManager.d.ts.map +1 -0
  352. package/dist/components/ModalStackManager.js +52 -0
  353. package/dist/components/ModalStackManager.js.map +1 -0
  354. package/dist/components/MultiFileUpload.d.ts +15 -0
  355. package/dist/components/MultiFileUpload.d.ts.map +1 -0
  356. package/dist/components/MultiFileUpload.js +138 -0
  357. package/dist/components/MultiFileUpload.js.map +1 -0
  358. package/dist/components/NavBar.d.ts +30 -0
  359. package/dist/components/NavBar.d.ts.map +1 -0
  360. package/dist/components/NavBar.js +80 -0
  361. package/dist/components/NavBar.js.map +1 -0
  362. package/dist/components/NavigationDrawer.d.ts +48 -0
  363. package/dist/components/NavigationDrawer.d.ts.map +1 -0
  364. package/dist/components/NavigationDrawer.js +95 -0
  365. package/dist/components/NavigationDrawer.js.map +1 -0
  366. package/dist/components/NotificationCenterPanel.d.ts +25 -0
  367. package/dist/components/NotificationCenterPanel.d.ts.map +1 -0
  368. package/dist/components/NotificationCenterPanel.js +50 -0
  369. package/dist/components/NotificationCenterPanel.js.map +1 -0
  370. package/dist/components/OTPInput.d.ts +15 -0
  371. package/dist/components/OTPInput.d.ts.map +1 -0
  372. package/dist/components/OTPInput.js +144 -0
  373. package/dist/components/OTPInput.js.map +1 -0
  374. package/dist/components/OfflineState.d.ts +36 -0
  375. package/dist/components/OfflineState.d.ts.map +1 -0
  376. package/dist/components/OfflineState.js +21 -0
  377. package/dist/components/OfflineState.js.map +1 -0
  378. package/dist/components/OrderSummary.d.ts +19 -0
  379. package/dist/components/OrderSummary.d.ts.map +1 -0
  380. package/dist/components/OrderSummary.js +8 -0
  381. package/dist/components/OrderSummary.js.map +1 -0
  382. package/dist/components/Pagination.d.ts +28 -0
  383. package/dist/components/Pagination.d.ts.map +1 -0
  384. package/dist/components/Pagination.js +119 -0
  385. package/dist/components/Pagination.js.map +1 -0
  386. package/dist/components/Panel.d.ts +14 -0
  387. package/dist/components/Panel.d.ts.map +1 -0
  388. package/dist/components/Panel.js +27 -0
  389. package/dist/components/Panel.js.map +1 -0
  390. package/dist/components/Paragraph.d.ts +6 -0
  391. package/dist/components/Paragraph.d.ts.map +1 -0
  392. package/dist/components/Paragraph.js +7 -0
  393. package/dist/components/Paragraph.js.map +1 -0
  394. package/dist/components/PasswordInput.d.ts +16 -0
  395. package/dist/components/PasswordInput.d.ts.map +1 -0
  396. package/dist/components/PasswordInput.js +66 -0
  397. package/dist/components/PasswordInput.js.map +1 -0
  398. package/dist/components/PaymentMethodSelector.d.ts +22 -0
  399. package/dist/components/PaymentMethodSelector.d.ts.map +1 -0
  400. package/dist/components/PaymentMethodSelector.js +24 -0
  401. package/dist/components/PaymentMethodSelector.js.map +1 -0
  402. package/dist/components/PermissionsMatrix.d.ts +23 -0
  403. package/dist/components/PermissionsMatrix.d.ts.map +1 -0
  404. package/dist/components/PermissionsMatrix.js +52 -0
  405. package/dist/components/PermissionsMatrix.js.map +1 -0
  406. package/dist/components/Popover.d.ts +19 -0
  407. package/dist/components/Popover.d.ts.map +1 -0
  408. package/dist/components/Popover.js +159 -0
  409. package/dist/components/Popover.js.map +1 -0
  410. package/dist/components/PriceDisplay.d.ts +18 -0
  411. package/dist/components/PriceDisplay.d.ts.map +1 -0
  412. package/dist/components/PriceDisplay.js +37 -0
  413. package/dist/components/PriceDisplay.js.map +1 -0
  414. package/dist/components/ProductCard.d.ts +30 -0
  415. package/dist/components/ProductCard.d.ts.map +1 -0
  416. package/dist/components/ProductCard.js +73 -0
  417. package/dist/components/ProductCard.js.map +1 -0
  418. package/dist/components/Progress.d.ts +9 -0
  419. package/dist/components/Progress.d.ts.map +1 -0
  420. package/dist/components/Progress.js +13 -0
  421. package/dist/components/Progress.js.map +1 -0
  422. package/dist/components/PromptSuggestionChips.d.ts +15 -0
  423. package/dist/components/PromptSuggestionChips.d.ts.map +1 -0
  424. package/dist/components/PromptSuggestionChips.js +17 -0
  425. package/dist/components/PromptSuggestionChips.js.map +1 -0
  426. package/dist/components/PropertyList.d.ts +29 -0
  427. package/dist/components/PropertyList.d.ts.map +1 -0
  428. package/dist/components/PropertyList.js +90 -0
  429. package/dist/components/PropertyList.js.map +1 -0
  430. package/dist/components/QRCodeGenerator.d.ts +17 -0
  431. package/dist/components/QRCodeGenerator.d.ts.map +1 -0
  432. package/dist/components/QRCodeGenerator.js +56 -0
  433. package/dist/components/QRCodeGenerator.js.map +1 -0
  434. package/dist/components/QuantitySelector.d.ts +16 -0
  435. package/dist/components/QuantitySelector.d.ts.map +1 -0
  436. package/dist/components/QuantitySelector.js +55 -0
  437. package/dist/components/QuantitySelector.js.map +1 -0
  438. package/dist/components/QueryBuilder.d.ts +30 -0
  439. package/dist/components/QueryBuilder.d.ts.map +1 -0
  440. package/dist/components/QueryBuilder.js +227 -0
  441. package/dist/components/QueryBuilder.js.map +1 -0
  442. package/dist/components/RadioGroup.d.ts +16 -0
  443. package/dist/components/RadioGroup.d.ts.map +1 -0
  444. package/dist/components/RadioGroup.js +36 -0
  445. package/dist/components/RadioGroup.js.map +1 -0
  446. package/dist/components/RangeSlider.d.ts +18 -0
  447. package/dist/components/RangeSlider.d.ts.map +1 -0
  448. package/dist/components/RangeSlider.js +121 -0
  449. package/dist/components/RangeSlider.js.map +1 -0
  450. package/dist/components/RatingInput.d.ts +15 -0
  451. package/dist/components/RatingInput.d.ts.map +1 -0
  452. package/dist/components/RatingInput.js +44 -0
  453. package/dist/components/RatingInput.js.map +1 -0
  454. package/dist/components/RecoveryCodeDisplay.d.ts +12 -0
  455. package/dist/components/RecoveryCodeDisplay.d.ts.map +1 -0
  456. package/dist/components/RecoveryCodeDisplay.js +48 -0
  457. package/dist/components/RecoveryCodeDisplay.js.map +1 -0
  458. package/dist/components/ResizablePanel.d.ts +18 -0
  459. package/dist/components/ResizablePanel.d.ts.map +1 -0
  460. package/dist/components/ResizablePanel.js +64 -0
  461. package/dist/components/ResizablePanel.js.map +1 -0
  462. package/dist/components/Reviews.d.ts +26 -0
  463. package/dist/components/Reviews.d.ts.map +1 -0
  464. package/dist/components/Reviews.js +30 -0
  465. package/dist/components/Reviews.js.map +1 -0
  466. package/dist/components/RichTextEditor.d.ts +14 -0
  467. package/dist/components/RichTextEditor.d.ts.map +1 -0
  468. package/dist/components/RichTextEditor.js +38 -0
  469. package/dist/components/RichTextEditor.js.map +1 -0
  470. package/dist/components/RotarySelector.d.ts +20 -0
  471. package/dist/components/RotarySelector.d.ts.map +1 -0
  472. package/dist/components/RotarySelector.js +99 -0
  473. package/dist/components/RotarySelector.js.map +1 -0
  474. package/dist/components/SchedulerTimeline.d.ts +31 -0
  475. package/dist/components/SchedulerTimeline.d.ts.map +1 -0
  476. package/dist/components/SchedulerTimeline.js +210 -0
  477. package/dist/components/SchedulerTimeline.js.map +1 -0
  478. package/dist/components/ScrollArea.d.ts +11 -0
  479. package/dist/components/ScrollArea.d.ts.map +1 -0
  480. package/dist/components/ScrollArea.js +132 -0
  481. package/dist/components/ScrollArea.js.map +1 -0
  482. package/dist/components/SearchInput.d.ts +13 -0
  483. package/dist/components/SearchInput.d.ts.map +1 -0
  484. package/dist/components/SearchInput.js +34 -0
  485. package/dist/components/SearchInput.js.map +1 -0
  486. package/dist/components/SectionHeader.d.ts +27 -0
  487. package/dist/components/SectionHeader.d.ts.map +1 -0
  488. package/dist/components/SectionHeader.js +18 -0
  489. package/dist/components/SectionHeader.js.map +1 -0
  490. package/dist/components/SecurityActivityLog.d.ts +20 -0
  491. package/dist/components/SecurityActivityLog.d.ts.map +1 -0
  492. package/dist/components/SecurityActivityLog.js +56 -0
  493. package/dist/components/SecurityActivityLog.js.map +1 -0
  494. package/dist/components/SegmentedInput.d.ts +15 -0
  495. package/dist/components/SegmentedInput.d.ts.map +1 -0
  496. package/dist/components/SegmentedInput.js +134 -0
  497. package/dist/components/SegmentedInput.js.map +1 -0
  498. package/dist/components/Select.d.ts +57 -0
  499. package/dist/components/Select.d.ts.map +1 -0
  500. package/dist/components/Select.js +275 -0
  501. package/dist/components/Select.js.map +1 -0
  502. package/dist/components/Sheet.d.ts +35 -0
  503. package/dist/components/Sheet.d.ts.map +1 -0
  504. package/dist/components/Sheet.js +117 -0
  505. package/dist/components/Sheet.js.map +1 -0
  506. package/dist/components/Sidebar.d.ts +23 -0
  507. package/dist/components/Sidebar.d.ts.map +1 -0
  508. package/dist/components/Sidebar.js +21 -0
  509. package/dist/components/Sidebar.js.map +1 -0
  510. package/dist/components/SignaturePad.d.ts +19 -0
  511. package/dist/components/SignaturePad.d.ts.map +1 -0
  512. package/dist/components/SignaturePad.js +133 -0
  513. package/dist/components/SignaturePad.js.map +1 -0
  514. package/dist/components/SignupForm.d.ts +15 -0
  515. package/dist/components/SignupForm.d.ts.map +1 -0
  516. package/dist/components/SignupForm.js +50 -0
  517. package/dist/components/SignupForm.js.map +1 -0
  518. package/dist/components/Skeleton.d.ts +3 -0
  519. package/dist/components/Skeleton.d.ts.map +1 -0
  520. package/dist/components/Skeleton.js +13 -0
  521. package/dist/components/Skeleton.js.map +1 -0
  522. package/dist/components/SlideToDelete.d.ts +26 -0
  523. package/dist/components/SlideToDelete.d.ts.map +1 -0
  524. package/dist/components/SlideToDelete.js +88 -0
  525. package/dist/components/SlideToDelete.js.map +1 -0
  526. package/dist/components/Slider.d.ts +18 -0
  527. package/dist/components/Slider.d.ts.map +1 -0
  528. package/dist/components/Slider.js +99 -0
  529. package/dist/components/Slider.js.map +1 -0
  530. package/dist/components/Snackbar.d.ts +16 -0
  531. package/dist/components/Snackbar.d.ts.map +1 -0
  532. package/dist/components/Snackbar.js +39 -0
  533. package/dist/components/Snackbar.js.map +1 -0
  534. package/dist/components/Spacer.d.ts +21 -0
  535. package/dist/components/Spacer.d.ts.map +1 -0
  536. package/dist/components/Spacer.js +44 -0
  537. package/dist/components/Spacer.js.map +1 -0
  538. package/dist/components/Sparkline.d.ts +17 -0
  539. package/dist/components/Sparkline.d.ts.map +1 -0
  540. package/dist/components/Sparkline.js +41 -0
  541. package/dist/components/Sparkline.js.map +1 -0
  542. package/dist/components/Spinner.d.ts +8 -0
  543. package/dist/components/Spinner.d.ts.map +1 -0
  544. package/dist/components/Spinner.js +26 -0
  545. package/dist/components/Spinner.js.map +1 -0
  546. package/dist/components/SplitButton.d.ts +20 -0
  547. package/dist/components/SplitButton.d.ts.map +1 -0
  548. package/dist/components/SplitButton.js +48 -0
  549. package/dist/components/SplitButton.js.map +1 -0
  550. package/dist/components/SplitView.d.ts +40 -0
  551. package/dist/components/SplitView.d.ts.map +1 -0
  552. package/dist/components/SplitView.js +14 -0
  553. package/dist/components/SplitView.js.map +1 -0
  554. package/dist/components/StatisticDisplay.d.ts +48 -0
  555. package/dist/components/StatisticDisplay.d.ts.map +1 -0
  556. package/dist/components/StatisticDisplay.js +141 -0
  557. package/dist/components/StatisticDisplay.js.map +1 -0
  558. package/dist/components/Stepper.d.ts +24 -0
  559. package/dist/components/Stepper.d.ts.map +1 -0
  560. package/dist/components/Stepper.js +99 -0
  561. package/dist/components/Stepper.js.map +1 -0
  562. package/dist/components/StickyContainer.d.ts +32 -0
  563. package/dist/components/StickyContainer.d.ts.map +1 -0
  564. package/dist/components/StickyContainer.js +17 -0
  565. package/dist/components/StickyContainer.js.map +1 -0
  566. package/dist/components/Switch.d.ts +12 -0
  567. package/dist/components/Switch.d.ts.map +1 -0
  568. package/dist/components/Switch.js +46 -0
  569. package/dist/components/Switch.js.map +1 -0
  570. package/dist/components/Table.d.ts +22 -0
  571. package/dist/components/Table.d.ts.map +1 -0
  572. package/dist/components/Table.js +72 -0
  573. package/dist/components/Table.js.map +1 -0
  574. package/dist/components/Tabs.d.ts +29 -0
  575. package/dist/components/Tabs.d.ts.map +1 -0
  576. package/dist/components/Tabs.js +63 -0
  577. package/dist/components/Tabs.js.map +1 -0
  578. package/dist/components/Tag.d.ts +14 -0
  579. package/dist/components/Tag.d.ts.map +1 -0
  580. package/dist/components/Tag.js +44 -0
  581. package/dist/components/Tag.js.map +1 -0
  582. package/dist/components/TagsInput.d.ts +15 -0
  583. package/dist/components/TagsInput.d.ts.map +1 -0
  584. package/dist/components/TagsInput.js +54 -0
  585. package/dist/components/TagsInput.js.map +1 -0
  586. package/dist/components/Text.d.ts +21 -0
  587. package/dist/components/Text.d.ts.map +1 -0
  588. package/dist/components/Text.js +47 -0
  589. package/dist/components/Text.js.map +1 -0
  590. package/dist/components/Textarea.d.ts +6 -0
  591. package/dist/components/Textarea.d.ts.map +1 -0
  592. package/dist/components/Textarea.js +10 -0
  593. package/dist/components/Textarea.js.map +1 -0
  594. package/dist/components/ThemeToggle.d.ts +22 -0
  595. package/dist/components/ThemeToggle.d.ts.map +1 -0
  596. package/dist/components/ThemeToggle.js +81 -0
  597. package/dist/components/ThemeToggle.js.map +1 -0
  598. package/dist/components/TimePicker.d.ts +15 -0
  599. package/dist/components/TimePicker.d.ts.map +1 -0
  600. package/dist/components/TimePicker.js +148 -0
  601. package/dist/components/TimePicker.js.map +1 -0
  602. package/dist/components/Timeline.d.ts +21 -0
  603. package/dist/components/Timeline.d.ts.map +1 -0
  604. package/dist/components/Timeline.js +63 -0
  605. package/dist/components/Timeline.js.map +1 -0
  606. package/dist/components/Title.d.ts +17 -0
  607. package/dist/components/Title.d.ts.map +1 -0
  608. package/dist/components/Title.js +46 -0
  609. package/dist/components/Title.js.map +1 -0
  610. package/dist/components/Toast.d.ts +25 -0
  611. package/dist/components/Toast.d.ts.map +1 -0
  612. package/dist/components/Toast.js +96 -0
  613. package/dist/components/Toast.js.map +1 -0
  614. package/dist/components/Tooltip.d.ts +13 -0
  615. package/dist/components/Tooltip.d.ts.map +1 -0
  616. package/dist/components/Tooltip.js +20 -0
  617. package/dist/components/Tooltip.js.map +1 -0
  618. package/dist/components/TopActionBar.d.ts +60 -0
  619. package/dist/components/TopActionBar.d.ts.map +1 -0
  620. package/dist/components/TopActionBar.js +69 -0
  621. package/dist/components/TopActionBar.js.map +1 -0
  622. package/dist/components/TreeView.d.ts +29 -0
  623. package/dist/components/TreeView.d.ts.map +1 -0
  624. package/dist/components/TreeView.js +97 -0
  625. package/dist/components/TreeView.js.map +1 -0
  626. package/dist/components/TwoFactorAuth.d.ts +12 -0
  627. package/dist/components/TwoFactorAuth.d.ts.map +1 -0
  628. package/dist/components/TwoFactorAuth.js +48 -0
  629. package/dist/components/TwoFactorAuth.js.map +1 -0
  630. package/dist/components/VideoPlayer.d.ts +11 -0
  631. package/dist/components/VideoPlayer.d.ts.map +1 -0
  632. package/dist/components/VideoPlayer.js +132 -0
  633. package/dist/components/VideoPlayer.js.map +1 -0
  634. package/dist/components/VoiceRecorder.d.ts +11 -0
  635. package/dist/components/VoiceRecorder.d.ts.map +1 -0
  636. package/dist/components/VoiceRecorder.js +145 -0
  637. package/dist/components/VoiceRecorder.js.map +1 -0
  638. package/dist/components/WindowControls.d.ts +10 -0
  639. package/dist/components/WindowControls.d.ts.map +1 -0
  640. package/dist/components/WindowControls.js +18 -0
  641. package/dist/components/WindowControls.js.map +1 -0
  642. package/dist/components/WindowFrame.d.ts +11 -0
  643. package/dist/components/WindowFrame.d.ts.map +1 -0
  644. package/dist/components/WindowFrame.js +26 -0
  645. package/dist/components/WindowFrame.js.map +1 -0
  646. package/dist/globals.css +316 -0
  647. package/dist/index.d.ts +249 -0
  648. package/dist/index.d.ts.map +1 -0
  649. package/dist/index.js +144 -0
  650. package/dist/index.js.map +1 -0
  651. package/dist/lib/utils.d.ts +3 -0
  652. package/dist/lib/utils.d.ts.map +1 -0
  653. package/dist/lib/utils.js +6 -0
  654. package/dist/lib/utils.js.map +1 -0
  655. package/dist/scripts/build-registry.d.ts +2 -0
  656. package/dist/scripts/build-registry.d.ts.map +1 -0
  657. package/dist/scripts/build-registry.js +58 -0
  658. package/dist/scripts/build-registry.js.map +1 -0
  659. package/dist/tokens.d.ts +281 -0
  660. package/dist/tokens.d.ts.map +1 -0
  661. package/dist/tokens.js +265 -0
  662. package/dist/tokens.js.map +1 -0
  663. package/dist/tsconfig.build.tsbuildinfo +1 -0
  664. package/package.json +118 -0
@@ -0,0 +1,95 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import { motion, AnimatePresence } from 'framer-motion';
4
+ import { cn } from '../lib/utils';
5
+ export const NavigationDrawer = React.forwardRef(({ isOpen, onClose, position = 'left', sections = [], header, footer, width = 'md', showBackdrop = true, closeOnBackdropClick = true, belowNavBar = false, navBarHeight = 56, className = '', ...props }, ref) => {
6
+ const widthStyles = {
7
+ sm: 'w-64',
8
+ md: 'w-80',
9
+ lg: 'w-96',
10
+ };
11
+ const slideVariants = {
12
+ left: {
13
+ hidden: { x: '-100%' },
14
+ visible: { x: 0 },
15
+ exit: { x: '-100%' },
16
+ },
17
+ right: {
18
+ hidden: { x: '100%' },
19
+ visible: { x: 0 },
20
+ exit: { x: '100%' },
21
+ },
22
+ };
23
+ const backdropVariants = {
24
+ hidden: { opacity: 0 },
25
+ visible: { opacity: 1 },
26
+ exit: { opacity: 0 },
27
+ };
28
+ const baseDrawerStyles = `
29
+ fixed ${position === 'left' ? 'left-0' : 'right-0'}
30
+ ${widthStyles[width]}
31
+ bg-surface-primary
32
+ shadow-xl
33
+ flex flex-col
34
+ ${belowNavBar ? 'z-dropdown' : 'z-modal'}
35
+ `;
36
+ const backdropClass = cn('fixed bg-black/40 backdrop-blur-sm', belowNavBar ? 'z-dropdown' : 'z-modal', !belowNavBar && 'inset-0');
37
+ const drawerStyle = belowNavBar
38
+ ? {
39
+ top: `${navBarHeight}px`,
40
+ height: `calc(100vh - ${navBarHeight}px)`,
41
+ }
42
+ : {
43
+ top: 0,
44
+ height: '100vh',
45
+ };
46
+ const backdropStyle = belowNavBar
47
+ ? {
48
+ top: `${navBarHeight}px`,
49
+ left: 0,
50
+ right: 0,
51
+ bottom: 0,
52
+ }
53
+ : {};
54
+ const itemBase = `
55
+ flex items-center justify-between gap-3 px-4 py-3 rounded-md text-sm font-medium
56
+ transition-apple focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-accent-blue
57
+ cursor-pointer
58
+ `;
59
+ const itemActive = `text-text-primary bg-accent-blue/10 border-l-2 border-accent-blue`;
60
+ const itemInactive = `text-text-secondary hover:bg-surface-secondary hover:text-text-primary`;
61
+ const handleBackdropClick = () => {
62
+ if (closeOnBackdropClick) {
63
+ onClose();
64
+ }
65
+ };
66
+ // Lock body scroll when drawer is open
67
+ React.useEffect(() => {
68
+ if (isOpen) {
69
+ document.body.style.overflow = 'hidden';
70
+ }
71
+ else {
72
+ document.body.style.overflow = '';
73
+ }
74
+ return () => {
75
+ document.body.style.overflow = '';
76
+ };
77
+ }, [isOpen]);
78
+ // Handle escape key
79
+ React.useEffect(() => {
80
+ const handleEscape = (e) => {
81
+ if (e.key === 'Escape' && isOpen) {
82
+ onClose();
83
+ }
84
+ };
85
+ document.addEventListener('keydown', handleEscape);
86
+ return () => document.removeEventListener('keydown', handleEscape);
87
+ }, [isOpen, onClose]);
88
+ return (_jsx(AnimatePresence, { children: isOpen && (_jsxs(_Fragment, { children: [showBackdrop && (_jsx(motion.div, { className: backdropClass, style: backdropStyle, variants: backdropVariants, initial: "hidden", animate: "visible", exit: "exit", transition: { duration: 0.2 }, onClick: handleBackdropClick, "aria-hidden": "true" })), _jsxs(motion.div, { ref: ref, className: cn(baseDrawerStyles, className), style: drawerStyle, variants: slideVariants[position], initial: "hidden", animate: "visible", exit: "exit", transition: { type: 'spring', stiffness: 300, damping: 30 }, role: "dialog", "aria-modal": "true", ...props, children: [header && (_jsx("div", { className: "flex-shrink-0 px-4 py-4 border-b border-border-primary", children: header })), _jsx("div", { className: "flex-1 overflow-y-auto px-2 py-4", children: sections.map((section, sectionIdx) => (_jsxs("div", { className: "mb-6 last:mb-0", children: [section.title && (_jsx("h3", { className: "px-4 mb-2 text-xs font-semibold text-text-tertiary uppercase tracking-wide", children: section.title })), _jsx("nav", { className: "space-y-1", children: section.items.map((item, itemIdx) => {
89
+ const Component = item.href ? 'a' : 'button';
90
+ const isActive = !!item.active;
91
+ return (_jsxs(Component, { href: item.href, onClick: item.onClick, className: cn(itemBase, isActive ? itemActive : itemInactive), children: [_jsxs("div", { className: "flex items-center gap-3", children: [item.icon && (_jsx("span", { className: "inline-flex flex-shrink-0", children: item.icon })), _jsx("span", { children: item.label })] }), item.badge && (_jsx("span", { className: "inline-flex items-center justify-center px-2 py-0.5 text-xs font-semibold rounded-full bg-accent-blue text-white", children: item.badge }))] }, itemIdx));
92
+ }) })] }, sectionIdx))) }), footer && (_jsx("div", { className: "flex-shrink-0 px-4 py-4 border-t border-border-primary", children: footer }))] })] })) }));
93
+ });
94
+ NavigationDrawer.displayName = 'NavigationDrawer';
95
+ //# sourceMappingURL=NavigationDrawer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NavigationDrawer.js","sourceRoot":"","sources":["../../components/NavigationDrawer.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,25 @@
1
+ import React from 'react';
2
+ export type NotificationType = 'info' | 'success' | 'warning' | 'error';
3
+ export interface Notification {
4
+ id: string;
5
+ title: string;
6
+ message?: string;
7
+ type?: NotificationType;
8
+ timestamp: string;
9
+ read?: boolean;
10
+ action?: {
11
+ label: string;
12
+ onClick: () => void;
13
+ };
14
+ icon?: React.ReactNode;
15
+ }
16
+ export interface NotificationCenterPanelProps extends React.HTMLAttributes<HTMLDivElement> {
17
+ notifications: Notification[];
18
+ onNotificationClick?: (notification: Notification) => void;
19
+ onMarkAllRead?: () => void;
20
+ onClearAll?: () => void;
21
+ onDismiss?: (notification: Notification) => void;
22
+ className?: string;
23
+ }
24
+ export declare const NotificationCenterPanel: React.ForwardRefExoticComponent<NotificationCenterPanelProps & React.RefAttributes<HTMLDivElement>>;
25
+ //# sourceMappingURL=NotificationCenterPanel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NotificationCenterPanel.d.ts","sourceRoot":"","sources":["../../components/NotificationCenterPanel.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAWxC,MAAM,MAAM,gBAAgB,GAAG,MAAM,GAAG,SAAS,GAAG,SAAS,GAAG,OAAO,CAAC;AAExE,MAAM,WAAW,YAAY;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,gBAAgB,CAAC;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,MAAM,CAAC,EAAE;QACL,KAAK,EAAE,MAAM,CAAC;QACd,OAAO,EAAE,MAAM,IAAI,CAAC;KACvB,CAAC;IACF,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC1B;AAED,MAAM,WAAW,4BAA6B,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACtF,aAAa,EAAE,YAAY,EAAE,CAAC;IAC9B,mBAAmB,CAAC,EAAE,CAAC,YAAY,EAAE,YAAY,KAAK,IAAI,CAAC;IAC3D,aAAa,CAAC,EAAE,MAAM,IAAI,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,IAAI,CAAC;IACxB,SAAS,CAAC,EAAE,CAAC,YAAY,EAAE,YAAY,KAAK,IAAI,CAAC;IACjD,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAoCD,eAAO,MAAM,uBAAuB,qGAkJnC,CAAC"}
@@ -0,0 +1,50 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import React from 'react';
4
+ import { cn } from '../lib/utils';
5
+ import { motion } from 'framer-motion';
6
+ import { X, Bell, CheckCircle2, AlertCircle, Info, XCircle } from 'lucide-react';
7
+ import { Button } from './Button';
8
+ import { Badge } from './Badge';
9
+ /* ========================================
10
+ HELPERS
11
+ ======================================== */
12
+ const getTypeIcon = (type) => {
13
+ switch (type) {
14
+ case 'success':
15
+ return _jsx(CheckCircle2, { className: "w-5 h-5 text-status-success" });
16
+ case 'warning':
17
+ return _jsx(AlertCircle, { className: "w-5 h-5 text-status-warning" });
18
+ case 'error':
19
+ return _jsx(XCircle, { className: "w-5 h-5 text-status-error" });
20
+ default:
21
+ return _jsx(Info, { className: "w-5 h-5 text-accent-blue" });
22
+ }
23
+ };
24
+ const getTypeStyles = (type) => {
25
+ switch (type) {
26
+ case 'success':
27
+ return 'border-status-success/20 bg-status-success/5';
28
+ case 'warning':
29
+ return 'border-status-warning/20 bg-status-warning/5';
30
+ case 'error':
31
+ return 'border-status-error/20 bg-status-error/5';
32
+ default:
33
+ return 'border-border-primary bg-surface-primary';
34
+ }
35
+ };
36
+ /* ========================================
37
+ COMPONENT
38
+ ======================================== */
39
+ export const NotificationCenterPanel = React.forwardRef(({ notifications, onNotificationClick, onMarkAllRead, onClearAll, onDismiss, className, ...props }, ref) => {
40
+ const unreadCount = notifications.filter(n => !n.read).length;
41
+ return (_jsxs("div", { ref: ref, className: cn("w-full max-w-md bg-surface-primary border border-border-primary rounded-2xl shadow-xl overflow-hidden", className), ...props, children: [_jsxs("div", { className: "flex items-center justify-between px-6 py-4 border-b border-border-primary", children: [_jsxs("div", { className: "flex items-center gap-3", children: [_jsx(Bell, { className: "w-5 h-5 text-text-primary" }), _jsx("h2", { className: "text-lg font-semibold text-text-primary", children: "Notifications" }), unreadCount > 0 && (_jsx(Badge, { variant: "error", size: "sm", children: unreadCount }))] }), _jsxs("div", { className: "flex items-center gap-2", children: [onMarkAllRead && unreadCount > 0 && (_jsx(Button, { variant: "ghost", size: "sm", onClick: onMarkAllRead, children: "Mark all read" })), onClearAll && notifications.length > 0 && (_jsx(Button, { variant: "ghost", size: "sm", onClick: onClearAll, children: "Clear all" }))] })] }), _jsx("div", { className: "max-h-[600px] overflow-y-auto", children: notifications.length === 0 ? (_jsxs("div", { className: "flex flex-col items-center justify-center py-12 px-6 text-center", children: [_jsx(Bell, { className: "w-12 h-12 text-text-tertiary mb-3" }), _jsx("p", { className: "text-sm font-medium text-text-primary mb-1", children: "No notifications" }), _jsx("p", { className: "text-xs text-text-secondary", children: "You're all caught up!" })] })) : (_jsx("div", { className: "divide-y divide-border-primary", children: notifications.map((notification, index) => (_jsx(motion.div, { initial: { opacity: 0, x: -10 }, animate: { opacity: 1, x: 0 }, transition: { delay: index * 0.05 }, className: cn("relative px-6 py-4 transition-colors", !notification.read && "bg-accent-blue/5", "hover:bg-surface-secondary/50"), onClick: () => onNotificationClick?.(notification), children: _jsxs("div", { className: "flex items-start gap-3", children: [_jsx("div", { className: "flex-shrink-0 mt-0.5", children: notification.icon || getTypeIcon(notification.type) }), _jsxs("div", { className: "flex-1 min-w-0", children: [_jsxs("div", { className: "flex items-start justify-between gap-2 mb-1", children: [_jsx("h3", { className: cn("text-sm font-semibold", notification.read ? "text-text-secondary" : "text-text-primary"), children: notification.title }), !notification.read && (_jsx("div", { className: "w-2 h-2 bg-accent-blue rounded-full flex-shrink-0 mt-1.5" }))] }), notification.message && (_jsx("p", { className: "text-xs text-text-secondary mb-2 line-clamp-2", children: notification.message })), _jsxs("div", { className: "flex items-center justify-between", children: [_jsx("span", { className: "text-xs text-text-tertiary", children: notification.timestamp }), notification.action && (_jsx(Button, { variant: "ghost", size: "sm", onClick: (e) => {
42
+ e.stopPropagation();
43
+ notification.action?.onClick();
44
+ }, children: notification.action.label }))] })] }), onDismiss && (_jsx(Button, { variant: "ghost", size: "sm", onClick: (e) => {
45
+ e.stopPropagation();
46
+ onDismiss(notification);
47
+ }, className: "flex-shrink-0", children: _jsx(X, { className: "w-4 h-4" }) }))] }) }, notification.id))) })) })] }));
48
+ });
49
+ NotificationCenterPanel.displayName = 'NotificationCenterPanel';
50
+ //# sourceMappingURL=NotificationCenterPanel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NotificationCenterPanel.js","sourceRoot":"","sources":["../../components/NotificationCenterPanel.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import React from 'react';
2
+ export interface OTPInputProps {
3
+ length?: number;
4
+ value?: string;
5
+ onChange?: (value: string) => void;
6
+ onComplete?: (value: string) => void;
7
+ disabled?: boolean;
8
+ error?: boolean;
9
+ separator?: React.ReactNode;
10
+ groupSize?: number;
11
+ className?: string;
12
+ autoFocus?: boolean;
13
+ }
14
+ export declare const OTPInput: React.FC<OTPInputProps>;
15
+ //# sourceMappingURL=OTPInput.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OTPInput.d.ts","sourceRoot":"","sources":["../../components/OTPInput.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAsC,MAAM,OAAO,CAAC;AAQ3D,MAAM,WAAW,aAAa;IAC1B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACrC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,SAAS,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,OAAO,CAAC;CACvB;AAMD,eAAO,MAAM,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CA4L5C,CAAC"}
@@ -0,0 +1,144 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React, { useRef, useState, useEffect } from 'react';
3
+ import { motion } from 'framer-motion';
4
+ import { cn } from '../lib/utils';
5
+ /* ========================================
6
+ OTP INPUT COMPONENT
7
+ ======================================== */
8
+ export const OTPInput = ({ length = 6, value = '', onChange, onComplete, disabled = false, error = false, separator = _jsx("span", { className: "text-text-tertiary font-bold", children: "-" }), groupSize = 3, className, autoFocus = false, }) => {
9
+ const inputRefs = useRef([]);
10
+ // Initialize state
11
+ const [values, setValues] = useState(() => {
12
+ const initialValues = Array(length).fill('');
13
+ if (value) {
14
+ const chars = value.split('');
15
+ chars.forEach((char, i) => {
16
+ if (i < length)
17
+ initialValues[i] = char;
18
+ });
19
+ }
20
+ return initialValues;
21
+ });
22
+ // Sync with external value
23
+ useEffect(() => {
24
+ if (value !== undefined) {
25
+ const newValues = Array(length).fill('');
26
+ const chars = value.split('');
27
+ chars.forEach((char, i) => {
28
+ if (i < length)
29
+ newValues[i] = char;
30
+ });
31
+ setValues(newValues);
32
+ }
33
+ }, [value, length]);
34
+ // Auto focus first input
35
+ useEffect(() => {
36
+ if (autoFocus && !disabled) {
37
+ inputRefs.current[0]?.focus();
38
+ }
39
+ }, [autoFocus, disabled]);
40
+ const focusInput = (index) => {
41
+ if (inputRefs.current[index]) {
42
+ inputRefs.current[index]?.focus();
43
+ }
44
+ };
45
+ const handleChange = (index, e) => {
46
+ const val = e.target.value;
47
+ // Only allow numbers
48
+ if (!/^\d*$/.test(val))
49
+ return;
50
+ let newValues = [...values];
51
+ // Handle paste or multi-char input
52
+ if (val.length > 1) {
53
+ const chars = val.split('').filter(c => /\d/.test(c));
54
+ let currentIndex = index;
55
+ chars.forEach((char) => {
56
+ if (currentIndex < length) {
57
+ newValues[currentIndex] = char;
58
+ currentIndex++;
59
+ }
60
+ });
61
+ setValues(newValues);
62
+ const newValueString = newValues.join('');
63
+ onChange?.(newValueString);
64
+ if (newValueString.length === length) {
65
+ onComplete?.(newValueString);
66
+ inputRefs.current[length - 1]?.blur();
67
+ }
68
+ else {
69
+ focusInput(Math.min(currentIndex, length - 1));
70
+ }
71
+ return;
72
+ }
73
+ // Handle single char
74
+ newValues[index] = val;
75
+ setValues(newValues);
76
+ const newValueString = newValues.join('');
77
+ onChange?.(newValueString);
78
+ if (val && index < length - 1) {
79
+ focusInput(index + 1);
80
+ }
81
+ if (newValueString.length === length) {
82
+ onComplete?.(newValueString);
83
+ if (index === length - 1) {
84
+ inputRefs.current[index]?.blur();
85
+ }
86
+ }
87
+ };
88
+ const handleKeyDown = (index, e) => {
89
+ if (e.key === 'Backspace') {
90
+ e.preventDefault();
91
+ if (values[index]) {
92
+ const newValues = [...values];
93
+ newValues[index] = '';
94
+ setValues(newValues);
95
+ onChange?.(newValues.join(''));
96
+ }
97
+ else if (index > 0) {
98
+ const newValues = [...values];
99
+ newValues[index - 1] = '';
100
+ setValues(newValues);
101
+ onChange?.(newValues.join(''));
102
+ focusInput(index - 1);
103
+ }
104
+ }
105
+ else if (e.key === 'ArrowLeft' && index > 0) {
106
+ e.preventDefault();
107
+ focusInput(index - 1);
108
+ }
109
+ else if (e.key === 'ArrowRight' && index < length - 1) {
110
+ e.preventDefault();
111
+ focusInput(index + 1);
112
+ }
113
+ };
114
+ const handlePaste = (e) => {
115
+ e.preventDefault();
116
+ const pastedData = e.clipboardData.getData('text');
117
+ const chars = pastedData.split('').filter(c => /\d/.test(c));
118
+ const newValues = [...values];
119
+ let currentIndex = 0;
120
+ chars.forEach((char) => {
121
+ if (currentIndex < length) {
122
+ newValues[currentIndex] = char;
123
+ currentIndex++;
124
+ }
125
+ });
126
+ setValues(newValues);
127
+ const newValueString = newValues.join('');
128
+ onChange?.(newValueString);
129
+ if (newValueString.length === length) {
130
+ onComplete?.(newValueString);
131
+ inputRefs.current[length - 1]?.blur();
132
+ }
133
+ else {
134
+ focusInput(Math.min(currentIndex, length - 1));
135
+ }
136
+ };
137
+ return (_jsx("div", { className: cn("flex items-center gap-2", className), children: Array.from({ length }).map((_, index) => (_jsxs(React.Fragment, { children: [index > 0 && index % groupSize === 0 && separator, _jsx(motion.div, { whileFocus: { scale: 1.05, y: -2 }, transition: { type: 'spring', stiffness: 300, damping: 30 }, children: _jsx("input", { ref: (el) => {
138
+ inputRefs.current[index] = el;
139
+ }, type: "text", inputMode: "numeric", maxLength: 1, value: values[index], onChange: (e) => handleChange(index, e), onKeyDown: (e) => handleKeyDown(index, e), onPaste: handlePaste, disabled: disabled, className: cn("w-12 h-14 text-2xl text-center font-semibold rounded-xl border bg-surface-primary text-text-primary transition-all shadow-sm", "focus:outline-none focus:ring-4 focus:ring-accent-blue/10 focus:border-accent-blue", "disabled:opacity-50 disabled:cursor-not-allowed disabled:bg-surface-secondary", error
140
+ ? "border-status-error text-status-error focus:border-status-error focus:ring-status-error/10"
141
+ : "border-border-primary") }) })] }, index))) }));
142
+ };
143
+ OTPInput.displayName = 'OTPInput';
144
+ //# sourceMappingURL=OTPInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OTPInput.js","sourceRoot":"","sources":["../../components/OTPInput.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,36 @@
1
+ import React from 'react';
2
+ export interface OfflineStateProps {
3
+ /**
4
+ * Title of the offline state
5
+ * @default "No Internet Connection"
6
+ */
7
+ title?: string;
8
+ /**
9
+ * Description text
10
+ * @default "Please check your network settings and try again."
11
+ */
12
+ description?: string;
13
+ /**
14
+ * Callback function when the retry button is clicked
15
+ */
16
+ onRetry?: () => void;
17
+ /**
18
+ * Whether the retry action is currently in progress
19
+ */
20
+ isRetrying?: boolean;
21
+ /**
22
+ * Whether to display as a full page overlay
23
+ * @default false
24
+ */
25
+ fullPage?: boolean;
26
+ /**
27
+ * Custom class name
28
+ */
29
+ className?: string;
30
+ /**
31
+ * Custom icon to display
32
+ */
33
+ icon?: React.ReactNode;
34
+ }
35
+ export declare const OfflineState: React.FC<OfflineStateProps>;
36
+ //# sourceMappingURL=OfflineState.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OfflineState.d.ts","sourceRoot":"","sources":["../../components/OfflineState.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAK1B,MAAM,WAAW,iBAAiB;IAC9B;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IACf;;;OAGG;IACH,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB;;OAEG;IACH,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB;;OAEG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB;;;OAGG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB;;OAEG;IACH,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC1B;AAED,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAiEpD,CAAC"}
@@ -0,0 +1,21 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { motion } from 'framer-motion';
3
+ import { WifiOff, RefreshCw } from 'lucide-react';
4
+ import { Button } from './Button';
5
+ export const OfflineState = ({ title = "No Internet Connection", description = "Please check your network settings and try again.", onRetry, isRetrying = false, fullPage = false, className = '', icon, }) => {
6
+ const containerClasses = `
7
+ flex flex-col items-center justify-center text-center p-8
8
+ ${fullPage ? 'fixed inset-0 z-50 bg-background-primary/95 backdrop-blur-sm' : 'w-full h-full bg-surface-primary rounded-2xl'}
9
+ ${className}
10
+ `.trim().replace(/\s+/g, ' ');
11
+ return (_jsx("div", { className: containerClasses, children: _jsxs(motion.div, { initial: { opacity: 0, scale: 0.95 }, animate: { opacity: 1, scale: 1 }, transition: { duration: 0.4, ease: [0.16, 1, 0.3, 1] }, className: "max-w-md mx-auto flex flex-col items-center", children: [_jsxs("div", { className: "mb-6 relative", children: [_jsx(motion.div, { className: "absolute inset-0 bg-status-error/10 rounded-full blur-xl", animate: {
12
+ opacity: [0.3, 0.6, 0.3],
13
+ scale: [1, 1.1, 1]
14
+ }, transition: {
15
+ duration: 3,
16
+ repeat: Infinity,
17
+ ease: "easeInOut"
18
+ } }), _jsx("div", { className: "relative bg-surface-secondary p-5 rounded-full", children: icon || _jsx(WifiOff, { className: "w-10 h-10 text-text-secondary", strokeWidth: 1.5 }) })] }), _jsx("h3", { className: "text-xl font-semibold text-text-primary mb-2", children: title }), _jsx("p", { className: "text-text-secondary mb-8 leading-relaxed", children: description }), onRetry && (_jsx(Button, { variant: "primary", onClick: onRetry, loading: isRetrying, leftIcon: !isRetrying ? _jsx(RefreshCw, { size: 16 }) : undefined, children: "Try Again" }))] }) }));
19
+ };
20
+ OfflineState.displayName = 'OfflineState';
21
+ //# sourceMappingURL=OfflineState.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OfflineState.js","sourceRoot":"","sources":["../../components/OfflineState.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAoClC,MAAM,CAAC,MAAM,YAAY,GAAgC,CAAC,EACtD,KAAK,GAAG,wBAAwB,EAChC,WAAW,GAAG,mDAAmD,EACjE,OAAO,EACP,UAAU,GAAG,KAAK,EAClB,QAAQ,GAAG,KAAK,EAChB,SAAS,GAAG,EAAE,EACd,IAAI,GACP,EAAE,EAAE;IACD,MAAM,gBAAgB,GAAG;;MAEvB,QAAQ,CAAC,CAAC,CAAC,8DAA8D,CAAC,CAAC,CAAC,8CAA8C;MAC1H,SAAS;GACZ,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAE5B,OAAO,CACH,cAAK,SAAS,EAAE,gBAAgB,YAC5B,MAAC,MAAM,CAAC,GAAG,IACP,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,EACpC,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,EACjC,UAAU,EAAE,EAAE,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,EACtD,SAAS,EAAC,6CAA6C,aAGvD,eAAK,SAAS,EAAC,eAAe,aAC1B,KAAC,MAAM,CAAC,GAAG,IACP,SAAS,EAAC,0DAA0D,EACpE,OAAO,EAAE;gCACL,OAAO,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC;gCACxB,KAAK,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;6BACrB,EACD,UAAU,EAAE;gCACR,QAAQ,EAAE,CAAC;gCACX,MAAM,EAAE,QAAQ;gCAChB,IAAI,EAAE,WAAW;6BACpB,GACH,EACF,cAAK,SAAS,EAAC,gDAAgD,YAC1D,IAAI,IAAI,KAAC,OAAO,IAAC,SAAS,EAAC,+BAA+B,EAAC,WAAW,EAAE,GAAG,GAAI,GAC9E,IACJ,EAGN,aAAI,SAAS,EAAC,8CAA8C,YACvD,KAAK,GACL,EAEL,YAAG,SAAS,EAAC,0CAA0C,YAClD,WAAW,GACZ,EAGH,OAAO,IAAI,CACR,KAAC,MAAM,IACH,OAAO,EAAC,SAAS,EACjB,OAAO,EAAE,OAAO,EAChB,OAAO,EAAE,UAAU,EACnB,QAAQ,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,KAAC,SAAS,IAAC,IAAI,EAAE,EAAE,GAAI,CAAC,CAAC,CAAC,SAAS,0BAGtD,CACZ,IACQ,GACX,CACT,CAAC;AACN,CAAC,CAAC;AAEF,YAAY,CAAC,WAAW,GAAG,cAAc,CAAC"}
@@ -0,0 +1,19 @@
1
+ import React from 'react';
2
+ export interface OrderItem {
3
+ id: string;
4
+ name: string;
5
+ price: number;
6
+ quantity: number;
7
+ image: string;
8
+ variant?: string;
9
+ }
10
+ export interface OrderSummaryProps {
11
+ items: OrderItem[];
12
+ currency?: string;
13
+ discountAmount?: number;
14
+ shippingCost?: number;
15
+ taxAmount?: number;
16
+ className?: string;
17
+ }
18
+ export declare const OrderSummary: React.FC<OrderSummaryProps>;
19
+ //# sourceMappingURL=OrderSummary.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OrderSummary.d.ts","sourceRoot":"","sources":["../../components/OrderSummary.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,MAAM,WAAW,SAAS;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,iBAAiB;IAC9B,KAAK,EAAE,SAAS,EAAE,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAsHpD,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { ShoppingBag } from 'lucide-react';
3
+ export const OrderSummary = ({ items, currency = '$', discountAmount = 0, shippingCost = 0, taxAmount = 0, className = '', }) => {
4
+ const subtotal = items.reduce((sum, item) => sum + item.price * item.quantity, 0);
5
+ const total = subtotal - discountAmount + shippingCost + taxAmount;
6
+ return (_jsxs("div", { className: `bg-surface-primary border border-border-primary rounded-2xl overflow-hidden shadow-sm ${className}`, children: [_jsx("div", { className: "p-6 border-b border-border-primary bg-background-secondary/30", children: _jsxs("div", { className: "flex items-center gap-3", children: [_jsx("div", { className: "w-10 h-10 rounded-xl bg-accent-blue/10 flex items-center justify-center", children: _jsx(ShoppingBag, { className: "w-5 h-5 text-accent-blue" }) }), _jsxs("div", { children: [_jsx("h2", { className: "text-lg font-bold text-text-primary", children: "Order Summary" }), _jsxs("p", { className: "text-sm text-text-secondary", children: [items.length, " ", items.length === 1 ? 'item' : 'items'] })] })] }) }), _jsxs("div", { className: "p-6", children: [_jsx("div", { className: "space-y-6 mb-8", children: items.map((item) => (_jsxs("div", { className: "flex gap-4 group", children: [_jsxs("div", { className: "relative overflow-hidden rounded-xl border border-border-primary bg-background-tertiary", children: [_jsx("img", { src: item.image, alt: item.name, className: "w-20 h-20 object-cover transform group-hover:scale-105 transition-transform duration-500" }), _jsxs("div", { className: "absolute bottom-0 right-0 bg-surface-primary/90 backdrop-blur-sm px-2 py-0.5 rounded-tl-lg border-t border-l border-border-primary text-xs font-medium text-text-secondary", children: ["x", item.quantity] })] }), _jsxs("div", { className: "flex-1 min-w-0 py-1", children: [_jsxs("div", { className: "flex justify-between items-start gap-4", children: [_jsxs("div", { className: "space-y-1", children: [_jsx("h3", { className: "font-semibold text-text-primary text-sm leading-tight", children: item.name }), item.variant && (_jsx("p", { className: "text-xs text-text-tertiary inline-flex items-center px-2 py-0.5 rounded-md bg-background-secondary border border-border-primary", children: item.variant }))] }), _jsxs("p", { className: "font-semibold text-text-primary text-sm whitespace-nowrap", children: [currency, (item.price * item.quantity).toFixed(2)] })] }), item.quantity > 1 && (_jsxs("p", { className: "text-xs text-text-tertiary mt-2", children: [currency, item.price.toFixed(2), " each"] }))] })] }, item.id))) }), _jsxs("div", { className: "space-y-3 pt-6 border-t border-border-dashed", children: [_jsxs("div", { className: "flex justify-between text-sm", children: [_jsx("span", { className: "text-text-secondary", children: "Subtotal" }), _jsxs("span", { className: "font-medium text-text-primary", children: [currency, subtotal.toFixed(2)] })] }), discountAmount > 0 && (_jsxs("div", { className: "flex justify-between text-sm", children: [_jsx("span", { className: "text-text-secondary", children: "Discount" }), _jsxs("span", { className: "font-medium text-status-success bg-status-success/10 px-2 py-0.5 rounded-md", children: ["-", currency, discountAmount.toFixed(2)] })] })), _jsxs("div", { className: "flex justify-between text-sm", children: [_jsx("span", { className: "text-text-secondary", children: "Shipping" }), _jsx("span", { className: `font-medium ${shippingCost === 0 ? 'text-status-success' : 'text-text-primary'}`, children: shippingCost === 0 ? 'Free' : `${currency}${shippingCost.toFixed(2)}` })] }), taxAmount > 0 && (_jsxs("div", { className: "flex justify-between text-sm", children: [_jsx("span", { className: "text-text-secondary", children: "Tax" }), _jsxs("span", { className: "font-medium text-text-primary", children: [currency, taxAmount.toFixed(2)] })] })), _jsxs("div", { className: "flex justify-between items-baseline pt-4 mt-4 border-t border-border-primary", children: [_jsx("span", { className: "text-base font-semibold text-text-primary", children: "Total" }), _jsxs("span", { className: "text-2xl font-bold text-text-primary tracking-tight", children: [currency, total.toFixed(2)] })] })] })] })] }));
7
+ };
8
+ //# sourceMappingURL=OrderSummary.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OrderSummary.js","sourceRoot":"","sources":["../../components/OrderSummary.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,28 @@
1
+ import React from 'react';
2
+ import { HTMLMotionProps } from 'framer-motion';
3
+ /**
4
+ * Pagination component – Apple-style page navigation.
5
+ *
6
+ * Designed to follow the Apple‑style design system tokens.
7
+ * Features smooth transitions, hover states, and responsive design.
8
+ */
9
+ export interface PaginationProps extends Omit<HTMLMotionProps<'nav'>, 'children'> {
10
+ /** Current active page (1-indexed) */
11
+ currentPage: number;
12
+ /** Total number of pages */
13
+ totalPages: number;
14
+ /** Callback when page changes */
15
+ onPageChange: (page: number) => void;
16
+ /** Number of page buttons to show around current page */
17
+ siblingCount?: number;
18
+ /** Show first/last page buttons */
19
+ showFirstLast?: boolean;
20
+ /** Show previous/next buttons */
21
+ showPrevNext?: boolean;
22
+ /** Optional className for custom styling */
23
+ className?: string;
24
+ /** Size variant */
25
+ size?: 'sm' | 'md' | 'lg';
26
+ }
27
+ export declare const Pagination: React.ForwardRefExoticComponent<Omit<PaginationProps, "ref"> & React.RefAttributes<HTMLDivElement>>;
28
+ //# sourceMappingURL=Pagination.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Pagination.d.ts","sourceRoot":"","sources":["../../components/Pagination.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAU,eAAe,EAAE,MAAM,eAAe,CAAC;AAGxD;;;;;GAKG;AAEH,MAAM,WAAW,eAAgB,SAAQ,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC;IAC7E,sCAAsC;IACtC,WAAW,EAAE,MAAM,CAAC;IACpB,4BAA4B;IAC5B,UAAU,EAAE,MAAM,CAAC;IACnB,iCAAiC;IACjC,YAAY,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IACrC,yDAAyD;IACzD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,mCAAmC;IACnC,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,iCAAiC;IACjC,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,4CAA4C;IAC5C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,mBAAmB;IACnB,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;CAC7B;AA6DD,eAAO,MAAM,UAAU,qGAkNtB,CAAC"}