Skip to content

Commit

Permalink
chore: Refactor color picker fab button component
Browse files Browse the repository at this point in the history
  • Loading branch information
fluid-design-io committed Jun 24, 2024
1 parent 1932b93 commit d85a1e3
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 42 deletions.
81 changes: 40 additions & 41 deletions apps/web/components/core/color-picker-fab-button.tsx
Original file line number Diff line number Diff line change
@@ -1,67 +1,66 @@
"use client";
'use client'

import { useColorStore } from "@/store/store";
import { BaseColorTypes, ColorMode } from "@/types/app";
import { cn } from "@ui/lib/utils";
import { motion, AnimatePresence } from "framer-motion";
import ColorPickerModal from "../palette/color-picker-modal";
import { useState } from "react";
import { colorHelper } from "@/lib/colorHelper";
import { useColorStore } from '@/context/color-store-provider'
import { colorHelper } from '@/lib/colorHelper'
import { ColorMode, ColorOptions } from '@/types/app'
import { cn } from '@ui/lib/utils'
import { AnimatePresence, motion } from 'framer-motion'
import { useState } from 'react'

const ColorPickerFabButton = ({ type }: { type: BaseColorTypes }) => {
const { baseColors, updateBaseColor } = useColorStore();
const [isOpen, setIsOpen] = useState(false);
const colorString = colorHelper.toColorMode(baseColors[type], ColorMode.HEX);
import ColorPickerModal from '../palette/color-picker-modal'

const ColorPickerFabButton = ({ type }: { type: keyof ColorOptions }) => {
const [isOpen, setIsOpen] = useState(false)
const {
setColor,
colors: { baseColors },
} = useColorStore((s) => s)
const colorString = colorHelper.toColorMode(baseColors[type], ColorMode.HEX)
const shadowColor = {
primary: "hover:shadow-primary/30",
secondary: "hover:shadow-secondary/30",
accent: "hover:shadow-accent/30",
};
accent: 'hover:shadow-accent/30',
primary: 'hover:shadow-primary/30',
secondary: 'hover:shadow-secondary/30',
}
return (
<AnimatePresence mode="sync" initial={false}>
<AnimatePresence initial={false} mode="sync">
<motion.button
className={cn(
"relative h-12 w-12 shadow-lg transition-shadow hover:shadow-xl",
shadowColor[type],
)}
onClick={() => setIsOpen(true)}
animate={{ borderRadius: 48, scale: 1 }}
className={cn('relative h-12 w-12 shadow-lg transition-shadow hover:shadow-xl', shadowColor[type])}
exit={{ borderRadius: 16, scale: 0.88 }}
initial={{ borderRadius: 16, scale: 0.88 }}
key={`color-picker-${type}`}
initial={{ scale: 0.88, borderRadius: 16 }}
animate={{ scale: 1, borderRadius: 48 }}
exit={{ scale: 0.88, borderRadius: 16 }}
whileHover={{ scale: 1.05 }}
whileTap={{ scale: 0.95 }}
layoutId={`color-picker-${type}-fab`}
onClick={() => setIsOpen(true)}
transition={{
type: "spring",
bounce: 0.2,
type: 'spring',
}}
layoutId={`color-picker-${type}-fab`}
whileHover={{ scale: 1.05 }}
whileTap={{ scale: 0.95 }}
>
<motion.span
key={`color-picker-${type}-fill`}
className={cn(
"absolute inset-0 rounded-full transition-all",
"ring-2 ring-inset",
isOpen
? "ring-transparent"
: "ring-white delay-500 duration-1000 dark:ring-white/40",
'absolute inset-0 rounded-full transition-all',
'ring-2 ring-inset',
isOpen ? 'ring-transparent' : 'ring-white delay-500 duration-1000 dark:ring-white/40'
)}
key={`color-picker-${type}-fill`}
style={{ backgroundColor: colorString }}
/>
<span className="sr-only">Click to change {type} color</span>
<motion.div layoutId={`color-picker-value-${type}-fab`} />
</motion.button>
{isOpen && (
<ColorPickerModal
onClose={() => setIsOpen(false)}
colorString={colorString}
onChange={updateBaseColor}
type={type}
onChange={(k, c) => setColor(k, colorHelper.toHex(c))}
onClose={() => setIsOpen(false)}
prefix="fab"
type={type}
/>
)}
</AnimatePresence>
);
};
)
}

export default ColorPickerFabButton;
export default ColorPickerFabButton
3 changes: 2 additions & 1 deletion apps/web/components/core/color-picker-fab.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import { BaseColorTypes } from "@/types/app";
import { cn } from "@ui/lib/utils";

import ColorPickerFabButton from "./color-picker-fab-button";

function ColorPickerFab() {
Expand All @@ -10,11 +11,11 @@ function ColorPickerFab() {
)}
>
<div
id="color-picker-fab"
className={cn(
"pointer-events-auto flex max-w-xs items-center justify-center gap-4 rounded-full border border-white/10 p-2 shadow-lg backdrop-blur-xl backdrop-brightness-105 backdrop-saturate-150 transition-opacity dark:border-white/5 dark:backdrop-brightness-95",
// "bg-background-accent/75",
)}
id="color-picker-fab"
style={{
background: `hsl(var(--background-accent) / 0.75)`,
backgroundImage: `url()`,
Expand Down

0 comments on commit d85a1e3

Please sign in to comment.