@elench/shell 0.1.1 → 0.1.2

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 (307) hide show
  1. package/README.md +46 -7
  2. package/dist/components/shell/activity-bar.d.ts +2 -0
  3. package/dist/components/shell/activity-bar.d.ts.map +1 -0
  4. package/dist/components/shell/activity-bar.js +19 -0
  5. package/dist/components/shell/activity-bar.js.map +1 -0
  6. package/dist/components/shell/app-shell.d.ts +11 -0
  7. package/dist/components/shell/app-shell.d.ts.map +1 -0
  8. package/dist/components/shell/app-shell.js +323 -0
  9. package/dist/components/shell/app-shell.js.map +1 -0
  10. package/dist/components/shell/context-action-menu.d.ts +7 -0
  11. package/dist/components/shell/context-action-menu.d.ts.map +1 -0
  12. package/dist/components/shell/context-action-menu.js +75 -0
  13. package/dist/components/shell/context-action-menu.js.map +1 -0
  14. package/dist/components/shell/default-layout.d.ts +3 -0
  15. package/dist/components/shell/default-layout.d.ts.map +1 -0
  16. package/dist/components/shell/default-layout.js +63 -0
  17. package/dist/components/shell/default-layout.js.map +1 -0
  18. package/dist/components/shell/left-sidebar.d.ts +2 -0
  19. package/dist/components/shell/left-sidebar.d.ts.map +1 -0
  20. package/dist/components/shell/left-sidebar.js +16 -0
  21. package/dist/components/shell/left-sidebar.js.map +1 -0
  22. package/dist/components/shell/primitives/activity-nav.d.ts +7 -0
  23. package/dist/components/shell/primitives/activity-nav.d.ts.map +1 -0
  24. package/dist/components/shell/primitives/activity-nav.js +12 -0
  25. package/dist/components/shell/primitives/activity-nav.js.map +1 -0
  26. package/dist/components/shell/primitives/inspector-panel.d.ts +25 -0
  27. package/dist/components/shell/primitives/inspector-panel.d.ts.map +1 -0
  28. package/dist/components/shell/primitives/inspector-panel.js +32 -0
  29. package/dist/components/shell/primitives/inspector-panel.js.map +1 -0
  30. package/dist/components/shell/primitives/instance-row.d.ts +20 -0
  31. package/dist/components/shell/primitives/instance-row.d.ts.map +1 -0
  32. package/dist/components/shell/primitives/instance-row.js +16 -0
  33. package/dist/components/shell/primitives/instance-row.js.map +1 -0
  34. package/dist/components/shell/primitives/search-bar-primitives.d.ts +21 -0
  35. package/dist/components/shell/primitives/search-bar-primitives.d.ts.map +1 -0
  36. package/dist/components/shell/primitives/search-bar-primitives.js +24 -0
  37. package/dist/components/shell/primitives/search-bar-primitives.js.map +1 -0
  38. package/dist/components/shell/primitives/shell-frame.d.ts +10 -0
  39. package/dist/components/shell/primitives/shell-frame.d.ts.map +1 -0
  40. package/dist/components/shell/primitives/shell-frame.js +26 -0
  41. package/dist/components/shell/primitives/shell-frame.js.map +1 -0
  42. package/dist/components/shell/primitives/shell-status-bar.d.ts +13 -0
  43. package/dist/components/shell/primitives/shell-status-bar.d.ts.map +1 -0
  44. package/dist/components/shell/primitives/shell-status-bar.js +18 -0
  45. package/dist/components/shell/primitives/shell-status-bar.js.map +1 -0
  46. package/dist/components/shell/primitives/shell-surface.d.ts +19 -0
  47. package/dist/components/shell/primitives/shell-surface.d.ts.map +1 -0
  48. package/dist/components/shell/primitives/shell-surface.js +73 -0
  49. package/dist/components/shell/primitives/shell-surface.js.map +1 -0
  50. package/dist/components/shell/primitives/shell-toolbar.d.ts +8 -0
  51. package/dist/components/shell/primitives/shell-toolbar.d.ts.map +1 -0
  52. package/dist/components/shell/primitives/shell-toolbar.js +22 -0
  53. package/dist/components/shell/primitives/shell-toolbar.js.map +1 -0
  54. package/dist/components/shell/primitives/sidebar-action-row.d.ts +14 -0
  55. package/dist/components/shell/primitives/sidebar-action-row.d.ts.map +1 -0
  56. package/dist/components/shell/primitives/sidebar-action-row.js +9 -0
  57. package/dist/components/shell/primitives/sidebar-action-row.js.map +1 -0
  58. package/dist/components/shell/primitives/sidebar-frame.d.ts +12 -0
  59. package/dist/components/shell/primitives/sidebar-frame.d.ts.map +1 -0
  60. package/dist/components/shell/primitives/sidebar-frame.js +19 -0
  61. package/dist/components/shell/primitives/sidebar-frame.js.map +1 -0
  62. package/dist/components/shell/primitives/sidebar-section.d.ts +15 -0
  63. package/dist/components/shell/primitives/sidebar-section.d.ts.map +1 -0
  64. package/dist/components/shell/primitives/sidebar-section.js +23 -0
  65. package/dist/components/shell/primitives/sidebar-section.js.map +1 -0
  66. package/dist/components/shell/primitives/workspace-page.d.ts +21 -0
  67. package/dist/components/shell/primitives/workspace-page.d.ts.map +1 -0
  68. package/dist/components/shell/primitives/workspace-page.js +18 -0
  69. package/dist/components/shell/primitives/workspace-page.js.map +1 -0
  70. package/dist/components/shell/right-inspector.d.ts +2 -0
  71. package/dist/components/shell/right-inspector.d.ts.map +1 -0
  72. package/dist/components/shell/right-inspector.js +32 -0
  73. package/dist/components/shell/right-inspector.js.map +1 -0
  74. package/dist/components/shell/search-action-groups.d.ts +6 -0
  75. package/dist/components/shell/search-action-groups.d.ts.map +1 -0
  76. package/dist/components/shell/search-action-groups.js +37 -0
  77. package/dist/components/shell/search-action-groups.js.map +1 -0
  78. package/dist/components/shell/search-bar.d.ts +2 -0
  79. package/dist/components/shell/search-bar.d.ts.map +1 -0
  80. package/dist/components/shell/search-bar.js +161 -0
  81. package/dist/components/shell/search-bar.js.map +1 -0
  82. package/dist/components/shell/shell-layout.d.ts +30 -0
  83. package/dist/components/shell/shell-layout.d.ts.map +1 -0
  84. package/dist/components/shell/shell-layout.js +176 -0
  85. package/dist/components/shell/shell-layout.js.map +1 -0
  86. package/dist/components/shell/shell-model.d.ts +14 -0
  87. package/dist/components/shell/shell-model.d.ts.map +1 -0
  88. package/dist/components/shell/shell-model.js +75 -0
  89. package/dist/components/shell/shell-model.js.map +1 -0
  90. package/dist/components/shell/status-bar.d.ts +2 -0
  91. package/dist/components/shell/status-bar.d.ts.map +1 -0
  92. package/dist/components/shell/status-bar.js +16 -0
  93. package/dist/components/shell/status-bar.js.map +1 -0
  94. package/dist/components/shell/tab-strip-bridge.d.ts +32 -0
  95. package/dist/components/shell/tab-strip-bridge.d.ts.map +1 -0
  96. package/dist/components/shell/tab-strip-bridge.js +46 -0
  97. package/dist/components/shell/tab-strip-bridge.js.map +1 -0
  98. package/dist/components/shell/top-bar.d.ts +2 -0
  99. package/dist/components/shell/top-bar.d.ts.map +1 -0
  100. package/dist/components/shell/top-bar.js +24 -0
  101. package/dist/components/shell/top-bar.js.map +1 -0
  102. package/dist/components/shell/use-shell-surface-action-groups.d.ts +16 -0
  103. package/dist/components/shell/use-shell-surface-action-groups.d.ts.map +1 -0
  104. package/dist/components/shell/use-shell-surface-action-groups.js +169 -0
  105. package/dist/components/shell/use-shell-surface-action-groups.js.map +1 -0
  106. package/dist/components/shell/workspace-surface-context-menu.d.ts +12 -0
  107. package/dist/components/shell/workspace-surface-context-menu.d.ts.map +1 -0
  108. package/dist/components/shell/workspace-surface-context-menu.js +27 -0
  109. package/dist/components/shell/workspace-surface-context-menu.js.map +1 -0
  110. package/dist/components/shell/workspace-tab-content.d.ts +7 -0
  111. package/dist/components/shell/workspace-tab-content.d.ts.map +1 -0
  112. package/dist/components/shell/workspace-tab-content.js +15 -0
  113. package/dist/components/shell/workspace-tab-content.js.map +1 -0
  114. package/dist/components/system/async-state.d.ts +22 -0
  115. package/dist/components/system/async-state.d.ts.map +1 -0
  116. package/dist/components/system/async-state.js +34 -0
  117. package/dist/components/system/async-state.js.map +1 -0
  118. package/dist/components/system/status.d.ts +16 -0
  119. package/dist/components/system/status.d.ts.map +1 -0
  120. package/dist/components/system/status.js +42 -0
  121. package/dist/components/system/status.js.map +1 -0
  122. package/dist/components/ui/badge.d.ts +10 -0
  123. package/dist/components/ui/badge.d.ts.map +1 -0
  124. package/dist/components/ui/badge.js +26 -0
  125. package/dist/components/ui/badge.js.map +1 -0
  126. package/dist/components/ui/button.d.ts +11 -0
  127. package/dist/components/ui/button.d.ts.map +1 -0
  128. package/dist/components/ui/button.js +37 -0
  129. package/dist/components/ui/button.js.map +1 -0
  130. package/dist/components/ui/card.d.ts +12 -0
  131. package/dist/components/ui/card.d.ts.map +1 -0
  132. package/dist/components/ui/card.js +26 -0
  133. package/dist/components/ui/card.js.map +1 -0
  134. package/dist/components/ui/checkbox.d.ts +5 -0
  135. package/dist/components/ui/checkbox.d.ts.map +1 -0
  136. package/dist/components/ui/checkbox.js +11 -0
  137. package/dist/components/ui/checkbox.js.map +1 -0
  138. package/dist/components/ui/context-menu.d.ts +31 -0
  139. package/dist/components/ui/context-menu.d.ts.map +1 -0
  140. package/dist/components/ui/context-menu.js +54 -0
  141. package/dist/components/ui/context-menu.js.map +1 -0
  142. package/dist/components/ui/dialog.d.ts +18 -0
  143. package/dist/components/ui/dialog.d.ts.map +1 -0
  144. package/dist/components/ui/dialog.js +39 -0
  145. package/dist/components/ui/dialog.js.map +1 -0
  146. package/dist/components/ui/dropdown-menu.d.ts +30 -0
  147. package/dist/components/ui/dropdown-menu.d.ts.map +1 -0
  148. package/dist/components/ui/dropdown-menu.js +53 -0
  149. package/dist/components/ui/dropdown-menu.js.map +1 -0
  150. package/dist/components/ui/icon-button.d.ts +10 -0
  151. package/dist/components/ui/icon-button.d.ts.map +1 -0
  152. package/dist/components/ui/icon-button.js +7 -0
  153. package/dist/components/ui/icon-button.js.map +1 -0
  154. package/dist/components/ui/input.d.ts +4 -0
  155. package/dist/components/ui/input.d.ts.map +1 -0
  156. package/dist/components/ui/input.js +8 -0
  157. package/dist/components/ui/input.js.map +1 -0
  158. package/dist/components/ui/kbd.d.ts +3 -0
  159. package/dist/components/ui/kbd.d.ts.map +1 -0
  160. package/dist/components/ui/kbd.js +6 -0
  161. package/dist/components/ui/kbd.js.map +1 -0
  162. package/dist/components/ui/label.d.ts +5 -0
  163. package/dist/components/ui/label.d.ts.map +1 -0
  164. package/dist/components/ui/label.js +10 -0
  165. package/dist/components/ui/label.js.map +1 -0
  166. package/dist/components/ui/popover.d.ts +11 -0
  167. package/dist/components/ui/popover.d.ts.map +1 -0
  168. package/dist/components/ui/popover.js +28 -0
  169. package/dist/components/ui/popover.js.map +1 -0
  170. package/dist/components/ui/scroll-area.d.ts +6 -0
  171. package/dist/components/ui/scroll-area.d.ts.map +1 -0
  172. package/dist/components/ui/scroll-area.js +13 -0
  173. package/dist/components/ui/scroll-area.js.map +1 -0
  174. package/dist/components/ui/search-field.d.ts +9 -0
  175. package/dist/components/ui/search-field.d.ts.map +1 -0
  176. package/dist/components/ui/search-field.js +9 -0
  177. package/dist/components/ui/search-field.js.map +1 -0
  178. package/dist/components/ui/select.d.ts +25 -0
  179. package/dist/components/ui/select.d.ts.map +1 -0
  180. package/dist/components/ui/select.js +35 -0
  181. package/dist/components/ui/select.js.map +1 -0
  182. package/dist/components/ui/separator.d.ts +5 -0
  183. package/dist/components/ui/separator.d.ts.map +1 -0
  184. package/dist/components/ui/separator.js +10 -0
  185. package/dist/components/ui/separator.js.map +1 -0
  186. package/dist/components/ui/skeleton.d.ts +3 -0
  187. package/dist/components/ui/skeleton.d.ts.map +1 -0
  188. package/dist/components/ui/skeleton.js +9 -0
  189. package/dist/components/ui/skeleton.js.map +1 -0
  190. package/dist/components/ui/switch.d.ts +7 -0
  191. package/dist/components/ui/switch.d.ts.map +1 -0
  192. package/dist/components/ui/switch.js +10 -0
  193. package/dist/components/ui/switch.js.map +1 -0
  194. package/dist/components/ui/tabs.d.ts +12 -0
  195. package/dist/components/ui/tabs.d.ts.map +1 -0
  196. package/dist/components/ui/tabs.js +31 -0
  197. package/dist/components/ui/tabs.js.map +1 -0
  198. package/dist/components/ui/textarea.d.ts +4 -0
  199. package/dist/components/ui/textarea.d.ts.map +1 -0
  200. package/dist/components/ui/textarea.js +8 -0
  201. package/dist/components/ui/textarea.js.map +1 -0
  202. package/dist/components/ui/tooltip.d.ts +8 -0
  203. package/dist/components/ui/tooltip.d.ts.map +1 -0
  204. package/dist/components/ui/tooltip.js +19 -0
  205. package/dist/components/ui/tooltip.js.map +1 -0
  206. package/dist/hooks/shell/shell-registry-provider.d.ts +20 -0
  207. package/dist/hooks/shell/shell-registry-provider.d.ts.map +1 -0
  208. package/dist/hooks/shell/shell-registry-provider.js +42 -0
  209. package/dist/hooks/shell/shell-registry-provider.js.map +1 -0
  210. package/dist/hooks/shell/use-shell-shortcuts.d.ts +2 -0
  211. package/dist/hooks/shell/use-shell-shortcuts.d.ts.map +1 -0
  212. package/dist/hooks/shell/use-shell-shortcuts.js +27 -0
  213. package/dist/hooks/shell/use-shell-shortcuts.js.map +1 -0
  214. package/dist/hooks/shell/use-shell-store.d.ts +40 -0
  215. package/dist/hooks/shell/use-shell-store.d.ts.map +1 -0
  216. package/dist/hooks/shell/use-shell-store.js +420 -0
  217. package/dist/hooks/shell/use-shell-store.js.map +1 -0
  218. package/dist/hooks/shell/use-shell-tab-strip-bridge.d.ts +7 -0
  219. package/dist/hooks/shell/use-shell-tab-strip-bridge.d.ts.map +1 -0
  220. package/dist/hooks/shell/use-shell-tab-strip-bridge.js +316 -0
  221. package/dist/hooks/shell/use-shell-tab-strip-bridge.js.map +1 -0
  222. package/dist/hooks/use-keyboard-shortcut.d.ts +10 -0
  223. package/dist/hooks/use-keyboard-shortcut.d.ts.map +1 -0
  224. package/dist/hooks/use-keyboard-shortcut.js +35 -0
  225. package/dist/hooks/use-keyboard-shortcut.js.map +1 -0
  226. package/dist/hooks/use-media-query.d.ts +2 -0
  227. package/dist/hooks/use-media-query.d.ts.map +1 -0
  228. package/dist/hooks/use-media-query.js +14 -0
  229. package/dist/hooks/use-media-query.js.map +1 -0
  230. package/dist/hooks/use-theme.d.ts +14 -0
  231. package/dist/hooks/use-theme.d.ts.map +1 -0
  232. package/dist/hooks/use-theme.js +43 -0
  233. package/dist/hooks/use-theme.js.map +1 -0
  234. package/dist/hooks/workspace/use-workspace-draft-store.d.ts +45 -0
  235. package/dist/hooks/workspace/use-workspace-draft-store.d.ts.map +1 -0
  236. package/dist/hooks/workspace/use-workspace-draft-store.js +197 -0
  237. package/dist/hooks/workspace/use-workspace-draft-store.js.map +1 -0
  238. package/dist/index.d.ts +3 -28
  239. package/dist/index.d.ts.map +1 -1
  240. package/dist/index.js +1 -1
  241. package/dist/index.js.map +1 -1
  242. package/dist/lib/infra/logger.d.ts +10 -0
  243. package/dist/lib/infra/logger.d.ts.map +1 -0
  244. package/dist/lib/infra/logger.js +24 -0
  245. package/dist/lib/infra/logger.js.map +1 -0
  246. package/dist/lib/observe/event.d.ts +20 -0
  247. package/dist/lib/observe/event.d.ts.map +1 -0
  248. package/dist/lib/observe/event.js +60 -0
  249. package/dist/lib/observe/event.js.map +1 -0
  250. package/dist/lib/observe/ids.d.ts +3 -0
  251. package/dist/lib/observe/ids.d.ts.map +1 -0
  252. package/dist/lib/observe/ids.js +9 -0
  253. package/dist/lib/observe/ids.js.map +1 -0
  254. package/dist/lib/observe/index.d.ts +7 -0
  255. package/dist/lib/observe/index.d.ts.map +1 -0
  256. package/dist/lib/observe/index.js +6 -0
  257. package/dist/lib/observe/index.js.map +1 -0
  258. package/dist/lib/observe/logger.d.ts +25 -0
  259. package/dist/lib/observe/logger.d.ts.map +1 -0
  260. package/dist/lib/observe/logger.js +53 -0
  261. package/dist/lib/observe/logger.js.map +1 -0
  262. package/dist/lib/observe/nop.d.ts +3 -0
  263. package/dist/lib/observe/nop.d.ts.map +1 -0
  264. package/dist/lib/observe/nop.js +9 -0
  265. package/dist/lib/observe/nop.js.map +1 -0
  266. package/dist/lib/observe/shell.d.ts +19 -0
  267. package/dist/lib/observe/shell.d.ts.map +1 -0
  268. package/dist/lib/observe/shell.js +49 -0
  269. package/dist/lib/observe/shell.js.map +1 -0
  270. package/dist/lib/observe/stdout.d.ts +3 -0
  271. package/dist/lib/observe/stdout.d.ts.map +1 -0
  272. package/dist/lib/observe/stdout.js +6 -0
  273. package/dist/lib/observe/stdout.js.map +1 -0
  274. package/dist/lib/observe/types.d.ts +14 -0
  275. package/dist/lib/observe/types.d.ts.map +1 -0
  276. package/dist/lib/observe/types.js +2 -0
  277. package/dist/lib/observe/types.js.map +1 -0
  278. package/dist/lib/shell/actions.d.ts +33 -0
  279. package/dist/lib/shell/actions.d.ts.map +1 -0
  280. package/dist/lib/shell/actions.js +2 -0
  281. package/dist/lib/shell/actions.js.map +1 -0
  282. package/dist/lib/shell/persistence.d.ts +7 -0
  283. package/dist/lib/shell/persistence.d.ts.map +1 -0
  284. package/dist/lib/shell/persistence.js +18 -0
  285. package/dist/lib/shell/persistence.js.map +1 -0
  286. package/dist/lib/shell/status.d.ts +4 -0
  287. package/dist/lib/shell/status.d.ts.map +1 -0
  288. package/dist/lib/shell/status.js +31 -0
  289. package/dist/lib/shell/status.js.map +1 -0
  290. package/dist/lib/shell/types.d.ts +40 -0
  291. package/dist/lib/shell/types.d.ts.map +1 -0
  292. package/dist/lib/shell/types.js +2 -0
  293. package/dist/lib/shell/types.js.map +1 -0
  294. package/dist/lib/utils.d.ts +4 -0
  295. package/dist/lib/utils.d.ts.map +1 -0
  296. package/dist/lib/utils.js +11 -0
  297. package/dist/lib/utils.js.map +1 -0
  298. package/dist/public-api.d.ts +109 -0
  299. package/dist/public-api.d.ts.map +1 -0
  300. package/dist/public-api.js +145 -0
  301. package/dist/public-api.js.map +1 -0
  302. package/dist/styles.css +249 -379
  303. package/package.json +16 -10
  304. package/dist/shell.d.ts +0 -147
  305. package/dist/shell.d.ts.map +0 -1
  306. package/dist/shell.js +0 -339
  307. package/dist/shell.js.map +0 -1
