@moontra/moonui-pro 2.4.5 → 2.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.mjs CHANGED
@@ -3,10 +3,11 @@ import { twMerge } from 'tailwind-merge';
3
3
  import * as t from 'react';
4
4
  import t__default, { useState, useRef, useCallback, forwardRef, createContext, useContext, useMemo, useEffect, useDebugValue, Component, useLayoutEffect } from 'react';
5
5
  import * as AccordionPrimitive from '@radix-ui/react-accordion';
6
- import { ChevronDown, Info, AlertCircle, AlertTriangle, Check, X, MoreHorizontal, Loader2, Minus, Search, ChevronRight, Circle, ChevronUp, Lock, Sparkles, Plus, ChevronLeft, Calendar, Edit, Trash2, Clock, MapPin, User, GripVertical, MessageCircle, Paperclip, Bold as Bold$1, Italic as Italic$1, Underline as Underline$1, Strikethrough, Code as Code$1, Type, Heading1, Heading2, Heading3, AlignLeft, AlignCenter, AlignRight, AlignJustify, List, ListOrdered, CheckSquare, Quote, Palette, Highlighter, Link2, Image as Image$1, Table as Table$1, Settings, Undo, Redo, Eye, RefreshCw, Wand2, Maximize, FileText, Languages, TrendingUp, TrendingDown, ZoomOut, ZoomIn, Download, FileSpreadsheet, FileJson, Maximize2, Move, Activity, Star, Upload, CheckCircle2, Filter, FileDown, ArrowUp, ArrowDown, ArrowUpDown, ChevronsLeft, ChevronsRight, ExternalLink, BarChart3, Users, DollarSign, Github, GitFork, Server, EyeOff, RotateCw, Zap, Monitor, Timer, Cpu, MemoryStick, HardDrive, Network, CheckCircle, Video, Music, Archive, File, Columns, XCircle, ArrowDownRight, ArrowUpRight } from 'lucide-react';
6
+ import { ChevronDown, Info, AlertCircle, AlertTriangle, Check, X, MoreHorizontal, Loader2, Minus, Search, ChevronRight, Circle, ChevronUp, Lock, Sparkles, Plus, ChevronLeft, Calendar as Calendar$1, Edit, Trash2, Clock, MapPin, User, GripVertical, MessageCircle, Paperclip, Bold as Bold$1, Italic as Italic$1, Underline as Underline$1, Strikethrough, Code as Code$1, Type, Heading1, Heading2, Heading3, AlignLeft, AlignCenter, AlignRight, AlignJustify, List, ListOrdered, CheckSquare, Quote, Palette, Highlighter, Link2, Image as Image$1, Table as Table$1, Settings, Undo, Redo, Eye, RefreshCw, Wand2, Maximize, FileText, Languages, TrendingUp, TrendingDown, ZoomOut, ZoomIn, Download, FileSpreadsheet, FileJson, Maximize2, Move, Menu, Bell, Edit3, LayoutGrid, Upload, Share2, Save, CheckCircle2, Filter, FileDown, ArrowUp, ArrowDown, ArrowUpDown, ChevronsLeft, ChevronsRight, ExternalLink, CalendarIcon, DollarSign, Users, Github, Star, GitFork, Activity, Server, EyeOff, RotateCw, Zap, Monitor, Timer, Cpu, MemoryStick, HardDrive, Network, CheckCircle, BarChart3, Video, Music, Archive, File, Columns, XCircle, Grip, Unlock, Minimize2, Map as Map$1, Target, MoreVertical, BellOff, ArrowDownRight, ArrowUpRight } from 'lucide-react';
7
7
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
8
8
  import { cva } from 'class-variance-authority';
9
9
  import * as AvatarPrimitive from '@radix-ui/react-avatar';
10
+ import { DayPicker } from 'react-day-picker';
10
11
  import { motion, AnimatePresence, useMotionValue, useSpring, useTransform, animate } from 'framer-motion';
11
12
  import * as CheckboxPrimitive from '@radix-ui/react-checkbox';
12
13
  import ReactDOM3 from 'react-dom';
@@ -16,6 +17,7 @@ import { createDialogScope } from '@radix-ui/react-dialog';
16
17
  import * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';
17
18
  import * as LabelPrimitive from '@radix-ui/react-label';
18
19
  import * as PopoverPrimitive from '@radix-ui/react-popover';
20
+ import * as ScrollAreaPrimitive from '@radix-ui/react-scroll-area';
19
21
  import * as SelectPrimitive from '@radix-ui/react-select';
20
22
  import * as SeparatorPrimitive from '@radix-ui/react-separator';
21
23
  import * as SwitchPrimitives from '@radix-ui/react-switch';
@@ -25,6 +27,9 @@ import * as TooltipPrimitive from '@radix-ui/react-tooltip';
25
27
  import { useSyncExternalStore } from 'use-sync-external-store/shim/index.js';
26
28
  import { useSyncExternalStoreWithSelector } from 'use-sync-external-store/shim/with-selector.js';
27
29
  import { ResponsiveContainer, LineChart, Line, RadialBarChart, Tooltip, Legend, RadialBar, RadarChart, PolarGrid, PolarAngleAxis, PolarRadiusAxis, Radar, ScatterChart, CartesianGrid, XAxis, YAxis, Scatter, PieChart, Pie, Cell, AreaChart, Area, ReferenceLine, Brush, BarChart, Bar, ReferenceArea } from 'recharts';
30
+ import { startOfDay, endOfDay, subDays, startOfWeek, endOfWeek, startOfMonth, endOfMonth, format, formatDistanceToNow } from 'date-fns';
31
+ import GridLayout from 'react-grid-layout';
32
+ import 'react-grid-layout/css/styles.css';
28
33
  import { DragDropContext, Droppable, Draggable } from '@hello-pangea/dnd';
29
34
  import { useForm } from 'react-hook-form';
30
35
  import { flexRender, useReactTable, getCoreRowModel, getPaginationRowModel, getSortedRowModel, getFilteredRowModel } from '@tanstack/react-table';
@@ -2535,6 +2540,56 @@ var MoonUIButtonPro = t.forwardRef(
2535
2540
  }
2536
2541
  );
2537
2542
  MoonUIButtonPro.displayName = "MoonUIButtonPro";
