@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,213 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useState, useRef, useEffect } from 'react';
3
+ import { motion, AnimatePresence } from 'framer-motion';
4
+ /* ========================================
5
+ UTILITY FUNCTIONS
6
+ ======================================== */
7
+ const formatDate = (date, format = 'medium') => {
8
+ const optionsMap = {
9
+ short: { month: 'numeric', day: 'numeric', year: 'numeric' },
10
+ medium: { month: 'short', day: 'numeric', year: 'numeric' },
11
+ long: { month: 'long', day: 'numeric', year: 'numeric' },
12
+ };
13
+ return new Intl.DateTimeFormat('en-US', optionsMap[format]).format(date);
14
+ };
15
+ const isSameDay = (date1, date2) => {
16
+ return (date1.getFullYear() === date2.getFullYear() &&
17
+ date1.getMonth() === date2.getMonth() &&
18
+ date1.getDate() === date2.getDate());
19
+ };
20
+ const getDaysInMonth = (year, month) => {
21
+ return new Date(year, month + 1, 0).getDate();
22
+ };
23
+ const getFirstDayOfMonth = (year, month) => {
24
+ return new Date(year, month, 1).getDay();
25
+ };
26
+ const isDateDisabled = (date, minDate, maxDate) => {
27
+ if (minDate && date < minDate)
28
+ return true;
29
+ if (maxDate && date > maxDate)
30
+ return true;
31
+ return false;
32
+ };
33
+ /* ========================================
34
+ STYLES
35
+ ======================================== */
36
+ const baseInputStyles = `
37
+ w-full
38
+ bg-surface-primary
39
+ border border-border-primary
40
+ text-text-primary
41
+ placeholder:text-text-tertiary
42
+ transition-apple
43
+ focus:outline-none
44
+ focus:border-accent-blue
45
+ focus:ring-2
46
+ focus:ring-accent-blue/20
47
+ disabled:opacity-40
48
+ disabled:cursor-not-allowed
49
+ cursor-pointer
50
+ `;
51
+ const sizeStyles = {
52
+ sm: 'h-8 px-3 text-sm rounded-lg',
53
+ md: 'h-10 px-4 text-base rounded-xl',
54
+ lg: 'h-12 px-5 text-lg rounded-xl',
55
+ };
56
+ const Calendar = ({ range, onSelectDate, minDate, maxDate, currentMonth, onMonthChange, }) => {
57
+ const [hoveredDate, setHoveredDate] = useState(null);
58
+ const year = currentMonth.getFullYear();
59
+ const month = currentMonth.getMonth();
60
+ const daysInMonth = getDaysInMonth(year, month);
61
+ const firstDay = getFirstDayOfMonth(year, month);
62
+ const today = new Date();
63
+ const days = Array.from({ length: daysInMonth }, (_, i) => i + 1);
64
+ const emptyDays = Array.from({ length: firstDay }, (_, i) => i);
65
+ const monthNames = [
66
+ 'January', 'February', 'March', 'April', 'May', 'June',
67
+ 'July', 'August', 'September', 'October', 'November', 'December'
68
+ ];
69
+ const handlePrevMonth = () => {
70
+ const newDate = new Date(year, month - 1, 1);
71
+ onMonthChange(newDate);
72
+ };
73
+ const handleNextMonth = () => {
74
+ const newDate = new Date(year, month + 1, 1);
75
+ onMonthChange(newDate);
76
+ };
77
+ const handleDayClick = (day) => {
78
+ const date = new Date(year, month, day);
79
+ if (!isDateDisabled(date, minDate, maxDate)) {
80
+ onSelectDate(date);
81
+ }
82
+ };
83
+ const isDateInRange = (date) => {
84
+ if (range.from && range.to) {
85
+ return date >= range.from && date <= range.to;
86
+ }
87
+ if (range.from && hoveredDate) {
88
+ return (date >= range.from && date <= hoveredDate) || (date <= range.from && date >= hoveredDate);
89
+ }
90
+ return false;
91
+ };
92
+ return (_jsx(motion.div, { initial: { opacity: 0, y: -8, scale: 0.96 }, animate: { opacity: 1, y: 0, scale: 1 }, exit: { opacity: 0, y: -8, scale: 0.96 }, transition: {
93
+ type: 'spring',
94
+ stiffness: 400,
95
+ damping: 30,
96
+ }, className: "absolute top-full left-0 mt-2 z-[1300] w-full min-w-[300px] max-w-[340px]", children: _jsxs("div", { className: "bg-surface-primary border border-border-primary rounded-2xl shadow-lg p-4 backdrop-blur-xl", children: [_jsxs("div", { className: "flex items-center justify-between mb-4", children: [_jsx(motion.button, { whileHover: { scale: 1.05 }, whileTap: { scale: 0.95 }, onClick: handlePrevMonth, className: "p-2 rounded-lg hover:bg-surface-secondary transition-apple", type: "button", children: _jsx("svg", { className: "w-5 h-5 text-text-primary", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M15 19l-7-7 7-7" }) }) }), _jsxs("h3", { className: "text-base font-semibold text-text-primary", children: [monthNames[month], " ", year] }), _jsx(motion.button, { whileHover: { scale: 1.05 }, whileTap: { scale: 0.95 }, onClick: handleNextMonth, className: "p-2 rounded-lg hover:bg-surface-secondary transition-apple", type: "button", children: _jsx("svg", { className: "w-5 h-5 text-text-primary", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M9 5l7 7-7 7" }) }) })] }), _jsx("div", { className: "grid grid-cols-7 gap-1 mb-2", children: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'].map((day) => (_jsx("div", { className: "text-center text-xs font-medium text-text-tertiary py-2", children: day }, day))) }), _jsxs("div", { className: "grid grid-cols-7 gap-1", onMouseLeave: () => setHoveredDate(null), children: [emptyDays.map((_, index) => (_jsx("div", { className: "aspect-square" }, `empty-${index}`))), days.map((day) => {
97
+ const date = new Date(year, month, day);
98
+ const isSelectedStart = range.from && isSameDay(date, range.from);
99
+ const isSelectedEnd = range.to && isSameDay(date, range.to);
100
+ const isSelected = isSelectedStart || isSelectedEnd;
101
+ const isInRange = isDateInRange(date);
102
+ const isToday = isSameDay(date, today);
103
+ const isDisabled = isDateDisabled(date, minDate, maxDate);
104
+ let roundedClass = 'rounded-lg';
105
+ if (isInRange) {
106
+ if (isSelectedStart && isSelectedEnd)
107
+ roundedClass = 'rounded-lg';
108
+ else if (isSelectedStart)
109
+ roundedClass = 'rounded-l-lg rounded-r-none';
110
+ else if (isSelectedEnd)
111
+ roundedClass = 'rounded-r-lg rounded-l-none';
112
+ else
113
+ roundedClass = 'rounded-none';
114
+ }
115
+ return (_jsx(motion.button, { whileHover: !isDisabled ? { scale: 1.05, zIndex: 10 } : {}, whileTap: !isDisabled ? { scale: 0.95 } : {}, onClick: () => handleDayClick(day), onMouseEnter: () => setHoveredDate(date), disabled: isDisabled, className: `
116
+ aspect-square text-sm font-medium relative
117
+ transition-colors duration-200
118
+ ${roundedClass}
119
+ ${isSelected
120
+ ? 'bg-accent-blue text-white z-10'
121
+ : isInRange
122
+ ? 'bg-accent-blue/10 text-text-primary'
123
+ : isToday
124
+ ? 'bg-accent-blue/5 text-accent-blue border border-accent-blue/20'
125
+ : 'text-text-primary hover:bg-surface-secondary'}
126
+ ${isDisabled ? 'opacity-30 cursor-not-allowed' : 'cursor-pointer'}
127
+ `, type: "button", children: day }, day));
128
+ })] })] }) }));
129
+ };
130
+ /* ========================================
131
+ DATE RANGE PICKER COMPONENT
132
+ ======================================== */
133
+ export const DateRangePicker = ({ label, value, onChange, placeholder = 'Select date range', error, helperText, disabled = false, minDate, maxDate, dateFormat = 'medium', size = 'md', className = '', }) => {
134
+ const [isOpen, setIsOpen] = useState(false);
135
+ const [range, setRange] = useState(value || { from: null, to: null });
136
+ const [currentMonth, setCurrentMonth] = useState(value?.from || new Date());
137
+ const containerRef = useRef(null);
138
+ const hasError = !!error;
139
+ // Sync state with props
140
+ useEffect(() => {
141
+ if (value) {
142
+ setRange(value);
143
+ if (value.from)
144
+ setCurrentMonth(value.from);
145
+ }
146
+ }, [value]);
147
+ useEffect(() => {
148
+ const handleClickOutside = (event) => {
149
+ if (containerRef.current && !containerRef.current.contains(event.target)) {
150
+ setIsOpen(false);
151
+ }
152
+ };
153
+ if (isOpen) {
154
+ document.addEventListener('mousedown', handleClickOutside);
155
+ }
156
+ return () => {
157
+ document.removeEventListener('mousedown', handleClickOutside);
158
+ };
159
+ }, [isOpen]);
160
+ const handleSelectDate = (date) => {
161
+ let newRange = { ...range };
162
+ if (!range.from || (range.from && range.to)) {
163
+ // Start new range
164
+ newRange = { from: date, to: null };
165
+ }
166
+ else {
167
+ // Complete range
168
+ if (date < range.from) {
169
+ newRange = { from: date, to: range.from };
170
+ }
171
+ else {
172
+ newRange = { from: range.from, to: date };
173
+ }
174
+ setIsOpen(false); // Close on second selection
175
+ }
176
+ setRange(newRange);
177
+ onChange?.(newRange);
178
+ };
179
+ const handleInputClick = () => {
180
+ if (!disabled && !isOpen) {
181
+ setIsOpen(true);
182
+ }
183
+ };
184
+ const handleClear = (e) => {
185
+ e.stopPropagation();
186
+ const newRange = { from: null, to: null };
187
+ setRange(newRange);
188
+ onChange?.(newRange);
189
+ };
190
+ const getDisplayText = () => {
191
+ if (!range.from)
192
+ return '';
193
+ if (!range.to)
194
+ return formatDate(range.from, dateFormat);
195
+ return `${formatDate(range.from, dateFormat)} - ${formatDate(range.to, dateFormat)}`;
196
+ };
197
+ const inputClassName = `
198
+ ${baseInputStyles}
199
+ ${sizeStyles[size]}
200
+ ${hasError ? 'border-status-error focus:border-status-error focus:ring-status-error/20' : ''}
201
+ ${className}
202
+ `.trim().replace(/\s+/g, ' ');
203
+ return (_jsxs("div", { className: "w-full", ref: containerRef, children: [label && (_jsx("label", { className: "block text-sm font-medium text-text-primary mb-2", children: label })), _jsxs("div", { className: "relative", children: [_jsx(motion.div, { whileHover: !disabled ? { scale: 1.005 } : {}, transition: {
204
+ type: 'spring',
205
+ stiffness: 300,
206
+ damping: 30,
207
+ }, children: _jsx("input", { type: "text", readOnly: true, value: getDisplayText(), onClick: handleInputClick, placeholder: placeholder, disabled: disabled, className: inputClassName }) }), _jsxs("div", { className: "absolute right-3 top-1/2 -translate-y-1/2 flex items-center gap-1", children: [range.from && !disabled && (_jsx(motion.button, { whileHover: { scale: 1.1 }, whileTap: { scale: 0.9 }, onClick: handleClear, className: "p-1 rounded-md hover:bg-surface-secondary transition-apple", type: "button", children: _jsx("svg", { className: "w-4 h-4 text-text-tertiary", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M6 18L18 6M6 6l12 12" }) }) })), _jsx("svg", { className: "w-5 h-5 text-text-tertiary pointer-events-none", fill: "none", viewBox: "0 0 24 24", stroke: "currentColor", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M8 7V3m8 4V3m-9 8h10M5 21h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v12a2 2 0 002 2z" }) })] }), _jsx(AnimatePresence, { children: isOpen && (_jsx(Calendar, { range: range, onSelectDate: handleSelectDate, minDate: minDate, maxDate: maxDate, currentMonth: currentMonth, onMonthChange: setCurrentMonth })) })] }), (error || helperText) && (_jsx(motion.p, { initial: { opacity: 0, y: -4 }, animate: { opacity: 1, y: 0 }, transition: { duration: 0.16 }, className: `
208
+ mt-2 text-sm
209
+ ${hasError ? 'text-status-error' : 'text-text-secondary'}
210
+ `, children: error || helperText }))] }));
211
+ };
212
+ DateRangePicker.displayName = 'DateRangePicker';
213
+ //# sourceMappingURL=DateRangePicker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DateRangePicker.js","sourceRoot":"","sources":["../../components/DateRangePicker.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ import React from 'react';
2
+ export type DefinitionItem = {
3
+ term: React.ReactNode;
4
+ description: React.ReactNode;
5
+ };
6
+ export type DefinitionListVariant = 'default' | 'bordered' | 'striped' | 'compact';
7
+ export type DefinitionListOrientation = 'horizontal' | 'vertical';
8
+ export interface DefinitionListProps extends React.HTMLAttributes<HTMLDListElement> {
9
+ items: DefinitionItem[];
10
+ variant?: DefinitionListVariant;
11
+ orientation?: DefinitionListOrientation;
12
+ divider?: boolean;
13
+ hoverable?: boolean;
14
+ density?: 'comfortable' | 'compact';
15
+ }
16
+ export declare const DefinitionList: React.ForwardRefExoticComponent<DefinitionListProps & React.RefAttributes<HTMLDListElement>>;
17
+ export interface CompactDefinitionListProps extends Omit<DefinitionListProps, 'density' | 'variant'> {
18
+ variant?: Exclude<DefinitionListVariant, 'compact'>;
19
+ }
20
+ export declare const CompactDefinitionList: React.ForwardRefExoticComponent<CompactDefinitionListProps & React.RefAttributes<HTMLDListElement>>;
21
+ //# sourceMappingURL=DefinitionList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DefinitionList.d.ts","sourceRoot":"","sources":["../../components/DefinitionList.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAC;AAQ1C,MAAM,MAAM,cAAc,GAAG;IACzB,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC;IACtB,WAAW,EAAE,KAAK,CAAC,SAAS,CAAC;CAChC,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG,SAAS,GAAG,UAAU,GAAG,SAAS,GAAG,SAAS,CAAC;AACnF,MAAM,MAAM,yBAAyB,GAAG,YAAY,GAAG,UAAU,CAAC;AAElE,MAAM,WAAW,mBAAoB,SAAQ,KAAK,CAAC,cAAc,CAAC,gBAAgB,CAAC;IAC/E,KAAK,EAAE,cAAc,EAAE,CAAC;IACxB,OAAO,CAAC,EAAE,qBAAqB,CAAC;IAChC,WAAW,CAAC,EAAE,yBAAyB,CAAC;IACxC,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,OAAO,CAAC,EAAE,aAAa,GAAG,SAAS,CAAC;CACvC;AAMD,eAAO,MAAM,cAAc,8FAsG1B,CAAC;AAQF,MAAM,WAAW,0BAA2B,SAAQ,IAAI,CAAC,mBAAmB,EAAE,SAAS,GAAG,SAAS,CAAC;IAChG,OAAO,CAAC,EAAE,OAAO,CAAC,qBAAqB,EAAE,SAAS,CAAC,CAAC;CACvD;AAED,eAAO,MAAM,qBAAqB,qGAIjC,CAAC"}
@@ -0,0 +1,44 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { forwardRef } from 'react';
3
+ import { motion } from 'framer-motion';
4
+ import { cn } from '../lib/utils';
5
+ /* ========================================
6
+ DEFINITION LIST COMPONENT
7
+ ======================================== */
8
+ export const DefinitionList = forwardRef(({ items, variant = 'default', orientation = 'horizontal', divider = false, hoverable = false, density = 'comfortable', className, ...props }, ref) => {
9
+ const isHorizontal = orientation === 'horizontal';
10
+ const isCompact = density === 'compact';
11
+ const containerVariants = {
12
+ default: "bg-surface-primary",
13
+ bordered: "bg-surface-primary border border-border-primary rounded-xl",
14
+ striped: "bg-surface-primary",
15
+ compact: "bg-transparent",
16
+ };
17
+ const itemVariants = {
18
+ default: "",
19
+ bordered: "border-b border-border-primary last:border-b-0",
20
+ striped: "even:bg-surface-secondary/50",
21
+ compact: "",
22
+ };
23
+ const paddingClass = isCompact ? "py-2" : "py-3";
24
+ const gapClass = isCompact ? "gap-2" : "gap-4";
25
+ const MotionDL = motion.dl;
26
+ return (_jsx(MotionDL, { ref: ref, className: cn("overflow-hidden", containerVariants[variant], variant === 'bordered' && "shadow-sm", className), initial: { opacity: 0, y: 8 }, animate: { opacity: 1, y: 0 }, transition: {
27
+ duration: 0.22,
28
+ ease: [0.16, 1, 0.3, 1],
29
+ }, ...props, children: items.map((item, index) => (_jsxs(motion.div, { className: cn("group", itemVariants[variant], isHorizontal
30
+ ? `flex ${gapClass} ${paddingClass} px-4 sm:px-6`
31
+ : `flex flex-col ${gapClass} ${paddingClass} px-4 sm:px-6`, divider && index !== items.length - 1 && "border-b border-border-primary", hoverable && "transition-colors hover:bg-surface-secondary/30 cursor-default"), initial: { opacity: 0, x: -10 }, animate: { opacity: 1, x: 0 }, transition: {
32
+ duration: 0.2,
33
+ delay: index * 0.03,
34
+ ease: [0.16, 1, 0.3, 1],
35
+ }, children: [_jsx("dt", { className: cn("font-semibold text-text-primary", isHorizontal
36
+ ? "min-w-[140px] sm:min-w-[180px] flex-shrink-0"
37
+ : "mb-1", isCompact ? "text-sm" : "text-base"), children: item.term }), _jsx("dd", { className: cn("text-text-secondary", isHorizontal ? "flex-1" : "", isCompact ? "text-sm" : "text-base"), children: item.description })] }, index))) }));
38
+ });
39
+ DefinitionList.displayName = 'DefinitionList';
40
+ export const CompactDefinitionList = forwardRef((props, ref) => {
41
+ return _jsx(DefinitionList, { ref: ref, ...props, density: "compact" });
42
+ });
43
+ CompactDefinitionList.displayName = 'CompactDefinitionList';
44
+ //# sourceMappingURL=DefinitionList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DefinitionList.js","sourceRoot":"","sources":["../../components/DefinitionList.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,36 @@
1
+ import React from 'react';
2
+ export type DescriptionHighlightTrend = 'up' | 'down' | 'neutral';
3
+ export interface DescriptionHighlightProps extends React.HTMLAttributes<HTMLDivElement> {
4
+ label: React.ReactNode;
5
+ value: React.ReactNode;
6
+ change?: React.ReactNode;
7
+ trend?: DescriptionHighlightTrend;
8
+ icon?: React.ReactNode;
9
+ badge?: React.ReactNode;
10
+ helper?: React.ReactNode;
11
+ emphasis?: 'default' | 'soft';
12
+ compact?: boolean;
13
+ }
14
+ export type DescriptionMetadataItem = {
15
+ label: React.ReactNode;
16
+ value: React.ReactNode;
17
+ icon?: React.ReactNode;
18
+ hint?: React.ReactNode;
19
+ };
20
+ export interface DescriptionBlockProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'title'> {
21
+ eyebrow?: React.ReactNode;
22
+ title: React.ReactNode;
23
+ subtitle?: React.ReactNode;
24
+ description?: React.ReactNode;
25
+ badges?: React.ReactNode[];
26
+ metadata?: DescriptionMetadataItem[];
27
+ metadataColumns?: 1 | 2 | 3;
28
+ media?: React.ReactNode;
29
+ actions?: React.ReactNode;
30
+ footer?: React.ReactNode;
31
+ layout?: 'stacked' | 'split';
32
+ variant?: 'default' | 'soft' | 'panel' | 'glass';
33
+ align?: 'start' | 'center';
34
+ }
35
+ export declare const DescriptionBlock: React.ForwardRefExoticComponent<DescriptionBlockProps & React.RefAttributes<HTMLDivElement>>;
36
+ //# sourceMappingURL=DescriptionBlock.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DescriptionBlock.d.ts","sourceRoot":"","sources":["../../components/DescriptionBlock.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAC;AAS1C,MAAM,MAAM,yBAAyB,GAAG,IAAI,GAAG,MAAM,GAAG,SAAS,CAAC;AAElE,MAAM,WAAW,yBAA0B,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACnF,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,KAAK,CAAC,EAAE,yBAAyB,CAAC;IAClC,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACxB,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,QAAQ,CAAC,EAAE,SAAS,GAAG,MAAM,CAAC;IAC9B,OAAO,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,MAAM,MAAM,uBAAuB,GAAG;IAClC,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC1B,CAAC;AAEF,MAAM,WAAW,qBAAsB,SAAQ,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,OAAO,CAAC;IAC9F,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC;IACvB,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,WAAW,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC9B,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC;IAC3B,QAAQ,CAAC,EAAE,uBAAuB,EAAE,CAAC;IACrC,eAAe,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAC5B,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACxB,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,MAAM,CAAC,EAAE,SAAS,GAAG,OAAO,CAAC;IAC7B,OAAO,CAAC,EAAE,SAAS,GAAG,MAAM,GAAG,OAAO,GAAG,OAAO,CAAC;IACjD,KAAK,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;CAC9B;AAMD,eAAO,MAAM,gBAAgB,8FAwI5B,CAAC"}
@@ -0,0 +1,27 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { forwardRef } from 'react';
3
+ import { motion } from 'framer-motion';
4
+ import { cn } from '../lib/utils';
5
+ import { Badge } from './Badge';
6
+ /* ========================================
7
+ DESCRIPTION BLOCK
8
+ ======================================== */
9
+ export const DescriptionBlock = forwardRef(({ eyebrow, title, subtitle, description, badges, metadata, metadataColumns = 2, media, actions, footer, layout = 'stacked', variant = 'default', align = 'start', className, ...props }, ref) => {
10
+ const MotionSection = motion.section;
11
+ const variantClasses = {
12
+ default: 'bg-surface-primary border border-border-primary shadow-sm',
13
+ soft: 'bg-surface-secondary/60 border border-border-primary/50',
14
+ panel: 'bg-surface-primary/90 border border-border-primary shadow-lg',
15
+ glass: 'bg-white/5 dark:bg-white/2 backdrop-blur-2xl border border-white/10 shadow-[0_20px_80px_rgba(15,23,42,0.15)]',
16
+ };
17
+ const metadataGrid = {
18
+ 1: 'grid-cols-1',
19
+ 2: 'grid-cols-1 sm:grid-cols-2',
20
+ 3: 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-3',
21
+ };
22
+ return (_jsxs(MotionSection, { ref: ref, className: cn('rounded-3xl p-6 sm:p-8 space-y-6', variantClasses[variant], className), initial: { opacity: 0, y: 20 }, animate: { opacity: 1, y: 0 }, transition: { duration: 0.3, ease: [0.16, 1, 0.3, 1] }, ...props, children: [_jsx("div", { className: cn(layout === 'split'
23
+ ? 'grid gap-8 lg:grid-cols-[1.8fr_1fr]'
24
+ : 'space-y-10'), children: _jsxs("div", { className: cn('space-y-7', align === 'center' && 'text-center items-center flex flex-col'), children: [eyebrow && (_jsx("p", { className: "text-xs font-semibold uppercase tracking-[0.35em] text-text-tertiary", children: eyebrow })), _jsxs("div", { className: "space-y-3 w-full", children: [_jsxs("div", { className: "space-y-2", children: [_jsx("div", { className: cn('text-3xl font-semibold tracking-tight text-text-primary', align === 'center' && 'text-center'), children: title }), subtitle && (_jsx("p", { className: cn('text-lg text-text-secondary', align === 'center' && 'text-center'), children: subtitle }))] }), badges && badges.length > 0 && (_jsx("div", { className: cn('flex flex-wrap gap-2', align === 'center' && 'justify-center'), children: badges.map((badge, index) => (_jsx(Badge, { size: "sm", className: "bg-surface-secondary/60 border border-border-primary/60 text-text-secondary", children: badge }, index))) }))] }), description && (_jsx("div", { className: cn('text-base text-text-secondary leading-relaxed max-w-2xl', align === 'center' && 'mx-auto text-center'), children: description })), actions && (_jsx("div", { className: cn('flex flex-wrap gap-3', align === 'center' && 'justify-center'), children: actions })), media && (_jsx("div", { className: "overflow-hidden rounded-2xl border border-border-primary/60 bg-surface-secondary/40", children: media })), metadata && metadata.length > 0 && (_jsxs("div", { className: "space-y-4", children: [_jsx("p", { className: "text-xs font-semibold uppercase tracking-[0.3em] text-text-tertiary", children: "Detalles" }), _jsx("div", { className: cn('grid gap-6', metadataGrid[metadataColumns]), children: metadata.map((item, index) => (_jsxs("div", { className: "rounded-2xl border border-border-primary/40 bg-surface-secondary/30 p-5 space-y-1.5", children: [_jsxs("div", { className: "flex items-center gap-2 text-xs font-semibold uppercase tracking-wide text-text-tertiary", children: [item.icon && _jsx("span", { className: "text-text-tertiary", children: item.icon }), _jsx("span", { children: item.label })] }), _jsx("div", { className: "text-text-primary text-lg font-semibold break-words", children: item.value }), item.hint && (_jsx("p", { className: "text-sm text-text-secondary", children: item.hint }))] }, index))) })] }))] }) }), layout === 'stacked' && footer && (_jsxs(_Fragment, { children: [_jsx("br", {}), _jsx("div", { className: "rounded-2xl border border-dashed border-border-primary/60 p-4 text-sm text-text-secondary", children: footer })] }))] }));
25
+ });
26
+ DescriptionBlock.displayName = 'DescriptionBlock';
27
+ //# sourceMappingURL=DescriptionBlock.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DescriptionBlock.js","sourceRoot":"","sources":["../../components/DescriptionBlock.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import React from 'react';
2
+ export type DeviceType = 'phone' | 'tablet' | 'laptop' | 'desktop' | 'other';
3
+ export type DeviceStatus = 'active' | 'inactive' | 'suspended';
4
+ export interface Device {
5
+ id: string;
6
+ name: string;
7
+ type: DeviceType;
8
+ os?: string;
9
+ browser?: string;
10
+ lastActive?: string;
11
+ location?: string;
12
+ ipAddress?: string;
13
+ status: DeviceStatus;
14
+ isCurrentDevice?: boolean;
15
+ }
16
+ export interface DeviceListProps extends React.HTMLAttributes<HTMLDivElement> {
17
+ devices: Device[];
18
+ onRemove?: (device: Device) => void;
19
+ onMoreActions?: (device: Device) => void;
20
+ showActions?: boolean;
21
+ className?: string;
22
+ }
23
+ export declare const DeviceList: React.ForwardRefExoticComponent<DeviceListProps & React.RefAttributes<HTMLDivElement>>;
24
+ //# sourceMappingURL=DeviceList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DeviceList.d.ts","sourceRoot":"","sources":["../../components/DeviceList.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAW1B,MAAM,MAAM,UAAU,GAAG,OAAO,GAAG,QAAQ,GAAG,QAAQ,GAAG,SAAS,GAAG,OAAO,CAAC;AAC7E,MAAM,MAAM,YAAY,GAAG,QAAQ,GAAG,UAAU,GAAG,WAAW,CAAC;AAE/D,MAAM,WAAW,MAAM;IACnB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,UAAU,CAAC;IACjB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,YAAY,CAAC;IACrB,eAAe,CAAC,EAAE,OAAO,CAAC;CAC7B;AAED,MAAM,WAAW,eAAgB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACzE,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IACpC,aAAa,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IACzC,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAuCD,eAAO,MAAM,UAAU,wFA6FtB,CAAC"}
@@ -0,0 +1,46 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
+ import React from 'react';
4
+ import { cn } from '../lib/utils';
5
+ import { motion } from 'framer-motion';
6
+ import { Smartphone, Monitor, Tablet, Laptop, Trash2, MoreVertical } from 'lucide-react';
7
+ import { Button } from './Button';
8
+ import { Badge } from './Badge';
9
+ /* ========================================
10
+ HELPERS
11
+ ======================================== */
12
+ const getDeviceIcon = (type) => {
13
+ switch (type) {
14
+ case 'phone':
15
+ return _jsx(Smartphone, { className: "w-5 h-5" });
16
+ case 'tablet':
17
+ return _jsx(Tablet, { className: "w-5 h-5" });
18
+ case 'laptop':
19
+ return _jsx(Laptop, { className: "w-5 h-5" });
20
+ case 'desktop':
21
+ return _jsx(Monitor, { className: "w-5 h-5" });
22
+ default:
23
+ return _jsx(Smartphone, { className: "w-5 h-5" });
24
+ }
25
+ };
26
+ const getStatusBadge = (status, isCurrent) => {
27
+ if (isCurrent) {
28
+ return _jsx(Badge, { variant: "success", size: "sm", children: "Current Device" });
29
+ }
30
+ switch (status) {
31
+ case 'active':
32
+ return _jsx(Badge, { variant: "success", size: "sm", children: "Active" });
33
+ case 'inactive':
34
+ return _jsx(Badge, { variant: "default", size: "sm", children: "Inactive" });
35
+ case 'suspended':
36
+ return _jsx(Badge, { variant: "error", size: "sm", children: "Suspended" });
37
+ }
38
+ };
39
+ /* ========================================
40
+ COMPONENT
41
+ ======================================== */
42
+ export const DeviceList = React.forwardRef(({ devices, onRemove, onMoreActions, showActions = true, className, ...props }, ref) => {
43
+ return (_jsx("div", { ref: ref, className: cn("w-full space-y-2", className), ...props, children: devices.map((device, index) => (_jsxs(motion.div, { initial: { opacity: 0, y: 10 }, animate: { opacity: 1, y: 0 }, transition: { delay: index * 0.05 }, className: cn("flex items-center gap-4 p-4 rounded-xl border", "bg-surface-primary border-border-primary", "hover:bg-surface-secondary transition-colors"), children: [_jsx("div", { className: "flex-shrink-0 p-2 bg-surface-secondary rounded-lg text-text-tertiary", children: getDeviceIcon(device.type) }), _jsxs("div", { className: "flex-1 min-w-0", children: [_jsxs("div", { className: "flex items-center gap-2 mb-1", children: [_jsx("h3", { className: "text-sm font-semibold text-text-primary truncate", children: device.name }), getStatusBadge(device.status, device.isCurrentDevice)] }), _jsxs("div", { className: "flex flex-wrap items-center gap-3 text-xs text-text-secondary", children: [device.os && _jsx("span", { children: device.os }), device.browser && (_jsxs(_Fragment, { children: [_jsx("span", { className: "text-text-tertiary", children: "\u2022" }), _jsx("span", { children: device.browser })] })), device.lastActive && (_jsxs(_Fragment, { children: [_jsx("span", { className: "text-text-tertiary", children: "\u2022" }), _jsxs("span", { children: ["Last active: ", device.lastActive] })] }))] }), device.location && (_jsx("p", { className: "text-xs text-text-tertiary mt-1", children: device.location }))] }), showActions && (_jsxs("div", { className: "flex-shrink-0 flex items-center gap-2", children: [onMoreActions && (_jsx(Button, { variant: "ghost", size: "sm", onClick: () => onMoreActions(device), children: _jsx(MoreVertical, { className: "w-4 h-4" }) })), onRemove && !device.isCurrentDevice && (_jsx(Button, { variant: "ghost", size: "sm", onClick: () => onRemove(device), children: _jsx(Trash2, { className: "w-4 h-4 text-status-error" }) }))] }))] }, device.id))) }));
44
+ });
45
+ DeviceList.displayName = 'DeviceList';
46
+ //# sourceMappingURL=DeviceList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DeviceList.js","sourceRoot":"","sources":["../../components/DeviceList.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ export type DiffViewMode = 'unified' | 'split';
3
+ export interface DiffViewerProps {
4
+ oldText: string;
5
+ newText: string;
6
+ oldTitle?: string;
7
+ newTitle?: string;
8
+ initialMode?: DiffViewMode;
9
+ className?: string;
10
+ hideHeader?: boolean;
11
+ }
12
+ export declare const DiffViewer: React.FC<DiffViewerProps>;
13
+ //# sourceMappingURL=DiffViewer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DiffViewer.d.ts","sourceRoot":"","sources":["../../components/DiffViewer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA4B,MAAM,OAAO,CAAC;AASjD,MAAM,MAAM,YAAY,GAAG,SAAS,GAAG,OAAO,CAAC;AAE/C,MAAM,WAAW,eAAe;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,YAAY,CAAC;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,OAAO,CAAC;CACxB;AAwED,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAyLhD,CAAC"}
@@ -0,0 +1,93 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useMemo, useState } from 'react';
3
+ import { cn } from '../lib/utils';
4
+ import { Button } from './Button';
5
+ import { Columns, Rows } from 'lucide-react';
6
+ /* ========================================
7
+ DIFF ALGORITHM (Simple LCS)
8
+ ======================================== */
9
+ const computeDiff = (oldText, newText) => {
10
+ const oldLines = oldText.split('\n');
11
+ const newLines = newText.split('\n');
12
+ const N = oldLines.length;
13
+ const M = newLines.length;
14
+ // LCS Matrix
15
+ const lcs = Array(N + 1).fill(0).map(() => Array(M + 1).fill(0));
16
+ for (let i = 1; i <= N; i++) {
17
+ for (let j = 1; j <= M; j++) {
18
+ if (oldLines[i - 1] === newLines[j - 1]) {
19
+ lcs[i][j] = lcs[i - 1][j - 1] + 1;
20
+ }
21
+ else {
22
+ lcs[i][j] = Math.max(lcs[i - 1][j], lcs[i][j - 1]);
23
+ }
24
+ }
25
+ }
26
+ // Backtrack
27
+ const diff = [];
28
+ let i = N;
29
+ let j = M;
30
+ while (i > 0 || j > 0) {
31
+ if (i > 0 && j > 0 && oldLines[i - 1] === newLines[j - 1]) {
32
+ diff.unshift({
33
+ type: 'unchanged',
34
+ content: oldLines[i - 1],
35
+ oldLineNumber: i,
36
+ newLineNumber: j
37
+ });
38
+ i--;
39
+ j--;
40
+ }
41
+ else if (j > 0 && (i === 0 || lcs[i][j - 1] >= lcs[i - 1][j])) {
42
+ diff.unshift({
43
+ type: 'added',
44
+ content: newLines[j - 1],
45
+ newLineNumber: j
46
+ });
47
+ j--;
48
+ }
49
+ else {
50
+ diff.unshift({
51
+ type: 'removed',
52
+ content: oldLines[i - 1],
53
+ oldLineNumber: i
54
+ });
55
+ i--;
56
+ }
57
+ }
58
+ return diff;
59
+ };
60
+ /* ========================================
61
+ COMPONENTS
62
+ ======================================== */
63
+ export const DiffViewer = ({ oldText, newText, oldTitle = 'Original', newTitle = 'Modified', initialMode = 'unified', className, hideHeader = false, }) => {
64
+ const [mode, setMode] = useState(initialMode);
65
+ const diffLines = useMemo(() => computeDiff(oldText, newText), [oldText, newText]);
66
+ const renderUnified = () => (_jsx("div", { className: "font-mono text-xs", children: diffLines.map((line, idx) => (_jsxs("div", { className: cn("flex", line.type === 'added' && "bg-green-100/50 dark:bg-green-900/20", line.type === 'removed' && "bg-red-100/50 dark:bg-red-900/20", line.type === 'unchanged' && "hover:bg-black/5 dark:hover:bg-white/5"), children: [_jsx("div", { className: "flex-none w-12 text-right pr-4 py-0.5 select-none text-text-tertiary border-r border-border-primary/30 opacity-50", children: line.oldLineNumber || '' }), _jsx("div", { className: "flex-none w-12 text-right pr-4 py-0.5 select-none text-text-tertiary border-r border-border-primary/30 opacity-50", children: line.newLineNumber || '' }), _jsxs("div", { className: cn("flex-none w-8 text-center py-0.5 select-none font-bold", line.type === 'added' && "text-green-600 dark:text-green-400", line.type === 'removed' && "text-red-600 dark:text-red-400", line.type === 'unchanged' && "text-text-secondary"), children: [line.type === 'added' && '+', line.type === 'removed' && '-'] }), _jsx("div", { className: cn("flex-1 py-0.5 px-4 whitespace-pre-wrap break-all", line.type === 'added' && "text-green-900 dark:text-green-100", line.type === 'removed' && "text-red-900 dark:text-red-100 line-through opacity-70", line.type === 'unchanged' && "text-text-secondary"), children: line.content })] }, idx))) }));
67
+ const renderSplit = () => {
68
+ // For split view, we need to align changes.
69
+ // This simple implementation just renders two columns but doesn't perfectly align complex diff blocks vertically
70
+ // like a sophisticated diff tool (e.g. GitHub) would with empty spacers.
71
+ // To improve this without deps, we can process the diffLines to insert "empty" placeholders.
72
+ const leftSide = [];
73
+ const rightSide = [];
74
+ diffLines.forEach(line => {
75
+ if (line.type === 'unchanged') {
76
+ leftSide.push(line);
77
+ rightSide.push(line);
78
+ }
79
+ else if (line.type === 'removed') {
80
+ leftSide.push(line);
81
+ rightSide.push({ type: 'unchanged', content: '', newLineNumber: undefined }); // Placeholder
82
+ }
83
+ else if (line.type === 'added') {
84
+ leftSide.push({ type: 'unchanged', content: '', oldLineNumber: undefined }); // Placeholder
85
+ rightSide.push(line);
86
+ }
87
+ });
88
+ return (_jsxs("div", { className: "flex font-mono text-xs divide-x divide-border-primary/30", children: [_jsx("div", { className: "flex-1 min-w-0", children: leftSide.map((line, idx) => (_jsxs("div", { className: cn("flex", line.type === 'removed' && "bg-red-100/50 dark:bg-red-900/20", !line.oldLineNumber && line.content === '' && "bg-black/5 dark:bg-white/5" // Placeholder styling
89
+ ), children: [_jsx("div", { className: "flex-none w-12 text-right pr-4 py-0.5 select-none text-text-tertiary border-r border-border-primary/30 opacity-50", children: line.oldLineNumber || '' }), _jsx("div", { className: cn("flex-1 py-0.5 px-4 whitespace-pre-wrap break-all", line.type === 'removed' ? "text-red-900 dark:text-red-100" : "text-text-secondary", !line.oldLineNumber && "select-none"), children: line.content })] }, idx))) }), _jsx("div", { className: "flex-1 min-w-0", children: rightSide.map((line, idx) => (_jsxs("div", { className: cn("flex", line.type === 'added' && "bg-green-100/50 dark:bg-green-900/20", !line.newLineNumber && line.content === '' && "bg-black/5 dark:bg-white/5"), children: [_jsx("div", { className: "flex-none w-12 text-right pr-4 py-0.5 select-none text-text-tertiary border-r border-border-primary/30 opacity-50", children: line.newLineNumber || '' }), _jsx("div", { className: cn("flex-1 py-0.5 px-4 whitespace-pre-wrap break-all", line.type === 'added' ? "text-green-900 dark:text-green-100" : "text-text-secondary", !line.newLineNumber && "select-none"), children: line.content })] }, idx))) })] }));
90
+ };
91
+ return (_jsxs("div", { className: cn("border border-border-primary/50 rounded-lg overflow-hidden bg-surface-primary", className), children: [!hideHeader && (_jsxs("div", { className: "flex items-center justify-between px-4 py-2 bg-surface-secondary border-b border-border-primary/50", children: [_jsxs("div", { className: "flex items-center gap-4 text-sm", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "w-2 h-2 rounded-full bg-red-500/50" }), _jsx("span", { className: "font-medium text-text-secondary", children: oldTitle })] }), _jsx("span", { className: "text-text-tertiary", children: "\u2192" }), _jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "w-2 h-2 rounded-full bg-green-500/50" }), _jsx("span", { className: "font-medium text-text-secondary", children: newTitle })] })] }), _jsxs("div", { className: "flex bg-surface-primary rounded-md p-0.5 border border-border-primary/50", children: [_jsxs(Button, { variant: "ghost", size: "sm", onClick: () => setMode('unified'), className: cn("h-6 px-2 text-xs gap-1.5", mode === 'unified' ? "bg-surface-secondary shadow-sm text-text-primary" : "text-text-tertiary"), children: [_jsx(Rows, { className: "w-3.5 h-3.5" }), "Unified"] }), _jsxs(Button, { variant: "ghost", size: "sm", onClick: () => setMode('split'), className: cn("h-6 px-2 text-xs gap-1.5", mode === 'split' ? "bg-surface-secondary shadow-sm text-text-primary" : "text-text-tertiary"), children: [_jsx(Columns, { className: "w-3.5 h-3.5" }), "Split"] })] })] })), _jsx("div", { className: "overflow-x-auto", children: mode === 'unified' ? renderUnified() : renderSplit() })] }));
92
+ };
93
+ //# sourceMappingURL=DiffViewer.js.map