@kuzenbo/core 0.0.3 → 0.0.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/dist/avatar-CXhwmJgG.js +65 -0
- package/dist/avatar-CXhwmJgG.js.map +1 -0
- package/dist/{avatar-image-Ce26D2fb.d.ts → avatar-DpiupAAM.d.ts} +35 -2
- package/dist/avatar-DpiupAAM.d.ts.map +1 -0
- package/dist/badge-BKRm6jL7.js +58 -0
- package/dist/badge-BKRm6jL7.js.map +1 -0
- package/dist/button-nAbTNrxA.d.ts +78 -0
- package/dist/button-nAbTNrxA.d.ts.map +1 -0
- package/dist/{dialog-trigger-BUF3elAP.js → dialog-CD5lfQA9.js} +33 -10
- package/dist/dialog-CD5lfQA9.js.map +1 -0
- package/dist/{dialog-viewport-Ce1huyAI.d.ts → dialog-DEkdr-9K.d.ts} +64 -2
- package/dist/dialog-DEkdr-9K.d.ts.map +1 -0
- package/dist/{dropdown-menu-trigger-COnFGfDa.js → dropdown-menu-BJi-V71O.js} +137 -101
- package/dist/dropdown-menu-BJi-V71O.js.map +1 -0
- package/dist/{dropdown-menu-trigger-BpgtLUvf.d.ts → dropdown-menu-Bpj576m0.d.ts} +259 -123
- package/dist/dropdown-menu-Bpj576m0.d.ts.map +1 -0
- package/dist/input-Ex9ZRqbo.js +38 -0
- package/dist/input-Ex9ZRqbo.js.map +1 -0
- package/dist/input-WWoBCgxe.d.ts +46 -0
- package/dist/input-WWoBCgxe.d.ts.map +1 -0
- package/dist/{input-group-textarea-B-rP98r5.js → input-group-CjcHP0L4.js} +50 -31
- package/dist/input-group-CjcHP0L4.js.map +1 -0
- package/dist/provider.js +4 -2
- package/dist/scroll-bar-C4qEUKlT.js.map +1 -1
- package/dist/separator-C8Qw2ADs.d.ts +13 -0
- package/dist/separator-C8Qw2ADs.d.ts.map +1 -0
- package/dist/{sheet-trigger-D7neoTF5.js → sheet-imSHXfFH.js} +29 -10
- package/dist/sheet-imSHXfFH.js.map +1 -0
- package/dist/{size-context-BjRwqlSg.js → size-context-CvLl3pMC.js} +3 -3
- package/dist/size-context-CvLl3pMC.js.map +1 -0
- package/dist/size-context-DXfCAlWF.d.ts.map +1 -1
- package/dist/size-provider-18EvJgDT.js.map +1 -1
- package/dist/size-provider-Bd2C6gKd.d.ts.map +1 -1
- package/dist/size-system-BTsMqZRQ.js +99 -0
- package/dist/size-system-BTsMqZRQ.js.map +1 -0
- package/dist/size-system-wzOLSuax.d.ts.map +1 -1
- package/dist/size.js +4 -2
- package/dist/{slider-root-presentation-ChJHPMIV.js → slider-root-presentation-B6OO_iCT.js} +19 -19
- package/dist/slider-root-presentation-B6OO_iCT.js.map +1 -0
- package/dist/{slider-value-Db8SCu0c.d.ts → slider-style-tokens-CZezJilZ.d.ts} +55 -55
- package/dist/slider-style-tokens-CZezJilZ.d.ts.map +1 -0
- package/dist/textarea-C8dsnn8D.d.ts +37 -0
- package/dist/textarea-C8dsnn8D.d.ts.map +1 -0
- package/dist/textarea-CkiM1N_I.js +39 -0
- package/dist/textarea-CkiM1N_I.js.map +1 -0
- package/dist/toggle-CxkIncmZ.d.ts +53 -0
- package/dist/toggle-CxkIncmZ.d.ts.map +1 -0
- package/dist/{tooltip-trigger-qXw-_nbh.js → tooltip-D0BEpCQx.js} +38 -13
- package/dist/tooltip-D0BEpCQx.js.map +1 -0
- package/dist/{tooltip-viewport-csA6luqI.d.ts → tooltip-DbJxt69l.d.ts} +61 -13
- package/dist/tooltip-DbJxt69l.d.ts.map +1 -0
- package/dist/ui/accordion.d.ts +4 -4
- package/dist/ui/accordion.d.ts.map +1 -1
- package/dist/ui/accordion.js +53 -52
- package/dist/ui/accordion.js.map +1 -1
- package/dist/ui/affix.d.ts +3 -2
- package/dist/ui/affix.d.ts.map +1 -1
- package/dist/ui/affix.js +8 -7
- package/dist/ui/affix.js.map +1 -1
- package/dist/ui/alert-dialog.d.ts +3 -1
- package/dist/ui/alert-dialog.d.ts.map +1 -1
- package/dist/ui/alert-dialog.js +12 -9
- package/dist/ui/alert-dialog.js.map +1 -1
- package/dist/ui/alert.d.ts +32 -32
- package/dist/ui/alert.d.ts.map +1 -1
- package/dist/ui/alert.js +88 -86
- package/dist/ui/alert.js.map +1 -1
- package/dist/ui/announcement.d.ts.map +1 -1
- package/dist/ui/announcement.js +5 -3
- package/dist/ui/announcement.js.map +1 -1
- package/dist/ui/aspect-ratio.d.ts.map +1 -1
- package/dist/ui/aspect-ratio.js.map +1 -1
- package/dist/ui/autocomplete.d.ts +74 -74
- package/dist/ui/autocomplete.d.ts.map +1 -1
- package/dist/ui/autocomplete.js +57 -53
- package/dist/ui/autocomplete.js.map +1 -1
- package/dist/ui/avatar.d.ts +2 -39
- package/dist/ui/avatar.js +2 -24
- package/dist/ui/badge.d.ts +28 -28
- package/dist/ui/badge.d.ts.map +1 -1
- package/dist/ui/badge.js +3 -53
- package/dist/ui/breadcrumb.d.ts +64 -64
- package/dist/ui/breadcrumb.d.ts.map +1 -1
- package/dist/ui/breadcrumb.js +49 -45
- package/dist/ui/breadcrumb.js.map +1 -1
- package/dist/ui/button-group.d.ts +34 -34
- package/dist/ui/button-group.d.ts.map +1 -1
- package/dist/ui/button-group.js +31 -28
- package/dist/ui/button-group.js.map +1 -1
- package/dist/ui/button.d.ts +2 -78
- package/dist/ui/button.js +42 -42
- package/dist/ui/button.js.map +1 -1
- package/dist/ui/card.d.ts.map +1 -1
- package/dist/ui/card.js +8 -6
- package/dist/ui/card.js.map +1 -1
- package/dist/ui/carousel.d.ts +1 -1
- package/dist/ui/carousel.d.ts.map +1 -1
- package/dist/ui/carousel.js +36 -17
- package/dist/ui/carousel.js.map +1 -1
- package/dist/ui/checkbox-group.d.ts.map +1 -1
- package/dist/ui/checkbox-group.js +2 -0
- package/dist/ui/checkbox-group.js.map +1 -1
- package/dist/ui/checkbox.d.ts +20 -20
- package/dist/ui/checkbox.d.ts.map +1 -1
- package/dist/ui/checkbox.js +15 -13
- package/dist/ui/checkbox.js.map +1 -1
- package/dist/ui/code.d.ts.map +1 -1
- package/dist/ui/code.js +5 -5
- package/dist/ui/code.js.map +1 -1
- package/dist/ui/collapsible.js +1 -1
- package/dist/ui/collapsible.js.map +1 -1
- package/dist/ui/combobox.d.ts +107 -107
- package/dist/ui/combobox.d.ts.map +1 -1
- package/dist/ui/combobox.js +88 -87
- package/dist/ui/combobox.js.map +1 -1
- package/dist/ui/command.d.ts +57 -58
- package/dist/ui/command.d.ts.map +1 -1
- package/dist/ui/command.js +54 -64
- package/dist/ui/command.js.map +1 -1
- package/dist/ui/container.d.ts.map +1 -1
- package/dist/ui/container.js.map +1 -1
- package/dist/ui/context-menu.d.ts +132 -132
- package/dist/ui/context-menu.d.ts.map +1 -1
- package/dist/ui/context-menu.js +102 -98
- package/dist/ui/context-menu.js.map +1 -1
- package/dist/ui/copy-button.d.ts +1 -3
- package/dist/ui/copy-button.d.ts.map +1 -1
- package/dist/ui/copy-button.js +12 -13
- package/dist/ui/copy-button.js.map +1 -1
- package/dist/ui/dialog.d.ts +2 -66
- package/dist/ui/dialog.js +2 -24
- package/dist/ui/drawer.d.ts +91 -91
- package/dist/ui/drawer.d.ts.map +1 -1
- package/dist/ui/drawer.js +68 -66
- package/dist/ui/drawer.js.map +1 -1
- package/dist/ui/dropdown-menu.d.ts +3 -144
- package/dist/ui/dropdown-menu.js +3 -38
- package/dist/ui/dropzone.d.ts +55 -55
- package/dist/ui/dropzone.d.ts.map +1 -1
- package/dist/ui/dropzone.js +77 -72
- package/dist/ui/dropzone.js.map +1 -1
- package/dist/ui/emoji-picker.d.ts +79 -79
- package/dist/ui/emoji-picker.d.ts.map +1 -1
- package/dist/ui/emoji-picker.js +92 -87
- package/dist/ui/emoji-picker.js.map +1 -1
- package/dist/ui/empty.d.ts +61 -59
- package/dist/ui/empty.d.ts.map +1 -1
- package/dist/ui/empty.js +49 -44
- package/dist/ui/empty.js.map +1 -1
- package/dist/ui/field.d.ts +11 -11
- package/dist/ui/field.d.ts.map +1 -1
- package/dist/ui/field.js +9 -7
- package/dist/ui/field.js.map +1 -1
- package/dist/ui/fieldset.d.ts.map +1 -1
- package/dist/ui/fieldset.js.map +1 -1
- package/dist/ui/form.d.ts +8 -8
- package/dist/ui/form.d.ts.map +1 -1
- package/dist/ui/form.js +2 -0
- package/dist/ui/form.js.map +1 -1
- package/dist/ui/input-group.d.ts +35 -35
- package/dist/ui/input-group.d.ts.map +1 -1
- package/dist/ui/input-group.js +2 -28
- package/dist/ui/input-otp.d.ts +36 -36
- package/dist/ui/input-otp.d.ts.map +1 -1
- package/dist/ui/input-otp.js +29 -28
- package/dist/ui/input-otp.js.map +1 -1
- package/dist/ui/input.d.ts +2 -46
- package/dist/ui/input.js +2 -34
- package/dist/ui/item.d.ts +20 -20
- package/dist/ui/item.d.ts.map +1 -1
- package/dist/ui/item.js +24 -22
- package/dist/ui/item.js.map +1 -1
- package/dist/ui/kbd.d.ts.map +1 -1
- package/dist/ui/kbd.js +10 -8
- package/dist/ui/kbd.js.map +1 -1
- package/dist/ui/label.d.ts.map +1 -1
- package/dist/ui/label.js.map +1 -1
- package/dist/ui/marquee.d.ts.map +1 -1
- package/dist/ui/marquee.js +1 -1
- package/dist/ui/marquee.js.map +1 -1
- package/dist/ui/menubar.d.ts +133 -134
- package/dist/ui/menubar.d.ts.map +1 -1
- package/dist/ui/menubar.js +84 -81
- package/dist/ui/menubar.js.map +1 -1
- package/dist/ui/meter.d.ts.map +1 -1
- package/dist/ui/meter.js +2 -0
- package/dist/ui/meter.js.map +1 -1
- package/dist/ui/navigation-list.d.ts +226 -226
- package/dist/ui/navigation-list.d.ts.map +1 -1
- package/dist/ui/navigation-list.js +242 -235
- package/dist/ui/navigation-list.js.map +1 -1
- package/dist/ui/navigation-menu.d.ts +82 -82
- package/dist/ui/navigation-menu.d.ts.map +1 -1
- package/dist/ui/navigation-menu.js +72 -67
- package/dist/ui/navigation-menu.js.map +1 -1
- package/dist/ui/number-field.d.ts +34 -34
- package/dist/ui/number-field.d.ts.map +1 -1
- package/dist/ui/number-field.js +26 -23
- package/dist/ui/number-field.js.map +1 -1
- package/dist/ui/pagination.d.ts +42 -42
- package/dist/ui/pagination.d.ts.map +1 -1
- package/dist/ui/pagination.js +45 -41
- package/dist/ui/pagination.js.map +1 -1
- package/dist/ui/pill.d.ts +2 -3
- package/dist/ui/pill.d.ts.map +1 -1
- package/dist/ui/pill.js +34 -23
- package/dist/ui/pill.js.map +1 -1
- package/dist/ui/popover.d.ts +13 -11
- package/dist/ui/popover.d.ts.map +1 -1
- package/dist/ui/popover.js +17 -14
- package/dist/ui/popover.js.map +1 -1
- package/dist/ui/portal.d.ts.map +1 -1
- package/dist/ui/portal.js +52 -11
- package/dist/ui/portal.js.map +1 -1
- package/dist/ui/preview-card.js +5 -5
- package/dist/ui/preview-card.js.map +1 -1
- package/dist/ui/progress.js.map +1 -1
- package/dist/ui/qr-code.d.ts.map +1 -1
- package/dist/ui/qr-code.js +7 -7
- package/dist/ui/qr-code.js.map +1 -1
- package/dist/ui/radio-group.d.ts +22 -22
- package/dist/ui/radio-group.d.ts.map +1 -1
- package/dist/ui/radio-group.js +17 -15
- package/dist/ui/radio-group.js.map +1 -1
- package/dist/ui/range-slider.d.ts +1 -1
- package/dist/ui/range-slider.d.ts.map +1 -1
- package/dist/ui/range-slider.js +4 -7
- package/dist/ui/range-slider.js.map +1 -1
- package/dist/ui/rating.d.ts +35 -35
- package/dist/ui/rating.d.ts.map +1 -1
- package/dist/ui/rating.js +55 -46
- package/dist/ui/rating.js.map +1 -1
- package/dist/ui/resizable.d.ts.map +1 -1
- package/dist/ui/resizable.js +2 -2
- package/dist/ui/resizable.js.map +1 -1
- package/dist/ui/scroll-area.d.ts.map +1 -1
- package/dist/ui/scroll-area.js +2 -0
- package/dist/ui/scroll-area.js.map +1 -1
- package/dist/ui/select.d.ts +87 -87
- package/dist/ui/select.d.ts.map +1 -1
- package/dist/ui/select.js +85 -84
- package/dist/ui/select.js.map +1 -1
- package/dist/ui/separator.d.ts +2 -13
- package/dist/ui/separator.js +2 -0
- package/dist/ui/separator.js.map +1 -1
- package/dist/ui/sheet.d.ts.map +1 -1
- package/dist/ui/sheet.js +2 -24
- package/dist/ui/sidebar.d.ts +73 -74
- package/dist/ui/sidebar.d.ts.map +1 -1
- package/dist/ui/sidebar.js +87 -84
- package/dist/ui/sidebar.js.map +1 -1
- package/dist/ui/skeleton.d.ts.map +1 -1
- package/dist/ui/skeleton.js +1 -1
- package/dist/ui/skeleton.js.map +1 -1
- package/dist/ui/slider.d.ts +1 -1
- package/dist/ui/slider.d.ts.map +1 -1
- package/dist/ui/slider.js +3 -1
- package/dist/ui/slider.js.map +1 -1
- package/dist/ui/spacer.d.ts.map +1 -1
- package/dist/ui/spacer.js +2 -2
- package/dist/ui/spacer.js.map +1 -1
- package/dist/ui/spinner.js +4 -2
- package/dist/ui/spinner.js.map +1 -1
- package/dist/ui/switch.d.ts +11 -11
- package/dist/ui/switch.js +7 -7
- package/dist/ui/switch.js.map +1 -1
- package/dist/ui/table.d.ts +60 -60
- package/dist/ui/table.d.ts.map +1 -1
- package/dist/ui/table.js +54 -46
- package/dist/ui/table.js.map +1 -1
- package/dist/ui/tabs.d.ts +25 -25
- package/dist/ui/tabs.d.ts.map +1 -1
- package/dist/ui/tabs.js +75 -68
- package/dist/ui/tabs.js.map +1 -1
- package/dist/ui/textarea.d.ts +2 -37
- package/dist/ui/textarea.js +3 -34
- package/dist/ui/theme-icon.d.ts +30 -30
- package/dist/ui/theme-icon.d.ts.map +1 -1
- package/dist/ui/theme-icon.js +22 -22
- package/dist/ui/theme-icon.js.map +1 -1
- package/dist/ui/timeline.d.ts +6 -6
- package/dist/ui/timeline.d.ts.map +1 -1
- package/dist/ui/timeline.js +165 -163
- package/dist/ui/timeline.js.map +1 -1
- package/dist/ui/toggle-group.d.ts +32 -32
- package/dist/ui/toggle-group.d.ts.map +1 -1
- package/dist/ui/toggle-group.js +22 -16
- package/dist/ui/toggle-group.js.map +1 -1
- package/dist/ui/toggle.d.ts +2 -53
- package/dist/ui/toggle.js +17 -15
- package/dist/ui/toggle.js.map +1 -1
- package/dist/ui/toolbar.d.ts +54 -54
- package/dist/ui/toolbar.d.ts.map +1 -1
- package/dist/ui/toolbar.js +45 -40
- package/dist/ui/toolbar.js.map +1 -1
- package/dist/ui/tooltip.d.ts +2 -54
- package/dist/ui/tooltip.js +2 -28
- package/dist/ui/typography.d.ts +50 -36
- package/dist/ui/typography.d.ts.map +1 -1
- package/dist/ui/typography.js +28 -17
- package/dist/ui/typography.js.map +1 -1
- package/package.json +15 -15
- package/dist/avatar-image-BQ_NEKH4.js +0 -47
- package/dist/avatar-image-BQ_NEKH4.js.map +0 -1
- package/dist/avatar-image-Ce26D2fb.d.ts.map +0 -1
- package/dist/dialog-trigger-BUF3elAP.js.map +0 -1
- package/dist/dialog-viewport-Ce1huyAI.d.ts.map +0 -1
- package/dist/dropdown-menu-trigger-BpgtLUvf.d.ts.map +0 -1
- package/dist/dropdown-menu-trigger-COnFGfDa.js.map +0 -1
- package/dist/input-group-textarea-B-rP98r5.js.map +0 -1
- package/dist/sheet-trigger-D7neoTF5.js.map +0 -1
- package/dist/size-context-BjRwqlSg.js.map +0 -1
- package/dist/size-system-DTXmtQXw.js +0 -47
- package/dist/size-system-DTXmtQXw.js.map +0 -1
- package/dist/slider-root-presentation-ChJHPMIV.js.map +0 -1
- package/dist/slider-value-Db8SCu0c.d.ts.map +0 -1
- package/dist/tooltip-trigger-qXw-_nbh.js.map +0 -1
- package/dist/tooltip-viewport-csA6luqI.d.ts.map +0 -1
- package/dist/ui/avatar.d.ts.map +0 -1
- package/dist/ui/avatar.js.map +0 -1
- package/dist/ui/badge.js.map +0 -1
- package/dist/ui/button.d.ts.map +0 -1
- package/dist/ui/dialog.d.ts.map +0 -1
- package/dist/ui/dialog.js.map +0 -1
- package/dist/ui/dropdown-menu.d.ts.map +0 -1
- package/dist/ui/dropdown-menu.js.map +0 -1
- package/dist/ui/input-group.js.map +0 -1
- package/dist/ui/input.d.ts.map +0 -1
- package/dist/ui/input.js.map +0 -1
- package/dist/ui/separator.d.ts.map +0 -1
- package/dist/ui/sheet.js.map +0 -1
- package/dist/ui/textarea.d.ts.map +0 -1
- package/dist/ui/textarea.js.map +0 -1
- package/dist/ui/toggle.d.ts.map +0 -1
- package/dist/ui/tooltip.d.ts.map +0 -1
- package/dist/ui/tooltip.js.map +0 -1
- package/dist/use-badge-default-props-8d9wPL0k.js +0 -8
- package/dist/use-badge-default-props-8d9wPL0k.js.map +0 -1
- package/dist/use-input-default-props-B6VgKXGM.js +0 -8
- package/dist/use-input-default-props-B6VgKXGM.js.map +0 -1
- package/dist/use-textarea-default-props-7MlOxkDO.js +0 -8
- package/dist/use-textarea-default-props-7MlOxkDO.js.map +0 -1
package/dist/ui/context-menu.js
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
1
3
|
import { a as useComponentSize } from "../size-provider-18EvJgDT.js";
|
|
2
4
|
import { t as mergeBaseUIClassName } from "../merge-base-ui-class-name-HKsgjcXj.js";
|
|
3
|
-
import { createContext, useContext } from "react";
|
|
5
|
+
import { createContext, useContext, useMemo } from "react";
|
|
4
6
|
import { jsx, jsxs } from "react/jsx-runtime";
|
|
5
7
|
import { cn, tv } from "tailwind-variants";
|
|
6
8
|
import { ArrowRight01Icon, Tick02Icon } from "@hugeicons/core-free-icons";
|
|
@@ -33,33 +35,33 @@ const ContextMenuOverlayContext = createContext({});
|
|
|
33
35
|
//#endregion
|
|
34
36
|
//#region src/ui/context-menu/context-menu-checkbox-item.tsx
|
|
35
37
|
const contextMenuCheckboxItemVariants = tv({
|
|
38
|
+
defaultVariants: { size: "md" },
|
|
36
39
|
slots: {
|
|
37
40
|
indicator: "pointer-events-none absolute flex items-center justify-center [&_svg]:pointer-events-none [&_svg]:shrink-0",
|
|
38
|
-
root: "relative flex
|
|
41
|
+
root: "cursor-clickable focus:bg-accent focus:text-accent-foreground relative flex items-center rounded-md outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:cursor-not-allowed data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0"
|
|
39
42
|
},
|
|
40
43
|
variants: { size: {
|
|
41
|
-
|
|
42
|
-
indicator: "right-
|
|
43
|
-
root: "gap-
|
|
44
|
-
},
|
|
45
|
-
sm: {
|
|
46
|
-
indicator: "right-2 size-3.5 [&_svg:not([class*='size-'])]:size-3.5",
|
|
47
|
-
root: "gap-1.5 rounded-[min(var(--radius-md),10px)] py-1 pr-7 pl-2 text-sm [&_svg:not([class*='size-'])]:size-3.5"
|
|
44
|
+
lg: {
|
|
45
|
+
indicator: "right-2.5 size-4 [&_svg:not([class*='size-'])]:size-4",
|
|
46
|
+
root: "gap-2 py-1.5 pr-9 pl-2 text-sm [&_svg:not([class*='size-'])]:size-4"
|
|
48
47
|
},
|
|
49
48
|
md: {
|
|
50
49
|
indicator: "right-2 size-4 [&_svg:not([class*='size-'])]:size-4",
|
|
51
50
|
root: "gap-1.5 py-1 pr-8 pl-1.5 text-sm [&_svg:not([class*='size-'])]:size-4"
|
|
52
51
|
},
|
|
53
|
-
|
|
54
|
-
indicator: "right-2
|
|
55
|
-
root: "gap-
|
|
52
|
+
sm: {
|
|
53
|
+
indicator: "right-2 size-3.5 [&_svg:not([class*='size-'])]:size-3.5",
|
|
54
|
+
root: "gap-1.5 rounded-[min(var(--radius-md),10px)] py-1 pr-7 pl-2 text-sm [&_svg:not([class*='size-'])]:size-3.5"
|
|
56
55
|
},
|
|
57
56
|
xl: {
|
|
58
57
|
indicator: "right-3 size-5 [&_svg:not([class*='size-'])]:size-5",
|
|
59
58
|
root: "gap-2.5 py-2 pr-10 pl-2.5 text-base [&_svg:not([class*='size-'])]:size-5"
|
|
59
|
+
},
|
|
60
|
+
xs: {
|
|
61
|
+
indicator: "right-1.5 size-3 [&_svg:not([class*='size-'])]:size-3",
|
|
62
|
+
root: "gap-1 rounded-[min(var(--radius-md),8px)] py-1 pr-6 pl-1.5 text-xs [&_svg:not([class*='size-'])]:size-3"
|
|
60
63
|
}
|
|
61
|
-
} }
|
|
62
|
-
defaultVariants: { size: "md" }
|
|
64
|
+
} }
|
|
63
65
|
});
|
|
64
66
|
const ContextMenuCheckboxItem = ({ className, children, checked, size, ...props }) => {
|
|
65
67
|
const { size: rootSize } = useContext(ContextMenuContext);
|
|
@@ -85,15 +87,15 @@ const ContextMenuCheckboxItem = ({ className, children, checked, size, ...props
|
|
|
85
87
|
//#endregion
|
|
86
88
|
//#region src/ui/context-menu/context-menu-popup.tsx
|
|
87
89
|
const contextMenuPopupVariants = tv({
|
|
88
|
-
base: "z-
|
|
90
|
+
base: "z-overlay bg-popover text-popover-foreground ring-foreground/10 data-closed:animate-out data-closed:fade-out-0 data-closed:zoom-out-95 data-open:animate-in data-open:fade-in-0 data-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 max-h-(--available-height) origin-(--transform-origin) overflow-x-hidden overflow-y-auto shadow-md ring-1 duration-100 outline-none",
|
|
91
|
+
defaultVariants: { size: "md" },
|
|
89
92
|
variants: { size: {
|
|
90
|
-
xs: "min-w-28 rounded-[min(var(--radius-md),8px)] p-0.5",
|
|
91
|
-
sm: "min-w-32 rounded-[min(var(--radius-md),10px)] p-0.5",
|
|
92
|
-
md: "min-w-36 rounded-md p-1",
|
|
93
93
|
lg: "min-w-40 rounded-md p-1.5",
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
94
|
+
md: "min-w-36 rounded-md p-1",
|
|
95
|
+
sm: "min-w-32 rounded-[min(var(--radius-md),10px)] p-0.5",
|
|
96
|
+
xl: "min-w-44 rounded-md p-2",
|
|
97
|
+
xs: "min-w-28 rounded-[min(var(--radius-md),8px)] p-0.5"
|
|
98
|
+
} }
|
|
97
99
|
});
|
|
98
100
|
const ContextMenuPopup = ({ className, size, ...props }) => {
|
|
99
101
|
const { size: rootSize } = useContext(ContextMenuContext);
|
|
@@ -117,7 +119,7 @@ const ContextMenuPortal = ({ ...props }) => /* @__PURE__ */ jsx(ContextMenu$1.Po
|
|
|
117
119
|
//#endregion
|
|
118
120
|
//#region src/ui/context-menu/context-menu-positioner.tsx
|
|
119
121
|
const ContextMenuPositioner = ({ className, ...props }) => /* @__PURE__ */ jsx(ContextMenu$1.Positioner, {
|
|
120
|
-
className: cn("
|
|
122
|
+
className: cn("z-overlay isolate outline-none", className),
|
|
121
123
|
"data-slot": "context-menu-positioner",
|
|
122
124
|
...props
|
|
123
125
|
});
|
|
@@ -127,8 +129,9 @@ const ContextMenuPositioner = ({ className, ...props }) => /* @__PURE__ */ jsx(C
|
|
|
127
129
|
const ContextMenuContent = ({ className, align = "start", alignOffset = 4, side = "right", sideOffset = 0, size, ...props }) => {
|
|
128
130
|
const { size: rootSize } = useContext(ContextMenuContext);
|
|
129
131
|
const resolvedSize = size ?? rootSize ?? "md";
|
|
132
|
+
const contextValue = useMemo(() => ({ size: resolvedSize }), [resolvedSize]);
|
|
130
133
|
return /* @__PURE__ */ jsx(ContextMenuOverlayContext.Provider, {
|
|
131
|
-
value:
|
|
134
|
+
value: contextValue,
|
|
132
135
|
children: /* @__PURE__ */ jsx(ContextMenuPortal, { children: /* @__PURE__ */ jsx(ContextMenuPositioner, {
|
|
133
136
|
align,
|
|
134
137
|
alignOffset,
|
|
@@ -155,28 +158,28 @@ const ContextMenuGroup = ({ ...props }) => /* @__PURE__ */ jsx(ContextMenu$1.Gro
|
|
|
155
158
|
//#endregion
|
|
156
159
|
//#region src/ui/context-menu/context-menu-item.tsx
|
|
157
160
|
const contextMenuItemVariants = tv({
|
|
158
|
-
base: "group/context-menu-item
|
|
161
|
+
base: "group/context-menu-item cursor-clickable focus:bg-accent focus:text-accent-foreground relative flex items-center outline-hidden select-none data-disabled:pointer-events-none data-disabled:cursor-not-allowed data-disabled:opacity-50 data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0",
|
|
162
|
+
defaultVariants: {
|
|
163
|
+
inset: false,
|
|
164
|
+
size: "md",
|
|
165
|
+
variant: "default"
|
|
166
|
+
},
|
|
159
167
|
variants: {
|
|
160
168
|
inset: {
|
|
161
169
|
false: "",
|
|
162
170
|
true: ""
|
|
163
171
|
},
|
|
164
172
|
size: {
|
|
165
|
-
xs: "gap-1 rounded-[min(var(--radius-md),8px)] px-1.5 py-1 text-xs [&_svg:not([class*='size-'])]:size-3",
|
|
166
|
-
sm: "gap-1.5 rounded-[min(var(--radius-md),10px)] px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-3.5",
|
|
167
|
-
md: "gap-1.5 rounded-md px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-4",
|
|
168
173
|
lg: "gap-2 rounded-md px-2 py-1.5 text-sm [&_svg:not([class*='size-'])]:size-4",
|
|
169
|
-
|
|
174
|
+
md: "gap-1.5 rounded-md px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-4",
|
|
175
|
+
sm: "gap-1.5 rounded-[min(var(--radius-md),10px)] px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-3.5",
|
|
176
|
+
xl: "gap-2.5 rounded-md px-2.5 py-2 text-base [&_svg:not([class*='size-'])]:size-5",
|
|
177
|
+
xs: "gap-1 rounded-[min(var(--radius-md),8px)] px-1.5 py-1 text-xs [&_svg:not([class*='size-'])]:size-3"
|
|
170
178
|
},
|
|
171
179
|
variant: {
|
|
172
180
|
danger: "text-danger-foreground focus:bg-danger focus:text-danger-foreground dark:focus:bg-danger/20 *:[svg]:text-danger-foreground",
|
|
173
181
|
default: "focus:*:[svg]:text-accent-foreground"
|
|
174
182
|
}
|
|
175
|
-
},
|
|
176
|
-
defaultVariants: {
|
|
177
|
-
inset: false,
|
|
178
|
-
size: "md",
|
|
179
|
-
variant: "default"
|
|
180
183
|
}
|
|
181
184
|
});
|
|
182
185
|
const ContextMenuItem = ({ className, inset, size, variant = "default", ...props }) => {
|
|
@@ -200,15 +203,15 @@ const ContextMenuItem = ({ className, inset, size, variant = "default", ...props
|
|
|
200
203
|
//#endregion
|
|
201
204
|
//#region src/ui/context-menu/context-menu-label.tsx
|
|
202
205
|
const contextMenuLabelVariants = tv({
|
|
203
|
-
base: "
|
|
206
|
+
base: "text-muted-foreground font-medium data-[inset]:pl-8",
|
|
207
|
+
defaultVariants: { size: "md" },
|
|
204
208
|
variants: { size: {
|
|
205
|
-
xs: "px-1.5 py-1 text-[11px]",
|
|
206
|
-
sm: "px-1.5 py-1 text-xs",
|
|
207
|
-
md: "px-1.5 py-1 text-xs",
|
|
208
209
|
lg: "px-2 py-1.5 text-xs",
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
210
|
+
md: "px-1.5 py-1 text-xs",
|
|
211
|
+
sm: "px-1.5 py-1 text-xs",
|
|
212
|
+
xl: "px-2.5 py-1.5 text-sm",
|
|
213
|
+
xs: "px-1.5 py-1 text-[11px]"
|
|
214
|
+
} }
|
|
212
215
|
});
|
|
213
216
|
const ContextMenuLabel = ({ className, inset, size, ...props }) => {
|
|
214
217
|
const { size: rootSize } = useContext(ContextMenuContext);
|
|
@@ -226,28 +229,28 @@ const ContextMenuLabel = ({ className, inset, size, ...props }) => {
|
|
|
226
229
|
//#endregion
|
|
227
230
|
//#region src/ui/context-menu/context-menu-link-item.tsx
|
|
228
231
|
const contextMenuLinkItemVariants = tv({
|
|
229
|
-
base: "group/context-menu-link-item
|
|
232
|
+
base: "group/context-menu-link-item cursor-clickable focus:bg-accent focus:text-accent-foreground relative flex items-center outline-hidden select-none data-disabled:pointer-events-none data-disabled:cursor-not-allowed data-disabled:opacity-50 data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0",
|
|
233
|
+
defaultVariants: {
|
|
234
|
+
inset: false,
|
|
235
|
+
size: "md",
|
|
236
|
+
variant: "default"
|
|
237
|
+
},
|
|
230
238
|
variants: {
|
|
231
239
|
inset: {
|
|
232
240
|
false: "",
|
|
233
241
|
true: ""
|
|
234
242
|
},
|
|
235
243
|
size: {
|
|
236
|
-
xs: "gap-1 rounded-[min(var(--radius-md),8px)] px-1.5 py-1 text-xs [&_svg:not([class*='size-'])]:size-3",
|
|
237
|
-
sm: "gap-1.5 rounded-[min(var(--radius-md),10px)] px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-3.5",
|
|
238
|
-
md: "gap-1.5 rounded-md px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-4",
|
|
239
244
|
lg: "gap-2 rounded-md px-2 py-1.5 text-sm [&_svg:not([class*='size-'])]:size-4",
|
|
240
|
-
|
|
245
|
+
md: "gap-1.5 rounded-md px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-4",
|
|
246
|
+
sm: "gap-1.5 rounded-[min(var(--radius-md),10px)] px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-3.5",
|
|
247
|
+
xl: "gap-2.5 rounded-md px-2.5 py-2 text-base [&_svg:not([class*='size-'])]:size-5",
|
|
248
|
+
xs: "gap-1 rounded-[min(var(--radius-md),8px)] px-1.5 py-1 text-xs [&_svg:not([class*='size-'])]:size-3"
|
|
241
249
|
},
|
|
242
250
|
variant: {
|
|
243
251
|
danger: "text-danger-foreground focus:bg-danger focus:text-danger-foreground dark:focus:bg-danger/20 *:[svg]:text-danger-foreground",
|
|
244
252
|
default: "focus:*:[svg]:text-accent-foreground"
|
|
245
253
|
}
|
|
246
|
-
},
|
|
247
|
-
defaultVariants: {
|
|
248
|
-
inset: false,
|
|
249
|
-
size: "md",
|
|
250
|
-
variant: "default"
|
|
251
254
|
}
|
|
252
255
|
});
|
|
253
256
|
const ContextMenuLinkItem = ({ className, inset, size, variant = "default", ...props }) => {
|
|
@@ -278,33 +281,33 @@ const ContextMenuRadioGroup = ({ ...props }) => /* @__PURE__ */ jsx(ContextMenu$
|
|
|
278
281
|
//#endregion
|
|
279
282
|
//#region src/ui/context-menu/context-menu-radio-item.tsx
|
|
280
283
|
const contextMenuRadioItemVariants = tv({
|
|
284
|
+
defaultVariants: { size: "md" },
|
|
281
285
|
slots: {
|
|
282
286
|
indicator: "pointer-events-none absolute flex items-center justify-center [&_svg]:pointer-events-none [&_svg]:shrink-0",
|
|
283
|
-
root: "relative flex
|
|
287
|
+
root: "cursor-clickable focus:bg-accent focus:text-accent-foreground relative flex items-center rounded-md outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:cursor-not-allowed data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0"
|
|
284
288
|
},
|
|
285
289
|
variants: { size: {
|
|
286
|
-
|
|
287
|
-
indicator: "right-
|
|
288
|
-
root: "gap-
|
|
289
|
-
},
|
|
290
|
-
sm: {
|
|
291
|
-
indicator: "right-2 size-3.5 [&_svg:not([class*='size-'])]:size-3.5",
|
|
292
|
-
root: "gap-1.5 rounded-[min(var(--radius-md),10px)] py-1 pr-7 pl-2 text-sm [&_svg:not([class*='size-'])]:size-3.5"
|
|
290
|
+
lg: {
|
|
291
|
+
indicator: "right-2.5 size-4 [&_svg:not([class*='size-'])]:size-4",
|
|
292
|
+
root: "gap-2 py-1.5 pr-9 pl-2 text-sm [&_svg:not([class*='size-'])]:size-4"
|
|
293
293
|
},
|
|
294
294
|
md: {
|
|
295
295
|
indicator: "right-2 size-4 [&_svg:not([class*='size-'])]:size-4",
|
|
296
296
|
root: "gap-1.5 py-1 pr-8 pl-1.5 text-sm [&_svg:not([class*='size-'])]:size-4"
|
|
297
297
|
},
|
|
298
|
-
|
|
299
|
-
indicator: "right-2
|
|
300
|
-
root: "gap-
|
|
298
|
+
sm: {
|
|
299
|
+
indicator: "right-2 size-3.5 [&_svg:not([class*='size-'])]:size-3.5",
|
|
300
|
+
root: "gap-1.5 rounded-[min(var(--radius-md),10px)] py-1 pr-7 pl-2 text-sm [&_svg:not([class*='size-'])]:size-3.5"
|
|
301
301
|
},
|
|
302
302
|
xl: {
|
|
303
303
|
indicator: "right-3 size-5 [&_svg:not([class*='size-'])]:size-5",
|
|
304
304
|
root: "gap-2.5 py-2 pr-10 pl-2.5 text-base [&_svg:not([class*='size-'])]:size-5"
|
|
305
|
+
},
|
|
306
|
+
xs: {
|
|
307
|
+
indicator: "right-1.5 size-3 [&_svg:not([class*='size-'])]:size-3",
|
|
308
|
+
root: "gap-1 rounded-[min(var(--radius-md),8px)] py-1 pr-6 pl-1.5 text-xs [&_svg:not([class*='size-'])]:size-3"
|
|
305
309
|
}
|
|
306
|
-
} }
|
|
307
|
-
defaultVariants: { size: "md" }
|
|
310
|
+
} }
|
|
308
311
|
});
|
|
309
312
|
const ContextMenuRadioItem = ({ className, children, size, ...props }) => {
|
|
310
313
|
const { size: rootSize } = useContext(ContextMenuContext);
|
|
@@ -329,15 +332,15 @@ const ContextMenuRadioItem = ({ className, children, size, ...props }) => {
|
|
|
329
332
|
//#endregion
|
|
330
333
|
//#region src/ui/context-menu/context-menu-separator.tsx
|
|
331
334
|
const contextMenuSeparatorVariants = tv({
|
|
332
|
-
base: "h-px
|
|
335
|
+
base: "bg-border h-px",
|
|
336
|
+
defaultVariants: { size: "md" },
|
|
333
337
|
variants: { size: {
|
|
334
|
-
xs: "-mx-0.5 my-0.5",
|
|
335
|
-
sm: "-mx-0.5 my-0.5",
|
|
336
|
-
md: "-mx-1 my-1",
|
|
337
338
|
lg: "-mx-1.5 my-1.5",
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
339
|
+
md: "-mx-1 my-1",
|
|
340
|
+
sm: "-mx-0.5 my-0.5",
|
|
341
|
+
xl: "-mx-2 my-2",
|
|
342
|
+
xs: "-mx-0.5 my-0.5"
|
|
343
|
+
} }
|
|
341
344
|
});
|
|
342
345
|
const ContextMenuSeparator = ({ className, size, ...props }) => {
|
|
343
346
|
const { size: rootSize } = useContext(ContextMenuContext);
|
|
@@ -354,15 +357,15 @@ const ContextMenuSeparator = ({ className, size, ...props }) => {
|
|
|
354
357
|
//#endregion
|
|
355
358
|
//#region src/ui/context-menu/context-menu-shortcut.tsx
|
|
356
359
|
const contextMenuShortcutVariants = tv({
|
|
357
|
-
base: "
|
|
360
|
+
base: "text-muted-foreground group-focus/context-menu-item:text-accent-foreground ml-auto",
|
|
361
|
+
defaultVariants: { size: "md" },
|
|
358
362
|
variants: { size: {
|
|
359
|
-
xs: "text-[10px] tracking-wide",
|
|
360
|
-
sm: "text-xs tracking-wider",
|
|
361
|
-
md: "text-xs tracking-widest",
|
|
362
363
|
lg: "text-xs tracking-widest",
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
364
|
+
md: "text-xs tracking-widest",
|
|
365
|
+
sm: "text-xs tracking-wider",
|
|
366
|
+
xl: "text-sm tracking-wide",
|
|
367
|
+
xs: "text-[10px] tracking-wide"
|
|
368
|
+
} }
|
|
366
369
|
});
|
|
367
370
|
const ContextMenuShortcut = ({ className, size, ...props }) => {
|
|
368
371
|
const { size: rootSize } = useContext(ContextMenuContext);
|
|
@@ -387,14 +390,14 @@ const ContextMenuSub = ({ ...props }) => /* @__PURE__ */ jsx(ContextMenu$1.Subme
|
|
|
387
390
|
//#region src/ui/context-menu/context-menu-sub-content.tsx
|
|
388
391
|
const contextMenuSubContentVariants = tv({
|
|
389
392
|
base: "w-auto shadow-lg",
|
|
393
|
+
defaultVariants: { size: "md" },
|
|
390
394
|
variants: { size: {
|
|
391
|
-
xs: "min-w-[84px] rounded-[min(var(--radius-md),8px)]",
|
|
392
|
-
sm: "min-w-[90px] rounded-[min(var(--radius-md),10px)]",
|
|
393
|
-
md: "min-w-[96px] rounded-md",
|
|
394
395
|
lg: "min-w-[104px] rounded-md",
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
396
|
+
md: "min-w-[96px] rounded-md",
|
|
397
|
+
sm: "min-w-[90px] rounded-[min(var(--radius-md),10px)]",
|
|
398
|
+
xl: "min-w-[112px] rounded-md",
|
|
399
|
+
xs: "min-w-[84px] rounded-[min(var(--radius-md),8px)]"
|
|
400
|
+
} }
|
|
398
401
|
});
|
|
399
402
|
const ContextMenuSubContent = ({ className, size, ...props }) => {
|
|
400
403
|
const { size: rootSize } = useContext(ContextMenuContext);
|
|
@@ -412,33 +415,33 @@ const ContextMenuSubContent = ({ className, size, ...props }) => {
|
|
|
412
415
|
//#endregion
|
|
413
416
|
//#region src/ui/context-menu/context-menu-sub-trigger.tsx
|
|
414
417
|
const contextMenuSubTriggerVariants = tv({
|
|
418
|
+
defaultVariants: { size: "md" },
|
|
415
419
|
slots: {
|
|
416
420
|
icon: "ml-auto",
|
|
417
|
-
root: "
|
|
421
|
+
root: "cursor-clickable focus:bg-accent focus:text-accent-foreground data-open:bg-accent data-open:text-accent-foreground flex items-center outline-hidden select-none data-disabled:cursor-not-allowed data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0"
|
|
418
422
|
},
|
|
419
423
|
variants: { size: {
|
|
420
|
-
|
|
421
|
-
icon: "size-
|
|
422
|
-
root: "gap-
|
|
423
|
-
},
|
|
424
|
-
sm: {
|
|
425
|
-
icon: "size-3.5",
|
|
426
|
-
root: "gap-1.5 rounded-[min(var(--radius-md),10px)] px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-3.5"
|
|
424
|
+
lg: {
|
|
425
|
+
icon: "size-4",
|
|
426
|
+
root: "gap-2 rounded-md px-2 py-1.5 text-sm [&_svg:not([class*='size-'])]:size-4"
|
|
427
427
|
},
|
|
428
428
|
md: {
|
|
429
429
|
icon: "size-4",
|
|
430
430
|
root: "gap-1.5 rounded-md px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-4"
|
|
431
431
|
},
|
|
432
|
-
|
|
433
|
-
icon: "size-
|
|
434
|
-
root: "gap-
|
|
432
|
+
sm: {
|
|
433
|
+
icon: "size-3.5",
|
|
434
|
+
root: "gap-1.5 rounded-[min(var(--radius-md),10px)] px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-3.5"
|
|
435
435
|
},
|
|
436
436
|
xl: {
|
|
437
437
|
icon: "size-5",
|
|
438
438
|
root: "gap-2.5 rounded-md px-2.5 py-2 text-base [&_svg:not([class*='size-'])]:size-5"
|
|
439
|
+
},
|
|
440
|
+
xs: {
|
|
441
|
+
icon: "size-3",
|
|
442
|
+
root: "gap-1 rounded-[min(var(--radius-md),8px)] px-1.5 py-1 text-xs [&_svg:not([class*='size-'])]:size-3"
|
|
439
443
|
}
|
|
440
|
-
} }
|
|
441
|
-
defaultVariants: { size: "md" }
|
|
444
|
+
} }
|
|
442
445
|
});
|
|
443
446
|
const ContextMenuSubTrigger = ({ className, inset, children, size, ...props }) => {
|
|
444
447
|
const { size: rootSize } = useContext(ContextMenuContext);
|
|
@@ -462,7 +465,7 @@ const ContextMenuSubTrigger = ({ className, inset, children, size, ...props }) =
|
|
|
462
465
|
//#endregion
|
|
463
466
|
//#region src/ui/context-menu/context-menu-trigger.tsx
|
|
464
467
|
const ContextMenuTrigger = ({ className, ...props }) => /* @__PURE__ */ jsx(ContextMenu$1.Trigger, {
|
|
465
|
-
className: cn("cursor-
|
|
468
|
+
className: cn("cursor-clickable select-none", className),
|
|
466
469
|
"data-slot": "context-menu-trigger",
|
|
467
470
|
...props
|
|
468
471
|
});
|
|
@@ -471,8 +474,9 @@ const ContextMenuTrigger = ({ className, ...props }) => /* @__PURE__ */ jsx(Cont
|
|
|
471
474
|
//#region src/ui/context-menu/context-menu.tsx
|
|
472
475
|
const ContextMenu = ({ size: providedSize, ...props }) => {
|
|
473
476
|
const size = useComponentSize(providedSize);
|
|
477
|
+
const contextValue = useMemo(() => ({ size }), [size]);
|
|
474
478
|
return /* @__PURE__ */ jsx(ContextMenuContext.Provider, {
|
|
475
|
-
value:
|
|
479
|
+
value: contextValue,
|
|
476
480
|
children: /* @__PURE__ */ jsx(ContextMenu$1.Root, {
|
|
477
481
|
"data-size": size,
|
|
478
482
|
"data-slot": "context-menu",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context-menu.js","names":["ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive"],"sources":["../../src/ui/context-menu/context-menu-arrow.tsx","../../src/ui/context-menu/context-menu-backdrop.tsx","../../src/ui/context-menu/context-menu-context.tsx","../../src/ui/context-menu/context-menu-overlay-context.tsx","../../src/ui/context-menu/context-menu-checkbox-item.tsx","../../src/ui/context-menu/context-menu-popup.tsx","../../src/ui/context-menu/context-menu-portal.tsx","../../src/ui/context-menu/context-menu-positioner.tsx","../../src/ui/context-menu/context-menu-content.tsx","../../src/ui/context-menu/context-menu-group.tsx","../../src/ui/context-menu/context-menu-item.tsx","../../src/ui/context-menu/context-menu-label.tsx","../../src/ui/context-menu/context-menu-link-item.tsx","../../src/ui/context-menu/context-menu-radio-group.tsx","../../src/ui/context-menu/context-menu-radio-item.tsx","../../src/ui/context-menu/context-menu-separator.tsx","../../src/ui/context-menu/context-menu-shortcut.tsx","../../src/ui/context-menu/context-menu-sub.tsx","../../src/ui/context-menu/context-menu-sub-content.tsx","../../src/ui/context-menu/context-menu-sub-trigger.tsx","../../src/ui/context-menu/context-menu-trigger.tsx","../../src/ui/context-menu/context-menu.tsx"],"sourcesContent":["import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { cn } from \"tailwind-variants\";\nexport type ContextMenuArrowProps = ContextMenuPrimitive.Arrow.Props;\n\nconst ContextMenuArrow = ({ className, ...props }: ContextMenuArrowProps) => (\n <ContextMenuPrimitive.Arrow\n className={cn(\"fill-popover stroke-border\", className)}\n data-slot=\"context-menu-arrow\"\n {...props}\n />\n);\n\nexport { ContextMenuArrow };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { cn } from \"tailwind-variants\";\nexport type ContextMenuBackdropProps = ContextMenuPrimitive.Backdrop.Props;\n\nconst ContextMenuBackdrop = ({\n className,\n ...props\n}: ContextMenuBackdropProps) => (\n <ContextMenuPrimitive.Backdrop\n className={cn(className)}\n data-slot=\"context-menu-backdrop\"\n {...props}\n />\n);\n\nexport { ContextMenuBackdrop };\n","\"use client\";\n\nimport { createContext } from \"react\";\n\nimport type { InputSize } from \"../input/input\";\n\nexport interface ContextMenuContextValue {\n size?: InputSize;\n}\n\nconst ContextMenuContext = createContext<ContextMenuContextValue>({\n size: \"md\",\n});\n\nexport { ContextMenuContext };\n","\"use client\";\n\nimport { createContext } from \"react\";\n\nimport type { InputSize } from \"../input/input\";\n\nexport interface ContextMenuOverlayContextValue {\n size?: InputSize;\n}\n\nconst ContextMenuOverlayContext = createContext<ContextMenuOverlayContextValue>(\n {}\n);\n\nexport { ContextMenuOverlayContext };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { Tick02Icon } from \"@hugeicons/core-free-icons\";\nimport { HugeiconsIcon } from \"@hugeicons/react\";\nimport { useContext } from \"react\";\nimport { cn, tv, type VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\n\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuCheckboxItemVariants = tv({\n slots: {\n indicator:\n \"pointer-events-none absolute flex items-center justify-center [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n root: \"relative flex cursor-pointer items-center rounded-md outline-hidden select-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:cursor-not-allowed data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n },\n variants: {\n size: {\n xs: {\n indicator: \"right-1.5 size-3 [&_svg:not([class*='size-'])]:size-3\",\n root: \"gap-1 rounded-[min(var(--radius-md),8px)] py-1 pr-6 pl-1.5 text-xs [&_svg:not([class*='size-'])]:size-3\",\n },\n sm: {\n indicator: \"right-2 size-3.5 [&_svg:not([class*='size-'])]:size-3.5\",\n root: \"gap-1.5 rounded-[min(var(--radius-md),10px)] py-1 pr-7 pl-2 text-sm [&_svg:not([class*='size-'])]:size-3.5\",\n },\n md: {\n indicator: \"right-2 size-4 [&_svg:not([class*='size-'])]:size-4\",\n root: \"gap-1.5 py-1 pr-8 pl-1.5 text-sm [&_svg:not([class*='size-'])]:size-4\",\n },\n lg: {\n indicator: \"right-2.5 size-4 [&_svg:not([class*='size-'])]:size-4\",\n root: \"gap-2 py-1.5 pr-9 pl-2 text-sm [&_svg:not([class*='size-'])]:size-4\",\n },\n xl: {\n indicator: \"right-3 size-5 [&_svg:not([class*='size-'])]:size-5\",\n root: \"gap-2.5 py-2 pr-10 pl-2.5 text-base [&_svg:not([class*='size-'])]:size-5\",\n },\n },\n },\n defaultVariants: {\n size: \"md\",\n },\n});\n\ntype ContextMenuCheckboxItemVariantProps = VariantProps<\n typeof contextMenuCheckboxItemVariants\n>;\n\nexport type ContextMenuCheckboxItemProps =\n ContextMenuPrimitive.CheckboxItem.Props & ContextMenuCheckboxItemVariantProps;\n\nconst ContextMenuCheckboxItem = ({\n className,\n children,\n checked,\n size,\n ...props\n}: ContextMenuCheckboxItemProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n const { indicator, root } = contextMenuCheckboxItemVariants({\n size: resolvedSize,\n });\n\n return (\n <ContextMenuPrimitive.CheckboxItem\n checked={checked}\n className={cn(root(), className)}\n data-size={resolvedSize}\n data-slot=\"context-menu-checkbox-item\"\n {...props}\n >\n <span className={indicator()}>\n <ContextMenuPrimitive.CheckboxItemIndicator>\n <HugeiconsIcon icon={Tick02Icon} strokeWidth={2} />\n </ContextMenuPrimitive.CheckboxItemIndicator>\n </span>\n {children}\n </ContextMenuPrimitive.CheckboxItem>\n );\n};\n\nexport { ContextMenuCheckboxItem };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { useContext } from \"react\";\nimport { cn, tv, type VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\n\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuPopupVariants = tv({\n base: \"z-50 max-h-(--available-height) origin-(--transform-origin) overflow-x-hidden overflow-y-auto bg-popover text-popover-foreground shadow-md ring-1 ring-foreground/10 duration-100 outline-none data-closed:animate-out data-closed:fade-out-0 data-closed:zoom-out-95 data-open:animate-in data-open:fade-in-0 data-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\",\n variants: {\n size: {\n xs: \"min-w-28 rounded-[min(var(--radius-md),8px)] p-0.5\",\n sm: \"min-w-32 rounded-[min(var(--radius-md),10px)] p-0.5\",\n md: \"min-w-36 rounded-md p-1\",\n lg: \"min-w-40 rounded-md p-1.5\",\n xl: \"min-w-44 rounded-md p-2\",\n },\n },\n defaultVariants: {\n size: \"md\",\n },\n});\n\ntype ContextMenuPopupVariantProps = VariantProps<\n typeof contextMenuPopupVariants\n>;\n\nexport type ContextMenuPopupProps = ContextMenuPrimitive.Popup.Props &\n ContextMenuPopupVariantProps;\n\nconst ContextMenuPopup = ({\n className,\n size,\n ...props\n}: ContextMenuPopupProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <ContextMenuPrimitive.Popup\n className={cn(\n contextMenuPopupVariants({ size: resolvedSize }),\n className\n )}\n data-size={resolvedSize}\n data-slot=\"context-menu-popup\"\n {...props}\n />\n );\n};\n\nexport { ContextMenuPopup };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nexport type ContextMenuPortalProps = ContextMenuPrimitive.Portal.Props;\n\nconst ContextMenuPortal = ({ ...props }: ContextMenuPortalProps) => (\n <ContextMenuPrimitive.Portal data-slot=\"context-menu-portal\" {...props} />\n);\n\nexport { ContextMenuPortal };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { cn } from \"tailwind-variants\";\nexport type ContextMenuPositionerProps = ContextMenuPrimitive.Positioner.Props;\n\nconst ContextMenuPositioner = ({\n className,\n ...props\n}: ContextMenuPositionerProps) => (\n <ContextMenuPrimitive.Positioner\n className={cn(\"isolate z-50 outline-none\", className)}\n data-slot=\"context-menu-positioner\"\n {...props}\n />\n);\n\nexport { ContextMenuPositioner };\n","import type { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\n\nimport { useContext } from \"react\";\n\nimport type { InputSize } from \"../input/input\";\n\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\nimport { ContextMenuPopup } from \"./context-menu-popup\";\nimport { ContextMenuPortal } from \"./context-menu-portal\";\nimport { ContextMenuPositioner } from \"./context-menu-positioner\";\nexport type ContextMenuContentProps = ContextMenuPrimitive.Popup.Props &\n Pick<\n ContextMenuPrimitive.Positioner.Props,\n \"align\" | \"alignOffset\" | \"side\" | \"sideOffset\"\n > & {\n size?: InputSize;\n };\n\nconst ContextMenuContent = ({\n className,\n align = \"start\",\n alignOffset = 4,\n side = \"right\",\n sideOffset = 0,\n size,\n ...props\n}: ContextMenuContentProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const resolvedSize = size ?? rootSize ?? \"md\";\n\n return (\n <ContextMenuOverlayContext.Provider value={{ size: resolvedSize }}>\n <ContextMenuPortal>\n <ContextMenuPositioner\n align={align}\n alignOffset={alignOffset}\n side={side}\n sideOffset={sideOffset}\n >\n <ContextMenuPopup\n className={className}\n data-size={resolvedSize}\n data-slot=\"context-menu-content\"\n size={resolvedSize}\n {...props}\n />\n </ContextMenuPositioner>\n </ContextMenuPortal>\n </ContextMenuOverlayContext.Provider>\n );\n};\n\nexport { ContextMenuContent };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nexport type ContextMenuGroupProps = ContextMenuPrimitive.Group.Props;\n\nconst ContextMenuGroup = ({ ...props }: ContextMenuGroupProps) => (\n <ContextMenuPrimitive.Group data-slot=\"context-menu-group\" {...props} />\n);\n\nexport { ContextMenuGroup };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { useContext } from \"react\";\nimport { tv, type VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\n\nimport { mergeBaseUIClassName } from \"../../utils/merge-base-ui-class-name\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuItemVariants = tv({\n base: \"group/context-menu-item relative flex cursor-pointer items-center outline-hidden select-none focus:bg-accent focus:text-accent-foreground data-disabled:pointer-events-none data-disabled:cursor-not-allowed data-disabled:opacity-50 data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n variants: {\n inset: {\n false: \"\",\n true: \"\",\n },\n size: {\n xs: \"gap-1 rounded-[min(var(--radius-md),8px)] px-1.5 py-1 text-xs [&_svg:not([class*='size-'])]:size-3\",\n sm: \"gap-1.5 rounded-[min(var(--radius-md),10px)] px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-3.5\",\n md: \"gap-1.5 rounded-md px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-4\",\n lg: \"gap-2 rounded-md px-2 py-1.5 text-sm [&_svg:not([class*='size-'])]:size-4\",\n xl: \"gap-2.5 rounded-md px-2.5 py-2 text-base [&_svg:not([class*='size-'])]:size-5\",\n },\n variant: {\n danger:\n \"text-danger-foreground focus:bg-danger focus:text-danger-foreground dark:focus:bg-danger/20 *:[svg]:text-danger-foreground\",\n default: \"focus:*:[svg]:text-accent-foreground\",\n },\n },\n defaultVariants: {\n inset: false,\n size: \"md\",\n variant: \"default\",\n },\n});\n\nexport type ContextMenuItemProps = ContextMenuPrimitive.Item.Props &\n VariantProps<typeof contextMenuItemVariants>;\n\nconst ContextMenuItem = ({\n className,\n inset,\n size,\n variant = \"default\",\n ...props\n}: ContextMenuItemProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <ContextMenuPrimitive.Item\n className={mergeBaseUIClassName<ContextMenuPrimitive.Item.State>(\n contextMenuItemVariants({\n inset: Boolean(inset),\n size: resolvedSize,\n variant,\n }),\n className\n )}\n data-inset={inset}\n data-size={resolvedSize}\n data-slot=\"context-menu-item\"\n data-variant={variant}\n {...props}\n />\n );\n};\n\nexport { ContextMenuItem };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { useContext } from \"react\";\nimport { cn, tv, type VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\n\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuLabelVariants = tv({\n base: \"font-medium text-muted-foreground data-[inset]:pl-8\",\n variants: {\n size: {\n xs: \"px-1.5 py-1 text-[11px]\",\n sm: \"px-1.5 py-1 text-xs\",\n md: \"px-1.5 py-1 text-xs\",\n lg: \"px-2 py-1.5 text-xs\",\n xl: \"px-2.5 py-1.5 text-sm\",\n },\n },\n defaultVariants: {\n size: \"md\",\n },\n});\n\nexport type ContextMenuLabelProps = ContextMenuPrimitive.GroupLabel.Props & {\n inset?: boolean;\n} & VariantProps<typeof contextMenuLabelVariants>;\n\nconst ContextMenuLabel = ({\n className,\n inset,\n size,\n ...props\n}: ContextMenuLabelProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <ContextMenuPrimitive.GroupLabel\n className={cn(\n contextMenuLabelVariants({ size: resolvedSize }),\n className\n )}\n data-inset={inset}\n data-size={resolvedSize}\n data-slot=\"context-menu-label\"\n {...props}\n />\n );\n};\n\nexport { ContextMenuLabel };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { useContext } from \"react\";\nimport { tv, type VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\n\nimport { mergeBaseUIClassName } from \"../../utils/merge-base-ui-class-name\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuLinkItemVariants = tv({\n base: \"group/context-menu-link-item relative flex cursor-pointer items-center outline-hidden select-none focus:bg-accent focus:text-accent-foreground data-disabled:pointer-events-none data-disabled:cursor-not-allowed data-disabled:opacity-50 data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n variants: {\n inset: {\n false: \"\",\n true: \"\",\n },\n size: {\n xs: \"gap-1 rounded-[min(var(--radius-md),8px)] px-1.5 py-1 text-xs [&_svg:not([class*='size-'])]:size-3\",\n sm: \"gap-1.5 rounded-[min(var(--radius-md),10px)] px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-3.5\",\n md: \"gap-1.5 rounded-md px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-4\",\n lg: \"gap-2 rounded-md px-2 py-1.5 text-sm [&_svg:not([class*='size-'])]:size-4\",\n xl: \"gap-2.5 rounded-md px-2.5 py-2 text-base [&_svg:not([class*='size-'])]:size-5\",\n },\n variant: {\n danger:\n \"text-danger-foreground focus:bg-danger focus:text-danger-foreground dark:focus:bg-danger/20 *:[svg]:text-danger-foreground\",\n default: \"focus:*:[svg]:text-accent-foreground\",\n },\n },\n defaultVariants: {\n inset: false,\n size: \"md\",\n variant: \"default\",\n },\n});\n\nexport type ContextMenuLinkItemProps = ContextMenuPrimitive.LinkItem.Props &\n VariantProps<typeof contextMenuLinkItemVariants>;\n\nconst ContextMenuLinkItem = ({\n className,\n inset,\n size,\n variant = \"default\",\n ...props\n}: ContextMenuLinkItemProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <ContextMenuPrimitive.LinkItem\n className={mergeBaseUIClassName<ContextMenuPrimitive.LinkItem.State>(\n contextMenuLinkItemVariants({\n inset: Boolean(inset),\n size: resolvedSize,\n variant,\n }),\n className\n )}\n data-inset={inset}\n data-size={resolvedSize}\n data-slot=\"context-menu-link-item\"\n data-variant={variant}\n {...props}\n />\n );\n};\n\nexport { ContextMenuLinkItem };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nexport type ContextMenuRadioGroupProps = ContextMenuPrimitive.RadioGroup.Props;\n\nconst ContextMenuRadioGroup = ({ ...props }: ContextMenuRadioGroupProps) => (\n <ContextMenuPrimitive.RadioGroup\n data-slot=\"context-menu-radio-group\"\n {...props}\n />\n);\n\nexport { ContextMenuRadioGroup };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { Tick02Icon } from \"@hugeicons/core-free-icons\";\nimport { HugeiconsIcon } from \"@hugeicons/react\";\nimport { useContext } from \"react\";\nimport { cn, tv, type VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\n\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuRadioItemVariants = tv({\n slots: {\n indicator:\n \"pointer-events-none absolute flex items-center justify-center [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n root: \"relative flex cursor-pointer items-center rounded-md outline-hidden select-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:cursor-not-allowed data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n },\n variants: {\n size: {\n xs: {\n indicator: \"right-1.5 size-3 [&_svg:not([class*='size-'])]:size-3\",\n root: \"gap-1 rounded-[min(var(--radius-md),8px)] py-1 pr-6 pl-1.5 text-xs [&_svg:not([class*='size-'])]:size-3\",\n },\n sm: {\n indicator: \"right-2 size-3.5 [&_svg:not([class*='size-'])]:size-3.5\",\n root: \"gap-1.5 rounded-[min(var(--radius-md),10px)] py-1 pr-7 pl-2 text-sm [&_svg:not([class*='size-'])]:size-3.5\",\n },\n md: {\n indicator: \"right-2 size-4 [&_svg:not([class*='size-'])]:size-4\",\n root: \"gap-1.5 py-1 pr-8 pl-1.5 text-sm [&_svg:not([class*='size-'])]:size-4\",\n },\n lg: {\n indicator: \"right-2.5 size-4 [&_svg:not([class*='size-'])]:size-4\",\n root: \"gap-2 py-1.5 pr-9 pl-2 text-sm [&_svg:not([class*='size-'])]:size-4\",\n },\n xl: {\n indicator: \"right-3 size-5 [&_svg:not([class*='size-'])]:size-5\",\n root: \"gap-2.5 py-2 pr-10 pl-2.5 text-base [&_svg:not([class*='size-'])]:size-5\",\n },\n },\n },\n defaultVariants: {\n size: \"md\",\n },\n});\n\ntype ContextMenuRadioItemVariantProps = VariantProps<\n typeof contextMenuRadioItemVariants\n>;\n\nexport type ContextMenuRadioItemProps = ContextMenuPrimitive.RadioItem.Props &\n ContextMenuRadioItemVariantProps;\n\nconst ContextMenuRadioItem = ({\n className,\n children,\n size,\n ...props\n}: ContextMenuRadioItemProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n const { indicator, root } = contextMenuRadioItemVariants({\n size: resolvedSize,\n });\n\n return (\n <ContextMenuPrimitive.RadioItem\n className={cn(root(), className)}\n data-size={resolvedSize}\n data-slot=\"context-menu-radio-item\"\n {...props}\n >\n <span className={indicator()}>\n <ContextMenuPrimitive.RadioItemIndicator>\n <HugeiconsIcon icon={Tick02Icon} strokeWidth={2} />\n </ContextMenuPrimitive.RadioItemIndicator>\n </span>\n {children}\n </ContextMenuPrimitive.RadioItem>\n );\n};\n\nexport { ContextMenuRadioItem };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { useContext } from \"react\";\nimport { cn, tv, type VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\n\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuSeparatorVariants = tv({\n base: \"h-px bg-border\",\n variants: {\n size: {\n xs: \"-mx-0.5 my-0.5\",\n sm: \"-mx-0.5 my-0.5\",\n md: \"-mx-1 my-1\",\n lg: \"-mx-1.5 my-1.5\",\n xl: \"-mx-2 my-2\",\n },\n },\n defaultVariants: {\n size: \"md\",\n },\n});\n\nexport type ContextMenuSeparatorProps = ContextMenuPrimitive.Separator.Props;\n\nconst ContextMenuSeparator = ({\n className,\n size,\n ...props\n}: ContextMenuSeparatorProps &\n VariantProps<typeof contextMenuSeparatorVariants>) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <ContextMenuPrimitive.Separator\n className={cn(\n contextMenuSeparatorVariants({ size: resolvedSize }),\n className\n )}\n data-size={resolvedSize}\n data-slot=\"context-menu-separator\"\n {...props}\n />\n );\n};\n\nexport { ContextMenuSeparator };\n","import type { ComponentProps } from \"react\";\n\nimport { useContext } from \"react\";\nimport { cn, tv, type VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\n\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuShortcutVariants = tv({\n base: \"ml-auto text-muted-foreground group-focus/context-menu-item:text-accent-foreground\",\n variants: {\n size: {\n xs: \"text-[10px] tracking-wide\",\n sm: \"text-xs tracking-wider\",\n md: \"text-xs tracking-widest\",\n lg: \"text-xs tracking-widest\",\n xl: \"text-sm tracking-wide\",\n },\n },\n defaultVariants: {\n size: \"md\",\n },\n});\n\nexport type ContextMenuShortcutProps = ComponentProps<\"span\"> &\n VariantProps<typeof contextMenuShortcutVariants>;\n\nconst ContextMenuShortcut = ({\n className,\n size,\n ...props\n}: ContextMenuShortcutProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <span\n className={cn(\n contextMenuShortcutVariants({ size: resolvedSize }),\n className\n )}\n data-size={resolvedSize}\n data-slot=\"context-menu-shortcut\"\n {...props}\n />\n );\n};\n\nexport { ContextMenuShortcut };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nexport type ContextMenuSubProps = ContextMenuPrimitive.SubmenuRoot.Props;\n\nconst ContextMenuSub = ({ ...props }: ContextMenuSubProps) => (\n <ContextMenuPrimitive.SubmenuRoot data-slot=\"context-menu-sub\" {...props} />\n);\n\nexport { ContextMenuSub };\n","import type { ComponentProps } from \"react\";\n\nimport { useContext } from \"react\";\nimport { cn, tv, type VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\n\nimport { ContextMenuContent } from \"./context-menu-content\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuSubContentVariants = tv({\n base: \"w-auto shadow-lg\",\n variants: {\n size: {\n xs: \"min-w-[84px] rounded-[min(var(--radius-md),8px)]\",\n sm: \"min-w-[90px] rounded-[min(var(--radius-md),10px)]\",\n md: \"min-w-[96px] rounded-md\",\n lg: \"min-w-[104px] rounded-md\",\n xl: \"min-w-[112px] rounded-md\",\n },\n },\n defaultVariants: {\n size: \"md\",\n },\n});\n\nexport type ContextMenuSubContentProps = ComponentProps<\n typeof ContextMenuContent\n> &\n VariantProps<typeof contextMenuSubContentVariants>;\n\nconst ContextMenuSubContent = ({\n className,\n size,\n ...props\n}: ContextMenuSubContentProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <ContextMenuContent\n className={cn(\n contextMenuSubContentVariants({ size: resolvedSize }),\n className\n )}\n data-slot=\"context-menu-sub-content\"\n side=\"right\"\n size={resolvedSize}\n {...props}\n />\n );\n};\n\nexport { ContextMenuSubContent };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { ArrowRight01Icon } from \"@hugeicons/core-free-icons\";\nimport { HugeiconsIcon } from \"@hugeicons/react\";\nimport { useContext } from \"react\";\nimport { cn, tv, type VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\n\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuSubTriggerVariants = tv({\n slots: {\n icon: \"ml-auto\",\n root: \"flex cursor-pointer items-center outline-hidden select-none focus:bg-accent focus:text-accent-foreground data-disabled:cursor-not-allowed data-open:bg-accent data-open:text-accent-foreground data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n },\n variants: {\n size: {\n xs: {\n icon: \"size-3\",\n root: \"gap-1 rounded-[min(var(--radius-md),8px)] px-1.5 py-1 text-xs [&_svg:not([class*='size-'])]:size-3\",\n },\n sm: {\n icon: \"size-3.5\",\n root: \"gap-1.5 rounded-[min(var(--radius-md),10px)] px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-3.5\",\n },\n md: {\n icon: \"size-4\",\n root: \"gap-1.5 rounded-md px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-4\",\n },\n lg: {\n icon: \"size-4\",\n root: \"gap-2 rounded-md px-2 py-1.5 text-sm [&_svg:not([class*='size-'])]:size-4\",\n },\n xl: {\n icon: \"size-5\",\n root: \"gap-2.5 rounded-md px-2.5 py-2 text-base [&_svg:not([class*='size-'])]:size-5\",\n },\n },\n },\n defaultVariants: {\n size: \"md\",\n },\n});\n\nexport type ContextMenuSubTriggerProps =\n ContextMenuPrimitive.SubmenuTrigger.Props & {\n inset?: boolean;\n } & VariantProps<typeof contextMenuSubTriggerVariants>;\n\nconst ContextMenuSubTrigger = ({\n className,\n inset,\n children,\n size,\n ...props\n}: ContextMenuSubTriggerProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n const { icon, root } = contextMenuSubTriggerVariants({ size: resolvedSize });\n\n return (\n <ContextMenuPrimitive.SubmenuTrigger\n className={cn(root(), className)}\n data-inset={inset}\n data-size={resolvedSize}\n data-slot=\"context-menu-sub-trigger\"\n {...props}\n >\n {children}\n <HugeiconsIcon\n className={icon()}\n icon={ArrowRight01Icon}\n strokeWidth={2}\n />\n </ContextMenuPrimitive.SubmenuTrigger>\n );\n};\n\nexport { ContextMenuSubTrigger };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { cn } from \"tailwind-variants\";\nexport type ContextMenuTriggerProps = ContextMenuPrimitive.Trigger.Props;\n\nconst ContextMenuTrigger = ({\n className,\n ...props\n}: ContextMenuTriggerProps) => (\n <ContextMenuPrimitive.Trigger\n className={cn(\"cursor-pointer select-none\", className)}\n data-slot=\"context-menu-trigger\"\n {...props}\n />\n);\n\nexport { ContextMenuTrigger };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\n\nimport type { InputSize } from \"../input/input\";\n\nimport { useComponentSize } from \"../shared/size/size-provider\";\nimport { ContextMenuArrow } from \"./context-menu-arrow\";\nimport { ContextMenuBackdrop } from \"./context-menu-backdrop\";\nimport { ContextMenuCheckboxItem } from \"./context-menu-checkbox-item\";\nimport { ContextMenuContent } from \"./context-menu-content\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuGroup } from \"./context-menu-group\";\nimport { ContextMenuItem } from \"./context-menu-item\";\nimport { ContextMenuLabel } from \"./context-menu-label\";\nimport { ContextMenuLinkItem } from \"./context-menu-link-item\";\nimport { ContextMenuPopup } from \"./context-menu-popup\";\nimport { ContextMenuPortal } from \"./context-menu-portal\";\nimport { ContextMenuPositioner } from \"./context-menu-positioner\";\nimport { ContextMenuRadioGroup } from \"./context-menu-radio-group\";\nimport { ContextMenuRadioItem } from \"./context-menu-radio-item\";\nimport { ContextMenuSeparator } from \"./context-menu-separator\";\nimport { ContextMenuShortcut } from \"./context-menu-shortcut\";\nimport { ContextMenuSub } from \"./context-menu-sub\";\nimport { ContextMenuSubContent } from \"./context-menu-sub-content\";\nimport { ContextMenuSubTrigger } from \"./context-menu-sub-trigger\";\nimport { ContextMenuTrigger } from \"./context-menu-trigger\";\nexport type ContextMenuProps = ContextMenuPrimitive.Root.Props & {\n size?: InputSize;\n};\n\nconst ContextMenu = ({ size: providedSize, ...props }: ContextMenuProps) => {\n const size = useComponentSize(providedSize);\n\n return (\n <ContextMenuContext.Provider value={{ size }}>\n <ContextMenuPrimitive.Root\n data-size={size}\n data-slot=\"context-menu\"\n {...props}\n />\n </ContextMenuContext.Provider>\n );\n};\n\nContextMenu.Arrow = ContextMenuArrow;\nContextMenu.Backdrop = ContextMenuBackdrop;\nContextMenu.CheckboxItem = ContextMenuCheckboxItem;\nContextMenu.Content = ContextMenuContent;\nContextMenu.Group = ContextMenuGroup;\nContextMenu.Item = ContextMenuItem;\nContextMenu.Label = ContextMenuLabel;\nContextMenu.LinkItem = ContextMenuLinkItem;\nContextMenu.Portal = ContextMenuPortal;\nContextMenu.Popup = ContextMenuPopup;\nContextMenu.Positioner = ContextMenuPositioner;\nContextMenu.RadioGroup = ContextMenuRadioGroup;\nContextMenu.RadioItem = ContextMenuRadioItem;\nContextMenu.Separator = ContextMenuSeparator;\nContextMenu.Shortcut = ContextMenuShortcut;\nContextMenu.Sub = ContextMenuSub;\nContextMenu.SubContent = ContextMenuSubContent;\nContextMenu.SubTrigger = ContextMenuSubTrigger;\nContextMenu.Trigger = ContextMenuTrigger;\n\nexport {\n ContextMenu,\n ContextMenuArrow,\n ContextMenuBackdrop,\n ContextMenuCheckboxItem,\n ContextMenuContent,\n ContextMenuGroup,\n ContextMenuItem,\n ContextMenuLabel,\n ContextMenuLinkItem,\n ContextMenuPortal,\n ContextMenuPopup,\n ContextMenuPositioner,\n ContextMenuRadioGroup,\n ContextMenuRadioItem,\n ContextMenuSeparator,\n ContextMenuShortcut,\n ContextMenuSub,\n ContextMenuSubContent,\n ContextMenuSubTrigger,\n ContextMenuTrigger,\n};\n\nexport type { ContextMenuArrowProps } from \"./context-menu-arrow\";\nexport type { ContextMenuBackdropProps } from \"./context-menu-backdrop\";\nexport type { ContextMenuCheckboxItemProps } from \"./context-menu-checkbox-item\";\nexport type { ContextMenuContentProps } from \"./context-menu-content\";\nexport type { ContextMenuGroupProps } from \"./context-menu-group\";\nexport type { ContextMenuItemProps } from \"./context-menu-item\";\nexport type { ContextMenuLabelProps } from \"./context-menu-label\";\nexport type { ContextMenuLinkItemProps } from \"./context-menu-link-item\";\nexport type { ContextMenuPopupProps } from \"./context-menu-popup\";\nexport type { ContextMenuPortalProps } from \"./context-menu-portal\";\nexport type { ContextMenuPositionerProps } from \"./context-menu-positioner\";\nexport type { ContextMenuRadioGroupProps } from \"./context-menu-radio-group\";\nexport type { ContextMenuRadioItemProps } from \"./context-menu-radio-item\";\nexport type { ContextMenuSeparatorProps } from \"./context-menu-separator\";\nexport type { ContextMenuShortcutProps } from \"./context-menu-shortcut\";\nexport type { ContextMenuSubProps } from \"./context-menu-sub\";\nexport type { ContextMenuSubContentProps } from \"./context-menu-sub-content\";\nexport type { ContextMenuSubTriggerProps } from \"./context-menu-sub-trigger\";\nexport type { ContextMenuTriggerProps } from \"./context-menu-trigger\";\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"context-menu.js","names":["ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive","ContextMenuPrimitive"],"sources":["../../src/ui/context-menu/context-menu-arrow.tsx","../../src/ui/context-menu/context-menu-backdrop.tsx","../../src/ui/context-menu/context-menu-context.tsx","../../src/ui/context-menu/context-menu-overlay-context.tsx","../../src/ui/context-menu/context-menu-checkbox-item.tsx","../../src/ui/context-menu/context-menu-popup.tsx","../../src/ui/context-menu/context-menu-portal.tsx","../../src/ui/context-menu/context-menu-positioner.tsx","../../src/ui/context-menu/context-menu-content.tsx","../../src/ui/context-menu/context-menu-group.tsx","../../src/ui/context-menu/context-menu-item.tsx","../../src/ui/context-menu/context-menu-label.tsx","../../src/ui/context-menu/context-menu-link-item.tsx","../../src/ui/context-menu/context-menu-radio-group.tsx","../../src/ui/context-menu/context-menu-radio-item.tsx","../../src/ui/context-menu/context-menu-separator.tsx","../../src/ui/context-menu/context-menu-shortcut.tsx","../../src/ui/context-menu/context-menu-sub.tsx","../../src/ui/context-menu/context-menu-sub-content.tsx","../../src/ui/context-menu/context-menu-sub-trigger.tsx","../../src/ui/context-menu/context-menu-trigger.tsx","../../src/ui/context-menu/context-menu.tsx"],"sourcesContent":["import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { cn } from \"tailwind-variants\";\nexport type ContextMenuArrowProps = ContextMenuPrimitive.Arrow.Props;\n\nconst ContextMenuArrow = ({ className, ...props }: ContextMenuArrowProps) => (\n <ContextMenuPrimitive.Arrow\n className={cn(\"fill-popover stroke-border\", className)}\n data-slot=\"context-menu-arrow\"\n {...props}\n />\n);\n\nexport { ContextMenuArrow };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { cn } from \"tailwind-variants\";\nexport type ContextMenuBackdropProps = ContextMenuPrimitive.Backdrop.Props;\n\nconst ContextMenuBackdrop = ({\n className,\n ...props\n}: ContextMenuBackdropProps) => (\n <ContextMenuPrimitive.Backdrop\n className={cn(className)}\n data-slot=\"context-menu-backdrop\"\n {...props}\n />\n);\n\nexport { ContextMenuBackdrop };\n","\"use client\";\n\nimport { createContext } from \"react\";\n\nimport type { InputSize } from \"../input/input\";\n\nexport interface ContextMenuContextValue {\n size?: InputSize;\n}\n\nconst ContextMenuContext = createContext<ContextMenuContextValue>({\n size: \"md\",\n});\n\nexport { ContextMenuContext };\n","\"use client\";\n\nimport { createContext } from \"react\";\n\nimport type { InputSize } from \"../input/input\";\n\nexport interface ContextMenuOverlayContextValue {\n size?: InputSize;\n}\n\nconst ContextMenuOverlayContext = createContext<ContextMenuOverlayContextValue>(\n {}\n);\n\nexport { ContextMenuOverlayContext };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { Tick02Icon } from \"@hugeicons/core-free-icons\";\nimport { HugeiconsIcon } from \"@hugeicons/react\";\nimport { useContext } from \"react\";\nimport { cn, tv } from \"tailwind-variants\";\nimport type { VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuCheckboxItemVariants = tv({\n defaultVariants: {\n size: \"md\",\n },\n slots: {\n indicator:\n \"pointer-events-none absolute flex items-center justify-center [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n root: \"cursor-clickable focus:bg-accent focus:text-accent-foreground relative flex items-center rounded-md outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:cursor-not-allowed data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n },\n variants: {\n size: {\n lg: {\n indicator: \"right-2.5 size-4 [&_svg:not([class*='size-'])]:size-4\",\n root: \"gap-2 py-1.5 pr-9 pl-2 text-sm [&_svg:not([class*='size-'])]:size-4\",\n },\n md: {\n indicator: \"right-2 size-4 [&_svg:not([class*='size-'])]:size-4\",\n root: \"gap-1.5 py-1 pr-8 pl-1.5 text-sm [&_svg:not([class*='size-'])]:size-4\",\n },\n sm: {\n indicator: \"right-2 size-3.5 [&_svg:not([class*='size-'])]:size-3.5\",\n root: \"gap-1.5 rounded-[min(var(--radius-md),10px)] py-1 pr-7 pl-2 text-sm [&_svg:not([class*='size-'])]:size-3.5\",\n },\n xl: {\n indicator: \"right-3 size-5 [&_svg:not([class*='size-'])]:size-5\",\n root: \"gap-2.5 py-2 pr-10 pl-2.5 text-base [&_svg:not([class*='size-'])]:size-5\",\n },\n xs: {\n indicator: \"right-1.5 size-3 [&_svg:not([class*='size-'])]:size-3\",\n root: \"gap-1 rounded-[min(var(--radius-md),8px)] py-1 pr-6 pl-1.5 text-xs [&_svg:not([class*='size-'])]:size-3\",\n },\n },\n },\n});\n\ntype ContextMenuCheckboxItemVariantProps = VariantProps<\n typeof contextMenuCheckboxItemVariants\n>;\n\nexport type ContextMenuCheckboxItemProps =\n ContextMenuPrimitive.CheckboxItem.Props & ContextMenuCheckboxItemVariantProps;\n\nconst ContextMenuCheckboxItem = ({\n className,\n children,\n checked,\n size,\n ...props\n}: ContextMenuCheckboxItemProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n const { indicator, root } = contextMenuCheckboxItemVariants({\n size: resolvedSize,\n });\n\n return (\n <ContextMenuPrimitive.CheckboxItem\n checked={checked}\n className={cn(root(), className)}\n data-size={resolvedSize}\n data-slot=\"context-menu-checkbox-item\"\n {...props}\n >\n <span className={indicator()}>\n <ContextMenuPrimitive.CheckboxItemIndicator>\n <HugeiconsIcon icon={Tick02Icon} strokeWidth={2} />\n </ContextMenuPrimitive.CheckboxItemIndicator>\n </span>\n {children}\n </ContextMenuPrimitive.CheckboxItem>\n );\n};\n\nexport { ContextMenuCheckboxItem };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { useContext } from \"react\";\nimport { cn, tv } from \"tailwind-variants\";\nimport type { VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuPopupVariants = tv({\n base: \"z-overlay bg-popover text-popover-foreground ring-foreground/10 data-closed:animate-out data-closed:fade-out-0 data-closed:zoom-out-95 data-open:animate-in data-open:fade-in-0 data-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 max-h-(--available-height) origin-(--transform-origin) overflow-x-hidden overflow-y-auto shadow-md ring-1 duration-100 outline-none\",\n defaultVariants: {\n size: \"md\",\n },\n variants: {\n size: {\n lg: \"min-w-40 rounded-md p-1.5\",\n md: \"min-w-36 rounded-md p-1\",\n sm: \"min-w-32 rounded-[min(var(--radius-md),10px)] p-0.5\",\n xl: \"min-w-44 rounded-md p-2\",\n xs: \"min-w-28 rounded-[min(var(--radius-md),8px)] p-0.5\",\n },\n },\n});\n\ntype ContextMenuPopupVariantProps = VariantProps<\n typeof contextMenuPopupVariants\n>;\n\nexport type ContextMenuPopupProps = ContextMenuPrimitive.Popup.Props &\n ContextMenuPopupVariantProps;\n\nconst ContextMenuPopup = ({\n className,\n size,\n ...props\n}: ContextMenuPopupProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <ContextMenuPrimitive.Popup\n className={cn(\n contextMenuPopupVariants({ size: resolvedSize }),\n className\n )}\n data-size={resolvedSize}\n data-slot=\"context-menu-popup\"\n {...props}\n />\n );\n};\n\nexport { ContextMenuPopup };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nexport type ContextMenuPortalProps = ContextMenuPrimitive.Portal.Props;\n\nconst ContextMenuPortal = ({ ...props }: ContextMenuPortalProps) => (\n <ContextMenuPrimitive.Portal data-slot=\"context-menu-portal\" {...props} />\n);\n\nexport { ContextMenuPortal };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { cn } from \"tailwind-variants\";\nexport type ContextMenuPositionerProps = ContextMenuPrimitive.Positioner.Props;\n\nconst ContextMenuPositioner = ({\n className,\n ...props\n}: ContextMenuPositionerProps) => (\n <ContextMenuPrimitive.Positioner\n className={cn(\"z-overlay isolate outline-none\", className)}\n data-slot=\"context-menu-positioner\"\n {...props}\n />\n);\n\nexport { ContextMenuPositioner };\n","import type { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { useContext, useMemo } from \"react\";\n\nimport type { InputSize } from \"../input/input\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\nimport { ContextMenuPopup } from \"./context-menu-popup\";\nimport { ContextMenuPortal } from \"./context-menu-portal\";\nimport { ContextMenuPositioner } from \"./context-menu-positioner\";\nexport type ContextMenuContentProps = ContextMenuPrimitive.Popup.Props &\n Pick<\n ContextMenuPrimitive.Positioner.Props,\n \"align\" | \"alignOffset\" | \"side\" | \"sideOffset\"\n > & {\n size?: InputSize;\n };\n\nconst ContextMenuContent = ({\n className,\n align = \"start\",\n alignOffset = 4,\n side = \"right\",\n sideOffset = 0,\n size,\n ...props\n}: ContextMenuContentProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const resolvedSize = size ?? rootSize ?? \"md\";\n const contextValue = useMemo(() => ({ size: resolvedSize }), [resolvedSize]);\n\n return (\n <ContextMenuOverlayContext.Provider value={contextValue}>\n <ContextMenuPortal>\n <ContextMenuPositioner\n align={align}\n alignOffset={alignOffset}\n side={side}\n sideOffset={sideOffset}\n >\n <ContextMenuPopup\n className={className}\n data-size={resolvedSize}\n data-slot=\"context-menu-content\"\n size={resolvedSize}\n {...props}\n />\n </ContextMenuPositioner>\n </ContextMenuPortal>\n </ContextMenuOverlayContext.Provider>\n );\n};\n\nexport { ContextMenuContent };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nexport type ContextMenuGroupProps = ContextMenuPrimitive.Group.Props;\n\nconst ContextMenuGroup = ({ ...props }: ContextMenuGroupProps) => (\n <ContextMenuPrimitive.Group data-slot=\"context-menu-group\" {...props} />\n);\n\nexport { ContextMenuGroup };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { useContext } from \"react\";\nimport { tv } from \"tailwind-variants\";\nimport type { VariantProps } from \"tailwind-variants\";\n\nimport { mergeBaseUIClassName } from \"../../utils/merge-base-ui-class-name\";\nimport type { InputSize } from \"../input/input\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuItemVariants = tv({\n base: \"group/context-menu-item cursor-clickable focus:bg-accent focus:text-accent-foreground relative flex items-center outline-hidden select-none data-disabled:pointer-events-none data-disabled:cursor-not-allowed data-disabled:opacity-50 data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n defaultVariants: {\n inset: false,\n size: \"md\",\n variant: \"default\",\n },\n variants: {\n inset: {\n false: \"\",\n true: \"\",\n },\n size: {\n lg: \"gap-2 rounded-md px-2 py-1.5 text-sm [&_svg:not([class*='size-'])]:size-4\",\n md: \"gap-1.5 rounded-md px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-4\",\n sm: \"gap-1.5 rounded-[min(var(--radius-md),10px)] px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-3.5\",\n xl: \"gap-2.5 rounded-md px-2.5 py-2 text-base [&_svg:not([class*='size-'])]:size-5\",\n xs: \"gap-1 rounded-[min(var(--radius-md),8px)] px-1.5 py-1 text-xs [&_svg:not([class*='size-'])]:size-3\",\n },\n variant: {\n danger:\n \"text-danger-foreground focus:bg-danger focus:text-danger-foreground dark:focus:bg-danger/20 *:[svg]:text-danger-foreground\",\n default: \"focus:*:[svg]:text-accent-foreground\",\n },\n },\n});\n\nexport type ContextMenuItemProps = ContextMenuPrimitive.Item.Props &\n VariantProps<typeof contextMenuItemVariants>;\n\nconst ContextMenuItem = ({\n className,\n inset,\n size,\n variant = \"default\",\n ...props\n}: ContextMenuItemProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <ContextMenuPrimitive.Item\n className={mergeBaseUIClassName<ContextMenuPrimitive.Item.State>(\n contextMenuItemVariants({\n inset: Boolean(inset),\n size: resolvedSize,\n variant,\n }),\n className\n )}\n data-inset={inset}\n data-size={resolvedSize}\n data-slot=\"context-menu-item\"\n data-variant={variant}\n {...props}\n />\n );\n};\n\nexport { ContextMenuItem };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { useContext } from \"react\";\nimport { cn, tv } from \"tailwind-variants\";\nimport type { VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuLabelVariants = tv({\n base: \"text-muted-foreground font-medium data-[inset]:pl-8\",\n defaultVariants: {\n size: \"md\",\n },\n variants: {\n size: {\n lg: \"px-2 py-1.5 text-xs\",\n md: \"px-1.5 py-1 text-xs\",\n sm: \"px-1.5 py-1 text-xs\",\n xl: \"px-2.5 py-1.5 text-sm\",\n xs: \"px-1.5 py-1 text-[11px]\",\n },\n },\n});\n\nexport type ContextMenuLabelProps = ContextMenuPrimitive.GroupLabel.Props & {\n inset?: boolean;\n} & VariantProps<typeof contextMenuLabelVariants>;\n\nconst ContextMenuLabel = ({\n className,\n inset,\n size,\n ...props\n}: ContextMenuLabelProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <ContextMenuPrimitive.GroupLabel\n className={cn(\n contextMenuLabelVariants({ size: resolvedSize }),\n className\n )}\n data-inset={inset}\n data-size={resolvedSize}\n data-slot=\"context-menu-label\"\n {...props}\n />\n );\n};\n\nexport { ContextMenuLabel };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { useContext } from \"react\";\nimport { tv } from \"tailwind-variants\";\nimport type { VariantProps } from \"tailwind-variants\";\n\nimport { mergeBaseUIClassName } from \"../../utils/merge-base-ui-class-name\";\nimport type { InputSize } from \"../input/input\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuLinkItemVariants = tv({\n base: \"group/context-menu-link-item cursor-clickable focus:bg-accent focus:text-accent-foreground relative flex items-center outline-hidden select-none data-disabled:pointer-events-none data-disabled:cursor-not-allowed data-disabled:opacity-50 data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n defaultVariants: {\n inset: false,\n size: \"md\",\n variant: \"default\",\n },\n variants: {\n inset: {\n false: \"\",\n true: \"\",\n },\n size: {\n lg: \"gap-2 rounded-md px-2 py-1.5 text-sm [&_svg:not([class*='size-'])]:size-4\",\n md: \"gap-1.5 rounded-md px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-4\",\n sm: \"gap-1.5 rounded-[min(var(--radius-md),10px)] px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-3.5\",\n xl: \"gap-2.5 rounded-md px-2.5 py-2 text-base [&_svg:not([class*='size-'])]:size-5\",\n xs: \"gap-1 rounded-[min(var(--radius-md),8px)] px-1.5 py-1 text-xs [&_svg:not([class*='size-'])]:size-3\",\n },\n variant: {\n danger:\n \"text-danger-foreground focus:bg-danger focus:text-danger-foreground dark:focus:bg-danger/20 *:[svg]:text-danger-foreground\",\n default: \"focus:*:[svg]:text-accent-foreground\",\n },\n },\n});\n\nexport type ContextMenuLinkItemProps = ContextMenuPrimitive.LinkItem.Props &\n VariantProps<typeof contextMenuLinkItemVariants>;\n\nconst ContextMenuLinkItem = ({\n className,\n inset,\n size,\n variant = \"default\",\n ...props\n}: ContextMenuLinkItemProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <ContextMenuPrimitive.LinkItem\n className={mergeBaseUIClassName<ContextMenuPrimitive.LinkItem.State>(\n contextMenuLinkItemVariants({\n inset: Boolean(inset),\n size: resolvedSize,\n variant,\n }),\n className\n )}\n data-inset={inset}\n data-size={resolvedSize}\n data-slot=\"context-menu-link-item\"\n data-variant={variant}\n {...props}\n />\n );\n};\n\nexport { ContextMenuLinkItem };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nexport type ContextMenuRadioGroupProps = ContextMenuPrimitive.RadioGroup.Props;\n\nconst ContextMenuRadioGroup = ({ ...props }: ContextMenuRadioGroupProps) => (\n <ContextMenuPrimitive.RadioGroup\n data-slot=\"context-menu-radio-group\"\n {...props}\n />\n);\n\nexport { ContextMenuRadioGroup };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { Tick02Icon } from \"@hugeicons/core-free-icons\";\nimport { HugeiconsIcon } from \"@hugeicons/react\";\nimport { useContext } from \"react\";\nimport { cn, tv } from \"tailwind-variants\";\nimport type { VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuRadioItemVariants = tv({\n defaultVariants: {\n size: \"md\",\n },\n slots: {\n indicator:\n \"pointer-events-none absolute flex items-center justify-center [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n root: \"cursor-clickable focus:bg-accent focus:text-accent-foreground relative flex items-center rounded-md outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:cursor-not-allowed data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n },\n variants: {\n size: {\n lg: {\n indicator: \"right-2.5 size-4 [&_svg:not([class*='size-'])]:size-4\",\n root: \"gap-2 py-1.5 pr-9 pl-2 text-sm [&_svg:not([class*='size-'])]:size-4\",\n },\n md: {\n indicator: \"right-2 size-4 [&_svg:not([class*='size-'])]:size-4\",\n root: \"gap-1.5 py-1 pr-8 pl-1.5 text-sm [&_svg:not([class*='size-'])]:size-4\",\n },\n sm: {\n indicator: \"right-2 size-3.5 [&_svg:not([class*='size-'])]:size-3.5\",\n root: \"gap-1.5 rounded-[min(var(--radius-md),10px)] py-1 pr-7 pl-2 text-sm [&_svg:not([class*='size-'])]:size-3.5\",\n },\n xl: {\n indicator: \"right-3 size-5 [&_svg:not([class*='size-'])]:size-5\",\n root: \"gap-2.5 py-2 pr-10 pl-2.5 text-base [&_svg:not([class*='size-'])]:size-5\",\n },\n xs: {\n indicator: \"right-1.5 size-3 [&_svg:not([class*='size-'])]:size-3\",\n root: \"gap-1 rounded-[min(var(--radius-md),8px)] py-1 pr-6 pl-1.5 text-xs [&_svg:not([class*='size-'])]:size-3\",\n },\n },\n },\n});\n\ntype ContextMenuRadioItemVariantProps = VariantProps<\n typeof contextMenuRadioItemVariants\n>;\n\nexport type ContextMenuRadioItemProps = ContextMenuPrimitive.RadioItem.Props &\n ContextMenuRadioItemVariantProps;\n\nconst ContextMenuRadioItem = ({\n className,\n children,\n size,\n ...props\n}: ContextMenuRadioItemProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n const { indicator, root } = contextMenuRadioItemVariants({\n size: resolvedSize,\n });\n\n return (\n <ContextMenuPrimitive.RadioItem\n className={cn(root(), className)}\n data-size={resolvedSize}\n data-slot=\"context-menu-radio-item\"\n {...props}\n >\n <span className={indicator()}>\n <ContextMenuPrimitive.RadioItemIndicator>\n <HugeiconsIcon icon={Tick02Icon} strokeWidth={2} />\n </ContextMenuPrimitive.RadioItemIndicator>\n </span>\n {children}\n </ContextMenuPrimitive.RadioItem>\n );\n};\n\nexport { ContextMenuRadioItem };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { useContext } from \"react\";\nimport { cn, tv } from \"tailwind-variants\";\nimport type { VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuSeparatorVariants = tv({\n base: \"bg-border h-px\",\n defaultVariants: {\n size: \"md\",\n },\n variants: {\n size: {\n lg: \"-mx-1.5 my-1.5\",\n md: \"-mx-1 my-1\",\n sm: \"-mx-0.5 my-0.5\",\n xl: \"-mx-2 my-2\",\n xs: \"-mx-0.5 my-0.5\",\n },\n },\n});\n\nexport type ContextMenuSeparatorProps = ContextMenuPrimitive.Separator.Props;\n\nconst ContextMenuSeparator = ({\n className,\n size,\n ...props\n}: ContextMenuSeparatorProps &\n VariantProps<typeof contextMenuSeparatorVariants>) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <ContextMenuPrimitive.Separator\n className={cn(\n contextMenuSeparatorVariants({ size: resolvedSize }),\n className\n )}\n data-size={resolvedSize}\n data-slot=\"context-menu-separator\"\n {...props}\n />\n );\n};\n\nexport { ContextMenuSeparator };\n","import type { ComponentProps } from \"react\";\nimport { useContext } from \"react\";\nimport { cn, tv } from \"tailwind-variants\";\nimport type { VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuShortcutVariants = tv({\n base: \"text-muted-foreground group-focus/context-menu-item:text-accent-foreground ml-auto\",\n defaultVariants: {\n size: \"md\",\n },\n variants: {\n size: {\n lg: \"text-xs tracking-widest\",\n md: \"text-xs tracking-widest\",\n sm: \"text-xs tracking-wider\",\n xl: \"text-sm tracking-wide\",\n xs: \"text-[10px] tracking-wide\",\n },\n },\n});\n\nexport type ContextMenuShortcutProps = ComponentProps<\"span\"> &\n VariantProps<typeof contextMenuShortcutVariants>;\n\nconst ContextMenuShortcut = ({\n className,\n size,\n ...props\n}: ContextMenuShortcutProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <span\n className={cn(\n contextMenuShortcutVariants({ size: resolvedSize }),\n className\n )}\n data-size={resolvedSize}\n data-slot=\"context-menu-shortcut\"\n {...props}\n />\n );\n};\n\nexport { ContextMenuShortcut };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nexport type ContextMenuSubProps = ContextMenuPrimitive.SubmenuRoot.Props;\n\nconst ContextMenuSub = ({ ...props }: ContextMenuSubProps) => (\n <ContextMenuPrimitive.SubmenuRoot data-slot=\"context-menu-sub\" {...props} />\n);\n\nexport { ContextMenuSub };\n","import type { ComponentProps } from \"react\";\nimport { useContext } from \"react\";\nimport { cn, tv } from \"tailwind-variants\";\nimport type { VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\nimport { ContextMenuContent } from \"./context-menu-content\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuSubContentVariants = tv({\n base: \"w-auto shadow-lg\",\n defaultVariants: {\n size: \"md\",\n },\n variants: {\n size: {\n lg: \"min-w-[104px] rounded-md\",\n md: \"min-w-[96px] rounded-md\",\n sm: \"min-w-[90px] rounded-[min(var(--radius-md),10px)]\",\n xl: \"min-w-[112px] rounded-md\",\n xs: \"min-w-[84px] rounded-[min(var(--radius-md),8px)]\",\n },\n },\n});\n\nexport type ContextMenuSubContentProps = ComponentProps<\n typeof ContextMenuContent\n> &\n VariantProps<typeof contextMenuSubContentVariants>;\n\nconst ContextMenuSubContent = ({\n className,\n size,\n ...props\n}: ContextMenuSubContentProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n\n return (\n <ContextMenuContent\n className={cn(\n contextMenuSubContentVariants({ size: resolvedSize }),\n className\n )}\n data-slot=\"context-menu-sub-content\"\n side=\"right\"\n size={resolvedSize}\n {...props}\n />\n );\n};\n\nexport { ContextMenuSubContent };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { ArrowRight01Icon } from \"@hugeicons/core-free-icons\";\nimport { HugeiconsIcon } from \"@hugeicons/react\";\nimport { useContext } from \"react\";\nimport { cn, tv } from \"tailwind-variants\";\nimport type { VariantProps } from \"tailwind-variants\";\n\nimport type { InputSize } from \"../input/input\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuOverlayContext } from \"./context-menu-overlay-context\";\n\nconst contextMenuSubTriggerVariants = tv({\n defaultVariants: {\n size: \"md\",\n },\n slots: {\n icon: \"ml-auto\",\n root: \"cursor-clickable focus:bg-accent focus:text-accent-foreground data-open:bg-accent data-open:text-accent-foreground flex items-center outline-hidden select-none data-disabled:cursor-not-allowed data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0\",\n },\n variants: {\n size: {\n lg: {\n icon: \"size-4\",\n root: \"gap-2 rounded-md px-2 py-1.5 text-sm [&_svg:not([class*='size-'])]:size-4\",\n },\n md: {\n icon: \"size-4\",\n root: \"gap-1.5 rounded-md px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-4\",\n },\n sm: {\n icon: \"size-3.5\",\n root: \"gap-1.5 rounded-[min(var(--radius-md),10px)] px-1.5 py-1 text-sm [&_svg:not([class*='size-'])]:size-3.5\",\n },\n xl: {\n icon: \"size-5\",\n root: \"gap-2.5 rounded-md px-2.5 py-2 text-base [&_svg:not([class*='size-'])]:size-5\",\n },\n xs: {\n icon: \"size-3\",\n root: \"gap-1 rounded-[min(var(--radius-md),8px)] px-1.5 py-1 text-xs [&_svg:not([class*='size-'])]:size-3\",\n },\n },\n },\n});\n\nexport type ContextMenuSubTriggerProps =\n ContextMenuPrimitive.SubmenuTrigger.Props & {\n inset?: boolean;\n } & VariantProps<typeof contextMenuSubTriggerVariants>;\n\nconst ContextMenuSubTrigger = ({\n className,\n inset,\n children,\n size,\n ...props\n}: ContextMenuSubTriggerProps) => {\n const { size: rootSize } = useContext(ContextMenuContext);\n const { size: overlaySize } = useContext(ContextMenuOverlayContext);\n const resolvedSize: InputSize = size ?? overlaySize ?? rootSize ?? \"md\";\n const { icon, root } = contextMenuSubTriggerVariants({ size: resolvedSize });\n\n return (\n <ContextMenuPrimitive.SubmenuTrigger\n className={cn(root(), className)}\n data-inset={inset}\n data-size={resolvedSize}\n data-slot=\"context-menu-sub-trigger\"\n {...props}\n >\n {children}\n <HugeiconsIcon\n className={icon()}\n icon={ArrowRight01Icon}\n strokeWidth={2}\n />\n </ContextMenuPrimitive.SubmenuTrigger>\n );\n};\n\nexport { ContextMenuSubTrigger };\n","import { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { cn } from \"tailwind-variants\";\nexport type ContextMenuTriggerProps = ContextMenuPrimitive.Trigger.Props;\n\nconst ContextMenuTrigger = ({\n className,\n ...props\n}: ContextMenuTriggerProps) => (\n <ContextMenuPrimitive.Trigger\n className={cn(\"cursor-clickable select-none\", className)}\n data-slot=\"context-menu-trigger\"\n {...props}\n />\n);\n\nexport { ContextMenuTrigger };\n","\"use client\";\n\nimport { ContextMenu as ContextMenuPrimitive } from \"@base-ui/react/context-menu\";\nimport { useMemo } from \"react\";\n\nimport type { InputSize } from \"../input/input\";\nimport { useComponentSize } from \"../shared/size/size-provider\";\nimport { ContextMenuArrow } from \"./context-menu-arrow\";\nimport { ContextMenuBackdrop } from \"./context-menu-backdrop\";\nimport { ContextMenuCheckboxItem } from \"./context-menu-checkbox-item\";\nimport { ContextMenuContent } from \"./context-menu-content\";\nimport { ContextMenuContext } from \"./context-menu-context\";\nimport { ContextMenuGroup } from \"./context-menu-group\";\nimport { ContextMenuItem } from \"./context-menu-item\";\nimport { ContextMenuLabel } from \"./context-menu-label\";\nimport { ContextMenuLinkItem } from \"./context-menu-link-item\";\nimport { ContextMenuPopup } from \"./context-menu-popup\";\nimport { ContextMenuPortal } from \"./context-menu-portal\";\nimport { ContextMenuPositioner } from \"./context-menu-positioner\";\nimport { ContextMenuRadioGroup } from \"./context-menu-radio-group\";\nimport { ContextMenuRadioItem } from \"./context-menu-radio-item\";\nimport { ContextMenuSeparator } from \"./context-menu-separator\";\nimport { ContextMenuShortcut } from \"./context-menu-shortcut\";\nimport { ContextMenuSub } from \"./context-menu-sub\";\nimport { ContextMenuSubContent } from \"./context-menu-sub-content\";\nimport { ContextMenuSubTrigger } from \"./context-menu-sub-trigger\";\nimport { ContextMenuTrigger } from \"./context-menu-trigger\";\nexport type ContextMenuProps = ContextMenuPrimitive.Root.Props & {\n size?: InputSize;\n};\n\nconst ContextMenu = ({ size: providedSize, ...props }: ContextMenuProps) => {\n const size = useComponentSize(providedSize);\n const contextValue = useMemo(() => ({ size }), [size]);\n\n return (\n <ContextMenuContext.Provider value={contextValue}>\n <ContextMenuPrimitive.Root\n data-size={size}\n data-slot=\"context-menu\"\n {...props}\n />\n </ContextMenuContext.Provider>\n );\n};\n\nContextMenu.Arrow = ContextMenuArrow;\nContextMenu.Backdrop = ContextMenuBackdrop;\nContextMenu.CheckboxItem = ContextMenuCheckboxItem;\nContextMenu.Content = ContextMenuContent;\nContextMenu.Group = ContextMenuGroup;\nContextMenu.Item = ContextMenuItem;\nContextMenu.Label = ContextMenuLabel;\nContextMenu.LinkItem = ContextMenuLinkItem;\nContextMenu.Portal = ContextMenuPortal;\nContextMenu.Popup = ContextMenuPopup;\nContextMenu.Positioner = ContextMenuPositioner;\nContextMenu.RadioGroup = ContextMenuRadioGroup;\nContextMenu.RadioItem = ContextMenuRadioItem;\nContextMenu.Separator = ContextMenuSeparator;\nContextMenu.Shortcut = ContextMenuShortcut;\nContextMenu.Sub = ContextMenuSub;\nContextMenu.SubContent = ContextMenuSubContent;\nContextMenu.SubTrigger = ContextMenuSubTrigger;\nContextMenu.Trigger = ContextMenuTrigger;\n\nexport {\n ContextMenu,\n ContextMenuArrow,\n ContextMenuBackdrop,\n ContextMenuCheckboxItem,\n ContextMenuContent,\n ContextMenuGroup,\n ContextMenuItem,\n ContextMenuLabel,\n ContextMenuLinkItem,\n ContextMenuPortal,\n ContextMenuPopup,\n ContextMenuPositioner,\n ContextMenuRadioGroup,\n ContextMenuRadioItem,\n ContextMenuSeparator,\n ContextMenuShortcut,\n ContextMenuSub,\n ContextMenuSubContent,\n ContextMenuSubTrigger,\n ContextMenuTrigger,\n};\n\nexport type { ContextMenuArrowProps } from \"./context-menu-arrow\";\nexport type { ContextMenuBackdropProps } from \"./context-menu-backdrop\";\nexport type { ContextMenuCheckboxItemProps } from \"./context-menu-checkbox-item\";\nexport type { ContextMenuContentProps } from \"./context-menu-content\";\nexport type { ContextMenuGroupProps } from \"./context-menu-group\";\nexport type { ContextMenuItemProps } from \"./context-menu-item\";\nexport type { ContextMenuLabelProps } from \"./context-menu-label\";\nexport type { ContextMenuLinkItemProps } from \"./context-menu-link-item\";\nexport type { ContextMenuPopupProps } from \"./context-menu-popup\";\nexport type { ContextMenuPortalProps } from \"./context-menu-portal\";\nexport type { ContextMenuPositionerProps } from \"./context-menu-positioner\";\nexport type { ContextMenuRadioGroupProps } from \"./context-menu-radio-group\";\nexport type { ContextMenuRadioItemProps } from \"./context-menu-radio-item\";\nexport type { ContextMenuSeparatorProps } from \"./context-menu-separator\";\nexport type { ContextMenuShortcutProps } from \"./context-menu-shortcut\";\nexport type { ContextMenuSubProps } from \"./context-menu-sub\";\nexport type { ContextMenuSubContentProps } from \"./context-menu-sub-content\";\nexport type { ContextMenuSubTriggerProps } from \"./context-menu-sub-trigger\";\nexport type { ContextMenuTriggerProps } from \"./context-menu-trigger\";\n"],"mappings":"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"}
|
package/dist/ui/copy-button.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Button } from "
|
|
1
|
+
import { t as Button } from "../button-nAbTNrxA.js";
|
|
2
2
|
import { ComponentProps, ReactNode } from "react";
|
|
3
3
|
import * as react_jsx_runtime0 from "react/jsx-runtime";
|
|
4
4
|
|
|
@@ -9,7 +9,6 @@ type CopyButtonContent = ReactNode | ((status: CopyButtonStatus) => ReactNode);
|
|
|
9
9
|
type CopyButtonProps = Omit<ComponentProps<typeof Button>, "aria-pressed" | "children" | "isLoading" | "onClick"> & {
|
|
10
10
|
value: string;
|
|
11
11
|
timeout?: number;
|
|
12
|
-
useLegacyFallback?: boolean;
|
|
13
12
|
status?: CopyButtonStatus;
|
|
14
13
|
defaultStatus?: CopyButtonStatus;
|
|
15
14
|
onStatusChange?: (status: CopyButtonStatus) => void;
|
|
@@ -22,7 +21,6 @@ declare const CopyButton: ({
|
|
|
22
21
|
className,
|
|
23
22
|
value,
|
|
24
23
|
timeout,
|
|
25
|
-
useLegacyFallback,
|
|
26
24
|
status,
|
|
27
25
|
defaultStatus,
|
|
28
26
|
onStatusChange,
|