2543
+ function Calendar({
2544
+ className,
2545
+ classNames,
2546
+ showOutsideDays = true,
2547
+ ...props
2548
+ }) {
2549
+ return /* @__PURE__ */ jsx(
2550
+ DayPicker,
2551
+ {
2552
+ showOutsideDays,
2553
+ className: cn("p-3", className),
2554
+ classNames: {
2555
+ months: "flex flex-col sm:flex-row space-y-4 sm:space-x-4 sm:space-y-0",
2556
+ month: "space-y-4",
2557
+ caption: "flex justify-center pt-1 relative items-center",
2558
+ caption_label: "text-sm font-medium",
2559
+ nav: "space-x-1 flex items-center",
2560
+ nav_button: cn(
2561
+ moonUIButtonProVariants({ variant: "outline" }),
2562
+ "h-7 w-7 bg-transparent p-0 opacity-50 hover:opacity-100"
2563
+ ),
2564
+ nav_button_previous: "absolute left-1",
2565
+ nav_button_next: "absolute right-1",
2566
+ table: "w-full border-collapse space-y-1",
2567
+ head_row: "flex",
2568
+ head_cell: "text-muted-foreground rounded-md w-9 font-normal text-[0.8rem]",
2569
+ row: "flex w-full mt-2",
2570
+ cell: "h-9 w-9 text-center text-sm p-0 relative [&:has([aria-selected].day-range-end)]:rounded-r-md [&:has([aria-selected].day-outside)]:bg-accent/50 [&:has([aria-selected])]:bg-accent first:[&:has([aria-selected])]:rounded-l-md last:[&:has([aria-selected])]:rounded-r-md focus-within:relative focus-within:z-20",
2571
+ day: cn(
2572
+ moonUIButtonProVariants({ variant: "ghost" }),
2573
+ "h-9 w-9 p-0 font-normal aria-selected:opacity-100"
2574
+ ),
2575
+ day_range_end: "day-range-end",
2576
+ day_selected: "bg-primary text-primary-foreground hover:bg-primary hover:text-primary-foreground focus:bg-primary focus:text-primary-foreground",
2577
+ day_today: "bg-accent text-accent-foreground",
2578
+ day_outside: "day-outside text-muted-foreground opacity-50 aria-selected:bg-accent/50 aria-selected:text-muted-foreground aria-selected:opacity-30",
2579
+ day_disabled: "text-muted-foreground opacity-50",
2580
+ day_range_middle: "aria-selected:bg-accent aria-selected:text-accent-foreground",
2581
+ day_hidden: "invisible",
2582
+ ...classNames
2583
+ },
2584
+ components: {
2585
+ // IconLeft: () => <ChevronLeft className="h-4 w-4" />,
2586
+ // IconRight: () => <ChevronRight className="h-4 w-4" />,
2587
+ },
2588
+ ...props
2589
+ }
2590
+ );
2591
+ }
2592
+ Calendar.displayName = "Calendar";
2538
2593
  cva("", {
2539
2594
  variants: {
2540
2595
  hover: {
@@ -3791,7 +3846,7 @@ var me = t.forwardRef((r2, o) => {
3791
3846
  var e;
3792
3847
  return Array.from(((e = I.current) == null ? void 0 : e.querySelectorAll(ce)) || []);
3793
3848
  }
3794
- function X14(e) {
3849
+ function X17(e) {
3795
3850
  let s = V()[e];
3796
3851
  s && E.setState("value", s.getAttribute(T));
3797
3852
  }
@@ -3806,10 +3861,10 @@ var me = t.forwardRef((r2, o) => {
3806
3861
  s = e > 0 ? we(s, N) : De(s, N), i = s == null ? void 0 : s.querySelector(ce);
3807
3862
  i ? E.setState("value", i.getAttribute(T)) : Q(e);
3808
3863
  }
3809
- let oe = () => X14(V().length - 1), ie3 = (e) => {
3864
+ let oe = () => X17(V().length - 1), ie3 = (e) => {
3810
3865
  e.preventDefault(), e.metaKey ? oe() : e.altKey ? re(1) : Q(1);
3811
3866
  }, se = (e) => {
3812
- e.preventDefault(), e.metaKey ? X14(0) : e.altKey ? re(-1) : Q(-1);
3867
+ e.preventDefault(), e.metaKey ? X17(0) : e.altKey ? re(-1) : Q(-1);
3813
3868
  };
3814
3869
  return t.createElement(Primitive2.div, { ref: o, tabIndex: -1, ...O, "cmdk-root": "", onKeyDown: (e) => {
3815
3870
  var s;
@@ -3836,7 +3891,7 @@ var me = t.forwardRef((r2, o) => {
3836
3891
  break;
3837
3892
  }
3838
3893
  case "Home": {
3839
- e.preventDefault(), X14(0);
3894
+ e.preventDefault(), X17(0);
3840
3895
  break;
3841
3896
  }
3842
3897
  case "End": {
@@ -5105,6 +5160,36 @@ var MoonUIRadioItemWithLabelPro = t.forwardRef(({
5105
5160
  ] });
5106
5161
  });
5107
5162
  MoonUIRadioItemWithLabelPro.displayName = "RadioItemWithLabelPro";
5163
+ var ScrollArea = t.forwardRef(({ className, children, ...props }, ref) => /* @__PURE__ */ jsxs(
5164
+ ScrollAreaPrimitive.Root,
5165
+ {
5166
+ ref,
5167
+ className: cn("relative overflow-hidden", className),
5168
+ ...props,
5169
+ children: [
5170
+ /* @__PURE__ */ jsx(ScrollAreaPrimitive.Viewport, { className: "h-full w-full rounded-[inherit]", children }),
5171
+ /* @__PURE__ */ jsx(ScrollBar, {}),
5172
+ /* @__PURE__ */ jsx(ScrollAreaPrimitive.Corner, {})
5173
+ ]
5174
+ }
5175
+ ));
5176
+ ScrollArea.displayName = ScrollAreaPrimitive.Root.displayName;
5177
+ var ScrollBar = t.forwardRef(({ className, orientation = "vertical", ...props }, ref) => /* @__PURE__ */ jsx(
5178
+ ScrollAreaPrimitive.ScrollAreaScrollbar,
5179
+ {
5180
+ ref,
5181
+ orientation,
5182
+ className: cn(
5183
+ "flex touch-none select-none transition-colors",
5184
+ orientation === "vertical" && "h-full w-2.5 border-l border-l-transparent p-[1px]",
5185
+ orientation === "horizontal" && "h-2.5 flex-col border-t border-t-transparent p-[1px]",
5186
+ className
5187
+ ),
5188
+ ...props,
5189
+ children: /* @__PURE__ */ jsx(ScrollAreaPrimitive.ScrollAreaThumb, { className: "relative flex-1 rounded-full bg-border" })
5190
+ }
5191
+ ));
5192
+ ScrollBar.displayName = ScrollAreaPrimitive.ScrollAreaScrollbar.displayName;
5108
5193
  var MoonUISelectPro = SelectPrimitive.Root;
5109
5194
  MoonUISelectPro.displayName = "MoonUISelectPro";
5110
5195
  var MoonUISelectGroupPro = SelectPrimitive.Group;
@@ -5379,6 +5464,103 @@ var MoonUISeparatorPro = t.forwardRef(
5379
5464
  )
5380
5465
  );
5381
5466
  MoonUISeparatorPro.displayName = SeparatorPrimitive.Root.displayName;
5467
+ var Sheet = DialogPrimitive.Root;
5468
+ var SheetTrigger = DialogPrimitive.Trigger;
5469
+ var SheetClose = DialogPrimitive.Close;
5470
+ var SheetPortal = DialogPrimitive.Portal;
5471
+ var SheetOverlay = t.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsx(
5472
+ DialogPrimitive.Overlay,
5473
+ {
5474
+ className: cn(
5475
+ "fixed inset-0 z-50 bg-background/80 backdrop-blur-sm data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",
5476
+ className
5477
+ ),
5478
+ ...props,
5479
+ ref
5480
+ }
5481
+ ));
5482
+ SheetOverlay.displayName = DialogPrimitive.Overlay.displayName;
5483
+ var sheetVariants = cva(
5484
+ "fixed z-50 gap-4 bg-background p-6 shadow-lg transition ease-in-out data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:duration-300 data-[state=open]:duration-500",
5485
+ {
5486
+ variants: {
5487
+ side: {
5488
+ top: "inset-x-0 top-0 border-b data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top",
5489
+ bottom: "inset-x-0 bottom-0 border-t data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom",
5490
+ left: "inset-y-0 left-0 h-full w-3/4 border-r data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left sm:max-w-sm",
5491
+ right: "inset-y-0 right-0 h-full w-3/4 border-l data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right sm:max-w-sm"
5492
+ }
5493
+ },
5494
+ defaultVariants: {
5495
+ side: "right"
5496
+ }
5497
+ }
5498
+ );
5499
+ var SheetContent = t.forwardRef(({ side = "right", className, children, ...props }, ref) => /* @__PURE__ */ jsxs(SheetPortal, { children: [
5500
+ /* @__PURE__ */ jsx(SheetOverlay, {}),
5501
+ /* @__PURE__ */ jsxs(
5502
+ DialogPrimitive.Content,
5503
+ {
5504
+ ref,
5505
+ className: cn(sheetVariants({ side }), className),
5506
+ ...props,
5507
+ children: [
5508
+ children,
5509
+ /* @__PURE__ */ jsxs(DialogPrimitive.Close, { className: "absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-secondary", children: [
5510
+ /* @__PURE__ */ jsx(X, { className: "h-4 w-4" }),
5511
+ /* @__PURE__ */ jsx("span", { className: "sr-only", children: "Close" })
5512
+ ] })
5513
+ ]
5514
+ }
5515
+ )
5516
+ ] }));
5517
+ SheetContent.displayName = DialogPrimitive.Content.displayName;
5518
+ var SheetHeader = ({
5519
+ className,
5520
+ ...props
5521
+ }) => /* @__PURE__ */ jsx(
5522
+ "div",
5523
+ {
5524
+ className: cn(
5525
+ "flex flex-col space-y-2 text-center sm:text-left",
5526
+ className
5527
+ ),
5528
+ ...props
5529
+ }
5530
+ );
5531
+ SheetHeader.displayName = "SheetHeader";
5532
+ var SheetFooter = ({
5533
+ className,
5534
+ ...props
5535
+ }) => /* @__PURE__ */ jsx(
5536
+ "div",
5537
+ {
5538
+ className: cn(
5539
+ "flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",
5540
+ className
5541
+ ),
5542
+ ...props
5543
+ }
5544
+ );
5545
+ SheetFooter.displayName = "SheetFooter";
5546
+ var SheetTitle = t.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsx(
5547
+ DialogPrimitive.Title,
5548
+ {
5549
+ ref,
5550
+ className: cn("text-lg font-semibold text-foreground", className),
5551
+ ...props
5552
+ }
5553
+ ));
5554
+ SheetTitle.displayName = DialogPrimitive.Title.displayName;
5555
+ var SheetDescription = t.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsx(
5556
+ DialogPrimitive.Description,
5557
+ {
5558
+ ref,
5559
+ className: cn("text-sm text-muted-foreground", className),
5560
+ ...props
5561
+ }
5562
+ ));
5563
+ SheetDescription.displayName = DialogPrimitive.Description.displayName;
5382
5564
  function MoonUISkeletonPro({
5383
5565
  className,
5384
5566
  ...props
@@ -6296,7 +6478,7 @@ var Toggle = t.forwardRef((props, forwardedRef) => {
6296
6478
  );
6297
6479
  });
6298
6480
  Toggle.displayName = NAME;
6299
- var Root16 = Toggle;
6481
+ var Root18 = Toggle;
6300
6482
  var MoonUItoggleVariantsPro = cva(
6301
6483
  "inline-flex items-center justify-center rounded-md text-sm font-medium ring-offset-background transition-colors hover:bg-muted hover:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 data-[state=on]:bg-accent data-[state=on]:text-accent-foreground",
6302
6484
  {
@@ -6318,14 +6500,14 @@ var MoonUItoggleVariantsPro = cva(
6318
6500
  }
6319
6501
  );
6320
6502
  var MoonUITogglePro = t.forwardRef(({ className, variant, size, ...props }, ref) => /* @__PURE__ */ jsx(
6321
- Root16,
6503
+ Root18,
6322
6504
  {
6323
6505
  ref,
6324
6506
  className: cn(MoonUItoggleVariantsPro({ variant, size, className })),
6325
6507
  ...props
6326
6508
  }
6327
6509
  ));
6328
- MoonUITogglePro.displayName = Root16.displayName;
6510
+ MoonUITogglePro.displayName = Root18.displayName;
6329
6511
  var MoonUITooltipProviderPro = TooltipPrimitive.Provider;
6330
6512
  var tooltipVariants = cva(
6331
6513
  "z-50 overflow-hidden rounded-md border bg-popover px-3 py-1.5 text-sm text-popover-foreground shadow-md animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",
@@ -7457,7 +7639,7 @@ function EventDialog({
7457
7639
  return /* @__PURE__ */ jsx(MoonUIDialogPro, { open, onOpenChange, children: /* @__PURE__ */ jsxs(MoonUIDialogContentPro, { className: "sm:max-w-[500px]", children: [
7458
7640
  /* @__PURE__ */ jsxs(MoonUIDialogHeaderPro, { children: [
7459
7641
  /* @__PURE__ */ jsxs(MoonUIDialogTitlePro, { className: "flex items-center gap-2", children: [
7460
- /* @__PURE__ */ jsx(Calendar, { className: "w-5 h-5" }),
7642
+ /* @__PURE__ */ jsx(Calendar$1, { className: "w-5 h-5" }),
7461
7643
  mode === "create" ? "Create Event" : "Edit Event"
7462
7644
  ] }),
7463
7645
  /* @__PURE__ */ jsx(MoonUIDialogDescriptionPro, { children: mode === "create" ? "Add a new event to your calendar." : "Edit the event details." })
@@ -7659,7 +7841,7 @@ var EVENT_COLORS = {
7659
7841
  reminder: "bg-yellow-500",
7660
7842
  event: "bg-purple-500"
7661
7843
  };
7662
- function Calendar2({
7844
+ function Calendar3({
7663
7845
  events = [],
7664
7846
  onEventClick,
7665
7847
  onEventAdd,
@@ -7829,7 +8011,7 @@ function Calendar2({
7829
8011
  /* @__PURE__ */ jsx(MoonUICardHeaderPro, { children: /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between", children: [
7830
8012
  /* @__PURE__ */ jsxs("div", { children: [
7831
8013
  /* @__PURE__ */ jsxs(MoonUICardTitlePro, { className: "flex items-center gap-2", children: [
7832
- /* @__PURE__ */ jsx(Calendar, { className: "h-5 w-5" }),
8014
+ /* @__PURE__ */ jsx(Calendar$1, { className: "h-5 w-5" }),
7833
8015
  "Calendar"
7834
8016
  ] }),
7835
8017
  /* @__PURE__ */ jsxs(MoonUICardDescriptionPro, { children: [
@@ -8265,7 +8447,7 @@ function Kanban({
8265
8447
  "flex items-center gap-1",
8266
8448
  isOverdue(card.dueDate) && "text-destructive"
8267
8449
  ), children: [
8268
- /* @__PURE__ */ jsx(Calendar, { className: "h-3 w-3" }),
8450
+ /* @__PURE__ */ jsx(Calendar$1, { className: "h-3 w-3" }),
8269
8451
  /* @__PURE__ */ jsx("span", { children: formatDate(card.dueDate) })
8270
8452
  ] })
8271
8453
  ] }),
@@ -48887,7 +49069,7 @@ function Timeline({
48887
49069
  /* @__PURE__ */ jsx("span", { children: event.metadata.duration })
48888
49070
  ] }),
48889
49071
  event.metadata.location && /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1", children: [
48890
- /* @__PURE__ */ jsx(Calendar, { className: "h-3 w-3" }),
49072
+ /* @__PURE__ */ jsx(Calendar$1, { className: "h-3 w-3" }),
48891
49073
  /* @__PURE__ */ jsx("span", { children: event.metadata.location })
48892
49074
  ] }),
48893
49075
  event.metadata.comments && event.metadata.comments > 0 && /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1", children: [
@@ -49149,14 +49331,18 @@ function AdvancedChart({
49149
49331
  }, [selectedTheme]);
49150
49332
  const gradientId = t__default.useId();
49151
49333
  const trend = t__default.useMemo(() => {
49152
- if (!data.length || !series.length)
49334
+ if (!data || !Array.isArray(data) || !data.length || !series || !Array.isArray(series) || !series.length)
49153
49335
  return null;
49154
49336
  const firstSeries = series[0];
49337
+ if (!firstSeries || !firstSeries.dataKey)
49338
+ return null;
49155
49339
  const values = data.map((d) => Number(d[firstSeries.dataKey])).filter((v) => !isNaN(v));
49156
49340
  if (values.length < 2)
49157
49341
  return null;
49158
49342
  const first2 = values[0];
49159
49343
  const last = values[values.length - 1];
49344
+ if (first2 === 0)
49345
+ return null;
49160
49346
  const change = (last - first2) / first2 * 100;
49161
49347
  return {
49162
49348
  direction: change > 0 ? "up" : change < 0 ? "down" : "neutral",
@@ -49179,9 +49365,9 @@ function AdvancedChart({
49179
49365
  toggleSeriesVisibility(entry.dataKey);
49180
49366
  }
49181
49367
  };
49182
- const handleExport = (format) => {
49368
+ const handleExport = (format2) => {
49183
49369
  if (onExport) {
49184
- onExport(format);
49370
+ onExport(format2);
49185
49371
  }
49186
49372
  };
49187
49373
  const handleZoom = (direction) => {
@@ -49210,6 +49396,9 @@ function AdvancedChart({
49210
49396
  );
49211
49397
  }) });
49212
49398
  const renderChart = () => {
49399
+ if (!data || !Array.isArray(data) || !series || !Array.isArray(series)) {
49400
+ return /* @__PURE__ */ jsx("div", { className: "flex items-center justify-center h-full text-muted-foreground", children: "No data available" });
49401
+ }
49213
49402
  const commonProps = {
49214
49403
  data,
49215
49404
  width: typeof width === "string" ? void 0 : width,
@@ -49998,43 +50187,147 @@ function AdvancedChart({
49998
50187
  }
49999
50188
  );
50000
50189
  }
50001
- var METRIC_COLORS = {
50002
- primary: "text-blue-600",
50003
- success: "text-green-600",
50004
- warning: "text-yellow-600",
50005
- danger: "text-red-600",
50006
- info: "text-purple-600"
50007
- };
50008
- var WIDGET_SIZES = {
50009
- sm: "col-span-1",
50010
- md: "col-span-2",
50011
- lg: "col-span-3",
50012
- xl: "col-span-4"
50013
- };
50014
- function Dashboard({
50015
- metrics = [],
50016
- widgets = [],
50017
- onMetricClick,
50018
- onWidgetAction,
50190
+ function MetricCard({
50191
+ data,
50192
+ onClick,
50193
+ onAction,
50019
50194
  className,
50020
- showHeader = true,
50021
- title = "Dashboard",
50022
- description = "Overview of your key metrics and performance",
50023
- refreshable = true,
50024
- onRefresh,
50025
- loading = false
50195
+ showSparkline = true,
50196
+ showForecast = false,
50197
+ interactive = true,
50198
+ glassmorphism = false
50026
50199
  }) {
50027
- const [refreshing, setRefreshing] = t__default.useState(false);
50028
- const handleRefresh = async () => {
50029
- if (onRefresh) {
50030
- setRefreshing(true);
50031
- try {
50032
- await onRefresh();
50033
- } finally {
50034
- setRefreshing(false);
50035
- }
50200
+ const [isHovered, setIsHovered] = t__default.useState(false);
50201
+ const colorClasses = {
50202
+ primary: "text-blue-600 dark:text-blue-400",
50203
+ success: "text-green-600 dark:text-green-400",
50204
+ warning: "text-yellow-600 dark:text-yellow-400",
50205
+ danger: "text-red-600 dark:text-red-400",
50206
+ info: "text-purple-600 dark:text-purple-400"
50207
+ };
50208
+ const getChangeColor = (type) => {
50209
+ switch (type) {
50210
+ case "increase":
50211
+ return "text-green-600 dark:text-green-400";
50212
+ case "decrease":
50213
+ return "text-red-600 dark:text-red-400";
50214
+ default:
50215
+ return "text-gray-600 dark:text-gray-400";
50216
+ }
50217
+ };
50218
+ const getChangeIcon = (type) => {
50219
+ switch (type) {
50220
+ case "increase":
50221
+ return /* @__PURE__ */ jsx(ArrowUpRight, { className: "h-4 w-4" });
50222
+ case "decrease":
50223
+ return /* @__PURE__ */ jsx(ArrowDownRight, { className: "h-4 w-4" });
50224
+ default:
50225
+ return /* @__PURE__ */ jsx(Minus, { className: "h-4 w-4" });
50036
50226
  }
50037
50227
  };
50228
+ const renderSparkline = () => {
50229
+ if (!data.sparkline || data.sparkline.length < 2)
50230
+ return null;
50231
+ const max = Math.max(...data.sparkline);
50232
+ const min = Math.min(...data.sparkline);
50233
+ const range = max - min || 1;
50234
+ const points = data.sparkline.map((value, index) => {
50235
+ const x = index / (data.sparkline.length - 1) * 100;
50236
+ const y = 100 - (value - min) / range * 100;
50237
+ return `${x},${y}`;
50238
+ }).join(" ");
50239
+ const gradientId = `gradient-${data.id}`;
50240
+ return /* @__PURE__ */ jsx(
50241
+ motion.div,
50242
+ {
50243
+ className: "absolute bottom-0 left-0 right-0 h-16 overflow-hidden rounded-b-lg opacity-20",
50244
+ initial: { opacity: 0 },
50245
+ animate: { opacity: isHovered ? 0.3 : 0.2 },
50246
+ transition: { duration: 0.2 },
50247
+ children: /* @__PURE__ */ jsxs(
50248
+ "svg",
50249
+ {
50250
+ className: "w-full h-full",
50251
+ viewBox: "0 0 100 100",
50252
+ preserveAspectRatio: "none",
50253
+ children: [
50254
+ /* @__PURE__ */ jsx("defs", { children: /* @__PURE__ */ jsxs("linearGradient", { id: gradientId, x1: "0%", y1: "0%", x2: "0%", y2: "100%", children: [
50255
+ /* @__PURE__ */ jsx("stop", { offset: "0%", stopColor: "currentColor", stopOpacity: "0.3" }),
50256
+ /* @__PURE__ */ jsx("stop", { offset: "100%", stopColor: "currentColor", stopOpacity: "0" })
50257
+ ] }) }),
50258
+ /* @__PURE__ */ jsx(
50259
+ "polyline",
50260
+ {
50261
+ fill: "none",
50262
+ stroke: "currentColor",
50263
+ strokeWidth: "2",
50264
+ points,
50265
+ className: colorClasses[data.color || "primary"]
50266
+ }
50267
+ ),
50268
+ /* @__PURE__ */ jsx(
50269
+ "polygon",
50270
+ {
50271
+ fill: `url(#${gradientId})`,
50272
+ points: `0,100 ${points} 100,100`,
50273
+ className: colorClasses[data.color || "primary"]
50274
+ }
50275
+ )
50276
+ ]
50277
+ }
50278
+ )
50279
+ }
50280
+ );
50281
+ };
50282
+ const renderProgress = () => {
50283
+ if (!data.target)
50284
+ return null;
50285
+ const currentValue = typeof data.value === "number" ? data.value : parseFloat(data.value);
50286
+ const progress = currentValue / data.target * 100;
50287
+ return /* @__PURE__ */ jsxs(
50288
+ motion.div,
50289
+ {
50290
+ className: "mt-3",
50291
+ initial: { opacity: 0, y: 10 },
50292
+ animate: { opacity: 1, y: 0 },
50293
+ transition: { delay: 0.1 },
50294
+ children: [
50295
+ /* @__PURE__ */ jsxs("div", { className: "flex justify-between text-xs text-muted-foreground mb-1", children: [
50296
+ /* @__PURE__ */ jsx("span", { children: "Progress to target" }),
50297
+ /* @__PURE__ */ jsxs("span", { children: [
50298
+ progress.toFixed(1),
50299
+ "%"
50300
+ ] })
50301
+ ] }),
50302
+ /* @__PURE__ */ jsx("div", { className: "h-1.5 bg-muted rounded-full overflow-hidden", children: /* @__PURE__ */ jsx(
50303
+ motion.div,
50304
+ {
50305
+ className: cn(
50306
+ "h-full rounded-full",
50307
+ progress >= 100 ? "bg-green-500" : "bg-primary"
50308
+ ),
50309
+ initial: { width: 0 },
50310
+ animate: { width: `${Math.min(progress, 100)}%` },
50311
+ transition: { duration: 0.5, ease: "easeOut" }
50312
+ }
50313
+ ) }),
50314
+ /* @__PURE__ */ jsxs("div", { className: "flex justify-between text-xs text-muted-foreground mt-1", children: [
50315
+ /* @__PURE__ */ jsxs("span", { children: [
50316
+ currentValue,
50317
+ " ",
50318
+ data.unit
50319
+ ] }),
50320
+ /* @__PURE__ */ jsxs("span", { children: [
50321
+ "Target: ",
50322
+ data.target,
50323
+ " ",
50324
+ data.unit
50325
+ ] })
50326
+ ] })
50327
+ ]
50328
+ }
50329
+ );
50330
+ };
50038
50331
  const formatValue = (value) => {
50039
50332
  if (typeof value === "number") {
50040
50333
  if (value >= 1e6) {
@@ -50046,159 +50339,1703 @@ function Dashboard({
50046
50339
  }
50047
50340
  return value.toString();
50048
50341
  };
50049
- const getChangeIcon = (type) => {
50050
- switch (type) {
50051
- case "increase":
50052
- return /* @__PURE__ */ jsx(ArrowUpRight, { className: "h-4 w-4" });
50053
- case "decrease":
50054
- return /* @__PURE__ */ jsx(ArrowDownRight, { className: "h-4 w-4" });
50055
- case "neutral":
50056
- return /* @__PURE__ */ jsx(Minus, { className: "h-4 w-4" });
50057
- }
50342
+ const cardVariants = {
50343
+ initial: { opacity: 0, y: 20 },
50344
+ animate: {
50345
+ opacity: 1,
50346
+ y: 0,
50347
+ transition: { duration: 0.3, ease: "easeOut" }
50348
+ },
50349
+ hover: interactive ? {
50350
+ y: -2,
50351
+ transition: { duration: 0.2 }
50352
+ } : {}
50058
50353
  };
50059
- const getChangeColor = (type) => {
50060
- switch (type) {
50061
- case "increase":
50062
- return "text-green-600";
50063
- case "decrease":
50064
- return "text-red-600";
50065
- case "neutral":
50066
- return "text-gray-600";
50354
+ return /* @__PURE__ */ jsx(
50355
+ motion.div,
50356
+ {
50357
+ variants: cardVariants,
50358
+ initial: "initial",
50359
+ animate: "animate",
50360
+ whileHover: "hover",
50361
+ onHoverStart: () => setIsHovered(true),
50362
+ onHoverEnd: () => setIsHovered(false),
50363
+ children: /* @__PURE__ */ jsxs(
50364
+ MoonUICardPro,
50365
+ {
50366
+ className: cn(
50367
+ "relative overflow-hidden cursor-pointer transition-all duration-300",
50368
+ interactive && "hover:shadow-lg hover:shadow-primary/5",
50369
+ glassmorphism && "bg-background/60 backdrop-blur-md border-white/10",
50370
+ className
50371
+ ),
50372
+ onClick,
50373
+ children: [
50374
+ glassmorphism && /* @__PURE__ */ jsx("div", { className: "absolute inset-0 bg-gradient-to-br from-primary/5 to-transparent" }),
50375
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between p-4 pb-2", children: [
50376
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-3", children: [
50377
+ /* @__PURE__ */ jsx(
50378
+ motion.div,
50379
+ {
50380
+ className: cn(
50381
+ "p-2 rounded-lg",
50382
+ glassmorphism ? "bg-white/10 backdrop-blur" : "bg-muted"
50383
+ ),
50384
+ whileHover: { scale: 1.05 },
50385
+ whileTap: { scale: 0.95 },
50386
+ children: /* @__PURE__ */ jsx("div", { className: cn("h-5 w-5", colorClasses[data.color || "primary"]), children: data.icon })
50387
+ }
50388
+ ),
50389
+ /* @__PURE__ */ jsx("div", { children: /* @__PURE__ */ jsx("h3", { className: "text-sm font-medium text-muted-foreground", children: data.title }) })
50390
+ ] }),
50391
+ interactive && /* @__PURE__ */ jsxs(MoonUIDropdownMenuPro, { children: [
50392
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuTriggerPro, { asChild: true, children: /* @__PURE__ */ jsx(
50393
+ MoonUIButtonPro,
50394
+ {
50395
+ variant: "ghost",
50396
+ size: "sm",
50397
+ className: "h-8 w-8 p-0",
50398
+ onClick: (e) => e.stopPropagation(),
50399
+ children: /* @__PURE__ */ jsx(MoreVertical, { className: "h-4 w-4" })
50400
+ }
50401
+ ) }),
50402
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuContentPro, { align: "end", children: [
50403
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => onAction?.("fullscreen"), children: [
50404
+ /* @__PURE__ */ jsx(Maximize2, { className: "mr-2 h-4 w-4" }),
50405
+ "Fullscreen"
50406
+ ] }),
50407
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => onAction?.("export"), children: [
50408
+ /* @__PURE__ */ jsx(Download, { className: "mr-2 h-4 w-4" }),
50409
+ "Export Data"
50410
+ ] }),
50411
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => onAction?.("share"), children: [
50412
+ /* @__PURE__ */ jsx(Share2, { className: "mr-2 h-4 w-4" }),
50413
+ "Share"
50414
+ ] })
50415
+ ] })
50416
+ ] })
50417
+ ] }),
50418
+ /* @__PURE__ */ jsxs("div", { className: "px-4 pb-4", children: [
50419
+ /* @__PURE__ */ jsx(MoonUITooltipProviderPro, { children: /* @__PURE__ */ jsxs(MoonUITooltipPro, { children: [
50420
+ /* @__PURE__ */ jsx(MoonUITooltipTriggerPro, { asChild: true, children: /* @__PURE__ */ jsxs(
50421
+ motion.div,
50422
+ {
50423
+ className: "text-3xl font-bold tracking-tight",
50424
+ animate: {
50425
+ scale: isHovered ? 1.02 : 1
50426
+ },
50427
+ transition: { duration: 0.2 },
50428
+ children: [
50429
+ formatValue(data.value),
50430
+ data.unit && /* @__PURE__ */ jsx("span", { className: "text-lg ml-1 text-muted-foreground", children: data.unit })
50431
+ ]
50432
+ }
50433
+ ) }),
50434
+ /* @__PURE__ */ jsx(MoonUITooltipContentPro, { children: /* @__PURE__ */ jsxs("p", { children: [
50435
+ "Exact value: ",
50436
+ data.value,
50437
+ " ",
50438
+ data.unit
50439
+ ] }) })
50440
+ ] }) }),
50441
+ data.change && /* @__PURE__ */ jsxs(
50442
+ motion.div,
50443
+ {
50444
+ className: cn(
50445
+ "flex items-center gap-1 text-sm mt-2",
50446
+ getChangeColor(data.change.type)
50447
+ ),
50448
+ initial: { opacity: 0, x: -10 },
50449
+ animate: { opacity: 1, x: 0 },
50450
+ transition: { delay: 0.1 },
50451
+ children: [
50452
+ getChangeIcon(data.change.type),
50453
+ /* @__PURE__ */ jsxs("span", { className: "font-medium", children: [
50454
+ data.change.type === "neutral" ? "" : data.change.type === "increase" ? "+" : "-",
50455
+ Math.abs(data.change.value),
50456
+ "%"
50457
+ ] }),
50458
+ /* @__PURE__ */ jsxs("span", { className: "text-muted-foreground", children: [
50459
+ "from ",
50460
+ data.change.period
50461
+ ] })
50462
+ ]
50463
+ }
50464
+ ),
50465
+ showForecast && data.forecast && /* @__PURE__ */ jsxs(
50466
+ motion.div,
50467
+ {
50468
+ className: "flex items-center gap-1 text-xs text-muted-foreground mt-1",
50469
+ initial: { opacity: 0 },
50470
+ animate: { opacity: 1 },
50471
+ transition: { delay: 0.2 },
50472
+ children: [
50473
+ /* @__PURE__ */ jsx(TrendingUp, { className: "h-3 w-3" }),
50474
+ /* @__PURE__ */ jsxs("span", { children: [
50475
+ "Forecast: ",
50476
+ formatValue(data.forecast),
50477
+ " ",
50478
+ data.unit
50479
+ ] })
50480
+ ]
50481
+ }
50482
+ ),
50483
+ renderProgress()
50484
+ ] }),
50485
+ showSparkline && renderSparkline()
50486
+ ]
50487
+ }
50488
+ )
50067
50489
  }
50068
- };
50069
- const renderMetricCard = (metric) => {
50070
- const colorClass = metric.color ? METRIC_COLORS[metric.color] : "text-foreground";
50490
+ );
50491
+ }
50492
+ var CHART_COLORS = {
50493
+ default: ["#3b82f6", "#10b981", "#f59e0b", "#ef4444", "#8b5cf6", "#ec4899"],
50494
+ pastel: ["#93c5fd", "#86efac", "#fcd34d", "#fca5a5", "#c4b5fd", "#fbcfe8"],
50495
+ vibrant: ["#2563eb", "#059669", "#d97706", "#dc2626", "#7c3aed", "#db2777"],
50496
+ monochrome: ["#1f2937", "#374151", "#4b5563", "#6b7280", "#9ca3af", "#d1d5db"]
50497
+ };
50498
+ function ChartWidget({
50499
+ id,
50500
+ title,
50501
+ description,
50502
+ data,
50503
+ className,
50504
+ height = 300,
50505
+ onAction,
50506
+ loading = false,
50507
+ refreshing = false,
50508
+ glassmorphism = false,
50509
+ interactive = true
50510
+ }) {
50511
+ const [colorScheme, setColorScheme] = t__default.useState("default");
50512
+ const [isFullscreen, setIsFullscreen] = t__default.useState(false);
50513
+ const colors = CHART_COLORS[colorScheme];
50514
+ const CustomTooltip2 = ({ active, payload, label }) => {
50515
+ if (!active || !payload)
50516
+ return null;
50071
50517
  return /* @__PURE__ */ jsxs(
50072
- MoonUICardPro,
50518
+ motion.div,
50073
50519
  {
50520
+ initial: { opacity: 0, scale: 0.9 },
50521
+ animate: { opacity: 1, scale: 1 },
50074
50522
  className: cn(
50075
- "cursor-pointer hover:shadow-md transition-shadow",
50076
- onMetricClick && "hover:bg-muted/50"
50523
+ "p-3 rounded-lg shadow-lg",
50524
+ glassmorphism ? "bg-background/80 backdrop-blur-md border border-white/10" : "bg-background border"
50077
50525
  ),
50078
- onClick: () => onMetricClick?.(metric),
50079
50526
  children: [
50080
- /* @__PURE__ */ jsxs(MoonUICardHeaderPro, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
50081
- /* @__PURE__ */ jsx(MoonUICardTitlePro, { className: "text-sm font-medium", children: metric.title }),
50082
- /* @__PURE__ */ jsx("div", { className: cn("h-4 w-4", colorClass), children: metric.icon })
50527
+ /* @__PURE__ */ jsx("p", { className: "text-sm font-medium", children: label }),
50528
+ payload.map((entry, index) => /* @__PURE__ */ jsxs("p", { className: "text-sm mt-1", children: [
50529
+ /* @__PURE__ */ jsx(
50530
+ "span",
50531
+ {
50532
+ className: "inline-block w-3 h-3 rounded-full mr-2",
50533
+ style: { backgroundColor: entry.color }
50534
+ }
50535
+ ),
50536
+ entry.name,
50537
+ ": ",
50538
+ entry.value
50539
+ ] }, index))
50540
+ ]
50541
+ }
50542
+ );
50543
+ };
50544
+ const renderChart = () => {
50545
+ if (!data.data || data.data.length === 0) {
50546
+ return /* @__PURE__ */ jsx("div", { className: "flex items-center justify-center h-full text-muted-foreground", children: "No data available" });
50547
+ }
50548
+ const chartProps = {
50549
+ data: data.data,
50550
+ margin: { top: 5, right: 30, left: 20, bottom: 5 }
50551
+ };
50552
+ switch (data.type) {
50553
+ case "line":
50554
+ return /* @__PURE__ */ jsx(ResponsiveContainer, { width: "100%", height, children: /* @__PURE__ */ jsxs(LineChart, { ...chartProps, children: [
50555
+ /* @__PURE__ */ jsx(CartesianGrid, { strokeDasharray: "3 3", className: "opacity-30" }),
50556
+ /* @__PURE__ */ jsx(XAxis, { dataKey: "name" }),
50557
+ /* @__PURE__ */ jsx(YAxis, {}),
50558
+ /* @__PURE__ */ jsx(Tooltip, { content: /* @__PURE__ */ jsx(CustomTooltip2, {}) }),
50559
+ interactive && /* @__PURE__ */ jsx(Legend, {}),
50560
+ Object.keys(data.data[0]).filter((key) => key !== "name").map((key, index) => /* @__PURE__ */ jsx(
50561
+ Line,
50562
+ {
50563
+ type: "monotone",
50564
+ dataKey: key,
50565
+ stroke: colors[index % colors.length],
50566
+ strokeWidth: 2,
50567
+ dot: { r: 4 },
50568
+ activeDot: { r: 6 }
50569
+ },
50570
+ key
50571
+ ))
50572
+ ] }) });
50573
+ case "bar":
50574
+ return /* @__PURE__ */ jsx(ResponsiveContainer, { width: "100%", height, children: /* @__PURE__ */ jsxs(BarChart, { ...chartProps, children: [
50575
+ /* @__PURE__ */ jsx(CartesianGrid, { strokeDasharray: "3 3", className: "opacity-30" }),
50576
+ /* @__PURE__ */ jsx(XAxis, { dataKey: "name" }),
50577
+ /* @__PURE__ */ jsx(YAxis, {}),
50578
+ /* @__PURE__ */ jsx(Tooltip, { content: /* @__PURE__ */ jsx(CustomTooltip2, {}) }),
50579
+ interactive && /* @__PURE__ */ jsx(Legend, {}),
50580
+ Object.keys(data.data[0]).filter((key) => key !== "name").map((key, index) => /* @__PURE__ */ jsx(
50581
+ Bar,
50582
+ {
50583
+ dataKey: key,
50584
+ fill: colors[index % colors.length],
50585
+ radius: [4, 4, 0, 0]
50586
+ },
50587
+ key
50588
+ ))
50589
+ ] }) });
50590
+ case "area":
50591
+ return /* @__PURE__ */ jsx(ResponsiveContainer, { width: "100%", height, children: /* @__PURE__ */ jsxs(AreaChart, { ...chartProps, children: [
50592
+ /* @__PURE__ */ jsx(CartesianGrid, { strokeDasharray: "3 3", className: "opacity-30" }),
50593
+ /* @__PURE__ */ jsx(XAxis, { dataKey: "name" }),
50594
+ /* @__PURE__ */ jsx(YAxis, {}),
50595
+ /* @__PURE__ */ jsx(Tooltip, { content: /* @__PURE__ */ jsx(CustomTooltip2, {}) }),
50596
+ interactive && /* @__PURE__ */ jsx(Legend, {}),
50597
+ Object.keys(data.data[0]).filter((key) => key !== "name").map((key, index) => /* @__PURE__ */ jsx(
50598
+ Area,
50599
+ {
50600
+ type: "monotone",
50601
+ dataKey: key,
50602
+ stroke: colors[index % colors.length],
50603
+ fill: colors[index % colors.length],
50604
+ fillOpacity: 0.2
50605
+ },
50606
+ key
50607
+ ))
50608
+ ] }) });
50609
+ case "pie":
50610
+ case "donut":
50611
+ return /* @__PURE__ */ jsx(ResponsiveContainer, { width: "100%", height, children: /* @__PURE__ */ jsxs(PieChart, { children: [
50612
+ /* @__PURE__ */ jsx(
50613
+ Pie,
50614
+ {
50615
+ data: data.data,
50616
+ cx: "50%",
50617
+ cy: "50%",
50618
+ labelLine: false,
50619
+ label: interactive,
50620
+ outerRadius: data.type === "donut" ? 80 : 100,
50621
+ innerRadius: data.type === "donut" ? 50 : 0,
50622
+ fill: "#8884d8",
50623
+ dataKey: "value",
50624
+ children: data.data.map((entry, index) => /* @__PURE__ */ jsx(Cell, { fill: colors[index % colors.length] }, `cell-${index}`))
50625
+ }
50626
+ ),
50627
+ /* @__PURE__ */ jsx(Tooltip, { content: /* @__PURE__ */ jsx(CustomTooltip2, {}) }),
50628
+ interactive && /* @__PURE__ */ jsx(Legend, {})
50629
+ ] }) });
50630
+ case "radar":
50631
+ return /* @__PURE__ */ jsx(ResponsiveContainer, { width: "100%", height, children: /* @__PURE__ */ jsxs(RadarChart, { data: data.data, children: [
50632
+ /* @__PURE__ */ jsx(PolarGrid, {}),
50633
+ /* @__PURE__ */ jsx(PolarAngleAxis, { dataKey: "subject" }),
50634
+ /* @__PURE__ */ jsx(PolarRadiusAxis, {}),
50635
+ Object.keys(data.data[0]).filter((key) => key !== "subject").map((key, index) => /* @__PURE__ */ jsx(
50636
+ Radar,
50637
+ {
50638
+ name: key,
50639
+ dataKey: key,
50640
+ stroke: colors[index % colors.length],
50641
+ fill: colors[index % colors.length],
50642
+ fillOpacity: 0.3
50643
+ },
50644
+ key
50645
+ )),
50646
+ /* @__PURE__ */ jsx(Tooltip, { content: /* @__PURE__ */ jsx(CustomTooltip2, {}) }),
50647
+ interactive && /* @__PURE__ */ jsx(Legend, {})
50648
+ ] }) });
50649
+ default:
50650
+ return null;
50651
+ }
50652
+ };
50653
+ const cardVariants = {
50654
+ initial: { opacity: 0, scale: 0.95 },
50655
+ animate: {
50656
+ opacity: 1,
50657
+ scale: 1,
50658
+ transition: { duration: 0.3, ease: "easeOut" }
50659
+ }
50660
+ };
50661
+ return /* @__PURE__ */ jsx(
50662
+ motion.div,
50663
+ {
50664
+ variants: cardVariants,
50665
+ initial: "initial",
50666
+ animate: "animate",
50667
+ className: cn(isFullscreen && "fixed inset-4 z-50"),
50668
+ children: /* @__PURE__ */ jsxs(MoonUICardPro, { className: cn(
50669
+ "relative overflow-hidden transition-all duration-300",
50670
+ glassmorphism && "bg-background/60 backdrop-blur-md border-white/10",
50671
+ isFullscreen && "h-full",
50672
+ className
50673
+ ), children: [
50674
+ /* @__PURE__ */ jsxs(MoonUICardHeaderPro, { className: "flex flex-row items-center justify-between space-y-0 pb-2", children: [
50675
+ /* @__PURE__ */ jsxs("div", { children: [
50676
+ /* @__PURE__ */ jsx(MoonUICardTitlePro, { className: "text-base font-semibold", children: title }),
50677
+ description && /* @__PURE__ */ jsx("p", { className: "text-sm text-muted-foreground mt-1", children: description })
50083
50678
  ] }),
50084
- /* @__PURE__ */ jsxs(MoonUICardContentPro, { children: [
50085
- /* @__PURE__ */ jsx("div", { className: "text-2xl font-bold", children: formatValue(metric.value) }),
50086
- metric.change && /* @__PURE__ */ jsxs("div", { className: cn(
50087
- "flex items-center text-xs mt-1",
50088
- getChangeColor(metric.change.type)
50089
- ), children: [
50090
- getChangeIcon(metric.change.type),
50091
- /* @__PURE__ */ jsxs("span", { className: "ml-1", children: [
50092
- Math.abs(metric.change.value),
50093
- "% from ",
50094
- metric.change.period
50679
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
50680
+ refreshing && /* @__PURE__ */ jsx(
50681
+ motion.div,
50682
+ {
50683
+ animate: { rotate: 360 },
50684
+ transition: { duration: 1, repeat: Infinity, ease: "linear" },
50685
+ children: /* @__PURE__ */ jsx(RefreshCw, { className: "h-4 w-4 text-muted-foreground" })
50686
+ }
50687
+ ),
50688
+ interactive && /* @__PURE__ */ jsxs(MoonUIDropdownMenuPro, { children: [
50689
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuTriggerPro, { asChild: true, children: /* @__PURE__ */ jsx(MoonUIButtonPro, { variant: "ghost", size: "sm", className: "h-8 w-8 p-0", children: /* @__PURE__ */ jsx(MoreVertical, { className: "h-4 w-4" }) }) }),
50690
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuContentPro, { align: "end", className: "w-48", children: [
50691
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => {
50692
+ setIsFullscreen(!isFullscreen);
50693
+ onAction?.("fullscreen", { fullscreen: !isFullscreen });
50694
+ }, children: [
50695
+ /* @__PURE__ */ jsx(Maximize2, { className: "mr-2 h-4 w-4" }),
50696
+ isFullscreen ? "Exit Fullscreen" : "Fullscreen"
50697
+ ] }),
50698
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuSubPro, { children: [
50699
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuSubTriggerPro, { children: [
50700
+ /* @__PURE__ */ jsx(Palette, { className: "mr-2 h-4 w-4" }),
50701
+ "Color Scheme"
50702
+ ] }),
50703
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuSubContentPro, { children: Object.keys(CHART_COLORS).map((scheme2) => /* @__PURE__ */ jsx(
50704
+ MoonUIDropdownMenuItemPro,
50705
+ {
50706
+ onClick: () => setColorScheme(scheme2),
50707
+ children: /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
50708
+ /* @__PURE__ */ jsx("div", { className: "flex gap-1", children: CHART_COLORS[scheme2].slice(0, 3).map((color, i) => /* @__PURE__ */ jsx(
50709
+ "div",
50710
+ {
50711
+ className: "w-3 h-3 rounded-full",
50712
+ style: { backgroundColor: color }
50713
+ },
50714
+ i
50715
+ )) }),
50716
+ /* @__PURE__ */ jsx("span", { className: "capitalize", children: scheme2 })
50717
+ ] })
50718
+ },
50719
+ scheme2
50720
+ )) })
50721
+ ] }),
50722
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuSeparatorPro, {}),
50723
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => onAction?.("export", { format: "png" }), children: [
50724
+ /* @__PURE__ */ jsx(Download, { className: "mr-2 h-4 w-4" }),
50725
+ "Export as PNG"
50726
+ ] }),
50727
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => onAction?.("export", { format: "csv" }), children: [
50728
+ /* @__PURE__ */ jsx(Download, { className: "mr-2 h-4 w-4" }),
50729
+ "Export Data"
50730
+ ] }),
50731
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuSeparatorPro, {}),
50732
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => onAction?.("filter"), children: [
50733
+ /* @__PURE__ */ jsx(Filter, { className: "mr-2 h-4 w-4" }),
50734
+ "Filter Data"
50735
+ ] }),
50736
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => onAction?.("settings"), children: [
50737
+ /* @__PURE__ */ jsx(Settings, { className: "mr-2 h-4 w-4" }),
50738
+ "Chart Settings"
50739
+ ] })
50095
50740
  ] })
50096
- ] }),
50097
- metric.description && /* @__PURE__ */ jsx("p", { className: "text-xs text-muted-foreground mt-1", children: metric.description })
50741
+ ] })
50098
50742
  ] })
50099
- ]
50100
- },
50101
- metric.id
50102
- );
50743
+ ] }),
50744
+ /* @__PURE__ */ jsx(MoonUICardContentPro, { className: "p-0 px-4 pb-4", children: /* @__PURE__ */ jsx(AnimatePresence, { mode: "wait", children: loading ? /* @__PURE__ */ jsx(
50745
+ motion.div,
50746
+ {
50747
+ initial: { opacity: 0 },
50748
+ animate: { opacity: 1 },
50749
+ exit: { opacity: 0 },
50750
+ className: "flex items-center justify-center",
50751
+ style: { height },
50752
+ children: /* @__PURE__ */ jsxs("div", { className: "space-y-2", children: [
50753
+ /* @__PURE__ */ jsx("div", { className: "animate-pulse bg-muted h-4 w-32 rounded" }),
50754
+ /* @__PURE__ */ jsx("div", { className: "animate-pulse bg-muted h-4 w-24 rounded" }),
50755
+ /* @__PURE__ */ jsx("div", { className: "animate-pulse bg-muted h-4 w-28 rounded" })
50756
+ ] })
50757
+ },
50758
+ "loading"
50759
+ ) : /* @__PURE__ */ jsx(
50760
+ motion.div,
50761
+ {
50762
+ initial: { opacity: 0, y: 10 },
50763
+ animate: { opacity: 1, y: 0 },
50764
+ exit: { opacity: 0, y: -10 },
50765
+ transition: { duration: 0.3 },
50766
+ children: renderChart()
50767
+ },
50768
+ "chart"
50769
+ ) }) })
50770
+ ] })
50771
+ }
50772
+ );
50773
+ }
50774
+ function ActivityFeed({
50775
+ items,
50776
+ title = "Activity Feed",
50777
+ className,
50778
+ height = 400,
50779
+ onItemClick,
50780
+ onAction,
50781
+ loading = false,
50782
+ showFilters = true,
50783
+ showNotifications = true,
50784
+ glassmorphism = false,
50785
+ realtime = false
50786
+ }) {
50787
+ const [filter, setFilter] = t__default.useState("all");
50788
+ const [notificationsEnabled, setNotificationsEnabled] = t__default.useState(true);
50789
+ const [newItems, setNewItems] = t__default.useState([]);
50790
+ t__default.useEffect(() => {
50791
+ if (!realtime)
50792
+ return;
50793
+ const interval = setInterval(() => {
50794
+ const randomItem = {
50795
+ id: `new-${Date.now()}`,
50796
+ type: ["info", "success", "warning", "error"][Math.floor(Math.random() * 4)],
50797
+ title: "New activity",
50798
+ description: "Something happened just now",
50799
+ timestamp: /* @__PURE__ */ new Date(),
50800
+ user: {
50801
+ name: "System",
50802
+ avatar: void 0
50803
+ }
50804
+ };
50805
+ setNewItems((prev) => [randomItem, ...prev].slice(0, 3));
50806
+ setTimeout(() => {
50807
+ setNewItems((prev) => prev.filter((item) => item.id !== randomItem.id));
50808
+ }, 5e3);
50809
+ }, 1e4);
50810
+ return () => clearInterval(interval);
50811
+ }, [realtime]);
50812
+ const getTypeIcon = (type) => {
50813
+ switch (type) {
50814
+ case "info":
50815
+ return /* @__PURE__ */ jsx(Info, { className: "h-4 w-4" });
50816
+ case "success":
50817
+ return /* @__PURE__ */ jsx(CheckCircle, { className: "h-4 w-4" });
50818
+ case "warning":
50819
+ return /* @__PURE__ */ jsx(AlertCircle, { className: "h-4 w-4" });
50820
+ case "error":
50821
+ return /* @__PURE__ */ jsx(XCircle, { className: "h-4 w-4" });
50822
+ }
50103
50823
  };
50104
- const renderWidget = (widget) => {
50105
- const sizeClass = WIDGET_SIZES[widget.size || "md"];
50106
- return /* @__PURE__ */ jsxs(MoonUICardPro, { className: cn("h-fit", sizeClass), children: [
50107
- /* @__PURE__ */ jsx(MoonUICardHeaderPro, { children: /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between", children: [
50108
- /* @__PURE__ */ jsxs("div", { children: [
50109
- /* @__PURE__ */ jsx(MoonUICardTitlePro, { className: "text-base", children: widget.title }),
50110
- widget.description && /* @__PURE__ */ jsx(MoonUICardDescriptionPro, { className: "mt-1", children: widget.description })
50824
+ const getTypeColor = (type) => {
50825
+ switch (type) {
50826
+ case "info":
50827
+ return "text-blue-500 bg-blue-100 dark:bg-blue-900/20";
50828
+ case "success":
50829
+ return "text-green-500 bg-green-100 dark:bg-green-900/20";
50830
+ case "warning":
50831
+ return "text-yellow-500 bg-yellow-100 dark:bg-yellow-900/20";
50832
+ case "error":
50833
+ return "text-red-500 bg-red-100 dark:bg-red-900/20";
50834
+ }
50835
+ };
50836
+ const filteredItems = [...newItems, ...items].filter(
50837
+ (item) => filter === "all" || item.type === filter
50838
+ );
50839
+ const renderActivityItem = (item, isNew = false) => /* @__PURE__ */ jsxs(
50840
+ motion.div,
50841
+ {
50842
+ layout: true,
50843
+ initial: { opacity: 0, x: -20 },
50844
+ animate: { opacity: 1, x: 0 },
50845
+ exit: { opacity: 0, x: 20 },
50846
+ whileHover: { x: 4 },
50847
+ transition: { duration: 0.2 },
50848
+ className: cn(
50849
+ "group relative flex gap-3 p-3 rounded-lg cursor-pointer transition-colors",
50850
+ "hover:bg-muted/50",
50851
+ isNew && "bg-primary/5 border-l-2 border-primary"
50852
+ ),
50853
+ onClick: () => onItemClick?.(item),
50854
+ children: [
50855
+ /* @__PURE__ */ jsx("div", { className: "absolute left-7 top-12 bottom-0 w-px bg-border" }),
50856
+ /* @__PURE__ */ jsx("div", { className: "relative z-10 flex-shrink-0", children: item.user?.avatar ? /* @__PURE__ */ jsxs(MoonUIAvatarPro, { className: "h-8 w-8", children: [
50857
+ /* @__PURE__ */ jsx(MoonUIAvatarImagePro, { src: item.user.avatar }),
50858
+ /* @__PURE__ */ jsx(MoonUIAvatarFallbackPro, { children: item.user.name[0] })
50859
+ ] }) : /* @__PURE__ */ jsx("div", { className: cn(
50860
+ "h-8 w-8 rounded-full flex items-center justify-center",
50861
+ getTypeColor(item.type)
50862
+ ), children: item.icon || getTypeIcon(item.type) }) }),
50863
+ /* @__PURE__ */ jsxs("div", { className: "flex-1 min-w-0", children: [
50864
+ /* @__PURE__ */ jsxs("div", { className: "flex items-start justify-between gap-2", children: [
50865
+ /* @__PURE__ */ jsxs("div", { className: "flex-1 min-w-0", children: [
50866
+ /* @__PURE__ */ jsxs("p", { className: "text-sm font-medium leading-tight", children: [
50867
+ item.user?.name && /* @__PURE__ */ jsxs("span", { className: "text-foreground", children: [
50868
+ item.user.name,
50869
+ " "
50870
+ ] }),
50871
+ /* @__PURE__ */ jsx("span", { className: "text-muted-foreground", children: item.title })
50872
+ ] }),
50873
+ item.description && /* @__PURE__ */ jsx("p", { className: "text-sm text-muted-foreground mt-0.5 line-clamp-2", children: item.description })
50874
+ ] }),
50875
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1 text-xs text-muted-foreground whitespace-nowrap", children: [
50876
+ /* @__PURE__ */ jsx(Clock, { className: "h-3 w-3" }),
50877
+ formatDistanceToNow(item.timestamp, { addSuffix: true })
50878
+ ] })
50879
+ ] }),
50880
+ isNew && /* @__PURE__ */ jsx(
50881
+ motion.div,
50882
+ {
50883
+ initial: { scale: 0 },
50884
+ animate: { scale: 1 },
50885
+ className: "inline-block mt-1",
50886
+ children: /* @__PURE__ */ jsx(MoonUIBadgePro, { variant: "default", className: "text-xs", children: "New" })
50887
+ }
50888
+ )
50111
50889
  ] }),
50890
+ /* @__PURE__ */ jsx("div", { className: "opacity-0 group-hover:opacity-100 transition-opacity", children: /* @__PURE__ */ jsx(
50891
+ MoonUIButtonPro,
50892
+ {
50893
+ variant: "ghost",
50894
+ size: "sm",
50895
+ className: "h-6 w-6 p-0",
50896
+ onClick: (e) => {
50897
+ e.stopPropagation();
50898
+ onAction?.("more", item);
50899
+ },
50900
+ children: /* @__PURE__ */ jsx(MoreHorizontal, { className: "h-3 w-3" })
50901
+ }
50902
+ ) })
50903
+ ]
50904
+ },
50905
+ item.id
50906
+ );
50907
+ return /* @__PURE__ */ jsxs(MoonUICardPro, { className: cn(
50908
+ "relative overflow-hidden",
50909
+ glassmorphism && "bg-background/60 backdrop-blur-md border-white/10",
50910
+ className
50911
+ ), children: [
50912
+ /* @__PURE__ */ jsxs(MoonUICardHeaderPro, { className: "flex flex-row items-center justify-between space-y-0 pb-3", children: [
50913
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
50914
+ /* @__PURE__ */ jsx(Activity, { className: "h-4 w-4 text-muted-foreground" }),
50915
+ /* @__PURE__ */ jsx(MoonUICardTitlePro, { className: "text-base font-semibold", children: title }),
50916
+ realtime && /* @__PURE__ */ jsxs(MoonUIBadgePro, { variant: "secondary", className: "text-xs", children: [
50917
+ /* @__PURE__ */ jsx("span", { className: "mr-1 h-1.5 w-1.5 rounded-full bg-green-500 animate-pulse" }),
50918
+ "Live"
50919
+ ] })
50920
+ ] }),
50921
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1", children: [
50922
+ showFilters && /* @__PURE__ */ jsxs(MoonUIDropdownMenuPro, { children: [
50923
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuTriggerPro, { asChild: true, children: /* @__PURE__ */ jsxs(MoonUIButtonPro, { variant: "ghost", size: "sm", className: "h-8 px-2", children: [
50924
+ /* @__PURE__ */ jsx(Filter, { className: "h-4 w-4 mr-1" }),
50925
+ filter !== "all" && /* @__PURE__ */ jsx(MoonUIBadgePro, { variant: "secondary", className: "ml-1", children: filter })
50926
+ ] }) }),
50927
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuContentPro, { align: "end", children: [
50928
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuItemPro, { onClick: () => setFilter("all"), children: "All Activities" }),
50929
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuSeparatorPro, {}),
50930
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => setFilter("info"), children: [
50931
+ /* @__PURE__ */ jsx(Info, { className: "mr-2 h-4 w-4 text-blue-500" }),
50932
+ "Information"
50933
+ ] }),
50934
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => setFilter("success"), children: [
50935
+ /* @__PURE__ */ jsx(CheckCircle, { className: "mr-2 h-4 w-4 text-green-500" }),
50936
+ "Success"
50937
+ ] }),
50938
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => setFilter("warning"), children: [
50939
+ /* @__PURE__ */ jsx(AlertCircle, { className: "mr-2 h-4 w-4 text-yellow-500" }),
50940
+ "Warning"
50941
+ ] }),
50942
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => setFilter("error"), children: [
50943
+ /* @__PURE__ */ jsx(XCircle, { className: "mr-2 h-4 w-4 text-red-500" }),
50944
+ "Error"
50945
+ ] })
50946
+ ] })
50947
+ ] }),
50948
+ showNotifications && /* @__PURE__ */ jsx(
50949
+ MoonUIButtonPro,
50950
+ {
50951
+ variant: "ghost",
50952
+ size: "sm",
50953
+ className: "h-8 w-8 p-0",
50954
+ onClick: () => {
50955
+ setNotificationsEnabled(!notificationsEnabled);
50956
+ onAction?.("notifications", { enabled: !notificationsEnabled });
50957
+ },
50958
+ children: notificationsEnabled ? /* @__PURE__ */ jsx(Bell, { className: "h-4 w-4" }) : /* @__PURE__ */ jsx(BellOff, { className: "h-4 w-4 text-muted-foreground" })
50959
+ }
50960
+ ),
50112
50961
  /* @__PURE__ */ jsx(
50113
50962
  MoonUIButtonPro,
50114
50963
  {
50115
50964
  variant: "ghost",
50116
50965
  size: "sm",
50117
- onClick: () => onWidgetAction?.(widget.id, "menu"),
50118
- children: /* @__PURE__ */ jsx(BarChart3, { className: "h-4 w-4" })
50966
+ className: "h-8 w-8 p-0",
50967
+ onClick: () => onAction?.("refresh"),
50968
+ children: /* @__PURE__ */ jsx(RefreshCw, { className: "h-4 w-4" })
50119
50969
  }
50120
50970
  )
50121
- ] }) }),
50122
- /* @__PURE__ */ jsx(MoonUICardContentPro, { children: widget.loading ? /* @__PURE__ */ jsx("div", { className: "flex items-center justify-center h-32", children: /* @__PURE__ */ jsx("div", { className: "animate-spin rounded-full h-8 w-8 border-b-2 border-primary" }) }) : widget.error ? /* @__PURE__ */ jsx("div", { className: "flex items-center justify-center h-32 text-destructive", children: /* @__PURE__ */ jsx("p", { className: "text-sm", children: widget.error }) }) : widget.content })
50123
- ] }, widget.id);
50971
+ ] })
50972
+ ] }),
50973
+ /* @__PURE__ */ jsx(MoonUICardContentPro, { className: "p-0", children: /* @__PURE__ */ jsx(ScrollArea, { className: "px-4 pb-4", style: { height }, children: /* @__PURE__ */ jsx(AnimatePresence, { mode: "popLayout", children: loading ? /* @__PURE__ */ jsx(
50974
+ motion.div,
50975
+ {
50976
+ initial: { opacity: 0 },
50977
+ animate: { opacity: 1 },
50978
+ exit: { opacity: 0 },
50979
+ className: "space-y-3",
50980
+ children: [...Array(5)].map((_, i) => /* @__PURE__ */ jsxs("div", { className: "flex gap-3", children: [
50981
+ /* @__PURE__ */ jsx("div", { className: "h-8 w-8 rounded-full bg-muted animate-pulse" }),
50982
+ /* @__PURE__ */ jsxs("div", { className: "flex-1 space-y-2", children: [
50983
+ /* @__PURE__ */ jsx("div", { className: "h-4 bg-muted rounded animate-pulse" }),
50984
+ /* @__PURE__ */ jsx("div", { className: "h-3 bg-muted rounded w-3/4 animate-pulse" })
50985
+ ] })
50986
+ ] }, i))
50987
+ },
50988
+ "loading"
50989
+ ) : filteredItems.length === 0 ? /* @__PURE__ */ jsxs(
50990
+ motion.div,
50991
+ {
50992
+ initial: { opacity: 0 },
50993
+ animate: { opacity: 1 },
50994
+ className: "flex flex-col items-center justify-center py-12 text-muted-foreground",
50995
+ children: [
50996
+ /* @__PURE__ */ jsx(Activity, { className: "h-8 w-8 mb-2" }),
50997
+ /* @__PURE__ */ jsx("p", { className: "text-sm", children: "No activities to show" })
50998
+ ]
50999
+ },
51000
+ "empty"
51001
+ ) : /* @__PURE__ */ jsx("div", { className: "space-y-1", children: filteredItems.map(
51002
+ (item) => renderActivityItem(item, newItems.some((newItem) => newItem.id === item.id))
51003
+ ) }) }) }) })
51004
+ ] });
51005
+ }
51006
+
51007
+ // node_modules/react-resizable/css/styles.css
51008
+ styleInject(".react-resizable {\n position: relative;\n}\n.react-resizable-handle {\n position: absolute;\n width: 20px;\n height: 20px;\n background-repeat: no-repeat;\n background-origin: content-box;\n box-sizing: border-box;\n background-image: url();\n background-position: bottom right;\n padding: 0 3px 3px 0;\n}\n.react-resizable-handle-sw {\n bottom: 0;\n left: 0;\n cursor: sw-resize;\n transform: rotate(90deg);\n}\n.react-resizable-handle-se {\n bottom: 0;\n right: 0;\n cursor: se-resize;\n}\n.react-resizable-handle-nw {\n top: 0;\n left: 0;\n cursor: nw-resize;\n transform: rotate(180deg);\n}\n.react-resizable-handle-ne {\n top: 0;\n right: 0;\n cursor: ne-resize;\n transform: rotate(270deg);\n}\n.react-resizable-handle-w,\n.react-resizable-handle-e {\n top: 50%;\n margin-top: -10px;\n cursor: ew-resize;\n}\n.react-resizable-handle-w {\n left: 0;\n transform: rotate(135deg);\n}\n.react-resizable-handle-e {\n right: 0;\n transform: rotate(315deg);\n}\n.react-resizable-handle-n,\n.react-resizable-handle-s {\n left: 50%;\n margin-left: -10px;\n cursor: ns-resize;\n}\n.react-resizable-handle-n {\n top: 0;\n transform: rotate(225deg);\n}\n.react-resizable-handle-s {\n bottom: 0;\n transform: rotate(45deg);\n}\n");
51009
+ function DashboardGrid({
51010
+ widgets,
51011
+ onLayoutChange,
51012
+ onWidgetRemove,
51013
+ onWidgetAction,
51014
+ editMode = false,
51015
+ className,
51016
+ glassmorphism = false,
51017
+ breakpoints = { lg: 1200, md: 996, sm: 768, xs: 480, xxs: 0 },
51018
+ cols = { lg: 12, md: 10, sm: 6, xs: 4, xxs: 2 },
51019
+ rowHeight = 60,
51020
+ margin = [16, 16],
51021
+ containerPadding = [0, 0]
51022
+ }) {
51023
+ t__default.useState({});
51024
+ const [currentBreakpoint, setCurrentBreakpoint] = t__default.useState("lg");
51025
+ const [lockedWidgets, setLockedWidgets] = t__default.useState(/* @__PURE__ */ new Set());
51026
+ const [fullscreenWidget, setFullscreenWidget] = t__default.useState(null);
51027
+ const generateLayout = () => {
51028
+ return widgets.map((widget) => ({
51029
+ i: widget.id,
51030
+ x: widget.position.x,
51031
+ y: widget.position.y,
51032
+ w: widget.size.w,
51033
+ h: widget.size.h,
51034
+ minW: widget.size.minW || 2,
51035
+ maxW: widget.size.maxW || 12,
51036
+ minH: widget.size.minH || 2,
51037
+ maxH: widget.size.maxH || 8,
51038
+ isDraggable: editMode && !lockedWidgets.has(widget.id) && widget.permissions?.canMove !== false,
51039
+ isResizable: editMode && !lockedWidgets.has(widget.id) && widget.permissions?.canResize !== false
51040
+ }));
50124
51041
  };
50125
- const defaultMetrics = [
50126
- {
50127
- id: "total-users",
50128
- title: "Total Users",
50129
- value: 2543,
50130
- change: { value: 12, type: "increase", period: "last month" },
50131
- icon: /* @__PURE__ */ jsx(Users, { className: "h-4 w-4" }),
50132
- color: "primary"
50133
- },
50134
- {
50135
- id: "revenue",
50136
- title: "Revenue",
50137
- value: "$12,345",
50138
- change: { value: 8, type: "increase", period: "last month" },
50139
- icon: /* @__PURE__ */ jsx(DollarSign, { className: "h-4 w-4" }),
50140
- color: "success"
50141
- },
50142
- {
50143
- id: "active-sessions",
50144
- title: "Active Sessions",
50145
- value: 1234,
50146
- change: { value: 2, type: "decrease", period: "last hour" },
50147
- icon: /* @__PURE__ */ jsx(Activity, { className: "h-4 w-4" }),
50148
- color: "warning"
50149
- },
50150
- {
50151
- id: "conversion-rate",
50152
- title: "Conversion Rate",
50153
- value: "3.2%",
50154
- change: { value: 0.3, type: "increase", period: "last week" },
50155
- icon: /* @__PURE__ */ jsx(TrendingUp, { className: "h-4 w-4" }),
50156
- color: "info"
51042
+ const toggleWidgetLock = (widgetId) => {
51043
+ setLockedWidgets((prev) => {
51044
+ const newSet = new Set(prev);
51045
+ if (newSet.has(widgetId)) {
51046
+ newSet.delete(widgetId);
51047
+ } else {
51048
+ newSet.add(widgetId);
51049
+ }
51050
+ return newSet;
51051
+ });
51052
+ };
51053
+ const toggleFullscreen = (widgetId) => {
51054
+ if (fullscreenWidget === widgetId) {
51055
+ setFullscreenWidget(null);
51056
+ } else {
51057
+ setFullscreenWidget(widgetId);
50157
51058
  }
50158
- ];
50159
- const displayMetrics = metrics.length > 0 ? metrics : defaultMetrics;
50160
- if (loading) {
50161
- return /* @__PURE__ */ jsx("div", { className: cn("w-full", className), children: /* @__PURE__ */ jsxs("div", { className: "animate-pulse space-y-4", children: [
50162
- /* @__PURE__ */ jsx("div", { className: "h-8 bg-muted rounded w-1/4" }),
50163
- /* @__PURE__ */ jsx("div", { className: "grid gap-4 md:grid-cols-2 lg:grid-cols-4", children: [...Array(4)].map((_, i) => /* @__PURE__ */ jsx("div", { className: "h-32 bg-muted rounded" }, i)) })
50164
- ] }) });
50165
- }
50166
- return /* @__PURE__ */ jsxs("div", { className: cn("w-full space-y-6", className), children: [
50167
- showHeader && /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between", children: [
50168
- /* @__PURE__ */ jsxs("div", { children: [
50169
- /* @__PURE__ */ jsx("h1", { className: "text-2xl font-bold tracking-tight", children: title }),
50170
- /* @__PURE__ */ jsx("p", { className: "text-muted-foreground", children: description })
50171
- ] }),
50172
- refreshable && /* @__PURE__ */ jsxs(
50173
- MoonUIButtonPro,
51059
+ };
51060
+ const renderWidget = (widget) => {
51061
+ const isLocked = lockedWidgets.has(widget.id);
51062
+ const isFullscreen = fullscreenWidget === widget.id;
51063
+ const widgetContent = () => {
51064
+ switch (widget.type) {
51065
+ case "metric":
51066
+ return /* @__PURE__ */ jsx(
51067
+ MetricCard,
51068
+ {
51069
+ data: widget.data,
51070
+ onAction: (action) => onWidgetAction?.(widget.id, action),
51071
+ glassmorphism
51072
+ }
51073
+ );
51074
+ case "chart":
51075
+ return /* @__PURE__ */ jsx(
51076
+ ChartWidget,
51077
+ {
51078
+ id: widget.id,
51079
+ title: widget.title,
51080
+ description: widget.description,
51081
+ data: widget.data,
51082
+ loading: widget.loading,
51083
+ glassmorphism,
51084
+ onAction: (action, data) => onWidgetAction?.(widget.id, action, data)
51085
+ }
51086
+ );
51087
+ case "activity":
51088
+ return /* @__PURE__ */ jsx(
51089
+ ActivityFeed,
51090
+ {
51091
+ items: widget.data?.items || [],
51092
+ title: widget.title,
51093
+ loading: widget.loading,
51094
+ glassmorphism,
51095
+ realtime: widget.data?.realtime,
51096
+ onAction: (action, data) => onWidgetAction?.(widget.id, action, data)
51097
+ }
51098
+ );
51099
+ default:
51100
+ return /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-center h-full text-muted-foreground", children: [
51101
+ "Widget type not supported: ",
51102
+ widget.type
51103
+ ] });
51104
+ }
51105
+ };
51106
+ return /* @__PURE__ */ jsxs(
51107
+ motion.div,
51108
+ {
51109
+ className: cn(
51110
+ "relative group h-full",
51111
+ isFullscreen && "!fixed !inset-4 !z-50 !h-auto !w-auto"
51112
+ ),
51113
+ layout: !isFullscreen,
51114
+ transition: { duration: 0.2 },
51115
+ children: [
51116
+ /* @__PURE__ */ jsx("div", { className: "h-full", children: widgetContent() }),
51117
+ editMode && !isFullscreen && /* @__PURE__ */ jsx(
51118
+ motion.div,
51119
+ {
51120
+ initial: { opacity: 0 },
51121
+ animate: { opacity: 1 },
51122
+ className: "absolute top-2 right-2 z-10 opacity-0 group-hover:opacity-100 transition-opacity",
51123
+ children: /* @__PURE__ */ jsxs("div", { className: cn(
51124
+ "flex items-center gap-1 p-1 rounded-lg",
51125
+ glassmorphism ? "bg-background/80 backdrop-blur-sm" : "bg-background/95",
51126
+ "border shadow-sm"
51127
+ ), children: [
51128
+ !isLocked && /* @__PURE__ */ jsx("div", { className: "drag-handle cursor-move p-1 hover:bg-muted rounded", children: /* @__PURE__ */ jsx(Grip, { className: "h-4 w-4" }) }),
51129
+ /* @__PURE__ */ jsx(
51130
+ MoonUIButtonPro,
51131
+ {
51132
+ variant: "ghost",
51133
+ size: "sm",
51134
+ className: "h-6 w-6 p-0",
51135
+ onClick: () => toggleWidgetLock(widget.id),
51136
+ children: isLocked ? /* @__PURE__ */ jsx(Lock, { className: "h-3 w-3" }) : /* @__PURE__ */ jsx(Unlock, { className: "h-3 w-3" })
51137
+ }
51138
+ ),
51139
+ /* @__PURE__ */ jsx(
51140
+ MoonUIButtonPro,
51141
+ {
51142
+ variant: "ghost",
51143
+ size: "sm",
51144
+ className: "h-6 w-6 p-0",
51145
+ onClick: () => toggleFullscreen(widget.id),
51146
+ children: /* @__PURE__ */ jsx(Maximize2, { className: "h-3 w-3" })
51147
+ }
51148
+ ),
51149
+ /* @__PURE__ */ jsx(
51150
+ MoonUIButtonPro,
51151
+ {
51152
+ variant: "ghost",
51153
+ size: "sm",
51154
+ className: "h-6 w-6 p-0",
51155
+ onClick: () => onWidgetAction?.(widget.id, "settings"),
51156
+ children: /* @__PURE__ */ jsx(Settings, { className: "h-3 w-3" })
51157
+ }
51158
+ ),
51159
+ widget.permissions?.canDelete !== false && /* @__PURE__ */ jsx(
51160
+ MoonUIButtonPro,
51161
+ {
51162
+ variant: "ghost",
51163
+ size: "sm",
51164
+ className: "h-6 w-6 p-0 text-destructive hover:text-destructive",
51165
+ onClick: () => onWidgetRemove?.(widget.id),
51166
+ children: /* @__PURE__ */ jsx(X, { className: "h-3 w-3" })
51167
+ }
51168
+ )
51169
+ ] })
51170
+ }
51171
+ ),
51172
+ isFullscreen && /* @__PURE__ */ jsx(
51173
+ motion.div,
51174
+ {
51175
+ initial: { opacity: 0, y: -10 },
51176
+ animate: { opacity: 1, y: 0 },
51177
+ className: "absolute top-4 right-4 z-10",
51178
+ children: /* @__PURE__ */ jsxs(
51179
+ MoonUIButtonPro,
51180
+ {
51181
+ variant: "outline",
51182
+ size: "sm",
51183
+ onClick: () => toggleFullscreen(widget.id),
51184
+ children: [
51185
+ /* @__PURE__ */ jsx(Minimize2, { className: "h-4 w-4 mr-2" }),
51186
+ "Exit Fullscreen"
51187
+ ]
51188
+ }
51189
+ )
51190
+ }
51191
+ )
51192
+ ]
51193
+ },
51194
+ widget.id
51195
+ );
51196
+ };
51197
+ return /* @__PURE__ */ jsxs("div", { className: cn("w-full", className), children: [
51198
+ /* @__PURE__ */ jsx(AnimatePresence, { children: fullscreenWidget ? (
51199
+ // Fullscreen widget
51200
+ /* @__PURE__ */ jsx(
51201
+ motion.div,
50174
51202
  {
50175
- variant: "outline",
50176
- onClick: handleRefresh,
50177
- disabled: refreshing,
50178
- children: [
50179
- refreshing ? /* @__PURE__ */ jsx("div", { className: "animate-spin rounded-full h-4 w-4 border-b-2 border-primary mr-2" }) : /* @__PURE__ */ jsx(Activity, { className: "h-4 w-4 mr-2" }),
50180
- "Refresh"
50181
- ]
51203
+ initial: { opacity: 0 },
51204
+ animate: { opacity: 1 },
51205
+ exit: { opacity: 0 },
51206
+ className: "fixed inset-0 z-40 bg-background",
51207
+ children: widgets.filter((w2) => w2.id === fullscreenWidget).map(renderWidget)
50182
51208
  }
50183
51209
  )
51210
+ ) : (
51211
+ // Grid layout
51212
+ /* @__PURE__ */ jsx(
51213
+ GridLayout,
51214
+ {
51215
+ className: "layout",
51216
+ layout: generateLayout(),
51217
+ cols: cols[currentBreakpoint] || cols.lg,
51218
+ rowHeight,
51219
+ width: 1200,
51220
+ margin,
51221
+ containerPadding,
51222
+ onLayoutChange: (layout) => {
51223
+ onLayoutChange?.(layout);
51224
+ },
51225
+ onBreakpointChange: (breakpoint) => {
51226
+ setCurrentBreakpoint(breakpoint);
51227
+ },
51228
+ draggableHandle: ".drag-handle",
51229
+ isDraggable: editMode,
51230
+ isResizable: editMode,
51231
+ compactType: "vertical",
51232
+ preventCollision: false,
51233
+ children: widgets.map((widget) => /* @__PURE__ */ jsx("div", { children: renderWidget(widget) }, widget.id))
51234
+ }
51235
+ )
51236
+ ) }),
51237
+ editMode && !fullscreenWidget && /* @__PURE__ */ jsx(
51238
+ motion.div,
51239
+ {
51240
+ initial: { opacity: 0 },
51241
+ animate: { opacity: 0.1 },
51242
+ className: "absolute inset-0 pointer-events-none",
51243
+ style: {
51244
+ backgroundImage: `
51245
+ repeating-linear-gradient(
51246
+ 0deg,
51247
+ var(--border) 0px,
51248
+ transparent 1px,
51249
+ transparent ${rowHeight + margin[1]}px,
51250
+ var(--border) ${rowHeight + margin[1]}px
51251
+ ),
51252
+ repeating-linear-gradient(
51253
+ 90deg,
51254
+ var(--border) 0px,
51255
+ transparent 1px,
51256
+ transparent ${100 / cols[currentBreakpoint]}%,
51257
+ var(--border) ${100 / cols[currentBreakpoint]}%
51258
+ )
51259
+ `
51260
+ }
51261
+ }
51262
+ )
51263
+ ] });
51264
+ }
51265
+ var PRESET_RANGES = [
51266
+ {
51267
+ label: "Today",
51268
+ value: "today",
51269
+ getRange: () => ({
51270
+ start: startOfDay(/* @__PURE__ */ new Date()),
51271
+ end: endOfDay(/* @__PURE__ */ new Date()),
51272
+ label: "Today",
51273
+ preset: "today"
51274
+ })
51275
+ },
51276
+ {
51277
+ label: "Yesterday",
51278
+ value: "yesterday",
51279
+ getRange: () => ({
51280
+ start: startOfDay(subDays(/* @__PURE__ */ new Date(), 1)),
51281
+ end: endOfDay(subDays(/* @__PURE__ */ new Date(), 1)),
51282
+ label: "Yesterday",
51283
+ preset: "yesterday"
51284
+ })
51285
+ },
51286
+ {
51287
+ label: "Last 7 days",
51288
+ value: "last7days",
51289
+ getRange: () => ({
51290
+ start: startOfDay(subDays(/* @__PURE__ */ new Date(), 6)),
51291
+ end: endOfDay(/* @__PURE__ */ new Date()),
51292
+ label: "Last 7 days",
51293
+ preset: "last7days"
51294
+ })
51295
+ },
51296
+ {
51297
+ label: "Last 30 days",
51298
+ value: "last30days",
51299
+ getRange: () => ({
51300
+ start: startOfDay(subDays(/* @__PURE__ */ new Date(), 29)),
51301
+ end: endOfDay(/* @__PURE__ */ new Date()),
51302
+ label: "Last 30 days",
51303
+ preset: "last30days"
51304
+ })
51305
+ },
51306
+ {
51307
+ label: "This week",
51308
+ value: "thisWeek",
51309
+ getRange: () => ({
51310
+ start: startOfWeek(/* @__PURE__ */ new Date()),
51311
+ end: endOfWeek(/* @__PURE__ */ new Date()),
51312
+ label: "This week",
51313
+ preset: "custom"
51314
+ })
51315
+ },
51316
+ {
51317
+ label: "This month",
51318
+ value: "thisMonth",
51319
+ getRange: () => ({
51320
+ start: startOfMonth(/* @__PURE__ */ new Date()),
51321
+ end: endOfMonth(/* @__PURE__ */ new Date()),
51322
+ label: "This month",
51323
+ preset: "thisMonth"
51324
+ })
51325
+ },
51326
+ {
51327
+ label: "Last month",
51328
+ value: "lastMonth",
51329
+ getRange: () => {
51330
+ const lastMonth = subDays(startOfMonth(/* @__PURE__ */ new Date()), 1);
51331
+ return {
51332
+ start: startOfMonth(lastMonth),
51333
+ end: endOfMonth(lastMonth),
51334
+ label: "Last month",
51335
+ preset: "lastMonth"
51336
+ };
51337
+ }
51338
+ }
51339
+ ];
51340
+ function TimeRangePicker({
51341
+ value,
51342
+ onChange,
51343
+ className,
51344
+ showPresets = true,
51345
+ showComparison = false,
51346
+ glassmorphism = false
51347
+ }) {
51348
+ const [isOpen, setIsOpen] = t__default.useState(false);
51349
+ const [customRange, setCustomRange] = t__default.useState({});
51350
+ const [comparisonEnabled, setComparisonEnabled] = t__default.useState(false);
51351
+ const currentRange = value || PRESET_RANGES[2].getRange();
51352
+ const formatRange = (range) => {
51353
+ if (range.preset && range.preset !== "custom") {
51354
+ return range.label;
51355
+ }
51356
+ return `${format(range.start, "MMM d")} - ${format(range.end, "MMM d, yyyy")}`;
51357
+ };
51358
+ const handlePresetSelect = (preset) => {
51359
+ const range = preset.getRange();
51360
+ onChange?.(range);
51361
+ setIsOpen(false);
51362
+ };
51363
+ const handleCustomRangeSelect = () => {
51364
+ if (customRange.from && customRange.to) {
51365
+ onChange?.({
51366
+ start: startOfDay(customRange.from),
51367
+ end: endOfDay(customRange.to),
51368
+ label: `${format(customRange.from, "MMM d")} - ${format(customRange.to, "MMM d, yyyy")}`,
51369
+ preset: "custom"
51370
+ });
51371
+ setIsOpen(false);
51372
+ }
51373
+ };
51374
+ return /* @__PURE__ */ jsxs(MoonUIPopoverPro, { open: isOpen, onOpenChange: setIsOpen, children: [
51375
+ /* @__PURE__ */ jsx(MoonUIPopoverTriggerPro, { asChild: true, children: /* @__PURE__ */ jsxs(
51376
+ MoonUIButtonPro,
51377
+ {
51378
+ variant: "outline",
51379
+ className: cn(
51380
+ "justify-start text-left font-normal",
51381
+ glassmorphism && "bg-background/60 backdrop-blur-sm border-white/10",
51382
+ !value && "text-muted-foreground",
51383
+ className
51384
+ ),
51385
+ children: [
51386
+ /* @__PURE__ */ jsx(CalendarIcon, { className: "mr-2 h-4 w-4" }),
51387
+ formatRange(currentRange),
51388
+ /* @__PURE__ */ jsx(ChevronDown, { className: "ml-auto h-4 w-4 opacity-50" })
51389
+ ]
51390
+ }
51391
+ ) }),
51392
+ /* @__PURE__ */ jsx(
51393
+ MoonUIPopoverContentPro,
51394
+ {
51395
+ className: cn(
51396
+ "w-auto p-0",
51397
+ glassmorphism && "bg-background/95 backdrop-blur-md border-white/10"
51398
+ ),
51399
+ align: "start",
51400
+ children: /* @__PURE__ */ jsx(
51401
+ motion.div,
51402
+ {
51403
+ initial: { opacity: 0, y: -10 },
51404
+ animate: { opacity: 1, y: 0 },
51405
+ transition: { duration: 0.2 },
51406
+ children: /* @__PURE__ */ jsxs("div", { className: "flex", children: [
51407
+ showPresets && /* @__PURE__ */ jsxs("div", { className: "border-r p-3", children: [
51408
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2 px-2 pb-2", children: [
51409
+ /* @__PURE__ */ jsx(Clock, { className: "h-4 w-4 text-muted-foreground" }),
51410
+ /* @__PURE__ */ jsx("h4", { className: "text-sm font-medium", children: "Quick Select" })
51411
+ ] }),
51412
+ /* @__PURE__ */ jsx("div", { className: "space-y-1", children: PRESET_RANGES.map((preset) => /* @__PURE__ */ jsx(
51413
+ motion.button,
51414
+ {
51415
+ whileHover: { x: 2 },
51416
+ whileTap: { scale: 0.98 },
51417
+ onClick: () => handlePresetSelect(preset),
51418
+ className: cn(
51419
+ "w-full text-left px-2 py-1.5 text-sm rounded-md transition-colors",
51420
+ "hover:bg-muted",
51421
+ currentRange.preset === preset.value && "bg-primary text-primary-foreground"
51422
+ ),
51423
+ children: preset.label
51424
+ },
51425
+ preset.value
51426
+ )) }),
51427
+ showComparison && /* @__PURE__ */ jsx("div", { className: "mt-4 pt-4 border-t", children: /* @__PURE__ */ jsxs("label", { className: "flex items-center gap-2 px-2 cursor-pointer", children: [
51428
+ /* @__PURE__ */ jsx(
51429
+ "input",
51430
+ {
51431
+ type: "checkbox",
51432
+ checked: comparisonEnabled,
51433
+ onChange: (e) => setComparisonEnabled(e.target.checked),
51434
+ className: "rounded"
51435
+ }
51436
+ ),
51437
+ /* @__PURE__ */ jsx("span", { className: "text-sm", children: "Compare to previous period" })
51438
+ ] }) })
51439
+ ] }),
51440
+ /* @__PURE__ */ jsxs("div", { className: "p-3", children: [
51441
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2 px-2 pb-2", children: [
51442
+ /* @__PURE__ */ jsx(CalendarIcon, { className: "h-4 w-4 text-muted-foreground" }),
51443
+ /* @__PURE__ */ jsx("h4", { className: "text-sm font-medium", children: "Custom Range" })
51444
+ ] }),
51445
+ /* @__PURE__ */ jsx(
51446
+ Calendar,
51447
+ {
51448
+ mode: "range",
51449
+ selected: {
51450
+ from: customRange.from,
51451
+ to: customRange.to
51452
+ },
51453
+ onSelect: (range) => setCustomRange(range || {}),
51454
+ numberOfMonths: 2,
51455
+ className: "rounded-md"
51456
+ }
51457
+ ),
51458
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between pt-3 px-2", children: [
51459
+ /* @__PURE__ */ jsx("div", { className: "text-sm text-muted-foreground", children: customRange.from && customRange.to && /* @__PURE__ */ jsxs("span", { children: [
51460
+ Math.ceil((customRange.to.getTime() - customRange.from.getTime()) / (1e3 * 60 * 60 * 24)),
51461
+ " days selected"
51462
+ ] }) }),
51463
+ /* @__PURE__ */ jsxs("div", { className: "flex gap-2", children: [
51464
+ /* @__PURE__ */ jsx(
51465
+ MoonUIButtonPro,
51466
+ {
51467
+ variant: "ghost",
51468
+ size: "sm",
51469
+ onClick: () => {
51470
+ setCustomRange({});
51471
+ setIsOpen(false);
51472
+ },
51473
+ children: "Cancel"
51474
+ }
51475
+ ),
51476
+ /* @__PURE__ */ jsx(
51477
+ MoonUIButtonPro,
51478
+ {
51479
+ size: "sm",
51480
+ onClick: handleCustomRangeSelect,
51481
+ disabled: !customRange.from || !customRange.to,
51482
+ children: "Apply"
51483
+ }
51484
+ )
51485
+ ] })
51486
+ ] })
51487
+ ] })
51488
+ ] })
51489
+ }
51490
+ )
51491
+ }
51492
+ )
51493
+ ] });
51494
+ }
51495
+ var DASHBOARD_TEMPLATES = [
51496
+ {
51497
+ id: "analytics",
51498
+ name: "Analytics Dashboard",
51499
+ description: "Comprehensive analytics with metrics and charts",
51500
+ category: "analytics",
51501
+ theme: "analytics",
51502
+ widgets: [
51503
+ {
51504
+ type: "metric",
51505
+ title: "Total Revenue",
51506
+ size: { w: 3, h: 2 },
51507
+ position: { x: 0, y: 0 },
51508
+ data: {
51509
+ id: "revenue",
51510
+ title: "Total Revenue",
51511
+ value: 125430,
51512
+ change: { value: 12, type: "increase", period: "last month" },
51513
+ color: "success",
51514
+ icon: /* @__PURE__ */ jsx(DollarSign, { className: "h-4 w-4" }),
51515
+ sparkline: [100, 120, 115, 125, 130, 128, 132],
51516
+ unit: "$"
51517
+ }
51518
+ },
51519
+ {
51520
+ type: "metric",
51521
+ title: "Active Users",
51522
+ size: { w: 3, h: 2 },
51523
+ position: { x: 3, y: 0 },
51524
+ data: {
51525
+ id: "users",
51526
+ title: "Active Users",
51527
+ value: 2543,
51528
+ change: { value: 8, type: "increase", period: "last week" },
51529
+ color: "primary",
51530
+ icon: /* @__PURE__ */ jsx(Users, { className: "h-4 w-4" }),
51531
+ sparkline: [200, 220, 210, 230, 225, 240, 254]
51532
+ }
51533
+ },
51534
+ {
51535
+ type: "chart",
51536
+ title: "Revenue Trend",
51537
+ size: { w: 6, h: 4 },
51538
+ position: { x: 0, y: 2 },
51539
+ data: {
51540
+ type: "area",
51541
+ data: [
51542
+ { name: "Jan", revenue: 4e3, profit: 2400 },
51543
+ { name: "Feb", revenue: 3e3, profit: 1398 },
51544
+ { name: "Mar", revenue: 5e3, profit: 3200 },
51545
+ { name: "Apr", revenue: 4500, profit: 2900 },
51546
+ { name: "May", revenue: 6e3, profit: 3800 },
51547
+ { name: "Jun", revenue: 5500, profit: 3400 }
51548
+ ]
51549
+ }
51550
+ },
51551
+ {
51552
+ type: "activity",
51553
+ title: "Recent Activity",
51554
+ size: { w: 3, h: 6 },
51555
+ position: { x: 9, y: 0 },
51556
+ data: {
51557
+ realtime: true,
51558
+ items: [
51559
+ {
51560
+ id: "1",
51561
+ type: "success",
51562
+ title: "completed a purchase",
51563
+ description: "Order #12345 - $250.00",
51564
+ timestamp: new Date(Date.now() - 1e3 * 60 * 5),
51565
+ user: { name: "John Doe" }
51566
+ },
51567
+ {
51568
+ id: "2",
51569
+ type: "info",
51570
+ title: "signed up",
51571
+ description: "New user registration",
51572
+ timestamp: new Date(Date.now() - 1e3 * 60 * 15),
51573
+ user: { name: "Jane Smith" }
51574
+ }
51575
+ ]
51576
+ }
51577
+ }
51578
+ ]
51579
+ },
51580
+ {
51581
+ id: "sales",
51582
+ name: "Sales Dashboard",
51583
+ description: "Track sales performance and targets",
51584
+ category: "sales",
51585
+ theme: "sales",
51586
+ widgets: [
51587
+ // Sales-specific widgets
51588
+ ]
51589
+ },
51590
+ {
51591
+ id: "monitoring",
51592
+ name: "System Monitoring",
51593
+ description: "Monitor system health and performance",
51594
+ category: "operations",
51595
+ theme: "monitoring",
51596
+ widgets: [
51597
+ // Monitoring widgets
51598
+ ]
51599
+ }
51600
+ ];
51601
+ var WIDGET_TYPE_ICONS = {
51602
+ metric: /* @__PURE__ */ jsx(BarChart3, { className: "h-4 w-4" }),
51603
+ chart: /* @__PURE__ */ jsx(Activity, { className: "h-4 w-4" }),
51604
+ table: /* @__PURE__ */ jsx(Table$1, { className: "h-4 w-4" }),
51605
+ map: /* @__PURE__ */ jsx(Map$1, { className: "h-4 w-4" }),
51606
+ activity: /* @__PURE__ */ jsx(Clock, { className: "h-4 w-4" }),
51607
+ calendar: /* @__PURE__ */ jsx(Calendar$1, { className: "h-4 w-4" }),
51608
+ progress: /* @__PURE__ */ jsx(Target, { className: "h-4 w-4" }),
51609
+ comparison: /* @__PURE__ */ jsx(TrendingUp, { className: "h-4 w-4" })
51610
+ };
51611
+ var THEME_COLORS = {
51612
+ analytics: "from-blue-500/10 to-purple-500/10",
51613
+ sales: "from-green-500/10 to-emerald-500/10",
51614
+ monitoring: "from-orange-500/10 to-red-500/10",
51615
+ finance: "from-indigo-500/10 to-blue-500/10",
51616
+ custom: "from-gray-500/10 to-gray-600/10"
51617
+ };
51618
+ function Dashboard({
51619
+ config,
51620
+ widgets: initialWidgets = [],
51621
+ templates = DASHBOARD_TEMPLATES,
51622
+ onConfigChange,
51623
+ onWidgetAdd,
51624
+ onWidgetRemove,
51625
+ onWidgetUpdate,
51626
+ onExport,
51627
+ onImport,
51628
+ className,
51629
+ showHeader = true,
51630
+ title = "Dashboard",
51631
+ description = "Real-time analytics and insights",
51632
+ editable = true,
51633
+ realtime = false,
51634
+ glassmorphism = true
51635
+ }) {
51636
+ const [editMode, setEditMode] = t__default.useState(false);
51637
+ const [widgets, setWidgets] = t__default.useState(initialWidgets);
51638
+ const [selectedTheme, setSelectedTheme] = t__default.useState("analytics");
51639
+ const [timeRange, setTimeRange] = t__default.useState();
51640
+ const [searchQuery, setSearchQuery] = t__default.useState("");
51641
+ const [showWidgetLibrary, setShowWidgetLibrary] = t__default.useState(false);
51642
+ const [showTemplates, setShowTemplates] = t__default.useState(false);
51643
+ const [refreshing, setRefreshing] = t__default.useState(false);
51644
+ const [notifications, setNotifications] = t__default.useState(3);
51645
+ t__default.useEffect(() => {
51646
+ if (!realtime)
51647
+ return;
51648
+ const interval = setInterval(() => {
51649
+ setWidgets((prev) => prev.map((widget) => {
51650
+ if (widget.type === "metric" && widget.data) {
51651
+ const newValue = typeof widget.data.value === "number" ? widget.data.value + Math.floor(Math.random() * 10 - 5) : widget.data.value;
51652
+ return {
51653
+ ...widget,
51654
+ data: {
51655
+ ...widget.data,
51656
+ value: newValue,
51657
+ lastUpdated: /* @__PURE__ */ new Date()
51658
+ }
51659
+ };
51660
+ }
51661
+ return widget;
51662
+ }));
51663
+ }, 5e3);
51664
+ return () => clearInterval(interval);
51665
+ }, [realtime]);
51666
+ const handleAddWidget = (type) => {
51667
+ const newWidget = {
51668
+ id: `widget-${Date.now()}`,
51669
+ type,
51670
+ title: `New ${type} Widget`,
51671
+ size: { w: 3, h: 3 },
51672
+ position: { x: 0, y: 0 },
51673
+ data: generateDefaultData(type)
51674
+ };
51675
+ setWidgets((prev) => [...prev, newWidget]);
51676
+ onWidgetAdd?.(newWidget);
51677
+ setShowWidgetLibrary(false);
51678
+ };
51679
+ const applyTemplate = (template) => {
51680
+ const newWidgets = template.widgets.map((w2, index) => ({
51681
+ ...w2,
51682
+ id: `widget-${Date.now()}-${index}`
51683
+ }));
51684
+ setWidgets(newWidgets);
51685
+ setSelectedTheme(template.theme);
51686
+ setShowTemplates(false);
51687
+ };
51688
+ const generateDefaultData = (type) => {
51689
+ switch (type) {
51690
+ case "metric":
51691
+ return {
51692
+ id: "new-metric",
51693
+ title: "New Metric",
51694
+ value: 0,
51695
+ icon: /* @__PURE__ */ jsx(BarChart3, { className: "h-4 w-4" }),
51696
+ color: "primary"
51697
+ };
51698
+ case "chart":
51699
+ return {
51700
+ type: "line",
51701
+ data: [
51702
+ { name: "Mon", value: 100 },
51703
+ { name: "Tue", value: 120 },
51704
+ { name: "Wed", value: 110 },
51705
+ { name: "Thu", value: 130 },
51706
+ { name: "Fri", value: 125 }
51707
+ ]
51708
+ };
51709
+ case "activity":
51710
+ return {
51711
+ items: [],
51712
+ realtime: true
51713
+ };
51714
+ default:
51715
+ return {};
51716
+ }
51717
+ };
51718
+ const WidgetLibrary = () => /* @__PURE__ */ jsx(Sheet, { open: showWidgetLibrary, onOpenChange: setShowWidgetLibrary, children: /* @__PURE__ */ jsxs(SheetContent, { className: cn(
51719
+ "w-[400px] sm:w-[540px]",
51720
+ glassmorphism && "bg-background/95 backdrop-blur-md"
51721
+ ), children: [
51722
+ /* @__PURE__ */ jsxs(SheetHeader, { children: [
51723
+ /* @__PURE__ */ jsx(SheetTitle, { children: "Widget Library" }),
51724
+ /* @__PURE__ */ jsx(SheetDescription, { children: "Add widgets to customize your dashboard" })
50184
51725
  ] }),
50185
- /* @__PURE__ */ jsx("div", { className: "grid gap-4 md:grid-cols-2 lg:grid-cols-4", children: displayMetrics.map(renderMetricCard) }),
50186
- widgets.length > 0 && /* @__PURE__ */ jsx("div", { className: "grid gap-4 md:grid-cols-2 lg:grid-cols-4", children: widgets.map(renderWidget) }),
50187
- /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2 pt-4 border-t", children: [
50188
- /* @__PURE__ */ jsxs(MoonUIButtonPro, { variant: "outline", size: "sm", children: [
50189
- /* @__PURE__ */ jsx(Download, { className: "h-4 w-4 mr-2" }),
50190
- "Export Data"
51726
+ /* @__PURE__ */ jsxs("div", { className: "mt-6 space-y-4", children: [
51727
+ /* @__PURE__ */ jsxs("div", { className: "relative", children: [
51728
+ /* @__PURE__ */ jsx(Search, { className: "absolute left-3 top-3 h-4 w-4 text-muted-foreground" }),
51729
+ /* @__PURE__ */ jsx(
51730
+ MoonUIInputPro,
51731
+ {
51732
+ placeholder: "Search widgets...",
51733
+ value: searchQuery,
51734
+ onChange: (e) => setSearchQuery(e.target.value),
51735
+ className: "pl-10"
51736
+ }
51737
+ )
50191
51738
  ] }),
50192
- /* @__PURE__ */ jsxs(MoonUIButtonPro, { variant: "outline", size: "sm", children: [
50193
- /* @__PURE__ */ jsx(Calendar, { className: "h-4 w-4 mr-2" }),
50194
- "Schedule Report"
51739
+ /* @__PURE__ */ jsx(ScrollArea, { className: "h-[calc(100vh-200px)]", children: /* @__PURE__ */ jsx("div", { className: "grid grid-cols-2 gap-4", children: Object.entries(WIDGET_TYPE_ICONS).filter(([type]) => type.toLowerCase().includes(searchQuery.toLowerCase())).map(([type, icon]) => /* @__PURE__ */ jsx(
51740
+ motion.div,
51741
+ {
51742
+ whileHover: { scale: 1.02 },
51743
+ whileTap: { scale: 0.98 },
51744
+ children: /* @__PURE__ */ jsxs(
51745
+ MoonUIButtonPro,
51746
+ {
51747
+ variant: "outline",
51748
+ className: "w-full h-24 flex-col gap-2",
51749
+ onClick: () => handleAddWidget(type),
51750
+ children: [
51751
+ /* @__PURE__ */ jsx("div", { className: "p-2 rounded-lg bg-muted", children: icon }),
51752
+ /* @__PURE__ */ jsx("span", { className: "capitalize text-sm", children: type })
51753
+ ]
51754
+ }
51755
+ )
51756
+ },
51757
+ type
51758
+ )) }) })
51759
+ ] })
51760
+ ] }) });
51761
+ const TemplateGallery = () => /* @__PURE__ */ jsx(MoonUIDialogPro, { open: showTemplates, onOpenChange: setShowTemplates, children: /* @__PURE__ */ jsxs(MoonUIDialogContentPro, { className: cn(
51762
+ "max-w-4xl",
51763
+ glassmorphism && "bg-background/95 backdrop-blur-md"
51764
+ ), children: [
51765
+ /* @__PURE__ */ jsxs(MoonUIDialogHeaderPro, { children: [
51766
+ /* @__PURE__ */ jsx(MoonUIDialogTitlePro, { children: "Dashboard Templates" }),
51767
+ /* @__PURE__ */ jsx(MoonUIDialogDescriptionPro, { children: "Start with a pre-built template or create your own" })
51768
+ ] }),
51769
+ /* @__PURE__ */ jsxs(MoonUITabsPro, { defaultValue: "all", className: "mt-4", children: [
51770
+ /* @__PURE__ */ jsxs(MoonUITabsListPro, { children: [
51771
+ /* @__PURE__ */ jsx(MoonUITabsTriggerPro, { value: "all", children: "All Templates" }),
51772
+ /* @__PURE__ */ jsx(MoonUITabsTriggerPro, { value: "analytics", children: "Analytics" }),
51773
+ /* @__PURE__ */ jsx(MoonUITabsTriggerPro, { value: "sales", children: "Sales" }),
51774
+ /* @__PURE__ */ jsx(MoonUITabsTriggerPro, { value: "operations", children: "Operations" })
50195
51775
  ] }),
50196
- /* @__PURE__ */ jsxs(MoonUIButtonPro, { variant: "outline", size: "sm", children: [
50197
- /* @__PURE__ */ jsx(Star, { className: "h-4 w-4 mr-2" }),
50198
- "Save View"
50199
- ] })
51776
+ /* @__PURE__ */ jsx(MoonUITabsContentPro, { value: "all", className: "mt-4", children: /* @__PURE__ */ jsx("div", { className: "grid grid-cols-3 gap-4", children: templates.map((template) => /* @__PURE__ */ jsx(
51777
+ motion.div,
51778
+ {
51779
+ whileHover: { y: -4 },
51780
+ className: "cursor-pointer",
51781
+ onClick: () => applyTemplate(template),
51782
+ children: /* @__PURE__ */ jsxs("div", { className: cn(
51783
+ "relative overflow-hidden rounded-lg border p-4 hover:shadow-lg transition-all",
51784
+ "bg-gradient-to-br",
51785
+ THEME_COLORS[template.theme]
51786
+ ), children: [
51787
+ template.isPro && /* @__PURE__ */ jsx(MoonUIBadgePro, { className: "absolute top-2 right-2", variant: "secondary", children: "PRO" }),
51788
+ /* @__PURE__ */ jsx("h3", { className: "font-semibold mb-1", children: template.name }),
51789
+ /* @__PURE__ */ jsx("p", { className: "text-sm text-muted-foreground", children: template.description }),
51790
+ /* @__PURE__ */ jsxs("div", { className: "mt-3 flex items-center gap-2 text-xs text-muted-foreground", children: [
51791
+ /* @__PURE__ */ jsxs("span", { children: [
51792
+ template.widgets.length,
51793
+ " widgets"
51794
+ ] }),
51795
+ /* @__PURE__ */ jsx("span", { children: "\u2022" }),
51796
+ /* @__PURE__ */ jsx("span", { className: "capitalize", children: template.category })
51797
+ ] })
51798
+ ] })
51799
+ },
51800
+ template.id
51801
+ )) }) })
50200
51802
  ] })
50201
- ] });
51803
+ ] }) });
51804
+ return /* @__PURE__ */ jsxs(
51805
+ motion.div,
51806
+ {
51807
+ className: cn(
51808
+ "w-full min-h-screen",
51809
+ glassmorphism && "bg-gradient-to-br",
51810
+ glassmorphism && THEME_COLORS[selectedTheme],
51811
+ className
51812
+ ),
51813
+ initial: { opacity: 0 },
51814
+ animate: { opacity: 1 },
51815
+ transition: { duration: 0.5 },
51816
+ children: [
51817
+ showHeader && /* @__PURE__ */ jsxs(
51818
+ motion.div,
51819
+ {
51820
+ className: cn(
51821
+ "sticky top-0 z-30 border-b",
51822
+ glassmorphism ? "bg-background/80 backdrop-blur-md" : "bg-background"
51823
+ ),
51824
+ initial: { y: -50 },
51825
+ animate: { y: 0 },
51826
+ transition: { type: "spring", stiffness: 300, damping: 30 },
51827
+ children: [
51828
+ /* @__PURE__ */ jsx("div", { className: "px-6 py-4", children: /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between", children: [
51829
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-4", children: [
51830
+ /* @__PURE__ */ jsx(
51831
+ motion.div,
51832
+ {
51833
+ whileHover: { scale: 1.05 },
51834
+ whileTap: { scale: 0.95 },
51835
+ children: /* @__PURE__ */ jsx(MoonUIButtonPro, { variant: "ghost", size: "sm", className: "lg:hidden", children: /* @__PURE__ */ jsx(Menu, { className: "h-5 w-5" }) })
51836
+ }
51837
+ ),
51838
+ /* @__PURE__ */ jsxs("div", { children: [
51839
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
51840
+ /* @__PURE__ */ jsx("h1", { className: "text-2xl font-bold tracking-tight", children: title }),
51841
+ realtime && /* @__PURE__ */ jsxs(MoonUIBadgePro, { variant: "secondary", className: "animate-pulse", children: [
51842
+ /* @__PURE__ */ jsx("span", { className: "mr-1 h-1.5 w-1.5 rounded-full bg-green-500" }),
51843
+ "Real-time"
51844
+ ] })
51845
+ ] }),
51846
+ /* @__PURE__ */ jsx("p", { className: "text-sm text-muted-foreground", children: description })
51847
+ ] })
51848
+ ] }),
51849
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
51850
+ /* @__PURE__ */ jsx(
51851
+ TimeRangePicker,
51852
+ {
51853
+ value: timeRange,
51854
+ onChange: setTimeRange,
51855
+ glassmorphism
51856
+ }
51857
+ ),
51858
+ /* @__PURE__ */ jsx("div", { className: "relative", children: /* @__PURE__ */ jsxs(MoonUIButtonPro, { variant: "ghost", size: "sm", className: "relative", children: [
51859
+ /* @__PURE__ */ jsx(Bell, { className: "h-4 w-4" }),
51860
+ notifications > 0 && /* @__PURE__ */ jsx("span", { className: "absolute -top-1 -right-1 h-4 w-4 rounded-full bg-destructive text-[10px] font-medium text-destructive-foreground flex items-center justify-center", children: notifications })
51861
+ ] }) }),
51862
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuPro, { children: [
51863
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuTriggerPro, { asChild: true, children: /* @__PURE__ */ jsx(MoonUIButtonPro, { variant: "ghost", size: "sm", children: /* @__PURE__ */ jsx(Palette, { className: "h-4 w-4" }) }) }),
51864
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuContentPro, { align: "end", children: [
51865
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuItemPro, { onClick: () => setSelectedTheme("analytics"), children: /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
51866
+ /* @__PURE__ */ jsx("div", { className: "h-4 w-4 rounded bg-gradient-to-br from-blue-500 to-purple-500" }),
51867
+ "Analytics"
51868
+ ] }) }),
51869
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuItemPro, { onClick: () => setSelectedTheme("sales"), children: /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
51870
+ /* @__PURE__ */ jsx("div", { className: "h-4 w-4 rounded bg-gradient-to-br from-green-500 to-emerald-500" }),
51871
+ "Sales"
51872
+ ] }) }),
51873
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuItemPro, { onClick: () => setSelectedTheme("monitoring"), children: /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
51874
+ /* @__PURE__ */ jsx("div", { className: "h-4 w-4 rounded bg-gradient-to-br from-orange-500 to-red-500" }),
51875
+ "Monitoring"
51876
+ ] }) })
51877
+ ] })
51878
+ ] }),
51879
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuPro, { children: [
51880
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuTriggerPro, { asChild: true, children: /* @__PURE__ */ jsxs(MoonUIButtonPro, { variant: "outline", size: "sm", children: [
51881
+ /* @__PURE__ */ jsx(Settings, { className: "h-4 w-4 mr-2" }),
51882
+ "Actions"
51883
+ ] }) }),
51884
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuContentPro, { align: "end", className: "w-48", children: [
51885
+ editable && /* @__PURE__ */ jsxs(Fragment, { children: [
51886
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => setEditMode(!editMode), children: [
51887
+ /* @__PURE__ */ jsx(Edit3, { className: "mr-2 h-4 w-4" }),
51888
+ editMode ? "Exit Edit Mode" : "Edit Layout"
51889
+ ] }),
51890
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => setShowWidgetLibrary(true), children: [
51891
+ /* @__PURE__ */ jsx(Plus, { className: "mr-2 h-4 w-4" }),
51892
+ "Add Widget"
51893
+ ] }),
51894
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => setShowTemplates(true), children: [
51895
+ /* @__PURE__ */ jsx(LayoutGrid, { className: "mr-2 h-4 w-4" }),
51896
+ "Templates"
51897
+ ] }),
51898
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuSeparatorPro, {})
51899
+ ] }),
51900
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuSubPro, { children: [
51901
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuSubTriggerPro, { children: [
51902
+ /* @__PURE__ */ jsx(Download, { className: "mr-2 h-4 w-4" }),
51903
+ "Export"
51904
+ ] }),
51905
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuSubContentPro, { children: [
51906
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuItemPro, { onClick: () => onExport?.("json"), children: "As JSON" }),
51907
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuItemPro, { onClick: () => onExport?.("pdf"), children: "As PDF" }),
51908
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuItemPro, { onClick: () => onExport?.("png"), children: "As Image" })
51909
+ ] })
51910
+ ] }),
51911
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { children: [
51912
+ /* @__PURE__ */ jsx(Upload, { className: "mr-2 h-4 w-4" }),
51913
+ "Import"
51914
+ ] }),
51915
+ /* @__PURE__ */ jsx(MoonUIDropdownMenuSeparatorPro, {}),
51916
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { onClick: () => setRefreshing(true), children: [
51917
+ /* @__PURE__ */ jsx(RefreshCw, { className: "mr-2 h-4 w-4" }),
51918
+ "Refresh Data"
51919
+ ] }),
51920
+ /* @__PURE__ */ jsxs(MoonUIDropdownMenuItemPro, { children: [
51921
+ /* @__PURE__ */ jsx(Share2, { className: "mr-2 h-4 w-4" }),
51922
+ "Share Dashboard"
51923
+ ] })
51924
+ ] })
51925
+ ] })
51926
+ ] })
51927
+ ] }) }),
51928
+ /* @__PURE__ */ jsx(AnimatePresence, { children: editMode && /* @__PURE__ */ jsx(
51929
+ motion.div,
51930
+ {
51931
+ initial: { height: 0, opacity: 0 },
51932
+ animate: { height: "auto", opacity: 1 },
51933
+ exit: { height: 0, opacity: 0 },
51934
+ className: "bg-primary/10 border-t border-primary/20",
51935
+ children: /* @__PURE__ */ jsxs("div", { className: "px-6 py-2 flex items-center justify-between", children: [
51936
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2 text-sm", children: [
51937
+ /* @__PURE__ */ jsx(Sparkles, { className: "h-4 w-4 text-primary" }),
51938
+ /* @__PURE__ */ jsx("span", { children: "Edit mode enabled - Drag widgets to rearrange" })
51939
+ ] }),
51940
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
51941
+ /* @__PURE__ */ jsxs(
51942
+ MoonUIButtonPro,
51943
+ {
51944
+ variant: "ghost",
51945
+ size: "sm",
51946
+ onClick: () => setEditMode(false),
51947
+ children: [
51948
+ /* @__PURE__ */ jsx(X, { className: "h-4 w-4 mr-1" }),
51949
+ "Cancel"
51950
+ ]
51951
+ }
51952
+ ),
51953
+ /* @__PURE__ */ jsxs(
51954
+ MoonUIButtonPro,
51955
+ {
51956
+ variant: "primary",
51957
+ size: "sm",
51958
+ onClick: () => {
51959
+ setEditMode(false);
51960
+ },
51961
+ children: [
51962
+ /* @__PURE__ */ jsx(Save, { className: "h-4 w-4 mr-1" }),
51963
+ "Save Changes"
51964
+ ]
51965
+ }
51966
+ )
51967
+ ] })
51968
+ ] })
51969
+ }
51970
+ ) })
51971
+ ]
51972
+ }
51973
+ ),
51974
+ /* @__PURE__ */ jsx("div", { className: "p-6", children: widgets.length === 0 ? (
51975
+ // Empty state
51976
+ /* @__PURE__ */ jsxs(
51977
+ motion.div,
51978
+ {
51979
+ initial: { opacity: 0, scale: 0.9 },
51980
+ animate: { opacity: 1, scale: 1 },
51981
+ className: "flex flex-col items-center justify-center min-h-[400px] text-center",
51982
+ children: [
51983
+ /* @__PURE__ */ jsx("div", { className: cn(
51984
+ "p-4 rounded-full mb-4",
51985
+ glassmorphism ? "bg-background/60 backdrop-blur-sm" : "bg-muted"
51986
+ ), children: /* @__PURE__ */ jsx(LayoutGrid, { className: "h-8 w-8 text-muted-foreground" }) }),
51987
+ /* @__PURE__ */ jsx("h3", { className: "text-lg font-semibold mb-2", children: "No widgets added yet" }),
51988
+ /* @__PURE__ */ jsx("p", { className: "text-muted-foreground mb-4", children: "Start by adding widgets or choosing a template" }),
51989
+ /* @__PURE__ */ jsxs("div", { className: "flex gap-2", children: [
51990
+ /* @__PURE__ */ jsxs(MoonUIButtonPro, { onClick: () => setShowWidgetLibrary(true), children: [
51991
+ /* @__PURE__ */ jsx(Plus, { className: "h-4 w-4 mr-2" }),
51992
+ "Add Widget"
51993
+ ] }),
51994
+ /* @__PURE__ */ jsxs(MoonUIButtonPro, { variant: "outline", onClick: () => setShowTemplates(true), children: [
51995
+ /* @__PURE__ */ jsx(LayoutGrid, { className: "h-4 w-4 mr-2" }),
51996
+ "Browse Templates"
51997
+ ] })
51998
+ ] })
51999
+ ]
52000
+ }
52001
+ )
52002
+ ) : (
52003
+ // Dashboard grid
52004
+ /* @__PURE__ */ jsx(
52005
+ DashboardGrid,
52006
+ {
52007
+ widgets,
52008
+ onLayoutChange: (layout) => {
52009
+ const updatedWidgets = widgets.map((widget) => {
52010
+ const layoutItem = layout.find((l) => l.i === widget.id);
52011
+ if (layoutItem) {
52012
+ return {
52013
+ ...widget,
52014
+ position: { x: layoutItem.x, y: layoutItem.y },
52015
+ size: { ...widget.size, w: layoutItem.w, h: layoutItem.h }
52016
+ };
52017
+ }
52018
+ return widget;
52019
+ });
52020
+ setWidgets(updatedWidgets);
52021
+ },
52022
+ onWidgetRemove: (widgetId) => {
52023
+ setWidgets((prev) => prev.filter((w2) => w2.id !== widgetId));
52024
+ onWidgetRemove?.(widgetId);
52025
+ },
52026
+ onWidgetAction: (widgetId, action, data) => {
52027
+ console.log("Widget action:", widgetId, action, data);
52028
+ },
52029
+ editMode,
52030
+ glassmorphism
52031
+ }
52032
+ )
52033
+ ) }),
52034
+ /* @__PURE__ */ jsx(WidgetLibrary, {}),
52035
+ /* @__PURE__ */ jsx(TemplateGallery, {})
52036
+ ]
52037
+ }
52038
+ );
50202
52039
  }
