@shopito/design-system-fe 0.1.25 → 0.1.26

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.
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","names":[],"sources":["../src/components/common/Container/Container.tsx","../src/components/common/Main/Main.tsx","../node_modules/classnames/index.js","../src/components/common/Button/Button.tsx","../src/components/common/LoadingSpin/LoadingSpin.tsx","../src/components/common/IconButton/IconButton.tsx","../src/components/common/Input/Input.tsx","../src/components/common/Select/Select.tsx","../src/components/common/Typography/Heading.tsx","../src/components/common/Typography/Text.tsx","../src/components/common/Badge/Badge.tsx","../src/components/common/Card/Card.tsx","../src/components/common/Spinner/Spinner.tsx","../src/components/common/Alert/Alert.tsx","../src/components/common/Modal/Modal.tsx","../src/components/common/Checkbox/Checkbox.tsx","../src/components/common/Toggle/Toggle.tsx","../src/components/common/Avatar/Avatar.tsx","../src/components/common/Stack/Stack.tsx","../src/components/common/Grid/Grid.tsx","../src/components/common/QuantityInput/QuantityInput.tsx","../src/components/common/Pagination/Pagination.tsx","../src/components/common/Carousel/CarouselBtn.tsx","../src/components/common/Carousel/Carousel.tsx","../src/components/Header/Header.tsx","../src/components/CategoryTree/CategoryTree.tsx","../src/components/MegaMenu/MegaMenu.tsx","../src/components/BannerCarousel/BannerCarousel.tsx","../src/components/ProductCard/ProductCard.tsx","../src/components/ProductGrid/ProductGrid.tsx","../src/components/common/ProductCarousel/ProductCarousel.tsx","../src/components/CallToAction/CallToAction.tsx","../src/components/Footer/Footer.tsx"],"sourcesContent":["import { type ReactNode } from 'react';\n\nexport interface ContainerProps {\n children: ReactNode;\n}\n\nexport const Container = ({ children }: ContainerProps) => {\n return <div className=\"container\">{children}</div>;\n};\n","import { type ReactNode } from 'react';\nimport { Container } from '../Container';\n\nexport interface MainProps {\n children: ReactNode;\n}\n\nexport const Main = ({ children }: MainProps) => {\n return (\n <main className=\"main\">\n <Container>{children}</Container>\n </main>\n );\n};\n","/*!\n\tCopyright (c) 2018 Jed Watson.\n\tLicensed under the MIT License (MIT), see\n\thttp://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\n\tfunction classNames () {\n\t\tvar classes = '';\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (arg) {\n\t\t\t\tclasses = appendClass(classes, parseValue(arg));\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction parseValue (arg) {\n\t\tif (typeof arg === 'string' || typeof arg === 'number') {\n\t\t\treturn arg;\n\t\t}\n\n\t\tif (typeof arg !== 'object') {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (Array.isArray(arg)) {\n\t\t\treturn classNames.apply(null, arg);\n\t\t}\n\n\t\tif (arg.toString !== Object.prototype.toString && !arg.toString.toString().includes('[native code]')) {\n\t\t\treturn arg.toString();\n\t\t}\n\n\t\tvar classes = '';\n\n\t\tfor (var key in arg) {\n\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\tclasses = appendClass(classes, key);\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction appendClass (value, newClass) {\n\t\tif (!newClass) {\n\t\t\treturn value;\n\t\t}\n\t\n\t\tif (value) {\n\t\t\treturn value + ' ' + newClass;\n\t\t}\n\t\n\t\treturn value + newClass;\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n","import { forwardRef } from 'react';\nimport type { ButtonHTMLAttributes } from 'react';\nimport clx from 'classnames';\n\ntype Variant = 'primary' | 'secondary' | 'outline' | 'ghost' | 'danger';\ntype Size = 'xs' | 'sm' | 'md' | 'lg';\n\nexport interface ButtonProps extends ButtonHTMLAttributes<HTMLButtonElement> {\n variant?: Variant;\n size?: Size;\n loading?: boolean;\n fullWidth?: boolean;\n}\n\nexport const Button = forwardRef<HTMLButtonElement, ButtonProps>(\n (\n {\n variant = 'primary',\n size = 'md',\n loading = false,\n fullWidth = false,\n disabled,\n children,\n className = '',\n ...props\n },\n ref,\n ) => {\n const isDisabled = disabled || loading;\n\n return (\n <button\n ref={ref}\n disabled={isDisabled}\n className={clx(\n 'btn',\n variant && `btn-${variant}`,\n size && `btn-${size}`,\n fullWidth && 'w-full',\n className,\n )}\n {...props}\n >\n {loading && (\n <svg\n className=\"animate-spin h-4 w-4 shrink-0\"\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n >\n <circle\n className=\"opacity-25\"\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n stroke=\"currentColor\"\n strokeWidth=\"4\"\n />\n <path\n className=\"opacity-75\"\n fill=\"currentColor\"\n d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4z\"\n />\n </svg>\n )}\n {children}\n </button>\n );\n },\n);\n\nButton.displayName = 'Button';\n","import clx from 'classnames';\n\ntype Size = 'xs' | 'sm' | 'md' | 'lg';\n\nexport interface LoadingSpinProps {\n size: Size;\n}\n\nexport const LoadingSpin = ({ size = 'md' }: LoadingSpinProps) => {\n return (\n <svg\n className={clx('loading-spin', `loading-spin-${size}`)}\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n >\n <circle\n className=\"opacity-25\"\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n stroke=\"currentColor\"\n strokeWidth=\"4\"\n />\n <path\n className=\"opacity-75\"\n fill=\"currentColor\"\n d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4z\"\n />\n </svg>\n );\n};\n","import { forwardRef } from 'react';\nimport type { ButtonHTMLAttributes, ReactNode } from 'react';\nimport clx from 'classnames';\nimport { LoadingSpin } from '../LoadingSpin';\n\ntype Variant = 'primary' | 'secondary' | 'outline' | 'ghost' | 'danger';\ntype Size = 'xs' | 'sm' | 'md' | 'lg';\n\nexport interface IconButtonProps extends ButtonHTMLAttributes<HTMLButtonElement> {\n icon: ReactNode;\n label: string;\n variant?: Variant;\n size?: Size;\n loading?: boolean;\n}\n\nexport const IconButton = forwardRef<HTMLButtonElement, IconButtonProps>(\n (\n {\n icon,\n label,\n variant = 'ghost',\n size = 'md',\n loading = false,\n disabled,\n className = '',\n ...props\n },\n ref,\n ) => {\n const isDisabled = disabled || loading;\n\n return (\n <button\n ref={ref}\n disabled={isDisabled}\n aria-label={label}\n title={label}\n className={clx(\n 'icon-button',\n `icon-button-${variant}`,\n `icon-button-${size}`,\n className,\n )}\n {...props}\n >\n {loading ? <LoadingSpin size={size} /> : icon}\n </button>\n );\n },\n);\n\nIconButton.displayName = 'IconButton';\n","import { forwardRef } from 'react';\nimport type { InputHTMLAttributes, ReactNode } from 'react';\nimport clx from 'classnames';\n\nexport interface InputProps extends InputHTMLAttributes<HTMLInputElement> {\n label?: string;\n error?: string;\n hint?: string;\n leftIcon?: ReactNode;\n rightIcon?: ReactNode;\n}\n\nexport const Input = forwardRef<HTMLInputElement, InputProps>(\n (\n { label, error, hint, leftIcon, rightIcon, className = '', id, ...props },\n ref,\n ) => {\n const inputId = id ?? label?.toLowerCase().replace(/\\s+/g, '-');\n\n return (\n <div className={'w-full'}>\n {label && (\n <label htmlFor={inputId} className=\"input-label\">\n {label}\n </label>\n )}\n <div className=\"relative\">\n {leftIcon && <span className=\"left-icon\">{leftIcon}</span>}\n <input\n ref={ref}\n id={inputId}\n className={clx(\n 'input',\n error && 'has-error',\n !!leftIcon && 'with-left-icon',\n !!rightIcon && 'with-right-icon',\n 'w-full',\n className,\n )}\n {...props}\n />\n {rightIcon && <span className=\"right-icon\">{rightIcon}</span>}\n </div>\n {(error || hint) && (\n <p className={clx('helper-text', error && 'has-error')}>\n {error ?? hint}\n </p>\n )}\n </div>\n );\n },\n);\n\nInput.displayName = 'Input';\n","import { forwardRef } from 'react';\nimport type { SelectHTMLAttributes } from 'react';\nimport clx from 'classnames';\n\nexport interface SelectOption {\n value: string;\n label: string;\n disabled?: boolean;\n}\n\nexport interface SelectProps extends SelectHTMLAttributes<HTMLSelectElement> {\n label?: string;\n error?: string;\n hint?: string;\n options: SelectOption[];\n placeholder?: string;\n}\n\nexport const Select = forwardRef<HTMLSelectElement, SelectProps>(\n (\n { label, error, hint, options, placeholder, className = '', id, ...props },\n ref,\n ) => {\n const selectId = id ?? label?.toLowerCase().replace(/\\s+/g, '-');\n\n return (\n <div className={clx('select-wrapper', 'w-full')}>\n {label && (\n <label htmlFor={selectId} className=\"select-label\">\n {label}\n </label>\n )}\n <div className=\"relative\">\n <select\n ref={ref}\n id={selectId}\n className={clx('select', 'w-full', error && 'has-error', className)}\n {...props}\n >\n {placeholder && (\n <option value=\"\" disabled>\n {placeholder}\n </option>\n )}\n {options.map((opt) => (\n <option key={opt.value} value={opt.value} disabled={opt.disabled}>\n {opt.label}\n </option>\n ))}\n </select>\n {/* Chevron icon */}\n <span className=\"select-chevron-icon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M19.5 8.25l-7.5 7.5-7.5-7.5\"\n />\n </svg>\n </span>\n </div>\n {(error || hint) && (\n <p className={clx('select-helper', error && 'has-error')}>\n {error ?? hint}\n </p>\n )}\n </div>\n );\n },\n);\n\nSelect.displayName = 'Select';\n","import type { HTMLAttributes, ReactNode } from 'react';\nimport cx from 'classnames';\nimport type { Color } from './Text';\n\ntype HeadingLevel = 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n\ninterface HeadingProps extends HTMLAttributes<HTMLHeadingElement> {\n as?: HeadingLevel;\n level?: 1 | 2 | 3 | 4 | 5 | 6;\n color?: Color;\n children: ReactNode;\n}\n\nexport const Heading = ({\n as,\n level = 1,\n color = 'default',\n className = '',\n children,\n ...props\n}: HeadingProps) => {\n const Tag = as ?? (`h${level}` as HeadingLevel);\n\n return (\n <Tag\n className={cx(`text-color-${color}`, `heading-size-${level}`, className)}\n {...props}\n >\n {children}\n </Tag>\n );\n};\n","import type { ElementType, HTMLAttributes, ReactNode } from 'react';\nimport cx from 'classnames';\n\ntype TextVariant = 'body' | 'body-sm' | 'caption' | 'overline' | 'code';\n\nexport type Color =\n | 'default'\n | 'muted'\n | 'primary'\n | 'success'\n | 'warning'\n | 'danger'\n | 'inherit';\n\ninterface TextProps extends HTMLAttributes<HTMLElement> {\n variant?: TextVariant;\n color?: Color;\n as?: ElementType;\n children: ReactNode;\n}\n\nexport const Text = ({\n variant = 'body',\n color = 'default',\n as: Tag = 'p',\n className = '',\n children,\n ...props\n}: TextProps) => {\n return (\n <Tag\n className={cx(\n `text-color-${color}`,\n `text-variant-${variant}`,\n className,\n )}\n {...props}\n >\n {children}\n </Tag>\n );\n};\n","import type { HTMLAttributes, ReactNode } from 'react';\nimport clx from 'classnames';\n\ntype BadgeVariant =\n | 'default'\n | 'primary'\n | 'success'\n | 'warning'\n | 'danger'\n | 'outline';\n\ntype BadgeSize = 'sm' | 'md';\n\nexport interface BadgeProps extends HTMLAttributes<HTMLSpanElement> {\n variant?: BadgeVariant;\n size?: BadgeSize;\n dot?: boolean;\n children: ReactNode;\n}\n\nexport function Badge({\n variant = 'default',\n size = 'md',\n dot = false,\n className,\n children,\n ...props\n}: BadgeProps) {\n return (\n <span\n className={clx('badge', `badge-${variant}`, `badge-${size}`, className)}\n {...props}\n >\n {dot && <span className={clx('badge-dot', `badge-dot-${variant}`)} />}\n {children}\n </span>\n );\n}\n","import type { HTMLAttributes, ReactNode } from 'react'\n\nexport interface CardProps extends HTMLAttributes<HTMLDivElement> {\n children: ReactNode\n padding?: 'none' | 'sm' | 'md' | 'lg'\n shadow?: boolean\n border?: boolean\n}\n\nexport interface CardHeaderProps extends HTMLAttributes<HTMLDivElement> {\n children: ReactNode\n}\n\nexport interface CardBodyProps extends HTMLAttributes<HTMLDivElement> {\n children: ReactNode\n}\n\nexport interface CardFooterProps extends HTMLAttributes<HTMLDivElement> {\n children: ReactNode\n}\n\nconst paddingClasses = {\n none: '',\n sm: 'p-4',\n md: 'p-6',\n lg: 'p-8',\n}\n\nexport function Card({\n children,\n padding = 'md',\n shadow = true,\n border = true,\n className = '',\n ...props\n}: CardProps) {\n return (\n <div\n className={[\n 'bg-white rounded-xl overflow-hidden',\n border ? 'border border-gray-200' : '',\n shadow ? 'shadow-sm' : '',\n paddingClasses[padding],\n className,\n ]\n .filter(Boolean)\n .join(' ')}\n {...props}\n >\n {children}\n </div>\n )\n}\n\nexport function CardHeader({ children, className = '', ...props }: CardHeaderProps) {\n return (\n <div\n className={['px-6 py-4 border-b border-gray-100', className].filter(Boolean).join(' ')}\n {...props}\n >\n {children}\n </div>\n )\n}\n\nexport function CardBody({ children, className = '', ...props }: CardBodyProps) {\n return (\n <div className={['p-6', className].filter(Boolean).join(' ')} {...props}>\n {children}\n </div>\n )\n}\n\nexport function CardFooter({ children, className = '', ...props }: CardFooterProps) {\n return (\n <div\n className={[\n 'px-6 py-4 border-t border-gray-100 bg-gray-50',\n className,\n ]\n .filter(Boolean)\n .join(' ')}\n {...props}\n >\n {children}\n </div>\n )\n}\n","import type { HTMLAttributes } from 'react';\nimport clx from 'classnames';\n\ntype SpinnerSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\ntype SpinnerColor = 'primary' | 'white' | 'gray';\n\nexport interface SpinnerProps extends HTMLAttributes<HTMLSpanElement> {\n size?: SpinnerSize;\n color?: SpinnerColor;\n label?: string;\n}\n\nexport function Spinner({\n size = 'md',\n color = 'primary',\n label = 'Loading…',\n className = '',\n ...props\n}: SpinnerProps) {\n return (\n <span\n role=\"status\"\n aria-label={label}\n className={clx('spinner-wrapper', className)}\n {...props}\n >\n <span className={clx('spinner', `spinner-${size}`, `spinner-${color}`)} />\n <span className=\"sr-only\">{label}</span>\n </span>\n );\n}\n","import type { HTMLAttributes, ReactNode } from 'react';\nimport clx from 'classnames';\n\ntype AlertVariant = 'info' | 'success' | 'warning' | 'danger';\n\nexport interface AlertProps extends HTMLAttributes<HTMLDivElement> {\n variant?: AlertVariant;\n title?: string;\n children: ReactNode;\n onClose?: () => void;\n}\n\nconst variantIcon: Record<AlertVariant, ReactNode> = {\n info: (\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M11.25 11.25l.041-.02a.75.75 0 011.063.852l-.708 2.836a.75.75 0 001.063.853l.041-.021M21 12a9 9 0 11-18 0 9 9 0 0118 0zm-9-3.75h.008v.008H12V8.25z\"\n />\n ),\n success: (\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M9 12.75L11.25 15 15 9.75M21 12a9 9 0 11-18 0 9 9 0 0118 0z\"\n />\n ),\n warning: (\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M12 9v3.75m-9.303 3.376c-.866 1.5.217 3.374 1.948 3.374h14.71c1.73 0 2.813-1.874 1.948-3.374L13.949 3.378c-.866-1.5-3.032-1.5-3.898 0L2.697 16.126zM12 15.75h.007v.008H12v-.008z\"\n />\n ),\n danger: (\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M12 9v3.75m9-.75a9 9 0 11-18 0 9 9 0 0118 0zm-9 3.75h.008v.008H12v-.008z\"\n />\n ),\n};\n\nexport function Alert({\n variant = 'info',\n title,\n children,\n onClose,\n className = '',\n ...props\n}: AlertProps) {\n return (\n <div\n role=\"alert\"\n className={clx('alert', `alert-${variant}`, 'w-full', className)}\n {...props}\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className={clx('alert-icon', `alert-icon-${variant}`)}\n >\n {variantIcon[variant]}\n </svg>\n <div className=\"flex-1 min-w-0\">\n {title && <p className=\"alert-title\">{title}</p>}\n <div className=\"alert-text\">{children}</div>\n </div>\n {onClose && (\n <button\n onClick={onClose}\n className=\"alert-close-btn\"\n aria-label=\"Close\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M6 18L18 6M6 6l12 12\"\n />\n </svg>\n </button>\n )}\n </div>\n );\n}\n","import { useEffect, useRef } from 'react'\nimport type { ReactNode } from 'react'\nimport { createPortal } from 'react-dom'\n\ntype ModalSize = 'sm' | 'md' | 'lg' | 'xl' | 'full'\n\nexport interface ModalProps {\n open: boolean\n onClose: () => void\n title?: string\n children: ReactNode\n footer?: ReactNode\n size?: ModalSize\n closeOnBackdrop?: boolean\n}\n\nconst sizeClasses: Record<ModalSize, string> = {\n sm: 'max-w-sm',\n md: 'max-w-md',\n lg: 'max-w-lg',\n xl: 'max-w-xl',\n full: 'max-w-full mx-4',\n}\n\nexport function Modal({\n open,\n onClose,\n title,\n children,\n footer,\n size = 'md',\n closeOnBackdrop = true,\n}: ModalProps) {\n const backdropRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n if (!open) return\n const prev = document.body.style.overflow\n document.body.style.overflow = 'hidden'\n return () => {\n document.body.style.overflow = prev\n }\n }, [open])\n\n useEffect(() => {\n if (!open) return\n const onKey = (e: KeyboardEvent) => {\n if (e.key === 'Escape') onClose()\n }\n document.addEventListener('keydown', onKey)\n return () => document.removeEventListener('keydown', onKey)\n }, [open, onClose])\n\n if (!open) return null\n\n return createPortal(\n <div\n ref={backdropRef}\n className=\"fixed inset-0 z-50 flex items-center justify-center p-4 bg-black/50 backdrop-blur-sm\"\n onClick={(e) => {\n if (closeOnBackdrop && e.target === backdropRef.current) onClose()\n }}\n >\n <div\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby={title ? 'modal-title' : undefined}\n className={[\n 'relative w-full bg-white rounded-xl shadow-xl flex flex-col max-h-[90vh]',\n sizeClasses[size],\n ].join(' ')}\n >\n {title && (\n <div className=\"flex items-center justify-between px-6 py-4 border-b border-gray-100 shrink-0\">\n <h2 id=\"modal-title\" className=\"text-lg font-semibold text-gray-900\">\n {title}\n </h2>\n <button\n onClick={onClose}\n className=\"text-gray-400 hover:text-gray-600 transition-colors\"\n aria-label=\"Close modal\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-5 h-5\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M6 18L18 6M6 6l12 12\"\n />\n </svg>\n </button>\n </div>\n )}\n <div className=\"flex-1 overflow-y-auto px-6 py-4\">{children}</div>\n {footer && (\n <div className=\"px-6 py-4 border-t border-gray-100 shrink-0 bg-gray-50 rounded-b-xl\">\n {footer}\n </div>\n )}\n </div>\n </div>,\n document.body,\n )\n}\n","import { forwardRef } from 'react';\nimport type { InputHTMLAttributes } from 'react';\nimport clx from 'classnames';\n\nexport interface CheckboxProps extends Omit<\n InputHTMLAttributes<HTMLInputElement>,\n 'type'\n> {\n label?: string;\n description?: string;\n error?: string;\n indeterminate?: boolean;\n}\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n (\n { label, description, error, indeterminate, className = '', id, ...props },\n ref,\n ) => {\n const inputId = id ?? label?.toLowerCase().replace(/\\s+/g, '-');\n\n return (\n <div className={clx('checkbox-wrapper', className)}>\n <div className=\"checkbox-wrapper-inner\">\n <input\n ref={(el) => {\n if (el) el.indeterminate = indeterminate ?? false;\n if (typeof ref === 'function') ref(el);\n else if (ref) ref.current = el;\n }}\n id={inputId}\n type=\"checkbox\"\n className={clx('checkbox', error && 'has-error')}\n {...props}\n />\n </div>\n {(label || description) && (\n <div>\n {label && (\n <label htmlFor={inputId} className=\"checkbox-label\">\n {label}\n </label>\n )}\n {description && (\n <p className=\"checkbox-description\">{description}</p>\n )}\n {error && <p className=\"checkbox-error\">{error}</p>}\n </div>\n )}\n </div>\n );\n },\n);\n\nCheckbox.displayName = 'Checkbox';\n","import { forwardRef } from 'react';\nimport type { InputHTMLAttributes } from 'react';\nimport clx from 'classnames';\n\ntype ToggleSize = 'sm' | 'md' | 'lg';\n\nexport interface ToggleProps extends Omit<\n InputHTMLAttributes<HTMLInputElement>,\n 'type' | 'size'\n> {\n label?: string;\n description?: string;\n size?: ToggleSize;\n}\n\nexport const Toggle = forwardRef<HTMLInputElement, ToggleProps>(\n ({ label, description, size = 'md', className = '', id, ...props }, ref) => {\n const inputId = id ?? label?.toLowerCase().replace(/\\s+/g, '-');\n\n return (\n <label\n htmlFor={inputId}\n className={clx(\n 'toggle',\n props.disabled && 'toggle-disabled',\n className,\n )}\n >\n <div className={clx('toggle-wrapper', `toggle-wrapper-${size}`)}>\n <input\n ref={ref}\n id={inputId}\n type=\"checkbox\"\n role=\"switch\"\n className=\"sr-only peer\"\n {...props}\n />\n <div className=\"toggle-track\" />\n <div className={clx('toggle-thumb', `toggle-thumb-${size}`)} />\n </div>\n {(label || description) && (\n <div>\n {label && <span className=\"toggle-label\">{label}</span>}\n {description && (\n <span className=\"toggle-description\">{description}</span>\n )}\n </div>\n )}\n </label>\n );\n },\n);\n\nToggle.displayName = 'Toggle';\n","import type { HTMLAttributes, ReactNode } from 'react';\nimport clx from 'classnames';\n\ntype AvatarSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\n\nexport interface AvatarProps extends HTMLAttributes<HTMLSpanElement> {\n src?: string;\n alt?: string;\n name?: string;\n size?: AvatarSize;\n}\n\nexport interface AvatarGroupProps extends HTMLAttributes<HTMLDivElement> {\n max?: number;\n size?: AvatarSize;\n children: ReactNode;\n}\n\nconst bgColors = [\n 'bg-red-500',\n 'bg-orange-500',\n 'bg-amber-500',\n 'bg-emerald-500',\n 'bg-teal-500',\n 'bg-cyan-500',\n 'bg-blue-500',\n 'bg-violet-500',\n 'bg-pink-500',\n];\n\nexport function Avatar({\n src,\n alt,\n name,\n size = 'md',\n className,\n ...props\n}: AvatarProps) {\n const baseClasses = ['avatar', `avatar-${size}`, className];\n\n const nameToColor = (n: string) => {\n let hash = 0;\n for (let i = 0; i < n.length; i++) hash += n.charCodeAt(i);\n return bgColors[hash % bgColors.length];\n };\n\n const getInitials = (name: string) =>\n name\n .split(' ')\n .slice(0, 2)\n .map((n) => n[0])\n .join('')\n .toUpperCase();\n\n if (src) {\n return (\n <span className={clx(baseClasses)} {...props}>\n <img\n src={src}\n alt={alt ?? name ?? ''}\n className=\"w-full h-full object-cover\"\n />\n </span>\n );\n }\n\n if (name) {\n return (\n <span\n className={clx(baseClasses, nameToColor(name))}\n aria-label={name}\n {...props}\n >\n {getInitials(name)}\n </span>\n );\n }\n\n // Fallback icon\n return (\n <span className={clx(baseClasses, 'avatar-fallback')} {...props}>\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"currentColor\"\n viewBox=\"0 0 24 24\"\n className=\"w-3/5 h-3/5\"\n >\n <path\n fillRule=\"evenodd\"\n d=\"M7.5 6a4.5 4.5 0 119 0 4.5 4.5 0 01-9 0zM3.751 20.105a8.25 8.25 0 0116.498 0 .75.75 0 01-.437.695A18.683 18.683 0 0112 22.5c-2.786 0-5.433-.608-7.812-1.7a.75.75 0 01-.437-.695z\"\n clipRule=\"evenodd\"\n />\n </svg>\n </span>\n );\n}\n","import type { ReactNode } from 'react';\nimport cx from 'classnames';\n\ninterface StackProps {\n direction?: 'row' | 'column';\n gap?: number;\n alignItems?: 'start' | 'end' | 'center' | 'baseline' | 'stretch';\n justifyItems?: 'start' | 'end' | 'center' | 'stretch';\n justifyContent?:\n | 'normal'\n | 'start'\n | 'end'\n | 'center'\n | 'between'\n | 'around'\n | 'evenly'\n | 'stretch';\n className?: string;\n children?: ReactNode;\n}\n\nexport const Stack = ({\n direction = 'row',\n gap,\n alignItems = 'start',\n justifyItems = 'start',\n justifyContent = 'normal',\n className,\n children,\n}: StackProps) => {\n const alignItemsMap: Record<string, string> = {\n start: 'items-start',\n end: 'items-end',\n center: 'items-center',\n baseline: 'items-baseline',\n stretch: 'items-stretch',\n };\n\n const justifyItemsMap: Record<string, string> = {\n start: 'justify-items-start',\n end: 'justify-items-end',\n center: 'justify-items-center',\n stretch: 'justify-items-stretch',\n };\n\n const justifyContentMap: Record<string, string> = {\n normal: 'justify-normal',\n start: 'justify-start',\n end: 'justify-end',\n center: 'justify-center',\n between: 'justify-between',\n around: 'justify-around',\n evenly: 'justify-evenly',\n stretch: 'justify-stretch',\n };\n\n return (\n <div\n className={cx(\n 'stack',\n `stack-${direction}`,\n gap && `gap-${gap}`,\n alignItemsMap[alignItems],\n justifyItemsMap[justifyItems],\n justifyContentMap[justifyContent],\n className,\n )}\n >\n {children}\n </div>\n );\n};\n","import type { ElementType, HTMLAttributes, ReactNode } from 'react';\nimport cx from 'classnames';\n\n// ─── Types ────────────────────────────────────────────────────────────────────\n\nexport type ColSpan = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12;\nexport type ColOffset = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11;\nexport type GridCols = 1 | 2 | 3 | 4 | 6 | 12;\nexport type GapSize = 0 | 1 | 2 | 3 | 4 | 5 | 6 | 8 | 10 | 12 | 16;\n\nexport interface GridProps {\n children?: ReactNode;\n cols?: GridCols;\n gap?: GapSize;\n rowGap?: GapSize;\n colGap?: GapSize;\n as?: ElementType;\n className?: string;\n}\n\nexport interface ColProps extends HTMLAttributes<HTMLDivElement> {\n children?: ReactNode;\n /** Výchozí šířka (mobile-first) */\n span?: ColSpan;\n sm?: ColSpan;\n md?: ColSpan;\n lg?: ColSpan;\n xl?: ColSpan;\n /** Přeskočit N sloupců od aktuální pozice (mobile-first) */\n offset?: ColOffset;\n smOffset?: ColOffset;\n mdOffset?: ColOffset;\n lgOffset?: ColOffset;\n xlOffset?: ColOffset;\n}\n\n// ─── Class maps — všechny literální stringy, Tailwind je detekuje při scanu ──\n\nconst colsMap: Record<GridCols, string> = {\n 1: 'grid-cols-1',\n 2: 'grid-cols-2',\n 3: 'grid-cols-3',\n 4: 'grid-cols-4',\n 6: 'grid-cols-6',\n 12: 'grid-cols-12',\n};\n\nconst gapMap: Record<GapSize, string> = {\n 0: 'gap-0',\n 1: 'gap-1',\n 2: 'gap-2',\n 3: 'gap-3',\n 4: 'gap-4',\n 5: 'gap-5',\n 6: 'gap-6',\n 8: 'gap-8',\n 10: 'gap-10',\n 12: 'gap-12',\n 16: 'gap-16',\n};\n\nconst rowGapMap: Record<GapSize, string> = {\n 0: 'gap-y-0',\n 1: 'gap-y-1',\n 2: 'gap-y-2',\n 3: 'gap-y-3',\n 4: 'gap-y-4',\n 5: 'gap-y-5',\n 6: 'gap-y-6',\n 8: 'gap-y-8',\n 10: 'gap-y-10',\n 12: 'gap-y-12',\n 16: 'gap-y-16',\n};\n\nconst colGapMap: Record<GapSize, string> = {\n 0: 'gap-x-0',\n 1: 'gap-x-1',\n 2: 'gap-x-2',\n 3: 'gap-x-3',\n 4: 'gap-x-4',\n 5: 'gap-x-5',\n 6: 'gap-x-6',\n 8: 'gap-x-8',\n 10: 'gap-x-10',\n 12: 'gap-x-12',\n 16: 'gap-x-16',\n};\n\n// Span — bez prefixu (výchozí, mobile-first)\nconst spanMap: Record<ColSpan, string> = {\n 1: 'col-span-1',\n 2: 'col-span-2',\n 3: 'col-span-3',\n 4: 'col-span-4',\n 5: 'col-span-5',\n 6: 'col-span-6',\n 7: 'col-span-7',\n 8: 'col-span-8',\n 9: 'col-span-9',\n 10: 'col-span-10',\n 11: 'col-span-11',\n 12: 'col-span-12',\n};\n\nconst smSpanMap: Record<ColSpan, string> = {\n 1: 'sm:col-span-1',\n 2: 'sm:col-span-2',\n 3: 'sm:col-span-3',\n 4: 'sm:col-span-4',\n 5: 'sm:col-span-5',\n 6: 'sm:col-span-6',\n 7: 'sm:col-span-7',\n 8: 'sm:col-span-8',\n 9: 'sm:col-span-9',\n 10: 'sm:col-span-10',\n 11: 'sm:col-span-11',\n 12: 'sm:col-span-12',\n};\n\nconst mdSpanMap: Record<ColSpan, string> = {\n 1: 'md:col-span-1',\n 2: 'md:col-span-2',\n 3: 'md:col-span-3',\n 4: 'md:col-span-4',\n 5: 'md:col-span-5',\n 6: 'md:col-span-6',\n 7: 'md:col-span-7',\n 8: 'md:col-span-8',\n 9: 'md:col-span-9',\n 10: 'md:col-span-10',\n 11: 'md:col-span-11',\n 12: 'md:col-span-12',\n};\n\nconst lgSpanMap: Record<ColSpan, string> = {\n 1: 'lg:col-span-1',\n 2: 'lg:col-span-2',\n 3: 'lg:col-span-3',\n 4: 'lg:col-span-4',\n 5: 'lg:col-span-5',\n 6: 'lg:col-span-6',\n 7: 'lg:col-span-7',\n 8: 'lg:col-span-8',\n 9: 'lg:col-span-9',\n 10: 'lg:col-span-10',\n 11: 'lg:col-span-11',\n 12: 'lg:col-span-12',\n};\n\nconst xlSpanMap: Record<ColSpan, string> = {\n 1: 'xl:col-span-1',\n 2: 'xl:col-span-2',\n 3: 'xl:col-span-3',\n 4: 'xl:col-span-4',\n 5: 'xl:col-span-5',\n 6: 'xl:col-span-6',\n 7: 'xl:col-span-7',\n 8: 'xl:col-span-8',\n 9: 'xl:col-span-9',\n 10: 'xl:col-span-10',\n 11: 'xl:col-span-11',\n 12: 'xl:col-span-12',\n};\n\n// Offset: přeskočit N sloupců → col-start-(N+1)\nconst offsetMap: Record<ColOffset, string> = {\n 1: 'col-start-2',\n 2: 'col-start-3',\n 3: 'col-start-4',\n 4: 'col-start-5',\n 5: 'col-start-6',\n 6: 'col-start-7',\n 7: 'col-start-8',\n 8: 'col-start-9',\n 9: 'col-start-10',\n 10: 'col-start-11',\n 11: 'col-start-12',\n};\n\nconst smOffsetMap: Record<ColOffset, string> = {\n 1: 'sm:col-start-2',\n 2: 'sm:col-start-3',\n 3: 'sm:col-start-4',\n 4: 'sm:col-start-5',\n 5: 'sm:col-start-6',\n 6: 'sm:col-start-7',\n 7: 'sm:col-start-8',\n 8: 'sm:col-start-9',\n 9: 'sm:col-start-10',\n 10: 'sm:col-start-11',\n 11: 'sm:col-start-12',\n};\n\nconst mdOffsetMap: Record<ColOffset, string> = {\n 1: 'md:col-start-2',\n 2: 'md:col-start-3',\n 3: 'md:col-start-4',\n 4: 'md:col-start-5',\n 5: 'md:col-start-6',\n 6: 'md:col-start-7',\n 7: 'md:col-start-8',\n 8: 'md:col-start-9',\n 9: 'md:col-start-10',\n 10: 'md:col-start-11',\n 11: 'md:col-start-12',\n};\n\nconst lgOffsetMap: Record<ColOffset, string> = {\n 1: 'lg:col-start-2',\n 2: 'lg:col-start-3',\n 3: 'lg:col-start-4',\n 4: 'lg:col-start-5',\n 5: 'lg:col-start-6',\n 6: 'lg:col-start-7',\n 7: 'lg:col-start-8',\n 8: 'lg:col-start-9',\n 9: 'lg:col-start-10',\n 10: 'lg:col-start-11',\n 11: 'lg:col-start-12',\n};\n\nconst xlOffsetMap: Record<ColOffset, string> = {\n 1: 'xl:col-start-2',\n 2: 'xl:col-start-3',\n 3: 'xl:col-start-4',\n 4: 'xl:col-start-5',\n 5: 'xl:col-start-6',\n 6: 'xl:col-start-7',\n 7: 'xl:col-start-8',\n 8: 'xl:col-start-9',\n 9: 'xl:col-start-10',\n 10: 'xl:col-start-11',\n 11: 'xl:col-start-12',\n};\n\n// ─── Components ───────────────────────────────────────────────────────────────\n\nexport const Grid = ({\n children,\n cols = 12,\n gap,\n rowGap,\n colGap,\n as: Tag = 'div',\n className,\n}: GridProps) => (\n <Tag\n className={cx(\n 'grid',\n 'w-full',\n colsMap[cols],\n gap !== undefined && gapMap[gap],\n rowGap !== undefined && rowGapMap[rowGap],\n colGap !== undefined && colGapMap[colGap],\n className,\n )}\n >\n {children}\n </Tag>\n);\n\nGrid.displayName = 'Grid';\n\nexport const Col = ({\n children,\n span,\n sm,\n md,\n lg,\n xl,\n offset,\n smOffset,\n mdOffset,\n lgOffset,\n xlOffset,\n className,\n ...rest\n}: ColProps) => (\n <div\n className={cx(\n span && spanMap[span],\n sm && smSpanMap[sm],\n md && mdSpanMap[md],\n lg && lgSpanMap[lg],\n xl && xlSpanMap[xl],\n offset && offsetMap[offset],\n smOffset && smOffsetMap[smOffset],\n mdOffset && mdOffsetMap[mdOffset],\n lgOffset && lgOffsetMap[lgOffset],\n xlOffset && xlOffsetMap[xlOffset],\n className,\n )}\n {...rest}\n >\n {children}\n </div>\n);\n\nCol.displayName = 'Col';\n","import { useEffect, useId, useRef, useState } from 'react';\nimport clx from 'classnames';\n\nexport interface QuantityInputProps {\n value: number;\n onChange: (value: number) => void;\n min?: number;\n max?: number;\n step?: number;\n disabled?: boolean;\n label?: string;\n error?: string;\n hint?: string;\n id?: string;\n className?: string;\n}\n\nexport const QuantityInput = ({\n value,\n onChange,\n min = 1,\n max = 999,\n step = 1,\n disabled = false,\n label,\n error,\n hint,\n id,\n className,\n}: QuantityInputProps) => {\n const generatedId = useId();\n const inputId = id ?? generatedId;\n const inputRef = useRef<HTMLInputElement>(null);\n\n // Lokální string stav — umožňuje volné psaní, clamping proběhne při blur\n const [inputValue, setInputValue] = useState(String(value));\n\n // Synchronizace při změně value zvenčí (controlled)\n useEffect(() => {\n if (document.activeElement !== inputRef.current) {\n setInputValue(String(value));\n }\n }, [value]);\n\n const clamp = (n: number) => Math.min(max, Math.max(min, n));\n\n const commitValue = (raw: string) => {\n const parsed = parseInt(raw, 10);\n const next = isNaN(parsed) ? value : clamp(parsed);\n setInputValue(String(next));\n if (next !== value) onChange(next);\n };\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const raw = e.target.value.replace(/[^0-9]/g, '');\n setInputValue(raw);\n // Průběžně volej onChange jen pokud je platné číslo\n const parsed = parseInt(raw, 10);\n if (!isNaN(parsed)) onChange(clamp(parsed));\n };\n\n const handleBlur = () => commitValue(inputValue);\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (e.key === 'Enter') {\n commitValue(inputValue);\n inputRef.current?.blur();\n return;\n }\n // Blokuj vše kromě číslic a ovládacích kláves\n const allowed = [\n 'Backspace', 'Delete', 'Tab', 'Escape',\n 'ArrowLeft', 'ArrowRight', 'Home', 'End',\n ];\n if (!allowed.includes(e.key) && !/^[0-9]$/.test(e.key) && !e.metaKey && !e.ctrlKey) {\n e.preventDefault();\n }\n };\n\n const decrement = () => onChange(clamp(value - step));\n const increment = () => onChange(clamp(value + step));\n\n const canDecrement = value - step >= min;\n const canIncrement = value + step <= max;\n\n return (\n <div className={clx('quantity-input-wrapper', className)}>\n {label && (\n <label htmlFor={inputId} className=\"input-label\">\n {label}\n </label>\n )}\n\n <div className={clx('quantity-input', error && 'has-error', disabled && 'is-disabled')}>\n <button\n type=\"button\"\n className=\"quantity-btn\"\n onClick={decrement}\n disabled={disabled || !canDecrement}\n aria-label=\"Snížit množství\"\n tabIndex={-1}\n >\n <MinusIcon />\n </button>\n\n <input\n ref={inputRef}\n id={inputId}\n type=\"text\"\n inputMode=\"numeric\"\n className=\"quantity-field\"\n value={inputValue}\n onChange={handleChange}\n onBlur={handleBlur}\n onKeyDown={handleKeyDown}\n disabled={disabled}\n aria-label={label ?? 'Množství'}\n aria-valuemin={min}\n aria-valuemax={max}\n aria-valuenow={value}\n />\n\n <button\n type=\"button\"\n className=\"quantity-btn\"\n onClick={increment}\n disabled={disabled || !canIncrement}\n aria-label=\"Zvýšit množství\"\n tabIndex={-1}\n >\n <PlusIcon />\n </button>\n </div>\n\n {(error || hint) && (\n <p className={clx('helper-text', error && 'has-error')}>{error ?? hint}</p>\n )}\n </div>\n );\n};\n\nQuantityInput.displayName = 'QuantityInput';\n\nconst MinusIcon = () => (\n <svg width=\"12\" height=\"2\" viewBox=\"0 0 12 2\" fill=\"none\" aria-hidden=\"true\">\n <path d=\"M1 1H11\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" />\n </svg>\n);\n\nconst PlusIcon = () => (\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" aria-hidden=\"true\">\n <path d=\"M6 1V11M1 6H11\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" />\n </svg>\n);\n","'use client';\n\nimport type { ButtonHTMLAttributes } from 'react';\nimport clx from 'classnames';\n\nexport interface PaginationProps {\n page: number;\n totalPages: number;\n onPageChange: (page: number) => void;\n siblingsCount?: number;\n}\n\nconst range = (start: number, end: number) =>\n Array.from({ length: end - start + 1 }, (_, i) => start + i);\n\nconst buildPages = (\n page: number,\n totalPages: number,\n siblings: number,\n): (number | '…')[] => {\n const totalNumbers = siblings * 2 + 5;\n\n if (totalPages <= totalNumbers) return range(1, totalPages);\n\n const leftSibling = Math.max(page - siblings, 1);\n const rightSibling = Math.min(page + siblings, totalPages);\n const showLeftDots = leftSibling > 2;\n const showRightDots = rightSibling < totalPages - 1;\n\n if (!showLeftDots && showRightDots) {\n const leftRange = range(1, 3 + siblings * 2);\n return [...leftRange, '…', totalPages];\n }\n\n if (showLeftDots && !showRightDots) {\n const rightRange = range(totalPages - (2 + siblings * 2), totalPages);\n return [1, '…', ...rightRange];\n }\n\n return [1, '…', ...range(leftSibling, rightSibling), '…', totalPages];\n};\n\nconst PageButton = ({\n active,\n disabled,\n children,\n ...props\n}: ButtonHTMLAttributes<HTMLButtonElement> & { active?: boolean }) => {\n return (\n <button\n disabled={disabled}\n className={clx(\n 'pagination-button',\n `pagination-button-${active ? 'active' : 'inactive'}`,\n )}\n {...props}\n >\n {children}\n </button>\n );\n};\n\nexport const Pagination = ({\n page,\n totalPages,\n onPageChange,\n siblingsCount = 1,\n}: PaginationProps) => {\n const pages = buildPages(page, totalPages, siblingsCount);\n\n return (\n <nav aria-label=\"Pagination\" className=\"pagination\">\n <PageButton\n disabled={page <= 1}\n onClick={() => onPageChange(page - 1)}\n aria-label=\"Previous page\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M15.75 19.5L8.25 12l7.5-7.5\"\n />\n </svg>\n </PageButton>\n\n {pages.map((p, i) =>\n p === '…' ? (\n <span key={`dots-${i}`} className=\"pagination-dots\">\n …\n </span>\n ) : (\n <PageButton\n key={p}\n active={p === page}\n onClick={() => onPageChange(p)}\n aria-label={`Page ${p}`}\n aria-current={p === page ? 'page' : undefined}\n >\n {p}\n </PageButton>\n ),\n )}\n\n <PageButton\n disabled={page >= totalPages}\n onClick={() => onPageChange(page + 1)}\n aria-label=\"Next page\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M8.25 4.5l7.5 7.5-7.5 7.5\"\n />\n </svg>\n </PageButton>\n </nav>\n );\n};\n","import cx from 'classnames';\n\ninterface CarouselBtnProps {\n direction: 'prev' | 'next';\n disabled?: boolean;\n onClick?: () => void;\n}\n\nexport const CarouselBtn = ({\n direction,\n disabled,\n onClick,\n}: CarouselBtnProps) => {\n return (\n <button\n onClick={onClick}\n disabled={disabled}\n className={cx(\n 'carousel-btn',\n direction === 'prev' ? 'carousel-btn-prev' : 'carousel-btn-next',\n )}\n aria-label={direction === 'prev' ? 'Previous slide' : 'Next slide'}\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-5 h-5\"\n >\n {direction === 'prev' ? (\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M15.75 19.5L8.25 12l7.5-7.5\"\n />\n ) : (\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M8.25 4.5l7.5 7.5-7.5 7.5\"\n />\n )}\n </svg>\n </button>\n );\n};\n","import {\n useState,\n useEffect,\n useLayoutEffect,\n useCallback,\n useRef,\n Children,\n Fragment,\n} from 'react';\nimport type { ReactNode, HTMLAttributes, CSSProperties } from 'react';\nimport clx from 'classnames';\nimport { CarouselBtn } from './CarouselBtn';\n\nexport interface CarouselCoverProps {\n /** Image URL rendered as background-size: cover */\n src: string;\n alt?: string;\n children?: ReactNode;\n className?: string;\n style?: CSSProperties;\n}\n\n/** Drop inside a Carousel slide — renders image as cover background */\nexport function CarouselCover({\n src,\n alt,\n children,\n className,\n style,\n}: CarouselCoverProps) {\n return (\n <div\n role={alt ? 'img' : undefined}\n aria-label={alt}\n className={clx('carousel-cover', className)}\n style={{ backgroundImage: `url(${src})`, ...style }}\n >\n {children}\n </div>\n );\n}\n\nexport interface CarouselProps extends HTMLAttributes<HTMLDivElement> {\n children: ReactNode;\n /** Number of slides visible at once */\n slidesPerView?: number;\n /** Gap between slides in px */\n gap?: number;\n /** Fixed slide height in px */\n height?: number;\n /** Show prev/next arrow buttons */\n arrows?: boolean;\n /** Show dot navigation indicators */\n dots?: boolean;\n autoPlay?: boolean;\n autoPlayInterval?: number;\n /** Wrap around from last to first slide */\n loop?: boolean;\n}\n\nexport function Carousel({\n children,\n slidesPerView = 1,\n gap = 16,\n height,\n arrows = true,\n dots = true,\n autoPlay = false,\n autoPlayInterval = 4000,\n loop = false,\n className,\n ...props\n}: CarouselProps) {\n const slides = Children.toArray(children);\n const count = slides.length;\n const maxIndex = loop ? count - 1 : Math.max(0, count - slidesPerView);\n const hasNav = count > slidesPerView;\n\n const [current, setCurrent] = useState(0);\n const [paused, setPaused] = useState(false);\n const trackRef = useRef<HTMLDivElement>(null);\n const viewportRef = useRef<HTMLDivElement>(null);\n const timerRef = useRef<ReturnType<typeof setInterval> | null>(null);\n const touchStartX = useRef<number | null>(null);\n\n const applyTransform = useCallback((index: number, animated = true) => {\n const track = trackRef.current;\n if (!track) return;\n const slide = track.children[index] as HTMLElement | undefined;\n if (!slide) return;\n if (!animated) {\n track.style.transition = 'none';\n track.getBoundingClientRect();\n }\n track.style.transform = `translateX(${-slide.offsetLeft}px)`;\n if (!animated) {\n track.getBoundingClientRect();\n track.style.transition = '';\n }\n }, []);\n\n const goTo = useCallback(\n (index: number) => {\n const next = loop\n ? ((index % count) + count) % count\n : Math.max(0, Math.min(index, maxIndex));\n setCurrent(next);\n },\n [count, loop, maxIndex],\n );\n\n const prev = useCallback(() => goTo(current - 1), [current, goTo]);\n const next = useCallback(() => goTo(current + 1), [current, goTo]);\n\n useLayoutEffect(() => {\n applyTransform(current);\n }, [current, applyTransform]);\n\n useEffect(() => {\n const viewport = viewportRef.current;\n if (!viewport) return;\n const observer = new ResizeObserver(() => applyTransform(current, false));\n observer.observe(viewport);\n return () => observer.disconnect();\n }, [current, applyTransform]);\n\n useEffect(() => {\n if (!autoPlay || paused || !hasNav) return;\n timerRef.current = setInterval(next, autoPlayInterval);\n return () => {\n if (timerRef.current) clearInterval(timerRef.current);\n };\n }, [autoPlay, paused, autoPlayInterval, next, hasNav]);\n\n const handleTouchStart = (e: React.TouchEvent) => {\n touchStartX.current = e.touches[0].clientX;\n };\n const handleTouchEnd = (e: React.TouchEvent) => {\n if (touchStartX.current === null) return;\n const delta = e.changedTouches[0].clientX - touchStartX.current;\n if (Math.abs(delta) > 50) delta < 0 ? next() : prev();\n touchStartX.current = null;\n };\n\n if (count === 0) return null;\n\n const canGoPrev = loop || current > 0;\n const canGoNext = loop || current < maxIndex;\n\n const slideWidth = `calc((100% - ${gap}px * ${slidesPerView - 1}) / ${slidesPerView})`;\n\n return (\n <div\n className={clx('carousel-wrapper', className)}\n onMouseEnter={() => setPaused(true)}\n onMouseLeave={() => setPaused(false)}\n onTouchStart={handleTouchStart}\n onTouchEnd={handleTouchEnd}\n {...props}\n >\n <div\n ref={viewportRef}\n className=\"carousel-viewport\"\n style={height ? { height } : undefined}\n >\n <div\n ref={trackRef}\n className=\"carousel-track\"\n style={{ gap: `${gap}px` }}\n >\n {slides.map((slide, i) => (\n <div\n key={i}\n className=\"carousel-slide\"\n style={{\n minWidth: slideWidth,\n maxWidth: slideWidth,\n ...(height && { height }),\n }}\n aria-hidden={i < current || i >= current + slidesPerView}\n >\n {slide}\n </div>\n ))}\n </div>\n </div>\n {arrows && hasNav && (\n <Fragment>\n <CarouselBtn direction=\"prev\" disabled={!canGoPrev} onClick={prev} />\n <CarouselBtn direction=\"next\" disabled={!canGoNext} onClick={next} />\n </Fragment>\n )}\n {dots && hasNav && (\n <div className=\"carousel-dots\">\n {Array.from({ length: maxIndex + 1 }).map((_, i) => (\n <button\n key={i}\n onClick={() => goTo(i)}\n className={clx(\n 'carousel-dot',\n i === current && 'carousel-dot-active',\n )}\n aria-label={`Go to slide ${i + 1}`}\n aria-current={i === current ? 'true' : undefined}\n />\n ))}\n </div>\n )}\n </div>\n );\n}\n","import { useRef, useState } from 'react';\nimport type { ReactNode, KeyboardEvent } from 'react';\nimport { Input } from '../common/Input/Input';\n\nexport interface CurrencyOption {\n code: string;\n symbol: string;\n label: string;\n}\n\nexport interface LocaleOption {\n code: string;\n label: string;\n flag?: string;\n}\n\nexport interface HeaderProps {\n /** Logo — ReactNode (image, SVG, text) */\n logo?: ReactNode;\n /** Search placeholder */\n searchPlaceholder?: string;\n onSearch?: (query: string) => void;\n /** Cart */\n cartItemCount?: number;\n onCartClick?: () => void;\n /** Customer */\n isLoggedIn?: boolean;\n customerName?: string;\n onCustomerClick?: () => void;\n /** Currency */\n currencies?: CurrencyOption[];\n selectedCurrency?: string;\n onCurrencyChange?: (code: string) => void;\n /** Locale / eshop */\n locales?: LocaleOption[];\n selectedLocale?: string;\n onLocaleChange?: (code: string) => void;\n /** Extra right slot */\n rightSlot?: ReactNode;\n}\n\n// ─── Small internal dropdown ────────────────────────────────────────────────\n\ninterface DropdownProps<T extends { label: string }> {\n trigger: ReactNode;\n items: T[];\n onSelect: (item: T) => void;\n getKey: (item: T) => string;\n renderItem?: (item: T) => ReactNode;\n}\n\nfunction Dropdown<T extends { label: string }>({\n trigger,\n items,\n onSelect,\n getKey,\n renderItem,\n}: DropdownProps<T>) {\n const [open, setOpen] = useState(false);\n const ref = useRef<HTMLDivElement>(null);\n\n const close = () => setOpen(false);\n\n // Close on outside click\n const handleBlur = (e: React.FocusEvent) => {\n if (!ref.current?.contains(e.relatedTarget as Node)) close();\n };\n\n const onKey = (e: KeyboardEvent) => {\n if (e.key === 'Escape') close();\n };\n\n return (\n <div ref={ref} className=\"relative\" onBlur={handleBlur} onKeyDown={onKey}>\n <div\n role=\"button\"\n tabIndex={0}\n onClick={() => setOpen((v) => !v)}\n onKeyDown={(e) => e.key === 'Enter' && setOpen((v) => !v)}\n className=\"cursor-pointer\"\n >\n {trigger}\n </div>\n {open && (\n <ul\n role=\"menu\"\n className=\"absolute right-0 top-full mt-1 z-50 min-w-28 bg-white rounded-lg shadow-lg border border-gray-100 py-1 text-sm\"\n >\n {items.map((item) => (\n <li key={getKey(item)} role=\"none\">\n <button\n role=\"menuitem\"\n className=\"w-full px-3 py-1.5 text-left hover:bg-gray-50 text-gray-700 whitespace-nowrap\"\n onClick={() => {\n onSelect(item);\n close();\n }}\n >\n {renderItem ? renderItem(item) : item.label}\n </button>\n </li>\n ))}\n </ul>\n )}\n </div>\n );\n}\n\n// ─── Search icon ─────────────────────────────────────────────────────────────\n\nfunction SearchIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M21 21l-5.197-5.197m0 0A7.5 7.5 0 105.196 15.803a7.5 7.5 0 0010.607 10.607z\"\n />\n </svg>\n );\n}\n\n// ─── Header ──────────────────────────────────────────────────────────────────\n\nexport function Header({\n logo,\n searchPlaceholder = 'Hledat produkty…',\n onSearch,\n cartItemCount = 0,\n onCartClick,\n isLoggedIn = false,\n customerName,\n onCustomerClick,\n currencies = [],\n selectedCurrency,\n onCurrencyChange,\n locales = [],\n selectedLocale,\n onLocaleChange,\n rightSlot,\n}: HeaderProps) {\n const [searchQuery, setSearchQuery] = useState('');\n\n const activeCurrency = currencies.find((c) => c.code === selectedCurrency);\n const activeLocale = locales.find((l) => l.code === selectedLocale);\n\n const handleSearchKey = (e: KeyboardEvent<HTMLInputElement>) => {\n if (e.key === 'Enter') onSearch?.(searchQuery);\n };\n\n return (\n <header className=\"bg-white border-b border-gray-200 sticky top-0 z-40\">\n <div className=\"max-w-7xl mx-auto px-4 h-16 flex items-center gap-4\">\n {/* Logo */}\n <div className=\"shrink-0\">\n {logo ?? (\n <span className=\"text-xl font-bold text-primary-600 tracking-tight\">\n shopito\n </span>\n )}\n </div>\n\n {/* Search */}\n <div className=\"flex-1 max-w-xl\">\n <Input\n placeholder={searchPlaceholder}\n value={searchQuery}\n onChange={(e: any) => setSearchQuery(e.target.value)}\n onKeyDown={handleSearchKey}\n leftIcon={<SearchIcon />}\n rightIcon={\n searchQuery ? (\n <button\n onClick={() => {\n setSearchQuery('');\n onSearch?.('');\n }}\n className=\"hover:text-gray-600 transition-colors\"\n aria-label=\"Clear search\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-3.5 h-3.5\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M6 18L18 6M6 6l12 12\"\n />\n </svg>\n </button>\n ) : undefined\n }\n />\n </div>\n\n {/* Right controls */}\n <div className=\"flex items-center gap-1 shrink-0 ml-auto\">\n {/* Currency switcher */}\n {currencies.length > 0 && (\n <Dropdown\n trigger={\n <button className=\"flex items-center gap-1 px-2 py-1.5 rounded-md text-sm text-gray-600 hover:bg-gray-50 transition-colors font-medium\">\n <span>{activeCurrency?.symbol ?? selectedCurrency}</span>\n <span className=\"text-xs text-gray-400\">\n {activeCurrency?.code ?? selectedCurrency}\n </span>\n <ChevronDown className=\"w-3 h-3 text-gray-400\" />\n </button>\n }\n items={currencies}\n getKey={(c) => c.code}\n onSelect={(c) => onCurrencyChange?.(c.code)}\n renderItem={(c) => (\n <span className=\"flex items-center gap-2\">\n <span className=\"w-6 text-center font-medium text-gray-500\">\n {c.symbol}\n </span>\n <span>{c.label}</span>\n </span>\n )}\n />\n )}\n\n {/* Locale switcher */}\n {locales.length > 0 && (\n <Dropdown\n trigger={\n <button className=\"flex items-center gap-1 px-2 py-1.5 rounded-md text-sm text-gray-600 hover:bg-gray-50 transition-colors\">\n {activeLocale?.flag && (\n <span className=\"text-base leading-none\">\n {activeLocale.flag}\n </span>\n )}\n <span className=\"font-medium uppercase\">\n {activeLocale?.code ?? selectedLocale}\n </span>\n <ChevronDown className=\"w-3 h-3 text-gray-400\" />\n </button>\n }\n items={locales}\n getKey={(l) => l.code}\n onSelect={(l) => onLocaleChange?.(l.code)}\n renderItem={(l) => (\n <span className=\"flex items-center gap-2\">\n {l.flag && <span className=\"text-base\">{l.flag}</span>}\n <span>{l.label}</span>\n </span>\n )}\n />\n )}\n\n {/* Divider */}\n {(currencies.length > 0 || locales.length > 0) && (\n <div className=\"w-px h-5 bg-gray-200 mx-1\" />\n )}\n\n {/* Customer button */}\n <button\n onClick={onCustomerClick}\n className=\"flex items-center gap-1.5 px-2.5 py-1.5 rounded-md text-sm text-gray-600 hover:bg-gray-50 transition-colors\"\n aria-label={isLoggedIn ? 'My account' : 'Sign in'}\n >\n {isLoggedIn ? (\n <>\n <div className=\"w-6 h-6 rounded-full bg-primary-600 text-white flex items-center justify-center text-xs font-bold\">\n {(customerName ?? 'U')[0].toUpperCase()}\n </div>\n {customerName && (\n <span className=\"hidden sm:block font-medium max-w-32 truncate\">\n {customerName}\n </span>\n )}\n </>\n ) : (\n <>\n <UserIcon className=\"w-5 h-5\" />\n <span className=\"hidden sm:block font-medium\">\n Přihlásit se\n </span>\n </>\n )}\n </button>\n\n {/* Cart */}\n <button\n onClick={onCartClick}\n className=\"relative flex items-center gap-1.5 px-2.5 py-1.5 rounded-md text-sm text-gray-600 hover:bg-gray-50 transition-colors\"\n aria-label={`Cart, ${cartItemCount} items`}\n >\n <CartIcon className=\"w-5 h-5\" />\n <span className=\"hidden sm:block font-medium\">Košík</span>\n {cartItemCount > 0 && (\n <span className=\"absolute -top-0.5 -right-0.5 min-w-4.5 h-4.5 flex items-center justify-center rounded-full bg-primary-600 text-white text-[10px] font-bold leading-none px-1\">\n {cartItemCount > 99 ? '99+' : cartItemCount}\n </span>\n )}\n </button>\n\n {rightSlot}\n </div>\n </div>\n </header>\n );\n}\n\n// ─── Icon helpers ─────────────────────────────────────────────────────────────\n\nfunction ChevronDown({ className }: { className?: string }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className={className}\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M19.5 8.25l-7.5 7.5-7.5-7.5\"\n />\n </svg>\n );\n}\n\nfunction UserIcon({ className }: { className?: string }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className={className}\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M15.75 6a3.75 3.75 0 11-7.5 0 3.75 3.75 0 017.5 0zM4.501 20.118a7.5 7.5 0 0114.998 0A17.933 17.933 0 0112 21.75c-2.676 0-5.216-.584-7.499-1.632z\"\n />\n </svg>\n );\n}\n\nfunction CartIcon({ className }: { className?: string }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className={className}\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M2.25 3h1.386c.51 0 .955.343 1.087.835l.383 1.437M7.5 14.25a3 3 0 00-3 3h15.75m-12.75-3h11.218c1.121-2.3 2.1-4.684 2.924-7.138a60.114 60.114 0 00-16.536-1.84M7.5 14.25L5.106 5.272M6 20.25a.75.75 0 11-1.5 0 .75.75 0 011.5 0zm12.75 0a.75.75 0 11-1.5 0 .75.75 0 011.5 0z\"\n />\n </svg>\n );\n}\n","import { useState } from 'react'\n\nexport interface Category {\n id: string\n label: string\n icon?: string\n count?: number\n children?: Category[]\n}\n\nexport interface CategoryTreeProps {\n categories: Category[]\n activeId?: string\n onSelect?: (category: Category) => void\n /** Show product counts */\n showCounts?: boolean\n /** All nodes expanded by default */\n defaultExpandAll?: boolean\n className?: string\n}\n\ninterface TreeNodeProps {\n node: Category\n activeId: string | undefined\n onSelect: (category: Category) => void\n showCounts: boolean\n depth: number\n defaultExpandAll: boolean\n}\n\nfunction TreeNode({\n node,\n activeId,\n onSelect,\n showCounts,\n depth,\n defaultExpandAll,\n}: TreeNodeProps) {\n const hasChildren = node.children && node.children.length > 0\n const [expanded, setExpanded] = useState(defaultExpandAll || isAncestorOf(node, activeId))\n const isActive = node.id === activeId\n\n return (\n <li>\n <div\n className={[\n 'group flex items-center gap-1.5 rounded-lg px-2 py-1.5 cursor-pointer select-none',\n 'transition-colors text-sm',\n isActive\n ? 'bg-primary-50 text-primary-700 font-medium'\n : 'text-gray-700 hover:bg-gray-50 hover:text-gray-900',\n depth > 0 ? `ml-${Math.min(depth * 4, 8)}` : '',\n ]\n .filter(Boolean)\n .join(' ')}\n style={depth > 0 ? { marginLeft: depth * 16 } : undefined}\n onClick={() => {\n onSelect(node)\n if (hasChildren) setExpanded((v) => !v)\n }}\n role=\"button\"\n tabIndex={0}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n onSelect(node)\n if (hasChildren) setExpanded((v) => !v)\n }\n }}\n aria-expanded={hasChildren ? expanded : undefined}\n >\n {/* Expand toggle */}\n {hasChildren ? (\n <span\n className={`shrink-0 text-gray-400 transition-transform duration-150 ${expanded ? 'rotate-90' : ''}`}\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-3.5 h-3.5\"\n >\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M8.25 4.5l7.5 7.5-7.5 7.5\" />\n </svg>\n </span>\n ) : (\n <span className=\"w-3.5 shrink-0\" />\n )}\n\n {/* Icon */}\n {node.icon && <span className=\"text-base leading-none\">{node.icon}</span>}\n\n {/* Label */}\n <span className=\"flex-1 truncate\">{node.label}</span>\n\n {/* Count */}\n {showCounts && node.count !== undefined && (\n <span\n className={`text-xs rounded-full px-1.5 py-0.5 font-medium ${\n isActive ? 'bg-primary-100 text-primary-600' : 'bg-gray-100 text-gray-500'\n }`}\n >\n {node.count}\n </span>\n )}\n </div>\n\n {/* Children */}\n {hasChildren && expanded && (\n <ul role=\"group\">\n {node.children!.map((child) => (\n <TreeNode\n key={child.id}\n node={child}\n activeId={activeId}\n onSelect={onSelect}\n showCounts={showCounts}\n depth={depth + 1}\n defaultExpandAll={defaultExpandAll}\n />\n ))}\n </ul>\n )}\n </li>\n )\n}\n\nfunction isAncestorOf(node: Category, activeId: string | undefined): boolean {\n if (!activeId) return false\n if (!node.children) return false\n return node.children.some(\n (c) => c.id === activeId || isAncestorOf(c, activeId),\n )\n}\n\nexport function CategoryTree({\n categories,\n activeId,\n onSelect,\n showCounts = true,\n defaultExpandAll = false,\n className = '',\n ...props\n}: CategoryTreeProps) {\n const handleSelect = (cat: Category) => onSelect?.(cat)\n\n return (\n <nav\n aria-label=\"Category navigation\"\n className={['w-full', className].filter(Boolean).join(' ')}\n {...props}\n >\n <ul role=\"tree\" className=\"space-y-0.5\">\n {categories.map((cat) => (\n <TreeNode\n key={cat.id}\n node={cat}\n activeId={activeId}\n onSelect={handleSelect}\n showCounts={showCounts}\n depth={0}\n defaultExpandAll={defaultExpandAll}\n />\n ))}\n </ul>\n </nav>\n )\n}\n","import { useState, useRef } from 'react'\n\nexport interface MegaMenuSubItem {\n id: string\n label: string\n href?: string\n badge?: string\n}\n\nexport interface MegaMenuColumn {\n heading?: string\n items: MegaMenuSubItem[]\n}\n\nexport interface MegaMenuFeatured {\n image?: string\n eyebrow?: string\n title: string\n description?: string\n cta?: string\n href?: string\n}\n\nexport interface MegaMenuItem {\n id: string\n label: string\n icon?: string\n href?: string\n /** If columns are present, hovering opens the mega panel */\n columns?: MegaMenuColumn[]\n featured?: MegaMenuFeatured\n}\n\nexport interface MegaMenuProps {\n items: MegaMenuItem[]\n activeId?: string\n onNavigate?: (item: MegaMenuSubItem | MegaMenuItem) => void\n}\n\n// ─── Mega panel ──────────────────────────────────────────────────────────────\n\ninterface MegaPanelProps {\n item: MegaMenuItem\n onNavigate: (subItem: MegaMenuSubItem | MegaMenuItem) => void\n onClose: () => void\n}\n\nfunction MegaPanel({ item, onNavigate, onClose }: MegaPanelProps) {\n if (!item.columns?.length) return null\n\n return (\n <div className=\"absolute left-0 right-0 top-full z-50 bg-white border-b border-gray-200 shadow-lg\">\n <div className=\"max-w-7xl mx-auto px-4 py-6 flex gap-8\">\n {/* Columns */}\n <div className=\"flex-1 grid grid-cols-2 md:grid-cols-3 lg:grid-cols-4 gap-6\">\n {item.columns.map((col, ci) => (\n <div key={ci}>\n {col.heading && (\n <p className=\"text-xs font-semibold uppercase tracking-wider text-gray-400 mb-2\">\n {col.heading}\n </p>\n )}\n <ul className=\"space-y-1\">\n {col.items.map((sub) => (\n <li key={sub.id}>\n <button\n className=\"flex items-center gap-1.5 text-sm text-gray-700 hover:text-primary-600 transition-colors py-0.5\"\n onClick={() => {\n onNavigate(sub)\n onClose()\n }}\n >\n {sub.label}\n {sub.badge && (\n <span className=\"text-[10px] font-semibold px-1.5 py-0.5 rounded-full bg-danger-50 text-danger-600 leading-none\">\n {sub.badge}\n </span>\n )}\n </button>\n </li>\n ))}\n </ul>\n </div>\n ))}\n </div>\n\n {/* Featured card */}\n {item.featured && (\n <div className=\"w-52 shrink-0\">\n <button\n className=\"group block w-full rounded-xl overflow-hidden border border-gray-100 text-left hover:shadow-md transition-shadow\"\n onClick={() => {\n onNavigate(item)\n onClose()\n }}\n >\n {item.featured.image ? (\n <img\n src={item.featured.image}\n alt={item.featured.title}\n className=\"w-full h-28 object-cover\"\n />\n ) : (\n <div className=\"w-full h-28 bg-linear-to-br from-primary-100 to-primary-200 flex items-center justify-center text-4xl\">\n {item.icon ?? '🛍️'}\n </div>\n )}\n <div className=\"p-3\">\n {item.featured.eyebrow && (\n <p className=\"text-[10px] font-semibold uppercase tracking-wider text-primary-500 mb-0.5\">\n {item.featured.eyebrow}\n </p>\n )}\n <p className=\"text-sm font-semibold text-gray-900 group-hover:text-primary-600 transition-colors\">\n {item.featured.title}\n </p>\n {item.featured.description && (\n <p className=\"text-xs text-gray-500 mt-0.5 line-clamp-2\">\n {item.featured.description}\n </p>\n )}\n {item.featured.cta && (\n <span className=\"inline-block mt-2 text-xs font-medium text-primary-600\">\n {item.featured.cta} →\n </span>\n )}\n </div>\n </button>\n </div>\n )}\n </div>\n </div>\n )\n}\n\n// ─── MegaMenu ────────────────────────────────────────────────────────────────\n\nexport function MegaMenu({\n items,\n activeId,\n onNavigate,\n}: MegaMenuProps) {\n const [openId, setOpenId] = useState<string | null>(null)\n const timeoutRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n\n const open = (id: string) => {\n if (timeoutRef.current) clearTimeout(timeoutRef.current)\n setOpenId(id)\n }\n\n const scheduleClose = () => {\n timeoutRef.current = setTimeout(() => setOpenId(null), 120)\n }\n\n const cancelClose = () => {\n if (timeoutRef.current) clearTimeout(timeoutRef.current)\n }\n\n const activeItem = items.find((i) => i.id === openId)\n\n return (\n <nav\n aria-label=\"Main navigation\"\n className=\"relative bg-white border-b border-gray-100\"\n onMouseLeave={scheduleClose}\n >\n <div className=\"max-w-7xl mx-auto px-4\">\n <ul className=\"flex items-center gap-0\" role=\"menubar\">\n {items.map((item) => {\n const hasMega = !!item.columns?.length\n const isOpen = openId === item.id\n const isActive = activeId === item.id\n\n return (\n <li key={item.id} role=\"none\">\n <button\n role=\"menuitem\"\n aria-haspopup={hasMega ? 'true' : undefined}\n aria-expanded={hasMega ? isOpen : undefined}\n className={[\n 'flex items-center gap-1.5 px-4 py-3.5 text-sm font-medium transition-colors relative',\n 'outline-none focus-visible:ring-2 focus-visible:ring-inset focus-visible:ring-primary-500',\n isActive || isOpen\n ? 'text-primary-600'\n : 'text-gray-700 hover:text-gray-900',\n isOpen\n ? 'after:absolute after:bottom-0 after:left-0 after:right-0 after:h-0.5 after:bg-primary-600'\n : '',\n ]\n .filter(Boolean)\n .join(' ')}\n onMouseEnter={() => hasMega ? open(item.id) : setOpenId(null)}\n onFocus={() => hasMega && open(item.id)}\n onClick={() => {\n if (!hasMega) {\n onNavigate?.(item)\n setOpenId(null)\n }\n }}\n >\n {item.icon && <span className=\"text-base leading-none\">{item.icon}</span>}\n {item.label}\n {hasMega && (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className={`w-3.5 h-3.5 transition-transform duration-150 ${isOpen ? 'rotate-180' : ''}`}\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M19.5 8.25l-7.5 7.5-7.5-7.5\"\n />\n </svg>\n )}\n </button>\n </li>\n )\n })}\n </ul>\n </div>\n\n {/* Mega panel */}\n {activeItem?.columns?.length && (\n <div\n onMouseEnter={cancelClose}\n onMouseLeave={scheduleClose}\n >\n <MegaPanel\n item={activeItem}\n onNavigate={(sub) => onNavigate?.(sub)}\n onClose={() => setOpenId(null)}\n />\n </div>\n )}\n </nav>\n )\n}\n","import { useState, useEffect, useCallback, useRef } from 'react'\n\nexport interface Banner {\n id: string\n /** Background image URL or gradient CSS value */\n backgroundImage?: string\n backgroundColor?: string\n /** Overlaid text content */\n eyebrow?: string\n title: string\n subtitle?: string\n ctaLabel?: string\n ctaHref?: string\n onCtaClick?: () => void\n /** Image on the right side of the banner */\n sideImage?: string\n /** Text colors — default to white for dark backgrounds */\n textColor?: 'light' | 'dark'\n}\n\nexport interface BannerCarouselProps {\n banners: Banner[]\n autoPlay?: boolean\n autoPlayInterval?: number\n /** Show arrow navigation */\n arrows?: boolean\n /** Show dot indicators */\n dots?: boolean\n className?: string\n /** Aspect ratio of the banner — default 3/1 */\n aspectRatio?: string\n}\n\nexport function BannerCarousel({\n banners,\n autoPlay = true,\n autoPlayInterval = 5000,\n arrows = true,\n dots = true,\n className = '',\n aspectRatio = '3 / 1',\n}: BannerCarouselProps) {\n const [current, setCurrent] = useState(0)\n const [paused, setPaused] = useState(false)\n const timerRef = useRef<ReturnType<typeof setInterval> | null>(null)\n const trackRef = useRef<HTMLDivElement>(null)\n\n const count = banners.length\n\n const goTo = useCallback(\n (index: number) => {\n setCurrent(((index % count) + count) % count)\n },\n [count],\n )\n\n const prev = () => goTo(current - 1)\n const next = useCallback(() => goTo(current + 1), [current, goTo])\n\n // Auto-play\n useEffect(() => {\n if (!autoPlay || paused || count <= 1) return\n timerRef.current = setInterval(next, autoPlayInterval)\n return () => {\n if (timerRef.current) clearInterval(timerRef.current)\n }\n }, [autoPlay, paused, autoPlayInterval, next, count])\n\n // Swipe support\n const touchStartX = useRef<number | null>(null)\n const handleTouchStart = (e: React.TouchEvent) => {\n touchStartX.current = e.touches[0].clientX\n }\n const handleTouchEnd = (e: React.TouchEvent) => {\n if (touchStartX.current === null) return\n const delta = e.changedTouches[0].clientX - touchStartX.current\n if (Math.abs(delta) > 50) delta < 0 ? next() : prev()\n touchStartX.current = null\n }\n\n if (count === 0) return null\n\n const banner = banners[current]\n const isLight = banner.textColor === 'light' || !banner.textColor\n\n return (\n <div\n className={['relative overflow-hidden rounded-xl', className].filter(Boolean).join(' ')}\n style={{ aspectRatio }}\n onMouseEnter={() => setPaused(true)}\n onMouseLeave={() => setPaused(false)}\n onTouchStart={handleTouchStart}\n onTouchEnd={handleTouchEnd}\n >\n {/* Slides */}\n <div ref={trackRef} className=\"relative w-full h-full\">\n {banners.map((b, i) => (\n <div\n key={b.id}\n aria-hidden={i !== current}\n className={[\n 'absolute inset-0 transition-opacity duration-700',\n i === current ? 'opacity-100 z-10' : 'opacity-0 z-0',\n ].join(' ')}\n style={{\n background: b.backgroundImage\n ? `url(${b.backgroundImage}) center/cover no-repeat`\n : b.backgroundColor ?? 'linear-gradient(135deg, #1d4ed8 0%, #7c3aed 100%)',\n }}\n >\n {/* Overlay for readability */}\n {b.backgroundImage && (\n <div className=\"absolute inset-0 bg-gradient-to-r from-black/50 via-black/20 to-transparent\" />\n )}\n\n {/* Content */}\n <div className=\"relative z-10 h-full flex items-center px-8 md:px-12 gap-8\">\n <div className=\"flex-1 max-w-lg\">\n {b.eyebrow && (\n <p\n className={`text-xs font-semibold uppercase tracking-widest mb-2 ${\n isLight ? 'text-white/70' : 'text-gray-500'\n }`}\n >\n {b.eyebrow}\n </p>\n )}\n <h2\n className={`text-2xl md:text-3xl lg:text-4xl font-bold leading-tight ${\n isLight ? 'text-white' : 'text-gray-900'\n }`}\n >\n {b.title}\n </h2>\n {b.subtitle && (\n <p\n className={`mt-2 text-sm md:text-base ${\n isLight ? 'text-white/80' : 'text-gray-600'\n }`}\n >\n {b.subtitle}\n </p>\n )}\n {b.ctaLabel && (\n <button\n onClick={b.onCtaClick}\n className={[\n 'mt-5 inline-flex items-center gap-2 px-5 py-2.5 rounded-lg text-sm font-semibold transition-all',\n isLight\n ? 'bg-white text-gray-900 hover:bg-gray-100'\n : 'bg-primary-600 text-white hover:bg-primary-700',\n ].join(' ')}\n >\n {b.ctaLabel}\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M8.25 4.5l7.5 7.5-7.5 7.5\" />\n </svg>\n </button>\n )}\n </div>\n\n {/* Side image */}\n {b.sideImage && (\n <div className=\"hidden md:block flex-1 h-full flex items-end justify-end overflow-hidden\">\n <img\n src={b.sideImage}\n alt=\"\"\n className=\"h-full w-auto object-contain object-bottom drop-shadow-2xl\"\n />\n </div>\n )}\n </div>\n </div>\n ))}\n </div>\n\n {/* Arrow navigation */}\n {arrows && count > 1 && (\n <>\n <button\n onClick={prev}\n className=\"absolute left-3 top-1/2 -translate-y-1/2 z-20 w-9 h-9 flex items-center justify-center rounded-full bg-black/30 text-white hover:bg-black/50 transition-colors backdrop-blur-sm\"\n aria-label=\"Previous banner\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" strokeWidth={2} stroke=\"currentColor\" className=\"w-5 h-5\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M15.75 19.5L8.25 12l7.5-7.5\" />\n </svg>\n </button>\n <button\n onClick={next}\n className=\"absolute right-3 top-1/2 -translate-y-1/2 z-20 w-9 h-9 flex items-center justify-center rounded-full bg-black/30 text-white hover:bg-black/50 transition-colors backdrop-blur-sm\"\n aria-label=\"Next banner\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" strokeWidth={2} stroke=\"currentColor\" className=\"w-5 h-5\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M8.25 4.5l7.5 7.5-7.5 7.5\" />\n </svg>\n </button>\n </>\n )}\n\n {/* Dot indicators */}\n {dots && count > 1 && (\n <div className=\"absolute bottom-3 left-1/2 -translate-x-1/2 z-20 flex gap-1.5\">\n {banners.map((_, i) => (\n <button\n key={i}\n onClick={() => goTo(i)}\n aria-label={`Go to slide ${i + 1}`}\n className={[\n 'rounded-full transition-all duration-300',\n i === current\n ? 'w-5 h-2 bg-white'\n : 'w-2 h-2 bg-white/50 hover:bg-white/80',\n ].join(' ')}\n />\n ))}\n </div>\n )}\n\n {/* Auto-play progress bar */}\n {autoPlay && count > 1 && (\n <div className=\"absolute bottom-0 left-0 right-0 h-0.5 bg-white/20 z-20\">\n <div\n key={`${current}-${paused}`}\n className={`h-full bg-white/60 ${paused ? '' : 'animate-progress'}`}\n style={{\n animation: paused ? 'none' : `progress ${autoPlayInterval}ms linear`,\n }}\n />\n </div>\n )}\n </div>\n )\n}\n","import { useState } from 'react'\nimport { Badge } from '../common/Badge/Badge'\nimport { Button } from '../common/Button/Button'\n\nexport interface ProductCardProduct {\n id: string\n name: string\n slug?: string\n /** Primary image URL */\n image?: string\n /** Secondary image on hover */\n imageHover?: string\n price: number\n originalPrice?: number\n currency?: string\n /** 'new' | 'sale' | 'hot' | custom string */\n badge?: string\n /** 0–5 */\n rating?: number\n reviewCount?: number\n inStock?: boolean\n /** Variants available (e.g. colors) */\n variants?: { id: string; color?: string; label: string }[]\n}\n\nexport interface ProductCardProps {\n product: ProductCardProduct\n onAddToCart?: (product: ProductCardProduct) => void\n onWishlistToggle?: (product: ProductCardProduct) => void\n isWishlisted?: boolean\n onProductClick?: (product: ProductCardProduct) => void\n /** compact — narrower, used in grids with 4+ columns */\n size?: 'default' | 'compact'\n className?: string\n}\n\nfunction StarIcon({ filled }: { filled: boolean }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n className={`w-3.5 h-3.5 ${filled ? 'fill-amber-400 stroke-amber-400' : 'fill-gray-200 stroke-gray-300'}`}\n strokeWidth={1}\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M11.48 3.499a.562.562 0 011.04 0l2.125 5.111a.563.563 0 00.475.345l5.518.442c.499.04.701.663.321.988l-4.204 3.602a.563.563 0 00-.182.557l1.285 5.385a.562.562 0 01-.84.61l-4.725-2.885a.563.563 0 00-.586 0L6.982 20.54a.562.562 0 01-.84-.61l1.285-5.386a.562.562 0 00-.182-.557l-4.204-3.602a.563.563 0 01.321-.988l5.518-.442a.563.563 0 00.475-.345L11.48 3.5z\"\n />\n </svg>\n )\n}\n\nfunction StarRating({ value, count }: { value: number; count?: number }) {\n return (\n <div className=\"flex items-center gap-1\">\n <div className=\"flex gap-0.5\">\n {[1, 2, 3, 4, 5].map((s) => (\n <StarIcon key={s} filled={s <= Math.round(value)} />\n ))}\n </div>\n {count !== undefined && (\n <span className=\"text-xs text-gray-400\">({count})</span>\n )}\n </div>\n )\n}\n\nfunction badgeVariant(badge: string) {\n const b = badge.toLowerCase()\n if (b === 'sale' || b === 'akce') return 'danger' as const\n if (b === 'new' || b === 'nové') return 'primary' as const\n if (b === 'hot') return 'warning' as const\n return 'default' as const\n}\n\nfunction formatPrice(price: number, currency = 'Kč') {\n return `${price.toLocaleString('cs-CZ')} ${currency}`\n}\n\nfunction discountPercent(original: number, current: number) {\n return Math.round((1 - current / original) * 100)\n}\n\nexport function ProductCard({\n product,\n onAddToCart,\n onWishlistToggle,\n isWishlisted = false,\n onProductClick,\n size = 'default',\n className = '',\n}: ProductCardProps) {\n const [hovered, setHovered] = useState(false)\n const [addedToCart, setAddedToCart] = useState(false)\n\n const hasDiscount =\n product.originalPrice !== undefined && product.originalPrice > product.price\n\n const handleAddToCart = (e: React.MouseEvent) => {\n e.stopPropagation()\n onAddToCart?.(product)\n setAddedToCart(true)\n setTimeout(() => setAddedToCart(false), 1500)\n }\n\n const handleWishlist = (e: React.MouseEvent) => {\n e.stopPropagation()\n onWishlistToggle?.(product)\n }\n\n return (\n <article\n className={[\n 'group relative flex flex-col bg-white rounded-xl border border-gray-200',\n 'hover:shadow-md transition-shadow duration-200 overflow-hidden cursor-pointer',\n className,\n ]\n .filter(Boolean)\n .join(' ')}\n onClick={() => onProductClick?.(product)}\n onMouseEnter={() => setHovered(true)}\n onMouseLeave={() => setHovered(false)}\n >\n {/* Image */}\n <div className={`relative overflow-hidden bg-gray-50 ${size === 'compact' ? 'aspect-square' : 'aspect-4/3'}`}>\n {product.image ? (\n <img\n src={hovered && product.imageHover ? product.imageHover : product.image}\n alt={product.name}\n className=\"w-full h-full object-contain p-4 transition-transform duration-300 group-hover:scale-105\"\n />\n ) : (\n <div className=\"w-full h-full flex items-center justify-center text-5xl bg-linear-to-br from-gray-100 to-gray-200\">\n 🛍️\n </div>\n )}\n\n {/* Badge */}\n {product.badge && (\n <div className=\"absolute top-2 left-2\">\n <Badge variant={badgeVariant(product.badge)} size=\"sm\">\n {product.badge === 'sale' && hasDiscount\n ? `-${discountPercent(product.originalPrice!, product.price)}%`\n : product.badge}\n </Badge>\n </div>\n )}\n\n {/* Out of stock overlay */}\n {product.inStock === false && (\n <div className=\"absolute inset-0 bg-white/70 flex items-center justify-center\">\n <span className=\"text-sm font-semibold text-gray-500 bg-white/90 px-3 py-1 rounded-full border border-gray-200\">\n Vyprodáno\n </span>\n </div>\n )}\n\n {/* Wishlist button */}\n <button\n onClick={handleWishlist}\n aria-label={isWishlisted ? 'Remove from wishlist' : 'Add to wishlist'}\n className={[\n 'absolute top-2 right-2 w-8 h-8 flex items-center justify-center rounded-full bg-white shadow-sm border border-gray-100',\n 'transition-all duration-200',\n 'opacity-0 group-hover:opacity-100 focus:opacity-100',\n isWishlisted ? 'text-danger-500' : 'text-gray-400 hover:text-danger-400',\n ].join(' ')}\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className={`w-4 h-4 ${isWishlisted ? 'fill-current' : 'fill-none'}`}\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M21 8.25c0-2.485-2.099-4.5-4.688-4.5-1.935 0-3.597 1.126-4.312 2.733-.715-1.607-2.377-2.733-4.313-2.733C5.1 3.75 3 5.765 3 8.25c0 7.22 9 12 9 12s9-4.78 9-12z\"\n />\n </svg>\n </button>\n\n {/* Quick add — slides up on hover */}\n <div\n className={[\n 'absolute bottom-0 left-0 right-0 p-2 transition-transform duration-200',\n hovered ? 'translate-y-0' : 'translate-y-full',\n ].join(' ')}\n >\n <Button\n variant=\"primary\"\n size=\"sm\"\n fullWidth\n loading={false}\n disabled={product.inStock === false}\n onClick={handleAddToCart}\n className=\"shadow-lg\"\n >\n {addedToCart ? (\n <span className=\"flex items-center gap-1.5\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" strokeWidth={2} stroke=\"currentColor\" className=\"w-4 h-4\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M4.5 12.75l6 6 9-13.5\" />\n </svg>\n Přidáno\n </span>\n ) : (\n 'Přidat do košíku'\n )}\n </Button>\n </div>\n </div>\n\n {/* Info */}\n <div className={`flex flex-col gap-1.5 ${size === 'compact' ? 'p-3' : 'p-4'}`}>\n {/* Color variants */}\n {product.variants && product.variants.length > 0 && (\n <div className=\"flex gap-1\">\n {product.variants.slice(0, 5).map((v) => (\n <span\n key={v.id}\n title={v.label}\n className=\"w-4 h-4 rounded-full border border-gray-300 shrink-0\"\n style={{ backgroundColor: v.color ?? '#ccc' }}\n />\n ))}\n {product.variants.length > 5 && (\n <span className=\"text-xs text-gray-400\">+{product.variants.length - 5}</span>\n )}\n </div>\n )}\n\n {/* Name */}\n <h3\n className={`font-medium text-gray-900 leading-snug line-clamp-2 group-hover:text-primary-600 transition-colors ${\n size === 'compact' ? 'text-xs' : 'text-sm'\n }`}\n >\n {product.name}\n </h3>\n\n {/* Rating */}\n {product.rating !== undefined && (\n <StarRating value={product.rating} count={product.reviewCount} />\n )}\n\n {/* Price */}\n <div className=\"flex items-baseline gap-2 mt-auto pt-1\">\n <span\n className={`font-bold text-gray-900 ${size === 'compact' ? 'text-base' : 'text-lg'}`}\n >\n {formatPrice(product.price, product.currency)}\n </span>\n {hasDiscount && (\n <span className=\"text-sm text-gray-400 line-through\">\n {formatPrice(product.originalPrice!, product.currency)}\n </span>\n )}\n </div>\n </div>\n </article>\n )\n}\n","import type { ReactNode } from 'react'\nimport { ProductCard } from '../ProductCard/ProductCard'\nimport type { ProductCardProduct, ProductCardProps } from '../ProductCard/ProductCard'\nimport { Pagination } from '../common/Pagination/Pagination'\nimport { Select } from '../common/Select/Select'\n\nexport type GridColumns = 2 | 3 | 4 | 5\n\nexport interface SortOption {\n value: string\n label: string\n}\n\nexport interface ProductGridProps {\n products: ProductCardProduct[]\n /** Total products (for pagination) */\n totalCount?: number\n /** Current page */\n page?: number\n onPageChange?: (page: number) => void\n /** Products per page */\n perPage?: number\n /** Column count */\n columns?: GridColumns\n /** Sort options */\n sortOptions?: SortOption[]\n selectedSort?: string\n onSortChange?: (value: string) => void\n /** Active filters summary */\n activeFilters?: string[]\n onRemoveFilter?: (filter: string) => void\n onClearFilters?: () => void\n /** Loading skeleton */\n loading?: boolean\n /** Empty state slot */\n emptyState?: ReactNode\n /** ProductCard passthrough props */\n onAddToCart?: ProductCardProps['onAddToCart']\n onWishlistToggle?: ProductCardProps['onWishlistToggle']\n onProductClick?: ProductCardProps['onProductClick']\n wishlisted?: string[]\n className?: string\n}\n\nconst colClasses: Record<GridColumns, string> = {\n 2: 'grid-cols-2',\n 3: 'grid-cols-2 md:grid-cols-3',\n 4: 'grid-cols-2 sm:grid-cols-3 lg:grid-cols-4',\n 5: 'grid-cols-2 sm:grid-cols-3 md:grid-cols-4 lg:grid-cols-5',\n}\n\nconst DEFAULT_SORT_OPTIONS: SortOption[] = [\n { value: 'newest', label: 'Nejnovější' },\n { value: 'price-asc', label: 'Cena: od nejnižší' },\n { value: 'price-desc', label: 'Cena: od nejvyšší' },\n { value: 'rating', label: 'Hodnocení' },\n { value: 'bestseller', label: 'Bestsellery' },\n]\n\nfunction SkeletonCard() {\n return (\n <div className=\"rounded-xl border border-gray-100 overflow-hidden animate-pulse\">\n <div className=\"aspect-4/3 bg-gray-200\" />\n <div className=\"p-4 space-y-2\">\n <div className=\"h-3 bg-gray-200 rounded w-3/4\" />\n <div className=\"h-3 bg-gray-200 rounded w-1/2\" />\n <div className=\"h-5 bg-gray-200 rounded w-1/3 mt-2\" />\n </div>\n </div>\n )\n}\n\nexport function ProductGrid({\n products,\n totalCount,\n page = 1,\n onPageChange,\n perPage = 20,\n columns = 4,\n sortOptions = DEFAULT_SORT_OPTIONS,\n selectedSort,\n onSortChange,\n activeFilters = [],\n onRemoveFilter,\n onClearFilters,\n loading = false,\n emptyState,\n onAddToCart,\n onWishlistToggle,\n onProductClick,\n wishlisted = [],\n className = '',\n}: ProductGridProps) {\n const totalPages = totalCount ? Math.ceil(totalCount / perPage) : undefined\n const cardSize = columns >= 5 ? 'compact' : 'default'\n\n return (\n <div className={['w-full', className].filter(Boolean).join(' ')}>\n {/* Toolbar */}\n <div className=\"flex flex-wrap items-center justify-between gap-3 mb-4\">\n {/* Left: count + active filters */}\n <div className=\"flex flex-wrap items-center gap-2\">\n {totalCount !== undefined && (\n <span className=\"text-sm text-gray-500\">\n <span className=\"font-semibold text-gray-900\">{totalCount}</span> produktů\n </span>\n )}\n {activeFilters.map((f) => (\n <span\n key={f}\n className=\"inline-flex items-center gap-1 text-xs bg-primary-50 text-primary-700 border border-primary-200 rounded-full px-2.5 py-1\"\n >\n {f}\n <button\n onClick={() => onRemoveFilter?.(f)}\n aria-label={`Remove filter ${f}`}\n className=\"hover:text-primary-900 transition-colors\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" strokeWidth={2} stroke=\"currentColor\" className=\"w-3 h-3\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n </span>\n ))}\n {activeFilters.length > 1 && (\n <button\n onClick={onClearFilters}\n className=\"text-xs text-gray-400 hover:text-gray-600 underline underline-offset-2 transition-colors\"\n >\n Zrušit vše\n </button>\n )}\n </div>\n\n {/* Right: sort */}\n <Select\n options={sortOptions}\n value={selectedSort ?? ''}\n onChange={(e) => onSortChange?.(e.target.value)}\n aria-label=\"Sort products\"\n className=\"text-sm\"\n />\n </div>\n\n {/* Grid */}\n {loading ? (\n <div className={`grid gap-4 ${colClasses[columns]}`}>\n {Array.from({ length: perPage > 12 ? 12 : perPage }).map((_, i) => (\n <SkeletonCard key={i} />\n ))}\n </div>\n ) : products.length === 0 ? (\n <div className=\"py-16 text-center\">\n {emptyState ?? (\n <div className=\"space-y-2\">\n <p className=\"text-4xl\">🔍</p>\n <p className=\"font-semibold text-gray-900\">Žádné produkty nenalezeny</p>\n <p className=\"text-sm text-gray-500\">Zkuste upravit filtry nebo hledat jinak.</p>\n {activeFilters.length > 0 && (\n <button\n onClick={onClearFilters}\n className=\"mt-3 text-sm text-primary-600 hover:underline\"\n >\n Zrušit všechny filtry\n </button>\n )}\n </div>\n )}\n </div>\n ) : (\n <div className={`grid gap-4 ${colClasses[columns]}`}>\n {products.map((product) => (\n <ProductCard\n key={product.id}\n product={product}\n size={cardSize}\n onAddToCart={onAddToCart}\n onWishlistToggle={onWishlistToggle}\n onProductClick={onProductClick}\n isWishlisted={wishlisted.includes(product.id)}\n />\n ))}\n </div>\n )}\n\n {/* Pagination */}\n {totalPages && totalPages > 1 && onPageChange && (\n <div className=\"flex justify-center mt-8\">\n <Pagination\n page={page}\n totalPages={totalPages}\n onPageChange={onPageChange}\n />\n </div>\n )}\n </div>\n )\n}\n","import { useState, useEffect, useRef } from 'react';\nimport type { ReactNode, HTMLAttributes } from 'react';\nimport clx from 'classnames';\nimport { CarouselBtn } from '../Carousel';\n\nexport interface ProductCarouselProps extends HTMLAttributes<HTMLDivElement> {\n children: ReactNode;\n /** Gap between cards in px */\n gap?: number;\n /** Fraction of viewport width to scroll per arrow click (0–1) */\n scrollStep?: number;\n}\n\nexport function ProductCarousel({\n children,\n gap = 16,\n scrollStep = 0.8,\n className,\n ...props\n}: ProductCarouselProps) {\n const viewportRef = useRef<HTMLDivElement>(null);\n const [canPrev, setCanPrev] = useState(false);\n const [canNext, setCanNext] = useState(false);\n\n const updateArrows = () => {\n const el = viewportRef.current;\n if (!el) return;\n setCanPrev(el.scrollLeft > 1);\n setCanNext(el.scrollLeft < el.scrollWidth - el.clientWidth - 1);\n };\n\n useEffect(() => {\n updateArrows();\n const el = viewportRef.current;\n if (!el) return;\n el.addEventListener('scroll', updateArrows, { passive: true });\n const observer = new ResizeObserver(updateArrows);\n observer.observe(el);\n return () => {\n el.removeEventListener('scroll', updateArrows);\n observer.disconnect();\n };\n }, []);\n\n const scrollBy = (dir: 1 | -1) => {\n const el = viewportRef.current;\n if (!el) return;\n el.scrollBy({\n left: dir * el.clientWidth * scrollStep,\n behavior: 'smooth',\n });\n };\n\n return (\n <div className={clx('carousel-wrapper', className)} {...props}>\n <div ref={viewportRef} className=\"product-carousel-viewport\">\n <div className=\"product-carousel-track\" style={{ gap: `${gap}px` }}>\n {children}\n </div>\n </div>\n\n {canPrev && <CarouselBtn direction=\"prev\" onClick={() => scrollBy(-1)} />}\n {canNext && <CarouselBtn direction=\"next\" onClick={() => scrollBy(1)} />}\n </div>\n );\n}\n","import type { ReactNode, CSSProperties } from 'react'\nimport { Button } from '../common/Button/Button'\nimport type { ButtonProps } from '../common/Button/Button'\n\n// ─── Types ────────────────────────────────────────────────────────────────────\n\ntype CtaAlign = 'left' | 'center' | 'right'\ntype CtaSize = 'sm' | 'md' | 'lg' | 'xl'\ntype CtaVariant = 'default' | 'primary' | 'dark' | 'gradient' | 'outline' | 'image'\ntype CtaLayout = 'stacked' | 'inline'\n\nexport interface CtaAction {\n label: string\n onClick?: () => void\n href?: string\n variant?: ButtonProps['variant']\n size?: ButtonProps['size']\n}\n\nexport interface CallToActionProps {\n // Content\n eyebrow?: string\n title: string\n description?: string\n actions?: CtaAction[]\n\n // Layout\n align?: CtaAlign\n layout?: CtaLayout\n size?: CtaSize\n\n // Visual\n variant?: CtaVariant\n /** Custom background colour or gradient CSS value (overrides variant background) */\n background?: string\n /** For variant=\"image\": URL of background image */\n backgroundImage?: string\n /** Extra decorative slot — e.g. an illustration, icon or badge */\n media?: ReactNode\n\n // Misc\n className?: string\n style?: CSSProperties\n}\n\n// ─── Config maps ─────────────────────────────────────────────────────────────\n\nconst variantClasses: Record<CtaVariant, string> = {\n default: 'bg-gray-50 border border-gray-200',\n primary: 'bg-primary-600',\n dark: 'bg-gray-900',\n gradient: 'bg-linear-to-br from-primary-600 via-primary-700 to-violet-700',\n outline: 'bg-white border-2 border-primary-600',\n image: 'relative overflow-hidden', // bg applied inline via style\n}\n\nconst variantTextClasses: Record<CtaVariant, { eyebrow: string; title: string; description: string }> = {\n default: { eyebrow: 'text-primary-600', title: 'text-gray-900', description: 'text-gray-600' },\n primary: { eyebrow: 'text-primary-100', title: 'text-white', description: 'text-primary-100' },\n dark: { eyebrow: 'text-primary-400', title: 'text-white', description: 'text-gray-400' },\n gradient: { eyebrow: 'text-primary-200', title: 'text-white', description: 'text-primary-100' },\n outline: { eyebrow: 'text-primary-600', title: 'text-gray-900', description: 'text-gray-600' },\n image: { eyebrow: 'text-white/70', title: 'text-white', description: 'text-white/80' },\n}\n\nconst sizeClasses: Record<CtaSize, { wrapper: string; title: string; description: string; eyebrow: string }> = {\n sm: { wrapper: 'px-6 py-6 rounded-xl', title: 'text-xl font-bold', description: 'text-sm', eyebrow: 'text-xs' },\n md: { wrapper: 'px-8 py-10 rounded-2xl', title: 'text-2xl font-bold', description: 'text-base', eyebrow: 'text-xs' },\n lg: { wrapper: 'px-10 py-14 rounded-2xl', title: 'text-3xl font-bold', description: 'text-lg', eyebrow: 'text-sm' },\n xl: { wrapper: 'px-12 py-20 rounded-3xl', title: 'text-4xl font-extrabold leading-tight', description: 'text-xl', eyebrow: 'text-sm' },\n}\n\nconst alignClasses: Record<CtaAlign, { wrapper: string; actions: string }> = {\n left: { wrapper: 'items-start text-left', actions: 'justify-start' },\n center: { wrapper: 'items-center text-center', actions: 'justify-center' },\n right: { wrapper: 'items-end text-right', actions: 'justify-end' },\n}\n\n// ─── Component ───────────────────────────────────────────────────────────────\n\nexport function CallToAction({\n eyebrow,\n title,\n description,\n actions = [],\n align = 'center',\n layout = 'stacked',\n size = 'md',\n variant = 'default',\n background,\n backgroundImage,\n media,\n className = '',\n style,\n}: CallToActionProps) {\n const textColors = variantTextClasses[variant]\n const sizes = sizeClasses[size]\n const alignment = alignClasses[align]\n const isInline = layout === 'inline'\n\n const inlineStyle: CSSProperties = {\n ...(background ? { background } : {}),\n ...(backgroundImage ? { backgroundImage: `url(${backgroundImage})`, backgroundSize: 'cover', backgroundPosition: 'center' } : {}),\n ...style,\n }\n\n return (\n <div\n className={[\n 'w-full',\n variantClasses[variant],\n sizes.wrapper,\n className,\n ].filter(Boolean).join(' ')}\n style={Object.keys(inlineStyle).length ? inlineStyle : undefined}\n >\n {/* Image overlay */}\n {(variant === 'image' || backgroundImage) && (\n <div className=\"absolute inset-0 bg-black/50\" />\n )}\n\n <div className={`relative ${isInline ? 'flex flex-wrap items-center justify-between gap-6' : `flex flex-col gap-4 ${alignment.wrapper}`}`}>\n\n {/* Text block */}\n <div className={`flex flex-col gap-2 ${isInline ? 'flex-1 min-w-0' : alignment.wrapper}`}>\n {eyebrow && (\n <p className={`font-semibold uppercase tracking-widest ${sizes.eyebrow} ${textColors.eyebrow}`}>\n {eyebrow}\n </p>\n )}\n <h2 className={`${sizes.title} ${textColors.title}`}>\n {title}\n </h2>\n {description && (\n <p className={`max-w-2xl ${sizes.description} ${textColors.description}`}>\n {description}\n </p>\n )}\n </div>\n\n {/* Media slot */}\n {media && !isInline && (\n <div className=\"mt-2\">{media}</div>\n )}\n\n {/* Actions */}\n {actions.length > 0 && (\n <div className={`flex flex-wrap gap-3 ${isInline ? 'shrink-0' : alignment.actions}`}>\n {actions.map((action, i) => {\n const btn = (\n <Button\n key={i}\n variant={action.variant ?? (i === 0 ? resolveDefaultPrimaryVariant(variant) : 'outline')}\n size={action.size ?? (size === 'sm' ? 'sm' : size === 'xl' ? 'lg' : 'md')}\n onClick={action.onClick}\n >\n {action.label}\n </Button>\n )\n return action.href ? (\n <a key={i} href={action.href} className=\"contents\">{btn}</a>\n ) : btn\n })}\n </div>\n )}\n </div>\n </div>\n )\n}\n\n/** Pick a sensible default button variant that contrasts with the CTA background */\nfunction resolveDefaultPrimaryVariant(ctaVariant: CtaVariant): ButtonProps['variant'] {\n if (ctaVariant === 'default' || ctaVariant === 'outline') return 'primary'\n return 'secondary' // white-ish on dark/coloured backgrounds\n}\n","import type { ReactNode } from 'react';\nimport { Container } from '../common/Container';\n\n// ─── Types ────────────────────────────────────────────────────────────────────\n\nexport interface FooterContact {\n icon?: 'phone' | 'email' | 'address' | 'hours' | ReactNode;\n label: string;\n value: string;\n href?: string;\n}\n\nexport interface FooterLink {\n label: string;\n href?: string;\n onClick?: () => void;\n}\n\nexport interface FooterLinkGroup {\n heading: string;\n links: FooterLink[];\n}\n\nexport interface FooterSocialLink {\n label: string;\n href?: string;\n icon: 'facebook' | 'instagram' | 'twitter' | 'youtube' | 'tiktok' | ReactNode;\n}\n\nexport interface FooterProps {\n // Branding\n logo?: ReactNode;\n tagline?: string;\n\n // Contact section\n contactHeading?: string;\n contacts?: FooterContact[];\n\n // Links section\n linkGroups?: FooterLinkGroup[];\n\n // Social\n socialLinks?: FooterSocialLink[];\n\n // Bottom bar\n copyright?: string;\n bottomLinks?: FooterLink[];\n\n className?: string;\n}\n\n// ─── Icons ────────────────────────────────────────────────────────────────────\n\nfunction PhoneIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-4 h-4 shrink-0\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M2.25 6.75c0 8.284 6.716 15 15 15h2.25a2.25 2.25 0 002.25-2.25v-1.372c0-.516-.351-.966-.852-1.091l-4.423-1.106c-.44-.11-.902.055-1.173.417l-.97 1.293c-.282.376-.769.542-1.21.38a12.035 12.035 0 01-7.143-7.143c-.162-.441.004-.928.38-1.21l1.293-.97c.363-.271.527-.734.417-1.173L6.963 3.102a1.125 1.125 0 00-1.091-.852H4.5A2.25 2.25 0 002.25 4.5v2.25z\"\n />\n </svg>\n );\n}\n\nfunction EmailIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-4 h-4 shrink-0\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M21.75 6.75v10.5a2.25 2.25 0 01-2.25 2.25h-15a2.25 2.25 0 01-2.25-2.25V6.75m19.5 0A2.25 2.25 0 0019.5 4.5h-15a2.25 2.25 0 00-2.25 2.25m19.5 0v.243a2.25 2.25 0 01-1.07 1.916l-7.5 4.615a2.25 2.25 0 01-2.36 0L3.32 8.91a2.25 2.25 0 01-1.07-1.916V6.75\"\n />\n </svg>\n );\n}\n\nfunction AddressIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-4 h-4 shrink-0\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M15 10.5a3 3 0 11-6 0 3 3 0 016 0z\"\n />\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M19.5 10.5c0 7.142-7.5 11.25-7.5 11.25S4.5 17.642 4.5 10.5a7.5 7.5 0 1115 0z\"\n />\n </svg>\n );\n}\n\nfunction HoursIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-4 h-4 shrink-0\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M12 6v6h4.5m4.5 0a9 9 0 11-18 0 9 9 0 0118 0z\"\n />\n </svg>\n );\n}\n\nfunction FacebookIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path d=\"M24 12.073C24 5.405 18.627 0 12 0S0 5.405 0 12.073C0 18.1 4.388 23.094 10.125 24v-8.437H7.078v-3.49h3.047V9.41c0-3.025 1.792-4.697 4.533-4.697 1.312 0 2.686.236 2.686.236v2.97h-1.513c-1.491 0-1.956.93-1.956 1.886v2.267h3.328l-.532 3.49h-2.796V24C19.612 23.094 24 18.1 24 12.073z\" />\n </svg>\n );\n}\n\nfunction InstagramIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path d=\"M12 2.163c3.204 0 3.584.012 4.85.07 3.252.148 4.771 1.691 4.919 4.919.058 1.265.069 1.645.069 4.849 0 3.205-.012 3.584-.069 4.849-.149 3.225-1.664 4.771-4.919 4.919-1.266.058-1.644.07-4.85.07-3.204 0-3.584-.012-4.849-.07-3.26-.149-4.771-1.699-4.919-4.92-.058-1.265-.07-1.644-.07-4.849 0-3.204.013-3.583.07-4.849.149-3.227 1.664-4.771 4.919-4.919 1.266-.057 1.645-.069 4.849-.069zm0-2.163c-3.259 0-3.667.014-4.947.072-4.358.2-6.78 2.618-6.98 6.98-.059 1.281-.073 1.689-.073 4.948 0 3.259.014 3.668.072 4.948.2 4.358 2.618 6.78 6.98 6.98 1.281.058 1.689.072 4.948.072 3.259 0 3.668-.014 4.948-.072 4.354-.2 6.782-2.618 6.979-6.98.059-1.28.073-1.689.073-4.948 0-3.259-.014-3.667-.072-4.947-.196-4.354-2.617-6.78-6.979-6.98-1.281-.059-1.69-.073-4.949-.073zm0 5.838a6.162 6.162 0 100 12.324 6.162 6.162 0 000-12.324zM12 16a4 4 0 110-8 4 4 0 010 8zm6.406-11.845a1.44 1.44 0 100 2.881 1.44 1.44 0 000-2.881z\" />\n </svg>\n );\n}\n\nfunction TwitterIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path d=\"M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z\" />\n </svg>\n );\n}\n\nfunction YoutubeIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path d=\"M23.498 6.186a3.016 3.016 0 00-2.122-2.136C19.505 3.545 12 3.545 12 3.545s-7.505 0-9.377.505A3.017 3.017 0 00.502 6.186C0 8.07 0 12 0 12s0 3.93.502 5.814a3.016 3.016 0 002.122 2.136c1.871.505 9.376.505 9.376.505s7.505 0 9.377-.505a3.015 3.015 0 002.122-2.136C24 15.93 24 12 24 12s0-3.93-.502-5.814zM9.545 15.568V8.432L15.818 12l-6.273 3.568z\" />\n </svg>\n );\n}\n\nfunction TiktokIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path d=\"M19.59 6.69a4.83 4.83 0 01-3.77-4.25V2h-3.45v13.67a2.89 2.89 0 01-2.88 2.5 2.89 2.89 0 01-2.89-2.89 2.89 2.89 0 012.89-2.89c.28 0 .54.04.79.1V9.01a6.33 6.33 0 00-.79-.05 6.34 6.34 0 00-6.34 6.34 6.34 6.34 0 006.34 6.34 6.34 6.34 0 006.33-6.34V8.69a8.18 8.18 0 004.78 1.52V6.76a4.85 4.85 0 01-1.01-.07z\" />\n </svg>\n );\n}\n\nconst SOCIAL_ICONS = {\n facebook: FacebookIcon,\n instagram: InstagramIcon,\n twitter: TwitterIcon,\n youtube: YoutubeIcon,\n tiktok: TiktokIcon,\n};\nconst CONTACT_ICONS = {\n phone: PhoneIcon,\n email: EmailIcon,\n address: AddressIcon,\n hours: HoursIcon,\n};\n\nfunction resolveContactIcon(icon: FooterContact['icon']) {\n if (!icon) return null;\n if (typeof icon === 'string') {\n const Icon = CONTACT_ICONS[icon as keyof typeof CONTACT_ICONS];\n return Icon ? <Icon /> : null;\n }\n return icon;\n}\n\nfunction resolveSocialIcon(icon: FooterSocialLink['icon']) {\n if (typeof icon === 'string') {\n const Icon = SOCIAL_ICONS[icon as keyof typeof SOCIAL_ICONS];\n return Icon ? <Icon /> : null;\n }\n return icon;\n}\n\n// ─── Component ────────────────────────────────────────────────────────────────\n\nexport function Footer({\n logo,\n tagline,\n contactHeading = 'Kontakty',\n contacts = [],\n linkGroups = [],\n socialLinks = [],\n copyright,\n bottomLinks = [],\n className = '',\n}: FooterProps) {\n const year = new Date().getFullYear();\n\n return (\n <footer\n className={['bg-gray-900 text-gray-300', className]\n .filter(Boolean)\n .join(' ')}\n >\n <Container>\n {/* ── Main section ───────────────────────────────────────────────────── */}\n <div className=\"max-w-7xl mx-auto px-4 py-12 grid grid-cols-1 md:grid-cols-2 gap-10 lg:gap-16\">\n {/* ── Left: Contact section ──────────────────────────────────────── */}\n <div className=\"flex flex-col gap-6\">\n {/* Logo + tagline */}\n <div>\n {logo ? (\n <div className=\"mb-3\">{logo}</div>\n ) : (\n <span className=\"text-xl font-bold text-white tracking-tight mb-3 block\">\n shopito\n </span>\n )}\n {tagline && (\n <p className=\"text-sm text-gray-400 max-w-xs\">{tagline}</p>\n )}\n </div>\n\n {/* Contacts */}\n {contacts.length > 0 && (\n <div>\n <h3 className=\"text-xs font-semibold uppercase tracking-widest text-gray-500 mb-3\">\n {contactHeading}\n </h3>\n <ul className=\"space-y-3\">\n {contacts.map((c, i) => {\n const icon = resolveContactIcon(c.icon);\n const inner = (\n <div className=\"flex items-start gap-2.5\">\n {icon && (\n <span className=\"mt-0.5 text-primary-400\">\n {icon}\n </span>\n )}\n <div>\n <p className=\"text-xs text-gray-500 leading-none mb-0.5\">\n {c.label}\n </p>\n <p\n className={`text-sm text-gray-200 ${c.href ? 'hover:text-white transition-colors' : ''}`}\n >\n {c.value}\n </p>\n </div>\n </div>\n );\n\n return (\n <li key={i}>\n {c.href ? <a href={c.href}>{inner}</a> : inner}\n </li>\n );\n })}\n </ul>\n </div>\n )}\n\n {/* Social links */}\n {socialLinks.length > 0 && (\n <div className=\"flex gap-2 flex-wrap\">\n {socialLinks.map((s, i) => (\n <a\n key={i}\n href={s.href}\n aria-label={s.label}\n className=\"w-8 h-8 flex items-center justify-center rounded-lg bg-gray-800 text-gray-400 hover:bg-primary-600 hover:text-white transition-colors\"\n >\n {resolveSocialIcon(s.icon)}\n </a>\n ))}\n </div>\n )}\n </div>\n\n {/* ── Right: Link groups ─────────────────────────────────────────── */}\n {linkGroups.length > 0 && (\n <div\n className={`grid gap-8 ${linkGroups.length === 1 ? 'grid-cols-1' : linkGroups.length === 2 ? 'grid-cols-2' : 'grid-cols-2 sm:grid-cols-3'}`}\n >\n {linkGroups.map((group, gi) => (\n <div key={gi}>\n <h3 className=\"text-xs font-semibold uppercase tracking-widest text-gray-500 mb-3\">\n {group.heading}\n </h3>\n <ul className=\"space-y-2\">\n {group.links.map((link, li) => (\n <li key={li}>\n {link.href ? (\n <a\n href={link.href}\n className=\"text-sm text-gray-400 hover:text-white transition-colors\"\n >\n {link.label}\n </a>\n ) : (\n <button\n onClick={link.onClick}\n className=\"text-sm text-gray-400 hover:text-white transition-colors text-left\"\n >\n {link.label}\n </button>\n )}\n </li>\n ))}\n </ul>\n </div>\n ))}\n </div>\n )}\n </div>\n\n {/* ── Bottom bar ─────────────────────────────────────────────────────── */}\n <div className=\"border-t border-gray-800\">\n <div className=\"max-w-7xl mx-auto px-4 py-4 flex flex-wrap items-center justify-between gap-3\">\n <p className=\"text-xs text-gray-500\">\n {copyright ?? `© ${year} Shopito. Všechna práva vyhrazena.`}\n </p>\n {bottomLinks.length > 0 && (\n <nav className=\"flex flex-wrap gap-4\">\n {bottomLinks.map((link, i) =>\n link.href ? (\n <a\n key={i}\n href={link.href}\n className=\"text-xs text-gray-500 hover:text-gray-300 transition-colors\"\n >\n {link.label}\n </a>\n ) : (\n <button\n key={i}\n onClick={link.onClick}\n className=\"text-xs text-gray-500 hover:text-gray-300 transition-colors\"\n >\n {link.label}\n </button>\n ),\n )}\n </nav>\n )}\n </div>\n </div>\n </Container>\n </footer>\n );\n}\n"],"x_google_ignoreList":[2],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs","names":["Symbol","objectProto","hasOwnProperty","nativeObjectToString","symToStringTag","Symbol","Symbol","isObject","funcTag","genTag","isFunction","isObject","funcToString","objectProto","hasOwnProperty","isObject","isFunction","HASH_UNDEFINED","hasOwnProperty","hasOwnProperty","Stack","hasOwnProperty","argsTag","objectProto","hasOwnProperty","propertyIsEnumerable","freeExports","freeModule","Buffer","MAX_SAFE_INTEGER","argsTag","arrayTag","boolTag","dateTag","errorTag","funcTag","mapTag","numberTag","objectTag","regexpTag","setTag","stringTag","weakMapTag","arrayBufferTag","dataViewTag","float32Tag","float64Tag","int8Tag","int16Tag","int32Tag","uint8Tag","uint8ClampedTag","uint16Tag","uint32Tag","freeExports","freeModule","hasOwnProperty","hasOwnProperty","isFunction","hasOwnProperty","isObject","Buffer","Promise","WeakMap","mapTag","objectTag","setTag","weakMapTag","dataViewTag","Promise","WeakMap","Uint8Array","Uint8Array","symbolProto","Symbol","boolTag","dateTag","mapTag","numberTag","regexpTag","setTag","stringTag","symbolTag","arrayBufferTag","dataViewTag","float32Tag","float64Tag","int8Tag","int16Tag","int32Tag","uint8Tag","uint8ClampedTag","uint16Tag","uint32Tag","isObject","mapTag","getTag","setTag","getTag","CLONE_DEEP_FLAG","CLONE_SYMBOLS_FLAG","symbolTag","isObject","getTag","Stack","CLONE_SYMBOLS_FLAG","INFINITY","Symbol","invariant","Children","useLayoutEffect","useEffect","Component"],"sources":["../src/components/common/Container/Container.tsx","../src/components/common/Main/Main.tsx","../node_modules/classnames/index.js","../src/components/common/Button/Button.tsx","../src/components/common/LoadingSpin/LoadingSpin.tsx","../src/components/common/IconButton/IconButton.tsx","../src/components/common/Input/Input.tsx","../src/components/common/Select/Select.tsx","../src/components/common/Typography/Heading.tsx","../src/components/common/Typography/Text.tsx","../src/components/common/Badge/Badge.tsx","../src/components/common/Card/Card.tsx","../src/components/common/Spinner/Spinner.tsx","../src/components/common/Alert/Alert.tsx","../src/components/common/Modal/Modal.tsx","../src/components/common/Checkbox/Checkbox.tsx","../src/components/common/Toggle/Toggle.tsx","../src/components/common/Avatar/Avatar.tsx","../src/components/common/Stack/Stack.tsx","../src/components/common/Grid/Grid.tsx","../src/components/common/QuantityInput/QuantityInput.tsx","../src/components/common/Pagination/Pagination.tsx","../src/components/common/Carousel/CarouselBtn.tsx","../src/components/common/Carousel/Carousel.tsx","../node_modules/deepmerge/dist/es.js","../node_modules/lodash-es/_freeGlobal.js","../node_modules/lodash-es/_root.js","../node_modules/lodash-es/_Symbol.js","../node_modules/lodash-es/_getRawTag.js","../node_modules/lodash-es/_objectToString.js","../node_modules/lodash-es/_baseGetTag.js","../node_modules/lodash-es/_overArg.js","../node_modules/lodash-es/_getPrototype.js","../node_modules/lodash-es/isObjectLike.js","../node_modules/lodash-es/_listCacheClear.js","../node_modules/lodash-es/eq.js","../node_modules/lodash-es/_assocIndexOf.js","../node_modules/lodash-es/_listCacheDelete.js","../node_modules/lodash-es/_listCacheGet.js","../node_modules/lodash-es/_listCacheHas.js","../node_modules/lodash-es/_listCacheSet.js","../node_modules/lodash-es/_ListCache.js","../node_modules/lodash-es/_stackClear.js","../node_modules/lodash-es/_stackDelete.js","../node_modules/lodash-es/_stackGet.js","../node_modules/lodash-es/_stackHas.js","../node_modules/lodash-es/isObject.js","../node_modules/lodash-es/isFunction.js","../node_modules/lodash-es/_coreJsData.js","../node_modules/lodash-es/_isMasked.js","../node_modules/lodash-es/_toSource.js","../node_modules/lodash-es/_baseIsNative.js","../node_modules/lodash-es/_getValue.js","../node_modules/lodash-es/_getNative.js","../node_modules/lodash-es/_Map.js","../node_modules/lodash-es/_nativeCreate.js","../node_modules/lodash-es/_hashClear.js","../node_modules/lodash-es/_hashDelete.js","../node_modules/lodash-es/_hashGet.js","../node_modules/lodash-es/_hashHas.js","../node_modules/lodash-es/_hashSet.js","../node_modules/lodash-es/_Hash.js","../node_modules/lodash-es/_mapCacheClear.js","../node_modules/lodash-es/_isKeyable.js","../node_modules/lodash-es/_getMapData.js","../node_modules/lodash-es/_mapCacheDelete.js","../node_modules/lodash-es/_mapCacheGet.js","../node_modules/lodash-es/_mapCacheHas.js","../node_modules/lodash-es/_mapCacheSet.js","../node_modules/lodash-es/_MapCache.js","../node_modules/lodash-es/_stackSet.js","../node_modules/lodash-es/_Stack.js","../node_modules/lodash-es/_arrayEach.js","../node_modules/lodash-es/_defineProperty.js","../node_modules/lodash-es/_baseAssignValue.js","../node_modules/lodash-es/_assignValue.js","../node_modules/lodash-es/_copyObject.js","../node_modules/lodash-es/_baseTimes.js","../node_modules/lodash-es/_baseIsArguments.js","../node_modules/lodash-es/isArguments.js","../node_modules/lodash-es/isArray.js","../node_modules/lodash-es/stubFalse.js","../node_modules/lodash-es/isBuffer.js","../node_modules/lodash-es/_isIndex.js","../node_modules/lodash-es/isLength.js","../node_modules/lodash-es/_baseIsTypedArray.js","../node_modules/lodash-es/_baseUnary.js","../node_modules/lodash-es/_nodeUtil.js","../node_modules/lodash-es/isTypedArray.js","../node_modules/lodash-es/_arrayLikeKeys.js","../node_modules/lodash-es/_isPrototype.js","../node_modules/lodash-es/_nativeKeys.js","../node_modules/lodash-es/_baseKeys.js","../node_modules/lodash-es/isArrayLike.js","../node_modules/lodash-es/keys.js","../node_modules/lodash-es/_baseAssign.js","../node_modules/lodash-es/_nativeKeysIn.js","../node_modules/lodash-es/_baseKeysIn.js","../node_modules/lodash-es/keysIn.js","../node_modules/lodash-es/_baseAssignIn.js","../node_modules/lodash-es/_cloneBuffer.js","../node_modules/lodash-es/_copyArray.js","../node_modules/lodash-es/_arrayFilter.js","../node_modules/lodash-es/stubArray.js","../node_modules/lodash-es/_getSymbols.js","../node_modules/lodash-es/_copySymbols.js","../node_modules/lodash-es/_arrayPush.js","../node_modules/lodash-es/_getSymbolsIn.js","../node_modules/lodash-es/_copySymbolsIn.js","../node_modules/lodash-es/_baseGetAllKeys.js","../node_modules/lodash-es/_getAllKeys.js","../node_modules/lodash-es/_getAllKeysIn.js","../node_modules/lodash-es/_DataView.js","../node_modules/lodash-es/_Promise.js","../node_modules/lodash-es/_Set.js","../node_modules/lodash-es/_WeakMap.js","../node_modules/lodash-es/_getTag.js","../node_modules/lodash-es/_initCloneArray.js","../node_modules/lodash-es/_Uint8Array.js","../node_modules/lodash-es/_cloneArrayBuffer.js","../node_modules/lodash-es/_cloneDataView.js","../node_modules/lodash-es/_cloneRegExp.js","../node_modules/lodash-es/_cloneSymbol.js","../node_modules/lodash-es/_cloneTypedArray.js","../node_modules/lodash-es/_initCloneByTag.js","../node_modules/lodash-es/_baseCreate.js","../node_modules/lodash-es/_initCloneObject.js","../node_modules/lodash-es/_baseIsMap.js","../node_modules/lodash-es/isMap.js","../node_modules/lodash-es/_baseIsSet.js","../node_modules/lodash-es/isSet.js","../node_modules/lodash-es/_baseClone.js","../node_modules/lodash-es/cloneDeep.js","../node_modules/react-fast-compare/index.js","../node_modules/tiny-warning/dist/tiny-warning.esm.js","../node_modules/lodash-es/clone.js","../node_modules/lodash-es/_arrayMap.js","../node_modules/lodash-es/isSymbol.js","../node_modules/lodash-es/memoize.js","../node_modules/lodash-es/_memoizeCapped.js","../node_modules/lodash-es/_stringToPath.js","../node_modules/lodash-es/_toKey.js","../node_modules/lodash-es/_baseToString.js","../node_modules/lodash-es/toString.js","../node_modules/lodash-es/toPath.js","../node_modules/react-is/cjs/react-is.production.min.js","../node_modules/react-is/cjs/react-is.development.js","../node_modules/react-is/index.js","../node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../node_modules/formik/dist/formik.esm.js","../src/components/Header/Header.tsx","../src/components/CategoryTree/CategoryTree.tsx","../src/components/MegaMenu/MegaMenu.tsx","../src/components/BannerCarousel/BannerCarousel.tsx","../src/components/ProductCard/ProductCard.tsx","../src/components/ProductGrid/ProductGrid.tsx","../src/components/common/ProductCarousel/ProductCarousel.tsx","../src/components/CallToAction/CallToAction.tsx","../src/components/Footer/Footer.tsx"],"sourcesContent":["import { type ReactNode } from 'react';\n\nexport interface ContainerProps {\n children: ReactNode;\n}\n\nexport const Container = ({ children }: ContainerProps) => {\n return <div className=\"container\">{children}</div>;\n};\n","import { type ReactNode } from 'react';\nimport { Container } from '../Container';\n\nexport interface MainProps {\n children: ReactNode;\n}\n\nexport const Main = ({ children }: MainProps) => {\n return (\n <main className=\"main\">\n <Container>{children}</Container>\n </main>\n );\n};\n","/*!\n\tCopyright (c) 2018 Jed Watson.\n\tLicensed under the MIT License (MIT), see\n\thttp://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\n\tfunction classNames () {\n\t\tvar classes = '';\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (arg) {\n\t\t\t\tclasses = appendClass(classes, parseValue(arg));\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction parseValue (arg) {\n\t\tif (typeof arg === 'string' || typeof arg === 'number') {\n\t\t\treturn arg;\n\t\t}\n\n\t\tif (typeof arg !== 'object') {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (Array.isArray(arg)) {\n\t\t\treturn classNames.apply(null, arg);\n\t\t}\n\n\t\tif (arg.toString !== Object.prototype.toString && !arg.toString.toString().includes('[native code]')) {\n\t\t\treturn arg.toString();\n\t\t}\n\n\t\tvar classes = '';\n\n\t\tfor (var key in arg) {\n\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\tclasses = appendClass(classes, key);\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction appendClass (value, newClass) {\n\t\tif (!newClass) {\n\t\t\treturn value;\n\t\t}\n\t\n\t\tif (value) {\n\t\t\treturn value + ' ' + newClass;\n\t\t}\n\t\n\t\treturn value + newClass;\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n","import { forwardRef } from 'react';\nimport type { ButtonHTMLAttributes } from 'react';\nimport clx from 'classnames';\n\ntype Variant = 'primary' | 'secondary' | 'outline' | 'ghost' | 'danger';\ntype Size = 'xs' | 'sm' | 'md' | 'lg';\n\nexport interface ButtonProps extends ButtonHTMLAttributes<HTMLButtonElement> {\n variant?: Variant;\n size?: Size;\n loading?: boolean;\n fullWidth?: boolean;\n}\n\nexport const Button = forwardRef<HTMLButtonElement, ButtonProps>(\n (\n {\n variant = 'primary',\n size = 'md',\n loading = false,\n fullWidth = false,\n disabled,\n children,\n className = '',\n ...props\n },\n ref,\n ) => {\n const isDisabled = disabled || loading;\n\n return (\n <button\n ref={ref}\n disabled={isDisabled}\n className={clx(\n 'btn',\n variant && `btn-${variant}`,\n size && `btn-${size}`,\n fullWidth && 'w-full',\n className,\n )}\n {...props}\n >\n {loading && (\n <svg\n className=\"animate-spin h-4 w-4 shrink-0\"\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n >\n <circle\n className=\"opacity-25\"\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n stroke=\"currentColor\"\n strokeWidth=\"4\"\n />\n <path\n className=\"opacity-75\"\n fill=\"currentColor\"\n d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4z\"\n />\n </svg>\n )}\n {children}\n </button>\n );\n },\n);\n\nButton.displayName = 'Button';\n","import clx from 'classnames';\n\ntype Size = 'xs' | 'sm' | 'md' | 'lg';\n\nexport interface LoadingSpinProps {\n size: Size;\n}\n\nexport const LoadingSpin = ({ size = 'md' }: LoadingSpinProps) => {\n return (\n <svg\n className={clx('loading-spin', `loading-spin-${size}`)}\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n >\n <circle\n className=\"opacity-25\"\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n stroke=\"currentColor\"\n strokeWidth=\"4\"\n />\n <path\n className=\"opacity-75\"\n fill=\"currentColor\"\n d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4z\"\n />\n </svg>\n );\n};\n","import { forwardRef } from 'react';\nimport type { ButtonHTMLAttributes, ReactNode } from 'react';\nimport clx from 'classnames';\nimport { LoadingSpin } from '../LoadingSpin';\n\ntype Variant = 'primary' | 'secondary' | 'outline' | 'ghost' | 'danger';\ntype Size = 'xs' | 'sm' | 'md' | 'lg';\n\nexport interface IconButtonProps extends ButtonHTMLAttributes<HTMLButtonElement> {\n icon: ReactNode;\n label: string;\n variant?: Variant;\n size?: Size;\n loading?: boolean;\n}\n\nexport const IconButton = forwardRef<HTMLButtonElement, IconButtonProps>(\n (\n {\n icon,\n label,\n variant = 'ghost',\n size = 'md',\n loading = false,\n disabled,\n className = '',\n ...props\n },\n ref,\n ) => {\n const isDisabled = disabled || loading;\n\n return (\n <button\n ref={ref}\n disabled={isDisabled}\n aria-label={label}\n title={label}\n className={clx(\n 'icon-button',\n `icon-button-${variant}`,\n `icon-button-${size}`,\n className,\n )}\n {...props}\n >\n {loading ? <LoadingSpin size={size} /> : icon}\n </button>\n );\n },\n);\n\nIconButton.displayName = 'IconButton';\n","import { forwardRef } from 'react';\nimport type { InputHTMLAttributes, ReactNode } from 'react';\nimport type { FieldProps } from 'formik';\nimport clx from 'classnames';\n\nexport interface InputProps\n extends FieldProps, Omit<InputHTMLAttributes<HTMLInputElement>, 'form'> {\n label?: string;\n error?: string;\n hint?: string;\n leftIcon?: ReactNode;\n rightIcon?: ReactNode;\n}\n\nexport const Input = forwardRef<HTMLInputElement, InputProps>(\n (\n {\n label,\n error,\n hint,\n leftIcon,\n rightIcon,\n className = '',\n id,\n field,\n form,\n ...props\n },\n ref,\n ) => {\n const inputId = id ?? label?.toLowerCase().replace(/\\s+/g, '-');\n\n return (\n <div className={'w-full'}>\n {label && (\n <label htmlFor={inputId} className=\"input-label\">\n {label}\n </label>\n )}\n <div className=\"relative\">\n {leftIcon && <span className=\"left-icon\">{leftIcon}</span>}\n <input\n ref={ref}\n id={inputId}\n className={clx(\n 'input',\n error && 'has-error',\n !!leftIcon && 'with-left-icon',\n !!rightIcon && 'with-right-icon',\n 'w-full',\n className,\n )}\n {...props}\n {...field}\n />\n {rightIcon && <span className=\"right-icon\">{rightIcon}</span>}\n </div>\n {(error || hint) && (\n <p className={clx('helper-text', error && 'has-error')}>\n {error ?? hint}\n </p>\n )}\n </div>\n );\n },\n);\n\nInput.displayName = 'Input';\n","import { forwardRef } from 'react';\nimport type { SelectHTMLAttributes } from 'react';\nimport clx from 'classnames';\n\nexport interface SelectOption {\n value: string;\n label: string;\n disabled?: boolean;\n}\n\nexport interface SelectProps extends SelectHTMLAttributes<HTMLSelectElement> {\n label?: string;\n error?: string;\n hint?: string;\n options: SelectOption[];\n placeholder?: string;\n}\n\nexport const Select = forwardRef<HTMLSelectElement, SelectProps>(\n (\n { label, error, hint, options, placeholder, className = '', id, ...props },\n ref,\n ) => {\n const selectId = id ?? label?.toLowerCase().replace(/\\s+/g, '-');\n\n return (\n <div className={clx('select-wrapper', 'w-full')}>\n {label && (\n <label htmlFor={selectId} className=\"select-label\">\n {label}\n </label>\n )}\n <div className=\"relative\">\n <select\n ref={ref}\n id={selectId}\n className={clx('select', 'w-full', error && 'has-error', className)}\n {...props}\n >\n {placeholder && (\n <option value=\"\" disabled>\n {placeholder}\n </option>\n )}\n {options.map((opt) => (\n <option key={opt.value} value={opt.value} disabled={opt.disabled}>\n {opt.label}\n </option>\n ))}\n </select>\n {/* Chevron icon */}\n <span className=\"select-chevron-icon\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M19.5 8.25l-7.5 7.5-7.5-7.5\"\n />\n </svg>\n </span>\n </div>\n {(error || hint) && (\n <p className={clx('select-helper', error && 'has-error')}>\n {error ?? hint}\n </p>\n )}\n </div>\n );\n },\n);\n\nSelect.displayName = 'Select';\n","import type { HTMLAttributes, ReactNode } from 'react';\nimport cx from 'classnames';\nimport type { Color } from './Text';\n\ntype HeadingLevel = 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n\ninterface HeadingProps extends HTMLAttributes<HTMLHeadingElement> {\n as?: HeadingLevel;\n level?: 1 | 2 | 3 | 4 | 5 | 6;\n color?: Color;\n children: ReactNode;\n}\n\nexport const Heading = ({\n as,\n level = 1,\n color = 'default',\n className = '',\n children,\n ...props\n}: HeadingProps) => {\n const Tag = as ?? (`h${level}` as HeadingLevel);\n\n return (\n <Tag\n className={cx(`text-color-${color}`, `heading-size-${level}`, className)}\n {...props}\n >\n {children}\n </Tag>\n );\n};\n","import type { ElementType, HTMLAttributes, ReactNode } from 'react';\nimport cx from 'classnames';\n\ntype TextVariant = 'body' | 'body-sm' | 'caption' | 'overline' | 'code';\n\nexport type Color =\n | 'default'\n | 'muted'\n | 'primary'\n | 'success'\n | 'warning'\n | 'danger'\n | 'inherit';\n\ninterface TextProps extends HTMLAttributes<HTMLElement> {\n variant?: TextVariant;\n color?: Color;\n as?: ElementType;\n children: ReactNode;\n}\n\nexport const Text = ({\n variant = 'body',\n color = 'default',\n as: Tag = 'p',\n className = '',\n children,\n ...props\n}: TextProps) => {\n return (\n <Tag\n className={cx(\n `text-color-${color}`,\n `text-variant-${variant}`,\n className,\n )}\n {...props}\n >\n {children}\n </Tag>\n );\n};\n","import type { HTMLAttributes, ReactNode } from 'react';\nimport clx from 'classnames';\n\ntype BadgeVariant =\n | 'default'\n | 'primary'\n | 'success'\n | 'warning'\n | 'danger'\n | 'outline';\n\ntype BadgeSize = 'sm' | 'md';\n\nexport interface BadgeProps extends HTMLAttributes<HTMLSpanElement> {\n variant?: BadgeVariant;\n size?: BadgeSize;\n dot?: boolean;\n children: ReactNode;\n}\n\nexport function Badge({\n variant = 'default',\n size = 'md',\n dot = false,\n className,\n children,\n ...props\n}: BadgeProps) {\n return (\n <span\n className={clx('badge', `badge-${variant}`, `badge-${size}`, className)}\n {...props}\n >\n {dot && <span className={clx('badge-dot', `badge-dot-${variant}`)} />}\n {children}\n </span>\n );\n}\n","import type { HTMLAttributes, ReactNode } from 'react'\n\nexport interface CardProps extends HTMLAttributes<HTMLDivElement> {\n children: ReactNode\n padding?: 'none' | 'sm' | 'md' | 'lg'\n shadow?: boolean\n border?: boolean\n}\n\nexport interface CardHeaderProps extends HTMLAttributes<HTMLDivElement> {\n children: ReactNode\n}\n\nexport interface CardBodyProps extends HTMLAttributes<HTMLDivElement> {\n children: ReactNode\n}\n\nexport interface CardFooterProps extends HTMLAttributes<HTMLDivElement> {\n children: ReactNode\n}\n\nconst paddingClasses = {\n none: '',\n sm: 'p-4',\n md: 'p-6',\n lg: 'p-8',\n}\n\nexport function Card({\n children,\n padding = 'md',\n shadow = true,\n border = true,\n className = '',\n ...props\n}: CardProps) {\n return (\n <div\n className={[\n 'bg-white rounded-xl overflow-hidden',\n border ? 'border border-gray-200' : '',\n shadow ? 'shadow-sm' : '',\n paddingClasses[padding],\n className,\n ]\n .filter(Boolean)\n .join(' ')}\n {...props}\n >\n {children}\n </div>\n )\n}\n\nexport function CardHeader({ children, className = '', ...props }: CardHeaderProps) {\n return (\n <div\n className={['px-6 py-4 border-b border-gray-100', className].filter(Boolean).join(' ')}\n {...props}\n >\n {children}\n </div>\n )\n}\n\nexport function CardBody({ children, className = '', ...props }: CardBodyProps) {\n return (\n <div className={['p-6', className].filter(Boolean).join(' ')} {...props}>\n {children}\n </div>\n )\n}\n\nexport function CardFooter({ children, className = '', ...props }: CardFooterProps) {\n return (\n <div\n className={[\n 'px-6 py-4 border-t border-gray-100 bg-gray-50',\n className,\n ]\n .filter(Boolean)\n .join(' ')}\n {...props}\n >\n {children}\n </div>\n )\n}\n","import type { HTMLAttributes } from 'react';\nimport clx from 'classnames';\n\ntype SpinnerSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\ntype SpinnerColor = 'primary' | 'white' | 'gray';\n\nexport interface SpinnerProps extends HTMLAttributes<HTMLSpanElement> {\n size?: SpinnerSize;\n color?: SpinnerColor;\n label?: string;\n}\n\nexport function Spinner({\n size = 'md',\n color = 'primary',\n label = 'Loading…',\n className = '',\n ...props\n}: SpinnerProps) {\n return (\n <span\n role=\"status\"\n aria-label={label}\n className={clx('spinner-wrapper', className)}\n {...props}\n >\n <span className={clx('spinner', `spinner-${size}`, `spinner-${color}`)} />\n <span className=\"sr-only\">{label}</span>\n </span>\n );\n}\n","import type { HTMLAttributes, ReactNode } from 'react';\nimport clx from 'classnames';\n\ntype AlertVariant = 'info' | 'success' | 'warning' | 'danger';\n\nexport interface AlertProps extends HTMLAttributes<HTMLDivElement> {\n variant?: AlertVariant;\n title?: string;\n children: ReactNode;\n onClose?: () => void;\n}\n\nconst variantIcon: Record<AlertVariant, ReactNode> = {\n info: (\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M11.25 11.25l.041-.02a.75.75 0 011.063.852l-.708 2.836a.75.75 0 001.063.853l.041-.021M21 12a9 9 0 11-18 0 9 9 0 0118 0zm-9-3.75h.008v.008H12V8.25z\"\n />\n ),\n success: (\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M9 12.75L11.25 15 15 9.75M21 12a9 9 0 11-18 0 9 9 0 0118 0z\"\n />\n ),\n warning: (\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M12 9v3.75m-9.303 3.376c-.866 1.5.217 3.374 1.948 3.374h14.71c1.73 0 2.813-1.874 1.948-3.374L13.949 3.378c-.866-1.5-3.032-1.5-3.898 0L2.697 16.126zM12 15.75h.007v.008H12v-.008z\"\n />\n ),\n danger: (\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M12 9v3.75m9-.75a9 9 0 11-18 0 9 9 0 0118 0zm-9 3.75h.008v.008H12v-.008z\"\n />\n ),\n};\n\nexport function Alert({\n variant = 'info',\n title,\n children,\n onClose,\n className = '',\n ...props\n}: AlertProps) {\n return (\n <div\n role=\"alert\"\n className={clx('alert', `alert-${variant}`, 'w-full', className)}\n {...props}\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className={clx('alert-icon', `alert-icon-${variant}`)}\n >\n {variantIcon[variant]}\n </svg>\n <div className=\"flex-1 min-w-0\">\n {title && <p className=\"alert-title\">{title}</p>}\n <div className=\"alert-text\">{children}</div>\n </div>\n {onClose && (\n <button\n onClick={onClose}\n className=\"alert-close-btn\"\n aria-label=\"Close\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M6 18L18 6M6 6l12 12\"\n />\n </svg>\n </button>\n )}\n </div>\n );\n}\n","import { useEffect, useRef } from 'react'\nimport type { ReactNode } from 'react'\nimport { createPortal } from 'react-dom'\n\ntype ModalSize = 'sm' | 'md' | 'lg' | 'xl' | 'full'\n\nexport interface ModalProps {\n open: boolean\n onClose: () => void\n title?: string\n children: ReactNode\n footer?: ReactNode\n size?: ModalSize\n closeOnBackdrop?: boolean\n}\n\nconst sizeClasses: Record<ModalSize, string> = {\n sm: 'max-w-sm',\n md: 'max-w-md',\n lg: 'max-w-lg',\n xl: 'max-w-xl',\n full: 'max-w-full mx-4',\n}\n\nexport function Modal({\n open,\n onClose,\n title,\n children,\n footer,\n size = 'md',\n closeOnBackdrop = true,\n}: ModalProps) {\n const backdropRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n if (!open) return\n const prev = document.body.style.overflow\n document.body.style.overflow = 'hidden'\n return () => {\n document.body.style.overflow = prev\n }\n }, [open])\n\n useEffect(() => {\n if (!open) return\n const onKey = (e: KeyboardEvent) => {\n if (e.key === 'Escape') onClose()\n }\n document.addEventListener('keydown', onKey)\n return () => document.removeEventListener('keydown', onKey)\n }, [open, onClose])\n\n if (!open) return null\n\n return createPortal(\n <div\n ref={backdropRef}\n className=\"fixed inset-0 z-50 flex items-center justify-center p-4 bg-black/50 backdrop-blur-sm\"\n onClick={(e) => {\n if (closeOnBackdrop && e.target === backdropRef.current) onClose()\n }}\n >\n <div\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby={title ? 'modal-title' : undefined}\n className={[\n 'relative w-full bg-white rounded-xl shadow-xl flex flex-col max-h-[90vh]',\n sizeClasses[size],\n ].join(' ')}\n >\n {title && (\n <div className=\"flex items-center justify-between px-6 py-4 border-b border-gray-100 shrink-0\">\n <h2 id=\"modal-title\" className=\"text-lg font-semibold text-gray-900\">\n {title}\n </h2>\n <button\n onClick={onClose}\n className=\"text-gray-400 hover:text-gray-600 transition-colors\"\n aria-label=\"Close modal\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-5 h-5\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M6 18L18 6M6 6l12 12\"\n />\n </svg>\n </button>\n </div>\n )}\n <div className=\"flex-1 overflow-y-auto px-6 py-4\">{children}</div>\n {footer && (\n <div className=\"px-6 py-4 border-t border-gray-100 shrink-0 bg-gray-50 rounded-b-xl\">\n {footer}\n </div>\n )}\n </div>\n </div>,\n document.body,\n )\n}\n","import { forwardRef } from 'react';\nimport type { InputHTMLAttributes } from 'react';\nimport clx from 'classnames';\n\nexport interface CheckboxProps extends Omit<\n InputHTMLAttributes<HTMLInputElement>,\n 'type'\n> {\n label?: string;\n description?: string;\n error?: string;\n indeterminate?: boolean;\n}\n\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n (\n { label, description, error, indeterminate, className = '', id, ...props },\n ref,\n ) => {\n const inputId = id ?? label?.toLowerCase().replace(/\\s+/g, '-');\n\n return (\n <div className={clx('checkbox-wrapper', className)}>\n <div className=\"checkbox-wrapper-inner\">\n <input\n ref={(el) => {\n if (el) el.indeterminate = indeterminate ?? false;\n if (typeof ref === 'function') ref(el);\n else if (ref) ref.current = el;\n }}\n id={inputId}\n type=\"checkbox\"\n className={clx('checkbox', error && 'has-error')}\n {...props}\n />\n </div>\n {(label || description) && (\n <div>\n {label && (\n <label htmlFor={inputId} className=\"checkbox-label\">\n {label}\n </label>\n )}\n {description && (\n <p className=\"checkbox-description\">{description}</p>\n )}\n {error && <p className=\"checkbox-error\">{error}</p>}\n </div>\n )}\n </div>\n );\n },\n);\n\nCheckbox.displayName = 'Checkbox';\n","import { forwardRef } from 'react';\nimport type { InputHTMLAttributes } from 'react';\nimport clx from 'classnames';\n\ntype ToggleSize = 'sm' | 'md' | 'lg';\n\nexport interface ToggleProps extends Omit<\n InputHTMLAttributes<HTMLInputElement>,\n 'type' | 'size'\n> {\n label?: string;\n description?: string;\n size?: ToggleSize;\n}\n\nexport const Toggle = forwardRef<HTMLInputElement, ToggleProps>(\n ({ label, description, size = 'md', className = '', id, ...props }, ref) => {\n const inputId = id ?? label?.toLowerCase().replace(/\\s+/g, '-');\n\n return (\n <label\n htmlFor={inputId}\n className={clx(\n 'toggle',\n props.disabled && 'toggle-disabled',\n className,\n )}\n >\n <div className={clx('toggle-wrapper', `toggle-wrapper-${size}`)}>\n <input\n ref={ref}\n id={inputId}\n type=\"checkbox\"\n role=\"switch\"\n className=\"sr-only peer\"\n {...props}\n />\n <div className=\"toggle-track\" />\n <div className={clx('toggle-thumb', `toggle-thumb-${size}`)} />\n </div>\n {(label || description) && (\n <div>\n {label && <span className=\"toggle-label\">{label}</span>}\n {description && (\n <span className=\"toggle-description\">{description}</span>\n )}\n </div>\n )}\n </label>\n );\n },\n);\n\nToggle.displayName = 'Toggle';\n","import type { HTMLAttributes, ReactNode } from 'react';\nimport clx from 'classnames';\n\ntype AvatarSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\n\nexport interface AvatarProps extends HTMLAttributes<HTMLSpanElement> {\n src?: string;\n alt?: string;\n name?: string;\n size?: AvatarSize;\n}\n\nexport interface AvatarGroupProps extends HTMLAttributes<HTMLDivElement> {\n max?: number;\n size?: AvatarSize;\n children: ReactNode;\n}\n\nconst bgColors = [\n 'bg-red-500',\n 'bg-orange-500',\n 'bg-amber-500',\n 'bg-emerald-500',\n 'bg-teal-500',\n 'bg-cyan-500',\n 'bg-blue-500',\n 'bg-violet-500',\n 'bg-pink-500',\n];\n\nexport function Avatar({\n src,\n alt,\n name,\n size = 'md',\n className,\n ...props\n}: AvatarProps) {\n const baseClasses = ['avatar', `avatar-${size}`, className];\n\n const nameToColor = (n: string) => {\n let hash = 0;\n for (let i = 0; i < n.length; i++) hash += n.charCodeAt(i);\n return bgColors[hash % bgColors.length];\n };\n\n const getInitials = (name: string) =>\n name\n .split(' ')\n .slice(0, 2)\n .map((n) => n[0])\n .join('')\n .toUpperCase();\n\n if (src) {\n return (\n <span className={clx(baseClasses)} {...props}>\n <img\n src={src}\n alt={alt ?? name ?? ''}\n className=\"w-full h-full object-cover\"\n />\n </span>\n );\n }\n\n if (name) {\n return (\n <span\n className={clx(baseClasses, nameToColor(name))}\n aria-label={name}\n {...props}\n >\n {getInitials(name)}\n </span>\n );\n }\n\n // Fallback icon\n return (\n <span className={clx(baseClasses, 'avatar-fallback')} {...props}>\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"currentColor\"\n viewBox=\"0 0 24 24\"\n className=\"w-3/5 h-3/5\"\n >\n <path\n fillRule=\"evenodd\"\n d=\"M7.5 6a4.5 4.5 0 119 0 4.5 4.5 0 01-9 0zM3.751 20.105a8.25 8.25 0 0116.498 0 .75.75 0 01-.437.695A18.683 18.683 0 0112 22.5c-2.786 0-5.433-.608-7.812-1.7a.75.75 0 01-.437-.695z\"\n clipRule=\"evenodd\"\n />\n </svg>\n </span>\n );\n}\n","import type { ReactNode } from 'react';\nimport cx from 'classnames';\n\ninterface StackProps {\n direction?: 'row' | 'column';\n gap?: number;\n alignItems?: 'start' | 'end' | 'center' | 'baseline' | 'stretch';\n justifyItems?: 'start' | 'end' | 'center' | 'stretch';\n justifyContent?:\n | 'normal'\n | 'start'\n | 'end'\n | 'center'\n | 'between'\n | 'around'\n | 'evenly'\n | 'stretch';\n className?: string;\n children?: ReactNode;\n}\n\nexport const Stack = ({\n direction = 'row',\n gap,\n alignItems = 'start',\n justifyItems = 'start',\n justifyContent = 'normal',\n className,\n children,\n}: StackProps) => {\n const alignItemsMap: Record<string, string> = {\n start: 'items-start',\n end: 'items-end',\n center: 'items-center',\n baseline: 'items-baseline',\n stretch: 'items-stretch',\n };\n\n const justifyItemsMap: Record<string, string> = {\n start: 'justify-items-start',\n end: 'justify-items-end',\n center: 'justify-items-center',\n stretch: 'justify-items-stretch',\n };\n\n const justifyContentMap: Record<string, string> = {\n normal: 'justify-normal',\n start: 'justify-start',\n end: 'justify-end',\n center: 'justify-center',\n between: 'justify-between',\n around: 'justify-around',\n evenly: 'justify-evenly',\n stretch: 'justify-stretch',\n };\n\n return (\n <div\n className={cx(\n 'stack',\n `stack-${direction}`,\n gap && `gap-${gap}`,\n alignItemsMap[alignItems],\n justifyItemsMap[justifyItems],\n justifyContentMap[justifyContent],\n className,\n )}\n >\n {children}\n </div>\n );\n};\n","import type { ElementType, HTMLAttributes, ReactNode } from 'react';\nimport cx from 'classnames';\n\n// ─── Types ────────────────────────────────────────────────────────────────────\n\nexport type ColSpan = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12;\nexport type ColOffset = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11;\nexport type GridCols = 1 | 2 | 3 | 4 | 6 | 12;\nexport type GapSize = 0 | 1 | 2 | 3 | 4 | 5 | 6 | 8 | 10 | 12 | 16;\n\nexport interface GridProps {\n children?: ReactNode;\n cols?: GridCols;\n gap?: GapSize;\n rowGap?: GapSize;\n colGap?: GapSize;\n as?: ElementType;\n className?: string;\n}\n\nexport interface ColProps extends HTMLAttributes<HTMLDivElement> {\n children?: ReactNode;\n /** Výchozí šířka (mobile-first) */\n span?: ColSpan;\n sm?: ColSpan;\n md?: ColSpan;\n lg?: ColSpan;\n xl?: ColSpan;\n /** Přeskočit N sloupců od aktuální pozice (mobile-first) */\n offset?: ColOffset;\n smOffset?: ColOffset;\n mdOffset?: ColOffset;\n lgOffset?: ColOffset;\n xlOffset?: ColOffset;\n}\n\n// ─── Class maps — všechny literální stringy, Tailwind je detekuje při scanu ──\n\nconst colsMap: Record<GridCols, string> = {\n 1: 'grid-cols-1',\n 2: 'grid-cols-2',\n 3: 'grid-cols-3',\n 4: 'grid-cols-4',\n 6: 'grid-cols-6',\n 12: 'grid-cols-12',\n};\n\nconst gapMap: Record<GapSize, string> = {\n 0: 'gap-0',\n 1: 'gap-1',\n 2: 'gap-2',\n 3: 'gap-3',\n 4: 'gap-4',\n 5: 'gap-5',\n 6: 'gap-6',\n 8: 'gap-8',\n 10: 'gap-10',\n 12: 'gap-12',\n 16: 'gap-16',\n};\n\nconst rowGapMap: Record<GapSize, string> = {\n 0: 'gap-y-0',\n 1: 'gap-y-1',\n 2: 'gap-y-2',\n 3: 'gap-y-3',\n 4: 'gap-y-4',\n 5: 'gap-y-5',\n 6: 'gap-y-6',\n 8: 'gap-y-8',\n 10: 'gap-y-10',\n 12: 'gap-y-12',\n 16: 'gap-y-16',\n};\n\nconst colGapMap: Record<GapSize, string> = {\n 0: 'gap-x-0',\n 1: 'gap-x-1',\n 2: 'gap-x-2',\n 3: 'gap-x-3',\n 4: 'gap-x-4',\n 5: 'gap-x-5',\n 6: 'gap-x-6',\n 8: 'gap-x-8',\n 10: 'gap-x-10',\n 12: 'gap-x-12',\n 16: 'gap-x-16',\n};\n\n// Span — bez prefixu (výchozí, mobile-first)\nconst spanMap: Record<ColSpan, string> = {\n 1: 'col-span-1',\n 2: 'col-span-2',\n 3: 'col-span-3',\n 4: 'col-span-4',\n 5: 'col-span-5',\n 6: 'col-span-6',\n 7: 'col-span-7',\n 8: 'col-span-8',\n 9: 'col-span-9',\n 10: 'col-span-10',\n 11: 'col-span-11',\n 12: 'col-span-12',\n};\n\nconst smSpanMap: Record<ColSpan, string> = {\n 1: 'sm:col-span-1',\n 2: 'sm:col-span-2',\n 3: 'sm:col-span-3',\n 4: 'sm:col-span-4',\n 5: 'sm:col-span-5',\n 6: 'sm:col-span-6',\n 7: 'sm:col-span-7',\n 8: 'sm:col-span-8',\n 9: 'sm:col-span-9',\n 10: 'sm:col-span-10',\n 11: 'sm:col-span-11',\n 12: 'sm:col-span-12',\n};\n\nconst mdSpanMap: Record<ColSpan, string> = {\n 1: 'md:col-span-1',\n 2: 'md:col-span-2',\n 3: 'md:col-span-3',\n 4: 'md:col-span-4',\n 5: 'md:col-span-5',\n 6: 'md:col-span-6',\n 7: 'md:col-span-7',\n 8: 'md:col-span-8',\n 9: 'md:col-span-9',\n 10: 'md:col-span-10',\n 11: 'md:col-span-11',\n 12: 'md:col-span-12',\n};\n\nconst lgSpanMap: Record<ColSpan, string> = {\n 1: 'lg:col-span-1',\n 2: 'lg:col-span-2',\n 3: 'lg:col-span-3',\n 4: 'lg:col-span-4',\n 5: 'lg:col-span-5',\n 6: 'lg:col-span-6',\n 7: 'lg:col-span-7',\n 8: 'lg:col-span-8',\n 9: 'lg:col-span-9',\n 10: 'lg:col-span-10',\n 11: 'lg:col-span-11',\n 12: 'lg:col-span-12',\n};\n\nconst xlSpanMap: Record<ColSpan, string> = {\n 1: 'xl:col-span-1',\n 2: 'xl:col-span-2',\n 3: 'xl:col-span-3',\n 4: 'xl:col-span-4',\n 5: 'xl:col-span-5',\n 6: 'xl:col-span-6',\n 7: 'xl:col-span-7',\n 8: 'xl:col-span-8',\n 9: 'xl:col-span-9',\n 10: 'xl:col-span-10',\n 11: 'xl:col-span-11',\n 12: 'xl:col-span-12',\n};\n\n// Offset: přeskočit N sloupců → col-start-(N+1)\nconst offsetMap: Record<ColOffset, string> = {\n 1: 'col-start-2',\n 2: 'col-start-3',\n 3: 'col-start-4',\n 4: 'col-start-5',\n 5: 'col-start-6',\n 6: 'col-start-7',\n 7: 'col-start-8',\n 8: 'col-start-9',\n 9: 'col-start-10',\n 10: 'col-start-11',\n 11: 'col-start-12',\n};\n\nconst smOffsetMap: Record<ColOffset, string> = {\n 1: 'sm:col-start-2',\n 2: 'sm:col-start-3',\n 3: 'sm:col-start-4',\n 4: 'sm:col-start-5',\n 5: 'sm:col-start-6',\n 6: 'sm:col-start-7',\n 7: 'sm:col-start-8',\n 8: 'sm:col-start-9',\n 9: 'sm:col-start-10',\n 10: 'sm:col-start-11',\n 11: 'sm:col-start-12',\n};\n\nconst mdOffsetMap: Record<ColOffset, string> = {\n 1: 'md:col-start-2',\n 2: 'md:col-start-3',\n 3: 'md:col-start-4',\n 4: 'md:col-start-5',\n 5: 'md:col-start-6',\n 6: 'md:col-start-7',\n 7: 'md:col-start-8',\n 8: 'md:col-start-9',\n 9: 'md:col-start-10',\n 10: 'md:col-start-11',\n 11: 'md:col-start-12',\n};\n\nconst lgOffsetMap: Record<ColOffset, string> = {\n 1: 'lg:col-start-2',\n 2: 'lg:col-start-3',\n 3: 'lg:col-start-4',\n 4: 'lg:col-start-5',\n 5: 'lg:col-start-6',\n 6: 'lg:col-start-7',\n 7: 'lg:col-start-8',\n 8: 'lg:col-start-9',\n 9: 'lg:col-start-10',\n 10: 'lg:col-start-11',\n 11: 'lg:col-start-12',\n};\n\nconst xlOffsetMap: Record<ColOffset, string> = {\n 1: 'xl:col-start-2',\n 2: 'xl:col-start-3',\n 3: 'xl:col-start-4',\n 4: 'xl:col-start-5',\n 5: 'xl:col-start-6',\n 6: 'xl:col-start-7',\n 7: 'xl:col-start-8',\n 8: 'xl:col-start-9',\n 9: 'xl:col-start-10',\n 10: 'xl:col-start-11',\n 11: 'xl:col-start-12',\n};\n\n// ─── Components ───────────────────────────────────────────────────────────────\n\nexport const Grid = ({\n children,\n cols = 12,\n gap,\n rowGap,\n colGap,\n as: Tag = 'div',\n className,\n}: GridProps) => (\n <Tag\n className={cx(\n 'grid',\n 'w-full',\n colsMap[cols],\n gap !== undefined && gapMap[gap],\n rowGap !== undefined && rowGapMap[rowGap],\n colGap !== undefined && colGapMap[colGap],\n className,\n )}\n >\n {children}\n </Tag>\n);\n\nGrid.displayName = 'Grid';\n\nexport const Col = ({\n children,\n span,\n sm,\n md,\n lg,\n xl,\n offset,\n smOffset,\n mdOffset,\n lgOffset,\n xlOffset,\n className,\n ...rest\n}: ColProps) => (\n <div\n className={cx(\n span && spanMap[span],\n sm && smSpanMap[sm],\n md && mdSpanMap[md],\n lg && lgSpanMap[lg],\n xl && xlSpanMap[xl],\n offset && offsetMap[offset],\n smOffset && smOffsetMap[smOffset],\n mdOffset && mdOffsetMap[mdOffset],\n lgOffset && lgOffsetMap[lgOffset],\n xlOffset && xlOffsetMap[xlOffset],\n className,\n )}\n {...rest}\n >\n {children}\n </div>\n);\n\nCol.displayName = 'Col';\n","import { useEffect, useId, useRef, useState } from 'react';\nimport clx from 'classnames';\n\nexport interface QuantityInputProps {\n value: number;\n onChange: (value: number) => void;\n min?: number;\n max?: number;\n step?: number;\n disabled?: boolean;\n label?: string;\n error?: string;\n hint?: string;\n id?: string;\n className?: string;\n}\n\nexport const QuantityInput = ({\n value,\n onChange,\n min = 1,\n max = 999,\n step = 1,\n disabled = false,\n label,\n error,\n hint,\n id,\n className,\n}: QuantityInputProps) => {\n const generatedId = useId();\n const inputId = id ?? generatedId;\n const inputRef = useRef<HTMLInputElement>(null);\n\n // Lokální string stav — umožňuje volné psaní, clamping proběhne při blur\n const [inputValue, setInputValue] = useState(String(value));\n\n // Synchronizace při změně value zvenčí (controlled)\n useEffect(() => {\n if (document.activeElement !== inputRef.current) {\n setInputValue(String(value));\n }\n }, [value]);\n\n const clamp = (n: number) => Math.min(max, Math.max(min, n));\n\n const commitValue = (raw: string) => {\n const parsed = parseInt(raw, 10);\n const next = isNaN(parsed) ? value : clamp(parsed);\n setInputValue(String(next));\n if (next !== value) onChange(next);\n };\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const raw = e.target.value.replace(/[^0-9]/g, '');\n setInputValue(raw);\n // Průběžně volej onChange jen pokud je platné číslo\n const parsed = parseInt(raw, 10);\n if (!isNaN(parsed)) onChange(clamp(parsed));\n };\n\n const handleBlur = () => commitValue(inputValue);\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (e.key === 'Enter') {\n commitValue(inputValue);\n inputRef.current?.blur();\n return;\n }\n // Blokuj vše kromě číslic a ovládacích kláves\n const allowed = [\n 'Backspace', 'Delete', 'Tab', 'Escape',\n 'ArrowLeft', 'ArrowRight', 'Home', 'End',\n ];\n if (!allowed.includes(e.key) && !/^[0-9]$/.test(e.key) && !e.metaKey && !e.ctrlKey) {\n e.preventDefault();\n }\n };\n\n const decrement = () => onChange(clamp(value - step));\n const increment = () => onChange(clamp(value + step));\n\n const canDecrement = value - step >= min;\n const canIncrement = value + step <= max;\n\n return (\n <div className={clx('quantity-input-wrapper', className)}>\n {label && (\n <label htmlFor={inputId} className=\"input-label\">\n {label}\n </label>\n )}\n\n <div className={clx('quantity-input', error && 'has-error', disabled && 'is-disabled')}>\n <button\n type=\"button\"\n className=\"quantity-btn\"\n onClick={decrement}\n disabled={disabled || !canDecrement}\n aria-label=\"Snížit množství\"\n tabIndex={-1}\n >\n <MinusIcon />\n </button>\n\n <input\n ref={inputRef}\n id={inputId}\n type=\"text\"\n inputMode=\"numeric\"\n className=\"quantity-field\"\n value={inputValue}\n onChange={handleChange}\n onBlur={handleBlur}\n onKeyDown={handleKeyDown}\n disabled={disabled}\n aria-label={label ?? 'Množství'}\n aria-valuemin={min}\n aria-valuemax={max}\n aria-valuenow={value}\n />\n\n <button\n type=\"button\"\n className=\"quantity-btn\"\n onClick={increment}\n disabled={disabled || !canIncrement}\n aria-label=\"Zvýšit množství\"\n tabIndex={-1}\n >\n <PlusIcon />\n </button>\n </div>\n\n {(error || hint) && (\n <p className={clx('helper-text', error && 'has-error')}>{error ?? hint}</p>\n )}\n </div>\n );\n};\n\nQuantityInput.displayName = 'QuantityInput';\n\nconst MinusIcon = () => (\n <svg width=\"12\" height=\"2\" viewBox=\"0 0 12 2\" fill=\"none\" aria-hidden=\"true\">\n <path d=\"M1 1H11\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" />\n </svg>\n);\n\nconst PlusIcon = () => (\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" aria-hidden=\"true\">\n <path d=\"M6 1V11M1 6H11\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" />\n </svg>\n);\n","'use client';\n\nimport type { ButtonHTMLAttributes } from 'react';\nimport clx from 'classnames';\n\nexport interface PaginationProps {\n page: number;\n totalPages: number;\n onPageChange: (page: number) => void;\n siblingsCount?: number;\n}\n\nconst range = (start: number, end: number) =>\n Array.from({ length: end - start + 1 }, (_, i) => start + i);\n\nconst buildPages = (\n page: number,\n totalPages: number,\n siblings: number,\n): (number | '…')[] => {\n const totalNumbers = siblings * 2 + 5;\n\n if (totalPages <= totalNumbers) return range(1, totalPages);\n\n const leftSibling = Math.max(page - siblings, 1);\n const rightSibling = Math.min(page + siblings, totalPages);\n const showLeftDots = leftSibling > 2;\n const showRightDots = rightSibling < totalPages - 1;\n\n if (!showLeftDots && showRightDots) {\n const leftRange = range(1, 3 + siblings * 2);\n return [...leftRange, '…', totalPages];\n }\n\n if (showLeftDots && !showRightDots) {\n const rightRange = range(totalPages - (2 + siblings * 2), totalPages);\n return [1, '…', ...rightRange];\n }\n\n return [1, '…', ...range(leftSibling, rightSibling), '…', totalPages];\n};\n\nconst PageButton = ({\n active,\n disabled,\n children,\n ...props\n}: ButtonHTMLAttributes<HTMLButtonElement> & { active?: boolean }) => {\n return (\n <button\n disabled={disabled}\n className={clx(\n 'pagination-button',\n `pagination-button-${active ? 'active' : 'inactive'}`,\n )}\n {...props}\n >\n {children}\n </button>\n );\n};\n\nexport const Pagination = ({\n page,\n totalPages,\n onPageChange,\n siblingsCount = 1,\n}: PaginationProps) => {\n const pages = buildPages(page, totalPages, siblingsCount);\n\n return (\n <nav aria-label=\"Pagination\" className=\"pagination\">\n <PageButton\n disabled={page <= 1}\n onClick={() => onPageChange(page - 1)}\n aria-label=\"Previous page\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M15.75 19.5L8.25 12l7.5-7.5\"\n />\n </svg>\n </PageButton>\n\n {pages.map((p, i) =>\n p === '…' ? (\n <span key={`dots-${i}`} className=\"pagination-dots\">\n …\n </span>\n ) : (\n <PageButton\n key={p}\n active={p === page}\n onClick={() => onPageChange(p)}\n aria-label={`Page ${p}`}\n aria-current={p === page ? 'page' : undefined}\n >\n {p}\n </PageButton>\n ),\n )}\n\n <PageButton\n disabled={page >= totalPages}\n onClick={() => onPageChange(page + 1)}\n aria-label=\"Next page\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M8.25 4.5l7.5 7.5-7.5 7.5\"\n />\n </svg>\n </PageButton>\n </nav>\n );\n};\n","import cx from 'classnames';\n\ninterface CarouselBtnProps {\n direction: 'prev' | 'next';\n disabled?: boolean;\n onClick?: () => void;\n}\n\nexport const CarouselBtn = ({\n direction,\n disabled,\n onClick,\n}: CarouselBtnProps) => {\n return (\n <button\n onClick={onClick}\n disabled={disabled}\n className={cx(\n 'carousel-btn',\n direction === 'prev' ? 'carousel-btn-prev' : 'carousel-btn-next',\n )}\n aria-label={direction === 'prev' ? 'Previous slide' : 'Next slide'}\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-5 h-5\"\n >\n {direction === 'prev' ? (\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M15.75 19.5L8.25 12l7.5-7.5\"\n />\n ) : (\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M8.25 4.5l7.5 7.5-7.5 7.5\"\n />\n )}\n </svg>\n </button>\n );\n};\n","import {\n useState,\n useEffect,\n useLayoutEffect,\n useCallback,\n useRef,\n Children,\n Fragment,\n} from 'react';\nimport type { ReactNode, HTMLAttributes, CSSProperties } from 'react';\nimport clx from 'classnames';\nimport { CarouselBtn } from './CarouselBtn';\n\nexport interface CarouselCoverProps {\n /** Image URL rendered as background-size: cover */\n src: string;\n alt?: string;\n children?: ReactNode;\n className?: string;\n style?: CSSProperties;\n}\n\n/** Drop inside a Carousel slide — renders image as cover background */\nexport function CarouselCover({\n src,\n alt,\n children,\n className,\n style,\n}: CarouselCoverProps) {\n return (\n <div\n role={alt ? 'img' : undefined}\n aria-label={alt}\n className={clx('carousel-cover', className)}\n style={{ backgroundImage: `url(${src})`, ...style }}\n >\n {children}\n </div>\n );\n}\n\nexport interface CarouselProps extends HTMLAttributes<HTMLDivElement> {\n children: ReactNode;\n /** Number of slides visible at once */\n slidesPerView?: number;\n /** Gap between slides in px */\n gap?: number;\n /** Fixed slide height in px */\n height?: number;\n /** Show prev/next arrow buttons */\n arrows?: boolean;\n /** Show dot navigation indicators */\n dots?: boolean;\n autoPlay?: boolean;\n autoPlayInterval?: number;\n /** Wrap around from last to first slide */\n loop?: boolean;\n}\n\nexport function Carousel({\n children,\n slidesPerView = 1,\n gap = 16,\n height,\n arrows = true,\n dots = true,\n autoPlay = false,\n autoPlayInterval = 4000,\n loop = false,\n className,\n ...props\n}: CarouselProps) {\n const slides = Children.toArray(children);\n const count = slides.length;\n const maxIndex = loop ? count - 1 : Math.max(0, count - slidesPerView);\n const hasNav = count > slidesPerView;\n\n const [current, setCurrent] = useState(0);\n const [paused, setPaused] = useState(false);\n const trackRef = useRef<HTMLDivElement>(null);\n const viewportRef = useRef<HTMLDivElement>(null);\n const timerRef = useRef<ReturnType<typeof setInterval> | null>(null);\n const touchStartX = useRef<number | null>(null);\n\n const applyTransform = useCallback((index: number, animated = true) => {\n const track = trackRef.current;\n if (!track) return;\n const slide = track.children[index] as HTMLElement | undefined;\n if (!slide) return;\n if (!animated) {\n track.style.transition = 'none';\n track.getBoundingClientRect();\n }\n track.style.transform = `translateX(${-slide.offsetLeft}px)`;\n if (!animated) {\n track.getBoundingClientRect();\n track.style.transition = '';\n }\n }, []);\n\n const goTo = useCallback(\n (index: number) => {\n const next = loop\n ? ((index % count) + count) % count\n : Math.max(0, Math.min(index, maxIndex));\n setCurrent(next);\n },\n [count, loop, maxIndex],\n );\n\n const prev = useCallback(() => goTo(current - 1), [current, goTo]);\n const next = useCallback(() => goTo(current + 1), [current, goTo]);\n\n useLayoutEffect(() => {\n applyTransform(current);\n }, [current, applyTransform]);\n\n useEffect(() => {\n const viewport = viewportRef.current;\n if (!viewport) return;\n const observer = new ResizeObserver(() => applyTransform(current, false));\n observer.observe(viewport);\n return () => observer.disconnect();\n }, [current, applyTransform]);\n\n useEffect(() => {\n if (!autoPlay || paused || !hasNav) return;\n timerRef.current = setInterval(next, autoPlayInterval);\n return () => {\n if (timerRef.current) clearInterval(timerRef.current);\n };\n }, [autoPlay, paused, autoPlayInterval, next, hasNav]);\n\n const handleTouchStart = (e: React.TouchEvent) => {\n touchStartX.current = e.touches[0].clientX;\n };\n const handleTouchEnd = (e: React.TouchEvent) => {\n if (touchStartX.current === null) return;\n const delta = e.changedTouches[0].clientX - touchStartX.current;\n if (Math.abs(delta) > 50) delta < 0 ? next() : prev();\n touchStartX.current = null;\n };\n\n if (count === 0) return null;\n\n const canGoPrev = loop || current > 0;\n const canGoNext = loop || current < maxIndex;\n\n const slideWidth = `calc((100% - ${gap}px * ${slidesPerView - 1}) / ${slidesPerView})`;\n\n return (\n <div\n className={clx('carousel-wrapper', className)}\n onMouseEnter={() => setPaused(true)}\n onMouseLeave={() => setPaused(false)}\n onTouchStart={handleTouchStart}\n onTouchEnd={handleTouchEnd}\n {...props}\n >\n <div\n ref={viewportRef}\n className=\"carousel-viewport\"\n style={height ? { height } : undefined}\n >\n <div\n ref={trackRef}\n className=\"carousel-track\"\n style={{ gap: `${gap}px` }}\n >\n {slides.map((slide, i) => (\n <div\n key={i}\n className=\"carousel-slide\"\n style={{\n minWidth: slideWidth,\n maxWidth: slideWidth,\n ...(height && { height }),\n }}\n aria-hidden={i < current || i >= current + slidesPerView}\n >\n {slide}\n </div>\n ))}\n </div>\n </div>\n {arrows && hasNav && (\n <Fragment>\n <CarouselBtn direction=\"prev\" disabled={!canGoPrev} onClick={prev} />\n <CarouselBtn direction=\"next\" disabled={!canGoNext} onClick={next} />\n </Fragment>\n )}\n {dots && hasNav && (\n <div className=\"carousel-dots\">\n {Array.from({ length: maxIndex + 1 }).map((_, i) => (\n <button\n key={i}\n onClick={() => goTo(i)}\n className={clx(\n 'carousel-dot',\n i === current && 'carousel-dot-active',\n )}\n aria-label={`Go to slide ${i + 1}`}\n aria-current={i === current ? 'true' : undefined}\n />\n ))}\n </div>\n )}\n </div>\n );\n}\n","var isMergeableObject = function isMergeableObject(value) {\n\treturn isNonNullObject(value)\n\t\t&& !isSpecial(value)\n};\n\nfunction isNonNullObject(value) {\n\treturn !!value && typeof value === 'object'\n}\n\nfunction isSpecial(value) {\n\tvar stringValue = Object.prototype.toString.call(value);\n\n\treturn stringValue === '[object RegExp]'\n\t\t|| stringValue === '[object Date]'\n\t\t|| isReactElement(value)\n}\n\n// see https://github.com/facebook/react/blob/b5ac963fb791d1298e7f396236383bc955f916c1/src/isomorphic/classic/element/ReactElement.js#L21-L25\nvar canUseSymbol = typeof Symbol === 'function' && Symbol.for;\nvar REACT_ELEMENT_TYPE = canUseSymbol ? Symbol.for('react.element') : 0xeac7;\n\nfunction isReactElement(value) {\n\treturn value.$$typeof === REACT_ELEMENT_TYPE\n}\n\nfunction emptyTarget(val) {\n\treturn Array.isArray(val) ? [] : {}\n}\n\nfunction cloneUnlessOtherwiseSpecified(value, options) {\n\treturn (options.clone !== false && options.isMergeableObject(value))\n\t\t? deepmerge(emptyTarget(value), value, options)\n\t\t: value\n}\n\nfunction defaultArrayMerge(target, source, options) {\n\treturn target.concat(source).map(function(element) {\n\t\treturn cloneUnlessOtherwiseSpecified(element, options)\n\t})\n}\n\nfunction mergeObject(target, source, options) {\n\tvar destination = {};\n\tif (options.isMergeableObject(target)) {\n\t\tObject.keys(target).forEach(function(key) {\n\t\t\tdestination[key] = cloneUnlessOtherwiseSpecified(target[key], options);\n\t\t});\n\t}\n\tObject.keys(source).forEach(function(key) {\n\t\tif (!options.isMergeableObject(source[key]) || !target[key]) {\n\t\t\tdestination[key] = cloneUnlessOtherwiseSpecified(source[key], options);\n\t\t} else {\n\t\t\tdestination[key] = deepmerge(target[key], source[key], options);\n\t\t}\n\t});\n\treturn destination\n}\n\nfunction deepmerge(target, source, options) {\n\toptions = options || {};\n\toptions.arrayMerge = options.arrayMerge || defaultArrayMerge;\n\toptions.isMergeableObject = options.isMergeableObject || isMergeableObject;\n\n\tvar sourceIsArray = Array.isArray(source);\n\tvar targetIsArray = Array.isArray(target);\n\tvar sourceAndTargetTypesMatch = sourceIsArray === targetIsArray;\n\n\tif (!sourceAndTargetTypesMatch) {\n\t\treturn cloneUnlessOtherwiseSpecified(source, options)\n\t} else if (sourceIsArray) {\n\t\treturn options.arrayMerge(target, source, options)\n\t} else {\n\t\treturn mergeObject(target, source, options)\n\t}\n}\n\ndeepmerge.all = function deepmergeAll(array, options) {\n\tif (!Array.isArray(array)) {\n\t\tthrow new Error('first argument should be an array')\n\t}\n\n\treturn array.reduce(function(prev, next) {\n\t\treturn deepmerge(prev, next, options)\n\t}, {})\n};\n\nvar deepmerge_1 = deepmerge;\n\nexport default deepmerge_1;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nexport default freeGlobal;\n","import freeGlobal from './_freeGlobal.js';\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nexport default root;\n","import root from './_root.js';\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nexport default Symbol;\n","import Symbol from './_Symbol.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nexport default getRawTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nexport default objectToString;\n","import Symbol from './_Symbol.js';\nimport getRawTag from './_getRawTag.js';\nimport objectToString from './_objectToString.js';\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nexport default baseGetTag;\n","/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\nexport default overArg;\n","import overArg from './_overArg.js';\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nexport default getPrototype;\n","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nexport default isObjectLike;\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\nexport default listCacheClear;\n","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\nexport default eq;\n","import eq from './eq.js';\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\nexport default assocIndexOf;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\nexport default listCacheDelete;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\nexport default listCacheGet;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\nexport default listCacheHas;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\nexport default listCacheSet;\n","import listCacheClear from './_listCacheClear.js';\nimport listCacheDelete from './_listCacheDelete.js';\nimport listCacheGet from './_listCacheGet.js';\nimport listCacheHas from './_listCacheHas.js';\nimport listCacheSet from './_listCacheSet.js';\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nexport default ListCache;\n","import ListCache from './_ListCache.js';\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\nexport default stackClear;\n","/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\nexport default stackDelete;\n","/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\nexport default stackGet;\n","/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\nexport default stackHas;\n","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nexport default isObject;\n","import baseGetTag from './_baseGetTag.js';\nimport isObject from './isObject.js';\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nexport default isFunction;\n","import root from './_root.js';\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nexport default coreJsData;\n","import coreJsData from './_coreJsData.js';\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\nexport default isMasked;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\nexport default toSource;\n","import isFunction from './isFunction.js';\nimport isMasked from './_isMasked.js';\nimport isObject from './isObject.js';\nimport toSource from './_toSource.js';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\nexport default baseIsNative;\n","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\nexport default getValue;\n","import baseIsNative from './_baseIsNative.js';\nimport getValue from './_getValue.js';\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\nexport default getNative;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nexport default Map;\n","import getNative from './_getNative.js';\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nexport default nativeCreate;\n","import nativeCreate from './_nativeCreate.js';\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\nexport default hashClear;\n","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\nexport default hashDelete;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nexport default hashGet;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nexport default hashHas;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\nexport default hashSet;\n","import hashClear from './_hashClear.js';\nimport hashDelete from './_hashDelete.js';\nimport hashGet from './_hashGet.js';\nimport hashHas from './_hashHas.js';\nimport hashSet from './_hashSet.js';\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nexport default Hash;\n","import Hash from './_Hash.js';\nimport ListCache from './_ListCache.js';\nimport Map from './_Map.js';\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\nexport default mapCacheClear;\n","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\nexport default isKeyable;\n","import isKeyable from './_isKeyable.js';\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\nexport default getMapData;\n","import getMapData from './_getMapData.js';\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\nexport default mapCacheDelete;\n","import getMapData from './_getMapData.js';\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\nexport default mapCacheGet;\n","import getMapData from './_getMapData.js';\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\nexport default mapCacheHas;\n","import getMapData from './_getMapData.js';\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\nexport default mapCacheSet;\n","import mapCacheClear from './_mapCacheClear.js';\nimport mapCacheDelete from './_mapCacheDelete.js';\nimport mapCacheGet from './_mapCacheGet.js';\nimport mapCacheHas from './_mapCacheHas.js';\nimport mapCacheSet from './_mapCacheSet.js';\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nexport default MapCache;\n","import ListCache from './_ListCache.js';\nimport Map from './_Map.js';\nimport MapCache from './_MapCache.js';\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\nexport default stackSet;\n","import ListCache from './_ListCache.js';\nimport stackClear from './_stackClear.js';\nimport stackDelete from './_stackDelete.js';\nimport stackGet from './_stackGet.js';\nimport stackHas from './_stackHas.js';\nimport stackSet from './_stackSet.js';\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nexport default Stack;\n","/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\nfunction arrayEach(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (iteratee(array[index], index, array) === false) {\n break;\n }\n }\n return array;\n}\n\nexport default arrayEach;\n","import getNative from './_getNative.js';\n\nvar defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n}());\n\nexport default defineProperty;\n","import defineProperty from './_defineProperty.js';\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n}\n\nexport default baseAssignValue;\n","import baseAssignValue from './_baseAssignValue.js';\nimport eq from './eq.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n var objValue = object[key];\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n}\n\nexport default assignValue;\n","import assignValue from './_assignValue.js';\nimport baseAssignValue from './_baseAssignValue.js';\n\n/**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object, customizer) {\n var isNew = !object;\n object || (object = {});\n\n var index = -1,\n length = props.length;\n\n while (++index < length) {\n var key = props[index];\n\n var newValue = customizer\n ? customizer(object[key], source[key], key, object, source)\n : undefined;\n\n if (newValue === undefined) {\n newValue = source[key];\n }\n if (isNew) {\n baseAssignValue(object, key, newValue);\n } else {\n assignValue(object, key, newValue);\n }\n }\n return object;\n}\n\nexport default copyObject;\n","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\nexport default baseTimes;\n","import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nexport default baseIsArguments;\n","import baseIsArguments from './_baseIsArguments.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\nexport default isArguments;\n","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nexport default isArray;\n","/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nexport default stubFalse;\n","import root from './_root.js';\nimport stubFalse from './stubFalse.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nexport default isBuffer;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nexport default isIndex;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nexport default isLength;\n","import baseGetTag from './_baseGetTag.js';\nimport isLength from './isLength.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nexport default baseIsTypedArray;\n","/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\nexport default baseUnary;\n","import freeGlobal from './_freeGlobal.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n // Use `util.types` for Node.js 10+.\n var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n if (types) {\n return types;\n }\n\n // Legacy `process.binding('util')` for Node.js < 10.\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\nexport default nodeUtil;\n","import baseIsTypedArray from './_baseIsTypedArray.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nexport default isTypedArray;\n","import baseTimes from './_baseTimes.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\nimport isBuffer from './isBuffer.js';\nimport isIndex from './_isIndex.js';\nimport isTypedArray from './isTypedArray.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\nexport default arrayLikeKeys;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\nexport default isPrototype;\n","import overArg from './_overArg.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nexport default nativeKeys;\n","import isPrototype from './_isPrototype.js';\nimport nativeKeys from './_nativeKeys.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\nexport default baseKeys;\n","import isFunction from './isFunction.js';\nimport isLength from './isLength.js';\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\nexport default isArrayLike;\n","import arrayLikeKeys from './_arrayLikeKeys.js';\nimport baseKeys from './_baseKeys.js';\nimport isArrayLike from './isArrayLike.js';\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nexport default keys;\n","import copyObject from './_copyObject.js';\nimport keys from './keys.js';\n\n/**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssign(object, source) {\n return object && copyObject(source, keys(source), object);\n}\n\nexport default baseAssign;\n","/**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction nativeKeysIn(object) {\n var result = [];\n if (object != null) {\n for (var key in Object(object)) {\n result.push(key);\n }\n }\n return result;\n}\n\nexport default nativeKeysIn;\n","import isObject from './isObject.js';\nimport isPrototype from './_isPrototype.js';\nimport nativeKeysIn from './_nativeKeysIn.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeysIn(object) {\n if (!isObject(object)) {\n return nativeKeysIn(object);\n }\n var isProto = isPrototype(object),\n result = [];\n\n for (var key in object) {\n if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n result.push(key);\n }\n }\n return result;\n}\n\nexport default baseKeysIn;\n","import arrayLikeKeys from './_arrayLikeKeys.js';\nimport baseKeysIn from './_baseKeysIn.js';\nimport isArrayLike from './isArrayLike.js';\n\n/**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\nfunction keysIn(object) {\n return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n}\n\nexport default keysIn;\n","import copyObject from './_copyObject.js';\nimport keysIn from './keysIn.js';\n\n/**\n * The base implementation of `_.assignIn` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssignIn(object, source) {\n return object && copyObject(source, keysIn(source), object);\n}\n\nexport default baseAssignIn;\n","import root from './_root.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined;\n\n/**\n * Creates a clone of `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\nfunction cloneBuffer(buffer, isDeep) {\n if (isDeep) {\n return buffer.slice();\n }\n var length = buffer.length,\n result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n buffer.copy(result);\n return result;\n}\n\nexport default cloneBuffer;\n","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n var index = -1,\n length = source.length;\n\n array || (array = Array(length));\n while (++index < length) {\n array[index] = source[index];\n }\n return array;\n}\n\nexport default copyArray;\n","/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\nexport default arrayFilter;\n","/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\nexport default stubArray;\n","import arrayFilter from './_arrayFilter.js';\nimport stubArray from './stubArray.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\nexport default getSymbols;\n","import copyObject from './_copyObject.js';\nimport getSymbols from './_getSymbols.js';\n\n/**\n * Copies own symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbols(source, object) {\n return copyObject(source, getSymbols(source), object);\n}\n\nexport default copySymbols;\n","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\nexport default arrayPush;\n","import arrayPush from './_arrayPush.js';\nimport getPrototype from './_getPrototype.js';\nimport getSymbols from './_getSymbols.js';\nimport stubArray from './stubArray.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own and inherited enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {\n var result = [];\n while (object) {\n arrayPush(result, getSymbols(object));\n object = getPrototype(object);\n }\n return result;\n};\n\nexport default getSymbolsIn;\n","import copyObject from './_copyObject.js';\nimport getSymbolsIn from './_getSymbolsIn.js';\n\n/**\n * Copies own and inherited symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbolsIn(source, object) {\n return copyObject(source, getSymbolsIn(source), object);\n}\n\nexport default copySymbolsIn;\n","import arrayPush from './_arrayPush.js';\nimport isArray from './isArray.js';\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\nexport default baseGetAllKeys;\n","import baseGetAllKeys from './_baseGetAllKeys.js';\nimport getSymbols from './_getSymbols.js';\nimport keys from './keys.js';\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\nexport default getAllKeys;\n","import baseGetAllKeys from './_baseGetAllKeys.js';\nimport getSymbolsIn from './_getSymbolsIn.js';\nimport keysIn from './keysIn.js';\n\n/**\n * Creates an array of own and inherited enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeysIn(object) {\n return baseGetAllKeys(object, keysIn, getSymbolsIn);\n}\n\nexport default getAllKeysIn;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView');\n\nexport default DataView;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Promise = getNative(root, 'Promise');\n\nexport default Promise;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nexport default Set;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nexport default WeakMap;\n","import DataView from './_DataView.js';\nimport Map from './_Map.js';\nimport Promise from './_Promise.js';\nimport Set from './_Set.js';\nimport WeakMap from './_WeakMap.js';\nimport baseGetTag from './_baseGetTag.js';\nimport toSource from './_toSource.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n setTag = '[object Set]',\n weakMapTag = '[object WeakMap]';\n\nvar dataViewTag = '[object DataView]';\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\nexport default getTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n var length = array.length,\n result = new array.constructor(length);\n\n // Add properties assigned by `RegExp#exec`.\n if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n result.index = array.index;\n result.input = array.input;\n }\n return result;\n}\n\nexport default initCloneArray;\n","import root from './_root.js';\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nexport default Uint8Array;\n","import Uint8Array from './_Uint8Array.js';\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n return result;\n}\n\nexport default cloneArrayBuffer;\n","import cloneArrayBuffer from './_cloneArrayBuffer.js';\n\n/**\n * Creates a clone of `dataView`.\n *\n * @private\n * @param {Object} dataView The data view to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned data view.\n */\nfunction cloneDataView(dataView, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n}\n\nexport default cloneDataView;\n","/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\nfunction cloneRegExp(regexp) {\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n result.lastIndex = regexp.lastIndex;\n return result;\n}\n\nexport default cloneRegExp;\n","import Symbol from './_Symbol.js';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\nfunction cloneSymbol(symbol) {\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n}\n\nexport default cloneSymbol;\n","import cloneArrayBuffer from './_cloneArrayBuffer.js';\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nexport default cloneTypedArray;\n","import cloneArrayBuffer from './_cloneArrayBuffer.js';\nimport cloneDataView from './_cloneDataView.js';\nimport cloneRegExp from './_cloneRegExp.js';\nimport cloneSymbol from './_cloneSymbol.js';\nimport cloneTypedArray from './_cloneTypedArray.js';\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, isDeep) {\n var Ctor = object.constructor;\n switch (tag) {\n case arrayBufferTag:\n return cloneArrayBuffer(object);\n\n case boolTag:\n case dateTag:\n return new Ctor(+object);\n\n case dataViewTag:\n return cloneDataView(object, isDeep);\n\n case float32Tag: case float64Tag:\n case int8Tag: case int16Tag: case int32Tag:\n case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n return cloneTypedArray(object, isDeep);\n\n case mapTag:\n return new Ctor;\n\n case numberTag:\n case stringTag:\n return new Ctor(object);\n\n case regexpTag:\n return cloneRegExp(object);\n\n case setTag:\n return new Ctor;\n\n case symbolTag:\n return cloneSymbol(object);\n }\n}\n\nexport default initCloneByTag;\n","import isObject from './isObject.js';\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nvar baseCreate = (function() {\n function object() {}\n return function(proto) {\n if (!isObject(proto)) {\n return {};\n }\n if (objectCreate) {\n return objectCreate(proto);\n }\n object.prototype = proto;\n var result = new object;\n object.prototype = undefined;\n return result;\n };\n}());\n\nexport default baseCreate;\n","import baseCreate from './_baseCreate.js';\nimport getPrototype from './_getPrototype.js';\nimport isPrototype from './_isPrototype.js';\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n return (typeof object.constructor == 'function' && !isPrototype(object))\n ? baseCreate(getPrototype(object))\n : {};\n}\n\nexport default initCloneObject;\n","import getTag from './_getTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]';\n\n/**\n * The base implementation of `_.isMap` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n */\nfunction baseIsMap(value) {\n return isObjectLike(value) && getTag(value) == mapTag;\n}\n\nexport default baseIsMap;\n","import baseIsMap from './_baseIsMap.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsMap = nodeUtil && nodeUtil.isMap;\n\n/**\n * Checks if `value` is classified as a `Map` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n * @example\n *\n * _.isMap(new Map);\n * // => true\n *\n * _.isMap(new WeakMap);\n * // => false\n */\nvar isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\n\nexport default isMap;\n","import getTag from './_getTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar setTag = '[object Set]';\n\n/**\n * The base implementation of `_.isSet` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n */\nfunction baseIsSet(value) {\n return isObjectLike(value) && getTag(value) == setTag;\n}\n\nexport default baseIsSet;\n","import baseIsSet from './_baseIsSet.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsSet = nodeUtil && nodeUtil.isSet;\n\n/**\n * Checks if `value` is classified as a `Set` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n * @example\n *\n * _.isSet(new Set);\n * // => true\n *\n * _.isSet(new WeakSet);\n * // => false\n */\nvar isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\n\nexport default isSet;\n","import Stack from './_Stack.js';\nimport arrayEach from './_arrayEach.js';\nimport assignValue from './_assignValue.js';\nimport baseAssign from './_baseAssign.js';\nimport baseAssignIn from './_baseAssignIn.js';\nimport cloneBuffer from './_cloneBuffer.js';\nimport copyArray from './_copyArray.js';\nimport copySymbols from './_copySymbols.js';\nimport copySymbolsIn from './_copySymbolsIn.js';\nimport getAllKeys from './_getAllKeys.js';\nimport getAllKeysIn from './_getAllKeysIn.js';\nimport getTag from './_getTag.js';\nimport initCloneArray from './_initCloneArray.js';\nimport initCloneByTag from './_initCloneByTag.js';\nimport initCloneObject from './_initCloneObject.js';\nimport isArray from './isArray.js';\nimport isBuffer from './isBuffer.js';\nimport isMap from './isMap.js';\nimport isObject from './isObject.js';\nimport isSet from './isSet.js';\nimport keys from './keys.js';\nimport keysIn from './keysIn.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_FLAT_FLAG = 2,\n CLONE_SYMBOLS_FLAG = 4;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\ncloneableTags[boolTag] = cloneableTags[dateTag] =\ncloneableTags[float32Tag] = cloneableTags[float64Tag] =\ncloneableTags[int8Tag] = cloneableTags[int16Tag] =\ncloneableTags[int32Tag] = cloneableTags[mapTag] =\ncloneableTags[numberTag] = cloneableTags[objectTag] =\ncloneableTags[regexpTag] = cloneableTags[setTag] =\ncloneableTags[stringTag] = cloneableTags[symbolTag] =\ncloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\ncloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Deep clone\n * 2 - Flatten inherited properties\n * 4 - Clone symbols\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\nfunction baseClone(value, bitmask, customizer, key, object, stack) {\n var result,\n isDeep = bitmask & CLONE_DEEP_FLAG,\n isFlat = bitmask & CLONE_FLAT_FLAG,\n isFull = bitmask & CLONE_SYMBOLS_FLAG;\n\n if (customizer) {\n result = object ? customizer(value, key, object, stack) : customizer(value);\n }\n if (result !== undefined) {\n return result;\n }\n if (!isObject(value)) {\n return value;\n }\n var isArr = isArray(value);\n if (isArr) {\n result = initCloneArray(value);\n if (!isDeep) {\n return copyArray(value, result);\n }\n } else {\n var tag = getTag(value),\n isFunc = tag == funcTag || tag == genTag;\n\n if (isBuffer(value)) {\n return cloneBuffer(value, isDeep);\n }\n if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n result = (isFlat || isFunc) ? {} : initCloneObject(value);\n if (!isDeep) {\n return isFlat\n ? copySymbolsIn(value, baseAssignIn(result, value))\n : copySymbols(value, baseAssign(result, value));\n }\n } else {\n if (!cloneableTags[tag]) {\n return object ? value : {};\n }\n result = initCloneByTag(value, tag, isDeep);\n }\n }\n // Check for circular references and return its corresponding clone.\n stack || (stack = new Stack);\n var stacked = stack.get(value);\n if (stacked) {\n return stacked;\n }\n stack.set(value, result);\n\n if (isSet(value)) {\n value.forEach(function(subValue) {\n result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));\n });\n } else if (isMap(value)) {\n value.forEach(function(subValue, key) {\n result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n }\n\n var keysFunc = isFull\n ? (isFlat ? getAllKeysIn : getAllKeys)\n : (isFlat ? keysIn : keys);\n\n var props = isArr ? undefined : keysFunc(value);\n arrayEach(props || value, function(subValue, key) {\n if (props) {\n key = subValue;\n subValue = value[key];\n }\n // Recursively populate clone (susceptible to call stack limits).\n assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n return result;\n}\n\nexport default baseClone;\n","import baseClone from './_baseClone.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * This method is like `_.clone` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @returns {*} Returns the deep cloned value.\n * @see _.clone\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var deep = _.cloneDeep(objects);\n * console.log(deep[0] === objects[0]);\n * // => false\n */\nfunction cloneDeep(value) {\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\n}\n\nexport default cloneDeep;\n","'use strict';\n\nvar isArray = Array.isArray;\nvar keyList = Object.keys;\nvar hasProp = Object.prototype.hasOwnProperty;\nvar hasElementType = typeof Element !== 'undefined';\n\nfunction equal(a, b) {\n // fast-deep-equal index.js 2.0.1\n if (a === b) return true;\n\n if (a && b && typeof a == 'object' && typeof b == 'object') {\n var arrA = isArray(a)\n , arrB = isArray(b)\n , i\n , length\n , key;\n\n if (arrA && arrB) {\n length = a.length;\n if (length != b.length) return false;\n for (i = length; i-- !== 0;)\n if (!equal(a[i], b[i])) return false;\n return true;\n }\n\n if (arrA != arrB) return false;\n\n var dateA = a instanceof Date\n , dateB = b instanceof Date;\n if (dateA != dateB) return false;\n if (dateA && dateB) return a.getTime() == b.getTime();\n\n var regexpA = a instanceof RegExp\n , regexpB = b instanceof RegExp;\n if (regexpA != regexpB) return false;\n if (regexpA && regexpB) return a.toString() == b.toString();\n\n var keys = keyList(a);\n length = keys.length;\n\n if (length !== keyList(b).length)\n return false;\n\n for (i = length; i-- !== 0;)\n if (!hasProp.call(b, keys[i])) return false;\n // end fast-deep-equal\n\n // start react-fast-compare\n // custom handling for DOM elements\n if (hasElementType && a instanceof Element && b instanceof Element)\n return a === b;\n\n // custom handling for React\n for (i = length; i-- !== 0;) {\n key = keys[i];\n if (key === '_owner' && a.$$typeof) {\n // React-specific: avoid traversing React elements' _owner.\n // _owner contains circular references\n // and is not needed when comparing the actual elements (and not their owners)\n // .$$typeof and ._store on just reasonable markers of a react element\n continue;\n } else {\n // all other properties should be traversed as usual\n if (!equal(a[key], b[key])) return false;\n }\n }\n // end react-fast-compare\n\n // fast-deep-equal index.js 2.0.1\n return true;\n }\n\n return a !== a && b !== b;\n}\n// end fast-deep-equal\n\nmodule.exports = function exportedEqual(a, b) {\n try {\n return equal(a, b);\n } catch (error) {\n if ((error.message && error.message.match(/stack|recursion/i)) || (error.number === -2146828260)) {\n // warn on circular references, don't crash\n // browsers give this different errors name and messages:\n // chrome/safari: \"RangeError\", \"Maximum call stack size exceeded\"\n // firefox: \"InternalError\", too much recursion\"\n // edge: \"Error\", \"Out of stack space\"\n console.warn('Warning: react-fast-compare does not handle circular references.', error.name, error.message);\n return false;\n }\n // some other error. we should definitely know about these\n throw error;\n }\n};\n","var isProduction = process.env.NODE_ENV === 'production';\nfunction warning(condition, message) {\n if (!isProduction) {\n if (condition) {\n return;\n }\n\n var text = \"Warning: \" + message;\n\n if (typeof console !== 'undefined') {\n console.warn(text);\n }\n\n try {\n throw Error(text);\n } catch (x) {}\n }\n}\n\nexport default warning;\n","import baseClone from './_baseClone.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * Creates a shallow clone of `value`.\n *\n * **Note:** This method is loosely based on the\n * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)\n * and supports cloning arrays, array buffers, booleans, date objects, maps,\n * numbers, `Object` objects, regexes, sets, strings, symbols, and typed\n * arrays. The own enumerable properties of `arguments` objects are cloned\n * as plain objects. An empty object is returned for uncloneable values such\n * as error objects, functions, DOM nodes, and WeakMaps.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to clone.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeep\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var shallow = _.clone(objects);\n * console.log(shallow[0] === objects[0]);\n * // => true\n */\nfunction clone(value) {\n return baseClone(value, CLONE_SYMBOLS_FLAG);\n}\n\nexport default clone;\n","/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length,\n result = Array(length);\n\n while (++index < length) {\n result[index] = iteratee(array[index], index, array);\n }\n return result;\n}\n\nexport default arrayMap;\n","import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nexport default isSymbol;\n","import MapCache from './_MapCache.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nexport default memoize;\n","import memoize from './memoize.js';\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n var result = memoize(func, function(key) {\n if (cache.size === MAX_MEMOIZE_SIZE) {\n cache.clear();\n }\n return key;\n });\n\n var cache = result.cache;\n return result;\n}\n\nexport default memoizeCapped;\n","import memoizeCapped from './_memoizeCapped.js';\n\n/** Used to match property names within property paths. */\nvar rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n var result = [];\n if (string.charCodeAt(0) === 46 /* . */) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, subString) {\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n});\n\nexport default stringToPath;\n","import isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nexport default toKey;\n","import Symbol from './_Symbol.js';\nimport arrayMap from './_arrayMap.js';\nimport isArray from './isArray.js';\nimport isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isArray(value)) {\n // Recursively convert values (susceptible to call stack limits).\n return arrayMap(value, baseToString) + '';\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nexport default baseToString;\n","import baseToString from './_baseToString.js';\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n return value == null ? '' : baseToString(value);\n}\n\nexport default toString;\n","import arrayMap from './_arrayMap.js';\nimport copyArray from './_copyArray.js';\nimport isArray from './isArray.js';\nimport isSymbol from './isSymbol.js';\nimport stringToPath from './_stringToPath.js';\nimport toKey from './_toKey.js';\nimport toString from './toString.js';\n\n/**\n * Converts `value` to a property path array.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {*} value The value to convert.\n * @returns {Array} Returns the new property path array.\n * @example\n *\n * _.toPath('a.b.c');\n * // => ['a', 'b', 'c']\n *\n * _.toPath('a[0].b.c');\n * // => ['a', '0', 'b', 'c']\n */\nfunction toPath(value) {\n if (isArray(value)) {\n return arrayMap(value, toKey);\n }\n return isSymbol(value) ? [value] : copyArray(stringToPath(toString(value)));\n}\n\nexport default toPath;\n","/** @license React v16.13.1\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';var b=\"function\"===typeof Symbol&&Symbol.for,c=b?Symbol.for(\"react.element\"):60103,d=b?Symbol.for(\"react.portal\"):60106,e=b?Symbol.for(\"react.fragment\"):60107,f=b?Symbol.for(\"react.strict_mode\"):60108,g=b?Symbol.for(\"react.profiler\"):60114,h=b?Symbol.for(\"react.provider\"):60109,k=b?Symbol.for(\"react.context\"):60110,l=b?Symbol.for(\"react.async_mode\"):60111,m=b?Symbol.for(\"react.concurrent_mode\"):60111,n=b?Symbol.for(\"react.forward_ref\"):60112,p=b?Symbol.for(\"react.suspense\"):60113,q=b?\nSymbol.for(\"react.suspense_list\"):60120,r=b?Symbol.for(\"react.memo\"):60115,t=b?Symbol.for(\"react.lazy\"):60116,v=b?Symbol.for(\"react.block\"):60121,w=b?Symbol.for(\"react.fundamental\"):60117,x=b?Symbol.for(\"react.responder\"):60118,y=b?Symbol.for(\"react.scope\"):60119;\nfunction z(a){if(\"object\"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function A(a){return z(a)===m}exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d;\nexports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;exports.isAsyncMode=function(a){return A(a)||z(a)===l};exports.isConcurrentMode=A;exports.isContextConsumer=function(a){return z(a)===k};exports.isContextProvider=function(a){return z(a)===h};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return z(a)===n};exports.isFragment=function(a){return z(a)===e};exports.isLazy=function(a){return z(a)===t};\nexports.isMemo=function(a){return z(a)===r};exports.isPortal=function(a){return z(a)===d};exports.isProfiler=function(a){return z(a)===g};exports.isStrictMode=function(a){return z(a)===f};exports.isSuspense=function(a){return z(a)===p};\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||\"object\"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===w||a.$$typeof===x||a.$$typeof===y||a.$$typeof===v)};exports.typeOf=z;\n","/** @license React v16.13.1\n * react-is.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\n\n\nif (process.env.NODE_ENV !== \"production\") {\n (function() {\n'use strict';\n\n// The Symbol used to tag the ReactElement-like types. If there is no native Symbol\n// nor polyfill, then a plain number is used for performance.\nvar hasSymbol = typeof Symbol === 'function' && Symbol.for;\nvar REACT_ELEMENT_TYPE = hasSymbol ? Symbol.for('react.element') : 0xeac7;\nvar REACT_PORTAL_TYPE = hasSymbol ? Symbol.for('react.portal') : 0xeaca;\nvar REACT_FRAGMENT_TYPE = hasSymbol ? Symbol.for('react.fragment') : 0xeacb;\nvar REACT_STRICT_MODE_TYPE = hasSymbol ? Symbol.for('react.strict_mode') : 0xeacc;\nvar REACT_PROFILER_TYPE = hasSymbol ? Symbol.for('react.profiler') : 0xead2;\nvar REACT_PROVIDER_TYPE = hasSymbol ? Symbol.for('react.provider') : 0xeacd;\nvar REACT_CONTEXT_TYPE = hasSymbol ? Symbol.for('react.context') : 0xeace; // TODO: We don't use AsyncMode or ConcurrentMode anymore. They were temporary\n// (unstable) APIs that have been removed. Can we remove the symbols?\n\nvar REACT_ASYNC_MODE_TYPE = hasSymbol ? Symbol.for('react.async_mode') : 0xeacf;\nvar REACT_CONCURRENT_MODE_TYPE = hasSymbol ? Symbol.for('react.concurrent_mode') : 0xeacf;\nvar REACT_FORWARD_REF_TYPE = hasSymbol ? Symbol.for('react.forward_ref') : 0xead0;\nvar REACT_SUSPENSE_TYPE = hasSymbol ? Symbol.for('react.suspense') : 0xead1;\nvar REACT_SUSPENSE_LIST_TYPE = hasSymbol ? Symbol.for('react.suspense_list') : 0xead8;\nvar REACT_MEMO_TYPE = hasSymbol ? Symbol.for('react.memo') : 0xead3;\nvar REACT_LAZY_TYPE = hasSymbol ? Symbol.for('react.lazy') : 0xead4;\nvar REACT_BLOCK_TYPE = hasSymbol ? Symbol.for('react.block') : 0xead9;\nvar REACT_FUNDAMENTAL_TYPE = hasSymbol ? Symbol.for('react.fundamental') : 0xead5;\nvar REACT_RESPONDER_TYPE = hasSymbol ? Symbol.for('react.responder') : 0xead6;\nvar REACT_SCOPE_TYPE = hasSymbol ? Symbol.for('react.scope') : 0xead7;\n\nfunction isValidElementType(type) {\n return typeof type === 'string' || typeof type === 'function' || // Note: its typeof might be other than 'symbol' or 'number' if it's a polyfill.\n type === REACT_FRAGMENT_TYPE || type === REACT_CONCURRENT_MODE_TYPE || type === REACT_PROFILER_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || typeof type === 'object' && type !== null && (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_FUNDAMENTAL_TYPE || type.$$typeof === REACT_RESPONDER_TYPE || type.$$typeof === REACT_SCOPE_TYPE || type.$$typeof === REACT_BLOCK_TYPE);\n}\n\nfunction typeOf(object) {\n if (typeof object === 'object' && object !== null) {\n var $$typeof = object.$$typeof;\n\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE:\n var type = object.type;\n\n switch (type) {\n case REACT_ASYNC_MODE_TYPE:\n case REACT_CONCURRENT_MODE_TYPE:\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n return type;\n\n default:\n var $$typeofType = type && type.$$typeof;\n\n switch ($$typeofType) {\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n case REACT_PROVIDER_TYPE:\n return $$typeofType;\n\n default:\n return $$typeof;\n }\n\n }\n\n case REACT_PORTAL_TYPE:\n return $$typeof;\n }\n }\n\n return undefined;\n} // AsyncMode is deprecated along with isAsyncMode\n\nvar AsyncMode = REACT_ASYNC_MODE_TYPE;\nvar ConcurrentMode = REACT_CONCURRENT_MODE_TYPE;\nvar ContextConsumer = REACT_CONTEXT_TYPE;\nvar ContextProvider = REACT_PROVIDER_TYPE;\nvar Element = REACT_ELEMENT_TYPE;\nvar ForwardRef = REACT_FORWARD_REF_TYPE;\nvar Fragment = REACT_FRAGMENT_TYPE;\nvar Lazy = REACT_LAZY_TYPE;\nvar Memo = REACT_MEMO_TYPE;\nvar Portal = REACT_PORTAL_TYPE;\nvar Profiler = REACT_PROFILER_TYPE;\nvar StrictMode = REACT_STRICT_MODE_TYPE;\nvar Suspense = REACT_SUSPENSE_TYPE;\nvar hasWarnedAboutDeprecatedIsAsyncMode = false; // AsyncMode should be deprecated\n\nfunction isAsyncMode(object) {\n {\n if (!hasWarnedAboutDeprecatedIsAsyncMode) {\n hasWarnedAboutDeprecatedIsAsyncMode = true; // Using console['warn'] to evade Babel and ESLint\n\n console['warn']('The ReactIs.isAsyncMode() alias has been deprecated, ' + 'and will be removed in React 17+. Update your code to use ' + 'ReactIs.isConcurrentMode() instead. It has the exact same API.');\n }\n }\n\n return isConcurrentMode(object) || typeOf(object) === REACT_ASYNC_MODE_TYPE;\n}\nfunction isConcurrentMode(object) {\n return typeOf(object) === REACT_CONCURRENT_MODE_TYPE;\n}\nfunction isContextConsumer(object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n}\nfunction isContextProvider(object) {\n return typeOf(object) === REACT_PROVIDER_TYPE;\n}\nfunction isElement(object) {\n return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE;\n}\nfunction isForwardRef(object) {\n return typeOf(object) === REACT_FORWARD_REF_TYPE;\n}\nfunction isFragment(object) {\n return typeOf(object) === REACT_FRAGMENT_TYPE;\n}\nfunction isLazy(object) {\n return typeOf(object) === REACT_LAZY_TYPE;\n}\nfunction isMemo(object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n}\nfunction isPortal(object) {\n return typeOf(object) === REACT_PORTAL_TYPE;\n}\nfunction isProfiler(object) {\n return typeOf(object) === REACT_PROFILER_TYPE;\n}\nfunction isStrictMode(object) {\n return typeOf(object) === REACT_STRICT_MODE_TYPE;\n}\nfunction isSuspense(object) {\n return typeOf(object) === REACT_SUSPENSE_TYPE;\n}\n\nexports.AsyncMode = AsyncMode;\nexports.ConcurrentMode = ConcurrentMode;\nexports.ContextConsumer = ContextConsumer;\nexports.ContextProvider = ContextProvider;\nexports.Element = Element;\nexports.ForwardRef = ForwardRef;\nexports.Fragment = Fragment;\nexports.Lazy = Lazy;\nexports.Memo = Memo;\nexports.Portal = Portal;\nexports.Profiler = Profiler;\nexports.StrictMode = StrictMode;\nexports.Suspense = Suspense;\nexports.isAsyncMode = isAsyncMode;\nexports.isConcurrentMode = isConcurrentMode;\nexports.isContextConsumer = isContextConsumer;\nexports.isContextProvider = isContextProvider;\nexports.isElement = isElement;\nexports.isForwardRef = isForwardRef;\nexports.isFragment = isFragment;\nexports.isLazy = isLazy;\nexports.isMemo = isMemo;\nexports.isPortal = isPortal;\nexports.isProfiler = isProfiler;\nexports.isStrictMode = isStrictMode;\nexports.isSuspense = isSuspense;\nexports.isValidElementType = isValidElementType;\nexports.typeOf = typeOf;\n })();\n}\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","'use strict';\n\nvar reactIs = require('react-is');\n\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n '$$typeof': true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n '$$typeof': true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {};\nTYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;\nTYPE_STATICS[reactIs.Memo] = MEMO_STATICS;\n\nfunction getStatics(component) {\n // React v16.11 and below\n if (reactIs.isMemo(component)) {\n return MEMO_STATICS;\n } // React v16.12 and above\n\n\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') {\n // don't hoist over string (html) components\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n\n return targetComponent;\n}\n\nmodule.exports = hoistNonReactStatics;\n","import deepmerge from 'deepmerge';\nimport isPlainObject from 'lodash-es/isPlainObject';\nimport cloneDeep from 'lodash-es/cloneDeep';\nimport { createContext, useContext, Children, useRef, useEffect, useState, useCallback, useMemo, useImperativeHandle, createElement, useLayoutEffect, forwardRef, Component } from 'react';\nimport isEqual from 'react-fast-compare';\nimport invariant from 'tiny-warning';\nimport clone from 'lodash-es/clone';\nimport toPath from 'lodash-es/toPath';\nimport hoistNonReactStatics from 'hoist-non-react-statics';\n\nfunction _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}\n\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}\n\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}\n\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\nvar FormikContext = /*#__PURE__*/createContext(undefined);\nFormikContext.displayName = 'FormikContext';\nvar FormikProvider = FormikContext.Provider;\nvar FormikConsumer = FormikContext.Consumer;\nfunction useFormikContext() {\n var formik = useContext(FormikContext);\n !!!formik ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"Formik context is undefined, please verify you are calling useFormikContext() as child of a <Formik> component.\") : invariant(false) : void 0;\n return formik;\n}\n\n/** @private is the value an empty array? */\n\nvar isEmptyArray = function isEmptyArray(value) {\n return Array.isArray(value) && value.length === 0;\n};\n/** @private is the given object a Function? */\n\nvar isFunction = function isFunction(obj) {\n return typeof obj === 'function';\n};\n/** @private is the given object an Object? */\n\nvar isObject = function isObject(obj) {\n return obj !== null && typeof obj === 'object';\n};\n/** @private is the given object an integer? */\n\nvar isInteger = function isInteger(obj) {\n return String(Math.floor(Number(obj))) === obj;\n};\n/** @private is the given object a string? */\n\nvar isString = function isString(obj) {\n return Object.prototype.toString.call(obj) === '[object String]';\n};\n/** @private is the given object a NaN? */\n// eslint-disable-next-line no-self-compare\n\nvar isNaN$1 = function isNaN(obj) {\n return obj !== obj;\n};\n/** @private Does a React component have exactly 0 children? */\n\nvar isEmptyChildren = function isEmptyChildren(children) {\n return Children.count(children) === 0;\n};\n/** @private is the given object/value a promise? */\n\nvar isPromise = function isPromise(value) {\n return isObject(value) && isFunction(value.then);\n};\n/** @private is the given object/value a type of synthetic event? */\n\nvar isInputEvent = function isInputEvent(value) {\n return value && isObject(value) && isObject(value.target);\n};\n/**\r\n * Same as document.activeElement but wraps in a try-catch block. In IE it is\r\n * not safe to call document.activeElement if there is nothing focused.\r\n *\r\n * The activeElement will be null only if the document or document body is not\r\n * yet defined.\r\n *\r\n * @param {?Document} doc Defaults to current document.\r\n * @return {Element | null}\r\n * @see https://github.com/facebook/fbjs/blob/master/packages/fbjs/src/core/dom/getActiveElement.js\r\n */\n\nfunction getActiveElement(doc) {\n doc = doc || (typeof document !== 'undefined' ? document : undefined);\n\n if (typeof doc === 'undefined') {\n return null;\n }\n\n try {\n return doc.activeElement || doc.body;\n } catch (e) {\n return doc.body;\n }\n}\n/**\r\n * Deeply get a value from an object via its path.\r\n */\n\nfunction getIn(obj, key, def, p) {\n if (p === void 0) {\n p = 0;\n }\n\n var path = toPath(key);\n\n while (obj && p < path.length) {\n obj = obj[path[p++]];\n } // check if path is not in the end\n\n\n if (p !== path.length && !obj) {\n return def;\n }\n\n return obj === undefined ? def : obj;\n}\n/**\r\n * Deeply set a value from in object via it's path. If the value at `path`\r\n * has changed, return a shallow copy of obj with `value` set at `path`.\r\n * If `value` has not changed, return the original `obj`.\r\n *\r\n * Existing objects / arrays along `path` are also shallow copied. Sibling\r\n * objects along path retain the same internal js reference. Since new\r\n * objects / arrays are only created along `path`, we can test if anything\r\n * changed in a nested structure by comparing the object's reference in\r\n * the old and new object, similar to how russian doll cache invalidation\r\n * works.\r\n *\r\n * In earlier versions of this function, which used cloneDeep, there were\r\n * issues whereby settings a nested value would mutate the parent\r\n * instead of creating a new object. `clone` avoids that bug making a\r\n * shallow copy of the objects along the update path\r\n * so no object is mutated in place.\r\n *\r\n * Before changing this function, please read through the following\r\n * discussions.\r\n *\r\n * @see https://github.com/developit/linkstate\r\n * @see https://github.com/jaredpalmer/formik/pull/123\r\n */\n\nfunction setIn(obj, path, value) {\n var res = clone(obj); // this keeps inheritance when obj is a class\n\n var resVal = res;\n var i = 0;\n var pathArray = toPath(path);\n\n for (; i < pathArray.length - 1; i++) {\n var currentPath = pathArray[i];\n var currentObj = getIn(obj, pathArray.slice(0, i + 1));\n\n if (currentObj && (isObject(currentObj) || Array.isArray(currentObj))) {\n resVal = resVal[currentPath] = clone(currentObj);\n } else {\n var nextPath = pathArray[i + 1];\n resVal = resVal[currentPath] = isInteger(nextPath) && Number(nextPath) >= 0 ? [] : {};\n }\n } // Return original object if new value is the same as current\n\n\n if ((i === 0 ? obj : resVal)[pathArray[i]] === value) {\n return obj;\n }\n\n if (value === undefined) {\n delete resVal[pathArray[i]];\n } else {\n resVal[pathArray[i]] = value;\n } // If the path array has a single element, the loop did not run.\n // Deleting on `resVal` had no effect in this scenario, so we delete on the result instead.\n\n\n if (i === 0 && value === undefined) {\n delete res[pathArray[i]];\n }\n\n return res;\n}\n/**\r\n * Recursively a set the same value for all keys and arrays nested object, cloning\r\n * @param object\r\n * @param value\r\n * @param visited\r\n * @param response\r\n */\n\nfunction setNestedObjectValues(object, value, visited, response) {\n if (visited === void 0) {\n visited = new WeakMap();\n }\n\n if (response === void 0) {\n response = {};\n }\n\n for (var _i = 0, _Object$keys = Object.keys(object); _i < _Object$keys.length; _i++) {\n var k = _Object$keys[_i];\n var val = object[k];\n\n if (isObject(val)) {\n if (!visited.get(val)) {\n visited.set(val, true); // In order to keep array values consistent for both dot path and\n // bracket syntax, we need to check if this is an array so that\n // this will output { friends: [true] } and not { friends: { \"0\": true } }\n\n response[k] = Array.isArray(val) ? [] : {};\n setNestedObjectValues(val, value, visited, response[k]);\n }\n } else {\n response[k] = value;\n }\n }\n\n return response;\n}\n\nfunction formikReducer(state, msg) {\n switch (msg.type) {\n case 'SET_VALUES':\n return _extends({}, state, {\n values: msg.payload\n });\n\n case 'SET_TOUCHED':\n return _extends({}, state, {\n touched: msg.payload\n });\n\n case 'SET_ERRORS':\n if (isEqual(state.errors, msg.payload)) {\n return state;\n }\n\n return _extends({}, state, {\n errors: msg.payload\n });\n\n case 'SET_STATUS':\n return _extends({}, state, {\n status: msg.payload\n });\n\n case 'SET_ISSUBMITTING':\n return _extends({}, state, {\n isSubmitting: msg.payload\n });\n\n case 'SET_ISVALIDATING':\n return _extends({}, state, {\n isValidating: msg.payload\n });\n\n case 'SET_FIELD_VALUE':\n return _extends({}, state, {\n values: setIn(state.values, msg.payload.field, msg.payload.value)\n });\n\n case 'SET_FIELD_TOUCHED':\n return _extends({}, state, {\n touched: setIn(state.touched, msg.payload.field, msg.payload.value)\n });\n\n case 'SET_FIELD_ERROR':\n return _extends({}, state, {\n errors: setIn(state.errors, msg.payload.field, msg.payload.value)\n });\n\n case 'RESET_FORM':\n return _extends({}, state, msg.payload);\n\n case 'SET_FORMIK_STATE':\n return msg.payload(state);\n\n case 'SUBMIT_ATTEMPT':\n return _extends({}, state, {\n touched: setNestedObjectValues(state.values, true),\n isSubmitting: true,\n submitCount: state.submitCount + 1\n });\n\n case 'SUBMIT_FAILURE':\n return _extends({}, state, {\n isSubmitting: false\n });\n\n case 'SUBMIT_SUCCESS':\n return _extends({}, state, {\n isSubmitting: false\n });\n\n default:\n return state;\n }\n} // Initial empty states // objects\n\n\nvar emptyErrors = {};\nvar emptyTouched = {};\nfunction useFormik(_ref) {\n var _ref$validateOnChange = _ref.validateOnChange,\n validateOnChange = _ref$validateOnChange === void 0 ? true : _ref$validateOnChange,\n _ref$validateOnBlur = _ref.validateOnBlur,\n validateOnBlur = _ref$validateOnBlur === void 0 ? true : _ref$validateOnBlur,\n _ref$validateOnMount = _ref.validateOnMount,\n validateOnMount = _ref$validateOnMount === void 0 ? false : _ref$validateOnMount,\n isInitialValid = _ref.isInitialValid,\n _ref$enableReinitiali = _ref.enableReinitialize,\n enableReinitialize = _ref$enableReinitiali === void 0 ? false : _ref$enableReinitiali,\n onSubmit = _ref.onSubmit,\n rest = _objectWithoutPropertiesLoose(_ref, [\"validateOnChange\", \"validateOnBlur\", \"validateOnMount\", \"isInitialValid\", \"enableReinitialize\", \"onSubmit\"]);\n\n var props = _extends({\n validateOnChange: validateOnChange,\n validateOnBlur: validateOnBlur,\n validateOnMount: validateOnMount,\n onSubmit: onSubmit\n }, rest);\n\n var initialValues = useRef(props.initialValues);\n var initialErrors = useRef(props.initialErrors || emptyErrors);\n var initialTouched = useRef(props.initialTouched || emptyTouched);\n var initialStatus = useRef(props.initialStatus);\n var isMounted = useRef(false);\n var fieldRegistry = useRef({});\n\n if (process.env.NODE_ENV !== \"production\") {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useEffect(function () {\n !(typeof isInitialValid === 'undefined') ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'isInitialValid has been deprecated and will be removed in future versions of Formik. Please use initialErrors or validateOnMount instead.') : invariant(false) : void 0; // eslint-disable-next-line\n }, []);\n }\n\n useEffect(function () {\n isMounted.current = true;\n return function () {\n isMounted.current = false;\n };\n }, []);\n\n var _React$useState = useState(0),\n setIteration = _React$useState[1];\n\n var stateRef = useRef({\n values: cloneDeep(props.initialValues),\n errors: cloneDeep(props.initialErrors) || emptyErrors,\n touched: cloneDeep(props.initialTouched) || emptyTouched,\n status: cloneDeep(props.initialStatus),\n isSubmitting: false,\n isValidating: false,\n submitCount: 0\n });\n var state = stateRef.current;\n var dispatch = useCallback(function (action) {\n var prev = stateRef.current;\n stateRef.current = formikReducer(prev, action); // force rerender\n\n if (prev !== stateRef.current) setIteration(function (x) {\n return x + 1;\n });\n }, []);\n var runValidateHandler = useCallback(function (values, field) {\n return new Promise(function (resolve, reject) {\n var maybePromisedErrors = props.validate(values, field);\n\n if (maybePromisedErrors == null) {\n // use loose null check here on purpose\n resolve(emptyErrors);\n } else if (isPromise(maybePromisedErrors)) {\n maybePromisedErrors.then(function (errors) {\n resolve(errors || emptyErrors);\n }, function (actualException) {\n if (process.env.NODE_ENV !== 'production') {\n console.warn(\"Warning: An unhandled error was caught during validation in <Formik validate />\", actualException);\n }\n\n reject(actualException);\n });\n } else {\n resolve(maybePromisedErrors);\n }\n });\n }, [props.validate]);\n /**\r\n * Run validation against a Yup schema and optionally run a function if successful\r\n */\n\n var runValidationSchema = useCallback(function (values, field) {\n var validationSchema = props.validationSchema;\n var schema = isFunction(validationSchema) ? validationSchema(field) : validationSchema;\n var promise = field && schema.validateAt ? schema.validateAt(field, values) : validateYupSchema(values, schema);\n return new Promise(function (resolve, reject) {\n promise.then(function () {\n resolve(emptyErrors);\n }, function (err) {\n // Yup will throw a validation error if validation fails. We catch those and\n // resolve them into Formik errors. We can sniff if something is a Yup error\n // by checking error.name.\n // @see https://github.com/jquense/yup#validationerrorerrors-string--arraystring-value-any-path-string\n if (err.name === 'ValidationError') {\n resolve(yupToFormErrors(err));\n } else {\n // We throw any other errors\n if (process.env.NODE_ENV !== 'production') {\n console.warn(\"Warning: An unhandled error was caught during validation in <Formik validationSchema />\", err);\n }\n\n reject(err);\n }\n });\n });\n }, [props.validationSchema]);\n var runSingleFieldLevelValidation = useCallback(function (field, value) {\n return new Promise(function (resolve) {\n return resolve(fieldRegistry.current[field].validate(value));\n });\n }, []);\n var runFieldLevelValidations = useCallback(function (values) {\n var fieldKeysWithValidation = Object.keys(fieldRegistry.current).filter(function (f) {\n return isFunction(fieldRegistry.current[f].validate);\n }); // Construct an array with all of the field validation functions\n\n var fieldValidations = fieldKeysWithValidation.length > 0 ? fieldKeysWithValidation.map(function (f) {\n return runSingleFieldLevelValidation(f, getIn(values, f));\n }) : [Promise.resolve('DO_NOT_DELETE_YOU_WILL_BE_FIRED')]; // use special case ;)\n\n return Promise.all(fieldValidations).then(function (fieldErrorsList) {\n return fieldErrorsList.reduce(function (prev, curr, index) {\n if (curr === 'DO_NOT_DELETE_YOU_WILL_BE_FIRED') {\n return prev;\n }\n\n if (curr) {\n prev = setIn(prev, fieldKeysWithValidation[index], curr);\n }\n\n return prev;\n }, {});\n });\n }, [runSingleFieldLevelValidation]); // Run all validations and return the result\n\n var runAllValidations = useCallback(function (values) {\n return Promise.all([runFieldLevelValidations(values), props.validationSchema ? runValidationSchema(values) : {}, props.validate ? runValidateHandler(values) : {}]).then(function (_ref2) {\n var fieldErrors = _ref2[0],\n schemaErrors = _ref2[1],\n validateErrors = _ref2[2];\n var combinedErrors = deepmerge.all([fieldErrors, schemaErrors, validateErrors], {\n arrayMerge: arrayMerge\n });\n return combinedErrors;\n });\n }, [props.validate, props.validationSchema, runFieldLevelValidations, runValidateHandler, runValidationSchema]); // Run all validations methods and update state accordingly\n\n var validateFormWithHighPriority = useEventCallback(function (values) {\n if (values === void 0) {\n values = state.values;\n }\n\n dispatch({\n type: 'SET_ISVALIDATING',\n payload: true\n });\n return runAllValidations(values).then(function (combinedErrors) {\n if (!!isMounted.current) {\n dispatch({\n type: 'SET_ISVALIDATING',\n payload: false\n });\n dispatch({\n type: 'SET_ERRORS',\n payload: combinedErrors\n });\n }\n\n return combinedErrors;\n });\n });\n useEffect(function () {\n if (validateOnMount && isMounted.current === true && isEqual(initialValues.current, props.initialValues)) {\n validateFormWithHighPriority(initialValues.current);\n }\n }, [validateOnMount, validateFormWithHighPriority]);\n var resetForm = useCallback(function (nextState) {\n var values = nextState && nextState.values ? nextState.values : initialValues.current;\n var errors = nextState && nextState.errors ? nextState.errors : initialErrors.current ? initialErrors.current : props.initialErrors || {};\n var touched = nextState && nextState.touched ? nextState.touched : initialTouched.current ? initialTouched.current : props.initialTouched || {};\n var status = nextState && nextState.status ? nextState.status : initialStatus.current ? initialStatus.current : props.initialStatus;\n initialValues.current = values;\n initialErrors.current = errors;\n initialTouched.current = touched;\n initialStatus.current = status;\n\n var dispatchFn = function dispatchFn() {\n dispatch({\n type: 'RESET_FORM',\n payload: {\n isSubmitting: !!nextState && !!nextState.isSubmitting,\n errors: errors,\n touched: touched,\n status: status,\n values: values,\n isValidating: !!nextState && !!nextState.isValidating,\n submitCount: !!nextState && !!nextState.submitCount && typeof nextState.submitCount === 'number' ? nextState.submitCount : 0\n }\n });\n };\n\n if (props.onReset) {\n var maybePromisedOnReset = props.onReset(state.values, imperativeMethods);\n\n if (isPromise(maybePromisedOnReset)) {\n maybePromisedOnReset.then(dispatchFn);\n } else {\n dispatchFn();\n }\n } else {\n dispatchFn();\n }\n }, [props.initialErrors, props.initialStatus, props.initialTouched, props.onReset]);\n useEffect(function () {\n if (isMounted.current === true && !isEqual(initialValues.current, props.initialValues)) {\n if (enableReinitialize) {\n initialValues.current = props.initialValues;\n resetForm();\n\n if (validateOnMount) {\n validateFormWithHighPriority(initialValues.current);\n }\n }\n }\n }, [enableReinitialize, props.initialValues, resetForm, validateOnMount, validateFormWithHighPriority]);\n useEffect(function () {\n if (enableReinitialize && isMounted.current === true && !isEqual(initialErrors.current, props.initialErrors)) {\n initialErrors.current = props.initialErrors || emptyErrors;\n dispatch({\n type: 'SET_ERRORS',\n payload: props.initialErrors || emptyErrors\n });\n }\n }, [enableReinitialize, props.initialErrors]);\n useEffect(function () {\n if (enableReinitialize && isMounted.current === true && !isEqual(initialTouched.current, props.initialTouched)) {\n initialTouched.current = props.initialTouched || emptyTouched;\n dispatch({\n type: 'SET_TOUCHED',\n payload: props.initialTouched || emptyTouched\n });\n }\n }, [enableReinitialize, props.initialTouched]);\n useEffect(function () {\n if (enableReinitialize && isMounted.current === true && !isEqual(initialStatus.current, props.initialStatus)) {\n initialStatus.current = props.initialStatus;\n dispatch({\n type: 'SET_STATUS',\n payload: props.initialStatus\n });\n }\n }, [enableReinitialize, props.initialStatus, props.initialTouched]);\n var validateField = useEventCallback(function (name) {\n // This will efficiently validate a single field by avoiding state\n // changes if the validation function is synchronous. It's different from\n // what is called when using validateForm.\n if (fieldRegistry.current[name] && isFunction(fieldRegistry.current[name].validate)) {\n var value = getIn(state.values, name);\n var maybePromise = fieldRegistry.current[name].validate(value);\n\n if (isPromise(maybePromise)) {\n // Only flip isValidating if the function is async.\n dispatch({\n type: 'SET_ISVALIDATING',\n payload: true\n });\n return maybePromise.then(function (x) {\n return x;\n }).then(function (error) {\n dispatch({\n type: 'SET_FIELD_ERROR',\n payload: {\n field: name,\n value: error\n }\n });\n dispatch({\n type: 'SET_ISVALIDATING',\n payload: false\n });\n });\n } else {\n dispatch({\n type: 'SET_FIELD_ERROR',\n payload: {\n field: name,\n value: maybePromise\n }\n });\n return Promise.resolve(maybePromise);\n }\n } else if (props.validationSchema) {\n dispatch({\n type: 'SET_ISVALIDATING',\n payload: true\n });\n return runValidationSchema(state.values, name).then(function (x) {\n return x;\n }).then(function (error) {\n dispatch({\n type: 'SET_FIELD_ERROR',\n payload: {\n field: name,\n value: getIn(error, name)\n }\n });\n dispatch({\n type: 'SET_ISVALIDATING',\n payload: false\n });\n });\n }\n\n return Promise.resolve();\n });\n var registerField = useCallback(function (name, _ref3) {\n var validate = _ref3.validate;\n fieldRegistry.current[name] = {\n validate: validate\n };\n }, []);\n var unregisterField = useCallback(function (name) {\n delete fieldRegistry.current[name];\n }, []);\n var setTouched = useEventCallback(function (touched, shouldValidate) {\n dispatch({\n type: 'SET_TOUCHED',\n payload: touched\n });\n var willValidate = shouldValidate === undefined ? validateOnBlur : shouldValidate;\n return willValidate ? validateFormWithHighPriority(state.values) : Promise.resolve();\n });\n var setErrors = useCallback(function (errors) {\n dispatch({\n type: 'SET_ERRORS',\n payload: errors\n });\n }, []);\n var setValues = useEventCallback(function (values, shouldValidate) {\n var resolvedValues = isFunction(values) ? values(state.values) : values;\n dispatch({\n type: 'SET_VALUES',\n payload: resolvedValues\n });\n var willValidate = shouldValidate === undefined ? validateOnChange : shouldValidate;\n return willValidate ? validateFormWithHighPriority(resolvedValues) : Promise.resolve();\n });\n var setFieldError = useCallback(function (field, value) {\n dispatch({\n type: 'SET_FIELD_ERROR',\n payload: {\n field: field,\n value: value\n }\n });\n }, []);\n var setFieldValue = useEventCallback(function (field, value, shouldValidate) {\n var resolvedValue = isFunction(value) ? value(getIn(state.values, field)) : value;\n dispatch({\n type: 'SET_FIELD_VALUE',\n payload: {\n field: field,\n value: resolvedValue\n }\n });\n var willValidate = shouldValidate === undefined ? validateOnChange : shouldValidate;\n return willValidate ? validateFormWithHighPriority(setIn(state.values, field, resolvedValue)) : Promise.resolve();\n });\n var executeChange = useCallback(function (eventOrTextValue, maybePath) {\n // By default, assume that the first argument is a string. This allows us to use\n // handleChange with React Native and React Native Web's onChangeText prop which\n // provides just the value of the input.\n var field = maybePath;\n var val = eventOrTextValue;\n var parsed; // If the first argument is not a string though, it has to be a synthetic React Event (or a fake one),\n // so we handle like we would a normal HTML change event.\n\n if (!isString(eventOrTextValue)) {\n // If we can, persist the event\n // @see https://reactjs.org/docs/events.html#event-pooling\n if (eventOrTextValue.persist) {\n eventOrTextValue.persist();\n }\n\n var target = eventOrTextValue.target ? eventOrTextValue.target : eventOrTextValue.currentTarget;\n var type = target.type,\n name = target.name,\n id = target.id,\n value = target.value,\n checked = target.checked,\n outerHTML = target.outerHTML,\n options = target.options,\n multiple = target.multiple;\n field = maybePath ? maybePath : name ? name : id;\n\n if (!field && process.env.NODE_ENV !== \"production\") {\n warnAboutMissingIdentifier({\n htmlContent: outerHTML,\n documentationAnchorLink: 'handlechange-e-reactchangeeventany--void',\n handlerName: 'handleChange'\n });\n }\n\n val = /number|range/.test(type) ? (parsed = parseFloat(value), isNaN(parsed) ? '' : parsed) : /checkbox/.test(type) // checkboxes\n ? getValueForCheckbox(getIn(state.values, field), checked, value) : options && multiple // <select multiple>\n ? getSelectedValues(options) : value;\n }\n\n if (field) {\n // Set form fields by name\n setFieldValue(field, val);\n }\n }, [setFieldValue, state.values]);\n var handleChange = useEventCallback(function (eventOrPath) {\n if (isString(eventOrPath)) {\n return function (event) {\n return executeChange(event, eventOrPath);\n };\n } else {\n executeChange(eventOrPath);\n }\n });\n var setFieldTouched = useEventCallback(function (field, touched, shouldValidate) {\n if (touched === void 0) {\n touched = true;\n }\n\n dispatch({\n type: 'SET_FIELD_TOUCHED',\n payload: {\n field: field,\n value: touched\n }\n });\n var willValidate = shouldValidate === undefined ? validateOnBlur : shouldValidate;\n return willValidate ? validateFormWithHighPriority(state.values) : Promise.resolve();\n });\n var executeBlur = useCallback(function (e, path) {\n if (e.persist) {\n e.persist();\n }\n\n var _e$target = e.target,\n name = _e$target.name,\n id = _e$target.id,\n outerHTML = _e$target.outerHTML;\n var field = path ? path : name ? name : id;\n\n if (!field && process.env.NODE_ENV !== \"production\") {\n warnAboutMissingIdentifier({\n htmlContent: outerHTML,\n documentationAnchorLink: 'handleblur-e-any--void',\n handlerName: 'handleBlur'\n });\n }\n\n setFieldTouched(field, true);\n }, [setFieldTouched]);\n var handleBlur = useEventCallback(function (eventOrString) {\n if (isString(eventOrString)) {\n return function (event) {\n return executeBlur(event, eventOrString);\n };\n } else {\n executeBlur(eventOrString);\n }\n });\n var setFormikState = useCallback(function (stateOrCb) {\n if (isFunction(stateOrCb)) {\n dispatch({\n type: 'SET_FORMIK_STATE',\n payload: stateOrCb\n });\n } else {\n dispatch({\n type: 'SET_FORMIK_STATE',\n payload: function payload() {\n return stateOrCb;\n }\n });\n }\n }, []);\n var setStatus = useCallback(function (status) {\n dispatch({\n type: 'SET_STATUS',\n payload: status\n });\n }, []);\n var setSubmitting = useCallback(function (isSubmitting) {\n dispatch({\n type: 'SET_ISSUBMITTING',\n payload: isSubmitting\n });\n }, []);\n var submitForm = useEventCallback(function () {\n dispatch({\n type: 'SUBMIT_ATTEMPT'\n });\n return validateFormWithHighPriority().then(function (combinedErrors) {\n // In case an error was thrown and passed to the resolved Promise,\n // `combinedErrors` can be an instance of an Error. We need to check\n // that and abort the submit.\n // If we don't do that, calling `Object.keys(new Error())` yields an\n // empty array, which causes the validation to pass and the form\n // to be submitted.\n var isInstanceOfError = combinedErrors instanceof Error;\n var isActuallyValid = !isInstanceOfError && Object.keys(combinedErrors).length === 0;\n\n if (isActuallyValid) {\n // Proceed with submit...\n //\n // To respect sync submit fns, we can't simply wrap executeSubmit in a promise and\n // _always_ dispatch SUBMIT_SUCCESS because isSubmitting would then always be false.\n // This would be fine in simple cases, but make it impossible to disable submit\n // buttons where people use callbacks or promises as side effects (which is basically\n // all of v1 Formik code). Instead, recall that we are inside of a promise chain already,\n // so we can try/catch executeSubmit(), if it returns undefined, then just bail.\n // If there are errors, throw em. Otherwise, wrap executeSubmit in a promise and handle\n // cleanup of isSubmitting on behalf of the consumer.\n var promiseOrUndefined;\n\n try {\n promiseOrUndefined = executeSubmit(); // Bail if it's sync, consumer is responsible for cleaning up\n // via setSubmitting(false)\n\n if (promiseOrUndefined === undefined) {\n return;\n }\n } catch (error) {\n throw error;\n }\n\n return Promise.resolve(promiseOrUndefined).then(function (result) {\n if (!!isMounted.current) {\n dispatch({\n type: 'SUBMIT_SUCCESS'\n });\n }\n\n return result;\n })[\"catch\"](function (_errors) {\n if (!!isMounted.current) {\n dispatch({\n type: 'SUBMIT_FAILURE'\n }); // This is a legit error rejected by the onSubmit fn\n // so we don't want to break the promise chain\n\n throw _errors;\n }\n });\n } else if (!!isMounted.current) {\n // ^^^ Make sure Formik is still mounted before updating state\n dispatch({\n type: 'SUBMIT_FAILURE'\n }); // throw combinedErrors;\n\n if (isInstanceOfError) {\n throw combinedErrors;\n }\n }\n\n return;\n });\n });\n var handleSubmit = useEventCallback(function (e) {\n if (e && e.preventDefault && isFunction(e.preventDefault)) {\n e.preventDefault();\n }\n\n if (e && e.stopPropagation && isFunction(e.stopPropagation)) {\n e.stopPropagation();\n } // Warn if form submission is triggered by a <button> without a\n // specified `type` attribute during development. This mitigates\n // a common gotcha in forms with both reset and submit buttons,\n // where the dev forgets to add type=\"button\" to the reset button.\n\n\n if (process.env.NODE_ENV !== \"production\" && typeof document !== 'undefined') {\n // Safely get the active element (works with IE)\n var activeElement = getActiveElement();\n\n if (activeElement !== null && activeElement instanceof HTMLButtonElement) {\n !(activeElement.attributes && activeElement.attributes.getNamedItem('type')) ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'You submitted a Formik form using a button with an unspecified `type` attribute. Most browsers default button elements to `type=\"submit\"`. If this is not a submit button, please add `type=\"button\"`.') : invariant(false) : void 0;\n }\n }\n\n submitForm()[\"catch\"](function (reason) {\n console.warn(\"Warning: An unhandled error was caught from submitForm()\", reason);\n });\n });\n var imperativeMethods = {\n resetForm: resetForm,\n validateForm: validateFormWithHighPriority,\n validateField: validateField,\n setErrors: setErrors,\n setFieldError: setFieldError,\n setFieldTouched: setFieldTouched,\n setFieldValue: setFieldValue,\n setStatus: setStatus,\n setSubmitting: setSubmitting,\n setTouched: setTouched,\n setValues: setValues,\n setFormikState: setFormikState,\n submitForm: submitForm\n };\n var executeSubmit = useEventCallback(function () {\n return onSubmit(state.values, imperativeMethods);\n });\n var handleReset = useEventCallback(function (e) {\n if (e && e.preventDefault && isFunction(e.preventDefault)) {\n e.preventDefault();\n }\n\n if (e && e.stopPropagation && isFunction(e.stopPropagation)) {\n e.stopPropagation();\n }\n\n resetForm();\n });\n var getFieldMeta = useCallback(function (name) {\n return {\n value: getIn(state.values, name),\n error: getIn(state.errors, name),\n touched: !!getIn(state.touched, name),\n initialValue: getIn(initialValues.current, name),\n initialTouched: !!getIn(initialTouched.current, name),\n initialError: getIn(initialErrors.current, name)\n };\n }, [state.errors, state.touched, state.values]);\n var getFieldHelpers = useCallback(function (name) {\n return {\n setValue: function setValue(value, shouldValidate) {\n return setFieldValue(name, value, shouldValidate);\n },\n setTouched: function setTouched(value, shouldValidate) {\n return setFieldTouched(name, value, shouldValidate);\n },\n setError: function setError(value) {\n return setFieldError(name, value);\n }\n };\n }, [setFieldValue, setFieldTouched, setFieldError]);\n var getFieldProps = useCallback(function (nameOrOptions) {\n var isAnObject = isObject(nameOrOptions);\n var name = isAnObject ? nameOrOptions.name : nameOrOptions;\n var valueState = getIn(state.values, name);\n var field = {\n name: name,\n value: valueState,\n onChange: handleChange,\n onBlur: handleBlur\n };\n\n if (isAnObject) {\n var type = nameOrOptions.type,\n valueProp = nameOrOptions.value,\n is = nameOrOptions.as,\n multiple = nameOrOptions.multiple;\n\n if (type === 'checkbox') {\n if (valueProp === undefined) {\n field.checked = !!valueState;\n } else {\n field.checked = !!(Array.isArray(valueState) && ~valueState.indexOf(valueProp));\n field.value = valueProp;\n }\n } else if (type === 'radio') {\n field.checked = valueState === valueProp;\n field.value = valueProp;\n } else if (is === 'select' && multiple) {\n field.value = field.value || [];\n field.multiple = true;\n }\n }\n\n return field;\n }, [handleBlur, handleChange, state.values]);\n var dirty = useMemo(function () {\n return !isEqual(initialValues.current, state.values);\n }, [initialValues.current, state.values]);\n var isValid = useMemo(function () {\n return typeof isInitialValid !== 'undefined' ? dirty ? state.errors && Object.keys(state.errors).length === 0 : isInitialValid !== false && isFunction(isInitialValid) ? isInitialValid(props) : isInitialValid : state.errors && Object.keys(state.errors).length === 0;\n }, [isInitialValid, dirty, state.errors, props]);\n\n var ctx = _extends({}, state, {\n initialValues: initialValues.current,\n initialErrors: initialErrors.current,\n initialTouched: initialTouched.current,\n initialStatus: initialStatus.current,\n handleBlur: handleBlur,\n handleChange: handleChange,\n handleReset: handleReset,\n handleSubmit: handleSubmit,\n resetForm: resetForm,\n setErrors: setErrors,\n setFormikState: setFormikState,\n setFieldTouched: setFieldTouched,\n setFieldValue: setFieldValue,\n setFieldError: setFieldError,\n setStatus: setStatus,\n setSubmitting: setSubmitting,\n setTouched: setTouched,\n setValues: setValues,\n submitForm: submitForm,\n validateForm: validateFormWithHighPriority,\n validateField: validateField,\n isValid: isValid,\n dirty: dirty,\n unregisterField: unregisterField,\n registerField: registerField,\n getFieldProps: getFieldProps,\n getFieldMeta: getFieldMeta,\n getFieldHelpers: getFieldHelpers,\n validateOnBlur: validateOnBlur,\n validateOnChange: validateOnChange,\n validateOnMount: validateOnMount\n });\n\n return ctx;\n}\nfunction Formik(props) {\n var formikbag = useFormik(props);\n var component = props.component,\n children = props.children,\n render = props.render,\n innerRef = props.innerRef; // This allows folks to pass a ref to <Formik />\n\n useImperativeHandle(innerRef, function () {\n return formikbag;\n });\n\n if (process.env.NODE_ENV !== \"production\") {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useEffect(function () {\n !!props.render ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"<Formik render> has been deprecated and will be removed in future versions of Formik. Please use a child callback function instead. To get rid of this warning, replace <Formik render={(props) => ...} /> with <Formik>{(props) => ...}</Formik>\") : invariant(false) : void 0; // eslint-disable-next-line\n }, []);\n }\n\n return createElement(FormikProvider, {\n value: formikbag\n }, component ? createElement(component, formikbag) : render ? render(formikbag) : children // children come last, always called\n ? isFunction(children) ? children(formikbag) : !isEmptyChildren(children) ? Children.only(children) : null : null);\n}\n\nfunction warnAboutMissingIdentifier(_ref4) {\n var htmlContent = _ref4.htmlContent,\n documentationAnchorLink = _ref4.documentationAnchorLink,\n handlerName = _ref4.handlerName;\n console.warn(\"Warning: Formik called `\" + handlerName + \"`, but you forgot to pass an `id` or `name` attribute to your input:\\n \" + htmlContent + \"\\n Formik cannot determine which value to update. For more info see https://formik.org/docs/api/formik#\" + documentationAnchorLink + \"\\n \");\n}\n/**\r\n * Transform Yup ValidationError to a more usable object\r\n */\n\n\nfunction yupToFormErrors(yupError) {\n var errors = {};\n\n if (yupError.inner) {\n if (yupError.inner.length === 0) {\n return setIn(errors, yupError.path, yupError.message);\n }\n\n for (var _iterator = yupError.inner, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref5;\n\n if (_isArray) {\n if (_i >= _iterator.length) break;\n _ref5 = _iterator[_i++];\n } else {\n _i = _iterator.next();\n if (_i.done) break;\n _ref5 = _i.value;\n }\n\n var err = _ref5;\n\n if (!getIn(errors, err.path)) {\n errors = setIn(errors, err.path, err.message);\n }\n }\n }\n\n return errors;\n}\n/**\r\n * Validate a yup schema.\r\n */\n\nfunction validateYupSchema(values, schema, sync, context) {\n if (sync === void 0) {\n sync = false;\n }\n\n var normalizedValues = prepareDataForValidation(values);\n return schema[sync ? 'validateSync' : 'validate'](normalizedValues, {\n abortEarly: false,\n context: context || normalizedValues\n });\n}\n/**\r\n * Recursively prepare values.\r\n */\n\nfunction prepareDataForValidation(values) {\n var data = Array.isArray(values) ? [] : {};\n\n for (var k in values) {\n if (Object.prototype.hasOwnProperty.call(values, k)) {\n var key = String(k);\n\n if (Array.isArray(values[key]) === true) {\n data[key] = values[key].map(function (value) {\n if (Array.isArray(value) === true || isPlainObject(value)) {\n return prepareDataForValidation(value);\n } else {\n return value !== '' ? value : undefined;\n }\n });\n } else if (isPlainObject(values[key])) {\n data[key] = prepareDataForValidation(values[key]);\n } else {\n data[key] = values[key] !== '' ? values[key] : undefined;\n }\n }\n }\n\n return data;\n}\n/**\r\n * deepmerge array merging algorithm\r\n * https://github.com/KyleAMathews/deepmerge#combine-array\r\n */\n\nfunction arrayMerge(target, source, options) {\n var destination = target.slice();\n source.forEach(function merge(e, i) {\n if (typeof destination[i] === 'undefined') {\n var cloneRequested = options.clone !== false;\n var shouldClone = cloneRequested && options.isMergeableObject(e);\n destination[i] = shouldClone ? deepmerge(Array.isArray(e) ? [] : {}, e, options) : e;\n } else if (options.isMergeableObject(e)) {\n destination[i] = deepmerge(target[i], e, options);\n } else if (target.indexOf(e) === -1) {\n destination.push(e);\n }\n });\n return destination;\n}\n/** Return multi select values based on an array of options */\n\n\nfunction getSelectedValues(options) {\n return Array.from(options).filter(function (el) {\n return el.selected;\n }).map(function (el) {\n return el.value;\n });\n}\n/** Return the next value for a checkbox */\n\n\nfunction getValueForCheckbox(currentValue, checked, valueProp) {\n // If the current value was a boolean, return a boolean\n if (typeof currentValue === 'boolean') {\n return Boolean(checked);\n } // If the currentValue was not a boolean we want to return an array\n\n\n var currentArrayOfValues = [];\n var isValueInArray = false;\n var index = -1;\n\n if (!Array.isArray(currentValue)) {\n // eslint-disable-next-line eqeqeq\n if (!valueProp || valueProp == 'true' || valueProp == 'false') {\n return Boolean(checked);\n }\n } else {\n // If the current value is already an array, use it\n currentArrayOfValues = currentValue;\n index = currentValue.indexOf(valueProp);\n isValueInArray = index >= 0;\n } // If the checkbox was checked and the value is not already present in the aray we want to add the new value to the array of values\n\n\n if (checked && valueProp && !isValueInArray) {\n return currentArrayOfValues.concat(valueProp);\n } // If the checkbox was unchecked and the value is not in the array, simply return the already existing array of values\n\n\n if (!isValueInArray) {\n return currentArrayOfValues;\n } // If the checkbox was unchecked and the value is in the array, remove the value and return the array\n\n\n return currentArrayOfValues.slice(0, index).concat(currentArrayOfValues.slice(index + 1));\n} // React currently throws a warning when using useLayoutEffect on the server.\n// To get around it, we can conditionally useEffect on the server (no-op) and\n// useLayoutEffect in the browser.\n// @see https://gist.github.com/gaearon/e7d97cdf38a2907924ea12e4ebdf3c85\n\n\nvar useIsomorphicLayoutEffect = typeof window !== 'undefined' && typeof window.document !== 'undefined' && typeof window.document.createElement !== 'undefined' ? useLayoutEffect : useEffect;\n\nfunction useEventCallback(fn) {\n var ref = useRef(fn); // we copy a ref to the callback scoped to the current state/props on each render\n\n useIsomorphicLayoutEffect(function () {\n ref.current = fn;\n });\n return useCallback(function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return ref.current.apply(void 0, args);\n }, []);\n}\n\nfunction useField(propsOrFieldName) {\n var formik = useFormikContext();\n var getFieldProps = formik.getFieldProps,\n getFieldMeta = formik.getFieldMeta,\n getFieldHelpers = formik.getFieldHelpers,\n registerField = formik.registerField,\n unregisterField = formik.unregisterField;\n var isAnObject = isObject(propsOrFieldName); // Normalize propsOrFieldName to FieldHookConfig<Val>\n\n var props = isAnObject ? propsOrFieldName : {\n name: propsOrFieldName\n };\n var fieldName = props.name,\n validateFn = props.validate;\n useEffect(function () {\n if (fieldName) {\n registerField(fieldName, {\n validate: validateFn\n });\n }\n\n return function () {\n if (fieldName) {\n unregisterField(fieldName);\n }\n };\n }, [registerField, unregisterField, fieldName, validateFn]);\n\n if (process.env.NODE_ENV !== \"production\") {\n !formik ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'useField() / <Field /> must be used underneath a <Formik> component or withFormik() higher order component') : invariant(false) : void 0;\n }\n\n !fieldName ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Invalid field name. Either pass `useField` a string or an object containing a `name` key.') : invariant(false) : void 0;\n var fieldHelpers = useMemo(function () {\n return getFieldHelpers(fieldName);\n }, [getFieldHelpers, fieldName]);\n return [getFieldProps(props), getFieldMeta(fieldName), fieldHelpers];\n}\nfunction Field(_ref) {\n var validate = _ref.validate,\n name = _ref.name,\n render = _ref.render,\n children = _ref.children,\n is = _ref.as,\n component = _ref.component,\n className = _ref.className,\n props = _objectWithoutPropertiesLoose(_ref, [\"validate\", \"name\", \"render\", \"children\", \"as\", \"component\", \"className\"]);\n\n var _useFormikContext = useFormikContext(),\n formik = _objectWithoutPropertiesLoose(_useFormikContext, [\"validate\", \"validationSchema\"]);\n\n if (process.env.NODE_ENV !== \"production\") {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useEffect(function () {\n !!render ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"<Field render> has been deprecated and will be removed in future versions of Formik. Please use a child callback function instead. To get rid of this warning, replace <Field name=\\\"\" + name + \"\\\" render={({field, form}) => ...} /> with <Field name=\\\"\" + name + \"\\\">{({field, form, meta}) => ...}</Field>\") : invariant(false) : void 0;\n !!(is && children && isFunction(children)) ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'You should not use <Field as> and <Field children> as a function in the same <Field> component; <Field as> will be ignored.') : invariant(false) : void 0;\n !!(component && children && isFunction(children)) ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'You should not use <Field component> and <Field children> as a function in the same <Field> component; <Field component> will be ignored.') : invariant(false) : void 0;\n !!(render && children && !isEmptyChildren(children)) ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'You should not use <Field render> and <Field children> in the same <Field> component; <Field children> will be ignored') : invariant(false) : void 0; // eslint-disable-next-line\n }, []);\n } // Register field and field-level validation with parent <Formik>\n\n\n var registerField = formik.registerField,\n unregisterField = formik.unregisterField;\n useEffect(function () {\n registerField(name, {\n validate: validate\n });\n return function () {\n unregisterField(name);\n };\n }, [registerField, unregisterField, name, validate]);\n var field = formik.getFieldProps(_extends({\n name: name\n }, props));\n var meta = formik.getFieldMeta(name);\n var legacyBag = {\n field: field,\n form: formik\n };\n\n if (render) {\n return render(_extends({}, legacyBag, {\n meta: meta\n }));\n }\n\n if (isFunction(children)) {\n return children(_extends({}, legacyBag, {\n meta: meta\n }));\n }\n\n if (component) {\n // This behavior is backwards compat with earlier Formik 0.9 to 1.x\n if (typeof component === 'string') {\n var innerRef = props.innerRef,\n rest = _objectWithoutPropertiesLoose(props, [\"innerRef\"]);\n\n return createElement(component, _extends({\n ref: innerRef\n }, field, rest, {\n className: className\n }), children);\n } // We don't pass `meta` for backwards compat\n\n\n return createElement(component, _extends({\n field: field,\n form: formik\n }, props, {\n className: className\n }), children);\n } // default to input here so we can check for both `as` and `children` above\n\n\n var asElement = is || 'input';\n\n if (typeof asElement === 'string') {\n var _innerRef = props.innerRef,\n _rest = _objectWithoutPropertiesLoose(props, [\"innerRef\"]);\n\n return createElement(asElement, _extends({\n ref: _innerRef\n }, field, _rest, {\n className: className\n }), children);\n }\n\n return createElement(asElement, _extends({}, field, props, {\n className: className\n }), children);\n}\n\nvar Form = /*#__PURE__*/forwardRef(function (props, ref) {\n // iOS needs an \"action\" attribute for nice input: https://stackoverflow.com/a/39485162/406725\n // We default the action to \"#\" in case the preventDefault fails (just updates the URL hash)\n var action = props.action,\n rest = _objectWithoutPropertiesLoose(props, [\"action\"]);\n\n var _action = action != null ? action : '#';\n\n var _useFormikContext = useFormikContext(),\n handleReset = _useFormikContext.handleReset,\n handleSubmit = _useFormikContext.handleSubmit;\n\n return createElement(\"form\", _extends({\n onSubmit: handleSubmit,\n ref: ref,\n onReset: handleReset,\n action: _action\n }, rest));\n});\nForm.displayName = 'Form';\n\n/**\r\n * A public higher-order component to access the imperative API\r\n */\n\nfunction withFormik(_ref) {\n var _ref$mapPropsToValues = _ref.mapPropsToValues,\n mapPropsToValues = _ref$mapPropsToValues === void 0 ? function (vanillaProps) {\n var val = {};\n\n for (var k in vanillaProps) {\n if (vanillaProps.hasOwnProperty(k) && typeof vanillaProps[k] !== 'function') {\n // @todo TypeScript fix\n val[k] = vanillaProps[k];\n }\n }\n\n return val;\n } : _ref$mapPropsToValues,\n config = _objectWithoutPropertiesLoose(_ref, [\"mapPropsToValues\"]);\n\n return function createFormik(Component$1) {\n var componentDisplayName = Component$1.displayName || Component$1.name || Component$1.constructor && Component$1.constructor.name || 'Component';\n /**\r\n * We need to use closures here for to provide the wrapped component's props to\r\n * the respective withFormik config methods.\r\n */\n\n var C = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(C, _React$Component);\n\n function C() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n\n _this.validate = function (values) {\n return config.validate(values, _this.props);\n };\n\n _this.validationSchema = function () {\n return isFunction(config.validationSchema) ? config.validationSchema(_this.props) : config.validationSchema;\n };\n\n _this.handleSubmit = function (values, actions) {\n return config.handleSubmit(values, _extends({}, actions, {\n props: _this.props\n }));\n };\n\n _this.renderFormComponent = function (formikProps) {\n return createElement(Component$1, _extends({}, _this.props, formikProps));\n };\n\n return _this;\n }\n\n var _proto = C.prototype;\n\n _proto.render = function render() {\n var _this$props = this.props,\n props = _objectWithoutPropertiesLoose(_this$props, [\"children\"]);\n\n return createElement(Formik, _extends({}, props, config, {\n validate: config.validate && this.validate,\n validationSchema: config.validationSchema && this.validationSchema,\n initialValues: mapPropsToValues(this.props),\n initialStatus: config.mapPropsToStatus && config.mapPropsToStatus(this.props),\n initialErrors: config.mapPropsToErrors && config.mapPropsToErrors(this.props),\n initialTouched: config.mapPropsToTouched && config.mapPropsToTouched(this.props),\n onSubmit: this.handleSubmit,\n children: this.renderFormComponent\n }));\n };\n\n return C;\n }(Component);\n\n C.displayName = \"WithFormik(\" + componentDisplayName + \")\";\n return hoistNonReactStatics(C, Component$1 // cast type to ComponentClass (even if SFC)\n );\n };\n}\n\n/**\r\n * Connect any component to Formik context, and inject as a prop called `formik`;\r\n * @param Comp React Component\r\n */\n\nfunction connect(Comp) {\n var C = function C(props) {\n return createElement(FormikConsumer, null, function (formik) {\n !!!formik ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"Formik context is undefined, please verify you are rendering <Form>, <Field>, <FastField>, <FieldArray>, or your custom context-using component as a child of a <Formik> component. Component name: \" + Comp.name) : invariant(false) : void 0;\n return createElement(Comp, _extends({}, props, {\n formik: formik\n }));\n });\n };\n\n var componentDisplayName = Comp.displayName || Comp.name || Comp.constructor && Comp.constructor.name || 'Component'; // Assign Comp to C.WrappedComponent so we can access the inner component in tests\n // For example, <Field.WrappedComponent /> gets us <FieldInner/>\n\n C.WrappedComponent = Comp;\n C.displayName = \"FormikConnect(\" + componentDisplayName + \")\";\n return hoistNonReactStatics(C, Comp // cast type to ComponentClass (even if SFC)\n );\n}\n\n/**\r\n * Some array helpers!\r\n */\n\nvar move = function move(array, from, to) {\n var copy = copyArrayLike(array);\n var value = copy[from];\n copy.splice(from, 1);\n copy.splice(to, 0, value);\n return copy;\n};\nvar swap = function swap(arrayLike, indexA, indexB) {\n var copy = copyArrayLike(arrayLike);\n var a = copy[indexA];\n copy[indexA] = copy[indexB];\n copy[indexB] = a;\n return copy;\n};\nvar insert = function insert(arrayLike, index, value) {\n var copy = copyArrayLike(arrayLike);\n copy.splice(index, 0, value);\n return copy;\n};\nvar replace = function replace(arrayLike, index, value) {\n var copy = copyArrayLike(arrayLike);\n copy[index] = value;\n return copy;\n};\n\nvar copyArrayLike = function copyArrayLike(arrayLike) {\n if (!arrayLike) {\n return [];\n } else if (Array.isArray(arrayLike)) {\n return [].concat(arrayLike);\n } else {\n var maxIndex = Object.keys(arrayLike).map(function (key) {\n return parseInt(key);\n }).reduce(function (max, el) {\n return el > max ? el : max;\n }, 0);\n return Array.from(_extends({}, arrayLike, {\n length: maxIndex + 1\n }));\n }\n};\n\nvar createAlterationHandler = function createAlterationHandler(alteration, defaultFunction) {\n var fn = typeof alteration === 'function' ? alteration : defaultFunction;\n return function (data) {\n if (Array.isArray(data) || isObject(data)) {\n var clone = copyArrayLike(data);\n return fn(clone);\n } // This can be assumed to be a primitive, which\n // is a case for top level validation errors\n\n\n return data;\n };\n};\n\nvar FieldArrayInner = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(FieldArrayInner, _React$Component);\n\n function FieldArrayInner(props) {\n var _this;\n\n _this = _React$Component.call(this, props) || this; // We need TypeScript generics on these, so we'll bind them in the constructor\n // @todo Fix TS 3.2.1\n\n _this.updateArrayField = function (fn, alterTouched, alterErrors) {\n var _this$props = _this.props,\n name = _this$props.name,\n setFormikState = _this$props.formik.setFormikState;\n setFormikState(function (prevState) {\n var updateErrors = createAlterationHandler(alterErrors, fn);\n var updateTouched = createAlterationHandler(alterTouched, fn); // values fn should be executed before updateErrors and updateTouched,\n // otherwise it causes an error with unshift.\n\n var values = setIn(prevState.values, name, fn(getIn(prevState.values, name)));\n var fieldError = alterErrors ? updateErrors(getIn(prevState.errors, name)) : undefined;\n var fieldTouched = alterTouched ? updateTouched(getIn(prevState.touched, name)) : undefined;\n\n if (isEmptyArray(fieldError)) {\n fieldError = undefined;\n }\n\n if (isEmptyArray(fieldTouched)) {\n fieldTouched = undefined;\n }\n\n return _extends({}, prevState, {\n values: values,\n errors: alterErrors ? setIn(prevState.errors, name, fieldError) : prevState.errors,\n touched: alterTouched ? setIn(prevState.touched, name, fieldTouched) : prevState.touched\n });\n });\n };\n\n _this.push = function (value) {\n return _this.updateArrayField(function (arrayLike) {\n return [].concat(copyArrayLike(arrayLike), [cloneDeep(value)]);\n }, false, false);\n };\n\n _this.handlePush = function (value) {\n return function () {\n return _this.push(value);\n };\n };\n\n _this.swap = function (indexA, indexB) {\n return _this.updateArrayField(function (array) {\n return swap(array, indexA, indexB);\n }, true, true);\n };\n\n _this.handleSwap = function (indexA, indexB) {\n return function () {\n return _this.swap(indexA, indexB);\n };\n };\n\n _this.move = function (from, to) {\n return _this.updateArrayField(function (array) {\n return move(array, from, to);\n }, true, true);\n };\n\n _this.handleMove = function (from, to) {\n return function () {\n return _this.move(from, to);\n };\n };\n\n _this.insert = function (index, value) {\n return _this.updateArrayField(function (array) {\n return insert(array, index, value);\n }, function (array) {\n return insert(array, index, null);\n }, function (array) {\n return insert(array, index, null);\n });\n };\n\n _this.handleInsert = function (index, value) {\n return function () {\n return _this.insert(index, value);\n };\n };\n\n _this.replace = function (index, value) {\n return _this.updateArrayField(function (array) {\n return replace(array, index, value);\n }, false, false);\n };\n\n _this.handleReplace = function (index, value) {\n return function () {\n return _this.replace(index, value);\n };\n };\n\n _this.unshift = function (value) {\n var length = -1;\n\n _this.updateArrayField(function (array) {\n var arr = array ? [value].concat(array) : [value];\n length = arr.length;\n return arr;\n }, function (array) {\n return array ? [null].concat(array) : [null];\n }, function (array) {\n return array ? [null].concat(array) : [null];\n });\n\n return length;\n };\n\n _this.handleUnshift = function (value) {\n return function () {\n return _this.unshift(value);\n };\n };\n\n _this.handleRemove = function (index) {\n return function () {\n return _this.remove(index);\n };\n };\n\n _this.handlePop = function () {\n return function () {\n return _this.pop();\n };\n };\n\n _this.remove = _this.remove.bind(_assertThisInitialized(_this));\n _this.pop = _this.pop.bind(_assertThisInitialized(_this));\n return _this;\n }\n\n var _proto = FieldArrayInner.prototype;\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n if (this.props.validateOnChange && this.props.formik.validateOnChange && !isEqual(getIn(prevProps.formik.values, prevProps.name), getIn(this.props.formik.values, this.props.name))) {\n this.props.formik.validateForm(this.props.formik.values);\n }\n };\n\n _proto.remove = function remove(index) {\n // We need to make sure we also remove relevant pieces of `touched` and `errors`\n var result;\n this.updateArrayField( // so this gets call 3 times\n function (array) {\n var copy = array ? copyArrayLike(array) : [];\n\n if (!result) {\n result = copy[index];\n }\n\n if (isFunction(copy.splice)) {\n copy.splice(index, 1);\n } // if the array only includes undefined values we have to return an empty array\n\n\n return isFunction(copy.every) ? copy.every(function (v) {\n return v === undefined;\n }) ? [] : copy : copy;\n }, true, true);\n return result;\n };\n\n _proto.pop = function pop() {\n // Remove relevant pieces of `touched` and `errors` too!\n var result;\n this.updateArrayField( // so this gets call 3 times\n function (array) {\n var tmp = array.slice();\n\n if (!result) {\n result = tmp && tmp.pop && tmp.pop();\n }\n\n return tmp;\n }, true, true);\n return result;\n };\n\n _proto.render = function render() {\n var arrayHelpers = {\n push: this.push,\n pop: this.pop,\n swap: this.swap,\n move: this.move,\n insert: this.insert,\n replace: this.replace,\n unshift: this.unshift,\n remove: this.remove,\n handlePush: this.handlePush,\n handlePop: this.handlePop,\n handleSwap: this.handleSwap,\n handleMove: this.handleMove,\n handleInsert: this.handleInsert,\n handleReplace: this.handleReplace,\n handleUnshift: this.handleUnshift,\n handleRemove: this.handleRemove\n };\n\n var _this$props2 = this.props,\n component = _this$props2.component,\n render = _this$props2.render,\n children = _this$props2.children,\n name = _this$props2.name,\n _this$props2$formik = _this$props2.formik,\n restOfFormik = _objectWithoutPropertiesLoose(_this$props2$formik, [\"validate\", \"validationSchema\"]);\n\n var props = _extends({}, arrayHelpers, {\n form: restOfFormik,\n name: name\n });\n\n return component ? createElement(component, props) : render ? render(props) : children // children come last, always called\n ? typeof children === 'function' ? children(props) : !isEmptyChildren(children) ? Children.only(children) : null : null;\n };\n\n return FieldArrayInner;\n}(Component);\n\nFieldArrayInner.defaultProps = {\n validateOnChange: true\n};\nvar FieldArray = /*#__PURE__*/connect(FieldArrayInner);\n\nvar ErrorMessageImpl = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(ErrorMessageImpl, _React$Component);\n\n function ErrorMessageImpl() {\n return _React$Component.apply(this, arguments) || this;\n }\n\n var _proto = ErrorMessageImpl.prototype;\n\n _proto.shouldComponentUpdate = function shouldComponentUpdate(props) {\n if (getIn(this.props.formik.errors, this.props.name) !== getIn(props.formik.errors, this.props.name) || getIn(this.props.formik.touched, this.props.name) !== getIn(props.formik.touched, this.props.name) || Object.keys(this.props).length !== Object.keys(props).length) {\n return true;\n } else {\n return false;\n }\n };\n\n _proto.render = function render() {\n var _this$props = this.props,\n component = _this$props.component,\n formik = _this$props.formik,\n render = _this$props.render,\n children = _this$props.children,\n name = _this$props.name,\n rest = _objectWithoutPropertiesLoose(_this$props, [\"component\", \"formik\", \"render\", \"children\", \"name\"]);\n\n var touch = getIn(formik.touched, name);\n var error = getIn(formik.errors, name);\n return !!touch && !!error ? render ? isFunction(render) ? render(error) : null : children ? isFunction(children) ? children(error) : null : component ? createElement(component, rest, error) : error : null;\n };\n\n return ErrorMessageImpl;\n}(Component);\n\nvar ErrorMessage = /*#__PURE__*/connect(ErrorMessageImpl);\n\n/**\r\n * Custom Field component for quickly hooking into Formik\r\n * context and wiring up forms.\r\n */\n\nvar FastFieldInner = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(FastFieldInner, _React$Component);\n\n function FastFieldInner(props) {\n var _this;\n\n _this = _React$Component.call(this, props) || this;\n var render = props.render,\n children = props.children,\n component = props.component,\n is = props.as,\n name = props.name;\n !!render ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"<FastField render> has been deprecated. Please use a child callback function instead: <FastField name={\" + name + \"}>{props => ...}</FastField> instead.\") : invariant(false) : void 0;\n !!(component && render) ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'You should not use <FastField component> and <FastField render> in the same <FastField> component; <FastField component> will be ignored') : invariant(false) : void 0;\n !!(is && children && isFunction(children)) ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'You should not use <FastField as> and <FastField children> as a function in the same <FastField> component; <FastField as> will be ignored.') : invariant(false) : void 0;\n !!(component && children && isFunction(children)) ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'You should not use <FastField component> and <FastField children> as a function in the same <FastField> component; <FastField component> will be ignored.') : invariant(false) : void 0;\n !!(render && children && !isEmptyChildren(children)) ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'You should not use <FastField render> and <FastField children> in the same <FastField> component; <FastField children> will be ignored') : invariant(false) : void 0;\n return _this;\n }\n\n var _proto = FastFieldInner.prototype;\n\n _proto.shouldComponentUpdate = function shouldComponentUpdate(props) {\n if (this.props.shouldUpdate) {\n return this.props.shouldUpdate(props, this.props);\n } else if (props.name !== this.props.name || getIn(props.formik.values, this.props.name) !== getIn(this.props.formik.values, this.props.name) || getIn(props.formik.errors, this.props.name) !== getIn(this.props.formik.errors, this.props.name) || getIn(props.formik.touched, this.props.name) !== getIn(this.props.formik.touched, this.props.name) || Object.keys(this.props).length !== Object.keys(props).length || props.formik.isSubmitting !== this.props.formik.isSubmitting) {\n return true;\n } else {\n return false;\n }\n };\n\n _proto.componentDidMount = function componentDidMount() {\n // Register the Field with the parent Formik. Parent will cycle through\n // registered Field's validate fns right prior to submit\n this.props.formik.registerField(this.props.name, {\n validate: this.props.validate\n });\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n if (this.props.name !== prevProps.name) {\n this.props.formik.unregisterField(prevProps.name);\n this.props.formik.registerField(this.props.name, {\n validate: this.props.validate\n });\n }\n\n if (this.props.validate !== prevProps.validate) {\n this.props.formik.registerField(this.props.name, {\n validate: this.props.validate\n });\n }\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.props.formik.unregisterField(this.props.name);\n };\n\n _proto.render = function render() {\n var _this$props = this.props,\n name = _this$props.name,\n render = _this$props.render,\n is = _this$props.as,\n children = _this$props.children,\n component = _this$props.component,\n formik = _this$props.formik,\n props = _objectWithoutPropertiesLoose(_this$props, [\"validate\", \"name\", \"render\", \"as\", \"children\", \"component\", \"shouldUpdate\", \"formik\"]);\n\n var restOfFormik = _objectWithoutPropertiesLoose(formik, [\"validate\", \"validationSchema\"]);\n\n var field = formik.getFieldProps(_extends({\n name: name\n }, props));\n var meta = {\n value: getIn(formik.values, name),\n error: getIn(formik.errors, name),\n touched: !!getIn(formik.touched, name),\n initialValue: getIn(formik.initialValues, name),\n initialTouched: !!getIn(formik.initialTouched, name),\n initialError: getIn(formik.initialErrors, name)\n };\n var bag = {\n field: field,\n meta: meta,\n form: restOfFormik\n };\n\n if (render) {\n return render(bag);\n }\n\n if (isFunction(children)) {\n return children(bag);\n }\n\n if (component) {\n // This behavior is backwards compat with earlier Formik 0.9 to 1.x\n if (typeof component === 'string') {\n var innerRef = props.innerRef,\n rest = _objectWithoutPropertiesLoose(props, [\"innerRef\"]);\n\n return createElement(component, _extends({\n ref: innerRef\n }, field, rest), children);\n } // We don't pass `meta` for backwards compat\n\n\n return createElement(component, _extends({\n field: field,\n form: formik\n }, props), children);\n } // default to input here so we can check for both `as` and `children` above\n\n\n var asElement = is || 'input';\n\n if (typeof asElement === 'string') {\n var _innerRef = props.innerRef,\n _rest = _objectWithoutPropertiesLoose(props, [\"innerRef\"]);\n\n return createElement(asElement, _extends({\n ref: _innerRef\n }, field, _rest), children);\n }\n\n return createElement(asElement, _extends({}, field, props), children);\n };\n\n return FastFieldInner;\n}(Component);\n\nvar FastField = /*#__PURE__*/connect(FastFieldInner);\n\nexport { ErrorMessage, FastField, Field, FieldArray, Form, Formik, FormikConsumer, FormikContext, FormikProvider, connect, getActiveElement, getIn, insert, isEmptyArray, isEmptyChildren, isFunction, isInputEvent, isInteger, isNaN$1 as isNaN, isObject, isPromise, isString, move, prepareDataForValidation, replace, setIn, setNestedObjectValues, swap, useField, useFormik, useFormikContext, validateYupSchema, withFormik, yupToFormErrors };\n//# sourceMappingURL=formik.esm.js.map\n","import { useRef, useState } from 'react';\nimport type { ReactNode, KeyboardEvent } from 'react';\nimport { Input } from '../common/Input/Input';\nimport { Field } from 'formik';\n\nexport interface CurrencyOption {\n code: string;\n symbol: string;\n label: string;\n}\n\nexport interface LocaleOption {\n code: string;\n label: string;\n flag?: string;\n}\n\nexport interface HeaderProps {\n /** Logo — ReactNode (image, SVG, text) */\n logo?: ReactNode;\n /** Search placeholder */\n searchPlaceholder?: string;\n onSearch?: (query: string) => void;\n /** Cart */\n cartItemCount?: number;\n onCartClick?: () => void;\n /** Customer */\n isLoggedIn?: boolean;\n customerName?: string;\n onCustomerClick?: () => void;\n /** Currency */\n currencies?: CurrencyOption[];\n selectedCurrency?: string;\n onCurrencyChange?: (code: string) => void;\n /** Locale / eshop */\n locales?: LocaleOption[];\n selectedLocale?: string;\n onLocaleChange?: (code: string) => void;\n /** Extra right slot */\n rightSlot?: ReactNode;\n}\n\n// ─── Small internal dropdown ────────────────────────────────────────────────\n\ninterface DropdownProps<T extends { label: string }> {\n trigger: ReactNode;\n items: T[];\n onSelect: (item: T) => void;\n getKey: (item: T) => string;\n renderItem?: (item: T) => ReactNode;\n}\n\nfunction Dropdown<T extends { label: string }>({\n trigger,\n items,\n onSelect,\n getKey,\n renderItem,\n}: DropdownProps<T>) {\n const [open, setOpen] = useState(false);\n const ref = useRef<HTMLDivElement>(null);\n\n const close = () => setOpen(false);\n\n // Close on outside click\n const handleBlur = (e: React.FocusEvent) => {\n if (!ref.current?.contains(e.relatedTarget as Node)) close();\n };\n\n const onKey = (e: KeyboardEvent) => {\n if (e.key === 'Escape') close();\n };\n\n return (\n <div ref={ref} className=\"relative\" onBlur={handleBlur} onKeyDown={onKey}>\n <div\n role=\"button\"\n tabIndex={0}\n onClick={() => setOpen((v) => !v)}\n onKeyDown={(e) => e.key === 'Enter' && setOpen((v) => !v)}\n className=\"cursor-pointer\"\n >\n {trigger}\n </div>\n {open && (\n <ul\n role=\"menu\"\n className=\"absolute right-0 top-full mt-1 z-50 min-w-28 bg-white rounded-lg shadow-lg border border-gray-100 py-1 text-sm\"\n >\n {items.map((item) => (\n <li key={getKey(item)} role=\"none\">\n <button\n role=\"menuitem\"\n className=\"w-full px-3 py-1.5 text-left hover:bg-gray-50 text-gray-700 whitespace-nowrap\"\n onClick={() => {\n onSelect(item);\n close();\n }}\n >\n {renderItem ? renderItem(item) : item.label}\n </button>\n </li>\n ))}\n </ul>\n )}\n </div>\n );\n}\n\n// ─── Search icon ─────────────────────────────────────────────────────────────\n\nfunction SearchIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M21 21l-5.197-5.197m0 0A7.5 7.5 0 105.196 15.803a7.5 7.5 0 0010.607 10.607z\"\n />\n </svg>\n );\n}\n\n// ─── Header ──────────────────────────────────────────────────────────────────\n\nexport function Header({\n logo,\n searchPlaceholder = 'Hledat produkty…',\n onSearch,\n cartItemCount = 0,\n onCartClick,\n isLoggedIn = false,\n customerName,\n onCustomerClick,\n currencies = [],\n selectedCurrency,\n onCurrencyChange,\n locales = [],\n selectedLocale,\n onLocaleChange,\n rightSlot,\n}: HeaderProps) {\n const [searchQuery, setSearchQuery] = useState('');\n\n const activeCurrency = currencies.find((c) => c.code === selectedCurrency);\n const activeLocale = locales.find((l) => l.code === selectedLocale);\n\n const handleSearchKey = (e: KeyboardEvent<HTMLInputElement>) => {\n if (e.key === 'Enter') onSearch?.(searchQuery);\n };\n\n return (\n <header className=\"bg-white border-b border-gray-200 sticky top-0 z-40\">\n <div className=\"max-w-7xl mx-auto px-4 h-16 flex items-center gap-4\">\n {/* Logo */}\n <div className=\"shrink-0\">\n {logo ?? (\n <span className=\"text-xl font-bold text-primary-600 tracking-tight\">\n shopito\n </span>\n )}\n </div>\n\n {/* Search */}\n <div className=\"flex-1 max-w-xl\">\n <Field\n component={Input}\n placeholder={searchPlaceholder}\n value={searchQuery}\n onChange={(e: any) => setSearchQuery(e.target.value)}\n onKeyDown={handleSearchKey}\n leftIcon={<SearchIcon />}\n rightIcon={\n searchQuery ? (\n <button\n onClick={() => {\n setSearchQuery('');\n onSearch?.('');\n }}\n className=\"hover:text-gray-600 transition-colors\"\n aria-label=\"Clear search\"\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-3.5 h-3.5\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M6 18L18 6M6 6l12 12\"\n />\n </svg>\n </button>\n ) : undefined\n }\n />\n </div>\n\n {/* Right controls */}\n <div className=\"flex items-center gap-1 shrink-0 ml-auto\">\n {/* Currency switcher */}\n {currencies.length > 0 && (\n <Dropdown\n trigger={\n <button className=\"flex items-center gap-1 px-2 py-1.5 rounded-md text-sm text-gray-600 hover:bg-gray-50 transition-colors font-medium\">\n <span>{activeCurrency?.symbol ?? selectedCurrency}</span>\n <span className=\"text-xs text-gray-400\">\n {activeCurrency?.code ?? selectedCurrency}\n </span>\n <ChevronDown className=\"w-3 h-3 text-gray-400\" />\n </button>\n }\n items={currencies}\n getKey={(c) => c.code}\n onSelect={(c) => onCurrencyChange?.(c.code)}\n renderItem={(c) => (\n <span className=\"flex items-center gap-2\">\n <span className=\"w-6 text-center font-medium text-gray-500\">\n {c.symbol}\n </span>\n <span>{c.label}</span>\n </span>\n )}\n />\n )}\n\n {/* Locale switcher */}\n {locales.length > 0 && (\n <Dropdown\n trigger={\n <button className=\"flex items-center gap-1 px-2 py-1.5 rounded-md text-sm text-gray-600 hover:bg-gray-50 transition-colors\">\n {activeLocale?.flag && (\n <span className=\"text-base leading-none\">\n {activeLocale.flag}\n </span>\n )}\n <span className=\"font-medium uppercase\">\n {activeLocale?.code ?? selectedLocale}\n </span>\n <ChevronDown className=\"w-3 h-3 text-gray-400\" />\n </button>\n }\n items={locales}\n getKey={(l) => l.code}\n onSelect={(l) => onLocaleChange?.(l.code)}\n renderItem={(l) => (\n <span className=\"flex items-center gap-2\">\n {l.flag && <span className=\"text-base\">{l.flag}</span>}\n <span>{l.label}</span>\n </span>\n )}\n />\n )}\n\n {/* Divider */}\n {(currencies.length > 0 || locales.length > 0) && (\n <div className=\"w-px h-5 bg-gray-200 mx-1\" />\n )}\n\n {/* Customer button */}\n <button\n onClick={onCustomerClick}\n className=\"flex items-center gap-1.5 px-2.5 py-1.5 rounded-md text-sm text-gray-600 hover:bg-gray-50 transition-colors\"\n aria-label={isLoggedIn ? 'My account' : 'Sign in'}\n >\n {isLoggedIn ? (\n <>\n <div className=\"w-6 h-6 rounded-full bg-primary-600 text-white flex items-center justify-center text-xs font-bold\">\n {(customerName ?? 'U')[0].toUpperCase()}\n </div>\n {customerName && (\n <span className=\"hidden sm:block font-medium max-w-32 truncate\">\n {customerName}\n </span>\n )}\n </>\n ) : (\n <>\n <UserIcon className=\"w-5 h-5\" />\n <span className=\"hidden sm:block font-medium\">\n Přihlásit se\n </span>\n </>\n )}\n </button>\n\n {/* Cart */}\n <button\n onClick={onCartClick}\n className=\"relative flex items-center gap-1.5 px-2.5 py-1.5 rounded-md text-sm text-gray-600 hover:bg-gray-50 transition-colors\"\n aria-label={`Cart, ${cartItemCount} items`}\n >\n <CartIcon className=\"w-5 h-5\" />\n <span className=\"hidden sm:block font-medium\">Košík</span>\n {cartItemCount > 0 && (\n <span className=\"absolute -top-0.5 -right-0.5 min-w-4.5 h-4.5 flex items-center justify-center rounded-full bg-primary-600 text-white text-[10px] font-bold leading-none px-1\">\n {cartItemCount > 99 ? '99+' : cartItemCount}\n </span>\n )}\n </button>\n\n {rightSlot}\n </div>\n </div>\n </header>\n );\n}\n\n// ─── Icon helpers ─────────────────────────────────────────────────────────────\n\nfunction ChevronDown({ className }: { className?: string }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className={className}\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M19.5 8.25l-7.5 7.5-7.5-7.5\"\n />\n </svg>\n );\n}\n\nfunction UserIcon({ className }: { className?: string }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className={className}\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M15.75 6a3.75 3.75 0 11-7.5 0 3.75 3.75 0 017.5 0zM4.501 20.118a7.5 7.5 0 0114.998 0A17.933 17.933 0 0112 21.75c-2.676 0-5.216-.584-7.499-1.632z\"\n />\n </svg>\n );\n}\n\nfunction CartIcon({ className }: { className?: string }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className={className}\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M2.25 3h1.386c.51 0 .955.343 1.087.835l.383 1.437M7.5 14.25a3 3 0 00-3 3h15.75m-12.75-3h11.218c1.121-2.3 2.1-4.684 2.924-7.138a60.114 60.114 0 00-16.536-1.84M7.5 14.25L5.106 5.272M6 20.25a.75.75 0 11-1.5 0 .75.75 0 011.5 0zm12.75 0a.75.75 0 11-1.5 0 .75.75 0 011.5 0z\"\n />\n </svg>\n );\n}\n","import { useState } from 'react'\n\nexport interface Category {\n id: string\n label: string\n icon?: string\n count?: number\n children?: Category[]\n}\n\nexport interface CategoryTreeProps {\n categories: Category[]\n activeId?: string\n onSelect?: (category: Category) => void\n /** Show product counts */\n showCounts?: boolean\n /** All nodes expanded by default */\n defaultExpandAll?: boolean\n className?: string\n}\n\ninterface TreeNodeProps {\n node: Category\n activeId: string | undefined\n onSelect: (category: Category) => void\n showCounts: boolean\n depth: number\n defaultExpandAll: boolean\n}\n\nfunction TreeNode({\n node,\n activeId,\n onSelect,\n showCounts,\n depth,\n defaultExpandAll,\n}: TreeNodeProps) {\n const hasChildren = node.children && node.children.length > 0\n const [expanded, setExpanded] = useState(defaultExpandAll || isAncestorOf(node, activeId))\n const isActive = node.id === activeId\n\n return (\n <li>\n <div\n className={[\n 'group flex items-center gap-1.5 rounded-lg px-2 py-1.5 cursor-pointer select-none',\n 'transition-colors text-sm',\n isActive\n ? 'bg-primary-50 text-primary-700 font-medium'\n : 'text-gray-700 hover:bg-gray-50 hover:text-gray-900',\n depth > 0 ? `ml-${Math.min(depth * 4, 8)}` : '',\n ]\n .filter(Boolean)\n .join(' ')}\n style={depth > 0 ? { marginLeft: depth * 16 } : undefined}\n onClick={() => {\n onSelect(node)\n if (hasChildren) setExpanded((v) => !v)\n }}\n role=\"button\"\n tabIndex={0}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n onSelect(node)\n if (hasChildren) setExpanded((v) => !v)\n }\n }}\n aria-expanded={hasChildren ? expanded : undefined}\n >\n {/* Expand toggle */}\n {hasChildren ? (\n <span\n className={`shrink-0 text-gray-400 transition-transform duration-150 ${expanded ? 'rotate-90' : ''}`}\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-3.5 h-3.5\"\n >\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M8.25 4.5l7.5 7.5-7.5 7.5\" />\n </svg>\n </span>\n ) : (\n <span className=\"w-3.5 shrink-0\" />\n )}\n\n {/* Icon */}\n {node.icon && <span className=\"text-base leading-none\">{node.icon}</span>}\n\n {/* Label */}\n <span className=\"flex-1 truncate\">{node.label}</span>\n\n {/* Count */}\n {showCounts && node.count !== undefined && (\n <span\n className={`text-xs rounded-full px-1.5 py-0.5 font-medium ${\n isActive ? 'bg-primary-100 text-primary-600' : 'bg-gray-100 text-gray-500'\n }`}\n >\n {node.count}\n </span>\n )}\n </div>\n\n {/* Children */}\n {hasChildren && expanded && (\n <ul role=\"group\">\n {node.children!.map((child) => (\n <TreeNode\n key={child.id}\n node={child}\n activeId={activeId}\n onSelect={onSelect}\n showCounts={showCounts}\n depth={depth + 1}\n defaultExpandAll={defaultExpandAll}\n />\n ))}\n </ul>\n )}\n </li>\n )\n}\n\nfunction isAncestorOf(node: Category, activeId: string | undefined): boolean {\n if (!activeId) return false\n if (!node.children) return false\n return node.children.some(\n (c) => c.id === activeId || isAncestorOf(c, activeId),\n )\n}\n\nexport function CategoryTree({\n categories,\n activeId,\n onSelect,\n showCounts = true,\n defaultExpandAll = false,\n className = '',\n ...props\n}: CategoryTreeProps) {\n const handleSelect = (cat: Category) => onSelect?.(cat)\n\n return (\n <nav\n aria-label=\"Category navigation\"\n className={['w-full', className].filter(Boolean).join(' ')}\n {...props}\n >\n <ul role=\"tree\" className=\"space-y-0.5\">\n {categories.map((cat) => (\n <TreeNode\n key={cat.id}\n node={cat}\n activeId={activeId}\n onSelect={handleSelect}\n showCounts={showCounts}\n depth={0}\n defaultExpandAll={defaultExpandAll}\n />\n ))}\n </ul>\n </nav>\n )\n}\n","import { useState, useRef } from 'react'\n\nexport interface MegaMenuSubItem {\n id: string\n label: string\n href?: string\n badge?: string\n}\n\nexport interface MegaMenuColumn {\n heading?: string\n items: MegaMenuSubItem[]\n}\n\nexport interface MegaMenuFeatured {\n image?: string\n eyebrow?: string\n title: string\n description?: string\n cta?: string\n href?: string\n}\n\nexport interface MegaMenuItem {\n id: string\n label: string\n icon?: string\n href?: string\n /** If columns are present, hovering opens the mega panel */\n columns?: MegaMenuColumn[]\n featured?: MegaMenuFeatured\n}\n\nexport interface MegaMenuProps {\n items: MegaMenuItem[]\n activeId?: string\n onNavigate?: (item: MegaMenuSubItem | MegaMenuItem) => void\n}\n\n// ─── Mega panel ──────────────────────────────────────────────────────────────\n\ninterface MegaPanelProps {\n item: MegaMenuItem\n onNavigate: (subItem: MegaMenuSubItem | MegaMenuItem) => void\n onClose: () => void\n}\n\nfunction MegaPanel({ item, onNavigate, onClose }: MegaPanelProps) {\n if (!item.columns?.length) return null\n\n return (\n <div className=\"absolute left-0 right-0 top-full z-50 bg-white border-b border-gray-200 shadow-lg\">\n <div className=\"max-w-7xl mx-auto px-4 py-6 flex gap-8\">\n {/* Columns */}\n <div className=\"flex-1 grid grid-cols-2 md:grid-cols-3 lg:grid-cols-4 gap-6\">\n {item.columns.map((col, ci) => (\n <div key={ci}>\n {col.heading && (\n <p className=\"text-xs font-semibold uppercase tracking-wider text-gray-400 mb-2\">\n {col.heading}\n </p>\n )}\n <ul className=\"space-y-1\">\n {col.items.map((sub) => (\n <li key={sub.id}>\n <button\n className=\"flex items-center gap-1.5 text-sm text-gray-700 hover:text-primary-600 transition-colors py-0.5\"\n onClick={() => {\n onNavigate(sub)\n onClose()\n }}\n >\n {sub.label}\n {sub.badge && (\n <span className=\"text-[10px] font-semibold px-1.5 py-0.5 rounded-full bg-danger-50 text-danger-600 leading-none\">\n {sub.badge}\n </span>\n )}\n </button>\n </li>\n ))}\n </ul>\n </div>\n ))}\n </div>\n\n {/* Featured card */}\n {item.featured && (\n <div className=\"w-52 shrink-0\">\n <button\n className=\"group block w-full rounded-xl overflow-hidden border border-gray-100 text-left hover:shadow-md transition-shadow\"\n onClick={() => {\n onNavigate(item)\n onClose()\n }}\n >\n {item.featured.image ? (\n <img\n src={item.featured.image}\n alt={item.featured.title}\n className=\"w-full h-28 object-cover\"\n />\n ) : (\n <div className=\"w-full h-28 bg-linear-to-br from-primary-100 to-primary-200 flex items-center justify-center text-4xl\">\n {item.icon ?? '🛍️'}\n </div>\n )}\n <div className=\"p-3\">\n {item.featured.eyebrow && (\n <p className=\"text-[10px] font-semibold uppercase tracking-wider text-primary-500 mb-0.5\">\n {item.featured.eyebrow}\n </p>\n )}\n <p className=\"text-sm font-semibold text-gray-900 group-hover:text-primary-600 transition-colors\">\n {item.featured.title}\n </p>\n {item.featured.description && (\n <p className=\"text-xs text-gray-500 mt-0.5 line-clamp-2\">\n {item.featured.description}\n </p>\n )}\n {item.featured.cta && (\n <span className=\"inline-block mt-2 text-xs font-medium text-primary-600\">\n {item.featured.cta} →\n </span>\n )}\n </div>\n </button>\n </div>\n )}\n </div>\n </div>\n )\n}\n\n// ─── MegaMenu ────────────────────────────────────────────────────────────────\n\nexport function MegaMenu({\n items,\n activeId,\n onNavigate,\n}: MegaMenuProps) {\n const [openId, setOpenId] = useState<string | null>(null)\n const timeoutRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n\n const open = (id: string) => {\n if (timeoutRef.current) clearTimeout(timeoutRef.current)\n setOpenId(id)\n }\n\n const scheduleClose = () => {\n timeoutRef.current = setTimeout(() => setOpenId(null), 120)\n }\n\n const cancelClose = () => {\n if (timeoutRef.current) clearTimeout(timeoutRef.current)\n }\n\n const activeItem = items.find((i) => i.id === openId)\n\n return (\n <nav\n aria-label=\"Main navigation\"\n className=\"relative bg-white border-b border-gray-100\"\n onMouseLeave={scheduleClose}\n >\n <div className=\"max-w-7xl mx-auto px-4\">\n <ul className=\"flex items-center gap-0\" role=\"menubar\">\n {items.map((item) => {\n const hasMega = !!item.columns?.length\n const isOpen = openId === item.id\n const isActive = activeId === item.id\n\n return (\n <li key={item.id} role=\"none\">\n <button\n role=\"menuitem\"\n aria-haspopup={hasMega ? 'true' : undefined}\n aria-expanded={hasMega ? isOpen : undefined}\n className={[\n 'flex items-center gap-1.5 px-4 py-3.5 text-sm font-medium transition-colors relative',\n 'outline-none focus-visible:ring-2 focus-visible:ring-inset focus-visible:ring-primary-500',\n isActive || isOpen\n ? 'text-primary-600'\n : 'text-gray-700 hover:text-gray-900',\n isOpen\n ? 'after:absolute after:bottom-0 after:left-0 after:right-0 after:h-0.5 after:bg-primary-600'\n : '',\n ]\n .filter(Boolean)\n .join(' ')}\n onMouseEnter={() => hasMega ? open(item.id) : setOpenId(null)}\n onFocus={() => hasMega && open(item.id)}\n onClick={() => {\n if (!hasMega) {\n onNavigate?.(item)\n setOpenId(null)\n }\n }}\n >\n {item.icon && <span className=\"text-base leading-none\">{item.icon}</span>}\n {item.label}\n {hasMega && (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className={`w-3.5 h-3.5 transition-transform duration-150 ${isOpen ? 'rotate-180' : ''}`}\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M19.5 8.25l-7.5 7.5-7.5-7.5\"\n />\n </svg>\n )}\n </button>\n </li>\n )\n })}\n </ul>\n </div>\n\n {/* Mega panel */}\n {activeItem?.columns?.length && (\n <div\n onMouseEnter={cancelClose}\n onMouseLeave={scheduleClose}\n >\n <MegaPanel\n item={activeItem}\n onNavigate={(sub) => onNavigate?.(sub)}\n onClose={() => setOpenId(null)}\n />\n </div>\n )}\n </nav>\n )\n}\n","import { useState, useEffect, useCallback, useRef } from 'react'\n\nexport interface Banner {\n id: string\n /** Background image URL or gradient CSS value */\n backgroundImage?: string\n backgroundColor?: string\n /** Overlaid text content */\n eyebrow?: string\n title: string\n subtitle?: string\n ctaLabel?: string\n ctaHref?: string\n onCtaClick?: () => void\n /** Image on the right side of the banner */\n sideImage?: string\n /** Text colors — default to white for dark backgrounds */\n textColor?: 'light' | 'dark'\n}\n\nexport interface BannerCarouselProps {\n banners: Banner[]\n autoPlay?: boolean\n autoPlayInterval?: number\n /** Show arrow navigation */\n arrows?: boolean\n /** Show dot indicators */\n dots?: boolean\n className?: string\n /** Aspect ratio of the banner — default 3/1 */\n aspectRatio?: string\n}\n\nexport function BannerCarousel({\n banners,\n autoPlay = true,\n autoPlayInterval = 5000,\n arrows = true,\n dots = true,\n className = '',\n aspectRatio = '3 / 1',\n}: BannerCarouselProps) {\n const [current, setCurrent] = useState(0)\n const [paused, setPaused] = useState(false)\n const timerRef = useRef<ReturnType<typeof setInterval> | null>(null)\n const trackRef = useRef<HTMLDivElement>(null)\n\n const count = banners.length\n\n const goTo = useCallback(\n (index: number) => {\n setCurrent(((index % count) + count) % count)\n },\n [count],\n )\n\n const prev = () => goTo(current - 1)\n const next = useCallback(() => goTo(current + 1), [current, goTo])\n\n // Auto-play\n useEffect(() => {\n if (!autoPlay || paused || count <= 1) return\n timerRef.current = setInterval(next, autoPlayInterval)\n return () => {\n if (timerRef.current) clearInterval(timerRef.current)\n }\n }, [autoPlay, paused, autoPlayInterval, next, count])\n\n // Swipe support\n const touchStartX = useRef<number | null>(null)\n const handleTouchStart = (e: React.TouchEvent) => {\n touchStartX.current = e.touches[0].clientX\n }\n const handleTouchEnd = (e: React.TouchEvent) => {\n if (touchStartX.current === null) return\n const delta = e.changedTouches[0].clientX - touchStartX.current\n if (Math.abs(delta) > 50) delta < 0 ? next() : prev()\n touchStartX.current = null\n }\n\n if (count === 0) return null\n\n const banner = banners[current]\n const isLight = banner.textColor === 'light' || !banner.textColor\n\n return (\n <div\n className={['relative overflow-hidden rounded-xl', className].filter(Boolean).join(' ')}\n style={{ aspectRatio }}\n onMouseEnter={() => setPaused(true)}\n onMouseLeave={() => setPaused(false)}\n onTouchStart={handleTouchStart}\n onTouchEnd={handleTouchEnd}\n >\n {/* Slides */}\n <div ref={trackRef} className=\"relative w-full h-full\">\n {banners.map((b, i) => (\n <div\n key={b.id}\n aria-hidden={i !== current}\n className={[\n 'absolute inset-0 transition-opacity duration-700',\n i === current ? 'opacity-100 z-10' : 'opacity-0 z-0',\n ].join(' ')}\n style={{\n background: b.backgroundImage\n ? `url(${b.backgroundImage}) center/cover no-repeat`\n : b.backgroundColor ?? 'linear-gradient(135deg, #1d4ed8 0%, #7c3aed 100%)',\n }}\n >\n {/* Overlay for readability */}\n {b.backgroundImage && (\n <div className=\"absolute inset-0 bg-gradient-to-r from-black/50 via-black/20 to-transparent\" />\n )}\n\n {/* Content */}\n <div className=\"relative z-10 h-full flex items-center px-8 md:px-12 gap-8\">\n <div className=\"flex-1 max-w-lg\">\n {b.eyebrow && (\n <p\n className={`text-xs font-semibold uppercase tracking-widest mb-2 ${\n isLight ? 'text-white/70' : 'text-gray-500'\n }`}\n >\n {b.eyebrow}\n </p>\n )}\n <h2\n className={`text-2xl md:text-3xl lg:text-4xl font-bold leading-tight ${\n isLight ? 'text-white' : 'text-gray-900'\n }`}\n >\n {b.title}\n </h2>\n {b.subtitle && (\n <p\n className={`mt-2 text-sm md:text-base ${\n isLight ? 'text-white/80' : 'text-gray-600'\n }`}\n >\n {b.subtitle}\n </p>\n )}\n {b.ctaLabel && (\n <button\n onClick={b.onCtaClick}\n className={[\n 'mt-5 inline-flex items-center gap-2 px-5 py-2.5 rounded-lg text-sm font-semibold transition-all',\n isLight\n ? 'bg-white text-gray-900 hover:bg-gray-100'\n : 'bg-primary-600 text-white hover:bg-primary-700',\n ].join(' ')}\n >\n {b.ctaLabel}\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={2}\n stroke=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M8.25 4.5l7.5 7.5-7.5 7.5\" />\n </svg>\n </button>\n )}\n </div>\n\n {/* Side image */}\n {b.sideImage && (\n <div className=\"hidden md:block flex-1 h-full flex items-end justify-end overflow-hidden\">\n <img\n src={b.sideImage}\n alt=\"\"\n className=\"h-full w-auto object-contain object-bottom drop-shadow-2xl\"\n />\n </div>\n )}\n </div>\n </div>\n ))}\n </div>\n\n {/* Arrow navigation */}\n {arrows && count > 1 && (\n <>\n <button\n onClick={prev}\n className=\"absolute left-3 top-1/2 -translate-y-1/2 z-20 w-9 h-9 flex items-center justify-center rounded-full bg-black/30 text-white hover:bg-black/50 transition-colors backdrop-blur-sm\"\n aria-label=\"Previous banner\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" strokeWidth={2} stroke=\"currentColor\" className=\"w-5 h-5\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M15.75 19.5L8.25 12l7.5-7.5\" />\n </svg>\n </button>\n <button\n onClick={next}\n className=\"absolute right-3 top-1/2 -translate-y-1/2 z-20 w-9 h-9 flex items-center justify-center rounded-full bg-black/30 text-white hover:bg-black/50 transition-colors backdrop-blur-sm\"\n aria-label=\"Next banner\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" strokeWidth={2} stroke=\"currentColor\" className=\"w-5 h-5\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M8.25 4.5l7.5 7.5-7.5 7.5\" />\n </svg>\n </button>\n </>\n )}\n\n {/* Dot indicators */}\n {dots && count > 1 && (\n <div className=\"absolute bottom-3 left-1/2 -translate-x-1/2 z-20 flex gap-1.5\">\n {banners.map((_, i) => (\n <button\n key={i}\n onClick={() => goTo(i)}\n aria-label={`Go to slide ${i + 1}`}\n className={[\n 'rounded-full transition-all duration-300',\n i === current\n ? 'w-5 h-2 bg-white'\n : 'w-2 h-2 bg-white/50 hover:bg-white/80',\n ].join(' ')}\n />\n ))}\n </div>\n )}\n\n {/* Auto-play progress bar */}\n {autoPlay && count > 1 && (\n <div className=\"absolute bottom-0 left-0 right-0 h-0.5 bg-white/20 z-20\">\n <div\n key={`${current}-${paused}`}\n className={`h-full bg-white/60 ${paused ? '' : 'animate-progress'}`}\n style={{\n animation: paused ? 'none' : `progress ${autoPlayInterval}ms linear`,\n }}\n />\n </div>\n )}\n </div>\n )\n}\n","import { useState } from 'react'\nimport { Badge } from '../common/Badge/Badge'\nimport { Button } from '../common/Button/Button'\n\nexport interface ProductCardProduct {\n id: string\n name: string\n slug?: string\n /** Primary image URL */\n image?: string\n /** Secondary image on hover */\n imageHover?: string\n price: number\n originalPrice?: number\n currency?: string\n /** 'new' | 'sale' | 'hot' | custom string */\n badge?: string\n /** 0–5 */\n rating?: number\n reviewCount?: number\n inStock?: boolean\n /** Variants available (e.g. colors) */\n variants?: { id: string; color?: string; label: string }[]\n}\n\nexport interface ProductCardProps {\n product: ProductCardProduct\n onAddToCart?: (product: ProductCardProduct) => void\n onWishlistToggle?: (product: ProductCardProduct) => void\n isWishlisted?: boolean\n onProductClick?: (product: ProductCardProduct) => void\n /** compact — narrower, used in grids with 4+ columns */\n size?: 'default' | 'compact'\n className?: string\n}\n\nfunction StarIcon({ filled }: { filled: boolean }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n className={`w-3.5 h-3.5 ${filled ? 'fill-amber-400 stroke-amber-400' : 'fill-gray-200 stroke-gray-300'}`}\n strokeWidth={1}\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M11.48 3.499a.562.562 0 011.04 0l2.125 5.111a.563.563 0 00.475.345l5.518.442c.499.04.701.663.321.988l-4.204 3.602a.563.563 0 00-.182.557l1.285 5.385a.562.562 0 01-.84.61l-4.725-2.885a.563.563 0 00-.586 0L6.982 20.54a.562.562 0 01-.84-.61l1.285-5.386a.562.562 0 00-.182-.557l-4.204-3.602a.563.563 0 01.321-.988l5.518-.442a.563.563 0 00.475-.345L11.48 3.5z\"\n />\n </svg>\n )\n}\n\nfunction StarRating({ value, count }: { value: number; count?: number }) {\n return (\n <div className=\"flex items-center gap-1\">\n <div className=\"flex gap-0.5\">\n {[1, 2, 3, 4, 5].map((s) => (\n <StarIcon key={s} filled={s <= Math.round(value)} />\n ))}\n </div>\n {count !== undefined && (\n <span className=\"text-xs text-gray-400\">({count})</span>\n )}\n </div>\n )\n}\n\nfunction badgeVariant(badge: string) {\n const b = badge.toLowerCase()\n if (b === 'sale' || b === 'akce') return 'danger' as const\n if (b === 'new' || b === 'nové') return 'primary' as const\n if (b === 'hot') return 'warning' as const\n return 'default' as const\n}\n\nfunction formatPrice(price: number, currency = 'Kč') {\n return `${price.toLocaleString('cs-CZ')} ${currency}`\n}\n\nfunction discountPercent(original: number, current: number) {\n return Math.round((1 - current / original) * 100)\n}\n\nexport function ProductCard({\n product,\n onAddToCart,\n onWishlistToggle,\n isWishlisted = false,\n onProductClick,\n size = 'default',\n className = '',\n}: ProductCardProps) {\n const [hovered, setHovered] = useState(false)\n const [addedToCart, setAddedToCart] = useState(false)\n\n const hasDiscount =\n product.originalPrice !== undefined && product.originalPrice > product.price\n\n const handleAddToCart = (e: React.MouseEvent) => {\n e.stopPropagation()\n onAddToCart?.(product)\n setAddedToCart(true)\n setTimeout(() => setAddedToCart(false), 1500)\n }\n\n const handleWishlist = (e: React.MouseEvent) => {\n e.stopPropagation()\n onWishlistToggle?.(product)\n }\n\n return (\n <article\n className={[\n 'group relative flex flex-col bg-white rounded-xl border border-gray-200',\n 'hover:shadow-md transition-shadow duration-200 overflow-hidden cursor-pointer',\n className,\n ]\n .filter(Boolean)\n .join(' ')}\n onClick={() => onProductClick?.(product)}\n onMouseEnter={() => setHovered(true)}\n onMouseLeave={() => setHovered(false)}\n >\n {/* Image */}\n <div className={`relative overflow-hidden bg-gray-50 ${size === 'compact' ? 'aspect-square' : 'aspect-4/3'}`}>\n {product.image ? (\n <img\n src={hovered && product.imageHover ? product.imageHover : product.image}\n alt={product.name}\n className=\"w-full h-full object-contain p-4 transition-transform duration-300 group-hover:scale-105\"\n />\n ) : (\n <div className=\"w-full h-full flex items-center justify-center text-5xl bg-linear-to-br from-gray-100 to-gray-200\">\n 🛍️\n </div>\n )}\n\n {/* Badge */}\n {product.badge && (\n <div className=\"absolute top-2 left-2\">\n <Badge variant={badgeVariant(product.badge)} size=\"sm\">\n {product.badge === 'sale' && hasDiscount\n ? `-${discountPercent(product.originalPrice!, product.price)}%`\n : product.badge}\n </Badge>\n </div>\n )}\n\n {/* Out of stock overlay */}\n {product.inStock === false && (\n <div className=\"absolute inset-0 bg-white/70 flex items-center justify-center\">\n <span className=\"text-sm font-semibold text-gray-500 bg-white/90 px-3 py-1 rounded-full border border-gray-200\">\n Vyprodáno\n </span>\n </div>\n )}\n\n {/* Wishlist button */}\n <button\n onClick={handleWishlist}\n aria-label={isWishlisted ? 'Remove from wishlist' : 'Add to wishlist'}\n className={[\n 'absolute top-2 right-2 w-8 h-8 flex items-center justify-center rounded-full bg-white shadow-sm border border-gray-100',\n 'transition-all duration-200',\n 'opacity-0 group-hover:opacity-100 focus:opacity-100',\n isWishlisted ? 'text-danger-500' : 'text-gray-400 hover:text-danger-400',\n ].join(' ')}\n >\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className={`w-4 h-4 ${isWishlisted ? 'fill-current' : 'fill-none'}`}\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M21 8.25c0-2.485-2.099-4.5-4.688-4.5-1.935 0-3.597 1.126-4.312 2.733-.715-1.607-2.377-2.733-4.313-2.733C5.1 3.75 3 5.765 3 8.25c0 7.22 9 12 9 12s9-4.78 9-12z\"\n />\n </svg>\n </button>\n\n {/* Quick add — slides up on hover */}\n <div\n className={[\n 'absolute bottom-0 left-0 right-0 p-2 transition-transform duration-200',\n hovered ? 'translate-y-0' : 'translate-y-full',\n ].join(' ')}\n >\n <Button\n variant=\"primary\"\n size=\"sm\"\n fullWidth\n loading={false}\n disabled={product.inStock === false}\n onClick={handleAddToCart}\n className=\"shadow-lg\"\n >\n {addedToCart ? (\n <span className=\"flex items-center gap-1.5\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" strokeWidth={2} stroke=\"currentColor\" className=\"w-4 h-4\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M4.5 12.75l6 6 9-13.5\" />\n </svg>\n Přidáno\n </span>\n ) : (\n 'Přidat do košíku'\n )}\n </Button>\n </div>\n </div>\n\n {/* Info */}\n <div className={`flex flex-col gap-1.5 ${size === 'compact' ? 'p-3' : 'p-4'}`}>\n {/* Color variants */}\n {product.variants && product.variants.length > 0 && (\n <div className=\"flex gap-1\">\n {product.variants.slice(0, 5).map((v) => (\n <span\n key={v.id}\n title={v.label}\n className=\"w-4 h-4 rounded-full border border-gray-300 shrink-0\"\n style={{ backgroundColor: v.color ?? '#ccc' }}\n />\n ))}\n {product.variants.length > 5 && (\n <span className=\"text-xs text-gray-400\">+{product.variants.length - 5}</span>\n )}\n </div>\n )}\n\n {/* Name */}\n <h3\n className={`font-medium text-gray-900 leading-snug line-clamp-2 group-hover:text-primary-600 transition-colors ${\n size === 'compact' ? 'text-xs' : 'text-sm'\n }`}\n >\n {product.name}\n </h3>\n\n {/* Rating */}\n {product.rating !== undefined && (\n <StarRating value={product.rating} count={product.reviewCount} />\n )}\n\n {/* Price */}\n <div className=\"flex items-baseline gap-2 mt-auto pt-1\">\n <span\n className={`font-bold text-gray-900 ${size === 'compact' ? 'text-base' : 'text-lg'}`}\n >\n {formatPrice(product.price, product.currency)}\n </span>\n {hasDiscount && (\n <span className=\"text-sm text-gray-400 line-through\">\n {formatPrice(product.originalPrice!, product.currency)}\n </span>\n )}\n </div>\n </div>\n </article>\n )\n}\n","import type { ReactNode } from 'react'\nimport { ProductCard } from '../ProductCard/ProductCard'\nimport type { ProductCardProduct, ProductCardProps } from '../ProductCard/ProductCard'\nimport { Pagination } from '../common/Pagination/Pagination'\nimport { Select } from '../common/Select/Select'\n\nexport type GridColumns = 2 | 3 | 4 | 5\n\nexport interface SortOption {\n value: string\n label: string\n}\n\nexport interface ProductGridProps {\n products: ProductCardProduct[]\n /** Total products (for pagination) */\n totalCount?: number\n /** Current page */\n page?: number\n onPageChange?: (page: number) => void\n /** Products per page */\n perPage?: number\n /** Column count */\n columns?: GridColumns\n /** Sort options */\n sortOptions?: SortOption[]\n selectedSort?: string\n onSortChange?: (value: string) => void\n /** Active filters summary */\n activeFilters?: string[]\n onRemoveFilter?: (filter: string) => void\n onClearFilters?: () => void\n /** Loading skeleton */\n loading?: boolean\n /** Empty state slot */\n emptyState?: ReactNode\n /** ProductCard passthrough props */\n onAddToCart?: ProductCardProps['onAddToCart']\n onWishlistToggle?: ProductCardProps['onWishlistToggle']\n onProductClick?: ProductCardProps['onProductClick']\n wishlisted?: string[]\n className?: string\n}\n\nconst colClasses: Record<GridColumns, string> = {\n 2: 'grid-cols-2',\n 3: 'grid-cols-2 md:grid-cols-3',\n 4: 'grid-cols-2 sm:grid-cols-3 lg:grid-cols-4',\n 5: 'grid-cols-2 sm:grid-cols-3 md:grid-cols-4 lg:grid-cols-5',\n}\n\nconst DEFAULT_SORT_OPTIONS: SortOption[] = [\n { value: 'newest', label: 'Nejnovější' },\n { value: 'price-asc', label: 'Cena: od nejnižší' },\n { value: 'price-desc', label: 'Cena: od nejvyšší' },\n { value: 'rating', label: 'Hodnocení' },\n { value: 'bestseller', label: 'Bestsellery' },\n]\n\nfunction SkeletonCard() {\n return (\n <div className=\"rounded-xl border border-gray-100 overflow-hidden animate-pulse\">\n <div className=\"aspect-4/3 bg-gray-200\" />\n <div className=\"p-4 space-y-2\">\n <div className=\"h-3 bg-gray-200 rounded w-3/4\" />\n <div className=\"h-3 bg-gray-200 rounded w-1/2\" />\n <div className=\"h-5 bg-gray-200 rounded w-1/3 mt-2\" />\n </div>\n </div>\n )\n}\n\nexport function ProductGrid({\n products,\n totalCount,\n page = 1,\n onPageChange,\n perPage = 20,\n columns = 4,\n sortOptions = DEFAULT_SORT_OPTIONS,\n selectedSort,\n onSortChange,\n activeFilters = [],\n onRemoveFilter,\n onClearFilters,\n loading = false,\n emptyState,\n onAddToCart,\n onWishlistToggle,\n onProductClick,\n wishlisted = [],\n className = '',\n}: ProductGridProps) {\n const totalPages = totalCount ? Math.ceil(totalCount / perPage) : undefined\n const cardSize = columns >= 5 ? 'compact' : 'default'\n\n return (\n <div className={['w-full', className].filter(Boolean).join(' ')}>\n {/* Toolbar */}\n <div className=\"flex flex-wrap items-center justify-between gap-3 mb-4\">\n {/* Left: count + active filters */}\n <div className=\"flex flex-wrap items-center gap-2\">\n {totalCount !== undefined && (\n <span className=\"text-sm text-gray-500\">\n <span className=\"font-semibold text-gray-900\">{totalCount}</span> produktů\n </span>\n )}\n {activeFilters.map((f) => (\n <span\n key={f}\n className=\"inline-flex items-center gap-1 text-xs bg-primary-50 text-primary-700 border border-primary-200 rounded-full px-2.5 py-1\"\n >\n {f}\n <button\n onClick={() => onRemoveFilter?.(f)}\n aria-label={`Remove filter ${f}`}\n className=\"hover:text-primary-900 transition-colors\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" strokeWidth={2} stroke=\"currentColor\" className=\"w-3 h-3\">\n <path strokeLinecap=\"round\" strokeLinejoin=\"round\" d=\"M6 18L18 6M6 6l12 12\" />\n </svg>\n </button>\n </span>\n ))}\n {activeFilters.length > 1 && (\n <button\n onClick={onClearFilters}\n className=\"text-xs text-gray-400 hover:text-gray-600 underline underline-offset-2 transition-colors\"\n >\n Zrušit vše\n </button>\n )}\n </div>\n\n {/* Right: sort */}\n <Select\n options={sortOptions}\n value={selectedSort ?? ''}\n onChange={(e) => onSortChange?.(e.target.value)}\n aria-label=\"Sort products\"\n className=\"text-sm\"\n />\n </div>\n\n {/* Grid */}\n {loading ? (\n <div className={`grid gap-4 ${colClasses[columns]}`}>\n {Array.from({ length: perPage > 12 ? 12 : perPage }).map((_, i) => (\n <SkeletonCard key={i} />\n ))}\n </div>\n ) : products.length === 0 ? (\n <div className=\"py-16 text-center\">\n {emptyState ?? (\n <div className=\"space-y-2\">\n <p className=\"text-4xl\">🔍</p>\n <p className=\"font-semibold text-gray-900\">Žádné produkty nenalezeny</p>\n <p className=\"text-sm text-gray-500\">Zkuste upravit filtry nebo hledat jinak.</p>\n {activeFilters.length > 0 && (\n <button\n onClick={onClearFilters}\n className=\"mt-3 text-sm text-primary-600 hover:underline\"\n >\n Zrušit všechny filtry\n </button>\n )}\n </div>\n )}\n </div>\n ) : (\n <div className={`grid gap-4 ${colClasses[columns]}`}>\n {products.map((product) => (\n <ProductCard\n key={product.id}\n product={product}\n size={cardSize}\n onAddToCart={onAddToCart}\n onWishlistToggle={onWishlistToggle}\n onProductClick={onProductClick}\n isWishlisted={wishlisted.includes(product.id)}\n />\n ))}\n </div>\n )}\n\n {/* Pagination */}\n {totalPages && totalPages > 1 && onPageChange && (\n <div className=\"flex justify-center mt-8\">\n <Pagination\n page={page}\n totalPages={totalPages}\n onPageChange={onPageChange}\n />\n </div>\n )}\n </div>\n )\n}\n","import { useState, useEffect, useRef } from 'react';\nimport type { ReactNode, HTMLAttributes } from 'react';\nimport clx from 'classnames';\nimport { CarouselBtn } from '../Carousel';\n\nexport interface ProductCarouselProps extends HTMLAttributes<HTMLDivElement> {\n children: ReactNode;\n /** Gap between cards in px */\n gap?: number;\n /** Fraction of viewport width to scroll per arrow click (0–1) */\n scrollStep?: number;\n}\n\nexport function ProductCarousel({\n children,\n gap = 16,\n scrollStep = 0.8,\n className,\n ...props\n}: ProductCarouselProps) {\n const viewportRef = useRef<HTMLDivElement>(null);\n const [canPrev, setCanPrev] = useState(false);\n const [canNext, setCanNext] = useState(false);\n\n const updateArrows = () => {\n const el = viewportRef.current;\n if (!el) return;\n setCanPrev(el.scrollLeft > 1);\n setCanNext(el.scrollLeft < el.scrollWidth - el.clientWidth - 1);\n };\n\n useEffect(() => {\n updateArrows();\n const el = viewportRef.current;\n if (!el) return;\n el.addEventListener('scroll', updateArrows, { passive: true });\n const observer = new ResizeObserver(updateArrows);\n observer.observe(el);\n return () => {\n el.removeEventListener('scroll', updateArrows);\n observer.disconnect();\n };\n }, []);\n\n const scrollBy = (dir: 1 | -1) => {\n const el = viewportRef.current;\n if (!el) return;\n el.scrollBy({\n left: dir * el.clientWidth * scrollStep,\n behavior: 'smooth',\n });\n };\n\n return (\n <div className={clx('carousel-wrapper', className)} {...props}>\n <div ref={viewportRef} className=\"product-carousel-viewport\">\n <div className=\"product-carousel-track\" style={{ gap: `${gap}px` }}>\n {children}\n </div>\n </div>\n\n {canPrev && <CarouselBtn direction=\"prev\" onClick={() => scrollBy(-1)} />}\n {canNext && <CarouselBtn direction=\"next\" onClick={() => scrollBy(1)} />}\n </div>\n );\n}\n","import type { ReactNode, CSSProperties } from 'react'\nimport { Button } from '../common/Button/Button'\nimport type { ButtonProps } from '../common/Button/Button'\n\n// ─── Types ────────────────────────────────────────────────────────────────────\n\ntype CtaAlign = 'left' | 'center' | 'right'\ntype CtaSize = 'sm' | 'md' | 'lg' | 'xl'\ntype CtaVariant = 'default' | 'primary' | 'dark' | 'gradient' | 'outline' | 'image'\ntype CtaLayout = 'stacked' | 'inline'\n\nexport interface CtaAction {\n label: string\n onClick?: () => void\n href?: string\n variant?: ButtonProps['variant']\n size?: ButtonProps['size']\n}\n\nexport interface CallToActionProps {\n // Content\n eyebrow?: string\n title: string\n description?: string\n actions?: CtaAction[]\n\n // Layout\n align?: CtaAlign\n layout?: CtaLayout\n size?: CtaSize\n\n // Visual\n variant?: CtaVariant\n /** Custom background colour or gradient CSS value (overrides variant background) */\n background?: string\n /** For variant=\"image\": URL of background image */\n backgroundImage?: string\n /** Extra decorative slot — e.g. an illustration, icon or badge */\n media?: ReactNode\n\n // Misc\n className?: string\n style?: CSSProperties\n}\n\n// ─── Config maps ─────────────────────────────────────────────────────────────\n\nconst variantClasses: Record<CtaVariant, string> = {\n default: 'bg-gray-50 border border-gray-200',\n primary: 'bg-primary-600',\n dark: 'bg-gray-900',\n gradient: 'bg-linear-to-br from-primary-600 via-primary-700 to-violet-700',\n outline: 'bg-white border-2 border-primary-600',\n image: 'relative overflow-hidden', // bg applied inline via style\n}\n\nconst variantTextClasses: Record<CtaVariant, { eyebrow: string; title: string; description: string }> = {\n default: { eyebrow: 'text-primary-600', title: 'text-gray-900', description: 'text-gray-600' },\n primary: { eyebrow: 'text-primary-100', title: 'text-white', description: 'text-primary-100' },\n dark: { eyebrow: 'text-primary-400', title: 'text-white', description: 'text-gray-400' },\n gradient: { eyebrow: 'text-primary-200', title: 'text-white', description: 'text-primary-100' },\n outline: { eyebrow: 'text-primary-600', title: 'text-gray-900', description: 'text-gray-600' },\n image: { eyebrow: 'text-white/70', title: 'text-white', description: 'text-white/80' },\n}\n\nconst sizeClasses: Record<CtaSize, { wrapper: string; title: string; description: string; eyebrow: string }> = {\n sm: { wrapper: 'px-6 py-6 rounded-xl', title: 'text-xl font-bold', description: 'text-sm', eyebrow: 'text-xs' },\n md: { wrapper: 'px-8 py-10 rounded-2xl', title: 'text-2xl font-bold', description: 'text-base', eyebrow: 'text-xs' },\n lg: { wrapper: 'px-10 py-14 rounded-2xl', title: 'text-3xl font-bold', description: 'text-lg', eyebrow: 'text-sm' },\n xl: { wrapper: 'px-12 py-20 rounded-3xl', title: 'text-4xl font-extrabold leading-tight', description: 'text-xl', eyebrow: 'text-sm' },\n}\n\nconst alignClasses: Record<CtaAlign, { wrapper: string; actions: string }> = {\n left: { wrapper: 'items-start text-left', actions: 'justify-start' },\n center: { wrapper: 'items-center text-center', actions: 'justify-center' },\n right: { wrapper: 'items-end text-right', actions: 'justify-end' },\n}\n\n// ─── Component ───────────────────────────────────────────────────────────────\n\nexport function CallToAction({\n eyebrow,\n title,\n description,\n actions = [],\n align = 'center',\n layout = 'stacked',\n size = 'md',\n variant = 'default',\n background,\n backgroundImage,\n media,\n className = '',\n style,\n}: CallToActionProps) {\n const textColors = variantTextClasses[variant]\n const sizes = sizeClasses[size]\n const alignment = alignClasses[align]\n const isInline = layout === 'inline'\n\n const inlineStyle: CSSProperties = {\n ...(background ? { background } : {}),\n ...(backgroundImage ? { backgroundImage: `url(${backgroundImage})`, backgroundSize: 'cover', backgroundPosition: 'center' } : {}),\n ...style,\n }\n\n return (\n <div\n className={[\n 'w-full',\n variantClasses[variant],\n sizes.wrapper,\n className,\n ].filter(Boolean).join(' ')}\n style={Object.keys(inlineStyle).length ? inlineStyle : undefined}\n >\n {/* Image overlay */}\n {(variant === 'image' || backgroundImage) && (\n <div className=\"absolute inset-0 bg-black/50\" />\n )}\n\n <div className={`relative ${isInline ? 'flex flex-wrap items-center justify-between gap-6' : `flex flex-col gap-4 ${alignment.wrapper}`}`}>\n\n {/* Text block */}\n <div className={`flex flex-col gap-2 ${isInline ? 'flex-1 min-w-0' : alignment.wrapper}`}>\n {eyebrow && (\n <p className={`font-semibold uppercase tracking-widest ${sizes.eyebrow} ${textColors.eyebrow}`}>\n {eyebrow}\n </p>\n )}\n <h2 className={`${sizes.title} ${textColors.title}`}>\n {title}\n </h2>\n {description && (\n <p className={`max-w-2xl ${sizes.description} ${textColors.description}`}>\n {description}\n </p>\n )}\n </div>\n\n {/* Media slot */}\n {media && !isInline && (\n <div className=\"mt-2\">{media}</div>\n )}\n\n {/* Actions */}\n {actions.length > 0 && (\n <div className={`flex flex-wrap gap-3 ${isInline ? 'shrink-0' : alignment.actions}`}>\n {actions.map((action, i) => {\n const btn = (\n <Button\n key={i}\n variant={action.variant ?? (i === 0 ? resolveDefaultPrimaryVariant(variant) : 'outline')}\n size={action.size ?? (size === 'sm' ? 'sm' : size === 'xl' ? 'lg' : 'md')}\n onClick={action.onClick}\n >\n {action.label}\n </Button>\n )\n return action.href ? (\n <a key={i} href={action.href} className=\"contents\">{btn}</a>\n ) : btn\n })}\n </div>\n )}\n </div>\n </div>\n )\n}\n\n/** Pick a sensible default button variant that contrasts with the CTA background */\nfunction resolveDefaultPrimaryVariant(ctaVariant: CtaVariant): ButtonProps['variant'] {\n if (ctaVariant === 'default' || ctaVariant === 'outline') return 'primary'\n return 'secondary' // white-ish on dark/coloured backgrounds\n}\n","import type { ReactNode } from 'react';\nimport { Container } from '../common/Container';\n\n// ─── Types ────────────────────────────────────────────────────────────────────\n\nexport interface FooterContact {\n icon?: 'phone' | 'email' | 'address' | 'hours' | ReactNode;\n label: string;\n value: string;\n href?: string;\n}\n\nexport interface FooterLink {\n label: string;\n href?: string;\n onClick?: () => void;\n}\n\nexport interface FooterLinkGroup {\n heading: string;\n links: FooterLink[];\n}\n\nexport interface FooterSocialLink {\n label: string;\n href?: string;\n icon: 'facebook' | 'instagram' | 'twitter' | 'youtube' | 'tiktok' | ReactNode;\n}\n\nexport interface FooterProps {\n // Branding\n logo?: ReactNode;\n tagline?: string;\n\n // Contact section\n contactHeading?: string;\n contacts?: FooterContact[];\n\n // Links section\n linkGroups?: FooterLinkGroup[];\n\n // Social\n socialLinks?: FooterSocialLink[];\n\n // Bottom bar\n copyright?: string;\n bottomLinks?: FooterLink[];\n\n className?: string;\n}\n\n// ─── Icons ────────────────────────────────────────────────────────────────────\n\nfunction PhoneIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-4 h-4 shrink-0\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M2.25 6.75c0 8.284 6.716 15 15 15h2.25a2.25 2.25 0 002.25-2.25v-1.372c0-.516-.351-.966-.852-1.091l-4.423-1.106c-.44-.11-.902.055-1.173.417l-.97 1.293c-.282.376-.769.542-1.21.38a12.035 12.035 0 01-7.143-7.143c-.162-.441.004-.928.38-1.21l1.293-.97c.363-.271.527-.734.417-1.173L6.963 3.102a1.125 1.125 0 00-1.091-.852H4.5A2.25 2.25 0 002.25 4.5v2.25z\"\n />\n </svg>\n );\n}\n\nfunction EmailIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-4 h-4 shrink-0\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M21.75 6.75v10.5a2.25 2.25 0 01-2.25 2.25h-15a2.25 2.25 0 01-2.25-2.25V6.75m19.5 0A2.25 2.25 0 0019.5 4.5h-15a2.25 2.25 0 00-2.25 2.25m19.5 0v.243a2.25 2.25 0 01-1.07 1.916l-7.5 4.615a2.25 2.25 0 01-2.36 0L3.32 8.91a2.25 2.25 0 01-1.07-1.916V6.75\"\n />\n </svg>\n );\n}\n\nfunction AddressIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-4 h-4 shrink-0\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M15 10.5a3 3 0 11-6 0 3 3 0 016 0z\"\n />\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M19.5 10.5c0 7.142-7.5 11.25-7.5 11.25S4.5 17.642 4.5 10.5a7.5 7.5 0 1115 0z\"\n />\n </svg>\n );\n}\n\nfunction HoursIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n strokeWidth={1.5}\n stroke=\"currentColor\"\n className=\"w-4 h-4 shrink-0\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n d=\"M12 6v6h4.5m4.5 0a9 9 0 11-18 0 9 9 0 0118 0z\"\n />\n </svg>\n );\n}\n\nfunction FacebookIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path d=\"M24 12.073C24 5.405 18.627 0 12 0S0 5.405 0 12.073C0 18.1 4.388 23.094 10.125 24v-8.437H7.078v-3.49h3.047V9.41c0-3.025 1.792-4.697 4.533-4.697 1.312 0 2.686.236 2.686.236v2.97h-1.513c-1.491 0-1.956.93-1.956 1.886v2.267h3.328l-.532 3.49h-2.796V24C19.612 23.094 24 18.1 24 12.073z\" />\n </svg>\n );\n}\n\nfunction InstagramIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path d=\"M12 2.163c3.204 0 3.584.012 4.85.07 3.252.148 4.771 1.691 4.919 4.919.058 1.265.069 1.645.069 4.849 0 3.205-.012 3.584-.069 4.849-.149 3.225-1.664 4.771-4.919 4.919-1.266.058-1.644.07-4.85.07-3.204 0-3.584-.012-4.849-.07-3.26-.149-4.771-1.699-4.919-4.92-.058-1.265-.07-1.644-.07-4.849 0-3.204.013-3.583.07-4.849.149-3.227 1.664-4.771 4.919-4.919 1.266-.057 1.645-.069 4.849-.069zm0-2.163c-3.259 0-3.667.014-4.947.072-4.358.2-6.78 2.618-6.98 6.98-.059 1.281-.073 1.689-.073 4.948 0 3.259.014 3.668.072 4.948.2 4.358 2.618 6.78 6.98 6.98 1.281.058 1.689.072 4.948.072 3.259 0 3.668-.014 4.948-.072 4.354-.2 6.782-2.618 6.979-6.98.059-1.28.073-1.689.073-4.948 0-3.259-.014-3.667-.072-4.947-.196-4.354-2.617-6.78-6.979-6.98-1.281-.059-1.69-.073-4.949-.073zm0 5.838a6.162 6.162 0 100 12.324 6.162 6.162 0 000-12.324zM12 16a4 4 0 110-8 4 4 0 010 8zm6.406-11.845a1.44 1.44 0 100 2.881 1.44 1.44 0 000-2.881z\" />\n </svg>\n );\n}\n\nfunction TwitterIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path d=\"M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z\" />\n </svg>\n );\n}\n\nfunction YoutubeIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path d=\"M23.498 6.186a3.016 3.016 0 00-2.122-2.136C19.505 3.545 12 3.545 12 3.545s-7.505 0-9.377.505A3.017 3.017 0 00.502 6.186C0 8.07 0 12 0 12s0 3.93.502 5.814a3.016 3.016 0 002.122 2.136c1.871.505 9.376.505 9.376.505s7.505 0 9.377-.505a3.015 3.015 0 002.122-2.136C24 15.93 24 12 24 12s0-3.93-.502-5.814zM9.545 15.568V8.432L15.818 12l-6.273 3.568z\" />\n </svg>\n );\n}\n\nfunction TiktokIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className=\"w-4 h-4\"\n >\n <path d=\"M19.59 6.69a4.83 4.83 0 01-3.77-4.25V2h-3.45v13.67a2.89 2.89 0 01-2.88 2.5 2.89 2.89 0 01-2.89-2.89 2.89 2.89 0 012.89-2.89c.28 0 .54.04.79.1V9.01a6.33 6.33 0 00-.79-.05 6.34 6.34 0 00-6.34 6.34 6.34 6.34 0 006.34 6.34 6.34 6.34 0 006.33-6.34V8.69a8.18 8.18 0 004.78 1.52V6.76a4.85 4.85 0 01-1.01-.07z\" />\n </svg>\n );\n}\n\nconst SOCIAL_ICONS = {\n facebook: FacebookIcon,\n instagram: InstagramIcon,\n twitter: TwitterIcon,\n youtube: YoutubeIcon,\n tiktok: TiktokIcon,\n};\nconst CONTACT_ICONS = {\n phone: PhoneIcon,\n email: EmailIcon,\n address: AddressIcon,\n hours: HoursIcon,\n};\n\nfunction resolveContactIcon(icon: FooterContact['icon']) {\n if (!icon) return null;\n if (typeof icon === 'string') {\n const Icon = CONTACT_ICONS[icon as keyof typeof CONTACT_ICONS];\n return Icon ? <Icon /> : null;\n }\n return icon;\n}\n\nfunction resolveSocialIcon(icon: FooterSocialLink['icon']) {\n if (typeof icon === 'string') {\n const Icon = SOCIAL_ICONS[icon as keyof typeof SOCIAL_ICONS];\n return Icon ? <Icon /> : null;\n }\n return icon;\n}\n\n// ─── Component ────────────────────────────────────────────────────────────────\n\nexport function Footer({\n logo,\n tagline,\n contactHeading = 'Kontakty',\n contacts = [],\n linkGroups = [],\n socialLinks = [],\n copyright,\n bottomLinks = [],\n className = '',\n}: FooterProps) {\n const year = new Date().getFullYear();\n\n return (\n <footer\n className={['bg-gray-900 text-gray-300', className]\n .filter(Boolean)\n .join(' ')}\n >\n <Container>\n {/* ── Main section ───────────────────────────────────────────────────── */}\n <div className=\"max-w-7xl mx-auto px-4 py-12 grid grid-cols-1 md:grid-cols-2 gap-10 lg:gap-16\">\n {/* ── Left: Contact section ──────────────────────────────────────── */}\n <div className=\"flex flex-col gap-6\">\n {/* Logo + tagline */}\n <div>\n {logo ? (\n <div className=\"mb-3\">{logo}</div>\n ) : (\n <span className=\"text-xl font-bold text-white tracking-tight mb-3 block\">\n shopito\n </span>\n )}\n {tagline && (\n <p className=\"text-sm text-gray-400 max-w-xs\">{tagline}</p>\n )}\n </div>\n\n {/* Contacts */}\n {contacts.length > 0 && (\n <div>\n <h3 className=\"text-xs font-semibold uppercase tracking-widest text-gray-500 mb-3\">\n {contactHeading}\n </h3>\n <ul className=\"space-y-3\">\n {contacts.map((c, i) => {\n const icon = resolveContactIcon(c.icon);\n const inner = (\n <div className=\"flex items-start gap-2.5\">\n {icon && (\n <span className=\"mt-0.5 text-primary-400\">\n {icon}\n </span>\n )}\n <div>\n <p className=\"text-xs text-gray-500 leading-none mb-0.5\">\n {c.label}\n </p>\n <p\n className={`text-sm text-gray-200 ${c.href ? 'hover:text-white transition-colors' : ''}`}\n >\n {c.value}\n </p>\n </div>\n </div>\n );\n\n return (\n <li key={i}>\n {c.href ? <a href={c.href}>{inner}</a> : inner}\n </li>\n );\n })}\n </ul>\n </div>\n )}\n\n {/* Social links */}\n {socialLinks.length > 0 && (\n <div className=\"flex gap-2 flex-wrap\">\n {socialLinks.map((s, i) => (\n <a\n key={i}\n href={s.href}\n aria-label={s.label}\n className=\"w-8 h-8 flex items-center justify-center rounded-lg bg-gray-800 text-gray-400 hover:bg-primary-600 hover:text-white transition-colors\"\n >\n {resolveSocialIcon(s.icon)}\n </a>\n ))}\n </div>\n )}\n </div>\n\n {/* ── Right: Link groups ─────────────────────────────────────────── */}\n {linkGroups.length > 0 && (\n <div\n className={`grid gap-8 ${linkGroups.length === 1 ? 'grid-cols-1' : linkGroups.length === 2 ? 'grid-cols-2' : 'grid-cols-2 sm:grid-cols-3'}`}\n >\n {linkGroups.map((group, gi) => (\n <div key={gi}>\n <h3 className=\"text-xs font-semibold uppercase tracking-widest text-gray-500 mb-3\">\n {group.heading}\n </h3>\n <ul className=\"space-y-2\">\n {group.links.map((link, li) => (\n <li key={li}>\n {link.href ? (\n <a\n href={link.href}\n className=\"text-sm text-gray-400 hover:text-white transition-colors\"\n >\n {link.label}\n </a>\n ) : (\n <button\n onClick={link.onClick}\n className=\"text-sm text-gray-400 hover:text-white transition-colors text-left\"\n >\n {link.label}\n </button>\n )}\n </li>\n ))}\n </ul>\n </div>\n ))}\n </div>\n )}\n </div>\n\n {/* ── Bottom bar ─────────────────────────────────────────────────────── */}\n <div className=\"border-t border-gray-800\">\n <div className=\"max-w-7xl mx-auto px-4 py-4 flex flex-wrap items-center justify-between gap-3\">\n <p className=\"text-xs text-gray-500\">\n {copyright ?? `© ${year} Shopito. Všechna práva vyhrazena.`}\n </p>\n {bottomLinks.length > 0 && (\n <nav className=\"flex flex-wrap gap-4\">\n {bottomLinks.map((link, i) =>\n link.href ? (\n <a\n key={i}\n href={link.href}\n className=\"text-xs text-gray-500 hover:text-gray-300 transition-colors\"\n >\n {link.label}\n </a>\n ) : (\n <button\n key={i}\n onClick={link.onClick}\n className=\"text-xs text-gray-500 hover:text-gray-300 transition-colors\"\n >\n {link.label}\n </button>\n ),\n )}\n </nav>\n )}\n </div>\n </div>\n </Container>\n </footer>\n );\n}\n"],"x_google_ignoreList":[2,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149],"mappings":"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"}