@lindle/linoardo 1.0.16 → 1.0.17

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 (96) hide show
  1. package/dist/ExpansionPanelItem-Bd6ZWGkR.d.cts +58 -0
  2. package/dist/ExpansionPanelItem-DOjgDeB6.d.ts +58 -0
  3. package/dist/button.cjs +206 -0
  4. package/dist/button.cjs.map +1 -0
  5. package/dist/button.d.cts +19 -0
  6. package/dist/button.d.ts +19 -0
  7. package/dist/button.js +4 -0
  8. package/dist/button.js.map +1 -0
  9. package/dist/chip.cjs +247 -0
  10. package/dist/chip.cjs.map +1 -0
  11. package/dist/chip.d.cts +368 -0
  12. package/dist/chip.d.ts +368 -0
  13. package/dist/chip.js +4 -0
  14. package/dist/chip.js.map +1 -0
  15. package/dist/chunk-32KFNI6K.js +114 -0
  16. package/dist/chunk-32KFNI6K.js.map +1 -0
  17. package/dist/chunk-3EGIRBQ3.js +100 -0
  18. package/dist/chunk-3EGIRBQ3.js.map +1 -0
  19. package/dist/chunk-5GY2JCBO.js +92 -0
  20. package/dist/chunk-5GY2JCBO.js.map +1 -0
  21. package/dist/chunk-7LLAWEDF.js +179 -0
  22. package/dist/chunk-7LLAWEDF.js.map +1 -0
  23. package/dist/chunk-E32P5AHO.js +125 -0
  24. package/dist/chunk-E32P5AHO.js.map +1 -0
  25. package/dist/chunk-GA6HSRN6.js +235 -0
  26. package/dist/chunk-GA6HSRN6.js.map +1 -0
  27. package/dist/chunk-IEILIKS2.js +8 -0
  28. package/dist/chunk-IEILIKS2.js.map +1 -0
  29. package/dist/chunk-PWK6MLZT.js +239 -0
  30. package/dist/chunk-PWK6MLZT.js.map +1 -0
  31. package/dist/chunk-TTDFAKOL.js +98 -0
  32. package/dist/chunk-TTDFAKOL.js.map +1 -0
  33. package/dist/chunk-U6NAIIDI.js +99 -0
  34. package/dist/chunk-U6NAIIDI.js.map +1 -0
  35. package/dist/chunk-XFPBICJG.js +127 -0
  36. package/dist/chunk-XFPBICJG.js.map +1 -0
  37. package/dist/dialog.cjs +121 -0
  38. package/dist/dialog.cjs.map +1 -0
  39. package/dist/dialog.d.cts +17 -0
  40. package/dist/dialog.d.ts +17 -0
  41. package/dist/dialog.js +3 -0
  42. package/dist/dialog.js.map +1 -0
  43. package/dist/expansion-panel/item.cjs +195 -0
  44. package/dist/expansion-panel/item.cjs.map +1 -0
  45. package/dist/expansion-panel/item.d.cts +3 -0
  46. package/dist/expansion-panel/item.d.ts +3 -0
  47. package/dist/expansion-panel/item.js +3 -0
  48. package/dist/expansion-panel/item.js.map +1 -0
  49. package/dist/expansion-panel.cjs +356 -0
  50. package/dist/expansion-panel.cjs.map +1 -0
  51. package/dist/expansion-panel.d.cts +8 -0
  52. package/dist/expansion-panel.d.ts +8 -0
  53. package/dist/expansion-panel.js +4 -0
  54. package/dist/expansion-panel.js.map +1 -0
  55. package/dist/global.types-E2uVLemv.d.cts +7 -0
  56. package/dist/global.types-E2uVLemv.d.ts +7 -0
  57. package/dist/index-Md3BuoGM.d.cts +32 -0
  58. package/dist/index-d_JuI06O.d.ts +32 -0
  59. package/dist/index.cjs +148 -144
  60. package/dist/index.cjs.map +1 -1
  61. package/dist/index.d.cts +12 -549
  62. package/dist/index.d.ts +12 -549
  63. package/dist/index.js +11 -1330
  64. package/dist/index.js.map +1 -1
  65. package/dist/input.cjs +106 -0
  66. package/dist/input.cjs.map +1 -0
  67. package/dist/input.d.cts +22 -0
  68. package/dist/input.d.ts +22 -0
  69. package/dist/input.js +4 -0
  70. package/dist/input.js.map +1 -0
  71. package/dist/list/item.cjs +149 -0
  72. package/dist/list/item.cjs.map +1 -0
  73. package/dist/list/item.d.cts +3 -0
  74. package/dist/list/item.d.ts +3 -0
  75. package/dist/list/item.js +3 -0
  76. package/dist/list/item.js.map +1 -0
  77. package/dist/list.cjs +235 -0
  78. package/dist/list.cjs.map +1 -0
  79. package/dist/list.d.cts +17 -0
  80. package/dist/list.d.ts +17 -0
  81. package/dist/list.js +4 -0
  82. package/dist/list.js.map +1 -0
  83. package/dist/menu.cjs +122 -0
  84. package/dist/menu.cjs.map +1 -0
  85. package/dist/menu.d.cts +20 -0
  86. package/dist/menu.d.ts +20 -0
  87. package/dist/menu.js +3 -0
  88. package/dist/menu.js.map +1 -0
  89. package/dist/styles.css +0 -24
  90. package/dist/tooltip.cjs +136 -0
  91. package/dist/tooltip.cjs.map +1 -0
  92. package/dist/tooltip.d.cts +19 -0
  93. package/dist/tooltip.d.ts +19 -0
  94. package/dist/tooltip.js +3 -0
  95. package/dist/tooltip.js.map +1 -0
  96. package/package.json +52 -2
