@gram-ai/elements 1.27.4 → 1.27.5
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/README.md +72 -60
- package/README.typedoc.md +6 -6
- package/bin/cli.js +74 -74
- package/dist/compat-shims-CO9JXXV4.cjs.map +1 -1
- package/dist/{compat-shims-BPJ7Q68c.js → compat-shims-DxtUrORi.js} +4 -2
- package/dist/compat-shims-DxtUrORi.js.map +1 -0
- package/dist/components/ShareButton/index.d.ts +2 -2
- package/dist/components/assistant-ui/message-feedback.d.ts +1 -1
- package/dist/components/assistant-ui/tooltip-icon-button.d.ts +2 -2
- package/dist/components/ui/avatar.d.ts +2 -2
- package/dist/components/ui/button.d.ts +1 -1
- package/dist/components/ui/calendar.d.ts +1 -1
- package/dist/components/ui/collapsible.d.ts +1 -1
- package/dist/components/ui/dialog.d.ts +4 -4
- package/dist/components/ui/popover.d.ts +2 -2
- package/dist/components/ui/skeleton.d.ts +1 -1
- package/dist/components/ui/time-range-picker.d.ts +1 -1
- package/dist/components/ui/tool-ui.d.ts +7 -7
- package/dist/components/ui/tooltip.d.ts +2 -2
- package/dist/contexts/ConnectionStatusContext.d.ts +1 -1
- package/dist/elements.cjs +1 -1
- package/dist/elements.js +2 -2
- package/dist/hooks/useDensity.d.ts +73 -73
- package/dist/hooks/useMCPTools.d.ts +1 -1
- package/dist/hooks/useRadius.d.ts +1 -1
- package/dist/{index-BpJstUh1.cjs → index-C4bFBGfl.cjs} +4 -4
- package/dist/{index-BpJstUh1.cjs.map → index-C4bFBGfl.cjs.map} +1 -1
- package/dist/{index-CUitXazZ.js → index-D93pV0_o.js} +55 -55
- package/dist/{index-CUitXazZ.js.map → index-D93pV0_o.js.map} +1 -1
- package/dist/{index-D0bAYNQy.js → index-DuCQRbcQ.js} +279 -265
- package/dist/index-DuCQRbcQ.js.map +1 -0
- package/dist/{index-KSX4Qjip.cjs → index-y_PNN5vK.cjs} +10 -10
- package/dist/index-y_PNN5vK.cjs.map +1 -0
- package/dist/lib/cassette.d.ts +4 -4
- package/dist/lib/errorTracking.d.ts +1 -1
- package/dist/lib/messageConverter.d.ts +1 -1
- package/dist/lib/models.d.ts +1 -1
- package/dist/plugins/chart/ui/bar-chart.d.ts +1 -1
- package/dist/plugins/generative-ui/ui/accordion-wrapper.d.ts +2 -2
- package/dist/plugins/generative-ui/ui/accordion.d.ts +1 -1
- package/dist/plugins/generative-ui/ui/action-button.d.ts +2 -2
- package/dist/plugins/generative-ui/ui/alert-wrapper.d.ts +1 -1
- package/dist/plugins/generative-ui/ui/alert.d.ts +4 -4
- package/dist/plugins/generative-ui/ui/avatar.d.ts +5 -5
- package/dist/plugins/generative-ui/ui/badge.d.ts +2 -2
- package/dist/plugins/generative-ui/ui/button-wrapper.d.ts +2 -2
- package/dist/plugins/generative-ui/ui/button.d.ts +2 -2
- package/dist/plugins/generative-ui/ui/card-wrapper.d.ts +2 -2
- package/dist/plugins/generative-ui/ui/card.d.ts +8 -8
- package/dist/plugins/generative-ui/ui/checkbox.d.ts +1 -1
- package/dist/plugins/generative-ui/ui/data-table.d.ts +2 -2
- package/dist/plugins/generative-ui/ui/dialog.d.ts +3 -3
- package/dist/plugins/generative-ui/ui/dropdown-menu.d.ts +3 -3
- package/dist/plugins/generative-ui/ui/grid.d.ts +3 -3
- package/dist/plugins/generative-ui/ui/input-wrapper.d.ts +1 -1
- package/dist/plugins/generative-ui/ui/input.d.ts +2 -2
- package/dist/plugins/generative-ui/ui/label.d.ts +1 -1
- package/dist/plugins/generative-ui/ui/metric.d.ts +3 -3
- package/dist/plugins/generative-ui/ui/pagination.d.ts +6 -6
- package/dist/plugins/generative-ui/ui/popover.d.ts +4 -4
- package/dist/plugins/generative-ui/ui/progress.d.ts +2 -2
- package/dist/plugins/generative-ui/ui/radio-group.d.ts +1 -1
- package/dist/plugins/generative-ui/ui/select.d.ts +2 -2
- package/dist/plugins/generative-ui/ui/separator.d.ts +1 -1
- package/dist/plugins/generative-ui/ui/skeleton.d.ts +1 -1
- package/dist/plugins/generative-ui/ui/stack.d.ts +6 -6
- package/dist/plugins/generative-ui/ui/switch.d.ts +2 -2
- package/dist/plugins/generative-ui/ui/table.d.ts +9 -9
- package/dist/plugins/generative-ui/ui/tabs-wrapper.d.ts +1 -1
- package/dist/plugins/generative-ui/ui/tabs.d.ts +1 -1
- package/dist/plugins/generative-ui/ui/text.d.ts +3 -3
- package/dist/plugins/generative-ui/ui/textarea.d.ts +2 -2
- package/dist/plugins/generative-ui/ui/tooltip.d.ts +1 -1
- package/dist/plugins.cjs +1 -1
- package/dist/plugins.js +1 -1
- package/dist/{profiler-BFkhZRxj.js → profiler-FpBY9eRv.js} +2 -2
- package/dist/{profiler-BFkhZRxj.js.map → profiler-FpBY9eRv.js.map} +1 -1
- package/dist/{profiler-CyzxBxVz.cjs → profiler-_mthyjvo.cjs} +2 -2
- package/dist/{profiler-CyzxBxVz.cjs.map → profiler-_mthyjvo.cjs.map} +1 -1
- package/dist/react-shim.js +1 -1
- package/dist/server/express.cjs.map +1 -1
- package/dist/server/express.js.map +1 -1
- package/dist/{startRecording-Dq92sEHf.cjs → startRecording-NJcpiHw-.cjs} +2 -2
- package/dist/{startRecording-Dq92sEHf.cjs.map → startRecording-NJcpiHw-.cjs.map} +1 -1
- package/dist/{startRecording-C-PPAs_Z.js → startRecording-r5MXQ2Dm.js} +2 -2
- package/dist/{startRecording-C-PPAs_Z.js.map → startRecording-r5MXQ2Dm.js.map} +1 -1
- package/dist/types/index.d.ts +2 -2
- package/package.json +1 -5
- package/src/compat-plugin.ts +14 -14
- package/src/compat-shims.ts +33 -31
- package/src/compat.test.ts +48 -48
- package/src/compat.ts +6 -6
- package/src/components/Chat/index.tsx +17 -17
- package/src/components/Chat/stories/Charts.stories.tsx +98 -98
- package/src/components/Chat/stories/Composer.stories.tsx +15 -15
- package/src/components/Chat/stories/ConnectionConfiguration.stories.tsx +44 -44
- package/src/components/Chat/stories/CustomComponents.stories.tsx +17 -17
- package/src/components/Chat/stories/Density.stories.tsx +20 -20
- package/src/components/Chat/stories/ErrorBoundary.stories.tsx +47 -47
- package/src/components/Chat/stories/FrontendTools.stories.tsx +39 -39
- package/src/components/Chat/stories/GenerativeUI.stories.tsx +48 -48
- package/src/components/Chat/stories/MessageFeedback.stories.tsx +52 -52
- package/src/components/Chat/stories/Modal.stories.tsx +28 -28
- package/src/components/Chat/stories/Model.stories.tsx +11 -11
- package/src/components/Chat/stories/Radius.stories.tsx +20 -20
- package/src/components/Chat/stories/Sidecar.stories.tsx +13 -13
- package/src/components/Chat/stories/StyleIsolation.stories.tsx +11 -11
- package/src/components/Chat/stories/Theme.stories.tsx +25 -25
- package/src/components/Chat/stories/Thread.stories.tsx +25 -25
- package/src/components/Chat/stories/ToolApproval.stories.tsx +55 -55
- package/src/components/Chat/stories/ToolMentions.stories.tsx +17 -17
- package/src/components/Chat/stories/Tools.stories.tsx +88 -88
- package/src/components/Chat/stories/Variants.stories.tsx +32 -32
- package/src/components/Chat/stories/Welcome.stories.tsx +14 -14
- package/src/components/ChatHistory.tsx +7 -7
- package/src/components/FrontendTools/index.tsx +5 -5
- package/src/components/Replay.stories.tsx +157 -157
- package/src/components/Replay.tsx +76 -73
- package/src/components/ShadowRoot.tsx +40 -40
- package/src/components/ShareButton/index.tsx +32 -32
- package/src/components/assistant-ui/assistant-modal.tsx +92 -87
- package/src/components/assistant-ui/assistant-sidecar.tsx +35 -35
- package/src/components/assistant-ui/attachment.tsx +80 -80
- package/src/components/assistant-ui/connection-status-indicator.tsx +33 -33
- package/src/components/assistant-ui/error-boundary.tsx +34 -34
- package/src/components/assistant-ui/follow-on-suggestions.tsx +26 -26
- package/src/components/assistant-ui/markdown-text.tsx +69 -69
- package/src/components/assistant-ui/mentioned-tools-badges.tsx +38 -38
- package/src/components/assistant-ui/message-feedback.tsx +57 -50
- package/src/components/assistant-ui/reasoning.tsx +83 -83
- package/src/components/assistant-ui/thread-list.tsx +45 -45
- package/src/components/assistant-ui/thread.tsx +278 -278
- package/src/components/assistant-ui/tool-fallback.tsx +37 -37
- package/src/components/assistant-ui/tool-group.tsx +26 -26
- package/src/components/assistant-ui/tool-mention-autocomplete.tsx +122 -122
- package/src/components/assistant-ui/tooltip-icon-button.tsx +18 -18
- package/src/components/ui/avatar.tsx +12 -12
- package/src/components/ui/button.tsx +12 -12
- package/src/components/ui/buttonVariants.ts +17 -17
- package/src/components/ui/calendar.tsx +106 -106
- package/src/components/ui/charts.stories.tsx +56 -56
- package/src/components/ui/collapsible.tsx +5 -5
- package/src/components/ui/dialog.tsx +30 -30
- package/src/components/ui/generative-ui.stories.tsx +200 -200
- package/src/components/ui/generative-ui.tsx +26 -26
- package/src/components/ui/popover.tsx +14 -14
- package/src/components/ui/skeleton.tsx +5 -5
- package/src/components/ui/time-range-picker.stories.tsx +80 -80
- package/src/components/ui/time-range-picker.tsx +245 -244
- package/src/components/ui/tool-ui.stories.tsx +37 -37
- package/src/components/ui/tool-ui.tsx +221 -215
- package/src/components/ui/tooltip.tsx +15 -15
- package/src/constants/tailwind.ts +1 -1
- package/src/contexts/ChatIdContext.tsx +7 -7
- package/src/contexts/ConnectionStatusContext.tsx +64 -64
- package/src/contexts/ElementsProvider.tsx +214 -213
- package/src/contexts/ReplayContext.ts +3 -3
- package/src/contexts/ToolApprovalContext.tsx +54 -54
- package/src/contexts/ToolExecutionContext.tsx +34 -34
- package/src/contexts/contexts.ts +7 -7
- package/src/contexts/portal-container-context.ts +2 -2
- package/src/contexts/portal-container.tsx +7 -7
- package/src/embedded.ts +1 -1
- package/src/global.css +25 -25
- package/src/hooks/useAuth.ts +72 -72
- package/src/hooks/useDensity.ts +79 -79
- package/src/hooks/useElements.ts +6 -6
- package/src/hooks/useExpanded.ts +12 -12
- package/src/hooks/useFollowOnSuggestions.ts +83 -83
- package/src/hooks/useGramThreadListAdapter.tsx +99 -99
- package/src/hooks/useMCPTools.ts +47 -47
- package/src/hooks/useModel.ts +14 -14
- package/src/hooks/usePluginComponents.ts +11 -11
- package/src/hooks/usePortalContainer.ts +5 -5
- package/src/hooks/useRadius.ts +23 -23
- package/src/hooks/useRecordCassette.ts +34 -34
- package/src/hooks/useSession.ts +11 -11
- package/src/hooks/useThemeProps.ts +13 -13
- package/src/hooks/useThreadId.ts +4 -4
- package/src/hooks/useToolApproval.ts +7 -7
- package/src/hooks/useToolMentions.ts +40 -40
- package/src/index.ts +26 -26
- package/src/lib/api.test.ts +61 -61
- package/src/lib/api.ts +4 -3
- package/src/lib/auth.ts +13 -13
- package/src/lib/cassette.ts +84 -84
- package/src/lib/easing.ts +1 -1
- package/src/lib/errorTracking.config.ts +5 -5
- package/src/lib/errorTracking.ts +29 -29
- package/src/lib/generative-ui.ts +7 -7
- package/src/lib/humanize.ts +3 -3
- package/src/lib/messageConverter.test.ts +130 -127
- package/src/lib/messageConverter.ts +196 -196
- package/src/lib/models.ts +21 -20
- package/src/lib/token.test.ts +56 -56
- package/src/lib/token.ts +14 -14
- package/src/lib/tool-mentions.ts +45 -45
- package/src/lib/tools.ts +66 -62
- package/src/lib/utils.ts +5 -5
- package/src/lib.d.ts +1 -1
- package/src/plugins/README.md +5 -5
- package/src/plugins/chart/catalog.ts +18 -18
- package/src/plugins/chart/chart.test.ts +31 -31
- package/src/plugins/chart/component.tsx +34 -34
- package/src/plugins/chart/index.ts +4 -4
- package/src/plugins/chart/ui/area-chart.tsx +42 -42
- package/src/plugins/chart/ui/bar-chart.tsx +46 -46
- package/src/plugins/chart/ui/donut-chart.tsx +48 -48
- package/src/plugins/chart/ui/index.ts +7 -7
- package/src/plugins/chart/ui/line-chart.tsx +43 -43
- package/src/plugins/chart/ui/pie-chart.tsx +44 -44
- package/src/plugins/chart/ui/radar-chart.tsx +33 -33
- package/src/plugins/chart/ui/scatter-chart.tsx +43 -43
- package/src/plugins/components/MacOSWindowFrame.tsx +15 -15
- package/src/plugins/components/PluginLoadingState.tsx +10 -10
- package/src/plugins/components/index.ts +1 -1
- package/src/plugins/generative-ui/catalog.ts +54 -54
- package/src/plugins/generative-ui/component.tsx +85 -85
- package/src/plugins/generative-ui/index.ts +4 -4
- package/src/plugins/generative-ui/ui/accordion-wrapper.tsx +16 -16
- package/src/plugins/generative-ui/ui/accordion.tsx +16 -16
- package/src/plugins/generative-ui/ui/action-button.tsx +28 -28
- package/src/plugins/generative-ui/ui/alert-wrapper.tsx +8 -8
- package/src/plugins/generative-ui/ui/alert.tsx +20 -20
- package/src/plugins/generative-ui/ui/avatar-wrapper.tsx +7 -7
- package/src/plugins/generative-ui/ui/avatar.tsx +30 -30
- package/src/plugins/generative-ui/ui/badge.tsx +22 -22
- package/src/plugins/generative-ui/ui/button-wrapper.tsx +12 -12
- package/src/plugins/generative-ui/ui/button.tsx +28 -28
- package/src/plugins/generative-ui/ui/card-wrapper.tsx +8 -8
- package/src/plugins/generative-ui/ui/card.tsx +27 -27
- package/src/plugins/generative-ui/ui/checkbox-wrapper.tsx +9 -9
- package/src/plugins/generative-ui/ui/checkbox.tsx +9 -9
- package/src/plugins/generative-ui/ui/data-table.tsx +8 -8
- package/src/plugins/generative-ui/ui/dialog.tsx +31 -31
- package/src/plugins/generative-ui/ui/dropdown-menu.tsx +44 -44
- package/src/plugins/generative-ui/ui/grid.tsx +12 -12
- package/src/plugins/generative-ui/ui/index.ts +40 -40
- package/src/plugins/generative-ui/ui/input-wrapper.tsx +11 -11
- package/src/plugins/generative-ui/ui/input.tsx +9 -9
- package/src/plugins/generative-ui/ui/label.tsx +8 -8
- package/src/plugins/generative-ui/ui/list.tsx +11 -11
- package/src/plugins/generative-ui/ui/metric.tsx +23 -23
- package/src/plugins/generative-ui/ui/pagination.tsx +28 -28
- package/src/plugins/generative-ui/ui/popover.tsx +21 -21
- package/src/plugins/generative-ui/ui/progress.tsx +13 -13
- package/src/plugins/generative-ui/ui/radio-group.tsx +12 -12
- package/src/plugins/generative-ui/ui/select-wrapper.tsx +7 -7
- package/src/plugins/generative-ui/ui/select.tsx +37 -37
- package/src/plugins/generative-ui/ui/separator.tsx +9 -9
- package/src/plugins/generative-ui/ui/skeleton-wrapper.tsx +10 -10
- package/src/plugins/generative-ui/ui/skeleton.tsx +5 -5
- package/src/plugins/generative-ui/ui/stack.tsx +28 -28
- package/src/plugins/generative-ui/ui/switch.tsx +11 -11
- package/src/plugins/generative-ui/ui/table.tsx +32 -32
- package/src/plugins/generative-ui/ui/tabs-wrapper.tsx +11 -11
- package/src/plugins/generative-ui/ui/tabs.tsx +26 -26
- package/src/plugins/generative-ui/ui/text.tsx +12 -12
- package/src/plugins/generative-ui/ui/textarea.tsx +7 -7
- package/src/plugins/generative-ui/ui/tooltip.tsx +12 -12
- package/src/plugins/index.ts +7 -7
- package/src/react-shim.ts +6 -6
- package/src/server/bun.ts +12 -12
- package/src/server/core.ts +25 -25
- package/src/server/express.ts +17 -15
- package/src/server/fastify.ts +14 -14
- package/src/server/hono.ts +9 -9
- package/src/server/nextjs.ts +12 -12
- package/src/server/tanstack-start.ts +12 -12
- package/src/server.ts +27 -27
- package/src/storybook.d.ts +4 -4
- package/src/types/index.ts +122 -122
- package/src/types/plugins.ts +7 -7
- package/src/vite-env.d.ts +12 -12
- package/dist/compat-shims-BPJ7Q68c.js.map +0 -1
- package/dist/index-D0bAYNQy.js.map +0 -1
- package/dist/index-KSX4Qjip.cjs.map +0 -1
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
|
|
1
|
+
"use client";
|
|
2
2
|
|
|
3
|
-
import * as React from
|
|
4
|
-
import { CheckIcon, ChevronRightIcon, CircleIcon } from
|
|
5
|
-
import { DropdownMenu as DropdownMenuPrimitive } from
|
|
3
|
+
import * as React from "react";
|
|
4
|
+
import { CheckIcon, ChevronRightIcon, CircleIcon } from "lucide-react";
|
|
5
|
+
import { DropdownMenu as DropdownMenuPrimitive } from "radix-ui";
|
|
6
6
|
|
|
7
|
-
import { cn } from
|
|
7
|
+
import { cn } from "@/lib/utils";
|
|
8
8
|
|
|
9
9
|
function DropdownMenu({
|
|
10
10
|
...props
|
|
11
11
|
}: React.ComponentProps<typeof DropdownMenuPrimitive.Root>) {
|
|
12
|
-
return <DropdownMenuPrimitive.Root data-slot="dropdown-menu" {...props}
|
|
12
|
+
return <DropdownMenuPrimitive.Root data-slot="dropdown-menu" {...props} />;
|
|
13
13
|
}
|
|
14
14
|
|
|
15
15
|
function DropdownMenuPortal({
|
|
@@ -17,7 +17,7 @@ function DropdownMenuPortal({
|
|
|
17
17
|
}: React.ComponentProps<typeof DropdownMenuPrimitive.Portal>) {
|
|
18
18
|
return (
|
|
19
19
|
<DropdownMenuPrimitive.Portal data-slot="dropdown-menu-portal" {...props} />
|
|
20
|
-
)
|
|
20
|
+
);
|
|
21
21
|
}
|
|
22
22
|
|
|
23
23
|
function DropdownMenuTrigger({
|
|
@@ -28,7 +28,7 @@ function DropdownMenuTrigger({
|
|
|
28
28
|
data-slot="dropdown-menu-trigger"
|
|
29
29
|
{...props}
|
|
30
30
|
/>
|
|
31
|
-
)
|
|
31
|
+
);
|
|
32
32
|
}
|
|
33
33
|
|
|
34
34
|
function DropdownMenuContent({
|
|
@@ -42,13 +42,13 @@ function DropdownMenuContent({
|
|
|
42
42
|
data-slot="dropdown-menu-content"
|
|
43
43
|
sideOffset={sideOffset}
|
|
44
44
|
className={cn(
|
|
45
|
-
|
|
46
|
-
className
|
|
45
|
+
"z-50 max-h-(--radix-dropdown-menu-content-available-height) min-w-[8rem] origin-(--radix-dropdown-menu-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border bg-popover p-1 text-popover-foreground shadow-md 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 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[state=open]:animate-in data-[state=open]:fade-in-0 data-[state=open]:zoom-in-95",
|
|
46
|
+
className,
|
|
47
47
|
)}
|
|
48
48
|
{...props}
|
|
49
49
|
/>
|
|
50
50
|
</DropdownMenuPrimitive.Portal>
|
|
51
|
-
)
|
|
51
|
+
);
|
|
52
52
|
}
|
|
53
53
|
|
|
54
54
|
function DropdownMenuGroup({
|
|
@@ -56,17 +56,17 @@ function DropdownMenuGroup({
|
|
|
56
56
|
}: React.ComponentProps<typeof DropdownMenuPrimitive.Group>) {
|
|
57
57
|
return (
|
|
58
58
|
<DropdownMenuPrimitive.Group data-slot="dropdown-menu-group" {...props} />
|
|
59
|
-
)
|
|
59
|
+
);
|
|
60
60
|
}
|
|
61
61
|
|
|
62
62
|
function DropdownMenuItem({
|
|
63
63
|
className,
|
|
64
64
|
inset,
|
|
65
|
-
variant =
|
|
65
|
+
variant = "default",
|
|
66
66
|
...props
|
|
67
67
|
}: React.ComponentProps<typeof DropdownMenuPrimitive.Item> & {
|
|
68
|
-
inset?: boolean
|
|
69
|
-
variant?:
|
|
68
|
+
inset?: boolean;
|
|
69
|
+
variant?: "default" | "destructive";
|
|
70
70
|
}) {
|
|
71
71
|
return (
|
|
72
72
|
<DropdownMenuPrimitive.Item
|
|
@@ -74,12 +74,12 @@ function DropdownMenuItem({
|
|
|
74
74
|
data-inset={inset}
|
|
75
75
|
data-variant={variant}
|
|
76
76
|
className={cn(
|
|
77
|
-
"
|
|
78
|
-
className
|
|
77
|
+
"relative flex cursor-default items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-hidden select-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50 data-[inset]:pl-8 data-[variant=destructive]:text-destructive data-[variant=destructive]:focus:bg-destructive/10 data-[variant=destructive]:focus:text-destructive dark:data-[variant=destructive]:focus:bg-destructive/20 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 [&_svg:not([class*='text-'])]:text-muted-foreground data-[variant=destructive]:*:[svg]:!text-destructive",
|
|
78
|
+
className,
|
|
79
79
|
)}
|
|
80
80
|
{...props}
|
|
81
81
|
/>
|
|
82
|
-
)
|
|
82
|
+
);
|
|
83
83
|
}
|
|
84
84
|
|
|
85
85
|
function DropdownMenuCheckboxItem({
|
|
@@ -92,8 +92,8 @@ function DropdownMenuCheckboxItem({
|
|
|
92
92
|
<DropdownMenuPrimitive.CheckboxItem
|
|
93
93
|
data-slot="dropdown-menu-checkbox-item"
|
|
94
94
|
className={cn(
|
|
95
|
-
"
|
|
96
|
-
className
|
|
95
|
+
"relative flex cursor-default items-center gap-2 rounded-sm py-1.5 pr-2 pl-8 text-sm outline-hidden select-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
|
|
96
|
+
className,
|
|
97
97
|
)}
|
|
98
98
|
checked={checked}
|
|
99
99
|
{...props}
|
|
@@ -105,7 +105,7 @@ function DropdownMenuCheckboxItem({
|
|
|
105
105
|
</span>
|
|
106
106
|
{children}
|
|
107
107
|
</DropdownMenuPrimitive.CheckboxItem>
|
|
108
|
-
)
|
|
108
|
+
);
|
|
109
109
|
}
|
|
110
110
|
|
|
111
111
|
function DropdownMenuRadioGroup({
|
|
@@ -116,7 +116,7 @@ function DropdownMenuRadioGroup({
|
|
|
116
116
|
data-slot="dropdown-menu-radio-group"
|
|
117
117
|
{...props}
|
|
118
118
|
/>
|
|
119
|
-
)
|
|
119
|
+
);
|
|
120
120
|
}
|
|
121
121
|
|
|
122
122
|
function DropdownMenuRadioItem({
|
|
@@ -128,8 +128,8 @@ function DropdownMenuRadioItem({
|
|
|
128
128
|
<DropdownMenuPrimitive.RadioItem
|
|
129
129
|
data-slot="dropdown-menu-radio-item"
|
|
130
130
|
className={cn(
|
|
131
|
-
"
|
|
132
|
-
className
|
|
131
|
+
"relative flex cursor-default items-center gap-2 rounded-sm py-1.5 pr-2 pl-8 text-sm outline-hidden select-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
|
|
132
|
+
className,
|
|
133
133
|
)}
|
|
134
134
|
{...props}
|
|
135
135
|
>
|
|
@@ -140,7 +140,7 @@ function DropdownMenuRadioItem({
|
|
|
140
140
|
</span>
|
|
141
141
|
{children}
|
|
142
142
|
</DropdownMenuPrimitive.RadioItem>
|
|
143
|
-
)
|
|
143
|
+
);
|
|
144
144
|
}
|
|
145
145
|
|
|
146
146
|
function DropdownMenuLabel({
|
|
@@ -148,19 +148,19 @@ function DropdownMenuLabel({
|
|
|
148
148
|
inset,
|
|
149
149
|
...props
|
|
150
150
|
}: React.ComponentProps<typeof DropdownMenuPrimitive.Label> & {
|
|
151
|
-
inset?: boolean
|
|
151
|
+
inset?: boolean;
|
|
152
152
|
}) {
|
|
153
153
|
return (
|
|
154
154
|
<DropdownMenuPrimitive.Label
|
|
155
155
|
data-slot="dropdown-menu-label"
|
|
156
156
|
data-inset={inset}
|
|
157
157
|
className={cn(
|
|
158
|
-
|
|
159
|
-
className
|
|
158
|
+
"px-2 py-1.5 text-sm font-medium data-[inset]:pl-8",
|
|
159
|
+
className,
|
|
160
160
|
)}
|
|
161
161
|
{...props}
|
|
162
162
|
/>
|
|
163
|
-
)
|
|
163
|
+
);
|
|
164
164
|
}
|
|
165
165
|
|
|
166
166
|
function DropdownMenuSeparator({
|
|
@@ -170,32 +170,32 @@ function DropdownMenuSeparator({
|
|
|
170
170
|
return (
|
|
171
171
|
<DropdownMenuPrimitive.Separator
|
|
172
172
|
data-slot="dropdown-menu-separator"
|
|
173
|
-
className={cn(
|
|
173
|
+
className={cn("-mx-1 my-1 h-px bg-border", className)}
|
|
174
174
|
{...props}
|
|
175
175
|
/>
|
|
176
|
-
)
|
|
176
|
+
);
|
|
177
177
|
}
|
|
178
178
|
|
|
179
179
|
function DropdownMenuShortcut({
|
|
180
180
|
className,
|
|
181
181
|
...props
|
|
182
|
-
}: React.ComponentProps<
|
|
182
|
+
}: React.ComponentProps<"span">) {
|
|
183
183
|
return (
|
|
184
184
|
<span
|
|
185
185
|
data-slot="dropdown-menu-shortcut"
|
|
186
186
|
className={cn(
|
|
187
|
-
|
|
188
|
-
className
|
|
187
|
+
"ml-auto text-xs tracking-widest text-muted-foreground",
|
|
188
|
+
className,
|
|
189
189
|
)}
|
|
190
190
|
{...props}
|
|
191
191
|
/>
|
|
192
|
-
)
|
|
192
|
+
);
|
|
193
193
|
}
|
|
194
194
|
|
|
195
195
|
function DropdownMenuSub({
|
|
196
196
|
...props
|
|
197
197
|
}: React.ComponentProps<typeof DropdownMenuPrimitive.Sub>) {
|
|
198
|
-
return <DropdownMenuPrimitive.Sub data-slot="dropdown-menu-sub" {...props}
|
|
198
|
+
return <DropdownMenuPrimitive.Sub data-slot="dropdown-menu-sub" {...props} />;
|
|
199
199
|
}
|
|
200
200
|
|
|
201
201
|
function DropdownMenuSubTrigger({
|
|
@@ -204,22 +204,22 @@ function DropdownMenuSubTrigger({
|
|
|
204
204
|
children,
|
|
205
205
|
...props
|
|
206
206
|
}: React.ComponentProps<typeof DropdownMenuPrimitive.SubTrigger> & {
|
|
207
|
-
inset?: boolean
|
|
207
|
+
inset?: boolean;
|
|
208
208
|
}) {
|
|
209
209
|
return (
|
|
210
210
|
<DropdownMenuPrimitive.SubTrigger
|
|
211
211
|
data-slot="dropdown-menu-sub-trigger"
|
|
212
212
|
data-inset={inset}
|
|
213
213
|
className={cn(
|
|
214
|
-
"
|
|
215
|
-
className
|
|
214
|
+
"flex cursor-default items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-hidden select-none focus:bg-accent focus:text-accent-foreground data-[inset]:pl-8 data-[state=open]:bg-accent data-[state=open]:text-accent-foreground [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 [&_svg:not([class*='text-'])]:text-muted-foreground",
|
|
215
|
+
className,
|
|
216
216
|
)}
|
|
217
217
|
{...props}
|
|
218
218
|
>
|
|
219
219
|
{children}
|
|
220
220
|
<ChevronRightIcon className="ml-auto size-4" />
|
|
221
221
|
</DropdownMenuPrimitive.SubTrigger>
|
|
222
|
-
)
|
|
222
|
+
);
|
|
223
223
|
}
|
|
224
224
|
|
|
225
225
|
function DropdownMenuSubContent({
|
|
@@ -230,12 +230,12 @@ function DropdownMenuSubContent({
|
|
|
230
230
|
<DropdownMenuPrimitive.SubContent
|
|
231
231
|
data-slot="dropdown-menu-sub-content"
|
|
232
232
|
className={cn(
|
|
233
|
-
|
|
234
|
-
className
|
|
233
|
+
"z-50 min-w-[8rem] origin-(--radix-dropdown-menu-content-transform-origin) overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg 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 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[state=open]:animate-in data-[state=open]:fade-in-0 data-[state=open]:zoom-in-95",
|
|
234
|
+
className,
|
|
235
235
|
)}
|
|
236
236
|
{...props}
|
|
237
237
|
/>
|
|
238
|
-
)
|
|
238
|
+
);
|
|
239
239
|
}
|
|
240
240
|
|
|
241
241
|
export {
|
|
@@ -254,4 +254,4 @@ export {
|
|
|
254
254
|
DropdownMenuSub,
|
|
255
255
|
DropdownMenuSubTrigger,
|
|
256
256
|
DropdownMenuSubContent,
|
|
257
|
-
}
|
|
257
|
+
};
|
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
import * as React from
|
|
2
|
-
import { cn } from
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import { cn } from "@/lib/utils";
|
|
3
3
|
|
|
4
|
-
export interface GridProps extends React.ComponentProps<
|
|
5
|
-
columns?: number
|
|
6
|
-
gap?:
|
|
4
|
+
export interface GridProps extends React.ComponentProps<"div"> {
|
|
5
|
+
columns?: number;
|
|
6
|
+
gap?: "sm" | "md" | "lg";
|
|
7
7
|
}
|
|
8
8
|
|
|
9
9
|
const gapClasses = {
|
|
10
|
-
sm:
|
|
11
|
-
md:
|
|
12
|
-
lg:
|
|
13
|
-
}
|
|
10
|
+
sm: "gap-2",
|
|
11
|
+
md: "gap-4",
|
|
12
|
+
lg: "gap-6",
|
|
13
|
+
};
|
|
14
14
|
|
|
15
15
|
export function Grid({
|
|
16
16
|
columns = 2,
|
|
17
|
-
gap =
|
|
17
|
+
gap = "md",
|
|
18
18
|
className,
|
|
19
19
|
...props
|
|
20
20
|
}: GridProps) {
|
|
21
21
|
return (
|
|
22
22
|
<div
|
|
23
23
|
data-slot="grid"
|
|
24
|
-
className={cn(
|
|
24
|
+
className={cn("grid", gapClasses[gap], className)}
|
|
25
25
|
style={{ gridTemplateColumns: `repeat(${columns}, minmax(0, 1fr))` }}
|
|
26
26
|
{...props}
|
|
27
27
|
/>
|
|
28
|
-
)
|
|
28
|
+
);
|
|
29
29
|
}
|
|
@@ -1,43 +1,43 @@
|
|
|
1
1
|
// Vercel shadcn primitives
|
|
2
|
-
export * from
|
|
3
|
-
export * from
|
|
4
|
-
export * from
|
|
5
|
-
export * from
|
|
6
|
-
export * from
|
|
7
|
-
export * from
|
|
8
|
-
export * from
|
|
9
|
-
export * from
|
|
10
|
-
export * from
|
|
11
|
-
export * from
|
|
12
|
-
export * from
|
|
13
|
-
export * from
|
|
14
|
-
export * from
|
|
15
|
-
export * from
|
|
16
|
-
export * from
|
|
17
|
-
export * from
|
|
18
|
-
export * from
|
|
19
|
-
export * from
|
|
20
|
-
export * from
|
|
21
|
-
export * from
|
|
22
|
-
export * from
|
|
23
|
-
export * from
|
|
24
|
-
export * from
|
|
2
|
+
export * from "./accordion";
|
|
3
|
+
export * from "./alert";
|
|
4
|
+
export * from "./avatar";
|
|
5
|
+
export * from "./badge";
|
|
6
|
+
export * from "./button";
|
|
7
|
+
export * from "./card";
|
|
8
|
+
export * from "./checkbox";
|
|
9
|
+
export * from "./dialog";
|
|
10
|
+
export * from "./dropdown-menu";
|
|
11
|
+
export * from "./input";
|
|
12
|
+
export * from "./label";
|
|
13
|
+
export * from "./pagination";
|
|
14
|
+
export * from "./popover";
|
|
15
|
+
export * from "./progress";
|
|
16
|
+
export * from "./radio-group";
|
|
17
|
+
export * from "./select";
|
|
18
|
+
export * from "./separator";
|
|
19
|
+
export * from "./skeleton";
|
|
20
|
+
export * from "./switch";
|
|
21
|
+
export * from "./table";
|
|
22
|
+
export * from "./tabs";
|
|
23
|
+
export * from "./textarea";
|
|
24
|
+
export * from "./tooltip";
|
|
25
25
|
|
|
26
26
|
// json-render catalog wrappers
|
|
27
|
-
export * from
|
|
28
|
-
export * from
|
|
29
|
-
export * from
|
|
30
|
-
export * from
|
|
31
|
-
export * from
|
|
32
|
-
export * from
|
|
33
|
-
export * from
|
|
34
|
-
export * from
|
|
35
|
-
export * from
|
|
36
|
-
export * from
|
|
37
|
-
export * from
|
|
38
|
-
export * from
|
|
39
|
-
export * from
|
|
40
|
-
export * from
|
|
41
|
-
export * from
|
|
42
|
-
export * from
|
|
43
|
-
export * from
|
|
27
|
+
export * from "./accordion-wrapper";
|
|
28
|
+
export * from "./action-button";
|
|
29
|
+
export * from "./alert-wrapper";
|
|
30
|
+
export * from "./avatar-wrapper";
|
|
31
|
+
export * from "./button-wrapper";
|
|
32
|
+
export * from "./card-wrapper";
|
|
33
|
+
export * from "./checkbox-wrapper";
|
|
34
|
+
export * from "./data-table";
|
|
35
|
+
export * from "./grid";
|
|
36
|
+
export * from "./input-wrapper";
|
|
37
|
+
export * from "./list";
|
|
38
|
+
export * from "./metric";
|
|
39
|
+
export * from "./select-wrapper";
|
|
40
|
+
export * from "./skeleton-wrapper";
|
|
41
|
+
export * from "./stack";
|
|
42
|
+
export * from "./tabs-wrapper";
|
|
43
|
+
export * from "./text";
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
|
|
1
|
+
"use client";
|
|
2
2
|
|
|
3
|
-
import * as React from
|
|
4
|
-
import { Input } from
|
|
5
|
-
import { Label } from
|
|
3
|
+
import * as React from "react";
|
|
4
|
+
import { Input } from "./input";
|
|
5
|
+
import { Label } from "./label";
|
|
6
6
|
|
|
7
7
|
export interface InputWrapperProps {
|
|
8
|
-
label?: string
|
|
9
|
-
placeholder?: string
|
|
10
|
-
type?:
|
|
8
|
+
label?: string;
|
|
9
|
+
placeholder?: string;
|
|
10
|
+
type?: "text" | "email" | "password" | "number" | "tel";
|
|
11
11
|
/** Path for form state management (future use) */
|
|
12
|
-
valuePath: string
|
|
12
|
+
valuePath: string;
|
|
13
13
|
}
|
|
14
14
|
|
|
15
15
|
/**
|
|
@@ -18,10 +18,10 @@ export interface InputWrapperProps {
|
|
|
18
18
|
export function InputWrapper({
|
|
19
19
|
label,
|
|
20
20
|
placeholder,
|
|
21
|
-
type =
|
|
21
|
+
type = "text",
|
|
22
22
|
valuePath,
|
|
23
23
|
}: InputWrapperProps) {
|
|
24
|
-
const id = React.useId()
|
|
24
|
+
const id = React.useId();
|
|
25
25
|
|
|
26
26
|
return (
|
|
27
27
|
<div className="flex flex-col gap-1.5">
|
|
@@ -34,5 +34,5 @@ export function InputWrapper({
|
|
|
34
34
|
data-value-path={valuePath}
|
|
35
35
|
/>
|
|
36
36
|
</div>
|
|
37
|
-
)
|
|
37
|
+
);
|
|
38
38
|
}
|
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
import * as React from
|
|
1
|
+
import * as React from "react";
|
|
2
2
|
|
|
3
|
-
import { cn } from
|
|
3
|
+
import { cn } from "@/lib/utils";
|
|
4
4
|
|
|
5
|
-
function Input({ className, type, ...props }: React.ComponentProps<
|
|
5
|
+
function Input({ className, type, ...props }: React.ComponentProps<"input">) {
|
|
6
6
|
return (
|
|
7
7
|
<input
|
|
8
8
|
type={type}
|
|
9
9
|
data-slot="input"
|
|
10
10
|
className={cn(
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
className
|
|
11
|
+
"h-9 w-full min-w-0 rounded-md border border-input bg-transparent px-3 py-1 text-base shadow-xs transition-[color,box-shadow] outline-none selection:bg-primary selection:text-primary-foreground file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium file:text-foreground placeholder:text-muted-foreground disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50 md:text-sm dark:bg-input/30",
|
|
12
|
+
"focus-visible:border-ring focus-visible:ring-[3px] focus-visible:ring-ring/50",
|
|
13
|
+
"aria-invalid:border-destructive aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40",
|
|
14
|
+
className,
|
|
15
15
|
)}
|
|
16
16
|
{...props}
|
|
17
17
|
/>
|
|
18
|
-
)
|
|
18
|
+
);
|
|
19
19
|
}
|
|
20
20
|
|
|
21
|
-
export { Input }
|
|
21
|
+
export { Input };
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
|
|
1
|
+
"use client";
|
|
2
2
|
|
|
3
|
-
import * as React from
|
|
4
|
-
import { Label as LabelPrimitive } from
|
|
3
|
+
import * as React from "react";
|
|
4
|
+
import { Label as LabelPrimitive } from "radix-ui";
|
|
5
5
|
|
|
6
|
-
import { cn } from
|
|
6
|
+
import { cn } from "@/lib/utils";
|
|
7
7
|
|
|
8
8
|
function Label({
|
|
9
9
|
className,
|
|
@@ -13,12 +13,12 @@ function Label({
|
|
|
13
13
|
<LabelPrimitive.Root
|
|
14
14
|
data-slot="label"
|
|
15
15
|
className={cn(
|
|
16
|
-
|
|
17
|
-
className
|
|
16
|
+
"flex items-center gap-2 text-sm leading-none font-medium select-none group-data-[disabled=true]:pointer-events-none group-data-[disabled=true]:opacity-50 peer-disabled:cursor-not-allowed peer-disabled:opacity-50",
|
|
17
|
+
className,
|
|
18
18
|
)}
|
|
19
19
|
{...props}
|
|
20
20
|
/>
|
|
21
|
-
)
|
|
21
|
+
);
|
|
22
22
|
}
|
|
23
23
|
|
|
24
|
-
export { Label }
|
|
24
|
+
export { Label };
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
import * as React from
|
|
2
|
-
import { cn } from
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import { cn } from "@/lib/utils";
|
|
3
3
|
|
|
4
4
|
export interface ListProps {
|
|
5
|
-
items: string[]
|
|
6
|
-
ordered?: boolean
|
|
7
|
-
className?: string
|
|
5
|
+
items: string[];
|
|
6
|
+
ordered?: boolean;
|
|
7
|
+
className?: string;
|
|
8
8
|
}
|
|
9
9
|
|
|
10
10
|
export function List({ items, ordered = false, className }: ListProps) {
|
|
11
11
|
const listClasses = cn(
|
|
12
|
-
|
|
13
|
-
ordered ?
|
|
14
|
-
className
|
|
15
|
-
)
|
|
12
|
+
"space-y-1 pl-4 text-foreground",
|
|
13
|
+
ordered ? "list-decimal" : "list-disc",
|
|
14
|
+
className,
|
|
15
|
+
);
|
|
16
16
|
|
|
17
17
|
if (ordered) {
|
|
18
18
|
return (
|
|
@@ -21,7 +21,7 @@ export function List({ items, ordered = false, className }: ListProps) {
|
|
|
21
21
|
<li key={index}>{item}</li>
|
|
22
22
|
))}
|
|
23
23
|
</ol>
|
|
24
|
-
)
|
|
24
|
+
);
|
|
25
25
|
}
|
|
26
26
|
|
|
27
27
|
return (
|
|
@@ -30,5 +30,5 @@ export function List({ items, ordered = false, className }: ListProps) {
|
|
|
30
30
|
<li key={index}>{item}</li>
|
|
31
31
|
))}
|
|
32
32
|
</ul>
|
|
33
|
-
)
|
|
33
|
+
);
|
|
34
34
|
}
|
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
import * as React from
|
|
2
|
-
import { cn } from
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import { cn } from "@/lib/utils";
|
|
3
3
|
|
|
4
|
-
export interface MetricProps extends React.ComponentProps<
|
|
5
|
-
label: string
|
|
6
|
-
value: string | number
|
|
7
|
-
format?:
|
|
4
|
+
export interface MetricProps extends React.ComponentProps<"div"> {
|
|
5
|
+
label: string;
|
|
6
|
+
value: string | number;
|
|
7
|
+
format?: "number" | "currency" | "percent";
|
|
8
8
|
}
|
|
9
9
|
|
|
10
10
|
function formatValue(
|
|
11
11
|
value: string | number,
|
|
12
|
-
format?:
|
|
12
|
+
format?: "number" | "currency" | "percent",
|
|
13
13
|
): string {
|
|
14
|
-
if (typeof value ===
|
|
14
|
+
if (typeof value === "string") return value;
|
|
15
15
|
|
|
16
16
|
switch (format) {
|
|
17
|
-
case
|
|
18
|
-
return new Intl.NumberFormat(
|
|
19
|
-
style:
|
|
20
|
-
currency:
|
|
21
|
-
}).format(value)
|
|
22
|
-
case
|
|
23
|
-
return new Intl.NumberFormat(
|
|
24
|
-
style:
|
|
17
|
+
case "currency":
|
|
18
|
+
return new Intl.NumberFormat("en-US", {
|
|
19
|
+
style: "currency",
|
|
20
|
+
currency: "USD",
|
|
21
|
+
}).format(value);
|
|
22
|
+
case "percent":
|
|
23
|
+
return new Intl.NumberFormat("en-US", {
|
|
24
|
+
style: "percent",
|
|
25
25
|
minimumFractionDigits: 0,
|
|
26
26
|
maximumFractionDigits: 1,
|
|
27
|
-
}).format(value)
|
|
28
|
-
case
|
|
27
|
+
}).format(value);
|
|
28
|
+
case "number":
|
|
29
29
|
default:
|
|
30
|
-
return new Intl.NumberFormat(
|
|
30
|
+
return new Intl.NumberFormat("en-US").format(value);
|
|
31
31
|
}
|
|
32
32
|
}
|
|
33
33
|
|
|
@@ -41,13 +41,13 @@ export function Metric({
|
|
|
41
41
|
return (
|
|
42
42
|
<div
|
|
43
43
|
data-slot="metric"
|
|
44
|
-
className={cn(
|
|
44
|
+
className={cn("flex flex-col", className)}
|
|
45
45
|
{...props}
|
|
46
46
|
>
|
|
47
|
-
<span className="text-muted-foreground
|
|
48
|
-
<span className="text-
|
|
47
|
+
<span className="text-sm text-muted-foreground">{label}</span>
|
|
48
|
+
<span className="text-2xl font-semibold text-foreground">
|
|
49
49
|
{formatValue(value, format)}
|
|
50
50
|
</span>
|
|
51
51
|
</div>
|
|
52
|
-
)
|
|
52
|
+
);
|
|
53
53
|
}
|