@appcorp/shadcn 1.0.10

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 (78) hide show
  1. package/README.md +138 -0
  2. package/app/layout.d.ts +7 -0
  3. package/app/layout.js +18 -0
  4. package/app/page.d.ts +2 -0
  5. package/app/page.js +16 -0
  6. package/components/badge.d.ts +9 -0
  7. package/components/badge.js +82 -0
  8. package/components/button.d.ts +10 -0
  9. package/components/button.js +91 -0
  10. package/components/card.d.ts +9 -0
  11. package/components/card.js +94 -0
  12. package/components/carousel.d.ts +19 -0
  13. package/components/carousel.js +168 -0
  14. package/components/checkbox.d.ts +9 -0
  15. package/components/checkbox.js +87 -0
  16. package/components/combobox.d.ts +70 -0
  17. package/components/combobox.js +315 -0
  18. package/components/command.d.ts +18 -0
  19. package/components/command.js +115 -0
  20. package/components/context-menu.d.ts +25 -0
  21. package/components/context-menu.js +148 -0
  22. package/components/dialog.d.ts +15 -0
  23. package/components/dialog.js +118 -0
  24. package/components/drawer.d.ts +13 -0
  25. package/components/drawer.js +115 -0
  26. package/components/dropdown-menu.d.ts +25 -0
  27. package/components/dropdown-menu.js +148 -0
  28. package/components/enhanced-dropzone.d.ts +21 -0
  29. package/components/enhanced-dropzone.js +187 -0
  30. package/components/enhanced-table-footer-action.d.ts +35 -0
  31. package/components/enhanced-table-footer-action.js +110 -0
  32. package/components/enhanced-table-footer-page.d.ts +34 -0
  33. package/components/enhanced-table-footer-page.js +132 -0
  34. package/components/enhanced-table-footer-pagination.d.ts +38 -0
  35. package/components/enhanced-table-footer-pagination.js +116 -0
  36. package/components/enhanced-table-header-action.d.ts +7 -0
  37. package/components/enhanced-table-header-action.js +21 -0
  38. package/components/enhanced-table-header-search.d.ts +12 -0
  39. package/components/enhanced-table-header-search.js +17 -0
  40. package/components/enhanced-table.d.ts +87 -0
  41. package/components/enhanced-table.js +221 -0
  42. package/components/form.d.ts +24 -0
  43. package/components/form.js +125 -0
  44. package/components/input.d.ts +8 -0
  45. package/components/input.js +86 -0
  46. package/components/label.d.ts +7 -0
  47. package/components/label.js +68 -0
  48. package/components/popover.d.ts +7 -0
  49. package/components/popover.js +82 -0
  50. package/components/select.d.ts +15 -0
  51. package/components/select.js +127 -0
  52. package/components/separator.d.ts +4 -0
  53. package/components/separator.js +66 -0
  54. package/components/shadcn-io/color-picker/index.d.ts +43 -0
  55. package/components/shadcn-io/color-picker/index.js +304 -0
  56. package/components/shadcn-io/copy-button/index.d.ts +16 -0
  57. package/components/shadcn-io/copy-button/index.js +121 -0
  58. package/components/shadcn-io/dropzone/index.d.ts +19 -0
  59. package/components/shadcn-io/dropzone/index.js +131 -0
  60. package/components/shadcn-io/gantt/index.d.ts +145 -0
  61. package/components/shadcn-io/gantt/index.js +767 -0
  62. package/components/shadcn-io/table/index.d.ts +60 -0
  63. package/components/shadcn-io/table/index.js +138 -0
  64. package/components/sonner.d.ts +4 -0
  65. package/components/sonner.js +54 -0
  66. package/components/switch.d.ts +9 -0
  67. package/components/switch.js +89 -0
  68. package/components/table.d.ts +10 -0
  69. package/components/table.js +101 -0
  70. package/components/textarea.d.ts +8 -0
  71. package/components/textarea.js +86 -0
  72. package/lib/themes.d.ts +147 -0
  73. package/lib/themes.js +150 -0
  74. package/lib/toast-utils.d.ts +44 -0
  75. package/lib/toast-utils.js +212 -0
  76. package/lib/utils.d.ts +2 -0
  77. package/lib/utils.js +12 -0
  78. package/package.json +101 -0
