@brainfish-ai/components 0.26.0 → 0.27.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (243) hide show
  1. package/dist/alert-dialog.d.ts +6 -2
  2. package/dist/button.d.ts +4 -2
  3. package/dist/chat-search.d.ts +14 -1
  4. package/dist/confirm-dialog.d.ts +3 -1
  5. package/dist/convos.d.ts +3 -0
  6. package/dist/esm/chunks/ChatSearch.bblH7kYY.js +95 -0
  7. package/dist/esm/chunks/ChatSearch.bblH7kYY.js.map +1 -0
  8. package/dist/esm/chunks/Conversation.CuRp-tJL.js +22 -0
  9. package/dist/esm/chunks/{Conversation.BriXFYqU.js.map → Conversation.CuRp-tJL.js.map} +1 -1
  10. package/dist/esm/chunks/FormattedMessage.XNMN23hm.js +23 -0
  11. package/dist/esm/chunks/FormattedMessage.XNMN23hm.js.map +1 -0
  12. package/dist/esm/chunks/MermaidDiagram.PRgXQ5Yh.js +2 -0
  13. package/dist/esm/chunks/{MermaidDiagram.xQ0CVFOI.js.map → MermaidDiagram.PRgXQ5Yh.js.map} +1 -1
  14. package/dist/esm/chunks/_commonjsHelpers.lGe4XDVY.js +2 -0
  15. package/dist/esm/chunks/_commonjsHelpers.lGe4XDVY.js.map +1 -0
  16. package/dist/esm/chunks/button.D_2SonNs.js +3 -0
  17. package/dist/esm/chunks/button.D_2SonNs.js.map +1 -0
  18. package/dist/esm/chunks/chart.BDL2tf-S.js +10 -0
  19. package/dist/esm/chunks/{chart.4ZbtBMmR.js.map → chart.BDL2tf-S.js.map} +1 -1
  20. package/dist/esm/chunks/chat-logo.CqPppEb9.js +3 -0
  21. package/dist/esm/chunks/chat-logo.CqPppEb9.js.map +1 -0
  22. package/dist/esm/chunks/combobox.MyoPH18G.js +6 -0
  23. package/dist/esm/chunks/{combobox.CJKym3Z1.js.map → combobox.MyoPH18G.js.map} +1 -1
  24. package/dist/esm/chunks/dark.DuW7JuAk.js +2 -0
  25. package/dist/esm/chunks/{dark.Cq2RCgy4.js.map → dark.DuW7JuAk.js.map} +1 -1
  26. package/dist/esm/chunks/data-table.CJOR-1Kf.js +5 -0
  27. package/dist/esm/chunks/{data-table.DbcAYxMY.js.map → data-table.CJOR-1Kf.js.map} +1 -1
  28. package/dist/esm/chunks/date-picker.C2VT_rZ9.js +4 -0
  29. package/dist/esm/chunks/{date-picker._cBTpdEK.js.map → date-picker.C2VT_rZ9.js.map} +1 -1
  30. package/dist/esm/chunks/extends.DPdBf6DS.js +2 -0
  31. package/dist/esm/chunks/extends.DPdBf6DS.js.map +1 -0
  32. package/dist/esm/chunks/feature-flags.DOcVlPHk.js +3 -0
  33. package/dist/esm/chunks/{feature-flags.DeDEcnd1.js.map → feature-flags.DOcVlPHk.js.map} +1 -1
  34. package/dist/esm/chunks/feedback.CLMuSvsg.js +13 -0
  35. package/dist/esm/chunks/{feedback.W2OzN-5r.js.map → feedback.CLMuSvsg.js.map} +1 -1
  36. package/dist/esm/chunks/file-upload-status.D8RhMcbO.js +8 -0
  37. package/dist/esm/chunks/{file-upload-status.DP2iuttI.js.map → file-upload-status.D8RhMcbO.js.map} +1 -1
  38. package/dist/esm/chunks/filters.BHp3ukNW.js +22 -0
  39. package/dist/esm/chunks/{filters.-7vSLEQ2.js.map → filters.BHp3ukNW.js.map} +1 -1
  40. package/dist/esm/chunks/font-picker.B9GPXyK4.js +6 -0
  41. package/dist/esm/chunks/{font-picker.DisEoE8a.js.map → font-picker.B9GPXyK4.js.map} +1 -1
  42. package/dist/esm/chunks/formatDate.D2xEZm8f.js +2 -0
  43. package/dist/esm/chunks/{formatDate.CWN6IFKq.js.map → formatDate.D2xEZm8f.js.map} +1 -1
  44. package/dist/esm/chunks/formatNumber.DhVn228t.js +2 -0
  45. package/dist/esm/chunks/{formatNumber.Bm2k8QrT.js.map → formatNumber.DhVn228t.js.map} +1 -1
  46. package/dist/esm/chunks/generating-star.BN9p_FDu.js +7 -0
  47. package/dist/esm/chunks/generating-star.BN9p_FDu.js.map +1 -0
  48. package/dist/esm/chunks/header-nav.DdOXbPSM.js +10 -0
  49. package/dist/esm/chunks/{header-nav.b4hvOsKc.js.map → header-nav.DdOXbPSM.js.map} +1 -1
  50. package/dist/esm/chunks/header-pane.DrVjpN5S.js +20 -0
  51. package/dist/esm/chunks/{header-pane.BFXHXxVn.js.map → header-pane.DrVjpN5S.js.map} +1 -1
  52. package/dist/esm/chunks/hooks.BQTKhHSv.js +2 -0
  53. package/dist/esm/chunks/hooks.BQTKhHSv.js.map +1 -0
  54. package/dist/esm/chunks/index.uF4ME3WQ.js +4 -0
  55. package/dist/esm/chunks/{index.BqibIWDw.js.map → index.uF4ME3WQ.js.map} +1 -1
  56. package/dist/esm/chunks/input-with-tags.DLv9e0XI.js +5 -0
  57. package/dist/esm/chunks/{input-with-tags.tg2nhPFv.js.map → input-with-tags.DLv9e0XI.js.map} +1 -1
  58. package/dist/esm/chunks/logo.CketsPBx.js +5 -0
  59. package/dist/esm/chunks/{logo.D5BMN6Db.js.map → logo.CketsPBx.js.map} +1 -1
  60. package/dist/esm/chunks/primary.CMQbo1GJ.js +2 -0
  61. package/dist/esm/chunks/{primary.CtiRZbqq.js.map → primary.CMQbo1GJ.js.map} +1 -1
  62. package/dist/esm/chunks/review-list.Cn5bw-lP.js +6 -0
  63. package/dist/esm/chunks/review-list.Cn5bw-lP.js.map +1 -0
  64. package/dist/esm/chunks/sidebar.DsEgGwJU.js +25 -0
  65. package/dist/esm/chunks/sidebar.DsEgGwJU.js.map +1 -0
  66. package/dist/esm/chunks/simpleSelect.DK1qZSXM.js +3 -0
  67. package/dist/esm/chunks/{simpleSelect.B1rktKkt.js.map → simpleSelect.DK1qZSXM.js.map} +1 -1
  68. package/dist/esm/chunks/status-badge.BLB0pWDn.js +3 -0
  69. package/dist/esm/chunks/status-badge.BLB0pWDn.js.map +1 -0
  70. package/dist/esm/chunks/trend-value.BPBDBsk2.js +3 -0
  71. package/dist/esm/chunks/{trend-value.COSukPwk.js.map → trend-value.BPBDBsk2.js.map} +1 -1
  72. package/dist/esm/chunks/two-level-combobox.DJYP--W9.js +8 -0
  73. package/dist/esm/chunks/{two-level-combobox.BXs2z9u5.js.map → two-level-combobox.DJYP--W9.js.map} +1 -1
  74. package/dist/esm/chunks/useChartDateFormatters.Dx2h5AAm.js +2 -0
  75. package/dist/esm/chunks/{useChartDateFormatters.DS9ASgFO.js.map → useChartDateFormatters.Dx2h5AAm.js.map} +1 -1
  76. package/dist/esm/chunks/utils.C6Qu-kwd.js +2 -0
  77. package/dist/esm/chunks/{utils.Cwtlq8dh.js.map → utils.C6Qu-kwd.js.map} +1 -1
  78. package/dist/esm/colors.js +1 -169
  79. package/dist/esm/colors.js.map +1 -1
  80. package/dist/esm/components/article-suggestions-banner.js +4 -53
  81. package/dist/esm/components/article-suggestions-banner.js.map +1 -1
  82. package/dist/esm/components/articles-coverage.js +4 -116
  83. package/dist/esm/components/articles-coverage.js.map +1 -1
  84. package/dist/esm/components/articles-updated.js +4 -74
  85. package/dist/esm/components/articles-updated.js.map +1 -1
  86. package/dist/esm/components/breadcrumbs.js +3 -13
  87. package/dist/esm/components/breadcrumbs.js.map +1 -1
  88. package/dist/esm/components/chart-area-linear.js +6 -66
  89. package/dist/esm/components/chart-area-linear.js.map +1 -1
  90. package/dist/esm/components/chart-radial-stacked.js +2 -48
  91. package/dist/esm/components/chart-radial-stacked.js.map +1 -1
  92. package/dist/esm/components/chat-search.js +1 -1
  93. package/dist/esm/components/combobox.js +1 -1
  94. package/dist/esm/components/confirm-dialog.js +2 -47
  95. package/dist/esm/components/confirm-dialog.js.map +1 -1
  96. package/dist/esm/components/conversation.js +1 -1
  97. package/dist/esm/components/convos.js +27 -607
  98. package/dist/esm/components/convos.js.map +1 -1
  99. package/dist/esm/components/data-table.js +1 -1
  100. package/dist/esm/components/date-picker.js +1 -1
  101. package/dist/esm/components/discoveries-created.js +4 -64
  102. package/dist/esm/components/discoveries-created.js.map +1 -1
  103. package/dist/esm/components/feedback.js +1 -1
  104. package/dist/esm/components/file-upload.js +1 -1
  105. package/dist/esm/components/filter.js +1 -1
  106. package/dist/esm/components/font-picker.js +1 -1
  107. package/dist/esm/components/generating-star.js +1 -1
  108. package/dist/esm/components/input-with-tags.js +1 -1
  109. package/dist/esm/components/logo.js +1 -1
  110. package/dist/esm/components/markdown.js +1 -2
  111. package/dist/esm/components/markdown.js.map +1 -1
  112. package/dist/esm/components/metric-card.js +3 -29
  113. package/dist/esm/components/metric-card.js.map +1 -1
  114. package/dist/esm/components/select.js +1 -1
  115. package/dist/esm/components/trend-value.js +1 -1
  116. package/dist/esm/components/two-level-combobox.js +1 -1
  117. package/dist/esm/components/ui/accordion.js +7 -46
  118. package/dist/esm/components/ui/accordion.js.map +1 -1
  119. package/dist/esm/components/ui/alert-dialog.js +3 -114
  120. package/dist/esm/components/ui/alert-dialog.js.map +1 -1
  121. package/dist/esm/components/ui/alert.js +4 -103
  122. package/dist/esm/components/ui/alert.js.map +1 -1
  123. package/dist/esm/components/ui/avatar.js +7 -89
  124. package/dist/esm/components/ui/avatar.js.map +1 -1
  125. package/dist/esm/components/ui/badge.js +2 -26
  126. package/dist/esm/components/ui/badge.js.map +1 -1
  127. package/dist/esm/components/ui/breadcrumb.js +4 -60
  128. package/dist/esm/components/ui/breadcrumb.js.map +1 -1
  129. package/dist/esm/components/ui/button-group.js +4 -88
  130. package/dist/esm/components/ui/button-group.js.map +1 -1
  131. package/dist/esm/components/ui/button.js +1 -5
  132. package/dist/esm/components/ui/button.js.map +1 -1
  133. package/dist/esm/components/ui/calendar.js +2 -20
  134. package/dist/esm/components/ui/calendar.js.map +1 -1
  135. package/dist/esm/components/ui/card.js +1 -55
  136. package/dist/esm/components/ui/card.js.map +1 -1
  137. package/dist/esm/components/ui/collapsible.js +1 -33
  138. package/dist/esm/components/ui/collapsible.js.map +1 -1
  139. package/dist/esm/components/ui/combobox.js +1 -1
  140. package/dist/esm/components/ui/command.js +2 -79
  141. package/dist/esm/components/ui/command.js.map +1 -1
  142. package/dist/esm/components/ui/dialog.js +4 -60
  143. package/dist/esm/components/ui/dialog.js.map +1 -1
  144. package/dist/esm/components/ui/div-button.js +2 -61
  145. package/dist/esm/components/ui/div-button.js.map +1 -1
  146. package/dist/esm/components/ui/dropdown-menu.js +3 -114
  147. package/dist/esm/components/ui/dropdown-menu.js.map +1 -1
  148. package/dist/esm/components/ui/icon.js +2 -25
  149. package/dist/esm/components/ui/icon.js.map +1 -1
  150. package/dist/esm/components/ui/input.js +4 -47
  151. package/dist/esm/components/ui/input.js.map +1 -1
  152. package/dist/esm/components/ui/item.js +11 -140
  153. package/dist/esm/components/ui/item.js.map +1 -1
  154. package/dist/esm/components/ui/label.js +1 -19
  155. package/dist/esm/components/ui/label.js.map +1 -1
  156. package/dist/esm/components/ui/popover.js +1 -31
  157. package/dist/esm/components/ui/popover.js.map +1 -1
  158. package/dist/esm/components/ui/progress.js +2 -22
  159. package/dist/esm/components/ui/progress.js.map +1 -1
  160. package/dist/esm/components/ui/scroll-area.js +2 -32
  161. package/dist/esm/components/ui/scroll-area.js.map +1 -1
  162. package/dist/esm/components/ui/select.js +5 -66
  163. package/dist/esm/components/ui/select.js.map +1 -1
  164. package/dist/esm/components/ui/separator.js +1 -23
  165. package/dist/esm/components/ui/separator.js.map +1 -1
  166. package/dist/esm/components/ui/sheet.js +3 -62
  167. package/dist/esm/components/ui/sheet.js.map +1 -1
  168. package/dist/esm/components/ui/spinner.js +2 -17
  169. package/dist/esm/components/ui/spinner.js.map +1 -1
  170. package/dist/esm/components/ui/switch.js +2 -26
  171. package/dist/esm/components/ui/switch.js.map +1 -1
  172. package/dist/esm/components/ui/table.js +1 -82
  173. package/dist/esm/components/ui/table.js.map +1 -1
  174. package/dist/esm/components/ui/textarea.js +1 -33
  175. package/dist/esm/components/ui/textarea.js.map +1 -1
  176. package/dist/esm/components/ui/tooltip.js +3 -31
  177. package/dist/esm/components/ui/tooltip.js.map +1 -1
  178. package/dist/esm/global.css +1 -1
  179. package/dist/esm/index.js +1 -53
  180. package/dist/esm/index.js.map +1 -1
  181. package/dist/esm/layouts/full-layout.js +1 -1
  182. package/dist/esm/layouts/header-nav.js +1 -1
  183. package/dist/esm/layouts/sidebar.js +1 -1
  184. package/dist/esm/logos/microsoft-logo.js +6 -66
  185. package/dist/esm/logos/microsoft-logo.js.map +1 -1
  186. package/dist/esm/logos/microsoft-teams-logo.js +12 -112
  187. package/dist/esm/logos/microsoft-teams-logo.js.map +1 -1
  188. package/dist/esm/logos/slack-logo.js +3 -39
  189. package/dist/esm/logos/slack-logo.js.map +1 -1
  190. package/dist/esm/scenes/knowledge-review.js +17 -380
  191. package/dist/esm/scenes/knowledge-review.js.map +1 -1
  192. package/dist/esm/tailwind.preset.js +1 -1526
  193. package/dist/esm/tailwind.preset.js.map +1 -1
  194. package/dist/index.d.ts +32 -5
  195. package/dist/logo.d.ts +9 -0
  196. package/dist/stats.html +47 -46
  197. package/package.json +17 -18
  198. package/tailwind.preset.ts +1 -0
  199. package/dist/esm/chunks/ChatSearch.CeQrTOVx.js +0 -6825
  200. package/dist/esm/chunks/ChatSearch.CeQrTOVx.js.map +0 -1
  201. package/dist/esm/chunks/Conversation.BriXFYqU.js +0 -831
  202. package/dist/esm/chunks/FormattedMessage.CRbM-hF6.js +0 -39715
  203. package/dist/esm/chunks/FormattedMessage.CRbM-hF6.js.map +0 -1
  204. package/dist/esm/chunks/MermaidDiagram.xQ0CVFOI.js +0 -50
  205. package/dist/esm/chunks/_commonjsHelpers.BFTU3MAI.js +0 -8
  206. package/dist/esm/chunks/_commonjsHelpers.BFTU3MAI.js.map +0 -1
  207. package/dist/esm/chunks/button.DQL6gCAt.js +0 -48
  208. package/dist/esm/chunks/button.DQL6gCAt.js.map +0 -1
  209. package/dist/esm/chunks/chart.4ZbtBMmR.js +0 -199
  210. package/dist/esm/chunks/combobox.CJKym3Z1.js +0 -95
  211. package/dist/esm/chunks/dark.Cq2RCgy4.js +0 -18
  212. package/dist/esm/chunks/data-table.DbcAYxMY.js +0 -102
  213. package/dist/esm/chunks/date-picker._cBTpdEK.js +0 -26
  214. package/dist/esm/chunks/extends.mO86zOh3.js +0 -12
  215. package/dist/esm/chunks/extends.mO86zOh3.js.map +0 -1
  216. package/dist/esm/chunks/feature-flags.DeDEcnd1.js +0 -22
  217. package/dist/esm/chunks/feedback.W2OzN-5r.js +0 -214
  218. package/dist/esm/chunks/file-upload-status.DP2iuttI.js +0 -141
  219. package/dist/esm/chunks/filters.-7vSLEQ2.js +0 -565
  220. package/dist/esm/chunks/font-picker.DisEoE8a.js +0 -181
  221. package/dist/esm/chunks/formatDate.CWN6IFKq.js +0 -952
  222. package/dist/esm/chunks/formatNumber.Bm2k8QrT.js +0 -10
  223. package/dist/esm/chunks/generating-star.DMDPNTaM.js +0 -1501
  224. package/dist/esm/chunks/generating-star.DMDPNTaM.js.map +0 -1
  225. package/dist/esm/chunks/header-nav.b4hvOsKc.js +0 -197
  226. package/dist/esm/chunks/header-pane.BFXHXxVn.js +0 -559
  227. package/dist/esm/chunks/hooks.BWVaVAT-.js +0 -343
  228. package/dist/esm/chunks/hooks.BWVaVAT-.js.map +0 -1
  229. package/dist/esm/chunks/index.BqibIWDw.js +0 -137
  230. package/dist/esm/chunks/input-with-tags.tg2nhPFv.js +0 -110
  231. package/dist/esm/chunks/logo.D5BMN6Db.js +0 -191
  232. package/dist/esm/chunks/primary.CtiRZbqq.js +0 -18
  233. package/dist/esm/chunks/review-list.BtSnfpSc.js +0 -117
  234. package/dist/esm/chunks/review-list.BtSnfpSc.js.map +0 -1
  235. package/dist/esm/chunks/sidebar.BamKohb5.js +0 -803
  236. package/dist/esm/chunks/sidebar.BamKohb5.js.map +0 -1
  237. package/dist/esm/chunks/simpleSelect.B1rktKkt.js +0 -23
  238. package/dist/esm/chunks/status-badge.eFJ1PYeb.js +0 -18
  239. package/dist/esm/chunks/status-badge.eFJ1PYeb.js.map +0 -1
  240. package/dist/esm/chunks/trend-value.COSukPwk.js +0 -51
  241. package/dist/esm/chunks/two-level-combobox.BXs2z9u5.js +0 -132
  242. package/dist/esm/chunks/useChartDateFormatters.DS9ASgFO.js +0 -11
  243. package/dist/esm/chunks/utils.Cwtlq8dh.js +0 -45
