premium-react-loaders 3.0.0 → 3.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (153) hide show
  1. package/README.md +45 -3
  2. package/dist/components/3d/CubeSpinner.d.ts +21 -0
  3. package/dist/components/3d/CubeSpinner.d.ts.map +1 -0
  4. package/dist/components/3d/FlipCard.d.ts +21 -0
  5. package/dist/components/3d/FlipCard.d.ts.map +1 -0
  6. package/dist/components/3d/Helix.d.ts +23 -0
  7. package/dist/components/3d/Helix.d.ts.map +1 -0
  8. package/dist/components/3d/PerspectiveRing.d.ts +21 -0
  9. package/dist/components/3d/PerspectiveRing.d.ts.map +1 -0
  10. package/dist/components/3d/PlaneRotate.d.ts +21 -0
  11. package/dist/components/3d/PlaneRotate.d.ts.map +1 -0
  12. package/dist/components/3d/index.d.ts +6 -0
  13. package/dist/components/3d/index.d.ts.map +1 -0
  14. package/dist/components/accessibility/LiveRegion.d.ts +34 -0
  15. package/dist/components/accessibility/LiveRegion.d.ts.map +1 -0
  16. package/dist/components/accessibility/index.d.ts +2 -0
  17. package/dist/components/accessibility/index.d.ts.map +1 -0
  18. package/dist/components/index.d.ts +3 -0
  19. package/dist/components/index.d.ts.map +1 -1
  20. package/dist/components/skeleton/DataTableSkeleton.d.ts +25 -0
  21. package/dist/components/skeleton/DataTableSkeleton.d.ts.map +1 -0
  22. package/dist/components/skeleton/SmartSkeleton.d.ts +23 -0
  23. package/dist/components/skeleton/SmartSkeleton.d.ts.map +1 -0
  24. package/dist/components/skeleton/index.d.ts +2 -0
  25. package/dist/components/skeleton/index.d.ts.map +1 -1
  26. package/dist/components/smart/FormFieldLoader.d.ts +22 -0
  27. package/dist/components/smart/FormFieldLoader.d.ts.map +1 -0
  28. package/dist/components/smart/index.d.ts +2 -0
  29. package/dist/components/smart/index.d.ts.map +1 -0
  30. package/dist/hooks/index.d.ts +6 -0
  31. package/dist/hooks/index.d.ts.map +1 -1
  32. package/dist/hooks/useLoadingAnalytics.d.ts +101 -0
  33. package/dist/hooks/useLoadingAnalytics.d.ts.map +1 -0
  34. package/dist/hooks/useLoadingOrchestrator.d.ts +104 -0
  35. package/dist/hooks/useLoadingOrchestrator.d.ts.map +1 -0
  36. package/dist/hooks/useSmartLoader.d.ts +98 -0
  37. package/dist/hooks/useSmartLoader.d.ts.map +1 -0
  38. package/dist/index.cjs +49 -31
  39. package/dist/index.js +49 -31
  40. package/dist/index10.cjs +1 -1
  41. package/dist/index10.js +1 -1
  42. package/dist/index11.cjs +1 -1
  43. package/dist/index11.js +1 -1
  44. package/dist/index12.cjs +1 -1
  45. package/dist/index12.js +1 -1
  46. package/dist/index13.cjs +1 -1
  47. package/dist/index13.js +1 -1
  48. package/dist/index14.cjs +1 -1
  49. package/dist/index14.js +1 -1
  50. package/dist/index15.cjs +1 -1
  51. package/dist/index15.js +1 -1
  52. package/dist/index16.cjs +131 -66
  53. package/dist/index16.js +132 -67
  54. package/dist/index17.cjs +245 -30
  55. package/dist/index17.js +246 -31
  56. package/dist/index18.cjs +24 -36
  57. package/dist/index18.js +24 -36
  58. package/dist/index19.cjs +19 -21
  59. package/dist/index19.js +19 -21
  60. package/dist/index20.cjs +25 -20
  61. package/dist/index20.js +25 -20
  62. package/dist/index21.cjs +22 -32
  63. package/dist/index21.js +22 -32
  64. package/dist/index22.cjs +26 -35
  65. package/dist/index22.js +28 -37
  66. package/dist/index23.cjs +40 -76
  67. package/dist/index23.js +42 -78
  68. package/dist/index24.cjs +53 -102
  69. package/dist/index24.js +54 -103
  70. package/dist/index25.cjs +46 -80
  71. package/dist/index25.js +47 -81
  72. package/dist/index26.cjs +105 -103
  73. package/dist/index26.js +107 -105
  74. package/dist/index27.cjs +108 -27
  75. package/dist/index27.js +111 -30
  76. package/dist/index28.cjs +104 -36
  77. package/dist/index28.js +106 -38
  78. package/dist/index29.cjs +22 -30
  79. package/dist/index29.js +23 -31
  80. package/dist/index30.cjs +30 -32
  81. package/dist/index30.js +31 -33
  82. package/dist/index31.cjs +49 -52
  83. package/dist/index31.js +50 -53
  84. package/dist/index32.cjs +37 -108
  85. package/dist/index32.js +38 -109
  86. package/dist/index33.cjs +54 -72
  87. package/dist/index33.js +55 -73
  88. package/dist/index34.cjs +112 -80
  89. package/dist/index34.js +112 -80
  90. package/dist/index35.cjs +78 -145
  91. package/dist/index35.js +80 -147
  92. package/dist/index36.cjs +78 -57
  93. package/dist/index36.js +79 -58
  94. package/dist/index37.cjs +138 -84
  95. package/dist/index37.js +140 -86
  96. package/dist/index38.cjs +33 -106
  97. package/dist/index38.js +34 -107
  98. package/dist/index39.cjs +66 -50
  99. package/dist/index39.js +66 -50
  100. package/dist/index40.cjs +123 -44
  101. package/dist/index40.js +124 -45
  102. package/dist/index41.cjs +43 -85
  103. package/dist/index41.js +44 -86
  104. package/dist/index42.cjs +35 -27
  105. package/dist/index42.js +35 -27
  106. package/dist/index43.cjs +87 -58
  107. package/dist/index43.js +87 -58
  108. package/dist/index44.cjs +35 -88
  109. package/dist/index44.js +36 -89
  110. package/dist/index45.cjs +62 -58
  111. package/dist/index45.js +63 -59
  112. package/dist/index46.cjs +87 -110
  113. package/dist/index46.js +88 -111
  114. package/dist/index47.cjs +101 -120
  115. package/dist/index47.js +102 -121
  116. package/dist/index48.cjs +158 -0
  117. package/dist/index48.js +158 -0
  118. package/dist/index49.cjs +167 -0
  119. package/dist/index49.js +167 -0
  120. package/dist/index50.cjs +110 -0
  121. package/dist/index50.js +110 -0
  122. package/dist/index51.cjs +112 -0
  123. package/dist/index51.js +112 -0
  124. package/dist/index52.cjs +144 -0
  125. package/dist/index52.js +144 -0
  126. package/dist/index53.cjs +112 -0
  127. package/dist/index53.js +112 -0
  128. package/dist/index54.cjs +189 -0
  129. package/dist/index54.js +189 -0
  130. package/dist/index55.cjs +53 -0
  131. package/dist/index55.js +53 -0
  132. package/dist/index56.cjs +125 -0
  133. package/dist/index56.js +125 -0
  134. package/dist/index7.cjs +1 -1
  135. package/dist/index7.js +1 -1
  136. package/dist/index8.cjs +1 -1
  137. package/dist/index8.js +1 -1
  138. package/dist/index9.cjs +1 -1
  139. package/dist/index9.js +1 -1
  140. package/dist/premium-react-loaders.css +140 -0
  141. package/dist/types/3d.d.ts +85 -0
  142. package/dist/types/3d.d.ts.map +1 -0
  143. package/dist/types/accessibility.d.ts +35 -0
  144. package/dist/types/accessibility.d.ts.map +1 -0
  145. package/dist/types/index.d.ts +3 -0
  146. package/dist/types/index.d.ts.map +1 -1
  147. package/dist/types/smart.d.ts +63 -0
  148. package/dist/types/smart.d.ts.map +1 -0
  149. package/dist/utils/accessibility.d.ts +67 -0
  150. package/dist/utils/accessibility.d.ts.map +1 -0
  151. package/dist/utils/index.d.ts +1 -0
  152. package/dist/utils/index.d.ts.map +1 -1
  153. package/package.json +1 -1
