@b3-crow/ui-kit 0.0.30 → 0.0.31-pr30.1

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 (295) hide show
  1. package/dist/components/backgrounds/AnimatedBackground.d.ts.map +1 -0
  2. package/dist/components/backgrounds/AnimatedBackground.js.map +1 -0
  3. package/dist/components/backgrounds/Globe.d.ts.map +1 -0
  4. package/dist/components/backgrounds/Globe.js.map +1 -0
  5. package/dist/components/backgrounds/GradientBackground.d.ts.map +1 -0
  6. package/dist/components/backgrounds/GradientBackground.js.map +1 -0
  7. package/dist/components/{Button.d.ts → buttons/Button.d.ts} +5 -2
  8. package/dist/components/buttons/Button.d.ts.map +1 -0
  9. package/dist/components/buttons/Button.js +41 -0
  10. package/dist/components/buttons/Button.js.map +1 -0
  11. package/dist/components/buttons/CompanyPageButton.d.ts +10 -0
  12. package/dist/components/buttons/CompanyPageButton.d.ts.map +1 -0
  13. package/dist/components/buttons/CompanyPageButton.js +8 -0
  14. package/dist/components/buttons/CompanyPageButton.js.map +1 -0
  15. package/dist/components/cards/Card.d.ts.map +1 -0
  16. package/dist/components/{Card.js → cards/Card.js} +1 -1
  17. package/dist/components/cards/Card.js.map +1 -0
  18. package/dist/components/cards/CheckoutSummary.d.ts +38 -0
  19. package/dist/components/cards/CheckoutSummary.d.ts.map +1 -0
  20. package/dist/components/cards/CheckoutSummary.js +54 -0
  21. package/dist/components/cards/CheckoutSummary.js.map +1 -0
  22. package/dist/components/cards/ConnectionOption.d.ts +13 -0
  23. package/dist/components/cards/ConnectionOption.d.ts.map +1 -0
  24. package/dist/components/cards/ConnectionOption.js +22 -0
  25. package/dist/components/cards/ConnectionOption.js.map +1 -0
  26. package/dist/components/cards/InvitationDetailsCard.d.ts +8 -0
  27. package/dist/components/cards/InvitationDetailsCard.d.ts.map +1 -0
  28. package/dist/components/cards/InvitationDetailsCard.js +5 -0
  29. package/dist/components/cards/InvitationDetailsCard.js.map +1 -0
  30. package/dist/components/cards/OrderSummaryCard.d.ts +29 -0
  31. package/dist/components/cards/OrderSummaryCard.d.ts.map +1 -0
  32. package/dist/components/cards/OrderSummaryCard.js +8 -0
  33. package/dist/components/cards/OrderSummaryCard.js.map +1 -0
  34. package/dist/components/cards/PendingInviteCard.d.ts +26 -0
  35. package/dist/components/cards/PendingInviteCard.d.ts.map +1 -0
  36. package/dist/components/cards/PendingInviteCard.js +63 -0
  37. package/dist/components/cards/PendingInviteCard.js.map +1 -0
  38. package/dist/components/cards/PlanCard.d.ts +50 -0
  39. package/dist/components/cards/PlanCard.d.ts.map +1 -0
  40. package/dist/components/cards/PlanCard.js +40 -0
  41. package/dist/components/cards/PlanCard.js.map +1 -0
  42. package/dist/components/cards/PricingCard.d.ts +35 -0
  43. package/dist/components/cards/PricingCard.d.ts.map +1 -0
  44. package/dist/components/cards/PricingCard.js +42 -0
  45. package/dist/components/cards/PricingCard.js.map +1 -0
  46. package/dist/components/cards/RunAgentCard.d.ts +9 -0
  47. package/dist/components/cards/RunAgentCard.d.ts.map +1 -0
  48. package/dist/components/cards/RunAgentCard.js +15 -0
  49. package/dist/components/cards/RunAgentCard.js.map +1 -0
  50. package/dist/components/cards/SyncStatusCard.d.ts +8 -0
  51. package/dist/components/cards/SyncStatusCard.d.ts.map +1 -0
  52. package/dist/components/cards/SyncStatusCard.js +29 -0
  53. package/dist/components/cards/SyncStatusCard.js.map +1 -0
  54. package/dist/components/dashboard/ChatHistorySection.d.ts +4 -0
  55. package/dist/components/dashboard/ChatHistorySection.d.ts.map +1 -0
  56. package/dist/components/dashboard/ChatHistorySection.js +116 -0
  57. package/dist/components/dashboard/ChatHistorySection.js.map +1 -0
  58. package/dist/components/dashboard/DashboardBackground.d.ts +4 -0
  59. package/dist/components/dashboard/DashboardBackground.d.ts.map +1 -0
  60. package/dist/components/dashboard/DashboardBackground.js +13 -0
  61. package/dist/components/dashboard/DashboardBackground.js.map +1 -0
  62. package/dist/components/dashboard/FilterDropdown.d.ts +14 -0
  63. package/dist/components/dashboard/FilterDropdown.d.ts.map +1 -0
  64. package/dist/components/dashboard/FilterDropdown.js +115 -0
  65. package/dist/components/dashboard/FilterDropdown.js.map +1 -0
  66. package/dist/components/dashboard/GlassPanel.d.ts +4 -0
  67. package/dist/components/dashboard/GlassPanel.d.ts.map +1 -0
  68. package/dist/components/dashboard/GlassPanel.js +11 -0
  69. package/dist/components/dashboard/GlassPanel.js.map +1 -0
  70. package/dist/components/dashboard/Header.d.ts +4 -0
  71. package/dist/components/dashboard/Header.d.ts.map +1 -0
  72. package/dist/components/dashboard/Header.js +126 -0
  73. package/dist/components/dashboard/Header.js.map +1 -0
  74. package/dist/components/dashboard/IconBadge.d.ts +12 -0
  75. package/dist/components/dashboard/IconBadge.d.ts.map +1 -0
  76. package/dist/components/dashboard/IconBadge.js +34 -0
  77. package/dist/components/dashboard/IconBadge.js.map +1 -0
  78. package/dist/components/dashboard/ListItem.d.ts +10 -0
  79. package/dist/components/dashboard/ListItem.d.ts.map +1 -0
  80. package/dist/components/dashboard/ListItem.js +13 -0
  81. package/dist/components/dashboard/ListItem.js.map +1 -0
  82. package/dist/components/dashboard/MetricsCard.d.ts +10 -0
  83. package/dist/components/dashboard/MetricsCard.d.ts.map +1 -0
  84. package/dist/components/dashboard/MetricsCard.js +41 -0
  85. package/dist/components/dashboard/MetricsCard.js.map +1 -0
  86. package/dist/components/dashboard/MobileSidebar.d.ts +4 -0
  87. package/dist/components/dashboard/MobileSidebar.d.ts.map +1 -0
  88. package/dist/components/dashboard/MobileSidebar.js +51 -0
  89. package/dist/components/dashboard/MobileSidebar.js.map +1 -0
  90. package/dist/components/dashboard/NavMenu.d.ts +8 -0
  91. package/dist/components/dashboard/NavMenu.d.ts.map +1 -0
  92. package/dist/components/dashboard/NavMenu.js +66 -0
  93. package/dist/components/dashboard/NavMenu.js.map +1 -0
  94. package/dist/components/dashboard/PatternCard.d.ts +16 -0
  95. package/dist/components/dashboard/PatternCard.d.ts.map +1 -0
  96. package/dist/components/dashboard/PatternCard.js +75 -0
  97. package/dist/components/dashboard/PatternCard.js.map +1 -0
  98. package/dist/components/dashboard/SearchInput.d.ts +14 -0
  99. package/dist/components/dashboard/SearchInput.d.ts.map +1 -0
  100. package/dist/components/dashboard/SearchInput.js +36 -0
  101. package/dist/components/dashboard/SearchInput.js.map +1 -0
  102. package/dist/components/dashboard/SectionHeader.d.ts +13 -0
  103. package/dist/components/dashboard/SectionHeader.d.ts.map +1 -0
  104. package/dist/components/dashboard/SectionHeader.js +19 -0
  105. package/dist/components/dashboard/SectionHeader.js.map +1 -0
  106. package/dist/components/dashboard/SettingsDropup.d.ts +11 -0
  107. package/dist/components/dashboard/SettingsDropup.d.ts.map +1 -0
  108. package/dist/components/dashboard/SettingsDropup.js +35 -0
  109. package/dist/components/dashboard/SettingsDropup.js.map +1 -0
  110. package/dist/components/dashboard/SettingsModal.d.ts +4 -0
  111. package/dist/components/dashboard/SettingsModal.d.ts.map +1 -0
  112. package/dist/components/dashboard/SettingsModal.js +65 -0
  113. package/dist/components/dashboard/SettingsModal.js.map +1 -0
  114. package/dist/components/dashboard/SidePanel.d.ts +12 -0
  115. package/dist/components/dashboard/SidePanel.d.ts.map +1 -0
  116. package/dist/components/dashboard/SidePanel.js +79 -0
  117. package/dist/components/dashboard/SidePanel.js.map +1 -0
  118. package/dist/components/dashboard/Sidebar.d.ts +4 -0
  119. package/dist/components/dashboard/Sidebar.d.ts.map +1 -0
  120. package/dist/components/dashboard/Sidebar.js +24 -0
  121. package/dist/components/dashboard/Sidebar.js.map +1 -0
  122. package/dist/components/dashboard/SidebarLogo.d.ts +7 -0
  123. package/dist/components/dashboard/SidebarLogo.d.ts.map +1 -0
  124. package/dist/components/dashboard/SidebarLogo.js +6 -0
  125. package/dist/components/dashboard/SidebarLogo.js.map +1 -0
  126. package/dist/components/dashboard/SourceIcon.d.ts +7 -0
  127. package/dist/components/dashboard/SourceIcon.d.ts.map +1 -0
  128. package/dist/components/dashboard/SourceIcon.js +20 -0
  129. package/dist/components/dashboard/SourceIcon.js.map +1 -0
  130. package/dist/components/dashboard/StatusBadge.d.ts +14 -0
  131. package/dist/components/dashboard/StatusBadge.d.ts.map +1 -0
  132. package/dist/components/dashboard/StatusBadge.js +30 -0
  133. package/dist/components/dashboard/StatusBadge.js.map +1 -0
  134. package/dist/components/dashboard/StatusIndicator.d.ts +7 -0
  135. package/dist/components/dashboard/StatusIndicator.d.ts.map +1 -0
  136. package/dist/components/dashboard/StatusIndicator.js +26 -0
  137. package/dist/components/dashboard/StatusIndicator.js.map +1 -0
  138. package/dist/components/dashboard/Tag.d.ts +7 -0
  139. package/dist/components/dashboard/Tag.d.ts.map +1 -0
  140. package/dist/components/dashboard/Tag.js +9 -0
  141. package/dist/components/dashboard/Tag.js.map +1 -0
  142. package/dist/components/dashboard/TipCard.d.ts +5 -0
  143. package/dist/components/dashboard/TipCard.d.ts.map +1 -0
  144. package/dist/components/dashboard/TipCard.js +10 -0
  145. package/dist/components/dashboard/TipCard.js.map +1 -0
  146. package/dist/components/dashboard/ToggleSwitch.d.ts +8 -0
  147. package/dist/components/dashboard/ToggleSwitch.d.ts.map +1 -0
  148. package/dist/components/dashboard/ToggleSwitch.js +15 -0
  149. package/dist/components/dashboard/ToggleSwitch.js.map +1 -0
  150. package/dist/components/dashboard/index.d.ts +26 -0
  151. package/dist/components/dashboard/index.d.ts.map +1 -0
  152. package/dist/components/dashboard/index.js +26 -0
  153. package/dist/components/dashboard/index.js.map +1 -0
  154. package/dist/components/dashboard/types.d.ts +111 -0
  155. package/dist/components/dashboard/types.d.ts.map +1 -0
  156. package/dist/components/dashboard/types.js +2 -0
  157. package/dist/components/dashboard/types.js.map +1 -0
  158. package/dist/components/display/CodeBlock.d.ts +10 -0
  159. package/dist/components/display/CodeBlock.d.ts.map +1 -0
  160. package/dist/components/display/CodeBlock.js +20 -0
  161. package/dist/components/display/CodeBlock.js.map +1 -0
  162. package/dist/components/display/ConnectionStatus.d.ts +8 -0
  163. package/dist/components/display/ConnectionStatus.d.ts.map +1 -0
  164. package/dist/components/display/ConnectionStatus.js +5 -0
  165. package/dist/components/display/ConnectionStatus.js.map +1 -0
  166. package/dist/components/display/Logo.d.ts +16 -0
  167. package/dist/components/display/Logo.d.ts.map +1 -0
  168. package/dist/components/display/Logo.js +43 -0
  169. package/dist/components/display/Logo.js.map +1 -0
  170. package/dist/components/display/PackageManagerSelector.d.ts +8 -0
  171. package/dist/components/display/PackageManagerSelector.d.ts.map +1 -0
  172. package/dist/components/display/PackageManagerSelector.js +20 -0
  173. package/dist/components/display/PackageManagerSelector.js.map +1 -0
  174. package/dist/components/index.d.ts +41 -11
  175. package/dist/components/index.d.ts.map +1 -1
  176. package/dist/components/index.js +41 -11
  177. package/dist/components/index.js.map +1 -1
  178. package/dist/components/inputs/ApiKeyInput.d.ts +8 -0
  179. package/dist/components/inputs/ApiKeyInput.d.ts.map +1 -0
  180. package/dist/components/inputs/ApiKeyInput.js +22 -0
  181. package/dist/components/inputs/ApiKeyInput.js.map +1 -0
  182. package/dist/components/inputs/Checkbox.d.ts +11 -0
  183. package/dist/components/inputs/Checkbox.d.ts.map +1 -0
  184. package/dist/components/inputs/Checkbox.js +19 -0
  185. package/dist/components/inputs/Checkbox.js.map +1 -0
  186. package/dist/components/inputs/EmailTagInput.d.ts +9 -0
  187. package/dist/components/inputs/EmailTagInput.d.ts.map +1 -0
  188. package/dist/components/inputs/EmailTagInput.js +61 -0
  189. package/dist/components/inputs/EmailTagInput.js.map +1 -0
  190. package/dist/components/inputs/Input.d.ts +16 -0
  191. package/dist/components/inputs/Input.d.ts.map +1 -0
  192. package/dist/components/inputs/Input.js +42 -0
  193. package/dist/components/inputs/Input.js.map +1 -0
  194. package/dist/components/inputs/InputField.d.ts.map +1 -0
  195. package/dist/components/{InputField.js → inputs/InputField.js} +1 -1
  196. package/dist/components/inputs/InputField.js.map +1 -0
  197. package/dist/components/inputs/NumberStepper.d.ts +15 -0
  198. package/dist/components/inputs/NumberStepper.d.ts.map +1 -0
  199. package/dist/components/inputs/NumberStepper.js +49 -0
  200. package/dist/components/inputs/NumberStepper.js.map +1 -0
  201. package/dist/components/inputs/PermissionToggle.d.ts +15 -0
  202. package/dist/components/inputs/PermissionToggle.d.ts.map +1 -0
  203. package/dist/components/inputs/PermissionToggle.js +18 -0
  204. package/dist/components/inputs/PermissionToggle.js.map +1 -0
  205. package/dist/components/inputs/Select.d.ts +24 -0
  206. package/dist/components/inputs/Select.d.ts.map +1 -0
  207. package/dist/components/inputs/Select.js +156 -0
  208. package/dist/components/inputs/Select.js.map +1 -0
  209. package/dist/components/inputs/TagInput.d.ts +10 -0
  210. package/dist/components/inputs/TagInput.d.ts.map +1 -0
  211. package/dist/components/inputs/TagInput.js +20 -0
  212. package/dist/components/inputs/TagInput.js.map +1 -0
  213. package/dist/components/inputs/ToggleOption.d.ts +20 -0
  214. package/dist/components/inputs/ToggleOption.d.ts.map +1 -0
  215. package/dist/components/inputs/ToggleOption.js +70 -0
  216. package/dist/components/inputs/ToggleOption.js.map +1 -0
  217. package/dist/components/layout/Divider.d.ts +11 -0
  218. package/dist/components/layout/Divider.d.ts.map +1 -0
  219. package/dist/components/layout/Divider.js +15 -0
  220. package/dist/components/layout/Divider.js.map +1 -0
  221. package/dist/components/layout/Footer.d.ts +37 -0
  222. package/dist/components/layout/Footer.d.ts.map +1 -0
  223. package/dist/components/layout/Footer.js +49 -0
  224. package/dist/components/layout/Footer.js.map +1 -0
  225. package/dist/components/layout/FormSection.d.ts +9 -0
  226. package/dist/components/layout/FormSection.d.ts.map +1 -0
  227. package/dist/components/layout/FormSection.js +7 -0
  228. package/dist/components/layout/FormSection.js.map +1 -0
  229. package/dist/components/layout/LinkGroup.d.ts +15 -0
  230. package/dist/components/layout/LinkGroup.d.ts.map +1 -0
  231. package/dist/components/layout/LinkGroup.js +28 -0
  232. package/dist/components/layout/LinkGroup.js.map +1 -0
  233. package/dist/components/layout/Navbar.d.ts +32 -0
  234. package/dist/components/layout/Navbar.d.ts.map +1 -0
  235. package/dist/components/layout/Navbar.js +35 -0
  236. package/dist/components/layout/Navbar.js.map +1 -0
  237. package/dist/components/layout/PageHeader.d.ts +17 -0
  238. package/dist/components/layout/PageHeader.d.ts.map +1 -0
  239. package/dist/components/layout/PageHeader.js +86 -0
  240. package/dist/components/layout/PageHeader.js.map +1 -0
  241. package/dist/components/layout/SegmentedControl.d.ts +16 -0
  242. package/dist/components/layout/SegmentedControl.d.ts.map +1 -0
  243. package/dist/components/layout/SegmentedControl.js +24 -0
  244. package/dist/components/layout/SegmentedControl.js.map +1 -0
  245. package/dist/components/typography/HeroText.d.ts.map +1 -0
  246. package/dist/components/typography/HeroText.js.map +1 -0
  247. package/dist/components/typography/SectionLabel.d.ts.map +1 -0
  248. package/dist/components/typography/SectionLabel.js.map +1 -0
  249. package/dist/components/typography/Subtitle.d.ts.map +1 -0
  250. package/dist/components/typography/Subtitle.js.map +1 -0
  251. package/dist/components/typography/TypewriterText.d.ts.map +1 -0
  252. package/dist/components/typography/TypewriterText.js.map +1 -0
  253. package/dist/styles.css +1 -1
  254. package/package.json +9 -2
  255. package/dist/components/AnimatedBackground.d.ts.map +0 -1
  256. package/dist/components/AnimatedBackground.js.map +0 -1
  257. package/dist/components/Button.d.ts.map +0 -1
  258. package/dist/components/Button.js +0 -26
  259. package/dist/components/Button.js.map +0 -1
  260. package/dist/components/Card.d.ts.map +0 -1
  261. package/dist/components/Card.js.map +0 -1
  262. package/dist/components/Globe.d.ts.map +0 -1
  263. package/dist/components/Globe.js.map +0 -1
  264. package/dist/components/GradientBackground.d.ts.map +0 -1
  265. package/dist/components/GradientBackground.js.map +0 -1
  266. package/dist/components/HeroText.d.ts.map +0 -1
  267. package/dist/components/HeroText.js.map +0 -1
  268. package/dist/components/InputField.d.ts.map +0 -1
  269. package/dist/components/InputField.js.map +0 -1
  270. package/dist/components/Logo.d.ts +0 -6
  271. package/dist/components/Logo.d.ts.map +0 -1
  272. package/dist/components/Logo.js +0 -7
  273. package/dist/components/Logo.js.map +0 -1
  274. package/dist/components/SectionLabel.d.ts.map +0 -1
  275. package/dist/components/SectionLabel.js.map +0 -1
  276. package/dist/components/Subtitle.d.ts.map +0 -1
  277. package/dist/components/Subtitle.js.map +0 -1
  278. package/dist/components/TypewriterText.d.ts.map +0 -1
  279. package/dist/components/TypewriterText.js.map +0 -1
  280. /package/dist/components/{AnimatedBackground.d.ts → backgrounds/AnimatedBackground.d.ts} +0 -0
  281. /package/dist/components/{AnimatedBackground.js → backgrounds/AnimatedBackground.js} +0 -0
  282. /package/dist/components/{Globe.d.ts → backgrounds/Globe.d.ts} +0 -0
  283. /package/dist/components/{Globe.js → backgrounds/Globe.js} +0 -0
  284. /package/dist/components/{GradientBackground.d.ts → backgrounds/GradientBackground.d.ts} +0 -0
  285. /package/dist/components/{GradientBackground.js → backgrounds/GradientBackground.js} +0 -0
  286. /package/dist/components/{Card.d.ts → cards/Card.d.ts} +0 -0
  287. /package/dist/components/{InputField.d.ts → inputs/InputField.d.ts} +0 -0
  288. /package/dist/components/{HeroText.d.ts → typography/HeroText.d.ts} +0 -0
  289. /package/dist/components/{HeroText.js → typography/HeroText.js} +0 -0
  290. /package/dist/components/{SectionLabel.d.ts → typography/SectionLabel.d.ts} +0 -0
  291. /package/dist/components/{SectionLabel.js → typography/SectionLabel.js} +0 -0
  292. /package/dist/components/{Subtitle.d.ts → typography/Subtitle.d.ts} +0 -0
  293. /package/dist/components/{Subtitle.js → typography/Subtitle.js} +0 -0
  294. /package/dist/components/{TypewriterText.d.ts → typography/TypewriterText.d.ts} +0 -0
  295. /package/dist/components/{TypewriterText.js → typography/TypewriterText.js} +0 -0