@@ -0,0 +1,43 @@
1
+ import React from "react";
2
+ import Color from "color";
3
+ import { Slider } from "radix-ui";
4
+ import { type ComponentProps, type HTMLAttributes } from "react";
5
+ import { Button } from "../../button";
6
+ import { SelectTrigger } from "../../select";
7
+ interface ColorPickerContextValue {
8
+ hue: number;
9
+ saturation: number;
10
+ lightness: number;
11
+ alpha: number;
12
+ mode: string;
13
+ setHue: (hue: number) => void;
14
+ setSaturation: (saturation: number) => void;
15
+ setLightness: (lightness: number) => void;
16
+ setAlpha: (alpha: number) => void;
17
+ setMode: (mode: string) => void;
18
+ }
19
+ export declare const useColorPicker: () => ColorPickerContextValue;
20
+ export type ColorPickerProps = Omit<HTMLAttributes<HTMLDivElement>, "onChange"> & {
21
+ value?: Parameters<typeof Color>[0];
22
+ defaultValue?: Parameters<typeof Color>[0];
23
+ onChange?: (value: [number, number, number, number]) => void;
24
+ error?: string;
25
+ info?: string;
26
+ label?: string;
27
+ required?: boolean;
28
+ id?: string;
29
+ };
30
+ export declare const ColorPicker: ({ value, defaultValue, onChange, className, error, info, label, required, id, ...props }: ColorPickerProps) => React.JSX.Element;
31
+ export type ColorPickerSelectionProps = HTMLAttributes<HTMLDivElement>;
32
+ export declare const ColorPickerSelection: React.MemoExoticComponent<({ className, ...props }: ColorPickerSelectionProps) => React.JSX.Element>;
33
+ export type ColorPickerHueProps = ComponentProps<typeof Slider.Root>;
34
+ export declare const ColorPickerHue: ({ className, ...props }: ColorPickerHueProps) => React.JSX.Element;
35
+ export type ColorPickerAlphaProps = ComponentProps<typeof Slider.Root>;
36
+ export declare const ColorPickerAlpha: ({ className, ...props }: ColorPickerAlphaProps) => React.JSX.Element;
37
+ export type ColorPickerEyeDropperProps = ComponentProps<typeof Button>;
38
+ export declare const ColorPickerEyeDropper: ({ className, ...props }: ColorPickerEyeDropperProps) => React.JSX.Element;
39
+ export type ColorPickerOutputProps = ComponentProps<typeof SelectTrigger>;
40
+ export declare const ColorPickerOutput: ({ className, ...props }: ColorPickerOutputProps) => React.JSX.Element;
41
+ export type ColorPickerFormatProps = HTMLAttributes<HTMLDivElement>;
42
+ export declare const ColorPickerFormat: ({ className, ...props }: ColorPickerFormatProps) => React.JSX.Element | null;
43
+ export {};
@@ -0,0 +1,304 @@
1
+ "use client";
2
+ "use strict";
3
+ var __assign = (this && this.__assign) || function () {
4
+ __assign = Object.assign || function(t) {
5
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
6
+ s = arguments[i];
7
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
8
+ t[p] = s[p];
9
+ }
10
+ return t;
11
+ };
12
+ return __assign.apply(this, arguments);
13
+ };
14
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
15
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
16
+ return new (P || (P = Promise))(function (resolve, reject) {
17
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
18
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
19
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
20
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
21
+ });
22
+ };
23
+ var __generator = (this && this.__generator) || function (thisArg, body) {
24
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
25
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
26
+ function verb(n) { return function (v) { return step([n, v]); }; }
27
+ function step(op) {
28
+ if (f) throw new TypeError("Generator is already executing.");
29
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
30
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
31
+ if (y = 0, t) op = [op[0] & 2, t.value];
32
+ switch (op[0]) {
33
+ case 0: case 1: t = op; break;
34
+ case 4: _.label++; return { value: op[1], done: false };
35
+ case 5: _.label++; y = op[1]; op = [0]; continue;
36
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
37
+ default:
38
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
39
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
40
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
41
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
42
+ if (t[2]) _.ops.pop();
43
+ _.trys.pop(); continue;
44
+ }
45
+ op = body.call(thisArg, _);
46
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
47
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
48
+ }
49
+ };
50
+ var __rest = (this && this.__rest) || function (s, e) {
51
+ var t = {};
52
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
53
+ t[p] = s[p];
54
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
55
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
56
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
57
+ t[p[i]] = s[p[i]];
58
+ }
59
+ return t;
60
+ };
61
+ var __importDefault = (this && this.__importDefault) || function (mod) {
62
+ return (mod && mod.__esModule) ? mod : { "default": mod };
63
+ };
64
+ Object.defineProperty(exports, "__esModule", { value: true });
65
+ exports.ColorPickerFormat = exports.ColorPickerOutput = exports.ColorPickerEyeDropper = exports.ColorPickerAlpha = exports.ColorPickerHue = exports.ColorPickerSelection = exports.ColorPicker = exports.useColorPicker = void 0;
66
+ var react_1 = __importDefault(require("react"));
67
+ var color_1 = __importDefault(require("color"));
68
+ var lucide_react_1 = require("lucide-react");
69
+ var radix_ui_1 = require("radix-ui");
70
+ var react_2 = require("react");
71
+ var button_1 = require("../../button");
72
+ var input_1 = require("../../input");
73
+ var label_1 = require("../../label");
74
+ var select_1 = require("../../select");
75
+ var utils_1 = require("../../../lib/utils");
76
+ var ColorPickerContext = (0, react_2.createContext)(undefined);
77
+ var useColorPicker = function () {
78
+ var context = (0, react_2.useContext)(ColorPickerContext);
79
+ if (!context) {
80
+ throw new Error("useColorPicker must be used within a ColorPickerProvider");
81
+ }
82
+ return context;
83
+ };
84
+ exports.useColorPicker = useColorPicker;
85
+ var ColorPicker = function (_a) {
86
+ var value = _a.value, _b = _a.defaultValue, defaultValue = _b === void 0 ? "#000000" : _b, onChange = _a.onChange, className = _a.className, error = _a.error, info = _a.info, label = _a.label, required = _a.required, id = _a.id, props = __rest(_a, ["value", "defaultValue", "onChange", "className", "error", "info", "label", "required", "id"]);
87
+ var selectedColor = (0, color_1.default)(value);
88
+ var defaultColor = (0, color_1.default)(defaultValue);
89
+ var _c = (0, react_2.useState)(selectedColor.hue() || defaultColor.hue() || 0), hue = _c[0], setHue = _c[1];
90
+ var _d = (0, react_2.useState)(selectedColor.saturationl() || defaultColor.saturationl() || 100), saturation = _d[0], setSaturation = _d[1];
91
+ var _e = (0, react_2.useState)(selectedColor.lightness() || defaultColor.lightness() || 50), lightness = _e[0], setLightness = _e[1];
92
+ var _f = (0, react_2.useState)(selectedColor.alpha() * 100 || defaultColor.alpha() * 100), alpha = _f[0], setAlpha = _f[1];
93
+ var _g = (0, react_2.useState)("hex"), mode = _g[0], setMode = _g[1];
94
+ // Determine if there's an error (for styling)
95
+ var hasError = Boolean(error);
96
+ // Update color when controlled value changes
97
+ (0, react_2.useEffect)(function () {
98
+ if (value) {
99
+ var color = color_1.default.rgb(value).rgb().object();
100
+ setHue(color.r);
101
+ setSaturation(color.g);
102
+ setLightness(color.b);
103
+ setAlpha(color.a);
104
+ }
105
+ }, [value]);
106
+ // Notify parent of changes
107
+ (0, react_2.useEffect)(function () {
108
+ if (onChange) {
109
+ var color = color_1.default.hsl(hue, saturation, lightness).alpha(alpha / 100);
110
+ var rgba = color.rgb().array();
111
+ onChange([rgba[0], rgba[1], rgba[2], alpha / 100]);
112
+ }
113
+ }, [hue, saturation, lightness, alpha, onChange]);
114
+ var colorPickerElement = (react_1.default.createElement(ColorPickerContext.Provider, { value: {
115
+ hue: hue,
116
+ saturation: saturation,
117
+ lightness: lightness,
118
+ alpha: alpha,
119
+ mode: mode,
120
+ setHue: setHue,
121
+ setSaturation: setSaturation,
122
+ setLightness: setLightness,
123
+ setAlpha: setAlpha,
124
+ setMode: setMode,
125
+ } },
126
+ react_1.default.createElement("div", __assign({ id: id, className: (0, utils_1.cn)("flex size-full flex-col gap-4",
127
+ // Error state styling
128
+ hasError && "border-destructive", className), "aria-invalid": hasError }, props))));
129
+ // If label is provided, render the complete color picker with label structure
130
+ if (label) {
131
+ return (react_1.default.createElement("div", { className: "w-full space-y-2" },
132
+ react_1.default.createElement(label_1.Label, { htmlFor: id, required: required }, label),
133
+ colorPickerElement,
134
+ (error || info) && (react_1.default.createElement("div", null, error ? (react_1.default.createElement("p", { className: "text-xs text-destructive" }, error)) : info ? (react_1.default.createElement("p", { className: "text-xs text-blue-600 dark:text-blue-400" }, info)) : null))));
135
+ }
136
+ // If no label, render just the color picker with messages (backward compatibility)
137
+ return (react_1.default.createElement("div", { className: "w-full" },
138
+ colorPickerElement,
139
+ (error || info) && (react_1.default.createElement("div", null, error ? (react_1.default.createElement("p", { className: "text-xs text-destructive" }, error)) : info ? (react_1.default.createElement("p", { className: "text-xs text-blue-600 dark:text-blue-400" }, info)) : null))));
140
+ };
141
+ exports.ColorPicker = ColorPicker;
142
+ exports.ColorPickerSelection = (0, react_2.memo)(function (_a) {
143
+ var className = _a.className, props = __rest(_a, ["className"]);
144
+ var containerRef = (0, react_2.useRef)(null);
145
+ var _b = (0, react_2.useState)(false), isDragging = _b[0], setIsDragging = _b[1];
146
+ var _c = (0, react_2.useState)(0), positionX = _c[0], setPositionX = _c[1];
147
+ var _d = (0, react_2.useState)(0), positionY = _d[0], setPositionY = _d[1];
148
+ var _e = (0, exports.useColorPicker)(), hue = _e.hue, setSaturation = _e.setSaturation, setLightness = _e.setLightness;
149
+ var backgroundGradient = (0, react_2.useMemo)(function () {
150
+ return "linear-gradient(0deg, rgba(0,0,0,1), rgba(0,0,0,0)),\n linear-gradient(90deg, rgba(255,255,255,1), rgba(255,255,255,0)),\n hsl(".concat(hue, ", 100%, 50%)");
151
+ }, [hue]);
152
+ var handlePointerMove = (0, react_2.useCallback)(function (event) {
153
+ if (!(isDragging && containerRef.current)) {
154
+ return;
155
+ }
156
+ var rect = containerRef.current.getBoundingClientRect();
157
+ var x = Math.max(0, Math.min(1, (event.clientX - rect.left) / rect.width));
158
+ var y = Math.max(0, Math.min(1, (event.clientY - rect.top) / rect.height));
159
+ setPositionX(x);
160
+ setPositionY(y);
161
+ setSaturation(x * 100);
162
+ var topLightness = x < 0.01 ? 100 : 50 + 50 * (1 - x);
163
+ var lightness = topLightness * (1 - y);
164
+ setLightness(lightness);
165
+ }, [isDragging, setSaturation, setLightness]);
166
+ (0, react_2.useEffect)(function () {
167
+ var handlePointerUp = function () { return setIsDragging(false); };
168
+ if (isDragging) {
169
+ window.addEventListener("pointermove", handlePointerMove);
170
+ window.addEventListener("pointerup", handlePointerUp);
171
+ }
172
+ return function () {
173
+ window.removeEventListener("pointermove", handlePointerMove);
174
+ window.removeEventListener("pointerup", handlePointerUp);
175
+ };
176
+ }, [isDragging, handlePointerMove]);
177
+ return (react_1.default.createElement("div", __assign({ className: (0, utils_1.cn)("relative size-full cursor-crosshair rounded", className), onPointerDown: function (e) {
178
+ e.preventDefault();
179
+ setIsDragging(true);
180
+ handlePointerMove(e.nativeEvent);
181
+ }, ref: containerRef, style: {
182
+ background: backgroundGradient,
183
+ } }, props),
184
+ react_1.default.createElement("div", { className: "-translate-x-1/2 -translate-y-1/2 pointer-events-none absolute h-4 w-4 rounded-full border-2 border-white", style: {
185
+ left: "".concat(positionX * 100, "%"),
186
+ top: "".concat(positionY * 100, "%"),
187
+ boxShadow: "0 0 0 1px rgba(0,0,0,0.5)",
188
+ } })));
189
+ });
190
+ exports.ColorPickerSelection.displayName = "ColorPickerSelection";
191
+ var ColorPickerHue = function (_a) {
192
+ var className = _a.className, props = __rest(_a, ["className"]);
193
+ var _b = (0, exports.useColorPicker)(), hue = _b.hue, setHue = _b.setHue;
194
+ return (react_1.default.createElement(radix_ui_1.Slider.Root, __assign({ className: (0, utils_1.cn)("relative flex h-4 w-full touch-none", className), max: 360, onValueChange: function (_a) {
195
+ var hue = _a[0];
196
+ return setHue(hue);
197
+ }, step: 1, value: [hue] }, props),
198
+ react_1.default.createElement(radix_ui_1.Slider.Track, { className: "relative my-0.5 h-3 w-full grow rounded-full bg-[linear-gradient(90deg,#FF0000,#FFFF00,#00FF00,#00FFFF,#0000FF,#FF00FF,#FF0000)]" },
199
+ react_1.default.createElement(radix_ui_1.Slider.Range, { className: "absolute h-full" })),
200
+ react_1.default.createElement(radix_ui_1.Slider.Thumb, { className: "block h-4 w-4 rounded-full border border-primary/50 bg-background shadow transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50" })));
201
+ };
202
+ exports.ColorPickerHue = ColorPickerHue;
203
+ var ColorPickerAlpha = function (_a) {
204
+ var className = _a.className, props = __rest(_a, ["className"]);
205
+ var _b = (0, exports.useColorPicker)(), alpha = _b.alpha, setAlpha = _b.setAlpha;
206
+ return (react_1.default.createElement(radix_ui_1.Slider.Root, __assign({ className: (0, utils_1.cn)("relative flex h-4 w-full touch-none", className), max: 100, onValueChange: function (_a) {
207
+ var alpha = _a[0];
208
+ return setAlpha(alpha);
209
+ }, step: 1, value: [alpha] }, props),
210
+ react_1.default.createElement(radix_ui_1.Slider.Track, { className: "relative my-0.5 h-3 w-full grow rounded-full", style: {
211
+ background: 'url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAMUlEQVQ4T2NkYGAQYcAP3uCTZhw1gGGYhAGBZIA/nYDCgBDAm9BGDWAAJyRCgLaBCAAgXwixzAS0pgAAAABJRU5ErkJggg==") left center',
212
+ } },
213
+ react_1.default.createElement("div", { className: "absolute inset-0 rounded-full bg-gradient-to-r from-transparent to-black/50" }),
214
+ react_1.default.createElement(radix_ui_1.Slider.Range, { className: "absolute h-full rounded-full bg-transparent" })),
215
+ react_1.default.createElement(radix_ui_1.Slider.Thumb, { className: "block h-4 w-4 rounded-full border border-primary/50 bg-background shadow transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50" })));
216
+ };
217
+ exports.ColorPickerAlpha = ColorPickerAlpha;
218
+ var ColorPickerEyeDropper = function (_a) {
219
+ var className = _a.className, props = __rest(_a, ["className"]);
220
+ var _b = (0, exports.useColorPicker)(), setHue = _b.setHue, setSaturation = _b.setSaturation, setLightness = _b.setLightness, setAlpha = _b.setAlpha;
221
+ var handleEyeDropper = function () { return __awaiter(void 0, void 0, void 0, function () {
222
+ var eyeDropper, result, color, _a, h, s, l, error_1;
223
+ return __generator(this, function (_b) {
224
+ switch (_b.label) {
225
+ case 0:
226
+ _b.trys.push([0, 2, , 3]);
227
+ eyeDropper = new EyeDropper();
228
+ return [4 /*yield*/, eyeDropper.open()];
229
+ case 1:
230
+ result = _b.sent();
231
+ color = (0, color_1.default)(result.sRGBHex);
232
+ _a = color.hsl().array(), h = _a[0], s = _a[1], l = _a[2];
233
+ setHue(h);
234
+ setSaturation(s);
235
+ setLightness(l);
236
+ setAlpha(100);
237
+ return [3 /*break*/, 3];
238
+ case 2:
239
+ error_1 = _b.sent();
240
+ console.error("EyeDropper failed:", error_1);
241
+ return [3 /*break*/, 3];
242
+ case 3: return [2 /*return*/];
243
+ }
244
+ });
245
+ }); };
246
+ return (react_1.default.createElement(button_1.Button, __assign({ className: (0, utils_1.cn)("shrink-0 text-muted-foreground", className), onClick: handleEyeDropper, size: "icon", variant: "outline", type: "button" }, props),
247
+ react_1.default.createElement(lucide_react_1.PipetteIcon, { size: 16 })));
248
+ };
249
+ exports.ColorPickerEyeDropper = ColorPickerEyeDropper;
250
+ var formats = ["hex", "rgb", "css", "hsl"];
251
+ var ColorPickerOutput = function (_a) {
252
+ var className = _a.className, props = __rest(_a, ["className"]);
253
+ var _b = (0, exports.useColorPicker)(), mode = _b.mode, setMode = _b.setMode;
254
+ return (react_1.default.createElement(select_1.Select, { onValueChange: setMode, value: mode },
255
+ react_1.default.createElement(select_1.SelectTrigger, __assign({ className: (0, utils_1.cn)("h-8 w-20 shrink-0 text-xs", className) }, props),
256
+ react_1.default.createElement(select_1.SelectValue, { placeholder: "Mode" })),
257
+ react_1.default.createElement(select_1.SelectContent, null, formats.map(function (format) { return (react_1.default.createElement(select_1.SelectItem, { className: "text-xs", key: format, value: format }, format.toUpperCase())); }))));
258
+ };
259
+ exports.ColorPickerOutput = ColorPickerOutput;
260
+ var PercentageInput = function (_a) {
261
+ var className = _a.className, props = __rest(_a, ["className"]);
262
+ return (react_1.default.createElement("div", { className: "relative" },
263
+ react_1.default.createElement(input_1.Input, __assign({ readOnly: true, type: "text" }, props, { className: (0, utils_1.cn)("h-8 w-[3.25rem] rounded-l-none bg-secondary px-2 text-xs shadow-none", className) })),
264
+ react_1.default.createElement("span", { className: "-translate-y-1/2 absolute top-1/2 right-2 text-muted-foreground text-xs" }, "%")));
265
+ };
266
+ var ColorPickerFormat = function (_a) {
267
+ var className = _a.className, props = __rest(_a, ["className"]);
268
+ var _b = (0, exports.useColorPicker)(), hue = _b.hue, saturation = _b.saturation, lightness = _b.lightness, alpha = _b.alpha, mode = _b.mode;
269
+ var color = color_1.default.hsl(hue, saturation, lightness, alpha / 100);
270
+ if (mode === "hex") {
271
+ var hex = color.hex();
272
+ return (react_1.default.createElement("div", __assign({ className: (0, utils_1.cn)("-space-x-px relative flex w-full items-center rounded-md shadow-sm", className) }, props),
273
+ react_1.default.createElement(input_1.Input, { className: "h-8 rounded-r-none bg-secondary px-2 text-xs shadow-none", readOnly: true, type: "text", value: hex }),
274
+ react_1.default.createElement(PercentageInput, { value: alpha })));
275
+ }
276
+ if (mode === "rgb") {
277
+ var rgb = color
278
+ .rgb()
279
+ .array()
280
+ .map(function (value) { return Math.round(value); });
281
+ return (react_1.default.createElement("div", __assign({ className: (0, utils_1.cn)("-space-x-px flex items-center rounded-md shadow-sm", className) }, props),
282
+ rgb.map(function (value, index) { return (react_1.default.createElement(input_1.Input, { className: (0, utils_1.cn)("h-8 rounded-r-none bg-secondary px-2 text-xs shadow-none", index && "rounded-l-none", className), key: index, readOnly: true, type: "text", value: value })); }),
283
+ react_1.default.createElement(PercentageInput, { value: alpha })));
284
+ }
285
+ if (mode === "css") {
286
+ var rgb = color
287
+ .rgb()
288
+ .array()
289
+ .map(function (value) { return Math.round(value); });
290
+ return (react_1.default.createElement("div", __assign({ className: (0, utils_1.cn)("w-full rounded-md shadow-sm", className) }, props),
291
+ react_1.default.createElement(input_1.Input, __assign({ className: "h-8 w-full bg-secondary px-2 text-xs shadow-none", readOnly: true, type: "text", value: "rgba(".concat(rgb.join(", "), ", ").concat(alpha, "%)") }, props))));
292
+ }
293
+ if (mode === "hsl") {
294
+ var hsl = color
295
+ .hsl()
296
+ .array()
297
+ .map(function (value) { return Math.round(value); });
298
+ return (react_1.default.createElement("div", __assign({ className: (0, utils_1.cn)("-space-x-px flex items-center rounded-md shadow-sm", className) }, props),
299
+ hsl.map(function (value, index) { return (react_1.default.createElement(input_1.Input, { className: (0, utils_1.cn)("h-8 rounded-r-none bg-secondary px-2 text-xs shadow-none", index && "rounded-l-none", className), key: index, readOnly: true, type: "text", value: value })); }),
300
+ react_1.default.createElement(PercentageInput, { value: alpha })));
301
+ }
302
+ return null;
303
+ };
304
+ exports.ColorPickerFormat = ColorPickerFormat;
@@ -0,0 +1,16 @@
1
+ import * as React from "react";
2
+ import { HTMLMotionProps } from "motion/react";
3
+ import { type VariantProps } from "class-variance-authority";
4
+ declare const buttonVariants: (props?: ({
5
+ variant?: "default" | "secondary" | "destructive" | "outline" | "ghost" | "muted" | null | undefined;
6
+ size?: "default" | "sm" | "lg" | "md" | null | undefined;
7
+ } & import("class-variance-authority/dist/types").ClassProp) | undefined) => string;
8
+ type CopyButtonProps = Omit<HTMLMotionProps<"button">, "children" | "onCopy"> & VariantProps<typeof buttonVariants> & {
9
+ content?: string;
10
+ delay?: number;
11
+ onCopy?: (content: string) => void;
12
+ isCopied?: boolean;
13
+ onCopyChange?: (isCopied: boolean) => void;
14
+ };
15
+ declare function CopyButton({ content, className, size, variant, delay, onClick, onCopy, isCopied, onCopyChange, ...props }: CopyButtonProps): React.JSX.Element;
16
+ export { CopyButton, buttonVariants, type CopyButtonProps };
@@ -0,0 +1,121 @@
1
+ "use client";
2
+ "use strict";
3
+ var __assign = (this && this.__assign) || function () {
4
+ __assign = Object.assign || function(t) {
5
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
6
+ s = arguments[i];
7
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
8
+ t[p] = s[p];
9
+ }
10
+ return t;
11
+ };
12
+ return __assign.apply(this, arguments);
13
+ };
14
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
15
+ if (k2 === undefined) k2 = k;
16
+ var desc = Object.getOwnPropertyDescriptor(m, k);
17
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
18
+ desc = { enumerable: true, get: function() { return m[k]; } };
19
+ }
20
+ Object.defineProperty(o, k2, desc);
21
+ }) : (function(o, m, k, k2) {
22
+ if (k2 === undefined) k2 = k;
23
+ o[k2] = m[k];
24
+ }));
25
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
26
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
27
+ }) : function(o, v) {
28
+ o["default"] = v;
29
+ });
30
+ var __importStar = (this && this.__importStar) || (function () {
31
+ var ownKeys = function(o) {
32
+ ownKeys = Object.getOwnPropertyNames || function (o) {
33
+ var ar = [];
34
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
35
+ return ar;
36
+ };
37
+ return ownKeys(o);
38
+ };
39
+ return function (mod) {
40
+ if (mod && mod.__esModule) return mod;
41
+ var result = {};
42
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
43
+ __setModuleDefault(result, mod);
44
+ return result;
45
+ };
46
+ })();
47
+ var __rest = (this && this.__rest) || function (s, e) {
48
+ var t = {};
49
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
50
+ t[p] = s[p];
51
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
52
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
53
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
54
+ t[p[i]] = s[p[i]];
55
+ }
56
+ return t;
57
+ };
58
+ Object.defineProperty(exports, "__esModule", { value: true });
59
+ exports.buttonVariants = void 0;
60
+ exports.CopyButton = CopyButton;
61
+ var React = __importStar(require("react"));
62
+ var react_1 = require("motion/react");
63
+ var lucide_react_1 = require("lucide-react");
64
+ var class_variance_authority_1 = require("class-variance-authority");
65
+ var utils_1 = require("../../../lib/utils");
66
+ var buttonVariants = (0, class_variance_authority_1.cva)("inline-flex items-center justify-center cursor-pointer rounded-md transition-colors disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none shrink-0 [&_svg]:shrink-0 outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive", {
67
+ variants: {
68
+ variant: {
69
+ default: "bg-primary text-primary-foreground shadow-xs hover:bg-primary/90",
70
+ muted: "bg-muted text-muted-foreground",
71
+ destructive: "bg-destructive text-white shadow-xs hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60",
72
+ outline: "border bg-background shadow-xs hover:bg-accent hover:text-accent-foreground dark:bg-input/30 dark:border-input dark:hover:bg-input/50",
73
+ secondary: "bg-secondary text-secondary-foreground shadow-xs hover:bg-secondary/80",
74
+ ghost: "hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50",
75
+ },
76
+ size: {
77
+ default: "size-8 rounded-lg [&_svg]:size-4",
78
+ sm: "size-6 [&_svg]:size-3",
79
+ md: "size-10 rounded-lg [&_svg]:size-5",
80
+ lg: "size-12 rounded-xl [&_svg]:size-6",
81
+ },
82
+ },
83
+ defaultVariants: {
84
+ variant: "default",
85
+ size: "default",
86
+ },
87
+ });
88
+ exports.buttonVariants = buttonVariants;
89
+ function CopyButton(_a) {
90
+ var content = _a.content, className = _a.className, size = _a.size, variant = _a.variant, _b = _a.delay, delay = _b === void 0 ? 3000 : _b, onClick = _a.onClick, onCopy = _a.onCopy, isCopied = _a.isCopied, onCopyChange = _a.onCopyChange, props = __rest(_a, ["content", "className", "size", "variant", "delay", "onClick", "onCopy", "isCopied", "onCopyChange"]);
91
+ var _c = React.useState(isCopied !== null && isCopied !== void 0 ? isCopied : false), localIsCopied = _c[0], setLocalIsCopied = _c[1];
92
+ var Icon = localIsCopied ? lucide_react_1.CheckIcon : lucide_react_1.CopyIcon;
93
+ React.useEffect(function () {
94
+ setLocalIsCopied(isCopied !== null && isCopied !== void 0 ? isCopied : false);
95
+ }, [isCopied]);
96
+ var handleIsCopied = React.useCallback(function (isCopied) {
97
+ setLocalIsCopied(isCopied);
98
+ onCopyChange === null || onCopyChange === void 0 ? void 0 : onCopyChange(isCopied);
99
+ }, [onCopyChange]);
100
+ var handleCopy = React.useCallback(function (e) {
101
+ if (isCopied)
102
+ return;
103
+ if (content) {
104
+ navigator.clipboard
105
+ .writeText(content)
106
+ .then(function () {
107
+ handleIsCopied(true);
108
+ setTimeout(function () { return handleIsCopied(false); }, delay);
109
+ onCopy === null || onCopy === void 0 ? void 0 : onCopy(content);
110
+ })
111
+ .catch(function (error) {
112
+ console.error("Error copying command", error);
113
+ });
114
+ }
115
+ onClick === null || onClick === void 0 ? void 0 : onClick(e);
116
+ }, [isCopied, content, delay, onClick, onCopy, handleIsCopied]);
117
+ return (React.createElement(react_1.motion.button, __assign({ "data-slot": "copy-button", whileHover: { scale: 1.05 }, whileTap: { scale: 0.95 }, className: (0, utils_1.cn)(buttonVariants({ variant: variant, size: size }), className), onClick: handleCopy }, props),
118
+ React.createElement(react_1.AnimatePresence, { mode: "wait" },
119
+ React.createElement(react_1.motion.span, { key: localIsCopied ? "check" : "copy", "data-slot": "copy-button-icon", initial: { scale: 0 }, animate: { scale: 1 }, exit: { scale: 0 }, transition: { duration: 0.15 } },
120
+ React.createElement(Icon, null)))));
121
+ }
@@ -0,0 +1,19 @@
1
+ import React, { ReactNode } from "react";
2
+ import type { DropEvent, DropzoneOptions, FileRejection } from "react-dropzone";
3
+ export type DropzoneProps = Omit<DropzoneOptions, "onDrop"> & {
4
+ src?: File[];
5
+ className?: string;
6
+ onDrop?: (acceptedFiles: File[], fileRejections: FileRejection[], event: DropEvent) => void;
7
+ children?: ReactNode;
8
+ };
9
+ export declare const Dropzone: ({ accept, maxFiles, maxSize, minSize, onDrop, onError, disabled, src, className, children, ...props }: DropzoneProps) => React.JSX.Element;
10
+ export type DropzoneContentProps = {
11
+ children?: ReactNode;
12
+ className?: string;
13
+ };
14
+ export declare const DropzoneContent: ({ children, className, }: DropzoneContentProps) => string | number | bigint | true | Iterable<React.ReactNode> | Promise<string | number | bigint | boolean | React.ReactPortal | React.ReactElement<unknown, string | React.JSXElementConstructor<any>> | Iterable<React.ReactNode> | null | undefined> | React.JSX.Element | null;
15
+ export type DropzoneEmptyStateProps = {
16
+ children?: ReactNode;
17
+ className?: string;
18
+ };
19
+ export declare const DropzoneEmptyState: ({ children, className, }: DropzoneEmptyStateProps) => string | number | bigint | true | Iterable<React.ReactNode> | Promise<string | number | bigint | boolean | React.ReactPortal | React.ReactElement<unknown, string | React.JSXElementConstructor<any>> | Iterable<React.ReactNode> | null | undefined> | React.JSX.Element | null;
@@ -0,0 +1,131 @@
1
+ "use client";
2
+ "use strict";
3
+ var __assign = (this && this.__assign) || function () {
4
+ __assign = Object.assign || function(t) {
5
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
6
+ s = arguments[i];
7
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
8
+ t[p] = s[p];
9
+ }
10
+ return t;
11
+ };
12
+ return __assign.apply(this, arguments);
13
+ };
14
+ var __rest = (this && this.__rest) || function (s, e) {
15
+ var t = {};
16
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
17
+ t[p] = s[p];
18
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
19
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
20
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
21
+ t[p[i]] = s[p[i]];
22
+ }
23
+ return t;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.DropzoneEmptyState = exports.DropzoneContent = exports.Dropzone = void 0;
30
+ var lucide_react_1 = require("lucide-react");
31
+ var react_1 = __importDefault(require("react"));
32
+ var react_2 = require("react");
33
+ var react_dropzone_1 = require("react-dropzone");
34
+ var button_1 = require("../../button");
35
+ var utils_1 = require("../../../lib/utils");
36
+ var renderBytes = function (bytes) {
37
+ var units = ["B", "KB", "MB", "GB", "TB", "PB"];
38
+ var size = bytes;
39
+ var unitIndex = 0;
40
+ while (size >= 1024 && unitIndex < units.length - 1) {
41
+ size /= 1024;
42
+ unitIndex++;
43
+ }
44
+ return "".concat(size.toFixed(2)).concat(units[unitIndex]);
45
+ };
46
+ var DropzoneContext = (0, react_2.createContext)(undefined);
47
+ var Dropzone = function (_a) {
48
+ var accept = _a.accept, _b = _a.maxFiles, maxFiles = _b === void 0 ? 1 : _b, maxSize = _a.maxSize, minSize = _a.minSize, onDrop = _a.onDrop, onError = _a.onError, disabled = _a.disabled, src = _a.src, className = _a.className, children = _a.children, props = __rest(_a, ["accept", "maxFiles", "maxSize", "minSize", "onDrop", "onError", "disabled", "src", "className", "children"]);
49
+ var _c = (0, react_dropzone_1.useDropzone)(__assign({ accept: accept, maxFiles: maxFiles, maxSize: maxSize, minSize: minSize, onError: onError, disabled: disabled, onDrop: function (acceptedFiles, fileRejections, event) {
50
+ var _a, _b;
51
+ if (fileRejections.length > 0) {
52
+ var message = (_b = (_a = fileRejections.at(0)) === null || _a === void 0 ? void 0 : _a.errors.at(0)) === null || _b === void 0 ? void 0 : _b.message;
53
+ onError === null || onError === void 0 ? void 0 : onError(new Error(message));
54
+ return;
55
+ }
56
+ onDrop === null || onDrop === void 0 ? void 0 : onDrop(acceptedFiles, fileRejections, event);
57
+ } }, props)), getRootProps = _c.getRootProps, getInputProps = _c.getInputProps, isDragActive = _c.isDragActive;
58
+ return (react_1.default.createElement(DropzoneContext.Provider, { key: JSON.stringify(src), value: { src: src, accept: accept, maxSize: maxSize, minSize: minSize, maxFiles: maxFiles } },
59
+ react_1.default.createElement(button_1.Button, __assign({ className: (0, utils_1.cn)("relative h-auto w-full flex-col overflow-hidden p-8", isDragActive && "outline-none ring-1 ring-ring", className), disabled: disabled, type: "button", variant: "outline" }, getRootProps()),
60
+ react_1.default.createElement("input", __assign({}, getInputProps(), { disabled: disabled })),
61
+ children)));
62
+ };
63
+ exports.Dropzone = Dropzone;
64
+ var maxLabelItems = 3;
65
+ var DropzoneContent = function (_a) {
66
+ var children = _a.children, className = _a.className;
67
+ // Use useContext directly here so the component is safe to render even when
68
+ // there is no surrounding <Dropzone /> provider (avoids an exception during
69
+ // SSR or when a consumer imports DropzoneContent standalone).
70
+ var context = (0, react_2.useContext)(DropzoneContext);
71
+ if (!context) {
72
+ return null;
73
+ }
74
+ var src = context.src;
75
+ if (!src) {
76
+ return null;
77
+ }
78
+ if (children) {
79
+ return children;
80
+ }
81
+ return (react_1.default.createElement("div", { className: (0, utils_1.cn)("flex flex-col items-center justify-center", className) },
82
+ react_1.default.createElement("div", { className: "flex size-8 items-center justify-center rounded-md bg-muted text-muted-foreground" },
83
+ react_1.default.createElement(lucide_react_1.UploadIcon, { size: 16 })),
84
+ react_1.default.createElement("p", { className: "my-2 w-full truncate font-medium text-sm" }, src.length > maxLabelItems
85
+ ? "".concat(new Intl.ListFormat("en").format(src.slice(0, maxLabelItems).map(function (file) { return file.name; })), " and ").concat(src.length - maxLabelItems, " more")
86
+ : new Intl.ListFormat("en").format(src.map(function (file) { return file.name; }))),
87
+ react_1.default.createElement("p", { className: "w-full text-wrap text-muted-foreground text-xs" }, "Drag and drop or click to replace")));
88
+ };
89
+ exports.DropzoneContent = DropzoneContent;
90
+ var DropzoneEmptyState = function (_a) {
91
+ var children = _a.children, className = _a.className;
92
+ // Read context directly and return null when a Dropzone provider isn't
93
+ // present. This keeps the empty state component safe to import and render
94
+ // without requiring the wrapping Dropzone component.
95
+ var context = (0, react_2.useContext)(DropzoneContext);
96
+ if (!context) {
97
+ return null;
98
+ }
99
+ var src = context.src, accept = context.accept, maxSize = context.maxSize, minSize = context.minSize, maxFiles = context.maxFiles;
100
+ if (src) {
101
+ return null;
102
+ }
103
+ if (children) {
104
+ return children;
105
+ }
106
+ var caption = "";
107
+ if (accept) {
108
+ caption += "Accepts ";
109
+ caption += new Intl.ListFormat("en").format(Object.keys(accept));
110
+ }
111
+ if (minSize && maxSize) {
112
+ caption += " between ".concat(renderBytes(minSize), " and ").concat(renderBytes(maxSize));
113
+ }
114
+ else if (minSize) {
115
+ caption += " at least ".concat(renderBytes(minSize));
116
+ }
117
+ else if (maxSize) {
118
+ caption += " less than ".concat(renderBytes(maxSize));
119
+ }
120
+ return (react_1.default.createElement("div", { className: (0, utils_1.cn)("flex flex-col items-center justify-center", className) },
121
+ react_1.default.createElement("div", { className: "flex size-8 items-center justify-center rounded-md bg-muted text-muted-foreground" },
122
+ react_1.default.createElement(lucide_react_1.UploadIcon, { size: 16 })),
123
+ react_1.default.createElement("p", { className: "my-2 w-full truncate text-wrap font-medium text-sm" },
124
+ "Upload ",
125
+ maxFiles === 1 ? "a file" : "files"),
126
+ react_1.default.createElement("p", { className: "w-full truncate text-wrap text-muted-foreground text-xs" }, "Drag and drop or click to upload"),
127
+ caption && (react_1.default.createElement("p", { className: "text-wrap text-muted-foreground text-xs" },
128
+ caption,
129
+ "."))));
130
+ };
131
+ exports.DropzoneEmptyState = DropzoneEmptyState;