@@ -1 +1 @@
1
- {"version":3,"file":"chart-radial-stacked.js","sources":["../../../src/components/chart-radial-stacked/chart-radial-stacked.tsx"],"sourcesContent":["import React from 'react';\nimport { Label, PolarRadiusAxis, RadialBar, RadialBarChart } from 'recharts';\n\nimport { Trend, TrendValue } from '../trend-value';\n\nimport { formatNumber } from '@/lib/formatNumber';\nimport { Card, CardContent, CardHeader, CardTitle } from '@/components/ui/card';\nimport { ChartConfig, ChartContainer, ChartTooltip, ChartTooltipContent } from '@/components/ui/chart';\nimport { cn } from '@/lib/utils';\n\nexport interface ChartRadialStackedProps {\n title: string;\n data: Record<string, number>[];\n chartConfig: ChartConfig;\n trend?: Trend;\n trendValue?: string;\n className?: string;\n}\n\nexport function ChartRadialStacked({\n title,\n data,\n chartConfig,\n trend,\n trendValue,\n className,\n}: ChartRadialStackedProps) {\n // Early return if data is invalid\n if (!data || data.length === 0) {\n return null;\n }\n\n const OUTER_RADIUS = 120;\n const INNER_RADIUS = 80;\n\n // return the sum\n const metricLabel = Object.values(data[0]).reduce((a, b) => (typeof b === 'number' ? a + b : a), 0);\n const formattedMetricLabel = formatNumber(metricLabel);\n\n // returns the data in sorted order by value\n const sortedData = Object.entries(data[0]).sort((a, b) => b[1] - a[1]); // Sort by value (descending)\n\n return (\n <Card className={cn('flex flex-col w-full min-w-60 p-4 shadow-none', className)}>\n <CardHeader className=\"p-0 space-y-0\" data-name=\"header\">\n <CardTitle className=\"uppercase font-inter heading-xxxs tracking-normal\">{title}</CardTitle>\n </CardHeader>\n <CardContent data-name=\"content\" className=\"p-0 flex-1 min-h-0\">\n <ChartContainer config={chartConfig} className=\"mx-auto aspect-[2/1] w-full max-w-52\">\n <RadialBarChart data={data} endAngle={180} innerRadius={INNER_RADIUS} outerRadius={OUTER_RADIUS} cy=\"100%\">\n <ChartTooltip cursor={false} content={<ChartTooltipContent hideLabel />} />\n <PolarRadiusAxis tick={false} tickLine={false} axisLine={false}>\n <Label\n content={({ viewBox }) => {\n if (viewBox && 'cx' in viewBox && 'cy' in viewBox) {\n return (\n <text x={viewBox.cx} y={viewBox.cy} textAnchor=\"middle\">\n <tspan x={viewBox.cx} y={(viewBox.cy || 0) - 16} className=\"fill-foreground text-xl font-inter\">\n {formattedMetricLabel}\n </tspan>\n </text>\n );\n }\n\n return null;\n }}\n />\n </PolarRadiusAxis>\n {sortedData.map(([key]) => (\n <RadialBar\n key={key}\n dataKey={key}\n stackId=\"a\"\n cornerRadius={4}\n fill={chartConfig[key]?.color || `var(--color-${key})`}\n className=\"stroke-card stroke-2\"\n />\n ))}\n </RadialBarChart>\n </ChartContainer>\n {trend && trendValue && (\n <TrendValue variant=\"long\" trend={trend} trendValue={trendValue} className=\"mt-4 justify-center\" />\n )}\n </CardContent>\n </Card>\n );\n}\n"],"names":["React"],"mappings":"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"}
1
+ {"version":3,"file":"chart-radial-stacked.js","sources":["../../../src/components/chart-radial-stacked/chart-radial-stacked.tsx"],"sourcesContent":["import React from 'react';\nimport { Label, PolarRadiusAxis, RadialBar, RadialBarChart } from 'recharts';\n\nimport { Trend, TrendValue } from '../trend-value';\n\nimport { formatNumber } from '@/lib/formatNumber';\nimport { Card, CardContent, CardHeader, CardTitle } from '@/components/ui/card';\nimport { ChartConfig, ChartContainer, ChartTooltip, ChartTooltipContent } from '@/components/ui/chart';\nimport { cn } from '@/lib/utils';\n\nexport interface ChartRadialStackedProps {\n title: string;\n data: Record<string, number>[];\n chartConfig: ChartConfig;\n trend?: Trend;\n trendValue?: string;\n className?: string;\n}\n\nexport function ChartRadialStacked({\n title,\n data,\n chartConfig,\n trend,\n trendValue,\n className,\n}: ChartRadialStackedProps) {\n // Early return if data is invalid\n if (!data || data.length === 0) {\n return null;\n }\n\n const OUTER_RADIUS = 120;\n const INNER_RADIUS = 80;\n\n // return the sum\n const metricLabel = Object.values(data[0]).reduce((a, b) => (typeof b === 'number' ? a + b : a), 0);\n const formattedMetricLabel = formatNumber(metricLabel);\n\n // returns the data in sorted order by value\n const sortedData = Object.entries(data[0]).sort((a, b) => b[1] - a[1]); // Sort by value (descending)\n\n return (\n <Card className={cn('flex flex-col w-full min-w-60 p-4 shadow-none', className)}>\n <CardHeader className=\"p-0 space-y-0\" data-name=\"header\">\n <CardTitle className=\"uppercase font-inter heading-xxxs tracking-normal\">{title}</CardTitle>\n </CardHeader>\n <CardContent data-name=\"content\" className=\"p-0 flex-1 min-h-0\">\n <ChartContainer config={chartConfig} className=\"mx-auto aspect-[2/1] w-full max-w-52\">\n <RadialBarChart data={data} endAngle={180} innerRadius={INNER_RADIUS} outerRadius={OUTER_RADIUS} cy=\"100%\">\n <ChartTooltip cursor={false} content={<ChartTooltipContent hideLabel />} />\n <PolarRadiusAxis tick={false} tickLine={false} axisLine={false}>\n <Label\n content={({ viewBox }) => {\n if (viewBox && 'cx' in viewBox && 'cy' in viewBox) {\n return (\n <text x={viewBox.cx} y={viewBox.cy} textAnchor=\"middle\">\n <tspan x={viewBox.cx} y={(viewBox.cy || 0) - 16} className=\"fill-foreground text-xl font-inter\">\n {formattedMetricLabel}\n </tspan>\n </text>\n );\n }\n\n return null;\n }}\n />\n </PolarRadiusAxis>\n {sortedData.map(([key]) => (\n <RadialBar\n key={key}\n dataKey={key}\n stackId=\"a\"\n cornerRadius={4}\n fill={chartConfig[key]?.color || `var(--color-${key})`}\n className=\"stroke-card stroke-2\"\n />\n ))}\n </RadialBarChart>\n </ChartContainer>\n {trend && trendValue && (\n <TrendValue variant=\"long\" trend={trend} trendValue={trendValue} className=\"mt-4 justify-center\" />\n )}\n </CardContent>\n </Card>\n );\n}\n"],"names":["ChartRadialStacked","title","data","chartConfig","trend","trendValue","className","length","metricLabel","Object","values","reduce","a","b","formattedMetricLabel","formatNumber","sortedData","entries","sort","React","createElement","Card","cn","CardHeader","CardTitle","CardContent","ChartContainer","config","RadialBarChart","endAngle","innerRadius","outerRadius","cy","ChartTooltip","cursor","content","ChartTooltipContent","hideLabel","PolarRadiusAxis","tick","tickLine","axisLine","Label","viewBox","x","cx","y","textAnchor","map","key","RadialBar","dataKey","stackId","cornerRadius","fill","color","TrendValue","variant"],"mappings":"6ZAmBO,SAASA,GAAmBC,MACjCA,EAAAC,KACAA,EAAAC,YACAA,EAAAC,MACAA,EAAAC,WACAA,EAAAC,UACAA,IAGA,IAAKJ,GAAwB,IAAhBA,EAAKK,OAChB,OAAO,KAGT,MAIMC,EAAcC,OAAOC,OAAOR,EAAK,IAAIS,OAAO,CAACC,EAAGC,IAAoB,iBAANA,EAAiBD,EAAIC,EAAID,EAAI,GAC3FE,EAAuBC,EAAaP,GAGpCQ,EAAaP,OAAOQ,QAAQf,EAAK,IAAIgB,KAAK,CAACN,EAAGC,IAAMA,EAAE,GAAKD,EAAE;AAEnE,OACEO,EAAAC,cAACC,EAAA,CAAKf,UAAWgB,EAAG,gDAAiDhB,mBACnEa,EAAAC,cAACG,EAAA,CAAWjB,UAAU,gBAAgB,YAAU,yBAC9Ca,EAAAC,cAACI,EAAA,CAAUlB,UAAU,qDAAqDL,mBAE5EkB,EAAAC,cAACK,EAAA,CAAY,YAAU,UAAUnB,UAAU,qCACzCa,EAAAC,cAACM,EAAA,CAAeC,OAAQxB,EAAaG,UAAU,uDAC7Ca,EAAAC,cAACQ,EAAA,CAAe1B,OAAY2B,SAAU,IAAKC,YAhB9B,GAgByDC,YAjBzD,IAiBoFC,GAAG,uBAClGb,EAAAC,cAACa,EAAA,CAAaC,QAAQ,EAAOC,uBAAShB,EAAAC,cAACgB,EAAA,CAAoBC,WAAS,qBACpElB,EAAAC,cAACkB,EAAA,CAAgBC,MAAM,EAAOC,UAAU,EAAOC,UAAU,kBACvDtB,EAAAC,cAACsB,EAAA,CACCP,QAAS,EAAGQ,aACNA,GAAW,OAAQA,GAAW,OAAQA,iBAEtCxB,EAAAC,cAAC,QAAKwB,EAAGD,EAAQE,GAAIC,EAAGH,EAAQX,GAAIe,WAAW,yBAC7C5B,EAAAC,cAAC,SAAMwB,EAAGD,EAAQE,GAAIC,GAAIH,EAAQX,IAAM,GAAK,GAAI1B,UAAU,sCACxDQ,IAMF,QAIZE,EAAWgC,IAAI,EAAEC,oBAChB9B,EAAAC,cAAC8B,EAAA,CACCD,MACAE,QAASF,EACTG,QAAQ,IACRC,aAAc,EACdC,KAAMnD,EAAY8C,IAAMM,OAAS,eAAeN,KAChD3C,UAAU,4BAKjBF,GAASC,kBACRc,EAAAC,cAACoC,EAAA,CAAWC,QAAQ,OAAOrD,QAAcC,aAAwBC,UAAU,yBAKrF"}
@@ -1,2 +1,2 @@
1
- export { C as ChatSearch, a as ChatSearchProvider, u as useChatSearch, b as useIsChatSearchDirty } from '../chunks/ChatSearch.CeQrTOVx.js';
1
+ export{C as ChatSearch,a as ChatSearchProvider,R as ResolvedConversationFooter,u as useChatSearch,b as useIsChatSearchDirty}from"../chunks/ChatSearch.bblH7kYY.js";
2
2
  //# sourceMappingURL=chat-search.js.map