50203
52040
  function DraggableList({
50204
52041
  items,
@@ -51371,7 +53208,7 @@ var OptimizedImageInternal = ({
51371
53208
  width,
51372
53209
  height,
51373
53210
  quality = 75,
51374
- format = "auto",
53211
+ format: format2 = "auto",
51375
53212
  lazy = true,
51376
53213
  blur: blur2 = true,
51377
53214
  priority = false,
@@ -51410,7 +53247,7 @@ var OptimizedImageInternal = ({
51410
53247
  params.set("f", options.format);
51411
53248
  return optimizedUrl;
51412
53249
  };
51413
- const optimizedSrc = getOptimizedSrc(src, { width, height, quality, format });
53250
+ const optimizedSrc = getOptimizedSrc(src, { width, height, quality, format: format2 });
51414
53251
  const handleImageLoad = () => {
51415
53252
  setIsLoaded(true);
51416
53253
  setIsLoading(false);
@@ -51574,7 +53411,7 @@ var OptimizedImageInternal = ({
51574
53411
  ] }),
51575
53412
  /* @__PURE__ */ jsxs("div", { children: [
51576
53413
  "Format: ",
51577
- format
53414
+ format2
51578
53415
  ] })
51579
53416
  ]
51580
53417
  }
@@ -53475,11 +55312,11 @@ function downloadFile(content, filename, mimeType) {
53475
55312
  URL.revokeObjectURL(url);
53476
55313
  }
53477
55314
  async function exportData(data, options) {
53478
- const { format, filename = "data-export", columns, includeHeaders = true } = options;
55315
+ const { format: format2, filename = "data-export", columns, includeHeaders = true } = options;
53479
55316
  let content;
53480
55317
  let mimeType;
53481
55318
  let extension;
53482
- switch (format) {
55319
+ switch (format2) {
53483
55320
  case "csv":
53484
55321
  content = dataToCSV(data, columns, includeHeaders);
53485
55322
  mimeType = "text/csv;charset=utf-8;";
@@ -53493,7 +55330,7 @@ async function exportData(data, options) {
53493
55330
  case "xlsx":
53494
55331
  throw new Error("XLSX export requires additional dependencies. Use CSV format instead.");
53495
55332
  default:
53496
- throw new Error(`Unsupported export format: ${format}`);
55333
+ throw new Error(`Unsupported export format: ${format2}`);
53497
55334
  }
53498
55335
  const finalFilename = `${filename}-${( new Date()).toISOString().split("T")[0]}.${extension}`;
53499
55336
  downloadFile(content, finalFilename, mimeType);
@@ -53976,11 +55813,11 @@ function DataTable({
53976
55813
  rowSelection: features.rowSelection !== false || selectable,
53977
55814
  export: features.export !== false || exportable
53978
55815
  });
53979
- const handleExport = async (format) => {
55816
+ const handleExport = async (format2) => {
53980
55817
  const selectedRows = table.getFilteredSelectedRowModel().rows;
53981
55818
  const dataToExport = selectedRows.length > 0 ? selectedRows.map((row) => row.original) : table.getFilteredRowModel().rows.map((row) => row.original);
53982
55819
  if (typeof exportable === "object" && exportable.onExport) {
53983
- exportable.onExport(dataToExport, format);
55820
+ exportable.onExport(dataToExport, format2);
53984
55821
  return;
53985
55822
  }
53986
55823
  if (onExport) {
@@ -53990,7 +55827,7 @@ function DataTable({
53990
55827
  const filename = typeof exportable === "object" && exportable.filename ? exportable.filename : "data-export";
53991
55828
  const visibleColumns = getVisibleColumns(columns, columnVisibility);
53992
55829
  await exportData(dataToExport, {
53993
- format,
55830
+ format: format2,
53994
55831
  filename,
53995
55832
  columns: visibleColumns,
53996
55833
  includeHeaders: true
@@ -54366,7 +56203,7 @@ __export(enhanced_exports, {
54366
56203
  DialogProFooter: () => DialogProFooter,
54367
56204
  DialogProHeader: () => DialogProHeader,
54368
56205
  DialogProTitle: () => DialogProTitle,
54369
- DialogProTrigger: () => DialogTrigger,
56206
+ DialogProTrigger: () => DialogTrigger2,
54370
56207
  EnhancedCardDescription: () => EnhancedCardDescription,
54371
56208
  EnhancedCardTitle: () => EnhancedCardTitle,
54372
56209
  badgeVariants: () => badgeVariants,
@@ -54899,7 +56736,7 @@ var CardProFooter = t__default.forwardRef(({ className, ...props }, ref) => /* @
54899
56736
  ));
54900
56737
  CardProFooter.displayName = "CardProFooter";
54901
56738
  var Dialog = DialogPrimitive.Root;
54902
- var DialogTrigger = DialogPrimitive.Trigger;
56739
+ var DialogTrigger2 = DialogPrimitive.Trigger;
54903
56740
  var DialogPortal = DialogPrimitive.Portal;
54904
56741
  var DialogClose = DialogPrimitive.Close;
54905
56742
  var DialogProOverlay = t.forwardRef(({ className, blur: blur2 = "md", variant = "default", ...props }, ref) => {
@@ -55248,4 +57085,4 @@ var BadgePro = t__default.forwardRef(({
55248
57085
  });
55249
57086
  BadgePro.displayName = "BadgePro";
55250
57087
 
55251
- export { MoonUIAccordionPro as Accordion, MoonUIAccordionContentPro as AccordionContent, MoonUIAccordionItemPro as AccordionItem, MoonUIAccordionTriggerPro as AccordionTrigger, AdvancedChart, AdvancedForms, MoonUIAlertPro as Alert, MoonUIAlertDescriptionPro as AlertDescription, MoonUIAlertTitlePro as AlertTitle, AnimatedButton, MoonUIAspectRatioPro as AspectRatio, MoonUIAvatarPro as Avatar, MoonUIAvatarFallbackPro as AvatarFallback, MoonUIAvatarImagePro as AvatarImage, MoonUIBadgePro as Badge, MoonUIBreadcrumbPro as Breadcrumb, MoonUIBreadcrumbEllipsisPro as BreadcrumbEllipsis, MoonUIBreadcrumbItemPro as BreadcrumbItem, MoonUIBreadcrumbLinkPro as BreadcrumbLink, MoonUIBreadcrumbListPro as BreadcrumbList, MoonUIBreadcrumbPagePro as BreadcrumbPage, MoonUIBreadcrumbSeparatorPro as BreadcrumbSeparator, MoonUIButtonPro as Button, Calendar2 as Calendar, MoonUICardPro as Card, MoonUICardContentPro as CardContent, MoonUICardDescriptionPro as CardDescription, MoonUICardFooterPro as CardFooter, MoonUICardHeaderPro as CardHeader, MoonUICardTitlePro as CardTitle, MoonUICheckboxPro as Checkbox, MoonUICollapsiblePro as Collapsible, MoonUICollapsibleContentPro as CollapsibleContent, MoonUICollapsibleTriggerPro as CollapsibleTrigger, MoonUIColorPickerPro as ColorPicker, MoonUICommandPro as Command, MoonUICommandDialogPro as CommandDialog, MoonUICommandEmptyPro as CommandEmpty, MoonUICommandGroupPro as CommandGroup, MoonUICommandInputPro as CommandInput, MoonUICommandItemPro as CommandItem, MoonUICommandListPro as CommandList, MoonUICommandSeparatorPro as CommandSeparator, MoonUICommandShortcutPro as CommandShortcut, Dashboard, DataTable, MoonUIDialogPro as Dialog, MoonUIDialogClosePro as DialogClose, MoonUIDialogContentPro as DialogContent, MoonUIDialogDescriptionPro as DialogDescription, MoonUIDialogFooterPro as DialogFooter, MoonUIDialogHeaderPro as DialogHeader, MoonUIDialogTitlePro as DialogTitle, MoonUIDialogTriggerPro as DialogTrigger, DraggableList, MoonUIDropdownMenuPro as DropdownMenu, MoonUIDropdownMenuCheckboxItemPro as DropdownMenuCheckboxItem, MoonUIDropdownMenuContentPro as DropdownMenuContent, MoonUIDropdownMenuGroupPro as DropdownMenuGroup, MoonUIDropdownMenuItemPro as DropdownMenuItem, MoonUIDropdownMenuLabelPro as DropdownMenuLabel, MoonUIDropdownMenuPortalPro as DropdownMenuPortal, MoonUIDropdownMenuRadioGroupPro as DropdownMenuRadioGroup, MoonUIDropdownMenuRadioItemPro as DropdownMenuRadioItem, MoonUIDropdownMenuSeparatorPro as DropdownMenuSeparator, MoonUIDropdownMenuShortcutPro as DropdownMenuShortcut, MoonUIDropdownMenuSubPro as DropdownMenuSub, MoonUIDropdownMenuSubContentPro as DropdownMenuSubContent, MoonUIDropdownMenuSubTriggerPro as DropdownMenuSubTrigger, MoonUIDropdownMenuTriggerPro as DropdownMenuTrigger, enhanced_exports as Enhanced, ErrorBoundary, FileUpload, FloatingActionButton, GitHubStars, HealthCheck, HoverCard3D, MoonUIInputPro as Input, Kanban, MoonUILabelPro as Label, LazyComponent, LazyImage, LazyList, MagneticButton, MemoryAnalytics, MemoryEfficientData, MoonUIAccordionContentPro, MoonUIAccordionItemPro, MoonUIAccordionPro, MoonUIAccordionTriggerPro, MoonUIAlertDescriptionPro, MoonUIAlertPro, MoonUIAlertTitlePro, MoonUIAspectRatioPro, MoonUIAvatarFallbackPro, MoonUIAvatarImagePro, MoonUIAvatarPro, MoonUIBadgePro, MoonUIBreadcrumbEllipsisPro, MoonUIBreadcrumbItemPro, MoonUIBreadcrumbLinkPro, MoonUIBreadcrumbListPro, MoonUIBreadcrumbPagePro, MoonUIBreadcrumbPro, MoonUIBreadcrumbSeparatorPro, MoonUIButtonPro, MoonUICardContentPro, MoonUICardDescriptionPro, MoonUICardFooterPro, MoonUICardHeaderPro, MoonUICardPro, MoonUICardTitlePro, MoonUICheckboxPro, MoonUICollapsibleContentPro, MoonUICollapsiblePro, MoonUICollapsibleTriggerPro, MoonUIColorPickerPro, MoonUICommandDialogPro, MoonUICommandEmptyPro, MoonUICommandGroupPro, MoonUICommandInputPro, MoonUICommandItemPro, MoonUICommandListPro, MoonUICommandPro, MoonUICommandSeparatorPro, MoonUICommandShortcutPro, MoonUIDialogClosePro, MoonUIDialogContentPro, MoonUIDialogDescriptionPro, MoonUIDialogFooterPro, MoonUIDialogHeaderPro, MoonUIDialogPro, MoonUIDialogTitlePro, MoonUIDialogTriggerPro, MoonUIDropdownMenuCheckboxItemPro, MoonUIDropdownMenuContentPro, MoonUIDropdownMenuGroupPro, MoonUIDropdownMenuItemPro, MoonUIDropdownMenuLabelPro, MoonUIDropdownMenuPortalPro, MoonUIDropdownMenuPro, MoonUIDropdownMenuRadioGroupPro, MoonUIDropdownMenuRadioItemPro, MoonUIDropdownMenuSeparatorPro, MoonUIDropdownMenuShortcutPro, MoonUIDropdownMenuSubContentPro, MoonUIDropdownMenuSubPro, MoonUIDropdownMenuSubTriggerPro, MoonUIDropdownMenuTriggerPro, MoonUIInputPro, MoonUILabelPro, MoonUIPaginationContentPro, MoonUIPaginationEllipsisPro, MoonUIPaginationItemPro, MoonUIPaginationLinkPro, MoonUIPaginationNextPro, MoonUIPaginationPreviousPro, MoonUIPaginationPro, MoonUIPopoverContentPro, MoonUIPopoverPro, MoonUIPopoverTriggerPro, MoonUIProgressPro, MoonUIRadioGroupContextPro, MoonUIRadioGroupItemPro, MoonUIRadioGroupPro, MoonUIRadioItemWithLabelPro, MoonUIRadioLabelPro, MoonUISelectContentPro, MoonUISelectGroupPro, MoonUISelectItemPro, MoonUISelectLabelPro, MoonUISelectPro, MoonUISelectSeparatorPro, MoonUISelectTriggerPro, MoonUISelectValuePro, MoonUISeparatorPro, MoonUISkeletonPro, MoonUISliderPro, MoonUISwitchPro, MoonUITableBodyPro, MoonUITableCaptionPro, MoonUITableCellPro, MoonUITableFooterPro, MoonUITableHeadPro, MoonUITableHeaderPro, MoonUITablePro, MoonUITableRowPro, MoonUITabsContentPro, MoonUITabsListPro, MoonUITabsPro, MoonUITabsTriggerPro, MoonUITextareaPro, MoonUIToastPro, MoonUITogglePro, MoonUITooltipContentPro, MoonUITooltipPro, MoonUITooltipProviderPro, MoonUITooltipTriggerPro, MoonUIalertVariantsPro, MoonUIaspectRatioVariantsPro, MoonUIbreadcrumbVariantsPro, MoonUIcollapsibleContentVariantsPro, MoonUIcollapsibleTriggerVariantsPro, MoonUIcommandVariantsPro, MoonUIradioGroupItemVariantsPro, MoonUItableVariantsPro, MoonUItoggleVariantsPro, OptimizedImage, MoonUIPaginationPro as Pagination, MoonUIPaginationContentPro as PaginationContent, MoonUIPaginationEllipsisPro as PaginationEllipsis, MoonUIPaginationItemPro as PaginationItem, MoonUIPaginationLinkPro as PaginationLink, MoonUIPaginationNextPro as PaginationNext, MoonUIPaginationPreviousPro as PaginationPrevious, PerformanceDebugger, PerformanceMonitor, PinchZoom, MoonUIPopoverPro as Popover, MoonUIPopoverContentPro as PopoverContent, MoonUIPopoverTriggerPro as PopoverTrigger, MoonUIProgressPro as Progress, MoonUIRadioGroupPro as RadioGroup, MoonUIRadioGroupContextPro as RadioGroupContext, MoonUIRadioGroupItemPro as RadioGroupItem, MoonUIRadioItemWithLabelPro as RadioItemWithLabel, MoonUIRadioLabelPro as RadioLabel, RichTextEditor, MoonUISelectPro as Select, MoonUISelectContentPro as SelectContent, MoonUISelectGroupPro as SelectGroup, MoonUISelectItemPro as SelectItem, MoonUISelectLabelPro as SelectLabel, MoonUISelectSeparatorPro as SelectSeparator, MoonUISelectTriggerPro as SelectTrigger, MoonUISelectValuePro as SelectValue, SelectableVirtualList, MoonUISeparatorPro as Separator, MoonUISkeletonPro as Skeleton, MoonUISliderPro as Slider, SpotlightCard, SwipeableCard, MoonUISwitchPro as Switch, MoonUITablePro as Table, MoonUITableBodyPro as TableBody, MoonUITableCaptionPro as TableCaption, MoonUITableCellPro as TableCell, MoonUITableFooterPro as TableFooter, MoonUITableHeadPro as TableHead, MoonUITableHeaderPro as TableHeader, MoonUITableRowPro as TableRow, MoonUITabsPro as Tabs, MoonUITabsContentPro as TabsContent, MoonUITabsListPro as TabsList, MoonUITabsTriggerPro as TabsTrigger, MoonUITextareaPro as Textarea, Timeline, MoonUIToastPro as Toast, MoonUITogglePro as Toggle, MoonUITooltipPro as Tooltip, MoonUITooltipContentPro as TooltipContent, MoonUITooltipProviderPro as TooltipProvider, MoonUITooltipTriggerPro as TooltipTrigger, VirtualList, MoonUIalertVariantsPro as alertVariants, animatedButtonVariants, MoonUIaspectRatioVariantsPro as aspectRatioVariants, moonUIBadgeVariantsPro as badgeVariants, MoonUIbreadcrumbVariantsPro as breadcrumbVariants, moonUIButtonProVariants as buttonVariants, cn, MoonUIcollapsibleContentVariantsPro as collapsibleContentVariants, MoonUIcollapsibleTriggerVariantsPro as collapsibleTriggerVariants, MoonUIcommandVariantsPro as commandVariants, getExpandableColumn, moonUIBadgeVariantsPro, moonUIButtonProVariants, moonUISeparatorVariantsPro, MoonUIradioGroupItemVariantsPro as radioGroupItemVariants, moonUISeparatorVariantsPro as separatorVariants, MoonUItableVariantsPro as tableVariants, MoonUItoggleVariantsPro as toggleVariants, useExpandableRows, useStreamingData, useVirtualList };
57088
+ export { MoonUIAccordionPro as Accordion, MoonUIAccordionContentPro as AccordionContent, MoonUIAccordionItemPro as AccordionItem, MoonUIAccordionTriggerPro as AccordionTrigger, Calendar3 as AdvancedCalendar, AdvancedChart, AdvancedForms, MoonUIAlertPro as Alert, MoonUIAlertDescriptionPro as AlertDescription, MoonUIAlertTitlePro as AlertTitle, AnimatedButton, MoonUIAspectRatioPro as AspectRatio, MoonUIAvatarPro as Avatar, MoonUIAvatarFallbackPro as AvatarFallback, MoonUIAvatarImagePro as AvatarImage, MoonUIBadgePro as Badge, MoonUIBreadcrumbPro as Breadcrumb, MoonUIBreadcrumbEllipsisPro as BreadcrumbEllipsis, MoonUIBreadcrumbItemPro as BreadcrumbItem, MoonUIBreadcrumbLinkPro as BreadcrumbLink, MoonUIBreadcrumbListPro as BreadcrumbList, MoonUIBreadcrumbPagePro as BreadcrumbPage, MoonUIBreadcrumbSeparatorPro as BreadcrumbSeparator, MoonUIButtonPro as Button, Calendar, MoonUICardPro as Card, MoonUICardContentPro as CardContent, MoonUICardDescriptionPro as CardDescription, MoonUICardFooterPro as CardFooter, MoonUICardHeaderPro as CardHeader, MoonUICardTitlePro as CardTitle, MoonUICheckboxPro as Checkbox, MoonUICollapsiblePro as Collapsible, MoonUICollapsibleContentPro as CollapsibleContent, MoonUICollapsibleTriggerPro as CollapsibleTrigger, MoonUIColorPickerPro as ColorPicker, MoonUICommandPro as Command, MoonUICommandDialogPro as CommandDialog, MoonUICommandEmptyPro as CommandEmpty, MoonUICommandGroupPro as CommandGroup, MoonUICommandInputPro as CommandInput, MoonUICommandItemPro as CommandItem, MoonUICommandListPro as CommandList, MoonUICommandSeparatorPro as CommandSeparator, MoonUICommandShortcutPro as CommandShortcut, Dashboard, DataTable, MoonUIDialogPro as Dialog, MoonUIDialogClosePro as DialogClose, MoonUIDialogContentPro as DialogContent, MoonUIDialogDescriptionPro as DialogDescription, MoonUIDialogFooterPro as DialogFooter, MoonUIDialogHeaderPro as DialogHeader, MoonUIDialogTitlePro as DialogTitle, MoonUIDialogTriggerPro as DialogTrigger, DraggableList, MoonUIDropdownMenuPro as DropdownMenu, MoonUIDropdownMenuCheckboxItemPro as DropdownMenuCheckboxItem, MoonUIDropdownMenuContentPro as DropdownMenuContent, MoonUIDropdownMenuGroupPro as DropdownMenuGroup, MoonUIDropdownMenuItemPro as DropdownMenuItem, MoonUIDropdownMenuLabelPro as DropdownMenuLabel, MoonUIDropdownMenuPortalPro as DropdownMenuPortal, MoonUIDropdownMenuRadioGroupPro as DropdownMenuRadioGroup, MoonUIDropdownMenuRadioItemPro as DropdownMenuRadioItem, MoonUIDropdownMenuSeparatorPro as DropdownMenuSeparator, MoonUIDropdownMenuShortcutPro as DropdownMenuShortcut, MoonUIDropdownMenuSubPro as DropdownMenuSub, MoonUIDropdownMenuSubContentPro as DropdownMenuSubContent, MoonUIDropdownMenuSubTriggerPro as DropdownMenuSubTrigger, MoonUIDropdownMenuTriggerPro as DropdownMenuTrigger, enhanced_exports as Enhanced, ErrorBoundary, FileUpload, FloatingActionButton, GitHubStars, HealthCheck, HoverCard3D, MoonUIInputPro as Input, Kanban, MoonUILabelPro as Label, LazyComponent, LazyImage, LazyList, MagneticButton, MemoryAnalytics, MemoryEfficientData, MoonUIAccordionContentPro, MoonUIAccordionItemPro, MoonUIAccordionPro, MoonUIAccordionTriggerPro, MoonUIAlertDescriptionPro, MoonUIAlertPro, MoonUIAlertTitlePro, MoonUIAspectRatioPro, MoonUIAvatarFallbackPro, MoonUIAvatarImagePro, MoonUIAvatarPro, MoonUIBadgePro, MoonUIBreadcrumbEllipsisPro, MoonUIBreadcrumbItemPro, MoonUIBreadcrumbLinkPro, MoonUIBreadcrumbListPro, MoonUIBreadcrumbPagePro, MoonUIBreadcrumbPro, MoonUIBreadcrumbSeparatorPro, MoonUIButtonPro, MoonUICardContentPro, MoonUICardDescriptionPro, MoonUICardFooterPro, MoonUICardHeaderPro, MoonUICardPro, MoonUICardTitlePro, MoonUICheckboxPro, MoonUICollapsibleContentPro, MoonUICollapsiblePro, MoonUICollapsibleTriggerPro, MoonUIColorPickerPro, MoonUICommandDialogPro, MoonUICommandEmptyPro, MoonUICommandGroupPro, MoonUICommandInputPro, MoonUICommandItemPro, MoonUICommandListPro, MoonUICommandPro, MoonUICommandSeparatorPro, MoonUICommandShortcutPro, MoonUIDialogClosePro, MoonUIDialogContentPro, MoonUIDialogDescriptionPro, MoonUIDialogFooterPro, MoonUIDialogHeaderPro, MoonUIDialogPro, MoonUIDialogTitlePro, MoonUIDialogTriggerPro, MoonUIDropdownMenuCheckboxItemPro, MoonUIDropdownMenuContentPro, MoonUIDropdownMenuGroupPro, MoonUIDropdownMenuItemPro, MoonUIDropdownMenuLabelPro, MoonUIDropdownMenuPortalPro, MoonUIDropdownMenuPro, MoonUIDropdownMenuRadioGroupPro, MoonUIDropdownMenuRadioItemPro, MoonUIDropdownMenuSeparatorPro, MoonUIDropdownMenuShortcutPro, MoonUIDropdownMenuSubContentPro, MoonUIDropdownMenuSubPro, MoonUIDropdownMenuSubTriggerPro, MoonUIDropdownMenuTriggerPro, MoonUIInputPro, MoonUILabelPro, MoonUIPaginationContentPro, MoonUIPaginationEllipsisPro, MoonUIPaginationItemPro, MoonUIPaginationLinkPro, MoonUIPaginationNextPro, MoonUIPaginationPreviousPro, MoonUIPaginationPro, MoonUIPopoverContentPro, MoonUIPopoverPro, MoonUIPopoverTriggerPro, MoonUIProgressPro, MoonUIRadioGroupContextPro, MoonUIRadioGroupItemPro, MoonUIRadioGroupPro, MoonUIRadioItemWithLabelPro, MoonUIRadioLabelPro, MoonUISelectContentPro, MoonUISelectGroupPro, MoonUISelectItemPro, MoonUISelectLabelPro, MoonUISelectPro, MoonUISelectSeparatorPro, MoonUISelectTriggerPro, MoonUISelectValuePro, MoonUISeparatorPro, MoonUISkeletonPro, MoonUISliderPro, MoonUISwitchPro, MoonUITableBodyPro, MoonUITableCaptionPro, MoonUITableCellPro, MoonUITableFooterPro, MoonUITableHeadPro, MoonUITableHeaderPro, MoonUITablePro, MoonUITableRowPro, MoonUITabsContentPro, MoonUITabsListPro, MoonUITabsPro, MoonUITabsTriggerPro, MoonUITextareaPro, MoonUIToastPro, MoonUITogglePro, MoonUITooltipContentPro, MoonUITooltipPro, MoonUITooltipProviderPro, MoonUITooltipTriggerPro, MoonUIalertVariantsPro, MoonUIaspectRatioVariantsPro, MoonUIbreadcrumbVariantsPro, MoonUIcollapsibleContentVariantsPro, MoonUIcollapsibleTriggerVariantsPro, MoonUIcommandVariantsPro, MoonUIradioGroupItemVariantsPro, MoonUItableVariantsPro, MoonUItoggleVariantsPro, OptimizedImage, MoonUIPaginationPro as Pagination, MoonUIPaginationContentPro as PaginationContent, MoonUIPaginationEllipsisPro as PaginationEllipsis, MoonUIPaginationItemPro as PaginationItem, MoonUIPaginationLinkPro as PaginationLink, MoonUIPaginationNextPro as PaginationNext, MoonUIPaginationPreviousPro as PaginationPrevious, PerformanceDebugger, PerformanceMonitor, PinchZoom, MoonUIPopoverPro as Popover, MoonUIPopoverContentPro as PopoverContent, MoonUIPopoverTriggerPro as PopoverTrigger, MoonUIProgressPro as Progress, MoonUIRadioGroupPro as RadioGroup, MoonUIRadioGroupContextPro as RadioGroupContext, MoonUIRadioGroupItemPro as RadioGroupItem, MoonUIRadioItemWithLabelPro as RadioItemWithLabel, MoonUIRadioLabelPro as RadioLabel, RichTextEditor, ScrollArea, ScrollBar, MoonUISelectPro as Select, MoonUISelectContentPro as SelectContent, MoonUISelectGroupPro as SelectGroup, MoonUISelectItemPro as SelectItem, MoonUISelectLabelPro as SelectLabel, MoonUISelectSeparatorPro as SelectSeparator, MoonUISelectTriggerPro as SelectTrigger, MoonUISelectValuePro as SelectValue, SelectableVirtualList, MoonUISeparatorPro as Separator, Sheet, SheetClose, SheetContent, SheetDescription, SheetFooter, SheetHeader, SheetOverlay, SheetPortal, SheetTitle, SheetTrigger, MoonUISkeletonPro as Skeleton, MoonUISliderPro as Slider, SpotlightCard, SwipeableCard, MoonUISwitchPro as Switch, MoonUITablePro as Table, MoonUITableBodyPro as TableBody, MoonUITableCaptionPro as TableCaption, MoonUITableCellPro as TableCell, MoonUITableFooterPro as TableFooter, MoonUITableHeadPro as TableHead, MoonUITableHeaderPro as TableHeader, MoonUITableRowPro as TableRow, MoonUITabsPro as Tabs, MoonUITabsContentPro as TabsContent, MoonUITabsListPro as TabsList, MoonUITabsTriggerPro as TabsTrigger, MoonUITextareaPro as Textarea, Timeline, MoonUIToastPro as Toast, MoonUITogglePro as Toggle, MoonUITooltipPro as Tooltip, MoonUITooltipContentPro as TooltipContent, MoonUITooltipProviderPro as TooltipProvider, MoonUITooltipTriggerPro as TooltipTrigger, VirtualList, MoonUIalertVariantsPro as alertVariants, animatedButtonVariants, MoonUIaspectRatioVariantsPro as aspectRatioVariants, moonUIBadgeVariantsPro as badgeVariants, MoonUIbreadcrumbVariantsPro as breadcrumbVariants, moonUIButtonProVariants as buttonVariants, cn, MoonUIcollapsibleContentVariantsPro as collapsibleContentVariants, MoonUIcollapsibleTriggerVariantsPro as collapsibleTriggerVariants, MoonUIcommandVariantsPro as commandVariants, getExpandableColumn, moonUIBadgeVariantsPro, moonUIButtonProVariants, moonUISeparatorVariantsPro, MoonUIradioGroupItemVariantsPro as radioGroupItemVariants, moonUISeparatorVariantsPro as separatorVariants, MoonUItableVariantsPro as tableVariants, MoonUItoggleVariantsPro as toggleVariants, useExpandableRows, useStreamingData, useVirtualList };