katalyst-riya-test 1.0.1 → 1.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -75,9 +75,11 @@ __export(index_exports, {
75
75
  Loading: () => Loading_default,
76
76
  Modal: () => Modal,
77
77
  NestedDropdown: () => NestedDropdown_default,
78
+ Notice: () => Notice_default,
78
79
  OTPInput: () => OTPInput_default,
79
80
  Paragraph: () => Paragraph_default,
80
81
  Popover: () => Popover_default,
82
+ Progress: () => Progress_default,
81
83
  Radio: () => Radio_default,
82
84
  Skeleton: () => Skeleton_default,
83
85
  Slider: () => Slider_default,
@@ -2522,7 +2524,7 @@ function Modal({
2522
2524
 
2523
2525
  // src/components/NestedDropdown.tsx
2524
2526
  var import_fi = require("react-icons/fi");
2525
- var import_react27 = require("react");
2527
+ var import_react27 = __toESM(require("react"), 1);
2526
2528
  var NestedDropdown = ({
2527
2529
  data,
2528
2530
  onSelect,
@@ -2568,38 +2570,38 @@ var NestedDropdown = ({
2568
2570
  handleItemClick(item, [...currentPath]);
2569
2571
  }
2570
2572
  };
2571
- return /* @__PURE__ */ React.createElement("div", { className: "relative w-full max-w-[200px]", ref: dropdownRef }, /* @__PURE__ */ React.createElement(
2573
+ return /* @__PURE__ */ import_react27.default.createElement("div", { className: "relative w-full max-w-[200px]", ref: dropdownRef }, /* @__PURE__ */ import_react27.default.createElement(
2572
2574
  "button",
2573
2575
  {
2574
2576
  type: "button",
2575
2577
  className: "w-full flex justify-between items-center py-3 px-4 text-sm bg-white border border-gray-300 rounded-lg shadow-sm text-left focus:outline-none focus:ring-1 focus:ring-primary-600 focus:border-primary-500 hover:border-gray-400 transition-colors duration-200",
2576
2578
  onClick: toggleDropdown
2577
2579
  },
2578
- /* @__PURE__ */ React.createElement(
2580
+ /* @__PURE__ */ import_react27.default.createElement(
2579
2581
  "span",
2580
2582
  {
2581
2583
  className: `whitespace-nowrap text-ellipsis overflow-hidden w-[180px] ${selectedItem ? "text-gray-900 font-medium" : "text-gray-500"}`
2582
2584
  },
2583
2585
  selectedItem ? selectedItem.name : placeholder
2584
2586
  ),
2585
- /* @__PURE__ */ React.createElement(
2587
+ /* @__PURE__ */ import_react27.default.createElement(
2586
2588
  import_fi.FiChevronDown,
2587
2589
  {
2588
2590
  className: `w-5 h-5 text-gray-400 transform transition-transform duration-200 ${isOpen ? "rotate-180" : ""}`
2589
2591
  }
2590
2592
  )
2591
- ), isOpen && /* @__PURE__ */ React.createElement("div", { className: "absolute z-50 w-[200px] mt-1 bg-white rounded-lg shadow-xl max-h-96" }, /* @__PURE__ */ React.createElement("div", { className: "flex flex-col h-full" }, /* @__PURE__ */ React.createElement("div", { className: "border-b border-gray-200" }, /* @__PURE__ */ React.createElement("div", { className: "relative" }, /* @__PURE__ */ React.createElement(
2593
+ ), isOpen && /* @__PURE__ */ import_react27.default.createElement("div", { className: "absolute z-50 w-[200px] mt-1 bg-white rounded-lg shadow-xl max-h-96" }, /* @__PURE__ */ import_react27.default.createElement("div", { className: "flex flex-col h-full" }, /* @__PURE__ */ import_react27.default.createElement("div", { className: "border-b border-gray-200" }, /* @__PURE__ */ import_react27.default.createElement("div", { className: "relative" }, /* @__PURE__ */ import_react27.default.createElement(
2592
2594
  "input",
2593
2595
  {
2594
2596
  type: "text",
2595
2597
  placeholder: "Search",
2596
2598
  className: "w-full pl-3 pr-4 py-2 focus:outline-none focus:border-b focus:border-b-primary-600 text-sm"
2597
2599
  }
2598
- ), /* @__PURE__ */ React.createElement("div", { className: "absolute right-2 top-1/2 transform -translate-y-1/2" }, /* @__PURE__ */ React.createElement("span", { className: "text-xs text-gray-400 bg-gray-100 px-2 py-1 rounded" }, "Q")))), /* @__PURE__ */ React.createElement("div", { className: "flex-1 overflow-y-auto bg-white max-h-[200px]" }, /* @__PURE__ */ React.createElement("div", { className: "" }, data?.map((item) => {
2600
+ ), /* @__PURE__ */ import_react27.default.createElement("div", { className: "absolute right-2 top-1/2 transform -translate-y-1/2" }, /* @__PURE__ */ import_react27.default.createElement("span", { className: "text-xs text-gray-400 bg-gray-100 px-2 py-1 rounded" }, "Q")))), /* @__PURE__ */ import_react27.default.createElement("div", { className: "flex-1 overflow-y-auto bg-white max-h-[200px]" }, /* @__PURE__ */ import_react27.default.createElement("div", { className: "" }, data?.map((item) => {
2599
2601
  const children = getChildren(item);
2600
2602
  const hasChildren = children && children.length > 0;
2601
2603
  const isActive = activePath[0]?._id === item._id;
2602
- return /* @__PURE__ */ React.createElement(
2604
+ return /* @__PURE__ */ import_react27.default.createElement(
2603
2605
  "div",
2604
2606
  {
2605
2607
  key: item._id,
@@ -2610,22 +2612,22 @@ var NestedDropdown = ({
2610
2612
  `,
2611
2613
  onClick: (e) => handleCategoryClick(item, 0, e)
2612
2614
  },
2613
- /* @__PURE__ */ React.createElement("span", { className: "text-sm text-gray-800" }, item.name),
2614
- hasChildren && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(import_fi.FiChevronRight, { className: "w-4 h-4 text-gray-400" }))
2615
+ /* @__PURE__ */ import_react27.default.createElement("span", { className: "text-sm text-gray-800" }, item.name),
2616
+ hasChildren && /* @__PURE__ */ import_react27.default.createElement(import_react27.default.Fragment, null, /* @__PURE__ */ import_react27.default.createElement(import_fi.FiChevronRight, { className: "w-4 h-4 text-gray-400" }))
2615
2617
  );
2616
- })))), activePath?.length > 0 && /* @__PURE__ */ React.createElement("div", { className: "absolute left-full top-[36px] flex" }, activePath?.map((pathItem, level) => {
2618
+ })))), activePath?.length > 0 && /* @__PURE__ */ import_react27.default.createElement("div", { className: "absolute left-full top-[36px] flex" }, activePath?.map((pathItem, level) => {
2617
2619
  const children = getChildren(pathItem);
2618
- return /* @__PURE__ */ React.createElement(
2620
+ return /* @__PURE__ */ import_react27.default.createElement(
2619
2621
  "div",
2620
2622
  {
2621
2623
  key: pathItem._id,
2622
2624
  className: "w-[200px] bg-white border border-gray-200 shadow-xl rounded-b-lg max-h-[200px] overflow-y-auto"
2623
2625
  },
2624
- /* @__PURE__ */ React.createElement("div", { className: "" }, /* @__PURE__ */ React.createElement("div", { className: "" }, children?.map((child) => {
2626
+ /* @__PURE__ */ import_react27.default.createElement("div", { className: "" }, /* @__PURE__ */ import_react27.default.createElement("div", { className: "" }, children?.map((child) => {
2625
2627
  const childChildren = getChildren(child);
2626
2628
  const hasChildren = childChildren && childChildren.length > 0;
2627
2629
  const isActive = activePath[level + 1]?._id === child._id;
2628
- return /* @__PURE__ */ React.createElement(
2630
+ return /* @__PURE__ */ import_react27.default.createElement(
2629
2631
  "div",
2630
2632
  {
2631
2633
  key: child._id,
@@ -2636,8 +2638,8 @@ var NestedDropdown = ({
2636
2638
  `,
2637
2639
  onClick: (e) => handleCategoryClick(child, level + 1, e)
2638
2640
  },
2639
- /* @__PURE__ */ React.createElement("span", { className: "text-sm text-gray-800" }, child.name),
2640
- hasChildren && /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(import_fi.FiChevronRight, { className: "w-4 h-4 text-gray-400" }), /* @__PURE__ */ React.createElement("div", { className: "absolute opacity-0 group-hover:opacity-100 transition-opacity duration-200 bg-gray-800 text-white text-xs py-1 px-2 rounded bottom-full mb-1 left-1/2 transform -translate-x-1/2 whitespace-nowrap z-10" }, "Double-click to select", /* @__PURE__ */ React.createElement("div", { className: "absolute top-full left-1/2 transform -translate-x-1/2 border-4 border-transparent border-t-gray-800" })))
2641
+ /* @__PURE__ */ import_react27.default.createElement("span", { className: "text-sm text-gray-800" }, child.name),
2642
+ hasChildren && /* @__PURE__ */ import_react27.default.createElement(import_react27.default.Fragment, null, /* @__PURE__ */ import_react27.default.createElement(import_fi.FiChevronRight, { className: "w-4 h-4 text-gray-400" }), /* @__PURE__ */ import_react27.default.createElement("div", { className: "absolute opacity-0 group-hover:opacity-100 transition-opacity duration-200 bg-gray-800 text-white text-xs py-1 px-2 rounded bottom-full mb-1 left-1/2 transform -translate-x-1/2 whitespace-nowrap z-10" }, "Double-click to select", /* @__PURE__ */ import_react27.default.createElement("div", { className: "absolute top-full left-1/2 transform -translate-x-1/2 border-4 border-transparent border-t-gray-800" })))
2641
2643
  );
2642
2644
  })))
2643
2645
  );
@@ -2645,15 +2647,85 @@ var NestedDropdown = ({
2645
2647
  };
2646
2648
  var NestedDropdown_default = NestedDropdown;
2647
2649
 
2648
- // src/components/OTPInput.tsx
2650
+ // src/components/Notice.tsx
2649
2651
  var import_react28 = __toESM(require("react"), 1);
2652
+ var import_class_variance_authority9 = require("class-variance-authority");
2653
+ var import_ri4 = require("react-icons/ri");
2654
+ var variantIconMap = {
2655
+ success: /* @__PURE__ */ import_react28.default.createElement(import_ri4.RiThumbUpLine, { size: 20, color: "#fff" }),
2656
+ warning: /* @__PURE__ */ import_react28.default.createElement(import_ri4.RiQuestionLine, { size: 20, color: "#fff" }),
2657
+ info: /* @__PURE__ */ import_react28.default.createElement(import_ri4.RiErrorWarningLine, { size: 20, color: "#fff" }),
2658
+ error: /* @__PURE__ */ import_react28.default.createElement(import_ri4.RiAlertFill, { size: 20, color: "#fff" }),
2659
+ default: /* @__PURE__ */ import_react28.default.createElement(import_ri4.RiShieldCheckLine, { size: 20, color: "#fff" })
2660
+ };
2661
+ var VariantIcon = ({ variant }) => /* @__PURE__ */ import_react28.default.createElement("span", null, variantIconMap[variant]);
2662
+ var noticeVariants = (0, import_class_variance_authority9.cva)(
2663
+ "fixed z-[10000000000] p-4 w-fit rounded-[6px] shadow-sm text-white transition-all duration-700",
2664
+ {
2665
+ variants: {
2666
+ variant: {
2667
+ success: "bg-success",
2668
+ warning: "bg-[#ffaa33]",
2669
+ info: "bg-primary-700",
2670
+ error: "bg-error",
2671
+ default: "bg-gray-800"
2672
+ },
2673
+ position: {
2674
+ "top-left": "top-4 left-4 mx-auto slide-in-top-left",
2675
+ "top-right": "top-4 right-4 mx-auto slide-in-top-right",
2676
+ "bottom-left": "bottom-4 left-4 slide-in-bottom-left",
2677
+ "bottom-right": "bottom-4 right-4 slide-in-bottom-right",
2678
+ "top-center": "top-4 left-0 right-0 mx-auto slide-in-top",
2679
+ "bottom-center": "bottom-4 left-0 right-0 mx-auto slide-in-bottom"
2680
+ }
2681
+ },
2682
+ defaultVariants: {
2683
+ position: "top-left",
2684
+ variant: "default"
2685
+ }
2686
+ }
2687
+ );
2688
+ var Notice = ({
2689
+ children,
2690
+ noticeTitle,
2691
+ variant = "default",
2692
+ position = "top-left",
2693
+ showIcon = true,
2694
+ open,
2695
+ setOpen,
2696
+ className,
2697
+ ...props
2698
+ }) => {
2699
+ if (!open) return null;
2700
+ const hasTitle = Boolean(noticeTitle?.length);
2701
+ return /* @__PURE__ */ import_react28.default.createElement(
2702
+ "div",
2703
+ {
2704
+ ...props,
2705
+ className: cn(noticeVariants({ variant, position }), className)
2706
+ },
2707
+ /* @__PURE__ */ import_react28.default.createElement("div", { className: "relative pr-8" }, /* @__PURE__ */ import_react28.default.createElement(
2708
+ "button",
2709
+ {
2710
+ onClick: () => setOpen(false),
2711
+ className: "absolute top-0 right-0 cursor-pointer",
2712
+ "aria-label": "Close notice"
2713
+ },
2714
+ /* @__PURE__ */ import_react28.default.createElement(import_ri4.RiCloseLine, { size: 20 })
2715
+ ), /* @__PURE__ */ import_react28.default.createElement("div", { className: "flex items-start gap-2" }, showIcon && /* @__PURE__ */ import_react28.default.createElement(VariantIcon, { variant }), /* @__PURE__ */ import_react28.default.createElement("div", null, hasTitle && /* @__PURE__ */ import_react28.default.createElement("p", { className: "font-bold text-sm mb-1" }, noticeTitle), /* @__PURE__ */ import_react28.default.createElement("p", { className: "text-sm" }, children))))
2716
+ );
2717
+ };
2718
+ var Notice_default = Notice;
2719
+
2720
+ // src/components/OTPInput.tsx
2721
+ var import_react29 = __toESM(require("react"), 1);
2650
2722
  var OTPInput = ({
2651
2723
  length,
2652
2724
  onChange,
2653
2725
  type = "text"
2654
2726
  }) => {
2655
- const [otpValues, setOtpValues] = (0, import_react28.useState)(Array(length).fill(""));
2656
- const inputsRef = (0, import_react28.useRef)([]);
2727
+ const [otpValues, setOtpValues] = (0, import_react29.useState)(Array(length).fill(""));
2728
+ const inputsRef = (0, import_react29.useRef)([]);
2657
2729
  const handleChange = (e, idx) => {
2658
2730
  let value = e.target.value;
2659
2731
  if (type === "number") value = value.replace(/\D/g, "");
@@ -2685,7 +2757,7 @@ var OTPInput = ({
2685
2757
  onChange(newOtp.join(""));
2686
2758
  inputsRef.current[Math.min(pasteData.length, length - 1)]?.focus();
2687
2759
  };
2688
- return /* @__PURE__ */ import_react28.default.createElement("div", { className: "flex items-center gap-2" }, Array.from({ length }).map((_, idx) => /* @__PURE__ */ import_react28.default.createElement(
2760
+ return /* @__PURE__ */ import_react29.default.createElement("div", { className: "flex items-center gap-2" }, Array.from({ length }).map((_, idx) => /* @__PURE__ */ import_react29.default.createElement(
2689
2761
  Input_default,
2690
2762
  {
2691
2763
  key: idx,
@@ -2706,8 +2778,8 @@ var OTPInput = ({
2706
2778
  var OTPInput_default = OTPInput;
2707
2779
 
2708
2780
  // src/components/Popover.tsx
2709
- var import_react29 = __toESM(require("react"), 1);
2710
- var Popover = (0, import_react29.forwardRef)(
2781
+ var import_react30 = __toESM(require("react"), 1);
2782
+ var Popover = (0, import_react30.forwardRef)(
2711
2783
  ({
2712
2784
  isOpen,
2713
2785
  setIsOpen,
@@ -2716,9 +2788,9 @@ var Popover = (0, import_react29.forwardRef)(
2716
2788
  className,
2717
2789
  postion = "bottom-right"
2718
2790
  }, ref) => {
2719
- const triggerRef = (0, import_react29.useRef)(null);
2720
- const contentRef = (0, import_react29.useRef)(null);
2721
- (0, import_react29.useEffect)(() => {
2791
+ const triggerRef = (0, import_react30.useRef)(null);
2792
+ const contentRef = (0, import_react30.useRef)(null);
2793
+ (0, import_react30.useEffect)(() => {
2722
2794
  const handleClickOutside = (event) => {
2723
2795
  if (!triggerRef.current?.contains(event.target) && !contentRef.current?.contains(event.target)) {
2724
2796
  setIsOpen(false);
@@ -2727,7 +2799,7 @@ var Popover = (0, import_react29.forwardRef)(
2727
2799
  document.addEventListener("mousedown", handleClickOutside);
2728
2800
  return () => document.removeEventListener("mousedown", handleClickOutside);
2729
2801
  }, [setIsOpen]);
2730
- return /* @__PURE__ */ import_react29.default.createElement("div", { className: "relative w-max", ref }, /* @__PURE__ */ import_react29.default.createElement(
2802
+ return /* @__PURE__ */ import_react30.default.createElement("div", { className: "relative w-max", ref }, /* @__PURE__ */ import_react30.default.createElement(
2731
2803
  "div",
2732
2804
  {
2733
2805
  className: "cursor-pointer",
@@ -2735,7 +2807,7 @@ var Popover = (0, import_react29.forwardRef)(
2735
2807
  onClick: () => setIsOpen(!isOpen)
2736
2808
  },
2737
2809
  trigger
2738
- ), isOpen && /* @__PURE__ */ import_react29.default.createElement(
2810
+ ), isOpen && /* @__PURE__ */ import_react30.default.createElement(
2739
2811
  "div",
2740
2812
  {
2741
2813
  ref: contentRef,
@@ -2750,11 +2822,11 @@ var Popover = (0, import_react29.forwardRef)(
2750
2822
  className
2751
2823
  )
2752
2824
  },
2753
- /* @__PURE__ */ import_react29.default.createElement(
2825
+ /* @__PURE__ */ import_react30.default.createElement(
2754
2826
  "div",
2755
2827
  {
2756
2828
  className: cn(
2757
- "absolute h-3 w-3 bg-white dark:bg-dark border border-primary-200 dark:border-primary-700 rotate-45",
2829
+ "absolute z-0 h-3 w-3 bg-white dark:bg-dark border border-primary-200 dark:border-primary-700 rotate-45",
2758
2830
  postion === "bottom-left" && "-top-1.5 left-4 border-b-0 border-r-0",
2759
2831
  postion === "bottom-right" && "-top-1.5 right-4 border-b-0 border-r-0",
2760
2832
  postion === "top-left" && "-bottom-1.5 left-4 border-t-0 border-l-0",
@@ -2771,10 +2843,73 @@ var Popover = (0, import_react29.forwardRef)(
2771
2843
  Popover.displayName = "Popover";
2772
2844
  var Popover_default = Popover;
2773
2845
 
2846
+ // src/components/Progress.tsx
2847
+ var import_react31 = __toESM(require("react"), 1);
2848
+ var Progress = ({
2849
+ progress,
2850
+ progressText = "",
2851
+ progressColor,
2852
+ progressTextPosition,
2853
+ rounded,
2854
+ height = "4px"
2855
+ }) => {
2856
+ const _progress = Math?.min(Math?.max(0, progress), 100);
2857
+ return /* @__PURE__ */ import_react31.default.createElement(
2858
+ "div",
2859
+ {
2860
+ className: cn(
2861
+ progressTextPosition === "right" ? "flex items-center gap-1" : progressTextPosition === "left" ? "flex items-center gap-1" : ""
2862
+ )
2863
+ },
2864
+ /* @__PURE__ */ import_react31.default.createElement(
2865
+ "span",
2866
+ {
2867
+ className: cn(
2868
+ "text-dark dark:text-light text-sm",
2869
+ progressTextPosition === "left" ? "inline-block" : progressTextPosition === "top" ? "flex justify-end" : "hidden"
2870
+ )
2871
+ },
2872
+ progressText
2873
+ ),
2874
+ /* @__PURE__ */ import_react31.default.createElement(
2875
+ "div",
2876
+ {
2877
+ className: cn(
2878
+ "w-full h-1 bg-gray-200 dark:bg-gray-800",
2879
+ rounded && "rounded"
2880
+ ),
2881
+ style: { height },
2882
+ role: "progressbar",
2883
+ "aria-valuenow": _progress,
2884
+ "aria-valuemin": 0,
2885
+ "aria-valuemax": 100
2886
+ },
2887
+ /* @__PURE__ */ import_react31.default.createElement(
2888
+ "div",
2889
+ {
2890
+ className: `${progressColor} h-full transition-all delay-100 duration-300 ease-in ${rounded && "rounded"}`,
2891
+ style: { width: `${_progress}%` }
2892
+ }
2893
+ )
2894
+ ),
2895
+ /* @__PURE__ */ import_react31.default.createElement(
2896
+ "span",
2897
+ {
2898
+ className: cn(
2899
+ "text-dark dark:text-light text-sm",
2900
+ progressTextPosition === "bottom" ? "flex justify-end" : progressTextPosition === "top" ? "hidden" : progressTextPosition === "right" ? "flex justify-end" : "hidden"
2901
+ )
2902
+ },
2903
+ progressText
2904
+ )
2905
+ );
2906
+ };
2907
+ var Progress_default = Progress;
2908
+
2774
2909
  // src/components/Radio.tsx
2775
- var import_react30 = __toESM(require("react"), 1);
2776
- var import_class_variance_authority9 = require("class-variance-authority");
2777
- var radioVariants = (0, import_class_variance_authority9.cva)("", {
2910
+ var import_react32 = __toESM(require("react"), 1);
2911
+ var import_class_variance_authority10 = require("class-variance-authority");
2912
+ var radioVariants = (0, import_class_variance_authority10.cva)("", {
2778
2913
  variants: {
2779
2914
  size: {
2780
2915
  sm: "h-3 w-3",
@@ -2785,9 +2920,9 @@ var radioVariants = (0, import_class_variance_authority9.cva)("", {
2785
2920
  size: "sm"
2786
2921
  }
2787
2922
  });
2788
- var Radio = (0, import_react30.forwardRef)(
2923
+ var Radio = (0, import_react32.forwardRef)(
2789
2924
  ({ size, disabled, checked, className, id, name, ...props }, ref) => {
2790
- return /* @__PURE__ */ import_react30.default.createElement("div", { className: "relative inline-flex items-center cursor-pointer" }, /* @__PURE__ */ import_react30.default.createElement(
2925
+ return /* @__PURE__ */ import_react32.default.createElement("div", { className: "relative inline-flex items-center cursor-pointer" }, /* @__PURE__ */ import_react32.default.createElement(
2791
2926
  "input",
2792
2927
  {
2793
2928
  ...props,
@@ -2804,7 +2939,7 @@ var Radio = (0, import_react30.forwardRef)(
2804
2939
  radioVariants({ size, className })
2805
2940
  )
2806
2941
  }
2807
- ), /* @__PURE__ */ import_react30.default.createElement(
2942
+ ), /* @__PURE__ */ import_react32.default.createElement(
2808
2943
  "span",
2809
2944
  {
2810
2945
  "aria-hidden": "true",
@@ -2820,7 +2955,7 @@ Radio.displayName = "Radio";
2820
2955
  var Radio_default = Radio;
2821
2956
 
2822
2957
  // src/components/Skeleton.tsx
2823
- var import_react31 = __toESM(require("react"), 1);
2958
+ var import_react33 = __toESM(require("react"), 1);
2824
2959
  var Skeleton = ({
2825
2960
  width = "100%",
2826
2961
  height = "100%",
@@ -2833,7 +2968,7 @@ var Skeleton = ({
2833
2968
  borderRadius: circle ? "50%" : void 0,
2834
2969
  display: "block"
2835
2970
  };
2836
- return /* @__PURE__ */ import_react31.default.createElement(
2971
+ return /* @__PURE__ */ import_react33.default.createElement(
2837
2972
  "span",
2838
2973
  {
2839
2974
  className: cn(
@@ -2850,11 +2985,11 @@ var Skeleton = ({
2850
2985
  var Skeleton_default = Skeleton;
2851
2986
 
2852
2987
  // src/components/Slider.tsx
2853
- var import_react32 = __toESM(require("react"), 1);
2854
- var Slider = (0, import_react32.forwardRef)(
2988
+ var import_react34 = __toESM(require("react"), 1);
2989
+ var Slider = (0, import_react34.forwardRef)(
2855
2990
  ({ value, min = 0, max = 100, size = "sm", ...props }, ref) => {
2856
2991
  const progress = (value - min) / (max - min) * 100;
2857
- return /* @__PURE__ */ import_react32.default.createElement(import_react32.default.Fragment, null, /* @__PURE__ */ import_react32.default.createElement(
2992
+ return /* @__PURE__ */ import_react34.default.createElement(import_react34.default.Fragment, null, /* @__PURE__ */ import_react34.default.createElement(
2858
2993
  "input",
2859
2994
  {
2860
2995
  ref,
@@ -2878,14 +3013,14 @@ Slider.displayName = "Slider";
2878
3013
  var Slider_default = Slider;
2879
3014
 
2880
3015
  // src/components/StatsCard.tsx
2881
- var import_react33 = __toESM(require("react"), 1);
3016
+ var import_react35 = __toESM(require("react"), 1);
2882
3017
  var StatsCard = ({
2883
3018
  statTitle,
2884
3019
  statDesc,
2885
3020
  className,
2886
3021
  cardIcon
2887
3022
  }) => {
2888
- return /* @__PURE__ */ import_react33.default.createElement(
3023
+ return /* @__PURE__ */ import_react35.default.createElement(
2889
3024
  Card,
2890
3025
  {
2891
3026
  className: cn(
@@ -2893,21 +3028,21 @@ var StatsCard = ({
2893
3028
  className
2894
3029
  )
2895
3030
  },
2896
- /* @__PURE__ */ import_react33.default.createElement("span", { className: "group-hover:text-white text-dark dark:text-white" }, cardIcon),
2897
- /* @__PURE__ */ import_react33.default.createElement(CardTitle, { className: "group-hover:text-white text-[48px] font-bold text-primary-500 dark:text-white my-4" }, statTitle),
2898
- /* @__PURE__ */ import_react33.default.createElement(CardDescription, { className: "group-hover:text-white text-[24px] hover:text-white text-dark leading-[25px]" }, statDesc)
3031
+ /* @__PURE__ */ import_react35.default.createElement("span", { className: "group-hover:text-white text-dark dark:text-white" }, cardIcon),
3032
+ /* @__PURE__ */ import_react35.default.createElement(CardTitle, { className: "group-hover:text-white text-[48px] font-bold text-primary-500 dark:text-white my-4" }, statTitle),
3033
+ /* @__PURE__ */ import_react35.default.createElement(CardDescription, { className: "group-hover:text-white text-[24px] hover:text-white text-dark leading-[25px]" }, statDesc)
2899
3034
  );
2900
3035
  };
2901
3036
  var StatsCard_default = StatsCard;
2902
3037
 
2903
3038
  // src/components/Tabs.tsx
2904
- var import_react34 = __toESM(require("react"), 1);
3039
+ var import_react36 = __toESM(require("react"), 1);
2905
3040
  var TabsContainer = ({
2906
3041
  children,
2907
3042
  className,
2908
3043
  position = "horizontal"
2909
3044
  }) => {
2910
- return /* @__PURE__ */ import_react34.default.createElement("div", { className: cn(position === "vertical" ? "flex" : "block", className) }, children);
3045
+ return /* @__PURE__ */ import_react36.default.createElement("div", { className: cn(position === "vertical" ? "flex" : "block", className) }, children);
2911
3046
  };
2912
3047
  var TabList = ({
2913
3048
  onChange,
@@ -2917,10 +3052,10 @@ var TabList = ({
2917
3052
  className,
2918
3053
  position = "horizontal"
2919
3054
  }) => {
2920
- const [focusIndex, setFocusIndex] = import_react34.default.useState(0);
2921
- const tabRefs = import_react34.default.useRef([]);
3055
+ const [focusIndex, setFocusIndex] = import_react36.default.useState(0);
3056
+ const tabRefs = import_react36.default.useRef([]);
2922
3057
  const handleKeyDown = (e, index) => {
2923
- const tabCount = import_react34.default.Children.count(children);
3058
+ const tabCount = import_react36.default.Children.count(children);
2924
3059
  switch (e.key) {
2925
3060
  case "ArrowRight": {
2926
3061
  if (position === "horizontal") {
@@ -2973,7 +3108,7 @@ var TabList = ({
2973
3108
  }
2974
3109
  }
2975
3110
  };
2976
- return /* @__PURE__ */ import_react34.default.createElement(
3111
+ return /* @__PURE__ */ import_react36.default.createElement(
2977
3112
  "div",
2978
3113
  {
2979
3114
  className: cn(
@@ -2985,9 +3120,9 @@ var TabList = ({
2985
3120
  "aria-label": ariaLabel,
2986
3121
  "aria-orientation": position
2987
3122
  },
2988
- import_react34.default.Children.map(children, (child, index) => {
2989
- if (import_react34.default.isValidElement(child)) {
2990
- return import_react34.default.cloneElement(child, {
3123
+ import_react36.default.Children.map(children, (child, index) => {
3124
+ if (import_react36.default.isValidElement(child)) {
3125
+ return import_react36.default.cloneElement(child, {
2991
3126
  onChange,
2992
3127
  box,
2993
3128
  position,
@@ -3002,7 +3137,7 @@ var TabList = ({
3002
3137
  })
3003
3138
  );
3004
3139
  };
3005
- var Tab = import_react34.default.forwardRef(
3140
+ var Tab = import_react36.default.forwardRef(
3006
3141
  ({
3007
3142
  label,
3008
3143
  value,
@@ -3017,7 +3152,7 @@ var Tab = import_react34.default.forwardRef(
3017
3152
  position = "horizontal"
3018
3153
  }, ref) => {
3019
3154
  const isSelected = value === selectedTabValue;
3020
- return /* @__PURE__ */ import_react34.default.createElement(
3155
+ return /* @__PURE__ */ import_react36.default.createElement(
3021
3156
  "button",
3022
3157
  {
3023
3158
  ref,
@@ -3047,9 +3182,9 @@ var Tab = import_react34.default.forwardRef(
3047
3182
  className
3048
3183
  )
3049
3184
  },
3050
- icon && /* @__PURE__ */ import_react34.default.createElement("span", { "aria-hidden": "true" }, icon),
3185
+ icon && /* @__PURE__ */ import_react36.default.createElement("span", { "aria-hidden": "true" }, icon),
3051
3186
  label,
3052
- content && /* @__PURE__ */ import_react34.default.createElement("span", { "aria-hidden": "true" }, content)
3187
+ content && /* @__PURE__ */ import_react36.default.createElement("span", { "aria-hidden": "true" }, content)
3053
3188
  );
3054
3189
  }
3055
3190
  );
@@ -3059,7 +3194,7 @@ var TabPanel = ({
3059
3194
  children,
3060
3195
  className
3061
3196
  }) => {
3062
- return value === currentValue ? /* @__PURE__ */ import_react34.default.createElement(
3197
+ return value === currentValue ? /* @__PURE__ */ import_react36.default.createElement(
3063
3198
  "div",
3064
3199
  {
3065
3200
  role: "tabpanel",
@@ -3075,9 +3210,9 @@ Tab.displayName = "Tab";
3075
3210
  var Tabs_default = TabsContainer;
3076
3211
 
3077
3212
  // src/components/Textarea.tsx
3078
- var import_class_variance_authority10 = require("class-variance-authority");
3079
- var import_react35 = __toESM(require("react"), 1);
3080
- var textareaVariants = (0, import_class_variance_authority10.cva)(
3213
+ var import_class_variance_authority11 = require("class-variance-authority");
3214
+ var import_react37 = __toESM(require("react"), 1);
3215
+ var textareaVariants = (0, import_class_variance_authority11.cva)(
3081
3216
  "flex items-center gap-2 font-karla bg-transparent text-sm outline-none rounded-radius-md border py-2 px-4 disabled:opacity-60 disabled:select-none disabled:pointer-events-none w-full",
3082
3217
  {
3083
3218
  variants: {
@@ -3091,9 +3226,9 @@ var textareaVariants = (0, import_class_variance_authority10.cva)(
3091
3226
  }
3092
3227
  }
3093
3228
  );
3094
- var Textarea = (0, import_react35.forwardRef)(
3229
+ var Textarea = (0, import_react37.forwardRef)(
3095
3230
  ({ className, rows, cols, variant, disabled, children, ...props }, ref) => {
3096
- return /* @__PURE__ */ import_react35.default.createElement(
3231
+ return /* @__PURE__ */ import_react37.default.createElement(
3097
3232
  "textarea",
3098
3233
  {
3099
3234
  ...props,
@@ -3111,9 +3246,9 @@ Textarea.displayName = "Textarea";
3111
3246
  var Textarea_default = Textarea;
3112
3247
 
3113
3248
  // src/components/Toggle.tsx
3114
- var import_class_variance_authority11 = require("class-variance-authority");
3115
- var import_react36 = __toESM(require("react"), 1);
3116
- var toggleVariants = (0, import_class_variance_authority11.cva)(
3249
+ var import_class_variance_authority12 = require("class-variance-authority");
3250
+ var import_react38 = __toESM(require("react"), 1);
3251
+ var toggleVariants = (0, import_class_variance_authority12.cva)(
3117
3252
  "rounded-radius-xl bg-gray-300 transition-colors peer-checked:bg-primary-500 peer-active:ring-2 peer-active:ring-primary-300",
3118
3253
  {
3119
3254
  variants: {
@@ -3127,9 +3262,9 @@ var toggleVariants = (0, import_class_variance_authority11.cva)(
3127
3262
  }
3128
3263
  }
3129
3264
  );
3130
- var Toggle = (0, import_react36.forwardRef)(
3265
+ var Toggle = (0, import_react38.forwardRef)(
3131
3266
  ({ icon, children, disabled, size = "lg", ...props }, ref) => {
3132
- return /* @__PURE__ */ import_react36.default.createElement(
3267
+ return /* @__PURE__ */ import_react38.default.createElement(
3133
3268
  "label",
3134
3269
  {
3135
3270
  className: cn(
@@ -3137,7 +3272,7 @@ var Toggle = (0, import_react36.forwardRef)(
3137
3272
  disabled && "opacity-50 pointer-events-none"
3138
3273
  )
3139
3274
  },
3140
- /* @__PURE__ */ import_react36.default.createElement("div", { className: "relative" }, /* @__PURE__ */ import_react36.default.createElement(
3275
+ /* @__PURE__ */ import_react38.default.createElement("div", { className: "relative" }, /* @__PURE__ */ import_react38.default.createElement(
3141
3276
  "input",
3142
3277
  {
3143
3278
  type: "checkbox",
@@ -3146,7 +3281,7 @@ var Toggle = (0, import_react36.forwardRef)(
3146
3281
  ...props,
3147
3282
  className: "sr-only peer"
3148
3283
  }
3149
- ), /* @__PURE__ */ import_react36.default.createElement("div", { className: cn(toggleVariants({ size })) }), /* @__PURE__ */ import_react36.default.createElement(
3284
+ ), /* @__PURE__ */ import_react38.default.createElement("div", { className: cn(toggleVariants({ size })) }), /* @__PURE__ */ import_react38.default.createElement(
3150
3285
  "div",
3151
3286
  {
3152
3287
  className: cn(
@@ -3154,7 +3289,7 @@ var Toggle = (0, import_react36.forwardRef)(
3154
3289
  size === "sm" ? "peer-checked:translate-x-2 top-[1px] left-[2px] w-5 h-4 rounded-radius-md" : "peer-checked:translate-x-[11px] top-[2.5px] left-1 h-[22px] w-[34px] rounded-radius-lg"
3155
3290
  )
3156
3291
  },
3157
- /* @__PURE__ */ import_react36.default.createElement("span", { className: "flex items-center justify-center" }, icon),
3292
+ /* @__PURE__ */ import_react38.default.createElement("span", { className: "flex items-center justify-center" }, icon),
3158
3293
  children
3159
3294
  ))
3160
3295
  );
@@ -3164,12 +3299,12 @@ Toggle.displayName = "Toggle";
3164
3299
  var Toggle_default = Toggle;
3165
3300
 
3166
3301
  // src/components/TreeView.tsx
3167
- var import_react37 = __toESM(require("react"), 1);
3302
+ var import_react39 = __toESM(require("react"), 1);
3168
3303
  var import_hi5 = require("react-icons/hi");
3169
3304
  var TreeViewLeadingVisual = ({
3170
3305
  children
3171
- }) => /* @__PURE__ */ import_react37.default.createElement("span", { className: "flex items-center shrink-0 w-5 h-5 justify-center" }, children);
3172
- var TreeViewTrailingVisual = ({ children, label }) => /* @__PURE__ */ import_react37.default.createElement("span", { "aria-label": label, className: "ml-auto flex items-center shrink-0" }, children);
3306
+ }) => /* @__PURE__ */ import_react39.default.createElement("span", { className: "flex items-center shrink-0 w-5 h-5 justify-center" }, children);
3307
+ var TreeViewTrailingVisual = ({ children, label }) => /* @__PURE__ */ import_react39.default.createElement("span", { "aria-label": label, className: "ml-auto flex items-center shrink-0" }, children);
3173
3308
  var TreeViewSubTree = ({
3174
3309
  children,
3175
3310
  expanded = false,
@@ -3179,7 +3314,7 @@ var TreeViewSubTree = ({
3179
3314
  count
3180
3315
  }) => {
3181
3316
  if (flat) return null;
3182
- return /* @__PURE__ */ import_react37.default.createElement(
3317
+ return /* @__PURE__ */ import_react39.default.createElement(
3183
3318
  "ul",
3184
3319
  {
3185
3320
  role: "group",
@@ -3189,7 +3324,7 @@ var TreeViewSubTree = ({
3189
3324
  className
3190
3325
  )
3191
3326
  },
3192
- state === "loading" ? /* @__PURE__ */ import_react37.default.createElement("li", { className: "pl-6 py-1 text-gray-500 italic" }, "Loading", count ? ` ${count} items...` : "...") : children
3327
+ state === "loading" ? /* @__PURE__ */ import_react39.default.createElement("li", { className: "pl-6 py-1 text-gray-500 italic" }, "Loading", count ? ` ${count} items...` : "...") : children
3193
3328
  );
3194
3329
  };
3195
3330
  var TreeViewItem = ({
@@ -3208,8 +3343,8 @@ var TreeViewItem = ({
3208
3343
  const trailing = [];
3209
3344
  const content = [];
3210
3345
  const subTrees = [];
3211
- import_react37.Children.forEach(children, (child) => {
3212
- if (!(0, import_react37.isValidElement)(child)) {
3346
+ import_react39.Children.forEach(children, (child) => {
3347
+ if (!(0, import_react39.isValidElement)(child)) {
3213
3348
  content.push(child);
3214
3349
  return;
3215
3350
  }
@@ -3226,7 +3361,7 @@ var TreeViewItem = ({
3226
3361
  onToggle?.(id);
3227
3362
  }
3228
3363
  };
3229
- return /* @__PURE__ */ import_react37.default.createElement(import_react37.default.Fragment, null, /* @__PURE__ */ import_react37.default.createElement(
3364
+ return /* @__PURE__ */ import_react39.default.createElement(import_react39.default.Fragment, null, /* @__PURE__ */ import_react39.default.createElement(
3230
3365
  "li",
3231
3366
  {
3232
3367
  role: "treeitem",
@@ -3243,12 +3378,12 @@ var TreeViewItem = ({
3243
3378
  className
3244
3379
  )
3245
3380
  },
3246
- !leading.length && hasSubTree && !flat && /* @__PURE__ */ import_react37.default.createElement("span", { className: "text-gray-400" }, expanded ? /* @__PURE__ */ import_react37.default.createElement(import_hi5.HiChevronDown, { size: 18 }) : /* @__PURE__ */ import_react37.default.createElement(import_hi5.HiChevronRight, { size: 18 })),
3381
+ !leading.length && hasSubTree && !flat && /* @__PURE__ */ import_react39.default.createElement("span", { className: "text-gray-400" }, expanded ? /* @__PURE__ */ import_react39.default.createElement(import_hi5.HiChevronDown, { size: 18 }) : /* @__PURE__ */ import_react39.default.createElement(import_hi5.HiChevronRight, { size: 18 })),
3247
3382
  leading,
3248
- /* @__PURE__ */ import_react37.default.createElement("span", { className: "flex-1 truncate" }, content),
3383
+ /* @__PURE__ */ import_react39.default.createElement("span", { className: "flex-1 truncate" }, content),
3249
3384
  trailing
3250
3385
  ), subTrees.map(
3251
- (subTree, index) => import_react37.default.cloneElement(subTree, {
3386
+ (subTree, index) => import_react39.default.cloneElement(subTree, {
3252
3387
  expanded,
3253
3388
  flat,
3254
3389
  key: `${id}-subtree-${index}`
@@ -3265,10 +3400,10 @@ var TreeView = ({
3265
3400
  onExpandedChange,
3266
3401
  allowMultiple = true
3267
3402
  }) => {
3268
- const [internalExpanded, setInternalExpanded] = (0, import_react37.useState)(
3403
+ const [internalExpanded, setInternalExpanded] = (0, import_react39.useState)(
3269
3404
  () => new Set(defaultExpandedIds)
3270
3405
  );
3271
- const [selectedId, setSelectedId] = (0, import_react37.useState)(null);
3406
+ const [selectedId, setSelectedId] = (0, import_react39.useState)(null);
3272
3407
  const expandedSet = expandedIds ? new Set(expandedIds) : internalExpanded;
3273
3408
  const toggleNode = (id) => {
3274
3409
  const update = (prev) => {
@@ -3292,10 +3427,10 @@ var TreeView = ({
3292
3427
  setInternalExpanded(update);
3293
3428
  }
3294
3429
  };
3295
- const enhance = (nodes, level = 0) => import_react37.Children.map(nodes, (child) => {
3296
- if (!(0, import_react37.isValidElement)(child)) return child;
3430
+ const enhance = (nodes, level = 0) => import_react39.Children.map(nodes, (child) => {
3431
+ if (!(0, import_react39.isValidElement)(child)) return child;
3297
3432
  if (child.type === TreeViewItem) {
3298
- return import_react37.default.cloneElement(child, {
3433
+ return import_react39.default.cloneElement(child, {
3299
3434
  level,
3300
3435
  expanded: expandedSet.has(child.props.id),
3301
3436
  selected: selectedId === child.props.id,
@@ -3310,14 +3445,14 @@ var TreeView = ({
3310
3445
  });
3311
3446
  }
3312
3447
  if (child.type === TreeViewSubTree) {
3313
- return import_react37.default.cloneElement(child, {
3448
+ return import_react39.default.cloneElement(child, {
3314
3449
  // Increase level for items inside the SubTree
3315
3450
  children: enhance(child.props.children, level + 1)
3316
3451
  });
3317
3452
  }
3318
3453
  return child;
3319
3454
  });
3320
- return /* @__PURE__ */ import_react37.default.createElement(
3455
+ return /* @__PURE__ */ import_react39.default.createElement(
3321
3456
  "ul",
3322
3457
  {
3323
3458
  role: "tree",
@@ -3379,9 +3514,11 @@ var TreeView_default = TreeView;
3379
3514
  Loading,
3380
3515
  Modal,
3381
3516
  NestedDropdown,
3517
+ Notice,
3382
3518
  OTPInput,
3383
3519
  Paragraph,
3384
3520
  Popover,
3521
+ Progress,
3385
3522
  Radio,
3386
3523
  Skeleton,
3387
3524
  Slider,