package/dist/index23.cjs CHANGED
@@ -2,19 +2,15 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("react/jsx-runtime");
4
4
  const react = require("react");
5
- const colors = require("./index4.cjs");
6
- const hooks = require("./index47.cjs");
5
+ const hooks = require("./index56.cjs");
7
6
  const classNames = require("./index3.cjs");
8
- const ProgressBar = react.forwardRef(
7
+ const colors = require("./index4.cjs");
8
+ const SpinnerWave = react.forwardRef(
9
9
  ({
10
- value = 0,
11
- indeterminate = false,
12
- showValue = false,
13
- height = "0.5rem",
10
+ size = "md",
14
11
  color = "#3b82f6",
15
- secondaryColor = "#e0e0e0",
16
- gradient = false,
17
- buffer,
12
+ ripples = 3,
13
+ maxScale = 2,
18
14
  speed = "normal",
19
15
  reverse = false,
20
16
  respectMotionPreference = true,
@@ -23,14 +19,13 @@ const ProgressBar = react.forwardRef(
23
19
  transition,
24
20
  className,
25
21
  style,
26
- testId = "progress-bar",
22
+ testId = "spinner-wave",
27
23
  visible = true,
28
- ariaLabel,
24
+ ariaLabel = "Loading...",
29
25
  ...rest
30
26
  }, ref) => {
31
27
  const prefersReducedMotion = hooks.useReducedMotion();
32
28
  const effectiveDuration = hooks.getEffectiveDuration(speed, respectMotionPreference, prefersReducedMotion);
33
- const gradientId = react.useMemo(() => `progress-bar-gradient-${Math.random().toString(36).substr(2, 9)}`, []);
34
29
  const { shouldRender, opacity, transitionStyle } = hooks.useLoaderVisibility(
35
30
  visible,
36
31
  delay,
@@ -38,81 +33,50 @@ const ProgressBar = react.forwardRef(
38
33
  transition
39
34
  );
40
35
  if (!shouldRender) return null;
41
- const clampedValue = Math.min(100, Math.max(0, value));
42
- const clampedBuffer = buffer !== void 0 ? Math.min(100, Math.max(0, buffer)) : void 0;
43
- const progressLabel = ariaLabel || `Loading ${clampedValue}%`;
44
- return /* @__PURE__ */ jsxRuntime.jsxs(
36
+ const sizeValue = colors.normalizeSize(size);
37
+ return /* @__PURE__ */ jsxRuntime.jsx(
45
38
  "div",
46
39
  {
47
40
  ref,
48
41
  "data-testid": testId,
49
- className: classNames.cn("relative w-full overflow-hidden rounded-full", className),
42
+ className: classNames.cn("inline-flex items-center justify-center", className),
50
43
  style: {
51
- height: colors.normalizeSize(height),
52
- backgroundColor: secondaryColor,
53
44
  ...style,
54
45
  opacity,
55
46
  transition: transitionStyle
56
47
  },
57
- role: "progressbar",
58
- "aria-label": progressLabel,
59
- "aria-valuenow": indeterminate ? void 0 : clampedValue,
60
- "aria-valuemin": 0,
61
- "aria-valuemax": 100,
48
+ role: "status",
49
+ "aria-label": ariaLabel,
50
+ "aria-busy": "true",
62
51
  ...rest,
63
- children: [
64
- gradient && !indeterminate && /* @__PURE__ */ jsxRuntime.jsx("svg", { width: "0", height: "0", style: { position: "absolute" }, children: /* @__PURE__ */ jsxRuntime.jsx("defs", { children: /* @__PURE__ */ jsxRuntime.jsxs("linearGradient", { id: gradientId, x1: "0%", y1: "0%", x2: "100%", y2: "0%", children: [
65
- /* @__PURE__ */ jsxRuntime.jsx("stop", { offset: "0%", stopColor: color }),
66
- /* @__PURE__ */ jsxRuntime.jsx("stop", { offset: "100%", stopColor: secondaryColor || "#8b5cf6" })
67
- ] }) }) }),
68
- clampedBuffer !== void 0 && !indeterminate && /* @__PURE__ */ jsxRuntime.jsx(
69
- "div",
70
- {
71
- className: "absolute h-full rounded-full opacity-30",
72
- style: {
73
- width: `${clampedBuffer}%`,
74
- backgroundColor: color
75
- }
76
- }
77
- ),
78
- indeterminate ? /* @__PURE__ */ jsxRuntime.jsx(
79
- "div",
80
- {
81
- className: "absolute h-full rounded-full",
82
- style: {
83
- backgroundColor: gradient ? `url(#${gradientId})` : color,
84
- animation: `progress-indeterminate ${effectiveDuration} ease-in-out infinite`,
85
- animationDirection: reverse ? "reverse" : "normal",
86
- width: "40%"
87
- }
88
- }
89
- ) : /* @__PURE__ */ jsxRuntime.jsx(
90
- "div",
91
- {
92
- className: "h-full rounded-full transition-all duration-300 ease-in-out",
93
- style: {
94
- width: `${clampedValue}%`,
95
- background: gradient ? `url(#${gradientId})` : color
96
- }
97
- }
98
- ),
99
- showValue && !indeterminate && /* @__PURE__ */ jsxRuntime.jsxs(
100
- "span",
101
- {
102
- className: "absolute inset-0 flex items-center justify-center text-xs font-medium",
103
- style: {
104
- color: clampedValue > 50 ? colors.getContrastColor(color) : secondaryColor === "#e0e0e0" ? "#000000" : colors.getContrastColor(secondaryColor)
52
+ children: /* @__PURE__ */ jsxRuntime.jsx(
53
+ "div",
54
+ {
55
+ className: "relative",
56
+ style: {
57
+ width: sizeValue,
58
+ height: sizeValue
59
+ },
60
+ children: Array.from({ length: ripples }).map((_, index) => /* @__PURE__ */ jsxRuntime.jsx(
61
+ "div",
62
+ {
63
+ className: "absolute inset-0 rounded-full border-2",
64
+ style: {
65
+ borderColor: color,
66
+ animation: `ripple-expand ${effectiveDuration} ease-out infinite`,
67
+ animationDelay: reverse ? `${(ripples - index - 1) * 0.4}s` : `${index * 0.4}s`,
68
+ animationDirection: reverse ? "reverse" : "normal",
69
+ // @ts-ignore - CSS variable for animation
70
+ "--max-scale": maxScale
71
+ }
105
72
  },
106
- children: [
107
- clampedValue,
108
- "%"
109
- ]
110
- }
111
- )
112
- ]
73
+ index
74
+ ))
75
+ }
76
+ )
113
77
  }
114
78
  );
115
79
  }
116
80
  );
117
- ProgressBar.displayName = "ProgressBar";
118
- exports.ProgressBar = ProgressBar;
81
+ SpinnerWave.displayName = "SpinnerWave";
82
+ exports.SpinnerWave = SpinnerWave;
package/dist/index23.js CHANGED
@@ -1,18 +1,14 @@
1
- import { jsxs, jsx } from "react/jsx-runtime";
2
- import { forwardRef, useMemo } from "react";
3
- import { normalizeSize, getContrastColor } from "./index4.js";
4
- import { useReducedMotion, useLoaderVisibility, getEffectiveDuration } from "./index47.js";
1
+ import { jsx } from "react/jsx-runtime";
2
+ import { forwardRef } from "react";
3
+ import { useReducedMotion, useLoaderVisibility, getEffectiveDuration } from "./index56.js";
5
4
  import { cn } from "./index3.js";
6
- const ProgressBar = forwardRef(
5
+ import { normalizeSize } from "./index4.js";
6
+ const SpinnerWave = forwardRef(
7
7
  ({
8
- value = 0,
9
- indeterminate = false,
10
- showValue = false,
11
- height = "0.5rem",
8
+ size = "md",
12
9
  color = "#3b82f6",
13
- secondaryColor = "#e0e0e0",
14
- gradient = false,
15
- buffer,
10
+ ripples = 3,
11
+ maxScale = 2,
16
12
  speed = "normal",
17
13
  reverse = false,
18
14
  respectMotionPreference = true,
@@ -21,14 +17,13 @@ const ProgressBar = forwardRef(
21
17
  transition,
22
18
  className,
23
19
  style,
24
- testId = "progress-bar",
20
+ testId = "spinner-wave",
25
21
  visible = true,
26
- ariaLabel,
22
+ ariaLabel = "Loading...",
27
23
  ...rest
28
24
  }, ref) => {
29
25
  const prefersReducedMotion = useReducedMotion();
30
26
  const effectiveDuration = getEffectiveDuration(speed, respectMotionPreference, prefersReducedMotion);
31
- const gradientId = useMemo(() => `progress-bar-gradient-${Math.random().toString(36).substr(2, 9)}`, []);
32
27
  const { shouldRender, opacity, transitionStyle } = useLoaderVisibility(
33
28
  visible,
34
29
  delay,
@@ -36,83 +31,52 @@ const ProgressBar = forwardRef(
36
31
  transition
37
32
  );
38
33
  if (!shouldRender) return null;
39
- const clampedValue = Math.min(100, Math.max(0, value));
40
- const clampedBuffer = buffer !== void 0 ? Math.min(100, Math.max(0, buffer)) : void 0;
41
- const progressLabel = ariaLabel || `Loading ${clampedValue}%`;
42
- return /* @__PURE__ */ jsxs(
34
+ const sizeValue = normalizeSize(size);
35
+ return /* @__PURE__ */ jsx(
43
36
  "div",
44
37
  {
45
38
  ref,
46
39
  "data-testid": testId,
47
- className: cn("relative w-full overflow-hidden rounded-full", className),
40
+ className: cn("inline-flex items-center justify-center", className),
48
41
  style: {
49
- height: normalizeSize(height),
50
- backgroundColor: secondaryColor,
51
42
  ...style,
52
43
  opacity,
53
44
  transition: transitionStyle
54
45
  },
55
- role: "progressbar",
56
- "aria-label": progressLabel,
57
- "aria-valuenow": indeterminate ? void 0 : clampedValue,
58
- "aria-valuemin": 0,
59
- "aria-valuemax": 100,
46
+ role: "status",
47
+ "aria-label": ariaLabel,
48
+ "aria-busy": "true",
60
49
  ...rest,
61
- children: [
62
- gradient && !indeterminate && /* @__PURE__ */ jsx("svg", { width: "0", height: "0", style: { position: "absolute" }, children: /* @__PURE__ */ jsx("defs", { children: /* @__PURE__ */ jsxs("linearGradient", { id: gradientId, x1: "0%", y1: "0%", x2: "100%", y2: "0%", children: [
63
- /* @__PURE__ */ jsx("stop", { offset: "0%", stopColor: color }),
64
- /* @__PURE__ */ jsx("stop", { offset: "100%", stopColor: secondaryColor || "#8b5cf6" })
65
- ] }) }) }),
66
- clampedBuffer !== void 0 && !indeterminate && /* @__PURE__ */ jsx(
67
- "div",
68
- {
69
- className: "absolute h-full rounded-full opacity-30",
70
- style: {
71
- width: `${clampedBuffer}%`,
72
- backgroundColor: color
73
- }
74
- }
75
- ),
76
- indeterminate ? /* @__PURE__ */ jsx(
77
- "div",
78
- {
79
- className: "absolute h-full rounded-full",
80
- style: {
81
- backgroundColor: gradient ? `url(#${gradientId})` : color,
82
- animation: `progress-indeterminate ${effectiveDuration} ease-in-out infinite`,
83
- animationDirection: reverse ? "reverse" : "normal",
84
- width: "40%"
85
- }
86
- }
87
- ) : /* @__PURE__ */ jsx(
88
- "div",
89
- {
90
- className: "h-full rounded-full transition-all duration-300 ease-in-out",
91
- style: {
92
- width: `${clampedValue}%`,
93
- background: gradient ? `url(#${gradientId})` : color
94
- }
95
- }
96
- ),
97
- showValue && !indeterminate && /* @__PURE__ */ jsxs(
98
- "span",
99
- {
100
- className: "absolute inset-0 flex items-center justify-center text-xs font-medium",
101
- style: {
102
- color: clampedValue > 50 ? getContrastColor(color) : secondaryColor === "#e0e0e0" ? "#000000" : getContrastColor(secondaryColor)
50
+ children: /* @__PURE__ */ jsx(
51
+ "div",
52
+ {
53
+ className: "relative",
54
+ style: {
55
+ width: sizeValue,
56
+ height: sizeValue
57
+ },
58
+ children: Array.from({ length: ripples }).map((_, index) => /* @__PURE__ */ jsx(
59
+ "div",
60
+ {
61
+ className: "absolute inset-0 rounded-full border-2",
62
+ style: {
63
+ borderColor: color,
64
+ animation: `ripple-expand ${effectiveDuration} ease-out infinite`,
65
+ animationDelay: reverse ? `${(ripples - index - 1) * 0.4}s` : `${index * 0.4}s`,
66
+ animationDirection: reverse ? "reverse" : "normal",
67
+ // @ts-ignore - CSS variable for animation
68
+ "--max-scale": maxScale
69
+ }
103
70
  },
104
- children: [
105
- clampedValue,
106
- "%"
107
- ]
108
- }
109
- )
110
- ]
71
+ index
72
+ ))
73
+ }
74
+ )
111
75
  }
112
76
  );
113
77
  }
114
78
  );
115
- ProgressBar.displayName = "ProgressBar";
79
+ SpinnerWave.displayName = "SpinnerWave";
116
80
  export {
117
- ProgressBar
81
+ SpinnerWave
118
82
  };
package/dist/index24.cjs CHANGED
@@ -2,19 +2,15 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("react/jsx-runtime");
4
4
  const react = require("react");
5
- const hooks = require("./index47.cjs");
6
- const colors = require("./index4.cjs");
5
+ const hooks = require("./index56.cjs");
7
6
  const classNames = require("./index3.cjs");
8
- const ProgressCircle = react.forwardRef(
7
+ const colors = require("./index4.cjs");
8
+ const SpinnerPulse = react.forwardRef(
9
9
  ({
10
- value = 0,
11
- indeterminate = false,
12
- showValue = false,
13
- size = "lg",
14
- thickness = 4,
10
+ size = "md",
15
11
  color = "#3b82f6",
16
- secondaryColor = "#e0e0e0",
17
- buffer,
12
+ pulses = 2,
13
+ maxScale = 1.8,
18
14
  speed = "normal",
19
15
  reverse = false,
20
16
  respectMotionPreference = true,
@@ -23,9 +19,9 @@ const ProgressCircle = react.forwardRef(
23
19
  transition,
24
20
  className,
25
21
  style,
26
- testId = "progress-circle",
22
+ testId = "spinner-pulse",
27
23
  visible = true,
28
- ariaLabel,
24
+ ariaLabel = "Loading...",
29
25
  ...rest
30
26
  }, ref) => {
31
27
  const prefersReducedMotion = hooks.useReducedMotion();
@@ -37,110 +33,65 @@ const ProgressCircle = react.forwardRef(
37
33
  transition
38
34
  );
39
35
  if (!shouldRender) return null;
40
- const clampedValue = Math.min(100, Math.max(0, value));
41
- const clampedBuffer = buffer !== void 0 ? Math.min(100, Math.max(0, buffer)) : void 0;
42
- const sizeValue = colors.parseSizeToNumber(size, 56);
43
- const thicknessValue = colors.parseSizeToNumber(thickness, 4);
44
- const radius = (sizeValue - thicknessValue * 2) / 2;
45
- const circumference = 2 * Math.PI * radius;
46
- const strokeDashoffset = circumference - clampedValue / 100 * circumference;
47
- const bufferDashoffset = clampedBuffer !== void 0 ? circumference - clampedBuffer / 100 * circumference : void 0;
48
- const progressLabel = ariaLabel || `Loading ${clampedValue}%`;
49
- return /* @__PURE__ */ jsxRuntime.jsxs(
36
+ const sizeValue = colors.normalizeSize(size);
37
+ return /* @__PURE__ */ jsxRuntime.jsx(
50
38
  "div",
51
39
  {
52
40
  ref,
53
41
  "data-testid": testId,
54
- className: classNames.cn("inline-flex items-center justify-center relative", className),
42
+ className: classNames.cn("inline-flex items-center justify-center", className),
55
43
  style: {
56
- width: colors.normalizeSize(size),
57
- height: colors.normalizeSize(size),
58
44
  ...style,
59
45
  opacity,
60
46
  transition: transitionStyle
61
47
  },
62
- role: "progressbar",
63
- "aria-label": progressLabel,
64
- "aria-valuenow": indeterminate ? void 0 : clampedValue,
65
- "aria-valuemin": 0,
66
- "aria-valuemax": 100,
48
+ role: "status",
49
+ "aria-label": ariaLabel,
50
+ "aria-busy": "true",
67
51
  ...rest,
68
- children: [
69
- /* @__PURE__ */ jsxRuntime.jsxs(
70
- "svg",
71
- {
72
- className: classNames.cn(indeterminate && "animate-spinner-rotate"),
52
+ children: /* @__PURE__ */ jsxRuntime.jsxs(
53
+ "div",
54
+ {
55
+ className: "relative",
56
+ style: {
73
57
  width: sizeValue,
74
- height: sizeValue,
75
- viewBox: `0 0 ${sizeValue} ${sizeValue}`,
76
- style: indeterminate ? {
77
- animation: `spinner-rotate ${effectiveDuration} linear infinite`,
78
- animationDirection: reverse ? "reverse" : "normal"
79
- } : void 0,
80
- children: [
81
- /* @__PURE__ */ jsxRuntime.jsx(
82
- "circle",
83
- {
84
- cx: sizeValue / 2,
85
- cy: sizeValue / 2,
86
- r: radius,
87
- fill: "none",
88
- stroke: secondaryColor,
89
- strokeWidth: thicknessValue
90
- }
91
- ),
92
- bufferDashoffset !== void 0 && !indeterminate && /* @__PURE__ */ jsxRuntime.jsx(
93
- "circle",
94
- {
95
- cx: sizeValue / 2,
96
- cy: sizeValue / 2,
97
- r: radius,
98
- fill: "none",
99
- stroke: color,
100
- strokeWidth: thicknessValue,
101
- strokeLinecap: "round",
102
- strokeDasharray: circumference,
103
- strokeDashoffset: bufferDashoffset,
104
- transform: `rotate(-90 ${sizeValue / 2} ${sizeValue / 2})`,
105
- opacity: 0.3
58
+ height: sizeValue
59
+ },
60
+ children: [
61
+ Array.from({ length: pulses }).map((_, index) => /* @__PURE__ */ jsxRuntime.jsx(
62
+ "div",
63
+ {
64
+ className: "absolute inset-0 rounded-full",
65
+ style: {
66
+ backgroundColor: color,
67
+ animation: `heartbeat-pulse ${effectiveDuration} ease-out infinite`,
68
+ animationDelay: reverse ? `${(pulses - index - 1) * 0.3}s` : `${index * 0.3}s`,
69
+ animationDirection: reverse ? "reverse" : "normal",
70
+ // @ts-ignore - CSS variable for animation
71
+ "--max-scale": maxScale
106
72
  }
107
- ),
108
- /* @__PURE__ */ jsxRuntime.jsx(
109
- "circle",
110
- {
111
- cx: sizeValue / 2,
112
- cy: sizeValue / 2,
113
- r: radius,
114
- fill: "none",
115
- stroke: color,
116
- strokeWidth: thicknessValue,
117
- strokeLinecap: "round",
118
- strokeDasharray: circumference,
119
- strokeDashoffset: indeterminate ? circumference * 0.75 : strokeDashoffset,
120
- transform: `rotate(-90 ${sizeValue / 2} ${sizeValue / 2})`,
121
- style: {
122
- transition: indeterminate ? "none" : "stroke-dashoffset 0.3s ease-in-out"
123
- }
73
+ },
74
+ index
75
+ )),
76
+ /* @__PURE__ */ jsxRuntime.jsx(
77
+ "div",
78
+ {
79
+ className: "absolute rounded-full",
80
+ style: {
81
+ backgroundColor: color,
82
+ width: "50%",
83
+ height: "50%",
84
+ top: "25%",
85
+ left: "25%"
124
86
  }
125
- )
126
- ]
127
- }
128
- ),
129
- showValue && !indeterminate && /* @__PURE__ */ jsxRuntime.jsxs(
130
- "span",
131
- {
132
- className: "absolute text-sm font-medium",
133
- style: { color },
134
- children: [
135
- clampedValue,
136
- "%"
137
- ]
138
- }
139
- )
140
- ]
87
+ }
88
+ )
89
+ ]
90
+ }
91
+ )
141
92
  }
142
93
  );
143
94
  }
144
95
  );
145
- ProgressCircle.displayName = "ProgressCircle";
146
- exports.ProgressCircle = ProgressCircle;
96
+ SpinnerPulse.displayName = "SpinnerPulse";
97
+ exports.SpinnerPulse = SpinnerPulse;