@appcorp/stellar-solutions-modules 0.1.45 → 0.1.47

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.
@@ -0,0 +1,19 @@
1
+ import * as React from "react";
2
+ import useEmblaCarousel, { type UseEmblaCarouselType } from "embla-carousel-react";
3
+ import { Button } from "@/components/ui/button";
4
+ type CarouselApi = UseEmblaCarouselType[1];
5
+ type UseCarouselParameters = Parameters<typeof useEmblaCarousel>;
6
+ type CarouselOptions = UseCarouselParameters[0];
7
+ type CarouselPlugin = UseCarouselParameters[1];
8
+ type CarouselProps = {
9
+ opts?: CarouselOptions;
10
+ plugins?: CarouselPlugin;
11
+ orientation?: "horizontal" | "vertical";
12
+ setApi?: (api: CarouselApi) => void;
13
+ };
14
+ declare function Carousel({ orientation, opts, setApi, plugins, className, children, ...props }: React.ComponentProps<"div"> & CarouselProps): React.JSX.Element;
15
+ declare function CarouselContent({ className, ...props }: React.ComponentProps<"div">): React.JSX.Element;
16
+ declare function CarouselItem({ className, ...props }: React.ComponentProps<"div">): React.JSX.Element;
17
+ declare function CarouselPrevious({ className, variant, size, ...props }: React.ComponentProps<typeof Button>): React.JSX.Element;
18
+ declare function CarouselNext({ className, variant, size, ...props }: React.ComponentProps<typeof Button>): React.JSX.Element;
19
+ export { type CarouselApi, Carousel, CarouselContent, CarouselItem, CarouselPrevious, CarouselNext, };
@@ -0,0 +1,168 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
59
+ return (mod && mod.__esModule) ? mod : { "default": mod };
60
+ };
61
+ Object.defineProperty(exports, "__esModule", { value: true });
62
+ exports.Carousel = Carousel;
63
+ exports.CarouselContent = CarouselContent;
64
+ exports.CarouselItem = CarouselItem;
65
+ exports.CarouselPrevious = CarouselPrevious;
66
+ exports.CarouselNext = CarouselNext;
67
+ var React = __importStar(require("react"));
68
+ var embla_carousel_react_1 = __importDefault(require("embla-carousel-react"));
69
+ var lucide_react_1 = require("lucide-react");
70
+ var utils_1 = require("@/lib/utils");
71
+ var button_1 = require("@/components/ui/button");
72
+ var CarouselContext = React.createContext(null);
73
+ function useCarousel() {
74
+ var context = React.useContext(CarouselContext);
75
+ if (!context) {
76
+ throw new Error("useCarousel must be used within a <Carousel />");
77
+ }
78
+ return context;
79
+ }
80
+ function Carousel(_a) {
81
+ var _b = _a.orientation, orientation = _b === void 0 ? "horizontal" : _b, opts = _a.opts, setApi = _a.setApi, plugins = _a.plugins, className = _a.className, children = _a.children, props = __rest(_a, ["orientation", "opts", "setApi", "plugins", "className", "children"]);
82
+ var _c = (0, embla_carousel_react_1.default)(__assign(__assign({}, opts), { axis: orientation === "horizontal" ? "x" : "y" }), plugins), carouselRef = _c[0], api = _c[1];
83
+ var _d = React.useState(false), canScrollPrev = _d[0], setCanScrollPrev = _d[1];
84
+ var _e = React.useState(false), canScrollNext = _e[0], setCanScrollNext = _e[1];
85
+ var onSelect = React.useCallback(function (api) {
86
+ if (!api)
87
+ return;
88
+ setCanScrollPrev(api.canScrollPrev());
89
+ setCanScrollNext(api.canScrollNext());
90
+ }, []);
91
+ var scrollPrev = React.useCallback(function () {
92
+ api === null || api === void 0 ? void 0 : api.scrollPrev();
93
+ }, [api]);
94
+ var scrollNext = React.useCallback(function () {
95
+ api === null || api === void 0 ? void 0 : api.scrollNext();
96
+ }, [api]);
97
+ var handleKeyDown = React.useCallback(function (event) {
98
+ if (event.key === "ArrowLeft") {
99
+ event.preventDefault();
100
+ scrollPrev();
101
+ }
102
+ else if (event.key === "ArrowRight") {
103
+ event.preventDefault();
104
+ scrollNext();
105
+ }
106
+ }, [scrollPrev, scrollNext]);
107
+ React.useEffect(function () {
108
+ if (!api || !setApi)
109
+ return;
110
+ setApi(api);
111
+ }, [api, setApi]);
112
+ React.useEffect(function () {
113
+ if (!api)
114
+ return;
115
+ onSelect(api);
116
+ api.on("reInit", onSelect);
117
+ api.on("select", onSelect);
118
+ return function () {
119
+ api === null || api === void 0 ? void 0 : api.off("select", onSelect);
120
+ };
121
+ }, [api, onSelect]);
122
+ return (React.createElement(CarouselContext.Provider, { value: {
123
+ carouselRef: carouselRef,
124
+ api: api,
125
+ opts: opts,
126
+ orientation: orientation || ((opts === null || opts === void 0 ? void 0 : opts.axis) === "y" ? "vertical" : "horizontal"),
127
+ scrollPrev: scrollPrev,
128
+ scrollNext: scrollNext,
129
+ canScrollPrev: canScrollPrev,
130
+ canScrollNext: canScrollNext,
131
+ } },
132
+ React.createElement("div", __assign({ onKeyDownCapture: handleKeyDown, className: (0, utils_1.cn)("relative", className), role: "region", "aria-roledescription": "carousel", "data-slot": "carousel" }, props), children)));
133
+ }
134
+ function CarouselContent(_a) {
135
+ var className = _a.className, props = __rest(_a, ["className"]);
136
+ var _b = useCarousel(), carouselRef = _b.carouselRef, orientation = _b.orientation;
137
+ return (React.createElement("div", { ref: carouselRef, className: "overflow-hidden", "data-slot": "carousel-content" },
138
+ React.createElement("div", __assign({ className: (0, utils_1.cn)("flex", orientation === "horizontal" ? "-ml-4" : "-mt-4 flex-col", className) }, props))));
139
+ }
140
+ function CarouselItem(_a) {
141
+ var className = _a.className, props = __rest(_a, ["className"]);
142
+ var orientation = useCarousel().orientation;
143
+ return (React.createElement("div", __assign({ role: "group", "aria-roledescription": "slide", "data-slot": "carousel-item", className: (0, utils_1.cn)("min-w-0 shrink-0 grow-0 basis-full", orientation === "horizontal" ? "pl-4" : "pt-4", className) }, props)));
144
+ }
145
+ function CarouselPrevious(_a) {
146
+ var className = _a.className, _b = _a.variant, variant = _b === void 0 ? "outline" : _b, _c = _a.size, size = _c === void 0 ? "icon" : _c, props = __rest(_a, ["className", "variant", "size"]);
147
+ var _d = useCarousel(), orientation = _d.orientation, scrollPrev = _d.scrollPrev, canScrollPrev = _d.canScrollPrev;
148
+ return (React.createElement(button_1.Button, __assign({}, props, { "data-slot": "carousel-previous", variant: variant, size: size, className: (0, utils_1.cn)("absolute size-8 rounded-full", orientation === "horizontal"
149
+ ? "top-1/2 -left-12 -translate-y-1/2"
150
+ : "-top-12 left-1/2 -translate-x-1/2 rotate-90", className), disabled: !canScrollPrev, onClick: function (e) {
151
+ e.stopPropagation();
152
+ scrollPrev();
153
+ } }),
154
+ React.createElement(lucide_react_1.ArrowLeft, null),
155
+ React.createElement("span", { className: "sr-only" }, "Previous slide")));
156
+ }
157
+ function CarouselNext(_a) {
158
+ var className = _a.className, _b = _a.variant, variant = _b === void 0 ? "outline" : _b, _c = _a.size, size = _c === void 0 ? "icon" : _c, props = __rest(_a, ["className", "variant", "size"]);
159
+ var _d = useCarousel(), orientation = _d.orientation, scrollNext = _d.scrollNext, canScrollNext = _d.canScrollNext;
160
+ return (React.createElement(button_1.Button, __assign({}, props, { "data-slot": "carousel-next", variant: variant, size: size, className: (0, utils_1.cn)("absolute size-8 rounded-full", orientation === "horizontal"
161
+ ? "top-1/2 -right-12 -translate-y-1/2"
162
+ : "-bottom-12 left-1/2 -translate-x-1/2 rotate-90", className), disabled: !canScrollNext, onClick: function (e) {
163
+ e.stopPropagation();
164
+ scrollNext();
165
+ } }),
166
+ React.createElement(lucide_react_1.ArrowRight, null),
167
+ React.createElement("span", { className: "sr-only" }, "Next slide")));
168
+ }
@@ -0,0 +1,21 @@
1
+ import React from "react";
2
+ import type { DropzoneOptions } from "react-dropzone";
3
+ export type EnhancedDropzoneProps = {
4
+ id?: string;
5
+ className?: string;
6
+ label?: string;
7
+ info?: string;
8
+ error?: string;
9
+ accept?: DropzoneOptions["accept"] | string[];
10
+ maxFiles?: number;
11
+ maxSize?: number;
12
+ minSize?: number;
13
+ disabled?: boolean;
14
+ /** initial list of files or urls to show as previews */
15
+ initial?: Array<File | string>;
16
+ /** Called when selected File[] changes */
17
+ onChange?: (files: File[]) => void;
18
+ /** Called when a provided remote URL preview is removed (if provided) */
19
+ onRemoveUrl?: (url: string) => void;
20
+ };
21
+ export declare const EnhancedDropzone: React.FC<EnhancedDropzoneProps>;
@@ -0,0 +1,225 @@
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 __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
48
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
49
+ if (ar || !(i in from)) {
50
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
51
+ ar[i] = from[i];
52
+ }
53
+ }
54
+ return to.concat(ar || Array.prototype.slice.call(from));
55
+ };
56
+ Object.defineProperty(exports, "__esModule", { value: true });
57
+ exports.EnhancedDropzone = void 0;
58
+ var react_1 = __importStar(require("react"));
59
+ var react_dropzone_1 = require("react-dropzone");
60
+ var utils_1 = require("../../lib/utils");
61
+ var carousel_1 = require("./carousel");
62
+ var button_1 = require("./button");
63
+ var lucide_react_1 = require("lucide-react");
64
+ var dropzone_1 = require("./shadcn-io/dropzone");
65
+ var EnhancedDropzone = function (_a) {
66
+ var id = _a.id, label = _a.label, info = _a.info, error = _a.error, accept = _a.accept, _b = _a.maxFiles, maxFiles = _b === void 0 ? 10 : _b, maxSize = _a.maxSize, minSize = _a.minSize, disabled = _a.disabled, _c = _a.initial, initial = _c === void 0 ? [] : _c, onChange = _a.onChange, onRemoveUrl = _a.onRemoveUrl, className = _a.className;
67
+ // Files selected locally (File objects)
68
+ var _d = (0, react_1.useState)([]), files = _d[0], setFiles = _d[1];
69
+ // Previews array contains strings (object URLs or provided URLs) in display order
70
+ var _e = (0, react_1.useState)([]), previews = _e[0], setPreviews = _e[1];
71
+ // Track which previews are remote (came from initial string URLs)
72
+ var _f = (0, react_1.useState)({}), remotePreviews = _f[0], setRemotePreviews = _f[1];
73
+ var createdUrlsRef = (0, react_1.useRef)([]);
74
+ // Track remote URLs removed by the user so they don't reappear when
75
+ // previews are rebuilt from the unchanged `initial` prop.
76
+ var removedRemoteRef = (0, react_1.useRef)(new Set());
77
+ var dropzoneOptions = {
78
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
79
+ accept: (Array.isArray(accept) ? undefined : accept) || undefined,
80
+ maxFiles: maxFiles,
81
+ maxSize: maxSize,
82
+ minSize: minSize,
83
+ disabled: disabled,
84
+ onDrop: function (acceptedFiles) {
85
+ // append files, respecting maxFiles
86
+ var nextFiles = __spreadArray(__spreadArray([], files, true), acceptedFiles, true);
87
+ if (maxFiles && nextFiles.length > maxFiles)
88
+ nextFiles = nextFiles.slice(0, maxFiles);
89
+ setFiles(nextFiles);
90
+ onChange === null || onChange === void 0 ? void 0 : onChange(nextFiles);
91
+ },
92
+ };
93
+ var _g = (0, react_dropzone_1.useDropzone)(dropzoneOptions), getRootProps = _g.getRootProps, getInputProps = _g.getInputProps, isDragActive = _g.isDragActive;
94
+ // Build previews from initial and files
95
+ (0, react_1.useEffect)(function () {
96
+ // cleanup previous object URLs
97
+ (createdUrlsRef.current || []).forEach(function (u) {
98
+ try {
99
+ URL.revokeObjectURL(u);
100
+ }
101
+ catch (_a) { }
102
+ });
103
+ createdUrlsRef.current = [];
104
+ var next = [];
105
+ var remoteMap = {};
106
+ // start with initial items (may be File or string)
107
+ initial.forEach(function (item) {
108
+ if (typeof item === "string") {
109
+ // skip any remote URL the user removed earlier
110
+ if (removedRemoteRef.current.has(item))
111
+ return;
112
+ next.push(item);
113
+ remoteMap[item] = true;
114
+ }
115
+ else if (item instanceof File) {
116
+ try {
117
+ var url = URL.createObjectURL(item);
118
+ next.push(url);
119
+ createdUrlsRef.current.push(url);
120
+ }
121
+ catch (_a) {
122
+ next.push("");
123
+ }
124
+ }
125
+ else {
126
+ next.push("");
127
+ }
128
+ });
129
+ // then local files
130
+ files.forEach(function (f) {
131
+ try {
132
+ var url = URL.createObjectURL(f);
133
+ next.push(url);
134
+ createdUrlsRef.current.push(url);
135
+ }
136
+ catch (_a) {
137
+ next.push("");
138
+ }
139
+ });
140
+ setPreviews(next);
141
+ setRemotePreviews(remoteMap);
142
+ return function () {
143
+ (createdUrlsRef.current || []).forEach(function (u) {
144
+ try {
145
+ URL.revokeObjectURL(u);
146
+ }
147
+ catch (_a) { }
148
+ });
149
+ createdUrlsRef.current = [];
150
+ };
151
+ // files and initial are the dependencies
152
+ }, [files, initial]);
153
+ // Remove a local file by index (index relative to files slice after initial length)
154
+ var handleRemoveLocal = function (index) {
155
+ var next = files.filter(function (_, i) { return i !== index; });
156
+ setFiles(next);
157
+ onChange === null || onChange === void 0 ? void 0 : onChange(next);
158
+ };
159
+ // Remove a preview by its absolute preview index (index within `previews`)
160
+ // If the preview is remote (string from `initial`), call onRemoveUrl and
161
+ // remove only that single occurrence. If it's a local file, delegate to
162
+ // handleRemoveLocal with the computed files index.
163
+ var handleRemoveByPreviewIndex = function (previewIndex) {
164
+ var entry = previews[previewIndex];
165
+ if (entry === undefined)
166
+ return;
167
+ var isRemote = Boolean(remotePreviews[entry]);
168
+ if (isRemote) {
169
+ // notify parent
170
+ onRemoveUrl === null || onRemoveUrl === void 0 ? void 0 : onRemoveUrl(entry);
171
+ // record removal locally so the value isn't re-added from the `initial`
172
+ // prop on the next rebuild
173
+ removedRemoteRef.current.add(entry);
174
+ // remove only the specific preview at previewIndex
175
+ setPreviews(function (p) {
176
+ var next = __spreadArray([], p, true);
177
+ next.splice(previewIndex, 1);
178
+ return next;
179
+ });
180
+ setRemotePreviews(function (m) {
181
+ var next = __assign({}, m);
182
+ delete next[entry];
183
+ return next;
184
+ });
185
+ return;
186
+ }
187
+ // local file - compute index relative to files array and remove
188
+ var fileIndex = previewIndex - initial.length;
189
+ if (fileIndex >= 0 && fileIndex < files.length) {
190
+ handleRemoveLocal(fileIndex);
191
+ }
192
+ };
193
+ // (handleRemoveRemote removed) - use handleRemoveByPreviewIndex instead so we
194
+ // can remove single occurrences by index.
195
+ // carousel (embla) handles scrolling via CarouselPrevious/Next
196
+ return (react_1.default.createElement("div", { className: (0, utils_1.cn)("w-full border-red-300", className) },
197
+ label && (react_1.default.createElement("label", { className: "mb-2 block text-sm font-medium" }, label)),
198
+ react_1.default.createElement("div", __assign({}, getRootProps(), { className: (0, utils_1.cn)("relative w-full rounded-md border border-dashed p-6 text-center mx-auto", isDragActive && "ring-1 ring-ring", disabled && "opacity-60 pointer-events-none") }),
199
+ react_1.default.createElement("input", __assign({}, getInputProps(), { id: id })),
200
+ previews && previews.length > 0 ? (react_1.default.createElement("div", { className: "flex flex-col items-center" },
201
+ react_1.default.createElement("div", { className: "relative w-60" },
202
+ react_1.default.createElement("div", { className: "relative w-60" },
203
+ react_1.default.createElement(carousel_1.Carousel, { className: "w-60" },
204
+ react_1.default.createElement(carousel_1.CarouselPrevious, { onPointerDown: function (e) { return e.stopPropagation(); }, onMouseDown: function (e) { return e.stopPropagation(); } }),
205
+ react_1.default.createElement(carousel_1.CarouselNext, { onPointerDown: function (e) { return e.stopPropagation(); }, onMouseDown: function (e) { return e.stopPropagation(); } }),
206
+ react_1.default.createElement(carousel_1.CarouselContent, { className: "no-scrollbar flex gap-2 px-4 py-2", onPointerDown: function (e) { return e.stopPropagation(); }, onClick: function (e) { return e.stopPropagation(); } }, previews.map(function (p, idx) {
207
+ return (react_1.default.createElement(carousel_1.CarouselItem, { key: "".concat(String(p), "-").concat(idx), className: "max-w-30 max-auto" }, p ? (react_1.default.createElement("div", { className: "relative" },
208
+ react_1.default.createElement("img", { src: p, alt: "preview-".concat(idx), className: "h-28 w-28 rounded-md object-cover" }),
209
+ react_1.default.createElement(button_1.Button, { size: "icon", variant: "ghost", onClick: function (e) {
210
+ e.stopPropagation();
211
+ handleRemoveByPreviewIndex(idx);
212
+ }, className: "absolute right-1 top-1 rounded bg-white/80 p-0", "aria-label": "Remove image" },
213
+ react_1.default.createElement(lucide_react_1.XIcon, { size: 7 })))) : (react_1.default.createElement("div", { className: "flex h-28 w-40 items-center justify-center rounded-md bg-muted text-muted-foreground" },
214
+ react_1.default.createElement("span", { className: "text-xs" }, "File")))));
215
+ }))))),
216
+ react_1.default.createElement("p", { className: "mt-2 w-full truncate text-sm font-medium" },
217
+ previews.length,
218
+ " selected"))) : (
219
+ // <div className="text-sm">
220
+ // Drag & drop files here, or click to select
221
+ // </div>
222
+ react_1.default.createElement(dropzone_1.DropzoneEmptyState, null))),
223
+ (error || info) && (react_1.default.createElement("div", { className: "mt-2" }, 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))));
224
+ };
225
+ exports.EnhancedDropzone = EnhancedDropzone;
@@ -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("") 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,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 | React.JSX.Element | Iterable<React.ReactNode> | Promise<string | number | bigint | boolean | React.ReactPortal | React.ReactElement<unknown, string | React.JSXElementConstructor<any>> | Iterable<React.ReactNode> | null | undefined> | null;
15
+ export type DropzoneEmptyStateProps = {
16
+ children?: ReactNode;
17
+ className?: string;
18
+ };
19
+ export declare const DropzoneEmptyState: ({ children, className, }: DropzoneEmptyStateProps) => string | number | bigint | true | React.JSX.Element | Iterable<React.ReactNode> | Promise<string | number | bigint | boolean | React.ReactPortal | React.ReactElement<unknown, string | React.JSXElementConstructor<any>> | Iterable<React.ReactNode> | null | undefined> | 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("@/components/ui/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;
package/index.d.ts CHANGED
@@ -3,12 +3,14 @@ export * from "./components/theme-switcher";
3
3
  export * from "./components/ui/badge";
4
4
  export * from "./components/ui/button";
5
5
  export * from "./components/ui/card";
6
+ export * from "./components/ui/carousel";
6
7
  export * from "./components/ui/checkbox";
7
8
  export * from "./components/ui/combobox";
8
9
  export * from "./components/ui/command";
9
10
  export * from "./components/ui/dialog";
10
11
  export * from "./components/ui/drawer";
11
12
  export * from "./components/ui/dropdown-menu";
13
+ export * from "./components/ui/enhanced-dropzone";
12
14
  export * from "./components/ui/enhanced-table-footer-action";
13
15
  export * from "./components/ui/enhanced-table-footer-page";
14
16
  export * from "./components/ui/enhanced-table-footer-pagination";
@@ -21,6 +23,8 @@ export * from "./components/ui/label";
21
23
  export * from "./components/ui/popover";
22
24
  export * from "./components/ui/select";
23
25
  export * from "./components/ui/separator";
26
+ export * from "./components/ui/shadcn-io/color-picker";
27
+ export * from "./components/ui/shadcn-io/dropzone";
24
28
  export * from "./components/ui/sonner";
25
29
  export * from "./components/ui/switch";
26
30
  export * from "./components/ui/textarea";
package/index.js CHANGED
@@ -19,12 +19,14 @@ __exportStar(require("./components/theme-switcher"), exports);
19
19
  __exportStar(require("./components/ui/badge"), exports);
20
20
  __exportStar(require("./components/ui/button"), exports);
21
21
  __exportStar(require("./components/ui/card"), exports);
22
+ __exportStar(require("./components/ui/carousel"), exports);
22
23
  __exportStar(require("./components/ui/checkbox"), exports);
23
24
  __exportStar(require("./components/ui/combobox"), exports);
24
25
  __exportStar(require("./components/ui/command"), exports);
25
26
  __exportStar(require("./components/ui/dialog"), exports);
26
27
  __exportStar(require("./components/ui/drawer"), exports);
27
28
  __exportStar(require("./components/ui/dropdown-menu"), exports);
29
+ __exportStar(require("./components/ui/enhanced-dropzone"), exports);
28
30
  __exportStar(require("./components/ui/enhanced-table-footer-action"), exports);
29
31
  __exportStar(require("./components/ui/enhanced-table-footer-page"), exports);
30
32
  __exportStar(require("./components/ui/enhanced-table-footer-pagination"), exports);
@@ -37,6 +39,8 @@ __exportStar(require("./components/ui/label"), exports);
37
39
  __exportStar(require("./components/ui/popover"), exports);
38
40
  __exportStar(require("./components/ui/select"), exports);
39
41
  __exportStar(require("./components/ui/separator"), exports);
42
+ __exportStar(require("./components/ui/shadcn-io/color-picker"), exports);
43
+ __exportStar(require("./components/ui/shadcn-io/dropzone"), exports);
40
44
  __exportStar(require("./components/ui/sonner"), exports);
41
45
  __exportStar(require("./components/ui/switch"), exports);
42
46
  __exportStar(require("./components/ui/textarea"), exports);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@appcorp/stellar-solutions-modules",
3
- "version": "0.1.45",
3
+ "version": "0.1.47",
4
4
  "scripts": {
5
5
  "automate": "./automate.sh",
6
6
  "build": "yarn clean && yarn build:ts && cp package.json lib && cp README.md lib && cp yarn.lock lib",