premium-react-loaders 1.0.2 → 1.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 (107) hide show
  1. package/dist/components/progress/ProgressSteps.d.ts +16 -0
  2. package/dist/components/progress/ProgressSteps.d.ts.map +1 -0
  3. package/dist/components/progress/index.d.ts +1 -0
  4. package/dist/components/progress/index.d.ts.map +1 -1
  5. package/dist/components/pulse/TypingIndicator.d.ts +16 -0
  6. package/dist/components/pulse/TypingIndicator.d.ts.map +1 -0
  7. package/dist/components/pulse/index.d.ts +1 -0
  8. package/dist/components/pulse/index.d.ts.map +1 -1
  9. package/dist/components/skeleton/SkeletonForm.d.ts +16 -0
  10. package/dist/components/skeleton/SkeletonForm.d.ts.map +1 -0
  11. package/dist/components/skeleton/index.d.ts +1 -0
  12. package/dist/components/skeleton/index.d.ts.map +1 -1
  13. package/dist/components/spinner/SpinnerPulse.d.ts +15 -0
  14. package/dist/components/spinner/SpinnerPulse.d.ts.map +1 -0
  15. package/dist/components/spinner/SpinnerWave.d.ts +15 -0
  16. package/dist/components/spinner/SpinnerWave.d.ts.map +1 -0
  17. package/dist/components/spinner/index.d.ts +2 -0
  18. package/dist/components/spinner/index.d.ts.map +1 -1
  19. package/dist/index.cjs +23 -13
  20. package/dist/index.cjs.map +1 -1
  21. package/dist/index.d.ts +1 -1
  22. package/dist/index.js +23 -13
  23. package/dist/index.js.map +1 -1
  24. package/dist/index13.cjs +54 -35
  25. package/dist/index13.cjs.map +1 -1
  26. package/dist/index13.js +56 -37
  27. package/dist/index13.js.map +1 -1
  28. package/dist/index14.cjs +23 -12
  29. package/dist/index14.cjs.map +1 -1
  30. package/dist/index14.js +23 -12
  31. package/dist/index14.js.map +1 -1
  32. package/dist/index15.cjs +11 -34
  33. package/dist/index15.cjs.map +1 -1
  34. package/dist/index15.js +11 -34
  35. package/dist/index15.js.map +1 -1
  36. package/dist/index16.cjs +40 -23
  37. package/dist/index16.cjs.map +1 -1
  38. package/dist/index16.js +41 -24
  39. package/dist/index16.js.map +1 -1
  40. package/dist/index17.cjs +23 -36
  41. package/dist/index17.cjs.map +1 -1
  42. package/dist/index17.js +23 -36
  43. package/dist/index17.js.map +1 -1
  44. package/dist/index18.cjs +46 -78
  45. package/dist/index18.cjs.map +1 -1
  46. package/dist/index18.js +48 -80
  47. package/dist/index18.js.map +1 -1
  48. package/dist/index19.cjs +39 -103
  49. package/dist/index19.cjs.map +1 -1
  50. package/dist/index19.js +40 -104
  51. package/dist/index19.js.map +1 -1
  52. package/dist/index20.cjs +52 -107
  53. package/dist/index20.cjs.map +1 -1
  54. package/dist/index20.js +54 -109
  55. package/dist/index20.js.map +1 -1
  56. package/dist/index21.cjs +73 -27
  57. package/dist/index21.cjs.map +1 -1
  58. package/dist/index21.js +76 -30
  59. package/dist/index21.js.map +1 -1
  60. package/dist/index22.cjs +98 -31
  61. package/dist/index22.cjs.map +1 -1
  62. package/dist/index22.js +99 -32
  63. package/dist/index22.js.map +1 -1
  64. package/dist/index23.cjs +104 -33
  65. package/dist/index23.cjs.map +1 -1
  66. package/dist/index23.js +106 -35
  67. package/dist/index23.js.map +1 -1
  68. package/dist/index24.cjs +108 -48
  69. package/dist/index24.cjs.map +1 -1
  70. package/dist/index24.js +110 -50
  71. package/dist/index24.js.map +1 -1
  72. package/dist/index25.cjs +55 -16
  73. package/dist/index25.cjs.map +1 -1
  74. package/dist/index25.js +54 -15
  75. package/dist/index25.js.map +1 -1
  76. package/dist/index26.cjs +62 -0
  77. package/dist/index26.cjs.map +1 -0
  78. package/dist/index26.js +62 -0
  79. package/dist/index26.js.map +1 -0
  80. package/dist/index27.cjs +64 -0
  81. package/dist/index27.cjs.map +1 -0
  82. package/dist/index27.js +64 -0
  83. package/dist/index27.js.map +1 -0
  84. package/dist/index28.cjs +61 -0
  85. package/dist/index28.cjs.map +1 -0
  86. package/dist/index28.js +61 -0
  87. package/dist/index28.js.map +1 -0
  88. package/dist/index29.cjs +71 -0
  89. package/dist/index29.cjs.map +1 -0
  90. package/dist/index29.js +71 -0
  91. package/dist/index29.js.map +1 -0
  92. package/dist/index3.cjs +1 -1
  93. package/dist/index3.js +1 -1
  94. package/dist/index30.cjs +18 -0
  95. package/dist/index30.cjs.map +1 -0
  96. package/dist/index30.js +18 -0
  97. package/dist/index30.js.map +1 -0
  98. package/dist/premium-react-loaders.css +29 -0
  99. package/dist/types/progress.d.ts +24 -1
  100. package/dist/types/progress.d.ts.map +1 -1
  101. package/dist/types/pulse.d.ts +13 -0
  102. package/dist/types/pulse.d.ts.map +1 -1
  103. package/dist/types/skeleton.d.ts +17 -0
  104. package/dist/types/skeleton.d.ts.map +1 -1
  105. package/dist/types/spinner.d.ts +18 -0
  106. package/dist/types/spinner.d.ts.map +1 -1
  107. package/package.json +1 -1
