@deckai/deck-ui 0.0.18 → 0.0.20
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/components/AboutCard.cjs +5 -5
- package/dist/components/AboutCard.cjs.map +1 -1
- package/dist/components/AboutCard.js +5 -5
- package/dist/components/AboutCard.js.map +1 -1
- package/dist/components/Accordion.cjs +6 -6
- package/dist/components/Accordion.cjs.map +1 -1
- package/dist/components/Accordion.js +6 -6
- package/dist/components/Accordion.js.map +1 -1
- package/dist/components/AddWorkCard.cjs +6 -6
- package/dist/components/AddWorkCard.cjs.map +1 -1
- package/dist/components/AddWorkCard.d.cts +2 -2
- package/dist/components/AddWorkCard.d.ts +2 -2
- package/dist/components/AddWorkCard.js +6 -6
- package/dist/components/AddWorkCard.js.map +1 -1
- package/dist/components/AutocompleteInput.cjs +5 -5
- package/dist/components/AutocompleteInput.cjs.map +1 -1
- package/dist/components/AutocompleteInput.d.cts +15 -16
- package/dist/components/AutocompleteInput.d.ts +15 -16
- package/dist/components/AutocompleteInput.js +5 -5
- package/dist/components/AutocompleteInput.js.map +1 -1
- package/dist/components/Avatar.cjs +1 -1
- package/dist/components/Avatar.cjs.map +1 -1
- package/dist/components/Avatar.d.cts +1 -2
- package/dist/components/Avatar.d.ts +1 -2
- package/dist/components/Avatar.js +1 -1
- package/dist/components/Avatar.js.map +1 -1
- package/dist/components/Badge.cjs +5 -5
- package/dist/components/Badge.cjs.map +1 -1
- package/dist/components/Badge.d.cts +1 -1
- package/dist/components/Badge.d.ts +1 -1
- package/dist/components/Badge.js +5 -5
- package/dist/components/Badge.js.map +1 -1
- package/dist/components/Breadcrumbs.cjs +6 -6
- package/dist/components/Breadcrumbs.cjs.map +1 -1
- package/dist/components/Breadcrumbs.js +6 -6
- package/dist/components/Breadcrumbs.js.map +1 -1
- package/dist/components/Button.cjs +6 -6
- package/dist/components/Button.cjs.map +1 -1
- package/dist/components/Button.js +6 -6
- package/dist/components/Button.js.map +1 -1
- package/dist/components/Carousel.cjs +1 -1
- package/dist/components/Carousel.cjs.map +1 -1
- package/dist/components/Carousel.js +1 -1
- package/dist/components/Carousel.js.map +1 -1
- package/dist/components/Collapsible.cjs +7 -7
- package/dist/components/Collapsible.cjs.map +1 -1
- package/dist/components/Collapsible.js +7 -7
- package/dist/components/Collapsible.js.map +1 -1
- package/dist/components/Combobox.cjs +5 -5
- package/dist/components/Combobox.cjs.map +1 -1
- package/dist/components/Combobox.js +5 -5
- package/dist/components/Combobox.js.map +1 -1
- package/dist/components/ContactItem.cjs +6 -6
- package/dist/components/ContactItem.cjs.map +1 -1
- package/dist/components/ContactItem.js +6 -6
- package/dist/components/ContactItem.js.map +1 -1
- package/dist/components/Dropdown.cjs +5 -5
- package/dist/components/Dropdown.cjs.map +1 -1
- package/dist/components/Dropdown.js +5 -5
- package/dist/components/Dropdown.js.map +1 -1
- package/dist/components/EditButton.cjs +7 -7
- package/dist/components/EditButton.cjs.map +1 -1
- package/dist/components/EditButton.js +7 -7
- package/dist/components/EditButton.js.map +1 -1
- package/dist/components/Icon.cjs +1 -1
- package/dist/components/Icon.cjs.map +1 -1
- package/dist/components/Icon.d.cts +2 -3
- package/dist/components/Icon.d.ts +2 -3
- package/dist/components/Icon.js +1 -1
- package/dist/components/Icon.js.map +1 -1
- package/dist/components/IconRenderer.cjs +1 -1
- package/dist/components/IconRenderer.cjs.map +1 -1
- package/dist/components/IconRenderer.d.cts +2 -1
- package/dist/components/IconRenderer.d.ts +2 -1
- package/dist/components/IconRenderer.js +1 -1
- package/dist/components/IconRenderer.js.map +1 -1
- package/dist/components/Input.cjs +6 -6
- package/dist/components/Input.cjs.map +1 -1
- package/dist/components/Input.d.cts +1 -0
- package/dist/components/Input.d.ts +1 -0
- package/dist/components/Input.js +6 -6
- package/dist/components/Input.js.map +1 -1
- package/dist/components/Link.cjs +4 -4
- package/dist/components/Link.cjs.map +1 -1
- package/dist/components/Link.d.cts +1 -0
- package/dist/components/Link.d.ts +1 -0
- package/dist/components/Link.js +4 -4
- package/dist/components/Link.js.map +1 -1
- package/dist/components/Modal.cjs +2 -0
- package/dist/components/Modal.cjs.map +1 -0
- package/dist/components/Modal.d.cts +31 -0
- package/dist/components/Modal.d.ts +31 -0
- package/dist/components/Modal.js +2 -0
- package/dist/components/Modal.js.map +1 -0
- package/dist/components/MultiSelectCombobox.cjs +5 -5
- package/dist/components/MultiSelectCombobox.cjs.map +1 -1
- package/dist/components/MultiSelectCombobox.js +5 -5
- package/dist/components/MultiSelectCombobox.js.map +1 -1
- package/dist/components/Navbar.cjs +6 -6
- package/dist/components/Navbar.cjs.map +1 -1
- package/dist/components/Navbar.d.cts +2 -1
- package/dist/components/Navbar.d.ts +2 -1
- package/dist/components/Navbar.js +6 -6
- package/dist/components/Navbar.js.map +1 -1
- package/dist/components/NavbarItem.cjs +7 -1
- package/dist/components/NavbarItem.cjs.map +1 -1
- package/dist/components/NavbarItem.d.cts +6 -2
- package/dist/components/NavbarItem.d.ts +6 -2
- package/dist/components/NavbarItem.js +7 -1
- package/dist/components/NavbarItem.js.map +1 -1
- package/dist/components/Option.cjs +6 -6
- package/dist/components/Option.cjs.map +1 -1
- package/dist/components/Option.d.cts +4 -0
- package/dist/components/Option.d.ts +4 -0
- package/dist/components/Option.js +6 -6
- package/dist/components/Option.js.map +1 -1
- package/dist/components/Pressable.cjs +1 -1
- package/dist/components/Pressable.cjs.map +1 -1
- package/dist/components/Pressable.js +1 -1
- package/dist/components/Pressable.js.map +1 -1
- package/dist/components/ProfileCard.cjs +6 -6
- package/dist/components/ProfileCard.cjs.map +1 -1
- package/dist/components/ProfileCard.js +6 -6
- package/dist/components/ProfileCard.js.map +1 -1
- package/dist/components/ProgressBar.cjs +1 -1
- package/dist/components/ProgressBar.cjs.map +1 -1
- package/dist/components/ProgressBar.js +1 -1
- package/dist/components/ProgressBar.js.map +1 -1
- package/dist/components/RadioGroup.cjs +5 -5
- package/dist/components/RadioGroup.cjs.map +1 -1
- package/dist/components/RadioGroup.js +5 -5
- package/dist/components/RadioGroup.js.map +1 -1
- package/dist/components/SegmentedTabs.cjs +5 -5
- package/dist/components/SegmentedTabs.cjs.map +1 -1
- package/dist/components/SegmentedTabs.js +5 -5
- package/dist/components/SegmentedTabs.js.map +1 -1
- package/dist/components/Sidebar.cjs +1 -1
- package/dist/components/Sidebar.cjs.map +1 -1
- package/dist/components/Sidebar.js +1 -1
- package/dist/components/Sidebar.js.map +1 -1
- package/dist/components/SlideButton.cjs +1 -1
- package/dist/components/SlideButton.cjs.map +1 -1
- package/dist/components/SlideButton.js +1 -1
- package/dist/components/SlideButton.js.map +1 -1
- package/dist/components/Slider.cjs +2 -0
- package/dist/components/Slider.cjs.map +1 -0
- package/dist/components/Slider.d.cts +7 -0
- package/dist/components/Slider.d.ts +7 -0
- package/dist/components/Slider.js +2 -0
- package/dist/components/Slider.js.map +1 -0
- package/dist/components/SocialCard.cjs +5 -5
- package/dist/components/SocialCard.cjs.map +1 -1
- package/dist/components/SocialCard.d.cts +2 -2
- package/dist/components/SocialCard.d.ts +2 -2
- package/dist/components/SocialCard.js +5 -5
- package/dist/components/SocialCard.js.map +1 -1
- package/dist/components/Spinner.cjs +1 -1
- package/dist/components/Spinner.cjs.map +1 -1
- package/dist/components/Spinner.js +1 -1
- package/dist/components/Spinner.js.map +1 -1
- package/dist/components/Switch.cjs +1 -1
- package/dist/components/Switch.cjs.map +1 -1
- package/dist/components/Switch.d.cts +1 -1
- package/dist/components/Switch.d.ts +1 -1
- package/dist/components/Switch.js +1 -1
- package/dist/components/Switch.js.map +1 -1
- package/dist/components/Tabs.cjs +3 -3
- package/dist/components/Tabs.cjs.map +1 -1
- package/dist/components/Tabs.js +3 -3
- package/dist/components/Tabs.js.map +1 -1
- package/dist/components/Tag.cjs +6 -6
- package/dist/components/Tag.cjs.map +1 -1
- package/dist/components/Tag.js +6 -6
- package/dist/components/Tag.js.map +1 -1
- package/dist/components/Text.cjs +2 -2
- package/dist/components/Text.cjs.map +1 -1
- package/dist/components/Text.d.cts +1 -1
- package/dist/components/Text.d.ts +1 -1
- package/dist/components/Text.js +2 -2
- package/dist/components/Text.js.map +1 -1
- package/dist/components/TextArea.cjs +4 -4
- package/dist/components/TextArea.cjs.map +1 -1
- package/dist/components/TextArea.js +4 -4
- package/dist/components/TextArea.js.map +1 -1
- package/dist/components/Toast.cjs +6 -6
- package/dist/components/Toast.cjs.map +1 -1
- package/dist/components/Toast.js +6 -6
- package/dist/components/Toast.js.map +1 -1
- package/dist/components/Tooltip.cjs +7 -1
- package/dist/components/Tooltip.cjs.map +1 -1
- package/dist/components/Tooltip.js +7 -1
- package/dist/components/Tooltip.js.map +1 -1
- package/dist/components/VideoPlayer.cjs +8 -0
- package/dist/components/VideoPlayer.cjs.map +1 -0
- package/dist/components/VideoPlayer.d.cts +36 -0
- package/dist/components/VideoPlayer.d.ts +36 -0
- package/dist/components/VideoPlayer.js +8 -0
- package/dist/components/VideoPlayer.js.map +1 -0
- package/dist/components/WorkCard.cjs +6 -6
- package/dist/components/WorkCard.cjs.map +1 -1
- package/dist/components/WorkCard.d.cts +2 -1
- package/dist/components/WorkCard.d.ts +2 -1
- package/dist/components/WorkCard.js +6 -6
- package/dist/components/WorkCard.js.map +1 -1
- package/dist/index.cjs +7 -7
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +14 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.js +7 -7
- package/dist/index.js.map +1 -1
- package/dist/responsive-CjR1yA5N.d.cts +4 -0
- package/dist/responsive-CjR1yA5N.d.ts +4 -0
- package/dist/styles/styles.css +2 -2
- package/package.json +2 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/utils/index.ts","../../src/components/Icon.tsx","../../src/utils/tailwind.ts","../../src/components/Pressable.tsx","../../src/hooks/useMediaQuery.ts","../../src/components/Carousel.tsx"],"names":["cn","inputs","twMerge","clsx","COLOR_MAP","BREAKPOINT_MAP","processSizes","sizes","sizeArray","mediaQueries","baseSize","size","breakpoint","valueStr","value","acc","query","Icon","React","name","color","title","className","style","props","ref","IconComponent","IconMap","sizeStyles","focusRingStyles","Pressable","children","type","disabled","useIsomorphicLayoutEffect","useEffect","useMediaQuery","matches","setMatches","useState","getMatches","useCallback","mediaQuery","handleChange","Carousel","gap","scrollContainerRef","useRef","showLeftPaddle","setShowLeftPaddle","showRightPaddle","setShowRightPaddle","isHoveringStart","setIsHoveringStart","isHoveringEnd","setIsHoveringEnd","touchStart","setTouchStart","touchEnd","setTouchEnd","isMobile","checkScrollPosition","container","scrollLeft","scrollWidth","clientWidth","handleMouseMove","rect","mouseX","HOVER_THRESHOLD","handleTouchStart","handleTouchMove","handleTouchEnd","distance","itemWidth","direction","targetScroll","handleWheel","isHorizontalScroll","scrollAmount","observer","scroll","handleKeyDown","x","child"],"mappings":"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","file":"Carousel.cjs","sourcesContent":["import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n\nexport const noopFn = () => {};\n","import React, { SVGProps } from \"react\";\nimport { IconName, IconMap } from \"@deckai/icons\";\nimport { IconColors } from \"../types/tailwind\";\nimport { cn } from \"../utils\";\n\ntype Breakpoint = \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\";\ntype ResponsiveSize = number | `${Breakpoint}:${number}`;\n\nexport type IconProps = {\n name: IconName;\n /** @default 24 */\n size?: ResponsiveSize | ResponsiveSize[];\n /** @default primary */\n color?: IconColors;\n title?: string;\n className?: string;\n style?: React.CSSProperties;\n} & Omit<SVGProps<SVGSVGElement>, \"aria-hidden\" | \"aria-label\">;\n\nconst COLOR_MAP: Record<IconColors, string> = {\n primary: \"#080808\",\n secondary: \"#666666\",\n white: \"#ffffff\",\n primaryBlue: \"#089CCB\",\n disabled: \"#888888\",\n danger: \"#FF0000\"\n};\n\nconst BREAKPOINT_MAP: Record<Breakpoint, string> = {\n sm: \"640px\",\n md: \"768px\",\n lg: \"1024px\",\n xl: \"1280px\",\n \"2xl\": \"1536px\"\n};\n\nconst processSizes = (\n sizes: ResponsiveSize | ResponsiveSize[] | undefined\n): React.CSSProperties => {\n if (!sizes) return { width: \"24px\", height: \"24px\" };\n\n const sizeArray = Array.isArray(sizes) ? sizes : [sizes];\n const mediaQueries: Record<string, string> = {};\n let baseSize: string | undefined;\n\n // Process each size\n sizeArray.forEach((size) => {\n if (typeof size === \"number\") {\n baseSize = `${size}px`;\n } else {\n const [breakpoint, valueStr] = size.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n mediaQueries[`@media (min-width: ${BREAKPOINT_MAP[breakpoint]})`] =\n `${value}px`;\n }\n });\n\n // Create the style object with the correct structure\n return {\n width: baseSize || \"24px\",\n height: baseSize || \"24px\",\n ...Object.entries(mediaQueries).reduce(\n (acc, [query, size]) => ({\n ...acc,\n [query]: {\n width: size,\n height: size\n }\n }),\n {}\n )\n };\n};\n\nexport const Icon = React.forwardRef<SVGSVGElement, IconProps>(\n (\n {\n name,\n size = 24,\n color = \"primary\",\n title,\n className,\n style = {},\n ...props\n },\n ref\n ) => {\n const IconComponent = IconMap[name];\n const sizeStyles = processSizes(size);\n\n return (\n <div\n className={cn(\"flex justify-center items-center\", className)}\n style={{\n ...sizeStyles,\n [\"--icon-stroke\" as string]: COLOR_MAP[color],\n ...style\n }}\n >\n <IconComponent\n ref={ref}\n aria-hidden={!title}\n aria-label={title}\n stroke={name.includes(\"filled\") ? undefined : COLOR_MAP[color]}\n {...props}\n />\n </div>\n );\n }\n);\n\nIcon.displayName = \"Icon\";\n","import { Colors, Typography } from \"../types/tailwind\";\n\n// Generate safelist patterns for all color utilities so you can use any theme color variable in your code\nexport const generateSafelist = (colors: Colors, typography: Typography) => {\n const colorNames = Object.keys(colors) as (keyof Colors)[];\n const utilities = [\"bg\", \"text\", \"border\", \"ring\", \"divide\", \"outline\"];\n const variants = [\"hover:\", \"focus:\", \"active:\", \"disabled:\"];\n\n const safelist: string[] = [];\n\n colorNames.forEach((colorName) => {\n if (typeof colors[colorName] === \"object\") {\n // Handle nested color objects (with number keys)\n Object.keys(colors[colorName]).forEach((shade) => {\n utilities.forEach((utility) => {\n // Base utility\n safelist.push(`${utility}-${colorName}-${shade}`);\n\n // Variant utilities\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}-${shade}`);\n });\n });\n });\n } else {\n // Handle direct color values\n utilities.forEach((utility) => {\n safelist.push(`${utility}-${colorName}`);\n\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}`);\n });\n });\n }\n });\n\n // Generate typography classes\n Object.entries(typography).forEach(([family, sizes]) => {\n Object.keys(sizes).forEach((size) => {\n // Base typography classes\n safelist.push(`text-${family}-${size}`);\n\n // Add variants\n variants.forEach((variant) => {\n safelist.push(`${variant}text-${family}-${size}`);\n });\n });\n });\n\n const breakpoints = [\"sm\", \"md\", \"lg\", \"xl\", \"2xl\"];\n const typographyClasses = Object.entries(typography).flatMap(\n ([category, sizes]) =>\n Object.keys(sizes).map((size) => `text-${category}-${size}`)\n );\n\n // Generate responsive variants\n const responsiveTypographyClasses = typographyClasses.flatMap((className) =>\n breakpoints.map((breakpoint) => `${breakpoint}:${className}`)\n );\n\n return [\n ...typographyClasses,\n ...responsiveTypographyClasses\n // ... rest of your safelist\n ];\n};\n\nexport const focusRingStyles =\n \"focus-visible:outline-none focus-visible:border-2 focus-visible:border-primary-100\";\n\nexport const focusRingStylesCoerced = \"border-2 border-primary-100\";\n","import React, { ButtonHTMLAttributes } from \"react\";\nimport { focusRingStyles } from \"../utils/tailwind\";\nimport { cn } from \"../utils\";\n\nexport type PressableProps = ButtonHTMLAttributes<HTMLButtonElement>;\n\nexport const Pressable = React.forwardRef<HTMLButtonElement, PressableProps>(\n ({ children, type = \"button\", className, disabled, ...props }, ref) => (\n <button\n ref={ref}\n type={type}\n disabled={disabled}\n className={cn(\n \"appearance-none hover:opacity-80 transition-all active:scale-95\",\n focusRingStyles,\n disabled && \"opacity-50 cursor-not-allowed\",\n className\n )}\n {...props}\n >\n {children}\n </button>\n )\n);\n\nPressable.displayName = \"Pressable\";\n","import { useCallback, useEffect, useState } from \"react\";\n\nconst useIsomorphicLayoutEffect =\n typeof window !== \"undefined\" ? useEffect : () => {};\n\nexport const useMediaQuery = (query: string): boolean => {\n // Initialize with null to prevent hydration mismatch\n const [matches, setMatches] = useState<boolean | null>(null);\n\n const getMatches = useCallback((query: string): boolean => {\n if (typeof window !== \"undefined\") {\n return window.matchMedia(query).matches;\n }\n return false;\n }, []);\n\n // Update matches after mount to prevent hydration mismatch\n useIsomorphicLayoutEffect(() => {\n setMatches(getMatches(query));\n }, [query, getMatches]);\n\n useEffect(() => {\n if (typeof window !== \"undefined\") {\n const mediaQuery = window.matchMedia(query);\n\n const handleChange = () => {\n setMatches(getMatches(query));\n };\n\n mediaQuery.addEventListener(\"change\", handleChange);\n\n return () => {\n mediaQuery.removeEventListener(\"change\", handleChange);\n };\n }\n }, [query, getMatches]);\n\n // Return false during SSR, actual value after hydration\n return matches ?? false;\n};\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport * as ScrollArea from \"@radix-ui/react-scroll-area\";\nimport { Icon } from \"./Icon\";\nimport { Pressable } from \"./Pressable\";\nimport { useMediaQuery } from \"../hooks/useMediaQuery\";\n\nexport type CarouselProps = {\n children: React.ReactNode;\n /** Optional className for the root element */\n className?: string;\n /** Optional gap between items in pixels */\n gap?: number;\n};\n\nexport const Carousel = ({\n children,\n className = \"\",\n gap = 20\n}: CarouselProps) => {\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const [showLeftPaddle, setShowLeftPaddle] = useState(false);\n const [showRightPaddle, setShowRightPaddle] = useState(false);\n const [isHoveringStart, setIsHoveringStart] = useState(false);\n const [isHoveringEnd, setIsHoveringEnd] = useState(false);\n const [touchStart, setTouchStart] = useState<number | null>(null);\n const [touchEnd, setTouchEnd] = useState<number | null>(null);\n const isMobile = useMediaQuery(\"(max-width: 768px)\");\n\n const checkScrollPosition = useCallback(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const { scrollLeft, scrollWidth, clientWidth } = container;\n setShowLeftPaddle(scrollLeft > 0);\n setShowRightPaddle(Math.ceil(scrollLeft + clientWidth) < scrollWidth);\n }, []);\n\n const handleMouseMove = useCallback(\n (e: React.MouseEvent) => {\n if (isMobile) return;\n\n const container = e.currentTarget;\n const rect = container.getBoundingClientRect();\n const mouseX = e.clientX - rect.left;\n const HOVER_THRESHOLD = 300;\n\n setIsHoveringStart(mouseX < HOVER_THRESHOLD);\n setIsHoveringEnd(mouseX > rect.width - HOVER_THRESHOLD);\n },\n [isMobile]\n );\n\n // Touch handling\n const handleTouchStart = useCallback((e: React.TouchEvent) => {\n setTouchStart(e.touches[0].clientX);\n setTouchEnd(null);\n }, []);\n\n const handleTouchMove = useCallback((e: React.TouchEvent) => {\n setTouchEnd(e.touches[0].clientX);\n }, []);\n\n const handleTouchEnd = useCallback(() => {\n if (!touchStart || !touchEnd) return;\n\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const distance = touchStart - touchEnd;\n const minSwipeDistance = 50;\n\n if (Math.abs(distance) < minSwipeDistance) {\n return;\n }\n\n const itemWidth = container.clientWidth;\n const direction = distance > 0 ? 1 : -1;\n const targetScroll = container.scrollLeft + itemWidth * direction;\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, [touchStart, touchEnd]);\n\n const handleWheel = useCallback((e: WheelEvent) => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n // Check if the scroll is predominantly horizontal or if shift key is pressed\n const isHorizontalScroll = Math.abs(e.deltaX) > Math.abs(e.deltaY);\n if (!isHorizontalScroll && !e.shiftKey) return;\n\n e.preventDefault();\n\n // Determine the scroll amount based on the input type\n const scrollAmount = isHorizontalScroll ? e.deltaX : e.deltaY;\n\n // Apply smooth scrolling\n container.scrollBy({\n left: scrollAmount,\n behavior: \"smooth\"\n });\n }, []);\n\n useEffect(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const observer = new ResizeObserver(checkScrollPosition);\n observer.observe(container);\n\n container.addEventListener(\"scroll\", checkScrollPosition);\n container.addEventListener(\"wheel\", handleWheel, { passive: false });\n\n return () => {\n observer.disconnect();\n container.removeEventListener(\"scroll\", checkScrollPosition);\n container.removeEventListener(\"wheel\", handleWheel);\n };\n }, [checkScrollPosition, handleWheel]);\n\n const scroll = useCallback((direction: \"left\" | \"right\") => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const scrollAmount = container.clientWidth;\n const targetScroll =\n container.scrollLeft +\n (direction === \"left\" ? -scrollAmount : scrollAmount);\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, []);\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n if (e.key === \"ArrowLeft\") {\n scroll(\"left\");\n } else if (e.key === \"ArrowRight\") {\n scroll(\"right\");\n }\n },\n [scroll]\n );\n\n return (\n <div\n className={`relative group ${className}`}\n onKeyDown={handleKeyDown}\n onMouseMove={handleMouseMove}\n onMouseLeave={() => {\n setIsHoveringStart(false);\n setIsHoveringEnd(false);\n }}\n onTouchStart={handleTouchStart}\n onTouchMove={handleTouchMove}\n onTouchEnd={handleTouchEnd}\n role=\"region\"\n aria-label=\"Carousel\"\n >\n <ScrollArea.Root className=\"overflow-hidden\" type=\"hover\">\n <ScrollArea.Viewport\n ref={scrollContainerRef}\n className=\"w-full overflow-x-auto snap-x snap-mandatory\"\n style={{\n scrollbarWidth: \"none\",\n msOverflowStyle: \"none\",\n WebkitOverflowScrolling: \"touch\"\n }}\n >\n <div\n className=\"inline-flex\"\n style={{\n gap: `${gap}px`\n }}\n >\n {React.Children.map(children, (child) =>\n child === null ? null : (\n <div className=\"snap-start shrink-0\">{child}</div>\n )\n )}\n </div>\n </ScrollArea.Viewport>\n </ScrollArea.Root>\n\n {/* Navigation Paddles - Only show on desktop */}\n {!isMobile && (\n <>\n {showLeftPaddle && isHoveringStart && (\n <Pressable\n onClick={() => scroll(\"left\")}\n className=\"absolute left-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll left\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-left\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n\n {showRightPaddle && isHoveringEnd && (\n <Pressable\n onClick={() => scroll(\"right\")}\n className=\"absolute right-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll right\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-right\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n </>\n )}\n </div>\n );\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["../../src/utils/index.ts","../../src/utils/responsive.ts","../../src/components/Icon.tsx","../../src/utils/tailwind.ts","../../src/components/Pressable.tsx","../../src/hooks/useMediaQuery.ts","../../src/components/Carousel.tsx"],"names":["cn","inputs","twMerge","clsx","BASE_SIZES","RESPONSIVE_SIZES","getSizeKey","size","getResponsiveSize","baseSize","classes","styles","key","baseKey","responsiveClasses","s","breakpoint","valueStr","value","valueKey","COLOR_MAP","Icon","React","name","color","title","className","style","props","ref","IconComponent","IconMap","responsiveSizeClasses","responsiveSizeStyles","focusRingStyles","Pressable","children","type","disabled","useIsomorphicLayoutEffect","useEffect","useMediaQuery","query","matches","setMatches","useState","getMatches","useCallback","mediaQuery","handleChange","Carousel","gap","scrollContainerRef","useRef","showLeftPaddle","setShowLeftPaddle","showRightPaddle","setShowRightPaddle","isHoveringStart","setIsHoveringStart","isHoveringEnd","setIsHoveringEnd","touchStart","setTouchStart","touchEnd","setTouchEnd","isMobile","checkScrollPosition","container","scrollLeft","scrollWidth","clientWidth","handleMouseMove","rect","mouseX","HOVER_THRESHOLD","handleTouchStart","handleTouchMove","handleTouchEnd","distance","itemWidth","direction","targetScroll","handleWheel","isHorizontalScroll","scrollAmount","observer","scroll","handleKeyDown","C","child"],"mappings":"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","file":"Carousel.cjs","sourcesContent":["import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n\nexport const noopFn = () => {};\n","export type Breakpoint = \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\";\nexport type ResponsiveSize = number | `${Breakpoint}:${number}`;\n\ntype SizeKey =\n | \"12\"\n | \"16\"\n | \"18\"\n | \"20\"\n | \"24\"\n | \"32\"\n | \"36\"\n | \"40\"\n | \"42\"\n | \"48\"\n | \"64\"\n | \"72\";\n\n// These constants help Tailwind identify the classes during compilation\nconst BASE_SIZES: Record<SizeKey, string> = {\n \"12\": \"h-[12px] w-[12px]\",\n \"16\": \"h-[16px] w-[16px]\",\n \"18\": \"h-[18px] w-[18px]\",\n \"20\": \"h-[20px] w-[20px]\",\n \"24\": \"h-[24px] w-[24px]\",\n \"32\": \"h-[32px] w-[32px]\",\n \"36\": \"h-[36px] w-[36px]\",\n \"40\": \"h-[40px] w-[40px]\",\n \"42\": \"h-[42px] w-[42px]\",\n \"48\": \"h-[48px] w-[48px]\",\n \"64\": \"h-[64px] w-[64px]\",\n \"72\": \"h-[72px] w-[72px]\"\n};\n\nconst RESPONSIVE_SIZES: Record<Breakpoint, Record<SizeKey, string>> = {\n sm: {\n \"12\": \"sm:h-[12px] sm:w-[12px]\",\n \"16\": \"sm:h-[16px] sm:w-[16px]\",\n \"18\": \"sm:h-[18px] sm:w-[18px]\",\n \"20\": \"sm:h-[20px] sm:w-[20px]\",\n \"24\": \"sm:h-[24px] sm:w-[24px]\",\n \"32\": \"sm:h-[32px] sm:w-[32px]\",\n \"36\": \"sm:h-[36px] sm:w-[36px]\",\n \"40\": \"sm:h-[40px] sm:w-[40px]\",\n \"42\": \"sm:h-[42px] sm:w-[42px]\",\n \"48\": \"sm:h-[48px] sm:w-[48px]\",\n \"64\": \"sm:h-[64px] sm:w-[64px]\",\n \"72\": \"sm:h-[72px] sm:w-[72px]\"\n },\n md: {\n \"12\": \"md:h-[12px] md:w-[12px]\",\n \"16\": \"md:h-[16px] md:w-[16px]\",\n \"18\": \"md:h-[18px] md:w-[18px]\",\n \"20\": \"md:h-[20px] md:w-[20px]\",\n \"24\": \"md:h-[24px] md:w-[24px]\",\n \"32\": \"md:h-[32px] md:w-[32px]\",\n \"36\": \"md:h-[36px] md:w-[36px]\",\n \"40\": \"md:h-[40px] md:w-[40px]\",\n \"42\": \"md:h-[42px] md:w-[42px]\",\n \"48\": \"md:h-[48px] md:w-[48px]\",\n \"64\": \"md:h-[64px] md:w-[64px]\",\n \"72\": \"md:h-[72px] md:w-[72px]\"\n },\n lg: {\n \"12\": \"lg:h-[12px] lg:w-[12px]\",\n \"16\": \"lg:h-[16px] lg:w-[16px]\",\n \"18\": \"lg:h-[18px] lg:w-[18px]\",\n \"20\": \"lg:h-[20px] lg:w-[20px]\",\n \"24\": \"lg:h-[24px] lg:w-[24px]\",\n \"32\": \"lg:h-[32px] lg:w-[32px]\",\n \"36\": \"lg:h-[36px] lg:w-[36px]\",\n \"40\": \"lg:h-[40px] lg:w-[40px]\",\n \"42\": \"lg:h-[42px] lg:w-[42px]\",\n \"48\": \"lg:h-[48px] lg:w-[48px]\",\n \"64\": \"lg:h-[64px] lg:w-[64px]\",\n \"72\": \"lg:h-[72px] lg:w-[72px]\"\n },\n xl: {\n \"12\": \"xl:h-[12px] xl:w-[12px]\",\n \"16\": \"xl:h-[16px] xl:w-[16px]\",\n \"18\": \"xl:h-[18px] xl:w-[18px]\",\n \"20\": \"xl:h-[20px] xl:w-[20px]\",\n \"24\": \"xl:h-[24px] xl:w-[24px]\",\n \"32\": \"xl:h-[32px] xl:w-[32px]\",\n \"36\": \"xl:h-[36px] xl:w-[36px]\",\n \"40\": \"xl:h-[40px] xl:w-[40px]\",\n \"42\": \"xl:h-[42px] xl:w-[42px]\",\n \"48\": \"xl:h-[48px] xl:w-[48px]\",\n \"64\": \"xl:h-[64px] xl:w-[64px]\",\n \"72\": \"xl:h-[72px] xl:w-[72px]\"\n },\n \"2xl\": {\n \"12\": \"2xl:h-[12px] 2xl:w-[12px]\",\n \"16\": \"2xl:h-[16px] 2xl:w-[16px]\",\n \"18\": \"2xl:h-[18px] 2xl:w-[18px]\",\n \"20\": \"2xl:h-[20px] 2xl:w-[20px]\",\n \"24\": \"2xl:h-[24px] 2xl:w-[24px]\",\n \"32\": \"2xl:h-[32px] 2xl:w-[32px]\",\n \"36\": \"2xl:h-[36px] 2xl:w-[36px]\",\n \"40\": \"2xl:h-[40px] 2xl:w-[40px]\",\n \"42\": \"2xl:h-[42px] 2xl:w-[42px]\",\n \"48\": \"2xl:h-[48px] 2xl:w-[48px]\",\n \"64\": \"2xl:h-[64px] 2xl:w-[64px]\",\n \"72\": \"2xl:h-[72px] 2xl:w-[72px]\"\n }\n};\n\nconst getSizeKey = (size: number): SizeKey | undefined => {\n return String(size) as SizeKey;\n};\n\nexport const getResponsiveSize = (\n size: ResponsiveSize | ResponsiveSize[] | undefined,\n baseSize: number = 24\n): {\n responsiveSizeClasses: string;\n responsiveSizeStyles: Record<string, string>;\n} => {\n const classes: string[] = [];\n const styles: Record<string, string> = {};\n\n // If no size provided, use baseSize\n if (size === undefined) {\n const key = getSizeKey(baseSize);\n if (key) {\n classes.push(BASE_SIZES[key]);\n } else {\n styles.height = `${baseSize}px`;\n styles.width = `${baseSize}px`;\n }\n }\n\n // If size is a number, use that directly\n if (typeof size === \"number\") {\n const key = getSizeKey(size);\n if (key) {\n classes.push(BASE_SIZES[key]);\n } else {\n styles.height = `${size}px`;\n styles.width = `${size}px`;\n }\n }\n\n // If array of responsive sizes, generate responsive classes\n if (Array.isArray(size)) {\n const baseKey = getSizeKey(baseSize);\n const responsiveClasses = [\n (baseKey && BASE_SIZES[baseKey]) || `h-[${baseSize}px] w-[${baseSize}px]`\n ];\n\n size.forEach((s) => {\n if (typeof s === \"string\") {\n const [breakpoint, valueStr] = s.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n const key = getSizeKey(value);\n classes.push(\n (key && RESPONSIVE_SIZES[breakpoint]?.[key]) ||\n `${breakpoint}:h-[${value}px] ${breakpoint}:w-[${value}px]`\n );\n }\n });\n\n classes.push(...responsiveClasses);\n }\n\n if (typeof size === \"string\") {\n const [breakpoint, valueStr] = size.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n const valueKey = getSizeKey(value);\n classes.push(\n (valueKey && RESPONSIVE_SIZES[breakpoint]?.[valueKey]) ||\n `${breakpoint}:h-[${value}px] ${breakpoint}:w-[${value}px]`\n );\n }\n\n return {\n responsiveSizeClasses: classes.join(\" \"),\n responsiveSizeStyles: styles\n };\n};\n","import { IconMap, IconName } from \"@deckai/icons\";\nimport React, { SVGProps } from \"react\";\nimport { IconColors } from \"../types/tailwind\";\nimport { cn } from \"../utils\";\nimport { ResponsiveSize, getResponsiveSize } from \"../utils/responsive\";\n\nexport type IconProps = {\n name: IconName;\n /** @default 24 */\n size?: ResponsiveSize | ResponsiveSize[];\n /** @default primary */\n color?: IconColors;\n title?: string;\n className?: string;\n style?: React.CSSProperties;\n} & Omit<SVGProps<SVGSVGElement>, \"aria-hidden\" | \"aria-label\">;\n\nconst COLOR_MAP: Record<IconColors, string> = {\n primary: \"#080808\",\n secondary: \"#666666\",\n white: \"#ffffff\",\n primaryBlue: \"#089CCB\",\n disabled: \"#888888\",\n danger: \"#FF0000\"\n};\n\nexport const Icon = React.forwardRef<SVGSVGElement, IconProps>(\n (\n {\n name,\n size = 24,\n color = \"primary\",\n title,\n className,\n style = {},\n ...props\n },\n ref\n ) => {\n const IconComponent = IconMap[name];\n const { responsiveSizeClasses, responsiveSizeStyles } = getResponsiveSize(\n size,\n 24\n );\n\n return (\n <div\n className={cn(\n \"flex justify-center items-center\",\n responsiveSizeClasses,\n className\n )}\n style={{\n [\"--icon-stroke\" as string]: COLOR_MAP[color],\n ...responsiveSizeStyles,\n ...style\n }}\n >\n <IconComponent\n ref={ref}\n aria-hidden={!title}\n aria-label={title}\n stroke={name.includes(\"filled\") ? undefined : COLOR_MAP[color]}\n {...props}\n />\n </div>\n );\n }\n);\n\nIcon.displayName = \"Icon\";\n","import { Colors, Typography } from \"../types/tailwind\";\n\n// Generate safelist patterns for all color utilities so you can use any theme color variable in your code\nexport const generateSafelist = (colors: Colors, typography: Typography) => {\n const colorNames = Object.keys(colors) as (keyof Colors)[];\n const utilities = [\"bg\", \"text\", \"border\", \"ring\", \"divide\", \"outline\"];\n const variants = [\"hover:\", \"focus:\", \"active:\", \"disabled:\"];\n const breakpoints = [\"sm\", \"md\", \"lg\", \"xl\", \"2xl\"];\n const sizes = [\"24\", \"42\", \"48\", \"64\", \"72\"]; // Add all the sizes you need\n\n const safelist: (string | { pattern: RegExp; variants: string[] })[] = [];\n\n colorNames.forEach((colorName) => {\n if (typeof colors[colorName] === \"object\") {\n // Handle nested color objects (with number keys)\n Object.keys(colors[colorName]).forEach((shade) => {\n utilities.forEach((utility) => {\n // Base utility\n safelist.push(`${utility}-${colorName}-${shade}`);\n\n // Variant utilities\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}-${shade}`);\n });\n });\n });\n } else {\n // Handle direct color values\n utilities.forEach((utility) => {\n safelist.push(`${utility}-${colorName}`);\n\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}`);\n });\n });\n }\n });\n\n // Generate typography classes\n Object.entries(typography).forEach(([family, sizes]) => {\n Object.keys(sizes).forEach((size) => {\n // Base typography classes\n safelist.push(`text-${family}-${size}`);\n\n // Add variants\n variants.forEach((variant) => {\n safelist.push(`${variant}text-${family}-${size}`);\n });\n });\n });\n\n const typographyClasses = Object.entries(typography).flatMap(\n ([category, sizes]) =>\n Object.keys(sizes).map((size) => `text-${category}-${size}`)\n );\n\n // Generate responsive variants\n const responsiveTypographyClasses = typographyClasses.flatMap((className) =>\n breakpoints.map((breakpoint) => `${breakpoint}:${className}`)\n );\n\n // Generate size classes with responsive variants\n const sizeClasses = sizes.flatMap((size) => [\n `h-[${size}px]`,\n `w-[${size}px]`,\n ...breakpoints.flatMap((bp) => [\n `${bp}:h-[${size}px]`,\n `${bp}:w-[${size}px]`\n ])\n ]);\n\n return [...typographyClasses, ...responsiveTypographyClasses, ...sizeClasses];\n};\n\nexport const focusRingStyles =\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-100\";\nexport const focusRingWithinStyles =\n \"focus-within:outline-none focus-within:ring-2 focus-within:ring-primary-100\";\nexport const focusRingStylesCoerced = \"ring-2 ring-primary-100\";\n","import React, { ButtonHTMLAttributes } from \"react\";\nimport { focusRingStyles } from \"../utils/tailwind\";\nimport { cn } from \"../utils\";\n\nexport type PressableProps = ButtonHTMLAttributes<HTMLButtonElement>;\n\nexport const Pressable = React.forwardRef<HTMLButtonElement, PressableProps>(\n ({ children, type = \"button\", className, disabled, ...props }, ref) => (\n <button\n ref={ref}\n type={type}\n disabled={disabled}\n className={cn(\n \"appearance-none hover:opacity-80 transition-all active:scale-95\",\n focusRingStyles,\n disabled && \"opacity-50 cursor-not-allowed\",\n className\n )}\n {...props}\n >\n {children}\n </button>\n )\n);\n\nPressable.displayName = \"Pressable\";\n","import { useCallback, useEffect, useState } from \"react\";\n\nconst useIsomorphicLayoutEffect =\n typeof window !== \"undefined\" ? useEffect : () => {};\n\nexport const useMediaQuery = (query: string): boolean => {\n // Initialize with null to prevent hydration mismatch\n const [matches, setMatches] = useState<boolean | null>(null);\n\n const getMatches = useCallback((query: string): boolean => {\n if (typeof window !== \"undefined\") {\n return window.matchMedia(query).matches;\n }\n return false;\n }, []);\n\n // Update matches after mount to prevent hydration mismatch\n useIsomorphicLayoutEffect(() => {\n setMatches(getMatches(query));\n }, [query, getMatches]);\n\n useEffect(() => {\n if (typeof window !== \"undefined\") {\n const mediaQuery = window.matchMedia(query);\n\n const handleChange = () => {\n setMatches(getMatches(query));\n };\n\n mediaQuery.addEventListener(\"change\", handleChange);\n\n return () => {\n mediaQuery.removeEventListener(\"change\", handleChange);\n };\n }\n }, [query, getMatches]);\n\n // Return false during SSR, actual value after hydration\n return matches ?? false;\n};\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport * as ScrollArea from \"@radix-ui/react-scroll-area\";\nimport { Icon } from \"./Icon\";\nimport { Pressable } from \"./Pressable\";\nimport { useMediaQuery } from \"../hooks/useMediaQuery\";\n\nexport type CarouselProps = {\n children: React.ReactNode;\n /** Optional className for the root element */\n className?: string;\n /** Optional gap between items in pixels */\n gap?: number;\n};\n\nexport const Carousel = ({\n children,\n className = \"\",\n gap = 20\n}: CarouselProps) => {\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const [showLeftPaddle, setShowLeftPaddle] = useState(false);\n const [showRightPaddle, setShowRightPaddle] = useState(false);\n const [isHoveringStart, setIsHoveringStart] = useState(false);\n const [isHoveringEnd, setIsHoveringEnd] = useState(false);\n const [touchStart, setTouchStart] = useState<number | null>(null);\n const [touchEnd, setTouchEnd] = useState<number | null>(null);\n const isMobile = useMediaQuery(\"(max-width: 768px)\");\n\n const checkScrollPosition = useCallback(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const { scrollLeft, scrollWidth, clientWidth } = container;\n setShowLeftPaddle(scrollLeft > 0);\n setShowRightPaddle(Math.ceil(scrollLeft + clientWidth) < scrollWidth);\n }, []);\n\n const handleMouseMove = useCallback(\n (e: React.MouseEvent) => {\n if (isMobile) return;\n\n const container = e.currentTarget;\n const rect = container.getBoundingClientRect();\n const mouseX = e.clientX - rect.left;\n const HOVER_THRESHOLD = 300;\n\n setIsHoveringStart(mouseX < HOVER_THRESHOLD);\n setIsHoveringEnd(mouseX > rect.width - HOVER_THRESHOLD);\n },\n [isMobile]\n );\n\n // Touch handling\n const handleTouchStart = useCallback((e: React.TouchEvent) => {\n setTouchStart(e.touches[0].clientX);\n setTouchEnd(null);\n }, []);\n\n const handleTouchMove = useCallback((e: React.TouchEvent) => {\n setTouchEnd(e.touches[0].clientX);\n }, []);\n\n const handleTouchEnd = useCallback(() => {\n if (!touchStart || !touchEnd) return;\n\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const distance = touchStart - touchEnd;\n const minSwipeDistance = 50;\n\n if (Math.abs(distance) < minSwipeDistance) {\n return;\n }\n\n const itemWidth = container.clientWidth;\n const direction = distance > 0 ? 1 : -1;\n const targetScroll = container.scrollLeft + itemWidth * direction;\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, [touchStart, touchEnd]);\n\n const handleWheel = useCallback((e: WheelEvent) => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n // Check if the scroll is predominantly horizontal or if shift key is pressed\n const isHorizontalScroll = Math.abs(e.deltaX) > Math.abs(e.deltaY);\n if (!isHorizontalScroll && !e.shiftKey) return;\n\n e.preventDefault();\n\n // Determine the scroll amount based on the input type\n const scrollAmount = isHorizontalScroll ? e.deltaX : e.deltaY;\n\n // Apply smooth scrolling\n container.scrollBy({\n left: scrollAmount,\n behavior: \"smooth\"\n });\n }, []);\n\n useEffect(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const observer = new ResizeObserver(checkScrollPosition);\n observer.observe(container);\n\n container.addEventListener(\"scroll\", checkScrollPosition);\n container.addEventListener(\"wheel\", handleWheel, { passive: false });\n\n return () => {\n observer.disconnect();\n container.removeEventListener(\"scroll\", checkScrollPosition);\n container.removeEventListener(\"wheel\", handleWheel);\n };\n }, [checkScrollPosition, handleWheel]);\n\n const scroll = useCallback((direction: \"left\" | \"right\") => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const scrollAmount = container.clientWidth;\n const targetScroll =\n container.scrollLeft +\n (direction === \"left\" ? -scrollAmount : scrollAmount);\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, []);\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n if (e.key === \"ArrowLeft\") {\n scroll(\"left\");\n } else if (e.key === \"ArrowRight\") {\n scroll(\"right\");\n }\n },\n [scroll]\n );\n\n return (\n <div\n className={`relative group ${className}`}\n onKeyDown={handleKeyDown}\n onMouseMove={handleMouseMove}\n onMouseLeave={() => {\n setIsHoveringStart(false);\n setIsHoveringEnd(false);\n }}\n onTouchStart={handleTouchStart}\n onTouchMove={handleTouchMove}\n onTouchEnd={handleTouchEnd}\n role=\"region\"\n aria-label=\"Carousel\"\n >\n <ScrollArea.Root className=\"overflow-hidden\" type=\"hover\">\n <ScrollArea.Viewport\n ref={scrollContainerRef}\n className=\"w-full overflow-x-auto snap-x snap-mandatory\"\n style={{\n scrollbarWidth: \"none\",\n msOverflowStyle: \"none\",\n WebkitOverflowScrolling: \"touch\"\n }}\n >\n <div\n className=\"inline-flex\"\n style={{\n gap: `${gap}px`\n }}\n >\n {React.Children.map(children, (child) =>\n child === null ? null : (\n <div className=\"snap-start shrink-0\">{child}</div>\n )\n )}\n </div>\n </ScrollArea.Viewport>\n </ScrollArea.Root>\n\n {/* Navigation Paddles - Only show on desktop */}\n {!isMobile && (\n <>\n {showLeftPaddle && isHoveringStart && (\n <Pressable\n onClick={() => scroll(\"left\")}\n className=\"absolute left-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll left\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-left\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n\n {showRightPaddle && isHoveringEnd && (\n <Pressable\n onClick={() => scroll(\"right\")}\n className=\"absolute right-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll right\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-right\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n </>\n )}\n </div>\n );\n};\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import
|
|
1
|
+
import p,{useRef,useState,useCallback,useEffect}from'react';import*as C from'@radix-ui/react-scroll-area';import {IconMap}from'@deckai/icons';import {clsx}from'clsx';import {twMerge}from'tailwind-merge';function b(...t){return twMerge(clsx(t))}var T={12:"h-[12px] w-[12px]",16:"h-[16px] w-[16px]",18:"h-[18px] w-[18px]",20:"h-[20px] w-[20px]",24:"h-[24px] w-[24px]",32:"h-[32px] w-[32px]",36:"h-[36px] w-[36px]",40:"h-[40px] w-[40px]",42:"h-[42px] w-[42px]",48:"h-[48px] w-[48px]",64:"h-[64px] w-[64px]",72:"h-[72px] w-[72px]"},N={sm:{12:"sm:h-[12px] sm:w-[12px]",16:"sm:h-[16px] sm:w-[16px]",18:"sm:h-[18px] sm:w-[18px]",20:"sm:h-[20px] sm:w-[20px]",24:"sm:h-[24px] sm:w-[24px]",32:"sm:h-[32px] sm:w-[32px]",36:"sm:h-[36px] sm:w-[36px]",40:"sm:h-[40px] sm:w-[40px]",42:"sm:h-[42px] sm:w-[42px]",48:"sm:h-[48px] sm:w-[48px]",64:"sm:h-[64px] sm:w-[64px]",72:"sm:h-[72px] sm:w-[72px]"},md:{12:"md:h-[12px] md:w-[12px]",16:"md:h-[16px] md:w-[16px]",18:"md:h-[18px] md:w-[18px]",20:"md:h-[20px] md:w-[20px]",24:"md:h-[24px] md:w-[24px]",32:"md:h-[32px] md:w-[32px]",36:"md:h-[36px] md:w-[36px]",40:"md:h-[40px] md:w-[40px]",42:"md:h-[42px] md:w-[42px]",48:"md:h-[48px] md:w-[48px]",64:"md:h-[64px] md:w-[64px]",72:"md:h-[72px] md:w-[72px]"},lg:{12:"lg:h-[12px] lg:w-[12px]",16:"lg:h-[16px] lg:w-[16px]",18:"lg:h-[18px] lg:w-[18px]",20:"lg:h-[20px] lg:w-[20px]",24:"lg:h-[24px] lg:w-[24px]",32:"lg:h-[32px] lg:w-[32px]",36:"lg:h-[36px] lg:w-[36px]",40:"lg:h-[40px] lg:w-[40px]",42:"lg:h-[42px] lg:w-[42px]",48:"lg:h-[48px] lg:w-[48px]",64:"lg:h-[64px] lg:w-[64px]",72:"lg:h-[72px] lg:w-[72px]"},xl:{12:"xl:h-[12px] xl:w-[12px]",16:"xl:h-[16px] xl:w-[16px]",18:"xl:h-[18px] xl:w-[18px]",20:"xl:h-[20px] xl:w-[20px]",24:"xl:h-[24px] xl:w-[24px]",32:"xl:h-[32px] xl:w-[32px]",36:"xl:h-[36px] xl:w-[36px]",40:"xl:h-[40px] xl:w-[40px]",42:"xl:h-[42px] xl:w-[42px]",48:"xl:h-[48px] xl:w-[48px]",64:"xl:h-[64px] xl:w-[64px]",72:"xl:h-[72px] xl:w-[72px]"},"2xl":{12:"2xl:h-[12px] 2xl:w-[12px]",16:"2xl:h-[16px] 2xl:w-[16px]",18:"2xl:h-[18px] 2xl:w-[18px]",20:"2xl:h-[20px] 2xl:w-[20px]",24:"2xl:h-[24px] 2xl:w-[24px]",32:"2xl:h-[32px] 2xl:w-[32px]",36:"2xl:h-[36px] 2xl:w-[36px]",40:"2xl:h-[40px] 2xl:w-[40px]",42:"2xl:h-[42px] 2xl:w-[42px]",48:"2xl:h-[48px] 2xl:w-[48px]",64:"2xl:h-[64px] 2xl:w-[64px]",72:"2xl:h-[72px] 2xl:w-[72px]"}},v=t=>String(t),O=(t,l=24)=>{let r=[],s={};if(t===undefined){let o=v(l);o?r.push(T[o]):(s.height=`${l}px`,s.width=`${l}px`);}if(typeof t=="number"){let o=v(t);o?r.push(T[o]):(s.height=`${t}px`,s.width=`${t}px`);}if(Array.isArray(t)){let o=v(l),i=[o&&T[o]||`h-[${l}px] w-[${l}px]`];t.forEach(x=>{if(typeof x=="string"){let[c,w]=x.split(":"),m=parseInt(w,10),d=v(m);r.push(d&&N[c]?.[d]||`${c}:h-[${m}px] ${c}:w-[${m}px]`);}}),r.push(...i);}if(typeof t=="string"){let[o,i]=t.split(":"),x=parseInt(i,10),c=v(x);r.push(c&&N[o]?.[c]||`${o}:h-[${x}px] ${o}:w-[${x}px]`);}return {responsiveSizeClasses:r.join(" "),responsiveSizeStyles:s}};var B={primary:"#080808",secondary:"#666666",white:"#ffffff",primaryBlue:"#089CCB",disabled:"#888888",danger:"#FF0000"},$=p.forwardRef(({name:t,size:l=24,color:r="primary",title:s,className:o,style:i={},...x},c)=>{let w=IconMap[t],{responsiveSizeClasses:m,responsiveSizeStyles:d}=O(l,24);return p.createElement("div",{className:b("flex justify-center items-center",m,o),style:{"--icon-stroke":B[r],...d,...i}},p.createElement(w,{ref:c,"aria-hidden":!s,"aria-label":s,stroke:t.includes("filled")?undefined:B[r],...x}))});$.displayName="Icon";var H="focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-100";var E=p.forwardRef(({children:t,type:l="button",className:r,disabled:s,...o},i)=>p.createElement("button",{ref:i,type:l,disabled:s,className:b("appearance-none hover:opacity-80 transition-all active:scale-95",H,s&&"opacity-50 cursor-not-allowed",r),...o},t));E.displayName="Pressable";var q=typeof window<"u"?useEffect:()=>{},V=t=>{let[l,r]=useState(null),s=useCallback(o=>typeof window<"u"?window.matchMedia(o).matches:false,[]);return q(()=>{r(s(t));},[t,s]),useEffect(()=>{if(typeof window<"u"){let o=window.matchMedia(t),i=()=>{r(s(t));};return o.addEventListener("change",i),()=>{o.removeEventListener("change",i);}}},[t,s]),l??false};var Me=({children:t,className:l="",gap:r=20})=>{let s=useRef(null),[o,i]=useState(false),[x,c]=useState(false),[w,m]=useState(false),[d,I]=useState(false),[M,j]=useState(null),[k,A]=useState(null),R=V("(max-width: 768px)"),y=useCallback(()=>{let e=s.current;if(!e)return;let{scrollLeft:n,scrollWidth:a,clientWidth:h}=e;i(n>0),c(Math.ceil(n+h)<a);},[]),W=useCallback(e=>{if(R)return;let a=e.currentTarget.getBoundingClientRect(),h=e.clientX-a.left,S=300;m(h<S),I(h>a.width-S);},[R]),D=useCallback(e=>{j(e.touches[0].clientX),A(null);},[]),G=useCallback(e=>{A(e.touches[0].clientX);},[]),X=useCallback(()=>{if(!M||!k)return;let e=s.current;if(!e)return;let n=M-k;if(Math.abs(n)<50)return;let h=e.clientWidth,S=n>0?1:-1,F=e.scrollLeft+h*S;e.scrollTo({left:F,behavior:"smooth"});},[M,k]),P=useCallback(e=>{let n=s.current;if(!n)return;let a=Math.abs(e.deltaX)>Math.abs(e.deltaY);if(!a&&!e.shiftKey)return;e.preventDefault();let h=a?e.deltaX:e.deltaY;n.scrollBy({left:h,behavior:"smooth"});},[]);useEffect(()=>{let e=s.current;if(!e)return;let n=new ResizeObserver(y);return n.observe(e),e.addEventListener("scroll",y),e.addEventListener("wheel",P,{passive:false}),()=>{n.disconnect(),e.removeEventListener("scroll",y),e.removeEventListener("wheel",P);}},[y,P]);let g=useCallback(e=>{let n=s.current;if(!n)return;let a=n.clientWidth,h=n.scrollLeft+(e==="left"?-a:a);n.scrollTo({left:h,behavior:"smooth"});},[]),_=useCallback(e=>{e.key==="ArrowLeft"?g("left"):e.key==="ArrowRight"&&g("right");},[g]);return p.createElement("div",{className:`relative group ${l}`,onKeyDown:_,onMouseMove:W,onMouseLeave:()=>{m(false),I(false);},onTouchStart:D,onTouchMove:G,onTouchEnd:X,role:"region","aria-label":"Carousel"},p.createElement(C.Root,{className:"overflow-hidden",type:"hover"},p.createElement(C.Viewport,{ref:s,className:"w-full overflow-x-auto snap-x snap-mandatory",style:{scrollbarWidth:"none",msOverflowStyle:"none",WebkitOverflowScrolling:"touch"}},p.createElement("div",{className:"inline-flex",style:{gap:`${r}px`}},p.Children.map(t,e=>e===null?null:p.createElement("div",{className:"snap-start shrink-0"},e))))),!R&&p.createElement(p.Fragment,null,o&&w&&p.createElement(E,{onClick:()=>g("left"),className:"absolute left-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200","aria-label":"Scroll left"},p.createElement("div",{className:"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm"},p.createElement($,{name:"arrow-left",size:24,color:"white"}))),x&&d&&p.createElement(E,{onClick:()=>g("right"),className:"absolute right-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200","aria-label":"Scroll right"},p.createElement("div",{className:"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm"},p.createElement($,{name:"arrow-right",size:24,color:"white"})))))};export{Me as Carousel};//# sourceMappingURL=Carousel.js.map
|
|
2
2
|
//# sourceMappingURL=Carousel.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/utils/index.ts","../../src/components/Icon.tsx","../../src/utils/tailwind.ts","../../src/components/Pressable.tsx","../../src/hooks/useMediaQuery.ts","../../src/components/Carousel.tsx"],"names":["cn","inputs","twMerge","clsx","COLOR_MAP","BREAKPOINT_MAP","processSizes","sizes","sizeArray","mediaQueries","baseSize","size","breakpoint","valueStr","value","acc","query","Icon","React","name","color","title","className","style","props","ref","IconComponent","IconMap","sizeStyles","focusRingStyles","Pressable","children","type","disabled","useIsomorphicLayoutEffect","useEffect","useMediaQuery","matches","setMatches","useState","getMatches","useCallback","mediaQuery","handleChange","Carousel","gap","scrollContainerRef","useRef","showLeftPaddle","setShowLeftPaddle","showRightPaddle","setShowRightPaddle","isHoveringStart","setIsHoveringStart","isHoveringEnd","setIsHoveringEnd","touchStart","setTouchStart","touchEnd","setTouchEnd","isMobile","checkScrollPosition","container","scrollLeft","scrollWidth","clientWidth","handleMouseMove","rect","mouseX","HOVER_THRESHOLD","handleTouchStart","handleTouchMove","handleTouchEnd","distance","itemWidth","direction","targetScroll","handleWheel","isHorizontalScroll","scrollAmount","observer","scroll","handleKeyDown","child"],"mappings":"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","file":"Carousel.js","sourcesContent":["import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n\nexport const noopFn = () => {};\n","import React, { SVGProps } from \"react\";\nimport { IconName, IconMap } from \"@deckai/icons\";\nimport { IconColors } from \"../types/tailwind\";\nimport { cn } from \"../utils\";\n\ntype Breakpoint = \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\";\ntype ResponsiveSize = number | `${Breakpoint}:${number}`;\n\nexport type IconProps = {\n name: IconName;\n /** @default 24 */\n size?: ResponsiveSize | ResponsiveSize[];\n /** @default primary */\n color?: IconColors;\n title?: string;\n className?: string;\n style?: React.CSSProperties;\n} & Omit<SVGProps<SVGSVGElement>, \"aria-hidden\" | \"aria-label\">;\n\nconst COLOR_MAP: Record<IconColors, string> = {\n primary: \"#080808\",\n secondary: \"#666666\",\n white: \"#ffffff\",\n primaryBlue: \"#089CCB\",\n disabled: \"#888888\",\n danger: \"#FF0000\"\n};\n\nconst BREAKPOINT_MAP: Record<Breakpoint, string> = {\n sm: \"640px\",\n md: \"768px\",\n lg: \"1024px\",\n xl: \"1280px\",\n \"2xl\": \"1536px\"\n};\n\nconst processSizes = (\n sizes: ResponsiveSize | ResponsiveSize[] | undefined\n): React.CSSProperties => {\n if (!sizes) return { width: \"24px\", height: \"24px\" };\n\n const sizeArray = Array.isArray(sizes) ? sizes : [sizes];\n const mediaQueries: Record<string, string> = {};\n let baseSize: string | undefined;\n\n // Process each size\n sizeArray.forEach((size) => {\n if (typeof size === \"number\") {\n baseSize = `${size}px`;\n } else {\n const [breakpoint, valueStr] = size.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n mediaQueries[`@media (min-width: ${BREAKPOINT_MAP[breakpoint]})`] =\n `${value}px`;\n }\n });\n\n // Create the style object with the correct structure\n return {\n width: baseSize || \"24px\",\n height: baseSize || \"24px\",\n ...Object.entries(mediaQueries).reduce(\n (acc, [query, size]) => ({\n ...acc,\n [query]: {\n width: size,\n height: size\n }\n }),\n {}\n )\n };\n};\n\nexport const Icon = React.forwardRef<SVGSVGElement, IconProps>(\n (\n {\n name,\n size = 24,\n color = \"primary\",\n title,\n className,\n style = {},\n ...props\n },\n ref\n ) => {\n const IconComponent = IconMap[name];\n const sizeStyles = processSizes(size);\n\n return (\n <div\n className={cn(\"flex justify-center items-center\", className)}\n style={{\n ...sizeStyles,\n [\"--icon-stroke\" as string]: COLOR_MAP[color],\n ...style\n }}\n >\n <IconComponent\n ref={ref}\n aria-hidden={!title}\n aria-label={title}\n stroke={name.includes(\"filled\") ? undefined : COLOR_MAP[color]}\n {...props}\n />\n </div>\n );\n }\n);\n\nIcon.displayName = \"Icon\";\n","import { Colors, Typography } from \"../types/tailwind\";\n\n// Generate safelist patterns for all color utilities so you can use any theme color variable in your code\nexport const generateSafelist = (colors: Colors, typography: Typography) => {\n const colorNames = Object.keys(colors) as (keyof Colors)[];\n const utilities = [\"bg\", \"text\", \"border\", \"ring\", \"divide\", \"outline\"];\n const variants = [\"hover:\", \"focus:\", \"active:\", \"disabled:\"];\n\n const safelist: string[] = [];\n\n colorNames.forEach((colorName) => {\n if (typeof colors[colorName] === \"object\") {\n // Handle nested color objects (with number keys)\n Object.keys(colors[colorName]).forEach((shade) => {\n utilities.forEach((utility) => {\n // Base utility\n safelist.push(`${utility}-${colorName}-${shade}`);\n\n // Variant utilities\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}-${shade}`);\n });\n });\n });\n } else {\n // Handle direct color values\n utilities.forEach((utility) => {\n safelist.push(`${utility}-${colorName}`);\n\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}`);\n });\n });\n }\n });\n\n // Generate typography classes\n Object.entries(typography).forEach(([family, sizes]) => {\n Object.keys(sizes).forEach((size) => {\n // Base typography classes\n safelist.push(`text-${family}-${size}`);\n\n // Add variants\n variants.forEach((variant) => {\n safelist.push(`${variant}text-${family}-${size}`);\n });\n });\n });\n\n const breakpoints = [\"sm\", \"md\", \"lg\", \"xl\", \"2xl\"];\n const typographyClasses = Object.entries(typography).flatMap(\n ([category, sizes]) =>\n Object.keys(sizes).map((size) => `text-${category}-${size}`)\n );\n\n // Generate responsive variants\n const responsiveTypographyClasses = typographyClasses.flatMap((className) =>\n breakpoints.map((breakpoint) => `${breakpoint}:${className}`)\n );\n\n return [\n ...typographyClasses,\n ...responsiveTypographyClasses\n // ... rest of your safelist\n ];\n};\n\nexport const focusRingStyles =\n \"focus-visible:outline-none focus-visible:border-2 focus-visible:border-primary-100\";\n\nexport const focusRingStylesCoerced = \"border-2 border-primary-100\";\n","import React, { ButtonHTMLAttributes } from \"react\";\nimport { focusRingStyles } from \"../utils/tailwind\";\nimport { cn } from \"../utils\";\n\nexport type PressableProps = ButtonHTMLAttributes<HTMLButtonElement>;\n\nexport const Pressable = React.forwardRef<HTMLButtonElement, PressableProps>(\n ({ children, type = \"button\", className, disabled, ...props }, ref) => (\n <button\n ref={ref}\n type={type}\n disabled={disabled}\n className={cn(\n \"appearance-none hover:opacity-80 transition-all active:scale-95\",\n focusRingStyles,\n disabled && \"opacity-50 cursor-not-allowed\",\n className\n )}\n {...props}\n >\n {children}\n </button>\n )\n);\n\nPressable.displayName = \"Pressable\";\n","import { useCallback, useEffect, useState } from \"react\";\n\nconst useIsomorphicLayoutEffect =\n typeof window !== \"undefined\" ? useEffect : () => {};\n\nexport const useMediaQuery = (query: string): boolean => {\n // Initialize with null to prevent hydration mismatch\n const [matches, setMatches] = useState<boolean | null>(null);\n\n const getMatches = useCallback((query: string): boolean => {\n if (typeof window !== \"undefined\") {\n return window.matchMedia(query).matches;\n }\n return false;\n }, []);\n\n // Update matches after mount to prevent hydration mismatch\n useIsomorphicLayoutEffect(() => {\n setMatches(getMatches(query));\n }, [query, getMatches]);\n\n useEffect(() => {\n if (typeof window !== \"undefined\") {\n const mediaQuery = window.matchMedia(query);\n\n const handleChange = () => {\n setMatches(getMatches(query));\n };\n\n mediaQuery.addEventListener(\"change\", handleChange);\n\n return () => {\n mediaQuery.removeEventListener(\"change\", handleChange);\n };\n }\n }, [query, getMatches]);\n\n // Return false during SSR, actual value after hydration\n return matches ?? false;\n};\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport * as ScrollArea from \"@radix-ui/react-scroll-area\";\nimport { Icon } from \"./Icon\";\nimport { Pressable } from \"./Pressable\";\nimport { useMediaQuery } from \"../hooks/useMediaQuery\";\n\nexport type CarouselProps = {\n children: React.ReactNode;\n /** Optional className for the root element */\n className?: string;\n /** Optional gap between items in pixels */\n gap?: number;\n};\n\nexport const Carousel = ({\n children,\n className = \"\",\n gap = 20\n}: CarouselProps) => {\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const [showLeftPaddle, setShowLeftPaddle] = useState(false);\n const [showRightPaddle, setShowRightPaddle] = useState(false);\n const [isHoveringStart, setIsHoveringStart] = useState(false);\n const [isHoveringEnd, setIsHoveringEnd] = useState(false);\n const [touchStart, setTouchStart] = useState<number | null>(null);\n const [touchEnd, setTouchEnd] = useState<number | null>(null);\n const isMobile = useMediaQuery(\"(max-width: 768px)\");\n\n const checkScrollPosition = useCallback(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const { scrollLeft, scrollWidth, clientWidth } = container;\n setShowLeftPaddle(scrollLeft > 0);\n setShowRightPaddle(Math.ceil(scrollLeft + clientWidth) < scrollWidth);\n }, []);\n\n const handleMouseMove = useCallback(\n (e: React.MouseEvent) => {\n if (isMobile) return;\n\n const container = e.currentTarget;\n const rect = container.getBoundingClientRect();\n const mouseX = e.clientX - rect.left;\n const HOVER_THRESHOLD = 300;\n\n setIsHoveringStart(mouseX < HOVER_THRESHOLD);\n setIsHoveringEnd(mouseX > rect.width - HOVER_THRESHOLD);\n },\n [isMobile]\n );\n\n // Touch handling\n const handleTouchStart = useCallback((e: React.TouchEvent) => {\n setTouchStart(e.touches[0].clientX);\n setTouchEnd(null);\n }, []);\n\n const handleTouchMove = useCallback((e: React.TouchEvent) => {\n setTouchEnd(e.touches[0].clientX);\n }, []);\n\n const handleTouchEnd = useCallback(() => {\n if (!touchStart || !touchEnd) return;\n\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const distance = touchStart - touchEnd;\n const minSwipeDistance = 50;\n\n if (Math.abs(distance) < minSwipeDistance) {\n return;\n }\n\n const itemWidth = container.clientWidth;\n const direction = distance > 0 ? 1 : -1;\n const targetScroll = container.scrollLeft + itemWidth * direction;\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, [touchStart, touchEnd]);\n\n const handleWheel = useCallback((e: WheelEvent) => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n // Check if the scroll is predominantly horizontal or if shift key is pressed\n const isHorizontalScroll = Math.abs(e.deltaX) > Math.abs(e.deltaY);\n if (!isHorizontalScroll && !e.shiftKey) return;\n\n e.preventDefault();\n\n // Determine the scroll amount based on the input type\n const scrollAmount = isHorizontalScroll ? e.deltaX : e.deltaY;\n\n // Apply smooth scrolling\n container.scrollBy({\n left: scrollAmount,\n behavior: \"smooth\"\n });\n }, []);\n\n useEffect(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const observer = new ResizeObserver(checkScrollPosition);\n observer.observe(container);\n\n container.addEventListener(\"scroll\", checkScrollPosition);\n container.addEventListener(\"wheel\", handleWheel, { passive: false });\n\n return () => {\n observer.disconnect();\n container.removeEventListener(\"scroll\", checkScrollPosition);\n container.removeEventListener(\"wheel\", handleWheel);\n };\n }, [checkScrollPosition, handleWheel]);\n\n const scroll = useCallback((direction: \"left\" | \"right\") => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const scrollAmount = container.clientWidth;\n const targetScroll =\n container.scrollLeft +\n (direction === \"left\" ? -scrollAmount : scrollAmount);\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, []);\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n if (e.key === \"ArrowLeft\") {\n scroll(\"left\");\n } else if (e.key === \"ArrowRight\") {\n scroll(\"right\");\n }\n },\n [scroll]\n );\n\n return (\n <div\n className={`relative group ${className}`}\n onKeyDown={handleKeyDown}\n onMouseMove={handleMouseMove}\n onMouseLeave={() => {\n setIsHoveringStart(false);\n setIsHoveringEnd(false);\n }}\n onTouchStart={handleTouchStart}\n onTouchMove={handleTouchMove}\n onTouchEnd={handleTouchEnd}\n role=\"region\"\n aria-label=\"Carousel\"\n >\n <ScrollArea.Root className=\"overflow-hidden\" type=\"hover\">\n <ScrollArea.Viewport\n ref={scrollContainerRef}\n className=\"w-full overflow-x-auto snap-x snap-mandatory\"\n style={{\n scrollbarWidth: \"none\",\n msOverflowStyle: \"none\",\n WebkitOverflowScrolling: \"touch\"\n }}\n >\n <div\n className=\"inline-flex\"\n style={{\n gap: `${gap}px`\n }}\n >\n {React.Children.map(children, (child) =>\n child === null ? null : (\n <div className=\"snap-start shrink-0\">{child}</div>\n )\n )}\n </div>\n </ScrollArea.Viewport>\n </ScrollArea.Root>\n\n {/* Navigation Paddles - Only show on desktop */}\n {!isMobile && (\n <>\n {showLeftPaddle && isHoveringStart && (\n <Pressable\n onClick={() => scroll(\"left\")}\n className=\"absolute left-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll left\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-left\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n\n {showRightPaddle && isHoveringEnd && (\n <Pressable\n onClick={() => scroll(\"right\")}\n className=\"absolute right-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll right\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-right\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n </>\n )}\n </div>\n );\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["../../src/utils/index.ts","../../src/utils/responsive.ts","../../src/components/Icon.tsx","../../src/utils/tailwind.ts","../../src/components/Pressable.tsx","../../src/hooks/useMediaQuery.ts","../../src/components/Carousel.tsx"],"names":["cn","inputs","twMerge","clsx","BASE_SIZES","RESPONSIVE_SIZES","getSizeKey","size","getResponsiveSize","baseSize","classes","styles","key","baseKey","responsiveClasses","s","breakpoint","valueStr","value","valueKey","COLOR_MAP","Icon","React","name","color","title","className","style","props","ref","IconComponent","IconMap","responsiveSizeClasses","responsiveSizeStyles","focusRingStyles","Pressable","children","type","disabled","useIsomorphicLayoutEffect","useEffect","useMediaQuery","query","matches","setMatches","useState","getMatches","useCallback","mediaQuery","handleChange","Carousel","gap","scrollContainerRef","useRef","showLeftPaddle","setShowLeftPaddle","showRightPaddle","setShowRightPaddle","isHoveringStart","setIsHoveringStart","isHoveringEnd","setIsHoveringEnd","touchStart","setTouchStart","touchEnd","setTouchEnd","isMobile","checkScrollPosition","container","scrollLeft","scrollWidth","clientWidth","handleMouseMove","rect","mouseX","HOVER_THRESHOLD","handleTouchStart","handleTouchMove","handleTouchEnd","distance","itemWidth","direction","targetScroll","handleWheel","isHorizontalScroll","scrollAmount","observer","scroll","handleKeyDown","child"],"mappings":"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","file":"Carousel.js","sourcesContent":["import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n\nexport const noopFn = () => {};\n","export type Breakpoint = \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\";\nexport type ResponsiveSize = number | `${Breakpoint}:${number}`;\n\ntype SizeKey =\n | \"12\"\n | \"16\"\n | \"18\"\n | \"20\"\n | \"24\"\n | \"32\"\n | \"36\"\n | \"40\"\n | \"42\"\n | \"48\"\n | \"64\"\n | \"72\";\n\n// These constants help Tailwind identify the classes during compilation\nconst BASE_SIZES: Record<SizeKey, string> = {\n \"12\": \"h-[12px] w-[12px]\",\n \"16\": \"h-[16px] w-[16px]\",\n \"18\": \"h-[18px] w-[18px]\",\n \"20\": \"h-[20px] w-[20px]\",\n \"24\": \"h-[24px] w-[24px]\",\n \"32\": \"h-[32px] w-[32px]\",\n \"36\": \"h-[36px] w-[36px]\",\n \"40\": \"h-[40px] w-[40px]\",\n \"42\": \"h-[42px] w-[42px]\",\n \"48\": \"h-[48px] w-[48px]\",\n \"64\": \"h-[64px] w-[64px]\",\n \"72\": \"h-[72px] w-[72px]\"\n};\n\nconst RESPONSIVE_SIZES: Record<Breakpoint, Record<SizeKey, string>> = {\n sm: {\n \"12\": \"sm:h-[12px] sm:w-[12px]\",\n \"16\": \"sm:h-[16px] sm:w-[16px]\",\n \"18\": \"sm:h-[18px] sm:w-[18px]\",\n \"20\": \"sm:h-[20px] sm:w-[20px]\",\n \"24\": \"sm:h-[24px] sm:w-[24px]\",\n \"32\": \"sm:h-[32px] sm:w-[32px]\",\n \"36\": \"sm:h-[36px] sm:w-[36px]\",\n \"40\": \"sm:h-[40px] sm:w-[40px]\",\n \"42\": \"sm:h-[42px] sm:w-[42px]\",\n \"48\": \"sm:h-[48px] sm:w-[48px]\",\n \"64\": \"sm:h-[64px] sm:w-[64px]\",\n \"72\": \"sm:h-[72px] sm:w-[72px]\"\n },\n md: {\n \"12\": \"md:h-[12px] md:w-[12px]\",\n \"16\": \"md:h-[16px] md:w-[16px]\",\n \"18\": \"md:h-[18px] md:w-[18px]\",\n \"20\": \"md:h-[20px] md:w-[20px]\",\n \"24\": \"md:h-[24px] md:w-[24px]\",\n \"32\": \"md:h-[32px] md:w-[32px]\",\n \"36\": \"md:h-[36px] md:w-[36px]\",\n \"40\": \"md:h-[40px] md:w-[40px]\",\n \"42\": \"md:h-[42px] md:w-[42px]\",\n \"48\": \"md:h-[48px] md:w-[48px]\",\n \"64\": \"md:h-[64px] md:w-[64px]\",\n \"72\": \"md:h-[72px] md:w-[72px]\"\n },\n lg: {\n \"12\": \"lg:h-[12px] lg:w-[12px]\",\n \"16\": \"lg:h-[16px] lg:w-[16px]\",\n \"18\": \"lg:h-[18px] lg:w-[18px]\",\n \"20\": \"lg:h-[20px] lg:w-[20px]\",\n \"24\": \"lg:h-[24px] lg:w-[24px]\",\n \"32\": \"lg:h-[32px] lg:w-[32px]\",\n \"36\": \"lg:h-[36px] lg:w-[36px]\",\n \"40\": \"lg:h-[40px] lg:w-[40px]\",\n \"42\": \"lg:h-[42px] lg:w-[42px]\",\n \"48\": \"lg:h-[48px] lg:w-[48px]\",\n \"64\": \"lg:h-[64px] lg:w-[64px]\",\n \"72\": \"lg:h-[72px] lg:w-[72px]\"\n },\n xl: {\n \"12\": \"xl:h-[12px] xl:w-[12px]\",\n \"16\": \"xl:h-[16px] xl:w-[16px]\",\n \"18\": \"xl:h-[18px] xl:w-[18px]\",\n \"20\": \"xl:h-[20px] xl:w-[20px]\",\n \"24\": \"xl:h-[24px] xl:w-[24px]\",\n \"32\": \"xl:h-[32px] xl:w-[32px]\",\n \"36\": \"xl:h-[36px] xl:w-[36px]\",\n \"40\": \"xl:h-[40px] xl:w-[40px]\",\n \"42\": \"xl:h-[42px] xl:w-[42px]\",\n \"48\": \"xl:h-[48px] xl:w-[48px]\",\n \"64\": \"xl:h-[64px] xl:w-[64px]\",\n \"72\": \"xl:h-[72px] xl:w-[72px]\"\n },\n \"2xl\": {\n \"12\": \"2xl:h-[12px] 2xl:w-[12px]\",\n \"16\": \"2xl:h-[16px] 2xl:w-[16px]\",\n \"18\": \"2xl:h-[18px] 2xl:w-[18px]\",\n \"20\": \"2xl:h-[20px] 2xl:w-[20px]\",\n \"24\": \"2xl:h-[24px] 2xl:w-[24px]\",\n \"32\": \"2xl:h-[32px] 2xl:w-[32px]\",\n \"36\": \"2xl:h-[36px] 2xl:w-[36px]\",\n \"40\": \"2xl:h-[40px] 2xl:w-[40px]\",\n \"42\": \"2xl:h-[42px] 2xl:w-[42px]\",\n \"48\": \"2xl:h-[48px] 2xl:w-[48px]\",\n \"64\": \"2xl:h-[64px] 2xl:w-[64px]\",\n \"72\": \"2xl:h-[72px] 2xl:w-[72px]\"\n }\n};\n\nconst getSizeKey = (size: number): SizeKey | undefined => {\n return String(size) as SizeKey;\n};\n\nexport const getResponsiveSize = (\n size: ResponsiveSize | ResponsiveSize[] | undefined,\n baseSize: number = 24\n): {\n responsiveSizeClasses: string;\n responsiveSizeStyles: Record<string, string>;\n} => {\n const classes: string[] = [];\n const styles: Record<string, string> = {};\n\n // If no size provided, use baseSize\n if (size === undefined) {\n const key = getSizeKey(baseSize);\n if (key) {\n classes.push(BASE_SIZES[key]);\n } else {\n styles.height = `${baseSize}px`;\n styles.width = `${baseSize}px`;\n }\n }\n\n // If size is a number, use that directly\n if (typeof size === \"number\") {\n const key = getSizeKey(size);\n if (key) {\n classes.push(BASE_SIZES[key]);\n } else {\n styles.height = `${size}px`;\n styles.width = `${size}px`;\n }\n }\n\n // If array of responsive sizes, generate responsive classes\n if (Array.isArray(size)) {\n const baseKey = getSizeKey(baseSize);\n const responsiveClasses = [\n (baseKey && BASE_SIZES[baseKey]) || `h-[${baseSize}px] w-[${baseSize}px]`\n ];\n\n size.forEach((s) => {\n if (typeof s === \"string\") {\n const [breakpoint, valueStr] = s.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n const key = getSizeKey(value);\n classes.push(\n (key && RESPONSIVE_SIZES[breakpoint]?.[key]) ||\n `${breakpoint}:h-[${value}px] ${breakpoint}:w-[${value}px]`\n );\n }\n });\n\n classes.push(...responsiveClasses);\n }\n\n if (typeof size === \"string\") {\n const [breakpoint, valueStr] = size.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n const valueKey = getSizeKey(value);\n classes.push(\n (valueKey && RESPONSIVE_SIZES[breakpoint]?.[valueKey]) ||\n `${breakpoint}:h-[${value}px] ${breakpoint}:w-[${value}px]`\n );\n }\n\n return {\n responsiveSizeClasses: classes.join(\" \"),\n responsiveSizeStyles: styles\n };\n};\n","import { IconMap, IconName } from \"@deckai/icons\";\nimport React, { SVGProps } from \"react\";\nimport { IconColors } from \"../types/tailwind\";\nimport { cn } from \"../utils\";\nimport { ResponsiveSize, getResponsiveSize } from \"../utils/responsive\";\n\nexport type IconProps = {\n name: IconName;\n /** @default 24 */\n size?: ResponsiveSize | ResponsiveSize[];\n /** @default primary */\n color?: IconColors;\n title?: string;\n className?: string;\n style?: React.CSSProperties;\n} & Omit<SVGProps<SVGSVGElement>, \"aria-hidden\" | \"aria-label\">;\n\nconst COLOR_MAP: Record<IconColors, string> = {\n primary: \"#080808\",\n secondary: \"#666666\",\n white: \"#ffffff\",\n primaryBlue: \"#089CCB\",\n disabled: \"#888888\",\n danger: \"#FF0000\"\n};\n\nexport const Icon = React.forwardRef<SVGSVGElement, IconProps>(\n (\n {\n name,\n size = 24,\n color = \"primary\",\n title,\n className,\n style = {},\n ...props\n },\n ref\n ) => {\n const IconComponent = IconMap[name];\n const { responsiveSizeClasses, responsiveSizeStyles } = getResponsiveSize(\n size,\n 24\n );\n\n return (\n <div\n className={cn(\n \"flex justify-center items-center\",\n responsiveSizeClasses,\n className\n )}\n style={{\n [\"--icon-stroke\" as string]: COLOR_MAP[color],\n ...responsiveSizeStyles,\n ...style\n }}\n >\n <IconComponent\n ref={ref}\n aria-hidden={!title}\n aria-label={title}\n stroke={name.includes(\"filled\") ? undefined : COLOR_MAP[color]}\n {...props}\n />\n </div>\n );\n }\n);\n\nIcon.displayName = \"Icon\";\n","import { Colors, Typography } from \"../types/tailwind\";\n\n// Generate safelist patterns for all color utilities so you can use any theme color variable in your code\nexport const generateSafelist = (colors: Colors, typography: Typography) => {\n const colorNames = Object.keys(colors) as (keyof Colors)[];\n const utilities = [\"bg\", \"text\", \"border\", \"ring\", \"divide\", \"outline\"];\n const variants = [\"hover:\", \"focus:\", \"active:\", \"disabled:\"];\n const breakpoints = [\"sm\", \"md\", \"lg\", \"xl\", \"2xl\"];\n const sizes = [\"24\", \"42\", \"48\", \"64\", \"72\"]; // Add all the sizes you need\n\n const safelist: (string | { pattern: RegExp; variants: string[] })[] = [];\n\n colorNames.forEach((colorName) => {\n if (typeof colors[colorName] === \"object\") {\n // Handle nested color objects (with number keys)\n Object.keys(colors[colorName]).forEach((shade) => {\n utilities.forEach((utility) => {\n // Base utility\n safelist.push(`${utility}-${colorName}-${shade}`);\n\n // Variant utilities\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}-${shade}`);\n });\n });\n });\n } else {\n // Handle direct color values\n utilities.forEach((utility) => {\n safelist.push(`${utility}-${colorName}`);\n\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}`);\n });\n });\n }\n });\n\n // Generate typography classes\n Object.entries(typography).forEach(([family, sizes]) => {\n Object.keys(sizes).forEach((size) => {\n // Base typography classes\n safelist.push(`text-${family}-${size}`);\n\n // Add variants\n variants.forEach((variant) => {\n safelist.push(`${variant}text-${family}-${size}`);\n });\n });\n });\n\n const typographyClasses = Object.entries(typography).flatMap(\n ([category, sizes]) =>\n Object.keys(sizes).map((size) => `text-${category}-${size}`)\n );\n\n // Generate responsive variants\n const responsiveTypographyClasses = typographyClasses.flatMap((className) =>\n breakpoints.map((breakpoint) => `${breakpoint}:${className}`)\n );\n\n // Generate size classes with responsive variants\n const sizeClasses = sizes.flatMap((size) => [\n `h-[${size}px]`,\n `w-[${size}px]`,\n ...breakpoints.flatMap((bp) => [\n `${bp}:h-[${size}px]`,\n `${bp}:w-[${size}px]`\n ])\n ]);\n\n return [...typographyClasses, ...responsiveTypographyClasses, ...sizeClasses];\n};\n\nexport const focusRingStyles =\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-100\";\nexport const focusRingWithinStyles =\n \"focus-within:outline-none focus-within:ring-2 focus-within:ring-primary-100\";\nexport const focusRingStylesCoerced = \"ring-2 ring-primary-100\";\n","import React, { ButtonHTMLAttributes } from \"react\";\nimport { focusRingStyles } from \"../utils/tailwind\";\nimport { cn } from \"../utils\";\n\nexport type PressableProps = ButtonHTMLAttributes<HTMLButtonElement>;\n\nexport const Pressable = React.forwardRef<HTMLButtonElement, PressableProps>(\n ({ children, type = \"button\", className, disabled, ...props }, ref) => (\n <button\n ref={ref}\n type={type}\n disabled={disabled}\n className={cn(\n \"appearance-none hover:opacity-80 transition-all active:scale-95\",\n focusRingStyles,\n disabled && \"opacity-50 cursor-not-allowed\",\n className\n )}\n {...props}\n >\n {children}\n </button>\n )\n);\n\nPressable.displayName = \"Pressable\";\n","import { useCallback, useEffect, useState } from \"react\";\n\nconst useIsomorphicLayoutEffect =\n typeof window !== \"undefined\" ? useEffect : () => {};\n\nexport const useMediaQuery = (query: string): boolean => {\n // Initialize with null to prevent hydration mismatch\n const [matches, setMatches] = useState<boolean | null>(null);\n\n const getMatches = useCallback((query: string): boolean => {\n if (typeof window !== \"undefined\") {\n return window.matchMedia(query).matches;\n }\n return false;\n }, []);\n\n // Update matches after mount to prevent hydration mismatch\n useIsomorphicLayoutEffect(() => {\n setMatches(getMatches(query));\n }, [query, getMatches]);\n\n useEffect(() => {\n if (typeof window !== \"undefined\") {\n const mediaQuery = window.matchMedia(query);\n\n const handleChange = () => {\n setMatches(getMatches(query));\n };\n\n mediaQuery.addEventListener(\"change\", handleChange);\n\n return () => {\n mediaQuery.removeEventListener(\"change\", handleChange);\n };\n }\n }, [query, getMatches]);\n\n // Return false during SSR, actual value after hydration\n return matches ?? false;\n};\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport * as ScrollArea from \"@radix-ui/react-scroll-area\";\nimport { Icon } from \"./Icon\";\nimport { Pressable } from \"./Pressable\";\nimport { useMediaQuery } from \"../hooks/useMediaQuery\";\n\nexport type CarouselProps = {\n children: React.ReactNode;\n /** Optional className for the root element */\n className?: string;\n /** Optional gap between items in pixels */\n gap?: number;\n};\n\nexport const Carousel = ({\n children,\n className = \"\",\n gap = 20\n}: CarouselProps) => {\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const [showLeftPaddle, setShowLeftPaddle] = useState(false);\n const [showRightPaddle, setShowRightPaddle] = useState(false);\n const [isHoveringStart, setIsHoveringStart] = useState(false);\n const [isHoveringEnd, setIsHoveringEnd] = useState(false);\n const [touchStart, setTouchStart] = useState<number | null>(null);\n const [touchEnd, setTouchEnd] = useState<number | null>(null);\n const isMobile = useMediaQuery(\"(max-width: 768px)\");\n\n const checkScrollPosition = useCallback(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const { scrollLeft, scrollWidth, clientWidth } = container;\n setShowLeftPaddle(scrollLeft > 0);\n setShowRightPaddle(Math.ceil(scrollLeft + clientWidth) < scrollWidth);\n }, []);\n\n const handleMouseMove = useCallback(\n (e: React.MouseEvent) => {\n if (isMobile) return;\n\n const container = e.currentTarget;\n const rect = container.getBoundingClientRect();\n const mouseX = e.clientX - rect.left;\n const HOVER_THRESHOLD = 300;\n\n setIsHoveringStart(mouseX < HOVER_THRESHOLD);\n setIsHoveringEnd(mouseX > rect.width - HOVER_THRESHOLD);\n },\n [isMobile]\n );\n\n // Touch handling\n const handleTouchStart = useCallback((e: React.TouchEvent) => {\n setTouchStart(e.touches[0].clientX);\n setTouchEnd(null);\n }, []);\n\n const handleTouchMove = useCallback((e: React.TouchEvent) => {\n setTouchEnd(e.touches[0].clientX);\n }, []);\n\n const handleTouchEnd = useCallback(() => {\n if (!touchStart || !touchEnd) return;\n\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const distance = touchStart - touchEnd;\n const minSwipeDistance = 50;\n\n if (Math.abs(distance) < minSwipeDistance) {\n return;\n }\n\n const itemWidth = container.clientWidth;\n const direction = distance > 0 ? 1 : -1;\n const targetScroll = container.scrollLeft + itemWidth * direction;\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, [touchStart, touchEnd]);\n\n const handleWheel = useCallback((e: WheelEvent) => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n // Check if the scroll is predominantly horizontal or if shift key is pressed\n const isHorizontalScroll = Math.abs(e.deltaX) > Math.abs(e.deltaY);\n if (!isHorizontalScroll && !e.shiftKey) return;\n\n e.preventDefault();\n\n // Determine the scroll amount based on the input type\n const scrollAmount = isHorizontalScroll ? e.deltaX : e.deltaY;\n\n // Apply smooth scrolling\n container.scrollBy({\n left: scrollAmount,\n behavior: \"smooth\"\n });\n }, []);\n\n useEffect(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const observer = new ResizeObserver(checkScrollPosition);\n observer.observe(container);\n\n container.addEventListener(\"scroll\", checkScrollPosition);\n container.addEventListener(\"wheel\", handleWheel, { passive: false });\n\n return () => {\n observer.disconnect();\n container.removeEventListener(\"scroll\", checkScrollPosition);\n container.removeEventListener(\"wheel\", handleWheel);\n };\n }, [checkScrollPosition, handleWheel]);\n\n const scroll = useCallback((direction: \"left\" | \"right\") => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const scrollAmount = container.clientWidth;\n const targetScroll =\n container.scrollLeft +\n (direction === \"left\" ? -scrollAmount : scrollAmount);\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, []);\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n if (e.key === \"ArrowLeft\") {\n scroll(\"left\");\n } else if (e.key === \"ArrowRight\") {\n scroll(\"right\");\n }\n },\n [scroll]\n );\n\n return (\n <div\n className={`relative group ${className}`}\n onKeyDown={handleKeyDown}\n onMouseMove={handleMouseMove}\n onMouseLeave={() => {\n setIsHoveringStart(false);\n setIsHoveringEnd(false);\n }}\n onTouchStart={handleTouchStart}\n onTouchMove={handleTouchMove}\n onTouchEnd={handleTouchEnd}\n role=\"region\"\n aria-label=\"Carousel\"\n >\n <ScrollArea.Root className=\"overflow-hidden\" type=\"hover\">\n <ScrollArea.Viewport\n ref={scrollContainerRef}\n className=\"w-full overflow-x-auto snap-x snap-mandatory\"\n style={{\n scrollbarWidth: \"none\",\n msOverflowStyle: \"none\",\n WebkitOverflowScrolling: \"touch\"\n }}\n >\n <div\n className=\"inline-flex\"\n style={{\n gap: `${gap}px`\n }}\n >\n {React.Children.map(children, (child) =>\n child === null ? null : (\n <div className=\"snap-start shrink-0\">{child}</div>\n )\n )}\n </div>\n </ScrollArea.Viewport>\n </ScrollArea.Root>\n\n {/* Navigation Paddles - Only show on desktop */}\n {!isMobile && (\n <>\n {showLeftPaddle && isHoveringStart && (\n <Pressable\n onClick={() => scroll(\"left\")}\n className=\"absolute left-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll left\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-left\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n\n {showRightPaddle && isHoveringEnd && (\n <Pressable\n onClick={() => scroll(\"right\")}\n className=\"absolute right-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll right\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-right\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n </>\n )}\n </div>\n );\n};\n"]}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var n=require('react'),v=require('@radix-ui/react-collapsible'),clsx=require('clsx'),tailwindMerge=require('tailwind-merge'),c=require('@radix-ui/react-toast'),icons=require('@deckai/icons');function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var n__namespace=/*#__PURE__*/_interopNamespace(n);var v__namespace=/*#__PURE__*/_interopNamespace(v);var c__namespace=/*#__PURE__*/_interopNamespace(c);var b="focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-100";function d(...e){return tailwindMerge.twMerge(clsx.clsx(e))}var E=n__namespace.default.forwardRef(({children:e,type:s="button",className:t,disabled:r,...o},a)=>n__namespace.default.createElement("button",{ref:a,type:s,disabled:r,className:d("appearance-none hover:opacity-80 transition-all active:scale-95",b,r&&"opacity-50 cursor-not-allowed",t),...o},e));E.displayName="Pressable";var j={xl:"h1",lg:"h1",md:"h2",sm:"h3",xs:"h4"},K=e=>{let[s,t]=e.split("-");return s==="heading"?j[t]||"p":s==="label"?"label":"p"},z={light:"font-light",regular:"font-regular",semibold:"font-semibold",bold:"font-bold"},G=e=>e?(Array.isArray(e)?e:[e]).map(t=>{if(t.includes(":")){let[r,o]=t.split(":");return `${r}:text-${o}`}return `text-${t}`}).join(" "):"text-body-default",h=n__namespace.default.forwardRef(({variant:e="body-default",color:s="primary",as:t,className:r,children:o,weight:a,...p},i)=>{let l=G(e),x=s==="inherit"?"text-inherit":`text-${s}`,m=n__namespace.default.useMemo(()=>{let y=typeof e=="string"?e.split(":").pop():Array.isArray(e)?e[0].split(":").pop():"body-default";return K(y)},[e]);return n__namespace.default.createElement(t||m,{ref:i,className:`
|
|
2
2
|
font-sans antialiased
|
|
3
|
-
${
|
|
4
|
-
${
|
|
5
|
-
${
|
|
6
|
-
${
|
|
7
|
-
`,...
|
|
3
|
+
${l}
|
|
4
|
+
${x}
|
|
5
|
+
${a&&`!${z[a]}`}
|
|
6
|
+
${r}
|
|
7
|
+
`,...p},o)});h.displayName="Text";var H={12:"h-[12px] w-[12px]",16:"h-[16px] w-[16px]",18:"h-[18px] w-[18px]",20:"h-[20px] w-[20px]",24:"h-[24px] w-[24px]",32:"h-[32px] w-[32px]",36:"h-[36px] w-[36px]",40:"h-[40px] w-[40px]",42:"h-[42px] w-[42px]",48:"h-[48px] w-[48px]",64:"h-[64px] w-[64px]",72:"h-[72px] w-[72px]"},S={sm:{12:"sm:h-[12px] sm:w-[12px]",16:"sm:h-[16px] sm:w-[16px]",18:"sm:h-[18px] sm:w-[18px]",20:"sm:h-[20px] sm:w-[20px]",24:"sm:h-[24px] sm:w-[24px]",32:"sm:h-[32px] sm:w-[32px]",36:"sm:h-[36px] sm:w-[36px]",40:"sm:h-[40px] sm:w-[40px]",42:"sm:h-[42px] sm:w-[42px]",48:"sm:h-[48px] sm:w-[48px]",64:"sm:h-[64px] sm:w-[64px]",72:"sm:h-[72px] sm:w-[72px]"},md:{12:"md:h-[12px] md:w-[12px]",16:"md:h-[16px] md:w-[16px]",18:"md:h-[18px] md:w-[18px]",20:"md:h-[20px] md:w-[20px]",24:"md:h-[24px] md:w-[24px]",32:"md:h-[32px] md:w-[32px]",36:"md:h-[36px] md:w-[36px]",40:"md:h-[40px] md:w-[40px]",42:"md:h-[42px] md:w-[42px]",48:"md:h-[48px] md:w-[48px]",64:"md:h-[64px] md:w-[64px]",72:"md:h-[72px] md:w-[72px]"},lg:{12:"lg:h-[12px] lg:w-[12px]",16:"lg:h-[16px] lg:w-[16px]",18:"lg:h-[18px] lg:w-[18px]",20:"lg:h-[20px] lg:w-[20px]",24:"lg:h-[24px] lg:w-[24px]",32:"lg:h-[32px] lg:w-[32px]",36:"lg:h-[36px] lg:w-[36px]",40:"lg:h-[40px] lg:w-[40px]",42:"lg:h-[42px] lg:w-[42px]",48:"lg:h-[48px] lg:w-[48px]",64:"lg:h-[64px] lg:w-[64px]",72:"lg:h-[72px] lg:w-[72px]"},xl:{12:"xl:h-[12px] xl:w-[12px]",16:"xl:h-[16px] xl:w-[16px]",18:"xl:h-[18px] xl:w-[18px]",20:"xl:h-[20px] xl:w-[20px]",24:"xl:h-[24px] xl:w-[24px]",32:"xl:h-[32px] xl:w-[32px]",36:"xl:h-[36px] xl:w-[36px]",40:"xl:h-[40px] xl:w-[40px]",42:"xl:h-[42px] xl:w-[42px]",48:"xl:h-[48px] xl:w-[48px]",64:"xl:h-[64px] xl:w-[64px]",72:"xl:h-[72px] xl:w-[72px]"},"2xl":{12:"2xl:h-[12px] 2xl:w-[12px]",16:"2xl:h-[16px] 2xl:w-[16px]",18:"2xl:h-[18px] 2xl:w-[18px]",20:"2xl:h-[20px] 2xl:w-[20px]",24:"2xl:h-[24px] 2xl:w-[24px]",32:"2xl:h-[32px] 2xl:w-[32px]",36:"2xl:h-[36px] 2xl:w-[36px]",40:"2xl:h-[40px] 2xl:w-[40px]",42:"2xl:h-[42px] 2xl:w-[42px]",48:"2xl:h-[48px] 2xl:w-[48px]",64:"2xl:h-[64px] 2xl:w-[64px]",72:"2xl:h-[72px] 2xl:w-[72px]"}},u=e=>String(e),k=(e,s=24)=>{let t=[],r={};if(e===undefined){let o=u(s);o?t.push(H[o]):(r.height=`${s}px`,r.width=`${s}px`);}if(typeof e=="number"){let o=u(e);o?t.push(H[o]):(r.height=`${e}px`,r.width=`${e}px`);}if(Array.isArray(e)){let o=u(s),a=[o&&H[o]||`h-[${s}px] w-[${s}px]`];e.forEach(p=>{if(typeof p=="string"){let[i,l]=p.split(":"),x=parseInt(l,10),m=u(x);t.push(m&&S[i]?.[m]||`${i}:h-[${x}px] ${i}:w-[${x}px]`);}}),t.push(...a);}if(typeof e=="string"){let[o,a]=e.split(":"),p=parseInt(a,10),i=u(p);t.push(i&&S[o]?.[i]||`${o}:h-[${p}px] ${o}:w-[${p}px]`);}return {responsiveSizeClasses:t.join(" "),responsiveSizeStyles:r}};var N={primary:"#080808",secondary:"#666666",white:"#ffffff",primaryBlue:"#089CCB",disabled:"#888888",danger:"#FF0000"},T=n__namespace.default.forwardRef(({name:e,size:s=24,color:t="primary",title:r,className:o,style:a={},...p},i)=>{let l=icons.IconMap[e],{responsiveSizeClasses:x,responsiveSizeStyles:m}=k(s,24);return n__namespace.default.createElement("div",{className:d("flex justify-center items-center",x,o),style:{"--icon-stroke":N[t],...m,...a}},n__namespace.default.createElement(l,{ref:i,"aria-hidden":!r,"aria-label":r,stroke:e.includes("filled")?undefined:N[t],...p}))});T.displayName="Icon";var W={black:"bg-primary text-white",accent:"bg-primary-100 text-white",secondary:"bg-secondary-100 text-secondary"},_={black:"border border-text text-primary",accent:"border border-primary-100 text-primary-100",secondary:"border border-text-secondary text-secondary"},w=n__namespace.forwardRef(({className:e,variant:s="filled",color:t="black",isLoading:r=false,children:o,disabled:a,end:p,...i},l)=>n__namespace.createElement("button",{ref:l,className:d(`
|
|
8
8
|
sm:px-7 px-4
|
|
9
9
|
py-2
|
|
10
10
|
inline-flex items-center justify-center
|
|
@@ -12,5 +12,5 @@
|
|
|
12
12
|
transition-colors duration-200
|
|
13
13
|
disabled:opacity-50 disabled:pointer-events-none
|
|
14
14
|
hover:opacity-80 active:scale-95
|
|
15
|
-
truncate`,
|
|
15
|
+
truncate`,b,s==="filled"?W[t]:s==="transparent"?"bg-transparent text-text":_[t],e),disabled:a||r,type:"button",...i},typeof o=="string"?n__namespace.createElement(h,{variant:["sm:body-default-bold","body-xxs-semibold"],color:"inherit"},o):o,p));w.displayName="Button";var D={default:{icon:"information",className:"bg-gray-900 text-white"},success:{icon:"check",className:"bg-green-600 text-white"},error:{icon:"danger",className:"bg-tertiary-10 text-white"},warning:{icon:"warning-2",className:"bg-tertiary-20 text-white"}},A=n__namespace.forwardRef(({title:e,message:s,action:t,secondaryAction:r,variant:o="default",duration:a=5e3,className:p,onOpenChange:i,allowOutsideClick:l=true,onClose:x,...m},$)=>{let y=D[o],I=n__namespace.useCallback(R=>{!l&&R===false||(i?.(R),R||x?.());},[i,l,x]);return n__namespace.createElement(c__namespace.Root,{ref:$,onOpenChange:I,duration:a,className:d("group pointer-events-auto relative flex w-full flex-col gap-4 rounded-lg p-4 items-center","shadow-lg","data-[state=open]:animate-in data-[state=closed]:animate-out","data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0","data-[state=closed]:slide-out-to-right-full data-[state=open]:slide-in-from-right-full",y.className,p),...m},n__namespace.createElement(c__namespace.Close,{className:"absolute right-1 top-1 h-[40px] w-[40px] p-1 hover:bg-white/10 flex items-center justify-center rounded-lg","aria-label":"Close",onClick:x},n__namespace.createElement(T,{name:"close",size:16,color:"white"})),n__namespace.createElement("div",{className:"flex gap-4"},n__namespace.createElement(T,{name:y.icon,className:"h-5 w-5 shrink-0",color:"white"}),n__namespace.createElement("div",{className:"flex flex-col flex-1 gap-2"},e&&n__namespace.createElement(c__namespace.Title,{asChild:true},n__namespace.createElement(h,{variant:"body-default-bold",color:"inherit"},e)),n__namespace.createElement(c__namespace.Description,{asChild:true},n__namespace.createElement(h,{variant:"body-xs-medium",color:"inherit"},s)))),(t||r)&&n__namespace.createElement("div",{className:"flex gap-2 justify-end mt-2"},r&&n__namespace.createElement(c__namespace.Action,{asChild:true,altText:r.label},n__namespace.createElement("div",{className:"min-h-[40px] flex items-center"},n__namespace.createElement(w,{variant:r.variant||"outlined",color:"black",className:"border-white text-white hover:bg-white/10",onClick:r.onClick},r.label))),t&&n__namespace.createElement(c__namespace.Action,{asChild:true,altText:t.label},n__namespace.createElement("div",{className:"flex items-center"},n__namespace.createElement(w,{variant:t.variant||"outlined",color:"black",className:"border-white text-white hover:bg-white/10",onClick:t.onClick},t.label)))))});A.displayName="Toast";var B=typeof window<"u"?n.useLayoutEffect:n.useEffect;var X=({children:e,maxHeight:s=100})=>{let[t,r]=n__namespace.default.useState(false),o=n.useRef(null),[a,p]=n.useState(s);B(()=>{if(!o.current)return;let l=new ResizeObserver(x=>{for(let m of x)p(m.target.scrollHeight);});return l.observe(o.current),()=>l.disconnect()},[]);let i=a>s;return n__namespace.default.createElement(v__namespace.Root,{open:t,onOpenChange:r},n__namespace.default.createElement("div",{className:"relative"},n__namespace.default.createElement("div",{className:"overflow-hidden transition-[height] duration-300 ease-in-out",style:{height:t?`${a}px`:`${s}px`}},n__namespace.default.createElement("div",{ref:o,className:"w-full"},e)),i&&n__namespace.default.createElement(v__namespace.Trigger,{asChild:true},n__namespace.default.createElement(E,{className:d("absolute -bottom-8 left-0 right-0","flex items-end justify-center","h-16 pt-8 pb-2",!t&&"bg-gradient-to-b from-transparent via-white to-white","hover:opacity-100 transition-opacity")},n__namespace.default.createElement(h,{variant:"label-default",color:"secondary"},t?"See less":"See more")))))};X.displayName="Collapsible";exports.Collapsible=X;//# sourceMappingURL=Collapsible.cjs.map
|
|
16
16
|
//# sourceMappingURL=Collapsible.cjs.map
|