@@ -0,0 +1,16 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { ContextActionMenu } from "@/components/shell/context-action-menu";
4
+ import { useShellSurfaceActionGroups } from "@/components/shell/use-shell-surface-action-groups";
5
+ import { EmptyState } from "@/components/system/async-state";
6
+ import { useShellRegistry } from "@/hooks/shell/shell-registry-provider";
7
+ import { ShellSurfaceRoot } from "@/components/shell/primitives/shell-surface";
8
+ export function LeftSidebar() {
9
+ const { activeModeWorkspace } = useShellRegistry();
10
+ const contextMenuGroups = useShellSurfaceActionGroups({
11
+ includeActiveTab: false,
12
+ includeAppearance: false,
13
+ });
14
+ return (_jsx(ContextActionMenu, { groups: contextMenuGroups, children: _jsx(ShellSurfaceRoot, { "aria-label": "Left sidebar", className: "flex h-full min-w-0 flex-col overflow-hidden bg-bg-surface", surface: "sidebar", children: activeModeWorkspace ? (_jsx(activeModeWorkspace.Sidebar, {})) : (_jsx("div", { className: "p-3", children: _jsx(EmptyState, { title: "Workspace unavailable", description: "No sidebar is registered for the current workspace mode.", className: "min-h-[12rem]" }) })) }) }));
15
+ }
16
+ //# sourceMappingURL=left-sidebar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"left-sidebar.js","sourceRoot":"","sources":["../../../src/components/shell/left-sidebar.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAE,2BAA2B,EAAE,MAAM,oDAAoD,CAAC;AACjG,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,uCAAuC,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,6CAA6C,CAAC;AAE/E,MAAM,UAAU,WAAW;IACzB,MAAM,EAAE,mBAAmB,EAAE,GAAG,gBAAgB,EAAE,CAAC;IACnD,MAAM,iBAAiB,GAAG,2BAA2B,CAAC;QACpD,gBAAgB,EAAE,KAAK;QACvB,iBAAiB,EAAE,KAAK;KACzB,CAAC,CAAC;IAEH,OAAO,CACL,KAAC,iBAAiB,IAAC,MAAM,EAAE,iBAAiB,YAC1C,KAAC,gBAAgB,kBACJ,cAAc,EACzB,SAAS,EAAC,4DAA4D,EACtE,OAAO,EAAC,SAAS,YAEhB,mBAAmB,CAAC,CAAC,CAAC,CACrB,KAAC,mBAAmB,CAAC,OAAO,KAAG,CAChC,CAAC,CAAC,CAAC,CACF,cAAK,SAAS,EAAC,KAAK,YAClB,KAAC,UAAU,IACT,KAAK,EAAC,uBAAuB,EAC7B,WAAW,EAAC,0DAA0D,EACtE,SAAS,EAAC,eAAe,GACzB,GACE,CACP,GACgB,GACD,CACrB,CAAC;AACJ,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { ButtonHTMLAttributes, ComponentProps } from "react";
2
+ export declare function ActivityNav({ children, className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
3
+ export declare function ActivityNavButton({ active, className, children, ...props }: ButtonHTMLAttributes<HTMLButtonElement> & {
4
+ active?: boolean;
5
+ }): import("react/jsx-runtime").JSX.Element;
6
+ export declare function ActivityNavSpacer({ className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
7
+ //# sourceMappingURL=activity-nav.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"activity-nav.d.ts","sourceRoot":"","sources":["../../../../src/components/shell/primitives/activity-nav.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAGlE,wBAAgB,WAAW,CAAC,EAC1B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAavB;AAED,wBAAgB,iBAAiB,CAAC,EAChC,MAAc,EACd,SAAS,EACT,QAAQ,EACR,GAAG,KAAK,EACT,EAAE,oBAAoB,CAAC,iBAAiB,CAAC,GAAG;IAC3C,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,2CAiBA;AAED,wBAAgB,iBAAiB,CAAC,EAChC,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAEvB"}
@@ -0,0 +1,12 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { cn } from "@/lib/utils";
3
+ export function ActivityNav({ children, className, ...props }) {
4
+ return (_jsx("nav", { "aria-label": "Shell navigation", className: cn("flex h-full flex-col items-center gap-[2px] bg-background px-0 py-3 select-none", className), ...props, children: children }));
5
+ }
6
+ export function ActivityNavButton({ active = false, className, children, ...props }) {
7
+ return (_jsx("button", { "data-active": active || undefined, className: cn("relative flex size-9 items-center justify-center rounded-[8px] text-fg-tertiary transition-[color,background-color,transform]", "hover:bg-bg-hover hover:text-fg-secondary active:translate-y-[0.5px]", "data-[active=true]:bg-primary/12 data-[active=true]:text-fg", "data-[active=true]:before:absolute data-[active=true]:before:top-1/2 data-[active=true]:before:left-[-8px] data-[active=true]:before:h-[18px] data-[active=true]:before:w-[3px] data-[active=true]:before:-translate-y-1/2 data-[active=true]:before:rounded-r-[2px] data-[active=true]:before:bg-primary data-[active=true]:before:content-['']", className), type: "button", ...props, children: children }));
8
+ }
9
+ export function ActivityNavSpacer({ className, ...props }) {
10
+ return _jsx("div", { className: cn("flex-1", className), ...props });
11
+ }
12
+ //# sourceMappingURL=activity-nav.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"activity-nav.js","sourceRoot":"","sources":["../../../../src/components/shell/primitives/activity-nav.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AAEjC,MAAM,UAAU,WAAW,CAAC,EAC1B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACc;IACtB,OAAO,CACL,4BACa,kBAAkB,EAC7B,SAAS,EAAE,EAAE,CACX,iFAAiF,EACjF,SAAS,CACV,KACG,KAAK,YAER,QAAQ,GACL,CACP,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,EAChC,MAAM,GAAG,KAAK,EACd,SAAS,EACT,QAAQ,EACR,GAAG,KAAK,EAGT;IACC,OAAO,CACL,gCACe,MAAM,IAAI,SAAS,EAChC,SAAS,EAAE,EAAE,CACX,+HAA+H,EAC/H,sEAAsE,EACtE,6DAA6D,EAC7D,kVAAkV,EAClV,SAAS,CACV,EACD,IAAI,EAAC,QAAQ,KACT,KAAK,YAER,QAAQ,GACF,CACV,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,EAChC,SAAS,EACT,GAAG,KAAK,EACc;IACtB,OAAO,cAAK,SAAS,EAAE,EAAE,CAAC,QAAQ,EAAE,SAAS,CAAC,KAAM,KAAK,GAAI,CAAC;AAChE,CAAC"}
@@ -0,0 +1,25 @@
1
+ import type { ComponentProps, ReactNode } from "react";
2
+ export declare function InspectorPanel({ children, className, ...props }: ComponentProps<"aside">): import("react/jsx-runtime").JSX.Element;
3
+ export declare function InspectorHeader({ action, title, className, }: {
4
+ title: string;
5
+ action?: ReactNode;
6
+ className?: string;
7
+ }): import("react/jsx-runtime").JSX.Element;
8
+ export declare function InspectorScroll({ children, className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
9
+ export declare function InspectorSection({ title, children, className, }: {
10
+ title: string;
11
+ children: ReactNode;
12
+ className?: string;
13
+ }): import("react/jsx-runtime").JSX.Element;
14
+ export declare function InspectorField({ label, value, className, }: {
15
+ label: ReactNode;
16
+ value: ReactNode;
17
+ className?: string;
18
+ }): import("react/jsx-runtime").JSX.Element;
19
+ export declare function InspectorValue({ children, className, mono, tone, }: {
20
+ children: ReactNode;
21
+ className?: string;
22
+ mono?: boolean;
23
+ tone?: "default" | "healthy" | "failed" | "info";
24
+ }): import("react/jsx-runtime").JSX.Element;
25
+ //# sourceMappingURL=inspector-panel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inspector-panel.d.ts","sourceRoot":"","sources":["../../../../src/components/shell/primitives/inspector-panel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAKvD,wBAAgB,cAAc,CAAC,EAC7B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,OAAO,CAAC,2CAazB;AAED,wBAAgB,eAAe,CAAC,EAC9B,MAAM,EACN,KAAK,EACL,SAAS,GACV,EAAE;IACD,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,2CAuBA;AAED,wBAAgB,eAAe,CAAC,EAC9B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAgBvB;AAED,wBAAgB,gBAAgB,CAAC,EAC/B,KAAK,EACL,QAAQ,EACR,SAAS,GACV,EAAE;IACD,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,SAAS,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,2CA+BA;AAED,wBAAgB,cAAc,CAAC,EAC7B,KAAK,EACL,KAAK,EACL,SAAS,GACV,EAAE;IACD,KAAK,EAAE,SAAS,CAAC;IACjB,KAAK,EAAE,SAAS,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,2CA8BA;AAED,wBAAgB,cAAc,CAAC,EAC7B,QAAQ,EACR,SAAS,EACT,IAAY,EACZ,IAAgB,GACjB,EAAE;IACD,QAAQ,EAAE,SAAS,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,IAAI,CAAC,EAAE,SAAS,GAAG,SAAS,GAAG,QAAQ,GAAG,MAAM,CAAC;CAClD,2CAqBA"}
@@ -0,0 +1,32 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn } from "@/lib/utils";
3
+ import { ShellHeaderBar } from "./shell-frame";
4
+ import { ShellSurfaceRoot, useShellSurface } from "./shell-surface";
5
+ export function InspectorPanel({ children, className, ...props }) {
6
+ return (_jsx(ShellSurfaceRoot, { className: cn("flex h-full min-w-0 flex-col overflow-hidden bg-bg-surface", className), surface: "inspector", ...props, children: children }));
7
+ }
8
+ export function InspectorHeader({ action, title, className, }) {
9
+ const { isCompact, isNarrow } = useShellSurface();
10
+ return (_jsxs(ShellHeaderBar, { className: cn("justify-between border-b border-border bg-bg-surface px-3 pt-0 pb-0 pl-4", isCompact && "px-2.5 pl-3", isNarrow && "px-2 pl-2.5", className), children: [_jsx("span", { className: cn("truncate text-[11px] font-semibold tracking-[0.06em] text-fg-tertiary uppercase", isNarrow && "text-[10px]"), children: title }), action] }));
11
+ }
12
+ export function InspectorScroll({ children, className, ...props }) {
13
+ const { isCompact, isNarrow } = useShellSurface();
14
+ return (_jsx("div", { className: cn("min-h-0 min-w-0 flex-1 overflow-x-hidden overflow-y-auto py-1", isCompact && "py-0.5", isNarrow && "py-0", className), ...props, children: children }));
15
+ }
16
+ export function InspectorSection({ title, children, className, }) {
17
+ const { isCompact, isNarrow } = useShellSurface();
18
+ return (_jsxs("section", { className: cn("border-b border-border-subtle px-4 py-3 last:border-b-0", isCompact && "px-3 py-2.5", isNarrow && "px-2.5 py-2", className), children: [_jsx("div", { className: cn("mb-2.5 text-[10px] font-semibold tracking-[0.06em] text-fg-tertiary uppercase", isCompact && "mb-2", isNarrow && "mb-1.5 text-[9.5px]"), children: title }), _jsx("div", { className: cn(!isNarrow &&
19
+ "grid grid-cols-[auto_1fr] items-baseline [&>*]:col-span-2"), children: children })] }));
20
+ }
21
+ export function InspectorField({ label, value, className, }) {
22
+ const { isCompact, isNarrow } = useShellSurface();
23
+ return (_jsxs("div", { className: cn("col-span-2 grid grid-cols-subgrid items-baseline gap-x-2.5 py-1", isCompact && "gap-x-2 py-0.75", isNarrow && "flex flex-col items-start gap-1.5 py-1.25", className), children: [_jsx("span", { className: cn("text-[12px] text-fg-tertiary", isNarrow && "text-[11px]"), children: label }), _jsx("span", { className: cn("text-[12px] font-medium text-fg-secondary", isNarrow ? "max-w-full text-left" : "min-w-0 truncate text-right"), children: value })] }));
24
+ }
25
+ export function InspectorValue({ children, className, mono = false, tone = "default", }) {
26
+ const { isNarrow } = useShellSurface();
27
+ return (_jsx("span", { className: cn("inline-block max-w-full text-[12px] font-medium text-fg-secondary", isNarrow ? "whitespace-normal text-left" : "truncate text-right", mono &&
28
+ (isNarrow
29
+ ? "break-all font-mono text-[11.5px]"
30
+ : "font-mono text-[11.5px]"), tone === "healthy" && "text-status-ok", tone === "failed" && "text-status-err", tone === "info" && "text-status-info", className), children: children }));
31
+ }
32
+ //# sourceMappingURL=inspector-panel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inspector-panel.js","sourceRoot":"","sources":["../../../../src/components/shell/primitives/inspector-panel.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ import { type ButtonHTMLAttributes, type ReactNode } from "react";
2
+ type InstanceTone = "api" | "frontend" | "runner" | "telemetry" | "default";
3
+ export type InstanceRowProps = ButtonHTMLAttributes<HTMLButtonElement> & {
4
+ active?: boolean;
5
+ detail: string;
6
+ icon: ReactNode;
7
+ tone?: InstanceTone;
8
+ title: string;
9
+ suffix?: ReactNode;
10
+ };
11
+ export declare const InstanceRow: import("react").ForwardRefExoticComponent<ButtonHTMLAttributes<HTMLButtonElement> & {
12
+ active?: boolean;
13
+ detail: string;
14
+ icon: ReactNode;
15
+ tone?: InstanceTone;
16
+ title: string;
17
+ suffix?: ReactNode;
18
+ } & import("react").RefAttributes<HTMLButtonElement>>;
19
+ export {};
20
+ //# sourceMappingURL=instance-row.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"instance-row.d.ts","sourceRoot":"","sources":["../../../../src/components/shell/primitives/instance-row.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAc,KAAK,oBAAoB,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAI9E,KAAK,YAAY,GAAG,KAAK,GAAG,UAAU,GAAG,QAAQ,GAAG,WAAW,GAAG,SAAS,CAAC;AAU5E,MAAM,MAAM,gBAAgB,GAAG,oBAAoB,CAAC,iBAAiB,CAAC,GAAG;IACvE,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,SAAS,CAAC;IAChB,IAAI,CAAC,EAAE,YAAY,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,SAAS,CAAC;CACpB,CAAC;AAEF,eAAO,MAAM,WAAW;aARb,OAAO;YACR,MAAM;UACR,SAAS;WACR,YAAY;WACZ,MAAM;aACJ,SAAS;qDAqEnB,CAAC"}
@@ -0,0 +1,16 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { forwardRef } from "react";
3
+ import { cn } from "@/lib/utils";
4
+ import { useShellSurface } from "./shell-surface";
5
+ const toneClassName = {
6
+ api: "bg-blue-500/12 text-blue-400",
7
+ frontend: "bg-violet-500/12 text-violet-300",
8
+ runner: "bg-amber-500/12 text-amber-300",
9
+ telemetry: "bg-green-500/12 text-green-300",
10
+ default: "bg-slate-400/14 text-slate-300",
11
+ };
12
+ export const InstanceRow = forwardRef(function InstanceRow({ active = false, className, detail, icon, suffix, title, tone = "default", ...props }, ref) {
13
+ const { isCompact, isNarrow } = useShellSurface();
14
+ return (_jsxs("button", { "data-active": active || undefined, "data-tone": tone, className: cn("group/instance relative my-px flex w-full items-center gap-2.5 rounded-lg px-2 py-1.5 text-left transition-colors", isCompact && "gap-2 px-1.5 py-1.5", isNarrow && "gap-1.5 px-1.5 py-1.25", "hover:bg-bg-hover active:bg-bg-active data-[active=true]:bg-primary/12", "data-[active=true]:before:absolute data-[active=true]:before:inset-y-2 data-[active=true]:before:left-0.5 data-[active=true]:before:w-0.5 data-[active=true]:before:rounded-full data-[active=true]:before:bg-primary data-[active=true]:before:content-['']", className), ref: ref, type: "button", ...props, children: [_jsx("span", { className: cn("flex size-[30px] shrink-0 items-center justify-center rounded-[7px]", isCompact && "size-7 rounded-md", isNarrow && "size-6 rounded-md", toneClassName[tone]), children: icon }), _jsxs("span", { className: "min-w-0 flex-1", children: [_jsx("span", { className: cn("block truncate text-[13px] leading-[1.3] font-medium text-fg-secondary transition-colors", isCompact && "text-[12.5px]", isNarrow && "text-[12px]", active && "text-fg", "group-hover/instance:text-fg"), children: title }), !isNarrow ? (_jsx("span", { className: "mt-0.5 block truncate text-[11.5px] leading-[1.4] text-fg-tertiary", children: detail })) : null] }), suffix && !isNarrow ? (_jsx("span", { className: "shrink-0", children: suffix })) : null] }));
15
+ });
16
+ //# sourceMappingURL=instance-row.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"instance-row.js","sourceRoot":"","sources":["../../../../src/components/shell/primitives/instance-row.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAA6C,MAAM,OAAO,CAAC;AAC9E,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AACjC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAIlD,MAAM,aAAa,GAAiC;IAClD,GAAG,EAAE,8BAA8B;IACnC,QAAQ,EAAE,kCAAkC;IAC5C,MAAM,EAAE,gCAAgC;IACxC,SAAS,EAAE,gCAAgC;IAC3C,OAAO,EAAE,gCAAgC;CAC1C,CAAC;AAWF,MAAM,CAAC,MAAM,WAAW,GAAG,UAAU,CACnC,SAAS,WAAW,CAClB,EACE,MAAM,GAAG,KAAK,EACd,SAAS,EACT,MAAM,EACN,IAAI,EACJ,MAAM,EACN,KAAK,EACL,IAAI,GAAG,SAAS,EAChB,GAAG,KAAK,EACT,EACD,GAAG;IAEH,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,eAAe,EAAE,CAAC;IAElD,OAAO,CACL,iCACe,MAAM,IAAI,SAAS,eACrB,IAAI,EACf,SAAS,EAAE,EAAE,CACX,mHAAmH,EACnH,SAAS,IAAI,qBAAqB,EAClC,QAAQ,IAAI,wBAAwB,EACpC,wEAAwE,EACxE,8PAA8P,EAC9P,SAAS,CACV,EACD,GAAG,EAAE,GAAG,EACR,IAAI,EAAC,QAAQ,KACT,KAAK,aAET,eACE,SAAS,EAAE,EAAE,CACX,qEAAqE,EACrE,SAAS,IAAI,mBAAmB,EAChC,QAAQ,IAAI,mBAAmB,EAC/B,aAAa,CAAC,IAAI,CAAC,CACpB,YAEA,IAAI,GACA,EACP,gBAAM,SAAS,EAAC,gBAAgB,aAC9B,eACE,SAAS,EAAE,EAAE,CACX,0FAA0F,EAC1F,SAAS,IAAI,eAAe,EAC5B,QAAQ,IAAI,aAAa,EACzB,MAAM,IAAI,SAAS,EACnB,8BAA8B,CAC/B,YAEA,KAAK,GACD,EACN,CAAC,QAAQ,CAAC,CAAC,CAAC,CACX,eAAM,SAAS,EAAC,oEAAoE,YACjF,MAAM,GACF,CACR,CAAC,CAAC,CAAC,IAAI,IACH,EACN,MAAM,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CACrB,eAAM,SAAS,EAAC,UAAU,YAAE,MAAM,GAAQ,CAC3C,CAAC,CAAC,CAAC,IAAI,IACD,CACV,CAAC;AACJ,CAAC,CACF,CAAC"}
@@ -0,0 +1,21 @@
1
+ import { type ComponentProps, type ReactNode } from "react";
2
+ import { Command } from "cmdk";
3
+ export declare const SearchBarList: import("react").ForwardRefExoticComponent<Omit<{
4
+ children?: React.ReactNode;
5
+ } & Pick<Pick<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "key" | keyof import("react").HTMLAttributes<HTMLDivElement>> & {
6
+ ref?: React.Ref<HTMLDivElement>;
7
+ } & {
8
+ asChild?: boolean;
9
+ }, "asChild" | "key" | keyof import("react").HTMLAttributes<HTMLDivElement>> & {
10
+ label?: string;
11
+ } & import("react").RefAttributes<HTMLDivElement>, "ref"> & import("react").RefAttributes<HTMLDivElement>>;
12
+ export declare function SearchBarEmpty(props: ComponentProps<typeof Command.Empty>): import("react/jsx-runtime").JSX.Element;
13
+ export declare function SearchBarItem({ children, className, endSlot, ...props }: ComponentProps<typeof Command.Item> & {
14
+ endSlot?: ReactNode;
15
+ }): import("react/jsx-runtime").JSX.Element;
16
+ export declare function SearchBarGroupHeading({ children, className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
17
+ export declare function SearchBarStatusDot({ className, tone, }: {
18
+ className?: string;
19
+ tone: string;
20
+ }): import("react/jsx-runtime").JSX.Element;
21
+ //# sourceMappingURL=search-bar-primitives.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search-bar-primitives.d.ts","sourceRoot":"","sources":["../../../../src/components/shell/primitives/search-bar-primitives.tsx"],"names":[],"mappings":"AAAA,OAAO,EAEL,KAAK,cAAc,EAEnB,KAAK,SAAS,EACf,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAG/B,eAAO,MAAM,aAAa;;;;;;;;0GAaxB,CAAC;AAEH,wBAAgB,cAAc,CAAC,KAAK,EAAE,cAAc,CAAC,OAAO,OAAO,CAAC,KAAK,CAAC,2CAEzE;AAED,wBAAgB,aAAa,CAAC,EAC5B,QAAQ,EACR,SAAS,EACT,OAAO,EACP,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG;IACvC,OAAO,CAAC,EAAE,SAAS,CAAC;CACrB,2CAeA;AAED,wBAAgB,qBAAqB,CAAC,EACpC,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAYvB;AAED,wBAAgB,kBAAkB,CAAC,EACjC,SAAS,EACT,IAAI,GACL,EAAE;IACD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;CACd,2CAkBA"}
@@ -0,0 +1,24 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { forwardRef, } from "react";
3
+ import { Command } from "cmdk";
4
+ import { cn } from "@/lib/utils";
5
+ export const SearchBarList = forwardRef(function SearchBarList({ children, className, ...props }, ref) {
6
+ return (_jsx(Command.List, { className: cn("max-h-[min(420px,55vh)] overflow-auto p-2", className), ref: ref, ...props, children: children }));
7
+ });
8
+ export function SearchBarEmpty(props) {
9
+ return _jsx(Command.Empty, { className: "p-4 text-sm text-fg-tertiary", ...props });
10
+ }
11
+ export function SearchBarItem({ children, className, endSlot, ...props }) {
12
+ return (_jsxs(Command.Item, { className: cn("flex cursor-pointer items-center justify-between gap-3 rounded-md px-[10px] py-[6px] text-[13px] text-fg-secondary outline-none", "data-[selected=true]:bg-primary/12 data-[selected=true]:text-fg", "data-[disabled=true]:cursor-default data-[disabled=true]:opacity-70", className), ...props, children: [children, endSlot] }));
13
+ }
14
+ export function SearchBarGroupHeading({ children, className, ...props }) {
15
+ return (_jsx("div", { className: cn("px-2 py-2 text-[0.7rem] font-bold tracking-[0.08em] text-fg-tertiary uppercase", className), ...props, children: children }));
16
+ }
17
+ export function SearchBarStatusDot({ className, tone, }) {
18
+ return (_jsx("span", { className: cn("inline-block size-2 rounded-full", tone === "healthy" && "bg-status-ok", tone === "failed" && "bg-status-err", tone === "degraded" && "bg-status-warn", tone === "deploying" && "bg-status-info", tone !== "healthy" &&
19
+ tone !== "failed" &&
20
+ tone !== "degraded" &&
21
+ tone !== "deploying" &&
22
+ "bg-status-muted", className) }));
23
+ }
24
+ //# sourceMappingURL=search-bar-primitives.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search-bar-primitives.js","sourceRoot":"","sources":["../../../../src/components/shell/primitives/search-bar-primitives.tsx"],"names":[],"mappings":";AAAA,OAAO,EACL,UAAU,GAIX,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AAEjC,MAAM,CAAC,MAAM,aAAa,GAAG,UAAU,CAGrC,SAAS,aAAa,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,GAAG;IAC7D,OAAO,CACL,KAAC,OAAO,CAAC,IAAI,IACX,SAAS,EAAE,EAAE,CAAC,2CAA2C,EAAE,SAAS,CAAC,EACrE,GAAG,EAAE,GAAG,KACJ,KAAK,YAER,QAAQ,GACI,CAChB,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,MAAM,UAAU,cAAc,CAAC,KAA2C;IACxE,OAAO,KAAC,OAAO,CAAC,KAAK,IAAC,SAAS,EAAC,8BAA8B,KAAK,KAAK,GAAI,CAAC;AAC/E,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,EAC5B,QAAQ,EACR,SAAS,EACT,OAAO,EACP,GAAG,KAAK,EAGT;IACC,OAAO,CACL,MAAC,OAAO,CAAC,IAAI,IACX,SAAS,EAAE,EAAE,CACX,iIAAiI,EACjI,iEAAiE,EACjE,qEAAqE,EACrE,SAAS,CACV,KACG,KAAK,aAER,QAAQ,EACR,OAAO,IACK,CAChB,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,qBAAqB,CAAC,EACpC,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACc;IACtB,OAAO,CACL,cACE,SAAS,EAAE,EAAE,CACX,gFAAgF,EAChF,SAAS,CACV,KACG,KAAK,YAER,QAAQ,GACL,CACP,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,EACjC,SAAS,EACT,IAAI,GAIL;IACC,OAAO,CACL,eACE,SAAS,EAAE,EAAE,CACX,kCAAkC,EAClC,IAAI,KAAK,SAAS,IAAI,cAAc,EACpC,IAAI,KAAK,QAAQ,IAAI,eAAe,EACpC,IAAI,KAAK,UAAU,IAAI,gBAAgB,EACvC,IAAI,KAAK,WAAW,IAAI,gBAAgB,EACxC,IAAI,KAAK,SAAS;YAChB,IAAI,KAAK,QAAQ;YACjB,IAAI,KAAK,UAAU;YACnB,IAAI,KAAK,WAAW;YACpB,iBAAiB,EACnB,SAAS,CACV,GACD,CACH,CAAC;AACJ,CAAC"}
@@ -0,0 +1,10 @@
1
+ import type { ComponentProps } from "react";
2
+ export declare function ShellViewport({ children, compact, className, ...props }: ComponentProps<"div"> & {
3
+ compact?: boolean;
4
+ }): import("react/jsx-runtime").JSX.Element;
5
+ export declare function ShellHeaderSlot({ children, className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
6
+ export declare function ShellRailSlot({ children, className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
7
+ export declare function ShellMainSlot({ children, className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
8
+ export declare function ShellStatusSlot({ children, className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
9
+ export declare function ShellHeaderBar({ children, className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
10
+ //# sourceMappingURL=shell-frame.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell-frame.d.ts","sourceRoot":"","sources":["../../../../src/components/shell/primitives/shell-frame.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAM5C,wBAAgB,aAAa,CAAC,EAC5B,QAAQ,EACR,OAAe,EACf,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,GAAG;IACzB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,2CAuBA;AAED,wBAAgB,eAAe,CAAC,EAC9B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAMvB;AAED,wBAAgB,aAAa,CAAC,EAC5B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAMvB;AAED,wBAAgB,aAAa,CAAC,EAC5B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAYvB;AAED,wBAAgB,eAAe,CAAC,EAC9B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAYvB;AAED,wBAAgB,cAAc,CAAC,EAC7B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAMvB"}
@@ -0,0 +1,26 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn } from "@/lib/utils";
3
+ const NOISE_BACKGROUND = "url(\"data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E\")";
4
+ export function ShellViewport({ children, compact = false, className, ...props }) {
5
+ return (_jsxs("div", { "data-compact": compact || undefined, className: cn("fixed inset-0 grid bg-background shell-viewport-y-gap", "grid-cols-[52px_minmax(0,1fr)] grid-rows-[auto_minmax(0,1fr)_auto]", className), ...props, children: [_jsx("div", { "aria-hidden": "true", className: "pointer-events-none absolute inset-0 opacity-[0.015]", style: {
6
+ backgroundImage: NOISE_BACKGROUND,
7
+ backgroundRepeat: "repeat",
8
+ backgroundSize: "256px 256px",
9
+ } }), children] }));
10
+ }
11
+ export function ShellHeaderSlot({ children, className, ...props }) {
12
+ return (_jsx("div", { className: cn("z-10 col-[1/-1] row-[1]", className), ...props, children: children }));
13
+ }
14
+ export function ShellRailSlot({ children, className, ...props }) {
15
+ return (_jsx("div", { className: cn("z-10 col-[1] row-[2/-1]", className), ...props, children: children }));
16
+ }
17
+ export function ShellMainSlot({ children, className, ...props }) {
18
+ return (_jsx("div", { className: cn("col-[2] row-[2] min-h-0 min-w-0 shell-main-gap-no-left", className), ...props, children: children }));
19
+ }
20
+ export function ShellStatusSlot({ children, className, ...props }) {
21
+ return (_jsx("div", { className: cn("col-[2] row-[3] min-w-0 shell-main-gap-no-left", className), ...props, children: children }));
22
+ }
23
+ export function ShellHeaderBar({ children, className, ...props }) {
24
+ return (_jsx("div", { className: cn("flex h-9 shrink-0 items-center", className), ...props, children: children }));
25
+ }
26
+ //# sourceMappingURL=shell-frame.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell-frame.js","sourceRoot":"","sources":["../../../../src/components/shell/primitives/shell-frame.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AAEjC,MAAM,gBAAgB,GACpB,sSAAsS,CAAC;AAEzS,MAAM,UAAU,aAAa,CAAC,EAC5B,QAAQ,EACR,OAAO,GAAG,KAAK,EACf,SAAS,EACT,GAAG,KAAK,EAGT;IACC,OAAO,CACL,+BACgB,OAAO,IAAI,SAAS,EAClC,SAAS,EAAE,EAAE,CACX,uDAAuD,EACvD,oEAAoE,EACpE,SAAS,CACV,KACG,KAAK,aAET,6BACc,MAAM,EAClB,SAAS,EAAC,sDAAsD,EAChE,KAAK,EAAE;oBACL,eAAe,EAAE,gBAAgB;oBACjC,gBAAgB,EAAE,QAAQ;oBAC1B,cAAc,EAAE,aAAa;iBAC9B,GACD,EACD,QAAQ,IACL,CACP,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAC9B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACc;IACtB,OAAO,CACL,cAAK,SAAS,EAAE,EAAE,CAAC,yBAAyB,EAAE,SAAS,CAAC,KAAM,KAAK,YAChE,QAAQ,GACL,CACP,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,EAC5B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACc;IACtB,OAAO,CACL,cAAK,SAAS,EAAE,EAAE,CAAC,yBAAyB,EAAE,SAAS,CAAC,KAAM,KAAK,YAChE,QAAQ,GACL,CACP,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,EAC5B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACc;IACtB,OAAO,CACL,cACE,SAAS,EAAE,EAAE,CACX,wDAAwD,EACxD,SAAS,CACV,KACG,KAAK,YAER,QAAQ,GACL,CACP,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAC9B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACc;IACtB,OAAO,CACL,cACE,SAAS,EAAE,EAAE,CACX,gDAAgD,EAChD,SAAS,CACV,KACG,KAAK,YAER,QAAQ,GACL,CACP,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAC7B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACc;IACtB,OAAO,CACL,cAAK,SAAS,EAAE,EAAE,CAAC,gCAAgC,EAAE,SAAS,CAAC,KAAM,KAAK,YACvE,QAAQ,GACL,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,13 @@
1
+ import type { ComponentProps, ReactNode } from "react";
2
+ export declare function ShellStatusBar({ children, className, ...props }: ComponentProps<"footer">): import("react/jsx-runtime").JSX.Element;
3
+ export declare function ShellStatusPill({ children, className, ...props }: ComponentProps<"span">): import("react/jsx-runtime").JSX.Element;
4
+ export declare function ShellStatusItem({ children, className, hiddenBelowDesktop, ...props }: ComponentProps<"span"> & {
5
+ hiddenBelowDesktop?: boolean;
6
+ }): import("react/jsx-runtime").JSX.Element;
7
+ export declare function ShellStatusSelected({ children, className, ...props }: ComponentProps<"span">): import("react/jsx-runtime").JSX.Element;
8
+ export declare function ShellStatusMetric({ label, prefix, className, }: {
9
+ label: ReactNode;
10
+ prefix?: ReactNode;
11
+ className?: string;
12
+ }): import("react/jsx-runtime").JSX.Element;
13
+ //# sourceMappingURL=shell-status-bar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell-status-bar.d.ts","sourceRoot":"","sources":["../../../../src/components/shell/primitives/shell-status-bar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGvD,wBAAgB,cAAc,CAAC,EAC7B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,QAAQ,CAAC,2CAY1B;AAED,wBAAgB,eAAe,CAAC,EAC9B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,MAAM,CAAC,2CAYxB;AAED,wBAAgB,eAAe,CAAC,EAC9B,QAAQ,EACR,SAAS,EACT,kBAA0B,EAC1B,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,MAAM,CAAC,GAAG;IAC1B,kBAAkB,CAAC,EAAE,OAAO,CAAC;CAC9B,2CAaA;AAED,wBAAgB,mBAAmB,CAAC,EAClC,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,MAAM,CAAC,2CASxB;AAED,wBAAgB,iBAAiB,CAAC,EAChC,KAAK,EACL,MAAM,EACN,SAAS,GACV,EAAE;IACD,KAAK,EAAE,SAAS,CAAC;IACjB,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,2CAOA"}
@@ -0,0 +1,18 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn } from "@/lib/utils";
3
+ export function ShellStatusBar({ children, className, ...props }) {
4
+ return (_jsx("footer", { className: cn("flex items-center gap-3 bg-background px-4 font-mono text-[11px] text-fg-tertiary select-none", className), ...props, children: children }));
5
+ }
6
+ export function ShellStatusPill({ children, className, ...props }) {
7
+ return (_jsx("span", { className: cn("rounded-[3px] bg-bg-elevated px-[7px] py-[1px] text-[10px] font-semibold tracking-[0.06em] uppercase", className), ...props, children: children }));
8
+ }
9
+ export function ShellStatusItem({ children, className, hiddenBelowDesktop = false, ...props }) {
10
+ return (_jsx("span", { className: cn("inline-flex items-center gap-[5px]", hiddenBelowDesktop && "max-[1180px]:hidden", className), ...props, children: children }));
11
+ }
12
+ export function ShellStatusSelected({ children, className, ...props }) {
13
+ return (_jsx("span", { className: cn("ml-auto min-w-0 truncate whitespace-nowrap", className), ...props, children: children }));
14
+ }
15
+ export function ShellStatusMetric({ label, prefix, className, }) {
16
+ return (_jsxs(ShellStatusItem, { className: className, children: [prefix, label] }));
17
+ }
18
+ //# sourceMappingURL=shell-status-bar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell-status-bar.js","sourceRoot":"","sources":["../../../../src/components/shell/primitives/shell-status-bar.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AAEjC,MAAM,UAAU,cAAc,CAAC,EAC7B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACiB;IACzB,OAAO,CACL,iBACE,SAAS,EAAE,EAAE,CACX,+FAA+F,EAC/F,SAAS,CACV,KACG,KAAK,YAER,QAAQ,GACF,CACV,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAC9B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACe;IACvB,OAAO,CACL,eACE,SAAS,EAAE,EAAE,CACX,sGAAsG,EACtG,SAAS,CACV,KACG,KAAK,YAER,QAAQ,GACJ,CACR,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAC9B,QAAQ,EACR,SAAS,EACT,kBAAkB,GAAG,KAAK,EAC1B,GAAG,KAAK,EAGT;IACC,OAAO,CACL,eACE,SAAS,EAAE,EAAE,CACX,oCAAoC,EACpC,kBAAkB,IAAI,qBAAqB,EAC3C,SAAS,CACV,KACG,KAAK,YAER,QAAQ,GACJ,CACR,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,EAClC,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACe;IACvB,OAAO,CACL,eACE,SAAS,EAAE,EAAE,CAAC,4CAA4C,EAAE,SAAS,CAAC,KAClE,KAAK,YAER,QAAQ,GACJ,CACR,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,EAChC,KAAK,EACL,MAAM,EACN,SAAS,GAKV;IACC,OAAO,CACL,MAAC,eAAe,IAAC,SAAS,EAAE,SAAS,aAClC,MAAM,EACN,KAAK,IACU,CACnB,CAAC;AACJ,CAAC"}
@@ -0,0 +1,19 @@
1
+ import { type ComponentProps, type ReactNode } from "react";
2
+ export type ShellSurfaceKind = "sidebar" | "inspector";
3
+ export type ShellSurfaceDensity = "narrow" | "compact" | "wide";
4
+ type ShellSurfaceContextValue = {
5
+ surface: ShellSurfaceKind;
6
+ density: ShellSurfaceDensity;
7
+ width: number | null;
8
+ isCompact: boolean;
9
+ isNarrow: boolean;
10
+ isWide: boolean;
11
+ };
12
+ export declare function ShellSurfaceRoot({ children, className, surface, widthOverride, ...props }: ComponentProps<"aside"> & {
13
+ children: ReactNode;
14
+ surface: ShellSurfaceKind;
15
+ widthOverride?: number;
16
+ }): import("react/jsx-runtime").JSX.Element;
17
+ export declare function useShellSurface(): ShellSurfaceContextValue;
18
+ export {};
19
+ //# sourceMappingURL=shell-surface.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell-surface.d.ts","sourceRoot":"","sources":["../../../../src/components/shell/primitives/shell-surface.tsx"],"names":[],"mappings":"AAEA,OAAO,EAEL,KAAK,cAAc,EACnB,KAAK,SAAS,EAKf,MAAM,OAAO,CAAC;AAEf,MAAM,MAAM,gBAAgB,GAAG,SAAS,GAAG,WAAW,CAAC;AACvD,MAAM,MAAM,mBAAmB,GAAG,QAAQ,GAAG,SAAS,GAAG,MAAM,CAAC;AAEhE,KAAK,wBAAwB,GAAG;IAC9B,OAAO,EAAE,gBAAgB,CAAC;IAC1B,OAAO,EAAE,mBAAmB,CAAC;IAC7B,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,SAAS,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,OAAO,CAAC;IAClB,MAAM,EAAE,OAAO,CAAC;CACjB,CAAC;AAkEF,wBAAgB,gBAAgB,CAAC,EAC/B,QAAQ,EACR,SAAS,EACT,OAAO,EACP,aAAa,EACb,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,OAAO,CAAC,GAAG;IAC3B,QAAQ,EAAE,SAAS,CAAC;IACpB,OAAO,EAAE,gBAAgB,CAAC;IAC1B,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,2CA2CA;AAED,wBAAgB,eAAe,6BAE9B"}
@@ -0,0 +1,73 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { createContext, useContext, useEffect, useMemo, useState, } from "react";
4
+ const DEFAULT_SURFACE_STATE = {
5
+ surface: "sidebar",
6
+ density: "wide",
7
+ width: null,
8
+ isCompact: false,
9
+ isNarrow: false,
10
+ isWide: true,
11
+ };
12
+ const ShellSurfaceContext = createContext(DEFAULT_SURFACE_STATE);
13
+ const SURFACE_BREAKPOINTS = {
14
+ sidebar: {
15
+ narrow: 220,
16
+ compact: 300,
17
+ },
18
+ inspector: {
19
+ narrow: 280,
20
+ compact: 360,
21
+ },
22
+ };
23
+ function getDensity(surface, width) {
24
+ if (width == null) {
25
+ return "wide";
26
+ }
27
+ const { compact, narrow } = SURFACE_BREAKPOINTS[surface];
28
+ if (width < narrow) {
29
+ return "narrow";
30
+ }
31
+ if (width < compact) {
32
+ return "compact";
33
+ }
34
+ return "wide";
35
+ }
36
+ function buildSurfaceState(surface, width) {
37
+ const density = getDensity(surface, width);
38
+ return {
39
+ surface,
40
+ density,
41
+ width,
42
+ isCompact: density !== "wide",
43
+ isNarrow: density === "narrow",
44
+ isWide: density === "wide",
45
+ };
46
+ }
47
+ export function ShellSurfaceRoot({ children, className, surface, widthOverride, ...props }) {
48
+ const [node, setNode] = useState(null);
49
+ const [measuredWidth, setMeasuredWidth] = useState(null);
50
+ useEffect(() => {
51
+ if (typeof widthOverride === "number" || !node) {
52
+ return;
53
+ }
54
+ const updateWidth = () => {
55
+ const nextWidth = node.getBoundingClientRect().width;
56
+ setMeasuredWidth((current) => current === nextWidth ? current : nextWidth);
57
+ };
58
+ updateWidth();
59
+ const observer = new ResizeObserver(() => {
60
+ updateWidth();
61
+ });
62
+ observer.observe(node);
63
+ return () => observer.disconnect();
64
+ }, [node, widthOverride]);
65
+ const value = useMemo(() => {
66
+ return buildSurfaceState(surface, widthOverride ?? measuredWidth);
67
+ }, [measuredWidth, surface, widthOverride]);
68
+ return (_jsx(ShellSurfaceContext.Provider, { value: value, children: _jsx("aside", { className: className, "data-density": value.density, "data-surface": surface, ref: setNode, ...props, children: children }) }));
69
+ }
70
+ export function useShellSurface() {
71
+ return useContext(ShellSurfaceContext);
72
+ }
73
+ //# sourceMappingURL=shell-surface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell-surface.js","sourceRoot":"","sources":["../../../../src/components/shell/primitives/shell-surface.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EACL,aAAa,EAGb,UAAU,EACV,SAAS,EACT,OAAO,EACP,QAAQ,GACT,MAAM,OAAO,CAAC;AAcf,MAAM,qBAAqB,GAA6B;IACtD,OAAO,EAAE,SAAS;IAClB,OAAO,EAAE,MAAM;IACf,KAAK,EAAE,IAAI;IACX,SAAS,EAAE,KAAK;IAChB,QAAQ,EAAE,KAAK;IACf,MAAM,EAAE,IAAI;CACb,CAAC;AAEF,MAAM,mBAAmB,GAAG,aAAa,CACvC,qBAAqB,CACtB,CAAC;AAEF,MAAM,mBAAmB,GAMrB;IACF,OAAO,EAAE;QACP,MAAM,EAAE,GAAG;QACX,OAAO,EAAE,GAAG;KACb;IACD,SAAS,EAAE;QACT,MAAM,EAAE,GAAG;QACX,OAAO,EAAE,GAAG;KACb;CACF,CAAC;AAEF,SAAS,UAAU,CACjB,OAAyB,EACzB,KAAoB;IAEpB,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;QAClB,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,mBAAmB,CAAC,OAAO,CAAC,CAAC;IACzD,IAAI,KAAK,GAAG,MAAM,EAAE,CAAC;QACnB,OAAO,QAAQ,CAAC;IAClB,CAAC;IACD,IAAI,KAAK,GAAG,OAAO,EAAE,CAAC;QACpB,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,SAAS,iBAAiB,CACxB,OAAyB,EACzB,KAAoB;IAEpB,MAAM,OAAO,GAAG,UAAU,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;IAE3C,OAAO;QACL,OAAO;QACP,OAAO;QACP,KAAK;QACL,SAAS,EAAE,OAAO,KAAK,MAAM;QAC7B,QAAQ,EAAE,OAAO,KAAK,QAAQ;QAC9B,MAAM,EAAE,OAAO,KAAK,MAAM;KAC3B,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,EAC/B,QAAQ,EACR,SAAS,EACT,OAAO,EACP,aAAa,EACb,GAAG,KAAK,EAKT;IACC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAqB,IAAI,CAAC,CAAC;IAC3D,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAgB,IAAI,CAAC,CAAC;IAExE,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,OAAO,aAAa,KAAK,QAAQ,IAAI,CAAC,IAAI,EAAE,CAAC;YAC/C,OAAO;QACT,CAAC;QAED,MAAM,WAAW,GAAG,GAAG,EAAE;YACvB,MAAM,SAAS,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;YACrD,gBAAgB,CAAC,CAAC,OAAO,EAAE,EAAE,CAC3B,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAC5C,CAAC;QACJ,CAAC,CAAC;QAEF,WAAW,EAAE,CAAC;QAEd,MAAM,QAAQ,GAAG,IAAI,cAAc,CAAC,GAAG,EAAE;YACvC,WAAW,EAAE,CAAC;QAChB,CAAC,CAAC,CAAC;QAEH,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACvB,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC;IACrC,CAAC,EAAE,CAAC,IAAI,EAAE,aAAa,CAAC,CAAC,CAAC;IAE1B,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,EAAE;QACzB,OAAO,iBAAiB,CAAC,OAAO,EAAE,aAAa,IAAI,aAAa,CAAC,CAAC;IACpE,CAAC,EAAE,CAAC,aAAa,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC;IAE5C,OAAO,CACL,KAAC,mBAAmB,CAAC,QAAQ,IAAC,KAAK,EAAE,KAAK,YACxC,gBACE,SAAS,EAAE,SAAS,kBACN,KAAK,CAAC,OAAO,kBACb,OAAO,EACrB,GAAG,EAAE,OAAO,KACR,KAAK,YAER,QAAQ,GACH,GACqB,CAChC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,eAAe;IAC7B,OAAO,UAAU,CAAC,mBAAmB,CAAC,CAAC;AACzC,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { ComponentProps } from "react";
2
+ export declare function ShellToolbar({ children, className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
3
+ export declare function ShellToolbarBrand({ children, className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
4
+ export declare function ShellToolbarWordmark({ className, ...props }: ComponentProps<"span">): import("react/jsx-runtime").JSX.Element;
5
+ export declare function ShellToolbarDivider({ className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
6
+ export declare function ShellToolbarSpacer({ className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
7
+ export declare function ShellToolbarActions({ className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
8
+ //# sourceMappingURL=shell-toolbar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell-toolbar.d.ts","sourceRoot":"","sources":["../../../../src/components/shell/primitives/shell-toolbar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAI5C,wBAAgB,YAAY,CAAC,EAC3B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CASvB;AAED,wBAAgB,iBAAiB,CAAC,EAChC,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAMvB;AAED,wBAAgB,oBAAoB,CAAC,EACnC,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,MAAM,CAAC,2CAWxB;AAED,wBAAgB,mBAAmB,CAAC,EAClC,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAOvB;AAED,wBAAgB,kBAAkB,CAAC,EACjC,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAEvB;AAED,wBAAgB,mBAAmB,CAAC,EAClC,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAIvB"}
@@ -0,0 +1,22 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { cn } from "@/lib/utils";
3
+ import { ShellHeaderBar } from "./shell-frame";
4
+ export function ShellToolbar({ children, className, ...props }) {
5
+ return (_jsx(ShellHeaderBar, { className: cn("gap-2 px-3 pt-0 pb-0 pl-4 bg-background", className), ...props, children: children }));
6
+ }
7
+ export function ShellToolbarBrand({ children, className, ...props }) {
8
+ return (_jsx("div", { className: cn("mr-2 flex items-center gap-2", className), ...props, children: children }));
9
+ }
10
+ export function ShellToolbarWordmark({ className, ...props }) {
11
+ return (_jsx("span", { className: cn("text-sm font-semibold tracking-[-0.01em] bg-clip-text text-transparent", className), style: { backgroundImage: "var(--gradient-brand)" }, ...props }));
12
+ }
13
+ export function ShellToolbarDivider({ className, ...props }) {
14
+ return (_jsx("div", { className: cn("mx-1 h-5 w-px bg-border max-[820px]:hidden", className), ...props }));
15
+ }
16
+ export function ShellToolbarSpacer({ className, ...props }) {
17
+ return _jsx("div", { className: cn("flex-1", className), ...props });
18
+ }
19
+ export function ShellToolbarActions({ className, ...props }) {
20
+ return (_jsx("div", { className: cn("flex items-center gap-[2px]", className), ...props }));
21
+ }
22
+ //# sourceMappingURL=shell-toolbar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell-toolbar.js","sourceRoot":"","sources":["../../../../src/components/shell/primitives/shell-toolbar.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AACjC,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAE/C,MAAM,UAAU,YAAY,CAAC,EAC3B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACc;IACtB,OAAO,CACL,KAAC,cAAc,IACb,SAAS,EAAE,EAAE,CAAC,yCAAyC,EAAE,SAAS,CAAC,KAC/D,KAAK,YAER,QAAQ,GACM,CAClB,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,EAChC,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACc;IACtB,OAAO,CACL,cAAK,SAAS,EAAE,EAAE,CAAC,8BAA8B,EAAE,SAAS,CAAC,KAAM,KAAK,YACrE,QAAQ,GACL,CACP,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,EACnC,SAAS,EACT,GAAG,KAAK,EACe;IACvB,OAAO,CACL,eACE,SAAS,EAAE,EAAE,CACX,wEAAwE,EACxE,SAAS,CACV,EACD,KAAK,EAAE,EAAE,eAAe,EAAE,uBAAuB,EAAE,KAC/C,KAAK,GACT,CACH,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,EAClC,SAAS,EACT,GAAG,KAAK,EACc;IACtB,OAAO,CACL,cACE,SAAS,EAAE,EAAE,CAAC,4CAA4C,EAAE,SAAS,CAAC,KAClE,KAAK,GACT,CACH,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,EACjC,SAAS,EACT,GAAG,KAAK,EACc;IACtB,OAAO,cAAK,SAAS,EAAE,EAAE,CAAC,QAAQ,EAAE,SAAS,CAAC,KAAM,KAAK,GAAI,CAAC;AAChE,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,EAClC,SAAS,EACT,GAAG,KAAK,EACc;IACtB,OAAO,CACL,cAAK,SAAS,EAAE,EAAE,CAAC,6BAA6B,EAAE,SAAS,CAAC,KAAM,KAAK,GAAI,CAC5E,CAAC;AACJ,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { type ButtonHTMLAttributes, type ReactNode } from "react";
2
+ export type SidebarActionRowProps = ButtonHTMLAttributes<HTMLButtonElement> & {
3
+ active?: boolean;
4
+ description?: string;
5
+ icon: ReactNode;
6
+ title: string;
7
+ };
8
+ export declare const SidebarActionRow: import("react").ForwardRefExoticComponent<ButtonHTMLAttributes<HTMLButtonElement> & {
9
+ active?: boolean;
10
+ description?: string;
11
+ icon: ReactNode;
12
+ title: string;
13
+ } & import("react").RefAttributes<HTMLButtonElement>>;
14
+ //# sourceMappingURL=sidebar-action-row.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-action-row.d.ts","sourceRoot":"","sources":["../../../../src/components/shell/primitives/sidebar-action-row.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAc,KAAK,oBAAoB,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAI9E,MAAM,MAAM,qBAAqB,GAAG,oBAAoB,CAAC,iBAAiB,CAAC,GAAG;IAC5E,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,SAAS,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,eAAO,MAAM,gBAAgB;aANlB,OAAO;kBACF,MAAM;UACd,SAAS;WACR,MAAM;qDA+Cb,CAAC"}
@@ -0,0 +1,9 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { forwardRef } from "react";
3
+ import { cn } from "@/lib/utils";
4
+ import { useShellSurface } from "./shell-surface";
5
+ export const SidebarActionRow = forwardRef(function SidebarActionRow({ active = false, className, description, icon, title, ...props }, ref) {
6
+ const { isCompact, isNarrow, isWide } = useShellSurface();
7
+ return (_jsxs("button", { "data-active": active || undefined, className: cn("group/action my-px flex w-full items-center gap-2.5 rounded-md px-[14px] py-[7px] text-left text-[13px] font-medium text-fg-secondary transition-colors", isCompact && "gap-2 px-3 py-2 text-[12.5px]", isNarrow && "gap-1.5 px-2.5 py-1.5 text-[12px]", "hover:bg-bg-hover hover:text-fg active:bg-bg-active", active && "bg-primary/12 text-fg", className), ref: ref, type: "button", ...props, children: [_jsx("span", { className: cn("shrink-0 text-fg-tertiary transition-colors group-hover/action:text-fg-secondary group-data-[active=true]/action:text-fg-secondary", isNarrow && "[&_svg]:size-3.5"), children: icon }), _jsxs("span", { className: "min-w-0 flex-1", children: [_jsx("span", { className: cn("block truncate", isNarrow && "leading-[1.25]"), children: title }), description && isWide ? (_jsx("span", { className: "mt-0.5 block truncate text-[11px] text-fg-tertiary", children: description })) : null] })] }));
8
+ });
9
+ //# sourceMappingURL=sidebar-action-row.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-action-row.js","sourceRoot":"","sources":["../../../../src/components/shell/primitives/sidebar-action-row.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAA6C,MAAM,OAAO,CAAC;AAC9E,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AACjC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AASlD,MAAM,CAAC,MAAM,gBAAgB,GAAG,UAAU,CAGxC,SAAS,gBAAgB,CACzB,EAAE,MAAM,GAAG,KAAK,EAAE,SAAS,EAAE,WAAW,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,KAAK,EAAE,EACjE,GAAG;IAEH,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,eAAe,EAAE,CAAC;IAE1D,OAAO,CACL,iCACe,MAAM,IAAI,SAAS,EAChC,SAAS,EAAE,EAAE,CACX,yJAAyJ,EACzJ,SAAS,IAAI,+BAA+B,EAC5C,QAAQ,IAAI,mCAAmC,EAC/C,qDAAqD,EACrD,MAAM,IAAI,uBAAuB,EACjC,SAAS,CACV,EACD,GAAG,EAAE,GAAG,EACR,IAAI,EAAC,QAAQ,KACT,KAAK,aAET,eACE,SAAS,EAAE,EAAE,CACX,oIAAoI,EACpI,QAAQ,IAAI,kBAAkB,CAC/B,YAEA,IAAI,GACA,EACP,gBAAM,SAAS,EAAC,gBAAgB,aAC9B,eAAM,SAAS,EAAE,EAAE,CAAC,gBAAgB,EAAE,QAAQ,IAAI,gBAAgB,CAAC,YAChE,KAAK,GACD,EACN,WAAW,IAAI,MAAM,CAAC,CAAC,CAAC,CACvB,eAAM,SAAS,EAAC,oDAAoD,YACjE,WAAW,GACP,CACR,CAAC,CAAC,CAAC,IAAI,IACH,IACA,CACV,CAAC;AACJ,CAAC,CAAC,CAAC"}
@@ -0,0 +1,12 @@
1
+ import type { ComponentProps, ReactNode } from "react";
2
+ import type { ShellActionGroup } from "@/lib/shell/actions";
3
+ import { ScrollArea } from "@/components/ui/scroll-area";
4
+ export declare function SidebarFrame({ children, action, title, className, contextMenuGroups, }: {
5
+ title: string;
6
+ children: ReactNode;
7
+ action?: ReactNode;
8
+ className?: string;
9
+ contextMenuGroups?: ShellActionGroup[];
10
+ }): import("react/jsx-runtime").JSX.Element;
11
+ export declare function SidebarScroll({ children, className, ...props }: ComponentProps<typeof ScrollArea>): import("react/jsx-runtime").JSX.Element;
12
+ //# sourceMappingURL=sidebar-frame.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-frame.d.ts","sourceRoot":"","sources":["../../../../src/components/shell/primitives/sidebar-frame.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAKzD,wBAAgB,YAAY,CAAC,EAC3B,QAAQ,EACR,MAAM,EACN,KAAK,EACL,SAAS,EACT,iBAAiB,GAClB,EAAE;IACD,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,SAAS,CAAC;IACpB,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,iBAAiB,CAAC,EAAE,gBAAgB,EAAE,CAAC;CACxC,2CAkCA;AAED,wBAAgB,aAAa,CAAC,EAC5B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,OAAO,UAAU,CAAC,2CAiBnC"}
@@ -0,0 +1,19 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { ContextActionMenu } from "@/components/shell/context-action-menu";
3
+ import { ScrollArea } from "@/components/ui/scroll-area";
4
+ import { cn } from "@/lib/utils";
5
+ import { ShellHeaderBar } from "./shell-frame";
6
+ import { useShellSurface } from "./shell-surface";
7
+ export function SidebarFrame({ children, action, title, className, contextMenuGroups, }) {
8
+ const { isCompact, isNarrow } = useShellSurface();
9
+ const frame = (_jsxs("div", { className: cn("flex h-full min-h-0 flex-col", className), children: [_jsxs(ShellHeaderBar, { className: cn("justify-between border-b border-border bg-bg-surface px-3 pt-0 pb-0 pl-4", isCompact && "px-2.5 pl-3", isNarrow && "h-11 px-2 pl-2.5"), children: [_jsx("span", { className: cn("truncate text-[11px] font-semibold tracking-[0.06em] text-fg-tertiary uppercase", isNarrow && "text-[10px]"), children: title }), action] }), _jsx(SidebarScroll, { children: children })] }));
10
+ if (!contextMenuGroups || contextMenuGroups.length === 0) {
11
+ return frame;
12
+ }
13
+ return (_jsx(ContextActionMenu, { groups: contextMenuGroups, children: _jsx("div", { className: "h-full", children: frame }) }));
14
+ }
15
+ export function SidebarScroll({ children, className, ...props }) {
16
+ const { isCompact, isNarrow } = useShellSurface();
17
+ return (_jsx(ScrollArea, { className: cn("min-h-0 flex-1 px-1.5 py-1.5", isCompact && "px-1.25 py-1.25", isNarrow && "px-1 py-1", className), type: "auto", ...props, children: children }));
18
+ }
19
+ //# sourceMappingURL=sidebar-frame.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-frame.js","sourceRoot":"","sources":["../../../../src/components/shell/primitives/sidebar-frame.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAE3E,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AACjC,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAElD,MAAM,UAAU,YAAY,CAAC,EAC3B,QAAQ,EACR,MAAM,EACN,KAAK,EACL,SAAS,EACT,iBAAiB,GAOlB;IACC,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,eAAe,EAAE,CAAC;IAClD,MAAM,KAAK,GAAG,CACZ,eAAK,SAAS,EAAE,EAAE,CAAC,8BAA8B,EAAE,SAAS,CAAC,aAC3D,MAAC,cAAc,IACb,SAAS,EAAE,EAAE,CACX,0EAA0E,EAC1E,SAAS,IAAI,aAAa,EAC1B,QAAQ,IAAI,kBAAkB,CAC/B,aAED,eACE,SAAS,EAAE,EAAE,CACX,iFAAiF,EACjF,QAAQ,IAAI,aAAa,CAC1B,YAEA,KAAK,GACD,EACN,MAAM,IACQ,EACjB,KAAC,aAAa,cAAE,QAAQ,GAAiB,IACrC,CACP,CAAC;IAEF,IAAI,CAAC,iBAAiB,IAAI,iBAAiB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO,CACL,KAAC,iBAAiB,IAAC,MAAM,EAAE,iBAAiB,YAC1C,cAAK,SAAS,EAAC,QAAQ,YAAE,KAAK,GAAO,GACnB,CACrB,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,EAC5B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EAC0B;IAClC,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,eAAe,EAAE,CAAC;IAElD,OAAO,CACL,KAAC,UAAU,IACT,SAAS,EAAE,EAAE,CACX,8BAA8B,EAC9B,SAAS,IAAI,iBAAiB,EAC9B,QAAQ,IAAI,WAAW,EACvB,SAAS,CACV,EACD,IAAI,EAAC,MAAM,KACP,KAAK,YAER,QAAQ,GACE,CACd,CAAC;AACJ,CAAC"}
@@ -0,0 +1,15 @@
1
+ import type { ComponentProps, ReactNode } from "react";
2
+ export declare function SidebarSection({ children, className, ...props }: ComponentProps<"section">): import("react/jsx-runtime").JSX.Element;
3
+ export declare function SidebarSectionHeader({ collapsed, count, onClick, title, }: {
4
+ title: string;
5
+ count?: ReactNode;
6
+ collapsed?: boolean;
7
+ onClick?: () => void;
8
+ }): import("react/jsx-runtime").JSX.Element;
9
+ export declare function SidebarSectionContent({ children, collapsed, className, }: {
10
+ children: ReactNode;
11
+ collapsed?: boolean;
12
+ className?: string;
13
+ }): import("react/jsx-runtime").JSX.Element;
14
+ export declare function SidebarSectionLabel({ children, className, ...props }: ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
15
+ //# sourceMappingURL=sidebar-section.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-section.d.ts","sourceRoot":"","sources":["../../../../src/components/shell/primitives/sidebar-section.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAMvD,wBAAgB,cAAc,CAAC,EAC7B,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,SAAS,CAAC,2CAM3B;AAED,wBAAgB,oBAAoB,CAAC,EACnC,SAAiB,EACjB,KAAK,EACL,OAAO,EACP,KAAK,GACN,EAAE;IACD,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;CACtB,2CA0CA;AAED,wBAAgB,qBAAqB,CAAC,EACpC,QAAQ,EACR,SAAiB,EACjB,SAAS,GACV,EAAE;IACD,QAAQ,EAAE,SAAS,CAAC;IACpB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,2CAkBA;AAED,wBAAgB,mBAAmB,CAAC,EAClC,QAAQ,EACR,SAAS,EACT,GAAG,KAAK,EACT,EAAE,cAAc,CAAC,KAAK,CAAC,2CAevB"}