@contractspec/lib.ui-kit-web 3.7.6 → 3.8.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/README.md +33 -88
- package/dist/browser/ui/accordion.js +4 -4
- package/dist/browser/ui/alert-dialog.js +9 -9
- package/dist/browser/ui/alert.js +4 -4
- package/dist/browser/ui/atoms/FilterSelect/FilterSelect.js +51 -51
- package/dist/browser/ui/atoms/FilterSelect/index.js +51 -51
- package/dist/browser/ui/atoms/LoadingSpinner/LoadingSpinner.js +1 -1
- package/dist/browser/ui/atoms/Pagination/Pagination.js +13 -13
- package/dist/browser/ui/atoms/Pagination/index.js +13 -13
- package/dist/browser/ui/atoms/SearchInput/SearchInput.js +8 -8
- package/dist/browser/ui/atoms/SearchInput/index.js +8 -8
- package/dist/browser/ui/avatar.js +1 -1
- package/dist/browser/ui/badge.js +3 -3
- package/dist/browser/ui/breadcrumb.js +4 -4
- package/dist/browser/ui/button.js +5 -5
- package/dist/browser/ui/calendar.js +21 -21
- package/dist/browser/ui/card.js +2 -2
- package/dist/browser/ui/carousel.js +6 -6
- package/dist/browser/ui/checkbox.js +2 -2
- package/dist/browser/ui/command.js +14 -14
- package/dist/browser/ui/confirm-dialog.js +9 -9
- package/dist/browser/ui/context-menu.js +10 -10
- package/dist/browser/ui/cta.js +5 -5
- package/dist/browser/ui/data-table.js +1005 -0
- package/dist/browser/ui/data-table.parts.js +463 -0
- package/dist/browser/ui/date-picker.js +26 -26
- package/dist/browser/ui/date-range-picker.js +24 -24
- package/dist/browser/ui/datetime-picker.js +29 -29
- package/dist/browser/ui/dialog.js +5 -5
- package/dist/browser/ui/drawer.js +5 -5
- package/dist/browser/ui/dropdown-menu.js +10 -10
- package/dist/browser/ui/empty-state.js +5 -5
- package/dist/browser/ui/empty.js +7 -7
- package/dist/browser/ui/field.js +12 -12
- package/dist/browser/ui/form.js +4 -4
- package/dist/browser/ui/hover-card.js +2 -2
- package/dist/browser/ui/input-group.js +16 -16
- package/dist/browser/ui/input-otp.js +4 -4
- package/dist/browser/ui/input.js +1 -1
- package/dist/browser/ui/label.js +2 -2
- package/dist/browser/ui/loading-button.js +8 -8
- package/dist/browser/ui/marketing/FeatureGrid.js +3 -3
- package/dist/browser/ui/marketing/Hero.js +7 -7
- package/dist/browser/ui/marketing/PricingTable.js +10 -10
- package/dist/browser/ui/menubar.js +12 -12
- package/dist/browser/ui/molecules/Autocomplete/index.js +26 -26
- package/dist/browser/ui/molecules/SearchAndFilter/SearchAndFilter.js +62 -62
- package/dist/browser/ui/molecules/SearchAndFilter/index.js +62 -62
- package/dist/browser/ui/molecules/SkeletonList.js +1 -1
- package/dist/browser/ui/nav-layout.js +22 -22
- package/dist/browser/ui/navigation-menu.js +7 -7
- package/dist/browser/ui/organisms/ErrorBoundary/ErrorBoundary.js +11 -11
- package/dist/browser/ui/organisms/ListPage/ListPage.js +84 -84
- package/dist/browser/ui/page-header.js +4 -4
- package/dist/browser/ui/pagination.js +6 -6
- package/dist/browser/ui/popover.js +2 -2
- package/dist/browser/ui/progress.js +3 -3
- package/dist/browser/ui/radio-group.js +3 -3
- package/dist/browser/ui/resizable.js +3 -3
- package/dist/browser/ui/scroll-area.js +4 -4
- package/dist/browser/ui/section.js +1 -1
- package/dist/browser/ui/select.js +6 -6
- package/dist/browser/ui/separator.js +2 -2
- package/dist/browser/ui/sheet.js +5 -5
- package/dist/browser/ui/sidebar.js +64 -64
- package/dist/browser/ui/skeleton.js +1 -1
- package/dist/browser/ui/slider.js +6 -6
- package/dist/browser/ui/stack.js +1 -1
- package/dist/browser/ui/stat-card-group.js +5 -5
- package/dist/browser/ui/stepper.js +2 -2
- package/dist/browser/ui/switch.js +3 -3
- package/dist/browser/ui/table.js +5 -5
- package/dist/browser/ui/tabs.js +3 -3
- package/dist/browser/ui/text.js +2 -2
- package/dist/browser/ui/textarea.js +1 -1
- package/dist/browser/ui/time-picker.js +10 -10
- package/dist/browser/ui/toast.js +5 -5
- package/dist/browser/ui/toaster.js +5 -5
- package/dist/browser/ui/toggle-group.js +7 -7
- package/dist/browser/ui/toggle.js +5 -5
- package/dist/browser/ui/tooltip.js +3 -3
- package/dist/browser/ui/typography.js +14 -14
- package/dist/browser/ui/usecases/UseCaseCard.js +8 -8
- package/dist/browser/ui/usecases/UserStoryCard.js +3 -3
- package/dist/browser/ui/visualization/Visualization.js +439 -0
- package/dist/browser/ui/visualization/Visualization.support.js +128 -0
- package/dist/browser/ui/visualization/index.js +10 -0
- package/dist/ui/accordion.d.ts +2 -2
- package/dist/ui/accordion.js +4 -4
- package/dist/ui/alert-dialog.d.ts +2 -2
- package/dist/ui/alert-dialog.js +9 -9
- package/dist/ui/alert.d.ts +2 -2
- package/dist/ui/alert.js +4 -4
- package/dist/ui/atoms/FilterSelect/FilterSelect.js +51 -51
- package/dist/ui/atoms/FilterSelect/index.d.ts +1 -1
- package/dist/ui/atoms/FilterSelect/index.js +51 -51
- package/dist/ui/atoms/LoadingSpinner/LoadingSpinner.js +1 -1
- package/dist/ui/atoms/LoadingSpinner/index.d.ts +1 -1
- package/dist/ui/atoms/Pagination/Pagination.js +13 -13
- package/dist/ui/atoms/Pagination/index.js +13 -13
- package/dist/ui/atoms/SearchInput/SearchInput.js +8 -8
- package/dist/ui/atoms/SearchInput/index.js +8 -8
- package/dist/ui/avatar.d.ts +2 -2
- package/dist/ui/avatar.js +1 -1
- package/dist/ui/badge.d.ts +1 -1
- package/dist/ui/badge.js +3 -3
- package/dist/ui/breadcrumb.d.ts +1 -1
- package/dist/ui/breadcrumb.js +4 -4
- package/dist/ui/button.d.ts +1 -1
- package/dist/ui/button.js +5 -5
- package/dist/ui/calendar.js +21 -21
- package/dist/ui/card.d.ts +1 -1
- package/dist/ui/card.js +2 -2
- package/dist/ui/carousel.d.ts +2 -2
- package/dist/ui/carousel.js +6 -6
- package/dist/ui/checkbox.d.ts +1 -1
- package/dist/ui/checkbox.js +2 -2
- package/dist/ui/collapsible.d.ts +1 -1
- package/dist/ui/command.d.ts +2 -2
- package/dist/ui/command.js +14 -14
- package/dist/ui/confirm-dialog.js +9 -9
- package/dist/ui/context-menu.d.ts +2 -2
- package/dist/ui/context-menu.js +10 -10
- package/dist/ui/cta.js +5 -5
- package/dist/ui/data-table.d.ts +12 -0
- package/dist/ui/data-table.js +1000 -0
- package/dist/ui/data-table.parts.d.ts +14 -0
- package/dist/ui/data-table.parts.js +458 -0
- package/dist/ui/date-picker.js +26 -26
- package/dist/ui/date-range-picker.js +24 -24
- package/dist/ui/datetime-picker.js +29 -29
- package/dist/ui/dialog.d.ts +1 -1
- package/dist/ui/dialog.js +5 -5
- package/dist/ui/drawer.d.ts +1 -1
- package/dist/ui/drawer.js +5 -5
- package/dist/ui/dropdown-menu.d.ts +2 -2
- package/dist/ui/dropdown-menu.js +10 -10
- package/dist/ui/empty-state.d.ts +1 -1
- package/dist/ui/empty-state.js +5 -5
- package/dist/ui/empty.d.ts +2 -2
- package/dist/ui/empty.js +7 -7
- package/dist/ui/field.d.ts +2 -2
- package/dist/ui/field.js +12 -12
- package/dist/ui/form.d.ts +3 -3
- package/dist/ui/form.js +4 -4
- package/dist/ui/hover-card.d.ts +2 -2
- package/dist/ui/hover-card.js +2 -2
- package/dist/ui/input-group.d.ts +2 -2
- package/dist/ui/input-group.js +16 -16
- package/dist/ui/input-otp.d.ts +2 -2
- package/dist/ui/input-otp.js +4 -4
- package/dist/ui/input.js +1 -1
- package/dist/ui/label.d.ts +1 -1
- package/dist/ui/label.js +2 -2
- package/dist/ui/loading-button.js +8 -8
- package/dist/ui/map/index.d.ts +1 -1
- package/dist/ui/marketing/FeatureGrid.js +3 -3
- package/dist/ui/marketing/Hero.js +7 -7
- package/dist/ui/marketing/PricingTable.js +10 -10
- package/dist/ui/marketing/index.d.ts +1 -1
- package/dist/ui/menubar.d.ts +2 -2
- package/dist/ui/menubar.js +12 -12
- package/dist/ui/molecules/Autocomplete/index.js +26 -26
- package/dist/ui/molecules/SearchAndFilter/SearchAndFilter.js +62 -62
- package/dist/ui/molecules/SearchAndFilter/index.js +62 -62
- package/dist/ui/molecules/SkeletonList.js +1 -1
- package/dist/ui/nav-layout.d.ts +1 -1
- package/dist/ui/nav-layout.js +22 -22
- package/dist/ui/navigation-menu.d.ts +2 -2
- package/dist/ui/navigation-menu.js +7 -7
- package/dist/ui/organisms/ErrorBoundary/ErrorBoundary.js +11 -11
- package/dist/ui/organisms/ErrorBoundary/index.d.ts +1 -1
- package/dist/ui/organisms/ListPage/ListPage.js +84 -84
- package/dist/ui/organisms/ListPage/index.d.ts +1 -1
- package/dist/ui/organisms/ListPage/types.d.ts +1 -1
- package/dist/ui/page-header.d.ts +1 -1
- package/dist/ui/page-header.js +4 -4
- package/dist/ui/pagination.js +6 -6
- package/dist/ui/popover.d.ts +2 -2
- package/dist/ui/popover.js +2 -2
- package/dist/ui/progress.d.ts +1 -1
- package/dist/ui/progress.js +3 -3
- package/dist/ui/radio-group.d.ts +1 -1
- package/dist/ui/radio-group.js +3 -3
- package/dist/ui/resizable.d.ts +2 -2
- package/dist/ui/resizable.js +3 -3
- package/dist/ui/scroll-area.d.ts +1 -1
- package/dist/ui/scroll-area.js +4 -4
- package/dist/ui/section.d.ts +1 -1
- package/dist/ui/section.js +1 -1
- package/dist/ui/select.d.ts +1 -1
- package/dist/ui/select.js +6 -6
- package/dist/ui/separator.d.ts +1 -1
- package/dist/ui/separator.js +2 -2
- package/dist/ui/sheet.d.ts +2 -2
- package/dist/ui/sheet.js +5 -5
- package/dist/ui/sidebar.d.ts +1 -1
- package/dist/ui/sidebar.js +64 -64
- package/dist/ui/skeleton.js +1 -1
- package/dist/ui/slider.d.ts +1 -1
- package/dist/ui/slider.js +6 -6
- package/dist/ui/stack.d.ts +4 -4
- package/dist/ui/stack.js +1 -1
- package/dist/ui/stat-card-group.js +5 -5
- package/dist/ui/stepper.js +2 -2
- package/dist/ui/switch.d.ts +1 -1
- package/dist/ui/switch.js +3 -3
- package/dist/ui/table.d.ts +1 -1
- package/dist/ui/table.js +5 -5
- package/dist/ui/tabs.d.ts +2 -2
- package/dist/ui/tabs.js +3 -3
- package/dist/ui/text.js +2 -2
- package/dist/ui/textarea.js +1 -1
- package/dist/ui/time-picker.js +10 -10
- package/dist/ui/toast.d.ts +2 -2
- package/dist/ui/toast.js +5 -5
- package/dist/ui/toaster.js +5 -5
- package/dist/ui/toggle-group.d.ts +1 -1
- package/dist/ui/toggle-group.js +7 -7
- package/dist/ui/toggle.d.ts +1 -1
- package/dist/ui/toggle.js +5 -5
- package/dist/ui/tooltip.d.ts +2 -2
- package/dist/ui/tooltip.js +3 -3
- package/dist/ui/typography.js +14 -14
- package/dist/ui/use-toast.d.ts +1 -1
- package/dist/ui/usecases/UseCaseCard.js +8 -8
- package/dist/ui/usecases/UserStoryCard.js +3 -3
- package/dist/ui/visualization/Visualization.d.ts +9 -0
- package/dist/ui/visualization/Visualization.js +434 -0
- package/dist/ui/visualization/Visualization.support.d.ts +15 -0
- package/dist/ui/visualization/Visualization.support.js +123 -0
- package/dist/ui/visualization/index.d.ts +1 -0
- package/dist/ui/visualization/index.js +5 -0
- package/package.json +72 -9
|
@@ -7,9 +7,9 @@ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require
|
|
|
7
7
|
});
|
|
8
8
|
|
|
9
9
|
// ui/menubar.tsx
|
|
10
|
+
import { cn } from "@contractspec/lib.ui-kit-core/utils";
|
|
10
11
|
import * as MenubarPrimitive from "@radix-ui/react-menubar";
|
|
11
12
|
import { CheckIcon, ChevronRightIcon, CircleIcon } from "lucide-react";
|
|
12
|
-
import { cn } from "@contractspec/lib.ui-kit-core/utils";
|
|
13
13
|
import { jsxDEV } from "react/jsx-dev-runtime";
|
|
14
14
|
"use client";
|
|
15
15
|
function Menubar({
|
|
@@ -18,7 +18,7 @@ function Menubar({
|
|
|
18
18
|
}) {
|
|
19
19
|
return /* @__PURE__ */ jsxDEV(MenubarPrimitive.Root, {
|
|
20
20
|
"data-slot": "menubar",
|
|
21
|
-
className: cn("
|
|
21
|
+
className: cn("flex h-9 items-center gap-1 rounded-md border bg-background p-1 shadow-2xs", className),
|
|
22
22
|
...props
|
|
23
23
|
}, undefined, false, undefined, this);
|
|
24
24
|
}
|
|
@@ -60,7 +60,7 @@ function MenubarTrigger({
|
|
|
60
60
|
}) {
|
|
61
61
|
return /* @__PURE__ */ jsxDEV(MenubarPrimitive.Trigger, {
|
|
62
62
|
"data-slot": "menubar-trigger",
|
|
63
|
-
className: cn("focus:bg-accent focus:text-accent-foreground data-[state=open]:bg-accent data-[state=open]:text-accent-foreground
|
|
63
|
+
className: cn("flex select-none items-center rounded-xs px-2 py-1 font-medium text-sm outline-hidden focus:bg-accent focus:text-accent-foreground data-[state=open]:bg-accent data-[state=open]:text-accent-foreground", className),
|
|
64
64
|
...props
|
|
65
65
|
}, undefined, false, undefined, this);
|
|
66
66
|
}
|
|
@@ -77,7 +77,7 @@ function MenubarContent({
|
|
|
77
77
|
align,
|
|
78
78
|
alignOffset,
|
|
79
79
|
sideOffset,
|
|
80
|
-
className: cn("
|
|
80
|
+
className: cn("data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-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 z-50 min-w-48 origin-(--radix-menubar-content-transform-origin) overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md data-[state=open]:animate-in", className),
|
|
81
81
|
...props
|
|
82
82
|
}, undefined, false, undefined, this)
|
|
83
83
|
}, undefined, false, undefined, this);
|
|
@@ -92,7 +92,7 @@ function MenubarItem({
|
|
|
92
92
|
"data-slot": "menubar-item",
|
|
93
93
|
"data-inset": inset,
|
|
94
94
|
"data-variant": variant,
|
|
95
|
-
className: cn("
|
|
95
|
+
className: cn("relative flex cursor-default select-none items-center gap-2 rounded-xs px-2 py-1.5 text-sm outline-hidden focus:bg-accent focus:text-accent-foreground data-disabled:pointer-events-none data-inset:pl-8 data-[variant=destructive]:text-destructive data-disabled:opacity-50 data-[variant=destructive]:focus:bg-destructive/10 data-[variant=destructive]:focus:text-destructive dark:data-[variant=destructive]:focus:bg-destructive/20 [&_svg:not([class*='size-'])]:size-4 [&_svg:not([class*='text-'])]:text-muted-foreground [&_svg]:pointer-events-none [&_svg]:shrink-0 data-[variant=destructive]:*:[svg]:text-destructive!", className),
|
|
96
96
|
...props
|
|
97
97
|
}, undefined, false, undefined, this);
|
|
98
98
|
}
|
|
@@ -104,7 +104,7 @@ function MenubarCheckboxItem({
|
|
|
104
104
|
}) {
|
|
105
105
|
return /* @__PURE__ */ jsxDEV(MenubarPrimitive.CheckboxItem, {
|
|
106
106
|
"data-slot": "menubar-checkbox-item",
|
|
107
|
-
className: cn("
|
|
107
|
+
className: cn("relative flex cursor-default select-none items-center gap-2 rounded-xs py-1.5 pr-2 pl-8 text-sm outline-hidden focus:bg-accent focus:text-accent-foreground data-disabled:pointer-events-none data-disabled:opacity-50 [&_svg:not([class*='size-'])]:size-4 [&_svg]:pointer-events-none [&_svg]:shrink-0", className),
|
|
108
108
|
checked,
|
|
109
109
|
...props,
|
|
110
110
|
children: [
|
|
@@ -127,7 +127,7 @@ function MenubarRadioItem({
|
|
|
127
127
|
}) {
|
|
128
128
|
return /* @__PURE__ */ jsxDEV(MenubarPrimitive.RadioItem, {
|
|
129
129
|
"data-slot": "menubar-radio-item",
|
|
130
|
-
className: cn("
|
|
130
|
+
className: cn("relative flex cursor-default select-none items-center gap-2 rounded-xs py-1.5 pr-2 pl-8 text-sm outline-hidden focus:bg-accent focus:text-accent-foreground data-disabled:pointer-events-none data-disabled:opacity-50 [&_svg:not([class*='size-'])]:size-4 [&_svg]:pointer-events-none [&_svg]:shrink-0", className),
|
|
131
131
|
...props,
|
|
132
132
|
children: [
|
|
133
133
|
/* @__PURE__ */ jsxDEV("span", {
|
|
@@ -150,7 +150,7 @@ function MenubarLabel({
|
|
|
150
150
|
return /* @__PURE__ */ jsxDEV(MenubarPrimitive.Label, {
|
|
151
151
|
"data-slot": "menubar-label",
|
|
152
152
|
"data-inset": inset,
|
|
153
|
-
className: cn("px-2 py-1.5 text-sm
|
|
153
|
+
className: cn("px-2 py-1.5 font-medium text-sm data-inset:pl-8", className),
|
|
154
154
|
...props
|
|
155
155
|
}, undefined, false, undefined, this);
|
|
156
156
|
}
|
|
@@ -160,7 +160,7 @@ function MenubarSeparator({
|
|
|
160
160
|
}) {
|
|
161
161
|
return /* @__PURE__ */ jsxDEV(MenubarPrimitive.Separator, {
|
|
162
162
|
"data-slot": "menubar-separator",
|
|
163
|
-
className: cn("
|
|
163
|
+
className: cn("-mx-1 my-1 h-px bg-border", className),
|
|
164
164
|
...props
|
|
165
165
|
}, undefined, false, undefined, this);
|
|
166
166
|
}
|
|
@@ -170,7 +170,7 @@ function MenubarShortcut({
|
|
|
170
170
|
}) {
|
|
171
171
|
return /* @__PURE__ */ jsxDEV("span", {
|
|
172
172
|
"data-slot": "menubar-shortcut",
|
|
173
|
-
className: cn("text-muted-foreground
|
|
173
|
+
className: cn("ml-auto text-muted-foreground text-xs tracking-widest", className),
|
|
174
174
|
...props
|
|
175
175
|
}, undefined, false, undefined, this);
|
|
176
176
|
}
|
|
@@ -191,7 +191,7 @@ function MenubarSubTrigger({
|
|
|
191
191
|
return /* @__PURE__ */ jsxDEV(MenubarPrimitive.SubTrigger, {
|
|
192
192
|
"data-slot": "menubar-sub-trigger",
|
|
193
193
|
"data-inset": inset,
|
|
194
|
-
className: cn("
|
|
194
|
+
className: cn("flex cursor-default select-none items-center rounded-xs px-2 py-1.5 text-sm outline-hidden focus:bg-accent focus:text-accent-foreground data-[state=open]:bg-accent data-inset:pl-8 data-[state=open]:text-accent-foreground", className),
|
|
195
195
|
...props,
|
|
196
196
|
children: [
|
|
197
197
|
children,
|
|
@@ -207,7 +207,7 @@ function MenubarSubContent({
|
|
|
207
207
|
}) {
|
|
208
208
|
return /* @__PURE__ */ jsxDEV(MenubarPrimitive.SubContent, {
|
|
209
209
|
"data-slot": "menubar-sub-content",
|
|
210
|
-
className: cn("
|
|
210
|
+
className: cn("data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-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 z-50 min-w-32 origin-(--radix-menubar-content-transform-origin) overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg data-[state=closed]:animate-out data-[state=open]:animate-in", className),
|
|
211
211
|
...props
|
|
212
212
|
}, undefined, false, undefined, this);
|
|
213
213
|
}
|
|
@@ -7,23 +7,23 @@ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require
|
|
|
7
7
|
});
|
|
8
8
|
|
|
9
9
|
// ui/button.tsx
|
|
10
|
+
import { cn } from "@contractspec/lib.ui-kit-core/utils";
|
|
10
11
|
import { Slot } from "@radix-ui/react-slot";
|
|
11
12
|
import { cva } from "class-variance-authority";
|
|
12
|
-
import { cn } from "@contractspec/lib.ui-kit-core/utils";
|
|
13
13
|
import { jsxDEV } from "react/jsx-dev-runtime";
|
|
14
|
-
var buttonVariants = cva("inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm
|
|
14
|
+
var buttonVariants = cva("inline-flex shrink-0 items-center justify-center gap-2 whitespace-nowrap rounded-md font-medium text-sm outline-hidden transition-all focus-visible:border-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50 aria-invalid:border-destructive aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 [&_svg:not([class*='size-'])]:size-4 [&_svg]:pointer-events-none [&_svg]:shrink-0", {
|
|
15
15
|
variants: {
|
|
16
16
|
variant: {
|
|
17
17
|
default: "bg-primary text-primary-foreground hover:bg-primary/90",
|
|
18
|
-
destructive: "bg-destructive text-white hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40
|
|
19
|
-
outline: "border bg-background shadow-2xs hover:bg-accent hover:text-accent-foreground dark:
|
|
18
|
+
destructive: "bg-destructive text-white hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:bg-destructive/60 dark:focus-visible:ring-destructive/40",
|
|
19
|
+
outline: "border bg-background shadow-2xs hover:bg-accent hover:text-accent-foreground dark:border-input dark:bg-input/30 dark:hover:bg-input/50",
|
|
20
20
|
secondary: "bg-secondary text-secondary-foreground hover:bg-secondary/80",
|
|
21
21
|
ghost: "hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50",
|
|
22
22
|
link: "text-primary underline-offset-4 hover:underline"
|
|
23
23
|
},
|
|
24
24
|
size: {
|
|
25
25
|
default: "h-9 px-4 py-2 has-[>svg]:px-3",
|
|
26
|
-
sm: "h-8
|
|
26
|
+
sm: "h-8 gap-1.5 rounded-md px-3 has-[>svg]:px-2.5",
|
|
27
27
|
lg: "h-10 rounded-md px-6 has-[>svg]:px-4",
|
|
28
28
|
icon: "size-9"
|
|
29
29
|
}
|
|
@@ -56,9 +56,9 @@ function Button({
|
|
|
56
56
|
}, undefined, false, undefined, this);
|
|
57
57
|
}
|
|
58
58
|
// ui/dialog.tsx
|
|
59
|
+
import { cn as cn2 } from "@contractspec/lib.ui-kit-core/utils";
|
|
59
60
|
import * as DialogPrimitive from "@radix-ui/react-dialog";
|
|
60
61
|
import { XIcon } from "lucide-react";
|
|
61
|
-
import { cn as cn2 } from "@contractspec/lib.ui-kit-core/utils";
|
|
62
62
|
import { jsxDEV as jsxDEV2 } from "react/jsx-dev-runtime";
|
|
63
63
|
"use client";
|
|
64
64
|
function Dialog({
|
|
@@ -99,7 +99,7 @@ function DialogOverlay({
|
|
|
99
99
|
}) {
|
|
100
100
|
return /* @__PURE__ */ jsxDEV2(DialogPrimitive.Overlay, {
|
|
101
101
|
"data-slot": "dialog-overlay",
|
|
102
|
-
className: cn2("data-[state=
|
|
102
|
+
className: cn2("data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 fixed inset-0 z-50 bg-black/50 data-[state=closed]:animate-out data-[state=open]:animate-in", className),
|
|
103
103
|
...props
|
|
104
104
|
}, undefined, false, undefined, this);
|
|
105
105
|
}
|
|
@@ -115,13 +115,13 @@ function DialogContent({
|
|
|
115
115
|
/* @__PURE__ */ jsxDEV2(DialogOverlay, {}, undefined, false, undefined, this),
|
|
116
116
|
/* @__PURE__ */ jsxDEV2(DialogPrimitive.Content, {
|
|
117
117
|
"data-slot": "dialog-content",
|
|
118
|
-
className: cn2("
|
|
118
|
+
className: cn2("data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 fixed top-[50%] left-[50%] z-50 grid w-full max-w-[calc(100%-2rem)] translate-x-[-50%] translate-y-[-50%] gap-4 rounded-lg border bg-background p-6 shadow-lg duration-200 data-[state=closed]:animate-out data-[state=open]:animate-in sm:max-w-lg", className),
|
|
119
119
|
...props,
|
|
120
120
|
children: [
|
|
121
121
|
children,
|
|
122
122
|
showCloseButton && /* @__PURE__ */ jsxDEV2(DialogPrimitive.Close, {
|
|
123
123
|
"data-slot": "dialog-close",
|
|
124
|
-
className: "
|
|
124
|
+
className: "absolute top-4 right-4 rounded-xs opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-hidden focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground [&_svg:not([class*='size-'])]:size-4 [&_svg]:pointer-events-none [&_svg]:shrink-0",
|
|
125
125
|
children: [
|
|
126
126
|
/* @__PURE__ */ jsxDEV2(XIcon, {}, undefined, false, undefined, this),
|
|
127
127
|
/* @__PURE__ */ jsxDEV2("span", {
|
|
@@ -161,7 +161,7 @@ function DialogTitle({
|
|
|
161
161
|
}) {
|
|
162
162
|
return /* @__PURE__ */ jsxDEV2(DialogPrimitive.Title, {
|
|
163
163
|
"data-slot": "dialog-title",
|
|
164
|
-
className: cn2("text-lg leading-none
|
|
164
|
+
className: cn2("font-semibold text-lg leading-none", className),
|
|
165
165
|
...props
|
|
166
166
|
}, undefined, false, undefined, this);
|
|
167
167
|
}
|
|
@@ -176,9 +176,9 @@ function DialogDescription({
|
|
|
176
176
|
}, undefined, false, undefined, this);
|
|
177
177
|
}
|
|
178
178
|
// ui/command.tsx
|
|
179
|
+
import { cn as cn3 } from "@contractspec/lib.ui-kit-core/utils";
|
|
179
180
|
import { Command as CommandPrimitive } from "cmdk";
|
|
180
181
|
import { SearchIcon } from "lucide-react";
|
|
181
|
-
import { cn as cn3 } from "@contractspec/lib.ui-kit-core/utils";
|
|
182
182
|
import { jsxDEV as jsxDEV3 } from "react/jsx-dev-runtime";
|
|
183
183
|
"use client";
|
|
184
184
|
function Command({
|
|
@@ -187,7 +187,7 @@ function Command({
|
|
|
187
187
|
}) {
|
|
188
188
|
return /* @__PURE__ */ jsxDEV3(CommandPrimitive, {
|
|
189
189
|
"data-slot": "command",
|
|
190
|
-
className: cn3("
|
|
190
|
+
className: cn3("flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground", className),
|
|
191
191
|
...props
|
|
192
192
|
}, undefined, false, undefined, this);
|
|
193
193
|
}
|
|
@@ -217,7 +217,7 @@ function CommandDialog({
|
|
|
217
217
|
className: cn3("overflow-hidden p-0", className),
|
|
218
218
|
showCloseButton,
|
|
219
219
|
children: /* @__PURE__ */ jsxDEV3(Command, {
|
|
220
|
-
className: "
|
|
220
|
+
className: "**:data-[slot=command-input-wrapper]:h-12 [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-group]]:px-2 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5",
|
|
221
221
|
children
|
|
222
222
|
}, undefined, false, undefined, this)
|
|
223
223
|
}, undefined, false, undefined, this)
|
|
@@ -237,7 +237,7 @@ function CommandInput({
|
|
|
237
237
|
}, undefined, false, undefined, this),
|
|
238
238
|
/* @__PURE__ */ jsxDEV3(CommandPrimitive.Input, {
|
|
239
239
|
"data-slot": "command-input",
|
|
240
|
-
className: cn3("
|
|
240
|
+
className: cn3("flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-hidden placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50", className),
|
|
241
241
|
...props
|
|
242
242
|
}, undefined, false, undefined, this)
|
|
243
243
|
]
|
|
@@ -249,7 +249,7 @@ function CommandList({
|
|
|
249
249
|
}) {
|
|
250
250
|
return /* @__PURE__ */ jsxDEV3(CommandPrimitive.List, {
|
|
251
251
|
"data-slot": "command-list",
|
|
252
|
-
className: cn3("max-h-[300px] scroll-py-1 overflow-
|
|
252
|
+
className: cn3("max-h-[300px] scroll-py-1 overflow-y-auto overflow-x-hidden", className),
|
|
253
253
|
...props
|
|
254
254
|
}, undefined, false, undefined, this);
|
|
255
255
|
}
|
|
@@ -268,7 +268,7 @@ function CommandGroup({
|
|
|
268
268
|
}) {
|
|
269
269
|
return /* @__PURE__ */ jsxDEV3(CommandPrimitive.Group, {
|
|
270
270
|
"data-slot": "command-group",
|
|
271
|
-
className: cn3("text-foreground [&_[cmdk-group-heading]]:
|
|
271
|
+
className: cn3("overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group-heading]]:text-xs", className),
|
|
272
272
|
...props
|
|
273
273
|
}, undefined, false, undefined, this);
|
|
274
274
|
}
|
|
@@ -278,7 +278,7 @@ function CommandSeparator({
|
|
|
278
278
|
}) {
|
|
279
279
|
return /* @__PURE__ */ jsxDEV3(CommandPrimitive.Separator, {
|
|
280
280
|
"data-slot": "command-separator",
|
|
281
|
-
className: cn3("
|
|
281
|
+
className: cn3("-mx-1 h-px bg-border", className),
|
|
282
282
|
...props
|
|
283
283
|
}, undefined, false, undefined, this);
|
|
284
284
|
}
|
|
@@ -288,7 +288,7 @@ function CommandItem({
|
|
|
288
288
|
}) {
|
|
289
289
|
return /* @__PURE__ */ jsxDEV3(CommandPrimitive.Item, {
|
|
290
290
|
"data-slot": "command-item",
|
|
291
|
-
className: cn3("
|
|
291
|
+
className: cn3("relative flex cursor-default select-none items-center gap-2 rounded-xs px-2 py-1.5 text-sm outline-hidden data-[disabled=true]:pointer-events-none data-[selected=true]:bg-accent data-[selected=true]:text-accent-foreground data-[disabled=true]:opacity-50 [&_svg:not([class*='size-'])]:size-4 [&_svg:not([class*='text-'])]:text-muted-foreground [&_svg]:pointer-events-none [&_svg]:shrink-0", className),
|
|
292
292
|
...props
|
|
293
293
|
}, undefined, false, undefined, this);
|
|
294
294
|
}
|
|
@@ -298,13 +298,13 @@ function CommandShortcut({
|
|
|
298
298
|
}) {
|
|
299
299
|
return /* @__PURE__ */ jsxDEV3("span", {
|
|
300
300
|
"data-slot": "command-shortcut",
|
|
301
|
-
className: cn3("text-muted-foreground
|
|
301
|
+
className: cn3("ml-auto text-muted-foreground text-xs tracking-widest", className),
|
|
302
302
|
...props
|
|
303
303
|
}, undefined, false, undefined, this);
|
|
304
304
|
}
|
|
305
305
|
// ui/popover.tsx
|
|
306
|
-
import * as PopoverPrimitive from "@radix-ui/react-popover";
|
|
307
306
|
import { cn as cn4 } from "@contractspec/lib.ui-kit-core/utils";
|
|
307
|
+
import * as PopoverPrimitive from "@radix-ui/react-popover";
|
|
308
308
|
import { jsxDEV as jsxDEV4 } from "react/jsx-dev-runtime";
|
|
309
309
|
"use client";
|
|
310
310
|
function Popover({
|
|
@@ -334,7 +334,7 @@ function PopoverContent({
|
|
|
334
334
|
"data-slot": "popover-content",
|
|
335
335
|
align,
|
|
336
336
|
sideOffset,
|
|
337
|
-
className: cn4("
|
|
337
|
+
className: cn4("data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-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 z-50 w-72 origin-(--radix-popover-content-transform-origin) rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-hidden data-[state=closed]:animate-out data-[state=open]:animate-in", className),
|
|
338
338
|
...props
|
|
339
339
|
}, undefined, false, undefined, this)
|
|
340
340
|
}, undefined, false, undefined, this);
|
|
@@ -348,8 +348,8 @@ function PopoverAnchor({
|
|
|
348
348
|
}, undefined, false, undefined, this);
|
|
349
349
|
}
|
|
350
350
|
// ui/drawer.tsx
|
|
351
|
-
import { Drawer as DrawerPrimitive } from "vaul";
|
|
352
351
|
import { cn as cn5 } from "@contractspec/lib.ui-kit-core/utils";
|
|
352
|
+
import { Drawer as DrawerPrimitive } from "vaul";
|
|
353
353
|
import { jsxDEV as jsxDEV5 } from "react/jsx-dev-runtime";
|
|
354
354
|
"use client";
|
|
355
355
|
function Drawer({
|
|
@@ -390,7 +390,7 @@ function DrawerOverlay({
|
|
|
390
390
|
}) {
|
|
391
391
|
return /* @__PURE__ */ jsxDEV5(DrawerPrimitive.Overlay, {
|
|
392
392
|
"data-slot": "drawer-overlay",
|
|
393
|
-
className: cn5("data-[state=
|
|
393
|
+
className: cn5("data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 fixed inset-0 z-50 bg-black/50 data-[state=closed]:animate-out data-[state=open]:animate-in", className),
|
|
394
394
|
...props
|
|
395
395
|
}, undefined, false, undefined, this);
|
|
396
396
|
}
|
|
@@ -405,11 +405,11 @@ function DrawerContent({
|
|
|
405
405
|
/* @__PURE__ */ jsxDEV5(DrawerOverlay, {}, undefined, false, undefined, this),
|
|
406
406
|
/* @__PURE__ */ jsxDEV5(DrawerPrimitive.Content, {
|
|
407
407
|
"data-slot": "drawer-content",
|
|
408
|
-
className: cn5("group/drawer-content
|
|
408
|
+
className: cn5("group/drawer-content fixed z-50 flex h-auto flex-col bg-background", "data-[vaul-drawer-direction=top]:inset-x-0 data-[vaul-drawer-direction=top]:top-0 data-[vaul-drawer-direction=top]:mb-24 data-[vaul-drawer-direction=top]:max-h-[80vh] data-[vaul-drawer-direction=top]:rounded-b-lg data-[vaul-drawer-direction=top]:border-b", "data-[vaul-drawer-direction=bottom]:inset-x-0 data-[vaul-drawer-direction=bottom]:bottom-0 data-[vaul-drawer-direction=bottom]:mt-24 data-[vaul-drawer-direction=bottom]:max-h-[80vh] data-[vaul-drawer-direction=bottom]:rounded-t-lg data-[vaul-drawer-direction=bottom]:border-t", "data-[vaul-drawer-direction=right]:inset-y-0 data-[vaul-drawer-direction=right]:right-0 data-[vaul-drawer-direction=right]:w-3/4 data-[vaul-drawer-direction=right]:border-l sm:data-[vaul-drawer-direction=right]:max-w-sm", "data-[vaul-drawer-direction=left]:inset-y-0 data-[vaul-drawer-direction=left]:left-0 data-[vaul-drawer-direction=left]:w-3/4 data-[vaul-drawer-direction=left]:border-r sm:data-[vaul-drawer-direction=left]:max-w-sm", className),
|
|
409
409
|
...props,
|
|
410
410
|
children: [
|
|
411
411
|
/* @__PURE__ */ jsxDEV5("div", {
|
|
412
|
-
className: "
|
|
412
|
+
className: "mx-auto mt-4 hidden h-2 w-[100px] shrink-0 rounded-full bg-muted group-data-[vaul-drawer-direction=bottom]/drawer-content:block"
|
|
413
413
|
}, undefined, false, undefined, this),
|
|
414
414
|
children
|
|
415
415
|
]
|
|
@@ -443,7 +443,7 @@ function DrawerTitle({
|
|
|
443
443
|
}) {
|
|
444
444
|
return /* @__PURE__ */ jsxDEV5(DrawerPrimitive.Title, {
|
|
445
445
|
"data-slot": "drawer-title",
|
|
446
|
-
className: cn5("text-foreground
|
|
446
|
+
className: cn5("font-semibold text-foreground", className),
|
|
447
447
|
...props
|
|
448
448
|
}, undefined, false, undefined, this);
|
|
449
449
|
}
|