@peak-ai/canvas 1.4.38-rc.8 → 1.4.39
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.
- package/GrapesjsCanvas.d.ts +2 -1
- package/GrapesjsCanvas.js +2 -2
- package/GrapesjsCanvas.js.map +1 -1
- package/package.json +2 -2
- package/plugins/helpers/render-components.js +6 -7
- package/plugins/helpers/render-components.js.map +1 -1
- package/shadcn/components/ui/chart.js +2 -2
- package/shadcn/components/ui/chart.js.map +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import _extends from"@babel/runtime/helpers/extends";import _objectWithoutPropertiesLoose from"@babel/runtime/helpers/objectWithoutPropertiesLoose";var _excluded=["id","className","children","config","isEditable"];import*as React from"react";import*as RechartsPrimitive from"recharts";import{cn}from"../../utils"
|
|
2
|
-
import{jsx as _jsx,jsxs as _jsxs}from"react/jsx-runtime";var THEMES={light:"",dark:".dark"};var ChartContext=/*#__PURE__*/React.createContext(null);function useChart(){var context=React.useContext(ChartContext);if(!context){throw new Error("useChart must be used within a <ChartContainer />")}return context}function ChartContainer(_ref){var id=_ref.id,className=_ref.className,children=_ref.children,config=_ref.config,isEditable=_ref.isEditable,props=_objectWithoutPropertiesLoose(_ref,_excluded);var uniqueId=id||"id-"+Math.random().toString(36).substring(2,9);var chartId="chart-"+uniqueId;
|
|
1
|
+
import _extends from"@babel/runtime/helpers/extends";import _objectWithoutPropertiesLoose from"@babel/runtime/helpers/objectWithoutPropertiesLoose";var _excluded=["id","className","children","config","isEditable"];import*as React from"react";import*as RechartsPrimitive from"recharts";import{cn}from"../../utils";// Format: { THEME_NAME: CSS_SELECTOR }
|
|
2
|
+
import{jsx as _jsx,jsxs as _jsxs}from"react/jsx-runtime";var THEMES={light:"",dark:".dark"};var ChartContext=/*#__PURE__*/React.createContext(null);function useChart(){var context=React.useContext(ChartContext);if(!context){throw new Error("useChart must be used within a <ChartContainer />")}return context}function ChartContainer(_ref){var id=_ref.id,className=_ref.className,children=_ref.children,config=_ref.config,isEditable=_ref.isEditable,props=_objectWithoutPropertiesLoose(_ref,_excluded);var uniqueId=id||"id-"+Math.random().toString(36).substring(2,9);var chartId="chart-"+uniqueId;return/*#__PURE__*/_jsx(ChartContext.Provider,{value:{config:config},children:/*#__PURE__*/_jsxs("div",_extends({"data-slot":"chart","data-chart":chartId,className:cn("[&_.recharts-cartesian-axis-tick_text]:fill-muted-foreground [&_.recharts-cartesian-grid_line[stroke='#ccc']]:stroke-border/50 [&_.recharts-curve.recharts-tooltip-cursor]:stroke-border [&_.recharts-polar-grid_[stroke='#ccc']]:stroke-border [&_.recharts-radial-bar-background-sector]:fill-muted [&_.recharts-rectangle.recharts-tooltip-cursor]:fill-muted [&_.recharts-reference-line_[stroke='#ccc']]:stroke-border flex aspect-video justify-center text-xs [&_.recharts-dot[stroke='#fff']]:stroke-transparent [&_.recharts-layer]:outline-hidden [&_.recharts-sector]:outline-hidden [&_.recharts-sector[stroke='#fff']]:stroke-transparent [&_.recharts-surface]:outline-hidden",className),contentEditable:isEditable},props,{children:[/*#__PURE__*/_jsx(ChartStyle,{id:chartId,config:config}),/*#__PURE__*/_jsx(RechartsPrimitive.ResponsiveContainer,{children:children})]}))})}function ChartStyle(_ref2){var id=_ref2.id,config=_ref2.config;var colorConfig=Object.entries(config).filter(function(_ref3){var conf=_ref3[1];return conf.theme||conf.color});if(!colorConfig.length){return null}return/*#__PURE__*/_jsx("style",{dangerouslySetInnerHTML:{__html:Object.entries(THEMES).map(function(_ref4){var theme=_ref4[0],prefix=_ref4[1];return"\n"+prefix+" [data-chart="+id+"] {\n"+colorConfig.map(function(_ref5){var _itemConfig$theme;var key=_ref5[0],itemConfig=_ref5[1];var color=((_itemConfig$theme=itemConfig.theme)==null?void 0:_itemConfig$theme[theme])||itemConfig.color;return color?" --color-"+key+": "+color+";":null}).join("\n")+"\n}\n"}).join("\n")}})}var ChartTooltip=RechartsPrimitive.Tooltip;function ChartTooltipContent(_ref6){var active=_ref6.active,payload=_ref6.payload,className=_ref6.className,_ref6$indicator=_ref6.indicator,indicator=_ref6$indicator===void 0?"dot":_ref6$indicator,_ref6$hideLabel=_ref6.hideLabel,hideLabel=_ref6$hideLabel===void 0?false:_ref6$hideLabel,_ref6$hideIndicator=_ref6.hideIndicator,hideIndicator=_ref6$hideIndicator===void 0?false:_ref6$hideIndicator,label=_ref6.label,labelFormatter=_ref6.labelFormatter,labelClassName=_ref6.labelClassName,formatter=_ref6.formatter,color=_ref6.color,nameKey=_ref6.nameKey,labelKey=_ref6.labelKey;var _useChart=useChart(),config=_useChart.config;var tooltipLabel=React.useMemo(function(){var _config;if(hideLabel||!(payload!=null&&payload.length)){return null}var item=payload[0];var key=""+(labelKey||(item==null?void 0:item.dataKey)||(item==null?void 0:item.name)||"value");var itemConfig=getPayloadConfigFromPayload(config,item,key);var value=!labelKey&&typeof label==="string"?((_config=config[label])==null?void 0:_config.label)||label:itemConfig==null?void 0:itemConfig.label;if(labelFormatter){return/*#__PURE__*/_jsx("div",{className:cn("font-medium",labelClassName),children:labelFormatter(value,payload)})}if(!value){return null}return/*#__PURE__*/_jsx("div",{className:cn("font-medium",labelClassName),children:value})},[label,labelFormatter,payload,hideLabel,labelClassName,config,labelKey]);if(!active||!(payload!=null&&payload.length)){return null}var nestLabel=payload.length===1&&indicator!=="dot";return/*#__PURE__*/_jsxs("div",{className:cn("border-border/50 bg-white grid min-w-[8rem] items-start gap-1.5 rounded-lg border px-2.5 py-1.5 text-xs shadow-xl",className),children:[!nestLabel?tooltipLabel:null,/*#__PURE__*/_jsx("div",{className:"grid gap-1.5",children:payload.map(function(item,index){var key=""+(nameKey||item.name||item.dataKey||"value");var itemConfig=getPayloadConfigFromPayload(config,item,key);var indicatorColor=color||item.payload.fill||item.color;return/*#__PURE__*/_jsx("div",{className:cn("[&>svg]:text-muted-foreground flex w-full flex-wrap items-stretch gap-2 [&>svg]:h-2.5 [&>svg]:w-2.5",indicator==="dot"&&"items-center"),children:formatter&&(item==null?void 0:item.value)!==undefined&&item.name?formatter(item.value,item.name,item,index,item.payload):/*#__PURE__*/_jsxs(React.Fragment,{children:[itemConfig!=null&&itemConfig.icon?/*#__PURE__*/_jsx(itemConfig.icon,{}):!hideIndicator&&/*#__PURE__*/_jsx("div",{className:cn("shrink-0 rounded-[2px] border-(--color-border) bg-(--color-bg)",{"h-2.5 w-2.5":indicator==="dot","w-1":indicator==="line","w-0 border-[1.5px] border-dashed bg-transparent":indicator==="dashed","my-0.5":nestLabel&&indicator==="dashed"}),style:{"--color-bg":indicatorColor,"--color-border":indicatorColor}}),/*#__PURE__*/_jsxs("div",{className:cn("flex flex-1 justify-between leading-none",nestLabel?"items-end":"items-center"),children:[/*#__PURE__*/_jsxs("div",{className:"grid gap-1.5",children:[nestLabel?tooltipLabel:null,/*#__PURE__*/_jsx("span",{className:"text-muted-foreground mr-2",children:(itemConfig==null?void 0:itemConfig.label)||item.name})]}),item.value&&/*#__PURE__*/_jsx("span",{className:"text-foreground font-mono font-medium tabular-nums",children:item.value.toLocaleString()})]})]})},item.dataKey+"-"+index)})})]})}var ChartLegend=RechartsPrimitive.Legend;function ChartLegendContent(_ref7){var className=_ref7.className,_ref7$hideIcon=_ref7.hideIcon,hideIcon=_ref7$hideIcon===void 0?false:_ref7$hideIcon,payload=_ref7.payload,_ref7$verticalAlign=_ref7.verticalAlign,verticalAlign=_ref7$verticalAlign===void 0?"bottom":_ref7$verticalAlign,nameKey=_ref7.nameKey;var _useChart2=useChart(),config=_useChart2.config;if(!(payload!=null&&payload.length)){return null}return/*#__PURE__*/_jsx("div",{className:cn("flex items-center justify-center gap-4",verticalAlign==="top"?"pb-3":"pt-3",className),children:payload.map(function(item,index){var key=""+(nameKey||"value");var itemConfig=getPayloadConfigFromPayload(config,item,key);return/*#__PURE__*/_jsxs("div",{className:cn("[&>svg]:text-muted-foreground flex items-center gap-1.5 [&>svg]:h-3 [&>svg]:w-3"),children:[itemConfig!=null&&itemConfig.icon&&!hideIcon?/*#__PURE__*/_jsx(itemConfig.icon,{}):/*#__PURE__*/_jsx("div",{className:"h-2 w-2 shrink-0 rounded-[2px]",style:{backgroundColor:item.color}}),itemConfig==null?void 0:itemConfig.label]},item.value+"-"+index)})})}// Helper to extract item config from a payload.
|
|
3
3
|
function getPayloadConfigFromPayload(config,payload,key){if(typeof payload!=="object"||payload===null){return undefined}var payloadPayload="payload"in payload&&typeof payload.payload==="object"&&payload.payload!==null?payload.payload:undefined;var configLabelKey=key;if(key in payload&&typeof payload[key]==="string"){configLabelKey=payload[key]}else if(payloadPayload&&key in payloadPayload&&typeof payloadPayload[key]==="string"){configLabelKey=payloadPayload[key]}return configLabelKey in config?config[configLabelKey]:config[key]}export{ChartContainer,ChartTooltip,ChartTooltipContent,ChartLegend,ChartLegendContent,ChartStyle};
|
|
4
4
|
//# sourceMappingURL=chart.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chart.js","names":["React","RechartsPrimitive","cn","ChartLoader","jsx","_jsx","jsxs","_jsxs","THEMES","light","dark","ChartContext","createContext","useChart","context","useContext","Error","ChartContainer","_ref","id","className","children","config","isEditable","props","_objectWithoutPropertiesLoose","_excluded","uniqueId","Math","random","toString","substring","chartId","containerRef","useRef","_React$useState","useState","isReady","setIsReady","useEffect","timeoutId","retryCount","maxRetries","checkDimensions","current","rect","getBoundingClientRect","computedStyle","window","getComputedStyle","hasValidDimensions","width","height","parseFloat","setTimeout","clearTimeout","Provider","value","_extends","ref","contentEditable","style","minWidth","minHeight","ChartStyle","flex","ResponsiveContainer","_ref2","colorConfig","Object","entries","filter","_ref3","conf","theme","color","length","dangerouslySetInnerHTML","__html","map","_ref4","prefix","_ref5","_itemConfig$theme","key","itemConfig","join","ChartTooltip","Tooltip","ChartTooltipContent","_ref6","active","payload","_ref6$indicator","indicator","_ref6$hideLabel","hideLabel","_ref6$hideIndicator","hideIndicator","label","labelFormatter","labelClassName","formatter","nameKey","labelKey","_useChart","tooltipLabel","useMemo","_config","item","dataKey","name","getPayloadConfigFromPayload","nestLabel","index","indicatorColor","fill","undefined","Fragment","icon","toLocaleString","ChartLegend","Legend","ChartLegendContent","_ref7","_ref7$hideIcon","hideIcon","_ref7$verticalAlign","verticalAlign","_useChart2","backgroundColor","payloadPayload","configLabelKey"],"sources":["../../../../src/shadcn/components/ui/chart.tsx"],"sourcesContent":["import * as React from 'react';\nimport * as RechartsPrimitive from 'recharts';\n\nimport { cn } from '../../utils';\nimport { ChartLoader } from './skeleton';\n\n// Format: { THEME_NAME: CSS_SELECTOR }\nconst THEMES = { light: '', dark: '.dark' } as const;\n\nexport type ChartConfig = {\n [k in string]: {\n label?: React.ReactNode;\n icon?: React.ComponentType;\n } & (\n | { color?: string; theme?: never }\n | { color?: never; theme: Record<keyof typeof THEMES, string> }\n );\n};\n\ntype ChartContextProps = {\n config: ChartConfig;\n};\n\nconst ChartContext = React.createContext<ChartContextProps | null>(null);\n\nfunction useChart() {\n const context = React.useContext(ChartContext);\n\n if (!context) {\n throw new Error('useChart must be used within a <ChartContainer />');\n }\n\n return context;\n}\n\nfunction ChartContainer({\n id,\n className,\n children,\n config,\n isEditable,\n ...props\n}: React.ComponentProps<'div'> & {\n config: ChartConfig;\n children: React.ComponentProps<typeof RechartsPrimitive.ResponsiveContainer>['children'];\n isEditable?: boolean;\n}) {\n const uniqueId = id || `id-${Math.random().toString(36).substring(2, 9)}`;\n const chartId = `chart-${uniqueId}`;\n const containerRef = React.useRef<HTMLDivElement>(null);\n const [isReady, setIsReady] = React.useState(false);\n\n React.useEffect(() => {\n let timeoutId: NodeJS.Timeout | null = null;\n let retryCount = 0;\n const maxRetries = 100;\n\n function checkDimensions() {\n if (!containerRef.current) {\n return;\n }\n\n const rect = containerRef.current.getBoundingClientRect();\n const computedStyle = window.getComputedStyle(containerRef.current);\n \n const hasValidDimensions = (\n rect.width >= 200 && rect.height >= 200 &&\n parseFloat(computedStyle.width) >= 200 && \n parseFloat(computedStyle.height) >= 200\n );\n\n if (hasValidDimensions) {\n setIsReady(true);\n } else if (retryCount < maxRetries) {\n retryCount = retryCount + 1;\n timeoutId = setTimeout(checkDimensions, 50);\n } else {\n setIsReady(true);\n }\n }\n\n timeoutId = setTimeout(checkDimensions, 200);\n\n return () => {\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n };\n }, []);\n\n return (\n <ChartContext.Provider value={{ config }}>\n <div\n ref={containerRef}\n data-slot=\"chart\"\n data-chart={chartId}\n className={cn(\n \"[&_.recharts-cartesian-axis-tick_text]:fill-muted-foreground [&_.recharts-cartesian-grid_line[stroke='#ccc']]:stroke-border/50 [&_.recharts-curve.recharts-tooltip-cursor]:stroke-border [&_.recharts-polar-grid_[stroke='#ccc']]:stroke-border [&_.recharts-radial-bar-background-sector]:fill-muted [&_.recharts-rectangle.recharts-tooltip-cursor]:fill-muted [&_.recharts-reference-line_[stroke='#ccc']]:stroke-border flex aspect-video justify-center text-xs [&_.recharts-dot[stroke='#fff']]:stroke-transparent [&_.recharts-layer]:outline-hidden [&_.recharts-sector]:outline-hidden [&_.recharts-sector[stroke='#fff']]:stroke-transparent [&_.recharts-surface]:outline-hidden\",\n className,\n )}\n contentEditable={isEditable}\n style={{ minWidth: '200px', minHeight: '200px', ...props.style }}\n {...props}\n >\n <ChartStyle id={chartId} config={config} />\n <div \n style={{ \n width: '100%', \n height: '100%', \n }}\n >\n <div style={{ flex: 1 }}>\n {isReady ? (\n <RechartsPrimitive.ResponsiveContainer \n width=\"100%\" \n height=\"100%\"\n >\n {children}\n </RechartsPrimitive.ResponsiveContainer>\n ) : (\n <ChartLoader />\n )}\n </div>\n </div>\n </div>\n </ChartContext.Provider>\n );\n}\n\nfunction ChartStyle({ id, config }: { id: string; config: ChartConfig }) {\n const colorConfig = Object.entries(config).filter(([, conf]) => conf.theme || conf.color);\n\n if (!colorConfig.length) {\n return null;\n }\n\n return (\n <style\n dangerouslySetInnerHTML={{\n __html: Object.entries(THEMES)\n .map(\n ([theme, prefix]) => `\n${prefix} [data-chart=${id}] {\n${colorConfig\n .map(([key, itemConfig]) => {\n const color = itemConfig.theme?.[theme as keyof typeof itemConfig.theme] || itemConfig.color;\n\n return color ? ` --color-${key}: ${color};` : null;\n })\n .join('\\n')}\n}\n`,\n )\n .join('\\n'),\n }}\n />\n );\n}\n\nconst ChartTooltip = RechartsPrimitive.Tooltip;\n\nfunction ChartTooltipContent({\n active,\n payload,\n className,\n indicator = 'dot',\n hideLabel = false,\n hideIndicator = false,\n label,\n labelFormatter,\n labelClassName,\n formatter,\n color,\n nameKey,\n labelKey,\n}: React.ComponentProps<typeof RechartsPrimitive.Tooltip> &\n React.ComponentProps<'div'> & {\n hideLabel?: boolean;\n hideIndicator?: boolean;\n indicator?: 'line' | 'dot' | 'dashed';\n nameKey?: string;\n labelKey?: string;\n }) {\n const { config } = useChart();\n\n const tooltipLabel = React.useMemo(() => {\n if (hideLabel || !payload?.length) {\n return null;\n }\n\n const [item] = payload;\n const key = `${labelKey || item?.dataKey || item?.name || 'value'}`;\n const itemConfig = getPayloadConfigFromPayload(config, item, key);\n const value =\n !labelKey && typeof label === 'string'\n ? config[label as keyof typeof config]?.label || label\n : itemConfig?.label;\n\n if (labelFormatter) {\n return (\n <div className={cn('font-medium', labelClassName)}>{labelFormatter(value, payload)}</div>\n );\n }\n\n if (!value) {\n return null;\n }\n\n return <div className={cn('font-medium', labelClassName)}>{value}</div>;\n }, [label, labelFormatter, payload, hideLabel, labelClassName, config, labelKey]);\n\n if (!active || !payload?.length) {\n return null;\n }\n\n const nestLabel = payload.length === 1 && indicator !== 'dot';\n\n return (\n <div\n className={cn(\n 'border-border/50 bg-white grid min-w-[8rem] items-start gap-1.5 rounded-lg border px-2.5 py-1.5 text-xs shadow-xl',\n className,\n )}\n >\n {!nestLabel ? tooltipLabel : null}\n <div className=\"grid gap-1.5\">\n {payload.map((item, index) => {\n const key = `${nameKey || item.name || item.dataKey || 'value'}`;\n const itemConfig = getPayloadConfigFromPayload(config, item, key);\n const indicatorColor = color || item.payload.fill || item.color;\n\n return (\n <div\n key={`${item.dataKey}-${index}`}\n className={cn(\n '[&>svg]:text-muted-foreground flex w-full flex-wrap items-stretch gap-2 [&>svg]:h-2.5 [&>svg]:w-2.5',\n indicator === 'dot' && 'items-center',\n )}\n >\n {formatter && item?.value !== undefined && item.name ? (\n formatter(item.value, item.name, item, index, item.payload)\n ) : (\n <React.Fragment>\n {itemConfig?.icon ? (\n <itemConfig.icon />\n ) : (\n !hideIndicator && (\n <div\n className={cn(\n 'shrink-0 rounded-[2px] border-(--color-border) bg-(--color-bg)',\n {\n 'h-2.5 w-2.5': indicator === 'dot',\n 'w-1': indicator === 'line',\n 'w-0 border-[1.5px] border-dashed bg-transparent':\n indicator === 'dashed',\n 'my-0.5': nestLabel && indicator === 'dashed',\n },\n )}\n style={\n {\n '--color-bg': indicatorColor,\n '--color-border': indicatorColor,\n } as React.CSSProperties\n }\n />\n )\n )}\n <div\n className={cn(\n 'flex flex-1 justify-between leading-none',\n nestLabel ? 'items-end' : 'items-center',\n )}\n >\n <div className=\"grid gap-1.5\">\n {nestLabel ? tooltipLabel : null}\n <span className=\"text-muted-foreground mr-2\">\n {itemConfig?.label || item.name}\n </span>\n </div>\n {item.value && (\n <span className=\"text-foreground font-mono font-medium tabular-nums\">\n {item.value.toLocaleString()}\n </span>\n )}\n </div>\n </React.Fragment>\n )}\n </div>\n );\n })}\n </div>\n </div>\n );\n}\n\nconst ChartLegend = RechartsPrimitive.Legend;\n\nfunction ChartLegendContent({\n className,\n hideIcon = false,\n payload,\n verticalAlign = 'bottom',\n nameKey,\n}: React.ComponentProps<'div'> &\n Pick<RechartsPrimitive.LegendProps, 'payload' | 'verticalAlign'> & {\n hideIcon?: boolean;\n nameKey?: string;\n }) {\n const { config } = useChart();\n\n if (!payload?.length) {\n return null;\n }\n\n return (\n <div\n className={cn(\n 'flex items-center justify-center gap-4',\n verticalAlign === 'top' ? 'pb-3' : 'pt-3',\n className,\n )}\n >\n {payload.map((item, index) => {\n const key = `${nameKey || 'value'}`;\n const itemConfig = getPayloadConfigFromPayload(config, item, key);\n\n return (\n <div\n key={`${item.value}-${index}`}\n className={cn(\n '[&>svg]:text-muted-foreground flex items-center gap-1.5 [&>svg]:h-3 [&>svg]:w-3',\n )}\n >\n {itemConfig?.icon && !hideIcon ? (\n <itemConfig.icon />\n ) : (\n <div\n className=\"h-2 w-2 shrink-0 rounded-[2px]\"\n style={{\n backgroundColor: item.color,\n }}\n />\n )}\n {itemConfig?.label}\n </div>\n );\n })}\n </div>\n );\n}\n\n// Helper to extract item config from a payload.\nfunction getPayloadConfigFromPayload(config: ChartConfig, payload: unknown, key: string) {\n if (typeof payload !== 'object' || payload === null) {\n return undefined;\n }\n\n const payloadPayload =\n 'payload' in payload && typeof payload.payload === 'object' && payload.payload !== null\n ? payload.payload\n : undefined;\n\n let configLabelKey: string = key;\n\n if (key in payload && typeof payload[key as keyof typeof payload] === 'string') {\n configLabelKey = payload[key as keyof typeof payload] as string;\n } else if (\n payloadPayload &&\n key in payloadPayload &&\n typeof payloadPayload[key as keyof typeof payloadPayload] === 'string'\n ) {\n configLabelKey = payloadPayload[key as keyof typeof payloadPayload] as string;\n }\n\n return configLabelKey in config ? config[configLabelKey] : config[key as keyof typeof config];\n}\n\nexport {\n ChartContainer,\n ChartTooltip,\n ChartTooltipContent,\n ChartLegend,\n ChartLegendContent,\n ChartStyle,\n};\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"chart.js","names":["React","RechartsPrimitive","cn","jsx","_jsx","jsxs","_jsxs","THEMES","light","dark","ChartContext","createContext","useChart","context","useContext","Error","ChartContainer","_ref","id","className","children","config","isEditable","props","_objectWithoutPropertiesLoose","_excluded","uniqueId","Math","random","toString","substring","chartId","Provider","value","_extends","contentEditable","ChartStyle","ResponsiveContainer","_ref2","colorConfig","Object","entries","filter","_ref3","conf","theme","color","length","dangerouslySetInnerHTML","__html","map","_ref4","prefix","_ref5","_itemConfig$theme","key","itemConfig","join","ChartTooltip","Tooltip","ChartTooltipContent","_ref6","active","payload","_ref6$indicator","indicator","_ref6$hideLabel","hideLabel","_ref6$hideIndicator","hideIndicator","label","labelFormatter","labelClassName","formatter","nameKey","labelKey","_useChart","tooltipLabel","useMemo","_config","item","dataKey","name","getPayloadConfigFromPayload","nestLabel","index","indicatorColor","fill","undefined","Fragment","icon","style","toLocaleString","ChartLegend","Legend","ChartLegendContent","_ref7","_ref7$hideIcon","hideIcon","_ref7$verticalAlign","verticalAlign","_useChart2","backgroundColor","payloadPayload","configLabelKey"],"sources":["../../../../src/shadcn/components/ui/chart.tsx"],"sourcesContent":["import * as React from 'react';\nimport * as RechartsPrimitive from 'recharts';\n\nimport { cn } from '../../utils';\n\n// Format: { THEME_NAME: CSS_SELECTOR }\nconst THEMES = { light: '', dark: '.dark' } as const;\n\nexport type ChartConfig = {\n [k in string]: {\n label?: React.ReactNode;\n icon?: React.ComponentType;\n } & (\n | { color?: string; theme?: never }\n | { color?: never; theme: Record<keyof typeof THEMES, string> }\n );\n};\n\ntype ChartContextProps = {\n config: ChartConfig;\n};\n\nconst ChartContext = React.createContext<ChartContextProps | null>(null);\n\nfunction useChart() {\n const context = React.useContext(ChartContext);\n\n if (!context) {\n throw new Error('useChart must be used within a <ChartContainer />');\n }\n\n return context;\n}\n\nfunction ChartContainer({\n id,\n className,\n children,\n config,\n isEditable,\n ...props\n}: React.ComponentProps<'div'> & {\n config: ChartConfig;\n children: React.ComponentProps<typeof RechartsPrimitive.ResponsiveContainer>['children'];\n isEditable?: boolean;\n}) {\n const uniqueId = id || `id-${Math.random().toString(36).substring(2, 9)}`;\n const chartId = `chart-${uniqueId}`;\n\n return (\n <ChartContext.Provider value={{ config }}>\n <div\n data-slot=\"chart\"\n data-chart={chartId}\n className={cn(\n \"[&_.recharts-cartesian-axis-tick_text]:fill-muted-foreground [&_.recharts-cartesian-grid_line[stroke='#ccc']]:stroke-border/50 [&_.recharts-curve.recharts-tooltip-cursor]:stroke-border [&_.recharts-polar-grid_[stroke='#ccc']]:stroke-border [&_.recharts-radial-bar-background-sector]:fill-muted [&_.recharts-rectangle.recharts-tooltip-cursor]:fill-muted [&_.recharts-reference-line_[stroke='#ccc']]:stroke-border flex aspect-video justify-center text-xs [&_.recharts-dot[stroke='#fff']]:stroke-transparent [&_.recharts-layer]:outline-hidden [&_.recharts-sector]:outline-hidden [&_.recharts-sector[stroke='#fff']]:stroke-transparent [&_.recharts-surface]:outline-hidden\",\n className,\n )}\n contentEditable={isEditable}\n {...props}\n >\n <ChartStyle id={chartId} config={config} />\n <RechartsPrimitive.ResponsiveContainer>{children}</RechartsPrimitive.ResponsiveContainer>\n </div>\n </ChartContext.Provider>\n );\n}\n\nfunction ChartStyle({ id, config }: { id: string; config: ChartConfig }) {\n const colorConfig = Object.entries(config).filter(([, conf]) => conf.theme || conf.color);\n\n if (!colorConfig.length) {\n return null;\n }\n\n return (\n <style\n dangerouslySetInnerHTML={{\n __html: Object.entries(THEMES)\n .map(\n ([theme, prefix]) => `\n${prefix} [data-chart=${id}] {\n${colorConfig\n .map(([key, itemConfig]) => {\n const color = itemConfig.theme?.[theme as keyof typeof itemConfig.theme] || itemConfig.color;\n\n return color ? ` --color-${key}: ${color};` : null;\n })\n .join('\\n')}\n}\n`,\n )\n .join('\\n'),\n }}\n />\n );\n}\n\nconst ChartTooltip = RechartsPrimitive.Tooltip;\n\nfunction ChartTooltipContent({\n active,\n payload,\n className,\n indicator = 'dot',\n hideLabel = false,\n hideIndicator = false,\n label,\n labelFormatter,\n labelClassName,\n formatter,\n color,\n nameKey,\n labelKey,\n}: React.ComponentProps<typeof RechartsPrimitive.Tooltip> &\n React.ComponentProps<'div'> & {\n hideLabel?: boolean;\n hideIndicator?: boolean;\n indicator?: 'line' | 'dot' | 'dashed';\n nameKey?: string;\n labelKey?: string;\n }) {\n const { config } = useChart();\n\n const tooltipLabel = React.useMemo(() => {\n if (hideLabel || !payload?.length) {\n return null;\n }\n\n const [item] = payload;\n const key = `${labelKey || item?.dataKey || item?.name || 'value'}`;\n const itemConfig = getPayloadConfigFromPayload(config, item, key);\n const value =\n !labelKey && typeof label === 'string'\n ? config[label as keyof typeof config]?.label || label\n : itemConfig?.label;\n\n if (labelFormatter) {\n return (\n <div className={cn('font-medium', labelClassName)}>{labelFormatter(value, payload)}</div>\n );\n }\n\n if (!value) {\n return null;\n }\n\n return <div className={cn('font-medium', labelClassName)}>{value}</div>;\n }, [label, labelFormatter, payload, hideLabel, labelClassName, config, labelKey]);\n\n if (!active || !payload?.length) {\n return null;\n }\n\n const nestLabel = payload.length === 1 && indicator !== 'dot';\n\n return (\n <div\n className={cn(\n 'border-border/50 bg-white grid min-w-[8rem] items-start gap-1.5 rounded-lg border px-2.5 py-1.5 text-xs shadow-xl',\n className,\n )}\n >\n {!nestLabel ? tooltipLabel : null}\n <div className=\"grid gap-1.5\">\n {payload.map((item, index) => {\n const key = `${nameKey || item.name || item.dataKey || 'value'}`;\n const itemConfig = getPayloadConfigFromPayload(config, item, key);\n const indicatorColor = color || item.payload.fill || item.color;\n\n return (\n <div\n key={`${item.dataKey}-${index}`}\n className={cn(\n '[&>svg]:text-muted-foreground flex w-full flex-wrap items-stretch gap-2 [&>svg]:h-2.5 [&>svg]:w-2.5',\n indicator === 'dot' && 'items-center',\n )}\n >\n {formatter && item?.value !== undefined && item.name ? (\n formatter(item.value, item.name, item, index, item.payload)\n ) : (\n <React.Fragment>\n {itemConfig?.icon ? (\n <itemConfig.icon />\n ) : (\n !hideIndicator && (\n <div\n className={cn(\n 'shrink-0 rounded-[2px] border-(--color-border) bg-(--color-bg)',\n {\n 'h-2.5 w-2.5': indicator === 'dot',\n 'w-1': indicator === 'line',\n 'w-0 border-[1.5px] border-dashed bg-transparent':\n indicator === 'dashed',\n 'my-0.5': nestLabel && indicator === 'dashed',\n },\n )}\n style={\n {\n '--color-bg': indicatorColor,\n '--color-border': indicatorColor,\n } as React.CSSProperties\n }\n />\n )\n )}\n <div\n className={cn(\n 'flex flex-1 justify-between leading-none',\n nestLabel ? 'items-end' : 'items-center',\n )}\n >\n <div className=\"grid gap-1.5\">\n {nestLabel ? tooltipLabel : null}\n <span className=\"text-muted-foreground mr-2\">\n {itemConfig?.label || item.name}\n </span>\n </div>\n {item.value && (\n <span className=\"text-foreground font-mono font-medium tabular-nums\">\n {item.value.toLocaleString()}\n </span>\n )}\n </div>\n </React.Fragment>\n )}\n </div>\n );\n })}\n </div>\n </div>\n );\n}\n\nconst ChartLegend = RechartsPrimitive.Legend;\n\nfunction ChartLegendContent({\n className,\n hideIcon = false,\n payload,\n verticalAlign = 'bottom',\n nameKey,\n}: React.ComponentProps<'div'> &\n Pick<RechartsPrimitive.LegendProps, 'payload' | 'verticalAlign'> & {\n hideIcon?: boolean;\n nameKey?: string;\n }) {\n const { config } = useChart();\n\n if (!payload?.length) {\n return null;\n }\n\n return (\n <div\n className={cn(\n 'flex items-center justify-center gap-4',\n verticalAlign === 'top' ? 'pb-3' : 'pt-3',\n className,\n )}\n >\n {payload.map((item, index) => {\n const key = `${nameKey || 'value'}`;\n const itemConfig = getPayloadConfigFromPayload(config, item, key);\n\n return (\n <div\n key={`${item.value}-${index}`}\n className={cn(\n '[&>svg]:text-muted-foreground flex items-center gap-1.5 [&>svg]:h-3 [&>svg]:w-3',\n )}\n >\n {itemConfig?.icon && !hideIcon ? (\n <itemConfig.icon />\n ) : (\n <div\n className=\"h-2 w-2 shrink-0 rounded-[2px]\"\n style={{\n backgroundColor: item.color,\n }}\n />\n )}\n {itemConfig?.label}\n </div>\n );\n })}\n </div>\n );\n}\n\n// Helper to extract item config from a payload.\nfunction getPayloadConfigFromPayload(config: ChartConfig, payload: unknown, key: string) {\n if (typeof payload !== 'object' || payload === null) {\n return undefined;\n }\n\n const payloadPayload =\n 'payload' in payload && typeof payload.payload === 'object' && payload.payload !== null\n ? payload.payload\n : undefined;\n\n let configLabelKey: string = key;\n\n if (key in payload && typeof payload[key as keyof typeof payload] === 'string') {\n configLabelKey = payload[key as keyof typeof payload] as string;\n } else if (\n payloadPayload &&\n key in payloadPayload &&\n typeof payloadPayload[key as keyof typeof payloadPayload] === 'string'\n ) {\n configLabelKey = payloadPayload[key as keyof typeof payloadPayload] as string;\n }\n\n return configLabelKey in config ? config[configLabelKey] : config[key as keyof typeof config];\n}\n\nexport {\n ChartContainer,\n ChartTooltip,\n ChartTooltipContent,\n ChartLegend,\n ChartLegendContent,\n ChartStyle,\n};\n"],"mappings":"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","ignoreList":[]}
|