@primereact/headless 11.0.0-alpha.5 → 11.0.0-alpha.7

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.
Files changed (57) hide show
  1. package/carousel/index.d.ts +2 -0
  2. package/carousel/index.mjs +2 -0
  3. package/carousel/index.mjs.map +1 -0
  4. package/carousel/useCarousel.d.ts +23 -0
  5. package/carousel/useCarousel.props.d.ts +2 -0
  6. package/carousel/useCarousel.test.d.ts +0 -0
  7. package/dataview/index.d.ts +2 -0
  8. package/dataview/index.mjs +2 -0
  9. package/dataview/index.mjs.map +1 -0
  10. package/dataview/useDataView.d.ts +3 -0
  11. package/dataview/useDataView.props.d.ts +2 -0
  12. package/dataview/useDataView.test.d.ts +0 -0
  13. package/fileupload/index.d.ts +2 -0
  14. package/fileupload/index.mjs +2 -0
  15. package/fileupload/index.mjs.map +1 -0
  16. package/fileupload/useFileUpload.d.ts +26 -0
  17. package/fileupload/useFileUpload.props.d.ts +2 -0
  18. package/fileupload/useFileUpload.test.d.ts +0 -0
  19. package/gallery/index.d.ts +2 -0
  20. package/gallery/index.mjs +2 -0
  21. package/gallery/index.mjs.map +1 -0
  22. package/gallery/item/index.d.ts +2 -0
  23. package/gallery/item/index.mjs +2 -0
  24. package/gallery/item/index.mjs.map +1 -0
  25. package/gallery/item/useGalleryItem.d.ts +45 -0
  26. package/gallery/item/useGalleryItem.props.d.ts +2 -0
  27. package/gallery/useGallery.d.ts +37 -0
  28. package/gallery/useGallery.props.d.ts +2 -0
  29. package/gallery/useGallery.test.d.ts +0 -0
  30. package/inputnumber/index.d.ts +2 -0
  31. package/inputnumber/index.mjs +2 -0
  32. package/inputnumber/index.mjs.map +1 -0
  33. package/inputnumber/useInputNumber.d.ts +24 -0
  34. package/inputnumber/useInputNumber.props.d.ts +2 -0
  35. package/inputnumber/useInputNumber.test.d.ts +0 -0
  36. package/package.json +4 -4
  37. package/speeddial/index.mjs +1 -1
  38. package/speeddial/index.mjs.map +1 -1
  39. package/speeddial/useSpeedDial.d.ts +2 -1
  40. package/toast/index.css +2 -0
  41. package/toast/index.css.map +1 -0
  42. package/toast/index.d.ts +2 -0
  43. package/toast/index.mjs +2 -0
  44. package/toast/index.mjs.map +1 -0
  45. package/toast/item/index.css +2 -0
  46. package/toast/item/index.css.map +1 -0
  47. package/toast/item/index.d.ts +2 -0
  48. package/toast/item/index.mjs +2 -0
  49. package/toast/item/index.mjs.map +1 -0
  50. package/toast/item/useToastItem.d.ts +21 -0
  51. package/toast/item/useToastItem.props.d.ts +2 -0
  52. package/toast/item/useToastItem.test.d.ts +0 -0
  53. package/toast/useToast.d.ts +18 -0
  54. package/toast/useToast.props.d.ts +2 -0
  55. package/toast/useToast.test.d.ts +0 -0
  56. package/tooltip/index.mjs +1 -1
  57. package/tooltip/index.mjs.map +1 -1
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/gallery/item/useGalleryItem.tsx","../../../../primereact/src/gallery/Gallery.tsx","../../../../primereact/src/base/index.ts","../../../../primereact/src/gallery/Gallery.context.ts","../../../../primereact/src/gallery/Gallery.props.ts","../../../../primereact/src/gallery/backdrop/GalleryBackdrop.tsx","../../../../primereact/src/gallery/backdrop/GalleryBackdrop.props.ts","../../../../primereact/src/gallery/content/GalleryContent.tsx","../../../../primereact/src/gallery/content/GalleryContent.props.ts","../../../../primereact/src/gallery/item/GalleryItem.tsx","../../../../primereact/src/gallery/item/GalleryItem.context.ts","../../../../primereact/src/gallery/item/GalleryItem.props.ts","../../../../primereact/src/gallery/next/GalleryNext.tsx","../../../../primereact/src/gallery/next/GalleryNext.props.ts","../../../../primereact/src/gallery/prev/GalleryPrev.tsx","../../../../primereact/src/gallery/prev/GalleryPrev.props.ts","../../../../primereact/src/gallery/thumbnail/GalleryThumbnail.tsx","../../../../primereact/src/carousel/Carousel.tsx","../../../../primereact/src/carousel/Carousel.context.ts","../../../../primereact/src/carousel/Carousel.props.ts","../../../../primereact/src/carousel/content/CarouselContent.tsx","../../../../primereact/src/carousel/content/CarouselContent.props.ts","../../../../primereact/src/carousel/indicator/CarouselIndicator.tsx","../../../../primereact/src/carousel/indicator/CarouselIndicator.props.ts","../../../../primereact/src/carousel/indicators/CarouselIndicators.tsx","../../../../primereact/src/carousel/indicators/CarouselIndicators.props.ts","../../../../primereact/src/carousel/item/CarouselItem.tsx","../../../../primereact/src/carousel/item/CarouselItem.props.ts","../../../../primereact/src/carousel/next/CarouselNext.tsx","../../../../primereact/src/carousel/next/CarouselNext.props.ts","../../../../primereact/src/carousel/prev/CarouselPrev.tsx","../../../../primereact/src/carousel/prev/CarouselPrev.props.ts","../../../../primereact/src/gallery/thumbnail/GalleryThumbnail.props.ts","../../../../primereact/src/gallery/thumbnailcontent/GalleryThumbnailContent.tsx","../../../../primereact/src/gallery/thumbnailcontent/GalleryThumbnailContent.props.ts","../../../../primereact/src/gallery/thumbnailitem/GalleryThumbnailItem.tsx","../../../../primereact/src/gallery/thumbnailitem/GalleryThumbnailItem.props.ts","../../../../primereact/src/gallery/toolbar/GalleryToolbar.tsx","../../../../primereact/src/gallery/toolbar/GalleryToolbar.props.ts","../../../../primereact/src/gallery/toolbaritem/GalleryToolbarItem.tsx","../../../../primereact/src/gallery/toolbaritem/GalleryToolbarItem.props.ts","../../../src/gallery/item/useGalleryItem.props.ts"],"sourcesContent":["import { withHeadless } from '@primereact/core/headless';\nimport { useGalleryContext } from 'primereact/gallery';\nimport * as React from 'react';\nimport { defaultItemProps } from './useGalleryItem.props';\n\nexport const useGalleryItem = withHeadless({\n name: 'useGalleryItem',\n defaultProps: defaultItemProps,\n setup: ({ props, elementRef }) => {\n const { normalScale = 1, zoomedScale = 3 } = props;\n\n const gallery = useGalleryContext();\n const [index, setIndex] = React.useState(-1);\n const [isActive, setIsActive] = React.useState(false);\n const [position, setPosition] = React.useState({ x: 0, y: 0 });\n const [scale, setScale] = React.useState(1);\n const [rotation, setRotation] = React.useState(0);\n const [flip, setFlip] = React.useState({ x: 1, y: 1 });\n\n const [isDragging, setIsDragging] = React.useState(false);\n const [dragStart, setDragStart] = React.useState({ x: 0, y: 0 });\n const [hasDragged, setHasDragged] = React.useState(false);\n\n const pointerDataRef = React.useRef<Map<number, { x: number; y: number }>>(new Map());\n const lastDistanceRef = React.useRef(0);\n\n const calculateItemSize = React.useCallback(() => {\n if (!gallery?.contentRef.current || !elementRef.current) return;\n\n const contentRect = gallery?.contentRef.current.getBoundingClientRect();\n\n const imageElement = elementRef.current.firstElementChild as HTMLImageElement;\n\n if (!imageElement) return;\n\n let naturalWidth = imageElement.naturalWidth || imageElement.offsetWidth;\n let naturalHeight = imageElement.naturalHeight || imageElement.offsetHeight;\n\n if (naturalWidth === 0 || naturalHeight === 0) return;\n\n const isRotated = Math.abs(rotation) % 180 === 90;\n\n if (isRotated) {\n [naturalWidth, naturalHeight] = [naturalHeight, naturalWidth];\n }\n\n const naturalAspectRatio = naturalWidth / naturalHeight;\n const contentAspectRatio = contentRect.width / contentRect.height;\n\n let targetWidth, targetHeight;\n\n if (naturalAspectRatio > contentAspectRatio) {\n targetWidth = Math.min(contentRect.width * 0.99, naturalWidth);\n targetHeight = targetWidth / naturalAspectRatio;\n } else {\n targetHeight = Math.min(contentRect.height * 0.99, naturalHeight);\n targetWidth = targetHeight * naturalAspectRatio;\n }\n\n if (isRotated) {\n imageElement.style.width = `${targetHeight}px`;\n imageElement.style.height = `${targetWidth}px`;\n elementRef.current.style.width = `${targetHeight > 0 ? targetHeight : 'auto'}px`;\n elementRef.current.style.height = `${targetWidth > 0 ? targetWidth : 'auto'}px`;\n } else {\n imageElement.style.width = `${targetWidth}px`;\n imageElement.style.height = `${targetHeight}px`;\n elementRef.current.style.width = `${targetWidth > 0 ? targetWidth : 'auto'}px`;\n elementRef.current.style.height = `${targetHeight > 0 ? targetHeight : 'auto'}px`;\n }\n\n elementRef.current.style.aspectRatio = `${naturalWidth / naturalHeight}`;\n }, [gallery?.contentRef, rotation]);\n\n const calculateConstraints = React.useCallback(\n (targetScale?: number) => {\n if (!gallery?.contentRef.current || !elementRef.current) return { minX: 0, maxX: 0, minY: 0, maxY: 0 };\n\n const contentRect = gallery?.contentRef.current.getBoundingClientRect();\n const scaleToUse = targetScale !== undefined ? targetScale : scale;\n\n const itemElement = elementRef.current.firstElementChild as HTMLElement;\n\n if (!itemElement) return { minX: 0, maxX: 0, minY: 0, maxY: 0 };\n\n let originalWidth = itemElement.offsetWidth;\n let originalHeight = itemElement.offsetHeight;\n\n const isRotated = Math.abs(rotation) % 180 === 90;\n\n if (isRotated) {\n [originalWidth, originalHeight] = [originalHeight, originalWidth];\n }\n\n const scaledWidth = originalWidth * scaleToUse;\n const scaledHeight = originalHeight * scaleToUse;\n\n const contentCenterX = contentRect.width / 2;\n const contentCenterY = contentRect.height / 2;\n\n const halfScaledWidth = scaledWidth / 2;\n const halfScaledHeight = scaledHeight / 2;\n\n const maxX = halfScaledWidth > contentCenterX ? halfScaledWidth - contentCenterX : 0;\n const minX = halfScaledWidth > contentCenterX ? -(halfScaledWidth - contentCenterX) : 0;\n\n const maxY = halfScaledHeight > contentCenterY ? halfScaledHeight - contentCenterY : 0;\n const minY = halfScaledHeight > contentCenterY ? -(halfScaledHeight - contentCenterY) : 0;\n\n return { minX, maxX, minY, maxY };\n },\n [gallery?.contentRef, scale, rotation]\n );\n\n const zoomIn = React.useCallback(() => {\n setScale(zoomedScale);\n\n const hiddenStyles = {\n visibility: 'hidden',\n opacity: 0,\n pointerEvents: 'none',\n userSelect: 'none',\n touchAction: 'none'\n };\n\n if (gallery?.toolbarRef.current) {\n Object.assign(gallery?.toolbarRef.current.style, hiddenStyles);\n }\n\n if (gallery?.thumbnailRef.current) {\n // @ts-expect-error - thumbnailRef may not have elementRef property\n Object.assign(gallery?.thumbnailRef.current.elementRef.current.style, hiddenStyles);\n }\n\n if (gallery?.prevRef.current) {\n Object.assign(gallery.prevRef.current.style, hiddenStyles);\n }\n\n if (gallery?.nextRef.current) {\n Object.assign(gallery.nextRef.current.style, hiddenStyles);\n }\n\n if (elementRef.current) {\n elementRef.current.style.cursor = 'zoom-out';\n elementRef.current.style.pointerEvents = 'auto';\n }\n }, [zoomedScale, gallery?.toolbarRef, gallery?.thumbnailRef, gallery?.prevRef, gallery?.nextRef]);\n\n const zoomOut = React.useCallback(() => {\n setScale(normalScale);\n setPosition({ x: 0, y: 0 });\n\n const resetStyles = {\n visibility: '',\n opacity: '',\n pointerEvents: '',\n userSelect: '',\n touchAction: ''\n };\n\n if (gallery?.toolbarRef.current) {\n Object.assign(gallery.toolbarRef.current.style, resetStyles);\n }\n\n if (gallery?.thumbnailRef.current) {\n // @ts-expect-error - thumbnailRef may not have elementRef property\n Object.assign(gallery.thumbnailRef.current.elementRef.current.style, resetStyles);\n }\n\n if (gallery?.prevRef.current) {\n Object.assign(gallery.prevRef.current.style, resetStyles);\n }\n\n if (gallery?.nextRef.current) {\n Object.assign(gallery.nextRef.current.style, resetStyles);\n }\n\n if (elementRef.current) {\n elementRef.current.style.cursor = 'zoom-in';\n elementRef.current.style.pointerEvents = 'auto';\n }\n }, [normalScale, gallery?.toolbarRef, gallery?.thumbnailRef, gallery?.prevRef, gallery?.nextRef]);\n\n const rotateLeft = () => {\n if (!elementRef.current) return;\n\n elementRef.current.style.transition = 'none';\n setRotation((prev) => prev - 90);\n setTimeout(() => {\n if (elementRef.current) {\n elementRef.current.style.transition = '';\n }\n }, 0);\n };\n\n const rotateRight = () => {\n if (!elementRef.current) return;\n\n elementRef.current.style.transition = 'none';\n setRotation((prev) => prev + 90);\n setTimeout(() => {\n if (elementRef.current) {\n elementRef.current.style.transition = '';\n }\n }, 0);\n };\n\n const flipX = () => {\n setFlip((prev) => ({ ...prev, x: Math.sign(prev.x) * -1 }));\n };\n\n const flipY = () => {\n setFlip((prev) => ({ ...prev, y: Math.sign(prev.y) * -1 }));\n };\n\n const download = () => {\n if (!elementRef.current) return;\n\n const imageElement = elementRef.current.querySelector('img') as HTMLImageElement;\n\n if (!imageElement || !imageElement.src) return;\n\n const link = document.createElement('a');\n\n link.href = imageElement.src;\n\n const urlParts = imageElement.src.split('/');\n const filename = urlParts[urlParts.length - 1] || 'image.jpg';\n\n link.download = filename;\n link.target = '_blank';\n\n document.body.appendChild(link);\n link.click();\n document.body.removeChild(link);\n };\n\n const handleClick = React.useCallback(\n (e: React.MouseEvent) => {\n if (hasDragged) {\n setHasDragged(false);\n\n return;\n }\n\n if (scale === normalScale) {\n if (elementRef.current) {\n const itemRect = elementRef.current.getBoundingClientRect();\n\n const itemCenterX = itemRect.width / 2;\n const itemCenterY = itemRect.height / 2;\n\n const clickX = e.clientX - itemRect.left;\n const clickY = e.clientY - itemRect.top;\n\n const offsetX = itemCenterX - clickX;\n const offsetY = itemCenterY - clickY;\n\n const zoomOffsetX = offsetX * (zoomedScale - 1);\n const zoomOffsetY = offsetY * (zoomedScale - 1);\n\n const constraints = calculateConstraints(zoomedScale);\n const constrainedX = Math.max(constraints.minX, Math.min(constraints.maxX, zoomOffsetX));\n const constrainedY = Math.max(constraints.minY, Math.min(constraints.maxY, zoomOffsetY));\n\n setPosition({ x: constrainedX, y: constrainedY });\n }\n\n zoomIn();\n } else {\n zoomOut();\n }\n },\n [hasDragged, normalScale, zoomedScale, calculateConstraints, scale, zoomIn, zoomOut]\n );\n const handleDragStart = React.useCallback((e: React.DragEvent<HTMLDivElement>) => {\n e.preventDefault();\n }, []);\n\n const handlePointerDown = React.useCallback(\n (e: React.PointerEvent) => {\n e.currentTarget.setPointerCapture(e.pointerId);\n pointerDataRef.current.set(e.pointerId, { x: e.clientX, y: e.clientY });\n\n if (scale > 1) {\n if (e.pointerType === 'mouse') {\n setIsDragging(true);\n setDragStart({ x: e.clientX - position.x, y: e.clientY - position.y });\n setHasDragged(false);\n } else if (e.pointerType === 'touch' && pointerDataRef.current.size === 1) {\n setIsDragging(true);\n setDragStart({ x: e.clientX - position.x, y: e.clientY - position.y });\n setHasDragged(false);\n lastDistanceRef.current = 0;\n }\n }\n\n if (e.pointerType === 'touch' && pointerDataRef.current.size === 1) {\n lastDistanceRef.current = 0;\n }\n },\n [scale, position]\n );\n\n const handlePointerMove = React.useCallback(\n (e: React.PointerEvent) => {\n if (!pointerDataRef.current.has(e.pointerId) || !elementRef.current) return;\n\n elementRef.current.style.transition = 'none';\n\n // Preserve cursor during move\n const currentCursor = elementRef.current.style.cursor;\n\n if (!currentCursor) {\n elementRef.current.style.cursor = scale > normalScale ? 'zoom-out' : 'zoom-in';\n }\n\n pointerDataRef.current.set(e.pointerId, { x: e.clientX, y: e.clientY });\n\n const pointers = Array.from(pointerDataRef.current.values());\n\n if (pointers.length === 2) {\n const [p1, p2] = pointers;\n const distance = Math.hypot(p2.x - p1.x, p2.y - p1.y);\n\n if (lastDistanceRef.current > 0) {\n const delta = (distance - lastDistanceRef.current) * 0.01;\n\n if (Math.abs(delta) > 0.01) {\n const newScale = scale === normalScale ? zoomedScale : normalScale;\n\n const constraints = calculateConstraints(newScale);\n const constrainedX = Math.max(constraints.minX, Math.min(constraints.maxX, position.x));\n const constrainedY = Math.max(constraints.minY, Math.min(constraints.maxY, position.y));\n\n setPosition({ x: constrainedX, y: constrainedY });\n\n setScale(newScale);\n }\n }\n\n lastDistanceRef.current = distance;\n } else if (pointers.length === 1 && isDragging) {\n const pointer = pointers[0];\n const newX = pointer.x - dragStart.x;\n const newY = pointer.y - dragStart.y;\n const constraints = calculateConstraints();\n\n const computedX = Math.max(constraints.minX, Math.min(constraints.maxX, newX));\n const computedY = Math.max(constraints.minY, Math.min(constraints.maxY, newY));\n\n setPosition({\n x: computedX,\n y: computedY\n });\n setHasDragged(true);\n }\n },\n [isDragging, dragStart, scale, normalScale, zoomedScale, position, calculateConstraints]\n );\n\n const handlePointerUp = React.useCallback((e: React.PointerEvent) => {\n if (!elementRef.current) return;\n\n elementRef.current.style.transition = '';\n // Restore proper cursor after interaction\n elementRef.current.style.cursor = scale > normalScale ? 'zoom-out' : 'zoom-in';\n e.currentTarget.releasePointerCapture(e.pointerId);\n pointerDataRef.current.delete(e.pointerId);\n\n if (pointerDataRef.current.size < 2) lastDistanceRef.current = 0;\n\n if (pointerDataRef.current.size === 0) {\n setIsDragging(false);\n }\n }, []);\n\n React.useEffect(() => {\n if (scale <= 1) {\n setPosition({ x: 0, y: 0 });\n }\n }, [scale]);\n\n React.useEffect(() => {\n if (gallery?.state.activeIndex === index && document.readyState === 'complete') {\n calculateItemSize();\n }\n }, [gallery?.state.activeIndex, index, calculateItemSize]);\n\n React.useEffect(() => {\n if (gallery?.state.activeIndex === index) {\n calculateItemSize();\n }\n }, [rotation, calculateItemSize, gallery?.state.activeIndex, index]);\n\n React.useEffect(() => {\n if (gallery?.state.activeIndex === index && gallery?.state.isFullscreen !== undefined) {\n calculateItemSize();\n }\n }, [gallery?.state.isFullscreen, calculateItemSize, gallery?.state.activeIndex, index]);\n\n React.useEffect(() => {\n const handleResize = () => {\n if (gallery?.state.activeIndex === index) {\n calculateItemSize();\n }\n };\n\n window.addEventListener('resize', handleResize);\n\n return () => window.removeEventListener('resize', handleResize);\n }, [gallery?.state.activeIndex, index, calculateItemSize]);\n\n React.useEffect(() => {\n if (gallery && elementRef.current) {\n const index = gallery.registerItem(elementRef.current as HTMLDivElement);\n\n setIndex(index);\n }\n }, [gallery]);\n\n React.useEffect(() => {\n const handleCustomEvent = (e: CustomEvent) => {\n if (e.detail?.action === 'zoom-in') {\n zoomIn();\n } else if (e.detail?.action === 'zoom-out') {\n zoomOut();\n } else if (e.detail?.action === 'rotate-left') {\n rotateLeft();\n } else if (e.detail?.action === 'rotate-right') {\n rotateRight();\n } else if (e.detail?.action === 'flip-x') {\n flipX();\n } else if (e.detail?.action === 'flip-y') {\n flipY();\n } else if (e.detail?.action === 'download') {\n download();\n }\n };\n\n const itemElement = elementRef.current;\n\n if (itemElement) {\n itemElement.addEventListener('gallery-zoom-in', handleCustomEvent as EventListener);\n itemElement.addEventListener('gallery-zoom-out', handleCustomEvent as EventListener);\n itemElement.addEventListener('gallery-rotate-left', handleCustomEvent as EventListener);\n itemElement.addEventListener('gallery-rotate-right', handleCustomEvent as EventListener);\n itemElement.addEventListener('gallery-flip-x', handleCustomEvent as EventListener);\n itemElement.addEventListener('gallery-flip-y', handleCustomEvent as EventListener);\n itemElement.addEventListener('gallery-download', handleCustomEvent as EventListener);\n }\n\n return () => {\n if (itemElement) {\n itemElement.removeEventListener('gallery-zoom-in', handleCustomEvent as EventListener);\n itemElement.removeEventListener('gallery-zoom-out', handleCustomEvent as EventListener);\n itemElement.removeEventListener('gallery-rotate-left', handleCustomEvent as EventListener);\n itemElement.removeEventListener('gallery-rotate-right', handleCustomEvent as EventListener);\n itemElement.removeEventListener('gallery-flip-x', handleCustomEvent as EventListener);\n itemElement.removeEventListener('gallery-flip-y', handleCustomEvent as EventListener);\n itemElement.removeEventListener('gallery-download', handleCustomEvent as EventListener);\n }\n };\n }, [normalScale, zoomedScale]);\n\n React.useEffect(() => {\n if (gallery?.state.activeIndex === index) {\n setIsActive(true);\n } else {\n setIsActive(false);\n }\n }, [gallery?.state.activeIndex, index]);\n\n const attributes = React.useMemo(() => {\n return {\n 'data-active': isActive\n };\n }, [isActive]);\n\n const CSSVariables = React.useMemo(() => {\n return {\n '--position-x': `${position.x}px`,\n '--position-y': `${position.y}px`,\n '--scale': `${scale}`,\n '--rotation': `${rotation}deg`,\n '--flip-x': flip.x,\n '--flip-y': flip.y\n } as React.CSSProperties;\n }, [position, scale, rotation, flip]);\n\n const state = {\n index,\n position,\n scale,\n rotation,\n flip,\n isActive,\n dragStart,\n hasDragged\n };\n\n return {\n state,\n attributes,\n CSSVariables,\n handlePointerUp,\n handlePointerMove,\n handlePointerDown,\n handleClick,\n handleDragStart,\n zoomIn,\n zoomOut,\n rotateLeft,\n rotateRight,\n flipX,\n flipY,\n download,\n calculateConstraints,\n calculateItemSize\n };\n }\n});\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { useGallery } from '@primereact/headless/gallery';\nimport { styles } from '@primereact/styles/gallery';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { GalleryProvider } from './Gallery.context';\nimport { defaultProps } from './Gallery.props';\nimport { GalleryBackdrop } from './backdrop/GalleryBackdrop';\nimport { GalleryContent } from './content/GalleryContent';\nimport { GalleryItem } from './item/GalleryItem';\nimport { GalleryNext } from './next/GalleryNext';\nimport { GalleryPrev } from './prev/GalleryPrev';\nimport { GalleryThumbnail } from './thumbnail/GalleryThumbnail';\nimport { GalleryThumbnailContent } from './thumbnailcontent/GalleryThumbnailContent';\nimport { GalleryThumbnailItem } from './thumbnailitem/GalleryThumbnailItem';\nimport { GalleryToolbar } from './toolbar/GalleryToolbar';\nimport { GalleryToolbarItem } from './toolbaritem/GalleryToolbarItem';\n\nexport const Gallery = withComponent({\n name: 'Gallery',\n defaultProps,\n styles,\n setup(instance) {\n const gallery = useGallery(instance.inProps);\n\n return gallery;\n },\n render(instance) {\n const { id, props, ptmi, cx } = instance;\n\n const rootProps = mergeProps(\n {\n id,\n className: cx('root')\n },\n ptmi('root')\n );\n\n return (\n <GalleryProvider value={instance}>\n <Component instance={instance} attrs={rootProps} children={props.children} />\n </GalleryProvider>\n );\n },\n components: {\n Backdrop: GalleryBackdrop,\n Content: GalleryContent,\n Item: GalleryItem,\n Next: GalleryNext,\n Prev: GalleryPrev,\n Toolbar: GalleryToolbar,\n ToolbarItem: GalleryToolbarItem,\n Thumbnail: GalleryThumbnail,\n ThumbnailContent: GalleryThumbnailContent,\n ThumbnailItem: GalleryThumbnailItem\n }\n});\n","import { withComponent as withComponentInCore } from '@primereact/core/component';\nimport { styles as baseStyles } from '@primereact/styles/base';\nimport type { withComponentOptions } from '@primereact/types/core';\nimport type { StylesOptions } from '@primereact/types/styles';\n\nexport const withComponent = <IProps, DProps, Exposes extends Record<PropertyKey, unknown> = Record<PropertyKey, unknown>, Styles = StylesOptions, CData = Record<string, unknown>>({\n name = 'UnknownComponent',\n defaultProps,\n styles = {\n ...baseStyles,\n name: 'global'\n } as Styles,\n components,\n setup,\n render\n}: withComponentOptions<IProps, DProps, Exposes, Styles, CData>) => {\n return withComponentInCore<IProps, DProps, Exposes, Styles, CData>({\n name,\n defaultProps,\n styles,\n components,\n setup,\n render\n });\n};\n","import { createOptionalContext } from '@primereact/core/utils';\nimport type { GalleryInstance } from '@primereact/types/shared/gallery';\n\nexport const [GalleryProvider, useGalleryContext] = createOptionalContext<GalleryInstance>();\n","import * as HeadlessGallery from '@primereact/headless/gallery';\nimport type { GalleryProps } from '@primereact/types/shared/gallery';\n\nexport const defaultProps: GalleryProps = {\n ...HeadlessGallery.defaultProps,\n as: 'div'\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { useGalleryContext } from '../Gallery.context';\nimport { defaultCloseProps } from './GalleryBackdrop.props';\n\nexport const GalleryBackdrop = withComponent({\n name: 'GalleryBackdrop',\n defaultProps: defaultCloseProps,\n setup() {\n const gallery = useGalleryContext();\n\n return { gallery };\n },\n render(instance) {\n const { props, ptmi, gallery } = instance;\n\n const rootProps = mergeProps(\n {\n className: gallery?.cx('backdrop')\n },\n ptmi('root')\n );\n\n return <Component instance={instance} attrs={rootProps} children={props.children} />;\n }\n});\n","import { GalleryBackdropProps } from '@primereact/types/shared/gallery';\n\nexport const defaultCloseProps: GalleryBackdropProps = {\n as: 'div'\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { useGalleryContext } from '../Gallery.context';\nimport { defaultContentProps } from './GalleryContent.props';\n\nexport const GalleryContent = withComponent({\n name: 'GalleryContent',\n defaultProps: defaultContentProps,\n setup() {\n const gallery = useGalleryContext();\n\n return { gallery };\n },\n render(instance) {\n const { props, ptmi, gallery } = instance;\n\n const rootProps = mergeProps(\n {\n className: gallery?.cx('content')\n },\n ptmi('root')\n );\n\n return <Component instance={instance} attrs={rootProps} children={props.children} ref={gallery?.contentRef} />;\n }\n});\n","import { GalleryContentProps } from '@primereact/types/shared/gallery';\n\nexport const defaultContentProps: GalleryContentProps = {\n as: 'div'\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { useGalleryItem } from '@primereact/headless/gallery/item';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { useGalleryContext } from '../Gallery.context';\nimport { GalleryItemProvider } from './GalleryItem.context';\nimport { defaultProps } from './GalleryItem.props';\n\nexport const GalleryItem = withComponent({\n name: 'GalleryItem',\n defaultProps,\n setup(instance) {\n const gallery = useGalleryContext();\n const galleryItem = useGalleryItem(instance.inProps);\n\n return { ...galleryItem, gallery };\n },\n render(instance) {\n const { id, props, ptmi, gallery, handleClick, handlePointerDown, handlePointerMove, handlePointerUp, handleDragStart, CSSVariables, attributes } = instance;\n\n const rootProps = mergeProps(\n {\n id,\n className: gallery?.cx('item'),\n onClick: handleClick,\n onPointerDown: handlePointerDown,\n onPointerMove: handlePointerMove,\n onPointerUp: handlePointerUp,\n onDragStart: handleDragStart,\n style: CSSVariables,\n ...attributes\n },\n ptmi('root'),\n gallery?.ptm('item')\n );\n\n return (\n <GalleryItemProvider value={instance}>\n <Component instance={instance} attrs={rootProps} children={props.children} />\n </GalleryItemProvider>\n );\n }\n});\n","import { createOptionalContext } from '@primereact/core/utils';\nimport type { GalleryItemInstance } from '@primereact/types/shared/gallery';\n\nexport const [GalleryItemProvider, useGalleryItemContext] = createOptionalContext<GalleryItemInstance>();\n","import * as HeadlessGallery from '@primereact/headless/gallery';\nimport type { GalleryItemProps } from '@primereact/types/shared/gallery';\n\nexport const defaultProps: GalleryItemProps = {\n ...HeadlessGallery.defaultProps,\n as: 'div'\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { useGalleryContext } from '../Gallery.context';\nimport { defaultNextProps } from './GalleryNext.props';\n\nexport const GalleryNext = withComponent({\n name: 'GalleryNext',\n defaultProps: defaultNextProps,\n setup() {\n const gallery = useGalleryContext();\n\n return { gallery };\n },\n render(instance) {\n const { props, ptmi, gallery } = instance;\n\n const rootProps = mergeProps(\n {\n className: gallery?.cx('next'),\n onClick: gallery?.actions?.next\n },\n ptmi('root')\n );\n\n return <Component instance={instance} attrs={rootProps} children={props.children} ref={gallery?.nextRef} />;\n }\n});\n","import { GalleryNextProps } from '@primereact/types/shared/gallery';\n\nexport const defaultNextProps: GalleryNextProps = {\n as: 'button'\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { useGalleryContext } from '../Gallery.context';\nimport { defaultPrevProps } from './GalleryPrev.props';\n\nexport const GalleryPrev = withComponent({\n name: 'GalleryPrev',\n defaultProps: defaultPrevProps,\n setup() {\n const gallery = useGalleryContext();\n\n return { gallery };\n },\n render(instance) {\n const { props, ptmi, gallery } = instance;\n\n const rootProps = mergeProps(\n {\n className: gallery?.cx('prev'),\n onClick: gallery?.actions?.prev\n },\n ptmi('root')\n );\n\n return <Component instance={instance} attrs={rootProps} children={props.children} ref={gallery?.prevRef} />;\n }\n});\n","import { GalleryPrevProps } from '@primereact/types/shared/gallery';\n\nexport const defaultPrevProps: GalleryPrevProps = {\n as: 'button'\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport { Carousel } from 'primereact/carousel';\nimport * as React from 'react';\nimport { useGalleryContext } from '../Gallery.context';\nimport { defaultThumbnailProps } from './GalleryThumbnail.props';\n\nexport const GalleryThumbnail = withComponent({\n name: 'GalleryThumbnail',\n defaultProps: defaultThumbnailProps,\n setup() {\n const gallery = useGalleryContext();\n\n return { gallery };\n },\n render(instance) {\n const { props, ptmi, gallery } = instance;\n\n const rootProps = mergeProps(\n {\n className: gallery?.cx('thumbnail')\n },\n ptmi('root')\n );\n\n return <Component as={Carousel} instance={instance} attrs={rootProps} children={props.children} ref={gallery?.thumbnailRef} />;\n }\n});\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { useCarousel } from '@primereact/headless/carousel';\nimport { styles } from '@primereact/styles/carousel';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { CarouselProvider } from './Carousel.context';\nimport { defaultProps } from './Carousel.props';\nimport { CarouselContent } from './content';\nimport { CarouselIndicator } from './indicator';\nimport { CarouselIndicators } from './indicators';\nimport { CarouselItem } from './item';\nimport { CarouselNext } from './next';\nimport { CarouselPrev } from './prev';\n\nexport const Carousel = withComponent({\n name: 'Carousel',\n defaultProps,\n styles,\n setup(instance) {\n const carousel = useCarousel(instance.inProps);\n\n return carousel;\n },\n render(instance) {\n const { id, props, ptmi, cx } = instance;\n\n const rootProps = mergeProps(\n {\n id,\n className: cx('root')\n },\n ptmi('root')\n );\n\n return (\n <CarouselProvider value={instance}>\n <Component instance={instance} attrs={rootProps} children={props.children} />\n </CarouselProvider>\n );\n },\n components: {\n Content: CarouselContent,\n Item: CarouselItem,\n Next: CarouselNext,\n Prev: CarouselPrev,\n Indicators: CarouselIndicators,\n Indicator: CarouselIndicator\n }\n});\n","import { createOptionalContext } from '@primereact/core/utils';\nimport type { CarouselInstance } from '@primereact/types/shared/carousel';\n\nexport const [CarouselProvider, useCarouselContext] = createOptionalContext<CarouselInstance>();\n","import * as HeadlessCarousel from '@primereact/headless/carousel';\nimport type { CarouselProps } from '@primereact/types/shared/carousel';\n\nexport const defaultProps: CarouselProps = {\n ...HeadlessCarousel.defaultProps,\n as: 'div'\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { useCarouselContext } from '../Carousel.context';\nimport { defaultContentProps } from './CarouselContent.props';\n\nexport const CarouselContent = withComponent({\n name: 'CarouselContent',\n defaultProps: defaultContentProps,\n setup() {\n const carousel = useCarouselContext();\n\n return { carousel };\n },\n render(instance) {\n const { props, ptmi, carousel } = instance;\n\n const contentProps = mergeProps(\n {\n className: carousel?.cx('content', { orientation: carousel?.props.orientation }),\n style: {\n ...({\n '--p-swipe-amount-x': `0px`,\n '--p-swipe-amount-y': `0px`,\n '--p-spacing': `${carousel?.props.spacing}px`\n } as React.CSSProperties)\n },\n onPointerDown: carousel?.handlePointerDown,\n onPointerMove: carousel?.handlePointerMove,\n onPointerUp: carousel?.handlePointerUp,\n onClick: carousel?.handleClick,\n onClickCapture: carousel?.handleClick\n },\n carousel?.ptm('content'),\n ptmi('root')\n );\n\n const viewportProps = mergeProps(\n {\n className: carousel?.cx('viewport')\n },\n carousel?.ptm('viewport')\n );\n\n return (\n <div {...viewportProps}>\n <Component instance={instance} attrs={contentProps} children={props.children} ref={carousel?.carouselRef} />\n </div>\n );\n }\n});\n","import type { CarouselContentProps } from '@primereact/types/shared/carousel';\n\nexport const defaultContentProps: CarouselContentProps = {\n as: 'div'\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { useCarouselContext } from '../Carousel.context';\nimport { defaultIndicatorProps } from './CarouselIndicator.props';\n\nexport const CarouselIndicator = withComponent({\n name: 'CarouselIndicator',\n defaultProps: defaultIndicatorProps,\n setup() {\n const carousel = useCarouselContext();\n\n return { carousel };\n },\n render(instance) {\n const { props, ptmi, carousel } = instance;\n\n const contentProps = mergeProps(\n {\n className: carousel?.cx('indicator', { active: props.index === carousel?.state?.activeIndex }),\n onClick: () => carousel?.slideTo(undefined, props.snap)\n },\n carousel?.ptm('indicator'),\n ptmi('root')\n );\n\n return <Component instance={instance} attrs={contentProps} children={props.children} />;\n }\n});\n","import type { CarouselIndicatorProps } from '@primereact/types/shared/carousel';\n\nexport const defaultIndicatorProps: CarouselIndicatorProps = {\n as: 'button',\n snap: undefined,\n index: undefined\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { useCarouselContext } from '../Carousel.context';\nimport { CarouselIndicator } from '../indicator/CarouselIndicator';\nimport { defaultIndicatorsProps } from './CarouselIndicators.props';\n\nexport const CarouselIndicators = withComponent({\n name: 'CarouselIndicators',\n defaultProps: defaultIndicatorsProps,\n setup() {\n const carousel = useCarouselContext();\n\n return { carousel };\n },\n render(instance) {\n const { props, ptmi, carousel } = instance;\n\n const contentProps = mergeProps(\n {\n className: carousel?.cx('indicators')\n },\n carousel?.ptm('indicators'),\n ptmi('root')\n );\n\n return (\n <Component\n instance={instance}\n attrs={contentProps}\n children={\n props.children ?? (\n <>\n {carousel?.state?.snapPoints.map((snap, i) => (\n <CarouselIndicator key={i} snap={snap} index={i} />\n ))}\n </>\n )\n }\n />\n );\n }\n});\n","import type { CarouselIndicatorsProps } from '@primereact/types/shared/carousel';\n\nexport const defaultIndicatorsProps: CarouselIndicatorsProps = {\n as: 'div'\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { useCarouselContext } from '../Carousel.context';\nimport { defaultItemProps } from './CarouselItem.props';\n\nexport const CarouselItem = withComponent({\n name: 'CarouselItem',\n defaultProps: defaultItemProps,\n setup() {\n const carousel = useCarouselContext();\n\n return { carousel };\n },\n render(instance) {\n const { props, ptmi, carousel } = instance;\n\n const rootProps = mergeProps(\n {\n className: carousel?.cx('item'),\n style: {\n '--p-slide-size': `${props.size}%`\n }\n },\n carousel?.ptm('item'),\n ptmi('root')\n );\n\n return <Component instance={instance} attrs={rootProps} children={props.children} ref={carousel?.addSlideRef} />;\n }\n});\n","import type { CarouselItemProps } from '@primereact/types/shared/carousel';\n\nexport const defaultItemProps: CarouselItemProps = {\n as: 'div',\n size: 100\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { useCarouselContext } from '../Carousel.context';\nimport { defaultNextProps } from './CarouselNext.props';\n\nexport const CarouselNext = withComponent({\n name: 'CarouselNext',\n defaultProps: defaultNextProps,\n setup() {\n const carousel = useCarouselContext();\n\n return { carousel };\n },\n render(instance) {\n const { props, ptmi, carousel } = instance;\n\n const disabled = carousel?.state.nextDisabled;\n const rootProps = mergeProps(\n {\n className: carousel?.cx('prev', { disabled }),\n onClick: carousel?.handleNext,\n disabled\n },\n carousel?.ptm('prev'),\n ptmi('root')\n );\n\n return <Component instance={instance} attrs={rootProps} children={props.children} />;\n }\n});\n","import type { CarouselNextProps } from '@primereact/types/shared/carousel';\n\nexport const defaultNextProps: CarouselNextProps = {\n as: 'button'\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { useCarouselContext } from '../Carousel.context';\nimport { defaultPrevProps } from './CarouselPrev.props';\n\nexport const CarouselPrev = withComponent({\n name: 'CarouselPrev',\n defaultProps: defaultPrevProps,\n setup() {\n const carousel = useCarouselContext();\n\n return { carousel };\n },\n render(instance) {\n const { props, ptmi, carousel } = instance;\n\n const disabled = carousel?.state.prevDisabled;\n const rootProps = mergeProps(\n {\n className: carousel?.cx('prev', { disabled }),\n onClick: carousel?.handlePrev,\n disabled\n },\n carousel?.ptm('prev'),\n ptmi('root')\n );\n\n return <Component instance={instance} attrs={rootProps} children={props.children} />;\n }\n});\n","import type { CarouselPrevProps } from '@primereact/types/shared/carousel';\n\nexport const defaultPrevProps: CarouselPrevProps = {\n as: 'button'\n};\n","import { GalleryThumbnailProps } from '@primereact/types/shared/gallery';\n\nexport const defaultThumbnailProps: GalleryThumbnailProps = {\n as: 'div'\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport { Carousel } from 'primereact/carousel';\nimport * as React from 'react';\nimport { useGalleryContext } from '../Gallery.context';\nimport { defaultThumbnailContentProps } from './GalleryThumbnailContent.props';\n\nexport const GalleryThumbnailContent = withComponent({\n name: 'GalleryThumbnailContent',\n defaultProps: defaultThumbnailContentProps,\n setup() {\n const gallery = useGalleryContext();\n\n return { gallery };\n },\n render(instance) {\n const { props, ptmi, gallery } = instance;\n\n const rootProps = mergeProps(\n {\n className: gallery?.cx('thumbnailContent')\n },\n ptmi('root')\n );\n\n return <Component as={Carousel.Content} instance={instance} attrs={rootProps} children={props.children} />;\n }\n});\n","import { GalleryThumbnailContentProps } from '@primereact/types/shared/gallery';\n\nexport const defaultThumbnailContentProps: GalleryThumbnailContentProps = {};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport { Carousel } from 'primereact/carousel';\nimport * as React from 'react';\nimport { useGalleryContext } from '../Gallery.context';\nimport { defaultThumbnailItemProps } from './GalleryThumbnailItem.props';\n\nexport const GalleryThumbnailItem = withComponent({\n name: 'GalleryThumbnailItem',\n defaultProps: defaultThumbnailItemProps,\n setup() {\n const gallery = useGalleryContext();\n\n return { gallery };\n },\n render(instance) {\n const { props, ptmi, gallery } = instance;\n\n const rootProps = mergeProps(\n {\n className: gallery?.cx('thumbnailItem')\n },\n ptmi('root')\n );\n\n return <Component as={Carousel.Item} instance={instance} attrs={rootProps} children={props.children} />;\n }\n});\n","import { GalleryThumbnailItemProps } from '@primereact/types/shared/gallery';\n\nexport const defaultThumbnailItemProps: GalleryThumbnailItemProps = {};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { useGalleryContext } from '../Gallery.context';\nimport { defaultToolbarProps } from './GalleryToolbar.props';\n\nexport const GalleryToolbar = withComponent({\n name: 'GalleryToolbar',\n defaultProps: defaultToolbarProps,\n setup() {\n const gallery = useGalleryContext();\n\n return { gallery };\n },\n render(instance) {\n const { props, ptmi, gallery } = instance;\n\n const rootProps = mergeProps(\n {\n className: gallery?.cx('toolbar')\n },\n ptmi('root')\n );\n\n return <Component instance={instance} attrs={rootProps} children={props.children} ref={gallery?.toolbarRef} />;\n }\n});\n","import { GalleryToolbarProps } from '@primereact/types/shared/gallery';\n\nexport const defaultToolbarProps: GalleryToolbarProps = {\n as: 'div'\n};\n","'use client';\nimport { Component } from '@primereact/core/component';\nimport { mergeProps } from '@primeuix/utils';\nimport { withComponent } from 'primereact/base';\nimport * as React from 'react';\nimport { useGalleryContext } from '../Gallery.context';\nimport { defaultToolbarItemProps } from './GalleryToolbarItem.props';\n\nexport const GalleryToolbarItem = withComponent({\n name: 'GalleryToolbarItem',\n defaultProps: defaultToolbarItemProps,\n setup() {\n const gallery = useGalleryContext();\n\n return { gallery };\n },\n render(instance) {\n const { props, ptmi, gallery } = instance;\n\n const rootProps = mergeProps(\n {\n className: gallery?.cx('toolbarItem'),\n onClick: () => {\n gallery?.handleClickAction(props?.action);\n props?.onClick?.();\n }\n },\n ptmi('root')\n );\n\n return <Component instance={instance} attrs={rootProps} children={props.children} />;\n }\n});\n","import { GalleryToolbarItemProps } from '@primereact/types/shared/gallery';\n\nexport const defaultToolbarItemProps: GalleryToolbarItemProps = {\n as: 'div',\n action: undefined,\n onClick: undefined\n};\n","import type { useGalleryItemProps } from '@primereact/types/shared/gallery';\n\nexport const defaultItemProps: useGalleryItemProps = {\n normalScale: 1,\n zoomedScale: 3\n};\n"],"mappings":"6bAAA,OAAS,gBAAAA,OAAoB,4BCC7B,OAAS,aAAAC,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,+BAC3B,OAAS,UAAAC,OAAc,6BACvB,OAAS,cAAAC,OAAkB,kBCJ3B,OAAS,iBAAiBC,OAA2B,6BACrD,OAAS,UAAUC,OAAkB,0BAI9B,IAAMC,EAAgB,CAAuJ,CAChL,KAAAC,EAAO,mBACP,aAAAC,EACA,OAAAC,EAASC,EAAAC,EAAA,GACFC,IADE,CAEL,KAAM,QACV,GACA,WAAAC,EACA,MAAAC,EACA,OAAAC,CACJ,IACWC,GAA4D,CAC/D,KAAAT,EACA,aAAAC,EACA,OAAAC,EACA,WAAAI,EACA,MAAAC,EACA,OAAAC,CACJ,CAAC,EDjBL,UAAYE,MAAW,QENvB,OAAS,yBAAAC,OAA6B,yBAG/B,GAAM,CAACC,GAAiBC,CAAiB,EAAIF,GAAuC,ECH3F,UAAYG,OAAqB,+BAG1B,IAAMC,GAA6BC,EAAAC,EAAA,GACnB,iBADmB,CAEtC,GAAI,KACR,GCLA,OAAS,aAAAC,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,OAAW,QCFhB,IAAMC,GAA0C,CACnD,GAAI,KACR,EDIO,IAAMC,GAAkBC,EAAc,CACzC,KAAM,kBACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,QAFOC,EAAkB,CAEjB,CACrB,EACA,OAAOC,EAAU,CACb,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,QAAAC,CAAQ,EAAIH,EAE3BI,EAAYC,GACd,CACI,UAAWF,GAAA,YAAAA,EAAS,GAAG,WAC3B,EACAD,EAAK,MAAM,CACf,EAEA,OAAO,iBAACI,GAAA,CAAU,SAAUN,EAAU,MAAOI,EAAW,SAAUH,EAAM,SAAU,CACtF,CACJ,CAAC,EE3BD,OAAS,aAAAM,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,OAAW,QCFhB,IAAMC,GAA2C,CACpD,GAAI,KACR,EDIO,IAAMC,GAAiBC,EAAc,CACxC,KAAM,iBACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,QAFOC,EAAkB,CAEjB,CACrB,EACA,OAAOC,EAAU,CACb,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,QAAAC,CAAQ,EAAIH,EAE3BI,EAAYC,GACd,CACI,UAAWF,GAAA,YAAAA,EAAS,GAAG,UAC3B,EACAD,EAAK,MAAM,CACf,EAEA,OAAO,iBAACI,GAAA,CAAU,SAAUN,EAAU,MAAOI,EAAW,SAAUH,EAAM,SAAU,IAAKE,GAAA,YAAAA,EAAS,WAAY,CAChH,CACJ,CAAC,EE3BD,OAAS,aAAAI,OAAiB,6BAC1B,OAAS,kBAAAC,OAAsB,oCAC/B,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,MAAW,QCLvB,OAAS,yBAAAC,OAA6B,yBAG/B,GAAM,CAACC,GAAqBC,EAAqB,EAAIF,GAA2C,ECHvG,UAAYG,OAAqB,+BAG1B,IAAMC,GAAiCC,EAAAC,EAAA,GACvB,iBADuB,CAE1C,GAAI,KACR,GFIO,IAAMC,GAAcC,EAAc,CACrC,KAAM,cACN,aAAAC,GACA,MAAMC,EAAU,CACZ,IAAMC,EAAUC,EAAkB,EAC5BC,EAAcC,GAAeJ,EAAS,OAAO,EAEnD,OAAOK,EAAAC,EAAA,GAAKH,GAAL,CAAkB,QAAAF,CAAQ,EACrC,EACA,OAAOD,EAAU,CACb,GAAM,CAAE,GAAAO,EAAI,MAAAC,EAAO,KAAAC,EAAM,QAAAR,EAAS,YAAAS,EAAa,kBAAAC,EAAmB,kBAAAC,EAAmB,gBAAAC,EAAiB,gBAAAC,EAAiB,aAAAC,EAAc,WAAAC,CAAW,EAAIhB,EAE9IiB,EAAYC,GACdZ,EAAA,CACI,GAAAC,EACA,UAAWN,GAAA,YAAAA,EAAS,GAAG,QACvB,QAASS,EACT,cAAeC,EACf,cAAeC,EACf,YAAaC,EACb,YAAaC,EACb,MAAOC,GACJC,GAEPP,EAAK,MAAM,EACXR,GAAA,YAAAA,EAAS,IAAI,OACjB,EAEA,OACI,gBAACkB,GAAA,CAAoB,MAAOnB,GACxB,gBAACoB,GAAA,CAAU,SAAUpB,EAAU,MAAOiB,EAAW,SAAUT,EAAM,SAAU,CAC/E,CAER,CACJ,CAAC,EG3CD,OAAS,aAAAa,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,OAAW,QCFhB,IAAMC,GAAqC,CAC9C,GAAI,QACR,EDIO,IAAMC,GAAcC,EAAc,CACrC,KAAM,cACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,QAFOC,EAAkB,CAEjB,CACrB,EACA,OAAOC,EAAU,CAhBrB,IAAAC,EAiBQ,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,QAAAC,CAAQ,EAAIJ,EAE3BK,EAAYC,GACd,CACI,UAAWF,GAAA,YAAAA,EAAS,GAAG,QACvB,SAASH,EAAAG,GAAA,YAAAA,EAAS,UAAT,YAAAH,EAAkB,IAC/B,EACAE,EAAK,MAAM,CACf,EAEA,OAAO,iBAACI,GAAA,CAAU,SAAUP,EAAU,MAAOK,EAAW,SAAUH,EAAM,SAAU,IAAKE,GAAA,YAAAA,EAAS,QAAS,CAC7G,CACJ,CAAC,EE5BD,OAAS,aAAAI,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,OAAW,QCFhB,IAAMC,GAAqC,CAC9C,GAAI,QACR,EDIO,IAAMC,GAAcC,EAAc,CACrC,KAAM,cACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,QAFOC,EAAkB,CAEjB,CACrB,EACA,OAAOC,EAAU,CAhBrB,IAAAC,EAiBQ,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,QAAAC,CAAQ,EAAIJ,EAE3BK,EAAYC,GACd,CACI,UAAWF,GAAA,YAAAA,EAAS,GAAG,QACvB,SAASH,EAAAG,GAAA,YAAAA,EAAS,UAAT,YAAAH,EAAkB,IAC/B,EACAE,EAAK,MAAM,CACf,EAEA,OAAO,iBAACI,GAAA,CAAU,SAAUP,EAAU,MAAOK,EAAW,SAAUH,EAAM,SAAU,IAAKE,GAAA,YAAAA,EAAS,QAAS,CAC7G,CACJ,CAAC,EE5BD,OAAS,aAAAI,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBCD3B,OAAS,aAAAC,OAAiB,6BAC1B,OAAS,eAAAC,OAAmB,gCAC5B,OAAS,UAAAC,OAAc,8BACvB,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,MAAW,QCNvB,OAAS,yBAAAC,OAA6B,yBAG/B,GAAM,CAACC,GAAkBC,CAAkB,EAAIF,GAAwC,ECH9F,UAAYG,OAAsB,gCAG3B,IAAMC,GAA8BC,EAAAC,EAAA,GACnB,iBADmB,CAEvC,GAAI,KACR,GCLA,OAAS,aAAAC,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,MAAW,QCFhB,IAAMC,GAA4C,CACrD,GAAI,KACR,EDIO,IAAMC,GAAkBC,EAAc,CACzC,KAAM,kBACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,SAFQC,EAAmB,CAElB,CACtB,EACA,OAAOC,EAAU,CACb,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,SAAAC,CAAS,EAAIH,EAE5BI,EAAeC,GACjB,CACI,UAAWF,GAAA,YAAAA,EAAU,GAAG,UAAW,CAAE,YAAaA,GAAA,YAAAA,EAAU,MAAM,WAAY,GAC9E,MAAO,CAEC,qBAAsB,MACtB,qBAAsB,MACtB,cAAe,GAAGA,GAAA,YAAAA,EAAU,MAAM,OAAO,IAEjD,EACA,cAAeA,GAAA,YAAAA,EAAU,kBACzB,cAAeA,GAAA,YAAAA,EAAU,kBACzB,YAAaA,GAAA,YAAAA,EAAU,gBACvB,QAASA,GAAA,YAAAA,EAAU,YACnB,eAAgBA,GAAA,YAAAA,EAAU,WAC9B,EACAA,GAAA,YAAAA,EAAU,IAAI,WACdD,EAAK,MAAM,CACf,EAEMI,EAAgBD,GAClB,CACI,UAAWF,GAAA,YAAAA,EAAU,GAAG,WAC5B,EACAA,GAAA,YAAAA,EAAU,IAAI,WAClB,EAEA,OACI,gBAAC,MAAAI,EAAA,GAAQD,GACL,gBAACE,GAAA,CAAU,SAAUR,EAAU,MAAOI,EAAc,SAAUH,EAAM,SAAU,IAAKE,GAAA,YAAAA,EAAU,YAAa,CAC9G,CAER,CACJ,CAAC,EEnDD,OAAS,aAAAM,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,OAAW,QCFhB,IAAMC,GAAgD,CACzD,GAAI,SACJ,KAAM,OACN,MAAO,MACX,EDEO,IAAMC,EAAoBC,EAAc,CAC3C,KAAM,oBACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,SAFQC,EAAmB,CAElB,CACtB,EACA,OAAOC,EAAU,CAhBrB,IAAAC,EAiBQ,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,SAAAC,CAAS,EAAIJ,EAE5BK,EAAeC,GACjB,CACI,UAAWF,GAAA,YAAAA,EAAU,GAAG,YAAa,CAAE,OAAQF,EAAM,UAAUD,EAAAG,GAAA,YAAAA,EAAU,QAAV,YAAAH,EAAiB,YAAY,GAC5F,QAAS,IAAMG,GAAA,YAAAA,EAAU,QAAQ,OAAWF,EAAM,KACtD,EACAE,GAAA,YAAAA,EAAU,IAAI,aACdD,EAAK,MAAM,CACf,EAEA,OAAO,iBAACI,GAAA,CAAU,SAAUP,EAAU,MAAOK,EAAc,SAAUH,EAAM,SAAU,CACzF,CACJ,CAAC,EE7BD,OAAS,aAAAM,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,MAAW,QCFhB,IAAMC,GAAkD,CAC3D,GAAI,KACR,EDKO,IAAMC,GAAqBC,EAAc,CAC5C,KAAM,qBACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,SAFQC,EAAmB,CAElB,CACtB,EACA,OAAOC,EAAU,CAjBrB,IAAAC,EAAAC,EAkBQ,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,SAAAC,CAAS,EAAIL,EAE5BM,EAAeC,GACjB,CACI,UAAWF,GAAA,YAAAA,EAAU,GAAG,aAC5B,EACAA,GAAA,YAAAA,EAAU,IAAI,cACdD,EAAK,MAAM,CACf,EAEA,OACI,gBAACI,GAAA,CACG,SAAUR,EACV,MAAOM,EACP,UACIJ,EAAAC,EAAM,WAAN,KAAAD,EACI,iCACKD,EAAAI,GAAA,YAAAA,EAAU,QAAV,YAAAJ,EAAiB,WAAW,IAAI,CAACQ,EAAMC,IACpC,gBAACC,EAAA,CAAkB,IAAKD,EAAG,KAAMD,EAAM,MAAOC,EAAG,EAEzD,EAGZ,CAER,CACJ,CAAC,EE3CD,OAAS,aAAAE,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,OAAW,QCFhB,IAAMC,GAAsC,CAC/C,GAAI,MACJ,KAAM,GACV,EDGO,IAAMC,GAAeC,EAAc,CACtC,KAAM,eACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,SAFQC,EAAmB,CAElB,CACtB,EACA,OAAOC,EAAU,CACb,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,SAAAC,CAAS,EAAIH,EAE5BI,EAAYC,GACd,CACI,UAAWF,GAAA,YAAAA,EAAU,GAAG,QACxB,MAAO,CACH,iBAAkB,GAAGF,EAAM,IAAI,GACnC,CACJ,EACAE,GAAA,YAAAA,EAAU,IAAI,QACdD,EAAK,MAAM,CACf,EAEA,OAAO,iBAACI,GAAA,CAAU,SAAUN,EAAU,MAAOI,EAAW,SAAUH,EAAM,SAAU,IAAKE,GAAA,YAAAA,EAAU,YAAa,CAClH,CACJ,CAAC,EE/BD,OAAS,aAAAI,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,OAAW,QCFhB,IAAMC,GAAsC,CAC/C,GAAI,QACR,EDIO,IAAMC,GAAeC,EAAc,CACtC,KAAM,eACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,SAFQC,EAAmB,CAElB,CACtB,EACA,OAAOC,EAAU,CACb,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,SAAAC,CAAS,EAAIH,EAE5BI,EAAWD,GAAA,YAAAA,EAAU,MAAM,aAC3BE,EAAYC,GACd,CACI,UAAWH,GAAA,YAAAA,EAAU,GAAG,OAAQ,CAAE,SAAAC,CAAS,GAC3C,QAASD,GAAA,YAAAA,EAAU,WACnB,SAAAC,CACJ,EACAD,GAAA,YAAAA,EAAU,IAAI,QACdD,EAAK,MAAM,CACf,EAEA,OAAO,iBAACK,GAAA,CAAU,SAAUP,EAAU,MAAOK,EAAW,SAAUJ,EAAM,SAAU,CACtF,CACJ,CAAC,EE/BD,OAAS,aAAAO,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,OAAW,QCFhB,IAAMC,GAAsC,CAC/C,GAAI,QACR,EDIO,IAAMC,GAAeC,EAAc,CACtC,KAAM,eACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,SAFQC,EAAmB,CAElB,CACtB,EACA,OAAOC,EAAU,CACb,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,SAAAC,CAAS,EAAIH,EAE5BI,EAAWD,GAAA,YAAAA,EAAU,MAAM,aAC3BE,EAAYC,GACd,CACI,UAAWH,GAAA,YAAAA,EAAU,GAAG,OAAQ,CAAE,SAAAC,CAAS,GAC3C,QAASD,GAAA,YAAAA,EAAU,WACnB,SAAAC,CACJ,EACAD,GAAA,YAAAA,EAAU,IAAI,QACdD,EAAK,MAAM,CACf,EAEA,OAAO,iBAACK,GAAA,CAAU,SAAUP,EAAU,MAAOK,EAAW,SAAUJ,EAAM,SAAU,CACtF,CACJ,CAAC,EbhBM,IAAMO,EAAWC,EAAc,CAClC,KAAM,WACN,aAAAC,GACA,OAAAC,GACA,MAAMC,EAAU,CAGZ,OAFiBC,GAAYD,EAAS,OAAO,CAGjD,EACA,OAAOA,EAAU,CACb,GAAM,CAAE,GAAAE,EAAI,MAAAC,EAAO,KAAAC,EAAM,GAAAC,CAAG,EAAIL,EAE1BM,EAAYC,GACd,CACI,GAAAL,EACA,UAAWG,EAAG,MAAM,CACxB,EACAD,EAAK,MAAM,CACf,EAEA,OACI,gBAACI,GAAA,CAAiB,MAAOR,GACrB,gBAACS,GAAA,CAAU,SAAUT,EAAU,MAAOM,EAAW,SAAUH,EAAM,SAAU,CAC/E,CAER,EACA,WAAY,CACR,QAASO,GACT,KAAMC,GACN,KAAMC,GACN,KAAMC,GACN,WAAYC,GACZ,UAAWC,CACf,CACJ,CAAC,ED7CD,UAAYC,OAAW,QgBHhB,IAAMC,GAA+C,CACxD,GAAI,KACR,EhBKO,IAAMC,GAAmBC,EAAc,CAC1C,KAAM,mBACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,QAFOC,EAAkB,CAEjB,CACrB,EACA,OAAOC,EAAU,CACb,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,QAAAC,CAAQ,EAAIH,EAE3BI,EAAYC,GACd,CACI,UAAWF,GAAA,YAAAA,EAAS,GAAG,YAC3B,EACAD,EAAK,MAAM,CACf,EAEA,OAAO,iBAACI,GAAA,CAAU,GAAIC,EAAU,SAAUP,EAAU,MAAOI,EAAW,SAAUH,EAAM,SAAU,IAAKE,GAAA,YAAAA,EAAS,aAAc,CAChI,CACJ,CAAC,EiB5BD,OAAS,aAAAK,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAG3B,UAAYC,OAAW,QCHhB,IAAMC,GAA6D,CAAC,EDOpE,IAAMC,GAA0BC,EAAc,CACjD,KAAM,0BACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,QAFOC,EAAkB,CAEjB,CACrB,EACA,OAAOC,EAAU,CACb,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,QAAAC,CAAQ,EAAIH,EAE3BI,EAAYC,GACd,CACI,UAAWF,GAAA,YAAAA,EAAS,GAAG,mBAC3B,EACAD,EAAK,MAAM,CACf,EAEA,OAAO,iBAACI,GAAA,CAAU,GAAIC,EAAS,QAAS,SAAUP,EAAU,MAAOI,EAAW,SAAUH,EAAM,SAAU,CAC5G,CACJ,CAAC,EE5BD,OAAS,aAAAO,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAG3B,UAAYC,OAAW,QCHhB,IAAMC,GAAuD,CAAC,EDO9D,IAAMC,GAAuBC,EAAc,CAC9C,KAAM,uBACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,QAFOC,EAAkB,CAEjB,CACrB,EACA,OAAOC,EAAU,CACb,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,QAAAC,CAAQ,EAAIH,EAE3BI,EAAYC,GACd,CACI,UAAWF,GAAA,YAAAA,EAAS,GAAG,gBAC3B,EACAD,EAAK,MAAM,CACf,EAEA,OAAO,iBAACI,GAAA,CAAU,GAAIC,EAAS,KAAM,SAAUP,EAAU,MAAOI,EAAW,SAAUH,EAAM,SAAU,CACzG,CACJ,CAAC,EE5BD,OAAS,aAAAO,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,OAAW,QCFhB,IAAMC,GAA2C,CACpD,GAAI,KACR,EDIO,IAAMC,GAAiBC,EAAc,CACxC,KAAM,iBACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,QAFOC,EAAkB,CAEjB,CACrB,EACA,OAAOC,EAAU,CACb,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,QAAAC,CAAQ,EAAIH,EAE3BI,EAAYC,GACd,CACI,UAAWF,GAAA,YAAAA,EAAS,GAAG,UAC3B,EACAD,EAAK,MAAM,CACf,EAEA,OAAO,iBAACI,GAAA,CAAU,SAAUN,EAAU,MAAOI,EAAW,SAAUH,EAAM,SAAU,IAAKE,GAAA,YAAAA,EAAS,WAAY,CAChH,CACJ,CAAC,EE3BD,OAAS,aAAAI,OAAiB,6BAC1B,OAAS,cAAAC,OAAkB,kBAE3B,UAAYC,OAAW,QCFhB,IAAMC,GAAmD,CAC5D,GAAI,MACJ,OAAQ,OACR,QAAS,MACb,EDEO,IAAMC,GAAqBC,EAAc,CAC5C,KAAM,qBACN,aAAcC,GACd,OAAQ,CAGJ,MAAO,CAAE,QAFOC,EAAkB,CAEjB,CACrB,EACA,OAAOC,EAAU,CACb,GAAM,CAAE,MAAAC,EAAO,KAAAC,EAAM,QAAAC,CAAQ,EAAIH,EAE3BI,EAAYC,GACd,CACI,UAAWF,GAAA,YAAAA,EAAS,GAAG,eACvB,QAAS,IAAM,CAtB/B,IAAAG,EAuBoBH,GAAA,MAAAA,EAAS,kBAAkBF,GAAA,YAAAA,EAAO,SAClCK,EAAAL,GAAA,YAAAA,EAAO,UAAP,MAAAK,EAAA,KAAAL,EACJ,CACJ,EACAC,EAAK,MAAM,CACf,EAEA,OAAO,iBAACK,GAAA,CAAU,SAAUP,EAAU,MAAOI,EAAW,SAAUH,EAAM,SAAU,CACtF,CACJ,CAAC,EtCZM,IAAMO,GAAUC,EAAc,CACjC,KAAM,UACN,aAAAC,GACA,OAAAC,GACA,MAAMC,EAAU,CAGZ,OAFgBC,GAAWD,EAAS,OAAO,CAG/C,EACA,OAAOA,EAAU,CACb,GAAM,CAAE,GAAAE,EAAI,MAAAC,EAAO,KAAAC,EAAM,GAAAC,CAAG,EAAIL,EAE1BM,EAAYC,GACd,CACI,GAAAL,EACA,UAAWG,EAAG,MAAM,CACxB,EACAD,EAAK,MAAM,CACf,EAEA,OACI,gBAACI,GAAA,CAAgB,MAAOR,GACpB,gBAACS,GAAA,CAAU,SAAUT,EAAU,MAAOM,EAAW,SAAUH,EAAM,SAAU,CAC/E,CAER,EACA,WAAY,CACR,SAAUO,GACV,QAASC,GACT,KAAMC,GACN,KAAMC,GACN,KAAMC,GACN,QAASC,GACT,YAAaC,GACb,UAAWC,GACX,iBAAkBC,GAClB,cAAeC,EACnB,CACJ,CAAC,EDxDD,UAAYC,MAAW,QyCAhB,IAAMC,GAAwC,CACjD,YAAa,EACb,YAAa,CACjB,EzCAO,IAAMC,GAAiBC,GAAa,CACvC,KAAM,iBACN,aAAcC,GACd,MAAO,CAAC,CAAE,MAAAC,EAAO,WAAAC,CAAW,IAAM,CAC9B,GAAM,CAAE,YAAAC,EAAc,EAAG,YAAAC,EAAc,CAAE,EAAIH,EAEvCI,EAAUC,EAAkB,EAC5B,CAACC,EAAOC,CAAQ,EAAU,WAAS,EAAE,EACrC,CAACC,EAAUC,CAAW,EAAU,WAAS,EAAK,EAC9C,CAACC,EAAUC,CAAW,EAAU,WAAS,CAAE,EAAG,EAAG,EAAG,CAAE,CAAC,EACvD,CAACC,EAAOC,CAAQ,EAAU,WAAS,CAAC,EACpC,CAACC,EAAUC,CAAW,EAAU,WAAS,CAAC,EAC1C,CAACC,EAAMC,CAAO,EAAU,WAAS,CAAE,EAAG,EAAG,EAAG,CAAE,CAAC,EAE/C,CAACC,EAAYC,CAAa,EAAU,WAAS,EAAK,EAClD,CAACC,EAAWC,EAAY,EAAU,WAAS,CAAE,EAAG,EAAG,EAAG,CAAE,CAAC,EACzD,CAACC,EAAYC,CAAa,EAAU,WAAS,EAAK,EAElDC,EAAuB,SAA8C,IAAI,GAAK,EAC9EC,EAAwB,SAAO,CAAC,EAEhCC,EAA0B,cAAY,IAAM,CAC9C,GAAI,EAACtB,GAAA,MAAAA,EAAS,WAAW,UAAW,CAACH,EAAW,QAAS,OAEzD,IAAM0B,EAAcvB,GAAA,YAAAA,EAAS,WAAW,QAAQ,wBAE1CwB,EAAe3B,EAAW,QAAQ,kBAExC,GAAI,CAAC2B,EAAc,OAEnB,IAAIC,EAAeD,EAAa,cAAgBA,EAAa,YACzDE,EAAgBF,EAAa,eAAiBA,EAAa,aAE/D,GAAIC,IAAiB,GAAKC,IAAkB,EAAG,OAE/C,IAAMC,EAAY,KAAK,IAAIjB,CAAQ,EAAI,MAAQ,GAE3CiB,IACA,CAACF,EAAcC,CAAa,EAAI,CAACA,EAAeD,CAAY,GAGhE,IAAMG,EAAqBH,EAAeC,EACpCG,EAAqBN,EAAY,MAAQA,EAAY,OAEvDO,EAAaC,EAEbH,EAAqBC,GACrBC,EAAc,KAAK,IAAIP,EAAY,MAAQ,IAAME,CAAY,EAC7DM,EAAeD,EAAcF,IAE7BG,EAAe,KAAK,IAAIR,EAAY,OAAS,IAAMG,CAAa,EAChEI,EAAcC,EAAeH,GAG7BD,GACAH,EAAa,MAAM,MAAQ,GAAGO,CAAY,KAC1CP,EAAa,MAAM,OAAS,GAAGM,CAAW,KAC1CjC,EAAW,QAAQ,MAAM,MAAQ,GAAGkC,EAAe,EAAIA,EAAe,MAAM,KAC5ElC,EAAW,QAAQ,MAAM,OAAS,GAAGiC,EAAc,EAAIA,EAAc,MAAM,OAE3EN,EAAa,MAAM,MAAQ,GAAGM,CAAW,KACzCN,EAAa,MAAM,OAAS,GAAGO,CAAY,KAC3ClC,EAAW,QAAQ,MAAM,MAAQ,GAAGiC,EAAc,EAAIA,EAAc,MAAM,KAC1EjC,EAAW,QAAQ,MAAM,OAAS,GAAGkC,EAAe,EAAIA,EAAe,MAAM,MAGjFlC,EAAW,QAAQ,MAAM,YAAc,GAAG4B,EAAeC,CAAa,EAC1E,EAAG,CAAC1B,GAAA,YAAAA,EAAS,WAAYU,CAAQ,CAAC,EAE5BsB,EAA6B,cAC9BC,GAAyB,CACtB,GAAI,EAACjC,GAAA,MAAAA,EAAS,WAAW,UAAW,CAACH,EAAW,QAAS,MAAO,CAAE,KAAM,EAAG,KAAM,EAAG,KAAM,EAAG,KAAM,CAAE,EAErG,IAAM0B,EAAcvB,GAAA,YAAAA,EAAS,WAAW,QAAQ,wBAC1CkC,EAAaD,IAAgB,OAAYA,EAAczB,EAEvD2B,EAActC,EAAW,QAAQ,kBAEvC,GAAI,CAACsC,EAAa,MAAO,CAAE,KAAM,EAAG,KAAM,EAAG,KAAM,EAAG,KAAM,CAAE,EAE9D,IAAIC,EAAgBD,EAAY,YAC5BE,EAAiBF,EAAY,aAEf,KAAK,IAAIzB,CAAQ,EAAI,MAAQ,KAG3C,CAAC0B,EAAeC,CAAc,EAAI,CAACA,EAAgBD,CAAa,GAGpE,IAAME,EAAcF,EAAgBF,EAC9BK,EAAeF,EAAiBH,EAEhCM,EAAiBjB,EAAY,MAAQ,EACrCkB,EAAiBlB,EAAY,OAAS,EAEtCmB,EAAkBJ,EAAc,EAChCK,EAAmBJ,EAAe,EAElCK,GAAOF,EAAkBF,EAAiBE,EAAkBF,EAAiB,EAC7EK,GAAOH,EAAkBF,EAAiB,EAAEE,EAAkBF,GAAkB,EAEhFM,GAAOH,EAAmBF,EAAiBE,EAAmBF,EAAiB,EAC/EM,GAAOJ,EAAmBF,EAAiB,EAAEE,EAAmBF,GAAkB,EAExF,MAAO,CAAE,KAAAI,GAAM,KAAAD,GAAM,KAAAG,GAAM,KAAAD,EAAK,CACpC,EACA,CAAC9C,GAAA,YAAAA,EAAS,WAAYQ,EAAOE,CAAQ,CACzC,EAEMsC,EAAe,cAAY,IAAM,CACnCvC,EAASV,CAAW,EAEpB,IAAMkD,EAAe,CACjB,WAAY,SACZ,QAAS,EACT,cAAe,OACf,WAAY,OACZ,YAAa,MACjB,EAEIjD,GAAA,MAAAA,EAAS,WAAW,SACpB,OAAO,OAAOA,GAAA,YAAAA,EAAS,WAAW,QAAQ,MAAOiD,CAAY,EAG7DjD,GAAA,MAAAA,EAAS,aAAa,SAEtB,OAAO,OAAOA,GAAA,YAAAA,EAAS,aAAa,QAAQ,WAAW,QAAQ,MAAOiD,CAAY,EAGlFjD,GAAA,MAAAA,EAAS,QAAQ,SACjB,OAAO,OAAOA,EAAQ,QAAQ,QAAQ,MAAOiD,CAAY,EAGzDjD,GAAA,MAAAA,EAAS,QAAQ,SACjB,OAAO,OAAOA,EAAQ,QAAQ,QAAQ,MAAOiD,CAAY,EAGzDpD,EAAW,UACXA,EAAW,QAAQ,MAAM,OAAS,WAClCA,EAAW,QAAQ,MAAM,cAAgB,OAEjD,EAAG,CAACE,EAAaC,GAAA,YAAAA,EAAS,WAAYA,GAAA,YAAAA,EAAS,aAAcA,GAAA,YAAAA,EAAS,QAASA,GAAA,YAAAA,EAAS,OAAO,CAAC,EAE1FkD,EAAgB,cAAY,IAAM,CACpCzC,EAASX,CAAW,EACpBS,EAAY,CAAE,EAAG,EAAG,EAAG,CAAE,CAAC,EAE1B,IAAM4C,EAAc,CAChB,WAAY,GACZ,QAAS,GACT,cAAe,GACf,WAAY,GACZ,YAAa,EACjB,EAEInD,GAAA,MAAAA,EAAS,WAAW,SACpB,OAAO,OAAOA,EAAQ,WAAW,QAAQ,MAAOmD,CAAW,EAG3DnD,GAAA,MAAAA,EAAS,aAAa,SAEtB,OAAO,OAAOA,EAAQ,aAAa,QAAQ,WAAW,QAAQ,MAAOmD,CAAW,EAGhFnD,GAAA,MAAAA,EAAS,QAAQ,SACjB,OAAO,OAAOA,EAAQ,QAAQ,QAAQ,MAAOmD,CAAW,EAGxDnD,GAAA,MAAAA,EAAS,QAAQ,SACjB,OAAO,OAAOA,EAAQ,QAAQ,QAAQ,MAAOmD,CAAW,EAGxDtD,EAAW,UACXA,EAAW,QAAQ,MAAM,OAAS,UAClCA,EAAW,QAAQ,MAAM,cAAgB,OAEjD,EAAG,CAACC,EAAaE,GAAA,YAAAA,EAAS,WAAYA,GAAA,YAAAA,EAAS,aAAcA,GAAA,YAAAA,EAAS,QAASA,GAAA,YAAAA,EAAS,OAAO,CAAC,EAE1FoD,GAAa,IAAM,CAChBvD,EAAW,UAEhBA,EAAW,QAAQ,MAAM,WAAa,OACtCc,EAAa0C,GAASA,EAAO,EAAE,EAC/B,WAAW,IAAM,CACTxD,EAAW,UACXA,EAAW,QAAQ,MAAM,WAAa,GAE9C,EAAG,CAAC,EACR,EAEMyD,GAAc,IAAM,CACjBzD,EAAW,UAEhBA,EAAW,QAAQ,MAAM,WAAa,OACtCc,EAAa0C,GAASA,EAAO,EAAE,EAC/B,WAAW,IAAM,CACTxD,EAAW,UACXA,EAAW,QAAQ,MAAM,WAAa,GAE9C,EAAG,CAAC,EACR,EAEM0D,GAAQ,IAAM,CAChB1C,EAASwC,GAAUG,EAAAC,EAAA,GAAKJ,GAAL,CAAW,EAAG,KAAK,KAAKA,EAAK,CAAC,EAAI,EAAG,EAAE,CAC9D,EAEMK,GAAQ,IAAM,CAChB7C,EAASwC,GAAUG,EAAAC,EAAA,GAAKJ,GAAL,CAAW,EAAG,KAAK,KAAKA,EAAK,CAAC,EAAI,EAAG,EAAE,CAC9D,EAEMM,GAAW,IAAM,CACnB,GAAI,CAAC9D,EAAW,QAAS,OAEzB,IAAM2B,EAAe3B,EAAW,QAAQ,cAAc,KAAK,EAE3D,GAAI,CAAC2B,GAAgB,CAACA,EAAa,IAAK,OAExC,IAAMoC,EAAO,SAAS,cAAc,GAAG,EAEvCA,EAAK,KAAOpC,EAAa,IAEzB,IAAMqC,EAAWrC,EAAa,IAAI,MAAM,GAAG,EACrCsC,EAAWD,EAASA,EAAS,OAAS,CAAC,GAAK,YAElDD,EAAK,SAAWE,EAChBF,EAAK,OAAS,SAEd,SAAS,KAAK,YAAYA,CAAI,EAC9BA,EAAK,MAAM,EACX,SAAS,KAAK,YAAYA,CAAI,CAClC,EAEMG,GAAoB,cACrBC,GAAwB,CACrB,GAAI9C,EAAY,CACZC,EAAc,EAAK,EAEnB,MACJ,CAEA,GAAIX,IAAUV,EAAa,CACvB,GAAID,EAAW,QAAS,CACpB,IAAMoE,EAAWpE,EAAW,QAAQ,sBAAsB,EAEpDqE,EAAcD,EAAS,MAAQ,EAC/BE,EAAcF,EAAS,OAAS,EAEhCG,EAASJ,EAAE,QAAUC,EAAS,KAC9BI,EAASL,EAAE,QAAUC,EAAS,IAE9BK,EAAUJ,EAAcE,EACxBG,EAAUJ,EAAcE,EAExBG,EAAcF,GAAWvE,EAAc,GACvC0E,EAAcF,GAAWxE,EAAc,GAEvC2E,EAAc1C,EAAqBjC,CAAW,EAC9C4E,EAAe,KAAK,IAAID,EAAY,KAAM,KAAK,IAAIA,EAAY,KAAMF,CAAW,CAAC,EACjFI,EAAe,KAAK,IAAIF,EAAY,KAAM,KAAK,IAAIA,EAAY,KAAMD,CAAW,CAAC,EAEvFlE,EAAY,CAAE,EAAGoE,EAAc,EAAGC,CAAa,CAAC,CACpD,CAEA5B,EAAO,CACX,MACIE,EAAQ,CAEhB,EACA,CAAChC,EAAYpB,EAAaC,EAAaiC,EAAsBxB,EAAOwC,EAAQE,CAAO,CACvF,EACM2B,GAAwB,cAAab,GAAuC,CAC9EA,EAAE,eAAe,CACrB,EAAG,CAAC,CAAC,EAECc,GAA0B,cAC3Bd,GAA0B,CACvBA,EAAE,cAAc,kBAAkBA,EAAE,SAAS,EAC7C5C,EAAe,QAAQ,IAAI4C,EAAE,UAAW,CAAE,EAAGA,EAAE,QAAS,EAAGA,EAAE,OAAQ,CAAC,EAElExD,EAAQ,IACJwD,EAAE,cAAgB,SAClBjD,EAAc,EAAI,EAClBE,GAAa,CAAE,EAAG+C,EAAE,QAAU1D,EAAS,EAAG,EAAG0D,EAAE,QAAU1D,EAAS,CAAE,CAAC,EACrEa,EAAc,EAAK,GACZ6C,EAAE,cAAgB,SAAW5C,EAAe,QAAQ,OAAS,IACpEL,EAAc,EAAI,EAClBE,GAAa,CAAE,EAAG+C,EAAE,QAAU1D,EAAS,EAAG,EAAG0D,EAAE,QAAU1D,EAAS,CAAE,CAAC,EACrEa,EAAc,EAAK,EACnBE,EAAgB,QAAU,IAI9B2C,EAAE,cAAgB,SAAW5C,EAAe,QAAQ,OAAS,IAC7DC,EAAgB,QAAU,EAElC,EACA,CAACb,EAAOF,CAAQ,CACpB,EAEMyE,GAA0B,cAC3Bf,GAA0B,CACvB,GAAI,CAAC5C,EAAe,QAAQ,IAAI4C,EAAE,SAAS,GAAK,CAACnE,EAAW,QAAS,OAErEA,EAAW,QAAQ,MAAM,WAAa,OAGhBA,EAAW,QAAQ,MAAM,SAG3CA,EAAW,QAAQ,MAAM,OAASW,EAAQV,EAAc,WAAa,WAGzEsB,EAAe,QAAQ,IAAI4C,EAAE,UAAW,CAAE,EAAGA,EAAE,QAAS,EAAGA,EAAE,OAAQ,CAAC,EAEtE,IAAMgB,EAAW,MAAM,KAAK5D,EAAe,QAAQ,OAAO,CAAC,EAE3D,GAAI4D,EAAS,SAAW,EAAG,CACvB,GAAM,CAACC,EAAIC,CAAE,EAAIF,EACXG,EAAW,KAAK,MAAMD,EAAG,EAAID,EAAG,EAAGC,EAAG,EAAID,EAAG,CAAC,EAEpD,GAAI5D,EAAgB,QAAU,EAAG,CAC7B,IAAM+D,GAASD,EAAW9D,EAAgB,SAAW,IAErD,GAAI,KAAK,IAAI+D,CAAK,EAAI,IAAM,CACxB,IAAMC,EAAW7E,IAAUV,EAAcC,EAAcD,EAEjD4E,EAAc1C,EAAqBqD,CAAQ,EAC3CV,EAAe,KAAK,IAAID,EAAY,KAAM,KAAK,IAAIA,EAAY,KAAMpE,EAAS,CAAC,CAAC,EAChFsE,EAAe,KAAK,IAAIF,EAAY,KAAM,KAAK,IAAIA,EAAY,KAAMpE,EAAS,CAAC,CAAC,EAEtFC,EAAY,CAAE,EAAGoE,EAAc,EAAGC,CAAa,CAAC,EAEhDnE,EAAS4E,CAAQ,CACrB,CACJ,CAEAhE,EAAgB,QAAU8D,CAC9B,SAAWH,EAAS,SAAW,GAAKlE,EAAY,CAC5C,IAAMwE,EAAUN,EAAS,CAAC,EACpBO,EAAOD,EAAQ,EAAItE,EAAU,EAC7BwE,EAAOF,EAAQ,EAAItE,EAAU,EAC7B0D,EAAc1C,EAAqB,EAEnCyD,EAAY,KAAK,IAAIf,EAAY,KAAM,KAAK,IAAIA,EAAY,KAAMa,CAAI,CAAC,EACvEG,EAAY,KAAK,IAAIhB,EAAY,KAAM,KAAK,IAAIA,EAAY,KAAMc,CAAI,CAAC,EAE7EjF,EAAY,CACR,EAAGkF,EACH,EAAGC,CACP,CAAC,EACDvE,EAAc,EAAI,CACtB,CACJ,EACA,CAACL,EAAYE,EAAWR,EAAOV,EAAaC,EAAaO,EAAU0B,CAAoB,CAC3F,EAEM2D,GAAwB,cAAa3B,GAA0B,CAC5DnE,EAAW,UAEhBA,EAAW,QAAQ,MAAM,WAAa,GAEtCA,EAAW,QAAQ,MAAM,OAASW,EAAQV,EAAc,WAAa,UACrEkE,EAAE,cAAc,sBAAsBA,EAAE,SAAS,EACjD5C,EAAe,QAAQ,OAAO4C,EAAE,SAAS,EAErC5C,EAAe,QAAQ,KAAO,IAAGC,EAAgB,QAAU,GAE3DD,EAAe,QAAQ,OAAS,GAChCL,EAAc,EAAK,EAE3B,EAAG,CAAC,CAAC,EAEC,YAAU,IAAM,CACdP,GAAS,GACTD,EAAY,CAAE,EAAG,EAAG,EAAG,CAAE,CAAC,CAElC,EAAG,CAACC,CAAK,CAAC,EAEJ,YAAU,IAAM,EACdR,GAAA,YAAAA,EAAS,MAAM,eAAgBE,GAAS,SAAS,aAAe,YAChEoB,EAAkB,CAE1B,EAAG,CAACtB,GAAA,YAAAA,EAAS,MAAM,YAAaE,EAAOoB,CAAiB,CAAC,EAEnD,YAAU,IAAM,EACdtB,GAAA,YAAAA,EAAS,MAAM,eAAgBE,GAC/BoB,EAAkB,CAE1B,EAAG,CAACZ,EAAUY,EAAmBtB,GAAA,YAAAA,EAAS,MAAM,YAAaE,CAAK,CAAC,EAE7D,YAAU,IAAM,EACdF,GAAA,YAAAA,EAAS,MAAM,eAAgBE,IAASF,GAAA,YAAAA,EAAS,MAAM,gBAAiB,QACxEsB,EAAkB,CAE1B,EAAG,CAACtB,GAAA,YAAAA,EAAS,MAAM,aAAcsB,EAAmBtB,GAAA,YAAAA,EAAS,MAAM,YAAaE,CAAK,CAAC,EAEhF,YAAU,IAAM,CAClB,IAAM0F,EAAe,IAAM,EACnB5F,GAAA,YAAAA,EAAS,MAAM,eAAgBE,GAC/BoB,EAAkB,CAE1B,EAEA,cAAO,iBAAiB,SAAUsE,CAAY,EAEvC,IAAM,OAAO,oBAAoB,SAAUA,CAAY,CAClE,EAAG,CAAC5F,GAAA,YAAAA,EAAS,MAAM,YAAaE,EAAOoB,CAAiB,CAAC,EAEnD,YAAU,IAAM,CAClB,GAAItB,GAAWH,EAAW,QAAS,CAC/B,IAAMK,EAAQF,EAAQ,aAAaH,EAAW,OAAyB,EAEvEM,EAASD,CAAK,CAClB,CACJ,EAAG,CAACF,CAAO,CAAC,EAEN,YAAU,IAAM,CAClB,IAAM6F,EAAqB7B,GAAmB,CAta1D,IAAA8B,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,IAuaoBN,EAAA9B,EAAE,SAAF,YAAA8B,EAAU,UAAW,UACrB9C,EAAO,IACA+C,EAAA/B,EAAE,SAAF,YAAA+B,EAAU,UAAW,WAC5B7C,EAAQ,IACD8C,EAAAhC,EAAE,SAAF,YAAAgC,EAAU,UAAW,cAC5B5C,GAAW,IACJ6C,EAAAjC,EAAE,SAAF,YAAAiC,EAAU,UAAW,eAC5B3C,GAAY,IACL4C,EAAAlC,EAAE,SAAF,YAAAkC,EAAU,UAAW,SAC5B3C,GAAM,IACC4C,EAAAnC,EAAE,SAAF,YAAAmC,EAAU,UAAW,SAC5BzC,GAAM,IACC0C,EAAApC,EAAE,SAAF,YAAAoC,EAAU,UAAW,YAC5BzC,GAAS,CAEjB,EAEMxB,EAActC,EAAW,QAE/B,OAAIsC,IACAA,EAAY,iBAAiB,kBAAmB0D,CAAkC,EAClF1D,EAAY,iBAAiB,mBAAoB0D,CAAkC,EACnF1D,EAAY,iBAAiB,sBAAuB0D,CAAkC,EACtF1D,EAAY,iBAAiB,uBAAwB0D,CAAkC,EACvF1D,EAAY,iBAAiB,iBAAkB0D,CAAkC,EACjF1D,EAAY,iBAAiB,iBAAkB0D,CAAkC,EACjF1D,EAAY,iBAAiB,mBAAoB0D,CAAkC,GAGhF,IAAM,CACL1D,IACAA,EAAY,oBAAoB,kBAAmB0D,CAAkC,EACrF1D,EAAY,oBAAoB,mBAAoB0D,CAAkC,EACtF1D,EAAY,oBAAoB,sBAAuB0D,CAAkC,EACzF1D,EAAY,oBAAoB,uBAAwB0D,CAAkC,EAC1F1D,EAAY,oBAAoB,iBAAkB0D,CAAkC,EACpF1D,EAAY,oBAAoB,iBAAkB0D,CAAkC,EACpF1D,EAAY,oBAAoB,mBAAoB0D,CAAkC,EAE9F,CACJ,EAAG,CAAC/F,EAAaC,CAAW,CAAC,EAEvB,YAAU,IAAM,EACdC,GAAA,YAAAA,EAAS,MAAM,eAAgBE,EAC/BG,EAAY,EAAI,EAEhBA,EAAY,EAAK,CAEzB,EAAG,CAACL,GAAA,YAAAA,EAAS,MAAM,YAAaE,CAAK,CAAC,EAEtC,IAAMmG,GAAmB,UAAQ,KACtB,CACH,cAAejG,CACnB,GACD,CAACA,CAAQ,CAAC,EAEPkG,GAAqB,UAAQ,KACxB,CACH,eAAgB,GAAGhG,EAAS,CAAC,KAC7B,eAAgB,GAAGA,EAAS,CAAC,KAC7B,UAAW,GAAGE,CAAK,GACnB,aAAc,GAAGE,CAAQ,MACzB,WAAYE,EAAK,EACjB,WAAYA,EAAK,CACrB,GACD,CAACN,EAAUE,EAAOE,EAAUE,CAAI,CAAC,EAapC,MAAO,CACH,MAZU,CACV,MAAAV,EACA,SAAAI,EACA,MAAAE,EACA,SAAAE,EACA,KAAAE,EACA,SAAAR,EACA,UAAAY,EACA,WAAAE,CACJ,EAII,WAAAmF,GACA,aAAAC,GACA,gBAAAX,GACA,kBAAAZ,GACA,kBAAAD,GACA,YAAAf,GACA,gBAAAc,GACA,OAAA7B,EACA,QAAAE,EACA,WAAAE,GACA,YAAAE,GACA,MAAAC,GACA,MAAAG,GACA,SAAAC,GACA,qBAAA3B,EACA,kBAAAV,CACJ,CACJ,CACJ,CAAC","names":["withHeadless","Component","useGallery","styles","mergeProps","withComponentInCore","baseStyles","withComponent","name","defaultProps","styles","__spreadProps","__spreadValues","baseStyles","components","setup","render","withComponentInCore","React","createOptionalContext","GalleryProvider","useGalleryContext","HeadlessGallery","defaultProps","__spreadProps","__spreadValues","Component","mergeProps","React","defaultCloseProps","GalleryBackdrop","withComponent","defaultCloseProps","useGalleryContext","instance","props","ptmi","gallery","rootProps","mergeProps","Component","Component","mergeProps","React","defaultContentProps","GalleryContent","withComponent","defaultContentProps","useGalleryContext","instance","props","ptmi","gallery","rootProps","mergeProps","Component","Component","useGalleryItem","mergeProps","React","createOptionalContext","GalleryItemProvider","useGalleryItemContext","HeadlessGallery","defaultProps","__spreadProps","__spreadValues","GalleryItem","withComponent","defaultProps","instance","gallery","useGalleryContext","galleryItem","useGalleryItem","__spreadProps","__spreadValues","id","props","ptmi","handleClick","handlePointerDown","handlePointerMove","handlePointerUp","handleDragStart","CSSVariables","attributes","rootProps","mergeProps","GalleryItemProvider","Component","Component","mergeProps","React","defaultNextProps","GalleryNext","withComponent","defaultNextProps","useGalleryContext","instance","_a","props","ptmi","gallery","rootProps","mergeProps","Component","Component","mergeProps","React","defaultPrevProps","GalleryPrev","withComponent","defaultPrevProps","useGalleryContext","instance","_a","props","ptmi","gallery","rootProps","mergeProps","Component","Component","mergeProps","Component","useCarousel","styles","mergeProps","React","createOptionalContext","CarouselProvider","useCarouselContext","HeadlessCarousel","defaultProps","__spreadProps","__spreadValues","Component","mergeProps","React","defaultContentProps","CarouselContent","withComponent","defaultContentProps","useCarouselContext","instance","props","ptmi","carousel","contentProps","mergeProps","viewportProps","__spreadValues","Component","Component","mergeProps","React","defaultIndicatorProps","CarouselIndicator","withComponent","defaultIndicatorProps","useCarouselContext","instance","_a","props","ptmi","carousel","contentProps","mergeProps","Component","Component","mergeProps","React","defaultIndicatorsProps","CarouselIndicators","withComponent","defaultIndicatorsProps","useCarouselContext","instance","_a","_b","props","ptmi","carousel","contentProps","mergeProps","Component","snap","i","CarouselIndicator","Component","mergeProps","React","defaultItemProps","CarouselItem","withComponent","defaultItemProps","useCarouselContext","instance","props","ptmi","carousel","rootProps","mergeProps","Component","Component","mergeProps","React","defaultNextProps","CarouselNext","withComponent","defaultNextProps","useCarouselContext","instance","props","ptmi","carousel","disabled","rootProps","mergeProps","Component","Component","mergeProps","React","defaultPrevProps","CarouselPrev","withComponent","defaultPrevProps","useCarouselContext","instance","props","ptmi","carousel","disabled","rootProps","mergeProps","Component","Carousel","withComponent","defaultProps","styles","instance","useCarousel","id","props","ptmi","cx","rootProps","mergeProps","CarouselProvider","Component","CarouselContent","CarouselItem","CarouselNext","CarouselPrev","CarouselIndicators","CarouselIndicator","React","defaultThumbnailProps","GalleryThumbnail","withComponent","defaultThumbnailProps","useGalleryContext","instance","props","ptmi","gallery","rootProps","mergeProps","Component","Carousel","Component","mergeProps","React","defaultThumbnailContentProps","GalleryThumbnailContent","withComponent","defaultThumbnailContentProps","useGalleryContext","instance","props","ptmi","gallery","rootProps","mergeProps","Component","Carousel","Component","mergeProps","React","defaultThumbnailItemProps","GalleryThumbnailItem","withComponent","defaultThumbnailItemProps","useGalleryContext","instance","props","ptmi","gallery","rootProps","mergeProps","Component","Carousel","Component","mergeProps","React","defaultToolbarProps","GalleryToolbar","withComponent","defaultToolbarProps","useGalleryContext","instance","props","ptmi","gallery","rootProps","mergeProps","Component","Component","mergeProps","React","defaultToolbarItemProps","GalleryToolbarItem","withComponent","defaultToolbarItemProps","useGalleryContext","instance","props","ptmi","gallery","rootProps","mergeProps","_a","Component","Gallery","withComponent","defaultProps","styles","instance","useGallery","id","props","ptmi","cx","rootProps","mergeProps","GalleryProvider","Component","GalleryBackdrop","GalleryContent","GalleryItem","GalleryNext","GalleryPrev","GalleryToolbar","GalleryToolbarItem","GalleryThumbnail","GalleryThumbnailContent","GalleryThumbnailItem","React","defaultItemProps","useGalleryItem","withHeadless","defaultItemProps","props","elementRef","normalScale","zoomedScale","gallery","useGalleryContext","index","setIndex","isActive","setIsActive","position","setPosition","scale","setScale","rotation","setRotation","flip","setFlip","isDragging","setIsDragging","dragStart","setDragStart","hasDragged","setHasDragged","pointerDataRef","lastDistanceRef","calculateItemSize","contentRect","imageElement","naturalWidth","naturalHeight","isRotated","naturalAspectRatio","contentAspectRatio","targetWidth","targetHeight","calculateConstraints","targetScale","scaleToUse","itemElement","originalWidth","originalHeight","scaledWidth","scaledHeight","contentCenterX","contentCenterY","halfScaledWidth","halfScaledHeight","maxX","minX","maxY","minY","zoomIn","hiddenStyles","zoomOut","resetStyles","rotateLeft","prev","rotateRight","flipX","__spreadProps","__spreadValues","flipY","download","link","urlParts","filename","handleClick","e","itemRect","itemCenterX","itemCenterY","clickX","clickY","offsetX","offsetY","zoomOffsetX","zoomOffsetY","constraints","constrainedX","constrainedY","handleDragStart","handlePointerDown","handlePointerMove","pointers","p1","p2","distance","delta","newScale","pointer","newX","newY","computedX","computedY","handlePointerUp","handleResize","handleCustomEvent","_a","_b","_c","_d","_e","_f","_g","attributes","CSSVariables"]}
@@ -0,0 +1,45 @@
1
+ import * as React from 'react';
2
+ export declare const useGalleryItem: (inProps?: unknown) => import("@primereact/types/core").HeadlessInstance<import("@primereact/types/shared/gallery").useGalleryItemProps, unknown, {
3
+ state: {
4
+ index: number;
5
+ position: {
6
+ x: number;
7
+ y: number;
8
+ };
9
+ scale: number;
10
+ rotation: number;
11
+ flip: {
12
+ x: number;
13
+ y: number;
14
+ };
15
+ isActive: boolean;
16
+ dragStart: {
17
+ x: number;
18
+ y: number;
19
+ };
20
+ hasDragged: boolean;
21
+ };
22
+ attributes: {
23
+ 'data-active': boolean;
24
+ };
25
+ CSSVariables: React.CSSProperties;
26
+ handlePointerUp: (e: React.PointerEvent) => void;
27
+ handlePointerMove: (e: React.PointerEvent) => void;
28
+ handlePointerDown: (e: React.PointerEvent) => void;
29
+ handleClick: (e: React.MouseEvent) => void;
30
+ handleDragStart: (e: React.DragEvent<HTMLDivElement>) => void;
31
+ zoomIn: () => void;
32
+ zoomOut: () => void;
33
+ rotateLeft: () => void;
34
+ rotateRight: () => void;
35
+ flipX: () => void;
36
+ flipY: () => void;
37
+ download: () => void;
38
+ calculateConstraints: (targetScale?: number) => {
39
+ minX: number;
40
+ maxX: number;
41
+ minY: number;
42
+ maxY: number;
43
+ };
44
+ calculateItemSize: () => void;
45
+ }>;
@@ -0,0 +1,2 @@
1
+ import type { useGalleryItemProps } from '@primereact/types/shared/gallery';
2
+ export declare const defaultItemProps: useGalleryItemProps;
@@ -0,0 +1,37 @@
1
+ import * as React from 'react';
2
+ export declare const useGallery: (inProps?: unknown) => import("@primereact/types/core").HeadlessInstance<import("@primereact/types/shared/gallery").useGalleryProps, unknown, {
3
+ state: {
4
+ isFullscreen: boolean;
5
+ activeIndex: number;
6
+ };
7
+ registerItem: (ref: HTMLDivElement | null) => number;
8
+ handleNext: () => void;
9
+ handlePrev: () => void;
10
+ createCustomEvent: (action: string) => () => void;
11
+ toggleFullScreen: () => void;
12
+ handleClickAction: (action?: string) => void;
13
+ actions: {
14
+ zoomIn: () => void;
15
+ zoomOut: () => void;
16
+ rotateLeft: () => void;
17
+ rotateRight: () => void;
18
+ flipX: () => void;
19
+ flipY: () => void;
20
+ download: () => void;
21
+ next: () => void;
22
+ prev: () => void;
23
+ toggleFullScreen: () => void;
24
+ };
25
+ contentRef: React.RefObject<HTMLDivElement | null>;
26
+ toolbarRef: React.RefObject<HTMLDivElement | null>;
27
+ thumbnailRef: React.RefObject<React.RefObject<(<I extends import("@primereact/types/core").ComponentInstance, T extends React.ElementType>(inProps?: (import("@primereact/types/core").GlobalComponentProps<I, unknown, T, unknown, unknown> & {} & {} & Omit<import("@primereact/types/shared").ExtractProps<T>, keyof import("@primereact/types/core").GlobalComponentProps<I_1, P, T_1, unknown, unknown>> & import("@primereact/types/shared/carousel").CarouselProps) | undefined) => React.JSX.Element | null) & {
28
+ Content: (<I extends import("@primereact/types/core").ComponentInstance, T extends React.ElementType>(inProps?: (import("@primereact/types/core").GlobalComponentProps<I, unknown, T, unknown, unknown> & {} & {} & Omit<import("@primereact/types/shared").ExtractProps<T>, keyof import("@primereact/types/core").GlobalComponentProps<I_1, P, T_1, unknown, unknown>> & import("@primereact/types/shared/carousel").CarouselContentProps) | undefined) => React.JSX.Element | null) & Record<string, unknown> & React.FC<{}>;
29
+ Item: (<I extends import("@primereact/types/core").ComponentInstance, T extends React.ElementType>(inProps?: (import("@primereact/types/core").GlobalComponentProps<I, unknown, T, unknown, unknown> & {} & {} & Omit<import("@primereact/types/shared").ExtractProps<T>, keyof import("@primereact/types/core").GlobalComponentProps<I_1, P, T_1, unknown, unknown>> & import("@primereact/types/shared/carousel").CarouselItemProps) | undefined) => React.JSX.Element | null) & Record<string, unknown> & React.FC<{}>;
30
+ Next: (<I extends import("@primereact/types/core").ComponentInstance, T extends React.ElementType>(inProps?: (import("@primereact/types/core").GlobalComponentProps<I, unknown, T, unknown, unknown> & {} & {} & Omit<import("@primereact/types/shared").ExtractProps<T>, keyof import("@primereact/types/core").GlobalComponentProps<I_1, P, T_1, unknown, unknown>> & import("@primereact/types/shared/carousel").CarouselNextProps) | undefined) => React.JSX.Element | null) & Record<string, unknown> & React.FC<{}>;
31
+ Prev: (<I extends import("@primereact/types/core").ComponentInstance, T extends React.ElementType>(inProps?: (import("@primereact/types/core").GlobalComponentProps<I, unknown, T, unknown, unknown> & {} & {} & Omit<import("@primereact/types/shared").ExtractProps<T>, keyof import("@primereact/types/core").GlobalComponentProps<I_1, P, T_1, unknown, unknown>> & import("@primereact/types/shared/carousel").CarouselPrevProps) | undefined) => React.JSX.Element | null) & Record<string, unknown> & React.FC<{}>;
32
+ Indicators: (<I extends import("@primereact/types/core").ComponentInstance, T extends React.ElementType>(inProps?: (import("@primereact/types/core").GlobalComponentProps<I, unknown, T, unknown, unknown> & {} & {} & Omit<import("@primereact/types/shared").ExtractProps<T>, keyof import("@primereact/types/core").GlobalComponentProps<I_1, P, T_1, unknown, unknown>> & import("@primereact/types/shared/carousel").CarouselIndicatorsProps) | undefined) => React.JSX.Element | null) & Record<string, unknown> & React.FC<{}>;
33
+ Indicator: (<I extends import("@primereact/types/core").ComponentInstance, T extends React.ElementType>(inProps?: (import("@primereact/types/core").GlobalComponentProps<I, unknown, T, unknown, unknown> & {} & {} & Omit<import("@primereact/types/shared").ExtractProps<T>, keyof import("@primereact/types/core").GlobalComponentProps<I_1, P, T_1, unknown, unknown>> & import("@primereact/types/shared/carousel").CarouselIndicatorProps) | undefined) => React.JSX.Element | null) & Record<string, unknown> & React.FC<{}>;
34
+ } & React.FC<{}>> | null>;
35
+ prevRef: React.RefObject<HTMLButtonElement | null>;
36
+ nextRef: React.RefObject<HTMLButtonElement | null>;
37
+ }>;
@@ -0,0 +1,2 @@
1
+ import type { useGalleryProps } from '@primereact/types/shared/gallery';
2
+ export declare const defaultProps: useGalleryProps;
File without changes
@@ -0,0 +1,2 @@
1
+ export * from './useInputNumber';
2
+ export * from './useInputNumber.props';
@@ -0,0 +1,2 @@
1
+ var ve=Object.defineProperty,Je=Object.defineProperties;var qe=Object.getOwnPropertyDescriptors;var fe=Object.getOwnPropertySymbols;var ze=Object.prototype.hasOwnProperty,Qe=Object.prototype.propertyIsEnumerable;var me=(r,R,x)=>R in r?ve(r,R,{enumerable:!0,configurable:!0,writable:!0,value:x}):r[R]=x,ge=(r,R)=>{for(var x in R||(R={}))ze.call(R,x)&&me(r,x,R[x]);if(fe)for(var x of fe(R))Qe.call(R,x)&&me(r,x,R[x]);return r},de=(r,R)=>Je(r,qe(R));import{withHeadless as Xe}from"@primereact/core/headless";import{useMountEffect as Ye,useUnmountEffect as Ze,useUpdateEffect as X}from"@primereact/hooks";import{clearSelection as en,getSelection as Re,isEmpty as nn,isNotEmpty as Ie}from"@primeuix/utils";import*as d from"react";var Ee={value:void 0,defaultValue:void 0,format:!0,locale:void 0,mode:"decimal",prefix:void 0,suffix:void 0,currency:void 0,currencyDisplay:void 0,useGrouping:!0,minFractionDigits:void 0,maxFractionDigits:void 0,roundingMode:void 0,min:void 0,max:void 0,step:1,allowEmpty:!0,highlightOnFocus:!1,target:void 0,onValueChange:void 0,onChange:void 0};var sn=Xe({name:"useInputNumber",defaultProps:Ee,setup({props:r}){let[R,x]=d.useState(!1),Y=d.useRef(null),j=d.useRef(null),U=d.useRef(null),Z=d.useRef(null),O=d.useRef(null),W=d.useRef(null),P=d.useRef(null),v=d.useRef(null),b=d.useRef(null),E=d.useRef(null),g=d.useRef(null),C=d.useRef(null),s=d.useRef(null),T=d.useRef(null),V=d.useRef(null),K=d.useRef(null),xe={focused:R},J=()=>{var e,n;return{localeMatcher:r.localeMatcher,style:r.mode,currency:r.currency,currencyDisplay:r.currencyDisplay,useGrouping:r.useGrouping,minimumFractionDigits:(e=r.minFractionDigits)!=null?e:void 0,maximumFractionDigits:(n=r.maxFractionDigits)!=null?n:void 0,roundingMode:r.roundingMode}},ee=()=>{Z.current=new Intl.NumberFormat(r.locale,J());let e=[...new Intl.NumberFormat(r.locale,{useGrouping:!1}).format(9876543210)].reverse(),n=new Map(e.map((t,u)=>[t,u]));b.current=new RegExp(`[${e.join("")}]`,"g"),E.current=be(),g.current=ye(),C.current=Me(),s.current=he(),T.current=Te(),V.current=Se(),K.current=t=>n.get(t)},B=e=>e.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),he=()=>{var n,t;let e=new Intl.NumberFormat(r.locale,de(ge({},J()),{useGrouping:!1}));return new RegExp(`[${e.format(1.1).replace((n=C.current)!=null?n:"","").trim().replace((t=b.current)!=null?t:"","")}]`,"g")},be=()=>{var n;let e=new Intl.NumberFormat(r.locale,{useGrouping:!0});return O.current=e.format(1e6).trim().replace((n=b.current)!=null?n:"","").charAt(0),new RegExp(`[${O.current}]`,"g")},ye=()=>{var n;let e=new Intl.NumberFormat(r.locale,{useGrouping:!1});return new RegExp(`[${e.format(-1).trim().replace((n=b.current)!=null?n:"","")}]`,"g")},Me=()=>{var e,n;if(r.currency){let t=new Intl.NumberFormat(r.locale,{style:"currency",currency:r.currency,currencyDisplay:r.currencyDisplay,minimumFractionDigits:0,maximumFractionDigits:0,roundingMode:r.roundingMode});return new RegExp(`[${t.format(1).replace(/\s/g,"").replace((e=b.current)!=null?e:"","").replace((n=E.current)!=null?n:"","")}]`,"g")}return new RegExp("[]","g")},Se=()=>{if(r.prefix)V.current=new RegExp(B(r.prefix),"g");else{let n=new Intl.NumberFormat(r.locale,{style:r.mode,currency:r.currency,currencyDisplay:r.currencyDisplay}).format(1).split("1")[0];V.current=new RegExp(B(n),"g")}return V.current},Te=()=>{if(r.suffix)T.current=new RegExp(B(r.suffix),"g");else{let n=new Intl.NumberFormat(r.locale,{style:r.mode,currency:r.currency,currencyDisplay:r.currencyDisplay,minimumFractionDigits:0,maximumFractionDigits:0,roundingMode:r.roundingMode}).format(1).split("1")[1];T.current=new RegExp(B(n),"g")}return T.current},p=e=>{if(e!=null){if(typeof e=="string"&&e==="-")return e;if(r.format){let n=new Intl.NumberFormat(r.locale,J()),t=typeof e=="string"?Number(e):e,u=n.format(t);return r.prefix&&(u=r.prefix+u),r.suffix&&(u=u+r.suffix),u}return e.toString()}return""},L=e=>{var t;let n=e.replace(T.current||"","").replace(V.current||"","").trim().replace(/\s/g,"").replace(C.current||"","");if(s.current&&g.current&&b.current){let u=new RegExp(`[${[...new Intl.NumberFormat(r.locale,{useGrouping:!1}).format(9876543210)].reverse().join("")}${new Intl.NumberFormat(r.locale).format(1.1).replace(/[0-9]/g,"")}${new Intl.NumberFormat(r.locale).format(-1).replace(/[0-9]/g,"")}]`,"g");n=((t=n.match(u))==null?void 0:t.join(""))||""}if(E.current&&(n=n.replace(E.current,"")),g.current&&(n=n.replace(g.current,"-")),s.current&&(n=n.replace(s.current,".")),b.current&&K.current&&(n=n.replace(b.current,u=>{let l=K.current?K.current(u):void 0;return l!==void 0?l.toString():""})),n){if(n==="-")return n;let u=+n;return isNaN(u)?null:u}return null},D=()=>{let e=u=>{var l,c,i,o;return u?"tagName"in u&&u.tagName==="INPUT"?u:"inputRef"in u&&((i=(c=(l=u.inputRef)==null?void 0:l.current)==null?void 0:c.elementRef)!=null&&i.current)?u.inputRef.current.elementRef.current:"elementRef"in u&&((o=u.elementRef)!=null&&o.current)?u.elementRef.current:null:null},n=null;r.target&&(n="current"in r.target?r.target.current:r.target);let t=n||Y.current;return e(t)},Le=(e,n)=>{let t=e.toString(),u=n.toString(),l=t.includes(".")?t.split(".")[1].length:0,c=u.includes(".")?u.split(".")[1].length:0,i=Math.max(l,c),o=Math.pow(10,i);return Math.round((e+n)*o)/o},q=(e,n,t)=>{if(r.readOnly)return;let u=n||500;G(),j.current=setTimeout(()=>{q(e,40,t)},u),z(e,t)},z=(e,n)=>{var u;let t=D();if(t){let l=((u=r.step)!=null?u:1)*n,c=L(t.value)||0,i=k(Le(c,l));ae(i,null,"spin",String(c)),N(e,i),ie(e,String(c),i)}},De=(e,n)=>{var t;if(!r.disabled){let u=D();u&&u.focus(),q(e,void 0,(t=n!=null?n:r.step)!=null?t:1),e.preventDefault()}},He=(e,n)=>{var t;if(!r.disabled){let u=D();u&&u.focus(),q(e,void 0,n!=null?n:((t=r.step)!=null?t:1)*-1),e.preventDefault()}},we=()=>{r.disabled||G()},ne=e=>{var n;r.disabled||r.readOnly||(v.current&&(e.target.value=(n=U.current)!=null?n:""),v.current=!1)},Ce=e=>{var S,F,w,a;if(r.readOnly)return;let n=e.target;if(e.altKey||e.ctrlKey||e.metaKey){v.current=!0,U.current=n.value;return}U.current=n.value;let t=(S=n.selectionStart)!=null?S:0,u=(F=n.selectionEnd)!=null?F:0,l=u-t,c=n.value,i=null;switch(e.code||e.key){case"ArrowUp":z(e,1),e.preventDefault();break;case"ArrowDown":z(e,-1),e.preventDefault();break;case"ArrowLeft":if(l>1){let f=H(c.charAt(t))?t+1:t+2;e.target.setSelectionRange(f,f)}else H(c.charAt(t-1))||e.preventDefault();break;case"ArrowRight":if(l>1){let f=u-1;e.target.setSelectionRange(f,f)}else H(c.charAt(t))||e.preventDefault();break;case"Tab":case"Enter":case"NumpadEnter":i=k(L(c)),e.target.value=p(i),e.target.setAttribute("aria-valuenow",i!=null?String(i):""),N(e,i);break;case"Backspace":{if(e.preventDefault(),t===u){t>=c.length&&P.current!==null&&(t=c.length-P.current.length,e.target.setSelectionRange(t,t));let f=c.charAt(t-1),{decimalCharIndex:I,decimalCharIndexWithoutPrefix:y}=re(c);if(H(f)){let h=oe(c);if(E.current&&E.current.test(f))E.current.lastIndex=0,i=c.slice(0,t-2)+c.slice(t-1);else if(s.current&&s.current.test(f))s.current&&(s.current.lastIndex=0),h?e.target.setSelectionRange(t-1,t-1):i=c.slice(0,t-1)+c.slice(t);else if(I>0&&t>I){let m=te()&&(r.minFractionDigits||0)<h?"":"0";i=c.slice(0,t-1)+m+c.slice(t)}else if(y===1){i=c.slice(0,t-1)+"0"+c.slice(t);let m=L(i);i=typeof m=="number"&&m>0?i:""}else i=c.slice(0,t-1)+c.slice(t)}M(e,i,null,"delete-single")}else i=le(c,t,u),M(e,i,null,"delete-range");break}case"Delete":if(e.preventDefault(),t===u){let f=c.charAt(t),{decimalCharIndex:I,decimalCharIndexWithoutPrefix:y}=re(c);if(H(f)){let h=oe(c);if(E.current&&E.current.test(f))E.current.lastIndex=0,i=c.slice(0,t)+c.slice(t+2);else if(s.current&&s.current.test(f))s.current.lastIndex=0,h?e.target.setSelectionRange(t+1,t+1):i=c.slice(0,t)+c.slice(t+1);else if(I>0&&t>I){let m=te()&&(r.minFractionDigits||0)<h?"":"0";i=c.slice(0,t)+m+c.slice(t+1)}else if(y===1){i=c.slice(0,t)+"0"+c.slice(t+1);let m=L(i);i=typeof m=="number"&&m>0?i:""}else i=c.slice(0,t)+c.slice(t+1)}M(e,i,null,"delete-back-single")}else i=le(c,t,u),M(e,i,null,"delete-range");break;case"Home":e.preventDefault(),Ie(r.min)&&N(e,(w=r.min)!=null?w:0);break;case"End":e.preventDefault(),Ie(r.max)&&N(e,(a=r.max)!=null?a:100);break;default:break}},Fe=e=>{if(r.readOnly)return;let n=e.key,t=Ve(n),u=Pe(n);e.code!=="Enter"&&e.preventDefault(),(Number(n)>=0&&Number(n)<=9||u||t)&&ue(e,n,{isDecimalSign:t,isMinusSign:u})},pe=e=>{var t;if(r.readOnly)return;e.preventDefault();let n=(t=e.clipboardData||window.clipboardData)==null?void 0:t.getData("Text");if(n){let u=L(n);u!=null&&ue(e,u.toString())}},Ne=()=>r.min===void 0||r.min===null||r.min<0,Pe=e=>g.current&&g.current.test(e)||e==="-"?(g.current&&(g.current.lastIndex=0),!0):!1,Ve=e=>{var n;return(n=r.locale)!=null&&n.includes("fr")&&[".",","].includes(e)||s.current&&s.current.test(e)?(s.current&&(s.current.lastIndex=0),!0):!1},te=()=>r.mode==="decimal",re=e=>{let n=s.current?e.search(s.current):-1;s.current&&(s.current.lastIndex=0);let t=e.replace(V.current||"","").trim().replace(/\s/g,"").replace(C.current||"",""),u=s.current?t.search(s.current):-1;return s.current&&(s.current.lastIndex=0),{decimalCharIndex:n,decimalCharIndexWithoutPrefix:u}},ke=e=>{let n=i=>{i&&(i.lastIndex=0)},t=s.current?e.search(s.current):-1;n(s.current);let u=g.current?e.search(g.current):-1;n(g.current);let l=T.current?e.search(T.current):-1;n(T.current);let c=C.current?e.search(C.current):-1;return n(C.current),{decimalCharIndex:t,minusCharIndex:u,suffixCharIndex:l,currencyCharIndex:c}},ue=(e,n,t={isDecimalSign:!1,isMinusSign:!1})=>{var f,I,y,h;let u=g.current?n.search(g.current):-1;if(g.current&&(g.current.lastIndex=0),!Ne()&&u!==-1)return;let l=(f=e.target.selectionStart)!=null?f:0,c=(I=e.target.selectionEnd)!=null?I:0,i=e.target.value.trim(),{decimalCharIndex:o,minusCharIndex:S,suffixCharIndex:F,currencyCharIndex:w}=ke(i),a;if(t.isMinusSign){let m=S===-1;(l===0||l===w+1)&&(a=i,(m||c!==0)&&(a=$(i,n,0,c)),M(e,a,n,"insert"))}else if(t.isDecimalSign)o>0&&l===o?M(e,i,n,"insert"):(o>l&&o<c||o===-1&&r.maxFractionDigits)&&(a=$(i,n,l,c),M(e,a,n,"insert"));else{let m=(h=(y=Z.current)==null?void 0:y.resolvedOptions().maximumFractionDigits)!=null?h:0,_=l!==c?"range-insert":"insert";if(o>0&&l>o){if(l+n.length-(o+1)<=m){let A=w>=l?w-1:F>=l?F:i.length;a=i.slice(0,l)+n+i.slice(l+n.length,A)+i.slice(A),M(e,a,n,_)}}else a=$(i,n,l,c),M(e,a,n,_)}},$=(e,n,t,u)=>{var c;if((n==="."?n:n.split(".")).length===2){let i=e.slice(t,u).search((c=s.current)!=null?c:"");return s.current&&(s.current.lastIndex=0),i>0?e.slice(0,t)+p(n)+e.slice(u):p(n)||e}else return u-t===e.length?p(n):t===0?n+e.slice(u):u===e.length?e.slice(0,t)+n:e.slice(0,t)+n+e.slice(u)},le=(e,n,t)=>{let u;return t-n===e.length?u="":n===0?u=e.slice(t):t===e.length?u=e.slice(0,n):u=e.slice(0,n)+e.slice(t),u},Q=()=>{var S;let e=D();if(!e)return 0;let n=e.value,t=(S=e.selectionStart)!=null?S:0,u=n.length,l=null,c=(W.current||"").length;n=n.replace(W.current||"",""),t=t-c;let i=n.charAt(t);if(H(i))return t+c;let o=t-1;for(;o>=0;)if(i=n.charAt(o),H(i)){l=o+c;break}else o--;if(l!==null)e.setSelectionRange&&e.setSelectionRange(l+1,l+1);else{for(o=t;o<u;)if(i=n.charAt(o),H(i)){l=o+c;break}else o++;l!==null&&e.setSelectionRange&&e.setSelectionRange(l,l)}return l||0},Ae=()=>{let e=D();if(!e)return;let n=e.value;!r.readOnly&&n!==Re()&&Q()},H=e=>e.length===1&&(b.current&&b.current.test(e)||s.current&&s.current.test(e)||E.current&&E.current.test(e)||g.current&&g.current.test(e))?(Oe(),!0):!1,Oe=()=>{b.current&&(b.current.lastIndex=0),s.current&&(s.current.lastIndex=0),E.current&&(E.current.lastIndex=0),g.current&&(g.current.lastIndex=0)},ce=()=>{var u,l;let e=(l=(u=r.value)!=null?u:r.defaultValue)!=null?l:null,n=Be(e);se(n);let t=k(e);e!==null&&e!==t&&N(null,t)},M=(e,n,t,u)=>{let l=e.target.value,c=null;n!=null&&(c=L(n),c=!c&&!r.allowEmpty?0:c,ae(c,t,u,n),ie(e,l,c))},Ke=(e,n)=>{if(n===null&&e!==null)return!0;if(n!=null){let t=typeof e=="string"?L(e):e;return n!==t}return!1},ie=(e,n,t)=>{r.onChange&&Ke(n,t)&&r.onChange({originalEvent:e,value:t})},k=e=>e==="-"||e==null?null:r.min!=null&&typeof r.min=="number"&&typeof e=="number"&&e<r.min?r.min:r.max!=null&&typeof r.max=="number"&&typeof e=="number"&&e>r.max?r.max:e,Be=e=>nn(e)?null:r.min!==void 0&&r.min!==null&&e!==null&&e<r.min?r.min:r.max!==void 0&&r.max!==null&&e!==null&&e>r.max?r.max:e,ae=(e,n,t,u)=>{var S,F;n=n||"";let l=D();if(!l)return;let c=l.value,i=p(e),o=c.length;if(i!==u&&(i=Ge(i,u)),o===0){l.value=i,l.setSelectionRange&&l.setSelectionRange(0,0);let a=Q()+n.length;l.setSelectionRange&&l.setSelectionRange(a,a)}else{let w=(S=l.selectionStart)!=null?S:0,a=(F=l.selectionEnd)!=null?F:0;l.value=i;let f=i.length;if(t==="range-insert"){let I=L((c||"").slice(0,w)),h=(I!==null?I.toString():"").split("").join(`(${O.current})?`),m=new RegExp(h,"g");m.test(i);let _=n.split("").join(`(${O.current})?`),A=new RegExp(_,"g");A.test(i.slice(m.lastIndex)),a=m.lastIndex+A.lastIndex,l.setSelectionRange&&l.setSelectionRange(a,a)}else if(f===o)t==="insert"||t==="delete-back-single"?l.setSelectionRange&&l.setSelectionRange(a+1,a+1):t==="delete-single"?l.setSelectionRange&&l.setSelectionRange(a-1,a-1):(t==="delete-range"||t==="spin")&&l.setSelectionRange&&l.setSelectionRange(a,a);else if(t==="delete-back-single"){let I=c.charAt(a-1),y=c.charAt(a),h=o-f,m=E.current?E.current.test(y):!1;m&&h===1?a+=1:!m&&H(I)&&(a+=-1*h+1),E.current&&(E.current.lastIndex=0),l.setSelectionRange&&l.setSelectionRange(a,a)}else if(c==="-"&&t==="insert"){l.setSelectionRange&&l.setSelectionRange(0,0);let y=Q()+n.length+1;l.setSelectionRange&&l.setSelectionRange(y,y)}else a=a+(f-o),l.setSelectionRange&&l.setSelectionRange(a,a)}l.setAttribute("aria-valuenow",String(e))},$e=e=>{var n;return!e&&!r.allowEmpty?(n=r.min)!=null?n:0:e},se=e=>{e=$e(e);let n=D();if(!n)return;let t=n.value,u=p(e);t!==u&&(n.value=u,n.setAttribute("aria-valuenow",String(e)))},Ge=(e,n)=>{if(e&&n){let t=s.current,u=t?n.search(t):-1;if(t&&(t.lastIndex=0),P.current)return u!==-1?e.replace(P.current,"").split(t!=null?t:"")[0]+n.replace(P.current,"").slice(u)+P.current:e;if(W.current)return u!==-1?e.split(t!=null?t:"")[0]+n.slice(u):e}return e},oe=e=>{var n,t,u;if(e){let l=e.split((n=s.current)!=null?n:"");if(l.length===2)return l[1].replace((t=T.current)!=null?t:"","").trim().replace(/\s/g,"").replace((u=C.current)!=null?u:"","").length}return 0},N=(e,n)=>{if(r.onValueChange){let t;e?t=e:t={target:D()},r.onValueChange({originalEvent:t,value:n})}},_e=e=>{x(!0);let n=D();!r.disabled&&!r.readOnly&&(n==null?void 0:n.value)!==Re()&&r.highlightOnFocus&&e.target.select()},je=e=>{x(!1);let n=e.target,t=k(L(n.value));n.value=p(t),n.setAttribute("aria-valuenow",String(t)),N(e,t),!r.disabled&&!r.readOnly&&r.highlightOnFocus&&en()},G=()=>{j.current&&clearInterval(j.current)},Ue=()=>{var e,n;return r.max!==void 0&&((n=(e=r.value)!=null?e:r.defaultValue)!=null?n:0)>=r.max},We=()=>{var e,n;return r.min!==void 0&&((n=(e=r.value)!=null?e:r.defaultValue)!=null?n:0)<=r.min};return Ze(()=>{G()}),Ye(()=>{var u,l;ee();let e=(l=(u=r.value)!=null?u:r.defaultValue)!=null?l:null,n=k(e);se(typeof n=="number"?n:null),e!==null&&e!==n&&N(null,n)}),X(()=>{ee(),ce()},[r.locale,r.localeMatcher,r.mode,r.currency,r.currencyDisplay,r.useGrouping,r.minFractionDigits,r.maxFractionDigits,r.suffix,r.prefix]),X(()=>{ce()},[r.value,r.defaultValue]),X(()=>{r.disabled&&G()},[r.disabled]),{state:xe,inputRef:Y,onChange:ne,onInput:ne,onInputKeyDown:Ce,onInputKeyPress:Fe,onInputClick:Ae,onPaste:pe,onInputFocus:_e,onInputBlur:je,onValueChange:r.onValueChange,maxBoundry:Ue,minBoundry:We,increment:De,decrement:He,stopSpin:we}}});export{Ee as defaultProps,sn as useInputNumber};
2
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/inputnumber/useInputNumber.ts","../../src/inputnumber/useInputNumber.props.ts"],"sourcesContent":["import { withHeadless } from '@primereact/core/headless';\nimport { useMountEffect, useUnmountEffect, useUpdateEffect } from '@primereact/hooks';\nimport { useInputNumberProps } from '@primereact/types/shared/inputnumber';\nimport { clearSelection, getSelection, isEmpty, isNotEmpty } from '@primeuix/utils';\nimport * as React from 'react';\nimport { defaultProps } from './useInputNumber.props';\n\nexport const useInputNumber = withHeadless({\n name: 'useInputNumber',\n defaultProps,\n setup({ props }) {\n const [focused, setFocused] = React.useState<boolean>(false);\n const inputRef = React.useRef<{ elementRef: React.RefObject<HTMLInputElement> } | null>(null);\n const timer = React.useRef<NodeJS.Timeout | null>(null);\n const lastValue = React.useRef<string | null>(null);\n const numberFormat = React.useRef<Intl.NumberFormat | null>(null);\n const groupChar = React.useRef<string | null>(null);\n const prefixChar = React.useRef<string | null>(null);\n const suffixChar = React.useRef<string | null>(null);\n const isSpecialChar = React.useRef<boolean | null>(null);\n const _numeral = React.useRef<RegExp | null>(null);\n const _group = React.useRef<RegExp | null>(null);\n const _minusSign = React.useRef<RegExp | null>(null);\n const _currency = React.useRef<RegExp | null>(null);\n const _decimal = React.useRef<RegExp | null>(null);\n const _suffix = React.useRef<RegExp | null>(null);\n const _prefix = React.useRef<RegExp | null>(null);\n const _index = React.useRef<((d: string) => number | undefined) | null>(null);\n\n const state = {\n focused\n };\n\n const getOptions = () => {\n return {\n localeMatcher: props.localeMatcher,\n style: props.mode,\n currency: props.currency,\n currencyDisplay: props.currencyDisplay,\n useGrouping: props.useGrouping,\n minimumFractionDigits: props.minFractionDigits ?? undefined,\n maximumFractionDigits: props.maxFractionDigits ?? undefined,\n roundingMode: props.roundingMode\n };\n };\n\n const constructParser = () => {\n numberFormat.current = new Intl.NumberFormat(props.locale, getOptions());\n const numerals = [...new Intl.NumberFormat(props.locale, { useGrouping: false }).format(9876543210)].reverse();\n const index = new Map(numerals.map((d, i) => [d, i]));\n\n _numeral.current = new RegExp(`[${numerals.join('')}]`, 'g');\n _group.current = getGroupingExpression();\n _minusSign.current = getMinusSignExpression();\n _currency.current = getCurrencyExpression();\n _decimal.current = getDecimalExpression();\n _suffix.current = getSuffixExpression();\n _prefix.current = getPrefixExpression();\n _index.current = (d) => index.get(d);\n };\n\n const escapeRegExp = (text: string) => {\n return text.replace(/[-[\\]{}()*+?.,\\\\^$|#\\s]/g, '\\\\$&');\n };\n\n const getDecimalExpression = () => {\n const formatter = new Intl.NumberFormat(props.locale, { ...getOptions(), useGrouping: false });\n\n return new RegExp(\n `[${formatter\n .format(1.1)\n .replace(_currency.current ?? '', '')\n .trim()\n .replace(_numeral.current ?? '', '')}]`,\n 'g'\n );\n };\n\n const getGroupingExpression = () => {\n const formatter = new Intl.NumberFormat(props.locale, { useGrouping: true });\n\n groupChar.current = formatter\n .format(1000000)\n .trim()\n .replace(_numeral.current ?? '', '')\n .charAt(0);\n\n return new RegExp(`[${groupChar.current}]`, 'g');\n };\n\n const getMinusSignExpression = () => {\n const formatter = new Intl.NumberFormat(props.locale, { useGrouping: false });\n\n return new RegExp(\n `[${formatter\n .format(-1)\n .trim()\n .replace(_numeral.current ?? '', '')}]`,\n 'g'\n );\n };\n\n const getCurrencyExpression = () => {\n if (props.currency) {\n const formatter = new Intl.NumberFormat(props.locale, { style: 'currency', currency: props.currency, currencyDisplay: props.currencyDisplay, minimumFractionDigits: 0, maximumFractionDigits: 0, roundingMode: props.roundingMode });\n\n return new RegExp(\n `[${formatter\n .format(1)\n .replace(/\\s/g, '')\n .replace(_numeral.current ?? '', '')\n .replace(_group.current ?? '', '')}]`,\n 'g'\n );\n }\n\n return new RegExp(`[]`, 'g');\n };\n\n const getPrefixExpression = () => {\n if (props.prefix) {\n _prefix.current = new RegExp(escapeRegExp(props.prefix), 'g');\n } else {\n const formatter = new Intl.NumberFormat(props.locale, { style: props.mode, currency: props.currency, currencyDisplay: props.currencyDisplay });\n\n const prefixStr = formatter.format(1).split('1')[0];\n\n _prefix.current = new RegExp(escapeRegExp(prefixStr), 'g');\n }\n\n return _prefix.current;\n };\n\n const getSuffixExpression = () => {\n if (props.suffix) {\n _suffix.current = new RegExp(escapeRegExp(props.suffix), 'g');\n } else {\n const formatter = new Intl.NumberFormat(props.locale, { style: props.mode, currency: props.currency, currencyDisplay: props.currencyDisplay, minimumFractionDigits: 0, maximumFractionDigits: 0, roundingMode: props.roundingMode });\n\n const suffixStr = formatter.format(1).split('1')[1];\n\n _suffix.current = new RegExp(escapeRegExp(suffixStr), 'g');\n }\n\n return _suffix.current;\n };\n\n const formatValue = (value: number | string | null | undefined) => {\n if (value != null) {\n if (typeof value === 'string' && value === '-') {\n // Minus sign\n return value;\n }\n\n if (props.format) {\n const formatter = new Intl.NumberFormat(props.locale, getOptions());\n const numericValue = typeof value === 'string' ? Number(value) : value;\n let formattedValue = formatter.format(numericValue);\n\n if (props.prefix) {\n formattedValue = props.prefix + formattedValue;\n }\n\n if (props.suffix) {\n formattedValue = formattedValue + props.suffix;\n }\n\n return formattedValue;\n }\n\n return value.toString();\n }\n\n return '';\n };\n\n const parseValue = (text: string) => {\n let cleanText = text\n .replace(_suffix.current || '', '')\n .replace(_prefix.current || '', '')\n .trim()\n .replace(/\\s/g, '')\n .replace(_currency.current || '', '');\n\n if (_decimal.current && _minusSign.current && _numeral.current) {\n const validChars = new RegExp(\n `[${[...new Intl.NumberFormat(props.locale, { useGrouping: false }).format(9876543210)].reverse().join('')}${new Intl.NumberFormat(props.locale).format(1.1).replace(/[0-9]/g, '')}${new Intl.NumberFormat(props.locale)\n .format(-1)\n .replace(/[0-9]/g, '')}]`,\n 'g'\n );\n\n cleanText = cleanText.match(validChars)?.join('') || '';\n }\n\n if (_group.current) {\n cleanText = cleanText.replace(_group.current, '');\n }\n\n if (_minusSign.current) {\n cleanText = cleanText.replace(_minusSign.current, '-');\n }\n\n if (_decimal.current) {\n cleanText = cleanText.replace(_decimal.current, '.');\n }\n\n if (_numeral.current && _index.current) {\n cleanText = cleanText.replace(_numeral.current, (d) => {\n const res = _index.current ? _index.current(d) : undefined;\n\n return res !== undefined ? res.toString() : '';\n });\n }\n\n if (cleanText) {\n if (cleanText === '-') return cleanText;\n\n const parsedValue = +cleanText;\n\n return isNaN(parsedValue) ? null : parsedValue;\n }\n\n return null;\n };\n\n const getInputElement = (): HTMLInputElement | null => {\n const extractHTMLInput = (ref: HTMLInputElement | { elementRef?: React.RefObject<HTMLInputElement>; inputRef?: React.RefObject<{ elementRef: React.RefObject<HTMLInputElement> }> } | null): HTMLInputElement | null => {\n if (!ref) return null;\n\n if ('tagName' in ref && ref.tagName === 'INPUT') {\n return ref;\n } else {\n if ('inputRef' in ref && ref.inputRef?.current?.elementRef?.current) {\n return ref.inputRef.current.elementRef.current;\n }\n\n if ('elementRef' in ref && ref.elementRef?.current) {\n return ref.elementRef.current;\n }\n }\n\n return null;\n };\n\n let targetRef = null;\n\n if (props.target) {\n targetRef = 'current' in props.target ? props.target.current : props.target;\n }\n\n const refToUse = targetRef || inputRef.current;\n\n return extractHTMLInput(refToUse);\n };\n\n const addWithPrecision = (base: number, increment: number) => {\n const baseStr = base.toString();\n const stepStr = increment.toString();\n\n const baseDecimalPlaces = baseStr.includes('.') ? baseStr.split('.')[1].length : 0;\n const stepDecimalPlaces = stepStr.includes('.') ? stepStr.split('.')[1].length : 0;\n\n const maxDecimalPlaces = Math.max(baseDecimalPlaces, stepDecimalPlaces);\n const precision = Math.pow(10, maxDecimalPlaces);\n\n return Math.round((base + increment) * precision) / precision;\n };\n\n const repeat = (event: React.KeyboardEvent<HTMLInputElement> | React.MouseEvent<HTMLInputElement> | React.PointerEvent<HTMLButtonElement> | null, interval: number | undefined, dir: number) => {\n if (props.readOnly) {\n return;\n }\n\n const i = interval || 500;\n\n clearTimer();\n timer.current = setTimeout(() => {\n repeat(event, 40, dir);\n }, i);\n\n spin(event, dir);\n };\n\n const spin = (event: React.KeyboardEvent<HTMLInputElement> | React.MouseEvent<HTMLInputElement> | React.PointerEvent<HTMLButtonElement> | null, dir: number) => {\n const inputEl = getInputElement();\n\n if (inputEl) {\n const step = (props.step ?? 1) * dir;\n const currentValue = parseValue(inputEl.value) || 0;\n const newValue = validateValue(addWithPrecision(currentValue as number, step));\n\n updateInput(newValue as number, null, 'spin', String(currentValue));\n updateModel(event, newValue as useInputNumberProps['value']);\n handleOnInput(event, String(currentValue), newValue as number);\n }\n };\n\n const increment = (event: React.KeyboardEvent<HTMLInputElement> | React.MouseEvent<HTMLInputElement> | React.PointerEvent<HTMLButtonElement>, dir: number) => {\n if (!props.disabled) {\n const inputEl = getInputElement();\n\n if (inputEl) {\n inputEl.focus();\n }\n\n repeat(event, undefined, dir ?? props.step ?? 1);\n event.preventDefault();\n }\n };\n\n const decrement = (event: React.KeyboardEvent<HTMLInputElement> | React.MouseEvent<HTMLInputElement> | React.PointerEvent<HTMLButtonElement>, dir: number) => {\n if (!props.disabled) {\n const inputEl = getInputElement();\n\n if (inputEl) {\n inputEl.focus();\n }\n\n repeat(event, undefined, dir ?? (props.step ?? 1) * -1);\n event.preventDefault();\n }\n };\n\n const stopSpin = () => {\n if (!props.disabled) {\n clearTimer();\n }\n };\n\n const onInput = (event: React.ChangeEvent<HTMLInputElement>) => {\n if (props.disabled || props.readOnly) {\n return;\n }\n\n if (isSpecialChar.current) {\n (event.target as HTMLInputElement).value = lastValue.current ?? '';\n }\n\n isSpecialChar.current = false;\n };\n\n const onInputKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (props.readOnly) {\n return;\n }\n\n const inputElement = event.target as HTMLInputElement;\n\n if (event.altKey || event.ctrlKey || event.metaKey) {\n isSpecialChar.current = true;\n lastValue.current = inputElement.value;\n\n return;\n }\n\n lastValue.current = inputElement.value;\n\n let selectionStart = inputElement.selectionStart ?? 0;\n const selectionEnd = inputElement.selectionEnd ?? 0;\n const selectionRange = selectionEnd - selectionStart;\n const inputValue = inputElement.value;\n let newValueStr = null;\n const code = event.code || event.key;\n\n switch (code) {\n case 'ArrowUp':\n spin(event, 1);\n event.preventDefault();\n break;\n\n case 'ArrowDown':\n spin(event, -1);\n event.preventDefault();\n break;\n\n case 'ArrowLeft':\n if (selectionRange > 1) {\n const cursorPosition = isNumeralChar(inputValue.charAt(selectionStart)) ? selectionStart + 1 : selectionStart + 2;\n\n (event.target as HTMLInputElement).setSelectionRange(cursorPosition, cursorPosition);\n } else if (!isNumeralChar(inputValue.charAt(selectionStart - 1))) {\n event.preventDefault();\n }\n\n break;\n\n case 'ArrowRight':\n if (selectionRange > 1) {\n const cursorPosition = selectionEnd - 1;\n\n (event.target as HTMLInputElement).setSelectionRange(cursorPosition, cursorPosition);\n } else if (!isNumeralChar(inputValue.charAt(selectionStart))) {\n event.preventDefault();\n }\n\n break;\n\n case 'Tab':\n case 'Enter':\n case 'NumpadEnter':\n newValueStr = validateValue(parseValue(inputValue)) as useInputNumberProps['value'];\n (event.target as HTMLInputElement).value = formatValue(newValueStr);\n (event.target as HTMLInputElement).setAttribute('aria-valuenow', newValueStr != null ? String(newValueStr) : '');\n updateModel(event, newValueStr);\n break;\n\n case 'Backspace': {\n event.preventDefault();\n\n if (selectionStart === selectionEnd) {\n if (selectionStart >= inputValue.length && suffixChar.current !== null) {\n selectionStart = inputValue.length - suffixChar.current.length;\n (event.target as HTMLInputElement).setSelectionRange(selectionStart, selectionStart);\n }\n\n const deleteChar = inputValue.charAt(selectionStart - 1);\n const { decimalCharIndex, decimalCharIndexWithoutPrefix } = getDecimalCharIndexes(inputValue);\n\n if (isNumeralChar(deleteChar)) {\n const decimalLength = getDecimalLength(inputValue);\n\n if (_group.current && _group.current.test(deleteChar)) {\n _group.current.lastIndex = 0;\n\n newValueStr = inputValue.slice(0, selectionStart - 2) + inputValue.slice(selectionStart - 1);\n } else if (_decimal.current && _decimal.current.test(deleteChar)) {\n if (_decimal.current) {\n _decimal.current.lastIndex = 0;\n }\n\n if (decimalLength) {\n (event.target as HTMLInputElement).setSelectionRange(selectionStart - 1, selectionStart - 1);\n } else {\n newValueStr = inputValue.slice(0, selectionStart - 1) + inputValue.slice(selectionStart);\n }\n } else if (decimalCharIndex > 0 && selectionStart > decimalCharIndex) {\n const insertedText = isDecimalMode() && (props.minFractionDigits || 0) < decimalLength ? '' : '0';\n\n newValueStr = inputValue.slice(0, selectionStart - 1) + insertedText + inputValue.slice(selectionStart);\n } else if (decimalCharIndexWithoutPrefix === 1) {\n newValueStr = inputValue.slice(0, selectionStart - 1) + '0' + inputValue.slice(selectionStart);\n const parsed = parseValue(newValueStr);\n\n newValueStr = typeof parsed === 'number' && parsed > 0 ? newValueStr : '';\n } else {\n newValueStr = inputValue.slice(0, selectionStart - 1) + inputValue.slice(selectionStart);\n }\n }\n\n updateValue(event, newValueStr as string, null, 'delete-single');\n } else {\n newValueStr = deleteRange(inputValue, selectionStart, selectionEnd);\n updateValue(event, newValueStr, null, 'delete-range');\n }\n\n break;\n }\n\n case 'Delete':\n event.preventDefault();\n\n if (selectionStart === selectionEnd) {\n const deleteChar = inputValue.charAt(selectionStart);\n const { decimalCharIndex, decimalCharIndexWithoutPrefix } = getDecimalCharIndexes(inputValue);\n\n if (isNumeralChar(deleteChar)) {\n const decimalLength = getDecimalLength(inputValue);\n\n if (_group.current && _group.current.test(deleteChar)) {\n _group.current.lastIndex = 0;\n newValueStr = inputValue.slice(0, selectionStart) + inputValue.slice(selectionStart + 2);\n } else if (_decimal.current && _decimal.current.test(deleteChar)) {\n _decimal.current.lastIndex = 0;\n\n if (decimalLength) {\n (event.target as HTMLInputElement).setSelectionRange(selectionStart + 1, selectionStart + 1);\n } else {\n newValueStr = inputValue.slice(0, selectionStart) + inputValue.slice(selectionStart + 1);\n }\n } else if (decimalCharIndex > 0 && selectionStart > decimalCharIndex) {\n const insertedText = isDecimalMode() && (props.minFractionDigits || 0) < decimalLength ? '' : '0';\n\n newValueStr = inputValue.slice(0, selectionStart) + insertedText + inputValue.slice(selectionStart + 1);\n } else if (decimalCharIndexWithoutPrefix === 1) {\n newValueStr = inputValue.slice(0, selectionStart) + '0' + inputValue.slice(selectionStart + 1);\n const parsed = parseValue(newValueStr);\n\n newValueStr = typeof parsed === 'number' && parsed > 0 ? newValueStr : '';\n } else {\n newValueStr = inputValue.slice(0, selectionStart) + inputValue.slice(selectionStart + 1);\n }\n }\n\n updateValue(event, newValueStr as string, null, 'delete-back-single');\n } else {\n newValueStr = deleteRange(inputValue, selectionStart, selectionEnd);\n updateValue(event, newValueStr, null, 'delete-range');\n }\n\n break;\n\n case 'Home':\n event.preventDefault();\n\n if (isNotEmpty(props.min)) {\n updateModel(event, props.min ?? 0);\n }\n\n break;\n\n case 'End':\n event.preventDefault();\n\n if (isNotEmpty(props.max)) {\n updateModel(event, props.max ?? 100);\n }\n\n break;\n\n default:\n break;\n }\n };\n\n const onInputKeyPress = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (props.readOnly) {\n return;\n }\n\n const char = event.key;\n const isDecimalSign = isDecimalSignFn(char);\n const isMinusSign = isMinusSignFn(char);\n\n if (event.code !== 'Enter') {\n event.preventDefault();\n }\n\n if ((Number(char) >= 0 && Number(char) <= 9) || isMinusSign || isDecimalSign) {\n insert(event, char, { isDecimalSign, isMinusSign });\n }\n };\n\n const onPaste = (event: React.ClipboardEvent<HTMLInputElement>) => {\n if (props.readOnly) {\n return;\n }\n\n event.preventDefault();\n const data = (event.clipboardData || (window as Window & { clipboardData?: DataTransfer }).clipboardData)?.getData('Text');\n\n if (data) {\n const filteredData = parseValue(data);\n\n if (filteredData != null) {\n insert(event, filteredData.toString());\n }\n }\n };\n\n const allowMinusSign = () => {\n return props.min === undefined || props.min === null || props.min < 0;\n };\n\n const isMinusSignFn = (char: string) => {\n if ((_minusSign.current && _minusSign.current.test(char)) || char === '-') {\n if (_minusSign.current) {\n _minusSign.current.lastIndex = 0;\n }\n\n return true;\n }\n\n return false;\n };\n\n const isDecimalSignFn = (char: string) => {\n if ((props.locale?.includes('fr') && ['.', ','].includes(char)) || (_decimal.current && _decimal.current.test(char))) {\n if (_decimal.current) {\n _decimal.current.lastIndex = 0;\n }\n\n return true;\n }\n\n return false;\n };\n\n const isDecimalMode = () => {\n return props.mode === 'decimal';\n };\n\n const getDecimalCharIndexes = (val: string) => {\n const decimalCharIndex = _decimal.current ? val.search(_decimal.current) : -1;\n\n if (_decimal.current) {\n _decimal.current.lastIndex = 0;\n }\n\n const filteredVal = val\n .replace(_prefix.current || '', '')\n .trim()\n .replace(/\\s/g, '')\n .replace(_currency.current || '', '');\n const decimalCharIndexWithoutPrefix = _decimal.current ? filteredVal.search(_decimal.current) : -1;\n\n if (_decimal.current) {\n _decimal.current.lastIndex = 0;\n }\n\n return { decimalCharIndex, decimalCharIndexWithoutPrefix };\n };\n\n const getCharIndexes = (val: string) => {\n const resetRegexLastIndex = (regex: RegExp | null) => {\n if (regex) {\n regex.lastIndex = 0;\n }\n };\n\n const decimalCharIndex = _decimal.current ? val.search(_decimal.current) : -1;\n\n resetRegexLastIndex(_decimal.current);\n\n const minusCharIndex = _minusSign.current ? val.search(_minusSign.current) : -1;\n\n resetRegexLastIndex(_minusSign.current);\n\n const suffixCharIndex = _suffix.current ? val.search(_suffix.current) : -1;\n\n resetRegexLastIndex(_suffix.current);\n\n const currencyCharIndex = _currency.current ? val.search(_currency.current) : -1;\n\n resetRegexLastIndex(_currency.current);\n\n return { decimalCharIndex, minusCharIndex, suffixCharIndex, currencyCharIndex };\n };\n\n const insert = (event: React.KeyboardEvent<HTMLInputElement> | React.ClipboardEvent<HTMLInputElement>, text: string, sign = { isDecimalSign: false, isMinusSign: false }) => {\n const minusCharIndexOnText = _minusSign.current ? text.search(_minusSign.current) : -1;\n\n if (_minusSign.current) {\n _minusSign.current.lastIndex = 0;\n }\n\n if (!allowMinusSign() && minusCharIndexOnText !== -1) {\n return;\n }\n\n const selectionStart = (event.target as HTMLInputElement).selectionStart ?? 0;\n const selectionEnd = (event.target as HTMLInputElement).selectionEnd ?? 0;\n const inputValue = (event.target as HTMLInputElement).value.trim();\n const { decimalCharIndex, minusCharIndex, suffixCharIndex, currencyCharIndex } = getCharIndexes(inputValue);\n let newValueStr;\n\n if (sign.isMinusSign) {\n const isNewMinusSign = minusCharIndex === -1;\n\n if (selectionStart === 0 || selectionStart === currencyCharIndex + 1) {\n newValueStr = inputValue;\n\n if (isNewMinusSign || selectionEnd !== 0) {\n newValueStr = insertText(inputValue, text, 0, selectionEnd);\n }\n\n updateValue(event, newValueStr, text, 'insert');\n }\n } else if (sign.isDecimalSign) {\n if (decimalCharIndex > 0 && selectionStart === decimalCharIndex) {\n updateValue(event, inputValue, text, 'insert');\n } else if (decimalCharIndex > selectionStart && decimalCharIndex < selectionEnd) {\n newValueStr = insertText(inputValue, text, selectionStart, selectionEnd);\n updateValue(event, newValueStr, text, 'insert');\n } else if (decimalCharIndex === -1 && props.maxFractionDigits) {\n newValueStr = insertText(inputValue, text, selectionStart, selectionEnd);\n updateValue(event, newValueStr, text, 'insert');\n }\n } else {\n const maxFractionDigits = numberFormat.current?.resolvedOptions().maximumFractionDigits ?? 0;\n const operation = selectionStart !== selectionEnd ? 'range-insert' : 'insert';\n\n if (decimalCharIndex > 0 && selectionStart > decimalCharIndex) {\n if (selectionStart + text.length - (decimalCharIndex + 1) <= maxFractionDigits) {\n const charIndex = currencyCharIndex >= selectionStart ? currencyCharIndex - 1 : suffixCharIndex >= selectionStart ? suffixCharIndex : inputValue.length;\n\n newValueStr = inputValue.slice(0, selectionStart) + text + inputValue.slice(selectionStart + text.length, charIndex) + inputValue.slice(charIndex);\n updateValue(event, newValueStr, text, operation);\n }\n } else {\n newValueStr = insertText(inputValue, text, selectionStart, selectionEnd);\n updateValue(event, newValueStr, text, operation);\n }\n }\n };\n\n const insertText = (value: string, text: string, start: number, end: number) => {\n const textSplit = text === '.' ? text : text.split('.');\n\n if (textSplit.length === 2) {\n const decimalCharIndex = value.slice(start, end).search(_decimal.current ?? '');\n\n if (_decimal.current) {\n _decimal.current.lastIndex = 0;\n }\n\n return decimalCharIndex > 0 ? value.slice(0, start) + formatValue(text) + value.slice(end) : formatValue(text) || value;\n } else if (end - start === value.length) {\n return formatValue(text);\n } else if (start === 0) {\n return text + value.slice(end);\n } else if (end === value.length) {\n return value.slice(0, start) + text;\n } else {\n return value.slice(0, start) + text + value.slice(end);\n }\n };\n\n const deleteRange = (value: string, start: number, end: number) => {\n let newValueStr;\n\n if (end - start === value.length) newValueStr = '';\n else if (start === 0) newValueStr = value.slice(end);\n else if (end === value.length) newValueStr = value.slice(0, start);\n else newValueStr = value.slice(0, start) + value.slice(end);\n\n return newValueStr;\n };\n\n const initCursor = () => {\n const inputEl = getInputElement();\n\n if (!inputEl) return 0;\n\n let inputValue = inputEl.value;\n let selectionStart = inputEl.selectionStart ?? 0;\n const valueLength = inputValue.length;\n let index = null;\n\n // remove prefix\n const prefixLength = (prefixChar.current || '').length;\n\n inputValue = inputValue.replace(prefixChar.current || '', '');\n selectionStart = selectionStart - prefixLength;\n\n let char = inputValue.charAt(selectionStart);\n\n if (isNumeralChar(char)) {\n return selectionStart + prefixLength;\n }\n\n //left\n let i = selectionStart - 1;\n\n while (i >= 0) {\n char = inputValue.charAt(i);\n\n if (isNumeralChar(char)) {\n index = i + prefixLength;\n break;\n } else {\n i--;\n }\n }\n\n if (index !== null) {\n if (inputEl.setSelectionRange) inputEl.setSelectionRange(index + 1, index + 1);\n } else {\n i = selectionStart;\n\n while (i < valueLength) {\n char = inputValue.charAt(i);\n\n if (isNumeralChar(char)) {\n index = i + prefixLength;\n break;\n } else {\n i++;\n }\n }\n\n if (index !== null) {\n if (inputEl.setSelectionRange) inputEl.setSelectionRange(index, index);\n }\n }\n\n return index || 0;\n };\n\n const onInputClick = () => {\n const inputEl = getInputElement();\n\n if (!inputEl) return;\n\n const currentValue = inputEl.value;\n\n if (!props.readOnly && currentValue !== getSelection()) {\n initCursor();\n }\n };\n\n const isNumeralChar = (char: string) => {\n if (char.length === 1 && ((_numeral.current && _numeral.current.test(char)) || (_decimal.current && _decimal.current.test(char)) || (_group.current && _group.current.test(char)) || (_minusSign.current && _minusSign.current.test(char)))) {\n resetRegex();\n\n return true;\n }\n\n return false;\n };\n\n const resetRegex = () => {\n if (_numeral.current) _numeral.current.lastIndex = 0;\n\n if (_decimal.current) _decimal.current.lastIndex = 0;\n\n if (_group.current) _group.current.lastIndex = 0;\n\n if (_minusSign.current) _minusSign.current.lastIndex = 0;\n };\n\n const changeValue = () => {\n const _value = props.value ?? props.defaultValue ?? null;\n const val = validateValueByLimit(_value);\n\n updateInputValue(val);\n\n const newValue = validateValue(_value);\n\n if (_value !== null && _value !== newValue) {\n updateModel(null, newValue as useInputNumberProps['value']);\n }\n };\n\n const updateValue = (event: React.ChangeEvent<HTMLInputElement> | React.KeyboardEvent<HTMLInputElement> | React.ClipboardEvent<HTMLInputElement>, valueStr: string, insertedValueStr: string | null, operation: string) => {\n const currentValue = (event.target as HTMLInputElement).value;\n let newValue = null;\n\n if (valueStr != null) {\n newValue = parseValue(valueStr);\n newValue = !newValue && !props.allowEmpty ? 0 : newValue;\n\n updateInput(newValue, insertedValueStr, operation, valueStr);\n handleOnInput(event, currentValue, newValue);\n }\n };\n\n const isValueChanged = (currentValue: string | number | null, newValue: number | string | null) => {\n if (newValue === null && currentValue !== null) {\n return true;\n }\n\n if (newValue != null) {\n const parsedCurrentValue = typeof currentValue === 'string' ? parseValue(currentValue) : currentValue;\n\n return newValue !== parsedCurrentValue;\n }\n\n return false;\n };\n\n const handleOnInput = (\n event: React.ChangeEvent<HTMLInputElement> | React.KeyboardEvent<HTMLInputElement> | React.MouseEvent<HTMLInputElement> | React.ClipboardEvent<HTMLInputElement> | React.PointerEvent<HTMLButtonElement> | null,\n currentValue: string,\n newValue: number | string | null\n ) => {\n if (props.onChange && isValueChanged(currentValue, newValue)) {\n props.onChange({\n originalEvent: event,\n value: newValue as number\n });\n }\n };\n\n const validateValue = (value: number | string | null) => {\n if (value === '-' || value == null) {\n return null;\n }\n\n if (props.min != null && typeof props.min === 'number' && typeof value === 'number' && value < props.min) {\n return props.min;\n }\n\n if (props.max != null && typeof props.max === 'number' && typeof value === 'number' && value > props.max) {\n return props.max;\n }\n\n return value;\n };\n\n const validateValueByLimit = (value: number | null) => {\n if (isEmpty(value)) {\n return null;\n }\n\n if (props.min !== undefined && props.min !== null && value !== null && value < props.min) {\n return props.min;\n }\n\n if (props.max !== undefined && props.max !== null && value !== null && value > props.max) {\n return props.max;\n }\n\n return value;\n };\n\n const updateInput = (value: number | string | null, insertedValueStr: string | null, operation: string, valueStr: string) => {\n insertedValueStr = insertedValueStr || '';\n const inputEl = getInputElement();\n\n if (!inputEl) return;\n\n const inputValue = inputEl.value;\n\n let newValue = formatValue(value);\n const currentLength = inputValue.length;\n\n if (newValue !== valueStr) {\n newValue = concatValues(newValue, valueStr);\n }\n\n if (currentLength === 0) {\n inputEl.value = newValue;\n if (inputEl.setSelectionRange) inputEl.setSelectionRange(0, 0);\n\n const index = initCursor();\n const selectionEnd = index + insertedValueStr.length;\n\n if (inputEl.setSelectionRange) inputEl.setSelectionRange(selectionEnd, selectionEnd);\n } else {\n const selectionStart = inputEl.selectionStart ?? 0;\n let selectionEnd = inputEl.selectionEnd ?? 0;\n\n inputEl.value = newValue;\n const newLength = newValue.length;\n\n if (operation === 'range-insert') {\n const startValue = parseValue((inputValue || '').slice(0, selectionStart));\n const startValueStr = startValue !== null ? startValue.toString() : '';\n const startExpr = startValueStr.split('').join(`(${groupChar.current})?`);\n const sRegex = new RegExp(startExpr, 'g');\n\n sRegex.test(newValue);\n\n const tExpr = insertedValueStr.split('').join(`(${groupChar.current})?`);\n const tRegex = new RegExp(tExpr, 'g');\n\n tRegex.test(newValue.slice(sRegex.lastIndex));\n\n selectionEnd = sRegex.lastIndex + tRegex.lastIndex;\n if (inputEl.setSelectionRange) inputEl.setSelectionRange(selectionEnd, selectionEnd);\n } else if (newLength === currentLength) {\n if (operation === 'insert' || operation === 'delete-back-single') {\n if (inputEl.setSelectionRange) inputEl.setSelectionRange(selectionEnd + 1, selectionEnd + 1);\n } else if (operation === 'delete-single') {\n if (inputEl.setSelectionRange) inputEl.setSelectionRange(selectionEnd - 1, selectionEnd - 1);\n } else if (operation === 'delete-range' || operation === 'spin') {\n if (inputEl.setSelectionRange) inputEl.setSelectionRange(selectionEnd, selectionEnd);\n }\n } else if (operation === 'delete-back-single') {\n const prevChar = inputValue.charAt(selectionEnd - 1);\n const nextChar = inputValue.charAt(selectionEnd);\n const diff = currentLength - newLength;\n const isGroupChar = _group.current ? _group.current.test(nextChar) : false;\n\n if (isGroupChar && diff === 1) {\n selectionEnd += 1;\n } else if (!isGroupChar && isNumeralChar(prevChar)) {\n selectionEnd += -1 * diff + 1;\n }\n\n if (_group.current) {\n _group.current.lastIndex = 0;\n }\n\n if (inputEl.setSelectionRange) inputEl.setSelectionRange(selectionEnd, selectionEnd);\n } else if (inputValue === '-' && operation === 'insert') {\n if (inputEl.setSelectionRange) inputEl.setSelectionRange(0, 0);\n\n const index = initCursor();\n const selectionEnd = index + insertedValueStr.length + 1;\n\n if (inputEl.setSelectionRange) inputEl.setSelectionRange(selectionEnd, selectionEnd);\n } else {\n selectionEnd = selectionEnd + (newLength - currentLength);\n if (inputEl.setSelectionRange) inputEl.setSelectionRange(selectionEnd, selectionEnd);\n }\n }\n\n inputEl.setAttribute('aria-valuenow', String(value));\n };\n\n const evaluateEmpty = (newValue: useInputNumberProps['value']) => {\n return !newValue && !props.allowEmpty ? (props.min ?? 0) : newValue;\n };\n\n const updateInputValue = (newValue: useInputNumberProps['value']) => {\n newValue = evaluateEmpty(newValue);\n\n const inputEl = getInputElement();\n\n if (!inputEl) return;\n\n const value = inputEl.value;\n const _formattedValue = formatValue(newValue);\n\n if (value !== _formattedValue) {\n inputEl.value = _formattedValue;\n inputEl.setAttribute('aria-valuenow', String(newValue));\n }\n };\n\n const concatValues = (val1: string, val2: string) => {\n if (val1 && val2) {\n const decimalRegex = _decimal.current;\n const decimalCharIndex = decimalRegex ? val2.search(decimalRegex) : -1;\n\n if (decimalRegex) {\n decimalRegex.lastIndex = 0;\n }\n\n if (suffixChar.current) {\n return decimalCharIndex !== -1 ? val1.replace(suffixChar.current, '').split(decimalRegex ?? '')[0] + val2.replace(suffixChar.current, '').slice(decimalCharIndex) + suffixChar.current : val1;\n } else if (prefixChar.current) {\n return decimalCharIndex !== -1 ? val1.split(decimalRegex ?? '')[0] + val2.slice(decimalCharIndex) : val1;\n }\n }\n\n return val1;\n };\n\n const getDecimalLength = (value: string) => {\n if (value) {\n const valueSplit = value.split(_decimal.current ?? '');\n\n if (valueSplit.length === 2) {\n return valueSplit[1]\n .replace(_suffix.current ?? '', '')\n .trim()\n .replace(/\\s/g, '')\n .replace(_currency.current ?? '', '').length;\n }\n }\n\n return 0;\n };\n\n const updateModel = (\n event: React.ChangeEvent<HTMLInputElement> | React.KeyboardEvent<HTMLInputElement> | React.MouseEvent<HTMLInputElement> | React.PointerEvent<HTMLButtonElement> | React.PointerEvent<HTMLButtonElement> | null,\n value: useInputNumberProps['value']\n ) => {\n if (props.onValueChange) {\n let originalEvent;\n\n if (event) {\n originalEvent = event;\n } else {\n // Create a dummy synthetic event if event is null\n const inputEl = getInputElement();\n\n originalEvent = {\n ...({} as React.FormEvent<HTMLInputElement>),\n target: inputEl as EventTarget & HTMLInputElement\n };\n }\n\n props.onValueChange({\n originalEvent,\n value: value as number\n });\n }\n };\n\n const onInputFocus = (event: React.FocusEvent<HTMLInputElement>) => {\n setFocused(true);\n\n const inputEl = getInputElement();\n\n if (!props.disabled && !props.readOnly && inputEl?.value !== getSelection() && props.highlightOnFocus) {\n event.target.select();\n }\n };\n\n const onInputBlur = (event: React.FocusEvent<HTMLInputElement>) => {\n setFocused(false);\n\n const input = event.target as HTMLInputElement;\n const newValue = validateValue(parseValue(input.value)) as useInputNumberProps['value'];\n\n input.value = formatValue(newValue);\n input.setAttribute('aria-valuenow', String(newValue));\n updateModel(event, newValue);\n\n if (!props.disabled && !props.readOnly && props.highlightOnFocus) {\n clearSelection();\n }\n };\n\n const clearTimer = () => {\n if (timer.current) {\n clearInterval(timer.current);\n }\n };\n\n const maxBoundry = () => {\n return props.max !== undefined && (props.value ?? props.defaultValue ?? 0) >= props.max;\n };\n\n const minBoundry = () => {\n return props.min !== undefined && (props.value ?? props.defaultValue ?? 0) <= props.min;\n };\n\n useUnmountEffect(() => {\n clearTimer();\n });\n\n useMountEffect(() => {\n constructParser();\n\n const initialValue = props.value ?? props.defaultValue ?? null;\n const newValue = validateValue(initialValue as number | null);\n const valueForInput = typeof newValue === 'number' ? newValue : null;\n\n updateInputValue(valueForInput);\n\n if (initialValue !== null && initialValue !== newValue) {\n updateModel(null, newValue as number);\n }\n });\n\n useUpdateEffect(() => {\n constructParser();\n changeValue();\n }, [props.locale, props.localeMatcher, props.mode, props.currency, props.currencyDisplay, props.useGrouping, props.minFractionDigits, props.maxFractionDigits, props.suffix, props.prefix]);\n\n useUpdateEffect(() => {\n changeValue();\n }, [props.value, props.defaultValue]);\n\n useUpdateEffect(() => {\n if (props.disabled) {\n clearTimer();\n }\n }, [props.disabled]);\n\n return {\n state,\n inputRef,\n // methods\n onChange: onInput,\n onInput,\n onInputKeyDown,\n onInputKeyPress,\n onInputClick,\n onPaste,\n onInputFocus,\n onInputBlur,\n onValueChange: props.onValueChange,\n maxBoundry,\n minBoundry,\n increment,\n decrement,\n stopSpin\n };\n }\n});\n","import type { useInputNumberProps } from '@primereact/types/shared/inputnumber';\n\nexport const defaultProps: useInputNumberProps = {\n value: undefined,\n defaultValue: undefined,\n format: true,\n locale: undefined,\n mode: 'decimal',\n prefix: undefined,\n suffix: undefined,\n currency: undefined,\n currencyDisplay: undefined,\n useGrouping: true,\n minFractionDigits: undefined,\n maxFractionDigits: undefined,\n roundingMode: undefined,\n min: undefined,\n max: undefined,\n step: 1,\n allowEmpty: true,\n highlightOnFocus: false,\n target: undefined,\n onValueChange: undefined,\n onChange: undefined\n};\n"],"mappings":"+bAAA,OAAS,gBAAAA,OAAoB,4BAC7B,OAAS,kBAAAC,GAAgB,oBAAAC,GAAkB,mBAAAC,MAAuB,oBAElE,OAAS,kBAAAC,GAAgB,gBAAAC,GAAc,WAAAC,GAAS,cAAAC,OAAkB,kBAClE,UAAYC,MAAW,QCFhB,IAAMC,GAAoC,CAC7C,MAAO,OACP,aAAc,OACd,OAAQ,GACR,OAAQ,OACR,KAAM,UACN,OAAQ,OACR,OAAQ,OACR,SAAU,OACV,gBAAiB,OACjB,YAAa,GACb,kBAAmB,OACnB,kBAAmB,OACnB,aAAc,OACd,IAAK,OACL,IAAK,OACL,KAAM,EACN,WAAY,GACZ,iBAAkB,GAClB,OAAQ,OACR,cAAe,OACf,SAAU,MACd,EDjBO,IAAMC,GAAiBC,GAAa,CACvC,KAAM,iBACN,aAAAC,GACA,MAAM,CAAE,MAAAC,CAAM,EAAG,CACb,GAAM,CAACC,EAASC,CAAU,EAAU,WAAkB,EAAK,EACrDC,EAAiB,SAAiE,IAAI,EACtFC,EAAc,SAA8B,IAAI,EAChDC,EAAkB,SAAsB,IAAI,EAC5CC,EAAqB,SAAiC,IAAI,EAC1DC,EAAkB,SAAsB,IAAI,EAC5CC,EAAmB,SAAsB,IAAI,EAC7CC,EAAmB,SAAsB,IAAI,EAC7CC,EAAsB,SAAuB,IAAI,EACjDC,EAAiB,SAAsB,IAAI,EAC3CC,EAAe,SAAsB,IAAI,EACzCC,EAAmB,SAAsB,IAAI,EAC7CC,EAAkB,SAAsB,IAAI,EAC5CC,EAAiB,SAAsB,IAAI,EAC3CC,EAAgB,SAAsB,IAAI,EAC1CC,EAAgB,SAAsB,IAAI,EAC1CC,EAAe,SAAmD,IAAI,EAEtEC,GAAQ,CACV,QAAAlB,CACJ,EAEMmB,EAAa,IAAM,CAjCjC,IAAAC,EAAAC,EAkCY,MAAO,CACH,cAAetB,EAAM,cACrB,MAAOA,EAAM,KACb,SAAUA,EAAM,SAChB,gBAAiBA,EAAM,gBACvB,YAAaA,EAAM,YACnB,uBAAuBqB,EAAArB,EAAM,oBAAN,KAAAqB,EAA2B,OAClD,uBAAuBC,EAAAtB,EAAM,oBAAN,KAAAsB,EAA2B,OAClD,aAActB,EAAM,YACxB,CACJ,EAEMuB,GAAkB,IAAM,CAC1BjB,EAAa,QAAU,IAAI,KAAK,aAAaN,EAAM,OAAQoB,EAAW,CAAC,EACvE,IAAMI,EAAW,CAAC,GAAG,IAAI,KAAK,aAAaxB,EAAM,OAAQ,CAAE,YAAa,EAAM,CAAC,EAAE,OAAO,UAAU,CAAC,EAAE,QAAQ,EACvGyB,EAAQ,IAAI,IAAID,EAAS,IAAI,CAACE,EAAGC,IAAM,CAACD,EAAGC,CAAC,CAAC,CAAC,EAEpDhB,EAAS,QAAU,IAAI,OAAO,IAAIa,EAAS,KAAK,EAAE,CAAC,IAAK,GAAG,EAC3DZ,EAAO,QAAUgB,GAAsB,EACvCf,EAAW,QAAUgB,GAAuB,EAC5Cf,EAAU,QAAUgB,GAAsB,EAC1Cf,EAAS,QAAUgB,GAAqB,EACxCf,EAAQ,QAAUgB,GAAoB,EACtCf,EAAQ,QAAUgB,GAAoB,EACtCf,EAAO,QAAWQ,GAAMD,EAAM,IAAIC,CAAC,CACvC,EAEMQ,EAAgBC,GACXA,EAAK,QAAQ,2BAA4B,MAAM,EAGpDJ,GAAuB,IAAM,CAjE3C,IAAAV,EAAAC,EAkEY,IAAMc,EAAY,IAAI,KAAK,aAAapC,EAAM,OAAQqC,GAAAC,GAAA,GAAKlB,EAAW,GAAhB,CAAmB,YAAa,EAAM,EAAC,EAE7F,OAAO,IAAI,OACP,IAAIgB,EACC,OAAO,GAAG,EACV,SAAQf,EAAAP,EAAU,UAAV,KAAAO,EAAqB,GAAI,EAAE,EACnC,KAAK,EACL,SAAQC,EAAAX,EAAS,UAAT,KAAAW,EAAoB,GAAI,EAAE,CAAC,IACxC,GACJ,CACJ,EAEMM,GAAwB,IAAM,CA9E5C,IAAAP,EA+EY,IAAMe,EAAY,IAAI,KAAK,aAAapC,EAAM,OAAQ,CAAE,YAAa,EAAK,CAAC,EAE3E,OAAAO,EAAU,QAAU6B,EACf,OAAO,GAAO,EACd,KAAK,EACL,SAAQf,EAAAV,EAAS,UAAT,KAAAU,EAAoB,GAAI,EAAE,EAClC,OAAO,CAAC,EAEN,IAAI,OAAO,IAAId,EAAU,OAAO,IAAK,GAAG,CACnD,EAEMsB,GAAyB,IAAM,CA1F7C,IAAAR,EA2FY,IAAMe,EAAY,IAAI,KAAK,aAAapC,EAAM,OAAQ,CAAE,YAAa,EAAM,CAAC,EAE5E,OAAO,IAAI,OACP,IAAIoC,EACC,OAAO,EAAE,EACT,KAAK,EACL,SAAQf,EAAAV,EAAS,UAAT,KAAAU,EAAoB,GAAI,EAAE,CAAC,IACxC,GACJ,CACJ,EAEMS,GAAwB,IAAM,CAtG5C,IAAAT,EAAAC,EAuGY,GAAItB,EAAM,SAAU,CAChB,IAAMoC,EAAY,IAAI,KAAK,aAAapC,EAAM,OAAQ,CAAE,MAAO,WAAY,SAAUA,EAAM,SAAU,gBAAiBA,EAAM,gBAAiB,sBAAuB,EAAG,sBAAuB,EAAG,aAAcA,EAAM,YAAa,CAAC,EAEnO,OAAO,IAAI,OACP,IAAIoC,EACC,OAAO,CAAC,EACR,QAAQ,MAAO,EAAE,EACjB,SAAQf,EAAAV,EAAS,UAAT,KAAAU,EAAoB,GAAI,EAAE,EAClC,SAAQC,EAAAV,EAAO,UAAP,KAAAU,EAAkB,GAAI,EAAE,CAAC,IACtC,GACJ,CACJ,CAEA,OAAO,IAAI,OAAO,KAAM,GAAG,CAC/B,EAEMW,GAAsB,IAAM,CAC9B,GAAIjC,EAAM,OACNiB,EAAQ,QAAU,IAAI,OAAOiB,EAAalC,EAAM,MAAM,EAAG,GAAG,MACzD,CAGH,IAAMuC,EAFY,IAAI,KAAK,aAAavC,EAAM,OAAQ,CAAE,MAAOA,EAAM,KAAM,SAAUA,EAAM,SAAU,gBAAiBA,EAAM,eAAgB,CAAC,EAEjH,OAAO,CAAC,EAAE,MAAM,GAAG,EAAE,CAAC,EAElDiB,EAAQ,QAAU,IAAI,OAAOiB,EAAaK,CAAS,EAAG,GAAG,CAC7D,CAEA,OAAOtB,EAAQ,OACnB,EAEMe,GAAsB,IAAM,CAC9B,GAAIhC,EAAM,OACNgB,EAAQ,QAAU,IAAI,OAAOkB,EAAalC,EAAM,MAAM,EAAG,GAAG,MACzD,CAGH,IAAMwC,EAFY,IAAI,KAAK,aAAaxC,EAAM,OAAQ,CAAE,MAAOA,EAAM,KAAM,SAAUA,EAAM,SAAU,gBAAiBA,EAAM,gBAAiB,sBAAuB,EAAG,sBAAuB,EAAG,aAAcA,EAAM,YAAa,CAAC,EAEvM,OAAO,CAAC,EAAE,MAAM,GAAG,EAAE,CAAC,EAElDgB,EAAQ,QAAU,IAAI,OAAOkB,EAAaM,CAAS,EAAG,GAAG,CAC7D,CAEA,OAAOxB,EAAQ,OACnB,EAEMyB,EAAeC,GAA8C,CAC/D,GAAIA,GAAS,KAAM,CACf,GAAI,OAAOA,GAAU,UAAYA,IAAU,IAEvC,OAAOA,EAGX,GAAI1C,EAAM,OAAQ,CACd,IAAMoC,EAAY,IAAI,KAAK,aAAapC,EAAM,OAAQoB,EAAW,CAAC,EAC5DuB,EAAe,OAAOD,GAAU,SAAW,OAAOA,CAAK,EAAIA,EAC7DE,EAAiBR,EAAU,OAAOO,CAAY,EAElD,OAAI3C,EAAM,SACN4C,EAAiB5C,EAAM,OAAS4C,GAGhC5C,EAAM,SACN4C,EAAiBA,EAAiB5C,EAAM,QAGrC4C,CACX,CAEA,OAAOF,EAAM,SAAS,CAC1B,CAEA,MAAO,EACX,EAEMG,EAAcV,GAAiB,CAhL7C,IAAAd,EAiLY,IAAIyB,EAAYX,EACX,QAAQnB,EAAQ,SAAW,GAAI,EAAE,EACjC,QAAQC,EAAQ,SAAW,GAAI,EAAE,EACjC,KAAK,EACL,QAAQ,MAAO,EAAE,EACjB,QAAQH,EAAU,SAAW,GAAI,EAAE,EAExC,GAAIC,EAAS,SAAWF,EAAW,SAAWF,EAAS,QAAS,CAC5D,IAAMoC,EAAa,IAAI,OACnB,IAAI,CAAC,GAAG,IAAI,KAAK,aAAa/C,EAAM,OAAQ,CAAE,YAAa,EAAM,CAAC,EAAE,OAAO,UAAU,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,GAAG,IAAI,KAAK,aAAaA,EAAM,MAAM,EAAE,OAAO,GAAG,EAAE,QAAQ,SAAU,EAAE,CAAC,GAAG,IAAI,KAAK,aAAaA,EAAM,MAAM,EAClN,OAAO,EAAE,EACT,QAAQ,SAAU,EAAE,CAAC,IAC1B,GACJ,EAEA8C,IAAYzB,EAAAyB,EAAU,MAAMC,CAAU,IAA1B,YAAA1B,EAA6B,KAAK,MAAO,EACzD,CAsBA,GApBIT,EAAO,UACPkC,EAAYA,EAAU,QAAQlC,EAAO,QAAS,EAAE,GAGhDC,EAAW,UACXiC,EAAYA,EAAU,QAAQjC,EAAW,QAAS,GAAG,GAGrDE,EAAS,UACT+B,EAAYA,EAAU,QAAQ/B,EAAS,QAAS,GAAG,GAGnDJ,EAAS,SAAWO,EAAO,UAC3B4B,EAAYA,EAAU,QAAQnC,EAAS,QAAUe,GAAM,CACnD,IAAMsB,EAAM9B,EAAO,QAAUA,EAAO,QAAQQ,CAAC,EAAI,OAEjD,OAAOsB,IAAQ,OAAYA,EAAI,SAAS,EAAI,EAChD,CAAC,GAGDF,EAAW,CACX,GAAIA,IAAc,IAAK,OAAOA,EAE9B,IAAMG,EAAc,CAACH,EAErB,OAAO,MAAMG,CAAW,EAAI,KAAOA,CACvC,CAEA,OAAO,IACX,EAEMC,EAAkB,IAA+B,CACnD,IAAMC,EAAoBC,GAA8L,CAnOpO,IAAA/B,EAAAC,EAAA+B,EAAAC,EAoOgB,OAAKF,EAED,YAAaA,GAAOA,EAAI,UAAY,QAC7BA,EAEH,aAAcA,KAAOC,GAAA/B,GAAAD,EAAA+B,EAAI,WAAJ,YAAA/B,EAAc,UAAd,YAAAC,EAAuB,aAAvB,MAAA+B,EAAmC,SACjDD,EAAI,SAAS,QAAQ,WAAW,QAGvC,eAAgBA,KAAOE,EAAAF,EAAI,aAAJ,MAAAE,EAAgB,SAChCF,EAAI,WAAW,QAIvB,KAdU,IAerB,EAEIG,EAAY,KAEZvD,EAAM,SACNuD,EAAY,YAAavD,EAAM,OAASA,EAAM,OAAO,QAAUA,EAAM,QAGzE,IAAMwD,EAAWD,GAAapD,EAAS,QAEvC,OAAOgD,EAAiBK,CAAQ,CACpC,EAEMC,GAAmB,CAACC,EAAcC,IAAsB,CAC1D,IAAMC,EAAUF,EAAK,SAAS,EACxBG,EAAUF,EAAU,SAAS,EAE7BG,EAAoBF,EAAQ,SAAS,GAAG,EAAIA,EAAQ,MAAM,GAAG,EAAE,CAAC,EAAE,OAAS,EAC3EG,EAAoBF,EAAQ,SAAS,GAAG,EAAIA,EAAQ,MAAM,GAAG,EAAE,CAAC,EAAE,OAAS,EAE3EG,EAAmB,KAAK,IAAIF,EAAmBC,CAAiB,EAChEE,EAAY,KAAK,IAAI,GAAID,CAAgB,EAE/C,OAAO,KAAK,OAAON,EAAOC,GAAaM,CAAS,EAAIA,CACxD,EAEMC,EAAS,CAACC,EAAkIC,EAA8BC,IAAgB,CAC5L,GAAIrE,EAAM,SACN,OAGJ,IAAM2B,EAAIyC,GAAY,IAEtBE,EAAW,EACXlE,EAAM,QAAU,WAAW,IAAM,CAC7B8D,EAAOC,EAAO,GAAIE,CAAG,CACzB,EAAG1C,CAAC,EAEJ4C,EAAKJ,EAAOE,CAAG,CACnB,EAEME,EAAO,CAACJ,EAAkIE,IAAgB,CA5RxK,IAAAhD,EA6RY,IAAMmD,EAAUtB,EAAgB,EAEhC,GAAIsB,EAAS,CACT,IAAMC,IAAQpD,EAAArB,EAAM,OAAN,KAAAqB,EAAc,GAAKgD,EAC3BK,EAAe7B,EAAW2B,EAAQ,KAAK,GAAK,EAC5CG,EAAWC,EAAcnB,GAAiBiB,EAAwBD,CAAI,CAAC,EAE7EI,GAAYF,EAAoB,KAAM,OAAQ,OAAOD,CAAY,CAAC,EAClEI,EAAYX,EAAOQ,CAAwC,EAC3DI,GAAcZ,EAAO,OAAOO,CAAY,EAAGC,CAAkB,CACjE,CACJ,EAEMhB,GAAY,CAACQ,EAA2HE,IAAgB,CA1StK,IAAAhD,EA2SY,GAAI,CAACrB,EAAM,SAAU,CACjB,IAAMwE,EAAUtB,EAAgB,EAE5BsB,GACAA,EAAQ,MAAM,EAGlBN,EAAOC,EAAO,QAAW9C,EAAAgD,GAAA,KAAAA,EAAOrE,EAAM,OAAb,KAAAqB,EAAqB,CAAC,EAC/C8C,EAAM,eAAe,CACzB,CACJ,EAEMa,GAAY,CAACb,EAA2HE,IAAgB,CAvTtK,IAAAhD,EAwTY,GAAI,CAACrB,EAAM,SAAU,CACjB,IAAMwE,EAAUtB,EAAgB,EAE5BsB,GACAA,EAAQ,MAAM,EAGlBN,EAAOC,EAAO,OAAWE,GAAA,KAAAA,IAAQhD,EAAArB,EAAM,OAAN,KAAAqB,EAAc,GAAK,EAAE,EACtD8C,EAAM,eAAe,CACzB,CACJ,EAEMc,GAAW,IAAM,CACdjF,EAAM,UACPsE,EAAW,CAEnB,EAEMY,GAAWf,GAA+C,CA1UxE,IAAA9C,EA2UgBrB,EAAM,UAAYA,EAAM,WAIxBU,EAAc,UACbyD,EAAM,OAA4B,OAAQ9C,EAAAhB,EAAU,UAAV,KAAAgB,EAAqB,IAGpEX,EAAc,QAAU,GAC5B,EAEMyE,GAAkBhB,GAAiD,CAtVjF,IAAA9C,EAAAC,EAAA+B,EAAAC,EAuVY,GAAItD,EAAM,SACN,OAGJ,IAAMoF,EAAejB,EAAM,OAE3B,GAAIA,EAAM,QAAUA,EAAM,SAAWA,EAAM,QAAS,CAChDzD,EAAc,QAAU,GACxBL,EAAU,QAAU+E,EAAa,MAEjC,MACJ,CAEA/E,EAAU,QAAU+E,EAAa,MAEjC,IAAIC,GAAiBhE,EAAA+D,EAAa,iBAAb,KAAA/D,EAA+B,EAC9CiE,GAAehE,EAAA8D,EAAa,eAAb,KAAA9D,EAA6B,EAC5CiE,EAAiBD,EAAeD,EAChCG,EAAaJ,EAAa,MAC5BK,EAAc,KAGlB,OAFatB,EAAM,MAAQA,EAAM,IAEnB,CACV,IAAK,UACDI,EAAKJ,EAAO,CAAC,EACbA,EAAM,eAAe,EACrB,MAEJ,IAAK,YACDI,EAAKJ,EAAO,EAAE,EACdA,EAAM,eAAe,EACrB,MAEJ,IAAK,YACD,GAAIoB,EAAiB,EAAG,CACpB,IAAMG,EAAiBC,EAAcH,EAAW,OAAOH,CAAc,CAAC,EAAIA,EAAiB,EAAIA,EAAiB,EAE/GlB,EAAM,OAA4B,kBAAkBuB,EAAgBA,CAAc,CACvF,MAAYC,EAAcH,EAAW,OAAOH,EAAiB,CAAC,CAAC,GAC3DlB,EAAM,eAAe,EAGzB,MAEJ,IAAK,aACD,GAAIoB,EAAiB,EAAG,CACpB,IAAMG,EAAiBJ,EAAe,EAErCnB,EAAM,OAA4B,kBAAkBuB,EAAgBA,CAAc,CACvF,MAAYC,EAAcH,EAAW,OAAOH,CAAc,CAAC,GACvDlB,EAAM,eAAe,EAGzB,MAEJ,IAAK,MACL,IAAK,QACL,IAAK,cACDsB,EAAcb,EAAc/B,EAAW2C,CAAU,CAAC,EACjDrB,EAAM,OAA4B,MAAQ1B,EAAYgD,CAAW,EACjEtB,EAAM,OAA4B,aAAa,gBAAiBsB,GAAe,KAAO,OAAOA,CAAW,EAAI,EAAE,EAC/GX,EAAYX,EAAOsB,CAAW,EAC9B,MAEJ,IAAK,YAAa,CAGd,GAFAtB,EAAM,eAAe,EAEjBkB,IAAmBC,EAAc,CAC7BD,GAAkBG,EAAW,QAAU/E,EAAW,UAAY,OAC9D4E,EAAiBG,EAAW,OAAS/E,EAAW,QAAQ,OACvD0D,EAAM,OAA4B,kBAAkBkB,EAAgBA,CAAc,GAGvF,IAAMO,EAAaJ,EAAW,OAAOH,EAAiB,CAAC,EACjD,CAAE,iBAAAQ,EAAkB,8BAAAC,CAA8B,EAAIC,GAAsBP,CAAU,EAE5F,GAAIG,EAAcC,CAAU,EAAG,CAC3B,IAAMI,EAAgBC,GAAiBT,CAAU,EAEjD,GAAI5E,EAAO,SAAWA,EAAO,QAAQ,KAAKgF,CAAU,EAChDhF,EAAO,QAAQ,UAAY,EAE3B6E,EAAcD,EAAW,MAAM,EAAGH,EAAiB,CAAC,EAAIG,EAAW,MAAMH,EAAiB,CAAC,UACpFtE,EAAS,SAAWA,EAAS,QAAQ,KAAK6E,CAAU,EACvD7E,EAAS,UACTA,EAAS,QAAQ,UAAY,GAG7BiF,EACC7B,EAAM,OAA4B,kBAAkBkB,EAAiB,EAAGA,EAAiB,CAAC,EAE3FI,EAAcD,EAAW,MAAM,EAAGH,EAAiB,CAAC,EAAIG,EAAW,MAAMH,CAAc,UAEpFQ,EAAmB,GAAKR,EAAiBQ,EAAkB,CAClE,IAAMK,EAAeC,GAAc,IAAMnG,EAAM,mBAAqB,GAAKgG,EAAgB,GAAK,IAE9FP,EAAcD,EAAW,MAAM,EAAGH,EAAiB,CAAC,EAAIa,EAAeV,EAAW,MAAMH,CAAc,CAC1G,SAAWS,IAAkC,EAAG,CAC5CL,EAAcD,EAAW,MAAM,EAAGH,EAAiB,CAAC,EAAI,IAAMG,EAAW,MAAMH,CAAc,EAC7F,IAAMe,EAASvD,EAAW4C,CAAW,EAErCA,EAAc,OAAOW,GAAW,UAAYA,EAAS,EAAIX,EAAc,EAC3E,MACIA,EAAcD,EAAW,MAAM,EAAGH,EAAiB,CAAC,EAAIG,EAAW,MAAMH,CAAc,CAE/F,CAEAgB,EAAYlC,EAAOsB,EAAuB,KAAM,eAAe,CACnE,MACIA,EAAca,GAAYd,EAAYH,EAAgBC,CAAY,EAClEe,EAAYlC,EAAOsB,EAAa,KAAM,cAAc,EAGxD,KACJ,CAEA,IAAK,SAGD,GAFAtB,EAAM,eAAe,EAEjBkB,IAAmBC,EAAc,CACjC,IAAMM,EAAaJ,EAAW,OAAOH,CAAc,EAC7C,CAAE,iBAAAQ,EAAkB,8BAAAC,CAA8B,EAAIC,GAAsBP,CAAU,EAE5F,GAAIG,EAAcC,CAAU,EAAG,CAC3B,IAAMI,EAAgBC,GAAiBT,CAAU,EAEjD,GAAI5E,EAAO,SAAWA,EAAO,QAAQ,KAAKgF,CAAU,EAChDhF,EAAO,QAAQ,UAAY,EAC3B6E,EAAcD,EAAW,MAAM,EAAGH,CAAc,EAAIG,EAAW,MAAMH,EAAiB,CAAC,UAChFtE,EAAS,SAAWA,EAAS,QAAQ,KAAK6E,CAAU,EAC3D7E,EAAS,QAAQ,UAAY,EAEzBiF,EACC7B,EAAM,OAA4B,kBAAkBkB,EAAiB,EAAGA,EAAiB,CAAC,EAE3FI,EAAcD,EAAW,MAAM,EAAGH,CAAc,EAAIG,EAAW,MAAMH,EAAiB,CAAC,UAEpFQ,EAAmB,GAAKR,EAAiBQ,EAAkB,CAClE,IAAMK,EAAeC,GAAc,IAAMnG,EAAM,mBAAqB,GAAKgG,EAAgB,GAAK,IAE9FP,EAAcD,EAAW,MAAM,EAAGH,CAAc,EAAIa,EAAeV,EAAW,MAAMH,EAAiB,CAAC,CAC1G,SAAWS,IAAkC,EAAG,CAC5CL,EAAcD,EAAW,MAAM,EAAGH,CAAc,EAAI,IAAMG,EAAW,MAAMH,EAAiB,CAAC,EAC7F,IAAMe,EAASvD,EAAW4C,CAAW,EAErCA,EAAc,OAAOW,GAAW,UAAYA,EAAS,EAAIX,EAAc,EAC3E,MACIA,EAAcD,EAAW,MAAM,EAAGH,CAAc,EAAIG,EAAW,MAAMH,EAAiB,CAAC,CAE/F,CAEAgB,EAAYlC,EAAOsB,EAAuB,KAAM,oBAAoB,CACxE,MACIA,EAAca,GAAYd,EAAYH,EAAgBC,CAAY,EAClEe,EAAYlC,EAAOsB,EAAa,KAAM,cAAc,EAGxD,MAEJ,IAAK,OACDtB,EAAM,eAAe,EAEjBoC,GAAWvG,EAAM,GAAG,GACpB8E,EAAYX,GAAOd,EAAArD,EAAM,MAAN,KAAAqD,EAAa,CAAC,EAGrC,MAEJ,IAAK,MACDc,EAAM,eAAe,EAEjBoC,GAAWvG,EAAM,GAAG,GACpB8E,EAAYX,GAAOb,EAAAtD,EAAM,MAAN,KAAAsD,EAAa,GAAG,EAGvC,MAEJ,QACI,KACR,CACJ,EAEMkD,GAAmBrC,GAAiD,CACtE,GAAInE,EAAM,SACN,OAGJ,IAAMyG,EAAOtC,EAAM,IACbuC,EAAgBC,GAAgBF,CAAI,EACpCG,EAAcC,GAAcJ,CAAI,EAElCtC,EAAM,OAAS,SACfA,EAAM,eAAe,GAGpB,OAAOsC,CAAI,GAAK,GAAK,OAAOA,CAAI,GAAK,GAAMG,GAAeF,IAC3DI,GAAO3C,EAAOsC,EAAM,CAAE,cAAAC,EAAe,YAAAE,CAAY,CAAC,CAE1D,EAEMG,GAAW5C,GAAkD,CA/hB3E,IAAA9C,EAgiBY,GAAIrB,EAAM,SACN,OAGJmE,EAAM,eAAe,EACrB,IAAM6C,GAAQ3F,EAAA8C,EAAM,eAAkB,OAAqD,gBAA7E,YAAA9C,EAA6F,QAAQ,QAEnH,GAAI2F,EAAM,CACN,IAAMC,EAAepE,EAAWmE,CAAI,EAEhCC,GAAgB,MAChBH,GAAO3C,EAAO8C,EAAa,SAAS,CAAC,CAE7C,CACJ,EAEMC,GAAiB,IACZlH,EAAM,MAAQ,QAAaA,EAAM,MAAQ,MAAQA,EAAM,IAAM,EAGlE6G,GAAiBJ,GACd5F,EAAW,SAAWA,EAAW,QAAQ,KAAK4F,CAAI,GAAMA,IAAS,KAC9D5F,EAAW,UACXA,EAAW,QAAQ,UAAY,GAG5B,IAGJ,GAGL8F,GAAmBF,GAAiB,CAhkBlD,IAAApF,EAikBY,OAAKA,EAAArB,EAAM,SAAN,MAAAqB,EAAc,SAAS,OAAS,CAAC,IAAK,GAAG,EAAE,SAASoF,CAAI,GAAO1F,EAAS,SAAWA,EAAS,QAAQ,KAAK0F,CAAI,GAC1G1F,EAAS,UACTA,EAAS,QAAQ,UAAY,GAG1B,IAGJ,EACX,EAEMoF,GAAgB,IACXnG,EAAM,OAAS,UAGpB+F,GAAyBoB,GAAgB,CAC3C,IAAMtB,EAAmB9E,EAAS,QAAUoG,EAAI,OAAOpG,EAAS,OAAO,EAAI,GAEvEA,EAAS,UACTA,EAAS,QAAQ,UAAY,GAGjC,IAAMqG,EAAcD,EACf,QAAQlG,EAAQ,SAAW,GAAI,EAAE,EACjC,KAAK,EACL,QAAQ,MAAO,EAAE,EACjB,QAAQH,EAAU,SAAW,GAAI,EAAE,EAClCgF,EAAgC/E,EAAS,QAAUqG,EAAY,OAAOrG,EAAS,OAAO,EAAI,GAEhG,OAAIA,EAAS,UACTA,EAAS,QAAQ,UAAY,GAG1B,CAAE,iBAAA8E,EAAkB,8BAAAC,CAA8B,CAC7D,EAEMuB,GAAkBF,GAAgB,CACpC,IAAMG,EAAuBC,GAAyB,CAC9CA,IACAA,EAAM,UAAY,EAE1B,EAEM1B,EAAmB9E,EAAS,QAAUoG,EAAI,OAAOpG,EAAS,OAAO,EAAI,GAE3EuG,EAAoBvG,EAAS,OAAO,EAEpC,IAAMyG,EAAiB3G,EAAW,QAAUsG,EAAI,OAAOtG,EAAW,OAAO,EAAI,GAE7EyG,EAAoBzG,EAAW,OAAO,EAEtC,IAAM4G,EAAkBzG,EAAQ,QAAUmG,EAAI,OAAOnG,EAAQ,OAAO,EAAI,GAExEsG,EAAoBtG,EAAQ,OAAO,EAEnC,IAAM0G,EAAoB5G,EAAU,QAAUqG,EAAI,OAAOrG,EAAU,OAAO,EAAI,GAE9E,OAAAwG,EAAoBxG,EAAU,OAAO,EAE9B,CAAE,iBAAA+E,EAAkB,eAAA2B,EAAgB,gBAAAC,EAAiB,kBAAAC,CAAkB,CAClF,EAEMZ,GAAS,CAAC3C,EAAuFhC,EAAcwF,EAAO,CAAE,cAAe,GAAO,YAAa,EAAM,IAAM,CA/nBrL,IAAAtG,EAAAC,EAAA+B,EAAAC,EAgoBY,IAAMsE,EAAuB/G,EAAW,QAAUsB,EAAK,OAAOtB,EAAW,OAAO,EAAI,GAMpF,GAJIA,EAAW,UACXA,EAAW,QAAQ,UAAY,GAG/B,CAACqG,GAAe,GAAKU,IAAyB,GAC9C,OAGJ,IAAMvC,GAAkBhE,EAAA8C,EAAM,OAA4B,iBAAlC,KAAA9C,EAAoD,EACtEiE,GAAgBhE,EAAA6C,EAAM,OAA4B,eAAlC,KAAA7C,EAAkD,EAClEkE,EAAcrB,EAAM,OAA4B,MAAM,KAAK,EAC3D,CAAE,iBAAA0B,EAAkB,eAAA2B,EAAgB,gBAAAC,EAAiB,kBAAAC,CAAkB,EAAIL,GAAe7B,CAAU,EACtGC,EAEJ,GAAIkC,EAAK,YAAa,CAClB,IAAME,EAAiBL,IAAmB,IAEtCnC,IAAmB,GAAKA,IAAmBqC,EAAoB,KAC/DjC,EAAcD,GAEVqC,GAAkBvC,IAAiB,KACnCG,EAAcqC,EAAWtC,EAAYrD,EAAM,EAAGmD,CAAY,GAG9De,EAAYlC,EAAOsB,EAAatD,EAAM,QAAQ,EAEtD,SAAWwF,EAAK,cACR9B,EAAmB,GAAKR,IAAmBQ,EAC3CQ,EAAYlC,EAAOqB,EAAYrD,EAAM,QAAQ,GACtC0D,EAAmBR,GAAkBQ,EAAmBP,GAGxDO,IAAqB,IAAM7F,EAAM,qBACxCyF,EAAcqC,EAAWtC,EAAYrD,EAAMkD,EAAgBC,CAAY,EACvEe,EAAYlC,EAAOsB,EAAatD,EAAM,QAAQ,OAE/C,CACH,IAAM4F,GAAoBzE,GAAAD,EAAA/C,EAAa,UAAb,YAAA+C,EAAsB,kBAAkB,wBAAxC,KAAAC,EAAiE,EACrF0E,EAAY3C,IAAmBC,EAAe,eAAiB,SAErE,GAAIO,EAAmB,GAAKR,EAAiBQ,GACzC,GAAIR,EAAiBlD,EAAK,QAAU0D,EAAmB,IAAMkC,EAAmB,CAC5E,IAAME,EAAYP,GAAqBrC,EAAiBqC,EAAoB,EAAID,GAAmBpC,EAAiBoC,EAAkBjC,EAAW,OAEjJC,EAAcD,EAAW,MAAM,EAAGH,CAAc,EAAIlD,EAAOqD,EAAW,MAAMH,EAAiBlD,EAAK,OAAQ8F,CAAS,EAAIzC,EAAW,MAAMyC,CAAS,EACjJ5B,EAAYlC,EAAOsB,EAAatD,EAAM6F,CAAS,CACnD,OAEAvC,EAAcqC,EAAWtC,EAAYrD,EAAMkD,EAAgBC,CAAY,EACvEe,EAAYlC,EAAOsB,EAAatD,EAAM6F,CAAS,CAEvD,CACJ,EAEMF,EAAa,CAACpF,EAAeP,EAAc+F,EAAeC,IAAgB,CAxrBxF,IAAA9G,EA2rBY,IAFkBc,IAAS,IAAMA,EAAOA,EAAK,MAAM,GAAG,GAExC,SAAW,EAAG,CACxB,IAAM0D,EAAmBnD,EAAM,MAAMwF,EAAOC,CAAG,EAAE,QAAO9G,EAAAN,EAAS,UAAT,KAAAM,EAAoB,EAAE,EAE9E,OAAIN,EAAS,UACTA,EAAS,QAAQ,UAAY,GAG1B8E,EAAmB,EAAInD,EAAM,MAAM,EAAGwF,CAAK,EAAIzF,EAAYN,CAAI,EAAIO,EAAM,MAAMyF,CAAG,EAAI1F,EAAYN,CAAI,GAAKO,CACtH,KAAO,QAAIyF,EAAMD,IAAUxF,EAAM,OACtBD,EAAYN,CAAI,EAChB+F,IAAU,EACV/F,EAAOO,EAAM,MAAMyF,CAAG,EACtBA,IAAQzF,EAAM,OACdA,EAAM,MAAM,EAAGwF,CAAK,EAAI/F,EAExBO,EAAM,MAAM,EAAGwF,CAAK,EAAI/F,EAAOO,EAAM,MAAMyF,CAAG,CAE7D,EAEM7B,GAAc,CAAC5D,EAAewF,EAAeC,IAAgB,CAC/D,IAAI1C,EAEJ,OAAI0C,EAAMD,IAAUxF,EAAM,OAAQ+C,EAAc,GACvCyC,IAAU,EAAGzC,EAAc/C,EAAM,MAAMyF,CAAG,EAC1CA,IAAQzF,EAAM,OAAQ+C,EAAc/C,EAAM,MAAM,EAAGwF,CAAK,EAC5DzC,EAAc/C,EAAM,MAAM,EAAGwF,CAAK,EAAIxF,EAAM,MAAMyF,CAAG,EAEnD1C,CACX,EAEM2C,EAAa,IAAM,CAztBjC,IAAA/G,EA0tBY,IAAMmD,EAAUtB,EAAgB,EAEhC,GAAI,CAACsB,EAAS,MAAO,GAErB,IAAIgB,EAAahB,EAAQ,MACrBa,GAAiBhE,EAAAmD,EAAQ,iBAAR,KAAAnD,EAA0B,EACzCgH,EAAc7C,EAAW,OAC3B/D,EAAQ,KAGN6G,GAAgB9H,EAAW,SAAW,IAAI,OAEhDgF,EAAaA,EAAW,QAAQhF,EAAW,SAAW,GAAI,EAAE,EAC5D6E,EAAiBA,EAAiBiD,EAElC,IAAI7B,EAAOjB,EAAW,OAAOH,CAAc,EAE3C,GAAIM,EAAcc,CAAI,EAClB,OAAOpB,EAAiBiD,EAI5B,IAAI3G,EAAI0D,EAAiB,EAEzB,KAAO1D,GAAK,GAGR,GAFA8E,EAAOjB,EAAW,OAAO7D,CAAC,EAEtBgE,EAAcc,CAAI,EAAG,CACrBhF,EAAQE,EAAI2G,EACZ,KACJ,MACI3G,IAIR,GAAIF,IAAU,KACN+C,EAAQ,mBAAmBA,EAAQ,kBAAkB/C,EAAQ,EAAGA,EAAQ,CAAC,MAC1E,CAGH,IAFAE,EAAI0D,EAEG1D,EAAI0G,GAGP,GAFA5B,EAAOjB,EAAW,OAAO7D,CAAC,EAEtBgE,EAAcc,CAAI,EAAG,CACrBhF,EAAQE,EAAI2G,EACZ,KACJ,MACI3G,IAIJF,IAAU,MACN+C,EAAQ,mBAAmBA,EAAQ,kBAAkB/C,EAAOA,CAAK,CAE7E,CAEA,OAAOA,GAAS,CACpB,EAEM8G,GAAe,IAAM,CACvB,IAAM/D,EAAUtB,EAAgB,EAEhC,GAAI,CAACsB,EAAS,OAEd,IAAME,EAAeF,EAAQ,MAEzB,CAACxE,EAAM,UAAY0E,IAAiB8D,GAAa,GACjDJ,EAAW,CAEnB,EAEMzC,EAAiBc,GACfA,EAAK,SAAW,IAAO9F,EAAS,SAAWA,EAAS,QAAQ,KAAK8F,CAAI,GAAO1F,EAAS,SAAWA,EAAS,QAAQ,KAAK0F,CAAI,GAAO7F,EAAO,SAAWA,EAAO,QAAQ,KAAK6F,CAAI,GAAO5F,EAAW,SAAWA,EAAW,QAAQ,KAAK4F,CAAI,IACpOgC,GAAW,EAEJ,IAGJ,GAGLA,GAAa,IAAM,CACjB9H,EAAS,UAASA,EAAS,QAAQ,UAAY,GAE/CI,EAAS,UAASA,EAAS,QAAQ,UAAY,GAE/CH,EAAO,UAASA,EAAO,QAAQ,UAAY,GAE3CC,EAAW,UAASA,EAAW,QAAQ,UAAY,EAC3D,EAEM6H,GAAc,IAAM,CArzBlC,IAAArH,EAAAC,EAszBY,IAAMqH,GAASrH,GAAAD,EAAArB,EAAM,QAAN,KAAAqB,EAAerB,EAAM,eAArB,KAAAsB,EAAqC,KAC9C6F,EAAMyB,GAAqBD,CAAM,EAEvCE,GAAiB1B,CAAG,EAEpB,IAAMxC,EAAWC,EAAc+D,CAAM,EAEjCA,IAAW,MAAQA,IAAWhE,GAC9BG,EAAY,KAAMH,CAAwC,CAElE,EAEM0B,EAAc,CAAClC,EAA6H2E,EAAkBC,EAAiCf,IAAsB,CACvN,IAAMtD,EAAgBP,EAAM,OAA4B,MACpDQ,EAAW,KAEXmE,GAAY,OACZnE,EAAW9B,EAAWiG,CAAQ,EAC9BnE,EAAW,CAACA,GAAY,CAAC3E,EAAM,WAAa,EAAI2E,EAEhDE,GAAYF,EAAUoE,EAAkBf,EAAWc,CAAQ,EAC3D/D,GAAcZ,EAAOO,EAAcC,CAAQ,EAEnD,EAEMqE,GAAiB,CAACtE,EAAsCC,IAAqC,CAC/F,GAAIA,IAAa,MAAQD,IAAiB,KACtC,MAAO,GAGX,GAAIC,GAAY,KAAM,CAClB,IAAMsE,EAAqB,OAAOvE,GAAiB,SAAW7B,EAAW6B,CAAY,EAAIA,EAEzF,OAAOC,IAAasE,CACxB,CAEA,MAAO,EACX,EAEMlE,GAAgB,CAClBZ,EACAO,EACAC,IACC,CACG3E,EAAM,UAAYgJ,GAAetE,EAAcC,CAAQ,GACvD3E,EAAM,SAAS,CACX,cAAemE,EACf,MAAOQ,CACX,CAAC,CAET,EAEMC,EAAiBlC,GACfA,IAAU,KAAOA,GAAS,KACnB,KAGP1C,EAAM,KAAO,MAAQ,OAAOA,EAAM,KAAQ,UAAY,OAAO0C,GAAU,UAAYA,EAAQ1C,EAAM,IAC1FA,EAAM,IAGbA,EAAM,KAAO,MAAQ,OAAOA,EAAM,KAAQ,UAAY,OAAO0C,GAAU,UAAYA,EAAQ1C,EAAM,IAC1FA,EAAM,IAGV0C,EAGLkG,GAAwBlG,GACtBwG,GAAQxG,CAAK,EACN,KAGP1C,EAAM,MAAQ,QAAaA,EAAM,MAAQ,MAAQ0C,IAAU,MAAQA,EAAQ1C,EAAM,IAC1EA,EAAM,IAGbA,EAAM,MAAQ,QAAaA,EAAM,MAAQ,MAAQ0C,IAAU,MAAQA,EAAQ1C,EAAM,IAC1EA,EAAM,IAGV0C,EAGLmC,GAAc,CAACnC,EAA+BqG,EAAiCf,EAAmBc,IAAqB,CA14BrI,IAAAzH,EAAAC,EA24BYyH,EAAmBA,GAAoB,GACvC,IAAMvE,EAAUtB,EAAgB,EAEhC,GAAI,CAACsB,EAAS,OAEd,IAAMgB,EAAahB,EAAQ,MAEvBG,EAAWlC,EAAYC,CAAK,EAC1ByG,EAAgB3D,EAAW,OAMjC,GAJIb,IAAamE,IACbnE,EAAWyE,GAAazE,EAAUmE,CAAQ,GAG1CK,IAAkB,EAAG,CACrB3E,EAAQ,MAAQG,EACZH,EAAQ,mBAAmBA,EAAQ,kBAAkB,EAAG,CAAC,EAG7D,IAAMc,EADQ8C,EAAW,EACIW,EAAiB,OAE1CvE,EAAQ,mBAAmBA,EAAQ,kBAAkBc,EAAcA,CAAY,CACvF,KAAO,CACH,IAAMD,GAAiBhE,EAAAmD,EAAQ,iBAAR,KAAAnD,EAA0B,EAC7CiE,GAAehE,EAAAkD,EAAQ,eAAR,KAAAlD,EAAwB,EAE3CkD,EAAQ,MAAQG,EAChB,IAAM0E,EAAY1E,EAAS,OAE3B,GAAIqD,IAAc,eAAgB,CAC9B,IAAMsB,EAAazG,GAAY2C,GAAc,IAAI,MAAM,EAAGH,CAAc,CAAC,EAEnEkE,GADgBD,IAAe,KAAOA,EAAW,SAAS,EAAI,IACpC,MAAM,EAAE,EAAE,KAAK,IAAI/I,EAAU,OAAO,IAAI,EAClEiJ,EAAS,IAAI,OAAOD,EAAW,GAAG,EAExCC,EAAO,KAAK7E,CAAQ,EAEpB,IAAM8E,EAAQV,EAAiB,MAAM,EAAE,EAAE,KAAK,IAAIxI,EAAU,OAAO,IAAI,EACjEmJ,EAAS,IAAI,OAAOD,EAAO,GAAG,EAEpCC,EAAO,KAAK/E,EAAS,MAAM6E,EAAO,SAAS,CAAC,EAE5ClE,EAAekE,EAAO,UAAYE,EAAO,UACrClF,EAAQ,mBAAmBA,EAAQ,kBAAkBc,EAAcA,CAAY,CACvF,SAAW+D,IAAcF,EACjBnB,IAAc,UAAYA,IAAc,qBACpCxD,EAAQ,mBAAmBA,EAAQ,kBAAkBc,EAAe,EAAGA,EAAe,CAAC,EACpF0C,IAAc,gBACjBxD,EAAQ,mBAAmBA,EAAQ,kBAAkBc,EAAe,EAAGA,EAAe,CAAC,GACpF0C,IAAc,gBAAkBA,IAAc,SACjDxD,EAAQ,mBAAmBA,EAAQ,kBAAkBc,EAAcA,CAAY,UAEhF0C,IAAc,qBAAsB,CAC3C,IAAM2B,EAAWnE,EAAW,OAAOF,EAAe,CAAC,EAC7CsE,EAAWpE,EAAW,OAAOF,CAAY,EACzCuE,EAAOV,EAAgBE,EACvBS,EAAclJ,EAAO,QAAUA,EAAO,QAAQ,KAAKgJ,CAAQ,EAAI,GAEjEE,GAAeD,IAAS,EACxBvE,GAAgB,EACT,CAACwE,GAAenE,EAAcgE,CAAQ,IAC7CrE,GAAgB,GAAKuE,EAAO,GAG5BjJ,EAAO,UACPA,EAAO,QAAQ,UAAY,GAG3B4D,EAAQ,mBAAmBA,EAAQ,kBAAkBc,EAAcA,CAAY,CACvF,SAAWE,IAAe,KAAOwC,IAAc,SAAU,CACjDxD,EAAQ,mBAAmBA,EAAQ,kBAAkB,EAAG,CAAC,EAG7D,IAAMc,EADQ8C,EAAW,EACIW,EAAiB,OAAS,EAEnDvE,EAAQ,mBAAmBA,EAAQ,kBAAkBc,EAAcA,CAAY,CACvF,MACIA,EAAeA,GAAgB+D,EAAYF,GACvC3E,EAAQ,mBAAmBA,EAAQ,kBAAkBc,EAAcA,CAAY,CAE3F,CAEAd,EAAQ,aAAa,gBAAiB,OAAO9B,CAAK,CAAC,CACvD,EAEMqH,GAAiBpF,GAA2C,CAh+B1E,IAAAtD,EAi+BY,MAAO,CAACsD,GAAY,CAAC3E,EAAM,YAAcqB,EAAArB,EAAM,MAAN,KAAAqB,EAAa,EAAKsD,CAC/D,EAEMkE,GAAoBlE,GAA2C,CACjEA,EAAWoF,GAAcpF,CAAQ,EAEjC,IAAMH,EAAUtB,EAAgB,EAEhC,GAAI,CAACsB,EAAS,OAEd,IAAM9B,EAAQ8B,EAAQ,MAChBwF,EAAkBvH,EAAYkC,CAAQ,EAExCjC,IAAUsH,IACVxF,EAAQ,MAAQwF,EAChBxF,EAAQ,aAAa,gBAAiB,OAAOG,CAAQ,CAAC,EAE9D,EAEMyE,GAAe,CAACa,EAAcC,IAAiB,CACjD,GAAID,GAAQC,EAAM,CACd,IAAMC,EAAepJ,EAAS,QACxB8E,EAAmBsE,EAAeD,EAAK,OAAOC,CAAY,EAAI,GAMpE,GAJIA,IACAA,EAAa,UAAY,GAGzB1J,EAAW,QACX,OAAOoF,IAAqB,GAAKoE,EAAK,QAAQxJ,EAAW,QAAS,EAAE,EAAE,MAAM0J,GAAA,KAAAA,EAAgB,EAAE,EAAE,CAAC,EAAID,EAAK,QAAQzJ,EAAW,QAAS,EAAE,EAAE,MAAMoF,CAAgB,EAAIpF,EAAW,QAAUwJ,EACtL,GAAIzJ,EAAW,QAClB,OAAOqF,IAAqB,GAAKoE,EAAK,MAAME,GAAA,KAAAA,EAAgB,EAAE,EAAE,CAAC,EAAID,EAAK,MAAMrE,CAAgB,EAAIoE,CAE5G,CAEA,OAAOA,CACX,EAEMhE,GAAoBvD,GAAkB,CAvgCpD,IAAArB,EAAAC,EAAA+B,EAwgCY,GAAIX,EAAO,CACP,IAAM0H,EAAa1H,EAAM,OAAMrB,EAAAN,EAAS,UAAT,KAAAM,EAAoB,EAAE,EAErD,GAAI+I,EAAW,SAAW,EACtB,OAAOA,EAAW,CAAC,EACd,SAAQ9I,EAAAN,EAAQ,UAAR,KAAAM,EAAmB,GAAI,EAAE,EACjC,KAAK,EACL,QAAQ,MAAO,EAAE,EACjB,SAAQ+B,EAAAvC,EAAU,UAAV,KAAAuC,EAAqB,GAAI,EAAE,EAAE,MAElD,CAEA,MAAO,EACX,EAEMyB,EAAc,CAChBX,EACAzB,IACC,CACD,GAAI1C,EAAM,cAAe,CACrB,IAAIqK,EAEAlG,EACAkG,EAAgBlG,EAKhBkG,EAAgB,CAEZ,OAJYnH,EAAgB,CAKhC,EAGJlD,EAAM,cAAc,CAChB,cAAAqK,EACA,MAAO3H,CACX,CAAC,CACL,CACJ,EAEM4H,GAAgBnG,GAA8C,CAChEjE,EAAW,EAAI,EAEf,IAAMsE,EAAUtB,EAAgB,EAE5B,CAAClD,EAAM,UAAY,CAACA,EAAM,WAAYwE,GAAA,YAAAA,EAAS,SAAUgE,GAAa,GAAKxI,EAAM,kBACjFmE,EAAM,OAAO,OAAO,CAE5B,EAEMoG,GAAepG,GAA8C,CAC/DjE,EAAW,EAAK,EAEhB,IAAMsK,EAAQrG,EAAM,OACdQ,EAAWC,EAAc/B,EAAW2H,EAAM,KAAK,CAAC,EAEtDA,EAAM,MAAQ/H,EAAYkC,CAAQ,EAClC6F,EAAM,aAAa,gBAAiB,OAAO7F,CAAQ,CAAC,EACpDG,EAAYX,EAAOQ,CAAQ,EAEvB,CAAC3E,EAAM,UAAY,CAACA,EAAM,UAAYA,EAAM,kBAC5CyK,GAAe,CAEvB,EAEMnG,EAAa,IAAM,CACjBlE,EAAM,SACN,cAAcA,EAAM,OAAO,CAEnC,EAEMsK,GAAa,IAAM,CAhlCjC,IAAArJ,EAAAC,EAilCY,OAAOtB,EAAM,MAAQ,UAAcsB,GAAAD,EAAArB,EAAM,QAAN,KAAAqB,EAAerB,EAAM,eAArB,KAAAsB,EAAqC,IAAMtB,EAAM,GACxF,EAEM2K,GAAa,IAAM,CAplCjC,IAAAtJ,EAAAC,EAqlCY,OAAOtB,EAAM,MAAQ,UAAcsB,GAAAD,EAAArB,EAAM,QAAN,KAAAqB,EAAerB,EAAM,eAArB,KAAAsB,EAAqC,IAAMtB,EAAM,GACxF,EAEA,OAAA4K,GAAiB,IAAM,CACnBtG,EAAW,CACf,CAAC,EAEDuG,GAAe,IAAM,CA5lC7B,IAAAxJ,EAAAC,EA6lCYC,GAAgB,EAEhB,IAAMuJ,GAAexJ,GAAAD,EAAArB,EAAM,QAAN,KAAAqB,EAAerB,EAAM,eAArB,KAAAsB,EAAqC,KACpDqD,EAAWC,EAAckG,CAA6B,EAG5DjC,GAFsB,OAAOlE,GAAa,SAAWA,EAAW,IAElC,EAE1BmG,IAAiB,MAAQA,IAAiBnG,GAC1CG,EAAY,KAAMH,CAAkB,CAE5C,CAAC,EAEDoG,EAAgB,IAAM,CAClBxJ,GAAgB,EAChBmH,GAAY,CAChB,EAAG,CAAC1I,EAAM,OAAQA,EAAM,cAAeA,EAAM,KAAMA,EAAM,SAAUA,EAAM,gBAAiBA,EAAM,YAAaA,EAAM,kBAAmBA,EAAM,kBAAmBA,EAAM,OAAQA,EAAM,MAAM,CAAC,EAE1L+K,EAAgB,IAAM,CAClBrC,GAAY,CAChB,EAAG,CAAC1I,EAAM,MAAOA,EAAM,YAAY,CAAC,EAEpC+K,EAAgB,IAAM,CACd/K,EAAM,UACNsE,EAAW,CAEnB,EAAG,CAACtE,EAAM,QAAQ,CAAC,EAEZ,CACH,MAAAmB,GACA,SAAAhB,EAEA,SAAU+E,GACV,QAAAA,GACA,eAAAC,GACA,gBAAAqB,GACA,aAAA+B,GACA,QAAAxB,GACA,aAAAuD,GACA,YAAAC,GACA,cAAevK,EAAM,cACrB,WAAA0K,GACA,WAAAC,GACA,UAAAhH,GACA,UAAAqB,GACA,SAAAC,EACJ,CACJ,CACJ,CAAC","names":["withHeadless","useMountEffect","useUnmountEffect","useUpdateEffect","clearSelection","getSelection","isEmpty","isNotEmpty","React","defaultProps","useInputNumber","withHeadless","defaultProps","props","focused","setFocused","inputRef","timer","lastValue","numberFormat","groupChar","prefixChar","suffixChar","isSpecialChar","_numeral","_group","_minusSign","_currency","_decimal","_suffix","_prefix","_index","state","getOptions","_a","_b","constructParser","numerals","index","d","i","getGroupingExpression","getMinusSignExpression","getCurrencyExpression","getDecimalExpression","getSuffixExpression","getPrefixExpression","escapeRegExp","text","formatter","__spreadProps","__spreadValues","prefixStr","suffixStr","formatValue","value","numericValue","formattedValue","parseValue","cleanText","validChars","res","parsedValue","getInputElement","extractHTMLInput","ref","_c","_d","targetRef","refToUse","addWithPrecision","base","increment","baseStr","stepStr","baseDecimalPlaces","stepDecimalPlaces","maxDecimalPlaces","precision","repeat","event","interval","dir","clearTimer","spin","inputEl","step","currentValue","newValue","validateValue","updateInput","updateModel","handleOnInput","decrement","stopSpin","onInput","onInputKeyDown","inputElement","selectionStart","selectionEnd","selectionRange","inputValue","newValueStr","cursorPosition","isNumeralChar","deleteChar","decimalCharIndex","decimalCharIndexWithoutPrefix","getDecimalCharIndexes","decimalLength","getDecimalLength","insertedText","isDecimalMode","parsed","updateValue","deleteRange","isNotEmpty","onInputKeyPress","char","isDecimalSign","isDecimalSignFn","isMinusSign","isMinusSignFn","insert","onPaste","data","filteredData","allowMinusSign","val","filteredVal","getCharIndexes","resetRegexLastIndex","regex","minusCharIndex","suffixCharIndex","currencyCharIndex","sign","minusCharIndexOnText","isNewMinusSign","insertText","maxFractionDigits","operation","charIndex","start","end","initCursor","valueLength","prefixLength","onInputClick","getSelection","resetRegex","changeValue","_value","validateValueByLimit","updateInputValue","valueStr","insertedValueStr","isValueChanged","parsedCurrentValue","isEmpty","currentLength","concatValues","newLength","startValue","startExpr","sRegex","tExpr","tRegex","prevChar","nextChar","diff","isGroupChar","evaluateEmpty","_formattedValue","val1","val2","decimalRegex","valueSplit","originalEvent","onInputFocus","onInputBlur","input","clearSelection","maxBoundry","minBoundry","useUnmountEffect","useMountEffect","initialValue","useUpdateEffect"]}
@@ -0,0 +1,24 @@
1
+ import { useInputNumberProps } from '@primereact/types/shared/inputnumber';
2
+ import * as React from 'react';
3
+ export declare const useInputNumber: (inProps?: unknown) => import("@primereact/types/core").HeadlessInstance<useInputNumberProps, unknown, {
4
+ state: {
5
+ focused: boolean;
6
+ };
7
+ inputRef: React.RefObject<{
8
+ elementRef: React.RefObject<HTMLInputElement>;
9
+ } | null>;
10
+ onChange: (event: React.ChangeEvent<HTMLInputElement>) => void;
11
+ onInput: (event: React.ChangeEvent<HTMLInputElement>) => void;
12
+ onInputKeyDown: (event: React.KeyboardEvent<HTMLInputElement>) => void;
13
+ onInputKeyPress: (event: React.KeyboardEvent<HTMLInputElement>) => void;
14
+ onInputClick: () => void;
15
+ onPaste: (event: React.ClipboardEvent<HTMLInputElement>) => void;
16
+ onInputFocus: (event: React.FocusEvent<HTMLInputElement>) => void;
17
+ onInputBlur: (event: React.FocusEvent<HTMLInputElement>) => void;
18
+ onValueChange: ((event: import("@primereact/types/shared/inputnumber").useInputNumberValueChangeEvent) => void) | undefined;
19
+ maxBoundry: () => boolean;
20
+ minBoundry: () => boolean;
21
+ increment: (event: React.KeyboardEvent<HTMLInputElement> | React.MouseEvent<HTMLInputElement> | React.PointerEvent<HTMLButtonElement>, dir: number) => void;
22
+ decrement: (event: React.KeyboardEvent<HTMLInputElement> | React.MouseEvent<HTMLInputElement> | React.PointerEvent<HTMLButtonElement>, dir: number) => void;
23
+ stopSpin: () => void;
24
+ }>;
@@ -0,0 +1,2 @@
1
+ import type { useInputNumberProps } from '@primereact/types/shared/inputnumber';
2
+ export declare const defaultProps: useInputNumberProps;
File without changes
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@primereact/headless",
3
- "version": "11.0.0-alpha.5",
3
+ "version": "11.0.0-alpha.7",
4
4
  "author": "PrimeTek Informatics",
5
5
  "description": "",
6
6
  "homepage": "https://primereact.org/",
@@ -32,9 +32,9 @@
32
32
  "access": "public"
33
33
  },
34
34
  "dependencies": {
35
- "@primeuix/styled": "^0.7.2",
35
+ "@primeuix/styled": "^0.7.4",
36
36
  "@primeuix/utils": "^0.6.1",
37
- "@primereact/core": "11.0.0-alpha.5",
38
- "@primereact/hooks": "11.0.0-alpha.5"
37
+ "@primereact/core": "11.0.0-alpha.7",
38
+ "@primereact/hooks": "11.0.0-alpha.7"
39
39
  }
40
40
  }