@6thbridge/hexa 0.0.0-pr34-18 → 0.0.0-pr35-20

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.
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/tooltip/index.tsx","../src/utils/index.ts","../src/components/label/FormLabel.tsx","../src/components/label/index.tsx","../src/components/loader/index.tsx","../src/components/button/index.tsx","../src/components/input/index.tsx","../src/components/form/ErrorMessage.tsx","../src/components/form/FormDescription.tsx","../src/components/password-input/index.tsx","../src/components/password-input/icons/Eye.tsx","../src/components/password-input/icons/EyeOff.tsx","../src/components/password-input/icons/Check.tsx","../src/components/password-input/icons/Fail.tsx","../src/components/textarea/index.tsx","../src/components/searcheable/index.tsx","../src/components/command/index.tsx","../src/components/dialog/index.tsx","../src/components/dialog/icon/CloseIcon.tsx","../src/components/popover/index.tsx","../src/components/scroll-area/index.tsx","../src/components/country/data.ts","../src/components/phone-input/index.tsx","../src/components/phone-input/Flag.tsx","../src/components/country/index.tsx","../src/components/select/index.tsx","../src/components/otp/index.tsx","../src/components/banner/index.tsx","../src/components/copyable-label/index.tsx","../src/components/text-overflow/index.tsx","../src/components/debounced-input/index.tsx","../src/components/dev-banner/index.tsx","../src/components/drawer/index.tsx","../src/components/drawer/icon/CloseIcon.tsx","../src/hooks/useWindowSize.ts","../src/components/locale-selctor/icons/Check.tsx","../src/components/locale-selctor/icons/EnglishFlag.tsx","../src/components/locale-selctor/icons/FrenchFlag.tsx","../src/components/locale-selctor/icons/UpDownIcon.tsx","../src/components/locale-selctor/index.tsx","../src/components/sidebar/index.tsx","../src/components/sidebar/business/components/Content.tsx","../src/components/sidebar/business/components/Trigger.tsx","../src/components/sidebar/business/components/ActiveBusinessIcon.tsx","../src/components/sidebar/business/BusinessBar.tsx","../src/components/sidebar/NavItems.tsx","../src/hooks/useLocalStorage.tsx","../src/components/sidebar/components/OpenSidebarIcon.tsx","../src/components/sidebar/components/ClosedSidebarIcon.tsx","../src/components/sidebar/components/SidebarToggle.tsx","../src/components/status/index.tsx","../src/components/table/index.tsx","../src/components/table/pagination/index.tsx","../src/components/table/pagination/utils.tsx","../src/components/table/TableBody.tsx","../src/components/table/ToolBar.tsx","../src/components/table/filters/FilterContent.tsx","../src/components/radio/index.tsx","../src/components/calendar/CalendarInput.tsx","../src/components/calendar/index.tsx","../src/components/table/filters/helper/useFilterStore.ts","../src/components/table/filters/index.tsx","../src/components/table/filters/components/FilterLabelCount.tsx","../src/hooks/useMountClient.tsx","../src/components/permission/context.tsx","../src/components/permission/hook.ts","../src/components/permission/index.tsx","../src/actions/amount.action.ts","../src/actions/date.action.ts"],"sourcesContent":["\"use client\";\n\nimport * as React from \"react\";\nimport * as TooltipPrimitive from \"@radix-ui/react-tooltip\";\n\nimport { cn } from \"@/src/utils\";\n\nconst TooltipProvider = TooltipPrimitive.Provider;\n\nconst TooltipRoot = TooltipPrimitive.Root;\n\nconst TooltipTrigger = TooltipPrimitive.Trigger;\n\nconst TooltipContent = React.forwardRef<\n React.ElementRef<typeof TooltipPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content>\n>(({ className, sideOffset = 2, ...props }, ref) => (\n <TooltipPrimitive.Content\n ref={ref}\n sideOffset={sideOffset}\n className={cn(\n \"z-50 rounded-md border border-transparent bg-gray-50 px-3 py-1.5 text-base font-semibold text-bold text-black/40 shadow-xl- animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 [box-shadow:3px_4px_11px_0px_#0000001A,13px_16px_21px_0px_#00000017,29px_36px_28px_0px_#0000000D,52px_65px_33px_0px_#00000003,82px_101px_36px_0px_#00000000]\",\n className,\n )}\n {...props}\n >\n {props.children}\n {/* <TooltipPrimitive.Arrow className=\"!fill-gray-50 w-6\" /> */}\n </TooltipPrimitive.Content>\n));\n\nTooltipContent.displayName = TooltipPrimitive.Content.displayName;\n\nexport type TooltipPropsType = {\n trigger: React.ReactNode;\n children: React.ReactNode;\n contentClassName?: string;\n triggerClassName?: string;\n asChild?: boolean;\n side?: TooltipPrimitive.TooltipContentProps[\"side\"];\n sideOffset?: number;\n align?: TooltipPrimitive.TooltipContentProps[\"align\"];\n alignOffset?: number;\n delayDuration?: number;\n hasArrow?: boolean;\n arrowClassName?: string;\n};\n\nconst Tooltip = ({\n trigger,\n children,\n contentClassName,\n triggerClassName,\n asChild = true,\n side,\n sideOffset,\n align,\n alignOffset,\n delayDuration = 100,\n hasArrow = true,\n arrowClassName,\n ...props\n}: TooltipPropsType &\n React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Root>) => {\n return (\n <TooltipProvider>\n <TooltipRoot delayDuration={delayDuration} {...props}>\n <div className=\"flex justify-center items-center\">\n <TooltipTrigger asChild={asChild} className={triggerClassName}>\n {trigger}\n </TooltipTrigger>\n <TooltipContent\n side={side}\n sideOffset={sideOffset}\n align={align}\n alignOffset={alignOffset}\n className={contentClassName}\n >\n {children}\n {hasArrow && (\n <TooltipPrimitive.Arrow\n className={cn(\"fill-white\", arrowClassName)}\n />\n )}\n </TooltipContent>\n </div>\n </TooltipRoot>\n </TooltipProvider>\n );\n};\nTooltip.displayName = \"Tooltip\";\n\nexport {\n Tooltip,\n TooltipProvider,\n TooltipRoot,\n TooltipTrigger,\n TooltipContent,\n};\n","import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\ntype Status =\n | string\n | \"unpaid\"\n | \"partial-payment\"\n | \"active\"\n | \"paid\"\n | \"inactive\"\n | \"in-progress\"\n | \"failed\"\n | \"abandoned\"\n | \"success\";\n\ntype Variant = \"success\" | \"failed\" | \"pending\" | \"abandoned\";\ntype StatusVariantMap = Record<Status, Variant>;\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n\nexport function areObjectsEqual<T extends object>(obj1: T, obj2: T): boolean {\n const keys1 = Object.keys(obj1);\n const keys2 = Object.keys(obj2);\n\n if (keys1.length !== keys2.length) {\n return false;\n }\n\n for (const key of keys1) {\n const val1 = obj1[key as keyof T];\n const val2 = obj2[key as keyof T];\n\n if (\n typeof val1 === \"object\" &&\n val1 !== null &&\n typeof val2 === \"object\" &&\n val2 !== null\n ) {\n if (!areObjectsEqual(val1, val2)) {\n return false;\n }\n } else if (val1 !== val2) {\n return false;\n }\n }\n\n return true;\n}\n\nconst defaultStatusGroups: StatusVariantMap = {\n unpaid: \"pending\",\n \"partial-payment\": \"pending\",\n active: \"success\",\n paid: \"success\",\n inactive: \"abandoned\",\n \"in-progress\": \"pending\",\n failed: \"failed\",\n abandoned: \"abandoned\",\n success: \"success\",\n};\n\nexport const getStatusVariant = (\n status: Status,\n customGroups?: Partial<StatusVariantMap>,\n): Variant => {\n const mergedGroups = { ...defaultStatusGroups, ...customGroups };\n return mergedGroups[status] || \"pending\";\n};\n","import React from \"react\";\n\nimport * as LabelPrimitive from \"@radix-ui/react-label\";\nimport { Label } from \".\";\nimport { cn } from \"@/src/utils\";\n\nconst FormLabel = React.forwardRef<\n React.ElementRef<typeof LabelPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root> & {\n showAsterisk?: boolean;\n error?: string;\n formItemId?: string;\n }\n>(({ className, children, showAsterisk, error, ...props }, ref) => {\n return (\n <Label\n ref={ref}\n className={cn(error && \"text-red-500\", className)}\n // htmlFor={formItemId}\n {...props}\n >\n {showAsterisk ? (\n <p>\n {children}\n <span className=\"text-red-500\">*</span>\n </p>\n ) : (\n children\n )}\n </Label>\n );\n});\n\nFormLabel.displayName = \"FormLabel\";\n\nexport { FormLabel };\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as LabelPrimitive from \"@radix-ui/react-label\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\n\nimport { cn } from \"@/src/utils\";\n\nconst labelVariants = cva(\n \"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70\",\n);\n\nconst Label = React.forwardRef<\n React.ElementRef<typeof LabelPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root> &\n VariantProps<typeof labelVariants>\n>(({ className, ...props }, ref) => (\n <LabelPrimitive.Root\n ref={ref}\n className={cn(labelVariants(), className)}\n {...props}\n />\n));\nLabel.displayName = LabelPrimitive.Root.displayName;\n\nexport { Label };\n","type Colours = \"primary\" | \"secondary\";\n\nexport const Loader = ({\n size = 16,\n colour = \"primary\",\n}: {\n size?: number;\n colour?: Colours;\n}) => {\n return (\n <svg\n className=\"animate-spin\"\n width={size}\n height={size}\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n >\n <circle cx=\"10\" cy=\"10\" r=\"9.25\" stroke=\"transparent\" strokeWidth=\"1.5\" />\n <path\n d=\"M10 0.595792C10 0.266746 10.267 -0.00185055 10.5954 0.0177417C11.9786 0.100242 13.3318 0.469461 14.5682 1.1044C15.9816 1.83021 17.2016 2.88235 18.1273 4.17366C19.0531 5.46496 19.6578 6.95826 19.8913 8.52984C20.1249 10.1014 19.9807 11.706 19.4705 13.2108C18.9604 14.7155 18.0991 16.077 16.9579 17.1825C15.8167 18.288 14.4285 19.1056 12.9084 19.5677C11.3882 20.0298 9.77982 20.123 8.21646 19.8397C6.84883 19.5918 5.55009 19.0619 4.40196 18.2863C4.12931 18.1021 4.08072 17.7265 4.28083 17.4653C4.48094 17.2041 4.85388 17.1564 5.12801 17.3384C6.12474 18.0001 7.24768 18.4531 8.42898 18.6672C9.80606 18.9168 11.2228 18.8347 12.5618 18.4276C13.9008 18.0206 15.1236 17.3004 16.1288 16.3266C17.134 15.3528 17.8927 14.1536 18.342 12.8282C18.7914 11.5027 18.9185 10.0893 18.7127 8.70502C18.507 7.32071 17.9743 6.00535 17.1589 4.86792C16.3435 3.73048 15.2688 2.80371 14.0238 2.16439C12.9559 1.61596 11.789 1.29259 10.5954 1.21173C10.2671 1.18949 10 0.92484 10 0.595792Z\"\n fill={colour === \"primary\" ? \"#ffffff\" : \"currentColor\"}\n className=\"rounded\"\n />\n </svg>\n );\n};\n","\"use client\";\n\nimport * as React from \"react\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\n\nimport { cn } from \"@/src/utils\";\nimport { Loader } from \"../loader\";\nimport { ButtonHTMLAttributes } from \"react\";\nimport { DetailedHTMLProps } from \"react\";\n\nconst buttonVariants = cva(\n \"overflow-hidden isolate inline-flex h-fit items-center justify-center whitespace-nowrap text-sm font-medium ring-offset-background dark:ring-offset-transparent transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:!pointer-events-none\",\n {\n variants: {\n variant: {\n primary:\n \"border-primary-main bg-primary-main hover:bg-primary-main/70 disabled:bg-primary-main/70 text-white font-bold\",\n danger:\n \"border-red-600 bg-red-600 hover:bg-red-600/70 disabled:bg-red-600/70 text-white font-bold\",\n neutral:\n \"!border-0 bg-transparent text-primary-main hover:opacity-80 disabled:opacity-60\",\n outlined:\n \"border border-primary-main text-primary-main hover:opacity-80 disabled:opacity-60\",\n \"danger-outlined\":\n \"border border-red-600 text-red-600 hover:opacity-80 disabled:opacity-60\",\n \"light-outlined\":\n \"border-white text-white hover:opacity-80 disabled:opacity-60\",\n \"dark-text\":\n \"border-transparent bg-transparent hover:bg-opacity-70 disabled:bg-opacity-70 text-black font-medium\",\n light:\n \"border-white bg-white hover:bg-opacity-70 disabled:bg-opacity-70 text-primary-main font-semibold\",\n },\n size: {\n // lg: \"h-15 px-8 items-center\",\n // sm: \"h-10 px-3.5 items-center text-sm\",\n default:\n \"py-[0.625rem] px-[1.5rem] text-[0.875rem] leading-[1.25rem] font-medium rounded-lg\",\n sm: \"py-[0.375rem] px-[1rem] leading-[1rem] font-normal text-sm rounded-lg\",\n lg: \"py-[0.75rem] px-[1.5rem] text-[1rem] leading-[1.5rem] font-medium rounded-lg\",\n md: \"py-[0.625rem] px-[1.5rem] text-[0.875rem] leading-[1.25rem] font-medium rounded-lg\",\n \"icon-sm\":\n \"h-[1.75rem] w-[1.75rem] flex justify-center items-center font-medium rounded-lg\",\n icon: \"h-[2.5rem] w-[2.75rem] flex justify-center items-center font-medium rounded-lg\",\n \"icon-lg\":\n \"h-[3rem] w-[3rem] flex justify-center items-center font-medium rounded-lg\",\n },\n },\n defaultVariants: {\n variant: \"primary\",\n size: \"default\",\n },\n },\n);\n\nexport interface ButtonProps\n // extends React.ButtonHTMLAttributes<HTMLButtonElement>,\n extends DetailedHTMLProps<\n ButtonHTMLAttributes<HTMLButtonElement>,\n HTMLButtonElement\n >,\n VariantProps<typeof buttonVariants> {\n asChild?: boolean;\n isLoading?: boolean;\n leftNode?: React.ReactNode;\n rightNode?: React.ReactNode;\n LoaderSize?: number;\n}\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n (\n {\n className,\n variant = \"primary\",\n size,\n asChild = false,\n isLoading = false,\n leftNode,\n rightNode,\n LoaderSize,\n // ref,\n ...props\n },\n ref,\n ) => {\n const Component = asChild ? Slot : \"button\";\n\n const { children, disabled, ...rest } = props;\n const reference = React.useRef<HTMLButtonElement>(null);\n\n return (\n <Component\n className={cn(buttonVariants({ variant, size, className }))}\n ref={reference || ref}\n disabled={disabled || isLoading}\n {...rest}\n children={\n <div className=\"flex font-medium justify-center items-center gap-2\">\n {/* {leftNode}\n {children}\n {rightNode}\n {isLoading && <Loader />} */}\n\n {isLoading ? (\n <>\n <span className=\"mx-auto\">\n <Loader size={LoaderSize} colour=\"secondary\" />\n </span>\n </>\n ) : (\n <>\n {leftNode}\n {children}\n {rightNode}\n </>\n )}\n </div>\n }\n />\n );\n },\n);\n\nButton.displayName = \"Button\";\n\nexport { Button, buttonVariants };\n","\"use client\";\n\nimport * as React from \"react\";\n\nimport { cn } from \"@/src/utils\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { FormLabel } from \"../label/FormLabel\";\nimport { ErrorMessage } from \"../form/ErrorMessage\";\nimport { FormDescription } from \"../form/FormDescription\";\n\nexport const inputVariants = cva(\n \"!p-0 flex h-full w-full !border-transparent !bg-transparent text-base focus-visible:bg-transparent focus-visible:outline-none focus-visible:ring-0 focus-visible:ring-offset-0 disabled:cursor-not-allowed disabled:opacity-50\",\n {\n variants: {\n status: {\n default: \"placeholder:text-[#C4C4C4] dark:placeholder:text-[#9299A2]\",\n error: \"placeholder:text-red-500 text-red-500\",\n loading: \"placeholder:text-[#C4C4C4] dark:placeholder:text-[#9299A2]\",\n prefilled: \"\",\n neutral: \"\",\n },\n },\n defaultVariants: {\n status: \"default\",\n },\n },\n);\n\nexport interface BaseInnerInputProps\n extends React.InputHTMLAttributes<HTMLInputElement>,\n VariantProps<typeof inputVariants> {}\n\nconst BaseInnerInput = React.forwardRef<HTMLInputElement, BaseInnerInputProps>(\n ({ className, status, type, ...props }, ref) => {\n return (\n <input\n type={type}\n className={cn(inputVariants({ status }), className)}\n ref={ref}\n {...props}\n />\n );\n },\n);\nBaseInnerInput.displayName = \"BaseInnerInput\";\n\nexport const inputContainerVariants = cva(\n \"flex relative h-10 w-full rounded-[4px] dark:!bg-transparent border transition px-3 py-2 text-base placeholder:text-[#79818C] focus-within:outline-0 focus-within:ring-0 focus-visible:ring-offset-0 disabled:cursor-not-allowed disabled:opacity-50 dark:disabled:!border-[#9299A2]\",\n {\n variants: {\n status: {\n default:\n \"border-[#DEDEDE] bg-white text-[#191919] dark:!bg-transparent caret-text-primary focus-within:bg-white dark:focus-within:!bg-transparent dark:text-white focus-within:border-primary-main dark:focus-within:border-[#9299A2] dark:disabled:!border-[#9299A2]\",\n error:\n \"placeholder:text-red-500 bg-red-50 border-red-500 dark:!bg-status-error-bg-dark text-red-500 focus-within:bg-red-50 focus-within:border-red-500\",\n loading: \"\",\n prefilled:\n \"bg-[#F6F6F6] border-[#DEDEDE] dark:!bg-transparent caret-[#DEDEDE] focus-within:bg-[#F6F6F6] focus-within:border-[#DEDEDE] dark:!border-[#9299A2] dark:focus-within:border-[#9299A2]\",\n neutral:\n \"bg-[#F6F6F6] border-[#DEDEDE] dark:!bg-transparent caret-[#DEDEDE] focus-within:bg-[#F6F6F6] focus-within:border-[#DEDEDE] dark:!border-[#9299A2] dark:focus-within:border-[#9299A2]\",\n },\n },\n defaultVariants: {\n status: \"default\",\n },\n },\n);\n\nexport const sideVariants = cva(\n \"top-0 flex justify-center items-center h-full min-w-[50px] max-w-[100px] dark:!bg-transparent transition px-3 py-2 text-base placeholder:text-[#79818C] focus-within:outline-0 focus-within:ring-0 focus-visible:ring-offset-0 disabled:cursor-not-allowed disabled:opacity-50 dark:disabled:!border-[#9299A2]\",\n {\n variants: {\n side: {\n left: \"left-0 rounded-l-[8px] border-r\",\n right: \"right-0 rounded-r-[8px] border-l\",\n },\n status: {\n default:\n \"border-[#DEDEDE] bg-white text-[#191919] dark:!bg-transparent caret-primary-main focus-within:bg-white dark:focus-within:!bg-transparent dark:text-white focus-within:border-primary-main dark:focus-within:border-[#9299A2] dark:disabled:!border-[#9299A2]\",\n error:\n \"placeholder:text-red-500 bg-red-50 border-red-500 dark:!bg-red-50 text-red-500 focus-within:bg-red-50 focus-within:border-red-500\",\n loading: \"\",\n prefilled:\n \"bg-[#F6F6F6] border-[#DEDEDE] dark:!bg-transparent caret-[#DEDEDE] focus-within:bg-[#F6F6F6] focus-within:border-[#DEDEDE] dark:!border-[#9299A2] dark:focus-within:border-[#9299A2]\",\n neutral: \"bg-transparent border-0 caret-[#DEDEDE] !px-0\",\n },\n },\n defaultVariants: {\n status: \"default\",\n side: \"left\",\n },\n },\n);\n\nexport interface InputProps\n extends BaseInnerInputProps,\n VariantProps<typeof inputContainerVariants> {\n isLoading?: boolean;\n error?: string;\n leftNode?: React.ReactNode;\n rightNode?: React.ReactNode;\n sideNodeClassName?: string;\n label?: string;\n showAsterisk?: boolean;\n description?: React.ReactNode;\n}\n\nconst Input = React.forwardRef<HTMLInputElement, InputProps>(\n (\n {\n className,\n status = \"default\",\n disabled,\n error,\n isLoading,\n sideNodeClassName,\n showAsterisk,\n label,\n description,\n ...props\n },\n ref,\n ) => {\n let containerStatus: VariantProps<typeof inputContainerVariants>[\"status\"] =\n status;\n\n if (error) containerStatus = \"error\";\n if (isLoading) containerStatus = \"loading\";\n if (disabled) containerStatus = \"prefilled\";\n\n return (\n <div className=\"relative space-y-1 w-full\">\n {label && (\n <FormLabel showAsterisk={showAsterisk} error={error}>\n {label}\n </FormLabel>\n )}\n <div\n className={cn(\n inputContainerVariants({ status: containerStatus }),\n props.leftNode ? \"pl-0\" : \"\",\n props.rightNode ? \"pr-0\" : \"\",\n className,\n )}\n >\n {props.leftNode ? (\n <div\n className={cn(\n sideVariants({\n status: containerStatus,\n side: \"left\",\n }),\n sideNodeClassName,\n )}\n >\n {props.leftNode}\n </div>\n ) : null}\n <BaseInnerInput\n ref={ref}\n disabled={isLoading || disabled}\n className={cn({\n \"!pl-3\": props.leftNode && status !== \"neutral\",\n \"!pr-3\": props.rightNode && status !== \"neutral\",\n })}\n {...props}\n />\n {props.rightNode ? (\n <div\n className={cn(\n sideVariants({\n status: containerStatus,\n side: \"right\",\n }),\n sideNodeClassName,\n )}\n >\n {props.rightNode}\n </div>\n ) : null}\n </div>\n {description && (\n <FormDescription className=\"text-gray-400 text-sm !font-normal\">\n {description}\n </FormDescription>\n )}\n <ErrorMessage error={error} />\n </div>\n );\n },\n);\n\n// const Input = ({\n// className,\n// status = \"default\",\n// disabled,\n// error,\n// isLoading,\n// sideNodeClassName,\n// showAsterisk,\n// label,\n// description,\n// ref,\n// ...props\n// }: InputProps) => {\n// let containerStatus: VariantProps<typeof inputContainerVariants>[\"status\"] =\n// status;\n\n// if (error) containerStatus = \"error\";\n// if (isLoading) containerStatus = \"loading\";\n// if (disabled) containerStatus = \"prefilled\";\n\n// return (\n// <div className=\"relative space-y-1 w-full\">\n// {label && (\n// <FormLabel showAsterisk={showAsterisk} error={error}>\n// {label}\n// </FormLabel>\n// )}\n// <div\n// className={cn(\n// inputContainerVariants({ status: containerStatus }),\n// props.leftNode ? \"pl-0\" : \"\",\n// props.rightNode ? \"pr-0\" : \"\",\n// className,\n// )}\n// >\n// {props.leftNode ? (\n// <div\n// className={cn(\n// sideVariants({\n// status: containerStatus,\n// side: \"left\",\n// }),\n// sideNodeClassName,\n// )}\n// >\n// {props.leftNode}\n// </div>\n// ) : null}\n// <BaseInnerInput\n// ref={ref}\n// disabled={isLoading || disabled}\n// className={cn({\n// \"!pl-3\": props.leftNode && status !== \"neutral\",\n// \"!pr-3\": props.rightNode && status !== \"neutral\",\n// })}\n// {...props}\n// />\n// {props.rightNode ? (\n// <div\n// className={cn(\n// sideVariants({\n// status: containerStatus,\n// side: \"right\",\n// }),\n// sideNodeClassName,\n// )}\n// >\n// {props.rightNode}\n// </div>\n// ) : null}\n// </div>\n// {description && (\n// <FormDescription className=\"text-gray-400 text-sm !font-normal\">\n// {description}\n// </FormDescription>\n// )}\n// <ErrorMessage error={error} />\n// </div>\n// );\n// };\n\nInput.displayName = \"Input\";\n\nexport { Input };\n","import { cn } from \"@/src/utils\";\nimport React from \"react\";\n\nconst ErrorMessage = React.forwardRef<\n HTMLParagraphElement,\n React.HTMLAttributes<HTMLParagraphElement> & {\n error?: string;\n }\n>(({ className, children, error, ...props }, ref) => {\n const body = error ?? children;\n\n if (!body) {\n return null;\n }\n\n return (\n <p\n ref={ref}\n className={cn(\"text-xs font-normal text-[#F04248]\", className)}\n {...props}\n >\n {body}\n </p>\n );\n});\nErrorMessage.displayName = \"ErrorMessage\";\n\nexport { ErrorMessage };\n","import { cn } from \"@/src/utils\";\nimport React from \"react\";\n\nconst FormDescription = React.forwardRef<\n HTMLDivElement,\n React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={cn(\"text-sm text-[#8E98A8\", className)}\n {...props}\n />\n );\n});\nFormDescription.displayName = \"FormDescription\";\n\nexport { FormDescription };\n","import { useMemo, useState } from \"react\";\nimport { Eye } from \"./icons/Eye\";\nimport { EyeOff } from \"./icons/EyeOff\";\nimport { Input, InputProps } from \"../input\";\nimport { cn } from \"@/src/utils\";\nimport { Check } from \"./icons/Check\";\nimport { Fail } from \"./icons/Fail\";\n\nconst validationOptions = [\n {\n label: \"Uppercase\",\n key: \"uppercase\",\n RegExp: /[A-Z]/,\n validated: false,\n },\n {\n label: \"Lowercase\",\n key: \"lowercase\",\n RegExp: /[a-z]/,\n validated: false,\n },\n {\n label: \"Number\",\n key: \"number\",\n RegExp: /\\d/,\n validated: false,\n },\n {\n label: \"8 Characters\",\n key: \"eight-chars\",\n RegExp: /.{8}/,\n validated: false,\n },\n];\n\ntype PasswordInputProps = InputProps & {\n /**\n * onValidate(validated: boolean, value: string) => void\n * args - validated: this is boolean value that indicated that all validation options were met\n * args - value: this is the string input value\n */\n onValidate?: (validated: boolean, value: string) => void;\n disableValidation?: boolean;\n};\nconst PasswordInput = ({\n onValidate,\n onChange,\n disableValidation,\n ...props\n}: PasswordInputProps) => {\n const [passwordVisible, setPasswordVisible] = useState(false);\n const [validatedValues, setValidatedValues] = useState(validationOptions);\n\n const validatePassword = (value: string) => {\n return validationOptions.map((option) => ({\n ...option,\n validated: option.RegExp.test(value),\n }));\n };\n\n const checkPasswordStrength = (value: string) => {\n const validatedOptions = validatePassword(value);\n const allValidated = validatedOptions.every((option) => option.validated);\n\n setValidatedValues(validatedOptions);\n\n return allValidated;\n };\n\n const handlePaswordInputChange: React.ChangeEventHandler<HTMLInputElement> = (\n e,\n ) => {\n if (onChange) onChange(e);\n\n if (disableValidation) return;\n\n const value = e?.target?.value;\n const validated = checkPasswordStrength(value);\n\n if (onValidate) onValidate(validated, value);\n };\n\n const ValidateComp = useMemo(() => {\n return (\n <div className=\"flex items-center gap-2\">\n {validatedValues?.map((value) => (\n <div\n className={cn(\"text-xs flex items-center gap-0.5\", {\n \"text-[#62C554]\": value?.validated,\n \"text-[#8E98A8]\": !value?.validated,\n })}\n key={value?.key}\n >\n <span className=\"\">{value?.validated ? <Check /> : <Fail />}</span>\n <span className=\"\">{value?.label}</span>\n </div>\n ))}\n </div>\n );\n }, [validatedValues]);\n\n return (\n <Input\n sideNodeClassName=\"!border-l-0\"\n rightNode={\n passwordVisible ? (\n <button\n type=\"button\"\n onClick={() => setPasswordVisible((val) => !val)}\n >\n <Eye />\n </button>\n ) : (\n <button\n type=\"button\"\n onClick={() => setPasswordVisible((val) => !val)}\n >\n <EyeOff />\n </button>\n )\n }\n type={passwordVisible ? \"text\" : \"password\"}\n onChange={handlePaswordInputChange}\n description={!disableValidation && ValidateComp}\n {...props}\n />\n );\n};\n\nPasswordInput.displayName = \"PasswordInput\";\n\nexport { PasswordInput };\n","export const Eye = () => {\n return (\n <svg\n width=\"18\"\n height=\"14\"\n viewBox=\"0 0 18 14\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M1.54639 7.26103C1.48389 7.09264 1.48389 6.90741 1.54639 6.73903C2.15517 5.26292 3.18853 4.00081 4.51547 3.1127C5.84241 2.22459 7.40317 1.75049 8.99989 1.75049C10.5966 1.75049 12.1574 2.22459 13.4843 3.1127C14.8113 4.00081 15.8446 5.26292 16.4534 6.73903C16.5159 6.90741 16.5159 7.09264 16.4534 7.26103C15.8446 8.73713 14.8113 9.99925 13.4843 10.8874C12.1574 11.7755 10.5966 12.2496 8.99989 12.2496C7.40317 12.2496 5.84241 11.7755 4.51547 10.8874C3.18853 9.99925 2.15517 8.73713 1.54639 7.26103Z\"\n stroke=\"#8E98A8\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M9 9.25C10.2426 9.25 11.25 8.24264 11.25 7C11.25 5.75736 10.2426 4.75 9 4.75C7.75736 4.75 6.75 5.75736 6.75 7C6.75 8.24264 7.75736 9.25 9 9.25Z\"\n stroke=\"#8E98A8\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n};\n","export const EyeOff = () => {\n return (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M4.08759 12.69C3.26171 11.9072 2.61006 10.9591 2.17509 9.90752C2.10081 9.73454 2.0625 9.54826 2.0625 9.36001C2.0625 9.17177 2.10081 8.98549 2.17509 8.81252C2.75274 7.4073 3.72095 6.19704 4.96509 5.32502C6.14597 4.4998 7.55989 4.07405 9.00009 4.11002C10.0363 4.084 11.064 4.30239 12.0001 4.74752M13.9201 6.03752C14.7415 6.81964 15.3904 7.76486 15.8251 8.81252C15.8994 8.98549 15.9377 9.17177 15.9377 9.36001C15.9377 9.54826 15.8994 9.73454 15.8251 9.90752C15.2474 11.3127 14.2792 12.523 13.0351 13.395C11.8542 14.2202 10.4403 14.646 9.00009 14.61C7.9639 14.636 6.93616 14.4176 6.00009 13.9725\"\n stroke=\"#8E98A8\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M6.5325 10.2375C6.42732 9.95694 6.37395 9.65962 6.375 9.36C6.375 8.66381 6.65156 7.99613 7.14384 7.50384C7.63613 7.01156 8.30381 6.735 9 6.735C9.3 6.7335 9.597 6.7875 9.8775 6.8925M11.4675 8.4825C11.5725 8.763 11.6265 9.06 11.625 9.36C11.625 10.0562 11.3484 10.7239 10.8562 11.2162C10.3639 11.7084 9.69619 11.985 9 11.985C8.70038 11.986 8.40306 11.9327 8.1225 11.8275M2.25 15L14.25 3\"\n stroke=\"#8E98A8\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n};\n","export const Check = () => {\n return (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M8.89802 2.93408L9.70202 3.49808L6.21602 8.52608H5.41202L3.46802 5.80208L4.27202 5.05208L5.81402 6.49208L8.89802 2.93408Z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n};\n","export const Fail = () => {\n return (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M3.37891 8.62142L6.00041 5.99992L8.62191 8.62142M8.62191 3.37842L5.99991 5.99992L3.37891 3.37842\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n};\n","import * as React from \"react\";\n\nimport { cn } from \"@/src/utils\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { inputContainerVariants } from \"../input\";\nimport { DetailedHTMLProps } from \"react\";\nimport { FormLabel } from \"../label/FormLabel\";\nimport { FormDescription } from \"../form/FormDescription\";\nimport { ErrorMessage } from \"../form/ErrorMessage\";\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nconst textareaContainerVariants = cva(\n \"flex relative min-h-[80px] w-full rounded-[8px] border transition px-3 py-2 text-base placeholder:text-[#79818C] focus-within:outline-0 focus-within:ring-0 focus-visible:ring-offset-0 disabled:cursor-not-allowed disabled:opacity-50\",\n {\n variants: {\n status: {\n default:\n \"border-[#D7D7D7] dark:border-[#676767] bg-white text-[#191919] dark:!bg-transparent caret-primary-main focus-within:bg-white dark:focus-within:!bg-transparent dark:text-white focus-within:border-primary-main dark:focus-within:border-[#9299A2] dark:border-[#9299A2] dark:disabled:!border-[#9299A2]\",\n error:\n \"placeholder:text-status-error-fill bg-status-error-bg border-status-error-fill dark:!bg-status-error-bg-dark text-status-error-fill focus-within:bg-status-error-bg focus-within:border-status-error-fill\",\n loading: \"placeholder:text-[#C4C4C4]\",\n prefilled:\n \"resize-none bg-[#F6F6F6] border-[#D7D7D7] dark:!bg-transparent caret-[#D7D7D7] focus-within:bg-[#F6F6F6] focus-within:border-[#D7D7D7] dark:!border-[#9299A2] dark:focus-within:border-[#9299A2]\",\n neutral: \"\",\n },\n },\n defaultVariants: {\n status: \"default\",\n },\n },\n);\n\nexport interface TextareaProps\n extends DetailedHTMLProps<\n React.TextareaHTMLAttributes<HTMLTextAreaElement>,\n HTMLTextAreaElement\n >,\n VariantProps<typeof inputContainerVariants> {\n isLoading?: boolean;\n error?: string;\n label?: string;\n showAsterisk?: boolean;\n description?: React.ReactNode;\n}\n\nconst Textarea = ({\n className,\n status = \"default\",\n disabled,\n error,\n isLoading,\n showAsterisk,\n label,\n description,\n ...props\n}: TextareaProps) => {\n let containerStatus: VariantProps<\n typeof textareaContainerVariants\n >[\"status\"] = status;\n\n if (error) containerStatus = \"error\";\n if (isLoading) containerStatus = \"loading\";\n if (disabled) containerStatus = \"prefilled\";\n\n return (\n <div className=\"relative space-y-1\">\n <FormLabel showAsterisk={showAsterisk} error={error}>\n {label}\n </FormLabel>\n <textarea\n className={cn(\n \"min-h-[80px]\",\n inputContainerVariants({ status: containerStatus }),\n className,\n )}\n disabled={isLoading || disabled}\n {...props}\n />\n <FormDescription className=\"text-gray-400 text-sm !font-normal\">\n {description}\n </FormDescription>\n <ErrorMessage error={error} />\n </div>\n );\n};\n\nTextarea.displayName = \"Textarea\";\n\nexport { Textarea };\n","(\"use client\");\n\nimport * as React from \"react\";\n\nimport {\n Command,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n} from \"../command\";\nimport { PopoverContent, PopoverRoot, PopoverTrigger } from \"../popover\";\nimport { cn } from \"@/src/utils\";\nimport { ScrollArea } from \"../scroll-area\";\nimport { VariantProps } from \"class-variance-authority\";\nimport { inputContainerVariants } from \"../input\";\n\ntype SearchableDataType = {\n value: string;\n label: string;\n} & {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any; // Allows for additional properties\n};\n\ninterface SearchableProps {\n modal?: boolean;\n hideSearch?: boolean;\n loading?: boolean;\n inputValue?: string;\n onInputValueChange?: (arg: string) => void;\n disabled?: boolean;\n placeholder?: string;\n value?: SearchableDataType;\n options: SearchableDataType[] | [];\n optionComponent?: (arg: SearchableDataType) => React.ReactNode;\n className?: string;\n containerClassName?: string;\n onChange: (value: SearchableDataType) => void;\n onValueChange?: (value: string) => void;\n children?: React.ReactNode;\n}\n\ninterface SearchableTriggerProps\n extends VariantProps<typeof inputContainerVariants> {\n disabled?: boolean;\n placeholder?: string;\n value?: string;\n className?: string;\n id?: string;\n}\n\nconst SearchableTrigger = ({\n className,\n value,\n placeholder = \"\",\n status,\n disabled,\n id,\n}: SearchableTriggerProps) => {\n return (\n <PopoverTrigger asChild disabled={disabled} id={id ?? \"searchable-trigger\"}>\n <button\n disabled={disabled}\n className={cn(\n inputContainerVariants({ status }),\n \"[&>span]:justify-start [&>span]:items-center gap-2 flex h-12 w-full items-center justify-between goup\",\n value ? \"\" : \"text-[#79818C]\",\n className,\n )}\n >\n {value ?? placeholder ?? \"Select options...\"}\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n className=\" data-[state=open]:goup-rotate-180\"\n >\n <path\n d=\"M16.5999 7.45825L11.1666 12.8916C10.5249 13.5333 9.4749 13.5333 8.83324 12.8916L3.3999 7.45825\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeMiterlimit=\"10\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </button>\n </PopoverTrigger>\n );\n};\n\nconst Searchable = ({\n options = [],\n value,\n onChange,\n containerClassName,\n placeholder,\n disabled,\n loading,\n optionComponent,\n children,\n modal = false,\n hideSearch,\n className,\n inputValue,\n onValueChange,\n onInputValueChange,\n}: SearchableProps) => {\n const [open, setOpen] = React.useState(false);\n\n const triggerRef = React.useRef<HTMLDivElement | null>(null);\n\n const [width, setWidth] = React.useState<number | undefined>(undefined);\n\n React.useLayoutEffect(() => {\n if (triggerRef.current) {\n setWidth(triggerRef.current.clientWidth);\n }\n }, [triggerRef.current]);\n\n return (\n <PopoverRoot modal={modal} open={open} onOpenChange={setOpen}>\n <div className={cn(\"w-full\", className)} ref={triggerRef}>\n {children}\n </div>\n <PopoverContent\n portal={!modal}\n className=\"p-0 min-w-[200px]\"\n style={{ width }}\n >\n <Command\n className={cn(\"relative max-h-[270px]\", {\n \"mt-2\": !hideSearch,\n })}\n >\n {!hideSearch && (\n <CommandInput\n loading={loading}\n placeholder={placeholder ?? \"Search options...\"}\n onValueChange={onInputValueChange}\n value={inputValue}\n CommandInputContainerClassName=\"mx-2 border rounded-md border-[#DEDEDE]\"\n />\n )}\n <ScrollArea\n viewPortClassName=\"max-h-[225px]\"\n className={cn(\n \"w-full px-0 h-full overflow-y-auto\",\n containerClassName,\n )}\n >\n <CommandList>\n {!hideSearch && <CommandEmpty>No result found.</CommandEmpty>}\n <CommandGroup className=\"w-full\">\n {options?.map((option) => (\n <CommandItem\n defaultValue={value?.label}\n key={option.value}\n value={option.label}\n disabled={disabled}\n onSelect={() => {\n onChange(option);\n setOpen(false);\n onValueChange?.(option?.value);\n }}\n id={option.value}\n >\n {!optionComponent ? option.label : optionComponent(option)}\n </CommandItem>\n ))}\n </CommandGroup>\n </CommandList>\n </ScrollArea>\n </Command>\n </PopoverContent>\n </PopoverRoot>\n );\n};\n\nexport { Searchable, SearchableTrigger };\n\nexport type { SearchableProps, SearchableTriggerProps, SearchableDataType };\n","\"use client\";\n\nimport * as React from \"react\";\nimport { type DialogProps } from \"@radix-ui/react-dialog\";\nimport { Command as CommandPrimitive } from \"cmdk\";\nimport { Search } from \"lucide-react\";\n\nimport { cn } from \"@/src/utils\";\nimport { Dialog, DialogContent } from \"@/src/components/dialog\";\nimport { Loader } from \"../loader\";\n\nconst Command = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive\n ref={ref}\n className={cn(\n \"flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground\",\n className,\n )}\n {...props}\n />\n));\nCommand.displayName = CommandPrimitive.displayName;\n\ninterface CommandDialogProps extends DialogProps {\n trigger?: React.ReactNode;\n}\n\nconst CommandDialog = ({ children, ...props }: CommandDialogProps) => {\n return (\n <Dialog {...props} trigger={props?.trigger ?? <></>}>\n <DialogContent className=\"overflow-hidden p-0\">\n <Command className=\"[&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-group]]:px-2 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5\">\n {children}\n </Command>\n </DialogContent>\n </Dialog>\n );\n};\n\ninterface CommandInputProps\n extends React.ComponentPropsWithoutRef<typeof CommandPrimitive.Input> {\n CommandInputContainerClassName?: string;\n loading?: boolean;\n}\n\nconst CommandInput = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Input>,\n CommandInputProps\n>(({ className, CommandInputContainerClassName, loading, ...props }, ref) => (\n <div\n className={cn(\n \"flex items-center border-0 px-3 gap-2\",\n CommandInputContainerClassName,\n )}\n cmdk-input-wrapper=\"\"\n >\n {loading ? (\n <Loader size={16} colour=\"secondary\" />\n ) : (\n <Search className=\"mr-2 h-4 w-4 shrink-0 opacity-50\" />\n )}\n <CommandPrimitive.Input\n ref={ref}\n className={cn(\n \"flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50\",\n className,\n )}\n disabled={loading}\n {...props}\n />\n </div>\n));\n\nCommandInput.displayName = CommandPrimitive.Input.displayName;\n\nconst CommandList = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.List>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.List>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.List\n ref={ref}\n className={cn(\"overflow-y-auto overflow-x-hidden\", className)}\n {...props}\n />\n));\n\nCommandList.displayName = CommandPrimitive.List.displayName;\n\nconst CommandEmpty = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Empty>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Empty>\n>((props, ref) => (\n <CommandPrimitive.Empty\n ref={ref}\n className=\"py-6 text-center text-sm\"\n {...props}\n />\n));\n\nCommandEmpty.displayName = CommandPrimitive.Empty.displayName;\n\nconst CommandGroup = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Group>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Group>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Group\n ref={ref}\n className={cn(\n \"overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground\",\n className,\n )}\n {...props}\n />\n));\n\nCommandGroup.displayName = CommandPrimitive.Group.displayName;\n\nconst CommandSeparator = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Separator>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Separator\n ref={ref}\n className={cn(\"-mx-1 h-px bg-border\", className)}\n {...props}\n />\n));\nCommandSeparator.displayName = CommandPrimitive.Separator.displayName;\n\nconst CommandItem = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Item>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Item\n ref={ref}\n className={cn(\n \"relative text=[#222222] flex cursor-default gap-2 select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none data-[disabled=true]:pointer-events-none data-[selected=true]:bg-primary-accent data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0\",\n className,\n )}\n {...props}\n />\n));\n\nCommandItem.displayName = CommandPrimitive.Item.displayName;\n\nconst CommandShortcut = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLSpanElement>) => {\n return (\n <span\n className={cn(\n \"ml-auto text-xs tracking-widest text-muted-foreground\",\n className,\n )}\n {...props}\n />\n );\n};\nCommandShortcut.displayName = \"CommandShortcut\";\n\nexport {\n Command,\n CommandDialog,\n CommandInput,\n CommandList,\n CommandEmpty,\n CommandGroup,\n CommandItem,\n CommandShortcut,\n CommandSeparator,\n};\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as DialogPrimitive from \"@radix-ui/react-dialog\";\n\nimport { cn } from \"@/src/utils\";\nimport { CloseIcon } from \"./icon/CloseIcon\";\n\nconst DialogRoot = DialogPrimitive.Root;\n\nconst DialogTrigger = DialogPrimitive.Trigger;\n\nconst DialogPortal = DialogPrimitive.Portal;\n\nconst DialogOverlay = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Overlay>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Overlay\n ref={ref}\n className={cn(\n \"fixed inset-0 z-50 bg-black/60 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0\",\n className,\n )}\n {...props}\n />\n));\nDialogOverlay.displayName = DialogPrimitive.Overlay.displayName;\n\nconst DialogContent = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Content> & {\n hideCloseButton?: boolean;\n }\n>(({ className, hideCloseButton, children, ...props }, ref) => (\n <DialogPortal>\n <DialogOverlay />\n <DialogPrimitive.Content\n ref={ref}\n className={cn(\n \"fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border border-transparent bg-white p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] rounded-lg max-h-[95%] overflow-y-auto\",\n className,\n )}\n {...props}\n >\n {children}\n {!hideCloseButton && (\n <DialogPrimitive.Close className=\"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground\">\n <CloseIcon />\n\n <span className=\"sr-only\">Close</span>\n </DialogPrimitive.Close>\n )}\n </DialogPrimitive.Content>\n </DialogPortal>\n));\nDialogContent.displayName = DialogPrimitive.Content.displayName;\n\nconst DialogHeader = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\"flex flex-col space-y-1.5 text-left\", className)}\n {...props}\n />\n);\nDialogHeader.displayName = \"DialogHeader\";\n\nconst DialogFooter = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\"flex flex-row justify-end sm:space-x-2\", className)}\n {...props}\n />\n);\nDialogFooter.displayName = \"DialogFooter\";\n\nconst DialogTitle = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Title>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Title>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Title\n ref={ref}\n className={cn(\n \"text-xl font-semibold leading-none tracking-tight\",\n className,\n )}\n {...props}\n />\n));\nDialogTitle.displayName = DialogPrimitive.Title.displayName;\n\nconst DialogDescription = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Description>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Description>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Description\n ref={ref}\n className={cn(\"text-sm text-gray-500\", className)}\n {...props}\n />\n));\nDialogDescription.displayName = DialogPrimitive.Description.displayName;\n\nexport type DialogPropsType = {\n trigger?: React.ReactNode;\n children: React.ReactNode;\n title?: React.ReactNode;\n description?: React.ReactNode;\n footer?: React.ReactNode;\n hideCloseButton?: boolean;\n contentClassName?: string;\n headerClassName?: string;\n titleClassName?: string;\n descriptionClassName?: string;\n footerClassName?: string;\n asChild?: boolean;\n onOpenAutoFocus?: (e: Event) => void;\n onCloseAutoFocus?: (e: Event) => void;\n onInteractOutside?: (e: Event) => void;\n onPointerDownOutside?: (e: Event) => void;\n onEscapeKeyDown?: (e: KeyboardEvent) => void;\n};\n\nconst Dialog = ({\n trigger = undefined,\n children,\n open,\n onOpenChange,\n hideCloseButton,\n footer,\n title,\n description,\n contentClassName,\n headerClassName,\n titleClassName,\n descriptionClassName,\n footerClassName,\n asChild = true,\n onOpenAutoFocus,\n onCloseAutoFocus,\n onEscapeKeyDown,\n onInteractOutside,\n onPointerDownOutside,\n ...props\n}: React.ComponentPropsWithoutRef<typeof DialogPrimitive.Root> &\n DialogPropsType) => {\n return (\n <DialogRoot {...props} open={open} onOpenChange={onOpenChange}>\n <DialogTrigger asChild={asChild}>{trigger}</DialogTrigger>\n <DialogPortal>\n <DialogContent\n className={contentClassName}\n hideCloseButton={hideCloseButton}\n onOpenAutoFocus={onOpenAutoFocus}\n onCloseAutoFocus={onCloseAutoFocus}\n onEscapeKeyDown={onEscapeKeyDown}\n onPointerDownOutside={onPointerDownOutside}\n onInteractOutside={onInteractOutside}\n >\n {title || description ? (\n <DialogHeader className={headerClassName}>\n {title && (\n <DialogTitle className={titleClassName}>{title}</DialogTitle>\n )}\n {description && (\n <DialogDescription className={descriptionClassName}>\n {description}\n </DialogDescription>\n )}\n </DialogHeader>\n ) : (\n <></>\n )}\n {children}\n {footer && (\n <DialogFooter className={footerClassName}>{footer}</DialogFooter>\n )}\n </DialogContent>\n </DialogPortal>\n </DialogRoot>\n );\n};\nDialog.displayName = DialogPrimitive.Dialog.displayName;\n\nexport { Dialog, DialogRoot, DialogContent };\n","export const CloseIcon = () => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n className=\"lucide lucide-x\"\n >\n <path d=\"M18 6 6 18\" />\n <path d=\"m6 6 12 12\" />\n </svg>\n );\n};\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\";\n\nimport { cn } from \"@/src/utils\";\n\nconst PopoverRoot = PopoverPrimitive.Root;\n\nconst PopoverTrigger = PopoverPrimitive.Trigger;\n\nconst PopoverContent = React.forwardRef<\n React.ElementRef<typeof PopoverPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Content> & {\n portal?: boolean;\n }\n>(\n (\n { className, align = \"center\", sideOffset = 4, portal = true, ...props },\n ref,\n ) =>\n portal ? (\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n ref={ref}\n align={align}\n sideOffset={sideOffset}\n className={cn(\n \"pointer-events-auto z-50 w-72 rounded-md border border-transparent bg-white p-4 text-[#191919] shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2\",\n className,\n )}\n onOpenAutoFocus={props.onOpenAutoFocus}\n onCloseAutoFocus={props.onCloseAutoFocus}\n {...props}\n />\n </PopoverPrimitive.Portal>\n ) : (\n <PopoverPrimitive.Content\n ref={ref}\n align={align}\n sideOffset={sideOffset}\n className={cn(\n \"pointer-events-auto z-50 w-72 rounded-md border border-transparent bg-white p-4 text-[#191919] shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2\",\n className,\n )}\n onOpenAutoFocus={props.onOpenAutoFocus}\n onCloseAutoFocus={props.onCloseAutoFocus}\n {...props}\n />\n ),\n);\nPopoverContent.displayName = PopoverPrimitive.Content.displayName;\n\nexport type PopoverPropsType = {\n trigger: React.ReactNode;\n children: React.ReactNode;\n contentClassName?: string;\n triggerClassName?: string;\n asChild?: boolean;\n align?: PopoverPrimitive.PopoverContentProps[\"align\"];\n side?: PopoverPrimitive.PopoverContentProps[\"side\"];\n alignOffset?: number | undefined;\n sideOffset?: number | undefined;\n onOpenAutoFocus?: (e: Event) => void;\n onCloseAutoFocus?: (e: Event) => void;\n portal?: boolean;\n id?: string;\n};\n\nconst Popover = ({\n trigger,\n children,\n open,\n onOpenChange,\n contentClassName,\n asChild = true,\n align,\n side,\n alignOffset,\n triggerClassName,\n sideOffset,\n onOpenAutoFocus,\n onCloseAutoFocus,\n portal = true,\n id = \"popover\",\n ...props\n}: React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Root> &\n PopoverPropsType) => {\n return (\n <PopoverRoot {...props} open={open} onOpenChange={onOpenChange}>\n <PopoverTrigger\n asChild={asChild}\n className={triggerClassName}\n id={`${id}-trigger`}\n >\n {trigger}\n </PopoverTrigger>\n <PopoverContent\n alignOffset={alignOffset}\n sideOffset={sideOffset}\n side={side}\n align={align}\n className={contentClassName}\n onOpenAutoFocus={onOpenAutoFocus}\n onCloseAutoFocus={onCloseAutoFocus}\n portal={portal}\n id={`${id}-content`}\n >\n {children}\n </PopoverContent>\n </PopoverRoot>\n );\n};\nPopover.displayName = PopoverPrimitive.Root.displayName;\n\nexport { Popover, PopoverRoot, PopoverTrigger, PopoverContent };\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as ScrollAreaPrimitive from \"@radix-ui/react-scroll-area\";\n\nimport { cn } from \"@/src/utils\";\n\nconst ScrollArea = React.forwardRef<\n React.ElementRef<typeof ScrollAreaPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof ScrollAreaPrimitive.Root> & {\n viewPortClassName?: string;\n }\n>(({ className, viewPortClassName, children, ...props }, ref) => (\n <ScrollAreaPrimitive.Root\n ref={ref}\n className={cn(\"relative overflow-hidden\", className)}\n {...props}\n >\n <ScrollAreaPrimitive.Viewport\n className={cn(\"h-full w-full rounded-[inherit]\", viewPortClassName)}\n >\n {children}\n </ScrollAreaPrimitive.Viewport>\n <ScrollBar />\n <ScrollAreaPrimitive.Corner />\n </ScrollAreaPrimitive.Root>\n));\nScrollArea.displayName = ScrollAreaPrimitive.Root.displayName;\n\nconst ScrollBar = React.forwardRef<\n React.ElementRef<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>,\n React.ComponentPropsWithoutRef<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>\n>(({ className, orientation = \"vertical\", ...props }, ref) => (\n <ScrollAreaPrimitive.ScrollAreaScrollbar\n ref={ref}\n orientation={orientation}\n className={cn(\n \"flex touch-none select-none transition-colors\",\n orientation === \"vertical\" &&\n \"h-full w-2.5 border-l border-l-transparent p-[1px]\",\n orientation === \"horizontal\" &&\n \"h-2.5 flex-col border-t border-t-transparent p-[1px]\",\n className,\n )}\n {...props}\n >\n <ScrollAreaPrimitive.ScrollAreaThumb className=\"relative flex-1 rounded-full bg-[#959595] transition hover:bg-[#808080]\" />\n </ScrollAreaPrimitive.ScrollAreaScrollbar>\n));\nScrollBar.displayName = ScrollAreaPrimitive.ScrollAreaScrollbar.displayName;\n\nexport { ScrollArea, ScrollBar };\n","export const countryData = [\n {\n countryCode: \"GLOBAL\",\n countryName: \"Global\",\n currency: \"Dollars\",\n currencyCode: \"USD\",\n internetCountryCode: \"GLOBAL\",\n },\n {\n countryName: \"Benin\",\n countryCode: \"+229\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"BJ\",\n },\n {\n countryName: \"Burkina Faso\",\n countryCode: \"+226\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"BF\",\n },\n {\n countryName: \"Cameroon\",\n countryCode: \"+237\",\n currency: \"Central African CFA franc\",\n currencyCode: \"XAF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"CM\",\n },\n {\n countryName: \"Chad\",\n countryCode: \"+235\",\n currency: \"Central African CFA franc\",\n currencyCode: \"XAF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"TD\",\n },\n {\n countryName: \"DR Congo\",\n countryCode: \"+243\",\n currency: \"Congolese franc\",\n currencyCode: \"CDF\",\n currencyIcon: \"FC\",\n internetCountryCode: \"CD\",\n },\n {\n countryName: \"Eswatini\",\n countryCode: \"+268\",\n currency: \"Swazi lilangeni\",\n currencyCode: \"SZL\",\n currencyIcon: \"L\",\n internetCountryCode: \"SZ\",\n },\n {\n countryName: \"Gabon\",\n countryCode: \"+241\",\n currency: \"Central African CFA franc\",\n currencyCode: \"XAF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"GA\",\n },\n {\n countryName: \"Ghana\",\n countryCode: \"+233\",\n currency: \"Ghanaian cedi\",\n currencyCode: \"GHS\",\n currencyIcon: \"₵\",\n internetCountryCode: \"GH\",\n },\n {\n countryName: \"Guinea\",\n countryCode: \"+224\",\n currency: \"Guinean franc\",\n currencyCode: \"GNF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"GN\",\n },\n {\n countryName: \"Ivory Coast\",\n countryCode: \"+225\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"CI\",\n },\n {\n countryName: \"Kenya\",\n countryCode: \"+254\",\n currency: \"Kenyan shilling\",\n currencyCode: \"KES\",\n currencyIcon: \"Sh\",\n internetCountryCode: \"KE\",\n },\n {\n countryName: \"Lesotho\",\n countryCode: \"+266\",\n currency: \"Lesotho loti\",\n currencyCode: \"LSL\",\n currencyIcon: \"L\",\n internetCountryCode: \"LS\",\n },\n {\n countryName: \"Liberia\",\n countryCode: \"+231\",\n currency: \"Liberian dollar\",\n currencyCode: \"LRD\",\n currencyIcon: \"$\",\n internetCountryCode: \"LR\",\n },\n {\n countryName: \"Madagascar\",\n countryCode: \"+261\",\n currency: \"Malagasy ariary\",\n currencyCode: \"MGA\",\n currencyIcon: \"Ar\",\n internetCountryCode: \"MG\",\n },\n {\n countryName: \"Malawi\",\n countryCode: \"+265\",\n currency: \"Malawian kwacha\",\n currencyCode: \"MWK\",\n currencyIcon: \"MK\",\n internetCountryCode: \"MW\",\n },\n {\n countryName: \"Mali\",\n countryCode: \"+223\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"ML\",\n },\n {\n countryName: \"Mozambique\",\n countryCode: \"+258\",\n currency: \"Mozambican metical\",\n currencyCode: \"MZN\",\n currencyIcon: \"MT\",\n internetCountryCode: \"MZ\",\n },\n {\n countryName: \"Namibia\",\n countryCode: \"+264\",\n currency: \"Namibian dollar\",\n currencyCode: \"NAD\",\n currencyIcon: \"$\",\n internetCountryCode: \"NA\",\n },\n {\n countryName: \"Niger\",\n countryCode: \"+227\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"NE\",\n },\n {\n countryName: \"Nigeria\",\n countryCode: \"+234\",\n currency: \"Nigerian naira\",\n currencyCode: \"NGN\",\n currencyIcon: \"₦\",\n internetCountryCode: \"NG\",\n },\n {\n countryName: \"Republic of the Congo\",\n countryCode: \"+242\",\n currency: \"Central African CFA franc\",\n currencyCode: \"XAF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"CG\",\n },\n {\n countryName: \"Rwanda\",\n countryCode: \"+250\",\n currency: \"Rwandan franc\",\n currencyCode: \"RWF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"RW\",\n },\n {\n countryName: \"Senegal\",\n countryCode: \"+221\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"SN\",\n },\n {\n countryName: \"Seychelles\",\n countryCode: \"+248\",\n currency: \"Seychellois rupee\",\n currencyCode: \"SCR\",\n currencyIcon: \"₨\",\n internetCountryCode: \"SC\",\n },\n {\n countryName: \"South Africa\",\n countryCode: \"+27\",\n currency: \"South African rand\",\n currencyCode: \"ZAR\",\n currencyIcon: \"R\",\n internetCountryCode: \"ZA\",\n },\n {\n countryName: \"South Sudan\",\n countryCode: \"+211\",\n currency: \"South Sudanese pound\",\n currencyCode: \"SSP\",\n currencyIcon: \"£\",\n internetCountryCode: \"SS\",\n },\n {\n countryName: \"Tanzania\",\n countryCode: \"+255\",\n currency: \"Tanzanian shilling\",\n currencyCode: \"TZS\",\n currencyIcon: \"Sh\",\n internetCountryCode: \"TZ\",\n },\n {\n countryName: \"Togo\",\n countryCode: \"+228\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"TG\",\n },\n {\n countryName: \"Uganda\",\n countryCode: \"+256\",\n currency: \"Ugandan shilling\",\n currencyCode: \"UGX\",\n currencyIcon: \"Sh\",\n internetCountryCode: \"UG\",\n },\n {\n countryName: \"Zambia\",\n countryCode: \"+260\",\n currency: \"Zambian kwacha\",\n currencyCode: \"ZMW\",\n currencyIcon: \"ZK\",\n internetCountryCode: \"ZM\",\n },\n];\n\nexport const getCountryDataMap = () => {\n const frequency = {} as Record<string, string>;\n\n countryData?.forEach((country) => {\n frequency[country?.internetCountryCode] = country?.countryName;\n });\n\n return frequency;\n};\n","\"use client\";\n\nimport * as React from \"react\";\n\nimport * as RPNInput from \"react-phone-number-input\";\n\nimport flags from \"react-phone-number-input/flags\";\n\nimport {\n Command,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n} from \"../command\";\nimport { Input, InputProps, inputContainerVariants } from \"../input\";\nimport { PopoverRoot, PopoverContent, PopoverTrigger } from \"../popover\";\n\nimport { cn } from \"@/src/utils\";\nimport { ScrollArea } from \"../scroll-area\";\nimport { VariantProps } from \"class-variance-authority\";\nimport FlatGlobeIcon from \"./Flag\";\nimport { FormLabel } from \"../label/FormLabel\";\nimport { FormDescription } from \"../form/FormDescription\";\nimport { ErrorMessage } from \"../form/ErrorMessage\";\n\nexport type PhoneInputValue = RPNInput.Value;\n\nexport type PhoneInputProps = Omit<\n React.InputHTMLAttributes<HTMLInputElement>,\n \"onChange\" | \"value\"\n> &\n Omit<RPNInput.Props<typeof RPNInput.default>, \"onChange\"> & {\n onChange?: (value: RPNInput.Value) => void;\n } & {\n status?: VariantProps<typeof inputContainerVariants>[\"status\"];\n defaultCountry?: RPNInput.Country;\n modal?: boolean;\n label?: string;\n showAsterisk?: boolean;\n description?: React.ReactNode;\n error?: string;\n };\n\nconst PhoneInput: React.ForwardRefExoticComponent<PhoneInputProps> =\n React.forwardRef<React.ElementRef<typeof RPNInput.default>, PhoneInputProps>(\n (\n {\n className,\n onChange,\n defaultCountry = \"NG\",\n modal,\n showAsterisk,\n label,\n description,\n error,\n ...props\n },\n ref,\n ) => {\n /**\n * did this so I can pass the status prop to the country\n * select so I can change the appearance based on the status\n */\n const CountrySelectWrapper = (innerProps: CountrySelectProps) => {\n return (\n <CountrySelect {...innerProps} status={props.status} modal={modal} />\n );\n };\n\n return (\n <div className=\"relative space-y-1\">\n <FormLabel showAsterisk={showAsterisk} error={error}>\n {label}\n </FormLabel>\n <RPNInput.default\n ref={ref}\n className={cn(\"flex\", className)}\n flagComponent={FlagComponent}\n countrySelectComponent={CountrySelectWrapper}\n inputComponent={InputComponent}\n defaultCountry={defaultCountry}\n /**\n * Handles the onChange event.\n *\n * react-phone-number-input might trigger the onChange event as undefined\n * when a valid phone number is not entered. To prevent this,\n * the value is coerced to an empty string.\n *\n * @param {E164Number | undefined} value - The entered value\n */\n onChange={(value) => {\n if (onChange) {\n onChange?.(value as RPNInput.Value);\n }\n }}\n {...props}\n />\n <FormDescription className=\"text-gray-400 text-sm !font-normal\">\n {description}\n </FormDescription>\n <ErrorMessage error={error} />\n </div>\n );\n },\n );\nPhoneInput.displayName = \"PhoneInput\";\n\nconst InputComponent = React.forwardRef<HTMLInputElement, InputProps>(\n ({ className, ...props }, ref) => {\n return (\n <Input\n className={cn(\"!rounded-s-none h-10\", className)}\n {...props}\n ref={ref}\n />\n );\n },\n);\nInputComponent.displayName = \"InputComponent\";\n\ntype CountrySelectOption = { label: string; value: RPNInput.Country };\n\ntype CountrySelectProps = {\n disabled?: boolean;\n modal?: boolean;\n value: RPNInput.Country;\n onChange: (value: RPNInput.Country) => void;\n options: CountrySelectOption[];\n status?: VariantProps<typeof inputContainerVariants>[\"status\"];\n};\n\nconst CountrySelect = ({\n disabled,\n value,\n onChange,\n options,\n status,\n modal,\n}: CountrySelectProps) => {\n const handleSelect = React.useCallback(\n (country: RPNInput.Country) => {\n onChange(country);\n },\n [onChange],\n );\n\n return (\n <PopoverRoot modal={modal}>\n <PopoverTrigger disabled={disabled}>\n <div\n className={cn(\n inputContainerVariants({ status }),\n \"transition justify-center items-center disabled:text-base-500 flex gap-3 h-10 rounded-e-none border-e-0 pl-2 pr-2\",\n )}\n >\n <FlagComponent country={value} countryName={value} />\n <svg\n className={cn(\n \"mr-0.5 h-4 w-4 opacity-50\",\n disabled ? \"hidden\" : \"opacity-100\",\n )}\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n >\n <path\n d=\"M16.5999 7.45825L11.1666 12.8916C10.5249 13.5333 9.4749 13.5333 8.83324 12.8916L3.3999 7.45825\"\n stroke=\"#959595\"\n strokeWidth=\"1.5\"\n strokeMiterlimit=\"10\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </div>\n </PopoverTrigger>\n <PopoverContent portal={!modal} className=\"w-[200px] md:w-[300px] p-0\">\n <Command>\n <CommandList>\n <ScrollArea className=\"h-72\">\n <CommandInput placeholder=\"Search country...\" />\n <CommandEmpty>No country found.</CommandEmpty>\n <CommandGroup>\n {options\n .filter((x) => x.value)\n .map((option) => (\n <CommandItem\n className=\"gap-2\"\n key={`${option.value}-${option.label}`}\n onSelect={() => handleSelect(option.value)}\n >\n <FlagComponent\n country={option.value}\n countryName={option.label}\n />\n <span className=\"flex-1 text-sm\">{option.label}</span>\n {option.value && (\n <span className=\"text-[#191919]/50 text-sm dark:text-white\">\n {`+${RPNInput.getCountryCallingCode(option.value)}`}\n </span>\n )}\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n className={cn(\n \"ml-auto\",\n option.value === value ? \"opacity-100\" : \"opacity-0\",\n )}\n >\n <path\n d=\"M4 8.00008L6.66353 10.6636L12 5.33655\"\n stroke=\"#959595\"\n strokeWidth=\"1.06667\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </CommandItem>\n ))}\n </CommandGroup>\n </ScrollArea>\n </CommandList>\n </Command>\n </PopoverContent>\n </PopoverRoot>\n );\n};\n\ntype FlagComponentProps = RPNInput.FlagProps & {\n className?: string;\n};\n\nconst FlagComponent = ({\n country,\n countryName,\n className,\n}: FlagComponentProps) => {\n const Flag = flags[country];\n\n if (country === (\"GLOBAL\" as unknown))\n return (\n <span\n className={cn(\n \"bg-white/20 flex h-4 w-6 overflow-hidden rounded-sm\",\n className,\n )}\n >\n <FlatGlobeIcon className=\"w-full h-[90%]\" />\n </span>\n );\n\n return (\n <span\n className={cn(\n \"bg-white/20 flex h-4 w-6 overflow-hidden rounded-sm\",\n className,\n )}\n >\n {Flag && <Flag title={countryName} />}\n </span>\n );\n};\nFlagComponent.displayName = \"FlagComponent\";\n\nexport { PhoneInput, FlagComponent };\n","// import React from 'react'\n\n// export const Flag = () => {\n// return (\n// <div>Flag</div>\n// )\n// }\n\nimport type React from \"react\";\n\nconst FlatGlobeIcon: React.FC<React.SVGProps<SVGSVGElement>> = (props) => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 32 32\"\n fill=\"none\"\n {...props}\n >\n <rect width=\"32\" height=\"32\" fill=\"#60A5FA\" /> {/* Ocean color */}\n {/* Continents */}\n <path\n d=\"M3 10L7 8L10 9L13 8L16 10L19 9L22 11L25 10L28 12V15L26 17L28 19L27 22L29 24L27 26L24 25L21 26L18 24L15 25L12 23L9 24L6 22L4 23L2 21V18L4 16L3 13L5 11L3 10Z\"\n fill=\"#34D399\"\n />\n {/* Antarctica */}\n <rect x=\"2\" y=\"28\" width=\"28\" height=\"3\" fill=\"#D1D5DB\" />\n {/* Grid lines */}\n <path\n d=\"M0 16H32M8 0V32M16 0V32M24 0V32\"\n stroke=\"#2563EB\"\n strokeWidth=\"0.5\"\n vectorEffect=\"non-scaling-stroke\"\n />\n {/* Equator */}\n <path\n d=\"M0 16H32\"\n stroke=\"#2563EB\"\n strokeWidth=\"1\"\n vectorEffect=\"non-scaling-stroke\"\n />\n </svg>\n );\n};\n\nexport default FlatGlobeIcon;\n","import { inputContainerVariants } from \"../input\";\nimport { Searchable, SearchableDataType } from \"../searcheable\";\nimport { VariantProps } from \"class-variance-authority\";\nimport { countryData, getCountryDataMap } from \"./data\";\nimport { PopoverTrigger } from \"../popover\";\nimport { cn } from \"@/src/utils\";\nimport { FlagComponent } from \"../phone-input\";\nimport { Country as CountryCode } from \"react-phone-number-input\";\nimport { FormLabel } from \"../label/FormLabel\";\nimport { FormDescription } from \"../form/FormDescription\";\nimport { ErrorMessage } from \"../form/ErrorMessage\";\n\ntype CountryPropsStatus = VariantProps<typeof inputContainerVariants>[\"status\"];\n\ninterface CountryProps {\n modal?: boolean;\n hideSearch?: boolean;\n loading?: boolean;\n inputValue?: string;\n onInputValueChange?: (arg: string) => void;\n disabled?: boolean;\n placeholder?: string;\n value?: SearchableDataType;\n optionComponent?: (arg: SearchableDataType) => React.ReactNode;\n className?: string;\n containerClassName?: string;\n onChange: (value: SearchableDataType) => void;\n status?: CountryPropsStatus;\n label?: string;\n showAsterisk?: boolean;\n description?: React.ReactNode;\n error?: string;\n}\n\ninterface CountryTriggerProps\n extends VariantProps<typeof inputContainerVariants> {\n disabled?: boolean;\n placeholder?: string;\n value?: string;\n className?: string;\n}\n\nconst countryMap = getCountryDataMap();\n\nconst CountryTrigger = ({\n className,\n value,\n placeholder = \"\",\n status,\n disabled,\n}: CountryTriggerProps) => {\n return (\n <PopoverTrigger asChild disabled={disabled}>\n <button\n disabled={disabled}\n className={cn(\n inputContainerVariants({ status }),\n \"[&>span]:justify-start [&>span]:items-center gap-2 flex w-full items-center justify-between goup\",\n value ? \"\" : \"text-[#79818C]\",\n className,\n )}\n >\n {value ? (\n <div className=\"flex gap-2 items-center\">\n <FlagComponent\n country={value as CountryCode}\n countryName={value}\n className=\"ml-1 !w-6 h-5\"\n />\n <span className=\"\"> {countryMap[value]}</span>\n </div>\n ) : (\n (placeholder ?? \"Select options...\")\n )}\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n className=\" data-[state=open]:goup-rotate-180\"\n >\n <path\n d=\"M16.5999 7.45825L11.1666 12.8916C10.5249 13.5333 9.4749 13.5333 8.83324 12.8916L3.3999 7.45825\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeMiterlimit=\"10\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </button>\n </PopoverTrigger>\n );\n};\n\nconst Country = ({\n hideSearch = true,\n showAsterisk,\n label,\n description,\n error,\n ...props\n}: CountryProps) => {\n const options = countryData?.map((country) => ({\n value: country?.internetCountryCode,\n label: country?.countryName,\n ...country,\n }));\n\n return (\n <div className=\"relative space-y-1\">\n <FormLabel showAsterisk={showAsterisk} error={error}>\n {label}\n </FormLabel>\n <Searchable\n options={options}\n hideSearch={hideSearch}\n optionComponent={(arg) => {\n return (\n <div className=\"w-full flex items-center gap-2\">\n <FlagComponent\n country={arg?.internetCountryCode}\n countryName={arg?.label}\n className=\"ml-2 !w-6 !h-5\"\n />\n <span className=\"flex-1 text-sm\">{arg?.label}</span>\n </div>\n );\n }}\n {...props}\n >\n <CountryTrigger\n value={props?.value?.value}\n status={props?.status}\n placeholder={props?.placeholder ?? \" Select Country\"}\n />\n </Searchable>\n <FormDescription className=\"text-gray-400 text-sm !font-normal\">\n {description}\n </FormDescription>\n <ErrorMessage error={error} />\n </div>\n );\n};\n\nexport { Country };\nexport type { CountryProps };\n\n//Todo -\n// dataSource - array of countries\n// availableCountries - countries to be filtered by countryCode\n","import { ErrorMessage } from \"../form/ErrorMessage\";\nimport { FormDescription } from \"../form/FormDescription\";\nimport { inputContainerVariants } from \"../input\";\nimport { FormLabel } from \"../label/FormLabel\";\nimport {\n Searchable,\n SearchableDataType,\n SearchableTrigger,\n} from \"../searcheable\";\nimport { VariantProps } from \"class-variance-authority\";\n\ntype SelectPropsStatus = VariantProps<typeof inputContainerVariants>[\"status\"];\n\ninterface SelectProps {\n modal?: boolean;\n hideSearch?: boolean;\n loading?: boolean;\n inputValue?: string;\n onInputValueChange?: (arg: string) => void;\n disabled?: boolean;\n placeholder?: string;\n value?: SearchableDataType;\n options: SearchableDataType[];\n optionComponent?: (arg: SearchableDataType) => React.ReactNode;\n className?: string;\n containerClassName?: string;\n onChange: (value: SearchableDataType) => void;\n status?: SelectPropsStatus;\n label?: string;\n showAsterisk?: boolean;\n description?: React.ReactNode;\n error?: string;\n id?: string;\n}\n\nconst Select = ({\n showAsterisk,\n label,\n description,\n error,\n hideSearch = true,\n status,\n ...props\n}: SelectProps) => {\n return (\n <div className=\"relative space-y-1\">\n <FormLabel showAsterisk={showAsterisk} error={error}>\n {label}\n </FormLabel>\n <Searchable\n hideSearch={hideSearch}\n {...props}\n containerClassName=\"h-full\"\n >\n <SearchableTrigger\n disabled={props?.disabled}\n placeholder={props?.placeholder ?? \"Select\"}\n status={status}\n value={props?.value?.label ?? props?.value?.value}\n className={props?.className}\n id={props?.id}\n />\n </Searchable>\n <FormDescription className=\"text-gray-400 text-sm !font-normal\">\n {description}\n </FormDescription>\n <ErrorMessage error={error} />\n </div>\n );\n};\n\nexport { Select };\nexport type { SelectProps };\n\n//Todo\n// onchange value\n","import OtpInput, { OTPInputProps as InputProps } from \"react-otp-input\";\nimport { cn } from \"@/src/utils\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { useMemo } from \"react\";\n\nconst otpInputVariants = cva(\n \"transition cursor-default placeholder:text-black dark:placeholder:text-white rounded-lg !h-14 !w-14 border aspect-square text-base font-semibold tracking-normal outline-none placeholder:text-sm placeholder:font-normal text-black focus:bg-white\",\n {\n variants: {\n status: {\n default:\n \"border-gray-300 dark:border-[#d4d4d4] focus:border-gray-400 focus-visible:!ring-offset-gray-200 focus:ring-offset-gray-200 !ring-gray-200 !focus-visible:ring-1 bg-white dark:!bg-transparent dark:focus-visible:!ring-0 dark:focus-within:!bg-transparent dark:text-white dark:focus-within:border-[#9299A2] dark:border-[#676767] dark:disabled:!border-[#9299A2]\",\n error:\n \"placeholder:text-red-600 bg-red-50 border-red-600 text-red-600 focus-within:bg-red-50 focus-within:border-red-600\",\n loading: \"placeholder:text-[#C4C4C4]\",\n },\n },\n defaultVariants: {\n status: \"default\",\n },\n },\n);\n\ntype DefailtInputProps = Omit<InputProps, \"renderInput\">;\n\nexport type OTPInputProps = DefailtInputProps &\n VariantProps<typeof otpInputVariants> & {};\n\nexport const OTPInput = ({\n numInputs = 4,\n inputStyle,\n containerStyle,\n placeholder = \"-\",\n status,\n ...props\n}: OTPInputProps) => {\n const placeholderValue = useMemo(() => {\n if (placeholder) return placeholder;\n\n const numInputArr = new Array<string>(numInputs).fill(\"\");\n const result = numInputArr.reduce((accumulator, currentValue) => {\n return (accumulator += currentValue);\n }, \"\");\n\n return result;\n }, [numInputs, placeholder]);\n\n return (\n <OtpInput\n numInputs={numInputs}\n placeholder={placeholderValue}\n containerStyle={cn(\"w-full\", containerStyle)}\n inputStyle={cn(otpInputVariants({ status }), inputStyle)}\n renderInput={(props) => <input {...props} />}\n {...props}\n />\n );\n};\n","import { useState, useEffect } from \"react\";\n\ninterface BannerTypes {\n type?: \"gray\" | \"info\" | \"warning\" | \"success\" | \"danger\";\n}\n\ninterface BannerProps extends BannerTypes {\n title?: React.ReactNode;\n description?: React.ReactNode;\n showIcon?: boolean;\n showCloseButton?: boolean;\n bottomNode?: React.ReactNode;\n sideNode?: React.ReactNode;\n open: boolean;\n onClose?: () => void;\n}\n\nconst Icon = ({ type }: BannerTypes) => {\n if (type === \"gray\") {\n return (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M10 0C4.49 0 0 4.49 0 10C0 15.51 4.49 20 10 20C15.51 20 20 15.51 20 10C20 4.49 15.51 0 10 0ZM14.78 7.7L9.11 13.37C8.97 13.51 8.78 13.59 8.58 13.59C8.38 13.59 8.19 13.51 8.05 13.37L5.22 10.54C4.93 10.25 4.93 9.77 5.22 9.48C5.51 9.19 5.99 9.19 6.28 9.48L8.58 11.78L13.72 6.64C14.01 6.35 14.49 6.35 14.78 6.64C15.07 6.93 15.07 7.4 14.78 7.7Z\"\n fill=\"#79818C\"\n />\n </svg>\n );\n } else if (type === \"info\") {\n return (\n <svg\n stroke=\"#70B6F6\"\n fill=\"#70B6F6\"\n stroke-width=\"0\"\n viewBox=\"0 0 16 16\"\n height=\"24\"\n width=\"24\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path d=\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16m.93-9.412-1 4.705c-.07.34.029.533.304.533.194 0 .487-.07.686-.246l-.088.416c-.287.346-.92.598-1.465.598-.703 0-1.002-.422-.808-1.319l.738-3.468c.064-.293.006-.399-.287-.47l-.451-.081.082-.381 2.29-.287zM8 5.5a1 1 0 1 1 0-2 1 1 0 0 1 0 2\"></path>\n </svg>\n );\n } else if (type === \"warning\") {\n return (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M9.99984 1.66663C5.40817 1.66663 1.6665 5.40829 1.6665 9.99996C1.6665 14.5916 5.40817 18.3333 9.99984 18.3333C14.5915 18.3333 18.3332 14.5916 18.3332 9.99996C18.3332 5.40829 14.5915 1.66663 9.99984 1.66663ZM9.37484 6.66663C9.37484 6.32496 9.65817 6.04163 9.99984 6.04163C10.3415 6.04163 10.6248 6.32496 10.6248 6.66663V10.8333C10.6248 11.175 10.3415 11.4583 9.99984 11.4583C9.65817 11.4583 9.37484 11.175 9.37484 10.8333V6.66663ZM10.7665 13.65C10.7248 13.7583 10.6665 13.8416 10.5915 13.925C10.5082 14 10.4165 14.0583 10.3165 14.1C10.2165 14.1416 10.1082 14.1666 9.99984 14.1666C9.8915 14.1666 9.78317 14.1416 9.68317 14.1C9.58317 14.0583 9.4915 14 9.40817 13.925C9.33317 13.8416 9.27484 13.7583 9.23317 13.65C9.1915 13.55 9.1665 13.4416 9.1665 13.3333C9.1665 13.225 9.1915 13.1166 9.23317 13.0166C9.27484 12.9166 9.33317 12.825 9.40817 12.7416C9.4915 12.6666 9.58317 12.6083 9.68317 12.5666C9.88317 12.4833 10.1165 12.4833 10.3165 12.5666C10.4165 12.6083 10.5082 12.6666 10.5915 12.7416C10.6665 12.825 10.7248 12.9166 10.7665 13.0166C10.8082 13.1166 10.8332 13.225 10.8332 13.3333C10.8332 13.4416 10.8082 13.55 10.7665 13.65Z\"\n fill=\"#FFC700\"\n />\n </svg>\n );\n } else if (type === \"success\") {\n return (\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M12 2C6.49 2 2 6.49 2 12C2 17.51 6.49 22 12 22C17.51 22 22 17.51 22 12C22 6.49 17.51 2 12 2ZM16.78 9.7L11.11 15.37C10.97 15.51 10.78 15.59 10.58 15.59C10.38 15.59 10.19 15.51 10.05 15.37L7.22 12.54C6.93 12.25 6.93 11.77 7.22 11.48C7.51 11.19 7.99 11.19 8.28 11.48L10.58 13.78L15.72 8.64C16.01 8.35 16.49 8.35 16.78 8.64C17.07 8.93 17.07 9.4 16.78 9.7Z\"\n fill=\"#00D488\"\n />\n </svg>\n );\n } else {\n return (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M9.99984 1.66663C5.40817 1.66663 1.6665 5.40829 1.6665 9.99996C1.6665 14.5916 5.40817 18.3333 9.99984 18.3333C14.5915 18.3333 18.3332 14.5916 18.3332 9.99996C18.3332 5.40829 14.5915 1.66663 9.99984 1.66663ZM9.37484 6.66663C9.37484 6.32496 9.65817 6.04163 9.99984 6.04163C10.3415 6.04163 10.6248 6.32496 10.6248 6.66663V10.8333C10.6248 11.175 10.3415 11.4583 9.99984 11.4583C9.65817 11.4583 9.37484 11.175 9.37484 10.8333V6.66663ZM10.7665 13.65C10.7248 13.7583 10.6665 13.8416 10.5915 13.925C10.5082 14 10.4165 14.0583 10.3165 14.1C10.2165 14.1416 10.1082 14.1666 9.99984 14.1666C9.8915 14.1666 9.78317 14.1416 9.68317 14.1C9.58317 14.0583 9.4915 14 9.40817 13.925C9.33317 13.8416 9.27484 13.7583 9.23317 13.65C9.1915 13.55 9.1665 13.4416 9.1665 13.3333C9.1665 13.225 9.1915 13.1166 9.23317 13.0166C9.27484 12.9166 9.33317 12.825 9.40817 12.7416C9.4915 12.6666 9.58317 12.6083 9.68317 12.5666C9.88317 12.4833 10.1165 12.4833 10.3165 12.5666C10.4165 12.6083 10.5082 12.6666 10.5915 12.7416C10.6665 12.825 10.7248 12.9166 10.7665 13.0166C10.8082 13.1166 10.8332 13.225 10.8332 13.3333C10.8332 13.4416 10.8082 13.55 10.7665 13.65Z\"\n fill=\"#F04248\"\n />\n </svg>\n );\n }\n};\n\nexport const Banner = ({\n type = \"info\",\n title,\n description,\n open,\n showCloseButton,\n bottomNode,\n sideNode,\n onClose,\n showIcon = true,\n}: BannerProps) => {\n const [isOpen, setIsOpen] = useState<boolean>(open);\n\n useEffect(() => {\n setIsOpen(open);\n }, [open]);\n\n let bgColor = \"\";\n let stripeColor = \"\";\n switch (type) {\n case \"gray\":\n bgColor = \"#eeeef0\";\n stripeColor = \"#79818c\";\n break;\n case \"info\":\n bgColor = \"#ebf5fd\";\n stripeColor = \"#70B6F6\";\n break;\n case \"warning\":\n bgColor = \"#fff8df\";\n stripeColor = \"#ffc700\";\n break;\n case \"success\":\n bgColor = \"#e0f9f0\";\n stripeColor = \"#49e0aa\";\n break;\n case \"danger\":\n bgColor = \"#fde8e9\";\n stripeColor = \"#f3777c\";\n break;\n default:\n bgColor = \"#eeeef0\";\n stripeColor = \"#79818c\";\n break;\n }\n\n function handleClose() {\n setIsOpen(false);\n if (onClose) {\n onClose();\n }\n }\n\n if (!isOpen) {\n return null;\n }\n\n return (\n <div\n className=\"w-full shadow-lg transform flex items-center rounded-md\"\n style={{\n background: bgColor || \"#ebf5fd\",\n }}\n >\n <div\n className=\"flex-none absolute rounded-l-[2px] rounded-l-4px h-[4px] w-full top-0\"\n style={{\n background: stripeColor || \"#70B6F6\",\n }}\n />\n\n <div className=\"w-full gap-3 h-full flex flex-row justify-between px-4 md:px-4 py-3 md:py-4\">\n <div className=\"flex flex-row gap-2.5 items-start w-full h-full\">\n {showIcon && (\n <div className=\"h-full flex justify-end\">\n <Icon type={type} />\n </div>\n )}\n\n <div className=\"w-full gap-3 h-full flex flex-col md:flex-row items-start justify-between\">\n <div className=\"flex-1 gap-3 h-full flex flex-col items-start justify-between\">\n {(title || description) && (\n <div>\n {title && (\n <div className=\"text-sm font-bold text-[#191919]\">\n {title}\n </div>\n )}\n {description && (\n <div className=\"text-sm font-normal text-[#5D5D5D] mt-1\">\n {description}\n </div>\n )}\n </div>\n )}\n\n {bottomNode}\n </div>\n {sideNode}\n </div>\n </div>\n\n {showCloseButton && (\n <div className=\"w-1/10 h-full flex flex-col justify-start items-center\">\n <button onClick={handleClose}>\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M3.3335 3.33337L12.6662 12.6661\"\n stroke=\"#191919\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M3.33429 12.6661L12.667 3.33337\"\n stroke=\"#191919\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </button>\n </div>\n )}\n </div>\n </div>\n );\n};\n","import { useState } from \"react\";\nimport { Copy, CheckIcon } from \"lucide-react\";\nimport { motion, AnimatePresence } from \"framer-motion\";\nimport { cn } from \"@/src/utils\";\nimport { TextOverflow } from \"../text-overflow\";\n\ninterface CopyableLabelProps {\n text: string;\n textToCopy?: string; //this is coppied to the clipboard if passed as a prop instead of the text prop passed else defaults to the text prop\n onCopy?: () => void;\n iconsPosition?: \"left\" | \"right\";\n clampText?: boolean;\n textClassName?: string;\n clampMode?: \"truncate\" | \"wrap\";\n isLink?: boolean;\n}\n\nconst CopyableLabel: React.FC<CopyableLabelProps> = ({\n text,\n textToCopy,\n onCopy,\n iconsPosition = \"right\",\n clampText = true,\n clampMode = \"truncate\",\n isLink = false,\n textClassName,\n}) => {\n const [copied, setCopied] = useState(false);\n\n const copyToClipboard = () => {\n navigator.clipboard.writeText(textToCopy ?? text).then(() => {\n setCopied(true);\n onCopy?.();\n setTimeout(() => setCopied(false), 2000);\n });\n };\n\n const Icon = copied ? CheckIcon : Copy;\n\n return (\n <div className=\"flex items-center space-x-2 cursor-pointer text-[#717171] bg-gray-100 w-fit max-w-full rounded-md p-1 px-2\">\n {iconsPosition === \"left\" && (\n <AnimatedIcon Icon={Icon} onClick={copyToClipboard} copied={copied} />\n )}\n <TextOverflow\n as={isLink ? \"a\" : \"span\"}\n mode={!clampText ? \"overflow\" : clampMode}\n className={cn({ underline: isLink }, textClassName)}\n href={isLink ? text : undefined}\n >\n {text}\n </TextOverflow>\n\n {iconsPosition === \"right\" && (\n <AnimatedIcon Icon={Icon} onClick={copyToClipboard} copied={copied} />\n )}\n </div>\n );\n};\n\nconst AnimatedIcon: React.FC<{\n Icon: React.ElementType;\n onClick: () => void;\n copied: boolean;\n}> = ({ Icon, onClick, copied }) => (\n <AnimatePresence mode=\"wait\">\n <motion.div\n key={copied ? \"check\" : \"copy\"}\n initial={{ opacity: 0, scale: 0.8 }}\n animate={{ opacity: 1, scale: 1 }}\n exit={{ opacity: 0, scale: 0.8 }}\n transition={{ duration: 0.2 }}\n onClick={onClick}\n >\n <Icon\n className={`w-5 h-5 ${copied ? \"text-green-500\" : \"text-gray-500 hover:text-gray-700 transition\"}`}\n />\n </motion.div>\n </AnimatePresence>\n);\n\nexport { CopyableLabel };\n","import { cn } from \"@/src/utils\";\nimport React from \"react\";\n\nexport interface TextOverflowProps extends React.HTMLAttributes<HTMLElement> {\n children: React.ReactNode;\n mode?: \"wrap\" | \"truncate\" | \"overflow\";\n as?: React.ElementType;\n href?: string;\n}\n/**\n * TextOverflow is a React component that controls how text overflows its container.\n *\n * Props:\n * - children: ReactNode - The content to display.\n * - mode: \"truncate\" | \"wrap\" | \"overflow\" (default: \"truncate\")\n * - \"truncate\": Single line, truncated with ellipsis.\n * - \"wrap\": Allows text to wrap onto multiple lines.\n * - \"overflow\": No special overflow handling.\n * - as: React.ElementType - The HTML element or React component to render as the container (default: \"div\").\n * - href: string (optional) - If provided and 'as' is an anchor, sets the link target to \"_blank\".\n * - className: string (optional) - Additional CSS classes for the container.\n * - ...rest: Other HTML attributes passed to the container.\n */\nexport const TextOverflow = ({\n children,\n mode = \"truncate\",\n className,\n as: Component = \"div\",\n ...rest\n}: TextOverflowProps) => {\n return (\n <Component\n className={cn(\n {\n \"text-ellipsis overflow-hidden whitespace-nowrap\":\n mode === \"truncate\",\n \"whitespace-normal break-words\": mode === \"wrap\",\n \"\": mode === \"overflow\",\n },\n className,\n )}\n target={rest?.href ? \"_blank\" : undefined}\n {...rest}\n >\n {children}\n </Component>\n );\n};\n","import React, { ChangeEvent, useEffect, useState } from \"react\";\nimport { BaseInnerInputProps, Input } from \"../input\";\nimport { cn } from \"@/src/utils\";\nimport { Search } from \"lucide-react\";\n\ntype DebouncedInputProps = {\n value?: string;\n\n onChange: (e: string) => void;\n debounce?: number;\n addon?: React.ReactNode;\n} & Omit<BaseInnerInputProps, \"onChange\" | \"size\">;\n\nexport const DebouncedInput = ({\n value: initialValue,\n onChange,\n debounce = 500,\n addon,\n ...props\n}: DebouncedInputProps) => {\n const [value, setValue] = useState<string>(initialValue ?? \"\");\n\n const handleInputChange = (event: ChangeEvent<HTMLInputElement>) =>\n setValue(event.target.value);\n\n useEffect(() => {\n if (!initialValue) return;\n setValue(initialValue);\n }, [initialValue]);\n\n useEffect(() => {\n const timeout = setTimeout(() => {\n onChange(value);\n }, debounce);\n\n return () => clearTimeout(timeout);\n }, [value, debounce, onChange]);\n\n return (\n <Input\n leftNode={\n (addon as React.ReactElement) ?? (\n <Search className=\" w-4 h-4 text-gray-400\" />\n )\n }\n sideNodeClassName=\"bg-transparent !pr-0 !w-4 border-0 !min-w-[40px]\"\n {...props}\n className={cn(\n \"!pl-0 py-1 border-[.5px] border-[#E9EBF8] rounded-xl text-sm w-full h-8 focus:outline-none focus:placeholder:hidden focus:!ring-2 !focus:ring-primary-main bg-[#F5F8FF] focus-within:!bg-transparent placeholder:text-xs\",\n props?.className,\n )}\n onChange={handleInputChange}\n value={value}\n />\n );\n};\n","import { useEffect } from \"react\";\nimport { X } from \"lucide-react\";\n\ntype Props = {\n environment: \"staging\" | \"sandbox\" | \"production\";\n branch: string;\n version: string;\n deployTime: string;\n onClose: () => void;\n showBanner: boolean;\n initDefault: () => void;\n removeFromStorage: () => void;\n syncLocalStorageToState: () => void;\n};\nexport const DevBanner = (props: Props) => {\n const {\n environment,\n branch,\n version,\n deployTime,\n showBanner,\n onClose,\n initDefault,\n removeFromStorage,\n syncLocalStorageToState,\n } = props;\n\n const currentEnv = environment || process.env.NEXT_PUBLIC_NODE_ENV;\n\n // Early return must happen before any hooks\n if (currentEnv !== \"staging\" && currentEnv !== \"sandbox\") {\n return null;\n }\n\n useEffect(() => {\n // Sync localstorage value to showBanner state\n syncLocalStorageToState();\n }, [syncLocalStorageToState]);\n\n useEffect(() => {\n let interval: NodeJS.Timeout;\n\n if (currentEnv === \"staging\" || currentEnv === \"sandbox\") {\n interval = setInterval(\n () => {\n removeFromStorage();\n initDefault();\n },\n 5 * 60 * 1000, // 5 minutes in milliseconds\n );\n }\n\n return () => {\n if (interval) {\n clearInterval(interval);\n }\n };\n }, [\n showBanner,\n environment,\n onClose,\n removeFromStorage,\n initDefault,\n currentEnv,\n ]);\n\n if (!showBanner) return null;\n\n return (\n <div className=\"w-fit p-4 border shadow-md bg-white rounded-md z-[99999] absolute top-2 right-2 min-w-96\">\n <button onClick={onClose} className=\"absolute top-2 right-2\">\n <X />\n </button>\n <div className=\"space-y-2 text-sm\">\n <div className=\"flex gap-2\">\n <span className=\"font-medium\">Environment:</span>\n <span className=\"text-blue-600 capitalize\">{currentEnv}</span>\n </div>\n <div className=\"flex gap-2\">\n <span className=\"font-medium\">Branch:</span>\n <span className=\"text-green-600 capitalize\">\n {branch || process.env.NEXT_PUBLIC_DEPLOY_BRANCH}\n </span>\n </div>\n <div className=\"flex gap-2\">\n <span className=\"font-medium\">Version:</span>\n <span className=\"text-purple-600\">\n {version || process.env.NEXT_PUBLIC_DEPLOY_VERSION}\n </span>\n </div>\n <div className=\"flex gap-2\">\n <span className=\"font-medium\">Deploy Time:</span>\n <span className=\"text-orange-600\">\n {deployTime || process.env.NEXT_PUBLIC_DEPLOY_TIME}\n </span>\n </div>\n </div>\n </div>\n );\n};\n","// import React from 'react'\n\n// export const Drawer = () => {\n// return (\n// <div>Drawer</div>\n// )\n// }\n\n\"use client\";\n\nimport * as React from \"react\";\nimport { Drawer as DrawerPrimitive } from \"vaul\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\n\nimport { cn } from \"@/src/utils\";\nimport { DialogCloseProps } from \"@radix-ui/react-dialog\";\nimport { CloseIcon } from \"./icon/CloseIcon\";\nimport { useWindowSize } from \"@/src/hooks/useWindowSize\";\n\ntype DrawerRootType = React.ComponentProps<typeof DrawerPrimitive.Root> & {\n id?: string;\n};\n\nconst DrawerRoot = ({\n shouldScaleBackground = true,\n ...props\n}: DrawerRootType) => (\n <DrawerPrimitive.Root\n direction=\"right\"\n shouldScaleBackground={shouldScaleBackground}\n {...props}\n />\n);\n\nDrawerRoot.displayName = \"Drawer\";\n\nconst DrawerTrigger = DrawerPrimitive.Trigger;\n\nconst DrawerClose: React.ForwardRefExoticComponent<\n DialogCloseProps & React.RefAttributes<HTMLButtonElement>\n> = DrawerPrimitive.Close;\n\nconst DrawerPortal = DrawerPrimitive.Portal;\n\nconst DrawerOverlay = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Overlay>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n <DrawerPrimitive.Overlay\n className={cn(\n \"fixed inset-0 z-40 bg-black/75 !m-0 !p-0 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0\",\n className,\n )}\n {...props}\n ref={ref}\n />\n));\n\nDrawerOverlay.displayName = DrawerPrimitive.Overlay.displayName;\n\nconst DrawerVariants = cva(\n \"fixed focus-visible:outline-0 z-50 gap-4 bg-white shadow-lg dark:bg-[#2B2B2B] dark:text-white transition ease-in-out data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:duration-300 data-[state=open]:duration-500 dark:border-none !select-text\",\n {\n variants: {\n side: {\n top: \"inset-x-0 top-0 border-b data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top rounded-b-lg\",\n bottom:\n \"inset-x-0 bottom-0 border-t data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom rounded-t-lg\",\n left: \"inset-y-0 left-0 h-full w-3/4 border-r data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left sm:max-w-[512px] \",\n right:\n \"inset-y-0 right-0 h-full w-3/4 border-l data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right sm:max-w-[512px]\",\n },\n },\n defaultVariants: {\n side: \"right\",\n },\n },\n);\n\ninterface SheetContentProps\n extends React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Content>,\n VariantProps<typeof DrawerVariants> {}\n\nconst DrawerContent = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Content>,\n SheetContentProps & {\n hideCloseButton?: boolean;\n }\n>(\n (\n { side = \"right\", hideCloseButton, className, children, id, ...props },\n ref,\n ) => (\n <DrawerPortal>\n <DrawerOverlay />\n <DrawerPrimitive.Content\n ref={ref}\n className={cn(DrawerVariants({ side }), className)}\n {...props}\n >\n <button className=\"bg-gray-300 block md:!hidden mx-auto mt-4 md:!mt-0 h-1.5 w-[80px] rounded-full opacity-70 transition-opacity hover:opacity-100 relative\" />\n {children}\n {!hideCloseButton && (\n <DrawerPrimitive.Close\n id={`${id}-close-button`}\n className=\"absolute right-2 top-3 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-secondary\"\n >\n <CloseIcon />\n\n <span className=\"sr-only\">Close</span>\n </DrawerPrimitive.Close>\n )}\n </DrawerPrimitive.Content>\n </DrawerPortal>\n ),\n);\n\nDrawerContent.displayName = DrawerPrimitive.Content.displayName;\n\nconst DrawerHeader = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\n \"text-lg flex flex-col border-b border-b-gray-200 space-y-1 text-left w-full p-3\",\n className,\n )}\n {...props}\n />\n);\n\nDrawerHeader.displayName = \"DrawerHeader\";\n\nconst DrawerFooter = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\n \"flex flex-col-reverse sm:flex-row m-auto right-0 left-0 p-3 sm:space-x-2 border-t border-t-[#EDEDED] dark:border-t-[#242424] w-full\",\n className,\n )}\n {...props}\n />\n);\n\nDrawerFooter.displayName = \"DrawerFooter\";\n\nconst DrawerTitle = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Title>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Title>\n>(({ className, ...props }, ref) => (\n <DrawerPrimitive.Title\n ref={ref}\n className={cn(\n \"text-xl font-semibold text-[#191919] dark:text-white\",\n className,\n )}\n {...props}\n />\n));\n\nDrawerTitle.displayName = DrawerPrimitive.Title.displayName;\n\nconst DrawerDescription = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Description>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Description>\n>(({ className, ...props }, ref) => (\n <DrawerPrimitive.Description\n ref={ref}\n className={cn(\"text-xs text-[#5d5c5c] dark:text-white\", className)}\n {...props}\n />\n));\n\nDrawerDescription.displayName = DrawerPrimitive.Description.displayName;\n\nexport type DrawerPropsType = {\n trigger?: React.ReactNode;\n children: React.ReactNode;\n title?: React.ReactNode;\n description?: React.ReactNode;\n footer?: React.ReactNode;\n hideCloseButton?: boolean;\n contentClassName?: string;\n drawerContentClassName?: string;\n headerClassName?: string;\n titleClassName?: string;\n descriptionClassName?: string;\n footerClassName?: string;\n asChild?: boolean;\n onOpenAutoFocus?: (e: Event) => void;\n onCloseAutoFocus?: (e: Event) => void;\n};\n\nconst Drawer = ({\n trigger = undefined,\n children,\n open = undefined,\n onOpenChange = undefined,\n hideCloseButton,\n footer,\n title,\n description,\n contentClassName,\n headerClassName,\n titleClassName,\n descriptionClassName,\n footerClassName,\n asChild = true,\n onOpenAutoFocus,\n drawerContentClassName,\n onCloseAutoFocus,\n id = \"drawer\",\n}: Omit<DrawerRootType, \"value\"> & DrawerPropsType) => {\n const { width } = useWindowSize();\n const direction = width < 768 ? \"bottom\" : \"right\";\n\n return (\n <DrawerRoot open={open} onOpenChange={onOpenChange} direction={direction}>\n <DrawerTrigger\n className=\"cursor-pointer\"\n asChild={asChild}\n id={`${id}-open-trigger`}\n >\n {trigger}\n </DrawerTrigger>\n <DrawerContent\n className={cn(\n \"flex flex-col gap-0 justify-start items-start max-h-[90vh] md:max-h-full w-full !max-w-md\",\n contentClassName,\n )}\n side={direction}\n hideCloseButton={hideCloseButton}\n onOpenAutoFocus={onOpenAutoFocus}\n onCloseAutoFocus={onCloseAutoFocus}\n id={`${id}-content`}\n >\n {title || description ? (\n <DrawerHeader className={headerClassName} id={`${id}-header`}>\n {title && (\n <DrawerTitle className={titleClassName} id={`${id}-title`}>\n {title}\n </DrawerTitle>\n )}\n {description && (\n <DrawerDescription\n id={`${id}-description`}\n className={descriptionClassName}\n >\n {description}\n </DrawerDescription>\n )}\n </DrawerHeader>\n ) : (\n <></>\n )}\n\n <div\n className={cn(\n \"flex w-full overflow-y-auto flex-col justify-start items-start p-4 flex-1 h-[30px]\",\n drawerContentClassName,\n )}\n >\n {children}\n </div>\n\n {footer && (\n <DrawerFooter className={footerClassName}>{footer}</DrawerFooter>\n )}\n </DrawerContent>\n </DrawerRoot>\n );\n};\n\nexport { Drawer, DrawerRoot, DrawerClose };\n","export const CloseIcon = () => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n className=\"lucide lucide-x\"\n >\n <path d=\"M18 6 6 18\" />\n <path d=\"m6 6 12 12\" />\n </svg>\n );\n};\n","import { useState, useEffect } from \"react\";\n\ntype WindowSize = {\n width: number;\n height: number;\n};\n\nexport function useWindowSize(): WindowSize {\n const [windowSize, setWindowSize] = useState<WindowSize>({\n width: 100,\n height: 100,\n });\n\n useEffect(() => {\n function handleResize() {\n setWindowSize({\n width: window.innerWidth,\n height: window.innerHeight,\n });\n }\n\n window.addEventListener(\"resize\", handleResize);\n\n handleResize();\n\n return () => window.removeEventListener(\"resize\", handleResize);\n }, []);\n\n return windowSize;\n}\n","export const Check = () => {\n return (\n <svg\n stroke=\"currentColor\"\n fill=\"currentColor\"\n strokeWidth=\"0\"\n viewBox=\"0 0 20 20\"\n aria-hidden=\"true\"\n className=\"h-5 w-5\"\n height=\"1em\"\n width=\"1em\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fillRule=\"evenodd\"\n d=\"M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z\"\n clipRule=\"evenodd\"\n ></path>\n </svg>\n );\n};\n","import { SVGProps } from \"react\";\n\nexport const EnglishFlag = (props: SVGProps<SVGSVGElement>) => {\n return (\n <svg\n viewBox=\"0 0 60 30\"\n className=\"w-full max-w-md h-auto\"\n aria-label=\"Union Jack - Flag of the United Kingdom\"\n {...props}\n >\n {/* Blue background */}\n <rect width=\"60\" height=\"30\" fill=\"#00247D\" />\n\n {/* White diagonal crosses */}\n <path d=\"M0,0 L60,30 M60,0 L0,30\" stroke=\"#FFFFFF\" strokeWidth=\"6\" />\n\n {/* Red diagonal crosses */}\n <path d=\"M0,0 L60,30 M60,0 L0,30\" stroke=\"#CF142B\" strokeWidth=\"4\" />\n\n {/* White cross */}\n <path d=\"M30,0 L30,30 M0,15 L60,15\" stroke=\"#FFFFFF\" strokeWidth=\"10\" />\n\n {/* Red cross */}\n <path d=\"M30,0 L30,30 M0,15 L60,15\" stroke=\"#CF142B\" strokeWidth=\"6\" />\n </svg>\n );\n};\n","import { SVGProps } from \"react\";\n\nexport const FrenchFlag = (props: SVGProps<SVGSVGElement>) => {\n return (\n <svg\n viewBox=\"0 0 60 40\"\n className=\"w-full max-w-md h-auto\"\n aria-label=\"Tricolore - Flag of France\"\n {...props}\n >\n {/* Blue stripe */}\n <rect x=\"0\" y=\"0\" width=\"20\" height=\"40\" fill=\"#002395\" />\n\n {/* White stripe */}\n <rect x=\"20\" y=\"0\" width=\"20\" height=\"40\" fill=\"#FFFFFF\" />\n\n {/* Red stripe */}\n <rect x=\"40\" y=\"0\" width=\"20\" height=\"40\" fill=\"#ED2939\" />\n </svg>\n );\n};\n","export const UpDownIcon = () => {\n return (\n <svg\n width=\"20\"\n height=\"18\"\n viewBox=\"0 0 8 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M5.50257 12.9395L3.68439 14.7576L1.86621 12.9395\"\n stroke=\"currentColor\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M5.50257 5.06055L3.68439 3.24237L1.86621 5.06055\"\n stroke=\"currentColor\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n};\n","import { cn } from \"@/src/utils\";\nimport { PopoverContent, PopoverRoot, PopoverTrigger } from \"../popover\";\nimport { Check } from \"./icons/Check\";\nimport { EnglishFlag } from \"./icons/EnglishFlag\";\nimport { FrenchFlag } from \"./icons/FrenchFlag\";\nimport { UpDownIcon } from \"./icons/UpDownIcon\";\nimport { PopoverClose } from \"@radix-ui/react-popover\";\n\nconst localeListOptons = [\n {\n key: \"en\",\n label: \"English\",\n },\n {\n key: \"fr\",\n label: \"French\",\n },\n];\n\ntype LocaleOption = {\n key: string;\n label: string;\n};\n\nconst LocaleIcon = ({ locale }: { locale?: string }) => {\n if (locale === \"fr\") return <FrenchFlag width={10} />;\n return <EnglishFlag width={10} />;\n};\n\nconst LocaleTrigger = ({ locale }: { locale?: string }) => {\n return (\n <div className=\"px-2 py-1 \">\n <div className=\"flex items-center gap-2.5\">\n <LocaleIcon locale={locale} />{\" \"}\n <span className=\"uppercase\">{locale}</span>\n <UpDownIcon />\n </div>\n </div>\n );\n};\n\nexport const LocaleSelector = ({\n locale = \"en\",\n onChange,\n locales = localeListOptons,\n}: {\n locale?: string;\n onChange?: (locale: string) => void;\n locales?: LocaleOption[];\n}) => {\n return (\n <PopoverRoot>\n <div className=\"flex items-center gap-2 px-2 py-1 rounded-lg shadow border-[0.5px] border-gray-50/50 text-current bg-white/10 \">\n <PopoverTrigger className={\"!p-0 !bg-transparent \"}>\n <LocaleTrigger locale={locale} />\n </PopoverTrigger>\n </div>\n <PopoverContent\n side=\"bottom\"\n className=\"p-0 max-w-max rounded-md overflow-hidden mx-auto mt-2\"\n >\n <div>\n {locales?.map((_locale) => (\n <PopoverClose\n type=\"button\"\n key={_locale?.key}\n className={cn(\n \"flex items-center gap-3 px-3 py-1 text-sm hover:bg-blue-50 w-full transition-all\",\n { \"bg-blue-100\": locale && locale === _locale?.key },\n )}\n onClick={() => onChange?.(_locale?.key)}\n >\n {_locale?.label} {locale && locale === _locale?.key && <Check />}\n </PopoverClose>\n ))}\n </div>\n </PopoverContent>\n </PopoverRoot>\n );\n};\n","import { useMemo, useRef, useState } from \"react\";\nimport { BusinessBar } from \"./business/BusinessBar\";\nimport { SidebarProps } from \"./utils/types\";\nimport { NavItems } from \"./NavItems\";\nimport { cn } from \"@/src/utils\";\nimport { X } from \"lucide-react\";\nimport { OpenSidebarIcon } from \"./components/OpenSidebarIcon\";\nimport { ClosedSidebarIcon } from \"./components/ClosedSidebarIcon\";\nimport { SidebarToggle } from \"./components/SidebarToggle\";\n\nexport const Sidebar = ({\n isSidebarCollapsed,\n onToggleSideBar,\n isMobile,\n links,\n businessProps,\n currentPath,\n onNavigate,\n appConfig,\n collapseType: propCollapseType,\n onLogoutClick,\n openSidebarIcon = <OpenSidebarIcon />,\n closedSidebarIcon = <ClosedSidebarIcon />,\n nodeAfterSideBarLogo,\n}: SidebarProps) => {\n const collapseType = useMemo(() => {\n if (isMobile) return \"hidden\";\n\n return propCollapseType || (isMobile ? \"hidden\" : \"icons\");\n }, [isMobile, propCollapseType]);\n\n const [isBusinessShown, setIsBusinessShown] = useState(false);\n const isIconsOnly = collapseType === \"icons\" && isSidebarCollapsed;\n const sideBarRef = useRef(null);\n const {\n businessList,\n activeBusiness,\n toggleAddBusinessDrawer,\n handleSetActiveBusiness,\n } = businessProps;\n\n const toggleShowBusiness = (isBusinessShown: boolean) =>\n setIsBusinessShown(isBusinessShown);\n\n const handleSwitchBusiness = (clientId: string) => {\n handleSetActiveBusiness?.(clientId);\n toggleShowBusiness(false);\n };\n\n const sideBarLogo = useMemo(() => {\n if (collapseType === \"hidden\") {\n return openSidebarIcon;\n }\n\n return isSidebarCollapsed ? closedSidebarIcon : openSidebarIcon;\n }, [isSidebarCollapsed, openSidebarIcon, closedSidebarIcon, collapseType]);\n\n const showBackdrop =\n isMobile && collapseType === \"hidden\" && isSidebarCollapsed;\n\n return (\n <>\n {showBackdrop && (\n <div\n className=\"fixed inset-0 z-40 bg-black bg-opacity-40 transition-all animate-in fade-in-15\"\n onClick={() => onToggleSideBar(false)}\n />\n )}\n\n <div\n className={cn(\"relative flex flex-row h-full\", {\n \"fixed inset-0 z-50 pointer-events-none\": showBackdrop,\n })}\n >\n <div className=\"absolute -right-[22px] top-0 z-30\">\n {collapseType === \"icons\" && (\n <SidebarToggle\n isSidebarCollapsed={isSidebarCollapsed}\n onToggleSideBar={onToggleSideBar}\n />\n )}\n </div>\n\n <aside\n id=\"sidebar_menu\"\n ref={sideBarRef}\n className={cn(\n \"relative pt-4 h-full max-h-screen bg-[#FBFBFB] overflow-hidden flex-col flex transition-all duration-300 w-64 gap-y-5\",\n {\n \"!fixed\": collapseType === \"hidden\",\n \"w-[311px]\": isSidebarCollapsed && collapseType !== \"icons\",\n \"w-[75px]\": isSidebarCollapsed && collapseType === \"icons\",\n \"w-[270px]\": !isSidebarCollapsed && collapseType === \"icons\",\n \"w-0 lg:w-0 pointer-events-none\":\n !isSidebarCollapsed && collapseType === \"hidden\",\n \"pointer-events-auto\":\n isSidebarCollapsed && collapseType === \"hidden\",\n \"left-0 top-0\": isMobile && collapseType === \"hidden\",\n \"-translate-x-full\":\n !isSidebarCollapsed && isMobile && collapseType !== \"hidden\",\n \"translate-x-0\":\n isSidebarCollapsed && isMobile && collapseType === \"hidden\",\n },\n )}\n >\n <div\n className={cn(\"flex items-center py-2 justify-center w-full\", {\n \"justify-between px-2\": isMobile,\n })}\n >\n <section\n className={cn({\n \"ml-2\": isMobile,\n \"-ml-16\": !isSidebarCollapsed,\n })}\n >\n {sideBarLogo}\n </section>\n\n {collapseType === \"hidden\" && (\n <div\n onClick={() => onToggleSideBar(false)}\n className=\"flex items-center gap-2 text-3xl cursor-pointer mr-5\"\n >\n <X size={24} className=\"text-black hover:opacity-60\" />\n </div>\n )}\n </div>\n\n {nodeAfterSideBarLogo}\n\n <div className=\"flex-1 overflow-y-auto px-0 h-full max-h-[calc(100vh-200px)]\">\n <NavItems\n isIconsOnly={isIconsOnly}\n collapseType={collapseType}\n currentPath={currentPath}\n isSidebarCollapsed={isSidebarCollapsed}\n links={links}\n onNavigate={onNavigate}\n onToggleSideBar={onToggleSideBar}\n appConfig={appConfig}\n isMobile={isMobile}\n />\n </div>\n\n <div className=\"absolute bottom-5 w-full\">\n <BusinessBar\n activeBusiness={activeBusiness}\n handleSwitchBusiness={handleSwitchBusiness}\n isBusinessShown={isBusinessShown}\n toggleAddBusinessDrawer={toggleAddBusinessDrawer}\n toggleShowBusiness={toggleShowBusiness}\n businesses={businessList || []}\n iconOnly={collapseType === \"icons\" ? isSidebarCollapsed : false}\n onLogoutClick={onLogoutClick}\n isMobile={isMobile}\n onToggleSideBar={onToggleSideBar}\n collapseType={collapseType}\n />\n </div>\n </aside>\n </div>\n </>\n );\n};\n","import { AnimatePresence, motion } from \"framer-motion\";\nimport { ChangeEvent, useMemo, useState } from \"react\";\nimport { HiCheck } from \"react-icons/hi\";\nimport { FiLogOut } from \"react-icons/fi\";\nimport { BsPlus } from \"react-icons/bs\";\nimport { cn } from \"@/src/utils\";\nimport { BusinessType } from \"@/src/utils/types\";\nimport { Input } from \"@/src/components/input\";\nimport { BusinessBarTrigger } from \"./Trigger\";\nimport { ChevronUp } from \"lucide-react\";\nimport { SidebarProps } from \"../../utils/types\";\nimport { ActiveBusinessIcon } from \"./ActiveBusinessIcon\";\n\ntype BusinessBarProps = {\n activeBusiness: BusinessType;\n businesses?: BusinessType[];\n toggleAddBusinessDrawer: () => void;\n handleSwitchBusiness: (_: string) => void;\n onLogoutClick: () => void;\n toggleShowBusiness: (_: boolean) => void;\n} & Pick<SidebarProps, \"onToggleSideBar\" | \"isMobile\" | \"collapseType\">;\n\nconst businessPopUpVariants = {\n hidden: { y: \"-12px\", opacity: 0 },\n visible: {\n y: \"0\",\n opacity: 1,\n transition: {\n type: \"spring\",\n damping: 25,\n stiffness: 500,\n },\n },\n exit: {\n y: \"-12px\",\n opacity: 0,\n transition: {\n type: \"spring\",\n damping: 25,\n stiffness: 500,\n },\n },\n};\n\nexport const BusinessBarContent = ({\n activeBusiness,\n toggleAddBusinessDrawer,\n businesses = [],\n handleSwitchBusiness,\n onLogoutClick,\n onToggleSideBar,\n toggleShowBusiness,\n isMobile,\n collapseType,\n}: BusinessBarProps) => {\n const [searchText, setSearchText] = useState(\"\");\n const searchedBusinesses = useMemo(() => {\n const text = searchText.toLowerCase();\n return (businesses || []).filter((b) =>\n b.name?.toLowerCase().startsWith(text),\n );\n }, [businesses, searchText]);\n const hiddenCollapseType = collapseType === \"hidden\" || isMobile;\n\n const onSearchChange = (e: ChangeEvent<HTMLInputElement>) =>\n setSearchText(e.target.value);\n\n const onBusinessClick = (clientId?: string) => {\n handleSwitchBusiness(clientId || \"\");\n if (hiddenCollapseType) {\n onToggleSideBar(false);\n }\n setSearchText(\"\");\n };\n const onToggleAddBusinessDrawer = () => {\n toggleAddBusinessDrawer();\n toggleShowBusiness(false);\n if (hiddenCollapseType) {\n onToggleSideBar(false);\n }\n setSearchText(\"\");\n };\n const onHandleLogoutClick = () => {\n onLogoutClick?.();\n toggleShowBusiness(false);\n if (hiddenCollapseType) {\n onToggleSideBar(false);\n }\n setSearchText(\"\");\n };\n return (\n <AnimatePresence initial={false}>\n <motion.div\n initial=\"hidden\"\n animate=\"visible\"\n exit=\"exit\"\n variants={businessPopUpVariants}\n >\n <div\n className=\"w-72 bg-white border-x border-t rounded-xl overflow-hidden p-3\"\n style={{\n boxShadow: `\n 3px 4px 11px 0px #0000001A,\n 13px 16px 21px 0px #00000017,\n 29px 36px 28px 0px #0000000D,\n 52px 65px 33px 0px #00000003,\n 82px 101px 36px 0px #00000000\n `,\n }}\n >\n <BusinessBarTrigger\n activeBusiness={activeBusiness}\n rightNode={<ActiveBusinessIcon />}\n className=\"bg-[#FAFAFA] border-none p-3\"\n />\n\n <div className=\"mt-3\">\n <Input\n label=\"Search Account\"\n leftNode={<ChevronUp className=\"h-4 w-4 text-gray-500\" />}\n value={searchText}\n onChange={onSearchChange}\n placeholder=\"Search Account\"\n className=\"text-sm\"\n />\n </div>\n\n <ul className=\"max-h-48 overflow-y-auto mt-2 px-1 space-y-2\">\n {searchedBusinesses.map((b) => (\n <BusinessBarTrigger\n key={b.clientId}\n onTriggerClick={() => onBusinessClick(b?.clientId)}\n activeBusiness={b}\n rightNode={\n activeBusiness.clientId === b.clientId ? (\n <HiCheck className=\"text-primary-600\" size={18} />\n ) : undefined\n }\n className={cn(\"bg-white border-none \", {\n \"bg-[#FAFAFA]\": activeBusiness.clientId === b.clientId,\n })}\n />\n ))}\n </ul>\n\n <div className=\"py-2 \">\n <button\n onClick={onToggleAddBusinessDrawer}\n className=\"w-full flex items-center justify-start gap-2 text-sm text-[#0033C7] border-[#BECFFF] border-[0.5px] rounded-lg py-2 px-3 hover:bg-primary-accent transition \"\n >\n <BsPlus size={18} className=\"text-primary-main\" /> Add Account\n </button>\n </div>\n\n <div className=\"bg-[#FAFAFA] px-3 py-2 -m-3 mt-4\">\n <button\n className=\"w-full flex items-center gap-2 text-sm text-black hover:text-gray-700 transition p-2 hover:bg-primary-accent\"\n onClick={onHandleLogoutClick}\n >\n <FiLogOut size={16} /> Log Out\n </button>\n </div>\n </div>\n </motion.div>\n </AnimatePresence>\n );\n};\n","import { TextOverflow } from \"@/src/components/text-overflow\";\nimport { cn } from \"@/src/utils\";\nimport { BusinessType } from \"@/src/utils/types\";\n\ntype BusinessBarProps = {\n activeBusiness: BusinessType;\n iconOnly?: boolean;\n onTriggerClick?: () => void;\n className?: string;\n rightNode?: React.ReactNode;\n};\n\nexport const BusinessBarTrigger = ({\n activeBusiness,\n onTriggerClick,\n iconOnly = false,\n className,\n rightNode,\n}: BusinessBarProps) => {\n return (\n <div\n id=\"sidemenu_business_bar\"\n role=\"button\"\n onClick={onTriggerClick ? onTriggerClick : undefined}\n className={cn(\n \"relative flex w-full items-center rounded-lg text-black bg-white\",\n {\n \"border-[.5px] border-[#E9EBF8] py-1 px-2\": !iconOnly,\n \"hover:bg-primary-accent transition-all duration-150 cursor-pointer \":\n !!onTriggerClick,\n },\n className,\n )}\n >\n <section\n className={cn(\n \"flex items-center justify-center bg-[#E9EBF8] text-primary-main rounded-md mr-3 text-xl font-medium\",\n {\n \"w-10 h-10\": !iconOnly,\n \"w-full h-10 mr-0\": iconOnly,\n },\n )}\n >\n {activeBusiness?.name?.charAt(0) || \"M\"}\n </section>\n\n {!iconOnly && (\n <section className=\"flex-1 flex justify-between items-center relative text-black w-full -space-y-1 tracking-wide\">\n <div className=\"flex-1 min-w-0 max-w-[150px] w-full\">\n <TextOverflow\n as={\"h2\"}\n className=\"text-base capitalize font-medium\"\n >\n {activeBusiness?.name}\n </TextOverflow>\n <TextOverflow\n as={\"p\"}\n className=\"text-sm text-[#A5A5A5]\"\n onClick={undefined}\n >\n {activeBusiness?.email}\n </TextOverflow>\n </div>\n {rightNode}\n </section>\n )}\n </div>\n );\n};\n","import React from \"react\";\n\nexport const ActiveBusinessIcon = (props: React.SVGProps<SVGSVGElement>) => (\n <svg\n width=\"9\"\n height=\"8\"\n viewBox=\"0 0 9 8\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <circle cx=\"4.5\" cy=\"4\" r=\"4\" fill=\"#62C554\" />\n </svg>\n);\n","import { BusinessType } from \"@/src/utils/types\";\nimport { BusinessBarContent } from \"./components/Content\";\nimport { BusinessBarTrigger } from \"./components/Trigger\";\nimport { Popover } from \"../../popover\";\nimport { cn } from \"@/src/utils\";\nimport { SidebarProps } from \"../utils/types\";\n\ntype BusinessBarProps = {\n activeBusiness: BusinessType;\n businesses?: BusinessType[];\n isBusinessShown: boolean;\n toggleAddBusinessDrawer: () => void;\n toggleShowBusiness: (v: boolean) => void;\n handleSwitchBusiness: (_: string) => void;\n iconOnly?: boolean;\n onLogoutClick: () => void;\n isMobile: boolean;\n} & Pick<SidebarProps, \"onToggleSideBar\" | \"isMobile\" | \"collapseType\">;\n\nexport const BusinessBar = ({\n activeBusiness,\n toggleAddBusinessDrawer,\n toggleShowBusiness,\n businesses = [],\n handleSwitchBusiness,\n iconOnly = false,\n onLogoutClick,\n isMobile,\n onToggleSideBar,\n isBusinessShown,\n collapseType,\n}: BusinessBarProps) => {\n return (\n <div className=\"px-4 relative mb-0 \">\n <Popover\n side={isMobile ? \"top\" : \"right\"}\n open={isBusinessShown}\n onOpenChange={toggleShowBusiness}\n align=\"end\"\n contentClassName=\"!bg-transparent !shadow-none !p-0\"\n trigger={\n <div className=\"flex items-center w-full\">\n <BusinessBarTrigger\n activeBusiness={activeBusiness}\n onTriggerClick={() => toggleShowBusiness(true)}\n iconOnly={iconOnly}\n rightNode={<Icon className=\"stroke-gray-500\" />}\n />\n </div>\n }\n >\n <BusinessBarContent\n activeBusiness={activeBusiness}\n handleSwitchBusiness={handleSwitchBusiness}\n toggleAddBusinessDrawer={toggleAddBusinessDrawer}\n businesses={businesses}\n onLogoutClick={onLogoutClick}\n onToggleSideBar={onToggleSideBar}\n toggleShowBusiness={toggleShowBusiness}\n collapseType={collapseType}\n isMobile={isMobile}\n />\n </Popover>\n </div>\n );\n};\n\nconst Icon = ({ className }: { className?: string }) => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"18\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n className={cn(\n \"lucide lucide-chevrons-up-down-icon lucide-chevrons-up-down\",\n className,\n )}\n >\n <path d=\"M7 22l5 5 5-5\" />\n <path d=\"M7 4l5-5 5 5\" />\n </svg>\n );\n};\n","import { cn } from \"@/src/utils\";\nimport { AnimatePresence, motion } from \"framer-motion\";\nimport { useEffect } from \"react\";\nimport { FiChevronRight } from \"react-icons/fi\";\nimport { LinksType, SidebarProps } from \"./utils/types\";\nimport { Tooltip } from \"../tooltip\";\nimport { useLocalStorage } from \"@/src/hooks/useLocalStorage\";\n\ntype Props = {\n isIconsOnly: boolean;\n isMobile: boolean;\n} & Pick<\n SidebarProps,\n | \"isSidebarCollapsed\"\n | \"onToggleSideBar\"\n | \"onNavigate\"\n | \"currentPath\"\n | \"collapseType\"\n | \"links\"\n | \"appConfig\"\n>;\n\ntype SidebarMenuStorageType = Record<string, boolean>;\n\nconst accordionItemVariants = {\n hidden: { opacity: 0, height: 0 },\n visible: {\n opacity: 1,\n height: \"auto\",\n transition: {\n duration: 0.3,\n },\n },\n};\n\nexport const NavItems = ({\n isIconsOnly,\n isSidebarCollapsed,\n onToggleSideBar,\n currentPath,\n onNavigate,\n collapseType,\n links,\n appConfig,\n isMobile,\n}: Props) => {\n const SIDEBAR_MENU_STORAGE_KEY = \"@sidebar-expanded-menus\";\n const [expandedMenus, setExpandedMenus] =\n useLocalStorage<SidebarMenuStorageType>(SIDEBAR_MENU_STORAGE_KEY, {});\n\n const toggleAccordion = (linkId: string) => {\n setExpandedMenus((prev) => ({\n ...prev,\n [linkId]: !prev[linkId],\n }));\n };\n\n const handleMenuLink = (link: LinksType) => {\n const hasChildren = !!link?.children?.length;\n if (hasChildren) {\n if (isIconsOnly) {\n onToggleSideBar(!isSidebarCollapsed);\n setExpandedMenus((prev) => ({\n ...prev,\n [link.id]: true,\n }));\n } else {\n toggleAccordion(link.id);\n }\n return;\n }\n onNavigate(`/${link.to}`);\n };\n\n const getActiveMenu = (link: LinksType): boolean => {\n const hasChildren = !!link?.children?.length;\n if (hasChildren) {\n return (link.children || []).some((l) => currentPath === l.to);\n }\n return currentPath === link.to;\n };\n\n useEffect(() => {\n // Reset all expanded menus and only open the current path menu\n const expanded: SidebarMenuStorageType = {};\n\n // Find the link that contains the current path and expand only that one\n links.forEach((link) => {\n if (link.children && link.children.length > 0) {\n // If any child matches the current path, expand this menu\n if (link.children.some((child) => currentPath === child.to)) {\n expanded[link.id] = true;\n }\n }\n });\n\n // Replace all expanded menus with just the one for current path\n setExpandedMenus(expanded);\n }, [links, currentPath, isSidebarCollapsed]);\n\n return (\n <ul className=\"w-[90%] space-y-2.5\">\n {links.map((link, idx) => {\n if (link.isHidden) return null;\n if (appConfig?.hiddenRoutes?.includes(link.key ?? \"\")) return null;\n\n const active = getActiveMenu(link);\n const hasChildren = !!link?.children?.length;\n const isExpanded = expandedMenus[link.id];\n\n const menuItem = (\n <div\n className=\"mb-1 relative flex flex-col justify-center items-center\"\n key={idx}\n onClick={() => handleMenuLink(link)}\n >\n {active &&\n !isMobile &&\n (isIconsOnly || !hasChildren || !isExpanded) && (\n <div className=\"absolute bg-primary-main w-2 h-4 rounded-r-full -translate-y-1/2 top-1/2 left-0\" />\n )}\n\n <li\n key={link.to}\n id={link.id}\n className={cn(\n \"cursor-pointer transition text-base duration-300 w-full text-[#00000066] font-medium rounded-md mx-auto max-w-full ml-4 p-2\",\n {\n \"bg-[#F6F8FF] text-primary-main \":\n active && (!isExpanded || !isSidebarCollapsed),\n },\n {\n \"hover:bg-gray-100\":\n !active &&\n (collapseType !== \"icons\" || !isSidebarCollapsed),\n },\n {\n \"bg-white text-primary-main\": active,\n },\n {\n \"flex justify-center text-primary-main !px-0 max-w-[70%]\":\n isIconsOnly && active,\n \"flex justify-center !px-0 max-w-[70%]\":\n isIconsOnly && !active,\n },\n )}\n >\n <div\n className={cn(\"flex items-center w-full\", {\n \"justify-center\": isIconsOnly,\n })}\n >\n <Tooltip\n key={idx}\n trigger={\n <span className=\"w-6\" onClick={() => handleMenuLink(link)}>\n {link.icon}\n </span>\n }\n side=\"right\"\n hasArrow\n open={!isIconsOnly ? false : undefined}\n >\n {link.name}\n </Tooltip>\n {(collapseType !== \"icons\" || !isSidebarCollapsed) && (\n <>\n <span className=\"px-3 text-nowrap\">{link.name}</span>\n {hasChildren && (\n <span\n className=\"ml-auto transition-transform duration-300\"\n style={{\n transform: isExpanded\n ? \"rotate(90deg)\"\n : \"rotate(0deg)\",\n }}\n >\n <FiChevronRight size={18} />\n </span>\n )}\n </>\n )}\n </div>\n </li>\n\n {hasChildren &&\n (collapseType !== \"icons\" || !isSidebarCollapsed) && (\n <AnimatePresence>\n {isExpanded && (\n <motion.div\n initial=\"hidden\"\n animate=\"visible\"\n exit=\"hidden\"\n variants={accordionItemVariants}\n className=\"overflow-hidden w-full\"\n >\n <ul className=\" mt-1 relative \">\n {link.children?.map((childLink) => {\n if (childLink.isHidden) return null;\n const childActive = currentPath === childLink.to;\n return (\n <div\n id={childLink.id}\n className={cn(\"relative pl-12 bg-blue-100- mt-4\")}\n >\n <li\n className={cn(\n \"cursor-pointer transition text-base duration-300 px-3 w-full text-black font-medium opacity-40 rounded-md text-nowrap\",\n {\n \"bg-transparent opacity-100 text-primary-main\":\n childActive,\n },\n {\n \"hover:text-primary-main\": !childActive,\n },\n )}\n onClick={() => onNavigate(`/${childLink.to}`)}\n >\n {childLink.name}\n {childActive && (\n <>\n {!isMobile && (\n <div className=\"absolute bg-primary-main w-2 h-4 rounded-r-full -translate-y-1/2 top-1/2 left-0\" />\n )}\n <div\n id=\"vertical-bar-child\"\n className=\"h-4 w-0.5 bg-primary-main absolute left-[30px] z-10 -translate-y-1/2 top-1/2 rounded-t-full rounded-b-full \"\n />\n </>\n )}\n </li>\n </div>\n );\n })}\n <div\n id=\"vertical-bar\"\n className=\"bg-white rounded-t-full rounded-b-full h-full w-[4px] absolute left-[29px] top-0\"\n />\n </ul>\n </motion.div>\n )}\n </AnimatePresence>\n )}\n </div>\n );\n\n return menuItem;\n })}\n </ul>\n );\n};\n","import { useState, useEffect } from \"react\";\n\n/**\n * A custom hook to persist state in localStorage with type safety\n * @template T The type of the state to be stored\n * @param {string} key - The localStorage key to store the state under\n * @param {T} initialValue - The initial value to use if no value exists in localStorage\n * @returns {[T, React.Dispatch<React.SetStateAction<T>>]} A stateful value and a function to update it\n */\nexport const useLocalStorage = <T,>(\n key: string,\n initialValue: T,\n): [T, React.Dispatch<React.SetStateAction<T>>] => {\n // State to store our value\n // Pass initial state function to useState so logic is only executed once\n const [state, setState] = useState<T>(initialValue);\n\n // Only after mount/hydration, sync with localStorage\n const [isHydrated, setIsHydrated] = useState(false);\n\n // Once the component is hydrated, we can safely access localStorage\n useEffect(() => {\n setIsHydrated(true);\n\n try {\n const item = localStorage.getItem(key);\n if (item) {\n setState(JSON.parse(item));\n }\n } catch (error) {\n console.error(\"Error reading from localStorage:\", error);\n }\n }, [key]);\n\n // Update localStorage when state changes but only after hydration\n useEffect(() => {\n if (isHydrated) {\n try {\n localStorage.setItem(key, JSON.stringify(state));\n } catch (error) {\n console.error(\"Error writing to localStorage:\", error);\n }\n }\n }, [key, state, isHydrated]);\n\n return [state, setState];\n};\n","export const OpenSidebarIcon = () => {\n return (\n <svg\n width=\"100%\"\n height={40}\n xmlns=\"http://www.w3.org/2000/svg\"\n id=\"Layer_1\"\n data-name=\"Layer 1\"\n viewBox=\"0 0 1565.51 377.21\"\n >\n <g>\n <path\n fill=\"#0231C5\"\n d=\"m277.49,86.74v85.18l-.41,6.31v.21c-.72,5.8-2.38,11.28-4.86,16.35-1.45,3-3.21,5.9-5.28,8.49-1.55,2.07-3.42,4.04-5.28,5.9-1.66,1.55-3.42,3.11-5.28,4.45-1.66,1.24-3.42,2.38-5.28,3.42-1.76.93-3.52,1.76-5.28,2.59-1.24.52-2.48.93-3.83,1.35l-1.45.52-5.28,1.76-5.28,1.76-5.28,1.76-5.28,1.76-10.56,3.52-.52.21v19.15l-.41.1-3.62,1.14-.83.21-2.79.93-2.48.83-1.14.31-3.62,1.14-.62.21-3,.93-2.28.72-1.35.41-3.62,1.14-.41.1-.52.21h-.21v-37.26c0-1.55.31-3,.72-4.45.1-.31.21-.62.41-.93.83-1.86,2.07-3.52,3.62-4.86.41-.31.83-.72,1.35-1.04.72-.52,1.45-.83,2.28-1.24.21-.1.52-.21.72-.31l.21-.1,2.17-.72.62-.21,3.62-1.14,1.14-.41,5.28-1.76.83-.31,3.62-1.14.93-.31,5.28-1.76,5.28-1.76,5.28-1.76,5.28-1.76,3.83-1.24c.52-.1.93-.31,1.45-.52,1.97-.72,3.73-1.76,5.28-2.9,2.07-1.45,3.83-3.21,5.28-5.18,3.21-4.14,5.07-9.42,5.07-14.9v-85.08c0-5.59-1.76-10.76-5.07-15.01-1.45-1.86-3.11-3.52-5.07-4.97q-.1-.1-.21-.1c-1.66-1.24-3.42-2.17-5.28-2.9-1.76-.72-3.52-1.14-5.28-1.45-1.76-.31-3.52-.31-5.28-.21-1.76.1-3.52.41-5.28.93-.21.1-.52.1-.72.21l-4.55,1.45-5.28,1.66-5.28,1.76-5.69,1.55-5.28,1.76-5.28,1.66-5.28,1.76-5.28,1.66-5.28,1.66-5.28,1.76-5.28,1.66-5.28,1.66-5.28,1.76-5.28,1.66-5.28,1.76-5.28,1.66-5.28,1.76-5.69,1.66-5.28,1.76-3.83,1.24c-.52.21-1.04.31-1.55.52-1.86.72-3.73,1.76-5.28,2.9-2.07,1.45-3.83,3.21-5.28,5.18-3.21,4.24-5.07,9.42-5.07,15.01v33.33c0,3.93.83,7.25,2.07,10.04.1.31.21.52.41.83-.1.1-.31.1-.41.21-.83.41-1.55.72-2.28,1.24-.41.21-.83.52-1.35.72-1.24.72-2.48,1.55-3.62,2.38-.1.1-.31.21-.41.31-1.14.83-2.17,1.66-3.21,2.48-.72.62-1.45,1.24-2.07,1.97-.52.52-1.04.93-1.55,1.45-1.24,1.35-2.48,2.69-3.62,4.14-.1.1-.1.21-.21.31-.72.93-1.35,1.76-1.97,2.69-.52-.72-1.04-1.55-1.45-2.28-.72-1.14-1.35-2.28-1.86-3.52-.62-1.24-1.14-2.59-1.66-3.83-2.38-6-3.62-12.42-3.62-18.94v-33.64c0-8.07,1.86-15.94,5.28-22.77,1.45-3,3.21-5.9,5.28-8.49,1.55-2.07,3.42-4.04,5.28-5.9,1.66-1.55,3.42-3.11,5.28-4.45,1.66-1.24,3.42-2.38,5.28-3.42,1.66-.93,3.42-1.76,5.28-2.59,1.35-.52,2.59-1.04,3.93-1.45l1.35-.41,5.28-1.66,5.28-1.76,5.28-1.66,5.28-1.76,5.28-1.66,5.28-1.76,5.28-1.66,5.28-1.76,5.8-1.66,5.28-1.76,5.28-1.66,5.28-1.66,5.28-1.76,5.28-1.66,5.28-1.76,5.28-1.66,5.28-1.76,5.28-1.66,5.28-1.76,1.76-.52c1.14-.41,2.38-.72,3.62-1.04,1.76-.41,3.52-.83,5.28-1.04,1.76-.21,3.52-.41,5.28-.41,1.76-.1,3.52,0,5.28.1,1.76.1,3.52.31,5.28.62,1.76.31,3.52.72,5.28,1.24,1.76.52,3.62,1.14,5.28,1.86,1.76.72,3.62,1.66,5.28,2.59,1.86,1.04,3.62,2.17,5.28,3.42h.1c1.86,1.35,3.62,2.79,5.28,4.45,1.97,1.76,3.73,3.73,5.28,5.8,2.07,2.69,3.83,5.49,5.28,8.49,3.73,7.14,5.59,14.9,5.59,23.08Z\"\n ></path>\n <path\n fill=\"#0231C5\"\n d=\"m184.03,136.63v28.05l-.72.21-1.97.62-3.31,1.04-.21.1-3.62,1.14-1.45.52-2.17.72-.52.1h0l-2.17.72-1.86.62-1.76.52-3.52,1.14h-.1l-3.62,1.14-1.66.52-1.97.62-3.31,1.04-.21.1-3.62,1.14-1.45.52-2.17.72-.52.1-2.69.83-.41.1-3.62,1.14-1.24.41-2.38.72-2.9.93-.62.21-3.62,1.14-1.04.31-1.97.62-.62.21-2.79.93-.83.31-3,.93c-.21.1-.41.1-.62.21-.31.1-.62.21-.83.31-.93.41-1.86.83-2.79,1.35-.83.41-1.76.93-2.59,1.55-.31.21-.72.52-1.04.83-1.35,1.04-2.48,2.17-3.62,3.52-.21.21-.41.52-.62.83-1.14,1.55-2.17,3.21-3,5.07-1.35,3.11-2.07,6.42-2.07,9.94v82.39c0,2.59.72,5.07,2.07,7.14.83,1.35,2.07,2.59,3.42,3.62q.1.1.21.1c1.14.83,2.28,1.45,3.62,1.76,1.14.41,2.38.62,3.62.62,1.14,0,2.38-.1,3.62-.41.31-.1.62-.21.93-.31l2.59-.83,3.62-1.14,3.62-1.14,3.62-1.14,3.62-1.14,1.66-.52c.62-.21,1.24-.52,1.86-.83,1.35-.52,2.48-1.24,3.62-2.17,1.35-1.04,2.59-2.28,3.62-3.73,2.07-2.9,3.21-6.52,3.21-10.25v-58.48l.31-.1,3.62-1.14.21-.1,3.31-1.04,1.97-.62,1.66-.52,3.62-1.14h.1l3.52-1.14,1.76-.52,1.86-.62,3.42-1.14.21-.1,1.14-.41v67.07c0,2.48-.21,5.07-.62,7.45-.21.93-.31,1.76-.52,2.69-.83,3.52-1.97,6.83-3.62,9.94-1.04,2.07-2.28,4.04-3.62,6-1.14,1.55-2.28,3-3.62,4.45-1.14,1.24-2.38,2.38-3.62,3.42-1.14,1.04-2.38,1.86-3.62,2.79-1.14.83-2.38,1.55-3.62,2.28-1.14.62-2.38,1.24-3.62,1.76-.1,0-.21.1-.31.21-1.04.41-2.17.83-3.21,1.24-.31.1-.62.21-.93.31l-2.69.83-7.25,2.28-3.62,1.14-3.62,1.14-1.66.52c-.62.21-1.24.41-1.86.52-1.24.31-2.38.62-3.62.83-1.24.21-2.38.41-3.62.41-1.14.1-2.17.1-3.21.1h-.31c-1.24,0-2.38-.1-3.62-.21-1.24-.1-2.38-.31-3.62-.52s-2.38-.52-3.62-.93c-.72-.21-1.35-.41-2.07-.62-.52-.21-1.04-.41-1.55-.62-1.24-.52-2.38-1.04-3.62-1.66s-2.48-1.35-3.62-2.17c-.52-.31-1.04-.72-1.55-1.04-.72-.52-1.35-1.04-2.07-1.66-1.24-1.04-2.48-2.17-3.62-3.42-1.35-1.35-2.59-2.9-3.62-4.45-1.45-1.97-2.59-4.04-3.62-6.21-2.38-5.18-3.62-10.87-3.62-16.77v-82.39c0-6.62,1.24-13.04,3.62-18.94.52-1.35,1.04-2.59,1.66-3.83s1.24-2.38,1.86-3.52c.41-.83.93-1.55,1.45-2.28.62-.93,1.24-1.86,1.97-2.69,0-.1.1-.21.21-.21,1.14-1.45,2.28-2.79,3.62-4.14.52-.52.93-1.04,1.55-1.45.72-.72,1.35-1.24,2.07-1.86,1.04-.83,2.07-1.76,3.21-2.48.1-.1.31-.21.41-.31,1.14-.83,2.38-1.66,3.62-2.28.41-.21.83-.52,1.35-.72.72-.41,1.55-.83,2.28-1.24.1-.1.21-.1.41-.21.83-.41,1.76-.83,2.59-1.14.21-.1.41-.21.62-.21,1.04-.41,2.17-.83,3.21-1.14l.31-.1,1.04-.31,2.59-.83,2.79-.93.83-.31,3.62-1.14.83-.31,2.79-.83.62-.21,1.97-.62,1.04-.31,3.62-1.14.62-.21,2.9-.93,2.38-.72,1.24-.41,3.62-1.14.41-.1,2.69-.83.52-.1,2.17-.72,1.45-.41,3.62-1.14.21-.1,3.31-1.04,1.97-.62,1.66-.52,3.62-1.14h.1l3.52-1.14,1.76-.52,1.86-.62,2.17-.72h0l.52-.1,2.17-.72,1.45-.52,3.62-1.14.21-.1,3.31-1.04,1.97-.62,1.04-.41Z\"\n ></path>\n </g>\n <path\n fill=\"#000000\"\n d=\"m433.57,86.41c18.92,0,34.54,6.21,46.87,18.62,12.32,12.41,18.49,28.16,18.49,47.26s-6.16,34.85-18.49,47.26c-12.33,12.41-27.95,18.62-46.87,18.62h-35.41v50.51h-42.18V86.41h77.59Zm-6.51,97.38c8.5,0,15.49-2.95,20.96-8.85,5.47-5.9,8.2-13.45,8.2-22.65s-2.73-16.75-8.2-22.65c-5.47-5.9-12.46-8.85-20.96-8.85h-28.9v63.01h28.9Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m568.18,272.05c-18.23,0-32.63-6.16-43.22-18.49-10.59-12.32-15.88-28.21-15.88-47.65s5.47-34.89,16.4-47.39c10.94-12.5,25.34-18.75,43.22-18.75,8.85,0,16.75,1.91,23.69,5.73,6.94,3.82,12.15,9.03,15.62,15.62v-17.96h39.58v125.5h-39.58v-17.7c-3.47,6.25-8.81,11.33-16.01,15.23-7.2,3.91-15.15,5.86-23.82,5.86Zm11.46-33.07c9.54,0,16.92-3.12,22.13-9.37,5.21-6.25,7.81-14.15,7.81-23.69s-2.6-17.18-7.81-23.43c-5.21-6.25-12.59-9.37-22.13-9.37-9.03,0-16.27,3.04-21.74,9.11-5.47,6.08-8.2,13.97-8.2,23.69s2.73,17.66,8.2,23.82c5.47,6.16,12.71,9.24,21.74,9.24Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m765.53,143.17h39.84v121.59c0,19.44-5.99,34.54-17.97,45.3-11.29,9.72-26.65,14.58-46.08,14.58s-35.76-4.34-46.34-13.02c-10.24-8.68-15.45-19.7-15.62-33.07h40.1c.87,11.28,8.16,16.92,21.87,16.92,16.14,0,24.21-9.37,24.21-28.12v-19.53c-7.29,13.89-20.57,20.83-39.84,20.83-15.45,0-27.04-4.69-34.76-14.06-7.73-9.37-11.59-22.22-11.59-38.53v-72.9h39.83v66.91c0,18.05,7.38,27.08,22.13,27.08,7.81,0,13.8-2.82,17.97-8.46,4.17-5.64,6.25-13.41,6.25-23.3v-62.23Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m839.47,268.66V86.41h111.44v35.41h-69.26v49.21h69.26v34.63h-69.26v63.01h-42.18Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m1090.07,253.82c-12.59,12.5-29.47,18.75-50.64,18.75s-38.1-6.25-50.77-18.75c-12.67-12.5-19.01-28.47-19.01-47.91s6.33-35.36,19.01-47.78c12.67-12.41,29.59-18.62,50.77-18.62s38.05,6.21,50.64,18.62c12.58,12.41,18.88,28.34,18.88,47.78s-6.29,35.41-18.88,47.91Zm-50.64-15.1c9.2,0,16.49-3.03,21.87-9.11,5.38-6.07,8.07-13.97,8.07-23.69s-2.69-17.61-8.07-23.69c-5.38-6.07-12.67-9.11-21.87-9.11s-16.71,3.04-22,9.11c-5.3,6.08-7.94,13.97-7.94,23.69s2.64,17.62,7.94,23.69c5.29,6.08,12.63,9.11,22,9.11Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m1131.86,268.66v-125.5h39.84v18.23c7.46-14.41,21-21.61,40.62-21.61,30.55,0,45.82,17.1,45.82,51.29v77.59h-40.1v-64.57c0-10.76-1.69-18.57-5.08-23.43-3.39-4.86-9.07-7.29-17.05-7.29-16.14,0-24.21,9.89-24.21,29.68v65.61h-39.84Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m1353.43,237.68c5.55,0,10.15-.26,13.8-.78v31.76c-7.64,1.39-16.49,2.08-26.56,2.08-4.52,0-8.51-.26-11.98-.78-3.47-.52-7.38-1.69-11.72-3.52-4.34-1.82-7.9-4.3-10.68-7.42-2.78-3.13-5.17-7.64-7.16-13.54-2-5.9-2.99-12.84-2.99-20.83v-49.99h-19.79v-31.5h19.79v-37.23h39.84v37.23h28.38v31.5h-28.38v41.66c0,8.51,1.47,14.19,4.43,17.05,2.95,2.86,7.29,4.3,13.02,4.3Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m1513.55,199.4c0,5.21-.35,11.02-1.04,17.44h-92.69c.35,8.16,3.12,14.49,8.33,19.01,5.21,4.52,12.24,6.77,21.09,6.77,12.15,0,19.96-3.91,23.43-11.72h39.05c-1.91,12.33-8.64,22.35-20.18,30.07-11.55,7.72-25.65,11.59-42.31,11.59-21.35,0-38.19-5.9-50.51-17.7-12.33-11.8-18.49-28.12-18.49-48.95s6.16-36.67,18.49-48.56c12.32-11.89,28.73-17.83,49.21-17.83s35.23,5.56,47.39,16.66c12.15,11.11,18.23,25.52,18.23,43.22Zm-93.73-7.29h54.42c-.18-8.33-2.52-14.75-7.03-19.27-4.52-4.51-11.02-6.77-19.53-6.77s-15.23,2.39-20.18,7.16c-4.95,4.78-7.51,11.07-7.68,18.88Z\"\n ></path>\n </svg>\n );\n};\n","export const ClosedSidebarIcon = () => {\n return (\n <svg\n width=\"100%\"\n height=\"32\"\n viewBox=\"0 0 20 32\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className=\"pl-5\"\n >\n <path\n d=\"M19.686 5.71949V15.1448L19.6467 15.8434V15.8548V15.8663C19.5779 16.5076 19.4207 17.1146 19.1848 17.6758C19.0472 18.0079 18.8801 18.3286 18.6836 18.6149C18.5361 18.8439 18.3592 19.0615 18.1823 19.2677C18.025 19.4394 17.858 19.6112 17.6811 19.7601C17.5238 19.8975 17.3567 20.0235 17.1798 20.138C17.0127 20.2411 16.8456 20.3327 16.6786 20.4243C16.5606 20.4816 16.4427 20.5274 16.3149 20.5732L16.1773 20.6305L15.6761 20.8252L15.1748 21.0199L14.6736 21.2146L14.1723 21.4093L13.1698 21.7986L13.1207 21.8215V23.9402L13.0814 23.9517L12.7374 24.0777L12.6587 24.1006L12.3934 24.2036L12.1575 24.2953L12.0494 24.3296L11.7054 24.4556L11.6464 24.4785L11.3614 24.5816L11.1452 24.6617L11.0174 24.7075L10.6734 24.8335L10.6341 24.845L10.5849 24.8679H10.5653V20.745C10.5653 20.5732 10.5948 20.4129 10.6341 20.2526C10.6439 20.2182 10.6537 20.1838 10.6734 20.1495C10.752 19.9433 10.87 19.7601 11.0174 19.6112C11.0567 19.5769 11.096 19.5311 11.1452 19.4967C11.214 19.4394 11.2828 19.4051 11.3614 19.3593C11.381 19.3478 11.4105 19.3364 11.4302 19.3249L11.4498 19.3135L11.6562 19.2333L11.7152 19.2104L12.0592 19.0844L12.1673 19.0386L12.6686 18.8439L12.7472 18.8096L13.0912 18.6836L13.1796 18.6492L13.6809 18.4545L14.1821 18.2598L14.6834 18.0652L15.1846 17.8705L15.5483 17.733C15.5974 17.7216 15.6367 17.6987 15.6859 17.6758C15.8726 17.5956 16.0397 17.4811 16.1871 17.3551C16.3837 17.1948 16.5508 17.0001 16.6884 16.7825C16.9931 16.3244 17.17 15.7403 17.17 15.1333V5.71949C17.17 5.10106 17.0029 4.52844 16.6884 4.05889C16.5508 3.85275 16.3935 3.66951 16.2068 3.50917C16.197 3.49772 16.197 3.49772 16.1871 3.49772C16.0299 3.36029 15.8628 3.25722 15.6859 3.17705C15.5188 3.09689 15.3517 3.05108 15.1846 3.01672C15.0176 2.98236 14.8505 2.98236 14.6834 2.99382C14.5163 3.00527 14.3492 3.03963 14.1821 3.09689C14.1625 3.10834 14.133 3.10834 14.1133 3.11979L13.6809 3.28013L13.1796 3.46336L12.6784 3.65806L12.1378 3.82984L11.6366 4.02453L11.1353 4.20777L10.6341 4.40246L10.1328 4.5857L9.63159 4.76894L9.13034 4.96363L8.62909 5.14687L8.12784 5.3301L7.62659 5.52479L7.12534 5.70803L6.6241 5.90272L6.12285 6.08596L5.6216 6.28065L5.08103 6.46389L4.57979 6.65858L4.21614 6.79601C4.16699 6.81891 4.11785 6.83037 4.06871 6.85327C3.8918 6.93344 3.71489 7.04796 3.56746 7.17394C3.37089 7.33427 3.20381 7.52896 3.06621 7.74656C2.76153 8.2161 2.58462 8.78872 2.58462 9.40715V13.0948C2.58462 13.53 2.66325 13.8965 2.78119 14.2057C2.79102 14.2401 2.80085 14.263 2.8205 14.2973C2.81067 14.3088 2.79102 14.3088 2.78119 14.3202C2.70256 14.366 2.63376 14.4004 2.56496 14.4577C2.52565 14.4806 2.48634 14.5149 2.43719 14.5378C2.31925 14.618 2.20131 14.7096 2.0932 14.8012C2.08337 14.8127 2.06371 14.8241 2.05389 14.8356C1.94577 14.9272 1.84749 15.0188 1.74921 15.1104C1.68041 15.1792 1.61161 15.2479 1.55264 15.328C1.5035 15.3853 1.45435 15.4311 1.40521 15.4884C1.28727 15.6373 1.16933 15.7861 1.06122 15.9465C1.05139 15.9579 1.05139 15.9694 1.04156 15.9808C0.972761 16.0839 0.913791 16.1755 0.85482 16.2786C0.805678 16.1984 0.756536 16.1068 0.717223 16.0266C0.648424 15.9007 0.589453 15.7747 0.540311 15.6373C0.481341 15.4998 0.432199 15.3509 0.383057 15.2135C0.157004 14.5493 0.0390625 13.8392 0.0390625 13.1177V9.3957C0.0390625 8.50241 0.215974 7.63203 0.540311 6.87618C0.677909 6.54406 0.844992 6.22339 1.04156 5.93708C1.18899 5.70803 1.3659 5.49044 1.54281 5.28429C1.70006 5.11251 1.86715 4.94072 2.04406 4.79184C2.20131 4.65441 2.3684 4.52844 2.54531 4.41391C2.70256 4.31084 2.86964 4.21922 3.04656 4.1276C3.17432 4.07034 3.29227 4.01308 3.42003 3.96727L3.5478 3.92146L4.04905 3.73822L4.5503 3.54353L5.05155 3.36029L5.5528 3.1656L6.05405 2.98236L6.5553 2.78767L7.05654 2.60444L7.55779 2.40974L8.10818 2.22651L8.60943 2.03182L9.11068 1.84858L9.61193 1.66534L10.1132 1.47065L10.6144 1.28741L11.1157 1.09272L11.6169 0.909482L12.1182 0.714792L12.6194 0.531554L13.1207 0.336863L13.2878 0.279601C13.3959 0.233791 13.5138 0.199434 13.6317 0.165077C13.7988 0.119268 13.9659 0.073458 14.133 0.0505533C14.3001 0.0276485 14.4672 0.00474375 14.6342 0.00474375C14.8013 -0.00670864 14.9684 0.00474368 15.1355 0.0161961C15.3026 0.0276485 15.4697 0.0505533 15.6367 0.0849104C15.8038 0.119268 15.9709 0.165077 16.138 0.222339C16.3051 0.279601 16.482 0.348315 16.6392 0.428482C16.8063 0.508649 16.9832 0.61172 17.1405 0.714792C17.3174 0.829315 17.4845 0.955292 17.6417 1.09272C17.6417 1.09272 17.6417 1.09272 17.6516 1.09272C17.8285 1.2416 17.9956 1.40193 18.1528 1.58517C18.3396 1.77986 18.5066 1.99746 18.6541 2.22651C18.8506 2.52427 19.0177 2.83348 19.1553 3.1656C19.5091 3.95582 19.686 4.81475 19.686 5.71949Z\"\n fill=\"#0231C5\"\n />\n <path\n d=\"M10.8112 9.92822V13.0846L10.7425 13.1079L10.5557 13.1778L10.2412 13.2943L10.2215 13.3059L9.87755 13.434L9.73995 13.4923L9.53356 13.5738L9.48441 13.5855L9.27802 13.667L9.10111 13.7369L8.93402 13.7951L8.59986 13.9232H8.59003L8.24604 14.0514L8.08878 14.1096L7.90204 14.1795L7.58753 14.2959L7.56787 14.3076L7.22388 14.4357L7.08628 14.4939L6.87989 14.5755L6.83074 14.5871L6.57521 14.6803L6.53589 14.692L6.1919 14.8201L6.07396 14.8667L5.8479 14.9482L5.57271 15.053L5.51374 15.0763L5.16974 15.2044L5.07146 15.2394L4.88472 15.3093L4.82575 15.3326L4.56038 15.4374L4.48175 15.4723L4.19673 15.5771C4.17707 15.5888 4.15742 15.5888 4.13776 15.6004C4.10827 15.6121 4.07879 15.6237 4.05913 15.6354C3.97068 15.682 3.88222 15.7286 3.79377 15.7868C3.71514 15.8334 3.62668 15.8916 3.54806 15.9615C3.51857 15.9848 3.47926 16.0197 3.44977 16.0547C3.322 16.1712 3.21389 16.2993 3.10578 16.4507C3.08612 16.474 3.06646 16.5089 3.04681 16.5439C2.93869 16.7186 2.84041 16.9049 2.76178 17.1146C2.63401 17.464 2.56521 17.8367 2.56521 18.2327V27.5039C2.56521 27.7951 2.63401 28.0747 2.76178 28.3076C2.84041 28.459 2.95835 28.5988 3.08612 28.7153C3.09595 28.7269 3.09595 28.7269 3.10578 28.7269C3.21389 28.8201 3.322 28.89 3.44977 28.9249C3.55788 28.9715 3.67582 28.9948 3.79377 28.9948C3.90188 28.9948 4.01982 28.9831 4.13776 28.9482C4.16725 28.9366 4.19673 28.9249 4.22622 28.9133L4.47193 28.8201L4.81592 28.692L5.15991 28.5638L5.50391 28.4357L5.8479 28.3076L6.00516 28.2494C6.06413 28.2261 6.1231 28.1911 6.18207 28.1562C6.30984 28.098 6.41795 28.0164 6.52606 27.9116C6.65383 27.7951 6.77177 27.6554 6.87006 27.4923C7.06663 27.1662 7.17474 26.7585 7.17474 26.3392V19.7585L7.20422 19.7469L7.54822 19.6187L7.56787 19.6071L7.88238 19.4906L8.06912 19.4207L8.22638 19.3625L8.57037 19.2344H8.5802L8.91437 19.1063L9.08145 19.048L9.25836 18.9781L9.5827 18.85L9.60236 18.8384L9.71047 18.7918V26.3392C9.71047 26.6188 9.69081 26.9099 9.6515 27.1778C9.63184 27.2826 9.62201 27.3758 9.60236 27.4806C9.52373 27.8767 9.41562 28.2494 9.25836 28.5988C9.16008 28.8317 9.04214 29.053 8.91437 29.2743C8.80625 29.449 8.69814 29.6121 8.57037 29.7752C8.46226 29.9149 8.34432 30.043 8.22638 30.1595C8.11827 30.276 8.00032 30.3692 7.88238 30.474C7.77427 30.5672 7.65633 30.6487 7.53839 30.7302C7.43028 30.8001 7.31234 30.87 7.19439 30.9282C7.18457 30.9282 7.17474 30.9399 7.16491 30.9515C7.06663 30.9981 6.95851 31.0447 6.86023 31.0913C6.83074 31.1029 6.80126 31.1146 6.77177 31.1262L6.51624 31.2194L5.82825 31.4757L5.48425 31.6038L5.14026 31.7319L4.983 31.7901C4.92403 31.8134 4.86506 31.8367 4.80609 31.8484C4.68815 31.8833 4.58004 31.9183 4.4621 31.9415C4.34416 31.9648 4.23604 31.9881 4.1181 31.9881C4.00999 31.9998 3.91171 31.9998 3.81342 31.9998H3.78394C3.666 31.9998 3.55788 31.9881 3.43994 31.9765C3.322 31.9648 3.21389 31.9415 3.09595 31.9183C2.97801 31.895 2.8699 31.86 2.75195 31.8134C2.68316 31.7901 2.62419 31.7668 2.55539 31.7435C2.50624 31.7203 2.4571 31.697 2.40796 31.6737C2.29002 31.6154 2.18191 31.5572 2.06397 31.4873C1.94602 31.4174 1.82808 31.3359 1.71997 31.2427C1.67083 31.2078 1.62169 31.1612 1.57255 31.1262C1.50375 31.068 1.44478 31.0098 1.37598 30.9399C1.25804 30.8234 1.1401 30.6953 1.03198 30.5555C0.904214 30.4041 0.786273 30.2294 0.687989 30.0547C0.550391 29.8334 0.442278 29.6004 0.343994 29.3559C0.117941 28.7735 0 28.1329 0 27.469V18.1978C0 17.4524 0.117941 16.7302 0.343994 16.0663C0.393136 15.9149 0.442278 15.7751 0.501249 15.6354C0.560219 15.4956 0.61919 15.3675 0.67816 15.2394C0.717474 15.1462 0.766616 15.0647 0.815758 14.9831C0.874728 14.8783 0.933699 14.7735 1.0025 14.6803C1.0025 14.6687 1.01233 14.657 1.02215 14.657C1.13027 14.494 1.23838 14.3425 1.36615 14.1911C1.41529 14.1329 1.4546 14.0746 1.51358 14.0281C1.58237 13.9465 1.64134 13.8883 1.71014 13.8184C1.80843 13.7252 1.90671 13.6204 2.01482 13.5389C2.02465 13.5272 2.04431 13.5156 2.05414 13.5039C2.16225 13.4108 2.28019 13.3176 2.39813 13.2477C2.43745 13.2244 2.47676 13.1895 2.5259 13.1662C2.5947 13.1196 2.67333 13.073 2.74213 13.0264C2.75195 13.0147 2.76178 13.0147 2.78144 13.0031C2.86007 12.9565 2.94852 12.9099 3.02715 12.875C3.04681 12.8633 3.06646 12.8517 3.08612 12.8517C3.1844 12.8051 3.29252 12.7585 3.3908 12.7236L3.42029 12.7119L3.51857 12.677L3.76428 12.5838L4.02965 12.479L4.10828 12.444L4.45227 12.3159L4.5309 12.281L4.79626 12.1878L4.85523 12.1645L5.04197 12.0946L5.14026 12.0597L5.48425 11.9316L5.54322 11.9083L5.81842 11.8034L6.04447 11.7219L6.16241 11.6753L6.50641 11.5472L6.54572 11.5355L6.80126 11.4424L6.8504 11.4307L7.0568 11.3492L7.19439 11.3026L7.53839 11.1745L7.55805 11.1628L7.87256 11.0464L8.0593 10.9765L8.21655 10.9182L8.56054 10.7901H8.57037L8.90454 10.662L9.07162 10.6038L9.24853 10.5339L9.45493 10.4523L9.50407 10.4407L9.71047 10.3592L9.84807 10.3009L10.1921 10.1728L10.2117 10.1612L10.5262 10.0447L10.713 9.97481L10.8112 9.92822Z\"\n fill=\"#0231C5\"\n />\n </svg>\n );\n};\n","import { SVGProps } from \"react\";\n\ntype SidebarToggleProps = {\n onToggleSideBar: (isOpen: boolean) => void;\n isSidebarCollapsed: boolean;\n};\n\nexport const SidebarToggle = ({\n onToggleSideBar,\n isSidebarCollapsed,\n}: SidebarToggleProps) => {\n return (\n <button\n onClick={() => onToggleSideBar(!isSidebarCollapsed)}\n className=\"w-6 h-12 bg-[#EEF2FF] rounded-tr-md [clip-path:polygon(0%_0%,100%_0%,100%_60%,0%_100%,0%_100%)] mt-5 flex justify-center items-center pb-2 text-gray-700\"\n >\n {isSidebarCollapsed ? <OpenIcon /> : <CloseIcon />}\n </button>\n );\n};\n\nconst OpenIcon = (props: SVGProps<SVGSVGElement>) => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"15\"\n height=\"20\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n className=\"lucide lucide-panel-left-open-icon lucide-panel-left-open\"\n {...props}\n >\n <rect width=\"18\" height=\"18\" x=\"3\" y=\"3\" rx=\"2\" />\n <path d=\"M9 3v18\" />\n <path d=\"m14 9 3 3-3 3\" />\n </svg>\n );\n};\n\nconst CloseIcon = (props: SVGProps<SVGSVGElement>) => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"15\"\n height=\"20\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n className=\"lucide lucide-panel-right-open-icon lucide-panel-right-open\"\n {...props}\n >\n <rect width=\"18\" height=\"18\" x=\"3\" y=\"3\" rx=\"2\" />\n <path d=\"M15 3v18\" />\n <path d=\"m10 15-3-3 3-3\" />\n </svg>\n );\n};\n","import { cn } from \"@/src/utils\";\n\ntype Variant = \"success\" | \"failed\" | \"pending\" | \"abandoned\";\n\nexport const Status = ({\n status,\n variant,\n className,\n}: {\n status: string;\n variant: Variant;\n className?: string;\n}) => {\n return (\n <div>\n <div\n className={cn(\n \"order-first max-w-max flex-none rounded-full px-2 py-1 text-xs font-medium ring-1 ring-inset ring-current sm:order-none text-[14px] capitalize\",\n {\n \"bg-green-500/20 text-green-500\": variant === \"success\",\n },\n {\n \"bg-gray-500/20 text-white\": variant === \"abandoned\",\n },\n {\n \"bg-red-500/20 text-red-500\": variant === \"failed\",\n },\n {\n \"bg-yellow-500/20 text-yellow-500\": variant === \"pending\",\n },\n className,\n )}\n >\n <p>{status.replace(\"-\", \" \")}</p>\n </div>\n </div>\n );\n};\n","import { cn } from \"@/src/utils\";\nimport { Table as ReactTable, Row, RowData } from \"@tanstack/react-table\";\nimport { Loader } from \"lucide-react\";\nimport { ReactNode } from \"react\";\nimport { Pagination, PaginationProps } from \"./pagination\";\nimport { TableBody } from \"./TableBody\";\nimport { PageDataToolbar } from \"./ToolBar\";\nimport { FilterListItem } from \"./filters/FilterContent\";\n\nexport type TableSearchProps = {\n enabled: boolean;\n debounceRate?: number;\n onSearch?: (query: string) => void;\n};\n\nexport type TableDownloadProps = {\n enabled: boolean;\n buttonId?: string;\n onDownload?: () => void;\n buttonText?: string;\n};\nexport type TablePaginationProps = {\n enabled: boolean;\n} & PaginationProps;\n\ntype TableProps<T extends RowData> = {\n ExtraNode?: ReactNode;\n /**\n * @deprecated Use the `filterListOptions` prop instead.\n *\n * The `FilterMenu` prop is deprecated in favor of `filterListOptions`, which provides a more flexible and structured way to define filter options for the table.\n *\n * To manage the state of applied filters, use the `setAppliedFilters` callback. This function can be used to collect and update the current filter state based on user interactions with the filter list options.\n *\n * The `filterListOptions` prop accepts an array of filter configuration objects, allowing you to define available filters, their types, and possible values. This approach enables dynamic filter rendering and better state management compared to the static `FilterMenu` node.\n */\n FilterMenu?: ReactNode;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setAppliedFilters?: (values: Record<string, any>) => void;\n filterListOptions?: FilterListItem[];\n buttonClassName?: string;\n download?: TableDownloadProps;\n id?: string;\n isLoading?: boolean;\n isMobile?: boolean;\n isRefetching?: boolean;\n onExport?: () => void;\n onRefetch?: () => void;\n onRowClick?: (row: Row<T>) => void;\n pagination?: TablePaginationProps;\n search?: TableSearchProps;\n table: ReactTable<T>;\n};\n\nexport const Table = <T extends RowData>({\n table,\n isMobile = false,\n onRowClick,\n id = \"table\",\n onRefetch,\n isRefetching,\n FilterMenu,\n ExtraNode,\n //deprecated: onExport - use download\n onExport,\n search = {\n enabled: false,\n debounceRate: 700,\n },\n download = {\n enabled: false,\n buttonId: \"download_button\",\n buttonText: \"Export\",\n },\n isLoading,\n pagination,\n filterListOptions,\n setAppliedFilters,\n}: TableProps<T>) => {\n return (\n <div className={cn(\"relative w-full rounded-b border-0 overflow-x-auto\")}>\n <PageDataToolbar\n onRefetch={onRefetch}\n search={search}\n FilterMenu={FilterMenu}\n ExtraNode={ExtraNode}\n onExport={onExport}\n download={download}\n isRefetching={isRefetching}\n filterListOptions={filterListOptions}\n setAppliedFilters={setAppliedFilters}\n id={id}\n />\n\n <main className=\"w-full overflow-x-auto mt-5\">\n {isLoading ? (\n <div className=\"py-10 flex flex-col justify-center w-full items-center space-x-2\">\n <Loader size={20} className=\"animate-spin\" />\n <p className=\"mt-3 text-center text-gray-600 text-sm opacity-70 animate-pulse\">\n Loading...\n </p>\n </div>\n ) : table.getRowModel().rows.length < 1 ? (\n <div className=\"py-10 flex flex-col justify-center w-full items-center\">\n <p className=\"text-center text-gray-600 text-sm opacity-70\">\n No data available\n </p>\n </div>\n ) : (\n <div className=\"flex flex-col gap-2\">\n <TableBody\n table={table}\n isMobile={isMobile}\n onRowClick={onRowClick}\n id={id}\n />\n </div>\n )}\n </main>\n\n {!isLoading &&\n pagination?.enabled &&\n table.getRowModel().rows.length > 0 && (\n <Pagination\n {...pagination}\n currentPage={pagination?.currentPage ?? 1}\n totalPages={\n pagination?.totalPages ??\n Math.ceil(\n (pagination?.totalItems ?? 0) /\n Math.max(pagination?.itemsPerPage ?? 1, 1),\n ) ??\n 1\n }\n onPageChange={(page) => pagination?.onPageChange?.(page)}\n id={id}\n />\n )}\n </div>\n );\n};\n","import { ChevronLeftIcon, ChevronRightIcon } from \"lucide-react\";\nimport { renderPageNumbers } from \"./utils\";\n\nexport type PaginationProps = {\n currentPage?: number;\n totalPages?: number;\n onPageChange?: (page: number) => void;\n totalItems?: number;\n itemsPerPage?: number;\n id?: string;\n};\n\n/**\n * Pagination component for displaying pagination controls.\n * @param {number} currentPage - The current page number.\n * @param {number} totalPages - The total number of pages.\n * @param {function} onPageChange - Callback function to handle page change.\n * @param {number | undefined} itemsPerPage - The number of items per page.\n */\nexport const Pagination = ({\n currentPage = 1,\n totalPages = 1,\n onPageChange,\n itemsPerPage = 0,\n totalItems = 0,\n id = \"pagination\",\n}: PaginationProps) => {\n const handlePageClick = (page: number) => {\n if (page >= 1 && page <= totalPages) {\n onPageChange?.(page);\n }\n };\n const visibleRangeStart =\n itemsPerPage === 0 ? 1 : itemsPerPage * (currentPage - 1) + 1;\n const visibleRangeEnd =\n currentPage === totalPages\n ? totalItems\n : Math.min(visibleRangeStart + itemsPerPage - 1, totalItems);\n return (\n <div className=\"flex items-center justify-between border-t border-gray-200 px-4 py-3 sm:px-6 w-full flex-wrap gap-y-10 sm:gap-y-0\">\n {totalItems && (\n <section className=\"text-[#717171] text-[12px]\">\n <p className=\"\">\n Showing {visibleRangeStart} - {visibleRangeEnd} of {totalItems}\n </p>\n </section>\n )}\n <div className=\"flex items-center justify-center sm:justify-end \">\n <nav className=\" inline-flex gap-x-1 sm:gap-x-[10px] items-center\">\n <button\n onClick={() => handlePageClick(currentPage - 1)}\n id={`${id}-prev-button`}\n disabled={currentPage === 1}\n className=\"text-xs text-[#222222] hover:bg-primary-main/10 disabled:text-[#D9D9D9] disabled:cursor-not-allowed sm:flex hidden\"\n >\n <ChevronLeftIcon className=\"size-5\" />\n </button>\n {renderPageNumbers({ currentPage, totalPages, handlePageClick })}\n <button\n onClick={() => handlePageClick(currentPage + 1)}\n id={`${id}-next-button`}\n disabled={currentPage === totalPages}\n className=\"text-xs text-[#222222] hover:bg-primary-main/10 disabled:text-[#D9D9D9] disabled:cursor-not-allowed sm:flex hidden\"\n >\n <ChevronRightIcon className=\"size-5\" />\n </button>\n </nav>\n </div>\n </div>\n );\n};\n","type RenderPageNumbersProps = {\n totalPages: number;\n currentPage: number;\n handlePageClick: (page: number) => void;\n};\n\nconst PageButton = ({\n page,\n currentPage,\n onClick,\n}: {\n page: number | string;\n currentPage: number;\n onClick?: () => void;\n}) => {\n if (typeof page === \"string\") {\n return (\n <span className=\"px-3 py-1 sm:px-4 sm:py-2 text-xs sm:text-sm font-semibold text-gray-500\">\n {page}\n </span>\n );\n }\n\n return (\n <button\n onClick={onClick}\n id={`page-button-${page}`}\n className={`p-1 w-8 h-8 text-xs sm:text-sm rounded-full ${\n page === currentPage\n ? \"bg-primary-main text-white\"\n : \"text-[#717171] hover:bg-primary-main/10\"\n }`}\n >\n {page}\n </button>\n );\n};\n\nexport const renderPageNumbers = ({\n totalPages,\n currentPage,\n handlePageClick,\n}: RenderPageNumbersProps) => {\n const maxVisiblePages = 3;\n\n const getWindowBounds = () => {\n const halfWindow = Math.floor(maxVisiblePages / 2);\n let start = Math.max(1, currentPage - halfWindow);\n let end = Math.min(totalPages, start + maxVisiblePages - 1);\n\n if (end > totalPages) {\n start = Math.max(1, totalPages - maxVisiblePages + 1);\n end = totalPages;\n }\n\n return { start, end };\n };\n\n const { start, end } = getWindowBounds();\n const pages: (number | string)[] = [];\n\n if (start > 1) pages.push(1);\n if (start > 2) pages.push(\"...\");\n pages.push(...Array.from({ length: end - start + 1 }, (_, i) => start + i));\n if (end < totalPages - 1) pages.push(\"...\");\n if (end < totalPages) pages.push(totalPages);\n\n return pages.map((page, idx) => (\n <PageButton\n key={idx}\n page={page}\n currentPage={currentPage}\n onClick={\n typeof page === \"number\" ? () => handlePageClick(page) : undefined\n }\n />\n ));\n};\n","import {\n flexRender,\n Row,\n RowData,\n Table as ReactTable,\n} from \"@tanstack/react-table\";\nimport { cn } from \"@/src/utils\";\n\ntype TableBodyProps<T extends RowData> = {\n table: ReactTable<T>;\n isMobile: boolean;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n onRowClick?: (row: Row<any>) => void;\n id?: string;\n};\n\nexport const TableBody = <T extends RowData>({\n table,\n isMobile,\n onRowClick,\n id,\n}: TableBodyProps<T>) => {\n return (\n <div className={cn(\"relative w-full rounded-b border-0\", {})}>\n <table id={id ?? \"table\"} className=\"w-full overflow-x-scroll\">\n <thead>\n {table.getHeaderGroups().map((headerGroup) => (\n <tr\n className={cn(\n \" rounded text-[#717171] border-b- bg-[#FCFCFC]\",\n {},\n )}\n key={headerGroup.id}\n >\n {headerGroup.headers.map((header) => (\n <th\n className=\"relative py-3 text-base whitespace-nowrap pl-2.5 text-left font-normal capitalize\"\n colSpan={header.colSpan}\n key={header.id}\n style={{\n width: header.getSize(),\n }}\n >\n {header.isPlaceholder ? null : (\n <div\n className={cn(\"flex items-center\", {\n \"cursor-pointer select-none\":\n header.column.getCanSort(),\n })}\n onClick={header.column.getToggleSortingHandler()}\n >\n {header.isPlaceholder\n ? null\n : flexRender(\n header.column.columnDef.header,\n header.getContext(),\n )}\n </div>\n )}\n </th>\n ))}\n </tr>\n ))}\n </thead>\n <tbody className=\" pl-2.5\">\n {table?.getFilteredRowModel().rows.map((row) => (\n <tr\n className={cn(\n \"first-letter border-b border-zinc-100\",\n {\n \"hover:bg-gray-50\": !isMobile,\n },\n {\n \"hover:bg-gray-50 hover:cursor-pointer\": onRowClick,\n },\n )}\n key={row.id}\n onClick={() => (onRowClick ? onRowClick(row) : {})}\n >\n {row.getVisibleCells().map((cell) => (\n <td\n className={cn(\"\", {\n // block: false,\n })}\n key={cell.id}\n >\n <div\n className={cn(\"\", {\n \"w-max p-4 pl-2.5 text-black text-sm\": true,\n })}\n >\n {flexRender(cell.column.columnDef.cell, cell.getContext())}\n </div>\n </td>\n ))}\n </tr>\n ))}\n </tbody>\n </table>\n </div>\n );\n};\n","import { cn } from \"@/src/utils\";\nimport { Download, ListFilter, RotateCw } from \"lucide-react\";\nimport { ReactNode } from \"react\";\nimport { Button, buttonVariants } from \"../button\";\nimport { DebouncedInput } from \"../debounced-input\";\nimport { Popover } from \"../popover\";\nimport { TableDownloadProps, TableSearchProps } from \"./index\";\nimport { FilterListItem } from \"./filters/FilterContent\";\nimport { FilterPopover } from \"./filters\";\n\ntype PageDataToolbarProps = {\n onRefetch?: () => void;\n search?: TableSearchProps;\n FilterMenu?: ReactNode;\n ExtraNode?: ReactNode;\n onExport?: () => void;\n download?: TableDownloadProps;\n isRefetching?: boolean;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setAppliedFilters?: (values: Record<string, any>) => void;\n filterListOptions?: FilterListItem[];\n id?: string;\n};\n\nexport const PageDataToolbar = ({\n onRefetch,\n search,\n FilterMenu,\n ExtraNode,\n onExport,\n download,\n isRefetching,\n filterListOptions = [],\n setAppliedFilters,\n id = \"table-toolbar\",\n}: PageDataToolbarProps) => {\n const handleSearch = (query: string) => {\n search?.onSearch?.(query);\n };\n\n const handleRefetch = () => {\n try {\n onRefetch?.();\n } catch (e) {\n console.error(\"Error while refetching data\", e);\n }\n };\n\n return (\n <>\n {(onRefetch ||\n search?.enabled ||\n FilterMenu ||\n ExtraNode ||\n onExport) && (\n <div className=\"w-full flex flex-col sm:!flex-row justify-between items-start sm:items-center bg-white p-2 gap-2\">\n <div className=\"flex flex-1 flex-col sm:flex-row items-center gap-2 justify-start\">\n <div className=\" w-full flex gap-x-3\">\n {search?.enabled && (\n <section className=\"sm:w-56\">\n <DebouncedInput\n type=\"text\"\n placeholder=\"Enter search here...\"\n className=\"h-9\"\n onChange={handleSearch}\n debounce={search?.debounceRate}\n id={`${id}-search-input`}\n />\n </section>\n )}\n <div className=\" flex gap-2\">\n {onRefetch && (\n <Button\n onClick={handleRefetch}\n title=\"Refetch Data\"\n disabled={isRefetching}\n variant=\"outlined\"\n className=\"!border-[#DEDEDE] !text-gray-800 !px-[10px] !py-[8px] \"\n size={\"sm\"}\n id={`${id}-refetch-button`}\n >\n <RotateCw\n className={cn(\"w-4 h-4\", {\n \"animate-spin\": isRefetching,\n })}\n size={5}\n />\n </Button>\n )}\n\n {filterListOptions?.length ? (\n <FilterPopover\n setAppliedFilters={setAppliedFilters}\n filters={filterListOptions}\n id={`${id}-filter-popover`}\n />\n ) : null}\n\n {FilterMenu && (\n <Popover\n id={`${id}-deprecated-filter-popover`}\n trigger={\n <button\n title=\"Filter\"\n className={cn(\n \"!border-[#DEDEDE] !text-gray-800 !px-[10px] !py-[8px]\",\n buttonVariants({\n variant: \"outlined\",\n size: \"sm\",\n }),\n )}\n >\n <ListFilter className=\"w-4 h-4\" size={5} />\n </button>\n }\n >\n {FilterMenu}\n </Popover>\n )}\n </div>\n </div>\n </div>\n <div className=\"flex items-start flex-col gap-2 justify-center\">\n <section className=\"flex flex-col-reverse sm:flex-row gap-2\">\n <div className=\"flex gap-2\">\n {ExtraNode && ExtraNode}\n\n {onExport && (\n <Button\n variant=\"primary\"\n onClick={onExport}\n size={\"sm\"}\n id={`${id}-export-button`}\n >\n Export\n </Button>\n )}\n {download?.enabled && (\n <Button\n variant=\"primary\"\n leftNode={<Download className=\"w-4 h-5\" size={5} />}\n onClick={download?.onDownload}\n id={download.buttonId}\n size={\"sm\"}\n >\n {download?.buttonText}\n </Button>\n )}\n </div>\n </section>\n </div>\n </div>\n )}\n </>\n );\n};\n","\"use client\";\n\nimport React, { useEffect, useState } from \"react\";\nimport { useForm, Controller } from \"react-hook-form\";\nimport { Select } from \"../../select\";\nimport { Input, InputProps } from \"../../input\";\nimport { buttonVariants } from \"../../button\";\nimport { RadioGroup, RadioGroupItem } from \"../../radio\";\nimport { v4 } from \"uuid\";\nimport { FormLabel } from \"../../label/FormLabel\";\nimport { CalendarInput } from \"../../calendar/CalendarInput\";\nimport { useFilterStore } from \"./helper/useFilterStore\";\nimport { PopoverClose } from \"@radix-ui/react-popover\";\nimport { cn } from \"@/src/utils\";\n\ntype SelectOption = {\n value: string;\n label: string;\n};\n\ntype Base = {\n type: \"input\" | \"drop-down\" | \"date-range\" | \"multi\" | \"date\" | \"radio\";\n key: string;\n label: string;\n placeholder?: string;\n};\n\ntype FilterListOption = {\n type: \"input\";\n} & Exclude<InputProps, \"value\" | \"onChange\">;\n\ntype FilterListDate = {\n type: \"date\";\n date?: string | Date;\n};\ntype FilterListInputDropDown = {\n type: \"drop-down\" | \"multi\" | \"radio\";\n options: SelectOption[];\n};\n\nexport type FilterListItem = Base &\n (FilterListOption | FilterListInputDropDown | FilterListDate);\n\nexport type FilterContentProps = {\n filters: FilterListItem[];\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n values?: Record<string, any>;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setAppliedFilters?: (values: Record<string, any>) => void;\n id?: string;\n};\n\nexport type FilterListOptions = FilterListItem[];\n\nexport const FilterContent: React.FC<FilterContentProps> = ({\n filters,\n values = {},\n setAppliedFilters,\n id = \"filter-content\",\n}) => {\n const filterStore = useFilterStore();\n\n const { upDateFilter, resetFilters, filters: cachedFilters } = filterStore();\n\n const [syncFilter, setSyncFilter] = useState(true);\n\n const handleFiltersSync = () => {\n setSyncFilter(true);\n };\n\n const { control, handleSubmit } = useForm({\n defaultValues: cachedFilters ?? values,\n });\n\n useEffect(() => {\n if (syncFilter && setAppliedFilters) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setAppliedFilters(cachedFilters as any);\n setSyncFilter(false);\n }\n }, [syncFilter]);\n\n const handleReset = () => {\n resetFilters();\n handleFiltersSync();\n };\n\n const onSubmit = (\n values:\n | Record<string, unknown>\n | ((\n prev: Record<string, unknown> | null,\n ) => Record<string, unknown> | null)\n | null,\n ) => {\n const filtered = Object.fromEntries(\n Object.entries(values ?? {}).filter(\n ([, v]) => v !== undefined && v !== null && v !== \"\",\n ),\n );\n\n upDateFilter(filtered);\n handleFiltersSync();\n };\n\n return (\n <form onSubmit={handleSubmit(onSubmit)}>\n <div className=\"space-y-3\">\n {filters.map((filter) => {\n switch (filter.type) {\n case \"input\":\n return (\n <div key={filter.key}>\n <Controller\n name={filter.key}\n control={control}\n render={({ field, formState }) => (\n <Input\n error={formState?.errors?.root?.message}\n placeholder={filter?.placeholder}\n id={`${id}-${filter.key}`}\n {...field}\n {...filter}\n />\n )}\n />\n </div>\n );\n case \"drop-down\":\n return (\n <div key={filter.key}>\n <Controller\n name={filter.key}\n control={control}\n render={({\n field: { value, onChange },\n formState: { errors },\n }) => {\n return (\n <Select\n label={filter?.label}\n options={filter?.options}\n value={filter?.options?.find(\n (option) => String(option?.value) === String(value),\n )}\n onChange={(val) => onChange(val?.value)}\n error={errors?.[filter?.key]?.message as string}\n modal\n placeholder={filter?.placeholder}\n className=\"!h-10\"\n id={`${id}-${filter.key}`}\n />\n );\n }}\n />\n </div>\n );\n\n case \"radio\":\n return (\n <div key={filter.key}>\n <Controller\n name={filter.key}\n control={control}\n render={({ field: { value, onChange } }) => (\n <>\n <FormLabel className=\"block text-sm font-medium mb-2 text-pallet-text-white-black\">\n {filter?.label}\n </FormLabel>\n <RadioGroup\n onValueChange={onChange}\n defaultValue={value}\n aria-label={filter?.label}\n id={`${id}-${filter.key}`}\n >\n <div className=\"flex items-center gap-2\">\n {filter?.options?.map((option) => (\n <div\n key={v4()}\n className=\"flex items-center space-x-2\"\n >\n <RadioGroupItem\n value={option?.value}\n id={`${id}-${filter.key}-${option?.value}`}\n />\n <label\n htmlFor={`${id}-${filter.key}-${option?.value}`}\n className=\"text-xs\"\n >\n {option?.label}\n </label>\n </div>\n ))}\n </div>\n </RadioGroup>\n </>\n )}\n />\n </div>\n );\n case \"date\":\n return (\n <div key={filter.key}>\n <Controller\n name={filter.key}\n control={control}\n render={({ field }) => (\n <CalendarInput\n onChange={field?.onChange}\n value={field?.value}\n label={filter?.label}\n />\n )}\n />\n </div>\n );\n default:\n return null;\n }\n })}\n </div>\n <div style={{ marginTop: 28 }} className=\"grid grid-cols-2 gap-2\">\n <PopoverClose\n onClick={handleReset}\n className={cn(buttonVariants({ variant: \"outlined\", size: \"sm\" }))}\n type=\"button\"\n id={`${id}-reset-button`}\n >\n Reset\n </PopoverClose>\n <PopoverClose\n className={cn(buttonVariants({ size: \"sm\" }))}\n type=\"submit\"\n id={`${id}-submit-button`}\n >\n Submit\n </PopoverClose>\n </div>\n </form>\n );\n};\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as RadioGroupPrimitive from \"@radix-ui/react-radio-group\";\nimport { cn } from \"../../utils\";\n\ntype RadioGroupProps = React.ComponentPropsWithoutRef<\n typeof RadioGroupPrimitive.Root\n> & {\n className?: string;\n};\n\ntype RadioGroupItemProps = React.ComponentPropsWithoutRef<\n typeof RadioGroupPrimitive.Item\n> & {\n className?: string;\n};\n\nconst RadioGroup = React.forwardRef<\n React.ElementRef<typeof RadioGroupPrimitive.Root>,\n RadioGroupProps\n>(({ className, ...props }, ref) => {\n return (\n <RadioGroupPrimitive.Root\n className={cn(\"grid gap-2\", className)}\n {...props}\n ref={ref}\n />\n );\n});\nRadioGroup.displayName = RadioGroupPrimitive.Root.displayName;\n\nconst RadioGroupItem = React.forwardRef<\n React.ElementRef<typeof RadioGroupPrimitive.Item>,\n RadioGroupItemProps\n>(({ className, ...props }, ref) => {\n return (\n <RadioGroupPrimitive.Item\n ref={ref}\n className={cn(\n `aspect-square h-4 w-4 rounded-full border border-[#808080] text-primary-main ring-offset-background focus-visible:outline-none \n\t\t\t\t\t\tfocus-visible:border-purplring-purple-200 focus-visible:!ring-primary-main focus-visible:!ring-status-success-bg focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 focus-visible:ring-purple-200 \n\t\t\t\t\t\tfocus:border-purplring-purple-200 focus:!ring-primary-main focus:!ring-status-success-bg focus:ring-2 focus:ring-ring focus:ring-offset-2 focus:ring-purple-200 disabled:cursor-not-allowed disabled:opacity-50`,\n className,\n )}\n {...props}\n >\n <RadioGroupPrimitive.Indicator className=\"rounded-full flex items-center justify-center\">\n <div className=\"h-2 w-2 bg-current text-current rounded-full transition\" />\n </RadioGroupPrimitive.Indicator>\n </RadioGroupPrimitive.Item>\n );\n});\nRadioGroupItem.displayName = RadioGroupPrimitive.Item.displayName;\n\nexport { RadioGroup, RadioGroupItem };\n","\"use client\";\n\nimport * as React from \"react\";\nimport { DayPickerSingleProps } from \"react-day-picker\";\nimport { PopoverContent, PopoverRoot, PopoverTrigger } from \"../popover\";\nimport { cn } from \"../../utils\";\nimport { Calendar } from \".\";\nimport { FormLabel } from \"../label/FormLabel\";\nimport { VariantProps } from \"class-variance-authority\";\nimport { inputContainerVariants } from \"../input\";\n\ninterface DateInputButtonProps\n extends VariantProps<typeof inputContainerVariants> {\n value?: React.ReactNode;\n onClick?: () => void;\n error?: string;\n}\n\nexport const DateInputButton = React.forwardRef<\n HTMLButtonElement,\n DateInputButtonProps\n>(({ value, onClick, error, status }, ref) => (\n <div className=\"relative mt-2 rounded-md shadow-sm !w-full\">\n <button\n className={cn(\n inputContainerVariants({ status }),\n \"flex items-center gap-2 text\",\n // \"pl-3 text-left block w-full rounded-md border-0 py-1.5 pr-10 ring-1 ring-inset focus:ring-2 focus:ring-inset disabled:cursor-not-allowed disabled:bg-gray-50 disabled:text-gray-500 disabled:ring-gray-200 sm:text-sm sm:leading-6\",\n {\n \"text-gray-900 ring-gray-300 placeholder:text-gray-400 focus:ring-purple-600\":\n !error,\n \"text-red-900 ring-red-300 placeholder:text-red-300 focus:ring-red-500\":\n error,\n },\n )}\n onClick={onClick}\n ref={ref}\n type=\"button\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n className=\"lucide lucide-calendar-icon lucide-calendar\"\n >\n <path d=\"M8 2v4\" />\n <path d=\"M16 2v4\" />\n <rect width=\"18\" height=\"18\" x=\"3\" y=\"4\" rx=\"2\" />\n <path d=\"M3 10h18\" />\n </svg>\n {value || \"Select a date\"}\n </button>\n </div>\n));\n\nDateInputButton.displayName = \"DateInputButton\";\n\ninterface DateTriggerProps {\n // extends VariantProps<typeof inputContainerVariants>\n value: Date | undefined;\n placeholder?: string;\n className?: string;\n disabled?: boolean;\n isLoading?: boolean;\n error?: string;\n status?: \"default\" | \"error\" | \"loading\" | \"prefilled\";\n}\n\nconst format = (date: Date | undefined, placeholder: React.ReactNode) => {\n return date\n ? new Date(date).toLocaleDateString(\"en-US\", {\n year: \"numeric\",\n month: \"long\",\n day: \"numeric\",\n })\n : placeholder;\n};\n\nfunction Trigger({\n // status,\n value,\n className,\n placeholder = \"Pick a date\",\n ...props\n}: DateTriggerProps) {\n return (\n <PopoverTrigger asChild className={cn(\"cursor-pointer\", className)}>\n <DateInputButton\n value={format(value, placeholder)}\n error={props?.error}\n />\n </PopoverTrigger>\n );\n}\n\ntype DateProps = {\n children: React.ReactNode;\n modal?: boolean;\n disableDate?: boolean;\n} & Omit<DayPickerSingleProps, \"mode\">;\n\nfunction Picker({\n children,\n captionLayout = \"dropdown-buttons\",\n fromYear = 1900,\n toYear = new Date().getFullYear(),\n disableDate,\n modal,\n ...props\n}: DateProps) {\n const [open, setOpen] = React.useState(false);\n return (\n <PopoverRoot\n modal={modal}\n open={disableDate ? false : open}\n onOpenChange={setOpen}\n >\n {children}\n <PopoverContent align=\"start\" className=\"w-auto p-0\">\n <Calendar\n mode=\"single\"\n fromYear={fromYear}\n toYear={toYear}\n captionLayout={captionLayout}\n initialFocus\n classNames={{}}\n showOutsideDays={false}\n {...props}\n />\n </PopoverContent>\n </PopoverRoot>\n );\n}\n\nexport const formatFormDate = (\n date?: number | Date | string | null,\n dateFormat = \"yyyy-MM-dd\",\n) => {\n if (date) return String(format(new Date(date), dateFormat));\n return \"N/A\";\n};\n\ntype CalendarInputProps = {\n label?: string;\n helpText?: string | React.ReactNode;\n error?: string;\n optional?: boolean;\n onChange: (value: string | null) => void;\n value?: string;\n};\n\nconst CalendarInput = ({\n label,\n optional,\n onChange,\n error,\n helpText,\n value,\n}: CalendarInputProps) => {\n return (\n <div className=\"block w-full\">\n {label && (\n <div className=\"flex justify-between w-full\">\n <FormLabel className=\"block text-sm font-medium mb-0 text-pallet-text-white-black\">\n {label}\n </FormLabel>\n {optional && (\n <span\n className=\"text-sm leading-6 text-gray-500\"\n id=\"email-optional\"\n >\n Optional\n </span>\n )}\n </div>\n )}\n <Picker\n selected={value ? new Date(value) : undefined}\n onSelect={(date) => {\n const formattedDate = date ? formatFormDate(date, \"yyyy-MM-dd\") : \"\";\n // const formattedDate = formatFormDate(date, 'Y-m-d H:i:s');\n onChange(formattedDate);\n }}\n disabled={(date: Date) =>\n date < new Date(\"2000-01-01\") || date > new Date(\"3000-01-01\")\n }\n fromYear={2000}\n toYear={3000}\n >\n <div>\n <Trigger\n status={error ? \"error\" : \"default\"}\n value={value ? new Date(value) : undefined}\n />\n </div>\n </Picker>\n {error && (\n <p className=\"mt-2 text-sm text-red-600\" id={`${name}-error`}>\n {error}\n </p>\n )}\n\n {helpText && (\n <p className=\"mt-2 text-sm text-gray-500\" id={`${name}-description`}>\n {helpText}\n </p>\n )}\n </div>\n );\n};\n\nexport { Picker, Trigger, CalendarInput };\n","import { ChevronLeft, ChevronRight } from \"lucide-react\";\nimport * as React from \"react\";\nimport { DayPicker, DropdownProps, StyledElement } from \"react-day-picker\";\n\nimport { cn } from \"../../utils\";\nimport { Select } from \"../select\";\nimport { buttonVariants } from \"../button\";\n\nexport type CalendarProps = React.ComponentProps<typeof DayPicker> & {\n className?: string;\n classNames: Partial<StyledElement<string>> | undefined;\n showOutsideDays: boolean;\n};\n\nfunction Calendar({\n className,\n classNames,\n showOutsideDays = true,\n ...props\n}: CalendarProps) {\n return (\n <DayPicker\n showOutsideDays={showOutsideDays}\n className={cn(\"p-3\", className)}\n classNames={{\n months: \"flex flex-col sm:flex-row space-y-4 sm:space-x-4 sm:space-y-0\",\n month: \"space-y-4\",\n caption: \"flex justify-center pt-1 relative items-center\",\n caption_label: \"text-sm font-medium hidden\",\n\n // months: \"flex flex-col sm:flex-row space-y-4 sm:space-x-4 sm:space-y-0\",\n // month: \"space-y-4\",\n // caption: \"flex justify-center pt-1 relative items-center\",\n // caption_label: \"text-sm font-medium\",\n caption_dropdowns: \"flex justify-center gap-1 !px-4\",\n\n nav: \"space-x-1 flex items-center\",\n nav_button: cn(\n buttonVariants({ variant: \"outlined\" }),\n \"h-7 w-7 bg-transparent !text-black !border-0 p-0 opacity-50 hover:opacity-100\",\n ),\n nav_button_previous: \"absolute left-1\",\n nav_button_next: \"absolute right-1\",\n table: \"w-full border-collapse space-y-1\",\n head_row: \"flex\",\n head_cell:\n \"text-muted-foreground rounded-md w-9 font-normal text-[0.8rem]\",\n row: \"flex w-full mt-2\",\n cell: \"h-9 w-9 text-center text-sm p-0 relative [&:has([aria-selected].day-range-end)]:rounded-r-md [&:has([aria-selected].day-outside)]:bg-accent/50 [&:has([aria-selected])]:bg-accent first:[&:has([aria-selected])]:rounded-l-md last:[&:has([aria-selected])]:rounded-r-md focus-within:relative focus-within:z-20\",\n day: cn(\n buttonVariants({ variant: \"primary\" }),\n \"h-9 w-9 p-0 font-normal aria-selected:opacity-100 bg-white text-black/60\",\n ),\n day_range_end: \"day-range-end\",\n day_selected:\n \"!bg-primary-main !text-white hover:bg-primary hover:text-primary-foreground focus:bg-primary focus:text-primary-foreground\",\n day_today: \"bg-accent text-accent-foreground\",\n day_outside:\n \"day-outside text-muted-foreground aria-selected:bg-accent/50 aria-selected:text-muted-foreground\",\n day_disabled: \"text-muted-foreground opacity-50\",\n day_range_middle:\n \"aria-selected:bg-accent aria-selected:text-accent-foreground\",\n day_hidden: \"invisible\",\n ...classNames,\n }}\n components={{\n IconLeft: ({ ...props }) => (\n <ChevronLeft className=\"h-4 w-4\" {...props} />\n ),\n IconRight: ({ ...props }) => (\n <ChevronRight className=\"h-4 w-4\" {...props} />\n ),\n Dropdown: ({ value, onChange, children }: DropdownProps) => {\n const lgOptions = React.Children.toArray(\n children,\n ) as React.ReactElement<React.HTMLProps<HTMLOptionElement>>[];\n const options = lgOptions.map((option) => ({\n label: option.props.children as string,\n value: option.props.value?.toString() ?? \"\",\n }));\n\n // const selected = options.find((child) => child.value === value);\n\n const handleChange = (value: string) => {\n const changeEvent = {\n target: { value },\n } as React.ChangeEvent<HTMLSelectElement>;\n onChange?.(changeEvent);\n };\n\n return (\n <div className=\"\">\n <Select\n options={options}\n // getOptionLabel={(option) =>\n // (option?.props?.children as any) ?? \"\"\n // }\n // onInputValueChange={(value) => {\n // handleChange(value);\n // }}\n // getOptionValue={(option) => (option?.props?.value as any) ?? \"\"}\n value={options?.find(\n (option) => option?.value === value?.toString(),\n )}\n // size=\"xs\"\n onChange={(val) => handleChange(val?.value)}\n className=\"!border-0 !max-w-max\"\n // showShadow={false}\n // status='plain'\n />\n </div>\n );\n },\n }}\n disabled={(date) => date > new Date() || date < new Date(\"1900-01-01\")}\n // mode=\"single\"\n {...props}\n />\n );\n}\nCalendar.displayName = \"Calendar\";\n\nexport { Calendar };\n","\"use client\";\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { create } from \"zustand\";\n\ninterface FilterSliceType {\n filters: Record<string, any> | null;\n upDateFilter: (\n items:\n | Record<string, any>\n | ((prev: Record<string, any> | null) => Record<string, any> | null)\n | null,\n ) => void;\n resetFilters: () => void;\n}\n\nexport const FILTER_PREFIX = \"filter_\";\n\nconst syncFiltersWithURL = (filters: Record<string, any>) => {\n const params = new URLSearchParams(window?.location?.search);\n Object.keys(filters).forEach((key) => {\n params.set(`${FILTER_PREFIX}${key}`, filters[key]);\n });\n window.history.replaceState({}, \"\", `${window.location.pathname}?${params}`);\n};\n\nconst clearFiltersFromURL = () => {\n const params = new URLSearchParams(window.location.search);\n const keysToDelete: string[] = [];\n params.forEach((_, key) => {\n if (key.startsWith(FILTER_PREFIX)) {\n keysToDelete.push(key);\n }\n });\n keysToDelete.forEach((key) => params.delete(key));\n window.history.replaceState({}, \"\", `${window.location.pathname}?${params}`);\n};\n\nconst initializeFiltersFromURL = () => {\n if (typeof window === \"undefined\") {\n return {};\n }\n const params = new URLSearchParams(window.location.search);\n const filters: Record<string, any> = {};\n params.forEach((value, key) => {\n if (key.startsWith(FILTER_PREFIX)) {\n filters[key.replace(FILTER_PREFIX, \"\")] = value;\n }\n });\n return filters;\n};\n\nexport const createFilterStore = () => {\n return create<FilterSliceType>()((set) => ({\n filters: initializeFiltersFromURL(),\n resetFilters: () => {\n set({ filters: null });\n clearFiltersFromURL();\n },\n upDateFilter: (\n items:\n | Record<string, any>\n | ((prev: Record<string, any> | null) => Record<string, any> | null)\n | null,\n ) =>\n set((state) => {\n let newFilters;\n if (typeof items === \"function\") {\n newFilters = items(state.filters);\n } else {\n newFilters = { ...state?.filters, ...items };\n }\n syncFiltersWithURL(newFilters);\n return { filters: newFilters };\n }),\n }));\n};\n\nexport const useFilterStore = () => {\n const store = createFilterStore();\n\n return store;\n};\n","\"use client\";\n\nimport { cn } from \"@/src/utils\";\nimport { Popover } from \"../../popover\";\nimport { FilterContent, FilterContentProps } from \"./FilterContent\";\nimport { buttonVariants } from \"../../button\";\nimport { ListFilter } from \"lucide-react\";\nimport { ReactNode } from \"react\";\nimport { FilterLabelCount } from \"./components/FilterLabelCount\";\nimport { useMountClient } from \"@/src/hooks/useMountClient\";\n\ntype FilterPopoverProps = FilterContentProps & {\n isOpen?: boolean;\n trigger?: ReactNode;\n id?: string;\n};\n\nexport const FilterPopover = ({\n filters,\n setAppliedFilters,\n isOpen = false,\n id = \"filter-popover\",\n}: FilterPopoverProps) => {\n const { mounted: isClientMounted } = useMountClient();\n\n return isClientMounted ? (\n <div className=\"\">\n <Popover\n id={`${id}-filter-popover`}\n defaultOpen={isOpen}\n trigger={\n <button\n title=\"Filter\"\n className={cn(\n \"!border-[#DEDEDE] !text-gray-800 !p-0 flex items-center\",\n buttonVariants({\n variant: \"outlined\",\n size: \"sm\",\n }),\n )}\n type=\"button\"\n >\n <span className=\"!px-[10px] !py-[8px]\">\n <ListFilter className=\"w-4 h-4\" size={5} />\n </span>\n <FilterLabelCount setAppliedFilters={setAppliedFilters} />\n </button>\n }\n contentClassName=\"!border border-gray-200 pt-2\"\n >\n <FilterContent\n filters={filters}\n setAppliedFilters={setAppliedFilters}\n id={id}\n />\n </Popover>\n </div>\n ) : null;\n};\n","import { useEffect, useState } from \"react\";\nimport { useFilterStore } from \"../helper/useFilterStore\";\n\ntype Props = {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setAppliedFilters?: (values: Record<string, any>) => void;\n};\n\nexport const FilterLabelCount = ({ setAppliedFilters }: Props) => {\n const [syncFilter, setSyncFilter] = useState(true);\n const filterStore = useFilterStore();\n\n const { filters: cachedFilters } = filterStore();\n\n console.log(\"cachedFilters\", cachedFilters);\n\n const cachedKeys = Object.keys(cachedFilters ?? {});\n\n useEffect(() => {\n if (syncFilter && setAppliedFilters) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setAppliedFilters(cachedFilters as any);\n setSyncFilter(false);\n }\n }, [syncFilter]);\n\n return (\n <>\n {cachedKeys?.length ? (\n <div className=\"flex rounded-s-md bg-primary-main p-1 text-white text-sm px-2.5\">\n {cachedKeys?.length}\n </div>\n ) : (\n <></>\n )}\n </>\n );\n};\n","import { ReactNode, useEffect, useState } from \"react\";\n\nexport const useMountClient = () => {\n const [mounted, setMounted] = useState(false);\n\n useEffect(() => {\n setMounted(true);\n\n return () => setMounted(false);\n }, []);\n\n const MounClient = (children?: ReactNode) => {\n return mounted ? { children } : null;\n };\n return { mounted, MounClient };\n};\n","import { createContext, ReactNode, useMemo } from \"react\";\nimport { ResourcePermissions } from \"@/src/components/permission/types\";\n\nexport const PermissionsContext = createContext<\n ResourcePermissions | undefined\n>(undefined);\n\nexport const PermissionsProvider = ({\n permissions,\n children,\n}: {\n permissions: ResourcePermissions;\n children: ReactNode;\n}) => {\n const value = useMemo(() => permissions, [permissions]);\n return (\n <PermissionsContext.Provider value={value}>\n {children}\n </PermissionsContext.Provider>\n );\n};\n","import { useCallback, useContext, useMemo } from \"react\";\nimport { PermissionsContext } from \"./context\";\n\nexport const usePermissions = () => {\n const permissions = useContext(PermissionsContext);\n return permissions;\n};\n\nexport const useHasPermission = (permission: {\n resource?: string;\n action?: string;\n}) => {\n const permissions = usePermissions();\n\n const validatePermission = useCallback(\n (permission: { resource?: string; action?: string }) => {\n if (!permissions || !permission) return true;\n\n const hasAdminAccess = permissions.some(\n (p) => p.resource === \"all\" && p.action === \"administrator\",\n );\n\n if (hasAdminAccess) return true;\n\n const { resource, action } = permission;\n const matchingPermissions = permissions.filter(\n (p) => p.resource === resource,\n );\n const hasExactMatch = matchingPermissions.some(\n (p) => p.action === action,\n );\n if (hasExactMatch) return true;\n if (action === \"read\") {\n return matchingPermissions.some((p) => p.action === \"write\");\n }\n return false;\n },\n [permission],\n );\n\n const hasPermission = useMemo(\n () => validatePermission(permission),\n [permissions, permission],\n );\n\n return { hasPermission, validatePermission };\n};\n","import { useHasPermission } from \"./hook\";\nimport { ResourcePermissionProps } from \"./types\";\n\nexport const HasResourcePermission = ({\n permission,\n children,\n}: ResourcePermissionProps) => {\n const { hasPermission } = useHasPermission(permission || {});\n\n if (!permission) return <>{children}</>;\n\n return <>{hasPermission ? children : null}</>;\n};\n","export const CurrencySymbolMap: Record<string, string> = {\n USD: \"$\",\n CAD: \"CA$\",\n EUR: \"€\",\n AED: \"AED\",\n AFN: \"Af\",\n ALL: \"ALL\",\n AMD: \"AMD\",\n ARS: \"AR$\",\n AUD: \"AU$\",\n AZN: \"man.\",\n BAM: \"KM\",\n BDT: \"Tk\",\n BGN: \"BGN\",\n BHD: \"BD\",\n BIF: \"FBu\",\n BND: \"BN$\",\n BOB: \"Bs\",\n BRL: \"R$\",\n BWP: \"BWP\",\n BYN: \"Br\",\n BZD: \"BZ$\",\n CDF: \"CDF\",\n CHF: \"CHF\",\n CLP: \"CL$\",\n CNY: \"CN¥\",\n COP: \"CO$\",\n CRC: \"₡\",\n CVE: \"CV$\",\n CZK: \"Kč\",\n DJF: \"Fdj\",\n DKK: \"Dkr\",\n DOP: \"RD$\",\n DZD: \"DA\",\n EEK: \"Ekr\",\n EGP: \"EGP\",\n ERN: \"Nfk\",\n ETB: \"Br\",\n GBP: \"£\",\n GEL: \"GEL\",\n GHS: \"GH₵\",\n GNF: \"FG\",\n GTQ: \"GTQ\",\n HKD: \"HK$\",\n HNL: \"HNL\",\n HRK: \"kn\",\n HUF: \"Ft\",\n IDR: \"Rp\",\n ILS: \"₪\",\n INR: \"₹\",\n IQD: \"IQD\",\n IRR: \"IRR\",\n ISK: \"Ikr\",\n JMD: \"J$\",\n JOD: \"JD\",\n JPY: \"¥\",\n KES: \"Ksh\",\n KHR: \"KHR\",\n KMF: \"CF\",\n KRW: \"₩\",\n KWD: \"KD\",\n KZT: \"KZT\",\n LBP: \"L.L.\",\n LKR: \"SLRs\",\n LTL: \"Lt\",\n LVL: \"Ls\",\n LYD: \"LD\",\n MAD: \"MAD\",\n MDL: \"MDL\",\n MGA: \"MGA\",\n MKD: \"MKD\",\n MMK: \"MMK\",\n MOP: \"MOP$\",\n MUR: \"MURs\",\n MXN: \"MX$\",\n MYR: \"RM\",\n MZN: \"MTn\",\n NAD: \"N$\",\n NGN: \"₦\",\n NIO: \"C$\",\n NOK: \"Nkr\",\n NPR: \"NPRs\",\n NZD: \"NZ$\",\n OMR: \"OMR\",\n PAB: \"B/.\",\n PEN: \"S/.\",\n PHP: \"₱\",\n PKR: \"PKRs\",\n PLN: \"zł\",\n PYG: \"₲\",\n QAR: \"QR\",\n RON: \"RON\",\n RSD: \"din.\",\n RUB: \"RUB\",\n RWF: \"RWF\",\n SAR: \"SR\",\n SDG: \"SDG\",\n SEK: \"Skr\",\n SGD: \"S$\",\n SOS: \"Ssh\",\n SYP: \"SY£\",\n THB: \"฿\",\n TND: \"DT\",\n TOP: \"T$\",\n TRY: \"TL\",\n TTD: \"TT$\",\n TWD: \"NT$\",\n TZS: \"TSh\",\n UAH: \"₴\",\n UGX: \"USh\",\n UYU: \"$U\",\n UZS: \"UZS\",\n VEF: \"Bs.F.\",\n VND: \"₫\",\n XAF: \"F CFA\",\n XOF: \"CFA\",\n YER: \"YR\",\n ZAR: \"R\",\n ZMK: \"ZK\",\n ZWL: \"ZWL$\",\n};\nexport interface FormatCurrencyOptions {\n convertToMajorCurrency?: boolean;\n locale?: string;\n}\nexport class AmountAction {\n static getCurrencyLocaleMap(currency: string): string {\n const localeMap: Record<string, string> = {\n XOF: \"fr\",\n XAF: \"fr\",\n };\n return localeMap[currency] || \"en\";\n }\n static koboToNaira(amount: number | string) {\n return +amount / 100;\n }\n\n static nairaToKobo(amount: number | string) {\n return +amount * 100;\n }\n\n static getCurrencySymbol(currency: string): string {\n return CurrencySymbolMap[currency] || currency;\n }\n\n static formatAmountAndCurrency = (\n currency: string,\n value: number | string,\n options: FormatCurrencyOptions,\n ) => {\n const formatted = new Intl.NumberFormat(\n options?.locale || this.getCurrencyLocaleMap(currency),\n {\n maximumFractionDigits: 3,\n style: \"currency\",\n currency: currency,\n currencyDisplay: \"symbol\",\n },\n )\n .format(\n options?.convertToMajorCurrency\n ? this.koboToNaira(Number(value))\n : Number(value),\n )\n .replace(/^(\\D+)/, \"$1 \")\n .replace(\" \", \" \")\n .replace(/\\s+/, \"\");\n\n // Now replace the currency code with the desired symbol from the map\n const customSymbol = CurrencySymbolMap[currency] || currency;\n\n // Replace the currency code with our custom symbol\n return formatted.replace(currency, customSymbol);\n };\n}\n","// import dayjs from \"dayjs\";\nimport dayjs from \"dayjs\";\nexport class DateAction {\n static getDateLibrary(): dayjs.Dayjs {\n return dayjs();\n }\n static formatTimestampToDate(timestamp: number, dateFormat?: string) {\n return dayjs\n .unix(timestamp)\n .format(dateFormat || \"ddd, MMM, YYYY | HH:mm:ss\");\n }\n\n static formatDateToTimestamp(date: string) {\n return dayjs(date).unix();\n }\n}\n\n// console.log(\"Date\", dayjs().format(\"DD, MMM, YYYY | HH:mm:ss\"));\n"],"mappings":"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d,oBAAqB,IACvB,EACA,CACE,YAAa,WACb,YAAa,OACb,SAAU,4BACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,OACb,YAAa,OACb,SAAU,4BACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,WACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,WACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,IACd,oBAAqB,IACvB,EACA,CACE,YAAa,QACb,YAAa,OACb,SAAU,4BACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,QACb,YAAa,OACb,SAAU,gBACV,aAAc,MACd,aAAc,SACd,oBAAqB,IACvB,EACA,CACE,YAAa,SACb,YAAa,OACb,SAAU,gBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,cACb,YAAa,OACb,SAAU,yBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,QACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,UACb,YAAa,OACb,SAAU,eACV,aAAc,MACd,aAAc,IACd,oBAAqB,IACvB,EACA,CACE,YAAa,UACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,IACd,oBAAqB,IACvB,EACA,CACE,YAAa,aACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,SACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,OACb,YAAa,OACb,SAAU,yBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,aACb,YAAa,OACb,SAAU,qBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,UACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,IACd,oBAAqB,IACvB,EA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","names":["React","TooltipPrimitive","clsx","twMerge","cn","inputs","jsx","jsxs","TooltipProvider","TooltipRoot","TooltipTrigger","TooltipContent","className","sideOffset","props","ref","cn","Tooltip","trigger","children","contentClassName","triggerClassName","asChild","side","align","alignOffset","delayDuration","hasArrow","arrowClassName","React","React","LabelPrimitive","cva","jsx","labelVariants","cva","Label","className","props","ref","cn","jsx","jsxs","FormLabel","React","className","children","showAsterisk","error","props","ref","Label","cn","jsx","jsxs","Loader","size","colour","React","Slot","cva","Fragment","jsx","jsxs","buttonVariants","cva","Button","className","variant","size","asChild","isLoading","leftNode","rightNode","LoaderSize","props","ref","Component","Slot","children","disabled","rest","reference","cn","Loader","React","cva","React","jsx","ErrorMessage","className","children","error","props","ref","body","cn","React","jsx","FormDescription","className","props","ref","cn","jsx","jsxs","inputVariants","cva","BaseInnerInput","className","status","type","props","ref","cn","inputContainerVariants","sideVariants","Input","disabled","error","isLoading","sideNodeClassName","showAsterisk","label","description","containerStatus","FormLabel","FormDescription","ErrorMessage","useMemo","useState","jsx","jsxs","Eye","jsx","jsxs","EyeOff","jsx","Check","jsx","Fail","jsx","jsxs","validationOptions","PasswordInput","onValidate","onChange","disableValidation","props","passwordVisible","setPasswordVisible","useState","validatedValues","setValidatedValues","validatePassword","value","option","checkPasswordStrength","validatedOptions","allValidated","handlePaswordInputChange","e","validated","ValidateComp","useMemo","cn","Check","Fail","Input","val","Eye","EyeOff","cva","jsx","jsxs","textareaContainerVariants","cva","Textarea","className","status","disabled","error","isLoading","showAsterisk","label","description","props","containerStatus","FormLabel","cn","inputContainerVariants","FormDescription","ErrorMessage","React","React","CommandPrimitive","Search","React","DialogPrimitive","jsx","jsxs","CloseIcon","Fragment","jsx","jsxs","DialogRoot","DialogTrigger","DialogPortal","DialogOverlay","className","props","ref","cn","DialogContent","hideCloseButton","children","CloseIcon","DialogHeader","DialogFooter","DialogTitle","DialogDescription","Dialog","trigger","open","onOpenChange","footer","title","description","contentClassName","headerClassName","titleClassName","descriptionClassName","footerClassName","asChild","onOpenAutoFocus","onCloseAutoFocus","onEscapeKeyDown","onInteractOutside","onPointerDownOutside","Fragment","jsx","jsxs","Command","className","props","ref","CommandPrimitive","cn","CommandInput","className","CommandInputContainerClassName","loading","props","ref","jsxs","cn","jsx","Loader","Search","CommandPrimitive","CommandList","CommandEmpty","CommandGroup","CommandSeparator","CommandItem","CommandShortcut","React","PopoverPrimitive","jsx","jsxs","PopoverRoot","PopoverTrigger","PopoverContent","className","align","sideOffset","portal","props","ref","cn","Popover","trigger","children","open","onOpenChange","contentClassName","asChild","side","alignOffset","triggerClassName","onOpenAutoFocus","onCloseAutoFocus","id","React","ScrollAreaPrimitive","jsx","jsxs","ScrollArea","className","viewPortClassName","children","props","ref","cn","ScrollBar","orientation","jsx","jsxs","SearchableTrigger","className","value","placeholder","status","disabled","id","PopoverTrigger","cn","inputContainerVariants","Searchable","options","onChange","containerClassName","loading","optionComponent","children","modal","hideSearch","inputValue","onValueChange","onInputValueChange","open","setOpen","triggerRef","width","setWidth","PopoverRoot","PopoverContent","Command","CommandInput","ScrollArea","CommandList","CommandEmpty","CommandGroup","option","CommandItem","countryData","getCountryDataMap","frequency","country","React","RPNInput","flags","jsx","jsxs","FlatGlobeIcon","props","Flag_default","jsx","jsxs","PhoneInput","className","onChange","defaultCountry","modal","showAsterisk","label","description","error","props","ref","CountrySelectWrapper","innerProps","CountrySelect","FormLabel","cn","FlagComponent","InputComponent","value","FormDescription","ErrorMessage","Input","disabled","options","status","handleSelect","country","PopoverRoot","PopoverTrigger","inputContainerVariants","PopoverContent","Command","CommandList","ScrollArea","CommandInput","CommandEmpty","CommandGroup","x","option","CommandItem","countryName","Flag","flags","Flag_default","jsx","jsxs","countryMap","getCountryDataMap","CountryTrigger","className","value","placeholder","status","disabled","PopoverTrigger","cn","inputContainerVariants","FlagComponent","Country","hideSearch","showAsterisk","label","description","error","props","options","countryData","country","FormLabel","Searchable","arg","FormDescription","ErrorMessage","jsx","jsxs","Select","showAsterisk","label","description","error","hideSearch","status","props","FormLabel","Searchable","SearchableTrigger","FormDescription","ErrorMessage","OtpInput","cva","useMemo","jsx","otpInputVariants","OTPInput","numInputs","inputStyle","containerStyle","placeholder","status","props","placeholderValue","accumulator","currentValue","OtpInput","cn","useState","useEffect","jsx","jsxs","Icon","type","Banner","title","description","open","showCloseButton","bottomNode","sideNode","onClose","showIcon","isOpen","setIsOpen","bgColor","stripeColor","handleClose","useState","Copy","CheckIcon","motion","AnimatePresence","jsx","TextOverflow","children","mode","className","Component","rest","cn","jsx","jsxs","CopyableLabel","text","textToCopy","onCopy","iconsPosition","clampText","clampMode","isLink","textClassName","copied","setCopied","useState","copyToClipboard","Icon","CheckIcon","Copy","AnimatedIcon","TextOverflow","cn","onClick","AnimatePresence","motion","useEffect","useState","Search","jsx","DebouncedInput","initialValue","onChange","debounce","addon","props","value","setValue","useState","handleInputChange","event","useEffect","timeout","Input","cn","useEffect","X","jsx","jsxs","DevBanner","props","environment","branch","version","deployTime","showBanner","onClose","initDefault","removeFromStorage","syncLocalStorageToState","currentEnv","interval","React","DrawerPrimitive","cva","jsx","jsxs","CloseIcon","useState","useEffect","useWindowSize","windowSize","setWindowSize","handleResize","Fragment","jsx","jsxs","DrawerRoot","shouldScaleBackground","props","DrawerPrimitive","DrawerTrigger","DrawerClose","DrawerPortal","DrawerOverlay","className","ref","cn","DrawerVariants","cva","DrawerContent","side","hideCloseButton","children","id","CloseIcon","DrawerHeader","DrawerFooter","DrawerTitle","DrawerDescription","Drawer","trigger","open","onOpenChange","footer","title","description","contentClassName","headerClassName","titleClassName","descriptionClassName","footerClassName","asChild","onOpenAutoFocus","drawerContentClassName","onCloseAutoFocus","width","useWindowSize","direction","jsx","Check","jsx","jsxs","EnglishFlag","props","jsx","jsxs","FrenchFlag","props","jsx","jsxs","UpDownIcon","PopoverClose","jsx","jsxs","localeListOptons","LocaleIcon","locale","FrenchFlag","EnglishFlag","LocaleTrigger","UpDownIcon","LocaleSelector","onChange","locales","PopoverRoot","PopoverTrigger","PopoverContent","_locale","cn","Check","useMemo","useRef","useState","AnimatePresence","motion","useMemo","useState","HiCheck","FiLogOut","BsPlus","jsx","jsxs","BusinessBarTrigger","activeBusiness","onTriggerClick","iconOnly","className","rightNode","cn","TextOverflow","ChevronUp","jsx","ActiveBusinessIcon","props","jsx","jsxs","businessPopUpVariants","BusinessBarContent","activeBusiness","toggleAddBusinessDrawer","businesses","handleSwitchBusiness","onLogoutClick","onToggleSideBar","toggleShowBusiness","isMobile","collapseType","searchText","setSearchText","useState","searchedBusinesses","useMemo","text","b","hiddenCollapseType","onSearchChange","e","onBusinessClick","clientId","onToggleAddBusinessDrawer","onHandleLogoutClick","AnimatePresence","motion","BusinessBarTrigger","ActiveBusinessIcon","Input","ChevronUp","HiCheck","cn","BsPlus","FiLogOut","jsx","jsxs","BusinessBar","activeBusiness","toggleAddBusinessDrawer","toggleShowBusiness","businesses","handleSwitchBusiness","iconOnly","onLogoutClick","isMobile","onToggleSideBar","isBusinessShown","collapseType","Popover","BusinessBarTrigger","Icon","BusinessBarContent","className","cn","AnimatePresence","motion","useEffect","FiChevronRight","useState","useEffect","useLocalStorage","key","initialValue","state","setState","isHydrated","setIsHydrated","item","error","Fragment","jsx","jsxs","accordionItemVariants","NavItems","isIconsOnly","isSidebarCollapsed","onToggleSideBar","currentPath","onNavigate","collapseType","links","appConfig","isMobile","SIDEBAR_MENU_STORAGE_KEY","expandedMenus","setExpandedMenus","useLocalStorage","toggleAccordion","linkId","prev","handleMenuLink","link","getActiveMenu","l","useEffect","expanded","child","idx","active","hasChildren","isExpanded","cn","Tooltip","FiChevronRight","AnimatePresence","motion","childLink","childActive","X","jsx","jsxs","OpenSidebarIcon","jsx","jsxs","ClosedSidebarIcon","jsx","jsxs","SidebarToggle","onToggleSideBar","isSidebarCollapsed","OpenIcon","CloseIcon","props","Fragment","jsx","jsxs","Sidebar","isSidebarCollapsed","onToggleSideBar","isMobile","links","businessProps","currentPath","onNavigate","appConfig","propCollapseType","onLogoutClick","openSidebarIcon","OpenSidebarIcon","closedSidebarIcon","ClosedSidebarIcon","nodeAfterSideBarLogo","collapseType","useMemo","isBusinessShown","setIsBusinessShown","useState","isIconsOnly","sideBarRef","useRef","businessList","activeBusiness","toggleAddBusinessDrawer","handleSetActiveBusiness","toggleShowBusiness","handleSwitchBusiness","clientId","sideBarLogo","showBackdrop","cn","SidebarToggle","X","NavItems","BusinessBar","jsx","Status","status","variant","className","cn","Loader","ChevronLeftIcon","ChevronRightIcon","jsx","PageButton","page","currentPage","onClick","renderPageNumbers","totalPages","handlePageClick","getWindowBounds","halfWindow","start","end","pages","_","i","idx","jsx","jsxs","Pagination","currentPage","totalPages","onPageChange","itemsPerPage","totalItems","id","handlePageClick","page","visibleRangeStart","visibleRangeEnd","ChevronLeftIcon","renderPageNumbers","ChevronRightIcon","flexRender","jsx","jsxs","TableBody","table","isMobile","onRowClick","id","cn","headerGroup","header","flexRender","row","cell","Download","ListFilter","RotateCw","useEffect","useState","useForm","Controller","React","RadioGroupPrimitive","jsx","RadioGroup","className","props","ref","cn","RadioGroupItem","v4","React","ChevronLeft","ChevronRight","React","DayPicker","jsx","Calendar","className","classNames","showOutsideDays","props","DayPicker","cn","buttonVariants","ChevronLeft","ChevronRight","value","onChange","children","options","option","handleChange","Select","val","date","jsx","jsxs","DateInputButton","value","onClick","error","status","ref","cn","inputContainerVariants","format","date","placeholder","Trigger","className","props","PopoverTrigger","Picker","children","captionLayout","fromYear","toYear","disableDate","modal","open","setOpen","PopoverRoot","PopoverContent","Calendar","formatFormDate","dateFormat","CalendarInput","label","optional","onChange","helpText","FormLabel","formattedDate","create","FILTER_PREFIX","syncFiltersWithURL","filters","params","key","clearFiltersFromURL","keysToDelete","_","initializeFiltersFromURL","value","createFilterStore","set","items","state","newFilters","useFilterStore","PopoverClose","Fragment","jsx","jsxs","FilterContent","filters","values","setAppliedFilters","id","filterStore","useFilterStore","upDateFilter","resetFilters","cachedFilters","syncFilter","setSyncFilter","useState","handleFiltersSync","control","handleSubmit","useForm","useEffect","handleReset","filtered","v","filter","Controller","field","formState","Input","value","onChange","errors","Select","option","val","FormLabel","RadioGroup","RadioGroupItem","v4","CalendarInput","PopoverClose","cn","buttonVariants","ListFilter","useEffect","useState","Fragment","jsx","FilterLabelCount","setAppliedFilters","syncFilter","setSyncFilter","useState","filterStore","useFilterStore","cachedFilters","cachedKeys","useEffect","useEffect","useState","useMountClient","mounted","setMounted","children","jsx","jsxs","FilterPopover","filters","setAppliedFilters","isOpen","id","isClientMounted","useMountClient","Popover","cn","buttonVariants","ListFilter","FilterLabelCount","FilterContent","Fragment","jsx","jsxs","PageDataToolbar","onRefetch","search","FilterMenu","ExtraNode","onExport","download","isRefetching","filterListOptions","setAppliedFilters","id","handleSearch","query","handleRefetch","e","DebouncedInput","Button","RotateCw","cn","FilterPopover","Popover","buttonVariants","ListFilter","Download","jsx","jsxs","Table","table","isMobile","onRowClick","id","onRefetch","isRefetching","FilterMenu","ExtraNode","onExport","search","download","isLoading","pagination","filterListOptions","setAppliedFilters","cn","PageDataToolbar","Loader","TableBody","Pagination","page","createContext","useMemo","jsx","PermissionsContext","PermissionsProvider","permissions","children","value","useCallback","useContext","useMemo","usePermissions","useContext","PermissionsContext","useHasPermission","permission","permissions","validatePermission","useCallback","p","resource","action","matchingPermissions","useMemo","Fragment","jsx","HasResourcePermission","permission","children","hasPermission","useHasPermission","CurrencySymbolMap","_AmountAction","currency","amount","__publicField","value","options","formatted","customSymbol","AmountAction","dayjs","DateAction","timestamp","dateFormat","date"]}
1
+ {"version":3,"sources":["../src/components/tooltip/index.tsx","../src/utils/index.ts","../src/components/label/FormLabel.tsx","../src/components/label/index.tsx","../src/components/loader/index.tsx","../src/components/button/index.tsx","../src/components/input/index.tsx","../src/components/form/ErrorMessage.tsx","../src/components/form/FormDescription.tsx","../src/components/password-input/index.tsx","../src/components/password-input/icons/Eye.tsx","../src/components/password-input/icons/EyeOff.tsx","../src/components/password-input/icons/Check.tsx","../src/components/password-input/icons/Fail.tsx","../src/components/textarea/index.tsx","../src/components/searcheable/index.tsx","../src/components/command/index.tsx","../src/components/dialog/index.tsx","../src/components/dialog/icon/CloseIcon.tsx","../src/components/popover/index.tsx","../src/components/scroll-area/index.tsx","../src/components/country/data.ts","../src/components/phone-input/index.tsx","../src/components/phone-input/Flag.tsx","../src/components/country/index.tsx","../src/components/select/index.tsx","../src/components/otp/index.tsx","../src/components/banner/index.tsx","../src/components/copyable-label/index.tsx","../src/components/text-overflow/index.tsx","../src/components/debounced-input/index.tsx","../src/components/dev-banner/index.tsx","../src/components/drawer/index.tsx","../src/components/drawer/icon/CloseIcon.tsx","../src/hooks/useWindowSize.ts","../src/components/locale-selctor/icons/Check.tsx","../src/components/locale-selctor/icons/EnglishFlag.tsx","../src/components/locale-selctor/icons/FrenchFlag.tsx","../src/components/locale-selctor/icons/UpDownIcon.tsx","../src/components/locale-selctor/index.tsx","../src/components/sidebar/index.tsx","../src/components/sidebar/business/components/Content.tsx","../src/components/sidebar/business/components/Trigger.tsx","../src/components/sidebar/business/components/ActiveBusinessIcon.tsx","../src/components/sidebar/business/BusinessBar.tsx","../src/components/sidebar/NavItems.tsx","../src/hooks/useLocalStorage.tsx","../src/components/sidebar/components/OpenSidebarIcon.tsx","../src/components/sidebar/components/ClosedSidebarIcon.tsx","../src/components/sidebar/components/SidebarToggle.tsx","../src/components/status/index.tsx","../src/components/table/index.tsx","../src/components/table/pagination/index.tsx","../src/components/table/pagination/utils.tsx","../src/components/table/TableBody.tsx","../src/components/table/ToolBar.tsx","../src/components/table/filters/FilterContent.tsx","../src/components/radio/index.tsx","../src/components/calendar/CalendarInput.tsx","../src/components/calendar/index.tsx","../src/components/table/filters/helper/useFilterStore.ts","../src/components/table/filters/index.tsx","../src/components/table/filters/components/FilterLabelCount.tsx","../src/hooks/useMountClient.tsx","../src/components/permission/context.tsx","../src/components/permission/hook.ts","../src/components/permission/index.tsx","../src/actions/amount.action.ts","../src/actions/date.action.ts"],"sourcesContent":["\"use client\";\n\nimport * as React from \"react\";\nimport * as TooltipPrimitive from \"@radix-ui/react-tooltip\";\n\nimport { cn } from \"@/src/utils\";\n\nconst TooltipProvider = TooltipPrimitive.Provider;\n\nconst TooltipRoot = TooltipPrimitive.Root;\n\nconst TooltipTrigger = TooltipPrimitive.Trigger;\n\nconst TooltipContent = React.forwardRef<\n React.ElementRef<typeof TooltipPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content>\n>(({ className, sideOffset = 2, ...props }, ref) => (\n <TooltipPrimitive.Content\n ref={ref}\n sideOffset={sideOffset}\n className={cn(\n \"z-50 rounded-md border border-transparent bg-gray-50 px-3 py-1.5 text-base font-semibold text-bold text-black/40 shadow-xl- animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 [box-shadow:3px_4px_11px_0px_#0000001A,13px_16px_21px_0px_#00000017,29px_36px_28px_0px_#0000000D,52px_65px_33px_0px_#00000003,82px_101px_36px_0px_#00000000]\",\n className,\n )}\n {...props}\n >\n {props.children}\n {/* <TooltipPrimitive.Arrow className=\"!fill-gray-50 w-6\" /> */}\n </TooltipPrimitive.Content>\n));\n\nTooltipContent.displayName = TooltipPrimitive.Content.displayName;\n\nexport type TooltipPropsType = {\n trigger: React.ReactNode;\n children: React.ReactNode;\n contentClassName?: string;\n triggerClassName?: string;\n asChild?: boolean;\n side?: TooltipPrimitive.TooltipContentProps[\"side\"];\n sideOffset?: number;\n align?: TooltipPrimitive.TooltipContentProps[\"align\"];\n alignOffset?: number;\n delayDuration?: number;\n hasArrow?: boolean;\n arrowClassName?: string;\n};\n\nconst Tooltip = ({\n trigger,\n children,\n contentClassName,\n triggerClassName,\n asChild = true,\n side,\n sideOffset,\n align,\n alignOffset,\n delayDuration = 100,\n hasArrow = true,\n arrowClassName,\n ...props\n}: TooltipPropsType &\n React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Root>) => {\n return (\n <TooltipProvider>\n <TooltipRoot delayDuration={delayDuration} {...props}>\n <div className=\"flex justify-center items-center\">\n <TooltipTrigger asChild={asChild} className={triggerClassName}>\n {trigger}\n </TooltipTrigger>\n <TooltipContent\n side={side}\n sideOffset={sideOffset}\n align={align}\n alignOffset={alignOffset}\n className={contentClassName}\n >\n {children}\n {hasArrow && (\n <TooltipPrimitive.Arrow\n className={cn(\"fill-white\", arrowClassName)}\n />\n )}\n </TooltipContent>\n </div>\n </TooltipRoot>\n </TooltipProvider>\n );\n};\nTooltip.displayName = \"Tooltip\";\n\nexport {\n Tooltip,\n TooltipProvider,\n TooltipRoot,\n TooltipTrigger,\n TooltipContent,\n};\n","import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\ntype Status =\n | string\n | \"unpaid\"\n | \"partial-payment\"\n | \"active\"\n | \"paid\"\n | \"inactive\"\n | \"in-progress\"\n | \"failed\"\n | \"abandoned\"\n | \"success\";\n\ntype Variant = \"success\" | \"failed\" | \"pending\" | \"abandoned\";\ntype StatusVariantMap = Record<Status, Variant>;\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n\nexport function areObjectsEqual<T extends object>(obj1: T, obj2: T): boolean {\n const keys1 = Object.keys(obj1);\n const keys2 = Object.keys(obj2);\n\n if (keys1.length !== keys2.length) {\n return false;\n }\n\n for (const key of keys1) {\n const val1 = obj1[key as keyof T];\n const val2 = obj2[key as keyof T];\n\n if (\n typeof val1 === \"object\" &&\n val1 !== null &&\n typeof val2 === \"object\" &&\n val2 !== null\n ) {\n if (!areObjectsEqual(val1, val2)) {\n return false;\n }\n } else if (val1 !== val2) {\n return false;\n }\n }\n\n return true;\n}\n\nconst defaultStatusGroups: StatusVariantMap = {\n unpaid: \"pending\",\n \"partial-payment\": \"pending\",\n active: \"success\",\n paid: \"success\",\n inactive: \"abandoned\",\n \"in-progress\": \"pending\",\n failed: \"failed\",\n abandoned: \"abandoned\",\n success: \"success\",\n};\n\nexport const getStatusVariant = (\n status: Status,\n customGroups?: Partial<StatusVariantMap>,\n): Variant => {\n const mergedGroups = { ...defaultStatusGroups, ...customGroups };\n return mergedGroups[status] || \"pending\";\n};\n","import React from \"react\";\n\nimport * as LabelPrimitive from \"@radix-ui/react-label\";\nimport { Label } from \".\";\nimport { cn } from \"@/src/utils\";\n\nconst FormLabel = React.forwardRef<\n React.ElementRef<typeof LabelPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root> & {\n showAsterisk?: boolean;\n error?: string;\n formItemId?: string;\n }\n>(({ className, children, showAsterisk, error, ...props }, ref) => {\n return (\n <Label\n ref={ref}\n className={cn(error && \"text-red-500\", className)}\n // htmlFor={formItemId}\n {...props}\n >\n {showAsterisk ? (\n <p>\n {children}\n <span className=\"text-red-500\">*</span>\n </p>\n ) : (\n children\n )}\n </Label>\n );\n});\n\nFormLabel.displayName = \"FormLabel\";\n\nexport { FormLabel };\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as LabelPrimitive from \"@radix-ui/react-label\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\n\nimport { cn } from \"@/src/utils\";\n\nconst labelVariants = cva(\n \"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70\",\n);\n\nconst Label = React.forwardRef<\n React.ElementRef<typeof LabelPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root> &\n VariantProps<typeof labelVariants>\n>(({ className, ...props }, ref) => (\n <LabelPrimitive.Root\n ref={ref}\n className={cn(labelVariants(), className)}\n {...props}\n />\n));\nLabel.displayName = LabelPrimitive.Root.displayName;\n\nexport { Label };\n","type Colours = \"primary\" | \"secondary\";\n\nexport const Loader = ({\n size = 16,\n colour = \"primary\",\n}: {\n size?: number;\n colour?: Colours;\n}) => {\n return (\n <svg\n className=\"animate-spin\"\n width={size}\n height={size}\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n >\n <circle cx=\"10\" cy=\"10\" r=\"9.25\" stroke=\"transparent\" strokeWidth=\"1.5\" />\n <path\n d=\"M10 0.595792C10 0.266746 10.267 -0.00185055 10.5954 0.0177417C11.9786 0.100242 13.3318 0.469461 14.5682 1.1044C15.9816 1.83021 17.2016 2.88235 18.1273 4.17366C19.0531 5.46496 19.6578 6.95826 19.8913 8.52984C20.1249 10.1014 19.9807 11.706 19.4705 13.2108C18.9604 14.7155 18.0991 16.077 16.9579 17.1825C15.8167 18.288 14.4285 19.1056 12.9084 19.5677C11.3882 20.0298 9.77982 20.123 8.21646 19.8397C6.84883 19.5918 5.55009 19.0619 4.40196 18.2863C4.12931 18.1021 4.08072 17.7265 4.28083 17.4653C4.48094 17.2041 4.85388 17.1564 5.12801 17.3384C6.12474 18.0001 7.24768 18.4531 8.42898 18.6672C9.80606 18.9168 11.2228 18.8347 12.5618 18.4276C13.9008 18.0206 15.1236 17.3004 16.1288 16.3266C17.134 15.3528 17.8927 14.1536 18.342 12.8282C18.7914 11.5027 18.9185 10.0893 18.7127 8.70502C18.507 7.32071 17.9743 6.00535 17.1589 4.86792C16.3435 3.73048 15.2688 2.80371 14.0238 2.16439C12.9559 1.61596 11.789 1.29259 10.5954 1.21173C10.2671 1.18949 10 0.92484 10 0.595792Z\"\n fill={colour === \"primary\" ? \"#ffffff\" : \"currentColor\"}\n className=\"rounded\"\n />\n </svg>\n );\n};\n","\"use client\";\n\nimport * as React from \"react\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\n\nimport { cn } from \"@/src/utils\";\nimport { Loader } from \"../loader\";\nimport { ButtonHTMLAttributes } from \"react\";\nimport { DetailedHTMLProps } from \"react\";\n\nconst buttonVariants = cva(\n \"overflow-hidden isolate inline-flex h-fit items-center justify-center whitespace-nowrap text-sm font-medium ring-offset-background dark:ring-offset-transparent transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:!pointer-events-none\",\n {\n variants: {\n variant: {\n primary:\n \"border-primary-main bg-primary-main hover:bg-primary-main/70 disabled:bg-primary-main/70 text-white font-bold\",\n danger:\n \"border-red-600 bg-red-600 hover:bg-red-600/70 disabled:bg-red-600/70 text-white font-bold\",\n neutral:\n \"!border-0 bg-transparent text-primary-main hover:opacity-80 disabled:opacity-60\",\n outlined:\n \"border border-primary-main text-primary-main hover:opacity-80 disabled:opacity-60\",\n \"danger-outlined\":\n \"border border-red-600 text-red-600 hover:opacity-80 disabled:opacity-60\",\n \"light-outlined\":\n \"border-white text-white hover:opacity-80 disabled:opacity-60\",\n \"dark-text\":\n \"border-transparent bg-transparent hover:bg-opacity-70 disabled:bg-opacity-70 text-black font-medium\",\n light:\n \"border-white bg-white hover:bg-opacity-70 disabled:bg-opacity-70 text-primary-main font-semibold\",\n },\n size: {\n // lg: \"h-15 px-8 items-center\",\n // sm: \"h-10 px-3.5 items-center text-sm\",\n default:\n \"py-[0.625rem] px-[1.5rem] text-[0.875rem] leading-[1.25rem] font-medium rounded-lg\",\n sm: \"py-[0.375rem] px-[1rem] leading-[1rem] font-normal text-sm rounded-lg\",\n lg: \"py-[0.75rem] px-[1.5rem] text-[1rem] leading-[1.5rem] font-medium rounded-lg\",\n md: \"py-[0.625rem] px-[1.5rem] text-[0.875rem] leading-[1.25rem] font-medium rounded-lg\",\n \"icon-sm\":\n \"h-[1.75rem] w-[1.75rem] flex justify-center items-center font-medium rounded-lg\",\n icon: \"h-[2.5rem] w-[2.75rem] flex justify-center items-center font-medium rounded-lg\",\n \"icon-lg\":\n \"h-[3rem] w-[3rem] flex justify-center items-center font-medium rounded-lg\",\n },\n },\n defaultVariants: {\n variant: \"primary\",\n size: \"default\",\n },\n },\n);\n\nexport interface ButtonProps\n // extends React.ButtonHTMLAttributes<HTMLButtonElement>,\n extends DetailedHTMLProps<\n ButtonHTMLAttributes<HTMLButtonElement>,\n HTMLButtonElement\n >,\n VariantProps<typeof buttonVariants> {\n asChild?: boolean;\n isLoading?: boolean;\n leftNode?: React.ReactNode;\n rightNode?: React.ReactNode;\n LoaderSize?: number;\n}\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n (\n {\n className,\n variant = \"primary\",\n size,\n asChild = false,\n isLoading = false,\n leftNode,\n rightNode,\n LoaderSize,\n // ref,\n ...props\n },\n ref,\n ) => {\n const Component = asChild ? Slot : \"button\";\n\n const { children, disabled, ...rest } = props;\n const reference = React.useRef<HTMLButtonElement>(null);\n\n return (\n <Component\n className={cn(buttonVariants({ variant, size, className }))}\n ref={reference || ref}\n disabled={disabled || isLoading}\n {...rest}\n children={\n <div className=\"flex font-medium justify-center items-center gap-2\">\n {/* {leftNode}\n {children}\n {rightNode}\n {isLoading && <Loader />} */}\n\n {isLoading ? (\n <>\n <span className=\"mx-auto\">\n <Loader size={LoaderSize} colour=\"secondary\" />\n </span>\n </>\n ) : (\n <>\n {leftNode}\n {children}\n {rightNode}\n </>\n )}\n </div>\n }\n />\n );\n },\n);\n\nButton.displayName = \"Button\";\n\nexport { Button, buttonVariants };\n","\"use client\";\n\nimport * as React from \"react\";\n\nimport { cn } from \"@/src/utils\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { FormLabel } from \"../label/FormLabel\";\nimport { ErrorMessage } from \"../form/ErrorMessage\";\nimport { FormDescription } from \"../form/FormDescription\";\n\nexport const inputVariants = cva(\n \"!p-0 flex h-full w-full !border-transparent !bg-transparent text-base focus-visible:bg-transparent focus-visible:outline-none focus-visible:ring-0 focus-visible:ring-offset-0 disabled:cursor-not-allowed disabled:opacity-50\",\n {\n variants: {\n status: {\n default: \"placeholder:text-[#C4C4C4] dark:placeholder:text-[#9299A2]\",\n error: \"placeholder:text-red-500 text-red-500\",\n loading: \"placeholder:text-[#C4C4C4] dark:placeholder:text-[#9299A2]\",\n prefilled: \"\",\n neutral: \"\",\n },\n },\n defaultVariants: {\n status: \"default\",\n },\n },\n);\n\nexport interface BaseInnerInputProps\n extends React.InputHTMLAttributes<HTMLInputElement>,\n VariantProps<typeof inputVariants> {}\n\nconst BaseInnerInput = React.forwardRef<HTMLInputElement, BaseInnerInputProps>(\n ({ className, status, type, ...props }, ref) => {\n return (\n <input\n type={type}\n className={cn(inputVariants({ status }), className)}\n ref={ref}\n {...props}\n />\n );\n },\n);\nBaseInnerInput.displayName = \"BaseInnerInput\";\n\nexport const inputContainerVariants = cva(\n \"flex relative h-10 w-full rounded-[4px] dark:!bg-transparent border transition px-3 py-2 text-base placeholder:text-[#79818C] focus-within:outline-0 focus-within:ring-0 focus-visible:ring-offset-0 disabled:cursor-not-allowed disabled:opacity-50 dark:disabled:!border-[#9299A2]\",\n {\n variants: {\n status: {\n default:\n \"border-[#DEDEDE] bg-white text-[#191919] dark:!bg-transparent caret-text-primary focus-within:bg-white dark:focus-within:!bg-transparent dark:text-white focus-within:border-primary-main dark:focus-within:border-[#9299A2] dark:disabled:!border-[#9299A2]\",\n error:\n \"placeholder:text-red-500 bg-red-50 border-red-500 dark:!bg-status-error-bg-dark text-red-500 focus-within:bg-red-50 focus-within:border-red-500\",\n loading: \"\",\n prefilled:\n \"bg-[#F6F6F6] border-[#DEDEDE] dark:!bg-transparent caret-[#DEDEDE] focus-within:bg-[#F6F6F6] focus-within:border-[#DEDEDE] dark:!border-[#9299A2] dark:focus-within:border-[#9299A2]\",\n neutral:\n \"bg-[#F6F6F6] border-[#DEDEDE] dark:!bg-transparent caret-[#DEDEDE] focus-within:bg-[#F6F6F6] focus-within:border-[#DEDEDE] dark:!border-[#9299A2] dark:focus-within:border-[#9299A2]\",\n },\n },\n defaultVariants: {\n status: \"default\",\n },\n },\n);\n\nexport const sideVariants = cva(\n \"top-0 flex justify-center items-center h-full min-w-[50px] max-w-[100px] dark:!bg-transparent transition px-3 py-2 text-base placeholder:text-[#79818C] focus-within:outline-0 focus-within:ring-0 focus-visible:ring-offset-0 disabled:cursor-not-allowed disabled:opacity-50 dark:disabled:!border-[#9299A2]\",\n {\n variants: {\n side: {\n left: \"left-0 rounded-l-[8px] border-r\",\n right: \"right-0 rounded-r-[8px] border-l\",\n },\n status: {\n default:\n \"border-[#DEDEDE] bg-white text-[#191919] dark:!bg-transparent caret-primary-main focus-within:bg-white dark:focus-within:!bg-transparent dark:text-white focus-within:border-primary-main dark:focus-within:border-[#9299A2] dark:disabled:!border-[#9299A2]\",\n error:\n \"placeholder:text-red-500 bg-red-50 border-red-500 dark:!bg-red-50 text-red-500 focus-within:bg-red-50 focus-within:border-red-500\",\n loading: \"\",\n prefilled:\n \"bg-[#F6F6F6] border-[#DEDEDE] dark:!bg-transparent caret-[#DEDEDE] focus-within:bg-[#F6F6F6] focus-within:border-[#DEDEDE] dark:!border-[#9299A2] dark:focus-within:border-[#9299A2]\",\n neutral: \"bg-transparent border-0 caret-[#DEDEDE] !px-0\",\n },\n },\n defaultVariants: {\n status: \"default\",\n side: \"left\",\n },\n },\n);\n\nexport interface InputProps\n extends BaseInnerInputProps,\n VariantProps<typeof inputContainerVariants> {\n isLoading?: boolean;\n error?: string;\n leftNode?: React.ReactNode;\n rightNode?: React.ReactNode;\n sideNodeClassName?: string;\n label?: string;\n showAsterisk?: boolean;\n description?: React.ReactNode;\n}\n\nconst Input = React.forwardRef<HTMLInputElement, InputProps>(\n (\n {\n className,\n status = \"default\",\n disabled,\n error,\n isLoading,\n sideNodeClassName,\n showAsterisk,\n label,\n description,\n ...props\n },\n ref,\n ) => {\n let containerStatus: VariantProps<typeof inputContainerVariants>[\"status\"] =\n status;\n\n if (error) containerStatus = \"error\";\n if (isLoading) containerStatus = \"loading\";\n if (disabled) containerStatus = \"prefilled\";\n\n return (\n <div className=\"relative space-y-1 w-full\">\n {label && (\n <FormLabel showAsterisk={showAsterisk} error={error}>\n {label}\n </FormLabel>\n )}\n <div\n className={cn(\n inputContainerVariants({ status: containerStatus }),\n props.leftNode ? \"pl-0\" : \"\",\n props.rightNode ? \"pr-0\" : \"\",\n className,\n )}\n >\n {props.leftNode ? (\n <div\n className={cn(\n sideVariants({\n status: containerStatus,\n side: \"left\",\n }),\n sideNodeClassName,\n )}\n >\n {props.leftNode}\n </div>\n ) : null}\n <BaseInnerInput\n ref={ref}\n disabled={isLoading || disabled}\n className={cn({\n \"!pl-3\": props.leftNode && status !== \"neutral\",\n \"!pr-3\": props.rightNode && status !== \"neutral\",\n })}\n {...props}\n />\n {props.rightNode ? (\n <div\n className={cn(\n sideVariants({\n status: containerStatus,\n side: \"right\",\n }),\n sideNodeClassName,\n )}\n >\n {props.rightNode}\n </div>\n ) : null}\n </div>\n {description && (\n <FormDescription className=\"text-gray-400 text-sm !font-normal\">\n {description}\n </FormDescription>\n )}\n <ErrorMessage error={error} />\n </div>\n );\n },\n);\n\n// const Input = ({\n// className,\n// status = \"default\",\n// disabled,\n// error,\n// isLoading,\n// sideNodeClassName,\n// showAsterisk,\n// label,\n// description,\n// ref,\n// ...props\n// }: InputProps) => {\n// let containerStatus: VariantProps<typeof inputContainerVariants>[\"status\"] =\n// status;\n\n// if (error) containerStatus = \"error\";\n// if (isLoading) containerStatus = \"loading\";\n// if (disabled) containerStatus = \"prefilled\";\n\n// return (\n// <div className=\"relative space-y-1 w-full\">\n// {label && (\n// <FormLabel showAsterisk={showAsterisk} error={error}>\n// {label}\n// </FormLabel>\n// )}\n// <div\n// className={cn(\n// inputContainerVariants({ status: containerStatus }),\n// props.leftNode ? \"pl-0\" : \"\",\n// props.rightNode ? \"pr-0\" : \"\",\n// className,\n// )}\n// >\n// {props.leftNode ? (\n// <div\n// className={cn(\n// sideVariants({\n// status: containerStatus,\n// side: \"left\",\n// }),\n// sideNodeClassName,\n// )}\n// >\n// {props.leftNode}\n// </div>\n// ) : null}\n// <BaseInnerInput\n// ref={ref}\n// disabled={isLoading || disabled}\n// className={cn({\n// \"!pl-3\": props.leftNode && status !== \"neutral\",\n// \"!pr-3\": props.rightNode && status !== \"neutral\",\n// })}\n// {...props}\n// />\n// {props.rightNode ? (\n// <div\n// className={cn(\n// sideVariants({\n// status: containerStatus,\n// side: \"right\",\n// }),\n// sideNodeClassName,\n// )}\n// >\n// {props.rightNode}\n// </div>\n// ) : null}\n// </div>\n// {description && (\n// <FormDescription className=\"text-gray-400 text-sm !font-normal\">\n// {description}\n// </FormDescription>\n// )}\n// <ErrorMessage error={error} />\n// </div>\n// );\n// };\n\nInput.displayName = \"Input\";\n\nexport { Input };\n","import { cn } from \"@/src/utils\";\nimport React from \"react\";\n\nconst ErrorMessage = React.forwardRef<\n HTMLParagraphElement,\n React.HTMLAttributes<HTMLParagraphElement> & {\n error?: string;\n }\n>(({ className, children, error, ...props }, ref) => {\n const body = error ?? children;\n\n if (!body) {\n return null;\n }\n\n return (\n <p\n ref={ref}\n className={cn(\"text-xs font-normal text-[#F04248]\", className)}\n {...props}\n >\n {body}\n </p>\n );\n});\nErrorMessage.displayName = \"ErrorMessage\";\n\nexport { ErrorMessage };\n","import { cn } from \"@/src/utils\";\nimport React from \"react\";\n\nconst FormDescription = React.forwardRef<\n HTMLDivElement,\n React.HTMLAttributes<HTMLDivElement>\n>(({ className, ...props }, ref) => {\n return (\n <div\n ref={ref}\n className={cn(\"text-sm text-[#8E98A8\", className)}\n {...props}\n />\n );\n});\nFormDescription.displayName = \"FormDescription\";\n\nexport { FormDescription };\n","import { useMemo, useState } from \"react\";\nimport { Eye } from \"./icons/Eye\";\nimport { EyeOff } from \"./icons/EyeOff\";\nimport { Input, InputProps } from \"../input\";\nimport { cn } from \"@/src/utils\";\nimport { Check } from \"./icons/Check\";\nimport { Fail } from \"./icons/Fail\";\n\nconst validationOptions = [\n {\n label: \"Uppercase\",\n key: \"uppercase\",\n RegExp: /[A-Z]/,\n validated: false,\n },\n {\n label: \"Lowercase\",\n key: \"lowercase\",\n RegExp: /[a-z]/,\n validated: false,\n },\n {\n label: \"Number\",\n key: \"number\",\n RegExp: /\\d/,\n validated: false,\n },\n {\n label: \"8 Characters\",\n key: \"eight-chars\",\n RegExp: /.{8}/,\n validated: false,\n },\n];\n\ntype PasswordInputProps = InputProps & {\n /**\n * onValidate(validated: boolean, value: string) => void\n * args - validated: this is boolean value that indicated that all validation options were met\n * args - value: this is the string input value\n */\n onValidate?: (validated: boolean, value: string) => void;\n disableValidation?: boolean;\n};\nconst PasswordInput = ({\n onValidate,\n onChange,\n disableValidation,\n ...props\n}: PasswordInputProps) => {\n const [passwordVisible, setPasswordVisible] = useState(false);\n const [validatedValues, setValidatedValues] = useState(validationOptions);\n\n const validatePassword = (value: string) => {\n return validationOptions.map((option) => ({\n ...option,\n validated: option.RegExp.test(value),\n }));\n };\n\n const checkPasswordStrength = (value: string) => {\n const validatedOptions = validatePassword(value);\n const allValidated = validatedOptions.every((option) => option.validated);\n\n setValidatedValues(validatedOptions);\n\n return allValidated;\n };\n\n const handlePaswordInputChange: React.ChangeEventHandler<HTMLInputElement> = (\n e,\n ) => {\n if (onChange) onChange(e);\n\n if (disableValidation) return;\n\n const value = e?.target?.value;\n const validated = checkPasswordStrength(value);\n\n if (onValidate) onValidate(validated, value);\n };\n\n const ValidateComp = useMemo(() => {\n return (\n <div className=\"flex items-center gap-2\">\n {validatedValues?.map((value) => (\n <div\n className={cn(\"text-xs flex items-center gap-0.5\", {\n \"text-[#62C554]\": value?.validated,\n \"text-[#8E98A8]\": !value?.validated,\n })}\n key={value?.key}\n >\n <span className=\"\">{value?.validated ? <Check /> : <Fail />}</span>\n <span className=\"\">{value?.label}</span>\n </div>\n ))}\n </div>\n );\n }, [validatedValues]);\n\n return (\n <Input\n sideNodeClassName=\"!border-l-0\"\n rightNode={\n passwordVisible ? (\n <button\n type=\"button\"\n onClick={() => setPasswordVisible((val) => !val)}\n >\n <Eye />\n </button>\n ) : (\n <button\n type=\"button\"\n onClick={() => setPasswordVisible((val) => !val)}\n >\n <EyeOff />\n </button>\n )\n }\n type={passwordVisible ? \"text\" : \"password\"}\n onChange={handlePaswordInputChange}\n description={!disableValidation && ValidateComp}\n {...props}\n />\n );\n};\n\nPasswordInput.displayName = \"PasswordInput\";\n\nexport { PasswordInput };\n","export const Eye = () => {\n return (\n <svg\n width=\"18\"\n height=\"14\"\n viewBox=\"0 0 18 14\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M1.54639 7.26103C1.48389 7.09264 1.48389 6.90741 1.54639 6.73903C2.15517 5.26292 3.18853 4.00081 4.51547 3.1127C5.84241 2.22459 7.40317 1.75049 8.99989 1.75049C10.5966 1.75049 12.1574 2.22459 13.4843 3.1127C14.8113 4.00081 15.8446 5.26292 16.4534 6.73903C16.5159 6.90741 16.5159 7.09264 16.4534 7.26103C15.8446 8.73713 14.8113 9.99925 13.4843 10.8874C12.1574 11.7755 10.5966 12.2496 8.99989 12.2496C7.40317 12.2496 5.84241 11.7755 4.51547 10.8874C3.18853 9.99925 2.15517 8.73713 1.54639 7.26103Z\"\n stroke=\"#8E98A8\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M9 9.25C10.2426 9.25 11.25 8.24264 11.25 7C11.25 5.75736 10.2426 4.75 9 4.75C7.75736 4.75 6.75 5.75736 6.75 7C6.75 8.24264 7.75736 9.25 9 9.25Z\"\n stroke=\"#8E98A8\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n};\n","export const EyeOff = () => {\n return (\n <svg\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 18 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M4.08759 12.69C3.26171 11.9072 2.61006 10.9591 2.17509 9.90752C2.10081 9.73454 2.0625 9.54826 2.0625 9.36001C2.0625 9.17177 2.10081 8.98549 2.17509 8.81252C2.75274 7.4073 3.72095 6.19704 4.96509 5.32502C6.14597 4.4998 7.55989 4.07405 9.00009 4.11002C10.0363 4.084 11.064 4.30239 12.0001 4.74752M13.9201 6.03752C14.7415 6.81964 15.3904 7.76486 15.8251 8.81252C15.8994 8.98549 15.9377 9.17177 15.9377 9.36001C15.9377 9.54826 15.8994 9.73454 15.8251 9.90752C15.2474 11.3127 14.2792 12.523 13.0351 13.395C11.8542 14.2202 10.4403 14.646 9.00009 14.61C7.9639 14.636 6.93616 14.4176 6.00009 13.9725\"\n stroke=\"#8E98A8\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M6.5325 10.2375C6.42732 9.95694 6.37395 9.65962 6.375 9.36C6.375 8.66381 6.65156 7.99613 7.14384 7.50384C7.63613 7.01156 8.30381 6.735 9 6.735C9.3 6.7335 9.597 6.7875 9.8775 6.8925M11.4675 8.4825C11.5725 8.763 11.6265 9.06 11.625 9.36C11.625 10.0562 11.3484 10.7239 10.8562 11.2162C10.3639 11.7084 9.69619 11.985 9 11.985C8.70038 11.986 8.40306 11.9327 8.1225 11.8275M2.25 15L14.25 3\"\n stroke=\"#8E98A8\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n};\n","export const Check = () => {\n return (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M8.89802 2.93408L9.70202 3.49808L6.21602 8.52608H5.41202L3.46802 5.80208L4.27202 5.05208L5.81402 6.49208L8.89802 2.93408Z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n};\n","export const Fail = () => {\n return (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M3.37891 8.62142L6.00041 5.99992L8.62191 8.62142M8.62191 3.37842L5.99991 5.99992L3.37891 3.37842\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n};\n","import * as React from \"react\";\n\nimport { cn } from \"@/src/utils\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { inputContainerVariants } from \"../input\";\nimport { DetailedHTMLProps } from \"react\";\nimport { FormLabel } from \"../label/FormLabel\";\nimport { FormDescription } from \"../form/FormDescription\";\nimport { ErrorMessage } from \"../form/ErrorMessage\";\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nconst textareaContainerVariants = cva(\n \"flex relative min-h-[80px] w-full rounded-[8px] border transition px-3 py-2 text-base placeholder:text-[#79818C] focus-within:outline-0 focus-within:ring-0 focus-visible:ring-offset-0 disabled:cursor-not-allowed disabled:opacity-50\",\n {\n variants: {\n status: {\n default:\n \"border-[#D7D7D7] dark:border-[#676767] bg-white text-[#191919] dark:!bg-transparent caret-primary-main focus-within:bg-white dark:focus-within:!bg-transparent dark:text-white focus-within:border-primary-main dark:focus-within:border-[#9299A2] dark:border-[#9299A2] dark:disabled:!border-[#9299A2]\",\n error:\n \"placeholder:text-status-error-fill bg-status-error-bg border-status-error-fill dark:!bg-status-error-bg-dark text-status-error-fill focus-within:bg-status-error-bg focus-within:border-status-error-fill\",\n loading: \"placeholder:text-[#C4C4C4]\",\n prefilled:\n \"resize-none bg-[#F6F6F6] border-[#D7D7D7] dark:!bg-transparent caret-[#D7D7D7] focus-within:bg-[#F6F6F6] focus-within:border-[#D7D7D7] dark:!border-[#9299A2] dark:focus-within:border-[#9299A2]\",\n neutral: \"\",\n },\n },\n defaultVariants: {\n status: \"default\",\n },\n },\n);\n\nexport interface TextareaProps\n extends DetailedHTMLProps<\n React.TextareaHTMLAttributes<HTMLTextAreaElement>,\n HTMLTextAreaElement\n >,\n VariantProps<typeof inputContainerVariants> {\n isLoading?: boolean;\n error?: string;\n label?: string;\n showAsterisk?: boolean;\n description?: React.ReactNode;\n}\n\nconst Textarea = ({\n className,\n status = \"default\",\n disabled,\n error,\n isLoading,\n showAsterisk,\n label,\n description,\n ...props\n}: TextareaProps) => {\n let containerStatus: VariantProps<\n typeof textareaContainerVariants\n >[\"status\"] = status;\n\n if (error) containerStatus = \"error\";\n if (isLoading) containerStatus = \"loading\";\n if (disabled) containerStatus = \"prefilled\";\n\n return (\n <div className=\"relative space-y-1\">\n <FormLabel showAsterisk={showAsterisk} error={error}>\n {label}\n </FormLabel>\n <textarea\n className={cn(\n \"min-h-[80px]\",\n inputContainerVariants({ status: containerStatus }),\n className,\n )}\n disabled={isLoading || disabled}\n {...props}\n />\n <FormDescription className=\"text-gray-400 text-sm !font-normal\">\n {description}\n </FormDescription>\n <ErrorMessage error={error} />\n </div>\n );\n};\n\nTextarea.displayName = \"Textarea\";\n\nexport { Textarea };\n","(\"use client\");\n\nimport * as React from \"react\";\n\nimport {\n Command,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n} from \"../command\";\nimport { PopoverContent, PopoverRoot, PopoverTrigger } from \"../popover\";\nimport { cn } from \"@/src/utils\";\nimport { ScrollArea } from \"../scroll-area\";\nimport { VariantProps } from \"class-variance-authority\";\nimport { inputContainerVariants } from \"../input\";\n\ntype SearchableDataType = {\n value: string;\n label: string;\n} & {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any; // Allows for additional properties\n};\n\ninterface SearchableProps {\n modal?: boolean;\n hideSearch?: boolean;\n loading?: boolean;\n inputValue?: string;\n onInputValueChange?: (arg: string) => void;\n disabled?: boolean;\n placeholder?: string;\n value?: SearchableDataType;\n options: SearchableDataType[] | [];\n optionComponent?: (arg: SearchableDataType) => React.ReactNode;\n className?: string;\n containerClassName?: string;\n onChange: (value: SearchableDataType) => void;\n onValueChange?: (value: string) => void;\n children?: React.ReactNode;\n}\n\ninterface SearchableTriggerProps\n extends VariantProps<typeof inputContainerVariants> {\n disabled?: boolean;\n placeholder?: string;\n value?: string;\n className?: string;\n id?: string;\n}\n\nconst SearchableTrigger = ({\n className,\n value,\n placeholder = \"\",\n status,\n disabled,\n id,\n}: SearchableTriggerProps) => {\n return (\n <PopoverTrigger asChild disabled={disabled} id={id ?? \"searchable-trigger\"}>\n <button\n disabled={disabled}\n className={cn(\n inputContainerVariants({ status }),\n \"[&>span]:justify-start [&>span]:items-center gap-2 flex h-12 w-full items-center justify-between goup\",\n value ? \"\" : \"text-[#79818C]\",\n className,\n )}\n >\n {value ?? placeholder ?? \"Select options...\"}\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n className=\" data-[state=open]:goup-rotate-180\"\n >\n <path\n d=\"M16.5999 7.45825L11.1666 12.8916C10.5249 13.5333 9.4749 13.5333 8.83324 12.8916L3.3999 7.45825\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeMiterlimit=\"10\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </button>\n </PopoverTrigger>\n );\n};\n\nconst Searchable = ({\n options = [],\n value,\n onChange,\n containerClassName,\n placeholder,\n disabled,\n loading,\n optionComponent,\n children,\n modal = false,\n hideSearch,\n className,\n inputValue,\n onValueChange,\n onInputValueChange,\n}: SearchableProps) => {\n const [open, setOpen] = React.useState(false);\n\n const triggerRef = React.useRef<HTMLDivElement | null>(null);\n\n const [width, setWidth] = React.useState<number | undefined>(undefined);\n\n React.useLayoutEffect(() => {\n if (triggerRef.current) {\n setWidth(triggerRef.current.clientWidth);\n }\n }, [triggerRef.current]);\n\n return (\n <PopoverRoot modal={modal} open={open} onOpenChange={setOpen}>\n <div className={cn(\"w-full\", className)} ref={triggerRef}>\n {children}\n </div>\n <PopoverContent\n portal={!modal}\n className=\"p-0 min-w-[200px]\"\n style={{ width }}\n >\n <Command\n className={cn(\"relative max-h-[270px]\", {\n \"mt-2\": !hideSearch,\n })}\n >\n {!hideSearch && (\n <CommandInput\n loading={loading}\n placeholder={placeholder ?? \"Search options...\"}\n onValueChange={onInputValueChange}\n value={inputValue}\n CommandInputContainerClassName=\"mx-2 border rounded-md border-[#DEDEDE]\"\n />\n )}\n <ScrollArea\n viewPortClassName=\"max-h-[225px]\"\n className={cn(\n \"w-full px-0 h-full overflow-y-auto\",\n containerClassName,\n )}\n >\n <CommandList>\n {!hideSearch && <CommandEmpty>No result found.</CommandEmpty>}\n <CommandGroup className=\"w-full\">\n {options?.map((option) => (\n <CommandItem\n defaultValue={value?.label}\n key={option.value}\n value={option.label}\n disabled={disabled}\n onSelect={() => {\n onChange(option);\n setOpen(false);\n onValueChange?.(option?.value);\n }}\n id={option.value}\n >\n {!optionComponent ? option.label : optionComponent(option)}\n </CommandItem>\n ))}\n </CommandGroup>\n </CommandList>\n </ScrollArea>\n </Command>\n </PopoverContent>\n </PopoverRoot>\n );\n};\n\nexport { Searchable, SearchableTrigger };\n\nexport type { SearchableProps, SearchableTriggerProps, SearchableDataType };\n","\"use client\";\n\nimport * as React from \"react\";\nimport { type DialogProps } from \"@radix-ui/react-dialog\";\nimport { Command as CommandPrimitive } from \"cmdk\";\nimport { Search } from \"lucide-react\";\n\nimport { cn } from \"@/src/utils\";\nimport { Dialog, DialogContent } from \"@/src/components/dialog\";\nimport { Loader } from \"../loader\";\n\nconst Command = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive\n ref={ref}\n className={cn(\n \"flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground\",\n className,\n )}\n {...props}\n />\n));\nCommand.displayName = CommandPrimitive.displayName;\n\ninterface CommandDialogProps extends DialogProps {\n trigger?: React.ReactNode;\n}\n\nconst CommandDialog = ({ children, ...props }: CommandDialogProps) => {\n return (\n <Dialog {...props} trigger={props?.trigger ?? <></>}>\n <DialogContent className=\"overflow-hidden p-0\">\n <Command className=\"[&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-group]]:px-2 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5\">\n {children}\n </Command>\n </DialogContent>\n </Dialog>\n );\n};\n\ninterface CommandInputProps\n extends React.ComponentPropsWithoutRef<typeof CommandPrimitive.Input> {\n CommandInputContainerClassName?: string;\n loading?: boolean;\n}\n\nconst CommandInput = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Input>,\n CommandInputProps\n>(({ className, CommandInputContainerClassName, loading, ...props }, ref) => (\n <div\n className={cn(\n \"flex items-center border-0 px-3 gap-2\",\n CommandInputContainerClassName,\n )}\n cmdk-input-wrapper=\"\"\n >\n {loading ? (\n <Loader size={16} colour=\"secondary\" />\n ) : (\n <Search className=\"mr-2 h-4 w-4 shrink-0 opacity-50\" />\n )}\n <CommandPrimitive.Input\n ref={ref}\n className={cn(\n \"flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50\",\n className,\n )}\n disabled={loading}\n {...props}\n />\n </div>\n));\n\nCommandInput.displayName = CommandPrimitive.Input.displayName;\n\nconst CommandList = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.List>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.List>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.List\n ref={ref}\n className={cn(\"overflow-y-auto overflow-x-hidden\", className)}\n {...props}\n />\n));\n\nCommandList.displayName = CommandPrimitive.List.displayName;\n\nconst CommandEmpty = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Empty>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Empty>\n>((props, ref) => (\n <CommandPrimitive.Empty\n ref={ref}\n className=\"py-6 text-center text-sm\"\n {...props}\n />\n));\n\nCommandEmpty.displayName = CommandPrimitive.Empty.displayName;\n\nconst CommandGroup = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Group>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Group>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Group\n ref={ref}\n className={cn(\n \"overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground\",\n className,\n )}\n {...props}\n />\n));\n\nCommandGroup.displayName = CommandPrimitive.Group.displayName;\n\nconst CommandSeparator = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Separator>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Separator\n ref={ref}\n className={cn(\"-mx-1 h-px bg-border\", className)}\n {...props}\n />\n));\nCommandSeparator.displayName = CommandPrimitive.Separator.displayName;\n\nconst CommandItem = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Item>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Item\n ref={ref}\n className={cn(\n \"relative text=[#222222] flex cursor-default gap-2 select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none data-[disabled=true]:pointer-events-none data-[selected=true]:bg-primary-accent data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0\",\n className,\n )}\n {...props}\n />\n));\n\nCommandItem.displayName = CommandPrimitive.Item.displayName;\n\nconst CommandShortcut = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLSpanElement>) => {\n return (\n <span\n className={cn(\n \"ml-auto text-xs tracking-widest text-muted-foreground\",\n className,\n )}\n {...props}\n />\n );\n};\nCommandShortcut.displayName = \"CommandShortcut\";\n\nexport {\n Command,\n CommandDialog,\n CommandInput,\n CommandList,\n CommandEmpty,\n CommandGroup,\n CommandItem,\n CommandShortcut,\n CommandSeparator,\n};\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as DialogPrimitive from \"@radix-ui/react-dialog\";\n\nimport { cn } from \"@/src/utils\";\nimport { CloseIcon } from \"./icon/CloseIcon\";\n\nconst DialogRoot = DialogPrimitive.Root;\n\nconst DialogTrigger = DialogPrimitive.Trigger;\n\nconst DialogPortal = DialogPrimitive.Portal;\n\nconst DialogOverlay = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Overlay>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Overlay\n ref={ref}\n className={cn(\n \"fixed inset-0 z-50 bg-black/60 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0\",\n className,\n )}\n {...props}\n />\n));\nDialogOverlay.displayName = DialogPrimitive.Overlay.displayName;\n\nconst DialogContent = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Content> & {\n hideCloseButton?: boolean;\n }\n>(({ className, hideCloseButton, children, ...props }, ref) => (\n <DialogPortal>\n <DialogOverlay />\n <DialogPrimitive.Content\n ref={ref}\n className={cn(\n \"fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border border-transparent bg-white p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] rounded-lg max-h-[95%] overflow-y-auto\",\n className,\n )}\n {...props}\n >\n {children}\n {!hideCloseButton && (\n <DialogPrimitive.Close className=\"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground\">\n <CloseIcon />\n\n <span className=\"sr-only\">Close</span>\n </DialogPrimitive.Close>\n )}\n </DialogPrimitive.Content>\n </DialogPortal>\n));\nDialogContent.displayName = DialogPrimitive.Content.displayName;\n\nconst DialogHeader = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\"flex flex-col space-y-1.5 text-left\", className)}\n {...props}\n />\n);\nDialogHeader.displayName = \"DialogHeader\";\n\nconst DialogFooter = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\"flex flex-row justify-end sm:space-x-2\", className)}\n {...props}\n />\n);\nDialogFooter.displayName = \"DialogFooter\";\n\nconst DialogTitle = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Title>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Title>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Title\n ref={ref}\n className={cn(\n \"text-xl font-semibold leading-none tracking-tight\",\n className,\n )}\n {...props}\n />\n));\nDialogTitle.displayName = DialogPrimitive.Title.displayName;\n\nconst DialogDescription = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Description>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Description>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Description\n ref={ref}\n className={cn(\"text-sm text-gray-500\", className)}\n {...props}\n />\n));\nDialogDescription.displayName = DialogPrimitive.Description.displayName;\n\nexport type DialogPropsType = {\n trigger?: React.ReactNode;\n children: React.ReactNode;\n title?: React.ReactNode;\n description?: React.ReactNode;\n footer?: React.ReactNode;\n hideCloseButton?: boolean;\n contentClassName?: string;\n headerClassName?: string;\n titleClassName?: string;\n descriptionClassName?: string;\n footerClassName?: string;\n asChild?: boolean;\n onOpenAutoFocus?: (e: Event) => void;\n onCloseAutoFocus?: (e: Event) => void;\n onInteractOutside?: (e: Event) => void;\n onPointerDownOutside?: (e: Event) => void;\n onEscapeKeyDown?: (e: KeyboardEvent) => void;\n};\n\nconst Dialog = ({\n trigger = undefined,\n children,\n open,\n onOpenChange,\n hideCloseButton,\n footer,\n title,\n description,\n contentClassName,\n headerClassName,\n titleClassName,\n descriptionClassName,\n footerClassName,\n asChild = true,\n onOpenAutoFocus,\n onCloseAutoFocus,\n onEscapeKeyDown,\n onInteractOutside,\n onPointerDownOutside,\n ...props\n}: React.ComponentPropsWithoutRef<typeof DialogPrimitive.Root> &\n DialogPropsType) => {\n return (\n <DialogRoot {...props} open={open} onOpenChange={onOpenChange}>\n <DialogTrigger asChild={asChild}>{trigger}</DialogTrigger>\n <DialogPortal>\n <DialogContent\n className={contentClassName}\n hideCloseButton={hideCloseButton}\n onOpenAutoFocus={onOpenAutoFocus}\n onCloseAutoFocus={onCloseAutoFocus}\n onEscapeKeyDown={onEscapeKeyDown}\n onPointerDownOutside={onPointerDownOutside}\n onInteractOutside={onInteractOutside}\n >\n {title || description ? (\n <DialogHeader className={headerClassName}>\n {title && (\n <DialogTitle className={titleClassName}>{title}</DialogTitle>\n )}\n {description && (\n <DialogDescription className={descriptionClassName}>\n {description}\n </DialogDescription>\n )}\n </DialogHeader>\n ) : (\n <></>\n )}\n {children}\n {footer && (\n <DialogFooter className={footerClassName}>{footer}</DialogFooter>\n )}\n </DialogContent>\n </DialogPortal>\n </DialogRoot>\n );\n};\nDialog.displayName = DialogPrimitive.Dialog.displayName;\n\nexport { Dialog, DialogRoot, DialogContent };\n","export const CloseIcon = () => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n className=\"lucide lucide-x\"\n >\n <path d=\"M18 6 6 18\" />\n <path d=\"m6 6 12 12\" />\n </svg>\n );\n};\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\";\n\nimport { cn } from \"@/src/utils\";\n\nconst PopoverRoot = PopoverPrimitive.Root;\n\nconst PopoverTrigger = PopoverPrimitive.Trigger;\n\nconst PopoverContent = React.forwardRef<\n React.ElementRef<typeof PopoverPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Content> & {\n portal?: boolean;\n }\n>(\n (\n { className, align = \"center\", sideOffset = 4, portal = true, ...props },\n ref,\n ) =>\n portal ? (\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n ref={ref}\n align={align}\n sideOffset={sideOffset}\n className={cn(\n \"pointer-events-auto z-50 w-72 rounded-md border border-transparent bg-white p-4 text-[#191919] shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2\",\n className,\n )}\n onOpenAutoFocus={props.onOpenAutoFocus}\n onCloseAutoFocus={props.onCloseAutoFocus}\n {...props}\n />\n </PopoverPrimitive.Portal>\n ) : (\n <PopoverPrimitive.Content\n ref={ref}\n align={align}\n sideOffset={sideOffset}\n className={cn(\n \"pointer-events-auto z-50 w-72 rounded-md border border-transparent bg-white p-4 text-[#191919] shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2\",\n className,\n )}\n onOpenAutoFocus={props.onOpenAutoFocus}\n onCloseAutoFocus={props.onCloseAutoFocus}\n {...props}\n />\n ),\n);\nPopoverContent.displayName = PopoverPrimitive.Content.displayName;\n\nexport type PopoverPropsType = {\n trigger: React.ReactNode;\n children: React.ReactNode;\n contentClassName?: string;\n triggerClassName?: string;\n asChild?: boolean;\n align?: PopoverPrimitive.PopoverContentProps[\"align\"];\n side?: PopoverPrimitive.PopoverContentProps[\"side\"];\n alignOffset?: number | undefined;\n sideOffset?: number | undefined;\n onOpenAutoFocus?: (e: Event) => void;\n onCloseAutoFocus?: (e: Event) => void;\n portal?: boolean;\n id?: string;\n};\n\nconst Popover = ({\n trigger,\n children,\n open,\n onOpenChange,\n contentClassName,\n asChild = true,\n align,\n side,\n alignOffset,\n triggerClassName,\n sideOffset,\n onOpenAutoFocus,\n onCloseAutoFocus,\n portal = true,\n id = \"popover\",\n ...props\n}: React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Root> &\n PopoverPropsType) => {\n return (\n <PopoverRoot {...props} open={open} onOpenChange={onOpenChange}>\n <PopoverTrigger\n asChild={asChild}\n className={triggerClassName}\n id={`${id}-trigger`}\n >\n {trigger}\n </PopoverTrigger>\n <PopoverContent\n alignOffset={alignOffset}\n sideOffset={sideOffset}\n side={side}\n align={align}\n className={contentClassName}\n onOpenAutoFocus={onOpenAutoFocus}\n onCloseAutoFocus={onCloseAutoFocus}\n portal={portal}\n id={`${id}-content`}\n >\n {children}\n </PopoverContent>\n </PopoverRoot>\n );\n};\nPopover.displayName = PopoverPrimitive.Root.displayName;\n\nexport { Popover, PopoverRoot, PopoverTrigger, PopoverContent };\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as ScrollAreaPrimitive from \"@radix-ui/react-scroll-area\";\n\nimport { cn } from \"@/src/utils\";\n\nconst ScrollArea = React.forwardRef<\n React.ElementRef<typeof ScrollAreaPrimitive.Root>,\n React.ComponentPropsWithoutRef<typeof ScrollAreaPrimitive.Root> & {\n viewPortClassName?: string;\n }\n>(({ className, viewPortClassName, children, ...props }, ref) => (\n <ScrollAreaPrimitive.Root\n ref={ref}\n className={cn(\"relative overflow-hidden\", className)}\n {...props}\n >\n <ScrollAreaPrimitive.Viewport\n className={cn(\"h-full w-full rounded-[inherit]\", viewPortClassName)}\n >\n {children}\n </ScrollAreaPrimitive.Viewport>\n <ScrollBar />\n <ScrollAreaPrimitive.Corner />\n </ScrollAreaPrimitive.Root>\n));\nScrollArea.displayName = ScrollAreaPrimitive.Root.displayName;\n\nconst ScrollBar = React.forwardRef<\n React.ElementRef<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>,\n React.ComponentPropsWithoutRef<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>\n>(({ className, orientation = \"vertical\", ...props }, ref) => (\n <ScrollAreaPrimitive.ScrollAreaScrollbar\n ref={ref}\n orientation={orientation}\n className={cn(\n \"flex touch-none select-none transition-colors\",\n orientation === \"vertical\" &&\n \"h-full w-2.5 border-l border-l-transparent p-[1px]\",\n orientation === \"horizontal\" &&\n \"h-2.5 flex-col border-t border-t-transparent p-[1px]\",\n className,\n )}\n {...props}\n >\n <ScrollAreaPrimitive.ScrollAreaThumb className=\"relative flex-1 rounded-full bg-[#959595] transition hover:bg-[#808080]\" />\n </ScrollAreaPrimitive.ScrollAreaScrollbar>\n));\nScrollBar.displayName = ScrollAreaPrimitive.ScrollAreaScrollbar.displayName;\n\nexport { ScrollArea, ScrollBar };\n","export const countryData = [\n {\n countryCode: \"GLOBAL\",\n countryName: \"Global\",\n currency: \"Dollars\",\n currencyCode: \"USD\",\n internetCountryCode: \"GLOBAL\",\n },\n {\n countryName: \"Benin\",\n countryCode: \"+229\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"BJ\",\n },\n {\n countryName: \"Burkina Faso\",\n countryCode: \"+226\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"BF\",\n },\n {\n countryName: \"Cameroon\",\n countryCode: \"+237\",\n currency: \"Central African CFA franc\",\n currencyCode: \"XAF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"CM\",\n },\n {\n countryName: \"Chad\",\n countryCode: \"+235\",\n currency: \"Central African CFA franc\",\n currencyCode: \"XAF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"TD\",\n },\n {\n countryName: \"DR Congo\",\n countryCode: \"+243\",\n currency: \"Congolese franc\",\n currencyCode: \"CDF\",\n currencyIcon: \"FC\",\n internetCountryCode: \"CD\",\n },\n {\n countryName: \"Eswatini\",\n countryCode: \"+268\",\n currency: \"Swazi lilangeni\",\n currencyCode: \"SZL\",\n currencyIcon: \"L\",\n internetCountryCode: \"SZ\",\n },\n {\n countryName: \"Gabon\",\n countryCode: \"+241\",\n currency: \"Central African CFA franc\",\n currencyCode: \"XAF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"GA\",\n },\n {\n countryName: \"Ghana\",\n countryCode: \"+233\",\n currency: \"Ghanaian cedi\",\n currencyCode: \"GHS\",\n currencyIcon: \"₵\",\n internetCountryCode: \"GH\",\n },\n {\n countryName: \"Guinea\",\n countryCode: \"+224\",\n currency: \"Guinean franc\",\n currencyCode: \"GNF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"GN\",\n },\n {\n countryName: \"Ivory Coast\",\n countryCode: \"+225\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"CI\",\n },\n {\n countryName: \"Kenya\",\n countryCode: \"+254\",\n currency: \"Kenyan shilling\",\n currencyCode: \"KES\",\n currencyIcon: \"Sh\",\n internetCountryCode: \"KE\",\n },\n {\n countryName: \"Lesotho\",\n countryCode: \"+266\",\n currency: \"Lesotho loti\",\n currencyCode: \"LSL\",\n currencyIcon: \"L\",\n internetCountryCode: \"LS\",\n },\n {\n countryName: \"Liberia\",\n countryCode: \"+231\",\n currency: \"Liberian dollar\",\n currencyCode: \"LRD\",\n currencyIcon: \"$\",\n internetCountryCode: \"LR\",\n },\n {\n countryName: \"Madagascar\",\n countryCode: \"+261\",\n currency: \"Malagasy ariary\",\n currencyCode: \"MGA\",\n currencyIcon: \"Ar\",\n internetCountryCode: \"MG\",\n },\n {\n countryName: \"Malawi\",\n countryCode: \"+265\",\n currency: \"Malawian kwacha\",\n currencyCode: \"MWK\",\n currencyIcon: \"MK\",\n internetCountryCode: \"MW\",\n },\n {\n countryName: \"Mali\",\n countryCode: \"+223\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"ML\",\n },\n {\n countryName: \"Mozambique\",\n countryCode: \"+258\",\n currency: \"Mozambican metical\",\n currencyCode: \"MZN\",\n currencyIcon: \"MT\",\n internetCountryCode: \"MZ\",\n },\n {\n countryName: \"Namibia\",\n countryCode: \"+264\",\n currency: \"Namibian dollar\",\n currencyCode: \"NAD\",\n currencyIcon: \"$\",\n internetCountryCode: \"NA\",\n },\n {\n countryName: \"Niger\",\n countryCode: \"+227\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"NE\",\n },\n {\n countryName: \"Nigeria\",\n countryCode: \"+234\",\n currency: \"Nigerian naira\",\n currencyCode: \"NGN\",\n currencyIcon: \"₦\",\n internetCountryCode: \"NG\",\n },\n {\n countryName: \"Republic of the Congo\",\n countryCode: \"+242\",\n currency: \"Central African CFA franc\",\n currencyCode: \"XAF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"CG\",\n },\n {\n countryName: \"Rwanda\",\n countryCode: \"+250\",\n currency: \"Rwandan franc\",\n currencyCode: \"RWF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"RW\",\n },\n {\n countryName: \"Senegal\",\n countryCode: \"+221\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"SN\",\n },\n {\n countryName: \"Seychelles\",\n countryCode: \"+248\",\n currency: \"Seychellois rupee\",\n currencyCode: \"SCR\",\n currencyIcon: \"₨\",\n internetCountryCode: \"SC\",\n },\n {\n countryName: \"South Africa\",\n countryCode: \"+27\",\n currency: \"South African rand\",\n currencyCode: \"ZAR\",\n currencyIcon: \"R\",\n internetCountryCode: \"ZA\",\n },\n {\n countryName: \"South Sudan\",\n countryCode: \"+211\",\n currency: \"South Sudanese pound\",\n currencyCode: \"SSP\",\n currencyIcon: \"£\",\n internetCountryCode: \"SS\",\n },\n {\n countryName: \"Tanzania\",\n countryCode: \"+255\",\n currency: \"Tanzanian shilling\",\n currencyCode: \"TZS\",\n currencyIcon: \"Sh\",\n internetCountryCode: \"TZ\",\n },\n {\n countryName: \"Togo\",\n countryCode: \"+228\",\n currency: \"West African CFA franc\",\n currencyCode: \"XOF\",\n currencyIcon: \"Fr\",\n internetCountryCode: \"TG\",\n },\n {\n countryName: \"Uganda\",\n countryCode: \"+256\",\n currency: \"Ugandan shilling\",\n currencyCode: \"UGX\",\n currencyIcon: \"Sh\",\n internetCountryCode: \"UG\",\n },\n {\n countryName: \"Zambia\",\n countryCode: \"+260\",\n currency: \"Zambian kwacha\",\n currencyCode: \"ZMW\",\n currencyIcon: \"ZK\",\n internetCountryCode: \"ZM\",\n },\n];\n\nexport const getCountryDataMap = () => {\n const frequency = {} as Record<string, string>;\n // {UG: Uganda}\n\n countryData?.forEach((country) => {\n frequency[country?.internetCountryCode] = country?.countryName;\n });\n\n return frequency;\n};\n","\"use client\";\n\nimport * as React from \"react\";\n\nimport * as RPNInput from \"react-phone-number-input\";\n\nimport flags from \"react-phone-number-input/flags\";\n\nimport {\n Command,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n} from \"../command\";\nimport { Input, InputProps, inputContainerVariants } from \"../input\";\nimport { PopoverRoot, PopoverContent, PopoverTrigger } from \"../popover\";\n\nimport { cn } from \"@/src/utils\";\nimport { ScrollArea } from \"../scroll-area\";\nimport { VariantProps } from \"class-variance-authority\";\nimport FlatGlobeIcon from \"./Flag\";\nimport { FormLabel } from \"../label/FormLabel\";\nimport { FormDescription } from \"../form/FormDescription\";\nimport { ErrorMessage } from \"../form/ErrorMessage\";\n\nexport type PhoneInputValue = RPNInput.Value;\n\nexport type PhoneInputProps = Omit<\n React.InputHTMLAttributes<HTMLInputElement>,\n \"onChange\" | \"value\"\n> &\n Omit<RPNInput.Props<typeof RPNInput.default>, \"onChange\"> & {\n onChange?: (value: RPNInput.Value) => void;\n } & {\n status?: VariantProps<typeof inputContainerVariants>[\"status\"];\n defaultCountry?: RPNInput.Country;\n modal?: boolean;\n label?: string;\n showAsterisk?: boolean;\n description?: React.ReactNode;\n error?: string;\n };\n\nconst PhoneInput: React.ForwardRefExoticComponent<PhoneInputProps> =\n React.forwardRef<React.ElementRef<typeof RPNInput.default>, PhoneInputProps>(\n (\n {\n className,\n onChange,\n defaultCountry = \"NG\",\n modal,\n showAsterisk,\n label,\n description,\n error,\n ...props\n },\n ref,\n ) => {\n /**\n * did this so I can pass the status prop to the country\n * select so I can change the appearance based on the status\n */\n const CountrySelectWrapper = (innerProps: CountrySelectProps) => {\n return (\n <CountrySelect {...innerProps} status={props.status} modal={modal} />\n );\n };\n\n return (\n <div className=\"relative space-y-1\">\n <FormLabel showAsterisk={showAsterisk} error={error}>\n {label}\n </FormLabel>\n <RPNInput.default\n ref={ref}\n className={cn(\"flex\", className)}\n flagComponent={FlagComponent}\n countrySelectComponent={CountrySelectWrapper}\n inputComponent={InputComponent}\n defaultCountry={defaultCountry}\n /**\n * Handles the onChange event.\n *\n * react-phone-number-input might trigger the onChange event as undefined\n * when a valid phone number is not entered. To prevent this,\n * the value is coerced to an empty string.\n *\n * @param {E164Number | undefined} value - The entered value\n */\n onChange={(value) => {\n if (onChange) {\n onChange?.(value as RPNInput.Value);\n }\n }}\n {...props}\n />\n <FormDescription className=\"text-gray-400 text-sm !font-normal\">\n {description}\n </FormDescription>\n <ErrorMessage error={error} />\n </div>\n );\n },\n );\nPhoneInput.displayName = \"PhoneInput\";\n\nconst InputComponent = React.forwardRef<HTMLInputElement, InputProps>(\n ({ className, ...props }, ref) => {\n return (\n <Input\n className={cn(\"!rounded-s-none h-10\", className)}\n {...props}\n ref={ref}\n />\n );\n },\n);\nInputComponent.displayName = \"InputComponent\";\n\ntype CountrySelectOption = { label: string; value: RPNInput.Country };\n\ntype CountrySelectProps = {\n disabled?: boolean;\n modal?: boolean;\n value: RPNInput.Country;\n onChange: (value: RPNInput.Country) => void;\n options: CountrySelectOption[];\n status?: VariantProps<typeof inputContainerVariants>[\"status\"];\n};\n\nconst CountrySelect = ({\n disabled,\n value,\n onChange,\n options,\n status,\n modal,\n}: CountrySelectProps) => {\n const handleSelect = React.useCallback(\n (country: RPNInput.Country) => {\n onChange(country);\n },\n [onChange],\n );\n\n return (\n <PopoverRoot modal={modal}>\n <PopoverTrigger disabled={disabled}>\n <div\n className={cn(\n inputContainerVariants({ status }),\n \"transition justify-center items-center disabled:text-base-500 flex gap-3 h-10 rounded-e-none border-e-0 pl-2 pr-2\",\n )}\n >\n <FlagComponent country={value} countryName={value} />\n <svg\n className={cn(\n \"mr-0.5 h-4 w-4 opacity-50\",\n disabled ? \"hidden\" : \"opacity-100\",\n )}\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n >\n <path\n d=\"M16.5999 7.45825L11.1666 12.8916C10.5249 13.5333 9.4749 13.5333 8.83324 12.8916L3.3999 7.45825\"\n stroke=\"#959595\"\n strokeWidth=\"1.5\"\n strokeMiterlimit=\"10\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </div>\n </PopoverTrigger>\n <PopoverContent portal={!modal} className=\"w-[200px] md:w-[300px] p-0\">\n <Command>\n <CommandList>\n <ScrollArea className=\"h-72\">\n <CommandInput placeholder=\"Search country...\" />\n <CommandEmpty>No country found.</CommandEmpty>\n <CommandGroup>\n {options\n .filter((x) => x.value)\n .map((option) => (\n <CommandItem\n className=\"gap-2\"\n key={`${option.value}-${option.label}`}\n onSelect={() => handleSelect(option.value)}\n >\n <FlagComponent\n country={option.value}\n countryName={option.label}\n />\n <span className=\"flex-1 text-sm\">{option.label}</span>\n {option.value && (\n <span className=\"text-[#191919]/50 text-sm dark:text-white\">\n {`+${RPNInput.getCountryCallingCode(option.value)}`}\n </span>\n )}\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n className={cn(\n \"ml-auto\",\n option.value === value ? \"opacity-100\" : \"opacity-0\",\n )}\n >\n <path\n d=\"M4 8.00008L6.66353 10.6636L12 5.33655\"\n stroke=\"#959595\"\n strokeWidth=\"1.06667\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </CommandItem>\n ))}\n </CommandGroup>\n </ScrollArea>\n </CommandList>\n </Command>\n </PopoverContent>\n </PopoverRoot>\n );\n};\n\ntype FlagComponentProps = RPNInput.FlagProps & {\n className?: string;\n};\n\nconst FlagComponent = ({\n country,\n countryName,\n className,\n}: FlagComponentProps) => {\n const Flag = flags[country];\n\n if (country === (\"GLOBAL\" as unknown))\n return (\n <span\n className={cn(\n \"bg-white/20 flex h-4 w-6 overflow-hidden rounded-sm\",\n className,\n )}\n >\n <FlatGlobeIcon className=\"w-full h-[90%]\" />\n </span>\n );\n\n return (\n <span\n className={cn(\n \"bg-white/20 flex h-4 w-6 overflow-hidden rounded-sm\",\n className,\n )}\n >\n {Flag && <Flag title={countryName} />}\n </span>\n );\n};\nFlagComponent.displayName = \"FlagComponent\";\n\nexport { PhoneInput, FlagComponent };\n","// import React from 'react'\n\n// export const Flag = () => {\n// return (\n// <div>Flag</div>\n// )\n// }\n\nimport type React from \"react\";\n\nconst FlatGlobeIcon: React.FC<React.SVGProps<SVGSVGElement>> = (props) => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 32 32\"\n fill=\"none\"\n {...props}\n >\n <rect width=\"32\" height=\"32\" fill=\"#60A5FA\" /> {/* Ocean color */}\n {/* Continents */}\n <path\n d=\"M3 10L7 8L10 9L13 8L16 10L19 9L22 11L25 10L28 12V15L26 17L28 19L27 22L29 24L27 26L24 25L21 26L18 24L15 25L12 23L9 24L6 22L4 23L2 21V18L4 16L3 13L5 11L3 10Z\"\n fill=\"#34D399\"\n />\n {/* Antarctica */}\n <rect x=\"2\" y=\"28\" width=\"28\" height=\"3\" fill=\"#D1D5DB\" />\n {/* Grid lines */}\n <path\n d=\"M0 16H32M8 0V32M16 0V32M24 0V32\"\n stroke=\"#2563EB\"\n strokeWidth=\"0.5\"\n vectorEffect=\"non-scaling-stroke\"\n />\n {/* Equator */}\n <path\n d=\"M0 16H32\"\n stroke=\"#2563EB\"\n strokeWidth=\"1\"\n vectorEffect=\"non-scaling-stroke\"\n />\n </svg>\n );\n};\n\nexport default FlatGlobeIcon;\n","import { inputContainerVariants } from \"../input\";\nimport { Searchable, SearchableDataType } from \"../searcheable\";\nimport { VariantProps } from \"class-variance-authority\";\nimport { countryData, getCountryDataMap } from \"./data\";\nimport { PopoverTrigger } from \"../popover\";\nimport { cn } from \"@/src/utils\";\nimport { FlagComponent } from \"../phone-input\";\nimport { Country as CountryCode } from \"react-phone-number-input\";\nimport { FormLabel } from \"../label/FormLabel\";\nimport { FormDescription } from \"../form/FormDescription\";\nimport { ErrorMessage } from \"../form/ErrorMessage\";\n\ntype CountryPropsStatus = VariantProps<typeof inputContainerVariants>[\"status\"];\n\ninterface CountryProps {\n modal?: boolean;\n hideSearch?: boolean;\n loading?: boolean;\n inputValue?: string;\n onInputValueChange?: (arg: string) => void;\n disabled?: boolean;\n placeholder?: string;\n value?: SearchableDataType;\n optionComponent?: (arg: SearchableDataType) => React.ReactNode;\n className?: string;\n containerClassName?: string;\n onChange: (value: SearchableDataType) => void;\n status?: CountryPropsStatus;\n label?: string;\n showAsterisk?: boolean;\n description?: React.ReactNode;\n error?: string;\n}\n\ninterface CountryTriggerProps\n extends VariantProps<typeof inputContainerVariants> {\n disabled?: boolean;\n placeholder?: string;\n value?: string;\n className?: string;\n}\n\nconst countryMap = getCountryDataMap();\n\nconst CountryTrigger = ({\n className,\n value,\n placeholder = \"\",\n status,\n disabled,\n}: CountryTriggerProps) => {\n return (\n <PopoverTrigger asChild disabled={disabled} id=\"country-dropdown\">\n <button\n disabled={disabled}\n className={cn(\n inputContainerVariants({ status }),\n \"[&>span]:justify-start [&>span]:items-center gap-2 flex w-full items-center justify-between goup\",\n value ? \"\" : \"text-[#79818C]\",\n className,\n )}\n >\n {value ? (\n <div className=\"flex gap-2 items-center\">\n <FlagComponent\n country={value as CountryCode}\n countryName={value}\n className=\"ml-1 !w-6 h-5\"\n />\n <span className=\"\"> {countryMap[value]}</span>\n </div>\n ) : (\n (placeholder ?? \"Select options...\")\n )}\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n className=\" data-[state=open]:goup-rotate-180\"\n >\n <path\n d=\"M16.5999 7.45825L11.1666 12.8916C10.5249 13.5333 9.4749 13.5333 8.83324 12.8916L3.3999 7.45825\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeMiterlimit=\"10\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </button>\n </PopoverTrigger>\n );\n};\n\nconst Country = ({\n hideSearch = true,\n showAsterisk,\n label,\n description,\n error,\n ...props\n}: CountryProps) => {\n const options = countryData?.map((country) => ({\n value: country?.internetCountryCode,\n label: country?.countryName,\n ...country,\n }));\n\n return (\n <div className=\"relative space-y-1\">\n <FormLabel showAsterisk={showAsterisk} error={error}>\n {label}\n </FormLabel>\n <Searchable\n options={options}\n hideSearch={hideSearch}\n optionComponent={(arg) => {\n return (\n <div className=\"w-full flex items-center gap-2\">\n <FlagComponent\n country={arg?.internetCountryCode}\n countryName={arg?.label}\n className=\"ml-2 !w-6 !h-5\"\n />\n <span className=\"flex-1 text-sm\">{arg?.label}</span>\n </div>\n );\n }}\n {...props}\n >\n <CountryTrigger\n value={props?.value?.value}\n status={props?.status}\n placeholder={props?.placeholder ?? \" Select Country\"}\n />\n </Searchable>\n <FormDescription className=\"text-gray-400 text-sm !font-normal\">\n {description}\n </FormDescription>\n <ErrorMessage error={error} />\n </div>\n );\n};\n\nexport { Country };\nexport type { CountryProps };\n\n//Todo -\n// dataSource - array of countries\n// availableCountries - countries to be filtered by countryCode\n","import { ErrorMessage } from \"../form/ErrorMessage\";\nimport { FormDescription } from \"../form/FormDescription\";\nimport { inputContainerVariants } from \"../input\";\nimport { FormLabel } from \"../label/FormLabel\";\nimport {\n Searchable,\n SearchableDataType,\n SearchableTrigger,\n} from \"../searcheable\";\nimport { VariantProps } from \"class-variance-authority\";\n\ntype SelectPropsStatus = VariantProps<typeof inputContainerVariants>[\"status\"];\n\ninterface SelectProps {\n modal?: boolean;\n hideSearch?: boolean;\n loading?: boolean;\n inputValue?: string;\n onInputValueChange?: (arg: string) => void;\n disabled?: boolean;\n placeholder?: string;\n value?: SearchableDataType;\n options: SearchableDataType[];\n optionComponent?: (arg: SearchableDataType) => React.ReactNode;\n className?: string;\n containerClassName?: string;\n onChange: (value: SearchableDataType) => void;\n status?: SelectPropsStatus;\n label?: string;\n showAsterisk?: boolean;\n description?: React.ReactNode;\n error?: string;\n id?: string;\n}\n\nconst Select = ({\n showAsterisk,\n label,\n description,\n error,\n hideSearch = true,\n status,\n ...props\n}: SelectProps) => {\n return (\n <div className=\"relative space-y-1\">\n <FormLabel showAsterisk={showAsterisk} error={error}>\n {label}\n </FormLabel>\n <Searchable\n hideSearch={hideSearch}\n {...props}\n containerClassName=\"h-full\"\n >\n <SearchableTrigger\n disabled={props?.disabled}\n placeholder={props?.placeholder ?? \"Select\"}\n status={status}\n value={props?.value?.label ?? props?.value?.value}\n className={props?.className}\n id={props?.id}\n />\n </Searchable>\n <FormDescription className=\"text-gray-400 text-sm !font-normal\">\n {description}\n </FormDescription>\n <ErrorMessage error={error} />\n </div>\n );\n};\n\nexport { Select };\nexport type { SelectProps };\n\n//Todo\n// onchange value\n","import OtpInput, { OTPInputProps as InputProps } from \"react-otp-input\";\nimport { cn } from \"@/src/utils\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { useMemo } from \"react\";\n\nconst otpInputVariants = cva(\n \"transition cursor-default placeholder:text-black dark:placeholder:text-white rounded-lg !h-14 !w-14 border aspect-square text-base font-semibold tracking-normal outline-none placeholder:text-sm placeholder:font-normal text-black focus:bg-white\",\n {\n variants: {\n status: {\n default:\n \"border-gray-300 dark:border-[#d4d4d4] focus:border-gray-400 focus-visible:!ring-offset-gray-200 focus:ring-offset-gray-200 !ring-gray-200 !focus-visible:ring-1 bg-white dark:!bg-transparent dark:focus-visible:!ring-0 dark:focus-within:!bg-transparent dark:text-white dark:focus-within:border-[#9299A2] dark:border-[#676767] dark:disabled:!border-[#9299A2]\",\n error:\n \"placeholder:text-red-600 bg-red-50 border-red-600 text-red-600 focus-within:bg-red-50 focus-within:border-red-600\",\n loading: \"placeholder:text-[#C4C4C4]\",\n },\n },\n defaultVariants: {\n status: \"default\",\n },\n },\n);\n\ntype DefailtInputProps = Omit<InputProps, \"renderInput\">;\n\nexport type OTPInputProps = DefailtInputProps &\n VariantProps<typeof otpInputVariants> & {};\n\nexport const OTPInput = ({\n numInputs = 4,\n inputStyle,\n containerStyle,\n placeholder = \"-\",\n status,\n ...props\n}: OTPInputProps) => {\n const placeholderValue = useMemo(() => {\n if (placeholder) return placeholder;\n\n const numInputArr = new Array<string>(numInputs).fill(\"\");\n const result = numInputArr.reduce((accumulator, currentValue) => {\n return (accumulator += currentValue);\n }, \"\");\n\n return result;\n }, [numInputs, placeholder]);\n\n return (\n <OtpInput\n numInputs={numInputs}\n placeholder={placeholderValue}\n containerStyle={cn(\"w-full\", containerStyle)}\n inputStyle={cn(otpInputVariants({ status }), inputStyle)}\n renderInput={(props) => <input {...props} />}\n {...props}\n />\n );\n};\n","import { useState, useEffect } from \"react\";\n\ninterface BannerTypes {\n type?: \"gray\" | \"info\" | \"warning\" | \"success\" | \"danger\";\n}\n\ninterface BannerProps extends BannerTypes {\n title?: React.ReactNode;\n description?: React.ReactNode;\n showIcon?: boolean;\n showCloseButton?: boolean;\n bottomNode?: React.ReactNode;\n sideNode?: React.ReactNode;\n open: boolean;\n onClose?: () => void;\n}\n\nconst Icon = ({ type }: BannerTypes) => {\n if (type === \"gray\") {\n return (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M10 0C4.49 0 0 4.49 0 10C0 15.51 4.49 20 10 20C15.51 20 20 15.51 20 10C20 4.49 15.51 0 10 0ZM14.78 7.7L9.11 13.37C8.97 13.51 8.78 13.59 8.58 13.59C8.38 13.59 8.19 13.51 8.05 13.37L5.22 10.54C4.93 10.25 4.93 9.77 5.22 9.48C5.51 9.19 5.99 9.19 6.28 9.48L8.58 11.78L13.72 6.64C14.01 6.35 14.49 6.35 14.78 6.64C15.07 6.93 15.07 7.4 14.78 7.7Z\"\n fill=\"#79818C\"\n />\n </svg>\n );\n } else if (type === \"info\") {\n return (\n <svg\n stroke=\"#70B6F6\"\n fill=\"#70B6F6\"\n stroke-width=\"0\"\n viewBox=\"0 0 16 16\"\n height=\"24\"\n width=\"24\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path d=\"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16m.93-9.412-1 4.705c-.07.34.029.533.304.533.194 0 .487-.07.686-.246l-.088.416c-.287.346-.92.598-1.465.598-.703 0-1.002-.422-.808-1.319l.738-3.468c.064-.293.006-.399-.287-.47l-.451-.081.082-.381 2.29-.287zM8 5.5a1 1 0 1 1 0-2 1 1 0 0 1 0 2\"></path>\n </svg>\n );\n } else if (type === \"warning\") {\n return (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M9.99984 1.66663C5.40817 1.66663 1.6665 5.40829 1.6665 9.99996C1.6665 14.5916 5.40817 18.3333 9.99984 18.3333C14.5915 18.3333 18.3332 14.5916 18.3332 9.99996C18.3332 5.40829 14.5915 1.66663 9.99984 1.66663ZM9.37484 6.66663C9.37484 6.32496 9.65817 6.04163 9.99984 6.04163C10.3415 6.04163 10.6248 6.32496 10.6248 6.66663V10.8333C10.6248 11.175 10.3415 11.4583 9.99984 11.4583C9.65817 11.4583 9.37484 11.175 9.37484 10.8333V6.66663ZM10.7665 13.65C10.7248 13.7583 10.6665 13.8416 10.5915 13.925C10.5082 14 10.4165 14.0583 10.3165 14.1C10.2165 14.1416 10.1082 14.1666 9.99984 14.1666C9.8915 14.1666 9.78317 14.1416 9.68317 14.1C9.58317 14.0583 9.4915 14 9.40817 13.925C9.33317 13.8416 9.27484 13.7583 9.23317 13.65C9.1915 13.55 9.1665 13.4416 9.1665 13.3333C9.1665 13.225 9.1915 13.1166 9.23317 13.0166C9.27484 12.9166 9.33317 12.825 9.40817 12.7416C9.4915 12.6666 9.58317 12.6083 9.68317 12.5666C9.88317 12.4833 10.1165 12.4833 10.3165 12.5666C10.4165 12.6083 10.5082 12.6666 10.5915 12.7416C10.6665 12.825 10.7248 12.9166 10.7665 13.0166C10.8082 13.1166 10.8332 13.225 10.8332 13.3333C10.8332 13.4416 10.8082 13.55 10.7665 13.65Z\"\n fill=\"#FFC700\"\n />\n </svg>\n );\n } else if (type === \"success\") {\n return (\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M12 2C6.49 2 2 6.49 2 12C2 17.51 6.49 22 12 22C17.51 22 22 17.51 22 12C22 6.49 17.51 2 12 2ZM16.78 9.7L11.11 15.37C10.97 15.51 10.78 15.59 10.58 15.59C10.38 15.59 10.19 15.51 10.05 15.37L7.22 12.54C6.93 12.25 6.93 11.77 7.22 11.48C7.51 11.19 7.99 11.19 8.28 11.48L10.58 13.78L15.72 8.64C16.01 8.35 16.49 8.35 16.78 8.64C17.07 8.93 17.07 9.4 16.78 9.7Z\"\n fill=\"#00D488\"\n />\n </svg>\n );\n } else {\n return (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M9.99984 1.66663C5.40817 1.66663 1.6665 5.40829 1.6665 9.99996C1.6665 14.5916 5.40817 18.3333 9.99984 18.3333C14.5915 18.3333 18.3332 14.5916 18.3332 9.99996C18.3332 5.40829 14.5915 1.66663 9.99984 1.66663ZM9.37484 6.66663C9.37484 6.32496 9.65817 6.04163 9.99984 6.04163C10.3415 6.04163 10.6248 6.32496 10.6248 6.66663V10.8333C10.6248 11.175 10.3415 11.4583 9.99984 11.4583C9.65817 11.4583 9.37484 11.175 9.37484 10.8333V6.66663ZM10.7665 13.65C10.7248 13.7583 10.6665 13.8416 10.5915 13.925C10.5082 14 10.4165 14.0583 10.3165 14.1C10.2165 14.1416 10.1082 14.1666 9.99984 14.1666C9.8915 14.1666 9.78317 14.1416 9.68317 14.1C9.58317 14.0583 9.4915 14 9.40817 13.925C9.33317 13.8416 9.27484 13.7583 9.23317 13.65C9.1915 13.55 9.1665 13.4416 9.1665 13.3333C9.1665 13.225 9.1915 13.1166 9.23317 13.0166C9.27484 12.9166 9.33317 12.825 9.40817 12.7416C9.4915 12.6666 9.58317 12.6083 9.68317 12.5666C9.88317 12.4833 10.1165 12.4833 10.3165 12.5666C10.4165 12.6083 10.5082 12.6666 10.5915 12.7416C10.6665 12.825 10.7248 12.9166 10.7665 13.0166C10.8082 13.1166 10.8332 13.225 10.8332 13.3333C10.8332 13.4416 10.8082 13.55 10.7665 13.65Z\"\n fill=\"#F04248\"\n />\n </svg>\n );\n }\n};\n\nexport const Banner = ({\n type = \"info\",\n title,\n description,\n open,\n showCloseButton,\n bottomNode,\n sideNode,\n onClose,\n showIcon = true,\n}: BannerProps) => {\n const [isOpen, setIsOpen] = useState<boolean>(open);\n\n useEffect(() => {\n setIsOpen(open);\n }, [open]);\n\n let bgColor = \"\";\n let stripeColor = \"\";\n switch (type) {\n case \"gray\":\n bgColor = \"#eeeef0\";\n stripeColor = \"#79818c\";\n break;\n case \"info\":\n bgColor = \"#ebf5fd\";\n stripeColor = \"#70B6F6\";\n break;\n case \"warning\":\n bgColor = \"#fff8df\";\n stripeColor = \"#ffc700\";\n break;\n case \"success\":\n bgColor = \"#e0f9f0\";\n stripeColor = \"#49e0aa\";\n break;\n case \"danger\":\n bgColor = \"#fde8e9\";\n stripeColor = \"#f3777c\";\n break;\n default:\n bgColor = \"#eeeef0\";\n stripeColor = \"#79818c\";\n break;\n }\n\n function handleClose() {\n setIsOpen(false);\n if (onClose) {\n onClose();\n }\n }\n\n if (!isOpen) {\n return null;\n }\n\n return (\n <div\n className=\"w-full shadow-lg transform flex items-center rounded-md\"\n style={{\n background: bgColor || \"#ebf5fd\",\n }}\n >\n <div\n className=\"flex-none absolute rounded-l-[2px] rounded-l-4px h-[4px] w-full top-0\"\n style={{\n background: stripeColor || \"#70B6F6\",\n }}\n />\n\n <div className=\"w-full gap-3 h-full flex flex-row justify-between px-4 md:px-4 py-3 md:py-4\">\n <div className=\"flex flex-row gap-2.5 items-start w-full h-full\">\n {showIcon && (\n <div className=\"h-full flex justify-end\">\n <Icon type={type} />\n </div>\n )}\n\n <div className=\"w-full gap-3 h-full flex flex-col md:flex-row items-start justify-between\">\n <div className=\"flex-1 gap-3 h-full flex flex-col items-start justify-between\">\n {(title || description) && (\n <div>\n {title && (\n <div className=\"text-sm font-bold text-[#191919]\">\n {title}\n </div>\n )}\n {description && (\n <div className=\"text-sm font-normal text-[#5D5D5D] mt-1\">\n {description}\n </div>\n )}\n </div>\n )}\n\n {bottomNode}\n </div>\n {sideNode}\n </div>\n </div>\n\n {showCloseButton && (\n <div className=\"w-1/10 h-full flex flex-col justify-start items-center\">\n <button onClick={handleClose}>\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M3.3335 3.33337L12.6662 12.6661\"\n stroke=\"#191919\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M3.33429 12.6661L12.667 3.33337\"\n stroke=\"#191919\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </button>\n </div>\n )}\n </div>\n </div>\n );\n};\n","import { useState } from \"react\";\nimport { Copy, CheckIcon } from \"lucide-react\";\nimport { motion, AnimatePresence } from \"framer-motion\";\nimport { cn } from \"@/src/utils\";\nimport { TextOverflow } from \"../text-overflow\";\n\ninterface CopyableLabelProps {\n text: string;\n textToCopy?: string; //this is coppied to the clipboard if passed as a prop instead of the text prop passed else defaults to the text prop\n onCopy?: () => void;\n iconsPosition?: \"left\" | \"right\";\n clampText?: boolean;\n textClassName?: string;\n clampMode?: \"truncate\" | \"wrap\";\n isLink?: boolean;\n}\n\nconst CopyableLabel: React.FC<CopyableLabelProps> = ({\n text,\n textToCopy,\n onCopy,\n iconsPosition = \"right\",\n clampText = true,\n clampMode = \"truncate\",\n isLink = false,\n textClassName,\n}) => {\n const [copied, setCopied] = useState(false);\n\n const copyToClipboard = () => {\n navigator.clipboard.writeText(textToCopy ?? text).then(() => {\n setCopied(true);\n onCopy?.();\n setTimeout(() => setCopied(false), 2000);\n });\n };\n\n const Icon = copied ? CheckIcon : Copy;\n\n return (\n <div className=\"flex items-center space-x-2 cursor-pointer text-[#717171] bg-gray-100 w-fit max-w-full rounded-md p-1 px-2\">\n {iconsPosition === \"left\" && (\n <AnimatedIcon Icon={Icon} onClick={copyToClipboard} copied={copied} />\n )}\n <TextOverflow\n as={isLink ? \"a\" : \"span\"}\n mode={!clampText ? \"overflow\" : clampMode}\n className={cn({ underline: isLink }, textClassName)}\n href={isLink ? text : undefined}\n >\n {text}\n </TextOverflow>\n\n {iconsPosition === \"right\" && (\n <AnimatedIcon Icon={Icon} onClick={copyToClipboard} copied={copied} />\n )}\n </div>\n );\n};\n\nconst AnimatedIcon: React.FC<{\n Icon: React.ElementType;\n onClick: () => void;\n copied: boolean;\n}> = ({ Icon, onClick, copied }) => (\n <AnimatePresence mode=\"wait\">\n <motion.div\n key={copied ? \"check\" : \"copy\"}\n initial={{ opacity: 0, scale: 0.8 }}\n animate={{ opacity: 1, scale: 1 }}\n exit={{ opacity: 0, scale: 0.8 }}\n transition={{ duration: 0.2 }}\n onClick={onClick}\n >\n <Icon\n className={`w-5 h-5 ${copied ? \"text-green-500\" : \"text-gray-500 hover:text-gray-700 transition\"}`}\n />\n </motion.div>\n </AnimatePresence>\n);\n\nexport { CopyableLabel };\n","import { cn } from \"@/src/utils\";\nimport React from \"react\";\n\nexport interface TextOverflowProps extends React.HTMLAttributes<HTMLElement> {\n children: React.ReactNode;\n mode?: \"wrap\" | \"truncate\" | \"overflow\";\n as?: React.ElementType;\n href?: string;\n}\n/**\n * TextOverflow is a React component that controls how text overflows its container.\n *\n * Props:\n * - children: ReactNode - The content to display.\n * - mode: \"truncate\" | \"wrap\" | \"overflow\" (default: \"truncate\")\n * - \"truncate\": Single line, truncated with ellipsis.\n * - \"wrap\": Allows text to wrap onto multiple lines.\n * - \"overflow\": No special overflow handling.\n * - as: React.ElementType - The HTML element or React component to render as the container (default: \"div\").\n * - href: string (optional) - If provided and 'as' is an anchor, sets the link target to \"_blank\".\n * - className: string (optional) - Additional CSS classes for the container.\n * - ...rest: Other HTML attributes passed to the container.\n */\nexport const TextOverflow = ({\n children,\n mode = \"truncate\",\n className,\n as: Component = \"div\",\n ...rest\n}: TextOverflowProps) => {\n return (\n <Component\n className={cn(\n {\n \"text-ellipsis overflow-hidden whitespace-nowrap\":\n mode === \"truncate\",\n \"whitespace-normal break-words\": mode === \"wrap\",\n \"\": mode === \"overflow\",\n },\n className,\n )}\n target={rest?.href ? \"_blank\" : undefined}\n {...rest}\n >\n {children}\n </Component>\n );\n};\n","import React, { ChangeEvent, useEffect, useState } from \"react\";\nimport { BaseInnerInputProps, Input } from \"../input\";\nimport { cn } from \"@/src/utils\";\nimport { Search } from \"lucide-react\";\n\ntype DebouncedInputProps = {\n value?: string;\n\n onChange: (e: string) => void;\n debounce?: number;\n addon?: React.ReactNode;\n} & Omit<BaseInnerInputProps, \"onChange\" | \"size\">;\n\nexport const DebouncedInput = ({\n value: initialValue,\n onChange,\n debounce = 500,\n addon,\n ...props\n}: DebouncedInputProps) => {\n const [value, setValue] = useState<string>(initialValue ?? \"\");\n\n const handleInputChange = (event: ChangeEvent<HTMLInputElement>) =>\n setValue(event.target.value);\n\n useEffect(() => {\n if (!initialValue) return;\n setValue(initialValue);\n }, [initialValue]);\n\n useEffect(() => {\n const timeout = setTimeout(() => {\n onChange(value);\n }, debounce);\n\n return () => clearTimeout(timeout);\n }, [value, debounce, onChange]);\n\n return (\n <Input\n leftNode={\n (addon as React.ReactElement) ?? (\n <Search className=\" w-4 h-4 text-gray-400\" />\n )\n }\n sideNodeClassName=\"bg-transparent !pr-0 !w-4 border-0 !min-w-[40px]\"\n {...props}\n className={cn(\n \"!pl-0 py-1 border-[.5px] border-[#E9EBF8] rounded-xl text-sm w-full h-8 focus:outline-none focus:placeholder:hidden focus:!ring-2 !focus:ring-primary-main bg-[#F5F8FF] focus-within:!bg-transparent placeholder:text-xs\",\n props?.className,\n )}\n onChange={handleInputChange}\n value={value}\n />\n );\n};\n","import { useEffect } from \"react\";\nimport { X } from \"lucide-react\";\n\ntype Props = {\n environment: \"staging\" | \"sandbox\" | \"production\";\n branch: string;\n version: string;\n deployTime: string;\n onClose: () => void;\n showBanner: boolean;\n initDefault: () => void;\n removeFromStorage: () => void;\n syncLocalStorageToState: () => void;\n};\nexport const DevBanner = (props: Props) => {\n const {\n environment,\n branch,\n version,\n deployTime,\n showBanner,\n onClose,\n initDefault,\n removeFromStorage,\n syncLocalStorageToState,\n } = props;\n\n const currentEnv = environment || process.env.NEXT_PUBLIC_NODE_ENV;\n\n // Early return must happen before any hooks\n if (currentEnv !== \"staging\" && currentEnv !== \"sandbox\") {\n return null;\n }\n\n useEffect(() => {\n // Sync localstorage value to showBanner state\n syncLocalStorageToState();\n }, [syncLocalStorageToState]);\n\n useEffect(() => {\n let interval: NodeJS.Timeout;\n\n if (currentEnv === \"staging\" || currentEnv === \"sandbox\") {\n interval = setInterval(\n () => {\n removeFromStorage();\n initDefault();\n },\n 5 * 60 * 1000, // 5 minutes in milliseconds\n );\n }\n\n return () => {\n if (interval) {\n clearInterval(interval);\n }\n };\n }, [\n showBanner,\n environment,\n onClose,\n removeFromStorage,\n initDefault,\n currentEnv,\n ]);\n\n if (!showBanner) return null;\n\n return (\n <div className=\"w-fit p-4 border shadow-md bg-white rounded-md z-[99999] absolute top-2 right-2 min-w-96\">\n <button onClick={onClose} className=\"absolute top-2 right-2\">\n <X />\n </button>\n <div className=\"space-y-2 text-sm\">\n <div className=\"flex gap-2\">\n <span className=\"font-medium\">Environment:</span>\n <span className=\"text-blue-600 capitalize\">{currentEnv}</span>\n </div>\n <div className=\"flex gap-2\">\n <span className=\"font-medium\">Branch:</span>\n <span className=\"text-green-600 capitalize\">\n {branch || process.env.NEXT_PUBLIC_DEPLOY_BRANCH}\n </span>\n </div>\n <div className=\"flex gap-2\">\n <span className=\"font-medium\">Version:</span>\n <span className=\"text-purple-600\">\n {version || process.env.NEXT_PUBLIC_DEPLOY_VERSION}\n </span>\n </div>\n <div className=\"flex gap-2\">\n <span className=\"font-medium\">Deploy Time:</span>\n <span className=\"text-orange-600\">\n {deployTime || process.env.NEXT_PUBLIC_DEPLOY_TIME}\n </span>\n </div>\n </div>\n </div>\n );\n};\n","// import React from 'react'\n\n// export const Drawer = () => {\n// return (\n// <div>Drawer</div>\n// )\n// }\n\n\"use client\";\n\nimport * as React from \"react\";\nimport { Drawer as DrawerPrimitive } from \"vaul\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\n\nimport { cn } from \"@/src/utils\";\nimport { DialogCloseProps } from \"@radix-ui/react-dialog\";\nimport { CloseIcon } from \"./icon/CloseIcon\";\nimport { useWindowSize } from \"@/src/hooks/useWindowSize\";\n\ntype DrawerRootType = React.ComponentProps<typeof DrawerPrimitive.Root> & {\n id?: string;\n};\n\nconst DrawerRoot = ({\n shouldScaleBackground = true,\n ...props\n}: DrawerRootType) => (\n <DrawerPrimitive.Root\n direction=\"right\"\n shouldScaleBackground={shouldScaleBackground}\n {...props}\n />\n);\n\nDrawerRoot.displayName = \"Drawer\";\n\nconst DrawerTrigger = DrawerPrimitive.Trigger;\n\nconst DrawerClose: React.ForwardRefExoticComponent<\n DialogCloseProps & React.RefAttributes<HTMLButtonElement>\n> = DrawerPrimitive.Close;\n\nconst DrawerPortal = DrawerPrimitive.Portal;\n\nconst DrawerOverlay = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Overlay>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n <DrawerPrimitive.Overlay\n className={cn(\n \"fixed inset-0 z-40 bg-black/75 !m-0 !p-0 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0\",\n className,\n )}\n {...props}\n ref={ref}\n />\n));\n\nDrawerOverlay.displayName = DrawerPrimitive.Overlay.displayName;\n\nconst DrawerVariants = cva(\n \"fixed focus-visible:outline-0 z-50 gap-4 bg-white shadow-lg dark:bg-[#2B2B2B] dark:text-white transition ease-in-out data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:duration-300 data-[state=open]:duration-500 dark:border-none !select-text\",\n {\n variants: {\n side: {\n top: \"inset-x-0 top-0 border-b data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top rounded-b-lg\",\n bottom:\n \"inset-x-0 bottom-0 border-t data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom rounded-t-lg\",\n left: \"inset-y-0 left-0 h-full w-3/4 border-r data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left sm:max-w-[512px] \",\n right:\n \"inset-y-0 right-0 h-full w-3/4 border-l data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right sm:max-w-[512px]\",\n },\n },\n defaultVariants: {\n side: \"right\",\n },\n },\n);\n\ninterface SheetContentProps\n extends React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Content>,\n VariantProps<typeof DrawerVariants> {}\n\nconst DrawerContent = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Content>,\n SheetContentProps & {\n hideCloseButton?: boolean;\n }\n>(\n (\n { side = \"right\", hideCloseButton, className, children, id, ...props },\n ref,\n ) => (\n <DrawerPortal>\n <DrawerOverlay />\n <DrawerPrimitive.Content\n ref={ref}\n className={cn(DrawerVariants({ side }), className)}\n {...props}\n >\n <button className=\"bg-gray-300 block md:!hidden mx-auto mt-4 md:!mt-0 h-1.5 w-[80px] rounded-full opacity-70 transition-opacity hover:opacity-100 relative\" />\n {children}\n {!hideCloseButton && (\n <DrawerPrimitive.Close\n id={`${id}-close-button`}\n className=\"absolute right-2 top-3 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-secondary\"\n >\n <CloseIcon />\n\n <span className=\"sr-only\">Close</span>\n </DrawerPrimitive.Close>\n )}\n </DrawerPrimitive.Content>\n </DrawerPortal>\n ),\n);\n\nDrawerContent.displayName = DrawerPrimitive.Content.displayName;\n\nconst DrawerHeader = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\n \"text-lg flex flex-col border-b border-b-gray-200 space-y-1 text-left w-full p-3\",\n className,\n )}\n {...props}\n />\n);\n\nDrawerHeader.displayName = \"DrawerHeader\";\n\nconst DrawerFooter = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\n \"flex flex-col-reverse sm:flex-row m-auto right-0 left-0 p-3 sm:space-x-2 border-t border-t-[#EDEDED] dark:border-t-[#242424] w-full\",\n className,\n )}\n {...props}\n />\n);\n\nDrawerFooter.displayName = \"DrawerFooter\";\n\nconst DrawerTitle = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Title>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Title>\n>(({ className, ...props }, ref) => (\n <DrawerPrimitive.Title\n ref={ref}\n className={cn(\n \"text-xl font-semibold text-[#191919] dark:text-white\",\n className,\n )}\n {...props}\n />\n));\n\nDrawerTitle.displayName = DrawerPrimitive.Title.displayName;\n\nconst DrawerDescription = React.forwardRef<\n React.ElementRef<typeof DrawerPrimitive.Description>,\n React.ComponentPropsWithoutRef<typeof DrawerPrimitive.Description>\n>(({ className, ...props }, ref) => (\n <DrawerPrimitive.Description\n ref={ref}\n className={cn(\"text-xs text-[#5d5c5c] dark:text-white\", className)}\n {...props}\n />\n));\n\nDrawerDescription.displayName = DrawerPrimitive.Description.displayName;\n\nexport type DrawerPropsType = {\n trigger?: React.ReactNode;\n children: React.ReactNode;\n title?: React.ReactNode;\n description?: React.ReactNode;\n footer?: React.ReactNode;\n hideCloseButton?: boolean;\n contentClassName?: string;\n drawerContentClassName?: string;\n headerClassName?: string;\n titleClassName?: string;\n descriptionClassName?: string;\n footerClassName?: string;\n asChild?: boolean;\n onOpenAutoFocus?: (e: Event) => void;\n onCloseAutoFocus?: (e: Event) => void;\n};\n\nconst Drawer = ({\n trigger = undefined,\n children,\n open = undefined,\n onOpenChange = undefined,\n hideCloseButton,\n footer,\n title,\n description,\n contentClassName,\n headerClassName,\n titleClassName,\n descriptionClassName,\n footerClassName,\n asChild = true,\n onOpenAutoFocus,\n drawerContentClassName,\n onCloseAutoFocus,\n id = \"drawer\",\n}: Omit<DrawerRootType, \"value\"> & DrawerPropsType) => {\n const { width } = useWindowSize();\n const direction = width < 768 ? \"bottom\" : \"right\";\n\n return (\n <DrawerRoot open={open} onOpenChange={onOpenChange} direction={direction}>\n <DrawerTrigger\n className=\"cursor-pointer\"\n asChild={asChild}\n id={`${id}-open-trigger`}\n >\n {trigger}\n </DrawerTrigger>\n <DrawerContent\n className={cn(\n \"flex flex-col gap-0 justify-start items-start max-h-[90vh] md:max-h-full w-full !max-w-md\",\n contentClassName,\n )}\n side={direction}\n hideCloseButton={hideCloseButton}\n onOpenAutoFocus={onOpenAutoFocus}\n onCloseAutoFocus={onCloseAutoFocus}\n id={`${id}-content`}\n >\n {title || description ? (\n <DrawerHeader className={headerClassName} id={`${id}-header`}>\n {title && (\n <DrawerTitle className={titleClassName} id={`${id}-title`}>\n {title}\n </DrawerTitle>\n )}\n {description && (\n <DrawerDescription\n id={`${id}-description`}\n className={descriptionClassName}\n >\n {description}\n </DrawerDescription>\n )}\n </DrawerHeader>\n ) : (\n <></>\n )}\n\n <div\n className={cn(\n \"flex w-full overflow-y-auto flex-col justify-start items-start p-4 flex-1 h-[30px]\",\n drawerContentClassName,\n )}\n >\n {children}\n </div>\n\n {footer && (\n <DrawerFooter className={footerClassName}>{footer}</DrawerFooter>\n )}\n </DrawerContent>\n </DrawerRoot>\n );\n};\n\nexport { Drawer, DrawerRoot, DrawerClose };\n","export const CloseIcon = () => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n className=\"lucide lucide-x\"\n >\n <path d=\"M18 6 6 18\" />\n <path d=\"m6 6 12 12\" />\n </svg>\n );\n};\n","import { useState, useEffect } from \"react\";\n\ntype WindowSize = {\n width: number;\n height: number;\n};\n\nexport function useWindowSize(): WindowSize {\n const [windowSize, setWindowSize] = useState<WindowSize>({\n width: 100,\n height: 100,\n });\n\n useEffect(() => {\n function handleResize() {\n setWindowSize({\n width: window.innerWidth,\n height: window.innerHeight,\n });\n }\n\n window.addEventListener(\"resize\", handleResize);\n\n handleResize();\n\n return () => window.removeEventListener(\"resize\", handleResize);\n }, []);\n\n return windowSize;\n}\n","export const Check = () => {\n return (\n <svg\n stroke=\"currentColor\"\n fill=\"currentColor\"\n strokeWidth=\"0\"\n viewBox=\"0 0 20 20\"\n aria-hidden=\"true\"\n className=\"h-5 w-5\"\n height=\"1em\"\n width=\"1em\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fillRule=\"evenodd\"\n d=\"M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z\"\n clipRule=\"evenodd\"\n ></path>\n </svg>\n );\n};\n","import { SVGProps } from \"react\";\n\nexport const EnglishFlag = (props: SVGProps<SVGSVGElement>) => {\n return (\n <svg\n viewBox=\"0 0 60 30\"\n className=\"w-full max-w-md h-auto\"\n aria-label=\"Union Jack - Flag of the United Kingdom\"\n {...props}\n >\n {/* Blue background */}\n <rect width=\"60\" height=\"30\" fill=\"#00247D\" />\n\n {/* White diagonal crosses */}\n <path d=\"M0,0 L60,30 M60,0 L0,30\" stroke=\"#FFFFFF\" strokeWidth=\"6\" />\n\n {/* Red diagonal crosses */}\n <path d=\"M0,0 L60,30 M60,0 L0,30\" stroke=\"#CF142B\" strokeWidth=\"4\" />\n\n {/* White cross */}\n <path d=\"M30,0 L30,30 M0,15 L60,15\" stroke=\"#FFFFFF\" strokeWidth=\"10\" />\n\n {/* Red cross */}\n <path d=\"M30,0 L30,30 M0,15 L60,15\" stroke=\"#CF142B\" strokeWidth=\"6\" />\n </svg>\n );\n};\n","import { SVGProps } from \"react\";\n\nexport const FrenchFlag = (props: SVGProps<SVGSVGElement>) => {\n return (\n <svg\n viewBox=\"0 0 60 40\"\n className=\"w-full max-w-md h-auto\"\n aria-label=\"Tricolore - Flag of France\"\n {...props}\n >\n {/* Blue stripe */}\n <rect x=\"0\" y=\"0\" width=\"20\" height=\"40\" fill=\"#002395\" />\n\n {/* White stripe */}\n <rect x=\"20\" y=\"0\" width=\"20\" height=\"40\" fill=\"#FFFFFF\" />\n\n {/* Red stripe */}\n <rect x=\"40\" y=\"0\" width=\"20\" height=\"40\" fill=\"#ED2939\" />\n </svg>\n );\n};\n","export const UpDownIcon = () => {\n return (\n <svg\n width=\"20\"\n height=\"18\"\n viewBox=\"0 0 8 18\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M5.50257 12.9395L3.68439 14.7576L1.86621 12.9395\"\n stroke=\"currentColor\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M5.50257 5.06055L3.68439 3.24237L1.86621 5.06055\"\n stroke=\"currentColor\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n};\n","import { cn } from \"@/src/utils\";\nimport { PopoverContent, PopoverRoot, PopoverTrigger } from \"../popover\";\nimport { Check } from \"./icons/Check\";\nimport { EnglishFlag } from \"./icons/EnglishFlag\";\nimport { FrenchFlag } from \"./icons/FrenchFlag\";\nimport { UpDownIcon } from \"./icons/UpDownIcon\";\nimport { PopoverClose } from \"@radix-ui/react-popover\";\n\nconst localeListOptons = [\n {\n key: \"en\",\n label: \"English\",\n },\n {\n key: \"fr\",\n label: \"French\",\n },\n];\n\ntype LocaleOption = {\n key: string;\n label: string;\n};\n\nconst LocaleIcon = ({ locale }: { locale?: string }) => {\n if (locale === \"fr\") return <FrenchFlag width={10} />;\n return <EnglishFlag width={10} />;\n};\n\nconst LocaleTrigger = ({ locale }: { locale?: string }) => {\n return (\n <div className=\"px-2 py-1 \">\n <div className=\"flex items-center gap-2.5\">\n <LocaleIcon locale={locale} />{\" \"}\n <span className=\"uppercase\">{locale}</span>\n <UpDownIcon />\n </div>\n </div>\n );\n};\n\nexport const LocaleSelector = ({\n locale = \"en\",\n onChange,\n locales = localeListOptons,\n}: {\n locale?: string;\n onChange?: (locale: string) => void;\n locales?: LocaleOption[];\n}) => {\n return (\n <PopoverRoot>\n <div className=\"flex items-center gap-2 px-2 py-1 rounded-lg shadow border-[0.5px] border-gray-50/50 text-current bg-white/10 \">\n <PopoverTrigger\n className={\"!p-0 !bg-transparent \"}\n id=\"locale_select_dropdown\"\n >\n <LocaleTrigger locale={locale} />\n </PopoverTrigger>\n </div>\n <PopoverContent\n side=\"bottom\"\n className=\"p-0 max-w-max rounded-md overflow-hidden mx-auto mt-2\"\n >\n <div>\n {locales?.map((_locale) => (\n <PopoverClose\n type=\"button\"\n id={`locale_option_${_locale?.key}`}\n key={_locale?.key}\n className={cn(\n \"flex items-center gap-3 px-3 py-1 text-sm hover:bg-blue-50 w-full transition-all\",\n { \"bg-blue-100\": locale && locale === _locale?.key },\n )}\n onClick={() => onChange?.(_locale?.key)}\n >\n {_locale?.label} {locale && locale === _locale?.key && <Check />}\n </PopoverClose>\n ))}\n </div>\n </PopoverContent>\n </PopoverRoot>\n );\n};\n","import { useMemo, useRef, useState } from \"react\";\nimport { BusinessBar } from \"./business/BusinessBar\";\nimport { SidebarProps } from \"./utils/types\";\nimport { NavItems } from \"./NavItems\";\nimport { cn } from \"@/src/utils\";\nimport { X } from \"lucide-react\";\nimport { OpenSidebarIcon } from \"./components/OpenSidebarIcon\";\nimport { ClosedSidebarIcon } from \"./components/ClosedSidebarIcon\";\nimport { SidebarToggle } from \"./components/SidebarToggle\";\n\nexport const Sidebar = ({\n isSidebarCollapsed,\n onToggleSideBar,\n isMobile,\n links,\n businessProps,\n currentPath,\n onNavigate,\n appConfig,\n collapseType: propCollapseType,\n onLogoutClick,\n openSidebarIcon = <OpenSidebarIcon />,\n closedSidebarIcon = <ClosedSidebarIcon />,\n nodeAfterSideBarLogo,\n}: SidebarProps) => {\n const collapseType = useMemo(() => {\n if (isMobile) return \"hidden\";\n\n return propCollapseType || (isMobile ? \"hidden\" : \"icons\");\n }, [isMobile, propCollapseType]);\n\n const [isBusinessShown, setIsBusinessShown] = useState(false);\n const isIconsOnly = collapseType === \"icons\" && isSidebarCollapsed;\n const sideBarRef = useRef(null);\n const {\n businessList,\n activeBusiness,\n toggleAddBusinessDrawer,\n handleSetActiveBusiness,\n } = businessProps;\n\n const toggleShowBusiness = (isBusinessShown: boolean) =>\n setIsBusinessShown(isBusinessShown);\n\n const handleSwitchBusiness = (clientId: string) => {\n handleSetActiveBusiness?.(clientId);\n toggleShowBusiness(false);\n };\n\n const sideBarLogo = useMemo(() => {\n if (collapseType === \"hidden\") {\n return openSidebarIcon;\n }\n\n return isSidebarCollapsed ? closedSidebarIcon : openSidebarIcon;\n }, [isSidebarCollapsed, openSidebarIcon, closedSidebarIcon, collapseType]);\n\n const showBackdrop =\n isMobile && collapseType === \"hidden\" && isSidebarCollapsed;\n\n return (\n <>\n {showBackdrop && (\n <div\n className=\"fixed inset-0 z-40 bg-black bg-opacity-40 transition-all animate-in fade-in-15\"\n onClick={() => onToggleSideBar(false)}\n />\n )}\n\n <div\n className={cn(\"relative flex flex-row h-full\", {\n \"fixed inset-0 z-50 pointer-events-none\": showBackdrop,\n })}\n >\n <div className=\"absolute -right-[22px] top-0 z-20\">\n {collapseType === \"icons\" && (\n <SidebarToggle\n isSidebarCollapsed={isSidebarCollapsed}\n onToggleSideBar={onToggleSideBar}\n />\n )}\n </div>\n\n <aside\n id=\"sidebar_menu\"\n ref={sideBarRef}\n className={cn(\n \"relative pt-4 h-full max-h-screen bg-[#FBFBFB] overflow-hidden flex-col flex transition-all duration-300 w-64 gap-y-5\",\n {\n \"!fixed\": collapseType === \"hidden\",\n \"w-[311px]\": isSidebarCollapsed && collapseType !== \"icons\",\n \"w-[75px]\": isSidebarCollapsed && collapseType === \"icons\",\n \"w-[270px]\": !isSidebarCollapsed && collapseType === \"icons\",\n \"w-0 lg:w-0 pointer-events-none\":\n !isSidebarCollapsed && collapseType === \"hidden\",\n \"pointer-events-auto\":\n isSidebarCollapsed && collapseType === \"hidden\",\n \"left-0 top-0\": isMobile && collapseType === \"hidden\",\n \"-translate-x-full\":\n !isSidebarCollapsed && isMobile && collapseType !== \"hidden\",\n \"translate-x-0\":\n isSidebarCollapsed && isMobile && collapseType === \"hidden\",\n },\n )}\n >\n <div\n className={cn(\"flex items-center py-2 justify-center w-full\", {\n \"justify-between px-2\": isMobile,\n })}\n >\n <section\n className={cn({\n \"ml-2\": isMobile,\n \"-ml-16\": !isSidebarCollapsed,\n })}\n >\n {sideBarLogo}\n </section>\n\n {collapseType === \"hidden\" && (\n <div\n onClick={() => onToggleSideBar(false)}\n className=\"flex items-center gap-2 text-3xl cursor-pointer mr-5\"\n >\n <X size={24} className=\"text-black hover:opacity-60\" />\n </div>\n )}\n </div>\n\n {nodeAfterSideBarLogo}\n\n <div className=\"flex-1 overflow-y-auto px-0 h-full max-h-[calc(100vh-200px)]\">\n <NavItems\n isIconsOnly={isIconsOnly}\n collapseType={collapseType}\n currentPath={currentPath}\n isSidebarCollapsed={isSidebarCollapsed}\n links={links}\n onNavigate={onNavigate}\n onToggleSideBar={onToggleSideBar}\n appConfig={appConfig}\n isMobile={isMobile}\n />\n </div>\n\n <div className=\"absolute bottom-5 w-full\">\n <BusinessBar\n activeBusiness={activeBusiness}\n handleSwitchBusiness={handleSwitchBusiness}\n isBusinessShown={isBusinessShown}\n toggleAddBusinessDrawer={toggleAddBusinessDrawer}\n toggleShowBusiness={toggleShowBusiness}\n businesses={businessList || []}\n iconOnly={collapseType === \"icons\" ? isSidebarCollapsed : false}\n onLogoutClick={onLogoutClick}\n isMobile={isMobile}\n onToggleSideBar={onToggleSideBar}\n collapseType={collapseType}\n />\n </div>\n </aside>\n </div>\n </>\n );\n};\n","import { AnimatePresence, motion } from \"framer-motion\";\nimport { ChangeEvent, useMemo, useState } from \"react\";\nimport { HiCheck } from \"react-icons/hi\";\nimport { FiLogOut } from \"react-icons/fi\";\nimport { BsPlus } from \"react-icons/bs\";\nimport { cn } from \"@/src/utils\";\nimport { BusinessType } from \"@/src/utils/types\";\nimport { Input } from \"@/src/components/input\";\nimport { BusinessBarTrigger } from \"./Trigger\";\nimport { ChevronUp } from \"lucide-react\";\nimport { SidebarProps } from \"../../utils/types\";\nimport { ActiveBusinessIcon } from \"./ActiveBusinessIcon\";\n\ntype BusinessBarProps = {\n activeBusiness: BusinessType;\n businesses?: BusinessType[];\n toggleAddBusinessDrawer: () => void;\n handleSwitchBusiness: (_: string) => void;\n onLogoutClick: () => void;\n toggleShowBusiness: (_: boolean) => void;\n} & Pick<SidebarProps, \"onToggleSideBar\" | \"isMobile\" | \"collapseType\">;\n\nconst businessPopUpVariants = {\n hidden: { y: \"-12px\", opacity: 0 },\n visible: {\n y: \"0\",\n opacity: 1,\n transition: {\n type: \"spring\",\n damping: 25,\n stiffness: 500,\n },\n },\n exit: {\n y: \"-12px\",\n opacity: 0,\n transition: {\n type: \"spring\",\n damping: 25,\n stiffness: 500,\n },\n },\n};\n\nexport const BusinessBarContent = ({\n activeBusiness,\n toggleAddBusinessDrawer,\n businesses = [],\n handleSwitchBusiness,\n onLogoutClick,\n onToggleSideBar,\n toggleShowBusiness,\n isMobile,\n collapseType,\n}: BusinessBarProps) => {\n const [searchText, setSearchText] = useState(\"\");\n const searchedBusinesses = useMemo(() => {\n const text = searchText.toLowerCase();\n return (businesses || []).filter((b) =>\n b.name?.toLowerCase().startsWith(text),\n );\n }, [businesses, searchText]);\n const hiddenCollapseType = collapseType === \"hidden\" || isMobile;\n\n const onSearchChange = (e: ChangeEvent<HTMLInputElement>) =>\n setSearchText(e.target.value);\n\n const onBusinessClick = (clientId?: string) => {\n handleSwitchBusiness(clientId || \"\");\n if (hiddenCollapseType) {\n onToggleSideBar(false);\n }\n setSearchText(\"\");\n };\n const onToggleAddBusinessDrawer = () => {\n toggleAddBusinessDrawer();\n toggleShowBusiness(false);\n if (hiddenCollapseType) {\n onToggleSideBar(false);\n }\n setSearchText(\"\");\n };\n const onHandleLogoutClick = () => {\n onLogoutClick?.();\n toggleShowBusiness(false);\n if (hiddenCollapseType) {\n onToggleSideBar(false);\n }\n setSearchText(\"\");\n };\n return (\n <AnimatePresence initial={false}>\n <motion.div\n initial=\"hidden\"\n animate=\"visible\"\n exit=\"exit\"\n variants={businessPopUpVariants}\n >\n <div\n className=\"w-72 bg-white border-x border-t rounded-xl overflow-hidden p-3\"\n style={{\n boxShadow: `\n 3px 4px 11px 0px #0000001A,\n 13px 16px 21px 0px #00000017,\n 29px 36px 28px 0px #0000000D,\n 52px 65px 33px 0px #00000003,\n 82px 101px 36px 0px #00000000\n `,\n }}\n >\n <BusinessBarTrigger\n activeBusiness={activeBusiness}\n rightNode={<ActiveBusinessIcon />}\n className=\"bg-[#FAFAFA] border-none p-3\"\n />\n\n <div className=\"mt-3\">\n <Input\n label=\"Search Account\"\n leftNode={<ChevronUp className=\"h-4 w-4 text-gray-500\" />}\n value={searchText}\n onChange={onSearchChange}\n placeholder=\"Search Account\"\n className=\"text-sm\"\n />\n </div>\n\n <ul className=\"max-h-48 overflow-y-auto mt-2 px-1 space-y-2\">\n {searchedBusinesses.map((b) => (\n <BusinessBarTrigger\n key={b.clientId}\n onTriggerClick={() => onBusinessClick(b?.clientId)}\n activeBusiness={b}\n rightNode={\n activeBusiness.clientId === b.clientId ? (\n <HiCheck className=\"text-primary-600\" size={18} />\n ) : undefined\n }\n className={cn(\"bg-white border-none \", {\n \"bg-[#FAFAFA]\": activeBusiness.clientId === b.clientId,\n })}\n />\n ))}\n </ul>\n\n <div className=\"py-2 \">\n <button\n onClick={onToggleAddBusinessDrawer}\n className=\"w-full flex items-center justify-start gap-2 text-sm text-[#0033C7] border-[#BECFFF] border-[0.5px] rounded-lg py-2 px-3 hover:bg-primary-accent transition \"\n >\n <BsPlus size={18} className=\"text-primary-main\" /> Add Account\n </button>\n </div>\n\n <div className=\"bg-[#FAFAFA] px-3 py-2 -m-3 mt-4\">\n <button\n className=\"w-full flex items-center gap-2 text-sm text-black hover:text-gray-700 transition p-2 hover:bg-primary-accent\"\n onClick={onHandleLogoutClick}\n >\n <FiLogOut size={16} /> Log Out\n </button>\n </div>\n </div>\n </motion.div>\n </AnimatePresence>\n );\n};\n","import { TextOverflow } from \"@/src/components/text-overflow\";\nimport { cn } from \"@/src/utils\";\nimport { BusinessType } from \"@/src/utils/types\";\n\ntype BusinessBarProps = {\n activeBusiness: BusinessType;\n iconOnly?: boolean;\n onTriggerClick?: () => void;\n className?: string;\n rightNode?: React.ReactNode;\n};\n\nexport const BusinessBarTrigger = ({\n activeBusiness,\n onTriggerClick,\n iconOnly = false,\n className,\n rightNode,\n}: BusinessBarProps) => {\n return (\n <div\n id=\"sidemenu_business_bar\"\n role=\"button\"\n onClick={onTriggerClick ? onTriggerClick : undefined}\n className={cn(\n \"relative flex w-full items-center rounded-lg text-black bg-white\",\n {\n \"border-[.5px] border-[#E9EBF8] py-1 px-2\": !iconOnly,\n \"hover:bg-primary-accent transition-all duration-150 cursor-pointer \":\n !!onTriggerClick,\n },\n className,\n )}\n >\n <section\n className={cn(\n \"flex items-center justify-center bg-[#E9EBF8] text-primary-main rounded-md mr-3 text-xl font-medium\",\n {\n \"w-10 h-10\": !iconOnly,\n \"w-full h-10 mr-0\": iconOnly,\n },\n )}\n >\n {activeBusiness?.name?.charAt(0) || \"M\"}\n </section>\n\n {!iconOnly && (\n <section className=\"flex-1 flex justify-between items-center relative text-black w-full -space-y-1 tracking-wide\">\n <div className=\"flex-1 min-w-0 max-w-[150px] w-full\">\n <TextOverflow\n as={\"h2\"}\n className=\"text-base capitalize font-medium\"\n >\n {activeBusiness?.name}\n </TextOverflow>\n <TextOverflow\n as={\"p\"}\n className=\"text-sm text-[#A5A5A5]\"\n onClick={undefined}\n >\n {activeBusiness?.email}\n </TextOverflow>\n </div>\n {rightNode}\n </section>\n )}\n </div>\n );\n};\n","import React from \"react\";\n\nexport const ActiveBusinessIcon = (props: React.SVGProps<SVGSVGElement>) => (\n <svg\n width=\"9\"\n height=\"8\"\n viewBox=\"0 0 9 8\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <circle cx=\"4.5\" cy=\"4\" r=\"4\" fill=\"#62C554\" />\n </svg>\n);\n","import { BusinessType } from \"@/src/utils/types\";\nimport { BusinessBarContent } from \"./components/Content\";\nimport { BusinessBarTrigger } from \"./components/Trigger\";\nimport { Popover } from \"../../popover\";\nimport { cn } from \"@/src/utils\";\nimport { SidebarProps } from \"../utils/types\";\n\ntype BusinessBarProps = {\n activeBusiness: BusinessType;\n businesses?: BusinessType[];\n isBusinessShown: boolean;\n toggleAddBusinessDrawer: () => void;\n toggleShowBusiness: (v: boolean) => void;\n handleSwitchBusiness: (_: string) => void;\n iconOnly?: boolean;\n onLogoutClick: () => void;\n isMobile: boolean;\n} & Pick<SidebarProps, \"onToggleSideBar\" | \"isMobile\" | \"collapseType\">;\n\nexport const BusinessBar = ({\n activeBusiness,\n toggleAddBusinessDrawer,\n toggleShowBusiness,\n businesses = [],\n handleSwitchBusiness,\n iconOnly = false,\n onLogoutClick,\n isMobile,\n onToggleSideBar,\n isBusinessShown,\n collapseType,\n}: BusinessBarProps) => {\n return (\n <div className=\"px-4 relative mb-0 \">\n <Popover\n side={isMobile ? \"top\" : \"right\"}\n open={isBusinessShown}\n onOpenChange={toggleShowBusiness}\n align=\"end\"\n contentClassName=\"!bg-transparent !shadow-none !p-0\"\n trigger={\n <div className=\"flex items-center w-full\">\n <BusinessBarTrigger\n activeBusiness={activeBusiness}\n onTriggerClick={() => toggleShowBusiness(true)}\n iconOnly={iconOnly}\n rightNode={<Icon className=\"stroke-gray-500\" />}\n />\n </div>\n }\n >\n <BusinessBarContent\n activeBusiness={activeBusiness}\n handleSwitchBusiness={handleSwitchBusiness}\n toggleAddBusinessDrawer={toggleAddBusinessDrawer}\n businesses={businesses}\n onLogoutClick={onLogoutClick}\n onToggleSideBar={onToggleSideBar}\n toggleShowBusiness={toggleShowBusiness}\n collapseType={collapseType}\n isMobile={isMobile}\n />\n </Popover>\n </div>\n );\n};\n\nconst Icon = ({ className }: { className?: string }) => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"18\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n className={cn(\n \"lucide lucide-chevrons-up-down-icon lucide-chevrons-up-down\",\n className,\n )}\n >\n <path d=\"M7 22l5 5 5-5\" />\n <path d=\"M7 4l5-5 5 5\" />\n </svg>\n );\n};\n","import { cn } from \"@/src/utils\";\nimport { AnimatePresence, motion } from \"framer-motion\";\nimport { useEffect } from \"react\";\nimport { FiChevronRight } from \"react-icons/fi\";\nimport { LinksType, SidebarProps } from \"./utils/types\";\nimport { Tooltip } from \"../tooltip\";\nimport { useLocalStorage } from \"@/src/hooks/useLocalStorage\";\n\ntype Props = {\n isIconsOnly: boolean;\n isMobile: boolean;\n} & Pick<\n SidebarProps,\n | \"isSidebarCollapsed\"\n | \"onToggleSideBar\"\n | \"onNavigate\"\n | \"currentPath\"\n | \"collapseType\"\n | \"links\"\n | \"appConfig\"\n>;\n\ntype SidebarMenuStorageType = Record<string, boolean>;\n\nconst accordionItemVariants = {\n hidden: { opacity: 0, height: 0 },\n visible: {\n opacity: 1,\n height: \"auto\",\n transition: {\n duration: 0.3,\n },\n },\n};\n\nexport const NavItems = ({\n isIconsOnly,\n isSidebarCollapsed,\n onToggleSideBar,\n currentPath,\n onNavigate,\n collapseType,\n links,\n appConfig,\n isMobile,\n}: Props) => {\n const SIDEBAR_MENU_STORAGE_KEY = \"@sidebar-expanded-menus\";\n const [expandedMenus, setExpandedMenus] =\n useLocalStorage<SidebarMenuStorageType>(SIDEBAR_MENU_STORAGE_KEY, {});\n\n const toggleAccordion = (linkId: string) => {\n setExpandedMenus((prev) => ({\n ...prev,\n [linkId]: !prev[linkId],\n }));\n };\n\n const handleMenuLink = (link: LinksType) => {\n const hasChildren = !!link?.children?.length;\n if (hasChildren) {\n if (isIconsOnly) {\n onToggleSideBar(!isSidebarCollapsed);\n setExpandedMenus((prev) => ({\n ...prev,\n [link.id]: true,\n }));\n } else {\n toggleAccordion(link.id);\n }\n return;\n }\n onNavigate(`/${link.to}`);\n };\n\n const stripQuery = (path: string) => path.split(\"?\")[0];\n\n const getActiveMenu = (link: LinksType): boolean => {\n // Helper to strip query params from a path\n\n const hasChildren = !!link?.children?.length;\n if (hasChildren) {\n return (link.children || []).some(\n (l) => stripQuery(currentPath) === stripQuery(l.to),\n );\n }\n return stripQuery(currentPath) === stripQuery(link.to);\n };\n\n useEffect(() => {\n // Reset all expanded menus and only open the current path menu\n const expanded: SidebarMenuStorageType = {};\n\n // Find the link that contains the current path and expand only that one\n links.forEach((link) => {\n if (link.children && link.children.length > 0) {\n // If any child matches the current path, expand this menu\n if (\n link.children.some(\n (child) => stripQuery(currentPath) === stripQuery(child.to),\n )\n ) {\n expanded[link.id] = true;\n }\n }\n });\n\n // Replace all expanded menus with just the one for current path\n setExpandedMenus(expanded);\n }, [links, currentPath, isSidebarCollapsed]);\n\n return (\n <ul className=\"w-[90%] space-y-2.5\">\n {links.map((link, idx) => {\n if (link.isHidden) return null;\n if (appConfig?.hiddenRoutes?.includes(link.key ?? \"\")) return null;\n\n const active = getActiveMenu(link);\n const hasChildren = !!link?.children?.length;\n const isExpanded = expandedMenus[link.id];\n\n const menuItem = (\n <div\n className=\"mb-1 relative flex flex-col justify-center items-center\"\n key={idx}\n onClick={() => handleMenuLink(link)}\n >\n {active &&\n !isMobile &&\n (isIconsOnly || !hasChildren || !isExpanded) && (\n <div className=\"absolute bg-primary-main w-2 h-4 rounded-r-full -translate-y-1/2 top-1/2 left-0\" />\n )}\n\n <li\n key={link.to}\n id={link.id}\n className={cn(\n \"cursor-pointer transition text-base duration-300 w-full text-[#00000066] font-medium rounded-md mx-auto max-w-full ml-4 p-2\",\n {\n \"bg-[#F6F8FF] text-primary-main \":\n active && (!isExpanded || !isSidebarCollapsed),\n },\n {\n \"hover:bg-gray-100\":\n !active &&\n (collapseType !== \"icons\" || !isSidebarCollapsed),\n },\n {\n \"bg-white text-primary-main\": active,\n },\n {\n \"flex justify-center text-primary-main !px-0 max-w-[70%]\":\n isIconsOnly && active,\n \"flex justify-center !px-0 max-w-[70%]\":\n isIconsOnly && !active,\n },\n )}\n >\n <div\n className={cn(\"flex items-center w-full\", {\n \"justify-center\": isIconsOnly,\n })}\n >\n <Tooltip\n key={idx}\n trigger={\n <span className=\"w-6\" onClick={() => handleMenuLink(link)}>\n {link.icon}\n </span>\n }\n side=\"right\"\n hasArrow\n open={!isIconsOnly ? false : undefined}\n >\n {link.name}\n </Tooltip>\n {(collapseType !== \"icons\" || !isSidebarCollapsed) && (\n <>\n <span className=\"px-3 text-nowrap\">{link.name}</span>\n {hasChildren && (\n <span\n className=\"ml-auto transition-transform duration-300\"\n style={{\n transform: isExpanded\n ? \"rotate(90deg)\"\n : \"rotate(0deg)\",\n }}\n >\n <FiChevronRight size={18} />\n </span>\n )}\n </>\n )}\n </div>\n </li>\n\n {hasChildren &&\n (collapseType !== \"icons\" || !isSidebarCollapsed) && (\n <AnimatePresence>\n {isExpanded && (\n <motion.div\n initial=\"hidden\"\n animate=\"visible\"\n exit=\"hidden\"\n variants={accordionItemVariants}\n className=\"overflow-hidden w-full\"\n >\n <ul className=\" mt-1 relative \">\n {link.children?.map((childLink) => {\n if (childLink.isHidden) return null;\n const childActive =\n stripQuery(currentPath) ===\n stripQuery(childLink.to);\n return (\n <div\n id={childLink.id}\n className={cn(\"relative pl-12 bg-blue-100- mt-4\")}\n >\n <li\n className={cn(\n \"cursor-pointer transition text-base duration-300 px-3 w-full text-black font-medium opacity-40 rounded-md text-nowrap\",\n {\n \"bg-transparent opacity-100 text-primary-main\":\n childActive,\n },\n {\n \"hover:text-primary-main\": !childActive,\n },\n )}\n onClick={() => onNavigate(`/${childLink.to}`)}\n >\n {childLink.name}\n {childActive && (\n <>\n {!isMobile && (\n <div className=\"absolute bg-primary-main w-2 h-4 rounded-r-full -translate-y-1/2 top-1/2 left-0\" />\n )}\n <div\n id=\"vertical-bar-child\"\n className=\"h-4 w-0.5 bg-primary-main absolute left-[30px] z-10 -translate-y-1/2 top-1/2 rounded-t-full rounded-b-full \"\n />\n </>\n )}\n </li>\n </div>\n );\n })}\n <div\n id=\"vertical-bar\"\n className=\"bg-white rounded-t-full rounded-b-full h-full w-[4px] absolute left-[29px] top-0\"\n />\n </ul>\n </motion.div>\n )}\n </AnimatePresence>\n )}\n </div>\n );\n\n return menuItem;\n })}\n </ul>\n );\n};\n","import { useState, useEffect } from \"react\";\n\n/**\n * A custom hook to persist state in localStorage with type safety\n * @template T The type of the state to be stored\n * @param {string} key - The localStorage key to store the state under\n * @param {T} initialValue - The initial value to use if no value exists in localStorage\n * @returns {[T, React.Dispatch<React.SetStateAction<T>>]} A stateful value and a function to update it\n */\nexport const useLocalStorage = <T,>(\n key: string,\n initialValue: T,\n): [T, React.Dispatch<React.SetStateAction<T>>] => {\n // State to store our value\n // Pass initial state function to useState so logic is only executed once\n const [state, setState] = useState<T>(initialValue);\n\n // Only after mount/hydration, sync with localStorage\n const [isHydrated, setIsHydrated] = useState(false);\n\n // Once the component is hydrated, we can safely access localStorage\n useEffect(() => {\n setIsHydrated(true);\n\n try {\n const item = localStorage.getItem(key);\n if (item) {\n setState(JSON.parse(item));\n }\n } catch (error) {\n console.error(\"Error reading from localStorage:\", error);\n }\n }, [key]);\n\n // Update localStorage when state changes but only after hydration\n useEffect(() => {\n if (isHydrated) {\n try {\n localStorage.setItem(key, JSON.stringify(state));\n } catch (error) {\n console.error(\"Error writing to localStorage:\", error);\n }\n }\n }, [key, state, isHydrated]);\n\n return [state, setState];\n};\n","export const OpenSidebarIcon = () => {\n return (\n <svg\n width=\"100%\"\n height={40}\n xmlns=\"http://www.w3.org/2000/svg\"\n id=\"Layer_1\"\n data-name=\"Layer 1\"\n viewBox=\"0 0 1565.51 377.21\"\n >\n <g>\n <path\n fill=\"#0231C5\"\n d=\"m277.49,86.74v85.18l-.41,6.31v.21c-.72,5.8-2.38,11.28-4.86,16.35-1.45,3-3.21,5.9-5.28,8.49-1.55,2.07-3.42,4.04-5.28,5.9-1.66,1.55-3.42,3.11-5.28,4.45-1.66,1.24-3.42,2.38-5.28,3.42-1.76.93-3.52,1.76-5.28,2.59-1.24.52-2.48.93-3.83,1.35l-1.45.52-5.28,1.76-5.28,1.76-5.28,1.76-5.28,1.76-10.56,3.52-.52.21v19.15l-.41.1-3.62,1.14-.83.21-2.79.93-2.48.83-1.14.31-3.62,1.14-.62.21-3,.93-2.28.72-1.35.41-3.62,1.14-.41.1-.52.21h-.21v-37.26c0-1.55.31-3,.72-4.45.1-.31.21-.62.41-.93.83-1.86,2.07-3.52,3.62-4.86.41-.31.83-.72,1.35-1.04.72-.52,1.45-.83,2.28-1.24.21-.1.52-.21.72-.31l.21-.1,2.17-.72.62-.21,3.62-1.14,1.14-.41,5.28-1.76.83-.31,3.62-1.14.93-.31,5.28-1.76,5.28-1.76,5.28-1.76,5.28-1.76,3.83-1.24c.52-.1.93-.31,1.45-.52,1.97-.72,3.73-1.76,5.28-2.9,2.07-1.45,3.83-3.21,5.28-5.18,3.21-4.14,5.07-9.42,5.07-14.9v-85.08c0-5.59-1.76-10.76-5.07-15.01-1.45-1.86-3.11-3.52-5.07-4.97q-.1-.1-.21-.1c-1.66-1.24-3.42-2.17-5.28-2.9-1.76-.72-3.52-1.14-5.28-1.45-1.76-.31-3.52-.31-5.28-.21-1.76.1-3.52.41-5.28.93-.21.1-.52.1-.72.21l-4.55,1.45-5.28,1.66-5.28,1.76-5.69,1.55-5.28,1.76-5.28,1.66-5.28,1.76-5.28,1.66-5.28,1.66-5.28,1.76-5.28,1.66-5.28,1.66-5.28,1.76-5.28,1.66-5.28,1.76-5.28,1.66-5.28,1.76-5.69,1.66-5.28,1.76-3.83,1.24c-.52.21-1.04.31-1.55.52-1.86.72-3.73,1.76-5.28,2.9-2.07,1.45-3.83,3.21-5.28,5.18-3.21,4.24-5.07,9.42-5.07,15.01v33.33c0,3.93.83,7.25,2.07,10.04.1.31.21.52.41.83-.1.1-.31.1-.41.21-.83.41-1.55.72-2.28,1.24-.41.21-.83.52-1.35.72-1.24.72-2.48,1.55-3.62,2.38-.1.1-.31.21-.41.31-1.14.83-2.17,1.66-3.21,2.48-.72.62-1.45,1.24-2.07,1.97-.52.52-1.04.93-1.55,1.45-1.24,1.35-2.48,2.69-3.62,4.14-.1.1-.1.21-.21.31-.72.93-1.35,1.76-1.97,2.69-.52-.72-1.04-1.55-1.45-2.28-.72-1.14-1.35-2.28-1.86-3.52-.62-1.24-1.14-2.59-1.66-3.83-2.38-6-3.62-12.42-3.62-18.94v-33.64c0-8.07,1.86-15.94,5.28-22.77,1.45-3,3.21-5.9,5.28-8.49,1.55-2.07,3.42-4.04,5.28-5.9,1.66-1.55,3.42-3.11,5.28-4.45,1.66-1.24,3.42-2.38,5.28-3.42,1.66-.93,3.42-1.76,5.28-2.59,1.35-.52,2.59-1.04,3.93-1.45l1.35-.41,5.28-1.66,5.28-1.76,5.28-1.66,5.28-1.76,5.28-1.66,5.28-1.76,5.28-1.66,5.28-1.76,5.8-1.66,5.28-1.76,5.28-1.66,5.28-1.66,5.28-1.76,5.28-1.66,5.28-1.76,5.28-1.66,5.28-1.76,5.28-1.66,5.28-1.76,1.76-.52c1.14-.41,2.38-.72,3.62-1.04,1.76-.41,3.52-.83,5.28-1.04,1.76-.21,3.52-.41,5.28-.41,1.76-.1,3.52,0,5.28.1,1.76.1,3.52.31,5.28.62,1.76.31,3.52.72,5.28,1.24,1.76.52,3.62,1.14,5.28,1.86,1.76.72,3.62,1.66,5.28,2.59,1.86,1.04,3.62,2.17,5.28,3.42h.1c1.86,1.35,3.62,2.79,5.28,4.45,1.97,1.76,3.73,3.73,5.28,5.8,2.07,2.69,3.83,5.49,5.28,8.49,3.73,7.14,5.59,14.9,5.59,23.08Z\"\n ></path>\n <path\n fill=\"#0231C5\"\n d=\"m184.03,136.63v28.05l-.72.21-1.97.62-3.31,1.04-.21.1-3.62,1.14-1.45.52-2.17.72-.52.1h0l-2.17.72-1.86.62-1.76.52-3.52,1.14h-.1l-3.62,1.14-1.66.52-1.97.62-3.31,1.04-.21.1-3.62,1.14-1.45.52-2.17.72-.52.1-2.69.83-.41.1-3.62,1.14-1.24.41-2.38.72-2.9.93-.62.21-3.62,1.14-1.04.31-1.97.62-.62.21-2.79.93-.83.31-3,.93c-.21.1-.41.1-.62.21-.31.1-.62.21-.83.31-.93.41-1.86.83-2.79,1.35-.83.41-1.76.93-2.59,1.55-.31.21-.72.52-1.04.83-1.35,1.04-2.48,2.17-3.62,3.52-.21.21-.41.52-.62.83-1.14,1.55-2.17,3.21-3,5.07-1.35,3.11-2.07,6.42-2.07,9.94v82.39c0,2.59.72,5.07,2.07,7.14.83,1.35,2.07,2.59,3.42,3.62q.1.1.21.1c1.14.83,2.28,1.45,3.62,1.76,1.14.41,2.38.62,3.62.62,1.14,0,2.38-.1,3.62-.41.31-.1.62-.21.93-.31l2.59-.83,3.62-1.14,3.62-1.14,3.62-1.14,3.62-1.14,1.66-.52c.62-.21,1.24-.52,1.86-.83,1.35-.52,2.48-1.24,3.62-2.17,1.35-1.04,2.59-2.28,3.62-3.73,2.07-2.9,3.21-6.52,3.21-10.25v-58.48l.31-.1,3.62-1.14.21-.1,3.31-1.04,1.97-.62,1.66-.52,3.62-1.14h.1l3.52-1.14,1.76-.52,1.86-.62,3.42-1.14.21-.1,1.14-.41v67.07c0,2.48-.21,5.07-.62,7.45-.21.93-.31,1.76-.52,2.69-.83,3.52-1.97,6.83-3.62,9.94-1.04,2.07-2.28,4.04-3.62,6-1.14,1.55-2.28,3-3.62,4.45-1.14,1.24-2.38,2.38-3.62,3.42-1.14,1.04-2.38,1.86-3.62,2.79-1.14.83-2.38,1.55-3.62,2.28-1.14.62-2.38,1.24-3.62,1.76-.1,0-.21.1-.31.21-1.04.41-2.17.83-3.21,1.24-.31.1-.62.21-.93.31l-2.69.83-7.25,2.28-3.62,1.14-3.62,1.14-1.66.52c-.62.21-1.24.41-1.86.52-1.24.31-2.38.62-3.62.83-1.24.21-2.38.41-3.62.41-1.14.1-2.17.1-3.21.1h-.31c-1.24,0-2.38-.1-3.62-.21-1.24-.1-2.38-.31-3.62-.52s-2.38-.52-3.62-.93c-.72-.21-1.35-.41-2.07-.62-.52-.21-1.04-.41-1.55-.62-1.24-.52-2.38-1.04-3.62-1.66s-2.48-1.35-3.62-2.17c-.52-.31-1.04-.72-1.55-1.04-.72-.52-1.35-1.04-2.07-1.66-1.24-1.04-2.48-2.17-3.62-3.42-1.35-1.35-2.59-2.9-3.62-4.45-1.45-1.97-2.59-4.04-3.62-6.21-2.38-5.18-3.62-10.87-3.62-16.77v-82.39c0-6.62,1.24-13.04,3.62-18.94.52-1.35,1.04-2.59,1.66-3.83s1.24-2.38,1.86-3.52c.41-.83.93-1.55,1.45-2.28.62-.93,1.24-1.86,1.97-2.69,0-.1.1-.21.21-.21,1.14-1.45,2.28-2.79,3.62-4.14.52-.52.93-1.04,1.55-1.45.72-.72,1.35-1.24,2.07-1.86,1.04-.83,2.07-1.76,3.21-2.48.1-.1.31-.21.41-.31,1.14-.83,2.38-1.66,3.62-2.28.41-.21.83-.52,1.35-.72.72-.41,1.55-.83,2.28-1.24.1-.1.21-.1.41-.21.83-.41,1.76-.83,2.59-1.14.21-.1.41-.21.62-.21,1.04-.41,2.17-.83,3.21-1.14l.31-.1,1.04-.31,2.59-.83,2.79-.93.83-.31,3.62-1.14.83-.31,2.79-.83.62-.21,1.97-.62,1.04-.31,3.62-1.14.62-.21,2.9-.93,2.38-.72,1.24-.41,3.62-1.14.41-.1,2.69-.83.52-.1,2.17-.72,1.45-.41,3.62-1.14.21-.1,3.31-1.04,1.97-.62,1.66-.52,3.62-1.14h.1l3.52-1.14,1.76-.52,1.86-.62,2.17-.72h0l.52-.1,2.17-.72,1.45-.52,3.62-1.14.21-.1,3.31-1.04,1.97-.62,1.04-.41Z\"\n ></path>\n </g>\n <path\n fill=\"#000000\"\n d=\"m433.57,86.41c18.92,0,34.54,6.21,46.87,18.62,12.32,12.41,18.49,28.16,18.49,47.26s-6.16,34.85-18.49,47.26c-12.33,12.41-27.95,18.62-46.87,18.62h-35.41v50.51h-42.18V86.41h77.59Zm-6.51,97.38c8.5,0,15.49-2.95,20.96-8.85,5.47-5.9,8.2-13.45,8.2-22.65s-2.73-16.75-8.2-22.65c-5.47-5.9-12.46-8.85-20.96-8.85h-28.9v63.01h28.9Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m568.18,272.05c-18.23,0-32.63-6.16-43.22-18.49-10.59-12.32-15.88-28.21-15.88-47.65s5.47-34.89,16.4-47.39c10.94-12.5,25.34-18.75,43.22-18.75,8.85,0,16.75,1.91,23.69,5.73,6.94,3.82,12.15,9.03,15.62,15.62v-17.96h39.58v125.5h-39.58v-17.7c-3.47,6.25-8.81,11.33-16.01,15.23-7.2,3.91-15.15,5.86-23.82,5.86Zm11.46-33.07c9.54,0,16.92-3.12,22.13-9.37,5.21-6.25,7.81-14.15,7.81-23.69s-2.6-17.18-7.81-23.43c-5.21-6.25-12.59-9.37-22.13-9.37-9.03,0-16.27,3.04-21.74,9.11-5.47,6.08-8.2,13.97-8.2,23.69s2.73,17.66,8.2,23.82c5.47,6.16,12.71,9.24,21.74,9.24Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m765.53,143.17h39.84v121.59c0,19.44-5.99,34.54-17.97,45.3-11.29,9.72-26.65,14.58-46.08,14.58s-35.76-4.34-46.34-13.02c-10.24-8.68-15.45-19.7-15.62-33.07h40.1c.87,11.28,8.16,16.92,21.87,16.92,16.14,0,24.21-9.37,24.21-28.12v-19.53c-7.29,13.89-20.57,20.83-39.84,20.83-15.45,0-27.04-4.69-34.76-14.06-7.73-9.37-11.59-22.22-11.59-38.53v-72.9h39.83v66.91c0,18.05,7.38,27.08,22.13,27.08,7.81,0,13.8-2.82,17.97-8.46,4.17-5.64,6.25-13.41,6.25-23.3v-62.23Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m839.47,268.66V86.41h111.44v35.41h-69.26v49.21h69.26v34.63h-69.26v63.01h-42.18Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m1090.07,253.82c-12.59,12.5-29.47,18.75-50.64,18.75s-38.1-6.25-50.77-18.75c-12.67-12.5-19.01-28.47-19.01-47.91s6.33-35.36,19.01-47.78c12.67-12.41,29.59-18.62,50.77-18.62s38.05,6.21,50.64,18.62c12.58,12.41,18.88,28.34,18.88,47.78s-6.29,35.41-18.88,47.91Zm-50.64-15.1c9.2,0,16.49-3.03,21.87-9.11,5.38-6.07,8.07-13.97,8.07-23.69s-2.69-17.61-8.07-23.69c-5.38-6.07-12.67-9.11-21.87-9.11s-16.71,3.04-22,9.11c-5.3,6.08-7.94,13.97-7.94,23.69s2.64,17.62,7.94,23.69c5.29,6.08,12.63,9.11,22,9.11Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m1131.86,268.66v-125.5h39.84v18.23c7.46-14.41,21-21.61,40.62-21.61,30.55,0,45.82,17.1,45.82,51.29v77.59h-40.1v-64.57c0-10.76-1.69-18.57-5.08-23.43-3.39-4.86-9.07-7.29-17.05-7.29-16.14,0-24.21,9.89-24.21,29.68v65.61h-39.84Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m1353.43,237.68c5.55,0,10.15-.26,13.8-.78v31.76c-7.64,1.39-16.49,2.08-26.56,2.08-4.52,0-8.51-.26-11.98-.78-3.47-.52-7.38-1.69-11.72-3.52-4.34-1.82-7.9-4.3-10.68-7.42-2.78-3.13-5.17-7.64-7.16-13.54-2-5.9-2.99-12.84-2.99-20.83v-49.99h-19.79v-31.5h19.79v-37.23h39.84v37.23h28.38v31.5h-28.38v41.66c0,8.51,1.47,14.19,4.43,17.05,2.95,2.86,7.29,4.3,13.02,4.3Z\"\n ></path>\n <path\n fill=\"#000000\"\n d=\"m1513.55,199.4c0,5.21-.35,11.02-1.04,17.44h-92.69c.35,8.16,3.12,14.49,8.33,19.01,5.21,4.52,12.24,6.77,21.09,6.77,12.15,0,19.96-3.91,23.43-11.72h39.05c-1.91,12.33-8.64,22.35-20.18,30.07-11.55,7.72-25.65,11.59-42.31,11.59-21.35,0-38.19-5.9-50.51-17.7-12.33-11.8-18.49-28.12-18.49-48.95s6.16-36.67,18.49-48.56c12.32-11.89,28.73-17.83,49.21-17.83s35.23,5.56,47.39,16.66c12.15,11.11,18.23,25.52,18.23,43.22Zm-93.73-7.29h54.42c-.18-8.33-2.52-14.75-7.03-19.27-4.52-4.51-11.02-6.77-19.53-6.77s-15.23,2.39-20.18,7.16c-4.95,4.78-7.51,11.07-7.68,18.88Z\"\n ></path>\n </svg>\n );\n};\n","export const ClosedSidebarIcon = () => {\n return (\n <svg\n width=\"100%\"\n height=\"32\"\n viewBox=\"0 0 20 32\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className=\"pl-5\"\n >\n <path\n d=\"M19.686 5.71949V15.1448L19.6467 15.8434V15.8548V15.8663C19.5779 16.5076 19.4207 17.1146 19.1848 17.6758C19.0472 18.0079 18.8801 18.3286 18.6836 18.6149C18.5361 18.8439 18.3592 19.0615 18.1823 19.2677C18.025 19.4394 17.858 19.6112 17.6811 19.7601C17.5238 19.8975 17.3567 20.0235 17.1798 20.138C17.0127 20.2411 16.8456 20.3327 16.6786 20.4243C16.5606 20.4816 16.4427 20.5274 16.3149 20.5732L16.1773 20.6305L15.6761 20.8252L15.1748 21.0199L14.6736 21.2146L14.1723 21.4093L13.1698 21.7986L13.1207 21.8215V23.9402L13.0814 23.9517L12.7374 24.0777L12.6587 24.1006L12.3934 24.2036L12.1575 24.2953L12.0494 24.3296L11.7054 24.4556L11.6464 24.4785L11.3614 24.5816L11.1452 24.6617L11.0174 24.7075L10.6734 24.8335L10.6341 24.845L10.5849 24.8679H10.5653V20.745C10.5653 20.5732 10.5948 20.4129 10.6341 20.2526C10.6439 20.2182 10.6537 20.1838 10.6734 20.1495C10.752 19.9433 10.87 19.7601 11.0174 19.6112C11.0567 19.5769 11.096 19.5311 11.1452 19.4967C11.214 19.4394 11.2828 19.4051 11.3614 19.3593C11.381 19.3478 11.4105 19.3364 11.4302 19.3249L11.4498 19.3135L11.6562 19.2333L11.7152 19.2104L12.0592 19.0844L12.1673 19.0386L12.6686 18.8439L12.7472 18.8096L13.0912 18.6836L13.1796 18.6492L13.6809 18.4545L14.1821 18.2598L14.6834 18.0652L15.1846 17.8705L15.5483 17.733C15.5974 17.7216 15.6367 17.6987 15.6859 17.6758C15.8726 17.5956 16.0397 17.4811 16.1871 17.3551C16.3837 17.1948 16.5508 17.0001 16.6884 16.7825C16.9931 16.3244 17.17 15.7403 17.17 15.1333V5.71949C17.17 5.10106 17.0029 4.52844 16.6884 4.05889C16.5508 3.85275 16.3935 3.66951 16.2068 3.50917C16.197 3.49772 16.197 3.49772 16.1871 3.49772C16.0299 3.36029 15.8628 3.25722 15.6859 3.17705C15.5188 3.09689 15.3517 3.05108 15.1846 3.01672C15.0176 2.98236 14.8505 2.98236 14.6834 2.99382C14.5163 3.00527 14.3492 3.03963 14.1821 3.09689C14.1625 3.10834 14.133 3.10834 14.1133 3.11979L13.6809 3.28013L13.1796 3.46336L12.6784 3.65806L12.1378 3.82984L11.6366 4.02453L11.1353 4.20777L10.6341 4.40246L10.1328 4.5857L9.63159 4.76894L9.13034 4.96363L8.62909 5.14687L8.12784 5.3301L7.62659 5.52479L7.12534 5.70803L6.6241 5.90272L6.12285 6.08596L5.6216 6.28065L5.08103 6.46389L4.57979 6.65858L4.21614 6.79601C4.16699 6.81891 4.11785 6.83037 4.06871 6.85327C3.8918 6.93344 3.71489 7.04796 3.56746 7.17394C3.37089 7.33427 3.20381 7.52896 3.06621 7.74656C2.76153 8.2161 2.58462 8.78872 2.58462 9.40715V13.0948C2.58462 13.53 2.66325 13.8965 2.78119 14.2057C2.79102 14.2401 2.80085 14.263 2.8205 14.2973C2.81067 14.3088 2.79102 14.3088 2.78119 14.3202C2.70256 14.366 2.63376 14.4004 2.56496 14.4577C2.52565 14.4806 2.48634 14.5149 2.43719 14.5378C2.31925 14.618 2.20131 14.7096 2.0932 14.8012C2.08337 14.8127 2.06371 14.8241 2.05389 14.8356C1.94577 14.9272 1.84749 15.0188 1.74921 15.1104C1.68041 15.1792 1.61161 15.2479 1.55264 15.328C1.5035 15.3853 1.45435 15.4311 1.40521 15.4884C1.28727 15.6373 1.16933 15.7861 1.06122 15.9465C1.05139 15.9579 1.05139 15.9694 1.04156 15.9808C0.972761 16.0839 0.913791 16.1755 0.85482 16.2786C0.805678 16.1984 0.756536 16.1068 0.717223 16.0266C0.648424 15.9007 0.589453 15.7747 0.540311 15.6373C0.481341 15.4998 0.432199 15.3509 0.383057 15.2135C0.157004 14.5493 0.0390625 13.8392 0.0390625 13.1177V9.3957C0.0390625 8.50241 0.215974 7.63203 0.540311 6.87618C0.677909 6.54406 0.844992 6.22339 1.04156 5.93708C1.18899 5.70803 1.3659 5.49044 1.54281 5.28429C1.70006 5.11251 1.86715 4.94072 2.04406 4.79184C2.20131 4.65441 2.3684 4.52844 2.54531 4.41391C2.70256 4.31084 2.86964 4.21922 3.04656 4.1276C3.17432 4.07034 3.29227 4.01308 3.42003 3.96727L3.5478 3.92146L4.04905 3.73822L4.5503 3.54353L5.05155 3.36029L5.5528 3.1656L6.05405 2.98236L6.5553 2.78767L7.05654 2.60444L7.55779 2.40974L8.10818 2.22651L8.60943 2.03182L9.11068 1.84858L9.61193 1.66534L10.1132 1.47065L10.6144 1.28741L11.1157 1.09272L11.6169 0.909482L12.1182 0.714792L12.6194 0.531554L13.1207 0.336863L13.2878 0.279601C13.3959 0.233791 13.5138 0.199434 13.6317 0.165077C13.7988 0.119268 13.9659 0.073458 14.133 0.0505533C14.3001 0.0276485 14.4672 0.00474375 14.6342 0.00474375C14.8013 -0.00670864 14.9684 0.00474368 15.1355 0.0161961C15.3026 0.0276485 15.4697 0.0505533 15.6367 0.0849104C15.8038 0.119268 15.9709 0.165077 16.138 0.222339C16.3051 0.279601 16.482 0.348315 16.6392 0.428482C16.8063 0.508649 16.9832 0.61172 17.1405 0.714792C17.3174 0.829315 17.4845 0.955292 17.6417 1.09272C17.6417 1.09272 17.6417 1.09272 17.6516 1.09272C17.8285 1.2416 17.9956 1.40193 18.1528 1.58517C18.3396 1.77986 18.5066 1.99746 18.6541 2.22651C18.8506 2.52427 19.0177 2.83348 19.1553 3.1656C19.5091 3.95582 19.686 4.81475 19.686 5.71949Z\"\n fill=\"#0231C5\"\n />\n <path\n d=\"M10.8112 9.92822V13.0846L10.7425 13.1079L10.5557 13.1778L10.2412 13.2943L10.2215 13.3059L9.87755 13.434L9.73995 13.4923L9.53356 13.5738L9.48441 13.5855L9.27802 13.667L9.10111 13.7369L8.93402 13.7951L8.59986 13.9232H8.59003L8.24604 14.0514L8.08878 14.1096L7.90204 14.1795L7.58753 14.2959L7.56787 14.3076L7.22388 14.4357L7.08628 14.4939L6.87989 14.5755L6.83074 14.5871L6.57521 14.6803L6.53589 14.692L6.1919 14.8201L6.07396 14.8667L5.8479 14.9482L5.57271 15.053L5.51374 15.0763L5.16974 15.2044L5.07146 15.2394L4.88472 15.3093L4.82575 15.3326L4.56038 15.4374L4.48175 15.4723L4.19673 15.5771C4.17707 15.5888 4.15742 15.5888 4.13776 15.6004C4.10827 15.6121 4.07879 15.6237 4.05913 15.6354C3.97068 15.682 3.88222 15.7286 3.79377 15.7868C3.71514 15.8334 3.62668 15.8916 3.54806 15.9615C3.51857 15.9848 3.47926 16.0197 3.44977 16.0547C3.322 16.1712 3.21389 16.2993 3.10578 16.4507C3.08612 16.474 3.06646 16.5089 3.04681 16.5439C2.93869 16.7186 2.84041 16.9049 2.76178 17.1146C2.63401 17.464 2.56521 17.8367 2.56521 18.2327V27.5039C2.56521 27.7951 2.63401 28.0747 2.76178 28.3076C2.84041 28.459 2.95835 28.5988 3.08612 28.7153C3.09595 28.7269 3.09595 28.7269 3.10578 28.7269C3.21389 28.8201 3.322 28.89 3.44977 28.9249C3.55788 28.9715 3.67582 28.9948 3.79377 28.9948C3.90188 28.9948 4.01982 28.9831 4.13776 28.9482C4.16725 28.9366 4.19673 28.9249 4.22622 28.9133L4.47193 28.8201L4.81592 28.692L5.15991 28.5638L5.50391 28.4357L5.8479 28.3076L6.00516 28.2494C6.06413 28.2261 6.1231 28.1911 6.18207 28.1562C6.30984 28.098 6.41795 28.0164 6.52606 27.9116C6.65383 27.7951 6.77177 27.6554 6.87006 27.4923C7.06663 27.1662 7.17474 26.7585 7.17474 26.3392V19.7585L7.20422 19.7469L7.54822 19.6187L7.56787 19.6071L7.88238 19.4906L8.06912 19.4207L8.22638 19.3625L8.57037 19.2344H8.5802L8.91437 19.1063L9.08145 19.048L9.25836 18.9781L9.5827 18.85L9.60236 18.8384L9.71047 18.7918V26.3392C9.71047 26.6188 9.69081 26.9099 9.6515 27.1778C9.63184 27.2826 9.62201 27.3758 9.60236 27.4806C9.52373 27.8767 9.41562 28.2494 9.25836 28.5988C9.16008 28.8317 9.04214 29.053 8.91437 29.2743C8.80625 29.449 8.69814 29.6121 8.57037 29.7752C8.46226 29.9149 8.34432 30.043 8.22638 30.1595C8.11827 30.276 8.00032 30.3692 7.88238 30.474C7.77427 30.5672 7.65633 30.6487 7.53839 30.7302C7.43028 30.8001 7.31234 30.87 7.19439 30.9282C7.18457 30.9282 7.17474 30.9399 7.16491 30.9515C7.06663 30.9981 6.95851 31.0447 6.86023 31.0913C6.83074 31.1029 6.80126 31.1146 6.77177 31.1262L6.51624 31.2194L5.82825 31.4757L5.48425 31.6038L5.14026 31.7319L4.983 31.7901C4.92403 31.8134 4.86506 31.8367 4.80609 31.8484C4.68815 31.8833 4.58004 31.9183 4.4621 31.9415C4.34416 31.9648 4.23604 31.9881 4.1181 31.9881C4.00999 31.9998 3.91171 31.9998 3.81342 31.9998H3.78394C3.666 31.9998 3.55788 31.9881 3.43994 31.9765C3.322 31.9648 3.21389 31.9415 3.09595 31.9183C2.97801 31.895 2.8699 31.86 2.75195 31.8134C2.68316 31.7901 2.62419 31.7668 2.55539 31.7435C2.50624 31.7203 2.4571 31.697 2.40796 31.6737C2.29002 31.6154 2.18191 31.5572 2.06397 31.4873C1.94602 31.4174 1.82808 31.3359 1.71997 31.2427C1.67083 31.2078 1.62169 31.1612 1.57255 31.1262C1.50375 31.068 1.44478 31.0098 1.37598 30.9399C1.25804 30.8234 1.1401 30.6953 1.03198 30.5555C0.904214 30.4041 0.786273 30.2294 0.687989 30.0547C0.550391 29.8334 0.442278 29.6004 0.343994 29.3559C0.117941 28.7735 0 28.1329 0 27.469V18.1978C0 17.4524 0.117941 16.7302 0.343994 16.0663C0.393136 15.9149 0.442278 15.7751 0.501249 15.6354C0.560219 15.4956 0.61919 15.3675 0.67816 15.2394C0.717474 15.1462 0.766616 15.0647 0.815758 14.9831C0.874728 14.8783 0.933699 14.7735 1.0025 14.6803C1.0025 14.6687 1.01233 14.657 1.02215 14.657C1.13027 14.494 1.23838 14.3425 1.36615 14.1911C1.41529 14.1329 1.4546 14.0746 1.51358 14.0281C1.58237 13.9465 1.64134 13.8883 1.71014 13.8184C1.80843 13.7252 1.90671 13.6204 2.01482 13.5389C2.02465 13.5272 2.04431 13.5156 2.05414 13.5039C2.16225 13.4108 2.28019 13.3176 2.39813 13.2477C2.43745 13.2244 2.47676 13.1895 2.5259 13.1662C2.5947 13.1196 2.67333 13.073 2.74213 13.0264C2.75195 13.0147 2.76178 13.0147 2.78144 13.0031C2.86007 12.9565 2.94852 12.9099 3.02715 12.875C3.04681 12.8633 3.06646 12.8517 3.08612 12.8517C3.1844 12.8051 3.29252 12.7585 3.3908 12.7236L3.42029 12.7119L3.51857 12.677L3.76428 12.5838L4.02965 12.479L4.10828 12.444L4.45227 12.3159L4.5309 12.281L4.79626 12.1878L4.85523 12.1645L5.04197 12.0946L5.14026 12.0597L5.48425 11.9316L5.54322 11.9083L5.81842 11.8034L6.04447 11.7219L6.16241 11.6753L6.50641 11.5472L6.54572 11.5355L6.80126 11.4424L6.8504 11.4307L7.0568 11.3492L7.19439 11.3026L7.53839 11.1745L7.55805 11.1628L7.87256 11.0464L8.0593 10.9765L8.21655 10.9182L8.56054 10.7901H8.57037L8.90454 10.662L9.07162 10.6038L9.24853 10.5339L9.45493 10.4523L9.50407 10.4407L9.71047 10.3592L9.84807 10.3009L10.1921 10.1728L10.2117 10.1612L10.5262 10.0447L10.713 9.97481L10.8112 9.92822Z\"\n fill=\"#0231C5\"\n />\n </svg>\n );\n};\n","import { SVGProps } from \"react\";\n\ntype SidebarToggleProps = {\n onToggleSideBar: (isOpen: boolean) => void;\n isSidebarCollapsed: boolean;\n};\n\nexport const SidebarToggle = ({\n onToggleSideBar,\n isSidebarCollapsed,\n}: SidebarToggleProps) => {\n return (\n <button\n onClick={() => onToggleSideBar(!isSidebarCollapsed)}\n className=\"w-6 h-12 bg-[#EEF2FF] rounded-tr-md [clip-path:polygon(0%_0%,100%_0%,100%_60%,0%_100%,0%_100%)] mt-5 flex justify-center items-center pb-2 text-gray-700\"\n >\n {isSidebarCollapsed ? <OpenIcon /> : <CloseIcon />}\n </button>\n );\n};\n\nconst OpenIcon = (props: SVGProps<SVGSVGElement>) => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"15\"\n height=\"20\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n className=\"lucide lucide-panel-left-open-icon lucide-panel-left-open\"\n {...props}\n >\n <rect width=\"18\" height=\"18\" x=\"3\" y=\"3\" rx=\"2\" />\n <path d=\"M9 3v18\" />\n <path d=\"m14 9 3 3-3 3\" />\n </svg>\n );\n};\n\nconst CloseIcon = (props: SVGProps<SVGSVGElement>) => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"15\"\n height=\"20\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n className=\"lucide lucide-panel-right-open-icon lucide-panel-right-open\"\n {...props}\n >\n <rect width=\"18\" height=\"18\" x=\"3\" y=\"3\" rx=\"2\" />\n <path d=\"M15 3v18\" />\n <path d=\"m10 15-3-3 3-3\" />\n </svg>\n );\n};\n","import { cn } from \"@/src/utils\";\n\ntype Variant = \"success\" | \"failed\" | \"pending\" | \"abandoned\";\n\nexport const Status = ({\n status,\n variant,\n className,\n}: {\n status: string;\n variant: Variant;\n className?: string;\n}) => {\n return (\n <div>\n <div\n className={cn(\n \"order-first max-w-max flex-none rounded-full px-2 py-1 text-xs font-medium ring-1 ring-inset ring-current sm:order-none text-[14px] capitalize\",\n {\n \"bg-green-500/20 text-green-500\": variant === \"success\",\n },\n {\n \"bg-gray-500/20 text-white\": variant === \"abandoned\",\n },\n {\n \"bg-red-500/20 text-red-500\": variant === \"failed\",\n },\n {\n \"bg-yellow-500/20 text-yellow-500\": variant === \"pending\",\n },\n className,\n )}\n >\n <p>{status.replace(\"-\", \" \")}</p>\n </div>\n </div>\n );\n};\n","import { cn } from \"@/src/utils\";\nimport { Table as ReactTable, Row, RowData } from \"@tanstack/react-table\";\nimport { Loader } from \"lucide-react\";\nimport { ReactNode } from \"react\";\nimport { Pagination, PaginationProps } from \"./pagination\";\nimport { TableBody } from \"./TableBody\";\nimport { PageDataToolbar } from \"./ToolBar\";\nimport { FilterListItem } from \"./filters/FilterContent\";\n\nexport type TableSearchProps = {\n enabled: boolean;\n debounceRate?: number;\n onSearch?: (query: string) => void;\n};\n\nexport type TableDownloadProps = {\n enabled: boolean;\n buttonId?: string;\n onDownload?: () => void;\n buttonText?: string;\n};\nexport type TablePaginationProps = {\n enabled: boolean;\n} & PaginationProps;\n\ntype TableProps<T extends RowData> = {\n ExtraNode?: ReactNode;\n /**\n * @deprecated Use the `filterListOptions` prop instead.\n *\n * The `FilterMenu` prop is deprecated in favor of `filterListOptions`, which provides a more flexible and structured way to define filter options for the table.\n *\n * To manage the state of applied filters, use the `setAppliedFilters` callback. This function can be used to collect and update the current filter state based on user interactions with the filter list options.\n *\n * The `filterListOptions` prop accepts an array of filter configuration objects, allowing you to define available filters, their types, and possible values. This approach enables dynamic filter rendering and better state management compared to the static `FilterMenu` node.\n */\n FilterMenu?: ReactNode;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setAppliedFilters?: (values: Record<string, any>) => void;\n filterListOptions?: FilterListItem[];\n buttonClassName?: string;\n download?: TableDownloadProps;\n id?: string;\n isLoading?: boolean;\n isMobile?: boolean;\n isRefetching?: boolean;\n onExport?: () => void;\n onRefetch?: () => void;\n onRowClick?: (row: Row<T>) => void;\n pagination?: TablePaginationProps;\n search?: TableSearchProps;\n table: ReactTable<T>;\n};\n\nexport const Table = <T extends RowData>({\n table,\n isMobile = false,\n onRowClick,\n id = \"table\",\n onRefetch,\n isRefetching,\n FilterMenu,\n ExtraNode,\n //deprecated: onExport - use download\n onExport,\n search = {\n enabled: false,\n debounceRate: 700,\n },\n download = {\n enabled: false,\n buttonId: \"download_button\",\n buttonText: \"Export\",\n },\n isLoading,\n pagination,\n filterListOptions,\n setAppliedFilters,\n}: TableProps<T>) => {\n return (\n <div className={cn(\"relative w-full rounded-b border-0 overflow-x-auto\")}>\n <PageDataToolbar\n onRefetch={onRefetch}\n search={search}\n FilterMenu={FilterMenu}\n ExtraNode={ExtraNode}\n onExport={onExport}\n download={download}\n isRefetching={isRefetching}\n filterListOptions={filterListOptions}\n setAppliedFilters={setAppliedFilters}\n id={id}\n />\n\n <main className=\"w-full overflow-x-auto mt-5\">\n {isLoading ? (\n <div className=\"py-10 flex flex-col justify-center w-full items-center space-x-2\">\n <Loader size={20} className=\"animate-spin\" />\n <p className=\"mt-3 text-center text-gray-600 text-sm opacity-70 animate-pulse\">\n Loading...\n </p>\n </div>\n ) : table.getRowModel().rows.length < 1 ? (\n <div className=\"py-10 flex flex-col justify-center w-full items-center\">\n <p className=\"text-center text-gray-600 text-sm opacity-70\">\n No data available\n </p>\n </div>\n ) : (\n <div className=\"flex flex-col gap-2\">\n <TableBody\n table={table}\n isMobile={isMobile}\n onRowClick={onRowClick}\n id={id}\n />\n </div>\n )}\n </main>\n\n {!isLoading &&\n pagination?.enabled &&\n table.getRowModel().rows.length > 0 && (\n <Pagination\n {...pagination}\n currentPage={pagination?.currentPage ?? 1}\n totalPages={\n pagination?.totalPages ??\n Math.ceil(\n (pagination?.totalItems ?? 0) /\n Math.max(pagination?.itemsPerPage ?? 1, 1),\n ) ??\n 1\n }\n onPageChange={(page) => pagination?.onPageChange?.(page)}\n id={id}\n />\n )}\n </div>\n );\n};\n","import { ChevronLeftIcon, ChevronRightIcon } from \"lucide-react\";\nimport { renderPageNumbers } from \"./utils\";\n\nexport type PaginationProps = {\n currentPage?: number;\n totalPages?: number;\n onPageChange?: (page: number) => void;\n totalItems?: number;\n itemsPerPage?: number;\n id?: string;\n};\n\n/**\n * Pagination component for displaying pagination controls.\n * @param {number} currentPage - The current page number.\n * @param {number} totalPages - The total number of pages.\n * @param {function} onPageChange - Callback function to handle page change.\n * @param {number | undefined} itemsPerPage - The number of items per page.\n */\nexport const Pagination = ({\n currentPage = 1,\n totalPages = 1,\n onPageChange,\n itemsPerPage = 0,\n totalItems = 0,\n id = \"pagination\",\n}: PaginationProps) => {\n const handlePageClick = (page: number) => {\n if (page >= 1 && page <= totalPages) {\n onPageChange?.(page);\n }\n };\n const visibleRangeStart =\n itemsPerPage === 0 ? 1 : itemsPerPage * (currentPage - 1) + 1;\n const visibleRangeEnd =\n currentPage === totalPages\n ? totalItems\n : Math.min(visibleRangeStart + itemsPerPage - 1, totalItems);\n return (\n <div className=\"flex items-center justify-between border-t border-gray-200 px-4 py-3 sm:px-6 w-full flex-wrap gap-y-10 sm:gap-y-0\">\n {totalItems && (\n <section className=\"text-[#717171] text-[12px]\">\n <p className=\"\">\n Showing {visibleRangeStart} - {visibleRangeEnd} of {totalItems}\n </p>\n </section>\n )}\n <div className=\"flex items-center justify-center sm:justify-end \">\n <nav className=\" inline-flex gap-x-1 sm:gap-x-[10px] items-center\">\n <button\n onClick={() => handlePageClick(currentPage - 1)}\n id={`${id}-prev-button`}\n disabled={currentPage === 1}\n className=\"text-xs text-[#222222] hover:bg-primary-main/10 disabled:text-[#D9D9D9] disabled:cursor-not-allowed sm:flex hidden\"\n >\n <ChevronLeftIcon className=\"size-5\" />\n </button>\n {renderPageNumbers({ currentPage, totalPages, handlePageClick })}\n <button\n onClick={() => handlePageClick(currentPage + 1)}\n id={`${id}-next-button`}\n disabled={currentPage === totalPages}\n className=\"text-xs text-[#222222] hover:bg-primary-main/10 disabled:text-[#D9D9D9] disabled:cursor-not-allowed sm:flex hidden\"\n >\n <ChevronRightIcon className=\"size-5\" />\n </button>\n </nav>\n </div>\n </div>\n );\n};\n","type RenderPageNumbersProps = {\n totalPages: number;\n currentPage: number;\n handlePageClick: (page: number) => void;\n};\n\nconst PageButton = ({\n page,\n currentPage,\n onClick,\n}: {\n page: number | string;\n currentPage: number;\n onClick?: () => void;\n}) => {\n if (typeof page === \"string\") {\n return (\n <span className=\"px-3 py-1 sm:px-4 sm:py-2 text-xs sm:text-sm font-semibold text-gray-500\">\n {page}\n </span>\n );\n }\n\n return (\n <button\n onClick={onClick}\n id={`page-button-${page}`}\n className={`p-1 w-8 h-8 text-xs sm:text-sm rounded-full ${\n page === currentPage\n ? \"bg-primary-main text-white\"\n : \"text-[#717171] hover:bg-primary-main/10\"\n }`}\n >\n {page}\n </button>\n );\n};\n\nexport const renderPageNumbers = ({\n totalPages,\n currentPage,\n handlePageClick,\n}: RenderPageNumbersProps) => {\n const maxVisiblePages = 3;\n\n const getWindowBounds = () => {\n const halfWindow = Math.floor(maxVisiblePages / 2);\n let start = Math.max(1, currentPage - halfWindow);\n let end = Math.min(totalPages, start + maxVisiblePages - 1);\n\n if (end > totalPages) {\n start = Math.max(1, totalPages - maxVisiblePages + 1);\n end = totalPages;\n }\n\n return { start, end };\n };\n\n const { start, end } = getWindowBounds();\n const pages: (number | string)[] = [];\n\n if (start > 1) pages.push(1);\n if (start > 2) pages.push(\"...\");\n pages.push(...Array.from({ length: end - start + 1 }, (_, i) => start + i));\n if (end < totalPages - 1) pages.push(\"...\");\n if (end < totalPages) pages.push(totalPages);\n\n return pages.map((page, idx) => (\n <PageButton\n key={idx}\n page={page}\n currentPage={currentPage}\n onClick={\n typeof page === \"number\" ? () => handlePageClick(page) : undefined\n }\n />\n ));\n};\n","import {\n flexRender,\n Row,\n RowData,\n Table as ReactTable,\n} from \"@tanstack/react-table\";\nimport { cn } from \"@/src/utils\";\n\ntype TableBodyProps<T extends RowData> = {\n table: ReactTable<T>;\n isMobile: boolean;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n onRowClick?: (row: Row<any>) => void;\n id?: string;\n};\n\nexport const TableBody = <T extends RowData>({\n table,\n isMobile,\n onRowClick,\n id,\n}: TableBodyProps<T>) => {\n return (\n <div className={cn(\"relative w-full rounded-b border-0\", {})}>\n <table id={id ?? \"table\"} className=\"w-full overflow-x-scroll\">\n <thead>\n {table.getHeaderGroups().map((headerGroup) => (\n <tr\n className={cn(\n \" rounded text-[#717171] border-b- bg-[#FCFCFC]\",\n {},\n )}\n key={headerGroup.id}\n >\n {headerGroup.headers.map((header) => (\n <th\n className=\"relative py-3 text-base whitespace-nowrap pl-2.5 text-left font-normal capitalize\"\n colSpan={header.colSpan}\n key={header.id}\n style={{\n width: header.getSize(),\n }}\n >\n {header.isPlaceholder ? null : (\n <div\n className={cn(\"flex items-center\", {\n \"cursor-pointer select-none\":\n header.column.getCanSort(),\n })}\n onClick={header.column.getToggleSortingHandler()}\n >\n {header.isPlaceholder\n ? null\n : flexRender(\n header.column.columnDef.header,\n header.getContext(),\n )}\n </div>\n )}\n </th>\n ))}\n </tr>\n ))}\n </thead>\n <tbody className=\" pl-2.5\">\n {table?.getFilteredRowModel().rows.map((row) => (\n <tr\n className={cn(\n \"first-letter border-b border-zinc-100\",\n {\n \"hover:bg-gray-50\": !isMobile,\n },\n {\n \"hover:bg-gray-50 hover:cursor-pointer\": onRowClick,\n },\n )}\n key={row.id}\n onClick={() => (onRowClick ? onRowClick(row) : {})}\n >\n {row.getVisibleCells().map((cell) => (\n <td\n className={cn(\"\", {\n // block: false,\n })}\n key={cell.id}\n >\n <div\n className={cn(\"\", {\n \"w-max p-4 pl-2.5 text-black text-sm\": true,\n })}\n >\n {flexRender(cell.column.columnDef.cell, cell.getContext())}\n </div>\n </td>\n ))}\n </tr>\n ))}\n </tbody>\n </table>\n </div>\n );\n};\n","import { cn } from \"@/src/utils\";\nimport { Download, ListFilter, RotateCw } from \"lucide-react\";\nimport { ReactNode } from \"react\";\nimport { Button, buttonVariants } from \"../button\";\nimport { DebouncedInput } from \"../debounced-input\";\nimport { Popover } from \"../popover\";\nimport { TableDownloadProps, TableSearchProps } from \"./index\";\nimport { FilterListItem } from \"./filters/FilterContent\";\nimport { FilterPopover } from \"./filters\";\n\ntype PageDataToolbarProps = {\n onRefetch?: () => void;\n search?: TableSearchProps;\n FilterMenu?: ReactNode;\n ExtraNode?: ReactNode;\n onExport?: () => void;\n download?: TableDownloadProps;\n isRefetching?: boolean;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setAppliedFilters?: (values: Record<string, any>) => void;\n filterListOptions?: FilterListItem[];\n id?: string;\n};\n\nexport const PageDataToolbar = ({\n onRefetch,\n search,\n FilterMenu,\n ExtraNode,\n onExport,\n download,\n isRefetching,\n filterListOptions = [],\n setAppliedFilters,\n id = \"table-toolbar\",\n}: PageDataToolbarProps) => {\n const handleSearch = (query: string) => {\n search?.onSearch?.(query);\n };\n\n const handleRefetch = () => {\n try {\n onRefetch?.();\n } catch (e) {\n console.error(\"Error while refetching data\", e);\n }\n };\n\n return (\n <>\n {(onRefetch ||\n search?.enabled ||\n FilterMenu ||\n ExtraNode ||\n onExport) && (\n <div className=\"w-full flex flex-col sm:!flex-row justify-between items-start sm:items-center bg-white p-2 gap-2\">\n <div className=\"flex flex-1 flex-col sm:flex-row items-center gap-2 justify-start\">\n <div className=\" w-full flex gap-x-3\">\n {search?.enabled && (\n <section className=\"sm:w-56\">\n <DebouncedInput\n type=\"text\"\n placeholder=\"Enter search here...\"\n className=\"h-9\"\n onChange={handleSearch}\n debounce={search?.debounceRate}\n id={`${id}-search-input`}\n />\n </section>\n )}\n <div className=\" flex gap-2\">\n {onRefetch && (\n <Button\n onClick={handleRefetch}\n title=\"Refetch Data\"\n disabled={isRefetching}\n variant=\"outlined\"\n className=\"!border-[#DEDEDE] !text-gray-800 !px-[10px] !py-[8px] \"\n size={\"sm\"}\n id={`${id}-refetch-button`}\n >\n <RotateCw\n className={cn(\"w-4 h-4\", {\n \"animate-spin\": isRefetching,\n })}\n size={5}\n />\n </Button>\n )}\n\n {filterListOptions?.length ? (\n <FilterPopover\n setAppliedFilters={setAppliedFilters}\n filters={filterListOptions}\n id={`${id}-filter-popover`}\n />\n ) : null}\n\n {FilterMenu && (\n <Popover\n id={`${id}-deprecated-filter-popover`}\n trigger={\n <button\n title=\"Filter\"\n className={cn(\n \"!border-[#DEDEDE] !text-gray-800 !px-[10px] !py-[8px]\",\n buttonVariants({\n variant: \"outlined\",\n size: \"sm\",\n }),\n )}\n >\n <ListFilter className=\"w-4 h-4\" size={5} />\n </button>\n }\n >\n {FilterMenu}\n </Popover>\n )}\n </div>\n </div>\n </div>\n <div className=\"flex items-start flex-col gap-2 justify-center\">\n <section className=\"flex flex-col-reverse sm:flex-row gap-2\">\n <div className=\"flex gap-2\">\n {ExtraNode && ExtraNode}\n\n {onExport && (\n <Button\n variant=\"primary\"\n onClick={onExport}\n size={\"sm\"}\n id={`${id}-export-button`}\n >\n Export\n </Button>\n )}\n {download?.enabled && (\n <Button\n variant=\"primary\"\n leftNode={<Download className=\"w-4 h-5\" size={5} />}\n onClick={download?.onDownload}\n id={download.buttonId}\n size={\"sm\"}\n >\n {download?.buttonText}\n </Button>\n )}\n </div>\n </section>\n </div>\n </div>\n )}\n </>\n );\n};\n","\"use client\";\n\nimport React, { useEffect, useState } from \"react\";\nimport { useForm, Controller } from \"react-hook-form\";\nimport { Select } from \"../../select\";\nimport { Input, InputProps } from \"../../input\";\nimport { buttonVariants } from \"../../button\";\nimport { RadioGroup, RadioGroupItem } from \"../../radio\";\nimport { v4 } from \"uuid\";\nimport { FormLabel } from \"../../label/FormLabel\";\nimport { CalendarInput } from \"../../calendar/CalendarInput\";\nimport { useFilterStore } from \"./helper/useFilterStore\";\nimport { PopoverClose } from \"@radix-ui/react-popover\";\nimport { cn } from \"@/src/utils\";\n\ntype SelectOption = {\n value: string;\n label: string;\n};\n\ntype Base = {\n type: \"input\" | \"drop-down\" | \"date-range\" | \"multi\" | \"date\" | \"radio\";\n key: string;\n label: string;\n placeholder?: string;\n};\n\ntype FilterListOption = {\n type: \"input\";\n} & Exclude<InputProps, \"value\" | \"onChange\">;\n\ntype FilterListDate = {\n type: \"date\";\n date?: string | Date;\n};\ntype FilterListInputDropDown = {\n type: \"drop-down\" | \"multi\" | \"radio\";\n options: SelectOption[];\n};\n\nexport type FilterListItem = Base &\n (FilterListOption | FilterListInputDropDown | FilterListDate);\n\nexport type FilterContentProps = {\n filters: FilterListItem[];\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n values?: Record<string, any>;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setAppliedFilters?: (values: Record<string, any>) => void;\n id?: string;\n};\n\nexport type FilterListOptions = FilterListItem[];\n\nexport const FilterContent: React.FC<FilterContentProps> = ({\n filters,\n values = {},\n setAppliedFilters,\n id = \"filter-content\",\n}) => {\n const filterStore = useFilterStore();\n\n const { upDateFilter, resetFilters, filters: cachedFilters } = filterStore();\n\n const [syncFilter, setSyncFilter] = useState(true);\n\n const handleFiltersSync = () => {\n setSyncFilter(true);\n };\n\n const { control, handleSubmit } = useForm({\n defaultValues: cachedFilters ?? values,\n });\n\n useEffect(() => {\n if (syncFilter && setAppliedFilters) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setAppliedFilters(cachedFilters as any);\n setSyncFilter(false);\n }\n }, [syncFilter]);\n\n const handleReset = () => {\n resetFilters();\n handleFiltersSync();\n };\n\n const onSubmit = (\n values:\n | Record<string, unknown>\n | ((\n prev: Record<string, unknown> | null,\n ) => Record<string, unknown> | null)\n | null,\n ) => {\n const filtered = Object.fromEntries(\n Object.entries(values ?? {}).filter(\n ([, v]) => v !== undefined && v !== null && v !== \"\",\n ),\n );\n\n upDateFilter(filtered);\n handleFiltersSync();\n };\n\n return (\n <form onSubmit={handleSubmit(onSubmit)}>\n <div className=\"space-y-3\">\n {filters.map((filter) => {\n switch (filter.type) {\n case \"input\":\n return (\n <div key={filter.key}>\n <Controller\n name={filter.key}\n control={control}\n render={({ field, formState }) => (\n <Input\n error={formState?.errors?.root?.message}\n placeholder={filter?.placeholder}\n id={`${id}-${filter.key}`}\n {...field}\n {...filter}\n />\n )}\n />\n </div>\n );\n case \"drop-down\":\n return (\n <div key={filter.key}>\n <Controller\n name={filter.key}\n control={control}\n render={({\n field: { value, onChange },\n formState: { errors },\n }) => {\n return (\n <Select\n label={filter?.label}\n options={filter?.options}\n value={filter?.options?.find(\n (option) => String(option?.value) === String(value),\n )}\n onChange={(val) => onChange(val?.value)}\n error={errors?.[filter?.key]?.message as string}\n modal\n placeholder={filter?.placeholder}\n className=\"!h-10\"\n id={`${id}-${filter.key}`}\n />\n );\n }}\n />\n </div>\n );\n\n case \"radio\":\n return (\n <div key={filter.key}>\n <Controller\n name={filter.key}\n control={control}\n render={({ field: { value, onChange } }) => (\n <>\n <FormLabel className=\"block text-sm font-medium mb-2 text-pallet-text-white-black\">\n {filter?.label}\n </FormLabel>\n <RadioGroup\n onValueChange={onChange}\n defaultValue={value}\n aria-label={filter?.label}\n id={`${id}-${filter.key}`}\n >\n <div className=\"flex items-center gap-2\">\n {filter?.options?.map((option) => (\n <div\n key={v4()}\n className=\"flex items-center space-x-2\"\n >\n <RadioGroupItem\n value={option?.value}\n id={`${id}-${filter.key}-${option?.value}`}\n />\n <label\n htmlFor={`${id}-${filter.key}-${option?.value}`}\n className=\"text-xs\"\n >\n {option?.label}\n </label>\n </div>\n ))}\n </div>\n </RadioGroup>\n </>\n )}\n />\n </div>\n );\n case \"date\":\n return (\n <div key={filter.key}>\n <Controller\n name={filter.key}\n control={control}\n render={({ field }) => (\n <CalendarInput\n onChange={field?.onChange}\n value={field?.value}\n label={filter?.label}\n />\n )}\n />\n </div>\n );\n default:\n return null;\n }\n })}\n </div>\n <div style={{ marginTop: 28 }} className=\"grid grid-cols-2 gap-2\">\n <PopoverClose\n onClick={handleReset}\n className={cn(buttonVariants({ variant: \"outlined\", size: \"sm\" }))}\n type=\"button\"\n id={`${id}-reset-button`}\n >\n Reset\n </PopoverClose>\n <PopoverClose\n className={cn(buttonVariants({ size: \"sm\" }))}\n type=\"submit\"\n id={`${id}-submit-button`}\n >\n Submit\n </PopoverClose>\n </div>\n </form>\n );\n};\n","\"use client\";\n\nimport * as React from \"react\";\nimport * as RadioGroupPrimitive from \"@radix-ui/react-radio-group\";\nimport { cn } from \"../../utils\";\n\ntype RadioGroupProps = React.ComponentPropsWithoutRef<\n typeof RadioGroupPrimitive.Root\n> & {\n className?: string;\n};\n\ntype RadioGroupItemProps = React.ComponentPropsWithoutRef<\n typeof RadioGroupPrimitive.Item\n> & {\n className?: string;\n};\n\nconst RadioGroup = React.forwardRef<\n React.ElementRef<typeof RadioGroupPrimitive.Root>,\n RadioGroupProps\n>(({ className, ...props }, ref) => {\n return (\n <RadioGroupPrimitive.Root\n className={cn(\"grid gap-2\", className)}\n {...props}\n ref={ref}\n />\n );\n});\nRadioGroup.displayName = RadioGroupPrimitive.Root.displayName;\n\nconst RadioGroupItem = React.forwardRef<\n React.ElementRef<typeof RadioGroupPrimitive.Item>,\n RadioGroupItemProps\n>(({ className, ...props }, ref) => {\n return (\n <RadioGroupPrimitive.Item\n ref={ref}\n className={cn(\n `aspect-square h-4 w-4 rounded-full border border-[#808080] text-primary-main ring-offset-background focus-visible:outline-none \n\t\t\t\t\t\tfocus-visible:border-purplring-purple-200 focus-visible:!ring-primary-main focus-visible:!ring-status-success-bg focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 focus-visible:ring-purple-200 \n\t\t\t\t\t\tfocus:border-purplring-purple-200 focus:!ring-primary-main focus:!ring-status-success-bg focus:ring-2 focus:ring-ring focus:ring-offset-2 focus:ring-purple-200 disabled:cursor-not-allowed disabled:opacity-50`,\n className,\n )}\n {...props}\n >\n <RadioGroupPrimitive.Indicator className=\"rounded-full flex items-center justify-center\">\n <div className=\"h-2 w-2 bg-current text-current rounded-full transition\" />\n </RadioGroupPrimitive.Indicator>\n </RadioGroupPrimitive.Item>\n );\n});\nRadioGroupItem.displayName = RadioGroupPrimitive.Item.displayName;\n\nexport { RadioGroup, RadioGroupItem };\n","\"use client\";\n\nimport * as React from \"react\";\nimport { DayPickerSingleProps } from \"react-day-picker\";\nimport { PopoverContent, PopoverRoot, PopoverTrigger } from \"../popover\";\nimport { cn } from \"../../utils\";\nimport { Calendar } from \".\";\nimport { FormLabel } from \"../label/FormLabel\";\nimport { VariantProps } from \"class-variance-authority\";\nimport { inputContainerVariants } from \"../input\";\n\ninterface DateInputButtonProps\n extends VariantProps<typeof inputContainerVariants> {\n value?: React.ReactNode;\n onClick?: () => void;\n error?: string;\n}\n\nexport const DateInputButton = React.forwardRef<\n HTMLButtonElement,\n DateInputButtonProps\n>(({ value, onClick, error, status }, ref) => (\n <div className=\"relative mt-2 rounded-md shadow-sm !w-full\">\n <button\n className={cn(\n inputContainerVariants({ status }),\n \"flex items-center gap-2 text\",\n // \"pl-3 text-left block w-full rounded-md border-0 py-1.5 pr-10 ring-1 ring-inset focus:ring-2 focus:ring-inset disabled:cursor-not-allowed disabled:bg-gray-50 disabled:text-gray-500 disabled:ring-gray-200 sm:text-sm sm:leading-6\",\n {\n \"text-gray-900 ring-gray-300 placeholder:text-gray-400 focus:ring-purple-600\":\n !error,\n \"text-red-900 ring-red-300 placeholder:text-red-300 focus:ring-red-500\":\n error,\n },\n )}\n onClick={onClick}\n ref={ref}\n type=\"button\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"18\"\n height=\"18\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n className=\"lucide lucide-calendar-icon lucide-calendar\"\n >\n <path d=\"M8 2v4\" />\n <path d=\"M16 2v4\" />\n <rect width=\"18\" height=\"18\" x=\"3\" y=\"4\" rx=\"2\" />\n <path d=\"M3 10h18\" />\n </svg>\n {value || \"Select a date\"}\n </button>\n </div>\n));\n\nDateInputButton.displayName = \"DateInputButton\";\n\ninterface DateTriggerProps {\n // extends VariantProps<typeof inputContainerVariants>\n value: Date | undefined;\n placeholder?: string;\n className?: string;\n disabled?: boolean;\n isLoading?: boolean;\n error?: string;\n status?: \"default\" | \"error\" | \"loading\" | \"prefilled\";\n}\n\nconst format = (date: Date | undefined, placeholder: React.ReactNode) => {\n return date\n ? new Date(date).toLocaleDateString(\"en-US\", {\n year: \"numeric\",\n month: \"long\",\n day: \"numeric\",\n })\n : placeholder;\n};\n\nfunction Trigger({\n // status,\n value,\n className,\n placeholder = \"Pick a date\",\n ...props\n}: DateTriggerProps) {\n return (\n <PopoverTrigger asChild className={cn(\"cursor-pointer\", className)}>\n <DateInputButton\n value={format(value, placeholder)}\n error={props?.error}\n />\n </PopoverTrigger>\n );\n}\n\ntype DateProps = {\n children: React.ReactNode;\n modal?: boolean;\n disableDate?: boolean;\n} & Omit<DayPickerSingleProps, \"mode\">;\n\nfunction Picker({\n children,\n captionLayout = \"dropdown-buttons\",\n fromYear = 1900,\n toYear = new Date().getFullYear(),\n disableDate,\n modal,\n ...props\n}: DateProps) {\n const [open, setOpen] = React.useState(false);\n return (\n <PopoverRoot\n modal={modal}\n open={disableDate ? false : open}\n onOpenChange={setOpen}\n >\n {children}\n <PopoverContent align=\"start\" className=\"w-auto p-0\">\n <Calendar\n mode=\"single\"\n fromYear={fromYear}\n toYear={toYear}\n captionLayout={captionLayout}\n initialFocus\n classNames={{}}\n showOutsideDays={false}\n {...props}\n />\n </PopoverContent>\n </PopoverRoot>\n );\n}\n\nexport const formatFormDate = (\n date?: number | Date | string | null,\n dateFormat = \"yyyy-MM-dd\",\n) => {\n if (date) return String(format(new Date(date), dateFormat));\n return \"N/A\";\n};\n\ntype CalendarInputProps = {\n label?: string;\n helpText?: string | React.ReactNode;\n error?: string;\n optional?: boolean;\n onChange: (value: string | null) => void;\n value?: string;\n};\n\nconst CalendarInput = ({\n label,\n optional,\n onChange,\n error,\n helpText,\n value,\n}: CalendarInputProps) => {\n return (\n <div className=\"block w-full\">\n {label && (\n <div className=\"flex justify-between w-full\">\n <FormLabel className=\"block text-sm font-medium mb-0 text-pallet-text-white-black\">\n {label}\n </FormLabel>\n {optional && (\n <span\n className=\"text-sm leading-6 text-gray-500\"\n id=\"email-optional\"\n >\n Optional\n </span>\n )}\n </div>\n )}\n <Picker\n selected={value ? new Date(value) : undefined}\n onSelect={(date) => {\n const formattedDate = date ? formatFormDate(date, \"yyyy-MM-dd\") : \"\";\n // const formattedDate = formatFormDate(date, 'Y-m-d H:i:s');\n onChange(formattedDate);\n }}\n disabled={(date: Date) =>\n date < new Date(\"2000-01-01\") || date > new Date(\"3000-01-01\")\n }\n fromYear={2000}\n toYear={3000}\n >\n <div>\n <Trigger\n status={error ? \"error\" : \"default\"}\n value={value ? new Date(value) : undefined}\n />\n </div>\n </Picker>\n {error && (\n <p className=\"mt-2 text-sm text-red-600\" id={`${name}-error`}>\n {error}\n </p>\n )}\n\n {helpText && (\n <p className=\"mt-2 text-sm text-gray-500\" id={`${name}-description`}>\n {helpText}\n </p>\n )}\n </div>\n );\n};\n\nexport { Picker, Trigger, CalendarInput };\n","import { ChevronLeft, ChevronRight } from \"lucide-react\";\nimport * as React from \"react\";\nimport { DayPicker, DropdownProps, StyledElement } from \"react-day-picker\";\n\nimport { cn } from \"../../utils\";\nimport { Select } from \"../select\";\nimport { buttonVariants } from \"../button\";\n\nexport type CalendarProps = React.ComponentProps<typeof DayPicker> & {\n className?: string;\n classNames: Partial<StyledElement<string>> | undefined;\n showOutsideDays: boolean;\n};\n\nfunction Calendar({\n className,\n classNames,\n showOutsideDays = true,\n ...props\n}: CalendarProps) {\n return (\n <DayPicker\n showOutsideDays={showOutsideDays}\n className={cn(\"p-3\", className)}\n classNames={{\n months: \"flex flex-col sm:flex-row space-y-4 sm:space-x-4 sm:space-y-0\",\n month: \"space-y-4\",\n caption: \"flex justify-center pt-1 relative items-center\",\n caption_label: \"text-sm font-medium hidden\",\n\n // months: \"flex flex-col sm:flex-row space-y-4 sm:space-x-4 sm:space-y-0\",\n // month: \"space-y-4\",\n // caption: \"flex justify-center pt-1 relative items-center\",\n // caption_label: \"text-sm font-medium\",\n caption_dropdowns: \"flex justify-center gap-1 !px-4\",\n\n nav: \"space-x-1 flex items-center\",\n nav_button: cn(\n buttonVariants({ variant: \"outlined\" }),\n \"h-7 w-7 bg-transparent !text-black !border-0 p-0 opacity-50 hover:opacity-100\",\n ),\n nav_button_previous: \"absolute left-1\",\n nav_button_next: \"absolute right-1\",\n table: \"w-full border-collapse space-y-1\",\n head_row: \"flex\",\n head_cell:\n \"text-muted-foreground rounded-md w-9 font-normal text-[0.8rem]\",\n row: \"flex w-full mt-2\",\n cell: \"h-9 w-9 text-center text-sm p-0 relative [&:has([aria-selected].day-range-end)]:rounded-r-md [&:has([aria-selected].day-outside)]:bg-accent/50 [&:has([aria-selected])]:bg-accent first:[&:has([aria-selected])]:rounded-l-md last:[&:has([aria-selected])]:rounded-r-md focus-within:relative focus-within:z-20\",\n day: cn(\n buttonVariants({ variant: \"primary\" }),\n \"h-9 w-9 p-0 font-normal aria-selected:opacity-100 bg-white text-black/60\",\n ),\n day_range_end: \"day-range-end\",\n day_selected:\n \"!bg-primary-main !text-white hover:bg-primary hover:text-primary-foreground focus:bg-primary focus:text-primary-foreground\",\n day_today: \"bg-accent text-accent-foreground\",\n day_outside:\n \"day-outside text-muted-foreground aria-selected:bg-accent/50 aria-selected:text-muted-foreground\",\n day_disabled: \"text-muted-foreground opacity-50\",\n day_range_middle:\n \"aria-selected:bg-accent aria-selected:text-accent-foreground\",\n day_hidden: \"invisible\",\n ...classNames,\n }}\n components={{\n IconLeft: ({ ...props }) => (\n <ChevronLeft className=\"h-4 w-4\" {...props} />\n ),\n IconRight: ({ ...props }) => (\n <ChevronRight className=\"h-4 w-4\" {...props} />\n ),\n Dropdown: ({ value, onChange, children }: DropdownProps) => {\n const lgOptions = React.Children.toArray(\n children,\n ) as React.ReactElement<React.HTMLProps<HTMLOptionElement>>[];\n const options = lgOptions.map((option) => ({\n label: option.props.children as string,\n value: option.props.value?.toString() ?? \"\",\n }));\n\n // const selected = options.find((child) => child.value === value);\n\n const handleChange = (value: string) => {\n const changeEvent = {\n target: { value },\n } as React.ChangeEvent<HTMLSelectElement>;\n onChange?.(changeEvent);\n };\n\n return (\n <div className=\"\">\n <Select\n options={options}\n // getOptionLabel={(option) =>\n // (option?.props?.children as any) ?? \"\"\n // }\n // onInputValueChange={(value) => {\n // handleChange(value);\n // }}\n // getOptionValue={(option) => (option?.props?.value as any) ?? \"\"}\n value={options?.find(\n (option) => option?.value === value?.toString(),\n )}\n // size=\"xs\"\n onChange={(val) => handleChange(val?.value)}\n className=\"!border-0 !max-w-max\"\n // showShadow={false}\n // status='plain'\n />\n </div>\n );\n },\n }}\n disabled={(date) => date > new Date() || date < new Date(\"1900-01-01\")}\n // mode=\"single\"\n {...props}\n />\n );\n}\nCalendar.displayName = \"Calendar\";\n\nexport { Calendar };\n","\"use client\";\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { create } from \"zustand\";\n\ninterface FilterSliceType {\n filters: Record<string, any> | null;\n upDateFilter: (\n items:\n | Record<string, any>\n | ((prev: Record<string, any> | null) => Record<string, any> | null)\n | null,\n ) => void;\n resetFilters: () => void;\n}\n\nexport const FILTER_PREFIX = \"filter_\";\n\nconst syncFiltersWithURL = (filters: Record<string, any>) => {\n const params = new URLSearchParams(window?.location?.search);\n Object.keys(filters).forEach((key) => {\n params.set(`${FILTER_PREFIX}${key}`, filters[key]);\n });\n window.history.replaceState({}, \"\", `${window.location.pathname}?${params}`);\n};\n\nconst clearFiltersFromURL = () => {\n const params = new URLSearchParams(window.location.search);\n const keysToDelete: string[] = [];\n params.forEach((_, key) => {\n if (key.startsWith(FILTER_PREFIX)) {\n keysToDelete.push(key);\n }\n });\n keysToDelete.forEach((key) => params.delete(key));\n window.history.replaceState({}, \"\", `${window.location.pathname}?${params}`);\n};\n\nconst initializeFiltersFromURL = () => {\n if (typeof window === \"undefined\") {\n return {};\n }\n const params = new URLSearchParams(window.location.search);\n const filters: Record<string, any> = {};\n params.forEach((value, key) => {\n if (key.startsWith(FILTER_PREFIX)) {\n filters[key.replace(FILTER_PREFIX, \"\")] = value;\n }\n });\n return filters;\n};\n\nexport const createFilterStore = () => {\n return create<FilterSliceType>()((set) => ({\n filters: initializeFiltersFromURL(),\n resetFilters: () => {\n set({ filters: null });\n clearFiltersFromURL();\n },\n upDateFilter: (\n items:\n | Record<string, any>\n | ((prev: Record<string, any> | null) => Record<string, any> | null)\n | null,\n ) =>\n set((state) => {\n let newFilters;\n if (typeof items === \"function\") {\n newFilters = items(state.filters);\n } else {\n newFilters = { ...state?.filters, ...items };\n }\n syncFiltersWithURL(newFilters);\n return { filters: newFilters };\n }),\n }));\n};\n\nexport const useFilterStore = () => {\n const store = createFilterStore();\n\n return store;\n};\n","\"use client\";\n\nimport { cn } from \"@/src/utils\";\nimport { Popover } from \"../../popover\";\nimport { FilterContent, FilterContentProps } from \"./FilterContent\";\nimport { buttonVariants } from \"../../button\";\nimport { ListFilter } from \"lucide-react\";\nimport { ReactNode } from \"react\";\nimport { FilterLabelCount } from \"./components/FilterLabelCount\";\nimport { useMountClient } from \"@/src/hooks/useMountClient\";\n\ntype FilterPopoverProps = FilterContentProps & {\n isOpen?: boolean;\n trigger?: ReactNode;\n id?: string;\n};\n\nexport const FilterPopover = ({\n filters,\n setAppliedFilters,\n isOpen = false,\n id = \"filter-popover\",\n}: FilterPopoverProps) => {\n const { mounted: isClientMounted } = useMountClient();\n\n return isClientMounted ? (\n <div className=\"\">\n <Popover\n id={`${id}-filter-popover`}\n defaultOpen={isOpen}\n trigger={\n <button\n title=\"Filter\"\n className={cn(\n \"!border-[#DEDEDE] !text-gray-800 !p-0 flex items-center\",\n buttonVariants({\n variant: \"outlined\",\n size: \"sm\",\n }),\n )}\n type=\"button\"\n >\n <span className=\"!px-[10px] !py-[8px]\">\n <ListFilter className=\"w-4 h-4\" size={5} />\n </span>\n <FilterLabelCount setAppliedFilters={setAppliedFilters} />\n </button>\n }\n contentClassName=\"!border border-gray-200 pt-2\"\n >\n <FilterContent\n filters={filters}\n setAppliedFilters={setAppliedFilters}\n id={id}\n />\n </Popover>\n </div>\n ) : null;\n};\n","import { useEffect, useState } from \"react\";\nimport { useFilterStore } from \"../helper/useFilterStore\";\n\ntype Props = {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setAppliedFilters?: (values: Record<string, any>) => void;\n};\n\nexport const FilterLabelCount = ({ setAppliedFilters }: Props) => {\n const [syncFilter, setSyncFilter] = useState(true);\n const filterStore = useFilterStore();\n\n const { filters: cachedFilters } = filterStore();\n\n console.log(\"cachedFilters\", cachedFilters);\n\n const cachedKeys = Object.keys(cachedFilters ?? {});\n\n useEffect(() => {\n if (syncFilter && setAppliedFilters) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setAppliedFilters(cachedFilters as any);\n setSyncFilter(false);\n }\n }, [syncFilter]);\n\n return (\n <>\n {cachedKeys?.length ? (\n <div className=\"flex rounded-s-md bg-primary-main p-1 text-white text-sm px-2.5\">\n {cachedKeys?.length}\n </div>\n ) : (\n <></>\n )}\n </>\n );\n};\n","import { ReactNode, useEffect, useState } from \"react\";\n\nexport const useMountClient = () => {\n const [mounted, setMounted] = useState(false);\n\n useEffect(() => {\n setMounted(true);\n\n return () => setMounted(false);\n }, []);\n\n const MounClient = (children?: ReactNode) => {\n return mounted ? { children } : null;\n };\n return { mounted, MounClient };\n};\n","import { createContext, ReactNode, useMemo } from \"react\";\nimport { ResourcePermissions } from \"@/src/components/permission/types\";\n\nexport const PermissionsContext = createContext<\n ResourcePermissions | undefined\n>(undefined);\n\nexport const PermissionsProvider = ({\n permissions,\n children,\n}: {\n permissions: ResourcePermissions;\n children: ReactNode;\n}) => {\n const value = useMemo(() => permissions, [permissions]);\n return (\n <PermissionsContext.Provider value={value}>\n {children}\n </PermissionsContext.Provider>\n );\n};\n","import { useCallback, useContext, useMemo } from \"react\";\nimport { PermissionsContext } from \"./context\";\n\nexport const usePermissions = () => {\n const permissions = useContext(PermissionsContext);\n return permissions;\n};\n\nexport const useHasPermission = (permission: {\n resource?: string;\n action?: string;\n}) => {\n const permissions = usePermissions();\n\n const validatePermission = useCallback(\n (permission: { resource?: string; action?: string }) => {\n if (!permissions || !permission) return true;\n\n const hasAdminAccess = permissions.some(\n (p) => p.resource === \"all\" && p.action === \"administrator\",\n );\n\n if (hasAdminAccess) return true;\n\n const { resource, action } = permission;\n const matchingPermissions = permissions.filter(\n (p) => p.resource === resource,\n );\n const hasExactMatch = matchingPermissions.some(\n (p) => p.action === action,\n );\n if (hasExactMatch) return true;\n if (action === \"read\") {\n return matchingPermissions.some((p) => p.action === \"write\");\n }\n return false;\n },\n [permission],\n );\n\n const hasPermission = useMemo(\n () => validatePermission(permission),\n [permissions, permission],\n );\n\n return { hasPermission, validatePermission };\n};\n","import { useHasPermission } from \"./hook\";\nimport { ResourcePermissionProps } from \"./types\";\n\nexport const HasResourcePermission = ({\n permission,\n children,\n}: ResourcePermissionProps) => {\n const { hasPermission } = useHasPermission(permission || {});\n\n if (!permission) return <>{children}</>;\n\n return <>{hasPermission ? children : null}</>;\n};\n","export const CurrencySymbolMap: Record<string, string> = {\n USD: \"$\",\n CAD: \"CA$\",\n EUR: \"€\",\n AED: \"AED\",\n AFN: \"Af\",\n ALL: \"ALL\",\n AMD: \"AMD\",\n ARS: \"AR$\",\n AUD: \"AU$\",\n AZN: \"man.\",\n BAM: \"KM\",\n BDT: \"Tk\",\n BGN: \"BGN\",\n BHD: \"BD\",\n BIF: \"FBu\",\n BND: \"BN$\",\n BOB: \"Bs\",\n BRL: \"R$\",\n BWP: \"BWP\",\n BYN: \"Br\",\n BZD: \"BZ$\",\n CDF: \"CDF\",\n CHF: \"CHF\",\n CLP: \"CL$\",\n CNY: \"CN¥\",\n COP: \"CO$\",\n CRC: \"₡\",\n CVE: \"CV$\",\n CZK: \"Kč\",\n DJF: \"Fdj\",\n DKK: \"Dkr\",\n DOP: \"RD$\",\n DZD: \"DA\",\n EEK: \"Ekr\",\n EGP: \"EGP\",\n ERN: \"Nfk\",\n ETB: \"Br\",\n GBP: \"£\",\n GEL: \"GEL\",\n GHS: \"GH₵\",\n GNF: \"FG\",\n GTQ: \"GTQ\",\n HKD: \"HK$\",\n HNL: \"HNL\",\n HRK: \"kn\",\n HUF: \"Ft\",\n IDR: \"Rp\",\n ILS: \"₪\",\n INR: \"₹\",\n IQD: \"IQD\",\n IRR: \"IRR\",\n ISK: \"Ikr\",\n JMD: \"J$\",\n JOD: \"JD\",\n JPY: \"¥\",\n KES: \"Ksh\",\n KHR: \"KHR\",\n KMF: \"CF\",\n KRW: \"₩\",\n KWD: \"KD\",\n KZT: \"KZT\",\n LBP: \"L.L.\",\n LKR: \"SLRs\",\n LTL: \"Lt\",\n LVL: \"Ls\",\n LYD: \"LD\",\n MAD: \"MAD\",\n MDL: \"MDL\",\n MGA: \"MGA\",\n MKD: \"MKD\",\n MMK: \"MMK\",\n MOP: \"MOP$\",\n MUR: \"MURs\",\n MXN: \"MX$\",\n MYR: \"RM\",\n MZN: \"MTn\",\n NAD: \"N$\",\n NGN: \"₦\",\n NIO: \"C$\",\n NOK: \"Nkr\",\n NPR: \"NPRs\",\n NZD: \"NZ$\",\n OMR: \"OMR\",\n PAB: \"B/.\",\n PEN: \"S/.\",\n PHP: \"₱\",\n PKR: \"PKRs\",\n PLN: \"zł\",\n PYG: \"₲\",\n QAR: \"QR\",\n RON: \"RON\",\n RSD: \"din.\",\n RUB: \"RUB\",\n RWF: \"RWF\",\n SAR: \"SR\",\n SDG: \"SDG\",\n SEK: \"Skr\",\n SGD: \"S$\",\n SOS: \"Ssh\",\n SYP: \"SY£\",\n THB: \"฿\",\n TND: \"DT\",\n TOP: \"T$\",\n TRY: \"TL\",\n TTD: \"TT$\",\n TWD: \"NT$\",\n TZS: \"TSh\",\n UAH: \"₴\",\n UGX: \"USh\",\n UYU: \"$U\",\n UZS: \"UZS\",\n VEF: \"Bs.F.\",\n VND: \"₫\",\n XAF: \"F CFA\",\n XOF: \"CFA\",\n YER: \"YR\",\n ZAR: \"R\",\n ZMK: \"ZK\",\n ZWL: \"ZWL$\",\n};\nexport interface FormatCurrencyOptions {\n convertToMajorCurrency?: boolean;\n locale?: string;\n}\nexport class AmountAction {\n static getCurrencyLocaleMap(currency: string): string {\n const localeMap: Record<string, string> = {\n XOF: \"fr\",\n XAF: \"fr\",\n };\n return localeMap[currency] || \"en\";\n }\n static koboToNaira(amount: number | string) {\n return +amount / 100;\n }\n\n static nairaToKobo(amount: number | string) {\n return +amount * 100;\n }\n\n static getCurrencySymbol(currency: string): string {\n return CurrencySymbolMap[currency] || currency;\n }\n\n static formatAmountAndCurrency = (\n currency: string,\n value: number | string,\n options: FormatCurrencyOptions,\n ) => {\n const formatted = new Intl.NumberFormat(\n options?.locale || this.getCurrencyLocaleMap(currency),\n {\n maximumFractionDigits: 3,\n style: \"currency\",\n currency: currency,\n currencyDisplay: \"symbol\",\n },\n )\n .format(\n options?.convertToMajorCurrency\n ? this.koboToNaira(Number(value))\n : Number(value),\n )\n .replace(/^(\\D+)/, \"$1 \")\n .replace(\" \", \" \")\n .replace(/\\s+/, \"\");\n\n // Now replace the currency code with the desired symbol from the map\n const customSymbol = CurrencySymbolMap[currency] || currency;\n\n // Replace the currency code with our custom symbol\n return formatted.replace(currency, customSymbol);\n };\n}\n","// import dayjs from \"dayjs\";\nimport dayjs from \"dayjs\";\nexport class DateAction {\n static getDateLibrary(): dayjs.Dayjs {\n return dayjs();\n }\n static formatTimestampToDate(timestamp: number, dateFormat?: string) {\n return dayjs\n .unix(timestamp)\n .format(dateFormat || \"ddd, MMM, YYYY | HH:mm:ss\");\n }\n\n static formatDateToTimestamp(date: string) {\n return dayjs(date).unix();\n }\n}\n\n// console.log(\"Date\", dayjs().format(\"DD, MMM, YYYY | HH:mm:ss\"));\n"],"mappings":"yKAEA,UAAYA,OAAW,QACvB,UAAYC,MAAsB,0BCHlC,OAAS,QAAAC,OAA6B,OACtC,OAAS,WAAAC,OAAe,iBAiBjB,SAASC,KAAMC,EAAsB,CAC1C,OAAOF,GAAQD,GAAKG,CAAM,CAAC,CAC7B,CDHE,cAAAC,GAsDQ,QAAAC,OAtDR,oBAVF,IAAMC,GAAmC,WAEnCC,GAA+B,OAE/BC,GAAkC,UAElCC,GAAuB,cAG3B,CAAC,CAAE,UAAAC,EAAW,WAAAC,EAAa,EAAG,GAAGC,CAAM,EAAGC,IAC1CT,GAAkB,UAAjB,CACC,IAAKS,EACL,WAAYF,EACZ,UAAWG,EACT,ujBACAJ,CACF,EACC,GAAGE,EAEH,SAAAA,EAAM,SAET,CACD,EAEDH,GAAe,YAA+B,UAAQ,YAiBtD,IAAMM,GAAU,CAAC,CACf,QAAAC,EACA,SAAAC,EACA,iBAAAC,EACA,iBAAAC,EACA,QAAAC,EAAU,GACV,KAAAC,EACA,WAAAV,EACA,MAAAW,EACA,YAAAC,EACA,cAAAC,EAAgB,IAChB,SAAAC,EAAW,GACX,eAAAC,EACA,GAAGd,CACL,IAGIR,GAACE,GAAA,CACC,SAAAF,GAACG,GAAA,CAAY,cAAeiB,EAAgB,GAAGZ,EAC7C,SAAAP,GAAC,OAAI,UAAU,mCACb,UAAAD,GAACI,GAAA,CAAe,QAASY,EAAS,UAAWD,EAC1C,SAAAH,EACH,EACAX,GAACI,GAAA,CACC,KAAMY,EACN,WAAYV,EACZ,MAAOW,EACP,YAAaC,EACb,UAAWL,EAEV,UAAAD,EACAQ,GACCrB,GAAkB,QAAjB,CACC,UAAWU,EAAG,aAAcY,CAAc,EAC5C,GAEJ,GACF,EACF,EACF,EAGJX,GAAQ,YAAc,UE1FtB,OAAOY,OAAW,QCElB,UAAYC,OAAW,QACvB,UAAYC,OAAoB,wBAChC,OAAS,OAAAC,OAA8B,2BAarC,cAAAC,OAAA,oBATF,IAAMC,GAAgBC,GACpB,4FACF,EAEMC,GAAc,cAIlB,CAAC,CAAE,UAAAC,EAAW,GAAGC,CAAM,EAAGC,IAC1BN,GAAgB,QAAf,CACC,IAAKM,EACL,UAAWC,EAAGN,GAAc,EAAGG,CAAS,EACvC,GAAGC,EACN,CACD,EACDF,GAAM,YAA6B,QAAK,YDDhC,OAEE,OAAAK,GAFF,QAAAC,OAAA,oBAhBR,IAAMC,EAAYC,GAAM,WAOtB,CAAC,CAAE,UAAAC,EAAW,SAAAC,EAAU,aAAAC,EAAc,MAAAC,EAAO,GAAGC,CAAM,EAAGC,IAEvDT,GAACU,GAAA,CACC,IAAKD,EACL,UAAWE,EAAGJ,GAAS,eAAgBH,CAAS,EAE/C,GAAGI,EAEH,SAAAF,EACCL,GAAC,KACE,UAAAI,EACDL,GAAC,QAAK,UAAU,eAAe,aAAC,GAClC,EAEAK,EAEJ,CAEH,EAEDH,EAAU,YAAc,YEvBpB,OAOE,OAAAU,GAPF,QAAAC,OAAA,oBARG,IAAMC,GAAS,CAAC,CACrB,KAAAC,EAAO,GACP,OAAAC,EAAS,SACX,IAKIH,GAAC,OACC,UAAU,eACV,MAAOE,EACP,OAAQA,EACR,QAAQ,YACR,KAAK,OAEL,UAAAH,GAAC,UAAO,GAAG,KAAK,GAAG,KAAK,EAAE,OAAO,OAAO,cAAc,YAAY,MAAM,EACxEA,GAAC,QACC,EAAE,i8BACF,KAAMI,IAAW,UAAY,UAAY,eACzC,UAAU,UACZ,GACF,ECrBJ,UAAYC,OAAW,QACvB,OAAS,QAAAC,OAAY,uBACrB,OAAS,OAAAC,OAA8B,2BAoGzB,mBAAAC,GAEI,OAAAC,GAIJ,QAAAC,OANA,oBA7Fd,IAAMC,EAAiBC,GACrB,mTACA,CACE,SAAU,CACR,QAAS,CACP,QACE,gHACF,OACE,4FACF,QACE,kFACF,SACE,oFACF,kBACE,0EACF,iBACE,+DACF,YACE,uGACF,MACE,mGACJ,EACA,KAAM,CAGJ,QACE,qFACF,GAAI,yEACJ,GAAI,+EACJ,GAAI,qFACJ,UACE,kFACF,KAAM,iFACN,UACE,2EACJ,CACF,EACA,gBAAiB,CACf,QAAS,UACT,KAAM,SACR,CACF,CACF,EAgBMC,GAAe,cACnB,CACE,CACE,UAAAC,EACA,QAAAC,EAAU,UACV,KAAAC,EACA,QAAAC,EAAU,GACV,UAAAC,EAAY,GACZ,SAAAC,EACA,UAAAC,EACA,WAAAC,EAEA,GAAGC,CACL,EACAC,IACG,CACH,IAAMC,EAAYP,EAAUQ,GAAO,SAE7B,CAAE,SAAAC,EAAU,SAAAC,EAAU,GAAGC,CAAK,EAAIN,EAClCO,EAAkB,UAA0B,IAAI,EAEtD,OACEpB,GAACe,EAAA,CACC,UAAWM,EAAGnB,EAAe,CAAE,QAAAI,EAAS,KAAAC,EAAM,UAAAF,CAAU,CAAC,CAAC,EAC1D,IAAKe,GAAaN,EAClB,SAAUI,GAAYT,EACrB,GAAGU,EACJ,SACEnB,GAAC,OAAI,UAAU,qDAMZ,SAAAS,EACCT,GAAAD,GAAA,CACE,SAAAC,GAAC,QAAK,UAAU,UACd,SAAAA,GAACsB,GAAA,CAAO,KAAMV,EAAY,OAAO,YAAY,EAC/C,EACF,EAEAX,GAAAF,GAAA,CACG,UAAAW,EACAO,EACAN,GACH,EAEJ,EAEJ,CAEJ,CACF,EAEAP,GAAO,YAAc,SCzHrB,UAAYmB,OAAW,QAGvB,OAAS,OAAAC,OAA8B,2BCJvC,OAAOC,OAAW,QAed,cAAAC,OAAA,oBAbJ,IAAMC,EAAeF,GAAM,WAKzB,CAAC,CAAE,UAAAG,EAAW,SAAAC,EAAU,MAAAC,EAAO,GAAGC,CAAM,EAAGC,IAAQ,CACnD,IAAMC,EAAOH,GAASD,EAEtB,OAAKI,EAKHP,GAAC,KACC,IAAKM,EACL,UAAWE,EAAG,qCAAsCN,CAAS,EAC5D,GAAGG,EAEH,SAAAE,EACH,EAVO,IAYX,CAAC,EACDN,EAAa,YAAc,eCxB3B,OAAOQ,OAAW,QAOd,cAAAC,OAAA,oBALJ,IAAMC,EAAkBF,GAAM,WAG5B,CAAC,CAAE,UAAAG,EAAW,GAAGC,CAAM,EAAGC,IAExBJ,GAAC,OACC,IAAKI,EACL,UAAWC,EAAG,wBAAyBH,CAAS,EAC/C,GAAGC,EACN,CAEH,EACDF,EAAgB,YAAc,kBFoBxB,cAAAK,GAsGE,QAAAC,OAtGF,oBAzBC,IAAMC,GAAgBC,GAC3B,iOACA,CACE,SAAU,CACR,OAAQ,CACN,QAAS,6DACT,MAAO,wCACP,QAAS,6DACT,UAAW,GACX,QAAS,EACX,CACF,EACA,gBAAiB,CACf,OAAQ,SACV,CACF,CACF,EAMMC,GAAuB,cAC3B,CAAC,CAAE,UAAAC,EAAW,OAAAC,EAAQ,KAAAC,EAAM,GAAGC,CAAM,EAAGC,IAEpCT,GAAC,SACC,KAAMO,EACN,UAAWG,EAAGR,GAAc,CAAE,OAAAI,CAAO,CAAC,EAAGD,CAAS,EAClD,IAAKI,EACJ,GAAGD,EACN,CAGN,EACAJ,GAAe,YAAc,iBAEtB,IAAMO,EAAyBR,GACpC,uRACA,CACE,SAAU,CACR,OAAQ,CACN,QACE,+PACF,MACE,kJACF,QAAS,GACT,UACE,uLACF,QACE,sLACJ,CACF,EACA,gBAAiB,CACf,OAAQ,SACV,CACF,CACF,EAEaS,GAAeT,GAC1B,iTACA,CACE,SAAU,CACR,KAAM,CACJ,KAAM,kCACN,MAAO,kCACT,EACA,OAAQ,CACN,QACE,gQACF,MACE,oIACF,QAAS,GACT,UACE,uLACF,QAAS,+CACX,CACF,EACA,gBAAiB,CACf,OAAQ,UACR,KAAM,MACR,CACF,CACF,EAeMU,EAAc,cAClB,CACE,CACE,UAAAR,EACA,OAAAC,EAAS,UACT,SAAAQ,EACA,MAAAC,EACA,UAAAC,EACA,kBAAAC,EACA,aAAAC,EACA,MAAAC,EACA,YAAAC,EACA,GAAGZ,CACL,EACAC,IACG,CACH,IAAIY,EACFf,EAEF,OAAIS,IAAOM,EAAkB,SACzBL,IAAWK,EAAkB,WAC7BP,IAAUO,EAAkB,aAG9BpB,GAAC,OAAI,UAAU,4BACZ,UAAAkB,GACCnB,GAACsB,EAAA,CAAU,aAAcJ,EAAc,MAAOH,EAC3C,SAAAI,EACH,EAEFlB,GAAC,OACC,UAAWS,EACTC,EAAuB,CAAE,OAAQU,CAAgB,CAAC,EAClDb,EAAM,SAAW,OAAS,GAC1BA,EAAM,UAAY,OAAS,GAC3BH,CACF,EAEC,UAAAG,EAAM,SACLR,GAAC,OACC,UAAWU,EACTE,GAAa,CACX,OAAQS,EACR,KAAM,MACR,CAAC,EACDJ,CACF,EAEC,SAAAT,EAAM,SACT,EACE,KACJR,GAACI,GAAA,CACC,IAAKK,EACL,SAAUO,GAAaF,EACvB,UAAWJ,EAAG,CACZ,QAASF,EAAM,UAAYF,IAAW,UACtC,QAASE,EAAM,WAAaF,IAAW,SACzC,CAAC,EACA,GAAGE,EACN,EACCA,EAAM,UACLR,GAAC,OACC,UAAWU,EACTE,GAAa,CACX,OAAQS,EACR,KAAM,OACR,CAAC,EACDJ,CACF,EAEC,SAAAT,EAAM,UACT,EACE,MACN,EACCY,GACCpB,GAACuB,EAAA,CAAgB,UAAU,qCACxB,SAAAH,EACH,EAEFpB,GAACwB,EAAA,CAAa,MAAOT,EAAO,GAC9B,CAEJ,CACF,EAmFAF,EAAM,YAAc,QGjRpB,OAAS,WAAAY,GAAS,YAAAC,OAAgB,QCE9B,OAOE,OAAAC,GAPF,QAAAC,OAAA,oBAFG,IAAMC,GAAM,IAEfD,GAAC,OACC,MAAM,KACN,OAAO,KACP,QAAQ,YACR,KAAK,OACL,MAAM,6BAEN,UAAAD,GAAC,QACC,EAAE,kfACF,OAAO,UACP,YAAY,IACZ,cAAc,QACd,eAAe,QACjB,EACAA,GAAC,QACC,EAAE,kJACF,OAAO,UACP,YAAY,IACZ,cAAc,QACd,eAAe,QACjB,GACF,ECrBA,OAOE,OAAAG,GAPF,QAAAC,OAAA,oBAFG,IAAMC,GAAS,IAElBD,GAAC,OACC,MAAM,KACN,OAAO,KACP,QAAQ,YACR,KAAK,OACL,MAAM,6BAEN,UAAAD,GAAC,QACC,EAAE,klBACF,OAAO,UACP,YAAY,MACZ,cAAc,QACd,eAAe,QACjB,EACAA,GAAC,QACC,EAAE,kYACF,OAAO,UACP,YAAY,MACZ,cAAc,QACd,eAAe,QACjB,GACF,ECdE,cAAAG,OAAA,oBATC,IAAMC,GAAQ,IAEjBD,GAAC,OACC,MAAM,KACN,OAAO,KACP,QAAQ,YACR,KAAK,OACL,MAAM,6BAEN,SAAAA,GAAC,QACC,EAAE,4HACF,KAAK,eACP,EACF,ECJE,cAAAE,OAAA,oBATC,IAAMC,GAAO,IAEhBD,GAAC,OACC,MAAM,KACN,OAAO,KACP,QAAQ,YACR,KAAK,OACL,MAAM,6BAEN,SAAAA,GAAC,QACC,EAAE,mGACF,OAAO,eACP,YAAY,MACZ,cAAc,QACd,eAAe,QACjB,EACF,EJsEM,OAOyC,OAAAE,EAPzC,QAAAC,OAAA,oBA9EV,IAAMC,GAAoB,CACxB,CACE,MAAO,YACP,IAAK,YACL,OAAQ,QACR,UAAW,EACb,EACA,CACE,MAAO,YACP,IAAK,YACL,OAAQ,QACR,UAAW,EACb,EACA,CACE,MAAO,SACP,IAAK,SACL,OAAQ,KACR,UAAW,EACb,EACA,CACE,MAAO,eACP,IAAK,cACL,OAAQ,OACR,UAAW,EACb,CACF,EAWMC,GAAgB,CAAC,CACrB,WAAAC,EACA,SAAAC,EACA,kBAAAC,EACA,GAAGC,CACL,IAA0B,CACxB,GAAM,CAACC,EAAiBC,CAAkB,EAAIC,GAAS,EAAK,EACtD,CAACC,EAAiBC,CAAkB,EAAIF,GAASR,EAAiB,EAElEW,EAAoBC,GACjBZ,GAAkB,IAAKa,IAAY,CACxC,GAAGA,EACH,UAAWA,EAAO,OAAO,KAAKD,CAAK,CACrC,EAAE,EAGEE,EAAyBF,GAAkB,CAC/C,IAAMG,EAAmBJ,EAAiBC,CAAK,EACzCI,EAAeD,EAAiB,MAAOF,GAAWA,EAAO,SAAS,EAExE,OAAAH,EAAmBK,CAAgB,EAE5BC,CACT,EAEMC,EACJC,GACG,CAGH,GAFIf,GAAUA,EAASe,CAAC,EAEpBd,EAAmB,OAEvB,IAAMQ,EAAQM,GAAG,QAAQ,MACnBC,EAAYL,EAAsBF,CAAK,EAEzCV,GAAYA,EAAWiB,EAAWP,CAAK,CAC7C,EAEMQ,EAAeC,GAAQ,IAEzBvB,EAAC,OAAI,UAAU,0BACZ,SAAAW,GAAiB,IAAKG,GACrBb,GAAC,OACC,UAAWuB,EAAG,oCAAqC,CACjD,iBAAkBV,GAAO,UACzB,iBAAkB,CAACA,GAAO,SAC5B,CAAC,EAGD,UAAAd,EAAC,QAAK,UAAU,GAAI,SAAAc,GAAO,UAAYd,EAACyB,GAAA,EAAM,EAAKzB,EAAC0B,GAAA,EAAK,EAAG,EAC5D1B,EAAC,QAAK,UAAU,GAAI,SAAAc,GAAO,MAAM,IAH5BA,GAAO,GAId,CACD,EACH,EAED,CAACH,CAAe,CAAC,EAEpB,OACEX,EAAC2B,EAAA,CACC,kBAAkB,cAClB,UACEnB,EACER,EAAC,UACC,KAAK,SACL,QAAS,IAAMS,EAAoBmB,GAAQ,CAACA,CAAG,EAE/C,SAAA5B,EAAC6B,GAAA,EAAI,EACP,EAEA7B,EAAC,UACC,KAAK,SACL,QAAS,IAAMS,EAAoBmB,GAAQ,CAACA,CAAG,EAE/C,SAAA5B,EAAC8B,GAAA,EAAO,EACV,EAGJ,KAAMtB,EAAkB,OAAS,WACjC,SAAUW,EACV,YAAa,CAACb,GAAqBgB,EAClC,GAAGf,EACN,CAEJ,EAEAJ,GAAc,YAAc,gBK9H5B,OAAS,OAAA4B,OAA8B,2BA8DnC,OACE,OAAAC,GADF,QAAAC,OAAA,oBAtDJ,IAAMC,GAA4BC,GAChC,0OACA,CACE,SAAU,CACR,OAAQ,CACN,QACE,4SACF,MACE,4MACF,QAAS,6BACT,UACE,mMACF,QAAS,EACX,CACF,EACA,gBAAiB,CACf,OAAQ,SACV,CACF,CACF,EAeMC,GAAW,CAAC,CAChB,UAAAC,EACA,OAAAC,EAAS,UACT,SAAAC,EACA,MAAAC,EACA,UAAAC,EACA,aAAAC,EACA,MAAAC,EACA,YAAAC,EACA,GAAGC,CACL,IAAqB,CACnB,IAAIC,EAEUR,EAEd,OAAIE,IAAOM,EAAkB,SACzBL,IAAWK,EAAkB,WAC7BP,IAAUO,EAAkB,aAG9Bb,GAAC,OAAI,UAAU,qBACb,UAAAD,GAACe,EAAA,CAAU,aAAcL,EAAc,MAAOF,EAC3C,SAAAG,EACH,EACAX,GAAC,YACC,UAAWgB,EACT,eACAC,EAAuB,CAAE,OAAQH,CAAgB,CAAC,EAClDT,CACF,EACA,SAAUI,GAAaF,EACtB,GAAGM,EACN,EACAb,GAACkB,EAAA,CAAgB,UAAU,qCACxB,SAAAN,EACH,EACAZ,GAACmB,EAAA,CAAa,MAAOX,EAAO,GAC9B,CAEJ,EAEAJ,GAAS,YAAc,WCpFvB,UAAYgB,OAAW,QCAvB,UAAYC,OAAW,QAEvB,OAAS,WAAWC,MAAwB,OAC5C,OAAS,UAAAC,OAAc,eCHvB,UAAYC,OAAW,QACvB,UAAYC,MAAqB,yBCD7B,OAYE,OAAAC,GAZF,QAAAC,OAAA,oBAFG,IAAMC,GAAY,IAErBD,GAAC,OACC,MAAM,6BACN,MAAM,KACN,OAAO,KACP,QAAQ,YACR,KAAK,OACL,OAAO,eACP,YAAY,IACZ,cAAc,QACd,eAAe,QACf,UAAU,kBAEV,UAAAD,GAAC,QAAK,EAAE,aAAa,EACrBA,GAAC,QAAK,EAAE,aAAa,GACvB,EDEF,OA6JU,YAAAG,GA7JV,OAAAC,EA6BM,QAAAC,OA7BN,oBAVF,IAAMC,GAA6B,OAE7BC,GAAgC,UAEhCC,GAA+B,SAE/BC,GAAsB,cAG1B,CAAC,CAAE,UAAAC,EAAW,GAAGC,CAAM,EAAGC,IAC1BR,EAAiB,UAAhB,CACC,IAAKQ,EACL,UAAWC,EACT,yJACAH,CACF,EACC,GAAGC,EACN,CACD,EACDF,GAAc,YAA8B,UAAQ,YAEpD,IAAMK,GAAsB,cAK1B,CAAC,CAAE,UAAAJ,EAAW,gBAAAK,EAAiB,SAAAC,EAAU,GAAGL,CAAM,EAAGC,IACrDP,GAACG,GAAA,CACC,UAAAJ,EAACK,GAAA,EAAc,EACfJ,GAAiB,UAAhB,CACC,IAAKO,EACL,UAAWC,EACT,qiBACAH,CACF,EACC,GAAGC,EAEH,UAAAK,EACA,CAACD,GACAV,GAAiB,QAAhB,CAAsB,UAAU,gRAC/B,UAAAD,EAACa,GAAA,EAAU,EAEXb,EAAC,QAAK,UAAU,UAAU,iBAAK,GACjC,GAEJ,GACF,CACD,EACDU,GAAc,YAA8B,UAAQ,YAEpD,IAAMI,GAAe,CAAC,CACpB,UAAAR,EACA,GAAGC,CACL,IACEP,EAAC,OACC,UAAWS,EAAG,sCAAuCH,CAAS,EAC7D,GAAGC,EACN,EAEFO,GAAa,YAAc,eAE3B,IAAMC,GAAe,CAAC,CACpB,UAAAT,EACA,GAAGC,CACL,IACEP,EAAC,OACC,UAAWS,EAAG,yCAA0CH,CAAS,EAChE,GAAGC,EACN,EAEFQ,GAAa,YAAc,eAE3B,IAAMC,GAAoB,cAGxB,CAAC,CAAE,UAAAV,EAAW,GAAGC,CAAM,EAAGC,IAC1BR,EAAiB,QAAhB,CACC,IAAKQ,EACL,UAAWC,EACT,oDACAH,CACF,EACC,GAAGC,EACN,CACD,EACDS,GAAY,YAA8B,QAAM,YAEhD,IAAMC,GAA0B,cAG9B,CAAC,CAAE,UAAAX,EAAW,GAAGC,CAAM,EAAGC,IAC1BR,EAAiB,cAAhB,CACC,IAAKQ,EACL,UAAWC,EAAG,wBAAyBH,CAAS,EAC/C,GAAGC,EACN,CACD,EACDU,GAAkB,YAA8B,cAAY,YAsB5D,IAAMC,GAAS,CAAC,CACd,QAAAC,EAAU,OACV,SAAAP,EACA,KAAAQ,EACA,aAAAC,EACA,gBAAAV,EACA,OAAAW,EACA,MAAAC,EACA,YAAAC,EACA,iBAAAC,EACA,gBAAAC,EACA,eAAAC,EACA,qBAAAC,EACA,gBAAAC,EACA,QAAAC,EAAU,GACV,gBAAAC,EACA,iBAAAC,EACA,gBAAAC,EACA,kBAAAC,EACA,qBAAAC,EACA,GAAG5B,CACL,IAGIN,GAACC,GAAA,CAAY,GAAGK,EAAO,KAAMa,EAAM,aAAcC,EAC/C,UAAArB,EAACG,GAAA,CAAc,QAAS2B,EAAU,SAAAX,EAAQ,EAC1CnB,EAACI,GAAA,CACC,SAAAH,GAACS,GAAA,CACC,UAAWe,EACX,gBAAiBd,EACjB,gBAAiBoB,EACjB,iBAAkBC,EAClB,gBAAiBC,EACjB,qBAAsBE,EACtB,kBAAmBD,EAElB,UAAAX,GAASC,EACRvB,GAACa,GAAA,CAAa,UAAWY,EACtB,UAAAH,GACCvB,EAACgB,GAAA,CAAY,UAAWW,EAAiB,SAAAJ,EAAM,EAEhDC,GACCxB,EAACiB,GAAA,CAAkB,UAAWW,EAC3B,SAAAJ,EACH,GAEJ,EAEAxB,EAAAD,GAAA,EAAE,EAEHa,EACAU,GACCtB,EAACe,GAAA,CAAa,UAAWc,EAAkB,SAAAP,EAAO,GAEtD,EACF,GACF,EAGJJ,GAAO,YAA8B,SAAO,YD3K1C,OAiBgD,YAAAkB,GAjBhD,OAAAC,EAqCA,QAAAC,OArCA,oBAJF,IAAMC,GAAgB,cAGpB,CAAC,CAAE,UAAAC,EAAW,GAAGC,CAAM,EAAGC,IAC1BL,EAACM,EAAA,CACC,IAAKD,EACL,UAAWE,EACT,4FACAJ,CACF,EACC,GAAGC,EACN,CACD,EACDF,GAAQ,YAAcI,EAAiB,YAwBvC,IAAME,GAAqB,cAGzB,CAAC,CAAE,UAAAC,EAAW,+BAAAC,EAAgC,QAAAC,EAAS,GAAGC,CAAM,EAAGC,IACnEC,GAAC,OACC,UAAWC,EACT,wCACAL,CACF,EACA,qBAAmB,GAElB,UAAAC,EACCK,EAACC,GAAA,CAAO,KAAM,GAAI,OAAO,YAAY,EAErCD,EAACE,GAAA,CAAO,UAAU,mCAAmC,EAEvDF,EAACG,EAAiB,MAAjB,CACC,IAAKN,EACL,UAAWE,EACT,yJACAN,CACF,EACA,SAAUE,EACT,GAAGC,EACN,GACF,CACD,EAEDJ,GAAa,YAAcW,EAAiB,MAAM,YAElD,IAAMC,GAAoB,cAGxB,CAAC,CAAE,UAAAX,EAAW,GAAGG,CAAM,EAAGC,IAC1BG,EAACG,EAAiB,KAAjB,CACC,IAAKN,EACL,UAAWE,EAAG,oCAAqCN,CAAS,EAC3D,GAAGG,EACN,CACD,EAEDQ,GAAY,YAAcD,EAAiB,KAAK,YAEhD,IAAME,GAAqB,cAGzB,CAACT,EAAOC,IACRG,EAACG,EAAiB,MAAjB,CACC,IAAKN,EACL,UAAU,2BACT,GAAGD,EACN,CACD,EAEDS,GAAa,YAAcF,EAAiB,MAAM,YAElD,IAAMG,GAAqB,cAGzB,CAAC,CAAE,UAAAb,EAAW,GAAGG,CAAM,EAAGC,IAC1BG,EAACG,EAAiB,MAAjB,CACC,IAAKN,EACL,UAAWE,EACT,yNACAN,CACF,EACC,GAAGG,EACN,CACD,EAEDU,GAAa,YAAcH,EAAiB,MAAM,YAElD,IAAMI,GAAyB,cAG7B,CAAC,CAAE,UAAAd,EAAW,GAAGG,CAAM,EAAGC,IAC1BG,EAACG,EAAiB,UAAjB,CACC,IAAKN,EACL,UAAWE,EAAG,uBAAwBN,CAAS,EAC9C,GAAGG,EACN,CACD,EACDW,GAAiB,YAAcJ,EAAiB,UAAU,YAE1D,IAAMK,GAAoB,cAGxB,CAAC,CAAE,UAAAf,EAAW,GAAGG,CAAM,EAAGC,IAC1BG,EAACG,EAAiB,KAAjB,CACC,IAAKN,EACL,UAAWE,EACT,qSACAN,CACF,EACC,GAAGG,EACN,CACD,EAEDY,GAAY,YAAcL,EAAiB,KAAK,YAEhD,IAAMM,GAAkB,CAAC,CACvB,UAAAhB,EACA,GAAGG,CACL,IAEII,EAAC,QACC,UAAWD,EACT,wDACAN,CACF,EACC,GAAGG,EACN,EAGJa,GAAgB,YAAc,kBGhK9B,UAAYC,OAAW,QACvB,UAAYC,MAAsB,0BAoB1B,cAAAC,GAkEJ,QAAAC,OAlEI,oBAhBR,IAAMC,EAA+B,OAE/BC,EAAkC,UAElCC,EAAuB,cAM3B,CACE,CAAE,UAAAC,EAAW,MAAAC,EAAQ,SAAU,WAAAC,EAAa,EAAG,OAAAC,EAAS,GAAM,GAAGC,CAAM,EACvEC,IAEAF,EACER,GAAkB,SAAjB,CACC,SAAAA,GAAkB,UAAjB,CACC,IAAKU,EACL,MAAOJ,EACP,WAAYC,EACZ,UAAWI,EACT,ycACAN,CACF,EACA,gBAAiBI,EAAM,gBACvB,iBAAkBA,EAAM,iBACvB,GAAGA,EACN,EACF,EAEAT,GAAkB,UAAjB,CACC,IAAKU,EACL,MAAOJ,EACP,WAAYC,EACZ,UAAWI,EACT,ycACAN,CACF,EACA,gBAAiBI,EAAM,gBACvB,iBAAkBA,EAAM,iBACvB,GAAGA,EACN,CAEN,EACAL,EAAe,YAA+B,UAAQ,YAkBtD,IAAMQ,GAAU,CAAC,CACf,QAAAC,EACA,SAAAC,EACA,KAAAC,EACA,aAAAC,EACA,iBAAAC,EACA,QAAAC,EAAU,GACV,MAAAZ,EACA,KAAAa,EACA,YAAAC,EACA,iBAAAC,EACA,WAAAd,EACA,gBAAAe,EACA,iBAAAC,EACA,OAAAf,EAAS,GACT,GAAAgB,EAAK,UACL,GAAGf,CACL,IAGIR,GAACC,EAAA,CAAa,GAAGO,EAAO,KAAMM,EAAM,aAAcC,EAChD,UAAAhB,GAACG,EAAA,CACC,QAASe,EACT,UAAWG,EACX,GAAI,GAAGG,CAAE,WAER,SAAAX,EACH,EACAb,GAACI,EAAA,CACC,YAAagB,EACb,WAAYb,EACZ,KAAMY,EACN,MAAOb,EACP,UAAWW,EACX,gBAAiBK,EACjB,iBAAkBC,EAClB,OAAQf,EACR,GAAI,GAAGgB,CAAE,WAER,SAAAV,EACH,GACF,EAGJF,GAAQ,YAA+B,OAAK,YC/G5C,UAAYa,OAAW,QACvB,UAAYC,MAAyB,8BAUnC,OAKE,OAAAC,GALF,QAAAC,OAAA,oBANF,IAAMC,GAAmB,cAKvB,CAAC,CAAE,UAAAC,EAAW,kBAAAC,EAAmB,SAAAC,EAAU,GAAGC,CAAM,EAAGC,IACvDN,GAAqB,OAApB,CACC,IAAKM,EACL,UAAWC,EAAG,2BAA4BL,CAAS,EAClD,GAAGG,EAEJ,UAAAN,GAAqB,WAApB,CACC,UAAWQ,EAAG,kCAAmCJ,CAAiB,EAEjE,SAAAC,EACH,EACAL,GAACS,GAAA,EAAU,EACXT,GAAqB,SAApB,EAA2B,GAC9B,CACD,EACDE,GAAW,YAAkC,OAAK,YAElD,IAAMO,GAAkB,cAGtB,CAAC,CAAE,UAAAN,EAAW,YAAAO,EAAc,WAAY,GAAGJ,CAAM,EAAGC,IACpDP,GAAqB,sBAApB,CACC,IAAKO,EACL,YAAaG,EACb,UAAWF,EACT,gDACAE,IAAgB,YACd,qDACFA,IAAgB,cACd,uDACFP,CACF,EACC,GAAGG,EAEJ,SAAAN,GAAqB,kBAApB,CAAoC,UAAU,0EAA0E,EAC3H,CACD,EACDS,GAAU,YAAkC,sBAAoB,YLc1D,OAiBI,OAAAE,EAjBJ,QAAAC,OAAA,oBAVN,IAAMC,GAAoB,CAAC,CACzB,UAAAC,EACA,MAAAC,EACA,YAAAC,EAAc,GACd,OAAAC,EACA,SAAAC,EACA,GAAAC,CACF,IAEIR,EAACS,EAAA,CAAe,QAAO,GAAC,SAAUF,EAAU,GAAIC,GAAM,qBACpD,SAAAP,GAAC,UACC,SAAUM,EACV,UAAWG,EACTC,EAAuB,CAAE,OAAAL,CAAO,CAAC,EACjC,wGACAF,EAAQ,GAAK,iBACbD,CACF,EAEC,UAAAC,GAASC,GAAe,oBACzBL,EAAC,OACC,MAAM,KACN,OAAO,KACP,QAAQ,YACR,KAAK,OACL,UAAU,qCAEV,SAAAA,EAAC,QACC,EAAE,iGACF,OAAO,eACP,YAAY,MACZ,iBAAiB,KACjB,cAAc,QACd,eAAe,QACjB,EACF,GACF,EACF,EAIEY,GAAa,CAAC,CAClB,QAAAC,EAAU,CAAC,EACX,MAAAT,EACA,SAAAU,EACA,mBAAAC,EACA,YAAAV,EACA,SAAAE,EACA,QAAAS,EACA,gBAAAC,EACA,SAAAC,EACA,MAAAC,EAAQ,GACR,WAAAC,EACA,UAAAjB,EACA,WAAAkB,EACA,cAAAC,EACA,mBAAAC,CACF,IAAuB,CACrB,GAAM,CAACC,EAAMC,CAAO,EAAU,YAAS,EAAK,EAEtCC,EAAmB,UAA8B,IAAI,EAErD,CAACC,EAAOC,CAAQ,EAAU,YAA6B,MAAS,EAEtE,OAAM,mBAAgB,IAAM,CACtBF,EAAW,SACbE,EAASF,EAAW,QAAQ,WAAW,CAE3C,EAAG,CAACA,EAAW,OAAO,CAAC,EAGrBzB,GAAC4B,EAAA,CAAY,MAAOV,EAAO,KAAMK,EAAM,aAAcC,EACnD,UAAAzB,EAAC,OAAI,UAAWU,EAAG,SAAUP,CAAS,EAAG,IAAKuB,EAC3C,SAAAR,EACH,EACAlB,EAAC8B,EAAA,CACC,OAAQ,CAACX,EACT,UAAU,oBACV,MAAO,CAAE,MAAAQ,CAAM,EAEf,SAAA1B,GAAC8B,GAAA,CACC,UAAWrB,EAAG,yBAA0B,CACtC,OAAQ,CAACU,CACX,CAAC,EAEA,WAACA,GACApB,EAACgC,GAAA,CACC,QAAShB,EACT,YAAaX,GAAe,oBAC5B,cAAekB,EACf,MAAOF,EACP,+BAA+B,0CACjC,EAEFrB,EAACiC,GAAA,CACC,kBAAkB,gBAClB,UAAWvB,EACT,qCACAK,CACF,EAEA,SAAAd,GAACiC,GAAA,CACE,WAACd,GAAcpB,EAACmC,GAAA,CAAa,4BAAgB,EAC9CnC,EAACoC,GAAA,CAAa,UAAU,SACrB,SAAAvB,GAAS,IAAKwB,GACbrC,EAACsC,GAAA,CACC,aAAclC,GAAO,MAErB,MAAOiC,EAAO,MACd,SAAU9B,EACV,SAAU,IAAM,CACdO,EAASuB,CAAM,EACfZ,EAAQ,EAAK,EACbH,IAAgBe,GAAQ,KAAK,CAC/B,EACA,GAAIA,EAAO,MAEV,SAACpB,EAAiCA,EAAgBoB,CAAM,EAArCA,EAAO,OAVtBA,EAAO,KAWd,CACD,EACH,GACF,EACF,GACF,EACF,GACF,CAEJ,EMpLO,IAAME,GAAc,CACzB,CACE,YAAa,SACb,YAAa,SACb,SAAU,UACV,aAAc,MACd,oBAAqB,QACvB,EACA,CACE,YAAa,QACb,YAAa,OACb,SAAU,yBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,eACb,YAAa,OACb,SAAU,yBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,WACb,YAAa,OACb,SAAU,4BACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,OACb,YAAa,OACb,SAAU,4BACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,WACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,WACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,IACd,oBAAqB,IACvB,EACA,CACE,YAAa,QACb,YAAa,OACb,SAAU,4BACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,QACb,YAAa,OACb,SAAU,gBACV,aAAc,MACd,aAAc,SACd,oBAAqB,IACvB,EACA,CACE,YAAa,SACb,YAAa,OACb,SAAU,gBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,cACb,YAAa,OACb,SAAU,yBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,QACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,UACb,YAAa,OACb,SAAU,eACV,aAAc,MACd,aAAc,IACd,oBAAqB,IACvB,EACA,CACE,YAAa,UACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,IACd,oBAAqB,IACvB,EACA,CACE,YAAa,aACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,SACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,OACb,YAAa,OACb,SAAU,yBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,aACb,YAAa,OACb,SAAU,qBACV,aAAc,MACd,aAAc,KACd,oBAAqB,IACvB,EACA,CACE,YAAa,UACb,YAAa,OACb,SAAU,kBACV,aAAc,MACd,aAAc,IACd,oBAAqB,IACvB,EA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ACL,IAAK,MACL,IAAK,OACL,IAAK,KACL,IAAK,KACL,IAAK,MACL,IAAK,KACL,IAAK,MACL,IAAK,MACL,IAAK,KACL,IAAK,KACL,IAAK,MACL,IAAK,KACL,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,SACL,IAAK,MACL,IAAK,SACL,IAAK,MACL,IAAK,UACL,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,KACL,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,KACL,IAAK,OACL,IAAK,MACL,IAAK,WACL,IAAK,KACL,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,KACL,IAAK,KACL,IAAK,KACL,IAAK,SACL,IAAK,SACL,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,KACL,IAAK,KACL,IAAK,OACL,IAAK,MACL,IAAK,MACL,IAAK,KACL,IAAK,SACL,IAAK,KACL,IAAK,MACL,IAAK,OACL,IAAK,OACL,IAAK,KACL,IAAK,KACL,IAAK,KACL,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,OACL,IAAK,OACL,IAAK,MACL,IAAK,KACL,IAAK,MACL,IAAK,KACL,IAAK,SACL,IAAK,KACL,IAAK,MACL,IAAK,OACL,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,SACL,IAAK,OACL,IAAK,UACL,IAAK,SACL,IAAK,KACL,IAAK,MACL,IAAK,OACL,IAAK,MACL,IAAK,MACL,IAAK,KACL,IAAK,MACL,IAAK,MACL,IAAK,KACL,IAAK,MACL,IAAK,SACL,IAAK,SACL,IAAK,KACL,IAAK,KACL,IAAK,KACL,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,SACL,IAAK,MACL,IAAK,KACL,IAAK,MACL,IAAK,QACL,IAAK,SACL,IAAK,QACL,IAAK,MACL,IAAK,KACL,IAAK,IACL,IAAK,KACL,IAAK,MACP,EAKaC,GAAN,MAAMA,EAAa,CACxB,OAAO,qBAAqBC,EAA0B,CAKpD,MAJ0C,CACxC,IAAK,KACL,IAAK,IACP,EACiBA,CAAQ,GAAK,IAChC,CACA,OAAO,YAAYC,EAAyB,CAC1C,MAAO,CAACA,EAAS,GACnB,CAEA,OAAO,YAAYA,EAAyB,CAC1C,MAAO,CAACA,EAAS,GACnB,CAEA,OAAO,kBAAkBD,EAA0B,CACjD,OAAOF,GAAkBE,CAAQ,GAAKA,CACxC,CA+BF,EA7BEE,GApBWH,GAoBJ,0BAA0B,CAC/BC,EACAG,EACAC,IACG,CACH,IAAMC,EAAY,IAAI,KAAK,aACzBD,GAAS,QAAUL,GAAK,qBAAqBC,CAAQ,EACrD,CACE,sBAAuB,EACvB,MAAO,WACP,SAAUA,EACV,gBAAiB,QACnB,CACF,EACG,OACCI,GAAS,uBACLL,GAAK,YAAY,OAAOI,CAAK,CAAC,EAC9B,OAAOA,CAAK,CAClB,EACC,QAAQ,SAAU,KAAK,EACvB,QAAQ,SAAK,GAAG,EAChB,QAAQ,MAAO,EAAE,EAGdG,EAAeR,GAAkBE,CAAQ,GAAKA,EAGpD,OAAOK,EAAU,QAAQL,EAAUM,CAAY,CACjD,GAhDK,IAAMC,GAANR,GC5HP,OAAOS,OAAW,QACX,IAAMC,GAAN,KAAiB,CACtB,OAAO,gBAA8B,CACnC,OAAOD,GAAM,CACf,CACA,OAAO,sBAAsBE,EAAmBC,EAAqB,CACnE,OAAOH,GACJ,KAAKE,CAAS,EACd,OAAOC,GAAc,2BAA2B,CACrD,CAEA,OAAO,sBAAsBC,EAAc,CACzC,OAAOJ,GAAMI,CAAI,EAAE,KAAK,CAC1B,CACF","names":["React","TooltipPrimitive","clsx","twMerge","cn","inputs","jsx","jsxs","TooltipProvider","TooltipRoot","TooltipTrigger","TooltipContent","className","sideOffset","props","ref","cn","Tooltip","trigger","children","contentClassName","triggerClassName","asChild","side","align","alignOffset","delayDuration","hasArrow","arrowClassName","React","React","LabelPrimitive","cva","jsx","labelVariants","cva","Label","className","props","ref","cn","jsx","jsxs","FormLabel","React","className","children","showAsterisk","error","props","ref","Label","cn","jsx","jsxs","Loader","size","colour","React","Slot","cva","Fragment","jsx","jsxs","buttonVariants","cva","Button","className","variant","size","asChild","isLoading","leftNode","rightNode","LoaderSize","props","ref","Component","Slot","children","disabled","rest","reference","cn","Loader","React","cva","React","jsx","ErrorMessage","className","children","error","props","ref","body","cn","React","jsx","FormDescription","className","props","ref","cn","jsx","jsxs","inputVariants","cva","BaseInnerInput","className","status","type","props","ref","cn","inputContainerVariants","sideVariants","Input","disabled","error","isLoading","sideNodeClassName","showAsterisk","label","description","containerStatus","FormLabel","FormDescription","ErrorMessage","useMemo","useState","jsx","jsxs","Eye","jsx","jsxs","EyeOff","jsx","Check","jsx","Fail","jsx","jsxs","validationOptions","PasswordInput","onValidate","onChange","disableValidation","props","passwordVisible","setPasswordVisible","useState","validatedValues","setValidatedValues","validatePassword","value","option","checkPasswordStrength","validatedOptions","allValidated","handlePaswordInputChange","e","validated","ValidateComp","useMemo","cn","Check","Fail","Input","val","Eye","EyeOff","cva","jsx","jsxs","textareaContainerVariants","cva","Textarea","className","status","disabled","error","isLoading","showAsterisk","label","description","props","containerStatus","FormLabel","cn","inputContainerVariants","FormDescription","ErrorMessage","React","React","CommandPrimitive","Search","React","DialogPrimitive","jsx","jsxs","CloseIcon","Fragment","jsx","jsxs","DialogRoot","DialogTrigger","DialogPortal","DialogOverlay","className","props","ref","cn","DialogContent","hideCloseButton","children","CloseIcon","DialogHeader","DialogFooter","DialogTitle","DialogDescription","Dialog","trigger","open","onOpenChange","footer","title","description","contentClassName","headerClassName","titleClassName","descriptionClassName","footerClassName","asChild","onOpenAutoFocus","onCloseAutoFocus","onEscapeKeyDown","onInteractOutside","onPointerDownOutside","Fragment","jsx","jsxs","Command","className","props","ref","CommandPrimitive","cn","CommandInput","className","CommandInputContainerClassName","loading","props","ref","jsxs","cn","jsx","Loader","Search","CommandPrimitive","CommandList","CommandEmpty","CommandGroup","CommandSeparator","CommandItem","CommandShortcut","React","PopoverPrimitive","jsx","jsxs","PopoverRoot","PopoverTrigger","PopoverContent","className","align","sideOffset","portal","props","ref","cn","Popover","trigger","children","open","onOpenChange","contentClassName","asChild","side","alignOffset","triggerClassName","onOpenAutoFocus","onCloseAutoFocus","id","React","ScrollAreaPrimitive","jsx","jsxs","ScrollArea","className","viewPortClassName","children","props","ref","cn","ScrollBar","orientation","jsx","jsxs","SearchableTrigger","className","value","placeholder","status","disabled","id","PopoverTrigger","cn","inputContainerVariants","Searchable","options","onChange","containerClassName","loading","optionComponent","children","modal","hideSearch","inputValue","onValueChange","onInputValueChange","open","setOpen","triggerRef","width","setWidth","PopoverRoot","PopoverContent","Command","CommandInput","ScrollArea","CommandList","CommandEmpty","CommandGroup","option","CommandItem","countryData","getCountryDataMap","frequency","country","React","RPNInput","flags","jsx","jsxs","FlatGlobeIcon","props","Flag_default","jsx","jsxs","PhoneInput","className","onChange","defaultCountry","modal","showAsterisk","label","description","error","props","ref","CountrySelectWrapper","innerProps","CountrySelect","FormLabel","cn","FlagComponent","InputComponent","value","FormDescription","ErrorMessage","Input","disabled","options","status","handleSelect","country","PopoverRoot","PopoverTrigger","inputContainerVariants","PopoverContent","Command","CommandList","ScrollArea","CommandInput","CommandEmpty","CommandGroup","x","option","CommandItem","countryName","Flag","flags","Flag_default","jsx","jsxs","countryMap","getCountryDataMap","CountryTrigger","className","value","placeholder","status","disabled","PopoverTrigger","cn","inputContainerVariants","FlagComponent","Country","hideSearch","showAsterisk","label","description","error","props","options","countryData","country","FormLabel","Searchable","arg","FormDescription","ErrorMessage","jsx","jsxs","Select","showAsterisk","label","description","error","hideSearch","status","props","FormLabel","Searchable","SearchableTrigger","FormDescription","ErrorMessage","OtpInput","cva","useMemo","jsx","otpInputVariants","OTPInput","numInputs","inputStyle","containerStyle","placeholder","status","props","placeholderValue","accumulator","currentValue","OtpInput","cn","useState","useEffect","jsx","jsxs","Icon","type","Banner","title","description","open","showCloseButton","bottomNode","sideNode","onClose","showIcon","isOpen","setIsOpen","bgColor","stripeColor","handleClose","useState","Copy","CheckIcon","motion","AnimatePresence","jsx","TextOverflow","children","mode","className","Component","rest","cn","jsx","jsxs","CopyableLabel","text","textToCopy","onCopy","iconsPosition","clampText","clampMode","isLink","textClassName","copied","setCopied","useState","copyToClipboard","Icon","CheckIcon","Copy","AnimatedIcon","TextOverflow","cn","onClick","AnimatePresence","motion","useEffect","useState","Search","jsx","DebouncedInput","initialValue","onChange","debounce","addon","props","value","setValue","useState","handleInputChange","event","useEffect","timeout","Input","cn","useEffect","X","jsx","jsxs","DevBanner","props","environment","branch","version","deployTime","showBanner","onClose","initDefault","removeFromStorage","syncLocalStorageToState","currentEnv","interval","React","DrawerPrimitive","cva","jsx","jsxs","CloseIcon","useState","useEffect","useWindowSize","windowSize","setWindowSize","handleResize","Fragment","jsx","jsxs","DrawerRoot","shouldScaleBackground","props","DrawerPrimitive","DrawerTrigger","DrawerClose","DrawerPortal","DrawerOverlay","className","ref","cn","DrawerVariants","cva","DrawerContent","side","hideCloseButton","children","id","CloseIcon","DrawerHeader","DrawerFooter","DrawerTitle","DrawerDescription","Drawer","trigger","open","onOpenChange","footer","title","description","contentClassName","headerClassName","titleClassName","descriptionClassName","footerClassName","asChild","onOpenAutoFocus","drawerContentClassName","onCloseAutoFocus","width","useWindowSize","direction","jsx","Check","jsx","jsxs","EnglishFlag","props","jsx","jsxs","FrenchFlag","props","jsx","jsxs","UpDownIcon","PopoverClose","jsx","jsxs","localeListOptons","LocaleIcon","locale","FrenchFlag","EnglishFlag","LocaleTrigger","UpDownIcon","LocaleSelector","onChange","locales","PopoverRoot","PopoverTrigger","PopoverContent","_locale","cn","Check","useMemo","useRef","useState","AnimatePresence","motion","useMemo","useState","HiCheck","FiLogOut","BsPlus","jsx","jsxs","BusinessBarTrigger","activeBusiness","onTriggerClick","iconOnly","className","rightNode","cn","TextOverflow","ChevronUp","jsx","ActiveBusinessIcon","props","jsx","jsxs","businessPopUpVariants","BusinessBarContent","activeBusiness","toggleAddBusinessDrawer","businesses","handleSwitchBusiness","onLogoutClick","onToggleSideBar","toggleShowBusiness","isMobile","collapseType","searchText","setSearchText","useState","searchedBusinesses","useMemo","text","b","hiddenCollapseType","onSearchChange","e","onBusinessClick","clientId","onToggleAddBusinessDrawer","onHandleLogoutClick","AnimatePresence","motion","BusinessBarTrigger","ActiveBusinessIcon","Input","ChevronUp","HiCheck","cn","BsPlus","FiLogOut","jsx","jsxs","BusinessBar","activeBusiness","toggleAddBusinessDrawer","toggleShowBusiness","businesses","handleSwitchBusiness","iconOnly","onLogoutClick","isMobile","onToggleSideBar","isBusinessShown","collapseType","Popover","BusinessBarTrigger","Icon","BusinessBarContent","className","cn","AnimatePresence","motion","useEffect","FiChevronRight","useState","useEffect","useLocalStorage","key","initialValue","state","setState","isHydrated","setIsHydrated","item","error","Fragment","jsx","jsxs","accordionItemVariants","NavItems","isIconsOnly","isSidebarCollapsed","onToggleSideBar","currentPath","onNavigate","collapseType","links","appConfig","isMobile","SIDEBAR_MENU_STORAGE_KEY","expandedMenus","setExpandedMenus","useLocalStorage","toggleAccordion","linkId","prev","handleMenuLink","link","stripQuery","path","getActiveMenu","l","useEffect","expanded","child","idx","active","hasChildren","isExpanded","cn","Tooltip","FiChevronRight","AnimatePresence","motion","childLink","childActive","X","jsx","jsxs","OpenSidebarIcon","jsx","jsxs","ClosedSidebarIcon","jsx","jsxs","SidebarToggle","onToggleSideBar","isSidebarCollapsed","OpenIcon","CloseIcon","props","Fragment","jsx","jsxs","Sidebar","isSidebarCollapsed","onToggleSideBar","isMobile","links","businessProps","currentPath","onNavigate","appConfig","propCollapseType","onLogoutClick","openSidebarIcon","OpenSidebarIcon","closedSidebarIcon","ClosedSidebarIcon","nodeAfterSideBarLogo","collapseType","useMemo","isBusinessShown","setIsBusinessShown","useState","isIconsOnly","sideBarRef","useRef","businessList","activeBusiness","toggleAddBusinessDrawer","handleSetActiveBusiness","toggleShowBusiness","handleSwitchBusiness","clientId","sideBarLogo","showBackdrop","cn","SidebarToggle","X","NavItems","BusinessBar","jsx","Status","status","variant","className","cn","Loader","ChevronLeftIcon","ChevronRightIcon","jsx","PageButton","page","currentPage","onClick","renderPageNumbers","totalPages","handlePageClick","getWindowBounds","halfWindow","start","end","pages","_","i","idx","jsx","jsxs","Pagination","currentPage","totalPages","onPageChange","itemsPerPage","totalItems","id","handlePageClick","page","visibleRangeStart","visibleRangeEnd","ChevronLeftIcon","renderPageNumbers","ChevronRightIcon","flexRender","jsx","jsxs","TableBody","table","isMobile","onRowClick","id","cn","headerGroup","header","flexRender","row","cell","Download","ListFilter","RotateCw","useEffect","useState","useForm","Controller","React","RadioGroupPrimitive","jsx","RadioGroup","className","props","ref","cn","RadioGroupItem","v4","React","ChevronLeft","ChevronRight","React","DayPicker","jsx","Calendar","className","classNames","showOutsideDays","props","DayPicker","cn","buttonVariants","ChevronLeft","ChevronRight","value","onChange","children","options","option","handleChange","Select","val","date","jsx","jsxs","DateInputButton","value","onClick","error","status","ref","cn","inputContainerVariants","format","date","placeholder","Trigger","className","props","PopoverTrigger","Picker","children","captionLayout","fromYear","toYear","disableDate","modal","open","setOpen","PopoverRoot","PopoverContent","Calendar","formatFormDate","dateFormat","CalendarInput","label","optional","onChange","helpText","FormLabel","formattedDate","create","FILTER_PREFIX","syncFiltersWithURL","filters","params","key","clearFiltersFromURL","keysToDelete","_","initializeFiltersFromURL","value","createFilterStore","set","items","state","newFilters","useFilterStore","PopoverClose","Fragment","jsx","jsxs","FilterContent","filters","values","setAppliedFilters","id","filterStore","useFilterStore","upDateFilter","resetFilters","cachedFilters","syncFilter","setSyncFilter","useState","handleFiltersSync","control","handleSubmit","useForm","useEffect","handleReset","filtered","v","filter","Controller","field","formState","Input","value","onChange","errors","Select","option","val","FormLabel","RadioGroup","RadioGroupItem","v4","CalendarInput","PopoverClose","cn","buttonVariants","ListFilter","useEffect","useState","Fragment","jsx","FilterLabelCount","setAppliedFilters","syncFilter","setSyncFilter","useState","filterStore","useFilterStore","cachedFilters","cachedKeys","useEffect","useEffect","useState","useMountClient","mounted","setMounted","children","jsx","jsxs","FilterPopover","filters","setAppliedFilters","isOpen","id","isClientMounted","useMountClient","Popover","cn","buttonVariants","ListFilter","FilterLabelCount","FilterContent","Fragment","jsx","jsxs","PageDataToolbar","onRefetch","search","FilterMenu","ExtraNode","onExport","download","isRefetching","filterListOptions","setAppliedFilters","id","handleSearch","query","handleRefetch","e","DebouncedInput","Button","RotateCw","cn","FilterPopover","Popover","buttonVariants","ListFilter","Download","jsx","jsxs","Table","table","isMobile","onRowClick","id","onRefetch","isRefetching","FilterMenu","ExtraNode","onExport","search","download","isLoading","pagination","filterListOptions","setAppliedFilters","cn","PageDataToolbar","Loader","TableBody","Pagination","page","createContext","useMemo","jsx","PermissionsContext","PermissionsProvider","permissions","children","value","useCallback","useContext","useMemo","usePermissions","useContext","PermissionsContext","useHasPermission","permission","permissions","validatePermission","useCallback","p","resource","action","matchingPermissions","useMemo","Fragment","jsx","HasResourcePermission","permission","children","hasPermission","useHasPermission","CurrencySymbolMap","_AmountAction","currency","amount","__publicField","value","options","formatted","customSymbol","AmountAction","dayjs","DateAction","timestamp","dateFormat","date"]}