Skip to content

Commit

Permalink
Merge pull request Weaverse#230 from Weaverse/dev
Browse files Browse the repository at this point in the history
Add option to display color filters as swatches
  • Loading branch information
hta218 authored Dec 10, 2024
2 parents 61fc0da + 2a92ecf commit 42fc2d5
Show file tree
Hide file tree
Showing 6 changed files with 216 additions and 121 deletions.
23 changes: 8 additions & 15 deletions app/components/checkbox.tsx
Original file line number Diff line number Diff line change
@@ -1,34 +1,27 @@
import { Check } from "@phosphor-icons/react";
import * as CheckboxPrimitive from "@radix-ui/react-checkbox";
import * as React from "react";
import { cn } from "~/lib/cn";
import { IconCheck } from "./icons";

interface CheckboxProps
extends React.ComponentPropsWithoutRef<typeof CheckboxPrimitive.Root> {
label?: string;
label?: React.ReactNode;
}

const Checkbox = React.forwardRef<
export let Checkbox = React.forwardRef<
React.ElementRef<typeof CheckboxPrimitive.Root>,
CheckboxProps
>(({ className, label, ...props }, ref) => (
<div className={cn("flex items-center space-x-2.5", className)}>
<div className={cn("flex items-center gap-2.5", className)}>
<CheckboxPrimitive.Root
ref={ref}
className={cn(
"peer w-5 h-5 shrink-0 border ring-offset-background focus-visible:outline-none focus-visible:ring focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:bg-background data-[state=checked]:text-body",
)}
className="w-5 h-5 shrink-0 border border-line focus-visible:outline-none disabled:cursor-not-allowed disabled:opacity-50"
{...props}
>
<CheckboxPrimitive.Indicator
className={cn("flex items-center justify-center text-current")}
>
<IconCheck className="h-3 w-3" />
<CheckboxPrimitive.Indicator className="flex items-center justify-center text-current">
<Check weight="bold" className="h-3 w-3" />
</CheckboxPrimitive.Indicator>
</CheckboxPrimitive.Root>
{label ? <span>{label}</span> : null}
{label ? typeof label === "string" ? <span>{label}</span> : label : null}
</div>
));
Checkbox.displayName = CheckboxPrimitive.Root.displayName;

export { Checkbox };
10 changes: 8 additions & 2 deletions app/components/tooltip.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,19 +24,25 @@ export let TooltipTrigger = ({
}: TooltipTriggerProps) => <Trigger asChild={asChild} {...rest} />;

export let TooltipContent = forwardRef<HTMLDivElement, TooltipContentProps>(
({ children, className, sideOffset = 4, ...rest }, ref) => {
({ children, className, sideOffset = 4, style, ...rest }, ref) => {
return (
<Content
ref={ref}
className={cn(
"animate-slide-down-and-fade",
"z-50 px-4 rounded py-1 shadow-sm text-background bg-body opacity-0",
"z-50 px-4 rounded py-1 shadow-sm text-background bg-body",
className,
)}
align="center"
side="top"
sideOffset={sideOffset}
collisionPadding={8}
style={
{
"--slide-down-and-fade-duration": "0.3s",
...style,
} as React.CSSProperties
}
{...rest}
>
<Arrow asChild>
Expand Down
63 changes: 33 additions & 30 deletions app/modules/product-form/options.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,38 +6,41 @@ import type { ProductVariantFragmentFragment } from "storefrontapi.generated";
import { Tooltip, TooltipContent, TooltipTrigger } from "~/components/tooltip";
import { cn } from "~/lib/cn";

let variants = cva("border border-line hover:border-body cursor-pointer", {
variants: {
colorSize: {
sm: "w-8 h-8",
md: "w-10 h-10",
lg: "w-12 h-12",
},
buttonSize: {
sm: "min-w-8 h-8",
md: "min-w-10 h-10",
lg: "min-w-12 h-12",
},
imageSize: {
sm: "w-12 h-auto",
md: "w-16 h-auto",
lg: "w-20 h-auto",
},
shape: {
square: "",
circle: "rounded-full",
round: "rounded-md",
},
selected: {
true: "border-body",
false: "",
},
disabled: {
true: "diagonal",
false: "",
export let variants = cva(
"border border-line hover:border-body cursor-pointer",
{
variants: {
colorSize: {
sm: "w-8 h-8",
md: "w-10 h-10",
lg: "w-12 h-12",
},
buttonSize: {
sm: "min-w-8 h-8",
md: "min-w-10 h-10",
lg: "min-w-12 h-12",
},
imageSize: {
sm: "w-12 h-auto",
md: "w-16 h-auto",
lg: "w-20 h-auto",
},
shape: {
square: "",
circle: "rounded-full",
round: "rounded-md",
},
selected: {
true: "border-body",
false: "",
},
disabled: {
true: "diagonal",
false: "",
},
},
},
});
);

interface VariantOptionProps {
selectedOptionValue: string;
Expand Down
Loading

0 comments on commit 42fc2d5

Please sign in to comment.