@@ -0,0 +1,61 @@
1
+ import { jsx } from "react/jsx-runtime";
2
+ import { forwardRef } from "react";
3
+ import { normalizeSize, getAnimationDuration } from "./index4.js";
4
+ import { cn } from "./index3.js";
5
+ const TypingIndicator = forwardRef(
6
+ ({
7
+ size,
8
+ color = "#3b82f6",
9
+ dotCount = 3,
10
+ dotSize = 8,
11
+ gap = 4,
12
+ variant = "bounce",
13
+ speed = "normal",
14
+ className,
15
+ style,
16
+ testId = "typing-indicator",
17
+ visible = true,
18
+ ariaLabel = "Typing...",
19
+ ...rest
20
+ }, ref) => {
21
+ if (!visible) return null;
22
+ const animationDuration = getAnimationDuration(speed);
23
+ const gapValue = normalizeSize(gap);
24
+ return /* @__PURE__ */ jsx(
25
+ "div",
26
+ {
27
+ ref,
28
+ "data-testid": testId,
29
+ className: cn("inline-flex items-center", className),
30
+ style: {
31
+ gap: gapValue,
32
+ height: size ? normalizeSize(size) : "auto",
33
+ ...style
34
+ },
35
+ role: "status",
36
+ "aria-label": ariaLabel,
37
+ "aria-busy": "true",
38
+ ...rest,
39
+ children: Array.from({ length: dotCount }).map((_, index) => /* @__PURE__ */ jsx(
40
+ "div",
41
+ {
42
+ className: "rounded-full",
43
+ style: {
44
+ width: normalizeSize(dotSize),
45
+ height: normalizeSize(dotSize),
46
+ backgroundColor: color,
47
+ animation: `typing-${variant} ${animationDuration} ease-in-out infinite`,
48
+ animationDelay: `${index * 0.2}s`
49
+ }
50
+ },
51
+ index
52
+ ))
53
+ }
54
+ );
55
+ }
56
+ );
57
+ TypingIndicator.displayName = "TypingIndicator";
58
+ export {
59
+ TypingIndicator
60
+ };
61
+ //# sourceMappingURL=index28.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index28.js","sources":["../src/components/pulse/TypingIndicator.tsx"],"sourcesContent":["import { forwardRef } from 'react';\nimport { TypingIndicatorProps } from '../../types';\nimport { cn, normalizeSize, getAnimationDuration } from '../../utils';\n\n/**\n * TypingIndicator - Chat typing indicator\n *\n * A loader for messaging/chat applications showing typing activity.\n *\n * @example\n * ```tsx\n * <TypingIndicator />\n * <TypingIndicator variant=\"fade\" />\n * <TypingIndicator dotCount={5} color=\"#3b82f6\" />\n * <TypingIndicator dotSize={10} gap={6} />\n * ```\n */\nexport const TypingIndicator = forwardRef<HTMLDivElement, TypingIndicatorProps>(\n (\n {\n size,\n color = '#3b82f6',\n dotCount = 3,\n dotSize = 8,\n gap = 4,\n variant = 'bounce',\n speed = 'normal',\n className,\n style,\n testId = 'typing-indicator',\n visible = true,\n ariaLabel = 'Typing...',\n ...rest\n },\n ref\n ) => {\n if (!visible) return null;\n\n const animationDuration = getAnimationDuration(speed);\n const gapValue = normalizeSize(gap);\n\n return (\n <div\n ref={ref}\n data-testid={testId}\n className={cn('inline-flex items-center', className)}\n style={{\n gap: gapValue,\n height: size ? normalizeSize(size) : 'auto',\n ...style,\n }}\n role=\"status\"\n aria-label={ariaLabel}\n aria-busy=\"true\"\n {...rest}\n >\n {Array.from({ length: dotCount }).map((_, index) => (\n <div\n key={index}\n className=\"rounded-full\"\n style={{\n width: normalizeSize(dotSize),\n height: normalizeSize(dotSize),\n backgroundColor: color,\n animation: `typing-${variant} ${animationDuration} ease-in-out infinite`,\n animationDelay: `${index * 0.2}s`,\n }}\n />\n ))}\n </div>\n );\n }\n);\n\nTypingIndicator.displayName = 'TypingIndicator';\n"],"names":[],"mappings":";;;;AAiBO,MAAM,kBAAkB;AAAA,EAC7B,CACE;AAAA,IACE;AAAA,IACA,QAAQ;AAAA,IACR,WAAW;AAAA,IACX,UAAU;AAAA,IACV,MAAM;AAAA,IACN,UAAU;AAAA,IACV,QAAQ;AAAA,IACR;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT,UAAU;AAAA,IACV,YAAY;AAAA,IACZ,GAAG;AAAA,EAAA,GAEL,QACG;AACH,QAAI,CAAC,QAAS,QAAO;AAErB,UAAM,oBAAoB,qBAAqB,KAAK;AACpD,UAAM,WAAW,cAAc,GAAG;AAElC,WACE;AAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA,eAAa;AAAA,QACb,WAAW,GAAG,4BAA4B,SAAS;AAAA,QACnD,OAAO;AAAA,UACL,KAAK;AAAA,UACL,QAAQ,OAAO,cAAc,IAAI,IAAI;AAAA,UACrC,GAAG;AAAA,QAAA;AAAA,QAEL,MAAK;AAAA,QACL,cAAY;AAAA,QACZ,aAAU;AAAA,QACT,GAAG;AAAA,QAEH,UAAA,MAAM,KAAK,EAAE,QAAQ,UAAU,EAAE,IAAI,CAAC,GAAG,UACxC;AAAA,UAAC;AAAA,UAAA;AAAA,YAEC,WAAU;AAAA,YACV,OAAO;AAAA,cACL,OAAO,cAAc,OAAO;AAAA,cAC5B,QAAQ,cAAc,OAAO;AAAA,cAC7B,iBAAiB;AAAA,cACjB,WAAW,UAAU,OAAO,IAAI,iBAAiB;AAAA,cACjD,gBAAgB,GAAG,QAAQ,GAAG;AAAA,YAAA;AAAA,UAChC;AAAA,UARK;AAAA,QAAA,CAUR;AAAA,MAAA;AAAA,IAAA;AAAA,EAGP;AACF;AAEA,gBAAgB,cAAc;"}
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("react/jsx-runtime");
4
+ const react = require("react");
5
+ const classNames = require("./index3.cjs");
6
+ const LoaderOverlay = react.forwardRef(
7
+ ({
8
+ loading = false,
9
+ loader,
10
+ children,
11
+ position = "fixed",
12
+ backdropOpacity = 0.5,
13
+ backdropColor = "#000000",
14
+ blur = false,
15
+ className,
16
+ style,
17
+ testId = "loader-overlay",
18
+ ariaLabel = "Loading content...",
19
+ zIndex = 9999,
20
+ ...rest
21
+ }, ref) => {
22
+ const backdropStyles = {
23
+ backgroundColor: backdropColor,
24
+ opacity: backdropOpacity,
25
+ backdropFilter: blur ? "blur(4px)" : void 0,
26
+ WebkitBackdropFilter: blur ? "blur(4px)" : void 0
27
+ };
28
+ return /* @__PURE__ */ jsxRuntime.jsxs(
29
+ "div",
30
+ {
31
+ ref,
32
+ "data-testid": testId,
33
+ className: classNames.cn("relative", className),
34
+ style,
35
+ ...rest,
36
+ children: [
37
+ children,
38
+ loading && /* @__PURE__ */ jsxRuntime.jsxs(
39
+ "div",
40
+ {
41
+ className: classNames.cn(
42
+ "inset-0 flex items-center justify-center",
43
+ position === "fixed" ? "fixed" : "absolute"
44
+ ),
45
+ style: {
46
+ zIndex
47
+ },
48
+ role: "status",
49
+ "aria-label": ariaLabel,
50
+ "aria-busy": "true",
51
+ children: [
52
+ /* @__PURE__ */ jsxRuntime.jsx(
53
+ "div",
54
+ {
55
+ className: "absolute inset-0",
56
+ style: backdropStyles,
57
+ "aria-hidden": "true"
58
+ }
59
+ ),
60
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: "relative z-10", children: loader })
61
+ ]
62
+ }
63
+ )
64
+ ]
65
+ }
66
+ );
67
+ }
68
+ );
69
+ LoaderOverlay.displayName = "LoaderOverlay";
70
+ exports.LoaderOverlay = LoaderOverlay;
71
+ //# sourceMappingURL=index29.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index29.cjs","sources":["../src/components/overlay/LoaderOverlay.tsx"],"sourcesContent":["import { forwardRef } from 'react';\nimport { LoaderOverlayProps } from '../../types';\nimport { cn } from '../../utils';\n\n/**\n * LoaderOverlay - Overlay wrapper for displaying loaders over content\n *\n * A flexible overlay component that displays a loader over content during loading states.\n * Supports both full-screen and container-relative positioning.\n *\n * @example\n * ```tsx\n * // Full screen overlay\n * <LoaderOverlay loading={isLoading} loader={<SpinnerCircle />}>\n * <YourContent />\n * </LoaderOverlay>\n *\n * // Container overlay with custom backdrop\n * <LoaderOverlay\n * loading={isLoading}\n * loader={<SpinnerRing />}\n * position=\"absolute\"\n * backdropOpacity={0.7}\n * blur\n * >\n * <YourContent />\n * </LoaderOverlay>\n * ```\n */\nexport const LoaderOverlay = forwardRef<HTMLDivElement, LoaderOverlayProps>(\n (\n {\n loading = false,\n loader,\n children,\n position = 'fixed',\n backdropOpacity = 0.5,\n backdropColor = '#000000',\n blur = false,\n className,\n style,\n testId = 'loader-overlay',\n ariaLabel = 'Loading content...',\n zIndex = 9999,\n ...rest\n },\n ref\n ) => {\n const backdropStyles = {\n backgroundColor: backdropColor,\n opacity: backdropOpacity,\n backdropFilter: blur ? 'blur(4px)' : undefined,\n WebkitBackdropFilter: blur ? 'blur(4px)' : undefined,\n };\n\n return (\n <div\n ref={ref}\n data-testid={testId}\n className={cn('relative', className)}\n style={style}\n {...rest}\n >\n {children}\n\n {loading && (\n <div\n className={cn(\n 'inset-0 flex items-center justify-center',\n position === 'fixed' ? 'fixed' : 'absolute'\n )}\n style={{\n zIndex,\n }}\n role=\"status\"\n aria-label={ariaLabel}\n aria-busy=\"true\"\n >\n {/* Backdrop */}\n <div\n className=\"absolute inset-0\"\n style={backdropStyles}\n aria-hidden=\"true\"\n />\n\n {/* Loader */}\n <div className=\"relative z-10\">{loader}</div>\n </div>\n )}\n </div>\n );\n }\n);\n\nLoaderOverlay.displayName = 'LoaderOverlay';\n"],"names":["forwardRef","jsxs","cn","jsx"],"mappings":";;;;;AA6BO,MAAM,gBAAgBA,MAAAA;AAAAA,EAC3B,CACE;AAAA,IACE,UAAU;AAAA,IACV;AAAA,IACA;AAAA,IACA,WAAW;AAAA,IACX,kBAAkB;AAAA,IAClB,gBAAgB;AAAA,IAChB,OAAO;AAAA,IACP;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT,YAAY;AAAA,IACZ,SAAS;AAAA,IACT,GAAG;AAAA,EAAA,GAEL,QACG;AACH,UAAM,iBAAiB;AAAA,MACrB,iBAAiB;AAAA,MACjB,SAAS;AAAA,MACT,gBAAgB,OAAO,cAAc;AAAA,MACrC,sBAAsB,OAAO,cAAc;AAAA,IAAA;AAG7C,WACEC,2BAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA,eAAa;AAAA,QACb,WAAWC,WAAAA,GAAG,YAAY,SAAS;AAAA,QACnC;AAAA,QACC,GAAG;AAAA,QAEH,UAAA;AAAA,UAAA;AAAA,UAEA,WACCD,2BAAAA;AAAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAWC,WAAAA;AAAAA,gBACT;AAAA,gBACA,aAAa,UAAU,UAAU;AAAA,cAAA;AAAA,cAEnC,OAAO;AAAA,gBACL;AAAA,cAAA;AAAA,cAEF,MAAK;AAAA,cACL,cAAY;AAAA,cACZ,aAAU;AAAA,cAGV,UAAA;AAAA,gBAAAC,2BAAAA;AAAAA,kBAAC;AAAA,kBAAA;AAAA,oBACC,WAAU;AAAA,oBACV,OAAO;AAAA,oBACP,eAAY;AAAA,kBAAA;AAAA,gBAAA;AAAA,gBAIdA,2BAAAA,IAAC,OAAA,EAAI,WAAU,iBAAiB,UAAA,OAAA,CAAO;AAAA,cAAA;AAAA,YAAA;AAAA,UAAA;AAAA,QACzC;AAAA,MAAA;AAAA,IAAA;AAAA,EAIR;AACF;AAEA,cAAc,cAAc;;"}
@@ -0,0 +1,71 @@
1
+ import { jsxs, jsx } from "react/jsx-runtime";
2
+ import { forwardRef } from "react";
3
+ import { cn } from "./index3.js";
4
+ const LoaderOverlay = forwardRef(
5
+ ({
6
+ loading = false,
7
+ loader,
8
+ children,
9
+ position = "fixed",
10
+ backdropOpacity = 0.5,
11
+ backdropColor = "#000000",
12
+ blur = false,
13
+ className,
14
+ style,
15
+ testId = "loader-overlay",
16
+ ariaLabel = "Loading content...",
17
+ zIndex = 9999,
18
+ ...rest
19
+ }, ref) => {
20
+ const backdropStyles = {
21
+ backgroundColor: backdropColor,
22
+ opacity: backdropOpacity,
23
+ backdropFilter: blur ? "blur(4px)" : void 0,
24
+ WebkitBackdropFilter: blur ? "blur(4px)" : void 0
25
+ };
26
+ return /* @__PURE__ */ jsxs(
27
+ "div",
28
+ {
29
+ ref,
30
+ "data-testid": testId,
31
+ className: cn("relative", className),
32
+ style,
33
+ ...rest,
34
+ children: [
35
+ children,
36
+ loading && /* @__PURE__ */ jsxs(
37
+ "div",
38
+ {
39
+ className: cn(
40
+ "inset-0 flex items-center justify-center",
41
+ position === "fixed" ? "fixed" : "absolute"
42
+ ),
43
+ style: {
44
+ zIndex
45
+ },
46
+ role: "status",
47
+ "aria-label": ariaLabel,
48
+ "aria-busy": "true",
49
+ children: [
50
+ /* @__PURE__ */ jsx(
51
+ "div",
52
+ {
53
+ className: "absolute inset-0",
54
+ style: backdropStyles,
55
+ "aria-hidden": "true"
56
+ }
57
+ ),
58
+ /* @__PURE__ */ jsx("div", { className: "relative z-10", children: loader })
59
+ ]
60
+ }
61
+ )
62
+ ]
63
+ }
64
+ );
65
+ }
66
+ );
67
+ LoaderOverlay.displayName = "LoaderOverlay";
68
+ export {
69
+ LoaderOverlay
70
+ };
71
+ //# sourceMappingURL=index29.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index29.js","sources":["../src/components/overlay/LoaderOverlay.tsx"],"sourcesContent":["import { forwardRef } from 'react';\nimport { LoaderOverlayProps } from '../../types';\nimport { cn } from '../../utils';\n\n/**\n * LoaderOverlay - Overlay wrapper for displaying loaders over content\n *\n * A flexible overlay component that displays a loader over content during loading states.\n * Supports both full-screen and container-relative positioning.\n *\n * @example\n * ```tsx\n * // Full screen overlay\n * <LoaderOverlay loading={isLoading} loader={<SpinnerCircle />}>\n * <YourContent />\n * </LoaderOverlay>\n *\n * // Container overlay with custom backdrop\n * <LoaderOverlay\n * loading={isLoading}\n * loader={<SpinnerRing />}\n * position=\"absolute\"\n * backdropOpacity={0.7}\n * blur\n * >\n * <YourContent />\n * </LoaderOverlay>\n * ```\n */\nexport const LoaderOverlay = forwardRef<HTMLDivElement, LoaderOverlayProps>(\n (\n {\n loading = false,\n loader,\n children,\n position = 'fixed',\n backdropOpacity = 0.5,\n backdropColor = '#000000',\n blur = false,\n className,\n style,\n testId = 'loader-overlay',\n ariaLabel = 'Loading content...',\n zIndex = 9999,\n ...rest\n },\n ref\n ) => {\n const backdropStyles = {\n backgroundColor: backdropColor,\n opacity: backdropOpacity,\n backdropFilter: blur ? 'blur(4px)' : undefined,\n WebkitBackdropFilter: blur ? 'blur(4px)' : undefined,\n };\n\n return (\n <div\n ref={ref}\n data-testid={testId}\n className={cn('relative', className)}\n style={style}\n {...rest}\n >\n {children}\n\n {loading && (\n <div\n className={cn(\n 'inset-0 flex items-center justify-center',\n position === 'fixed' ? 'fixed' : 'absolute'\n )}\n style={{\n zIndex,\n }}\n role=\"status\"\n aria-label={ariaLabel}\n aria-busy=\"true\"\n >\n {/* Backdrop */}\n <div\n className=\"absolute inset-0\"\n style={backdropStyles}\n aria-hidden=\"true\"\n />\n\n {/* Loader */}\n <div className=\"relative z-10\">{loader}</div>\n </div>\n )}\n </div>\n );\n }\n);\n\nLoaderOverlay.displayName = 'LoaderOverlay';\n"],"names":[],"mappings":";;;AA6BO,MAAM,gBAAgB;AAAA,EAC3B,CACE;AAAA,IACE,UAAU;AAAA,IACV;AAAA,IACA;AAAA,IACA,WAAW;AAAA,IACX,kBAAkB;AAAA,IAClB,gBAAgB;AAAA,IAChB,OAAO;AAAA,IACP;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT,YAAY;AAAA,IACZ,SAAS;AAAA,IACT,GAAG;AAAA,EAAA,GAEL,QACG;AACH,UAAM,iBAAiB;AAAA,MACrB,iBAAiB;AAAA,MACjB,SAAS;AAAA,MACT,gBAAgB,OAAO,cAAc;AAAA,MACrC,sBAAsB,OAAO,cAAc;AAAA,IAAA;AAG7C,WACE;AAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA,eAAa;AAAA,QACb,WAAW,GAAG,YAAY,SAAS;AAAA,QACnC;AAAA,QACC,GAAG;AAAA,QAEH,UAAA;AAAA,UAAA;AAAA,UAEA,WACC;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,WAAW;AAAA,gBACT;AAAA,gBACA,aAAa,UAAU,UAAU;AAAA,cAAA;AAAA,cAEnC,OAAO;AAAA,gBACL;AAAA,cAAA;AAAA,cAEF,MAAK;AAAA,cACL,cAAY;AAAA,cACZ,aAAU;AAAA,cAGV,UAAA;AAAA,gBAAA;AAAA,kBAAC;AAAA,kBAAA;AAAA,oBACC,WAAU;AAAA,oBACV,OAAO;AAAA,oBACP,eAAY;AAAA,kBAAA;AAAA,gBAAA;AAAA,gBAId,oBAAC,OAAA,EAAI,WAAU,iBAAiB,UAAA,OAAA,CAAO;AAAA,cAAA;AAAA,YAAA;AAAA,UAAA;AAAA,QACzC;AAAA,MAAA;AAAA,IAAA;AAAA,EAIR;AACF;AAEA,cAAc,cAAc;"}
package/dist/index3.cjs CHANGED
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const clsx = require("./index25.cjs");
3
+ const clsx = require("./index30.cjs");
4
4
  function cn(...inputs) {
5
5
  return clsx.clsx(inputs);
6
6
  }
