From 1fee129c337069fc41d1c46141beaaec94033af8 Mon Sep 17 00:00:00 2001 From: kamtschatka Date: Sat, 18 May 2024 12:22:50 +0200 Subject: feature(web): Improve merging of tags by simple drag and drop #144 (#154) * Improve merging of tags by simple drag and drop #144 Added drag&drop functionality Allowing sorting the tags by name, as this is more intuitive * Improve merging of tags by simple drag and drop #144 minor renamings removed some unnecessary code * Improve merging of tags by simple drag and drop #144 extracted out the drag and drop functionality to be more encapsulated and reusable * Improve merging of tags by simple drag and drop #144 improved the usage sorter to additionally compare by name if the usage is the same * Improve merging of tags by simple drag and drop #144 replaced checkboxes with toggles floating on the right --------- Co-authored-by: kamtschatka --- apps/web/components/ui/toggle.tsx | 45 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 apps/web/components/ui/toggle.tsx (limited to 'apps/web/components/ui/toggle.tsx') diff --git a/apps/web/components/ui/toggle.tsx b/apps/web/components/ui/toggle.tsx new file mode 100644 index 00000000..a5834cf9 --- /dev/null +++ b/apps/web/components/ui/toggle.tsx @@ -0,0 +1,45 @@ +"use client"; + +import type { VariantProps } from "class-variance-authority"; +import * as React from "react"; +import { cn } from "@/lib/utils"; +import * as TogglePrimitive from "@radix-ui/react-toggle"; +import { cva } from "class-variance-authority"; + +const toggleVariants = cva( + "inline-flex items-center justify-center rounded-md text-sm font-medium ring-offset-background transition-colors hover:bg-muted hover:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 data-[state=on]:bg-accent data-[state=on]:text-accent-foreground", + { + variants: { + variant: { + default: "bg-transparent", + outline: + "border border-input bg-transparent hover:bg-accent hover:text-accent-foreground", + }, + size: { + default: "h-10 px-3", + sm: "h-9 px-2.5", + lg: "h-11 px-5", + }, + }, + defaultVariants: { + variant: "default", + size: "default", + }, + }, +); + +const Toggle = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef & + VariantProps +>(({ className, variant, size, ...props }, ref) => ( + +)); + +Toggle.displayName = TogglePrimitive.Root.displayName; + +export { Toggle, toggleVariants }; -- cgit v1.2.3-70-g09d2