@@ -0,0 +1,58 @@
1
+ import * as react from 'react';
2
+ import { P as Palette } from './global.types-E2uVLemv.cjs';
3
+
4
+ type ExpansionPanelValue = react.Key;
5
+ type ExpansionPanelVariant = 'elevated' | 'outlined' | 'tonal' | 'plain';
6
+ type ExpansionPanelDensity = 'compact' | 'default' | 'comfortable';
7
+ type ExpansionPanelRounded = 'none' | 'sm' | 'md' | 'lg' | 'xl';
8
+ type DivAttributes = Omit<react.HTMLAttributes<HTMLDivElement>, 'color' | 'value' | 'defaultValue' | 'onChange'>;
9
+ interface ExpansionPanelSharedProps extends DivAttributes {
10
+ variant?: ExpansionPanelVariant;
11
+ rounded?: ExpansionPanelRounded;
12
+ density?: ExpansionPanelDensity;
13
+ color?: Palette;
14
+ divider?: boolean;
15
+ }
16
+ interface ExpansionPanelSingleProps extends ExpansionPanelSharedProps {
17
+ multiple?: false;
18
+ value?: ExpansionPanelValue | null;
19
+ defaultValue?: ExpansionPanelValue | null;
20
+ onChange?: (value: ExpansionPanelValue | null) => void;
21
+ }
22
+ interface ExpansionPanelMultipleProps extends ExpansionPanelSharedProps {
23
+ multiple: true;
24
+ value?: ExpansionPanelValue[];
25
+ defaultValue?: ExpansionPanelValue[];
26
+ onChange?: (value: ExpansionPanelValue[]) => void;
27
+ }
28
+ type ExpansionPanelProps = ExpansionPanelSingleProps | ExpansionPanelMultipleProps;
29
+ interface ExpansionPanelContextValue {
30
+ expandedValues: ExpansionPanelValue[];
31
+ toggle: (value: ExpansionPanelValue, disabled?: boolean) => void;
32
+ density: ExpansionPanelDensity;
33
+ color: Palette;
34
+ divider: boolean;
35
+ rounded: ExpansionPanelRounded;
36
+ variant: ExpansionPanelVariant;
37
+ }
38
+ interface ExpansionPanelItemProps extends Omit<DivAttributes, 'title'> {
39
+ value?: ExpansionPanelValue;
40
+ title?: react.ReactNode;
41
+ subtitle?: react.ReactNode;
42
+ text?: react.ReactNode;
43
+ disabled?: boolean;
44
+ prepend?: react.ReactNode;
45
+ append?: react.ReactNode;
46
+ expandIcon?: react.ReactNode;
47
+ collapseIcon?: react.ReactNode;
48
+ hideToggleIcon?: boolean;
49
+ headerClassName?: string;
50
+ contentClassName?: string;
51
+ color?: Palette;
52
+ /** @internal */
53
+ __expansionPanelContext?: ExpansionPanelContextValue | null;
54
+ }
55
+
56
+ declare const ExpansionPanelItem: react.ForwardRefExoticComponent<ExpansionPanelItemProps & react.RefAttributes<HTMLDivElement>>;
57
+
58
+ export { ExpansionPanelItem as E, type ExpansionPanelItemProps as a, type ExpansionPanelProps as b, type ExpansionPanelValue as c, type ExpansionPanelVariant as d, type ExpansionPanelDensity as e, type ExpansionPanelRounded as f };
@@ -0,0 +1,58 @@
1
+ import * as react from 'react';
2
+ import { P as Palette } from './global.types-E2uVLemv.js';
3
+
4
+ type ExpansionPanelValue = react.Key;
5
+ type ExpansionPanelVariant = 'elevated' | 'outlined' | 'tonal' | 'plain';
6
+ type ExpansionPanelDensity = 'compact' | 'default' | 'comfortable';
7
+ type ExpansionPanelRounded = 'none' | 'sm' | 'md' | 'lg' | 'xl';
8
+ type DivAttributes = Omit<react.HTMLAttributes<HTMLDivElement>, 'color' | 'value' | 'defaultValue' | 'onChange'>;
9
+ interface ExpansionPanelSharedProps extends DivAttributes {
10
+ variant?: ExpansionPanelVariant;
11
+ rounded?: ExpansionPanelRounded;
12
+ density?: ExpansionPanelDensity;
13
+ color?: Palette;
14
+ divider?: boolean;
15
+ }
16
+ interface ExpansionPanelSingleProps extends ExpansionPanelSharedProps {
17
+ multiple?: false;
18
+ value?: ExpansionPanelValue | null;
19
+ defaultValue?: ExpansionPanelValue | null;
20
+ onChange?: (value: ExpansionPanelValue | null) => void;
21
+ }
22
+ interface ExpansionPanelMultipleProps extends ExpansionPanelSharedProps {
23
+ multiple: true;
24
+ value?: ExpansionPanelValue[];
25
+ defaultValue?: ExpansionPanelValue[];
26
+ onChange?: (value: ExpansionPanelValue[]) => void;
27
+ }
28
+ type ExpansionPanelProps = ExpansionPanelSingleProps | ExpansionPanelMultipleProps;
29
+ interface ExpansionPanelContextValue {
30
+ expandedValues: ExpansionPanelValue[];
31
+ toggle: (value: ExpansionPanelValue, disabled?: boolean) => void;
32
+ density: ExpansionPanelDensity;
33
+ color: Palette;
34
+ divider: boolean;
35
+ rounded: ExpansionPanelRounded;
36
+ variant: ExpansionPanelVariant;
37
+ }
38
+ interface ExpansionPanelItemProps extends Omit<DivAttributes, 'title'> {
39
+ value?: ExpansionPanelValue;
40
+ title?: react.ReactNode;
41
+ subtitle?: react.ReactNode;
42
+ text?: react.ReactNode;
43
+ disabled?: boolean;
44
+ prepend?: react.ReactNode;
45
+ append?: react.ReactNode;
46
+ expandIcon?: react.ReactNode;
47
+ collapseIcon?: react.ReactNode;
48
+ hideToggleIcon?: boolean;
49
+ headerClassName?: string;
50
+ contentClassName?: string;
51
+ color?: Palette;
52
+ /** @internal */
53
+ __expansionPanelContext?: ExpansionPanelContextValue | null;
54
+ }
55
+
56
+ declare const ExpansionPanelItem: react.ForwardRefExoticComponent<ExpansionPanelItemProps & react.RefAttributes<HTMLDivElement>>;
57
+
58
+ export { ExpansionPanelItem as E, type ExpansionPanelItemProps as a, type ExpansionPanelProps as b, type ExpansionPanelValue as c, type ExpansionPanelVariant as d, type ExpansionPanelDensity as e, type ExpansionPanelRounded as f };
@@ -0,0 +1,206 @@
1
+ 'use strict';
2
+
3
+ var React = require('react');
4
+ var tailwindMerge = require('tailwind-merge');
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+
7
+ function _interopNamespace(e) {
8
+ if (e && e.__esModule) return e;
9
+ var n = Object.create(null);
10
+ if (e) {
11
+ Object.keys(e).forEach(function (k) {
12
+ if (k !== 'default') {
13
+ var d = Object.getOwnPropertyDescriptor(e, k);
14
+ Object.defineProperty(n, k, d.get ? d : {
15
+ enumerable: true,
16
+ get: function () { return e[k]; }
17
+ });
18
+ }
19
+ });
20
+ }
21
+ n.default = e;
22
+ return Object.freeze(n);
23
+ }
24
+
25
+ var React__namespace = /*#__PURE__*/_interopNamespace(React);
26
+
27
+ // src/Containment/Button/index.tsx
28
+
29
+ // src/globals.ts
30
+ var iconBaseClasses = {
31
+ mdi: ["mdi"]
32
+ };
33
+ var base = "btn-base focus-visible:outline-none focus-visible:ring-2 rounded-lg transition-colors duration-200 font-medium disabled:opacity-50 disabled:cursor-not-allowed";
34
+ var blackAndWhiteVariantClass = "bg-white text-black border border-black focus-visible:ring-black/40 focus-visible:ring-offset-white";
35
+ var blackAndWhitePaletteClasses = {
36
+ solid: tailwindMerge.twMerge(blackAndWhiteVariantClass, "bg-black text-white"),
37
+ outline: blackAndWhiteVariantClass,
38
+ ghost: "bg-neutral-300 text-white",
39
+ text: blackAndWhiteVariantClass,
40
+ filled: "bg-black text-white",
41
+ underlined: tailwindMerge.twMerge(blackAndWhiteVariantClass, "b"),
42
+ rounded: blackAndWhiteVariantClass,
43
+ sharp: "bg-black text-white rounded-none"
44
+ };
45
+ var paletteVariantClasses = {
46
+ primary: {
47
+ solid: "bg-primary text-white hover:bg-primary/90 focus-visible:ring-primary",
48
+ sharp: "rounded-none bg-primary text-white hover:bg-primary/90 focus-visible:ring-primary",
49
+ outline: "border border-primary text-primary bg-white hover:bg-primary hover:text-white focus-visible:ring-primary",
50
+ ghost: "text-primary bg-primary/10 hover:bg-primary/20 focus-visible:ring-primary/40 border border-transparent",
51
+ text: "bg-transparent text-primary hover:bg-primary/10 focus-visible:ring-primary/30 underline-offset-2 border border-transparent",
52
+ filled: "bg-primary/15 text-primary border border-primary/30 hover:bg-primary/25 focus-visible:ring-primary/25",
53
+ underlined: "bg-transparent text-primary border border-transparent underline decoration-2 underline-offset-4 hover:bg-primary/5 focus-visible:ring-primary/25",
54
+ rounded: "rounded-full border border-primary/60 bg-primary/10 text-primary hover:bg-primary/20 focus-visible:ring-primary/25"
55
+ },
56
+ neutral: {
57
+ solid: "bg-gray-600 text-white hover:bg-gray-700 focus-visible:ring-gray-500",
58
+ sharp: "rounded-none bg-gray-600 text-white hover:bg-gray-700 focus-visible:ring-gray-500",
59
+ outline: "border border-gray-400 text-gray-700 bg-white hover:bg-gray-700 hover:text-white focus-visible:ring-gray-400",
60
+ ghost: "text-gray-700 bg-gray-100 hover:bg-gray-200 focus-visible:ring-gray-300 border border-transparent",
61
+ text: "bg-transparent text-gray-700 hover:bg-gray-100 focus-visible:ring-gray-200 underline-offset-2 border border-transparent",
62
+ filled: "bg-gray-200 text-gray-900 border border-gray-300 hover:bg-gray-300 focus-visible:ring-gray-300",
63
+ underlined: "bg-transparent text-gray-900 border border-transparent underline decoration-2 underline-offset-4 hover:bg-gray-100 focus-visible:ring-gray-300",
64
+ rounded: "rounded-full border border-gray-400 bg-white text-gray-800 hover:bg-gray-100 focus-visible:ring-gray-300"
65
+ },
66
+ info: {
67
+ solid: "bg-sky-500 text-white hover:bg-sky-600 focus-visible:ring-sky-400",
68
+ sharp: "rounded-none bg-sky-500 text-white hover:bg-sky-600 focus-visible:ring-sky-400",
69
+ outline: "border border-sky-500 text-sky-600 bg-white hover:bg-sky-500 hover:text-white focus-visible:ring-sky-400",
70
+ ghost: "text-sky-600 bg-sky-100 hover:bg-sky-200 focus-visible:ring-sky-300 border border-transparent",
71
+ text: "bg-transparent text-sky-600 hover:bg-sky-100 focus-visible:ring-sky-200 underline-offset-2 border border-transparent",
72
+ filled: "bg-sky-100 text-sky-700 border border-sky-200 hover:bg-sky-200 focus-visible:ring-sky-200",
73
+ underlined: "bg-transparent text-sky-600 border border-transparent underline decoration-2 underline-offset-4 hover:bg-sky-50 focus-visible:ring-sky-200",
74
+ rounded: "rounded-full border border-sky-500/70 bg-sky-50 text-sky-700 hover:bg-sky-100 focus-visible:ring-sky-200"
75
+ },
76
+ success: {
77
+ solid: "bg-emerald-500 text-white hover:bg-emerald-600 focus-visible:ring-emerald-400",
78
+ sharp: "rounded-none bg-emerald-500 text-white hover:bg-emerald-600 focus-visible:ring-emerald-400",
79
+ outline: "border border-emerald-500 text-emerald-600 bg-white hover:bg-emerald-500 hover:text-white focus-visible:ring-emerald-400",
80
+ ghost: "text-emerald-600 bg-emerald-100 hover:bg-emerald-200 focus-visible:ring-emerald-300 border border-transparent",
81
+ text: "bg-transparent text-emerald-600 hover:bg-emerald-100 focus-visible:ring-emerald-200 underline-offset-2 border border-transparent",
82
+ filled: "bg-emerald-100 text-emerald-700 border border-emerald-200 hover:bg-emerald-200 focus-visible:ring-emerald-200",
83
+ underlined: "bg-transparent text-emerald-600 border border-transparent underline decoration-2 underline-offset-4 hover:bg-emerald-50 focus-visible:ring-emerald-200",
84
+ rounded: "rounded-full border border-emerald-500/70 bg-emerald-50 text-emerald-700 hover:bg-emerald-100 focus-visible:ring-emerald-200"
85
+ },
86
+ warning: {
87
+ solid: "bg-amber-500 text-white hover:bg-amber-600 focus-visible:ring-amber-400",
88
+ sharp: "rounded-none bg-amber-500 text-white hover:bg-amber-600 focus-visible:ring-amber-400",
89
+ outline: "border border-amber-500 text-amber-600 bg-white hover:bg-amber-500 hover:text-white focus-visible:ring-amber-400",
90
+ ghost: "text-amber-600 bg-amber-100 hover:bg-amber-200 focus-visible:ring-amber-300 border border-transparent",
91
+ text: "bg-transparent text-amber-600 hover:bg-amber-100 focus-visible:ring-amber-200 underline-offset-2 border border-transparent",
92
+ filled: "bg-amber-100 text-amber-800 border border-amber-200 hover:bg-amber-200 focus-visible:ring-amber-200",
93
+ underlined: "bg-transparent text-amber-600 border border-transparent underline decoration-2 underline-offset-4 hover:bg-amber-50 focus-visible:ring-amber-200",
94
+ rounded: "rounded-full border border-amber-500/70 bg-amber-50 text-amber-700 hover:bg-amber-100 focus-visible:ring-amber-200"
95
+ },
96
+ danger: {
97
+ solid: "bg-red-500 text-white hover:bg-red-600 focus-visible:ring-red-400",
98
+ sharp: "rounded-none bg-red-500 text-white hover:bg-red-600 focus-visible:ring-red-400",
99
+ outline: "border border-red-500 text-red-600 bg-white hover:bg-red-500 hover:text-white focus-visible:ring-red-400",
100
+ ghost: "text-red-600 bg-red-100 hover:bg-red-200 focus-visible:ring-red-300 border border-transparent",
101
+ text: "bg-transparent text-red-600 hover:bg-red-100 focus-visible:ring-red-200 underline-offset-2 border border-transparent",
102
+ filled: "bg-red-100 text-red-700 border border-red-200 hover:bg-red-200 focus-visible:ring-red-200",
103
+ underlined: "bg-transparent text-red-600 border border-transparent underline decoration-2 underline-offset-4 hover:bg-red-50 focus-visible:ring-red-200",
104
+ rounded: "rounded-full border border-red-500/70 bg-red-50 text-red-700 hover:bg-red-100 focus-visible:ring-red-200"
105
+ },
106
+ surface: {
107
+ solid: "bg-white text-gray-900 border border-gray-200 hover:bg-gray-50 focus-visible:ring-gray-200",
108
+ sharp: "rounded-none bg-white text-gray-900 border border-gray-200 hover:bg-gray-50 focus-visible:ring-gray-200",
109
+ outline: "border border-gray-300 text-gray-900 bg-white hover:bg-gray-100 focus-visible:ring-gray-200",
110
+ ghost: "text-gray-900 bg-gray-100 hover:bg-gray-200 focus-visible:ring-gray-200 border border-transparent",
111
+ text: "bg-transparent text-gray-900 hover:bg-gray-100 focus-visible:ring-gray-200 underline-offset-2 border border-transparent",
112
+ filled: "bg-gray-50 text-gray-900 border border-gray-200 hover:bg-white focus-visible:ring-gray-200",
113
+ underlined: "bg-transparent text-gray-900 border border-transparent underline decoration-2 underline-offset-4 hover:bg-gray-100 focus-visible:ring-gray-200",
114
+ rounded: "rounded-full border border-gray-300 bg-white text-gray-900 hover:bg-gray-50 focus-visible:ring-gray-200"
115
+ },
116
+ bw: blackAndWhitePaletteClasses
117
+ };
118
+ var resolveVariantClass = (variant, palette) => {
119
+ const paletteVariants = paletteVariantClasses[palette] ?? paletteVariantClasses.primary;
120
+ return paletteVariants[variant] ?? paletteVariants.solid;
121
+ };
122
+ var resolveIconClassName = (icon) => {
123
+ if (!icon) {
124
+ return void 0;
125
+ }
126
+ if (typeof icon === "string") {
127
+ const trimmed = icon.trim();
128
+ if (!trimmed) {
129
+ return void 0;
130
+ }
131
+ if (trimmed.includes(" ")) {
132
+ return trimmed;
133
+ }
134
+ const normalized2 = trimmed.startsWith("mdi-") ? trimmed : `mdi-${trimmed}`;
135
+ return ["mdi", normalized2].join(" ");
136
+ }
137
+ const [library, providedName] = icon;
138
+ const normalizedLibrary = library.trim();
139
+ const baseClasses = iconBaseClasses[normalizedLibrary] ?? [normalizedLibrary];
140
+ const iconName = providedName.trim();
141
+ if (!iconName) {
142
+ return baseClasses.join(" ");
143
+ }
144
+ const normalized = iconName.startsWith("mdi-") ? iconName : `mdi-${iconName}`;
145
+ return Array.from(/* @__PURE__ */ new Set([...baseClasses, normalized])).join(" ");
146
+ };
147
+ var sizeClasses = {
148
+ "x-small": "px-2.5 py-1 text-xs",
149
+ small: "px-3 py-1.5 text-sm",
150
+ medium: "px-4 py-2 text-base",
151
+ large: "px-6 py-3 text-lg",
152
+ "x-large": "px-7 py-3.5 text-xl"
153
+ };
154
+ var Button = React__namespace.forwardRef(
155
+ ({
156
+ variant = "solid",
157
+ color = "primary",
158
+ size = "medium",
159
+ block = false,
160
+ loading = false,
161
+ loadingText,
162
+ icon,
163
+ className,
164
+ children,
165
+ disabled,
166
+ onClick,
167
+ ...rest
168
+ }, ref) => {
169
+ const variantClass = resolveVariantClass(variant, color);
170
+ const sizeClass = sizeClasses[size] ?? sizeClasses.medium;
171
+ const blockClass = block ? "w-full" : null;
172
+ const isDisabled = disabled || loading;
173
+ const cursor = onClick && !isDisabled ? "cursor-pointer" : "cursor-default";
174
+ const resolvedIconClass = resolveIconClassName(icon);
175
+ const shouldRenderIcon = Boolean(resolvedIconClass && !loading);
176
+ const isLoadingTextProvided = loadingText !== void 0 && loadingText !== null;
177
+ const content = loading && isLoadingTextProvided ? loadingText : children;
178
+ const hasDecorators = (loading || shouldRenderIcon) && Boolean(content);
179
+ const gapClass = hasDecorators ? "gap-2" : void 0;
180
+ const loadingIconClass = loading ? tailwindMerge.twMerge("mdi mdi-loading mdi-spin", "leading-none") : void 0;
181
+ const iconClassName = shouldRenderIcon ? tailwindMerge.twMerge("leading-none", resolvedIconClass) : void 0;
182
+ return /* @__PURE__ */ jsxRuntime.jsxs(
183
+ "button",
184
+ {
185
+ ...rest,
186
+ ref,
187
+ onClick,
188
+ disabled: isDisabled,
189
+ className: tailwindMerge.twMerge(base, cursor, variantClass, sizeClass, blockClass, gapClass, className),
190
+ "data-loading": loading || void 0,
191
+ "aria-busy": loading || void 0,
192
+ children: [
193
+ loading && /* @__PURE__ */ jsxRuntime.jsx("i", { className: loadingIconClass, "aria-hidden": true }),
194
+ iconClassName && /* @__PURE__ */ jsxRuntime.jsx("i", { className: iconClassName, "aria-hidden": true }),
195
+ content
196
+ ]
197
+ }
198
+ );
199
+ }
200
+ );
201
+ Button.displayName = "Button";
202
+ var Button_default = Button;
203
+
204
+ module.exports = Button_default;
205
+ //# sourceMappingURL=button.cjs.map
206
+ //# sourceMappingURL=button.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/globals.ts","../src/Containment/Button/states.button.ts","../src/Containment/Button/index.tsx"],"names":["twMerge","normalized","React","jsxs","jsx"],"mappings":"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","file":"button.cjs","sourcesContent":["export const iconBaseClasses = {\n mdi: ['mdi']\n} as const;\n","import { iconBaseClasses } from '@lindle/linoardo/globals';\nimport type { GlobalSize, Palette } from '@lindle/linoardo/global.types';\nimport type { ButtonProps, ButtonVariant } from './types.button';\nimport { twMerge } from 'tailwind-merge';\n\nexport const base =\n 'btn-base focus-visible:outline-none focus-visible:ring-2 rounded-lg transition-colors duration-200 font-medium disabled:opacity-50 disabled:cursor-not-allowed';\n\nconst blackAndWhiteVariantClass =\n 'bg-white text-black border border-black focus-visible:ring-black/40 focus-visible:ring-offset-white';\n\nconst blackAndWhitePaletteClasses = {\n solid: twMerge(blackAndWhiteVariantClass, 'bg-black text-white'),\n outline: blackAndWhiteVariantClass,\n ghost: 'bg-neutral-300 text-white',\n text: blackAndWhiteVariantClass,\n filled: 'bg-black text-white',\n underlined: twMerge(blackAndWhiteVariantClass, 'b'),\n rounded: blackAndWhiteVariantClass,\n sharp: 'bg-black text-white rounded-none'\n} satisfies Record<ButtonVariant, string>;\n\nconst paletteVariantClasses: Record<Palette, Record<ButtonVariant, string>> = {\n primary: {\n solid: 'bg-primary text-white hover:bg-primary/90 focus-visible:ring-primary',\n sharp: 'rounded-none bg-primary text-white hover:bg-primary/90 focus-visible:ring-primary',\n outline: 'border border-primary text-primary bg-white hover:bg-primary hover:text-white focus-visible:ring-primary',\n ghost: 'text-primary bg-primary/10 hover:bg-primary/20 focus-visible:ring-primary/40 border border-transparent',\n text: 'bg-transparent text-primary hover:bg-primary/10 focus-visible:ring-primary/30 underline-offset-2 border border-transparent',\n filled: 'bg-primary/15 text-primary border border-primary/30 hover:bg-primary/25 focus-visible:ring-primary/25',\n underlined:\n 'bg-transparent text-primary border border-transparent underline decoration-2 underline-offset-4 hover:bg-primary/5 focus-visible:ring-primary/25',\n rounded:\n 'rounded-full border border-primary/60 bg-primary/10 text-primary hover:bg-primary/20 focus-visible:ring-primary/25'\n },\n neutral: {\n solid: 'bg-gray-600 text-white hover:bg-gray-700 focus-visible:ring-gray-500',\n sharp: 'rounded-none bg-gray-600 text-white hover:bg-gray-700 focus-visible:ring-gray-500',\n outline:\n 'border border-gray-400 text-gray-700 bg-white hover:bg-gray-700 hover:text-white focus-visible:ring-gray-400',\n ghost: 'text-gray-700 bg-gray-100 hover:bg-gray-200 focus-visible:ring-gray-300 border border-transparent',\n text: 'bg-transparent text-gray-700 hover:bg-gray-100 focus-visible:ring-gray-200 underline-offset-2 border border-transparent',\n filled: 'bg-gray-200 text-gray-900 border border-gray-300 hover:bg-gray-300 focus-visible:ring-gray-300',\n underlined:\n 'bg-transparent text-gray-900 border border-transparent underline decoration-2 underline-offset-4 hover:bg-gray-100 focus-visible:ring-gray-300',\n rounded: 'rounded-full border border-gray-400 bg-white text-gray-800 hover:bg-gray-100 focus-visible:ring-gray-300'\n },\n info: {\n solid: 'bg-sky-500 text-white hover:bg-sky-600 focus-visible:ring-sky-400',\n sharp: 'rounded-none bg-sky-500 text-white hover:bg-sky-600 focus-visible:ring-sky-400',\n outline: 'border border-sky-500 text-sky-600 bg-white hover:bg-sky-500 hover:text-white focus-visible:ring-sky-400',\n ghost: 'text-sky-600 bg-sky-100 hover:bg-sky-200 focus-visible:ring-sky-300 border border-transparent',\n text: 'bg-transparent text-sky-600 hover:bg-sky-100 focus-visible:ring-sky-200 underline-offset-2 border border-transparent',\n filled: 'bg-sky-100 text-sky-700 border border-sky-200 hover:bg-sky-200 focus-visible:ring-sky-200',\n underlined:\n 'bg-transparent text-sky-600 border border-transparent underline decoration-2 underline-offset-4 hover:bg-sky-50 focus-visible:ring-sky-200',\n rounded: 'rounded-full border border-sky-500/70 bg-sky-50 text-sky-700 hover:bg-sky-100 focus-visible:ring-sky-200'\n },\n success: {\n solid: 'bg-emerald-500 text-white hover:bg-emerald-600 focus-visible:ring-emerald-400',\n sharp: 'rounded-none bg-emerald-500 text-white hover:bg-emerald-600 focus-visible:ring-emerald-400',\n outline:\n 'border border-emerald-500 text-emerald-600 bg-white hover:bg-emerald-500 hover:text-white focus-visible:ring-emerald-400',\n ghost:\n 'text-emerald-600 bg-emerald-100 hover:bg-emerald-200 focus-visible:ring-emerald-300 border border-transparent',\n text: 'bg-transparent text-emerald-600 hover:bg-emerald-100 focus-visible:ring-emerald-200 underline-offset-2 border border-transparent',\n filled:\n 'bg-emerald-100 text-emerald-700 border border-emerald-200 hover:bg-emerald-200 focus-visible:ring-emerald-200',\n underlined:\n 'bg-transparent text-emerald-600 border border-transparent underline decoration-2 underline-offset-4 hover:bg-emerald-50 focus-visible:ring-emerald-200',\n rounded:\n 'rounded-full border border-emerald-500/70 bg-emerald-50 text-emerald-700 hover:bg-emerald-100 focus-visible:ring-emerald-200'\n },\n warning: {\n solid: 'bg-amber-500 text-white hover:bg-amber-600 focus-visible:ring-amber-400',\n sharp: 'rounded-none bg-amber-500 text-white hover:bg-amber-600 focus-visible:ring-amber-400',\n outline:\n 'border border-amber-500 text-amber-600 bg-white hover:bg-amber-500 hover:text-white focus-visible:ring-amber-400',\n ghost: 'text-amber-600 bg-amber-100 hover:bg-amber-200 focus-visible:ring-amber-300 border border-transparent',\n text: 'bg-transparent text-amber-600 hover:bg-amber-100 focus-visible:ring-amber-200 underline-offset-2 border border-transparent',\n filled: 'bg-amber-100 text-amber-800 border border-amber-200 hover:bg-amber-200 focus-visible:ring-amber-200',\n underlined:\n 'bg-transparent text-amber-600 border border-transparent underline decoration-2 underline-offset-4 hover:bg-amber-50 focus-visible:ring-amber-200',\n rounded:\n 'rounded-full border border-amber-500/70 bg-amber-50 text-amber-700 hover:bg-amber-100 focus-visible:ring-amber-200'\n },\n danger: {\n solid: 'bg-red-500 text-white hover:bg-red-600 focus-visible:ring-red-400',\n sharp: 'rounded-none bg-red-500 text-white hover:bg-red-600 focus-visible:ring-red-400',\n outline: 'border border-red-500 text-red-600 bg-white hover:bg-red-500 hover:text-white focus-visible:ring-red-400',\n ghost: 'text-red-600 bg-red-100 hover:bg-red-200 focus-visible:ring-red-300 border border-transparent',\n text: 'bg-transparent text-red-600 hover:bg-red-100 focus-visible:ring-red-200 underline-offset-2 border border-transparent',\n filled: 'bg-red-100 text-red-700 border border-red-200 hover:bg-red-200 focus-visible:ring-red-200',\n underlined:\n 'bg-transparent text-red-600 border border-transparent underline decoration-2 underline-offset-4 hover:bg-red-50 focus-visible:ring-red-200',\n rounded: 'rounded-full border border-red-500/70 bg-red-50 text-red-700 hover:bg-red-100 focus-visible:ring-red-200'\n },\n surface: {\n solid: 'bg-white text-gray-900 border border-gray-200 hover:bg-gray-50 focus-visible:ring-gray-200',\n sharp: 'rounded-none bg-white text-gray-900 border border-gray-200 hover:bg-gray-50 focus-visible:ring-gray-200',\n outline: 'border border-gray-300 text-gray-900 bg-white hover:bg-gray-100 focus-visible:ring-gray-200',\n ghost: 'text-gray-900 bg-gray-100 hover:bg-gray-200 focus-visible:ring-gray-200 border border-transparent',\n text: 'bg-transparent text-gray-900 hover:bg-gray-100 focus-visible:ring-gray-200 underline-offset-2 border border-transparent',\n filled: 'bg-gray-50 text-gray-900 border border-gray-200 hover:bg-white focus-visible:ring-gray-200',\n underlined:\n 'bg-transparent text-gray-900 border border-transparent underline decoration-2 underline-offset-4 hover:bg-gray-100 focus-visible:ring-gray-200',\n rounded: 'rounded-full border border-gray-300 bg-white text-gray-900 hover:bg-gray-50 focus-visible:ring-gray-200'\n },\n bw: blackAndWhitePaletteClasses\n};\n\nexport const resolveVariantClass = (variant: ButtonVariant, palette: Palette) => {\n const paletteVariants = paletteVariantClasses[palette] ?? paletteVariantClasses.primary;\n return paletteVariants[variant] ?? paletteVariants.solid;\n};\n\nexport const resolveIconClassName = (icon?: ButtonProps['icon']) => {\n if (!icon) {\n return undefined;\n }\n\n if (typeof icon === 'string') {\n const trimmed = icon.trim();\n if (!trimmed) {\n return undefined;\n }\n\n if (trimmed.includes(' ')) {\n return trimmed;\n }\n\n const normalized = trimmed.startsWith('mdi-') ? trimmed : `mdi-${trimmed}`;\n return ['mdi', normalized].join(' ');\n }\n\n const [library, providedName] = icon;\n const normalizedLibrary = library.trim();\n const baseClasses = iconBaseClasses[normalizedLibrary as keyof typeof iconBaseClasses] ?? [normalizedLibrary];\n const iconName = providedName.trim();\n if (!iconName) {\n return baseClasses.join(' ');\n }\n\n const normalized = iconName.startsWith('mdi-') ? iconName : `mdi-${iconName}`;\n return Array.from(new Set([...baseClasses, normalized])).join(' ');\n};\n\nexport const sizeClasses = {\n 'x-small': 'px-2.5 py-1 text-xs',\n small: 'px-3 py-1.5 text-sm',\n medium: 'px-4 py-2 text-base',\n large: 'px-6 py-3 text-lg',\n 'x-large': 'px-7 py-3.5 text-xl'\n} satisfies Record<GlobalSize, string>;\n","import * as React from 'react';\nimport { twMerge } from 'tailwind-merge';\nimport { ButtonProps } from './types.button';\nimport { base, resolveIconClassName, resolveVariantClass, sizeClasses } from './states.button';\n\n/**\n * Containment button supporting variant, size, block layout and loading states.\n */\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n (\n {\n variant = 'solid',\n color = 'primary',\n size = 'medium',\n block = false,\n loading = false,\n loadingText,\n icon,\n className,\n children,\n disabled,\n onClick,\n ...rest\n },\n ref\n ) => {\n const variantClass = resolveVariantClass(variant, color);\n const sizeClass = sizeClasses[size] ?? sizeClasses.medium;\n const blockClass = block ? 'w-full' : null;\n const isDisabled = disabled || loading;\n const cursor = onClick && !isDisabled ? 'cursor-pointer' : 'cursor-default';\n const resolvedIconClass = resolveIconClassName(icon);\n const shouldRenderIcon = Boolean(resolvedIconClass && !loading);\n const isLoadingTextProvided = loadingText !== undefined && loadingText !== null;\n const content = loading && isLoadingTextProvided ? loadingText : children;\n const hasDecorators = (loading || shouldRenderIcon) && Boolean(content);\n const gapClass = hasDecorators ? 'gap-2' : undefined;\n const loadingIconClass = loading ? twMerge('mdi mdi-loading mdi-spin', 'leading-none') : undefined;\n const iconClassName = shouldRenderIcon ? twMerge('leading-none', resolvedIconClass) : undefined;\n\n return (\n <button\n {...rest}\n ref={ref}\n onClick={onClick}\n disabled={isDisabled}\n className={twMerge(base, cursor, variantClass, sizeClass, blockClass, gapClass, className)}\n data-loading={loading || undefined}\n aria-busy={loading || undefined}\n >\n {loading && <i className={loadingIconClass} aria-hidden />}\n {iconClassName && <i className={iconClassName} aria-hidden />}\n {content}\n </button>\n );\n }\n);\n\nButton.displayName = 'Button';\n\nexport default Button;\n"]}
@@ -0,0 +1,19 @@
1
+ import { G as GlobalVariant, P as Palette, a as GlobalSize, b as PropIcon } from './global.types-E2uVLemv.cjs';
2
+ import * as react from 'react';
3
+
4
+ type ButtonVariant = GlobalVariant;
5
+
6
+ /**
7
+ * Containment button supporting variant, size, block layout and loading states.
8
+ */
9
+ declare const Button: react.ForwardRefExoticComponent<react.ButtonHTMLAttributes<HTMLButtonElement> & {
10
+ variant?: ButtonVariant;
11
+ color?: Palette;
12
+ size?: GlobalSize;
13
+ block?: boolean;
14
+ loading?: boolean;
15
+ loadingText?: string;
16
+ icon?: PropIcon;
17
+ } & react.RefAttributes<HTMLButtonElement>>;
18
+
19
+ export { Button as default };
@@ -0,0 +1,19 @@
1
+ import { G as GlobalVariant, P as Palette, a as GlobalSize, b as PropIcon } from './global.types-E2uVLemv.js';
2
+ import * as react from 'react';
3
+
4
+ type ButtonVariant = GlobalVariant;
5
+
6
+ /**
7
+ * Containment button supporting variant, size, block layout and loading states.
8
+ */
9
+ declare const Button: react.ForwardRefExoticComponent<react.ButtonHTMLAttributes<HTMLButtonElement> & {
10
+ variant?: ButtonVariant;
11
+ color?: Palette;
12
+ size?: GlobalSize;
13
+ block?: boolean;
14
+ loading?: boolean;
15
+ loadingText?: string;
16
+ icon?: PropIcon;
17
+ } & react.RefAttributes<HTMLButtonElement>>;
18
+
19
+ export { Button as default };
package/dist/button.js ADDED
@@ -0,0 +1,4 @@
1
+ export { Button_default as default } from './chunk-7LLAWEDF.js';
2
+ import './chunk-IEILIKS2.js';
3
+ //# sourceMappingURL=button.js.map
4
+ //# sourceMappingURL=button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"button.js"}