@houssemdi2000/design-system 1.2.0 β 1.3.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.
- package/dist/components/Accordion/Accordion.d.ts +16 -0
- package/dist/components/Accordion/Accordion.stories.d.ts +6 -0
- package/dist/components/Accordion/index.d.ts +1 -0
- package/dist/components/Avatar/Avatar.d.ts +18 -0
- package/dist/components/Avatar/Avatar.stories.d.ts +9 -0
- package/dist/components/Avatar/index.d.ts +1 -0
- package/dist/components/Button/Button.d.ts +6 -0
- package/dist/components/Button/Button.stories.d.ts +1 -0
- package/dist/components/Carousel/SmartCarousel.d.ts +17 -0
- package/dist/components/Carousel/SmartCarousel.stories.d.ts +6 -0
- package/dist/components/Carousel/index.d.ts +1 -0
- package/dist/components/Colors/Colors.d.ts +182 -0
- package/dist/components/Colors/index.d.ts +1 -0
- package/dist/components/DragDrop/DragDrop.d.ts +16 -0
- package/dist/components/DragDrop/DragDrop.stories.d.ts +7 -0
- package/dist/components/DragDrop/index.d.ts +1 -0
- package/dist/components/Footer/Footer.d.ts +21 -0
- package/dist/components/Footer/Footer.stories.d.ts +6 -0
- package/dist/components/Footer/index.d.ts +1 -0
- package/dist/components/Form/Form.d.ts +35 -0
- package/dist/components/Form/Form.stories.d.ts +6 -0
- package/dist/components/Form/index.d.ts +1 -0
- package/dist/components/Input/Input.d.ts +18 -0
- package/dist/components/Input/Input.stories.d.ts +9 -0
- package/dist/components/Input/index.d.ts +1 -0
- package/dist/components/Layout/Layout.d.ts +14 -0
- package/dist/components/Layout/Layout.stories.d.ts +7 -0
- package/dist/components/Layout/index.d.ts +1 -0
- package/dist/components/Loading/Loading.d.ts +14 -0
- package/dist/components/Loading/Loading.stories.d.ts +10 -0
- package/dist/components/Loading/index.d.ts +1 -0
- package/dist/components/Modal/Modal.d.ts +12 -0
- package/dist/components/Modal/Modal.stories.d.ts +7 -0
- package/dist/components/Modal/index.d.ts +1 -0
- package/dist/components/Navbar/Navbar.d.ts +25 -0
- package/dist/components/Navbar/Navbar.stories.d.ts +6 -0
- package/dist/components/Navbar/index.d.ts +1 -0
- package/dist/components/Pagination/Pagination.d.ts +12 -0
- package/dist/components/Pagination/Pagination.stories.d.ts +8 -0
- package/dist/components/Pagination/index.d.ts +1 -0
- package/dist/components/ProfileMenu/ProfileMenu.d.ts +20 -0
- package/dist/components/ProfileMenu/ProfileMenu.stories.d.ts +6 -0
- package/dist/components/ProfileMenu/index.d.ts +1 -0
- package/dist/components/QuicklyLogin/QuicklyLogin.d.ts +17 -0
- package/dist/components/QuicklyLogin/QuicklyLogin.stories.d.ts +6 -0
- package/dist/components/SecureText/SecureText.d.ts +14 -0
- package/dist/components/SecureText/SecureText.stories.d.ts +8 -0
- package/dist/components/SecureText/index.d.ts +1 -0
- package/dist/components/Select/Select.d.ts +2 -0
- package/dist/components/Sidebar/Sidebar.d.ts +22 -0
- package/dist/components/Sidebar/Sidebar.stories.d.ts +6 -0
- package/dist/components/Sidebar/index.d.ts +1 -0
- package/dist/components/Slider/SmartSlider.d.ts +17 -0
- package/dist/components/Slider/SmartSlider.stories.d.ts +7 -0
- package/dist/components/Table/SmartTable.d.ts +23 -0
- package/dist/components/Table/SmartTable.stories.d.ts +10 -0
- package/dist/components/Table/index.d.ts +1 -0
- package/dist/components/TableFilterBar/TableFilterBar.d.ts +42 -0
- package/dist/components/TableFilterBar/TableFilterBar.stories.d.ts +7 -0
- package/dist/components/TableFilterBar/index.d.ts +1 -0
- package/dist/components/Tag/Tag.d.ts +13 -0
- package/dist/components/Tag/Tag.stories.d.ts +7 -0
- package/dist/components/Tag/index.d.ts +1 -0
- package/dist/components/Text/Text.d.ts +18 -0
- package/dist/components/Text/Text.stories.d.ts +8 -0
- package/dist/components/Text/index.d.ts +1 -0
- package/dist/components/Theme/ThemeContext.d.ts +12 -0
- package/dist/components/Theme/index.d.ts +2 -0
- package/dist/components/Theme/types.d.ts +7 -0
- package/dist/components/TimeLine/SmartTimeLine.d.ts +22 -0
- package/dist/components/TimeLine/SmartTimeLine.stories.d.ts +6 -0
- package/dist/components/TimeLine/index.d.ts +1 -0
- package/dist/components/Toast/ToastContext.d.ts +2 -1
- package/dist/components/index.d.ts +18 -0
- package/dist/index.esm.js +513 -43
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +534 -45
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../node_modules/style-inject/dist/style-inject.es.js","../src/components/Button/Button.tsx","../src/components/Center/Center.tsx","../src/components/Card/Card.tsx","../src/components/Bloc/Bloc.tsx","../src/components/Container/Container.tsx","../src/components/Row/Row.tsx","../src/components/Column/Column.tsx","../src/components/Grid/Grid.tsx","../src/components/Spacer/Spacer.tsx","../src/components/Divider/Divider.tsx","../src/components/Checkbox/Checkbox.tsx","../src/components/TextField/TextField.tsx","../src/components/Radio/Radio.tsx","../src/components/Select/Select.tsx","../src/components/Toast/ToastContext.tsx"],"sourcesContent":["function styleInject(css, ref) {\n if ( ref === void 0 ) ref = {};\n var insertAt = ref.insertAt;\n\n if (!css || typeof document === 'undefined') { return; }\n\n var head = document.head || document.getElementsByTagName('head')[0];\n var style = document.createElement('style');\n style.type = 'text/css';\n\n if (insertAt === 'top') {\n if (head.firstChild) {\n head.insertBefore(style, head.firstChild);\n } else {\n head.appendChild(style);\n }\n } else {\n head.appendChild(style);\n }\n\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n}\n\nexport default styleInject;\n","import \"./Button.css\";\r\nimport React from \"react\";\r\n\r\n\r\nexport interface ButtonProps {\r\n label: string;\r\n onClick?: () => void;\r\n variant?: \"primary\" | \"secondary\" | \"danger\" | \"dark\" | \"light\";\r\n size?: \"small\" | \"medium\" | \"large\";\r\n disabled?: boolean;\r\n icon?: React.ReactNode;\r\n iconPosition?: \"left\" | \"right\";\r\n backgroundColor?: string;\r\n color?: string;\r\n isLoading?: boolean;\r\n}\r\n\r\nexport const Button: React.FC<ButtonProps> = ({\r\n label,\r\n onClick,\r\n variant = \"primary\",\r\n size = \"medium\",\r\n disabled = false,\r\n icon,\r\n iconPosition = \"left\",\r\n backgroundColor,\r\n color,\r\n isLoading = false,\r\n}) => {\r\n return (\r\n <>\r\n <button\r\n className={`btn btn-${variant} btn-${size}`}\r\n onClick={onClick}\r\n disabled={disabled || isLoading}\r\n style={{ backgroundColor, color }}\r\n >\r\n {icon && iconPosition === \"left\" && <span className=\"btn-left-icon\">{icon}</span>}\r\n {label}\r\n {icon && iconPosition === \"right\" && <span className=\"btn-right-icon\">{icon}</span>}\r\n {isLoading && <span className=\"btn-spinner\"></span>}\r\n </button>\r\n </>\r\n );\r\n};\r\n","import \"./Center.css\"\r\n\r\nexport interface CenterProps {\r\n children: React.ReactNode;\r\n backgroundColor?: string;\r\n color?: string;\r\n}\r\n\r\nexport const Center: React.FC<CenterProps> = ({ children, backgroundColor = 'white', color = 'black' }) => {\r\n return <div className=\"center\" style={{ backgroundColor, color}}>{children}</div>;\r\n};\r\n","import React from \"react\";\r\nimport \"./Card.css\";\r\n\r\nexport interface CardProps {\r\n title?: string;\r\n children: React.ReactNode;\r\n backgroundColor?: string;\r\n color?: string;\r\n variant?: \"elevated\" | \"outlined\" | \"flat\";\r\n padding?: \"sm\" | \"md\" | \"lg\";\r\n footer?: React.ReactNode;\r\n}\r\n\r\nexport const Card: React.FC<CardProps> = ({\r\n title,\r\n children,\r\n footer,\r\n backgroundColor,\r\n color,\r\n variant = \"elevated\",\r\n padding = \"md\",\r\n}) => {\r\n return (\r\n <div\r\n className={`card card-${variant} card-padding-${padding}`}\r\n style={{ backgroundColor, color }}\r\n >\r\n {title && <div className=\"card-header\">{title}</div>}\r\n <div className=\"card-body\">{children}</div>\r\n {footer && <div className=\"card-footer\">{footer}</div>}\r\n </div>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./Bloc.css\";\r\n\r\nexport type BlocLayout =\r\n | \"default\"\r\n | \"center\"\r\n | \"row\"\r\n | \"row-between\"\r\n | \"column\"\r\n | \"sidebar\"\r\n | \"navbar\";\r\n\r\nexport interface BlocProps {\r\n children?: React.ReactNode;\r\n className?: string;\r\n style?: React.CSSProperties;\r\n layout?: BlocLayout;\r\n}\r\n\r\nexport const Bloc: React.FC<BlocProps> = ({\r\n children,\r\n className = \"\",\r\n style = {},\r\n layout = \"default\",\r\n}) => {\r\n const layoutStyles: React.CSSProperties = (() => {\r\n switch (layout) {\r\n case \"center\":\r\n return { display: \"flex\", justifyContent: \"center\", alignItems: \"center\" };\r\n case \"row\":\r\n return { display: \"flex\", flexDirection: \"row\", alignItems: \"center\" };\r\n case \"row-between\":\r\n return { display: \"flex\", flexDirection: \"row\", justifyContent: \"space-between\", alignItems: \"center\" };\r\n case \"column\":\r\n return { display: \"flex\", flexDirection: \"column\", alignItems: \"flex-start\" };\r\n case \"sidebar\":\r\n return { display: \"flex\", flexDirection: \"column\", alignItems: \"flex-start\", gap: \"12px\" };\r\n case \"navbar\":\r\n return { display: \"flex\", flexDirection: \"row\", justifyContent: \"space-between\", alignItems: \"center\", padding: \"12px 20px\" };\r\n default:\r\n return {};\r\n }\r\n })();\r\n\r\n return (\r\n <div className={`bloc ${className}`} style={{ ...layoutStyles, ...style }}>\r\n {children}\r\n </div>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./Container.css\";\r\n\r\nexport interface ContainerProps {\r\n children?: React.ReactNode;\r\n className?: string;\r\n style?: React.CSSProperties;\r\n fluid?: boolean;\r\n}\r\n\r\nexport const Container: React.FC<ContainerProps> = ({ children, className = \"\", style = {}, fluid = false }) => {\r\n return (\r\n <div className={`container ${fluid ? \"container-fluid\" : \"\"} ${className}`} style={style}>\r\n {children}\r\n </div>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./Row.css\";\r\n\r\nexport interface RowProps {\r\n children?: React.ReactNode;\r\n className?: string;\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport const Row: React.FC<RowProps> = ({\r\n children,\r\n className = \"\",\r\n style = {}\r\n}) => {\r\n return <div className={`row ${className}`} style={{...style}}>{children}</div>;\r\n};\r\n","import React from \"react\";\r\nimport \"./Column.css\";\r\n\r\nexport interface ColumnProps {\r\n children?: React.ReactNode;\r\n className?: \"small\" | \"medium\" | \"large\";\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport const Column: React.FC<ColumnProps> = ({ children, className = \"\", style = {}}) => {\r\n return (\r\n <div className={`col ${className}`} style={{...style}}>\r\n {children}\r\n </div>\r\n );\r\n};\r\n","import { Column } from \"../Column\";\r\nimport { Row } from \"../Row\";\r\n\r\nexport interface GridColumn {\r\n children?: React.ReactNode;\r\n span?: number;\r\n style?: React.CSSProperties;\r\n className?: \"small\" | \"medium\" | \"large\";\r\n}\r\n\r\nexport interface GridProps {\r\n items: GridColumn[];\r\n}\r\n\r\nexport const Grid: React.FC<GridProps> = ({ items }) => {\r\n\r\n return (\r\n <Row>\r\n {items.map((item: GridColumn, index: number) => (\r\n <Column\r\n key={index}\r\n className={item.className}\r\n style={{ ...item.style }}\r\n >\r\n {item.children}\r\n </Column>\r\n ))}\r\n </Row>\r\n );\r\n};\r\n","import React from \"react\";\r\n\r\nexport interface SpacerProps {\r\n size?: number;\r\n direction?: \"vertical\" | \"horizontal\";\r\n}\r\n\r\nexport const Spacer: React.FC<SpacerProps> = ({\r\n size = 16,\r\n direction = \"vertical\"\r\n}) => {\r\n const style: React.CSSProperties =\r\n direction === \"vertical\"\r\n ? { height: size }\r\n : { width: size, display: \"inline-block\" };\r\n\r\n return <div style={style} />;\r\n};\r\n","import React from \"react\";\r\n\r\nexport interface DividerProps {\r\n color?: string;\r\n thickness?: number;\r\n orientation?: \"horizontal\" | \"vertical\";\r\n margin?: number;\r\n}\r\n\r\nexport const Divider: React.FC<DividerProps> = ({\r\n color = \"#e0e0e0\",\r\n thickness = 1,\r\n orientation = \"horizontal\",\r\n margin = 8,\r\n}) => {\r\n const styles: React.CSSProperties =\r\n orientation === \"horizontal\"\r\n ? {\r\n width: \"100%\",\r\n height: thickness,\r\n backgroundColor: color,\r\n margin: `${margin}px 0`,\r\n }\r\n : {\r\n width: thickness,\r\n height: \"100%\",\r\n backgroundColor: color,\r\n margin: `0 ${margin}px`,\r\n };\r\n\r\n return <div style={styles} />;\r\n};\r\n","import React from \"react\";\r\nimport \"./Checkbox.css\";\r\n\r\nexport interface CheckboxProps {\r\n label?: string;\r\n checked: boolean;\r\n onChange: (value: boolean) => void;\r\n disabled?: boolean;\r\n error?: boolean;\r\n\r\n // Custom colors\r\n boxColor?: string;\r\n checkColor?: string;\r\n checkedBackground?: string;\r\n focusShadow?: string;\r\n\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport const Checkbox: React.FC<CheckboxProps> = ({\r\n label,\r\n checked,\r\n onChange,\r\n disabled = false,\r\n error = false,\r\n\r\n boxColor = \"#777\",\r\n checkColor = \"#fff\",\r\n checkedBackground = \"#007bff\",\r\n focusShadow = \"rgba(0, 123, 255, 0.4)\",\r\n\r\n style,\r\n}) => {\r\n return (\r\n <label\r\n className={`checkbox-container ${disabled ? \"disabled\" : \"\"}`}\r\n style={{\r\n [\"--cb-box-color\" as any]: boxColor,\r\n [\"--cb-check-color\" as any]: checkColor,\r\n [\"--cb-checked-bg\" as any]: checkedBackground,\r\n [\"--cb-focus-shadow\" as any]: focusShadow,\r\n }}\r\n >\r\n <input\r\n type=\"checkbox\"\r\n checked={checked}\r\n disabled={disabled}\r\n onChange={(e) => onChange(e.target.checked)}\r\n />\r\n\r\n <span className={`checkbox-box ${error ? \"error\" : \"\"}`} />\r\n\r\n {label && <span className=\"checkbox-label\">{label}</span>}\r\n </label>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./TextField.css\";\r\n\r\nexport interface TextFieldProps {\r\n label?: string;\r\n value?: string;\r\n placeholder?: string;\r\n onChange?: (value: string) => void;\r\n error?: string;\r\n disabled?: boolean;\r\n type?: string;\r\n fullWidth?: boolean;\r\n icon?: React.ReactNode;\r\n}\r\n\r\nexport const TextField: React.FC<TextFieldProps> = ({\r\n label,\r\n value = \"\",\r\n placeholder,\r\n onChange,\r\n error,\r\n disabled = false,\r\n type = \"text\",\r\n fullWidth = true,\r\n icon,\r\n}) => {\r\n return (\r\n <div className={`textfield ${fullWidth ? \"fullWidth\" : \"\"}`}>\r\n {label && <label className=\"textfield-label\">{label}</label>}\r\n\r\n <input\r\n type={type}\r\n className={`textfield-input ${error ? \"error\" : \"\"}`}\r\n value={value}\r\n placeholder={placeholder}\r\n disabled={disabled}\r\n onChange={(e) => onChange && onChange(e.target.value)}\r\n />\r\n {icon && <div className=\"textfield-icon\">{icon}</div>}\r\n\r\n {error && <p className=\"textfield-error\">{error}</p>}\r\n </div>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./Radio.css\";\r\n\r\nexport interface RadioProps {\r\n label?: string;\r\n name: string; // obligatoire pour grouper les radios\r\n value: string;\r\n selectedValue: string;\r\n onChange: (value: string) => void;\r\n\r\n disabled?: boolean;\r\n error?: boolean;\r\n\r\n // ThΓ¨me custom\r\n borderColor?: string;\r\n dotColor?: string;\r\n checkedBorderColor?: string;\r\n checkedBackground?: string;\r\n focusShadow?: string;\r\n\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport const Radio: React.FC<RadioProps> = ({\r\n label,\r\n name,\r\n value,\r\n selectedValue,\r\n onChange,\r\n disabled = false,\r\n error = false,\r\n\r\n borderColor = \"#777\",\r\n dotColor = \"#fff\",\r\n checkedBorderColor = \"#007bff\",\r\n checkedBackground = error ? \"#d93025\" : \"#007bff\",\r\n focusShadow = \"rgba(0, 123, 255, 0.4)\",\r\n\r\n style,\r\n}) => {\r\n const checked = selectedValue === value;\r\n\r\n return (\r\n <label\r\n className={`radio-container ${disabled ? \"disabled\" : \"\"}`}\r\n style={{\r\n ...style,\r\n [\"--rd-border-color\" as any]: borderColor,\r\n [\"--rd-dot-color\" as any]: dotColor,\r\n [\"--rd-checked-border\" as any]: checkedBorderColor,\r\n [\"--rd-checked-bg\" as any]: checkedBackground,\r\n [\"--rd-focus-shadow\" as any]: focusShadow,\r\n }}\r\n >\r\n <input\r\n type=\"radio\"\r\n name={name}\r\n value={value}\r\n disabled={disabled}\r\n checked={checked}\r\n onChange={() => onChange(value)}\r\n />\r\n\r\n <span className={`radio-circle ${error ? \"error\" : \"\"}`} />\r\n\r\n {label && <span className=\"radio-label\">{label}</span>}\r\n </label>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./Select.css\";\r\n\r\nexport interface SelectOption {\r\n value: string | number;\r\n label: string;\r\n\r\n bgColor?: string;\r\n textColor?: string;\r\n}\r\n\r\nexport interface SelectProps {\r\n label?: string;\r\n value: string | number;\r\n onChange: (value: string | number) => void;\r\n options: SelectOption[];\r\n disabled?: boolean;\r\n error?: boolean;\r\n\r\n // Custom colors\r\n borderColor?: string;\r\n focusBorder?: string;\r\n focusShadow?: string;\r\n errorColor?: string;\r\n\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport const Select: React.FC<SelectProps> = ({\r\n label,\r\n value,\r\n onChange,\r\n options,\r\n disabled = false,\r\n error = false,\r\n\r\n borderColor = \"#ccc\",\r\n focusBorder = \"#007bff\",\r\n focusShadow = \"rgba(0, 123, 255, 0.4)\",\r\n errorColor = \"#e63946\",\r\n\r\n style,\r\n}) => {\r\n return (\r\n <div className=\"select-wrapper\" style={style}>\r\n {label && <label className=\"select-label\">{label}</label>}\r\n\r\n <div\r\n className={`select-container ${disabled ? \"disabled\" : \"\"} ${\r\n error ? \"error\" : \"\"\r\n }`}\r\n >\r\n <select\r\n value={value}\r\n disabled={disabled}\r\n onChange={(e) => onChange(e.target.value)}\r\n style={{\r\n [\"--sel-border\" as any]: borderColor,\r\n [\"--sel-focus-border\" as any]: focusBorder,\r\n [\"--sel-focus-shadow\" as any]: focusShadow,\r\n [\"--sel-error\" as any]: errorColor,\r\n }}\r\n >\r\n {options.map((opt) => (\r\n <option\r\n key={opt.value}\r\n value={opt.value}\r\n style={{\r\n backgroundColor: opt.bgColor,\r\n color: opt.textColor,\r\n }}\r\n >\r\n {opt.label}\r\n </option>\r\n ))}\r\n </select>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","import React, { createContext, useContext, useState } from \"react\";\r\nimport \"./Toast.css\";\r\n\r\nexport type ToastVariant = \"success\" | \"error\" | \"warning\" | \"info\";\r\n\r\nexport interface Toast {\r\n id: string;\r\n message: string;\r\n variant?: ToastVariant;\r\n duration?: number;\r\n}\r\n\r\ninterface ToastContextType {\r\n addToast: (msg: string, variant?: ToastVariant, duration?: number) => void;\r\n}\r\n\r\nconst ToastContext = createContext<ToastContextType | undefined>(undefined);\r\n\r\nexport const useToast = () => {\r\n const ctx = useContext(ToastContext);\r\n if (!ctx) throw new Error(\"useToast must be used inside <ToastProvider>\");\r\n return ctx;\r\n};\r\n\r\nexport const ToastProvider: React.FC<{ children: React.ReactNode }> = ({ children }) => {\r\n const [toasts, setToasts] = useState<Toast[]>([]);\r\n\r\n function addToast(\r\n message: string,\r\n variant: ToastVariant = \"info\",\r\n duration = 3000\r\n ) {\r\n const toast: Toast = {\r\n id: Date.now().toString(),\r\n message,\r\n variant,\r\n duration,\r\n };\r\n\r\n setToasts((prev) => [...prev, toast]);\r\n\r\n // auto-remove\r\n setTimeout(() => {\r\n setToasts((prev) => prev.filter((t) => t.id !== toast.id));\r\n }, duration);\r\n }\r\n\r\n return (\r\n <ToastContext.Provider value={{ addToast }}>\r\n {children}\r\n\r\n {/* Toast container */}\r\n <div className=\"toast-container\">\r\n {toasts.map((t) => (\r\n <div key={t.id} className={`toast toast-${t.variant}`}>\r\n <span>{t.message}</span>\r\n <button className=\"toast-close\" onClick={() =>\r\n setToasts((prev) => prev.filter((x) => x.id !== t.id))\r\n }>\r\n β\r\n </button>\r\n </div>\r\n ))}\r\n </div>\r\n </ToastContext.Provider>\r\n );\r\n};\r\n"],"names":["_jsx","_Fragment","_jsxs","createContext","useContext","useState"],"mappings":"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","x_google_ignoreList":[0]}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../node_modules/style-inject/dist/style-inject.es.js","../src/components/Button/Button.tsx","../src/components/Center/Center.tsx","../src/components/Card/Card.tsx","../src/components/Bloc/Bloc.tsx","../src/components/Container/Container.tsx","../src/components/Row/Row.tsx","../src/components/Column/Column.tsx","../src/components/Grid/Grid.tsx","../src/components/Spacer/Spacer.tsx","../src/components/Divider/Divider.tsx","../src/components/Checkbox/Checkbox.tsx","../src/components/TextField/TextField.tsx","../src/components/Radio/Radio.tsx","../src/components/Select/Select.tsx","../src/components/Toast/ToastContext.tsx","../src/components/Modal/Modal.tsx","../src/components/Tag/Tag.tsx","../src/components/Colors/Colors.tsx","../src/components/Theme/ThemeContext.tsx","../src/components/Table/SmartTable.tsx","../src/components/Pagination/Pagination.tsx","../src/components/TableFilterBar/TableFilterBar.tsx","../src/components/Text/Text.tsx","../src/components/TimeLine/SmartTimeLine.tsx","../src/components/Carousel/SmartCarousel.tsx","../src/components/Navbar/Navbar.tsx","../src/components/Sidebar/Sidebar.tsx","../src/components/Footer/Footer.tsx","../src/components/Layout/Layout.tsx","../src/components/DragDrop/DragDrop.tsx","../node_modules/tslib/tslib.es6.js","../src/components/SecureText/SecureText.tsx","../src/components/Loading/Loading.tsx","../src/components/Avatar/Avatar.tsx","../src/components/ProfileMenu/ProfileMenu.tsx"],"sourcesContent":["function styleInject(css, ref) {\n if ( ref === void 0 ) ref = {};\n var insertAt = ref.insertAt;\n\n if (!css || typeof document === 'undefined') { return; }\n\n var head = document.head || document.getElementsByTagName('head')[0];\n var style = document.createElement('style');\n style.type = 'text/css';\n\n if (insertAt === 'top') {\n if (head.firstChild) {\n head.insertBefore(style, head.firstChild);\n } else {\n head.appendChild(style);\n }\n } else {\n head.appendChild(style);\n }\n\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n}\n\nexport default styleInject;\n","import \"./Button.css\";\r\nimport React from \"react\";\r\n\r\n\r\nexport interface ButtonProps {\r\n label: string;\r\n onClick?: () => void;\r\n variant?: \"primary\" | \"secondary\" | \"danger\" | \"dark\" | \"light\";\r\n size?: \"small\" | \"medium\" | \"large\";\r\n style?: React.CSSProperties;\r\n disabled?: boolean;\r\n icon?: React.ReactNode;\r\n iconPosition?: \"left\" | \"right\";\r\n backgroundColor?: string;\r\n color?: string;\r\n isLoading?: boolean;\r\n type?: \"button\" | \"submit\" | \"reset\";\r\n mt?: number;\r\n mb?: number;\r\n mr?: number;\r\n ml?: number;\r\n}\r\n\r\nexport const Button: React.FC<ButtonProps> = ({\r\n label,\r\n onClick,\r\n type = \"button\",\r\n variant = \"primary\",\r\n size = \"medium\",\r\n disabled = false,\r\n icon,\r\n iconPosition = \"left\",\r\n backgroundColor,\r\n color,\r\n isLoading = false,\r\n mt,\r\n mb,\r\n mr,\r\n ml,\r\n style = {}\r\n}) => {\r\n return (\r\n <>\r\n <button\r\n className={`btn btn-${variant} btn-${size}`}\r\n onClick={onClick}\r\n type={type}\r\n disabled={disabled || isLoading}\r\n style={{ ...style, backgroundColor, color, marginTop: mt, marginBottom: mb, marginRight: mr, marginLeft: ml }}\r\n >\r\n {icon && iconPosition === \"left\" && <span className=\"btn-left-icon\">{icon}</span>}\r\n {label}\r\n {icon && iconPosition === \"right\" && <span className=\"btn-right-icon\">{icon}</span>}\r\n {isLoading && <span className=\"btn-spinner\"></span>}\r\n </button>\r\n </>\r\n );\r\n};\r\n","import \"./Center.css\"\r\n\r\nexport interface CenterProps {\r\n children: React.ReactNode;\r\n backgroundColor?: string;\r\n color?: string;\r\n}\r\n\r\nexport const Center: React.FC<CenterProps> = ({ children, backgroundColor = 'white', color = 'black' }) => {\r\n return <div className=\"center\" style={{ backgroundColor, color}}>{children}</div>;\r\n};\r\n","import React from \"react\";\r\nimport \"./Card.css\";\r\n\r\nexport interface CardProps {\r\n title?: string;\r\n children: React.ReactNode;\r\n backgroundColor?: string;\r\n color?: string;\r\n variant?: \"elevated\" | \"outlined\" | \"flat\";\r\n padding?: \"sm\" | \"md\" | \"lg\";\r\n footer?: React.ReactNode;\r\n}\r\n\r\nexport const Card: React.FC<CardProps> = ({\r\n title,\r\n children,\r\n footer,\r\n backgroundColor,\r\n color,\r\n variant = \"elevated\",\r\n padding = \"md\",\r\n}) => {\r\n return (\r\n <div\r\n className={`card card-${variant} card-padding-${padding}`}\r\n style={{ backgroundColor, color }}\r\n >\r\n {title && <div className=\"card-header\">{title}</div>}\r\n <div className=\"card-body\">{children}</div>\r\n {footer && <div className=\"card-footer\">{footer}</div>}\r\n </div>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./Bloc.css\";\r\n\r\nexport type BlocLayout =\r\n | \"default\"\r\n | \"center\"\r\n | \"row\"\r\n | \"row-between\"\r\n | \"column\"\r\n | \"sidebar\"\r\n | \"navbar\";\r\n\r\nexport interface BlocProps {\r\n children?: React.ReactNode;\r\n className?: string;\r\n style?: React.CSSProperties;\r\n layout?: BlocLayout;\r\n}\r\n\r\nexport const Bloc: React.FC<BlocProps> = ({\r\n children,\r\n className = \"\",\r\n style = {},\r\n layout = \"default\",\r\n}) => {\r\n const layoutStyles: React.CSSProperties = (() => {\r\n switch (layout) {\r\n case \"center\":\r\n return { display: \"flex\", justifyContent: \"center\", alignItems: \"center\" };\r\n case \"row\":\r\n return { display: \"flex\", flexDirection: \"row\", alignItems: \"center\" };\r\n case \"row-between\":\r\n return { display: \"flex\", flexDirection: \"row\", justifyContent: \"space-between\", alignItems: \"center\" };\r\n case \"column\":\r\n return { display: \"flex\", flexDirection: \"column\", alignItems: \"flex-start\" };\r\n case \"sidebar\":\r\n return { display: \"flex\", flexDirection: \"column\", alignItems: \"flex-start\", gap: \"12px\" };\r\n case \"navbar\":\r\n return { display: \"flex\", flexDirection: \"row\", justifyContent: \"space-between\", alignItems: \"center\", padding: \"12px 20px\" };\r\n default:\r\n return {};\r\n }\r\n })();\r\n\r\n return (\r\n <div className={`bloc ${className}`} style={{ ...layoutStyles, ...style }}>\r\n {children}\r\n </div>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./Container.css\";\r\n\r\nexport interface ContainerProps {\r\n children?: React.ReactNode;\r\n className?: string;\r\n style?: React.CSSProperties;\r\n fluid?: boolean;\r\n}\r\n\r\nexport const Container: React.FC<ContainerProps> = ({ children, className = \"\", style = {}, fluid = false }) => {\r\n return (\r\n <div className={`container ${fluid ? \"container-fluid\" : \"\"} ${className}`} style={style}>\r\n {children}\r\n </div>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./Row.css\";\r\n\r\nexport interface RowProps {\r\n children?: React.ReactNode;\r\n className?: string;\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport const Row: React.FC<RowProps> = ({\r\n children,\r\n className = \"\",\r\n style = {}\r\n}) => {\r\n return <div className={`row ${className}`} style={{...style}}>{children}</div>;\r\n};\r\n","import React from \"react\";\r\nimport \"./Column.css\";\r\n\r\nexport interface ColumnProps {\r\n children?: React.ReactNode;\r\n className?: \"small\" | \"medium\" | \"large\";\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport const Column: React.FC<ColumnProps> = ({ children, className = \"\", style = {}}) => {\r\n return (\r\n <div className={`col ${className}`} style={{...style}}>\r\n {children}\r\n </div>\r\n );\r\n};\r\n","import { Column } from \"../Column\";\r\nimport { Row } from \"../Row\";\r\n\r\nexport interface GridColumn {\r\n children?: React.ReactNode;\r\n span?: number;\r\n style?: React.CSSProperties;\r\n className?: \"small\" | \"medium\" | \"large\";\r\n}\r\n\r\nexport interface GridProps {\r\n items: GridColumn[];\r\n}\r\n\r\nexport const Grid: React.FC<GridProps> = ({ items }) => {\r\n\r\n return (\r\n <Row>\r\n {items.map((item: GridColumn, index: number) => (\r\n <Column\r\n key={index}\r\n className={item.className}\r\n style={{ ...item.style }}\r\n >\r\n {item.children}\r\n </Column>\r\n ))}\r\n </Row>\r\n );\r\n};\r\n","import React from \"react\";\r\n\r\nexport interface SpacerProps {\r\n size?: number;\r\n direction?: \"vertical\" | \"horizontal\";\r\n}\r\n\r\nexport const Spacer: React.FC<SpacerProps> = ({\r\n size = 16,\r\n direction = \"vertical\"\r\n}) => {\r\n const style: React.CSSProperties =\r\n direction === \"vertical\"\r\n ? { height: size }\r\n : { width: size, display: \"inline-block\" };\r\n\r\n return <div style={style} />;\r\n};\r\n","import React from \"react\";\r\n\r\nexport interface DividerProps {\r\n color?: string;\r\n thickness?: number;\r\n orientation?: \"horizontal\" | \"vertical\";\r\n margin?: number;\r\n}\r\n\r\nexport const Divider: React.FC<DividerProps> = ({\r\n color = \"#e0e0e0\",\r\n thickness = 1,\r\n orientation = \"horizontal\",\r\n margin = 8,\r\n}) => {\r\n const styles: React.CSSProperties =\r\n orientation === \"horizontal\"\r\n ? {\r\n width: \"100%\",\r\n height: thickness,\r\n backgroundColor: color,\r\n margin: `${margin}px 0`,\r\n }\r\n : {\r\n width: thickness,\r\n height: \"100%\",\r\n backgroundColor: color,\r\n margin: `0 ${margin}px`,\r\n };\r\n\r\n return <div style={styles} />;\r\n};\r\n","import React from \"react\";\r\nimport \"./Checkbox.css\";\r\n\r\nexport interface CheckboxProps {\r\n label?: string;\r\n checked: boolean;\r\n onChange: (value: boolean) => void;\r\n disabled?: boolean;\r\n error?: boolean;\r\n\r\n // Custom colors\r\n boxColor?: string;\r\n checkColor?: string;\r\n checkedBackground?: string;\r\n focusShadow?: string;\r\n\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport const Checkbox: React.FC<CheckboxProps> = ({\r\n label,\r\n checked,\r\n onChange,\r\n disabled = false,\r\n error = false,\r\n\r\n boxColor = \"#777\",\r\n checkColor = \"#fff\",\r\n checkedBackground = \"#007bff\",\r\n focusShadow = \"rgba(0, 123, 255, 0.4)\",\r\n\r\n style,\r\n}) => {\r\n return (\r\n <label\r\n className={`checkbox-container ${disabled ? \"disabled\" : \"\"}`}\r\n style={{\r\n [\"--cb-box-color\" as any]: boxColor,\r\n [\"--cb-check-color\" as any]: checkColor,\r\n [\"--cb-checked-bg\" as any]: checkedBackground,\r\n [\"--cb-focus-shadow\" as any]: focusShadow,\r\n }}\r\n >\r\n <input\r\n type=\"checkbox\"\r\n checked={checked}\r\n disabled={disabled}\r\n onChange={(e) => onChange(e.target.checked)}\r\n />\r\n\r\n <span className={`checkbox-box ${error ? \"error\" : \"\"}`} />\r\n\r\n {label && <span className=\"checkbox-label\">{label}</span>}\r\n </label>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./TextField.css\";\r\n\r\nexport interface TextFieldProps {\r\n label?: string;\r\n value?: string;\r\n placeholder?: string;\r\n onChange?: (value: string) => void;\r\n error?: string;\r\n disabled?: boolean;\r\n type?: string;\r\n fullWidth?: boolean;\r\n icon?: React.ReactNode;\r\n}\r\n\r\nexport const TextField: React.FC<TextFieldProps> = ({\r\n label,\r\n value = \"\",\r\n placeholder,\r\n onChange,\r\n error,\r\n disabled = false,\r\n type = \"text\",\r\n fullWidth = true,\r\n icon,\r\n}) => {\r\n return (\r\n <div className={`textfield ${fullWidth ? \"fullWidth\" : \"\"}`}>\r\n {label && <label className=\"textfield-label\">{label}</label>}\r\n\r\n <input\r\n type={type}\r\n className={`textfield-input ${error ? \"error\" : \"\"}`}\r\n value={value}\r\n placeholder={placeholder}\r\n disabled={disabled}\r\n onChange={(e) => onChange && onChange(e.target.value)}\r\n />\r\n {icon && <div className=\"textfield-icon\">{icon}</div>}\r\n\r\n {error && <p className=\"textfield-error\">{error}</p>}\r\n </div>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./Radio.css\";\r\n\r\nexport interface RadioProps {\r\n label?: string;\r\n name: string; // obligatoire pour grouper les radios\r\n value: string;\r\n selectedValue: string;\r\n onChange: (value: string) => void;\r\n\r\n disabled?: boolean;\r\n error?: boolean;\r\n\r\n // ThΓ¨me custom\r\n borderColor?: string;\r\n dotColor?: string;\r\n checkedBorderColor?: string;\r\n checkedBackground?: string;\r\n focusShadow?: string;\r\n\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport const Radio: React.FC<RadioProps> = ({\r\n label,\r\n name,\r\n value,\r\n selectedValue,\r\n onChange,\r\n disabled = false,\r\n error = false,\r\n\r\n borderColor = \"#777\",\r\n dotColor = \"#fff\",\r\n checkedBorderColor = \"#007bff\",\r\n checkedBackground = error ? \"#d93025\" : \"#007bff\",\r\n focusShadow = \"rgba(0, 123, 255, 0.4)\",\r\n\r\n style,\r\n}) => {\r\n const checked = selectedValue === value;\r\n\r\n return (\r\n <label\r\n className={`radio-container ${disabled ? \"disabled\" : \"\"}`}\r\n style={{\r\n ...style,\r\n [\"--rd-border-color\" as any]: borderColor,\r\n [\"--rd-dot-color\" as any]: dotColor,\r\n [\"--rd-checked-border\" as any]: checkedBorderColor,\r\n [\"--rd-checked-bg\" as any]: checkedBackground,\r\n [\"--rd-focus-shadow\" as any]: focusShadow,\r\n }}\r\n >\r\n <input\r\n type=\"radio\"\r\n name={name}\r\n value={value}\r\n disabled={disabled}\r\n checked={checked}\r\n onChange={() => onChange(value)}\r\n />\r\n\r\n <span className={`radio-circle ${error ? \"error\" : \"\"}`} />\r\n\r\n {label && <span className=\"radio-label\">{label}</span>}\r\n </label>\r\n );\r\n};\r\n","import React, { useState, useRef, useEffect } from \"react\";\r\nimport \"./Select.css\";\r\n\r\nexport interface SelectOption {\r\n value: string | number;\r\n label: string;\r\n bgColor?: string;\r\n textColor?: string;\r\n}\r\n\r\nexport interface SelectProps {\r\n label?: string;\r\n goal?: string;\r\n value: string | number;\r\n onChange: (value: string | number) => void;\r\n options: SelectOption[];\r\n disabled?: boolean;\r\n error?: boolean;\r\n\r\n borderColor?: string;\r\n focusBorder?: string;\r\n focusShadow?: string;\r\n errorColor?: string;\r\n\r\n style?: React.CSSProperties;\r\n isDarkMode?: boolean;\r\n}\r\n\r\nexport const Select: React.FC<SelectProps> = ({\r\n label,\r\n goal = \"SELECT ...\",\r\n value,\r\n onChange,\r\n options,\r\n disabled = false,\r\n error = false,\r\n\r\n borderColor = \"#ccc\",\r\n focusBorder = \"#007bff\",\r\n focusShadow = \"rgba(0, 123, 255, 0.4)\",\r\n errorColor = \"#e63946\",\r\n isDarkMode = false,\r\n style,\r\n}) => {\r\n const [open, setOpen] = useState(false);\r\n const wrapperRef = useRef<HTMLDivElement>(null);\r\n\r\n const selected = options.find((o) => o.value === value);\r\n\r\n /** Close dropdown when clicking outside */\r\n useEffect(() => {\r\n const handleClick = (e: MouseEvent) => {\r\n if (\r\n wrapperRef.current &&\r\n !wrapperRef.current.contains(e.target as Node)\r\n ) {\r\n setOpen(false);\r\n }\r\n };\r\n document.addEventListener(\"mousedown\", handleClick);\r\n return () => document.removeEventListener(\"mousedown\", handleClick);\r\n }, []);\r\n\r\n return (\r\n <div\r\n className={`select-wrapper ${isDarkMode ? \"dark-mode\" : \"\"}`}\r\n style={style}\r\n ref={wrapperRef}\r\n >\r\n {label && <label className=\"select-label\">{label}</label>}\r\n\r\n <div\r\n className={`custom-select ${disabled ? \"disabled\" : \"\"} ${\r\n error ? \"error\" : \"\"\r\n } ${isDarkMode ? \"dark-mode\" : \"default\"}`}\r\n style={{\r\n [\"--sel-border\" as any]: isDarkMode ? \"black\" : borderColor,\r\n [\"--sel-focus-border\" as any]: focusBorder,\r\n [\"--sel-focus-shadow\" as any]: focusShadow,\r\n [\"--sel-error\" as any]: errorColor,\r\n }}\r\n onClick={() => !disabled && setOpen((o) => !o)}\r\n >\r\n <div className=\"selected-value\">{selected ? selected.label : goal}</div>\r\n\r\n <div className=\"arrow\">{open ? \"β²\" : \"βΌ\"}</div>\r\n\r\n {open && (\r\n <div\r\n className={`options-list ${isDarkMode ? \"dark-mode\" : \"default\"}`}\r\n >\r\n {options.map((opt) => (\r\n <div\r\n key={opt.value}\r\n className={`option-item ${opt.value === value ? \"active\" : \"\"}`}\r\n style={{\r\n background: opt.bgColor,\r\n color: opt.textColor,\r\n [\"--sel-item-active\" as any]: focusBorder,\r\n }}\r\n onClick={() => {\r\n onChange(opt.value);\r\n setOpen(false);\r\n }}\r\n >\r\n {opt.label}\r\n </div>\r\n ))}\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","import React, { createContext, useContext, useState } from \"react\";\r\nimport \"./Toast.css\";\r\n\r\nexport type ToastVariant = \"success\" | \"error\" | \"warning\" | \"info\";\r\n\r\nexport interface Toast {\r\n id: string;\r\n message: string;\r\n variant?: ToastVariant;\r\n duration?: number;\r\n position?: \"top-right\" | \"top-left\" | \"bottom-right\" | \"bottom-left\";\r\n}\r\n\r\ninterface ToastContextType {\r\n addToast: (\r\n msg: string,\r\n variant?: ToastVariant,\r\n duration?: number,\r\n position?: \"top-right\" | \"top-left\" | \"bottom-right\" | \"bottom-left\"\r\n ) => void;\r\n}\r\n\r\nconst ToastContext = createContext<ToastContextType | undefined>(undefined);\r\n\r\nexport const useToast = () => {\r\n const ctx = useContext(ToastContext);\r\n if (!ctx) throw new Error(\"useToast must be used inside <ToastProvider>\");\r\n return ctx;\r\n};\r\n\r\n// β IcΓ΄nes par dΓ©faut selon le variant\r\nconst TOAST_ICONS: Record<ToastVariant, string> = {\r\n success: \"βοΈ\",\r\n error: \"β\",\r\n warning: \"β οΈ\",\r\n info: \"βΉοΈ\",\r\n};\r\n\r\nexport const ToastProvider: React.FC<{ children: React.ReactNode }> = ({\r\n children,\r\n}) => {\r\n const [toasts, setToasts] = useState<Toast[]>([]);\r\n\r\n function addToast(\r\n message: string,\r\n variant: ToastVariant = \"info\",\r\n duration = 3000,\r\n position:\r\n | \"top-right\"\r\n | \"top-left\"\r\n | \"bottom-right\"\r\n | \"bottom-left\" = \"top-right\"\r\n ) {\r\n const toast: Toast = {\r\n id: Date.now().toString(),\r\n message,\r\n variant,\r\n duration,\r\n position,\r\n };\r\n\r\n setToasts((prev) => [...prev, toast]);\r\n\r\n setTimeout(() => {\r\n setToasts((prev) => prev.filter((t) => t.id !== toast.id));\r\n }, duration);\r\n }\r\n\r\n return (\r\n <ToastContext.Provider value={{ addToast }}>\r\n {children}\r\n\r\n {/* Container global */}\r\n <div className=\"toast-root\">\r\n {toasts.map((t) => (\r\n <div\r\n key={t.id}\r\n className={`toast toast-${t.variant} ${t.position}`}\r\n >\r\n <span className=\"toast-icon\">\r\n {TOAST_ICONS[t.variant ?? \"info\"]}\r\n </span>\r\n\r\n <span className=\"toast-message\">{t.message}</span>\r\n\r\n <button\r\n className=\"toast-close\"\r\n onClick={() =>\r\n setToasts((prev) => prev.filter((x) => x.id !== t.id))\r\n }\r\n >\r\n β\r\n </button>\r\n </div>\r\n ))}\r\n </div>\r\n </ToastContext.Provider>\r\n );\r\n};\r\n","import React, { useEffect } from \"react\";\r\nimport \"./Modal.css\";\r\nimport { Divider } from \"../Divider\";\r\n\r\nexport interface ModalProps {\r\n open: boolean;\r\n onClose: () => void;\r\n title?: string;\r\n children: React.ReactNode;\r\n width?: string; // ex: \"400px\"\r\n footer?: React.ReactNode;\r\n isDarkMode?: boolean;\r\n}\r\n\r\nexport const Modal: React.FC<ModalProps> = ({\r\n open,\r\n onClose,\r\n title,\r\n children,\r\n width = \"400px\",\r\n footer,\r\n isDarkMode = false,\r\n}) => {\r\n // Close with ESC key\r\n useEffect(() => {\r\n if (!open) return;\r\n\r\n const handleKey = (e: KeyboardEvent) => {\r\n if (e.key === \"Escape\") onClose();\r\n };\r\n\r\n window.addEventListener(\"keydown\", handleKey);\r\n return () => window.removeEventListener(\"keydown\", handleKey);\r\n }, [open]);\r\n\r\n if (!open) return null;\r\n\r\n const stopPropagation = (e: React.MouseEvent) => e.stopPropagation();\r\n\r\n return (\r\n <div className=\"modal-overlay\" onClick={onClose}>\r\n <div\r\n className={`modal-container ${isDarkMode ? \"dark-mode\" : \"light-mode\"}`}\r\n style={{ width }}\r\n onClick={stopPropagation}\r\n >\r\n <div className=\"modal-header\">\r\n {title && <h2 className=\"modal-title\">{title}</h2>}\r\n <button className={`modal-close-btn ${isDarkMode ? \"dark-mode\" : \"light-mode\"}`} onClick={onClose}>\r\n βοΈ\r\n </button>\r\n </div>\r\n <Divider margin={2}/>\r\n <div className=\"modal-body\">{children}</div>\r\n\r\n <div className=\"modal-footer\">{footer}</div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./Tag.css\";\r\n\r\nexport interface TagProps {\r\n label: string;\r\n variant?: \"filled\" | \"outline\" | \"soft\";\r\n color?: string;\r\n background?: string;\r\n borderColor?: string;\r\n closable?: boolean;\r\n disabled?: boolean;\r\n style?: React.CSSProperties;\r\n}\r\n\r\nexport const Tag: React.FC<TagProps> = ({\r\n label,\r\n variant = \"filled\",\r\n color = \"#fff\",\r\n background = \"#007bff\",\r\n borderColor = \"#007bff\",\r\n closable = false,\r\n disabled = false,\r\n style,\r\n}) => {\r\n const [isClosed, setIsClosed] = React.useState(false);\r\n\r\n return (\r\n <>\r\n {!isClosed && (\r\n <div\r\n className={`tag tag-${variant} ${disabled ? \"disabled\" : \"\"} ${\r\n isClosed ? \"none\" : \"\"\r\n }`}\r\n style={{\r\n [\"--tag-color\" as any]: color,\r\n [\"--tag-bg\" as any]: background,\r\n [\"--tag-border\" as any]: borderColor,\r\n ...style,\r\n }}\r\n >\r\n <span>{label}</span>\r\n\r\n {closable && (\r\n <button\r\n className=\"tag-close\"\r\n disabled={disabled}\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n setIsClosed(true);\r\n }}\r\n >\r\n Γ\r\n </button>\r\n )}\r\n </div>\r\n )}\r\n </>\r\n );\r\n};\r\n","export const Colors = {\r\n // Brand (Primary palette)\r\n primary: {\r\n 50: \"#fff6eb\",\r\n 100: \"#ffe8cc\",\r\n 200: \"#ffd3a3\",\r\n 300: \"#ffb86b\",\r\n 400: \"#ff9833\",\r\n 500: \"#ff7f00\",\r\n 600: \"#e36f00\",\r\n 700: \"#b85a00\",\r\n 800: \"#8c4500\",\r\n 900: \"#5c2d00\",\r\n },\r\n\r\n // Secondary palette\r\n secondary: {\r\n 50: \"#ebf8ff\",\r\n 100: \"#d0efff\",\r\n 200: \"#a9e2ff\",\r\n 300: \"#75d3ff\",\r\n 400: \"#33bdff\",\r\n 500: \"#009cff\",\r\n 600: \"#007dd6\",\r\n 700: \"#005fa6\",\r\n 800: \"#004676\",\r\n 900: \"#002c47\",\r\n },\r\n\r\n // Neutral / Grayscale\r\n neutral: {\r\n 0: \"#ffffff\",\r\n 50: \"#fafafa\",\r\n 100: \"#f5f5f5\",\r\n 200: \"#e5e5e5\",\r\n 300: \"#d4d4d4\",\r\n 400: \"#a3a3a3\",\r\n 500: \"#737373\",\r\n 600: \"#525252\",\r\n 700: \"#404040\",\r\n 800: \"#262626\",\r\n 900: \"#171717\",\r\n 950: \"#0a0a0a\",\r\n },\r\n\r\n // RAINBOW β full extended palette like Tailwind\r\n red: {\r\n 50: \"#fef2f2\", 100: \"#fee2e2\", 200: \"#fecaca\", 300: \"#fca5a5\",\r\n 400: \"#f87171\", 500: \"#ef4444\", 600: \"#dc2626\", 700: \"#b91c1c\",\r\n 800: \"#991b1b\", 900: \"#7f1d1d\",\r\n },\r\n\r\n green: {\r\n 50: \"#f0fdf4\", 100: \"#dcfce7\", 200: \"#bbf7d0\", 300: \"#86efac\",\r\n 400: \"#4ade80\", 500: \"#22c55e\", 600: \"#16a34a\", 700: \"#15803d\",\r\n 800: \"#166534\", 900: \"#14532d\",\r\n },\r\n\r\n blue: {\r\n 50: \"#eff6ff\", 100: \"#dbeafe\", 200: \"#bfdbfe\", 300: \"#93c5fd\",\r\n 400: \"#60a5fa\", 500: \"#3b82f6\", 600: \"#2563eb\", 700: \"#1d4ed8\",\r\n 800: \"#1e40af\", 900: \"#1e3a8a\",\r\n },\r\n\r\n yellow: {\r\n 50: \"#fefce8\", 100: \"#fef9c3\", 200: \"#fef08a\", 300: \"#fde047\",\r\n 400: \"#facc15\", 500: \"#eab308\", 600: \"#ca8a04\", 700: \"#a16207\",\r\n 800: \"#854d0e\", 900: \"#713f12\",\r\n },\r\n\r\n orange: {\r\n 50: \"#fff7ed\", 100: \"#ffedd5\", 200: \"#fed7aa\", 300: \"#fdba74\",\r\n 400: \"#fb923c\", 500: \"#f97316\", 600: \"#ea580c\", 700: \"#c2410c\",\r\n 800: \"#9a3412\", 900: \"#7c2d12\",\r\n },\r\n\r\n violet: {\r\n 50: \"#f5f3ff\", 100: \"#ede9fe\", 200: \"#ddd6fe\", 300: \"#c4b5fd\",\r\n 400: \"#a78bfa\", 500: \"#8b5cf6\", 600: \"#7c3aed\", 700: \"#6d28d9\",\r\n 800: \"#5b21b6\", 900: \"#4c1d95\",\r\n },\r\n\r\n pink: {\r\n 50: \"#fdf2f8\", 100: \"#fce7f3\", 200: \"#fbcfe8\", 300: \"#f9a8d4\",\r\n 400: \"#f472b6\", 500: \"#ec4899\", 600: \"#db2777\", 700: \"#be185d\",\r\n 800: \"#9d174d\", 900: \"#831843\",\r\n },\r\n\r\n teal: {\r\n 50: \"#f0fdfa\", 100: \"#ccfbf1\", 200: \"#99f6e4\", 300: \"#5eead4\",\r\n 400: \"#2dd4bf\", 500: \"#14b8a6\", 600: \"#0d9488\", 700: \"#0f766e\",\r\n 800: \"#115e59\", 900: \"#134e4a\",\r\n },\r\n\r\n // Semantic (status)\r\n success: \"#16a34a\",\r\n warning: \"#facc15\",\r\n error: \"#dc2626\",\r\n info: \"#2563eb\",\r\n\r\n // Social colors\r\n facebook: \"#1877f2\",\r\n twitter: \"#1da1f2\",\r\n instagram: \"#e1306c\",\r\n linkedin: \"#0a66c2\",\r\n youtube: \"#ff0000\",\r\n github: \"#333333\",\r\n\r\n // Glass / Frosted UI\r\n glass: {\r\n light: \"rgba(255, 255, 255, 0.4)\",\r\n medium: \"rgba(255, 255, 255, 0.25)\",\r\n dark: \"rgba(0, 0, 0, 0.4)\",\r\n },\r\n\r\n // Overlay (modals, dialogs)\r\n overlay: {\r\n light: \"rgba(0, 0, 0, 0.3)\",\r\n medium: \"rgba(0, 0, 0, 0.5)\",\r\n heavy: \"rgba(0, 0, 0, 0.7)\",\r\n },\r\n\r\n // Gradients\r\n gradients: {\r\n fire: \"linear-gradient(90deg, #f97316, #ef4444)\",\r\n ocean: \"linear-gradient(90deg, #0ea5e9, #6366f1)\",\r\n sunset: \"linear-gradient(90deg, #f43f5e, #fb923c)\",\r\n forest: \"linear-gradient(90deg, #22c55e, #0d9488)\",\r\n rainbow:\r\n \"linear-gradient(90deg, #ef4444, #f97316, #facc15, #22c55e, #3b82f6, #8b5cf6)\",\r\n },\r\n\r\n // Transparency presets\r\n transparent: \"transparent\",\r\n white: \"#ffffff\",\r\n black: \"#000000\",\r\n};\r\n\r\n\r\nexport const tco = {\r\n primary: \"#007bff\",\r\n primaryDark: \"#0056b3\",\r\n\r\n success: \"#2ecc71\",\r\n error: \"#e74c3c\",\r\n warning: \"#f39c12\",\r\n info: \"#3498db\",\r\n\r\n text: \"#222\",\r\n textDark: \"#fff\",\r\n\r\n borderDark: \"#ddd\",\r\n\r\n background: \"#ffffff\",\r\n backgroundDark: \"#333\",\r\n backgroundDark2: \"#222\",\r\n backgroundDark3: \"#111\",\r\n\r\n border: \"#ccc\",\r\n};","import React, { createContext, useContext, useState } from \"react\";\r\nimport { Theme } from \"./types\";\r\nimport { tco } from \"../Colors\";\r\n\r\ninterface ThemeContextType {\r\n theme: Theme;\r\n toggleDarkMode: () => void;\r\n setCustomTheme: (t: Partial<Theme>) => void;\r\n}\r\n\r\nconst ThemeContext = createContext<ThemeContextType | undefined>(undefined);\r\n\r\nexport const useTheme = () => {\r\n const ctx = useContext(ThemeContext);\r\n if (!ctx) throw new Error(\"useTheme must be used within ThemeProvider\");\r\n return ctx;\r\n};\r\n\r\nexport const ThemeProvider: React.FC<{ children: React.ReactNode }> = ({\r\n children,\r\n}) => {\r\n const [theme, setTheme] = useState<Theme>({\r\n primary: tco.primary,\r\n background: tco.background,\r\n text: tco.text,\r\n border: tco.border,\r\n mode: \"light\",\r\n });\r\n\r\n const toggleDarkMode = () => {\r\n setTheme((prev) => ({\r\n ...prev,\r\n mode: prev.mode === \"light\" ? \"dark\" : \"light\",\r\n background:\r\n prev.mode === \"light\" ? tco.backgroundDark : tco.background,\r\n text: prev.mode === \"light\" ? tco.textDark : tco.text,\r\n }));\r\n };\r\n\r\n const setCustomTheme = (t: Partial<Theme>) => {\r\n setTheme((prev) => ({ ...prev, ...t }));\r\n };\r\n\r\n return (\r\n <ThemeContext.Provider value={{ theme, toggleDarkMode, setCustomTheme }}>\r\n <div\r\n style={{\r\n backgroundColor: theme.background,\r\n color: theme.text,\r\n minHeight: \"100vh\",\r\n transition: \"all 0.25s ease\",\r\n }}\r\n >\r\n {children}\r\n </div>\r\n </ThemeContext.Provider>\r\n );\r\n};\r\n","import React, { useMemo, useState } from \"react\";\r\nimport \"./SmartTable.css\";\r\nimport { tco } from \"../Colors\";\r\n\r\nexport interface TableColumn<T> {\r\n key: keyof T;\r\n label: string;\r\n\r\n width?: string;\r\n align?: \"left\" | \"center\" | \"right\";\r\n\r\n render?: (value: T[keyof T], row: T) => React.ReactNode;\r\n\r\n // Sorting\r\n sortable?: boolean;\r\n}\r\n\r\nexport interface SmartTableProps<T> {\r\n data: T[];\r\n columns: TableColumn<T>[];\r\n\r\n loading?: boolean;\r\n\r\n clickable?: boolean;\r\n onRowClick?: (row: T) => void;\r\n\r\n striped?: boolean;\r\n bordered?: boolean;\r\n\r\n emptyText?: string;\r\n\r\n isDarkMode?: boolean;\r\n\r\n // Sorting\r\n enableSorting?: boolean;\r\n}\r\n\r\ntype SortDirection = \"asc\" | \"desc\" | null;\r\n\r\nexport function SmartTable<T>({\r\n data,\r\n columns,\r\n\r\n loading = false,\r\n clickable = false,\r\n onRowClick,\r\n striped = true,\r\n bordered = false,\r\n emptyText = \"No data available\",\r\n isDarkMode = false,\r\n enableSorting = false,\r\n}: SmartTableProps<T>) {\r\n const [sortKey, setSortKey] = useState<keyof T | null>(null);\r\n const [sortDirection, setSortDirection] = useState<SortDirection>(null);\r\n\r\n const handleSort = (key: keyof T) => {\r\n if (sortKey !== key) {\r\n setSortKey(key);\r\n setSortDirection(\"asc\");\r\n return;\r\n }\r\n\r\n if (sortDirection === \"asc\") {\r\n setSortDirection(\"desc\");\r\n } else if (sortDirection === \"desc\") {\r\n setSortKey(null);\r\n setSortDirection(null);\r\n } else {\r\n setSortDirection(\"asc\");\r\n }\r\n };\r\n\r\n const sortedData = useMemo(() => {\r\n if (!enableSorting || !sortKey || !sortDirection) return data;\r\n\r\n return [...data].sort((a, b) => {\r\n const aVal = a[sortKey];\r\n const bVal = b[sortKey];\r\n\r\n if (aVal == null) return 1;\r\n if (bVal == null) return -1;\r\n\r\n if (typeof aVal === \"number\" && typeof bVal === \"number\") {\r\n return sortDirection === \"asc\" ? aVal - bVal : bVal - aVal;\r\n }\r\n\r\n return sortDirection === \"asc\"\r\n ? String(aVal).localeCompare(String(bVal))\r\n : String(bVal).localeCompare(String(aVal));\r\n });\r\n }, [data, enableSorting, sortKey, sortDirection]);\r\n\r\n return (\r\n <div className={`st-wrapper ${bordered ? \"bordered\" : \"\"}`}>\r\n <table className=\"st-table\">\r\n <thead>\r\n <tr>\r\n {columns.map((col) => (\r\n <th\r\n key={String(col.key)}\r\n className={\r\n enableSorting && col.sortable ? \"st-sortable\" : \"\"\r\n }\r\n onClick={() =>\r\n enableSorting && col.sortable && handleSort(col.key)\r\n }\r\n style={{\r\n width: col.width,\r\n textAlign: col.align ?? \"left\",\r\n [\"--color-table-header\" as any]: isDarkMode\r\n ? tco.backgroundDark3\r\n : \"\",\r\n [\"--color-table-header-text\" as any]: isDarkMode\r\n ? tco.textDark\r\n : \"\",\r\n }}\r\n >\r\n <div className=\"st-th-content\">\r\n <span>{col.label}</span>\r\n\r\n {(enableSorting && col.sortable && col.sortable === true) ? (\r\n <span className=\"st-sort-icons\">\r\n <span\r\n className={\r\n sortKey === col.key && sortDirection === \"asc\"\r\n ? \"active\"\r\n : \"\"\r\n }\r\n >\r\n β²\r\n </span>\r\n <span\r\n className={\r\n sortKey === col.key && sortDirection === \"desc\"\r\n ? \"active\"\r\n : \"\"\r\n }\r\n >\r\n βΌ\r\n </span>\r\n </span>\r\n ) : null}\r\n </div>\r\n </th>\r\n ))}\r\n </tr>\r\n </thead>\r\n\r\n <tbody>\r\n {loading ? (\r\n <tr>\r\n <td colSpan={columns.length} className=\"st-loading\">\r\n Loading...\r\n </td>\r\n </tr>\r\n ) : sortedData.length === 0 ? (\r\n <tr>\r\n <td colSpan={columns.length} className=\"st-empty\">\r\n {emptyText}\r\n </td>\r\n </tr>\r\n ) : (\r\n sortedData.map((row, index) => (\r\n <tr\r\n key={index}\r\n style={{\r\n [\"--color-row-even\" as any]: isDarkMode\r\n ? tco.backgroundDark\r\n : \"\",\r\n [\"--color-row-odd\" as any]: isDarkMode\r\n ? tco.backgroundDark2\r\n : \"\",\r\n [\"--color-row-even-text\" as any]: isDarkMode\r\n ? tco.textDark\r\n : \"\",\r\n [\"--color-row-odd-text\" as any]: isDarkMode\r\n ? tco.textDark\r\n : \"\",\r\n }}\r\n className={`${\r\n striped ? (index % 2 === 0 ? \"even\" : \"odd\") : \"\"\r\n } ${clickable ? \"clickable\" : \"\"}`}\r\n onClick={() => clickable && onRowClick?.(row)}\r\n >\r\n {columns.map((col) => {\r\n const value = row[col.key];\r\n\r\n const renderValue = col.render\r\n ? col.render(value, row)\r\n : (value as unknown as React.ReactNode);\r\n\r\n return (\r\n <td\r\n key={String(col.key)}\r\n style={{ textAlign: col.align ?? \"left\" }}\r\n >\r\n {renderValue}\r\n </td>\r\n );\r\n })}\r\n </tr>\r\n ))\r\n )}\r\n </tbody>\r\n </table>\r\n </div>\r\n );\r\n}\r\n","import React from \"react\";\r\nimport \"./Pagination.css\";\r\nimport { tco } from \"../Colors\";\r\n\r\nexport interface PaginationProps {\r\n page: number;\r\n pageSize: number;\r\n total: number;\r\n color?: string;\r\n position?: \"left\" | \"center\" | \"right\";\r\n\r\n onPageChange: (page: number) => void;\r\n\r\n isDarkMode?: boolean;\r\n}\r\n\r\nexport const Pagination: React.FC<PaginationProps> = ({\r\n page,\r\n pageSize,\r\n total,\r\n onPageChange,\r\n isDarkMode = false,\r\n color = tco.primary,\r\n position = \"center\"\r\n}) => {\r\n const totalPages = Math.ceil(total / pageSize);\r\n\r\n if (totalPages <= 1) return null;\r\n\r\n const goToPage = (p: number) => {\r\n if (p < 1 || p > totalPages) return;\r\n onPageChange(p);\r\n };\r\n\r\n return (\r\n <div\r\n className=\"pagination\"\r\n style={{\r\n [\"--pg-bg\" as any]: isDarkMode ? tco.backgroundDark2 : \"#fff\",\r\n [\"--pg-text\" as any]: isDarkMode ? tco.textDark : \"#333\",\r\n [\"--pg-border\" as any]: isDarkMode ? tco.borderDark : \"#ddd\",\r\n [\"--pg-active\" as any]: color,\r\n justifyContent: position === \"left\" ? \"flex-start\" : position === \"center\" ? \"center\" : \"flex-end\"\r\n }}\r\n >\r\n <button disabled={page === 1} onClick={() => goToPage(page - 1)}>\r\n βΉ\r\n </button>\r\n\r\n {Array.from({ length: totalPages }).map((_, i) => {\r\n const p = i + 1;\r\n return (\r\n <button\r\n key={p}\r\n className={p === page ? \"active\" : \"\"}\r\n onClick={() => goToPage(p)}\r\n >\r\n {p}\r\n </button>\r\n );\r\n })}\r\n\r\n <button disabled={page === totalPages} onClick={() => goToPage(page + 1)}>\r\n βΊ\r\n </button>\r\n </div>\r\n );\r\n};\r\n","import React, { useState } from \"react\";\r\nimport \"./TableFilterBar.css\";\r\nimport { tco } from \"../Colors\";\r\n\r\nexport type FilterType = \"text\" | \"select\" | \"checkbox\" | \"radio\";\r\n\r\nexport interface BaseFilter {\r\n key: string;\r\n label: string;\r\n width?: \"large\" | \"medium\" | \"small\";\r\n}\r\n\r\nexport interface TextFilter extends BaseFilter {\r\n type: \"text\";\r\n placeholder?: string;\r\n}\r\n\r\nexport interface SelectFilter extends BaseFilter {\r\n type: \"select\";\r\n options: { label: string; value: string }[];\r\n}\r\n\r\nexport interface CheckboxFilter extends BaseFilter {\r\n type: \"checkbox\";\r\n}\r\n\r\nexport interface RadioFilter extends BaseFilter {\r\n type: \"radio\";\r\n options: { label: string; value: string }[];\r\n}\r\n\r\nexport type TableFilter =\r\n | TextFilter\r\n | SelectFilter\r\n | CheckboxFilter\r\n | RadioFilter;\r\n\r\nexport interface TableFilterBarProps {\r\n filters: TableFilter[];\r\n values: Record<string, any>;\r\n position?: \"left\" | \"center\" | \"right\";\r\n onChange: (key: string, value: any) => void;\r\n onReset?: () => void;\r\n isDarkMode?: boolean;\r\n gap?: number;\r\n collapsible?: boolean;\r\n resetButton?: React.ReactNode;\r\n}\r\n\r\nexport const TableFilterBar: React.FC<TableFilterBarProps> = ({\r\n filters,\r\n values,\r\n onChange,\r\n onReset,\r\n resetButton,\r\n isDarkMode = false,\r\n position = \"left\",\r\n gap = 16,\r\n collapsible = true,\r\n}) => {\r\n const [isOpen, setIsOpen] = useState(true);\r\n\r\n return (\r\n <>\r\n {isOpen && (\r\n <div\r\n className=\"tfb-container\"\r\n style={{\r\n [\"--tf-bg\" as any]: isDarkMode ? tco.backgroundDark2 : \"#fff\",\r\n [\"--tf-border\" as any]: isDarkMode ? tco.borderDark : \"#ddd\",\r\n [\"--tf-text\" as any]: isDarkMode ? tco.textDark : \"#333\",\r\n justifyContent:\r\n position === \"left\"\r\n ? \"flex-start\"\r\n : position === \"center\"\r\n ? \"center\"\r\n : \"flex-end\",\r\n gap: gap,\r\n }}\r\n >\r\n <div\r\n className=\"tfb-wrapper\"\r\n style={{\r\n justifyContent:\r\n position === \"left\"\r\n ? \"flex-start\"\r\n : position === \"center\"\r\n ? \"center\"\r\n : \"flex-end\",\r\n gap: gap,\r\n }}\r\n >\r\n {filters.map((filter) => (\r\n <div\r\n style={{\r\n width:\r\n filter.width === \"large\"\r\n ? \"50%\"\r\n : filter.width === \"medium\"\r\n ? \"30%\"\r\n : \"\",\r\n }}\r\n key={filter.key}\r\n className=\"tfb-item\"\r\n >\r\n <label>{filter.label}</label>\r\n\r\n {/* TEXT */}\r\n {filter.type === \"text\" && (\r\n <input\r\n type=\"text\"\r\n placeholder={filter.placeholder}\r\n value={values[filter.key] ?? \"\"}\r\n onChange={(e) => onChange(filter.key, e.target.value)}\r\n />\r\n )}\r\n\r\n {/* SELECT */}\r\n {filter.type === \"select\" && (\r\n <select\r\n value={values[filter.key] ?? \"\"}\r\n onChange={(e) => onChange(filter.key, e.target.value)}\r\n >\r\n <option value=\"\">All</option>\r\n {filter.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 {/* CHECKBOX */}\r\n {filter.type === \"checkbox\" && (\r\n <input\r\n type=\"checkbox\"\r\n checked={!!values[filter.key]}\r\n onChange={(e) => onChange(filter.key, e.target.checked)}\r\n />\r\n )}\r\n\r\n {/* RADIO */}\r\n {filter.type === \"radio\" && (\r\n <div className=\"tfb-radio-group\">\r\n {filter.options.map((opt) => (\r\n <label key={opt.value}>\r\n <input\r\n type=\"radio\"\r\n name={filter.key}\r\n value={opt.value}\r\n checked={values[filter.key] === opt.value}\r\n onChange={() => onChange(filter.key, opt.value)}\r\n />\r\n {opt.label}\r\n </label>\r\n ))}\r\n </div>\r\n )}\r\n </div>\r\n ))}\r\n\r\n {resetButton ? resetButton : (\r\n <button className=\"tfb-reset\" onClick={onReset}>\r\n Reset\r\n </button>\r\n )}\r\n </div>\r\n <div className=\"tfp-wrapper-toggle\">\r\n {collapsible && (\r\n <button onClick={() => setIsOpen(false)} title={\"Hide filters\"}>\r\n {\"β\"}\r\n </button>\r\n )}\r\n </div>\r\n </div>\r\n )}\r\n {collapsible && !isOpen && (\r\n <div className=\"tfp-wrapper-toggle-open\">\r\n <button onClick={() => setIsOpen(true)} title={\"Show filters\"}>\r\n {\"π\"}\r\n </button>\r\n </div>\r\n )}\r\n </>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./Text.css\";\r\nimport { tco } from \"../Colors\";\r\n\r\ntype TextAs =\r\n | \"h1\"\r\n | \"h2\"\r\n | \"h3\"\r\n | \"h4\"\r\n | \"h5\"\r\n | \"h6\"\r\n | \"p\"\r\n | \"span\"\r\n | \"label\"\r\n | \"small\"\r\n | \"div\";\r\n\r\ntype TextVariant =\r\n | \"title\"\r\n | \"subtitle\"\r\n | \"body\"\r\n | \"caption\"\r\n | \"overline\"\r\n | \"error\"\r\n | \"success\"\r\n | \"muted\";\r\n\r\ntype TextWeight = \"regular\" | \"medium\" | \"bold\";\r\ntype TextAlign = \"left\" | \"center\" | \"right\";\r\n\r\nexport interface TextProps {\r\n as?: TextAs;\r\n variant?: TextVariant;\r\n weight?: TextWeight;\r\n align?: TextAlign;\r\n color?: string;\r\n isDarkMode?: boolean;\r\n children: React.ReactNode;\r\n className?: string;\r\n}\r\n\r\nexport const Text: React.FC<TextProps> = ({\r\n as = \"span\",\r\n variant = \"body\",\r\n weight = \"regular\",\r\n align = \"left\",\r\n color,\r\n isDarkMode = false,\r\n className = \"\",\r\n children,\r\n}) => {\r\n const Component = as;\r\n\r\n return (\r\n <Component\r\n className={`txt txt-${variant} txt-${weight} txt-${align} ${className}`}\r\n style={{\r\n color:\r\n color ??\r\n (isDarkMode\r\n ? tco.textDark\r\n : undefined),\r\n }}\r\n >\r\n {children}\r\n </Component>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./SmartTimeLine.css\";\r\nimport { tco } from \"../Colors\";\r\n\r\nexport type TimelineOrientation = \"vertical\" | \"horizontal\";\r\n\r\nexport type TimelineStatus =\r\n | \"default\"\r\n | \"success\"\r\n | \"warning\"\r\n | \"error\"\r\n | \"info\";\r\n\r\nexport interface TimelineItem {\r\n id: string | number;\r\n title: string;\r\n description?: string;\r\n date?: string;\r\n status?: TimelineStatus;\r\n icon?: React.ReactNode;\r\n content?: React.ReactNode;\r\n}\r\n\r\nexport interface SmartTimelineProps {\r\n items: TimelineItem[];\r\n orientation?: TimelineOrientation;\r\n showLine?: boolean;\r\n clickable?: boolean;\r\n isDarkMode?: boolean;\r\n onItemClick?: (item: TimelineItem) => void;\r\n}\r\n\r\n\r\nexport const SmartTimeline: React.FC<SmartTimelineProps> = ({\r\n items,\r\n orientation = \"vertical\",\r\n showLine = true,\r\n clickable = false,\r\n isDarkMode = false,\r\n onItemClick,\r\n}) => {\r\n return (\r\n <div\r\n className={`stl-wrapper ${orientation}`}\r\n style={{\r\n [\"--tl-bg\" as any]: isDarkMode ? tco.backgroundDark2 : \"#fff\",\r\n [\"--tl-text\" as any]: isDarkMode ? tco.textDark : \"#333\",\r\n [\"--tl-line\" as any]: isDarkMode ? tco.borderDark : \"#ddd\",\r\n }}\r\n >\r\n {items.map((item, index) => (\r\n <TimelineRow\r\n key={item.id}\r\n item={item}\r\n index={index}\r\n last={index === items.length - 1}\r\n orientation={orientation}\r\n showLine={showLine}\r\n clickable={clickable}\r\n onClick={onItemClick}\r\n isDarkMode={isDarkMode}\r\n />\r\n ))}\r\n </div>\r\n );\r\n};\r\n\r\ninterface TimelineRowProps {\r\n item: TimelineItem;\r\n index: number;\r\n last: boolean;\r\n orientation: \"vertical\" | \"horizontal\";\r\n showLine: boolean;\r\n clickable: boolean;\r\n isDarkMode: boolean;\r\n onClick?: (item: TimelineItem) => void;\r\n}\r\n\r\nconst TimelineRow: React.FC<TimelineRowProps> = ({\r\n item,\r\n last,\r\n orientation,\r\n showLine,\r\n clickable,\r\n onClick,\r\n isDarkMode,\r\n}) => {\r\n return (\r\n <div\r\n className={`stl-item ${clickable ? \"clickable\" : \"\"}`}\r\n onClick={() => clickable && onClick?.(item)}\r\n >\r\n {/* Indicator */}\r\n <div className=\"stl-indicator\">\r\n <div\r\n className={`stl-dot status-${item.status ?? \"default\"}`}\r\n >\r\n {item.icon}\r\n </div>\r\n\r\n {showLine && !last && (\r\n <span className={`stl-line ${orientation}`} />\r\n )}\r\n </div>\r\n\r\n {/* Content */}\r\n <div className=\"stl-content\">\r\n {item.date && <span className=\"stl-date\">{item.date}</span>}\r\n <h4 className=\"stl-title\">{item.title}</h4>\r\n\r\n {item.description && (\r\n <p className=\"stl-desc\">{item.description}</p>\r\n )}\r\n\r\n {item.content && (\r\n <div className=\"stl-custom\">{item.content}</div>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","import React, { useEffect, useState } from \"react\";\r\nimport \"./SmartCarousel.css\";\r\nimport { tco } from \"../Colors\";\r\n\r\nexport interface CarouselImage {\r\n src: string;\r\n alt?: string;\r\n}\r\n\r\nexport interface SmartCarouselProps {\r\n images: CarouselImage[];\r\n\r\n autoPlay?: boolean;\r\n interval?: number;\r\n\r\n showArrows?: boolean;\r\n showDots?: boolean;\r\n activeDotColor?: string;\r\n\r\n isDarkMode?: boolean;\r\n\r\n height?: number | string;\r\n}\r\n\r\nexport const SmartCarousel: React.FC<SmartCarouselProps> = ({\r\n images,\r\n autoPlay = false,\r\n interval = 5000,\r\n showArrows = true,\r\n showDots = true,\r\n isDarkMode = false,\r\n height = 320,\r\n activeDotColor = tco.primary,\r\n}) => {\r\n const [index, setIndex] = useState(0);\r\n\r\n const next = () => setIndex((prev) => (prev + 1) % images.length);\r\n\r\n const prev = () =>\r\n setIndex((prev) => (prev - 1 + images.length) % images.length);\r\n\r\n useEffect(() => {\r\n if (!autoPlay) return;\r\n const timer = setInterval(next, interval);\r\n return () => clearInterval(timer);\r\n }, [autoPlay, interval]);\r\n\r\n if (!images.length) return null;\r\n\r\n return (\r\n <div\r\n className=\"sc-wrapper\"\r\n style={{\r\n height,\r\n [\"--sc-bg\" as any]: isDarkMode ? tco.backgroundDark2 : \"#000\",\r\n [\"--sc-dot\" as any]: isDarkMode ? tco.textDark : \"#fff\",\r\n [\"--sc-dot-active\" as any]: activeDotColor,\r\n }}\r\n >\r\n <div\r\n className=\"sc-track\"\r\n style={{ transform: `translateX(-${index * 100}%)` }}\r\n >\r\n {images.map((img, i) => (\r\n <img\r\n key={i}\r\n src={img.src}\r\n alt={img.alt ?? `slide-${i}`}\r\n className=\"sc-image\"\r\n />\r\n ))}\r\n </div>\r\n\r\n {showArrows && (\r\n <>\r\n <button\r\n className=\"sc-arrow left\"\r\n onClick={prev}\r\n aria-label=\"Previous\"\r\n >\r\n <span> βΉ</span>\r\n </button>\r\n <button className=\"sc-arrow right\" onClick={next} aria-label=\"Next\">\r\n <span> βΊ</span>\r\n </button>\r\n </>\r\n )}\r\n\r\n {showDots && (\r\n <div className=\"sc-dots\">\r\n {images.map((_, i) => (\r\n <span\r\n key={i}\r\n className={`sc-dot ${i === index ? \"active\" : \"\"}`}\r\n onClick={() => setIndex(i)}\r\n />\r\n ))}\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\n","import React, { useState } from \"react\";\r\nimport \"./Navbar.css\";\r\nimport { Button } from \"../Button\";\r\n\r\nexport interface NavbarLink {\r\n label: string;\r\n href?: string;\r\n onClick?: () => void;\r\n active?: boolean;\r\n}\r\n\r\nexport interface NavbarAction {\r\n element?: React.ReactNode;\r\n label?: string;\r\n icon?: React.ReactNode;\r\n onClick?: () => void;\r\n variant?: \"primary\" | \"secondary\" | \"ghost\";\r\n}\r\n\r\nexport interface NavbarProps {\r\n logo?: React.ReactNode;\r\n links?: NavbarLink[];\r\n actions?: NavbarAction[];\r\n position?: \"left\" | \"center\" | \"right\";\r\n sticky?: boolean;\r\n isDarkMode?: boolean;\r\n height?: number;\r\n}\r\n\r\n\r\nexport const Navbar: React.FC<NavbarProps> = ({\r\n logo,\r\n links = [],\r\n actions = [],\r\n position = \"left\",\r\n sticky = true,\r\n isDarkMode = false,\r\n height = 64\r\n}) => {\r\n const [open, setOpen] = useState(false);\r\n\r\n return (\r\n <nav\r\n className={`navbar ${isDarkMode ? \"dark\" : \"\"} ${\r\n sticky ? \"sticky\" : \"\"\r\n }`}\r\n style={{ height }}\r\n >\r\n <div className=\"navbar-container\">\r\n {/* Logo */}\r\n <div className=\"navbar-logo\">{logo}</div>\r\n\r\n {/* Links */}\r\n <ul className={`navbar-links ${position} ${open ? \"open\" : \"\"}`}>\r\n {\r\n links.map((link, i) => (\r\n <li\r\n key={i}\r\n className={`navbar-link ${link.active ? \"active\" : \"\"}`}\r\n onClick={() => {\r\n link.onClick?.();\r\n setOpen(false);\r\n }}\r\n >\r\n {link.href ? <a href={link.href}>{link.label}</a> : link.label}\r\n </li>\r\n ))\r\n }\r\n </ul>\r\n\r\n {/* Actions */}\r\n <div className=\"navbar-actions\">\r\n {actions.map((action, i) => (\r\n action.element ? action.element : <Button\r\n key={i}\r\n label={action.label ?? \"\"}\r\n icon={action.icon}\r\n variant={\"primary\"}\r\n size=\"small\"\r\n onClick={action.onClick}\r\n />\r\n ))}\r\n\r\n {/* Burger */}\r\n <div className=\"navbar-burger\" onClick={() => setOpen(!open)}>\r\n <span />\r\n <span />\r\n <span />\r\n </div>\r\n </div>\r\n </div>\r\n </nav>\r\n );\r\n};\r\n","// Sidebar.tsx\r\nimport React, { useState } from \"react\";\r\nimport \"./Sidebar.css\";\r\n// Sidebar.types.ts\r\n\r\nexport interface SidebarItem {\r\n label: string;\r\n icon?: React.ReactNode;\r\n href?: string;\r\n onClick?: () => void;\r\n active?: boolean;\r\n}\r\n\r\n\r\nexport interface SidebarProps {\r\n logo?: React.ReactNode;\r\n items?: SidebarItem[];\r\n footer?: React.ReactNode;\r\n\r\n collapsed?: boolean;\r\n onToggle?: (collapsed: boolean) => void;\r\n\r\n width?: number;\r\n collapsedWidth?: number;\r\n\r\n isDarkMode?: boolean;\r\n sticky?: boolean;\r\n style?: React.CSSProperties\r\n}\r\n\r\n\r\nexport const Sidebar: React.FC<SidebarProps> = ({\r\n logo,\r\n items = [],\r\n collapsed: controlledCollapsed,\r\n onToggle,\r\n width = 200,\r\n collapsedWidth = 50,\r\n isDarkMode = false,\r\n sticky = true,\r\n style = {}\r\n}) => {\r\n const [internalCollapsed, setInternalCollapsed] = useState(false);\r\n const collapsed = controlledCollapsed ?? internalCollapsed;\r\n\r\n const toggle = () => {\r\n const next = !collapsed;\r\n setInternalCollapsed(next);\r\n onToggle?.(next);\r\n };\r\n\r\n return (\r\n <aside\r\n className={`sidebar ${isDarkMode ? \"dark\" : \"\"} ${\r\n collapsed ? \"collapsed\" : \"\"\r\n } ${sticky ? \"sticky\" : \"\"}`}\r\n style={{...style, width: collapsed ? collapsedWidth : width }}\r\n >\r\n {/* Header */}\r\n <div className=\"sidebar-header\">\r\n <div className=\"sidebar-logo\">{logo}</div>\r\n\r\n <button className=\"sidebar-toggle\" onClick={toggle}>\r\n β°\r\n </button>\r\n </div>\r\n\r\n {/* Items */}\r\n <ul className=\"sidebar-items\">\r\n {items.map((item, i) => (\r\n <li\r\n key={i}\r\n className={`sidebar-item ${item.active ? \"active\" : \"\"}`}\r\n onClick={item.onClick}\r\n >\r\n {item.icon && <span className=\"sidebar-icon\">{item.icon}</span>}\r\n {!collapsed && <span className=\"sidebar-label\">{item.label}</span>}\r\n </li>\r\n ))}\r\n </ul>\r\n </aside>\r\n );\r\n};\r\n","// Footer.tsx\r\nimport React from \"react\";\r\nimport \"./Footer.css\";\r\n\r\nexport interface FooterLink {\r\n label: string;\r\n href?: string;\r\n onClick?: () => void;\r\n}\r\n\r\nexport interface FooterSection {\r\n title?: string;\r\n links?: FooterLink[];\r\n}\r\n\r\nexport interface FooterProps {\r\n left?: React.ReactNode;\r\n center?: React.ReactNode;\r\n right?: React.ReactNode;\r\n sections?: FooterSection[];\r\n isDarkMode?: boolean;\r\n height?: number;\r\n fixed?: boolean;\r\n}\r\n\r\nexport const Footer: React.FC<FooterProps> = ({\r\n left,\r\n center,\r\n right,\r\n sections = [],\r\n isDarkMode = false,\r\n height = 56,\r\n fixed = false\r\n}) => {\r\n return (\r\n <footer\r\n className={`footer ${isDarkMode ? \"dark\" : \"\"} ${\r\n fixed ? \"fixed\" : \"\"\r\n }`}\r\n style={{ height }}\r\n >\r\n <div className=\"footer-container\">\r\n {/* Left */}\r\n <div className=\"footer-left\">{left}</div>\r\n\r\n {/* Center */}\r\n <div className=\"footer-center\">{center}</div>\r\n\r\n {/* Right */}\r\n <div className=\"footer-right\">{right}</div>\r\n </div>\r\n\r\n {sections.length > 0 && (\r\n <div className=\"footer-sections\">\r\n {sections.map((section, i) => (\r\n <div key={i} className=\"footer-section\">\r\n {section.title && (\r\n <span className=\"footer-title\">{section.title}</span>\r\n )}\r\n\r\n {section.links?.map((link, j) => (\r\n <span\r\n key={j}\r\n className=\"footer-link\"\r\n onClick={link.onClick}\r\n >\r\n {link.href ? (\r\n <a href={link.href}>{link.label}</a>\r\n ) : (\r\n link.label\r\n )}\r\n </span>\r\n ))}\r\n </div>\r\n ))}\r\n </div>\r\n )}\r\n </footer>\r\n );\r\n};\r\n","// Layout.tsx\r\nimport React from \"react\";\r\nimport \"./Layout.css\";\r\n\r\n\r\nexport interface LayoutProps {\r\n header?: React.ReactNode;\r\n sidebar?: React.ReactNode;\r\n footer?: React.ReactNode;\r\n children: React.ReactNode;\r\n\r\n withSidebar?: boolean;\r\n withHeader?: boolean;\r\n withFooter?: boolean;\r\n\r\n sidebarWidth?: number;\r\n isDarkMode?: boolean;\r\n}\r\n\r\n\r\nexport const Layout: React.FC<LayoutProps> = ({\r\n header,\r\n sidebar,\r\n footer,\r\n children,\r\n withSidebar = true,\r\n withHeader = true,\r\n withFooter = true,\r\n sidebarWidth = 260,\r\n isDarkMode = false\r\n}) => {\r\n return (\r\n <div className={`layout ${isDarkMode ? \"dark\" : \"\"}`}>\r\n {withHeader && header}\r\n\r\n <div className=\"layout-main\">\r\n {withSidebar && sidebar && (\r\n <aside\r\n className=\"layout-sidebar\"\r\n style={{ width: sidebarWidth }}\r\n >\r\n {sidebar}\r\n </aside>\r\n )}\r\n\r\n <main className=\"layout-content\">{children}</main>\r\n </div>\r\n\r\n {withFooter && footer}\r\n </div>\r\n );\r\n};\r\n","import React, { useState } from \"react\";\r\nimport \"./DragDrop.css\";\r\n\r\nexport interface DragDropItem<T> {\r\n id: string;\r\n data: T;\r\n}\r\n\r\nexport interface DragDropProps<T> {\r\n items: DragDropItem<T>[];\r\n onChange: (items: DragDropItem<T>[]) => void;\r\n renderItem: (item: T) => React.ReactNode;\r\n\r\n direction?: \"vertical\" | \"horizontal\";\r\n gap?: number;\r\n draggable?: boolean;\r\n isDarkMode?: boolean;\r\n}\r\n\r\nexport function DragDrop<T>({\r\n items,\r\n onChange,\r\n renderItem,\r\n direction = \"vertical\",\r\n gap = 12,\r\n draggable = true,\r\n isDarkMode = false,\r\n}: DragDropProps<T>) {\r\n const [draggedId, setDraggedId] = useState<string | null>(null);\r\n\r\n const handleDragStart = (id: string) => {\r\n setDraggedId(id);\r\n };\r\n\r\n const handleDragOver = (e: React.DragEvent) => {\r\n e.preventDefault();\r\n };\r\n\r\n const handleDrop = (targetId: string) => {\r\n if (!draggedId || draggedId === targetId) return;\r\n\r\n const newItems = [...items];\r\n const fromIndex = newItems.findIndex(i => i.id === draggedId);\r\n const toIndex = newItems.findIndex(i => i.id === targetId);\r\n\r\n const [moved] = newItems.splice(fromIndex, 1);\r\n newItems.splice(toIndex, 0, moved);\r\n\r\n onChange(newItems);\r\n setDraggedId(null);\r\n };\r\n\r\n return (\r\n <div\r\n className={`dd-wrapper ${direction} ${isDarkMode ? \"dark\" : \"\"}`}\r\n style={{ gap }}\r\n >\r\n {items.map(item => (\r\n <div\r\n key={item.id}\r\n className={`dd-item ${draggedId === item.id ? \"dragging\" : \"\"}`}\r\n draggable={draggable}\r\n onDragStart={() => handleDragStart(item.id)}\r\n onDragOver={handleDragOver}\r\n onDrop={() => handleDrop(item.id)}\r\n >\r\n {renderItem(item.data)}\r\n </div>\r\n ))}\r\n </div>\r\n );\r\n}\r\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","import React, { useState } from \"react\";\r\nimport \"./SecureText.css\";\r\n\r\nexport interface SecureTextProps {\r\n value: string;\r\n masked?: boolean;\r\n copyable?: boolean;\r\n maskChar?: string;\r\n revealLabel?: string;\r\n copyLabel?: string;\r\n onCopy?: () => void;\r\n isDarkMode?: boolean;\r\n width?: number | string;\r\n}\r\n\r\nexport const SecureText: React.FC<SecureTextProps> = ({\r\n value,\r\n masked = true,\r\n copyable = true,\r\n maskChar = \"β’\",\r\n revealLabel = \"Show\",\r\n copyLabel = \"Copy\",\r\n onCopy,\r\n isDarkMode = false,\r\n width = \"100%\",\r\n}) => {\r\n const [visible, setVisible] = useState(!masked);\r\n const [copied, setCopied] = useState(false);\r\n\r\n const displayValue = visible\r\n ? value\r\n : maskChar.repeat(value.length);\r\n\r\n const handleCopy = async () => {\r\n await navigator.clipboard.writeText(value);\r\n setCopied(true);\r\n onCopy?.();\r\n setTimeout(() => setCopied(false), 1500);\r\n };\r\n\r\n return (\r\n <div\r\n className={`secure-text ${isDarkMode ? \"dark\" : \"\"}`}\r\n style={{ width }}\r\n >\r\n <span className=\"secure-text-value\">{displayValue}</span>\r\n\r\n <div className=\"secure-text-actions\">\r\n <button\r\n type=\"button\"\r\n onClick={() => setVisible(!visible)}\r\n title={visible ? \"Hide\" : revealLabel}\r\n >\r\n {visible ? \"π\" : \"π\"}\r\n </button>\r\n\r\n {copyable && (\r\n <button type=\"button\" onClick={handleCopy} title={copyLabel}>\r\n {copied ? \"β
\" : \"π\"}\r\n </button>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./Loading.css\";\r\n\r\nexport type LoadingVariant = \"spinner\" | \"dots\" | \"bar\";\r\nexport type LoadingSize = \"xs\" | \"sm\" | \"md\" | \"lg\";\r\n\r\nexport interface LoadingProps {\r\n variant?: LoadingVariant;\r\n size?: LoadingSize;\r\n text?: string;\r\n fullscreen?: boolean;\r\n overlay?: boolean;\r\n color?: string;\r\n isDarkMode?: boolean;\r\n}\r\n\r\nexport const Loading: React.FC<LoadingProps> = ({\r\n variant = \"spinner\",\r\n size = \"md\",\r\n text,\r\n fullscreen = false,\r\n overlay = false,\r\n color,\r\n isDarkMode = false,\r\n}) => {\r\n return (\r\n <div\r\n className={`loading-wrapper \r\n ${fullscreen ? \"fullscreen\" : \"\"} \r\n ${overlay ? \"overlay\" : \"\"} \r\n ${isDarkMode ? \"dark\" : \"\"}`}\r\n >\r\n <div\r\n className={`loading ${variant} ${size}`}\r\n style={{ [\"--loading-color\" as any]: color }}\r\n >\r\n {variant === \"spinner\" && <span className=\"spinner\" />}\r\n\r\n {variant === \"dots\" && (\r\n <>\r\n <span />\r\n <span />\r\n <span />\r\n </>\r\n )}\r\n\r\n {variant === \"bar\" && (\r\n <div className=\"bar-container\">\r\n <div className=\"bar-progress\" />\r\n </div>\r\n )}\r\n </div>\r\n\r\n {text && <p className=\"loading-text\">{text}</p>}\r\n </div>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport \"./Avatar.css\";\r\n\r\nexport type AvatarSize = \"xs\" | \"sm\" | \"md\" | \"lg\" | \"xl\";\r\nexport type AvatarShape = \"circle\" | \"rounded\" | \"square\";\r\nexport type AvatarStatus = \"online\" | \"offline\" | \"away\";\r\n\r\nexport interface AvatarProps {\r\n src?: string;\r\n alt?: string;\r\n name?: string; // used for initials\r\n size?: AvatarSize;\r\n shape?: AvatarShape;\r\n status?: AvatarStatus;\r\n backgroundColor?: string;\r\n color?: string;\r\n onClick?: () => void;\r\n isDarkMode?: boolean;\r\n}\r\n\r\nexport const Avatar: React.FC<AvatarProps> = ({\r\n src,\r\n alt = \"avatar\",\r\n name,\r\n size = \"md\",\r\n shape = \"circle\",\r\n status,\r\n backgroundColor,\r\n color,\r\n onClick,\r\n isDarkMode = false,\r\n}) => {\r\n const getInitials = () => {\r\n if (!name) return \"?\";\r\n const parts = name.trim().split(\" \");\r\n return parts.length === 1\r\n ? parts[0][0]\r\n : `${parts[0][0]}${parts[1][0]}`;\r\n };\r\n\r\n return (\r\n <div\r\n className={`\r\n avatar \r\n ${size} \r\n ${shape} \r\n ${onClick ? \"clickable\" : \"\"} \r\n ${isDarkMode ? \"dark\" : \"\"}\r\n `}\r\n style={{\r\n backgroundColor,\r\n color,\r\n }}\r\n onClick={onClick}\r\n >\r\n {src ? (\r\n <img src={src} alt={alt} />\r\n ) : (\r\n <span className=\"avatar-initials\">{getInitials()}</span>\r\n )}\r\n\r\n {status && <span className={`avatar-status ${status}`} />}\r\n </div>\r\n );\r\n};\r\n","import React, { useEffect, useRef, useState } from \"react\";\r\nimport \"./ProfileMenu.css\";\r\nimport { Avatar } from \"../Avatar/Avatar\";\r\n\r\nexport interface ProfileUser {\r\n name: string;\r\n email?: string;\r\n avatar?: string;\r\n}\r\n\r\nexport interface ProfileAction {\r\n label?: string;\r\n onClick?: () => void;\r\n icon?: React.ReactNode;\r\n danger?: boolean;\r\n divider?: boolean;\r\n}\r\n\r\nexport interface ProfileMenuProps {\r\n user: ProfileUser;\r\n actions: ProfileAction[];\r\n isDarkMode?: boolean;\r\n}\r\n\r\nexport const ProfileMenu: React.FC<ProfileMenuProps> = ({\r\n user,\r\n actions,\r\n isDarkMode = false,\r\n}) => {\r\n const [open, setOpen] = useState(false);\r\n const ref = useRef<HTMLDivElement>(null);\r\n\r\n // Close on outside click\r\n useEffect(() => {\r\n const handleClickOutside = (e: MouseEvent) => {\r\n if (ref.current && !ref.current.contains(e.target as Node)) {\r\n setOpen(false);\r\n }\r\n };\r\n document.addEventListener(\"mousedown\", handleClickOutside);\r\n return () => document.removeEventListener(\"mousedown\", handleClickOutside);\r\n }, []);\r\n\r\n return (\r\n <div className=\"profile-menu-wrapper\" ref={ref}>\r\n <Avatar\r\n src={user.avatar}\r\n name={user.name}\r\n size=\"sm\"\r\n onClick={() => setOpen(!open)}\r\n isDarkMode={isDarkMode}\r\n />\r\n\r\n {open && (\r\n <div className={`profile-menu ${isDarkMode ? \"dark\" : \"\"}`}>\r\n {/* User info */}\r\n <div className=\"profile-header\">\r\n <Avatar\r\n src={user.avatar}\r\n name={user.name}\r\n size=\"md\"\r\n isDarkMode={isDarkMode}\r\n />\r\n <div>\r\n <div className=\"profile-name\">{user.name}</div>\r\n {user.email && (\r\n <div className=\"profile-email\">{user.email}</div>\r\n )}\r\n </div>\r\n </div>\r\n\r\n {/* Actions */}\r\n <ul className=\"profile-actions\">\r\n {actions.map((action, i) =>\r\n action.divider ? (\r\n <li key={i} className=\"divider\" />\r\n ) : (\r\n <li\r\n key={i}\r\n className={`action ${action.danger ? \"danger\" : \"\"}`}\r\n onClick={() => {\r\n action.onClick?.();\r\n setOpen(false);\r\n }}\r\n >\r\n {action.icon && <span className=\"icon\">{action.icon}</span>}\r\n {action.label}\r\n </li>\r\n )\r\n )}\r\n </ul>\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\n"],"names":["_jsx","_Fragment","_jsxs","useState","useRef","useEffect","createContext","useContext","useMemo"],"mappings":"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","x_google_ignoreList":[0,31]}
|