@@ -0,0 +1,40 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { motion } from 'framer-motion';
3
+ import { cn } from '../../lib/utils';
4
+ import { Checkbox } from '../inputs/Checkbox';
5
+ export function PlanCard({ children, className = '', variant = 'default', padding = 'md', animated = true, animationDelay = 0, header, price, featuresTitle = 'INCLUDED LIMITS', specs, showSpecsDivider = true, features, footer, recommended = false, disabled = false, selected = false, showCheckbox = false, onCheckboxChange, }) {
6
+ const variantStyles = {
7
+ default: 'bg-white/[0.02] border border-white/10',
8
+ elevated: 'bg-white/[0.04] border border-white/20 shadow-card-glow',
9
+ outlined: 'bg-transparent border-2 border-white/20',
10
+ glass: 'bg-white/[0.03] backdrop-blur-lg border border-white/10',
11
+ plan: recommended
12
+ ? 'bg-white/[0.04] border border-violet-500/30 shadow-card-glow ring-1 ring-violet-500/20'
13
+ : 'bg-white/[0.02] border border-white/10 hover:border-white/20',
14
+ };
15
+ const paddingStyles = {
16
+ none: 'p-0',
17
+ sm: 'p-5',
18
+ md: 'p-8',
19
+ lg: 'p-10',
20
+ };
21
+ const buttonStyles = {
22
+ primary: 'bg-violet-600 hover:bg-violet-700 text-white shadow-glow hover:shadow-glow-hover',
23
+ secondary: 'bg-white/[0.03] hover:bg-white/[0.08] border border-white/10 text-white',
24
+ outline: 'bg-transparent border border-white/20 hover:bg-white/5 text-gray-300 hover:text-white',
25
+ };
26
+ const cardClasses = cn(variantStyles[variant], paddingStyles[padding], 'rounded-3xl transition-all duration-300 relative h-full flex flex-col', disabled && 'opacity-50 cursor-not-allowed', selected && 'ring-2 ring-violet-500', className);
27
+ const CardContent = (_jsxs("div", { className: cardClasses, children: [recommended && (_jsx("div", { className: "absolute top-0 right-0 left-0 flex justify-center -mt-3", children: _jsx("span", { className: "bg-violet-600 text-[10px] font-bold uppercase tracking-wider text-white px-3 py-1 rounded-full shadow-lg", children: "Recommended" }) })), showCheckbox && (_jsx("div", { className: "absolute top-6 right-6", children: _jsx(Checkbox, { checked: selected, onChange: e => onCheckboxChange?.(e.target.checked), size: "lg" }) })), header && (_jsxs("div", { className: cn('mb-3', recommended && 'mt-2', header.badge && 'mt-3'), children: [header.badge && (_jsx("span", { className: "inline-block bg-violet-600/20 text-violet-400 text-[10px] font-bold uppercase tracking-wider px-2 py-0.5 rounded mb-2", children: header.badge })), header.icon && (_jsx("div", { className: "mb-3 flex items-center justify-center", children: header.icon })), header.title && (_jsx("h3", { className: "text-lg font-semibold text-white mb-1", children: header.title })), header.description && (_jsx("p", { className: "text-xs text-gray-500 leading-relaxed", children: header.description }))] })), price && (_jsx("div", { className: "mb-6", children: _jsxs("div", { className: "flex items-baseline gap-1", children: [_jsx("span", { className: "text-4xl font-bold text-white", children: price.amount }), price.period && (_jsxs("span", { className: "text-gray-400 text-sm", children: ["/", price.period] }))] }) })), specs && specs.length > 0 && (_jsx("div", { className: cn('mb-5 space-y-1.5', showSpecsDivider && 'border-t border-white/5 pt-3'), children: specs.map((spec, index) => (_jsxs("div", { className: "flex justify-between text-[11px] text-gray-400", children: [_jsx("span", { children: spec.label }), _jsx("span", { className: cn(spec.highlighted ? 'text-white font-medium' : 'text-gray-200'), children: spec.value })] }, index))) })), features && features.length > 0 && (_jsxs("div", { className: "flex-grow mb-6", children: [featuresTitle && (_jsx("h4", { className: "text-[10px] font-bold uppercase tracking-wider text-gray-500 mb-4", children: featuresTitle })), _jsx("div", { className: "space-y-3", children: features.map((feature, index) => {
28
+ const textColor = feature.variant === 'disabled'
29
+ ? 'text-gray-500'
30
+ : feature.variant === 'highlighted'
31
+ ? 'text-gray-200 font-medium'
32
+ : 'text-gray-300';
33
+ return (_jsxs("div", { className: "flex items-center gap-3", children: [_jsx("span", { className: "text-violet-500 flex-shrink-0 text-sm", children: feature.icon }), _jsx("span", { className: cn('text-xs', textColor), children: feature.text })] }, index));
34
+ }) })] })), children && _jsx("div", { className: "flex-grow", children: children }), footer && (_jsxs("div", { className: "mt-auto", children: [footer.buttons && footer.buttons.length > 0 && (_jsx("div", { className: "space-y-2", children: footer.buttons.map((button, index) => (_jsx("button", { type: "button", onClick: button.onClick, disabled: disabled, className: cn('w-full text-sm font-medium py-2.5 rounded-full transition-all duration-200', 'disabled:opacity-50 disabled:cursor-not-allowed', buttonStyles[button.variant || 'outline']), children: button.text }, index))) })), footer.content && _jsx("div", { children: footer.content })] }))] }));
35
+ if (animated) {
36
+ return (_jsx(motion.div, { initial: { opacity: 0, y: 20 }, animate: { opacity: 1, y: 0 }, transition: { duration: 0.5, delay: animationDelay }, children: CardContent }));
37
+ }
38
+ return CardContent;
39
+ }
40
+ //# sourceMappingURL=PlanCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PlanCard.js","sourceRoot":"","sources":["../../../src/components/cards/PlanCard.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,35 @@
1
+ import { ReactNode } from 'react';
2
+ export interface PricingFeature {
3
+ label: string;
4
+ included: boolean;
5
+ }
6
+ export interface PricingInfoItem {
7
+ icon: ReactNode;
8
+ text: string;
9
+ }
10
+ export interface PricingCardProps {
11
+ icon: ReactNode;
12
+ category: string;
13
+ title: string;
14
+ description: string;
15
+ price: number | string;
16
+ period?: string;
17
+ interactions?: string;
18
+ patterns?: string;
19
+ infoItems?: PricingInfoItem[];
20
+ features: PricingFeature[];
21
+ isPopular?: boolean;
22
+ popularBadgeText?: string;
23
+ accentColor?: string;
24
+ borderColor?: string;
25
+ hoverBorderColor?: string;
26
+ backgroundColor?: string;
27
+ className?: string;
28
+ buttonText?: string;
29
+ onButtonClick?: () => void;
30
+ checkIcon?: ReactNode;
31
+ animated?: boolean;
32
+ animationDelay?: number;
33
+ }
34
+ export declare function PricingCard({ icon, category, title, description, price, period, interactions, patterns, infoItems, features, isPopular, popularBadgeText, accentColor, borderColor, hoverBorderColor, backgroundColor, className, buttonText, onButtonClick, checkIcon, animated, animationDelay, }: PricingCardProps): import("react/jsx-runtime").JSX.Element;
35
+ //# sourceMappingURL=PricingCard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PricingCard.d.ts","sourceRoot":"","sources":["../../../src/components/cards/PricingCard.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAMlC,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,OAAO,CAAC;CACnB;AAED,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,SAAS,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,SAAS,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;IACvB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,eAAe,EAAE,CAAC;IAC9B,QAAQ,EAAE,cAAc,EAAE,CAAC;IAC3B,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,IAAI,CAAC;IAC3B,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,wBAAgB,WAAW,CAAC,EAC1B,IAAI,EACJ,QAAQ,EACR,KAAK,EACL,WAAW,EACX,KAAK,EACL,MAAa,EACb,YAAY,EACZ,QAAQ,EACR,SAAS,EACT,QAAQ,EACR,SAAiB,EACjB,gBAAiC,EACjC,WAAuB,EACvB,WAAW,EACX,gBAAgB,EAChB,eAAe,EACf,SAAc,EACd,UAAU,EACV,aAAa,EACb,SAAS,EACT,QAAe,EACf,cAAkB,GACnB,EAAE,gBAAgB,2CAsIlB"}
@@ -0,0 +1,42 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { motion } from 'framer-motion';
4
+ import { IoCheckmarkCircleOutline } from 'react-icons/io5';
5
+ import { PiHeadCircuit } from 'react-icons/pi';
6
+ import { MdOutlineTouchApp } from 'react-icons/md';
7
+ export function PricingCard({ icon, category, title, description, price, period = 'mo', interactions, patterns, infoItems, features, isPopular = false, popularBadgeText = 'MOST POPULAR', accentColor = '#8B5CF6', borderColor, hoverBorderColor, backgroundColor, className = '', buttonText, onButtonClick, checkIcon, animated = true, animationDelay = 0, }) {
8
+ const defaultBorderColor = borderColor || (isPopular ? '#7C3AED80' : 'rgba(255, 255, 255, 0.1)');
9
+ const defaultHoverBorderColor = hoverBorderColor || 'rgba(255, 255, 255, 0.2)';
10
+ const defaultBackgroundColor = backgroundColor || 'bg-gradient-to-b from-white/5 to-transparent';
11
+ const displayInfoItems = infoItems || [
12
+ ...(interactions
13
+ ? [
14
+ {
15
+ icon: _jsx(MdOutlineTouchApp, { className: "h-4 w-4 text-gray-400" }),
16
+ text: interactions,
17
+ },
18
+ ]
19
+ : []),
20
+ ...(patterns
21
+ ? [
22
+ {
23
+ icon: _jsx(PiHeadCircuit, { className: "h-4 w-4 text-gray-400" }),
24
+ text: patterns,
25
+ },
26
+ ]
27
+ : []),
28
+ ];
29
+ const CardContent = (_jsxs("div", { className: `relative flex h-full flex-col rounded-2xl border ${defaultBackgroundColor} p-5 backdrop-blur-sm transition-all ${className}`, style: {
30
+ borderColor: defaultBorderColor,
31
+ '--hover-border-color': defaultHoverBorderColor,
32
+ }, onMouseEnter: e => {
33
+ e.currentTarget.style.borderColor = defaultHoverBorderColor;
34
+ }, onMouseLeave: e => {
35
+ e.currentTarget.style.borderColor = defaultBorderColor;
36
+ }, children: [isPopular && (_jsx("div", { className: "absolute -top-3 left-1/2 -translate-x-1/2", children: _jsx("span", { className: "rounded-full bg-purple-500 px-4 py-1 text-xs font-semibold text-white", children: popularBadgeText }) })), _jsxs("div", { className: "flex-grow", children: [_jsxs("div", { className: "flex items-center justify-between mb-5", children: [_jsx("div", { className: "flex h-10 w-10 items-center justify-center rounded-lg border border-white/10", style: { backgroundColor: `${accentColor}15` }, children: icon }), _jsx("span", { className: "text-xs font-medium uppercase tracking-wider text-gray-400", children: category })] }), _jsx("h3", { className: "mb-1.5 text-xl font-bold", style: { color: accentColor }, children: title }), _jsx("p", { className: "mb-5 text-sm text-gray-400", children: description })] }), _jsx("div", { className: "mb-5 border-t border-white/10 pt-5", children: _jsxs("div", { className: "flex items-baseline gap-1", children: [_jsx("span", { className: "text-3xl font-bold text-white", children: typeof price === 'number' ? `$${price}` : price }), period && _jsxs("span", { className: "text-gray-400", children: ["/", period] })] }) }), displayInfoItems.length > 0 && (_jsx("div", { className: "mb-5 space-y-2.5 text-sm", children: displayInfoItems.map((item, index) => (_jsxs("div", { className: "flex items-center gap-2 text-gray-300", children: [item.icon, _jsx("span", { children: item.text })] }, index))) })), _jsx("div", { className: "space-y-2.5", children: features.map((feature, index) => (_jsxs("div", { className: "flex items-center gap-2.5", children: [checkIcon || (_jsx(IoCheckmarkCircleOutline, { className: `h-4 w-4 ${feature.included ? 'opacity-100' : 'opacity-30'}`, style: { color: feature.included ? accentColor : '#666' } })), _jsx("span", { className: `text-sm ${feature.included ? 'text-gray-200' : 'text-gray-500'}`, children: feature.label })] }, index))) }), buttonText && (_jsx("button", { onClick: onButtonClick, className: "mt-5 w-full rounded-lg py-2.5 text-sm font-semibold text-white transition-all hover:opacity-90", style: { backgroundColor: accentColor }, children: buttonText }))] }));
37
+ if (animated) {
38
+ return (_jsx(motion.div, { className: "h-full", initial: { opacity: 0, y: 20 }, animate: { opacity: 1, y: 0 }, transition: { duration: 0.5, delay: animationDelay }, children: CardContent }));
39
+ }
40
+ return CardContent;
41
+ }
42
+ //# sourceMappingURL=PricingCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PricingCard.js","sourceRoot":"","sources":["../../../src/components/cards/PricingCard.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ interface RunAgentCardProps {
2
+ command: string;
3
+ description?: string;
4
+ title?: string;
5
+ onCopy?: (success: boolean) => void;
6
+ }
7
+ export declare function RunAgentCard({ command, description, title, onCopy, }: RunAgentCardProps): import("react/jsx-runtime").JSX.Element;
8
+ export {};
9
+ //# sourceMappingURL=RunAgentCard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RunAgentCard.d.ts","sourceRoot":"","sources":["../../../src/components/cards/RunAgentCard.tsx"],"names":[],"mappings":"AAEA,UAAU,iBAAiB;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;CACrC;AAED,wBAAgB,YAAY,CAAC,EAC3B,OAAO,EACP,WAA4F,EAC5F,KAAmB,EACnB,MAAM,GACP,EAAE,iBAAiB,2CAqCnB"}
@@ -0,0 +1,15 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { LuCopy } from 'react-icons/lu';
3
+ export function RunAgentCard({ command, description = 'Run this command on your local CCTV server to initiate the secure handshake.', title = 'Run agent', onCopy, }) {
4
+ const handleCopy = async () => {
5
+ try {
6
+ await navigator.clipboard.writeText(command);
7
+ onCopy?.(true);
8
+ }
9
+ catch (err) {
10
+ onCopy?.(false);
11
+ }
12
+ };
13
+ return (_jsxs("div", { className: "bg-white/[0.03] backdrop-blur-md border border-white/10 rounded-xl p-4 flex flex-col gap-3 h-full", children: [_jsx("h3", { className: "text-xs font-semibold text-violet-200/70 tracking-tight uppercase", children: title }), _jsxs("div", { className: "flex-grow flex flex-col justify-start", children: [_jsxs("div", { className: "w-full bg-[#050508] border border-white/10 rounded-lg p-3 flex items-center justify-between group-hover:border-violet-500/30 transition-colors overflow-hidden", children: [_jsx("code", { className: "text-xs text-gray-300 font-mono whitespace-nowrap overflow-x-auto pb-1 -mb-1 scrollbar-hide mr-2", children: command }), _jsx("div", { className: "bg-[#050508] pl-2 sticky right-0", children: _jsx("button", { type: "button", onClick: handleCopy, className: "text-gray-500 hover:text-white transition-colors", "aria-label": "Copy command to clipboard", children: _jsx(LuCopy, { className: "text-[14px]" }) }) })] }), _jsx("p", { className: "text-[10px] text-gray-600 mt-2 leading-tight", children: description })] })] }));
14
+ }
15
+ //# sourceMappingURL=RunAgentCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RunAgentCard.js","sourceRoot":"","sources":["../../../src/components/cards/RunAgentCard.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AASxC,MAAM,UAAU,YAAY,CAAC,EAC3B,OAAO,EACP,WAAW,GAAG,8EAA8E,EAC5F,KAAK,GAAG,WAAW,EACnB,MAAM,GACY;IAClB,MAAM,UAAU,GAAG,KAAK,IAAI,EAAE;QAC5B,IAAI,CAAC;YACH,MAAM,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;YAC7C,MAAM,EAAE,CAAC,IAAI,CAAC,CAAC;QACjB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,MAAM,EAAE,CAAC,KAAK,CAAC,CAAC;QAClB,CAAC;IACH,CAAC,CAAC;IAEF,OAAO,CACL,eAAK,SAAS,EAAC,mGAAmG,aAChH,aAAI,SAAS,EAAC,mEAAmE,YAC9E,KAAK,GACH,EACL,eAAK,SAAS,EAAC,uCAAuC,aACpD,eAAK,SAAS,EAAC,gKAAgK,aAC7K,eAAM,SAAS,EAAC,kGAAkG,YAC/G,OAAO,GACH,EACP,cAAK,SAAS,EAAC,kCAAkC,YAC/C,iBACE,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,UAAU,EACnB,SAAS,EAAC,kDAAkD,gBACjD,2BAA2B,YAEtC,KAAC,MAAM,IAAC,SAAS,EAAC,aAAa,GAAG,GAC3B,GACL,IACF,EACN,YAAG,SAAS,EAAC,8CAA8C,YACxD,WAAW,GACV,IACA,IACF,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,8 @@
1
+ interface SyncStatusCardProps {
2
+ lastSync?: string;
3
+ mentions?: number;
4
+ status?: 'ready' | 'syncing' | 'error';
5
+ }
6
+ export declare function SyncStatusCard({ lastSync, mentions, status, }: SyncStatusCardProps): import("react/jsx-runtime").JSX.Element;
7
+ export {};
8
+ //# sourceMappingURL=SyncStatusCard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SyncStatusCard.d.ts","sourceRoot":"","sources":["../../../src/components/cards/SyncStatusCard.tsx"],"names":[],"mappings":"AAAA,UAAU,mBAAmB;IAC3B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,OAAO,GAAG,SAAS,GAAG,OAAO,CAAC;CACxC;AAED,wBAAgB,cAAc,CAAC,EAC7B,QAAsB,EACtB,QAAe,EACf,MAAgB,GACjB,EAAE,mBAAmB,2CAkDrB"}
@@ -0,0 +1,29 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ export function SyncStatusCard({ lastSync = '2 min ago', mentions = 1284, status = 'ready', }) {
3
+ const statusConfig = {
4
+ ready: {
5
+ label: 'SYNC READY',
6
+ color: 'bg-violet-400',
7
+ borderColor: 'border-violet-500/30',
8
+ bgColor: 'bg-violet-500/5',
9
+ textColor: 'text-violet-300',
10
+ },
11
+ syncing: {
12
+ label: 'SYNCING',
13
+ color: 'bg-blue-400',
14
+ borderColor: 'border-blue-500/30',
15
+ bgColor: 'bg-blue-500/5',
16
+ textColor: 'text-blue-300',
17
+ },
18
+ error: {
19
+ label: 'ERROR',
20
+ color: 'bg-red-400',
21
+ borderColor: 'border-red-500/30',
22
+ bgColor: 'bg-red-500/5',
23
+ textColor: 'text-red-300',
24
+ },
25
+ };
26
+ const currentStatus = statusConfig[status];
27
+ return (_jsxs("div", { className: "mt-auto bg-[#0a0a0f]/60 rounded-xl p-3 border border-white/5 flex flex-col gap-2", children: [_jsxs("div", { className: "flex items-center justify-between text-[11px] text-gray-400", children: [_jsxs("span", { children: ["Last sync: ", _jsx("span", { className: "text-gray-300", children: lastSync })] }), _jsxs("span", { children: ["Mentions:", ' ', _jsx("span", { className: "text-gray-300", children: mentions.toLocaleString() })] })] }), _jsx("div", { className: "flex items-center gap-2", children: _jsxs("div", { className: `px-2 py-0.5 rounded-full border ${currentStatus.borderColor} text-[10px] font-bold tracking-wider ${currentStatus.textColor} uppercase ${currentStatus.bgColor} flex items-center gap-1.5`, children: [_jsx("div", { className: `w-1.5 h-1.5 rounded-full ${currentStatus.color} shadow-[0_0_5px_rgba(167,139,250,0.5)]` }), currentStatus.label] }) })] }));
28
+ }
29
+ //# sourceMappingURL=SyncStatusCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SyncStatusCard.js","sourceRoot":"","sources":["../../../src/components/cards/SyncStatusCard.tsx"],"names":[],"mappings":";AAMA,MAAM,UAAU,cAAc,CAAC,EAC7B,QAAQ,GAAG,WAAW,EACtB,QAAQ,GAAG,IAAI,EACf,MAAM,GAAG,OAAO,GACI;IACpB,MAAM,YAAY,GAAG;QACnB,KAAK,EAAE;YACL,KAAK,EAAE,YAAY;YACnB,KAAK,EAAE,eAAe;YACtB,WAAW,EAAE,sBAAsB;YACnC,OAAO,EAAE,iBAAiB;YAC1B,SAAS,EAAE,iBAAiB;SAC7B;QACD,OAAO,EAAE;YACP,KAAK,EAAE,SAAS;YAChB,KAAK,EAAE,aAAa;YACpB,WAAW,EAAE,oBAAoB;YACjC,OAAO,EAAE,eAAe;YACxB,SAAS,EAAE,eAAe;SAC3B;QACD,KAAK,EAAE;YACL,KAAK,EAAE,OAAO;YACd,KAAK,EAAE,YAAY;YACnB,WAAW,EAAE,mBAAmB;YAChC,OAAO,EAAE,cAAc;YACvB,SAAS,EAAE,cAAc;SAC1B;KACF,CAAC;IAEF,MAAM,aAAa,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC;IAE3C,OAAO,CACL,eAAK,SAAS,EAAC,kFAAkF,aAC/F,eAAK,SAAS,EAAC,6DAA6D,aAC1E,0CACa,eAAM,SAAS,EAAC,eAAe,YAAE,QAAQ,GAAQ,IACvD,EACP,wCACY,GAAG,EACb,eAAM,SAAS,EAAC,eAAe,YAAE,QAAQ,CAAC,cAAc,EAAE,GAAQ,IAC7D,IACH,EACN,cAAK,SAAS,EAAC,yBAAyB,YACtC,eACE,SAAS,EAAE,mCAAmC,aAAa,CAAC,WAAW,yCAAyC,aAAa,CAAC,SAAS,cAAc,aAAa,CAAC,OAAO,4BAA4B,aAEtM,cACE,SAAS,EAAE,4BAA4B,aAAa,CAAC,KAAK,yCAAyC,GAC9F,EACN,aAAa,CAAC,KAAK,IAChB,GACF,IACF,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { ChatHistoryItem, ChatHistorySectionProps } from './types';
2
+ export type { ChatHistoryItem, ChatHistorySectionProps };
3
+ export declare function ChatHistorySection({ items, activeItemId, isExpanded, isVisible, onItemClick, onToggleExpanded, onRename, onDelete, title, emptyMessage, }: ChatHistorySectionProps): import("react/jsx-runtime").JSX.Element | null;
4
+ //# sourceMappingURL=ChatHistorySection.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ChatHistorySection.d.ts","sourceRoot":"","sources":["../../../src/components/dashboard/ChatHistorySection.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,uBAAuB,EAAE,MAAM,SAAS,CAAC;AAKxE,YAAY,EAAE,eAAe,EAAE,uBAAuB,EAAE,CAAC;AAEzD,wBAAgB,kBAAkB,CAAC,EACjC,KAAU,EACV,YAAY,EACZ,UAAiB,EACjB,SAAgB,EAChB,WAAW,EACX,gBAAgB,EAChB,QAAQ,EACR,QAAQ,EACR,KAAsB,EACtB,YAAoD,GACrD,EAAE,uBAAuB,kDA4OzB"}
@@ -0,0 +1,116 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { ChevronDown, MoreHorizontal, Pencil, Trash2 } from 'lucide-react';
4
+ import { useEffect, useRef, useState } from 'react';
5
+ import { cn } from '../../lib/utils';
6
+ export function ChatHistorySection({ items = [], activeItemId, isExpanded = true, isVisible = true, onItemClick, onToggleExpanded, onRename, onDelete, title = 'Chat History', emptyMessage = 'No chats yet. Start a conversation!', }) {
7
+ const [newItemId, setNewItemId] = useState(null);
8
+ const [canAnimate, setCanAnimate] = useState(false);
9
+ const [openMenuId, setOpenMenuId] = useState(null);
10
+ const [editingId, setEditingId] = useState(null);
11
+ const [editValue, setEditValue] = useState('');
12
+ const menuRef = useRef(null);
13
+ const inputRef = useRef(null);
14
+ const seenItemsRef = useRef(new Set());
15
+ useEffect(() => {
16
+ for (const item of items) {
17
+ seenItemsRef.current.add(item.id);
18
+ }
19
+ const timer = setTimeout(() => {
20
+ setCanAnimate(true);
21
+ }, 600);
22
+ return () => clearTimeout(timer);
23
+ }, []);
24
+ useEffect(() => {
25
+ if (!canAnimate) {
26
+ for (const item of items) {
27
+ seenItemsRef.current.add(item.id);
28
+ }
29
+ return;
30
+ }
31
+ const seenItems = seenItemsRef.current;
32
+ const firstItem = items[0];
33
+ if (firstItem && !seenItems.has(firstItem.id)) {
34
+ seenItems.add(firstItem.id);
35
+ const timer = setTimeout(() => setNewItemId(firstItem.id), 0);
36
+ const resetTimer = setTimeout(() => setNewItemId(null), 350);
37
+ return () => {
38
+ clearTimeout(timer);
39
+ clearTimeout(resetTimer);
40
+ };
41
+ }
42
+ for (const item of items) {
43
+ seenItems.add(item.id);
44
+ }
45
+ }, [items, canAnimate]);
46
+ useEffect(() => {
47
+ if (!openMenuId)
48
+ return;
49
+ const handleClickOutside = (e) => {
50
+ if (menuRef.current && !menuRef.current.contains(e.target)) {
51
+ setOpenMenuId(null);
52
+ }
53
+ };
54
+ document.addEventListener('mousedown', handleClickOutside);
55
+ return () => document.removeEventListener('mousedown', handleClickOutside);
56
+ }, [openMenuId]);
57
+ useEffect(() => {
58
+ if (editingId && inputRef.current) {
59
+ inputRef.current.focus();
60
+ inputRef.current.select();
61
+ }
62
+ }, [editingId]);
63
+ const handleMenuClick = (e, itemId) => {
64
+ e.stopPropagation();
65
+ setOpenMenuId(openMenuId === itemId ? null : itemId);
66
+ };
67
+ const handleMenuKeyDown = (e, itemId) => {
68
+ if (e.key === 'Enter' || e.key === ' ') {
69
+ e.preventDefault();
70
+ e.stopPropagation();
71
+ setOpenMenuId(openMenuId === itemId ? null : itemId);
72
+ }
73
+ };
74
+ const handleRenameStart = (item) => {
75
+ setEditingId(item.id);
76
+ setEditValue(item.title);
77
+ setOpenMenuId(null);
78
+ };
79
+ const handleRenameSubmit = () => {
80
+ if (editingId && editValue.trim()) {
81
+ onRename?.(editingId, editValue.trim());
82
+ }
83
+ setEditingId(null);
84
+ setEditValue('');
85
+ };
86
+ const handleRenameKeyDown = (e) => {
87
+ if (e.key === 'Enter') {
88
+ handleRenameSubmit();
89
+ }
90
+ else if (e.key === 'Escape') {
91
+ setEditingId(null);
92
+ setEditValue('');
93
+ }
94
+ };
95
+ const handleDelete = (id) => {
96
+ setOpenMenuId(null);
97
+ onDelete?.(id);
98
+ };
99
+ if (!isVisible)
100
+ return null;
101
+ return (_jsxs("div", { className: cn('px-4 mt-4 transition-opacity duration-300 ease-in-out', isVisible ? 'opacity-100' : 'opacity-0'), children: [_jsxs("button", { type: "button", onClick: onToggleExpanded, className: "flex items-center justify-between w-full group", children: [_jsx("span", { className: "text-[13px] font-normal text-gray-400 leading-[21px]", children: title }), _jsx(ChevronDown, { size: 16, className: cn('text-gray-600 transition-transform duration-200', !isExpanded && '-rotate-90') })] }), _jsx("div", { className: "overflow-hidden transition-all duration-300 ease-in-out", style: {
102
+ maxHeight: isExpanded
103
+ ? `${Math.max(items.length * 42 + 16, 60)}px`
104
+ : '0px',
105
+ opacity: isExpanded ? 1 : 0,
106
+ }, children: _jsx("div", { className: "mt-2 flex flex-col gap-1", children: items.length === 0 ? (_jsx("p", { className: "text-xs italic py-2 text-gray-500", children: emptyMessage })) : (items.map(item => {
107
+ const isActive = item.id === activeItemId;
108
+ const isNew = item.id === newItemId;
109
+ const isEditing = editingId === item.id;
110
+ const isMenuOpen = openMenuId === item.id;
111
+ return (_jsxs("div", { className: "relative", ref: isMenuOpen ? menuRef : undefined, children: [_jsxs("button", { type: "button", onClick: () => !isEditing && onItemClick?.(item.id), className: cn('group relative flex items-center justify-between w-full rounded-lg transition-all duration-200', 'h-[37px] hover:bg-white/5', isActive &&
112
+ 'bg-white/[0.08] shadow-[inset_0px_1px_0px_1px_rgba(255,255,255,0.05)] outline outline-1 outline-white/[0.05] -outline-offset-1', isNew &&
113
+ 'animate-[chatHistorySlideIn_0.3s_ease-out_forwards]'), children: [isEditing ? (_jsx("input", { ref: inputRef, type: "text", value: editValue, onChange: e => setEditValue(e.target.value), onBlur: handleRenameSubmit, onKeyDown: handleRenameKeyDown, className: "text-[13px] font-bold bg-transparent border-none outline-none pl-3 pr-8 w-full text-gray-200 leading-[21px]", onClick: e => e.stopPropagation() })) : (_jsx("span", { className: "text-[13px] font-bold truncate pl-3 pr-8 text-left text-gray-200 leading-[21px] max-w-[198px]", children: item.title })), isActive && !isEditing && (_jsx("button", { type: "button", className: "absolute right-2 flex items-center justify-center w-[19px] h-[19px] cursor-pointer hover:bg-white/10 rounded", onClick: e => handleMenuClick(e, item.id), onKeyDown: e => handleMenuKeyDown(e, item.id), "aria-label": "Chat options", "aria-haspopup": "menu", "aria-expanded": isMenuOpen, children: _jsx(MoreHorizontal, { size: 14, className: "text-white" }) }))] }), isMenuOpen && (_jsxs("div", { role: "menu", className: "absolute right-0 top-full mt-1 z-50 min-w-[140px] rounded-lg overflow-hidden bg-[rgba(30,30,30,0.95)] border border-white/10 shadow-[0_4px_12px_rgba(0,0,0,0.5)]", children: [_jsxs("button", { type: "button", role: "menuitem", onClick: () => handleRenameStart(item), className: "flex items-center gap-2 w-full px-3 py-2 text-left hover:bg-white/10 transition-colors", children: [_jsx(Pencil, { size: 14, className: "text-gray-400" }), _jsx("span", { className: "text-[13px] text-gray-200", children: "Rename" })] }), _jsxs("button", { type: "button", role: "menuitem", onClick: () => handleDelete(item.id), className: "flex items-center gap-2 w-full px-3 py-2 text-left hover:bg-red-500/20 transition-colors", children: [_jsx(Trash2, { size: 14, className: "text-red-400" }), _jsx("span", { className: "text-[13px] text-red-400", children: "Delete" })] })] }))] }, item.id));
114
+ })) }) })] }));
115
+ }
116
+ //# sourceMappingURL=ChatHistorySection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ChatHistorySection.js","sourceRoot":"","sources":["../../../src/components/dashboard/ChatHistorySection.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import type { DashboardBackgroundProps } from './types';
2
+ export type { DashboardBackgroundProps };
3
+ export declare function DashboardBackground({ variant, noiseTextureSrc, sidebarWidth, }: DashboardBackgroundProps): import("react/jsx-runtime").JSX.Element;
4
+ //# sourceMappingURL=DashboardBackground.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DashboardBackground.d.ts","sourceRoot":"","sources":["../../../src/components/dashboard/DashboardBackground.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,SAAS,CAAC;AAGxD,YAAY,EAAE,wBAAwB,EAAE,CAAC;AAIzC,wBAAgB,mBAAmB,CAAC,EAClC,OAAmB,EACnB,eAAuC,EACvC,YAAkB,GACnB,EAAE,wBAAwB,2CAqD1B"}
@@ -0,0 +1,13 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { cn } from '../../lib/utils';
4
+ const DEFAULT_NOISE_TEXTURE = '/textures/noise.png';
5
+ export function DashboardBackground({ variant = 'default', noiseTextureSrc = DEFAULT_NOISE_TEXTURE, sidebarWidth = 280, }) {
6
+ if (variant === 'minimal') {
7
+ return (_jsx("div", { className: "fixed inset-0 pointer-events-none z-0", children: _jsx("div", { className: "absolute inset-0 bg-[#030005]" }) }));
8
+ }
9
+ return (_jsxs("div", { className: "fixed inset-0 pointer-events-none z-0 overflow-hidden", style: { '--sidebar-width': `${sidebarWidth}px` }, children: [_jsx("div", { className: "absolute inset-0 bg-[#030005]" }), _jsx("div", { className: cn('absolute top-0 bottom-0 right-0', 'bg-gradient-to-l from-[#1E1035] via-[#0A0515] to-transparent', 'animate-[fadeInHalf_0.6s_cubic-bezier(0.22,1,0.36,1)_forwards] opacity-0'), style: { left: `calc(var(--sidebar-width) + 25%)` } }), _jsx("img", { src: noiseTextureSrc, alt: "", role: "presentation", className: "absolute inset-0 w-full h-full opacity-[0.07] mix-blend-overlay object-cover" }), _jsx("div", { className: cn('absolute inset-0', 'animate-[fadeIn_0.6s_cubic-bezier(0.22,1,0.36,1)_forwards] opacity-0'), style: {
10
+ background: `radial-gradient(ellipse 55% 90% at calc(50% + calc(var(--sidebar-width) / 2)) 50%, rgba(3, 0, 5, 0) 0%, rgba(3, 0, 5, 0.50) 100%)`,
11
+ } }), _jsx("div", { className: cn('absolute w-[950px] h-[450px] bottom-0', 'bg-[rgba(133,78,210,0.45)] blur-[150px]', 'left-1/2 -translate-x-1/2 translate-y-[85%]', 'animate-[riseFromBelow_0.7s_cubic-bezier(0.22,1,0.36,1)_forwards]', 'md:left-[calc(50%+calc(var(--sidebar-width)/2))]') })] }));
12
+ }
13
+ //# sourceMappingURL=DashboardBackground.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DashboardBackground.js","sourceRoot":"","sources":["../../../src/components/dashboard/DashboardBackground.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAGb,OAAO,EAAE,EAAE,EAAE,MAAM,iBAAiB,CAAC;AAIrC,MAAM,qBAAqB,GAAG,qBAAqB,CAAC;AAEpD,MAAM,UAAU,mBAAmB,CAAC,EAClC,OAAO,GAAG,SAAS,EACnB,eAAe,GAAG,qBAAqB,EACvC,YAAY,GAAG,GAAG,GACO;IACzB,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;QAC1B,OAAO,CACL,cAAK,SAAS,EAAC,uCAAuC,YACpD,cAAK,SAAS,EAAC,+BAA+B,GAAG,GAC7C,CACP,CAAC;IACJ,CAAC;IAED,OAAO,CACL,eACE,SAAS,EAAC,uDAAuD,EACjE,KAAK,EAAE,EAAE,iBAAiB,EAAE,GAAG,YAAY,IAAI,EAAyB,aAExE,cAAK,SAAS,EAAC,+BAA+B,GAAG,EAEjD,cACE,SAAS,EAAE,EAAE,CACX,iCAAiC,EACjC,8DAA8D,EAC9D,0EAA0E,CAC3E,EACD,KAAK,EAAE,EAAE,IAAI,EAAE,kCAAkC,EAAE,GACnD,EAEF,cACE,GAAG,EAAE,eAAe,EACpB,GAAG,EAAC,EAAE,EACN,IAAI,EAAC,cAAc,EACnB,SAAS,EAAC,8EAA8E,GACxF,EAEF,cACE,SAAS,EAAE,EAAE,CACX,kBAAkB,EAClB,sEAAsE,CACvE,EACD,KAAK,EAAE;oBACL,UAAU,EAAE,mIAAmI;iBAChJ,GACD,EAEF,cACE,SAAS,EAAE,EAAE,CACX,uCAAuC,EACvC,yCAAyC,EACzC,6CAA6C,EAC7C,mEAAmE,EACnE,kDAAkD,CACnD,GACD,IACE,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,14 @@
1
+ export interface FilterOption {
2
+ label: string;
3
+ value: string;
4
+ }
5
+ export interface FilterDropdownProps {
6
+ label: string;
7
+ options: FilterOption[];
8
+ value?: string;
9
+ onChange?: (value: string) => void;
10
+ className?: string;
11
+ showBorder?: boolean;
12
+ }
13
+ export declare function FilterDropdown({ label, options, value, onChange, className, showBorder, }: FilterDropdownProps): import("react/jsx-runtime").JSX.Element;
14
+ //# sourceMappingURL=FilterDropdown.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FilterDropdown.d.ts","sourceRoot":"","sources":["../../../src/components/dashboard/FilterDropdown.tsx"],"names":[],"mappings":"AAOA,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,mBAAmB;IAClC,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,YAAY,EAAE,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,wBAAgB,cAAc,CAAC,EAC7B,KAAK,EACL,OAAO,EACP,KAAK,EACL,QAAQ,EACR,SAAS,EACT,UAAkB,GACnB,EAAE,mBAAmB,2CA4LrB"}
@@ -0,0 +1,115 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { Check, ChevronDown } from 'lucide-react';
4
+ import { useCallback, useEffect, useRef, useState } from 'react';
5
+ import { createPortal } from 'react-dom';
6
+ import { cn } from '../../lib/utils';
7
+ export function FilterDropdown({ label, options, value, onChange, className, showBorder = false, }) {
8
+ const [isOpen, setIsOpen] = useState(false);
9
+ const [selectedValue, setSelectedValue] = useState(value || options[0]?.value);
10
+ const [focusedIndex, setFocusedIndex] = useState(-1);
11
+ const [dropdownPosition, setDropdownPosition] = useState({ top: 0, left: 0 });
12
+ const buttonRef = useRef(null);
13
+ const dropdownRef = useRef(null);
14
+ useEffect(() => {
15
+ if (value !== undefined && value !== selectedValue) {
16
+ const timer = setTimeout(() => setSelectedValue(value), 0);
17
+ return () => clearTimeout(timer);
18
+ }
19
+ }, [value, selectedValue]);
20
+ const selectedOption = options.find(opt => opt.value === selectedValue);
21
+ const updatePosition = useCallback(() => {
22
+ if (buttonRef.current) {
23
+ const rect = buttonRef.current.getBoundingClientRect();
24
+ setDropdownPosition({
25
+ top: rect.bottom + 4,
26
+ left: rect.left,
27
+ });
28
+ }
29
+ }, []);
30
+ useEffect(() => {
31
+ function handleClickOutside(event) {
32
+ const target = event.target;
33
+ if (buttonRef.current &&
34
+ !buttonRef.current.contains(target) &&
35
+ dropdownRef.current &&
36
+ !dropdownRef.current.contains(target)) {
37
+ setIsOpen(false);
38
+ setFocusedIndex(-1);
39
+ }
40
+ }
41
+ document.addEventListener('mousedown', handleClickOutside);
42
+ return () => document.removeEventListener('mousedown', handleClickOutside);
43
+ }, []);
44
+ useEffect(() => {
45
+ if (isOpen) {
46
+ updatePosition();
47
+ window.addEventListener('scroll', updatePosition, true);
48
+ window.addEventListener('resize', updatePosition);
49
+ return () => {
50
+ window.removeEventListener('scroll', updatePosition, true);
51
+ window.removeEventListener('resize', updatePosition);
52
+ };
53
+ }
54
+ }, [isOpen, updatePosition]);
55
+ const handleSelect = (optionValue) => {
56
+ setSelectedValue(optionValue);
57
+ onChange?.(optionValue);
58
+ setIsOpen(false);
59
+ setFocusedIndex(-1);
60
+ };
61
+ const handleToggle = () => {
62
+ if (!isOpen) {
63
+ updatePosition();
64
+ setFocusedIndex(0);
65
+ }
66
+ setIsOpen(!isOpen);
67
+ };
68
+ const handleKeyDown = (e) => {
69
+ if (!isOpen) {
70
+ if (e.key === 'Enter' || e.key === ' ' || e.key === 'ArrowDown') {
71
+ e.preventDefault();
72
+ updatePosition();
73
+ setIsOpen(true);
74
+ setFocusedIndex(0);
75
+ }
76
+ return;
77
+ }
78
+ switch (e.key) {
79
+ case 'Escape':
80
+ e.preventDefault();
81
+ setIsOpen(false);
82
+ setFocusedIndex(-1);
83
+ buttonRef.current?.focus();
84
+ break;
85
+ case 'ArrowDown':
86
+ e.preventDefault();
87
+ setFocusedIndex(prev => (prev < options.length - 1 ? prev + 1 : 0));
88
+ break;
89
+ case 'ArrowUp':
90
+ e.preventDefault();
91
+ setFocusedIndex(prev => (prev > 0 ? prev - 1 : options.length - 1));
92
+ break;
93
+ case 'Enter':
94
+ case ' ':
95
+ e.preventDefault();
96
+ if (focusedIndex >= 0 && focusedIndex < options.length) {
97
+ handleSelect(options[focusedIndex].value);
98
+ }
99
+ break;
100
+ case 'Tab':
101
+ setIsOpen(false);
102
+ setFocusedIndex(-1);
103
+ break;
104
+ }
105
+ };
106
+ return (_jsxs("div", { className: cn('relative', className), children: [_jsxs("button", { ref: buttonRef, type: "button", onClick: handleToggle, onKeyDown: handleKeyDown, "aria-expanded": isOpen, "aria-haspopup": "listbox", "aria-label": `${label} filter`, className: cn('h-[34px] px-3 flex items-center gap-2 rounded-lg transition-colors hover:bg-white/5', showBorder && 'border-r border-white/10 rounded-r-none pr-4', isOpen ? 'bg-white/5' : 'bg-transparent'), children: [_jsx("span", { className: "text-xs font-medium text-gray-300", children: selectedOption?.label || label }), _jsx(ChevronDown, { size: 12, className: cn('text-gray-500 transition-transform', isOpen && 'rotate-180') })] }), isOpen &&
107
+ typeof document !== 'undefined' &&
108
+ createPortal(_jsx("div", { ref: dropdownRef, role: "listbox", "aria-label": `${label} options`, onKeyDown: handleKeyDown, className: "fixed min-w-[160px] py-1 rounded-lg z-[9999] bg-[rgba(20,10,35,0.98)] border border-white/10 shadow-[0_10px_40px_rgba(0,0,0,0.5)]", style: {
109
+ top: dropdownPosition.top,
110
+ left: dropdownPosition.left,
111
+ }, children: options.map((option, index) => (_jsxs("button", { type: "button", role: "option", "aria-selected": selectedValue === option.value, onClick: () => handleSelect(option.value), className: cn('w-full px-3 py-2 flex items-center justify-between text-left transition-colors', focusedIndex === index && 'bg-white/5', focusedIndex !== index && 'hover:bg-white/5'), children: [_jsx("span", { className: cn('text-xs', selectedValue === option.value
112
+ ? 'text-white'
113
+ : 'text-gray-400'), children: option.label }), selectedValue === option.value && (_jsx(Check, { size: 12, className: "text-purple-400" }))] }, option.value))) }), document.body)] }));
114
+ }
115
+ //# sourceMappingURL=FilterDropdown.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FilterDropdown.js","sourceRoot":"","sources":["../../../src/components/dashboard/FilterDropdown.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import type { GlassPanelProps } from './types';
2
+ export type { GlassPanelProps };
3
+ export declare function GlassPanel({ children, variant, className, }: GlassPanelProps): import("react/jsx-runtime").JSX.Element;
4
+ //# sourceMappingURL=GlassPanel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GlassPanel.d.ts","sourceRoot":"","sources":["../../../src/components/dashboard/GlassPanel.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAG/C,YAAY,EAAE,eAAe,EAAE,CAAC;AAEhC,wBAAgB,UAAU,CAAC,EACzB,QAAQ,EACR,OAAiB,EACjB,SAAc,GACf,EAAE,eAAe,2CAUjB"}
@@ -0,0 +1,11 @@
1
+ 'use client';
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { cn } from '../../lib/utils';
4
+ export function GlassPanel({ children, variant = 'light', className = '', }) {
5
+ const baseClasses = 'rounded-xl border';
6
+ const variantClasses = variant === 'light'
7
+ ? 'bg-white/[0.02] border-white/[0.06] backdrop-blur-sm'
8
+ : 'border-white/[0.06] bg-white/[0.01]';
9
+ return (_jsx("div", { className: cn(baseClasses, variantClasses, className), children: children }));
10
+ }
11
+ //# sourceMappingURL=GlassPanel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GlassPanel.js","sourceRoot":"","sources":["../../../src/components/dashboard/GlassPanel.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAGb,OAAO,EAAE,EAAE,EAAE,MAAM,iBAAiB,CAAC;AAIrC,MAAM,UAAU,UAAU,CAAC,EACzB,QAAQ,EACR,OAAO,GAAG,OAAO,EACjB,SAAS,GAAG,EAAE,GACE;IAChB,MAAM,WAAW,GAAG,mBAAmB,CAAC;IACxC,MAAM,cAAc,GAClB,OAAO,KAAK,OAAO;QACjB,CAAC,CAAC,sDAAsD;QACxD,CAAC,CAAC,qCAAqC,CAAC;IAE5C,OAAO,CACL,cAAK,SAAS,EAAE,EAAE,CAAC,WAAW,EAAE,cAAc,EAAE,SAAS,CAAC,YAAG,QAAQ,GAAO,CAC7E,CAAC;AACJ,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { DateRangeOption, HeaderProps } from './types';
2
+ export type { DateRangeOption, HeaderProps };
3
+ export declare function Header({ orgName, dateRange, onDateRangeChange, dateRangeOptions, userInitials, showNotification, onNotificationClick, onAvatarClick, minimal, onMenuClick, logoSrc, }: HeaderProps): import("react/jsx-runtime").JSX.Element;
4
+ //# sourceMappingURL=Header.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Header.d.ts","sourceRoot":"","sources":["../../../src/components/dashboard/Header.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAK5D,YAAY,EAAE,eAAe,EAAE,WAAW,EAAE,CAAC;AAwD7C,wBAAgB,MAAM,CAAC,EACrB,OAA6B,EAC7B,SAAyB,EACzB,iBAAiB,EACjB,gBAA0C,EAC1C,YAAmB,EACnB,gBAAuB,EACvB,mBAAmB,EACnB,aAAa,EACb,OAAe,EACf,WAAW,EACX,OAAO,GACR,EAAE,WAAW,2CA+Eb"}