package/dist/index3.js CHANGED
@@ -1,4 +1,4 @@
1
- import { clsx } from "./index25.js";
1
+ import { clsx } from "./index30.js";
2
2
  function cn(...inputs) {
3
3
  return clsx(inputs);
4
4
  }
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
+ function r(e) {
4
+ var t, f, n = "";
5
+ if ("string" == typeof e || "number" == typeof e) n += e;
6
+ else if ("object" == typeof e) if (Array.isArray(e)) {
7
+ var o = e.length;
8
+ for (t = 0; t < o; t++) e[t] && (f = r(e[t])) && (n && (n += " "), n += f);
9
+ } else for (f in e) e[f] && (n && (n += " "), n += f);
10
+ return n;
11
+ }
12
+ function clsx() {
13
+ for (var e, t, f = 0, n = "", o = arguments.length; f < o; f++) (e = arguments[f]) && (t = r(e)) && (n && (n += " "), n += t);
14
+ return n;
15
+ }
16
+ exports.clsx = clsx;
17
+ exports.default = clsx;
18
+ //# sourceMappingURL=index30.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index30.cjs","sources":["../node_modules/clsx/dist/clsx.mjs"],"sourcesContent":["function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;"],"names":[],"mappings":";;AAAA,SAAS,EAAE,GAAE;AAAC,MAAI,GAAE,GAAE,IAAE;AAAG,MAAG,YAAU,OAAO,KAAG,YAAU,OAAO,EAAE,MAAG;AAAA,WAAU,YAAU,OAAO,EAAE,KAAG,MAAM,QAAQ,CAAC,GAAE;AAAC,QAAI,IAAE,EAAE;AAAO,SAAI,IAAE,GAAE,IAAE,GAAE,IAAI,GAAE,CAAC,MAAI,IAAE,EAAE,EAAE,CAAC,CAAC,OAAK,MAAI,KAAG,MAAK,KAAG;AAAA,EAAE,MAAM,MAAI,KAAK,EAAE,GAAE,CAAC,MAAI,MAAI,KAAG,MAAK,KAAG;AAAG,SAAO;AAAC;AAAQ,SAAS,OAAM;AAAC,WAAQ,GAAE,GAAE,IAAE,GAAE,IAAE,IAAG,IAAE,UAAU,QAAO,IAAE,GAAE,IAAI,EAAC,IAAE,UAAU,CAAC,OAAK,IAAE,EAAE,CAAC,OAAK,MAAI,KAAG,MAAK,KAAG;AAAG,SAAO;AAAC;;;","x_google_ignoreList":[0]}
@@ -0,0 +1,18 @@
1
+ function r(e) {
2
+ var t, f, n = "";
3
+ if ("string" == typeof e || "number" == typeof e) n += e;
4
+ else if ("object" == typeof e) if (Array.isArray(e)) {
5
+ var o = e.length;
6
+ for (t = 0; t < o; t++) e[t] && (f = r(e[t])) && (n && (n += " "), n += f);
7
+ } else for (f in e) e[f] && (n && (n += " "), n += f);
8
+ return n;
9
+ }
10
+ function clsx() {
11
+ for (var e, t, f = 0, n = "", o = arguments.length; f < o; f++) (e = arguments[f]) && (t = r(e)) && (n && (n += " "), n += t);
12
+ return n;
13
+ }
14
+ export {
15
+ clsx,
16
+ clsx as default
17
+ };
18
+ //# sourceMappingURL=index30.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index30.js","sources":["../node_modules/clsx/dist/clsx.mjs"],"sourcesContent":["function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;"],"names":[],"mappings":"AAAA,SAAS,EAAE,GAAE;AAAC,MAAI,GAAE,GAAE,IAAE;AAAG,MAAG,YAAU,OAAO,KAAG,YAAU,OAAO,EAAE,MAAG;AAAA,WAAU,YAAU,OAAO,EAAE,KAAG,MAAM,QAAQ,CAAC,GAAE;AAAC,QAAI,IAAE,EAAE;AAAO,SAAI,IAAE,GAAE,IAAE,GAAE,IAAI,GAAE,CAAC,MAAI,IAAE,EAAE,EAAE,CAAC,CAAC,OAAK,MAAI,KAAG,MAAK,KAAG;AAAA,EAAE,MAAM,MAAI,KAAK,EAAE,GAAE,CAAC,MAAI,MAAI,KAAG,MAAK,KAAG;AAAG,SAAO;AAAC;AAAQ,SAAS,OAAM;AAAC,WAAQ,GAAE,GAAE,IAAE,GAAE,IAAE,IAAG,IAAE,UAAU,QAAO,IAAE,GAAE,IAAI,EAAC,IAAE,UAAU,CAAC,OAAK,IAAE,EAAE,CAAC,OAAK,MAAI,KAAG,MAAK,KAAG;AAAG,SAAO;AAAC;","x_google_ignoreList":[0]}
@@ -560,6 +560,9 @@ video {
560
560
  .mb-4 {
561
561
  margin-bottom: 1rem;
562
562
  }
563
+ .mt-1 {
564
+ margin-top: 0.25rem;
565
+ }
563
566
  .block {
564
567
  display: block;
565
568
  }
@@ -620,6 +623,9 @@ video {
620
623
  .grid-cols-4 {
621
624
  grid-template-columns: repeat(4, minmax(0, 1fr));
622
625
  }
626
+ .flex-row {
627
+ flex-direction: row;
628
+ }
623
629
  .flex-col {
624
630
  flex-direction: column;
625
631
  }
@@ -632,6 +638,12 @@ video {
632
638
  .items-center {
633
639
  align-items: center;
634
640
  }
641
+ .justify-start {
642
+ justify-content: flex-start;
643
+ }
644
+ .justify-end {
645
+ justify-content: flex-end;
646
+ }
635
647
  .justify-center {
636
648
  justify-content: center;
637
649
  }
@@ -694,6 +706,9 @@ video {
694
706
  .border {
695
707
  border-width: 1px;
696
708
  }
709
+ .border-2 {
710
+ border-width: 2px;
711
+ }
697
712
  .border-b {
698
713
  border-bottom-width: 1px;
699
714
  }
@@ -731,6 +746,12 @@ video {
731
746
  .pb-6 {
732
747
  padding-bottom: 1.5rem;
733
748
  }
749
+ .text-left {
750
+ text-align: left;
751
+ }
752
+ .text-center {
753
+ text-align: center;
754
+ }
734
755
  .text-2xl {
735
756
  font-size: 1.5rem;
736
757
  line-height: 2rem;
@@ -783,12 +804,20 @@ video {
783
804
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
784
805
  transition-duration: 150ms;
785
806
  }
807
+ .transition-colors {
808
+ transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
809
+ transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
810
+ transition-duration: 150ms;
811
+ }
786
812
  .duration-300 {
787
813
  transition-duration: 300ms;
788
814
  }
789
815
  .ease-in-out {
790
816
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
791
817
  }
818
+ .ease-out {
819
+ transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
820
+ }
792
821
  /* CSS Variables for theming */
793
822
  :root {
794
823
  --loader-primary: #3b82f6;
@@ -1,4 +1,4 @@
1
- import { ProgressLoaderProps } from './common';
1
+ import { ProgressLoaderProps, BaseLoaderProps } from './common';
2
2
  /**
3
3
  * ProgressBar component props
4
4
  */
@@ -30,4 +30,27 @@ export interface ProgressRingProps extends ProgressLoaderProps {
30
30
  /** Buffer value (0-100) for showing partial loading */
31
31
  buffer?: number;
32
32
  }
33
+ /**
34
+ * ProgressSteps component props
35
+ */
36
+ export interface ProgressStepsProps extends BaseLoaderProps {
37
+ /** Total number of steps (required) */
38
+ steps: number;
39
+ /** Current active step (0-indexed, required) */
40
+ currentStep: number;
41
+ /** Optional step labels */
42
+ labels?: string[];
43
+ /** Show step numbers */
44
+ showNumbers?: boolean;
45
+ /** Layout orientation */
46
+ orientation?: 'horizontal' | 'vertical';
47
+ /** Connector style between steps */
48
+ connector?: 'line' | 'none';
49
+ /** Color for completed steps */
50
+ completedColor?: string;
51
+ /** Color for active step */
52
+ activeColor?: string;
53
+ /** Color for inactive steps */
54
+ inactiveColor?: string;
55
+ }
33
56
  //# sourceMappingURL=progress.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"progress.d.ts","sourceRoot":"","sources":["../../src/types/progress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAE/C;;GAEG;AACH,MAAM,WAAW,gBAAiB,SAAQ,mBAAmB;IAC3D,iCAAiC;IACjC,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACzB,sBAAsB;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,uDAAuD;IACvD,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;GAEG;AACH,MAAM,WAAW,mBAAoB,SAAQ,mBAAmB;IAC9D,yBAAyB;IACzB,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACvB,uDAAuD;IACvD,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAkB,SAAQ,mBAAmB;IAC5D,uBAAuB;IACvB,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACvB,sBAAsB;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,uDAAuD;IACvD,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB"}
1
+ {"version":3,"file":"progress.d.ts","sourceRoot":"","sources":["../../src/types/progress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAEhE;;GAEG;AACH,MAAM,WAAW,gBAAiB,SAAQ,mBAAmB;IAC3D,iCAAiC;IACjC,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACzB,sBAAsB;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,uDAAuD;IACvD,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;GAEG;AACH,MAAM,WAAW,mBAAoB,SAAQ,mBAAmB;IAC9D,yBAAyB;IACzB,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACvB,uDAAuD;IACvD,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAkB,SAAQ,mBAAmB;IAC5D,uBAAuB;IACvB,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACvB,sBAAsB;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,uDAAuD;IACvD,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAmB,SAAQ,eAAe;IACzD,uCAAuC;IACvC,KAAK,EAAE,MAAM,CAAC;IACd,gDAAgD;IAChD,WAAW,EAAE,MAAM,CAAC;IACpB,2BAA2B;IAC3B,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,wBAAwB;IACxB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,yBAAyB;IACzB,WAAW,CAAC,EAAE,YAAY,GAAG,UAAU,CAAC;IACxC,oCAAoC;IACpC,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC5B,gCAAgC;IAChC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,4BAA4B;IAC5B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,+BAA+B;IAC/B,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB"}
@@ -22,4 +22,17 @@ export interface PulseBarsProps extends BaseLoaderProps {
22
22
  /** Number of bars */
23
23
  barCount?: number;
24
24
  }
25
+ /**
26
+ * TypingIndicator component props
27
+ */
28
+ export interface TypingIndicatorProps extends BaseLoaderProps {
29
+ /** Number of dots */
30
+ dotCount?: number;
31
+ /** Size of each dot */
32
+ dotSize?: number | string;
33
+ /** Space between dots */
34
+ gap?: number | string;
35
+ /** Animation style */
36
+ variant?: 'bounce' | 'fade';
37
+ }
25
38
  //# sourceMappingURL=pulse.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"pulse.d.ts","sourceRoot":"","sources":["../../src/types/pulse.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE3C;;GAEG;AACH,MAAM,WAAW,cAAe,SAAQ,eAAe;IACrD,qBAAqB;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,uBAAuB;IACvB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,cAAe,SAAQ,eAAe;IACrD,6BAA6B;IAC7B,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,cAAe,SAAQ,eAAe;IACrD,qBAAqB;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB"}
1
+ {"version":3,"file":"pulse.d.ts","sourceRoot":"","sources":["../../src/types/pulse.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE3C;;GAEG;AACH,MAAM,WAAW,cAAe,SAAQ,eAAe;IACrD,qBAAqB;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,uBAAuB;IACvB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,cAAe,SAAQ,eAAe;IACrD,6BAA6B;IAC7B,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,cAAe,SAAQ,eAAe;IACrD,qBAAqB;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,oBAAqB,SAAQ,eAAe;IAC3D,qBAAqB;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,uBAAuB;IACvB,OAAO,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC1B,yBAAyB;IACzB,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACtB,sBAAsB;IACtB,OAAO,CAAC,EAAE,QAAQ,GAAG,MAAM,CAAC;CAC7B"}
@@ -77,4 +77,21 @@ export interface SkeletonPageProps extends SkeletonBaseProps {
77
77
  /** Page layout variant */
78
78
  variant?: 'default' | 'dashboard' | 'article' | 'profile';
79
79
  }
80
+ /**
81
+ * SkeletonForm component props
82
+ */
83
+ export interface SkeletonFormProps extends SkeletonBaseProps {
84
+ /** Number of form fields */
85
+ fields?: number;
86
+ /** Show field labels */
87
+ showLabels?: boolean;
88
+ /** Show submit button */
89
+ showButton?: boolean;
90
+ /** Spacing between fields */
91
+ gap?: number | string;
92
+ /** Button width */
93
+ buttonWidth?: number | string;
94
+ /** Button alignment */
95
+ buttonPosition?: 'left' | 'right' | 'center';
96
+ }
80
97
  //# sourceMappingURL=skeleton.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"skeleton.d.ts","sourceRoot":"","sources":["../../src/types/skeleton.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAE7C;;GAEG;AACH,MAAM,MAAM,eAAe,GAAG,MAAM,GAAG,UAAU,GAAG,aAAa,GAAG,SAAS,CAAC;AAE9E;;GAEG;AACH,MAAM,WAAW,aAAc,SAAQ,iBAAiB;IACtD,oBAAoB;IACpB,OAAO,CAAC,EAAE,eAAe,CAAC;CAC3B;AAED;;GAEG;AACH,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,2BAA2B;IAC3B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,wBAAwB;IACxB,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACtB,iDAAiD;IACjD,aAAa,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CACjC;AAED;;GAEG;AACH,MAAM,WAAW,mBAAoB,SAAQ,iBAAiB;IAC5D,mBAAmB;IACnB,KAAK,CAAC,EAAE,QAAQ,GAAG,QAAQ,CAAC;CAC7B;AAED;;GAEG;AACH,MAAM,WAAW,kBAAmB,SAAQ,iBAAiB;IAC3D,gDAAgD;IAChD,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,kBAAkB;IAClB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,kBAAkB;IAClB,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC7B,kCAAkC;IAClC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,kBAAkB;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,2BAA2B;IAC3B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,kBAAkB;IAClB,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC7B,wBAAwB;IACxB,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CACvB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAmB,SAAQ,iBAAiB;IAC3D,qBAAqB;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,wBAAwB;IACxB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,wBAAwB;IACxB,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,0BAA0B;IAC1B,OAAO,CAAC,EAAE,SAAS,GAAG,WAAW,GAAG,SAAS,GAAG,SAAS,CAAC;CAC3D"}
1
+ {"version":3,"file":"skeleton.d.ts","sourceRoot":"","sources":["../../src/types/skeleton.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAE7C;;GAEG;AACH,MAAM,MAAM,eAAe,GAAG,MAAM,GAAG,UAAU,GAAG,aAAa,GAAG,SAAS,CAAC;AAE9E;;GAEG;AACH,MAAM,WAAW,aAAc,SAAQ,iBAAiB;IACtD,oBAAoB;IACpB,OAAO,CAAC,EAAE,eAAe,CAAC;CAC3B;AAED;;GAEG;AACH,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,2BAA2B;IAC3B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,wBAAwB;IACxB,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACtB,iDAAiD;IACjD,aAAa,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CACjC;AAED;;GAEG;AACH,MAAM,WAAW,mBAAoB,SAAQ,iBAAiB;IAC5D,mBAAmB;IACnB,KAAK,CAAC,EAAE,QAAQ,GAAG,QAAQ,CAAC;CAC7B;AAED;;GAEG;AACH,MAAM,WAAW,kBAAmB,SAAQ,iBAAiB;IAC3D,gDAAgD;IAChD,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,kBAAkB;IAClB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,kBAAkB;IAClB,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC7B,kCAAkC;IAClC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,kBAAkB;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,2BAA2B;IAC3B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,kBAAkB;IAClB,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC7B,wBAAwB;IACxB,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CACvB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAmB,SAAQ,iBAAiB;IAC3D,qBAAqB;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,wBAAwB;IACxB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,wBAAwB;IACxB,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,0BAA0B;IAC1B,OAAO,CAAC,EAAE,SAAS,GAAG,WAAW,GAAG,SAAS,GAAG,SAAS,CAAC;CAC3D;AAED;;GAEG;AACH,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,4BAA4B;IAC5B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,wBAAwB;IACxB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,yBAAyB;IACzB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,6BAA6B;IAC7B,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACtB,mBAAmB;IACnB,WAAW,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC9B,uBAAuB;IACvB,cAAc,CAAC,EAAE,MAAM,GAAG,OAAO,GAAG,QAAQ,CAAC;CAC9C"}
@@ -36,4 +36,22 @@ export interface SpinnerGridProps extends BaseLoaderProps {
36
36
  /** Grid size (e.g., 3 for 3x3) */
37
37
  gridSize?: number;
38
38
  }
39
+ /**
40
+ * SpinnerWave component props
41
+ */
42
+ export interface SpinnerWaveProps extends BaseLoaderProps {
43
+ /** Number of expanding ripples */
44
+ ripples?: number;
45
+ /** Maximum scale before fade */
46
+ maxScale?: number;
47
+ }
48
+ /**
49
+ * SpinnerPulse component props
50
+ */
51
+ export interface SpinnerPulseProps extends BaseLoaderProps {
52
+ /** Number of pulse circles (1-3) */
53
+ pulses?: number;
54
+ /** Maximum scale at expansion */
55
+ maxScale?: number;
56
+ }
39
57
  //# sourceMappingURL=spinner.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"spinner.d.ts","sourceRoot":"","sources":["../../src/types/spinner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE3C;;GAEG;AACH,MAAM,WAAW,kBAAmB,SAAQ,eAAe;IACzD,+BAA+B;IAC/B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAiB,SAAQ,eAAe;IACvD,4BAA4B;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAiB,SAAQ,eAAe;IACvD,qBAAqB;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,uBAAuB;IACvB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAiB,SAAQ,eAAe;IACvD,qBAAqB;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAiB,SAAQ,eAAe;IACvD,kCAAkC;IAClC,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB"}
1
+ {"version":3,"file":"spinner.d.ts","sourceRoot":"","sources":["../../src/types/spinner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE3C;;GAEG;AACH,MAAM,WAAW,kBAAmB,SAAQ,eAAe;IACzD,+BAA+B;IAC/B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAiB,SAAQ,eAAe;IACvD,4BAA4B;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAiB,SAAQ,eAAe;IACvD,qBAAqB;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,uBAAuB;IACvB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAiB,SAAQ,eAAe;IACvD,qBAAqB;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAiB,SAAQ,eAAe;IACvD,kCAAkC;IAClC,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAiB,SAAQ,eAAe;IACvD,kCAAkC;IAClC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,gCAAgC;IAChC,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAkB,SAAQ,eAAe;IACxD,oCAAoC;IACpC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,iCAAiC;IACjC,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "premium-react-loaders",
3
- "version": "1.0.2",
3
+ "version": "1.1.0",
4
4
  "description": "Premium, production-ready loading components for React with TypeScript and Tailwind CSS",
5
5
  "author": "Ishan Karunaratne",
6
6
  "license": "MIT",