@@ -1,2 +1,2 @@
1
- export { C as Combobox } from '../chunks/combobox.CJKym3Z1.js';
1
+ export{C as Combobox}from"../chunks/combobox.MyoPH18G.js";
2
2
  //# sourceMappingURL=combobox.js.map
@@ -1,48 +1,3 @@
1
- import React__default from 'react';
2
- import { AlertDialog, AlertDialogContent, AlertDialogHeader, AlertDialogTitle, AlertDialogDescription, AlertDialogFooter, AlertDialogCancel, AlertDialogAction } from './ui/alert-dialog.js';
3
-
4
- const ConfirmDialog = React__default.forwardRef(
5
- ({
6
- title,
7
- description,
8
- onSubmit,
9
- onCancel,
10
- open: externalOpen,
11
- onOpenChange: externalOnOpenChange,
12
- variant,
13
- cancelText,
14
- submitText,
15
- loadingText,
16
- zIndex = 50
17
- }, ref) => {
18
- const zIndexClass = zIndex ? `z-[${zIndex}]` : void 0;
19
- const [isLoading, setIsLoading] = React__default.useState(false);
20
- const [internalOpen, setInternalOpen] = React__default.useState(false);
21
- const isOpen = externalOpen ?? internalOpen;
22
- const setIsOpen = externalOnOpenChange ?? setInternalOpen;
23
- React__default.useImperativeHandle(ref, () => ({
24
- open: () => setIsOpen(true),
25
- close: () => setIsOpen(false)
26
- }));
27
- const handleCancel = () => {
28
- if (isLoading) return;
29
- onCancel?.();
30
- setIsOpen(false);
31
- };
32
- const handleSubmit = async () => {
33
- if (isLoading) return;
34
- setIsLoading(true);
35
- try {
36
- await onSubmit();
37
- setIsOpen(false);
38
- } finally {
39
- setIsLoading(false);
40
- }
41
- };
42
- return /* @__PURE__ */ React__default.createElement(AlertDialog, { open: isOpen, onOpenChange: setIsOpen }, /* @__PURE__ */ React__default.createElement(AlertDialogContent, { zIndex: zIndexClass }, /* @__PURE__ */ React__default.createElement(AlertDialogHeader, null, /* @__PURE__ */ React__default.createElement(AlertDialogTitle, null, title), /* @__PURE__ */ React__default.createElement(AlertDialogDescription, null, description)), /* @__PURE__ */ React__default.createElement(AlertDialogFooter, null, /* @__PURE__ */ React__default.createElement(AlertDialogCancel, { onClick: handleCancel, disabled: isLoading }, cancelText), /* @__PURE__ */ React__default.createElement(AlertDialogAction, { variant, onClick: handleSubmit, disabled: isLoading }, isLoading ? loadingText || submitText : submitText))));
43
- }
44
- );
45
- ConfirmDialog.displayName = "ConfirmDialog";
46
-
47
- export { ConfirmDialog };
1
+ import e from"react";import{AlertDialog as t,AlertDialogContent as n,AlertDialogHeader as a,AlertDialogTitle as l,AlertDialogDescription as r,AlertDialogFooter as i,AlertDialogCancel as o,AlertDialogAction as c}from"./ui/alert-dialog.js";const m=e.forwardRef(({title:m,description:d,onSubmit:s,onCancel:p,open:u,onOpenChange:E,variant:f,cancelText:x,submitText:C,loadingText:g,zIndex:b=50},v)=>{const y=b?`z-[${b}]`:void 0,[z,I]=e.useState(!1),[S,T]=e.useState(!1),h=u??S,k=E??T;e.useImperativeHandle(v,()=>({open:()=>k(!0),close:()=>k(!1)}));/* @__PURE__ */
2
+ return e.createElement(t,{open:h,onOpenChange:k},/* @__PURE__ */e.createElement(n,{zIndex:y},/* @__PURE__ */e.createElement(a,null,/* @__PURE__ */e.createElement(l,null,m),/* @__PURE__ */e.createElement(r,null,d)),/* @__PURE__ */e.createElement(i,null,/* @__PURE__ */e.createElement(o,{onClick:()=>{z||(p?.(),k(!1))},disabled:z},x),/* @__PURE__ */e.createElement(c,{variant:f,onClick:async()=>{if(!z){I(!0);try{await s(),k(!1)}finally{I(!1)}}},disabled:z},z&&g||C))))});m.displayName="ConfirmDialog";export{m as ConfirmDialog};
48
3
  //# sourceMappingURL=confirm-dialog.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"confirm-dialog.js","sources":["../../../src/components/confirm-dialog/confirm-dialog.tsx"],"sourcesContent":["import React from 'react';\n\nimport {\n AlertDialog,\n AlertDialogTitle,\n AlertDialogDescription,\n AlertDialogHeader,\n AlertDialogCancel,\n AlertDialogAction,\n AlertDialogFooter,\n AlertDialogContent,\n} from '../ui/alert-dialog';\n\ninterface Props {\n title: string;\n description: React.ReactNode;\n onSubmit: () => Promise<void> | void;\n onCancel?: () => void;\n // Optional external state control - if not provided, manages state internally\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n variant: React.ComponentProps<typeof AlertDialogAction>['variant'];\n cancelText: string;\n submitText: string;\n loadingText?: string;\n zIndex?: number; // z-index of the dialog\n}\n\nexport interface ConfirmDialogRef {\n open: () => void;\n close: () => void;\n}\n\nexport const ConfirmDialog = React.forwardRef<ConfirmDialogRef, Props>(\n (\n {\n title,\n description,\n onSubmit,\n onCancel,\n open: externalOpen,\n onOpenChange: externalOnOpenChange,\n variant,\n cancelText,\n submitText,\n loadingText,\n zIndex = 50,\n },\n ref,\n ) => {\n const zIndexClass = zIndex ? `z-[${zIndex}]` : undefined;\n const [isLoading, setIsLoading] = React.useState(false);\n\n // Internal state management (merged from useDialogState)\n const [internalOpen, setInternalOpen] = React.useState(false);\n\n // Use external state if provided, otherwise use internal state\n const isOpen = externalOpen ?? internalOpen;\n const setIsOpen = externalOnOpenChange ?? setInternalOpen;\n\n // Expose methods via ref for programmatic control\n React.useImperativeHandle(ref, () => ({\n open: () => setIsOpen(true),\n close: () => setIsOpen(false),\n }));\n\n const handleCancel = () => {\n if (isLoading) return; // Prevent cancel during loading\n onCancel?.();\n setIsOpen(false);\n };\n\n const handleSubmit = async () => {\n if (isLoading) return; // Prevent double submission\n\n setIsLoading(true);\n try {\n await onSubmit();\n setIsOpen(false); // Close dialog after successful submission\n } finally {\n setIsLoading(false);\n }\n };\n\n return (\n <AlertDialog open={isOpen} onOpenChange={setIsOpen}>\n <AlertDialogContent zIndex={zIndexClass}>\n <AlertDialogHeader>\n <AlertDialogTitle>{title}</AlertDialogTitle>\n <AlertDialogDescription>{description}</AlertDialogDescription>\n </AlertDialogHeader>\n <AlertDialogFooter>\n <AlertDialogCancel onClick={handleCancel} disabled={isLoading}>\n {cancelText}\n </AlertDialogCancel>\n <AlertDialogAction variant={variant} onClick={handleSubmit} disabled={isLoading}>\n {isLoading ? loadingText || submitText : submitText}\n </AlertDialogAction>\n </AlertDialogFooter>\n </AlertDialogContent>\n </AlertDialog>\n );\n },\n);\n\nConfirmDialog.displayName = 'ConfirmDialog';\n"],"names":["React"],"mappings":";;;AAiCO,MAAM,gBAAgBA,cAAA,CAAM,UAAA;AAAA,EACjC,CACE;AAAA,IACE,KAAA;AAAA,IACA,WAAA;AAAA,IACA,QAAA;AAAA,IACA,QAAA;AAAA,IACA,IAAA,EAAM,YAAA;AAAA,IACN,YAAA,EAAc,oBAAA;AAAA,IACd,OAAA;AAAA,IACA,UAAA;AAAA,IACA,UAAA;AAAA,IACA,WAAA;AAAA,IACA,MAAA,GAAS;AAAA,KAEX,GAAA,KACG;AACH,IAAA,MAAM,WAAA,GAAc,MAAA,GAAS,CAAA,GAAA,EAAM,MAAM,CAAA,CAAA,CAAA,GAAM,MAAA;AAC/C,IAAA,MAAM,CAAC,SAAA,EAAW,YAAY,CAAA,GAAIA,cAAA,CAAM,SAAS,KAAK,CAAA;AAGtD,IAAA,MAAM,CAAC,YAAA,EAAc,eAAe,CAAA,GAAIA,cAAA,CAAM,SAAS,KAAK,CAAA;AAG5D,IAAA,MAAM,SAAS,YAAA,IAAgB,YAAA;AAC/B,IAAA,MAAM,YAAY,oBAAA,IAAwB,eAAA;AAG1C,IAAAA,cAAA,CAAM,mBAAA,CAAoB,KAAK,OAAO;AAAA,MACpC,IAAA,EAAM,MAAM,SAAA,CAAU,IAAI,CAAA;AAAA,MAC1B,KAAA,EAAO,MAAM,SAAA,CAAU,KAAK;AAAA,KAC9B,CAAE,CAAA;AAEF,IAAA,MAAM,eAAe,MAAM;AACzB,MAAA,IAAI,SAAA,EAAW;AACf,MAAA,QAAA,IAAW;AACX,MAAA,SAAA,CAAU,KAAK,CAAA;AAAA,IACjB,CAAA;AAEA,IAAA,MAAM,eAAe,YAAY;AAC/B,MAAA,IAAI,SAAA,EAAW;AAEf,MAAA,YAAA,CAAa,IAAI,CAAA;AACjB,MAAA,IAAI;AACF,QAAA,MAAM,QAAA,EAAS;AACf,QAAA,SAAA,CAAU,KAAK,CAAA;AAAA,MACjB,CAAA,SAAE;AACA,QAAA,YAAA,CAAa,KAAK,CAAA;AAAA,MACpB;AAAA,IACF,CAAA;AAEA,IAAA,uBACEA,cAAA,CAAA,aAAA,CAAC,eAAY,IAAA,EAAM,MAAA,EAAQ,cAAc,SAAA,EAAA,kBACvCA,cAAA,CAAA,aAAA,CAAC,sBAAmB,MAAA,EAAQ,WAAA,EAAA,+CACzB,iBAAA,EAAA,IAAA,kBACCA,cAAA,CAAA,aAAA,CAAC,wBAAkB,KAAM,CAAA,+CACxB,sBAAA,EAAA,IAAA,EAAwB,WAAY,CACvC,CAAA,kBACAA,cAAA,CAAA,aAAA,CAAC,yCACCA,cAAA,CAAA,aAAA,CAAC,iBAAA,EAAA,EAAkB,SAAS,YAAA,EAAc,QAAA,EAAU,aACjD,UACH,CAAA,+CACC,iBAAA,EAAA,EAAkB,OAAA,EAAkB,SAAS,YAAA,EAAc,QAAA,EAAU,aACnE,SAAA,GAAY,WAAA,IAAe,aAAa,UAC3C,CACF,CACF,CACF,CAAA;AAAA,EAEJ;AACF;AAEA,aAAA,CAAc,WAAA,GAAc,eAAA;;;;"}
