@automa8e/ui 0.2.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 (451) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +2 -0
  3. package/dist/_virtual/index.js +6 -0
  4. package/dist/_virtual/index.js.map +1 -0
  5. package/dist/_virtual/index2.js +5 -0
  6. package/dist/_virtual/index2.js.map +1 -0
  7. package/dist/_virtual/use-sync-external-store-shim.development.js +5 -0
  8. package/dist/_virtual/use-sync-external-store-shim.development.js.map +1 -0
  9. package/dist/_virtual/use-sync-external-store-shim.production.js +5 -0
  10. package/dist/_virtual/use-sync-external-store-shim.production.js.map +1 -0
  11. package/dist/automa8e-ui.css +226 -0
  12. package/dist/components/automation/metric-card.d.ts +19 -0
  13. package/dist/components/automation/metric-card.d.ts.map +1 -0
  14. package/dist/components/automation/metric-card.js +59 -0
  15. package/dist/components/automation/metric-card.js.map +1 -0
  16. package/dist/components/automation/status-badge.d.ts +27 -0
  17. package/dist/components/automation/status-badge.d.ts.map +1 -0
  18. package/dist/components/automation/status-badge.js +112 -0
  19. package/dist/components/automation/status-badge.js.map +1 -0
  20. package/dist/components/automation/task-card.d.ts +14 -0
  21. package/dist/components/automation/task-card.d.ts.map +1 -0
  22. package/dist/components/automation/task-card.js +114 -0
  23. package/dist/components/automation/task-card.js.map +1 -0
  24. package/dist/components/automation/workflow-node.d.ts +20 -0
  25. package/dist/components/automation/workflow-node.d.ts.map +1 -0
  26. package/dist/components/automation/workflow-node.js +132 -0
  27. package/dist/components/automation/workflow-node.js.map +1 -0
  28. package/dist/components/layout/app-shell.d.ts +21 -0
  29. package/dist/components/layout/app-shell.d.ts.map +1 -0
  30. package/dist/components/layout/app-shell.js +35 -0
  31. package/dist/components/layout/app-shell.js.map +1 -0
  32. package/dist/components/layout/header.d.ts +16 -0
  33. package/dist/components/layout/header.d.ts.map +1 -0
  34. package/dist/components/layout/header.js +30 -0
  35. package/dist/components/layout/header.js.map +1 -0
  36. package/dist/components/layout/page-header.d.ts +16 -0
  37. package/dist/components/layout/page-header.d.ts.map +1 -0
  38. package/dist/components/layout/page-header.js +29 -0
  39. package/dist/components/layout/page-header.js.map +1 -0
  40. package/dist/components/layout/sidebar.d.ts +35 -0
  41. package/dist/components/layout/sidebar.d.ts.map +1 -0
  42. package/dist/components/layout/sidebar.js +103 -0
  43. package/dist/components/layout/sidebar.js.map +1 -0
  44. package/dist/components/ui/accordion.d.ts +8 -0
  45. package/dist/components/ui/accordion.d.ts.map +1 -0
  46. package/dist/components/ui/accordion.js +51 -0
  47. package/dist/components/ui/accordion.js.map +1 -0
  48. package/dist/components/ui/alert.d.ts +18 -0
  49. package/dist/components/ui/alert.d.ts.map +1 -0
  50. package/dist/components/ui/alert.js +89 -0
  51. package/dist/components/ui/alert.js.map +1 -0
  52. package/dist/components/ui/avatar.d.ts +20 -0
  53. package/dist/components/ui/avatar.d.ts.map +1 -0
  54. package/dist/components/ui/avatar.js +72 -0
  55. package/dist/components/ui/avatar.js.map +1 -0
  56. package/dist/components/ui/badge.d.ts +13 -0
  57. package/dist/components/ui/badge.d.ts.map +1 -0
  58. package/dist/components/ui/badge.js +54 -0
  59. package/dist/components/ui/badge.js.map +1 -0
  60. package/dist/components/ui/button.d.ts +15 -0
  61. package/dist/components/ui/button.d.ts.map +1 -0
  62. package/dist/components/ui/button.js +96 -0
  63. package/dist/components/ui/button.js.map +1 -0
  64. package/dist/components/ui/card.d.ts +16 -0
  65. package/dist/components/ui/card.d.ts.map +1 -0
  66. package/dist/components/ui/card.js +96 -0
  67. package/dist/components/ui/card.js.map +1 -0
  68. package/dist/components/ui/checkbox.d.ts +9 -0
  69. package/dist/components/ui/checkbox.d.ts.map +1 -0
  70. package/dist/components/ui/checkbox.js +29 -0
  71. package/dist/components/ui/checkbox.js.map +1 -0
  72. package/dist/components/ui/dialog.d.ts +28 -0
  73. package/dist/components/ui/dialog.d.ts.map +1 -0
  74. package/dist/components/ui/dialog.js +105 -0
  75. package/dist/components/ui/dialog.js.map +1 -0
  76. package/dist/components/ui/dropdown-menu.d.ts +29 -0
  77. package/dist/components/ui/dropdown-menu.d.ts.map +1 -0
  78. package/dist/components/ui/dropdown-menu.js +160 -0
  79. package/dist/components/ui/dropdown-menu.js.map +1 -0
  80. package/dist/components/ui/input.d.ts +14 -0
  81. package/dist/components/ui/input.d.ts.map +1 -0
  82. package/dist/components/ui/input.js +60 -0
  83. package/dist/components/ui/input.js.map +1 -0
  84. package/dist/components/ui/label.d.ts +13 -0
  85. package/dist/components/ui/label.d.ts.map +1 -0
  86. package/dist/components/ui/label.js +26 -0
  87. package/dist/components/ui/label.js.map +1 -0
  88. package/dist/components/ui/popover.d.ts +8 -0
  89. package/dist/components/ui/popover.d.ts.map +1 -0
  90. package/dist/components/ui/popover.js +29 -0
  91. package/dist/components/ui/popover.js.map +1 -0
  92. package/dist/components/ui/progress.d.ts +17 -0
  93. package/dist/components/ui/progress.d.ts.map +1 -0
  94. package/dist/components/ui/progress.js +80 -0
  95. package/dist/components/ui/progress.js.map +1 -0
  96. package/dist/components/ui/scroll-area.d.ts +6 -0
  97. package/dist/components/ui/scroll-area.d.ts.map +1 -0
  98. package/dist/components/ui/scroll-area.js +39 -0
  99. package/dist/components/ui/scroll-area.js.map +1 -0
  100. package/dist/components/ui/select.d.ts +16 -0
  101. package/dist/components/ui/select.d.ts.map +1 -0
  102. package/dist/components/ui/select.js +131 -0
  103. package/dist/components/ui/select.js.map +1 -0
  104. package/dist/components/ui/separator.d.ts +9 -0
  105. package/dist/components/ui/separator.d.ts.map +1 -0
  106. package/dist/components/ui/separator.js +50 -0
  107. package/dist/components/ui/separator.js.map +1 -0
  108. package/dist/components/ui/skeleton.d.ts +10 -0
  109. package/dist/components/ui/skeleton.d.ts.map +1 -0
  110. package/dist/components/ui/skeleton.js +30 -0
  111. package/dist/components/ui/skeleton.js.map +1 -0
  112. package/dist/components/ui/spinner.d.ts +14 -0
  113. package/dist/components/ui/spinner.d.ts.map +1 -0
  114. package/dist/components/ui/spinner.js +44 -0
  115. package/dist/components/ui/spinner.js.map +1 -0
  116. package/dist/components/ui/switch.d.ts +8 -0
  117. package/dist/components/ui/switch.d.ts.map +1 -0
  118. package/dist/components/ui/switch.js +43 -0
  119. package/dist/components/ui/switch.js.map +1 -0
  120. package/dist/components/ui/table.d.ts +11 -0
  121. package/dist/components/ui/table.d.ts.map +1 -0
  122. package/dist/components/ui/table.js +95 -0
  123. package/dist/components/ui/table.js.map +1 -0
  124. package/dist/components/ui/tabs.d.ts +20 -0
  125. package/dist/components/ui/tabs.d.ts.map +1 -0
  126. package/dist/components/ui/tabs.js +92 -0
  127. package/dist/components/ui/tabs.js.map +1 -0
  128. package/dist/components/ui/textarea.d.ts +12 -0
  129. package/dist/components/ui/textarea.d.ts.map +1 -0
  130. package/dist/components/ui/textarea.js +41 -0
  131. package/dist/components/ui/textarea.js.map +1 -0
  132. package/dist/components/ui/toast.d.ts +16 -0
  133. package/dist/components/ui/toast.d.ts.map +1 -0
  134. package/dist/components/ui/toast.js +113 -0
  135. package/dist/components/ui/toast.js.map +1 -0
  136. package/dist/components/ui/tooltip.d.ts +8 -0
  137. package/dist/components/ui/tooltip.d.ts.map +1 -0
  138. package/dist/components/ui/tooltip.js +28 -0
  139. package/dist/components/ui/tooltip.js.map +1 -0
  140. package/dist/hooks/use-debounce.d.ts +15 -0
  141. package/dist/hooks/use-debounce.d.ts.map +1 -0
  142. package/dist/hooks/use-debounce.js +15 -0
  143. package/dist/hooks/use-debounce.js.map +1 -0
  144. package/dist/hooks/use-local-storage.d.ts +9 -0
  145. package/dist/hooks/use-local-storage.d.ts.map +1 -0
  146. package/dist/hooks/use-local-storage.js +49 -0
  147. package/dist/hooks/use-local-storage.js.map +1 -0
  148. package/dist/hooks/use-media-query.d.ts +9 -0
  149. package/dist/hooks/use-media-query.d.ts.map +1 -0
  150. package/dist/hooks/use-media-query.js +20 -0
  151. package/dist/hooks/use-media-query.js.map +1 -0
  152. package/dist/index.d.ts +66 -0
  153. package/dist/index.d.ts.map +1 -0
  154. package/dist/index.js +153 -0
  155. package/dist/index.js.map +1 -0
  156. package/dist/lib/colors.d.ts +73 -0
  157. package/dist/lib/colors.d.ts.map +1 -0
  158. package/dist/lib/colors.js +64 -0
  159. package/dist/lib/colors.js.map +1 -0
  160. package/dist/lib/utils.d.ts +7 -0
  161. package/dist/lib/utils.d.ts.map +1 -0
  162. package/dist/lib/utils.js +9 -0
  163. package/dist/lib/utils.js.map +1 -0
  164. package/dist/node_modules/@floating-ui/core/dist/floating-ui.core.js +729 -0
  165. package/dist/node_modules/@floating-ui/core/dist/floating-ui.core.js.map +1 -0
  166. package/dist/node_modules/@floating-ui/dom/dist/floating-ui.dom.js +630 -0
  167. package/dist/node_modules/@floating-ui/dom/dist/floating-ui.dom.js.map +1 -0
  168. package/dist/node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.js +325 -0
  169. package/dist/node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.js.map +1 -0
  170. package/dist/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.js +177 -0
  171. package/dist/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.js.map +1 -0
  172. package/dist/node_modules/@floating-ui/utils/dist/floating-ui.utils.js +152 -0
  173. package/dist/node_modules/@floating-ui/utils/dist/floating-ui.utils.js.map +1 -0
  174. package/dist/node_modules/@radix-ui/number/dist/index.js +7 -0
  175. package/dist/node_modules/@radix-ui/number/dist/index.js.map +1 -0
  176. package/dist/node_modules/@radix-ui/primitive/dist/index.js +12 -0
  177. package/dist/node_modules/@radix-ui/primitive/dist/index.js.map +1 -0
  178. package/dist/node_modules/@radix-ui/react-accordion/dist/index.js +319 -0
  179. package/dist/node_modules/@radix-ui/react-accordion/dist/index.js.map +1 -0
  180. package/dist/node_modules/@radix-ui/react-arrow/dist/index.js +26 -0
  181. package/dist/node_modules/@radix-ui/react-arrow/dist/index.js.map +1 -0
  182. package/dist/node_modules/@radix-ui/react-avatar/dist/index.js +124 -0
  183. package/dist/node_modules/@radix-ui/react-avatar/dist/index.js.map +1 -0
  184. package/dist/node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-context/dist/index.js +66 -0
  185. package/dist/node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-context/dist/index.js.map +1 -0
  186. package/dist/node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-primitive/dist/index.js +40 -0
  187. package/dist/node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-primitive/dist/index.js.map +1 -0
  188. package/dist/node_modules/@radix-ui/react-checkbox/dist/index.js +280 -0
  189. package/dist/node_modules/@radix-ui/react-checkbox/dist/index.js.map +1 -0
  190. package/dist/node_modules/@radix-ui/react-collapsible/dist/index.js +152 -0
  191. package/dist/node_modules/@radix-ui/react-collapsible/dist/index.js.map +1 -0
  192. package/dist/node_modules/@radix-ui/react-collection/dist/index.js +71 -0
  193. package/dist/node_modules/@radix-ui/react-collection/dist/index.js.map +1 -0
  194. package/dist/node_modules/@radix-ui/react-collection/node_modules/@radix-ui/react-slot/dist/index.js +90 -0
  195. package/dist/node_modules/@radix-ui/react-collection/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
  196. package/dist/node_modules/@radix-ui/react-compose-refs/dist/index.js +40 -0
  197. package/dist/node_modules/@radix-ui/react-compose-refs/dist/index.js.map +1 -0
  198. package/dist/node_modules/@radix-ui/react-context/dist/index.js +82 -0
  199. package/dist/node_modules/@radix-ui/react-context/dist/index.js.map +1 -0
  200. package/dist/node_modules/@radix-ui/react-dialog/dist/index.js +342 -0
  201. package/dist/node_modules/@radix-ui/react-dialog/dist/index.js.map +1 -0
  202. package/dist/node_modules/@radix-ui/react-dialog/node_modules/@radix-ui/react-slot/dist/index.js +90 -0
  203. package/dist/node_modules/@radix-ui/react-dialog/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
  204. package/dist/node_modules/@radix-ui/react-direction/dist/index.js +11 -0
  205. package/dist/node_modules/@radix-ui/react-direction/dist/index.js.map +1 -0
  206. package/dist/node_modules/@radix-ui/react-dismissable-layer/dist/index.js +217 -0
  207. package/dist/node_modules/@radix-ui/react-dismissable-layer/dist/index.js.map +1 -0
  208. package/dist/node_modules/@radix-ui/react-dropdown-menu/dist/index.js +299 -0
  209. package/dist/node_modules/@radix-ui/react-dropdown-menu/dist/index.js.map +1 -0
  210. package/dist/node_modules/@radix-ui/react-focus-guards/dist/index.js +30 -0
  211. package/dist/node_modules/@radix-ui/react-focus-guards/dist/index.js.map +1 -0
  212. package/dist/node_modules/@radix-ui/react-focus-scope/dist/index.js +209 -0
  213. package/dist/node_modules/@radix-ui/react-focus-scope/dist/index.js.map +1 -0
  214. package/dist/node_modules/@radix-ui/react-id/dist/index.js +15 -0
  215. package/dist/node_modules/@radix-ui/react-id/dist/index.js.map +1 -0
  216. package/dist/node_modules/@radix-ui/react-label/dist/index.js +27 -0
  217. package/dist/node_modules/@radix-ui/react-label/dist/index.js.map +1 -0
  218. package/dist/node_modules/@radix-ui/react-label/node_modules/@radix-ui/react-primitive/dist/index.js +40 -0
  219. package/dist/node_modules/@radix-ui/react-label/node_modules/@radix-ui/react-primitive/dist/index.js.map +1 -0
  220. package/dist/node_modules/@radix-ui/react-menu/dist/index.js +881 -0
  221. package/dist/node_modules/@radix-ui/react-menu/dist/index.js.map +1 -0
  222. package/dist/node_modules/@radix-ui/react-menu/node_modules/@radix-ui/react-slot/dist/index.js +90 -0
  223. package/dist/node_modules/@radix-ui/react-menu/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
  224. package/dist/node_modules/@radix-ui/react-popover/dist/index.js +314 -0
  225. package/dist/node_modules/@radix-ui/react-popover/dist/index.js.map +1 -0
  226. package/dist/node_modules/@radix-ui/react-popover/node_modules/@radix-ui/react-slot/dist/index.js +90 -0
  227. package/dist/node_modules/@radix-ui/react-popover/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
  228. package/dist/node_modules/@radix-ui/react-popper/dist/index.js +294 -0
  229. package/dist/node_modules/@radix-ui/react-popper/dist/index.js.map +1 -0
  230. package/dist/node_modules/@radix-ui/react-portal/dist/index.js +19 -0
  231. package/dist/node_modules/@radix-ui/react-portal/dist/index.js.map +1 -0
  232. package/dist/node_modules/@radix-ui/react-presence/dist/index.js +130 -0
  233. package/dist/node_modules/@radix-ui/react-presence/dist/index.js.map +1 -0
  234. package/dist/node_modules/@radix-ui/react-primitive/dist/index.js +44 -0
  235. package/dist/node_modules/@radix-ui/react-primitive/dist/index.js.map +1 -0
  236. package/dist/node_modules/@radix-ui/react-primitive/node_modules/@radix-ui/react-slot/dist/index.js +90 -0
  237. package/dist/node_modules/@radix-ui/react-primitive/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
  238. package/dist/node_modules/@radix-ui/react-progress/dist/index.js +97 -0
  239. package/dist/node_modules/@radix-ui/react-progress/dist/index.js.map +1 -0
  240. package/dist/node_modules/@radix-ui/react-progress/node_modules/@radix-ui/react-context/dist/index.js +66 -0
  241. package/dist/node_modules/@radix-ui/react-progress/node_modules/@radix-ui/react-context/dist/index.js.map +1 -0
  242. package/dist/node_modules/@radix-ui/react-progress/node_modules/@radix-ui/react-primitive/dist/index.js +40 -0
  243. package/dist/node_modules/@radix-ui/react-progress/node_modules/@radix-ui/react-primitive/dist/index.js.map +1 -0
  244. package/dist/node_modules/@radix-ui/react-roving-focus/dist/index.js +228 -0
  245. package/dist/node_modules/@radix-ui/react-roving-focus/dist/index.js.map +1 -0
  246. package/dist/node_modules/@radix-ui/react-scroll-area/dist/index.js +728 -0
  247. package/dist/node_modules/@radix-ui/react-scroll-area/dist/index.js.map +1 -0
  248. package/dist/node_modules/@radix-ui/react-select/dist/index.js +1200 -0
  249. package/dist/node_modules/@radix-ui/react-select/dist/index.js.map +1 -0
  250. package/dist/node_modules/@radix-ui/react-select/node_modules/@radix-ui/react-slot/dist/index.js +90 -0
  251. package/dist/node_modules/@radix-ui/react-select/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
  252. package/dist/node_modules/@radix-ui/react-separator/dist/index.js +31 -0
  253. package/dist/node_modules/@radix-ui/react-separator/dist/index.js.map +1 -0
  254. package/dist/node_modules/@radix-ui/react-separator/node_modules/@radix-ui/react-primitive/dist/index.js +40 -0
  255. package/dist/node_modules/@radix-ui/react-separator/node_modules/@radix-ui/react-primitive/dist/index.js.map +1 -0
  256. package/dist/node_modules/@radix-ui/react-slot/dist/index.js +107 -0
  257. package/dist/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
  258. package/dist/node_modules/@radix-ui/react-switch/dist/index.js +156 -0
  259. package/dist/node_modules/@radix-ui/react-switch/dist/index.js.map +1 -0
  260. package/dist/node_modules/@radix-ui/react-tabs/dist/index.js +195 -0
  261. package/dist/node_modules/@radix-ui/react-tabs/dist/index.js.map +1 -0
  262. package/dist/node_modules/@radix-ui/react-toast/dist/index.js +645 -0
  263. package/dist/node_modules/@radix-ui/react-toast/dist/index.js.map +1 -0
  264. package/dist/node_modules/@radix-ui/react-tooltip/dist/index.js +501 -0
  265. package/dist/node_modules/@radix-ui/react-tooltip/dist/index.js.map +1 -0
  266. package/dist/node_modules/@radix-ui/react-tooltip/node_modules/@radix-ui/react-slot/dist/index.js +16 -0
  267. package/dist/node_modules/@radix-ui/react-tooltip/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
  268. package/dist/node_modules/@radix-ui/react-use-callback-ref/dist/index.js +15 -0
  269. package/dist/node_modules/@radix-ui/react-use-callback-ref/dist/index.js.map +1 -0
  270. package/dist/node_modules/@radix-ui/react-use-controllable-state/dist/index.js +72 -0
  271. package/dist/node_modules/@radix-ui/react-use-controllable-state/dist/index.js.map +1 -0
  272. package/dist/node_modules/@radix-ui/react-use-escape-keydown/dist/index.js +18 -0
  273. package/dist/node_modules/@radix-ui/react-use-escape-keydown/dist/index.js.map +1 -0
  274. package/dist/node_modules/@radix-ui/react-use-is-hydrated/dist/index.js +16 -0
  275. package/dist/node_modules/@radix-ui/react-use-is-hydrated/dist/index.js.map +1 -0
  276. package/dist/node_modules/@radix-ui/react-use-layout-effect/dist/index.js +7 -0
  277. package/dist/node_modules/@radix-ui/react-use-layout-effect/dist/index.js.map +1 -0
  278. package/dist/node_modules/@radix-ui/react-use-previous/dist/index.js +15 -0
  279. package/dist/node_modules/@radix-ui/react-use-previous/dist/index.js.map +1 -0
  280. package/dist/node_modules/@radix-ui/react-use-size/dist/index.js +40 -0
  281. package/dist/node_modules/@radix-ui/react-use-size/dist/index.js.map +1 -0
  282. package/dist/node_modules/@radix-ui/react-visually-hidden/dist/index.js +37 -0
  283. package/dist/node_modules/@radix-ui/react-visually-hidden/dist/index.js.map +1 -0
  284. package/dist/node_modules/aria-hidden/dist/es2015/index.js +123 -0
  285. package/dist/node_modules/aria-hidden/dist/es2015/index.js.map +1 -0
  286. package/dist/node_modules/class-variance-authority/dist/index.js +46 -0
  287. package/dist/node_modules/class-variance-authority/dist/index.js.map +1 -0
  288. package/dist/node_modules/clsx/dist/clsx.js +17 -0
  289. package/dist/node_modules/clsx/dist/clsx.js.map +1 -0
  290. package/dist/node_modules/get-nonce/dist/es2015/index.js +10 -0
  291. package/dist/node_modules/get-nonce/dist/es2015/index.js.map +1 -0
  292. package/dist/node_modules/lucide-react/dist/esm/Icon.js +43 -0
  293. package/dist/node_modules/lucide-react/dist/esm/Icon.js.map +1 -0
  294. package/dist/node_modules/lucide-react/dist/esm/createLucideIcon.js +25 -0
  295. package/dist/node_modules/lucide-react/dist/esm/createLucideIcon.js.map +1 -0
  296. package/dist/node_modules/lucide-react/dist/esm/defaultAttributes.js +21 -0
  297. package/dist/node_modules/lucide-react/dist/esm/defaultAttributes.js.map +1 -0
  298. package/dist/node_modules/lucide-react/dist/esm/icons/ban.js +15 -0
  299. package/dist/node_modules/lucide-react/dist/esm/icons/ban.js.map +1 -0
  300. package/dist/node_modules/lucide-react/dist/esm/icons/calendar.js +17 -0
  301. package/dist/node_modules/lucide-react/dist/esm/icons/calendar.js.map +1 -0
  302. package/dist/node_modules/lucide-react/dist/esm/icons/check.js +12 -0
  303. package/dist/node_modules/lucide-react/dist/esm/icons/check.js.map +1 -0
  304. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-down.js +14 -0
  305. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-down.js.map +1 -0
  306. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-left.js +14 -0
  307. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-left.js.map +1 -0
  308. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-right.js +14 -0
  309. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-right.js.map +1 -0
  310. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-up.js +12 -0
  311. package/dist/node_modules/lucide-react/dist/esm/icons/chevron-up.js.map +1 -0
  312. package/dist/node_modules/lucide-react/dist/esm/icons/circle-alert.js +16 -0
  313. package/dist/node_modules/lucide-react/dist/esm/icons/circle-alert.js.map +1 -0
  314. package/dist/node_modules/lucide-react/dist/esm/icons/circle-check.js +15 -0
  315. package/dist/node_modules/lucide-react/dist/esm/icons/circle-check.js.map +1 -0
  316. package/dist/node_modules/lucide-react/dist/esm/icons/circle-minus.js +15 -0
  317. package/dist/node_modules/lucide-react/dist/esm/icons/circle-minus.js.map +1 -0
  318. package/dist/node_modules/lucide-react/dist/esm/icons/circle-x.js +16 -0
  319. package/dist/node_modules/lucide-react/dist/esm/icons/circle-x.js.map +1 -0
  320. package/dist/node_modules/lucide-react/dist/esm/icons/circle.js +14 -0
  321. package/dist/node_modules/lucide-react/dist/esm/icons/circle.js.map +1 -0
  322. package/dist/node_modules/lucide-react/dist/esm/icons/clock.js +15 -0
  323. package/dist/node_modules/lucide-react/dist/esm/icons/clock.js.map +1 -0
  324. package/dist/node_modules/lucide-react/dist/esm/icons/flag.js +15 -0
  325. package/dist/node_modules/lucide-react/dist/esm/icons/flag.js.map +1 -0
  326. package/dist/node_modules/lucide-react/dist/esm/icons/git-branch.js +17 -0
  327. package/dist/node_modules/lucide-react/dist/esm/icons/git-branch.js.map +1 -0
  328. package/dist/node_modules/lucide-react/dist/esm/icons/info.js +16 -0
  329. package/dist/node_modules/lucide-react/dist/esm/icons/info.js.map +1 -0
  330. package/dist/node_modules/lucide-react/dist/esm/icons/loader-circle.js +14 -0
  331. package/dist/node_modules/lucide-react/dist/esm/icons/loader-circle.js.map +1 -0
  332. package/dist/node_modules/lucide-react/dist/esm/icons/minus.js +12 -0
  333. package/dist/node_modules/lucide-react/dist/esm/icons/minus.js.map +1 -0
  334. package/dist/node_modules/lucide-react/dist/esm/icons/pause.js +15 -0
  335. package/dist/node_modules/lucide-react/dist/esm/icons/pause.js.map +1 -0
  336. package/dist/node_modules/lucide-react/dist/esm/icons/play.js +14 -0
  337. package/dist/node_modules/lucide-react/dist/esm/icons/play.js.map +1 -0
  338. package/dist/node_modules/lucide-react/dist/esm/icons/send.js +21 -0
  339. package/dist/node_modules/lucide-react/dist/esm/icons/send.js.map +1 -0
  340. package/dist/node_modules/lucide-react/dist/esm/icons/tag.js +21 -0
  341. package/dist/node_modules/lucide-react/dist/esm/icons/tag.js.map +1 -0
  342. package/dist/node_modules/lucide-react/dist/esm/icons/timer.js +16 -0
  343. package/dist/node_modules/lucide-react/dist/esm/icons/timer.js.map +1 -0
  344. package/dist/node_modules/lucide-react/dist/esm/icons/trending-down.js +15 -0
  345. package/dist/node_modules/lucide-react/dist/esm/icons/trending-down.js.map +1 -0
  346. package/dist/node_modules/lucide-react/dist/esm/icons/trending-up.js +15 -0
  347. package/dist/node_modules/lucide-react/dist/esm/icons/trending-up.js.map +1 -0
  348. package/dist/node_modules/lucide-react/dist/esm/icons/triangle-alert.js +22 -0
  349. package/dist/node_modules/lucide-react/dist/esm/icons/triangle-alert.js.map +1 -0
  350. package/dist/node_modules/lucide-react/dist/esm/icons/x.js +15 -0
  351. package/dist/node_modules/lucide-react/dist/esm/icons/x.js.map +1 -0
  352. package/dist/node_modules/lucide-react/dist/esm/icons/zap.js +20 -0
  353. package/dist/node_modules/lucide-react/dist/esm/icons/zap.js.map +1 -0
  354. package/dist/node_modules/lucide-react/dist/esm/shared/src/utils.js +15 -0
  355. package/dist/node_modules/lucide-react/dist/esm/shared/src/utils.js.map +1 -0
  356. package/dist/node_modules/react-remove-scroll/dist/es2015/Combination.js +12 -0
  357. package/dist/node_modules/react-remove-scroll/dist/es2015/Combination.js.map +1 -0
  358. package/dist/node_modules/react-remove-scroll/dist/es2015/SideEffect.js +181 -0
  359. package/dist/node_modules/react-remove-scroll/dist/es2015/SideEffect.js.map +1 -0
  360. package/dist/node_modules/react-remove-scroll/dist/es2015/UI.js +39 -0
  361. package/dist/node_modules/react-remove-scroll/dist/es2015/UI.js.map +1 -0
  362. package/dist/node_modules/react-remove-scroll/dist/es2015/aggresiveCapture.js +20 -0
  363. package/dist/node_modules/react-remove-scroll/dist/es2015/aggresiveCapture.js.map +1 -0
  364. package/dist/node_modules/react-remove-scroll/dist/es2015/handleScroll.js +103 -0
  365. package/dist/node_modules/react-remove-scroll/dist/es2015/handleScroll.js.map +1 -0
  366. package/dist/node_modules/react-remove-scroll/dist/es2015/medium.js +6 -0
  367. package/dist/node_modules/react-remove-scroll/dist/es2015/medium.js.map +1 -0
  368. package/dist/node_modules/react-remove-scroll/dist/es2015/sidecar.js +8 -0
  369. package/dist/node_modules/react-remove-scroll/dist/es2015/sidecar.js.map +1 -0
  370. package/dist/node_modules/react-remove-scroll-bar/dist/es2015/component.js +48 -0
  371. package/dist/node_modules/react-remove-scroll-bar/dist/es2015/component.js.map +1 -0
  372. package/dist/node_modules/react-remove-scroll-bar/dist/es2015/constants.js +11 -0
  373. package/dist/node_modules/react-remove-scroll-bar/dist/es2015/constants.js.map +1 -0
  374. package/dist/node_modules/react-remove-scroll-bar/dist/es2015/utils.js +38 -0
  375. package/dist/node_modules/react-remove-scroll-bar/dist/es2015/utils.js.map +1 -0
  376. package/dist/node_modules/react-style-singleton/dist/es2015/component.js +14 -0
  377. package/dist/node_modules/react-style-singleton/dist/es2015/component.js.map +1 -0
  378. package/dist/node_modules/react-style-singleton/dist/es2015/hook.js +17 -0
  379. package/dist/node_modules/react-style-singleton/dist/es2015/hook.js.map +1 -0
  380. package/dist/node_modules/react-style-singleton/dist/es2015/singleton.js +49 -0
  381. package/dist/node_modules/react-style-singleton/dist/es2015/singleton.js.map +1 -0
  382. package/dist/node_modules/tailwind-merge/dist/bundle-mjs.js +2467 -0
  383. package/dist/node_modules/tailwind-merge/dist/bundle-mjs.js.map +1 -0
  384. package/dist/node_modules/tslib/tslib.es6.js +40 -0
  385. package/dist/node_modules/tslib/tslib.es6.js.map +1 -0
  386. package/dist/node_modules/use-callback-ref/dist/es2015/assignRef.js +12 -0
  387. package/dist/node_modules/use-callback-ref/dist/es2015/assignRef.js.map +1 -0
  388. package/dist/node_modules/use-callback-ref/dist/es2015/useMergeRef.js +36 -0
  389. package/dist/node_modules/use-callback-ref/dist/es2015/useMergeRef.js.map +1 -0
  390. package/dist/node_modules/use-callback-ref/dist/es2015/useRef.js +30 -0
  391. package/dist/node_modules/use-callback-ref/dist/es2015/useRef.js.map +1 -0
  392. package/dist/node_modules/use-sidecar/dist/es2015/exports.js +22 -0
  393. package/dist/node_modules/use-sidecar/dist/es2015/exports.js.map +1 -0
  394. package/dist/node_modules/use-sidecar/dist/es2015/medium.js +89 -0
  395. package/dist/node_modules/use-sidecar/dist/es2015/medium.js.map +1 -0
  396. package/dist/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js +78 -0
  397. package/dist/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js.map +1 -0
  398. package/dist/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.js +63 -0
  399. package/dist/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.js.map +1 -0
  400. package/dist/node_modules/use-sync-external-store/shim/index.js +18 -0
  401. package/dist/node_modules/use-sync-external-store/shim/index.js.map +1 -0
  402. package/dist/types/automation.d.ts +59 -0
  403. package/dist/types/automation.d.ts.map +1 -0
  404. package/dist/types/common.d.ts +38 -0
  405. package/dist/types/common.d.ts.map +1 -0
  406. package/package.json +119 -0
  407. package/registry/registry.json +218 -0
  408. package/src/components/automation/metric-card.tsx +113 -0
  409. package/src/components/automation/status-badge.tsx +136 -0
  410. package/src/components/automation/task-card.tsx +164 -0
  411. package/src/components/automation/workflow-node.tsx +186 -0
  412. package/src/components/layout/app-shell.tsx +58 -0
  413. package/src/components/layout/header.tsx +39 -0
  414. package/src/components/layout/page-header.tsx +42 -0
  415. package/src/components/layout/sidebar.tsx +190 -0
  416. package/src/components/ui/accordion.tsx +57 -0
  417. package/src/components/ui/alert.tsx +93 -0
  418. package/src/components/ui/avatar.tsx +94 -0
  419. package/src/components/ui/badge.tsx +69 -0
  420. package/src/components/ui/button.tsx +106 -0
  421. package/src/components/ui/card.tsx +96 -0
  422. package/src/components/ui/checkbox.tsx +40 -0
  423. package/src/components/ui/dialog.tsx +129 -0
  424. package/src/components/ui/dropdown-menu.tsx +194 -0
  425. package/src/components/ui/input.tsx +80 -0
  426. package/src/components/ui/label.tsx +37 -0
  427. package/src/components/ui/popover.tsx +29 -0
  428. package/src/components/ui/progress.tsx +92 -0
  429. package/src/components/ui/scroll-area.tsx +43 -0
  430. package/src/components/ui/select.tsx +157 -0
  431. package/src/components/ui/separator.tsx +56 -0
  432. package/src/components/ui/skeleton.tsx +41 -0
  433. package/src/components/ui/spinner.tsx +50 -0
  434. package/src/components/ui/switch.tsx +46 -0
  435. package/src/components/ui/table.tsx +117 -0
  436. package/src/components/ui/tabs.tsx +107 -0
  437. package/src/components/ui/textarea.tsx +50 -0
  438. package/src/components/ui/toast.tsx +139 -0
  439. package/src/components/ui/tooltip.tsx +28 -0
  440. package/src/hooks/use-debounce.ts +28 -0
  441. package/src/hooks/use-local-storage.ts +63 -0
  442. package/src/hooks/use-media-query.ts +29 -0
  443. package/src/index.ts +197 -0
  444. package/src/lib/colors.ts +102 -0
  445. package/src/lib/utils.ts +10 -0
  446. package/src/styles/globals.css +230 -0
  447. package/src/types/automation.ts +74 -0
  448. package/src/types/common.ts +48 -0
  449. package/tailwind/preset.cjs +98 -0
  450. package/tailwind/preset.css +5 -0
  451. package/tailwind/preset.ts +159 -0
