chordia-ui 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs.js","sources":["../src/components/primitives/ColorPalette.jsx","../src/components/primitives/Tabs.jsx","../src/components/primitives/Badge.jsx","../src/components/primitives/Checkbox.jsx","../src/components/primitives/TextInput.jsx","../src/components/primitives/TextArea.jsx","../src/components/primitives/Select.jsx","../src/components/primitives/FormLabel.jsx","../src/components/primitives/InlineConfirm.jsx","../node_modules/@dnd-kit/utilities/dist/utilities.esm.js","../node_modules/@dnd-kit/accessibility/dist/accessibility.esm.js","../node_modules/@dnd-kit/core/dist/core.esm.js","../node_modules/@dnd-kit/sortable/dist/sortable.esm.js","../src/components/data/DataTableFilters.jsx","../src/components/data/DataTable.jsx","../src/components/data/SummaryStatsPanel.jsx","../src/components/media/InteractionSummaryCard.jsx","../src/components/chat/ChatMessage.jsx","../src/components/chat/ThinkingIndicator.jsx","../src/components/chat/ChatInterface.jsx","../src/components/chat/ChatHistoryPanel.jsx","../src/components/chat/MessageThread.jsx","../src/components/navigation/Sidebar.jsx","../src/components/navigation/NavigationBar.jsx","../src/components/layout/FirstCallScreen.jsx","../src/components/layout/OnboardingChecklist.jsx","../src/components/layout/DemoProjectBanner.jsx","../src/components/layout/IntegrationCard.jsx","../src/components/layout/LoginForm.jsx","../src/components/notifications/NotificationItem.jsx","../src/components/notifications/NotificationPanel.jsx"],"sourcesContent":["\"use client\";\r\n\r\nimport React from \"react\";\r\n\r\n/**\r\n * ColorPalette component\r\n * Renders grouped color chips with name, hex, and usage text.\r\n *\r\n * @param {{ name: string; hex: string; usage: string; category: string; }[]} colors\r\n */\r\nexport default function ColorPalette({ colors = [] }) {\r\n // Group colors by category\r\n const groupedColors = colors.reduce((acc, color) => {\r\n if (!acc[color.category]) {\r\n acc[color.category] = [];\r\n }\r\n acc[color.category].push(color);\r\n return acc;\r\n }, {});\r\n\r\n return (\r\n <div\r\n style={{\r\n fontFamily: \"system-ui, -apple-system, sans-serif\",\r\n }}\r\n >\r\n {Object.entries(groupedColors).map(([category, categoryColors]) => (\r\n <div key={category} style={{ marginBottom: \"24px\" }}>\r\n {/* Category header */}\r\n <div\r\n style={{\r\n fontSize: '11px',\r\n letterSpacing: '0.14em',\r\n textTransform: 'uppercase',\r\n marginBottom: '12px',\r\n color: \"rgba(30, 33, 37, 0.62)\",\r\n fontWeight: 650,\r\n }}\r\n >\r\n {category}\r\n </div>\r\n\r\n {/* Color chips grid */}\r\n <div\r\n style={{\r\n display: \"grid\",\r\n gridTemplateColumns: \"repeat(auto-fill, minmax(220px, 1fr))\",\r\n gap: \"12px\",\r\n }}\r\n >\r\n {categoryColors.map((color, i) => (\r\n <div\r\n key={i}\r\n style={{\r\n border: \"1px solid rgba(52, 58, 64, 0.12)\",\r\n borderRadius: \"12px\",\r\n overflow: \"hidden\",\r\n background: \"rgba(255, 255, 255, 0.72)\",\r\n }}\r\n >\r\n {/* Color swatch */}\r\n <div\r\n style={{\r\n height: \"64px\",\r\n background: color.hex,\r\n borderBottom: \"1px solid rgba(52, 58, 64, 0.10)\",\r\n }}\r\n />\r\n\r\n {/* Color info */}\r\n <div style={{ padding: \"10px 12px\" }}>\r\n <div\r\n style={{\r\n fontSize: \"13px\",\r\n fontWeight: 680,\r\n color: \"rgba(30, 33, 37, 0.92)\",\r\n marginBottom: \"4px\",\r\n }}\r\n >\r\n {color.name}\r\n </div>\r\n <div\r\n style={{\r\n fontSize: \"11.5px\",\r\n fontFamily: \"ui-monospace, monospace\",\r\n color: \"rgba(30, 33, 37, 0.52)\",\r\n marginBottom: \"6px\",\r\n }}\r\n >\r\n {color.hex}\r\n </div>\r\n <div\r\n style={{\r\n fontSize: \"11.5px\",\r\n color: \"rgba(30, 33, 37, 0.62)\",\r\n lineHeight: 1.4,\r\n }}\r\n >\r\n {color.usage}\r\n </div>\r\n </div>\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n ))}\r\n </div>\r\n );\r\n}\r\n\r\n\r\n","\"use client\";\r\n\r\nimport React from \"react\";\r\n\r\n/**\r\n * Tabs Component\r\n * Horizontal tab bar matching the Chordia design system.\r\n * Uses warm underline for active state, muted text for inactive.\r\n *\r\n * @param {{ key: string; label: string }[]} tabs - Tab definitions\r\n * @param {string} active - Currently active tab key\r\n * @param {(key: string) => void} onSelect - Called when a tab is clicked\r\n * @param {\"default\" | \"compact\"} [size=\"default\"] - Tab size variant\r\n */\r\nexport default function Tabs({ tabs = [], active, onSelect, size = \"default\" }) {\r\n const isCompact = size === \"compact\";\r\n\r\n return (\r\n <div\r\n style={{\r\n display: \"flex\",\r\n borderBottom: \"1px solid var(--border)\",\r\n background: \"var(--paper)\",\r\n flexShrink: 0,\r\n overflowX: \"auto\",\r\n }}\r\n >\r\n {tabs.map((tab) => {\r\n const isActive = tab.key === active;\r\n return (\r\n <button\r\n key={tab.key}\r\n onClick={() => onSelect?.(tab.key)}\r\n style={{\r\n padding: isCompact ? \"8px 12px\" : \"10px 16px\",\r\n fontSize: isCompact ? 'var(--text-md)' : 'var(--text-lg)',\r\n fontWeight: 'var(--font-medium)',\r\n fontFamily: \"var(--font-sans)\",\r\n whiteSpace: \"nowrap\",\r\n cursor: \"pointer\",\r\n background: \"none\",\r\n color: isActive ? \"var(--text-ink)\" : \"var(--text-muted)\",\r\n borderTop: \"none\",\r\n borderLeft: \"none\",\r\n borderRight: \"none\",\r\n borderBottom: isActive\r\n ? \"2px solid var(--text-ink)\"\r\n : \"2px solid transparent\",\r\n transition: \"color 0.15s, border-color 0.15s\",\r\n letterSpacing: \"-0.01em\",\r\n }}\r\n onMouseEnter={(e) => {\r\n if (!isActive) e.currentTarget.style.color = \"var(--text-strong)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n if (!isActive) e.currentTarget.style.color = \"var(--text-muted)\";\r\n }}\r\n >\r\n {tab.label}\r\n </button>\r\n );\r\n })}\r\n </div>\r\n );\r\n}\r\n","\"use client\";\r\n\r\nexport default function Badge({ children, color, icon, ...props }) {\r\n const baseStyle = {\r\n fontSize: 'var(--text-xs)',\r\n padding: '1px 5px',\r\n borderRadius: 'var(--radius-sm)',\r\n display: 'inline-flex',\r\n alignItems: 'center'\r\n };\r\n\r\n const computedStyle = {\r\n ...baseStyle,\r\n color: color,\r\n backgroundColor: `color-mix(in srgb, ${color} 15%, transparent)`,\r\n ...props.style\r\n };\r\n\r\n return (\r\n <span style={computedStyle} {...props}>\r\n {icon && (\r\n <span style={{ marginRight: '3px' }}>\r\n {icon}\r\n </span>\r\n )}\r\n {children}\r\n </span>\r\n );\r\n}","\"use client\";\r\n\r\nimport { Check } from 'lucide-react';\r\n\r\n/**\r\n * Styled checkbox matching Chordia design system.\r\n * Uses --rail-tone (purple) when checked, --border when unchecked.\r\n * No native browser checkbox — fully custom.\r\n *\r\n * @param {boolean} checked\r\n * @param {function} onChange - receives new boolean value\r\n * @param {string} [label] - optional label text\r\n * @param {'md'|'sm'} [size='md']\r\n * @param {boolean} [disabled=false]\r\n * @param {object} [style] - override style on the outer label\r\n */\r\nexport default function Checkbox({\r\n checked = false,\r\n onChange,\r\n label,\r\n size = 'md',\r\n disabled = false,\r\n style,\r\n ...props\r\n}) {\r\n const boxSize = size === 'sm' ? 12 : 16;\r\n const checkSize = size === 'sm' ? 8 : 11;\r\n\r\n return (\r\n <label\r\n style={{\r\n display: 'inline-flex',\r\n alignItems: 'center',\r\n gap: size === 'sm' ? 3 : 'var(--spacing-2)',\r\n fontSize: size === 'sm' ? 'var(--text-xs)' : 'var(--text-sm)',\r\n color: disabled ? 'var(--text-faint)' : 'var(--text-base)',\r\n cursor: disabled ? 'not-allowed' : 'pointer',\r\n userSelect: 'none',\r\n ...style,\r\n }}\r\n onClick={(e) => {\r\n e.preventDefault();\r\n if (!disabled && onChange) onChange(!checked);\r\n }}\r\n {...props}\r\n >\r\n <span\r\n style={{\r\n width: boxSize,\r\n height: boxSize,\r\n borderRadius: size === 'sm' ? 2 : 3,\r\n border: `1px solid ${checked ? 'var(--text-ink)' : 'var(--border)'}`,\r\n background: checked ? 'var(--text-ink)' : 'transparent',\r\n display: 'inline-flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n transition: 'var(--transition-fast)',\r\n flexShrink: 0,\r\n opacity: disabled ? 0.5 : 1,\r\n }}\r\n >\r\n {checked && (\r\n <Check size={checkSize} style={{ color: 'white' }} strokeWidth={3} />\r\n )}\r\n </span>\r\n {label}\r\n </label>\r\n );\r\n}\r\n","\"use client\";\r\nimport React from 'react';\r\n\r\nconst baseStyle = {\r\n width: '100%',\r\n padding: 'var(--spacing-2)',\r\n fontSize: 'var(--text-md)',\r\n border: '1px solid var(--border)',\r\n borderRadius: 'var(--radius)',\r\n backgroundColor: 'var(--paper)',\r\n color: 'var(--text-base)',\r\n fontFamily: 'var(--font-sans)',\r\n outline: 'none',\r\n transition: 'border-color 0.15s ease',\r\n};\r\n\r\nexport default function TextInput({\r\n value,\r\n onChange,\r\n placeholder,\r\n disabled = false,\r\n mono = false,\r\n autoFocus = false,\r\n style,\r\n ...rest\r\n}) {\r\n return (\r\n <input\r\n type=\"text\"\r\n value={value}\r\n onChange={(e) => onChange?.(e.target.value)}\r\n placeholder={placeholder}\r\n disabled={disabled}\r\n autoFocus={autoFocus}\r\n style={{\r\n ...baseStyle,\r\n ...(mono ? { fontFamily: 'var(--font-mono)' } : {}),\r\n ...(disabled ? { opacity: 0.6, cursor: 'not-allowed' } : {}),\r\n ...style,\r\n }}\r\n onFocus={(e) => { e.currentTarget.style.borderColor = 'var(--border-hover)'; }}\r\n onBlur={(e) => { e.currentTarget.style.borderColor = 'var(--border)'; }}\r\n {...rest}\r\n />\r\n );\r\n}\r\n","\"use client\";\r\nimport React from 'react';\r\n\r\nconst baseStyle = {\r\n width: '100%',\r\n padding: 'var(--spacing-2)',\r\n fontSize: 'var(--text-md)',\r\n border: '1px solid var(--border)',\r\n borderRadius: 'var(--radius)',\r\n backgroundColor: 'var(--paper)',\r\n color: 'var(--text-base)',\r\n fontFamily: 'var(--font-sans)',\r\n outline: 'none',\r\n transition: 'border-color 0.15s ease',\r\n};\r\n\r\nexport default function TextArea({\r\n value,\r\n onChange,\r\n placeholder,\r\n disabled = false,\r\n mono = false,\r\n rows = 4,\r\n resize = true,\r\n style,\r\n ...rest\r\n}) {\r\n return (\r\n <textarea\r\n value={value}\r\n onChange={(e) => onChange?.(e.target.value)}\r\n placeholder={placeholder}\r\n disabled={disabled}\r\n rows={rows}\r\n style={{\r\n ...baseStyle,\r\n resize: resize ? 'vertical' : 'none',\r\n minHeight: rows * 20,\r\n ...(mono ? { fontFamily: 'var(--font-mono)' } : {}),\r\n ...(disabled ? { opacity: 0.6, cursor: 'not-allowed' } : {}),\r\n ...style,\r\n }}\r\n onFocus={(e) => { e.currentTarget.style.borderColor = 'var(--border-hover)'; }}\r\n onBlur={(e) => { e.currentTarget.style.borderColor = 'var(--border)'; }}\r\n {...rest}\r\n />\r\n );\r\n}\r\n","\"use client\";\r\nimport React from 'react';\r\n\r\nconst baseStyle = {\r\n width: '100%',\r\n padding: 'var(--spacing-1) var(--spacing-2)',\r\n fontSize: 'var(--text-md)',\r\n border: '1px solid var(--border)',\r\n borderRadius: 'var(--radius)',\r\n backgroundColor: 'var(--paper)',\r\n color: 'var(--text-base)',\r\n fontFamily: 'var(--font-sans)',\r\n cursor: 'pointer',\r\n outline: 'none',\r\n transition: 'border-color 0.15s ease',\r\n};\r\n\r\nexport default function Select({\r\n value,\r\n onChange,\r\n options = [],\r\n disabled = false,\r\n placeholder,\r\n style,\r\n ...rest\r\n}) {\r\n return (\r\n <select\r\n value={value}\r\n onChange={(e) => onChange?.(e.target.value)}\r\n disabled={disabled}\r\n style={{\r\n ...baseStyle,\r\n ...(disabled ? { opacity: 0.6, cursor: 'not-allowed' } : {}),\r\n ...style,\r\n }}\r\n onFocus={(e) => { e.currentTarget.style.borderColor = 'var(--border-hover)'; }}\r\n onBlur={(e) => { e.currentTarget.style.borderColor = 'var(--border)'; }}\r\n {...rest}\r\n >\r\n {placeholder && <option value=\"\">{placeholder}</option>}\r\n {options.map((opt) => (\r\n <option key={opt.value} value={opt.value}>\r\n {opt.label}\r\n </option>\r\n ))}\r\n </select>\r\n );\r\n}\r\n","\"use client\";\r\nimport React from 'react';\r\n\r\nexport default function FormLabel({ children, htmlFor, style }) {\r\n return (\r\n <label\r\n htmlFor={htmlFor}\r\n style={{\r\n display: 'block',\r\n fontSize: 'var(--text-base)',\r\n color: 'var(--text-muted)',\r\n marginBottom: 'var(--spacing-1)',\r\n fontFamily: 'var(--font-sans)',\r\n ...style,\r\n }}\r\n >\r\n {children}\r\n </label>\r\n );\r\n}\r\n","\"use client\";\r\nimport React, { useState } from 'react';\r\nimport SmallButton from './SmallButton.jsx';\r\n\r\nexport default function InlineConfirm({\r\n children,\r\n onConfirm,\r\n prompt = 'Delete?',\r\n confirmLabel = 'Yes',\r\n cancelLabel = 'No',\r\n style,\r\n}) {\r\n const [confirming, setConfirming] = useState(false);\r\n\r\n if (confirming) {\r\n return (\r\n <span\r\n style={{\r\n display: 'inline-flex',\r\n alignItems: 'center',\r\n gap: 'var(--spacing-1)',\r\n ...style,\r\n }}\r\n >\r\n <span\r\n style={{\r\n fontSize: 'var(--text-sm)',\r\n color: 'var(--text-muted)',\r\n }}\r\n >\r\n {prompt}\r\n </span>\r\n <SmallButton\r\n variant=\"ghost\"\r\n size=\"sm\"\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n onConfirm?.();\r\n setConfirming(false);\r\n }}\r\n style={{ color: 'var(--text-ink)', fontWeight: 'var(--font-semibold)' }}\r\n >\r\n {confirmLabel}\r\n </SmallButton>\r\n <SmallButton\r\n variant=\"ghost\"\r\n size=\"sm\"\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n setConfirming(false);\r\n }}\r\n >\r\n {cancelLabel}\r\n </SmallButton>\r\n </span>\r\n );\r\n }\r\n\r\n return (\r\n <span\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n setConfirming(true);\r\n }}\r\n style={{ cursor: 'pointer', ...style }}\r\n >\r\n {children}\r\n </span>\r\n );\r\n}\r\n","import { useMemo, useLayoutEffect, useEffect, useRef, useCallback } from 'react';\n\nfunction useCombinedRefs() {\n for (var _len = arguments.length, refs = new Array(_len), _key = 0; _key < _len; _key++) {\n refs[_key] = arguments[_key];\n }\n\n return useMemo(() => node => {\n refs.forEach(ref => ref(node));\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n refs);\n}\n\n// https://github.com/facebook/react/blob/master/packages/shared/ExecutionEnvironment.js\nconst canUseDOM = typeof window !== 'undefined' && typeof window.document !== 'undefined' && typeof window.document.createElement !== 'undefined';\n\nfunction isWindow(element) {\n const elementString = Object.prototype.toString.call(element);\n return elementString === '[object Window]' || // In Electron context the Window object serializes to [object global]\n elementString === '[object global]';\n}\n\nfunction isNode(node) {\n return 'nodeType' in node;\n}\n\nfunction getWindow(target) {\n var _target$ownerDocument, _target$ownerDocument2;\n\n if (!target) {\n return window;\n }\n\n if (isWindow(target)) {\n return target;\n }\n\n if (!isNode(target)) {\n return window;\n }\n\n return (_target$ownerDocument = (_target$ownerDocument2 = target.ownerDocument) == null ? void 0 : _target$ownerDocument2.defaultView) != null ? _target$ownerDocument : window;\n}\n\nfunction isDocument(node) {\n const {\n Document\n } = getWindow(node);\n return node instanceof Document;\n}\n\nfunction isHTMLElement(node) {\n if (isWindow(node)) {\n return false;\n }\n\n return node instanceof getWindow(node).HTMLElement;\n}\n\nfunction isSVGElement(node) {\n return node instanceof getWindow(node).SVGElement;\n}\n\nfunction getOwnerDocument(target) {\n if (!target) {\n return document;\n }\n\n if (isWindow(target)) {\n return target.document;\n }\n\n if (!isNode(target)) {\n return document;\n }\n\n if (isDocument(target)) {\n return target;\n }\n\n if (isHTMLElement(target) || isSVGElement(target)) {\n return target.ownerDocument;\n }\n\n return document;\n}\n\n/**\r\n * A hook that resolves to useEffect on the server and useLayoutEffect on the client\r\n * @param callback {function} Callback function that is invoked when the dependencies of the hook change\r\n */\n\nconst useIsomorphicLayoutEffect = canUseDOM ? useLayoutEffect : useEffect;\n\nfunction useEvent(handler) {\n const handlerRef = useRef(handler);\n useIsomorphicLayoutEffect(() => {\n handlerRef.current = handler;\n });\n return useCallback(function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return handlerRef.current == null ? void 0 : handlerRef.current(...args);\n }, []);\n}\n\nfunction useInterval() {\n const intervalRef = useRef(null);\n const set = useCallback((listener, duration) => {\n intervalRef.current = setInterval(listener, duration);\n }, []);\n const clear = useCallback(() => {\n if (intervalRef.current !== null) {\n clearInterval(intervalRef.current);\n intervalRef.current = null;\n }\n }, []);\n return [set, clear];\n}\n\nfunction useLatestValue(value, dependencies) {\n if (dependencies === void 0) {\n dependencies = [value];\n }\n\n const valueRef = useRef(value);\n useIsomorphicLayoutEffect(() => {\n if (valueRef.current !== value) {\n valueRef.current = value;\n }\n }, dependencies);\n return valueRef;\n}\n\nfunction useLazyMemo(callback, dependencies) {\n const valueRef = useRef();\n return useMemo(() => {\n const newValue = callback(valueRef.current);\n valueRef.current = newValue;\n return newValue;\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [...dependencies]);\n}\n\nfunction useNodeRef(onChange) {\n const onChangeHandler = useEvent(onChange);\n const node = useRef(null);\n const setNodeRef = useCallback(element => {\n if (element !== node.current) {\n onChangeHandler == null ? void 0 : onChangeHandler(element, node.current);\n }\n\n node.current = element;\n }, //eslint-disable-next-line\n []);\n return [node, setNodeRef];\n}\n\nfunction usePrevious(value) {\n const ref = useRef();\n useEffect(() => {\n ref.current = value;\n }, [value]);\n return ref.current;\n}\n\nlet ids = {};\nfunction useUniqueId(prefix, value) {\n return useMemo(() => {\n if (value) {\n return value;\n }\n\n const id = ids[prefix] == null ? 0 : ids[prefix] + 1;\n ids[prefix] = id;\n return prefix + \"-\" + id;\n }, [prefix, value]);\n}\n\nfunction createAdjustmentFn(modifier) {\n return function (object) {\n for (var _len = arguments.length, adjustments = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n adjustments[_key - 1] = arguments[_key];\n }\n\n return adjustments.reduce((accumulator, adjustment) => {\n const entries = Object.entries(adjustment);\n\n for (const [key, valueAdjustment] of entries) {\n const value = accumulator[key];\n\n if (value != null) {\n accumulator[key] = value + modifier * valueAdjustment;\n }\n }\n\n return accumulator;\n }, { ...object\n });\n };\n}\n\nconst add = /*#__PURE__*/createAdjustmentFn(1);\nconst subtract = /*#__PURE__*/createAdjustmentFn(-1);\n\nfunction hasViewportRelativeCoordinates(event) {\n return 'clientX' in event && 'clientY' in event;\n}\n\nfunction isKeyboardEvent(event) {\n if (!event) {\n return false;\n }\n\n const {\n KeyboardEvent\n } = getWindow(event.target);\n return KeyboardEvent && event instanceof KeyboardEvent;\n}\n\nfunction isTouchEvent(event) {\n if (!event) {\n return false;\n }\n\n const {\n TouchEvent\n } = getWindow(event.target);\n return TouchEvent && event instanceof TouchEvent;\n}\n\n/**\r\n * Returns the normalized x and y coordinates for mouse and touch events.\r\n */\n\nfunction getEventCoordinates(event) {\n if (isTouchEvent(event)) {\n if (event.touches && event.touches.length) {\n const {\n clientX: x,\n clientY: y\n } = event.touches[0];\n return {\n x,\n y\n };\n } else if (event.changedTouches && event.changedTouches.length) {\n const {\n clientX: x,\n clientY: y\n } = event.changedTouches[0];\n return {\n x,\n y\n };\n }\n }\n\n if (hasViewportRelativeCoordinates(event)) {\n return {\n x: event.clientX,\n y: event.clientY\n };\n }\n\n return null;\n}\n\nconst CSS = /*#__PURE__*/Object.freeze({\n Translate: {\n toString(transform) {\n if (!transform) {\n return;\n }\n\n const {\n x,\n y\n } = transform;\n return \"translate3d(\" + (x ? Math.round(x) : 0) + \"px, \" + (y ? Math.round(y) : 0) + \"px, 0)\";\n }\n\n },\n Scale: {\n toString(transform) {\n if (!transform) {\n return;\n }\n\n const {\n scaleX,\n scaleY\n } = transform;\n return \"scaleX(\" + scaleX + \") scaleY(\" + scaleY + \")\";\n }\n\n },\n Transform: {\n toString(transform) {\n if (!transform) {\n return;\n }\n\n return [CSS.Translate.toString(transform), CSS.Scale.toString(transform)].join(' ');\n }\n\n },\n Transition: {\n toString(_ref) {\n let {\n property,\n duration,\n easing\n } = _ref;\n return property + \" \" + duration + \"ms \" + easing;\n }\n\n }\n});\n\nconst SELECTOR = 'a,frame,iframe,input:not([type=hidden]):not(:disabled),select:not(:disabled),textarea:not(:disabled),button:not(:disabled),*[tabindex]';\nfunction findFirstFocusableNode(element) {\n if (element.matches(SELECTOR)) {\n return element;\n }\n\n return element.querySelector(SELECTOR);\n}\n\nexport { CSS, add, canUseDOM, findFirstFocusableNode, getEventCoordinates, getOwnerDocument, getWindow, hasViewportRelativeCoordinates, isDocument, isHTMLElement, isKeyboardEvent, isNode, isSVGElement, isTouchEvent, isWindow, subtract, useCombinedRefs, useEvent, useInterval, useIsomorphicLayoutEffect, useLatestValue, useLazyMemo, useNodeRef, usePrevious, useUniqueId };\n//# sourceMappingURL=utilities.esm.js.map\n","import React, { useState, useCallback } from 'react';\n\nconst hiddenStyles = {\n display: 'none'\n};\nfunction HiddenText(_ref) {\n let {\n id,\n value\n } = _ref;\n return React.createElement(\"div\", {\n id: id,\n style: hiddenStyles\n }, value);\n}\n\nfunction LiveRegion(_ref) {\n let {\n id,\n announcement,\n ariaLiveType = \"assertive\"\n } = _ref;\n // Hide element visually but keep it readable by screen readers\n const visuallyHidden = {\n position: 'fixed',\n top: 0,\n left: 0,\n width: 1,\n height: 1,\n margin: -1,\n border: 0,\n padding: 0,\n overflow: 'hidden',\n clip: 'rect(0 0 0 0)',\n clipPath: 'inset(100%)',\n whiteSpace: 'nowrap'\n };\n return React.createElement(\"div\", {\n id: id,\n style: visuallyHidden,\n role: \"status\",\n \"aria-live\": ariaLiveType,\n \"aria-atomic\": true\n }, announcement);\n}\n\nfunction useAnnouncement() {\n const [announcement, setAnnouncement] = useState('');\n const announce = useCallback(value => {\n if (value != null) {\n setAnnouncement(value);\n }\n }, []);\n return {\n announce,\n announcement\n };\n}\n\nexport { HiddenText, LiveRegion, useAnnouncement };\n//# sourceMappingURL=accessibility.esm.js.map\n","import React, { createContext, useContext, useEffect, useState, useCallback, useMemo, useRef, memo, useReducer, cloneElement, forwardRef } from 'react';\nimport { createPortal, unstable_batchedUpdates } from 'react-dom';\nimport { useUniqueId, getEventCoordinates, getWindow, isDocument, isHTMLElement, isSVGElement, canUseDOM, isWindow, isNode, getOwnerDocument, add, isKeyboardEvent, subtract, useLazyMemo, useInterval, usePrevious, useLatestValue, useEvent, useIsomorphicLayoutEffect, useNodeRef, findFirstFocusableNode, CSS } from '@dnd-kit/utilities';\nimport { useAnnouncement, HiddenText, LiveRegion } from '@dnd-kit/accessibility';\n\nconst DndMonitorContext = /*#__PURE__*/createContext(null);\n\nfunction useDndMonitor(listener) {\n const registerListener = useContext(DndMonitorContext);\n useEffect(() => {\n if (!registerListener) {\n throw new Error('useDndMonitor must be used within a children of <DndContext>');\n }\n\n const unsubscribe = registerListener(listener);\n return unsubscribe;\n }, [listener, registerListener]);\n}\n\nfunction useDndMonitorProvider() {\n const [listeners] = useState(() => new Set());\n const registerListener = useCallback(listener => {\n listeners.add(listener);\n return () => listeners.delete(listener);\n }, [listeners]);\n const dispatch = useCallback(_ref => {\n let {\n type,\n event\n } = _ref;\n listeners.forEach(listener => {\n var _listener$type;\n\n return (_listener$type = listener[type]) == null ? void 0 : _listener$type.call(listener, event);\n });\n }, [listeners]);\n return [dispatch, registerListener];\n}\n\nconst defaultScreenReaderInstructions = {\n draggable: \"\\n To pick up a draggable item, press the space bar.\\n While dragging, use the arrow keys to move the item.\\n Press space again to drop the item in its new position, or press escape to cancel.\\n \"\n};\nconst defaultAnnouncements = {\n onDragStart(_ref) {\n let {\n active\n } = _ref;\n return \"Picked up draggable item \" + active.id + \".\";\n },\n\n onDragOver(_ref2) {\n let {\n active,\n over\n } = _ref2;\n\n if (over) {\n return \"Draggable item \" + active.id + \" was moved over droppable area \" + over.id + \".\";\n }\n\n return \"Draggable item \" + active.id + \" is no longer over a droppable area.\";\n },\n\n onDragEnd(_ref3) {\n let {\n active,\n over\n } = _ref3;\n\n if (over) {\n return \"Draggable item \" + active.id + \" was dropped over droppable area \" + over.id;\n }\n\n return \"Draggable item \" + active.id + \" was dropped.\";\n },\n\n onDragCancel(_ref4) {\n let {\n active\n } = _ref4;\n return \"Dragging was cancelled. Draggable item \" + active.id + \" was dropped.\";\n }\n\n};\n\nfunction Accessibility(_ref) {\n let {\n announcements = defaultAnnouncements,\n container,\n hiddenTextDescribedById,\n screenReaderInstructions = defaultScreenReaderInstructions\n } = _ref;\n const {\n announce,\n announcement\n } = useAnnouncement();\n const liveRegionId = useUniqueId(\"DndLiveRegion\");\n const [mounted, setMounted] = useState(false);\n useEffect(() => {\n setMounted(true);\n }, []);\n useDndMonitor(useMemo(() => ({\n onDragStart(_ref2) {\n let {\n active\n } = _ref2;\n announce(announcements.onDragStart({\n active\n }));\n },\n\n onDragMove(_ref3) {\n let {\n active,\n over\n } = _ref3;\n\n if (announcements.onDragMove) {\n announce(announcements.onDragMove({\n active,\n over\n }));\n }\n },\n\n onDragOver(_ref4) {\n let {\n active,\n over\n } = _ref4;\n announce(announcements.onDragOver({\n active,\n over\n }));\n },\n\n onDragEnd(_ref5) {\n let {\n active,\n over\n } = _ref5;\n announce(announcements.onDragEnd({\n active,\n over\n }));\n },\n\n onDragCancel(_ref6) {\n let {\n active,\n over\n } = _ref6;\n announce(announcements.onDragCancel({\n active,\n over\n }));\n }\n\n }), [announce, announcements]));\n\n if (!mounted) {\n return null;\n }\n\n const markup = React.createElement(React.Fragment, null, React.createElement(HiddenText, {\n id: hiddenTextDescribedById,\n value: screenReaderInstructions.draggable\n }), React.createElement(LiveRegion, {\n id: liveRegionId,\n announcement: announcement\n }));\n return container ? createPortal(markup, container) : markup;\n}\n\nvar Action;\n\n(function (Action) {\n Action[\"DragStart\"] = \"dragStart\";\n Action[\"DragMove\"] = \"dragMove\";\n Action[\"DragEnd\"] = \"dragEnd\";\n Action[\"DragCancel\"] = \"dragCancel\";\n Action[\"DragOver\"] = \"dragOver\";\n Action[\"RegisterDroppable\"] = \"registerDroppable\";\n Action[\"SetDroppableDisabled\"] = \"setDroppableDisabled\";\n Action[\"UnregisterDroppable\"] = \"unregisterDroppable\";\n})(Action || (Action = {}));\n\nfunction noop() {}\n\nfunction useSensor(sensor, options) {\n return useMemo(() => ({\n sensor,\n options: options != null ? options : {}\n }), // eslint-disable-next-line react-hooks/exhaustive-deps\n [sensor, options]);\n}\n\nfunction useSensors() {\n for (var _len = arguments.length, sensors = new Array(_len), _key = 0; _key < _len; _key++) {\n sensors[_key] = arguments[_key];\n }\n\n return useMemo(() => [...sensors].filter(sensor => sensor != null), // eslint-disable-next-line react-hooks/exhaustive-deps\n [...sensors]);\n}\n\nconst defaultCoordinates = /*#__PURE__*/Object.freeze({\n x: 0,\n y: 0\n});\n\n/**\r\n * Returns the distance between two points\r\n */\nfunction distanceBetween(p1, p2) {\n return Math.sqrt(Math.pow(p1.x - p2.x, 2) + Math.pow(p1.y - p2.y, 2));\n}\n\nfunction getRelativeTransformOrigin(event, rect) {\n const eventCoordinates = getEventCoordinates(event);\n\n if (!eventCoordinates) {\n return '0 0';\n }\n\n const transformOrigin = {\n x: (eventCoordinates.x - rect.left) / rect.width * 100,\n y: (eventCoordinates.y - rect.top) / rect.height * 100\n };\n return transformOrigin.x + \"% \" + transformOrigin.y + \"%\";\n}\n\n/**\r\n * Sort collisions from smallest to greatest value\r\n */\nfunction sortCollisionsAsc(_ref, _ref2) {\n let {\n data: {\n value: a\n }\n } = _ref;\n let {\n data: {\n value: b\n }\n } = _ref2;\n return a - b;\n}\n/**\r\n * Sort collisions from greatest to smallest value\r\n */\n\nfunction sortCollisionsDesc(_ref3, _ref4) {\n let {\n data: {\n value: a\n }\n } = _ref3;\n let {\n data: {\n value: b\n }\n } = _ref4;\n return b - a;\n}\n/**\r\n * Returns the coordinates of the corners of a given rectangle:\r\n * [TopLeft {x, y}, TopRight {x, y}, BottomLeft {x, y}, BottomRight {x, y}]\r\n */\n\nfunction cornersOfRectangle(_ref5) {\n let {\n left,\n top,\n height,\n width\n } = _ref5;\n return [{\n x: left,\n y: top\n }, {\n x: left + width,\n y: top\n }, {\n x: left,\n y: top + height\n }, {\n x: left + width,\n y: top + height\n }];\n}\nfunction getFirstCollision(collisions, property) {\n if (!collisions || collisions.length === 0) {\n return null;\n }\n\n const [firstCollision] = collisions;\n return property ? firstCollision[property] : firstCollision;\n}\n\n/**\r\n * Returns the coordinates of the center of a given ClientRect\r\n */\n\nfunction centerOfRectangle(rect, left, top) {\n if (left === void 0) {\n left = rect.left;\n }\n\n if (top === void 0) {\n top = rect.top;\n }\n\n return {\n x: left + rect.width * 0.5,\n y: top + rect.height * 0.5\n };\n}\n/**\r\n * Returns the closest rectangles from an array of rectangles to the center of a given\r\n * rectangle.\r\n */\n\n\nconst closestCenter = _ref => {\n let {\n collisionRect,\n droppableRects,\n droppableContainers\n } = _ref;\n const centerRect = centerOfRectangle(collisionRect, collisionRect.left, collisionRect.top);\n const collisions = [];\n\n for (const droppableContainer of droppableContainers) {\n const {\n id\n } = droppableContainer;\n const rect = droppableRects.get(id);\n\n if (rect) {\n const distBetween = distanceBetween(centerOfRectangle(rect), centerRect);\n collisions.push({\n id,\n data: {\n droppableContainer,\n value: distBetween\n }\n });\n }\n }\n\n return collisions.sort(sortCollisionsAsc);\n};\n\n/**\r\n * Returns the closest rectangles from an array of rectangles to the corners of\r\n * another rectangle.\r\n */\n\nconst closestCorners = _ref => {\n let {\n collisionRect,\n droppableRects,\n droppableContainers\n } = _ref;\n const corners = cornersOfRectangle(collisionRect);\n const collisions = [];\n\n for (const droppableContainer of droppableContainers) {\n const {\n id\n } = droppableContainer;\n const rect = droppableRects.get(id);\n\n if (rect) {\n const rectCorners = cornersOfRectangle(rect);\n const distances = corners.reduce((accumulator, corner, index) => {\n return accumulator + distanceBetween(rectCorners[index], corner);\n }, 0);\n const effectiveDistance = Number((distances / 4).toFixed(4));\n collisions.push({\n id,\n data: {\n droppableContainer,\n value: effectiveDistance\n }\n });\n }\n }\n\n return collisions.sort(sortCollisionsAsc);\n};\n\n/**\r\n * Returns the intersecting rectangle area between two rectangles\r\n */\n\nfunction getIntersectionRatio(entry, target) {\n const top = Math.max(target.top, entry.top);\n const left = Math.max(target.left, entry.left);\n const right = Math.min(target.left + target.width, entry.left + entry.width);\n const bottom = Math.min(target.top + target.height, entry.top + entry.height);\n const width = right - left;\n const height = bottom - top;\n\n if (left < right && top < bottom) {\n const targetArea = target.width * target.height;\n const entryArea = entry.width * entry.height;\n const intersectionArea = width * height;\n const intersectionRatio = intersectionArea / (targetArea + entryArea - intersectionArea);\n return Number(intersectionRatio.toFixed(4));\n } // Rectangles do not overlap, or overlap has an area of zero (edge/corner overlap)\n\n\n return 0;\n}\n/**\r\n * Returns the rectangles that has the greatest intersection area with a given\r\n * rectangle in an array of rectangles.\r\n */\n\nconst rectIntersection = _ref => {\n let {\n collisionRect,\n droppableRects,\n droppableContainers\n } = _ref;\n const collisions = [];\n\n for (const droppableContainer of droppableContainers) {\n const {\n id\n } = droppableContainer;\n const rect = droppableRects.get(id);\n\n if (rect) {\n const intersectionRatio = getIntersectionRatio(rect, collisionRect);\n\n if (intersectionRatio > 0) {\n collisions.push({\n id,\n data: {\n droppableContainer,\n value: intersectionRatio\n }\n });\n }\n }\n }\n\n return collisions.sort(sortCollisionsDesc);\n};\n\n/**\r\n * Check if a given point is contained within a bounding rectangle\r\n */\n\nfunction isPointWithinRect(point, rect) {\n const {\n top,\n left,\n bottom,\n right\n } = rect;\n return top <= point.y && point.y <= bottom && left <= point.x && point.x <= right;\n}\n/**\r\n * Returns the rectangles that the pointer is hovering over\r\n */\n\n\nconst pointerWithin = _ref => {\n let {\n droppableContainers,\n droppableRects,\n pointerCoordinates\n } = _ref;\n\n if (!pointerCoordinates) {\n return [];\n }\n\n const collisions = [];\n\n for (const droppableContainer of droppableContainers) {\n const {\n id\n } = droppableContainer;\n const rect = droppableRects.get(id);\n\n if (rect && isPointWithinRect(pointerCoordinates, rect)) {\n /* There may be more than a single rectangle intersecting\r\n * with the pointer coordinates. In order to sort the\r\n * colliding rectangles, we measure the distance between\r\n * the pointer and the corners of the intersecting rectangle\r\n */\n const corners = cornersOfRectangle(rect);\n const distances = corners.reduce((accumulator, corner) => {\n return accumulator + distanceBetween(pointerCoordinates, corner);\n }, 0);\n const effectiveDistance = Number((distances / 4).toFixed(4));\n collisions.push({\n id,\n data: {\n droppableContainer,\n value: effectiveDistance\n }\n });\n }\n }\n\n return collisions.sort(sortCollisionsAsc);\n};\n\nfunction adjustScale(transform, rect1, rect2) {\n return { ...transform,\n scaleX: rect1 && rect2 ? rect1.width / rect2.width : 1,\n scaleY: rect1 && rect2 ? rect1.height / rect2.height : 1\n };\n}\n\nfunction getRectDelta(rect1, rect2) {\n return rect1 && rect2 ? {\n x: rect1.left - rect2.left,\n y: rect1.top - rect2.top\n } : defaultCoordinates;\n}\n\nfunction createRectAdjustmentFn(modifier) {\n return function adjustClientRect(rect) {\n for (var _len = arguments.length, adjustments = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n adjustments[_key - 1] = arguments[_key];\n }\n\n return adjustments.reduce((acc, adjustment) => ({ ...acc,\n top: acc.top + modifier * adjustment.y,\n bottom: acc.bottom + modifier * adjustment.y,\n left: acc.left + modifier * adjustment.x,\n right: acc.right + modifier * adjustment.x\n }), { ...rect\n });\n };\n}\nconst getAdjustedRect = /*#__PURE__*/createRectAdjustmentFn(1);\n\nfunction parseTransform(transform) {\n if (transform.startsWith('matrix3d(')) {\n const transformArray = transform.slice(9, -1).split(/, /);\n return {\n x: +transformArray[12],\n y: +transformArray[13],\n scaleX: +transformArray[0],\n scaleY: +transformArray[5]\n };\n } else if (transform.startsWith('matrix(')) {\n const transformArray = transform.slice(7, -1).split(/, /);\n return {\n x: +transformArray[4],\n y: +transformArray[5],\n scaleX: +transformArray[0],\n scaleY: +transformArray[3]\n };\n }\n\n return null;\n}\n\nfunction inverseTransform(rect, transform, transformOrigin) {\n const parsedTransform = parseTransform(transform);\n\n if (!parsedTransform) {\n return rect;\n }\n\n const {\n scaleX,\n scaleY,\n x: translateX,\n y: translateY\n } = parsedTransform;\n const x = rect.left - translateX - (1 - scaleX) * parseFloat(transformOrigin);\n const y = rect.top - translateY - (1 - scaleY) * parseFloat(transformOrigin.slice(transformOrigin.indexOf(' ') + 1));\n const w = scaleX ? rect.width / scaleX : rect.width;\n const h = scaleY ? rect.height / scaleY : rect.height;\n return {\n width: w,\n height: h,\n top: y,\n right: x + w,\n bottom: y + h,\n left: x\n };\n}\n\nconst defaultOptions = {\n ignoreTransform: false\n};\n/**\r\n * Returns the bounding client rect of an element relative to the viewport.\r\n */\n\nfunction getClientRect(element, options) {\n if (options === void 0) {\n options = defaultOptions;\n }\n\n let rect = element.getBoundingClientRect();\n\n if (options.ignoreTransform) {\n const {\n transform,\n transformOrigin\n } = getWindow(element).getComputedStyle(element);\n\n if (transform) {\n rect = inverseTransform(rect, transform, transformOrigin);\n }\n }\n\n const {\n top,\n left,\n width,\n height,\n bottom,\n right\n } = rect;\n return {\n top,\n left,\n width,\n height,\n bottom,\n right\n };\n}\n/**\r\n * Returns the bounding client rect of an element relative to the viewport.\r\n *\r\n * @remarks\r\n * The ClientRect returned by this method does not take into account transforms\r\n * applied to the element it measures.\r\n *\r\n */\n\nfunction getTransformAgnosticClientRect(element) {\n return getClientRect(element, {\n ignoreTransform: true\n });\n}\n\nfunction getWindowClientRect(element) {\n const width = element.innerWidth;\n const height = element.innerHeight;\n return {\n top: 0,\n left: 0,\n right: width,\n bottom: height,\n width,\n height\n };\n}\n\nfunction isFixed(node, computedStyle) {\n if (computedStyle === void 0) {\n computedStyle = getWindow(node).getComputedStyle(node);\n }\n\n return computedStyle.position === 'fixed';\n}\n\nfunction isScrollable(element, computedStyle) {\n if (computedStyle === void 0) {\n computedStyle = getWindow(element).getComputedStyle(element);\n }\n\n const overflowRegex = /(auto|scroll|overlay)/;\n const properties = ['overflow', 'overflowX', 'overflowY'];\n return properties.some(property => {\n const value = computedStyle[property];\n return typeof value === 'string' ? overflowRegex.test(value) : false;\n });\n}\n\nfunction getScrollableAncestors(element, limit) {\n const scrollParents = [];\n\n function findScrollableAncestors(node) {\n if (limit != null && scrollParents.length >= limit) {\n return scrollParents;\n }\n\n if (!node) {\n return scrollParents;\n }\n\n if (isDocument(node) && node.scrollingElement != null && !scrollParents.includes(node.scrollingElement)) {\n scrollParents.push(node.scrollingElement);\n return scrollParents;\n }\n\n if (!isHTMLElement(node) || isSVGElement(node)) {\n return scrollParents;\n }\n\n if (scrollParents.includes(node)) {\n return scrollParents;\n }\n\n const computedStyle = getWindow(element).getComputedStyle(node);\n\n if (node !== element) {\n if (isScrollable(node, computedStyle)) {\n scrollParents.push(node);\n }\n }\n\n if (isFixed(node, computedStyle)) {\n return scrollParents;\n }\n\n return findScrollableAncestors(node.parentNode);\n }\n\n if (!element) {\n return scrollParents;\n }\n\n return findScrollableAncestors(element);\n}\nfunction getFirstScrollableAncestor(node) {\n const [firstScrollableAncestor] = getScrollableAncestors(node, 1);\n return firstScrollableAncestor != null ? firstScrollableAncestor : null;\n}\n\nfunction getScrollableElement(element) {\n if (!canUseDOM || !element) {\n return null;\n }\n\n if (isWindow(element)) {\n return element;\n }\n\n if (!isNode(element)) {\n return null;\n }\n\n if (isDocument(element) || element === getOwnerDocument(element).scrollingElement) {\n return window;\n }\n\n if (isHTMLElement(element)) {\n return element;\n }\n\n return null;\n}\n\nfunction getScrollXCoordinate(element) {\n if (isWindow(element)) {\n return element.scrollX;\n }\n\n return element.scrollLeft;\n}\nfunction getScrollYCoordinate(element) {\n if (isWindow(element)) {\n return element.scrollY;\n }\n\n return element.scrollTop;\n}\nfunction getScrollCoordinates(element) {\n return {\n x: getScrollXCoordinate(element),\n y: getScrollYCoordinate(element)\n };\n}\n\nvar Direction;\n\n(function (Direction) {\n Direction[Direction[\"Forward\"] = 1] = \"Forward\";\n Direction[Direction[\"Backward\"] = -1] = \"Backward\";\n})(Direction || (Direction = {}));\n\nfunction isDocumentScrollingElement(element) {\n if (!canUseDOM || !element) {\n return false;\n }\n\n return element === document.scrollingElement;\n}\n\nfunction getScrollPosition(scrollingContainer) {\n const minScroll = {\n x: 0,\n y: 0\n };\n const dimensions = isDocumentScrollingElement(scrollingContainer) ? {\n height: window.innerHeight,\n width: window.innerWidth\n } : {\n height: scrollingContainer.clientHeight,\n width: scrollingContainer.clientWidth\n };\n const maxScroll = {\n x: scrollingContainer.scrollWidth - dimensions.width,\n y: scrollingContainer.scrollHeight - dimensions.height\n };\n const isTop = scrollingContainer.scrollTop <= minScroll.y;\n const isLeft = scrollingContainer.scrollLeft <= minScroll.x;\n const isBottom = scrollingContainer.scrollTop >= maxScroll.y;\n const isRight = scrollingContainer.scrollLeft >= maxScroll.x;\n return {\n isTop,\n isLeft,\n isBottom,\n isRight,\n maxScroll,\n minScroll\n };\n}\n\nconst defaultThreshold = {\n x: 0.2,\n y: 0.2\n};\nfunction getScrollDirectionAndSpeed(scrollContainer, scrollContainerRect, _ref, acceleration, thresholdPercentage) {\n let {\n top,\n left,\n right,\n bottom\n } = _ref;\n\n if (acceleration === void 0) {\n acceleration = 10;\n }\n\n if (thresholdPercentage === void 0) {\n thresholdPercentage = defaultThreshold;\n }\n\n const {\n isTop,\n isBottom,\n isLeft,\n isRight\n } = getScrollPosition(scrollContainer);\n const direction = {\n x: 0,\n y: 0\n };\n const speed = {\n x: 0,\n y: 0\n };\n const threshold = {\n height: scrollContainerRect.height * thresholdPercentage.y,\n width: scrollContainerRect.width * thresholdPercentage.x\n };\n\n if (!isTop && top <= scrollContainerRect.top + threshold.height) {\n // Scroll Up\n direction.y = Direction.Backward;\n speed.y = acceleration * Math.abs((scrollContainerRect.top + threshold.height - top) / threshold.height);\n } else if (!isBottom && bottom >= scrollContainerRect.bottom - threshold.height) {\n // Scroll Down\n direction.y = Direction.Forward;\n speed.y = acceleration * Math.abs((scrollContainerRect.bottom - threshold.height - bottom) / threshold.height);\n }\n\n if (!isRight && right >= scrollContainerRect.right - threshold.width) {\n // Scroll Right\n direction.x = Direction.Forward;\n speed.x = acceleration * Math.abs((scrollContainerRect.right - threshold.width - right) / threshold.width);\n } else if (!isLeft && left <= scrollContainerRect.left + threshold.width) {\n // Scroll Left\n direction.x = Direction.Backward;\n speed.x = acceleration * Math.abs((scrollContainerRect.left + threshold.width - left) / threshold.width);\n }\n\n return {\n direction,\n speed\n };\n}\n\nfunction getScrollElementRect(element) {\n if (element === document.scrollingElement) {\n const {\n innerWidth,\n innerHeight\n } = window;\n return {\n top: 0,\n left: 0,\n right: innerWidth,\n bottom: innerHeight,\n width: innerWidth,\n height: innerHeight\n };\n }\n\n const {\n top,\n left,\n right,\n bottom\n } = element.getBoundingClientRect();\n return {\n top,\n left,\n right,\n bottom,\n width: element.clientWidth,\n height: element.clientHeight\n };\n}\n\nfunction getScrollOffsets(scrollableAncestors) {\n return scrollableAncestors.reduce((acc, node) => {\n return add(acc, getScrollCoordinates(node));\n }, defaultCoordinates);\n}\nfunction getScrollXOffset(scrollableAncestors) {\n return scrollableAncestors.reduce((acc, node) => {\n return acc + getScrollXCoordinate(node);\n }, 0);\n}\nfunction getScrollYOffset(scrollableAncestors) {\n return scrollableAncestors.reduce((acc, node) => {\n return acc + getScrollYCoordinate(node);\n }, 0);\n}\n\nfunction scrollIntoViewIfNeeded(element, measure) {\n if (measure === void 0) {\n measure = getClientRect;\n }\n\n if (!element) {\n return;\n }\n\n const {\n top,\n left,\n bottom,\n right\n } = measure(element);\n const firstScrollableAncestor = getFirstScrollableAncestor(element);\n\n if (!firstScrollableAncestor) {\n return;\n }\n\n if (bottom <= 0 || right <= 0 || top >= window.innerHeight || left >= window.innerWidth) {\n element.scrollIntoView({\n block: 'center',\n inline: 'center'\n });\n }\n}\n\nconst properties = [['x', ['left', 'right'], getScrollXOffset], ['y', ['top', 'bottom'], getScrollYOffset]];\nclass Rect {\n constructor(rect, element) {\n this.rect = void 0;\n this.width = void 0;\n this.height = void 0;\n this.top = void 0;\n this.bottom = void 0;\n this.right = void 0;\n this.left = void 0;\n const scrollableAncestors = getScrollableAncestors(element);\n const scrollOffsets = getScrollOffsets(scrollableAncestors);\n this.rect = { ...rect\n };\n this.width = rect.width;\n this.height = rect.height;\n\n for (const [axis, keys, getScrollOffset] of properties) {\n for (const key of keys) {\n Object.defineProperty(this, key, {\n get: () => {\n const currentOffsets = getScrollOffset(scrollableAncestors);\n const scrollOffsetsDeltla = scrollOffsets[axis] - currentOffsets;\n return this.rect[key] + scrollOffsetsDeltla;\n },\n enumerable: true\n });\n }\n }\n\n Object.defineProperty(this, 'rect', {\n enumerable: false\n });\n }\n\n}\n\nclass Listeners {\n constructor(target) {\n this.target = void 0;\n this.listeners = [];\n\n this.removeAll = () => {\n this.listeners.forEach(listener => {\n var _this$target;\n\n return (_this$target = this.target) == null ? void 0 : _this$target.removeEventListener(...listener);\n });\n };\n\n this.target = target;\n }\n\n add(eventName, handler, options) {\n var _this$target2;\n\n (_this$target2 = this.target) == null ? void 0 : _this$target2.addEventListener(eventName, handler, options);\n this.listeners.push([eventName, handler, options]);\n }\n\n}\n\nfunction getEventListenerTarget(target) {\n // If the `event.target` element is removed from the document events will still be targeted\n // at it, and hence won't always bubble up to the window or document anymore.\n // If there is any risk of an element being removed while it is being dragged,\n // the best practice is to attach the event listeners directly to the target.\n // https://developer.mozilla.org/en-US/docs/Web/API/EventTarget\n const {\n EventTarget\n } = getWindow(target);\n return target instanceof EventTarget ? target : getOwnerDocument(target);\n}\n\nfunction hasExceededDistance(delta, measurement) {\n const dx = Math.abs(delta.x);\n const dy = Math.abs(delta.y);\n\n if (typeof measurement === 'number') {\n return Math.sqrt(dx ** 2 + dy ** 2) > measurement;\n }\n\n if ('x' in measurement && 'y' in measurement) {\n return dx > measurement.x && dy > measurement.y;\n }\n\n if ('x' in measurement) {\n return dx > measurement.x;\n }\n\n if ('y' in measurement) {\n return dy > measurement.y;\n }\n\n return false;\n}\n\nvar EventName;\n\n(function (EventName) {\n EventName[\"Click\"] = \"click\";\n EventName[\"DragStart\"] = \"dragstart\";\n EventName[\"Keydown\"] = \"keydown\";\n EventName[\"ContextMenu\"] = \"contextmenu\";\n EventName[\"Resize\"] = \"resize\";\n EventName[\"SelectionChange\"] = \"selectionchange\";\n EventName[\"VisibilityChange\"] = \"visibilitychange\";\n})(EventName || (EventName = {}));\n\nfunction preventDefault(event) {\n event.preventDefault();\n}\nfunction stopPropagation(event) {\n event.stopPropagation();\n}\n\nvar KeyboardCode;\n\n(function (KeyboardCode) {\n KeyboardCode[\"Space\"] = \"Space\";\n KeyboardCode[\"Down\"] = \"ArrowDown\";\n KeyboardCode[\"Right\"] = \"ArrowRight\";\n KeyboardCode[\"Left\"] = \"ArrowLeft\";\n KeyboardCode[\"Up\"] = \"ArrowUp\";\n KeyboardCode[\"Esc\"] = \"Escape\";\n KeyboardCode[\"Enter\"] = \"Enter\";\n KeyboardCode[\"Tab\"] = \"Tab\";\n})(KeyboardCode || (KeyboardCode = {}));\n\nconst defaultKeyboardCodes = {\n start: [KeyboardCode.Space, KeyboardCode.Enter],\n cancel: [KeyboardCode.Esc],\n end: [KeyboardCode.Space, KeyboardCode.Enter, KeyboardCode.Tab]\n};\nconst defaultKeyboardCoordinateGetter = (event, _ref) => {\n let {\n currentCoordinates\n } = _ref;\n\n switch (event.code) {\n case KeyboardCode.Right:\n return { ...currentCoordinates,\n x: currentCoordinates.x + 25\n };\n\n case KeyboardCode.Left:\n return { ...currentCoordinates,\n x: currentCoordinates.x - 25\n };\n\n case KeyboardCode.Down:\n return { ...currentCoordinates,\n y: currentCoordinates.y + 25\n };\n\n case KeyboardCode.Up:\n return { ...currentCoordinates,\n y: currentCoordinates.y - 25\n };\n }\n\n return undefined;\n};\n\nclass KeyboardSensor {\n constructor(props) {\n this.props = void 0;\n this.autoScrollEnabled = false;\n this.referenceCoordinates = void 0;\n this.listeners = void 0;\n this.windowListeners = void 0;\n this.props = props;\n const {\n event: {\n target\n }\n } = props;\n this.props = props;\n this.listeners = new Listeners(getOwnerDocument(target));\n this.windowListeners = new Listeners(getWindow(target));\n this.handleKeyDown = this.handleKeyDown.bind(this);\n this.handleCancel = this.handleCancel.bind(this);\n this.attach();\n }\n\n attach() {\n this.handleStart();\n this.windowListeners.add(EventName.Resize, this.handleCancel);\n this.windowListeners.add(EventName.VisibilityChange, this.handleCancel);\n setTimeout(() => this.listeners.add(EventName.Keydown, this.handleKeyDown));\n }\n\n handleStart() {\n const {\n activeNode,\n onStart\n } = this.props;\n const node = activeNode.node.current;\n\n if (node) {\n scrollIntoViewIfNeeded(node);\n }\n\n onStart(defaultCoordinates);\n }\n\n handleKeyDown(event) {\n if (isKeyboardEvent(event)) {\n const {\n active,\n context,\n options\n } = this.props;\n const {\n keyboardCodes = defaultKeyboardCodes,\n coordinateGetter = defaultKeyboardCoordinateGetter,\n scrollBehavior = 'smooth'\n } = options;\n const {\n code\n } = event;\n\n if (keyboardCodes.end.includes(code)) {\n this.handleEnd(event);\n return;\n }\n\n if (keyboardCodes.cancel.includes(code)) {\n this.handleCancel(event);\n return;\n }\n\n const {\n collisionRect\n } = context.current;\n const currentCoordinates = collisionRect ? {\n x: collisionRect.left,\n y: collisionRect.top\n } : defaultCoordinates;\n\n if (!this.referenceCoordinates) {\n this.referenceCoordinates = currentCoordinates;\n }\n\n const newCoordinates = coordinateGetter(event, {\n active,\n context: context.current,\n currentCoordinates\n });\n\n if (newCoordinates) {\n const coordinatesDelta = subtract(newCoordinates, currentCoordinates);\n const scrollDelta = {\n x: 0,\n y: 0\n };\n const {\n scrollableAncestors\n } = context.current;\n\n for (const scrollContainer of scrollableAncestors) {\n const direction = event.code;\n const {\n isTop,\n isRight,\n isLeft,\n isBottom,\n maxScroll,\n minScroll\n } = getScrollPosition(scrollContainer);\n const scrollElementRect = getScrollElementRect(scrollContainer);\n const clampedCoordinates = {\n x: Math.min(direction === KeyboardCode.Right ? scrollElementRect.right - scrollElementRect.width / 2 : scrollElementRect.right, Math.max(direction === KeyboardCode.Right ? scrollElementRect.left : scrollElementRect.left + scrollElementRect.width / 2, newCoordinates.x)),\n y: Math.min(direction === KeyboardCode.Down ? scrollElementRect.bottom - scrollElementRect.height / 2 : scrollElementRect.bottom, Math.max(direction === KeyboardCode.Down ? scrollElementRect.top : scrollElementRect.top + scrollElementRect.height / 2, newCoordinates.y))\n };\n const canScrollX = direction === KeyboardCode.Right && !isRight || direction === KeyboardCode.Left && !isLeft;\n const canScrollY = direction === KeyboardCode.Down && !isBottom || direction === KeyboardCode.Up && !isTop;\n\n if (canScrollX && clampedCoordinates.x !== newCoordinates.x) {\n const newScrollCoordinates = scrollContainer.scrollLeft + coordinatesDelta.x;\n const canScrollToNewCoordinates = direction === KeyboardCode.Right && newScrollCoordinates <= maxScroll.x || direction === KeyboardCode.Left && newScrollCoordinates >= minScroll.x;\n\n if (canScrollToNewCoordinates && !coordinatesDelta.y) {\n // We don't need to update coordinates, the scroll adjustment alone will trigger\n // logic to auto-detect the new container we are over\n scrollContainer.scrollTo({\n left: newScrollCoordinates,\n behavior: scrollBehavior\n });\n return;\n }\n\n if (canScrollToNewCoordinates) {\n scrollDelta.x = scrollContainer.scrollLeft - newScrollCoordinates;\n } else {\n scrollDelta.x = direction === KeyboardCode.Right ? scrollContainer.scrollLeft - maxScroll.x : scrollContainer.scrollLeft - minScroll.x;\n }\n\n if (scrollDelta.x) {\n scrollContainer.scrollBy({\n left: -scrollDelta.x,\n behavior: scrollBehavior\n });\n }\n\n break;\n } else if (canScrollY && clampedCoordinates.y !== newCoordinates.y) {\n const newScrollCoordinates = scrollContainer.scrollTop + coordinatesDelta.y;\n const canScrollToNewCoordinates = direction === KeyboardCode.Down && newScrollCoordinates <= maxScroll.y || direction === KeyboardCode.Up && newScrollCoordinates >= minScroll.y;\n\n if (canScrollToNewCoordinates && !coordinatesDelta.x) {\n // We don't need to update coordinates, the scroll adjustment alone will trigger\n // logic to auto-detect the new container we are over\n scrollContainer.scrollTo({\n top: newScrollCoordinates,\n behavior: scrollBehavior\n });\n return;\n }\n\n if (canScrollToNewCoordinates) {\n scrollDelta.y = scrollContainer.scrollTop - newScrollCoordinates;\n } else {\n scrollDelta.y = direction === KeyboardCode.Down ? scrollContainer.scrollTop - maxScroll.y : scrollContainer.scrollTop - minScroll.y;\n }\n\n if (scrollDelta.y) {\n scrollContainer.scrollBy({\n top: -scrollDelta.y,\n behavior: scrollBehavior\n });\n }\n\n break;\n }\n }\n\n this.handleMove(event, add(subtract(newCoordinates, this.referenceCoordinates), scrollDelta));\n }\n }\n }\n\n handleMove(event, coordinates) {\n const {\n onMove\n } = this.props;\n event.preventDefault();\n onMove(coordinates);\n }\n\n handleEnd(event) {\n const {\n onEnd\n } = this.props;\n event.preventDefault();\n this.detach();\n onEnd();\n }\n\n handleCancel(event) {\n const {\n onCancel\n } = this.props;\n event.preventDefault();\n this.detach();\n onCancel();\n }\n\n detach() {\n this.listeners.removeAll();\n this.windowListeners.removeAll();\n }\n\n}\nKeyboardSensor.activators = [{\n eventName: 'onKeyDown',\n handler: (event, _ref, _ref2) => {\n let {\n keyboardCodes = defaultKeyboardCodes,\n onActivation\n } = _ref;\n let {\n active\n } = _ref2;\n const {\n code\n } = event.nativeEvent;\n\n if (keyboardCodes.start.includes(code)) {\n const activator = active.activatorNode.current;\n\n if (activator && event.target !== activator) {\n return false;\n }\n\n event.preventDefault();\n onActivation == null ? void 0 : onActivation({\n event: event.nativeEvent\n });\n return true;\n }\n\n return false;\n }\n}];\n\nfunction isDistanceConstraint(constraint) {\n return Boolean(constraint && 'distance' in constraint);\n}\n\nfunction isDelayConstraint(constraint) {\n return Boolean(constraint && 'delay' in constraint);\n}\n\nclass AbstractPointerSensor {\n constructor(props, events, listenerTarget) {\n var _getEventCoordinates;\n\n if (listenerTarget === void 0) {\n listenerTarget = getEventListenerTarget(props.event.target);\n }\n\n this.props = void 0;\n this.events = void 0;\n this.autoScrollEnabled = true;\n this.document = void 0;\n this.activated = false;\n this.initialCoordinates = void 0;\n this.timeoutId = null;\n this.listeners = void 0;\n this.documentListeners = void 0;\n this.windowListeners = void 0;\n this.props = props;\n this.events = events;\n const {\n event\n } = props;\n const {\n target\n } = event;\n this.props = props;\n this.events = events;\n this.document = getOwnerDocument(target);\n this.documentListeners = new Listeners(this.document);\n this.listeners = new Listeners(listenerTarget);\n this.windowListeners = new Listeners(getWindow(target));\n this.initialCoordinates = (_getEventCoordinates = getEventCoordinates(event)) != null ? _getEventCoordinates : defaultCoordinates;\n this.handleStart = this.handleStart.bind(this);\n this.handleMove = this.handleMove.bind(this);\n this.handleEnd = this.handleEnd.bind(this);\n this.handleCancel = this.handleCancel.bind(this);\n this.handleKeydown = this.handleKeydown.bind(this);\n this.removeTextSelection = this.removeTextSelection.bind(this);\n this.attach();\n }\n\n attach() {\n const {\n events,\n props: {\n options: {\n activationConstraint,\n bypassActivationConstraint\n }\n }\n } = this;\n this.listeners.add(events.move.name, this.handleMove, {\n passive: false\n });\n this.listeners.add(events.end.name, this.handleEnd);\n\n if (events.cancel) {\n this.listeners.add(events.cancel.name, this.handleCancel);\n }\n\n this.windowListeners.add(EventName.Resize, this.handleCancel);\n this.windowListeners.add(EventName.DragStart, preventDefault);\n this.windowListeners.add(EventName.VisibilityChange, this.handleCancel);\n this.windowListeners.add(EventName.ContextMenu, preventDefault);\n this.documentListeners.add(EventName.Keydown, this.handleKeydown);\n\n if (activationConstraint) {\n if (bypassActivationConstraint != null && bypassActivationConstraint({\n event: this.props.event,\n activeNode: this.props.activeNode,\n options: this.props.options\n })) {\n return this.handleStart();\n }\n\n if (isDelayConstraint(activationConstraint)) {\n this.timeoutId = setTimeout(this.handleStart, activationConstraint.delay);\n this.handlePending(activationConstraint);\n return;\n }\n\n if (isDistanceConstraint(activationConstraint)) {\n this.handlePending(activationConstraint);\n return;\n }\n }\n\n this.handleStart();\n }\n\n detach() {\n this.listeners.removeAll();\n this.windowListeners.removeAll(); // Wait until the next event loop before removing document listeners\n // This is necessary because we listen for `click` and `selection` events on the document\n\n setTimeout(this.documentListeners.removeAll, 50);\n\n if (this.timeoutId !== null) {\n clearTimeout(this.timeoutId);\n this.timeoutId = null;\n }\n }\n\n handlePending(constraint, offset) {\n const {\n active,\n onPending\n } = this.props;\n onPending(active, constraint, this.initialCoordinates, offset);\n }\n\n handleStart() {\n const {\n initialCoordinates\n } = this;\n const {\n onStart\n } = this.props;\n\n if (initialCoordinates) {\n this.activated = true; // Stop propagation of click events once activation constraints are met\n\n this.documentListeners.add(EventName.Click, stopPropagation, {\n capture: true\n }); // Remove any text selection from the document\n\n this.removeTextSelection(); // Prevent further text selection while dragging\n\n this.documentListeners.add(EventName.SelectionChange, this.removeTextSelection);\n onStart(initialCoordinates);\n }\n }\n\n handleMove(event) {\n var _getEventCoordinates2;\n\n const {\n activated,\n initialCoordinates,\n props\n } = this;\n const {\n onMove,\n options: {\n activationConstraint\n }\n } = props;\n\n if (!initialCoordinates) {\n return;\n }\n\n const coordinates = (_getEventCoordinates2 = getEventCoordinates(event)) != null ? _getEventCoordinates2 : defaultCoordinates;\n const delta = subtract(initialCoordinates, coordinates); // Constraint validation\n\n if (!activated && activationConstraint) {\n if (isDistanceConstraint(activationConstraint)) {\n if (activationConstraint.tolerance != null && hasExceededDistance(delta, activationConstraint.tolerance)) {\n return this.handleCancel();\n }\n\n if (hasExceededDistance(delta, activationConstraint.distance)) {\n return this.handleStart();\n }\n }\n\n if (isDelayConstraint(activationConstraint)) {\n if (hasExceededDistance(delta, activationConstraint.tolerance)) {\n return this.handleCancel();\n }\n }\n\n this.handlePending(activationConstraint, delta);\n return;\n }\n\n if (event.cancelable) {\n event.preventDefault();\n }\n\n onMove(coordinates);\n }\n\n handleEnd() {\n const {\n onAbort,\n onEnd\n } = this.props;\n this.detach();\n\n if (!this.activated) {\n onAbort(this.props.active);\n }\n\n onEnd();\n }\n\n handleCancel() {\n const {\n onAbort,\n onCancel\n } = this.props;\n this.detach();\n\n if (!this.activated) {\n onAbort(this.props.active);\n }\n\n onCancel();\n }\n\n handleKeydown(event) {\n if (event.code === KeyboardCode.Esc) {\n this.handleCancel();\n }\n }\n\n removeTextSelection() {\n var _this$document$getSel;\n\n (_this$document$getSel = this.document.getSelection()) == null ? void 0 : _this$document$getSel.removeAllRanges();\n }\n\n}\n\nconst events = {\n cancel: {\n name: 'pointercancel'\n },\n move: {\n name: 'pointermove'\n },\n end: {\n name: 'pointerup'\n }\n};\nclass PointerSensor extends AbstractPointerSensor {\n constructor(props) {\n const {\n event\n } = props; // Pointer events stop firing if the target is unmounted while dragging\n // Therefore we attach listeners to the owner document instead\n\n const listenerTarget = getOwnerDocument(event.target);\n super(props, events, listenerTarget);\n }\n\n}\nPointerSensor.activators = [{\n eventName: 'onPointerDown',\n handler: (_ref, _ref2) => {\n let {\n nativeEvent: event\n } = _ref;\n let {\n onActivation\n } = _ref2;\n\n if (!event.isPrimary || event.button !== 0) {\n return false;\n }\n\n onActivation == null ? void 0 : onActivation({\n event\n });\n return true;\n }\n}];\n\nconst events$1 = {\n move: {\n name: 'mousemove'\n },\n end: {\n name: 'mouseup'\n }\n};\nvar MouseButton;\n\n(function (MouseButton) {\n MouseButton[MouseButton[\"RightClick\"] = 2] = \"RightClick\";\n})(MouseButton || (MouseButton = {}));\n\nclass MouseSensor extends AbstractPointerSensor {\n constructor(props) {\n super(props, events$1, getOwnerDocument(props.event.target));\n }\n\n}\nMouseSensor.activators = [{\n eventName: 'onMouseDown',\n handler: (_ref, _ref2) => {\n let {\n nativeEvent: event\n } = _ref;\n let {\n onActivation\n } = _ref2;\n\n if (event.button === MouseButton.RightClick) {\n return false;\n }\n\n onActivation == null ? void 0 : onActivation({\n event\n });\n return true;\n }\n}];\n\nconst events$2 = {\n cancel: {\n name: 'touchcancel'\n },\n move: {\n name: 'touchmove'\n },\n end: {\n name: 'touchend'\n }\n};\nclass TouchSensor extends AbstractPointerSensor {\n constructor(props) {\n super(props, events$2);\n }\n\n static setup() {\n // Adding a non-capture and non-passive `touchmove` listener in order\n // to force `event.preventDefault()` calls to work in dynamically added\n // touchmove event handlers. This is required for iOS Safari.\n window.addEventListener(events$2.move.name, noop, {\n capture: false,\n passive: false\n });\n return function teardown() {\n window.removeEventListener(events$2.move.name, noop);\n }; // We create a new handler because the teardown function of another sensor\n // could remove our event listener if we use a referentially equal listener.\n\n function noop() {}\n }\n\n}\nTouchSensor.activators = [{\n eventName: 'onTouchStart',\n handler: (_ref, _ref2) => {\n let {\n nativeEvent: event\n } = _ref;\n let {\n onActivation\n } = _ref2;\n const {\n touches\n } = event;\n\n if (touches.length > 1) {\n return false;\n }\n\n onActivation == null ? void 0 : onActivation({\n event\n });\n return true;\n }\n}];\n\nvar AutoScrollActivator;\n\n(function (AutoScrollActivator) {\n AutoScrollActivator[AutoScrollActivator[\"Pointer\"] = 0] = \"Pointer\";\n AutoScrollActivator[AutoScrollActivator[\"DraggableRect\"] = 1] = \"DraggableRect\";\n})(AutoScrollActivator || (AutoScrollActivator = {}));\n\nvar TraversalOrder;\n\n(function (TraversalOrder) {\n TraversalOrder[TraversalOrder[\"TreeOrder\"] = 0] = \"TreeOrder\";\n TraversalOrder[TraversalOrder[\"ReversedTreeOrder\"] = 1] = \"ReversedTreeOrder\";\n})(TraversalOrder || (TraversalOrder = {}));\n\nfunction useAutoScroller(_ref) {\n let {\n acceleration,\n activator = AutoScrollActivator.Pointer,\n canScroll,\n draggingRect,\n enabled,\n interval = 5,\n order = TraversalOrder.TreeOrder,\n pointerCoordinates,\n scrollableAncestors,\n scrollableAncestorRects,\n delta,\n threshold\n } = _ref;\n const scrollIntent = useScrollIntent({\n delta,\n disabled: !enabled\n });\n const [setAutoScrollInterval, clearAutoScrollInterval] = useInterval();\n const scrollSpeed = useRef({\n x: 0,\n y: 0\n });\n const scrollDirection = useRef({\n x: 0,\n y: 0\n });\n const rect = useMemo(() => {\n switch (activator) {\n case AutoScrollActivator.Pointer:\n return pointerCoordinates ? {\n top: pointerCoordinates.y,\n bottom: pointerCoordinates.y,\n left: pointerCoordinates.x,\n right: pointerCoordinates.x\n } : null;\n\n case AutoScrollActivator.DraggableRect:\n return draggingRect;\n }\n }, [activator, draggingRect, pointerCoordinates]);\n const scrollContainerRef = useRef(null);\n const autoScroll = useCallback(() => {\n const scrollContainer = scrollContainerRef.current;\n\n if (!scrollContainer) {\n return;\n }\n\n const scrollLeft = scrollSpeed.current.x * scrollDirection.current.x;\n const scrollTop = scrollSpeed.current.y * scrollDirection.current.y;\n scrollContainer.scrollBy(scrollLeft, scrollTop);\n }, []);\n const sortedScrollableAncestors = useMemo(() => order === TraversalOrder.TreeOrder ? [...scrollableAncestors].reverse() : scrollableAncestors, [order, scrollableAncestors]);\n useEffect(() => {\n if (!enabled || !scrollableAncestors.length || !rect) {\n clearAutoScrollInterval();\n return;\n }\n\n for (const scrollContainer of sortedScrollableAncestors) {\n if ((canScroll == null ? void 0 : canScroll(scrollContainer)) === false) {\n continue;\n }\n\n const index = scrollableAncestors.indexOf(scrollContainer);\n const scrollContainerRect = scrollableAncestorRects[index];\n\n if (!scrollContainerRect) {\n continue;\n }\n\n const {\n direction,\n speed\n } = getScrollDirectionAndSpeed(scrollContainer, scrollContainerRect, rect, acceleration, threshold);\n\n for (const axis of ['x', 'y']) {\n if (!scrollIntent[axis][direction[axis]]) {\n speed[axis] = 0;\n direction[axis] = 0;\n }\n }\n\n if (speed.x > 0 || speed.y > 0) {\n clearAutoScrollInterval();\n scrollContainerRef.current = scrollContainer;\n setAutoScrollInterval(autoScroll, interval);\n scrollSpeed.current = speed;\n scrollDirection.current = direction;\n return;\n }\n }\n\n scrollSpeed.current = {\n x: 0,\n y: 0\n };\n scrollDirection.current = {\n x: 0,\n y: 0\n };\n clearAutoScrollInterval();\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [acceleration, autoScroll, canScroll, clearAutoScrollInterval, enabled, interval, // eslint-disable-next-line react-hooks/exhaustive-deps\n JSON.stringify(rect), // eslint-disable-next-line react-hooks/exhaustive-deps\n JSON.stringify(scrollIntent), setAutoScrollInterval, scrollableAncestors, sortedScrollableAncestors, scrollableAncestorRects, // eslint-disable-next-line react-hooks/exhaustive-deps\n JSON.stringify(threshold)]);\n}\nconst defaultScrollIntent = {\n x: {\n [Direction.Backward]: false,\n [Direction.Forward]: false\n },\n y: {\n [Direction.Backward]: false,\n [Direction.Forward]: false\n }\n};\n\nfunction useScrollIntent(_ref2) {\n let {\n delta,\n disabled\n } = _ref2;\n const previousDelta = usePrevious(delta);\n return useLazyMemo(previousIntent => {\n if (disabled || !previousDelta || !previousIntent) {\n // Reset scroll intent tracking when auto-scrolling is disabled\n return defaultScrollIntent;\n }\n\n const direction = {\n x: Math.sign(delta.x - previousDelta.x),\n y: Math.sign(delta.y - previousDelta.y)\n }; // Keep track of the user intent to scroll in each direction for both axis\n\n return {\n x: {\n [Direction.Backward]: previousIntent.x[Direction.Backward] || direction.x === -1,\n [Direction.Forward]: previousIntent.x[Direction.Forward] || direction.x === 1\n },\n y: {\n [Direction.Backward]: previousIntent.y[Direction.Backward] || direction.y === -1,\n [Direction.Forward]: previousIntent.y[Direction.Forward] || direction.y === 1\n }\n };\n }, [disabled, delta, previousDelta]);\n}\n\nfunction useCachedNode(draggableNodes, id) {\n const draggableNode = id != null ? draggableNodes.get(id) : undefined;\n const node = draggableNode ? draggableNode.node.current : null;\n return useLazyMemo(cachedNode => {\n var _ref;\n\n if (id == null) {\n return null;\n } // In some cases, the draggable node can unmount while dragging\n // This is the case for virtualized lists. In those situations,\n // we fall back to the last known value for that node.\n\n\n return (_ref = node != null ? node : cachedNode) != null ? _ref : null;\n }, [node, id]);\n}\n\nfunction useCombineActivators(sensors, getSyntheticHandler) {\n return useMemo(() => sensors.reduce((accumulator, sensor) => {\n const {\n sensor: Sensor\n } = sensor;\n const sensorActivators = Sensor.activators.map(activator => ({\n eventName: activator.eventName,\n handler: getSyntheticHandler(activator.handler, sensor)\n }));\n return [...accumulator, ...sensorActivators];\n }, []), [sensors, getSyntheticHandler]);\n}\n\nvar MeasuringStrategy;\n\n(function (MeasuringStrategy) {\n MeasuringStrategy[MeasuringStrategy[\"Always\"] = 0] = \"Always\";\n MeasuringStrategy[MeasuringStrategy[\"BeforeDragging\"] = 1] = \"BeforeDragging\";\n MeasuringStrategy[MeasuringStrategy[\"WhileDragging\"] = 2] = \"WhileDragging\";\n})(MeasuringStrategy || (MeasuringStrategy = {}));\n\nvar MeasuringFrequency;\n\n(function (MeasuringFrequency) {\n MeasuringFrequency[\"Optimized\"] = \"optimized\";\n})(MeasuringFrequency || (MeasuringFrequency = {}));\n\nconst defaultValue = /*#__PURE__*/new Map();\nfunction useDroppableMeasuring(containers, _ref) {\n let {\n dragging,\n dependencies,\n config\n } = _ref;\n const [queue, setQueue] = useState(null);\n const {\n frequency,\n measure,\n strategy\n } = config;\n const containersRef = useRef(containers);\n const disabled = isDisabled();\n const disabledRef = useLatestValue(disabled);\n const measureDroppableContainers = useCallback(function (ids) {\n if (ids === void 0) {\n ids = [];\n }\n\n if (disabledRef.current) {\n return;\n }\n\n setQueue(value => {\n if (value === null) {\n return ids;\n }\n\n return value.concat(ids.filter(id => !value.includes(id)));\n });\n }, [disabledRef]);\n const timeoutId = useRef(null);\n const droppableRects = useLazyMemo(previousValue => {\n if (disabled && !dragging) {\n return defaultValue;\n }\n\n if (!previousValue || previousValue === defaultValue || containersRef.current !== containers || queue != null) {\n const map = new Map();\n\n for (let container of containers) {\n if (!container) {\n continue;\n }\n\n if (queue && queue.length > 0 && !queue.includes(container.id) && container.rect.current) {\n // This container does not need to be re-measured\n map.set(container.id, container.rect.current);\n continue;\n }\n\n const node = container.node.current;\n const rect = node ? new Rect(measure(node), node) : null;\n container.rect.current = rect;\n\n if (rect) {\n map.set(container.id, rect);\n }\n }\n\n return map;\n }\n\n return previousValue;\n }, [containers, queue, dragging, disabled, measure]);\n useEffect(() => {\n containersRef.current = containers;\n }, [containers]);\n useEffect(() => {\n if (disabled) {\n return;\n }\n\n measureDroppableContainers();\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [dragging, disabled]);\n useEffect(() => {\n if (queue && queue.length > 0) {\n setQueue(null);\n }\n }, //eslint-disable-next-line react-hooks/exhaustive-deps\n [JSON.stringify(queue)]);\n useEffect(() => {\n if (disabled || typeof frequency !== 'number' || timeoutId.current !== null) {\n return;\n }\n\n timeoutId.current = setTimeout(() => {\n measureDroppableContainers();\n timeoutId.current = null;\n }, frequency);\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [frequency, disabled, measureDroppableContainers, ...dependencies]);\n return {\n droppableRects,\n measureDroppableContainers,\n measuringScheduled: queue != null\n };\n\n function isDisabled() {\n switch (strategy) {\n case MeasuringStrategy.Always:\n return false;\n\n case MeasuringStrategy.BeforeDragging:\n return dragging;\n\n default:\n return !dragging;\n }\n }\n}\n\nfunction useInitialValue(value, computeFn) {\n return useLazyMemo(previousValue => {\n if (!value) {\n return null;\n }\n\n if (previousValue) {\n return previousValue;\n }\n\n return typeof computeFn === 'function' ? computeFn(value) : value;\n }, [computeFn, value]);\n}\n\nfunction useInitialRect(node, measure) {\n return useInitialValue(node, measure);\n}\n\n/**\r\n * Returns a new MutationObserver instance.\r\n * If `MutationObserver` is undefined in the execution environment, returns `undefined`.\r\n */\n\nfunction useMutationObserver(_ref) {\n let {\n callback,\n disabled\n } = _ref;\n const handleMutations = useEvent(callback);\n const mutationObserver = useMemo(() => {\n if (disabled || typeof window === 'undefined' || typeof window.MutationObserver === 'undefined') {\n return undefined;\n }\n\n const {\n MutationObserver\n } = window;\n return new MutationObserver(handleMutations);\n }, [handleMutations, disabled]);\n useEffect(() => {\n return () => mutationObserver == null ? void 0 : mutationObserver.disconnect();\n }, [mutationObserver]);\n return mutationObserver;\n}\n\n/**\r\n * Returns a new ResizeObserver instance bound to the `onResize` callback.\r\n * If `ResizeObserver` is undefined in the execution environment, returns `undefined`.\r\n */\n\nfunction useResizeObserver(_ref) {\n let {\n callback,\n disabled\n } = _ref;\n const handleResize = useEvent(callback);\n const resizeObserver = useMemo(() => {\n if (disabled || typeof window === 'undefined' || typeof window.ResizeObserver === 'undefined') {\n return undefined;\n }\n\n const {\n ResizeObserver\n } = window;\n return new ResizeObserver(handleResize);\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [disabled]);\n useEffect(() => {\n return () => resizeObserver == null ? void 0 : resizeObserver.disconnect();\n }, [resizeObserver]);\n return resizeObserver;\n}\n\nfunction defaultMeasure(element) {\n return new Rect(getClientRect(element), element);\n}\n\nfunction useRect(element, measure, fallbackRect) {\n if (measure === void 0) {\n measure = defaultMeasure;\n }\n\n const [rect, setRect] = useState(null);\n\n function measureRect() {\n setRect(currentRect => {\n if (!element) {\n return null;\n }\n\n if (element.isConnected === false) {\n var _ref;\n\n // Fall back to last rect we measured if the element is\n // no longer connected to the DOM.\n return (_ref = currentRect != null ? currentRect : fallbackRect) != null ? _ref : null;\n }\n\n const newRect = measure(element);\n\n if (JSON.stringify(currentRect) === JSON.stringify(newRect)) {\n return currentRect;\n }\n\n return newRect;\n });\n }\n\n const mutationObserver = useMutationObserver({\n callback(records) {\n if (!element) {\n return;\n }\n\n for (const record of records) {\n const {\n type,\n target\n } = record;\n\n if (type === 'childList' && target instanceof HTMLElement && target.contains(element)) {\n measureRect();\n break;\n }\n }\n }\n\n });\n const resizeObserver = useResizeObserver({\n callback: measureRect\n });\n useIsomorphicLayoutEffect(() => {\n measureRect();\n\n if (element) {\n resizeObserver == null ? void 0 : resizeObserver.observe(element);\n mutationObserver == null ? void 0 : mutationObserver.observe(document.body, {\n childList: true,\n subtree: true\n });\n } else {\n resizeObserver == null ? void 0 : resizeObserver.disconnect();\n mutationObserver == null ? void 0 : mutationObserver.disconnect();\n }\n }, [element]);\n return rect;\n}\n\nfunction useRectDelta(rect) {\n const initialRect = useInitialValue(rect);\n return getRectDelta(rect, initialRect);\n}\n\nconst defaultValue$1 = [];\nfunction useScrollableAncestors(node) {\n const previousNode = useRef(node);\n const ancestors = useLazyMemo(previousValue => {\n if (!node) {\n return defaultValue$1;\n }\n\n if (previousValue && previousValue !== defaultValue$1 && node && previousNode.current && node.parentNode === previousNode.current.parentNode) {\n return previousValue;\n }\n\n return getScrollableAncestors(node);\n }, [node]);\n useEffect(() => {\n previousNode.current = node;\n }, [node]);\n return ancestors;\n}\n\nfunction useScrollOffsets(elements) {\n const [scrollCoordinates, setScrollCoordinates] = useState(null);\n const prevElements = useRef(elements); // To-do: Throttle the handleScroll callback\n\n const handleScroll = useCallback(event => {\n const scrollingElement = getScrollableElement(event.target);\n\n if (!scrollingElement) {\n return;\n }\n\n setScrollCoordinates(scrollCoordinates => {\n if (!scrollCoordinates) {\n return null;\n }\n\n scrollCoordinates.set(scrollingElement, getScrollCoordinates(scrollingElement));\n return new Map(scrollCoordinates);\n });\n }, []);\n useEffect(() => {\n const previousElements = prevElements.current;\n\n if (elements !== previousElements) {\n cleanup(previousElements);\n const entries = elements.map(element => {\n const scrollableElement = getScrollableElement(element);\n\n if (scrollableElement) {\n scrollableElement.addEventListener('scroll', handleScroll, {\n passive: true\n });\n return [scrollableElement, getScrollCoordinates(scrollableElement)];\n }\n\n return null;\n }).filter(entry => entry != null);\n setScrollCoordinates(entries.length ? new Map(entries) : null);\n prevElements.current = elements;\n }\n\n return () => {\n cleanup(elements);\n cleanup(previousElements);\n };\n\n function cleanup(elements) {\n elements.forEach(element => {\n const scrollableElement = getScrollableElement(element);\n scrollableElement == null ? void 0 : scrollableElement.removeEventListener('scroll', handleScroll);\n });\n }\n }, [handleScroll, elements]);\n return useMemo(() => {\n if (elements.length) {\n return scrollCoordinates ? Array.from(scrollCoordinates.values()).reduce((acc, coordinates) => add(acc, coordinates), defaultCoordinates) : getScrollOffsets(elements);\n }\n\n return defaultCoordinates;\n }, [elements, scrollCoordinates]);\n}\n\nfunction useScrollOffsetsDelta(scrollOffsets, dependencies) {\n if (dependencies === void 0) {\n dependencies = [];\n }\n\n const initialScrollOffsets = useRef(null);\n useEffect(() => {\n initialScrollOffsets.current = null;\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n dependencies);\n useEffect(() => {\n const hasScrollOffsets = scrollOffsets !== defaultCoordinates;\n\n if (hasScrollOffsets && !initialScrollOffsets.current) {\n initialScrollOffsets.current = scrollOffsets;\n }\n\n if (!hasScrollOffsets && initialScrollOffsets.current) {\n initialScrollOffsets.current = null;\n }\n }, [scrollOffsets]);\n return initialScrollOffsets.current ? subtract(scrollOffsets, initialScrollOffsets.current) : defaultCoordinates;\n}\n\nfunction useSensorSetup(sensors) {\n useEffect(() => {\n if (!canUseDOM) {\n return;\n }\n\n const teardownFns = sensors.map(_ref => {\n let {\n sensor\n } = _ref;\n return sensor.setup == null ? void 0 : sensor.setup();\n });\n return () => {\n for (const teardown of teardownFns) {\n teardown == null ? void 0 : teardown();\n }\n };\n }, // TO-DO: Sensors length could theoretically change which would not be a valid dependency\n // eslint-disable-next-line react-hooks/exhaustive-deps\n sensors.map(_ref2 => {\n let {\n sensor\n } = _ref2;\n return sensor;\n }));\n}\n\nfunction useSyntheticListeners(listeners, id) {\n return useMemo(() => {\n return listeners.reduce((acc, _ref) => {\n let {\n eventName,\n handler\n } = _ref;\n\n acc[eventName] = event => {\n handler(event, id);\n };\n\n return acc;\n }, {});\n }, [listeners, id]);\n}\n\nfunction useWindowRect(element) {\n return useMemo(() => element ? getWindowClientRect(element) : null, [element]);\n}\n\nconst defaultValue$2 = [];\nfunction useRects(elements, measure) {\n if (measure === void 0) {\n measure = getClientRect;\n }\n\n const [firstElement] = elements;\n const windowRect = useWindowRect(firstElement ? getWindow(firstElement) : null);\n const [rects, setRects] = useState(defaultValue$2);\n\n function measureRects() {\n setRects(() => {\n if (!elements.length) {\n return defaultValue$2;\n }\n\n return elements.map(element => isDocumentScrollingElement(element) ? windowRect : new Rect(measure(element), element));\n });\n }\n\n const resizeObserver = useResizeObserver({\n callback: measureRects\n });\n useIsomorphicLayoutEffect(() => {\n resizeObserver == null ? void 0 : resizeObserver.disconnect();\n measureRects();\n elements.forEach(element => resizeObserver == null ? void 0 : resizeObserver.observe(element));\n }, [elements]);\n return rects;\n}\n\nfunction getMeasurableNode(node) {\n if (!node) {\n return null;\n }\n\n if (node.children.length > 1) {\n return node;\n }\n\n const firstChild = node.children[0];\n return isHTMLElement(firstChild) ? firstChild : node;\n}\n\nfunction useDragOverlayMeasuring(_ref) {\n let {\n measure\n } = _ref;\n const [rect, setRect] = useState(null);\n const handleResize = useCallback(entries => {\n for (const {\n target\n } of entries) {\n if (isHTMLElement(target)) {\n setRect(rect => {\n const newRect = measure(target);\n return rect ? { ...rect,\n width: newRect.width,\n height: newRect.height\n } : newRect;\n });\n break;\n }\n }\n }, [measure]);\n const resizeObserver = useResizeObserver({\n callback: handleResize\n });\n const handleNodeChange = useCallback(element => {\n const node = getMeasurableNode(element);\n resizeObserver == null ? void 0 : resizeObserver.disconnect();\n\n if (node) {\n resizeObserver == null ? void 0 : resizeObserver.observe(node);\n }\n\n setRect(node ? measure(node) : null);\n }, [measure, resizeObserver]);\n const [nodeRef, setRef] = useNodeRef(handleNodeChange);\n return useMemo(() => ({\n nodeRef,\n rect,\n setRef\n }), [rect, nodeRef, setRef]);\n}\n\nconst defaultSensors = [{\n sensor: PointerSensor,\n options: {}\n}, {\n sensor: KeyboardSensor,\n options: {}\n}];\nconst defaultData = {\n current: {}\n};\nconst defaultMeasuringConfiguration = {\n draggable: {\n measure: getTransformAgnosticClientRect\n },\n droppable: {\n measure: getTransformAgnosticClientRect,\n strategy: MeasuringStrategy.WhileDragging,\n frequency: MeasuringFrequency.Optimized\n },\n dragOverlay: {\n measure: getClientRect\n }\n};\n\nclass DroppableContainersMap extends Map {\n get(id) {\n var _super$get;\n\n return id != null ? (_super$get = super.get(id)) != null ? _super$get : undefined : undefined;\n }\n\n toArray() {\n return Array.from(this.values());\n }\n\n getEnabled() {\n return this.toArray().filter(_ref => {\n let {\n disabled\n } = _ref;\n return !disabled;\n });\n }\n\n getNodeFor(id) {\n var _this$get$node$curren, _this$get;\n\n return (_this$get$node$curren = (_this$get = this.get(id)) == null ? void 0 : _this$get.node.current) != null ? _this$get$node$curren : undefined;\n }\n\n}\n\nconst defaultPublicContext = {\n activatorEvent: null,\n active: null,\n activeNode: null,\n activeNodeRect: null,\n collisions: null,\n containerNodeRect: null,\n draggableNodes: /*#__PURE__*/new Map(),\n droppableRects: /*#__PURE__*/new Map(),\n droppableContainers: /*#__PURE__*/new DroppableContainersMap(),\n over: null,\n dragOverlay: {\n nodeRef: {\n current: null\n },\n rect: null,\n setRef: noop\n },\n scrollableAncestors: [],\n scrollableAncestorRects: [],\n measuringConfiguration: defaultMeasuringConfiguration,\n measureDroppableContainers: noop,\n windowRect: null,\n measuringScheduled: false\n};\nconst defaultInternalContext = {\n activatorEvent: null,\n activators: [],\n active: null,\n activeNodeRect: null,\n ariaDescribedById: {\n draggable: ''\n },\n dispatch: noop,\n draggableNodes: /*#__PURE__*/new Map(),\n over: null,\n measureDroppableContainers: noop\n};\nconst InternalContext = /*#__PURE__*/createContext(defaultInternalContext);\nconst PublicContext = /*#__PURE__*/createContext(defaultPublicContext);\n\nfunction getInitialState() {\n return {\n draggable: {\n active: null,\n initialCoordinates: {\n x: 0,\n y: 0\n },\n nodes: new Map(),\n translate: {\n x: 0,\n y: 0\n }\n },\n droppable: {\n containers: new DroppableContainersMap()\n }\n };\n}\nfunction reducer(state, action) {\n switch (action.type) {\n case Action.DragStart:\n return { ...state,\n draggable: { ...state.draggable,\n initialCoordinates: action.initialCoordinates,\n active: action.active\n }\n };\n\n case Action.DragMove:\n if (state.draggable.active == null) {\n return state;\n }\n\n return { ...state,\n draggable: { ...state.draggable,\n translate: {\n x: action.coordinates.x - state.draggable.initialCoordinates.x,\n y: action.coordinates.y - state.draggable.initialCoordinates.y\n }\n }\n };\n\n case Action.DragEnd:\n case Action.DragCancel:\n return { ...state,\n draggable: { ...state.draggable,\n active: null,\n initialCoordinates: {\n x: 0,\n y: 0\n },\n translate: {\n x: 0,\n y: 0\n }\n }\n };\n\n case Action.RegisterDroppable:\n {\n const {\n element\n } = action;\n const {\n id\n } = element;\n const containers = new DroppableContainersMap(state.droppable.containers);\n containers.set(id, element);\n return { ...state,\n droppable: { ...state.droppable,\n containers\n }\n };\n }\n\n case Action.SetDroppableDisabled:\n {\n const {\n id,\n key,\n disabled\n } = action;\n const element = state.droppable.containers.get(id);\n\n if (!element || key !== element.key) {\n return state;\n }\n\n const containers = new DroppableContainersMap(state.droppable.containers);\n containers.set(id, { ...element,\n disabled\n });\n return { ...state,\n droppable: { ...state.droppable,\n containers\n }\n };\n }\n\n case Action.UnregisterDroppable:\n {\n const {\n id,\n key\n } = action;\n const element = state.droppable.containers.get(id);\n\n if (!element || key !== element.key) {\n return state;\n }\n\n const containers = new DroppableContainersMap(state.droppable.containers);\n containers.delete(id);\n return { ...state,\n droppable: { ...state.droppable,\n containers\n }\n };\n }\n\n default:\n {\n return state;\n }\n }\n}\n\nfunction RestoreFocus(_ref) {\n let {\n disabled\n } = _ref;\n const {\n active,\n activatorEvent,\n draggableNodes\n } = useContext(InternalContext);\n const previousActivatorEvent = usePrevious(activatorEvent);\n const previousActiveId = usePrevious(active == null ? void 0 : active.id); // Restore keyboard focus on the activator node\n\n useEffect(() => {\n if (disabled) {\n return;\n }\n\n if (!activatorEvent && previousActivatorEvent && previousActiveId != null) {\n if (!isKeyboardEvent(previousActivatorEvent)) {\n return;\n }\n\n if (document.activeElement === previousActivatorEvent.target) {\n // No need to restore focus\n return;\n }\n\n const draggableNode = draggableNodes.get(previousActiveId);\n\n if (!draggableNode) {\n return;\n }\n\n const {\n activatorNode,\n node\n } = draggableNode;\n\n if (!activatorNode.current && !node.current) {\n return;\n }\n\n requestAnimationFrame(() => {\n for (const element of [activatorNode.current, node.current]) {\n if (!element) {\n continue;\n }\n\n const focusableNode = findFirstFocusableNode(element);\n\n if (focusableNode) {\n focusableNode.focus();\n break;\n }\n }\n });\n }\n }, [activatorEvent, disabled, draggableNodes, previousActiveId, previousActivatorEvent]);\n return null;\n}\n\nfunction applyModifiers(modifiers, _ref) {\n let {\n transform,\n ...args\n } = _ref;\n return modifiers != null && modifiers.length ? modifiers.reduce((accumulator, modifier) => {\n return modifier({\n transform: accumulator,\n ...args\n });\n }, transform) : transform;\n}\n\nfunction useMeasuringConfiguration(config) {\n return useMemo(() => ({\n draggable: { ...defaultMeasuringConfiguration.draggable,\n ...(config == null ? void 0 : config.draggable)\n },\n droppable: { ...defaultMeasuringConfiguration.droppable,\n ...(config == null ? void 0 : config.droppable)\n },\n dragOverlay: { ...defaultMeasuringConfiguration.dragOverlay,\n ...(config == null ? void 0 : config.dragOverlay)\n }\n }), // eslint-disable-next-line react-hooks/exhaustive-deps\n [config == null ? void 0 : config.draggable, config == null ? void 0 : config.droppable, config == null ? void 0 : config.dragOverlay]);\n}\n\nfunction useLayoutShiftScrollCompensation(_ref) {\n let {\n activeNode,\n measure,\n initialRect,\n config = true\n } = _ref;\n const initialized = useRef(false);\n const {\n x,\n y\n } = typeof config === 'boolean' ? {\n x: config,\n y: config\n } : config;\n useIsomorphicLayoutEffect(() => {\n const disabled = !x && !y;\n\n if (disabled || !activeNode) {\n initialized.current = false;\n return;\n }\n\n if (initialized.current || !initialRect) {\n // Return early if layout shift scroll compensation was already attempted\n // or if there is no initialRect to compare to.\n return;\n } // Get the most up to date node ref for the active draggable\n\n\n const node = activeNode == null ? void 0 : activeNode.node.current;\n\n if (!node || node.isConnected === false) {\n // Return early if there is no attached node ref or if the node is\n // disconnected from the document.\n return;\n }\n\n const rect = measure(node);\n const rectDelta = getRectDelta(rect, initialRect);\n\n if (!x) {\n rectDelta.x = 0;\n }\n\n if (!y) {\n rectDelta.y = 0;\n } // Only perform layout shift scroll compensation once\n\n\n initialized.current = true;\n\n if (Math.abs(rectDelta.x) > 0 || Math.abs(rectDelta.y) > 0) {\n const firstScrollableAncestor = getFirstScrollableAncestor(node);\n\n if (firstScrollableAncestor) {\n firstScrollableAncestor.scrollBy({\n top: rectDelta.y,\n left: rectDelta.x\n });\n }\n }\n }, [activeNode, x, y, initialRect, measure]);\n}\n\nconst ActiveDraggableContext = /*#__PURE__*/createContext({ ...defaultCoordinates,\n scaleX: 1,\n scaleY: 1\n});\nvar Status;\n\n(function (Status) {\n Status[Status[\"Uninitialized\"] = 0] = \"Uninitialized\";\n Status[Status[\"Initializing\"] = 1] = \"Initializing\";\n Status[Status[\"Initialized\"] = 2] = \"Initialized\";\n})(Status || (Status = {}));\n\nconst DndContext = /*#__PURE__*/memo(function DndContext(_ref) {\n var _sensorContext$curren, _dragOverlay$nodeRef$, _dragOverlay$rect, _over$rect;\n\n let {\n id,\n accessibility,\n autoScroll = true,\n children,\n sensors = defaultSensors,\n collisionDetection = rectIntersection,\n measuring,\n modifiers,\n ...props\n } = _ref;\n const store = useReducer(reducer, undefined, getInitialState);\n const [state, dispatch] = store;\n const [dispatchMonitorEvent, registerMonitorListener] = useDndMonitorProvider();\n const [status, setStatus] = useState(Status.Uninitialized);\n const isInitialized = status === Status.Initialized;\n const {\n draggable: {\n active: activeId,\n nodes: draggableNodes,\n translate\n },\n droppable: {\n containers: droppableContainers\n }\n } = state;\n const node = activeId != null ? draggableNodes.get(activeId) : null;\n const activeRects = useRef({\n initial: null,\n translated: null\n });\n const active = useMemo(() => {\n var _node$data;\n\n return activeId != null ? {\n id: activeId,\n // It's possible for the active node to unmount while dragging\n data: (_node$data = node == null ? void 0 : node.data) != null ? _node$data : defaultData,\n rect: activeRects\n } : null;\n }, [activeId, node]);\n const activeRef = useRef(null);\n const [activeSensor, setActiveSensor] = useState(null);\n const [activatorEvent, setActivatorEvent] = useState(null);\n const latestProps = useLatestValue(props, Object.values(props));\n const draggableDescribedById = useUniqueId(\"DndDescribedBy\", id);\n const enabledDroppableContainers = useMemo(() => droppableContainers.getEnabled(), [droppableContainers]);\n const measuringConfiguration = useMeasuringConfiguration(measuring);\n const {\n droppableRects,\n measureDroppableContainers,\n measuringScheduled\n } = useDroppableMeasuring(enabledDroppableContainers, {\n dragging: isInitialized,\n dependencies: [translate.x, translate.y],\n config: measuringConfiguration.droppable\n });\n const activeNode = useCachedNode(draggableNodes, activeId);\n const activationCoordinates = useMemo(() => activatorEvent ? getEventCoordinates(activatorEvent) : null, [activatorEvent]);\n const autoScrollOptions = getAutoScrollerOptions();\n const initialActiveNodeRect = useInitialRect(activeNode, measuringConfiguration.draggable.measure);\n useLayoutShiftScrollCompensation({\n activeNode: activeId != null ? draggableNodes.get(activeId) : null,\n config: autoScrollOptions.layoutShiftCompensation,\n initialRect: initialActiveNodeRect,\n measure: measuringConfiguration.draggable.measure\n });\n const activeNodeRect = useRect(activeNode, measuringConfiguration.draggable.measure, initialActiveNodeRect);\n const containerNodeRect = useRect(activeNode ? activeNode.parentElement : null);\n const sensorContext = useRef({\n activatorEvent: null,\n active: null,\n activeNode,\n collisionRect: null,\n collisions: null,\n droppableRects,\n draggableNodes,\n draggingNode: null,\n draggingNodeRect: null,\n droppableContainers,\n over: null,\n scrollableAncestors: [],\n scrollAdjustedTranslate: null\n });\n const overNode = droppableContainers.getNodeFor((_sensorContext$curren = sensorContext.current.over) == null ? void 0 : _sensorContext$curren.id);\n const dragOverlay = useDragOverlayMeasuring({\n measure: measuringConfiguration.dragOverlay.measure\n }); // Use the rect of the drag overlay if it is mounted\n\n const draggingNode = (_dragOverlay$nodeRef$ = dragOverlay.nodeRef.current) != null ? _dragOverlay$nodeRef$ : activeNode;\n const draggingNodeRect = isInitialized ? (_dragOverlay$rect = dragOverlay.rect) != null ? _dragOverlay$rect : activeNodeRect : null;\n const usesDragOverlay = Boolean(dragOverlay.nodeRef.current && dragOverlay.rect); // The delta between the previous and new position of the draggable node\n // is only relevant when there is no drag overlay\n\n const nodeRectDelta = useRectDelta(usesDragOverlay ? null : activeNodeRect); // Get the window rect of the dragging node\n\n const windowRect = useWindowRect(draggingNode ? getWindow(draggingNode) : null); // Get scrollable ancestors of the dragging node\n\n const scrollableAncestors = useScrollableAncestors(isInitialized ? overNode != null ? overNode : activeNode : null);\n const scrollableAncestorRects = useRects(scrollableAncestors); // Apply modifiers\n\n const modifiedTranslate = applyModifiers(modifiers, {\n transform: {\n x: translate.x - nodeRectDelta.x,\n y: translate.y - nodeRectDelta.y,\n scaleX: 1,\n scaleY: 1\n },\n activatorEvent,\n active,\n activeNodeRect,\n containerNodeRect,\n draggingNodeRect,\n over: sensorContext.current.over,\n overlayNodeRect: dragOverlay.rect,\n scrollableAncestors,\n scrollableAncestorRects,\n windowRect\n });\n const pointerCoordinates = activationCoordinates ? add(activationCoordinates, translate) : null;\n const scrollOffsets = useScrollOffsets(scrollableAncestors); // Represents the scroll delta since dragging was initiated\n\n const scrollAdjustment = useScrollOffsetsDelta(scrollOffsets); // Represents the scroll delta since the last time the active node rect was measured\n\n const activeNodeScrollDelta = useScrollOffsetsDelta(scrollOffsets, [activeNodeRect]);\n const scrollAdjustedTranslate = add(modifiedTranslate, scrollAdjustment);\n const collisionRect = draggingNodeRect ? getAdjustedRect(draggingNodeRect, modifiedTranslate) : null;\n const collisions = active && collisionRect ? collisionDetection({\n active,\n collisionRect,\n droppableRects,\n droppableContainers: enabledDroppableContainers,\n pointerCoordinates\n }) : null;\n const overId = getFirstCollision(collisions, 'id');\n const [over, setOver] = useState(null); // When there is no drag overlay used, we need to account for the\n // window scroll delta\n\n const appliedTranslate = usesDragOverlay ? modifiedTranslate : add(modifiedTranslate, activeNodeScrollDelta);\n const transform = adjustScale(appliedTranslate, (_over$rect = over == null ? void 0 : over.rect) != null ? _over$rect : null, activeNodeRect);\n const activeSensorRef = useRef(null);\n const instantiateSensor = useCallback((event, _ref2) => {\n let {\n sensor: Sensor,\n options\n } = _ref2;\n\n if (activeRef.current == null) {\n return;\n }\n\n const activeNode = draggableNodes.get(activeRef.current);\n\n if (!activeNode) {\n return;\n }\n\n const activatorEvent = event.nativeEvent;\n const sensorInstance = new Sensor({\n active: activeRef.current,\n activeNode,\n event: activatorEvent,\n options,\n // Sensors need to be instantiated with refs for arguments that change over time\n // otherwise they are frozen in time with the stale arguments\n context: sensorContext,\n\n onAbort(id) {\n const draggableNode = draggableNodes.get(id);\n\n if (!draggableNode) {\n return;\n }\n\n const {\n onDragAbort\n } = latestProps.current;\n const event = {\n id\n };\n onDragAbort == null ? void 0 : onDragAbort(event);\n dispatchMonitorEvent({\n type: 'onDragAbort',\n event\n });\n },\n\n onPending(id, constraint, initialCoordinates, offset) {\n const draggableNode = draggableNodes.get(id);\n\n if (!draggableNode) {\n return;\n }\n\n const {\n onDragPending\n } = latestProps.current;\n const event = {\n id,\n constraint,\n initialCoordinates,\n offset\n };\n onDragPending == null ? void 0 : onDragPending(event);\n dispatchMonitorEvent({\n type: 'onDragPending',\n event\n });\n },\n\n onStart(initialCoordinates) {\n const id = activeRef.current;\n\n if (id == null) {\n return;\n }\n\n const draggableNode = draggableNodes.get(id);\n\n if (!draggableNode) {\n return;\n }\n\n const {\n onDragStart\n } = latestProps.current;\n const event = {\n activatorEvent,\n active: {\n id,\n data: draggableNode.data,\n rect: activeRects\n }\n };\n unstable_batchedUpdates(() => {\n onDragStart == null ? void 0 : onDragStart(event);\n setStatus(Status.Initializing);\n dispatch({\n type: Action.DragStart,\n initialCoordinates,\n active: id\n });\n dispatchMonitorEvent({\n type: 'onDragStart',\n event\n });\n setActiveSensor(activeSensorRef.current);\n setActivatorEvent(activatorEvent);\n });\n },\n\n onMove(coordinates) {\n dispatch({\n type: Action.DragMove,\n coordinates\n });\n },\n\n onEnd: createHandler(Action.DragEnd),\n onCancel: createHandler(Action.DragCancel)\n });\n activeSensorRef.current = sensorInstance;\n\n function createHandler(type) {\n return async function handler() {\n const {\n active,\n collisions,\n over,\n scrollAdjustedTranslate\n } = sensorContext.current;\n let event = null;\n\n if (active && scrollAdjustedTranslate) {\n const {\n cancelDrop\n } = latestProps.current;\n event = {\n activatorEvent,\n active: active,\n collisions,\n delta: scrollAdjustedTranslate,\n over\n };\n\n if (type === Action.DragEnd && typeof cancelDrop === 'function') {\n const shouldCancel = await Promise.resolve(cancelDrop(event));\n\n if (shouldCancel) {\n type = Action.DragCancel;\n }\n }\n }\n\n activeRef.current = null;\n unstable_batchedUpdates(() => {\n dispatch({\n type\n });\n setStatus(Status.Uninitialized);\n setOver(null);\n setActiveSensor(null);\n setActivatorEvent(null);\n activeSensorRef.current = null;\n const eventName = type === Action.DragEnd ? 'onDragEnd' : 'onDragCancel';\n\n if (event) {\n const handler = latestProps.current[eventName];\n handler == null ? void 0 : handler(event);\n dispatchMonitorEvent({\n type: eventName,\n event\n });\n }\n });\n };\n }\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [draggableNodes]);\n const bindActivatorToSensorInstantiator = useCallback((handler, sensor) => {\n return (event, active) => {\n const nativeEvent = event.nativeEvent;\n const activeDraggableNode = draggableNodes.get(active);\n\n if ( // Another sensor is already instantiating\n activeRef.current !== null || // No active draggable\n !activeDraggableNode || // Event has already been captured\n nativeEvent.dndKit || nativeEvent.defaultPrevented) {\n return;\n }\n\n const activationContext = {\n active: activeDraggableNode\n };\n const shouldActivate = handler(event, sensor.options, activationContext);\n\n if (shouldActivate === true) {\n nativeEvent.dndKit = {\n capturedBy: sensor.sensor\n };\n activeRef.current = active;\n instantiateSensor(event, sensor);\n }\n };\n }, [draggableNodes, instantiateSensor]);\n const activators = useCombineActivators(sensors, bindActivatorToSensorInstantiator);\n useSensorSetup(sensors);\n useIsomorphicLayoutEffect(() => {\n if (activeNodeRect && status === Status.Initializing) {\n setStatus(Status.Initialized);\n }\n }, [activeNodeRect, status]);\n useEffect(() => {\n const {\n onDragMove\n } = latestProps.current;\n const {\n active,\n activatorEvent,\n collisions,\n over\n } = sensorContext.current;\n\n if (!active || !activatorEvent) {\n return;\n }\n\n const event = {\n active,\n activatorEvent,\n collisions,\n delta: {\n x: scrollAdjustedTranslate.x,\n y: scrollAdjustedTranslate.y\n },\n over\n };\n unstable_batchedUpdates(() => {\n onDragMove == null ? void 0 : onDragMove(event);\n dispatchMonitorEvent({\n type: 'onDragMove',\n event\n });\n });\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [scrollAdjustedTranslate.x, scrollAdjustedTranslate.y]);\n useEffect(() => {\n const {\n active,\n activatorEvent,\n collisions,\n droppableContainers,\n scrollAdjustedTranslate\n } = sensorContext.current;\n\n if (!active || activeRef.current == null || !activatorEvent || !scrollAdjustedTranslate) {\n return;\n }\n\n const {\n onDragOver\n } = latestProps.current;\n const overContainer = droppableContainers.get(overId);\n const over = overContainer && overContainer.rect.current ? {\n id: overContainer.id,\n rect: overContainer.rect.current,\n data: overContainer.data,\n disabled: overContainer.disabled\n } : null;\n const event = {\n active,\n activatorEvent,\n collisions,\n delta: {\n x: scrollAdjustedTranslate.x,\n y: scrollAdjustedTranslate.y\n },\n over\n };\n unstable_batchedUpdates(() => {\n setOver(over);\n onDragOver == null ? void 0 : onDragOver(event);\n dispatchMonitorEvent({\n type: 'onDragOver',\n event\n });\n });\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [overId]);\n useIsomorphicLayoutEffect(() => {\n sensorContext.current = {\n activatorEvent,\n active,\n activeNode,\n collisionRect,\n collisions,\n droppableRects,\n draggableNodes,\n draggingNode,\n draggingNodeRect,\n droppableContainers,\n over,\n scrollableAncestors,\n scrollAdjustedTranslate\n };\n activeRects.current = {\n initial: draggingNodeRect,\n translated: collisionRect\n };\n }, [active, activeNode, collisions, collisionRect, draggableNodes, draggingNode, draggingNodeRect, droppableRects, droppableContainers, over, scrollableAncestors, scrollAdjustedTranslate]);\n useAutoScroller({ ...autoScrollOptions,\n delta: translate,\n draggingRect: collisionRect,\n pointerCoordinates,\n scrollableAncestors,\n scrollableAncestorRects\n });\n const publicContext = useMemo(() => {\n const context = {\n active,\n activeNode,\n activeNodeRect,\n activatorEvent,\n collisions,\n containerNodeRect,\n dragOverlay,\n draggableNodes,\n droppableContainers,\n droppableRects,\n over,\n measureDroppableContainers,\n scrollableAncestors,\n scrollableAncestorRects,\n measuringConfiguration,\n measuringScheduled,\n windowRect\n };\n return context;\n }, [active, activeNode, activeNodeRect, activatorEvent, collisions, containerNodeRect, dragOverlay, draggableNodes, droppableContainers, droppableRects, over, measureDroppableContainers, scrollableAncestors, scrollableAncestorRects, measuringConfiguration, measuringScheduled, windowRect]);\n const internalContext = useMemo(() => {\n const context = {\n activatorEvent,\n activators,\n active,\n activeNodeRect,\n ariaDescribedById: {\n draggable: draggableDescribedById\n },\n dispatch,\n draggableNodes,\n over,\n measureDroppableContainers\n };\n return context;\n }, [activatorEvent, activators, active, activeNodeRect, dispatch, draggableDescribedById, draggableNodes, over, measureDroppableContainers]);\n return React.createElement(DndMonitorContext.Provider, {\n value: registerMonitorListener\n }, React.createElement(InternalContext.Provider, {\n value: internalContext\n }, React.createElement(PublicContext.Provider, {\n value: publicContext\n }, React.createElement(ActiveDraggableContext.Provider, {\n value: transform\n }, children)), React.createElement(RestoreFocus, {\n disabled: (accessibility == null ? void 0 : accessibility.restoreFocus) === false\n })), React.createElement(Accessibility, { ...accessibility,\n hiddenTextDescribedById: draggableDescribedById\n }));\n\n function getAutoScrollerOptions() {\n const activeSensorDisablesAutoscroll = (activeSensor == null ? void 0 : activeSensor.autoScrollEnabled) === false;\n const autoScrollGloballyDisabled = typeof autoScroll === 'object' ? autoScroll.enabled === false : autoScroll === false;\n const enabled = isInitialized && !activeSensorDisablesAutoscroll && !autoScrollGloballyDisabled;\n\n if (typeof autoScroll === 'object') {\n return { ...autoScroll,\n enabled\n };\n }\n\n return {\n enabled\n };\n }\n});\n\nconst NullContext = /*#__PURE__*/createContext(null);\nconst defaultRole = 'button';\nconst ID_PREFIX = 'Draggable';\nfunction useDraggable(_ref) {\n let {\n id,\n data,\n disabled = false,\n attributes\n } = _ref;\n const key = useUniqueId(ID_PREFIX);\n const {\n activators,\n activatorEvent,\n active,\n activeNodeRect,\n ariaDescribedById,\n draggableNodes,\n over\n } = useContext(InternalContext);\n const {\n role = defaultRole,\n roleDescription = 'draggable',\n tabIndex = 0\n } = attributes != null ? attributes : {};\n const isDragging = (active == null ? void 0 : active.id) === id;\n const transform = useContext(isDragging ? ActiveDraggableContext : NullContext);\n const [node, setNodeRef] = useNodeRef();\n const [activatorNode, setActivatorNodeRef] = useNodeRef();\n const listeners = useSyntheticListeners(activators, id);\n const dataRef = useLatestValue(data);\n useIsomorphicLayoutEffect(() => {\n draggableNodes.set(id, {\n id,\n key,\n node,\n activatorNode,\n data: dataRef\n });\n return () => {\n const node = draggableNodes.get(id);\n\n if (node && node.key === key) {\n draggableNodes.delete(id);\n }\n };\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [draggableNodes, id]);\n const memoizedAttributes = useMemo(() => ({\n role,\n tabIndex,\n 'aria-disabled': disabled,\n 'aria-pressed': isDragging && role === defaultRole ? true : undefined,\n 'aria-roledescription': roleDescription,\n 'aria-describedby': ariaDescribedById.draggable\n }), [disabled, role, tabIndex, isDragging, roleDescription, ariaDescribedById.draggable]);\n return {\n active,\n activatorEvent,\n activeNodeRect,\n attributes: memoizedAttributes,\n isDragging,\n listeners: disabled ? undefined : listeners,\n node,\n over,\n setNodeRef,\n setActivatorNodeRef,\n transform\n };\n}\n\nfunction useDndContext() {\n return useContext(PublicContext);\n}\n\nconst ID_PREFIX$1 = 'Droppable';\nconst defaultResizeObserverConfig = {\n timeout: 25\n};\nfunction useDroppable(_ref) {\n let {\n data,\n disabled = false,\n id,\n resizeObserverConfig\n } = _ref;\n const key = useUniqueId(ID_PREFIX$1);\n const {\n active,\n dispatch,\n over,\n measureDroppableContainers\n } = useContext(InternalContext);\n const previous = useRef({\n disabled\n });\n const resizeObserverConnected = useRef(false);\n const rect = useRef(null);\n const callbackId = useRef(null);\n const {\n disabled: resizeObserverDisabled,\n updateMeasurementsFor,\n timeout: resizeObserverTimeout\n } = { ...defaultResizeObserverConfig,\n ...resizeObserverConfig\n };\n const ids = useLatestValue(updateMeasurementsFor != null ? updateMeasurementsFor : id);\n const handleResize = useCallback(() => {\n if (!resizeObserverConnected.current) {\n // ResizeObserver invokes the `handleResize` callback as soon as `observe` is called,\n // assuming the element is rendered and displayed.\n resizeObserverConnected.current = true;\n return;\n }\n\n if (callbackId.current != null) {\n clearTimeout(callbackId.current);\n }\n\n callbackId.current = setTimeout(() => {\n measureDroppableContainers(Array.isArray(ids.current) ? ids.current : [ids.current]);\n callbackId.current = null;\n }, resizeObserverTimeout);\n }, //eslint-disable-next-line react-hooks/exhaustive-deps\n [resizeObserverTimeout]);\n const resizeObserver = useResizeObserver({\n callback: handleResize,\n disabled: resizeObserverDisabled || !active\n });\n const handleNodeChange = useCallback((newElement, previousElement) => {\n if (!resizeObserver) {\n return;\n }\n\n if (previousElement) {\n resizeObserver.unobserve(previousElement);\n resizeObserverConnected.current = false;\n }\n\n if (newElement) {\n resizeObserver.observe(newElement);\n }\n }, [resizeObserver]);\n const [nodeRef, setNodeRef] = useNodeRef(handleNodeChange);\n const dataRef = useLatestValue(data);\n useEffect(() => {\n if (!resizeObserver || !nodeRef.current) {\n return;\n }\n\n resizeObserver.disconnect();\n resizeObserverConnected.current = false;\n resizeObserver.observe(nodeRef.current);\n }, [nodeRef, resizeObserver]);\n useEffect(() => {\n dispatch({\n type: Action.RegisterDroppable,\n element: {\n id,\n key,\n disabled,\n node: nodeRef,\n rect,\n data: dataRef\n }\n });\n return () => dispatch({\n type: Action.UnregisterDroppable,\n key,\n id\n });\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [id]);\n useEffect(() => {\n if (disabled !== previous.current.disabled) {\n dispatch({\n type: Action.SetDroppableDisabled,\n id,\n key,\n disabled\n });\n previous.current.disabled = disabled;\n }\n }, [id, key, disabled, dispatch]);\n return {\n active,\n rect,\n isOver: (over == null ? void 0 : over.id) === id,\n node: nodeRef,\n over,\n setNodeRef\n };\n}\n\nfunction AnimationManager(_ref) {\n let {\n animation,\n children\n } = _ref;\n const [clonedChildren, setClonedChildren] = useState(null);\n const [element, setElement] = useState(null);\n const previousChildren = usePrevious(children);\n\n if (!children && !clonedChildren && previousChildren) {\n setClonedChildren(previousChildren);\n }\n\n useIsomorphicLayoutEffect(() => {\n if (!element) {\n return;\n }\n\n const key = clonedChildren == null ? void 0 : clonedChildren.key;\n const id = clonedChildren == null ? void 0 : clonedChildren.props.id;\n\n if (key == null || id == null) {\n setClonedChildren(null);\n return;\n }\n\n Promise.resolve(animation(id, element)).then(() => {\n setClonedChildren(null);\n });\n }, [animation, clonedChildren, element]);\n return React.createElement(React.Fragment, null, children, clonedChildren ? cloneElement(clonedChildren, {\n ref: setElement\n }) : null);\n}\n\nconst defaultTransform = {\n x: 0,\n y: 0,\n scaleX: 1,\n scaleY: 1\n};\nfunction NullifiedContextProvider(_ref) {\n let {\n children\n } = _ref;\n return React.createElement(InternalContext.Provider, {\n value: defaultInternalContext\n }, React.createElement(ActiveDraggableContext.Provider, {\n value: defaultTransform\n }, children));\n}\n\nconst baseStyles = {\n position: 'fixed',\n touchAction: 'none'\n};\n\nconst defaultTransition = activatorEvent => {\n const isKeyboardActivator = isKeyboardEvent(activatorEvent);\n return isKeyboardActivator ? 'transform 250ms ease' : undefined;\n};\n\nconst PositionedOverlay = /*#__PURE__*/forwardRef((_ref, ref) => {\n let {\n as,\n activatorEvent,\n adjustScale,\n children,\n className,\n rect,\n style,\n transform,\n transition = defaultTransition\n } = _ref;\n\n if (!rect) {\n return null;\n }\n\n const scaleAdjustedTransform = adjustScale ? transform : { ...transform,\n scaleX: 1,\n scaleY: 1\n };\n const styles = { ...baseStyles,\n width: rect.width,\n height: rect.height,\n top: rect.top,\n left: rect.left,\n transform: CSS.Transform.toString(scaleAdjustedTransform),\n transformOrigin: adjustScale && activatorEvent ? getRelativeTransformOrigin(activatorEvent, rect) : undefined,\n transition: typeof transition === 'function' ? transition(activatorEvent) : transition,\n ...style\n };\n return React.createElement(as, {\n className,\n style: styles,\n ref\n }, children);\n});\n\nconst defaultDropAnimationSideEffects = options => _ref => {\n let {\n active,\n dragOverlay\n } = _ref;\n const originalStyles = {};\n const {\n styles,\n className\n } = options;\n\n if (styles != null && styles.active) {\n for (const [key, value] of Object.entries(styles.active)) {\n if (value === undefined) {\n continue;\n }\n\n originalStyles[key] = active.node.style.getPropertyValue(key);\n active.node.style.setProperty(key, value);\n }\n }\n\n if (styles != null && styles.dragOverlay) {\n for (const [key, value] of Object.entries(styles.dragOverlay)) {\n if (value === undefined) {\n continue;\n }\n\n dragOverlay.node.style.setProperty(key, value);\n }\n }\n\n if (className != null && className.active) {\n active.node.classList.add(className.active);\n }\n\n if (className != null && className.dragOverlay) {\n dragOverlay.node.classList.add(className.dragOverlay);\n }\n\n return function cleanup() {\n for (const [key, value] of Object.entries(originalStyles)) {\n active.node.style.setProperty(key, value);\n }\n\n if (className != null && className.active) {\n active.node.classList.remove(className.active);\n }\n };\n};\n\nconst defaultKeyframeResolver = _ref2 => {\n let {\n transform: {\n initial,\n final\n }\n } = _ref2;\n return [{\n transform: CSS.Transform.toString(initial)\n }, {\n transform: CSS.Transform.toString(final)\n }];\n};\n\nconst defaultDropAnimationConfiguration = {\n duration: 250,\n easing: 'ease',\n keyframes: defaultKeyframeResolver,\n sideEffects: /*#__PURE__*/defaultDropAnimationSideEffects({\n styles: {\n active: {\n opacity: '0'\n }\n }\n })\n};\nfunction useDropAnimation(_ref3) {\n let {\n config,\n draggableNodes,\n droppableContainers,\n measuringConfiguration\n } = _ref3;\n return useEvent((id, node) => {\n if (config === null) {\n return;\n }\n\n const activeDraggable = draggableNodes.get(id);\n\n if (!activeDraggable) {\n return;\n }\n\n const activeNode = activeDraggable.node.current;\n\n if (!activeNode) {\n return;\n }\n\n const measurableNode = getMeasurableNode(node);\n\n if (!measurableNode) {\n return;\n }\n\n const {\n transform\n } = getWindow(node).getComputedStyle(node);\n const parsedTransform = parseTransform(transform);\n\n if (!parsedTransform) {\n return;\n }\n\n const animation = typeof config === 'function' ? config : createDefaultDropAnimation(config);\n scrollIntoViewIfNeeded(activeNode, measuringConfiguration.draggable.measure);\n return animation({\n active: {\n id,\n data: activeDraggable.data,\n node: activeNode,\n rect: measuringConfiguration.draggable.measure(activeNode)\n },\n draggableNodes,\n dragOverlay: {\n node,\n rect: measuringConfiguration.dragOverlay.measure(measurableNode)\n },\n droppableContainers,\n measuringConfiguration,\n transform: parsedTransform\n });\n });\n}\n\nfunction createDefaultDropAnimation(options) {\n const {\n duration,\n easing,\n sideEffects,\n keyframes\n } = { ...defaultDropAnimationConfiguration,\n ...options\n };\n return _ref4 => {\n let {\n active,\n dragOverlay,\n transform,\n ...rest\n } = _ref4;\n\n if (!duration) {\n // Do not animate if animation duration is zero.\n return;\n }\n\n const delta = {\n x: dragOverlay.rect.left - active.rect.left,\n y: dragOverlay.rect.top - active.rect.top\n };\n const scale = {\n scaleX: transform.scaleX !== 1 ? active.rect.width * transform.scaleX / dragOverlay.rect.width : 1,\n scaleY: transform.scaleY !== 1 ? active.rect.height * transform.scaleY / dragOverlay.rect.height : 1\n };\n const finalTransform = {\n x: transform.x - delta.x,\n y: transform.y - delta.y,\n ...scale\n };\n const animationKeyframes = keyframes({ ...rest,\n active,\n dragOverlay,\n transform: {\n initial: transform,\n final: finalTransform\n }\n });\n const [firstKeyframe] = animationKeyframes;\n const lastKeyframe = animationKeyframes[animationKeyframes.length - 1];\n\n if (JSON.stringify(firstKeyframe) === JSON.stringify(lastKeyframe)) {\n // The start and end keyframes are the same, infer that there is no animation needed.\n return;\n }\n\n const cleanup = sideEffects == null ? void 0 : sideEffects({\n active,\n dragOverlay,\n ...rest\n });\n const animation = dragOverlay.node.animate(animationKeyframes, {\n duration,\n easing,\n fill: 'forwards'\n });\n return new Promise(resolve => {\n animation.onfinish = () => {\n cleanup == null ? void 0 : cleanup();\n resolve();\n };\n });\n };\n}\n\nlet key = 0;\nfunction useKey(id) {\n return useMemo(() => {\n if (id == null) {\n return;\n }\n\n key++;\n return key;\n }, [id]);\n}\n\nconst DragOverlay = /*#__PURE__*/React.memo(_ref => {\n let {\n adjustScale = false,\n children,\n dropAnimation: dropAnimationConfig,\n style,\n transition,\n modifiers,\n wrapperElement = 'div',\n className,\n zIndex = 999\n } = _ref;\n const {\n activatorEvent,\n active,\n activeNodeRect,\n containerNodeRect,\n draggableNodes,\n droppableContainers,\n dragOverlay,\n over,\n measuringConfiguration,\n scrollableAncestors,\n scrollableAncestorRects,\n windowRect\n } = useDndContext();\n const transform = useContext(ActiveDraggableContext);\n const key = useKey(active == null ? void 0 : active.id);\n const modifiedTransform = applyModifiers(modifiers, {\n activatorEvent,\n active,\n activeNodeRect,\n containerNodeRect,\n draggingNodeRect: dragOverlay.rect,\n over,\n overlayNodeRect: dragOverlay.rect,\n scrollableAncestors,\n scrollableAncestorRects,\n transform,\n windowRect\n });\n const initialRect = useInitialValue(activeNodeRect);\n const dropAnimation = useDropAnimation({\n config: dropAnimationConfig,\n draggableNodes,\n droppableContainers,\n measuringConfiguration\n }); // We need to wait for the active node to be measured before connecting the drag overlay ref\n // otherwise collisions can be computed against a mispositioned drag overlay\n\n const ref = initialRect ? dragOverlay.setRef : undefined;\n return React.createElement(NullifiedContextProvider, null, React.createElement(AnimationManager, {\n animation: dropAnimation\n }, active && key ? React.createElement(PositionedOverlay, {\n key: key,\n id: active.id,\n ref: ref,\n as: wrapperElement,\n activatorEvent: activatorEvent,\n adjustScale: adjustScale,\n className: className,\n transition: transition,\n rect: initialRect,\n style: {\n zIndex,\n ...style\n },\n transform: modifiedTransform\n }, children) : null));\n});\n\nexport { AutoScrollActivator, DndContext, DragOverlay, KeyboardCode, KeyboardSensor, MeasuringFrequency, MeasuringStrategy, MouseSensor, PointerSensor, TouchSensor, TraversalOrder, applyModifiers, closestCenter, closestCorners, defaultAnnouncements, defaultCoordinates, defaultDropAnimationConfiguration as defaultDropAnimation, defaultDropAnimationSideEffects, defaultKeyboardCoordinateGetter, defaultScreenReaderInstructions, getClientRect, getFirstCollision, getScrollableAncestors, pointerWithin, rectIntersection, useDndContext, useDndMonitor, useDraggable, useDroppable, useSensor, useSensors };\n//# sourceMappingURL=core.esm.js.map\n","import React, { useMemo, useRef, useEffect, useState, useContext } from 'react';\nimport { useDndContext, getClientRect, useDroppable, useDraggable, closestCorners, getFirstCollision, getScrollableAncestors, KeyboardCode } from '@dnd-kit/core';\nimport { useUniqueId, useIsomorphicLayoutEffect, CSS, useCombinedRefs, isKeyboardEvent, subtract } from '@dnd-kit/utilities';\n\n/**\r\n * Move an array item to a different position. Returns a new array with the item moved to the new position.\r\n */\nfunction arrayMove(array, from, to) {\n const newArray = array.slice();\n newArray.splice(to < 0 ? newArray.length + to : to, 0, newArray.splice(from, 1)[0]);\n return newArray;\n}\n\n/**\r\n * Swap an array item to a different position. Returns a new array with the item swapped to the new position.\r\n */\nfunction arraySwap(array, from, to) {\n const newArray = array.slice();\n newArray[from] = array[to];\n newArray[to] = array[from];\n return newArray;\n}\n\nfunction getSortedRects(items, rects) {\n return items.reduce((accumulator, id, index) => {\n const rect = rects.get(id);\n\n if (rect) {\n accumulator[index] = rect;\n }\n\n return accumulator;\n }, Array(items.length));\n}\n\nfunction isValidIndex(index) {\n return index !== null && index >= 0;\n}\n\nfunction itemsEqual(a, b) {\n if (a === b) {\n return true;\n }\n\n if (a.length !== b.length) {\n return false;\n }\n\n for (let i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) {\n return false;\n }\n }\n\n return true;\n}\n\nfunction normalizeDisabled(disabled) {\n if (typeof disabled === 'boolean') {\n return {\n draggable: disabled,\n droppable: disabled\n };\n }\n\n return disabled;\n}\n\n// To-do: We should be calculating scale transformation\nconst defaultScale = {\n scaleX: 1,\n scaleY: 1\n};\nconst horizontalListSortingStrategy = _ref => {\n var _rects$activeIndex;\n\n let {\n rects,\n activeNodeRect: fallbackActiveRect,\n activeIndex,\n overIndex,\n index\n } = _ref;\n const activeNodeRect = (_rects$activeIndex = rects[activeIndex]) != null ? _rects$activeIndex : fallbackActiveRect;\n\n if (!activeNodeRect) {\n return null;\n }\n\n const itemGap = getItemGap(rects, index, activeIndex);\n\n if (index === activeIndex) {\n const newIndexRect = rects[overIndex];\n\n if (!newIndexRect) {\n return null;\n }\n\n return {\n x: activeIndex < overIndex ? newIndexRect.left + newIndexRect.width - (activeNodeRect.left + activeNodeRect.width) : newIndexRect.left - activeNodeRect.left,\n y: 0,\n ...defaultScale\n };\n }\n\n if (index > activeIndex && index <= overIndex) {\n return {\n x: -activeNodeRect.width - itemGap,\n y: 0,\n ...defaultScale\n };\n }\n\n if (index < activeIndex && index >= overIndex) {\n return {\n x: activeNodeRect.width + itemGap,\n y: 0,\n ...defaultScale\n };\n }\n\n return {\n x: 0,\n y: 0,\n ...defaultScale\n };\n};\n\nfunction getItemGap(rects, index, activeIndex) {\n const currentRect = rects[index];\n const previousRect = rects[index - 1];\n const nextRect = rects[index + 1];\n\n if (!currentRect || !previousRect && !nextRect) {\n return 0;\n }\n\n if (activeIndex < index) {\n return previousRect ? currentRect.left - (previousRect.left + previousRect.width) : nextRect.left - (currentRect.left + currentRect.width);\n }\n\n return nextRect ? nextRect.left - (currentRect.left + currentRect.width) : currentRect.left - (previousRect.left + previousRect.width);\n}\n\nconst rectSortingStrategy = _ref => {\n let {\n rects,\n activeIndex,\n overIndex,\n index\n } = _ref;\n const newRects = arrayMove(rects, overIndex, activeIndex);\n const oldRect = rects[index];\n const newRect = newRects[index];\n\n if (!newRect || !oldRect) {\n return null;\n }\n\n return {\n x: newRect.left - oldRect.left,\n y: newRect.top - oldRect.top,\n scaleX: newRect.width / oldRect.width,\n scaleY: newRect.height / oldRect.height\n };\n};\n\nconst rectSwappingStrategy = _ref => {\n let {\n activeIndex,\n index,\n rects,\n overIndex\n } = _ref;\n let oldRect;\n let newRect;\n\n if (index === activeIndex) {\n oldRect = rects[index];\n newRect = rects[overIndex];\n }\n\n if (index === overIndex) {\n oldRect = rects[index];\n newRect = rects[activeIndex];\n }\n\n if (!newRect || !oldRect) {\n return null;\n }\n\n return {\n x: newRect.left - oldRect.left,\n y: newRect.top - oldRect.top,\n scaleX: newRect.width / oldRect.width,\n scaleY: newRect.height / oldRect.height\n };\n};\n\n// To-do: We should be calculating scale transformation\nconst defaultScale$1 = {\n scaleX: 1,\n scaleY: 1\n};\nconst verticalListSortingStrategy = _ref => {\n var _rects$activeIndex;\n\n let {\n activeIndex,\n activeNodeRect: fallbackActiveRect,\n index,\n rects,\n overIndex\n } = _ref;\n const activeNodeRect = (_rects$activeIndex = rects[activeIndex]) != null ? _rects$activeIndex : fallbackActiveRect;\n\n if (!activeNodeRect) {\n return null;\n }\n\n if (index === activeIndex) {\n const overIndexRect = rects[overIndex];\n\n if (!overIndexRect) {\n return null;\n }\n\n return {\n x: 0,\n y: activeIndex < overIndex ? overIndexRect.top + overIndexRect.height - (activeNodeRect.top + activeNodeRect.height) : overIndexRect.top - activeNodeRect.top,\n ...defaultScale$1\n };\n }\n\n const itemGap = getItemGap$1(rects, index, activeIndex);\n\n if (index > activeIndex && index <= overIndex) {\n return {\n x: 0,\n y: -activeNodeRect.height - itemGap,\n ...defaultScale$1\n };\n }\n\n if (index < activeIndex && index >= overIndex) {\n return {\n x: 0,\n y: activeNodeRect.height + itemGap,\n ...defaultScale$1\n };\n }\n\n return {\n x: 0,\n y: 0,\n ...defaultScale$1\n };\n};\n\nfunction getItemGap$1(clientRects, index, activeIndex) {\n const currentRect = clientRects[index];\n const previousRect = clientRects[index - 1];\n const nextRect = clientRects[index + 1];\n\n if (!currentRect) {\n return 0;\n }\n\n if (activeIndex < index) {\n return previousRect ? currentRect.top - (previousRect.top + previousRect.height) : nextRect ? nextRect.top - (currentRect.top + currentRect.height) : 0;\n }\n\n return nextRect ? nextRect.top - (currentRect.top + currentRect.height) : previousRect ? currentRect.top - (previousRect.top + previousRect.height) : 0;\n}\n\nconst ID_PREFIX = 'Sortable';\nconst Context = /*#__PURE__*/React.createContext({\n activeIndex: -1,\n containerId: ID_PREFIX,\n disableTransforms: false,\n items: [],\n overIndex: -1,\n useDragOverlay: false,\n sortedRects: [],\n strategy: rectSortingStrategy,\n disabled: {\n draggable: false,\n droppable: false\n }\n});\nfunction SortableContext(_ref) {\n let {\n children,\n id,\n items: userDefinedItems,\n strategy = rectSortingStrategy,\n disabled: disabledProp = false\n } = _ref;\n const {\n active,\n dragOverlay,\n droppableRects,\n over,\n measureDroppableContainers\n } = useDndContext();\n const containerId = useUniqueId(ID_PREFIX, id);\n const useDragOverlay = Boolean(dragOverlay.rect !== null);\n const items = useMemo(() => userDefinedItems.map(item => typeof item === 'object' && 'id' in item ? item.id : item), [userDefinedItems]);\n const isDragging = active != null;\n const activeIndex = active ? items.indexOf(active.id) : -1;\n const overIndex = over ? items.indexOf(over.id) : -1;\n const previousItemsRef = useRef(items);\n const itemsHaveChanged = !itemsEqual(items, previousItemsRef.current);\n const disableTransforms = overIndex !== -1 && activeIndex === -1 || itemsHaveChanged;\n const disabled = normalizeDisabled(disabledProp);\n useIsomorphicLayoutEffect(() => {\n if (itemsHaveChanged && isDragging) {\n measureDroppableContainers(items);\n }\n }, [itemsHaveChanged, items, isDragging, measureDroppableContainers]);\n useEffect(() => {\n previousItemsRef.current = items;\n }, [items]);\n const contextValue = useMemo(() => ({\n activeIndex,\n containerId,\n disabled,\n disableTransforms,\n items,\n overIndex,\n useDragOverlay,\n sortedRects: getSortedRects(items, droppableRects),\n strategy\n }), // eslint-disable-next-line react-hooks/exhaustive-deps\n [activeIndex, containerId, disabled.draggable, disabled.droppable, disableTransforms, items, overIndex, droppableRects, useDragOverlay, strategy]);\n return React.createElement(Context.Provider, {\n value: contextValue\n }, children);\n}\n\nconst defaultNewIndexGetter = _ref => {\n let {\n id,\n items,\n activeIndex,\n overIndex\n } = _ref;\n return arrayMove(items, activeIndex, overIndex).indexOf(id);\n};\nconst defaultAnimateLayoutChanges = _ref2 => {\n let {\n containerId,\n isSorting,\n wasDragging,\n index,\n items,\n newIndex,\n previousItems,\n previousContainerId,\n transition\n } = _ref2;\n\n if (!transition || !wasDragging) {\n return false;\n }\n\n if (previousItems !== items && index === newIndex) {\n return false;\n }\n\n if (isSorting) {\n return true;\n }\n\n return newIndex !== index && containerId === previousContainerId;\n};\nconst defaultTransition = {\n duration: 200,\n easing: 'ease'\n};\nconst transitionProperty = 'transform';\nconst disabledTransition = /*#__PURE__*/CSS.Transition.toString({\n property: transitionProperty,\n duration: 0,\n easing: 'linear'\n});\nconst defaultAttributes = {\n roleDescription: 'sortable'\n};\n\n/*\r\n * When the index of an item changes while sorting,\r\n * we need to temporarily disable the transforms\r\n */\n\nfunction useDerivedTransform(_ref) {\n let {\n disabled,\n index,\n node,\n rect\n } = _ref;\n const [derivedTransform, setDerivedtransform] = useState(null);\n const previousIndex = useRef(index);\n useIsomorphicLayoutEffect(() => {\n if (!disabled && index !== previousIndex.current && node.current) {\n const initial = rect.current;\n\n if (initial) {\n const current = getClientRect(node.current, {\n ignoreTransform: true\n });\n const delta = {\n x: initial.left - current.left,\n y: initial.top - current.top,\n scaleX: initial.width / current.width,\n scaleY: initial.height / current.height\n };\n\n if (delta.x || delta.y) {\n setDerivedtransform(delta);\n }\n }\n }\n\n if (index !== previousIndex.current) {\n previousIndex.current = index;\n }\n }, [disabled, index, node, rect]);\n useEffect(() => {\n if (derivedTransform) {\n setDerivedtransform(null);\n }\n }, [derivedTransform]);\n return derivedTransform;\n}\n\nfunction useSortable(_ref) {\n let {\n animateLayoutChanges = defaultAnimateLayoutChanges,\n attributes: userDefinedAttributes,\n disabled: localDisabled,\n data: customData,\n getNewIndex = defaultNewIndexGetter,\n id,\n strategy: localStrategy,\n resizeObserverConfig,\n transition = defaultTransition\n } = _ref;\n const {\n items,\n containerId,\n activeIndex,\n disabled: globalDisabled,\n disableTransforms,\n sortedRects,\n overIndex,\n useDragOverlay,\n strategy: globalStrategy\n } = useContext(Context);\n const disabled = normalizeLocalDisabled(localDisabled, globalDisabled);\n const index = items.indexOf(id);\n const data = useMemo(() => ({\n sortable: {\n containerId,\n index,\n items\n },\n ...customData\n }), [containerId, customData, index, items]);\n const itemsAfterCurrentSortable = useMemo(() => items.slice(items.indexOf(id)), [items, id]);\n const {\n rect,\n node,\n isOver,\n setNodeRef: setDroppableNodeRef\n } = useDroppable({\n id,\n data,\n disabled: disabled.droppable,\n resizeObserverConfig: {\n updateMeasurementsFor: itemsAfterCurrentSortable,\n ...resizeObserverConfig\n }\n });\n const {\n active,\n activatorEvent,\n activeNodeRect,\n attributes,\n setNodeRef: setDraggableNodeRef,\n listeners,\n isDragging,\n over,\n setActivatorNodeRef,\n transform\n } = useDraggable({\n id,\n data,\n attributes: { ...defaultAttributes,\n ...userDefinedAttributes\n },\n disabled: disabled.draggable\n });\n const setNodeRef = useCombinedRefs(setDroppableNodeRef, setDraggableNodeRef);\n const isSorting = Boolean(active);\n const displaceItem = isSorting && !disableTransforms && isValidIndex(activeIndex) && isValidIndex(overIndex);\n const shouldDisplaceDragSource = !useDragOverlay && isDragging;\n const dragSourceDisplacement = shouldDisplaceDragSource && displaceItem ? transform : null;\n const strategy = localStrategy != null ? localStrategy : globalStrategy;\n const finalTransform = displaceItem ? dragSourceDisplacement != null ? dragSourceDisplacement : strategy({\n rects: sortedRects,\n activeNodeRect,\n activeIndex,\n overIndex,\n index\n }) : null;\n const newIndex = isValidIndex(activeIndex) && isValidIndex(overIndex) ? getNewIndex({\n id,\n items,\n activeIndex,\n overIndex\n }) : index;\n const activeId = active == null ? void 0 : active.id;\n const previous = useRef({\n activeId,\n items,\n newIndex,\n containerId\n });\n const itemsHaveChanged = items !== previous.current.items;\n const shouldAnimateLayoutChanges = animateLayoutChanges({\n active,\n containerId,\n isDragging,\n isSorting,\n id,\n index,\n items,\n newIndex: previous.current.newIndex,\n previousItems: previous.current.items,\n previousContainerId: previous.current.containerId,\n transition,\n wasDragging: previous.current.activeId != null\n });\n const derivedTransform = useDerivedTransform({\n disabled: !shouldAnimateLayoutChanges,\n index,\n node,\n rect\n });\n useEffect(() => {\n if (isSorting && previous.current.newIndex !== newIndex) {\n previous.current.newIndex = newIndex;\n }\n\n if (containerId !== previous.current.containerId) {\n previous.current.containerId = containerId;\n }\n\n if (items !== previous.current.items) {\n previous.current.items = items;\n }\n }, [isSorting, newIndex, containerId, items]);\n useEffect(() => {\n if (activeId === previous.current.activeId) {\n return;\n }\n\n if (activeId != null && previous.current.activeId == null) {\n previous.current.activeId = activeId;\n return;\n }\n\n const timeoutId = setTimeout(() => {\n previous.current.activeId = activeId;\n }, 50);\n return () => clearTimeout(timeoutId);\n }, [activeId]);\n return {\n active,\n activeIndex,\n attributes,\n data,\n rect,\n index,\n newIndex,\n items,\n isOver,\n isSorting,\n isDragging,\n listeners,\n node,\n overIndex,\n over,\n setNodeRef,\n setActivatorNodeRef,\n setDroppableNodeRef,\n setDraggableNodeRef,\n transform: derivedTransform != null ? derivedTransform : finalTransform,\n transition: getTransition()\n };\n\n function getTransition() {\n if ( // Temporarily disable transitions for a single frame to set up derived transforms\n derivedTransform || // Or to prevent items jumping to back to their \"new\" position when items change\n itemsHaveChanged && previous.current.newIndex === index) {\n return disabledTransition;\n }\n\n if (shouldDisplaceDragSource && !isKeyboardEvent(activatorEvent) || !transition) {\n return undefined;\n }\n\n if (isSorting || shouldAnimateLayoutChanges) {\n return CSS.Transition.toString({ ...transition,\n property: transitionProperty\n });\n }\n\n return undefined;\n }\n}\n\nfunction normalizeLocalDisabled(localDisabled, globalDisabled) {\n var _localDisabled$dragga, _localDisabled$droppa;\n\n if (typeof localDisabled === 'boolean') {\n return {\n draggable: localDisabled,\n // Backwards compatibility\n droppable: false\n };\n }\n\n return {\n draggable: (_localDisabled$dragga = localDisabled == null ? void 0 : localDisabled.draggable) != null ? _localDisabled$dragga : globalDisabled.draggable,\n droppable: (_localDisabled$droppa = localDisabled == null ? void 0 : localDisabled.droppable) != null ? _localDisabled$droppa : globalDisabled.droppable\n };\n}\n\nfunction hasSortableData(entry) {\n if (!entry) {\n return false;\n }\n\n const data = entry.data.current;\n\n if (data && 'sortable' in data && typeof data.sortable === 'object' && 'containerId' in data.sortable && 'items' in data.sortable && 'index' in data.sortable) {\n return true;\n }\n\n return false;\n}\n\nconst directions = [KeyboardCode.Down, KeyboardCode.Right, KeyboardCode.Up, KeyboardCode.Left];\nconst sortableKeyboardCoordinates = (event, _ref) => {\n let {\n context: {\n active,\n collisionRect,\n droppableRects,\n droppableContainers,\n over,\n scrollableAncestors\n }\n } = _ref;\n\n if (directions.includes(event.code)) {\n event.preventDefault();\n\n if (!active || !collisionRect) {\n return;\n }\n\n const filteredContainers = [];\n droppableContainers.getEnabled().forEach(entry => {\n if (!entry || entry != null && entry.disabled) {\n return;\n }\n\n const rect = droppableRects.get(entry.id);\n\n if (!rect) {\n return;\n }\n\n switch (event.code) {\n case KeyboardCode.Down:\n if (collisionRect.top < rect.top) {\n filteredContainers.push(entry);\n }\n\n break;\n\n case KeyboardCode.Up:\n if (collisionRect.top > rect.top) {\n filteredContainers.push(entry);\n }\n\n break;\n\n case KeyboardCode.Left:\n if (collisionRect.left > rect.left) {\n filteredContainers.push(entry);\n }\n\n break;\n\n case KeyboardCode.Right:\n if (collisionRect.left < rect.left) {\n filteredContainers.push(entry);\n }\n\n break;\n }\n });\n const collisions = closestCorners({\n active,\n collisionRect: collisionRect,\n droppableRects,\n droppableContainers: filteredContainers,\n pointerCoordinates: null\n });\n let closestId = getFirstCollision(collisions, 'id');\n\n if (closestId === (over == null ? void 0 : over.id) && collisions.length > 1) {\n closestId = collisions[1].id;\n }\n\n if (closestId != null) {\n const activeDroppable = droppableContainers.get(active.id);\n const newDroppable = droppableContainers.get(closestId);\n const newRect = newDroppable ? droppableRects.get(newDroppable.id) : null;\n const newNode = newDroppable == null ? void 0 : newDroppable.node.current;\n\n if (newNode && newRect && activeDroppable && newDroppable) {\n const newScrollAncestors = getScrollableAncestors(newNode);\n const hasDifferentScrollAncestors = newScrollAncestors.some((element, index) => scrollableAncestors[index] !== element);\n const hasSameContainer = isSameContainer(activeDroppable, newDroppable);\n const isAfterActive = isAfter(activeDroppable, newDroppable);\n const offset = hasDifferentScrollAncestors || !hasSameContainer ? {\n x: 0,\n y: 0\n } : {\n x: isAfterActive ? collisionRect.width - newRect.width : 0,\n y: isAfterActive ? collisionRect.height - newRect.height : 0\n };\n const rectCoordinates = {\n x: newRect.left,\n y: newRect.top\n };\n const newCoordinates = offset.x && offset.y ? rectCoordinates : subtract(rectCoordinates, offset);\n return newCoordinates;\n }\n }\n }\n\n return undefined;\n};\n\nfunction isSameContainer(a, b) {\n if (!hasSortableData(a) || !hasSortableData(b)) {\n return false;\n }\n\n return a.data.current.sortable.containerId === b.data.current.sortable.containerId;\n}\n\nfunction isAfter(a, b) {\n if (!hasSortableData(a) || !hasSortableData(b)) {\n return false;\n }\n\n if (!isSameContainer(a, b)) {\n return false;\n }\n\n return a.data.current.sortable.index < b.data.current.sortable.index;\n}\n\nexport { SortableContext, arrayMove, arraySwap, defaultAnimateLayoutChanges, defaultNewIndexGetter, hasSortableData, horizontalListSortingStrategy, rectSortingStrategy, rectSwappingStrategy, sortableKeyboardCoordinates, useSortable, verticalListSortingStrategy };\n//# sourceMappingURL=sortable.esm.js.map\n","\"use client\";\r\n\r\nimport React, { useState, useEffect, useRef, Suspense } from \"react\";\r\nimport { Download, ChevronDown, CalendarClock, CalendarDays } from \"lucide-react\";\r\nimport { createPortal } from \"react-dom\";\r\n// TODO: replace with framework-agnostic filter chips\r\nfunction CustomFilterChips() { return null; }\r\n\r\n/**\r\n * DataTableFilters Component\r\n * Displays filter buttons (Week to Date, Select Date Range, Export) and filter chips\r\n * \r\n * @param {Object} props\r\n * @param {React.ReactNode} props.dateRangePicker - DateRangePicker component (wrapped in Suspense)\r\n * @param {Function} props.onWeekToDate - Handler for \"Week to Date\" button\r\n * @param {Object} props.exportConfig - Export configuration\r\n * @param {boolean} props.exportConfig.isExporting - Whether export is in progress\r\n * @param {Function} props.exportConfig.onExport - Export handler (type) => void\r\n * @param {Array} props.exportConfig.types - Export types array (default: ['csv'])\r\n * @param {Object} props.filterChipsConfig - Filter chips configuration\r\n * @param {Object} props.filterChipsConfig.filters - Current filter values\r\n * @param {Function} props.filterChipsConfig.onChange - Filter chips change handler\r\n * @param {Function} props.filterChipsConfig.onClear - Clear all filters handler\r\n * @param {Array} props.filterChipsConfig.customFilters - Custom filter chips (e.g., date range)\r\n */\r\nexport default function DataTableFilters({\r\n dateRangePicker,\r\n onWeekToDate,\r\n exportConfig,\r\n filterChipsConfig,\r\n trailingActions, // Optional extra actions rendered after Export (e.g., Add Users button)\r\n}) {\r\n const [showExportMenu, setShowExportMenu] = useState(false);\r\n const exportButtonRef = useRef(null);\r\n const exportMenuRef = useRef(null);\r\n\r\n // Handle click outside to close export menu\r\n useEffect(() => {\r\n const handleClickOutside = (event) => {\r\n if (\r\n exportMenuRef.current &&\r\n !exportMenuRef.current.contains(event.target) &&\r\n exportButtonRef.current &&\r\n !exportButtonRef.current.contains(event.target)\r\n ) {\r\n setShowExportMenu(false);\r\n }\r\n };\r\n\r\n if (showExportMenu) {\r\n document.addEventListener(\"mousedown\", handleClickOutside);\r\n return () => {\r\n document.removeEventListener(\"mousedown\", handleClickOutside);\r\n };\r\n }\r\n }, [showExportMenu]);\r\n\r\n const openExportMenu = () => {\r\n setShowExportMenu((prev) => !prev);\r\n };\r\n\r\n const handleExport = (type) => {\r\n setShowExportMenu(false);\r\n if (exportConfig?.onExport) {\r\n exportConfig.onExport(type);\r\n }\r\n };\r\n\r\n // Check if there are any filter chips to display\r\n const hasFilterChips = () => {\r\n if (!filterChipsConfig?.filters) return false;\r\n \r\n const filters = filterChipsConfig.filters;\r\n const customFilters = filterChipsConfig.customFilters || [];\r\n \r\n // Check if any regular filters have values\r\n const hasRegularFilters = Object.entries(filters).some(([key, value]) => {\r\n if (Array.isArray(value) && value.length) return true;\r\n if (typeof value === \"string\" && value.trim() !== \"\") return true;\r\n if (value && typeof value === \"object\" && (value.min != null || value.max != null)) return true;\r\n return false;\r\n });\r\n \r\n // Check if any custom filters are active\r\n const hasCustomFilters = customFilters.some(filterObj => filterObj.active);\r\n \r\n return hasRegularFilters || hasCustomFilters;\r\n };\r\n\r\n const shouldShowChips = hasFilterChips();\r\n\r\n return (\r\n <div className=\"flex items-center gap-3 flex-wrap\">\r\n {/* Week to Date Button */}\r\n {onWeekToDate && (\r\n <button\r\n onClick={onWeekToDate}\r\n className=\"inline-flex items-center gap-2 rounded-lg border border-gray-300 bg-white/80 px-4 py-2.5 transition-colors hover:bg-white text-sm font-medium text-gray-900\"\r\n style={{ fontFamily: 'var(--font-sans)' }}\r\n >\r\n <CalendarClock size={16} />\r\n <span>Week to Date</span>\r\n </button>\r\n )}\r\n\r\n {/* Select Date Range */}\r\n {dateRangePicker && (\r\n <Suspense\r\n fallback={\r\n <div className=\"inline-flex items-center gap-2 rounded-lg border border-gray-300 bg-white/80 px-4 py-2.5 text-sm font-medium text-gray-400\">\r\n <CalendarClock size={16} />\r\n <span>Loading...</span>\r\n </div>\r\n }\r\n >\r\n {dateRangePicker}\r\n </Suspense>\r\n )}\r\n\r\n {/* Export Button */}\r\n {exportConfig && (\r\n <div className=\"relative\">\r\n <button\r\n ref={exportButtonRef}\r\n onClick={openExportMenu}\r\n disabled={exportConfig.isExporting}\r\n className=\"inline-flex items-center justify-between gap-2 rounded-lg border border-gray-300 bg-white/80 px-4 py-2.5 transition-colors hover:bg-white text-sm font-medium text-gray-900 disabled:opacity-50 disabled:cursor-not-allowed min-w-[120px]\"\r\n style={{ fontFamily: 'var(--font-sans)' }}\r\n >\r\n <div className=\"flex items-center gap-2\">\r\n <Download size={16} />\r\n <span>{exportConfig.isExporting ? \"Exporting...\" : \"Export\"}</span>\r\n </div>\r\n <ChevronDown size={16} />\r\n </button>\r\n {showExportMenu && (\r\n <div\r\n ref={exportMenuRef}\r\n className=\"absolute top-full right-0 mt-2 bg-white rounded-lg shadow-lg border border-gray-200 py-1 z-50 min-w-[120px]\"\r\n >\r\n {(exportConfig.types || [\"csv\"]).map((type) => (\r\n <button\r\n key={type}\r\n onClick={() => handleExport(type)}\r\n className=\"w-full text-left px-4 py-2 text-sm text-gray-700 hover:bg-gray-50 transition-colors\"\r\n style={{ fontFamily: 'var(--font-sans)' }}\r\n >\r\n Export {type.toUpperCase()}\r\n </button>\r\n ))}\r\n </div>\r\n )}\r\n </div>\r\n )}\r\n\r\n {/* Filter chips + optional trailing actions (e.g., Add Users / Add Agent) */}\r\n {(shouldShowChips || trailingActions) && (\r\n <>\r\n {/* Vertical line only when there are actual chips; this avoids double lines\r\n when we only show trailingActions (like Add Agent) with no chips. */}\r\n {shouldShowChips && (\r\n <div className=\"h-9 mt-1 w-px bg-gray-300 flex-shrink-0\"></div>\r\n )}\r\n\r\n {/* Filter Chips + trailing actions */}\r\n <div className=\"flex items-center gap-3 justify-end\">\r\n {shouldShowChips && filterChipsConfig && (\r\n <CustomFilterChips\r\n filters={filterChipsConfig.filters}\r\n onChange={filterChipsConfig.onChange}\r\n onClear={filterChipsConfig.onClear}\r\n customFilters={filterChipsConfig.customFilters || []}\r\n />\r\n )}\r\n {trailingActions && (\r\n <div className=\"flex-shrink-0\">\r\n {trailingActions}\r\n </div>\r\n )}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n );\r\n}\r\n\r\n","\"use client\";\r\n\r\nimport React, { useState, useMemo, useRef, useEffect, useCallback } from \"react\";\r\nimport {\r\n DndContext,\r\n closestCenter,\r\n KeyboardSensor,\r\n PointerSensor,\r\n useSensor,\r\n useSensors,\r\n DragOverlay,\r\n} from \"@dnd-kit/core\";\r\nimport {\r\n arrayMove,\r\n SortableContext,\r\n sortableKeyboardCoordinates,\r\n useSortable,\r\n horizontalListSortingStrategy,\r\n} from \"@dnd-kit/sortable\";\r\nimport { CSS } from \"@dnd-kit/utilities\";\r\nimport { GripVertical, ChevronUp, ChevronDown, Filter, ArrowUp, ArrowDown } from \"lucide-react\";\r\nimport { createPortal } from \"react-dom\";\r\n// TODO: replace with framework-agnostic toast\r\nconst toast = { error: (...args) => console.warn(\"toast.error:\", ...args), dismiss: () => {} };\r\n// TODO: replace with framework-agnostic pagination\r\nfunction Pagination() { return null; }\r\n// TODO: replace with framework-agnostic component\r\nfunction OpenCloseArrow({ isOpen, iconSize }) { return null; }\r\n// TODO: replace with framework-agnostic component\r\nfunction Separator() { return <div style={{ height: 1, background: \"rgba(52,58,64,0.08)\" }} />; }\r\n// TODO: replace with framework-agnostic context\r\nconst useUserContext = () => ({ userData: { email: \"anonymous\" } });\r\n// TODO: replace with framework-agnostic image\r\nconst Image = (props) => <img {...props} />;\r\nimport DataTableFilters from \"./DataTableFilters\";\r\n// TODO: replace with framework-agnostic tooltip\r\nfunction HoverBalloon({ children }) { return children; }\r\n\r\n/**\r\n * DataTable Component\r\n * Interactive table with column reordering, filtering, sorting, sticky headers, and pagination\r\n * Follows \"No Judgment\" principle - scores and counts displayed uniformly\r\n */\r\nexport default function DataTable({ \r\n data = [], \r\n columns = [], \r\n initialPageSize = 10, \r\n onRowClick,\r\n // Server-side pagination props (optional)\r\n totalCount = null, // Total count from server (null = use client-side pagination)\r\n page: controlledPage = null, // Controlled page (null = use internal state)\r\n pageSize: controlledPageSize = null, // Controlled pageSize (null = use internal state)\r\n onPageChange = null, // Callback for page changes (null = use internal state)\r\n onPageSizeChange = null, // Callback for pageSize changes (null = use internal state)\r\n onFilterChange = null, // Callback for filter changes (null = use client-side filtering)\r\n // Server-side sorting props (optional)\r\n onSort = null, // Callback for sort changes (null = use client-side sorting)\r\n sortFields = [], // Array of [field, direction] tuples from parent (null = use internal state)\r\n tableId = null, // Optional unique identifier for localStorage persistence (e.g., \"history\", \"agents\")\r\n isLoading = false, // Loading state to show overlay inside table\r\n // Filter props (optional)\r\n filtersConfig = null, // Configuration for filters (dateRangePicker, onWeekToDate, exportConfig, filterChipsConfig)\r\n}) {\r\n // Get user email for user-specific storage\r\n const { userData } = useUserContext();\r\n const userId = userData?.email || 'anonymous';\r\n\r\n // Component to show tooltip only when text is actually truncated\r\n const TruncatedCell = React.memo(({ children, content, className = \"\" }) => {\r\n const textRef = useRef(null);\r\n const [isTruncated, setIsTruncated] = useState(false);\r\n\r\n useEffect(() => {\r\n const checkTruncation = () => {\r\n if (textRef.current) {\r\n const isOverflowing = textRef.current.scrollWidth > textRef.current.clientWidth;\r\n setIsTruncated(isOverflowing);\r\n }\r\n };\r\n\r\n checkTruncation();\r\n const timeoutId = setTimeout(checkTruncation, 0);\r\n\r\n window.addEventListener('resize', checkTruncation);\r\n return () => {\r\n clearTimeout(timeoutId);\r\n window.removeEventListener('resize', checkTruncation);\r\n };\r\n }, [children, content]);\r\n\r\n const textElement = (\r\n <span className={`truncate block ${className}`} ref={textRef}>\r\n {children}\r\n </span>\r\n );\r\n\r\n if (isTruncated && content) {\r\n return (\r\n <HoverBalloon\r\n content={content}\r\n styling=\"bg-green-2 text-gray-900 px-3 py-2 text-sm rounded-lg shadow-md border border-gray-300 max-w-xs whitespace-normal\"\r\n indicatorColor=\"bg-green-2\"\r\n direction=\"top\"\r\n >\r\n {textElement}\r\n </HoverBalloon>\r\n );\r\n }\r\n\r\n return textElement;\r\n });\r\n TruncatedCell.displayName = 'TruncatedCell';\r\n\r\n // Use controlled pagination if props provided, otherwise use internal state\r\n const isServerSidePagination = totalCount !== null && onPageChange !== null;\r\n // Use server-side filtering if onFilterChange is provided\r\n const isServerSideFiltering = onFilterChange !== null;\r\n // Use server-side sorting if onSort is provided\r\n const isServerSideSorting = onSort !== null;\r\n const [internalPage, setInternalPage] = useState(1);\r\n const [internalPageSize, setInternalPageSize] = useState(initialPageSize);\r\n \r\n const page = controlledPage !== null ? controlledPage : internalPage;\r\n const pageSize = controlledPageSize !== null ? controlledPageSize : internalPageSize;\r\n \r\n const setPage = (newPage) => {\r\n if (onPageChange) {\r\n onPageChange(newPage);\r\n } else {\r\n setInternalPage(newPage);\r\n }\r\n };\r\n \r\n const setPageSize = (newSize) => {\r\n if (onPageSizeChange) {\r\n onPageSizeChange(newSize);\r\n } else {\r\n setInternalPageSize(newSize);\r\n }\r\n };\r\n \r\n const MAX_COLUMNS = 9;\r\n \r\n // Refs for localStorage persistence\r\n const userHasManuallyChangedColumns = useRef(false);\r\n \r\n // Generate unique storage key for this table (includes userId)\r\n const storageKey = useMemo(() => {\r\n if (tableId) {\r\n return `dataTable_columns_${tableId}:${userId}`;\r\n }\r\n // Fallback: use column keys to create unique identifier\r\n const columnKeys = columns.map(col => (col.id || col.key)).sort().join('_');\r\n return `dataTable_columns_${columnKeys}:${userId}`;\r\n }, [tableId, columns, userId]);\r\n \r\n const manualChangeFlagKey = useMemo(() => {\r\n if (tableId) {\r\n return `dataTable_manual_change_${tableId}:${userId}`;\r\n }\r\n return null;\r\n }, [tableId, userId]);\r\n \r\n // Load saved column visibility from localStorage\r\n const loadSavedColumns = useCallback((key, cols) => {\r\n if (typeof window === 'undefined' || !key || !cols || cols.length === 0) return null;\r\n try {\r\n const saved = localStorage.getItem(key);\r\n if (saved) {\r\n const savedColumns = JSON.parse(saved);\r\n // Validate that saved columns still exist in current columns\r\n const validColumns = savedColumns.filter(colId => \r\n cols.some(col => (col.id || col.key) === colId)\r\n );\r\n if (validColumns.length > 0) {\r\n return validColumns;\r\n }\r\n }\r\n } catch (error) {\r\n console.warn('Failed to load saved columns from localStorage:', error);\r\n }\r\n return null;\r\n }, []);\r\n \r\n const [filters, setFilters] = useState({});\r\n // Internal sorting state (only used for client-side sorting)\r\n const [internalSortField, setInternalSortField] = useState(null);\r\n const [internalSortDirection, setInternalSortDirection] = useState(\"asc\");\r\n \r\n // Sync internal filters when filterChipsConfig.filters changes (when chips are removed)\r\n// useEffect(() => {\r\n// if (isServerSideFiltering && filtersConfig?.filterChipsConfig?.filters) {\r\n// // Sync DataTable's internal filters with parent's filter chips\r\n// // This ensures input fields clear when chips are removed\r\n// setFilters(filtersConfig.filterChipsConfig.filters);\r\n// }\r\n// }, [filtersConfig?.filterChipsConfig?.filters, isServerSideFiltering]);\r\n \r\n // Get current sort state (from props if server-side, otherwise from internal state)\r\n // For server-side sorting, we need to map the sortField back to the column key\r\n // because History.js's handleSort maps some keys (e.g., \"evaluation.csat_score\" -> \"csat_score\")\r\n // but we need to compare against the original column key\r\n const getSortFieldForComparison = useCallback((sortFieldFromProps, columnId) => {\r\n // Reverse mapping: if sortField is \"csat_score\", it should match column \"evaluation.csat_score\"\r\n if (sortFieldFromProps === \"csat_score\" && columnId === \"evaluation.csat_score\") {\r\n return columnId;\r\n }\r\n // For other fields, use as-is (they should match)\r\n return sortFieldFromProps;\r\n }, []);\r\n \r\n const sortField = isServerSideSorting && sortFields.length > 0 ? sortFields[0][0] : internalSortField;\r\n const sortDirection = isServerSideSorting && sortFields.length > 0 ? sortFields[0][1] : internalSortDirection;\r\n // Support both 'id' and 'key' for column identifiers\r\n const [columnOrder, setColumnOrder] = useState(() => \r\n columns.map((col) => col.id || col.key)\r\n );\r\n // Column selection state - load persisted columns if they exist, otherwise default to first 9\r\n const [visibleColumns, setVisibleColumns] = useState(() => {\r\n // Try to load persisted columns immediately on mount\r\n if (typeof window !== 'undefined' && tableId) {\r\n try {\r\n // Check if user has manually changed columns before\r\n const hasManualChange = localStorage.getItem(`dataTable_manual_change_${tableId}:${userId}`) === 'true';\r\n \r\n if (hasManualChange) {\r\n // User has manually changed columns, load persisted selection immediately\r\n const saved = localStorage.getItem(`dataTable_columns_${tableId}:${userId}`);\r\n if (saved) {\r\n const savedColumns = JSON.parse(saved);\r\n if (Array.isArray(savedColumns) && savedColumns.length > 0) {\r\n userHasManuallyChangedColumns.current = true;\r\n // Validate saved columns exist in current columns\r\n const validColumns = savedColumns.filter(colId => \r\n columns.some(col => (col.id || col.key) === colId)\r\n );\r\n if (validColumns.length > 0) {\r\n return validColumns.slice(0, MAX_COLUMNS);\r\n }\r\n }\r\n }\r\n }\r\n } catch (error) {\r\n console.warn('Failed to load saved columns from localStorage:', error);\r\n }\r\n }\r\n \r\n // If no persisted columns, default to first 9 columns\r\n const columnIds = columns.map((col) => col.id || col.key);\r\n return columnIds.slice(0, MAX_COLUMNS);\r\n });\r\n const [isColumnDropdownOpen, setIsColumnDropdownOpen] = useState(false);\r\n const [columnDropdownPosition, setColumnDropdownPosition] = useState({ top: 0, left: 0, width: 0 });\r\n const [pendingSelection, setPendingSelection] = useState(new Set());\r\n const [pendingDeselection, setPendingDeselection] = useState(new Set());\r\n const [draggedColumnIndex, setDraggedColumnIndex] = useState(null);\r\n const [dragOverColumnIndex, setDragOverColumnIndex] = useState(null);\r\n const columnDropdownRef = useRef(null);\r\n const columnDropdownMenuRef = useRef(null);\r\n const toastTimeoutRef = useRef(null);\r\n const [activeId, setActiveId] = useState(null);\r\n const tableRef = useRef(null);\r\n\r\n // Helper to get column identifier (id or key)\r\n const getColumnId = (col) => col.id || col.key;\r\n\r\n const sensors = useSensors(\r\n useSensor(PointerSensor),\r\n useSensor(KeyboardSensor, {\r\n coordinateGetter: sortableKeyboardCoordinates,\r\n })\r\n );\r\n\r\n // Handle column drag end (table-level drag and drop)\r\n const handleDragEnd = (event) => {\r\n const { active, over } = event;\r\n if (over && active.id !== over.id) {\r\n // Mark that user has manually changed columns\r\n userHasManuallyChangedColumns.current = true;\r\n \r\n // Update visibleColumns order when dragging in table header\r\n setVisibleColumns((prev) => {\r\n const oldIndex = prev.indexOf(active.id);\r\n const newIndex = prev.indexOf(over.id);\r\n if (oldIndex !== -1 && newIndex !== -1) {\r\n const reordered = arrayMove(prev, oldIndex, newIndex);\r\n // Save immediately after drag\r\n saveColumnsToStorage(reordered);\r\n return reordered;\r\n }\r\n return prev;\r\n });\r\n \r\n // Also update columnOrder for consistency\r\n setColumnOrder((items) => {\r\n const oldIndex = items.indexOf(active.id);\r\n const newIndex = items.indexOf(over.id);\r\n return arrayMove(items, oldIndex, newIndex);\r\n });\r\n }\r\n setActiveId(null);\r\n };\r\n\r\n // Handle column drag start\r\n const handleDragStart = (event) => {\r\n setActiveId(event.active.id);\r\n };\r\n\r\n // Filter data based on filter inputs - supports multiple keywords\r\n // For server-side filtering, skip client-side filtering (data is already filtered by server)\r\n const filteredData = useMemo(() => {\r\n if (isServerSideFiltering) {\r\n // Server-side filtering: data is already filtered, use as-is\r\n return data || [];\r\n }\r\n \r\n // Client-side filtering: filter the data locally\r\n if (!data || data.length === 0) return [];\r\n \r\n return data.filter((row) => {\r\n return Object.keys(filters).every((key) => {\r\n const filterValue = filters[key];\r\n if (!filterValue || filterValue.trim() === \"\") return true;\r\n \r\n const cellValue = row[key];\r\n if (cellValue === null || cellValue === undefined) return false;\r\n \r\n const cellValueStr = String(cellValue).toLowerCase();\r\n const filterValueLower = filterValue.toLowerCase().trim();\r\n \r\n // Support multiple keywords separated by spaces\r\n // All keywords must be present in the cell value\r\n const keywords = filterValueLower.split(/\\s+/).filter(k => k.length > 0);\r\n \r\n return keywords.every(keyword => cellValueStr.includes(keyword));\r\n });\r\n });\r\n }, [data, filters, isServerSideFiltering]);\r\n\r\n // Sort filtered data\r\n // For server-side sorting, skip client-side sorting (data is already sorted by server)\r\n const sortedData = useMemo(() => {\r\n if (isServerSideSorting) {\r\n // Server-side sorting: data is already sorted, use as-is\r\n return filteredData;\r\n }\r\n \r\n // Client-side sorting: sort the filtered data locally\r\n if (!sortField) return filteredData;\r\n \r\n return [...filteredData].sort((a, b) => {\r\n const aVal = a[sortField];\r\n const bVal = b[sortField];\r\n \r\n // Handle null/undefined\r\n if (aVal === null || aVal === undefined) return 1;\r\n if (bVal === null || bVal === undefined) return -1;\r\n \r\n // Handle numbers\r\n if (typeof aVal === \"number\" && typeof bVal === \"number\") {\r\n return sortDirection === \"asc\" ? aVal - bVal : bVal - aVal;\r\n }\r\n \r\n // Handle strings\r\n const aStr = String(aVal).toLowerCase();\r\n const bStr = String(bVal).toLowerCase();\r\n \r\n if (sortDirection === \"asc\") {\r\n return aStr.localeCompare(bStr);\r\n } else {\r\n return bStr.localeCompare(aStr);\r\n }\r\n });\r\n }, [filteredData, sortField, sortDirection, isServerSideSorting]);\r\n\r\n // Paginate sorted data\r\n // For server-side pagination, use data as-is (already paginated by server)\r\n // For client-side pagination, paginate the sorted data\r\n const paginatedData = useMemo(() => {\r\n if (isServerSidePagination) {\r\n // Server-side: data is already paginated, use as-is\r\n // Use data directly (not sortedData) since server handles sorting\r\n return data || [];\r\n } else {\r\n // Client-side: paginate the sorted data\r\n const startIndex = (page - 1) * pageSize;\r\n const endIndex = startIndex + pageSize;\r\n return sortedData.slice(startIndex, endIndex);\r\n }\r\n }, [data, sortedData, page, pageSize, isServerSidePagination]);\r\n\r\n // Handle header click for sorting\r\n const handleSort = (field) => {\r\n if (isServerSideSorting && onSort) {\r\n // Server-side sorting: call parent's onSort callback\r\n onSort(field);\r\n // Reset to first page on sort (if pagination is controlled)\r\n if (onPageChange) {\r\n onPageChange(1);\r\n } else {\r\n setInternalPage(1);\r\n }\r\n } else {\r\n // Client-side sorting: update internal state\r\n if (internalSortField === field) {\r\n setInternalSortDirection(internalSortDirection === \"asc\" ? \"desc\" : \"asc\");\r\n } else {\r\n setInternalSortField(field);\r\n setInternalSortDirection(\"asc\");\r\n }\r\n setPage(1); // Reset to first page on sort\r\n }\r\n };\r\n\r\n // Handle filter change\r\n const handleFilterChange = (id, value) => {\r\n // Remove filter if value is empty, otherwise update it\r\n const newFilters = value && value.trim() !== \"\"\r\n ? { ...filters, [id]: value }\r\n : Object.fromEntries(Object.entries(filters).filter(([key]) => key !== id));\r\n \r\n // Update local filter state\r\n setFilters(newFilters);\r\n \r\n // If server-side filtering, notify parent component\r\n if (isServerSideFiltering && onFilterChange) {\r\n onFilterChange(newFilters);\r\n }\r\n \r\n // Reset to first page on filter (works for both client and server-side pagination)\r\n if (onPageChange) {\r\n onPageChange(1);\r\n } else {\r\n setInternalPage(1);\r\n }\r\n };\r\n\r\n // Show toast once for max columns limit\r\n const showToastOnce = (message) => {\r\n if (toastTimeoutRef.current) return;\r\n toast.error(message, { id: \"max-columns-toast\" });\r\n toastTimeoutRef.current = setTimeout(() => {\r\n toastTimeoutRef.current = null;\r\n }, 3000);\r\n };\r\n\r\n // Save columns to localStorage\r\n const saveColumnsToStorage = useCallback((cols) => {\r\n if (typeof window !== 'undefined' && storageKey && cols.length > 0 && userHasManuallyChangedColumns.current) {\r\n try {\r\n localStorage.setItem(storageKey, JSON.stringify(cols));\r\n if (manualChangeFlagKey) {\r\n localStorage.setItem(manualChangeFlagKey, 'true');\r\n }\r\n } catch (error) {\r\n console.warn('Failed to save columns to localStorage:', error);\r\n }\r\n }\r\n }, [storageKey, manualChangeFlagKey]);\r\n\r\n // Toggle column selection with smooth transitions\r\n const toggleColumnSelection = (columnId) => {\r\n // Mark that user has manually changed columns\r\n userHasManuallyChangedColumns.current = true;\r\n \r\n setVisibleColumns(prev => {\r\n // Unselecting: show unchecked state first, then remove from selected list\r\n if (prev.includes(columnId)) {\r\n // Clear any pending toast timeout when unselecting\r\n if (toastTimeoutRef.current) {\r\n clearTimeout(toastTimeoutRef.current);\r\n toastTimeoutRef.current = null;\r\n }\r\n toast.dismiss(\"max-columns-toast\");\r\n \r\n // Don't allow deselecting all columns\r\n if (prev.length === 1) return prev;\r\n \r\n // Show unchecked state first, then remove after delay\r\n setPendingDeselection(prevSet => new Set(prevSet).add(columnId));\r\n setTimeout(() => {\r\n setVisibleColumns(current => {\r\n const updated = current.filter(id => id !== columnId);\r\n // Save immediately after user change\r\n saveColumnsToStorage(updated);\r\n return updated;\r\n });\r\n setPendingDeselection(prevSet => {\r\n const next = new Set(prevSet);\r\n next.delete(columnId);\r\n return next;\r\n });\r\n }, 200); // 200ms delay for smooth transition\r\n \r\n return prev; // Return current state, actual removal happens in setTimeout\r\n }\r\n \r\n // Selecting: check if we're at the maximum limit\r\n if (prev.length >= MAX_COLUMNS) {\r\n showToastOnce(\"Maximum 9 column selection allowed\");\r\n return prev;\r\n }\r\n \r\n // Show checked state first, then add to selected list after delay\r\n setPendingSelection(prevSet => new Set(prevSet).add(columnId));\r\n setTimeout(() => {\r\n setVisibleColumns(current => {\r\n const updated = !current.includes(columnId) ? [...current, columnId] : current;\r\n // Save immediately after user change\r\n saveColumnsToStorage(updated);\r\n return updated;\r\n });\r\n setPendingSelection(prevSet => {\r\n const next = new Set(prevSet);\r\n next.delete(columnId);\r\n return next;\r\n });\r\n }, 200); // 200ms delay for smooth transition\r\n \r\n return prev; // Return current state, actual addition happens in setTimeout\r\n });\r\n };\r\n\r\n // Column drag handlers for reordering in dropdown\r\n const handleColumnDragStart = (e, index) => {\r\n setDraggedColumnIndex(index);\r\n };\r\n\r\n const handleColumnDragEnd = () => {\r\n setDraggedColumnIndex(null);\r\n setDragOverColumnIndex(null);\r\n };\r\n\r\n const handleColumnDragOver = (e, index) => {\r\n e.preventDefault();\r\n if (draggedColumnIndex !== null && draggedColumnIndex !== index) {\r\n setDragOverColumnIndex(index);\r\n }\r\n };\r\n\r\n const handleColumnDragLeave = () => {\r\n setDragOverColumnIndex(null);\r\n };\r\n\r\n const handleColumnDrop = (e, dropIndex) => {\r\n e.preventDefault();\r\n if (draggedColumnIndex !== null && draggedColumnIndex !== dropIndex) {\r\n // Mark that user has manually changed columns\r\n userHasManuallyChangedColumns.current = true;\r\n \r\n setVisibleColumns(prev => {\r\n const reordered = arrayMove(prev, draggedColumnIndex, dropIndex);\r\n // Save immediately after drag\r\n saveColumnsToStorage(reordered);\r\n return reordered;\r\n });\r\n }\r\n setDraggedColumnIndex(null);\r\n setDragOverColumnIndex(null);\r\n };\r\n\r\n // Update columnOrder when visibleColumns changes\r\n useEffect(() => {\r\n setColumnOrder(prev => {\r\n // Keep visible columns in their current order, append any new ones\r\n const visibleOrder = visibleColumns.filter(id => prev.includes(id));\r\n const newColumns = visibleColumns.filter(id => !prev.includes(id));\r\n const hiddenColumns = prev.filter(id => !visibleColumns.includes(id));\r\n return [...visibleOrder, ...newColumns, ...hiddenColumns];\r\n });\r\n }, [visibleColumns]);\r\n\r\n // Save to localStorage whenever visibleColumns changes (only if user has manually changed columns)\r\n useEffect(() => {\r\n if (typeof window !== 'undefined' && storageKey && visibleColumns.length > 0 && userHasManuallyChangedColumns.current) {\r\n try {\r\n localStorage.setItem(storageKey, JSON.stringify(visibleColumns));\r\n if (manualChangeFlagKey) {\r\n localStorage.setItem(manualChangeFlagKey, 'true');\r\n }\r\n } catch (error) {\r\n console.warn('Failed to save columns to localStorage:', error);\r\n }\r\n }\r\n }, [visibleColumns, storageKey, manualChangeFlagKey]);\r\n\r\n // Initialize visibleColumns when columns become available (if not already initialized)\r\n useEffect(() => {\r\n // Only initialize if columns are available and visibleColumns is empty\r\n if (columns.length > 0 && visibleColumns.length === 0) {\r\n // Check if user has manually changed columns before\r\n if (typeof window !== 'undefined' && tableId) {\r\n try {\r\n const hasManualChange = localStorage.getItem(`dataTable_manual_change_${tableId}:${userId}`) === 'true';\r\n if (hasManualChange) {\r\n const saved = localStorage.getItem(`dataTable_columns_${tableId}:${userId}`);\r\n if (saved) {\r\n const savedColumns = JSON.parse(saved);\r\n if (Array.isArray(savedColumns) && savedColumns.length > 0) {\r\n // Validate saved columns exist in current columns\r\n const validColumns = savedColumns.filter(colId => \r\n columns.some(col => (col.id || col.key) === colId)\r\n );\r\n if (validColumns.length > 0) {\r\n userHasManuallyChangedColumns.current = true;\r\n setVisibleColumns(validColumns.slice(0, MAX_COLUMNS));\r\n return;\r\n }\r\n }\r\n }\r\n }\r\n } catch (error) {\r\n console.warn('Failed to load saved columns from localStorage:', error);\r\n }\r\n }\r\n \r\n // Default to first 9 columns if no saved columns\r\n const columnIds = columns.map((col) => col.id || col.key);\r\n setVisibleColumns(columnIds.slice(0, MAX_COLUMNS));\r\n }\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, [columns, tableId, userId]);\r\n\r\n // Get ordered columns based on visibleColumns and columnOrder\r\n const orderedColumns = useMemo(() => {\r\n // Filter to only show visible columns, maintaining their order\r\n return visibleColumns\r\n .map((id) => columns.find((col) => getColumnId(col) === id))\r\n .filter(Boolean);\r\n }, [columns, visibleColumns]);\r\n\r\n // Check if any columns are filterable\r\n const hasFilterableColumns = useMemo(() => {\r\n return orderedColumns.some((col) => col.filterable === true);\r\n }, [orderedColumns]);\r\n\r\n // Column dropdown position management\r\n useEffect(() => {\r\n if (!isColumnDropdownOpen || !columnDropdownRef.current) return;\r\n\r\n const updatePosition = () => {\r\n if (columnDropdownRef.current) {\r\n const rect = columnDropdownRef.current.getBoundingClientRect();\r\n // For position: fixed, use viewport coordinates directly (no scroll offset needed)\r\n // This ensures the dropdown scrolls with the button\r\n // Connect menu directly to button (no gap)\r\n setColumnDropdownPosition({\r\n top: rect.bottom, // No gap - connect directly\r\n left: rect.left,\r\n width: Math.max(rect.width || 220, 220),\r\n });\r\n }\r\n };\r\n\r\n updatePosition();\r\n \r\n // Use simple scroll listeners like Dropdown component for smooth scrolling\r\n window.addEventListener(\"scroll\", updatePosition, true);\r\n window.addEventListener(\"resize\", updatePosition);\r\n\r\n return () => {\r\n window.removeEventListener(\"scroll\", updatePosition, true);\r\n window.removeEventListener(\"resize\", updatePosition);\r\n };\r\n }, [isColumnDropdownOpen]);\r\n\r\n // Close dropdown when clicking outside\r\n useEffect(() => {\r\n const handleClickOutside = (event) => {\r\n if (\r\n isColumnDropdownOpen &&\r\n columnDropdownRef.current &&\r\n !columnDropdownRef.current.contains(event.target) &&\r\n columnDropdownMenuRef.current &&\r\n !columnDropdownMenuRef.current.contains(event.target)\r\n ) {\r\n setIsColumnDropdownOpen(false);\r\n }\r\n };\r\n\r\n if (isColumnDropdownOpen) {\r\n document.addEventListener(\"mousedown\", handleClickOutside);\r\n return () => {\r\n document.removeEventListener(\"mousedown\", handleClickOutside);\r\n };\r\n }\r\n }, [isColumnDropdownOpen]);\r\n\r\n // Display text for dropdown button\r\n const displayText = visibleColumns.length === 1 \r\n ? columns.find(col => (col.id || col.key) === visibleColumns[0])?.label || \"1 selected\"\r\n : `${visibleColumns.length} selected`;\r\n\r\n // Sortable header cell component\r\n function SortableHeader({ column, isHeaderRow = true }) {\r\n const columnId = getColumnId(column);\r\n const {\r\n attributes,\r\n listeners,\r\n setNodeRef,\r\n transform,\r\n transition,\r\n isDragging,\r\n } = useSortable({ id: columnId });\r\n\r\n const style = {\r\n transform: CSS.Transform.toString(transform),\r\n transition,\r\n opacity: isDragging ? 0.5 : 1,\r\n width: column.width || \"auto\",\r\n minWidth: column.width || \"auto\",\r\n };\r\n\r\n // For server-side sorting, check if the sortField matches this column\r\n // Handle reverse mapping (e.g., \"csat_score\" matches \"evaluation.csat_score\")\r\n let isSorted = false;\r\n if (isServerSideSorting && sortFields.length > 0) {\r\n const sortFieldFromProps = sortFields[0][0];\r\n // Direct match\r\n if (sortFieldFromProps === columnId) {\r\n isSorted = true;\r\n }\r\n // Reverse mapping: \"csat_score\" matches \"evaluation.csat_score\"\r\n else if (sortFieldFromProps === \"csat_score\" && columnId === \"evaluation.csat_score\") {\r\n isSorted = true;\r\n }\r\n } else {\r\n // Client-side sorting: direct comparison\r\n isSorted = sortField === columnId;\r\n }\r\n \r\n const isAsc = sortDirection === \"asc\";\r\n const isFilterable = column.filterable === true; // Only filterable if explicitly set to true\r\n\r\n // Filter row\r\n if (!isHeaderRow) {\r\n return (\r\n <th\r\n style={{\r\n width: column.width || \"auto\",\r\n minWidth: column.width || \"auto\",\r\n }}\r\n className=\"sticky top-[57px] z-10 bg-[var(--paper-elevated)] border-b border-[var(--border-strong)] px-4 py-2 text-left\"\r\n >\r\n {isFilterable ? (\r\n <div className=\"relative\">\r\n <Filter\r\n size={12}\r\n className=\"absolute left-2 top-1/2 -translate-y-1/2 text-[var(--text-faint)] pointer-events-none\"\r\n />\r\n <input\r\n type=\"text\"\r\n placeholder=\"Filter...\"\r\n value={filters[columnId] || \"\"}\r\n onChange={(e) => {\r\n e.stopPropagation();\r\n handleFilterChange(columnId, e.target.value);\r\n }}\r\n onKeyDown={(e) => e.stopPropagation()}\r\n onMouseDown={(e) => e.stopPropagation()}\r\n className=\"w-full pl-7 pr-2 py-1.5 text-xs border border-[var(--border)] rounded bg-[var(--paper)] text-[var(--text-ink)] placeholder:text-[var(--text-faint)] focus:outline-none focus:border-[var(--border-hover)] focus:ring-1 focus:ring-[var(--focus)] transition-colors\"\r\n style={{ fontFamily: 'var(--font-sans)' }}\r\n autoComplete=\"off\"\r\n />\r\n </div>\r\n ) : (\r\n <div className=\"h-[34px]\"></div>\r\n )}\r\n </th>\r\n );\r\n }\r\n\r\n // Header row\r\n return (\r\n <th\r\n ref={setNodeRef}\r\n style={{\r\n ...style,\r\n padding: '12px 14px',\r\n textAlign: 'left',\r\n fontWeight: 650,\r\n fontSize: '11px',\r\n letterSpacing: '0.14em',\r\n textTransform: 'uppercase',\r\n color: 'rgba(30, 33, 37, 0.62)',\r\n cursor: column.sortable !== false ? 'pointer' : 'default',\r\n width: column.width || 'auto',\r\n borderRight: '1px solid rgba(52, 58, 64, 0.06)',\r\n userSelect: 'none',\r\n background: 'rgba(255, 255, 255, 0.95)',\r\n borderBottom: '1px solid rgba(52, 58, 64, 0.12)',\r\n position: 'sticky',\r\n top: 0,\r\n zIndex: 10,\r\n fontFamily: 'var(--font-sans)',\r\n }}\r\n >\r\n <div style={{ display: 'flex', alignItems: 'center', gap: '6px' }}>\r\n <div\r\n {...attributes}\r\n {...listeners}\r\n style={{ cursor: 'grab', color: 'rgba(30, 33, 37, 0.32)' }}\r\n >\r\n <GripVertical size={12} />\r\n </div>\r\n <span \r\n onClick={() => column.sortable !== false && handleSort(columnId)}\r\n style={{ cursor: column.sortable !== false ? 'pointer' : 'default' }}\r\n >\r\n {column.label.toUpperCase()}\r\n </span>\r\n {column.sortable !== false && isSorted && (\r\n <span>\r\n {isAsc ? <ChevronUp size={12} /> : <ChevronDown size={12} />}\r\n </span>\r\n )}\r\n </div>\r\n </th>\r\n );\r\n }\r\n\r\n // Drag overlay for column header\r\n const activeColumn = activeId ? columns.find((col) => getColumnId(col) === activeId) : null;\r\n\r\n // Column dropdown menu\r\n const columnDropdownMenu = isColumnDropdownOpen ? (\r\n <div\r\n ref={columnDropdownMenuRef}\r\n className=\"flex flex-col bg-white overflow-auto z-[49] min-w-[220px]\"\r\n style={{\r\n position: \"fixed\",\r\n top: `${columnDropdownPosition.top}px`,\r\n left: `${columnDropdownPosition.left}px`,\r\n width: columnDropdownPosition.width || 220,\r\n maxHeight: `400px`,\r\n fontFamily: 'var(--font-sans)',\r\n borderRadius: '0 0 8px 8px', // Rounded corners only on bottom\r\n boxShadow: '4px 4px 6px 0px #6D70681A, -4px 0px 6px 0px #6D70681A',\r\n border: '1px solid rgba(52, 58, 64, 0.12)',\r\n borderTop: 'none', // No top border to connect seamlessly\r\n }}\r\n >\r\n {/* Render selected columns first, in their current order */}\r\n {visibleColumns.map((columnId, index) => {\r\n const col = columns.find(c => getColumnId(c) === columnId);\r\n if (!col) return null;\r\n const actualIndex = visibleColumns.indexOf(columnId);\r\n const isDragging = draggedColumnIndex === actualIndex;\r\n const isDragOver = dragOverColumnIndex === actualIndex;\r\n \r\n return (\r\n <React.Fragment key={`selected-${columnId}-${index}`}>\r\n <div\r\n draggable\r\n onDragStart={(e) => handleColumnDragStart(e, actualIndex)}\r\n onDragEnd={handleColumnDragEnd}\r\n onDragOver={(e) => handleColumnDragOver(e, actualIndex)}\r\n onDragLeave={handleColumnDragLeave}\r\n onDrop={(e) => handleColumnDrop(e, actualIndex)}\r\n className={`flex items-center gap-2 px-3 py-2 rounded cursor-move transition-all ${\r\n isDragging ? 'opacity-50' : ''\r\n } ${\r\n isDragOver && draggedColumnIndex !== null && draggedColumnIndex !== actualIndex ? 'ring-2 ring-green-2 ring-offset-1' : ''\r\n }`}\r\n >\r\n {/* Drag icon */}\r\n <svg\r\n className=\"h-4 w-4 text-gray-600 flex-shrink-0\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n viewBox=\"0 0 24 24\"\r\n >\r\n <path\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n strokeWidth={2}\r\n d=\"M4 8h16M4 12h16M4 16h16\"\r\n />\r\n </svg>\r\n {/* Checkbox */}\r\n <button\r\n type=\"button\"\r\n onClick={(e) => {\r\n e.preventDefault();\r\n e.stopPropagation();\r\n toggleColumnSelection(columnId);\r\n }}\r\n className={`h-4 w-4 rounded-[2px] border flex items-center justify-center transition-colors flex-shrink-0 ${\r\n pendingDeselection.has(columnId) ? 'bg-white border-gray-300' : 'bg-green-2 border-green-2'\r\n }`}\r\n >\r\n {!pendingDeselection.has(columnId) && (\r\n <svg\r\n className=\"h-3 w-3\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n viewBox=\"0 0 24 24\"\r\n strokeWidth={3}\r\n style={{ color: '#1E2125' }}\r\n >\r\n <path\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n d=\"M5 13l4 4L19 7\"\r\n />\r\n </svg>\r\n )}\r\n </button>\r\n {/* Label */}\r\n <span className=\"text-sm text-gray-900 flex-1\" style={{ fontFamily: 'var(--font-sans)' }}>{col.label}</span>\r\n </div>\r\n {index < visibleColumns.length - 1 && <Separator />}\r\n </React.Fragment>\r\n );\r\n })}\r\n \r\n {/* Render unselected columns */}\r\n {columns\r\n .filter(col => !visibleColumns.includes(getColumnId(col)))\r\n .map((col, index) => {\r\n const columnId = getColumnId(col);\r\n const isPending = pendingSelection.has(columnId);\r\n const unselectedIndex = columns.filter(c => !visibleColumns.includes(getColumnId(c))).indexOf(col);\r\n return (\r\n <React.Fragment key={`unselected-${columnId}`}>\r\n {visibleColumns.length > 0 && unselectedIndex === 0 && <Separator />}\r\n <label\r\n className=\"flex items-center gap-2 px-3 py-2 hover:bg-gray-50 rounded cursor-pointer transition-colors\"\r\n onClick={(e) => {\r\n e.preventDefault();\r\n toggleColumnSelection(columnId);\r\n }}\r\n >\r\n <button\r\n type=\"button\"\r\n onClick={(e) => {\r\n e.preventDefault();\r\n e.stopPropagation();\r\n toggleColumnSelection(columnId);\r\n }}\r\n className={`h-4 w-4 rounded-[2px] border flex items-center justify-center transition-colors flex-shrink-0 ${\r\n isPending ? 'bg-green-2 border-green-2' : 'bg-white border-gray-300'\r\n }`}\r\n >\r\n {isPending && (\r\n <svg\r\n className=\"h-3 w-3\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n viewBox=\"0 0 24 24\"\r\n strokeWidth={3}\r\n style={{ color: '#1E2125' }}\r\n >\r\n <path\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n d=\"M5 13l4 4L19 7\"\r\n />\r\n </svg>\r\n )}\r\n </button>\r\n {/* Label */}\r\n <span className=\"text-sm text-gray-900 flex-1\">{col.label}</span>\r\n </label>\r\n {unselectedIndex < columns.filter(c => !visibleColumns.includes(getColumnId(c))).length - 1 && <Separator />}\r\n </React.Fragment>\r\n );\r\n })}\r\n </div>\r\n ) : null;\r\n\r\n return (\r\n <div className=\"w-full\" style={{top:'130px', position: 'sticky', zIndex: 35, backgroundColor: \"#F4F1E6\"}}>\r\n {/* Column Visibility Dropdown and Filters */}\r\n {columns.length > 0 && (\r\n <div \r\n className=\"pt-2 pb-1\"\r\n style={{\r\n position: \"sticky\",\r\n zIndex: 35,\r\n backgroundColor: \"#F4F1E6\",\r\n }}\r\n >\r\n <div className=\"flex items-center gap-3 flex-wrap\">\r\n {/* Select Columns Dropdown */}\r\n <div className=\"flex-shrink-0\">\r\n {/* Dropdown Title */}\r\n <div className=\"mb-1 ml-1.5\">\r\n <p className=\"text-xs font-medium text-gray-600\" style={{ fontFamily: 'var(--font-sans)' }}>Select Columns</p>\r\n </div>\r\n <div\r\n ref={columnDropdownRef}\r\n className=\"inline-flex items-center justify-between gap-2 px-4 py-2.5 bg-white/80 cursor-pointer hover:bg-white transition-colors text-sm font-medium text-gray-900 border border-gray-300 min-w-[220px]\"\r\n onClick={() => setIsColumnDropdownOpen(!isColumnDropdownOpen)}\r\n style={{ \r\n fontFamily: 'var(--font-sans)',\r\n borderRadius: isColumnDropdownOpen ? '8px 8px 0 0' : '8px', // Rounded top corners when open, all corners when closed\r\n }}\r\n >\r\n <span>{displayText}</span>\r\n <OpenCloseArrow isOpen={isColumnDropdownOpen} iconSize={16} />\r\n </div>\r\n {isColumnDropdownOpen && createPortal(columnDropdownMenu, document.body)}\r\n </div>\r\n\r\n {/* Vertical Line */}\r\n {filtersConfig && (\r\n <>\r\n <div className=\"h-9 mt-[1.5rem] w-px bg-gray-300 flex-shrink-0\"></div>\r\n <div className=\"flex-shrink-0 mt-[1.5rem]\">\r\n {/* Filters Component (Export, chips, Add Users, etc.) */}\r\n <DataTableFilters\r\n dateRangePicker={filtersConfig.dateRangePicker}\r\n onWeekToDate={filtersConfig.onWeekToDate}\r\n exportConfig={filtersConfig.exportConfig}\r\n filterChipsConfig={filtersConfig.filterChipsConfig}\r\n trailingActions={filtersConfig.trailingActions}\r\n />\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n </div>\r\n )}\r\n {/* Only render table if we have columns */}\r\n {columns.length > 0 && orderedColumns.length > 0 ? (\r\n <DndContext\r\n sensors={sensors}\r\n collisionDetection={closestCenter}\r\n onDragStart={handleDragStart}\r\n onDragEnd={handleDragEnd}\r\n >\r\n <div className=\"rounded-t-[14px]\" style={{\r\n border: '1px solid rgba(52, 58, 64, 0.12)',\r\n borderBottom: 'none',\r\n overflow: 'hidden',\r\n background: 'rgba(255, 255, 255, 0.82)',\r\n position: 'relative',\r\n top:'0.5rem'\r\n }}>\r\n {/* Loading overlay */}\r\n {isLoading && (\r\n <div style={{\r\n position: 'absolute',\r\n inset: 0,\r\n background: 'rgba(255, 255, 255, 0.9)',\r\n backdropFilter: 'blur(2px)',\r\n zIndex: 20,\r\n display: 'flex',\r\n flexDirection: 'column',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n borderRadius: '14px'\r\n }}>\r\n <div style={{\r\n display: 'flex',\r\n flexDirection: 'column',\r\n alignItems: 'center',\r\n gap: '12px'\r\n }}>\r\n <p style={{\r\n fontSize: '13px',\r\n color: 'rgba(30, 33, 37, 0.6)',\r\n margin: 0\r\n }}>Loading...</p>\r\n <Image\r\n src=\"/BrandLoading.gif\"\r\n alt=\"Loading\"\r\n width={50}\r\n height={50}\r\n unoptimized\r\n className=\"mt-1\"\r\n />\r\n </div>\r\n </div>\r\n )}\r\n <div className=\"overflow-x-auto custom-thin-scrollbar-hidden\" ref={tableRef} style={{ maxHeight: '500px', overflowY: 'auto', position: 'relative', zIndex: 1 }}>\r\n <table style={{\r\n width: '100%',\r\n borderCollapse: 'collapse',\r\n fontSize: '13px',\r\n fontFamily: 'var(--font-sans)'\r\n }}>\r\n <thead>\r\n {/* Header row with column labels */}\r\n <tr>\r\n <SortableContext\r\n items={visibleColumns}\r\n strategy={horizontalListSortingStrategy}\r\n >\r\n {orderedColumns.map((column) => (\r\n <SortableHeader key={`header-${getColumnId(column)}`} column={column} isHeaderRow={true} />\r\n ))}\r\n </SortableContext>\r\n </tr>\r\n {/* Filter row - only show if there are filterable columns */}\r\n {hasFilterableColumns && (\r\n <tr>\r\n {orderedColumns.map((column) => {\r\n const columnId = getColumnId(column);\r\n const isFilterable = column.filterable === true;\r\n return (\r\n <th\r\n key={`filter-${columnId}`}\r\n style={{\r\n padding: '8px 14px',\r\n background: 'rgba(244, 241, 230, 0.35)',\r\n borderBottom: '1px solid rgba(52, 58, 64, 0.10)',\r\n position: 'sticky',\r\n top: '41px',\r\n zIndex: 10,\r\n width: column.width || 'auto',\r\n fontFamily: 'var(--font-sans)',\r\n }}\r\n >\r\n {isFilterable ? (\r\n <div style={{ position: 'relative' }}>\r\n <input\r\n type=\"text\"\r\n placeholder=\"Filter...\"\r\n value={filters[columnId] || \"\"}\r\n onChange={(e) => {\r\n e.stopPropagation();\r\n handleFilterChange(columnId, e.target.value);\r\n }}\r\n onKeyDown={(e) => e.stopPropagation()}\r\n onMouseDown={(e) => e.stopPropagation()}\r\n style={{\r\n width: '100%',\r\n padding: '4px 8px 4px 26px',\r\n fontSize: '11.5px',\r\n border: '1px solid rgba(52, 58, 64, 0.16)',\r\n borderRadius: '6px',\r\n background: 'rgba(255, 255, 255, 0.85)',\r\n color: 'rgba(30, 33, 37, 0.78)',\r\n outline: 'none',\r\n fontFamily: 'var(--font-sans)',\r\n }}\r\n onFocus={(e) => {\r\n e.target.style.borderColor = 'rgba(231, 212, 162, 0.65)';\r\n e.target.style.background = 'rgba(255, 255, 255, 1)';\r\n }}\r\n onBlur={(e) => {\r\n e.target.style.borderColor = 'rgba(52, 58, 64, 0.16)';\r\n e.target.style.background = 'rgba(255, 255, 255, 0.85)';\r\n }}\r\n autoComplete=\"off\"\r\n />\r\n <Filter\r\n size={11}\r\n style={{\r\n position: 'absolute',\r\n left: '8px',\r\n top: '50%',\r\n transform: 'translateY(-50%)',\r\n color: 'rgba(30, 33, 37, 0.42)',\r\n pointerEvents: 'none'\r\n }}\r\n />\r\n </div>\r\n ) : (\r\n <div className=\"h-[34px]\"></div>\r\n )}\r\n </th>\r\n );\r\n })}\r\n </tr>\r\n )}\r\n </thead>\r\n <tbody>\r\n {!isLoading && paginatedData.length === 0 ? (\r\n <tr>\r\n <td\r\n colSpan={orderedColumns.length}\r\n style={{\r\n padding: '32px',\r\n textAlign: 'center',\r\n color: 'rgba(30, 33, 37, 0.42)',\r\n fontSize: '12px',\r\n fontFamily: 'var(--font-sans)',\r\n }}\r\n >\r\n No results found\r\n </td>\r\n </tr>\r\n ) : !isLoading && paginatedData.length > 0 ? (\r\n paginatedData.map((row, rowIndex) => (\r\n <tr\r\n key={rowIndex}\r\n data-row-id={row.id || rowIndex}\r\n style={{\r\n borderBottom: '1px solid rgba(52, 58, 64, 0.08)',\r\n cursor: onRowClick ? 'pointer' : 'default',\r\n transition: 'background 0.15s ease'\r\n }}\r\n onClick={onRowClick ? (e) => {\r\n e.stopPropagation();\r\n onRowClick(row, rowIndex);\r\n } : undefined}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background = 'rgba(231, 212, 162, 0.12)';\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = 'transparent';\r\n }}\r\n >\r\n {orderedColumns.map((column) => {\r\n const columnId = getColumnId(column);\r\n const cellValue = row[columnId];\r\n const renderValue = column.render\r\n ? column.render(cellValue, row)\r\n : cellValue;\r\n\r\n // Only show tooltip for string values that might be truncated\r\n const hasWidthConstraint = column.width && column.width !== 'auto';\r\n const isStringValue = typeof renderValue === 'string' && renderValue.trim() !== '';\r\n const shouldUseTruncatedCell = hasWidthConstraint && isStringValue;\r\n\r\n const displayValue = shouldUseTruncatedCell ? (\r\n <TruncatedCell content={renderValue}>\r\n {renderValue}\r\n </TruncatedCell>\r\n ) : renderValue;\r\n\r\n return (\r\n <td\r\n key={columnId}\r\n style={{\r\n padding: '10px 14px',\r\n color: 'rgba(30, 33, 37, 0.78)',\r\n fontSize: '13px',\r\n borderRight: '1px solid rgba(52, 58, 64, 0.04)',\r\n width: column.width || 'auto',\r\n fontFamily: 'var(--font-sans)',\r\n ...(shouldUseTruncatedCell && { maxWidth: column.width || '200px', overflow: 'hidden' }),\r\n }}\r\n >\r\n {displayValue}\r\n </td>\r\n );\r\n })}\r\n </tr>\r\n ))\r\n ) : null}\r\n </tbody>\r\n </table>\r\n </div>\r\n </div>\r\n\r\n <DragOverlay>\r\n {activeColumn ? (\r\n <div className=\"bg-[var(--paper-high)] border border-[var(--border-strong)] rounded px-4 py-2 shadow-lg\">\r\n <div className=\"flex items-center gap-2\">\r\n <GripVertical size={14} className=\"text-[var(--text-faint)]\" />\r\n <span className=\"text-sm font-semibold text-[var(--text-ink)]\">\r\n {activeColumn.label}\r\n </span>\r\n </div>\r\n </div>\r\n ) : null}\r\n </DragOverlay>\r\n </DndContext>\r\n ) : null}\r\n\r\n {(isServerSidePagination ? totalCount > 0 : sortedData.length > 0) && (\r\n <div className=\"border-t border-gray-200 bg-white rounded-b-[14px]\">\r\n <Pagination\r\n page={page}\r\n pageSizeOptions={[5,10, 20, 50, 100]}\r\n pageSize={pageSize}\r\n totalCount={isServerSidePagination ? totalCount : sortedData.length}\r\n currentDataLength={paginatedData.length}\r\n onPageChange={setPage}\r\n onPageSizeChange={onPageSizeChange ? (newSize) => {\r\n setPageSize(newSize);\r\n setPage(1);\r\n } : (newSize) => {\r\n setPageSize(newSize);\r\n setPage(1);\r\n }}\r\n showPageSizeSelector={true}\r\n />\r\n </div>\r\n )}\r\n </div>\r\n );\r\n}\r\n\r\n","\"use client\";\r\n\r\n/**\r\n * SummaryStatsPanel component\r\n * Displays key interaction metrics in a compact grid layout.\r\n * Designed for right or left rails with 2-column default.\r\n * Optional left accent bar draws attention to specific metrics without judgment.\r\n */\r\n\r\nexport default function SummaryStatsPanel({\r\n title = 'Summary stats',\r\n stats = [],\r\n columns = 2\r\n}) {\r\n return (\r\n <div style={{ fontFamily: 'system-ui, -apple-system, sans-serif' }}>\r\n {/* Header */}\r\n <div\r\n className=\"text-[11px] tracking-[0.14em] uppercase mb-[10px]\"\r\n style={{ color: 'rgba(30, 33, 37, 0.42)', fontWeight: 650 }}\r\n >\r\n {title}\r\n </div>\r\n\r\n {/* Grid */}\r\n <div\r\n style={{\r\n display: 'grid',\r\n gridTemplateColumns: `repeat(${columns}, minmax(0, 1fr))`,\r\n gap: '10px'\r\n }}\r\n >\r\n {stats.map((stat, i) => (\r\n <div\r\n key={i}\r\n style={{\r\n position: 'relative',\r\n border: '1px solid rgba(52, 58, 64, 0.12)',\r\n borderRadius: '12px',\r\n background: 'rgba(255, 255, 255, 0.72)',\r\n padding: stat.accentColor ? '10px 10px 10px 14px' : '10px',\r\n minHeight: '62px',\r\n display: 'flex',\r\n flexDirection: 'column',\r\n justifyContent: 'center',\r\n gap: '5px',\r\n overflow: 'hidden'\r\n }}\r\n >\r\n {/* Optional accent indicator */}\r\n {stat.accentColor && (\r\n <div\r\n style={{\r\n position: 'absolute',\r\n left: 0,\r\n top: 0,\r\n bottom: 0,\r\n width: '4px',\r\n background: stat.accentColor,\r\n borderTopLeftRadius: '12px',\r\n borderBottomLeftRadius: '12px'\r\n }}\r\n />\r\n )}\r\n\r\n {/* Label */}\r\n <div\r\n className=\"text-[10px] tracking-[0.14em] uppercase\"\r\n style={{\r\n color: 'rgba(30, 33, 37, 0.42)',\r\n fontWeight: 650,\r\n lineHeight: 1.1,\r\n whiteSpace: 'nowrap',\r\n overflow: 'hidden',\r\n textOverflow: 'ellipsis'\r\n }}\r\n >\r\n {stat.label}\r\n </div>\r\n\r\n {/* Value */}\r\n <div\r\n style={{\r\n fontSize: '13px',\r\n color: stat.valueStyle === 'muted' \r\n ? 'rgba(30, 33, 37, 0.56)' \r\n : 'rgba(30, 33, 37, 0.78)',\r\n fontWeight: 700,\r\n lineHeight: 1.15,\r\n whiteSpace: 'nowrap',\r\n overflow: 'hidden',\r\n textOverflow: 'ellipsis',\r\n fontFamily: stat.valueStyle === 'mono' \r\n ? 'ui-monospace, monospace' \r\n : 'inherit'\r\n }}\r\n >\r\n {stat.value}\r\n </div>\r\n\r\n {/* Subtext */}\r\n {stat.subtext && (\r\n <div\r\n style={{\r\n fontSize: '11px',\r\n color: 'rgba(30, 33, 37, 0.52)',\r\n lineHeight: 1.15,\r\n whiteSpace: 'nowrap',\r\n overflow: 'hidden',\r\n textOverflow: 'ellipsis'\r\n }}\r\n >\r\n {stat.subtext}\r\n </div>\r\n )}\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n );\r\n}\r\n\r\n","\"use client\";\r\n\r\nimport React from \"react\";\r\n\r\n/**\r\n * Direction rail color mapping.\r\n * Uses rail colors for categorization, not judgment.\r\n */\r\nconst DIRECTION_COLORS = {\r\n inbound: \"var(--rail-discovery, #5E88B0)\",\r\n outbound: \"var(--rail-purple, #9B7AA8)\",\r\n internal: \"var(--rail-outcome, #6B7C93)\",\r\n chat: \"var(--rail-teal, #7BA89D)\",\r\n};\r\n\r\n/**\r\n * Format seconds to mm:ss or h:mm:ss\r\n */\r\nconst formatDuration = (seconds) => {\r\n if (seconds == null || seconds <= 0) return null;\r\n const h = Math.floor(seconds / 3600);\r\n const m = Math.floor((seconds % 3600) / 60);\r\n const s = Math.round(seconds % 60);\r\n if (h > 0) return `${h}:${String(m).padStart(2, \"0\")}:${String(s).padStart(2, \"0\")}`;\r\n return `${m}:${String(s).padStart(2, \"0\")}`;\r\n};\r\n\r\n/**\r\n * Format a date string to a compact, readable form.\r\n */\r\nconst formatDate = (dateStr) => {\r\n if (!dateStr) return null;\r\n try {\r\n return new Date(dateStr).toLocaleDateString(\"en-US\", {\r\n month: \"short\",\r\n day: \"numeric\",\r\n hour: \"2-digit\",\r\n minute: \"2-digit\",\r\n });\r\n } catch {\r\n return null;\r\n }\r\n};\r\n\r\n/**\r\n * InteractionCard Component\r\n * Displays a summary card for a completed interaction (call/chat).\r\n * Designed for use in history lists, search results, and monitoring views.\r\n *\r\n * Uses the Chordia design language: left rail, muted metadata,\r\n * non-judgmental score display, subtle hover states.\r\n *\r\n * @param {Object} props\r\n * @param {string} [props.title] - Primary label (e.g., call purpose, one-liner)\r\n * @param {string} [props.agentName] - Agent who handled the interaction\r\n * @param {string} [props.customerName] - Customer name (omit if unknown)\r\n * @param {string} [props.date] - ISO date string for when the interaction occurred\r\n * @param {number} [props.duration] - Duration in seconds\r\n * @param {string} [props.direction] - \"inbound\" | \"outbound\" | \"internal\" | \"chat\"\r\n * @param {string} [props.driver] - Call driver / reason\r\n * @param {string} [props.sentiment] - Customer sentiment label\r\n * @param {string} [props.disposition] - Call disposition / outcome label\r\n * @param {Array} [props.scores] - [{label, value}] score metrics to display\r\n * @param {Array} [props.tags] - [{label, color?}] additional tag pills\r\n * @param {string} [props.railColor] - Override the left rail color\r\n * @param {boolean} [props.isActive] - Whether this card is currently selected/active\r\n * @param {Function} [props.onClick] - Click handler\r\n * @param {React.ReactNode} [props.children] - Additional content below the card body\r\n */\r\nexport default function InteractionCard({\r\n title,\r\n agentName,\r\n customerName,\r\n date,\r\n duration,\r\n direction,\r\n driver,\r\n sentiment,\r\n disposition,\r\n scores,\r\n tags,\r\n railColor,\r\n isActive = false,\r\n onClick,\r\n children,\r\n}) {\r\n const resolvedRailColor =\r\n railColor || DIRECTION_COLORS[direction] || \"var(--rail-outcome, #6B7C93)\";\r\n const formattedDuration = formatDuration(duration);\r\n const formattedDate = formatDate(date);\r\n\r\n // Collect metadata items\r\n const metaItems = [];\r\n if (agentName) metaItems.push(agentName);\r\n if (customerName) metaItems.push(customerName);\r\n if (formattedDate) metaItems.push(formattedDate);\r\n if (formattedDuration) metaItems.push(formattedDuration);\r\n\r\n // Collect tag items from explicit tags + contextual fields\r\n const allTags = [];\r\n if (direction) allTags.push({ label: direction });\r\n if (driver) allTags.push({ label: driver });\r\n if (sentiment) allTags.push({ label: sentiment });\r\n if (disposition) allTags.push({ label: disposition });\r\n if (tags) allTags.push(...tags);\r\n\r\n return (\r\n <div\r\n onClick={onClick}\r\n style={{\r\n position: \"relative\",\r\n padding: \"10px 14px 10px 18px\",\r\n borderRadius: \"var(--radius-md, 8px)\",\r\n overflow: \"hidden\",\r\n background: isActive\r\n ? \"var(--hover-warm-subtle, rgba(231,212,162,0.08))\"\r\n : \"var(--paper-elevated, rgba(255,255,255,0.82))\",\r\n border: `1px solid ${\r\n isActive\r\n ? \"var(--border-hover, rgba(52,58,64,0.18))\"\r\n : \"var(--border, rgba(52,58,64,0.12))\"\r\n }`,\r\n cursor: onClick ? \"pointer\" : \"default\",\r\n transition: \"background 0.15s, border-color 0.15s\",\r\n }}\r\n onMouseEnter={(e) => {\r\n if (!isActive && onClick) {\r\n e.currentTarget.style.background =\r\n \"var(--hover-warm-subtle, rgba(231,212,162,0.08))\";\r\n e.currentTarget.style.borderColor =\r\n \"var(--border-hover, rgba(52,58,64,0.18))\";\r\n }\r\n }}\r\n onMouseLeave={(e) => {\r\n if (!isActive) {\r\n e.currentTarget.style.background =\r\n \"var(--paper-elevated, rgba(255,255,255,0.82))\";\r\n e.currentTarget.style.borderColor =\r\n \"var(--border, rgba(52,58,64,0.12))\";\r\n }\r\n }}\r\n >\r\n {/* Left rail */}\r\n <div\r\n style={{\r\n position: \"absolute\",\r\n left: 0,\r\n top: 0,\r\n bottom: 0,\r\n width: \"var(--rail-width-thin, 4px)\",\r\n backgroundColor: resolvedRailColor,\r\n borderRadius: \"var(--radius-md, 8px) 0 0 var(--radius-md, 8px)\",\r\n }}\r\n />\r\n\r\n {/* Main content row */}\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"flex-start\",\r\n justifyContent: \"space-between\",\r\n gap: 12,\r\n }}\r\n >\r\n {/* Left: title + metadata */}\r\n <div style={{ flex: 1, minWidth: 0 }}>\r\n {/* Title */}\r\n {title ? (\r\n <div\r\n style={{\r\n fontSize: \"var(--text-md, 13px)\",\r\n fontWeight: 550,\r\n color: \"var(--text-strong, rgba(30,33,37,0.92))\",\r\n overflow: \"hidden\",\r\n textOverflow: \"ellipsis\",\r\n whiteSpace: \"nowrap\",\r\n lineHeight: \"var(--leading-snug, 1.375)\",\r\n }}\r\n >\r\n {title}\r\n </div>\r\n ) : null}\r\n\r\n {/* Metadata row */}\r\n {metaItems.length > 0 ? (\r\n <div\r\n style={{\r\n display: \"flex\",\r\n flexWrap: \"wrap\",\r\n gap: 6,\r\n marginTop: 3,\r\n fontSize: \"var(--text-sm, 11px)\",\r\n color: \"var(--text-muted, rgba(30,33,37,0.56))\",\r\n lineHeight: \"var(--leading-snug, 1.375)\",\r\n }}\r\n >\r\n {metaItems.map((item, i) => (\r\n <React.Fragment key={i}>\r\n {i > 0 ? (\r\n <span\r\n style={{\r\n color: \"var(--text-xfaint, rgba(30,33,37,0.28))\",\r\n }}\r\n >\r\n ·\r\n </span>\r\n ) : null}\r\n <span>{item}</span>\r\n </React.Fragment>\r\n ))}\r\n </div>\r\n ) : null}\r\n\r\n {/* Tags row */}\r\n {allTags.length > 0 ? (\r\n <div\r\n style={{\r\n display: \"flex\",\r\n flexWrap: \"wrap\",\r\n gap: 4,\r\n marginTop: 6,\r\n }}\r\n >\r\n {allTags.map((tag, i) => (\r\n <span\r\n key={i}\r\n style={{\r\n display: \"inline-block\",\r\n fontSize: \"var(--text-xs, 10px)\",\r\n fontWeight: 500,\r\n padding: \"1px 7px\",\r\n borderRadius: 999,\r\n background: \"var(--paper, rgba(255,255,255,0.78))\",\r\n border: \"1px solid var(--border-subtle, rgba(52,58,64,0.08))\",\r\n color: tag.color || \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n textTransform: \"capitalize\",\r\n letterSpacing: \"0.01em\",\r\n lineHeight: 1.5,\r\n }}\r\n >\r\n {tag.label}\r\n </span>\r\n ))}\r\n </div>\r\n ) : null}\r\n </div>\r\n\r\n {/* Right: score pills */}\r\n {scores && scores.length > 0 ? (\r\n <div\r\n style={{\r\n display: \"flex\",\r\n gap: 10,\r\n flexShrink: 0,\r\n alignItems: \"flex-start\",\r\n paddingTop: 2,\r\n }}\r\n >\r\n {scores.map((score, i) => (\r\n <div key={i} style={{ textAlign: \"center\", minWidth: 28 }}>\r\n <div\r\n style={{\r\n fontSize: \"var(--text-lg, 14px)\",\r\n fontWeight: 600,\r\n color: \"var(--text-strong, rgba(30,33,37,0.92))\",\r\n fontFamily: \"var(--font-mono, monospace)\",\r\n lineHeight: 1.2,\r\n }}\r\n >\r\n {score.value != null ? Math.round(score.value) : \"—\"}\r\n </div>\r\n <div\r\n style={{\r\n fontSize: \"var(--text-xxs, 9px)\",\r\n fontWeight: 650,\r\n textTransform: \"uppercase\",\r\n letterSpacing: \"var(--tracking-label, 0.16em)\",\r\n color: \"var(--text-xfaint, rgba(30,33,37,0.28))\",\r\n marginTop: 1,\r\n }}\r\n >\r\n {score.label}\r\n </div>\r\n </div>\r\n ))}\r\n </div>\r\n ) : null}\r\n </div>\r\n\r\n {/* Optional children slot */}\r\n {children}\r\n </div>\r\n );\r\n}\r\n","\"use client\";\r\n\r\nimport React, { useState } from \"react\";\r\nimport { Wrench, Copy, Check, PanelRightOpen } from \"lucide-react\";\r\n\r\n/**\r\n * Lightweight Markdown Renderer\r\n * Handles: code blocks, inline code, bold, italic, links, lists, headers, horizontal rules, file paths\r\n */\r\nconst MarkdownRenderer = ({ content, onCodeBlockClick, onFilePathClick }) => {\r\n const [copiedBlocks, setCopiedBlocks] = useState(new Set());\r\n\r\n const copyToClipboard = async (text, blockId) => {\r\n try {\r\n await navigator.clipboard.writeText(text);\r\n setCopiedBlocks(prev => new Set([...prev, blockId]));\r\n setTimeout(() => {\r\n setCopiedBlocks(prev => {\r\n const newSet = new Set(prev);\r\n newSet.delete(blockId);\r\n return newSet;\r\n });\r\n }, 2000);\r\n } catch (err) {\r\n console.error('Failed to copy text:', err);\r\n }\r\n };\r\n\r\n const renderCodeBlock = (code, language, blockId) => {\r\n const isCopied = copiedBlocks.has(blockId);\r\n \r\n return (\r\n <div \r\n key={blockId}\r\n style={{\r\n position: 'relative',\r\n marginBottom: '16px',\r\n borderRadius: '8px',\r\n background: 'var(--ink, #1E2125)',\r\n border: '1px solid var(--border-subtle, rgba(52,58,64,0.08))',\r\n overflow: 'hidden',\r\n }}\r\n >\r\n {/* Header with language and copy button */}\r\n <div style={{\r\n display: 'flex',\r\n justifyContent: 'space-between',\r\n alignItems: 'center',\r\n padding: '8px 12px',\r\n background: 'rgba(255,255,255,0.05)',\r\n borderBottom: '1px solid rgba(255,255,255,0.1)',\r\n }}>\r\n <span style={{\r\n fontSize: '11px',\r\n color: 'rgba(255,255,255,0.7)',\r\n fontFamily: 'var(--font-mono, monospace)',\r\n textTransform: 'uppercase',\r\n letterSpacing: '0.05em',\r\n }}>\r\n {language || 'code'}\r\n </span>\r\n <button\r\n onClick={() => copyToClipboard(code, blockId)}\r\n style={{\r\n background: 'none',\r\n border: 'none',\r\n color: 'rgba(255,255,255,0.7)',\r\n cursor: 'pointer',\r\n padding: '4px',\r\n borderRadius: '4px',\r\n display: 'flex',\r\n alignItems: 'center',\r\n gap: '4px',\r\n fontSize: '11px',\r\n transition: 'all 0.15s ease',\r\n }}\r\n onMouseEnter={(e) => {\r\n e.target.style.background = 'rgba(255,255,255,0.1)';\r\n e.target.style.color = 'rgba(255,255,255,0.9)';\r\n }}\r\n onMouseLeave={(e) => {\r\n e.target.style.background = 'none';\r\n e.target.style.color = 'rgba(255,255,255,0.7)';\r\n }}\r\n >\r\n {isCopied ? <Check size={12} /> : <Copy size={12} />}\r\n {isCopied ? 'Copied!' : 'Copy'}\r\n </button>\r\n {onCodeBlockClick && (\r\n <button\r\n onClick={() => onCodeBlockClick({ code, language })}\r\n style={{\r\n background: 'none',\r\n border: 'none',\r\n color: 'rgba(255,255,255,0.7)',\r\n cursor: 'pointer',\r\n padding: '4px',\r\n borderRadius: '4px',\r\n display: 'flex',\r\n alignItems: 'center',\r\n gap: '4px',\r\n fontSize: '11px',\r\n transition: 'all 0.15s ease',\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background = 'rgba(255,255,255,0.1)';\r\n e.currentTarget.style.color = 'rgba(255,255,255,0.9)';\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = 'none';\r\n e.currentTarget.style.color = 'rgba(255,255,255,0.7)';\r\n }}\r\n >\r\n <PanelRightOpen size={12} />\r\n Canvas\r\n </button>\r\n )}\r\n </div>\r\n {/* Code content */}\r\n <pre style={{\r\n margin: 0,\r\n padding: '12px',\r\n fontFamily: 'var(--font-mono, monospace)',\r\n fontSize: '13px',\r\n lineHeight: 1.4,\r\n color: 'rgba(255,255,255,0.95)',\r\n overflow: 'auto',\r\n whiteSpace: 'pre-wrap',\r\n wordBreak: 'break-word',\r\n }}>\r\n {code}\r\n </pre>\r\n </div>\r\n );\r\n };\r\n\r\n const parseMarkdown = (text) => {\r\n const elements = [];\r\n const lines = text.split('\\n');\r\n let i = 0;\r\n let blockId = 0;\r\n\r\n while (i < lines.length) {\r\n const line = lines[i];\r\n \r\n // Code blocks (```language)\r\n if (line.trim().startsWith('```')) {\r\n const language = line.trim().slice(3);\r\n let codeLines = [];\r\n i++;\r\n \r\n while (i < lines.length && !lines[i].trim().startsWith('```')) {\r\n codeLines.push(lines[i]);\r\n i++;\r\n }\r\n \r\n if (i < lines.length) i++; // Skip closing ```\r\n \r\n elements.push(renderCodeBlock(codeLines.join('\\n'), language, `code-${blockId++}`));\r\n continue;\r\n }\r\n \r\n // Headers\r\n if (line.startsWith('#')) {\r\n const level = line.match(/^#+/)[0].length;\r\n const text = line.slice(level).trim();\r\n const HeaderTag = level === 1 ? 'h2' : level === 2 ? 'h3' : level === 3 ? 'h4' : 'h5';\r\n \r\n elements.push(\r\n React.createElement(HeaderTag, {\r\n key: `header-${i}`,\r\n style: {\r\n fontSize: level === 1 ? '18px' : level === 2 ? '16px' : '14px',\r\n fontWeight: 720,\r\n color: 'var(--text-strong, rgba(30,33,37,0.92))',\r\n marginTop: elements.length > 0 ? '20px' : '0',\r\n marginBottom: '8px',\r\n lineHeight: 1.3,\r\n }\r\n }, text)\r\n );\r\n i++;\r\n continue;\r\n }\r\n \r\n // Horizontal rule\r\n if (line.trim() === '---' || line.trim() === '***') {\r\n elements.push(\r\n <hr key={`hr-${i}`} style={{\r\n border: 'none',\r\n borderTop: '1px solid var(--border-subtle, rgba(52,58,64,0.08))',\r\n margin: '16px 0',\r\n }} />\r\n );\r\n i++;\r\n continue;\r\n }\r\n \r\n // Lists\r\n if (line.match(/^(\\s*)([-*+]|\\d+\\.)\\s/)) {\r\n const listItems = [];\r\n const isOrdered = /^\\s*\\d+\\./.test(line);\r\n \r\n while (i < lines.length && (lines[i].match(/^(\\s*)([-*+]|\\d+\\.)\\s/) || lines[i].trim() === '')) {\r\n if (lines[i].trim() !== '') {\r\n const match = lines[i].match(/^(\\s*)([-*+]|\\d+\\.)\\s(.*)$/);\r\n if (match) {\r\n listItems.push(match[3]);\r\n }\r\n }\r\n i++;\r\n }\r\n \r\n const ListTag = isOrdered ? 'ol' : 'ul';\r\n elements.push(\r\n React.createElement(ListTag, {\r\n key: `list-${i}`,\r\n style: {\r\n margin: '8px 0',\r\n paddingLeft: '20px',\r\n color: 'var(--text-strong, rgba(30,33,37,0.92))',\r\n }\r\n }, listItems.map((item, idx) => \r\n React.createElement('li', {\r\n key: `item-${idx}`,\r\n style: { marginBottom: '4px' }\r\n }, parseInlineMarkdownWithContext(item))\r\n ))\r\n );\r\n continue;\r\n }\r\n \r\n // Tables (lines starting with |)\r\n if (line.trim().startsWith('|') && line.trim().endsWith('|')) {\r\n const tableRows = [];\r\n while (i < lines.length && lines[i].trim().startsWith('|') && lines[i].trim().endsWith('|')) {\r\n tableRows.push(lines[i]);\r\n i++;\r\n }\r\n \r\n if (tableRows.length >= 2) {\r\n // Parse cells from each row\r\n const parseCells = (row) => row.trim().slice(1, -1).split('|').map(c => c.trim());\r\n const headerCells = parseCells(tableRows[0]);\r\n \r\n // Check if row 1 is a separator (---|---|---)\r\n const isSeparator = (row) => parseCells(row).every(c => /^[-:]+$/.test(c));\r\n const hasSeparator = tableRows.length >= 2 && isSeparator(tableRows[1]);\r\n const bodyStart = hasSeparator ? 2 : 1;\r\n \r\n // Parse alignment from separator\r\n const alignments = hasSeparator ? parseCells(tableRows[1]).map(c => {\r\n if (c.startsWith(':') && c.endsWith(':')) return 'center';\r\n if (c.endsWith(':')) return 'right';\r\n return 'left';\r\n }) : headerCells.map(() => 'left');\r\n \r\n const cellStyle = {\r\n padding: '6px 12px',\r\n borderBottom: '1px solid var(--border-subtle, rgba(52,58,64,0.08))',\r\n fontSize: '13px',\r\n lineHeight: 1.5,\r\n color: 'var(--text-strong, rgba(30,33,37,0.92))',\r\n };\r\n \r\n elements.push(\r\n <div key={`table-${i}`} style={{ overflowX: 'auto', margin: '8px 0' }}>\r\n <table style={{\r\n borderCollapse: 'collapse',\r\n width: '100%',\r\n border: '1px solid var(--border-subtle, rgba(52,58,64,0.08))',\r\n borderRadius: '6px',\r\n overflow: 'hidden',\r\n }}>\r\n {hasSeparator && (\r\n <thead>\r\n <tr style={{ background: 'var(--hover-warm-subtle, rgba(231,212,162,0.08))' }}>\r\n {headerCells.map((cell, ci) => (\r\n <th key={ci} style={{ ...cellStyle, fontWeight: 660, textAlign: alignments[ci] || 'left', whiteSpace: 'nowrap' }}>\r\n {parseInlineMarkdownWithContext(cell)}\r\n </th>\r\n ))}\r\n </tr>\r\n </thead>\r\n )}\r\n <tbody>\r\n {(hasSeparator ? tableRows.slice(bodyStart) : tableRows).map((row, ri) => (\r\n <tr key={ri} style={{ background: ri % 2 === 1 ? 'var(--hover-warm-subtle, rgba(231,212,162,0.04))' : 'transparent' }}>\r\n {parseCells(row).map((cell, ci) => (\r\n <td key={ci} style={{ ...cellStyle, textAlign: alignments[ci] || 'left' }}>\r\n {parseInlineMarkdownWithContext(cell)}\r\n </td>\r\n ))}\r\n </tr>\r\n ))}\r\n </tbody>\r\n </table>\r\n </div>\r\n );\r\n }\r\n continue;\r\n }\r\n \r\n // Regular paragraphs\r\n if (line.trim()) {\r\n const paragraph = [];\r\n while (i < lines.length && lines[i].trim() && !lines[i].match(/^(#|```|---|\\*\\*\\*|(\\s*)([-*+]|\\d+\\.)\\s)/) && !(lines[i].trim().startsWith('|') && lines[i].trim().endsWith('|'))) {\r\n paragraph.push(lines[i]);\r\n i++;\r\n }\r\n \r\n if (paragraph.length > 0) {\r\n elements.push(\r\n <p key={`p-${i}`} style={{ \r\n margin: '8px 0',\r\n lineHeight: 1.6,\r\n color: 'var(--text-strong, rgba(30,33,37,0.92))',\r\n }}>\r\n {parseInlineMarkdownWithContext(paragraph.join(' '))}\r\n </p>\r\n );\r\n }\r\n } else {\r\n i++;\r\n }\r\n }\r\n \r\n return elements;\r\n };\r\n\r\n const parseInlineMarkdown = (text) => {\r\n const elements = [];\r\n let remaining = text;\r\n let key = 0;\r\n\r\n while (remaining.length > 0) {\r\n // File paths (before other patterns to catch them first)\r\n if (onFilePathClick) {\r\n // Match file paths: containing /src/, /components/, /packages/ or ending in common extensions\r\n const filePathMatch = remaining.match(/^([^\\s`*\\[]+(?:\\/src\\/|\\/components\\/|\\/packages\\/)[^\\s`*\\[]*|[^\\s`*\\[]*\\.(ts|tsx|js|jsx|py|css|scss|sass|json|md|yaml|yml|html|xml|sh|sql|go|rs|php|java|c|cpp|h|hpp)(?:\\b|$))/);\r\n if (filePathMatch) {\r\n const filePath = filePathMatch[1];\r\n elements.push(\r\n <span\r\n key={`file-path-${key++}`}\r\n onClick={() => onFilePathClick(filePath)}\r\n style={{\r\n color: 'var(--rail-discovery, #5E88B0)',\r\n textDecoration: 'underline',\r\n textDecorationStyle: 'dotted',\r\n textUnderlineOffset: '2px',\r\n cursor: 'pointer',\r\n fontFamily: 'var(--font-mono, monospace)',\r\n fontSize: '13px',\r\n transition: 'all 0.15s ease',\r\n ':hover': {\r\n background: 'var(--hover-warm-subtle, rgba(231,212,162,0.08))',\r\n textDecoration: 'underline',\r\n textDecorationStyle: 'solid'\r\n }\r\n }}\r\n onMouseEnter={(e) => {\r\n e.target.style.background = 'var(--hover-warm-subtle, rgba(231,212,162,0.08))';\r\n e.target.style.textDecorationStyle = 'solid';\r\n }}\r\n onMouseLeave={(e) => {\r\n e.target.style.background = 'none';\r\n e.target.style.textDecorationStyle = 'dotted';\r\n }}\r\n >\r\n {filePath}\r\n </span>\r\n );\r\n remaining = remaining.slice(filePathMatch[0].length);\r\n continue;\r\n }\r\n }\r\n\r\n // Inline code\r\n const inlineCodeMatch = remaining.match(/^`([^`]+)`/);\r\n if (inlineCodeMatch) {\r\n elements.push(\r\n <code key={`inline-code-${key++}`} style={{\r\n background: 'var(--hover-warm-subtle, rgba(231,212,162,0.08))',\r\n border: '1px solid var(--border-subtle, rgba(52,58,64,0.08))',\r\n borderRadius: '3px',\r\n padding: '2px 4px',\r\n fontFamily: 'var(--font-mono, monospace)',\r\n fontSize: '12px',\r\n color: 'var(--text-strong, rgba(30,33,37,0.92))',\r\n }}>\r\n {inlineCodeMatch[1]}\r\n </code>\r\n );\r\n remaining = remaining.slice(inlineCodeMatch[0].length);\r\n continue;\r\n }\r\n\r\n // Bold\r\n const boldMatch = remaining.match(/^\\*\\*([^*]+)\\*\\*/);\r\n if (boldMatch) {\r\n elements.push(\r\n <strong key={`bold-${key++}`} style={{\r\n fontWeight: 720,\r\n color: 'var(--text-strong, rgba(30,33,37,0.92))',\r\n }}>\r\n {boldMatch[1]}\r\n </strong>\r\n );\r\n remaining = remaining.slice(boldMatch[0].length);\r\n continue;\r\n }\r\n\r\n // Italic\r\n const italicMatch = remaining.match(/^\\*([^*]+)\\*/);\r\n if (italicMatch) {\r\n elements.push(\r\n <em key={`italic-${key++}`} style={{\r\n fontStyle: 'italic',\r\n color: 'var(--text-strong, rgba(30,33,37,0.92))',\r\n }}>\r\n {italicMatch[1]}\r\n </em>\r\n );\r\n remaining = remaining.slice(italicMatch[0].length);\r\n continue;\r\n }\r\n\r\n // Links\r\n const linkMatch = remaining.match(/^\\[([^\\]]+)\\]\\(([^)]+)\\)/);\r\n if (linkMatch) {\r\n elements.push(\r\n <a key={`link-${key++}`} \r\n href={linkMatch[2]} \r\n target=\"_blank\" \r\n rel=\"noopener noreferrer\"\r\n style={{\r\n color: 'var(--rail-discovery, #5E88B0)',\r\n textDecoration: 'underline',\r\n textUnderlineOffset: '2px',\r\n }}>\r\n {linkMatch[1]}\r\n </a>\r\n );\r\n remaining = remaining.slice(linkMatch[0].length);\r\n continue;\r\n }\r\n\r\n // Regular text — consume up to the next special char, or consume the special char itself if no pattern matched\r\n const nextSpecialChar = remaining.search(/[`*\\[]/);\r\n if (nextSpecialChar === -1) {\r\n // No more special chars — add rest and break\r\n elements.push(remaining);\r\n break;\r\n } else if (nextSpecialChar === 0) {\r\n // Special char at position 0 but no pattern matched — consume it as text\r\n elements.push(remaining[0]);\r\n remaining = remaining.slice(1);\r\n } else {\r\n elements.push(remaining.slice(0, nextSpecialChar));\r\n remaining = remaining.slice(nextSpecialChar);\r\n }\r\n }\r\n\r\n return elements.length === 1 && typeof elements[0] === 'string' ? elements[0] : elements;\r\n };\r\n\r\n // Helper to pass context to parseInlineMarkdown calls within parseMarkdown\r\n const parseInlineMarkdownWithContext = (text) => parseInlineMarkdown(text);\r\n \r\n return <div>{parseMarkdown(content)}</div>;\r\n};\r\n\r\n/**\r\n * ChatMessage Component\r\n * Individual message in chat interface with markdown support for assistant messages\r\n */\r\nexport default function ChatMessage({ \r\n role, \r\n content, \r\n html, \r\n timestamp, \r\n toolBadges, \r\n isStreaming,\r\n onCodeBlockClick,\r\n onFilePathClick,\r\n}) {\r\n const isUser = role === \"user\";\r\n\r\n return (\r\n <div\r\n style={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n alignItems: isUser ? \"flex-end\" : \"flex-start\",\r\n marginBottom: \"16px\",\r\n maxWidth: \"100%\",\r\n }}\r\n >\r\n {/* Role label */}\r\n <div\r\n style={{\r\n fontSize: \"var(--text-sm, 11px)\",\r\n color: \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n marginBottom: \"6px\",\r\n fontWeight: 650,\r\n letterSpacing: \"0.02em\",\r\n }}\r\n >\r\n {isUser ? \"You\" : \"Chordia\"}\r\n {isStreaming && !isUser && (\r\n <span style={{ marginLeft: \"6px\", color: \"var(--rail-purple, #9B7AA8)\" }}>\r\n ●\r\n </span>\r\n )}\r\n </div>\r\n\r\n {/* Tool badges */}\r\n {toolBadges && toolBadges.length > 0 && (\r\n <div style={{ \r\n marginBottom: \"8px\", \r\n display: \"flex\", \r\n flexWrap: \"wrap\", \r\n gap: \"4px\",\r\n maxWidth: \"75%\" \r\n }}>\r\n {toolBadges.map((badge, index) => (\r\n <span \r\n key={badge.id || index}\r\n style={{\r\n display: \"inline-block\",\r\n fontSize: \"11px\",\r\n padding: \"2px 8px\",\r\n borderRadius: \"6px\",\r\n background: \"var(--paper-elevated, rgba(255,255,255,0.82))\",\r\n border: `1px solid ${\r\n badge.pending \r\n ? \"var(--rail-discovery, #5A8CC0)\" \r\n : badge.success !== false \r\n ? \"var(--state-present, #5CB85C)\" \r\n : \"var(--rail-signal-churn, #C98A5A)\"\r\n }`,\r\n color: badge.pending \r\n ? \"var(--rail-discovery, #5A8CC0)\" \r\n : badge.success !== false \r\n ? \"var(--state-present, #5CB85C)\" \r\n : \"var(--rail-signal-churn, #C98A5A)\",\r\n }}\r\n >\r\n <Wrench size={10} style={{ marginRight: 3, verticalAlign: \"middle\" }} />\r\n {badge.name}\r\n {badge.pending ? \"...\" : badge.success !== false ? \" ✓\" : \" ✗\"}\r\n </span>\r\n ))}\r\n </div>\r\n )}\r\n\r\n {/* Message bubble */}\r\n <div\r\n style={{\r\n maxWidth: \"75%\",\r\n padding: \"12px 16px\",\r\n borderRadius: \"var(--radius-lg, 12px)\",\r\n background: isUser\r\n ? \"var(--card-customer, rgba(94,136,176,0.08))\"\r\n : \"var(--paper-elevated, rgba(255,255,255,0.82))\",\r\n border: isUser\r\n ? \"1px solid var(--border-subtle, rgba(52,58,64,0.08))\"\r\n : \"1px solid var(--border, rgba(52,58,64,0.12))\",\r\n fontSize: \"var(--text-base, 14px)\",\r\n lineHeight: 1.6,\r\n color: \"var(--text-strong, rgba(30,33,37,0.92))\",\r\n wordBreak: \"break-word\",\r\n }}\r\n >\r\n {html ? (\r\n <div dangerouslySetInnerHTML={{ __html: html }} />\r\n ) : isUser ? (\r\n // User messages stay plain text\r\n <div style={{ whiteSpace: \"pre-wrap\" }}>{content}</div>\r\n ) : (\r\n // Assistant messages get markdown rendering\r\n <MarkdownRenderer content={content || \"\"} onCodeBlockClick={onCodeBlockClick} onFilePathClick={onFilePathClick} />\r\n )}\r\n </div>\r\n\r\n {/* Timestamp */}\r\n {timestamp && (\r\n <div\r\n style={{\r\n fontSize: \"var(--text-xs-plus, 10.5px)\",\r\n color: \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n marginTop: \"4px\",\r\n fontFamily: \"var(--font-mono, monospace)\",\r\n }}\r\n >\r\n {timestamp}\r\n </div>\r\n )}\r\n </div>\r\n );\r\n}","\"use client\";\r\n\r\nexport default function ThinkingIndicator({ \r\n phase = \"thinking\", \r\n toolSteps = [], \r\n label,\r\n elapsedMs,\r\n compact = false\r\n}) {\r\n const formatElapsedTime = (ms) => {\r\n if (!ms || ms < 1000) return null;\r\n const seconds = Math.floor(ms / 1000);\r\n if (seconds < 60) return `${seconds}s`;\r\n const minutes = Math.floor(seconds / 60);\r\n const remainingSeconds = seconds % 60;\r\n return remainingSeconds > 0 ? `${minutes}m ${remainingSeconds}s` : `${minutes}m`;\r\n };\r\n\r\n const getPhaseLabel = () => {\r\n if (label) return label;\r\n switch (phase) {\r\n case \"thinking\": return \"Thinking...\";\r\n case \"tool\": return null;\r\n case \"responding\": return \"Responding...\";\r\n default: return \"Thinking...\";\r\n }\r\n };\r\n\r\n const renderToolStep = (step, index) => {\r\n const getStatusDot = () => {\r\n const baseDotStyle = {\r\n width: compact ? '4px' : '6px',\r\n height: compact ? '4px' : '6px',\r\n borderRadius: '50%',\r\n display: 'inline-block',\r\n marginRight: compact ? '6px' : '8px'\r\n };\r\n\r\n switch (step.status) {\r\n case 'active':\r\n return (\r\n <span \r\n style={{\r\n ...baseDotStyle,\r\n backgroundColor: 'var(--rail-purple, #9B7AA8)',\r\n animation: 'pulse 1.2s ease-in-out infinite'\r\n }}\r\n />\r\n );\r\n case 'done':\r\n return (\r\n <span \r\n style={{\r\n ...baseDotStyle,\r\n backgroundColor: 'var(--text-xfaint, rgba(30,33,37,0.28))'\r\n }}\r\n />\r\n );\r\n case 'error':\r\n return (\r\n <span \r\n style={{\r\n ...baseDotStyle,\r\n backgroundColor: 'var(--rail-compliance, #C98A5A)'\r\n }}\r\n />\r\n );\r\n default:\r\n return (\r\n <span \r\n style={{\r\n ...baseDotStyle,\r\n backgroundColor: 'var(--text-xfaint, rgba(30,33,37,0.28))'\r\n }}\r\n />\r\n );\r\n }\r\n };\r\n\r\n const getStatusText = () => {\r\n switch (step.status) {\r\n case 'done':\r\n return (\r\n <span style={{ \r\n color: 'var(--text-faint, rgba(30,33,37,0.36))',\r\n fontSize: compact ? '9px' : 'var(--text-xs-plus, 10.5px)'\r\n }}>\r\n ✓\r\n </span>\r\n );\r\n case 'error':\r\n return (\r\n <span style={{ \r\n color: 'var(--rail-compliance, #C98A5A)',\r\n fontSize: compact ? '9px' : 'var(--text-xs-plus, 10.5px)'\r\n }}>\r\n failed\r\n </span>\r\n );\r\n default:\r\n return null;\r\n }\r\n };\r\n\r\n return (\r\n <div \r\n key={index}\r\n style={{\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'space-between',\r\n marginBottom: compact ? '2px' : '4px'\r\n }}\r\n >\r\n <div style={{ display: 'flex', alignItems: 'center' }}>\r\n {getStatusDot()}\r\n <span style={{\r\n fontFamily: 'var(--font-mono)',\r\n fontSize: compact ? '9px' : 'var(--text-xs-plus, 10.5px)',\r\n color: 'var(--text-muted)'\r\n }}>\r\n {step.name}\r\n </span>\r\n </div>\r\n {getStatusText()}\r\n </div>\r\n );\r\n };\r\n\r\n const renderShimmerBar = () => (\r\n <div style={{\r\n width: '100%',\r\n height: compact ? '2px' : '3px',\r\n backgroundColor: 'var(--border-subtle, rgba(52,58,64,0.08))',\r\n borderRadius: compact ? '2px' : '3px',\r\n overflow: 'hidden',\r\n position: 'relative'\r\n }}>\r\n <div style={{\r\n position: 'absolute',\r\n top: 0,\r\n left: 0,\r\n right: 0,\r\n bottom: 0,\r\n background: 'linear-gradient(90deg, transparent 0%, rgba(155,122,168,0.3) 50%, transparent 100%)',\r\n animation: 'shimmer 2s linear infinite'\r\n }} />\r\n </div>\r\n );\r\n\r\n const renderCursor = () => (\r\n <span style={{\r\n width: compact ? '4px' : '6px',\r\n height: compact ? '10px' : '14px',\r\n backgroundColor: 'var(--rail-purple, #9B7AA8)',\r\n borderRadius: '1px',\r\n display: 'inline-block',\r\n marginLeft: '2px',\r\n animation: 'cursorBlink 0.8s ease-in-out infinite'\r\n }} />\r\n );\r\n\r\n const phaseLabel = getPhaseLabel();\r\n const elapsedTime = formatElapsedTime(elapsedMs);\r\n\r\n return (\r\n <div style={{\r\n borderLeft: `${compact ? '3px' : '4px'} solid var(--rail-purple, #9B7AA8)`,\r\n backgroundColor: 'var(--card-assistant, rgba(155,122,168,0.06))',\r\n border: '1px solid var(--border-subtle, rgba(52,58,64,0.08))',\r\n borderRadius: compact ? '8px' : '10px',\r\n padding: compact ? '8px 10px 8px 12px' : '10px 14px 10px 18px'\r\n }}>\r\n <style>\r\n {`\r\n @keyframes shimmer {\r\n 0% { transform: translateX(-100%); }\r\n 100% { transform: translateX(200%); }\r\n }\r\n \r\n @keyframes pulse {\r\n 0%, 100% { opacity: 0.4; }\r\n 50% { opacity: 1.0; }\r\n }\r\n \r\n @keyframes cursorBlink {\r\n 0%, 100% { opacity: 0; }\r\n 50% { opacity: 1; }\r\n }\r\n `}\r\n </style>\r\n \r\n {/* Header */}\r\n {!compact && (\r\n <div style={{\r\n fontSize: 'var(--text-xs-plus, 10.5px)',\r\n fontWeight: 650,\r\n textTransform: 'uppercase',\r\n letterSpacing: 'var(--tracking-label, 0.16em)',\r\n color: 'var(--text-faint, rgba(30,33,37,0.36))',\r\n marginBottom: '8px'\r\n }}>\r\n AI ASSISTANT\r\n </div>\r\n )}\r\n\r\n {/* Content based on phase */}\r\n {phase === \"thinking\" && (\r\n <div>\r\n <div style={{\r\n color: 'var(--text-muted)',\r\n fontWeight: 400,\r\n fontSize: compact ? '11px' : '13px',\r\n marginBottom: compact ? '4px' : '8px',\r\n display: 'flex',\r\n alignItems: 'center',\r\n gap: '6px'\r\n }}>\r\n {phaseLabel}\r\n {elapsedTime && (\r\n <span style={{\r\n fontSize: compact ? '9px' : '10px',\r\n color: 'var(--text-faint, rgba(30,33,37,0.36))',\r\n fontFamily: 'var(--font-mono, monospace)',\r\n }}>\r\n {elapsedTime}\r\n </span>\r\n )}\r\n </div>\r\n {renderShimmerBar()}\r\n </div>\r\n )}\r\n\r\n {phase === \"tool\" && (\r\n <div>\r\n {phaseLabel && (\r\n <div style={{\r\n color: 'var(--text-muted)',\r\n fontWeight: 400,\r\n fontSize: compact ? '11px' : '13px',\r\n marginBottom: compact ? '4px' : '8px',\r\n display: 'flex',\r\n alignItems: 'center',\r\n gap: '6px'\r\n }}>\r\n {phaseLabel}\r\n {elapsedTime && (\r\n <span style={{\r\n fontSize: compact ? '9px' : '10px',\r\n color: 'var(--text-faint, rgba(30,33,37,0.36))',\r\n fontFamily: 'var(--font-mono, monospace)',\r\n }}>\r\n {elapsedTime}\r\n </span>\r\n )}\r\n </div>\r\n )}\r\n <div style={{ marginBottom: compact ? '4px' : '8px' }}>\r\n {toolSteps.map((step, index) => renderToolStep(step, index))}\r\n </div>\r\n {renderShimmerBar()}\r\n </div>\r\n )}\r\n\r\n {phase === \"responding\" && (\r\n <div style={{\r\n color: 'var(--text-muted)',\r\n fontWeight: 400,\r\n fontSize: compact ? '11px' : '13px',\r\n display: 'flex',\r\n alignItems: 'center',\r\n gap: '6px'\r\n }}>\r\n <div style={{ display: 'flex', alignItems: 'center' }}>\r\n {phaseLabel}\r\n {renderCursor()}\r\n </div>\r\n {elapsedTime && (\r\n <span style={{\r\n fontSize: compact ? '9px' : '10px',\r\n color: 'var(--text-faint, rgba(30,33,37,0.36))',\r\n fontFamily: 'var(--font-mono, monospace)',\r\n }}>\r\n {elapsedTime}\r\n </span>\r\n )}\r\n </div>\r\n )}\r\n </div>\r\n );\r\n}","\"use client\";\r\n\r\nimport React, { useState, useRef, useEffect } from \"react\";\r\nimport { Send } from \"lucide-react\";\r\nimport ChatMessage from \"./ChatMessage\";\r\nimport ThinkingIndicator from \"./ThinkingIndicator\";\r\n// TODO: replace with framework-agnostic toast\r\nconst toast = { error: (...args) => console.warn(\"toast.error:\", ...args) };\r\n\r\n/**\r\n * ChatInterface Component\r\n * Interactive chat interface with streaming SSE support, thinking phases, and tool visibility.\r\n */\r\nexport default function ChatInterface({\r\n initialMessages = [],\r\n onSendMessage,\r\n onStreamMessage, // NEW: streaming version of onSendMessage\r\n onMessagesChange, // NEW: callback when messages array changes\r\n onCodeBlockClick, // callback when \"Canvas\" button clicked on a code block: ({ code, language }) => void\r\n placeholder = \"Ask a question about this interaction...\",\r\n title = \"Chat with Chordia\",\r\n}) {\r\n const [messages, setMessages] = useState(initialMessages || []);\r\n const [inputValue, setInputValue] = useState(\"\");\r\n const [isProcessing, setIsProcessing] = useState(false);\r\n const [isSending, setIsSending] = useState(false);\r\n const [currentAssistantMessage, setCurrentAssistantMessage] = useState(null);\r\n const [thinkingPhase, setThinkingPhase] = useState(\"thinking\");\r\n const [thinkingStartTime, setThinkingStartTime] = useState(null);\r\n const [elapsedMs, setElapsedMs] = useState(0);\r\n const messagesEndRef = useRef(null);\r\n const inputRef = useRef(null);\r\n const streamAbortController = useRef(null);\r\n const currentAssistantRef = useRef(null);\r\n const lastChunkTimeRef = useRef(null);\r\n const [streamSilent, setStreamSilent] = useState(false);\r\n const [silenceSeconds, setSilenceSeconds] = useState(0);\r\n\r\n // Auto-scroll to bottom when messages change\r\n useEffect(() => {\r\n messagesEndRef.current?.scrollIntoView({ behavior: \"smooth\" });\r\n }, [messages, isProcessing]);\r\n\r\n // Auto-resize textarea\r\n useEffect(() => {\r\n if (inputRef.current) {\r\n inputRef.current.style.height = \"auto\";\r\n inputRef.current.style.height = `${Math.min(\r\n inputRef.current.scrollHeight,\r\n 120\r\n )}px`;\r\n }\r\n }, [inputValue]);\r\n\r\n // Update messages and notify parent\r\n useEffect(() => {\r\n if (onMessagesChange) {\r\n const allMessages = [...messages];\r\n if (currentAssistantMessage) {\r\n allMessages.push(currentAssistantMessage);\r\n }\r\n onMessagesChange(allMessages);\r\n }\r\n }, [messages, currentAssistantMessage, onMessagesChange]);\r\n\r\n // Elapsed time tracker + silence detector\r\n useEffect(() => {\r\n let interval;\r\n if (isProcessing && thinkingStartTime) {\r\n interval = setInterval(() => {\r\n setElapsedMs(Date.now() - thinkingStartTime);\r\n // Detect stream silence (no chunks for 3s+)\r\n if (lastChunkTimeRef.current) {\r\n const gap = (Date.now() - lastChunkTimeRef.current) / 1000;\r\n if (gap >= 3) {\r\n setStreamSilent(true);\r\n setSilenceSeconds(Math.floor(gap));\r\n } else {\r\n setStreamSilent(false);\r\n }\r\n }\r\n }, 500);\r\n }\r\n return () => interval && clearInterval(interval);\r\n }, [isProcessing, thinkingStartTime]);\r\n\r\n const resetProcessingState = () => {\r\n setIsProcessing(false);\r\n setIsSending(false);\r\n setCurrentAssistantMessage(null);\r\n currentAssistantRef.current = null;\r\n setThinkingPhase(\"thinking\");\r\n setStreamSilent(false);\r\n setSilenceSeconds(0);\r\n lastChunkTimeRef.current = null;\r\n setThinkingStartTime(null);\r\n setElapsedMs(0);\r\n if (streamAbortController.current) {\r\n streamAbortController.current.abort();\r\n streamAbortController.current = null;\r\n }\r\n };\r\n\r\n const parseSSELine = (line) => {\r\n if (line.startsWith(\"data: \")) {\r\n const data = line.slice(6);\r\n if (data === \"[DONE]\") {\r\n return { type: \"done\" };\r\n }\r\n try {\r\n const parsed = JSON.parse(data);\r\n return { type: \"data\", data: parsed };\r\n } catch (e) {\r\n return null;\r\n }\r\n }\r\n return null;\r\n };\r\n\r\n const handleStreamChunk = (chunk) => {\r\n if (!chunk.choices?.[0]?.delta) return;\r\n\r\n lastChunkTimeRef.current = Date.now();\r\n setStreamSilent(false);\r\n\r\n const delta = chunk.choices[0].delta;\r\n \r\n // Check for tool use/result indicators\r\n if (delta.tool_calls || delta.tool_results) {\r\n setThinkingPhase(\"tool\");\r\n return;\r\n }\r\n\r\n // If we get content, switch to responding phase\r\n if (delta.content !== undefined) {\r\n setThinkingPhase(\"responding\");\r\n \r\n // Initialize or update current assistant message\r\n setCurrentAssistantMessage(prev => {\r\n const baseMessage = prev || {\r\n id: Date.now().toString(),\r\n role: \"assistant\",\r\n content: \"\",\r\n timestamp: new Date().toLocaleTimeString(\"en-US\", {\r\n hour: \"2-digit\",\r\n minute: \"2-digit\",\r\n }),\r\n isStreaming: true,\r\n };\r\n \r\n const updated = {\r\n ...baseMessage,\r\n content: (baseMessage.content || \"\") + (delta.content || \"\"),\r\n };\r\n currentAssistantRef.current = updated;\r\n return updated;\r\n });\r\n }\r\n };\r\n\r\n const processStream = async (stream) => {\r\n const reader = stream.getReader();\r\n const decoder = new TextDecoder();\r\n let buffer = \"\";\r\n\r\n try {\r\n while (true) {\r\n const { done, value } = await reader.read();\r\n if (done) break;\r\n\r\n buffer += decoder.decode(value, { stream: true });\r\n const lines = buffer.split(\"\\n\");\r\n buffer = lines.pop() || \"\"; // Keep incomplete line in buffer\r\n\r\n for (const line of lines) {\r\n if (line.trim()) {\r\n const parsed = parseSSELine(line);\r\n if (parsed) {\r\n if (parsed.type === \"done\") {\r\n return; // Stream complete\r\n } else if (parsed.type === \"data\") {\r\n handleStreamChunk(parsed.data);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n } finally {\r\n reader.releaseLock();\r\n }\r\n };\r\n\r\n const handleSend = async () => {\r\n if (!inputValue.trim() || isSending) return;\r\n\r\n const userContent = inputValue.trim();\r\n const userMessage = {\r\n id: Date.now().toString(),\r\n role: \"user\",\r\n content: userContent,\r\n timestamp: new Date().toLocaleTimeString(\"en-US\", {\r\n hour: \"2-digit\",\r\n minute: \"2-digit\",\r\n }),\r\n };\r\n\r\n // Add user message and start processing\r\n const newMessages = [...messages, userMessage];\r\n setMessages(newMessages);\r\n setInputValue(\"\");\r\n setIsProcessing(true);\r\n setIsSending(true);\r\n setThinkingPhase(\"thinking\");\r\n setThinkingStartTime(Date.now());\r\n lastChunkTimeRef.current = Date.now();\r\n\r\n // Create abort controller for this stream\r\n streamAbortController.current = new AbortController();\r\n\r\n try {\r\n let result;\r\n \r\n // Use streaming version if provided, otherwise fall back to regular\r\n if (onStreamMessage) {\r\n result = await onStreamMessage(userContent, newMessages);\r\n } else if (onSendMessage) {\r\n result = await onSendMessage(userContent, newMessages);\r\n } else {\r\n // Fallback to dummy response\r\n setTimeout(() => {\r\n const assistantMessage = {\r\n id: (Date.now() + 1).toString(),\r\n role: \"assistant\",\r\n content: \"This is a demonstration response. In a real implementation, this would connect to your LLM backend.\",\r\n timestamp: new Date().toLocaleTimeString(\"en-US\", {\r\n hour: \"2-digit\",\r\n minute: \"2-digit\",\r\n }),\r\n };\r\n setMessages(prev => [...prev, assistantMessage]);\r\n resetProcessingState();\r\n }, 1000);\r\n return;\r\n }\r\n\r\n // Handle ReadableStream response\r\n if (result instanceof ReadableStream) {\r\n await processStream(result);\r\n } \r\n // Handle Response with SSE body\r\n else if (result instanceof Response && result.body) {\r\n await processStream(result.body);\r\n }\r\n // Handle Promise that resolves to a stream\r\n else if (result && typeof result.then === \"function\") {\r\n const resolved = await result;\r\n if (resolved instanceof ReadableStream) {\r\n await processStream(resolved);\r\n } else if (resolved instanceof Response && resolved.body) {\r\n await processStream(resolved.body);\r\n }\r\n }\r\n\r\n // Finalize the assistant message using ref (state is stale in this closure)\r\n if (currentAssistantRef.current) {\r\n setMessages(prev => [...prev, { \r\n ...currentAssistantRef.current, \r\n isStreaming: false \r\n }]);\r\n }\r\n\r\n } catch (error) {\r\n if (error.name !== \"AbortError\") {\r\n toast.error(\"Failed to send message\");\r\n console.error(\"Stream error:\", error);\r\n }\r\n } finally {\r\n resetProcessingState();\r\n }\r\n };\r\n\r\n const handleKeyDown = (e) => {\r\n if (e.key === \"Enter\" && !e.shiftKey) {\r\n e.preventDefault();\r\n handleSend();\r\n }\r\n };\r\n\r\n return (\r\n <div\r\n style={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n height: \"100%\",\r\n border: \"1px solid var(--border, rgba(52,58,64,0.12))\",\r\n borderRadius: \"var(--radius-lg, 12px)\",\r\n background: \"var(--paper-elevated, rgba(255,255,255,0.82))\",\r\n overflow: \"hidden\",\r\n }}\r\n >\r\n {/* Header — hidden when title is empty */}\r\n {title ? <div\r\n style={{\r\n padding: \"16px 20px\",\r\n borderBottom: \"1px solid var(--border-subtle, rgba(52,58,64,0.08))\",\r\n background: \"var(--paper-elevated, rgba(255,255,255,0.82))\",\r\n }}\r\n >\r\n <div\r\n style={{\r\n fontSize: \"var(--text-lg, 16px)\",\r\n fontWeight: 720,\r\n letterSpacing: \"-0.01em\",\r\n color: \"var(--text-strong, rgba(30,33,37,0.92))\",\r\n }}\r\n >\r\n {title}\r\n </div>\r\n <div\r\n style={{\r\n fontSize: \"var(--text-sm, 11px)\",\r\n color: \"var(--text-muted, rgba(30,33,37,0.56))\",\r\n marginTop: \"2px\",\r\n }}\r\n >\r\n Ask questions, get insights from analyzed interactions\r\n </div>\r\n </div> : null}\r\n\r\n {/* Messages area */}\r\n <div\r\n style={{\r\n flex: 1,\r\n minHeight: 0,\r\n overflowY: \"auto\",\r\n padding: \"20px\",\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n }}\r\n >\r\n {messages.length === 0 ? (\r\n <div\r\n style={{\r\n flex: 1,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n color: \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n fontSize: \"var(--text-md, 13px)\",\r\n textAlign: \"center\",\r\n padding: \"40px\",\r\n }}\r\n >\r\n No messages yet. Start a conversation by asking a question below.\r\n </div>\r\n ) : (\r\n <>\r\n {messages.map((message) => (\r\n <ChatMessage\r\n key={message.id}\r\n role={message.role}\r\n content={message.content}\r\n html={message.html}\r\n timestamp={message.timestamp}\r\n toolBadges={message.toolBadges}\r\n isStreaming={message.isStreaming}\r\n onCodeBlockClick={onCodeBlockClick}\r\n />\r\n ))}\r\n \r\n {/* Current streaming message */}\r\n {currentAssistantMessage && (\r\n <ChatMessage\r\n key={currentAssistantMessage.id}\r\n role={currentAssistantMessage.role}\r\n content={currentAssistantMessage.content}\r\n timestamp={currentAssistantMessage.timestamp}\r\n isStreaming={true}\r\n onCodeBlockClick={onCodeBlockClick}\r\n />\r\n )}\r\n \r\n {/* Thinking indicator — shows during initial thinking or stream silence */}\r\n {isProcessing && (!currentAssistantMessage || streamSilent) && (\r\n <div style={{ marginBottom: \"16px\" }}>\r\n <ThinkingIndicator \r\n phase={streamSilent ? \"tool\" : thinkingPhase}\r\n elapsedMs={elapsedMs}\r\n label={\r\n streamSilent && silenceSeconds >= 30\r\n ? \"Compacting conversation — trimming context to stay sharp...\"\r\n : streamSilent && silenceSeconds >= 10\r\n ? \"Running background tasks...\"\r\n : streamSilent\r\n ? \"Still working...\"\r\n : undefined\r\n }\r\n />\r\n </div>\r\n )}\r\n \r\n <div ref={messagesEndRef} />\r\n </>\r\n )}\r\n </div>\r\n\r\n {/* Input area */}\r\n <div\r\n style={{\r\n borderTop: \"1px solid var(--border-subtle, rgba(52,58,64,0.08))\",\r\n padding: \"16px 20px\",\r\n background: \"var(--paper-elevated, rgba(255,255,255,0.82))\",\r\n }}\r\n >\r\n <div\r\n style={{\r\n display: \"flex\",\r\n gap: \"12px\",\r\n alignItems: \"flex-end\",\r\n }}\r\n >\r\n <textarea\r\n ref={inputRef}\r\n value={inputValue}\r\n onChange={(e) => setInputValue(e.target.value)}\r\n onKeyDown={handleKeyDown}\r\n placeholder={placeholder}\r\n rows={1}\r\n disabled={isSending}\r\n style={{\r\n flex: 1,\r\n padding: \"10px 14px\",\r\n fontSize: \"var(--text-base, 14px)\",\r\n lineHeight: 1.5,\r\n color: \"var(--text-strong, rgba(30,33,37,0.92))\",\r\n background: \"rgba(255, 255, 255, 0.95)\",\r\n border: \"1px solid rgba(52, 58, 64, 0.18)\",\r\n borderRadius: \"var(--radius-md, 8px)\",\r\n resize: \"none\",\r\n outline: \"none\",\r\n transition: \"border-color 0.15s ease\",\r\n fontFamily: \"inherit\",\r\n minHeight: \"42px\",\r\n maxHeight: \"120px\",\r\n opacity: isSending ? 0.6 : 1,\r\n cursor: isSending ? \"not-allowed\" : \"text\",\r\n }}\r\n onFocus={(e) => {\r\n if (!isSending) {\r\n e.target.style.borderColor = \"rgba(94, 136, 176, 0.35)\";\r\n }\r\n }}\r\n onBlur={(e) => {\r\n e.target.style.borderColor = \"rgba(52, 58, 64, 0.18)\";\r\n }}\r\n />\r\n <button\r\n onClick={handleSend}\r\n disabled={!inputValue.trim() || isSending}\r\n style={{\r\n padding: \"10px 16px\",\r\n background:\r\n inputValue.trim() && !isSending\r\n ? \"var(--rail-discovery, #5E88B0)\"\r\n : \"var(--border-subtle, rgba(52,58,64,0.08))\",\r\n color:\r\n inputValue.trim() && !isSending\r\n ? \"rgba(255, 255, 255, 0.95)\"\r\n : \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n border: \"none\",\r\n borderRadius: \"var(--radius-md, 8px)\",\r\n cursor:\r\n inputValue.trim() && !isSending ? \"pointer\" : \"not-allowed\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"6px\",\r\n fontSize: \"var(--text-md, 13px)\",\r\n fontWeight: 650,\r\n transition: \"all 0.15s ease\",\r\n height: \"42px\",\r\n }}\r\n onMouseEnter={(e) => {\r\n if (inputValue.trim() && !isSending) {\r\n e.currentTarget.style.background = \"rgba(94, 136, 176, 1)\";\r\n }\r\n }}\r\n onMouseLeave={(e) => {\r\n if (inputValue.trim() && !isSending) {\r\n e.currentTarget.style.background = \"var(--rail-discovery, #5E88B0)\";\r\n }\r\n }}\r\n >\r\n {isSending ? (\r\n <>\r\n <style>\r\n {`\r\n @keyframes buttonSpin {\r\n from { transform: rotate(0deg); }\r\n to { transform: rotate(360deg); }\r\n }\r\n `}\r\n </style>\r\n <div\r\n style={{\r\n width: \"14px\",\r\n height: \"14px\",\r\n border: \"2px solid rgba(255, 255, 255, 0.3)\",\r\n borderTopColor: \"white\",\r\n borderRadius: \"50%\",\r\n animation: \"buttonSpin 0.6s linear infinite\",\r\n }}\r\n />\r\n Sending...\r\n </>\r\n ) : (\r\n <>\r\n <Send size={16} />\r\n Send\r\n </>\r\n )}\r\n </button>\r\n </div>\r\n <div\r\n style={{\r\n fontSize: \"var(--text-sm, 11px)\",\r\n color: \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n marginTop: \"8px\",\r\n }}\r\n >\r\n Press Enter to send, Shift+Enter for new line\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}","\"use client\";\r\n\r\nimport React, { useState } from \"react\";\r\nimport { MessageSquare, Search, Clock, Pin } from \"lucide-react\";\r\n\r\n/**\r\n * ChatHistoryPanel Component\r\n * Panel showing chat thread history with search functionality.\r\n * \r\n * Props:\r\n * threads - Array of thread objects: { id, title, created_at, updated_at, message_count, last_message_preview, pinned, archived, tags }\r\n * activeThreadId - Currently selected thread id\r\n * onSelectThread - (threadId) => void\r\n * onNewChat - () => void\r\n * loading - boolean\r\n */\r\nexport default function ChatHistoryPanel({\r\n threads = [],\r\n activeThreadId,\r\n onSelectThread,\r\n onNewChat,\r\n loading = false,\r\n}) {\r\n const [searchQuery, setSearchQuery] = useState(\"\");\r\n\r\n const filteredThreads = threads.filter((thread) => {\r\n if (!searchQuery) return true;\r\n const q = searchQuery.toLowerCase();\r\n return (\r\n (thread.title || \"\").toLowerCase().includes(q) ||\r\n (thread.last_message_preview || \"\").toLowerCase().includes(q)\r\n );\r\n });\r\n\r\n // Sort: pinned first, then by updated_at descending\r\n const sortedThreads = [...filteredThreads].sort((a, b) => {\r\n if (a.pinned && !b.pinned) return -1;\r\n if (!a.pinned && b.pinned) return 1;\r\n const aTime = new Date(a.updated_at || a.created_at || 0).getTime();\r\n const bTime = new Date(b.updated_at || b.created_at || 0).getTime();\r\n return bTime - aTime;\r\n });\r\n\r\n const formatTime = (dateStr) => {\r\n if (!dateStr) return \"\";\r\n const d = new Date(dateStr);\r\n const now = new Date();\r\n const diffMs = now.getTime() - d.getTime();\r\n const diffDays = Math.floor(diffMs / 86400000);\r\n if (diffDays === 0) {\r\n return d.toLocaleTimeString(\"en-US\", { hour: \"2-digit\", minute: \"2-digit\" });\r\n } else if (diffDays === 1) {\r\n return \"Yesterday\";\r\n } else if (diffDays < 7) {\r\n return d.toLocaleDateString(\"en-US\", { weekday: \"short\" });\r\n } else {\r\n return d.toLocaleDateString(\"en-US\", { month: \"short\", day: \"numeric\" });\r\n }\r\n };\r\n\r\n return (\r\n <div\r\n style={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n height: \"100%\",\r\n background: \"var(--paper, rgba(255,255,255,0.95))\",\r\n borderRight: \"1px solid var(--border, rgba(52,58,64,0.12))\",\r\n overflow: \"hidden\",\r\n }}\r\n >\r\n {/* Header */}\r\n <div\r\n style={{\r\n padding: \"12px 14px\",\r\n borderBottom: \"1px solid var(--border-subtle, rgba(52,58,64,0.08))\",\r\n flexShrink: 0,\r\n }}\r\n >\r\n <div\r\n style={{\r\n display: \"flex\",\r\n justifyContent: \"space-between\",\r\n alignItems: \"center\",\r\n marginBottom: \"10px\",\r\n }}\r\n >\r\n <div\r\n style={{\r\n fontSize: \"13px\",\r\n fontWeight: 650,\r\n color: \"var(--text-ink, rgba(30,33,37,0.92))\",\r\n }}\r\n >\r\n Threads\r\n </div>\r\n {onNewChat && (\r\n <button\r\n onClick={onNewChat}\r\n style={{\r\n padding: \"4px 10px\",\r\n fontSize: \"11px\",\r\n fontWeight: 600,\r\n color: \"var(--rail-discovery, #5E88B0)\",\r\n background: \"rgba(94, 136, 176, 0.08)\",\r\n border: \"1px solid var(--border-subtle, rgba(52,58,64,0.08))\",\r\n borderRadius: \"6px\",\r\n cursor: \"pointer\",\r\n transition: \"all 0.15s ease\",\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background = \"rgba(94, 136, 176, 0.14)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = \"rgba(94, 136, 176, 0.08)\";\r\n }}\r\n >\r\n + New\r\n </button>\r\n )}\r\n </div>\r\n\r\n {/* Search */}\r\n <div style={{ position: \"relative\" }}>\r\n <Search\r\n size={13}\r\n style={{\r\n position: \"absolute\",\r\n left: \"10px\",\r\n top: \"50%\",\r\n transform: \"translateY(-50%)\",\r\n color: \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n pointerEvents: \"none\",\r\n }}\r\n />\r\n <input\r\n type=\"text\"\r\n value={searchQuery}\r\n onChange={(e) => setSearchQuery(e.target.value)}\r\n placeholder=\"Search threads...\"\r\n style={{\r\n width: \"100%\",\r\n padding: \"7px 10px 7px 32px\",\r\n fontSize: \"12px\",\r\n color: \"var(--text-ink, rgba(30,33,37,0.92))\",\r\n background: \"var(--paper-elevated, rgba(255,255,255,0.82))\",\r\n border: \"1px solid var(--border, rgba(52,58,64,0.12))\",\r\n borderRadius: \"6px\",\r\n outline: \"none\",\r\n transition: \"border-color 0.15s ease\",\r\n boxSizing: \"border-box\",\r\n }}\r\n onFocus={(e) => {\r\n e.target.style.borderColor = \"rgba(94, 136, 176, 0.35)\";\r\n }}\r\n onBlur={(e) => {\r\n e.target.style.borderColor = \"rgba(52, 58, 64, 0.12)\";\r\n }}\r\n />\r\n </div>\r\n </div>\r\n\r\n {/* Thread List */}\r\n <div style={{ flex: 1, overflowY: \"auto\", padding: \"4px 6px\" }}>\r\n {loading ? (\r\n <div\r\n style={{\r\n padding: \"30px 16px\",\r\n textAlign: \"center\",\r\n color: \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n fontSize: \"12px\",\r\n }}\r\n >\r\n Loading threads...\r\n </div>\r\n ) : sortedThreads.length === 0 ? (\r\n <div\r\n style={{\r\n padding: \"30px 16px\",\r\n textAlign: \"center\",\r\n color: \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n fontSize: \"12px\",\r\n }}\r\n >\r\n {searchQuery ? \"No threads found\" : \"No threads yet\"}\r\n </div>\r\n ) : (\r\n sortedThreads.map((thread) => {\r\n const isActive = thread.id === activeThreadId;\r\n return (\r\n <div\r\n key={thread.id}\r\n onClick={() => onSelectThread?.(thread.id)}\r\n style={{\r\n padding: \"10px 10px\",\r\n marginBottom: \"2px\",\r\n borderRadius: \"6px\",\r\n background: isActive\r\n ? \"rgba(94, 136, 176, 0.10)\"\r\n : \"transparent\",\r\n border: isActive\r\n ? \"1px solid rgba(94, 136, 176, 0.15)\"\r\n : \"1px solid transparent\",\r\n cursor: \"pointer\",\r\n transition: \"all 0.12s ease\",\r\n }}\r\n onMouseEnter={(e) => {\r\n if (!isActive) e.currentTarget.style.background = \"rgba(0,0,0,0.03)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n if (!isActive) e.currentTarget.style.background = \"transparent\";\r\n }}\r\n >\r\n {/* Title row */}\r\n <div style={{ display: \"flex\", alignItems: \"center\", gap: \"6px\", marginBottom: \"4px\" }}>\r\n <MessageSquare\r\n size={12}\r\n style={{\r\n color: isActive ? \"var(--rail-discovery, #5E88B0)\" : \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n flexShrink: 0,\r\n }}\r\n />\r\n <div\r\n style={{\r\n flex: 1,\r\n fontSize: \"12px\",\r\n fontWeight: isActive ? 650 : 550,\r\n color: isActive\r\n ? \"var(--text-ink, rgba(30,33,37,0.92))\"\r\n : \"var(--text-base, rgba(30,33,37,0.78))\",\r\n overflow: \"hidden\",\r\n textOverflow: \"ellipsis\",\r\n whiteSpace: \"nowrap\",\r\n }}\r\n >\r\n {thread.title || \"Untitled thread\"}\r\n </div>\r\n {thread.pinned && (\r\n <Pin size={10} style={{ color: \"var(--rail-discovery, #5E88B0)\", flexShrink: 0 }} />\r\n )}\r\n </div>\r\n\r\n {/* Preview */}\r\n {thread.last_message_preview && (\r\n <div\r\n style={{\r\n fontSize: \"11px\",\r\n color: \"var(--text-muted, rgba(30,33,37,0.56))\",\r\n overflow: \"hidden\",\r\n textOverflow: \"ellipsis\",\r\n whiteSpace: \"nowrap\",\r\n marginLeft: \"18px\",\r\n marginBottom: \"4px\",\r\n }}\r\n >\r\n {thread.last_message_preview}\r\n </div>\r\n )}\r\n\r\n {/* Meta */}\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"6px\",\r\n marginLeft: \"18px\",\r\n fontSize: \"10px\",\r\n color: \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n }}\r\n >\r\n <Clock size={9} />\r\n <span>{formatTime(thread.updated_at || thread.created_at)}</span>\r\n {thread.message_count != null && (\r\n <>\r\n <span>·</span>\r\n <span>{thread.message_count} msg{thread.message_count !== 1 ? \"s\" : \"\"}</span>\r\n </>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n })\r\n )}\r\n </div>\r\n </div>\r\n );\r\n}\r\n","\"use client\";\r\n\r\nimport React, { useState, useEffect, useRef } from \"react\";\r\nimport { Send, Paperclip, AtSign, Hash, Clock } from \"lucide-react\";\r\n// TODO: replace with framework-agnostic toast\r\nconst toast = { error: (...args) => console.warn(\"toast.error:\", ...args) };\r\n// TODO: replace with framework-agnostic context\r\nconst useUserContext = () => ({ userData: { name: \"User\", email: \"\" } });\r\n\r\n/**\r\n * MessageThread Component\r\n * Threaded messaging interface for team collaboration around sessions.\r\n * Supports mentions, condition references, and timestamp links.\r\n * Uses dummy data for demonstration purposes.\r\n */\r\nexport default function MessageThread({\r\n sessionTitle,\r\n messages: initialMessages,\r\n onSendMessage,\r\n currentUser,\r\n}) {\r\n const [messageInput, setMessageInput] = useState(\"\");\r\n const [isFocused, setIsFocused] = useState(false);\r\n const [messages, setMessages] = useState(initialMessages || []);\r\n const [isLoading, setIsLoading] = useState(false);\r\n const [isSending, setIsSending] = useState(false);\r\n const { userData } = useUserContext();\r\n const messagesEndRef = useRef(null);\r\n\r\n // Get current user from context if not provided\r\n const displayCurrentUser = currentUser || {\r\n name: userData?.name || \"You\",\r\n initials: userData?.name\r\n ?.split(\" \")\r\n .map((n) => n[0])\r\n .join(\"\")\r\n .toUpperCase() || \"YO\",\r\n color: \"#6B7C93\",\r\n };\r\n\r\n // Use initialMessages if provided, otherwise use empty array (no API fetching)\r\n useEffect(() => {\r\n if (initialMessages) {\r\n setMessages(initialMessages);\r\n } else {\r\n setMessages([]);\r\n }\r\n }, [initialMessages]);\r\n\r\n // Scroll to bottom when new messages arrive\r\n useEffect(() => {\r\n if (messagesEndRef.current) {\r\n messagesEndRef.current.scrollIntoView({ behavior: \"smooth\" });\r\n }\r\n }, [messages]);\r\n\r\n const handleSend = async () => {\r\n if (!messageInput.trim()) return;\r\n\r\n const content = messageInput.trim();\r\n setMessageInput(\"\");\r\n setIsSending(true);\r\n\r\n // Create optimistic message\r\n const optimisticMessage = {\r\n id: `temp-${Date.now()}`,\r\n author: {\r\n name: displayCurrentUser.name,\r\n role: userData?.role || \"\",\r\n initials: displayCurrentUser.initials,\r\n color: displayCurrentUser.color,\r\n },\r\n content: content,\r\n timestamp: \"Just now\",\r\n type: \"comment\",\r\n isOptimistic: true,\r\n };\r\n\r\n // Optimistically add message\r\n setMessages((prev) => [...prev, optimisticMessage]);\r\n\r\n // If onSendMessage callback is provided, use it\r\n if (onSendMessage) {\r\n try {\r\n await onSendMessage(content);\r\n // Remove optimistic flag after callback succeeds\r\n setMessages((prev) =>\r\n prev.map((msg) =>\r\n msg.id === optimisticMessage.id\r\n ? { ...msg, isOptimistic: false }\r\n : msg\r\n )\r\n );\r\n } catch (error) {\r\n // Remove optimistic message on error\r\n setMessages((prev) => prev.filter((msg) => msg.id !== optimisticMessage.id));\r\n toast.error(\"Failed to send message\");\r\n } finally {\r\n setIsSending(false);\r\n }\r\n return;\r\n }\r\n\r\n // No API - just confirm the optimistic message\r\n setTimeout(() => {\r\n setMessages((prev) =>\r\n prev.map((msg) =>\r\n msg.id === optimisticMessage.id\r\n ? { ...msg, isOptimistic: false }\r\n : msg\r\n )\r\n );\r\n setIsSending(false);\r\n }, 500);\r\n };\r\n\r\n const handleKeyPress = (e) => {\r\n if (e.key === \"Enter\" && !e.shiftKey) {\r\n e.preventDefault();\r\n handleSend();\r\n }\r\n };\r\n\r\n return (\r\n <div\r\n style={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n height: \"100%\",\r\n background: \"var(--paper-elevated, rgba(255,255,255,0.82))\",\r\n border: \"1px solid var(--border, rgba(52,58,64,0.12))\",\r\n borderRadius: \"var(--radius-lg, 12px)\",\r\n overflow: \"hidden\",\r\n }}\r\n >\r\n {/* Header */}\r\n {sessionTitle && (\r\n <div\r\n style={{\r\n padding: \"14px 16px\",\r\n borderBottom: \"1px solid var(--border, rgba(52,58,64,0.12))\",\r\n background: \"var(--paper-elevated, rgba(255,255,255,0.82))\",\r\n }}\r\n >\r\n <div\r\n style={{\r\n fontSize: \"var(--text-md, 13px)\",\r\n fontWeight: 680,\r\n color: \"var(--text-strong, rgba(30,33,37,0.92))\",\r\n marginBottom: \"3px\",\r\n }}\r\n >\r\n Session Discussion\r\n </div>\r\n {sessionTitle && (\r\n <div\r\n style={{\r\n fontSize: \"var(--text-sm, 11px)\",\r\n color: \"var(--text-muted, rgba(30,33,37,0.56))\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"8px\",\r\n }}\r\n >\r\n <span>{sessionTitle}</span>\r\n </div>\r\n )}\r\n </div>\r\n )}\r\n\r\n {/* Messages */}\r\n <div\r\n style={{\r\n flex: 1,\r\n overflowY: \"auto\",\r\n padding: \"16px\",\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n gap: \"16px\",\r\n }}\r\n >\r\n {isLoading ? (\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n padding: \"40px\",\r\n color: \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n }}\r\n >\r\n Loading messages...\r\n </div>\r\n ) : messages.length === 0 ? (\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n padding: \"40px\",\r\n color: \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n }}\r\n >\r\n No messages yet. Start the conversation!\r\n </div>\r\n ) : (\r\n messages.map((message) => (\r\n <div\r\n key={message.id}\r\n style={{\r\n display: \"flex\",\r\n gap: \"12px\",\r\n opacity: message.type === \"system\" ? 0.75 : 1,\r\n }}\r\n >\r\n {/* Avatar */}\r\n {message.type !== \"system\" && (\r\n <div\r\n style={{\r\n width: \"32px\",\r\n height: \"32px\",\r\n borderRadius: \"8px\",\r\n background: message.author.color,\r\n color: \"white\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n fontSize: \"11px\",\r\n fontWeight: 650,\r\n flexShrink: 0,\r\n opacity: 0.9,\r\n }}\r\n >\r\n {message.author.initials}\r\n </div>\r\n )}\r\n {message.type === \"system\" && (\r\n <div\r\n style={{\r\n width: \"32px\",\r\n height: \"32px\",\r\n borderRadius: \"8px\",\r\n background: \"rgba(30, 33, 37, 0.08)\",\r\n color: \"rgba(30, 33, 37, 0.52)\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n fontSize: \"11px\",\r\n fontWeight: 650,\r\n flexShrink: 0,\r\n }}\r\n >\r\n <Clock size={14} />\r\n </div>\r\n )}\r\n\r\n {/* Message content */}\r\n <div style={{ flex: 1, minWidth: 0 }}>\r\n {/* Author and timestamp */}\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"baseline\",\r\n gap: \"8px\",\r\n marginBottom: \"4px\",\r\n }}\r\n >\r\n <span\r\n style={{\r\n fontSize: \"var(--text-sm, 11px)\",\r\n fontWeight: 650,\r\n color: \"var(--text-base, rgba(30,33,37,0.78))\",\r\n }}\r\n >\r\n {message.author.name}\r\n </span>\r\n <span\r\n style={{\r\n fontSize: \"var(--text-sm, 11px)\",\r\n color: \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n fontFamily: \"var(--font-mono, monospace)\",\r\n }}\r\n >\r\n {message.timestamp}\r\n </span>\r\n {message.author.role && (\r\n <span\r\n style={{\r\n fontSize: \"var(--text-xs, 10px)\",\r\n color: \"var(--text-muted, rgba(30,33,37,0.56))\",\r\n background: \"rgba(30, 33, 37, 0.06)\",\r\n padding: \"2px 6px\",\r\n borderRadius: \"4px\",\r\n textTransform: \"uppercase\",\r\n letterSpacing: \"0.04em\",\r\n fontWeight: 600,\r\n }}\r\n >\r\n {message.author.role}\r\n </span>\r\n )}\r\n {message.isEdited && (\r\n <span\r\n style={{\r\n fontSize: \"var(--text-xs, 10px)\",\r\n color: \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n fontStyle: \"italic\",\r\n }}\r\n >\r\n (edited)\r\n </span>\r\n )}\r\n </div>\r\n\r\n {/* Message text */}\r\n <div\r\n style={{\r\n fontSize: \"var(--text-md, 13px)\",\r\n color: \"var(--text-base, rgba(30,33,37,0.78))\",\r\n lineHeight: 1.5,\r\n marginBottom: message.references ? \"8px\" : 0,\r\n }}\r\n >\r\n {message.content}\r\n </div>\r\n\r\n {/* References */}\r\n {message.references && message.references.length > 0 && (\r\n <div\r\n style={{\r\n display: \"flex\",\r\n flexWrap: \"wrap\",\r\n gap: \"6px\",\r\n marginTop: \"8px\",\r\n }}\r\n >\r\n {message.references.map((ref, idx) => (\r\n <button\r\n key={idx}\r\n type=\"button\"\r\n style={{\r\n fontSize: \"11px\",\r\n padding: \"4px 8px\",\r\n borderRadius: \"6px\",\r\n border: \"1px solid rgba(52, 58, 64, 0.16)\",\r\n background: \"rgba(255, 255, 255, 0.7)\",\r\n color:\r\n ref.type === \"condition\"\r\n ? \"rgba(94, 136, 176, 0.85)\"\r\n : ref.type === \"observation\"\r\n ? \"rgba(107, 123, 147, 0.85)\"\r\n : ref.type === \"timestamp\"\r\n ? \"rgba(184, 156, 106, 0.85)\"\r\n : \"rgba(30, 33, 37, 0.65)\",\r\n cursor: \"pointer\",\r\n display: \"inline-flex\",\r\n alignItems: \"center\",\r\n gap: \"4px\",\r\n transition: \"all 0.15s ease\",\r\n fontWeight: 550,\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background =\r\n \"rgba(255, 255, 255, 0.95)\";\r\n e.currentTarget.style.borderColor =\r\n \"rgba(52, 58, 64, 0.24)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background =\r\n \"rgba(255, 255, 255, 0.7)\";\r\n e.currentTarget.style.borderColor =\r\n \"rgba(52, 58, 64, 0.16)\";\r\n }}\r\n >\r\n {ref.type === \"timestamp\" && <Clock size={12} />}\r\n {(ref.type === \"condition\" ||\r\n ref.type === \"observation\") && <Hash size={12} />}\r\n {ref.label}\r\n </button>\r\n ))}\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n ))\r\n )}\r\n <div ref={messagesEndRef} />\r\n </div>\r\n\r\n {/* Input area */}\r\n <div\r\n style={{\r\n padding: \"12px\",\r\n borderTop: \"1px solid var(--border, rgba(52,58,64,0.12))\",\r\n background: \"var(--paper-elevated, rgba(255,255,255,0.82))\",\r\n }}\r\n >\r\n <div\r\n style={{\r\n display: \"flex\",\r\n gap: \"8px\",\r\n alignItems: \"flex-end\",\r\n }}\r\n >\r\n {/* Current user avatar */}\r\n <div\r\n style={{\r\n width: \"32px\",\r\n height: \"32px\",\r\n borderRadius: \"var(--radius-md, 8px)\",\r\n background: displayCurrentUser.color,\r\n color: \"white\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n fontSize: \"var(--text-sm, 11px)\",\r\n fontWeight: 650,\r\n flexShrink: 0,\r\n opacity: 0.9,\r\n }}\r\n >\r\n {displayCurrentUser.initials}\r\n </div>\r\n\r\n {/* Input field */}\r\n <div\r\n style={{\r\n flex: 1,\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n gap: \"8px\",\r\n }}\r\n >\r\n <textarea\r\n value={messageInput}\r\n onChange={(e) => setMessageInput(e.target.value)}\r\n onKeyDown={handleKeyPress}\r\n onFocus={() => setIsFocused(true)}\r\n onBlur={() => setIsFocused(false)}\r\n placeholder=\"Add a comment...\"\r\n style={{\r\n width: \"100%\",\r\n minHeight: \"38px\",\r\n maxHeight: \"120px\",\r\n padding: \"8px 12px\",\r\n fontSize: \"var(--text-md, 13px)\",\r\n color: \"var(--text-base, rgba(30,33,37,0.78))\",\r\n background: \"white\",\r\n border: `1px solid ${\r\n isFocused\r\n ? \"rgba(94, 136, 176, 0.35)\"\r\n : \"rgba(52, 58, 64, 0.16)\"\r\n }`,\r\n borderRadius: \"var(--radius-md, 8px)\",\r\n resize: \"vertical\",\r\n outline: \"none\",\r\n transition: \"border-color 0.15s ease\",\r\n fontFamily: \"inherit\",\r\n lineHeight: 1.5,\r\n }}\r\n />\r\n\r\n {/* Toolbar */}\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"space-between\",\r\n }}\r\n >\r\n <div style={{ display: \"flex\", gap: \"4px\" }}>\r\n <button\r\n type=\"button\"\r\n style={{\r\n padding: \"6px\",\r\n background: \"transparent\",\r\n border: \"none\",\r\n borderRadius: \"6px\",\r\n color: \"rgba(30, 33, 37, 0.52)\",\r\n cursor: \"pointer\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n transition: \"all 0.15s ease\",\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background =\r\n \"rgba(30, 33, 37, 0.06)\";\r\n e.currentTarget.style.color = \"rgba(30, 33, 37, 0.75)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = \"transparent\";\r\n e.currentTarget.style.color = \"rgba(30, 33, 37, 0.52)\";\r\n }}\r\n title=\"Mention user\"\r\n >\r\n <AtSign size={16} />\r\n </button>\r\n <button\r\n type=\"button\"\r\n style={{\r\n padding: \"6px\",\r\n background: \"transparent\",\r\n border: \"none\",\r\n borderRadius: \"6px\",\r\n color: \"rgba(30, 33, 37, 0.52)\",\r\n cursor: \"pointer\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n transition: \"all 0.15s ease\",\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background =\r\n \"rgba(30, 33, 37, 0.06)\";\r\n e.currentTarget.style.color = \"rgba(30, 33, 37, 0.75)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = \"transparent\";\r\n e.currentTarget.style.color = \"rgba(30, 33, 37, 0.52)\";\r\n }}\r\n title=\"Reference condition\"\r\n >\r\n <Hash size={16} />\r\n </button>\r\n <button\r\n type=\"button\"\r\n style={{\r\n padding: \"6px\",\r\n background: \"transparent\",\r\n border: \"none\",\r\n borderRadius: \"6px\",\r\n color: \"rgba(30, 33, 37, 0.52)\",\r\n cursor: \"pointer\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n transition: \"all 0.15s ease\",\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background =\r\n \"rgba(30, 33, 37, 0.06)\";\r\n e.currentTarget.style.color = \"rgba(30, 33, 37, 0.75)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = \"transparent\";\r\n e.currentTarget.style.color = \"rgba(30, 33, 37, 0.52)\";\r\n }}\r\n title=\"Attach file\"\r\n >\r\n <Paperclip size={16} />\r\n </button>\r\n </div>\r\n <button\r\n type=\"button\"\r\n onClick={handleSend}\r\n disabled={!messageInput.trim() || isSending}\r\n style={{\r\n padding: \"6px 12px\",\r\n background:\r\n messageInput.trim() && !isSending\r\n ? \"rgba(94, 136, 176, 0.85)\"\r\n : \"var(--border-subtle, rgba(52,58,64,0.08))\",\r\n border: \"none\",\r\n borderRadius: \"6px\",\r\n color:\r\n messageInput.trim() && !isSending\r\n ? \"white\"\r\n : \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n fontSize: \"var(--text-sm, 11px)\",\r\n fontWeight: 600,\r\n cursor:\r\n messageInput.trim() && !isSending\r\n ? \"pointer\"\r\n : \"not-allowed\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"6px\",\r\n transition: \"all 0.15s ease\",\r\n }}\r\n onMouseEnter={(e) => {\r\n if (messageInput.trim() && !isSending) {\r\n e.currentTarget.style.background = \"rgba(94, 136, 176, 1)\";\r\n }\r\n }}\r\n onMouseLeave={(e) => {\r\n if (messageInput.trim() && !isSending) {\r\n e.currentTarget.style.background =\r\n \"rgba(94, 136, 176, 0.85)\";\r\n }\r\n }}\r\n >\r\n {isSending ? (\r\n <>\r\n <style>\r\n {`\r\n @keyframes messageSpin {\r\n from { transform: rotate(0deg); }\r\n to { transform: rotate(360deg); }\r\n }\r\n `}\r\n </style>\r\n <div\r\n style={{\r\n width: \"14px\",\r\n height: \"14px\",\r\n border: \"2px solid rgba(255, 255, 255, 0.3)\",\r\n borderTopColor: \"white\",\r\n borderRadius: \"50%\",\r\n animation: \"messageSpin 0.6s linear infinite\",\r\n }}\r\n />\r\n Sending...\r\n </>\r\n ) : (\r\n <>\r\n <Send size={14} />\r\n Send\r\n </>\r\n )}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n <div\r\n style={{\r\n marginTop: \"8px\",\r\n fontSize: \"var(--text-sm, 11px)\",\r\n color: \"var(--text-faint, rgba(30,33,37,0.36))\",\r\n lineHeight: 1.4,\r\n }}\r\n >\r\n <strong>Tip:</strong> Use{\" \"}\r\n <code\r\n style={{\r\n background: \"rgba(30, 33, 37, 0.06)\",\r\n padding: \"2px 4px\",\r\n borderRadius: \"3px\",\r\n fontFamily: \"var(--font-mono, monospace)\",\r\n fontSize: \"var(--text-xs, 10px)\",\r\n }}\r\n >\r\n @\r\n </code>{\" \"}\r\n to mention teammates,{\" \"}\r\n <code\r\n style={{\r\n background: \"rgba(30, 33, 37, 0.06)\",\r\n padding: \"2px 4px\",\r\n borderRadius: \"3px\",\r\n fontFamily: \"var(--font-mono, monospace)\",\r\n fontSize: \"var(--text-xs, 10px)\",\r\n }}\r\n >\r\n #\r\n </code>{\" \"}\r\n to reference conditions\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n\r\n","\"use client\";\r\n\r\nimport React, { useState } from \"react\";\r\nimport {\r\n Home, FolderClosed, Users, Settings, ChevronDown, ChevronRight,\r\n LayoutDashboard, Clock3, Activity, Lightbulb, Bell, Plug, BarChart3,\r\n FileText, Headphones, Shield, Sliders, Workflow, SquareDot,\r\n PanelLeftClose, PanelLeft,\r\n} from \"lucide-react\";\r\n\r\n/**\r\n * Sidebar — collapsible navigation sidebar.\r\n *\r\n * Slot-based: pass menuItems as data, component handles rendering + expand/collapse.\r\n * No framework dependencies (no router, no auth, no API calls).\r\n *\r\n * Props:\r\n * - menuItems Array<MenuItem> Navigation items (see shape below)\r\n * - activeId string Currently active item id\r\n * - onNavigate function(href) Navigation callback\r\n * - collapsed boolean External collapsed state (controlled)\r\n * - onToggleCollapse function Toggle callback\r\n * - header ReactNode Optional header slot (logo, brand)\r\n * - footer ReactNode Optional footer slot (user, settings)\r\n * - width number Expanded width (default 240)\r\n * - collapsedWidth number Collapsed width (default 56)\r\n *\r\n * MenuItem shape:\r\n * - id string\r\n * - label string\r\n * - icon string (key from ICON_MAP) or ReactNode\r\n * - href string\r\n * - active boolean (override)\r\n * - children Array<MenuItem> (nested group)\r\n * - section string (section label above this item)\r\n */\r\n\r\nconst ICON_MAP = {\r\n home: Home,\r\n projects: FolderClosed,\r\n folder: FolderClosed,\r\n organization: Users,\r\n users: Users,\r\n dashboard: LayoutDashboard,\r\n history: Clock3,\r\n sessions: Clock3,\r\n monitoring: Activity,\r\n activity: Activity,\r\n insights: Lightbulb,\r\n notifications: Bell,\r\n integrations: Plug,\r\n settings: Settings,\r\n usage: BarChart3,\r\n docs: FileText,\r\n documentation: FileText,\r\n agents: Headphones,\r\n security: Shield,\r\n configuration: Sliders,\r\n workflow: Workflow,\r\n};\r\n\r\nfunction resolveIcon(icon) {\r\n if (!icon) return SquareDot;\r\n if (typeof icon === \"string\") return ICON_MAP[icon.toLowerCase()] || SquareDot;\r\n return icon;\r\n}\r\n\r\nexport default function Sidebar({\r\n menuItems = [],\r\n activeId,\r\n onNavigate,\r\n collapsed: controlledCollapsed,\r\n onToggleCollapse,\r\n header,\r\n footer,\r\n width = 240,\r\n collapsedWidth = 56,\r\n}) {\r\n const [internalCollapsed, setInternalCollapsed] = useState(false);\r\n const collapsed = controlledCollapsed !== undefined ? controlledCollapsed : internalCollapsed;\r\n const toggleCollapse = onToggleCollapse || (() => setInternalCollapsed(!internalCollapsed));\r\n\r\n const [expandedGroups, setExpandedGroups] = useState(() => {\r\n const initial = {};\r\n menuItems.forEach((item) => {\r\n if (item.children?.length) {\r\n // Auto-expand groups that contain the active item\r\n const hasActive = item.children.some((c) => c.id === activeId || c.active);\r\n initial[item.id] = hasActive;\r\n }\r\n });\r\n return initial;\r\n });\r\n\r\n const toggleGroup = (id) => {\r\n setExpandedGroups((prev) => ({ ...prev, [id]: !prev[id] }));\r\n };\r\n\r\n const currentWidth = collapsed ? collapsedWidth : width;\r\n\r\n return (\r\n <nav\r\n style={{\r\n width: currentWidth,\r\n minWidth: currentWidth,\r\n height: \"100%\",\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n background: \"var(--paper-elevated)\",\r\n borderRight: \"1px solid var(--border)\",\r\n fontFamily: \"var(--font-sans)\",\r\n transition: \"width 0.2s ease, min-width 0.2s ease\",\r\n overflow: \"hidden\",\r\n flexShrink: 0,\r\n }}\r\n >\r\n {/* Header slot */}\r\n {header && !collapsed && (\r\n <div style={{ padding: \"16px 16px 8px\", flexShrink: 0 }}>\r\n {header}\r\n </div>\r\n )}\r\n\r\n {/* Collapse toggle */}\r\n <div\r\n style={{\r\n display: \"flex\",\r\n justifyContent: collapsed ? \"center\" : \"flex-end\",\r\n padding: collapsed ? \"12px 0\" : \"8px 12px\",\r\n flexShrink: 0,\r\n }}\r\n >\r\n <button\r\n onClick={toggleCollapse}\r\n title={collapsed ? \"Expand sidebar\" : \"Collapse sidebar\"}\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n width: 28,\r\n height: 28,\r\n borderRadius: \"var(--radius-sm)\",\r\n border: \"none\",\r\n background: \"transparent\",\r\n color: \"var(--text-faint)\",\r\n cursor: \"pointer\",\r\n transition: \"background 0.15s ease, color 0.15s ease\",\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background = \"var(--hover-warm)\";\r\n e.currentTarget.style.color = \"var(--text-muted)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = \"transparent\";\r\n e.currentTarget.style.color = \"var(--text-faint)\";\r\n }}\r\n >\r\n {collapsed ? <PanelLeft size={16} /> : <PanelLeftClose size={16} />}\r\n </button>\r\n </div>\r\n\r\n {/* Menu items */}\r\n <div\r\n style={{\r\n flex: 1,\r\n overflowY: \"auto\",\r\n overflowX: \"hidden\",\r\n padding: collapsed ? \"0 8px\" : \"0 10px\",\r\n }}\r\n >\r\n {menuItems.map((item, idx) => (\r\n <React.Fragment key={item.id || idx}>\r\n {/* Section label */}\r\n {item.section && !collapsed && (\r\n <div\r\n style={{\r\n fontSize: \"var(--text-xs)\",\r\n fontWeight: 650,\r\n letterSpacing: \"0.08em\",\r\n textTransform: \"uppercase\",\r\n color: \"var(--text-faint)\",\r\n padding: \"16px 8px 6px\",\r\n lineHeight: 1,\r\n }}\r\n >\r\n {item.section}\r\n </div>\r\n )}\r\n\r\n {item.children?.length ? (\r\n <SidebarGroup\r\n item={item}\r\n activeId={activeId}\r\n expanded={!!expandedGroups[item.id]}\r\n onToggle={() => toggleGroup(item.id)}\r\n onNavigate={onNavigate}\r\n collapsed={collapsed}\r\n />\r\n ) : (\r\n <SidebarItem\r\n item={item}\r\n active={item.id === activeId || item.active}\r\n onNavigate={onNavigate}\r\n collapsed={collapsed}\r\n />\r\n )}\r\n </React.Fragment>\r\n ))}\r\n </div>\r\n\r\n {/* Footer slot */}\r\n {footer && !collapsed && (\r\n <div\r\n style={{\r\n padding: \"12px 16px\",\r\n borderTop: \"1px solid var(--border-subtle)\",\r\n flexShrink: 0,\r\n }}\r\n >\r\n {footer}\r\n </div>\r\n )}\r\n </nav>\r\n );\r\n}\r\n\r\nfunction SidebarItem({ item, active, onNavigate, collapsed }) {\r\n const Icon = resolveIcon(item.icon);\r\n const isReactIcon = typeof item.icon !== \"string\" && typeof item.icon !== \"undefined\";\r\n\r\n return (\r\n <button\r\n onClick={() => onNavigate?.(item.href || item.id)}\r\n title={collapsed ? item.label : undefined}\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: collapsed ? 0 : 10,\r\n justifyContent: collapsed ? \"center\" : \"flex-start\",\r\n width: \"100%\",\r\n padding: collapsed ? \"10px 0\" : \"8px 10px\",\r\n borderRadius: \"var(--radius-sm)\",\r\n border: \"none\",\r\n background: active ? \"var(--hover-warm)\" : \"transparent\",\r\n color: active ? \"var(--text-ink)\" : \"var(--text-base)\",\r\n fontWeight: active ? 550 : 400,\r\n fontSize: \"var(--text-sm)\",\r\n fontFamily: \"var(--font-sans)\",\r\n cursor: \"pointer\",\r\n textAlign: \"left\",\r\n transition: \"background 0.15s ease, color 0.1s ease\",\r\n marginBottom: 2,\r\n }}\r\n onMouseEnter={(e) => {\r\n if (!active) {\r\n e.currentTarget.style.background = \"var(--hover-warm-subtle)\";\r\n }\r\n }}\r\n onMouseLeave={(e) => {\r\n if (!active) {\r\n e.currentTarget.style.background = \"transparent\";\r\n }\r\n }}\r\n >\r\n {isReactIcon ? (\r\n <span style={{ flexShrink: 0, display: \"flex\" }}>{item.icon}</span>\r\n ) : (\r\n <Icon\r\n size={16}\r\n style={{\r\n flexShrink: 0,\r\n color: active ? \"var(--text-strong)\" : \"var(--text-muted)\",\r\n }}\r\n />\r\n )}\r\n {!collapsed && (\r\n <span\r\n style={{\r\n overflow: \"hidden\",\r\n textOverflow: \"ellipsis\",\r\n whiteSpace: \"nowrap\",\r\n }}\r\n >\r\n {item.label}\r\n </span>\r\n )}\r\n </button>\r\n );\r\n}\r\n\r\nfunction SidebarGroup({ item, activeId, expanded, onToggle, onNavigate, collapsed }) {\r\n const Icon = resolveIcon(item.icon);\r\n const hasActiveChild = item.children?.some((c) => c.id === activeId || c.active);\r\n\r\n if (collapsed) {\r\n // In collapsed mode, show just the group icon\r\n return (\r\n <button\r\n onClick={onToggle}\r\n title={item.label}\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n width: \"100%\",\r\n padding: \"10px 0\",\r\n borderRadius: \"var(--radius-sm)\",\r\n border: \"none\",\r\n background: hasActiveChild ? \"var(--hover-warm)\" : \"transparent\",\r\n color: hasActiveChild ? \"var(--text-ink)\" : \"var(--text-base)\",\r\n cursor: \"pointer\",\r\n marginBottom: 2,\r\n transition: \"background 0.15s ease\",\r\n }}\r\n onMouseEnter={(e) => {\r\n if (!hasActiveChild) e.currentTarget.style.background = \"var(--hover-warm-subtle)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n if (!hasActiveChild) e.currentTarget.style.background = \"transparent\";\r\n }}\r\n >\r\n <Icon\r\n size={16}\r\n style={{ color: hasActiveChild ? \"var(--text-strong)\" : \"var(--text-muted)\" }}\r\n />\r\n </button>\r\n );\r\n }\r\n\r\n return (\r\n <div style={{ marginBottom: 2 }}>\r\n {/* Group header */}\r\n <button\r\n onClick={onToggle}\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: 10,\r\n width: \"100%\",\r\n padding: \"8px 10px\",\r\n borderRadius: \"var(--radius-sm)\",\r\n border: \"none\",\r\n background: \"transparent\",\r\n color: hasActiveChild ? \"var(--text-ink)\" : \"var(--text-base)\",\r\n fontWeight: hasActiveChild ? 550 : 400,\r\n fontSize: \"var(--text-sm)\",\r\n fontFamily: \"var(--font-sans)\",\r\n cursor: \"pointer\",\r\n textAlign: \"left\",\r\n transition: \"background 0.15s ease\",\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background = \"var(--hover-warm-subtle)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = \"transparent\";\r\n }}\r\n >\r\n <Icon\r\n size={16}\r\n style={{\r\n flexShrink: 0,\r\n color: hasActiveChild ? \"var(--text-strong)\" : \"var(--text-muted)\",\r\n }}\r\n />\r\n <span\r\n style={{\r\n flex: 1,\r\n overflow: \"hidden\",\r\n textOverflow: \"ellipsis\",\r\n whiteSpace: \"nowrap\",\r\n }}\r\n >\r\n {item.label}\r\n </span>\r\n <ChevronDown\r\n size={14}\r\n style={{\r\n flexShrink: 0,\r\n color: \"var(--text-faint)\",\r\n transform: expanded ? \"rotate(0deg)\" : \"rotate(-90deg)\",\r\n transition: \"transform 0.2s ease\",\r\n }}\r\n />\r\n </button>\r\n\r\n {/* Children */}\r\n {expanded && (\r\n <div style={{ paddingLeft: 18, marginTop: 2 }}>\r\n {item.children.map((child, idx) => (\r\n <SidebarItem\r\n key={child.id || idx}\r\n item={child}\r\n active={child.id === activeId || child.active}\r\n onNavigate={onNavigate}\r\n collapsed={false}\r\n />\r\n ))}\r\n </div>\r\n )}\r\n </div>\r\n );\r\n}\r\n","import React from 'react';\r\nimport { LogOut, ChevronDown } from 'lucide-react';\r\n\r\n// Stable avatar colors — warm/neutral palette, no purple\r\nconst AVATAR_COLORS = [\r\n '#5a8a6e', // sage green\r\n '#b07d4f', // warm amber\r\n '#7a8fa6', // slate blue\r\n '#c47a5a', // terracotta\r\n '#6a9a8a', // teal\r\n '#a0785a', // clay\r\n '#5a7a9a', // steel blue\r\n '#9a7a5a', // caramel\r\n];\r\n\r\nfunction avatarColor(name) {\r\n if (!name) return AVATAR_COLORS[0];\r\n let hash = 0;\r\n for (let i = 0; i < name.length; i++) hash = ((hash << 5) - hash + name.charCodeAt(i)) | 0;\r\n return AVATAR_COLORS[Math.abs(hash) % AVATAR_COLORS.length];\r\n}\r\n\r\n/**\r\n * NavigationBar — top-level app header bar.\r\n *\r\n * Slot-based composition: pass children for center content, trailing for right content,\r\n * or use the built-in user/switcher/actions props for the standard Chordia layout.\r\n *\r\n * Props:\r\n * - logo ReactNode Left-side branding (defaults to \"Chordia\" wordmark)\r\n * - title string App title shown after logo\r\n * - userName string User's display name\r\n * - userEmail string Fallback if no userName\r\n * - userRole string Role badge (e.g. \"Admin\")\r\n * - onSignOut function Sign out callback (renders sign out button)\r\n * - children ReactNode Center slot — switchers, breadcrumbs, tabs, anything\r\n * - trailing ReactNode Right slot — status indicators, extra actions\r\n * - height number Bar height in px (default 48)\r\n * - style object Style overrides on the root element\r\n */\r\nexport default function NavigationBar({\r\n logo,\r\n title,\r\n userName,\r\n userEmail,\r\n userInitials,\r\n userRole,\r\n onSignOut,\r\n children,\r\n trailing,\r\n height = 48,\r\n style,\r\n}) {\r\n const displayName = userName || userEmail || '';\r\n const initials = userInitials || getInitials(displayName);\r\n\r\n return (\r\n <header\r\n style={{\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'space-between',\r\n padding: '0 20px',\r\n height,\r\n borderBottom: '1px solid var(--border)',\r\n background: 'var(--paper-elevated)',\r\n flexShrink: 0,\r\n fontFamily: 'var(--font-sans)',\r\n ...style,\r\n }}\r\n >\r\n {/* ─── Left: Logo + Title ─── */}\r\n <div style={{ display: 'flex', alignItems: 'center', gap: 10, flexShrink: 0 }}>\r\n {logo !== undefined ? logo : (\r\n <span style={{\r\n fontSize: 'var(--text-lg)',\r\n fontWeight: 700,\r\n fontFamily: 'var(--font-display)',\r\n color: 'var(--text-ink)',\r\n letterSpacing: '-0.01em',\r\n }}>\r\n Chordia\r\n </span>\r\n )}\r\n {title && (\r\n <>\r\n <span style={{\r\n width: 1,\r\n height: 18,\r\n background: 'var(--border)',\r\n flexShrink: 0,\r\n }} />\r\n <span style={{\r\n fontSize: 'var(--text-md)',\r\n fontWeight: 500,\r\n color: 'var(--text-muted)',\r\n }}>\r\n {title}\r\n </span>\r\n </>\r\n )}\r\n </div>\r\n\r\n {/* ─── Center: Slot for switchers, breadcrumbs, tabs ─── */}\r\n {children && (\r\n <div style={{\r\n display: 'flex',\r\n alignItems: 'center',\r\n gap: 8,\r\n flex: 1,\r\n justifyContent: 'center',\r\n minWidth: 0,\r\n }}>\r\n {children}\r\n </div>\r\n )}\r\n\r\n {/* ─── Right: User + trailing ─── */}\r\n <div style={{\r\n display: 'flex',\r\n alignItems: 'center',\r\n gap: 10,\r\n flexShrink: 0,\r\n }}>\r\n {trailing}\r\n\r\n {displayName && (\r\n <div style={{ display: 'flex', alignItems: 'center', gap: 8 }}>\r\n {/* Initials avatar */}\r\n <div style={{\r\n width: 30,\r\n height: 30,\r\n borderRadius: '50%',\r\n background: avatarColor(displayName),\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n flexShrink: 0,\r\n }}>\r\n <span style={{\r\n fontSize: 11,\r\n fontWeight: 600,\r\n color: '#fff',\r\n letterSpacing: '0.02em',\r\n lineHeight: 1,\r\n }}>\r\n {initials}\r\n </span>\r\n </div>\r\n\r\n {/* Name + role */}\r\n <div style={{ display: 'flex', flexDirection: 'column', gap: 1 }}>\r\n <span style={{\r\n fontSize: 'var(--text-sm)',\r\n fontWeight: 550,\r\n color: 'var(--text-strong)',\r\n lineHeight: 1.2,\r\n }}>\r\n {displayName}\r\n </span>\r\n {userRole && (\r\n <span style={{\r\n fontSize: 'var(--text-xs)',\r\n color: 'var(--text-muted)',\r\n lineHeight: 1.2,\r\n }}>\r\n {userRole}\r\n </span>\r\n )}\r\n </div>\r\n\r\n {/* Sign out */}\r\n {onSignOut && (\r\n <button\r\n onClick={onSignOut}\r\n title=\"Sign out\"\r\n style={{\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n width: 28,\r\n height: 28,\r\n borderRadius: 'var(--radius-sm)',\r\n border: 'none',\r\n background: 'transparent',\r\n color: 'var(--text-faint)',\r\n cursor: 'pointer',\r\n transition: 'background 0.15s ease, color 0.15s ease',\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background = 'var(--hover-warm)';\r\n e.currentTarget.style.color = 'var(--text-muted)';\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = 'transparent';\r\n e.currentTarget.style.color = 'var(--text-faint)';\r\n }}\r\n >\r\n <LogOut size={14} />\r\n </button>\r\n )}\r\n </div>\r\n )}\r\n </div>\r\n </header>\r\n );\r\n}\r\n\r\n/**\r\n * NavPill — compact switcher button for use inside NavigationBar.\r\n *\r\n * Props:\r\n * - label string Display text\r\n * - color string Rail color token (e.g. \"var(--rail-discovery)\")\r\n * - active boolean Whether dropdown is open\r\n * - onClick function Toggle callback\r\n */\r\nexport function NavPill({ label, color = 'var(--text-muted)', active, onClick }) {\r\n return (\r\n <button\r\n onClick={onClick}\r\n style={{\r\n display: 'flex',\r\n alignItems: 'center',\r\n gap: 4,\r\n fontSize: 'var(--text-sm)',\r\n fontWeight: 500,\r\n fontFamily: 'var(--font-sans)',\r\n padding: '4px 10px',\r\n borderRadius: 'var(--radius-sm)',\r\n border: `1px solid color-mix(in srgb, ${color} 30%, transparent)`,\r\n background: `color-mix(in srgb, ${color} 10%, transparent)`,\r\n color: color,\r\n cursor: 'pointer',\r\n transition: 'background 0.15s ease, border-color 0.15s ease',\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background = `color-mix(in srgb, ${color} 18%, transparent)`;\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = `color-mix(in srgb, ${color} 10%, transparent)`;\r\n }}\r\n >\r\n {label}\r\n <ChevronDown\r\n size={12}\r\n style={{\r\n transform: active ? 'rotate(180deg)' : 'rotate(0deg)',\r\n transition: 'transform 0.2s ease',\r\n opacity: 0.7,\r\n }}\r\n />\r\n </button>\r\n );\r\n}\r\n\r\n/**\r\n * NavDropdown — dropdown panel that attaches to a NavPill.\r\n * Wrap around NavPill and the dropdown content.\r\n *\r\n * Props:\r\n * - open boolean Whether dropdown is visible\r\n * - onClose function Close callback\r\n * - children ReactNode Dropdown items\r\n * - align string \"left\" | \"right\" (default \"left\")\r\n */\r\nexport function NavDropdown({ open, onClose, children, align = 'left' }) {\r\n if (!open) return null;\r\n return (\r\n <>\r\n <div\r\n onClick={onClose}\r\n style={{ position: 'fixed', inset: 0, zIndex: 99, background: 'rgba(0,0,0,0.03)' }}\r\n />\r\n <div style={{\r\n position: 'absolute',\r\n top: '100%',\r\n [align === 'right' ? 'right' : 'left']: 0,\r\n marginTop: 4,\r\n zIndex: 100,\r\n background: '#fff',\r\n border: '1px solid var(--border)',\r\n borderRadius: 'var(--radius)',\r\n padding: 4,\r\n minWidth: 200,\r\n maxHeight: 280,\r\n overflowY: 'auto',\r\n boxShadow: '0 8px 24px rgba(0,0,0,0.12)',\r\n }}>\r\n {children}\r\n </div>\r\n </>\r\n );\r\n}\r\n\r\n/**\r\n * NavDropdownItem — single item inside NavDropdown.\r\n *\r\n * Props:\r\n * - label string\r\n * - active boolean\r\n * - onClick function\r\n */\r\nexport function NavDropdownItem({ label, active, onClick }) {\r\n return (\r\n <div\r\n onClick={onClick}\r\n style={{\r\n padding: '8px 10px',\r\n borderRadius: 'var(--radius-sm)',\r\n cursor: 'pointer',\r\n fontSize: 'var(--text-sm)',\r\n color: active ? 'var(--text-ink)' : 'var(--text-base)',\r\n fontWeight: active ? 600 : 400,\r\n fontFamily: 'var(--font-sans)',\r\n background: active ? 'var(--hover-warm)' : 'transparent',\r\n transition: 'background 0.1s ease',\r\n }}\r\n onMouseEnter={(e) => {\r\n if (!active) e.currentTarget.style.background = 'var(--hover-warm-subtle)';\r\n }}\r\n onMouseLeave={(e) => {\r\n if (!active) e.currentTarget.style.background = 'transparent';\r\n }}\r\n >\r\n {label}\r\n </div>\r\n );\r\n}\r\n\r\n/**\r\n * StatusIndicator — connection/status pill for trailing slot.\r\n *\r\n * Props:\r\n * - connected boolean\r\n * - label string (optional, defaults to Connected/Disconnected)\r\n */\r\nexport function StatusIndicator({ connected, label }) {\r\n const text = label || (connected ? 'Connected' : 'Disconnected');\r\n return (\r\n <span style={{\r\n fontSize: 'var(--text-xs)',\r\n fontFamily: 'var(--font-sans)',\r\n padding: '3px 10px',\r\n borderRadius: 12,\r\n border: `1px solid ${connected ? 'var(--state-present)' : 'var(--border)'}`,\r\n color: connected ? 'var(--state-present)' : 'var(--text-faint)',\r\n background: connected ? 'rgba(37,163,114,0.08)' : 'transparent',\r\n transition: 'all 0.2s ease',\r\n }}>\r\n {text}\r\n </span>\r\n );\r\n}\r\n\r\nfunction getInitials(name) {\r\n if (!name) return '?';\r\n const parts = name.trim().split(/\\s+/);\r\n if (parts.length >= 2) {\r\n return (parts[0][0] + parts[parts.length - 1][0]).toUpperCase();\r\n }\r\n return name.slice(0, 2).toUpperCase();\r\n}\r\n","\"use client\";\r\n\r\nimport React, { useState, useRef } from \"react\";\r\nimport { Upload, Link, Sparkles, CheckCircle2, X } from \"lucide-react\";\r\n\r\n/**\r\n * FirstCallScreen Component\r\n * Displays an onboarding screen with three options for getting started:\r\n * Upload an interaction, Explore a demonstration project, or Connect a data source.\r\n */\r\nexport default function FirstCallScreen({\r\n onUploadCall,\r\n onConnectSource,\r\n onUseSample,\r\n showExamples = false,\r\n}) {\r\n const [hoveredCard, setHoveredCard] = useState(null);\r\n const [uploadedFile, setUploadedFile] = useState(null);\r\n const [connectedSource, setConnectedSource] = useState(null);\r\n const [selectedProject, setSelectedProject] = useState(null);\r\n const fileInputRef = useRef(null);\r\n\r\n // Dummy data sources for testing\r\n const dummyDataSources = [\r\n { id: \"five9\", name: \"Five9\", status: \"available\", description: \"Cloud contact center platform\" },\r\n { id: \"twilio\", name: \"Twilio Flex\", status: \"available\", description: \"Programmable contact center\" },\r\n { id: \"genesys\", name: \"Genesys Cloud\", status: \"available\", description: \"All-in-one cloud contact center\" },\r\n { id: \"zoom\", name: \"Zoom Phone\", status: \"coming-soon\", description: \"Cloud phone system\" },\r\n ];\r\n\r\n // Dummy demo projects for testing\r\n const dummyProjects = [\r\n {\r\n id: \"retail-support\",\r\n name: \"Retail Customer Support\",\r\n description: \"Sample interactions from retail customer service team\",\r\n interactions: 24,\r\n dateRange: \"Last 30 days\",\r\n },\r\n {\r\n id: \"healthcare-billing\",\r\n name: \"Healthcare Billing Inquiries\",\r\n description: \"Patient billing and insurance verification calls\",\r\n interactions: 18,\r\n dateRange: \"Last 2 weeks\",\r\n },\r\n {\r\n id: \"financial-services\",\r\n name: \"Financial Services Compliance\",\r\n description: \"Banking and financial advisory interactions\",\r\n interactions: 32,\r\n dateRange: \"Last 45 days\",\r\n },\r\n ];\r\n\r\n const handleFileUpload = (event) => {\r\n const file = event.target.files?.[0];\r\n if (file) {\r\n // Check if file is audio or video\r\n const isAudio = file.type.startsWith(\"audio/\");\r\n const isVideo = file.type.startsWith(\"video/\");\r\n \r\n if (isAudio || isVideo) {\r\n setUploadedFile({\r\n name: file.name,\r\n type: file.type,\r\n size: file.size,\r\n lastModified: new Date(file.lastModified),\r\n });\r\n if (onUploadCall) {\r\n onUploadCall(file);\r\n } else {\r\n console.log(\"File uploaded:\", file.name, file.type, `(${(file.size / 1024 / 1024).toFixed(2)} MB)`);\r\n }\r\n } else {\r\n alert(\"Please select an audio or video file.\");\r\n }\r\n }\r\n // Reset input so the same file can be selected again\r\n if (fileInputRef.current) {\r\n fileInputRef.current.value = \"\";\r\n }\r\n };\r\n\r\n const handleConnectSource = (sourceId) => {\r\n const source = dummyDataSources.find((s) => s.id === sourceId);\r\n if (source && source.status === \"available\") {\r\n setConnectedSource(source);\r\n if (onConnectSource) {\r\n onConnectSource(source);\r\n } else {\r\n console.log(\"Connected to:\", source.name);\r\n }\r\n }\r\n };\r\n\r\n const handleSelectProject = (projectId) => {\r\n const project = dummyProjects.find((p) => p.id === projectId);\r\n if (project) {\r\n setSelectedProject(project);\r\n if (onUseSample) {\r\n onUseSample(project);\r\n } else {\r\n console.log(\"Selected project:\", project.name);\r\n }\r\n }\r\n };\r\n\r\n const handleUploadClick = () => {\r\n if (fileInputRef.current) {\r\n fileInputRef.current.click();\r\n }\r\n };\r\n\r\n const handleSampleClick = () => {\r\n if (showExamples && !selectedProject) {\r\n // Show project selection if examples are enabled\r\n return;\r\n }\r\n if (onUseSample) {\r\n onUseSample(selectedProject || { id: \"default\", name: \"Demo Project\" });\r\n }\r\n };\r\n\r\n const handleConnectClick = () => {\r\n if (showExamples && !connectedSource) {\r\n // Show data source selection if examples are enabled\r\n return;\r\n }\r\n if (onConnectSource) {\r\n onConnectSource(connectedSource || { id: \"default\", name: \"Data Source\" });\r\n }\r\n };\r\n\r\n const options = [\r\n {\r\n id: \"upload\",\r\n icon: Upload,\r\n title: \"Upload an interaction\",\r\n description:\r\n \"Drop an audio or video recording to see what Compass surfaces\",\r\n recommended: false,\r\n onClick: handleUploadClick,\r\n },\r\n {\r\n id: \"sample\",\r\n icon: Sparkles,\r\n title: \"Explore a demonstration project\",\r\n description:\r\n \"See how Chordia Compass surfaces insights from real interaction data\",\r\n recommended: true,\r\n onClick: handleSampleClick,\r\n },\r\n {\r\n id: \"connect\",\r\n icon: Link,\r\n title: \"Connect a data source\",\r\n description:\r\n \"Link your existing system to automatically analyze interactions\",\r\n recommended: false,\r\n onClick: handleConnectClick,\r\n },\r\n ];\r\n\r\n return (\r\n <div\r\n style={{\r\n minHeight: \"100vh\",\r\n background: \"var(--surface-warm)\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n padding: \"32px\",\r\n }}\r\n >\r\n {/* Hidden file input */}\r\n <input\r\n ref={fileInputRef}\r\n type=\"file\"\r\n accept=\"audio/*,video/*\"\r\n onChange={handleFileUpload}\r\n style={{ display: \"none\" }}\r\n />\r\n <div style={{ maxWidth: \"680px\", width: \"100%\" }}>\r\n {/* Header */}\r\n <div style={{ textAlign: \"center\", marginBottom: \"48px\" }}>\r\n <h1\r\n style={{\r\n fontSize: \"32px\",\r\n fontWeight: 760,\r\n letterSpacing: \"-0.02em\",\r\n color: \"rgba(30, 33, 37, 0.92)\",\r\n marginBottom: \"12px\",\r\n lineHeight: 1.2,\r\n }}\r\n >\r\n Experience Compass with one interaction\r\n </h1>\r\n <p\r\n style={{\r\n fontSize: \"15px\",\r\n color: \"rgba(30, 33, 37, 0.65)\",\r\n lineHeight: 1.5,\r\n maxWidth: \"520px\",\r\n margin: \"0 auto\",\r\n }}\r\n >\r\n Compass surfaces evidence, signals, and actionable insights from\r\n customer interactions. Start by exploring what it reveals.\r\n </p>\r\n </div>\r\n\r\n {/* Options */}\r\n <div\r\n style={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n gap: \"16px\",\r\n }}\r\n >\r\n {options.map((option) => {\r\n const Icon = option.icon;\r\n const isHovered = hoveredCard === option.id;\r\n\r\n return (\r\n <button\r\n key={option.id}\r\n type=\"button\"\r\n onClick={option.onClick}\r\n onMouseEnter={() => setHoveredCard(option.id)}\r\n onMouseLeave={() => setHoveredCard(null)}\r\n style={{\r\n position: \"relative\",\r\n width: \"100%\",\r\n padding: \"24px 28px\",\r\n background: isHovered\r\n ? \"rgba(255, 255, 255, 0.95)\"\r\n : \"rgba(255, 255, 255, 0.85)\",\r\n border: option.recommended\r\n ? \"2px solid rgba(184, 156, 106, 0.35)\"\r\n : isHovered\r\n ? \"1px solid rgba(52, 58, 64, 0.20)\"\r\n : \"1px solid rgba(52, 58, 64, 0.12)\",\r\n borderRadius: \"16px\",\r\n cursor: \"pointer\",\r\n textAlign: \"left\",\r\n transition: \"all 0.2s ease\",\r\n transform: isHovered ? \"translateY(-2px)\" : \"translateY(0)\",\r\n boxShadow: isHovered\r\n ? \"0 12px 28px rgba(30, 33, 37, 0.12)\"\r\n : \"0 4px 12px rgba(30, 33, 37, 0.06)\",\r\n }}\r\n >\r\n {/* Recommended badge */}\r\n {option.recommended && (\r\n <div\r\n style={{\r\n position: \"absolute\",\r\n top: \"16px\",\r\n right: \"20px\",\r\n fontSize: \"10px\",\r\n fontWeight: 650,\r\n letterSpacing: \"0.06em\",\r\n textTransform: \"uppercase\",\r\n color: \"rgba(184, 156, 106, 0.75)\",\r\n background: \"rgba(184, 156, 106, 0.12)\",\r\n padding: \"4px 8px\",\r\n borderRadius: \"6px\",\r\n border: \"1px solid rgba(184, 156, 106, 0.2)\",\r\n }}\r\n >\r\n Recommended\r\n </div>\r\n )}\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"flex-start\",\r\n gap: \"18px\",\r\n }}\r\n >\r\n {/* Icon */}\r\n <div\r\n style={{\r\n width: \"48px\",\r\n height: \"48px\",\r\n borderRadius: \"12px\",\r\n background: option.recommended\r\n ? \"rgba(184, 156, 106, 0.12)\"\r\n : \"rgba(231, 212, 162, 0.20)\",\r\n border: option.recommended\r\n ? \"1px solid rgba(184, 156, 106, 0.25)\"\r\n : \"1px solid rgba(231, 212, 162, 0.35)\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n flexShrink: 0,\r\n }}\r\n >\r\n <Icon\r\n size={22}\r\n style={{\r\n color: option.recommended\r\n ? \"rgba(184, 156, 106, 0.75)\"\r\n : \"rgba(30, 33, 37, 0.52)\",\r\n }}\r\n />\r\n </div>\r\n\r\n {/* Content */}\r\n <div style={{ flex: 1, paddingTop: \"2px\" }}>\r\n <div\r\n style={{\r\n fontSize: \"17px\",\r\n fontWeight: 680,\r\n letterSpacing: \"-0.01em\",\r\n color: \"rgba(30, 33, 37, 0.92)\",\r\n marginBottom: \"6px\",\r\n lineHeight: 1.3,\r\n }}\r\n >\r\n {option.title}\r\n </div>\r\n <div\r\n style={{\r\n fontSize: \"13.5px\",\r\n color: \"rgba(30, 33, 37, 0.62)\",\r\n lineHeight: 1.5,\r\n }}\r\n >\r\n {option.description}\r\n </div>\r\n </div>\r\n </div>\r\n </button>\r\n );\r\n })}\r\n </div>\r\n\r\n {/* Footer note */}\r\n <div\r\n style={{\r\n marginTop: \"32px\",\r\n textAlign: \"center\",\r\n fontSize: \"12px\",\r\n color: \"rgba(30, 33, 37, 0.52)\",\r\n lineHeight: 1.5,\r\n }}\r\n >\r\n Your workspace has been created automatically. You can configure\r\n settings and add teammates later.\r\n </div>\r\n\r\n {/* Testing Examples Section */}\r\n {showExamples && (\r\n <div style={{ marginTop: \"48px\", paddingTop: \"32px\", borderTop: \"1px solid rgba(52, 58, 64, 0.12)\" }}>\r\n <h2\r\n style={{\r\n fontSize: \"20px\",\r\n fontWeight: 680,\r\n letterSpacing: \"-0.01em\",\r\n color: \"rgba(30, 33, 37, 0.92)\",\r\n marginBottom: \"24px\",\r\n }}\r\n >\r\n Testing Examples\r\n </h2>\r\n\r\n {/* Uploaded File Example */}\r\n {uploadedFile && (\r\n <div\r\n style={{\r\n marginBottom: \"24px\",\r\n padding: \"16px\",\r\n background: \"rgba(255, 255, 255, 0.85)\",\r\n border: \"1px solid rgba(52, 58, 64, 0.12)\",\r\n borderRadius: \"12px\",\r\n }}\r\n >\r\n <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"space-between\", marginBottom: \"8px\" }}>\r\n <div style={{ display: \"flex\", alignItems: \"center\", gap: \"8px\" }}>\r\n <CheckCircle2 size={18} style={{ color: \"#1F8F5A\" }} />\r\n <span style={{ fontSize: \"14px\", fontWeight: 650, color: \"rgba(30, 33, 37, 0.92)\" }}>\r\n File Uploaded\r\n </span>\r\n </div>\r\n <button\r\n onClick={() => setUploadedFile(null)}\r\n style={{\r\n background: \"none\",\r\n border: \"none\",\r\n cursor: \"pointer\",\r\n padding: \"4px\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n }}\r\n >\r\n <X size={16} style={{ color: \"rgba(30, 33, 37, 0.42)\" }} />\r\n </button>\r\n </div>\r\n <div style={{ fontSize: \"13px\", color: \"rgba(30, 33, 37, 0.65)\", lineHeight: 1.5 }}>\r\n <div><strong>Name:</strong> {uploadedFile.name}</div>\r\n <div><strong>Type:</strong> {uploadedFile.type}</div>\r\n <div><strong>Size:</strong> {(uploadedFile.size / 1024 / 1024).toFixed(2)} MB</div>\r\n <div><strong>Uploaded:</strong> {uploadedFile.lastModified.toLocaleString()}</div>\r\n </div>\r\n </div>\r\n )}\r\n\r\n {/* Demo Projects Selection */}\r\n {!selectedProject && (\r\n <div style={{ marginBottom: \"24px\" }}>\r\n <h3\r\n style={{\r\n fontSize: \"15px\",\r\n fontWeight: 650,\r\n color: \"rgba(30, 33, 37, 0.82)\",\r\n marginBottom: \"12px\",\r\n }}\r\n >\r\n Select a Demonstration Project:\r\n </h3>\r\n <div style={{ display: \"flex\", flexDirection: \"column\", gap: \"8px\" }}>\r\n {dummyProjects.map((project) => (\r\n <button\r\n key={project.id}\r\n onClick={() => handleSelectProject(project.id)}\r\n style={{\r\n padding: \"12px 16px\",\r\n background: \"rgba(255, 255, 255, 0.85)\",\r\n border: \"1px solid rgba(52, 58, 64, 0.12)\",\r\n borderRadius: \"8px\",\r\n textAlign: \"left\",\r\n cursor: \"pointer\",\r\n transition: \"all 0.15s ease\",\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background = \"rgba(255, 255, 255, 0.95)\";\r\n e.currentTarget.style.borderColor = \"rgba(52, 58, 64, 0.20)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = \"rgba(255, 255, 255, 0.85)\";\r\n e.currentTarget.style.borderColor = \"rgba(52, 58, 64, 0.12)\";\r\n }}\r\n >\r\n <div style={{ fontSize: \"14px\", fontWeight: 650, color: \"rgba(30, 33, 37, 0.92)\", marginBottom: \"4px\" }}>\r\n {project.name}\r\n </div>\r\n <div style={{ fontSize: \"12px\", color: \"rgba(30, 33, 37, 0.62)\", marginBottom: \"4px\" }}>\r\n {project.description}\r\n </div>\r\n <div style={{ fontSize: \"11px\", color: \"rgba(30, 33, 37, 0.52)\" }}>\r\n {project.interactions} interactions · {project.dateRange}\r\n </div>\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n )}\r\n\r\n {/* Selected Project Example */}\r\n {selectedProject && (\r\n <div\r\n style={{\r\n marginBottom: \"24px\",\r\n padding: \"16px\",\r\n background: \"rgba(255, 255, 255, 0.85)\",\r\n border: \"1px solid rgba(52, 58, 64, 0.12)\",\r\n borderRadius: \"12px\",\r\n }}\r\n >\r\n <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"space-between\", marginBottom: \"8px\" }}>\r\n <div style={{ display: \"flex\", alignItems: \"center\", gap: \"8px\" }}>\r\n <CheckCircle2 size={18} style={{ color: \"#1F8F5A\" }} />\r\n <span style={{ fontSize: \"14px\", fontWeight: 650, color: \"rgba(30, 33, 37, 0.92)\" }}>\r\n Project Selected: {selectedProject.name}\r\n </span>\r\n </div>\r\n <button\r\n onClick={() => setSelectedProject(null)}\r\n style={{\r\n background: \"none\",\r\n border: \"none\",\r\n cursor: \"pointer\",\r\n padding: \"4px\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n }}\r\n >\r\n <X size={16} style={{ color: \"rgba(30, 33, 37, 0.42)\" }} />\r\n </button>\r\n </div>\r\n <div style={{ fontSize: \"13px\", color: \"rgba(30, 33, 37, 0.65)\", lineHeight: 1.5 }}>\r\n <div>{selectedProject.description}</div>\r\n <div style={{ marginTop: \"4px\" }}>\r\n <strong>{selectedProject.interactions}</strong> interactions · <strong>{selectedProject.dateRange}</strong>\r\n </div>\r\n </div>\r\n </div>\r\n )}\r\n\r\n {/* Data Sources Selection */}\r\n {!connectedSource && (\r\n <div style={{ marginBottom: \"24px\" }}>\r\n <h3\r\n style={{\r\n fontSize: \"15px\",\r\n fontWeight: 650,\r\n color: \"rgba(30, 33, 37, 0.82)\",\r\n marginBottom: \"12px\",\r\n }}\r\n >\r\n Connect a Data Source:\r\n </h3>\r\n <div style={{ display: \"flex\", flexDirection: \"column\", gap: \"8px\" }}>\r\n {dummyDataSources.map((source) => (\r\n <button\r\n key={source.id}\r\n onClick={() => handleConnectSource(source.id)}\r\n disabled={source.status === \"coming-soon\"}\r\n style={{\r\n padding: \"12px 16px\",\r\n background: source.status === \"coming-soon\" \r\n ? \"rgba(255, 255, 255, 0.5)\" \r\n : \"rgba(255, 255, 255, 0.85)\",\r\n border: \"1px solid rgba(52, 58, 64, 0.12)\",\r\n borderRadius: \"8px\",\r\n textAlign: \"left\",\r\n cursor: source.status === \"coming-soon\" ? \"not-allowed\" : \"pointer\",\r\n transition: \"all 0.15s ease\",\r\n opacity: source.status === \"coming-soon\" ? 0.6 : 1,\r\n }}\r\n onMouseEnter={(e) => {\r\n if (source.status !== \"coming-soon\") {\r\n e.currentTarget.style.background = \"rgba(255, 255, 255, 0.95)\";\r\n e.currentTarget.style.borderColor = \"rgba(52, 58, 64, 0.20)\";\r\n }\r\n }}\r\n onMouseLeave={(e) => {\r\n if (source.status !== \"coming-soon\") {\r\n e.currentTarget.style.background = \"rgba(255, 255, 255, 0.85)\";\r\n e.currentTarget.style.borderColor = \"rgba(52, 58, 64, 0.12)\";\r\n }\r\n }}\r\n >\r\n <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"space-between\" }}>\r\n <div>\r\n <div style={{ fontSize: \"14px\", fontWeight: 650, color: \"rgba(30, 33, 37, 0.92)\", marginBottom: \"4px\" }}>\r\n {source.name}\r\n </div>\r\n <div style={{ fontSize: \"12px\", color: \"rgba(30, 33, 37, 0.62)\" }}>\r\n {source.description}\r\n </div>\r\n </div>\r\n {source.status === \"coming-soon\" && (\r\n <span\r\n style={{\r\n fontSize: \"10px\",\r\n fontWeight: 600,\r\n color: \"rgba(30, 33, 37, 0.42)\",\r\n background: \"rgba(30, 33, 37, 0.08)\",\r\n padding: \"4px 8px\",\r\n borderRadius: \"4px\",\r\n }}\r\n >\r\n Coming Soon\r\n </span>\r\n )}\r\n </div>\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n )}\r\n\r\n {/* Connected Source Example */}\r\n {connectedSource && (\r\n <div\r\n style={{\r\n marginBottom: \"24px\",\r\n padding: \"16px\",\r\n background: \"rgba(255, 255, 255, 0.85)\",\r\n border: \"1px solid rgba(52, 58, 64, 0.12)\",\r\n borderRadius: \"12px\",\r\n }}\r\n >\r\n <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"space-between\", marginBottom: \"8px\" }}>\r\n <div style={{ display: \"flex\", alignItems: \"center\", gap: \"8px\" }}>\r\n <CheckCircle2 size={18} style={{ color: \"#1F8F5A\" }} />\r\n <span style={{ fontSize: \"14px\", fontWeight: 650, color: \"rgba(30, 33, 37, 0.92)\" }}>\r\n Connected: {connectedSource.name}\r\n </span>\r\n </div>\r\n <button\r\n onClick={() => setConnectedSource(null)}\r\n style={{\r\n background: \"none\",\r\n border: \"none\",\r\n cursor: \"pointer\",\r\n padding: \"4px\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n }}\r\n >\r\n <X size={16} style={{ color: \"rgba(30, 33, 37, 0.42)\" }} />\r\n </button>\r\n </div>\r\n <div style={{ fontSize: \"13px\", color: \"rgba(30, 33, 37, 0.65)\", lineHeight: 1.5 }}>\r\n {connectedSource.description}\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n}\r\n\r\n","\"use client\";\r\n\r\nimport React, { useState } from \"react\";\r\nimport {\r\n X,\r\n CheckCircle2,\r\n Circle,\r\n ChevronRight,\r\n Sparkles,\r\n Users,\r\n FolderOpen,\r\n Link,\r\n Settings,\r\n BookOpen,\r\n} from \"lucide-react\";\r\n\r\n/**\r\n * OnboardingChecklist Component\r\n * Displays a collapsible checklist of onboarding tasks with progress tracking.\r\n * Shows completed items with checkmarks and allows interaction with incomplete items.\r\n */\r\nexport default function OnboardingChecklist({\r\n onDismiss,\r\n onItemClick,\r\n completedItems = [],\r\n}) {\r\n const [isCollapsed, setIsCollapsed] = useState(false);\r\n const [hoveredItem, setHoveredItem] = useState(null);\r\n\r\n const checklistItems = [\r\n {\r\n id: \"name-project\",\r\n title: \"Name your workspace\",\r\n description: \"Give your default project a meaningful name\",\r\n icon: FolderOpen,\r\n completed: completedItems.includes(\"name-project\"),\r\n optional: true,\r\n },\r\n {\r\n id: \"evaluate-second-interaction\",\r\n title: \"Evaluate another interaction\",\r\n description: \"Upload or connect a second interaction to see patterns\",\r\n icon: Sparkles,\r\n completed: completedItems.includes(\"evaluate-second-interaction\"),\r\n },\r\n {\r\n id: \"connect-source\",\r\n title: \"Connect a data source\",\r\n description: \"Link your system or platform for automatic evaluation\",\r\n icon: Link,\r\n completed: completedItems.includes(\"connect-source\"),\r\n },\r\n {\r\n id: \"invite-team\",\r\n title: \"Add teammates\",\r\n description: \"Invite managers or QA team members to collaborate\",\r\n icon: Users,\r\n completed: completedItems.includes(\"invite-team\"),\r\n optional: true,\r\n },\r\n {\r\n id: \"learn-concepts\",\r\n title: \"Understand Chordia concepts\",\r\n description: \"Learn how conditions, evidence, and confidence work\",\r\n icon: BookOpen,\r\n completed: completedItems.includes(\"learn-concepts\"),\r\n optional: true,\r\n },\r\n {\r\n id: \"configure-scope\",\r\n title: \"Clarify evaluation scope\",\r\n description: \"Customize which signals and conditions matter for your team\",\r\n icon: Settings,\r\n completed: completedItems.includes(\"configure-scope\"),\r\n optional: true,\r\n },\r\n ];\r\n\r\n const completedCount = checklistItems.filter((item) => item.completed).length;\r\n const totalCount = checklistItems.length;\r\n const progressPercent = (completedCount / totalCount) * 100;\r\n\r\n if (isCollapsed) {\r\n return (\r\n <button\r\n type=\"button\"\r\n onClick={() => setIsCollapsed(false)}\r\n style={{\r\n width: \"100%\",\r\n padding: \"14px 16px\",\r\n background: \"rgba(255, 255, 255, 0.85)\",\r\n border: \"1px solid rgba(52, 58, 64, 0.12)\",\r\n borderRadius: \"12px\",\r\n cursor: \"pointer\",\r\n textAlign: \"left\",\r\n transition: \"all 0.15s ease\",\r\n boxShadow: \"0 2px 8px rgba(30, 33, 37, 0.04)\",\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background = \"rgba(255, 255, 255, 0.95)\";\r\n e.currentTarget.style.borderColor = \"rgba(52, 58, 64, 0.18)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = \"rgba(255, 255, 255, 0.85)\";\r\n e.currentTarget.style.borderColor = \"rgba(52, 58, 64, 0.12)\";\r\n }}\r\n >\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"space-between\",\r\n gap: \"12px\",\r\n }}\r\n >\r\n <div\r\n style={{\r\n fontSize: \"13px\",\r\n fontWeight: 600,\r\n color: \"rgba(30, 33, 37, 0.75)\",\r\n }}\r\n >\r\n Getting started ({completedCount}/{totalCount})\r\n </div>\r\n <ChevronRight size={16} style={{ color: \"rgba(30, 33, 37, 0.42)\" }} />\r\n </div>\r\n </button>\r\n );\r\n }\r\n\r\n return (\r\n <div\r\n style={{\r\n background: \"rgba(255, 255, 255, 0.85)\",\r\n border: \"1px solid rgba(52, 58, 64, 0.12)\",\r\n borderRadius: \"16px\",\r\n overflow: \"hidden\",\r\n boxShadow: \"0 4px 16px rgba(30, 33, 37, 0.06)\",\r\n }}\r\n >\r\n {/* Header */}\r\n <div\r\n style={{\r\n padding: \"18px 20px 16px\",\r\n borderBottom: \"1px solid rgba(52, 58, 64, 0.08)\",\r\n }}\r\n >\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"flex-start\",\r\n justifyContent: \"space-between\",\r\n gap: \"12px\",\r\n }}\r\n >\r\n <div style={{ flex: 1 }}>\r\n <div\r\n style={{\r\n fontSize: \"15px\",\r\n fontWeight: 680,\r\n letterSpacing: \"-0.01em\",\r\n color: \"rgba(30, 33, 37, 0.92)\",\r\n marginBottom: \"6px\",\r\n lineHeight: 1.3,\r\n }}\r\n >\r\n Getting started with Chordia\r\n </div>\r\n <div\r\n style={{\r\n fontSize: \"12px\",\r\n color: \"rgba(30, 33, 37, 0.58)\",\r\n lineHeight: 1.4,\r\n }}\r\n >\r\n {completedCount} of {totalCount} completed\r\n </div>\r\n </div>\r\n <div style={{ display: \"flex\", gap: \"4px\" }}>\r\n {/* Collapse button */}\r\n <button\r\n type=\"button\"\r\n onClick={() => setIsCollapsed(true)}\r\n style={{\r\n width: \"28px\",\r\n height: \"28px\",\r\n borderRadius: \"6px\",\r\n background: \"transparent\",\r\n border: \"1px solid rgba(52, 58, 64, 0.12)\",\r\n cursor: \"pointer\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n transition: \"all 0.15s ease\",\r\n color: \"rgba(30, 33, 37, 0.52)\",\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background = \"rgba(231, 212, 162, 0.12)\";\r\n e.currentTarget.style.borderColor = \"rgba(52, 58, 64, 0.18)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = \"transparent\";\r\n e.currentTarget.style.borderColor = \"rgba(52, 58, 64, 0.12)\";\r\n }}\r\n title=\"Collapse\"\r\n >\r\n <ChevronRight size={14} />\r\n </button>\r\n {/* Dismiss button */}\r\n {onDismiss && (\r\n <button\r\n type=\"button\"\r\n onClick={onDismiss}\r\n style={{\r\n width: \"28px\",\r\n height: \"28px\",\r\n borderRadius: \"6px\",\r\n background: \"transparent\",\r\n border: \"1px solid rgba(52, 58, 64, 0.12)\",\r\n cursor: \"pointer\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n transition: \"all 0.15s ease\",\r\n color: \"rgba(30, 33, 37, 0.52)\",\r\n }}\r\n onMouseEnter={(e) => {\r\n e.currentTarget.style.background = \"rgba(231, 212, 162, 0.12)\";\r\n e.currentTarget.style.borderColor = \"rgba(52, 58, 64, 0.18)\";\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.background = \"transparent\";\r\n e.currentTarget.style.borderColor = \"rgba(52, 58, 64, 0.12)\";\r\n }}\r\n title=\"Dismiss checklist\"\r\n >\r\n <X size={14} />\r\n </button>\r\n )}\r\n </div>\r\n </div>\r\n {/* Progress bar */}\r\n <div\r\n style={{\r\n marginTop: \"14px\",\r\n height: \"6px\",\r\n background: \"rgba(30, 33, 37, 0.08)\",\r\n borderRadius: \"999px\",\r\n overflow: \"hidden\",\r\n }}\r\n >\r\n <div\r\n style={{\r\n height: \"100%\",\r\n width: `${progressPercent}%`,\r\n background:\r\n \"linear-gradient(90deg, rgba(184, 156, 106, 0.75) 0%, rgba(139, 157, 127, 0.75) 100%)\",\r\n borderRadius: \"999px\",\r\n transition: \"width 0.4s ease\",\r\n }}\r\n />\r\n </div>\r\n </div>\r\n\r\n {/* Checklist items */}\r\n <div style={{ padding: \"8px\" }}>\r\n {checklistItems.map((item, index) => {\r\n const Icon = item.icon;\r\n const isHovered = hoveredItem === item.id;\r\n\r\n return (\r\n <button\r\n key={item.id}\r\n type=\"button\"\r\n onClick={() => onItemClick?.(item.id)}\r\n onMouseEnter={() => setHoveredItem(item.id)}\r\n onMouseLeave={() => setHoveredItem(null)}\r\n disabled={item.completed}\r\n style={{\r\n width: \"100%\",\r\n padding: \"12px 14px\",\r\n background: item.completed\r\n ? \"rgba(139, 157, 127, 0.06)\"\r\n : isHovered\r\n ? \"rgba(231, 212, 162, 0.12)\"\r\n : \"transparent\",\r\n border: \"none\",\r\n borderRadius: \"10px\",\r\n cursor: item.completed ? \"default\" : \"pointer\",\r\n textAlign: \"left\",\r\n transition: \"all 0.15s ease\",\r\n marginBottom: index < checklistItems.length - 1 ? \"4px\" : \"0\",\r\n opacity: item.completed ? 0.7 : 1,\r\n }}\r\n >\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"flex-start\",\r\n gap: \"12px\",\r\n }}\r\n >\r\n {/* Icon/Checkbox */}\r\n <div\r\n style={{\r\n width: \"20px\",\r\n height: \"20px\",\r\n marginTop: \"1px\",\r\n flexShrink: 0,\r\n }}\r\n >\r\n {item.completed ? (\r\n <CheckCircle2\r\n size={20}\r\n style={{ color: \"rgba(139, 157, 127, 0.75)\" }}\r\n />\r\n ) : (\r\n <Circle\r\n size={20}\r\n style={{ color: \"rgba(30, 33, 37, 0.24)\" }}\r\n />\r\n )}\r\n </div>\r\n {/* Content */}\r\n <div style={{ flex: 1, minWidth: 0 }}>\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"8px\",\r\n marginBottom: \"3px\",\r\n }}\r\n >\r\n <Icon\r\n size={14}\r\n style={{ color: \"rgba(30, 33, 37, 0.52)\", flexShrink: 0 }}\r\n />\r\n <span\r\n style={{\r\n fontSize: \"13px\",\r\n fontWeight: 600,\r\n color: item.completed\r\n ? \"rgba(30, 33, 37, 0.52)\"\r\n : \"rgba(30, 33, 37, 0.85)\",\r\n textDecoration: item.completed ? \"line-through\" : \"none\",\r\n lineHeight: 1.3,\r\n }}\r\n >\r\n {item.title}\r\n </span>\r\n {item.optional && !item.completed && (\r\n <span\r\n style={{\r\n fontSize: \"9px\",\r\n fontWeight: 600,\r\n letterSpacing: \"0.04em\",\r\n textTransform: \"uppercase\",\r\n color: \"rgba(30, 33, 37, 0.42)\",\r\n background: \"rgba(30, 33, 37, 0.06)\",\r\n padding: \"2px 5px\",\r\n borderRadius: \"4px\",\r\n }}\r\n >\r\n Optional\r\n </span>\r\n )}\r\n </div>\r\n <div\r\n style={{\r\n fontSize: \"11.5px\",\r\n color: \"rgba(30, 33, 37, 0.52)\",\r\n lineHeight: 1.4,\r\n paddingLeft: \"22px\",\r\n }}\r\n >\r\n {item.description}\r\n </div>\r\n </div>\r\n {/* Arrow indicator (only for incomplete items on hover) */}\r\n {!item.completed && isHovered && (\r\n <ChevronRight\r\n size={16}\r\n style={{\r\n color: \"rgba(30, 33, 37, 0.32)\",\r\n marginTop: \"2px\",\r\n flexShrink: 0,\r\n }}\r\n />\r\n )}\r\n </div>\r\n </button>\r\n );\r\n })}\r\n </div>\r\n\r\n {/* Footer note */}\r\n <div\r\n style={{\r\n padding: \"12px 20px 16px\",\r\n borderTop: \"1px solid rgba(52, 58, 64, 0.08)\",\r\n }}\r\n >\r\n <div\r\n style={{\r\n fontSize: \"11px\",\r\n color: \"rgba(30, 33, 37, 0.52)\",\r\n lineHeight: 1.5,\r\n fontStyle: \"italic\",\r\n }}\r\n >\r\n You can dismiss this checklist anytime. These steps help you get the\r\n most from Chordia, but {'aren\\'t'} required.\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n}\r\n\r\n","\"use client\";\r\n\r\nimport React from \"react\";\r\n\r\n/**\r\n * DemoProjectBanner Component\r\n * Displays a diagonal banner in the top-right corner indicating a demo project.\r\n * Creates a triangular ribbon effect with rotated text.\r\n */\r\nexport default function DemoProjectBanner({\r\n text = \"Demo Project\",\r\n accentColor = \"#B89C6A\",\r\n textColor = \"rgba(255, 255, 255, 0.95)\",\r\n size = \"medium\",\r\n position = \"fixed\",\r\n}) {\r\n // Size configurations\r\n const sizeConfig = {\r\n small: {\r\n width: 140,\r\n height: 140,\r\n fontSize: \"11px\",\r\n letterSpacing: \"0.08em\",\r\n fontWeight: 650,\r\n },\r\n medium: {\r\n width: 180,\r\n height: 180,\r\n fontSize: \"12px\",\r\n letterSpacing: \"0.1em\",\r\n fontWeight: 680,\r\n },\r\n large: {\r\n width: 220,\r\n height: 220,\r\n fontSize: \"13px\",\r\n letterSpacing: \"0.12em\",\r\n fontWeight: 700,\r\n },\r\n };\r\n\r\n const config = sizeConfig[size];\r\n\r\n return (\r\n <div\r\n style={{\r\n position: position,\r\n top: 0,\r\n right: 0,\r\n width: config.width,\r\n height: config.height,\r\n overflow: \"hidden\",\r\n zIndex: position === \"fixed\" ? 9999 : 1,\r\n pointerEvents: \"none\",\r\n }}\r\n >\r\n {/* Triangle background */}\r\n <div\r\n style={{\r\n position: \"absolute\",\r\n top: 0,\r\n right: 0,\r\n width: 0,\r\n height: 0,\r\n borderStyle: \"solid\",\r\n borderWidth: `0 ${config.width}px ${config.height}px 0`,\r\n borderColor: `transparent ${accentColor} transparent transparent`,\r\n opacity: 0.92,\r\n }}\r\n />\r\n\r\n {/* Diagonal stripe for depth */}\r\n <div\r\n style={{\r\n position: \"absolute\",\r\n top: 0,\r\n right: 0,\r\n width: 0,\r\n height: 0,\r\n borderStyle: \"solid\",\r\n borderWidth: `0 ${config.width}px ${config.height}px 0`,\r\n borderColor: \"transparent rgba(0, 0, 0, 0.08) transparent transparent\",\r\n }}\r\n />\r\n\r\n {/* Text container - rotated 45deg */}\r\n <div\r\n style={{\r\n position: \"absolute\",\r\n top:\r\n size === \"small\"\r\n ? \"28px\"\r\n : size === \"medium\"\r\n ? \"38px\"\r\n : \"48px\",\r\n right:\r\n size === \"small\"\r\n ? \"-32px\"\r\n : size === \"medium\"\r\n ? \"-42px\"\r\n : \"-52px\",\r\n width:\r\n size === \"small\" ? \"160px\" : size === \"medium\" ? \"200px\" : \"240px\",\r\n transform: \"rotate(45deg)\",\r\n transformOrigin: \"center\",\r\n textAlign: \"center\",\r\n }}\r\n >\r\n <div\r\n style={{\r\n fontSize: config.fontSize,\r\n fontWeight: config.fontWeight,\r\n letterSpacing: config.letterSpacing,\r\n textTransform: \"uppercase\",\r\n color: textColor,\r\n textShadow: \"0 1px 2px rgba(0, 0, 0, 0.15)\",\r\n whiteSpace: \"nowrap\",\r\n userSelect: \"none\",\r\n }}\r\n >\r\n {text}\r\n </div>\r\n </div>\r\n\r\n {/* Subtle shadow for depth */}\r\n <div\r\n style={{\r\n position: \"absolute\",\r\n top: 0,\r\n right: 0,\r\n width: config.width,\r\n height: config.height,\r\n background:\r\n \"linear-gradient(135deg, transparent 0%, rgba(0, 0, 0, 0.04) 100%)\",\r\n pointerEvents: \"none\",\r\n }}\r\n />\r\n </div>\r\n );\r\n}\r\n\r\n","\"use client\";\r\n\r\nimport React from \"react\";\r\nimport { CheckCircle2, Circle, Settings } from \"lucide-react\";\r\n\r\n/**\r\n * IntegrationCard Component\r\n * Displays an integration provider card with status, logo, and configuration options\r\n */\r\nexport default function IntegrationCard({\r\n providerName,\r\n description,\r\n status = \"available\",\r\n railColor,\r\n logoUrl,\r\n icon,\r\n onConfigure,\r\n}) {\r\n const statusConfig = {\r\n connected: {\r\n label: \"Connected\",\r\n color: \"#6B7C93\",\r\n bgColor: \"rgba(107, 124, 147, 0.08)\",\r\n borderColor: \"rgba(107, 124, 147, 0.20)\",\r\n icon: <CheckCircle2 size={14} strokeWidth={2.5} />,\r\n },\r\n available: {\r\n label: \"Available\",\r\n color: \"#1E2125\",\r\n bgColor: \"rgba(30, 33, 37, 0.04)\",\r\n borderColor: \"rgba(30, 33, 37, 0.12)\",\r\n icon: <Circle size={14} strokeWidth={2} />,\r\n },\r\n \"coming-soon\": {\r\n label: \"Coming Soon\",\r\n color: \"rgba(30, 33, 37, 0.42)\",\r\n bgColor: \"transparent\",\r\n borderColor: \"rgba(30, 33, 37, 0.12)\",\r\n icon: <Circle size={14} strokeWidth={2} style={{ opacity: 0.4 }} />,\r\n },\r\n };\r\n\r\n const config = statusConfig[status] || statusConfig.available;\r\n\r\n return (\r\n <div\r\n style={{\r\n background: \"#FFFFFF\",\r\n border: `1px solid ${railColor}20`,\r\n borderRadius: \"8px\",\r\n position: \"relative\",\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n transition: \"all 0.15s ease\",\r\n cursor: status === \"coming-soon\" ? \"default\" : \"pointer\",\r\n opacity: status === \"coming-soon\" ? 0.6 : 1,\r\n overflow: \"hidden\",\r\n height: \"100%\",\r\n }}\r\n className=\"hover:shadow-sm\"\r\n >\r\n {/* Rail */}\r\n <div\r\n style={{\r\n position: \"absolute\",\r\n left: 0,\r\n top: 0,\r\n bottom: 0,\r\n width: \"4px\",\r\n background: railColor,\r\n opacity: status === \"coming-soon\" ? 0.4 : 1,\r\n }}\r\n />\r\n\r\n {/* Content wrapper with padding */}\r\n <div\r\n style={{\r\n padding: \"20px\",\r\n paddingLeft: \"24px\",\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n gap: \"16px\",\r\n height: \"100%\",\r\n }}\r\n >\r\n {/* Header: Logo + Status */}\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"flex-start\",\r\n justifyContent: \"space-between\",\r\n gap: \"12px\",\r\n }}\r\n >\r\n {/* Logo/Icon */}\r\n <div\r\n style={{\r\n width: \"48px\",\r\n height: \"48px\",\r\n borderRadius: \"6px\",\r\n background: `${railColor}08`,\r\n border: `1px solid ${railColor}18`,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n flexShrink: 0,\r\n }}\r\n >\r\n {logoUrl ? (\r\n <img\r\n src={logoUrl}\r\n alt={providerName}\r\n style={{ width: \"32px\", height: \"32px\", objectFit: \"contain\" }}\r\n />\r\n ) : (\r\n <div\r\n style={{\r\n color: railColor,\r\n fontSize: \"20px\",\r\n fontWeight: 650,\r\n opacity: 0.8,\r\n }}\r\n >\r\n {icon || (providerName ? providerName.charAt(0) : \"\")}\r\n </div>\r\n )}\r\n </div>\r\n\r\n {/* Status Badge */}\r\n <div\r\n style={{\r\n display: \"inline-flex\",\r\n alignItems: \"center\",\r\n gap: \"6px\",\r\n padding: \"4px 10px\",\r\n borderRadius: \"4px\",\r\n background: config.bgColor,\r\n border: `1px solid ${config.borderColor}`,\r\n fontSize: \"11px\",\r\n fontWeight: 600,\r\n letterSpacing: \"0.01em\",\r\n color: config.color,\r\n flexShrink: 0,\r\n }}\r\n >\r\n {config.icon}\r\n {config.label}\r\n </div>\r\n </div>\r\n\r\n {/* Content */}\r\n <div style={{ flex: 1, minHeight: 0 }}>\r\n <h3\r\n style={{\r\n fontSize: \"15px\",\r\n fontWeight: 650,\r\n color: \"rgba(30, 33, 37, 0.92)\",\r\n marginBottom: \"6px\",\r\n letterSpacing: \"-0.01em\",\r\n }}\r\n >\r\n {providerName}\r\n </h3>\r\n <p\r\n style={{\r\n fontSize: \"13px\",\r\n lineHeight: 1.5,\r\n color: \"rgba(30, 33, 37, 0.65)\",\r\n }}\r\n >\r\n {description}\r\n </p>\r\n </div>\r\n\r\n {/* Action Button - aligned to bottom */}\r\n {status !== \"coming-soon\" && (\r\n <button\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n onConfigure?.();\r\n }}\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n gap: \"8px\",\r\n padding: \"8px 14px\",\r\n border: \"1px solid rgba(30, 33, 37, 0.15)\",\r\n borderRadius: \"5px\",\r\n background: status === \"connected\" ? \"transparent\" : \"rgba(30, 33, 37, 0.03)\",\r\n fontSize: \"13px\",\r\n fontWeight: 600,\r\n color: \"rgba(30, 33, 37, 0.92)\",\r\n cursor: \"pointer\",\r\n transition: \"all 0.15s ease\",\r\n width: \"100%\",\r\n marginTop: \"auto\",\r\n }}\r\n className=\"hover:bg-[rgba(30,33,37,0.06)] hover:border-[rgba(30,33,37,0.20)]\"\r\n >\r\n <Settings size={14} strokeWidth={2.5} />\r\n {status === \"connected\" ? \"Configure\" : \"Connect\"}\r\n </button>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n}\r\n\r\n","\"use client\";\r\nimport React, { useState } from 'react';\r\nimport { Lock, Mail, Eye, EyeOff, ArrowRight } from 'lucide-react';\r\n\r\n// Logo asset — concentric circles + wordmark\r\nconst LOGO_URL = new URL('../../assets/chordia-logo.png', import.meta.url).href;\r\n\r\n/**\r\n * LoginForm — Chordia design system login component.\r\n *\r\n * Warm parchment aesthetic. Gold accents on focus, earth-tone CTA.\r\n * Purple is intentionally avoided — it's reserved for AI presence.\r\n *\r\n * Props:\r\n * - title: string (default: \"Chordia\") — only shown if no logo\r\n * - subtitle: string (default: \"Sign in to continue\")\r\n * - logo: ReactNode (optional — replaces the default logo image + subtitle)\r\n * - onLogin: (email, password) => Promise<void> | void\r\n * - loading: boolean\r\n * - error: string | null\r\n * - footer: ReactNode (optional — e.g. links, version info)\r\n * - showLabels: boolean (default: true)\r\n * - emailPlaceholder: string\r\n * - passwordPlaceholder: string\r\n * - onForgotPassword: () => void (optional — shows \"Forgot password?\" link)\r\n * - compact: boolean (default: false — skips the full-page centering wrapper)\r\n */\r\nexport default function LoginForm({\r\n title = 'Chordia',\r\n subtitle = 'Sign in to continue',\r\n logo,\r\n onLogin,\r\n loading = false,\r\n error = null,\r\n footer,\r\n showLabels = true,\r\n emailPlaceholder = 'you@company.com',\r\n passwordPlaceholder = 'Password',\r\n onForgotPassword,\r\n compact = false,\r\n}) {\r\n const [email, setEmail] = useState('');\r\n const [password, setPassword] = useState('');\r\n const [showPassword, setShowPassword] = useState(false);\r\n const [focused, setFocused] = useState(null);\r\n\r\n const handleSubmit = (e) => {\r\n e.preventDefault();\r\n if (!email || !password || loading) return;\r\n onLogin?.(email, password);\r\n };\r\n\r\n const canSubmit = email && password && !loading;\r\n\r\n // Warm earth accent — compliance orange, used for focus/CTA (not purple)\r\n const accentColor = 'var(--rail-compliance)';\r\n const accentRgba = '201, 138, 90'; // --rail-compliance raw\r\n\r\n const card = (\r\n <div style={{\r\n width: '100%',\r\n maxWidth: 400,\r\n background: 'var(--paper-elevated)',\r\n border: '1px solid var(--border)',\r\n borderRadius: 'var(--radius-lg)',\r\n padding: '44px 36px 36px',\r\n boxShadow: '0 8px 32px rgba(30, 33, 37, 0.06), 0 1px 3px rgba(30, 33, 37, 0.04)',\r\n position: 'relative',\r\n overflow: 'hidden',\r\n }}>\r\n {/* Decorative top rail — warm gold gradient */}\r\n <div style={{\r\n position: 'absolute',\r\n top: 0,\r\n left: 0,\r\n right: 0,\r\n height: 3,\r\n background: `linear-gradient(90deg, var(--state-unknown), ${accentColor})`,\r\n opacity: 0.6,\r\n }} />\r\n\r\n {/* Logo / Title area */}\r\n <div style={{ textAlign: 'center', marginBottom: 32 }}>\r\n {logo || (\r\n <>\r\n {/* Logo on a dark pill so the light-colored asset is visible */}\r\n <div style={{\r\n display: 'inline-flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n padding: '12px 24px',\r\n borderRadius: 'var(--radius-lg)',\r\n background: 'rgba(30, 33, 37, 0.92)',\r\n marginBottom: 16,\r\n }}>\r\n <img\r\n src={LOGO_URL}\r\n alt={title}\r\n style={{ height: 28, display: 'block' }}\r\n />\r\n </div>\r\n {subtitle && (\r\n <p style={{\r\n fontSize: 'var(--text-sm)',\r\n color: 'var(--text-muted)',\r\n marginTop: 4,\r\n marginBottom: 0,\r\n }}>{subtitle}</p>\r\n )}\r\n </>\r\n )}\r\n </div>\r\n\r\n <form onSubmit={handleSubmit}>\r\n {/* Email field */}\r\n <div style={{ marginBottom: 18 }}>\r\n {showLabels && (\r\n <label style={{\r\n display: 'block',\r\n fontSize: 'var(--text-sm)',\r\n fontWeight: 550,\r\n color: 'var(--text-strong)',\r\n marginBottom: 6,\r\n fontFamily: 'var(--font-sans)',\r\n }}>Email</label>\r\n )}\r\n <div style={{ position: 'relative', display: 'flex', alignItems: 'center' }}>\r\n <Mail size={15} style={{\r\n position: 'absolute',\r\n left: 12,\r\n color: focused === 'email' ? `rgba(${accentRgba}, 0.7)` : 'var(--text-faint)',\r\n pointerEvents: 'none',\r\n transition: 'color 0.2s ease',\r\n }} />\r\n <input\r\n type=\"email\"\r\n value={email}\r\n onChange={(e) => setEmail(e.target.value)}\r\n placeholder={emailPlaceholder}\r\n required\r\n autoFocus\r\n autoComplete=\"email\"\r\n style={{\r\n width: '100%',\r\n padding: '11px 12px 11px 38px',\r\n fontSize: 'var(--text-md)',\r\n border: '1px solid',\r\n borderColor: focused === 'email' ? accentColor : 'var(--border)',\r\n borderRadius: 'var(--radius)',\r\n backgroundColor: focused === 'email' ? 'rgba(255,255,255,0.95)' : 'var(--paper)',\r\n color: 'var(--text-ink)',\r\n fontFamily: 'var(--font-sans)',\r\n outline: 'none',\r\n transition: 'border-color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease',\r\n boxShadow: focused === 'email' ? `0 0 0 3px rgba(${accentRgba}, 0.1)` : 'none',\r\n }}\r\n onFocus={() => setFocused('email')}\r\n onBlur={() => setFocused(null)}\r\n />\r\n </div>\r\n </div>\r\n\r\n {/* Password field */}\r\n <div style={{ marginBottom: 6 }}>\r\n {showLabels && (\r\n <label style={{\r\n display: 'block',\r\n fontSize: 'var(--text-sm)',\r\n fontWeight: 550,\r\n color: 'var(--text-strong)',\r\n marginBottom: 6,\r\n fontFamily: 'var(--font-sans)',\r\n }}>Password</label>\r\n )}\r\n <div style={{ position: 'relative', display: 'flex', alignItems: 'center' }}>\r\n <Lock size={15} style={{\r\n position: 'absolute',\r\n left: 12,\r\n color: focused === 'password' ? `rgba(${accentRgba}, 0.7)` : 'var(--text-faint)',\r\n pointerEvents: 'none',\r\n transition: 'color 0.2s ease',\r\n }} />\r\n <input\r\n type={showPassword ? 'text' : 'password'}\r\n value={password}\r\n onChange={(e) => setPassword(e.target.value)}\r\n placeholder={passwordPlaceholder}\r\n required\r\n autoComplete=\"current-password\"\r\n style={{\r\n width: '100%',\r\n padding: '11px 42px 11px 38px',\r\n fontSize: 'var(--text-md)',\r\n border: '1px solid',\r\n borderColor: focused === 'password' ? accentColor : 'var(--border)',\r\n borderRadius: 'var(--radius)',\r\n backgroundColor: focused === 'password' ? 'rgba(255,255,255,0.95)' : 'var(--paper)',\r\n color: 'var(--text-ink)',\r\n fontFamily: 'var(--font-sans)',\r\n outline: 'none',\r\n transition: 'border-color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease',\r\n boxShadow: focused === 'password' ? `0 0 0 3px rgba(${accentRgba}, 0.1)` : 'none',\r\n }}\r\n onFocus={() => setFocused('password')}\r\n onBlur={() => setFocused(null)}\r\n />\r\n <button\r\n type=\"button\"\r\n onClick={() => setShowPassword(!showPassword)}\r\n style={{\r\n position: 'absolute',\r\n right: 8,\r\n background: 'none',\r\n border: 'none',\r\n padding: 4,\r\n cursor: 'pointer',\r\n color: 'var(--text-faint)',\r\n display: 'flex',\r\n alignItems: 'center',\r\n transition: 'color 0.15s ease',\r\n borderRadius: 'var(--radius-sm)',\r\n }}\r\n tabIndex={-1}\r\n onMouseEnter={(e) => { e.currentTarget.style.color = 'var(--text-muted)'; }}\r\n onMouseLeave={(e) => { e.currentTarget.style.color = 'var(--text-faint)'; }}\r\n >\r\n {showPassword ? <EyeOff size={16} /> : <Eye size={16} />}\r\n </button>\r\n </div>\r\n </div>\r\n\r\n {/* Forgot password link */}\r\n {onForgotPassword && (\r\n <div style={{ textAlign: 'right', marginBottom: 4 }}>\r\n <button\r\n type=\"button\"\r\n onClick={onForgotPassword}\r\n style={{\r\n background: 'none',\r\n border: 'none',\r\n padding: '2px 0',\r\n fontSize: 'var(--text-xs)',\r\n color: 'var(--text-muted)',\r\n cursor: 'pointer',\r\n fontFamily: 'var(--font-sans)',\r\n transition: 'color 0.15s ease',\r\n }}\r\n onMouseEnter={(e) => { e.currentTarget.style.color = 'var(--text-strong)'; }}\r\n onMouseLeave={(e) => { e.currentTarget.style.color = 'var(--text-muted)'; }}\r\n >\r\n Forgot password?\r\n </button>\r\n </div>\r\n )}\r\n\r\n {/* Error message — gold warning tint, no red */}\r\n {error && (\r\n <div style={{\r\n fontSize: 'var(--text-sm)',\r\n color: 'var(--text-strong)',\r\n marginTop: 12,\r\n padding: '8px 12px',\r\n background: 'color-mix(in srgb, var(--state-unknown) 10%, transparent)',\r\n border: '1px solid color-mix(in srgb, var(--state-unknown) 25%, transparent)',\r\n borderRadius: 'var(--radius-sm)',\r\n textAlign: 'center',\r\n fontWeight: 500,\r\n }}>{error}</div>\r\n )}\r\n\r\n {/* Submit button — dark ink, warm and authoritative */}\r\n <button\r\n type=\"submit\"\r\n disabled={!canSubmit}\r\n style={{\r\n width: '100%',\r\n padding: '11px 0',\r\n marginTop: 20,\r\n background: canSubmit ? 'var(--text-ink)' : 'var(--text-xfaint)',\r\n color: '#ffffff',\r\n border: 'none',\r\n borderRadius: 'var(--radius)',\r\n fontSize: 'var(--text-md)',\r\n fontWeight: 600,\r\n fontFamily: 'var(--font-sans)',\r\n cursor: canSubmit ? 'pointer' : 'not-allowed',\r\n transition: 'opacity 0.15s ease, transform 0.1s ease',\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n gap: 8,\r\n }}\r\n onMouseEnter={(e) => {\r\n if (canSubmit) {\r\n e.currentTarget.style.opacity = '0.85';\r\n e.currentTarget.style.transform = 'translateY(-1px)';\r\n }\r\n }}\r\n onMouseLeave={(e) => {\r\n e.currentTarget.style.opacity = '1';\r\n e.currentTarget.style.transform = 'translateY(0)';\r\n }}\r\n onMouseDown={(e) => {\r\n if (canSubmit) e.currentTarget.style.transform = 'translateY(0)';\r\n }}\r\n onMouseUp={(e) => {\r\n if (canSubmit) e.currentTarget.style.transform = 'translateY(-1px)';\r\n }}\r\n >\r\n {loading ? 'Signing in…' : (\r\n <>\r\n Sign In\r\n <ArrowRight size={16} />\r\n </>\r\n )}\r\n </button>\r\n </form>\r\n\r\n {/* Divider + Footer */}\r\n {footer && (\r\n <>\r\n <div style={{\r\n display: 'flex',\r\n alignItems: 'center',\r\n gap: 12,\r\n margin: '24px 0 16px',\r\n }}>\r\n <div style={{ flex: 1, height: 1, background: 'var(--border)' }} />\r\n <span style={{ fontSize: 'var(--text-xs)', color: 'var(--text-faint)' }}>or</span>\r\n <div style={{ flex: 1, height: 1, background: 'var(--border)' }} />\r\n </div>\r\n <div style={{\r\n textAlign: 'center',\r\n fontSize: 'var(--text-xs)',\r\n color: 'var(--text-faint)',\r\n }}>{footer}</div>\r\n </>\r\n )}\r\n </div>\r\n );\r\n\r\n if (compact) return card;\r\n\r\n return (\r\n <div style={{\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n minHeight: '100vh',\r\n background: 'var(--bg-chordia)',\r\n padding: 'var(--spacing-6)',\r\n }}>\r\n {card}\r\n </div>\r\n );\r\n}\r\n","\"use client\";\r\n\r\nimport React from \"react\";\r\nimport { X, Sparkles, AlertCircle, Wrench, Info } from \"lucide-react\";\r\n\r\n/**\r\n * NotificationItem Component\r\n * Displays a single notification item with type, title, message, timestamp, and actions.\r\n * \r\n * @param {Object} props - Component props\r\n * @param {string} props.type - Notification type: 'feature', 'issue', 'maintenance', or 'announcement'\r\n * @param {string} props.title - Notification title\r\n * @param {string} props.message - Notification message\r\n * @param {string} props.timestamp - Timestamp string\r\n * @param {boolean} props.isRead - Whether the notification is read\r\n * @param {Function} props.onDismiss - Callback when dismiss button is clicked\r\n * @param {Function} props.onClick - Callback when notification is clicked\r\n */\r\nconst notificationConfig = {\r\n feature: {\r\n railColor: \"#7B68A6\",\r\n icon: <Sparkles size={16} strokeWidth={2.5} />,\r\n label: \"New Feature\",\r\n },\r\n issue: {\r\n railColor: \"#C98A5A\",\r\n icon: <AlertCircle size={16} strokeWidth={2.5} />,\r\n label: \"Known Issue\",\r\n },\r\n maintenance: {\r\n railColor: \"#8B9D6F\",\r\n icon: <Wrench size={16} strokeWidth={2.5} />,\r\n label: \"Maintenance\",\r\n },\r\n announcement: {\r\n railColor: \"#6B7C93\",\r\n icon: <Info size={16} strokeWidth={2.5} />,\r\n label: \"Announcement\",\r\n },\r\n};\r\n\r\nexport default function NotificationItem({\r\n type,\r\n title,\r\n message,\r\n timestamp,\r\n isRead = false,\r\n onDismiss,\r\n onClick,\r\n}) {\r\n const config = notificationConfig[type] || notificationConfig.announcement;\r\n\r\n return (\r\n <div\r\n onClick={onClick}\r\n style={{\r\n position: \"relative\",\r\n background: isRead ? \"#FFFFFF\" : \"rgba(244, 241, 230, 0.4)\",\r\n border: \"1px solid rgba(30, 33, 37, 0.10)\",\r\n borderRadius: \"6px\",\r\n padding: \"12px 16px\",\r\n paddingLeft: \"20px\",\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n gap: \"6px\",\r\n cursor: onClick ? \"pointer\" : \"default\",\r\n transition: \"all 0.15s ease\",\r\n overflow: \"hidden\",\r\n }}\r\n className={onClick ? \"hover:border-[rgba(30,33,37,0.18)]\" : \"\"}\r\n >\r\n {/* Rail */}\r\n <div\r\n style={{\r\n position: \"absolute\",\r\n left: 0,\r\n top: 0,\r\n bottom: 0,\r\n width: \"4px\",\r\n background: config.railColor,\r\n }}\r\n />\r\n\r\n {/* Line 1: Title + Type badge + Timestamp + Dismiss */}\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"space-between\",\r\n gap: \"12px\",\r\n }}\r\n >\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"8px\",\r\n flex: 1,\r\n minWidth: 0,\r\n }}\r\n >\r\n {/* Title */}\r\n <h4\r\n style={{\r\n fontSize: \"13px\",\r\n fontWeight: 650,\r\n color: \"rgba(30, 33, 37, 0.92)\",\r\n letterSpacing: \"-0.01em\",\r\n flex: 1,\r\n minWidth: 0,\r\n overflow: \"hidden\",\r\n textOverflow: \"ellipsis\",\r\n whiteSpace: \"nowrap\",\r\n }}\r\n title={title}\r\n aria-label={title}\r\n >\r\n {title}\r\n </h4>\r\n {/* Type Badge */}\r\n <div\r\n style={{\r\n display: \"inline-flex\",\r\n alignItems: \"center\",\r\n gap: \"4px\",\r\n padding: \"2px 6px\",\r\n borderRadius: \"3px\",\r\n background: `${config.railColor}10`,\r\n border: `1px solid ${config.railColor}25`,\r\n fontSize: \"10px\",\r\n fontWeight: 600,\r\n letterSpacing: \"0.01em\",\r\n color: config.railColor,\r\n flexShrink: 0,\r\n }}\r\n >\r\n {config.icon}\r\n <span style={{ whiteSpace: \"nowrap\" }}>{config.label}</span>\r\n </div>\r\n </div>\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"8px\",\r\n flexShrink: 0,\r\n }}\r\n >\r\n {/* Timestamp with colored dot (only for unread) */}\r\n <div\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"6px\",\r\n }}\r\n >\r\n {!isRead && (\r\n <div\r\n style={{\r\n width: \"5px\",\r\n height: \"5px\",\r\n borderRadius: \"50%\",\r\n background: config.railColor,\r\n flexShrink: 0,\r\n }}\r\n />\r\n )}\r\n <span\r\n style={{\r\n fontSize: \"11px\",\r\n color: \"rgba(30, 33, 37, 0.52)\",\r\n fontWeight: 500,\r\n whiteSpace: \"nowrap\",\r\n }}\r\n >\r\n {timestamp}\r\n </span>\r\n </div>\r\n {/* Dismiss button */}\r\n {onDismiss && (\r\n <button\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n onDismiss();\r\n }}\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n padding: \"4px\",\r\n border: \"none\",\r\n background: \"transparent\",\r\n cursor: \"pointer\",\r\n color: \"rgba(30, 33, 37, 0.35)\",\r\n transition: \"color 0.15s ease\",\r\n borderRadius: \"3px\",\r\n }}\r\n className=\"hover:bg-[rgba(30,33,37,0.05)] hover:text-[rgba(30,33,37,0.65)]\"\r\n >\r\n <X size={14} strokeWidth={2.5} />\r\n </button>\r\n )}\r\n </div>\r\n </div>\r\n\r\n {/* Line 2: Message */}\r\n <p\r\n style={{\r\n fontSize: \"12px\",\r\n lineHeight: 1.45,\r\n color: \"rgba(30, 33, 37, 0.65)\",\r\n margin: 0,\r\n }}\r\n >\r\n {message}\r\n </p>\r\n </div>\r\n );\r\n}\r\n","\"use client\";\r\n\r\nimport React from \"react\";\r\nimport { Bell, Check } from \"lucide-react\";\r\nimport NotificationItem from \"./NotificationItem\";\r\n\r\n/**\r\n * NotificationPanel Component\r\n * Displays a panel of notifications with header, list, and actions.\r\n * \r\n * @param {Object} props - Component props\r\n * @param {Array} props.notifications - Array of notification objects\r\n * @param {string} props.notifications[].id - Notification ID\r\n * @param {string} props.notifications[].type - Notification type: 'feature', 'issue', 'maintenance', or 'announcement'\r\n * @param {string} props.notifications[].title - Notification title\r\n * @param {string} props.notifications[].message - Notification message\r\n * @param {string} props.notifications[].timestamp - Timestamp string\r\n * @param {boolean} props.notifications[].isRead - Whether the notification is read\r\n * @param {Function} props.onDismiss - Callback when dismiss button is clicked (receives id)\r\n * @param {Function} props.onMarkAllRead - Callback when mark all read button is clicked\r\n * @param {Function} props.onNotificationClick - Callback when notification is clicked (receives id)\r\n */\r\nexport default function NotificationPanel({\r\n notifications,\r\n onDismiss,\r\n onMarkAllRead,\r\n onNotificationClick,\r\n}) {\r\n const unreadCount = notifications.filter((n) => !n.isRead).length;\r\n\r\n return (\r\n <div\r\n style={{\r\n background: \"#FFFFFF\",\r\n border: \"1px solid rgba(30, 33, 37, 0.12)\",\r\n borderRadius: \"12px\",\r\n width: \"100%\",\r\n maxWidth: \"560px\",\r\n boxShadow: \"0 6px 24px rgba(0, 0, 0, 0.08)\",\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n maxHeight: \"600px\",\r\n overflow: \"hidden\",\r\n }}\r\n >\r\n {/* Header */}\r\n <div\r\n style={{\r\n padding: \"16px 20px\",\r\n borderBottom: \"1px solid rgba(30, 33, 37, 0.10)\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"space-between\",\r\n flexShrink: 0,\r\n background: \"#FFFFFF\",\r\n }}\r\n >\r\n <div style={{ display: \"flex\", alignItems: \"center\", gap: \"10px\" }}>\r\n <Bell size={18} strokeWidth={2.5} style={{ color: \"rgba(30, 33, 37, 0.65)\" }} />\r\n <h3\r\n style={{\r\n fontSize: \"15px\",\r\n fontWeight: 650,\r\n color: \"rgba(30, 33, 37, 0.92)\",\r\n letterSpacing: \"-0.01em\",\r\n }}\r\n >\r\n Notifications\r\n </h3>\r\n {unreadCount > 0 && (\r\n <div\r\n style={{\r\n padding: \"2px 8px\",\r\n borderRadius: \"12px\",\r\n background: \"rgba(107, 124, 147, 0.12)\",\r\n fontSize: \"11px\",\r\n fontWeight: 650,\r\n color: \"#6B7C93\",\r\n }}\r\n >\r\n {unreadCount}\r\n </div>\r\n )}\r\n </div>\r\n {unreadCount > 0 && onMarkAllRead && (\r\n <button\r\n onClick={onMarkAllRead}\r\n style={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n gap: \"8px\",\r\n padding: \"8px 12px\",\r\n border: \"1px solid rgba(30, 33, 37, 0.15)\",\r\n borderRadius: \"6px\",\r\n background: \"transparent\",\r\n fontSize: \"13px\",\r\n fontWeight: 600,\r\n color: \"rgba(30, 33, 37, 0.65)\",\r\n cursor: \"pointer\",\r\n transition: \"all 0.15s ease\",\r\n }}\r\n className=\"interactive hover:bg-warm hover:border-hover\"\r\n >\r\n <Check size={14} strokeWidth={2.5} />\r\n Mark all read\r\n </button>\r\n )}\r\n </div>\r\n\r\n {/* Notifications list */}\r\n <div\r\n style={{\r\n padding: \"16px\",\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n gap: \"12px\",\r\n overflowY: \"auto\",\r\n flex: 1,\r\n }}\r\n className=\"custom-thin-scrollbar\"\r\n >\r\n {notifications.length === 0 ? (\r\n <div\r\n style={{\r\n padding: \"40px 20px\",\r\n textAlign: \"center\",\r\n color: \"rgba(30, 33, 37, 0.42)\",\r\n }}\r\n >\r\n <Bell size={32} strokeWidth={1.5} style={{ margin: \"0 auto 12px\", opacity: 0.3 }} />\r\n <p style={{ fontSize: \"13px\", fontWeight: 500 }}>No notifications</p>\r\n </div>\r\n ) : (\r\n notifications.map((notification) => (\r\n <NotificationItem\r\n key={notification.id}\r\n type={notification.type}\r\n title={notification.title}\r\n message={notification.message}\r\n timestamp={notification.timestamp}\r\n isRead={notification.isRead}\r\n onDismiss={onDismiss ? () => onDismiss(notification.id) : undefined}\r\n onClick={onNotificationClick ? () => onNotificationClick(notification.id) : undefined}\r\n />\r\n ))\r\n )}\r\n </div>\r\n </div>\r\n );\r\n}\r\n\r\n"],"names":["ColorPalette","colors","groupedColors","acc","color","jsx","category","categoryColors","i","jsxs","Tabs","tabs","active","onSelect","size","isCompact","tab","isActive","e","Badge","children","icon","props","computedStyle","Checkbox","checked","onChange","label","disabled","style","boxSize","checkSize","Check","baseStyle","TextInput","value","placeholder","mono","autoFocus","rest","TextArea","rows","resize","Select","options","opt","FormLabel","htmlFor","InlineConfirm","onConfirm","prompt","confirmLabel","cancelLabel","confirming","setConfirming","useState","SmallButton","useCombinedRefs","_len","refs","_key","useMemo","node","ref","canUseDOM","isWindow","element","elementString","isNode","getWindow","target","_target$ownerDocument","_target$ownerDocument2","isDocument","Document","isHTMLElement","isSVGElement","getOwnerDocument","useIsomorphicLayoutEffect","useLayoutEffect","useEffect","useEvent","handler","handlerRef","useRef","useCallback","args","useInterval","intervalRef","set","listener","duration","clear","useLatestValue","dependencies","valueRef","useLazyMemo","callback","newValue","useNodeRef","onChangeHandler","setNodeRef","usePrevious","ids","useUniqueId","prefix","id","createAdjustmentFn","modifier","object","adjustments","accumulator","adjustment","entries","key","valueAdjustment","add","subtract","hasViewportRelativeCoordinates","event","isKeyboardEvent","KeyboardEvent","isTouchEvent","TouchEvent","getEventCoordinates","x","y","CSS","transform","scaleX","scaleY","_ref","property","easing","SELECTOR","findFirstFocusableNode","hiddenStyles","HiddenText","React","LiveRegion","announcement","ariaLiveType","visuallyHidden","useAnnouncement","setAnnouncement","DndMonitorContext","createContext","useDndMonitor","registerListener","useContext","useDndMonitorProvider","listeners","type","_listener$type","defaultScreenReaderInstructions","defaultAnnouncements","_ref2","over","_ref3","_ref4","Accessibility","announcements","container","hiddenTextDescribedById","screenReaderInstructions","announce","liveRegionId","mounted","setMounted","_ref5","_ref6","markup","createPortal","Action","noop","useSensor","sensor","useSensors","sensors","defaultCoordinates","distanceBetween","p1","p2","getRelativeTransformOrigin","rect","eventCoordinates","transformOrigin","sortCollisionsAsc","a","b","sortCollisionsDesc","cornersOfRectangle","left","top","height","width","getFirstCollision","collisions","firstCollision","centerOfRectangle","closestCenter","collisionRect","droppableRects","droppableContainers","centerRect","droppableContainer","distBetween","closestCorners","corners","rectCorners","distances","corner","index","effectiveDistance","getIntersectionRatio","entry","right","bottom","targetArea","entryArea","intersectionArea","intersectionRatio","rectIntersection","adjustScale","rect1","rect2","getRectDelta","createRectAdjustmentFn","getAdjustedRect","parseTransform","transformArray","inverseTransform","parsedTransform","translateX","translateY","w","h","defaultOptions","getClientRect","getTransformAgnosticClientRect","getWindowClientRect","isFixed","isScrollable","overflowRegex","getScrollableAncestors","limit","scrollParents","findScrollableAncestors","getFirstScrollableAncestor","firstScrollableAncestor","getScrollableElement","getScrollXCoordinate","getScrollYCoordinate","getScrollCoordinates","Direction","isDocumentScrollingElement","getScrollPosition","scrollingContainer","minScroll","dimensions","maxScroll","isTop","isLeft","isBottom","isRight","defaultThreshold","getScrollDirectionAndSpeed","scrollContainer","scrollContainerRect","acceleration","thresholdPercentage","direction","speed","threshold","getScrollElementRect","innerWidth","innerHeight","getScrollOffsets","scrollableAncestors","getScrollXOffset","getScrollYOffset","scrollIntoViewIfNeeded","measure","properties","Rect","scrollOffsets","axis","keys","getScrollOffset","currentOffsets","scrollOffsetsDeltla","Listeners","_this$target","eventName","_this$target2","getEventListenerTarget","EventTarget","hasExceededDistance","delta","measurement","dx","dy","EventName","preventDefault","stopPropagation","KeyboardCode","defaultKeyboardCodes","defaultKeyboardCoordinateGetter","currentCoordinates","KeyboardSensor","activeNode","onStart","context","keyboardCodes","coordinateGetter","scrollBehavior","code","newCoordinates","coordinatesDelta","scrollDelta","scrollElementRect","clampedCoordinates","canScrollX","canScrollY","newScrollCoordinates","canScrollToNewCoordinates","coordinates","onMove","onEnd","onCancel","onActivation","activator","isDistanceConstraint","constraint","isDelayConstraint","AbstractPointerSensor","events","listenerTarget","_getEventCoordinates","activationConstraint","bypassActivationConstraint","offset","onPending","initialCoordinates","_getEventCoordinates2","activated","onAbort","_this$document$getSel","PointerSensor","events$1","MouseButton","MouseSensor","events$2","TouchSensor","touches","AutoScrollActivator","TraversalOrder","useAutoScroller","canScroll","draggingRect","enabled","interval","order","pointerCoordinates","scrollableAncestorRects","scrollIntent","useScrollIntent","setAutoScrollInterval","clearAutoScrollInterval","scrollSpeed","scrollDirection","scrollContainerRef","autoScroll","scrollLeft","scrollTop","sortedScrollableAncestors","defaultScrollIntent","previousDelta","previousIntent","useCachedNode","draggableNodes","draggableNode","cachedNode","useCombineActivators","getSyntheticHandler","Sensor","sensorActivators","MeasuringStrategy","MeasuringFrequency","defaultValue","useDroppableMeasuring","containers","dragging","config","queue","setQueue","frequency","strategy","containersRef","isDisabled","disabledRef","measureDroppableContainers","timeoutId","previousValue","map","useInitialValue","computeFn","useInitialRect","useMutationObserver","handleMutations","mutationObserver","MutationObserver","useResizeObserver","handleResize","resizeObserver","ResizeObserver","defaultMeasure","useRect","fallbackRect","setRect","measureRect","currentRect","newRect","records","record","useRectDelta","initialRect","defaultValue$1","useScrollableAncestors","previousNode","ancestors","useScrollOffsets","elements","scrollCoordinates","setScrollCoordinates","prevElements","handleScroll","scrollingElement","previousElements","cleanup","scrollableElement","useScrollOffsetsDelta","initialScrollOffsets","hasScrollOffsets","useSensorSetup","teardownFns","teardown","useSyntheticListeners","useWindowRect","defaultValue$2","useRects","firstElement","windowRect","rects","setRects","measureRects","getMeasurableNode","firstChild","useDragOverlayMeasuring","handleNodeChange","nodeRef","setRef","defaultSensors","defaultData","defaultMeasuringConfiguration","DroppableContainersMap","_super$get","_this$get$node$curren","_this$get","defaultPublicContext","defaultInternalContext","InternalContext","PublicContext","getInitialState","reducer","state","action","RestoreFocus","activatorEvent","previousActivatorEvent","previousActiveId","activatorNode","focusableNode","applyModifiers","modifiers","useMeasuringConfiguration","useLayoutShiftScrollCompensation","initialized","rectDelta","ActiveDraggableContext","Status","DndContext","memo","_sensorContext$curren","_dragOverlay$nodeRef$","_dragOverlay$rect","_over$rect","accessibility","collisionDetection","measuring","store","useReducer","dispatch","dispatchMonitorEvent","registerMonitorListener","status","setStatus","isInitialized","activeId","translate","activeRects","_node$data","activeRef","activeSensor","setActiveSensor","setActivatorEvent","latestProps","draggableDescribedById","enabledDroppableContainers","measuringConfiguration","measuringScheduled","activationCoordinates","autoScrollOptions","getAutoScrollerOptions","initialActiveNodeRect","activeNodeRect","containerNodeRect","sensorContext","overNode","dragOverlay","draggingNode","draggingNodeRect","usesDragOverlay","nodeRectDelta","modifiedTranslate","scrollAdjustment","activeNodeScrollDelta","scrollAdjustedTranslate","overId","setOver","appliedTranslate","activeSensorRef","instantiateSensor","sensorInstance","onDragAbort","onDragPending","onDragStart","unstable_batchedUpdates","createHandler","cancelDrop","bindActivatorToSensorInstantiator","nativeEvent","activeDraggableNode","activationContext","activators","onDragMove","onDragOver","overContainer","publicContext","internalContext","activeSensorDisablesAutoscroll","autoScrollGloballyDisabled","NullContext","defaultRole","ID_PREFIX","useDraggable","data","attributes","ariaDescribedById","role","roleDescription","tabIndex","isDragging","setActivatorNodeRef","dataRef","memoizedAttributes","useDndContext","ID_PREFIX$1","defaultResizeObserverConfig","useDroppable","resizeObserverConfig","previous","resizeObserverConnected","callbackId","resizeObserverDisabled","updateMeasurementsFor","resizeObserverTimeout","newElement","previousElement","AnimationManager","animation","clonedChildren","setClonedChildren","setElement","previousChildren","cloneElement","defaultTransform","NullifiedContextProvider","baseStyles","defaultTransition","PositionedOverlay","forwardRef","as","className","transition","scaleAdjustedTransform","styles","defaultDropAnimationSideEffects","originalStyles","defaultKeyframeResolver","initial","final","defaultDropAnimationConfiguration","useDropAnimation","activeDraggable","measurableNode","createDefaultDropAnimation","sideEffects","keyframes","scale","finalTransform","animationKeyframes","firstKeyframe","lastKeyframe","resolve","useKey","DragOverlay","dropAnimationConfig","wrapperElement","zIndex","modifiedTransform","dropAnimation","arrayMove","array","from","to","newArray","getSortedRects","items","isValidIndex","itemsEqual","normalizeDisabled","defaultScale","horizontalListSortingStrategy","_rects$activeIndex","fallbackActiveRect","activeIndex","overIndex","itemGap","getItemGap","newIndexRect","previousRect","nextRect","rectSortingStrategy","newRects","oldRect","Context","SortableContext","userDefinedItems","disabledProp","containerId","useDragOverlay","item","previousItemsRef","itemsHaveChanged","disableTransforms","contextValue","defaultNewIndexGetter","defaultAnimateLayoutChanges","isSorting","wasDragging","newIndex","previousItems","previousContainerId","transitionProperty","disabledTransition","defaultAttributes","useDerivedTransform","derivedTransform","setDerivedtransform","previousIndex","current","useSortable","animateLayoutChanges","userDefinedAttributes","localDisabled","customData","getNewIndex","localStrategy","globalDisabled","sortedRects","globalStrategy","normalizeLocalDisabled","itemsAfterCurrentSortable","isOver","setDroppableNodeRef","setDraggableNodeRef","displaceItem","shouldDisplaceDragSource","dragSourceDisplacement","shouldAnimateLayoutChanges","getTransition","_localDisabled$dragga","_localDisabled$droppa","hasSortableData","directions","sortableKeyboardCoordinates","filteredContainers","closestId","activeDroppable","newDroppable","newNode","hasDifferentScrollAncestors","hasSameContainer","isSameContainer","isAfterActive","isAfter","rectCoordinates","CustomFilterChips","DataTableFilters","dateRangePicker","onWeekToDate","exportConfig","filterChipsConfig","trailingActions","showExportMenu","setShowExportMenu","exportButtonRef","exportMenuRef","handleClickOutside","openExportMenu","prev","handleExport","shouldShowChips","filters","customFilters","hasRegularFilters","hasCustomFilters","filterObj","CalendarClock","Suspense","Download","ChevronDown","Fragment","toast","Pagination","OpenCloseArrow","isOpen","iconSize","Separator","useUserContext","Image","HoverBalloon","DataTable","columns","initialPageSize","onRowClick","totalCount","controlledPage","controlledPageSize","onPageChange","onPageSizeChange","onFilterChange","onSort","sortFields","tableId","isLoading","filtersConfig","userData","userId","TruncatedCell","content","textRef","isTruncated","setIsTruncated","checkTruncation","isOverflowing","textElement","isServerSidePagination","isServerSideFiltering","isServerSideSorting","internalPage","setInternalPage","internalPageSize","setInternalPageSize","page","pageSize","setPage","newPage","setPageSize","newSize","MAX_COLUMNS","userHasManuallyChangedColumns","storageKey","col","manualChangeFlagKey","cols","saved","validColumns","colId","error","setFilters","internalSortField","setInternalSortField","internalSortDirection","setInternalSortDirection","sortFieldFromProps","columnId","sortField","sortDirection","columnOrder","setColumnOrder","visibleColumns","setVisibleColumns","savedColumns","isColumnDropdownOpen","setIsColumnDropdownOpen","columnDropdownPosition","setColumnDropdownPosition","pendingSelection","setPendingSelection","pendingDeselection","setPendingDeselection","draggedColumnIndex","setDraggedColumnIndex","dragOverColumnIndex","setDragOverColumnIndex","columnDropdownRef","columnDropdownMenuRef","toastTimeoutRef","setActiveId","tableRef","getColumnId","handleDragEnd","oldIndex","reordered","saveColumnsToStorage","handleDragStart","filteredData","row","filterValue","cellValue","cellValueStr","k","keyword","sortedData","aVal","bVal","aStr","bStr","paginatedData","startIndex","endIndex","handleSort","field","handleFilterChange","newFilters","showToastOnce","message","toggleColumnSelection","prevSet","updated","next","handleColumnDragStart","handleColumnDragEnd","handleColumnDragOver","handleColumnDragLeave","handleColumnDrop","dropIndex","visibleOrder","newColumns","hiddenColumns","columnIds","orderedColumns","hasFilterableColumns","updatePosition","displayText","_a","SortableHeader","column","isHeaderRow","isSorted","isAsc","isFilterable","GripVertical","ChevronUp","Filter","activeColumn","columnDropdownMenu","c","actualIndex","isDragOver","isPending","unselectedIndex","rowIndex","renderValue","hasWidthConstraint","isStringValue","shouldUseTruncatedCell","displayValue","SummaryStatsPanel","title","stats","stat","DIRECTION_COLORS","formatDuration","seconds","m","s","formatDate","dateStr","InteractionCard","agentName","customerName","date","driver","sentiment","disposition","scores","tags","railColor","onClick","resolvedRailColor","formattedDuration","formattedDate","metaItems","allTags","tag","score","MarkdownRenderer","onCodeBlockClick","onFilePathClick","copiedBlocks","setCopiedBlocks","copyToClipboard","text","blockId","newSet","err","renderCodeBlock","language","isCopied","Copy","PanelRightOpen","parseMarkdown","lines","line","codeLines","level","HeaderTag","listItems","isOrdered","match","ListTag","idx","parseInlineMarkdownWithContext","tableRows","parseCells","headerCells","isSeparator","hasSeparator","bodyStart","alignments","cellStyle","cell","ci","ri","paragraph","parseInlineMarkdown","remaining","filePathMatch","filePath","inlineCodeMatch","boldMatch","italicMatch","linkMatch","nextSpecialChar","ChatMessage","html","timestamp","toolBadges","isStreaming","isUser","badge","Wrench","ThinkingIndicator","phase","toolSteps","elapsedMs","compact","formatElapsedTime","ms","minutes","remainingSeconds","getPhaseLabel","renderToolStep","step","getStatusDot","baseDotStyle","getStatusText","renderShimmerBar","renderCursor","phaseLabel","elapsedTime","ChatInterface","initialMessages","onSendMessage","onStreamMessage","onMessagesChange","messages","setMessages","inputValue","setInputValue","isProcessing","setIsProcessing","isSending","setIsSending","currentAssistantMessage","setCurrentAssistantMessage","thinkingPhase","setThinkingPhase","thinkingStartTime","setThinkingStartTime","setElapsedMs","messagesEndRef","inputRef","streamAbortController","currentAssistantRef","lastChunkTimeRef","streamSilent","setStreamSilent","silenceSeconds","setSilenceSeconds","allMessages","gap","resetProcessingState","parseSSELine","handleStreamChunk","chunk","_b","baseMessage","processStream","stream","reader","decoder","buffer","done","parsed","handleSend","userContent","userMessage","newMessages","result","assistantMessage","resolved","handleKeyDown","Send","ChatHistoryPanel","threads","activeThreadId","onSelectThread","onNewChat","loading","searchQuery","setSearchQuery","sortedThreads","thread","q","aTime","formatTime","diffMs","diffDays","Search","MessageSquare","Pin","Clock","MessageThread","sessionTitle","currentUser","messageInput","setMessageInput","isFocused","setIsFocused","setIsLoading","displayCurrentUser","n","optimisticMessage","msg","handleKeyPress","Hash","AtSign","Paperclip","ICON_MAP","Home","FolderClosed","Users","LayoutDashboard","Clock3","Activity","Lightbulb","Bell","Plug","Settings","BarChart3","FileText","Headphones","Shield","Sliders","Workflow","resolveIcon","SquareDot","Sidebar","menuItems","onNavigate","controlledCollapsed","onToggleCollapse","header","footer","collapsedWidth","internalCollapsed","setInternalCollapsed","collapsed","toggleCollapse","expandedGroups","setExpandedGroups","hasActive","toggleGroup","currentWidth","PanelLeft","PanelLeftClose","SidebarGroup","SidebarItem","Icon","isReactIcon","expanded","onToggle","hasActiveChild","child","AVATAR_COLORS","avatarColor","name","hash","NavigationBar","logo","userName","userEmail","userInitials","userRole","onSignOut","trailing","displayName","initials","getInitials","LogOut","parts","FirstCallScreen","onUploadCall","onConnectSource","onUseSample","showExamples","hoveredCard","setHoveredCard","uploadedFile","setUploadedFile","connectedSource","setConnectedSource","selectedProject","setSelectedProject","fileInputRef","dummyDataSources","dummyProjects","handleFileUpload","file","isAudio","isVideo","handleConnectSource","sourceId","source","handleSelectProject","projectId","project","p","handleUploadClick","handleSampleClick","handleConnectClick","Upload","Sparkles","Link","option","isHovered","CheckCircle2","X","OnboardingChecklist","onDismiss","onItemClick","completedItems","isCollapsed","setIsCollapsed","hoveredItem","setHoveredItem","checklistItems","FolderOpen","BookOpen","completedCount","progressPercent","ChevronRight","Circle","DemoProjectBanner","accentColor","textColor","position","IntegrationCard","providerName","description","logoUrl","onConfigure","statusConfig","LOGO_URL","_documentCurrentScript","LoginForm","subtitle","onLogin","showLabels","emailPlaceholder","passwordPlaceholder","onForgotPassword","email","setEmail","password","setPassword","showPassword","setShowPassword","focused","setFocused","handleSubmit","canSubmit","accentRgba","card","Mail","Lock","EyeOff","Eye","ArrowRight","notificationConfig","AlertCircle","Info","NotificationItem","isRead","NotificationPanel","notifications","onMarkAllRead","onNotificationClick","unreadCount","notification"],"mappings":"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","x_google_ignoreList":[9,10,11,12]}