1
+ {"version":3,"file":"confirm-dialog.js","sources":["../../../src/components/confirm-dialog/confirm-dialog.tsx"],"sourcesContent":["import React from 'react';\n\nimport {\n AlertDialog,\n AlertDialogTitle,\n AlertDialogDescription,\n AlertDialogHeader,\n AlertDialogCancel,\n AlertDialogAction,\n AlertDialogFooter,\n AlertDialogContent,\n} from '../ui/alert-dialog';\n\ninterface Props {\n title: string;\n description: React.ReactNode;\n onSubmit: () => Promise<void> | void;\n onCancel?: () => void;\n // Optional external state control - if not provided, manages state internally\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n variant: React.ComponentProps<typeof AlertDialogAction>['variant'];\n cancelText: string;\n submitText: string;\n loadingText?: string;\n zIndex?: number; // z-index of the dialog\n}\n\nexport interface ConfirmDialogRef {\n open: () => void;\n close: () => void;\n}\n\nexport const ConfirmDialog = React.forwardRef<ConfirmDialogRef, Props>(\n (\n {\n title,\n description,\n onSubmit,\n onCancel,\n open: externalOpen,\n onOpenChange: externalOnOpenChange,\n variant,\n cancelText,\n submitText,\n loadingText,\n zIndex = 50,\n },\n ref,\n ) => {\n const zIndexClass = zIndex ? `z-[${zIndex}]` : undefined;\n const [isLoading, setIsLoading] = React.useState(false);\n\n // Internal state management (merged from useDialogState)\n const [internalOpen, setInternalOpen] = React.useState(false);\n\n // Use external state if provided, otherwise use internal state\n const isOpen = externalOpen ?? internalOpen;\n const setIsOpen = externalOnOpenChange ?? setInternalOpen;\n\n // Expose methods via ref for programmatic control\n React.useImperativeHandle(ref, () => ({\n open: () => setIsOpen(true),\n close: () => setIsOpen(false),\n }));\n\n const handleCancel = () => {\n if (isLoading) return; // Prevent cancel during loading\n onCancel?.();\n setIsOpen(false);\n };\n\n const handleSubmit = async () => {\n if (isLoading) return; // Prevent double submission\n\n setIsLoading(true);\n try {\n await onSubmit();\n setIsOpen(false); // Close dialog after successful submission\n } finally {\n setIsLoading(false);\n }\n };\n\n return (\n <AlertDialog open={isOpen} onOpenChange={setIsOpen}>\n <AlertDialogContent zIndex={zIndexClass}>\n <AlertDialogHeader>\n <AlertDialogTitle>{title}</AlertDialogTitle>\n <AlertDialogDescription>{description}</AlertDialogDescription>\n </AlertDialogHeader>\n <AlertDialogFooter>\n <AlertDialogCancel onClick={handleCancel} disabled={isLoading}>\n {cancelText}\n </AlertDialogCancel>\n <AlertDialogAction variant={variant} onClick={handleSubmit} disabled={isLoading}>\n {isLoading ? loadingText || submitText : submitText}\n </AlertDialogAction>\n </AlertDialogFooter>\n </AlertDialogContent>\n </AlertDialog>\n );\n },\n);\n\nConfirmDialog.displayName = 'ConfirmDialog';\n"],"names":["ConfirmDialog","React","forwardRef","title","description","onSubmit","onCancel","open","externalOpen","onOpenChange","externalOnOpenChange","variant","cancelText","submitText","loadingText","zIndex","ref","zIndexClass","isLoading","setIsLoading","useState","internalOpen","setInternalOpen","isOpen","setIsOpen","useImperativeHandle","close","createElement","AlertDialog","AlertDialogContent","AlertDialogHeader","AlertDialogTitle","AlertDialogDescription","AlertDialogFooter","AlertDialogCancel","onClick","disabled","AlertDialogAction","async","displayName"],"mappings":"8OAiCO,MAAMA,EAAgBC,EAAMC,WACjC,EAEIC,QACAC,cACAC,WACAC,WACAC,KAAMC,EACNC,aAAcC,EACdC,UACAC,aACAC,aACAC,cACAC,SAAS,IAEXC,KAEA,MAAMC,EAAcF,EAAS,MAAMA,UAAY,GACxCG,EAAWC,GAAgBlB,EAAMmB,UAAS,IAG1CC,EAAcC,GAAmBrB,EAAMmB,UAAS,GAGjDG,EAASf,GAAgBa,EACzBG,EAAYd,GAAwBY,EAG1CrB,EAAMwB,oBAAoBT,EAAK,KAAA,CAC7BT,KAAM,IAAMiB,GAAU,GACtBE,MAAO,IAAMF,GAAU;AAqBzB,OACEvB,EAAA0B,cAACC,GAAYrB,KAAMgB,EAAQd,aAAce,kBACvCvB,EAAA0B,cAACE,GAAmBd,OAAQE,kCACzBa,EAAA,oBACC7B,EAAA0B,cAACI,OAAkB5B,kCAClB6B,EAAA,KAAwB5B,mBAE3BH,EAAA0B,cAACM,sBACChC,EAAA0B,cAACO,EAAA,CAAkBC,QA1BN,KACfjB,IACJZ,MACAkB,GAAU,KAuBsCY,SAAUlB,GACjDN,kCAEFyB,EAAA,CAAkB1B,UAAkBwB,QAvBxBG,UACnB,IAAIpB,EAAJ,CAEAC,GAAa,GACb,UACQd,IACNmB,GAAU,EACZ,CAAA,QACEL,GAAa,EACf,CARe,GAsBmDiB,SAAUlB,GACnEA,GAAYJ,GAA4BD,QASvDb,EAAcuC,YAAc"}
@@ -1,2 +1,2 @@
1
- export { C as ContextPillBadge, a as Conversation, b as ConversationActions, c as ConversationInput, d as ConversationMessageAssistant, e as ConversationMessageUser, f as ConversationMessages, g as ConversationProvider, h as ConversationStatus, i as ConversationSuggestions, u as useConversation } from '../chunks/Conversation.BriXFYqU.js';
1
+ export{C as ContextPillBadge,a as Conversation,b as ConversationActions,c as ConversationInput,d as ConversationMessageAssistant,e as ConversationMessageUser,f as ConversationMessages,g as ConversationProvider,h as ConversationStatus,i as ConversationSuggestions,u as useConversation}from"../chunks/Conversation.CuRp-tJL.js";
2
2
  //# sourceMappingURL=conversation.js.map