@algorithm-shift/design-system 1.2.31 → 1.2.33

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.js CHANGED
@@ -298,35 +298,17 @@ function Input({ className, type, ...props }) {
298
298
  var import_jsx_runtime10 = require("react/jsx-runtime");
299
299
  var TextInput = ({ className, style, ...props }) => {
300
300
  const placeholder = props.placeholder || "Placeholder text";
301
- const regexPattern = props.regexPattern ?? "";
302
- const errorMessage = props.errorMessage ?? "Required";
303
- const noOfCharacters = props.noOfCharacters ?? 100;
304
- const isRequired = props.isRequired ?? false;
305
301
  const isEditable = props.isEditable ?? true;
306
302
  const isDisabled = props.isDisabled ?? false;
307
303
  const isReadonly = props.isReadonly ?? false;
308
304
  const isAutocomplete = props.isAutocomplete ?? false;
309
- const [value, setValue] = React2.useState("");
310
305
  const [error, setError] = React2.useState(null);
311
306
  React2.useEffect(() => {
312
307
  if (!props.validateOnMount) return;
313
308
  setError(props.errorMessage || null);
314
309
  }, [props.errorMessage, props.validateOnMount]);
315
310
  const handleChange = (e) => {
316
- if (props.hasFormContainer) {
317
- props.onChange?.(e);
318
- return;
319
- }
320
- const val = e.target.value;
321
- if (val.length > noOfCharacters) return;
322
- setValue(val);
323
- if (isRequired && val.trim() === "") {
324
- setError(errorMessage);
325
- } else if (regexPattern && !new RegExp(regexPattern).test(val)) {
326
- setError(errorMessage);
327
- } else {
328
- setError(null);
329
- }
311
+ props.onChange?.(e);
330
312
  };
331
313
  return /* @__PURE__ */ (0, import_jsx_runtime10.jsxs)(import_jsx_runtime10.Fragment, { children: [
332
314
  /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(
@@ -339,15 +321,12 @@ var TextInput = ({ className, style, ...props }) => {
339
321
  ...style,
340
322
  borderColor: error ? "#f87171" : style?.borderColor
341
323
  },
342
- value: props.value || value,
324
+ value: props.value,
343
325
  autoComplete: isAutocomplete ? "on" : "off",
344
326
  placeholder,
345
327
  onChange: handleChange,
346
328
  disabled: isDisabled || !isEditable,
347
- readOnly: isReadonly,
348
- required: isRequired,
349
- maxLength: noOfCharacters,
350
- pattern: regexPattern || void 0
329
+ readOnly: isReadonly
351
330
  }
352
331
  ),
353
332
  error && /* @__PURE__ */ (0, import_jsx_runtime10.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
@@ -560,35 +539,17 @@ var import_react4 = require("react");
560
539
  var import_jsx_runtime11 = require("react/jsx-runtime");
561
540
  var NumberInput = ({ className, style, ...props }) => {
562
541
  const placeholder = props.placeholder ?? "Placeholder text";
563
- const regexPattern = props.regexPattern ?? "";
564
- const errorMessage = props.errorMessage ?? "Required";
565
- const noOfCharacters = props.noOfCharacters ?? 100;
566
- const isRequired = props.isRequired ?? false;
567
542
  const isEditable = props.isEditable ?? true;
568
543
  const isDisabled = props.isDisabled ?? false;
569
544
  const isReadonly = props.isReadonly ?? false;
570
545
  const isAutocomplete = props.isAutocomplete ?? false;
571
- const [value, setValue] = React3.useState("");
572
546
  const [error, setError] = React3.useState(null);
573
547
  (0, import_react4.useEffect)(() => {
574
548
  if (!props.validateOnMount) return;
575
549
  setError(props.errorMessage || null);
576
550
  }, [props.errorMessage, props.validateOnMount]);
577
551
  const handleChange = (e) => {
578
- if (props.hasFormContainer) {
579
- props.onChange?.(e);
580
- return;
581
- }
582
- const val = e.target.value;
583
- if (val.length > noOfCharacters) return;
584
- setValue(val);
585
- if (isRequired && val.trim() === "") {
586
- setError(errorMessage);
587
- } else if (regexPattern && !new RegExp(regexPattern).test(val)) {
588
- setError(errorMessage);
589
- } else {
590
- setError(null);
591
- }
552
+ props.onChange?.(e);
592
553
  };
593
554
  return /* @__PURE__ */ (0, import_jsx_runtime11.jsxs)(import_jsx_runtime11.Fragment, { children: [
594
555
  /* @__PURE__ */ (0, import_jsx_runtime11.jsxs)("div", { className: "flex justify-start items-center relative", children: [
@@ -597,9 +558,9 @@ var NumberInput = ({ className, style, ...props }) => {
597
558
  Input,
598
559
  {
599
560
  type: "number",
600
- id: "number-field",
561
+ id: props.name || "number-field",
601
562
  name: props.name,
602
- value: props.value || value,
563
+ value: props.value,
603
564
  className: cn(className, error ? "border-red-500" : ""),
604
565
  style: {
605
566
  ...style,
@@ -609,10 +570,7 @@ var NumberInput = ({ className, style, ...props }) => {
609
570
  placeholder,
610
571
  onChange: handleChange,
611
572
  disabled: isDisabled || !isEditable,
612
- readOnly: isReadonly,
613
- required: isRequired,
614
- maxLength: noOfCharacters,
615
- pattern: regexPattern || void 0
573
+ readOnly: isReadonly
616
574
  }
617
575
  )
618
576
  ] }),
@@ -626,35 +584,17 @@ var React4 = __toESM(require("react"));
626
584
  var import_jsx_runtime12 = require("react/jsx-runtime");
627
585
  var EmailInput = ({ className, style, ...props }) => {
628
586
  const placeholder = props.placeholder ?? "Placeholder text";
629
- const regexPattern = props.regexPattern ?? "";
630
- const errorMessage = props.errorMessage ?? "Required";
631
- const noOfCharacters = props.noOfCharacters ?? 100;
632
- const isRequired = props.isRequired ?? false;
633
587
  const isEditable = props.isEditable ?? true;
634
588
  const isDisabled = props.isDisabled ?? false;
635
589
  const isReadonly = props.isReadonly ?? false;
636
590
  const isAutocomplete = props.isAutocomplete ?? false;
637
- const [value, setValue] = React4.useState("");
638
591
  const [error, setError] = React4.useState(null);
639
592
  React4.useEffect(() => {
640
593
  if (!props.validateOnMount) return;
641
594
  setError(props.errorMessage || null);
642
595
  }, [props.errorMessage, props.validateOnMount]);
643
596
  const handleChange = (e) => {
644
- if (props.hasFormContainer) {
645
- props.onChange?.(e);
646
- return;
647
- }
648
- const val = e.target.value;
649
- if (val.length > noOfCharacters) return;
650
- setValue(val);
651
- if (isRequired && val.trim() === "") {
652
- setError(errorMessage);
653
- } else if (regexPattern && !new RegExp(regexPattern).test(val)) {
654
- setError(errorMessage);
655
- } else {
656
- setError(null);
657
- }
597
+ props.onChange?.(e);
658
598
  };
659
599
  return /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)(import_jsx_runtime12.Fragment, { children: [
660
600
  /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)("div", { className: "flex justify-start items-center relative", children: [
@@ -664,7 +604,7 @@ var EmailInput = ({ className, style, ...props }) => {
664
604
  {
665
605
  type: "email",
666
606
  name: props.name,
667
- value: props.value || value,
607
+ value: props.value,
668
608
  className: cn(className, error ? "border-red-500" : ""),
669
609
  style: {
670
610
  ...style,
@@ -674,10 +614,7 @@ var EmailInput = ({ className, style, ...props }) => {
674
614
  placeholder,
675
615
  onChange: handleChange,
676
616
  disabled: isDisabled || !isEditable,
677
- readOnly: isReadonly,
678
- required: isRequired,
679
- maxLength: noOfCharacters,
680
- pattern: regexPattern || void 0
617
+ readOnly: isReadonly
681
618
  }
682
619
  )
683
620
  ] }),
@@ -691,35 +628,17 @@ var React5 = __toESM(require("react"));
691
628
  var import_jsx_runtime13 = require("react/jsx-runtime");
692
629
  var PasswordInput = ({ className, style, ...props }) => {
693
630
  const placeholder = props.placeholder ?? "Placeholder text";
694
- const regexPattern = props.regexPattern ?? "";
695
- const errorMessage = props.errorMessage ?? "Required";
696
- const noOfCharacters = props.noOfCharacters ?? 100;
697
- const isRequired = props.isRequired ?? false;
698
631
  const isEditable = props.isEditable ?? true;
699
632
  const isDisabled = props.isDisabled ?? false;
700
633
  const isReadonly = props.isReadonly ?? false;
701
634
  const isAutocomplete = props.isAutocomplete ?? false;
702
- const [value, setValue] = React5.useState("");
703
635
  const [error, setError] = React5.useState(null);
704
636
  React5.useEffect(() => {
705
637
  if (!props.validateOnMount) return;
706
638
  setError(props.errorMessage || null);
707
639
  }, [props.errorMessage, props.validateOnMount]);
708
640
  const handleChange = (e) => {
709
- if (props.hasFormContainer) {
710
- props.onChange?.(e);
711
- return;
712
- }
713
- const val = e.target.value;
714
- if (val.length > noOfCharacters) return;
715
- setValue(val);
716
- if (isRequired && val.trim() === "") {
717
- setError(errorMessage);
718
- } else if (regexPattern && !new RegExp(regexPattern).test(val)) {
719
- setError(errorMessage);
720
- } else {
721
- setError(null);
722
- }
641
+ props.onChange?.(e);
723
642
  };
724
643
  return /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)(import_jsx_runtime13.Fragment, { children: [
725
644
  /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)("div", { className: "flex justify-start items-center relative", children: [
@@ -728,9 +647,9 @@ var PasswordInput = ({ className, style, ...props }) => {
728
647
  Input,
729
648
  {
730
649
  type: "password",
731
- id: "password-field",
650
+ id: props.name || "password-field",
732
651
  name: props.name,
733
- value: props.value || value,
652
+ value: props.value,
734
653
  className: cn(className, error ? "border-red-500" : ""),
735
654
  style: {
736
655
  ...style,
@@ -740,10 +659,7 @@ var PasswordInput = ({ className, style, ...props }) => {
740
659
  placeholder,
741
660
  onChange: handleChange,
742
661
  disabled: isDisabled || !isEditable,
743
- readOnly: isReadonly,
744
- required: isRequired,
745
- maxLength: noOfCharacters,
746
- pattern: regexPattern || void 0
662
+ readOnly: isReadonly
747
663
  }
748
664
  )
749
665
  ] }),
@@ -775,35 +691,17 @@ function Textarea({ className, ...props }) {
775
691
  var import_jsx_runtime15 = require("react/jsx-runtime");
776
692
  var Textarea2 = ({ className, style, ...props }) => {
777
693
  const placeholder = props.placeholder ?? "Placeholder text";
778
- const regexPattern = props.regexPattern ?? "";
779
- const errorMessage = props.errorMessage ?? "Required";
780
- const noOfCharacters = props.noOfCharacters ?? 100;
781
- const isRequired = props.isRequired ?? false;
782
694
  const isEditable = props.isEditable ?? true;
783
695
  const isDisabled = props.isDisabled ?? false;
784
696
  const isReadonly = props.isReadonly ?? false;
785
697
  const isAutocomplete = props.isAutocomplete ?? false;
786
- const [value, setValue] = React6.useState("");
787
698
  const [error, setError] = React6.useState(null);
788
699
  React6.useEffect(() => {
789
700
  if (!props.validateOnMount) return;
790
701
  setError(props.errorMessage || null);
791
702
  }, [props.errorMessage, props.validateOnMount]);
792
703
  const handleChange = (e) => {
793
- if (props.hasFormContainer) {
794
- props.onChange?.(e);
795
- return;
796
- }
797
- const val = e.target.value;
798
- if (val.length > noOfCharacters) return;
799
- setValue(val);
800
- if (isRequired && val.trim() === "") {
801
- setError(errorMessage);
802
- } else if (regexPattern && !new RegExp(regexPattern).test(val)) {
803
- setError(errorMessage);
804
- } else {
805
- setError(null);
806
- }
704
+ props.onChange?.(e);
807
705
  };
808
706
  return /* @__PURE__ */ (0, import_jsx_runtime15.jsxs)(import_jsx_runtime15.Fragment, { children: [
809
707
  /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(
@@ -811,7 +709,7 @@ var Textarea2 = ({ className, style, ...props }) => {
811
709
  {
812
710
  id: "textarea-field",
813
711
  name: props.name,
814
- value: props.value || value,
712
+ value: props.value,
815
713
  className: cn(className, error ? "border-red-500" : ""),
816
714
  style: {
817
715
  ...style,
@@ -821,9 +719,7 @@ var Textarea2 = ({ className, style, ...props }) => {
821
719
  placeholder,
822
720
  onChange: handleChange,
823
721
  disabled: isDisabled || !isEditable,
824
- readOnly: isReadonly,
825
- required: isRequired,
826
- maxLength: noOfCharacters
722
+ readOnly: isReadonly
827
723
  }
828
724
  ),
829
725
  error && /* @__PURE__ */ (0, import_jsx_runtime15.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
@@ -836,35 +732,17 @@ var React7 = __toESM(require("react"));
836
732
  var import_jsx_runtime16 = require("react/jsx-runtime");
837
733
  var UrlInput = ({ className, style, ...props }) => {
838
734
  const placeholder = props.placeholder ?? "Placeholder text";
839
- const regexPattern = props.regexPattern ?? "";
840
- const errorMessage = props.errorMessage ?? "Required";
841
- const noOfCharacters = props.noOfCharacters ?? 100;
842
- const isRequired = props.isRequired ?? false;
843
735
  const isEditable = props.isEditable ?? true;
844
736
  const isDisabled = props.isDisabled ?? false;
845
737
  const isReadonly = props.isReadonly ?? false;
846
738
  const isAutocomplete = props.isAutocomplete ?? false;
847
- const [value, setValue] = React7.useState("");
848
739
  const [error, setError] = React7.useState(null);
849
740
  React7.useEffect(() => {
850
741
  if (!props.validateOnMount) return;
851
742
  setError(props.errorMessage || null);
852
743
  }, [props.errorMessage, props.validateOnMount]);
853
744
  const handleChange = (e) => {
854
- if (props.hasFormContainer) {
855
- props.onChange?.(e);
856
- return;
857
- }
858
- const val = e.target.value;
859
- if (val.length > noOfCharacters) return;
860
- setValue(val);
861
- if (isRequired && val.trim() === "") {
862
- setError(errorMessage);
863
- } else if (regexPattern && !new RegExp(regexPattern).test(val)) {
864
- setError(errorMessage);
865
- } else {
866
- setError(null);
867
- }
745
+ props.onChange?.(e);
868
746
  };
869
747
  return /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)(import_jsx_runtime16.Fragment, { children: [
870
748
  /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)("div", { className: "flex justify-start items-center relative", children: [
@@ -875,7 +753,7 @@ var UrlInput = ({ className, style, ...props }) => {
875
753
  id: "url-field",
876
754
  type: "url",
877
755
  name: props.name,
878
- value: props.value || value,
756
+ value: props.value,
879
757
  className: cn(className, error ? "border-red-500" : ""),
880
758
  style: {
881
759
  ...style,
@@ -885,10 +763,7 @@ var UrlInput = ({ className, style, ...props }) => {
885
763
  placeholder,
886
764
  onChange: handleChange,
887
765
  disabled: isDisabled || !isEditable,
888
- readOnly: isReadonly,
889
- required: isRequired,
890
- maxLength: noOfCharacters,
891
- pattern: regexPattern || void 0
766
+ readOnly: isReadonly
892
767
  }
893
768
  )
894
769
  ] }),
@@ -897,6 +772,9 @@ var UrlInput = ({ className, style, ...props }) => {
897
772
  };
898
773
  var UrlInput_default = UrlInput;
899
774
 
775
+ // src/components/Inputs/Checkbox/Checkbox.tsx
776
+ var import_react5 = require("react");
777
+
900
778
  // src/components/ui/checkbox.tsx
901
779
  var CheckboxPrimitive = __toESM(require("@radix-ui/react-checkbox"));
902
780
  var import_jsx_runtime17 = require("react/jsx-runtime");
@@ -948,14 +826,38 @@ function Label({
948
826
  // src/components/Inputs/Checkbox/Checkbox.tsx
949
827
  var import_jsx_runtime19 = require("react/jsx-runtime");
950
828
  var CheckboxInput = ({ className, style, ...props }) => {
829
+ const isEditable = props.isEditable ?? true;
830
+ const isDisabled = props.isDisabled ?? false;
951
831
  const text = props.text ? props.text : "Subscribe";
952
- return /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)("div", { className: "flex items-center space-x-2", children: [
953
- /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(Checkbox, { id: "newsletter" }),
954
- /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(Label, { htmlFor: "newsletter", children: text })
955
- ] }) });
832
+ const [error, setError] = (0, import_react5.useState)(null);
833
+ (0, import_react5.useEffect)(() => {
834
+ if (!props.validateOnMount) return;
835
+ setError(props.errorMessage || null);
836
+ }, [props.errorMessage, props.validateOnMount]);
837
+ const handleChange = (value) => {
838
+ props.onChange?.(value);
839
+ };
840
+ return /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)(import_jsx_runtime19.Fragment, { children: [
841
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)("div", { className: "flex items-center space-x-2", children: [
842
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
843
+ Checkbox,
844
+ {
845
+ id: props.name || "checkbox",
846
+ checked: !!props.value,
847
+ onCheckedChange: handleChange,
848
+ disabled: !isEditable || isDisabled
849
+ }
850
+ ),
851
+ /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(Label, { htmlFor: props.name || "checkbox", children: text })
852
+ ] }) }),
853
+ error && /* @__PURE__ */ (0, import_jsx_runtime19.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
854
+ ] });
956
855
  };
957
856
  var Checkbox_default = CheckboxInput;
958
857
 
858
+ // src/components/Inputs/RadioInput/RadioInput.tsx
859
+ var import_react6 = require("react");
860
+
959
861
  // src/components/ui/radio-group.tsx
960
862
  var RadioGroupPrimitive = __toESM(require("@radix-ui/react-radio-group"));
961
863
  var import_jsx_runtime20 = require("react/jsx-runtime");
@@ -999,39 +901,108 @@ function RadioGroupItem({
999
901
 
1000
902
  // src/components/Inputs/RadioInput/RadioInput.tsx
1001
903
  var import_jsx_runtime21 = require("react/jsx-runtime");
1002
- var RadioInput = ({ className, style, ...props }) => {
1003
- const text = Array.isArray(props.text) ? props.text : [props.text ?? "Subscribe"];
1004
- const formatList = text.filter((i) => i.value && i.label).map((item) => ({
1005
- label: item.label,
1006
- value: item.value
904
+ var RadioInput = ({
905
+ className,
906
+ style,
907
+ defaultValue,
908
+ onChange,
909
+ data = [],
910
+ dataKey,
911
+ dataLabel,
912
+ ...props
913
+ }) => {
914
+ const [error, setError] = (0, import_react6.useState)(null);
915
+ (0, import_react6.useEffect)(() => {
916
+ if (!props.validateOnMount) return;
917
+ setError(props.errorMessage || null);
918
+ }, [props.errorMessage, props.validateOnMount]);
919
+ const options = (data || []).map((item) => ({
920
+ value: item[dataKey || "value"],
921
+ label: item[dataLabel || "label"]
1007
922
  }));
1008
- return /* @__PURE__ */ (0, import_jsx_runtime21.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(RadioGroup, { defaultValue: "option-1", children: formatList?.map((item, index) => /* @__PURE__ */ (0, import_jsx_runtime21.jsxs)("div", { className: "flex items-center space-x-2", children: [
1009
- /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(RadioGroupItem, { value: item.value, id: `r${index}` }),
1010
- /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(Label, { htmlFor: `r${index}`, children: item.label })
1011
- ] }, index)) }) });
923
+ const handleChange = (value) => {
924
+ onChange?.(value);
925
+ };
926
+ const resolvedDefaultValue = (typeof defaultValue === "string" ? defaultValue : void 0) ?? options[0]?.value;
927
+ return /* @__PURE__ */ (0, import_jsx_runtime21.jsxs)(import_jsx_runtime21.Fragment, { children: [
928
+ /* @__PURE__ */ (0, import_jsx_runtime21.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime21.jsxs)(
929
+ RadioGroup,
930
+ {
931
+ defaultValue: resolvedDefaultValue,
932
+ onValueChange: handleChange,
933
+ children: [
934
+ options.length === 0 && /* @__PURE__ */ (0, import_jsx_runtime21.jsx)("div", { className: "text-sm text-gray-500", children: "No options available" }),
935
+ options.map((item) => /* @__PURE__ */ (0, import_jsx_runtime21.jsxs)("div", { className: "flex items-center space-x-2", children: [
936
+ /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(RadioGroupItem, { value: item.value, id: `radio-${item.value}` }),
937
+ /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(Label, { htmlFor: `radio-${item.value}`, children: item.label })
938
+ ] }, item.value))
939
+ ]
940
+ }
941
+ ) }),
942
+ error && /* @__PURE__ */ (0, import_jsx_runtime21.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
943
+ ] });
1012
944
  };
1013
945
  var RadioInput_default = RadioInput;
1014
946
 
1015
947
  // src/components/Inputs/MultiCheckbox/MultiCheckbox.tsx
948
+ var import_react7 = require("react");
1016
949
  var import_jsx_runtime22 = require("react/jsx-runtime");
1017
- var MultiCheckbox = ({ className, style, ...props }) => {
1018
- const text = Array.isArray(props.text) ? props.text : [props.text ?? "Subscribe"];
1019
- const formatList = text.filter((i) => i.value && i.label).map((item) => ({
1020
- label: item.label,
1021
- value: item.value
950
+ var MultiCheckbox = ({
951
+ className,
952
+ style,
953
+ data = [],
954
+ dataKey = "value",
955
+ dataLabel = "label",
956
+ value: propValue = {},
957
+ onChange,
958
+ isEditable = true,
959
+ isDisabled = false
960
+ }) => {
961
+ const [value, setValue] = (0, import_react7.useState)(propValue);
962
+ const options = (data || []).map((item) => ({
963
+ value: item[dataKey || "value"],
964
+ label: item[dataLabel || "label"]
1022
965
  }));
1023
- return /* @__PURE__ */ (0, import_jsx_runtime22.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime22.jsx)("div", { className: "flex gap-3 flex-col", children: formatList?.map((item, index) => /* @__PURE__ */ (0, import_jsx_runtime22.jsxs)("div", { className: "flex items-center space-x-2", children: [
1024
- /* @__PURE__ */ (0, import_jsx_runtime22.jsx)(Checkbox, { id: `newsletter-${index}` }),
1025
- /* @__PURE__ */ (0, import_jsx_runtime22.jsx)(Label, { htmlFor: `newsletter-${index}`, children: item.label })
1026
- ] }, index)) }) });
966
+ const handleChange = (0, import_react7.useCallback)(
967
+ (key, checked) => {
968
+ setValue((prev) => {
969
+ const newValue = { ...prev, [key]: checked };
970
+ onChange?.(newValue);
971
+ return newValue;
972
+ });
973
+ },
974
+ [onChange]
975
+ );
976
+ return /* @__PURE__ */ (0, import_jsx_runtime22.jsxs)(
977
+ "div",
978
+ {
979
+ className: cn("flex flex-col gap-3", className),
980
+ style,
981
+ children: [
982
+ options.length === 0 && /* @__PURE__ */ (0, import_jsx_runtime22.jsx)("p", { className: "text-sm text-gray-500", children: "No options available." }),
983
+ options.map((opt) => /* @__PURE__ */ (0, import_jsx_runtime22.jsxs)("div", { className: "flex items-center space-x-2", children: [
984
+ /* @__PURE__ */ (0, import_jsx_runtime22.jsx)(
985
+ Checkbox,
986
+ {
987
+ id: opt.value,
988
+ checked: !!value[opt.value],
989
+ onCheckedChange: (checked) => handleChange(opt.value, checked === true),
990
+ disabled: !isEditable || isDisabled
991
+ }
992
+ ),
993
+ /* @__PURE__ */ (0, import_jsx_runtime22.jsx)(Label, { htmlFor: opt.value, children: opt.label })
994
+ ] }, opt.value))
995
+ ]
996
+ }
997
+ );
1027
998
  };
1028
999
  var MultiCheckbox_default = MultiCheckbox;
1029
1000
 
1030
1001
  // src/components/Inputs/RichText/RichText.tsx
1031
- var import_react6 = require("react");
1002
+ var import_react9 = require("react");
1032
1003
 
1033
1004
  // src/components/Global/TinyMceEditor.tsx
1034
- var import_react5 = require("react");
1005
+ var import_react8 = require("react");
1035
1006
  var import_tinymce_react = require("@tinymce/tinymce-react");
1036
1007
  var import_jsx_runtime23 = require("react/jsx-runtime");
1037
1008
  function MyEditor({
@@ -1039,7 +1010,7 @@ function MyEditor({
1039
1010
  onChange,
1040
1011
  isDefault
1041
1012
  }) {
1042
- const editorRef = (0, import_react5.useRef)(null);
1013
+ const editorRef = (0, import_react8.useRef)(null);
1043
1014
  function stripOuterP(html) {
1044
1015
  const trimmedHtml = html.trim();
1045
1016
  if (!trimmedHtml) return "";
@@ -1051,7 +1022,7 @@ function MyEditor({
1051
1022
  }
1052
1023
  return trimmedHtml;
1053
1024
  }
1054
- const isDefaultToolbar = (0, import_react5.useMemo)(() => {
1025
+ const isDefaultToolbar = (0, import_react8.useMemo)(() => {
1055
1026
  let toolbar = "undo redo | formatselect | bold italic forecolor";
1056
1027
  if (isDefault) {
1057
1028
  toolbar = "undo redo | blocks | bold italic forecolor | alignleft aligncenter alignright alignjustify | bullist numlist outdent indent | removeformat | help";
@@ -1104,8 +1075,8 @@ function MyEditor({
1104
1075
  // src/components/Inputs/RichText/RichText.tsx
1105
1076
  var import_jsx_runtime24 = require("react/jsx-runtime");
1106
1077
  function RichText({ className, style, ...props }) {
1107
- const [error, setError] = (0, import_react6.useState)(null);
1108
- (0, import_react6.useEffect)(() => {
1078
+ const [error, setError] = (0, import_react9.useState)(null);
1079
+ (0, import_react9.useEffect)(() => {
1109
1080
  if (!props.validateOnMount) return;
1110
1081
  setError(props.errorMessage || null);
1111
1082
  }, [props.errorMessage, props.validateOnMount]);
@@ -1254,106 +1225,61 @@ function SelectScrollDownButton({
1254
1225
  );
1255
1226
  }
1256
1227
 
1257
- // src/components/Global/SelectDropdown.tsx
1258
- var import_jsx_runtime26 = require("react/jsx-runtime");
1259
- function SelectDropdown({
1260
- options,
1261
- placeholder = "Select an option",
1262
- value,
1263
- onChange,
1264
- className,
1265
- id,
1266
- disabled,
1267
- readOnly,
1268
- style,
1269
- name
1270
- }) {
1271
- return /* @__PURE__ */ (0, import_jsx_runtime26.jsxs)(Select, { name, value, onValueChange: onChange, disabled, children: [
1272
- /* @__PURE__ */ (0, import_jsx_runtime26.jsx)(
1273
- SelectTrigger,
1274
- {
1275
- id,
1276
- className,
1277
- style: style ?? {},
1278
- "aria-readonly": readOnly,
1279
- children: /* @__PURE__ */ (0, import_jsx_runtime26.jsx)(SelectValue, { placeholder })
1280
- }
1281
- ),
1282
- /* @__PURE__ */ (0, import_jsx_runtime26.jsx)(SelectContent, { children: options.map((opt) => /* @__PURE__ */ (0, import_jsx_runtime26.jsx)(SelectItem, { value: opt.value, children: opt.label }, opt.value)) })
1283
- ] });
1284
- }
1285
-
1286
1228
  // src/components/Inputs/Dropdown/Dropdown.tsx
1287
- var import_jsx_runtime27 = require("react/jsx-runtime");
1229
+ var import_jsx_runtime26 = require("react/jsx-runtime");
1288
1230
  var Dropdown = ({ className, style, ...props }) => {
1289
- const text = Array.isArray(props.text) ? props.text : [props.text ?? "Default"];
1231
+ const list = props.data || [];
1290
1232
  const placeholder = props.placeholder ? props.placeholder : "Placeholder text";
1291
- const formatList = text.filter((i) => i.value && i.label).map((item) => ({
1292
- label: item.label,
1293
- value: item.value
1294
- }));
1295
- const regexPattern = props.regexPattern ?? "";
1296
- const errorMessage = props.errorMessage ?? "Required";
1297
- const isRequired = props.isRequired ?? false;
1298
1233
  const isEditable = props.isEditable ?? true;
1299
1234
  const isDisabled = props.isDisabled ?? false;
1300
1235
  const isReadonly = props.isReadonly ?? false;
1301
- const isAutocomplete = props.isAutocomplete ?? false;
1302
- const [value, setValue] = React8.useState("");
1303
1236
  const [error, setError] = React8.useState(null);
1304
1237
  React8.useEffect(() => {
1305
1238
  if (!props.validateOnMount) return;
1306
1239
  setError(props.errorMessage || null);
1307
1240
  }, [props.errorMessage, props.validateOnMount]);
1308
- const handleChange = (val) => {
1309
- if (props.hasFormContainer) {
1310
- props.onChange?.(val);
1311
- return;
1312
- }
1313
- setValue(val);
1314
- if (isRequired && val.trim() === "") {
1315
- setError(errorMessage);
1316
- } else if (regexPattern && !new RegExp(regexPattern).test(val)) {
1317
- setError(errorMessage);
1318
- } else {
1319
- setError(null);
1320
- }
1241
+ const handleChange = (value) => {
1242
+ props.onChange?.(value);
1321
1243
  };
1322
- return /* @__PURE__ */ (0, import_jsx_runtime27.jsxs)(import_jsx_runtime27.Fragment, { children: [
1323
- /* @__PURE__ */ (0, import_jsx_runtime27.jsx)("div", { className: "flex gap-3 flex-col", children: /* @__PURE__ */ (0, import_jsx_runtime27.jsx)(
1324
- SelectDropdown,
1325
- {
1326
- options: formatList,
1327
- placeholder,
1328
- id: "select-field",
1329
- name: props.name,
1330
- value: props.value || value,
1331
- className: cn(className, error ? "border-red-500" : ""),
1332
- style: {
1333
- ...style,
1334
- borderColor: error ? "#f87171" : style?.borderColor
1335
- },
1336
- autoComplete: isAutocomplete ? "on" : "off",
1337
- onChange: handleChange,
1338
- disabled: isDisabled || !isEditable,
1339
- readOnly: isReadonly,
1340
- required: isRequired,
1341
- pattern: regexPattern || void 0
1342
- }
1343
- ) }),
1344
- error && /* @__PURE__ */ (0, import_jsx_runtime27.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
1244
+ const dataKey = props.dataKey || "value";
1245
+ const dataLabel = props.dataLabel || "label";
1246
+ const options = list.map((item) => ({
1247
+ value: item[dataKey],
1248
+ label: item[dataLabel]
1249
+ }));
1250
+ return /* @__PURE__ */ (0, import_jsx_runtime26.jsxs)(import_jsx_runtime26.Fragment, { children: [
1251
+ /* @__PURE__ */ (0, import_jsx_runtime26.jsxs)(Select, { name: props.name, value: props.value, onValueChange: handleChange, disabled: isDisabled || !isEditable, children: [
1252
+ /* @__PURE__ */ (0, import_jsx_runtime26.jsx)(
1253
+ SelectTrigger,
1254
+ {
1255
+ id: props.name || "select-field",
1256
+ className: cn(className, error ? "border-red-500" : ""),
1257
+ style: {
1258
+ ...style,
1259
+ borderColor: error ? "#f87171" : style?.borderColor
1260
+ },
1261
+ "aria-readonly": isReadonly,
1262
+ children: /* @__PURE__ */ (0, import_jsx_runtime26.jsx)(SelectValue, { placeholder })
1263
+ }
1264
+ ),
1265
+ /* @__PURE__ */ (0, import_jsx_runtime26.jsx)(SelectContent, { children: options.map((opt) => /* @__PURE__ */ (0, import_jsx_runtime26.jsx)(SelectItem, { value: opt.value, children: opt.label }, opt.value)) })
1266
+ ] }),
1267
+ error && /* @__PURE__ */ (0, import_jsx_runtime26.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
1345
1268
  ] });
1346
1269
  };
1347
1270
  var Dropdown_default = Dropdown;
1348
1271
 
1272
+ // src/components/Inputs/SwitchToggle/SwitchToggle.tsx
1273
+ var import_react10 = require("react");
1274
+
1349
1275
  // src/components/ui/switch.tsx
1350
1276
  var SwitchPrimitive = __toESM(require("@radix-ui/react-switch"));
1351
- var import_jsx_runtime28 = require("react/jsx-runtime");
1277
+ var import_jsx_runtime27 = require("react/jsx-runtime");
1352
1278
  function Switch({
1353
1279
  className,
1354
1280
  ...props
1355
1281
  }) {
1356
- return /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(
1282
+ return /* @__PURE__ */ (0, import_jsx_runtime27.jsx)(
1357
1283
  SwitchPrimitive.Root,
1358
1284
  {
1359
1285
  "data-slot": "switch",
@@ -1362,7 +1288,7 @@ function Switch({
1362
1288
  className
1363
1289
  ),
1364
1290
  ...props,
1365
- children: /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(
1291
+ children: /* @__PURE__ */ (0, import_jsx_runtime27.jsx)(
1366
1292
  SwitchPrimitive.Thumb,
1367
1293
  {
1368
1294
  "data-slot": "switch-thumb",
@@ -1376,13 +1302,33 @@ function Switch({
1376
1302
  }
1377
1303
 
1378
1304
  // src/components/Inputs/SwitchToggle/SwitchToggle.tsx
1379
- var import_jsx_runtime29 = require("react/jsx-runtime");
1305
+ var import_jsx_runtime28 = require("react/jsx-runtime");
1380
1306
  var SwitchToggle = ({ className, style, ...props }) => {
1381
- const text = Array.isArray(props.text) ? props.text : [props.text ?? "Subscribe"];
1382
- return /* @__PURE__ */ (0, import_jsx_runtime29.jsx)("div", { className, style, children: text?.map((item, index) => /* @__PURE__ */ (0, import_jsx_runtime29.jsxs)("div", { className: "flex items-center space-x-2 mb-2", children: [
1383
- /* @__PURE__ */ (0, import_jsx_runtime29.jsx)(Switch, { id: `switch-${index}` }),
1384
- /* @__PURE__ */ (0, import_jsx_runtime29.jsx)(Label, { htmlFor: `switch-${index}`, children: item })
1385
- ] }, index)) });
1307
+ const isEditable = props.isEditable ?? true;
1308
+ const isDisabled = props.isDisabled ?? false;
1309
+ const [error, setError] = (0, import_react10.useState)(null);
1310
+ (0, import_react10.useEffect)(() => {
1311
+ if (!props.validateOnMount) return;
1312
+ setError(props.errorMessage || null);
1313
+ }, [props.errorMessage, props.validateOnMount]);
1314
+ const handleChange = (value) => {
1315
+ props.onChange?.(value);
1316
+ };
1317
+ return /* @__PURE__ */ (0, import_jsx_runtime28.jsxs)(import_jsx_runtime28.Fragment, { children: [
1318
+ /* @__PURE__ */ (0, import_jsx_runtime28.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime28.jsxs)("div", { className: "flex items-center space-x-2 mb-2", children: [
1319
+ /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(
1320
+ Switch,
1321
+ {
1322
+ id: props.name || "switch",
1323
+ checked: !!props.value,
1324
+ onCheckedChange: handleChange,
1325
+ disabled: isDisabled || !isEditable
1326
+ }
1327
+ ),
1328
+ /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(Label, { htmlFor: props.name || "switch", children: props.text })
1329
+ ] }) }),
1330
+ error && /* @__PURE__ */ (0, import_jsx_runtime28.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
1331
+ ] });
1386
1332
  };
1387
1333
  var SwitchToggle_default = SwitchToggle;
1388
1334
 
@@ -1390,14 +1336,9 @@ var SwitchToggle_default = SwitchToggle;
1390
1336
  var React9 = __toESM(require("react"));
1391
1337
  var import_react_international_phone = require("react-international-phone");
1392
1338
  var import_style = require("react-international-phone/style.css");
1393
- var import_jsx_runtime30 = require("react/jsx-runtime");
1339
+ var import_jsx_runtime29 = require("react/jsx-runtime");
1394
1340
  var PhoneInput = ({ className, style, ...props }) => {
1395
1341
  const placeholder = props.placeholder ?? "Enter phone number";
1396
- const [value, setValue] = React9.useState("");
1397
- const regexPattern = props.regexPattern ?? "";
1398
- const errorMessage = props.errorMessage ?? "Required";
1399
- const noOfCharacters = props.noOfCharacters ?? 100;
1400
- const isRequired = props.isRequired ?? false;
1401
1342
  const isEditable = props.isEditable ?? true;
1402
1343
  const isDisabled = props.isDisabled ?? false;
1403
1344
  const [error, setError] = React9.useState(null);
@@ -1406,27 +1347,15 @@ var PhoneInput = ({ className, style, ...props }) => {
1406
1347
  setError(props.errorMessage || null);
1407
1348
  }, [props.errorMessage, props.validateOnMount]);
1408
1349
  const handleChange = (val) => {
1409
- if (props.hasFormContainer) {
1410
- props.onChange?.(val);
1411
- return;
1412
- }
1413
- if (val.length > noOfCharacters) return;
1414
- setValue(val);
1415
- if (isRequired && val.trim() === "") {
1416
- setError(errorMessage);
1417
- } else if (regexPattern && !new RegExp(regexPattern).test(val)) {
1418
- setError(errorMessage);
1419
- } else {
1420
- setError(null);
1421
- }
1350
+ props.onChange?.(val);
1422
1351
  };
1423
- return /* @__PURE__ */ (0, import_jsx_runtime30.jsxs)(import_jsx_runtime30.Fragment, { children: [
1424
- /* @__PURE__ */ (0, import_jsx_runtime30.jsx)(
1352
+ return /* @__PURE__ */ (0, import_jsx_runtime29.jsxs)(import_jsx_runtime29.Fragment, { children: [
1353
+ /* @__PURE__ */ (0, import_jsx_runtime29.jsx)(
1425
1354
  import_react_international_phone.PhoneInput,
1426
1355
  {
1427
1356
  defaultCountry: "in",
1428
1357
  name: props.name,
1429
- value: props.value || value,
1358
+ value: props.value,
1430
1359
  className: cn(className, error ? "border-red-500" : ""),
1431
1360
  style: {
1432
1361
  ...style,
@@ -1434,64 +1363,44 @@ var PhoneInput = ({ className, style, ...props }) => {
1434
1363
  },
1435
1364
  onChange: (phone) => handleChange(phone),
1436
1365
  inputProps: {
1437
- id: "phone-field",
1438
- required: isRequired
1366
+ id: "phone-field"
1439
1367
  },
1440
1368
  placeholder,
1441
- disabled: isDisabled || !isEditable,
1442
- required: isRequired
1369
+ disabled: isDisabled || !isEditable
1443
1370
  }
1444
1371
  ),
1445
- error && /* @__PURE__ */ (0, import_jsx_runtime30.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
1372
+ error && /* @__PURE__ */ (0, import_jsx_runtime29.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
1446
1373
  ] });
1447
1374
  };
1448
1375
  var PhoneInput_default = PhoneInput;
1449
1376
 
1450
1377
  // src/components/Inputs/SearchInput/SearchInput.tsx
1451
1378
  var React10 = __toESM(require("react"));
1452
- var import_jsx_runtime31 = require("react/jsx-runtime");
1379
+ var import_jsx_runtime30 = require("react/jsx-runtime");
1453
1380
  var SearchInput = ({ className, style, ...props }) => {
1454
1381
  const placeholder = props.placeholder ?? "Placeholder text";
1455
- const regexPattern = props.regexPattern ?? "";
1456
- const errorMessage = props.errorMessage ?? "Required";
1457
- const noOfCharacters = props.noOfCharacters ?? 100;
1458
- const isRequired = props.isRequired ?? false;
1459
1382
  const isEditable = props.isEditable ?? true;
1460
1383
  const isDisabled = props.isDisabled ?? false;
1461
1384
  const isReadonly = props.isReadonly ?? false;
1462
1385
  const isAutocomplete = props.isAutocomplete ?? false;
1463
- const [value, setValue] = React10.useState("");
1464
1386
  const [error, setError] = React10.useState(null);
1465
1387
  React10.useEffect(() => {
1466
1388
  if (!props.validateOnMount) return;
1467
1389
  setError(props.errorMessage || null);
1468
1390
  }, [props.errorMessage, props.validateOnMount]);
1469
1391
  const handleChange = (e) => {
1470
- if (props.hasFormContainer) {
1471
- props.onChange?.(e);
1472
- return;
1473
- }
1474
- const val = e.target.value;
1475
- if (val.length > noOfCharacters) return;
1476
- setValue(val);
1477
- if (isRequired && val.trim() === "") {
1478
- setError(errorMessage);
1479
- } else if (regexPattern && !new RegExp(regexPattern).test(val)) {
1480
- setError(errorMessage);
1481
- } else {
1482
- setError(null);
1483
- }
1392
+ props.onChange?.(e);
1484
1393
  };
1485
- return /* @__PURE__ */ (0, import_jsx_runtime31.jsxs)(import_jsx_runtime31.Fragment, { children: [
1486
- /* @__PURE__ */ (0, import_jsx_runtime31.jsxs)("div", { className: "flex justify-start items-center relative", children: [
1487
- /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(Search, { className: "absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-[#BDBDBD]" }),
1488
- /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(
1394
+ return /* @__PURE__ */ (0, import_jsx_runtime30.jsxs)(import_jsx_runtime30.Fragment, { children: [
1395
+ /* @__PURE__ */ (0, import_jsx_runtime30.jsxs)("div", { className: "flex justify-start items-center relative", children: [
1396
+ /* @__PURE__ */ (0, import_jsx_runtime30.jsx)(Search, { className: "left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-[#BDBDBD]" }),
1397
+ /* @__PURE__ */ (0, import_jsx_runtime30.jsx)(
1489
1398
  Input,
1490
1399
  {
1491
1400
  type: "text",
1492
- id: "text-field",
1401
+ id: props.name || "text-field",
1493
1402
  name: props.name,
1494
- value: props.value || value,
1403
+ value: props.value,
1495
1404
  className: cn(className, error ? "border-red-500" : ""),
1496
1405
  style: {
1497
1406
  ...style,
@@ -1501,30 +1410,27 @@ var SearchInput = ({ className, style, ...props }) => {
1501
1410
  placeholder,
1502
1411
  onChange: handleChange,
1503
1412
  disabled: isDisabled || !isEditable,
1504
- readOnly: isReadonly,
1505
- required: isRequired,
1506
- maxLength: noOfCharacters,
1507
- pattern: regexPattern || void 0
1413
+ readOnly: isReadonly
1508
1414
  }
1509
1415
  )
1510
1416
  ] }),
1511
- error && /* @__PURE__ */ (0, import_jsx_runtime31.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
1417
+ error && /* @__PURE__ */ (0, import_jsx_runtime30.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
1512
1418
  ] });
1513
1419
  };
1514
1420
  var SearchInput_default = SearchInput;
1515
1421
 
1516
1422
  // src/components/Inputs/FileInput/FileInput.tsx
1517
- var import_react7 = require("react");
1518
- var import_jsx_runtime32 = require("react/jsx-runtime");
1423
+ var import_react11 = require("react");
1424
+ var import_jsx_runtime31 = require("react/jsx-runtime");
1519
1425
  var FileInput = ({ className, style, ...props }) => {
1520
1426
  const placeholder = props.placeholder ?? "Placeholder text";
1521
- const [error, setError] = (0, import_react7.useState)(null);
1522
- (0, import_react7.useEffect)(() => {
1427
+ const [error, setError] = (0, import_react11.useState)(null);
1428
+ (0, import_react11.useEffect)(() => {
1523
1429
  if (!props.validateOnMount) return;
1524
1430
  setError(props.errorMessage || null);
1525
1431
  }, [props.errorMessage, props.validateOnMount]);
1526
- return /* @__PURE__ */ (0, import_jsx_runtime32.jsxs)("div", { className: "d-flex items-center relative align-middle", children: [
1527
- /* @__PURE__ */ (0, import_jsx_runtime32.jsx)(
1432
+ return /* @__PURE__ */ (0, import_jsx_runtime31.jsxs)("div", { className: "d-flex items-center relative align-middle", children: [
1433
+ /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(
1528
1434
  Input,
1529
1435
  {
1530
1436
  type: "file",
@@ -1539,35 +1445,29 @@ var FileInput = ({ className, style, ...props }) => {
1539
1445
  autoComplete: "off",
1540
1446
  placeholder,
1541
1447
  onChange: (e) => {
1542
- if (props.hasFormContainer) {
1543
- props.onChange?.(e);
1544
- return;
1545
- }
1448
+ props.onChange?.(e);
1546
1449
  }
1547
1450
  }
1548
1451
  ),
1549
- error && /* @__PURE__ */ (0, import_jsx_runtime32.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
1452
+ error && /* @__PURE__ */ (0, import_jsx_runtime31.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
1550
1453
  ] });
1551
1454
  };
1552
1455
  var FileInput_default = FileInput;
1553
1456
 
1554
1457
  // src/components/Inputs/DatePicker/DatePicker.tsx
1555
- var import_react8 = __toESM(require("react"));
1556
- var import_jsx_runtime33 = require("react/jsx-runtime");
1458
+ var import_react12 = __toESM(require("react"));
1459
+ var import_jsx_runtime32 = require("react/jsx-runtime");
1557
1460
  function DatePicker({ className, style, ...props }) {
1558
1461
  const placeholder = props.placeholder ?? "Placeholder text";
1559
1462
  const minimumDate = props.minimumDate ?? "none";
1560
1463
  const customMinimumDate = props.customMinimumDate ?? "";
1561
1464
  const maximumDate = props.maximumDate ?? "none";
1562
1465
  const customMaximumDate = props.customMaximumDate ?? "";
1563
- const errorMessage = props.errorMessage ?? "Required";
1564
- const isRequired = props.isRequired ?? false;
1565
1466
  const isEditable = props.isEditable ?? true;
1566
1467
  const isDisabled = props.isDisabled ?? false;
1567
1468
  const isReadonly = props.isReadonly ?? false;
1568
1469
  const isAutocomplete = props.isAutocomplete ?? false;
1569
- const [value, setValue] = import_react8.default.useState("");
1570
- const [error, setError] = import_react8.default.useState(null);
1470
+ const [error, setError] = import_react12.default.useState(null);
1571
1471
  const resolveDate = (option, customOption) => {
1572
1472
  if (!option) return void 0;
1573
1473
  switch (option) {
@@ -1582,27 +1482,17 @@ function DatePicker({ className, style, ...props }) {
1582
1482
  };
1583
1483
  const minDate = resolveDate(minimumDate, customMinimumDate);
1584
1484
  const maxDate = resolveDate(maximumDate, customMaximumDate);
1585
- (0, import_react8.useEffect)(() => {
1485
+ (0, import_react12.useEffect)(() => {
1586
1486
  if (!props.validateOnMount) return;
1587
1487
  setError(props.errorMessage || null);
1588
1488
  }, [props.errorMessage, props.validateOnMount]);
1589
1489
  const handleChange = (e) => {
1590
- if (props.hasFormContainer) {
1591
- props.onChange?.(e);
1592
- return;
1593
- }
1594
- const val = e.target.value;
1595
- setValue(val);
1596
- if (isRequired && val.trim() === "") {
1597
- setError(errorMessage);
1598
- } else {
1599
- setError(null);
1600
- }
1490
+ props.onChange?.(e);
1601
1491
  };
1602
- return /* @__PURE__ */ (0, import_jsx_runtime33.jsxs)(import_jsx_runtime33.Fragment, { children: [
1603
- /* @__PURE__ */ (0, import_jsx_runtime33.jsxs)("div", { className: "flex justify-start items-center relative", children: [
1604
- /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(Calendar, { className: "absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-[#BDBDBD]" }),
1605
- /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(
1492
+ return /* @__PURE__ */ (0, import_jsx_runtime32.jsxs)(import_jsx_runtime32.Fragment, { children: [
1493
+ /* @__PURE__ */ (0, import_jsx_runtime32.jsxs)("div", { className: "flex justify-start items-center relative", children: [
1494
+ /* @__PURE__ */ (0, import_jsx_runtime32.jsx)(Calendar, { className: "absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-[#BDBDBD]" }),
1495
+ /* @__PURE__ */ (0, import_jsx_runtime32.jsx)(
1606
1496
  Input,
1607
1497
  {
1608
1498
  type: "date",
@@ -1611,21 +1501,24 @@ function DatePicker({ className, style, ...props }) {
1611
1501
  onChange: handleChange,
1612
1502
  disabled: isDisabled || !isEditable,
1613
1503
  name: props.name,
1614
- value: props.value || value,
1615
- className: cn(className, error ? "border-red-500" : ""),
1504
+ value: props.value,
1505
+ className: cn(
1506
+ className,
1507
+ error ? "border-red-500" : "",
1508
+ "appearance-auto"
1509
+ ),
1616
1510
  style: {
1617
1511
  ...style,
1618
1512
  borderColor: error ? "#f87171" : style?.borderColor
1619
1513
  },
1620
1514
  readOnly: isReadonly,
1621
- required: isRequired,
1622
1515
  placeholder,
1623
1516
  min: minDate,
1624
1517
  max: maxDate
1625
1518
  }
1626
1519
  )
1627
1520
  ] }),
1628
- error && /* @__PURE__ */ (0, import_jsx_runtime33.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
1521
+ error && /* @__PURE__ */ (0, import_jsx_runtime32.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
1629
1522
  ] });
1630
1523
  }
1631
1524
 
@@ -1636,7 +1529,7 @@ var import_date_fns = require("date-fns");
1636
1529
  // src/components/ui/calendar.tsx
1637
1530
  var React12 = __toESM(require("react"));
1638
1531
  var import_react_day_picker = require("react-day-picker");
1639
- var import_jsx_runtime34 = require("react/jsx-runtime");
1532
+ var import_jsx_runtime33 = require("react/jsx-runtime");
1640
1533
  function Calendar2({
1641
1534
  className,
1642
1535
  classNames,
@@ -1648,7 +1541,7 @@ function Calendar2({
1648
1541
  ...props
1649
1542
  }) {
1650
1543
  const defaultClassNames = (0, import_react_day_picker.getDefaultClassNames)();
1651
- return /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(
1544
+ return /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(
1652
1545
  import_react_day_picker.DayPicker,
1653
1546
  {
1654
1547
  showOutsideDays,
@@ -1747,7 +1640,7 @@ function Calendar2({
1747
1640
  },
1748
1641
  components: {
1749
1642
  Root: ({ className: className2, rootRef, ...props2 }) => {
1750
- return /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(
1643
+ return /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(
1751
1644
  "div",
1752
1645
  {
1753
1646
  "data-slot": "calendar",
@@ -1759,10 +1652,10 @@ function Calendar2({
1759
1652
  },
1760
1653
  Chevron: ({ className: className2, orientation, ...props2 }) => {
1761
1654
  if (orientation === "left") {
1762
- return /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(ChevronLeft, { className: cn("size-4", className2), ...props2 });
1655
+ return /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(ChevronLeft, { className: cn("size-4", className2), ...props2 });
1763
1656
  }
1764
1657
  if (orientation === "right") {
1765
- return /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(
1658
+ return /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(
1766
1659
  ChevronRight,
1767
1660
  {
1768
1661
  className: cn("size-4", className2),
@@ -1770,11 +1663,11 @@ function Calendar2({
1770
1663
  }
1771
1664
  );
1772
1665
  }
1773
- return /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(ChevronDown, { className: cn("size-4", className2), ...props2 });
1666
+ return /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(ChevronDown, { className: cn("size-4", className2), ...props2 });
1774
1667
  },
1775
1668
  DayButton: CalendarDayButton,
1776
1669
  WeekNumber: ({ children, ...props2 }) => {
1777
- return /* @__PURE__ */ (0, import_jsx_runtime34.jsx)("td", { ...props2, children: /* @__PURE__ */ (0, import_jsx_runtime34.jsx)("div", { className: "flex size-(--cell-size) items-center justify-center text-center", children }) });
1670
+ return /* @__PURE__ */ (0, import_jsx_runtime33.jsx)("td", { ...props2, children: /* @__PURE__ */ (0, import_jsx_runtime33.jsx)("div", { className: "flex size-(--cell-size) items-center justify-center text-center", children }) });
1778
1671
  },
1779
1672
  ...components
1780
1673
  },
@@ -1793,7 +1686,7 @@ function CalendarDayButton({
1793
1686
  React12.useEffect(() => {
1794
1687
  if (modifiers.focused) ref.current?.focus();
1795
1688
  }, [modifiers.focused]);
1796
- return /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(
1689
+ return /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(
1797
1690
  Button,
1798
1691
  {
1799
1692
  ref,
@@ -1816,16 +1709,16 @@ function CalendarDayButton({
1816
1709
 
1817
1710
  // src/components/ui/popover.tsx
1818
1711
  var PopoverPrimitive = __toESM(require("@radix-ui/react-popover"));
1819
- var import_jsx_runtime35 = require("react/jsx-runtime");
1712
+ var import_jsx_runtime34 = require("react/jsx-runtime");
1820
1713
  function Popover({
1821
1714
  ...props
1822
1715
  }) {
1823
- return /* @__PURE__ */ (0, import_jsx_runtime35.jsx)(PopoverPrimitive.Root, { "data-slot": "popover", ...props });
1716
+ return /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(PopoverPrimitive.Root, { "data-slot": "popover", ...props });
1824
1717
  }
1825
1718
  function PopoverTrigger({
1826
1719
  ...props
1827
1720
  }) {
1828
- return /* @__PURE__ */ (0, import_jsx_runtime35.jsx)(PopoverPrimitive.Trigger, { "data-slot": "popover-trigger", ...props });
1721
+ return /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(PopoverPrimitive.Trigger, { "data-slot": "popover-trigger", ...props });
1829
1722
  }
1830
1723
  function PopoverContent({
1831
1724
  className,
@@ -1833,7 +1726,7 @@ function PopoverContent({
1833
1726
  sideOffset = 4,
1834
1727
  ...props
1835
1728
  }) {
1836
- return /* @__PURE__ */ (0, import_jsx_runtime35.jsx)(PopoverPrimitive.Portal, { children: /* @__PURE__ */ (0, import_jsx_runtime35.jsx)(
1729
+ return /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(PopoverPrimitive.Portal, { children: /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(
1837
1730
  PopoverPrimitive.Content,
1838
1731
  {
1839
1732
  "data-slot": "popover-content",
@@ -1849,41 +1742,58 @@ function PopoverContent({
1849
1742
  }
1850
1743
 
1851
1744
  // src/components/Inputs/DateRange/DateRange.tsx
1852
- var import_jsx_runtime36 = require("react/jsx-runtime");
1853
- var DateRange = ({ className, style }) => {
1854
- const [date, setDate] = React13.useState({
1855
- from: /* @__PURE__ */ new Date(),
1856
- to: (0, import_date_fns.addDays)(/* @__PURE__ */ new Date(), 7)
1857
- });
1858
- return /* @__PURE__ */ (0, import_jsx_runtime36.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime36.jsxs)(Popover, { children: [
1859
- /* @__PURE__ */ (0, import_jsx_runtime36.jsx)(PopoverTrigger, { asChild: true, children: /* @__PURE__ */ (0, import_jsx_runtime36.jsx)(
1860
- Button,
1861
- {
1862
- id: "date",
1863
- variant: "outline",
1864
- className: cn(
1865
- "w-[300px] justify-start text-left font-normal text-[11px]",
1866
- !date && "text-muted-foreground"
1867
- ),
1868
- children: date?.from ? date.to ? /* @__PURE__ */ (0, import_jsx_runtime36.jsxs)(import_jsx_runtime36.Fragment, { children: [
1869
- (0, import_date_fns.format)(date.from, "LLL dd, y"),
1870
- " -",
1871
- " ",
1872
- (0, import_date_fns.format)(date.to, "LLL dd, y")
1873
- ] }) : (0, import_date_fns.format)(date.from, "LLL dd, y") : /* @__PURE__ */ (0, import_jsx_runtime36.jsx)("span", { children: "Pick a date range" })
1874
- }
1875
- ) }),
1876
- /* @__PURE__ */ (0, import_jsx_runtime36.jsx)(PopoverContent, { className: "w-auto p-0", align: "start", children: /* @__PURE__ */ (0, import_jsx_runtime36.jsx)(
1877
- Calendar2,
1878
- {
1879
- mode: "range",
1880
- defaultMonth: date?.from,
1881
- selected: date,
1882
- onSelect: setDate,
1883
- numberOfMonths: 2
1884
- }
1885
- ) })
1886
- ] }) });
1745
+ var import_jsx_runtime35 = require("react/jsx-runtime");
1746
+ var DateRange = ({ className, style, ...props }) => {
1747
+ const [error, setError] = React13.useState(null);
1748
+ const isDateRange = (val) => !!val && val.from instanceof Date;
1749
+ const [date, setDate] = React13.useState(
1750
+ isDateRange(props.value) ? props.value : {
1751
+ from: /* @__PURE__ */ new Date(),
1752
+ to: (0, import_date_fns.addDays)(/* @__PURE__ */ new Date(), 7)
1753
+ }
1754
+ );
1755
+ React13.useEffect(() => {
1756
+ if (!props.validateOnMount) return;
1757
+ setError(props.errorMessage || null);
1758
+ }, [props.errorMessage, props.validateOnMount]);
1759
+ const handleChange = (value) => {
1760
+ setDate(value);
1761
+ if (value) {
1762
+ props.onChange?.(value);
1763
+ }
1764
+ };
1765
+ return /* @__PURE__ */ (0, import_jsx_runtime35.jsxs)(import_jsx_runtime35.Fragment, { children: [
1766
+ /* @__PURE__ */ (0, import_jsx_runtime35.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime35.jsxs)(Popover, { children: [
1767
+ /* @__PURE__ */ (0, import_jsx_runtime35.jsx)(PopoverTrigger, { asChild: true, children: /* @__PURE__ */ (0, import_jsx_runtime35.jsx)(
1768
+ Button,
1769
+ {
1770
+ id: "date",
1771
+ variant: "outline",
1772
+ className: cn(
1773
+ "w-[300px] justify-start text-left font-normal text-[11px]",
1774
+ !date && "text-muted-foreground"
1775
+ ),
1776
+ children: date?.from ? date.to ? /* @__PURE__ */ (0, import_jsx_runtime35.jsxs)(import_jsx_runtime35.Fragment, { children: [
1777
+ (0, import_date_fns.format)(date.from, "LLL dd, y"),
1778
+ " -",
1779
+ " ",
1780
+ (0, import_date_fns.format)(date.to, "LLL dd, y")
1781
+ ] }) : (0, import_date_fns.format)(date.from, "LLL dd, y") : /* @__PURE__ */ (0, import_jsx_runtime35.jsx)("span", { children: "Pick a date range" })
1782
+ }
1783
+ ) }),
1784
+ /* @__PURE__ */ (0, import_jsx_runtime35.jsx)(PopoverContent, { className: "w-auto p-0", align: "start", children: /* @__PURE__ */ (0, import_jsx_runtime35.jsx)(
1785
+ Calendar2,
1786
+ {
1787
+ mode: "range",
1788
+ defaultMonth: date?.from,
1789
+ selected: date,
1790
+ onSelect: handleChange,
1791
+ numberOfMonths: 2
1792
+ }
1793
+ ) })
1794
+ ] }) }),
1795
+ error && /* @__PURE__ */ (0, import_jsx_runtime35.jsx)("p", { className: "mt-1 text-xs text-red-500", children: error })
1796
+ ] });
1887
1797
  };
1888
1798
  var DateRange_default = DateRange;
1889
1799
 
@@ -1891,14 +1801,14 @@ var DateRange_default = DateRange;
1891
1801
  var import_react_table = require("@tanstack/react-table");
1892
1802
 
1893
1803
  // src/components/ui/table.tsx
1894
- var import_jsx_runtime37 = require("react/jsx-runtime");
1804
+ var import_jsx_runtime36 = require("react/jsx-runtime");
1895
1805
  function Table({ className, ...props }) {
1896
- return /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(
1806
+ return /* @__PURE__ */ (0, import_jsx_runtime36.jsx)(
1897
1807
  "div",
1898
1808
  {
1899
1809
  "data-slot": "table-container",
1900
1810
  className: "relative w-full overflow-x-auto rounded-md border border-gray-200 bg-white",
1901
- children: /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(
1811
+ children: /* @__PURE__ */ (0, import_jsx_runtime36.jsx)(
1902
1812
  "table",
1903
1813
  {
1904
1814
  "data-slot": "table",
@@ -1910,7 +1820,7 @@ function Table({ className, ...props }) {
1910
1820
  );
1911
1821
  }
1912
1822
  function TableHeader({ className, ...props }) {
1913
- return /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(
1823
+ return /* @__PURE__ */ (0, import_jsx_runtime36.jsx)(
1914
1824
  "thead",
1915
1825
  {
1916
1826
  "data-slot": "table-header",
@@ -1923,7 +1833,7 @@ function TableHeader({ className, ...props }) {
1923
1833
  );
1924
1834
  }
1925
1835
  function TableBody({ className, ...props }) {
1926
- return /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(
1836
+ return /* @__PURE__ */ (0, import_jsx_runtime36.jsx)(
1927
1837
  "tbody",
1928
1838
  {
1929
1839
  "data-slot": "table-body",
@@ -1936,7 +1846,7 @@ function TableBody({ className, ...props }) {
1936
1846
  );
1937
1847
  }
1938
1848
  function TableRow({ className, ...props }) {
1939
- return /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(
1849
+ return /* @__PURE__ */ (0, import_jsx_runtime36.jsx)(
1940
1850
  "tr",
1941
1851
  {
1942
1852
  "data-slot": "table-row",
@@ -1949,7 +1859,7 @@ function TableRow({ className, ...props }) {
1949
1859
  );
1950
1860
  }
1951
1861
  function TableHead({ className, ...props }) {
1952
- return /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(
1862
+ return /* @__PURE__ */ (0, import_jsx_runtime36.jsx)(
1953
1863
  "th",
1954
1864
  {
1955
1865
  "data-slot": "table-head",
@@ -1962,7 +1872,7 @@ function TableHead({ className, ...props }) {
1962
1872
  );
1963
1873
  }
1964
1874
  function TableCell({ className, ...props }) {
1965
- return /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(
1875
+ return /* @__PURE__ */ (0, import_jsx_runtime36.jsx)(
1966
1876
  "td",
1967
1877
  {
1968
1878
  "data-slot": "table-cell",
@@ -1976,7 +1886,7 @@ function TableCell({ className, ...props }) {
1976
1886
  }
1977
1887
 
1978
1888
  // src/components/ui/data-table.tsx
1979
- var import_jsx_runtime38 = require("react/jsx-runtime");
1889
+ var import_jsx_runtime37 = require("react/jsx-runtime");
1980
1890
  function DataTable({
1981
1891
  columns,
1982
1892
  rowActions,
@@ -2001,14 +1911,14 @@ function DataTable({
2001
1911
  onCellClick(rowData, columnId);
2002
1912
  }
2003
1913
  };
2004
- return /* @__PURE__ */ (0, import_jsx_runtime38.jsx)("div", { className: "overflow-hidden rounded-md border w-full", children: /* @__PURE__ */ (0, import_jsx_runtime38.jsxs)(Table, { children: [
2005
- /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(TableHeader, { children: table.getHeaderGroups().map((headerGroup) => /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(TableRow, { children: headerGroup.headers.map((header) => {
2006
- return /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(TableHead, { children: header.isPlaceholder ? null : (0, import_react_table.flexRender)(
1914
+ return /* @__PURE__ */ (0, import_jsx_runtime37.jsx)("div", { className: "overflow-hidden rounded-md border w-full", children: /* @__PURE__ */ (0, import_jsx_runtime37.jsxs)(Table, { children: [
1915
+ /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(TableHeader, { children: table.getHeaderGroups().map((headerGroup) => /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(TableRow, { children: headerGroup.headers.map((header) => {
1916
+ return /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(TableHead, { children: header.isPlaceholder ? null : (0, import_react_table.flexRender)(
2007
1917
  header.column.columnDef.header,
2008
1918
  header.getContext()
2009
1919
  ) }, header.id);
2010
1920
  }) }, headerGroup.id)) }),
2011
- /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(TableBody, { children: loading ? /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(TableRow, { children: /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(TableCell, { colSpan: columns.length, className: "h-24 text-center", children: "Loading..." }) }) : /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(import_jsx_runtime38.Fragment, { children: table.getRowModel().rows?.length ? table.getRowModel().rows.map((row) => /* @__PURE__ */ (0, import_jsx_runtime38.jsxs)(
1921
+ /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(TableBody, { children: loading ? /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(TableRow, { children: /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(TableCell, { colSpan: columns.length, className: "h-24 text-center", children: "Loading..." }) }) : /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(import_jsx_runtime37.Fragment, { children: table.getRowModel().rows?.length ? table.getRowModel().rows.map((row) => /* @__PURE__ */ (0, import_jsx_runtime37.jsxs)(
2012
1922
  TableRow,
2013
1923
  {
2014
1924
  "data-state": row.getIsSelected() && "selected",
@@ -2018,7 +1928,7 @@ function DataTable({
2018
1928
  const isCellClickable = cellClickEnabled(row.original, cell.column.id);
2019
1929
  const dynamicClass = cell.column.columnDef.meta?.cellClass || "";
2020
1930
  const dynamicStyle = cell.column.columnDef.meta?.cellStyle || {};
2021
- return /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(
1931
+ return /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(
2022
1932
  TableCell,
2023
1933
  {
2024
1934
  className: `${dynamicClass} ${isCellClickable ? "underline cursor-pointer" : ""}`,
@@ -2033,18 +1943,18 @@ function DataTable({
2033
1943
  cell.id
2034
1944
  );
2035
1945
  }),
2036
- rowActions.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime38.jsx)("div", { className: "absolute top-0 right-0 bg-white py-3 min-w-[100px] z-50 shadow-md flex items-center justify-center gap-3 p-2 opacity-0 group-hover:opacity-100 duration-300 h-full", children: rowActions.map((action, index) => /* @__PURE__ */ (0, import_jsx_runtime38.jsx)("p", { className: "text-[#383838] text-[12px] cursor-pointer font-[400]", children: action.header }, index)) })
1946
+ rowActions.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime37.jsx)("div", { className: "absolute top-0 right-0 bg-white py-3 min-w-[100px] z-50 shadow-md flex items-center justify-center gap-3 p-2 opacity-0 group-hover:opacity-100 duration-300 h-full", children: rowActions.map((action, index) => /* @__PURE__ */ (0, import_jsx_runtime37.jsx)("p", { className: "text-[#383838] text-[12px] cursor-pointer font-[400]", children: action.header }, index)) })
2037
1947
  ]
2038
1948
  },
2039
1949
  row.id
2040
- )) : /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(TableRow, { children: /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(TableCell, { colSpan: columns.length, className: "h-24 text-center", children: "No results." }) }) }) })
1950
+ )) : /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(TableRow, { children: /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(TableCell, { colSpan: columns.length, className: "h-24 text-center", children: "No results." }) }) }) })
2041
1951
  ] }) });
2042
1952
  }
2043
1953
 
2044
1954
  // src/components/ui/pagination.tsx
2045
- var import_jsx_runtime39 = require("react/jsx-runtime");
1955
+ var import_jsx_runtime38 = require("react/jsx-runtime");
2046
1956
  function Pagination({ className, ...props }) {
2047
- return /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(
1957
+ return /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(
2048
1958
  "nav",
2049
1959
  {
2050
1960
  role: "navigation",
@@ -2059,7 +1969,7 @@ function PaginationContent({
2059
1969
  className,
2060
1970
  ...props
2061
1971
  }) {
2062
- return /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(
1972
+ return /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(
2063
1973
  "ul",
2064
1974
  {
2065
1975
  "data-slot": "pagination-content",
@@ -2069,7 +1979,7 @@ function PaginationContent({
2069
1979
  );
2070
1980
  }
2071
1981
  function PaginationItem({ ...props }) {
2072
- return /* @__PURE__ */ (0, import_jsx_runtime39.jsx)("li", { "data-slot": "pagination-item", ...props });
1982
+ return /* @__PURE__ */ (0, import_jsx_runtime38.jsx)("li", { "data-slot": "pagination-item", ...props });
2073
1983
  }
2074
1984
  function PaginationLink({
2075
1985
  className,
@@ -2077,7 +1987,7 @@ function PaginationLink({
2077
1987
  size = "icon",
2078
1988
  ...props
2079
1989
  }) {
2080
- return /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(
1990
+ return /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(
2081
1991
  "a",
2082
1992
  {
2083
1993
  "aria-current": isActive ? "page" : void 0,
@@ -2098,7 +2008,7 @@ function PaginationPrevious({
2098
2008
  className,
2099
2009
  ...props
2100
2010
  }) {
2101
- return /* @__PURE__ */ (0, import_jsx_runtime39.jsxs)(
2011
+ return /* @__PURE__ */ (0, import_jsx_runtime38.jsxs)(
2102
2012
  PaginationLink,
2103
2013
  {
2104
2014
  "aria-label": "Go to previous page",
@@ -2106,8 +2016,8 @@ function PaginationPrevious({
2106
2016
  className: cn("gap-1 px-2.5 sm:pl-2.5", className),
2107
2017
  ...props,
2108
2018
  children: [
2109
- /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(ChevronLeft, {}),
2110
- /* @__PURE__ */ (0, import_jsx_runtime39.jsx)("span", { className: "hidden sm:block", children: "Previous" })
2019
+ /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(ChevronLeft, {}),
2020
+ /* @__PURE__ */ (0, import_jsx_runtime38.jsx)("span", { className: "hidden sm:block", children: "Previous" })
2111
2021
  ]
2112
2022
  }
2113
2023
  );
@@ -2116,7 +2026,7 @@ function PaginationNext({
2116
2026
  className,
2117
2027
  ...props
2118
2028
  }) {
2119
- return /* @__PURE__ */ (0, import_jsx_runtime39.jsxs)(
2029
+ return /* @__PURE__ */ (0, import_jsx_runtime38.jsxs)(
2120
2030
  PaginationLink,
2121
2031
  {
2122
2032
  "aria-label": "Go to next page",
@@ -2124,8 +2034,8 @@ function PaginationNext({
2124
2034
  className: cn("gap-1 px-2.5 sm:pr-2.5", className),
2125
2035
  ...props,
2126
2036
  children: [
2127
- /* @__PURE__ */ (0, import_jsx_runtime39.jsx)("span", { className: "hidden sm:block", children: "Next" }),
2128
- /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(ChevronRight, {})
2037
+ /* @__PURE__ */ (0, import_jsx_runtime38.jsx)("span", { className: "hidden sm:block", children: "Next" }),
2038
+ /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(ChevronRight, {})
2129
2039
  ]
2130
2040
  }
2131
2041
  );
@@ -2134,7 +2044,7 @@ function PaginationEllipsis({
2134
2044
  className,
2135
2045
  ...props
2136
2046
  }) {
2137
- return /* @__PURE__ */ (0, import_jsx_runtime39.jsxs)(
2047
+ return /* @__PURE__ */ (0, import_jsx_runtime38.jsxs)(
2138
2048
  "span",
2139
2049
  {
2140
2050
  "aria-hidden": true,
@@ -2142,15 +2052,15 @@ function PaginationEllipsis({
2142
2052
  className: cn("flex size-9 items-center justify-center", className),
2143
2053
  ...props,
2144
2054
  children: [
2145
- /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(Ellipsis, { className: "size-4" }),
2146
- /* @__PURE__ */ (0, import_jsx_runtime39.jsx)("span", { className: "sr-only", children: "More pages" })
2055
+ /* @__PURE__ */ (0, import_jsx_runtime38.jsx)(Ellipsis, { className: "size-4" }),
2056
+ /* @__PURE__ */ (0, import_jsx_runtime38.jsx)("span", { className: "sr-only", children: "More pages" })
2147
2057
  ]
2148
2058
  }
2149
2059
  );
2150
2060
  }
2151
2061
 
2152
2062
  // src/components/DataDisplay/Pagination/Pagination.tsx
2153
- var import_jsx_runtime40 = require("react/jsx-runtime");
2063
+ var import_jsx_runtime39 = require("react/jsx-runtime");
2154
2064
  var CustomPagination = ({
2155
2065
  totalPages,
2156
2066
  currentPage,
@@ -2192,15 +2102,15 @@ var CustomPagination = ({
2192
2102
  }
2193
2103
  };
2194
2104
  const pageNumbers = getPageNumbers();
2195
- return /* @__PURE__ */ (0, import_jsx_runtime40.jsx)(Pagination, { children: /* @__PURE__ */ (0, import_jsx_runtime40.jsxs)(PaginationContent, { children: [
2196
- /* @__PURE__ */ (0, import_jsx_runtime40.jsx)(PaginationItem, { children: /* @__PURE__ */ (0, import_jsx_runtime40.jsx)(
2105
+ return /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(Pagination, { children: /* @__PURE__ */ (0, import_jsx_runtime39.jsxs)(PaginationContent, { children: [
2106
+ /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(PaginationItem, { children: /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(
2197
2107
  PaginationPrevious,
2198
2108
  {
2199
2109
  onClick: () => handlePageChange(currentPage - 1),
2200
2110
  className: currentPage === 1 ? "pointer-events-none opacity-50" : "cursor-pointer"
2201
2111
  }
2202
2112
  ) }),
2203
- pageNumbers.map((pageNumber, index) => /* @__PURE__ */ (0, import_jsx_runtime40.jsx)(PaginationItem, { children: pageNumber === "..." ? /* @__PURE__ */ (0, import_jsx_runtime40.jsx)(PaginationEllipsis, {}) : /* @__PURE__ */ (0, import_jsx_runtime40.jsx)(
2113
+ pageNumbers.map((pageNumber, index) => /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(PaginationItem, { children: pageNumber === "..." ? /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(PaginationEllipsis, {}) : /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(
2204
2114
  PaginationLink,
2205
2115
  {
2206
2116
  onClick: () => handlePageChange(pageNumber),
@@ -2209,7 +2119,7 @@ var CustomPagination = ({
2209
2119
  children: pageNumber
2210
2120
  }
2211
2121
  ) }, index)),
2212
- /* @__PURE__ */ (0, import_jsx_runtime40.jsx)(PaginationItem, { children: /* @__PURE__ */ (0, import_jsx_runtime40.jsx)(
2122
+ /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(PaginationItem, { children: /* @__PURE__ */ (0, import_jsx_runtime39.jsx)(
2213
2123
  PaginationNext,
2214
2124
  {
2215
2125
  onClick: () => handlePageChange(currentPage + 1),
@@ -2221,22 +2131,22 @@ var CustomPagination = ({
2221
2131
  var Pagination_default = CustomPagination;
2222
2132
 
2223
2133
  // src/components/DataDisplay/Table/Table.tsx
2224
- var import_react9 = require("react");
2225
- var import_jsx_runtime41 = require("react/jsx-runtime");
2134
+ var import_react13 = require("react");
2135
+ var import_jsx_runtime40 = require("react/jsx-runtime");
2226
2136
  var Table2 = ({ columns, data, rowActions, className, style, pagination = false, itemsPerPage = 10, onPageChange, loading = false }) => {
2227
2137
  const rawColumns = Array.isArray(columns) ? columns : [];
2228
2138
  const rawData = Array.isArray(data) ? data : [];
2229
2139
  const rawRowActions = Array.isArray(rowActions) ? rowActions : [];
2230
- const [currentPage, setCurrentPage] = (0, import_react9.useState)(1);
2140
+ const [currentPage, setCurrentPage] = (0, import_react13.useState)(1);
2231
2141
  const enablePagination = pagination && rawData.length > itemsPerPage;
2232
2142
  const handlePageChange = (page) => {
2233
2143
  setCurrentPage(page);
2234
2144
  onPageChange?.(page);
2235
2145
  };
2236
2146
  const paginatedData = enablePagination ? rawData.slice((currentPage - 1) * itemsPerPage, currentPage * itemsPerPage) : rawData;
2237
- return /* @__PURE__ */ (0, import_jsx_runtime41.jsxs)("div", { className: `${className} space-y-3`, style, children: [
2238
- /* @__PURE__ */ (0, import_jsx_runtime41.jsx)(DataTable, { columns: rawColumns, data: paginatedData, rowActions: rawRowActions, loading }),
2239
- enablePagination && /* @__PURE__ */ (0, import_jsx_runtime41.jsx)(
2147
+ return /* @__PURE__ */ (0, import_jsx_runtime40.jsxs)("div", { className: `${className} space-y-3`, style, children: [
2148
+ /* @__PURE__ */ (0, import_jsx_runtime40.jsx)(DataTable, { columns: rawColumns, data: paginatedData, rowActions: rawRowActions, loading }),
2149
+ enablePagination && /* @__PURE__ */ (0, import_jsx_runtime40.jsx)(
2240
2150
  Pagination_default,
2241
2151
  {
2242
2152
  totalPages: Math.ceil(rawData.length / itemsPerPage),
@@ -2250,16 +2160,16 @@ var Table_default = Table2;
2250
2160
 
2251
2161
  // src/components/ui/dropdown-menu.tsx
2252
2162
  var DropdownMenuPrimitive = __toESM(require("@radix-ui/react-dropdown-menu"));
2253
- var import_jsx_runtime42 = require("react/jsx-runtime");
2163
+ var import_jsx_runtime41 = require("react/jsx-runtime");
2254
2164
  function DropdownMenu({
2255
2165
  ...props
2256
2166
  }) {
2257
- return /* @__PURE__ */ (0, import_jsx_runtime42.jsx)(DropdownMenuPrimitive.Root, { "data-slot": "dropdown-menu", ...props });
2167
+ return /* @__PURE__ */ (0, import_jsx_runtime41.jsx)(DropdownMenuPrimitive.Root, { "data-slot": "dropdown-menu", ...props });
2258
2168
  }
2259
2169
  function DropdownMenuTrigger({
2260
2170
  ...props
2261
2171
  }) {
2262
- return /* @__PURE__ */ (0, import_jsx_runtime42.jsx)(
2172
+ return /* @__PURE__ */ (0, import_jsx_runtime41.jsx)(
2263
2173
  DropdownMenuPrimitive.Trigger,
2264
2174
  {
2265
2175
  "data-slot": "dropdown-menu-trigger",
@@ -2272,7 +2182,7 @@ function DropdownMenuContent({
2272
2182
  sideOffset = 4,
2273
2183
  ...props
2274
2184
  }) {
2275
- return /* @__PURE__ */ (0, import_jsx_runtime42.jsx)(DropdownMenuPrimitive.Portal, { children: /* @__PURE__ */ (0, import_jsx_runtime42.jsx)(
2185
+ return /* @__PURE__ */ (0, import_jsx_runtime41.jsx)(DropdownMenuPrimitive.Portal, { children: /* @__PURE__ */ (0, import_jsx_runtime41.jsx)(
2276
2186
  DropdownMenuPrimitive.Content,
2277
2187
  {
2278
2188
  "data-slot": "dropdown-menu-content",
@@ -2291,7 +2201,7 @@ function DropdownMenuItem({
2291
2201
  variant = "default",
2292
2202
  ...props
2293
2203
  }) {
2294
- return /* @__PURE__ */ (0, import_jsx_runtime42.jsx)(
2204
+ return /* @__PURE__ */ (0, import_jsx_runtime41.jsx)(
2295
2205
  DropdownMenuPrimitive.Item,
2296
2206
  {
2297
2207
  "data-slot": "dropdown-menu-item",
@@ -2310,7 +2220,7 @@ function DropdownMenuLabel({
2310
2220
  inset,
2311
2221
  ...props
2312
2222
  }) {
2313
- return /* @__PURE__ */ (0, import_jsx_runtime42.jsx)(
2223
+ return /* @__PURE__ */ (0, import_jsx_runtime41.jsx)(
2314
2224
  DropdownMenuPrimitive.Label,
2315
2225
  {
2316
2226
  "data-slot": "dropdown-menu-label",
@@ -2327,7 +2237,7 @@ function DropdownMenuSeparator({
2327
2237
  className,
2328
2238
  ...props
2329
2239
  }) {
2330
- return /* @__PURE__ */ (0, import_jsx_runtime42.jsx)(
2240
+ return /* @__PURE__ */ (0, import_jsx_runtime41.jsx)(
2331
2241
  DropdownMenuPrimitive.Separator,
2332
2242
  {
2333
2243
  "data-slot": "dropdown-menu-separator",
@@ -2338,7 +2248,7 @@ function DropdownMenuSeparator({
2338
2248
  }
2339
2249
 
2340
2250
  // src/components/Navigation/Tabs/Tabs.tsx
2341
- var import_jsx_runtime43 = require("react/jsx-runtime");
2251
+ var import_jsx_runtime42 = require("react/jsx-runtime");
2342
2252
  var Tabs = ({ tabs, className, style, pathname, LinkComponent }) => {
2343
2253
  const rawTabs = Array.isArray(tabs) ? tabs : [];
2344
2254
  const baseClasses = "text-[12px] text-[#E9E9E9] p-2 text-center rounded-md transition-colors border-none outline-none focus:outline-none focus:ring-0 focus:ring-offset-0 cursor-pointer select-none ";
@@ -2348,7 +2258,7 @@ var Tabs = ({ tabs, className, style, pathname, LinkComponent }) => {
2348
2258
  if (!path) return false;
2349
2259
  return pathname === path || path !== "/" && pathname?.startsWith(path);
2350
2260
  };
2351
- return /* @__PURE__ */ (0, import_jsx_runtime43.jsx)("div", { className, style, children: rawTabs.map((tab, index) => {
2261
+ return /* @__PURE__ */ (0, import_jsx_runtime42.jsx)("div", { className, style, children: rawTabs.map((tab, index) => {
2352
2262
  const finalClasses = [
2353
2263
  baseClasses,
2354
2264
  isActive(tab.href) ? activeClasses : hoverClasses,
@@ -2356,29 +2266,29 @@ var Tabs = ({ tabs, className, style, pathname, LinkComponent }) => {
2356
2266
  ].join(" ");
2357
2267
  const hasDropdown = Array.isArray(tab.children) && tab.children.length > 0 && tab.isDropDown;
2358
2268
  if (hasDropdown) {
2359
- return /* @__PURE__ */ (0, import_jsx_runtime43.jsxs)(DropdownMenu, { children: [
2360
- /* @__PURE__ */ (0, import_jsx_runtime43.jsxs)(
2269
+ return /* @__PURE__ */ (0, import_jsx_runtime42.jsxs)(DropdownMenu, { children: [
2270
+ /* @__PURE__ */ (0, import_jsx_runtime42.jsxs)(
2361
2271
  DropdownMenuTrigger,
2362
2272
  {
2363
2273
  className: `${finalClasses} inline-flex items-center gap-1`,
2364
2274
  children: [
2365
2275
  tab.header,
2366
- /* @__PURE__ */ (0, import_jsx_runtime43.jsx)(ChevronDown, { className: "h-4 w-4 opacity-80" })
2276
+ /* @__PURE__ */ (0, import_jsx_runtime42.jsx)(ChevronDown, { className: "h-4 w-4 opacity-80" })
2367
2277
  ]
2368
2278
  }
2369
2279
  ),
2370
- /* @__PURE__ */ (0, import_jsx_runtime43.jsx)(
2280
+ /* @__PURE__ */ (0, import_jsx_runtime42.jsx)(
2371
2281
  DropdownMenuContent,
2372
2282
  {
2373
2283
  align: "start",
2374
2284
  sideOffset: 6,
2375
2285
  className: "z-50 min-w-[160px] rounded-md border border-gray-200 bg-white p-1 shadow-lg",
2376
- children: tab.children.map((item) => /* @__PURE__ */ (0, import_jsx_runtime43.jsx)(
2286
+ children: tab.children.map((item) => /* @__PURE__ */ (0, import_jsx_runtime42.jsx)(
2377
2287
  DropdownMenuItem,
2378
2288
  {
2379
2289
  asChild: true,
2380
2290
  className: "cursor-pointer rounded-sm px-3 py-2 text-[12px] text-gray-800 hover:bg-gray-100 focus:bg-gray-100",
2381
- children: LinkComponent ? /* @__PURE__ */ (0, import_jsx_runtime43.jsx)(LinkComponent, { href: item.href || "#", children: item.header }) : item.header
2291
+ children: LinkComponent ? /* @__PURE__ */ (0, import_jsx_runtime42.jsx)(LinkComponent, { href: item.href || "#", children: item.header }) : item.header
2382
2292
  },
2383
2293
  item.id
2384
2294
  ))
@@ -2386,19 +2296,19 @@ var Tabs = ({ tabs, className, style, pathname, LinkComponent }) => {
2386
2296
  )
2387
2297
  ] }, index);
2388
2298
  }
2389
- return tab.url && LinkComponent ? /* @__PURE__ */ (0, import_jsx_runtime43.jsx)(LinkComponent, { href: tab.url, className: finalClasses, style: tab.style, children: tab.header }, index) : /* @__PURE__ */ (0, import_jsx_runtime43.jsx)("div", { className: finalClasses, style: tab.style, role: "button", tabIndex: 0, children: tab.header }, index);
2299
+ return tab.url && LinkComponent ? /* @__PURE__ */ (0, import_jsx_runtime42.jsx)(LinkComponent, { href: tab.url, className: finalClasses, style: tab.style, children: tab.header }, index) : /* @__PURE__ */ (0, import_jsx_runtime42.jsx)("div", { className: finalClasses, style: tab.style, role: "button", tabIndex: 0, children: tab.header }, index);
2390
2300
  }) });
2391
2301
  };
2392
2302
  var Tabs_default = Tabs;
2393
2303
 
2394
2304
  // src/components/Navigation/Stages/Stages.tsx
2395
- var import_react10 = __toESM(require("react"));
2396
- var import_jsx_runtime44 = require("react/jsx-runtime");
2305
+ var import_react14 = __toESM(require("react"));
2306
+ var import_jsx_runtime43 = require("react/jsx-runtime");
2397
2307
  var StagesComponent = ({ stages, isShowBtn, buttonText, className, style }) => {
2398
- return /* @__PURE__ */ (0, import_jsx_runtime44.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime44.jsxs)("div", { className: "flex items-center justify-between bg-gray-50 p-2 rounded-lg border border-gray-200 w-full", children: [
2399
- /* @__PURE__ */ (0, import_jsx_runtime44.jsx)("div", { className: "flex items-center", children: /* @__PURE__ */ (0, import_jsx_runtime44.jsx)("button", { className: "p-2 hover:bg-gray-100 rounded", children: /* @__PURE__ */ (0, import_jsx_runtime44.jsx)("svg", { className: "w-4 h-4 text-gray-600", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime44.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M19 9l-7 7-7-7" }) }) }) }),
2400
- /* @__PURE__ */ (0, import_jsx_runtime44.jsx)("div", { className: "flex items-center flex-1 px-2", children: stages?.length > 0 && stages?.map((stage, index) => /* @__PURE__ */ (0, import_jsx_runtime44.jsxs)(import_react10.default.Fragment, { children: [
2401
- /* @__PURE__ */ (0, import_jsx_runtime44.jsx)(
2308
+ return /* @__PURE__ */ (0, import_jsx_runtime43.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime43.jsxs)("div", { className: "flex items-center justify-between bg-gray-50 p-2 rounded-lg border border-gray-200 w-full", children: [
2309
+ /* @__PURE__ */ (0, import_jsx_runtime43.jsx)("div", { className: "flex items-center", children: /* @__PURE__ */ (0, import_jsx_runtime43.jsx)("button", { className: "p-2 hover:bg-gray-100 rounded", children: /* @__PURE__ */ (0, import_jsx_runtime43.jsx)("svg", { className: "w-4 h-4 text-gray-600", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime43.jsx)("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M19 9l-7 7-7-7" }) }) }) }),
2310
+ /* @__PURE__ */ (0, import_jsx_runtime43.jsx)("div", { className: "flex items-center flex-1 px-2", children: stages?.length > 0 && stages?.map((stage, index) => /* @__PURE__ */ (0, import_jsx_runtime43.jsxs)(import_react14.default.Fragment, { children: [
2311
+ /* @__PURE__ */ (0, import_jsx_runtime43.jsx)(
2402
2312
  "button",
2403
2313
  {
2404
2314
  className: `
@@ -2406,26 +2316,26 @@ var StagesComponent = ({ stages, isShowBtn, buttonText, className, style }) => {
2406
2316
  children: stage.header
2407
2317
  }
2408
2318
  ),
2409
- index < stages.length - 1 && /* @__PURE__ */ (0, import_jsx_runtime44.jsx)("div", { className: "flex-shrink-0 w-3 h-px bg-gray-300" })
2319
+ index < stages.length - 1 && /* @__PURE__ */ (0, import_jsx_runtime43.jsx)("div", { className: "flex-shrink-0 w-3 h-px bg-gray-300" })
2410
2320
  ] }, stage.id)) }),
2411
- isShowBtn && /* @__PURE__ */ (0, import_jsx_runtime44.jsx)("div", { className: "flex items-center", children: /* @__PURE__ */ (0, import_jsx_runtime44.jsx)("button", { className: "bg-[#034486] text-white px-6 py-2 rounded-lg text-sm font-medium transition-colors duration-200 shadow-sm", children: buttonText }) })
2321
+ isShowBtn && /* @__PURE__ */ (0, import_jsx_runtime43.jsx)("div", { className: "flex items-center", children: /* @__PURE__ */ (0, import_jsx_runtime43.jsx)("button", { className: "bg-[#034486] text-white px-6 py-2 rounded-lg text-sm font-medium transition-colors duration-200 shadow-sm", children: buttonText }) })
2412
2322
  ] }) });
2413
2323
  };
2414
2324
  var Stages_default = StagesComponent;
2415
2325
 
2416
2326
  // src/components/Navigation/Spacer/Spacer.tsx
2417
- var import_jsx_runtime45 = require("react/jsx-runtime");
2327
+ var import_jsx_runtime44 = require("react/jsx-runtime");
2418
2328
  var Spacer = ({ className, style }) => {
2419
- return /* @__PURE__ */ (0, import_jsx_runtime45.jsx)("div", { className: `${className}`, style });
2329
+ return /* @__PURE__ */ (0, import_jsx_runtime44.jsx)("div", { className: `${className}`, style });
2420
2330
  };
2421
2331
  var Spacer_default = Spacer;
2422
2332
 
2423
2333
  // src/components/Navigation/Profile/Profile.tsx
2424
- var import_jsx_runtime46 = require("react/jsx-runtime");
2334
+ var import_jsx_runtime45 = require("react/jsx-runtime");
2425
2335
  var Profile = ({ profileType, showName, userName, className, style }) => {
2426
- return /* @__PURE__ */ (0, import_jsx_runtime46.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime46.jsxs)("div", { className: "flex gap-2 items-center justify-between w-30 cursor-pointer", children: [
2427
- showName && /* @__PURE__ */ (0, import_jsx_runtime46.jsx)("h4", { className: "text-[#000000] dark:text-[#fff] text-[13px] font-[500] mb-0", children: userName }),
2428
- profileType === "avatar" ? /* @__PURE__ */ (0, import_jsx_runtime46.jsx)(
2336
+ return /* @__PURE__ */ (0, import_jsx_runtime45.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime45.jsxs)("div", { className: "flex gap-2 items-center justify-between w-30 cursor-pointer", children: [
2337
+ showName && /* @__PURE__ */ (0, import_jsx_runtime45.jsx)("h4", { className: "text-[#000000] dark:text-[#fff] text-[13px] font-[500] mb-0", children: userName }),
2338
+ profileType === "avatar" ? /* @__PURE__ */ (0, import_jsx_runtime45.jsx)(
2429
2339
  "img",
2430
2340
  {
2431
2341
  src: "https://builder.development.algorithmshift.ai/images/toolset/profile.svg",
@@ -2433,16 +2343,16 @@ var Profile = ({ profileType, showName, userName, className, style }) => {
2433
2343
  width: 24,
2434
2344
  height: 24
2435
2345
  }
2436
- ) : /* @__PURE__ */ (0, import_jsx_runtime46.jsx)("div", { className: "w-6 h-6 bg-[#12715b] rounded-full text-[#fff] text-center text-[11px] flex items-center justify-center", children: "A" })
2346
+ ) : /* @__PURE__ */ (0, import_jsx_runtime45.jsx)("div", { className: "w-6 h-6 bg-[#12715b] rounded-full text-[#fff] text-center text-[11px] flex items-center justify-center", children: "A" })
2437
2347
  ] }) });
2438
2348
  };
2439
2349
  var Profile_default = Profile;
2440
2350
 
2441
2351
  // src/components/Navigation/Notification/Notification.tsx
2442
- var import_jsx_runtime47 = require("react/jsx-runtime");
2352
+ var import_jsx_runtime46 = require("react/jsx-runtime");
2443
2353
  var Notification = ({ className, style, badgeType, badgeCount = 0, hideBadgeWhenZero }) => {
2444
- return /* @__PURE__ */ (0, import_jsx_runtime47.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime47.jsxs)("div", { className: "w-[34px] h-[34px] bg-[#E9E9E9] rounded-md text-center flex items-center justify-center relative", children: [
2445
- /* @__PURE__ */ (0, import_jsx_runtime47.jsx)(
2354
+ return /* @__PURE__ */ (0, import_jsx_runtime46.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime46.jsxs)("div", { className: "w-[34px] h-[34px] bg-[#E9E9E9] rounded-md text-center flex items-center justify-center relative", children: [
2355
+ /* @__PURE__ */ (0, import_jsx_runtime46.jsx)(
2446
2356
  "img",
2447
2357
  {
2448
2358
  src: "https://builder.development.algorithmshift.ai/images/toolset/notification.svg",
@@ -2451,7 +2361,7 @@ var Notification = ({ className, style, badgeType, badgeCount = 0, hideBadgeWhen
2451
2361
  height: 18
2452
2362
  }
2453
2363
  ),
2454
- badgeType === "number" && !(hideBadgeWhenZero && badgeCount === 0) && badgeCount > 0 ? /* @__PURE__ */ (0, import_jsx_runtime47.jsx)("span", { className: "text-[10px] text-[#fff] bg-[#FF4A4A] w-[20px] h-[20px] rounded-full absolute top-0 right-0 transform translate-x-1/2 -translate-y-1/2 leading-[20px]", children: badgeCount }) : /* @__PURE__ */ (0, import_jsx_runtime47.jsx)("span", { className: "bg-[#FF4A4A] w-[10px] h-[10px] rounded-full absolute top-0 right-0 transform translate-x-1/2 -translate-y-1/2 leading-[20px]" })
2364
+ badgeType === "number" && !(hideBadgeWhenZero && badgeCount === 0) && badgeCount > 0 ? /* @__PURE__ */ (0, import_jsx_runtime46.jsx)("span", { className: "text-[10px] text-[#fff] bg-[#FF4A4A] w-[20px] h-[20px] rounded-full absolute top-0 right-0 transform translate-x-1/2 -translate-y-1/2 leading-[20px]", children: badgeCount }) : /* @__PURE__ */ (0, import_jsx_runtime46.jsx)("span", { className: "bg-[#FF4A4A] w-[10px] h-[10px] rounded-full absolute top-0 right-0 transform translate-x-1/2 -translate-y-1/2 leading-[20px]" })
2455
2365
  ] }) });
2456
2366
  };
2457
2367
  var Notification_default = Notification;
@@ -2460,7 +2370,7 @@ var Notification_default = Notification;
2460
2370
  var logo_placeholder_default = "";
2461
2371
 
2462
2372
  // src/components/Navigation/Logo/Logo.tsx
2463
- var import_jsx_runtime48 = require("react/jsx-runtime");
2373
+ var import_jsx_runtime47 = require("react/jsx-runtime");
2464
2374
  var Logo = ({
2465
2375
  className,
2466
2376
  style,
@@ -2468,7 +2378,7 @@ var Logo = ({
2468
2378
  altText = "Preview"
2469
2379
  }) => {
2470
2380
  if (!imageUrl) {
2471
- return /* @__PURE__ */ (0, import_jsx_runtime48.jsx)(
2381
+ return /* @__PURE__ */ (0, import_jsx_runtime47.jsx)(
2472
2382
  "div",
2473
2383
  {
2474
2384
  className: cn(
@@ -2476,19 +2386,19 @@ var Logo = ({
2476
2386
  "p-0"
2477
2387
  ),
2478
2388
  style,
2479
- children: /* @__PURE__ */ (0, import_jsx_runtime48.jsx)("img", { src: logo_placeholder_default, alt: altText, className: "opacity-50", width: 150, height: 80 })
2389
+ children: /* @__PURE__ */ (0, import_jsx_runtime47.jsx)("img", { src: logo_placeholder_default, alt: altText, className: "opacity-50", width: 150, height: 80 })
2480
2390
  }
2481
2391
  );
2482
2392
  }
2483
- return /* @__PURE__ */ (0, import_jsx_runtime48.jsx)("img", { src: imageUrl, alt: altText, className, style });
2393
+ return /* @__PURE__ */ (0, import_jsx_runtime47.jsx)("img", { src: imageUrl, alt: altText, className, style });
2484
2394
  };
2485
2395
  var Logo_default = Logo;
2486
2396
 
2487
2397
  // src/components/ui/avatar.tsx
2488
2398
  var React15 = __toESM(require("react"));
2489
2399
  var AvatarPrimitive = __toESM(require("@radix-ui/react-avatar"));
2490
- var import_jsx_runtime49 = require("react/jsx-runtime");
2491
- var Avatar = React15.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(
2400
+ var import_jsx_runtime48 = require("react/jsx-runtime");
2401
+ var Avatar = React15.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ (0, import_jsx_runtime48.jsx)(
2492
2402
  AvatarPrimitive.Root,
2493
2403
  {
2494
2404
  ref,
@@ -2500,7 +2410,7 @@ var Avatar = React15.forwardRef(({ className, ...props }, ref) => /* @__PURE__ *
2500
2410
  }
2501
2411
  ));
2502
2412
  Avatar.displayName = AvatarPrimitive.Root.displayName;
2503
- var AvatarImage = React15.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(
2413
+ var AvatarImage = React15.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ (0, import_jsx_runtime48.jsx)(
2504
2414
  AvatarPrimitive.Image,
2505
2415
  {
2506
2416
  ref,
@@ -2509,7 +2419,7 @@ var AvatarImage = React15.forwardRef(({ className, ...props }, ref) => /* @__PUR
2509
2419
  }
2510
2420
  ));
2511
2421
  AvatarImage.displayName = AvatarPrimitive.Image.displayName;
2512
- var AvatarFallback = React15.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(
2422
+ var AvatarFallback = React15.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ (0, import_jsx_runtime48.jsx)(
2513
2423
  AvatarPrimitive.Fallback,
2514
2424
  {
2515
2425
  ref,
@@ -2523,7 +2433,7 @@ var AvatarFallback = React15.forwardRef(({ className, ...props }, ref) => /* @__
2523
2433
  AvatarFallback.displayName = AvatarPrimitive.Fallback.displayName;
2524
2434
 
2525
2435
  // src/components/Navigation/Navbar/Navbar.tsx
2526
- var import_jsx_runtime50 = require("react/jsx-runtime");
2436
+ var import_jsx_runtime49 = require("react/jsx-runtime");
2527
2437
  function Navbar({
2528
2438
  style,
2529
2439
  badgeType,
@@ -2538,61 +2448,61 @@ function Navbar({
2538
2448
  ImageComponent
2539
2449
  }) {
2540
2450
  const isMobileView = canvasMode === "mobile" || canvasMode === "tablet";
2541
- return /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("nav", { className: "w-full border-b bg-white shadow-sm", style, children: /* @__PURE__ */ (0, import_jsx_runtime50.jsxs)("div", { className: "mx-auto flex max-w-7xl items-center justify-between px-4 py-2", children: [
2542
- LinkComponent && ImageComponent ? /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(LinkComponent, { href: "/", className: "flex items-center space-x-2", children: imageUrl ? /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(ImageComponent, { src: imageUrl, alt: altText, width: 200, height: 200 }) : /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("span", { className: "font-semibold text-blue-700", children: "Logo" }) }) : /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("span", { className: "font-semibold text-blue-700", children: "Logo" }),
2543
- /* @__PURE__ */ (0, import_jsx_runtime50.jsxs)("div", { className: "flex items-center space-x-3", children: [
2544
- !isMobileView ? /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("div", { className: "flex-1 px-6", children: /* @__PURE__ */ (0, import_jsx_runtime50.jsxs)("div", { className: "relative w-full max-w-md border border-gray-300 rounded-md", children: [
2545
- /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(Search, { className: "absolute left-3 top-1/2 -translate-y-1/2 h-4 w-4 text-gray-400" }),
2546
- /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(Input, { placeholder: "Search", className: "pl-9 text-gray-400" })
2547
- ] }) }) : /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(
2451
+ return /* @__PURE__ */ (0, import_jsx_runtime49.jsx)("nav", { className: "w-full border-b bg-white shadow-sm", style, children: /* @__PURE__ */ (0, import_jsx_runtime49.jsxs)("div", { className: "mx-auto flex max-w-7xl items-center justify-between px-4 py-2", children: [
2452
+ LinkComponent && ImageComponent ? /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(LinkComponent, { href: "/", className: "flex items-center space-x-2", children: imageUrl ? /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(ImageComponent, { src: imageUrl, alt: altText, width: 200, height: 200 }) : /* @__PURE__ */ (0, import_jsx_runtime49.jsx)("span", { className: "font-semibold text-blue-700", children: "Logo" }) }) : /* @__PURE__ */ (0, import_jsx_runtime49.jsx)("span", { className: "font-semibold text-blue-700", children: "Logo" }),
2453
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsxs)("div", { className: "flex items-center space-x-3", children: [
2454
+ !isMobileView ? /* @__PURE__ */ (0, import_jsx_runtime49.jsx)("div", { className: "flex-1 px-6", children: /* @__PURE__ */ (0, import_jsx_runtime49.jsxs)("div", { className: "relative w-full max-w-md border border-gray-300 rounded-md", children: [
2455
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(Search, { className: "absolute left-3 top-1/2 -translate-y-1/2 h-4 w-4 text-gray-400" }),
2456
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(Input, { placeholder: "Search", className: "pl-9 text-gray-400" })
2457
+ ] }) }) : /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(
2548
2458
  Button,
2549
2459
  {
2550
2460
  variant: "ghost",
2551
2461
  size: "icon",
2552
2462
  className: "border border-gray-400",
2553
- children: /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(Search, { className: "h-5 w-5 text-gray-400" })
2463
+ children: /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(Search, { className: "h-5 w-5 text-gray-400" })
2554
2464
  }
2555
2465
  ),
2556
- /* @__PURE__ */ (0, import_jsx_runtime50.jsxs)("div", { className: "relative bg-[#E9E9E9] rounded-md", children: [
2557
- /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(Button, { variant: "ghost", size: "icon", children: /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(Bell, { className: "h-5 w-5 text-[#1C1B1F]" }) }),
2558
- badgeType === "number" && !(hideBadgeWhenZero && badgeCount === 0) && badgeCount > 0 ? /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("span", { className: "absolute -top-1 -right-1 flex h-4 w-4 items-center justify-center rounded-full bg-red-500 text-[10px] text-white leading-8", children: badgeCount }) : /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("span", { className: "absolute -top-1 -right-1 flex h-2 w-2 items-center justify-center rounded-full bg-red-500" })
2466
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsxs)("div", { className: "relative bg-[#E9E9E9] rounded-md", children: [
2467
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(Button, { variant: "ghost", size: "icon", children: /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(Bell, { className: "h-5 w-5 text-[#1C1B1F]" }) }),
2468
+ badgeType === "number" && !(hideBadgeWhenZero && badgeCount === 0) && badgeCount > 0 ? /* @__PURE__ */ (0, import_jsx_runtime49.jsx)("span", { className: "absolute -top-1 -right-1 flex h-4 w-4 items-center justify-center rounded-full bg-red-500 text-[10px] text-white leading-8", children: badgeCount }) : /* @__PURE__ */ (0, import_jsx_runtime49.jsx)("span", { className: "absolute -top-1 -right-1 flex h-2 w-2 items-center justify-center rounded-full bg-red-500" })
2559
2469
  ] }),
2560
- /* @__PURE__ */ (0, import_jsx_runtime50.jsxs)(DropdownMenu, { children: [
2561
- /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(DropdownMenuTrigger, { asChild: true, children: /* @__PURE__ */ (0, import_jsx_runtime50.jsxs)("div", { className: "flex items-center space-x-2", children: [
2562
- !isMobileView && showName && /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("h4", { className: "text-[#000000] text-[13px] font-[500] mb-0", children: "Akbar Sheriff" }),
2563
- !isMobileView ? /* @__PURE__ */ (0, import_jsx_runtime50.jsxs)(import_jsx_runtime50.Fragment, { children: [
2564
- /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(Avatar, { className: "cursor-pointer h-8 w-8 text-gray-900", children: profileType === "avatar" ? /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(
2470
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsxs)(DropdownMenu, { children: [
2471
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(DropdownMenuTrigger, { asChild: true, children: /* @__PURE__ */ (0, import_jsx_runtime49.jsxs)("div", { className: "flex items-center space-x-2", children: [
2472
+ !isMobileView && showName && /* @__PURE__ */ (0, import_jsx_runtime49.jsx)("h4", { className: "text-[#000000] text-[13px] font-[500] mb-0", children: "Akbar Sheriff" }),
2473
+ !isMobileView ? /* @__PURE__ */ (0, import_jsx_runtime49.jsxs)(import_jsx_runtime49.Fragment, { children: [
2474
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(Avatar, { className: "cursor-pointer h-8 w-8 text-gray-900", children: profileType === "avatar" ? /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(
2565
2475
  AvatarImage,
2566
2476
  {
2567
2477
  src: "/images/appbuilder/toolset/profile.svg",
2568
2478
  alt: "Akbar Sheriff"
2569
2479
  }
2570
- ) : /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("div", { className: "w-8 h-8 bg-[#12715b] rounded-full text-[#fff] text-center text-[11px] flex items-center justify-center", children: "AS" }) }),
2571
- /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(
2480
+ ) : /* @__PURE__ */ (0, import_jsx_runtime49.jsx)("div", { className: "w-8 h-8 bg-[#12715b] rounded-full text-[#fff] text-center text-[11px] flex items-center justify-center", children: "AS" }) }),
2481
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(
2572
2482
  Button,
2573
2483
  {
2574
2484
  variant: "ghost",
2575
2485
  size: "icon",
2576
2486
  className: "text-gray-900 md:hidden",
2577
- children: /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(Menu, { className: "h-6 w-6" })
2487
+ children: /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(Menu, { className: "h-6 w-6" })
2578
2488
  }
2579
2489
  )
2580
- ] }) : /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(
2490
+ ] }) : /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(
2581
2491
  Button,
2582
2492
  {
2583
2493
  variant: "ghost",
2584
2494
  size: "icon",
2585
2495
  className: "text-gray-900",
2586
- children: /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(Menu, { className: "h-6 w-6" })
2496
+ children: /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(Menu, { className: "h-6 w-6" })
2587
2497
  }
2588
2498
  )
2589
2499
  ] }) }),
2590
- /* @__PURE__ */ (0, import_jsx_runtime50.jsxs)(DropdownMenuContent, { align: "end", className: "bg-white", children: [
2591
- /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(DropdownMenuLabel, { className: "text-black", children: "My Account" }),
2592
- /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(DropdownMenuSeparator, {}),
2593
- /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(DropdownMenuItem, { className: "text-black", children: "Profile" }),
2594
- /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(DropdownMenuItem, { className: "text-black", children: "Settings" }),
2595
- /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(DropdownMenuItem, { className: "text-black", children: "Logout" })
2500
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsxs)(DropdownMenuContent, { align: "end", className: "bg-white", children: [
2501
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(DropdownMenuLabel, { className: "text-black", children: "My Account" }),
2502
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(DropdownMenuSeparator, {}),
2503
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(DropdownMenuItem, { className: "text-black", children: "Profile" }),
2504
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(DropdownMenuItem, { className: "text-black", children: "Settings" }),
2505
+ /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(DropdownMenuItem, { className: "text-black", children: "Logout" })
2596
2506
  ] })
2597
2507
  ] })
2598
2508
  ] })
@@ -2601,28 +2511,28 @@ function Navbar({
2601
2511
 
2602
2512
  // src/components/Chart/BarChart.tsx
2603
2513
  var import_recharts = require("recharts");
2604
- var import_jsx_runtime51 = require("react/jsx-runtime");
2514
+ var import_jsx_runtime50 = require("react/jsx-runtime");
2605
2515
  var ChartComponent = ({ className, style, ...props }) => {
2606
2516
  const data = Array.isArray(props?.data) ? props.data : [];
2607
2517
  const chartType = props.chartType || "bar";
2608
2518
  const legendsPosition = props.legendsPosition === "middle" || props.legendsPosition === "bottom" ? props.legendsPosition : "top";
2609
- return /* @__PURE__ */ (0, import_jsx_runtime51.jsx)("div", { className: `${className} h-[400px]`, style, children: data.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts.ResponsiveContainer, { width: "100%", height: "100%", children: chartType === "bar" ? /* @__PURE__ */ (0, import_jsx_runtime51.jsxs)(import_recharts.BarChart, { data, children: [
2610
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts.CartesianGrid, { strokeDasharray: "3 3" }),
2611
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts.XAxis, { dataKey: "name" }),
2612
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts.YAxis, {}),
2613
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts.Tooltip, {}),
2614
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts.Legend, { verticalAlign: legendsPosition, align: "center" }),
2615
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts.Bar, { dataKey: "value", fill: "#00695C" })
2616
- ] }) : /* @__PURE__ */ (0, import_jsx_runtime51.jsxs)(import_recharts.AreaChart, { data, children: [
2617
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)("defs", { children: /* @__PURE__ */ (0, import_jsx_runtime51.jsxs)("linearGradient", { id: "colorCount", x1: "0", y1: "0", x2: "0", y2: "1", children: [
2618
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)("stop", { offset: "5%", stopColor: "#00695C", stopOpacity: 0.8 }),
2619
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)("stop", { offset: "95%", stopColor: "#00695C", stopOpacity: 0 })
2519
+ return /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("div", { className: `${className} h-[400px]`, style, children: data.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(import_recharts.ResponsiveContainer, { width: "100%", height: "100%", children: chartType === "bar" ? /* @__PURE__ */ (0, import_jsx_runtime50.jsxs)(import_recharts.BarChart, { data, children: [
2520
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(import_recharts.CartesianGrid, { strokeDasharray: "3 3" }),
2521
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(import_recharts.XAxis, { dataKey: "name" }),
2522
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(import_recharts.YAxis, {}),
2523
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(import_recharts.Tooltip, {}),
2524
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(import_recharts.Legend, { verticalAlign: legendsPosition, align: "center" }),
2525
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(import_recharts.Bar, { dataKey: "value", fill: "#00695C" })
2526
+ ] }) : /* @__PURE__ */ (0, import_jsx_runtime50.jsxs)(import_recharts.AreaChart, { data, children: [
2527
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("defs", { children: /* @__PURE__ */ (0, import_jsx_runtime50.jsxs)("linearGradient", { id: "colorCount", x1: "0", y1: "0", x2: "0", y2: "1", children: [
2528
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("stop", { offset: "5%", stopColor: "#00695C", stopOpacity: 0.8 }),
2529
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("stop", { offset: "95%", stopColor: "#00695C", stopOpacity: 0 })
2620
2530
  ] }) }),
2621
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts.CartesianGrid, { strokeDasharray: "3 3" }),
2622
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts.XAxis, { dataKey: "name" }),
2623
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts.YAxis, {}),
2624
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts.Tooltip, {}),
2625
- /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(
2531
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(import_recharts.CartesianGrid, { strokeDasharray: "3 3" }),
2532
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(import_recharts.XAxis, { dataKey: "name" }),
2533
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(import_recharts.YAxis, {}),
2534
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(import_recharts.Tooltip, {}),
2535
+ /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(
2626
2536
  import_recharts.Area,
2627
2537
  {
2628
2538
  type: "monotone",
@@ -2638,7 +2548,7 @@ var BarChart_default = ChartComponent;
2638
2548
 
2639
2549
  // src/components/Chart/PieChart.tsx
2640
2550
  var import_recharts2 = require("recharts");
2641
- var import_jsx_runtime52 = require("react/jsx-runtime");
2551
+ var import_jsx_runtime51 = require("react/jsx-runtime");
2642
2552
  var DonutChart = ({ className, style, ...props }) => {
2643
2553
  const data = Array.isArray(props?.data) ? props.data : [];
2644
2554
  const total = data.reduce((sum, d) => sum + d.value, 0);
@@ -2649,7 +2559,7 @@ var DonutChart = ({ className, style, ...props }) => {
2649
2559
  const renderLabel = ({ value, x, y }) => {
2650
2560
  if (value == null) return null;
2651
2561
  const percentage = (Number(value) / total * 100).toFixed(0);
2652
- return /* @__PURE__ */ (0, import_jsx_runtime52.jsxs)(
2562
+ return /* @__PURE__ */ (0, import_jsx_runtime51.jsxs)(
2653
2563
  "text",
2654
2564
  {
2655
2565
  x,
@@ -2671,33 +2581,33 @@ var DonutChart = ({ className, style, ...props }) => {
2671
2581
  const wrapperClass = canvasMode ? forceDesktop ? "flex-row" : "flex-col" : "flex-col md:flex-row";
2672
2582
  const renderLegends = () => {
2673
2583
  if (!showLegends) return null;
2674
- return /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(import_jsx_runtime52.Fragment, { children: data.map((d) => /* @__PURE__ */ (0, import_jsx_runtime52.jsxs)(
2584
+ return /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_jsx_runtime51.Fragment, { children: data.map((d) => /* @__PURE__ */ (0, import_jsx_runtime51.jsxs)(
2675
2585
  "div",
2676
2586
  {
2677
2587
  className: "flex items-center space-x-2 rounded-md border border-gray-200 px-3 py-2 w-[48%] md:w-auto",
2678
2588
  children: [
2679
- /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(
2589
+ /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(
2680
2590
  "span",
2681
2591
  {
2682
2592
  className: "inline-block w-[16px] h-[16px] rounded",
2683
2593
  style: { backgroundColor: d.color }
2684
2594
  }
2685
2595
  ),
2686
- /* @__PURE__ */ (0, import_jsx_runtime52.jsx)("span", { className: "text-[#000000] text-[12px] md:text-[13px] font-[500]", children: d.name })
2596
+ /* @__PURE__ */ (0, import_jsx_runtime51.jsx)("span", { className: "text-[#000000] text-[12px] md:text-[13px] font-[500]", children: d.name })
2687
2597
  ]
2688
2598
  },
2689
2599
  d.name
2690
2600
  )) });
2691
2601
  };
2692
- return /* @__PURE__ */ (0, import_jsx_runtime52.jsxs)(
2602
+ return /* @__PURE__ */ (0, import_jsx_runtime51.jsxs)(
2693
2603
  "div",
2694
2604
  {
2695
2605
  className: `relative flex items-center ${wrapperClass} ${className}`,
2696
2606
  style,
2697
2607
  children: [
2698
- /* @__PURE__ */ (0, import_jsx_runtime52.jsxs)("div", { className: "relative w-full md:w-[70%] h-[300px] md:h-[400px] flex items-center justify-center", children: [
2699
- data.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(import_recharts2.ResponsiveContainer, { width: "100%", height: "100%", children: /* @__PURE__ */ (0, import_jsx_runtime52.jsxs)(import_recharts2.PieChart, { children: [
2700
- /* @__PURE__ */ (0, import_jsx_runtime52.jsxs)(
2608
+ /* @__PURE__ */ (0, import_jsx_runtime51.jsxs)("div", { className: "relative w-full md:w-[70%] h-[300px] md:h-[400px] flex items-center justify-center", children: [
2609
+ data.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts2.ResponsiveContainer, { width: "100%", height: "100%", children: /* @__PURE__ */ (0, import_jsx_runtime51.jsxs)(import_recharts2.PieChart, { children: [
2610
+ /* @__PURE__ */ (0, import_jsx_runtime51.jsxs)(
2701
2611
  import_recharts2.Pie,
2702
2612
  {
2703
2613
  data,
@@ -2709,8 +2619,8 @@ var DonutChart = ({ className, style, ...props }) => {
2709
2619
  labelLine: false,
2710
2620
  isAnimationActive: false,
2711
2621
  children: [
2712
- data.map((entry, index) => /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(import_recharts2.Cell, { fill: entry.color }, `cell-${index}`)),
2713
- /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(
2622
+ data.map((entry, index) => /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts2.Cell, { fill: entry.color }, `cell-${index}`)),
2623
+ /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(
2714
2624
  import_recharts2.LabelList,
2715
2625
  {
2716
2626
  dataKey: "value",
@@ -2721,14 +2631,14 @@ var DonutChart = ({ className, style, ...props }) => {
2721
2631
  ]
2722
2632
  }
2723
2633
  ),
2724
- /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(import_recharts2.Tooltip, { formatter: (value, name) => [`${value}k`, name] })
2634
+ /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(import_recharts2.Tooltip, { formatter: (value, name) => [`${value}k`, name] })
2725
2635
  ] }) }),
2726
- /* @__PURE__ */ (0, import_jsx_runtime52.jsxs)("div", { className: "absolute left-1/2 top-1/2 -translate-x-1/2 -translate-y-1/2 text-2xl md:text-4xl font-bold text-[#000]", children: [
2636
+ /* @__PURE__ */ (0, import_jsx_runtime51.jsxs)("div", { className: "absolute left-1/2 top-1/2 -translate-x-1/2 -translate-y-1/2 text-2xl md:text-4xl font-bold text-[#000]", children: [
2727
2637
  total,
2728
2638
  "k"
2729
2639
  ] })
2730
2640
  ] }),
2731
- /* @__PURE__ */ (0, import_jsx_runtime52.jsx)("div", { className: `flex ${forceDesktop ? "flex-col ml-auto space-y-3" : "flex-wrap justify-center gap-2 mt-4"}
2641
+ /* @__PURE__ */ (0, import_jsx_runtime51.jsx)("div", { className: `flex ${forceDesktop ? "flex-col ml-auto space-y-3" : "flex-wrap justify-center gap-2 mt-4"}
2732
2642
  w-full md:w-auto`, children: renderLegends() })
2733
2643
  ]
2734
2644
  }
@@ -2737,10 +2647,10 @@ var DonutChart = ({ className, style, ...props }) => {
2737
2647
  var PieChart_default = DonutChart;
2738
2648
 
2739
2649
  // src/components/Blocks/EmailComposer.tsx
2740
- var import_jsx_runtime53 = require("react/jsx-runtime");
2650
+ var import_jsx_runtime52 = require("react/jsx-runtime");
2741
2651
  function EmailComposer({ className, style, to, setTo, showCc, setShowCc, showBcc, setShowBcc, cc, setCc, bcc, setBcc, subject, setSubject, body, setBody }) {
2742
- return /* @__PURE__ */ (0, import_jsx_runtime53.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime53.jsxs)("div", { className: "border rounded-md shadow bg-[#fff] p-4 mx-auto z-[50] relative", children: [
2743
- /* @__PURE__ */ (0, import_jsx_runtime53.jsx)("div", { className: "mb-3", children: /* @__PURE__ */ (0, import_jsx_runtime53.jsx)(
2652
+ return /* @__PURE__ */ (0, import_jsx_runtime52.jsx)("div", { className, style, children: /* @__PURE__ */ (0, import_jsx_runtime52.jsxs)("div", { className: "border rounded-md shadow bg-[#fff] p-4 mx-auto z-[50] relative", children: [
2653
+ /* @__PURE__ */ (0, import_jsx_runtime52.jsx)("div", { className: "mb-3", children: /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(
2744
2654
  "input",
2745
2655
  {
2746
2656
  type: "email",
@@ -2749,8 +2659,8 @@ function EmailComposer({ className, style, to, setTo, showCc, setShowCc, showBcc
2749
2659
  required: true
2750
2660
  }
2751
2661
  ) }),
2752
- /* @__PURE__ */ (0, import_jsx_runtime53.jsx)("div", { className: "mb-3", children: /* @__PURE__ */ (0, import_jsx_runtime53.jsxs)("div", { className: "flex items-center gap-2", children: [
2753
- /* @__PURE__ */ (0, import_jsx_runtime53.jsx)(
2662
+ /* @__PURE__ */ (0, import_jsx_runtime52.jsx)("div", { className: "mb-3", children: /* @__PURE__ */ (0, import_jsx_runtime52.jsxs)("div", { className: "flex items-center gap-2", children: [
2663
+ /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(
2754
2664
  "input",
2755
2665
  {
2756
2666
  type: "email",
@@ -2761,7 +2671,7 @@ function EmailComposer({ className, style, to, setTo, showCc, setShowCc, showBcc
2761
2671
  required: true
2762
2672
  }
2763
2673
  ),
2764
- !showCc && /* @__PURE__ */ (0, import_jsx_runtime53.jsx)(
2674
+ !showCc && /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(
2765
2675
  "button",
2766
2676
  {
2767
2677
  onClick: () => setShowCc?.(true),
@@ -2769,7 +2679,7 @@ function EmailComposer({ className, style, to, setTo, showCc, setShowCc, showBcc
2769
2679
  children: "Cc"
2770
2680
  }
2771
2681
  ),
2772
- !showBcc && /* @__PURE__ */ (0, import_jsx_runtime53.jsx)(
2682
+ !showBcc && /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(
2773
2683
  "button",
2774
2684
  {
2775
2685
  onClick: () => setShowBcc?.(true),
@@ -2778,7 +2688,7 @@ function EmailComposer({ className, style, to, setTo, showCc, setShowCc, showBcc
2778
2688
  }
2779
2689
  )
2780
2690
  ] }) }),
2781
- showCc && /* @__PURE__ */ (0, import_jsx_runtime53.jsx)("div", { className: "mb-3", children: /* @__PURE__ */ (0, import_jsx_runtime53.jsx)(
2691
+ showCc && /* @__PURE__ */ (0, import_jsx_runtime52.jsx)("div", { className: "mb-3", children: /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(
2782
2692
  "input",
2783
2693
  {
2784
2694
  type: "text",
@@ -2788,7 +2698,7 @@ function EmailComposer({ className, style, to, setTo, showCc, setShowCc, showBcc
2788
2698
  className: "w-full flex-1 border-2 rounded-md h-[40px] px-3 focus:outline-none border-[#E9E9E9] text-[#383838]"
2789
2699
  }
2790
2700
  ) }),
2791
- showBcc && /* @__PURE__ */ (0, import_jsx_runtime53.jsx)("div", { className: "mb-3", children: /* @__PURE__ */ (0, import_jsx_runtime53.jsx)(
2701
+ showBcc && /* @__PURE__ */ (0, import_jsx_runtime52.jsx)("div", { className: "mb-3", children: /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(
2792
2702
  "input",
2793
2703
  {
2794
2704
  type: "text",
@@ -2798,7 +2708,7 @@ function EmailComposer({ className, style, to, setTo, showCc, setShowCc, showBcc
2798
2708
  className: "w-full flex-1 border-2 rounded-md h-[40px] px-3 focus:outline-none border-[#E9E9E9] text-[#383838]"
2799
2709
  }
2800
2710
  ) }),
2801
- /* @__PURE__ */ (0, import_jsx_runtime53.jsx)("div", { className: "mb-3", children: /* @__PURE__ */ (0, import_jsx_runtime53.jsx)(
2711
+ /* @__PURE__ */ (0, import_jsx_runtime52.jsx)("div", { className: "mb-3", children: /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(
2802
2712
  "input",
2803
2713
  {
2804
2714
  type: "text",
@@ -2808,11 +2718,11 @@ function EmailComposer({ className, style, to, setTo, showCc, setShowCc, showBcc
2808
2718
  className: "w-full flex-1 border-2 rounded-md h-[40px] px-3 focus:outline-none border-[#E9E9E9] text-[#383838]"
2809
2719
  }
2810
2720
  ) }),
2811
- /* @__PURE__ */ (0, import_jsx_runtime53.jsx)("div", { className: "mb-4", children: /* @__PURE__ */ (0, import_jsx_runtime53.jsx)(MyEditor, { value: body, onChange: setBody }) }),
2812
- /* @__PURE__ */ (0, import_jsx_runtime53.jsxs)("div", { className: "flex justify-end gap-2", children: [
2813
- /* @__PURE__ */ (0, import_jsx_runtime53.jsx)("button", { className: "px-4 py-2 rounded-md text-gray-600 hover:bg-gray-100", children: "Discard" }),
2814
- /* @__PURE__ */ (0, import_jsx_runtime53.jsx)("button", { className: "px-4 py-2 rounded-md border text-[#12715B] border-[#12715B]", children: "Reset" }),
2815
- /* @__PURE__ */ (0, import_jsx_runtime53.jsx)("button", { className: "px-4 py-2 rounded-md bg-[#12715B] text-white", children: "Send" })
2721
+ /* @__PURE__ */ (0, import_jsx_runtime52.jsx)("div", { className: "mb-4", children: /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(MyEditor, { value: body, onChange: setBody }) }),
2722
+ /* @__PURE__ */ (0, import_jsx_runtime52.jsxs)("div", { className: "flex justify-end gap-2", children: [
2723
+ /* @__PURE__ */ (0, import_jsx_runtime52.jsx)("button", { className: "px-4 py-2 rounded-md text-gray-600 hover:bg-gray-100", children: "Discard" }),
2724
+ /* @__PURE__ */ (0, import_jsx_runtime52.jsx)("button", { className: "px-4 py-2 rounded-md border text-[#12715B] border-[#12715B]", children: "Reset" }),
2725
+ /* @__PURE__ */ (0, import_jsx_runtime52.jsx)("button", { className: "px-4 py-2 rounded-md bg-[#12715B] text-white", children: "Send" })
2816
2726
  ] })
2817
2727
  ] }) });
2818
2728
  }