@salesmind-ai/design-system 0.3.0 → 0.3.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (212) hide show
  1. package/README.md +32 -2
  2. package/dist/admin/index.cjs +68 -2928
  3. package/dist/admin/index.cjs.map +1 -1
  4. package/dist/admin/index.js +5 -2915
  5. package/dist/admin/index.js.map +1 -1
  6. package/dist/blog/index.cjs +53 -1064
  7. package/dist/blog/index.cjs.map +1 -1
  8. package/dist/blog/index.js +8 -1054
  9. package/dist/blog/index.js.map +1 -1
  10. package/dist/charts/index.cjs +46 -2694
  11. package/dist/charts/index.cjs.map +1 -1
  12. package/dist/charts/index.js +3 -2680
  13. package/dist/charts/index.js.map +1 -1
  14. package/dist/chunk-2GARWEJK.js +17 -0
  15. package/dist/chunk-2GARWEJK.js.map +1 -0
  16. package/dist/chunk-3NKRFUAR.js +37 -0
  17. package/dist/chunk-3NKRFUAR.js.map +1 -0
  18. package/dist/chunk-3TGSIILM.cjs +201 -0
  19. package/dist/chunk-3TGSIILM.cjs.map +1 -0
  20. package/dist/chunk-4GM5BGBN.cjs +801 -0
  21. package/dist/chunk-4GM5BGBN.cjs.map +1 -0
  22. package/dist/chunk-5LGDEZWY.cjs +2434 -0
  23. package/dist/chunk-5LGDEZWY.cjs.map +1 -0
  24. package/dist/chunk-6H4DSTXR.js +786 -0
  25. package/dist/chunk-6H4DSTXR.js.map +1 -0
  26. package/dist/chunk-6UNG76Y2.js +153 -0
  27. package/dist/chunk-6UNG76Y2.js.map +1 -0
  28. package/dist/chunk-7PX2AZ6Y.js +39 -0
  29. package/dist/chunk-7PX2AZ6Y.js.map +1 -0
  30. package/dist/chunk-B6AVAX4F.js +1415 -0
  31. package/dist/chunk-B6AVAX4F.js.map +1 -0
  32. package/dist/chunk-BILT5KD3.js +264 -0
  33. package/dist/chunk-BILT5KD3.js.map +1 -0
  34. package/dist/chunk-C2BCDNAV.js +24 -0
  35. package/dist/chunk-C2BCDNAV.js.map +1 -0
  36. package/dist/chunk-CH42VPWE.cjs +421 -0
  37. package/dist/chunk-CH42VPWE.cjs.map +1 -0
  38. package/dist/chunk-CJ2MKVAF.cjs +46 -0
  39. package/dist/chunk-CJ2MKVAF.cjs.map +1 -0
  40. package/dist/chunk-DP74LUXG.cjs +98 -0
  41. package/dist/chunk-DP74LUXG.cjs.map +1 -0
  42. package/dist/chunk-E7D6EKJ4.cjs +44 -0
  43. package/dist/chunk-E7D6EKJ4.cjs.map +1 -0
  44. package/dist/chunk-ECXBTUH6.cjs +584 -0
  45. package/dist/chunk-ECXBTUH6.cjs.map +1 -0
  46. package/dist/chunk-EFRAP5ES.js +157 -0
  47. package/dist/chunk-EFRAP5ES.js.map +1 -0
  48. package/dist/chunk-F6YYWMME.js +485 -0
  49. package/dist/chunk-F6YYWMME.js.map +1 -0
  50. package/dist/chunk-FAFAP4L5.js +183 -0
  51. package/dist/chunk-FAFAP4L5.js.map +1 -0
  52. package/dist/chunk-GUZIMHWS.js +1608 -0
  53. package/dist/chunk-GUZIMHWS.js.map +1 -0
  54. package/dist/chunk-H2Y6BSTL.cjs +69 -0
  55. package/dist/chunk-H2Y6BSTL.cjs.map +1 -0
  56. package/dist/chunk-HN4PHABT.js +126 -0
  57. package/dist/chunk-HN4PHABT.js.map +1 -0
  58. package/dist/chunk-HRENHNDJ.js +211 -0
  59. package/dist/chunk-HRENHNDJ.js.map +1 -0
  60. package/dist/chunk-I75BFEYT.cjs +2561 -0
  61. package/dist/chunk-I75BFEYT.cjs.map +1 -0
  62. package/dist/chunk-IFRATNLU.js +562 -0
  63. package/dist/chunk-IFRATNLU.js.map +1 -0
  64. package/dist/chunk-IYPXJ6YC.cjs +69 -0
  65. package/dist/chunk-IYPXJ6YC.cjs.map +1 -0
  66. package/dist/chunk-JPJN4YBC.js +409 -0
  67. package/dist/chunk-JPJN4YBC.js.map +1 -0
  68. package/dist/chunk-KBA2LFBG.js +62 -0
  69. package/dist/chunk-KBA2LFBG.js.map +1 -0
  70. package/dist/chunk-KCKUSU2M.cjs +166 -0
  71. package/dist/chunk-KCKUSU2M.cjs.map +1 -0
  72. package/dist/chunk-KJ2OXQF4.js +287 -0
  73. package/dist/chunk-KJ2OXQF4.js.map +1 -0
  74. package/dist/chunk-KNQEIU7O.cjs +1202 -0
  75. package/dist/chunk-KNQEIU7O.cjs.map +1 -0
  76. package/dist/chunk-KVGSVGRK.cjs +569 -0
  77. package/dist/chunk-KVGSVGRK.cjs.map +1 -0
  78. package/dist/chunk-L352JRV6.cjs +105 -0
  79. package/dist/chunk-L352JRV6.cjs.map +1 -0
  80. package/dist/chunk-LJADZITX.cjs +298 -0
  81. package/dist/chunk-LJADZITX.cjs.map +1 -0
  82. package/dist/chunk-LMJPWXTZ.cjs +194 -0
  83. package/dist/chunk-LMJPWXTZ.cjs.map +1 -0
  84. package/dist/chunk-LOWEAQST.js +701 -0
  85. package/dist/chunk-LOWEAQST.js.map +1 -0
  86. package/dist/chunk-MDB2WCRQ.cjs +137 -0
  87. package/dist/chunk-MDB2WCRQ.cjs.map +1 -0
  88. package/dist/chunk-MQDEE7HC.cjs +283 -0
  89. package/dist/chunk-MQDEE7HC.cjs.map +1 -0
  90. package/dist/chunk-MQRB634A.cjs +34 -0
  91. package/dist/chunk-MQRB634A.cjs.map +1 -0
  92. package/dist/chunk-MTI27RDV.js +185 -0
  93. package/dist/chunk-MTI27RDV.js.map +1 -0
  94. package/dist/chunk-MU6GW5ZV.js +2317 -0
  95. package/dist/chunk-MU6GW5ZV.js.map +1 -0
  96. package/dist/chunk-NN3TUHIH.js +28 -0
  97. package/dist/chunk-NN3TUHIH.js.map +1 -0
  98. package/dist/chunk-NT4LBP7D.cjs +111 -0
  99. package/dist/chunk-NT4LBP7D.cjs.map +1 -0
  100. package/dist/chunk-OLV7OD3X.cjs +502 -0
  101. package/dist/chunk-OLV7OD3X.cjs.map +1 -0
  102. package/dist/chunk-OXNXEQY7.js +2538 -0
  103. package/dist/chunk-OXNXEQY7.js.map +1 -0
  104. package/dist/chunk-P5BOFE5A.js +546 -0
  105. package/dist/chunk-P5BOFE5A.js.map +1 -0
  106. package/dist/chunk-Q2MFGYTE.cjs +1449 -0
  107. package/dist/chunk-Q2MFGYTE.cjs.map +1 -0
  108. package/dist/chunk-Q75DBVDY.cjs +68 -0
  109. package/dist/chunk-Q75DBVDY.cjs.map +1 -0
  110. package/dist/chunk-REQ5Q6ZI.js +1022 -0
  111. package/dist/chunk-REQ5Q6ZI.js.map +1 -0
  112. package/dist/chunk-SICKWUWB.js +62 -0
  113. package/dist/chunk-SICKWUWB.js.map +1 -0
  114. package/dist/chunk-T343CCH5.js +1190 -0
  115. package/dist/chunk-T343CCH5.js.map +1 -0
  116. package/dist/chunk-TEC62D4A.cjs +1624 -0
  117. package/dist/chunk-TEC62D4A.cjs.map +1 -0
  118. package/dist/chunk-TW5JB35D.js +2122 -0
  119. package/dist/chunk-TW5JB35D.js.map +1 -0
  120. package/dist/chunk-VC5LMUVQ.cjs +20 -0
  121. package/dist/chunk-VC5LMUVQ.cjs.map +1 -0
  122. package/dist/chunk-VM7WFMKI.cjs +76 -0
  123. package/dist/chunk-VM7WFMKI.cjs.map +1 -0
  124. package/dist/chunk-W2WTP6HS.cjs +233 -0
  125. package/dist/chunk-W2WTP6HS.cjs.map +1 -0
  126. package/dist/chunk-WH7PYHZY.cjs +35 -0
  127. package/dist/chunk-WH7PYHZY.cjs.map +1 -0
  128. package/dist/chunk-XQZVY7JJ.cjs +717 -0
  129. package/dist/chunk-XQZVY7JJ.cjs.map +1 -0
  130. package/dist/chunk-XU3OMQ7V.js +98 -0
  131. package/dist/chunk-XU3OMQ7V.js.map +1 -0
  132. package/dist/chunk-XWPDRMZG.js +62 -0
  133. package/dist/chunk-XWPDRMZG.js.map +1 -0
  134. package/dist/chunk-Y3CPKNB7.js +67 -0
  135. package/dist/chunk-Y3CPKNB7.js.map +1 -0
  136. package/dist/chunk-YNVRDD2P.js +98 -0
  137. package/dist/chunk-YNVRDD2P.js.map +1 -0
  138. package/dist/chunk-YSYR54XR.js +92 -0
  139. package/dist/chunk-YSYR54XR.js.map +1 -0
  140. package/dist/chunk-YTYDQBVY.cjs +162 -0
  141. package/dist/chunk-YTYDQBVY.cjs.map +1 -0
  142. package/dist/chunk-ZDLOA2UT.cjs +1042 -0
  143. package/dist/chunk-ZDLOA2UT.cjs.map +1 -0
  144. package/dist/chunk-ZWUKRCOJ.cjs +2162 -0
  145. package/dist/chunk-ZWUKRCOJ.cjs.map +1 -0
  146. package/dist/core/index.cjs +807 -4333
  147. package/dist/core/index.cjs.map +1 -1
  148. package/dist/core/index.js +14 -4130
  149. package/dist/core/index.js.map +1 -1
  150. package/dist/i18n/index.cjs +86 -558
  151. package/dist/i18n/index.cjs.map +1 -1
  152. package/dist/i18n/index.js +1 -544
  153. package/dist/i18n/index.js.map +1 -1
  154. package/dist/index.cjs +1432 -17139
  155. package/dist/index.cjs.map +1 -1
  156. package/dist/index.css +11 -7
  157. package/dist/index.css.map +1 -1
  158. package/dist/index.js +31 -16784
  159. package/dist/index.js.map +1 -1
  160. package/dist/marketing/index.cjs +142 -3072
  161. package/dist/marketing/index.cjs.map +1 -1
  162. package/dist/marketing/index.js +11 -3042
  163. package/dist/marketing/index.js.map +1 -1
  164. package/dist/motion/index.cjs +26 -1222
  165. package/dist/motion/index.cjs.map +1 -1
  166. package/dist/motion/index.js +2 -1215
  167. package/dist/motion/index.js.map +1 -1
  168. package/dist/nav/index.cjs +101 -1518
  169. package/dist/nav/index.cjs.map +1 -1
  170. package/dist/nav/index.js +4 -1498
  171. package/dist/nav/index.js.map +1 -1
  172. package/dist/report/index.cjs +171 -2403
  173. package/dist/report/index.cjs.map +1 -1
  174. package/dist/report/index.js +3 -2363
  175. package/dist/report/index.js.map +1 -1
  176. package/dist/sections/index.cjs +28 -378
  177. package/dist/sections/index.cjs.map +1 -1
  178. package/dist/sections/index.css +1 -4
  179. package/dist/sections/index.css.map +1 -1
  180. package/dist/sections/index.js +4 -372
  181. package/dist/sections/index.js.map +1 -1
  182. package/dist/social-proof/index.cjs +53 -1249
  183. package/dist/social-proof/index.cjs.map +1 -1
  184. package/dist/social-proof/index.css +10 -3
  185. package/dist/social-proof/index.css.map +1 -1
  186. package/dist/social-proof/index.js +6 -1234
  187. package/dist/social-proof/index.js.map +1 -1
  188. package/dist/theme/index.cjs +38 -565
  189. package/dist/theme/index.cjs.map +1 -1
  190. package/dist/theme/index.js +2 -555
  191. package/dist/theme/index.js.map +1 -1
  192. package/dist/web/client/index.cjs +48 -0
  193. package/dist/web/client/index.cjs.map +1 -0
  194. package/dist/web/client/index.css +456 -0
  195. package/dist/web/client/index.css.map +1 -0
  196. package/dist/web/client/index.d.cts +172 -0
  197. package/dist/web/client/index.d.ts +172 -0
  198. package/dist/web/client/index.js +7 -0
  199. package/dist/web/client/index.js.map +1 -0
  200. package/dist/web/index.cjs +158 -1346
  201. package/dist/web/index.cjs.map +1 -1
  202. package/dist/web/index.d.cts +5 -893
  203. package/dist/web/index.d.ts +5 -893
  204. package/dist/web/index.js +9 -1305
  205. package/dist/web/index.js.map +1 -1
  206. package/dist/web/server/index.cjs +32 -0
  207. package/dist/web/server/index.cjs.map +1 -0
  208. package/dist/web/server/index.d.cts +725 -0
  209. package/dist/web/server/index.d.ts +725 -0
  210. package/dist/web/server/index.js +3 -0
  211. package/dist/web/server/index.js.map +1 -0
  212. package/package.json +14 -1
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/ChartContainer/ChartContainer.tsx","../src/components/LineChart/LineChart.tsx","../src/components/BarChart/BarChart.tsx","../src/components/PieChart/PieChart.tsx","../src/components/FunnelChart/FunnelChart.tsx","../src/components/HeatmapChart/HeatmapChart.tsx","../src/components/Chart/ChartSwitchControl.tsx","../src/components/Chart/Chart.tsx","../src/components/MBTIRadar/MBTIRadar.tsx","../src/components/MBTITypeGrid/MBTITypeGrid.tsx"],"names":["Tooltip","jsx","jsxs","XAxis","YAxis","CartesianGrid","Legend","DEFAULT_COLORS","useMemo","Cell","clsx","Line","Bar","Pie","ResponsiveContainer","Fragment"],"mappings":"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","sourcesContent":["import React from 'react';\nimport clsx from 'clsx';\nimport { ResponsiveContainer } from 'recharts';\nimport { useReportMode, useChartData } from '../../report-engine';\nimport { DataStateIndicator } from '../DataStateIndicator';\nimport { DataCoverageBadge } from '../DataCoverageBadge';\nimport './ChartContainer.css';\n\nexport interface ChartContainerProps<T = Record<string, unknown>> {\n /** Chart title */\n title?: string;\n /** Chart subtitle/description */\n subtitle?: string;\n /** Chart height */\n height?: number;\n /** Chart data for validation */\n data?: T[];\n /** Required fields for data validation */\n requiredFields?: string[];\n /** Minimum sample size */\n minSampleSize?: number;\n /** Show data coverage badge */\n showCoverage?: boolean;\n /** Date range for coverage badge */\n dateRange?: { start: string; end: string };\n /** Loading state */\n loading?: boolean;\n /** Empty state message */\n emptyMessage?: string;\n /** Chart children (Recharts components) */\n children: React.ReactNode;\n /** Additional CSS class */\n className?: string;\n}\n\n/**\n * ChartContainer wraps charts with responsive sizing, theming, and data state handling.\n * It enforces data contracts and shows appropriate states when data is invalid.\n */\nexport function ChartContainer<T extends Record<string, unknown>>({\n title,\n subtitle,\n height = 300,\n data = [],\n requiredFields = [],\n minSampleSize = 30,\n showCoverage = true,\n dateRange,\n loading,\n emptyMessage = 'No data available',\n children,\n className,\n ...props\n}: ChartContainerProps<T>) {\n const { features } = useReportMode();\n\n const { state, isRenderable, message } = useChartData({\n data,\n requiredFields,\n minSampleSize,\n });\n\n const renderContent = () => {\n if (loading) {\n return (\n <div className=\"ds-chart-container__loading\">\n <div className=\"ds-chart-container__spinner\" />\n <span>Loading chart...</span>\n </div>\n );\n }\n\n if (!isRenderable && state !== 'VALID') {\n return (\n <div className=\"ds-chart-container__empty\">\n <DataStateIndicator\n state={state}\n variant=\"full\"\n details={{ message, sampleSize: data.length, requiredSize: minSampleSize }}\n />\n {state === 'INSUFFICIENT_SAMPLE' && data.length === 0 && (\n <p className=\"ds-chart-container__empty-message\">{emptyMessage}</p>\n )}\n </div>\n );\n }\n\n return (\n <ResponsiveContainer width=\"100%\" height={height}>\n {children as React.ReactElement}\n </ResponsiveContainer>\n );\n };\n\n return (\n <div\n className={clsx(\n 'ds-chart-container',\n loading && 'ds-chart-container--loading',\n !isRenderable && 'ds-chart-container--invalid',\n className,\n )}\n {...props}\n >\n {(title || subtitle || (showCoverage && features.showMethodology)) && (\n <header className=\"ds-chart-container__header\">\n <div className=\"ds-chart-container__header-content\">\n {title && <h4 className=\"ds-chart-container__title\">{title}</h4>}\n {subtitle && <p className=\"ds-chart-container__subtitle\">{subtitle}</p>}\n </div>\n {showCoverage && features.showMethodology && data.length > 0 && (\n <DataCoverageBadge\n sampleSize={data.length}\n requiredSize={minSampleSize}\n dateRange={dateRange}\n size=\"sm\"\n />\n )}\n </header>\n )}\n\n <div\n className=\"ds-chart-container__chart\"\n style={{ height: typeof height === 'number' ? height : undefined }}\n >\n {renderContent()}\n </div>\n\n {isRenderable && state !== 'VALID' && (\n <footer className=\"ds-chart-container__footer\">\n <DataStateIndicator state={state} variant=\"compact\" />\n </footer>\n )}\n </div>\n );\n}\n\nChartContainer.displayName = 'ChartContainer';\n","import React from 'react';\nimport {\n LineChart as RechartsLineChart,\n Line,\n XAxis,\n YAxis,\n CartesianGrid,\n Tooltip,\n Legend,\n} from 'recharts';\nimport { ChartContainer } from '../ChartContainer';\n\nexport interface LineConfig {\n /** Data key for the line */\n key: string;\n /** Display name */\n name?: string;\n /** Line color (CSS variable or hex) */\n color?: string;\n /** Dashed line */\n dashed?: boolean;\n /** Show dots on data points */\n dot?: boolean;\n}\n\nexport interface LineChartProps<T = Record<string, unknown>> {\n /** Chart data */\n data: T[];\n /** X-axis data key */\n xKey: string;\n /** Line configurations */\n lines: LineConfig[];\n /** Chart title */\n title?: string;\n /** Chart subtitle */\n subtitle?: string;\n /** Chart height */\n height?: number;\n /** Show grid lines */\n grid?: boolean;\n /** Show legend */\n legend?: boolean;\n /** Curve type */\n curve?: 'linear' | 'monotone' | 'step';\n /** Custom tooltip formatter */\n tooltipFormatter?: (value: number, name: string) => string;\n /** Minimum sample size */\n minSampleSize?: number;\n /** Date range */\n dateRange?: { start: string; end: string };\n /** Additional CSS class */\n className?: string;\n}\n\nconst DEFAULT_COLORS = [\n 'var(--brand-pink)',\n 'var(--brand-yellow)',\n 'var(--status-info)',\n 'var(--status-success)',\n 'var(--status-warning)',\n];\n\n/**\n * LineChart displays time-series or trend data.\n * Requires minimum 7 data points for meaningful visualization.\n */\nexport function LineChart<T extends Record<string, unknown>>({\n data,\n xKey,\n lines,\n title,\n subtitle,\n height = 300,\n grid = true,\n legend: showLegend = true,\n curve = 'monotone',\n minSampleSize = 7,\n dateRange,\n className,\n}: LineChartProps<T>) {\n const requiredFields = [xKey, ...lines.map((l) => l.key)];\n const chartData = React.useMemo(() => data.map((item) => ({ ...item })), [data]);\n\n return (\n <ChartContainer\n title={title}\n subtitle={subtitle}\n height={height}\n data={data}\n requiredFields={requiredFields}\n minSampleSize={minSampleSize}\n dateRange={dateRange}\n className={className}\n >\n <RechartsLineChart data={chartData} margin={{ top: 5, right: 20, left: 0, bottom: 5 }}>\n {grid && <CartesianGrid strokeDasharray=\"3 3\" vertical={false} />}\n <XAxis\n dataKey={xKey}\n tick={{ fontSize: 12 }}\n tickLine={false}\n axisLine={{ strokeWidth: 1 }}\n />\n <YAxis tick={{ fontSize: 12 }} tickLine={false} axisLine={false} width={40} />\n <Tooltip />\n {showLegend && <Legend />}\n {lines.map((line, index) => (\n <Line\n key={line.key}\n type={curve}\n dataKey={line.key}\n name={line.name || line.key}\n stroke={line.color || DEFAULT_COLORS[index % DEFAULT_COLORS.length]}\n strokeWidth={2}\n strokeDasharray={line.dashed ? '5 5' : undefined}\n dot={line.dot !== false}\n activeDot={{ r: 6 }}\n />\n ))}\n </RechartsLineChart>\n </ChartContainer>\n );\n}\n\nLineChart.displayName = 'LineChart';\n","import { useMemo } from 'react';\nimport {\n BarChart as RechartsBarChart,\n Bar,\n XAxis,\n YAxis,\n CartesianGrid,\n Tooltip,\n Legend,\n Cell,\n} from 'recharts';\nimport { ChartContainer } from '../ChartContainer';\n\nexport interface BarConfig {\n /** Data key for the bar */\n key: string;\n /** Display name */\n name?: string;\n /** Bar color (CSS variable or hex) */\n color?: string;\n /** Stack ID for stacked bars */\n stackId?: string;\n}\n\nexport interface BarChartProps<T = Record<string, unknown>> {\n /** Chart data */\n data: T[];\n /** X-axis data key (category key) */\n xKey: string;\n /** Bar configurations */\n bars: BarConfig[];\n /** Chart title */\n title?: string;\n /** Chart subtitle */\n subtitle?: string;\n /** Chart height */\n height?: number;\n /** Layout direction */\n layout?: 'horizontal' | 'vertical';\n /** Show grid lines */\n grid?: boolean;\n /** Show legend */\n legend?: boolean;\n /** Bar corner radius */\n radius?: number;\n /** Show value labels on bars */\n showLabels?: boolean;\n /** Custom tooltip formatter */\n tooltipFormatter?: (value: number, name: string) => string;\n /** Minimum sample size */\n minSampleSize?: number;\n /** Use category colors (different color per bar in single series) */\n categoryColors?: string[];\n /** Additional CSS class */\n className?: string;\n}\n\nconst DEFAULT_COLORS = [\n 'var(--brand-pink)',\n 'var(--brand-yellow)',\n 'var(--status-info)',\n 'var(--status-success)',\n 'var(--status-warning)',\n];\n\n/**\n * BarChart displays comparisons and distributions.\n * Requires minimum 5 categories for meaningful visualization.\n */\nexport function BarChart<T extends Record<string, unknown>>({\n data,\n xKey,\n bars,\n title,\n subtitle,\n height = 300,\n layout = 'horizontal',\n grid = true,\n legend: showLegend = true,\n radius = 4,\n showLabels = false,\n minSampleSize = 5,\n categoryColors,\n className,\n}: BarChartProps<T>) {\n const requiredFields = [xKey, ...bars.map((b) => b.key)];\n const isVertical = layout === 'vertical';\n const chartData = useMemo(() => data.map((item) => ({ ...item })), [data]);\n\n return (\n <ChartContainer\n title={title}\n subtitle={subtitle}\n height={height}\n data={chartData}\n requiredFields={requiredFields}\n minSampleSize={minSampleSize}\n className={className}\n >\n <RechartsBarChart\n data={chartData}\n layout={isVertical ? 'vertical' : 'horizontal'}\n margin={{ top: 5, right: 20, left: isVertical ? 80 : 0, bottom: 5 }}\n >\n {grid && (\n <CartesianGrid strokeDasharray=\"3 3\" horizontal={!isVertical} vertical={isVertical} />\n )}\n {isVertical ? (\n <>\n <XAxis type=\"number\" tick={{ fontSize: 12 }} tickLine={false} axisLine={false} />\n <YAxis\n type=\"category\"\n dataKey={xKey}\n tick={{ fontSize: 12 }}\n tickLine={false}\n axisLine={false}\n width={80}\n />\n </>\n ) : (\n <>\n <XAxis\n dataKey={xKey}\n tick={{ fontSize: 12 }}\n tickLine={false}\n axisLine={{ strokeWidth: 1 }}\n />\n <YAxis tick={{ fontSize: 12 }} tickLine={false} axisLine={false} width={40} />\n </>\n )}\n <Tooltip />\n {showLegend && bars.length > 1 && <Legend />}\n {bars.map((bar, barIndex) => (\n <Bar\n key={bar.key}\n dataKey={bar.key}\n name={bar.name || bar.key}\n fill={bar.color || DEFAULT_COLORS[barIndex % DEFAULT_COLORS.length]}\n stackId={bar.stackId}\n radius={[radius, radius, 0, 0]}\n label={showLabels ? { position: 'top', fontSize: 10 } : false}\n >\n {categoryColors &&\n chartData.map((_, index) => (\n <Cell key={`cell-${index}`} fill={categoryColors[index % categoryColors.length]} />\n ))}\n </Bar>\n ))}\n </RechartsBarChart>\n </ChartContainer>\n );\n}\n\nBarChart.displayName = 'BarChart';\n","import { useMemo } from 'react';\nimport { PieChart as RechartsPieChart, Pie, Cell, Tooltip, Legend } from 'recharts';\nimport { ChartContainer } from '../ChartContainer';\n\nexport interface PieChartDataItem {\n name: string;\n value: number;\n color?: string;\n}\n\nexport interface PieChartProps {\n /** Chart data */\n data: PieChartDataItem[];\n /** Chart title */\n title?: string;\n /** Chart subtitle */\n subtitle?: string;\n /** Chart height */\n height?: number;\n /** Inner radius for donut effect (0 = pie, >0 = donut) */\n innerRadius?: number;\n /** Outer radius */\n outerRadius?: number;\n /** Show labels */\n showLabels?: boolean;\n /** Label type */\n labelType?: 'percent' | 'value' | 'name';\n /** Show legend */\n legend?: boolean;\n /** Custom tooltip formatter */\n tooltipFormatter?: (value: number, name: string) => string;\n /** Minimum sample size (total of all values) */\n minSampleSize?: number;\n /** Additional CSS class */\n className?: string;\n}\n\nconst DEFAULT_COLORS = [\n 'var(--brand-pink)',\n 'var(--brand-yellow)',\n 'var(--status-info)',\n 'var(--status-success)',\n 'var(--status-warning)',\n 'var(--status-error)',\n '#8884d8',\n '#82ca9d',\n];\n\n/**\n * PieChart displays proportions and compositions.\n * Requires minimum 3 segments and n > 30 for meaningful visualization.\n */\nexport function PieChart({\n data,\n title,\n subtitle,\n height = 300,\n innerRadius = 0,\n outerRadius = 80,\n showLabels = true,\n labelType = 'percent',\n legend: showLegend = true,\n minSampleSize = 30,\n className,\n}: PieChartProps) {\n const safeData = useMemo(() => data.map((item) => ({ ...item })), [data]);\n const renderLabel = (props: { name?: string; value?: number; percent?: number }) => {\n const { name, value, percent } = props;\n switch (labelType) {\n case 'percent':\n return `${((percent ?? 0) * 100).toFixed(0)}%`;\n case 'value':\n return (value ?? 0).toLocaleString();\n case 'name':\n return name ?? '';\n default:\n return '';\n }\n };\n\n return (\n <ChartContainer\n title={title}\n subtitle={subtitle}\n height={height}\n data={safeData}\n requiredFields={['name', 'value']}\n minSampleSize={minSampleSize}\n className={className}\n >\n <RechartsPieChart>\n <Pie\n data={safeData}\n cx=\"50%\"\n cy=\"50%\"\n innerRadius={innerRadius}\n outerRadius={outerRadius}\n paddingAngle={2}\n dataKey=\"value\"\n label={showLabels ? renderLabel : undefined}\n labelLine={showLabels}\n >\n {safeData.map((entry, index) => (\n <Cell\n key={`cell-${index}`}\n fill={entry.color || DEFAULT_COLORS[index % DEFAULT_COLORS.length]}\n />\n ))}\n </Pie>\n <Tooltip />\n {showLegend && <Legend />}\n </RechartsPieChart>\n </ChartContainer>\n );\n}\n\nPieChart.displayName = 'PieChart';\n","import { useMemo } from 'react';\nimport clsx from 'clsx';\nimport { useReportMode } from '../../report-engine';\nimport { DataCoverageBadge } from '../DataCoverageBadge';\nimport { DataStateIndicator } from '../DataStateIndicator';\nimport './FunnelChart.css';\n\nexport interface FunnelStage {\n /** Stage name */\n name: string;\n /** Value/count at this stage */\n value: number;\n /** Optional color override */\n color?: string;\n}\n\nexport interface FunnelChartProps {\n /** Funnel stages (min 3 required) */\n stages: FunnelStage[];\n /** Chart title */\n title?: string;\n /** Chart subtitle */\n subtitle?: string;\n /** Show conversion rates between stages */\n showConversionRates?: boolean;\n /** Show drop-off percentages */\n showDropOff?: boolean;\n /** Show value labels */\n showValues?: boolean;\n /** Height in pixels */\n height?: number;\n /** Additional CSS class */\n className?: string;\n}\n\nconst DEFAULT_COLORS = [\n 'var(--brand-pink)',\n 'var(--brand-yellow)',\n 'var(--status-info)',\n 'var(--status-success)',\n 'var(--status-warning)',\n];\n\n/**\n * FunnelChart visualizes conversion funnels and drop-off rates.\n * Requires minimum 3 stages for meaningful visualization.\n */\nexport function FunnelChart({\n stages,\n title,\n subtitle,\n showConversionRates = true,\n showDropOff = true,\n showValues = true,\n height = 300,\n className,\n}: FunnelChartProps) {\n const { features } = useReportMode();\n\n const isValid = stages.length >= 3;\n const maxValue = stages.length > 0 ? Math.max(...stages.map((s) => s.value)) : 0;\n\n const stagesWithMetrics = useMemo(() => {\n return stages.map((stage, index) => {\n const prevStage = index > 0 ? stages[index - 1] : null;\n const conversionRate = prevStage ? (stage.value / prevStage.value) * 100 : 100;\n const dropOff = prevStage ? ((prevStage.value - stage.value) / prevStage.value) * 100 : 0;\n const widthPercent = maxValue > 0 ? (stage.value / maxValue) * 100 : 0;\n\n return {\n ...stage,\n conversionRate,\n dropOff,\n widthPercent,\n color: stage.color || DEFAULT_COLORS[index % DEFAULT_COLORS.length],\n };\n });\n }, [stages, maxValue]);\n\n if (!isValid) {\n return (\n <div className={clsx('ds-funnel-chart', 'ds-funnel-chart--invalid', className)}>\n {title && <h4 className=\"ds-funnel-chart__title\">{title}</h4>}\n <div className=\"ds-funnel-chart__empty\">\n <DataStateIndicator\n state=\"INSUFFICIENT_SAMPLE\"\n variant=\"full\"\n details={{\n message: 'Funnel requires at least 3 stages',\n sampleSize: stages.length,\n requiredSize: 3,\n }}\n />\n </div>\n </div>\n );\n }\n\n const totalConversion =\n stages.length > 1\n ? ((stages[stages.length - 1].value / stages[0].value) * 100).toFixed(1)\n : '100';\n\n return (\n <div className={clsx('ds-funnel-chart', className)} style={{ minHeight: height }}>\n {(title || subtitle) && (\n <header className=\"ds-funnel-chart__header\">\n <div>\n {title && <h4 className=\"ds-funnel-chart__title\">{title}</h4>}\n {subtitle && <p className=\"ds-funnel-chart__subtitle\">{subtitle}</p>}\n </div>\n {features.showMethodology && <DataCoverageBadge sampleSize={stages[0].value} size=\"sm\" />}\n </header>\n )}\n\n <div className=\"ds-funnel-chart__stages\">\n {stagesWithMetrics.map((stage, index) => (\n <div key={stage.name} className=\"ds-funnel-chart__stage\">\n <div className=\"ds-funnel-chart__bar-container\">\n <div\n className=\"ds-funnel-chart__bar\"\n style={{\n width: `${stage.widthPercent}%`,\n backgroundColor: stage.color,\n }}\n >\n {showValues && (\n <span className=\"ds-funnel-chart__value\">{stage.value.toLocaleString()}</span>\n )}\n </div>\n </div>\n\n <div className=\"ds-funnel-chart__label\">\n <span className=\"ds-funnel-chart__stage-name\">{stage.name}</span>\n {showConversionRates && index > 0 && (\n <span className=\"ds-funnel-chart__conversion\">\n {stage.conversionRate.toFixed(1)}% converted\n </span>\n )}\n </div>\n\n {showDropOff && index > 0 && stage.dropOff > 0 && (\n <div className=\"ds-funnel-chart__dropoff\">\n <span className=\"ds-funnel-chart__dropoff-arrow\">↓</span>\n <span className=\"ds-funnel-chart__dropoff-value\">-{stage.dropOff.toFixed(1)}%</span>\n </div>\n )}\n </div>\n ))}\n </div>\n\n <footer className=\"ds-funnel-chart__footer\">\n <span className=\"ds-funnel-chart__total\">\n Overall Conversion: <strong>{totalConversion}%</strong>\n </span>\n </footer>\n </div>\n );\n}\n\nFunnelChart.displayName = 'FunnelChart';\n","import { useMemo } from 'react';\nimport clsx from 'clsx';\nimport { useReportMode } from '../../report-engine';\nimport { DataCoverageBadge } from '../DataCoverageBadge';\nimport { Tooltip } from '../Tooltip/Tooltip';\nimport './HeatmapChart.css';\n\nexport interface HeatmapCell {\n /** X-axis value (column) */\n x: string;\n /** Y-axis value (row) */\n y: string;\n /** Cell value */\n value: number;\n}\n\nexport interface HeatmapChartProps {\n /** Heatmap data */\n data: HeatmapCell[];\n /** Chart title */\n title?: string;\n /** Chart subtitle */\n subtitle?: string;\n /** X-axis label */\n xLabel?: string;\n /** Y-axis label */\n yLabel?: string;\n /** Color scale (low to high) */\n colorScale?: [string, string];\n /** Show cell values */\n showValues?: boolean;\n /** Value formatter */\n valueFormatter?: (value: number) => string;\n /** Minimum cells required */\n minCells?: number;\n /** Additional CSS class */\n className?: string;\n}\n\n/**\n * HeatmapChart visualizes density and correlation data.\n * Requires minimum 25 cells for meaningful visualization.\n */\nexport function HeatmapChart({\n data,\n title,\n subtitle,\n xLabel,\n yLabel,\n colorScale = ['var(--glass-elevated)', 'var(--brand-pink)'],\n showValues = true,\n valueFormatter = (v) => v.toFixed(0),\n minCells = 25,\n className,\n}: HeatmapChartProps) {\n const { features } = useReportMode();\n\n // Extract unique x and y values\n const { xValues, yValues, cellMap, minValue, maxValue } = useMemo(() => {\n const xSet = new Set<string>();\n const ySet = new Set<string>();\n const map = new Map<string, number>();\n let min = Infinity;\n let max = -Infinity;\n\n for (const cell of data) {\n xSet.add(cell.x);\n ySet.add(cell.y);\n map.set(`${cell.x}-${cell.y}`, cell.value);\n min = Math.min(min, cell.value);\n max = Math.max(max, cell.value);\n }\n\n return {\n xValues: Array.from(xSet),\n yValues: Array.from(ySet),\n cellMap: map,\n minValue: min === Infinity ? 0 : min,\n maxValue: max === -Infinity ? 0 : max,\n };\n }, [data]);\n\n const isValid = data.length >= minCells;\n\n const getCellColor = (value: number) => {\n if (maxValue === minValue) return colorScale[0];\n const ratio = (value - minValue) / (maxValue - minValue);\n return `color-mix(in srgb, ${colorScale[1]} ${ratio * 100}%, ${colorScale[0]})`;\n };\n\n const getTextColor = (value: number) => {\n const ratio = (value - minValue) / (maxValue - minValue);\n return ratio > 0.5 ? 'white' : 'var(--text-primary)';\n };\n\n if (!isValid) {\n return (\n <div className={clsx('ds-heatmap-chart', 'ds-heatmap-chart--invalid', className)}>\n {title && <h4 className=\"ds-heatmap-chart__title\">{title}</h4>}\n <div className=\"ds-heatmap-chart__empty\">\n <p>Insufficient data for heatmap visualization</p>\n <p className=\"ds-heatmap-chart__empty-detail\">\n {data.length} cells provided, {minCells} required\n </p>\n </div>\n </div>\n );\n }\n\n return (\n <div className={clsx('ds-heatmap-chart', className)}>\n {(title || subtitle) && (\n <header className=\"ds-heatmap-chart__header\">\n <div>\n {title && <h4 className=\"ds-heatmap-chart__title\">{title}</h4>}\n {subtitle && <p className=\"ds-heatmap-chart__subtitle\">{subtitle}</p>}\n </div>\n {features.showMethodology && (\n <DataCoverageBadge sampleSize={data.length} requiredSize={minCells} size=\"sm\" />\n )}\n </header>\n )}\n\n <div className=\"ds-heatmap-chart__container\">\n {yLabel && (\n <div className=\"ds-heatmap-chart__y-label\">\n <span>{yLabel}</span>\n </div>\n )}\n\n <div className=\"ds-heatmap-chart__grid-wrapper\">\n <div\n className=\"ds-heatmap-chart__grid\"\n style={{\n gridTemplateColumns: `repeat(${xValues.length}, 1fr)`,\n gridTemplateRows: `repeat(${yValues.length}, 1fr)`,\n }}\n >\n {yValues.map((y) =>\n xValues.map((x) => {\n const value = cellMap.get(`${x}-${y}`) ?? 0;\n const cellContent = (\n <div\n key={`${x}-${y}`}\n className=\"ds-heatmap-chart__cell\"\n style={{\n backgroundColor: getCellColor(value),\n color: getTextColor(value),\n }}\n >\n {showValues && (\n <span className=\"ds-heatmap-chart__cell-value\">{valueFormatter(value)}</span>\n )}\n </div>\n );\n\n return (\n <Tooltip key={`${x}-${y}`} content={`${x}, ${y}: ${valueFormatter(value)}`}>\n {cellContent}\n </Tooltip>\n );\n }),\n )}\n </div>\n\n {/* X-axis labels */}\n <div\n className=\"ds-heatmap-chart__x-labels\"\n style={{ gridTemplateColumns: `repeat(${xValues.length}, 1fr)` }}\n >\n {xValues.map((x) => (\n <span key={x} className=\"ds-heatmap-chart__x-label\">\n {x}\n </span>\n ))}\n </div>\n </div>\n\n {/* Y-axis labels */}\n <div\n className=\"ds-heatmap-chart__y-labels\"\n style={{ gridTemplateRows: `repeat(${yValues.length}, 1fr)` }}\n >\n {yValues.map((y) => (\n <span key={y} className=\"ds-heatmap-chart__y-label-item\">\n {y}\n </span>\n ))}\n </div>\n </div>\n\n {xLabel && (\n <div className=\"ds-heatmap-chart__x-axis-label\">\n <span>{xLabel}</span>\n </div>\n )}\n\n {/* Legend */}\n <div className=\"ds-heatmap-chart__legend\">\n <span className=\"ds-heatmap-chart__legend-label\">Low</span>\n <div\n className=\"ds-heatmap-chart__legend-bar\"\n style={{\n background: `linear-gradient(to right, ${colorScale[0]}, ${colorScale[1]})`,\n }}\n />\n <span className=\"ds-heatmap-chart__legend-label\">High</span>\n </div>\n </div>\n );\n}\n\nHeatmapChart.displayName = 'HeatmapChart';\n","import clsx from 'clsx';\nimport type { ChartTypeId } from '../../report-engine/chart-types';\nimport { CHART_REGISTRY } from '../../report-engine/chart-types';\nimport './ChartSwitchControl.css';\n\nexport interface ChartSwitchControlProps {\n /** Currently selected chart type */\n currentType: ChartTypeId;\n /** Allowed chart types for switching */\n allowedTypes: ChartTypeId[];\n /** Callback when type changes */\n onTypeChange: (type: ChartTypeId) => void;\n /** Size variant */\n size?: 'sm' | 'md';\n /** Additional CSS class */\n className?: string;\n}\n\n/**\n * ChartSwitchControl allows users to switch between allowed chart types\n * within the same semantic family.\n */\nexport function ChartSwitchControl({\n currentType,\n allowedTypes,\n onTypeChange,\n size = 'sm',\n className,\n}: ChartSwitchControlProps) {\n if (allowedTypes.length <= 1) {\n return null;\n }\n\n return (\n <div className={clsx('ds-chart-switch', `ds-chart-switch--${size}`, className)}>\n {allowedTypes.map((type) => {\n const meta = CHART_REGISTRY[type];\n if (!meta) return null;\n\n const isActive = type === currentType;\n const Icon = getChartIcon(type);\n\n return (\n <button\n key={type}\n type=\"button\"\n className={clsx(\n 'ds-chart-switch__option',\n isActive && 'ds-chart-switch__option--active',\n )}\n onClick={() => onTypeChange(type)}\n title={meta.name}\n aria-pressed={isActive}\n >\n <Icon />\n <span className=\"ds-chart-switch__label\">{getShortLabel(type)}</span>\n </button>\n );\n })}\n </div>\n );\n}\n\nChartSwitchControl.displayName = 'ChartSwitchControl';\n\n/* ============================================================================\n CHART ICONS\n ============================================================================ */\n\nfunction getChartIcon(type: ChartTypeId): React.FC {\n const icons: Partial<Record<ChartTypeId, React.FC>> = {\n line: LineIcon,\n smooth_line: SmoothLineIcon,\n area: AreaIcon,\n stacked_area: StackedAreaIcon,\n area_100pct: StackedAreaIcon,\n bar: BarIcon,\n column: ColumnIcon,\n stacked_bar: StackedBarIcon,\n stacked_column: StackedColumnIcon,\n column_100pct: StackedColumnIcon,\n pie: PieIcon,\n donut: DonutIcon,\n histogram: HistogramIcon,\n funnel: FunnelIcon,\n heatmap: HeatmapIcon,\n };\n\n return icons[type] || DefaultChartIcon;\n}\n\nfunction getShortLabel(type: ChartTypeId): string {\n const labels: Partial<Record<ChartTypeId, string>> = {\n line: 'Line',\n smooth_line: 'Smooth',\n area: 'Area',\n stacked_area: 'Stacked',\n area_100pct: '100%',\n bar: 'Bar',\n column: 'Column',\n stacked_bar: 'Stacked',\n stacked_column: 'Stacked',\n column_100pct: '100%',\n pie: 'Pie',\n donut: 'Donut',\n histogram: 'Histogram',\n funnel: 'Funnel',\n heatmap: 'Heatmap',\n };\n\n return labels[type] || type;\n}\n\n/* ============================================================================\n ICON COMPONENTS\n ============================================================================ */\n\nfunction LineIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <polyline points=\"22 12 18 8 13 13 9 9 2 16\" />\n </svg>\n );\n}\n\nfunction SmoothLineIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <path d=\"M2 16 C6 16, 8 8, 12 12 S18 6, 22 10\" />\n </svg>\n );\n}\n\nfunction AreaIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <path d=\"M2 20 L2 16 L8 10 L14 14 L22 6 L22 20 Z\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n <polyline points=\"2 16 8 10 14 14 22 6\" />\n </svg>\n );\n}\n\nfunction StackedAreaIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <path d=\"M2 20 L2 14 L8 10 L14 12 L22 8 L22 20 Z\" fill=\"currentColor\" fillOpacity=\"0.3\" />\n <path d=\"M2 20 L2 16 L8 14 L14 15 L22 12 L22 20 Z\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n </svg>\n );\n}\n\nfunction BarIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <rect x=\"2\" y=\"4\" width=\"14\" height=\"4\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n <rect x=\"2\" y=\"10\" width=\"18\" height=\"4\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n <rect x=\"2\" y=\"16\" width=\"10\" height=\"4\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n </svg>\n );\n}\n\nfunction ColumnIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <rect x=\"4\" y=\"8\" width=\"4\" height=\"14\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n <rect x=\"10\" y=\"4\" width=\"4\" height=\"18\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n <rect x=\"16\" y=\"12\" width=\"4\" height=\"10\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n </svg>\n );\n}\n\nfunction StackedBarIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <rect x=\"2\" y=\"4\" width=\"8\" height=\"4\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.3\" />\n <rect x=\"10\" y=\"4\" width=\"6\" height=\"4\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.15\" />\n <rect x=\"2\" y=\"10\" width=\"12\" height=\"4\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.3\" />\n <rect x=\"14\" y=\"10\" width=\"6\" height=\"4\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.15\" />\n <rect x=\"2\" y=\"16\" width=\"6\" height=\"4\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.3\" />\n <rect x=\"8\" y=\"16\" width=\"4\" height=\"4\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.15\" />\n </svg>\n );\n}\n\nfunction StackedColumnIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <rect x=\"4\" y=\"14\" width=\"4\" height=\"8\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.3\" />\n <rect x=\"4\" y=\"8\" width=\"4\" height=\"6\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.15\" />\n <rect x=\"10\" y=\"10\" width=\"4\" height=\"12\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.3\" />\n <rect x=\"10\" y=\"4\" width=\"4\" height=\"6\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.15\" />\n <rect x=\"16\" y=\"16\" width=\"4\" height=\"6\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.3\" />\n <rect x=\"16\" y=\"12\" width=\"4\" height=\"4\" rx=\"1\" fill=\"currentColor\" fillOpacity=\"0.15\" />\n </svg>\n );\n}\n\nfunction PieIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <circle cx=\"12\" cy=\"12\" r=\"10\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n <path d=\"M12 2 A10 10 0 0 1 22 12 L12 12 Z\" fill=\"currentColor\" fillOpacity=\"0.3\" />\n </svg>\n );\n}\n\nfunction DonutIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <circle cx=\"12\" cy=\"12\" r=\"10\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n <circle cx=\"12\" cy=\"12\" r=\"5\" fill=\"var(--glass-elevated)\" stroke=\"none\" />\n <path\n d=\"M12 2 A10 10 0 0 1 22 12 L17 12 A5 5 0 0 0 12 7 Z\"\n fill=\"currentColor\"\n fillOpacity=\"0.3\"\n />\n </svg>\n );\n}\n\nfunction HistogramIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <rect x=\"2\" y=\"14\" width=\"4\" height=\"8\" rx=\"0\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n <rect x=\"6\" y=\"10\" width=\"4\" height=\"12\" rx=\"0\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n <rect x=\"10\" y=\"4\" width=\"4\" height=\"18\" rx=\"0\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n <rect x=\"14\" y=\"8\" width=\"4\" height=\"14\" rx=\"0\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n <rect x=\"18\" y=\"12\" width=\"4\" height=\"10\" rx=\"0\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n </svg>\n );\n}\n\nfunction FunnelIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <path d=\"M2 4 H22 L18 10 H6 Z\" fill=\"currentColor\" fillOpacity=\"0.3\" />\n <path d=\"M6 10 H18 L15 16 H9 Z\" fill=\"currentColor\" fillOpacity=\"0.25\" />\n <path d=\"M9 16 H15 L13 22 H11 Z\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n </svg>\n );\n}\n\nfunction HeatmapIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"1\"\n >\n <rect x=\"2\" y=\"2\" width=\"6\" height=\"6\" fill=\"currentColor\" fillOpacity=\"0.1\" />\n <rect x=\"9\" y=\"2\" width=\"6\" height=\"6\" fill=\"currentColor\" fillOpacity=\"0.3\" />\n <rect x=\"16\" y=\"2\" width=\"6\" height=\"6\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n <rect x=\"2\" y=\"9\" width=\"6\" height=\"6\" fill=\"currentColor\" fillOpacity=\"0.4\" />\n <rect x=\"9\" y=\"9\" width=\"6\" height=\"6\" fill=\"currentColor\" fillOpacity=\"0.6\" />\n <rect x=\"16\" y=\"9\" width=\"6\" height=\"6\" fill=\"currentColor\" fillOpacity=\"0.3\" />\n <rect x=\"2\" y=\"16\" width=\"6\" height=\"6\" fill=\"currentColor\" fillOpacity=\"0.2\" />\n <rect x=\"9\" y=\"16\" width=\"6\" height=\"6\" fill=\"currentColor\" fillOpacity=\"0.5\" />\n <rect x=\"16\" y=\"16\" width=\"6\" height=\"6\" fill=\"currentColor\" fillOpacity=\"0.4\" />\n </svg>\n );\n}\n\nfunction DefaultChartIcon() {\n return (\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n >\n <rect x=\"3\" y=\"3\" width=\"18\" height=\"18\" rx=\"2\" />\n <path d=\"M3 15 L9 9 L13 13 L21 5\" />\n </svg>\n );\n}\n","import { useMemo, useState } from 'react';\nimport clsx from 'clsx';\nimport {\n LineChart as RechartsLine,\n AreaChart as RechartsArea,\n BarChart as RechartsBar,\n PieChart as RechartsPie,\n Line,\n Area,\n Bar,\n Pie,\n Cell,\n XAxis,\n YAxis,\n CartesianGrid,\n Tooltip,\n Legend,\n ResponsiveContainer,\n} from 'recharts';\nimport type {\n ChartIntent,\n ChartTypeId,\n ChartValidationResult,\n} from '../../report-engine/chart-types';\nimport {\n CHART_REGISTRY,\n validateChartData,\n getAllowedSwitchTargets,\n getDefaultChartForIntent,\n} from '../../report-engine/chart-types';\nimport { useReportMode } from '../../report-engine';\nimport { DataStateIndicator } from '../DataStateIndicator';\nimport { DataCoverageBadge } from '../DataCoverageBadge';\nimport { ChartSwitchControl } from './ChartSwitchControl';\nimport './Chart.css';\n\n/* ============================================================================\n CHART PROPS\n ============================================================================ */\n\nexport interface ChartDimension {\n /** Field key in data */\n key: string;\n /** Display label */\n label?: string;\n /** Is this a time dimension */\n isTime?: boolean;\n}\n\nexport interface ChartMeasure {\n /** Field key in data */\n key: string;\n /** Display label */\n label?: string;\n /** Color (CSS variable or hex) */\n color?: string;\n /** Stack group ID */\n stackId?: string;\n}\n\nexport interface ChartProps<T = Record<string, unknown>> {\n /** Semantic intent of the visualization */\n intent: ChartIntent;\n /** Chart data */\n data: T[];\n /** Dimension fields (categories, time axis) */\n dimensions: ChartDimension[];\n /** Measure fields (values to visualize) */\n measures: ChartMeasure[];\n /** Default chart type */\n defaultType?: ChartTypeId;\n /** Allowed chart types for switching (defaults to all MVP types in family) */\n allowedTypes?: ChartTypeId[];\n /** Controlled chart type */\n chartType?: ChartTypeId;\n /** Callback when chart type changes */\n onChartTypeChange?: (type: ChartTypeId) => void;\n /** Allow user to switch chart types */\n allowSwitching?: boolean;\n /** Chart title */\n title?: string;\n /** Chart subtitle */\n subtitle?: string;\n /** Chart height */\n height?: number;\n /** Show legend */\n legend?: boolean;\n /** Show grid */\n grid?: boolean;\n /** Additional CSS class */\n className?: string;\n}\n\n/* ============================================================================\n DEFAULT COLORS\n ============================================================================ */\n\nconst CHART_COLORS = [\n 'var(--brand-pink)',\n 'var(--brand-yellow)',\n 'var(--status-info)',\n 'var(--status-success)',\n 'var(--status-warning)',\n 'var(--status-error)',\n];\n\nfunction getColor(index: number, customColor?: string): string {\n return customColor || CHART_COLORS[index % CHART_COLORS.length];\n}\n\n/* ============================================================================\n CHART COMPONENT\n ============================================================================ */\n\n/**\n * Chart is the unified abstraction layer for all visualizations.\n *\n * It provides:\n * - Intent-based chart selection\n * - Data contract validation\n * - Governed chart switching within semantic families\n * - Consistent theming and accessibility\n *\n * @example\n * ```tsx\n * <Chart\n * intent=\"trend\"\n * data={timeSeriesData}\n * dimensions={[{ key: 'date', isTime: true }]}\n * measures={[{ key: 'revenue', label: 'Revenue' }]}\n * defaultType=\"line\"\n * allowSwitching\n * />\n * ```\n */\nexport function Chart<T extends Record<string, unknown>>({\n intent,\n data,\n dimensions,\n measures,\n defaultType,\n allowedTypes,\n chartType: controlledType,\n onChartTypeChange,\n allowSwitching = false,\n title,\n subtitle,\n height = 300,\n legend: showLegend = true,\n grid = true,\n className,\n}: ChartProps<T>) {\n const { features } = useReportMode();\n\n // Determine chart type\n const resolvedDefault = defaultType || getDefaultChartForIntent(intent);\n const [internalType, setInternalType] = useState<ChartTypeId>(resolvedDefault);\n const activeType = controlledType ?? internalType;\n\n // Determine allowed types for switching\n const resolvedAllowedTypes = useMemo(() => {\n if (allowedTypes) return allowedTypes;\n return getAllowedSwitchTargets(activeType);\n }, [allowedTypes, activeType]);\n\n // Validate data against contract\n const validation = useMemo<ChartValidationResult>(() => {\n return validateChartData(\n activeType,\n data,\n dimensions.map((d) => d.key),\n measures.map((m) => m.key),\n );\n }, [activeType, data, dimensions, measures]);\n\n // Handle type change\n const handleTypeChange = (newType: ChartTypeId) => {\n if (onChartTypeChange) {\n onChartTypeChange(newType);\n } else {\n setInternalType(newType);\n }\n };\n\n // Get chart metadata\n const chartMeta = CHART_REGISTRY[activeType];\n\n // Render appropriate chart\n const renderChart = () => {\n if (!validation.isValid) {\n return (\n <div className=\"ds-chart__invalid\">\n <DataStateIndicator\n state=\"INSUFFICIENT_SAMPLE\"\n variant=\"full\"\n details={{\n message: validation.errors[0],\n sampleSize: data.length,\n requiredSize: chartMeta?.contract.minDataPoints || 0,\n }}\n />\n </div>\n );\n }\n\n const xKey = dimensions[0]?.key || 'x';\n\n switch (activeType) {\n case 'line':\n case 'smooth_line':\n return renderLineChart(xKey, activeType === 'smooth_line');\n\n case 'area':\n case 'stacked_area':\n case 'area_100pct':\n return renderAreaChart(xKey, activeType);\n\n case 'bar':\n case 'stacked_bar':\n return renderBarChart(xKey, activeType, 'horizontal');\n\n case 'column':\n case 'stacked_column':\n case 'column_100pct':\n return renderBarChart(xKey, activeType, 'vertical');\n\n case 'pie':\n case 'donut':\n return renderPieChart(xKey, activeType === 'donut');\n\n case 'histogram':\n return renderHistogram();\n\n default:\n return (\n <div className=\"ds-chart__unsupported\">\n Chart type \"{activeType}\" is not yet implemented\n </div>\n );\n }\n };\n\n // Line Chart Renderer\n const renderLineChart = (xKey: string, smooth: boolean) => (\n <ResponsiveContainer width=\"100%\" height={height}>\n <RechartsLine data={data} margin={{ top: 5, right: 20, left: 0, bottom: 5 }}>\n {grid && <CartesianGrid strokeDasharray=\"3 3\" vertical={false} />}\n <XAxis\n dataKey={xKey}\n tick={{ fontSize: 12 }}\n tickLine={false}\n axisLine={{ strokeWidth: 1 }}\n />\n <YAxis tick={{ fontSize: 12 }} tickLine={false} axisLine={false} width={40} />\n <Tooltip\n contentStyle={{\n background: 'var(--glass-elevated)',\n border: '1px solid var(--glass-border)',\n }}\n />\n {showLegend && measures.length > 1 && <Legend />}\n {measures.map((measure, idx) => (\n <Line\n key={measure.key}\n type={smooth ? 'monotone' : 'linear'}\n dataKey={measure.key}\n name={measure.label || measure.key}\n stroke={getColor(idx, measure.color)}\n strokeWidth={2}\n dot={true}\n activeDot={{ r: 6 }}\n />\n ))}\n </RechartsLine>\n </ResponsiveContainer>\n );\n\n // Area Chart Renderer\n const renderAreaChart = (xKey: string, type: ChartTypeId) => {\n const isStacked = type === 'stacked_area' || type === 'area_100pct';\n const is100Pct = type === 'area_100pct';\n\n // For 100% stacked, normalize data\n const chartData = is100Pct ? normalizeData(data, measures) : data;\n\n return (\n <ResponsiveContainer width=\"100%\" height={height}>\n <RechartsArea data={chartData} margin={{ top: 5, right: 20, left: 0, bottom: 5 }}>\n {grid && <CartesianGrid strokeDasharray=\"3 3\" vertical={false} />}\n <XAxis\n dataKey={xKey}\n tick={{ fontSize: 12 }}\n tickLine={false}\n axisLine={{ strokeWidth: 1 }}\n />\n <YAxis\n tick={{ fontSize: 12 }}\n tickLine={false}\n axisLine={false}\n width={40}\n domain={is100Pct ? [0, 100] : undefined}\n tickFormatter={is100Pct ? (v) => `${v}%` : undefined}\n />\n <Tooltip\n contentStyle={{\n background: 'var(--glass-elevated)',\n border: '1px solid var(--glass-border)',\n }}\n />\n {showLegend && <Legend />}\n {measures.map((measure, idx) => (\n <Area\n key={measure.key}\n type=\"monotone\"\n dataKey={measure.key}\n name={measure.label || measure.key}\n stroke={getColor(idx, measure.color)}\n fill={getColor(idx, measure.color)}\n fillOpacity={0.3}\n stackId={isStacked ? 'stack' : undefined}\n />\n ))}\n </RechartsArea>\n </ResponsiveContainer>\n );\n };\n\n // Bar/Column Chart Renderer\n const renderBarChart = (xKey: string, type: ChartTypeId, layout: 'horizontal' | 'vertical') => {\n const isStacked = type.includes('stacked') || type.includes('100pct');\n const is100Pct = type.includes('100pct');\n const isHorizontal = layout === 'horizontal';\n\n const chartData = is100Pct ? normalizeData(data, measures) : data;\n\n return (\n <ResponsiveContainer width=\"100%\" height={height}>\n <RechartsBar\n data={chartData}\n layout={isHorizontal ? 'vertical' : 'horizontal'}\n margin={{ top: 5, right: 20, left: isHorizontal ? 80 : 0, bottom: 5 }}\n >\n {grid && (\n <CartesianGrid\n strokeDasharray=\"3 3\"\n horizontal={!isHorizontal}\n vertical={isHorizontal}\n />\n )}\n {isHorizontal ? (\n <>\n <XAxis\n type=\"number\"\n tick={{ fontSize: 12 }}\n tickLine={false}\n axisLine={false}\n domain={is100Pct ? [0, 100] : undefined}\n tickFormatter={is100Pct ? (v) => `${v}%` : undefined}\n />\n <YAxis\n type=\"category\"\n dataKey={xKey}\n tick={{ fontSize: 12 }}\n tickLine={false}\n axisLine={false}\n width={80}\n />\n </>\n ) : (\n <>\n <XAxis\n dataKey={xKey}\n tick={{ fontSize: 12 }}\n tickLine={false}\n axisLine={{ strokeWidth: 1 }}\n />\n <YAxis\n tick={{ fontSize: 12 }}\n tickLine={false}\n axisLine={false}\n width={40}\n domain={is100Pct ? [0, 100] : undefined}\n tickFormatter={is100Pct ? (v) => `${v}%` : undefined}\n />\n </>\n )}\n <Tooltip\n contentStyle={{\n background: 'var(--glass-elevated)',\n border: '1px solid var(--glass-border)',\n }}\n />\n {showLegend && measures.length > 1 && <Legend />}\n {measures.map((measure, idx) => (\n <Bar\n key={measure.key}\n dataKey={measure.key}\n name={measure.label || measure.key}\n fill={getColor(idx, measure.color)}\n stackId={isStacked ? 'stack' : undefined}\n radius={isStacked ? undefined : [4, 4, 0, 0]}\n />\n ))}\n </RechartsBar>\n </ResponsiveContainer>\n );\n };\n\n // Pie/Donut Chart Renderer\n const renderPieChart = (nameKey: string, isDonut: boolean) => {\n const valueKey = measures[0]?.key || 'value';\n\n return (\n <ResponsiveContainer width=\"100%\" height={height}>\n <RechartsPie>\n <Pie\n data={data}\n dataKey={valueKey}\n nameKey={nameKey}\n cx=\"50%\"\n cy=\"50%\"\n innerRadius={isDonut ? '50%' : 0}\n outerRadius=\"80%\"\n label={({ name, percent }) => `${name}: ${((percent ?? 0) * 100).toFixed(0)}%`}\n labelLine={false}\n >\n {data.map((_, idx) => (\n <Cell key={`cell-${idx}`} fill={getColor(idx)} />\n ))}\n </Pie>\n <Tooltip\n contentStyle={{\n background: 'var(--glass-elevated)',\n border: '1px solid var(--glass-border)',\n }}\n />\n {showLegend && <Legend />}\n </RechartsPie>\n </ResponsiveContainer>\n );\n };\n\n // Histogram Renderer\n const renderHistogram = () => {\n const valueKey = measures[0]?.key || 'value';\n const binKey = dimensions[0]?.key || 'bin';\n\n return (\n <ResponsiveContainer width=\"100%\" height={height}>\n <RechartsBar data={data} margin={{ top: 5, right: 20, left: 0, bottom: 5 }}>\n {grid && <CartesianGrid strokeDasharray=\"3 3\" vertical={false} />}\n <XAxis\n dataKey={binKey}\n tick={{ fontSize: 12 }}\n tickLine={false}\n axisLine={{ strokeWidth: 1 }}\n />\n <YAxis tick={{ fontSize: 12 }} tickLine={false} axisLine={false} width={40} />\n <Tooltip\n contentStyle={{\n background: 'var(--glass-elevated)',\n border: '1px solid var(--glass-border)',\n }}\n />\n <Bar dataKey={valueKey} fill={getColor(0)} radius={[4, 4, 0, 0]} />\n </RechartsBar>\n </ResponsiveContainer>\n );\n };\n\n // Normalize data for 100% stacked charts\n const normalizeData = (sourceData: T[], sourceMeasures: ChartMeasure[]): T[] => {\n return sourceData.map((row) => {\n const total = sourceMeasures.reduce((sum, m) => {\n const val = row[m.key];\n return sum + (typeof val === 'number' ? val : 0);\n }, 0);\n\n if (total === 0) return row;\n\n const normalized = { ...row } as T;\n sourceMeasures.forEach((m) => {\n const val = row[m.key];\n if (typeof val === 'number') {\n (normalized as Record<string, unknown>)[m.key] = (val / total) * 100;\n }\n });\n return normalized;\n });\n };\n\n return (\n <div className={clsx('ds-chart', className)}>\n {/* Header */}\n {(title || subtitle || allowSwitching) && (\n <header className=\"ds-chart__header\">\n <div className=\"ds-chart__header-text\">\n {title && <h4 className=\"ds-chart__title\">{title}</h4>}\n {subtitle && <p className=\"ds-chart__subtitle\">{subtitle}</p>}\n </div>\n <div className=\"ds-chart__header-actions\">\n {features.showMethodology && data.length > 0 && (\n <DataCoverageBadge\n sampleSize={data.length}\n requiredSize={chartMeta?.contract.minDataPoints || 0}\n size=\"sm\"\n />\n )}\n {allowSwitching && resolvedAllowedTypes.length > 0 && (\n <ChartSwitchControl\n currentType={activeType}\n allowedTypes={[activeType, ...resolvedAllowedTypes]}\n onTypeChange={handleTypeChange}\n />\n )}\n </div>\n </header>\n )}\n\n {/* Warnings */}\n {validation.warnings.length > 0 && (\n <div className=\"ds-chart__warnings\">\n {validation.warnings.map((warning, idx) => (\n <div key={idx} className=\"ds-chart__warning\">\n {warning}\n </div>\n ))}\n </div>\n )}\n\n {/* Chart */}\n <div className=\"ds-chart__body\" style={{ height }}>\n {renderChart()}\n </div>\n </div>\n );\n}\n\nChart.displayName = 'Chart';\n","import { useMemo } from 'react';\nimport {\n RadarChart,\n PolarGrid,\n PolarAngleAxis,\n PolarRadiusAxis,\n Radar,\n Legend,\n Tooltip,\n} from 'recharts';\nimport clsx from 'clsx';\nimport { useReportMode } from '../../report-engine';\nimport { DataCoverageBadge } from '../DataCoverageBadge';\nimport { DataStateIndicator } from '../DataStateIndicator';\nimport { ConfidenceIndicator } from '../ConfidenceIndicator';\nimport './MBTIRadar.css';\n\n/**\n * MBTI dimension scores representing preference strengths.\n * Values should be 0-100 where 50 is neutral.\n */\nexport interface MBTIDimensions {\n /** Extraversion (0) vs Introversion (100) */\n EI: number;\n /** Sensing (0) vs Intuition (100) */\n SN: number;\n /** Thinking (0) vs Feeling (100) */\n TF: number;\n /** Judging (0) vs Perceiving (100) */\n JP: number;\n}\n\nexport interface MBTIRadarProps {\n /** MBTI dimension scores */\n dimensions: MBTIDimensions;\n /** Sample size for confidence calculation */\n sampleSize: number;\n /** Optional comparison dimensions (e.g., benchmark) */\n comparison?: MBTIDimensions;\n /** Chart title */\n title?: string;\n /** Chart subtitle */\n subtitle?: string;\n /** Chart size */\n size?: number;\n /** Show dimension labels */\n showLabels?: boolean;\n /** Show values on hover */\n showValues?: boolean;\n /** Minimum sample size (default: 20) */\n minSampleSize?: number;\n /** Confidence score (0-100) */\n confidence?: number;\n /** Additional CSS class */\n className?: string;\n}\n\ninterface RadarDataPoint {\n dimension: string;\n fullName: string;\n value: number;\n comparison?: number;\n leftLabel: string;\n rightLabel: string;\n}\n\nconst DIMENSION_LABELS = {\n EI: { left: 'Extraversion', right: 'Introversion', full: 'E/I' },\n SN: { left: 'Sensing', right: 'Intuition', full: 'S/N' },\n TF: { left: 'Thinking', right: 'Feeling', full: 'T/F' },\n JP: { left: 'Judging', right: 'Perceiving', full: 'J/P' },\n} as const;\n\n/**\n * MBTIRadar visualizes personality dimension scores as a radar chart.\n * Requires minimum 20 samples for meaningful visualization.\n *\n * Each dimension is scored 0-100:\n * - EI: 0 = Extraversion, 100 = Introversion\n * - SN: 0 = Sensing, 100 = Intuition\n * - TF: 0 = Thinking, 100 = Feeling\n * - JP: 0 = Judging, 100 = Perceiving\n */\nexport function MBTIRadar({\n dimensions,\n sampleSize,\n comparison,\n title,\n subtitle,\n size = 300,\n showLabels = true,\n showValues = true,\n minSampleSize = 20,\n confidence,\n className,\n}: MBTIRadarProps) {\n const { features } = useReportMode();\n const isValid = sampleSize >= minSampleSize;\n\n const radarData = useMemo<RadarDataPoint[]>(() => {\n return (Object.keys(dimensions) as Array<keyof MBTIDimensions>).map((key) => ({\n dimension: DIMENSION_LABELS[key].full,\n fullName: `${DIMENSION_LABELS[key].left} vs ${DIMENSION_LABELS[key].right}`,\n value: dimensions[key],\n comparison: comparison?.[key],\n leftLabel: DIMENSION_LABELS[key].left,\n rightLabel: DIMENSION_LABELS[key].right,\n }));\n }, [dimensions, comparison]);\n\n // Calculate derived MBTI type from dimensions\n const derivedType = useMemo(() => {\n const e = dimensions.EI < 50 ? 'E' : 'I';\n const s = dimensions.SN < 50 ? 'S' : 'N';\n const t = dimensions.TF < 50 ? 'T' : 'F';\n const j = dimensions.JP < 50 ? 'J' : 'P';\n return `${e}${s}${t}${j}`;\n }, [dimensions]);\n\n if (!isValid) {\n return (\n <div className={clsx('ds-mbti-radar', 'ds-mbti-radar--invalid', className)}>\n {title && <h4 className=\"ds-mbti-radar__title\">{title}</h4>}\n <div className=\"ds-mbti-radar__empty\">\n <DataStateIndicator\n state=\"INSUFFICIENT_SAMPLE\"\n variant=\"full\"\n details={{\n message: 'MBTI analysis requires sufficient sample size',\n sampleSize,\n requiredSize: minSampleSize,\n }}\n />\n </div>\n </div>\n );\n }\n\n const CustomTooltip = ({\n active,\n payload,\n }: {\n active?: boolean;\n payload?: Array<{ payload: RadarDataPoint; value: number; name: string }>;\n }) => {\n if (!active || !payload?.length) return null;\n const data = payload[0].payload;\n return (\n <div className=\"ds-mbti-radar__tooltip\">\n <p className=\"ds-mbti-radar__tooltip-title\">{data.fullName}</p>\n <p className=\"ds-mbti-radar__tooltip-value\">\n {data.leftLabel}: {100 - data.value}%\n </p>\n <p className=\"ds-mbti-radar__tooltip-value\">\n {data.rightLabel}: {data.value}%\n </p>\n {data.comparison !== undefined && (\n <p className=\"ds-mbti-radar__tooltip-comparison\">Benchmark: {data.comparison}%</p>\n )}\n </div>\n );\n };\n\n return (\n <div className={clsx('ds-mbti-radar', className)}>\n {(title || subtitle) && (\n <header className=\"ds-mbti-radar__header\">\n <div className=\"ds-mbti-radar__header-text\">\n {title && <h4 className=\"ds-mbti-radar__title\">{title}</h4>}\n {subtitle && <p className=\"ds-mbti-radar__subtitle\">{subtitle}</p>}\n </div>\n <div className=\"ds-mbti-radar__header-badges\">\n {features.showConfidenceScores && confidence !== undefined && (\n <ConfidenceIndicator score={confidence} size=\"sm\" />\n )}\n {features.showMethodology && (\n <DataCoverageBadge sampleSize={sampleSize} requiredSize={minSampleSize} size=\"sm\" />\n )}\n </div>\n </header>\n )}\n\n <div className=\"ds-mbti-radar__type-badge\">\n <span className=\"ds-mbti-radar__type-label\">Derived Type</span>\n <span className=\"ds-mbti-radar__type-value\">{derivedType}</span>\n </div>\n\n <div className=\"ds-mbti-radar__chart\" style={{ width: size, height: size }}>\n <RadarChart cx=\"50%\" cy=\"50%\" outerRadius=\"70%\" width={size} height={size} data={radarData}>\n <PolarGrid stroke=\"var(--glass-border)\" />\n <PolarAngleAxis\n dataKey=\"dimension\"\n tick={{ fill: 'var(--text-secondary)', fontSize: 12 }}\n />\n <PolarRadiusAxis\n angle={45}\n domain={[0, 100]}\n tick={{ fill: 'var(--text-tertiary)', fontSize: 10 }}\n tickCount={5}\n />\n <Radar\n name=\"Profile\"\n dataKey=\"value\"\n stroke=\"var(--brand-pink)\"\n fill=\"var(--brand-pink)\"\n fillOpacity={0.3}\n strokeWidth={2}\n />\n {comparison && (\n <Radar\n name=\"Benchmark\"\n dataKey=\"comparison\"\n stroke=\"var(--brand-yellow)\"\n fill=\"var(--brand-yellow)\"\n fillOpacity={0.1}\n strokeWidth={2}\n strokeDasharray=\"5 5\"\n />\n )}\n {showValues && <Tooltip content={<CustomTooltip />} />}\n {comparison && <Legend />}\n </RadarChart>\n </div>\n\n {showLabels && (\n <div className=\"ds-mbti-radar__dimensions\">\n {radarData.map((d) => (\n <div key={d.dimension} className=\"ds-mbti-radar__dimension\">\n <span className=\"ds-mbti-radar__dimension-left\">{d.leftLabel}</span>\n <div className=\"ds-mbti-radar__dimension-bar\">\n <div className=\"ds-mbti-radar__dimension-fill\" style={{ width: `${d.value}%` }} />\n <div className=\"ds-mbti-radar__dimension-marker\" style={{ left: `${d.value}%` }} />\n </div>\n <span className=\"ds-mbti-radar__dimension-right\">{d.rightLabel}</span>\n </div>\n ))}\n </div>\n )}\n </div>\n );\n}\n\nMBTIRadar.displayName = 'MBTIRadar';\n","import { useMemo } from 'react';\nimport clsx from 'clsx';\nimport type { MBTIType } from '../../report-engine/types';\nimport { useReportMode } from '../../report-engine';\nimport { DataCoverageBadge } from '../DataCoverageBadge';\nimport { DataStateIndicator } from '../DataStateIndicator';\nimport { ConfidenceIndicator } from '../ConfidenceIndicator';\nimport { Tooltip } from '../Tooltip/Tooltip';\nimport './MBTITypeGrid.css';\n\nexport interface MBTITypeCount {\n /** MBTI type */\n type: MBTIType;\n /** Count of individuals with this type */\n count: number;\n /** Optional response rate for this type */\n responseRate?: number;\n}\n\nexport interface MBTITypeGridProps {\n /** Distribution of MBTI types */\n data: MBTITypeCount[];\n /** Total sample size (sum of all counts) */\n sampleSize?: number;\n /** Chart title */\n title?: string;\n /** Chart subtitle */\n subtitle?: string;\n /** Show percentage labels */\n showPercentages?: boolean;\n /** Show count labels */\n showCounts?: boolean;\n /** Highlight types above this threshold (percentage) */\n highlightThreshold?: number;\n /** Minimum sample size (default: 50) */\n minSampleSize?: number;\n /** Confidence score (0-100) */\n confidence?: number;\n /** Click handler for type selection */\n onTypeClick?: (type: MBTIType) => void;\n /** Currently selected type */\n selectedType?: MBTIType;\n /** Additional CSS class */\n className?: string;\n}\n\n// MBTI type organized in the standard 4x4 grid\nconst MBTI_GRID: MBTIType[][] = [\n ['ISTJ', 'ISFJ', 'INFJ', 'INTJ'],\n ['ISTP', 'ISFP', 'INFP', 'INTP'],\n ['ESTP', 'ESFP', 'ENFP', 'ENTP'],\n ['ESTJ', 'ESFJ', 'ENFJ', 'ENTJ'],\n];\n\n// Type descriptions for tooltips\nconst TYPE_DESCRIPTIONS: Record<MBTIType, string> = {\n ISTJ: 'The Inspector - Practical, reliable, systematic',\n ISFJ: 'The Protector - Caring, supportive, traditional',\n INFJ: 'The Advocate - Insightful, principled, compassionate',\n INTJ: 'The Architect - Strategic, independent, determined',\n ISTP: 'The Virtuoso - Observant, practical, analytical',\n ISFP: 'The Adventurer - Artistic, sensitive, exploratory',\n INFP: 'The Mediator - Idealistic, empathetic, creative',\n INTP: 'The Logician - Inventive, logical, objective',\n ESTP: 'The Entrepreneur - Energetic, pragmatic, observant',\n ESFP: 'The Entertainer - Spontaneous, energetic, friendly',\n ENFP: 'The Campaigner - Enthusiastic, creative, sociable',\n ENTP: 'The Debater - Clever, curious, innovative',\n ESTJ: 'The Executive - Organized, logical, assertive',\n ESFJ: 'The Consul - Caring, sociable, traditional',\n ENFJ: 'The Protagonist - Charismatic, empathetic, organized',\n ENTJ: 'The Commander - Strategic, efficient, energetic',\n};\n\n// Column header labels\nconst COLUMN_LABELS = ['ST', 'SF', 'NF', 'NT'];\nconst ROW_LABELS = ['I-J', 'I-P', 'E-P', 'E-J'];\n\n/**\n * MBTITypeGrid displays the distribution of all 16 MBTI types in a 4x4 grid.\n * Requires minimum 50 samples for meaningful visualization.\n */\nexport function MBTITypeGrid({\n data,\n sampleSize: propSampleSize,\n title,\n subtitle,\n showPercentages = true,\n showCounts = true,\n highlightThreshold,\n minSampleSize = 50,\n confidence,\n onTypeClick,\n selectedType,\n className,\n}: MBTITypeGridProps) {\n const { features } = useReportMode();\n\n // Create a map of type to data\n const typeMap = useMemo(() => {\n const map = new Map<MBTIType, MBTITypeCount>();\n for (const item of data) {\n map.set(item.type, item);\n }\n return map;\n }, [data]);\n\n // Calculate total sample size\n const totalSampleSize = propSampleSize ?? data.reduce((sum, d) => sum + d.count, 0);\n const isValid = totalSampleSize >= minSampleSize;\n\n // Find max count for scaling\n const maxCount = useMemo(() => Math.max(...data.map((d) => d.count), 1), [data]);\n\n // Calculate percentages\n const getPercentage = (count: number) => {\n return totalSampleSize > 0 ? ((count / totalSampleSize) * 100).toFixed(1) : '0.0';\n };\n\n // Get cell intensity for heatmap effect\n const getIntensity = (count: number) => {\n if (maxCount === 0) return 0;\n return (count / maxCount) * 100;\n };\n\n // Check if type should be highlighted\n const isHighlighted = (type: MBTIType) => {\n if (!highlightThreshold) return false;\n const item = typeMap.get(type);\n if (!item) return false;\n const percentage = (item.count / totalSampleSize) * 100;\n return percentage >= highlightThreshold;\n };\n\n if (!isValid) {\n return (\n <div className={clsx('ds-mbti-type-grid', 'ds-mbti-type-grid--invalid', className)}>\n {title && <h4 className=\"ds-mbti-type-grid__title\">{title}</h4>}\n <div className=\"ds-mbti-type-grid__empty\">\n <DataStateIndicator\n state=\"INSUFFICIENT_SAMPLE\"\n variant=\"full\"\n details={{\n message: 'MBTI distribution analysis requires sufficient sample size',\n sampleSize: totalSampleSize,\n requiredSize: minSampleSize,\n }}\n />\n </div>\n </div>\n );\n }\n\n return (\n <div className={clsx('ds-mbti-type-grid', className)}>\n {(title || subtitle) && (\n <header className=\"ds-mbti-type-grid__header\">\n <div className=\"ds-mbti-type-grid__header-text\">\n {title && <h4 className=\"ds-mbti-type-grid__title\">{title}</h4>}\n {subtitle && <p className=\"ds-mbti-type-grid__subtitle\">{subtitle}</p>}\n </div>\n <div className=\"ds-mbti-type-grid__header-badges\">\n {features.showConfidenceScores && confidence !== undefined && (\n <ConfidenceIndicator score={confidence} size=\"sm\" />\n )}\n {features.showMethodology && (\n <DataCoverageBadge\n sampleSize={totalSampleSize}\n requiredSize={minSampleSize}\n size=\"sm\"\n />\n )}\n </div>\n </header>\n )}\n\n <div className=\"ds-mbti-type-grid__container\">\n {/* Column Headers */}\n <div className=\"ds-mbti-type-grid__column-headers\">\n <div className=\"ds-mbti-type-grid__corner\" />\n {COLUMN_LABELS.map((label) => (\n <div key={label} className=\"ds-mbti-type-grid__column-header\">\n {label}\n </div>\n ))}\n </div>\n\n {/* Grid Rows */}\n {MBTI_GRID.map((row, rowIndex) => (\n <div key={rowIndex} className=\"ds-mbti-type-grid__row\">\n <div className=\"ds-mbti-type-grid__row-header\">{ROW_LABELS[rowIndex]}</div>\n {row.map((type) => {\n const typeData = typeMap.get(type);\n const count = typeData?.count ?? 0;\n const percentage = getPercentage(count);\n const intensity = getIntensity(count);\n const highlighted = isHighlighted(type);\n const selected = selectedType === type;\n\n return (\n <Tooltip\n key={type}\n content={\n <div className=\"ds-mbti-type-grid__tooltip-content\">\n <strong>{type}</strong>\n <p>{TYPE_DESCRIPTIONS[type]}</p>\n <p>Count: {count.toLocaleString()}</p>\n <p>Percentage: {percentage}%</p>\n {typeData?.responseRate !== undefined && (\n <p>Response Rate: {typeData.responseRate.toFixed(1)}%</p>\n )}\n </div>\n }\n >\n <button\n type=\"button\"\n className={clsx(\n 'ds-mbti-type-grid__cell',\n highlighted && 'ds-mbti-type-grid__cell--highlighted',\n selected && 'ds-mbti-type-grid__cell--selected',\n onTypeClick && 'ds-mbti-type-grid__cell--clickable',\n )}\n onClick={() => onTypeClick?.(type)}\n disabled={!onTypeClick}\n style={\n {\n '--cell-intensity': `${intensity}%`,\n } as React.CSSProperties\n }\n >\n <span className=\"ds-mbti-type-grid__cell-type\">{type}</span>\n {showCounts && (\n <span className=\"ds-mbti-type-grid__cell-count\">\n {count.toLocaleString()}\n </span>\n )}\n {showPercentages && (\n <span className=\"ds-mbti-type-grid__cell-percentage\">{percentage}%</span>\n )}\n </button>\n </Tooltip>\n );\n })}\n </div>\n ))}\n </div>\n\n {/* Legend */}\n <div className=\"ds-mbti-type-grid__legend\">\n <div className=\"ds-mbti-type-grid__legend-item\">\n <span className=\"ds-mbti-type-grid__legend-bar ds-mbti-type-grid__legend-bar--gradient\" />\n <span className=\"ds-mbti-type-grid__legend-label\">Distribution density</span>\n </div>\n {highlightThreshold && (\n <div className=\"ds-mbti-type-grid__legend-item\">\n <span className=\"ds-mbti-type-grid__legend-bar ds-mbti-type-grid__legend-bar--highlight\" />\n <span className=\"ds-mbti-type-grid__legend-label\">\n {'>='}\n {highlightThreshold}% of sample\n </span>\n </div>\n )}\n </div>\n </div>\n );\n}\n\nMBTITypeGrid.displayName = 'MBTITypeGrid';\n"]}