@@ -0,0 +1,114 @@
1
+ import { jsxs, jsx } from "react/jsx-runtime";
2
+ import { cn } from "../../lib/utils.js";
3
+ import { Card, CardContent } from "../ui/card.js";
4
+ import { Avatar, AvatarImage, AvatarFallback } from "../ui/avatar.js";
5
+ import { Badge } from "../ui/badge.js";
6
+ import { StatusBadge } from "./status-badge.js";
7
+ import Flag from "../../node_modules/lucide-react/dist/esm/icons/flag.js";
8
+ import Calendar from "../../node_modules/lucide-react/dist/esm/icons/calendar.js";
9
+ import Tag from "../../node_modules/lucide-react/dist/esm/icons/tag.js";
10
+ const PRIORITY_CONFIG = {
11
+ critical: { label: "Critical", color: "text-destructive", dotClass: "bg-destructive" },
12
+ high: { label: "High", color: "text-warning", dotClass: "bg-warning" },
13
+ medium: { label: "Medium", color: "text-info", dotClass: "bg-info" },
14
+ low: { label: "Low", color: "text-muted-foreground", dotClass: "bg-muted-foreground" }
15
+ };
16
+ const TASK_TO_WORKFLOW_STATUS = {
17
+ running: "running",
18
+ completed: "completed",
19
+ failed: "failed",
20
+ pending: "pending",
21
+ skipped: "cancelled",
22
+ cancelled: "cancelled"
23
+ };
24
+ function TaskCard({
25
+ className,
26
+ task,
27
+ showPriority = true,
28
+ onSelect,
29
+ compact = false,
30
+ ...props
31
+ }) {
32
+ const priority = PRIORITY_CONFIG[task.priority];
33
+ const workflowStatus = TASK_TO_WORKFLOW_STATUS[task.status];
34
+ const formattedDue = task.dueAt ? new Date(task.dueAt).toLocaleDateString("en-US", { month: "short", day: "numeric" }) : null;
35
+ const isOverdue = task.dueAt && task.status !== "completed" && task.status !== "cancelled" && new Date(task.dueAt) < /* @__PURE__ */ new Date();
36
+ if (compact) {
37
+ return /* @__PURE__ */ jsxs(
38
+ "div",
39
+ {
40
+ className: cn(
41
+ "flex items-center gap-3 py-2 px-3 rounded-md hover:bg-muted/50 transition-colors",
42
+ onSelect && "cursor-pointer",
43
+ className
44
+ ),
45
+ onClick: () => onSelect == null ? void 0 : onSelect(task),
46
+ ...props,
47
+ children: [
48
+ /* @__PURE__ */ jsx(StatusBadge, { status: workflowStatus, size: "xs" }),
49
+ /* @__PURE__ */ jsx("span", { className: "flex-1 text-sm truncate", children: task.title }),
50
+ task.assignee && /* @__PURE__ */ jsxs(Avatar, { size: "xs", children: [
51
+ task.assignee.avatarUrl && /* @__PURE__ */ jsx(AvatarImage, { src: task.assignee.avatarUrl, alt: task.assignee.name }),
52
+ /* @__PURE__ */ jsx(AvatarFallback, { children: task.assignee.initials ?? task.assignee.name.slice(0, 2).toUpperCase() })
53
+ ] })
54
+ ]
55
+ }
56
+ );
57
+ }
58
+ return /* @__PURE__ */ jsx(
59
+ Card,
60
+ {
61
+ className: cn(
62
+ "transition-all duration-200",
63
+ onSelect && "cursor-pointer hover:border-primary/40 hover:shadow-glow-primary",
64
+ className
65
+ ),
66
+ onClick: () => onSelect == null ? void 0 : onSelect(task),
67
+ ...props,
68
+ children: /* @__PURE__ */ jsx(CardContent, { className: "p-4", children: /* @__PURE__ */ jsxs("div", { className: "flex items-start justify-between gap-3", children: [
69
+ /* @__PURE__ */ jsxs("div", { className: "flex-1 min-w-0", children: [
70
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2 flex-wrap", children: [
71
+ /* @__PURE__ */ jsx("h4", { className: cn(
72
+ "text-sm font-medium leading-tight",
73
+ task.status === "completed" && "line-through text-muted-foreground"
74
+ ), children: task.title }),
75
+ /* @__PURE__ */ jsx(StatusBadge, { status: workflowStatus, size: "xs" })
76
+ ] }),
77
+ task.description && /* @__PURE__ */ jsx("p", { className: "mt-1 text-xs text-muted-foreground line-clamp-2", children: task.description }),
78
+ /* @__PURE__ */ jsxs("div", { className: "mt-3 flex flex-wrap items-center gap-3", children: [
79
+ showPriority && /* @__PURE__ */ jsxs("div", { className: cn("flex items-center gap-1 text-xs font-medium", priority.color), children: [
80
+ /* @__PURE__ */ jsx(Flag, { className: "h-3 w-3" }),
81
+ priority.label
82
+ ] }),
83
+ formattedDue && /* @__PURE__ */ jsxs("div", { className: cn(
84
+ "flex items-center gap-1 text-xs",
85
+ isOverdue ? "text-destructive font-medium" : "text-muted-foreground"
86
+ ), children: [
87
+ /* @__PURE__ */ jsx(Calendar, { className: "h-3 w-3" }),
88
+ isOverdue && "Overdue · ",
89
+ formattedDue
90
+ ] }),
91
+ task.tags && task.tags.length > 0 && /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1", children: [
92
+ /* @__PURE__ */ jsx(Tag, { className: "h-3 w-3 text-muted-foreground" }),
93
+ /* @__PURE__ */ jsxs("div", { className: "flex gap-1 flex-wrap", children: [
94
+ task.tags.slice(0, 3).map((tag) => /* @__PURE__ */ jsx(Badge, { variant: "muted", size: "sm", children: tag }, tag)),
95
+ task.tags.length > 3 && /* @__PURE__ */ jsxs(Badge, { variant: "muted", size: "sm", children: [
96
+ "+",
97
+ task.tags.length - 3
98
+ ] })
99
+ ] })
100
+ ] })
101
+ ] })
102
+ ] }),
103
+ task.assignee && /* @__PURE__ */ jsxs(Avatar, { size: "sm", children: [
104
+ task.assignee.avatarUrl && /* @__PURE__ */ jsx(AvatarImage, { src: task.assignee.avatarUrl, alt: task.assignee.name }),
105
+ /* @__PURE__ */ jsx(AvatarFallback, { children: task.assignee.initials ?? task.assignee.name.slice(0, 2).toUpperCase() })
106
+ ] })
107
+ ] }) })
108
+ }
109
+ );
110
+ }
111
+ export {
112
+ TaskCard
113
+ };
114
+ //# sourceMappingURL=task-card.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"task-card.js","sources":["../../../src/components/automation/task-card.tsx"],"sourcesContent":["import * as React from 'react'\nimport { Calendar, Flag, Tag } from 'lucide-react'\nimport { cn } from '@/lib/utils'\nimport { Card, CardContent } from '@/components/ui/card'\nimport { Avatar, AvatarFallback, AvatarImage } from '@/components/ui/avatar'\nimport { Badge } from '@/components/ui/badge'\nimport { StatusBadge } from './status-badge'\nimport type { Task, TaskPriority } from '@/types/automation'\n\nconst PRIORITY_CONFIG: Record<TaskPriority, { label: string; color: string; dotClass: string }> = {\n critical: { label: 'Critical', color: 'text-destructive', dotClass: 'bg-destructive' },\n high: { label: 'High', color: 'text-warning', dotClass: 'bg-warning' },\n medium: { label: 'Medium', color: 'text-info', dotClass: 'bg-info' },\n low: { label: 'Low', color: 'text-muted-foreground', dotClass: 'bg-muted-foreground' },\n}\n\n// Map TaskStatus to WorkflowStatus for the StatusBadge\nconst TASK_TO_WORKFLOW_STATUS = {\n running: 'running',\n completed: 'completed',\n failed: 'failed',\n pending: 'pending',\n skipped: 'cancelled',\n cancelled: 'cancelled',\n} as const\n\nexport interface TaskCardProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onSelect'> {\n task: Task\n /** Show/hide priority indicator */\n showPriority?: boolean\n /** Called when card is clicked */\n onSelect?: (task: Task) => void\n /** Compact single-line mode */\n compact?: boolean\n}\n\nfunction TaskCard({\n className,\n task,\n showPriority = true,\n onSelect,\n compact = false,\n ...props\n}: TaskCardProps) {\n const priority = PRIORITY_CONFIG[task.priority]\n const workflowStatus = TASK_TO_WORKFLOW_STATUS[task.status]\n\n const formattedDue = task.dueAt\n ? new Date(task.dueAt).toLocaleDateString('en-US', { month: 'short', day: 'numeric' })\n : null\n\n const isOverdue =\n task.dueAt &&\n task.status !== 'completed' &&\n task.status !== 'cancelled' &&\n new Date(task.dueAt) < new Date()\n\n if (compact) {\n return (\n <div\n className={cn(\n 'flex items-center gap-3 py-2 px-3 rounded-md hover:bg-muted/50 transition-colors',\n onSelect && 'cursor-pointer',\n className\n )}\n onClick={() => onSelect?.(task)}\n {...props}\n >\n <StatusBadge status={workflowStatus} size=\"xs\" />\n <span className=\"flex-1 text-sm truncate\">{task.title}</span>\n {task.assignee && (\n <Avatar size=\"xs\">\n {task.assignee.avatarUrl && <AvatarImage src={task.assignee.avatarUrl} alt={task.assignee.name} />}\n <AvatarFallback>{task.assignee.initials ?? task.assignee.name.slice(0, 2).toUpperCase()}</AvatarFallback>\n </Avatar>\n )}\n </div>\n )\n }\n\n return (\n <Card\n className={cn(\n 'transition-all duration-200',\n onSelect && 'cursor-pointer hover:border-primary/40 hover:shadow-glow-primary',\n className\n )}\n onClick={() => onSelect?.(task)}\n {...props}\n >\n <CardContent className=\"p-4\">\n <div className=\"flex items-start justify-between gap-3\">\n <div className=\"flex-1 min-w-0\">\n {/* Title + status */}\n <div className=\"flex items-center gap-2 flex-wrap\">\n <h4 className={cn(\n 'text-sm font-medium leading-tight',\n task.status === 'completed' && 'line-through text-muted-foreground'\n )}>\n {task.title}\n </h4>\n <StatusBadge status={workflowStatus} size=\"xs\" />\n </div>\n\n {task.description && (\n <p className=\"mt-1 text-xs text-muted-foreground line-clamp-2\">{task.description}</p>\n )}\n\n {/* Meta row */}\n <div className=\"mt-3 flex flex-wrap items-center gap-3\">\n {showPriority && (\n <div className={cn('flex items-center gap-1 text-xs font-medium', priority.color)}>\n <Flag className=\"h-3 w-3\" />\n {priority.label}\n </div>\n )}\n\n {formattedDue && (\n <div className={cn(\n 'flex items-center gap-1 text-xs',\n isOverdue ? 'text-destructive font-medium' : 'text-muted-foreground'\n )}>\n <Calendar className=\"h-3 w-3\" />\n {isOverdue && 'Overdue · '}\n {formattedDue}\n </div>\n )}\n\n {task.tags && task.tags.length > 0 && (\n <div className=\"flex items-center gap-1\">\n <Tag className=\"h-3 w-3 text-muted-foreground\" />\n <div className=\"flex gap-1 flex-wrap\">\n {task.tags.slice(0, 3).map((tag) => (\n <Badge key={tag} variant=\"muted\" size=\"sm\">\n {tag}\n </Badge>\n ))}\n {task.tags.length > 3 && (\n <Badge variant=\"muted\" size=\"sm\">+{task.tags.length - 3}</Badge>\n )}\n </div>\n </div>\n )}\n </div>\n </div>\n\n {/* Assignee */}\n {task.assignee && (\n <Avatar size=\"sm\">\n {task.assignee.avatarUrl && (\n <AvatarImage src={task.assignee.avatarUrl} alt={task.assignee.name} />\n )}\n <AvatarFallback>\n {task.assignee.initials ?? task.assignee.name.slice(0, 2).toUpperCase()}\n </AvatarFallback>\n </Avatar>\n )}\n </div>\n </CardContent>\n </Card>\n )\n}\n\nexport { TaskCard }\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ import { WorkflowNodeData } from '../../types/automation';
2
+ import * as React from 'react';
3
+ export interface WorkflowNodeProps extends React.HTMLAttributes<HTMLDivElement> {
4
+ node: WorkflowNodeData;
5
+ /** Show as a compact inline node */
6
+ compact?: boolean;
7
+ /** Whether to show the connector line below */
8
+ showConnector?: boolean;
9
+ /** Whether this is the last node in the chain */
10
+ isLast?: boolean;
11
+ }
12
+ declare function WorkflowNode({ className, node, compact, showConnector, isLast, ...props }: WorkflowNodeProps): import("react/jsx-runtime").JSX.Element;
13
+ /** Renders a vertical workflow pipeline from an array of nodes */
14
+ export interface WorkflowPipelineProps extends React.HTMLAttributes<HTMLDivElement> {
15
+ nodes: WorkflowNodeData[];
16
+ compact?: boolean;
17
+ }
18
+ declare function WorkflowPipeline({ className, nodes, compact, ...props }: WorkflowPipelineProps): import("react/jsx-runtime").JSX.Element;
19
+ export { WorkflowNode, WorkflowPipeline };
20
+ //# sourceMappingURL=workflow-node.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-node.d.ts","sourceRoot":"","sources":["../../../src/components/automation/workflow-node.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAc9B,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AA8C1D,MAAM,WAAW,iBAAkB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC7E,IAAI,EAAE,gBAAgB,CAAA;IACtB,oCAAoC;IACpC,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,+CAA+C;IAC/C,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,iDAAiD;IACjD,MAAM,CAAC,EAAE,OAAO,CAAA;CACjB;AAED,iBAAS,YAAY,CAAC,EACpB,SAAS,EACT,IAAI,EACJ,OAAe,EACf,aAAqB,EACrB,MAAc,EACd,GAAG,KAAK,EACT,EAAE,iBAAiB,2CAoFnB;AAED,kEAAkE;AAClE,MAAM,WAAW,qBAAsB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACjF,KAAK,EAAE,gBAAgB,EAAE,CAAA;IACzB,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB;AAED,iBAAS,gBAAgB,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,OAAe,EAAE,GAAG,KAAK,EAAE,EAAE,qBAAqB,2CAc/F;AAED,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,CAAA"}
@@ -0,0 +1,132 @@
1
+ import { jsxs, jsx, Fragment } from "react/jsx-runtime";
2
+ import { cn } from "../../lib/utils.js";
3
+ import Send from "../../node_modules/lucide-react/dist/esm/icons/send.js";
4
+ import Timer from "../../node_modules/lucide-react/dist/esm/icons/timer.js";
5
+ import GitBranch from "../../node_modules/lucide-react/dist/esm/icons/git-branch.js";
6
+ import Play from "../../node_modules/lucide-react/dist/esm/icons/play.js";
7
+ import Zap from "../../node_modules/lucide-react/dist/esm/icons/zap.js";
8
+ import Clock from "../../node_modules/lucide-react/dist/esm/icons/clock.js";
9
+ import CircleAlert from "../../node_modules/lucide-react/dist/esm/icons/circle-alert.js";
10
+ import Pause from "../../node_modules/lucide-react/dist/esm/icons/pause.js";
11
+ import CircleCheck from "../../node_modules/lucide-react/dist/esm/icons/circle-check.js";
12
+ import LoaderCircle from "../../node_modules/lucide-react/dist/esm/icons/loader-circle.js";
13
+ const NODE_TYPE_CONFIG = {
14
+ trigger: {
15
+ icon: Zap,
16
+ label: "Trigger",
17
+ className: "border-primary/50 bg-primary/10 text-primary",
18
+ headerClass: "bg-primary/10"
19
+ },
20
+ action: {
21
+ icon: Play,
22
+ label: "Action",
23
+ className: "border-border bg-card text-foreground",
24
+ headerClass: "bg-muted"
25
+ },
26
+ condition: {
27
+ icon: GitBranch,
28
+ label: "Condition",
29
+ className: "border-info/50 bg-info/10 text-foreground",
30
+ headerClass: "bg-info/10"
31
+ },
32
+ delay: {
33
+ icon: Timer,
34
+ label: "Delay",
35
+ className: "border-warning/50 bg-warning/10 text-foreground",
36
+ headerClass: "bg-warning/10"
37
+ },
38
+ output: {
39
+ icon: Send,
40
+ label: "Output",
41
+ className: "border-success/50 bg-success/10 text-foreground",
42
+ headerClass: "bg-success/10"
43
+ }
44
+ };
45
+ const STATUS_INDICATOR = {
46
+ running: { icon: LoaderCircle, className: "text-workflow-running animate-spin" },
47
+ completed: { icon: CircleCheck, className: "text-workflow-completed" },
48
+ failed: { icon: CircleAlert, className: "text-workflow-failed" },
49
+ pending: { icon: Clock, className: "text-workflow-pending" },
50
+ paused: { icon: Pause, className: "text-workflow-paused" },
51
+ cancelled: { icon: CircleAlert, className: "text-workflow-cancelled" },
52
+ idle: { icon: Clock, className: "text-muted-foreground" },
53
+ scheduled: { icon: Clock, className: "text-info" }
54
+ };
55
+ function WorkflowNode({
56
+ className,
57
+ node,
58
+ compact = false,
59
+ showConnector = false,
60
+ isLast = false,
61
+ ...props
62
+ }) {
63
+ const typeConfig = NODE_TYPE_CONFIG[node.type];
64
+ const statusIndicator = STATUS_INDICATOR[node.status];
65
+ const TypeIcon = typeConfig.icon;
66
+ const StatusIcon = statusIndicator.icon;
67
+ const formatDuration = (ms) => {
68
+ if (ms < 1e3) return `${ms}ms`;
69
+ if (ms < 6e4) return `${(ms / 1e3).toFixed(1)}s`;
70
+ return `${Math.floor(ms / 6e4)}m ${Math.floor(ms % 6e4 / 1e3)}s`;
71
+ };
72
+ return /* @__PURE__ */ jsxs("div", { className: "relative flex flex-col items-center", children: [
73
+ /* @__PURE__ */ jsx(
74
+ "div",
75
+ {
76
+ className: cn(
77
+ "w-full rounded-lg border transition-all duration-200",
78
+ typeConfig.className,
79
+ node.status === "running" && "shadow-glow-primary animate-workflow-pulse",
80
+ node.status === "failed" && "border-workflow-failed/60",
81
+ compact ? "p-3" : "overflow-hidden",
82
+ className
83
+ ),
84
+ ...props,
85
+ children: compact ? /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
86
+ /* @__PURE__ */ jsx("div", { className: cn("flex h-6 w-6 shrink-0 items-center justify-center rounded", typeConfig.headerClass), children: /* @__PURE__ */ jsx(TypeIcon, { className: "h-3.5 w-3.5" }) }),
87
+ /* @__PURE__ */ jsx("span", { className: "flex-1 text-sm font-medium truncate", children: node.label }),
88
+ /* @__PURE__ */ jsx(StatusIcon, { className: cn("h-4 w-4 shrink-0", statusIndicator.className) })
89
+ ] }) : /* @__PURE__ */ jsxs(Fragment, { children: [
90
+ /* @__PURE__ */ jsxs("div", { className: cn("flex items-center gap-2.5 px-3 py-2.5", typeConfig.headerClass), children: [
91
+ /* @__PURE__ */ jsx("div", { className: "flex h-7 w-7 shrink-0 items-center justify-center rounded-md bg-background/50", children: /* @__PURE__ */ jsx(TypeIcon, { className: "h-4 w-4" }) }),
92
+ /* @__PURE__ */ jsxs("div", { className: "flex-1 min-w-0", children: [
93
+ /* @__PURE__ */ jsx("div", { className: "flex items-center gap-1.5", children: /* @__PURE__ */ jsx("span", { className: "text-[10px] font-semibold uppercase tracking-wider opacity-70", children: typeConfig.label }) }),
94
+ /* @__PURE__ */ jsx("p", { className: "text-sm font-semibold leading-tight truncate", children: node.label })
95
+ ] }),
96
+ /* @__PURE__ */ jsx(StatusIcon, { className: cn("h-4 w-4 shrink-0", statusIndicator.className) })
97
+ ] }),
98
+ (node.description || node.error || node.duration !== void 0) && /* @__PURE__ */ jsxs("div", { className: "px-3 py-2.5 space-y-1.5", children: [
99
+ node.description && /* @__PURE__ */ jsx("p", { className: "text-xs text-muted-foreground", children: node.description }),
100
+ node.error && /* @__PURE__ */ jsx("p", { className: "text-xs text-destructive font-mono bg-destructive/5 rounded px-2 py-1", children: node.error }),
101
+ node.duration !== void 0 && /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1 text-[10px] text-muted-foreground", children: [
102
+ /* @__PURE__ */ jsx(Clock, { className: "h-3 w-3" }),
103
+ /* @__PURE__ */ jsx("span", { children: formatDuration(node.duration) })
104
+ ] })
105
+ ] })
106
+ ] })
107
+ }
108
+ ),
109
+ showConnector && !isLast && /* @__PURE__ */ jsxs("div", { className: "flex flex-col items-center my-1", children: [
110
+ /* @__PURE__ */ jsx("div", { className: "w-px h-4 bg-border" }),
111
+ /* @__PURE__ */ jsx("div", { className: "w-1.5 h-1.5 rounded-full bg-border" }),
112
+ /* @__PURE__ */ jsx("div", { className: "w-px h-4 bg-border" })
113
+ ] })
114
+ ] });
115
+ }
116
+ function WorkflowPipeline({ className, nodes, compact = false, ...props }) {
117
+ return /* @__PURE__ */ jsx("div", { className: cn("flex flex-col", className), ...props, children: nodes.map((node, i) => /* @__PURE__ */ jsx(
118
+ WorkflowNode,
119
+ {
120
+ node,
121
+ compact,
122
+ showConnector: true,
123
+ isLast: i === nodes.length - 1
124
+ },
125
+ node.id
126
+ )) });
127
+ }
128
+ export {
129
+ WorkflowNode,
130
+ WorkflowPipeline
131
+ };
132
+ //# sourceMappingURL=workflow-node.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-node.js","sources":["../../../src/components/automation/workflow-node.tsx"],"sourcesContent":["import * as React from 'react'\nimport {\n Zap,\n Play,\n GitBranch,\n Timer,\n Send,\n AlertCircle,\n CheckCircle2,\n Loader2,\n Clock,\n Pause,\n} from 'lucide-react'\nimport { cn } from '@/lib/utils'\nimport type { WorkflowNodeData } from '@/types/automation'\n\nconst NODE_TYPE_CONFIG = {\n trigger: {\n icon: Zap,\n label: 'Trigger',\n className: 'border-primary/50 bg-primary/10 text-primary',\n headerClass: 'bg-primary/10',\n },\n action: {\n icon: Play,\n label: 'Action',\n className: 'border-border bg-card text-foreground',\n headerClass: 'bg-muted',\n },\n condition: {\n icon: GitBranch,\n label: 'Condition',\n className: 'border-info/50 bg-info/10 text-foreground',\n headerClass: 'bg-info/10',\n },\n delay: {\n icon: Timer,\n label: 'Delay',\n className: 'border-warning/50 bg-warning/10 text-foreground',\n headerClass: 'bg-warning/10',\n },\n output: {\n icon: Send,\n label: 'Output',\n className: 'border-success/50 bg-success/10 text-foreground',\n headerClass: 'bg-success/10',\n },\n}\n\nconst STATUS_INDICATOR = {\n running: { icon: Loader2, className: 'text-workflow-running animate-spin' },\n completed: { icon: CheckCircle2, className: 'text-workflow-completed' },\n failed: { icon: AlertCircle, className: 'text-workflow-failed' },\n pending: { icon: Clock, className: 'text-workflow-pending' },\n paused: { icon: Pause, className: 'text-workflow-paused' },\n cancelled: { icon: AlertCircle, className: 'text-workflow-cancelled' },\n idle: { icon: Clock, className: 'text-muted-foreground' },\n scheduled: { icon: Clock, className: 'text-info' },\n}\n\nexport interface WorkflowNodeProps extends React.HTMLAttributes<HTMLDivElement> {\n node: WorkflowNodeData\n /** Show as a compact inline node */\n compact?: boolean\n /** Whether to show the connector line below */\n showConnector?: boolean\n /** Whether this is the last node in the chain */\n isLast?: boolean\n}\n\nfunction WorkflowNode({\n className,\n node,\n compact = false,\n showConnector = false,\n isLast = false,\n ...props\n}: WorkflowNodeProps) {\n const typeConfig = NODE_TYPE_CONFIG[node.type]\n const statusIndicator = STATUS_INDICATOR[node.status]\n const TypeIcon = typeConfig.icon\n const StatusIcon = statusIndicator.icon\n\n const formatDuration = (ms: number) => {\n if (ms < 1000) return `${ms}ms`\n if (ms < 60000) return `${(ms / 1000).toFixed(1)}s`\n return `${Math.floor(ms / 60000)}m ${Math.floor((ms % 60000) / 1000)}s`\n }\n\n return (\n <div className=\"relative flex flex-col items-center\">\n <div\n className={cn(\n 'w-full rounded-lg border transition-all duration-200',\n typeConfig.className,\n node.status === 'running' && 'shadow-glow-primary animate-workflow-pulse',\n node.status === 'failed' && 'border-workflow-failed/60',\n compact ? 'p-3' : 'overflow-hidden',\n className\n )}\n {...props}\n >\n {compact ? (\n <div className=\"flex items-center gap-2\">\n <div className={cn('flex h-6 w-6 shrink-0 items-center justify-center rounded', typeConfig.headerClass)}>\n <TypeIcon className=\"h-3.5 w-3.5\" />\n </div>\n <span className=\"flex-1 text-sm font-medium truncate\">{node.label}</span>\n <StatusIcon className={cn('h-4 w-4 shrink-0', statusIndicator.className)} />\n </div>\n ) : (\n <>\n {/* Node header */}\n <div className={cn('flex items-center gap-2.5 px-3 py-2.5', typeConfig.headerClass)}>\n <div className=\"flex h-7 w-7 shrink-0 items-center justify-center rounded-md bg-background/50\">\n <TypeIcon className=\"h-4 w-4\" />\n </div>\n <div className=\"flex-1 min-w-0\">\n <div className=\"flex items-center gap-1.5\">\n <span className=\"text-[10px] font-semibold uppercase tracking-wider opacity-70\">\n {typeConfig.label}\n </span>\n </div>\n <p className=\"text-sm font-semibold leading-tight truncate\">{node.label}</p>\n </div>\n <StatusIcon className={cn('h-4 w-4 shrink-0', statusIndicator.className)} />\n </div>\n\n {/* Node body */}\n {(node.description || node.error || node.duration !== undefined) && (\n <div className=\"px-3 py-2.5 space-y-1.5\">\n {node.description && (\n <p className=\"text-xs text-muted-foreground\">{node.description}</p>\n )}\n {node.error && (\n <p className=\"text-xs text-destructive font-mono bg-destructive/5 rounded px-2 py-1\">\n {node.error}\n </p>\n )}\n {node.duration !== undefined && (\n <div className=\"flex items-center gap-1 text-[10px] text-muted-foreground\">\n <Clock className=\"h-3 w-3\" />\n <span>{formatDuration(node.duration)}</span>\n </div>\n )}\n </div>\n )}\n </>\n )}\n </div>\n\n {/* Connector line */}\n {showConnector && !isLast && (\n <div className=\"flex flex-col items-center my-1\">\n <div className=\"w-px h-4 bg-border\" />\n <div className=\"w-1.5 h-1.5 rounded-full bg-border\" />\n <div className=\"w-px h-4 bg-border\" />\n </div>\n )}\n </div>\n )\n}\n\n/** Renders a vertical workflow pipeline from an array of nodes */\nexport interface WorkflowPipelineProps extends React.HTMLAttributes<HTMLDivElement> {\n nodes: WorkflowNodeData[]\n compact?: boolean\n}\n\nfunction WorkflowPipeline({ className, nodes, compact = false, ...props }: WorkflowPipelineProps) {\n return (\n <div className={cn('flex flex-col', className)} {...props}>\n {nodes.map((node, i) => (\n <WorkflowNode\n key={node.id}\n node={node}\n compact={compact}\n showConnector\n isLast={i === nodes.length - 1}\n />\n ))}\n </div>\n )\n}\n\nexport { WorkflowNode, WorkflowPipeline }\n"],"names":["Loader2","CheckCircle2","AlertCircle"],"mappings":";;;;;;;;;;;;AAgBA,MAAM,mBAAmB;AAAA,EACvB,SAAS;AAAA,IACP,MAAM;AAAA,IACN,OAAO;AAAA,IACP,WAAW;AAAA,IACX,aAAa;AAAA,EAAA;AAAA,EAEf,QAAQ;AAAA,IACN,MAAM;AAAA,IACN,OAAO;AAAA,IACP,WAAW;AAAA,IACX,aAAa;AAAA,EAAA;AAAA,EAEf,WAAW;AAAA,IACT,MAAM;AAAA,IACN,OAAO;AAAA,IACP,WAAW;AAAA,IACX,aAAa;AAAA,EAAA;AAAA,EAEf,OAAO;AAAA,IACL,MAAM;AAAA,IACN,OAAO;AAAA,IACP,WAAW;AAAA,IACX,aAAa;AAAA,EAAA;AAAA,EAEf,QAAQ;AAAA,IACN,MAAM;AAAA,IACN,OAAO;AAAA,IACP,WAAW;AAAA,IACX,aAAa;AAAA,EAAA;AAEjB;AAEA,MAAM,mBAAmB;AAAA,EACvB,SAAS,EAAE,MAAMA,cAAS,WAAW,qCAAA;AAAA,EACrC,WAAW,EAAE,MAAMC,aAAc,WAAW,0BAAA;AAAA,EAC5C,QAAQ,EAAE,MAAMC,aAAa,WAAW,uBAAA;AAAA,EACxC,SAAS,EAAE,MAAM,OAAO,WAAW,wBAAA;AAAA,EACnC,QAAQ,EAAE,MAAM,OAAO,WAAW,uBAAA;AAAA,EAClC,WAAW,EAAE,MAAMA,aAAa,WAAW,0BAAA;AAAA,EAC3C,MAAM,EAAE,MAAM,OAAO,WAAW,wBAAA;AAAA,EAChC,WAAW,EAAE,MAAM,OAAO,WAAW,YAAA;AACvC;AAYA,SAAS,aAAa;AAAA,EACpB;AAAA,EACA;AAAA,EACA,UAAU;AAAA,EACV,gBAAgB;AAAA,EAChB,SAAS;AAAA,EACT,GAAG;AACL,GAAsB;AACpB,QAAM,aAAa,iBAAiB,KAAK,IAAI;AAC7C,QAAM,kBAAkB,iBAAiB,KAAK,MAAM;AACpD,QAAM,WAAW,WAAW;AAC5B,QAAM,aAAa,gBAAgB;AAEnC,QAAM,iBAAiB,CAAC,OAAe;AACrC,QAAI,KAAK,IAAM,QAAO,GAAG,EAAE;AAC3B,QAAI,KAAK,IAAO,QAAO,IAAI,KAAK,KAAM,QAAQ,CAAC,CAAC;AAChD,WAAO,GAAG,KAAK,MAAM,KAAK,GAAK,CAAC,KAAK,KAAK,MAAO,KAAK,MAAS,GAAI,CAAC;AAAA,EACtE;AAEA,SACE,qBAAC,OAAA,EAAI,WAAU,uCACb,UAAA;AAAA,IAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,WAAW;AAAA,UACT;AAAA,UACA,WAAW;AAAA,UACX,KAAK,WAAW,aAAa;AAAA,UAC7B,KAAK,WAAW,YAAY;AAAA,UAC5B,UAAU,QAAQ;AAAA,UAClB;AAAA,QAAA;AAAA,QAED,GAAG;AAAA,QAEH,UAAA,UACC,qBAAC,OAAA,EAAI,WAAU,2BACb,UAAA;AAAA,UAAA,oBAAC,OAAA,EAAI,WAAW,GAAG,6DAA6D,WAAW,WAAW,GACpG,UAAA,oBAAC,UAAA,EAAS,WAAU,cAAA,CAAc,GACpC;AAAA,UACA,oBAAC,QAAA,EAAK,WAAU,uCAAuC,eAAK,OAAM;AAAA,8BACjE,YAAA,EAAW,WAAW,GAAG,oBAAoB,gBAAgB,SAAS,EAAA,CAAG;AAAA,QAAA,EAAA,CAC5E,IAEA,qBAAA,UAAA,EAEE,UAAA;AAAA,UAAA,qBAAC,SAAI,WAAW,GAAG,yCAAyC,WAAW,WAAW,GAChF,UAAA;AAAA,YAAA,oBAAC,SAAI,WAAU,iFACb,8BAAC,UAAA,EAAS,WAAU,WAAU,EAAA,CAChC;AAAA,YACA,qBAAC,OAAA,EAAI,WAAU,kBACb,UAAA;AAAA,cAAA,oBAAC,OAAA,EAAI,WAAU,6BACb,UAAA,oBAAC,UAAK,WAAU,iEACb,UAAA,WAAW,MAAA,CACd,EAAA,CACF;AAAA,cACA,oBAAC,KAAA,EAAE,WAAU,gDAAgD,eAAK,MAAA,CAAM;AAAA,YAAA,GAC1E;AAAA,gCACC,YAAA,EAAW,WAAW,GAAG,oBAAoB,gBAAgB,SAAS,EAAA,CAAG;AAAA,UAAA,GAC5E;AAAA,WAGE,KAAK,eAAe,KAAK,SAAS,KAAK,aAAa,WACpD,qBAAC,OAAA,EAAI,WAAU,2BACZ,UAAA;AAAA,YAAA,KAAK,eACJ,oBAAC,KAAA,EAAE,WAAU,iCAAiC,eAAK,aAAY;AAAA,YAEhE,KAAK,SACJ,oBAAC,OAAE,WAAU,yEACV,eAAK,OACR;AAAA,YAED,KAAK,aAAa,UACjB,qBAAC,OAAA,EAAI,WAAU,6DACb,UAAA;AAAA,cAAA,oBAAC,OAAA,EAAM,WAAU,UAAA,CAAU;AAAA,cAC3B,oBAAC,QAAA,EAAM,UAAA,eAAe,KAAK,QAAQ,EAAA,CAAE;AAAA,YAAA,EAAA,CACvC;AAAA,UAAA,EAAA,CAEJ;AAAA,QAAA,EAAA,CAEJ;AAAA,MAAA;AAAA,IAAA;AAAA,IAKH,iBAAiB,CAAC,UACjB,qBAAC,OAAA,EAAI,WAAU,mCACb,UAAA;AAAA,MAAA,oBAAC,OAAA,EAAI,WAAU,qBAAA,CAAqB;AAAA,MACpC,oBAAC,OAAA,EAAI,WAAU,qCAAA,CAAqC;AAAA,MACpD,oBAAC,OAAA,EAAI,WAAU,qBAAA,CAAqB;AAAA,IAAA,EAAA,CACtC;AAAA,EAAA,GAEJ;AAEJ;AAQA,SAAS,iBAAiB,EAAE,WAAW,OAAO,UAAU,OAAO,GAAG,SAAgC;AAChG,SACE,oBAAC,OAAA,EAAI,WAAW,GAAG,iBAAiB,SAAS,GAAI,GAAG,OACjD,UAAA,MAAM,IAAI,CAAC,MAAM,MAChB;AAAA,IAAC;AAAA,IAAA;AAAA,MAEC;AAAA,MACA;AAAA,MACA,eAAa;AAAA,MACb,QAAQ,MAAM,MAAM,SAAS;AAAA,IAAA;AAAA,IAJxB,KAAK;AAAA,EAAA,CAMb,GACH;AAEJ;"}
@@ -0,0 +1,21 @@
1
+ import * as React from 'react';
2
+ export interface AppShellProps extends React.HTMLAttributes<HTMLDivElement> {
3
+ /** The sidebar component */
4
+ sidebar?: React.ReactNode;
5
+ /** The top header component */
6
+ header?: React.ReactNode;
7
+ /** Main content */
8
+ children: React.ReactNode;
9
+ /** Whether the sidebar is currently shown (for mobile overlay handling) */
10
+ sidebarOpen?: boolean;
11
+ }
12
+ /**
13
+ * AppShell provides the top-level layout structure:
14
+ * - Sidebar (left)
15
+ * - Main area (header + content)
16
+ */
17
+ declare function AppShell({ className, sidebar, header, children, sidebarOpen, ...props }: AppShellProps): import("react/jsx-runtime").JSX.Element;
18
+ /** Content wrapper with standard page padding */
19
+ declare function PageContent({ className, children, ...props }: React.HTMLAttributes<HTMLDivElement>): import("react/jsx-runtime").JSX.Element;
20
+ export { AppShell, PageContent };
21
+ //# sourceMappingURL=app-shell.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app-shell.d.ts","sourceRoot":"","sources":["../../../src/components/layout/app-shell.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAG9B,MAAM,WAAW,aAAc,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACzE,4BAA4B;IAC5B,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACzB,+BAA+B;IAC/B,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACxB,mBAAmB;IACnB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;IACzB,2EAA2E;IAC3E,WAAW,CAAC,EAAE,OAAO,CAAA;CACtB;AAED;;;;GAIG;AACH,iBAAS,QAAQ,CAAC,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAkB,EAAE,GAAG,KAAK,EAAE,EAAE,aAAa,2CA2BtG;AAED,iDAAiD;AACjD,iBAAS,WAAW,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,2CAM3F;AAED,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAA"}
@@ -0,0 +1,35 @@
1
+ import { jsxs, jsx } from "react/jsx-runtime";
2
+ import { cn } from "../../lib/utils.js";
3
+ function AppShell({ className, sidebar, header, children, sidebarOpen = true, ...props }) {
4
+ return /* @__PURE__ */ jsxs(
5
+ "div",
6
+ {
7
+ className: cn("flex h-screen w-full overflow-hidden bg-background", className),
8
+ ...props,
9
+ children: [
10
+ sidebar && /* @__PURE__ */ jsx(
11
+ "div",
12
+ {
13
+ className: cn(
14
+ "shrink-0 h-full transition-all duration-200",
15
+ !sidebarOpen && "hidden md:flex"
16
+ ),
17
+ children: sidebar
18
+ }
19
+ ),
20
+ /* @__PURE__ */ jsxs("div", { className: "flex flex-1 flex-col overflow-hidden min-w-0", children: [
21
+ header,
22
+ /* @__PURE__ */ jsx("main", { className: "flex-1 overflow-y-auto", children })
23
+ ] })
24
+ ]
25
+ }
26
+ );
27
+ }
28
+ function PageContent({ className, children, ...props }) {
29
+ return /* @__PURE__ */ jsx("div", { className: cn("p-6", className), ...props, children });
30
+ }
31
+ export {
32
+ AppShell,
33
+ PageContent
34
+ };
35
+ //# sourceMappingURL=app-shell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app-shell.js","sources":["../../../src/components/layout/app-shell.tsx"],"sourcesContent":["import * as React from 'react'\nimport { cn } from '@/lib/utils'\n\nexport interface AppShellProps extends React.HTMLAttributes<HTMLDivElement> {\n /** The sidebar component */\n sidebar?: React.ReactNode\n /** The top header component */\n header?: React.ReactNode\n /** Main content */\n children: React.ReactNode\n /** Whether the sidebar is currently shown (for mobile overlay handling) */\n sidebarOpen?: boolean\n}\n\n/**\n * AppShell provides the top-level layout structure:\n * - Sidebar (left)\n * - Main area (header + content)\n */\nfunction AppShell({ className, sidebar, header, children, sidebarOpen = true, ...props }: AppShellProps) {\n return (\n <div\n className={cn('flex h-screen w-full overflow-hidden bg-background', className)}\n {...props}\n >\n {/* Sidebar */}\n {sidebar && (\n <div\n className={cn(\n 'shrink-0 h-full transition-all duration-200',\n !sidebarOpen && 'hidden md:flex'\n )}\n >\n {sidebar}\n </div>\n )}\n\n {/* Main column */}\n <div className=\"flex flex-1 flex-col overflow-hidden min-w-0\">\n {header}\n <main className=\"flex-1 overflow-y-auto\">\n {children}\n </main>\n </div>\n </div>\n )\n}\n\n/** Content wrapper with standard page padding */\nfunction PageContent({ className, children, ...props }: React.HTMLAttributes<HTMLDivElement>) {\n return (\n <div className={cn('p-6', className)} {...props}>\n {children}\n </div>\n )\n}\n\nexport { AppShell, PageContent }\n"],"names":[],"mappings":";;AAmBA,SAAS,SAAS,EAAE,WAAW,SAAS,QAAQ,UAAU,cAAc,MAAM,GAAG,SAAwB;AACvG,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW,GAAG,sDAAsD,SAAS;AAAA,MAC5E,GAAG;AAAA,MAGH,UAAA;AAAA,QAAA,WACC;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,WAAW;AAAA,cACT;AAAA,cACA,CAAC,eAAe;AAAA,YAAA;AAAA,YAGjB,UAAA;AAAA,UAAA;AAAA,QAAA;AAAA,QAKL,qBAAC,OAAA,EAAI,WAAU,gDACZ,UAAA;AAAA,UAAA;AAAA,UACD,oBAAC,QAAA,EAAK,WAAU,0BACb,SAAA,CACH;AAAA,QAAA,EAAA,CACF;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGN;AAGA,SAAS,YAAY,EAAE,WAAW,UAAU,GAAG,SAA+C;AAC5F,SACE,oBAAC,SAAI,WAAW,GAAG,OAAO,SAAS,GAAI,GAAG,OACvC,UACH;AAEJ;"}
@@ -0,0 +1,16 @@
1
+ import * as React from 'react';
2
+ export interface HeaderProps extends React.HTMLAttributes<HTMLElement> {
3
+ /** Left slot — typically logo + nav */
4
+ left?: React.ReactNode;
5
+ /** Center slot — search, breadcrumbs */
6
+ center?: React.ReactNode;
7
+ /** Right slot — user menu, notifications, settings */
8
+ right?: React.ReactNode;
9
+ /** Makes header sticky at top */
10
+ sticky?: boolean;
11
+ /** Adds a bottom border */
12
+ bordered?: boolean;
13
+ }
14
+ declare const Header: React.ForwardRefExoticComponent<HeaderProps & React.RefAttributes<HTMLElement>>;
15
+ export { Header };
16
+ //# sourceMappingURL=header.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"header.d.ts","sourceRoot":"","sources":["../../../src/components/layout/header.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAG9B,MAAM,WAAW,WAAY,SAAQ,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC;IACpE,uCAAuC;IACvC,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,wCAAwC;IACxC,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACxB,sDAAsD;IACtD,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACvB,iCAAiC;IACjC,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,2BAA2B;IAC3B,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB;AAED,QAAA,MAAM,MAAM,iFAmBX,CAAA;AAGD,OAAO,EAAE,MAAM,EAAE,CAAA"}
@@ -0,0 +1,30 @@
1
+ import { jsxs, jsx } from "react/jsx-runtime";
2
+ import * as React from "react";
3
+ import { cn } from "../../lib/utils.js";
4
+ const Header = React.forwardRef(
5
+ ({ className, left, center, right, sticky = false, bordered = true, children, ...props }, ref) => /* @__PURE__ */ jsxs(
6
+ "header",
7
+ {
8
+ ref,
9
+ className: cn(
10
+ "z-40 flex h-14 w-full items-center gap-4 bg-background px-4",
11
+ sticky && "sticky top-0",
12
+ bordered && "border-b border-border",
13
+ className
14
+ ),
15
+ ...props,
16
+ children: [
17
+ left && /* @__PURE__ */ jsx("div", { className: "flex items-center gap-3", children: left }),
18
+ center && /* @__PURE__ */ jsx("div", { className: "flex flex-1 items-center justify-center", children: center }),
19
+ !center && /* @__PURE__ */ jsx("div", { className: "flex-1" }),
20
+ right && /* @__PURE__ */ jsx("div", { className: "flex items-center gap-2", children: right }),
21
+ children
22
+ ]
23
+ }
24
+ )
25
+ );
26
+ Header.displayName = "Header";
27
+ export {
28
+ Header
29
+ };
30
+ //# sourceMappingURL=header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"header.js","sources":["../../../src/components/layout/header.tsx"],"sourcesContent":["import * as React from 'react'\nimport { cn } from '@/lib/utils'\n\nexport interface HeaderProps extends React.HTMLAttributes<HTMLElement> {\n /** Left slot — typically logo + nav */\n left?: React.ReactNode\n /** Center slot — search, breadcrumbs */\n center?: React.ReactNode\n /** Right slot — user menu, notifications, settings */\n right?: React.ReactNode\n /** Makes header sticky at top */\n sticky?: boolean\n /** Adds a bottom border */\n bordered?: boolean\n}\n\nconst Header = React.forwardRef<HTMLElement, HeaderProps>(\n ({ className, left, center, right, sticky = false, bordered = true, children, ...props }, ref) => (\n <header\n ref={ref}\n className={cn(\n 'z-40 flex h-14 w-full items-center gap-4 bg-background px-4',\n sticky && 'sticky top-0',\n bordered && 'border-b border-border',\n className\n )}\n {...props}\n >\n {left && <div className=\"flex items-center gap-3\">{left}</div>}\n {center && <div className=\"flex flex-1 items-center justify-center\">{center}</div>}\n {!center && <div className=\"flex-1\" />}\n {right && <div className=\"flex items-center gap-2\">{right}</div>}\n {children}\n </header>\n )\n)\nHeader.displayName = 'Header'\n\nexport { Header }\n"],"names":[],"mappings":";;;AAgBA,MAAM,SAAS,MAAM;AAAA,EACnB,CAAC,EAAE,WAAW,MAAM,QAAQ,OAAO,SAAS,OAAO,WAAW,MAAM,UAAU,GAAG,MAAA,GAAS,QACxF;AAAA,IAAC;AAAA,IAAA;AAAA,MACC;AAAA,MACA,WAAW;AAAA,QACT;AAAA,QACA,UAAU;AAAA,QACV,YAAY;AAAA,QACZ;AAAA,MAAA;AAAA,MAED,GAAG;AAAA,MAEH,UAAA;AAAA,QAAA,QAAQ,oBAAC,OAAA,EAAI,WAAU,2BAA2B,UAAA,MAAK;AAAA,QACvD,UAAU,oBAAC,OAAA,EAAI,WAAU,2CAA2C,UAAA,QAAO;AAAA,QAC3E,CAAC,UAAU,oBAAC,OAAA,EAAI,WAAU,SAAA,CAAS;AAAA,QACnC,SAAS,oBAAC,OAAA,EAAI,WAAU,2BAA2B,UAAA,OAAM;AAAA,QACzD;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGP;AACA,OAAO,cAAc;"}
@@ -0,0 +1,16 @@
1
+ import * as React from 'react';
2
+ export interface PageHeaderProps extends React.HTMLAttributes<HTMLDivElement> {
3
+ /** Page title */
4
+ title: string;
5
+ /** Subtitle / description */
6
+ description?: string;
7
+ /** Slot for breadcrumbs above the title */
8
+ breadcrumbs?: React.ReactNode;
9
+ /** Slot for action buttons (top-right) */
10
+ actions?: React.ReactNode;
11
+ /** Optional decorative badge next to the title */
12
+ badge?: React.ReactNode;
13
+ }
14
+ declare const PageHeader: React.ForwardRefExoticComponent<PageHeaderProps & React.RefAttributes<HTMLDivElement>>;
15
+ export { PageHeader };
16
+ //# sourceMappingURL=page-header.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"page-header.d.ts","sourceRoot":"","sources":["../../../src/components/layout/page-header.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAG9B,MAAM,WAAW,eAAgB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC3E,iBAAiB;IACjB,KAAK,EAAE,MAAM,CAAA;IACb,6BAA6B;IAC7B,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,2CAA2C;IAC3C,WAAW,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IAC7B,0CAA0C;IAC1C,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACzB,kDAAkD;IAClD,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;CACxB;AAED,QAAA,MAAM,UAAU,wFAsBf,CAAA;AAGD,OAAO,EAAE,UAAU,EAAE,CAAA"}
@@ -0,0 +1,29 @@
1
+ import { jsxs, jsx } from "react/jsx-runtime";
2
+ import * as React from "react";
3
+ import { cn } from "../../lib/utils.js";
4
+ const PageHeader = React.forwardRef(
5
+ ({ className, title, description, breadcrumbs, actions, badge, ...props }, ref) => /* @__PURE__ */ jsxs(
6
+ "div",
7
+ {
8
+ ref,
9
+ className: cn("flex flex-col gap-1 pb-6 md:flex-row md:items-start md:justify-between", className),
10
+ ...props,
11
+ children: [
12
+ /* @__PURE__ */ jsxs("div", { className: "space-y-1.5", children: [
13
+ breadcrumbs && /* @__PURE__ */ jsx("div", { className: "mb-2", children: breadcrumbs }),
14
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-3 flex-wrap", children: [
15
+ /* @__PURE__ */ jsx("h1", { className: "text-2xl font-bold tracking-tight font-display", children: title }),
16
+ badge
17
+ ] }),
18
+ description && /* @__PURE__ */ jsx("p", { className: "text-sm text-muted-foreground max-w-2xl", children: description })
19
+ ] }),
20
+ actions && /* @__PURE__ */ jsx("div", { className: "flex items-center gap-2 shrink-0 mt-2 md:mt-0", children: actions })
21
+ ]
22
+ }
23
+ )
24
+ );
25
+ PageHeader.displayName = "PageHeader";
26
+ export {
27
+ PageHeader
28
+ };
29
+ //# sourceMappingURL=page-header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"page-header.js","sources":["../../../src/components/layout/page-header.tsx"],"sourcesContent":["import * as React from 'react'\nimport { cn } from '@/lib/utils'\n\nexport interface PageHeaderProps extends React.HTMLAttributes<HTMLDivElement> {\n /** Page title */\n title: string\n /** Subtitle / description */\n description?: string\n /** Slot for breadcrumbs above the title */\n breadcrumbs?: React.ReactNode\n /** Slot for action buttons (top-right) */\n actions?: React.ReactNode\n /** Optional decorative badge next to the title */\n badge?: React.ReactNode\n}\n\nconst PageHeader = React.forwardRef<HTMLDivElement, PageHeaderProps>(\n ({ className, title, description, breadcrumbs, actions, badge, ...props }, ref) => (\n <div\n ref={ref}\n className={cn('flex flex-col gap-1 pb-6 md:flex-row md:items-start md:justify-between', className)}\n {...props}\n >\n <div className=\"space-y-1.5\">\n {breadcrumbs && <div className=\"mb-2\">{breadcrumbs}</div>}\n <div className=\"flex items-center gap-3 flex-wrap\">\n <h1 className=\"text-2xl font-bold tracking-tight font-display\">{title}</h1>\n {badge}\n </div>\n {description && (\n <p className=\"text-sm text-muted-foreground max-w-2xl\">{description}</p>\n )}\n </div>\n {actions && (\n <div className=\"flex items-center gap-2 shrink-0 mt-2 md:mt-0\">{actions}</div>\n )}\n </div>\n )\n)\nPageHeader.displayName = 'PageHeader'\n\nexport { PageHeader }\n"],"names":[],"mappings":";;;AAgBA,MAAM,aAAa,MAAM;AAAA,EACvB,CAAC,EAAE,WAAW,OAAO,aAAa,aAAa,SAAS,OAAO,GAAG,SAAS,QACzE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC;AAAA,MACA,WAAW,GAAG,0EAA0E,SAAS;AAAA,MAChG,GAAG;AAAA,MAEJ,UAAA;AAAA,QAAA,qBAAC,OAAA,EAAI,WAAU,eACZ,UAAA;AAAA,UAAA,eAAe,oBAAC,OAAA,EAAI,WAAU,QAAQ,UAAA,aAAY;AAAA,UACnD,qBAAC,OAAA,EAAI,WAAU,qCACb,UAAA;AAAA,YAAA,oBAAC,MAAA,EAAG,WAAU,kDAAkD,UAAA,OAAM;AAAA,YACrE;AAAA,UAAA,GACH;AAAA,UACC,eACC,oBAAC,KAAA,EAAE,WAAU,2CAA2C,UAAA,YAAA,CAAY;AAAA,QAAA,GAExE;AAAA,QACC,WACC,oBAAC,OAAA,EAAI,WAAU,iDAAiD,UAAA,QAAA,CAAQ;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAIhF;AACA,WAAW,cAAc;"}
@@ -0,0 +1,35 @@
1
+ import * as React from 'react';
2
+ export interface SidebarNavItem {
3
+ id: string;
4
+ label: string;
5
+ icon?: React.ReactNode;
6
+ href?: string;
7
+ badge?: string | number;
8
+ active?: boolean;
9
+ disabled?: boolean;
10
+ onClick?: () => void;
11
+ children?: SidebarNavItem[];
12
+ }
13
+ export interface SidebarSection {
14
+ id: string;
15
+ label?: string;
16
+ items: SidebarNavItem[];
17
+ }
18
+ export interface SidebarProps extends React.HTMLAttributes<HTMLDivElement> {
19
+ sections?: SidebarSection[];
20
+ /** Whether sidebar is collapsed to icon-only mode */
21
+ collapsed?: boolean;
22
+ /** Called when collapse toggle is pressed */
23
+ onCollapsedChange?: (collapsed: boolean) => void;
24
+ /** Show collapse toggle button */
25
+ collapsible?: boolean;
26
+ /** Width when expanded */
27
+ width?: string;
28
+ /** Slot for logo/brand area */
29
+ header?: React.ReactNode;
30
+ /** Slot for footer content (user menu, etc.) */
31
+ footer?: React.ReactNode;
32
+ }
33
+ declare const Sidebar: React.ForwardRefExoticComponent<SidebarProps & React.RefAttributes<HTMLDivElement>>;
34
+ export { Sidebar };
35
+ //# sourceMappingURL=sidebar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar.d.ts","sourceRoot":"","sources":["../../../src/components/layout/sidebar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAO9B,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,MAAM,CAAA;IACV,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IACvB,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAA;IACpB,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAA;CAC5B;AAED,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,MAAM,CAAA;IACV,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,KAAK,EAAE,cAAc,EAAE,CAAA;CACxB;AAED,MAAM,WAAW,YAAa,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACxE,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAA;IAC3B,qDAAqD;IACrD,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,6CAA6C;IAC7C,iBAAiB,CAAC,EAAE,CAAC,SAAS,EAAE,OAAO,KAAK,IAAI,CAAA;IAChD,kCAAkC;IAClC,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB,0BAA0B;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,+BAA+B;IAC/B,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACxB,gDAAgD;IAChD,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;CACzB;AAwDD,QAAA,MAAM,OAAO,qFA2FZ,CAAA;AAGD,OAAO,EAAE,OAAO,EAAE,CAAA"}