`, so it can be styled via any CSS solution you prefer.\n * @see https://floating-ui.com/docs/FloatingOverlay\n */\nvar FloatingOverlay = /*#__PURE__*/React.forwardRef(function FloatingOverlay(props, ref) {\n var _props$lockScroll = props.lockScroll,\n lockScroll = _props$lockScroll === void 0 ? false : _props$lockScroll,\n rest = _objectWithoutProperties(props, _excluded5);\n var lockId = useId();\n index(function () {\n if (!lockScroll) return;\n activeLocks.add(lockId);\n var isIOS = /iP(hone|ad|od)|iOS/.test(getPlatform());\n var bodyStyle = document.body.style;\n // RTL scrollbar\n var scrollbarX = Math.round(document.documentElement.getBoundingClientRect().left) + document.documentElement.scrollLeft;\n var paddingProp = scrollbarX ? 'paddingLeft' : 'paddingRight';\n var scrollbarWidth = window.innerWidth - document.documentElement.clientWidth;\n var scrollX = bodyStyle.left ? parseFloat(bodyStyle.left) : window.scrollX;\n var scrollY = bodyStyle.top ? parseFloat(bodyStyle.top) : window.scrollY;\n bodyStyle.overflow = 'hidden';\n if (scrollbarWidth) {\n bodyStyle[paddingProp] = scrollbarWidth + \"px\";\n }\n\n // Only iOS doesn't respect `overflow: hidden` on document.body, and this\n // technique has fewer side effects.\n if (isIOS) {\n var _window$visualViewpor, _window$visualViewpor2;\n // iOS 12 does not support `visualViewport`.\n var offsetLeft = ((_window$visualViewpor = window.visualViewport) == null ? void 0 : _window$visualViewpor.offsetLeft) || 0;\n var offsetTop = ((_window$visualViewpor2 = window.visualViewport) == null ? void 0 : _window$visualViewpor2.offsetTop) || 0;\n Object.assign(bodyStyle, {\n position: 'fixed',\n top: -(scrollY - Math.floor(offsetTop)) + \"px\",\n left: -(scrollX - Math.floor(offsetLeft)) + \"px\",\n right: '0'\n });\n }\n return function () {\n activeLocks.delete(lockId);\n if (activeLocks.size === 0) {\n Object.assign(bodyStyle, _defineProperty({\n overflow: ''\n }, paddingProp, ''));\n if (isIOS) {\n Object.assign(bodyStyle, {\n position: '',\n top: '',\n left: '',\n right: ''\n });\n window.scrollTo(scrollX, scrollY);\n }\n }\n };\n }, [lockId, lockScroll]);\n return /*#__PURE__*/React.createElement(\"div\", _extends({\n ref: ref\n }, rest, {\n style: _objectSpread({\n position: 'fixed',\n overflow: 'auto',\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n }, rest.style)\n }));\n});\nfunction isButtonTarget(event) {\n return isHTMLElement(event.target) && event.target.tagName === 'BUTTON';\n}\nfunction isSpaceIgnored(element) {\n return isTypeableElement(element);\n}\n/**\n * Opens or closes the floating element when clicking the reference element.\n * @see https://floating-ui.com/docs/useClick\n */\nfunction useClick(context, props) {\n if (props === void 0) {\n props = {};\n }\n var open = context.open,\n onOpenChange = context.onOpenChange,\n dataRef = context.dataRef,\n domReference = context.elements.domReference;\n var _props4 = props,\n _props4$enabled = _props4.enabled,\n enabled = _props4$enabled === void 0 ? true : _props4$enabled,\n _props4$event = _props4.event,\n eventOption = _props4$event === void 0 ? 'click' : _props4$event,\n _props4$toggle = _props4.toggle,\n toggle = _props4$toggle === void 0 ? true : _props4$toggle,\n _props4$ignoreMouse = _props4.ignoreMouse,\n ignoreMouse = _props4$ignoreMouse === void 0 ? false : _props4$ignoreMouse,\n _props4$keyboardHandl = _props4.keyboardHandlers,\n keyboardHandlers = _props4$keyboardHandl === void 0 ? true : _props4$keyboardHandl;\n var pointerTypeRef = React.useRef();\n var didKeyDownRef = React.useRef(false);\n var reference = React.useMemo(function () {\n return {\n onPointerDown: function onPointerDown(event) {\n pointerTypeRef.current = event.pointerType;\n },\n onMouseDown: function onMouseDown(event) {\n var pointerType = pointerTypeRef.current;\n\n // Ignore all buttons except for the \"main\" button.\n // https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/button\n if (event.button !== 0) return;\n if (eventOption === 'click') return;\n if (isMouseLikePointerType(pointerType, true) && ignoreMouse) return;\n if (open && toggle && (dataRef.current.openEvent ? dataRef.current.openEvent.type === 'mousedown' : true)) {\n onOpenChange(false, event.nativeEvent, 'click');\n } else {\n // Prevent stealing focus from the floating element\n event.preventDefault();\n onOpenChange(true, event.nativeEvent, 'click');\n }\n },\n onClick: function onClick(event) {\n var pointerType = pointerTypeRef.current;\n if (eventOption === 'mousedown' && pointerTypeRef.current) {\n pointerTypeRef.current = undefined;\n return;\n }\n if (isMouseLikePointerType(pointerType, true) && ignoreMouse) return;\n if (open && toggle && (dataRef.current.openEvent ? dataRef.current.openEvent.type === 'click' : true)) {\n onOpenChange(false, event.nativeEvent, 'click');\n } else {\n onOpenChange(true, event.nativeEvent, 'click');\n }\n },\n onKeyDown: function onKeyDown(event) {\n pointerTypeRef.current = undefined;\n if (event.defaultPrevented || !keyboardHandlers || isButtonTarget(event)) {\n return;\n }\n if (event.key === ' ' && !isSpaceIgnored(domReference)) {\n // Prevent scrolling\n event.preventDefault();\n didKeyDownRef.current = true;\n }\n if (event.key === 'Enter') {\n if (open && toggle) {\n onOpenChange(false, event.nativeEvent, 'click');\n } else {\n onOpenChange(true, event.nativeEvent, 'click');\n }\n }\n },\n onKeyUp: function onKeyUp(event) {\n if (event.defaultPrevented || !keyboardHandlers || isButtonTarget(event) || isSpaceIgnored(domReference)) {\n return;\n }\n if (event.key === ' ' && didKeyDownRef.current) {\n didKeyDownRef.current = false;\n if (open && toggle) {\n onOpenChange(false, event.nativeEvent, 'click');\n } else {\n onOpenChange(true, event.nativeEvent, 'click');\n }\n }\n }\n };\n }, [dataRef, domReference, eventOption, ignoreMouse, keyboardHandlers, onOpenChange, open, toggle]);\n return React.useMemo(function () {\n return enabled ? {\n reference: reference\n } : {};\n }, [enabled, reference]);\n}\nfunction createVirtualElement(domElement, data) {\n var offsetX = null;\n var offsetY = null;\n var isAutoUpdateEvent = false;\n return {\n contextElement: domElement || undefined,\n getBoundingClientRect: function getBoundingClientRect() {\n var _data$dataRef$current;\n var domRect = (domElement == null ? void 0 : domElement.getBoundingClientRect()) || {\n width: 0,\n height: 0,\n x: 0,\n y: 0\n };\n var isXAxis = data.axis === 'x' || data.axis === 'both';\n var isYAxis = data.axis === 'y' || data.axis === 'both';\n var canTrackCursorOnAutoUpdate = ['mouseenter', 'mousemove'].includes(((_data$dataRef$current = data.dataRef.current.openEvent) == null ? void 0 : _data$dataRef$current.type) || '') && data.pointerType !== 'touch';\n var width = domRect.width;\n var height = domRect.height;\n var x = domRect.x;\n var y = domRect.y;\n if (offsetX == null && data.x && isXAxis) {\n offsetX = domRect.x - data.x;\n }\n if (offsetY == null && data.y && isYAxis) {\n offsetY = domRect.y - data.y;\n }\n x -= offsetX || 0;\n y -= offsetY || 0;\n width = 0;\n height = 0;\n if (!isAutoUpdateEvent || canTrackCursorOnAutoUpdate) {\n width = data.axis === 'y' ? domRect.width : 0;\n height = data.axis === 'x' ? domRect.height : 0;\n x = isXAxis && data.x != null ? data.x : x;\n y = isYAxis && data.y != null ? data.y : y;\n } else if (isAutoUpdateEvent && !canTrackCursorOnAutoUpdate) {\n height = data.axis === 'x' ? domRect.height : height;\n width = data.axis === 'y' ? domRect.width : width;\n }\n isAutoUpdateEvent = true;\n return {\n width: width,\n height: height,\n x: x,\n y: y,\n top: y,\n right: x + width,\n bottom: y + height,\n left: x\n };\n }\n };\n}\nfunction isMouseBasedEvent(event) {\n return event != null && event.clientX != null;\n}\n/**\n * Positions the floating element relative to a client point (in the viewport),\n * such as the mouse position. By default, it follows the mouse cursor.\n * @see https://floating-ui.com/docs/useClientPoint\n */\nfunction useClientPoint(context, props) {\n if (props === void 0) {\n props = {};\n }\n var open = context.open,\n dataRef = context.dataRef,\n _context$elements2 = context.elements,\n floating = _context$elements2.floating,\n domReference = _context$elements2.domReference,\n refs = context.refs;\n var _props5 = props,\n _props5$enabled = _props5.enabled,\n enabled = _props5$enabled === void 0 ? true : _props5$enabled,\n _props5$axis = _props5.axis,\n axis = _props5$axis === void 0 ? 'both' : _props5$axis,\n _props5$x = _props5.x,\n x = _props5$x === void 0 ? null : _props5$x,\n _props5$y = _props5.y,\n y = _props5$y === void 0 ? null : _props5$y;\n var initialRef = React.useRef(false);\n var cleanupListenerRef = React.useRef(null);\n var _React$useState17 = React.useState(),\n _React$useState18 = _slicedToArray(_React$useState17, 2),\n pointerType = _React$useState18[0],\n setPointerType = _React$useState18[1];\n var _React$useState19 = React.useState([]),\n _React$useState20 = _slicedToArray(_React$useState19, 2),\n reactive = _React$useState20[0],\n setReactive = _React$useState20[1];\n var setReference = useEffectEvent(function (x, y) {\n if (initialRef.current) return;\n\n // Prevent setting if the open event was not a mouse-like one\n // (e.g. focus to open, then hover over the reference element).\n // Only apply if the event exists.\n if (dataRef.current.openEvent && !isMouseBasedEvent(dataRef.current.openEvent)) {\n return;\n }\n refs.setPositionReference(createVirtualElement(domReference, {\n x: x,\n y: y,\n axis: axis,\n dataRef: dataRef,\n pointerType: pointerType\n }));\n });\n var handleReferenceEnterOrMove = useEffectEvent(function (event) {\n if (x != null || y != null) return;\n if (!open) {\n setReference(event.clientX, event.clientY);\n } else if (!cleanupListenerRef.current) {\n // If there's no cleanup, there's no listener, but we want to ensure\n // we add the listener if the cursor landed on the floating element and\n // then back on the reference (i.e. it's interactive).\n setReactive([]);\n }\n });\n\n // If the pointer is a mouse-like pointer, we want to continue following the\n // mouse even if the floating element is transitioning out. On touch\n // devices, this is undesirable because the floating element will move to\n // the dismissal touch point.\n var openCheck = isMouseLikePointerType(pointerType) ? floating : open;\n var addListener = React.useCallback(function () {\n // Explicitly specified `x`/`y` coordinates shouldn't add a listener.\n if (!openCheck || !enabled || x != null || y != null) return;\n var win = getWindow(floating);\n function handleMouseMove(event) {\n var target = getTarget(event);\n if (!contains(floating, target)) {\n setReference(event.clientX, event.clientY);\n } else {\n win.removeEventListener('mousemove', handleMouseMove);\n cleanupListenerRef.current = null;\n }\n }\n if (!dataRef.current.openEvent || isMouseBasedEvent(dataRef.current.openEvent)) {\n win.addEventListener('mousemove', handleMouseMove);\n var cleanup = function cleanup() {\n win.removeEventListener('mousemove', handleMouseMove);\n cleanupListenerRef.current = null;\n };\n cleanupListenerRef.current = cleanup;\n return cleanup;\n }\n refs.setPositionReference(domReference);\n }, [openCheck, enabled, x, y, floating, dataRef, refs, domReference, setReference]);\n React.useEffect(function () {\n return addListener();\n }, [addListener, reactive]);\n React.useEffect(function () {\n if (enabled && !floating) {\n initialRef.current = false;\n }\n }, [enabled, floating]);\n React.useEffect(function () {\n if (!enabled && open) {\n initialRef.current = true;\n }\n }, [enabled, open]);\n index(function () {\n if (enabled && (x != null || y != null)) {\n initialRef.current = false;\n setReference(x, y);\n }\n }, [enabled, x, y, setReference]);\n var reference = React.useMemo(function () {\n function setPointerTypeRef(_ref) {\n var pointerType = _ref.pointerType;\n setPointerType(pointerType);\n }\n return {\n onPointerDown: setPointerTypeRef,\n onPointerEnter: setPointerTypeRef,\n onMouseMove: handleReferenceEnterOrMove,\n onMouseEnter: handleReferenceEnterOrMove\n };\n }, [handleReferenceEnterOrMove]);\n return React.useMemo(function () {\n return enabled ? {\n reference: reference\n } : {};\n }, [enabled, reference]);\n}\nvar bubbleHandlerKeys = {\n pointerdown: 'onPointerDown',\n mousedown: 'onMouseDown',\n click: 'onClick'\n};\nvar captureHandlerKeys = {\n pointerdown: 'onPointerDownCapture',\n mousedown: 'onMouseDownCapture',\n click: 'onClickCapture'\n};\nvar normalizeProp = function normalizeProp(normalizable) {\n var _normalizable$escapeK, _normalizable$outside;\n return {\n escapeKey: typeof normalizable === 'boolean' ? normalizable : (_normalizable$escapeK = normalizable == null ? void 0 : normalizable.escapeKey) != null ? _normalizable$escapeK : false,\n outsidePress: typeof normalizable === 'boolean' ? normalizable : (_normalizable$outside = normalizable == null ? void 0 : normalizable.outsidePress) != null ? _normalizable$outside : true\n };\n};\n/**\n * Closes the floating element when a dismissal is requested — by default, when\n * the user presses the `escape` key or outside of the floating element.\n * @see https://floating-ui.com/docs/useDismiss\n */\nfunction useDismiss(context, props) {\n if (props === void 0) {\n props = {};\n }\n var open = context.open,\n onOpenChange = context.onOpenChange,\n elements = context.elements,\n dataRef = context.dataRef;\n var _props6 = props,\n _props6$enabled = _props6.enabled,\n enabled = _props6$enabled === void 0 ? true : _props6$enabled,\n _props6$escapeKey = _props6.escapeKey,\n escapeKey = _props6$escapeKey === void 0 ? true : _props6$escapeKey,\n _props6$outsidePress = _props6.outsidePress,\n unstable_outsidePress = _props6$outsidePress === void 0 ? true : _props6$outsidePress,\n _props6$outsidePressE = _props6.outsidePressEvent,\n outsidePressEvent = _props6$outsidePressE === void 0 ? 'pointerdown' : _props6$outsidePressE,\n _props6$referencePres = _props6.referencePress,\n referencePress = _props6$referencePres === void 0 ? false : _props6$referencePres,\n _props6$referencePres2 = _props6.referencePressEvent,\n referencePressEvent = _props6$referencePres2 === void 0 ? 'pointerdown' : _props6$referencePres2,\n _props6$ancestorScrol = _props6.ancestorScroll,\n ancestorScroll = _props6$ancestorScrol === void 0 ? false : _props6$ancestorScrol,\n bubbles = _props6.bubbles,\n capture = _props6.capture;\n var tree = useFloatingTree();\n var outsidePressFn = useEffectEvent(typeof unstable_outsidePress === 'function' ? unstable_outsidePress : function () {\n return false;\n });\n var outsidePress = typeof unstable_outsidePress === 'function' ? outsidePressFn : unstable_outsidePress;\n var insideReactTreeRef = React.useRef(false);\n var endedOrStartedInsideRef = React.useRef(false);\n var _normalizeProp = normalizeProp(bubbles),\n escapeKeyBubbles = _normalizeProp.escapeKey,\n outsidePressBubbles = _normalizeProp.outsidePress;\n var _normalizeProp2 = normalizeProp(capture),\n escapeKeyCapture = _normalizeProp2.escapeKey,\n outsidePressCapture = _normalizeProp2.outsidePress;\n var closeOnEscapeKeyDown = useEffectEvent(function (event) {\n var _dataRef$current$floa;\n if (!open || !enabled || !escapeKey || event.key !== 'Escape') {\n return;\n }\n var nodeId = (_dataRef$current$floa = dataRef.current.floatingContext) == null ? void 0 : _dataRef$current$floa.nodeId;\n var children = tree ? getChildren(tree.nodesRef.current, nodeId) : [];\n if (!escapeKeyBubbles) {\n event.stopPropagation();\n if (children.length > 0) {\n var shouldDismiss = true;\n children.forEach(function (child) {\n var _child$context;\n if ((_child$context = child.context) != null && _child$context.open && !child.context.dataRef.current.__escapeKeyBubbles) {\n shouldDismiss = false;\n return;\n }\n });\n if (!shouldDismiss) {\n return;\n }\n }\n }\n onOpenChange(false, isReactEvent(event) ? event.nativeEvent : event, 'escape-key');\n });\n var closeOnEscapeKeyDownCapture = useEffectEvent(function (event) {\n var _getTarget2;\n var callback = function callback() {\n var _getTarget;\n closeOnEscapeKeyDown(event);\n (_getTarget = getTarget(event)) == null || _getTarget.removeEventListener('keydown', callback);\n };\n (_getTarget2 = getTarget(event)) == null || _getTarget2.addEventListener('keydown', callback);\n });\n var closeOnPressOutside = useEffectEvent(function (event) {\n var _dataRef$current$floa2;\n // Given developers can stop the propagation of the synthetic event,\n // we can only be confident with a positive value.\n var insideReactTree = insideReactTreeRef.current;\n insideReactTreeRef.current = false;\n\n // When click outside is lazy (`click` event), handle dragging.\n // Don't close if:\n // - The click started inside the floating element.\n // - The click ended inside the floating element.\n var endedOrStartedInside = endedOrStartedInsideRef.current;\n endedOrStartedInsideRef.current = false;\n if (outsidePressEvent === 'click' && endedOrStartedInside) {\n return;\n }\n if (insideReactTree) {\n return;\n }\n if (typeof outsidePress === 'function' && !outsidePress(event)) {\n return;\n }\n var target = getTarget(event);\n var inertSelector = \"[\" + createAttribute('inert') + \"]\";\n var markers = getDocument(elements.floating).querySelectorAll(inertSelector);\n var targetRootAncestor = isElement(target) ? target : null;\n while (targetRootAncestor && !isLastTraversableNode(targetRootAncestor)) {\n var nextParent = getParentNode(targetRootAncestor);\n if (isLastTraversableNode(nextParent) || !isElement(nextParent)) {\n break;\n }\n targetRootAncestor = nextParent;\n }\n\n // Check if the click occurred on a third-party element injected after the\n // floating element rendered.\n if (markers.length && isElement(target) && !isRootElement(target) &&\n // Clicked on a direct ancestor (e.g. FloatingOverlay).\n !contains(target, elements.floating) &&\n // If the target root element contains none of the markers, then the\n // element was injected after the floating element rendered.\n Array.from(markers).every(function (marker) {\n return !contains(targetRootAncestor, marker);\n })) {\n return;\n }\n\n // Check if the click occurred on the scrollbar\n if (isHTMLElement(target) && floating) {\n // In Firefox, `target.scrollWidth > target.clientWidth` for inline\n // elements.\n var canScrollX = target.clientWidth > 0 && target.scrollWidth > target.clientWidth;\n var canScrollY = target.clientHeight > 0 && target.scrollHeight > target.clientHeight;\n var xCond = canScrollY && event.offsetX > target.clientWidth;\n\n // In some browsers it is possible to change the (or window)\n // scrollbar to the left side, but is very rare and is difficult to\n // check for. Plus, for modal dialogs with backdrops, it is more\n // important that the backdrop is checked but not so much the window.\n if (canScrollY) {\n var isRTL = getComputedStyle(target).direction === 'rtl';\n if (isRTL) {\n xCond = event.offsetX <= target.offsetWidth - target.clientWidth;\n }\n }\n if (xCond || canScrollX && event.offsetY > target.clientHeight) {\n return;\n }\n }\n var nodeId = (_dataRef$current$floa2 = dataRef.current.floatingContext) == null ? void 0 : _dataRef$current$floa2.nodeId;\n var targetIsInsideChildren = tree && getChildren(tree.nodesRef.current, nodeId).some(function (node) {\n var _node$context;\n return isEventTargetWithin(event, (_node$context = node.context) == null ? void 0 : _node$context.elements.floating);\n });\n if (isEventTargetWithin(event, elements.floating) || isEventTargetWithin(event, elements.domReference) || targetIsInsideChildren) {\n return;\n }\n var children = tree ? getChildren(tree.nodesRef.current, nodeId) : [];\n if (children.length > 0) {\n var shouldDismiss = true;\n children.forEach(function (child) {\n var _child$context2;\n if ((_child$context2 = child.context) != null && _child$context2.open && !child.context.dataRef.current.__outsidePressBubbles) {\n shouldDismiss = false;\n return;\n }\n });\n if (!shouldDismiss) {\n return;\n }\n }\n onOpenChange(false, event, 'outside-press');\n });\n var closeOnPressOutsideCapture = useEffectEvent(function (event) {\n var _getTarget4;\n var callback = function callback() {\n var _getTarget3;\n closeOnPressOutside(event);\n (_getTarget3 = getTarget(event)) == null || _getTarget3.removeEventListener(outsidePressEvent, callback);\n };\n (_getTarget4 = getTarget(event)) == null || _getTarget4.addEventListener(outsidePressEvent, callback);\n });\n React.useEffect(function () {\n if (!open || !enabled) {\n return;\n }\n dataRef.current.__escapeKeyBubbles = escapeKeyBubbles;\n dataRef.current.__outsidePressBubbles = outsidePressBubbles;\n function onScroll(event) {\n onOpenChange(false, event, 'ancestor-scroll');\n }\n var doc = getDocument(elements.floating);\n escapeKey && doc.addEventListener('keydown', escapeKeyCapture ? closeOnEscapeKeyDownCapture : closeOnEscapeKeyDown, escapeKeyCapture);\n outsidePress && doc.addEventListener(outsidePressEvent, outsidePressCapture ? closeOnPressOutsideCapture : closeOnPressOutside, outsidePressCapture);\n var ancestors = [];\n if (ancestorScroll) {\n if (isElement(elements.domReference)) {\n ancestors = getOverflowAncestors(elements.domReference);\n }\n if (isElement(elements.floating)) {\n ancestors = ancestors.concat(getOverflowAncestors(elements.floating));\n }\n if (!isElement(elements.reference) && elements.reference && elements.reference.contextElement) {\n ancestors = ancestors.concat(getOverflowAncestors(elements.reference.contextElement));\n }\n }\n\n // Ignore the visual viewport for scrolling dismissal (allow pinch-zoom)\n ancestors = ancestors.filter(function (ancestor) {\n var _doc$defaultView;\n return ancestor !== ((_doc$defaultView = doc.defaultView) == null ? void 0 : _doc$defaultView.visualViewport);\n });\n ancestors.forEach(function (ancestor) {\n ancestor.addEventListener('scroll', onScroll, {\n passive: true\n });\n });\n return function () {\n escapeKey && doc.removeEventListener('keydown', escapeKeyCapture ? closeOnEscapeKeyDownCapture : closeOnEscapeKeyDown, escapeKeyCapture);\n outsidePress && doc.removeEventListener(outsidePressEvent, outsidePressCapture ? closeOnPressOutsideCapture : closeOnPressOutside, outsidePressCapture);\n ancestors.forEach(function (ancestor) {\n ancestor.removeEventListener('scroll', onScroll);\n });\n };\n }, [dataRef, elements, escapeKey, outsidePress, outsidePressEvent, open, onOpenChange, ancestorScroll, enabled, escapeKeyBubbles, outsidePressBubbles, closeOnEscapeKeyDown, escapeKeyCapture, closeOnEscapeKeyDownCapture, closeOnPressOutside, outsidePressCapture, closeOnPressOutsideCapture]);\n React.useEffect(function () {\n insideReactTreeRef.current = false;\n }, [outsidePress, outsidePressEvent]);\n var reference = React.useMemo(function () {\n return _defineProperty({\n onKeyDown: closeOnEscapeKeyDown\n }, bubbleHandlerKeys[referencePressEvent], function (event) {\n if (referencePress) {\n onOpenChange(false, event.nativeEvent, 'reference-press');\n }\n });\n }, [closeOnEscapeKeyDown, onOpenChange, referencePress, referencePressEvent]);\n var floating = React.useMemo(function () {\n return _defineProperty({\n onKeyDown: closeOnEscapeKeyDown,\n onMouseDown: function onMouseDown() {\n endedOrStartedInsideRef.current = true;\n },\n onMouseUp: function onMouseUp() {\n endedOrStartedInsideRef.current = true;\n }\n }, captureHandlerKeys[outsidePressEvent], function () {\n insideReactTreeRef.current = true;\n });\n }, [closeOnEscapeKeyDown, outsidePressEvent]);\n return React.useMemo(function () {\n return enabled ? {\n reference: reference,\n floating: floating\n } : {};\n }, [enabled, reference, floating]);\n}\nfunction useFloatingRootContext(options) {\n var _options$open = options.open,\n open = _options$open === void 0 ? false : _options$open,\n onOpenChangeProp = options.onOpenChange,\n elementsProp = options.elements;\n var floatingId = useId();\n var dataRef = React.useRef({});\n var _React$useState21 = React.useState(function () {\n return createPubSub();\n }),\n _React$useState22 = _slicedToArray(_React$useState21, 1),\n events = _React$useState22[0];\n var nested = useFloatingParentNodeId() != null;\n if (process.env.NODE_ENV !== \"production\") {\n var optionDomReference = elementsProp.reference;\n if (optionDomReference && !isElement(optionDomReference)) {\n error('Cannot pass a virtual element to the `elements.reference` option,', 'as it must be a real DOM element. Use `refs.setPositionReference()`', 'instead.');\n }\n }\n var _React$useState23 = React.useState(elementsProp.reference),\n _React$useState24 = _slicedToArray(_React$useState23, 2),\n positionReference = _React$useState24[0],\n setPositionReference = _React$useState24[1];\n var onOpenChange = useEffectEvent(function (open, event, reason) {\n dataRef.current.openEvent = open ? event : undefined;\n events.emit('openchange', {\n open: open,\n event: event,\n reason: reason,\n nested: nested\n });\n onOpenChangeProp == null || onOpenChangeProp(open, event, reason);\n });\n var refs = React.useMemo(function () {\n return {\n setPositionReference: setPositionReference\n };\n }, []);\n var elements = React.useMemo(function () {\n return {\n reference: positionReference || elementsProp.reference || null,\n floating: elementsProp.floating || null,\n domReference: elementsProp.reference\n };\n }, [positionReference, elementsProp.reference, elementsProp.floating]);\n return React.useMemo(function () {\n return {\n dataRef: dataRef,\n open: open,\n onOpenChange: onOpenChange,\n elements: elements,\n events: events,\n floatingId: floatingId,\n refs: refs\n };\n }, [open, onOpenChange, elements, events, floatingId, refs]);\n}\n\n/**\n * Provides data to position a floating element and context to add interactions.\n * @see https://floating-ui.com/docs/useFloating\n */\nfunction useFloating(options) {\n if (options === void 0) {\n options = {};\n }\n var _options3 = options,\n nodeId = _options3.nodeId;\n var internalRootContext = useFloatingRootContext(_objectSpread(_objectSpread({}, options), {}, {\n elements: _objectSpread({\n reference: null,\n floating: null\n }, options.elements)\n }));\n var rootContext = options.rootContext || internalRootContext;\n var computedElements = rootContext.elements;\n var _React$useState25 = React.useState(null),\n _React$useState26 = _slicedToArray(_React$useState25, 2),\n _domReference = _React$useState26[0],\n setDomReference = _React$useState26[1];\n var _React$useState27 = React.useState(null),\n _React$useState28 = _slicedToArray(_React$useState27, 2),\n positionReference = _React$useState28[0],\n _setPositionReference = _React$useState28[1];\n var optionDomReference = computedElements == null ? void 0 : computedElements.reference;\n var domReference = optionDomReference || _domReference;\n var domReferenceRef = React.useRef(null);\n var tree = useFloatingTree();\n index(function () {\n if (domReference) {\n domReferenceRef.current = domReference;\n }\n }, [domReference]);\n var position = useFloating$1(_objectSpread(_objectSpread({}, options), {}, {\n elements: _objectSpread(_objectSpread({}, computedElements), positionReference && {\n reference: positionReference\n })\n }));\n var setPositionReference = React.useCallback(function (node) {\n var computedPositionReference = isElement(node) ? {\n getBoundingClientRect: function getBoundingClientRect() {\n return node.getBoundingClientRect();\n },\n contextElement: node\n } : node;\n // Store the positionReference in state if the DOM reference is specified externally via the\n // `elements.reference` option. This ensures that it won't be overridden on future renders.\n _setPositionReference(computedPositionReference);\n position.refs.setReference(computedPositionReference);\n }, [position.refs]);\n var setReference = React.useCallback(function (node) {\n if (isElement(node) || node === null) {\n domReferenceRef.current = node;\n setDomReference(node);\n }\n\n // Backwards-compatibility for passing a virtual element to `reference`\n // after it has set the DOM reference.\n if (isElement(position.refs.reference.current) || position.refs.reference.current === null ||\n // Don't allow setting virtual elements using the old technique back to\n // `null` to support `positionReference` + an unstable `reference`\n // callback ref.\n node !== null && !isElement(node)) {\n position.refs.setReference(node);\n }\n }, [position.refs]);\n var refs = React.useMemo(function () {\n return _objectSpread(_objectSpread({}, position.refs), {}, {\n setReference: setReference,\n setPositionReference: setPositionReference,\n domReference: domReferenceRef\n });\n }, [position.refs, setReference, setPositionReference]);\n var elements = React.useMemo(function () {\n return _objectSpread(_objectSpread({}, position.elements), {}, {\n domReference: domReference\n });\n }, [position.elements, domReference]);\n var context = React.useMemo(function () {\n return _objectSpread(_objectSpread(_objectSpread({}, position), rootContext), {}, {\n refs: refs,\n elements: elements,\n nodeId: nodeId\n });\n }, [position, refs, elements, nodeId, rootContext]);\n index(function () {\n rootContext.dataRef.current.floatingContext = context;\n var node = tree == null ? void 0 : tree.nodesRef.current.find(function (node) {\n return node.id === nodeId;\n });\n if (node) {\n node.context = context;\n }\n });\n return React.useMemo(function () {\n return _objectSpread(_objectSpread({}, position), {}, {\n context: context,\n refs: refs,\n elements: elements\n });\n }, [position, refs, elements, context]);\n}\n\n/**\n * Opens the floating element while the reference element has focus, like CSS\n * `:focus`.\n * @see https://floating-ui.com/docs/useFocus\n */\nfunction useFocus(context, props) {\n if (props === void 0) {\n props = {};\n }\n var open = context.open,\n onOpenChange = context.onOpenChange,\n events = context.events,\n dataRef = context.dataRef,\n elements = context.elements;\n var _props7 = props,\n _props7$enabled = _props7.enabled,\n enabled = _props7$enabled === void 0 ? true : _props7$enabled,\n _props7$visibleOnly = _props7.visibleOnly,\n visibleOnly = _props7$visibleOnly === void 0 ? true : _props7$visibleOnly;\n var blockFocusRef = React.useRef(false);\n var timeoutRef = React.useRef();\n var keyboardModalityRef = React.useRef(true);\n React.useEffect(function () {\n if (!enabled) return;\n var win = getWindow(elements.domReference);\n\n // If the reference was focused and the user left the tab/window, and the\n // floating element was not open, the focus should be blocked when they\n // return to the tab/window.\n function onBlur() {\n if (!open && isHTMLElement(elements.domReference) && elements.domReference === activeElement(getDocument(elements.domReference))) {\n blockFocusRef.current = true;\n }\n }\n function onKeyDown() {\n keyboardModalityRef.current = true;\n }\n win.addEventListener('blur', onBlur);\n win.addEventListener('keydown', onKeyDown, true);\n return function () {\n win.removeEventListener('blur', onBlur);\n win.removeEventListener('keydown', onKeyDown, true);\n };\n }, [elements.domReference, open, enabled]);\n React.useEffect(function () {\n if (!enabled) return;\n function onOpenChange(_ref) {\n var reason = _ref.reason;\n if (reason === 'reference-press' || reason === 'escape-key') {\n blockFocusRef.current = true;\n }\n }\n events.on('openchange', onOpenChange);\n return function () {\n events.off('openchange', onOpenChange);\n };\n }, [events, enabled]);\n React.useEffect(function () {\n return function () {\n clearTimeout(timeoutRef.current);\n };\n }, []);\n var reference = React.useMemo(function () {\n return {\n onPointerDown: function onPointerDown(event) {\n if (isVirtualPointerEvent(event.nativeEvent)) return;\n keyboardModalityRef.current = false;\n },\n onMouseLeave: function onMouseLeave() {\n blockFocusRef.current = false;\n },\n onFocus: function onFocus(event) {\n if (blockFocusRef.current) return;\n var target = getTarget(event.nativeEvent);\n if (visibleOnly && isElement(target)) {\n try {\n // Mac Safari unreliably matches `:focus-visible` on the reference\n // if focus was outside the page initially - use the fallback\n // instead.\n if (isSafari() && isMac()) throw Error();\n if (!target.matches(':focus-visible')) return;\n } catch (e) {\n // Old browsers will throw an error when using `:focus-visible`.\n if (!keyboardModalityRef.current && !isTypeableElement(target)) {\n return;\n }\n }\n }\n onOpenChange(true, event.nativeEvent, 'focus');\n },\n onBlur: function onBlur(event) {\n blockFocusRef.current = false;\n var relatedTarget = event.relatedTarget;\n var nativeEvent = event.nativeEvent;\n\n // Hit the non-modal focus management portal guard. Focus will be\n // moved into the floating element immediately after.\n var movedToFocusGuard = isElement(relatedTarget) && relatedTarget.hasAttribute(createAttribute('focus-guard')) && relatedTarget.getAttribute('data-type') === 'outside';\n\n // Wait for the window blur listener to fire.\n timeoutRef.current = window.setTimeout(function () {\n var _dataRef$current$floa;\n var activeEl = activeElement(elements.domReference ? elements.domReference.ownerDocument : document);\n\n // Focus left the page, keep it open.\n if (!relatedTarget && activeEl === elements.domReference) return;\n\n // When focusing the reference element (e.g. regular click), then\n // clicking into the floating element, prevent it from hiding.\n // Note: it must be focusable, e.g. `tabindex=\"-1\"`.\n // We can not rely on relatedTarget to point to the correct element\n // as it will only point to the shadow host of the newly focused element\n // and not the element that actually has received focus if it is located\n // inside a shadow root.\n if (contains((_dataRef$current$floa = dataRef.current.floatingContext) == null ? void 0 : _dataRef$current$floa.refs.floating.current, activeEl) || contains(elements.domReference, activeEl) || movedToFocusGuard) {\n return;\n }\n onOpenChange(false, nativeEvent, 'focus');\n });\n }\n };\n }, [dataRef, elements.domReference, onOpenChange, visibleOnly]);\n return React.useMemo(function () {\n return enabled ? {\n reference: reference\n } : {};\n }, [enabled, reference]);\n}\nvar ACTIVE_KEY = 'active';\nvar SELECTED_KEY = 'selected';\nfunction mergeProps(userProps, propsList, elementKey) {\n var map = new Map();\n var isItem = elementKey === 'item';\n var domUserProps = userProps;\n if (isItem && userProps) {\n var _ = userProps[ACTIVE_KEY],\n __ = userProps[SELECTED_KEY],\n validProps = _objectWithoutProperties(userProps, [ACTIVE_KEY, SELECTED_KEY].map(_toPropertyKey));\n domUserProps = validProps;\n }\n return _objectSpread(_objectSpread(_objectSpread({}, elementKey === 'floating' && {\n tabIndex: -1\n }), domUserProps), propsList.map(function (value) {\n var propsOrGetProps = value ? value[elementKey] : null;\n if (typeof propsOrGetProps === 'function') {\n return userProps ? propsOrGetProps(userProps) : null;\n }\n return propsOrGetProps;\n }).concat(userProps).reduce(function (acc, props) {\n if (!props) {\n return acc;\n }\n Object.entries(props).forEach(function (_ref) {\n var _ref10 = _slicedToArray(_ref, 2),\n key = _ref10[0],\n value = _ref10[1];\n if (isItem && [ACTIVE_KEY, SELECTED_KEY].includes(key)) {\n return;\n }\n if (key.indexOf('on') === 0) {\n if (!map.has(key)) {\n map.set(key, []);\n }\n if (typeof value === 'function') {\n var _map$get;\n (_map$get = map.get(key)) == null || _map$get.push(value);\n acc[key] = function () {\n var _map$get2;\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n return (_map$get2 = map.get(key)) == null ? void 0 : _map$get2.map(function (fn) {\n return fn.apply(void 0, args);\n }).find(function (val) {\n return val !== undefined;\n });\n };\n }\n } else {\n acc[key] = value;\n }\n });\n return acc;\n }, {}));\n}\n/**\n * Merges an array of interaction hooks' props into prop getters, allowing\n * event handler functions to be composed together without overwriting one\n * another.\n * @see https://floating-ui.com/docs/useInteractions\n */\nfunction useInteractions(propsList) {\n if (propsList === void 0) {\n propsList = [];\n }\n var referenceDeps = propsList.map(function (key) {\n return key == null ? void 0 : key.reference;\n });\n var floatingDeps = propsList.map(function (key) {\n return key == null ? void 0 : key.floating;\n });\n var itemDeps = propsList.map(function (key) {\n return key == null ? void 0 : key.item;\n });\n var getReferenceProps = React.useCallback(function (userProps) {\n return mergeProps(userProps, propsList, 'reference');\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n referenceDeps);\n var getFloatingProps = React.useCallback(function (userProps) {\n return mergeProps(userProps, propsList, 'floating');\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n floatingDeps);\n var getItemProps = React.useCallback(function (userProps) {\n return mergeProps(userProps, propsList, 'item');\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n itemDeps);\n return React.useMemo(function () {\n return {\n getReferenceProps: getReferenceProps,\n getFloatingProps: getFloatingProps,\n getItemProps: getItemProps\n };\n }, [getReferenceProps, getFloatingProps, getItemProps]);\n}\nvar isPreventScrollSupported = false;\nfunction doSwitch(orientation, vertical, horizontal) {\n switch (orientation) {\n case 'vertical':\n return vertical;\n case 'horizontal':\n return horizontal;\n default:\n return vertical || horizontal;\n }\n}\nfunction isMainOrientationKey(key, orientation) {\n var vertical = key === ARROW_UP || key === ARROW_DOWN;\n var horizontal = key === ARROW_LEFT || key === ARROW_RIGHT;\n return doSwitch(orientation, vertical, horizontal);\n}\nfunction isMainOrientationToEndKey(key, orientation, rtl) {\n var vertical = key === ARROW_DOWN;\n var horizontal = rtl ? key === ARROW_LEFT : key === ARROW_RIGHT;\n return doSwitch(orientation, vertical, horizontal) || key === 'Enter' || key === ' ' || key === '';\n}\nfunction isCrossOrientationOpenKey(key, orientation, rtl) {\n var vertical = rtl ? key === ARROW_LEFT : key === ARROW_RIGHT;\n var horizontal = key === ARROW_DOWN;\n return doSwitch(orientation, vertical, horizontal);\n}\nfunction isCrossOrientationCloseKey(key, orientation, rtl) {\n var vertical = rtl ? key === ARROW_RIGHT : key === ARROW_LEFT;\n var horizontal = key === ARROW_UP;\n return doSwitch(orientation, vertical, horizontal);\n}\n/**\n * Adds arrow key-based navigation of a list of items, either using real DOM\n * focus or virtual focus.\n * @see https://floating-ui.com/docs/useListNavigation\n */\nfunction useListNavigation(context, props) {\n var open = context.open,\n onOpenChange = context.onOpenChange,\n elements = context.elements;\n var listRef = props.listRef,\n activeIndex = props.activeIndex,\n _props$onNavigate = props.onNavigate,\n unstable_onNavigate = _props$onNavigate === void 0 ? function () {} : _props$onNavigate,\n _props$enabled = props.enabled,\n enabled = _props$enabled === void 0 ? true : _props$enabled,\n _props$selectedIndex = props.selectedIndex,\n selectedIndex = _props$selectedIndex === void 0 ? null : _props$selectedIndex,\n _props$allowEscape = props.allowEscape,\n allowEscape = _props$allowEscape === void 0 ? false : _props$allowEscape,\n _props$loop2 = props.loop,\n loop = _props$loop2 === void 0 ? false : _props$loop2,\n _props$nested = props.nested,\n nested = _props$nested === void 0 ? false : _props$nested,\n _props$rtl = props.rtl,\n rtl = _props$rtl === void 0 ? false : _props$rtl,\n _props$virtual = props.virtual,\n virtual = _props$virtual === void 0 ? false : _props$virtual,\n _props$focusItemOnOpe = props.focusItemOnOpen,\n focusItemOnOpen = _props$focusItemOnOpe === void 0 ? 'auto' : _props$focusItemOnOpe,\n _props$focusItemOnHov = props.focusItemOnHover,\n focusItemOnHover = _props$focusItemOnHov === void 0 ? true : _props$focusItemOnHov,\n _props$openOnArrowKey = props.openOnArrowKeyDown,\n openOnArrowKeyDown = _props$openOnArrowKey === void 0 ? true : _props$openOnArrowKey,\n _props$disabledIndice = props.disabledIndices,\n disabledIndices = _props$disabledIndice === void 0 ? undefined : _props$disabledIndice,\n _props$orientation2 = props.orientation,\n orientation = _props$orientation2 === void 0 ? 'vertical' : _props$orientation2,\n _props$cols2 = props.cols,\n cols = _props$cols2 === void 0 ? 1 : _props$cols2,\n _props$scrollItemInto = props.scrollItemIntoView,\n scrollItemIntoView = _props$scrollItemInto === void 0 ? true : _props$scrollItemInto,\n virtualItemRef = props.virtualItemRef,\n itemSizes = props.itemSizes,\n _props$dense2 = props.dense,\n dense = _props$dense2 === void 0 ? false : _props$dense2;\n if (process.env.NODE_ENV !== \"production\") {\n if (allowEscape) {\n if (!loop) {\n warn('`useListNavigation` looping must be enabled to allow escaping.');\n }\n if (!virtual) {\n warn('`useListNavigation` must be virtual to allow escaping.');\n }\n }\n if (orientation === 'vertical' && cols > 1) {\n warn('In grid list navigation mode (`cols` > 1), the `orientation` should', 'be either \"horizontal\" or \"both\".');\n }\n }\n var parentId = useFloatingParentNodeId();\n var tree = useFloatingTree();\n var onNavigate = useEffectEvent(unstable_onNavigate);\n var focusItemOnOpenRef = React.useRef(focusItemOnOpen);\n var indexRef = React.useRef(selectedIndex != null ? selectedIndex : -1);\n var keyRef = React.useRef(null);\n var isPointerModalityRef = React.useRef(true);\n var previousOnNavigateRef = React.useRef(onNavigate);\n var previousMountedRef = React.useRef(!!elements.floating);\n var previousOpenRef = React.useRef(open);\n var forceSyncFocus = React.useRef(false);\n var forceScrollIntoViewRef = React.useRef(false);\n var disabledIndicesRef = useLatestRef(disabledIndices);\n var latestOpenRef = useLatestRef(open);\n var scrollItemIntoViewRef = useLatestRef(scrollItemIntoView);\n var floatingRef = useLatestRef(elements.floating);\n var selectedIndexRef = useLatestRef(selectedIndex);\n var _React$useState29 = React.useState(),\n _React$useState30 = _slicedToArray(_React$useState29, 2),\n activeId = _React$useState30[0],\n setActiveId = _React$useState30[1];\n var _React$useState31 = React.useState(),\n _React$useState32 = _slicedToArray(_React$useState31, 2),\n virtualId = _React$useState32[0],\n setVirtualId = _React$useState32[1];\n var focusItem = useEffectEvent(function (listRef, indexRef, forceScrollIntoView) {\n if (forceScrollIntoView === void 0) {\n forceScrollIntoView = false;\n }\n function runFocus(item) {\n if (virtual) {\n setActiveId(item.id);\n tree == null || tree.events.emit('virtualfocus', item);\n if (virtualItemRef) {\n virtualItemRef.current = item;\n }\n } else {\n enqueueFocus(item, {\n preventScroll: true,\n // Mac Safari does not move the virtual cursor unless the focus call\n // is sync. However, for the very first focus call, we need to wait\n // for the position to be ready in order to prevent unwanted\n // scrolling. This means the virtual cursor will not move to the first\n // item when first opening the floating element, but will on\n // subsequent calls. `preventScroll` is supported in modern Safari,\n // so we can use that instead.\n // iOS Safari must be async or the first item will not be focused.\n sync: isMac() && isSafari() ? isPreventScrollSupported || forceSyncFocus.current : false\n });\n }\n }\n var initialItem = listRef.current[indexRef.current];\n if (initialItem) {\n runFocus(initialItem);\n }\n requestAnimationFrame(function () {\n var waitedItem = listRef.current[indexRef.current] || initialItem;\n if (!waitedItem) return;\n if (!initialItem) {\n runFocus(waitedItem);\n }\n var scrollIntoViewOptions = scrollItemIntoViewRef.current;\n var shouldScrollIntoView = scrollIntoViewOptions && item && (forceScrollIntoView || !isPointerModalityRef.current);\n if (shouldScrollIntoView) {\n // JSDOM doesn't support `.scrollIntoView()` but it's widely supported\n // by all browsers.\n waitedItem.scrollIntoView == null || waitedItem.scrollIntoView(typeof scrollIntoViewOptions === 'boolean' ? {\n block: 'nearest',\n inline: 'nearest'\n } : scrollIntoViewOptions);\n }\n });\n });\n index(function () {\n document.createElement('div').focus({\n get preventScroll() {\n isPreventScrollSupported = true;\n return false;\n }\n });\n }, []);\n\n // Sync `selectedIndex` to be the `activeIndex` upon opening the floating\n // element. Also, reset `activeIndex` upon closing the floating element.\n index(function () {\n if (!enabled) return;\n if (open && elements.floating) {\n if (focusItemOnOpenRef.current && selectedIndex != null) {\n // Regardless of the pointer modality, we want to ensure the selected\n // item comes into view when the floating element is opened.\n forceScrollIntoViewRef.current = true;\n indexRef.current = selectedIndex;\n onNavigate(selectedIndex);\n }\n } else if (previousMountedRef.current) {\n // Since the user can specify `onNavigate` conditionally\n // (onNavigate: open ? setActiveIndex : setSelectedIndex),\n // we store and call the previous function.\n indexRef.current = -1;\n previousOnNavigateRef.current(null);\n }\n }, [enabled, open, elements.floating, selectedIndex, onNavigate]);\n\n // Sync `activeIndex` to be the focused item while the floating element is\n // open.\n index(function () {\n if (!enabled) return;\n if (open && elements.floating) {\n if (activeIndex == null) {\n forceSyncFocus.current = false;\n if (selectedIndexRef.current != null) {\n return;\n }\n\n // Reset while the floating element was open (e.g. the list changed).\n if (previousMountedRef.current) {\n indexRef.current = -1;\n focusItem(listRef, indexRef);\n }\n\n // Initial sync.\n if ((!previousOpenRef.current || !previousMountedRef.current) && focusItemOnOpenRef.current && (keyRef.current != null || focusItemOnOpenRef.current === true && keyRef.current == null)) {\n var runs = 0;\n var waitForListPopulated = function waitForListPopulated() {\n if (listRef.current[0] == null) {\n // Avoid letting the browser paint if possible on the first try,\n // otherwise use rAF. Don't try more than twice, since something\n // is wrong otherwise.\n if (runs < 2) {\n var scheduler = runs ? requestAnimationFrame : queueMicrotask;\n scheduler(waitForListPopulated);\n }\n runs++;\n } else {\n indexRef.current = keyRef.current == null || isMainOrientationToEndKey(keyRef.current, orientation, rtl) || nested ? getMinIndex(listRef, disabledIndicesRef.current) : getMaxIndex(listRef, disabledIndicesRef.current);\n keyRef.current = null;\n onNavigate(indexRef.current);\n }\n };\n waitForListPopulated();\n }\n } else if (!isIndexOutOfBounds(listRef, activeIndex)) {\n indexRef.current = activeIndex;\n focusItem(listRef, indexRef, forceScrollIntoViewRef.current);\n forceScrollIntoViewRef.current = false;\n }\n }\n }, [enabled, open, elements.floating, activeIndex, selectedIndexRef, nested, listRef, orientation, rtl, onNavigate, focusItem, disabledIndicesRef]);\n\n // Ensure the parent floating element has focus when a nested child closes\n // to allow arrow key navigation to work after the pointer leaves the child.\n index(function () {\n var _nodes$find;\n if (!enabled || elements.floating || !tree || virtual || !previousMountedRef.current) {\n return;\n }\n var nodes = tree.nodesRef.current;\n var parent = (_nodes$find = nodes.find(function (node) {\n return node.id === parentId;\n })) == null || (_nodes$find = _nodes$find.context) == null ? void 0 : _nodes$find.elements.floating;\n var activeEl = activeElement(getDocument(elements.floating));\n var treeContainsActiveEl = nodes.some(function (node) {\n return node.context && contains(node.context.elements.floating, activeEl);\n });\n if (parent && !treeContainsActiveEl && isPointerModalityRef.current) {\n parent.focus({\n preventScroll: true\n });\n }\n }, [enabled, elements.floating, tree, parentId, virtual]);\n index(function () {\n if (!enabled) return;\n if (!tree) return;\n if (!virtual) return;\n if (parentId) return;\n function handleVirtualFocus(item) {\n setVirtualId(item.id);\n if (virtualItemRef) {\n virtualItemRef.current = item;\n }\n }\n tree.events.on('virtualfocus', handleVirtualFocus);\n return function () {\n tree.events.off('virtualfocus', handleVirtualFocus);\n };\n }, [enabled, tree, virtual, parentId, virtualItemRef]);\n index(function () {\n previousOnNavigateRef.current = onNavigate;\n previousMountedRef.current = !!elements.floating;\n });\n index(function () {\n if (!open) {\n keyRef.current = null;\n }\n }, [open]);\n index(function () {\n previousOpenRef.current = open;\n }, [open]);\n var hasActiveIndex = activeIndex != null;\n var item = React.useMemo(function () {\n function syncCurrentTarget(currentTarget) {\n if (!open) return;\n var index = listRef.current.indexOf(currentTarget);\n if (index !== -1) {\n onNavigate(index);\n }\n }\n var props = _objectSpread({\n onFocus: function onFocus(_ref) {\n var currentTarget = _ref.currentTarget;\n syncCurrentTarget(currentTarget);\n },\n onClick: function onClick(_ref2) {\n var currentTarget = _ref2.currentTarget;\n return currentTarget.focus({\n preventScroll: true\n });\n }\n }, focusItemOnHover && {\n onMouseMove: function onMouseMove(_ref3) {\n var currentTarget = _ref3.currentTarget;\n syncCurrentTarget(currentTarget);\n },\n onPointerLeave: function onPointerLeave(_ref4) {\n var pointerType = _ref4.pointerType;\n if (!isPointerModalityRef.current || pointerType === 'touch') {\n return;\n }\n indexRef.current = -1;\n focusItem(listRef, indexRef);\n onNavigate(null);\n if (!virtual) {\n enqueueFocus(floatingRef.current, {\n preventScroll: true\n });\n }\n }\n });\n return props;\n }, [open, floatingRef, focusItem, focusItemOnHover, listRef, onNavigate, virtual]);\n var commonOnKeyDown = useEffectEvent(function (event) {\n isPointerModalityRef.current = false;\n forceSyncFocus.current = true;\n\n // If the floating element is animating out, ignore navigation. Otherwise,\n // the `activeIndex` gets set to 0 despite not being open so the next time\n // the user ArrowDowns, the first item won't be focused.\n if (!latestOpenRef.current && event.currentTarget === floatingRef.current) {\n return;\n }\n if (nested && isCrossOrientationCloseKey(event.key, orientation, rtl)) {\n stopEvent(event);\n onOpenChange(false, event.nativeEvent, 'list-navigation');\n if (isHTMLElement(elements.domReference) && !virtual) {\n elements.domReference.focus();\n }\n return;\n }\n var currentIndex = indexRef.current;\n var minIndex = getMinIndex(listRef, disabledIndices);\n var maxIndex = getMaxIndex(listRef, disabledIndices);\n if (event.key === 'Home') {\n stopEvent(event);\n indexRef.current = minIndex;\n onNavigate(indexRef.current);\n }\n if (event.key === 'End') {\n stopEvent(event);\n indexRef.current = maxIndex;\n onNavigate(indexRef.current);\n }\n\n // Grid navigation.\n if (cols > 1) {\n var sizes = itemSizes || Array.from({\n length: listRef.current.length\n }, function () {\n return {\n width: 1,\n height: 1\n };\n });\n // To calculate movements on the grid, we use hypothetical cell indices\n // as if every item was 1x1, then convert back to real indices.\n var cellMap = buildCellMap(sizes, cols, dense);\n var minGridIndex = cellMap.findIndex(function (index) {\n return index != null && !isDisabled(listRef.current, index, disabledIndices);\n });\n // last enabled index\n var maxGridIndex = cellMap.reduce(function (foundIndex, index, cellIndex) {\n return index != null && !isDisabled(listRef.current, index, disabledIndices) ? cellIndex : foundIndex;\n }, -1);\n indexRef.current = cellMap[getGridNavigatedIndex({\n current: cellMap.map(function (itemIndex) {\n return itemIndex != null ? listRef.current[itemIndex] : null;\n })\n }, {\n event: event,\n orientation: orientation,\n loop: loop,\n cols: cols,\n // treat undefined (empty grid spaces) as disabled indices so we\n // don't end up in them\n disabledIndices: getCellIndices([].concat(_toConsumableArray(disabledIndices || listRef.current.map(function (_, index) {\n return isDisabled(listRef.current, index) ? index : undefined;\n })), [undefined]), cellMap),\n minIndex: minGridIndex,\n maxIndex: maxGridIndex,\n prevIndex: getCellIndexOfCorner(indexRef.current > maxIndex ? minIndex : indexRef.current, sizes, cellMap, cols,\n // use a corner matching the edge closest to the direction\n // we're moving in so we don't end up in the same item. Prefer\n // top/left over bottom/right.\n event.key === ARROW_DOWN ? 'bl' : event.key === ARROW_RIGHT ? 'tr' : 'tl'),\n stopEvent: true\n })]; // navigated cell will never be nullish\n\n onNavigate(indexRef.current);\n if (orientation === 'both') {\n return;\n }\n }\n if (isMainOrientationKey(event.key, orientation)) {\n stopEvent(event);\n\n // Reset the index if no item is focused.\n if (open && !virtual && activeElement(event.currentTarget.ownerDocument) === event.currentTarget) {\n indexRef.current = isMainOrientationToEndKey(event.key, orientation, rtl) ? minIndex : maxIndex;\n onNavigate(indexRef.current);\n return;\n }\n if (isMainOrientationToEndKey(event.key, orientation, rtl)) {\n if (loop) {\n indexRef.current = currentIndex >= maxIndex ? allowEscape && currentIndex !== listRef.current.length ? -1 : minIndex : findNonDisabledIndex(listRef, {\n startingIndex: currentIndex,\n disabledIndices: disabledIndices\n });\n } else {\n indexRef.current = Math.min(maxIndex, findNonDisabledIndex(listRef, {\n startingIndex: currentIndex,\n disabledIndices: disabledIndices\n }));\n }\n } else {\n if (loop) {\n indexRef.current = currentIndex <= minIndex ? allowEscape && currentIndex !== -1 ? listRef.current.length : maxIndex : findNonDisabledIndex(listRef, {\n startingIndex: currentIndex,\n decrement: true,\n disabledIndices: disabledIndices\n });\n } else {\n indexRef.current = Math.max(minIndex, findNonDisabledIndex(listRef, {\n startingIndex: currentIndex,\n decrement: true,\n disabledIndices: disabledIndices\n }));\n }\n }\n if (isIndexOutOfBounds(listRef, indexRef.current)) {\n onNavigate(null);\n } else {\n onNavigate(indexRef.current);\n }\n }\n });\n var ariaActiveDescendantProp = React.useMemo(function () {\n return virtual && open && hasActiveIndex && {\n 'aria-activedescendant': virtualId || activeId\n };\n }, [virtual, open, hasActiveIndex, virtualId, activeId]);\n var floating = React.useMemo(function () {\n return _objectSpread(_objectSpread({\n 'aria-orientation': orientation === 'both' ? undefined : orientation\n }, !isTypeableCombobox(elements.domReference) && ariaActiveDescendantProp), {}, {\n onKeyDown: commonOnKeyDown,\n onPointerMove: function onPointerMove() {\n isPointerModalityRef.current = true;\n }\n });\n }, [ariaActiveDescendantProp, commonOnKeyDown, elements.domReference, orientation]);\n var reference = React.useMemo(function () {\n function checkVirtualMouse(event) {\n if (focusItemOnOpen === 'auto' && isVirtualClick(event.nativeEvent)) {\n focusItemOnOpenRef.current = true;\n }\n }\n function checkVirtualPointer(event) {\n // `pointerdown` fires first, reset the state then perform the checks.\n focusItemOnOpenRef.current = focusItemOnOpen;\n if (focusItemOnOpen === 'auto' && isVirtualPointerEvent(event.nativeEvent)) {\n focusItemOnOpenRef.current = true;\n }\n }\n return _objectSpread(_objectSpread({}, ariaActiveDescendantProp), {}, {\n onKeyDown: function onKeyDown(event) {\n isPointerModalityRef.current = false;\n var isArrowKey = event.key.indexOf('Arrow') === 0;\n var isCrossOpenKey = isCrossOrientationOpenKey(event.key, orientation, rtl);\n var isCrossCloseKey = isCrossOrientationCloseKey(event.key, orientation, rtl);\n var isMainKey = isMainOrientationKey(event.key, orientation);\n var isNavigationKey = (nested ? isCrossOpenKey : isMainKey) || event.key === 'Enter' || event.key.trim() === '';\n if (virtual && open) {\n var rootNode = tree == null ? void 0 : tree.nodesRef.current.find(function (node) {\n return node.parentId == null;\n });\n var deepestNode = tree && rootNode ? getDeepestNode(tree.nodesRef.current, rootNode.id) : null;\n if (isArrowKey && deepestNode && virtualItemRef) {\n var eventObject = new KeyboardEvent('keydown', {\n key: event.key,\n bubbles: true\n });\n if (isCrossOpenKey || isCrossCloseKey) {\n var _deepestNode$context, _deepestNode$context2;\n var isCurrentTarget = ((_deepestNode$context = deepestNode.context) == null ? void 0 : _deepestNode$context.elements.domReference) === event.currentTarget;\n var dispatchItem = isCrossCloseKey && !isCurrentTarget ? (_deepestNode$context2 = deepestNode.context) == null ? void 0 : _deepestNode$context2.elements.domReference : isCrossOpenKey ? listRef.current.find(function (item) {\n return (item == null ? void 0 : item.id) === activeId;\n }) : null;\n if (dispatchItem) {\n stopEvent(event);\n dispatchItem.dispatchEvent(eventObject);\n setVirtualId(undefined);\n }\n }\n if (isMainKey && deepestNode.context) {\n if (deepestNode.context.open && deepestNode.parentId && event.currentTarget !== deepestNode.context.elements.domReference) {\n var _deepestNode$context$;\n stopEvent(event);\n (_deepestNode$context$ = deepestNode.context.elements.domReference) == null || _deepestNode$context$.dispatchEvent(eventObject);\n return;\n }\n }\n }\n return commonOnKeyDown(event);\n }\n\n // If a floating element should not open on arrow key down, avoid\n // setting `activeIndex` while it's closed.\n if (!open && !openOnArrowKeyDown && isArrowKey) {\n return;\n }\n if (isNavigationKey) {\n keyRef.current = nested && isMainKey ? null : event.key;\n }\n if (nested) {\n if (isCrossOpenKey) {\n stopEvent(event);\n if (open) {\n indexRef.current = getMinIndex(listRef, disabledIndicesRef.current);\n onNavigate(indexRef.current);\n } else {\n onOpenChange(true, event.nativeEvent, 'list-navigation');\n }\n }\n return;\n }\n if (isMainKey) {\n if (selectedIndex != null) {\n indexRef.current = selectedIndex;\n }\n stopEvent(event);\n if (!open && openOnArrowKeyDown) {\n onOpenChange(true, event.nativeEvent, 'list-navigation');\n } else {\n commonOnKeyDown(event);\n }\n if (open) {\n onNavigate(indexRef.current);\n }\n }\n },\n onFocus: function onFocus() {\n if (open && !virtual) {\n onNavigate(null);\n }\n },\n onPointerDown: checkVirtualPointer,\n onMouseDown: checkVirtualMouse,\n onClick: checkVirtualMouse\n });\n }, [activeId, ariaActiveDescendantProp, commonOnKeyDown, disabledIndicesRef, focusItemOnOpen, listRef, nested, onNavigate, onOpenChange, open, openOnArrowKeyDown, orientation, rtl, selectedIndex, tree, virtual, virtualItemRef]);\n return React.useMemo(function () {\n return enabled ? {\n reference: reference,\n floating: floating,\n item: item\n } : {};\n }, [enabled, reference, floating, item]);\n}\nvar componentRoleToAriaRoleMap = /*#__PURE__*/new Map([['select', 'listbox'], ['combobox', 'listbox'], ['label', false]]);\n\n/**\n * Adds base screen reader props to the reference and floating elements for a\n * given floating element `role`.\n * @see https://floating-ui.com/docs/useRole\n */\nfunction useRole(context, props) {\n var _componentRoleToAriaR;\n if (props === void 0) {\n props = {};\n }\n var open = context.open,\n floatingId = context.floatingId;\n var _props8 = props,\n _props8$enabled = _props8.enabled,\n enabled = _props8$enabled === void 0 ? true : _props8$enabled,\n _props8$role = _props8.role,\n role = _props8$role === void 0 ? 'dialog' : _props8$role;\n var ariaRole = (_componentRoleToAriaR = componentRoleToAriaRoleMap.get(role)) != null ? _componentRoleToAriaR : role;\n var referenceId = useId();\n var parentId = useFloatingParentNodeId();\n var isNested = parentId != null;\n var reference = React.useMemo(function () {\n if (ariaRole === 'tooltip' || role === 'label') {\n return _defineProperty({}, \"aria-\" + (role === 'label' ? 'labelledby' : 'describedby'), open ? floatingId : undefined);\n }\n return _objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSpread({\n 'aria-expanded': open ? 'true' : 'false',\n 'aria-haspopup': ariaRole === 'alertdialog' ? 'dialog' : ariaRole,\n 'aria-controls': open ? floatingId : undefined\n }, ariaRole === 'listbox' && {\n role: 'combobox'\n }), ariaRole === 'menu' && {\n id: referenceId\n }), ariaRole === 'menu' && isNested && {\n role: 'menuitem'\n }), role === 'select' && {\n 'aria-autocomplete': 'none'\n }), role === 'combobox' && {\n 'aria-autocomplete': 'list'\n });\n }, [ariaRole, floatingId, isNested, open, referenceId, role]);\n var floating = React.useMemo(function () {\n var floatingProps = _objectSpread({\n id: floatingId\n }, ariaRole && {\n role: ariaRole\n });\n if (ariaRole === 'tooltip' || role === 'label') {\n return floatingProps;\n }\n return _objectSpread(_objectSpread({}, floatingProps), ariaRole === 'menu' && {\n 'aria-labelledby': referenceId\n });\n }, [ariaRole, floatingId, referenceId, role]);\n var item = React.useCallback(function (_ref) {\n var active = _ref.active,\n selected = _ref.selected;\n var commonProps = _objectSpread({\n role: 'option'\n }, active && {\n id: floatingId + \"-option\"\n });\n\n // For `menu`, we are unable to tell if the item is a `menuitemradio`\n // or `menuitemcheckbox`. For backwards-compatibility reasons, also\n // avoid defaulting to `menuitem` as it may overwrite custom role props.\n switch (role) {\n case 'select':\n return _objectSpread(_objectSpread({}, commonProps), {}, {\n 'aria-selected': active && selected\n });\n case 'combobox':\n {\n return _objectSpread(_objectSpread({}, commonProps), active && {\n 'aria-selected': true\n });\n }\n }\n return {};\n }, [floatingId, role]);\n return React.useMemo(function () {\n return enabled ? {\n reference: reference,\n floating: floating,\n item: item\n } : {};\n }, [enabled, reference, floating, item]);\n}\n\n// Converts a JS style key like `backgroundColor` to a CSS transition-property\n// like `background-color`.\nvar camelCaseToKebabCase = function camelCaseToKebabCase(str) {\n return str.replace(/[A-Z]+(?![a-z])|[A-Z]/g, function ($, ofs) {\n return (ofs ? '-' : '') + $.toLowerCase();\n });\n};\nfunction execWithArgsOrReturn(valueOrFn, args) {\n return typeof valueOrFn === 'function' ? valueOrFn(args) : valueOrFn;\n}\nfunction useDelayUnmount(open, durationMs) {\n var _React$useState33 = React.useState(open),\n _React$useState34 = _slicedToArray(_React$useState33, 2),\n isMounted = _React$useState34[0],\n setIsMounted = _React$useState34[1];\n if (open && !isMounted) {\n setIsMounted(true);\n }\n React.useEffect(function () {\n if (!open && isMounted) {\n var timeout = setTimeout(function () {\n return setIsMounted(false);\n }, durationMs);\n return function () {\n return clearTimeout(timeout);\n };\n }\n }, [open, isMounted, durationMs]);\n return isMounted;\n}\n/**\n * Provides a status string to apply CSS transitions to a floating element,\n * correctly handling placement-aware transitions.\n * @see https://floating-ui.com/docs/useTransition#usetransitionstatus\n */\nfunction useTransitionStatus(context, props) {\n if (props === void 0) {\n props = {};\n }\n var open = context.open,\n floating = context.elements.floating;\n var _props9 = props,\n _props9$duration = _props9.duration,\n duration = _props9$duration === void 0 ? 250 : _props9$duration;\n var isNumberDuration = typeof duration === 'number';\n var closeDuration = (isNumberDuration ? duration : duration.close) || 0;\n var _React$useState35 = React.useState('unmounted'),\n _React$useState36 = _slicedToArray(_React$useState35, 2),\n status = _React$useState36[0],\n setStatus = _React$useState36[1];\n var isMounted = useDelayUnmount(open, closeDuration);\n if (!isMounted && status === 'close') {\n setStatus('unmounted');\n }\n index(function () {\n if (!floating) return;\n if (open) {\n setStatus('initial');\n var frame = requestAnimationFrame(function () {\n setStatus('open');\n });\n return function () {\n cancelAnimationFrame(frame);\n };\n }\n setStatus('close');\n }, [open, floating]);\n return {\n isMounted: isMounted,\n status: status\n };\n}\n/**\n * Provides styles to apply CSS transitions to a floating element, correctly\n * handling placement-aware transitions. Wrapper around `useTransitionStatus`.\n * @see https://floating-ui.com/docs/useTransition#usetransitionstyles\n */\nfunction useTransitionStyles(context, props) {\n if (props === void 0) {\n props = {};\n }\n var _props10 = props,\n _props10$initial = _props10.initial,\n unstable_initial = _props10$initial === void 0 ? {\n opacity: 0\n } : _props10$initial,\n unstable_open = _props10.open,\n unstable_close = _props10.close,\n unstable_common = _props10.common,\n _props10$duration = _props10.duration,\n duration = _props10$duration === void 0 ? 250 : _props10$duration;\n var placement = context.placement;\n var side = placement.split('-')[0];\n var fnArgs = React.useMemo(function () {\n return {\n side: side,\n placement: placement\n };\n }, [side, placement]);\n var isNumberDuration = typeof duration === 'number';\n var openDuration = (isNumberDuration ? duration : duration.open) || 0;\n var closeDuration = (isNumberDuration ? duration : duration.close) || 0;\n var _React$useState37 = React.useState(function () {\n return _objectSpread(_objectSpread({}, execWithArgsOrReturn(unstable_common, fnArgs)), execWithArgsOrReturn(unstable_initial, fnArgs));\n }),\n _React$useState38 = _slicedToArray(_React$useState37, 2),\n styles = _React$useState38[0],\n setStyles = _React$useState38[1];\n var _useTransitionStatus = useTransitionStatus(context, {\n duration: duration\n }),\n isMounted = _useTransitionStatus.isMounted,\n status = _useTransitionStatus.status;\n var initialRef = useLatestRef(unstable_initial);\n var openRef = useLatestRef(unstable_open);\n var closeRef = useLatestRef(unstable_close);\n var commonRef = useLatestRef(unstable_common);\n index(function () {\n var initialStyles = execWithArgsOrReturn(initialRef.current, fnArgs);\n var closeStyles = execWithArgsOrReturn(closeRef.current, fnArgs);\n var commonStyles = execWithArgsOrReturn(commonRef.current, fnArgs);\n var openStyles = execWithArgsOrReturn(openRef.current, fnArgs) || Object.keys(initialStyles).reduce(function (acc, key) {\n acc[key] = '';\n return acc;\n }, {});\n if (status === 'initial') {\n setStyles(function (styles) {\n return _objectSpread(_objectSpread({\n transitionProperty: styles.transitionProperty\n }, commonStyles), initialStyles);\n });\n }\n if (status === 'open') {\n setStyles(_objectSpread(_objectSpread({\n transitionProperty: Object.keys(openStyles).map(camelCaseToKebabCase).join(','),\n transitionDuration: openDuration + \"ms\"\n }, commonStyles), openStyles));\n }\n if (status === 'close') {\n var _styles = closeStyles || initialStyles;\n setStyles(_objectSpread(_objectSpread({\n transitionProperty: Object.keys(_styles).map(camelCaseToKebabCase).join(','),\n transitionDuration: closeDuration + \"ms\"\n }, commonStyles), _styles));\n }\n }, [closeDuration, closeRef, initialRef, openRef, commonRef, openDuration, status, fnArgs]);\n return {\n isMounted: isMounted,\n styles: styles\n };\n}\n\n/**\n * Provides a matching callback that can be used to focus an item as the user\n * types, often used in tandem with `useListNavigation()`.\n * @see https://floating-ui.com/docs/useTypeahead\n */\nfunction useTypeahead(context, props) {\n var _ref;\n var open = context.open,\n dataRef = context.dataRef;\n var listRef = props.listRef,\n activeIndex = props.activeIndex,\n unstable_onMatch = props.onMatch,\n unstable_onTypingChange = props.onTypingChange,\n _props$enabled2 = props.enabled,\n enabled = _props$enabled2 === void 0 ? true : _props$enabled2,\n _props$findMatch = props.findMatch,\n findMatch = _props$findMatch === void 0 ? null : _props$findMatch,\n _props$resetMs = props.resetMs,\n resetMs = _props$resetMs === void 0 ? 750 : _props$resetMs,\n _props$ignoreKeys = props.ignoreKeys,\n ignoreKeys = _props$ignoreKeys === void 0 ? [] : _props$ignoreKeys,\n _props$selectedIndex2 = props.selectedIndex,\n selectedIndex = _props$selectedIndex2 === void 0 ? null : _props$selectedIndex2;\n var timeoutIdRef = React.useRef();\n var stringRef = React.useRef('');\n var prevIndexRef = React.useRef((_ref = selectedIndex != null ? selectedIndex : activeIndex) != null ? _ref : -1);\n var matchIndexRef = React.useRef(null);\n var onMatch = useEffectEvent(unstable_onMatch);\n var onTypingChange = useEffectEvent(unstable_onTypingChange);\n var findMatchRef = useLatestRef(findMatch);\n var ignoreKeysRef = useLatestRef(ignoreKeys);\n index(function () {\n if (open) {\n clearTimeout(timeoutIdRef.current);\n matchIndexRef.current = null;\n stringRef.current = '';\n }\n }, [open]);\n index(function () {\n // Sync arrow key navigation but not typeahead navigation.\n if (open && stringRef.current === '') {\n var _ref2;\n prevIndexRef.current = (_ref2 = selectedIndex != null ? selectedIndex : activeIndex) != null ? _ref2 : -1;\n }\n }, [open, selectedIndex, activeIndex]);\n var setTypingChange = useEffectEvent(function (value) {\n if (value) {\n if (!dataRef.current.typing) {\n dataRef.current.typing = value;\n onTypingChange(value);\n }\n } else {\n if (dataRef.current.typing) {\n dataRef.current.typing = value;\n onTypingChange(value);\n }\n }\n });\n var onKeyDown = useEffectEvent(function (event) {\n function getMatchingIndex(list, orderedList, string) {\n var str = findMatchRef.current ? findMatchRef.current(orderedList, string) : orderedList.find(function (text) {\n return (text == null ? void 0 : text.toLocaleLowerCase().indexOf(string.toLocaleLowerCase())) === 0;\n });\n return str ? list.indexOf(str) : -1;\n }\n var listContent = listRef.current;\n if (stringRef.current.length > 0 && stringRef.current[0] !== ' ') {\n if (getMatchingIndex(listContent, listContent, stringRef.current) === -1) {\n setTypingChange(false);\n } else if (event.key === ' ') {\n stopEvent(event);\n }\n }\n if (listContent == null || ignoreKeysRef.current.includes(event.key) ||\n // Character key.\n event.key.length !== 1 ||\n // Modifier key.\n event.ctrlKey || event.metaKey || event.altKey) {\n return;\n }\n if (open && event.key !== ' ') {\n stopEvent(event);\n setTypingChange(true);\n }\n\n // Bail out if the list contains a word like \"llama\" or \"aaron\". TODO:\n // allow it in this case, too.\n var allowRapidSuccessionOfFirstLetter = listContent.every(function (text) {\n var _text$, _text$2;\n return text ? ((_text$ = text[0]) == null ? void 0 : _text$.toLocaleLowerCase()) !== ((_text$2 = text[1]) == null ? void 0 : _text$2.toLocaleLowerCase()) : true;\n });\n\n // Allows the user to cycle through items that start with the same letter\n // in rapid succession.\n if (allowRapidSuccessionOfFirstLetter && stringRef.current === event.key) {\n stringRef.current = '';\n prevIndexRef.current = matchIndexRef.current;\n }\n stringRef.current += event.key;\n clearTimeout(timeoutIdRef.current);\n timeoutIdRef.current = setTimeout(function () {\n stringRef.current = '';\n prevIndexRef.current = matchIndexRef.current;\n setTypingChange(false);\n }, resetMs);\n var prevIndex = prevIndexRef.current;\n var index = getMatchingIndex(listContent, [].concat(_toConsumableArray(listContent.slice((prevIndex || 0) + 1)), _toConsumableArray(listContent.slice(0, (prevIndex || 0) + 1))), stringRef.current);\n if (index !== -1) {\n onMatch(index);\n matchIndexRef.current = index;\n } else if (event.key !== ' ') {\n stringRef.current = '';\n setTypingChange(false);\n }\n });\n var reference = React.useMemo(function () {\n return {\n onKeyDown: onKeyDown\n };\n }, [onKeyDown]);\n var floating = React.useMemo(function () {\n return {\n onKeyDown: onKeyDown,\n onKeyUp: function onKeyUp(event) {\n if (event.key === ' ') {\n setTypingChange(false);\n }\n }\n };\n }, [onKeyDown, setTypingChange]);\n return React.useMemo(function () {\n return enabled ? {\n reference: reference,\n floating: floating\n } : {};\n }, [enabled, reference, floating]);\n}\nfunction getArgsWithCustomFloatingHeight(state, height) {\n return _objectSpread(_objectSpread({}, state), {}, {\n rects: _objectSpread(_objectSpread({}, state.rects), {}, {\n floating: _objectSpread(_objectSpread({}, state.rects.floating), {}, {\n height: height\n })\n })\n });\n}\n/**\n * Positions the floating element such that an inner element inside of it is\n * anchored to the reference element.\n * @see https://floating-ui.com/docs/inner\n */\nvar inner = function inner(props) {\n return {\n name: 'inner',\n options: props,\n fn: function fn(state) {\n return _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {\n var _evaluate, listRef, overflowRef, onFallbackChange, _evaluate$offset, innerOffset, _evaluate$index, index, _evaluate$minItemsVis, minItemsVisible, _evaluate$referenceOv, referenceOverflowThreshold, scrollRef, detectOverflowOptions, rects, floating, item, nextArgs, el, overflow, refOverflow, diffY, nextY, maxHeight;\n return _regeneratorRuntime().wrap(function _callee$(_context) {\n while (1) switch (_context.prev = _context.next) {\n case 0:\n _evaluate = evaluate(props, state), listRef = _evaluate.listRef, overflowRef = _evaluate.overflowRef, onFallbackChange = _evaluate.onFallbackChange, _evaluate$offset = _evaluate.offset, innerOffset = _evaluate$offset === void 0 ? 0 : _evaluate$offset, _evaluate$index = _evaluate.index, index = _evaluate$index === void 0 ? 0 : _evaluate$index, _evaluate$minItemsVis = _evaluate.minItemsVisible, minItemsVisible = _evaluate$minItemsVis === void 0 ? 4 : _evaluate$minItemsVis, _evaluate$referenceOv = _evaluate.referenceOverflowThreshold, referenceOverflowThreshold = _evaluate$referenceOv === void 0 ? 0 : _evaluate$referenceOv, scrollRef = _evaluate.scrollRef, detectOverflowOptions = _objectWithoutProperties(_evaluate, _excluded6);\n rects = state.rects, floating = state.elements.floating;\n item = listRef.current[index];\n if (process.env.NODE_ENV !== \"production\") {\n if (!state.placement.startsWith('bottom')) {\n warn('`placement` side must be \"bottom\" when using the `inner`', 'middleware.');\n }\n }\n if (item) {\n _context.next = 6;\n break;\n }\n return _context.abrupt(\"return\", {});\n case 6:\n _context.t0 = _objectSpread;\n _context.t1 = _objectSpread({}, state);\n _context.next = 10;\n return offset(-item.offsetTop - floating.clientTop - rects.reference.height / 2 - item.offsetHeight / 2 - innerOffset).fn(state);\n case 10:\n _context.t2 = _context.sent;\n nextArgs = (0, _context.t0)(_context.t1, _context.t2);\n el = (scrollRef == null ? void 0 : scrollRef.current) || floating;\n _context.next = 15;\n return detectOverflow(getArgsWithCustomFloatingHeight(nextArgs, el.scrollHeight), detectOverflowOptions);\n case 15:\n overflow = _context.sent;\n _context.next = 18;\n return detectOverflow(nextArgs, _objectSpread(_objectSpread({}, detectOverflowOptions), {}, {\n elementContext: 'reference'\n }));\n case 18:\n refOverflow = _context.sent;\n diffY = Math.max(0, overflow.top);\n nextY = nextArgs.y + diffY;\n maxHeight = Math.max(0, el.scrollHeight - diffY - Math.max(0, overflow.bottom));\n el.style.maxHeight = maxHeight + \"px\";\n el.scrollTop = diffY;\n\n // There is not enough space, fallback to standard anchored positioning\n if (onFallbackChange) {\n if (el.offsetHeight < item.offsetHeight * Math.min(minItemsVisible, listRef.current.length - 1) - 1 || refOverflow.top >= -referenceOverflowThreshold || refOverflow.bottom >= -referenceOverflowThreshold) {\n ReactDOM.flushSync(function () {\n return onFallbackChange(true);\n });\n } else {\n ReactDOM.flushSync(function () {\n return onFallbackChange(false);\n });\n }\n }\n if (!overflowRef) {\n _context.next = 29;\n break;\n }\n _context.next = 28;\n return detectOverflow(getArgsWithCustomFloatingHeight(_objectSpread(_objectSpread({}, nextArgs), {}, {\n y: nextY\n }), el.offsetHeight), detectOverflowOptions);\n case 28:\n overflowRef.current = _context.sent;\n case 29:\n return _context.abrupt(\"return\", {\n y: nextY\n });\n case 30:\n case \"end\":\n return _context.stop();\n }\n }, _callee);\n }))();\n }\n };\n};\n/**\n * Changes the `inner` middleware's `offset` upon a `wheel` event to\n * expand the floating element's height, revealing more list items.\n * @see https://floating-ui.com/docs/inner\n */\nfunction useInnerOffset(context, props) {\n var open = context.open,\n elements = context.elements;\n var _props$enabled3 = props.enabled,\n enabled = _props$enabled3 === void 0 ? true : _props$enabled3,\n overflowRef = props.overflowRef,\n scrollRef = props.scrollRef,\n unstable_onChange = props.onChange;\n var onChange = useEffectEvent(unstable_onChange);\n var controlledScrollingRef = React.useRef(false);\n var prevScrollTopRef = React.useRef(null);\n var initialOverflowRef = React.useRef(null);\n React.useEffect(function () {\n if (!enabled) return;\n function onWheel(e) {\n if (e.ctrlKey || !el || overflowRef.current == null) {\n return;\n }\n var dY = e.deltaY;\n var isAtTop = overflowRef.current.top >= -0.5;\n var isAtBottom = overflowRef.current.bottom >= -0.5;\n var remainingScroll = el.scrollHeight - el.clientHeight;\n var sign = dY < 0 ? -1 : 1;\n var method = dY < 0 ? 'max' : 'min';\n if (el.scrollHeight <= el.clientHeight) {\n return;\n }\n if (!isAtTop && dY > 0 || !isAtBottom && dY < 0) {\n e.preventDefault();\n ReactDOM.flushSync(function () {\n onChange(function (d) {\n return d + Math[method](dY, remainingScroll * sign);\n });\n });\n } else if (/firefox/i.test(getUserAgent())) {\n // Needed to propagate scrolling during momentum scrolling phase once\n // it gets limited by the boundary. UX improvement, not critical.\n el.scrollTop += dY;\n }\n }\n var el = (scrollRef == null ? void 0 : scrollRef.current) || elements.floating;\n if (open && el) {\n el.addEventListener('wheel', onWheel);\n\n // Wait for the position to be ready.\n requestAnimationFrame(function () {\n prevScrollTopRef.current = el.scrollTop;\n if (overflowRef.current != null) {\n initialOverflowRef.current = _objectSpread({}, overflowRef.current);\n }\n });\n return function () {\n prevScrollTopRef.current = null;\n initialOverflowRef.current = null;\n el.removeEventListener('wheel', onWheel);\n };\n }\n }, [enabled, open, elements.floating, overflowRef, scrollRef, onChange]);\n var floating = React.useMemo(function () {\n return {\n onKeyDown: function onKeyDown() {\n controlledScrollingRef.current = true;\n },\n onWheel: function onWheel() {\n controlledScrollingRef.current = false;\n },\n onPointerMove: function onPointerMove() {\n controlledScrollingRef.current = false;\n },\n onScroll: function onScroll() {\n var el = (scrollRef == null ? void 0 : scrollRef.current) || elements.floating;\n if (!overflowRef.current || !el || !controlledScrollingRef.current) {\n return;\n }\n if (prevScrollTopRef.current !== null) {\n var scrollDiff = el.scrollTop - prevScrollTopRef.current;\n if (overflowRef.current.bottom < -0.5 && scrollDiff < -1 || overflowRef.current.top < -0.5 && scrollDiff > 1) {\n ReactDOM.flushSync(function () {\n return onChange(function (d) {\n return d + scrollDiff;\n });\n });\n }\n }\n\n // [Firefox] Wait for the height change to have been applied.\n requestAnimationFrame(function () {\n prevScrollTopRef.current = el.scrollTop;\n });\n }\n };\n }, [elements.floating, onChange, overflowRef, scrollRef]);\n return React.useMemo(function () {\n return enabled ? {\n floating: floating\n } : {};\n }, [enabled, floating]);\n}\nfunction isPointInPolygon(point, polygon) {\n var _point = _slicedToArray(point, 2),\n x = _point[0],\n y = _point[1];\n var isInside = false;\n var length = polygon.length;\n for (var i = 0, j = length - 1; i < length; j = i++) {\n var _ref12 = polygon[i] || [0, 0],\n _ref13 = _slicedToArray(_ref12, 2),\n xi = _ref13[0],\n yi = _ref13[1];\n var _ref14 = polygon[j] || [0, 0],\n _ref15 = _slicedToArray(_ref14, 2),\n xj = _ref15[0],\n yj = _ref15[1];\n var intersect = yi >= y !== yj >= y && x <= (xj - xi) * (y - yi) / (yj - yi) + xi;\n if (intersect) {\n isInside = !isInside;\n }\n }\n return isInside;\n}\nfunction isInside(point, rect) {\n return point[0] >= rect.x && point[0] <= rect.x + rect.width && point[1] >= rect.y && point[1] <= rect.y + rect.height;\n}\n/**\n * Generates a safe polygon area that the user can traverse without closing the\n * floating element once leaving the reference element.\n * @see https://floating-ui.com/docs/useHover#safepolygon\n */\nfunction safePolygon(options) {\n if (options === void 0) {\n options = {};\n }\n var _options4 = options,\n _options4$buffer = _options4.buffer,\n buffer = _options4$buffer === void 0 ? 0.5 : _options4$buffer,\n _options4$blockPointe = _options4.blockPointerEvents,\n blockPointerEvents = _options4$blockPointe === void 0 ? false : _options4$blockPointe,\n _options4$requireInte = _options4.requireIntent,\n requireIntent = _options4$requireInte === void 0 ? true : _options4$requireInte;\n var timeoutId;\n var hasLanded = false;\n var lastX = null;\n var lastY = null;\n var lastCursorTime = performance.now();\n function getCursorSpeed(x, y) {\n var currentTime = performance.now();\n var elapsedTime = currentTime - lastCursorTime;\n if (lastX === null || lastY === null || elapsedTime === 0) {\n lastX = x;\n lastY = y;\n lastCursorTime = currentTime;\n return null;\n }\n var deltaX = x - lastX;\n var deltaY = y - lastY;\n var distance = Math.sqrt(deltaX * deltaX + deltaY * deltaY);\n var speed = distance / elapsedTime; // px / ms\n\n lastX = x;\n lastY = y;\n lastCursorTime = currentTime;\n return speed;\n }\n var fn = function fn(_ref) {\n var x = _ref.x,\n y = _ref.y,\n placement = _ref.placement,\n elements = _ref.elements,\n onClose = _ref.onClose,\n nodeId = _ref.nodeId,\n tree = _ref.tree;\n return function onMouseMove(event) {\n function close() {\n clearTimeout(timeoutId);\n onClose();\n }\n clearTimeout(timeoutId);\n if (!elements.domReference || !elements.floating || placement == null || x == null || y == null) {\n return;\n }\n var clientX = event.clientX,\n clientY = event.clientY;\n var clientPoint = [clientX, clientY];\n var target = getTarget(event);\n var isLeave = event.type === 'mouseleave';\n var isOverFloatingEl = contains(elements.floating, target);\n var isOverReferenceEl = contains(elements.domReference, target);\n var refRect = elements.domReference.getBoundingClientRect();\n var rect = elements.floating.getBoundingClientRect();\n var side = placement.split('-')[0];\n var cursorLeaveFromRight = x > rect.right - rect.width / 2;\n var cursorLeaveFromBottom = y > rect.bottom - rect.height / 2;\n var isOverReferenceRect = isInside(clientPoint, refRect);\n var isFloatingWider = rect.width > refRect.width;\n var isFloatingTaller = rect.height > refRect.height;\n var left = (isFloatingWider ? refRect : rect).left;\n var right = (isFloatingWider ? refRect : rect).right;\n var top = (isFloatingTaller ? refRect : rect).top;\n var bottom = (isFloatingTaller ? refRect : rect).bottom;\n if (isOverFloatingEl) {\n hasLanded = true;\n if (!isLeave) {\n return;\n }\n }\n if (isOverReferenceEl) {\n hasLanded = false;\n }\n if (isOverReferenceEl && !isLeave) {\n hasLanded = true;\n return;\n }\n\n // Prevent overlapping floating element from being stuck in an open-close\n // loop: https://github.com/floating-ui/floating-ui/issues/1910\n if (isLeave && isElement(event.relatedTarget) && contains(elements.floating, event.relatedTarget)) {\n return;\n }\n\n // If any nested child is open, abort.\n if (tree && getChildren(tree.nodesRef.current, nodeId).some(function (_ref2) {\n var context = _ref2.context;\n return context == null ? void 0 : context.open;\n })) {\n return;\n }\n\n // If the pointer is leaving from the opposite side, the \"buffer\" logic\n // creates a point where the floating element remains open, but should be\n // ignored.\n // A constant of 1 handles floating point rounding errors.\n if (side === 'top' && y >= refRect.bottom - 1 || side === 'bottom' && y <= refRect.top + 1 || side === 'left' && x >= refRect.right - 1 || side === 'right' && x <= refRect.left + 1) {\n return close();\n }\n\n // Ignore when the cursor is within the rectangular trough between the\n // two elements. Since the triangle is created from the cursor point,\n // which can start beyond the ref element's edge, traversing back and\n // forth from the ref to the floating element can cause it to close. This\n // ensures it always remains open in that case.\n var rectPoly = [];\n switch (side) {\n case 'top':\n rectPoly = [[left, refRect.top + 1], [left, rect.bottom - 1], [right, rect.bottom - 1], [right, refRect.top + 1]];\n break;\n case 'bottom':\n rectPoly = [[left, rect.top + 1], [left, refRect.bottom - 1], [right, refRect.bottom - 1], [right, rect.top + 1]];\n break;\n case 'left':\n rectPoly = [[rect.right - 1, bottom], [rect.right - 1, top], [refRect.left + 1, top], [refRect.left + 1, bottom]];\n break;\n case 'right':\n rectPoly = [[refRect.right - 1, bottom], [refRect.right - 1, top], [rect.left + 1, top], [rect.left + 1, bottom]];\n break;\n }\n function getPolygon(_ref3) {\n var _ref16 = _slicedToArray(_ref3, 2),\n x = _ref16[0],\n y = _ref16[1];\n switch (side) {\n case 'top':\n {\n var cursorPointOne = [isFloatingWider ? x + buffer / 2 : cursorLeaveFromRight ? x + buffer * 4 : x - buffer * 4, y + buffer + 1];\n var cursorPointTwo = [isFloatingWider ? x - buffer / 2 : cursorLeaveFromRight ? x + buffer * 4 : x - buffer * 4, y + buffer + 1];\n var commonPoints = [[rect.left, cursorLeaveFromRight ? rect.bottom - buffer : isFloatingWider ? rect.bottom - buffer : rect.top], [rect.right, cursorLeaveFromRight ? isFloatingWider ? rect.bottom - buffer : rect.top : rect.bottom - buffer]];\n return [cursorPointOne, cursorPointTwo].concat(commonPoints);\n }\n case 'bottom':\n {\n var _cursorPointOne = [isFloatingWider ? x + buffer / 2 : cursorLeaveFromRight ? x + buffer * 4 : x - buffer * 4, y - buffer];\n var _cursorPointTwo = [isFloatingWider ? x - buffer / 2 : cursorLeaveFromRight ? x + buffer * 4 : x - buffer * 4, y - buffer];\n var _commonPoints = [[rect.left, cursorLeaveFromRight ? rect.top + buffer : isFloatingWider ? rect.top + buffer : rect.bottom], [rect.right, cursorLeaveFromRight ? isFloatingWider ? rect.top + buffer : rect.bottom : rect.top + buffer]];\n return [_cursorPointOne, _cursorPointTwo].concat(_commonPoints);\n }\n case 'left':\n {\n var _cursorPointOne2 = [x + buffer + 1, isFloatingTaller ? y + buffer / 2 : cursorLeaveFromBottom ? y + buffer * 4 : y - buffer * 4];\n var _cursorPointTwo2 = [x + buffer + 1, isFloatingTaller ? y - buffer / 2 : cursorLeaveFromBottom ? y + buffer * 4 : y - buffer * 4];\n var _commonPoints2 = [[cursorLeaveFromBottom ? rect.right - buffer : isFloatingTaller ? rect.right - buffer : rect.left, rect.top], [cursorLeaveFromBottom ? isFloatingTaller ? rect.right - buffer : rect.left : rect.right - buffer, rect.bottom]];\n return [].concat(_commonPoints2, [_cursorPointOne2, _cursorPointTwo2]);\n }\n case 'right':\n {\n var _cursorPointOne3 = [x - buffer, isFloatingTaller ? y + buffer / 2 : cursorLeaveFromBottom ? y + buffer * 4 : y - buffer * 4];\n var _cursorPointTwo3 = [x - buffer, isFloatingTaller ? y - buffer / 2 : cursorLeaveFromBottom ? y + buffer * 4 : y - buffer * 4];\n var _commonPoints3 = [[cursorLeaveFromBottom ? rect.left + buffer : isFloatingTaller ? rect.left + buffer : rect.right, rect.top], [cursorLeaveFromBottom ? isFloatingTaller ? rect.left + buffer : rect.right : rect.left + buffer, rect.bottom]];\n return [_cursorPointOne3, _cursorPointTwo3].concat(_commonPoints3);\n }\n }\n }\n if (isPointInPolygon([clientX, clientY], rectPoly)) {\n return;\n }\n if (hasLanded && !isOverReferenceRect) {\n return close();\n }\n if (!isLeave && requireIntent) {\n var cursorSpeed = getCursorSpeed(event.clientX, event.clientY);\n var cursorSpeedThreshold = 0.1;\n if (cursorSpeed !== null && cursorSpeed < cursorSpeedThreshold) {\n return close();\n }\n }\n if (!isPointInPolygon([clientX, clientY], getPolygon([x, y]))) {\n close();\n } else if (!hasLanded && requireIntent) {\n timeoutId = window.setTimeout(close, 40);\n }\n };\n };\n fn.__options = {\n blockPointerEvents: blockPointerEvents\n };\n return fn;\n}\nexport { Composite, CompositeItem, FloatingArrow, FloatingDelayGroup, FloatingFocusManager, FloatingList, FloatingNode, FloatingOverlay, FloatingPortal, FloatingTree, inner, safePolygon, useClick, useClientPoint, useDelayGroup, useDelayGroupContext, useDismiss, useFloating, useFloatingNodeId, useFloatingParentNodeId, useFloatingPortalNode, useFloatingRootContext, useFloatingTree, useFocus, useHover, useId, useInnerOffset, useInteractions, useListItem, useListNavigation, useMergeRefs, useRole, useTransitionStatus, useTransitionStyles, useTypeahead };","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { autoUpdate as Z, flip as ee, inner as te, offset as ne, shift as le, size as re, useFloating as oe, useInnerOffset as ie, useInteractions as se } from \"@floating-ui/react\";\nimport * as j from \"react\";\nimport { createContext as _, useCallback as ae, useContext as R, useMemo as v, useRef as ue, useState as E } from \"react\";\nimport { useDisposables as fe } from '../hooks/use-disposables.js';\nimport { useEvent as z } from '../hooks/use-event.js';\nimport { useIsoMorphicEffect as A } from '../hooks/use-iso-morphic-effect.js';\nvar y = /*#__PURE__*/_({\n styles: void 0,\n setReference: function setReference() {},\n setFloating: function setFloating() {},\n getReferenceProps: function getReferenceProps() {\n return {};\n },\n getFloatingProps: function getFloatingProps() {\n return {};\n },\n slot: {}\n});\ny.displayName = \"FloatingContext\";\nvar S = /*#__PURE__*/_(null);\nS.displayName = \"PlacementContext\";\nfunction xe(e) {\n return v(function () {\n return e ? typeof e == \"string\" ? {\n to: e\n } : e : null;\n }, [e]);\n}\nfunction ye() {\n return R(y).setReference;\n}\nfunction Fe() {\n return R(y).getReferenceProps;\n}\nfunction be() {\n var _R = R(y),\n e = _R.getFloatingProps,\n t = _R.slot;\n return ae(function () {\n return Object.assign({}, e.apply(void 0, arguments), {\n \"data-anchor\": t.anchor\n });\n }, [e, t]);\n}\nfunction Re() {\n var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;\n e === !1 && (e = null), typeof e == \"string\" && (e = {\n to: e\n });\n var t = R(S),\n n = v(function () {\n return e;\n }, [JSON.stringify(e, typeof HTMLElement != \"undefined\" ? function (r, o) {\n return o instanceof HTMLElement ? o.outerHTML : o;\n } : void 0)]);\n A(function () {\n t == null || t(n != null ? n : null);\n }, [t, n]);\n var l = R(y);\n return v(function () {\n return [l.setFloating, e ? l.styles : {}];\n }, [l.setFloating, e, l.styles]);\n}\nvar q = 4;\nfunction ve(_ref) {\n var e = _ref.children,\n _ref$enabled = _ref.enabled,\n t = _ref$enabled === void 0 ? !0 : _ref$enabled;\n var _E = E(null),\n _E2 = _slicedToArray(_E, 2),\n n = _E2[0],\n l = _E2[1],\n _E3 = E(0),\n _E4 = _slicedToArray(_E3, 2),\n r = _E4[0],\n o = _E4[1],\n c = ue(null),\n _E5 = E(null),\n _E6 = _slicedToArray(_E5, 2),\n u = _E6[0],\n s = _E6[1];\n pe(u);\n var i = t && n !== null && u !== null,\n _ce = ce(n, u),\n _ce$to = _ce.to,\n F = _ce$to === void 0 ? \"bottom\" : _ce$to,\n _ce$gap = _ce.gap,\n C = _ce$gap === void 0 ? 0 : _ce$gap,\n _ce$offset = _ce.offset,\n M = _ce$offset === void 0 ? 0 : _ce$offset,\n _ce$padding = _ce.padding,\n p = _ce$padding === void 0 ? 0 : _ce$padding,\n P = _ce.inner,\n _F$split = F.split(\" \"),\n _F$split2 = _slicedToArray(_F$split, 2),\n a = _F$split2[0],\n _F$split2$ = _F$split2[1],\n f = _F$split2$ === void 0 ? \"center\" : _F$split2$;\n A(function () {\n i && o(0);\n }, [i]);\n var _oe = oe({\n open: i,\n placement: a === \"selection\" ? f === \"center\" ? \"bottom\" : \"bottom-\".concat(f) : f === \"center\" ? \"\".concat(a) : \"\".concat(a, \"-\").concat(f),\n strategy: \"absolute\",\n transform: !1,\n middleware: [ne({\n mainAxis: a === \"selection\" ? 0 : C,\n crossAxis: M\n }), le({\n padding: p\n }), a !== \"selection\" && ee({\n padding: p\n }), a === \"selection\" && P ? te(_objectSpread(_objectSpread({}, P), {}, {\n padding: p,\n overflowRef: c,\n offset: r,\n minItemsVisible: q,\n referenceOverflowThreshold: p,\n onFallbackChange: function onFallbackChange(h) {\n var O, W;\n if (!h) return;\n var d = g.elements.floating;\n if (!d) return;\n var T = parseFloat(getComputedStyle(d).scrollPaddingBottom) || 0,\n $ = Math.min(q, d.childElementCount),\n B = 0,\n N = 0;\n var _iterator = _createForOfIteratorHelper((W = (O = g.elements.floating) == null ? void 0 : O.childNodes) != null ? W : []),\n _step;\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var m = _step.value;\n if (m instanceof HTMLElement) {\n var x = m.offsetTop,\n k = x + m.clientHeight + T,\n H = d.scrollTop,\n U = H + d.clientHeight;\n if (x >= H && k <= U) $--;else {\n N = Math.max(0, Math.min(k, U) - Math.max(x, H)), B = m.clientHeight;\n break;\n }\n }\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n $ >= 1 && o(function (m) {\n var x = B * $ - N + T;\n return m >= x ? m : x;\n });\n }\n })) : null, re({\n padding: p,\n apply: function apply(_ref2) {\n var h = _ref2.availableWidth,\n d = _ref2.availableHeight,\n T = _ref2.elements;\n Object.assign(T.floating.style, {\n overflow: \"auto\",\n maxWidth: \"\".concat(h, \"px\"),\n maxHeight: \"min(var(--anchor-max-height, 100vh), \".concat(d, \"px)\")\n });\n }\n })].filter(Boolean),\n whileElementsMounted: Z\n }),\n b = _oe.refs,\n w = _oe.floatingStyles,\n g = _oe.context,\n _g$placement$split = g.placement.split(\"-\"),\n _g$placement$split2 = _slicedToArray(_g$placement$split, 2),\n _g$placement$split2$ = _g$placement$split2[0],\n I = _g$placement$split2$ === void 0 ? a : _g$placement$split2$,\n _g$placement$split2$2 = _g$placement$split2[1],\n V = _g$placement$split2$2 === void 0 ? f : _g$placement$split2$2;\n a === \"selection\" && (I = \"selection\");\n var G = v(function () {\n return {\n anchor: [I, V].filter(Boolean).join(\" \")\n };\n }, [I, V]),\n K = ie(g, {\n overflowRef: c,\n onChange: o\n }),\n _se = se([K]),\n Q = _se.getReferenceProps,\n X = _se.getFloatingProps,\n Y = z(function (h) {\n s(h), b.setFloating(h);\n });\n return /*#__PURE__*/j.createElement(S.Provider, {\n value: l\n }, /*#__PURE__*/j.createElement(y.Provider, {\n value: {\n setFloating: Y,\n setReference: b.setReference,\n styles: w,\n getReferenceProps: Q,\n getFloatingProps: X,\n slot: G\n }\n }, e));\n}\nfunction pe(e) {\n A(function () {\n if (!e) return;\n var t = new MutationObserver(function () {\n var n = window.getComputedStyle(e).maxHeight,\n l = parseFloat(n);\n if (isNaN(l)) return;\n var r = parseInt(n);\n isNaN(r) || l !== r && (e.style.maxHeight = \"\".concat(Math.ceil(l), \"px\"));\n });\n return t.observe(e, {\n attributes: !0,\n attributeFilter: [\"style\"]\n }), function () {\n t.disconnect();\n };\n }, [e]);\n}\nfunction ce(e, t) {\n var o, c, u;\n var n = L((o = e == null ? void 0 : e.gap) != null ? o : \"var(--anchor-gap, 0)\", t),\n l = L((c = e == null ? void 0 : e.offset) != null ? c : \"var(--anchor-offset, 0)\", t),\n r = L((u = e == null ? void 0 : e.padding) != null ? u : \"var(--anchor-padding, 0)\", t);\n return _objectSpread(_objectSpread({}, e), {}, {\n gap: n,\n offset: l,\n padding: r\n });\n}\nfunction L(e, t) {\n var n = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : void 0;\n var l = fe(),\n r = z(function (s, i) {\n if (s == null) return [n, null];\n if (typeof s == \"number\") return [s, null];\n if (typeof s == \"string\") {\n if (!i) return [n, null];\n var F = J(s, i);\n return [F, function (C) {\n var M = D(s);\n {\n var p = M.map(function (P) {\n return window.getComputedStyle(i).getPropertyValue(P);\n });\n l.requestAnimationFrame(function P() {\n l.nextFrame(P);\n var a = !1;\n var _iterator2 = _createForOfIteratorHelper(M.entries()),\n _step2;\n try {\n for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {\n var _ref3 = _step2.value;\n var _ref4 = _slicedToArray(_ref3, 2);\n var b = _ref4[0];\n var w = _ref4[1];\n var g = window.getComputedStyle(i).getPropertyValue(w);\n if (p[b] !== g) {\n p[b] = g, a = !0;\n break;\n }\n }\n } catch (err) {\n _iterator2.e(err);\n } finally {\n _iterator2.f();\n }\n if (!a) return;\n var f = J(s, i);\n F !== f && (C(f), F = f);\n });\n }\n return l.dispose;\n }];\n }\n return [n, null];\n }),\n o = v(function () {\n return r(e, t)[0];\n }, [e, t]),\n _E7 = E(),\n _E8 = _slicedToArray(_E7, 2),\n _E8$ = _E8[0],\n c = _E8$ === void 0 ? o : _E8$,\n u = _E8[1];\n return A(function () {\n var _r2 = r(e, t),\n _r3 = _slicedToArray(_r2, 2),\n s = _r3[0],\n i = _r3[1];\n if (u(s), !!i) return i(u);\n }, [e, t]), c;\n}\nfunction D(e) {\n var t = /var\\((.*)\\)/.exec(e);\n if (t) {\n var n = t[1].indexOf(\",\");\n if (n === -1) return [t[1]];\n var l = t[1].slice(0, n).trim(),\n r = t[1].slice(n + 1).trim();\n return r ? [l].concat(_toConsumableArray(D(r))) : [l];\n }\n return [];\n}\nfunction J(e, t) {\n var n = document.createElement(\"div\");\n t.appendChild(n), n.style.setProperty(\"margin-top\", \"0px\", \"important\"), n.style.setProperty(\"margin-top\", e, \"important\");\n var l = parseFloat(window.getComputedStyle(n).marginTop) || 0;\n return t.removeChild(n), l;\n}\nexport { ve as FloatingProvider, Re as useFloatingPanel, be as useFloatingPanelProps, ye as useFloatingReference, Fe as useFloatingReferenceProps, xe as useResolvedAnchor };","'use strict';\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nvar $Object = Object;\n\n// `ToObject` abstract operation\n// https://tc39.es/ecma262/#sec-toobject\nmodule.exports = function (argument) {\n return $Object(requireObjectCoercible(argument));\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar fails = require('../internals/fails');\nvar isArray = require('../internals/is-array');\nvar isObject = require('../internals/is-object');\nvar toObject = require('../internals/to-object');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar doesNotExceedSafeInteger = require('../internals/does-not-exceed-safe-integer');\nvar createProperty = require('../internals/create-property');\nvar arraySpeciesCreate = require('../internals/array-species-create');\nvar arrayMethodHasSpeciesSupport = require('../internals/array-method-has-species-support');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar V8_VERSION = require('../internals/engine-v8-version');\n\nvar IS_CONCAT_SPREADABLE = wellKnownSymbol('isConcatSpreadable');\n\n// We can't use this feature detection in V8 since it causes\n// deoptimization and serious performance degradation\n// https://github.com/zloirock/core-js/issues/679\nvar IS_CONCAT_SPREADABLE_SUPPORT = V8_VERSION >= 51 || !fails(function () {\n var array = [];\n array[IS_CONCAT_SPREADABLE] = false;\n return array.concat()[0] !== array;\n});\n\nvar isConcatSpreadable = function (O) {\n if (!isObject(O)) return false;\n var spreadable = O[IS_CONCAT_SPREADABLE];\n return spreadable !== undefined ? !!spreadable : isArray(O);\n};\n\nvar FORCED = !IS_CONCAT_SPREADABLE_SUPPORT || !arrayMethodHasSpeciesSupport('concat');\n\n// `Array.prototype.concat` method\n// https://tc39.es/ecma262/#sec-array.prototype.concat\n// with adding support of @@isConcatSpreadable and @@species\n$({ target: 'Array', proto: true, arity: 1, forced: FORCED }, {\n // eslint-disable-next-line no-unused-vars -- required for `.length`\n concat: function concat(arg) {\n var O = toObject(this);\n var A = arraySpeciesCreate(O, 0);\n var n = 0;\n var i, k, length, len, E;\n for (i = -1, length = arguments.length; i < length; i++) {\n E = i === -1 ? O : arguments[i];\n if (isConcatSpreadable(E)) {\n len = lengthOfArrayLike(E);\n doesNotExceedSafeInteger(n + len);\n for (k = 0; k < len; k++, n++) if (k in E) createProperty(A, n, E[k]);\n } else {\n doesNotExceedSafeInteger(n + 1);\n createProperty(A, n++, E);\n }\n }\n A.length = n;\n return A;\n }\n});\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar IE8_DOM_DEFINE = require('../internals/ie8-dom-define');\nvar V8_PROTOTYPE_DEFINE_BUG = require('../internals/v8-prototype-define-bug');\nvar anObject = require('../internals/an-object');\nvar toPropertyKey = require('../internals/to-property-key');\n\nvar $TypeError = TypeError;\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar $defineProperty = Object.defineProperty;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar $getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar ENUMERABLE = 'enumerable';\nvar CONFIGURABLE = 'configurable';\nvar WRITABLE = 'writable';\n\n// `Object.defineProperty` method\n// https://tc39.es/ecma262/#sec-object.defineproperty\nexports.f = DESCRIPTORS ? V8_PROTOTYPE_DEFINE_BUG ? function defineProperty(O, P, Attributes) {\n anObject(O);\n P = toPropertyKey(P);\n anObject(Attributes);\n if (typeof O === 'function' && P === 'prototype' && 'value' in Attributes && WRITABLE in Attributes && !Attributes[WRITABLE]) {\n var current = $getOwnPropertyDescriptor(O, P);\n if (current && current[WRITABLE]) {\n O[P] = Attributes.value;\n Attributes = {\n configurable: CONFIGURABLE in Attributes ? Attributes[CONFIGURABLE] : current[CONFIGURABLE],\n enumerable: ENUMERABLE in Attributes ? Attributes[ENUMERABLE] : current[ENUMERABLE],\n writable: false\n };\n }\n } return $defineProperty(O, P, Attributes);\n} : $defineProperty : function defineProperty(O, P, Attributes) {\n anObject(O);\n P = toPropertyKey(P);\n anObject(Attributes);\n if (IE8_DOM_DEFINE) try {\n return $defineProperty(O, P, Attributes);\n } catch (error) { /* empty */ }\n if ('get' in Attributes || 'set' in Attributes) throw new $TypeError('Accessors not supported');\n if ('value' in Attributes) O[P] = Attributes.value;\n return O;\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar IS_PURE = require('../internals/is-pure');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar global = require('../internals/global');\nvar path = require('../internals/path');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar isForced = require('../internals/is-forced');\nvar hasOwn = require('../internals/has-own-property');\nvar inheritIfRequired = require('../internals/inherit-if-required');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar isSymbol = require('../internals/is-symbol');\nvar toPrimitive = require('../internals/to-primitive');\nvar fails = require('../internals/fails');\nvar getOwnPropertyNames = require('../internals/object-get-own-property-names').f;\nvar getOwnPropertyDescriptor = require('../internals/object-get-own-property-descriptor').f;\nvar defineProperty = require('../internals/object-define-property').f;\nvar thisNumberValue = require('../internals/this-number-value');\nvar trim = require('../internals/string-trim').trim;\n\nvar NUMBER = 'Number';\nvar NativeNumber = global[NUMBER];\nvar PureNumberNamespace = path[NUMBER];\nvar NumberPrototype = NativeNumber.prototype;\nvar TypeError = global.TypeError;\nvar stringSlice = uncurryThis(''.slice);\nvar charCodeAt = uncurryThis(''.charCodeAt);\n\n// `ToNumeric` abstract operation\n// https://tc39.es/ecma262/#sec-tonumeric\nvar toNumeric = function (value) {\n var primValue = toPrimitive(value, 'number');\n return typeof primValue == 'bigint' ? primValue : toNumber(primValue);\n};\n\n// `ToNumber` abstract operation\n// https://tc39.es/ecma262/#sec-tonumber\nvar toNumber = function (argument) {\n var it = toPrimitive(argument, 'number');\n var first, third, radix, maxCode, digits, length, index, code;\n if (isSymbol(it)) throw new TypeError('Cannot convert a Symbol value to a number');\n if (typeof it == 'string' && it.length > 2) {\n it = trim(it);\n first = charCodeAt(it, 0);\n if (first === 43 || first === 45) {\n third = charCodeAt(it, 2);\n if (third === 88 || third === 120) return NaN; // Number('+0x1') should be NaN, old V8 fix\n } else if (first === 48) {\n switch (charCodeAt(it, 1)) {\n // fast equal of /^0b[01]+$/i\n case 66:\n case 98:\n radix = 2;\n maxCode = 49;\n break;\n // fast equal of /^0o[0-7]+$/i\n case 79:\n case 111:\n radix = 8;\n maxCode = 55;\n break;\n default:\n return +it;\n }\n digits = stringSlice(it, 2);\n length = digits.length;\n for (index = 0; index < length; index++) {\n code = charCodeAt(digits, index);\n // parseInt parses a string to a first unavailable symbol\n // but ToNumber should return NaN if a string contains unavailable symbols\n if (code < 48 || code > maxCode) return NaN;\n } return parseInt(digits, radix);\n }\n } return +it;\n};\n\nvar FORCED = isForced(NUMBER, !NativeNumber(' 0o1') || !NativeNumber('0b1') || NativeNumber('+0x1'));\n\nvar calledWithNew = function (dummy) {\n // includes check on 1..constructor(foo) case\n return isPrototypeOf(NumberPrototype, dummy) && fails(function () { thisNumberValue(dummy); });\n};\n\n// `Number` constructor\n// https://tc39.es/ecma262/#sec-number-constructor\nvar NumberWrapper = function Number(value) {\n var n = arguments.length < 1 ? 0 : NativeNumber(toNumeric(value));\n return calledWithNew(this) ? inheritIfRequired(Object(n), this, NumberWrapper) : n;\n};\n\nNumberWrapper.prototype = NumberPrototype;\nif (FORCED && !IS_PURE) NumberPrototype.constructor = NumberWrapper;\n\n$({ global: true, constructor: true, wrap: true, forced: FORCED }, {\n Number: NumberWrapper\n});\n\n// Use `internal/copy-constructor-properties` helper in `core-js@4`\nvar copyConstructorProperties = function (target, source) {\n for (var keys = DESCRIPTORS ? getOwnPropertyNames(source) : (\n // ES3:\n 'MAX_VALUE,MIN_VALUE,NaN,NEGATIVE_INFINITY,POSITIVE_INFINITY,' +\n // ES2015 (in case, if modules with ES2015 Number statics required before):\n 'EPSILON,MAX_SAFE_INTEGER,MIN_SAFE_INTEGER,isFinite,isInteger,isNaN,isSafeInteger,parseFloat,parseInt,' +\n // ESNext\n 'fromString,range'\n ).split(','), j = 0, key; keys.length > j; j++) {\n if (hasOwn(source, key = keys[j]) && !hasOwn(target, key)) {\n defineProperty(target, key, getOwnPropertyDescriptor(source, key));\n }\n }\n};\n\nif (IS_PURE && PureNumberNamespace) copyConstructorProperties(path[NUMBER], PureNumberNamespace);\nif (FORCED || IS_PURE) copyConstructorProperties(path[NUMBER], NativeNumber);\n","import React, { useState } from \"react\";\nimport { useForm } from \"./StateManagement\";\nimport { generateId } from \"../../utils/genIds\";\n\nexport const CustomFormFields = () => {\n const { state } = useForm();\n const CompMap = {\n text: CustomInput,\n checkbox: Checkbox,\n \"drop down\": CustomDropDown,\n };\n\n return (\n
\n {state.fundFormFields.map((ff, i) => {\n const C = CompMap[ff.input_type] || CustomInput;\n return ;\n })}\n
\n );\n};\n\nexport const CustomDropDown = ({ formField }) => {\n const { state, updateFormValue } = useForm();\n const { formSelectOptions } = state;\n\n const options = formSelectOptions.filter(\n (o) => o.form_field_id === formField.id\n );\n\n const handleSelectChange = (e) => {\n e.preventDefault();\n\n updateFormValue(formField, e.target.value);\n };\n\n return (\n
\n \n \n
\n );\n};\n\nexport const Checkbox = ({ formField }) => {\n const { updateFormValue } = useForm();\n const handleChange = (e) => {\n updateFormValue(formField, !formField.value);\n };\n\n return (\n <>\n
\n
\n
\n \n
\n
\n >\n );\n};\n\nexport const CustomInput = ({ formField }) => {\n const { updateFormValue } = useForm();\n const handleChange = (e) => {\n updateFormValue(formField, e.target.value);\n };\n\n return (\n <>\n
\n
\n
\n \n
\n
\n >\n );\n};\n\nexport const Input = ({\n type,\n label,\n name,\n isRequired,\n selectOptions = null,\n}) => {\n const { updateUserAttribute, state } = useForm();\n const { user, errors } = state;\n\n const handleChange = (e) => {\n updateUserAttribute(name, e.target.value);\n };\n const myerrors = errors[name] || [];\n\n const renderDropdown = () => {\n return (\n
\n );\n };\n\n return (\n <>\n
\n
\n
\n {type === \"dropdown\" ? (\n renderDropdown()\n ) : (\n
\n )}\n\n {myerrors.length > 0 ? (\n
\n ) : (\n \"\"\n )}\n
\n {myerrors.map((e, i) => {\n return (\n
\n {e}\n
\n );\n })}\n
\n >\n );\n};\n\nexport const SubmitBtn = () => {\n const { state, stripe } = useForm();\n const { amount, fund, loading } = state;\n\n const btnLoading = !stripe || loading;\n const buttonStyles =\n btnLoading || amount < 1 || isNaN(amount)\n ? \"w-full text-center text-xl px-3 py-4 mx-auto border border-transparent text-md leading-4 font-body font-medium rounded-md text-gray-800 bg-yellow-200 focus:outline-none transition ease-in-out \"\n : \"w-full text-center text-xl px-3 py-4 mx-auto border border-transparent text-md leading-4 font-body font-medium rounded-md text-gray-800 bg-yellow-600 hover:bg-yellow-800 focus:outline-none focus:border-indigo-700 focus:ring-indigo active:bg-indigo-700 transition ease-in-out duration-150\";\n\n const buttonText = fund.form_submit_text;\n\n return (\n
\n );\n};\n\nexport const AmountInput = () => {\n const { state, updateAmount } = useForm();\n const { fund, errors, amount, currentDueLevel } = state;\n\n const amountErrors = errors[\"amount\"] || [];\n\n const onChange = (e) => {\n updateAmount(e.target.value);\n };\n\n const preventScroll = (event) => {\n event.target.blur();\n event.stopPropagation();\n setTimeout(() => {\n event.target.focus();\n }, 0);\n };\n\n const label =\n fund.fund_type === \"misc_dues\" || currentDueLevel?.id === \"custom_amount\"\n ? \"Amount *\"\n : `Donation Amount (${fund.amount_currency})*`;\n\n return (\n <>\n
\n
\n
\n
\n $\n
\n
\n
\n {fund.amount_currency}\n
\n
\n {amountErrors.map((e, i) => {\n return (\n
\n {e}\n
\n );\n })}\n
\n >\n );\n};\n\nexport const DuesAmountInput = () => {\n const { updateDueLevel, setCustomDueLevel, state } = useForm();\n const { currentDueLevel, fund, dueLevels, autoPay, subscription_future_start } = state;\n\n const handleChange = (e) => {\n const { value } = e.target;\n\n value === \"custom_amount\"\n ? setCustomDueLevel(value)\n : updateDueLevel(value);\n };\n\n return (\n <>\n
\n
\n
\n \n
\n
\n {currentDueLevel.recurring && subscription_future_start &&
}\n
\n >\n );\n};\n\n// add a component where we can add a start date for recurring payments\nconst AutoPayScheduleInput = () => {\n const { state, dispatch } = useForm();\n const { currentDueLevel, autoPay, subscription_future_start, future_start_date, future_start_date_enabled } = state;\n // const [futureStart, setFutureStart] = useState(true);\n const setFutureStartDate = (value) => {\n dispatch({ type: \"UPDATE_FUTURE_START_DATE\", date: value })\n }\n const toggleFutureStartEnabled = () => {\n dispatch({ type: \"TOGGLE_FUTURE_START_DATE_ENABLED\" })\n }\n\n const id = generateId();\n\n // gets today and formats it to 2024-01-01 for the date field min attribute\n const minDate = new Date().toISOString().split('T')[0];\n // gets today and adds 60 days to it and formats it to 2024-01-01 for the date field max attribute\n const maxDate = new Date(new Date().setDate(new Date().getDate() + 60)).toISOString().split('T')[0];\n return <>\n
\n\n \n \n
\n {future_start_date_enabled &&\n
\n \n { setFutureStartDate(e.target.value) }}\n value={future_start_date}\n min={minDate}\n max={maxDate}\n className=\"block w-full transition duration-150 ease-in-out form-input sm:text-sm sm:leading-5\" type=\"date\" name=\"startdate\" />\n
\n }\n >\n}\n\n\nconst AutoPayInput = () => {\n const { updateAutoPay, state } = useForm();\n const { currentDueLevel, autoPay, force_autopay } = state;\n const id = generateId();\n const handleChange = () => {\n updateAutoPay(!autoPay);\n };\n\n const [show, setShow] = useState(false);\n\n const englishInterval = {\n \"weekly\": \"week\",\n \"bi-weekly\": \"two weeks\",\n \"monthly\": \"month\",\n \"quarterly\": \"quarter\",\n \"yearly\": \"year\",\n };\n\n return (\n <>\n {currentDueLevel.recurring && (\n !!force_autopay ? (\n
\n By completing this transaction, you acknowledge and understand this is a {currentDueLevel.interval} recurring payment.\n This means you'll be charged automatically every {englishInterval[currentDueLevel.interval]}, starting from the future date you specify below.\n
\n ) :\n <>\n
\n\n {!!autoPay && (\n
\n The plan you selected will charge your card on a{\" \"}\n {currentDueLevel.interval} schedule.\n
\n )}\n\n {show && (\n
\n )}\n >\n )}\n >\n );\n};\n\nexport const BaseErrors = () => {\n const {\n state: { errors },\n } = useForm();\n\n const baseErrors = errors[\"base\"] || [];\n\n return (\n <>\n {baseErrors.map((e, i) => {\n return (\n
\n );\n })}\n >\n );\n};\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\nvar defineSymbolToPrimitive = require('../internals/symbol-define-to-primitive');\n\n// `Symbol.toPrimitive` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.toprimitive\ndefineWellKnownSymbol('toPrimitive');\n\n// `Symbol.prototype[@@toPrimitive]` method\n// https://tc39.es/ecma262/#sec-symbol.prototype-@@toprimitive\ndefineSymbolToPrimitive();\n","'use strict';\nvar hasOwn = require('../internals/has-own-property');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar dateToPrimitive = require('../internals/date-to-primitive');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_PRIMITIVE = wellKnownSymbol('toPrimitive');\nvar DatePrototype = Date.prototype;\n\n// `Date.prototype[@@toPrimitive]` method\n// https://tc39.es/ecma262/#sec-date.prototype-@@toprimitive\nif (!hasOwn(DatePrototype, TO_PRIMITIVE)) {\n defineBuiltIn(DatePrototype, TO_PRIMITIVE, dateToPrimitive);\n}\n","'use strict';\nvar toLength = require('../internals/to-length');\n\n// `LengthOfArrayLike` abstract operation\n// https://tc39.es/ecma262/#sec-lengthofarraylike\nmodule.exports = function (obj) {\n return toLength(obj.length);\n};\n","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport { microTask as i } from './micro-task.js';\nfunction o() {\n var n = [],\n r = {\n addEventListener: function addEventListener(e, t, s, a) {\n return e.addEventListener(t, s, a), r.add(function () {\n return e.removeEventListener(t, s, a);\n });\n },\n requestAnimationFrame: function (_requestAnimationFrame) {\n function requestAnimationFrame() {\n return _requestAnimationFrame.apply(this, arguments);\n }\n requestAnimationFrame.toString = function () {\n return _requestAnimationFrame.toString();\n };\n return requestAnimationFrame;\n }(function () {\n var t = requestAnimationFrame.apply(void 0, arguments);\n return r.add(function () {\n return cancelAnimationFrame(t);\n });\n }),\n nextFrame: function nextFrame() {\n for (var _len = arguments.length, e = new Array(_len), _key = 0; _key < _len; _key++) {\n e[_key] = arguments[_key];\n }\n return r.requestAnimationFrame(function () {\n return r.requestAnimationFrame.apply(r, e);\n });\n },\n setTimeout: function (_setTimeout) {\n function setTimeout() {\n return _setTimeout.apply(this, arguments);\n }\n setTimeout.toString = function () {\n return _setTimeout.toString();\n };\n return setTimeout;\n }(function () {\n var t = setTimeout.apply(void 0, arguments);\n return r.add(function () {\n return clearTimeout(t);\n });\n }),\n microTask: function microTask() {\n for (var _len2 = arguments.length, e = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n e[_key2] = arguments[_key2];\n }\n var t = {\n current: !0\n };\n return i(function () {\n t.current && e[0]();\n }), r.add(function () {\n t.current = !1;\n });\n },\n style: function style(e, t, s) {\n var a = e.style.getPropertyValue(t);\n return Object.assign(e.style, _defineProperty({}, t, s)), this.add(function () {\n Object.assign(e.style, _defineProperty({}, t, a));\n });\n },\n group: function group(e) {\n var t = o();\n return e(t), this.add(function () {\n return t.dispose();\n });\n },\n add: function add(e) {\n return n.includes(e) || n.push(e), function () {\n var t = n.indexOf(e);\n if (t >= 0) {\n var _iterator = _createForOfIteratorHelper(n.splice(t, 1)),\n _step;\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var s = _step.value;\n s();\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n }\n };\n },\n dispose: function dispose() {\n var _iterator2 = _createForOfIteratorHelper(n.splice(0)),\n _step2;\n try {\n for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {\n var e = _step2.value;\n e();\n }\n } catch (err) {\n _iterator2.e(err);\n } finally {\n _iterator2.f();\n }\n }\n };\n return r;\n}\nexport { o as disposables };","\"use client\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nvar _excluded = [\"id\"];\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport m, { createContext as T, useContext as u, useMemo as c, useState as P } from \"react\";\nimport { useEvent as g } from '../../hooks/use-event.js';\nimport { useId as x } from '../../hooks/use-id.js';\nimport { useIsoMorphicEffect as y } from '../../hooks/use-iso-morphic-effect.js';\nimport { useSyncRefs as E } from '../../hooks/use-sync-refs.js';\nimport { useDisabled as v } from '../../internal/disabled.js';\nimport { forwardRefWithAs as R, render as I } from '../../utils/render.js';\nvar a = /*#__PURE__*/T(null);\na.displayName = \"DescriptionContext\";\nfunction f() {\n var r = u(a);\n if (r === null) {\n var e = new Error(\"You used a
component, but it is not inside a relevant parent.\");\n throw Error.captureStackTrace && Error.captureStackTrace(e, f), e;\n }\n return r;\n}\nfunction G() {\n var r, e;\n return (e = (r = u(a)) == null ? void 0 : r.value) != null ? e : void 0;\n}\nfunction U() {\n var _P = P([]),\n _P2 = _slicedToArray(_P, 2),\n r = _P2[0],\n e = _P2[1];\n return [r.length > 0 ? r.join(\" \") : void 0, c(function () {\n return function (t) {\n var i = g(function (n) {\n return e(function (s) {\n return [].concat(_toConsumableArray(s), [n]);\n }), function () {\n return e(function (s) {\n var o = s.slice(),\n p = o.indexOf(n);\n return p !== -1 && o.splice(p, 1), o;\n });\n };\n }),\n l = c(function () {\n return {\n register: i,\n slot: t.slot,\n name: t.name,\n props: t.props,\n value: t.value\n };\n }, [i, t.slot, t.name, t.props, t.value]);\n return /*#__PURE__*/m.createElement(a.Provider, {\n value: l\n }, t.children);\n };\n }, [e])];\n}\nvar S = \"p\";\nfunction C(r, e) {\n var d = x(),\n t = v(),\n _r$id = r.id,\n i = _r$id === void 0 ? \"headlessui-description-\".concat(d) : _r$id,\n l = _objectWithoutProperties(r, _excluded),\n n = f(),\n s = E(e);\n y(function () {\n return n.register(i);\n }, [i, n.register]);\n var o = t || !1,\n p = c(function () {\n return _objectSpread(_objectSpread({}, n.slot), {}, {\n disabled: o\n });\n }, [n.slot, o]),\n D = _objectSpread(_objectSpread({\n ref: s\n }, n.props), {}, {\n id: i\n });\n return I({\n ourProps: D,\n theirProps: l,\n slot: p,\n defaultTag: S,\n name: n.name || \"Description\"\n });\n}\nvar _ = R(C),\n w = Object.assign(_, {});\nexport { w as Description, G as useDescribedBy, U as useDescriptions };","import React from 'react';\nimport ReactToolTip from 'react-tooltip';\nimport { generateId } from '../utils/genIds';\n\nconst FormInput = (props) => {\n const {\n helperText,\n label,\n description,\n errors = [],\n modelName,\n model,\n attribute,\n type,\n options = [],\n value,\n setValue,\n required,\n toolTip,\n } = props;\n\n const inputMap = {\n textarea: TextArea,\n select: Select,\n checkbox: Checkbox,\n default: Input,\n };\n\n const id = generateId();\n const name = `${modelName}[${attribute}]`;\n\n let handleChange = null;\n if (typeof setValue === 'function') {\n handleChange = (e) => setValue(e.target.value);\n }\n\n let fundsTypeOptions = [];\n if (type === 'select') {\n fundsTypeOptions = Object.keys(options).map((e, i) => {\n return (\n
\n );\n });\n }\n\n let componentProps = {\n required,\n id,\n name,\n defaultValue: value || model[attribute],\n onChange: handleChange,\n };\n switch (type) {\n case 'select':\n componentProps = { ...componentProps, fundsTypeOptions };\n break;\n case 'textarea':\n break;\n default:\n componentProps = { ...componentProps, type };\n }\n\n const InputComponent = inputMap[type] || inputMap['default'];\n\n return (\n <>\n
\n {!!description && (\n
{description}
\n )}\n
\n
\n {errors.length > 0 ? (\n
\n ) : (\n ''\n )}\n
\n {errors.map((e, i) => {\n return (\n
\n {e}\n
\n );\n })}\n {helperText &&
{helperText}
}\n >\n );\n};\n\nconst Select = (props) => {\n const {\n required,\n id,\n name,\n defaultValue,\n onChange,\n fundsTypeOptions,\n } = props;\n\n return (\n
\n );\n};\n\nconst TextArea = (props) => {\n const { required, id, name, defaultValue, onChange } = props;\n\n return (\n
\n );\n};\n\n\nconst Checkbox = (props) => {\n const { required, id, name, defaultValue } = props;\n return (\n
\n \n \n \n
\n );\n}\n\nconst Input = (props) => {\n const { required, id, type, name, defaultValue, onChange } = props;\n\n return (\n
\n );\n};\n\nexport const ToolTip = (props) => {\n const { dataForId, dataTip } = props;\n\n return (\n <>\n
\n \n \n \n >\n );\n};\n\nexport default FormInput;\n","'use strict';\nvar $ = require('../internals/export');\nvar toObject = require('../internals/to-object');\nvar nativeKeys = require('../internals/object-keys');\nvar fails = require('../internals/fails');\n\nvar FAILS_ON_PRIMITIVES = fails(function () { nativeKeys(1); });\n\n// `Object.keys` method\n// https://tc39.es/ecma262/#sec-object.keys\n$({ target: 'Object', stat: true, forced: FAILS_ON_PRIMITIVES }, {\n keys: function keys(it) {\n return nativeKeys(toObject(it));\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar fails = require('../internals/fails');\nvar toObject = require('../internals/to-object');\nvar nativeGetPrototypeOf = require('../internals/object-get-prototype-of');\nvar CORRECT_PROTOTYPE_GETTER = require('../internals/correct-prototype-getter');\n\nvar FAILS_ON_PRIMITIVES = fails(function () { nativeGetPrototypeOf(1); });\n\n// `Object.getPrototypeOf` method\n// https://tc39.es/ecma262/#sec-object.getprototypeof\n$({ target: 'Object', stat: true, forced: FAILS_ON_PRIMITIVES, sham: !CORRECT_PROTOTYPE_GETTER }, {\n getPrototypeOf: function getPrototypeOf(it) {\n return nativeGetPrototypeOf(toObject(it));\n }\n});\n\n","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { useEffect as s, useState as o } from \"react\";\nimport { disposables as t } from '../utils/disposables.js';\nfunction p() {\n var _o = o(t),\n _o2 = _slicedToArray(_o, 1),\n e = _o2[0];\n return s(function () {\n return function () {\n return e.dispose();\n };\n }, [e]), e;\n}\nexport { p as useDisposables };","import { env as n } from './env.js';\nfunction u(r) {\n return n.isServer ? null : r instanceof Node ? r.ownerDocument : r != null && r.hasOwnProperty(\"current\") && r.current instanceof Node ? r.current.ownerDocument : document;\n}\nexport { u as getOwnerDocument };","import React from \"react\";\nimport {useCheckout} from \"./StateManagement\";\n\nexport const Input = ({\n type,\n label,\n name,\n isRequired,\n selectOptions = null,\n isChecked,\n context,\n}) => {\n const { updateUserAttribute, toggleSameAsBilling, setShippingAddress, setBillingAddress, state } = useCheckout();\n const { user, shipping_address, billing_address, errors } = state;\n const handleCheckboxChange = (event) => {\n toggleSameAsBilling( );\n };\n\n const contextHandlers = {\n user: updateUserAttribute,\n shipping: setShippingAddress,\n billing: setBillingAddress,\n };\n\n const handleChange = (e) => {\n const updateFunction = contextHandlers[context];\n if (updateFunction) {\n updateFunction(name, e.target.value);\n }\n };\n const myerrors = errors[name] || [];\n\n const value = \n context === 'shipping' ? shipping_address[name] : \n context === 'billing' ? billing_address[name] :\n user[name];\n\n\n const renderDropdown = () => {\n return (\n
\n );\n };\n\n return (\n <>\n
\n
\n
\n {type === 'dropdown' ? (\n renderDropdown()\n ) : (\n
\n )}\n\n {myerrors.length > 0 ? (\n
\n ) : (\n ''\n )}\n
\n {myerrors.map((e, i) => {\n return (\n
\n {e}\n
\n );\n })}\n
\n >\n );\n};","'use strict';\nvar NATIVE_WEAK_MAP = require('../internals/weak-map-basic-detection');\nvar global = require('../internals/global');\nvar isObject = require('../internals/is-object');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar hasOwn = require('../internals/has-own-property');\nvar shared = require('../internals/shared-store');\nvar sharedKey = require('../internals/shared-key');\nvar hiddenKeys = require('../internals/hidden-keys');\n\nvar OBJECT_ALREADY_INITIALIZED = 'Object already initialized';\nvar TypeError = global.TypeError;\nvar WeakMap = global.WeakMap;\nvar set, get, has;\n\nvar enforce = function (it) {\n return has(it) ? get(it) : set(it, {});\n};\n\nvar getterFor = function (TYPE) {\n return function (it) {\n var state;\n if (!isObject(it) || (state = get(it)).type !== TYPE) {\n throw new TypeError('Incompatible receiver, ' + TYPE + ' required');\n } return state;\n };\n};\n\nif (NATIVE_WEAK_MAP || shared.state) {\n var store = shared.state || (shared.state = new WeakMap());\n /* eslint-disable no-self-assign -- prototype methods protection */\n store.get = store.get;\n store.has = store.has;\n store.set = store.set;\n /* eslint-enable no-self-assign -- prototype methods protection */\n set = function (it, metadata) {\n if (store.has(it)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);\n metadata.facade = it;\n store.set(it, metadata);\n return metadata;\n };\n get = function (it) {\n return store.get(it) || {};\n };\n has = function (it) {\n return store.has(it);\n };\n} else {\n var STATE = sharedKey('state');\n hiddenKeys[STATE] = true;\n set = function (it, metadata) {\n if (hasOwn(it, STATE)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);\n metadata.facade = it;\n createNonEnumerableProperty(it, STATE, metadata);\n return metadata;\n };\n get = function (it) {\n return hasOwn(it, STATE) ? it[STATE] : {};\n };\n has = function (it) {\n return hasOwn(it, STATE);\n };\n}\n\nmodule.exports = {\n set: set,\n get: get,\n has: has,\n enforce: enforce,\n getterFor: getterFor\n};\n","import { useMemo as t } from \"react\";\nimport { getOwnerDocument as o } from '../utils/owner.js';\nfunction n() {\n for (var _len = arguments.length, e = new Array(_len), _key = 0; _key < _len; _key++) {\n e[_key] = arguments[_key];\n }\n return t(function () {\n return o.apply(void 0, e);\n }, [].concat(e));\n}\nexport { n as useOwnerDocument };","'use strict';\nvar $ = require('../internals/export');\nvar fails = require('../internals/fails');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar nativeGetOwnPropertyDescriptor = require('../internals/object-get-own-property-descriptor').f;\nvar DESCRIPTORS = require('../internals/descriptors');\n\nvar FORCED = !DESCRIPTORS || fails(function () { nativeGetOwnPropertyDescriptor(1); });\n\n// `Object.getOwnPropertyDescriptor` method\n// https://tc39.es/ecma262/#sec-object.getownpropertydescriptor\n$({ target: 'Object', stat: true, forced: FORCED, sham: !DESCRIPTORS }, {\n getOwnPropertyDescriptor: function getOwnPropertyDescriptor(it, key) {\n return nativeGetOwnPropertyDescriptor(toIndexedObject(it), key);\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar ownKeys = require('../internals/own-keys');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar getOwnPropertyDescriptorModule = require('../internals/object-get-own-property-descriptor');\nvar createProperty = require('../internals/create-property');\n\n// `Object.getOwnPropertyDescriptors` method\n// https://tc39.es/ecma262/#sec-object.getownpropertydescriptors\n$({ target: 'Object', stat: true, sham: !DESCRIPTORS }, {\n getOwnPropertyDescriptors: function getOwnPropertyDescriptors(object) {\n var O = toIndexedObject(object);\n var getOwnPropertyDescriptor = getOwnPropertyDescriptorModule.f;\n var keys = ownKeys(O);\n var result = {};\n var index = 0;\n var key, descriptor;\n while (keys.length > index) {\n descriptor = getOwnPropertyDescriptor(O, key = keys[index++]);\n if (descriptor !== undefined) createProperty(result, key, descriptor);\n }\n return result;\n }\n});\n","'use strict';\n// TODO: Remove this module from `core-js@4` since it's split to modules listed below\nrequire('../modules/es.promise.constructor');\nrequire('../modules/es.promise.all');\nrequire('../modules/es.promise.catch');\nrequire('../modules/es.promise.race');\nrequire('../modules/es.promise.reject');\nrequire('../modules/es.promise.resolve');\n","'use strict';\n// toObject with fallback for non-array-like ES3 strings\nvar IndexedObject = require('../internals/indexed-object');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nmodule.exports = function (it) {\n return IndexedObject(requireObjectCoercible(it));\n};\n","'use strict';\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\n\nvar $TypeError = TypeError;\n\n// `RequireObjectCoercible` abstract operation\n// https://tc39.es/ecma262/#sec-requireobjectcoercible\nmodule.exports = function (it) {\n if (isNullOrUndefined(it)) throw new $TypeError(\"Can't call method on \" + it);\n return it;\n};\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.asyncIterator` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.asynciterator\ndefineWellKnownSymbol('asyncIterator');\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\nvar setToStringTag = require('../internals/set-to-string-tag');\n\n// `Symbol.toStringTag` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.tostringtag\ndefineWellKnownSymbol('toStringTag');\n\n// `Symbol.prototype[@@toStringTag]` property\n// https://tc39.es/ecma262/#sec-symbol.prototype-@@tostringtag\nsetToStringTag(getBuiltIn('Symbol'), 'Symbol');\n","'use strict';\nvar $ = require('../internals/export');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar IndexedObject = require('../internals/indexed-object');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar arrayMethodIsStrict = require('../internals/array-method-is-strict');\n\nvar nativeJoin = uncurryThis([].join);\n\nvar ES3_STRINGS = IndexedObject !== Object;\nvar FORCED = ES3_STRINGS || !arrayMethodIsStrict('join', ',');\n\n// `Array.prototype.join` method\n// https://tc39.es/ecma262/#sec-array.prototype.join\n$({ target: 'Array', proto: true, forced: FORCED }, {\n join: function join(separator) {\n return nativeJoin(toIndexedObject(this), separator === undefined ? ',' : separator);\n }\n});\n","'use strict';\nvar NATIVE_ARRAY_BUFFER = require('../internals/array-buffer-basic-detection');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar global = require('../internals/global');\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\nvar hasOwn = require('../internals/has-own-property');\nvar classof = require('../internals/classof');\nvar tryToString = require('../internals/try-to-string');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar getPrototypeOf = require('../internals/object-get-prototype-of');\nvar setPrototypeOf = require('../internals/object-set-prototype-of');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar uid = require('../internals/uid');\nvar InternalStateModule = require('../internals/internal-state');\n\nvar enforceInternalState = InternalStateModule.enforce;\nvar getInternalState = InternalStateModule.get;\nvar Int8Array = global.Int8Array;\nvar Int8ArrayPrototype = Int8Array && Int8Array.prototype;\nvar Uint8ClampedArray = global.Uint8ClampedArray;\nvar Uint8ClampedArrayPrototype = Uint8ClampedArray && Uint8ClampedArray.prototype;\nvar TypedArray = Int8Array && getPrototypeOf(Int8Array);\nvar TypedArrayPrototype = Int8ArrayPrototype && getPrototypeOf(Int8ArrayPrototype);\nvar ObjectPrototype = Object.prototype;\nvar TypeError = global.TypeError;\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\nvar TYPED_ARRAY_TAG = uid('TYPED_ARRAY_TAG');\nvar TYPED_ARRAY_CONSTRUCTOR = 'TypedArrayConstructor';\n// Fixing native typed arrays in Opera Presto crashes the browser, see #595\nvar NATIVE_ARRAY_BUFFER_VIEWS = NATIVE_ARRAY_BUFFER && !!setPrototypeOf && classof(global.opera) !== 'Opera';\nvar TYPED_ARRAY_TAG_REQUIRED = false;\nvar NAME, Constructor, Prototype;\n\nvar TypedArrayConstructorsList = {\n Int8Array: 1,\n Uint8Array: 1,\n Uint8ClampedArray: 1,\n Int16Array: 2,\n Uint16Array: 2,\n Int32Array: 4,\n Uint32Array: 4,\n Float32Array: 4,\n Float64Array: 8\n};\n\nvar BigIntArrayConstructorsList = {\n BigInt64Array: 8,\n BigUint64Array: 8\n};\n\nvar isView = function isView(it) {\n if (!isObject(it)) return false;\n var klass = classof(it);\n return klass === 'DataView'\n || hasOwn(TypedArrayConstructorsList, klass)\n || hasOwn(BigIntArrayConstructorsList, klass);\n};\n\nvar getTypedArrayConstructor = function (it) {\n var proto = getPrototypeOf(it);\n if (!isObject(proto)) return;\n var state = getInternalState(proto);\n return (state && hasOwn(state, TYPED_ARRAY_CONSTRUCTOR)) ? state[TYPED_ARRAY_CONSTRUCTOR] : getTypedArrayConstructor(proto);\n};\n\nvar isTypedArray = function (it) {\n if (!isObject(it)) return false;\n var klass = classof(it);\n return hasOwn(TypedArrayConstructorsList, klass)\n || hasOwn(BigIntArrayConstructorsList, klass);\n};\n\nvar aTypedArray = function (it) {\n if (isTypedArray(it)) return it;\n throw new TypeError('Target is not a typed array');\n};\n\nvar aTypedArrayConstructor = function (C) {\n if (isCallable(C) && (!setPrototypeOf || isPrototypeOf(TypedArray, C))) return C;\n throw new TypeError(tryToString(C) + ' is not a typed array constructor');\n};\n\nvar exportTypedArrayMethod = function (KEY, property, forced, options) {\n if (!DESCRIPTORS) return;\n if (forced) for (var ARRAY in TypedArrayConstructorsList) {\n var TypedArrayConstructor = global[ARRAY];\n if (TypedArrayConstructor && hasOwn(TypedArrayConstructor.prototype, KEY)) try {\n delete TypedArrayConstructor.prototype[KEY];\n } catch (error) {\n // old WebKit bug - some methods are non-configurable\n try {\n TypedArrayConstructor.prototype[KEY] = property;\n } catch (error2) { /* empty */ }\n }\n }\n if (!TypedArrayPrototype[KEY] || forced) {\n defineBuiltIn(TypedArrayPrototype, KEY, forced ? property\n : NATIVE_ARRAY_BUFFER_VIEWS && Int8ArrayPrototype[KEY] || property, options);\n }\n};\n\nvar exportTypedArrayStaticMethod = function (KEY, property, forced) {\n var ARRAY, TypedArrayConstructor;\n if (!DESCRIPTORS) return;\n if (setPrototypeOf) {\n if (forced) for (ARRAY in TypedArrayConstructorsList) {\n TypedArrayConstructor = global[ARRAY];\n if (TypedArrayConstructor && hasOwn(TypedArrayConstructor, KEY)) try {\n delete TypedArrayConstructor[KEY];\n } catch (error) { /* empty */ }\n }\n if (!TypedArray[KEY] || forced) {\n // V8 ~ Chrome 49-50 `%TypedArray%` methods are non-writable non-configurable\n try {\n return defineBuiltIn(TypedArray, KEY, forced ? property : NATIVE_ARRAY_BUFFER_VIEWS && TypedArray[KEY] || property);\n } catch (error) { /* empty */ }\n } else return;\n }\n for (ARRAY in TypedArrayConstructorsList) {\n TypedArrayConstructor = global[ARRAY];\n if (TypedArrayConstructor && (!TypedArrayConstructor[KEY] || forced)) {\n defineBuiltIn(TypedArrayConstructor, KEY, property);\n }\n }\n};\n\nfor (NAME in TypedArrayConstructorsList) {\n Constructor = global[NAME];\n Prototype = Constructor && Constructor.prototype;\n if (Prototype) enforceInternalState(Prototype)[TYPED_ARRAY_CONSTRUCTOR] = Constructor;\n else NATIVE_ARRAY_BUFFER_VIEWS = false;\n}\n\nfor (NAME in BigIntArrayConstructorsList) {\n Constructor = global[NAME];\n Prototype = Constructor && Constructor.prototype;\n if (Prototype) enforceInternalState(Prototype)[TYPED_ARRAY_CONSTRUCTOR] = Constructor;\n}\n\n// WebKit bug - typed arrays constructors prototype is Object.prototype\nif (!NATIVE_ARRAY_BUFFER_VIEWS || !isCallable(TypedArray) || TypedArray === Function.prototype) {\n // eslint-disable-next-line no-shadow -- safe\n TypedArray = function TypedArray() {\n throw new TypeError('Incorrect invocation');\n };\n if (NATIVE_ARRAY_BUFFER_VIEWS) for (NAME in TypedArrayConstructorsList) {\n if (global[NAME]) setPrototypeOf(global[NAME], TypedArray);\n }\n}\n\nif (!NATIVE_ARRAY_BUFFER_VIEWS || !TypedArrayPrototype || TypedArrayPrototype === ObjectPrototype) {\n TypedArrayPrototype = TypedArray.prototype;\n if (NATIVE_ARRAY_BUFFER_VIEWS) for (NAME in TypedArrayConstructorsList) {\n if (global[NAME]) setPrototypeOf(global[NAME].prototype, TypedArrayPrototype);\n }\n}\n\n// WebKit bug - one more object in Uint8ClampedArray prototype chain\nif (NATIVE_ARRAY_BUFFER_VIEWS && getPrototypeOf(Uint8ClampedArrayPrototype) !== TypedArrayPrototype) {\n setPrototypeOf(Uint8ClampedArrayPrototype, TypedArrayPrototype);\n}\n\nif (DESCRIPTORS && !hasOwn(TypedArrayPrototype, TO_STRING_TAG)) {\n TYPED_ARRAY_TAG_REQUIRED = true;\n defineBuiltInAccessor(TypedArrayPrototype, TO_STRING_TAG, {\n configurable: true,\n get: function () {\n return isObject(this) ? this[TYPED_ARRAY_TAG] : undefined;\n }\n });\n for (NAME in TypedArrayConstructorsList) if (global[NAME]) {\n createNonEnumerableProperty(global[NAME], TYPED_ARRAY_TAG, NAME);\n }\n}\n\nmodule.exports = {\n NATIVE_ARRAY_BUFFER_VIEWS: NATIVE_ARRAY_BUFFER_VIEWS,\n TYPED_ARRAY_TAG: TYPED_ARRAY_TAG_REQUIRED && TYPED_ARRAY_TAG,\n aTypedArray: aTypedArray,\n aTypedArrayConstructor: aTypedArrayConstructor,\n exportTypedArrayMethod: exportTypedArrayMethod,\n exportTypedArrayStaticMethod: exportTypedArrayStaticMethod,\n getTypedArrayConstructor: getTypedArrayConstructor,\n isView: isView,\n isTypedArray: isTypedArray,\n TypedArray: TypedArray,\n TypedArrayPrototype: TypedArrayPrototype\n};\n","'use strict';\nvar global = require('../internals/global');\nvar setToStringTag = require('../internals/set-to-string-tag');\n\n// JSON[@@toStringTag] property\n// https://tc39.es/ecma262/#sec-json-@@tostringtag\nsetToStringTag(global.JSON, 'JSON', true);\n","'use strict';\nvar setToStringTag = require('../internals/set-to-string-tag');\n\n// Math[@@toStringTag] property\n// https://tc39.es/ecma262/#sec-math-@@tostringtag\nsetToStringTag(Math, 'Math', true);\n","'use strict';\nvar $ = require('../internals/export');\nvar assign = require('../internals/object-assign');\n\n// `Object.assign` method\n// https://tc39.es/ecma262/#sec-object.assign\n// eslint-disable-next-line es/no-object-assign -- required for testing\n$({ target: 'Object', stat: true, arity: 2, forced: Object.assign !== assign }, {\n assign: assign\n});\n","'use strict';\n/* global ActiveXObject -- old IE, WSH */\nvar anObject = require('../internals/an-object');\nvar definePropertiesModule = require('../internals/object-define-properties');\nvar enumBugKeys = require('../internals/enum-bug-keys');\nvar hiddenKeys = require('../internals/hidden-keys');\nvar html = require('../internals/html');\nvar documentCreateElement = require('../internals/document-create-element');\nvar sharedKey = require('../internals/shared-key');\n\nvar GT = '>';\nvar LT = '<';\nvar PROTOTYPE = 'prototype';\nvar SCRIPT = 'script';\nvar IE_PROTO = sharedKey('IE_PROTO');\n\nvar EmptyConstructor = function () { /* empty */ };\n\nvar scriptTag = function (content) {\n return LT + SCRIPT + GT + content + LT + '/' + SCRIPT + GT;\n};\n\n// Create object with fake `null` prototype: use ActiveX Object with cleared prototype\nvar NullProtoObjectViaActiveX = function (activeXDocument) {\n activeXDocument.write(scriptTag(''));\n activeXDocument.close();\n var temp = activeXDocument.parentWindow.Object;\n activeXDocument = null; // avoid memory leak\n return temp;\n};\n\n// Create object with fake `null` prototype: use iframe Object with cleared prototype\nvar NullProtoObjectViaIFrame = function () {\n // Thrash, waste and sodomy: IE GC bug\n var iframe = documentCreateElement('iframe');\n var JS = 'java' + SCRIPT + ':';\n var iframeDocument;\n iframe.style.display = 'none';\n html.appendChild(iframe);\n // https://github.com/zloirock/core-js/issues/475\n iframe.src = String(JS);\n iframeDocument = iframe.contentWindow.document;\n iframeDocument.open();\n iframeDocument.write(scriptTag('document.F=Object'));\n iframeDocument.close();\n return iframeDocument.F;\n};\n\n// Check for document.domain and active x support\n// No need to use active x approach when document.domain is not set\n// see https://github.com/es-shims/es5-shim/issues/150\n// variation of https://github.com/kitcambridge/es5-shim/commit/4f738ac066346\n// avoid IE GC bug\nvar activeXDocument;\nvar NullProtoObject = function () {\n try {\n activeXDocument = new ActiveXObject('htmlfile');\n } catch (error) { /* ignore */ }\n NullProtoObject = typeof document != 'undefined'\n ? document.domain && activeXDocument\n ? NullProtoObjectViaActiveX(activeXDocument) // old IE\n : NullProtoObjectViaIFrame()\n : NullProtoObjectViaActiveX(activeXDocument); // WSH\n var length = enumBugKeys.length;\n while (length--) delete NullProtoObject[PROTOTYPE][enumBugKeys[length]];\n return NullProtoObject();\n};\n\nhiddenKeys[IE_PROTO] = true;\n\n// `Object.create` method\n// https://tc39.es/ecma262/#sec-object.create\n// eslint-disable-next-line es/no-object-create -- safe\nmodule.exports = Object.create || function create(O, Properties) {\n var result;\n if (O !== null) {\n EmptyConstructor[PROTOTYPE] = anObject(O);\n result = new EmptyConstructor();\n EmptyConstructor[PROTOTYPE] = null;\n // add \"__proto__\" for Object.getPrototypeOf polyfill\n result[IE_PROTO] = O;\n } else result = NullProtoObject();\n return Properties === undefined ? result : definePropertiesModule.f(result, Properties);\n};\n","'use strict';\nvar defineProperty = require('../internals/object-define-property').f;\nvar hasOwn = require('../internals/has-own-property');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\n\nmodule.exports = function (target, TAG, STATIC) {\n if (target && !STATIC) target = target.prototype;\n if (target && !hasOwn(target, TO_STRING_TAG)) {\n defineProperty(target, TO_STRING_TAG, { configurable: true, value: TAG });\n }\n};\n","import React, {\n useContext,\n createContext,\n useReducer,\n useCallback,\n useMemo,\n useEffect,\n} from \"react\";\nimport { CardElement, useStripe, useElements, PaymentElement } from \"@stripe/react-stripe-js\";\nimport axios from \"../../utils/requests\";\n\nconst CheckoutContext = createContext(null);\n\nconst initialState = {\n user: {\n first_name: \"\",\n last_name: \"\",\n email: \"\",\n phone: \"\",\n },\n shipping_address: {\n shipping_first_name: \"\",\n shipping_last_name: \"\",\n shipping_line1: \"\",\n shipping_line2: \"\",\n shipping_city: \"\",\n shipping_region: \"\",\n shipping_country: \"\",\n shipping_postalcode: \"\",\n },\n billing_address: {\n billing_first_name: \"\",\n billing_last_name: \"\",\n billing_line1: \"\",\n billing_line2: \"\",\n billing_city: \"\",\n billing_region: \"\",\n billing_country: \"\",\n billing_postalcode: \"\",\n },\n organization: {},\n feeModel: {},\n amount: null,\n completed: false,\n loading: false,\n errors: {},\n autoPay: false,\n saveBillingInfo: false,\n transaction_id: null,\n order_id: null,\n paymentMethod: null,\n subscription_id: null,\n billingSameAsShipping: true,\n shippingOption: {},\n cart: {},\n formFields: [],\n formSelectOptions: [],\n formValues: {},\n orderSummary: {\n subtotal: null,\n shipping_cost: null,\n fees: null,\n total: null,\n },\n};\n\nexport const CheckoutFormProvider = (props) => {\n // added the form state\n const state = {\n ...initialState,\n formFields: props.formFields,\n formSelectOptions: props.formSelectOptions,\n organization: props.organization,\n paymentMethods: props.paymentMethods,\n cart: props.cart,\n feeModel: props.feeModel,\n shippingOptions: props.shippingOptions || [],\n };\n\n if (props.shippingOptions?.length > 0) {\n state.shippingOption = props.shippingOptions[0];\n }\n\n if (props.paymentMethods?.data?.length > 0) {\n state.paymentMethod = props.paymentMethods[0].id;\n }\n\n // props.currentUser ? (state.user = props.currentUser) : null;\n if (props.currentUser) {\n state.user = props.currentUser;\n state.billing_address = {\n billing_first_name: props.currentUser.first_name,\n billing_last_name: props.currentUser.last_name,\n billing_line1: props.currentUser.line1,\n billing_line2: props.currentUser.line2,\n billing_city: props.currentUser.city,\n billing_region: props.currentUser.region,\n billing_country: props.currentUser.country,\n billing_postalcode: props.currentUser.postalcode,\n };\n state.shipping_address = {\n shipping_first_name: props.currentUser.first_name,\n shipping_last_name: props.currentUser.last_name,\n shipping_line1: props.currentUser.line1,\n shipping_line2: props.currentUser.line2,\n shipping_city: props.currentUser.city,\n shipping_region: props.currentUser.region,\n shipping_country: props.currentUser.country,\n shipping_postalcode: props.currentUser.postalcode,\n };\n } else {\n null\n }\n\n const [store, dispatch] = useReducer(checkoutReducer, state);\n\n const value = React.useMemo(() => [store, dispatch], [store]);\n return
;\n};\n\nconst checkoutReducer = (state, action) => {\n switch (action.type) {\n case \"UPDATE_USER\":\n return { ...state, user: action.user };\n case \"TOGGLE_LOADING\":\n return { ...state, loading: !state.loading };\n case \"TOGGLE_COMPLETED\":\n return { ...state, completed: !state.completed };\n case \"SET_ERROR\":\n return { ...state, error: action.error };\n case \"SET_ERRORS\":\n return { ...state, errors: action.errors };\n case \"SET_PAYMENT_METHOD\":\n return { ...state, paymentMethod: action.paymentMethod };\n case \"SET_ORDER_ID\":\n return { ...state, order_id: action.order_id };\n case \"SET_TRANSACTION_ID\":\n return { ...state, transaction_id: action.transaction_id };\n case \"SET_SHIPPING_OPTION\":\n return { ...state, shippingOption: action.shippingOption };\n case \"UPDATE_SAVE_BILLING_INFO\":\n return { ...state, saveBillingInfo: action.saveBillingInfo };\n case \"TOGGLE_SAME_AS_BILLING\":\n return { \n ...state, \n billingSameAsShipping: action.billingSameAsShipping, \n shipping_address: action.billingSameAsShipping ? \n { \n shipping_first_name: state.billing_address.billing_first_name,\n shipping_last_name: state.billing_address.billing_last_name,\n shipping_line1: state.billing_address.billing_line1,\n shipping_line2: state.billing_address.billing_line2,\n shipping_city: state.billing_address.billing_city,\n shipping_region: state.billing_address.billing_region,\n shipping_country: state.billing_address.billing_country,\n shipping_postalcode: state.billing_address.billing_postalcode,\n } : { \n shipping_first_name: \"\",\n shipping_last_name: \"\",\n shipping_line1: \"\",\n shipping_line2: \"\",\n shipping_city: \"\",\n shipping_region: \"\",\n shipping_country: \"\",\n shipping_postalcode: \"\",\n } \n };\n case \"UPDATE_FORM_VALUE\":\n return { ...state, formValues: { ...state.formValues, [action.formFieldId]: action.value } };\n case \"COPY_BILLING_TO_SHIPPING\":\n return {\n ...state,\n shipping_address: {\n shipping_first_name: state.billing_address.billing_first_name,\n shipping_last_name: state.billing_address.billing_last_name,\n shipping_line1: state.billing_address.billing_line1,\n shipping_line2: state.billing_address.billing_line2,\n shipping_city: state.billing_address.billing_city,\n shipping_region: state.billing_address.billing_region,\n shipping_country: state.billing_address.billing_country,\n shipping_postalcode: state.billing_address.billing_postalcode,\n },\n };\n case \"SET_ORDER_SUMMARY\":\n return { ...state, orderSummary: action.orderSummary };\n case \"UPDATE_CART\":\n return { ...state, cart: action.cart };\n case \"UPDATE_SHIPPING_ADDRESS\":\n return { ...state, shipping_address: action.shipping_address };\n case \"UPDATE_BILLING_ADDRESS\":\n return { \n ...state,\n billing_address: action.billing_address,\n user: {\n ...state.user,\n first_name: action.billing_address.billing_first_name,\n last_name: action.billing_address.billing_last_name,\n },\n };\n case \"UPDATE_TOTAL_AMOUNT\":\n return { ...state, amount: action.amount };\n default:\n return state;\n }\n};\n\nexport const useCheckout = () => {\n const [state, dispatch] = useContext(CheckoutContext);\n\n const updateUserAttribute = useCallback(\n (attribute, value) => {\n const user = { ...state.user };\n user[attribute] = value;\n\n if (attribute === \"password\") user[\"password_confirmation\"] = value;\n\n dispatch({ type: \"UPDATE_USER\", user });\n\n },\n [state, dispatch]\n );\n\n const setPaymentMethod = useCallback(\n (method) => {\n dispatch({ type: \"SET_PAYMENT_METHOD\", paymentMethod: method.id });\n },\n [state, dispatch]\n );\n\n const toggleSaveBillingInfo = () => {\n dispatch({\n type: \"UPDATE_SAVE_BILLING_INFO\",\n saveBillingInfo: !state.saveBillingInfo,\n });\n };\n\n const toggleSameAsBilling = () => {\n dispatch({ type: \"TOGGLE_SAME_AS_BILLING\", billingSameAsShipping: !state.billingSameAsShipping });\n };\n\n const setShippingAddress = useCallback(\n (attribute, value) => {\n const shippingInfo = { ...state.shipping_address };\n shippingInfo[attribute] = value;\n\n dispatch({ type: \"UPDATE_SHIPPING_ADDRESS\", shipping_address: shippingInfo });\n },\n [state, dispatch]\n );\n\n const setBillingAddress = useCallback(\n (attribute, value) => {\n const billingInfo = { ...state.billing_address };\n billingInfo[attribute] = value;\n\n dispatch({ type: \"UPDATE_BILLING_ADDRESS\", billing_address: billingInfo });\n \n if (state.billingSameAsShipping) {\n dispatch({ type: \"COPY_BILLING_TO_SHIPPING\" });\n }\n },\n [state, dispatch]\n );\n\n const setShippingOption = useCallback(\n (method) => {\n dispatch({ type: \"SET_SHIPPING_OPTION\", shippingOption: method });\n },\n [state, dispatch]\n );\n\n const setOrderSummary = useCallback(\n (method) => {\n dispatch({ type: \"SET_ORDER_SUMMARY\", orderSummary: method });\n dispatch({ type: \"UPDATE_TOTAL_AMOUNT\", amount: method.total });\n },\n [state, dispatch]\n );\n\n const updateCartQuantity = useCallback(async (pvId, quantity) => {\n try {\n const response = await axios.post(`/o/${state.organization.slug}/add_to_cart?product_variant_id=${pvId}&product_variant_qty=${quantity}`, {\n product_variant_id: pvId,\n quantity: quantity,\n });\n const newCart = { ...state.cart };\n newCart.quantity[pvId] = quantity;\n dispatch({ type: \"UPDATE_CART\", cart: newCart });\n } catch (error) {\n console.error(\"Error updating cart item quantity:\", error); // Change to UI notification\n }\n }, [state, dispatch]);\n\n const removeCartItem = useCallback(async (pvId, quantity) => {\n try {\n const response = await axios.post(`/o/${state.organization.slug}/remove_from_cart?product_variant_id=${pvId}&product_variant_qty=${quantity}`, {\n product_variant_id: pvId,\n quantity: quantity,\n });\n const newCart = { ...state.cart };\n delete newCart.quantity[pvId];\n newCart.productVariants = newCart.productVariants.filter(pv => pv.id !== pvId);\n\n dispatch({ type: \"UPDATE_CART\", cart: newCart });\n } catch (error) {\n console.error(\"Error removing cart item:\", error);\n }\n }, [state, dispatch]);\n\n const shippingEnabled = useMemo(() => {\n if (state.shippingOptions.length > 0) {\n return state.cart.productVariants.some(\n (pv) => pv.product.shipping_enabled);\n }\n return false;\n }, [state.cart.productVariants]);\n\n useEffect(() => {\n if (!shippingEnabled && state.shippingOption != null) {\n dispatch({ type: \"SET_SHIPPING_OPTION\", shippingOption: null });\n }\n }, [shippingEnabled, state.shippingOption]);\n\n return {\n state,\n dispatch,\n stripe: useStripe(),\n elements: useElements(),\n toggleSaveBillingInfo,\n updateUserAttribute,\n setPaymentMethod,\n toggleSameAsBilling,\n setShippingOption,\n setOrderSummary,\n updateCartQuantity,\n removeCartItem,\n setShippingAddress,\n setBillingAddress,\n shippingEnabled,\n };\n};\n\n// this is the function that handles form submission of single charges\nexport const singleChargeSubmit = async ({\n state,\n dispatch,\n stripe,\n elements,\n}) => {\n const {\n user,\n organization,\n transaction_id,\n order_id,\n saveBillingInfo,\n paymentMethod,\n shipping_address,\n billing_address,\n shippingOption,\n formValues\n } = state;\n\n dispatch({ type: \"TOGGLE_LOADING\" });\n\n if (!stripe || !elements) {\n // Stripe.js has not loaded yet. Make sure to disable\n // form submission until Stripe.js has loaded.\n dispatch({ type: \"TOGGLE_LOADING\" });\n return;\n }\n\n let formValuesAttributes = Object.entries(formValues).map(([key, value]) => ({\n form_field_id: key,\n value: value,\n }));\n\n let params = {\n transaction_id,\n order_id,\n user_attributes: user,\n receipt_email: user.email,\n email: user.email,\n phone: user.phone,\n first_name: billing_address.billing_first_name,\n last_name: billing_address.billing_last_name,\n organization_id: organization.id,\n membership_id: user.membership_id,\n save_billing_info: saveBillingInfo,\n payment_method: paymentMethod,\n shipping_attributes: shipping_address,\n billing_attributes: billing_address,\n shipping_option_id: shippingOption?.id || null,\n shipping_cost: shippingOption?.cost_cents || 0,\n form_values_attributes: formValuesAttributes,\n };\n // console.log(params);\n\n\n // Create payment method\n // TODO PULL this into a new method,\n // only create a payment method if one is not set in the stage.\n // if a payment method is already in the state just use it. and\n // skip this method\n if (!paymentMethod) {\n const paymentMethodResponse = await createPaymentMethod({\n stripe,\n elements,\n organization,\n user,\n billing_address,\n });\n\n // return early and show errors if payment method doesnt create on stripe\n if (paymentMethodResponse.error) {\n dispatch({ type: \"TOGGLE_LOADING\" });\n dispatch({\n type: \"SET_ERRORS\",\n errors: { base: [paymentMethodResponse.error.message] },\n });\n return;\n }\n\n // set payment method id on the state so we dont do it again.\n dispatch({\n type: \"SET_PAYMENT_METHOD\",\n paymentMethod: paymentMethodResponse.paymentMethod.id,\n });\n params.payment_method = paymentMethodResponse.paymentMethod.id;\n }\n\n try {\n const response = await axios.post(`/o/${organization.id}/store/checkout`, {\n ...params,\n });\n\n dispatch({\n type: \"SET_TRANSACTION_ID\",\n transaction_id: response.data.transaction.id,\n });\n\n dispatch({\n type: \"SET_ORDER_ID\",\n order_id: response.data.order.id,\n });\n\n const result = await stripe.confirmCardPayment(\n response.data.stripe_intent.client_secret,\n { payment_method: params.payment_method }\n );\n\n if (result.error) {\n dispatch({ type: \"TOGGLE_LOADING\" });\n dispatch({\n type: \"SET_ERRORS\",\n errors: { base: [result.error.message] },\n });\n } else {\n if (result.paymentIntent.status === \"succeeded\") {\n // what do we do on the success of a card transaction\n window.location = `/o/${organization.slug}/store/checkout/receipt/?order_id=${response.data.order.id}`;\n dispatch({ type: \"TOGGLE_COMPLETED\" });\n dispatch({ type: \"TOGGLE_LOADING\" });\n }\n }\n } catch (error) {\n\n dispatch({ type: \"TOGGLE_LOADING\" });\n dispatch({ type: \"SET_ERRORS\", errors: error.response.data.errors });\n\n if (error.response.data.transaction_id) {\n dispatch({\n type: \"SET_TRANSACTION_ID\",\n transaction_id: error.response.data.transaction_id,\n });\n }\n if (error.response.data.order_id) {\n dispatch({\n type: \"SET_ORDER_ID\",\n order_id: error.response.data.order_id,\n });\n }\n }\n};\n\nconst createPaymentMethod = async ({\n stripe,\n elements,\n organization,\n user,\n billing_address,\n}) => {\n return await stripe.createPaymentMethod({\n type: \"card\",\n card: elements.getElement(CardElement),\n metadata: {\n organization_id: organization.id,\n },\n billing_details: {\n name: `${billing_address.billing_first_name} ${billing_address.billing_last_name}`,\n email: user.email,\n phone: user.phone && user.phone.length > 0 ? user.phone : null,\n address: {\n line1: billing_address.line1 && billing_address.line1.length > 0 ? billing_address.line1 : null,\n line2: billing_address.line2 && billing_address.line2.length > 0 ? billing_address.line2 : null,\n city: billing_address.city && billing_address.city.length > 0 ? billing_address.city : null,\n state: billing_address.region && billing_address.region.length > 0 ? billing_address.region : null,\n country: billing_address.country && billing_address.country.length > 0 ? billing_address.country : null,\n postal_code:\n billing_address.postalcode && billing_address.postalcode.length > 0\n ? billing_address.postalcode\n : null,\n },\n },\n // },\n });\n};\n","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { useCallback as r, useState as b } from \"react\";\nfunction c() {\n var u = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;\n var _b = b(u),\n _b2 = _slicedToArray(_b, 2),\n t = _b2[0],\n l = _b2[1],\n g = r(function (e) {\n return l(e);\n }, [t]),\n s = r(function (e) {\n return l(function (a) {\n return a | e;\n });\n }, [t]),\n m = r(function (e) {\n return (t & e) === e;\n }, [t]),\n n = r(function (e) {\n return l(function (a) {\n return a & ~e;\n });\n }, [l]),\n F = r(function (e) {\n return l(function (a) {\n return a ^ e;\n });\n }, [l]);\n return {\n flags: t,\n setFlag: g,\n addFlag: s,\n hasFlag: m,\n removeFlag: n,\n toggleFlag: F\n };\n}\nexport { c as useFlags };","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { useRef as T, useState as b } from \"react\";\nimport { disposables as m } from '../utils/disposables.js';\nimport { once as E } from '../utils/once.js';\nimport { useDisposables as S } from './use-disposables.js';\nimport { useFlags as g } from './use-flags.js';\nimport { useIsoMorphicEffect as L } from './use-iso-morphic-effect.js';\nvar y = function (a) {\n return a[a.None = 0] = \"None\", a[a.Closed = 1] = \"Closed\", a[a.Enter = 2] = \"Enter\", a[a.Leave = 4] = \"Leave\", a;\n}(y || {});\nfunction j(e) {\n var i = {};\n for (var t in e) e[t] === !0 && (i[\"data-\".concat(t)] = \"\");\n return i;\n}\nfunction x(e, i, t, r) {\n var _b = b(t),\n _b2 = _slicedToArray(_b, 2),\n a = _b2[0],\n u = _b2[1],\n _g = g(e && a ? 3 : 0),\n d = _g.hasFlag,\n f = _g.addFlag,\n o = _g.removeFlag,\n s = T(!1),\n n = T(!1),\n l = S();\n return L(function () {\n var c;\n if (e) {\n if (t && u(!0), !i) {\n t && f(3);\n return;\n }\n return (c = r == null ? void 0 : r.start) == null || c.call(r, t), C(i, {\n inFlight: s,\n prepare: function prepare() {\n n.current ? n.current = !1 : n.current = s.current, s.current = !0, !n.current && (t ? (f(3), o(4)) : (f(4), o(2)));\n },\n run: function run() {\n n.current ? t ? (o(3), f(4)) : (o(4), f(3)) : t ? o(1) : f(1);\n },\n done: function done() {\n var p;\n n.current && typeof i.getAnimations == \"function\" && i.getAnimations().length > 0 || (s.current = !1, o(7), t || u(!1), (p = r == null ? void 0 : r.end) == null || p.call(r, t));\n }\n });\n }\n }, [e, t, i, l]), e ? [a, {\n closed: d(1),\n enter: d(2),\n leave: d(4),\n transition: d(2) || d(4)\n }] : [t, {\n closed: void 0,\n enter: void 0,\n leave: void 0,\n transition: void 0\n }];\n}\nfunction C(e, _ref) {\n var i = _ref.prepare,\n t = _ref.run,\n r = _ref.done,\n a = _ref.inFlight;\n var u = m();\n return M(e, {\n prepare: i,\n inFlight: a\n }), u.nextFrame(function () {\n u.add(D(e, r)), t();\n }), u.dispose;\n}\nfunction D(e, i) {\n var t = E(i),\n r = m();\n if (!e) return r.dispose;\n var _getComputedStyle = getComputedStyle(e),\n a = _getComputedStyle.transitionDuration,\n u = _getComputedStyle.transitionDelay,\n _map = [a, u].map(function (s) {\n var _s$split$filter$map$s = s.split(\",\").filter(Boolean).map(function (l) {\n return l.includes(\"ms\") ? parseFloat(l) : parseFloat(l) * 1e3;\n }).sort(function (l, c) {\n return c - l;\n }),\n _s$split$filter$map$s2 = _slicedToArray(_s$split$filter$map$s, 1),\n _s$split$filter$map$s3 = _s$split$filter$map$s2[0],\n n = _s$split$filter$map$s3 === void 0 ? 0 : _s$split$filter$map$s3;\n return n;\n }),\n _map2 = _slicedToArray(_map, 2),\n d = _map2[0],\n f = _map2[1],\n o = d + f;\n if (o !== 0) {\n var s = r.group(function (n) {\n var l = n.setTimeout(function () {\n t(), n.dispose();\n }, o);\n n.addEventListener(e, \"transitionrun\", function (c) {\n c.target === c.currentTarget && (l(), n.addEventListener(e, \"transitioncancel\", function (p) {\n p.target === p.currentTarget && (t(), s());\n }));\n });\n });\n r.addEventListener(e, \"transitionend\", function (n) {\n n.target === n.currentTarget && (t(), r.dispose());\n });\n } else t();\n return r.dispose;\n}\nfunction M(e, _ref2) {\n var i = _ref2.inFlight,\n t = _ref2.prepare;\n if (i != null && i.current) {\n t();\n return;\n }\n var r = e.style.transition;\n e.style.transition = \"none\", t(), e.offsetHeight, e.style.transition = r;\n}\nexport { j as transitionDataAttributes, x as useTransition };","function l(r) {\n var e = {\n called: !1\n };\n return function () {\n if (!e.called) return e.called = !0, r.apply(void 0, arguments);\n };\n}\nexport { l as once };","import { useRef as o } from \"react\";\nimport { useWindowEvent as t } from './use-window-event.js';\nvar a = function (r) {\n return r[r.Forwards = 0] = \"Forwards\", r[r.Backwards = 1] = \"Backwards\", r;\n}(a || {});\nfunction u() {\n var e = o(0);\n return t(!0, \"keydown\", function (r) {\n r.key === \"Tab\" && (e.current = r.shiftKey ? 1 : 0);\n }, !0), e;\n}\nexport { a as Direction, u as useTabDirection };","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nvar toString = uncurryThis({}.toString);\nvar stringSlice = uncurryThis(''.slice);\n\nmodule.exports = function (it) {\n return stringSlice(toString(it), 8, -1);\n};\n","'use strict';\nvar trunc = require('../internals/math-trunc');\n\n// `ToIntegerOrInfinity` abstract operation\n// https://tc39.es/ecma262/#sec-tointegerorinfinity\nmodule.exports = function (argument) {\n var number = +argument;\n // eslint-disable-next-line no-self-compare -- NaN check\n return number !== number || number === 0 ? 0 : trunc(number);\n};\n","import n, { createContext as r, useContext as i } from \"react\";\nvar e = /*#__PURE__*/r(void 0);\nfunction a() {\n return i(e);\n}\nfunction l(_ref) {\n var t = _ref.value,\n o = _ref.children;\n return /*#__PURE__*/n.createElement(e.Provider, {\n value: t\n }, o);\n}\nexport { l as DisabledProvider, a as useDisabled };","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar definePropertyModule = require('../internals/object-define-property');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\n\nmodule.exports = DESCRIPTORS ? function (object, key, value) {\n return definePropertyModule.f(object, key, createPropertyDescriptor(1, value));\n} : function (object, key, value) {\n object[key] = value;\n return object;\n};\n","'use strict';\nvar makeBuiltIn = require('../internals/make-built-in');\nvar defineProperty = require('../internals/object-define-property');\n\nmodule.exports = function (target, name, descriptor) {\n if (descriptor.get) makeBuiltIn(descriptor.get, name, { getter: true });\n if (descriptor.set) makeBuiltIn(descriptor.set, name, { setter: true });\n return defineProperty.f(target, name, descriptor);\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar call = require('../internals/function-call');\nvar propertyIsEnumerableModule = require('../internals/object-property-is-enumerable');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar toPropertyKey = require('../internals/to-property-key');\nvar hasOwn = require('../internals/has-own-property');\nvar IE8_DOM_DEFINE = require('../internals/ie8-dom-define');\n\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar $getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\n// `Object.getOwnPropertyDescriptor` method\n// https://tc39.es/ecma262/#sec-object.getownpropertydescriptor\nexports.f = DESCRIPTORS ? $getOwnPropertyDescriptor : function getOwnPropertyDescriptor(O, P) {\n O = toIndexedObject(O);\n P = toPropertyKey(P);\n if (IE8_DOM_DEFINE) try {\n return $getOwnPropertyDescriptor(O, P);\n } catch (error) { /* empty */ }\n if (hasOwn(O, P)) return createPropertyDescriptor(!call(propertyIsEnumerableModule.f, O, P), O[P]);\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.invariant = invariant;\nfunction invariant(condition, format) {\n for (var _len = arguments.length, args = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {\n args[_key - 2] = arguments[_key];\n }\n if (isProduction()) {\n if (format === undefined) {\n throw new Error('invariant requires an error message argument');\n }\n }\n if (!condition) {\n var error;\n if (format === undefined) {\n error = new Error('Minified exception occurred; use the non-minified dev environment ' + 'for the full error message and additional helpful warnings.');\n } else {\n var argIndex = 0;\n error = new Error(format.replace(/%s/g, function () {\n return args[argIndex++];\n }));\n error.name = 'Invariant Violation';\n }\n error.framesToPop = 1 // we don't care about invariant's own frame\n ;\n\n throw error;\n }\n}\nfunction isProduction() {\n return typeof process !== 'undefined' && process.env['NODE_ENV'] === 'production';\n}","import React, { useState, useLayoutEffect } from 'react'\n// Stripe\nimport { Elements } from '@stripe/react-stripe-js';\nimport { loadStripe } from '@stripe/stripe-js';\n\nconst StripeSDKLoader = ({ stripe_publishable_key, children }) => {\n const [sdkLoaded, setSdkLoaded] = useState(false);\n const [stripe, setStripe] = useState(null);\n // const [options, setOptions] = useState(null);\n\n useLayoutEffect(() => {\n const promise = loadStripe(stripe_publishable_key)\n // const options = {\n // mode: 'payment',\n // currency: 'usd',\n // amount: 1099,\n // };\n setStripe(promise)\n setSdkLoaded(true)\n // setOptions(options)\n }, [])\n\n return (\n sdkLoaded ? (\n
\n {children}\n \n ) : (\n
Loading ...
\n )\n )\n}\nexport { StripeSDKLoader }","function r(n) {\n var e = n.parentElement,\n l = null;\n for (; e && !(e instanceof HTMLFieldSetElement);) e instanceof HTMLLegendElement && (l = e), e = e.parentElement;\n var t = (e == null ? void 0 : e.getAttribute(\"disabled\")) === \"\";\n return t && i(l) ? !1 : t;\n}\nfunction i(n) {\n if (!n) return !1;\n var e = n.previousElementSibling;\n for (; e !== null;) {\n if (e instanceof HTMLLegendElement) return !1;\n e = e.previousElementSibling;\n }\n return !0;\n}\nexport { r as isDisabledReactIssue7711 };","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar _exportNames = {};\nvar _indexJs = _interopRequireWildcard(require(\"./types/index.js\"));\nObject.keys(_indexJs).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _indexJs[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _indexJs[key];\n }\n });\n});\nvar _indexJs1 = _interopRequireWildcard(require(\"./core/index.js\"));\nObject.keys(_indexJs1).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _indexJs1[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _indexJs1[key];\n }\n });\n});\nvar _indexJs2 = _interopRequireWildcard(require(\"./hooks/index.js\"));\nObject.keys(_indexJs2).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _indexJs2[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _indexJs2[key];\n }\n });\n});\nfunction _interopRequireWildcard(obj) {\n if (obj && obj.__esModule) {\n return obj;\n } else {\n var newObj = {};\n if (obj != null) {\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {};\n if (desc.get || desc.set) {\n Object.defineProperty(newObj, key, desc);\n } else {\n newObj[key] = obj[key];\n }\n }\n }\n }\n newObj.default = obj;\n return newObj;\n }\n}","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nmodule.exports = uncurryThis({}.isPrototypeOf);\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this-clause');\nvar aCallable = require('../internals/a-callable');\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar bind = uncurryThis(uncurryThis.bind);\n\n// optional / simple context binding\nmodule.exports = function (fn, that) {\n aCallable(fn);\n return that === undefined ? fn : NATIVE_BIND ? bind(fn, that) : function (/* ...args */) {\n return fn.apply(that, arguments);\n };\n};\n","'use strict';\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nvar bind = require('./helpers/bind');\n\n/*global toString:true*/\n\n// utils is a library of generic helper functions non-specific to axios\n\nvar toString = Object.prototype.toString;\n\n/**\n * Determine if a value is an Array\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Array, otherwise false\n */\nfunction isArray(val) {\n return toString.call(val) === '[object Array]';\n}\n\n/**\n * Determine if a value is undefined\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if the value is undefined, otherwise false\n */\nfunction isUndefined(val) {\n return typeof val === 'undefined';\n}\n\n/**\n * Determine if a value is a Buffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Buffer, otherwise false\n */\nfunction isBuffer(val) {\n return val !== null && !isUndefined(val) && val.constructor !== null && !isUndefined(val.constructor) && typeof val.constructor.isBuffer === 'function' && val.constructor.isBuffer(val);\n}\n\n/**\n * Determine if a value is an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an ArrayBuffer, otherwise false\n */\nfunction isArrayBuffer(val) {\n return toString.call(val) === '[object ArrayBuffer]';\n}\n\n/**\n * Determine if a value is a FormData\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an FormData, otherwise false\n */\nfunction isFormData(val) {\n return typeof FormData !== 'undefined' && val instanceof FormData;\n}\n\n/**\n * Determine if a value is a view on an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a view on an ArrayBuffer, otherwise false\n */\nfunction isArrayBufferView(val) {\n var result;\n if (typeof ArrayBuffer !== 'undefined' && ArrayBuffer.isView) {\n result = ArrayBuffer.isView(val);\n } else {\n result = val && val.buffer && val.buffer instanceof ArrayBuffer;\n }\n return result;\n}\n\n/**\n * Determine if a value is a String\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a String, otherwise false\n */\nfunction isString(val) {\n return typeof val === 'string';\n}\n\n/**\n * Determine if a value is a Number\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Number, otherwise false\n */\nfunction isNumber(val) {\n return typeof val === 'number';\n}\n\n/**\n * Determine if a value is an Object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Object, otherwise false\n */\nfunction isObject(val) {\n return val !== null && _typeof(val) === 'object';\n}\n\n/**\n * Determine if a value is a Date\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Date, otherwise false\n */\nfunction isDate(val) {\n return toString.call(val) === '[object Date]';\n}\n\n/**\n * Determine if a value is a File\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a File, otherwise false\n */\nfunction isFile(val) {\n return toString.call(val) === '[object File]';\n}\n\n/**\n * Determine if a value is a Blob\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Blob, otherwise false\n */\nfunction isBlob(val) {\n return toString.call(val) === '[object Blob]';\n}\n\n/**\n * Determine if a value is a Function\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Function, otherwise false\n */\nfunction isFunction(val) {\n return toString.call(val) === '[object Function]';\n}\n\n/**\n * Determine if a value is a Stream\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Stream, otherwise false\n */\nfunction isStream(val) {\n return isObject(val) && isFunction(val.pipe);\n}\n\n/**\n * Determine if a value is a URLSearchParams object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a URLSearchParams object, otherwise false\n */\nfunction isURLSearchParams(val) {\n return typeof URLSearchParams !== 'undefined' && val instanceof URLSearchParams;\n}\n\n/**\n * Trim excess whitespace off the beginning and end of a string\n *\n * @param {String} str The String to trim\n * @returns {String} The String freed of excess whitespace\n */\nfunction trim(str) {\n return str.replace(/^\\s*/, '').replace(/\\s*$/, '');\n}\n\n/**\n * Determine if we're running in a standard browser environment\n *\n * This allows axios to run in a web worker, and react-native.\n * Both environments support XMLHttpRequest, but not fully standard globals.\n *\n * web workers:\n * typeof window -> undefined\n * typeof document -> undefined\n *\n * react-native:\n * navigator.product -> 'ReactNative'\n * nativescript\n * navigator.product -> 'NativeScript' or 'NS'\n */\nfunction isStandardBrowserEnv() {\n if (typeof navigator !== 'undefined' && (navigator.product === 'ReactNative' || navigator.product === 'NativeScript' || navigator.product === 'NS')) {\n return false;\n }\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\n\n/**\n * Iterate over an Array or an Object invoking a function for each item.\n *\n * If `obj` is an Array callback will be called passing\n * the value, index, and complete array for each item.\n *\n * If 'obj' is an Object callback will be called passing\n * the value, key, and complete object for each property.\n *\n * @param {Object|Array} obj The object to iterate\n * @param {Function} fn The callback to invoke for each item\n */\nfunction forEach(obj, fn) {\n // Don't bother if no value provided\n if (obj === null || typeof obj === 'undefined') {\n return;\n }\n\n // Force an array if not already something iterable\n if (_typeof(obj) !== 'object') {\n /*eslint no-param-reassign:0*/\n obj = [obj];\n }\n if (isArray(obj)) {\n // Iterate over array values\n for (var i = 0, l = obj.length; i < l; i++) {\n fn.call(null, obj[i], i, obj);\n }\n } else {\n // Iterate over object keys\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n fn.call(null, obj[key], key, obj);\n }\n }\n }\n}\n\n/**\n * Accepts varargs expecting each argument to be an object, then\n * immutably merges the properties of each object and returns result.\n *\n * When multiple objects contain the same key the later object in\n * the arguments list will take precedence.\n *\n * Example:\n *\n * ```js\n * var result = merge({foo: 123}, {foo: 456});\n * console.log(result.foo); // outputs 456\n * ```\n *\n * @param {Object} obj1 Object to merge\n * @returns {Object} Result of all merge properties\n */\nfunction merge( /* obj1, obj2, obj3, ... */\n) {\n var result = {};\n function assignValue(val, key) {\n if (_typeof(result[key]) === 'object' && _typeof(val) === 'object') {\n result[key] = merge(result[key], val);\n } else {\n result[key] = val;\n }\n }\n for (var i = 0, l = arguments.length; i < l; i++) {\n forEach(arguments[i], assignValue);\n }\n return result;\n}\n\n/**\n * Function equal to merge with the difference being that no reference\n * to original objects is kept.\n *\n * @see merge\n * @param {Object} obj1 Object to merge\n * @returns {Object} Result of all merge properties\n */\nfunction deepMerge( /* obj1, obj2, obj3, ... */\n) {\n var result = {};\n function assignValue(val, key) {\n if (_typeof(result[key]) === 'object' && _typeof(val) === 'object') {\n result[key] = deepMerge(result[key], val);\n } else if (_typeof(val) === 'object') {\n result[key] = deepMerge({}, val);\n } else {\n result[key] = val;\n }\n }\n for (var i = 0, l = arguments.length; i < l; i++) {\n forEach(arguments[i], assignValue);\n }\n return result;\n}\n\n/**\n * Extends object a by mutably adding to it the properties of object b.\n *\n * @param {Object} a The object to be extended\n * @param {Object} b The object to copy properties from\n * @param {Object} thisArg The object to bind function to\n * @return {Object} The resulting value of object a\n */\nfunction extend(a, b, thisArg) {\n forEach(b, function assignValue(val, key) {\n if (thisArg && typeof val === 'function') {\n a[key] = bind(val, thisArg);\n } else {\n a[key] = val;\n }\n });\n return a;\n}\nmodule.exports = {\n isArray: isArray,\n isArrayBuffer: isArrayBuffer,\n isBuffer: isBuffer,\n isFormData: isFormData,\n isArrayBufferView: isArrayBufferView,\n isString: isString,\n isNumber: isNumber,\n isObject: isObject,\n isUndefined: isUndefined,\n isDate: isDate,\n isFile: isFile,\n isBlob: isBlob,\n isFunction: isFunction,\n isStream: isStream,\n isURLSearchParams: isURLSearchParams,\n isStandardBrowserEnv: isStandardBrowserEnv,\n forEach: forEach,\n merge: merge,\n deepMerge: deepMerge,\n extend: extend,\n trim: trim\n};","\"use client\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nvar _excluded = [\"enabled\"],\n _excluded2 = [\"target\"];\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport f, { Fragment as g, createContext as E, useContext as T, useEffect as R, useMemo as c, useRef as A, useState as G } from \"react\";\nimport { createPortal as H } from \"react-dom\";\nimport { useEvent as L } from '../../hooks/use-event.js';\nimport { useIsoMorphicEffect as x } from '../../hooks/use-iso-morphic-effect.js';\nimport { useOnUnmount as O } from '../../hooks/use-on-unmount.js';\nimport { useOwnerDocument as _ } from '../../hooks/use-owner.js';\nimport { useServerHandoffComplete as h } from '../../hooks/use-server-handoff-complete.js';\nimport { optionalRef as F, useSyncRefs as P } from '../../hooks/use-sync-refs.js';\nimport { usePortalRoot as U } from '../../internal/portal-force-root.js';\nimport { env as C } from '../../utils/env.js';\nimport { forwardRefWithAs as m, render as d } from '../../utils/render.js';\nfunction D(p) {\n var r = U(),\n l = T(v),\n e = _(p),\n _G = G(function () {\n var t;\n if (!r && l !== null) return (t = l.current) != null ? t : null;\n if (C.isServer) return null;\n var u = e == null ? void 0 : e.getElementById(\"headlessui-portal-root\");\n if (u) return u;\n if (e === null) return null;\n var a = e.createElement(\"div\");\n return a.setAttribute(\"id\", \"headlessui-portal-root\"), e.body.appendChild(a);\n }),\n _G2 = _slicedToArray(_G, 2),\n o = _G2[0],\n n = _G2[1];\n return R(function () {\n o !== null && (e != null && e.body.contains(o) || e == null || e.body.appendChild(o));\n }, [o, e]), R(function () {\n r || l !== null && n(l.current);\n }, [l, n, r]), o;\n}\nvar M = g,\n N = m(function (r, l) {\n var e = r,\n o = A(null),\n n = P(F(function (i) {\n o.current = i;\n }), l),\n u = _(o),\n a = D(o),\n _G3 = G(function () {\n var i;\n return C.isServer ? null : (i = u == null ? void 0 : u.createElement(\"div\")) != null ? i : null;\n }),\n _G4 = _slicedToArray(_G3, 1),\n t = _G4[0],\n s = T(y),\n b = h();\n return x(function () {\n !a || !t || a.contains(t) || (t.setAttribute(\"data-headlessui-portal\", \"\"), a.appendChild(t));\n }, [a, t]), x(function () {\n if (t && s) return s.register(t);\n }, [s, t]), O(function () {\n var i;\n !a || !t || (t instanceof Node && a.contains(t) && a.removeChild(t), a.childNodes.length <= 0 && ((i = a.parentElement) == null || i.removeChild(a)));\n }), b ? !a || !t ? null : /*#__PURE__*/H(d({\n ourProps: {\n ref: n\n },\n theirProps: e,\n slot: {},\n defaultTag: M,\n name: \"Portal\"\n }), t) : null;\n });\nfunction S(p, r) {\n var l = P(r),\n _p$enabled = p.enabled,\n e = _p$enabled === void 0 ? !0 : _p$enabled,\n o = _objectWithoutProperties(p, _excluded);\n return e ? /*#__PURE__*/f.createElement(N, _objectSpread(_objectSpread({}, o), {}, {\n ref: l\n })) : d({\n ourProps: {\n ref: l\n },\n theirProps: o,\n slot: {},\n defaultTag: M,\n name: \"Portal\"\n });\n}\nvar j = g,\n v = /*#__PURE__*/E(null);\nfunction W(p, r) {\n var l = p.target,\n e = _objectWithoutProperties(p, _excluded2),\n n = {\n ref: P(r)\n };\n return /*#__PURE__*/f.createElement(v.Provider, {\n value: l\n }, d({\n ourProps: n,\n theirProps: e,\n defaultTag: j,\n name: \"Popover.Group\"\n }));\n}\nvar y = /*#__PURE__*/E(null);\nfunction ee() {\n var p = T(y),\n r = A([]),\n l = L(function (n) {\n return r.current.push(n), p && p.register(n), function () {\n return e(n);\n };\n }),\n e = L(function (n) {\n var u = r.current.indexOf(n);\n u !== -1 && r.current.splice(u, 1), p && p.unregister(n);\n }),\n o = c(function () {\n return {\n register: l,\n unregister: e,\n portals: r\n };\n }, [l, e, r]);\n return [r, c(function () {\n return function (_ref) {\n var u = _ref.children;\n return /*#__PURE__*/f.createElement(y.Provider, {\n value: o\n }, u);\n };\n }, [o])];\n}\nvar I = m(S),\n J = m(W),\n te = Object.assign(I, {\n Group: J\n });\nexport { te as Portal, J as PortalGroup, ee as useNestedPortals };","'use strict';\n\nvar vanilla = require('zustand/vanilla');\nvar react$1 = require('react');\nvar useSyncExternalStoreExports = require('use-sync-external-store/shim/with-selector');\nvar useSyncExternalStoreWithSelector = useSyncExternalStoreExports.useSyncExternalStoreWithSelector;\nvar didWarnAboutEqualityFn = false;\nfunction useStore(api, selector, equalityFn) {\n if (selector === void 0) {\n selector = api.getState;\n }\n if (process.env.NODE_ENV !== 'production' && equalityFn && !didWarnAboutEqualityFn) {\n console.warn(\"[DEPRECATED] Use `createWithEqualityFn` instead of `create` or use `useStoreWithEqualityFn` instead of `useStore`. They can be imported from 'zustand/traditional'. https://github.com/pmndrs/zustand/discussions/1937\");\n didWarnAboutEqualityFn = true;\n }\n var slice = useSyncExternalStoreWithSelector(api.subscribe, api.getState, api.getServerState || api.getState, selector, equalityFn);\n react$1.useDebugValue(slice);\n return slice;\n}\nvar createImpl = function createImpl(createState) {\n if (process.env.NODE_ENV !== 'production' && typeof createState !== 'function') {\n console.warn(\"[DEPRECATED] Passing a vanilla store will be unsupported in a future version. Instead use `import { useStore } from 'zustand'`.\");\n }\n var api = typeof createState === 'function' ? vanilla.createStore(createState) : createState;\n var useBoundStore = function useBoundStore(selector, equalityFn) {\n return useStore(api, selector, equalityFn);\n };\n Object.assign(useBoundStore, api);\n return useBoundStore;\n};\nvar create = function create(createState) {\n return createState ? createImpl(createState) : createImpl;\n};\nvar react = function react(createState) {\n if (process.env.NODE_ENV !== 'production') {\n console.warn(\"[DEPRECATED] Default export is deprecated. Instead use `import { create } from 'zustand'`.\");\n }\n return create(createState);\n};\nexports.create = create;\nexports.default = react;\nexports.useStore = useStore;\nObject.keys(vanilla).forEach(function (k) {\n if (k !== 'default' && !Object.prototype.hasOwnProperty.call(exports, k)) Object.defineProperty(exports, k, {\n enumerable: true,\n get: function get() {\n return vanilla[k];\n }\n });\n});\nmodule.exports = react;\nmodule.exports.create = create;\nmodule.exports.useStore = useStore;\nmodule.exports.createStore = vanilla.createStore;\nexports.default = module.exports;","/**\n * Calculate stripe fee from amount\n * so you can charge stripe fee to customers\n * lafif
\n */\nvar fees = {\n non_profit: {\n Percent: 2.2,\n Fixed: 0.3,\n },\n USD: {\n Percent: 2.9,\n Fixed: 0.3,\n },\n GBP: {\n Percent: 2.4,\n Fixed: 0.2,\n },\n EUR: {\n Percent: 2.4,\n Fixed: 0.24,\n },\n CAD: {\n Percent: 2.9,\n Fixed: 0.3,\n },\n AUD: {\n Percent: 2.9,\n Fixed: 0.3,\n },\n NOK: {\n Percent: 2.9,\n Fixed: 2,\n },\n DKK: {\n Percent: 2.9,\n Fixed: 1.8,\n },\n SEK: {\n Percent: 2.9,\n Fixed: 1.8,\n },\n JPY: {\n Percent: 3.6,\n Fixed: 0,\n },\n MXN: {\n Percent: 3.6,\n Fixed: 3,\n },\n};\n\nexport function calcFee(amount, feeModel, autoPay = false, offline = false) {\n if (feeModel.percent_structure_enabled) {\n return calcNewFee(amount, feeModel, autoPay, offline);\n } else {\n return calcOldFee(amount, feeModel, autoPay, offline);\n }\n}\n\nfunction calcNewFee(amount, feeModel, autoPay = false, offline) {\n var _fee = feeModel;\n\n const subscriptionPercent = parseFloat(\n (parseFloat(_fee.subscription_percent) + parseFloat(_fee.percent)) / 100\n ); // 0.5% fee for subs\n const singleChargePercent = parseFloat(_fee.percent / 100);\n\n if (feeModel.fee_type === \"union_pays\" || offline == true) {\n return {\n amount: amount,\n stripeFee: 0,\n unionlyFee: 0,\n totalFee: 0,\n total: !!amount ? amount.toFixed(2) : amount,\n };\n }\n\n const amount_cents = amount * 100;\n\n const unionlyFee =\n (amount_cents * (parseFloat(feeModel.ecommerce_percent) / 100.0)) / 100.0;\n\n var amount_with_unionly_fee = parseFloat(amount) + unionlyFee;\n\n var totalWithUnionlyFees =\n (amount_with_unionly_fee + parseFloat(_fee.fixed)) /\n (1 - parseFloat(_fee.percent) / 100);\n\n var subscriptionTotalWithUnionlyFees =\n (amount_with_unionly_fee + parseFloat(_fee.fixed)) /\n (1 - subscriptionPercent);\n\n var total = autoPay\n ? subscriptionTotalWithUnionlyFees // need to call toFixed or we are short\n : totalWithUnionlyFees;\n\n var stripeFee = total - amount_with_unionly_fee;\n var totalFee = total - amount;\n\n return {\n amount: amount,\n stripeFee: stripeFee.toFixed(2),\n unionlyFee: unionlyFee.toFixed(2),\n totalFee: totalFee.toFixed(2),\n total: total.toFixed(2),\n };\n}\n\nfunction calcOldFee(amount, feeModel, autoPay = false, offline) {\n var _fee = feeModel;\n const subscriptionPercent = parseFloat(\n (parseFloat(_fee.subscription_percent) + parseFloat(_fee.percent)) / 100\n ); // 0.5% fee for subs\n const singleChargePercent = parseFloat(_fee.percent / 100);\n\n if (feeModel.fee_type === \"union_pays\" || offline) {\n return {\n amount: amount,\n stripeFee: 0,\n unionlyFee: 0,\n totalFee: 0,\n total: !!amount ? amount.toFixed(2) : amount,\n };\n }\n\n var amount_with_unionly_fee = parseFloat(\n amount + parseFloat(feeModel.unionly_fee) / 100.0\n );\n\n var totalWithUnionlyFees =\n (amount_with_unionly_fee + parseFloat(_fee.fixed)) /\n (1 - parseFloat(_fee.percent) / 100);\n\n var subscriptionTotalWithUnionlyFees =\n (amount_with_unionly_fee + parseFloat(_fee.fixed)) /\n (1 - subscriptionPercent);\n\n var total = autoPay\n ? subscriptionTotalWithUnionlyFees // need to call toFixed or we are short\n : totalWithUnionlyFees;\n\n var stripeFee = total - amount_with_unionly_fee;\n var totalFee = total - amount;\n\n return {\n amount: amount,\n stripeFee: stripeFee.toFixed(2),\n unionlyFee: feeModel.unionly_fee.toFixed(2),\n totalFee: totalFee.toFixed(2),\n total: total.toFixed(2),\n };\n}\n","'use strict';\nmodule.exports = function (bitmap, value) {\n return {\n enumerable: !(bitmap & 1),\n configurable: !(bitmap & 2),\n writable: !(bitmap & 4),\n value: value\n };\n};\n","'use strict';\n// we can't use just `it == null` since of `document.all` special case\n// https://tc39.es/ecma262/#sec-IsHTMLDDA-internal-slot-aec\nmodule.exports = function (it) {\n return it === null || it === undefined;\n};\n","'use strict';\nvar hasOwn = require('../internals/has-own-property');\nvar isCallable = require('../internals/is-callable');\nvar toObject = require('../internals/to-object');\nvar sharedKey = require('../internals/shared-key');\nvar CORRECT_PROTOTYPE_GETTER = require('../internals/correct-prototype-getter');\n\nvar IE_PROTO = sharedKey('IE_PROTO');\nvar $Object = Object;\nvar ObjectPrototype = $Object.prototype;\n\n// `Object.getPrototypeOf` method\n// https://tc39.es/ecma262/#sec-object.getprototypeof\n// eslint-disable-next-line es/no-object-getprototypeof -- safe\nmodule.exports = CORRECT_PROTOTYPE_GETTER ? $Object.getPrototypeOf : function (O) {\n var object = toObject(O);\n if (hasOwn(object, IE_PROTO)) return object[IE_PROTO];\n var constructor = object.constructor;\n if (isCallable(constructor) && object instanceof constructor) {\n return constructor.prototype;\n } return object instanceof $Object ? ObjectPrototype : null;\n};\n","'use strict';\nvar bind = require('../internals/function-bind-context');\nvar call = require('../internals/function-call');\nvar anObject = require('../internals/an-object');\nvar tryToString = require('../internals/try-to-string');\nvar isArrayIteratorMethod = require('../internals/is-array-iterator-method');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar getIterator = require('../internals/get-iterator');\nvar getIteratorMethod = require('../internals/get-iterator-method');\nvar iteratorClose = require('../internals/iterator-close');\n\nvar $TypeError = TypeError;\n\nvar Result = function (stopped, result) {\n this.stopped = stopped;\n this.result = result;\n};\n\nvar ResultPrototype = Result.prototype;\n\nmodule.exports = function (iterable, unboundFunction, options) {\n var that = options && options.that;\n var AS_ENTRIES = !!(options && options.AS_ENTRIES);\n var IS_RECORD = !!(options && options.IS_RECORD);\n var IS_ITERATOR = !!(options && options.IS_ITERATOR);\n var INTERRUPTED = !!(options && options.INTERRUPTED);\n var fn = bind(unboundFunction, that);\n var iterator, iterFn, index, length, result, next, step;\n\n var stop = function (condition) {\n if (iterator) iteratorClose(iterator, 'normal', condition);\n return new Result(true, condition);\n };\n\n var callFn = function (value) {\n if (AS_ENTRIES) {\n anObject(value);\n return INTERRUPTED ? fn(value[0], value[1], stop) : fn(value[0], value[1]);\n } return INTERRUPTED ? fn(value, stop) : fn(value);\n };\n\n if (IS_RECORD) {\n iterator = iterable.iterator;\n } else if (IS_ITERATOR) {\n iterator = iterable;\n } else {\n iterFn = getIteratorMethod(iterable);\n if (!iterFn) throw new $TypeError(tryToString(iterable) + ' is not iterable');\n // optimisation for array iterators\n if (isArrayIteratorMethod(iterFn)) {\n for (index = 0, length = lengthOfArrayLike(iterable); length > index; index++) {\n result = callFn(iterable[index]);\n if (result && isPrototypeOf(ResultPrototype, result)) return result;\n } return new Result(false);\n }\n iterator = getIterator(iterable, iterFn);\n }\n\n next = IS_RECORD ? iterable.next : iterator.next;\n while (!(step = call(next, iterator)).done) {\n try {\n result = callFn(step.value);\n } catch (error) {\n iteratorClose(iterator, 'throw', error);\n }\n if (typeof result == 'object' && result && isPrototypeOf(ResultPrototype, result)) return result;\n } return new Result(false);\n};\n","'use strict';\nvar aCallable = require('../internals/a-callable');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\n\n// `GetMethod` abstract operation\n// https://tc39.es/ecma262/#sec-getmethod\nmodule.exports = function (V, P) {\n var func = V[P];\n return isNullOrUndefined(func) ? undefined : aCallable(func);\n};\n","'use strict';\nvar bind = require('../internals/function-bind-context');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar IndexedObject = require('../internals/indexed-object');\nvar toObject = require('../internals/to-object');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar arraySpeciesCreate = require('../internals/array-species-create');\n\nvar push = uncurryThis([].push);\n\n// `Array.prototype.{ forEach, map, filter, some, every, find, findIndex, filterReject }` methods implementation\nvar createMethod = function (TYPE) {\n var IS_MAP = TYPE === 1;\n var IS_FILTER = TYPE === 2;\n var IS_SOME = TYPE === 3;\n var IS_EVERY = TYPE === 4;\n var IS_FIND_INDEX = TYPE === 6;\n var IS_FILTER_REJECT = TYPE === 7;\n var NO_HOLES = TYPE === 5 || IS_FIND_INDEX;\n return function ($this, callbackfn, that, specificCreate) {\n var O = toObject($this);\n var self = IndexedObject(O);\n var length = lengthOfArrayLike(self);\n var boundFunction = bind(callbackfn, that);\n var index = 0;\n var create = specificCreate || arraySpeciesCreate;\n var target = IS_MAP ? create($this, length) : IS_FILTER || IS_FILTER_REJECT ? create($this, 0) : undefined;\n var value, result;\n for (;length > index; index++) if (NO_HOLES || index in self) {\n value = self[index];\n result = boundFunction(value, index, O);\n if (TYPE) {\n if (IS_MAP) target[index] = result; // map\n else if (result) switch (TYPE) {\n case 3: return true; // some\n case 5: return value; // find\n case 6: return index; // findIndex\n case 2: push(target, value); // filter\n } else switch (TYPE) {\n case 4: return false; // every\n case 7: push(target, value); // filterReject\n }\n }\n }\n return IS_FIND_INDEX ? -1 : IS_SOME || IS_EVERY ? IS_EVERY : target;\n };\n};\n\nmodule.exports = {\n // `Array.prototype.forEach` method\n // https://tc39.es/ecma262/#sec-array.prototype.foreach\n forEach: createMethod(0),\n // `Array.prototype.map` method\n // https://tc39.es/ecma262/#sec-array.prototype.map\n map: createMethod(1),\n // `Array.prototype.filter` method\n // https://tc39.es/ecma262/#sec-array.prototype.filter\n filter: createMethod(2),\n // `Array.prototype.some` method\n // https://tc39.es/ecma262/#sec-array.prototype.some\n some: createMethod(3),\n // `Array.prototype.every` method\n // https://tc39.es/ecma262/#sec-array.prototype.every\n every: createMethod(4),\n // `Array.prototype.find` method\n // https://tc39.es/ecma262/#sec-array.prototype.find\n find: createMethod(5),\n // `Array.prototype.findIndex` method\n // https://tc39.es/ecma262/#sec-array.prototype.findIndex\n findIndex: createMethod(6),\n // `Array.prototype.filterReject` method\n // https://github.com/tc39/proposal-array-filtering\n filterReject: createMethod(7)\n};\n","import n, { createContext as d, useContext as i } from \"react\";\nvar e = /*#__PURE__*/d(void 0);\nfunction u() {\n return i(e);\n}\nfunction f(_ref) {\n var t = _ref.id,\n r = _ref.children;\n return /*#__PURE__*/n.createElement(e.Provider, {\n value: t\n }, r);\n}\nexport { f as IdProvider, u as useProvidedId };","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { useRef as a, useState as m } from \"react\";\nimport { getOwnerDocument as d } from '../utils/owner.js';\nimport { useDisposables as g } from './use-disposables.js';\nimport { useEvent as u } from './use-event.js';\nfunction E(e) {\n var t = e.width / 2,\n n = e.height / 2;\n return {\n top: e.clientY - n,\n right: e.clientX + t,\n bottom: e.clientY + n,\n left: e.clientX - t\n };\n}\nfunction P(e, t) {\n return !(!e || !t || e.right < t.left || e.left > t.right || e.bottom < t.top || e.top > t.bottom);\n}\nfunction w() {\n var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n _ref$disabled = _ref.disabled,\n e = _ref$disabled === void 0 ? !1 : _ref$disabled;\n var t = a(null),\n _m = m(!1),\n _m2 = _slicedToArray(_m, 2),\n n = _m2[0],\n l = _m2[1],\n r = g(),\n o = u(function () {\n t.current = null, l(!1), r.dispose();\n }),\n f = u(function (s) {\n if (r.dispose(), t.current === null) {\n t.current = s.currentTarget, l(!0);\n {\n var i = d(s.currentTarget);\n r.addEventListener(i, \"pointerup\", o, !1), r.addEventListener(i, \"pointermove\", function (c) {\n if (t.current) {\n var p = E(c);\n l(P(p, t.current.getBoundingClientRect()));\n }\n }, !1), r.addEventListener(i, \"pointercancel\", o, !1);\n }\n }\n });\n return {\n pressed: n,\n pressProps: e ? {} : {\n onPointerDown: f,\n onPointerUp: o,\n onClick: o\n }\n };\n}\nexport { w as useActivePress };","import { useMemo as a } from \"react\";\nfunction e(t, u) {\n return a(function () {\n var n;\n if (t.type) return t.type;\n var r = (n = t.as) != null ? n : \"button\";\n if (typeof r == \"string\" && r.toLowerCase() === \"button\" || (u == null ? void 0 : u.tagName) === \"BUTTON\" && !u.hasAttribute(\"type\")) return \"button\";\n }, [t.type, t.as, u]);\n}\nexport { e as useResolveButtonType };","import React, { useContext, createContext, useReducer } from 'react';\n\nconst initialState = {\n hour: '',\n minute: '',\n ampm: '',\n day: 'Friday',\n frequency: 'daily',\n timezone: Intl.DateTimeFormat().resolvedOptions().timeZone,\n};\n\nconst formSettingsReducer = (state, action) => {\n switch (action.type) {\n case 'SET_HOUR':\n return {\n ...state,\n hour: action.hour,\n };\n case 'SET_MINUTE':\n return {\n ...state,\n minute: action.minute,\n };\n case 'SET_AMPM':\n return {\n ...state,\n ampm: action.ampm,\n };\n case 'SET_DAY':\n return {\n ...state,\n day: action.day,\n };\n case 'SET_FREQUENCY':\n return {\n ...state,\n frequency: action.frequency,\n };\n case 'SET_TIMEZONE':\n return {\n ...state,\n timezone: action.timezone,\n };\n default:\n return state;\n }\n};\n\nconst ScheduledReportContaxt = createContext(null);\n\nexport const useFields = () => {\n const [state, dispatch] = useContext(ScheduledReportContaxt);\n\n //\n // \"property\" param can be one of \"hour\", \"minute\", \"ampm\"\n const setTime = (val, property) => {\n dispatch({\n type: `SET_${property.toUpperCase()}`,\n [property]: val,\n });\n };\n\n const setDay = (day) => {\n dispatch({\n type: 'SET_DAY',\n day,\n });\n };\n\n const setFrequency = (frequency) => {\n dispatch({\n type: 'SET_FREQUENCY',\n frequency,\n });\n };\n\n const setTimeZone = (timezone) => {\n dispatch({\n type: 'SET_TIMEZONE',\n timezone,\n });\n };\n\n return {\n state,\n dispatch,\n setTime,\n setDay,\n setFrequency,\n setTimeZone,\n getTimeFromModel,\n };\n};\n\nexport const getTimeFromModel = (method, model) => {\n const time = model.time.replace(':', ' ').split(' ');\n\n switch (method) {\n case 'hour':\n return time[0];\n case 'minute':\n return time[1];\n case 'ampm':\n return time[2];\n default:\n return model.time;\n }\n};\n\nexport const ScheduledReportProvider = (props) => {\n const { model, modelName, errors } = props;\n\n const [state, dispatch] = useReducer(formSettingsReducer, {\n ...initialState,\n model,\n modelName,\n errors,\n hour: getTimeFromModel('hour', model),\n minute: getTimeFromModel('minute', model),\n ampm: getTimeFromModel('ampm', model),\n frequency: model.frequency,\n });\n\n const value = React.useMemo(() => [state, dispatch], [state]);\n\n return ;\n};\n","'use strict';\nvar path = require('../internals/path');\nvar hasOwn = require('../internals/has-own-property');\nvar wrappedWellKnownSymbolModule = require('../internals/well-known-symbol-wrapped');\nvar defineProperty = require('../internals/object-define-property').f;\n\nmodule.exports = function (NAME) {\n var Symbol = path.Symbol || (path.Symbol = {});\n if (!hasOwn(Symbol, NAME)) defineProperty(Symbol, NAME, {\n value: wrappedWellKnownSymbolModule.f(NAME)\n });\n};\n","import React, { useContext, createContext, useReducer } from 'react';\nimport { generateId } from '../../utils/genIds';\n\nconst newField = {\n id: null,\n objectId: null,\n label: '',\n field_type: '',\n required: false,\n destroy: false,\n};\n\nconst newDropdownOption = {\n id: null,\n objectId: null,\n fieldObjectId: null,\n value: '',\n destroy: false,\n};\n\nconst initialState = {\n resource: {\n include_address_fields: false,\n require_address_fields: false,\n },\n resource_name: '',\n fields: [],\n};\n\nconst fieldsReducer = (state, action) => {\n switch (action.type) {\n case 'ADD_FIELD':\n return { ...state, fields: [...state.fields, action.field] };\n case 'ADD_DROPDOWN_OPTION':\n return {\n ...state,\n dropdown_options: [...state.dropdown_options, action.dropdownOption],\n };\n case 'SET_DROPDOWN_OPTIONS':\n return { ...state, dropdown_options: action.dropdownOptions };\n case 'SET_FIELDS':\n return { ...state, fields: action.fields };\n case 'TOGGLE_ADDRESS_FIELDS':\n return { ...state, resource: { ...state.resource, ...action.addressFields } };\n default:\n return state;\n }\n};\n\nconst FieldsContext = createContext(null);\n\nexport const useFields = () => {\n const [state, dispatch] = useContext(FieldsContext);\n\n const addField = () => {\n dispatch({\n type: 'ADD_FIELD',\n field: { ...newField, objectId: generateId() },\n });\n };\n\n const removeField = (field) => {\n // const dueLevels = state.dueLevels\n // remove a due level if it does exist\n // toggle destroy a due level if it does exist\n if (field.id === null) {\n const newfields = state.fields.filter(\n (f) => f.objectId != field.objectId\n );\n dispatch({ type: 'SET_FIELDS', fields: newfields });\n } else {\n const newfields = state.fields.map((f) => {\n if (f.objectId === field.objectId) {\n return { ...f, destroy: true };\n } else {\n return { ...f };\n }\n });\n dispatch({ type: 'SET_FIELDS', fields: newfields });\n }\n };\n\n const toggleAddressFields = (shouldInclude) => {\n if (shouldInclude) {\n dispatch({\n type: 'TOGGLE_ADDRESS_FIELDS',\n addressFields: { include_address_fields: shouldInclude },\n });\n } else {\n dispatch({\n type: 'TOGGLE_ADDRESS_FIELDS',\n addressFields: {\n include_address_fields: shouldInclude,\n require_address_fields: shouldInclude,\n },\n });\n }\n };\n\n const toggleRequireAddressFields = (shouldRequire) => {\n dispatch({\n type: 'TOGGLE_ADDRESS_FIELDS',\n addressFields: {\n require_address_fields: shouldRequire,\n },\n });\n };\n\n const setFieldType = (field, input_type) => {\n const newFields = state.fields.map((f) => {\n if (f.objectId === field.objectId) return { ...f, input_type };\n\n return { ...f };\n });\n dispatch({ type: 'SET_FIELDS', fields: newFields });\n\n if (input_type === 'drop down') {\n const dropdownOption = {\n ...newDropdownOption,\n fieldObjectId: field.objectId,\n };\n dispatch({\n type: 'ADD_DROPDOWN_OPTION',\n dropdownOption,\n });\n }\n };\n\n const addOption = (field) => {\n dispatch({\n type: 'ADD_DROPDOWN_OPTION',\n dropdownOption: { ...newDropdownOption, fieldObjectId: field.objectId },\n });\n };\n\n const removeOption = (option) => {\n if (option.id === null) {\n const newOptions = state.dropdown_options.filter(\n (o) => o.objectId != option.objectId\n );\n dispatch({ type: 'SET_DROPDOWN_OPTIONS', dropdownOptions: newOptions });\n } else {\n const newOptions = state.dropdown_options.map((o) => {\n if (o.objectId === option.objectId) {\n return { ...o, destroy: true };\n } else {\n return { ...o };\n }\n });\n dispatch({\n type: 'SET_DROPDOWN_OPTIONS',\n dropdownOptions: newOptions,\n });\n }\n };\n\n return {\n state,\n dispatch,\n addField,\n removeField,\n toggleAddressFields,\n toggleRequireAddressFields,\n setFieldType,\n removeOption,\n addOption,\n };\n};\n\nexport const FieldsProvider = (props) => {\n // added the form state\n\n const [state, dispatch] = useReducer(fieldsReducer, {\n ...initialState,\n resource: props.resource,\n resource_name: props.resource_name,\n fields: props.fields || [],\n dropdown_options: props.dropdown_options || [],\n input_types: props.input_types,\n });\n\n const value = React.useMemo(() => [state, dispatch], [state]);\n\n return ;\n};\n","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _get() { if (typeof Reflect !== \"undefined\" && Reflect.get) { _get = Reflect.get.bind(); } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(arguments.length < 3 ? target : receiver); } return desc.value; }; } return _get.apply(this, arguments); }\nfunction _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; }\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, \"prototype\", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } else if (call !== void 0) { throw new TypeError(\"Derived constructors may only return object or undefined\"); } return _assertThisInitialized(self); }\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\nfunction _wrapNativeSuper(Class) { var _cache = typeof Map === \"function\" ? new Map() : undefined; _wrapNativeSuper = function _wrapNativeSuper(Class) { if (Class === null || !_isNativeFunction(Class)) return Class; if (typeof Class !== \"function\") { throw new TypeError(\"Super expression must either be null or a function\"); } if (typeof _cache !== \"undefined\") { if (_cache.has(Class)) return _cache.get(Class); _cache.set(Class, Wrapper); } function Wrapper() { return _construct(Class, arguments, _getPrototypeOf(this).constructor); } Wrapper.prototype = Object.create(Class.prototype, { constructor: { value: Wrapper, enumerable: false, writable: true, configurable: true } }); return _setPrototypeOf(Wrapper, Class); }; return _wrapNativeSuper(Class); }\nfunction _construct(Parent, args, Class) { if (_isNativeReflectConstruct()) { _construct = Reflect.construct.bind(); } else { _construct = function _construct(Parent, args, Class) { var a = [null]; a.push.apply(a, args); var Constructor = Function.bind.apply(Parent, a); var instance = new Constructor(); if (Class) _setPrototypeOf(instance, Class.prototype); return instance; }; } return _construct.apply(null, arguments); }\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\nfunction _isNativeFunction(fn) { return Function.toString.call(fn).indexOf(\"[native code]\") !== -1; }\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\nvar a = /*#__PURE__*/function (_Map) {\n _inherits(a, _Map);\n var _super = _createSuper(a);\n function a(t) {\n var _this;\n _classCallCheck(this, a);\n _this = _super.call(this);\n _this.factory = t;\n return _this;\n }\n _createClass(a, [{\n key: \"get\",\n value: function get(t) {\n var e = _get(_getPrototypeOf(a.prototype), \"get\", this).call(this, t);\n return e === void 0 && (e = this.factory(t), this.set(t, e)), e;\n }\n }]);\n return a;\n}( /*#__PURE__*/_wrapNativeSuper(Map));\nexport { a as DefaultMap };","function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nimport { useId as n } from \"react\";\nimport { DefaultMap as f } from '../utils/default-map.js';\nimport { createStore as u } from '../utils/store.js';\nimport { useIsoMorphicEffect as c } from './use-iso-morphic-effect.js';\nimport { useStore as l } from './use-store.js';\nvar p = new f(function () {\n return u(function () {\n return [];\n }, {\n ADD: function ADD(r) {\n return this.includes(r) ? this : [].concat(_toConsumableArray(this), [r]);\n },\n REMOVE: function REMOVE(r) {\n var e = this.indexOf(r);\n if (e === -1) return this;\n var t = this.slice();\n return t.splice(e, 1), t;\n }\n });\n});\nfunction x(r, e) {\n var t = p.get(e),\n i = n(),\n h = l(t);\n if (c(function () {\n if (r) return t.dispatch(\"ADD\", i), function () {\n return t.dispatch(\"REMOVE\", i);\n };\n }, [t, r]), !r) return !1;\n var s = h.indexOf(i),\n o = h.length;\n return s === -1 && (s = o, o += 1), s === o - 1;\n}\nexport { x as useIsTopLayer };","function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nvar i = Object.defineProperty;\nvar d = function d(t, e, n) {\n return e in t ? i(t, e, {\n enumerable: !0,\n configurable: !0,\n writable: !0,\n value: n\n }) : t[e] = n;\n};\nvar r = function r(t, e, n) {\n return d(t, _typeof(e) != \"symbol\" ? e + \"\" : e, n), n;\n};\nvar o = /*#__PURE__*/function () {\n function o() {\n _classCallCheck(this, o);\n r(this, \"current\", this.detect());\n r(this, \"handoffState\", \"pending\");\n r(this, \"currentId\", 0);\n }\n _createClass(o, [{\n key: \"set\",\n value: function set(e) {\n this.current !== e && (this.handoffState = \"pending\", this.currentId = 0, this.current = e);\n }\n }, {\n key: \"reset\",\n value: function reset() {\n this.set(this.detect());\n }\n }, {\n key: \"nextId\",\n value: function nextId() {\n return ++this.currentId;\n }\n }, {\n key: \"isServer\",\n get: function get() {\n return this.current === \"server\";\n }\n }, {\n key: \"isClient\",\n get: function get() {\n return this.current === \"client\";\n }\n }, {\n key: \"detect\",\n value: function detect() {\n return typeof window == \"undefined\" || typeof document == \"undefined\" ? \"server\" : \"client\";\n }\n }, {\n key: \"handoff\",\n value: function handoff() {\n this.handoffState === \"pending\" && (this.handoffState = \"complete\");\n }\n }, {\n key: \"isHandoffComplete\",\n get: function get() {\n return this.handoffState === \"complete\";\n }\n }]);\n return o;\n}();\nvar s = new o();\nexport { s as env };","'use strict';\nvar TO_STRING_TAG_SUPPORT = require('../internals/to-string-tag-support');\nvar isCallable = require('../internals/is-callable');\nvar classofRaw = require('../internals/classof-raw');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\nvar $Object = Object;\n\n// ES3 wrong here\nvar CORRECT_ARGUMENTS = classofRaw(function () { return arguments; }()) === 'Arguments';\n\n// fallback for IE11 Script Access Denied error\nvar tryGet = function (it, key) {\n try {\n return it[key];\n } catch (error) { /* empty */ }\n};\n\n// getting tag from ES6+ `Object.prototype.toString`\nmodule.exports = TO_STRING_TAG_SUPPORT ? classofRaw : function (it) {\n var O, tag, result;\n return it === undefined ? 'Undefined' : it === null ? 'Null'\n // @@toStringTag case\n : typeof (tag = tryGet(O = $Object(it), TO_STRING_TAG)) == 'string' ? tag\n // builtinTag case\n : CORRECT_ARGUMENTS ? classofRaw(O)\n // ES3 arguments fallback\n : (result = classofRaw(O)) === 'Object' && isCallable(O.callee) ? 'Arguments' : result;\n};\n","'use strict';\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar FunctionPrototype = Function.prototype;\nvar apply = FunctionPrototype.apply;\nvar call = FunctionPrototype.call;\n\n// eslint-disable-next-line es/no-reflect -- safe\nmodule.exports = typeof Reflect == 'object' && Reflect.apply || (NATIVE_BIND ? call.bind(apply) : function () {\n return call.apply(apply, arguments);\n});\n","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nvar g;\n\n// This works in non-strict mode\ng = function () {\n return this;\n}();\ntry {\n // This works if eval is allowed (see CSP)\n g = g || new Function(\"return this\")();\n} catch (e) {\n // This works if the window reference is available\n if ((typeof window === \"undefined\" ? \"undefined\" : _typeof(window)) === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;","'use strict';\nvar toPropertyKey = require('../internals/to-property-key');\nvar definePropertyModule = require('../internals/object-define-property');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\n\nmodule.exports = function (object, key, value) {\n var propertyKey = toPropertyKey(key);\n if (propertyKey in object) definePropertyModule.f(object, propertyKey, createPropertyDescriptor(0, value));\n else object[propertyKey] = value;\n};\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar create = require('../internals/object-create');\nvar defineProperty = require('../internals/object-define-property').f;\n\nvar UNSCOPABLES = wellKnownSymbol('unscopables');\nvar ArrayPrototype = Array.prototype;\n\n// Array.prototype[@@unscopables]\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\nif (ArrayPrototype[UNSCOPABLES] === undefined) {\n defineProperty(ArrayPrototype, UNSCOPABLES, {\n configurable: true,\n value: create(null)\n });\n}\n\n// add a key to Array.prototype[@@unscopables]\nmodule.exports = function (key) {\n ArrayPrototype[UNSCOPABLES][key] = true;\n};\n","'use strict';\n// `CreateIterResultObject` abstract operation\n// https://tc39.es/ecma262/#sec-createiterresultobject\nmodule.exports = function (value, done) {\n return { value: value, done: done };\n};\n","'use strict';\n// `GetIteratorDirect(obj)` abstract operation\n// https://tc39.es/proposal-iterator-helpers/#sec-getiteratordirect\nmodule.exports = function (obj) {\n return {\n iterator: obj,\n next: obj.next,\n done: false\n };\n};\n","function t(e) {\n typeof queueMicrotask == \"function\" ? queueMicrotask(e) : Promise.resolve().then(e).catch(function (o) {\n return setTimeout(function () {\n throw o;\n });\n });\n}\nexport { t as microTask };","import { useEffect as o } from \"react\";\nimport { disposables as u } from '../utils/disposables.js';\nimport { useLatestValue as c } from './use-latest-value.js';\nfunction m(s, n, l) {\n var i = c(function (t) {\n var e = t.getBoundingClientRect();\n e.x === 0 && e.y === 0 && e.width === 0 && e.height === 0 && l();\n });\n o(function () {\n if (!s) return;\n var t = n === null ? null : n instanceof HTMLElement ? n : n.current;\n if (!t) return;\n var e = u();\n if (typeof ResizeObserver != \"undefined\") {\n var r = new ResizeObserver(function () {\n return i.current(t);\n });\n r.observe(t), e.add(function () {\n return r.disconnect();\n });\n }\n if (typeof IntersectionObserver != \"undefined\") {\n var _r = new IntersectionObserver(function () {\n return i.current(t);\n });\n _r.observe(t), e.add(function () {\n return _r.disconnect();\n });\n }\n return function () {\n return e.dispose();\n };\n }, [n, i, s]);\n}\nexport { m as useOnDisappear };","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport o, { createContext as H, useContext as E, useEffect as m, useState as u } from \"react\";\nimport { createPortal as g } from \"react-dom\";\nimport { useDisposables as h } from '../hooks/use-disposables.js';\nimport { objectToFormEntries as x } from '../utils/form.js';\nimport { compact as y } from '../utils/render.js';\nimport { Hidden as l, HiddenFeatures as d } from './hidden.js';\nvar f = /*#__PURE__*/H(null);\nfunction W(t) {\n var _u = u(null),\n _u2 = _slicedToArray(_u, 2),\n e = _u2[0],\n r = _u2[1];\n return /*#__PURE__*/o.createElement(f.Provider, {\n value: {\n target: e\n }\n }, t.children, /*#__PURE__*/o.createElement(l, {\n features: d.Hidden,\n ref: r\n }));\n}\nfunction c(_ref) {\n var t = _ref.children;\n var e = E(f);\n if (!e) return /*#__PURE__*/o.createElement(o.Fragment, null, t);\n var r = e.target;\n return r ? /*#__PURE__*/g( /*#__PURE__*/o.createElement(o.Fragment, null, t), r) : null;\n}\nfunction j(_ref2) {\n var t = _ref2.data,\n e = _ref2.form,\n r = _ref2.disabled,\n n = _ref2.onReset,\n F = _ref2.overrides;\n var _u3 = u(null),\n _u4 = _slicedToArray(_u3, 2),\n i = _u4[0],\n a = _u4[1],\n p = h();\n return m(function () {\n if (n && i) return p.addEventListener(i, \"reset\", n);\n }, [i, e, n]), /*#__PURE__*/o.createElement(c, null, /*#__PURE__*/o.createElement(C, {\n setForm: a,\n formId: e\n }), x(t).map(function (_ref3) {\n var _ref4 = _slicedToArray(_ref3, 2),\n s = _ref4[0],\n v = _ref4[1];\n return /*#__PURE__*/o.createElement(l, _objectSpread({\n features: d.Hidden\n }, y(_objectSpread({\n key: s,\n as: \"input\",\n type: \"hidden\",\n hidden: !0,\n readOnly: !0,\n form: e,\n disabled: r,\n name: s,\n value: v\n }, F))));\n }));\n}\nfunction C(_ref5) {\n var t = _ref5.setForm,\n e = _ref5.formId;\n return m(function () {\n if (e) {\n var r = document.getElementById(e);\n r && t(r);\n }\n }, [t, e]), e ? null : /*#__PURE__*/o.createElement(l, {\n features: d.Hidden,\n as: \"input\",\n type: \"hidden\",\n hidden: !0,\n readOnly: !0,\n ref: function ref(r) {\n if (!r) return;\n var n = r.closest(\"form\");\n n && t(n);\n }\n });\n}\nexport { j as FormFields, W as FormFieldsProvider, c as HoistFormFields };","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nimport { disposables as s } from '../../utils/disposables.js';\nimport { createStore as i } from '../../utils/store.js';\nimport { adjustScrollbarPadding as l } from './adjust-scrollbar-padding.js';\nimport { handleIOSLocking as d } from './handle-ios-locking.js';\nimport { preventScroll as p } from './prevent-scroll.js';\nfunction m(e) {\n var n = {};\n var _iterator = _createForOfIteratorHelper(e),\n _step;\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var t = _step.value;\n Object.assign(n, t(n));\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n return n;\n}\nvar a = i(function () {\n return new Map();\n}, {\n PUSH: function PUSH(e, n) {\n var o;\n var t = (o = this.get(e)) != null ? o : {\n doc: e,\n count: 0,\n d: s(),\n meta: new Set()\n };\n return t.count++, t.meta.add(n), this.set(e, t), this;\n },\n POP: function POP(e, n) {\n var t = this.get(e);\n return t && (t.count--, t.meta.delete(n)), this;\n },\n SCROLL_PREVENT: function SCROLL_PREVENT(_ref) {\n var e = _ref.doc,\n n = _ref.d,\n t = _ref.meta;\n var o = {\n doc: e,\n d: n,\n meta: m(t)\n },\n c = [d(), l(), p()];\n c.forEach(function (_ref2) {\n var r = _ref2.before;\n return r == null ? void 0 : r(o);\n }), c.forEach(function (_ref3) {\n var r = _ref3.after;\n return r == null ? void 0 : r(o);\n });\n },\n SCROLL_ALLOW: function SCROLL_ALLOW(_ref4) {\n var e = _ref4.d;\n e.dispose();\n },\n TEARDOWN: function TEARDOWN(_ref5) {\n var e = _ref5.doc;\n this.delete(e);\n }\n});\na.subscribe(function () {\n var e = a.getSnapshot(),\n n = new Map();\n var _iterator2 = _createForOfIteratorHelper(e),\n _step2;\n try {\n for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {\n var _ref6 = _step2.value;\n var _ref7 = _slicedToArray(_ref6, 1);\n var t = _ref7[0];\n n.set(t, t.documentElement.style.overflow);\n }\n } catch (err) {\n _iterator2.e(err);\n } finally {\n _iterator2.f();\n }\n var _iterator3 = _createForOfIteratorHelper(e.values()),\n _step3;\n try {\n for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {\n var _t = _step3.value;\n var o = n.get(_t.doc) === \"hidden\",\n c = _t.count !== 0;\n (c && !o || !c && o) && a.dispatch(_t.count > 0 ? \"SCROLL_PREVENT\" : \"SCROLL_ALLOW\", _t), _t.count === 0 && a.dispatch(\"TEARDOWN\", _t);\n }\n } catch (err) {\n _iterator3.e(err);\n } finally {\n _iterator3.f();\n }\n});\nexport { a as overflows };","function d() {\n var r;\n return {\n before: function before(_ref) {\n var e = _ref.doc;\n var l;\n var o = e.documentElement,\n t = (l = e.defaultView) != null ? l : window;\n r = Math.max(0, t.innerWidth - o.clientWidth);\n },\n after: function after(_ref2) {\n var e = _ref2.doc,\n o = _ref2.d;\n var t = e.documentElement,\n l = Math.max(0, t.clientWidth - t.offsetWidth),\n n = Math.max(0, r - l);\n o.style(t, \"paddingRight\", \"\".concat(n, \"px\"));\n }\n };\n}\nexport { d as adjustScrollbarPadding };","import { disposables as m } from '../../utils/disposables.js';\nimport { isIOS as u } from '../../utils/platform.js';\nfunction d() {\n return u() ? {\n before: function before(_ref) {\n var r = _ref.doc,\n n = _ref.d,\n c = _ref.meta;\n function o(a) {\n return c.containers.flatMap(function (l) {\n return l();\n }).some(function (l) {\n return l.contains(a);\n });\n }\n n.microTask(function () {\n var s;\n if (window.getComputedStyle(r.documentElement).scrollBehavior !== \"auto\") {\n var t = m();\n t.style(r.documentElement, \"scrollBehavior\", \"auto\"), n.add(function () {\n return n.microTask(function () {\n return t.dispose();\n });\n });\n }\n var a = (s = window.scrollY) != null ? s : window.pageYOffset,\n l = null;\n n.addEventListener(r, \"click\", function (t) {\n if (t.target instanceof HTMLElement) try {\n var e = t.target.closest(\"a\");\n if (!e) return;\n var _URL = new URL(e.href),\n f = _URL.hash,\n i = r.querySelector(f);\n i && !o(i) && (l = i);\n } catch (_unused) {}\n }, !0), n.addEventListener(r, \"touchstart\", function (t) {\n if (t.target instanceof HTMLElement) if (o(t.target)) {\n var e = t.target;\n for (; e.parentElement && o(e.parentElement);) e = e.parentElement;\n n.style(e, \"overscrollBehavior\", \"contain\");\n } else n.style(t.target, \"touchAction\", \"none\");\n }), n.addEventListener(r, \"touchmove\", function (t) {\n if (t.target instanceof HTMLElement) {\n if (t.target.tagName === \"INPUT\") return;\n if (o(t.target)) {\n var e = t.target;\n for (; e.parentElement && e.dataset.headlessuiPortal !== \"\" && !(e.scrollHeight > e.clientHeight || e.scrollWidth > e.clientWidth);) e = e.parentElement;\n e.dataset.headlessuiPortal === \"\" && t.preventDefault();\n } else t.preventDefault();\n }\n }, {\n passive: !1\n }), n.add(function () {\n var e;\n var t = (e = window.scrollY) != null ? e : window.pageYOffset;\n a !== t && window.scrollTo(0, a), l && l.isConnected && (l.scrollIntoView({\n block: \"nearest\"\n }), l = null);\n });\n });\n }\n } : {};\n}\nexport { d as handleIOSLocking };","function r() {\n return {\n before: function before(_ref) {\n var e = _ref.doc,\n o = _ref.d;\n o.style(e.documentElement, \"overflow\", \"hidden\");\n }\n };\n}\nexport { r as preventScroll };","function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nimport { useDocumentOverflowLockedEffect as l } from './document-overflow/use-document-overflow.js';\nimport { useIsTopLayer as m } from './use-is-top-layer.js';\nfunction f(e, c) {\n var n = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : function () {\n return [document.body];\n };\n var r = m(e, \"scroll-lock\");\n l(r, c, function (t) {\n var o;\n return {\n containers: [].concat(_toConsumableArray((o = t.containers) != null ? o : []), [n])\n };\n });\n}\nexport { f as useScrollLock };","import { useStore as s } from '../../hooks/use-store.js';\nimport { useIsoMorphicEffect as u } from '../use-iso-morphic-effect.js';\nimport { overflows as t } from './overflow-store.js';\nfunction a(r, e) {\n var n = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : function () {\n return {\n containers: []\n };\n };\n var f = s(t),\n o = e ? f.get(e) : void 0,\n i = o ? o.count > 0 : !1;\n return u(function () {\n if (!(!e || !r)) return t.dispatch(\"PUSH\", e, n), function () {\n return t.dispatch(\"POP\", e, n);\n };\n }, [r, e]), i;\n}\nexport { a as useDocumentOverflowLockedEffect };","import { useEffect as c } from \"react\";\nimport { useLatestValue as a } from './use-latest-value.js';\nfunction i(t, e, o, n) {\n var u = a(o);\n c(function () {\n if (!t) return;\n function r(m) {\n u.current(m);\n }\n return document.addEventListener(e, r, n), function () {\n return document.removeEventListener(e, r, n);\n };\n }, [t, e, n]);\n}\nexport { i as useDocumentEvent };","function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nimport { useCallback as T, useRef as d } from \"react\";\nimport { FocusableMode as y, isFocusableElement as M } from '../utils/focus-management.js';\nimport { isMobile as g } from '../utils/platform.js';\nimport { useDocumentEvent as c } from './use-document-event.js';\nimport { useIsTopLayer as L } from './use-is-top-layer.js';\nimport { useLatestValue as b } from './use-latest-value.js';\nimport { useWindowEvent as P } from './use-window-event.js';\nvar E = 30;\nfunction R(p, f, C) {\n var u = L(p, \"outside-click\"),\n m = b(C),\n s = T(function (e, n) {\n if (e.defaultPrevented) return;\n var r = n(e);\n if (r === null || !r.getRootNode().contains(r) || !r.isConnected) return;\n var h = function l(o) {\n return typeof o == \"function\" ? l(o()) : Array.isArray(o) || o instanceof Set ? o : [o];\n }(f);\n var _iterator = _createForOfIteratorHelper(h),\n _step;\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var l = _step.value;\n if (l !== null && (l.contains(r) || e.composed && e.composedPath().includes(l))) return;\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n return !M(r, y.Loose) && r.tabIndex !== -1 && e.preventDefault(), m.current(e, r);\n }, [m, f]),\n i = d(null);\n c(u, \"pointerdown\", function (t) {\n var e, n;\n i.current = ((n = (e = t.composedPath) == null ? void 0 : e.call(t)) == null ? void 0 : n[0]) || t.target;\n }, !0), c(u, \"mousedown\", function (t) {\n var e, n;\n i.current = ((n = (e = t.composedPath) == null ? void 0 : e.call(t)) == null ? void 0 : n[0]) || t.target;\n }, !0), c(u, \"click\", function (t) {\n g() || i.current && (s(t, function () {\n return i.current;\n }), i.current = null);\n }, !0);\n var a = d({\n x: 0,\n y: 0\n });\n c(u, \"touchstart\", function (t) {\n a.current.x = t.touches[0].clientX, a.current.y = t.touches[0].clientY;\n }, !0), c(u, \"touchend\", function (t) {\n var e = {\n x: t.changedTouches[0].clientX,\n y: t.changedTouches[0].clientY\n };\n if (!(Math.abs(e.x - a.current.x) >= E || Math.abs(e.y - a.current.y) >= E)) return s(t, function () {\n return t.target instanceof HTMLElement ? t.target : null;\n });\n }, !0), P(u, \"blur\", function (t) {\n return s(t, function () {\n return window.document.activeElement instanceof HTMLIFrameElement ? window.document.activeElement : null;\n });\n }, !0);\n}\nexport { R as useOutsideClick };","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nimport f, { createContext as M, useContext as d, useState as H } from \"react\";\nimport { Hidden as E, HiddenFeatures as T } from '../internal/hidden.js';\nimport { getOwnerDocument as L } from '../utils/owner.js';\nimport { useEvent as s } from './use-event.js';\nimport { useOwnerDocument as h } from './use-owner.js';\nfunction R() {\n var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n _ref$defaultContainer = _ref.defaultContainers,\n l = _ref$defaultContainer === void 0 ? [] : _ref$defaultContainer,\n n = _ref.portals,\n o = _ref.mainTreeNode;\n var r = h(o),\n u = s(function () {\n var i, c;\n var t = [];\n var _iterator = _createForOfIteratorHelper(l),\n _step;\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var _e = _step.value;\n _e !== null && (_e instanceof HTMLElement ? t.push(_e) : \"current\" in _e && _e.current instanceof HTMLElement && t.push(_e.current));\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n if (n != null && n.current) {\n var _iterator2 = _createForOfIteratorHelper(n.current),\n _step2;\n try {\n for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {\n var e = _step2.value;\n t.push(e);\n }\n } catch (err) {\n _iterator2.e(err);\n } finally {\n _iterator2.f();\n }\n }\n var _iterator3 = _createForOfIteratorHelper((i = r == null ? void 0 : r.querySelectorAll(\"html > *, body > *\")) != null ? i : []),\n _step3;\n try {\n var _loop = function _loop() {\n var e = _step3.value;\n e !== document.body && e !== document.head && e instanceof HTMLElement && e.id !== \"headlessui-portal-root\" && (o && (e.contains(o) || e.contains((c = o == null ? void 0 : o.getRootNode()) == null ? void 0 : c.host)) || t.some(function (m) {\n return e.contains(m);\n }) || t.push(e));\n };\n for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {\n _loop();\n }\n } catch (err) {\n _iterator3.e(err);\n } finally {\n _iterator3.f();\n }\n return t;\n });\n return {\n resolveContainers: u,\n contains: s(function (t) {\n return u().some(function (i) {\n return i.contains(t);\n });\n })\n };\n}\nvar a = /*#__PURE__*/M(null);\nfunction O(_ref2) {\n var l = _ref2.children,\n n = _ref2.node;\n var _H = H(null),\n _H2 = _slicedToArray(_H, 2),\n o = _H2[0],\n r = _H2[1],\n u = b(n != null ? n : o);\n return /*#__PURE__*/f.createElement(a.Provider, {\n value: u\n }, l, u === null && /*#__PURE__*/f.createElement(E, {\n features: T.Hidden,\n ref: function ref(t) {\n var i, c;\n if (t) {\n var _iterator4 = _createForOfIteratorHelper((c = (i = L(t)) == null ? void 0 : i.querySelectorAll(\"html > *, body > *\")) != null ? c : []),\n _step4;\n try {\n for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {\n var e = _step4.value;\n if (e !== document.body && e !== document.head && e instanceof HTMLElement && e != null && e.contains(t)) {\n r(e);\n break;\n }\n }\n } catch (err) {\n _iterator4.e(err);\n } finally {\n _iterator4.f();\n }\n }\n }\n }));\n}\nfunction b() {\n var l = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;\n var n;\n return (n = d(a)) != null ? n : l;\n}\nexport { O as MainTreeProvider, b as useMainTreeNode, R as useRootContainers };","'use strict';\n/* eslint-disable es/no-symbol -- required for testing */\nvar V8_VERSION = require('../internals/engine-v8-version');\nvar fails = require('../internals/fails');\nvar global = require('../internals/global');\n\nvar $String = global.String;\n\n// eslint-disable-next-line es/no-object-getownpropertysymbols -- required for testing\nmodule.exports = !!Object.getOwnPropertySymbols && !fails(function () {\n var symbol = Symbol('symbol detection');\n // Chrome 38 Symbol has incorrect toString conversion\n // `get-own-property-symbols` polyfill symbols converted to object are not Symbol instances\n // nb: Do not call `String` directly to avoid this being optimized out to `symbol+''` which will,\n // of course, fail.\n return !$String(symbol) || !(Object(symbol) instanceof Symbol) ||\n // Chrome 38-40 symbols are not inherited from DOM collections prototypes to instances\n !Symbol.sham && V8_VERSION && V8_VERSION < 41;\n});\n","'use strict';\nvar $String = String;\n\nmodule.exports = function (argument) {\n try {\n return $String(argument);\n } catch (error) {\n return 'Object';\n }\n};\n","'use strict';\nvar IS_PURE = require('../internals/is-pure');\nvar store = require('../internals/shared-store');\n\n(module.exports = function (key, value) {\n return store[key] || (store[key] = value !== undefined ? value : {});\n})('versions', []).push({\n version: '3.34.0',\n mode: IS_PURE ? 'pure' : 'global',\n copyright: '© 2014-2023 Denis Pushkarev (zloirock.ru)',\n license: 'https://github.com/zloirock/core-js/blob/v3.34.0/LICENSE',\n source: 'https://github.com/zloirock/core-js'\n});\n","'use strict';\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\n\nvar min = Math.min;\n\n// `ToLength` abstract operation\n// https://tc39.es/ecma262/#sec-tolength\nmodule.exports = function (argument) {\n return argument > 0 ? min(toIntegerOrInfinity(argument), 0x1FFFFFFFFFFFFF) : 0; // 2 ** 53 - 1 == 9007199254740991\n};\n","'use strict';\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\n\nvar $TypeError = TypeError;\n\nmodule.exports = function (it, Prototype) {\n if (isPrototypeOf(Prototype, it)) return it;\n throw new $TypeError('Incorrect invocation');\n};\n","'use strict';\nvar aCallable = require('../internals/a-callable');\n\nvar $TypeError = TypeError;\n\nvar PromiseCapability = function (C) {\n var resolve, reject;\n this.promise = new C(function ($$resolve, $$reject) {\n if (resolve !== undefined || reject !== undefined) throw new $TypeError('Bad Promise constructor');\n resolve = $$resolve;\n reject = $$reject;\n });\n this.resolve = aCallable(resolve);\n this.reject = aCallable(reject);\n};\n\n// `NewPromiseCapability` abstract operation\n// https://tc39.es/ecma262/#sec-newpromisecapability\nmodule.exports.f = function (C) {\n return new PromiseCapability(C);\n};\n","'use strict';\nvar toPrimitive = require('../internals/to-primitive');\nvar isSymbol = require('../internals/is-symbol');\n\n// `ToPropertyKey` abstract operation\n// https://tc39.es/ecma262/#sec-topropertykey\nmodule.exports = function (argument) {\n var key = toPrimitive(argument, 'string');\n return isSymbol(key) ? key : key + '';\n};\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar isCallable = require('../internals/is-callable');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar USE_SYMBOL_AS_UID = require('../internals/use-symbol-as-uid');\n\nvar $Object = Object;\n\nmodule.exports = USE_SYMBOL_AS_UID ? function (it) {\n return typeof it == 'symbol';\n} : function (it) {\n var $Symbol = getBuiltIn('Symbol');\n return isCallable($Symbol) && isPrototypeOf($Symbol.prototype, $Object(it));\n};\n","'use strict';\nmodule.exports = typeof navigator != 'undefined' && String(navigator.userAgent) || '';\n","'use strict';\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\n\nvar max = Math.max;\nvar min = Math.min;\n\n// Helper for a popular repeating case of the spec:\n// Let integer be ? ToInteger(index).\n// If integer < 0, let result be max((length + integer), 0); else let result be min(integer, length).\nmodule.exports = function (index, length) {\n var integer = toIntegerOrInfinity(index);\n return integer < 0 ? max(integer + length, 0) : min(integer, length);\n};\n","'use strict';\nvar global = require('../internals/global');\nvar classof = require('../internals/classof-raw');\n\nmodule.exports = classof(global.process) === 'process';\n","'use strict';\nvar $TypeError = TypeError;\n\nmodule.exports = function (passed, required) {\n if (passed < required) throw new $TypeError('Not enough arguments');\n return passed;\n};\n","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport * as t from \"react\";\nimport { env as f } from '../utils/env.js';\nfunction s() {\n var r = typeof document == \"undefined\";\n return \"useSyncExternalStore\" in t ? function (o) {\n return o.useSyncExternalStore;\n }(t)(function () {\n return function () {};\n }, function () {\n return !1;\n }, function () {\n return !r;\n }) : !1;\n}\nfunction l() {\n var r = s(),\n _t$useState = t.useState(f.isHandoffComplete),\n _t$useState2 = _slicedToArray(_t$useState, 2),\n e = _t$useState2[0],\n n = _t$useState2[1];\n return e && f.isHandoffComplete === !1 && n(!1), t.useEffect(function () {\n e !== !0 && n(!0);\n }, [e]), t.useEffect(function () {\n return f.handoff();\n }, []), r ? !1 : e;\n}\nexport { l as useServerHandoffComplete };","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { useMemo as o, useReducer as h } from \"react\";\nimport { useIsoMorphicEffect as s } from './use-iso-morphic-effect.js';\nfunction f(e) {\n if (e === null) return {\n width: 0,\n height: 0\n };\n var _e$getBoundingClientR = e.getBoundingClientRect(),\n t = _e$getBoundingClientR.width,\n r = _e$getBoundingClientR.height;\n return {\n width: t,\n height: r\n };\n}\nfunction d(e) {\n var t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !1;\n var _h = h(function () {\n return {};\n }, {}),\n _h2 = _slicedToArray(_h, 2),\n r = _h2[0],\n u = _h2[1],\n i = o(function () {\n return f(e);\n }, [e, r]);\n return s(function () {\n if (!e) return;\n var n = new ResizeObserver(u);\n return n.observe(e), function () {\n n.disconnect();\n };\n }, [e]), t ? {\n width: \"\".concat(i.width, \"px\"),\n height: \"\".concat(i.height, \"px\")\n } : i;\n}\nexport { d as useElementSize };","'use strict';\nvar internalObjectKeys = require('../internals/object-keys-internal');\nvar enumBugKeys = require('../internals/enum-bug-keys');\n\nvar hiddenKeys = enumBugKeys.concat('length', 'prototype');\n\n// `Object.getOwnPropertyNames` method\n// https://tc39.es/ecma262/#sec-object.getownpropertynames\n// eslint-disable-next-line es/no-object-getownpropertynames -- safe\nexports.f = Object.getOwnPropertyNames || function getOwnPropertyNames(O) {\n return internalObjectKeys(O, hiddenKeys);\n};\n","'use strict';\n/* eslint-disable no-proto -- safe */\nvar uncurryThisAccessor = require('../internals/function-uncurry-this-accessor');\nvar anObject = require('../internals/an-object');\nvar aPossiblePrototype = require('../internals/a-possible-prototype');\n\n// `Object.setPrototypeOf` method\n// https://tc39.es/ecma262/#sec-object.setprototypeof\n// Works with __proto__ only. Old v8 can't work with null proto objects.\n// eslint-disable-next-line es/no-object-setprototypeof -- safe\nmodule.exports = Object.setPrototypeOf || ('__proto__' in {} ? function () {\n var CORRECT_SETTER = false;\n var test = {};\n var setter;\n try {\n setter = uncurryThisAccessor(Object.prototype, '__proto__', 'set');\n setter(test, []);\n CORRECT_SETTER = test instanceof Array;\n } catch (error) { /* empty */ }\n return function setPrototypeOf(O, proto) {\n anObject(O);\n aPossiblePrototype(proto);\n if (CORRECT_SETTER) setter(O, proto);\n else O.__proto__ = proto;\n return O;\n };\n}() : undefined);\n","'use strict';\nvar global = require('../internals/global');\n\nmodule.exports = global.Promise;\n","'use strict';\nvar fails = require('../internals/fails');\n\nmodule.exports = !fails(function () {\n // eslint-disable-next-line es/no-function-prototype-bind -- safe\n var test = (function () { /* empty */ }).bind();\n // eslint-disable-next-line no-prototype-builtins -- safe\n return typeof test != 'function' || test.hasOwnProperty('prototype');\n});\n","'use strict';\nvar global = require('../internals/global');\nvar userAgent = require('../internals/engine-user-agent');\n\nvar process = global.process;\nvar Deno = global.Deno;\nvar versions = process && process.versions || Deno && Deno.version;\nvar v8 = versions && versions.v8;\nvar match, version;\n\nif (v8) {\n match = v8.split('.');\n // in old Chrome, versions of V8 isn't V8 = Chrome / 10\n // but their correct versions are not interesting for us\n version = match[0] > 0 && match[0] < 4 ? 1 : +(match[0] + match[1]);\n}\n\n// BrowserFS NodeJS `process` polyfill incorrectly set `.v8` to `0.0`\n// so check `userAgent` even if `.v8` exists, but 0\nif (!version && userAgent) {\n match = userAgent.match(/Edge\\/(\\d+)/);\n if (!match || match[1] >= 74) {\n match = userAgent.match(/Chrome\\/(\\d+)/);\n if (match) version = +match[1];\n }\n}\n\nmodule.exports = version;\n","'use strict';\nvar classof = require('../internals/classof-raw');\n\n// `IsArray` abstract operation\n// https://tc39.es/ecma262/#sec-isarray\n// eslint-disable-next-line es/no-array-isarray -- safe\nmodule.exports = Array.isArray || function isArray(argument) {\n return classof(argument) === 'Array';\n};\n","'use strict';\nmodule.exports = {};\n","'use strict';\nvar global = require('../internals/global');\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar isCallable = require('../internals/is-callable');\nvar isForced = require('../internals/is-forced');\nvar inspectSource = require('../internals/inspect-source');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar IS_BROWSER = require('../internals/engine-is-browser');\nvar IS_DENO = require('../internals/engine-is-deno');\nvar IS_PURE = require('../internals/is-pure');\nvar V8_VERSION = require('../internals/engine-v8-version');\n\nvar NativePromisePrototype = NativePromiseConstructor && NativePromiseConstructor.prototype;\nvar SPECIES = wellKnownSymbol('species');\nvar SUBCLASSING = false;\nvar NATIVE_PROMISE_REJECTION_EVENT = isCallable(global.PromiseRejectionEvent);\n\nvar FORCED_PROMISE_CONSTRUCTOR = isForced('Promise', function () {\n var PROMISE_CONSTRUCTOR_SOURCE = inspectSource(NativePromiseConstructor);\n var GLOBAL_CORE_JS_PROMISE = PROMISE_CONSTRUCTOR_SOURCE !== String(NativePromiseConstructor);\n // V8 6.6 (Node 10 and Chrome 66) have a bug with resolving custom thenables\n // https://bugs.chromium.org/p/chromium/issues/detail?id=830565\n // We can't detect it synchronously, so just check versions\n if (!GLOBAL_CORE_JS_PROMISE && V8_VERSION === 66) return true;\n // We need Promise#{ catch, finally } in the pure version for preventing prototype pollution\n if (IS_PURE && !(NativePromisePrototype['catch'] && NativePromisePrototype['finally'])) return true;\n // We can't use @@species feature detection in V8 since it causes\n // deoptimization and performance degradation\n // https://github.com/zloirock/core-js/issues/679\n if (!V8_VERSION || V8_VERSION < 51 || !/native code/.test(PROMISE_CONSTRUCTOR_SOURCE)) {\n // Detect correctness of subclassing with @@species support\n var promise = new NativePromiseConstructor(function (resolve) { resolve(1); });\n var FakePromise = function (exec) {\n exec(function () { /* empty */ }, function () { /* empty */ });\n };\n var constructor = promise.constructor = {};\n constructor[SPECIES] = FakePromise;\n SUBCLASSING = promise.then(function () { /* empty */ }) instanceof FakePromise;\n if (!SUBCLASSING) return true;\n // Unhandled rejections tracking support, NodeJS Promise without it fails @@species test\n } return !GLOBAL_CORE_JS_PROMISE && (IS_BROWSER || IS_DENO) && !NATIVE_PROMISE_REJECTION_EVENT;\n});\n\nmodule.exports = {\n CONSTRUCTOR: FORCED_PROMISE_CONSTRUCTOR,\n REJECTION_EVENT: NATIVE_PROMISE_REJECTION_EVENT,\n SUBCLASSING: SUBCLASSING\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.useDragDropManager = useDragDropManager;\nvar _react = require(\"react\");\nvar _invariant = require(\"@react-dnd/invariant\");\nvar _indexJs = require(\"../core/index.js\");\nfunction useDragDropManager() {\n var _useContext = (0, _react).useContext(_indexJs.DndContext),\n dragDropManager = _useContext.dragDropManager;\n (0, _invariant).invariant(dragDropManager != null, 'Expected drag drop context');\n return dragDropManager;\n}","function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nimport { disposables as M } from '../utils/disposables.js';\nimport { getOwnerDocument as b } from '../utils/owner.js';\nimport { useIsTopLayer as L } from './use-is-top-layer.js';\nimport { useIsoMorphicEffect as T } from './use-iso-morphic-effect.js';\nvar f = new Map(),\n u = new Map();\nfunction h(t) {\n var e;\n var r = (e = u.get(t)) != null ? e : 0;\n return u.set(t, r + 1), r !== 0 ? function () {\n return m(t);\n } : (f.set(t, {\n \"aria-hidden\": t.getAttribute(\"aria-hidden\"),\n inert: t.inert\n }), t.setAttribute(\"aria-hidden\", \"true\"), t.inert = !0, function () {\n return m(t);\n });\n}\nfunction m(t) {\n var i;\n var r = (i = u.get(t)) != null ? i : 1;\n if (r === 1 ? u.delete(t) : u.set(t, r - 1), r !== 1) return;\n var e = f.get(t);\n e && (e[\"aria-hidden\"] === null ? t.removeAttribute(\"aria-hidden\") : t.setAttribute(\"aria-hidden\", e[\"aria-hidden\"]), t.inert = e.inert, f.delete(t));\n}\nfunction y(t) {\n var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n r = _ref.allowed,\n e = _ref.disallowed;\n var i = L(t, \"inert-others\");\n T(function () {\n var d, c;\n if (!i) return;\n var a = M();\n var _iterator = _createForOfIteratorHelper((d = e == null ? void 0 : e()) != null ? d : []),\n _step;\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var n = _step.value;\n n && a.add(h(n));\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n var s = (c = r == null ? void 0 : r()) != null ? c : [];\n var _iterator2 = _createForOfIteratorHelper(s),\n _step2;\n try {\n for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {\n var _n = _step2.value;\n if (!_n) continue;\n var l = b(_n);\n if (!l) continue;\n var o = _n.parentElement;\n for (; o && o !== l.body;) {\n var _iterator3 = _createForOfIteratorHelper(o.children),\n _step3;\n try {\n var _loop = function _loop() {\n var p = _step3.value;\n s.some(function (E) {\n return p.contains(E);\n }) || a.add(h(p));\n };\n for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {\n _loop();\n }\n } catch (err) {\n _iterator3.e(err);\n } finally {\n _iterator3.f();\n }\n o = o.parentElement;\n }\n }\n } catch (err) {\n _iterator2.e(err);\n } finally {\n _iterator2.f();\n }\n return a.dispose;\n }, [i, r, e]);\n}\nexport { y as useInertOthers };","import { useEffect as d } from \"react\";\nimport { useLatestValue as s } from './use-latest-value.js';\nfunction E(n, e, a, t) {\n var i = s(a);\n d(function () {\n n = n != null ? n : window;\n function r(o) {\n i.current(o);\n }\n return n.addEventListener(e, r, t), function () {\n return n.removeEventListener(e, r, t);\n };\n }, [n, e, t]);\n}\nexport { E as useEventListener };","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { useState as u } from \"react\";\nfunction l(e) {\n var _u = u(e),\n _u2 = _slicedToArray(_u, 1),\n t = _u2[0];\n return t;\n}\nexport { l as useDefaultValue };","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { useRef as o, useState as f } from \"react\";\nimport { useEvent as a } from './use-event.js';\nfunction T(l, r, c) {\n var _f = f(c),\n _f2 = _slicedToArray(_f, 2),\n i = _f2[0],\n s = _f2[1],\n e = l !== void 0,\n t = o(e),\n u = o(!1),\n d = o(!1);\n return e && !t.current && !u.current ? (u.current = !0, t.current = e, console.error(\"A component is changing from uncontrolled to controlled. This may be caused by the value changing from undefined to a defined value, which should not happen.\")) : !e && t.current && !d.current && (d.current = !0, t.current = e, console.error(\"A component is changing from controlled to uncontrolled. This may be caused by the value changing from a defined value to undefined, which should not happen.\")), [e ? l : i, a(function (n) {\n return e || s(n), r == null ? void 0 : r(n);\n })];\n}\nexport { T as useControllable };","function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nfunction e() {\n var i = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var s = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n var t = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];\n for (var _i2 = 0, _Object$entries = Object.entries(i); _i2 < _Object$entries.length; _i2++) {\n var _ref = _Object$entries[_i2];\n var _ref2 = _slicedToArray(_ref, 2);\n var r = _ref2[0];\n var n = _ref2[1];\n o(t, f(s, r), n);\n }\n return t;\n}\nfunction f(i, s) {\n return i ? i + \"[\" + s + \"]\" : s;\n}\nfunction o(i, s, t) {\n if (Array.isArray(t)) {\n var _iterator = _createForOfIteratorHelper(t.entries()),\n _step;\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var _ref3 = _step.value;\n var _ref4 = _slicedToArray(_ref3, 2);\n var r = _ref4[0];\n var n = _ref4[1];\n o(i, f(s, r.toString()), n);\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n } else t instanceof Date ? i.push([s, t.toISOString()]) : typeof t == \"boolean\" ? i.push([s, t ? \"1\" : \"0\"]) : typeof t == \"string\" ? i.push([s, t]) : typeof t == \"number\" ? i.push([s, \"\".concat(t)]) : t == null ? i.push([s, \"\"]) : e(t, s, i);\n}\nfunction p(i) {\n var t, r;\n var s = (t = i == null ? void 0 : i.form) != null ? t : i.closest(\"form\");\n if (s) {\n var _iterator2 = _createForOfIteratorHelper(s.elements),\n _step2;\n try {\n for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {\n var n = _step2.value;\n if (n !== i && (n.tagName === \"INPUT\" && n.type === \"submit\" || n.tagName === \"BUTTON\" && n.type === \"submit\" || n.nodeName === \"INPUT\" && n.type === \"image\")) {\n n.click();\n return;\n }\n }\n } catch (err) {\n _iterator2.e(err);\n } finally {\n _iterator2.f();\n }\n (r = s.requestSubmit) == null || r.call(s);\n }\n}\nexport { p as attemptSubmit, e as objectToFormEntries };","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"getEmptyImage\", {\n enumerable: true,\n get: function get() {\n return _getEmptyImageJs.getEmptyImage;\n }\n});\nexports.HTML5Backend = exports.NativeTypes = void 0;\nvar _html5BackendImplJs = require(\"./HTML5BackendImpl.js\");\nvar _NativeTypes = _interopRequireWildcard(require(\"./NativeTypes.js\"));\nvar _getEmptyImageJs = require(\"./getEmptyImage.js\");\nexports.NativeTypes = _NativeTypes;\nfunction _interopRequireWildcard(obj) {\n if (obj && obj.__esModule) {\n return obj;\n } else {\n var newObj = {};\n if (obj != null) {\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {};\n if (desc.get || desc.set) {\n Object.defineProperty(newObj, key, desc);\n } else {\n newObj[key] = obj[key];\n }\n }\n }\n }\n newObj.default = obj;\n return newObj;\n }\n}\nvar HTML5Backend = function createBackend(manager, context, options) {\n return new _html5BackendImplJs.HTML5BackendImpl(manager, context, options);\n};\nexports.HTML5Backend = HTML5Backend;","/**\n * react-number-format - 5.4.0\n * Author : Sudhanshu Yadav\n * Copyright (c) 2016, 2024 to Sudhanshu Yadav, released under the MIT license.\n * https://github.com/s-yadav/react-number-format\n */\n\nimport React, { useState, useMemo, useRef, useEffect, useLayoutEffect } from 'react';\n\n/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\n\nfunction __rest(s, e) {\n var t = {};\n for (var p in s) {\n if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) {\n t[p] = s[p];\n }\n }\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") {\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) {\n t[p[i]] = s[p[i]];\n }\n }\n }\n return t;\n}\nvar SourceType;\n(function (SourceType) {\n SourceType[\"event\"] = \"event\";\n SourceType[\"props\"] = \"prop\";\n})(SourceType || (SourceType = {}));\n\n// basic noop function\nfunction noop() {}\nfunction memoizeOnce(cb) {\n var lastArgs;\n var lastValue = undefined;\n return function () {\n var args = [],\n len = arguments.length;\n while (len--) args[len] = arguments[len];\n if (lastArgs && args.length === lastArgs.length && args.every(function (value, index) {\n return value === lastArgs[index];\n })) {\n return lastValue;\n }\n lastArgs = args;\n lastValue = cb.apply(void 0, args);\n return lastValue;\n };\n}\nfunction charIsNumber(char) {\n return !!(char || '').match(/\\d/);\n}\nfunction isNil(val) {\n return val === null || val === undefined;\n}\nfunction isNanValue(val) {\n return typeof val === 'number' && isNaN(val);\n}\nfunction isNotValidValue(val) {\n return isNil(val) || isNanValue(val) || typeof val === 'number' && !isFinite(val);\n}\nfunction escapeRegExp(str) {\n return str.replace(/[-[\\]/{}()*+?.\\\\^$|]/g, '\\\\$&');\n}\nfunction getThousandsGroupRegex(thousandsGroupStyle) {\n switch (thousandsGroupStyle) {\n case 'lakh':\n return /(\\d+?)(?=(\\d\\d)+(\\d)(?!\\d))(\\.\\d+)?/g;\n case 'wan':\n return /(\\d)(?=(\\d{4})+(?!\\d))/g;\n case 'thousand':\n default:\n return /(\\d)(?=(\\d{3})+(?!\\d))/g;\n }\n}\nfunction applyThousandSeparator(str, thousandSeparator, thousandsGroupStyle) {\n var thousandsGroupRegex = getThousandsGroupRegex(thousandsGroupStyle);\n var index = str.search(/[1-9]/);\n index = index === -1 ? str.length : index;\n return str.substring(0, index) + str.substring(index, str.length).replace(thousandsGroupRegex, '$1' + thousandSeparator);\n}\nfunction usePersistentCallback(cb) {\n var callbackRef = useRef(cb);\n // keep the callback ref upto date\n callbackRef.current = cb;\n /**\n * initialize a persistent callback which never changes\n * through out the component lifecycle\n */\n var persistentCbRef = useRef(function () {\n var args = [],\n len = arguments.length;\n while (len--) args[len] = arguments[len];\n return callbackRef.current.apply(callbackRef, args);\n });\n return persistentCbRef.current;\n}\n//spilt a float number into different parts beforeDecimal, afterDecimal, and negation\nfunction splitDecimal(numStr, allowNegative) {\n if (allowNegative === void 0) allowNegative = true;\n var hasNegation = numStr[0] === '-';\n var addNegation = hasNegation && allowNegative;\n numStr = numStr.replace('-', '');\n var parts = numStr.split('.');\n var beforeDecimal = parts[0];\n var afterDecimal = parts[1] || '';\n return {\n beforeDecimal: beforeDecimal,\n afterDecimal: afterDecimal,\n hasNegation: hasNegation,\n addNegation: addNegation\n };\n}\nfunction fixLeadingZero(numStr) {\n if (!numStr) {\n return numStr;\n }\n var isNegative = numStr[0] === '-';\n if (isNegative) {\n numStr = numStr.substring(1, numStr.length);\n }\n var parts = numStr.split('.');\n var beforeDecimal = parts[0].replace(/^0+/, '') || '0';\n var afterDecimal = parts[1] || '';\n return \"\" + (isNegative ? '-' : '') + beforeDecimal + (afterDecimal ? \".\" + afterDecimal : '');\n}\n/**\n * limit decimal numbers to given scale\n * Not used .fixedTo because that will break with big numbers\n */\nfunction limitToScale(numStr, scale, fixedDecimalScale) {\n var str = '';\n var filler = fixedDecimalScale ? '0' : '';\n for (var i = 0; i <= scale - 1; i++) {\n str += numStr[i] || filler;\n }\n return str;\n}\nfunction repeat(str, count) {\n return Array(count + 1).join(str);\n}\nfunction toNumericString(num) {\n var _num = num + ''; // typecast number to string\n // store the sign and remove it from the number.\n var sign = _num[0] === '-' ? '-' : '';\n if (sign) {\n _num = _num.substring(1);\n }\n // split the number into cofficient and exponent\n var ref = _num.split(/[eE]/g);\n var coefficient = ref[0];\n var exponent = ref[1];\n // covert exponent to number;\n exponent = Number(exponent);\n // if there is no exponent part or its 0, return the coffiecient with sign\n if (!exponent) {\n return sign + coefficient;\n }\n coefficient = coefficient.replace('.', '');\n /**\n * for scientific notation the current decimal index will be after first number (index 0)\n * So effective decimal index will always be 1 + exponent value\n */\n var decimalIndex = 1 + exponent;\n var coffiecientLn = coefficient.length;\n if (decimalIndex < 0) {\n // if decimal index is less then 0 add preceding 0s\n // add 1 as join will have\n coefficient = '0.' + repeat('0', Math.abs(decimalIndex)) + coefficient;\n } else if (decimalIndex >= coffiecientLn) {\n // if decimal index is less then 0 add leading 0s\n coefficient = coefficient + repeat('0', decimalIndex - coffiecientLn);\n } else {\n // else add decimal point at proper index\n coefficient = (coefficient.substring(0, decimalIndex) || '0') + '.' + coefficient.substring(decimalIndex);\n }\n return sign + coefficient;\n}\n/**\n * This method is required to round prop value to given scale.\n * Not used .round or .fixedTo because that will break with big numbers\n */\nfunction roundToPrecision(numStr, scale, fixedDecimalScale) {\n //if number is empty don't do anything return empty string\n if (['', '-'].indexOf(numStr) !== -1) {\n return numStr;\n }\n var shouldHaveDecimalSeparator = (numStr.indexOf('.') !== -1 || fixedDecimalScale) && scale;\n var ref = splitDecimal(numStr);\n var beforeDecimal = ref.beforeDecimal;\n var afterDecimal = ref.afterDecimal;\n var hasNegation = ref.hasNegation;\n var floatValue = parseFloat(\"0.\" + (afterDecimal || '0'));\n var floatValueStr = afterDecimal.length <= scale ? \"0.\" + afterDecimal : floatValue.toFixed(scale);\n var roundedDecimalParts = floatValueStr.split('.');\n var intPart = beforeDecimal;\n // if we have cary over from rounding decimal part, add that on before decimal\n if (beforeDecimal && Number(roundedDecimalParts[0])) {\n intPart = beforeDecimal.split('').reverse().reduce(function (roundedStr, current, idx) {\n if (roundedStr.length > idx) {\n return (Number(roundedStr[0]) + Number(current)).toString() + roundedStr.substring(1, roundedStr.length);\n }\n return current + roundedStr;\n }, roundedDecimalParts[0]);\n }\n var decimalPart = limitToScale(roundedDecimalParts[1] || '', scale, fixedDecimalScale);\n var negation = hasNegation ? '-' : '';\n var decimalSeparator = shouldHaveDecimalSeparator ? '.' : '';\n return \"\" + negation + intPart + decimalSeparator + decimalPart;\n}\n/** set the caret positon in an input field **/\nfunction setCaretPosition(el, caretPos) {\n el.value = el.value;\n // ^ this is used to not only get 'focus', but\n // to make sure we don't have it everything -selected-\n // (it causes an issue in chrome, and having it doesn't hurt any other browser)\n if (el !== null) {\n /* @ts-ignore */\n if (el.createTextRange) {\n /* @ts-ignore */\n var range = el.createTextRange();\n range.move('character', caretPos);\n range.select();\n return true;\n }\n // (el.selectionStart === 0 added for Firefox bug)\n if (el.selectionStart || el.selectionStart === 0) {\n el.focus();\n el.setSelectionRange(caretPos, caretPos);\n return true;\n }\n // fail city, fortunately this never happens (as far as I've tested) :)\n el.focus();\n return false;\n }\n}\n/**\n * TODO: remove dependency of findChangeRange, findChangedRangeFromCaretPositions is better way to find what is changed\n * currently this is mostly required by test and isCharacterSame util\n * Given previous value and newValue it returns the index\n * start - end to which values have changed.\n * This function makes assumption about only consecutive\n * characters are changed which is correct assumption for caret input.\n */\nvar findChangeRange = memoizeOnce(function (prevValue, newValue) {\n var i = 0,\n j = 0;\n var prevLength = prevValue.length;\n var newLength = newValue.length;\n while (prevValue[i] === newValue[i] && i < prevLength) {\n i++;\n }\n //check what has been changed from last\n while (prevValue[prevLength - 1 - j] === newValue[newLength - 1 - j] && newLength - j > i && prevLength - j > i) {\n j++;\n }\n return {\n from: {\n start: i,\n end: prevLength - j\n },\n to: {\n start: i,\n end: newLength - j\n }\n };\n});\nvar findChangedRangeFromCaretPositions = function findChangedRangeFromCaretPositions(lastCaretPositions, currentCaretPosition) {\n var startPosition = Math.min(lastCaretPositions.selectionStart, currentCaretPosition);\n return {\n from: {\n start: startPosition,\n end: lastCaretPositions.selectionEnd\n },\n to: {\n start: startPosition,\n end: currentCaretPosition\n }\n };\n};\n/*\n Returns a number whose value is limited to the given range\n*/\nfunction clamp(num, min, max) {\n return Math.min(Math.max(num, min), max);\n}\nfunction geInputCaretPosition(el) {\n /*Max of selectionStart and selectionEnd is taken for the patch of pixel and other mobile device caret bug*/\n return Math.max(el.selectionStart, el.selectionEnd);\n}\nfunction addInputMode() {\n return typeof navigator !== 'undefined' && !(navigator.platform && /iPhone|iPod/.test(navigator.platform));\n}\nfunction getDefaultChangeMeta(value) {\n return {\n from: {\n start: 0,\n end: 0\n },\n to: {\n start: 0,\n end: value.length\n },\n lastValue: ''\n };\n}\nfunction getMaskAtIndex(mask, index) {\n if (mask === void 0) mask = ' ';\n if (typeof mask === 'string') {\n return mask;\n }\n return mask[index] || ' ';\n}\nfunction defaultIsCharacterSame(ref) {\n var currentValue = ref.currentValue;\n var formattedValue = ref.formattedValue;\n var currentValueIndex = ref.currentValueIndex;\n var formattedValueIndex = ref.formattedValueIndex;\n return currentValue[currentValueIndex] === formattedValue[formattedValueIndex];\n}\nfunction getCaretPosition(newFormattedValue, lastFormattedValue, curValue, curCaretPos, boundary, isValidInputCharacter,\n/**\n * format function can change the character, the caret engine relies on mapping old value and new value\n * In such case if character is changed, parent can tell which chars are equivalent\n * Some example, all allowedDecimalCharacters are updated to decimalCharacters, 2nd case if user is coverting\n * number to different numeric system.\n */\nisCharacterSame) {\n if (isCharacterSame === void 0) isCharacterSame = defaultIsCharacterSame;\n\n /**\n * if something got inserted on empty value, add the formatted character before the current value,\n * This is to avoid the case where typed character is present on format characters\n */\n var firstAllowedPosition = boundary.findIndex(function (b) {\n return b;\n });\n var prefixFormat = newFormattedValue.slice(0, firstAllowedPosition);\n if (!lastFormattedValue && !curValue.startsWith(prefixFormat)) {\n lastFormattedValue = prefixFormat;\n curValue = prefixFormat + curValue;\n curCaretPos = curCaretPos + prefixFormat.length;\n }\n var curValLn = curValue.length;\n var formattedValueLn = newFormattedValue.length;\n // create index map\n var addedIndexMap = {};\n var indexMap = new Array(curValLn);\n for (var i = 0; i < curValLn; i++) {\n indexMap[i] = -1;\n for (var j = 0, jLn = formattedValueLn; j < jLn; j++) {\n var isCharSame = isCharacterSame({\n currentValue: curValue,\n lastValue: lastFormattedValue,\n formattedValue: newFormattedValue,\n currentValueIndex: i,\n formattedValueIndex: j\n });\n if (isCharSame && addedIndexMap[j] !== true) {\n indexMap[i] = j;\n addedIndexMap[j] = true;\n break;\n }\n }\n }\n /**\n * For current caret position find closest characters (left and right side)\n * which are properly mapped to formatted value.\n * The idea is that the new caret position will exist always in the boundary of\n * that mapped index\n */\n var pos = curCaretPos;\n while (pos < curValLn && (indexMap[pos] === -1 || !isValidInputCharacter(curValue[pos]))) {\n pos++;\n }\n // if the caret position is on last keep the endIndex as last for formatted value\n var endIndex = pos === curValLn || indexMap[pos] === -1 ? formattedValueLn : indexMap[pos];\n pos = curCaretPos - 1;\n while (pos > 0 && indexMap[pos] === -1) {\n pos--;\n }\n var startIndex = pos === -1 || indexMap[pos] === -1 ? 0 : indexMap[pos] + 1;\n /**\n * case where a char is added on suffix and removed from middle, example 2sq345 becoming $2,345 sq\n * there is still a mapping but the order of start index and end index is changed\n */\n if (startIndex > endIndex) {\n return endIndex;\n }\n /**\n * given the current caret position if it closer to startIndex\n * keep the new caret position on start index or keep it closer to endIndex\n */\n return curCaretPos - startIndex < endIndex - curCaretPos ? startIndex : endIndex;\n}\n/* This keeps the caret within typing area so people can't type in between prefix or suffix or format characters */\nfunction getCaretPosInBoundary(value, caretPos, boundary, direction) {\n var valLn = value.length;\n // clamp caret position to [0, value.length]\n caretPos = clamp(caretPos, 0, valLn);\n if (direction === 'left') {\n while (caretPos >= 0 && !boundary[caretPos]) {\n caretPos--;\n }\n // if we don't find any suitable caret position on left, set it on first allowed position\n if (caretPos === -1) {\n caretPos = boundary.indexOf(true);\n }\n } else {\n while (caretPos <= valLn && !boundary[caretPos]) {\n caretPos++;\n }\n // if we don't find any suitable caret position on right, set it on last allowed position\n if (caretPos > valLn) {\n caretPos = boundary.lastIndexOf(true);\n }\n }\n // if we still don't find caret position, set it at the end of value\n if (caretPos === -1) {\n caretPos = valLn;\n }\n return caretPos;\n}\nfunction caretUnknownFormatBoundary(formattedValue) {\n var boundaryAry = Array.from({\n length: formattedValue.length + 1\n }).map(function () {\n return true;\n });\n for (var i = 0, ln = boundaryAry.length; i < ln; i++) {\n // consider caret to be in boundary if it is before or after numeric value\n boundaryAry[i] = Boolean(charIsNumber(formattedValue[i]) || charIsNumber(formattedValue[i - 1]));\n }\n return boundaryAry;\n}\nfunction useInternalValues(value, defaultValue, valueIsNumericString, format, removeFormatting, onValueChange) {\n if (onValueChange === void 0) onValueChange = noop;\n var getValues = usePersistentCallback(function (value, valueIsNumericString) {\n var formattedValue, numAsString;\n if (isNotValidValue(value)) {\n numAsString = '';\n formattedValue = '';\n } else if (typeof value === 'number' || valueIsNumericString) {\n numAsString = typeof value === 'number' ? toNumericString(value) : value;\n formattedValue = format(numAsString);\n } else {\n numAsString = removeFormatting(value, undefined);\n formattedValue = format(numAsString);\n }\n return {\n formattedValue: formattedValue,\n numAsString: numAsString\n };\n });\n var ref = useState(function () {\n return getValues(isNil(value) ? defaultValue : value, valueIsNumericString);\n });\n var values = ref[0];\n var setValues = ref[1];\n var _onValueChange = function _onValueChange(newValues, sourceInfo) {\n if (newValues.formattedValue !== values.formattedValue) {\n setValues({\n formattedValue: newValues.formattedValue,\n numAsString: newValues.value\n });\n }\n // call parent on value change if only if formatted value is changed\n onValueChange(newValues, sourceInfo);\n };\n // if value is switch from controlled to uncontrolled, use the internal state's value to format with new props\n var _value = value;\n var _valueIsNumericString = valueIsNumericString;\n if (isNil(value)) {\n _value = values.numAsString;\n _valueIsNumericString = true;\n }\n var newValues = getValues(_value, _valueIsNumericString);\n useMemo(function () {\n setValues(newValues);\n }, [newValues.formattedValue]);\n return [values, _onValueChange];\n}\nfunction defaultRemoveFormatting(value) {\n return value.replace(/[^0-9]/g, '');\n}\nfunction defaultFormat(value) {\n return value;\n}\nfunction NumberFormatBase(props) {\n var type = props.type;\n if (type === void 0) type = 'text';\n var displayType = props.displayType;\n if (displayType === void 0) displayType = 'input';\n var customInput = props.customInput;\n var renderText = props.renderText;\n var getInputRef = props.getInputRef;\n var format = props.format;\n if (format === void 0) format = defaultFormat;\n var removeFormatting = props.removeFormatting;\n if (removeFormatting === void 0) removeFormatting = defaultRemoveFormatting;\n var defaultValue = props.defaultValue;\n var valueIsNumericString = props.valueIsNumericString;\n var onValueChange = props.onValueChange;\n var isAllowed = props.isAllowed;\n var onChange = props.onChange;\n if (onChange === void 0) onChange = noop;\n var onKeyDown = props.onKeyDown;\n if (onKeyDown === void 0) onKeyDown = noop;\n var onMouseUp = props.onMouseUp;\n if (onMouseUp === void 0) onMouseUp = noop;\n var onFocus = props.onFocus;\n if (onFocus === void 0) onFocus = noop;\n var onBlur = props.onBlur;\n if (onBlur === void 0) onBlur = noop;\n var propValue = props.value;\n var getCaretBoundary = props.getCaretBoundary;\n if (getCaretBoundary === void 0) getCaretBoundary = caretUnknownFormatBoundary;\n var isValidInputCharacter = props.isValidInputCharacter;\n if (isValidInputCharacter === void 0) isValidInputCharacter = charIsNumber;\n var isCharacterSame = props.isCharacterSame;\n var otherProps = __rest(props, [\"type\", \"displayType\", \"customInput\", \"renderText\", \"getInputRef\", \"format\", \"removeFormatting\", \"defaultValue\", \"valueIsNumericString\", \"onValueChange\", \"isAllowed\", \"onChange\", \"onKeyDown\", \"onMouseUp\", \"onFocus\", \"onBlur\", \"value\", \"getCaretBoundary\", \"isValidInputCharacter\", \"isCharacterSame\"]);\n var ref = useInternalValues(propValue, defaultValue, Boolean(valueIsNumericString), format, removeFormatting, onValueChange);\n var ref_0 = ref[0];\n var formattedValue = ref_0.formattedValue;\n var numAsString = ref_0.numAsString;\n var onFormattedValueChange = ref[1];\n var caretPositionBeforeChange = useRef();\n var lastUpdatedValue = useRef({\n formattedValue: formattedValue,\n numAsString: numAsString\n });\n var _onValueChange = function _onValueChange(values, source) {\n lastUpdatedValue.current = {\n formattedValue: values.formattedValue,\n numAsString: values.value\n };\n onFormattedValueChange(values, source);\n };\n var ref$1 = useState(false);\n var mounted = ref$1[0];\n var setMounted = ref$1[1];\n var focusedElm = useRef(null);\n var timeout = useRef({\n setCaretTimeout: null,\n focusTimeout: null\n });\n useEffect(function () {\n setMounted(true);\n return function () {\n clearTimeout(timeout.current.setCaretTimeout);\n clearTimeout(timeout.current.focusTimeout);\n };\n }, []);\n var _format = format;\n var getValueObject = function getValueObject(formattedValue, numAsString) {\n var floatValue = parseFloat(numAsString);\n return {\n formattedValue: formattedValue,\n value: numAsString,\n floatValue: isNaN(floatValue) ? undefined : floatValue\n };\n };\n var setPatchedCaretPosition = function setPatchedCaretPosition(el, caretPos, currentValue) {\n // don't reset the caret position when the whole input content is selected\n if (el.selectionStart === 0 && el.selectionEnd === el.value.length) {\n return;\n }\n /* setting caret position within timeout of 0ms is required for mobile chrome,\n otherwise browser resets the caret position after we set it\n We are also setting it without timeout so that in normal browser we don't see the flickering */\n setCaretPosition(el, caretPos);\n timeout.current.setCaretTimeout = setTimeout(function () {\n if (el.value === currentValue && el.selectionStart !== caretPos) {\n setCaretPosition(el, caretPos);\n }\n }, 0);\n };\n /* This keeps the caret within typing area so people can't type in between prefix or suffix */\n var correctCaretPosition = function correctCaretPosition(value, caretPos, direction) {\n return getCaretPosInBoundary(value, caretPos, getCaretBoundary(value), direction);\n };\n var getNewCaretPosition = function getNewCaretPosition(inputValue, newFormattedValue, caretPos) {\n var caretBoundary = getCaretBoundary(newFormattedValue);\n var updatedCaretPos = getCaretPosition(newFormattedValue, formattedValue, inputValue, caretPos, caretBoundary, isValidInputCharacter, isCharacterSame);\n //correct caret position if its outside of editable area\n updatedCaretPos = getCaretPosInBoundary(newFormattedValue, updatedCaretPos, caretBoundary);\n return updatedCaretPos;\n };\n var updateValueAndCaretPosition = function updateValueAndCaretPosition(params) {\n var newFormattedValue = params.formattedValue;\n if (newFormattedValue === void 0) newFormattedValue = '';\n var input = params.input;\n var source = params.source;\n var event = params.event;\n var numAsString = params.numAsString;\n var caretPos;\n if (input) {\n var inputValue = params.inputValue || input.value;\n var currentCaretPosition = geInputCaretPosition(input);\n /**\n * set the value imperatively, this is required for IE fix\n * This is also required as if new caret position is beyond the previous value.\n * Caret position will not be set correctly\n */\n input.value = newFormattedValue;\n //get the caret position\n caretPos = getNewCaretPosition(inputValue, newFormattedValue, currentCaretPosition);\n //set caret position imperatively\n if (caretPos !== undefined) {\n setPatchedCaretPosition(input, caretPos, newFormattedValue);\n }\n }\n if (newFormattedValue !== formattedValue) {\n // trigger onValueChange synchronously, so parent is updated along with the number format. Fix for #277, #287\n _onValueChange(getValueObject(newFormattedValue, numAsString), {\n event: event,\n source: source\n });\n }\n };\n /**\n * if the formatted value is not synced to parent, or if the formatted value is different from last synced value sync it\n * if the formatting props is removed, in which case last formatted value will be different from the numeric string value\n * in such case we need to inform the parent.\n */\n useEffect(function () {\n var ref = lastUpdatedValue.current;\n var lastFormattedValue = ref.formattedValue;\n var lastNumAsString = ref.numAsString;\n if (formattedValue !== lastFormattedValue || numAsString !== lastNumAsString) {\n _onValueChange(getValueObject(formattedValue, numAsString), {\n event: undefined,\n source: SourceType.props\n });\n }\n }, [formattedValue, numAsString]);\n // also if formatted value is changed from the props, we need to update the caret position\n // keep the last caret position if element is focused\n var currentCaretPosition = focusedElm.current ? geInputCaretPosition(focusedElm.current) : undefined;\n // needed to prevent warning with useLayoutEffect on server\n var useIsomorphicLayoutEffect = typeof window !== 'undefined' ? useLayoutEffect : useEffect;\n useIsomorphicLayoutEffect(function () {\n var input = focusedElm.current;\n if (formattedValue !== lastUpdatedValue.current.formattedValue && input) {\n var caretPos = getNewCaretPosition(lastUpdatedValue.current.formattedValue, formattedValue, currentCaretPosition);\n /**\n * set the value imperatively, as we set the caret position as well imperatively.\n * This is to keep value and caret position in sync\n */\n input.value = formattedValue;\n setPatchedCaretPosition(input, caretPos, formattedValue);\n }\n }, [formattedValue]);\n var formatInputValue = function formatInputValue(inputValue, event, source) {\n var input = event.target;\n var changeRange = caretPositionBeforeChange.current ? findChangedRangeFromCaretPositions(caretPositionBeforeChange.current, input.selectionEnd) : findChangeRange(formattedValue, inputValue);\n var changeMeta = Object.assign(Object.assign({}, changeRange), {\n lastValue: formattedValue\n });\n var _numAsString = removeFormatting(inputValue, changeMeta);\n var _formattedValue = _format(_numAsString);\n // formatting can remove some of the number chars, so we need to fine number string again\n _numAsString = removeFormatting(_formattedValue, undefined);\n if (isAllowed && !isAllowed(getValueObject(_formattedValue, _numAsString))) {\n //reset the caret position\n var input$1 = event.target;\n var currentCaretPosition = geInputCaretPosition(input$1);\n var caretPos = getNewCaretPosition(inputValue, formattedValue, currentCaretPosition);\n input$1.value = formattedValue;\n setPatchedCaretPosition(input$1, caretPos, formattedValue);\n return false;\n }\n updateValueAndCaretPosition({\n formattedValue: _formattedValue,\n numAsString: _numAsString,\n inputValue: inputValue,\n event: event,\n source: source,\n input: event.target\n });\n return true;\n };\n var setCaretPositionInfoBeforeChange = function setCaretPositionInfoBeforeChange(el, endOffset) {\n if (endOffset === void 0) endOffset = 0;\n var selectionStart = el.selectionStart;\n var selectionEnd = el.selectionEnd;\n caretPositionBeforeChange.current = {\n selectionStart: selectionStart,\n selectionEnd: selectionEnd + endOffset\n };\n };\n var _onChange = function _onChange(e) {\n var el = e.target;\n var inputValue = el.value;\n var changed = formatInputValue(inputValue, e, SourceType.event);\n if (changed) {\n onChange(e);\n }\n // reset the position, as we have already handled the caret position\n caretPositionBeforeChange.current = undefined;\n };\n var _onKeyDown = function _onKeyDown(e) {\n var el = e.target;\n var key = e.key;\n var selectionStart = el.selectionStart;\n var selectionEnd = el.selectionEnd;\n var value = el.value;\n if (value === void 0) value = '';\n var expectedCaretPosition;\n //Handle backspace and delete against non numerical/decimal characters or arrow keys\n if (key === 'ArrowLeft' || key === 'Backspace') {\n expectedCaretPosition = Math.max(selectionStart - 1, 0);\n } else if (key === 'ArrowRight') {\n expectedCaretPosition = Math.min(selectionStart + 1, value.length);\n } else if (key === 'Delete') {\n expectedCaretPosition = selectionStart;\n }\n // if key is delete and text is not selected keep the end offset to 1, as it deletes one character\n // this is required as selection is not changed on delete case, which changes the change range calculation\n var endOffset = 0;\n if (key === 'Delete' && selectionStart === selectionEnd) {\n endOffset = 1;\n }\n var isArrowKey = key === 'ArrowLeft' || key === 'ArrowRight';\n //if expectedCaretPosition is not set it means we don't want to Handle keyDown\n // also if multiple characters are selected don't handle\n if (expectedCaretPosition === undefined || selectionStart !== selectionEnd && !isArrowKey) {\n onKeyDown(e);\n // keep information of what was the caret position before keyDown\n // set it after onKeyDown, in case parent updates the position manually\n setCaretPositionInfoBeforeChange(el, endOffset);\n return;\n }\n var newCaretPosition = expectedCaretPosition;\n if (isArrowKey) {\n var direction = key === 'ArrowLeft' ? 'left' : 'right';\n newCaretPosition = correctCaretPosition(value, expectedCaretPosition, direction);\n // arrow left or right only moves the caret, so no need to handle the event, if we are handling it manually\n if (newCaretPosition !== expectedCaretPosition) {\n e.preventDefault();\n }\n } else if (key === 'Delete' && !isValidInputCharacter(value[expectedCaretPosition])) {\n // in case of delete go to closest caret boundary on the right side\n newCaretPosition = correctCaretPosition(value, expectedCaretPosition, 'right');\n } else if (key === 'Backspace' && !isValidInputCharacter(value[expectedCaretPosition])) {\n // in case of backspace go to closest caret boundary on the left side\n newCaretPosition = correctCaretPosition(value, expectedCaretPosition, 'left');\n }\n if (newCaretPosition !== expectedCaretPosition) {\n setPatchedCaretPosition(el, newCaretPosition, value);\n }\n onKeyDown(e);\n setCaretPositionInfoBeforeChange(el, endOffset);\n };\n /** required to handle the caret position when click anywhere within the input **/\n var _onMouseUp = function _onMouseUp(e) {\n var el = e.target;\n /**\n * NOTE: we have to give default value for value as in case when custom input is provided\n * value can come as undefined when nothing is provided on value prop.\n */\n var correctCaretPositionIfRequired = function correctCaretPositionIfRequired() {\n var selectionStart = el.selectionStart;\n var selectionEnd = el.selectionEnd;\n var value = el.value;\n if (value === void 0) value = '';\n if (selectionStart === selectionEnd) {\n var caretPosition = correctCaretPosition(value, selectionStart);\n if (caretPosition !== selectionStart) {\n setPatchedCaretPosition(el, caretPosition, value);\n }\n }\n };\n correctCaretPositionIfRequired();\n // try to correct after selection has updated by browser\n // this case is required when user clicks on some position while a text is selected on input\n requestAnimationFrame(function () {\n correctCaretPositionIfRequired();\n });\n onMouseUp(e);\n setCaretPositionInfoBeforeChange(el);\n };\n var _onFocus = function _onFocus(e) {\n // Workaround Chrome and Safari bug https://bugs.chromium.org/p/chromium/issues/detail?id=779328\n // (onFocus event target selectionStart is always 0 before setTimeout)\n if (e.persist) {\n e.persist();\n }\n var el = e.target;\n var currentTarget = e.currentTarget;\n focusedElm.current = el;\n timeout.current.focusTimeout = setTimeout(function () {\n var selectionStart = el.selectionStart;\n var selectionEnd = el.selectionEnd;\n var value = el.value;\n if (value === void 0) value = '';\n var caretPosition = correctCaretPosition(value, selectionStart);\n //setPatchedCaretPosition only when everything is not selected on focus (while tabbing into the field)\n if (caretPosition !== selectionStart && !(selectionStart === 0 && selectionEnd === value.length)) {\n setPatchedCaretPosition(el, caretPosition, value);\n }\n onFocus(Object.assign(Object.assign({}, e), {\n currentTarget: currentTarget\n }));\n }, 0);\n };\n var _onBlur = function _onBlur(e) {\n focusedElm.current = null;\n clearTimeout(timeout.current.focusTimeout);\n clearTimeout(timeout.current.setCaretTimeout);\n onBlur(e);\n };\n // add input mode on element based on format prop and device once the component is mounted\n var inputMode = mounted && addInputMode() ? 'numeric' : undefined;\n var inputProps = Object.assign({\n inputMode: inputMode\n }, otherProps, {\n type: type,\n value: formattedValue,\n onChange: _onChange,\n onKeyDown: _onKeyDown,\n onMouseUp: _onMouseUp,\n onFocus: _onFocus,\n onBlur: _onBlur\n });\n if (displayType === 'text') {\n return renderText ? /*#__PURE__*/React.createElement(React.Fragment, null, renderText(formattedValue, otherProps) || null) : /*#__PURE__*/React.createElement(\"span\", Object.assign({}, otherProps, {\n ref: getInputRef\n }), formattedValue);\n } else if (customInput) {\n var CustomInput = customInput;\n /* @ts-ignore */\n return /*#__PURE__*/React.createElement(CustomInput, Object.assign({}, inputProps, {\n ref: getInputRef\n }));\n }\n return /*#__PURE__*/React.createElement(\"input\", Object.assign({}, inputProps, {\n ref: getInputRef\n }));\n}\nfunction format(numStr, props) {\n var decimalScale = props.decimalScale;\n var fixedDecimalScale = props.fixedDecimalScale;\n var prefix = props.prefix;\n if (prefix === void 0) prefix = '';\n var suffix = props.suffix;\n if (suffix === void 0) suffix = '';\n var allowNegative = props.allowNegative;\n var thousandsGroupStyle = props.thousandsGroupStyle;\n if (thousandsGroupStyle === void 0) thousandsGroupStyle = 'thousand';\n // don't apply formatting on empty string or '-'\n if (numStr === '' || numStr === '-') {\n return numStr;\n }\n var ref = getSeparators(props);\n var thousandSeparator = ref.thousandSeparator;\n var decimalSeparator = ref.decimalSeparator;\n /**\n * Keep the decimal separator\n * when decimalScale is not defined or non zero and the numStr has decimal in it\n * Or if decimalScale is > 0 and fixeDecimalScale is true (even if numStr has no decimal)\n */\n var hasDecimalSeparator = decimalScale !== 0 && numStr.indexOf('.') !== -1 || decimalScale && fixedDecimalScale;\n var ref$1 = splitDecimal(numStr, allowNegative);\n var beforeDecimal = ref$1.beforeDecimal;\n var afterDecimal = ref$1.afterDecimal;\n var addNegation = ref$1.addNegation; // eslint-disable-line prefer-const\n //apply decimal precision if its defined\n if (decimalScale !== undefined) {\n afterDecimal = limitToScale(afterDecimal, decimalScale, !!fixedDecimalScale);\n }\n if (thousandSeparator) {\n beforeDecimal = applyThousandSeparator(beforeDecimal, thousandSeparator, thousandsGroupStyle);\n }\n //add prefix and suffix when there is a number present\n if (prefix) {\n beforeDecimal = prefix + beforeDecimal;\n }\n if (suffix) {\n afterDecimal = afterDecimal + suffix;\n }\n //restore negation sign\n if (addNegation) {\n beforeDecimal = '-' + beforeDecimal;\n }\n numStr = beforeDecimal + (hasDecimalSeparator && decimalSeparator || '') + afterDecimal;\n return numStr;\n}\nfunction getSeparators(props) {\n var decimalSeparator = props.decimalSeparator;\n if (decimalSeparator === void 0) decimalSeparator = '.';\n var thousandSeparator = props.thousandSeparator;\n var allowedDecimalSeparators = props.allowedDecimalSeparators;\n if (thousandSeparator === true) {\n thousandSeparator = ',';\n }\n if (!allowedDecimalSeparators) {\n allowedDecimalSeparators = [decimalSeparator, '.'];\n }\n return {\n decimalSeparator: decimalSeparator,\n thousandSeparator: thousandSeparator,\n allowedDecimalSeparators: allowedDecimalSeparators\n };\n}\nfunction handleNegation(value, allowNegative) {\n if (value === void 0) value = '';\n var negationRegex = new RegExp('(-)');\n var doubleNegationRegex = new RegExp('(-)(.)*(-)');\n // Check number has '-' value\n var hasNegation = negationRegex.test(value);\n // Check number has 2 or more '-' values\n var removeNegation = doubleNegationRegex.test(value);\n //remove negation\n value = value.replace(/-/g, '');\n if (hasNegation && !removeNegation && allowNegative) {\n value = '-' + value;\n }\n return value;\n}\nfunction getNumberRegex(decimalSeparator, global) {\n return new RegExp(\"(^-)|[0-9]|\" + escapeRegExp(decimalSeparator), global ? 'g' : undefined);\n}\nfunction isNumericString(val, prefix, suffix) {\n // for empty value we can always treat it as numeric string\n if (val === '') {\n return true;\n }\n return !(prefix === null || prefix === void 0 ? void 0 : prefix.match(/\\d/)) && !(suffix === null || suffix === void 0 ? void 0 : suffix.match(/\\d/)) && typeof val === 'string' && !isNaN(Number(val));\n}\nfunction removeFormatting(value, changeMeta, props) {\n var assign;\n if (changeMeta === void 0) changeMeta = getDefaultChangeMeta(value);\n var allowNegative = props.allowNegative;\n var prefix = props.prefix;\n if (prefix === void 0) prefix = '';\n var suffix = props.suffix;\n if (suffix === void 0) suffix = '';\n var decimalScale = props.decimalScale;\n var from = changeMeta.from;\n var to = changeMeta.to;\n var start = to.start;\n var end = to.end;\n var ref = getSeparators(props);\n var allowedDecimalSeparators = ref.allowedDecimalSeparators;\n var decimalSeparator = ref.decimalSeparator;\n var isBeforeDecimalSeparator = value[end] === decimalSeparator;\n /**\n * If only a number is added on empty input which matches with the prefix or suffix,\n * then don't remove it, just return the same\n */\n if (charIsNumber(value) && (value === prefix || value === suffix) && changeMeta.lastValue === '') {\n return value;\n }\n /** Check for any allowed decimal separator is added in the numeric format and replace it with decimal separator */\n if (end - start === 1 && allowedDecimalSeparators.indexOf(value[start]) !== -1) {\n var separator = decimalScale === 0 ? '' : decimalSeparator;\n value = value.substring(0, start) + separator + value.substring(start + 1, value.length);\n }\n var stripNegation = function stripNegation(value, start, end) {\n /**\n * if prefix starts with - we don't allow negative number to avoid confusion\n * if suffix starts with - and the value length is same as suffix length, then the - sign is from the suffix\n * In other cases, if the value starts with - then it is a negation\n */\n var hasNegation = false;\n var hasDoubleNegation = false;\n if (prefix.startsWith('-')) {\n hasNegation = false;\n } else if (value.startsWith('--')) {\n hasNegation = false;\n hasDoubleNegation = true;\n } else if (suffix.startsWith('-') && value.length === suffix.length) {\n hasNegation = false;\n } else if (value[0] === '-') {\n hasNegation = true;\n }\n var charsToRemove = hasNegation ? 1 : 0;\n if (hasDoubleNegation) {\n charsToRemove = 2;\n }\n // remove negation/double negation from start to simplify prefix logic as negation comes before prefix\n if (charsToRemove) {\n value = value.substring(charsToRemove);\n // account for the removal of the negation for start and end index\n start -= charsToRemove;\n end -= charsToRemove;\n }\n return {\n value: value,\n start: start,\n end: end,\n hasNegation: hasNegation\n };\n };\n var toMetadata = stripNegation(value, start, end);\n var hasNegation = toMetadata.hasNegation;\n assign = toMetadata, value = assign.value, start = assign.start, end = assign.end;\n var ref$1 = stripNegation(changeMeta.lastValue, from.start, from.end);\n var fromStart = ref$1.start;\n var fromEnd = ref$1.end;\n var lastValue = ref$1.value;\n // if only prefix and suffix part is updated reset the value to last value\n // if the changed range is from suffix in the updated value, and the the suffix starts with the same characters, allow the change\n var updatedSuffixPart = value.substring(start, end);\n if (value.length && lastValue.length && (fromStart > lastValue.length - suffix.length || fromEnd < prefix.length) && !(updatedSuffixPart && suffix.startsWith(updatedSuffixPart))) {\n value = lastValue;\n }\n /**\n * remove prefix\n * Remove whole prefix part if its present on the value\n * If the prefix is partially deleted (in which case change start index will be less the prefix length)\n * Remove only partial part of prefix.\n */\n var startIndex = 0;\n if (value.startsWith(prefix)) {\n startIndex += prefix.length;\n } else if (start < prefix.length) {\n startIndex = start;\n }\n value = value.substring(startIndex);\n // account for deleted prefix for end\n end -= startIndex;\n /**\n * Remove suffix\n * Remove whole suffix part if its present on the value\n * If the suffix is partially deleted (in which case change end index will be greater than the suffixStartIndex)\n * remove the partial part of suffix\n */\n var endIndex = value.length;\n var suffixStartIndex = value.length - suffix.length;\n if (value.endsWith(suffix)) {\n endIndex = suffixStartIndex;\n }\n // if the suffix is removed from the end\n else if (end > suffixStartIndex) {\n endIndex = end;\n }\n // if the suffix is removed from start\n else if (end > value.length - suffix.length) {\n endIndex = end;\n }\n value = value.substring(0, endIndex);\n // add the negation back and handle for double negation\n value = handleNegation(hasNegation ? \"-\" + value : value, allowNegative);\n // remove non numeric characters\n value = (value.match(getNumberRegex(decimalSeparator, true)) || []).join('');\n // replace the decimalSeparator with ., and only keep the first separator, ignore following ones\n var firstIndex = value.indexOf(decimalSeparator);\n value = value.replace(new RegExp(escapeRegExp(decimalSeparator), 'g'), function (match, index) {\n return index === firstIndex ? '.' : '';\n });\n //check if beforeDecimal got deleted and there is nothing after decimal,\n //clear all numbers in such case while keeping the - sign\n var ref$2 = splitDecimal(value, allowNegative);\n var beforeDecimal = ref$2.beforeDecimal;\n var afterDecimal = ref$2.afterDecimal;\n var addNegation = ref$2.addNegation; // eslint-disable-line prefer-const\n //clear only if something got deleted before decimal (cursor is before decimal)\n if (to.end - to.start < from.end - from.start && beforeDecimal === '' && isBeforeDecimalSeparator && !parseFloat(afterDecimal)) {\n value = addNegation ? '-' : '';\n }\n return value;\n}\nfunction _getCaretBoundary2(formattedValue, props) {\n var prefix = props.prefix;\n if (prefix === void 0) prefix = '';\n var suffix = props.suffix;\n if (suffix === void 0) suffix = '';\n var boundaryAry = Array.from({\n length: formattedValue.length + 1\n }).map(function () {\n return true;\n });\n var hasNegation = formattedValue[0] === '-';\n // fill for prefix and negation\n boundaryAry.fill(false, 0, prefix.length + (hasNegation ? 1 : 0));\n // fill for suffix\n var valLn = formattedValue.length;\n boundaryAry.fill(false, valLn - suffix.length + 1, valLn + 1);\n return boundaryAry;\n}\nfunction validateAndUpdateProps(props) {\n var ref = getSeparators(props);\n var thousandSeparator = ref.thousandSeparator;\n var decimalSeparator = ref.decimalSeparator;\n // eslint-disable-next-line prefer-const\n var prefix = props.prefix;\n if (prefix === void 0) prefix = '';\n var allowNegative = props.allowNegative;\n if (allowNegative === void 0) allowNegative = true;\n if (thousandSeparator === decimalSeparator) {\n throw new Error(\"\\n Decimal separator can't be same as thousand separator.\\n thousandSeparator: \" + thousandSeparator + \" (thousandSeparator = {true} is same as thousandSeparator = \\\",\\\")\\n decimalSeparator: \" + decimalSeparator + \" (default value for decimalSeparator is .)\\n \");\n }\n if (prefix.startsWith('-') && allowNegative) {\n // TODO: throw error in next major version\n console.error(\"\\n Prefix can't start with '-' when allowNegative is true.\\n prefix: \" + prefix + \"\\n allowNegative: \" + allowNegative + \"\\n \");\n allowNegative = false;\n }\n return Object.assign(Object.assign({}, props), {\n allowNegative: allowNegative\n });\n}\nfunction useNumericFormat(props) {\n // validate props\n props = validateAndUpdateProps(props);\n var _decimalSeparator = props.decimalSeparator;\n var _allowedDecimalSeparators = props.allowedDecimalSeparators;\n var thousandsGroupStyle = props.thousandsGroupStyle;\n var suffix = props.suffix;\n var allowNegative = props.allowNegative;\n var allowLeadingZeros = props.allowLeadingZeros;\n var onKeyDown = props.onKeyDown;\n if (onKeyDown === void 0) onKeyDown = noop;\n var onBlur = props.onBlur;\n if (onBlur === void 0) onBlur = noop;\n var thousandSeparator = props.thousandSeparator;\n var decimalScale = props.decimalScale;\n var fixedDecimalScale = props.fixedDecimalScale;\n var prefix = props.prefix;\n if (prefix === void 0) prefix = '';\n var defaultValue = props.defaultValue;\n var value = props.value;\n var valueIsNumericString = props.valueIsNumericString;\n var onValueChange = props.onValueChange;\n var restProps = __rest(props, [\"decimalSeparator\", \"allowedDecimalSeparators\", \"thousandsGroupStyle\", \"suffix\", \"allowNegative\", \"allowLeadingZeros\", \"onKeyDown\", \"onBlur\", \"thousandSeparator\", \"decimalScale\", \"fixedDecimalScale\", \"prefix\", \"defaultValue\", \"value\", \"valueIsNumericString\", \"onValueChange\"]);\n // get derived decimalSeparator and allowedDecimalSeparators\n var ref = getSeparators(props);\n var decimalSeparator = ref.decimalSeparator;\n var allowedDecimalSeparators = ref.allowedDecimalSeparators;\n var _format = function _format(numStr) {\n return format(numStr, props);\n };\n var _removeFormatting = function _removeFormatting(inputValue, changeMeta) {\n return removeFormatting(inputValue, changeMeta, props);\n };\n var _value = isNil(value) ? defaultValue : value;\n // try to figure out isValueNumericString based on format prop and value\n var _valueIsNumericString = valueIsNumericString !== null && valueIsNumericString !== void 0 ? valueIsNumericString : isNumericString(_value, prefix, suffix);\n if (!isNil(value)) {\n _valueIsNumericString = _valueIsNumericString || typeof value === 'number';\n } else if (!isNil(defaultValue)) {\n _valueIsNumericString = _valueIsNumericString || typeof defaultValue === 'number';\n }\n var roundIncomingValueToPrecision = function roundIncomingValueToPrecision(value) {\n if (isNotValidValue(value)) {\n return value;\n }\n if (typeof value === 'number') {\n value = toNumericString(value);\n }\n /**\n * only round numeric or float string values coming through props,\n * we don't need to do it for onChange events, as we want to prevent typing there\n */\n if (_valueIsNumericString && typeof decimalScale === 'number') {\n return roundToPrecision(value, decimalScale, Boolean(fixedDecimalScale));\n }\n return value;\n };\n var ref$1 = useInternalValues(roundIncomingValueToPrecision(value), roundIncomingValueToPrecision(defaultValue), Boolean(_valueIsNumericString), _format, _removeFormatting, onValueChange);\n var ref$1_0 = ref$1[0];\n var numAsString = ref$1_0.numAsString;\n var formattedValue = ref$1_0.formattedValue;\n var _onValueChange = ref$1[1];\n var _onKeyDown = function _onKeyDown(e) {\n var el = e.target;\n var key = e.key;\n var selectionStart = el.selectionStart;\n var selectionEnd = el.selectionEnd;\n var value = el.value;\n if (value === void 0) value = '';\n // if user tries to delete partial prefix then ignore it\n if ((key === 'Backspace' || key === 'Delete') && selectionEnd < prefix.length) {\n e.preventDefault();\n return;\n }\n // if multiple characters are selected and user hits backspace, no need to handle anything manually\n if (selectionStart !== selectionEnd) {\n onKeyDown(e);\n return;\n }\n // if user hits backspace, while the cursor is before prefix, and the input has negation, remove the negation\n if (key === 'Backspace' && value[0] === '-' && selectionStart === prefix.length + 1 && allowNegative) {\n // bring the cursor to after negation\n setCaretPosition(el, 1);\n }\n // don't allow user to delete decimal separator when decimalScale and fixedDecimalScale is set\n if (decimalScale && fixedDecimalScale) {\n if (key === 'Backspace' && value[selectionStart - 1] === decimalSeparator) {\n setCaretPosition(el, selectionStart - 1);\n e.preventDefault();\n } else if (key === 'Delete' && value[selectionStart] === decimalSeparator) {\n e.preventDefault();\n }\n }\n // if user presses the allowed decimal separator before the separator, move the cursor after the separator\n if ((allowedDecimalSeparators === null || allowedDecimalSeparators === void 0 ? void 0 : allowedDecimalSeparators.includes(key)) && value[selectionStart] === decimalSeparator) {\n setCaretPosition(el, selectionStart + 1);\n }\n var _thousandSeparator = thousandSeparator === true ? ',' : thousandSeparator;\n // move cursor when delete or backspace is pressed before/after thousand separator\n if (key === 'Backspace' && value[selectionStart - 1] === _thousandSeparator) {\n setCaretPosition(el, selectionStart - 1);\n }\n if (key === 'Delete' && value[selectionStart] === _thousandSeparator) {\n setCaretPosition(el, selectionStart + 1);\n }\n onKeyDown(e);\n };\n var _onBlur = function _onBlur(e) {\n var _value = numAsString;\n // if there no no numeric value, clear the input\n if (!_value.match(/\\d/g)) {\n _value = '';\n }\n // clear leading 0s\n if (!allowLeadingZeros) {\n _value = fixLeadingZero(_value);\n }\n // apply fixedDecimalScale on blur event\n if (fixedDecimalScale && decimalScale) {\n _value = roundToPrecision(_value, decimalScale, fixedDecimalScale);\n }\n if (_value !== numAsString) {\n var formattedValue = format(_value, props);\n _onValueChange({\n formattedValue: formattedValue,\n value: _value,\n floatValue: parseFloat(_value)\n }, {\n event: e,\n source: SourceType.event\n });\n }\n onBlur(e);\n };\n var isValidInputCharacter = function isValidInputCharacter(inputChar) {\n if (inputChar === decimalSeparator) {\n return true;\n }\n return charIsNumber(inputChar);\n };\n var isCharacterSame = function isCharacterSame(ref) {\n var currentValue = ref.currentValue;\n var lastValue = ref.lastValue;\n var formattedValue = ref.formattedValue;\n var currentValueIndex = ref.currentValueIndex;\n var formattedValueIndex = ref.formattedValueIndex;\n var curChar = currentValue[currentValueIndex];\n var newChar = formattedValue[formattedValueIndex];\n /**\n * NOTE: as thousand separator and allowedDecimalSeparators can be same, we need to check on\n * typed range if we have typed any character from allowedDecimalSeparators, in that case we\n * consider different characters like , and . same within the range of updated value.\n */\n var typedRange = findChangeRange(lastValue, currentValue);\n var to = typedRange.to;\n if (currentValueIndex >= to.start && currentValueIndex < to.end && allowedDecimalSeparators && allowedDecimalSeparators.includes(curChar) && newChar === decimalSeparator) {\n return true;\n }\n return curChar === newChar;\n };\n return Object.assign(Object.assign({}, restProps), {\n value: formattedValue,\n valueIsNumericString: false,\n isValidInputCharacter: isValidInputCharacter,\n isCharacterSame: isCharacterSame,\n onValueChange: _onValueChange,\n format: _format,\n removeFormatting: _removeFormatting,\n getCaretBoundary: function getCaretBoundary(formattedValue) {\n return _getCaretBoundary2(formattedValue, props);\n },\n onKeyDown: _onKeyDown,\n onBlur: _onBlur\n });\n}\nfunction NumericFormat(props) {\n var numericFormatProps = useNumericFormat(props);\n return /*#__PURE__*/React.createElement(NumberFormatBase, Object.assign({}, numericFormatProps));\n}\nfunction format$1(numStr, props) {\n var format = props.format;\n var allowEmptyFormatting = props.allowEmptyFormatting;\n var mask = props.mask;\n var patternChar = props.patternChar;\n if (patternChar === void 0) patternChar = '#';\n if (numStr === '' && !allowEmptyFormatting) {\n return '';\n }\n var hashCount = 0;\n var formattedNumberAry = format.split('');\n for (var i = 0, ln = format.length; i < ln; i++) {\n if (format[i] === patternChar) {\n formattedNumberAry[i] = numStr[hashCount] || getMaskAtIndex(mask, hashCount);\n hashCount += 1;\n }\n }\n return formattedNumberAry.join('');\n}\nfunction removeFormatting$1(value, changeMeta, props) {\n if (changeMeta === void 0) changeMeta = getDefaultChangeMeta(value);\n var format = props.format;\n var patternChar = props.patternChar;\n if (patternChar === void 0) patternChar = '#';\n var from = changeMeta.from;\n var to = changeMeta.to;\n var lastValue = changeMeta.lastValue;\n if (lastValue === void 0) lastValue = '';\n var isNumericSlot = function isNumericSlot(caretPos) {\n return format[caretPos] === patternChar;\n };\n var removeFormatChar = function removeFormatChar(string, startIndex) {\n var str = '';\n for (var i = 0; i < string.length; i++) {\n if (isNumericSlot(startIndex + i) && charIsNumber(string[i])) {\n str += string[i];\n }\n }\n return str;\n };\n var extractNumbers = function extractNumbers(str) {\n return str.replace(/[^0-9]/g, '');\n };\n // if format doesn't have any number, remove all the non numeric characters\n if (!format.match(/\\d/)) {\n return extractNumbers(value);\n }\n /**\n * if user paste the whole formatted text in an empty input or doing select all and paste, check if matches to the pattern\n * and remove the format characters, if there is a mismatch on the pattern, do plane number extract\n */\n if ((lastValue === '' || from.end - from.start === lastValue.length) && value.length === format.length) {\n var str = '';\n for (var i = 0; i < value.length; i++) {\n if (isNumericSlot(i)) {\n if (charIsNumber(value[i])) {\n str += value[i];\n }\n } else if (value[i] !== format[i]) {\n // if there is a mismatch on the pattern, do plane number extract\n return extractNumbers(value);\n }\n }\n return str;\n }\n /**\n * For partial change,\n * where ever there is a change on the input, we can break the number in three parts\n * 1st: left part which is unchanged\n * 2nd: middle part which is changed\n * 3rd: right part which is unchanged\n *\n * The first and third section will be same as last value, only the middle part will change\n * We can consider on the change part all the new characters are non format characters.\n * And on the first and last section it can have partial format characters.\n *\n * We pick first and last section from the lastValue (as that has 1-1 mapping with format)\n * and middle one from the update value.\n */\n var firstSection = lastValue.substring(0, from.start);\n var middleSection = value.substring(to.start, to.end);\n var lastSection = lastValue.substring(from.end);\n return \"\" + removeFormatChar(firstSection, 0) + extractNumbers(middleSection) + removeFormatChar(lastSection, from.end);\n}\nfunction getCaretBoundary$1(formattedValue, props) {\n var format = props.format;\n var mask = props.mask;\n var patternChar = props.patternChar;\n if (patternChar === void 0) patternChar = '#';\n var boundaryAry = Array.from({\n length: formattedValue.length + 1\n }).map(function () {\n return true;\n });\n var hashCount = 0;\n var firstEmptySlot = -1;\n var maskAndIndexMap = {};\n format.split('').forEach(function (char, index) {\n var maskAtIndex = undefined;\n if (char === patternChar) {\n hashCount++;\n maskAtIndex = getMaskAtIndex(mask, hashCount - 1);\n if (firstEmptySlot === -1 && formattedValue[index] === maskAtIndex) {\n firstEmptySlot = index;\n }\n }\n maskAndIndexMap[index] = maskAtIndex;\n });\n var isPosAllowed = function isPosAllowed(pos) {\n // the position is allowed if the position is not masked and valid number area\n return format[pos] === patternChar && formattedValue[pos] !== maskAndIndexMap[pos];\n };\n for (var i = 0, ln = boundaryAry.length; i < ln; i++) {\n // consider caret to be in boundary if it is before or after numeric value\n // Note: on pattern based format its denoted by patternCharacter\n // we should also allow user to put cursor on first empty slot\n boundaryAry[i] = i === firstEmptySlot || isPosAllowed(i) || isPosAllowed(i - 1);\n }\n // the first patternChar position is always allowed\n boundaryAry[format.indexOf(patternChar)] = true;\n return boundaryAry;\n}\nfunction validateProps(props) {\n var mask = props.mask;\n if (mask) {\n var maskAsStr = mask === 'string' ? mask : mask.toString();\n if (maskAsStr.match(/\\d/g)) {\n throw new Error(\"Mask \" + mask + \" should not contain numeric character;\");\n }\n }\n}\nfunction isNumericString$1(val, format) {\n //we can treat empty string as numeric string\n if (val === '') {\n return true;\n }\n return !(format === null || format === void 0 ? void 0 : format.match(/\\d/)) && typeof val === 'string' && (!!val.match(/^\\d+$/) || val === '');\n}\nfunction usePatternFormat(props) {\n var mask = props.mask;\n var allowEmptyFormatting = props.allowEmptyFormatting;\n var formatProp = props.format;\n var inputMode = props.inputMode;\n if (inputMode === void 0) inputMode = 'numeric';\n var onKeyDown = props.onKeyDown;\n if (onKeyDown === void 0) onKeyDown = noop;\n var patternChar = props.patternChar;\n if (patternChar === void 0) patternChar = '#';\n var value = props.value;\n var defaultValue = props.defaultValue;\n var valueIsNumericString = props.valueIsNumericString;\n var restProps = __rest(props, [\"mask\", \"allowEmptyFormatting\", \"format\", \"inputMode\", \"onKeyDown\", \"patternChar\", \"value\", \"defaultValue\", \"valueIsNumericString\"]);\n // validate props\n validateProps(props);\n var _getCaretBoundary = function _getCaretBoundary(formattedValue) {\n return getCaretBoundary$1(formattedValue, props);\n };\n var _onKeyDown = function _onKeyDown(e) {\n var key = e.key;\n var el = e.target;\n var selectionStart = el.selectionStart;\n var selectionEnd = el.selectionEnd;\n var value = el.value;\n // if multiple characters are selected and user hits backspace, no need to handle anything manually\n if (selectionStart !== selectionEnd) {\n onKeyDown(e);\n return;\n }\n // bring the cursor to closest numeric section\n var caretPos = selectionStart;\n // if backspace is pressed after the format characters, bring it to numeric section\n // if delete is pressed before the format characters, bring it to numeric section\n if (key === 'Backspace' || key === 'Delete') {\n var direction = 'right';\n if (key === 'Backspace') {\n while (caretPos > 0 && formatProp[caretPos - 1] !== patternChar) {\n caretPos--;\n }\n direction = 'left';\n } else {\n var formatLn = formatProp.length;\n while (caretPos < formatLn && formatProp[caretPos] !== patternChar) {\n caretPos++;\n }\n direction = 'right';\n }\n caretPos = getCaretPosInBoundary(value, caretPos, _getCaretBoundary(value), direction);\n } else if (formatProp[caretPos] !== patternChar && key !== 'ArrowLeft' && key !== 'ArrowRight') {\n // if user is typing on format character position, bring user to next allowed caret position\n caretPos = getCaretPosInBoundary(value, caretPos + 1, _getCaretBoundary(value), 'right');\n }\n // if we changing caret position, set the caret position\n if (caretPos !== selectionStart) {\n setCaretPosition(el, caretPos);\n }\n onKeyDown(e);\n };\n // try to figure out isValueNumericString based on format prop and value\n var _value = isNil(value) ? defaultValue : value;\n var isValueNumericString = valueIsNumericString !== null && valueIsNumericString !== void 0 ? valueIsNumericString : isNumericString$1(_value, formatProp);\n var _props = Object.assign(Object.assign({}, props), {\n valueIsNumericString: isValueNumericString\n });\n return Object.assign(Object.assign({}, restProps), {\n value: value,\n defaultValue: defaultValue,\n valueIsNumericString: isValueNumericString,\n inputMode: inputMode,\n format: function format(numStr) {\n return format$1(numStr, _props);\n },\n removeFormatting: function removeFormatting(inputValue, changeMeta) {\n return removeFormatting$1(inputValue, changeMeta, _props);\n },\n getCaretBoundary: _getCaretBoundary,\n onKeyDown: _onKeyDown\n });\n}\nfunction PatternFormat(props) {\n var patternFormatProps = usePatternFormat(props);\n return /*#__PURE__*/React.createElement(NumberFormatBase, Object.assign({}, patternFormatProps));\n}\nexport { NumberFormatBase, NumericFormat, PatternFormat, _getCaretBoundary2 as getNumericCaretBoundary, getCaretBoundary$1 as getPatternCaretBoundary, format as numericFormatter, format$1 as patternFormatter, removeFormatting as removeNumericFormat, removeFormatting$1 as removePatternFormat, useNumericFormat, usePatternFormat };","\"use client\";\n\nvar _excluded = [\"__demoMode\"],\n _excluded2 = [\"id\", \"disabled\", \"autoFocus\"],\n _excluded3 = [\"id\", \"anchor\", \"portal\", \"modal\", \"transition\"],\n _excluded4 = [\"id\", \"disabled\"],\n _excluded5 = [\"id\"];\nvar _$e;\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport { useFocusRing as se } from \"@react-aria/focus\";\nimport { useHover as le } from \"@react-aria/interactions\";\nimport v, { Fragment as q, createContext as ue, useCallback as pe, useContext as me, useEffect as de, useMemo as G, useReducer as ce, useRef as z } from \"react\";\nimport { flushSync as O } from \"react-dom\";\nimport { useActivePress as fe } from '../../hooks/use-active-press.js';\nimport { useDidElementMove as Te } from '../../hooks/use-did-element-move.js';\nimport { useDisposables as ye } from '../../hooks/use-disposables.js';\nimport { useElementSize as Ie } from '../../hooks/use-element-size.js';\nimport { useEvent as E } from '../../hooks/use-event.js';\nimport { useId as U } from '../../hooks/use-id.js';\nimport { useInertOthers as ge } from '../../hooks/use-inert-others.js';\nimport { useIsoMorphicEffect as H } from '../../hooks/use-iso-morphic-effect.js';\nimport { useOnDisappear as Ee } from '../../hooks/use-on-disappear.js';\nimport { useOutsideClick as Me } from '../../hooks/use-outside-click.js';\nimport { useOwnerDocument as Se } from '../../hooks/use-owner.js';\nimport { useResolveButtonType as Ae } from '../../hooks/use-resolve-button-type.js';\nimport { useScrollLock as Pe } from '../../hooks/use-scroll-lock.js';\nimport { useSyncRefs as B } from '../../hooks/use-sync-refs.js';\nimport { useTextValue as be } from '../../hooks/use-text-value.js';\nimport { useTrackedPointer as ve } from '../../hooks/use-tracked-pointer.js';\nimport { transitionDataAttributes as xe, useTransition as _e } from '../../hooks/use-transition.js';\nimport { useTreeWalker as Re } from '../../hooks/use-tree-walker.js';\nimport { FloatingProvider as De, useFloatingPanel as he, useFloatingPanelProps as Ce, useFloatingReference as Fe, useFloatingReferenceProps as Oe, useResolvedAnchor as Le } from '../../internal/floating.js';\nimport { OpenClosedProvider as Ge, State as N, useOpenClosed as Ue } from '../../internal/open-closed.js';\nimport { isDisabledReactIssue7711 as He } from '../../utils/bugs.js';\nimport { Focus as I, calculateActiveIndex as K } from '../../utils/calculate-active-index.js';\nimport { disposables as Be } from '../../utils/disposables.js';\nimport { Focus as Y, FocusableMode as Ne, focusFrom as ke, isFocusableElement as we, restoreFocusIfNecessary as Z, sortByDomNode as Ke } from '../../utils/focus-management.js';\nimport { match as ee } from '../../utils/match.js';\nimport { RenderFeatures as te, forwardRefWithAs as x, mergeProps as ne, render as _ } from '../../utils/render.js';\nimport { useDescriptions as We } from '../description/description.js';\nimport { Keys as y } from '../keyboard.js';\nimport { useLabelContext as je, useLabels as re } from '../label/label.js';\nimport { Portal as Qe } from '../portal/portal.js';\nvar Je = function (r) {\n return r[r.Open = 0] = \"Open\", r[r.Closed = 1] = \"Closed\", r;\n }(Je || {}),\n Ve = function (r) {\n return r[r.Pointer = 0] = \"Pointer\", r[r.Other = 1] = \"Other\", r;\n }(Ve || {}),\n Xe = function (a) {\n return a[a.OpenMenu = 0] = \"OpenMenu\", a[a.CloseMenu = 1] = \"CloseMenu\", a[a.GoToItem = 2] = \"GoToItem\", a[a.Search = 3] = \"Search\", a[a.ClearSearch = 4] = \"ClearSearch\", a[a.RegisterItem = 5] = \"RegisterItem\", a[a.UnregisterItem = 6] = \"UnregisterItem\", a[a.SetButtonElement = 7] = \"SetButtonElement\", a[a.SetItemsElement = 8] = \"SetItemsElement\", a;\n }(Xe || {});\nfunction W(e) {\n var n = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : function (r) {\n return r;\n };\n var r = e.activeItemIndex !== null ? e.items[e.activeItemIndex] : null,\n i = Ke(n(e.items.slice()), function (p) {\n return p.dataRef.current.domRef.current;\n }),\n o = r ? i.indexOf(r) : null;\n return o === -1 && (o = null), {\n items: i,\n activeItemIndex: o\n };\n}\nvar $e = (_$e = {}, _defineProperty(_$e, 1, function _(e) {\n return e.menuState === 1 ? e : _objectSpread(_objectSpread({}, e), {}, {\n activeItemIndex: null,\n menuState: 1\n });\n }), _defineProperty(_$e, 0, function _(e) {\n return e.menuState === 0 ? e : _objectSpread(_objectSpread({}, e), {}, {\n __demoMode: !1,\n menuState: 0\n });\n }), _defineProperty(_$e, 2, function _(e, n) {\n var p, m, l, u, a;\n if (e.menuState === 1) return e;\n var r = _objectSpread(_objectSpread({}, e), {}, {\n searchQuery: \"\",\n activationTrigger: (p = n.trigger) != null ? p : 1,\n __demoMode: !1\n });\n if (n.focus === I.Nothing) return _objectSpread(_objectSpread({}, r), {}, {\n activeItemIndex: null\n });\n if (n.focus === I.Specific) return _objectSpread(_objectSpread({}, r), {}, {\n activeItemIndex: e.items.findIndex(function (t) {\n return t.id === n.id;\n })\n });\n if (n.focus === I.Previous) {\n var t = e.activeItemIndex;\n if (t !== null) {\n var d = e.items[t].dataRef.current.domRef,\n f = K(n, {\n resolveItems: function resolveItems() {\n return e.items;\n },\n resolveActiveIndex: function resolveActiveIndex() {\n return e.activeItemIndex;\n },\n resolveId: function resolveId(c) {\n return c.id;\n },\n resolveDisabled: function resolveDisabled(c) {\n return c.dataRef.current.disabled;\n }\n });\n if (f !== null) {\n var c = e.items[f].dataRef.current.domRef;\n if (((m = d.current) == null ? void 0 : m.previousElementSibling) === c.current || ((l = c.current) == null ? void 0 : l.previousElementSibling) === null) return _objectSpread(_objectSpread({}, r), {}, {\n activeItemIndex: f\n });\n }\n }\n } else if (n.focus === I.Next) {\n var _t = e.activeItemIndex;\n if (_t !== null) {\n var _d = e.items[_t].dataRef.current.domRef,\n _f = K(n, {\n resolveItems: function resolveItems() {\n return e.items;\n },\n resolveActiveIndex: function resolveActiveIndex() {\n return e.activeItemIndex;\n },\n resolveId: function resolveId(c) {\n return c.id;\n },\n resolveDisabled: function resolveDisabled(c) {\n return c.dataRef.current.disabled;\n }\n });\n if (_f !== null) {\n var _c = e.items[_f].dataRef.current.domRef;\n if (((u = _d.current) == null ? void 0 : u.nextElementSibling) === _c.current || ((a = _c.current) == null ? void 0 : a.nextElementSibling) === null) return _objectSpread(_objectSpread({}, r), {}, {\n activeItemIndex: _f\n });\n }\n }\n }\n var i = W(e),\n o = K(n, {\n resolveItems: function resolveItems() {\n return i.items;\n },\n resolveActiveIndex: function resolveActiveIndex() {\n return i.activeItemIndex;\n },\n resolveId: function resolveId(t) {\n return t.id;\n },\n resolveDisabled: function resolveDisabled(t) {\n return t.dataRef.current.disabled;\n }\n });\n return _objectSpread(_objectSpread(_objectSpread({}, r), i), {}, {\n activeItemIndex: o\n });\n }), _defineProperty(_$e, 3, function _(e, n) {\n var i = e.searchQuery !== \"\" ? 0 : 1,\n o = e.searchQuery + n.value.toLowerCase(),\n m = (e.activeItemIndex !== null ? e.items.slice(e.activeItemIndex + i).concat(e.items.slice(0, e.activeItemIndex + i)) : e.items).find(function (u) {\n var a;\n return ((a = u.dataRef.current.textValue) == null ? void 0 : a.startsWith(o)) && !u.dataRef.current.disabled;\n }),\n l = m ? e.items.indexOf(m) : -1;\n return l === -1 || l === e.activeItemIndex ? _objectSpread(_objectSpread({}, e), {}, {\n searchQuery: o\n }) : _objectSpread(_objectSpread({}, e), {}, {\n searchQuery: o,\n activeItemIndex: l,\n activationTrigger: 1\n });\n }), _defineProperty(_$e, 4, function _(e) {\n return e.searchQuery === \"\" ? e : _objectSpread(_objectSpread({}, e), {}, {\n searchQuery: \"\",\n searchActiveItemIndex: null\n });\n }), _defineProperty(_$e, 5, function _(e, n) {\n var r = W(e, function (i) {\n return [].concat(_toConsumableArray(i), [{\n id: n.id,\n dataRef: n.dataRef\n }]);\n });\n return _objectSpread(_objectSpread({}, e), r);\n }), _defineProperty(_$e, 6, function _(e, n) {\n var r = W(e, function (i) {\n var o = i.findIndex(function (p) {\n return p.id === n.id;\n });\n return o !== -1 && i.splice(o, 1), i;\n });\n return _objectSpread(_objectSpread(_objectSpread({}, e), r), {}, {\n activationTrigger: 1\n });\n }), _defineProperty(_$e, 7, function _(e, n) {\n return e.buttonElement === n.element ? e : _objectSpread(_objectSpread({}, e), {}, {\n buttonElement: n.element\n });\n }), _defineProperty(_$e, 8, function _(e, n) {\n return e.itemsElement === n.element ? e : _objectSpread(_objectSpread({}, e), {}, {\n itemsElement: n.element\n });\n }), _$e),\n j = /*#__PURE__*/ue(null);\nj.displayName = \"MenuContext\";\nfunction k(e) {\n var n = me(j);\n if (n === null) {\n var r = new Error(\"<\".concat(e, \" /> is missing a parent component.\"));\n throw Error.captureStackTrace && Error.captureStackTrace(r, k), r;\n }\n return n;\n}\nfunction qe(e, n) {\n return ee(n.type, $e, e, n);\n}\nvar ze = q;\nfunction Ye(e, n) {\n var _ee;\n var _e$__demoMode = e.__demoMode,\n r = _e$__demoMode === void 0 ? !1 : _e$__demoMode,\n i = _objectWithoutProperties(e, _excluded),\n o = ce(qe, {\n __demoMode: r,\n menuState: r ? 0 : 1,\n buttonElement: null,\n itemsElement: null,\n items: [],\n searchQuery: \"\",\n activeItemIndex: null,\n activationTrigger: 1\n }),\n _o = _slicedToArray(o, 2),\n _o$ = _o[0],\n p = _o$.menuState,\n m = _o$.itemsElement,\n l = _o$.buttonElement,\n u = _o[1],\n a = B(n);\n Me(p === 0, [l, m], function (A, P) {\n u({\n type: 1\n }), we(P, Ne.Loose) || (A.preventDefault(), l == null || l.focus());\n });\n var d = E(function () {\n u({\n type: 1\n });\n }),\n f = G(function () {\n return {\n open: p === 0,\n close: d\n };\n }, [p, d]),\n c = {\n ref: a\n };\n return /*#__PURE__*/v.createElement(De, null, /*#__PURE__*/v.createElement(j.Provider, {\n value: o\n }, /*#__PURE__*/v.createElement(Ge, {\n value: ee(p, (_ee = {}, _defineProperty(_ee, 0, N.Open), _defineProperty(_ee, 1, N.Closed), _ee))\n }, _({\n ourProps: c,\n theirProps: i,\n slot: f,\n defaultTag: ze,\n name: \"Menu\"\n }))));\n}\nvar Ze = \"button\";\nfunction et(e, n) {\n var D;\n var r = U(),\n _e$id = e.id,\n i = _e$id === void 0 ? \"headlessui-menu-button-\".concat(r) : _e$id,\n _e$disabled = e.disabled,\n o = _e$disabled === void 0 ? !1 : _e$disabled,\n _e$autoFocus = e.autoFocus,\n p = _e$autoFocus === void 0 ? !1 : _e$autoFocus,\n m = _objectWithoutProperties(e, _excluded2),\n _k = k(\"Menu.Button\"),\n _k2 = _slicedToArray(_k, 2),\n l = _k2[0],\n u = _k2[1],\n a = Oe(),\n t = B(n, Fe(), E(function (T) {\n return u({\n type: 7,\n element: T\n });\n })),\n d = E(function (T) {\n switch (T.key) {\n case y.Space:\n case y.Enter:\n case y.ArrowDown:\n T.preventDefault(), T.stopPropagation(), O(function () {\n return u({\n type: 0\n });\n }), u({\n type: 2,\n focus: I.First\n });\n break;\n case y.ArrowUp:\n T.preventDefault(), T.stopPropagation(), O(function () {\n return u({\n type: 0\n });\n }), u({\n type: 2,\n focus: I.Last\n });\n break;\n }\n }),\n f = E(function (T) {\n switch (T.key) {\n case y.Space:\n T.preventDefault();\n break;\n }\n }),\n c = E(function (T) {\n var h;\n if (He(T.currentTarget)) return T.preventDefault();\n o || (l.menuState === 0 ? (O(function () {\n return u({\n type: 1\n });\n }), (h = l.buttonElement) == null || h.focus({\n preventScroll: !0\n })) : (T.preventDefault(), u({\n type: 0\n })));\n }),\n _se = se({\n autoFocus: p\n }),\n A = _se.isFocusVisible,\n P = _se.focusProps,\n _le = le({\n isDisabled: o\n }),\n M = _le.isHovered,\n b = _le.hoverProps,\n _fe = fe({\n disabled: o\n }),\n S = _fe.pressed,\n R = _fe.pressProps,\n C = G(function () {\n return {\n open: l.menuState === 0,\n active: S || l.menuState === 0,\n disabled: o,\n hover: M,\n focus: A,\n autofocus: p\n };\n }, [l, M, A, S, o, p]),\n F = ne(a(), {\n ref: t,\n id: i,\n type: Ae(e, l.buttonElement),\n \"aria-haspopup\": \"menu\",\n \"aria-controls\": (D = l.itemsElement) == null ? void 0 : D.id,\n \"aria-expanded\": l.menuState === 0,\n disabled: o || void 0,\n autoFocus: p,\n onKeyDown: d,\n onKeyUp: f,\n onClick: c\n }, P, b, R);\n return _({\n ourProps: F,\n theirProps: m,\n slot: C,\n defaultTag: Ze,\n name: \"Menu.Button\"\n });\n}\nvar tt = \"div\",\n nt = te.RenderStrategy | te.Static;\nfunction rt(e, n) {\n var Q, J;\n var r = U(),\n _e$id2 = e.id,\n i = _e$id2 === void 0 ? \"headlessui-menu-items-\".concat(r) : _e$id2,\n o = e.anchor,\n _e$portal = e.portal,\n p = _e$portal === void 0 ? !1 : _e$portal,\n _e$modal = e.modal,\n m = _e$modal === void 0 ? !0 : _e$modal,\n _e$transition = e.transition,\n l = _e$transition === void 0 ? !1 : _e$transition,\n u = _objectWithoutProperties(e, _excluded3),\n a = Le(o),\n _k3 = k(\"Menu.Items\"),\n _k4 = _slicedToArray(_k3, 2),\n t = _k4[0],\n d = _k4[1],\n _he = he(a),\n _he2 = _slicedToArray(_he, 2),\n f = _he2[0],\n c = _he2[1],\n A = Ce(),\n P = B(n, a ? f : null, E(function (s) {\n return d({\n type: 8,\n element: s\n });\n })),\n M = Se(t.itemsElement);\n a && (p = !0);\n var b = Ue(),\n _e2 = _e(l, t.itemsElement, b !== null ? (b & N.Open) === N.Open : t.menuState === 0),\n _e3 = _slicedToArray(_e2, 2),\n S = _e3[0],\n R = _e3[1];\n Ee(S, t.buttonElement, function () {\n d({\n type: 1\n });\n });\n var C = t.__demoMode ? !1 : m && t.menuState === 0;\n Pe(C, M);\n var F = t.__demoMode ? !1 : m && t.menuState === 0;\n ge(F, {\n allowed: pe(function () {\n return [t.buttonElement, t.itemsElement];\n }, [t.buttonElement, t.itemsElement])\n });\n var D = t.menuState !== 0,\n h = Te(D, t.buttonElement) ? !1 : S;\n de(function () {\n var s = t.itemsElement;\n s && t.menuState === 0 && s !== (M == null ? void 0 : M.activeElement) && s.focus({\n preventScroll: !0\n });\n }, [t.menuState, t.itemsElement, M]), Re(t.menuState === 0, {\n container: t.itemsElement,\n accept: function accept(s) {\n return s.getAttribute(\"role\") === \"menuitem\" ? NodeFilter.FILTER_REJECT : s.hasAttribute(\"role\") ? NodeFilter.FILTER_SKIP : NodeFilter.FILTER_ACCEPT;\n },\n walk: function walk(s) {\n s.setAttribute(\"role\", \"none\");\n }\n });\n var w = ye(),\n g = E(function (s) {\n var V, X, $;\n switch (w.dispose(), s.key) {\n case y.Space:\n if (t.searchQuery !== \"\") return s.preventDefault(), s.stopPropagation(), d({\n type: 3,\n value: s.key\n });\n case y.Enter:\n if (s.preventDefault(), s.stopPropagation(), d({\n type: 1\n }), t.activeItemIndex !== null) {\n var ie = t.items[t.activeItemIndex].dataRef;\n (X = (V = ie.current) == null ? void 0 : V.domRef.current) == null || X.click();\n }\n Z(t.buttonElement);\n break;\n case y.ArrowDown:\n return s.preventDefault(), s.stopPropagation(), d({\n type: 2,\n focus: I.Next\n });\n case y.ArrowUp:\n return s.preventDefault(), s.stopPropagation(), d({\n type: 2,\n focus: I.Previous\n });\n case y.Home:\n case y.PageUp:\n return s.preventDefault(), s.stopPropagation(), d({\n type: 2,\n focus: I.First\n });\n case y.End:\n case y.PageDown:\n return s.preventDefault(), s.stopPropagation(), d({\n type: 2,\n focus: I.Last\n });\n case y.Escape:\n s.preventDefault(), s.stopPropagation(), O(function () {\n return d({\n type: 1\n });\n }), ($ = t.buttonElement) == null || $.focus({\n preventScroll: !0\n });\n break;\n case y.Tab:\n s.preventDefault(), s.stopPropagation(), O(function () {\n return d({\n type: 1\n });\n }), ke(t.buttonElement, s.shiftKey ? Y.Previous : Y.Next);\n break;\n default:\n s.key.length === 1 && (d({\n type: 3,\n value: s.key\n }), w.setTimeout(function () {\n return d({\n type: 4\n });\n }, 350));\n break;\n }\n }),\n L = E(function (s) {\n switch (s.key) {\n case y.Space:\n s.preventDefault();\n break;\n }\n }),\n oe = G(function () {\n return {\n open: t.menuState === 0\n };\n }, [t.menuState]),\n ae = ne(a ? A() : {}, _objectSpread({\n \"aria-activedescendant\": t.activeItemIndex === null || (Q = t.items[t.activeItemIndex]) == null ? void 0 : Q.id,\n \"aria-labelledby\": (J = t.buttonElement) == null ? void 0 : J.id,\n id: i,\n onKeyDown: g,\n onKeyUp: L,\n role: \"menu\",\n tabIndex: t.menuState === 0 ? 0 : void 0,\n ref: P,\n style: _objectSpread(_objectSpread(_objectSpread({}, u.style), c), {}, {\n \"--button-width\": Ie(t.buttonElement, !0).width\n })\n }, xe(R)));\n return /*#__PURE__*/v.createElement(Qe, {\n enabled: p ? e.static || S : !1\n }, _({\n ourProps: ae,\n theirProps: u,\n slot: oe,\n defaultTag: tt,\n features: nt,\n visible: h,\n name: \"Menu.Items\"\n }));\n}\nvar ot = q;\nfunction at(e, n) {\n var r = U(),\n _e$id3 = e.id,\n i = _e$id3 === void 0 ? \"headlessui-menu-item-\".concat(r) : _e$id3,\n _e$disabled2 = e.disabled,\n o = _e$disabled2 === void 0 ? !1 : _e$disabled2,\n p = _objectWithoutProperties(e, _excluded4),\n _k5 = k(\"Menu.Item\"),\n _k6 = _slicedToArray(_k5, 2),\n m = _k6[0],\n l = _k6[1],\n u = m.activeItemIndex !== null ? m.items[m.activeItemIndex].id === i : !1,\n a = z(null),\n t = B(n, a);\n H(function () {\n if (!m.__demoMode && m.menuState === 0 && u && m.activationTrigger !== 0) return Be().requestAnimationFrame(function () {\n var g, L;\n (L = (g = a.current) == null ? void 0 : g.scrollIntoView) == null || L.call(g, {\n block: \"nearest\"\n });\n });\n }, [m.__demoMode, a, u, m.menuState, m.activationTrigger, m.activeItemIndex]);\n var d = be(a),\n f = z({\n disabled: o,\n domRef: a,\n get textValue() {\n return d();\n }\n });\n H(function () {\n f.current.disabled = o;\n }, [f, o]), H(function () {\n return l({\n type: 5,\n id: i,\n dataRef: f\n }), function () {\n return l({\n type: 6,\n id: i\n });\n };\n }, [f, i]);\n var c = E(function () {\n l({\n type: 1\n });\n }),\n A = E(function (g) {\n if (o) return g.preventDefault();\n l({\n type: 1\n }), Z(m.buttonElement);\n }),\n P = E(function () {\n if (o) return l({\n type: 2,\n focus: I.Nothing\n });\n l({\n type: 2,\n focus: I.Specific,\n id: i\n });\n }),\n M = ve(),\n b = E(function (g) {\n M.update(g), !o && (u || l({\n type: 2,\n focus: I.Specific,\n id: i,\n trigger: 0\n }));\n }),\n S = E(function (g) {\n M.wasMoved(g) && (o || u || l({\n type: 2,\n focus: I.Specific,\n id: i,\n trigger: 0\n }));\n }),\n R = E(function (g) {\n M.wasMoved(g) && (o || u && l({\n type: 2,\n focus: I.Nothing\n }));\n }),\n _re = re(),\n _re2 = _slicedToArray(_re, 2),\n C = _re2[0],\n F = _re2[1],\n _We = We(),\n _We2 = _slicedToArray(_We, 2),\n D = _We2[0],\n T = _We2[1],\n h = G(function () {\n return {\n active: u,\n focus: u,\n disabled: o,\n close: c\n };\n }, [u, o, c]);\n return /*#__PURE__*/v.createElement(F, null, /*#__PURE__*/v.createElement(T, null, _({\n ourProps: {\n id: i,\n ref: t,\n role: \"menuitem\",\n tabIndex: o === !0 ? void 0 : -1,\n \"aria-disabled\": o === !0 ? !0 : void 0,\n \"aria-labelledby\": C,\n \"aria-describedby\": D,\n disabled: void 0,\n onClick: A,\n onFocus: P,\n onPointerEnter: b,\n onMouseEnter: b,\n onPointerMove: S,\n onMouseMove: S,\n onPointerLeave: R,\n onMouseLeave: R\n },\n theirProps: p,\n slot: h,\n defaultTag: ot,\n name: \"Menu.Item\"\n })));\n}\nvar it = \"div\";\nfunction st(e, n) {\n var _re3 = re(),\n _re4 = _slicedToArray(_re3, 2),\n r = _re4[0],\n i = _re4[1];\n return /*#__PURE__*/v.createElement(i, null, _({\n ourProps: {\n ref: n,\n \"aria-labelledby\": r,\n role: \"group\"\n },\n theirProps: e,\n slot: {},\n defaultTag: it,\n name: \"Menu.Section\"\n }));\n}\nvar lt = \"header\";\nfunction ut(e, n) {\n var r = U(),\n _e$id4 = e.id,\n i = _e$id4 === void 0 ? \"headlessui-menu-heading-\".concat(r) : _e$id4,\n o = _objectWithoutProperties(e, _excluded5),\n p = je();\n H(function () {\n return p.register(i);\n }, [i, p.register]);\n var m = _objectSpread({\n id: i,\n ref: n,\n role: \"presentation\"\n }, p.props);\n return _({\n ourProps: m,\n theirProps: o,\n slot: {},\n defaultTag: lt,\n name: \"Menu.Heading\"\n });\n}\nvar pt = \"div\";\nfunction mt(e, n) {\n return _({\n ourProps: {\n ref: n,\n role: \"separator\"\n },\n theirProps: e,\n slot: {},\n defaultTag: pt,\n name: \"Menu.Separator\"\n });\n}\nvar dt = x(Ye),\n ct = x(et),\n ft = x(rt),\n Tt = x(at),\n yt = x(st),\n It = x(ut),\n gt = x(mt),\n Zt = Object.assign(dt, {\n Button: ct,\n Items: ft,\n Item: Tt,\n Section: yt,\n Heading: It,\n Separator: gt\n });\nexport { Zt as Menu, ct as MenuButton, It as MenuHeading, Tt as MenuItem, ft as MenuItems, yt as MenuSection, gt as MenuSeparator };","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar hasOwn = require('../internals/has-own-property');\n\nvar FunctionPrototype = Function.prototype;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getDescriptor = DESCRIPTORS && Object.getOwnPropertyDescriptor;\n\nvar EXISTS = hasOwn(FunctionPrototype, 'name');\n// additional protection from minified / mangled / dropped function names\nvar PROPER = EXISTS && (function something() { /* empty */ }).name === 'something';\nvar CONFIGURABLE = EXISTS && (!DESCRIPTORS || (DESCRIPTORS && getDescriptor(FunctionPrototype, 'name').configurable));\n\nmodule.exports = {\n EXISTS: EXISTS,\n PROPER: PROPER,\n CONFIGURABLE: CONFIGURABLE\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nmodule.exports = uncurryThis([].slice);\n","'use strict';\nvar $ = require('../internals/export');\nvar $find = require('../internals/array-iteration').find;\nvar addToUnscopables = require('../internals/add-to-unscopables');\n\nvar FIND = 'find';\nvar SKIPS_HOLES = true;\n\n// Shouldn't skip holes\n// eslint-disable-next-line es/no-array-prototype-find -- testing\nif (FIND in []) Array(1)[FIND](function () { SKIPS_HOLES = false; });\n\n// `Array.prototype.find` method\n// https://tc39.es/ecma262/#sec-array.prototype.find\n$({ target: 'Array', proto: true, forced: SKIPS_HOLES }, {\n find: function find(callbackfn /* , that = undefined */) {\n return $find(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\n\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\naddToUnscopables(FIND);\n","'use strict';\nvar apply = require('../internals/function-apply');\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fixRegExpWellKnownSymbolLogic = require('../internals/fix-regexp-well-known-symbol-logic');\nvar fails = require('../internals/fails');\nvar anObject = require('../internals/an-object');\nvar isCallable = require('../internals/is-callable');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\nvar toLength = require('../internals/to-length');\nvar toString = require('../internals/to-string');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\nvar advanceStringIndex = require('../internals/advance-string-index');\nvar getMethod = require('../internals/get-method');\nvar getSubstitution = require('../internals/get-substitution');\nvar regExpExec = require('../internals/regexp-exec-abstract');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar REPLACE = wellKnownSymbol('replace');\nvar max = Math.max;\nvar min = Math.min;\nvar concat = uncurryThis([].concat);\nvar push = uncurryThis([].push);\nvar stringIndexOf = uncurryThis(''.indexOf);\nvar stringSlice = uncurryThis(''.slice);\n\nvar maybeToString = function (it) {\n return it === undefined ? it : String(it);\n};\n\n// IE <= 11 replaces $0 with the whole match, as if it was $&\n// https://stackoverflow.com/questions/6024666/getting-ie-to-replace-a-regex-with-the-literal-string-0\nvar REPLACE_KEEPS_$0 = (function () {\n // eslint-disable-next-line regexp/prefer-escape-replacement-dollar-char -- required for testing\n return 'a'.replace(/./, '$0') === '$0';\n})();\n\n// Safari <= 13.0.3(?) substitutes nth capture where n>m with an empty string\nvar REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE = (function () {\n if (/./[REPLACE]) {\n return /./[REPLACE]('a', '$0') === '';\n }\n return false;\n})();\n\nvar REPLACE_SUPPORTS_NAMED_GROUPS = !fails(function () {\n var re = /./;\n re.exec = function () {\n var result = [];\n result.groups = { a: '7' };\n return result;\n };\n // eslint-disable-next-line regexp/no-useless-dollar-replacements -- false positive\n return ''.replace(re, '$') !== '7';\n});\n\n// @@replace logic\nfixRegExpWellKnownSymbolLogic('replace', function (_, nativeReplace, maybeCallNative) {\n var UNSAFE_SUBSTITUTE = REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE ? '$' : '$0';\n\n return [\n // `String.prototype.replace` method\n // https://tc39.es/ecma262/#sec-string.prototype.replace\n function replace(searchValue, replaceValue) {\n var O = requireObjectCoercible(this);\n var replacer = isNullOrUndefined(searchValue) ? undefined : getMethod(searchValue, REPLACE);\n return replacer\n ? call(replacer, searchValue, O, replaceValue)\n : call(nativeReplace, toString(O), searchValue, replaceValue);\n },\n // `RegExp.prototype[@@replace]` method\n // https://tc39.es/ecma262/#sec-regexp.prototype-@@replace\n function (string, replaceValue) {\n var rx = anObject(this);\n var S = toString(string);\n\n if (\n typeof replaceValue == 'string' &&\n stringIndexOf(replaceValue, UNSAFE_SUBSTITUTE) === -1 &&\n stringIndexOf(replaceValue, '$<') === -1\n ) {\n var res = maybeCallNative(nativeReplace, rx, S, replaceValue);\n if (res.done) return res.value;\n }\n\n var functionalReplace = isCallable(replaceValue);\n if (!functionalReplace) replaceValue = toString(replaceValue);\n\n var global = rx.global;\n var fullUnicode;\n if (global) {\n fullUnicode = rx.unicode;\n rx.lastIndex = 0;\n }\n\n var results = [];\n var result;\n while (true) {\n result = regExpExec(rx, S);\n if (result === null) break;\n\n push(results, result);\n if (!global) break;\n\n var matchStr = toString(result[0]);\n if (matchStr === '') rx.lastIndex = advanceStringIndex(S, toLength(rx.lastIndex), fullUnicode);\n }\n\n var accumulatedResult = '';\n var nextSourcePosition = 0;\n for (var i = 0; i < results.length; i++) {\n result = results[i];\n\n var matched = toString(result[0]);\n var position = max(min(toIntegerOrInfinity(result.index), S.length), 0);\n var captures = [];\n var replacement;\n // NOTE: This is equivalent to\n // captures = result.slice(1).map(maybeToString)\n // but for some reason `nativeSlice.call(result, 1, result.length)` (called in\n // the slice polyfill when slicing native arrays) \"doesn't work\" in safari 9 and\n // causes a crash (https://pastebin.com/N21QzeQA) when trying to debug it.\n for (var j = 1; j < result.length; j++) push(captures, maybeToString(result[j]));\n var namedCaptures = result.groups;\n if (functionalReplace) {\n var replacerArgs = concat([matched], captures, position, S);\n if (namedCaptures !== undefined) push(replacerArgs, namedCaptures);\n replacement = toString(apply(replaceValue, undefined, replacerArgs));\n } else {\n replacement = getSubstitution(matched, S, position, captures, namedCaptures, replaceValue);\n }\n if (position >= nextSourcePosition) {\n accumulatedResult += stringSlice(S, nextSourcePosition, position) + replacement;\n nextSourcePosition = position + matched.length;\n }\n }\n\n return accumulatedResult + stringSlice(S, nextSourcePosition);\n }\n ];\n}, !REPLACE_SUPPORTS_NAMED_GROUPS || !REPLACE_KEEPS_$0 || REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE);\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar classof = require('../internals/classof-raw');\n\nvar $Object = Object;\nvar split = uncurryThis(''.split);\n\n// fallback for non-array-like ES3 and non-enumerable old V8 strings\nmodule.exports = fails(function () {\n // throws an error in rhino, see https://github.com/mozilla/rhino/issues/346\n // eslint-disable-next-line no-prototype-builtins -- safe\n return !$Object('z').propertyIsEnumerable(0);\n}) ? function (it) {\n return classof(it) === 'String' ? split(it, '') : $Object(it);\n} : $Object;\n","'use strict';\nmodule.exports = {};\n","'use strict';\nvar internalObjectKeys = require('../internals/object-keys-internal');\nvar enumBugKeys = require('../internals/enum-bug-keys');\n\n// `Object.keys` method\n// https://tc39.es/ecma262/#sec-object.keys\n// eslint-disable-next-line es/no-object-keys -- safe\nmodule.exports = Object.keys || function keys(O) {\n return internalObjectKeys(O, enumBugKeys);\n};\n","'use strict';\nvar classofRaw = require('../internals/classof-raw');\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nmodule.exports = function (fn) {\n // Nashorn bug:\n // https://github.com/zloirock/core-js/issues/1128\n // https://github.com/zloirock/core-js/issues/1130\n if (classofRaw(fn) === 'Function') return uncurryThis(fn);\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar classof = require('../internals/classof');\nvar getBuiltIn = require('../internals/get-built-in');\nvar inspectSource = require('../internals/inspect-source');\n\nvar noop = function () { /* empty */ };\nvar empty = [];\nvar construct = getBuiltIn('Reflect', 'construct');\nvar constructorRegExp = /^\\s*(?:class|function)\\b/;\nvar exec = uncurryThis(constructorRegExp.exec);\nvar INCORRECT_TO_STRING = !constructorRegExp.test(noop);\n\nvar isConstructorModern = function isConstructor(argument) {\n if (!isCallable(argument)) return false;\n try {\n construct(noop, empty, argument);\n return true;\n } catch (error) {\n return false;\n }\n};\n\nvar isConstructorLegacy = function isConstructor(argument) {\n if (!isCallable(argument)) return false;\n switch (classof(argument)) {\n case 'AsyncFunction':\n case 'GeneratorFunction':\n case 'AsyncGeneratorFunction': return false;\n }\n try {\n // we can't check .prototype since constructors produced by .bind haven't it\n // `Function#toString` throws on some built-it function in some legacy engines\n // (for example, `DOMQuad` and similar in FF41-)\n return INCORRECT_TO_STRING || !!exec(constructorRegExp, inspectSource(argument));\n } catch (error) {\n return true;\n }\n};\n\nisConstructorLegacy.sham = true;\n\n// `IsConstructor` abstract operation\n// https://tc39.es/ecma262/#sec-isconstructor\nmodule.exports = !construct || fails(function () {\n var called;\n return isConstructorModern(isConstructorModern.call)\n || !isConstructorModern(Object)\n || !isConstructorModern(function () { called = true; })\n || called;\n}) ? isConstructorLegacy : isConstructorModern;\n","'use strict';\nvar classof = require('../internals/classof');\nvar getMethod = require('../internals/get-method');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\nvar Iterators = require('../internals/iterators');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar ITERATOR = wellKnownSymbol('iterator');\n\nmodule.exports = function (it) {\n if (!isNullOrUndefined(it)) return getMethod(it, ITERATOR)\n || getMethod(it, '@@iterator')\n || Iterators[classof(it)];\n};\n","'use strict';\nmodule.exports = function (exec) {\n try {\n return { error: false, value: exec() };\n } catch (error) {\n return { error: true, value: error };\n }\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\nvar toString = require('../internals/to-string');\n\nvar quot = /\"/g;\nvar replace = uncurryThis(''.replace);\n\n// `CreateHTML` abstract operation\n// https://tc39.es/ecma262/#sec-createhtml\nmodule.exports = function (string, tag, attribute, value) {\n var S = toString(requireObjectCoercible(string));\n var p1 = '<' + tag;\n if (attribute !== '') p1 += ' ' + attribute + '=\"' + replace(toString(value), quot, '"') + '\"';\n return p1 + '>' + S + '' + tag + '>';\n};\n","'use strict';\nvar fails = require('../internals/fails');\n\n// check the existence of a method, lowercase\n// of a tag and escaping quotes in arguments\nmodule.exports = function (METHOD_NAME) {\n return fails(function () {\n var test = ''[METHOD_NAME]('\"');\n return test !== test.toLowerCase() || test.split('\"').length > 3;\n });\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.END_DRAG = exports.DROP = exports.HOVER = exports.PUBLISH_DRAG_SOURCE = exports.BEGIN_DRAG = exports.INIT_COORDS = void 0;\nvar INIT_COORDS = 'dnd-core/INIT_COORDS';\nexports.INIT_COORDS = INIT_COORDS;\nvar BEGIN_DRAG = 'dnd-core/BEGIN_DRAG';\nexports.BEGIN_DRAG = BEGIN_DRAG;\nvar PUBLISH_DRAG_SOURCE = 'dnd-core/PUBLISH_DRAG_SOURCE';\nexports.PUBLISH_DRAG_SOURCE = PUBLISH_DRAG_SOURCE;\nvar HOVER = 'dnd-core/HOVER';\nexports.HOVER = HOVER;\nvar DROP = 'dnd-core/DROP';\nexports.DROP = DROP;\nvar END_DRAG = 'dnd-core/END_DRAG';\nexports.END_DRAG = END_DRAG;","import React, {\n useContext,\n createContext,\n useReducer,\n useCallback,\n} from \"react\";\nimport { useDrag, useDrop } from \"react-dnd\";\nimport { updateFundPositions } from \"../../utils/requests\";\nconst FundsContext = createContext(null);\n\nconst initialState = {\n funds: [],\n draggable: false,\n};\n\nexport const FundsProvider = (props) => {\n const { funds = [] } = props;\n const state = {\n ...initialState,\n funds,\n };\n\n const [store, dispatch] = useReducer(fundsReducer, state);\n\n const value = React.useMemo(() => [store, dispatch], [store]);\n return ;\n};\n\nconst fundsReducer = (state, action) => {\n switch (action.type) {\n case \"UPDATE_FUNDS\":\n return { ...state, funds: action.funds };\n case \"TOGGLE_DRAG\":\n return { ...state, draggable: !state.draggable };\n default:\n return state;\n }\n};\n\nexport const useFunds = () => {\n const [state, dispatch] = useContext(FundsContext);\n\n const moveFund = useCallback(\n (dragIndex, hoverIndex) => {\n const dragFund = state.funds[dragIndex];\n // const hoverFund = stat.funds[hoverIndex]\n const newFunds = [...state.funds];\n\n // first remove the item at dragIndex (the fund that is being dragged)\n // then insert the dragFund at the fund that is being hovered over\n newFunds.splice(dragIndex, 1);\n newFunds.splice(hoverIndex, 0, dragFund);\n\n // update position for the fund we dragged\n const sortedFunds = newFunds.map((f, i) => {\n if (f.id != dragFund.id) return f;\n\n const position =\n dragIndex > hoverIndex\n ? f.position - (dragIndex - hoverIndex)\n : f.position + (hoverIndex - dragIndex);\n\n return { ...f, position };\n });\n\n dispatch({ type: \"UPDATE_FUNDS\", funds: sortedFunds });\n },\n [state.funds]\n );\n\n const updatePositions = async (fundItem) => {\n const fund = state.funds.find((f) => f.id == fundItem.id);\n\n try {\n await updateFundPositions({\n fund: { id: fund.id, position: fund.position },\n });\n } catch (error) {\n }\n };\n\n const toggleDrag = () => {\n dispatch({ type: \"TOGGLE_DRAG\" });\n };\n\n return {\n state,\n dispatch,\n useDrag,\n useDrop,\n moveFund,\n updatePositions,\n toggleDrag,\n };\n};\n","import React, {\n useContext,\n createContext,\n useReducer,\n useCallback,\n} from 'react';\nimport { useDrag, useDrop } from 'react-dnd';\nimport { updateProductPositions } from '../../utils/requests';\nconst ProductsContext = createContext(null);\n\nconst initialState = {\n products: [],\n draggable: false,\n};\n\nexport const ProductsProvider = (props) => {\n const { products = [] } = props;\n const state = {\n ...initialState,\n products,\n };\n\n const [store, dispatch] = useReducer(productsReducer, state);\n\n const value = React.useMemo(() => [store, dispatch], [store]);\n return ;\n};\n\nconst productsReducer = (state, action) => {\n switch (action.type) {\n case 'UPDATE_FUNDS':\n return { ...state, products: action.products };\n case 'TOGGLE_DRAG':\n return { ...state, draggable: !state.draggable };\n default:\n return state;\n }\n};\n\nexport const useProducts = () => {\n const [state, dispatch] = useContext(ProductsContext);\n\n const moveProduct = useCallback(\n (dragIndex, hoverIndex) => {\n const dragProduct = state.products[dragIndex];\n // const hoverProduct = stat.products[hoverIndex]\n const newProducts = [...state.products];\n\n // first remove the item at dragIndex (the product that is being dragged)\n // then insert the dragProduct at the product that is being hovered over\n newProducts.splice(dragIndex, 1);\n newProducts.splice(hoverIndex, 0, dragProduct);\n\n // update position for the product we dragged\n const sortedProducts = newProducts.map((f, i) => {\n if (f.id != dragProduct.id) return f;\n\n const position =\n dragIndex > hoverIndex\n ? f.position - (dragIndex - hoverIndex)\n : f.position + (hoverIndex - dragIndex);\n\n return { ...f, position };\n });\n\n dispatch({ type: 'UPDATE_FUNDS', products: sortedProducts });\n },\n [state.products]\n );\n\n const updatePositions = async (productItem) => {\n const product = state.products.find((f) => f.id == productItem.id);\n\n try {\n await updateProductPositions({\n product: { id: product.id, position: product.position },\n });\n } catch (error) {\n }\n };\n\n const toggleDrag = () => {\n dispatch({ type: 'TOGGLE_DRAG' });\n };\n\n return {\n state,\n dispatch,\n useDrag,\n useDrop,\n moveProduct,\n updatePositions,\n toggleDrag,\n };\n};\n","import { useRef as r } from \"react\";\nimport { useIsoMorphicEffect as t } from './use-iso-morphic-effect.js';\nfunction f() {\n var e = r(!1);\n return t(function () {\n return e.current = !0, function () {\n e.current = !1;\n };\n }, []), e;\n}\nexport { f as useIsMounted };","import React, {\n useContext,\n createContext,\n useReducer,\n useCallback,\n} from 'react';\nimport { useStripe, useElements } from '@stripe/react-stripe-js';\n\nconst StripeContext = createContext(null);\n\nconst initialState = {\n model: {\n name: '',\n email: '',\n },\n appliedCoupon: {},\n paymentMethod: '',\n loading: false,\n couponLoading: false,\n error: '',\n};\n\nexport const StripeFormProvider = (props) => {\n const { errors, model } = props;\n const state = {\n ...initialState,\n model,\n errors,\n };\n\n const [store, dispatch] = useReducer(stripeFormReducer, state);\n\n const value = React.useMemo(() => [store, dispatch], [store]);\n return ;\n};\n\nconst stripeFormReducer = (state, action) => {\n switch (action.type) {\n case 'UPDATE_MODEL':\n return { ...state, model: action.model };\n case 'TOGGLE_LOADING':\n return { ...state, loading: !state.loading };\n case 'TOGGLE_COUPON_LOADING':\n return { ...state, couponLoading: !state.couponLoading };\n case 'TOGGLE_COMPLETED':\n return { ...state, completed: !state.completed };\n case 'SET_ERROR':\n return { ...state, error: action.error };\n case 'SET_ERRORS':\n return { ...state, errors: action.errors };\n case 'SET_PAYMENT_METHOD':\n return { ...state, paymentMethod: action.paymentMethod };\n case 'SET_COUPON':\n return { ...state, coupon: action.coupon };\n case 'SET_APPLIED_COUPON':\n return { ...state, appliedCoupon: action.appliedCoupon };\n default:\n return state;\n }\n};\n\nexport const useForm = () => {\n const [state, dispatch] = useContext(StripeContext);\n\n const updateModel = useCallback(\n (attribute, value) => {\n const model = { ...state.model };\n model[attribute] = value;\n dispatch({ type: 'UPDATE_MODEL', model });\n },\n [state, dispatch]\n );\n\n return {\n state,\n dispatch,\n stripe: useStripe(),\n elements: useElements(),\n updateModel,\n };\n};\n","function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nimport { useEffect as f, useRef as s } from \"react\";\nimport { useEvent as i } from './use-event.js';\nfunction m(u, t) {\n var e = s([]),\n r = i(u);\n f(function () {\n var o = _toConsumableArray(e.current);\n var _iterator = _createForOfIteratorHelper(t.entries()),\n _step;\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var _ref = _step.value;\n var _ref2 = _slicedToArray(_ref, 2);\n var a = _ref2[0];\n var l = _ref2[1];\n if (e.current[a] !== l) {\n var n = r(t, o);\n return e.current = t, n;\n }\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n }, [r].concat(_toConsumableArray(t)));\n}\nexport { m as useWatch };","import { onDocumentReady as d } from './document-ready.js';\nimport { focusableSelector as u } from './focus-management.js';\nvar r = [];\nd(function () {\n function e(t) {\n if (!(t.target instanceof HTMLElement) || t.target === document.body || r[0] === t.target) return;\n var n = t.target;\n n = n.closest(u), r.unshift(n != null ? n : t.target), r = r.filter(function (o) {\n return o != null && o.isConnected;\n }), r.splice(10);\n }\n window.addEventListener(\"click\", e, {\n capture: !0\n }), window.addEventListener(\"mousedown\", e, {\n capture: !0\n }), window.addEventListener(\"focus\", e, {\n capture: !0\n }), document.body.addEventListener(\"click\", e, {\n capture: !0\n }), document.body.addEventListener(\"mousedown\", e, {\n capture: !0\n }), document.body.addEventListener(\"focus\", e, {\n capture: !0\n });\n});\nexport { r as history };","function t(n) {\n function e() {\n document.readyState !== \"loading\" && (n(), document.removeEventListener(\"DOMContentLoaded\", e));\n }\n typeof window != \"undefined\" && typeof document != \"undefined\" && (document.addEventListener(\"DOMContentLoaded\", e), e());\n}\nexport { t as onDocumentReady };","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nvar id = 0;\nvar postfix = Math.random();\nvar toString = uncurryThis(1.0.toString);\n\nmodule.exports = function (key) {\n return 'Symbol(' + (key === undefined ? '' : key) + ')_' + toString(++id + postfix, 36);\n};\n","'use strict';\nvar global = require('../internals/global');\nvar isObject = require('../internals/is-object');\n\nvar document = global.document;\n// typeof document.createElement is 'object' in old IE\nvar EXISTS = isObject(document) && isObject(document.createElement);\n\nmodule.exports = function (it) {\n return EXISTS ? document.createElement(it) : {};\n};\n","'use strict';\nvar shared = require('../internals/shared');\nvar uid = require('../internals/uid');\n\nvar keys = shared('keys');\n\nmodule.exports = function (key) {\n return keys[key] || (keys[key] = uid(key));\n};\n","'use strict';\n// eslint-disable-next-line es/no-object-getownpropertysymbols -- safe\nexports.f = Object.getOwnPropertySymbols;\n","'use strict';\nvar $ = require('../internals/export');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\nvar thisNumberValue = require('../internals/this-number-value');\nvar $repeat = require('../internals/string-repeat');\nvar fails = require('../internals/fails');\n\nvar $RangeError = RangeError;\nvar $String = String;\nvar floor = Math.floor;\nvar repeat = uncurryThis($repeat);\nvar stringSlice = uncurryThis(''.slice);\nvar nativeToFixed = uncurryThis(1.0.toFixed);\n\nvar pow = function (x, n, acc) {\n return n === 0 ? acc : n % 2 === 1 ? pow(x, n - 1, acc * x) : pow(x * x, n / 2, acc);\n};\n\nvar log = function (x) {\n var n = 0;\n var x2 = x;\n while (x2 >= 4096) {\n n += 12;\n x2 /= 4096;\n }\n while (x2 >= 2) {\n n += 1;\n x2 /= 2;\n } return n;\n};\n\nvar multiply = function (data, n, c) {\n var index = -1;\n var c2 = c;\n while (++index < 6) {\n c2 += n * data[index];\n data[index] = c2 % 1e7;\n c2 = floor(c2 / 1e7);\n }\n};\n\nvar divide = function (data, n) {\n var index = 6;\n var c = 0;\n while (--index >= 0) {\n c += data[index];\n data[index] = floor(c / n);\n c = (c % n) * 1e7;\n }\n};\n\nvar dataToString = function (data) {\n var index = 6;\n var s = '';\n while (--index >= 0) {\n if (s !== '' || index === 0 || data[index] !== 0) {\n var t = $String(data[index]);\n s = s === '' ? t : s + repeat('0', 7 - t.length) + t;\n }\n } return s;\n};\n\nvar FORCED = fails(function () {\n return nativeToFixed(0.00008, 3) !== '0.000' ||\n nativeToFixed(0.9, 0) !== '1' ||\n nativeToFixed(1.255, 2) !== '1.25' ||\n nativeToFixed(1000000000000000128.0, 0) !== '1000000000000000128';\n}) || !fails(function () {\n // V8 ~ Android 4.3-\n nativeToFixed({});\n});\n\n// `Number.prototype.toFixed` method\n// https://tc39.es/ecma262/#sec-number.prototype.tofixed\n$({ target: 'Number', proto: true, forced: FORCED }, {\n toFixed: function toFixed(fractionDigits) {\n var number = thisNumberValue(this);\n var fractDigits = toIntegerOrInfinity(fractionDigits);\n var data = [0, 0, 0, 0, 0, 0];\n var sign = '';\n var result = '0';\n var e, z, j, k;\n\n // TODO: ES2018 increased the maximum number of fraction digits to 100, need to improve the implementation\n if (fractDigits < 0 || fractDigits > 20) throw new $RangeError('Incorrect fraction digits');\n // eslint-disable-next-line no-self-compare -- NaN check\n if (number !== number) return 'NaN';\n if (number <= -1e21 || number >= 1e21) return $String(number);\n if (number < 0) {\n sign = '-';\n number = -number;\n }\n if (number > 1e-21) {\n e = log(number * pow(2, 69, 1)) - 69;\n z = e < 0 ? number * pow(2, -e, 1) : number / pow(2, e, 1);\n z *= 0x10000000000000;\n e = 52 - e;\n if (e > 0) {\n multiply(data, 0, z);\n j = fractDigits;\n while (j >= 7) {\n multiply(data, 1e7, 0);\n j -= 7;\n }\n multiply(data, pow(10, j, 1), 0);\n j = e - 1;\n while (j >= 23) {\n divide(data, 1 << 23);\n j -= 23;\n }\n divide(data, 1 << j);\n multiply(data, 1, 1);\n divide(data, 2);\n result = dataToString(data);\n } else {\n multiply(data, 0, z);\n multiply(data, 1 << -e, 0);\n result = dataToString(data) + repeat('0', fractDigits);\n }\n }\n if (fractDigits > 0) {\n k = result.length;\n result = sign + (k <= fractDigits\n ? '0.' + repeat('0', fractDigits - k) + result\n : stringSlice(result, 0, k - fractDigits) + '.' + stringSlice(result, k - fractDigits));\n } else {\n result = sign + result;\n } return result;\n }\n});\n","'use strict';\nvar $propertyIsEnumerable = {}.propertyIsEnumerable;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\n// Nashorn ~ JDK8 bug\nvar NASHORN_BUG = getOwnPropertyDescriptor && !$propertyIsEnumerable.call({ 1: 2 }, 1);\n\n// `Object.prototype.propertyIsEnumerable` method implementation\n// https://tc39.es/ecma262/#sec-object.prototype.propertyisenumerable\nexports.f = NASHORN_BUG ? function propertyIsEnumerable(V) {\n var descriptor = getOwnPropertyDescriptor(this, V);\n return !!descriptor && descriptor.enumerable;\n} : $propertyIsEnumerable;\n","'use strict';\nvar global = require('../internals/global');\nvar defineGlobalProperty = require('../internals/define-global-property');\n\nvar SHARED = '__core-js_shared__';\nvar store = global[SHARED] || defineGlobalProperty(SHARED, {});\n\nmodule.exports = store;\n","'use strict';\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\n\nvar replacement = /#|\\.prototype\\./;\n\nvar isForced = function (feature, detection) {\n var value = data[normalize(feature)];\n return value === POLYFILL ? true\n : value === NATIVE ? false\n : isCallable(detection) ? fails(detection)\n : !!detection;\n};\n\nvar normalize = isForced.normalize = function (string) {\n return String(string).replace(replacement, '.').toLowerCase();\n};\n\nvar data = isForced.data = {};\nvar NATIVE = isForced.NATIVE = 'N';\nvar POLYFILL = isForced.POLYFILL = 'P';\n\nmodule.exports = isForced;\n","'use strict';\nvar toAbsoluteIndex = require('../internals/to-absolute-index');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar createProperty = require('../internals/create-property');\n\nvar $Array = Array;\nvar max = Math.max;\n\nmodule.exports = function (O, start, end) {\n var length = lengthOfArrayLike(O);\n var k = toAbsoluteIndex(start, length);\n var fin = toAbsoluteIndex(end === undefined ? length : end, length);\n var result = $Array(max(fin - k, 0));\n var n = 0;\n for (; k < fin; k++, n++) createProperty(result, n, O[k]);\n result.length = n;\n return result;\n};\n","'use strict';\nvar defineBuiltIn = require('../internals/define-built-in');\n\nmodule.exports = function (target, src, options) {\n for (var key in src) defineBuiltIn(target, key, src[key], options);\n return target;\n};\n","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.get = get;\nexports.without = without;\nexports.isString = isString;\nexports.isObject = isObject;\nexports.xor = xor;\nexports.intersection = intersection;\nfunction get(obj, path, defaultValue) {\n return path.split('.').reduce(function (a, c) {\n return a && a[c] ? a[c] : defaultValue || null;\n }, obj);\n}\nfunction without(items, item) {\n return items.filter(function (i) {\n return i !== item;\n });\n}\nfunction isString(input) {\n return typeof input === 'string';\n}\nfunction isObject(input) {\n return _typeof(input) === 'object';\n}\nfunction xor(itemsA, itemsB) {\n var map = new Map();\n var insertItem = function insertItem(item) {\n map.set(item, map.has(item) ? map.get(item) + 1 : 1);\n };\n itemsA.forEach(insertItem);\n itemsB.forEach(insertItem);\n var result = [];\n map.forEach(function (count, key) {\n if (count === 1) {\n result.push(key);\n }\n });\n return result;\n}\nfunction intersection(itemsA, itemsB) {\n return itemsA.filter(function (t) {\n return itemsB.indexOf(t) > -1;\n });\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar _exportNames = {};\nvar _dragSourceMonitorImplJs = _interopRequireWildcard(require(\"./DragSourceMonitorImpl.js\"));\nObject.keys(_dragSourceMonitorImplJs).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _dragSourceMonitorImplJs[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _dragSourceMonitorImplJs[key];\n }\n });\n});\nvar _dropTargetMonitorImplJs = _interopRequireWildcard(require(\"./DropTargetMonitorImpl.js\"));\nObject.keys(_dropTargetMonitorImplJs).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _dropTargetMonitorImplJs[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _dropTargetMonitorImplJs[key];\n }\n });\n});\nvar _sourceConnectorJs = _interopRequireWildcard(require(\"./SourceConnector.js\"));\nObject.keys(_sourceConnectorJs).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _sourceConnectorJs[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _sourceConnectorJs[key];\n }\n });\n});\nvar _targetConnectorJs = _interopRequireWildcard(require(\"./TargetConnector.js\"));\nObject.keys(_targetConnectorJs).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _targetConnectorJs[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _targetConnectorJs[key];\n }\n });\n});\nvar _registrationJs = _interopRequireWildcard(require(\"./registration.js\"));\nObject.keys(_registrationJs).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _registrationJs[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _registrationJs[key];\n }\n });\n});\nfunction _interopRequireWildcard(obj) {\n if (obj && obj.__esModule) {\n return obj;\n } else {\n var newObj = {};\n if (obj != null) {\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {};\n if (desc.get || desc.set) {\n Object.defineProperty(newObj, key, desc);\n } else {\n newObj[key] = obj[key];\n }\n }\n }\n }\n newObj.default = obj;\n return newObj;\n }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.useIsomorphicLayoutEffect = void 0;\nvar _react = require(\"react\");\nvar useIsomorphicLayoutEffect = typeof window !== 'undefined' ? _react.useLayoutEffect : _react.useEffect;\nexports.useIsomorphicLayoutEffect = useIsomorphicLayoutEffect;","'use strict';\nvar $ = require('../internals/export');\nvar $find = require('../internals/async-iterator-iteration').find;\n\n// `AsyncIterator.prototype.find` method\n// https://github.com/tc39/proposal-async-iterator-helpers\n$({ target: 'AsyncIterator', proto: true, real: true }, {\n find: function find(predicate) {\n return $find(this, predicate);\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar iterate = require('../internals/iterate');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar getIteratorDirect = require('../internals/get-iterator-direct');\n\n// `Iterator.prototype.find` method\n// https://github.com/tc39/proposal-iterator-helpers\n$({ target: 'Iterator', proto: true, real: true }, {\n find: function find(predicate) {\n anObject(this);\n aCallable(predicate);\n var record = getIteratorDirect(this);\n var counter = 0;\n return iterate(record, function (value, stop) {\n if (predicate(value, counter++)) return stop(value);\n }, { IS_RECORD: true, INTERRUPTED: true }).result;\n }\n});\n","function t() {\n return /iPhone/gi.test(window.navigator.platform) || /Mac/gi.test(window.navigator.platform) && window.navigator.maxTouchPoints > 0;\n}\nfunction i() {\n return /Android/gi.test(window.navigator.userAgent);\n}\nfunction n() {\n return t() || i();\n}\nexport { i as isAndroid, t as isIOS, n as isMobile };","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nimport { useCallback as n } from \"react\";\nfunction l(e, r) {\n return e !== null && r !== null && _typeof(e) == \"object\" && _typeof(r) == \"object\" && \"id\" in e && \"id\" in r ? e.id === r.id : e === r;\n}\nfunction u() {\n var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : l;\n return n(function (r, t) {\n if (typeof e == \"string\") {\n var o = e;\n return (r == null ? void 0 : r[o]) === (t == null ? void 0 : t[o]);\n }\n return e(r, t);\n }, [e]);\n}\nexport { u as useByComparator };","import { useRef as o } from \"react\";\nfunction t(e) {\n return [e.screenX, e.screenY];\n}\nfunction u() {\n var e = o([-1, -1]);\n return {\n wasMoved: function wasMoved(r) {\n var n = t(r);\n return e.current[0] === n[0] && e.current[1] === n[1] ? !1 : (e.current = n, !0);\n },\n update: function update(r) {\n e.current = t(r);\n }\n };\n}\nexport { u as useTrackedPointer };","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { v4 } from 'uuid';\nfunction ownKeys$2(object, enumerableOnly) {\n var keys = Object.keys(object);\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n enumerableOnly && (symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n })), keys.push.apply(keys, symbols);\n }\n return keys;\n}\nfunction _objectSpread2(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = null != arguments[i] ? arguments[i] : {};\n i % 2 ? ownKeys$2(Object(source), !0).forEach(function (key) {\n _defineProperty(target, key, source[key]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$2(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n return target;\n}\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nfunction _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) _setPrototypeOf(subClass, superClass);\n}\nfunction _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}\nfunction _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}\nfunction _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return _assertThisInitialized(self);\n}\nfunction _createSuper(Derived) {\n var hasNativeReflectConstruct = _isNativeReflectConstruct();\n return function _createSuperInternal() {\n var Super = _getPrototypeOf(Derived),\n result;\n if (hasNativeReflectConstruct) {\n var NewTarget = _getPrototypeOf(this).constructor;\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n return _possibleConstructorReturn(this, result);\n };\n}\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n}\nfunction _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n return arr2;\n}\nfunction _createForOfIteratorHelper(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n if (!it) {\n if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n var F = function F() {};\n return {\n s: F,\n n: function n() {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n },\n e: function e(_e) {\n throw _e;\n },\n f: F\n };\n }\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n var normalCompletion = true,\n didErr = false,\n err;\n return {\n s: function s() {\n it = it.call(o);\n },\n n: function n() {\n var step = it.next();\n normalCompletion = step.done;\n return step;\n },\n e: function e(_e2) {\n didErr = true;\n err = _e2;\n },\n f: function f() {\n try {\n if (!normalCompletion && it.return != null) it.return();\n } finally {\n if (didErr) throw err;\n }\n }\n };\n}\nvar commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};\nvar check = function check(it) {\n return it && it.Math == Math && it;\n};\n\n// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\nvar global$a =\n// eslint-disable-next-line es/no-global-this -- safe\ncheck((typeof globalThis === \"undefined\" ? \"undefined\" : _typeof(globalThis)) == 'object' && globalThis) || check((typeof window === \"undefined\" ? \"undefined\" : _typeof(window)) == 'object' && window) ||\n// eslint-disable-next-line no-restricted-globals -- safe\ncheck((typeof self === \"undefined\" ? \"undefined\" : _typeof(self)) == 'object' && self) || check(_typeof(commonjsGlobal) == 'object' && commonjsGlobal) ||\n// eslint-disable-next-line no-new-func -- fallback\nfunction () {\n return this;\n}() || Function('return this')();\nvar objectGetOwnPropertyDescriptor = {};\nvar fails$9 = function fails$9(exec) {\n try {\n return !!exec();\n } catch (error) {\n return true;\n }\n};\nvar fails$8 = fails$9;\n\n// Detect IE8's incomplete defineProperty implementation\nvar descriptors = !fails$8(function () {\n // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n return Object.defineProperty({}, 1, {\n get: function get() {\n return 7;\n }\n })[1] != 7;\n});\nvar fails$7 = fails$9;\nvar functionBindNative = !fails$7(function () {\n // eslint-disable-next-line es/no-function-prototype-bind -- safe\n var test = function () {/* empty */}.bind();\n // eslint-disable-next-line no-prototype-builtins -- safe\n return typeof test != 'function' || test.hasOwnProperty('prototype');\n});\nvar NATIVE_BIND$2 = functionBindNative;\nvar call$4 = Function.prototype.call;\nvar functionCall = NATIVE_BIND$2 ? call$4.bind(call$4) : function () {\n return call$4.apply(call$4, arguments);\n};\nvar objectPropertyIsEnumerable = {};\nvar $propertyIsEnumerable = {}.propertyIsEnumerable;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getOwnPropertyDescriptor$1 = Object.getOwnPropertyDescriptor;\n\n// Nashorn ~ JDK8 bug\nvar NASHORN_BUG = getOwnPropertyDescriptor$1 && !$propertyIsEnumerable.call({\n 1: 2\n}, 1);\n\n// `Object.prototype.propertyIsEnumerable` method implementation\n// https://tc39.es/ecma262/#sec-object.prototype.propertyisenumerable\nobjectPropertyIsEnumerable.f = NASHORN_BUG ? function propertyIsEnumerable(V) {\n var descriptor = getOwnPropertyDescriptor$1(this, V);\n return !!descriptor && descriptor.enumerable;\n} : $propertyIsEnumerable;\nvar createPropertyDescriptor$2 = function createPropertyDescriptor$2(bitmap, value) {\n return {\n enumerable: !(bitmap & 1),\n configurable: !(bitmap & 2),\n writable: !(bitmap & 4),\n value: value\n };\n};\nvar NATIVE_BIND$1 = functionBindNative;\nvar FunctionPrototype$1 = Function.prototype;\nvar call$3 = FunctionPrototype$1.call;\nvar uncurryThisWithBind = NATIVE_BIND$1 && FunctionPrototype$1.bind.bind(call$3, call$3);\nvar functionUncurryThisRaw = function functionUncurryThisRaw(fn) {\n return NATIVE_BIND$1 ? uncurryThisWithBind(fn) : function () {\n return call$3.apply(fn, arguments);\n };\n};\nvar uncurryThisRaw$1 = functionUncurryThisRaw;\nvar toString$1 = uncurryThisRaw$1({}.toString);\nvar stringSlice = uncurryThisRaw$1(''.slice);\nvar classofRaw$2 = function classofRaw$2(it) {\n return stringSlice(toString$1(it), 8, -1);\n};\nvar classofRaw$1 = classofRaw$2;\nvar uncurryThisRaw = functionUncurryThisRaw;\nvar functionUncurryThis = function functionUncurryThis(fn) {\n // Nashorn bug:\n // https://github.com/zloirock/core-js/issues/1128\n // https://github.com/zloirock/core-js/issues/1130\n if (classofRaw$1(fn) === 'Function') return uncurryThisRaw(fn);\n};\nvar uncurryThis$9 = functionUncurryThis;\nvar fails$6 = fails$9;\nvar classof$3 = classofRaw$2;\nvar $Object$3 = Object;\nvar split = uncurryThis$9(''.split);\n\n// fallback for non-array-like ES3 and non-enumerable old V8 strings\nvar indexedObject = fails$6(function () {\n // throws an error in rhino, see https://github.com/mozilla/rhino/issues/346\n // eslint-disable-next-line no-prototype-builtins -- safe\n return !$Object$3('z').propertyIsEnumerable(0);\n}) ? function (it) {\n return classof$3(it) == 'String' ? split(it, '') : $Object$3(it);\n} : $Object$3;\n\n// we can't use just `it == null` since of `document.all` special case\n// https://tc39.es/ecma262/#sec-IsHTMLDDA-internal-slot-aec\nvar isNullOrUndefined$2 = function isNullOrUndefined$2(it) {\n return it === null || it === undefined;\n};\nvar isNullOrUndefined$1 = isNullOrUndefined$2;\nvar $TypeError$5 = TypeError;\n\n// `RequireObjectCoercible` abstract operation\n// https://tc39.es/ecma262/#sec-requireobjectcoercible\nvar requireObjectCoercible$2 = function requireObjectCoercible$2(it) {\n if (isNullOrUndefined$1(it)) throw $TypeError$5(\"Can't call method on \" + it);\n return it;\n};\n\n// toObject with fallback for non-array-like ES3 strings\nvar IndexedObject$1 = indexedObject;\nvar requireObjectCoercible$1 = requireObjectCoercible$2;\nvar toIndexedObject$4 = function toIndexedObject$4(it) {\n return IndexedObject$1(requireObjectCoercible$1(it));\n};\nvar documentAll$2 = (typeof document === \"undefined\" ? \"undefined\" : _typeof(document)) == 'object' && document.all;\n\n// https://tc39.es/ecma262/#sec-IsHTMLDDA-internal-slot\nvar IS_HTMLDDA = typeof documentAll$2 == 'undefined' && documentAll$2 !== undefined;\nvar documentAll_1 = {\n all: documentAll$2,\n IS_HTMLDDA: IS_HTMLDDA\n};\nvar $documentAll$1 = documentAll_1;\nvar documentAll$1 = $documentAll$1.all;\n\n// `IsCallable` abstract operation\n// https://tc39.es/ecma262/#sec-iscallable\nvar isCallable$c = $documentAll$1.IS_HTMLDDA ? function (argument) {\n return typeof argument == 'function' || argument === documentAll$1;\n} : function (argument) {\n return typeof argument == 'function';\n};\nvar isCallable$b = isCallable$c;\nvar $documentAll = documentAll_1;\nvar documentAll = $documentAll.all;\nvar isObject$6 = $documentAll.IS_HTMLDDA ? function (it) {\n return _typeof(it) == 'object' ? it !== null : isCallable$b(it) || it === documentAll;\n} : function (it) {\n return _typeof(it) == 'object' ? it !== null : isCallable$b(it);\n};\nvar global$9 = global$a;\nvar isCallable$a = isCallable$c;\nvar aFunction = function aFunction(argument) {\n return isCallable$a(argument) ? argument : undefined;\n};\nvar getBuiltIn$5 = function getBuiltIn$5(namespace, method) {\n return arguments.length < 2 ? aFunction(global$9[namespace]) : global$9[namespace] && global$9[namespace][method];\n};\nvar uncurryThis$8 = functionUncurryThis;\nvar objectIsPrototypeOf = uncurryThis$8({}.isPrototypeOf);\nvar getBuiltIn$4 = getBuiltIn$5;\nvar engineUserAgent = getBuiltIn$4('navigator', 'userAgent') || '';\nvar global$8 = global$a;\nvar userAgent = engineUserAgent;\nvar process = global$8.process;\nvar Deno = global$8.Deno;\nvar versions = process && process.versions || Deno && Deno.version;\nvar v8 = versions && versions.v8;\nvar match, version;\nif (v8) {\n match = v8.split('.');\n // in old Chrome, versions of V8 isn't V8 = Chrome / 10\n // but their correct versions are not interesting for us\n version = match[0] > 0 && match[0] < 4 ? 1 : +(match[0] + match[1]);\n}\n\n// BrowserFS NodeJS `process` polyfill incorrectly set `.v8` to `0.0`\n// so check `userAgent` even if `.v8` exists, but 0\nif (!version && userAgent) {\n match = userAgent.match(/Edge\\/(\\d+)/);\n if (!match || match[1] >= 74) {\n match = userAgent.match(/Chrome\\/(\\d+)/);\n if (match) version = +match[1];\n }\n}\nvar engineV8Version = version;\n\n/* eslint-disable es/no-symbol -- required for testing */\n\nvar V8_VERSION = engineV8Version;\nvar fails$5 = fails$9;\n\n// eslint-disable-next-line es/no-object-getownpropertysymbols -- required for testing\nvar symbolConstructorDetection = !!Object.getOwnPropertySymbols && !fails$5(function () {\n var symbol = Symbol();\n // Chrome 38 Symbol has incorrect toString conversion\n // `get-own-property-symbols` polyfill symbols converted to object are not Symbol instances\n return !String(symbol) || !(Object(symbol) instanceof Symbol) ||\n // Chrome 38-40 symbols are not inherited from DOM collections prototypes to instances\n !Symbol.sham && V8_VERSION && V8_VERSION < 41;\n});\n\n/* eslint-disable es/no-symbol -- required for testing */\n\nvar NATIVE_SYMBOL$1 = symbolConstructorDetection;\nvar useSymbolAsUid = NATIVE_SYMBOL$1 && !Symbol.sham && _typeof(Symbol.iterator) == 'symbol';\nvar getBuiltIn$3 = getBuiltIn$5;\nvar isCallable$9 = isCallable$c;\nvar isPrototypeOf = objectIsPrototypeOf;\nvar USE_SYMBOL_AS_UID$1 = useSymbolAsUid;\nvar $Object$2 = Object;\nvar isSymbol$2 = USE_SYMBOL_AS_UID$1 ? function (it) {\n return _typeof(it) == 'symbol';\n} : function (it) {\n var $Symbol = getBuiltIn$3('Symbol');\n return isCallable$9($Symbol) && isPrototypeOf($Symbol.prototype, $Object$2(it));\n};\nvar $String$1 = String;\nvar tryToString$1 = function tryToString$1(argument) {\n try {\n return $String$1(argument);\n } catch (error) {\n return 'Object';\n }\n};\nvar isCallable$8 = isCallable$c;\nvar tryToString = tryToString$1;\nvar $TypeError$4 = TypeError;\n\n// `Assert: IsCallable(argument) is true`\nvar aCallable$2 = function aCallable$2(argument) {\n if (isCallable$8(argument)) return argument;\n throw $TypeError$4(tryToString(argument) + ' is not a function');\n};\nvar aCallable$1 = aCallable$2;\nvar isNullOrUndefined = isNullOrUndefined$2;\n\n// `GetMethod` abstract operation\n// https://tc39.es/ecma262/#sec-getmethod\nvar getMethod$1 = function getMethod$1(V, P) {\n var func = V[P];\n return isNullOrUndefined(func) ? undefined : aCallable$1(func);\n};\nvar call$2 = functionCall;\nvar isCallable$7 = isCallable$c;\nvar isObject$5 = isObject$6;\nvar $TypeError$3 = TypeError;\n\n// `OrdinaryToPrimitive` abstract operation\n// https://tc39.es/ecma262/#sec-ordinarytoprimitive\nvar ordinaryToPrimitive$1 = function ordinaryToPrimitive$1(input, pref) {\n var fn, val;\n if (pref === 'string' && isCallable$7(fn = input.toString) && !isObject$5(val = call$2(fn, input))) return val;\n if (isCallable$7(fn = input.valueOf) && !isObject$5(val = call$2(fn, input))) return val;\n if (pref !== 'string' && isCallable$7(fn = input.toString) && !isObject$5(val = call$2(fn, input))) return val;\n throw $TypeError$3(\"Can't convert object to primitive value\");\n};\nvar shared$3 = {\n exports: {}\n};\nvar global$7 = global$a;\n\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar defineProperty$2 = Object.defineProperty;\nvar defineGlobalProperty$3 = function defineGlobalProperty$3(key, value) {\n try {\n defineProperty$2(global$7, key, {\n value: value,\n configurable: true,\n writable: true\n });\n } catch (error) {\n global$7[key] = value;\n }\n return value;\n};\nvar global$6 = global$a;\nvar defineGlobalProperty$2 = defineGlobalProperty$3;\nvar SHARED = '__core-js_shared__';\nvar store$3 = global$6[SHARED] || defineGlobalProperty$2(SHARED, {});\nvar sharedStore = store$3;\nvar store$2 = sharedStore;\n(shared$3.exports = function (key, value) {\n return store$2[key] || (store$2[key] = value !== undefined ? value : {});\n})('versions', []).push({\n version: '3.25.5',\n mode: 'global',\n copyright: '© 2014-2022 Denis Pushkarev (zloirock.ru)',\n license: 'https://github.com/zloirock/core-js/blob/v3.25.5/LICENSE',\n source: 'https://github.com/zloirock/core-js'\n});\nvar requireObjectCoercible = requireObjectCoercible$2;\nvar $Object$1 = Object;\n\n// `ToObject` abstract operation\n// https://tc39.es/ecma262/#sec-toobject\nvar toObject$2 = function toObject$2(argument) {\n return $Object$1(requireObjectCoercible(argument));\n};\nvar uncurryThis$7 = functionUncurryThis;\nvar toObject$1 = toObject$2;\nvar hasOwnProperty = uncurryThis$7({}.hasOwnProperty);\n\n// `HasOwnProperty` abstract operation\n// https://tc39.es/ecma262/#sec-hasownproperty\n// eslint-disable-next-line es/no-object-hasown -- safe\nvar hasOwnProperty_1 = Object.hasOwn || function hasOwn(it, key) {\n return hasOwnProperty(toObject$1(it), key);\n};\nvar uncurryThis$6 = functionUncurryThis;\nvar id = 0;\nvar postfix = Math.random();\nvar toString = uncurryThis$6(1.0.toString);\nvar uid$2 = function uid$2(key) {\n return 'Symbol(' + (key === undefined ? '' : key) + ')_' + toString(++id + postfix, 36);\n};\nvar global$5 = global$a;\nvar shared$2 = shared$3.exports;\nvar hasOwn$6 = hasOwnProperty_1;\nvar uid$1 = uid$2;\nvar NATIVE_SYMBOL = symbolConstructorDetection;\nvar USE_SYMBOL_AS_UID = useSymbolAsUid;\nvar WellKnownSymbolsStore = shared$2('wks');\nvar Symbol$1 = global$5.Symbol;\nvar symbolFor = Symbol$1 && Symbol$1['for'];\nvar createWellKnownSymbol = USE_SYMBOL_AS_UID ? Symbol$1 : Symbol$1 && Symbol$1.withoutSetter || uid$1;\nvar wellKnownSymbol$5 = function wellKnownSymbol$5(name) {\n if (!hasOwn$6(WellKnownSymbolsStore, name) || !(NATIVE_SYMBOL || typeof WellKnownSymbolsStore[name] == 'string')) {\n var description = 'Symbol.' + name;\n if (NATIVE_SYMBOL && hasOwn$6(Symbol$1, name)) {\n WellKnownSymbolsStore[name] = Symbol$1[name];\n } else if (USE_SYMBOL_AS_UID && symbolFor) {\n WellKnownSymbolsStore[name] = symbolFor(description);\n } else {\n WellKnownSymbolsStore[name] = createWellKnownSymbol(description);\n }\n }\n return WellKnownSymbolsStore[name];\n};\nvar call$1 = functionCall;\nvar isObject$4 = isObject$6;\nvar isSymbol$1 = isSymbol$2;\nvar getMethod = getMethod$1;\nvar ordinaryToPrimitive = ordinaryToPrimitive$1;\nvar wellKnownSymbol$4 = wellKnownSymbol$5;\nvar $TypeError$2 = TypeError;\nvar TO_PRIMITIVE = wellKnownSymbol$4('toPrimitive');\n\n// `ToPrimitive` abstract operation\n// https://tc39.es/ecma262/#sec-toprimitive\nvar toPrimitive$1 = function toPrimitive$1(input, pref) {\n if (!isObject$4(input) || isSymbol$1(input)) return input;\n var exoticToPrim = getMethod(input, TO_PRIMITIVE);\n var result;\n if (exoticToPrim) {\n if (pref === undefined) pref = 'default';\n result = call$1(exoticToPrim, input, pref);\n if (!isObject$4(result) || isSymbol$1(result)) return result;\n throw $TypeError$2(\"Can't convert object to primitive value\");\n }\n if (pref === undefined) pref = 'number';\n return ordinaryToPrimitive(input, pref);\n};\nvar toPrimitive = toPrimitive$1;\nvar isSymbol = isSymbol$2;\n\n// `ToPropertyKey` abstract operation\n// https://tc39.es/ecma262/#sec-topropertykey\nvar toPropertyKey$2 = function toPropertyKey$2(argument) {\n var key = toPrimitive(argument, 'string');\n return isSymbol(key) ? key : key + '';\n};\nvar global$4 = global$a;\nvar isObject$3 = isObject$6;\nvar document$1 = global$4.document;\n// typeof document.createElement is 'object' in old IE\nvar EXISTS$1 = isObject$3(document$1) && isObject$3(document$1.createElement);\nvar documentCreateElement$1 = function documentCreateElement$1(it) {\n return EXISTS$1 ? document$1.createElement(it) : {};\n};\nvar DESCRIPTORS$7 = descriptors;\nvar fails$4 = fails$9;\nvar createElement = documentCreateElement$1;\n\n// Thanks to IE8 for its funny defineProperty\nvar ie8DomDefine = !DESCRIPTORS$7 && !fails$4(function () {\n // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n return Object.defineProperty(createElement('div'), 'a', {\n get: function get() {\n return 7;\n }\n }).a != 7;\n});\nvar DESCRIPTORS$6 = descriptors;\nvar call = functionCall;\nvar propertyIsEnumerableModule = objectPropertyIsEnumerable;\nvar createPropertyDescriptor$1 = createPropertyDescriptor$2;\nvar toIndexedObject$3 = toIndexedObject$4;\nvar toPropertyKey$1 = toPropertyKey$2;\nvar hasOwn$5 = hasOwnProperty_1;\nvar IE8_DOM_DEFINE$1 = ie8DomDefine;\n\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar $getOwnPropertyDescriptor$1 = Object.getOwnPropertyDescriptor;\n\n// `Object.getOwnPropertyDescriptor` method\n// https://tc39.es/ecma262/#sec-object.getownpropertydescriptor\nobjectGetOwnPropertyDescriptor.f = DESCRIPTORS$6 ? $getOwnPropertyDescriptor$1 : function getOwnPropertyDescriptor(O, P) {\n O = toIndexedObject$3(O);\n P = toPropertyKey$1(P);\n if (IE8_DOM_DEFINE$1) try {\n return $getOwnPropertyDescriptor$1(O, P);\n } catch (error) {/* empty */}\n if (hasOwn$5(O, P)) return createPropertyDescriptor$1(!call(propertyIsEnumerableModule.f, O, P), O[P]);\n};\nvar objectDefineProperty = {};\nvar DESCRIPTORS$5 = descriptors;\nvar fails$3 = fails$9;\n\n// V8 ~ Chrome 36-\n// https://bugs.chromium.org/p/v8/issues/detail?id=3334\nvar v8PrototypeDefineBug = DESCRIPTORS$5 && fails$3(function () {\n // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n return Object.defineProperty(function () {/* empty */}, 'prototype', {\n value: 42,\n writable: false\n }).prototype != 42;\n});\nvar isObject$2 = isObject$6;\nvar $String = String;\nvar $TypeError$1 = TypeError;\n\n// `Assert: Type(argument) is Object`\nvar anObject$4 = function anObject$4(argument) {\n if (isObject$2(argument)) return argument;\n throw $TypeError$1($String(argument) + ' is not an object');\n};\nvar DESCRIPTORS$4 = descriptors;\nvar IE8_DOM_DEFINE = ie8DomDefine;\nvar V8_PROTOTYPE_DEFINE_BUG$1 = v8PrototypeDefineBug;\nvar anObject$3 = anObject$4;\nvar toPropertyKey = toPropertyKey$2;\nvar $TypeError = TypeError;\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar $defineProperty = Object.defineProperty;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar $getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar ENUMERABLE = 'enumerable';\nvar CONFIGURABLE$1 = 'configurable';\nvar WRITABLE = 'writable';\n\n// `Object.defineProperty` method\n// https://tc39.es/ecma262/#sec-object.defineproperty\nobjectDefineProperty.f = DESCRIPTORS$4 ? V8_PROTOTYPE_DEFINE_BUG$1 ? function defineProperty(O, P, Attributes) {\n anObject$3(O);\n P = toPropertyKey(P);\n anObject$3(Attributes);\n if (typeof O === 'function' && P === 'prototype' && 'value' in Attributes && WRITABLE in Attributes && !Attributes[WRITABLE]) {\n var current = $getOwnPropertyDescriptor(O, P);\n if (current && current[WRITABLE]) {\n O[P] = Attributes.value;\n Attributes = {\n configurable: CONFIGURABLE$1 in Attributes ? Attributes[CONFIGURABLE$1] : current[CONFIGURABLE$1],\n enumerable: ENUMERABLE in Attributes ? Attributes[ENUMERABLE] : current[ENUMERABLE],\n writable: false\n };\n }\n }\n return $defineProperty(O, P, Attributes);\n} : $defineProperty : function defineProperty(O, P, Attributes) {\n anObject$3(O);\n P = toPropertyKey(P);\n anObject$3(Attributes);\n if (IE8_DOM_DEFINE) try {\n return $defineProperty(O, P, Attributes);\n } catch (error) {/* empty */}\n if ('get' in Attributes || 'set' in Attributes) throw $TypeError('Accessors not supported');\n if ('value' in Attributes) O[P] = Attributes.value;\n return O;\n};\nvar DESCRIPTORS$3 = descriptors;\nvar definePropertyModule$3 = objectDefineProperty;\nvar createPropertyDescriptor = createPropertyDescriptor$2;\nvar createNonEnumerableProperty$2 = DESCRIPTORS$3 ? function (object, key, value) {\n return definePropertyModule$3.f(object, key, createPropertyDescriptor(1, value));\n} : function (object, key, value) {\n object[key] = value;\n return object;\n};\nvar makeBuiltIn$2 = {\n exports: {}\n};\nvar DESCRIPTORS$2 = descriptors;\nvar hasOwn$4 = hasOwnProperty_1;\nvar FunctionPrototype = Function.prototype;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getDescriptor = DESCRIPTORS$2 && Object.getOwnPropertyDescriptor;\nvar EXISTS = hasOwn$4(FunctionPrototype, 'name');\n// additional protection from minified / mangled / dropped function names\nvar PROPER = EXISTS && function something() {/* empty */}.name === 'something';\nvar CONFIGURABLE = EXISTS && (!DESCRIPTORS$2 || DESCRIPTORS$2 && getDescriptor(FunctionPrototype, 'name').configurable);\nvar functionName = {\n EXISTS: EXISTS,\n PROPER: PROPER,\n CONFIGURABLE: CONFIGURABLE\n};\nvar uncurryThis$5 = functionUncurryThis;\nvar isCallable$6 = isCallable$c;\nvar store$1 = sharedStore;\nvar functionToString = uncurryThis$5(Function.toString);\n\n// this helper broken in `core-js@3.4.1-3.4.4`, so we can't use `shared` helper\nif (!isCallable$6(store$1.inspectSource)) {\n store$1.inspectSource = function (it) {\n return functionToString(it);\n };\n}\nvar inspectSource$2 = store$1.inspectSource;\nvar global$3 = global$a;\nvar isCallable$5 = isCallable$c;\nvar WeakMap$1 = global$3.WeakMap;\nvar weakMapBasicDetection = isCallable$5(WeakMap$1) && /native code/.test(String(WeakMap$1));\nvar shared$1 = shared$3.exports;\nvar uid = uid$2;\nvar keys = shared$1('keys');\nvar sharedKey$2 = function sharedKey$2(key) {\n return keys[key] || (keys[key] = uid(key));\n};\nvar hiddenKeys$4 = {};\nvar NATIVE_WEAK_MAP = weakMapBasicDetection;\nvar global$2 = global$a;\nvar isObject$1 = isObject$6;\nvar createNonEnumerableProperty$1 = createNonEnumerableProperty$2;\nvar hasOwn$3 = hasOwnProperty_1;\nvar shared = sharedStore;\nvar sharedKey$1 = sharedKey$2;\nvar hiddenKeys$3 = hiddenKeys$4;\nvar OBJECT_ALREADY_INITIALIZED = 'Object already initialized';\nvar TypeError$1 = global$2.TypeError;\nvar WeakMap = global$2.WeakMap;\nvar set, get, has;\nvar enforce = function enforce(it) {\n return has(it) ? get(it) : set(it, {});\n};\nvar getterFor = function getterFor(TYPE) {\n return function (it) {\n var state;\n if (!isObject$1(it) || (state = get(it)).type !== TYPE) {\n throw TypeError$1('Incompatible receiver, ' + TYPE + ' required');\n }\n return state;\n };\n};\nif (NATIVE_WEAK_MAP || shared.state) {\n var store = shared.state || (shared.state = new WeakMap());\n /* eslint-disable no-self-assign -- prototype methods protection */\n store.get = store.get;\n store.has = store.has;\n store.set = store.set;\n /* eslint-enable no-self-assign -- prototype methods protection */\n set = function set(it, metadata) {\n if (store.has(it)) throw TypeError$1(OBJECT_ALREADY_INITIALIZED);\n metadata.facade = it;\n store.set(it, metadata);\n return metadata;\n };\n get = function get(it) {\n return store.get(it) || {};\n };\n has = function has(it) {\n return store.has(it);\n };\n} else {\n var STATE = sharedKey$1('state');\n hiddenKeys$3[STATE] = true;\n set = function set(it, metadata) {\n if (hasOwn$3(it, STATE)) throw TypeError$1(OBJECT_ALREADY_INITIALIZED);\n metadata.facade = it;\n createNonEnumerableProperty$1(it, STATE, metadata);\n return metadata;\n };\n get = function get(it) {\n return hasOwn$3(it, STATE) ? it[STATE] : {};\n };\n has = function has(it) {\n return hasOwn$3(it, STATE);\n };\n}\nvar internalState = {\n set: set,\n get: get,\n has: has,\n enforce: enforce,\n getterFor: getterFor\n};\nvar fails$2 = fails$9;\nvar isCallable$4 = isCallable$c;\nvar hasOwn$2 = hasOwnProperty_1;\nvar DESCRIPTORS$1 = descriptors;\nvar CONFIGURABLE_FUNCTION_NAME = functionName.CONFIGURABLE;\nvar inspectSource$1 = inspectSource$2;\nvar InternalStateModule = internalState;\nvar enforceInternalState = InternalStateModule.enforce;\nvar getInternalState = InternalStateModule.get;\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar defineProperty$1 = Object.defineProperty;\nvar CONFIGURABLE_LENGTH = DESCRIPTORS$1 && !fails$2(function () {\n return defineProperty$1(function () {/* empty */}, 'length', {\n value: 8\n }).length !== 8;\n});\nvar TEMPLATE = String(String).split('String');\nvar makeBuiltIn$1 = makeBuiltIn$2.exports = function (value, name, options) {\n if (String(name).slice(0, 7) === 'Symbol(') {\n name = '[' + String(name).replace(/^Symbol\\(([^)]*)\\)/, '$1') + ']';\n }\n if (options && options.getter) name = 'get ' + name;\n if (options && options.setter) name = 'set ' + name;\n if (!hasOwn$2(value, 'name') || CONFIGURABLE_FUNCTION_NAME && value.name !== name) {\n if (DESCRIPTORS$1) defineProperty$1(value, 'name', {\n value: name,\n configurable: true\n });else value.name = name;\n }\n if (CONFIGURABLE_LENGTH && options && hasOwn$2(options, 'arity') && value.length !== options.arity) {\n defineProperty$1(value, 'length', {\n value: options.arity\n });\n }\n try {\n if (options && hasOwn$2(options, 'constructor') && options.constructor) {\n if (DESCRIPTORS$1) defineProperty$1(value, 'prototype', {\n writable: false\n });\n // in V8 ~ Chrome 53, prototypes of some methods, like `Array.prototype.values`, are non-writable\n } else if (value.prototype) value.prototype = undefined;\n } catch (error) {/* empty */}\n var state = enforceInternalState(value);\n if (!hasOwn$2(state, 'source')) {\n state.source = TEMPLATE.join(typeof name == 'string' ? name : '');\n }\n return value;\n};\n\n// add fake Function#toString for correct work wrapped methods / constructors with methods like LoDash isNative\n// eslint-disable-next-line no-extend-native -- required\nFunction.prototype.toString = makeBuiltIn$1(function toString() {\n return isCallable$4(this) && getInternalState(this).source || inspectSource$1(this);\n}, 'toString');\nvar isCallable$3 = isCallable$c;\nvar definePropertyModule$2 = objectDefineProperty;\nvar makeBuiltIn = makeBuiltIn$2.exports;\nvar defineGlobalProperty$1 = defineGlobalProperty$3;\nvar defineBuiltIn$1 = function defineBuiltIn$1(O, key, value, options) {\n if (!options) options = {};\n var simple = options.enumerable;\n var name = options.name !== undefined ? options.name : key;\n if (isCallable$3(value)) makeBuiltIn(value, name, options);\n if (options.global) {\n if (simple) O[key] = value;else defineGlobalProperty$1(key, value);\n } else {\n try {\n if (!options.unsafe) delete O[key];else if (O[key]) simple = true;\n } catch (error) {/* empty */}\n if (simple) O[key] = value;else definePropertyModule$2.f(O, key, {\n value: value,\n enumerable: false,\n configurable: !options.nonConfigurable,\n writable: !options.nonWritable\n });\n }\n return O;\n};\nvar objectGetOwnPropertyNames = {};\nvar ceil = Math.ceil;\nvar floor = Math.floor;\n\n// `Math.trunc` method\n// https://tc39.es/ecma262/#sec-math.trunc\n// eslint-disable-next-line es/no-math-trunc -- safe\nvar mathTrunc = Math.trunc || function trunc(x) {\n var n = +x;\n return (n > 0 ? floor : ceil)(n);\n};\nvar trunc = mathTrunc;\n\n// `ToIntegerOrInfinity` abstract operation\n// https://tc39.es/ecma262/#sec-tointegerorinfinity\nvar toIntegerOrInfinity$2 = function toIntegerOrInfinity$2(argument) {\n var number = +argument;\n // eslint-disable-next-line no-self-compare -- NaN check\n return number !== number || number === 0 ? 0 : trunc(number);\n};\nvar toIntegerOrInfinity$1 = toIntegerOrInfinity$2;\nvar max = Math.max;\nvar min$1 = Math.min;\n\n// Helper for a popular repeating case of the spec:\n// Let integer be ? ToInteger(index).\n// If integer < 0, let result be max((length + integer), 0); else let result be min(integer, length).\nvar toAbsoluteIndex$1 = function toAbsoluteIndex$1(index, length) {\n var integer = toIntegerOrInfinity$1(index);\n return integer < 0 ? max(integer + length, 0) : min$1(integer, length);\n};\nvar toIntegerOrInfinity = toIntegerOrInfinity$2;\nvar min = Math.min;\n\n// `ToLength` abstract operation\n// https://tc39.es/ecma262/#sec-tolength\nvar toLength$1 = function toLength$1(argument) {\n return argument > 0 ? min(toIntegerOrInfinity(argument), 0x1FFFFFFFFFFFFF) : 0; // 2 ** 53 - 1 == 9007199254740991\n};\n\nvar toLength = toLength$1;\n\n// `LengthOfArrayLike` abstract operation\n// https://tc39.es/ecma262/#sec-lengthofarraylike\nvar lengthOfArrayLike$2 = function lengthOfArrayLike$2(obj) {\n return toLength(obj.length);\n};\nvar toIndexedObject$2 = toIndexedObject$4;\nvar toAbsoluteIndex = toAbsoluteIndex$1;\nvar lengthOfArrayLike$1 = lengthOfArrayLike$2;\n\n// `Array.prototype.{ indexOf, includes }` methods implementation\nvar createMethod$1 = function createMethod$1(IS_INCLUDES) {\n return function ($this, el, fromIndex) {\n var O = toIndexedObject$2($this);\n var length = lengthOfArrayLike$1(O);\n var index = toAbsoluteIndex(fromIndex, length);\n var value;\n // Array#includes uses SameValueZero equality algorithm\n // eslint-disable-next-line no-self-compare -- NaN check\n if (IS_INCLUDES && el != el) while (length > index) {\n value = O[index++];\n // eslint-disable-next-line no-self-compare -- NaN check\n if (value != value) return true;\n // Array#indexOf ignores holes, Array#includes - not\n } else for (; length > index; index++) {\n if ((IS_INCLUDES || index in O) && O[index] === el) return IS_INCLUDES || index || 0;\n }\n return !IS_INCLUDES && -1;\n };\n};\nvar arrayIncludes = {\n // `Array.prototype.includes` method\n // https://tc39.es/ecma262/#sec-array.prototype.includes\n includes: createMethod$1(true),\n // `Array.prototype.indexOf` method\n // https://tc39.es/ecma262/#sec-array.prototype.indexof\n indexOf: createMethod$1(false)\n};\nvar uncurryThis$4 = functionUncurryThis;\nvar hasOwn$1 = hasOwnProperty_1;\nvar toIndexedObject$1 = toIndexedObject$4;\nvar indexOf = arrayIncludes.indexOf;\nvar hiddenKeys$2 = hiddenKeys$4;\nvar push$1 = uncurryThis$4([].push);\nvar objectKeysInternal = function objectKeysInternal(object, names) {\n var O = toIndexedObject$1(object);\n var i = 0;\n var result = [];\n var key;\n for (key in O) !hasOwn$1(hiddenKeys$2, key) && hasOwn$1(O, key) && push$1(result, key);\n // Don't enum bug & hidden keys\n while (names.length > i) if (hasOwn$1(O, key = names[i++])) {\n ~indexOf(result, key) || push$1(result, key);\n }\n return result;\n};\n\n// IE8- don't enum bug keys\nvar enumBugKeys$3 = ['constructor', 'hasOwnProperty', 'isPrototypeOf', 'propertyIsEnumerable', 'toLocaleString', 'toString', 'valueOf'];\nvar internalObjectKeys$1 = objectKeysInternal;\nvar enumBugKeys$2 = enumBugKeys$3;\nvar hiddenKeys$1 = enumBugKeys$2.concat('length', 'prototype');\n\n// `Object.getOwnPropertyNames` method\n// https://tc39.es/ecma262/#sec-object.getownpropertynames\n// eslint-disable-next-line es/no-object-getownpropertynames -- safe\nobjectGetOwnPropertyNames.f = Object.getOwnPropertyNames || function getOwnPropertyNames(O) {\n return internalObjectKeys$1(O, hiddenKeys$1);\n};\nvar objectGetOwnPropertySymbols = {};\n\n// eslint-disable-next-line es/no-object-getownpropertysymbols -- safe\nobjectGetOwnPropertySymbols.f = Object.getOwnPropertySymbols;\nvar getBuiltIn$2 = getBuiltIn$5;\nvar uncurryThis$3 = functionUncurryThis;\nvar getOwnPropertyNamesModule = objectGetOwnPropertyNames;\nvar getOwnPropertySymbolsModule = objectGetOwnPropertySymbols;\nvar anObject$2 = anObject$4;\nvar concat = uncurryThis$3([].concat);\n\n// all object keys, includes non-enumerable and symbols\nvar ownKeys$1 = getBuiltIn$2('Reflect', 'ownKeys') || function ownKeys(it) {\n var keys = getOwnPropertyNamesModule.f(anObject$2(it));\n var getOwnPropertySymbols = getOwnPropertySymbolsModule.f;\n return getOwnPropertySymbols ? concat(keys, getOwnPropertySymbols(it)) : keys;\n};\nvar hasOwn = hasOwnProperty_1;\nvar ownKeys = ownKeys$1;\nvar getOwnPropertyDescriptorModule = objectGetOwnPropertyDescriptor;\nvar definePropertyModule$1 = objectDefineProperty;\nvar copyConstructorProperties$1 = function copyConstructorProperties$1(target, source, exceptions) {\n var keys = ownKeys(source);\n var defineProperty = definePropertyModule$1.f;\n var getOwnPropertyDescriptor = getOwnPropertyDescriptorModule.f;\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n if (!hasOwn(target, key) && !(exceptions && hasOwn(exceptions, key))) {\n defineProperty(target, key, getOwnPropertyDescriptor(source, key));\n }\n }\n};\nvar fails$1 = fails$9;\nvar isCallable$2 = isCallable$c;\nvar replacement = /#|\\.prototype\\./;\nvar isForced$1 = function isForced$1(feature, detection) {\n var value = data[normalize(feature)];\n return value == POLYFILL ? true : value == NATIVE ? false : isCallable$2(detection) ? fails$1(detection) : !!detection;\n};\nvar normalize = isForced$1.normalize = function (string) {\n return String(string).replace(replacement, '.').toLowerCase();\n};\nvar data = isForced$1.data = {};\nvar NATIVE = isForced$1.NATIVE = 'N';\nvar POLYFILL = isForced$1.POLYFILL = 'P';\nvar isForced_1 = isForced$1;\nvar global$1 = global$a;\nvar getOwnPropertyDescriptor = objectGetOwnPropertyDescriptor.f;\nvar createNonEnumerableProperty = createNonEnumerableProperty$2;\nvar defineBuiltIn = defineBuiltIn$1;\nvar defineGlobalProperty = defineGlobalProperty$3;\nvar copyConstructorProperties = copyConstructorProperties$1;\nvar isForced = isForced_1;\n\n/*\n options.target - name of the target object\n options.global - target is the global object\n options.stat - export as static methods of target\n options.proto - export as prototype methods of target\n options.real - real prototype method for the `pure` version\n options.forced - export even if the native feature is available\n options.bind - bind methods to the target, required for the `pure` version\n options.wrap - wrap constructors to preventing global pollution, required for the `pure` version\n options.unsafe - use the simple assignment of property instead of delete + defineProperty\n options.sham - add a flag to not completely full polyfills\n options.enumerable - export as enumerable property\n options.dontCallGetSet - prevent calling a getter on target\n options.name - the .name of the function if it does not match the key\n*/\nvar _export = function _export(options, source) {\n var TARGET = options.target;\n var GLOBAL = options.global;\n var STATIC = options.stat;\n var FORCED, target, key, targetProperty, sourceProperty, descriptor;\n if (GLOBAL) {\n target = global$1;\n } else if (STATIC) {\n target = global$1[TARGET] || defineGlobalProperty(TARGET, {});\n } else {\n target = (global$1[TARGET] || {}).prototype;\n }\n if (target) for (key in source) {\n sourceProperty = source[key];\n if (options.dontCallGetSet) {\n descriptor = getOwnPropertyDescriptor(target, key);\n targetProperty = descriptor && descriptor.value;\n } else targetProperty = target[key];\n FORCED = isForced(GLOBAL ? key : TARGET + (STATIC ? '.' : '#') + key, options.forced);\n // contained in target\n if (!FORCED && targetProperty !== undefined) {\n if (_typeof(sourceProperty) == _typeof(targetProperty)) continue;\n copyConstructorProperties(sourceProperty, targetProperty);\n }\n // add a flag to not completely full polyfills\n if (options.sham || targetProperty && targetProperty.sham) {\n createNonEnumerableProperty(sourceProperty, 'sham', true);\n }\n defineBuiltIn(target, key, sourceProperty, options);\n }\n};\nvar uncurryThis$2 = functionUncurryThis;\nvar aCallable = aCallable$2;\nvar NATIVE_BIND = functionBindNative;\nvar bind$1 = uncurryThis$2(uncurryThis$2.bind);\n\n// optional / simple context binding\nvar functionBindContext = function functionBindContext(fn, that) {\n aCallable(fn);\n return that === undefined ? fn : NATIVE_BIND ? bind$1(fn, that) : function /* ...args */\n () {\n return fn.apply(that, arguments);\n };\n};\nvar classof$2 = classofRaw$2;\n\n// `IsArray` abstract operation\n// https://tc39.es/ecma262/#sec-isarray\n// eslint-disable-next-line es/no-array-isarray -- safe\nvar isArray$1 = Array.isArray || function isArray(argument) {\n return classof$2(argument) == 'Array';\n};\nvar wellKnownSymbol$3 = wellKnownSymbol$5;\nvar TO_STRING_TAG$1 = wellKnownSymbol$3('toStringTag');\nvar test = {};\ntest[TO_STRING_TAG$1] = 'z';\nvar toStringTagSupport = String(test) === '[object z]';\nvar TO_STRING_TAG_SUPPORT = toStringTagSupport;\nvar isCallable$1 = isCallable$c;\nvar classofRaw = classofRaw$2;\nvar wellKnownSymbol$2 = wellKnownSymbol$5;\nvar TO_STRING_TAG = wellKnownSymbol$2('toStringTag');\nvar $Object = Object;\n\n// ES3 wrong here\nvar CORRECT_ARGUMENTS = classofRaw(function () {\n return arguments;\n}()) == 'Arguments';\n\n// fallback for IE11 Script Access Denied error\nvar tryGet = function tryGet(it, key) {\n try {\n return it[key];\n } catch (error) {/* empty */}\n};\n\n// getting tag from ES6+ `Object.prototype.toString`\nvar classof$1 = TO_STRING_TAG_SUPPORT ? classofRaw : function (it) {\n var O, tag, result;\n return it === undefined ? 'Undefined' : it === null ? 'Null'\n // @@toStringTag case\n : typeof (tag = tryGet(O = $Object(it), TO_STRING_TAG)) == 'string' ? tag\n // builtinTag case\n : CORRECT_ARGUMENTS ? classofRaw(O)\n // ES3 arguments fallback\n : (result = classofRaw(O)) == 'Object' && isCallable$1(O.callee) ? 'Arguments' : result;\n};\nvar uncurryThis$1 = functionUncurryThis;\nvar fails = fails$9;\nvar isCallable = isCallable$c;\nvar classof = classof$1;\nvar getBuiltIn$1 = getBuiltIn$5;\nvar inspectSource = inspectSource$2;\nvar noop = function noop() {/* empty */};\nvar empty = [];\nvar construct = getBuiltIn$1('Reflect', 'construct');\nvar constructorRegExp = /^\\s*(?:class|function)\\b/;\nvar exec = uncurryThis$1(constructorRegExp.exec);\nvar INCORRECT_TO_STRING = !constructorRegExp.exec(noop);\nvar isConstructorModern = function isConstructor(argument) {\n if (!isCallable(argument)) return false;\n try {\n construct(noop, empty, argument);\n return true;\n } catch (error) {\n return false;\n }\n};\nvar isConstructorLegacy = function isConstructor(argument) {\n if (!isCallable(argument)) return false;\n switch (classof(argument)) {\n case 'AsyncFunction':\n case 'GeneratorFunction':\n case 'AsyncGeneratorFunction':\n return false;\n }\n try {\n // we can't check .prototype since constructors produced by .bind haven't it\n // `Function#toString` throws on some built-it function in some legacy engines\n // (for example, `DOMQuad` and similar in FF41-)\n return INCORRECT_TO_STRING || !!exec(constructorRegExp, inspectSource(argument));\n } catch (error) {\n return true;\n }\n};\nisConstructorLegacy.sham = true;\n\n// `IsConstructor` abstract operation\n// https://tc39.es/ecma262/#sec-isconstructor\nvar isConstructor$1 = !construct || fails(function () {\n var called;\n return isConstructorModern(isConstructorModern.call) || !isConstructorModern(Object) || !isConstructorModern(function () {\n called = true;\n }) || called;\n}) ? isConstructorLegacy : isConstructorModern;\nvar isArray = isArray$1;\nvar isConstructor = isConstructor$1;\nvar isObject = isObject$6;\nvar wellKnownSymbol$1 = wellKnownSymbol$5;\nvar SPECIES = wellKnownSymbol$1('species');\nvar $Array = Array;\n\n// a part of `ArraySpeciesCreate` abstract operation\n// https://tc39.es/ecma262/#sec-arrayspeciescreate\nvar arraySpeciesConstructor$1 = function arraySpeciesConstructor$1(originalArray) {\n var C;\n if (isArray(originalArray)) {\n C = originalArray.constructor;\n // cross-realm fallback\n if (isConstructor(C) && (C === $Array || isArray(C.prototype))) C = undefined;else if (isObject(C)) {\n C = C[SPECIES];\n if (C === null) C = undefined;\n }\n }\n return C === undefined ? $Array : C;\n};\nvar arraySpeciesConstructor = arraySpeciesConstructor$1;\n\n// `ArraySpeciesCreate` abstract operation\n// https://tc39.es/ecma262/#sec-arrayspeciescreate\nvar arraySpeciesCreate$1 = function arraySpeciesCreate$1(originalArray, length) {\n return new (arraySpeciesConstructor(originalArray))(length === 0 ? 0 : length);\n};\nvar bind = functionBindContext;\nvar uncurryThis = functionUncurryThis;\nvar IndexedObject = indexedObject;\nvar toObject = toObject$2;\nvar lengthOfArrayLike = lengthOfArrayLike$2;\nvar arraySpeciesCreate = arraySpeciesCreate$1;\nvar push = uncurryThis([].push);\n\n// `Array.prototype.{ forEach, map, filter, some, every, find, findIndex, filterReject }` methods implementation\nvar createMethod = function createMethod(TYPE) {\n var IS_MAP = TYPE == 1;\n var IS_FILTER = TYPE == 2;\n var IS_SOME = TYPE == 3;\n var IS_EVERY = TYPE == 4;\n var IS_FIND_INDEX = TYPE == 6;\n var IS_FILTER_REJECT = TYPE == 7;\n var NO_HOLES = TYPE == 5 || IS_FIND_INDEX;\n return function ($this, callbackfn, that, specificCreate) {\n var O = toObject($this);\n var self = IndexedObject(O);\n var boundFunction = bind(callbackfn, that);\n var length = lengthOfArrayLike(self);\n var index = 0;\n var create = specificCreate || arraySpeciesCreate;\n var target = IS_MAP ? create($this, length) : IS_FILTER || IS_FILTER_REJECT ? create($this, 0) : undefined;\n var value, result;\n for (; length > index; index++) if (NO_HOLES || index in self) {\n value = self[index];\n result = boundFunction(value, index, O);\n if (TYPE) {\n if (IS_MAP) target[index] = result; // map\n else if (result) switch (TYPE) {\n case 3:\n return true;\n // some\n case 5:\n return value;\n // find\n case 6:\n return index;\n // findIndex\n case 2:\n push(target, value);\n // filter\n } else switch (TYPE) {\n case 4:\n return false;\n // every\n case 7:\n push(target, value);\n // filterReject\n }\n }\n }\n\n return IS_FIND_INDEX ? -1 : IS_SOME || IS_EVERY ? IS_EVERY : target;\n };\n};\nvar arrayIteration = {\n // `Array.prototype.forEach` method\n // https://tc39.es/ecma262/#sec-array.prototype.foreach\n forEach: createMethod(0),\n // `Array.prototype.map` method\n // https://tc39.es/ecma262/#sec-array.prototype.map\n map: createMethod(1),\n // `Array.prototype.filter` method\n // https://tc39.es/ecma262/#sec-array.prototype.filter\n filter: createMethod(2),\n // `Array.prototype.some` method\n // https://tc39.es/ecma262/#sec-array.prototype.some\n some: createMethod(3),\n // `Array.prototype.every` method\n // https://tc39.es/ecma262/#sec-array.prototype.every\n every: createMethod(4),\n // `Array.prototype.find` method\n // https://tc39.es/ecma262/#sec-array.prototype.find\n find: createMethod(5),\n // `Array.prototype.findIndex` method\n // https://tc39.es/ecma262/#sec-array.prototype.findIndex\n findIndex: createMethod(6),\n // `Array.prototype.filterReject` method\n // https://github.com/tc39/proposal-array-filtering\n filterReject: createMethod(7)\n};\nvar objectDefineProperties = {};\nvar internalObjectKeys = objectKeysInternal;\nvar enumBugKeys$1 = enumBugKeys$3;\n\n// `Object.keys` method\n// https://tc39.es/ecma262/#sec-object.keys\n// eslint-disable-next-line es/no-object-keys -- safe\nvar objectKeys$1 = Object.keys || function keys(O) {\n return internalObjectKeys(O, enumBugKeys$1);\n};\nvar DESCRIPTORS = descriptors;\nvar V8_PROTOTYPE_DEFINE_BUG = v8PrototypeDefineBug;\nvar definePropertyModule = objectDefineProperty;\nvar anObject$1 = anObject$4;\nvar toIndexedObject = toIndexedObject$4;\nvar objectKeys = objectKeys$1;\n\n// `Object.defineProperties` method\n// https://tc39.es/ecma262/#sec-object.defineproperties\n// eslint-disable-next-line es/no-object-defineproperties -- safe\nobjectDefineProperties.f = DESCRIPTORS && !V8_PROTOTYPE_DEFINE_BUG ? Object.defineProperties : function defineProperties(O, Properties) {\n anObject$1(O);\n var props = toIndexedObject(Properties);\n var keys = objectKeys(Properties);\n var length = keys.length;\n var index = 0;\n var key;\n while (length > index) definePropertyModule.f(O, key = keys[index++], props[key]);\n return O;\n};\nvar getBuiltIn = getBuiltIn$5;\nvar html$1 = getBuiltIn('document', 'documentElement');\n\n/* global ActiveXObject -- old IE, WSH */\n\nvar anObject = anObject$4;\nvar definePropertiesModule = objectDefineProperties;\nvar enumBugKeys = enumBugKeys$3;\nvar hiddenKeys = hiddenKeys$4;\nvar html = html$1;\nvar documentCreateElement = documentCreateElement$1;\nvar sharedKey = sharedKey$2;\nvar GT = '>';\nvar LT = '<';\nvar PROTOTYPE = 'prototype';\nvar SCRIPT = 'script';\nvar IE_PROTO = sharedKey('IE_PROTO');\nvar EmptyConstructor = function EmptyConstructor() {/* empty */};\nvar scriptTag = function scriptTag(content) {\n return LT + SCRIPT + GT + content + LT + '/' + SCRIPT + GT;\n};\n\n// Create object with fake `null` prototype: use ActiveX Object with cleared prototype\nvar NullProtoObjectViaActiveX = function NullProtoObjectViaActiveX(activeXDocument) {\n activeXDocument.write(scriptTag(''));\n activeXDocument.close();\n var temp = activeXDocument.parentWindow.Object;\n activeXDocument = null; // avoid memory leak\n return temp;\n};\n\n// Create object with fake `null` prototype: use iframe Object with cleared prototype\nvar NullProtoObjectViaIFrame = function NullProtoObjectViaIFrame() {\n // Thrash, waste and sodomy: IE GC bug\n var iframe = documentCreateElement('iframe');\n var JS = 'java' + SCRIPT + ':';\n var iframeDocument;\n iframe.style.display = 'none';\n html.appendChild(iframe);\n // https://github.com/zloirock/core-js/issues/475\n iframe.src = String(JS);\n iframeDocument = iframe.contentWindow.document;\n iframeDocument.open();\n iframeDocument.write(scriptTag('document.F=Object'));\n iframeDocument.close();\n return iframeDocument.F;\n};\n\n// Check for document.domain and active x support\n// No need to use active x approach when document.domain is not set\n// see https://github.com/es-shims/es5-shim/issues/150\n// variation of https://github.com/kitcambridge/es5-shim/commit/4f738ac066346\n// avoid IE GC bug\nvar activeXDocument;\nvar _NullProtoObject = function NullProtoObject() {\n try {\n activeXDocument = new ActiveXObject('htmlfile');\n } catch (error) {/* ignore */}\n _NullProtoObject = typeof document != 'undefined' ? document.domain && activeXDocument ? NullProtoObjectViaActiveX(activeXDocument) // old IE\n : NullProtoObjectViaIFrame() : NullProtoObjectViaActiveX(activeXDocument); // WSH\n var length = enumBugKeys.length;\n while (length--) delete _NullProtoObject[PROTOTYPE][enumBugKeys[length]];\n return _NullProtoObject();\n};\nhiddenKeys[IE_PROTO] = true;\n\n// `Object.create` method\n// https://tc39.es/ecma262/#sec-object.create\n// eslint-disable-next-line es/no-object-create -- safe\nvar objectCreate = Object.create || function create(O, Properties) {\n var result;\n if (O !== null) {\n EmptyConstructor[PROTOTYPE] = anObject(O);\n result = new EmptyConstructor();\n EmptyConstructor[PROTOTYPE] = null;\n // add \"__proto__\" for Object.getPrototypeOf polyfill\n result[IE_PROTO] = O;\n } else result = _NullProtoObject();\n return Properties === undefined ? result : definePropertiesModule.f(result, Properties);\n};\nvar wellKnownSymbol = wellKnownSymbol$5;\nvar create = objectCreate;\nvar defineProperty = objectDefineProperty.f;\nvar UNSCOPABLES = wellKnownSymbol('unscopables');\nvar ArrayPrototype = Array.prototype;\n\n// Array.prototype[@@unscopables]\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\nif (ArrayPrototype[UNSCOPABLES] == undefined) {\n defineProperty(ArrayPrototype, UNSCOPABLES, {\n configurable: true,\n value: create(null)\n });\n}\n\n// add a key to Array.prototype[@@unscopables]\nvar addToUnscopables$1 = function addToUnscopables$1(key) {\n ArrayPrototype[UNSCOPABLES][key] = true;\n};\nvar $ = _export;\nvar $find = arrayIteration.find;\nvar addToUnscopables = addToUnscopables$1;\nvar FIND = 'find';\nvar SKIPS_HOLES = true;\n\n// Shouldn't skip holes\nif (FIND in []) Array(1)[FIND](function () {\n SKIPS_HOLES = false;\n});\n\n// `Array.prototype.find` method\n// https://tc39.es/ecma262/#sec-array.prototype.find\n$({\n target: 'Array',\n proto: true,\n forced: SKIPS_HOLES\n}, {\n find: function find(callbackfn /* , that = undefined */) {\n return $find(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\n\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\naddToUnscopables(FIND);\nvar CONSTANT = {\n GLOBAL: {\n HIDE: '__react_tooltip_hide_event',\n REBUILD: '__react_tooltip_rebuild_event',\n SHOW: '__react_tooltip_show_event'\n }\n};\n\n/**\n * Static methods for react-tooltip\n */\nvar dispatchGlobalEvent = function dispatchGlobalEvent(eventName, opts) {\n // Compatible with IE\n // @see http://stackoverflow.com/questions/26596123/internet-explorer-9-10-11-event-constructor-doesnt-work\n // @see https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent/CustomEvent\n var event;\n if (typeof window.CustomEvent === 'function') {\n event = new window.CustomEvent(eventName, {\n detail: opts\n });\n } else {\n event = document.createEvent('Event');\n event.initEvent(eventName, false, true, opts);\n }\n window.dispatchEvent(event);\n};\nfunction staticMethods(target) {\n /**\n * Hide all tooltip\n * @trigger ReactTooltip.hide()\n */\n target.hide = function (target) {\n dispatchGlobalEvent(CONSTANT.GLOBAL.HIDE, {\n target: target\n });\n };\n\n /**\n * Rebuild all tooltip\n * @trigger ReactTooltip.rebuild()\n */\n target.rebuild = function () {\n dispatchGlobalEvent(CONSTANT.GLOBAL.REBUILD);\n };\n\n /**\n * Show specific tooltip\n * @trigger ReactTooltip.show()\n */\n target.show = function (target) {\n dispatchGlobalEvent(CONSTANT.GLOBAL.SHOW, {\n target: target\n });\n };\n target.prototype.globalRebuild = function () {\n if (this.mount) {\n this.unbindListener();\n this.bindListener();\n }\n };\n target.prototype.globalShow = function (event) {\n if (this.mount) {\n var hasTarget = event && event.detail && event.detail.target && true || false;\n // Create a fake event, specific show will limit the type to `solid`\n // only `float` type cares e.clientX e.clientY\n this.showTooltip({\n currentTarget: hasTarget && event.detail.target\n }, true);\n }\n };\n target.prototype.globalHide = function (event) {\n if (this.mount) {\n var hasTarget = event && event.detail && event.detail.target && true || false;\n this.hideTooltip({\n currentTarget: hasTarget && event.detail.target\n }, hasTarget);\n }\n };\n}\n\n/**\n * Events that should be bound to the window\n */\nfunction windowListener(target) {\n target.prototype.bindWindowEvents = function (resizeHide) {\n // ReactTooltip.hide\n window.removeEventListener(CONSTANT.GLOBAL.HIDE, this.globalHide);\n window.addEventListener(CONSTANT.GLOBAL.HIDE, this.globalHide, false);\n\n // ReactTooltip.rebuild\n window.removeEventListener(CONSTANT.GLOBAL.REBUILD, this.globalRebuild);\n window.addEventListener(CONSTANT.GLOBAL.REBUILD, this.globalRebuild, false);\n\n // ReactTooltip.show\n window.removeEventListener(CONSTANT.GLOBAL.SHOW, this.globalShow);\n window.addEventListener(CONSTANT.GLOBAL.SHOW, this.globalShow, false);\n\n // Resize\n if (resizeHide) {\n window.removeEventListener('resize', this.onWindowResize);\n window.addEventListener('resize', this.onWindowResize, false);\n }\n };\n target.prototype.unbindWindowEvents = function () {\n window.removeEventListener(CONSTANT.GLOBAL.HIDE, this.globalHide);\n window.removeEventListener(CONSTANT.GLOBAL.REBUILD, this.globalRebuild);\n window.removeEventListener(CONSTANT.GLOBAL.SHOW, this.globalShow);\n window.removeEventListener('resize', this.onWindowResize);\n };\n\n /**\n * invoked by resize event of window\n */\n target.prototype.onWindowResize = function () {\n if (!this.mount) return;\n this.hideTooltip();\n };\n}\n\n/**\n * Custom events to control showing and hiding of tooltip\n *\n * @attributes\n * - `event` {String}\n * - `eventOff` {String}\n */\n\nvar checkStatus = function checkStatus(dataEventOff, e) {\n var show = this.state.show;\n var id = this.props.id;\n var isCapture = this.isCapture(e.currentTarget);\n var currentItem = e.currentTarget.getAttribute('currentItem');\n if (!isCapture) e.stopPropagation();\n if (show && currentItem === 'true') {\n if (!dataEventOff) this.hideTooltip(e);\n } else {\n e.currentTarget.setAttribute('currentItem', 'true');\n setUntargetItems(e.currentTarget, this.getTargetArray(id));\n this.showTooltip(e);\n }\n};\nvar setUntargetItems = function setUntargetItems(currentTarget, targetArray) {\n for (var i = 0; i < targetArray.length; i++) {\n if (currentTarget !== targetArray[i]) {\n targetArray[i].setAttribute('currentItem', 'false');\n } else {\n targetArray[i].setAttribute('currentItem', 'true');\n }\n }\n};\nvar customListeners = {\n id: '9b69f92e-d3fe-498b-b1b4-c5e63a51b0cf',\n set: function set(target, event, listener) {\n if (this.id in target) {\n var map = target[this.id];\n map[event] = listener;\n } else {\n // this is workaround for WeakMap, which is not supported in older browsers, such as IE\n Object.defineProperty(target, this.id, {\n configurable: true,\n value: _defineProperty({}, event, listener)\n });\n }\n },\n get: function get(target, event) {\n var map = target[this.id];\n if (map !== undefined) {\n return map[event];\n }\n }\n};\nfunction customEvent(target) {\n target.prototype.isCustomEvent = function (ele) {\n var event = this.state.event;\n return event || !!ele.getAttribute('data-event');\n };\n\n /* Bind listener for custom event */\n target.prototype.customBindListener = function (ele) {\n var _this = this;\n var _this$state = this.state,\n event = _this$state.event,\n eventOff = _this$state.eventOff;\n var dataEvent = ele.getAttribute('data-event') || event;\n var dataEventOff = ele.getAttribute('data-event-off') || eventOff;\n dataEvent.split(' ').forEach(function (event) {\n ele.removeEventListener(event, customListeners.get(ele, event));\n var customListener = checkStatus.bind(_this, dataEventOff);\n customListeners.set(ele, event, customListener);\n ele.addEventListener(event, customListener, false);\n });\n if (dataEventOff) {\n dataEventOff.split(' ').forEach(function (event) {\n ele.removeEventListener(event, _this.hideTooltip);\n ele.addEventListener(event, _this.hideTooltip, false);\n });\n }\n };\n\n /* Unbind listener for custom event */\n target.prototype.customUnbindListener = function (ele) {\n var _this$state2 = this.state,\n event = _this$state2.event,\n eventOff = _this$state2.eventOff;\n var dataEvent = event || ele.getAttribute('data-event');\n var dataEventOff = eventOff || ele.getAttribute('data-event-off');\n ele.removeEventListener(dataEvent, customListeners.get(ele, event));\n if (dataEventOff) ele.removeEventListener(dataEventOff, this.hideTooltip);\n };\n}\n\n/**\n * Util method to judge if it should follow capture model\n */\n\nfunction isCapture(target) {\n target.prototype.isCapture = function (currentTarget) {\n return currentTarget && currentTarget.getAttribute('data-iscapture') === 'true' || this.props.isCapture || false;\n };\n}\n\n/**\n * Util method to get effect\n */\n\nfunction getEffect(target) {\n target.prototype.getEffect = function (currentTarget) {\n var dataEffect = currentTarget.getAttribute('data-effect');\n return dataEffect || this.props.effect || 'float';\n };\n}\n\n/**\n * Util method to get effect\n */\nvar makeProxy = function makeProxy(e) {\n var proxy = {};\n for (var key in e) {\n if (typeof e[key] === 'function') {\n proxy[key] = e[key].bind(e);\n } else {\n proxy[key] = e[key];\n }\n }\n return proxy;\n};\nvar bodyListener = function bodyListener(callback, options, e) {\n var _options$respectEffec = options.respectEffect,\n respectEffect = _options$respectEffec === void 0 ? false : _options$respectEffec,\n _options$customEvent = options.customEvent,\n customEvent = _options$customEvent === void 0 ? false : _options$customEvent;\n var id = this.props.id;\n var tip = null;\n var forId;\n var target = e.target;\n var lastTarget;\n // walk up parent chain until tip is found\n // there is no match if parent visible area is matched by mouse position, so some corner cases might not work as expected\n while (tip === null && target !== null) {\n lastTarget = target;\n tip = target.getAttribute('data-tip') || null;\n forId = target.getAttribute('data-for') || null;\n target = target.parentElement;\n }\n target = lastTarget || e.target;\n if (this.isCustomEvent(target) && !customEvent) {\n return;\n }\n var isTargetBelongsToTooltip = id == null && forId == null || forId === id;\n if (tip != null && (!respectEffect || this.getEffect(target) === 'float') && isTargetBelongsToTooltip) {\n var proxy = makeProxy(e);\n proxy.currentTarget = target;\n callback(proxy);\n }\n};\nvar findCustomEvents = function findCustomEvents(targetArray, dataAttribute) {\n var events = {};\n targetArray.forEach(function (target) {\n var event = target.getAttribute(dataAttribute);\n if (event) event.split(' ').forEach(function (event) {\n return events[event] = true;\n });\n });\n return events;\n};\nvar getBody = function getBody() {\n return document.getElementsByTagName('body')[0];\n};\nfunction bodyMode(target) {\n target.prototype.isBodyMode = function () {\n return !!this.props.bodyMode;\n };\n target.prototype.bindBodyListener = function (targetArray) {\n var _this = this;\n var _this$state = this.state,\n event = _this$state.event,\n eventOff = _this$state.eventOff,\n possibleCustomEvents = _this$state.possibleCustomEvents,\n possibleCustomEventsOff = _this$state.possibleCustomEventsOff;\n var body = getBody();\n var customEvents = findCustomEvents(targetArray, 'data-event');\n var customEventsOff = findCustomEvents(targetArray, 'data-event-off');\n if (event != null) customEvents[event] = true;\n if (eventOff != null) customEventsOff[eventOff] = true;\n possibleCustomEvents.split(' ').forEach(function (event) {\n return customEvents[event] = true;\n });\n possibleCustomEventsOff.split(' ').forEach(function (event) {\n return customEventsOff[event] = true;\n });\n this.unbindBodyListener(body);\n var listeners = this.bodyModeListeners = {};\n if (event == null) {\n listeners.mouseover = bodyListener.bind(this, this.showTooltip, {});\n listeners.mousemove = bodyListener.bind(this, this.updateTooltip, {\n respectEffect: true\n });\n listeners.mouseout = bodyListener.bind(this, this.hideTooltip, {});\n }\n for (var _event in customEvents) {\n listeners[_event] = bodyListener.bind(this, function (e) {\n var targetEventOff = e.currentTarget.getAttribute('data-event-off') || eventOff;\n checkStatus.call(_this, targetEventOff, e);\n }, {\n customEvent: true\n });\n }\n for (var _event2 in customEventsOff) {\n listeners[_event2] = bodyListener.bind(this, this.hideTooltip, {\n customEvent: true\n });\n }\n for (var _event3 in listeners) {\n body.addEventListener(_event3, listeners[_event3]);\n }\n };\n target.prototype.unbindBodyListener = function (body) {\n body = body || getBody();\n var listeners = this.bodyModeListeners;\n for (var event in listeners) {\n body.removeEventListener(event, listeners[event]);\n }\n };\n}\n\n/**\n * Tracking target removing from DOM.\n * It's necessary to hide tooltip when it's target disappears.\n * Otherwise, the tooltip would be shown forever until another target\n * is triggered.\n *\n * If MutationObserver is not available, this feature just doesn't work.\n */\n\n// https://hacks.mozilla.org/2012/05/dom-mutationobserver-reacting-to-dom-changes-without-killing-browser-performance/\nvar getMutationObserverClass = function getMutationObserverClass() {\n return window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver;\n};\nfunction trackRemoval(target) {\n target.prototype.bindRemovalTracker = function () {\n var _this = this;\n var MutationObserver = getMutationObserverClass();\n if (MutationObserver == null) return;\n var observer = new MutationObserver(function (mutations) {\n for (var m1 = 0; m1 < mutations.length; m1++) {\n var mutation = mutations[m1];\n for (var m2 = 0; m2 < mutation.removedNodes.length; m2++) {\n var element = mutation.removedNodes[m2];\n if (element === _this.state.currentTarget) {\n _this.hideTooltip();\n return;\n }\n }\n }\n });\n observer.observe(window.document, {\n childList: true,\n subtree: true\n });\n this.removalTracker = observer;\n };\n target.prototype.unbindRemovalTracker = function () {\n if (this.removalTracker) {\n this.removalTracker.disconnect();\n this.removalTracker = null;\n }\n };\n}\n\n/**\n * Calculate the position of tooltip\n *\n * @params\n * - `e` {Event} the event of current mouse\n * - `target` {Element} the currentTarget of the event\n * - `node` {DOM} the react-tooltip object\n * - `place` {String} top / right / bottom / left\n * - `effect` {String} float / solid\n * - `offset` {Object} the offset to default position\n *\n * @return {Object}\n * - `isNewState` {Bool} required\n * - `newState` {Object}\n * - `position` {Object} {left: {Number}, top: {Number}}\n */\nfunction getPosition(e, target, node, place, desiredPlace, effect, offset) {\n var _getDimensions = getDimensions(node),\n tipWidth = _getDimensions.width,\n tipHeight = _getDimensions.height;\n var _getDimensions2 = getDimensions(target),\n targetWidth = _getDimensions2.width,\n targetHeight = _getDimensions2.height;\n var _getCurrentOffset = getCurrentOffset(e, target, effect),\n mouseX = _getCurrentOffset.mouseX,\n mouseY = _getCurrentOffset.mouseY;\n var defaultOffset = getDefaultPosition(effect, targetWidth, targetHeight, tipWidth, tipHeight);\n var _calculateOffset = calculateOffset(offset),\n extraOffsetX = _calculateOffset.extraOffsetX,\n extraOffsetY = _calculateOffset.extraOffsetY;\n var windowWidth = window.innerWidth;\n var windowHeight = window.innerHeight;\n var _getParent = getParent(node),\n parentTop = _getParent.parentTop,\n parentLeft = _getParent.parentLeft;\n\n // Get the edge offset of the tooltip\n var getTipOffsetLeft = function getTipOffsetLeft(place) {\n var offsetX = defaultOffset[place].l;\n return mouseX + offsetX + extraOffsetX;\n };\n var getTipOffsetRight = function getTipOffsetRight(place) {\n var offsetX = defaultOffset[place].r;\n return mouseX + offsetX + extraOffsetX;\n };\n var getTipOffsetTop = function getTipOffsetTop(place) {\n var offsetY = defaultOffset[place].t;\n return mouseY + offsetY + extraOffsetY;\n };\n var getTipOffsetBottom = function getTipOffsetBottom(place) {\n var offsetY = defaultOffset[place].b;\n return mouseY + offsetY + extraOffsetY;\n };\n\n //\n // Functions to test whether the tooltip's sides are inside\n // the client window for a given orientation p\n //\n // _____________\n // | | <-- Right side\n // | p = 'left' |\\\n // | |/ |\\\n // |_____________| |_\\ <-- Mouse\n // / \\ |\n // |\n // |\n // Bottom side\n //\n var outsideLeft = function outsideLeft(p) {\n return getTipOffsetLeft(p) < 0;\n };\n var outsideRight = function outsideRight(p) {\n return getTipOffsetRight(p) > windowWidth;\n };\n var outsideTop = function outsideTop(p) {\n return getTipOffsetTop(p) < 0;\n };\n var outsideBottom = function outsideBottom(p) {\n return getTipOffsetBottom(p) > windowHeight;\n };\n\n // Check whether the tooltip with orientation p is completely inside the client window\n var outside = function outside(p) {\n return outsideLeft(p) || outsideRight(p) || outsideTop(p) || outsideBottom(p);\n };\n var inside = function inside(p) {\n return !outside(p);\n };\n var placeIsInside = {\n top: inside('top'),\n bottom: inside('bottom'),\n left: inside('left'),\n right: inside('right')\n };\n function choose() {\n var allPlaces = desiredPlace.split(',').concat(place, ['top', 'bottom', 'left', 'right']);\n var _iterator = _createForOfIteratorHelper(allPlaces),\n _step;\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var d = _step.value;\n if (placeIsInside[d]) return d;\n }\n // if nothing is inside, just use the old place.\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n return place;\n }\n var chosen = choose();\n var isNewState = false;\n var newPlace;\n if (chosen && chosen !== place) {\n isNewState = true;\n newPlace = chosen;\n }\n if (isNewState) {\n return {\n isNewState: true,\n newState: {\n place: newPlace\n }\n };\n }\n return {\n isNewState: false,\n position: {\n left: parseInt(getTipOffsetLeft(place) - parentLeft, 10),\n top: parseInt(getTipOffsetTop(place) - parentTop, 10)\n }\n };\n}\nvar getDimensions = function getDimensions(node) {\n var _node$getBoundingClie = node.getBoundingClientRect(),\n height = _node$getBoundingClie.height,\n width = _node$getBoundingClie.width;\n return {\n height: parseInt(height, 10),\n width: parseInt(width, 10)\n };\n};\n\n// Get current mouse offset\nvar getCurrentOffset = function getCurrentOffset(e, currentTarget, effect) {\n var boundingClientRect = currentTarget.getBoundingClientRect();\n var targetTop = boundingClientRect.top;\n var targetLeft = boundingClientRect.left;\n var _getDimensions3 = getDimensions(currentTarget),\n targetWidth = _getDimensions3.width,\n targetHeight = _getDimensions3.height;\n if (effect === 'float') {\n return {\n mouseX: e.clientX,\n mouseY: e.clientY\n };\n }\n return {\n mouseX: targetLeft + targetWidth / 2,\n mouseY: targetTop + targetHeight / 2\n };\n};\n\n// List all possibility of tooltip final offset\n// This is useful in judging if it is necessary for tooltip to switch position when out of window\nvar getDefaultPosition = function getDefaultPosition(effect, targetWidth, targetHeight, tipWidth, tipHeight) {\n var top;\n var right;\n var bottom;\n var left;\n var disToMouse = 3;\n var triangleHeight = 2;\n var cursorHeight = 12; // Optimize for float bottom only, cause the cursor will hide the tooltip\n\n if (effect === 'float') {\n top = {\n l: -(tipWidth / 2),\n r: tipWidth / 2,\n t: -(tipHeight + disToMouse + triangleHeight),\n b: -disToMouse\n };\n bottom = {\n l: -(tipWidth / 2),\n r: tipWidth / 2,\n t: disToMouse + cursorHeight,\n b: tipHeight + disToMouse + triangleHeight + cursorHeight\n };\n left = {\n l: -(tipWidth + disToMouse + triangleHeight),\n r: -disToMouse,\n t: -(tipHeight / 2),\n b: tipHeight / 2\n };\n right = {\n l: disToMouse,\n r: tipWidth + disToMouse + triangleHeight,\n t: -(tipHeight / 2),\n b: tipHeight / 2\n };\n } else if (effect === 'solid') {\n top = {\n l: -(tipWidth / 2),\n r: tipWidth / 2,\n t: -(targetHeight / 2 + tipHeight + triangleHeight),\n b: -(targetHeight / 2)\n };\n bottom = {\n l: -(tipWidth / 2),\n r: tipWidth / 2,\n t: targetHeight / 2,\n b: targetHeight / 2 + tipHeight + triangleHeight\n };\n left = {\n l: -(tipWidth + targetWidth / 2 + triangleHeight),\n r: -(targetWidth / 2),\n t: -(tipHeight / 2),\n b: tipHeight / 2\n };\n right = {\n l: targetWidth / 2,\n r: tipWidth + targetWidth / 2 + triangleHeight,\n t: -(tipHeight / 2),\n b: tipHeight / 2\n };\n }\n return {\n top: top,\n bottom: bottom,\n left: left,\n right: right\n };\n};\n\n// Consider additional offset into position calculation\nvar calculateOffset = function calculateOffset(offset) {\n var extraOffsetX = 0;\n var extraOffsetY = 0;\n if (Object.prototype.toString.apply(offset) === '[object String]') {\n offset = JSON.parse(offset.toString().replace(/'/g, '\"'));\n }\n for (var key in offset) {\n if (key === 'top') {\n extraOffsetY -= parseInt(offset[key], 10);\n } else if (key === 'bottom') {\n extraOffsetY += parseInt(offset[key], 10);\n } else if (key === 'left') {\n extraOffsetX -= parseInt(offset[key], 10);\n } else if (key === 'right') {\n extraOffsetX += parseInt(offset[key], 10);\n }\n }\n return {\n extraOffsetX: extraOffsetX,\n extraOffsetY: extraOffsetY\n };\n};\n\n// Get the offset of the parent elements\nvar getParent = function getParent(currentTarget) {\n var currentParent = currentTarget;\n while (currentParent) {\n var computedStyle = window.getComputedStyle(currentParent);\n // transform and will-change: transform change the containing block\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_Block\n if (computedStyle.getPropertyValue('transform') !== 'none' || computedStyle.getPropertyValue('will-change') === 'transform') break;\n currentParent = currentParent.parentElement;\n }\n var parentTop = currentParent && currentParent.getBoundingClientRect().top || 0;\n var parentLeft = currentParent && currentParent.getBoundingClientRect().left || 0;\n return {\n parentTop: parentTop,\n parentLeft: parentLeft\n };\n};\n\n/**\n * To get the tooltip content\n * it may comes from data-tip or this.props.children\n * it should support multiline\n *\n * @params\n * - `tip` {String} value of data-tip\n * - `children` {ReactElement} this.props.children\n * - `multiline` {Any} could be Bool(true/false) or String('true'/'false')\n *\n * @return\n * - String or react component\n */\nfunction TipContent(tip, children, getContent, multiline) {\n if (children) return children;\n if (getContent !== undefined && getContent !== null) return getContent; // getContent can be 0, '', etc.\n if (getContent === null) return null; // Tip not exist and children is null or undefined\n\n var regexp = /
/;\n if (!multiline || multiline === 'false' || !regexp.test(tip)) {\n // No trim(), so that user can keep their input\n return tip;\n }\n\n // Multiline tooltip content\n return tip.split(regexp).map(function (d, i) {\n return /*#__PURE__*/React.createElement(\"span\", {\n key: i,\n className: \"multi-line\"\n }, d);\n });\n}\n\n/**\n * Support aria- and role in ReactTooltip\n *\n * @params props {Object}\n * @return {Object}\n */\nfunction parseAria(props) {\n var ariaObj = {};\n Object.keys(props).filter(function (prop) {\n // aria-xxx and role is acceptable\n return /(^aria-\\w+$|^role$)/.test(prop);\n }).forEach(function (prop) {\n ariaObj[prop] = props[prop];\n });\n return ariaObj;\n}\n\n/**\n * Convert nodelist to array\n * @see https://github.com/facebook/fbjs/blob/e66ba20ad5be433eb54423f2b097d829324d9de6/packages/fbjs/src/core/createArrayFromMixed.js#L24\n * NodeLists are functions in Safari\n */\n\nfunction nodeListToArray(nodeList) {\n var length = nodeList.length;\n if (nodeList.hasOwnProperty) {\n return Array.prototype.slice.call(nodeList);\n }\n return new Array(length).fill().map(function (index) {\n return nodeList[index];\n });\n}\nfunction generateUUID() {\n return 't' + v4();\n}\nvar baseCss = \".__react_component_tooltip {\\n border-radius: 3px;\\n display: inline-block;\\n font-size: 13px;\\n left: -999em;\\n opacity: 0;\\n position: fixed;\\n pointer-events: none;\\n transition: opacity 0.3s ease-out;\\n top: -999em;\\n visibility: hidden;\\n z-index: 999;\\n}\\n.__react_component_tooltip.allow_hover, .__react_component_tooltip.allow_click {\\n pointer-events: auto;\\n}\\n.__react_component_tooltip::before, .__react_component_tooltip::after {\\n content: \\\"\\\";\\n width: 0;\\n height: 0;\\n position: absolute;\\n}\\n.__react_component_tooltip.show {\\n opacity: 0.9;\\n margin-top: 0;\\n margin-left: 0;\\n visibility: visible;\\n}\\n.__react_component_tooltip.place-top::before {\\n bottom: 0;\\n left: 50%;\\n margin-left: -11px;\\n}\\n.__react_component_tooltip.place-bottom::before {\\n top: 0;\\n left: 50%;\\n margin-left: -11px;\\n}\\n.__react_component_tooltip.place-left::before {\\n right: 0;\\n top: 50%;\\n margin-top: -9px;\\n}\\n.__react_component_tooltip.place-right::before {\\n left: 0;\\n top: 50%;\\n margin-top: -9px;\\n}\\n.__react_component_tooltip .multi-line {\\n display: block;\\n padding: 2px 0;\\n text-align: center;\\n}\";\n\n/**\n * Default pop-up style values (text color, background color).\n */\nvar defaultColors = {\n dark: {\n text: '#fff',\n background: '#222',\n border: 'transparent',\n arrow: '#222'\n },\n success: {\n text: '#fff',\n background: '#8DC572',\n border: 'transparent',\n arrow: '#8DC572'\n },\n warning: {\n text: '#fff',\n background: '#F0AD4E',\n border: 'transparent',\n arrow: '#F0AD4E'\n },\n error: {\n text: '#fff',\n background: '#BE6464',\n border: 'transparent',\n arrow: '#BE6464'\n },\n info: {\n text: '#fff',\n background: '#337AB7',\n border: 'transparent',\n arrow: '#337AB7'\n },\n light: {\n text: '#222',\n background: '#fff',\n border: 'transparent',\n arrow: '#fff'\n }\n};\nfunction getDefaultPopupColors(type) {\n return defaultColors[type] ? _objectSpread2({}, defaultColors[type]) : undefined;\n}\nvar DEFAULT_PADDING = '8px 21px';\nvar DEFAULT_RADIUS = {\n tooltip: 3,\n arrow: 0\n};\n\n/**\n * Generates the specific tooltip style for use on render.\n */\nfunction generateTooltipStyle(uuid, customColors, type, hasBorder, padding, radius) {\n return generateStyle(uuid, getPopupColors(customColors, type, hasBorder), padding, radius);\n}\n\n/**\n * Generates the tooltip style rules based on the element-specified \"data-type\" property.\n */\nfunction generateStyle(uuid, colors) {\n var padding = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : DEFAULT_PADDING;\n var radius = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : DEFAULT_RADIUS;\n var textColor = colors.text;\n var backgroundColor = colors.background;\n var borderColor = colors.border;\n var arrowColor = colors.arrow;\n var arrowRadius = radius.arrow;\n var tooltipRadius = radius.tooltip;\n return \"\\n \\t.\".concat(uuid, \" {\\n\\t color: \").concat(textColor, \";\\n\\t background: \").concat(backgroundColor, \";\\n\\t border: 1px solid \").concat(borderColor, \";\\n\\t border-radius: \").concat(tooltipRadius, \"px;\\n\\t padding: \").concat(padding, \";\\n \\t}\\n\\n \\t.\").concat(uuid, \".place-top {\\n margin-top: -10px;\\n }\\n .\").concat(uuid, \".place-top::before {\\n content: \\\"\\\";\\n background-color: inherit;\\n position: absolute;\\n z-index: 2;\\n width: 20px;\\n height: 12px;\\n }\\n .\").concat(uuid, \".place-top::after {\\n content: \\\"\\\";\\n position: absolute;\\n width: 10px;\\n height: 10px;\\n border-top-right-radius: \").concat(arrowRadius, \"px;\\n border: 1px solid \").concat(borderColor, \";\\n background-color: \").concat(arrowColor, \";\\n z-index: -2;\\n bottom: -6px;\\n left: 50%;\\n margin-left: -6px;\\n transform: rotate(135deg);\\n }\\n\\n .\").concat(uuid, \".place-bottom {\\n margin-top: 10px;\\n }\\n .\").concat(uuid, \".place-bottom::before {\\n content: \\\"\\\";\\n background-color: inherit;\\n position: absolute;\\n z-index: -1;\\n width: 18px;\\n height: 10px;\\n }\\n .\").concat(uuid, \".place-bottom::after {\\n content: \\\"\\\";\\n position: absolute;\\n width: 10px;\\n height: 10px;\\n border-top-right-radius: \").concat(arrowRadius, \"px;\\n border: 1px solid \").concat(borderColor, \";\\n background-color: \").concat(arrowColor, \";\\n z-index: -2;\\n top: -6px;\\n left: 50%;\\n margin-left: -6px;\\n transform: rotate(45deg);\\n }\\n\\n .\").concat(uuid, \".place-left {\\n margin-left: -10px;\\n }\\n .\").concat(uuid, \".place-left::before {\\n content: \\\"\\\";\\n background-color: inherit;\\n position: absolute;\\n z-index: -1;\\n width: 10px;\\n height: 18px;\\n }\\n .\").concat(uuid, \".place-left::after {\\n content: \\\"\\\";\\n position: absolute;\\n width: 10px;\\n height: 10px;\\n border-top-right-radius: \").concat(arrowRadius, \"px;\\n border: 1px solid \").concat(borderColor, \";\\n background-color: \").concat(arrowColor, \";\\n z-index: -2;\\n right: -6px;\\n top: 50%;\\n margin-top: -6px;\\n transform: rotate(45deg);\\n }\\n\\n .\").concat(uuid, \".place-right {\\n margin-left: 10px;\\n }\\n .\").concat(uuid, \".place-right::before {\\n content: \\\"\\\";\\n background-color: inherit;\\n position: absolute;\\n z-index: -1;\\n width: 10px;\\n height: 18px;\\n }\\n .\").concat(uuid, \".place-right::after {\\n content: \\\"\\\";\\n position: absolute;\\n width: 10px;\\n height: 10px;\\n border-top-right-radius: \").concat(arrowRadius, \"px;\\n border: 1px solid \").concat(borderColor, \";\\n background-color: \").concat(arrowColor, \";\\n z-index: -2;\\n left: -6px;\\n top: 50%;\\n margin-top: -6px;\\n transform: rotate(-135deg);\\n }\\n \");\n}\nfunction getPopupColors(customColors, type, hasBorder) {\n var textColor = customColors.text;\n var backgroundColor = customColors.background;\n var borderColor = customColors.border;\n var arrowColor = customColors.arrow ? customColors.arrow : customColors.background;\n var colors = getDefaultPopupColors(type);\n if (textColor) {\n colors.text = textColor;\n }\n if (backgroundColor) {\n colors.background = backgroundColor;\n }\n if (hasBorder) {\n if (borderColor) {\n colors.border = borderColor;\n } else {\n colors.border = type === 'light' ? 'black' : 'white';\n }\n }\n if (arrowColor) {\n colors.arrow = arrowColor;\n }\n return colors;\n}\nvar _class, _class2;\n\n/* Polyfill */\nvar ReactTooltip = staticMethods(_class = windowListener(_class = customEvent(_class = isCapture(_class = getEffect(_class = bodyMode(_class = trackRemoval(_class = (_class2 = /*#__PURE__*/function (_React$Component) {\n _inherits(ReactTooltip, _React$Component);\n var _super = _createSuper(ReactTooltip);\n function ReactTooltip(props) {\n var _this;\n _classCallCheck(this, ReactTooltip);\n _this = _super.call(this, props);\n _this.state = {\n uuid: props.uuid || generateUUID(),\n place: props.place || 'top',\n // Direction of tooltip\n desiredPlace: props.place || 'top',\n type: props.type || 'dark',\n // Color theme of tooltip\n effect: props.effect || 'float',\n // float or fixed\n show: false,\n border: false,\n borderClass: 'border',\n customColors: {},\n customRadius: {},\n offset: {},\n padding: props.padding,\n extraClass: '',\n html: false,\n delayHide: 0,\n delayShow: 0,\n event: props.event || null,\n eventOff: props.eventOff || null,\n currentEvent: null,\n // Current mouse event\n currentTarget: null,\n // Current target of mouse event\n ariaProps: parseAria(props),\n // aria- and role attributes\n isEmptyTip: false,\n disable: false,\n possibleCustomEvents: props.possibleCustomEvents || '',\n possibleCustomEventsOff: props.possibleCustomEventsOff || '',\n originTooltip: null,\n isMultiline: false\n };\n _this.bind(['showTooltip', 'updateTooltip', 'hideTooltip', 'hideTooltipOnScroll', 'getTooltipContent', 'globalRebuild', 'globalShow', 'globalHide', 'onWindowResize', 'mouseOnToolTip']);\n _this.mount = true;\n _this.delayShowLoop = null;\n _this.delayHideLoop = null;\n _this.delayReshow = null;\n _this.intervalUpdateContent = null;\n return _this;\n }\n\n /**\n * For unify the bind and unbind listener\n */\n _createClass(ReactTooltip, [{\n key: \"bind\",\n value: function bind(methodArray) {\n var _this2 = this;\n methodArray.forEach(function (method) {\n _this2[method] = _this2[method].bind(_this2);\n });\n }\n }, {\n key: \"componentDidMount\",\n value: function componentDidMount() {\n var _this$props = this.props;\n _this$props.insecure;\n var resizeHide = _this$props.resizeHide,\n disableInternalStyle = _this$props.disableInternalStyle;\n this.mount = true;\n this.bindListener(); // Bind listener for tooltip\n this.bindWindowEvents(resizeHide); // Bind global event for static method\n\n if (!disableInternalStyle) {\n this.injectStyles(); // Inject styles for each DOM root having tooltip.\n }\n }\n }, {\n key: \"componentWillUnmount\",\n value: function componentWillUnmount() {\n this.mount = false;\n this.clearTimer();\n this.unbindListener();\n this.removeScrollListener(this.state.currentTarget);\n this.unbindWindowEvents();\n }\n\n /* Look for the closest DOM root having tooltip and inject styles. */\n }, {\n key: \"injectStyles\",\n value: function injectStyles() {\n var tooltipRef = this.tooltipRef;\n if (!tooltipRef) {\n return;\n }\n var parentNode = tooltipRef.parentNode;\n while (parentNode.parentNode) {\n parentNode = parentNode.parentNode;\n }\n var domRoot;\n switch (parentNode.constructor.name) {\n case 'Document':\n case 'HTMLDocument':\n case undefined:\n domRoot = parentNode.head;\n break;\n case 'ShadowRoot':\n default:\n domRoot = parentNode;\n break;\n }\n\n // Prevent styles duplication.\n if (!domRoot.querySelector('style[data-react-tooltip]')) {\n var style = document.createElement('style');\n style.textContent = baseCss;\n style.setAttribute('data-react-tooltip', 'true');\n domRoot.appendChild(style);\n }\n }\n\n /**\n * Return if the mouse is on the tooltip.\n * @returns {boolean} true - mouse is on the tooltip\n */\n }, {\n key: \"mouseOnToolTip\",\n value: function mouseOnToolTip() {\n var show = this.state.show;\n if (show && this.tooltipRef) {\n /* old IE or Firefox work around */\n if (!this.tooltipRef.matches) {\n /* old IE work around */\n if (this.tooltipRef.msMatchesSelector) {\n this.tooltipRef.matches = this.tooltipRef.msMatchesSelector;\n } else {\n /* old Firefox work around */\n this.tooltipRef.matches = this.tooltipRef.mozMatchesSelector;\n }\n }\n return this.tooltipRef.matches(':hover');\n }\n return false;\n }\n\n /**\n * Pick out corresponded target elements\n */\n }, {\n key: \"getTargetArray\",\n value: function getTargetArray(id) {\n var targetArray = [];\n var selector;\n if (!id) {\n selector = '[data-tip]:not([data-for])';\n } else {\n var escaped = id.replace(/\\\\/g, '\\\\\\\\').replace(/\"/g, '\\\\\"');\n selector = \"[data-tip][data-for=\\\"\".concat(escaped, \"\\\"]\");\n }\n\n // Scan document for shadow DOM elements\n nodeListToArray(document.getElementsByTagName('*')).filter(function (element) {\n return element.shadowRoot;\n }).forEach(function (element) {\n targetArray = targetArray.concat(nodeListToArray(element.shadowRoot.querySelectorAll(selector)));\n });\n return targetArray.concat(nodeListToArray(document.querySelectorAll(selector)));\n }\n\n /**\n * Bind listener to the target elements\n * These listeners used to trigger showing or hiding the tooltip\n */\n }, {\n key: \"bindListener\",\n value: function bindListener() {\n var _this3 = this;\n var _this$props2 = this.props,\n id = _this$props2.id,\n globalEventOff = _this$props2.globalEventOff,\n isCapture = _this$props2.isCapture;\n var targetArray = this.getTargetArray(id);\n targetArray.forEach(function (target) {\n if (target.getAttribute('currentItem') === null) {\n target.setAttribute('currentItem', 'false');\n }\n _this3.unbindBasicListener(target);\n if (_this3.isCustomEvent(target)) {\n _this3.customUnbindListener(target);\n }\n });\n if (this.isBodyMode()) {\n this.bindBodyListener(targetArray);\n } else {\n targetArray.forEach(function (target) {\n var isCaptureMode = _this3.isCapture(target);\n var effect = _this3.getEffect(target);\n if (_this3.isCustomEvent(target)) {\n _this3.customBindListener(target);\n return;\n }\n target.addEventListener('mouseenter', _this3.showTooltip, isCaptureMode);\n target.addEventListener('focus', _this3.showTooltip, isCaptureMode);\n if (effect === 'float') {\n target.addEventListener('mousemove', _this3.updateTooltip, isCaptureMode);\n }\n target.addEventListener('mouseleave', _this3.hideTooltip, isCaptureMode);\n target.addEventListener('blur', _this3.hideTooltip, isCaptureMode);\n });\n }\n\n // Global event to hide tooltip\n if (globalEventOff) {\n window.removeEventListener(globalEventOff, this.hideTooltip);\n window.addEventListener(globalEventOff, this.hideTooltip, isCapture);\n }\n\n // Track removal of targetArray elements from DOM\n this.bindRemovalTracker();\n }\n\n /**\n * Unbind listeners on target elements\n */\n }, {\n key: \"unbindListener\",\n value: function unbindListener() {\n var _this4 = this;\n var _this$props3 = this.props,\n id = _this$props3.id,\n globalEventOff = _this$props3.globalEventOff;\n if (this.isBodyMode()) {\n this.unbindBodyListener();\n } else {\n var targetArray = this.getTargetArray(id);\n targetArray.forEach(function (target) {\n _this4.unbindBasicListener(target);\n if (_this4.isCustomEvent(target)) _this4.customUnbindListener(target);\n });\n }\n if (globalEventOff) window.removeEventListener(globalEventOff, this.hideTooltip);\n this.unbindRemovalTracker();\n }\n\n /**\n * Invoke this before bind listener and unmount the component\n * it is necessary to invoke this even when binding custom event\n * so that the tooltip can switch between custom and default listener\n */\n }, {\n key: \"unbindBasicListener\",\n value: function unbindBasicListener(target) {\n var isCaptureMode = this.isCapture(target);\n target.removeEventListener('mouseenter', this.showTooltip, isCaptureMode);\n target.removeEventListener('mousemove', this.updateTooltip, isCaptureMode);\n target.removeEventListener('mouseleave', this.hideTooltip, isCaptureMode);\n }\n }, {\n key: \"getTooltipContent\",\n value: function getTooltipContent() {\n var _this$props4 = this.props,\n getContent = _this$props4.getContent,\n children = _this$props4.children;\n\n // Generate tooltip content\n var content;\n if (getContent) {\n if (Array.isArray(getContent)) {\n content = getContent[0] && getContent[0](this.state.originTooltip);\n } else {\n content = getContent(this.state.originTooltip);\n }\n }\n return TipContent(this.state.originTooltip, children, content, this.state.isMultiline);\n }\n }, {\n key: \"isEmptyTip\",\n value: function isEmptyTip(placeholder) {\n return typeof placeholder === 'string' && placeholder === '' || placeholder === null;\n }\n\n /**\n * When mouse enter, show the tooltip\n */\n }, {\n key: \"showTooltip\",\n value: function showTooltip(e, isGlobalCall) {\n if (!this.tooltipRef) {\n return;\n }\n if (isGlobalCall) {\n // Don't trigger other elements belongs to other ReactTooltip\n var targetArray = this.getTargetArray(this.props.id);\n var isMyElement = targetArray.some(function (ele) {\n return ele === e.currentTarget;\n });\n if (!isMyElement) return;\n }\n // Get the tooltip content\n // calculate in this phrase so that tip width height can be detected\n var _this$props5 = this.props,\n multiline = _this$props5.multiline,\n getContent = _this$props5.getContent;\n var originTooltip = e.currentTarget.getAttribute('data-tip');\n var isMultiline = e.currentTarget.getAttribute('data-multiline') || multiline || false;\n\n // If it is focus event or called by ReactTooltip.show, switch to `solid` effect\n var switchToSolid = e instanceof window.FocusEvent || isGlobalCall;\n\n // if it needs to skip adding hide listener to scroll\n var scrollHide = true;\n if (e.currentTarget.getAttribute('data-scroll-hide')) {\n scrollHide = e.currentTarget.getAttribute('data-scroll-hide') === 'true';\n } else if (this.props.scrollHide != null) {\n scrollHide = this.props.scrollHide;\n }\n\n // adding aria-describedby to target to make tooltips read by screen readers\n if (e && e.currentTarget && e.currentTarget.setAttribute) {\n e.currentTarget.setAttribute('aria-describedby', this.props.id || this.state.uuid);\n }\n\n // Make sure the correct place is set\n var desiredPlace = e.currentTarget.getAttribute('data-place') || this.props.place || 'top';\n var effect = switchToSolid && 'solid' || this.getEffect(e.currentTarget);\n var offset = e.currentTarget.getAttribute('data-offset') || this.props.offset || {};\n var result = getPosition(e, e.currentTarget, this.tooltipRef, desiredPlace.split(',')[0], desiredPlace, effect, offset);\n if (result.position && this.props.overridePosition) {\n result.position = this.props.overridePosition(result.position, e, e.currentTarget, this.tooltipRef, desiredPlace, desiredPlace, effect, offset);\n }\n var place = result.isNewState ? result.newState.place : desiredPlace.split(',')[0];\n\n // To prevent previously created timers from triggering\n this.clearTimer();\n var target = e.currentTarget;\n var reshowDelay = this.state.show ? target.getAttribute('data-delay-update') || this.props.delayUpdate : 0;\n var self = this;\n var updateState = function updateState() {\n self.setState({\n originTooltip: originTooltip,\n isMultiline: isMultiline,\n desiredPlace: desiredPlace,\n place: place,\n type: target.getAttribute('data-type') || self.props.type || 'dark',\n customColors: {\n text: target.getAttribute('data-text-color') || self.props.textColor || null,\n background: target.getAttribute('data-background-color') || self.props.backgroundColor || null,\n border: target.getAttribute('data-border-color') || self.props.borderColor || null,\n arrow: target.getAttribute('data-arrow-color') || self.props.arrowColor || null\n },\n customRadius: {\n tooltip: target.getAttribute('data-tooltip-radius') || self.props.tooltipRadius || '3',\n arrow: target.getAttribute('data-arrow-radius') || self.props.arrowRadius || '0'\n },\n effect: effect,\n offset: offset,\n padding: target.getAttribute('data-padding') || self.props.padding,\n html: (target.getAttribute('data-html') ? target.getAttribute('data-html') === 'true' : self.props.html) || false,\n delayShow: target.getAttribute('data-delay-show') || self.props.delayShow || 0,\n delayHide: target.getAttribute('data-delay-hide') || self.props.delayHide || 0,\n delayUpdate: target.getAttribute('data-delay-update') || self.props.delayUpdate || 0,\n border: (target.getAttribute('data-border') ? target.getAttribute('data-border') === 'true' : self.props.border) || false,\n borderClass: target.getAttribute('data-border-class') || self.props.borderClass || 'border',\n extraClass: target.getAttribute('data-class') || self.props[\"class\"] || self.props.className || '',\n disable: (target.getAttribute('data-tip-disable') ? target.getAttribute('data-tip-disable') === 'true' : self.props.disable) || false,\n currentTarget: target\n }, function () {\n if (scrollHide) {\n self.addScrollListener(self.state.currentTarget);\n }\n self.updateTooltip(e);\n if (getContent && Array.isArray(getContent)) {\n self.intervalUpdateContent = setInterval(function () {\n if (self.mount) {\n var _getContent = self.props.getContent;\n var placeholder = TipContent(originTooltip, '', _getContent[0](), isMultiline);\n var isEmptyTip = self.isEmptyTip(placeholder);\n self.setState({\n isEmptyTip: isEmptyTip\n });\n self.updatePosition();\n }\n }, getContent[1]);\n }\n });\n };\n\n // If there is no delay call immediately, don't allow events to get in first.\n if (reshowDelay) {\n this.delayReshow = setTimeout(updateState, reshowDelay);\n } else {\n updateState();\n }\n }\n\n /**\n * When mouse hover, update tool tip\n */\n }, {\n key: \"updateTooltip\",\n value: function updateTooltip(e) {\n var _this5 = this;\n var _this$state = this.state,\n delayShow = _this$state.delayShow,\n disable = _this$state.disable;\n var _this$props6 = this.props,\n afterShow = _this$props6.afterShow,\n disableProp = _this$props6.disable;\n var placeholder = this.getTooltipContent();\n var eventTarget = e.currentTarget || e.target;\n\n // Check if the mouse is actually over the tooltip, if so don't hide the tooltip\n if (this.mouseOnToolTip()) {\n return;\n }\n\n // if the tooltip is empty, disable the tooltip\n if (this.isEmptyTip(placeholder) || disable || disableProp) {\n return;\n }\n var delayTime = !this.state.show ? parseInt(delayShow, 10) : 0;\n var updateState = function updateState() {\n if (Array.isArray(placeholder) && placeholder.length > 0 || placeholder) {\n var isInvisible = !_this5.state.show;\n _this5.setState({\n currentEvent: e,\n currentTarget: eventTarget,\n show: true\n }, function () {\n _this5.updatePosition(function () {\n if (isInvisible && afterShow) {\n afterShow(e);\n }\n });\n });\n }\n };\n if (this.delayShowLoop) {\n clearTimeout(this.delayShowLoop);\n }\n if (delayTime) {\n this.delayShowLoop = setTimeout(updateState, delayTime);\n } else {\n this.delayShowLoop = null;\n updateState();\n }\n }\n\n /*\n * If we're mousing over the tooltip remove it when we leave.\n */\n }, {\n key: \"listenForTooltipExit\",\n value: function listenForTooltipExit() {\n var show = this.state.show;\n if (show && this.tooltipRef) {\n this.tooltipRef.addEventListener('mouseleave', this.hideTooltip);\n }\n }\n }, {\n key: \"removeListenerForTooltipExit\",\n value: function removeListenerForTooltipExit() {\n var show = this.state.show;\n if (show && this.tooltipRef) {\n this.tooltipRef.removeEventListener('mouseleave', this.hideTooltip);\n }\n }\n\n /**\n * When mouse leave, hide tooltip\n */\n }, {\n key: \"hideTooltip\",\n value: function hideTooltip(e, hasTarget) {\n var _this6 = this;\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {\n isScroll: false\n };\n var disable = this.state.disable;\n var isScroll = options.isScroll;\n var delayHide = isScroll ? 0 : this.state.delayHide;\n var _this$props7 = this.props,\n afterHide = _this$props7.afterHide,\n disableProp = _this$props7.disable;\n var placeholder = this.getTooltipContent();\n if (!this.mount) return;\n if (this.isEmptyTip(placeholder) || disable || disableProp) return; // if the tooltip is empty, disable the tooltip\n if (hasTarget) {\n // Don't trigger other elements belongs to other ReactTooltip\n var targetArray = this.getTargetArray(this.props.id);\n var isMyElement = targetArray.some(function (ele) {\n return ele === e.currentTarget;\n });\n if (!isMyElement || !this.state.show) return;\n }\n\n // clean up aria-describedby when hiding tooltip\n if (e && e.currentTarget && e.currentTarget.removeAttribute) {\n e.currentTarget.removeAttribute('aria-describedby');\n }\n var resetState = function resetState() {\n var isVisible = _this6.state.show;\n // Check if the mouse is actually over the tooltip, if so don't hide the tooltip\n if (_this6.mouseOnToolTip()) {\n _this6.listenForTooltipExit();\n return;\n }\n _this6.removeListenerForTooltipExit();\n _this6.setState({\n show: false\n }, function () {\n _this6.removeScrollListener(_this6.state.currentTarget);\n if (isVisible && afterHide) {\n afterHide(e);\n }\n });\n };\n this.clearTimer();\n if (delayHide) {\n this.delayHideLoop = setTimeout(resetState, parseInt(delayHide, 10));\n } else {\n resetState();\n }\n }\n\n /**\n * When scroll, hide tooltip\n */\n }, {\n key: \"hideTooltipOnScroll\",\n value: function hideTooltipOnScroll(event, hasTarget) {\n this.hideTooltip(event, hasTarget, {\n isScroll: true\n });\n }\n\n /**\n * Add scroll event listener when tooltip show\n * automatically hide the tooltip when scrolling\n */\n }, {\n key: \"addScrollListener\",\n value: function addScrollListener(currentTarget) {\n var isCaptureMode = this.isCapture(currentTarget);\n window.addEventListener('scroll', this.hideTooltipOnScroll, isCaptureMode);\n }\n }, {\n key: \"removeScrollListener\",\n value: function removeScrollListener(currentTarget) {\n var isCaptureMode = this.isCapture(currentTarget);\n window.removeEventListener('scroll', this.hideTooltipOnScroll, isCaptureMode);\n }\n\n // Calculation the position\n }, {\n key: \"updatePosition\",\n value: function updatePosition(callbackAfter) {\n var _this7 = this;\n var _this$state2 = this.state,\n currentEvent = _this$state2.currentEvent,\n currentTarget = _this$state2.currentTarget,\n place = _this$state2.place,\n desiredPlace = _this$state2.desiredPlace,\n effect = _this$state2.effect,\n offset = _this$state2.offset;\n var node = this.tooltipRef;\n var result = getPosition(currentEvent, currentTarget, node, place, desiredPlace, effect, offset);\n if (result.position && this.props.overridePosition) {\n result.position = this.props.overridePosition(result.position, currentEvent, currentTarget, node, place, desiredPlace, effect, offset);\n }\n if (result.isNewState) {\n // Switch to reverse placement\n return this.setState(result.newState, function () {\n _this7.updatePosition(callbackAfter);\n });\n }\n if (callbackAfter && typeof callbackAfter === 'function') {\n callbackAfter();\n }\n\n // Set tooltip position\n node.style.left = result.position.left + 'px';\n node.style.top = result.position.top + 'px';\n }\n\n /**\n * CLear all kinds of timeout of interval\n */\n }, {\n key: \"clearTimer\",\n value: function clearTimer() {\n if (this.delayShowLoop) {\n clearTimeout(this.delayShowLoop);\n this.delayShowLoop = null;\n }\n if (this.delayHideLoop) {\n clearTimeout(this.delayHideLoop);\n this.delayHideLoop = null;\n }\n if (this.delayReshow) {\n clearTimeout(this.delayReshow);\n this.delayReshow = null;\n }\n if (this.intervalUpdateContent) {\n clearInterval(this.intervalUpdateContent);\n this.intervalUpdateContent = null;\n }\n }\n }, {\n key: \"hasCustomColors\",\n value: function hasCustomColors() {\n var _this8 = this;\n return Boolean(Object.keys(this.state.customColors).find(function (color) {\n return color !== 'border' && _this8.state.customColors[color];\n }) || this.state.border && this.state.customColors['border']);\n }\n }, {\n key: \"render\",\n value: function render() {\n var _this9 = this;\n var _this$state3 = this.state,\n extraClass = _this$state3.extraClass,\n html = _this$state3.html,\n ariaProps = _this$state3.ariaProps,\n disable = _this$state3.disable,\n uuid = _this$state3.uuid;\n var content = this.getTooltipContent();\n var isEmptyTip = this.isEmptyTip(content);\n var style = this.props.disableInternalStyle ? '' : generateTooltipStyle(this.state.uuid, this.state.customColors, this.state.type, this.state.border, this.state.padding, this.state.customRadius);\n var tooltipClass = '__react_component_tooltip' + \" \".concat(this.state.uuid) + (this.state.show && !disable && !isEmptyTip ? ' show' : '') + (this.state.border ? ' ' + this.state.borderClass : '') + \" place-\".concat(this.state.place) +\n // top, bottom, left, right\n \" type-\".concat(this.hasCustomColors() ? 'custom' : this.state.type) + (\n // dark, success, warning, error, info, light, custom\n this.props.delayUpdate ? ' allow_hover' : '') + (this.props.clickable ? ' allow_click' : '');\n var Wrapper = this.props.wrapper;\n if (ReactTooltip.supportedWrappers.indexOf(Wrapper) < 0) {\n Wrapper = ReactTooltip.defaultProps.wrapper;\n }\n var wrapperClassName = [tooltipClass, extraClass].filter(Boolean).join(' ');\n if (html) {\n var htmlContent = \"\".concat(content).concat(style ? \"\\n\") : '');\n return /*#__PURE__*/React.createElement(Wrapper, _extends({\n className: \"\".concat(wrapperClassName),\n id: this.props.id || uuid,\n ref: function ref(_ref) {\n return _this9.tooltipRef = _ref;\n }\n }, ariaProps, {\n \"data-id\": \"tooltip\",\n dangerouslySetInnerHTML: {\n __html: htmlContent\n }\n }));\n } else {\n return /*#__PURE__*/React.createElement(Wrapper, _extends({\n className: \"\".concat(wrapperClassName),\n id: this.props.id || uuid\n }, ariaProps, {\n ref: function ref(_ref2) {\n return _this9.tooltipRef = _ref2;\n },\n \"data-id\": \"tooltip\"\n }), style && /*#__PURE__*/React.createElement(\"style\", {\n dangerouslySetInnerHTML: {\n __html: style\n },\n \"aria-hidden\": \"true\"\n }), content);\n }\n }\n }], [{\n key: \"propTypes\",\n get: function get() {\n return {\n uuid: PropTypes.string,\n children: PropTypes.any,\n place: PropTypes.string,\n type: PropTypes.string,\n effect: PropTypes.string,\n offset: PropTypes.object,\n padding: PropTypes.string,\n multiline: PropTypes.bool,\n border: PropTypes.bool,\n borderClass: PropTypes.string,\n textColor: PropTypes.string,\n backgroundColor: PropTypes.string,\n borderColor: PropTypes.string,\n arrowColor: PropTypes.string,\n arrowRadius: PropTypes.string,\n tooltipRadius: PropTypes.string,\n insecure: PropTypes.bool,\n \"class\": PropTypes.string,\n className: PropTypes.string,\n id: PropTypes.string,\n html: PropTypes.bool,\n delayHide: PropTypes.number,\n delayUpdate: PropTypes.number,\n delayShow: PropTypes.number,\n event: PropTypes.string,\n eventOff: PropTypes.string,\n isCapture: PropTypes.bool,\n globalEventOff: PropTypes.string,\n getContent: PropTypes.any,\n afterShow: PropTypes.func,\n afterHide: PropTypes.func,\n overridePosition: PropTypes.func,\n disable: PropTypes.bool,\n scrollHide: PropTypes.bool,\n resizeHide: PropTypes.bool,\n wrapper: PropTypes.string,\n bodyMode: PropTypes.bool,\n possibleCustomEvents: PropTypes.string,\n possibleCustomEventsOff: PropTypes.string,\n clickable: PropTypes.bool,\n disableInternalStyle: PropTypes.bool\n };\n }\n }, {\n key: \"getDerivedStateFromProps\",\n value: function getDerivedStateFromProps(nextProps, prevState) {\n var ariaProps = prevState.ariaProps;\n var newAriaProps = parseAria(nextProps);\n var isChanged = Object.keys(newAriaProps).some(function (props) {\n return newAriaProps[props] !== ariaProps[props];\n });\n if (!isChanged) {\n return null;\n }\n return _objectSpread2(_objectSpread2({}, prevState), {}, {\n ariaProps: newAriaProps\n });\n }\n }]);\n return ReactTooltip;\n}(React.Component), _defineProperty(_class2, \"defaultProps\", {\n insecure: true,\n resizeHide: true,\n wrapper: 'div',\n clickable: false\n}), _defineProperty(_class2, \"supportedWrappers\", ['div', 'span']), _defineProperty(_class2, \"displayName\", 'ReactTooltip'), _class2)) || _class) || _class) || _class) || _class) || _class) || _class) || _class;\nexport { ReactTooltip as default };","import React, { useContext, createContext, useReducer } from 'react';\n\nconst initialState = {\n formSetting: {\n include_address_fields: false,\n require_address_fields: false,\n include_membership_id_field: false,\n require_membership_id_field: false,\n },\n};\n\nconst formSettingsReducer = (state, action) => {\n switch (action.type) {\n case 'TOGGLE_FIELDS':\n return {\n ...state,\n formSetting: { ...state.formSetting, ...action.formSetting },\n };\n default:\n return state;\n }\n};\n\nconst FormSettingsContaxt = createContext(null);\n\nexport const useFields = () => {\n const [state, dispatch] = useContext(FormSettingsContaxt);\n\n const toggleAddressFields = (shouldInclude) => {\n if (shouldInclude) {\n dispatch({\n type: 'TOGGLE_FIELDS',\n formSetting: { include_address_fields: shouldInclude },\n });\n } else {\n dispatch({\n type: 'TOGGLE_FIELDS',\n formSetting: {\n include_address_fields: shouldInclude,\n require_address_fields: shouldInclude,\n },\n });\n }\n };\n\n const toggleMembershipIdField = (shouldInclude) => {\n if (shouldInclude) {\n dispatch({\n type: 'TOGGLE_FIELDS',\n formSetting: { include_membership_id_field: shouldInclude },\n });\n } else {\n dispatch({\n type: 'TOGGLE_FIELDS',\n formSetting: {\n include_membership_id_field: shouldInclude,\n require_membership_id_field: shouldInclude,\n },\n });\n }\n };\n\n const toggleRequireAddressFields = (shouldRequire) => {\n dispatch({\n type: 'TOGGLE_FIELDS',\n formSetting: { require_address_fields: shouldRequire },\n });\n };\n\n const toggleRequireMembershipIdField = (shouldRequire) => {\n dispatch({\n type: 'TOGGLE_FIELDS',\n formSetting: { require_membership_id_field: shouldRequire },\n });\n };\n\n return {\n state,\n dispatch,\n toggleAddressFields,\n toggleRequireAddressFields,\n toggleMembershipIdField,\n toggleRequireMembershipIdField,\n };\n};\n\nexport const FormSettingsProvider = (props) => {\n const [state, dispatch] = useReducer(formSettingsReducer, {\n ...initialState,\n formSetting: props.formSetting,\n fund: props.fund,\n });\n\n const value = React.useMemo(() => [state, dispatch], [state]);\n\n return ;\n};\n","import React from 'react';\n\nexport const FundHeading = ({ imageUrl, name, fundType }) => {\n return (\n \n
\n {!!imageUrl ? (\n

\n ) : (\n
\n {name[0]}\n \n )}\n
\n\n
\n
\n {name}\n
\n {fundType}\n \n
\n );\n};\n\nexport const FundStats = ({\n transactionTotalDollarsHuman,\n transactionsCount,\n}) => {\n return (\n \n
\n
\n
\n \n {transactionTotalDollarsHuman} \n {' '}\n
\n raised\n
\n
\n
\n
\n
\n {transactionsCount}\n
\n \n {transactionsCount == 1 ? 'donation' : 'donations'}\n \n
\n
\n
\n );\n};\n\nexport const FundFooter = ({ status, path }) => {\n const classNames = (status) => {\n switch (status) {\n case 'active':\n return ' bg-green-100 text-green-800';\n case 'inactive':\n return 'bg-yellow-50 text-yellow-text';\n case 'archived':\n return 'bg-red-100 text-red-800';\n default:\n return ' bg-green-100 text-green-800';\n }\n };\n\n return (\n \n );\n};\n","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport r, { useState as u } from \"react\";\nfunction f(_ref) {\n var o = _ref.children,\n e = _ref.freeze;\n var n = l(e, o);\n return /*#__PURE__*/r.createElement(r.Fragment, null, n);\n}\nfunction l(o, e) {\n var _u = u(e),\n _u2 = _slicedToArray(_u, 2),\n n = _u2[0],\n t = _u2[1];\n return !o && n !== e && t(e), o ? n : e;\n}\nexport { f as Frozen, l as useFrozenData };","export function currencyFormat(num) {\n // if the number start with a negative sign, mark it remove it and add it before the dollar sign\n if (num.toString().startsWith('-')) {\n return '-$' + num.toString().replace(/^-/, '').replace(/(\\d)(?=(\\d{3})+(?!\\d))/g, '$1,')\n }\n return '$' + num.toFixed(2).replace(/(\\d)(?=(\\d{3})+(?!\\d))/g, '$1,')\n}\n\nexport function prettyDate(date) {\n return new Date(date).toLocaleDateString('en-US', {\n year: 'numeric',\n month: 'long',\n day: 'numeric',\n })\n}","\"use client\";\n\nvar _excluded = [\"transition\", \"beforeEnter\", \"afterEnter\", \"beforeLeave\", \"afterLeave\", \"enter\", \"enterFrom\", \"enterTo\", \"entered\", \"leave\", \"leaveFrom\", \"leaveTo\"],\n _excluded2 = [\"show\", \"appear\", \"unmount\"];\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport f, { Fragment as O, createContext as ne, useContext as q, useEffect as he, useMemo as ie, useRef as E, useState as V } from \"react\";\nimport { useDisposables as ge } from '../../hooks/use-disposables.js';\nimport { useEvent as S } from '../../hooks/use-event.js';\nimport { useIsMounted as ve } from '../../hooks/use-is-mounted.js';\nimport { useIsoMorphicEffect as H } from '../../hooks/use-iso-morphic-effect.js';\nimport { useLatestValue as be } from '../../hooks/use-latest-value.js';\nimport { useServerHandoffComplete as re } from '../../hooks/use-server-handoff-complete.js';\nimport { useSyncRefs as oe } from '../../hooks/use-sync-refs.js';\nimport { transitionDataAttributes as Ee, useTransition as Se } from '../../hooks/use-transition.js';\nimport { OpenClosedProvider as ye, State as N, useOpenClosed as se } from '../../internal/open-closed.js';\nimport { classNames as Re } from '../../utils/class-names.js';\nimport { match as le } from '../../utils/match.js';\nimport { RenderFeatures as Pe, RenderStrategy as x, compact as xe, forwardRefWithAs as J, render as ae } from '../../utils/render.js';\nfunction ue(e) {\n var t;\n return !!(e.enter || e.enterFrom || e.enterTo || e.leave || e.leaveFrom || e.leaveTo) || ((t = e.as) != null ? t : de) !== O || f.Children.count(e.children) === 1;\n}\nvar w = /*#__PURE__*/ne(null);\nw.displayName = \"TransitionContext\";\nvar Ne = function (n) {\n return n.Visible = \"visible\", n.Hidden = \"hidden\", n;\n}(Ne || {});\nfunction _e() {\n var e = q(w);\n if (e === null) throw new Error(\"A is used but it is missing a parent or .\");\n return e;\n}\nfunction De() {\n var e = q(M);\n if (e === null) throw new Error(\"A is used but it is missing a parent or .\");\n return e;\n}\nvar M = /*#__PURE__*/ne(null);\nM.displayName = \"NestingContext\";\nfunction U(e) {\n return \"children\" in e ? U(e.children) : e.current.filter(function (_ref) {\n var t = _ref.el;\n return t.current !== null;\n }).filter(function (_ref2) {\n var t = _ref2.state;\n return t === \"visible\";\n }).length > 0;\n}\nfunction Te(e, t) {\n var n = be(e),\n l = E([]),\n y = ve(),\n R = ge(),\n T = S(function (o) {\n var _le;\n var i = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : x.Hidden;\n var a = l.current.findIndex(function (_ref3) {\n var s = _ref3.el;\n return s === o;\n });\n a !== -1 && (le(i, (_le = {}, _defineProperty(_le, x.Unmount, function () {\n l.current.splice(a, 1);\n }), _defineProperty(_le, x.Hidden, function () {\n l.current[a].state = \"hidden\";\n }), _le)), R.microTask(function () {\n var s;\n !U(l) && y.current && ((s = n.current) == null || s.call(n));\n }));\n }),\n P = S(function (o) {\n var i = l.current.find(function (_ref4) {\n var a = _ref4.el;\n return a === o;\n });\n return i ? i.state !== \"visible\" && (i.state = \"visible\") : l.current.push({\n el: o,\n state: \"visible\"\n }), function () {\n return T(o, x.Unmount);\n };\n }),\n p = E([]),\n m = E(Promise.resolve()),\n C = E({\n enter: [],\n leave: []\n }),\n h = S(function (o, i, a) {\n p.current.splice(0), t && (t.chains.current[i] = t.chains.current[i].filter(function (_ref5) {\n var _ref6 = _slicedToArray(_ref5, 1),\n s = _ref6[0];\n return s !== o;\n })), t == null || t.chains.current[i].push([o, new Promise(function (s) {\n p.current.push(s);\n })]), t == null || t.chains.current[i].push([o, new Promise(function (s) {\n Promise.all(C.current[i].map(function (_ref7) {\n var _ref8 = _slicedToArray(_ref7, 2),\n r = _ref8[0],\n d = _ref8[1];\n return d;\n })).then(function () {\n return s();\n });\n })]), i === \"enter\" ? m.current = m.current.then(function () {\n return t == null ? void 0 : t.wait.current;\n }).then(function () {\n return a(i);\n }) : a(i);\n }),\n g = S(function (o, i, a) {\n Promise.all(C.current[i].splice(0).map(function (_ref9) {\n var _ref10 = _slicedToArray(_ref9, 2),\n s = _ref10[0],\n r = _ref10[1];\n return r;\n })).then(function () {\n var s;\n (s = p.current.shift()) == null || s();\n }).then(function () {\n return a(i);\n });\n });\n return ie(function () {\n return {\n children: l,\n register: P,\n unregister: T,\n onStart: h,\n onStop: g,\n wait: m,\n chains: C\n };\n }, [P, T, l, h, g, C, m]);\n}\nvar de = O,\n fe = Pe.RenderStrategy;\nfunction He(e, t) {\n var ee, te;\n var _e$transition = e.transition,\n n = _e$transition === void 0 ? !0 : _e$transition,\n l = e.beforeEnter,\n y = e.afterEnter,\n R = e.beforeLeave,\n T = e.afterLeave,\n P = e.enter,\n p = e.enterFrom,\n m = e.enterTo,\n C = e.entered,\n h = e.leave,\n g = e.leaveFrom,\n o = e.leaveTo,\n i = _objectWithoutProperties(e, _excluded),\n _V = V(null),\n _V2 = _slicedToArray(_V, 2),\n a = _V2[0],\n s = _V2[1],\n r = E(null),\n d = ue(e),\n j = oe.apply(void 0, _toConsumableArray(d ? [r, t, s] : t === null ? [] : [t])),\n v = (ee = i.unmount) == null || ee ? x.Unmount : x.Hidden,\n _e2 = _e(),\n c = _e2.show,\n z = _e2.appear,\n K = _e2.initial,\n _V3 = V(c ? \"visible\" : \"hidden\"),\n _V4 = _slicedToArray(_V3, 2),\n b = _V4[0],\n G = _V4[1],\n Q = De(),\n A = Q.register,\n I = Q.unregister;\n H(function () {\n return A(r);\n }, [A, r]), H(function () {\n if (v === x.Hidden && r.current) {\n var _le2;\n if (c && b !== \"visible\") {\n G(\"visible\");\n return;\n }\n return le(b, (_le2 = {}, _defineProperty(_le2, \"hidden\", function hidden() {\n return I(r);\n }), _defineProperty(_le2, \"visible\", function visible() {\n return A(r);\n }), _le2));\n }\n }, [b, r, A, I, c, v]);\n var B = re();\n H(function () {\n if (d && B && b === \"visible\" && r.current === null) throw new Error(\"Did you forget to passthrough the `ref` to the actual DOM node?\");\n }, [r, b, B, d]);\n var ce = K && !z,\n Y = z && c && K,\n W = E(!1),\n F = Te(function () {\n W.current || (G(\"hidden\"), I(r));\n }, Q),\n Z = S(function (k) {\n W.current = !0;\n var L = k ? \"enter\" : \"leave\";\n F.onStart(r, L, function (D) {\n D === \"enter\" ? l == null || l() : D === \"leave\" && (R == null || R());\n });\n }),\n $ = S(function (k) {\n var L = k ? \"enter\" : \"leave\";\n W.current = !1, F.onStop(r, L, function (D) {\n D === \"enter\" ? y == null || y() : D === \"leave\" && (T == null || T());\n }), L === \"leave\" && !U(F) && (G(\"hidden\"), I(r));\n });\n he(function () {\n d && n || (Z(c), $(c));\n }, [c, d, n]);\n var pe = function () {\n return !(!n || !d || !B || ce);\n }(),\n _Se = Se(pe, a, c, {\n start: Z,\n end: $\n }),\n _Se2 = _slicedToArray(_Se, 2),\n u = _Se2[1],\n Ce = xe(_objectSpread({\n ref: j,\n className: ((te = Re(i.className, Y && P, Y && p, u.enter && P, u.enter && u.closed && p, u.enter && !u.closed && m, u.leave && h, u.leave && !u.closed && g, u.leave && u.closed && o, !u.transition && c && C)) == null ? void 0 : te.trim()) || void 0\n }, Ee(u))),\n _ = 0;\n return b === \"visible\" && (_ |= N.Open), b === \"hidden\" && (_ |= N.Closed), u.enter && (_ |= N.Opening), u.leave && (_ |= N.Closing), /*#__PURE__*/f.createElement(M.Provider, {\n value: F\n }, /*#__PURE__*/f.createElement(ye, {\n value: _\n }, ae({\n ourProps: Ce,\n theirProps: i,\n defaultTag: de,\n features: fe,\n visible: b === \"visible\",\n name: \"Transition.Child\"\n })));\n}\nfunction Ae(e, t) {\n var n = e.show,\n _e$appear = e.appear,\n l = _e$appear === void 0 ? !1 : _e$appear,\n _e$unmount = e.unmount,\n y = _e$unmount === void 0 ? !0 : _e$unmount,\n R = _objectWithoutProperties(e, _excluded2),\n T = E(null),\n P = ue(e),\n p = oe.apply(void 0, _toConsumableArray(P ? [T, t] : t === null ? [] : [t]));\n re();\n var m = se();\n if (n === void 0 && m !== null && (n = (m & N.Open) === N.Open), n === void 0) throw new Error(\"A is used but it is missing a `show={true | false}` prop.\");\n var _V5 = V(n ? \"visible\" : \"hidden\"),\n _V6 = _slicedToArray(_V5, 2),\n C = _V6[0],\n h = _V6[1],\n g = Te(function () {\n n || h(\"hidden\");\n }),\n _V7 = V(!0),\n _V8 = _slicedToArray(_V7, 2),\n o = _V8[0],\n i = _V8[1],\n a = E([n]);\n H(function () {\n o !== !1 && a.current[a.current.length - 1] !== n && (a.current.push(n), i(!1));\n }, [a, n]);\n var s = ie(function () {\n return {\n show: n,\n appear: l,\n initial: o\n };\n }, [n, l, o]);\n H(function () {\n n ? h(\"visible\") : !U(g) && T.current !== null && h(\"hidden\");\n }, [n, g]);\n var r = {\n unmount: y\n },\n d = S(function () {\n var v;\n o && i(!1), (v = e.beforeEnter) == null || v.call(e);\n }),\n j = S(function () {\n var v;\n o && i(!1), (v = e.beforeLeave) == null || v.call(e);\n });\n return /*#__PURE__*/f.createElement(M.Provider, {\n value: g\n }, /*#__PURE__*/f.createElement(w.Provider, {\n value: s\n }, ae({\n ourProps: _objectSpread(_objectSpread({}, r), {}, {\n as: O,\n children: /*#__PURE__*/f.createElement(me, _objectSpread(_objectSpread(_objectSpread({\n ref: p\n }, r), R), {}, {\n beforeEnter: d,\n beforeLeave: j\n }))\n }),\n theirProps: {},\n defaultTag: O,\n features: fe,\n visible: C === \"visible\",\n name: \"Transition\"\n })));\n}\nfunction Ie(e, t) {\n var n = q(w) !== null,\n l = se() !== null;\n return /*#__PURE__*/f.createElement(f.Fragment, null, !n && l ? /*#__PURE__*/f.createElement(X, _objectSpread({\n ref: t\n }, e)) : /*#__PURE__*/f.createElement(me, _objectSpread({\n ref: t\n }, e)));\n}\nvar X = J(Ae),\n me = J(He),\n Fe = J(Ie),\n Xe = Object.assign(X, {\n Child: Fe,\n Root: X\n });\nexport { Xe as Transition, Fe as TransitionChild };","\"use client\";\n\nvar _excluded = [\"value\", \"defaultValue\", \"onChange\", \"form\", \"name\", \"by\", \"disabled\", \"onClose\", \"__demoMode\", \"multiple\", \"immediate\", \"virtual\", \"nullable\"],\n _excluded2 = [\"id\", \"onChange\", \"displayValue\", \"disabled\", \"autoFocus\", \"type\"],\n _excluded3 = [\"id\", \"disabled\", \"autoFocus\"],\n _excluded4 = [\"id\", \"hold\", \"anchor\", \"portal\", \"modal\", \"transition\"],\n _excluded5 = [\"id\", \"value\", \"disabled\", \"order\"];\nvar _It;\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport { useFocusRing as Ee } from \"@react-aria/focus\";\nimport { useHover as Se } from \"@react-aria/interactions\";\nimport { useVirtualizer as Ne } from \"@tanstack/react-virtual\";\nimport F, { Fragment as Ie, createContext as me, createRef as ke, useCallback as ce, useContext as fe, useMemo as W, useReducer as Ue, useRef as Z, useState as He } from \"react\";\nimport { flushSync as ee } from \"react-dom\";\nimport { useActivePress as Ge } from '../../hooks/use-active-press.js';\nimport { useByComparator as ze } from '../../hooks/use-by-comparator.js';\nimport { useControllable as Ke } from '../../hooks/use-controllable.js';\nimport { useDefaultValue as We } from '../../hooks/use-default-value.js';\nimport { useDisposables as je } from '../../hooks/use-disposables.js';\nimport { useElementSize as Pe } from '../../hooks/use-element-size.js';\nimport { useEvent as c } from '../../hooks/use-event.js';\nimport { useId as se } from '../../hooks/use-id.js';\nimport { useInertOthers as $e } from '../../hooks/use-inert-others.js';\nimport { useIsoMorphicEffect as X } from '../../hooks/use-iso-morphic-effect.js';\nimport { useLatestValue as Xe } from '../../hooks/use-latest-value.js';\nimport { useOnDisappear as Je } from '../../hooks/use-on-disappear.js';\nimport { useOutsideClick as qe } from '../../hooks/use-outside-click.js';\nimport { useOwnerDocument as Ae } from '../../hooks/use-owner.js';\nimport { useRefocusableInput as Re } from '../../hooks/use-refocusable-input.js';\nimport { useResolveButtonType as Ye } from '../../hooks/use-resolve-button-type.js';\nimport { useScrollLock as Qe } from '../../hooks/use-scroll-lock.js';\nimport { useSyncRefs as de } from '../../hooks/use-sync-refs.js';\nimport { useTrackedPointer as Ze } from '../../hooks/use-tracked-pointer.js';\nimport { transitionDataAttributes as et, useTransition as tt } from '../../hooks/use-transition.js';\nimport { useTreeWalker as ot } from '../../hooks/use-tree-walker.js';\nimport { useWatch as _e } from '../../hooks/use-watch.js';\nimport { useDisabled as nt } from '../../internal/disabled.js';\nimport { FloatingProvider as it, useFloatingPanel as rt, useFloatingPanelProps as lt, useFloatingReference as at, useResolvedAnchor as ut } from '../../internal/floating.js';\nimport { FormFields as pt } from '../../internal/form-fields.js';\nimport { Frozen as st, useFrozenData as he } from '../../internal/frozen.js';\nimport { useProvidedId as dt } from '../../internal/id.js';\nimport { OpenClosedProvider as bt, State as be, useOpenClosed as mt } from '../../internal/open-closed.js';\nimport { history as Me } from '../../utils/active-element-history.js';\nimport { isDisabledReactIssue7711 as ct } from '../../utils/bugs.js';\nimport { Focus as I, calculateActiveIndex as De } from '../../utils/calculate-active-index.js';\nimport { disposables as Fe } from '../../utils/disposables.js';\nimport { sortByDomNode as ft } from '../../utils/focus-management.js';\nimport { match as te } from '../../utils/match.js';\nimport { isMobile as Tt } from '../../utils/platform.js';\nimport { RenderFeatures as Ve, forwardRefWithAs as ne, mergeProps as Te, render as ie } from '../../utils/render.js';\nimport { useDescribedBy as xt } from '../description/description.js';\nimport { Keys as B } from '../keyboard.js';\nimport { Label as gt, useLabelledBy as xe, useLabels as vt } from '../label/label.js';\nimport { MouseButton as Le } from '../mouse.js';\nimport { Portal as yt } from '../portal/portal.js';\nvar Ot = function (e) {\n return e[e.Open = 0] = \"Open\", e[e.Closed = 1] = \"Closed\", e;\n }(Ot || {}),\n Ct = function (e) {\n return e[e.Single = 0] = \"Single\", e[e.Multi = 1] = \"Multi\", e;\n }(Ct || {}),\n Et = function (o) {\n return o[o.Pointer = 0] = \"Pointer\", o[o.Focus = 1] = \"Focus\", o[o.Other = 2] = \"Other\", o;\n }(Et || {}),\n St = function (l) {\n return l[l.OpenCombobox = 0] = \"OpenCombobox\", l[l.CloseCombobox = 1] = \"CloseCombobox\", l[l.GoToOption = 2] = \"GoToOption\", l[l.SetTyping = 3] = \"SetTyping\", l[l.RegisterOption = 4] = \"RegisterOption\", l[l.UnregisterOption = 5] = \"UnregisterOption\", l[l.SetActivationTrigger = 6] = \"SetActivationTrigger\", l[l.UpdateVirtualConfiguration = 7] = \"UpdateVirtualConfiguration\", l[l.SetInputElement = 8] = \"SetInputElement\", l[l.SetButtonElement = 9] = \"SetButtonElement\", l[l.SetOptionsElement = 10] = \"SetOptionsElement\", l;\n }(St || {});\nfunction ge(t) {\n var n = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : function (e) {\n return e;\n };\n var e = t.activeOptionIndex !== null ? t.options[t.activeOptionIndex] : null,\n o = n(t.options.slice()),\n f = o.length > 0 && o[0].dataRef.current.order !== null ? o.sort(function (m, d) {\n return m.dataRef.current.order - d.dataRef.current.order;\n }) : ft(o, function (m) {\n return m.dataRef.current.domRef.current;\n }),\n b = e ? f.indexOf(e) : null;\n return b === -1 && (b = null), {\n options: f,\n activeOptionIndex: b\n };\n}\nvar It = (_It = {}, _defineProperty(_It, 1, function _(t) {\n var n;\n return (n = t.dataRef.current) != null && n.disabled || t.comboboxState === 1 ? t : _objectSpread(_objectSpread({}, t), {}, {\n activeOptionIndex: null,\n comboboxState: 1,\n isTyping: !1,\n activationTrigger: 2,\n __demoMode: !1\n });\n }), _defineProperty(_It, 0, function _(t) {\n var n, e;\n if ((n = t.dataRef.current) != null && n.disabled || t.comboboxState === 0) return t;\n if ((e = t.dataRef.current) != null && e.value) {\n var o = t.dataRef.current.calculateIndex(t.dataRef.current.value);\n if (o !== -1) return _objectSpread(_objectSpread({}, t), {}, {\n activeOptionIndex: o,\n comboboxState: 0,\n __demoMode: !1\n });\n }\n return _objectSpread(_objectSpread({}, t), {}, {\n comboboxState: 0,\n __demoMode: !1\n });\n }), _defineProperty(_It, 3, function _(t, n) {\n return t.isTyping === n.isTyping ? t : _objectSpread(_objectSpread({}, t), {}, {\n isTyping: n.isTyping\n });\n }), _defineProperty(_It, 2, function _(t, n) {\n var b, m, d, T;\n if ((b = t.dataRef.current) != null && b.disabled || t.optionsElement && !((m = t.dataRef.current) != null && m.optionsPropsRef.current.static) && t.comboboxState === 1) return t;\n if (t.virtual) {\n var _t$virtual = t.virtual,\n r = _t$virtual.options,\n i = _t$virtual.disabled,\n l = n.focus === I.Specific ? n.idx : De(n, {\n resolveItems: function resolveItems() {\n return r;\n },\n resolveActiveIndex: function resolveActiveIndex() {\n var A, s;\n return (s = (A = t.activeOptionIndex) != null ? A : r.findIndex(function (V) {\n return !i(V);\n })) != null ? s : null;\n },\n resolveDisabled: i,\n resolveId: function resolveId() {\n throw new Error(\"Function not implemented.\");\n }\n }),\n S = (d = n.trigger) != null ? d : 2;\n return t.activeOptionIndex === l && t.activationTrigger === S ? t : _objectSpread(_objectSpread({}, t), {}, {\n activeOptionIndex: l,\n activationTrigger: S,\n isTyping: !1,\n __demoMode: !1\n });\n }\n var e = ge(t);\n if (e.activeOptionIndex === null) {\n var _r = e.options.findIndex(function (i) {\n return !i.dataRef.current.disabled;\n });\n _r !== -1 && (e.activeOptionIndex = _r);\n }\n var o = n.focus === I.Specific ? n.idx : De(n, {\n resolveItems: function resolveItems() {\n return e.options;\n },\n resolveActiveIndex: function resolveActiveIndex() {\n return e.activeOptionIndex;\n },\n resolveId: function resolveId(r) {\n return r.id;\n },\n resolveDisabled: function resolveDisabled(r) {\n return r.dataRef.current.disabled;\n }\n }),\n f = (T = n.trigger) != null ? T : 2;\n return t.activeOptionIndex === o && t.activationTrigger === f ? t : _objectSpread(_objectSpread(_objectSpread({}, t), e), {}, {\n isTyping: !1,\n activeOptionIndex: o,\n activationTrigger: f,\n __demoMode: !1\n });\n }), _defineProperty(_It, 4, function _(t, n) {\n var b, m, d;\n if ((b = t.dataRef.current) != null && b.virtual) return _objectSpread(_objectSpread({}, t), {}, {\n options: [].concat(_toConsumableArray(t.options), [n.payload])\n });\n var e = n.payload,\n o = ge(t, function (T) {\n return T.push(e), T;\n });\n t.activeOptionIndex === null && (m = t.dataRef.current) != null && m.isSelected(n.payload.dataRef.current.value) && (o.activeOptionIndex = o.options.indexOf(e));\n var f = _objectSpread(_objectSpread(_objectSpread({}, t), o), {}, {\n activationTrigger: 2\n });\n return (d = t.dataRef.current) != null && d.__demoMode && t.dataRef.current.value === void 0 && (f.activeOptionIndex = 0), f;\n }), _defineProperty(_It, 5, function _(t, n) {\n var o;\n if ((o = t.dataRef.current) != null && o.virtual) return _objectSpread(_objectSpread({}, t), {}, {\n options: t.options.filter(function (f) {\n return f.id !== n.id;\n })\n });\n var e = ge(t, function (f) {\n var b = f.findIndex(function (m) {\n return m.id === n.id;\n });\n return b !== -1 && f.splice(b, 1), f;\n });\n return _objectSpread(_objectSpread(_objectSpread({}, t), e), {}, {\n activationTrigger: 2\n });\n }), _defineProperty(_It, 6, function _(t, n) {\n return t.activationTrigger === n.trigger ? t : _objectSpread(_objectSpread({}, t), {}, {\n activationTrigger: n.trigger\n });\n }), _defineProperty(_It, 7, function _(t, n) {\n var o, f;\n if (t.virtual === null) return _objectSpread(_objectSpread({}, t), {}, {\n virtual: {\n options: n.options,\n disabled: (o = n.disabled) != null ? o : function () {\n return !1;\n }\n }\n });\n if (t.virtual.options === n.options && t.virtual.disabled === n.disabled) return t;\n var e = t.activeOptionIndex;\n if (t.activeOptionIndex !== null) {\n var b = n.options.indexOf(t.virtual.options[t.activeOptionIndex]);\n b !== -1 ? e = b : e = null;\n }\n return _objectSpread(_objectSpread({}, t), {}, {\n activeOptionIndex: e,\n virtual: {\n options: n.options,\n disabled: (f = n.disabled) != null ? f : function () {\n return !1;\n }\n }\n });\n }), _defineProperty(_It, 8, function _(t, n) {\n return t.inputElement === n.element ? t : _objectSpread(_objectSpread({}, t), {}, {\n inputElement: n.element\n });\n }), _defineProperty(_It, 9, function _(t, n) {\n return t.buttonElement === n.element ? t : _objectSpread(_objectSpread({}, t), {}, {\n buttonElement: n.element\n });\n }), _defineProperty(_It, 10, function _(t, n) {\n return t.optionsElement === n.element ? t : _objectSpread(_objectSpread({}, t), {}, {\n optionsElement: n.element\n });\n }), _It),\n ve = /*#__PURE__*/me(null);\nve.displayName = \"ComboboxActionsContext\";\nfunction re(t) {\n var n = fe(ve);\n if (n === null) {\n var e = new Error(\"<\".concat(t, \" /> is missing a parent component.\"));\n throw Error.captureStackTrace && Error.captureStackTrace(e, re), e;\n }\n return n;\n}\nvar Be = /*#__PURE__*/me(null);\nfunction Pt(t) {\n var n = oe(\"VirtualProvider\"),\n e = n.virtual.options,\n _W = W(function () {\n var r = n.optionsElement;\n if (!r) return [0, 0];\n var i = window.getComputedStyle(r);\n return [parseFloat(i.paddingBlockStart || i.paddingTop), parseFloat(i.paddingBlockEnd || i.paddingBottom)];\n }, [n.optionsElement]),\n _W2 = _slicedToArray(_W, 2),\n o = _W2[0],\n f = _W2[1],\n b = Ne({\n enabled: e.length !== 0,\n scrollPaddingStart: o,\n scrollPaddingEnd: f,\n count: e.length,\n estimateSize: function estimateSize() {\n return 40;\n },\n getScrollElement: function getScrollElement() {\n return n.optionsElement;\n },\n overscan: 12\n }),\n _He = He(0),\n _He2 = _slicedToArray(_He, 2),\n m = _He2[0],\n d = _He2[1];\n X(function () {\n d(function (r) {\n return r + 1;\n });\n }, [e]);\n var T = b.getVirtualItems();\n return T.length === 0 ? null : /*#__PURE__*/F.createElement(Be.Provider, {\n value: b\n }, /*#__PURE__*/F.createElement(\"div\", {\n style: {\n position: \"relative\",\n width: \"100%\",\n height: \"\".concat(b.getTotalSize(), \"px\")\n },\n ref: function ref(r) {\n if (r) {\n if (typeof process != \"undefined\" && process.env.JEST_WORKER_ID !== void 0 || n.activationTrigger === 0) return;\n n.activeOptionIndex !== null && e.length > n.activeOptionIndex && b.scrollToIndex(n.activeOptionIndex);\n }\n }\n }, T.map(function (r) {\n var i;\n return /*#__PURE__*/F.createElement(Ie, {\n key: r.key\n }, /*#__PURE__*/F.cloneElement((i = t.children) == null ? void 0 : i.call(t, _objectSpread(_objectSpread({}, t.slot), {}, {\n option: e[r.index]\n })), {\n key: \"\".concat(m, \"-\").concat(r.key),\n \"data-index\": r.index,\n \"aria-setsize\": e.length,\n \"aria-posinset\": r.index + 1,\n style: {\n position: \"absolute\",\n top: 0,\n left: 0,\n transform: \"translateY(\".concat(r.start, \"px)\"),\n overflowAnchor: \"none\"\n }\n }));\n })));\n}\nvar le = /*#__PURE__*/me(null);\nle.displayName = \"ComboboxDataContext\";\nfunction oe(t) {\n var n = fe(le);\n if (n === null) {\n var e = new Error(\"<\".concat(t, \" /> is missing a parent component.\"));\n throw Error.captureStackTrace && Error.captureStackTrace(e, oe), e;\n }\n return n;\n}\nfunction At(t, n) {\n return te(n.type, It, t, n);\n}\nvar Rt = Ie;\nfunction _t(t, n) {\n var _te3;\n var ye, Oe;\n var e = nt(),\n o = t.value,\n f = t.defaultValue,\n b = t.onChange,\n m = t.form,\n d = t.name,\n T = t.by,\n _t$disabled = t.disabled,\n r = _t$disabled === void 0 ? e || !1 : _t$disabled,\n i = t.onClose,\n _t$__demoMode = t.__demoMode,\n l = _t$__demoMode === void 0 ? !1 : _t$__demoMode,\n _t$multiple = t.multiple,\n S = _t$multiple === void 0 ? !1 : _t$multiple,\n _t$immediate = t.immediate,\n A = _t$immediate === void 0 ? !1 : _t$immediate,\n _t$virtual2 = t.virtual,\n s = _t$virtual2 === void 0 ? null : _t$virtual2,\n V = t.nullable,\n N = _objectWithoutProperties(t, _excluded),\n _ = We(f),\n _Ke = Ke(o, b, _),\n _Ke2 = _slicedToArray(_Ke, 2),\n _Ke2$ = _Ke2[0],\n C = _Ke2$ === void 0 ? S ? [] : void 0 : _Ke2$,\n x = _Ke2[1],\n _Ue = Ue(At, {\n dataRef: /*#__PURE__*/ke(),\n comboboxState: l ? 0 : 1,\n isTyping: !1,\n options: [],\n virtual: s ? {\n options: s.options,\n disabled: (ye = s.disabled) != null ? ye : function () {\n return !1;\n }\n } : null,\n activeOptionIndex: null,\n activationTrigger: 2,\n inputElement: null,\n buttonElement: null,\n optionsElement: null,\n __demoMode: l\n }),\n _Ue2 = _slicedToArray(_Ue, 2),\n P = _Ue2[0],\n v = _Ue2[1],\n M = Z(!1),\n y = Z({\n static: !1,\n hold: !1\n }),\n D = ze(T),\n j = c(function (p) {\n return s ? T === null ? s.options.indexOf(p) : s.options.findIndex(function (g) {\n return D(g, p);\n }) : P.options.findIndex(function (g) {\n return D(g.dataRef.current.value, p);\n });\n }),\n q = ce(function (p) {\n var _te;\n return te(u.mode, (_te = {}, _defineProperty(_te, 1, function _() {\n return C.some(function (g) {\n return D(g, p);\n });\n }), _defineProperty(_te, 0, function _() {\n return D(C, p);\n }), _te));\n }, [C]),\n H = c(function (p) {\n return P.activeOptionIndex === j(p);\n }),\n u = W(function () {\n return _objectSpread(_objectSpread({}, P), {}, {\n immediate: A,\n optionsPropsRef: y,\n value: C,\n defaultValue: _,\n disabled: r,\n mode: S ? 1 : 0,\n virtual: s ? P.virtual : null,\n get activeOptionIndex() {\n if (M.current && P.activeOptionIndex === null && (s ? s.options.length > 0 : P.options.length > 0)) {\n if (s) {\n var g = s.options.findIndex(function (z) {\n var pe, Ce;\n return !((Ce = (pe = s.disabled) == null ? void 0 : pe.call(s, z)) != null && Ce);\n });\n if (g !== -1) return g;\n }\n var p = P.options.findIndex(function (g) {\n return !g.dataRef.current.disabled;\n });\n if (p !== -1) return p;\n }\n return P.activeOptionIndex;\n },\n calculateIndex: j,\n compare: D,\n isSelected: q,\n isActive: H\n });\n }, [C, _, r, S, l, P, s]);\n X(function () {\n var p;\n s && v({\n type: 7,\n options: s.options,\n disabled: (p = s.disabled) != null ? p : null\n });\n }, [s, s == null ? void 0 : s.options, s == null ? void 0 : s.disabled]), X(function () {\n P.dataRef.current = u;\n }, [u]);\n var G = u.comboboxState === 0;\n qe(G, [u.buttonElement, u.inputElement, u.optionsElement], function () {\n return L.closeCombobox();\n });\n var K = W(function () {\n var p, g, z;\n return {\n open: u.comboboxState === 0,\n disabled: r,\n activeIndex: u.activeOptionIndex,\n activeOption: u.activeOptionIndex === null ? null : u.virtual ? u.virtual.options[(p = u.activeOptionIndex) != null ? p : 0] : (z = (g = u.options[u.activeOptionIndex]) == null ? void 0 : g.dataRef.current.value) != null ? z : null,\n value: C\n };\n }, [u, r, C]),\n O = c(function () {\n if (u.activeOptionIndex !== null) {\n if (L.setIsTyping(!1), u.virtual) Q(u.virtual.options[u.activeOptionIndex]);else {\n var p = u.options[u.activeOptionIndex].dataRef;\n Q(p.current.value);\n }\n L.goToOption(I.Specific, u.activeOptionIndex);\n }\n }),\n k = c(function () {\n v({\n type: 0\n }), M.current = !0;\n }),\n Y = c(function () {\n v({\n type: 1\n }), M.current = !1, i == null || i();\n }),\n J = c(function (p) {\n v({\n type: 3,\n isTyping: p\n });\n }),\n h = c(function (p, g, z) {\n return M.current = !1, p === I.Specific ? v({\n type: 2,\n focus: I.Specific,\n idx: g,\n trigger: z\n }) : v({\n type: 2,\n focus: p,\n trigger: z\n });\n }),\n ae = c(function (p, g) {\n return v({\n type: 4,\n payload: {\n id: p,\n dataRef: g\n }\n }), function () {\n u.isActive(g.current.value) && (M.current = !0), v({\n type: 5,\n id: p\n });\n };\n }),\n Q = c(function (p) {\n var _te2;\n return te(u.mode, (_te2 = {}, _defineProperty(_te2, 0, function _() {\n return x == null ? void 0 : x(p);\n }), _defineProperty(_te2, 1, function _() {\n var g = u.value.slice(),\n z = g.findIndex(function (pe) {\n return D(pe, p);\n });\n return z === -1 ? g.push(p) : g.splice(z, 1), x == null ? void 0 : x(g);\n }), _te2));\n }),\n ue = c(function (p) {\n v({\n type: 6,\n trigger: p\n });\n }),\n a = c(function (p) {\n v({\n type: 8,\n element: p\n });\n }),\n U = c(function (p) {\n v({\n type: 9,\n element: p\n });\n }),\n R = c(function (p) {\n v({\n type: 10,\n element: p\n });\n }),\n L = W(function () {\n return {\n onChange: Q,\n registerOption: ae,\n goToOption: h,\n setIsTyping: J,\n closeCombobox: Y,\n openCombobox: k,\n setActivationTrigger: ue,\n selectActiveOption: O,\n setInputElement: a,\n setButtonElement: U,\n setOptionsElement: R\n };\n }, []),\n _vt = vt(),\n _vt2 = _slicedToArray(_vt, 2),\n E = _vt2[0],\n w = _vt2[1],\n $ = n === null ? {} : {\n ref: n\n },\n we = ce(function () {\n if (_ !== void 0) return x == null ? void 0 : x(_);\n }, [x, _]);\n return /*#__PURE__*/F.createElement(w, {\n value: E,\n props: {\n htmlFor: (Oe = u.inputElement) == null ? void 0 : Oe.id\n },\n slot: {\n open: u.comboboxState === 0,\n disabled: r\n }\n }, /*#__PURE__*/F.createElement(it, null, /*#__PURE__*/F.createElement(ve.Provider, {\n value: L\n }, /*#__PURE__*/F.createElement(le.Provider, {\n value: u\n }, /*#__PURE__*/F.createElement(bt, {\n value: te(u.comboboxState, (_te3 = {}, _defineProperty(_te3, 0, be.Open), _defineProperty(_te3, 1, be.Closed), _te3))\n }, d != null && /*#__PURE__*/F.createElement(pt, {\n disabled: r,\n data: C != null ? _defineProperty({}, d, C) : {},\n form: m,\n onReset: we\n }), ie({\n ourProps: $,\n theirProps: N,\n slot: K,\n defaultTag: Rt,\n name: \"Combobox\"\n }))))));\n}\nvar ht = \"input\";\nfunction Mt(t, n) {\n var J, h, ae, Q, ue;\n var e = oe(\"Combobox.Input\"),\n o = re(\"Combobox.Input\"),\n f = se(),\n b = dt(),\n _t$id = t.id,\n m = _t$id === void 0 ? b || \"headlessui-combobox-input-\".concat(f) : _t$id,\n d = t.onChange,\n T = t.displayValue,\n _t$disabled2 = t.disabled,\n r = _t$disabled2 === void 0 ? e.disabled || !1 : _t$disabled2,\n _t$autoFocus = t.autoFocus,\n i = _t$autoFocus === void 0 ? !1 : _t$autoFocus,\n _t$type = t.type,\n l = _t$type === void 0 ? \"text\" : _t$type,\n S = _objectWithoutProperties(t, _excluded2),\n A = Z(null),\n s = de(A, n, at(), o.setInputElement),\n V = Ae(e.inputElement),\n N = je(),\n _ = c(function () {\n o.onChange(null), e.optionsElement && (e.optionsElement.scrollTop = 0), o.goToOption(I.Nothing);\n }),\n C = W(function () {\n var a;\n return typeof T == \"function\" && e.value !== void 0 ? (a = T(e.value)) != null ? a : \"\" : typeof e.value == \"string\" ? e.value : \"\";\n }, [e.value, T]);\n _e(function (_ref2, _ref3) {\n var _ref4 = _slicedToArray(_ref2, 2),\n a = _ref4[0],\n U = _ref4[1];\n var _ref5 = _slicedToArray(_ref3, 2),\n R = _ref5[0],\n L = _ref5[1];\n if (e.isTyping) return;\n var E = A.current;\n E && ((L === 0 && U === 1 || a !== R) && (E.value = a), requestAnimationFrame(function () {\n if (e.isTyping || !E || (V == null ? void 0 : V.activeElement) !== E) return;\n var w = E.selectionStart,\n $ = E.selectionEnd;\n Math.abs(($ != null ? $ : 0) - (w != null ? w : 0)) === 0 && w === 0 && E.setSelectionRange(E.value.length, E.value.length);\n }));\n }, [C, e.comboboxState, V, e.isTyping]), _e(function (_ref6, _ref7) {\n var _ref8 = _slicedToArray(_ref6, 1),\n a = _ref8[0];\n var _ref9 = _slicedToArray(_ref7, 1),\n U = _ref9[0];\n if (a === 0 && U === 1) {\n if (e.isTyping) return;\n var R = A.current;\n if (!R) return;\n var L = R.value,\n E = R.selectionStart,\n w = R.selectionEnd,\n $ = R.selectionDirection;\n R.value = \"\", R.value = L, $ !== null ? R.setSelectionRange(E, w, $) : R.setSelectionRange(E, w);\n }\n }, [e.comboboxState]);\n var x = Z(!1),\n P = c(function () {\n x.current = !0;\n }),\n v = c(function () {\n N.nextFrame(function () {\n x.current = !1;\n });\n }),\n M = c(function (a) {\n var _te4, _te5;\n switch (o.setIsTyping(!0), a.key) {\n case B.Enter:\n if (e.comboboxState !== 0 || x.current) return;\n if (a.preventDefault(), a.stopPropagation(), e.activeOptionIndex === null) {\n o.closeCombobox();\n return;\n }\n o.selectActiveOption(), e.mode === 0 && o.closeCombobox();\n break;\n case B.ArrowDown:\n return a.preventDefault(), a.stopPropagation(), te(e.comboboxState, (_te4 = {}, _defineProperty(_te4, 0, function _() {\n return o.goToOption(I.Next);\n }), _defineProperty(_te4, 1, function _() {\n return o.openCombobox();\n }), _te4));\n case B.ArrowUp:\n return a.preventDefault(), a.stopPropagation(), te(e.comboboxState, (_te5 = {}, _defineProperty(_te5, 0, function _() {\n return o.goToOption(I.Previous);\n }), _defineProperty(_te5, 1, function _() {\n ee(function () {\n return o.openCombobox();\n }), e.value || o.goToOption(I.Last);\n }), _te5));\n case B.Home:\n if (a.shiftKey) break;\n return a.preventDefault(), a.stopPropagation(), o.goToOption(I.First);\n case B.PageUp:\n return a.preventDefault(), a.stopPropagation(), o.goToOption(I.First);\n case B.End:\n if (a.shiftKey) break;\n return a.preventDefault(), a.stopPropagation(), o.goToOption(I.Last);\n case B.PageDown:\n return a.preventDefault(), a.stopPropagation(), o.goToOption(I.Last);\n case B.Escape:\n return e.comboboxState !== 0 ? void 0 : (a.preventDefault(), e.optionsElement && !e.optionsPropsRef.current.static && a.stopPropagation(), e.mode === 0 && e.value === null && _(), o.closeCombobox());\n case B.Tab:\n if (e.comboboxState !== 0) return;\n e.mode === 0 && e.activationTrigger !== 1 && o.selectActiveOption(), o.closeCombobox();\n break;\n }\n }),\n y = c(function (a) {\n d == null || d(a), e.mode === 0 && a.target.value === \"\" && _(), o.openCombobox();\n }),\n D = c(function (a) {\n var R, L, E;\n var U = (R = a.relatedTarget) != null ? R : Me.find(function (w) {\n return w !== a.currentTarget;\n });\n if (!((L = e.optionsElement) != null && L.contains(U)) && !((E = e.buttonElement) != null && E.contains(U)) && e.comboboxState === 0) return a.preventDefault(), e.mode === 0 && e.value === null && _(), o.closeCombobox();\n }),\n j = c(function (a) {\n var R, L, E;\n var U = (R = a.relatedTarget) != null ? R : Me.find(function (w) {\n return w !== a.currentTarget;\n });\n (L = e.buttonElement) != null && L.contains(U) || (E = e.optionsElement) != null && E.contains(U) || e.disabled || e.immediate && e.comboboxState !== 0 && N.microTask(function () {\n ee(function () {\n return o.openCombobox();\n }), o.setActivationTrigger(1);\n });\n }),\n q = xe(),\n H = xt(),\n _Ee = Ee({\n autoFocus: i\n }),\n u = _Ee.isFocused,\n G = _Ee.focusProps,\n _Se = Se({\n isDisabled: r\n }),\n K = _Se.isHovered,\n O = _Se.hoverProps,\n k = W(function () {\n return {\n open: e.comboboxState === 0,\n disabled: r,\n hover: K,\n focus: u,\n autofocus: i\n };\n }, [e, K, u, i, r]),\n Y = Te({\n ref: s,\n id: m,\n role: \"combobox\",\n type: l,\n \"aria-controls\": (J = e.optionsElement) == null ? void 0 : J.id,\n \"aria-expanded\": e.comboboxState === 0,\n \"aria-activedescendant\": e.activeOptionIndex === null ? void 0 : e.virtual ? (h = e.options.find(function (a) {\n return !a.dataRef.current.disabled && e.compare(a.dataRef.current.value, e.virtual.options[e.activeOptionIndex]);\n })) == null ? void 0 : h.id : (ae = e.options[e.activeOptionIndex]) == null ? void 0 : ae.id,\n \"aria-labelledby\": q,\n \"aria-describedby\": H,\n \"aria-autocomplete\": \"list\",\n defaultValue: (ue = (Q = t.defaultValue) != null ? Q : e.defaultValue !== void 0 ? T == null ? void 0 : T(e.defaultValue) : null) != null ? ue : e.defaultValue,\n disabled: r || void 0,\n autoFocus: i,\n onCompositionStart: P,\n onCompositionEnd: v,\n onKeyDown: M,\n onChange: y,\n onFocus: j,\n onBlur: D\n }, G, O);\n return ie({\n ourProps: Y,\n theirProps: S,\n slot: k,\n defaultTag: ht,\n name: \"Combobox.Input\"\n });\n}\nvar Dt = \"button\";\nfunction Ft(t, n) {\n var M;\n var e = oe(\"Combobox.Button\"),\n o = re(\"Combobox.Button\"),\n f = de(n, o.setButtonElement),\n b = se(),\n _t$id2 = t.id,\n m = _t$id2 === void 0 ? \"headlessui-combobox-button-\".concat(b) : _t$id2,\n _t$disabled3 = t.disabled,\n d = _t$disabled3 === void 0 ? e.disabled || !1 : _t$disabled3,\n _t$autoFocus2 = t.autoFocus,\n T = _t$autoFocus2 === void 0 ? !1 : _t$autoFocus2,\n r = _objectWithoutProperties(t, _excluded3),\n i = Re(e.inputElement),\n l = c(function (y) {\n switch (y.key) {\n case B.Space:\n case B.Enter:\n y.preventDefault(), y.stopPropagation(), e.comboboxState === 1 && ee(function () {\n return o.openCombobox();\n }), i();\n return;\n case B.ArrowDown:\n y.preventDefault(), y.stopPropagation(), e.comboboxState === 1 && (ee(function () {\n return o.openCombobox();\n }), e.value || o.goToOption(I.First)), i();\n return;\n case B.ArrowUp:\n y.preventDefault(), y.stopPropagation(), e.comboboxState === 1 && (ee(function () {\n return o.openCombobox();\n }), e.value || o.goToOption(I.Last)), i();\n return;\n case B.Escape:\n if (e.comboboxState !== 0) return;\n y.preventDefault(), e.optionsElement && !e.optionsPropsRef.current.static && y.stopPropagation(), ee(function () {\n return o.closeCombobox();\n }), i();\n return;\n default:\n return;\n }\n }),\n S = c(function (y) {\n y.preventDefault(), !ct(y.currentTarget) && (y.button === Le.Left && (e.comboboxState === 0 ? o.closeCombobox() : o.openCombobox()), i());\n }),\n A = xe([m]),\n _Ee2 = Ee({\n autoFocus: T\n }),\n s = _Ee2.isFocusVisible,\n V = _Ee2.focusProps,\n _Se2 = Se({\n isDisabled: d\n }),\n N = _Se2.isHovered,\n _ = _Se2.hoverProps,\n _Ge = Ge({\n disabled: d\n }),\n C = _Ge.pressed,\n x = _Ge.pressProps,\n P = W(function () {\n return {\n open: e.comboboxState === 0,\n active: C || e.comboboxState === 0,\n disabled: d,\n value: e.value,\n hover: N,\n focus: s\n };\n }, [e, N, s, C, d]),\n v = Te({\n ref: f,\n id: m,\n type: Ye(t, e.buttonElement),\n tabIndex: -1,\n \"aria-haspopup\": \"listbox\",\n \"aria-controls\": (M = e.optionsElement) == null ? void 0 : M.id,\n \"aria-expanded\": e.comboboxState === 0,\n \"aria-labelledby\": A,\n disabled: d || void 0,\n autoFocus: T,\n onMouseDown: S,\n onKeyDown: l\n }, V, _, x);\n return ie({\n ourProps: v,\n theirProps: r,\n slot: P,\n defaultTag: Dt,\n name: \"Combobox.Button\"\n });\n}\nvar Vt = \"div\",\n Lt = Ve.RenderStrategy | Ve.Static;\nfunction Bt(t, n) {\n var k, Y, J;\n var e = se(),\n _t$id3 = t.id,\n o = _t$id3 === void 0 ? \"headlessui-combobox-options-\".concat(e) : _t$id3,\n _t$hold = t.hold,\n f = _t$hold === void 0 ? !1 : _t$hold,\n b = t.anchor,\n _t$portal = t.portal,\n m = _t$portal === void 0 ? !1 : _t$portal,\n _t$modal = t.modal,\n d = _t$modal === void 0 ? !0 : _t$modal,\n _t$transition = t.transition,\n T = _t$transition === void 0 ? !1 : _t$transition,\n r = _objectWithoutProperties(t, _excluded4),\n i = oe(\"Combobox.Options\"),\n l = re(\"Combobox.Options\"),\n S = ut(b);\n S && (m = !0);\n var _rt = rt(S),\n _rt2 = _slicedToArray(_rt, 2),\n A = _rt2[0],\n s = _rt2[1],\n V = lt(),\n N = de(n, S ? A : null, l.setOptionsElement),\n _ = Ae(i.optionsElement),\n C = mt(),\n _tt = tt(T, i.optionsElement, C !== null ? (C & be.Open) === be.Open : i.comboboxState === 0),\n _tt2 = _slicedToArray(_tt, 2),\n x = _tt2[0],\n P = _tt2[1];\n Je(x, i.inputElement, l.closeCombobox);\n var v = i.__demoMode ? !1 : d && i.comboboxState === 0;\n Qe(v, _);\n var M = i.__demoMode ? !1 : d && i.comboboxState === 0;\n $e(M, {\n allowed: ce(function () {\n return [i.inputElement, i.buttonElement, i.optionsElement];\n }, [i.inputElement, i.buttonElement, i.optionsElement])\n }), X(function () {\n var h;\n i.optionsPropsRef.current.static = (h = t.static) != null ? h : !1;\n }, [i.optionsPropsRef, t.static]), X(function () {\n i.optionsPropsRef.current.hold = f;\n }, [i.optionsPropsRef, f]), ot(i.comboboxState === 0, {\n container: i.optionsElement,\n accept: function accept(h) {\n return h.getAttribute(\"role\") === \"option\" ? NodeFilter.FILTER_REJECT : h.hasAttribute(\"role\") ? NodeFilter.FILTER_SKIP : NodeFilter.FILTER_ACCEPT;\n },\n walk: function walk(h) {\n h.setAttribute(\"role\", \"none\");\n }\n });\n var y = xe([(k = i.buttonElement) == null ? void 0 : k.id]),\n D = W(function () {\n return {\n open: i.comboboxState === 0,\n option: void 0\n };\n }, [i.comboboxState]),\n j = c(function () {\n l.setActivationTrigger(0);\n }),\n q = c(function (h) {\n h.preventDefault(), l.setActivationTrigger(0);\n }),\n H = Te(S ? V() : {}, _objectSpread({\n \"aria-labelledby\": y,\n role: \"listbox\",\n \"aria-multiselectable\": i.mode === 1 ? !0 : void 0,\n id: o,\n ref: N,\n style: _objectSpread(_objectSpread(_objectSpread({}, r.style), s), {}, {\n \"--input-width\": Pe(i.inputElement, !0).width,\n \"--button-width\": Pe(i.buttonElement, !0).width\n }),\n onWheel: i.activationTrigger === 0 ? void 0 : j,\n onMouseDown: q\n }, et(P))),\n u = x && i.comboboxState === 1,\n G = he(u, (Y = i.virtual) == null ? void 0 : Y.options),\n K = he(u, i.value),\n O = c(function (h) {\n return i.compare(K, h);\n });\n if (i.virtual) {\n if (G === void 0) throw new Error(\"Missing `options` in virtual mode\");\n Object.assign(r, {\n children: /*#__PURE__*/F.createElement(le.Provider, {\n value: G !== i.virtual.options ? _objectSpread(_objectSpread({}, i), {}, {\n virtual: _objectSpread(_objectSpread({}, i.virtual), {}, {\n options: G\n })\n }) : i\n }, /*#__PURE__*/F.createElement(Pt, {\n slot: D\n }, r.children))\n });\n }\n return /*#__PURE__*/F.createElement(yt, {\n enabled: m ? t.static || x : !1\n }, /*#__PURE__*/F.createElement(le.Provider, {\n value: i.mode === 1 ? i : _objectSpread(_objectSpread({}, i), {}, {\n isSelected: O\n })\n }, ie({\n ourProps: H,\n theirProps: _objectSpread(_objectSpread({}, r), {}, {\n children: /*#__PURE__*/F.createElement(st, {\n freeze: u\n }, typeof r.children == \"function\" ? (J = r.children) == null ? void 0 : J.call(r, D) : r.children)\n }),\n slot: D,\n defaultTag: Vt,\n features: Lt,\n visible: x,\n name: \"Combobox.Options\"\n })));\n}\nvar wt = \"div\";\nfunction Nt(t, n) {\n var H, u, G, K;\n var e = oe(\"Combobox.Option\"),\n o = re(\"Combobox.Option\"),\n f = se(),\n _t$id4 = t.id,\n b = _t$id4 === void 0 ? \"headlessui-combobox-option-\".concat(f) : _t$id4,\n m = t.value,\n _t$disabled4 = t.disabled,\n d = _t$disabled4 === void 0 ? (G = (u = (H = e.virtual) == null ? void 0 : H.disabled) == null ? void 0 : u.call(H, m)) != null ? G : !1 : _t$disabled4,\n _t$order = t.order,\n T = _t$order === void 0 ? null : _t$order,\n r = _objectWithoutProperties(t, _excluded5),\n i = Re(e.inputElement),\n l = e.virtual ? e.activeOptionIndex === e.calculateIndex(m) : e.activeOptionIndex === null ? !1 : ((K = e.options[e.activeOptionIndex]) == null ? void 0 : K.id) === b,\n S = e.isSelected(m),\n A = Z(null),\n s = Xe({\n disabled: d,\n value: m,\n domRef: A,\n order: T\n }),\n V = fe(Be),\n N = de(n, A, V ? V.measureElement : null),\n _ = c(function () {\n o.setIsTyping(!1), o.onChange(m);\n });\n X(function () {\n return o.registerOption(b, s);\n }, [s, b]);\n var C = Z(!(e.virtual || e.__demoMode));\n X(function () {\n if (!e.virtual && !e.__demoMode) return Fe().requestAnimationFrame(function () {\n C.current = !0;\n });\n }, [e.virtual, e.__demoMode]), X(function () {\n if (C.current && e.comboboxState === 0 && l && e.activationTrigger !== 0) return Fe().requestAnimationFrame(function () {\n var O, k;\n (k = (O = A.current) == null ? void 0 : O.scrollIntoView) == null || k.call(O, {\n block: \"nearest\"\n });\n });\n }, [A, l, e.comboboxState, e.activationTrigger, e.activeOptionIndex]);\n var x = c(function (O) {\n O.preventDefault(), O.button === Le.Left && (d || (_(), Tt() || requestAnimationFrame(function () {\n return i();\n }), e.mode === 0 && o.closeCombobox()));\n }),\n P = c(function () {\n if (d) return o.goToOption(I.Nothing);\n var O = e.calculateIndex(m);\n o.goToOption(I.Specific, O);\n }),\n v = Ze(),\n M = c(function (O) {\n return v.update(O);\n }),\n y = c(function (O) {\n if (!v.wasMoved(O) || d || l) return;\n var k = e.calculateIndex(m);\n o.goToOption(I.Specific, k, 0);\n }),\n D = c(function (O) {\n v.wasMoved(O) && (d || l && (e.optionsPropsRef.current.hold || o.goToOption(I.Nothing)));\n }),\n j = W(function () {\n return {\n active: l,\n focus: l,\n selected: S,\n disabled: d\n };\n }, [l, S, d]);\n return ie({\n ourProps: {\n id: b,\n ref: N,\n role: \"option\",\n tabIndex: d === !0 ? void 0 : -1,\n \"aria-disabled\": d === !0 ? !0 : void 0,\n \"aria-selected\": S,\n disabled: void 0,\n onMouseDown: x,\n onFocus: P,\n onPointerEnter: M,\n onMouseEnter: M,\n onPointerMove: y,\n onMouseMove: y,\n onPointerLeave: D,\n onMouseLeave: D\n },\n theirProps: r,\n slot: j,\n defaultTag: wt,\n name: \"Combobox.Option\"\n });\n}\nvar kt = ne(_t),\n Ut = ne(Ft),\n Ht = ne(Mt),\n Gt = gt,\n zt = ne(Bt),\n Kt = ne(Nt),\n ko = Object.assign(kt, {\n Input: Ht,\n Button: Ut,\n Label: Gt,\n Options: zt,\n Option: Kt\n });\nexport { ko as Combobox, Ut as ComboboxButton, Ht as ComboboxInput, Gt as ComboboxLabel, Kt as ComboboxOption, zt as ComboboxOptions };","'use strict';\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar tryToString = require('../internals/try-to-string');\nvar getIteratorMethod = require('../internals/get-iterator-method');\n\nvar $TypeError = TypeError;\n\nmodule.exports = function (argument, usingIterator) {\n var iteratorMethod = arguments.length < 2 ? getIteratorMethod(argument) : usingIterator;\n if (aCallable(iteratorMethod)) return anObject(call(iteratorMethod, argument));\n throw new $TypeError(tryToString(argument) + ' is not iterable');\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar anObject = require('../internals/an-object');\nvar getMethod = require('../internals/get-method');\n\nmodule.exports = function (iterator, kind, value) {\n var innerResult, innerError;\n anObject(iterator);\n try {\n innerResult = getMethod(iterator, 'return');\n if (!innerResult) {\n if (kind === 'throw') throw value;\n return value;\n }\n innerResult = call(innerResult, iterator);\n } catch (error) {\n innerError = true;\n innerResult = error;\n }\n if (kind === 'throw') throw value;\n if (innerError) throw innerResult;\n anObject(innerResult);\n return value;\n};\n","'use strict';\nvar fails = require('../internals/fails');\n\nmodule.exports = function (METHOD_NAME, argument) {\n var method = [][METHOD_NAME];\n return !!method && fails(function () {\n // eslint-disable-next-line no-useless-call -- required for testing\n method.call(null, argument || function () { return 1; }, 1);\n });\n};\n","'use strict';\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\nvar create = require('../internals/object-create');\nvar getPrototypeOf = require('../internals/object-get-prototype-of');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar IS_PURE = require('../internals/is-pure');\n\nvar ITERATOR = wellKnownSymbol('iterator');\nvar BUGGY_SAFARI_ITERATORS = false;\n\n// `%IteratorPrototype%` object\n// https://tc39.es/ecma262/#sec-%iteratorprototype%-object\nvar IteratorPrototype, PrototypeOfArrayIteratorPrototype, arrayIterator;\n\n/* eslint-disable es/no-array-prototype-keys -- safe */\nif ([].keys) {\n arrayIterator = [].keys();\n // Safari 8 has buggy iterators w/o `next`\n if (!('next' in arrayIterator)) BUGGY_SAFARI_ITERATORS = true;\n else {\n PrototypeOfArrayIteratorPrototype = getPrototypeOf(getPrototypeOf(arrayIterator));\n if (PrototypeOfArrayIteratorPrototype !== Object.prototype) IteratorPrototype = PrototypeOfArrayIteratorPrototype;\n }\n}\n\nvar NEW_ITERATOR_PROTOTYPE = !isObject(IteratorPrototype) || fails(function () {\n var test = {};\n // FF44- legacy iterators case\n return IteratorPrototype[ITERATOR].call(test) !== test;\n});\n\nif (NEW_ITERATOR_PROTOTYPE) IteratorPrototype = {};\nelse if (IS_PURE) IteratorPrototype = create(IteratorPrototype);\n\n// `%IteratorPrototype%[@@iterator]()` method\n// https://tc39.es/ecma262/#sec-%iteratorprototype%-@@iterator\nif (!isCallable(IteratorPrototype[ITERATOR])) {\n defineBuiltIn(IteratorPrototype, ITERATOR, function () {\n return this;\n });\n}\n\nmodule.exports = {\n IteratorPrototype: IteratorPrototype,\n BUGGY_SAFARI_ITERATORS: BUGGY_SAFARI_ITERATORS\n};\n","'use strict';\n/* eslint-disable regexp/no-empty-capturing-group, regexp/no-empty-group, regexp/no-lazy-ends -- testing */\n/* eslint-disable regexp/no-useless-quantifier -- testing */\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toString = require('../internals/to-string');\nvar regexpFlags = require('../internals/regexp-flags');\nvar stickyHelpers = require('../internals/regexp-sticky-helpers');\nvar shared = require('../internals/shared');\nvar create = require('../internals/object-create');\nvar getInternalState = require('../internals/internal-state').get;\nvar UNSUPPORTED_DOT_ALL = require('../internals/regexp-unsupported-dot-all');\nvar UNSUPPORTED_NCG = require('../internals/regexp-unsupported-ncg');\n\nvar nativeReplace = shared('native-string-replace', String.prototype.replace);\nvar nativeExec = RegExp.prototype.exec;\nvar patchedExec = nativeExec;\nvar charAt = uncurryThis(''.charAt);\nvar indexOf = uncurryThis(''.indexOf);\nvar replace = uncurryThis(''.replace);\nvar stringSlice = uncurryThis(''.slice);\n\nvar UPDATES_LAST_INDEX_WRONG = (function () {\n var re1 = /a/;\n var re2 = /b*/g;\n call(nativeExec, re1, 'a');\n call(nativeExec, re2, 'a');\n return re1.lastIndex !== 0 || re2.lastIndex !== 0;\n})();\n\nvar UNSUPPORTED_Y = stickyHelpers.BROKEN_CARET;\n\n// nonparticipating capturing group, copied from es5-shim's String#split patch.\nvar NPCG_INCLUDED = /()??/.exec('')[1] !== undefined;\n\nvar PATCH = UPDATES_LAST_INDEX_WRONG || NPCG_INCLUDED || UNSUPPORTED_Y || UNSUPPORTED_DOT_ALL || UNSUPPORTED_NCG;\n\nif (PATCH) {\n patchedExec = function exec(string) {\n var re = this;\n var state = getInternalState(re);\n var str = toString(string);\n var raw = state.raw;\n var result, reCopy, lastIndex, match, i, object, group;\n\n if (raw) {\n raw.lastIndex = re.lastIndex;\n result = call(patchedExec, raw, str);\n re.lastIndex = raw.lastIndex;\n return result;\n }\n\n var groups = state.groups;\n var sticky = UNSUPPORTED_Y && re.sticky;\n var flags = call(regexpFlags, re);\n var source = re.source;\n var charsAdded = 0;\n var strCopy = str;\n\n if (sticky) {\n flags = replace(flags, 'y', '');\n if (indexOf(flags, 'g') === -1) {\n flags += 'g';\n }\n\n strCopy = stringSlice(str, re.lastIndex);\n // Support anchored sticky behavior.\n if (re.lastIndex > 0 && (!re.multiline || re.multiline && charAt(str, re.lastIndex - 1) !== '\\n')) {\n source = '(?: ' + source + ')';\n strCopy = ' ' + strCopy;\n charsAdded++;\n }\n // ^(? + rx + ) is needed, in combination with some str slicing, to\n // simulate the 'y' flag.\n reCopy = new RegExp('^(?:' + source + ')', flags);\n }\n\n if (NPCG_INCLUDED) {\n reCopy = new RegExp('^' + source + '$(?!\\\\s)', flags);\n }\n if (UPDATES_LAST_INDEX_WRONG) lastIndex = re.lastIndex;\n\n match = call(nativeExec, sticky ? reCopy : re, strCopy);\n\n if (sticky) {\n if (match) {\n match.input = stringSlice(match.input, charsAdded);\n match[0] = stringSlice(match[0], charsAdded);\n match.index = re.lastIndex;\n re.lastIndex += match[0].length;\n } else re.lastIndex = 0;\n } else if (UPDATES_LAST_INDEX_WRONG && match) {\n re.lastIndex = re.global ? match.index + match[0].length : lastIndex;\n }\n if (NPCG_INCLUDED && match && match.length > 1) {\n // Fix browsers whose `exec` methods don't consistently return `undefined`\n // for NPCG, like IE8. NOTE: This doesn't work for /(.?)?/\n call(nativeReplace, match[0], reCopy, function () {\n for (i = 1; i < arguments.length - 2; i++) {\n if (arguments[i] === undefined) match[i] = undefined;\n }\n });\n }\n\n if (match && groups) {\n match.groups = object = create(null);\n for (i = 0; i < groups.length; i++) {\n group = groups[i];\n object[group[0]] = match[group[1]];\n }\n }\n\n return match;\n };\n}\n\nmodule.exports = patchedExec;\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\nvar toString = require('../internals/to-string');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nvar charAt = uncurryThis(''.charAt);\nvar charCodeAt = uncurryThis(''.charCodeAt);\nvar stringSlice = uncurryThis(''.slice);\n\nvar createMethod = function (CONVERT_TO_STRING) {\n return function ($this, pos) {\n var S = toString(requireObjectCoercible($this));\n var position = toIntegerOrInfinity(pos);\n var size = S.length;\n var first, second;\n if (position < 0 || position >= size) return CONVERT_TO_STRING ? '' : undefined;\n first = charCodeAt(S, position);\n return first < 0xD800 || first > 0xDBFF || position + 1 === size\n || (second = charCodeAt(S, position + 1)) < 0xDC00 || second > 0xDFFF\n ? CONVERT_TO_STRING\n ? charAt(S, position)\n : first\n : CONVERT_TO_STRING\n ? stringSlice(S, position, position + 2)\n : (first - 0xD800 << 10) + (second - 0xDC00) + 0x10000;\n };\n};\n\nmodule.exports = {\n // `String.prototype.codePointAt` method\n // https://tc39.es/ecma262/#sec-string.prototype.codepointat\n codeAt: createMethod(false),\n // `String.prototype.at` method\n // https://github.com/mathiasbynens/String.prototype.at\n charAt: createMethod(true)\n};\n","'use strict';\nvar global = require('../internals/global');\n\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar defineProperty = Object.defineProperty;\n\nmodule.exports = function (key, value) {\n try {\n defineProperty(global, key, { value: value, configurable: true, writable: true });\n } catch (error) {\n global[key] = value;\n } return value;\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar isCallable = require('../internals/is-callable');\nvar store = require('../internals/shared-store');\n\nvar functionToString = uncurryThis(Function.toString);\n\n// this helper broken in `core-js@3.4.1-3.4.4`, so we can't use `shared` helper\nif (!isCallable(store.inspectSource)) {\n store.inspectSource = function (it) {\n return functionToString(it);\n };\n}\n\nmodule.exports = store.inspectSource;\n","'use strict';\n// IE8- don't enum bug keys\nmodule.exports = [\n 'constructor',\n 'hasOwnProperty',\n 'isPrototypeOf',\n 'propertyIsEnumerable',\n 'toLocaleString',\n 'toString',\n 'valueOf'\n];\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\nvar test = {};\n\ntest[TO_STRING_TAG] = 'z';\n\nmodule.exports = String(test) === '[object z]';\n","'use strict';\nvar arraySpeciesConstructor = require('../internals/array-species-constructor');\n\n// `ArraySpeciesCreate` abstract operation\n// https://tc39.es/ecma262/#sec-arrayspeciescreate\nmodule.exports = function (originalArray, length) {\n return new (arraySpeciesConstructor(originalArray))(length === 0 ? 0 : length);\n};\n","'use strict';\nvar $TypeError = TypeError;\nvar MAX_SAFE_INTEGER = 0x1FFFFFFFFFFFFF; // 2 ** 53 - 1 == 9007199254740991\n\nmodule.exports = function (it) {\n if (it > MAX_SAFE_INTEGER) throw $TypeError('Maximum allowed index exceeded');\n return it;\n};\n","'use strict';\nvar fails = require('../internals/fails');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar V8_VERSION = require('../internals/engine-v8-version');\n\nvar SPECIES = wellKnownSymbol('species');\n\nmodule.exports = function (METHOD_NAME) {\n // We can't use this feature detection in V8 since it causes\n // deoptimization and serious performance degradation\n // https://github.com/zloirock/core-js/issues/677\n return V8_VERSION >= 51 || !fails(function () {\n var array = [];\n var constructor = array.constructor = {};\n constructor[SPECIES] = function () {\n return { foo: 1 };\n };\n return array[METHOD_NAME](Boolean).foo !== 1;\n });\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\nvar toString = require('../internals/to-string');\nvar whitespaces = require('../internals/whitespaces');\n\nvar replace = uncurryThis(''.replace);\nvar ltrim = RegExp('^[' + whitespaces + ']+');\nvar rtrim = RegExp('(^|[^' + whitespaces + '])[' + whitespaces + ']+$');\n\n// `String.prototype.{ trim, trimStart, trimEnd, trimLeft, trimRight }` methods implementation\nvar createMethod = function (TYPE) {\n return function ($this) {\n var string = toString(requireObjectCoercible($this));\n if (TYPE & 1) string = replace(string, ltrim, '');\n if (TYPE & 2) string = replace(string, rtrim, '$1');\n return string;\n };\n};\n\nmodule.exports = {\n // `String.prototype.{ trimLeft, trimStart }` methods\n // https://tc39.es/ecma262/#sec-string.prototype.trimstart\n start: createMethod(1),\n // `String.prototype.{ trimRight, trimEnd }` methods\n // https://tc39.es/ecma262/#sec-string.prototype.trimend\n end: createMethod(2),\n // `String.prototype.trim` method\n // https://tc39.es/ecma262/#sec-string.prototype.trim\n trim: createMethod(3)\n};\n","module.exports = function (module) {\n if (!module.webpackPolyfill) {\n module.deprecate = function () {};\n module.paths = [];\n // module.parent = undefined by default\n if (!module.children) module.children = [];\n Object.defineProperty(module, \"loaded\", {\n enumerable: true,\n get: function get() {\n return module.l;\n }\n });\n Object.defineProperty(module, \"id\", {\n enumerable: true,\n get: function get() {\n return module.i;\n }\n });\n module.webpackPolyfill = 1;\n }\n return module;\n};","import FileArea from './FileArea/index';\n\nexport default FileArea;\n","import React, { useState, useEffect, useRef } from 'react';\nimport { generateId } from '../../utils/genIds';\nimport Container from './DropArea';\nimport { DndProvider } from 'react-dnd'\nimport { HTML5Backend } from 'react-dnd-html5-backend'\n\n// max file size in bytes (10MB)\nconst MAX_FILE_SIZE = 10000000;\n\nconst FileArea = (props) => {\n const {\n name,\n hasMaxSize = true,\n buttonText = 'Change',\n acceptedTypes = [],\n } = props;\n\n return (\n <>\n \n \n \n >\n );\n};\n\nexport default FileArea;\n","import FormValuesFields from './FormValuesFields/index';\n\nexport default FormValuesFields;\n","import React, { useState } from 'react';\nimport { generateId } from \"../../utils/genIds\";\n\nexport default (props) => {\n // const { model, modelName, attribute, formFields, formSelectOptions } = props;\n const { formFields, state, dispatch } = props;\n\n const CompMap = {\n text: CustomInput,\n checkbox: Checkbox,\n \"drop down\": CustomDropDown,\n };\n\n return (\n \n {formFields.map((ff, i) => {\n const InputComponent = CompMap[ff.input_type] || CustomInput;\n return ;\n })}\n
\n );\n};\n\nconst CustomDropDown = ({ index, attribute, modelName, formField, formSelectOptions, state, dispatch }) => {\n const namePrefix = modelName ? `${modelName}[${attribute}][${index}]` : `${attribute}[${index}]`;\n const id = generateId();\n\n const handleChange = (e) => {\n const value = e.target.value;\n if (state && dispatch) {\n dispatch({\n type: \"UPDATE_FORM_VALUE\",\n formFieldId: formField.id,\n value,\n });\n }\n };\n\n const options = formSelectOptions.filter(\n (o) => o.form_field_id === formField.id\n );\n\n return (\n \n \n \n \n
\n );\n};\n\nconst Checkbox = ({ formField, modelName, attribute, index, state, dispatch }) => {\n const namePrefix = modelName ? `${modelName}[${attribute}][${index}]` : `${attribute}[${index}]`;\n const handleChange = (e) => {\n const value = e.target.value;\n if (state && dispatch) {\n dispatch({\n type: \"UPDATE_FORM_VALUE\",\n formFieldId: formField.id,\n value,\n });\n }\n };\n\n return (\n <>\n \n >\n );\n};\n\nconst CustomInput = ({ formField, attribute, index, modelName, state, dispatch }) => {\n const namePrefix = modelName ? `${modelName}[${attribute}][${index}]` : `${attribute}[${index}]`;\n const handleChange = (e) => {\n const value = e.target.value;\n if (state && dispatch) {\n dispatch({\n type: \"UPDATE_FORM_VALUE\",\n formFieldId: formField.id,\n value,\n });\n }\n };\n\n return (\n <>\n \n >\n );\n};\n\n","import React from 'react';\nimport { FieldsProvider, useFields } from './State';\nimport { FieldSetContainer } from './FormFields';\n\nexport default (props) => {\n const { resource, resource_name, fields, dropdown_options, input_types } = props;\n\n return (\n \n \n
\n
\n Customize Your Form\n
\n
\n Add unique form fields for gathering custom data from your\n members and clients\n
\n
\n
\n
\n \n \n );\n};\n\nconst FieldsListContainer = () => {\n const { state } = useFields();\n return (\n <>\n {state.fields.map((field, index) => {\n return (\n \n );\n })}\n >\n );\n};\n\nconst AddFieldButton = () => {\n const { addField } = useFields();\n\n const handleClick = (e) => {\n e.preventDefault();\n addField();\n };\n\n return (\n <>\n \n \n \n >\n );\n};\n","import React from 'react';\nimport { DndProvider } from 'react-dnd';\nimport { HTML5Backend } from 'react-dnd-html5-backend';\n\nimport { FundsProvider, useFunds } from './StateManagement';\nimport { FundCard } from './FundCard';\n\nconst FundsGrid = ({ newFundPath }) => {\n const { state, toggleDrag } = useFunds();\n const { funds, draggable } = state;\n\n const ToggleBG = !!draggable ? 'bg-indigo-600' : 'bg-gray-200';\n const ToggleBubbleBG = !!draggable ? 'translate-x-5' : 'translate-x-0';\n\n return (\n <>\n \n Your Fundraiser Pages\n
\n\n \n \n \n \n \n Enable drag-and-drop reordering\n \n
\n\n \n >\n );\n};\n\nconst Funds = ({ funds, newFundPath }) => {\n return (\n \n \n \n \n \n );\n};\n\nexport default Funds;\n","import React from \"react\";\nimport { InvoicePaymentFormProvider, useForm } from \"./provider\";\nimport { StripeSDKLoader } from \"../../utils/StripeSdkLoader\";\nimport { CardPaymentPage } from \"./CardPaymentPage\";\nimport { PickPaymentMethodPage } from \"./PickPaymentMethodPage\";\nimport { OfflinePaymentPage } from \"./OfflinePaymentPage\";\nimport { CreatePaymentMethodPage } from \"./CreatePaymentMethodPage\";\nimport { SuccessPage } from \"./SuccessPage\";\nimport StepWizard from \"react-step-wizard\";\n\nconst customAnimationClasses = {\n enterRight: '',\n enterLeft: '',\n exitRight: '',\n exitLeft: '',\n intro: ''\n}\nconst InvoicePaymentFormPage = () => {\n\n return (\n <>\n \n >\n )\n};\n\nconst InvoicePaymentForm = (props) => {\n const { stripe_publishable_key } = props\n return (\n \n \n \n \n \n );\n};\n\nexport default InvoicePaymentForm;\n","import React, { useState } from 'react'\n// import { Dialog, Transition } from '@headlessui/react'\n// import {\n// Bars3Icon,\n// CalendarIcon,\n// CogIcon,\n// HomeIcon,\n// MagnifyingGlassCircleIcon,\n// MapIcon,\n// MegaphoneIcon,\n// SquaresPlusIcon,\n// UserGroupIcon,\n// XMarkIcon,\n// } from '@heroicons/react/24/outline'\nimport SearchMembers from './SearchMembers'\n\nexport default function MembersListSidebar(props) {\n const { members, memberCount, currentMember, new_invoicing_member_path, fund } = props\n const [filteredMembers, setFilteredMembers] = useState(members || []);\n // let memberCount = Object.values(members).reduce((acc, val) => acc + val.length, 0);\n\n return (\n <>\n \n
\n\n
\n
Members
\n
Search directory of {memberCount} Members
\n
\n
\n \n \n\n
\n
\n
\n {/* Directory list */}\n \n >\n )\n}\n","import React from \"react\";\nimport { DndProvider } from \"react-dnd\";\nimport { HTML5Backend } from \"react-dnd-html5-backend\";\n\nimport { ProductsProvider, useProducts } from \"./StateManagement\";\nimport { ProductCard } from \"./ProductCard\";\n\nconst ProductsGrid = ({ newProductPath }) => {\n const { state, toggleDrag } = useProducts();\n const { products, draggable } = state;\n\n const ToggleBG = !!draggable ? \"bg-indigo-600\" : \"bg-gray-200\";\n const ToggleBubbleBG = !!draggable ? \"translate-x-5\" : \"translate-x-0\";\n\n return (\n <>\n \n Your Products\n
\n\n \n \n \n \n \n Enable drag-and-drop reordering\n \n
\n\n \n \n All Products ({products.length})\n \n
\n\n \n \n \n Product Info | \n Price | \n Quantity | \n Active | \n Action | \n
\n \n \n {!!products.length &&\n products.map((f, i) => (\n \n ))}\n \n
\n >\n );\n};\n\nconst Products = ({ products, newProductPath }) => {\n return (\n \n \n \n \n \n );\n};\n\nexport default Products;\n","import React, { useState, useContext, createContext, useReducer } from \"react\";\nimport { generateId } from \"../../utils/genIds\";\nimport DayPicker from \"../../utils/daypicker\";\n\nconst newScheduledReminder = {\n id: null,\n objectId: null,\n name: \"\",\n destroy: false,\n status: \"active\",\n days_before_or_after: 1,\n};\n\nconst initialState = {\n fund: {},\n disableAddRemove: false,\n scheduledReminders: [],\n};\n\nconst scheduledRemindersReducer = (state, action) => {\n switch (action.type) {\n case \"ADD_SCHEDULED_REMINDER\":\n return { ...state, scheduledReminders: [...state.scheduledReminders, action.scheduledReminder] };\n case \"UPDATE_SCHEDULED_REMINDER\":\n return {\n ...state, scheduledReminders: state.scheduledReminders.map((sr) => {\n if (sr.objectId === action.scheduledReminder.objectId) {\n return action.scheduledReminder\n } else {\n return sr\n }\n })\n };\n case \"SET_SCHEDULED_REMINDERS\":\n return { ...state, scheduledReminders: action.scheduledReminders };\n default:\n return state;\n }\n};\n\nconst ScheduledRemindersContext = createContext(null);\n\nconst useScheduledReminders = () => {\n const [state, dispatch] = useContext(ScheduledRemindersContext);\n\n const addScheduledReminder = () => {\n dispatch({\n type: \"ADD_SCHEDULED_REMINDER\",\n scheduledReminder: { ...newScheduledReminder, objectId: generateId() },\n });\n };\n\n const changeDay = (scheduledReminder, date) => {\n const curr = date.split('-').pop().replace(/^0/, '')\n dispatch({\n type: \"UPDATE_SCHEDULED_REMINDER\",\n scheduledReminder: { ...scheduledReminder, days_before_or_after: curr },\n });\n };\n\n const removeScheduledReminder = (scheduledReminder) => {\n // const scheduledReminders = state.scheduledReminders\n // remove a reminder if it does exist\n // toggle destroy a reminder if it does exist\n if (scheduledReminder.id === null) {\n const newScheduledReminders = state.scheduledReminders.filter(\n (dl) => dl.objectId != scheduledReminder.objectId\n );\n dispatch({ type: \"SET_SCHEDULED_REMINDERS\", scheduledReminders: newScheduledReminders });\n } else {\n\n const newScheduledReminders = state.scheduledReminders.map((dl) => {\n if (dl.objectId === scheduledReminder.objectId) {\n return { ...dl, destroy: true };\n } else {\n return { ...dl };\n }\n });\n dispatch({ type: \"SET_SCHEDULED_REMINDERS\", scheduledReminders: newScheduledReminders });\n }\n };\n\n return { state, dispatch, changeDay, addScheduledReminder, removeScheduledReminder };\n};\n\nconst ScheduledRemindersProvider = (props) => {\n // added the form state\n const scheduledReminders = props.scheduledReminders.map((sr) => {\n if (sr.id) {\n return { ...sr, objectId: sr.id };\n } else {\n return { ...sr, objectId: generateId() };\n }\n });\n\n const [state, dispatch] = useReducer(scheduledRemindersReducer, {\n ...initialState,\n fund: props.fund,\n disableAddRemove: props.disableAddRemove || false,\n scheduledReminders: scheduledReminders || [],\n scheduledRemindersStatuses: props.scheduledRemindersStatuses\n });\n\n const value = React.useMemo(() => [state, dispatch], [state]);\n\n return ;\n};\n\nconst ScheduledReminderFields = (props) => {\n const { removeScheduledReminder, changeDay, state } = useScheduledReminders();\n const { scheduledRemindersStatuses, disableAddRemove } = state;\n const { scheduledReminder, index } = props;\n const namePrefix = `fund[scheduled_reminders_attributes][${index}]`;\n\n const handleRemoveClick = (e) => {\n e.preventDefault();\n removeScheduledReminder(scheduledReminder);\n };\n\n return (\n <>\n {scheduledReminder.destroy ? (\n <>\n \n \n >\n ) : (\n <>\n {scheduledReminder.id ? (\n \n ) : (\n \"\"\n )}\n \n \n \n \n \n
\n
\n \n \n
\n
\n
\n\n
\n \n \n
\n\n
\n
\n\n
\n
\n
\n Number days before(if it is a reminder) or after(if it is an overdue notification) the due date reminder is sent\n
\n
\n
{ changeDay(scheduledReminder, day) }} />\n \n\n {/*
\n \n \n
*/}\n\n {disableAddRemove ? \"\" : (\n
\n
\n Note: The recurring schedule cannot be changed once saved.\n
\n\n
\n
\n )}\n
\n
\n >\n )}\n >\n );\n};\n\nconst ScheduledRemindersContainer = () => {\n const { state } = useScheduledReminders();\n return (\n <>\n {state.scheduledReminders.map((scheduledReminder, index) => {\n return (\n \n );\n })}\n >\n );\n};\n\nconst AddScheduledReminder = () => {\n const { addScheduledReminder } = useScheduledReminders();\n\n const handleClick = (e) => {\n e.preventDefault();\n addScheduledReminder();\n };\n\n return (\n <>\n \n \n \n >\n );\n};\n\nconst ScheduledRemindersForm = ({\n fund,\n disableAddRemove,\n scheduled_reminders: scheduledReminders,\n scheduled_reminders_statuses: scheduledRemindersStatuses,\n reminder_types: reminderTypes,\n}) => {\n\n return (\n <>\n \n \n
\n
\n Scheduled Reminders.\n
\n
\n Cusomize the Dates and times you would like to send reminders for your members to pay their dues.\n
\n
\n
\n {disableAddRemove ? \"\" :
}\n
\n
\n\n \n \n >\n );\n};\nexport default ScheduledRemindersForm;\n","import React from 'react';\nimport { ScheduledReportProvider, useFields, getTimeFromModel } from './State';\n\nexport default (props) => {\n const {\n model,\n modelName = 'scheduled_report',\n frequencyOptions,\n timezoneOptions,\n errors,\n } = props;\n\n return (\n \n \n
\n {!!model.id && (\n \n )}\n\n \n \n \n \n \n
\n
\n \n );\n};\n\nconst TimeField = () => {\n const { state, setTime } = useFields();\n const { model, modelName, hour, minute, ampm } = state;\n\n const onChangeTime = (e) => {\n const { name, value } = e.target;\n\n setTime(value, name);\n };\n\n return (\n \n
\n\n
\n
\n
\n \n :\n \n \n \n
\n
\n
\n );\n};\n\nconst FrequencyField = (props) => {\n const { state, setFrequency } = useFields();\n const { model, modelName } = state;\n const { frequencyOptions } = props;\n\n const onChangeFrequency = (e) => {\n const { value } = e.target;\n\n setFrequency(value);\n };\n\n return (\n \n
\n
\n \n
\n
\n );\n};\n\nconst DAYS = [\n 'Monday',\n 'Tuesday',\n 'Wednesday',\n 'Thursday',\n 'Friday',\n 'Saturday',\n 'Sunday',\n];\n\nconst DayField = () => {\n const { state, setDay } = useFields();\n const { model, modelName } = state;\n\n const onChangeDay = (e) => {\n const { value } = e.target;\n\n setDay(value);\n };\n\n if (state.frequency === 'daily') return null;\n\n return (\n \n
\n
\n \n
\n
\n );\n};\n\nconst TimezoneField = (props) => {\n const { state, setTimeZone } = useFields();\n const { model, modelName } = state;\n const { timezoneOptions } = props;\n\n const onChangeTimezone = (e) => {\n const { value } = e.target;\n\n setTimeZone(value);\n };\n\n return (\n \n
\n
\n \n
\n
\n );\n};\n\nconst EmailField = () => {\n const { state, setemail } = useFields();\n const { model, modelName, errors } = state;\n\n const onChangeEmail = (e) => {\n const { value } = e.target;\n\n setEmail(value);\n };\n\n return (\n \n
\n
\n \n
\n {!!errors.email && (\n
{errors.email}
\n )}\n
\n );\n};\n","import React from 'react';\nimport { CardElement } from '@stripe/react-stripe-js';\nimport { StripeFormProvider, useForm } from './StateManagement';\nimport FormInput from '../FormInput';\nimport { StripeSDKLoader } from '../../utils/StripeSdkLoader';\nimport { getCoupon } from '../../utils/requests';\n\nconst CARD_OPTIONS = {\n iconStyle: 'solid',\n style: {\n base: {\n color: '#303238',\n fontSize: '16px',\n fontFamily: '\"Rubik\", sans-serif',\n fontSmoothing: 'antialiased',\n '::placeholder': {\n color: '#6B6B6B',\n },\n },\n invalid: {\n color: '#e5424d',\n ':focus': {\n color: '#303238',\n },\n },\n },\n};\n\nconst FormFields = () => {\n const { state, updateModel } = useForm();\n const { model, loading, errors } = state;\n\n return (\n <>\n \n updateModel('email', e)}\n label=\"Email\"\n modelName=\"signup_form\"\n value={model.email}\n attribute=\"email\"\n type=\"text\"\n />\n
\n\n \n \n
\n\n \n \n
\n\n \n updateModel('name', e)}\n value={model.name}\n label=\"Organization Name\"\n modelName=\"signup_form\"\n attribute=\"name\"\n type=\"text\"\n />\n
\n\n \n updateModel('full_name', e)}\n value={model.full_name}\n label=\"Name On Card\"\n modelName=\"signup_form\"\n attribute=\"full_name\"\n type=\"text\"\n />\n
\n\n \n
\n
\n \n
\n {!!errors.card &&\n errors.card.map((e) => (\n
{e.message}
\n ))}\n
\n\n \n \n
\n >\n );\n};\n\nconst CouponField = (props) => {\n const { state, dispatch, updateModel } = useForm();\n const { model, couponLoading, errors } = state;\n\n const handleCoupon = async (e) => {\n e.preventDefault();\n\n dispatch({ type: 'TOGGLE_COUPON_LOADING' });\n try {\n const { data } = await getCoupon({ coupon: model.coupon });\n\n if (data.error || data.coupon.invalid) {\n // update state with coupon error...\n dispatch({\n type: 'SET_ERRORS',\n errors: { ...errors, coupon: ['Invalid coupon'] },\n });\n console.error(data.error);\n } else {\n dispatch({\n type: 'SET_APPLIED_COUPON',\n appliedCoupon: data.coupon,\n });\n updateModel('coupon_valid', true);\n\n // reset errors if the previous coupon attempt was invalid\n dispatch({\n type: 'SET_ERRORS',\n errors: { ...errors, coupon: [] },\n });\n }\n } catch (e) {\n console.error(e);\n } finally {\n dispatch({ type: 'TOGGLE_COUPON_LOADING' });\n }\n };\n\n const coupondDisabled =\n !model.coupon || model.coupon.trim().length < 1 || couponLoading;\n\n const disabledStyles = () => {\n return coupondDisabled ? 'opacity-75 cursor-not-allowed' : '';\n };\n\n return (\n <>\n \n updateModel('coupon', e)}\n value={model.coupon}\n label=\"Coupon Code\"\n modelName=\"signup_form\"\n attribute=\"coupon\"\n type=\"text\"\n />\n\n \n
\n\n \n >\n );\n};\n\nconst Form = () => {\n const { state, dispatch, stripe, elements } = useForm();\n const { model, loading, paymentMethod, error, appliedCoupon } = state;\n\n const formRef = React.useRef(null);\n\n const handleSignup = async (e) => {\n e.preventDefault();\n\n dispatch({ type: 'TOGGLE_LOADING' });\n if (!stripe || !elements) {\n // Stripe.js has not loaded yet. Make sure to disable\n // form submission until Stripe.js has loaded.\n dispatch({ type: 'TOGGLE_LOADING' });\n return;\n }\n\n // create a payment on stripe\n const result = await stripe.createPaymentMethod({\n type: 'card',\n card: elements.getElement(CardElement),\n billing_details: {\n name: `${model.full_name}`,\n email: model.email,\n },\n });\n\n if (!!result.error) {\n dispatch({ type: 'TOGGLE_LOADING' });\n dispatch({ type: 'SET_ERROR', error: result.error.message });\n } else {\n // update state with payment method id from createPaymentMethod\n dispatch({\n type: 'SET_PAYMENT_METHOD',\n paymentMethod: result.paymentMethod.id,\n });\n\n const form = formRef.current;\n const hiddenInput = document.createElement('input');\n hiddenInput.setAttribute('type', 'hidden');\n hiddenInput.setAttribute('name', 'signup_form[payment_method]');\n hiddenInput.setAttribute('value', result.paymentMethod.id);\n form.appendChild(hiddenInput);\n\n form.submit();\n }\n };\n\n const token = document.querySelector('[name=csrf-token]').content;\n\n return (\n \n
\n\n {!!loading && (\n
\n Processing card info...\n
\n )}\n
\n );\n};\n\nconst SignupForm = ({\n stripe_publishable_key = '',\n model = {},\n errors = {},\n}) => {\n return (\n \n \n \n \n \n );\n};\n\nexport default SignupForm;\n","import React from \"react\";\nimport { Input } from \"./FormInputs\";\nimport FormValuesFields from \"../FormValuesFields\";\nimport { COUNTRY_SELECT_OPTIONS } from \"../../utils/countrySelectOptions\";\nimport { StripeSDKLoader } from \"../../utils/StripeSdkLoader\";\nimport {\n CheckoutFormProvider,\n useCheckout,\n singleChargeSubmit,\n} from \"./StateManagement\";\nimport { PaymentMethodSection } from \"./PaymentComponents\";\nimport { ShippingOptionSection } from \"./ShippingComponents\";\nimport { OrderSummarySection } from \"./OrderSummaryComponents\";\n\nconst MainForm = () => {\n const { state, dispatch, stripe, elements, shippingEnabled } = useCheckout();\n const handleSubmit = async (event) => {\n event.preventDefault();\n singleChargeSubmit({ state, dispatch, stripe, elements });\n };\n\n const { loading } = state;\n \n // console.log(state);\n\n return (\n \n );\n};\n\nconst ShippingFields = ({ require_address_fields }) => {\n return (\n <>\n \n\n \n\n \n\n \n\n \n\n \n\n \n\n \n >\n );\n};\n\nconst BillingFields = ({ require_address_fields }) => {\n return (\n <>\n \n\n \n\n \n\n \n\n \n\n \n\n \n\n \n >\n );\n};\n\nconst StoreCheckoutForm = (props) => {\n const {\n stripe_publishable_key,\n organization,\n current_user,\n payment_methods,\n shipping_options,\n cart,\n fee_model,\n form_fields,\n form_select_options,\n } = props;\n\n return (\n \n \n \n \n \n );\n};\n\nexport default StoreCheckoutForm;\n","import React, { useState } from \"react\";\nimport DashboardAddCardProvider from \"./DashboardAddPaymentMethod\";\nimport axios from \"../../utils/requests\";\nimport { currencyFormat } from \"../../utils/formatters\";\n\nconst Index = (props) => {\n const { price, upcoming_invoice, redirect_url, payment_methods, stripe_publishable_key, customer, subscription_request_url, create_card_response_url } = props\n const defaultPaymentMethod = payment_methods.find(payment_method => payment_method.default == true)\n const [chosenCard, setChosenCard] = useState((defaultPaymentMethod ? defaultPaymentMethod : (payment_methods.length > 0 ? payment_methods[0] : null)))\n // const [chosenCard, setChosenCard] = useState(null)\n return (\n <>\n \n
\n
\n
\n
Product
\n \n
\n {price.product.name}: {currencyFormat(price.unit_amount / 100.0)} /{price.recurring.interval}\n
\n {upcoming_invoice != null ?\n <>\n
\n
Line Items
\n \n
\n {upcoming_invoice.lines.data.map((line, index) => {\n return (\n - \n
\n {line.description}\n
\n \n {currencyFormat(line.amount / 100.0)}\n \n \n )\n })\n\n }\n
\n
\n
Due Today
\n \n
\n
Your prorated charge today is \n {currencyFormat(upcoming_invoice.total / 100.0)}\n \n
\n \n >\n :\n <>\n >\n }\n
\n\n {/*\n
create card option even if there is cards
\n
pick the card to use
\n
add a submission so the subscription can be submitted
\n */}\n\n {payment_methods.length == 0 ?\n
\n :\n
\n }\n\n
\n
\n >\n )\n}\n\nconst MainForm = ({ stripe_publishable_key, subscription_request_url, redirect_url, create_card_response_url, chosenCard, setChosenCard, payment_methods, customer }) => {\n const [loading, setLoading] = useState(false)\n const [errors, setErrors] = useState(false)\n\n const handleSubmit = async (e) => {\n e.preventDefault()\n setLoading(true)\n try {\n const response = await axios.post(\n subscription_request_url, {\n payment_method_id: chosenCard.id,\n customer_id: customer.id\n });\n const data = await response.data\n\n if (response.status == 200) {\n window.location = redirect_url\n setLoading(false)\n }\n\n } catch (error) {\n setLoading(false)\n setErrors(error)\n }\n }\n\n return <>\n {chosenCard ?\n <>\n Payment method
\n \n
\n
{chosenCard.card.brand}
\n
\n
\n
\n
Ending with {chosenCard.card.last4}
\n
\n
Expires {chosenCard.card.exp_month}/{chosenCard.card.exp_year}
\n
\n
\n
\n
\n \n
\n
\n
\n \n\n
\n
\n >\n :\n <>\n \n >\n }\n >\n\n}\n\nconst ChoosePaymentMethod = ({ chosenCard, create_card_response_url, stripe_publishable_key, setChosenCard, payment_methods, customer }) => {\n\n const [showCreateCard, setShowCreateCard] = useState((payment_methods.length == 0) ? true : false)\n\n // still need to show the create card button if someone wants to add a new card\n\n return <>\n \n Choose Payment Method\n
\n still need to show the create card button if someone wants to add a new card\n {showCreateCard ? <>\n setShowCreateCard(false)}\n />\n\n >\n : <>\n {payment_methods.length > 0 ? <>\n \n {payment_methods.map(payment_method => (\n \n ))}\n
\n >\n :\n <>\n >}\n\n \n >}\n >\n}\n\nconst PaymentMethod = ({ payment_method, setChosenCard }) => {\n const isDefault = payment_method.default\n\n return <>\n setChosenCard(payment_method)} className=\"border-b border-gray-300 py-2 hover:bg-gray-200 cursor-pointer\">\n \n\n {/* create radio button that is selected */}\n
\n \n \n
\n\n
\n
\n
\n
**** **** **** {payment_method.card.last4}
\n Expires: {payment_method.card.exp_month}/{payment_method.card.exp_year}\n \n
\n
\n \n >\n}\n\nconst CardIcon = ({ brand, iconSize = \"h-8\" }) => {\n\n return \n {brand == \"visa\" &&\n
\n }\n {brand == \"mastercard\" &&\n
\n }\n {brand == \"amex\" &&\n
\n }\n {brand == \"discover\" &&\n
\n }\n
\n\n\n}\n\nexport default Index","var _excluded = [\"sitekey\", \"onChange\", \"theme\", \"type\", \"tabindex\", \"onExpired\", \"onErrored\", \"size\", \"stoken\", \"grecaptcha\", \"badge\", \"hl\", \"isolated\"];\nfunction _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n _setPrototypeOf(subClass, superClass);\n}\nfunction _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}\nimport * as React from \"react\";\nimport PropTypes from \"prop-types\";\nvar ReCAPTCHA = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(ReCAPTCHA, _React$Component);\n function ReCAPTCHA() {\n var _this;\n _this = _React$Component.call(this) || this;\n _this.handleExpired = _this.handleExpired.bind(_assertThisInitialized(_this));\n _this.handleErrored = _this.handleErrored.bind(_assertThisInitialized(_this));\n _this.handleChange = _this.handleChange.bind(_assertThisInitialized(_this));\n _this.handleRecaptchaRef = _this.handleRecaptchaRef.bind(_assertThisInitialized(_this));\n return _this;\n }\n var _proto = ReCAPTCHA.prototype;\n _proto.getCaptchaFunction = function getCaptchaFunction(fnName) {\n if (this.props.grecaptcha) {\n if (this.props.grecaptcha.enterprise) {\n return this.props.grecaptcha.enterprise[fnName];\n }\n return this.props.grecaptcha[fnName];\n }\n return null;\n };\n _proto.getValue = function getValue() {\n var getResponse = this.getCaptchaFunction(\"getResponse\");\n if (getResponse && this._widgetId !== undefined) {\n return getResponse(this._widgetId);\n }\n return null;\n };\n _proto.getWidgetId = function getWidgetId() {\n if (this.props.grecaptcha && this._widgetId !== undefined) {\n return this._widgetId;\n }\n return null;\n };\n _proto.execute = function execute() {\n var execute = this.getCaptchaFunction(\"execute\");\n if (execute && this._widgetId !== undefined) {\n return execute(this._widgetId);\n } else {\n this._executeRequested = true;\n }\n };\n _proto.executeAsync = function executeAsync() {\n var _this2 = this;\n return new Promise(function (resolve, reject) {\n _this2.executionResolve = resolve;\n _this2.executionReject = reject;\n _this2.execute();\n });\n };\n _proto.reset = function reset() {\n var resetter = this.getCaptchaFunction(\"reset\");\n if (resetter && this._widgetId !== undefined) {\n resetter(this._widgetId);\n }\n };\n _proto.forceReset = function forceReset() {\n var resetter = this.getCaptchaFunction(\"reset\");\n if (resetter) {\n resetter();\n }\n };\n _proto.handleExpired = function handleExpired() {\n if (this.props.onExpired) {\n this.props.onExpired();\n } else {\n this.handleChange(null);\n }\n };\n _proto.handleErrored = function handleErrored() {\n if (this.props.onErrored) {\n this.props.onErrored();\n }\n if (this.executionReject) {\n this.executionReject();\n delete this.executionResolve;\n delete this.executionReject;\n }\n };\n _proto.handleChange = function handleChange(token) {\n if (this.props.onChange) {\n this.props.onChange(token);\n }\n if (this.executionResolve) {\n this.executionResolve(token);\n delete this.executionReject;\n delete this.executionResolve;\n }\n };\n _proto.explicitRender = function explicitRender() {\n var render = this.getCaptchaFunction(\"render\");\n if (render && this._widgetId === undefined) {\n var wrapper = document.createElement(\"div\");\n this._widgetId = render(wrapper, {\n sitekey: this.props.sitekey,\n callback: this.handleChange,\n theme: this.props.theme,\n type: this.props.type,\n tabindex: this.props.tabindex,\n \"expired-callback\": this.handleExpired,\n \"error-callback\": this.handleErrored,\n size: this.props.size,\n stoken: this.props.stoken,\n hl: this.props.hl,\n badge: this.props.badge,\n isolated: this.props.isolated\n });\n this.captcha.appendChild(wrapper);\n }\n if (this._executeRequested && this.props.grecaptcha && this._widgetId !== undefined) {\n this._executeRequested = false;\n this.execute();\n }\n };\n _proto.componentDidMount = function componentDidMount() {\n this.explicitRender();\n };\n _proto.componentDidUpdate = function componentDidUpdate() {\n this.explicitRender();\n };\n _proto.handleRecaptchaRef = function handleRecaptchaRef(elem) {\n this.captcha = elem;\n };\n _proto.render = function render() {\n // consume properties owned by the reCATPCHA, pass the rest to the div so the user can style it.\n /* eslint-disable no-unused-vars */\n var _this$props = this.props,\n sitekey = _this$props.sitekey,\n onChange = _this$props.onChange,\n theme = _this$props.theme,\n type = _this$props.type,\n tabindex = _this$props.tabindex,\n onExpired = _this$props.onExpired,\n onErrored = _this$props.onErrored,\n size = _this$props.size,\n stoken = _this$props.stoken,\n grecaptcha = _this$props.grecaptcha,\n badge = _this$props.badge,\n hl = _this$props.hl,\n isolated = _this$props.isolated,\n childProps = _objectWithoutPropertiesLoose(_this$props, _excluded);\n /* eslint-enable no-unused-vars */\n return /*#__PURE__*/React.createElement(\"div\", _extends({}, childProps, {\n ref: this.handleRecaptchaRef\n }));\n };\n return ReCAPTCHA;\n}(React.Component);\nexport { ReCAPTCHA as default };\nReCAPTCHA.displayName = \"ReCAPTCHA\";\nReCAPTCHA.propTypes = {\n sitekey: PropTypes.string.isRequired,\n onChange: PropTypes.func,\n grecaptcha: PropTypes.object,\n theme: PropTypes.oneOf([\"dark\", \"light\"]),\n type: PropTypes.oneOf([\"image\", \"audio\"]),\n tabindex: PropTypes.number,\n onExpired: PropTypes.func,\n onErrored: PropTypes.func,\n size: PropTypes.oneOf([\"compact\", \"normal\", \"invisible\"]),\n stoken: PropTypes.string,\n hl: PropTypes.string,\n badge: PropTypes.oneOf([\"bottomright\", \"bottomleft\", \"inline\"]),\n isolated: PropTypes.bool\n};\nReCAPTCHA.defaultProps = {\n onChange: function onChange() {},\n theme: \"light\",\n type: \"image\",\n tabindex: 0,\n size: \"normal\",\n badge: \"bottomright\"\n};","function _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}\nimport { Component, createElement, forwardRef } from \"react\";\nimport PropTypes from \"prop-types\";\nimport hoistStatics from \"hoist-non-react-statics\";\nvar SCRIPT_MAP = {}; // A counter used to generate a unique id for each component that uses the function\n\nvar idCount = 0;\nexport default function makeAsyncScript(getScriptURL, options) {\n options = options || {};\n return function wrapWithAsyncScript(WrappedComponent) {\n var wrappedComponentName = WrappedComponent.displayName || WrappedComponent.name || \"Component\";\n var AsyncScriptLoader = /*#__PURE__*/\n function (_Component) {\n _inheritsLoose(AsyncScriptLoader, _Component);\n function AsyncScriptLoader(props, context) {\n var _this;\n _this = _Component.call(this, props, context) || this;\n _this.state = {};\n _this.__scriptURL = \"\";\n return _this;\n }\n var _proto = AsyncScriptLoader.prototype;\n _proto.asyncScriptLoaderGetScriptLoaderID = function asyncScriptLoaderGetScriptLoaderID() {\n if (!this.__scriptLoaderID) {\n this.__scriptLoaderID = \"async-script-loader-\" + idCount++;\n }\n return this.__scriptLoaderID;\n };\n _proto.setupScriptURL = function setupScriptURL() {\n this.__scriptURL = typeof getScriptURL === \"function\" ? getScriptURL() : getScriptURL;\n return this.__scriptURL;\n };\n _proto.asyncScriptLoaderHandleLoad = function asyncScriptLoaderHandleLoad(state) {\n var _this2 = this;\n\n // use reacts setState callback to fire props.asyncScriptOnLoad with new state/entry\n this.setState(state, function () {\n return _this2.props.asyncScriptOnLoad && _this2.props.asyncScriptOnLoad(_this2.state);\n });\n };\n _proto.asyncScriptLoaderTriggerOnScriptLoaded = function asyncScriptLoaderTriggerOnScriptLoaded() {\n var mapEntry = SCRIPT_MAP[this.__scriptURL];\n if (!mapEntry || !mapEntry.loaded) {\n throw new Error(\"Script is not loaded.\");\n }\n for (var obsKey in mapEntry.observers) {\n mapEntry.observers[obsKey](mapEntry);\n }\n delete window[options.callbackName];\n };\n _proto.componentDidMount = function componentDidMount() {\n var _this3 = this;\n var scriptURL = this.setupScriptURL();\n var key = this.asyncScriptLoaderGetScriptLoaderID();\n var _options = options,\n globalName = _options.globalName,\n callbackName = _options.callbackName,\n scriptId = _options.scriptId; // check if global object already attached to window\n\n if (globalName && typeof window[globalName] !== \"undefined\") {\n SCRIPT_MAP[scriptURL] = {\n loaded: true,\n observers: {}\n };\n } // check if script loading already\n\n if (SCRIPT_MAP[scriptURL]) {\n var entry = SCRIPT_MAP[scriptURL]; // if loaded or errored then \"finish\"\n\n if (entry && (entry.loaded || entry.errored)) {\n this.asyncScriptLoaderHandleLoad(entry);\n return;\n } // if still loading then callback to observer queue\n\n entry.observers[key] = function (entry) {\n return _this3.asyncScriptLoaderHandleLoad(entry);\n };\n return;\n }\n /*\n * hasn't started loading\n * start the \"magic\"\n * setup script to load and observers\n */\n\n var observers = {};\n observers[key] = function (entry) {\n return _this3.asyncScriptLoaderHandleLoad(entry);\n };\n SCRIPT_MAP[scriptURL] = {\n loaded: false,\n observers: observers\n };\n var script = document.createElement(\"script\");\n script.src = scriptURL;\n script.async = true;\n for (var attribute in options.attributes) {\n script.setAttribute(attribute, options.attributes[attribute]);\n }\n if (scriptId) {\n script.id = scriptId;\n }\n var callObserverFuncAndRemoveObserver = function callObserverFuncAndRemoveObserver(func) {\n if (SCRIPT_MAP[scriptURL]) {\n var mapEntry = SCRIPT_MAP[scriptURL];\n var observersMap = mapEntry.observers;\n for (var obsKey in observersMap) {\n if (func(observersMap[obsKey])) {\n delete observersMap[obsKey];\n }\n }\n }\n };\n if (callbackName && typeof window !== \"undefined\") {\n window[callbackName] = function () {\n return _this3.asyncScriptLoaderTriggerOnScriptLoaded();\n };\n }\n script.onload = function () {\n var mapEntry = SCRIPT_MAP[scriptURL];\n if (mapEntry) {\n mapEntry.loaded = true;\n callObserverFuncAndRemoveObserver(function (observer) {\n if (callbackName) {\n return false;\n }\n observer(mapEntry);\n return true;\n });\n }\n };\n script.onerror = function () {\n var mapEntry = SCRIPT_MAP[scriptURL];\n if (mapEntry) {\n mapEntry.errored = true;\n callObserverFuncAndRemoveObserver(function (observer) {\n observer(mapEntry);\n return true;\n });\n }\n };\n document.body.appendChild(script);\n };\n _proto.componentWillUnmount = function componentWillUnmount() {\n // Remove tag script\n var scriptURL = this.__scriptURL;\n if (options.removeOnUnmount === true) {\n var allScripts = document.getElementsByTagName(\"script\");\n for (var i = 0; i < allScripts.length; i += 1) {\n if (allScripts[i].src.indexOf(scriptURL) > -1) {\n if (allScripts[i].parentNode) {\n allScripts[i].parentNode.removeChild(allScripts[i]);\n }\n }\n }\n } // Clean the observer entry\n\n var mapEntry = SCRIPT_MAP[scriptURL];\n if (mapEntry) {\n delete mapEntry.observers[this.asyncScriptLoaderGetScriptLoaderID()];\n if (options.removeOnUnmount === true) {\n delete SCRIPT_MAP[scriptURL];\n }\n }\n };\n _proto.render = function render() {\n var globalName = options.globalName; // remove asyncScriptOnLoad from childProps\n\n var _this$props = this.props,\n asyncScriptOnLoad = _this$props.asyncScriptOnLoad,\n forwardedRef = _this$props.forwardedRef,\n childProps = _objectWithoutPropertiesLoose(_this$props, [\"asyncScriptOnLoad\", \"forwardedRef\"]); // eslint-disable-line no-unused-vars\n\n if (globalName && typeof window !== \"undefined\") {\n childProps[globalName] = typeof window[globalName] !== \"undefined\" ? window[globalName] : undefined;\n }\n childProps.ref = forwardedRef;\n return /*#__PURE__*/createElement(WrappedComponent, childProps);\n };\n return AsyncScriptLoader;\n }(Component); // Note the second param \"ref\" provided by React.forwardRef.\n // We can pass it along to AsyncScriptLoader as a regular prop, e.g. \"forwardedRef\"\n // And it can then be attached to the Component.\n\n var ForwardedComponent = /*#__PURE__*/forwardRef(function (props, ref) {\n return /*#__PURE__*/createElement(AsyncScriptLoader, _extends({}, props, {\n forwardedRef: ref\n }));\n });\n ForwardedComponent.displayName = \"AsyncScriptLoader(\" + wrappedComponentName + \")\";\n ForwardedComponent.propTypes = {\n asyncScriptOnLoad: PropTypes.func\n };\n return hoistStatics(ForwardedComponent, WrappedComponent);\n };\n}","import ReCAPTCHA from \"./recaptcha\";\nimport makeAsyncScriptLoader from \"react-async-script\";\nvar callbackName = \"onloadcallback\";\nvar globalName = \"grecaptcha\";\nfunction getOptions() {\n return typeof window !== \"undefined\" && window.recaptchaOptions || {};\n}\nfunction getURL() {\n var dynamicOptions = getOptions();\n var hostname = dynamicOptions.useRecaptchaNet ? \"recaptcha.net\" : \"www.google.com\";\n if (dynamicOptions.enterprise) {\n return \"https://\" + hostname + \"/recaptcha/enterprise.js?onload=\" + callbackName + \"&render=explicit\";\n }\n return \"https://\" + hostname + \"/recaptcha/api.js?onload=\" + callbackName + \"&render=explicit\";\n}\nexport default makeAsyncScriptLoader(getURL, {\n callbackName: callbackName,\n globalName: globalName,\n attributes: getOptions().nonce ? {\n nonce: getOptions().nonce\n } : {}\n})(ReCAPTCHA);","import RecaptchaWrapper from \"./recaptcha-wrapper\";\nimport ReCAPTCHA from \"./recaptcha\";\nexport default RecaptchaWrapper;\nexport { ReCAPTCHA };","import React from \"react\";\nimport { StripeFormProvider, useForm } from \"./StateManagement\";\nimport { COUNTRY_SELECT_OPTIONS } from \"../../utils/countrySelectOptions\";\nimport { ReceiptComponent } from \"./ReceiptPage\";\nimport { StripeSDKLoader } from \"../../utils/StripeSdkLoader\";\nimport { DuesForm } from \"./DuesForm\";\nimport { SingleChargeForm } from \"./SingleChargeForm\";\nimport { Input, SubmitBtn, CustomFormFields, BaseErrors } from \"./FormInputs\";\nimport { PaymentMethodSection } from \"./PaymentComponents\";\nimport ReCAPTCHA from \"react-google-recaptcha\";\n\nconst Form = () => {\n const { state, dispatch } = useForm();\n const { fund, feeModel, formSetting, recaptcha_site_key, recaptcha_enabled } = state;\n const recaptchaRef = React.createRef();\n\n let FormInstance = fund.fund_type === \"dues\" ? DuesForm : SingleChargeForm;\n\n let recaptchaChange = (value) => {\n dispatch({ type: \"UPDATE_RECAPTCHA\", recaptcha_response: value });\n }\n\n return (\n \n \n \n \n \n \n {feeModel.feeType != \"union_pays\" ? : \"\"}\n {recaptcha_enabled && (\n \n \n
\n )}\n \n \n \n );\n};\n\nconst AddressFields = () => {\n const { state } = useForm();\n const { formSetting } = state;\n\n if (!formSetting.include_address_fields) return null;\n\n return (\n <>\n \n \n \n \n \n \n >\n );\n};\n\nconst SaveBillingInfo = () => {\n const { state, toggleSaveBillingInfo } = useForm();\n const { autoPay, user, saveBillingInfo } = state;\n return (\n <>\n {user.id ? (\n \"\"\n ) : (\n <>\n {!!autoPay || (\n \n \n \n
\n )}\n {!saveBillingInfo || (\n \n )}\n >\n )}\n >\n );\n};\n\nconst Summary = () => {\n const { state } = useForm();\n const { chargeData, fund } = state;\n return (\n <>\n Summary
\n \n
\n Payment:{\" \"}\n {chargeData.amount > 0 ? `$` + chargeData.amount.toFixed(2) : \"\"}\n {fund.amount_currency != \"USD\" && ` ${fund.amount_currency}`}\n
\n
\n Processing Fee:{\" \"}\n {chargeData.amount > 0 ? `$` + chargeData.totalFee : \"\"}\n {fund.amount_currency != \"USD\" && ` ${fund.amount_currency}`}\n
\n
\n
\n \n Total: {chargeData.amount > 0 ? `$` + chargeData.total : \"\"}\n {fund.amount_currency != \"USD\" && ` ${fund.amount_currency}`}\n \n
\n
\n >\n );\n};\n\nconst LegalCopy = () => {\n const { autoPay } = useForm();\n return (\n <>\n \n >\n );\n};\n\nconst FormPage = () => {\n const {\n state: { completed },\n } = useForm();\n return completed ? : ;\n};\n\nconst StripeForm = (props) => {\n const stripe_publishable_key = props.stripe_publishable_key;\n return (\n \n \n \n \n \n );\n};\n\nexport default StripeForm;\n","import React, { useState } from 'react';\nimport { Player } from '@lottiefiles/react-lottie-player';\nimport { useInterval } from '../../utils/useInterval';\n\n\nexport default ({ invoicing_fund, member_count, due_date, reminders }) => {\n const invoicingFund = invoicing_fund;\n const [isUploadingMembers, setIsUploadingMembers] = useState(invoicingFund.uploading_members);\n const [memberCount, setMemberCount] = useState(member_count);\n\n useInterval(() => {\n if (isUploadingMembers) {\n fetch(`/dashboard/invoicing/${invoicingFund.id}.json`, {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json',\n 'X-CSRF-Token': document.querySelector('[name=csrf-token]').content,\n },\n })\n .then((response) => {\n if (response.ok) {\n return response.json();\n }\n throw new Error('Network response was not ok.');\n })\n .then((response) => {\n setIsUploadingMembers(response.uploading_members);\n setMemberCount(response.member_count)\n })\n .catch((error) => {\n // console.log(error.message));\n });\n }\n }, isUploadingMembers ? 1500 : null);\n\n return (\n \n
\n
\n {isUploadingMembers ? : }\n
\n
\n
\n )\n};\n\nconst StillUploading = () => {\n return (\n \n
\n
\n
\n Almost Finished\n
\n
Unionly is Currently Uploading your Members, should be just a few minutes
\n
(page will update when finished)
\n
\n
\n \n\n {/* display the schedule for due dates and reminder dates */}\n\n
\n )\n}\n\nconst FinalizeStep = ({ invoicingFund, memberCount, due_date, reminders }) => {\n return (\n <>\n \n
\n
\n Finished Uploading {memberCount} Members\n
\n
\n \n
Name: {invoicingFund.name}
\n
number of uploaded members: {memberCount}
\n
Schedule:
\n
The due date will be created on the {due_date} of every month.
\n
The members will be reminded to pay their dues:
\n
\n {reminders.map((reminder) => {\n return (\n - {reminder.days_before_or_after} day{reminder.days_before_or_after != 1 ? \"s\" : \"\"}\n {reminder.reminder_type == \"overdue\" ? \" after \" : \" before \"}\n the due day
\n )\n\n })}\n
\n
\n \n Activate\n \n >\n )\n}\n","import React, { useState, useEffect, useRef } from 'react';\n\nexport const useInterval = (callback, delay) => {\n const savedCallback = useRef();\n // Remember the latest callback.\n useEffect(() => {\n savedCallback.current = callback;\n }, [callback]);\n\n // Set up the interval.\n useEffect(() => {\n function tick() {\n savedCallback.current();\n }\n if (delay !== null) {\n let id = setInterval(tick, delay);\n return () => clearInterval(id);\n }\n }, [delay]);\n}","var _excluded = [\"title\", \"titleId\"];\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nimport * as React from \"react\";\nfunction CheckIcon(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n fill: \"none\",\n viewBox: \"0 0 24 24\",\n strokeWidth: 1.5,\n stroke: \"currentColor\",\n \"aria-hidden\": \"true\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n d: \"M4.5 12.75l6 6 9-13.5\"\n }));\n}\nvar ForwardRef = /*#__PURE__*/React.forwardRef(CheckIcon);\nexport default ForwardRef;","import React from 'react';\nimport Dropdown from './dropdown'\nimport { useRef, useState } from 'react'\nimport { Dialog, DialogPanel, DialogTitle, Transition, TransitionChild } from '@headlessui/react'\nimport { CheckIcon } from '@heroicons/react/24/outline'\n\nconst UpdateMembershipModal = (props) => {\n const { due_levels, fee_model, current_user, subscription } = props;\n const [open, setOpen] = useState(false)\n const [selectedDueLevel, setSelectedDueLevel] = useState(null)\n\n return (\n <>\n \n \n \n
\n >\n );\n};\n\n\n\nfunction Model({ isOpen, setOpen, due_levels, fee_model, currentUser, subscription, selectedDueLevel, setSelectedDueLevel }) {\n\n const cancelButtonRef = useRef(null)\n\n const handleClick = (e) => {\n e.preventDefault()\n }\n\n return (\n \n \n \n )\n}\n\n\nexport default UpdateMembershipModal;\n","export const ItemTypes = {\n FUND: 'FUND',\n};\n","export const ItemTypes = {\n PRODUCT: 'PRODUCT',\n};\n","import React from \"react\";\n\nexport const ProductHeading = ({ imageUrl, name, productType }) => {\n return (\n \n
\n {!!imageUrl ? (\n

\n ) : (\n
\n {name[0]}\n \n )}\n
\n\n
\n
\n {name}\n
\n \n SKU: {productType}\n \n \n
\n );\n};\n\nexport const ProductStats = ({\n transactionTotalDollarsHuman,\n transactionsCount,\n}) => {\n return (\n \n
\n
\n
\n \n {transactionTotalDollarsHuman} \n {\" \"}\n
\n raised\n
\n
\n
\n
\n
\n {transactionsCount}\n
\n \n {transactionsCount == 1 ? \"donation\" : \"donations\"}\n \n
\n
\n
\n );\n};\n\nexport const ProductStatus = ({ status, path }) => {\n const classNames = (status) => {\n switch (status) {\n case \"active\":\n return \" bg-green-100 text-green-800\";\n case \"inactive\":\n return \"bg-yellow-50 text-yellow-text\";\n case \"archived\":\n return \"bg-red-100 text-red-800\";\n default:\n return \" bg-green-100 text-green-800\";\n }\n };\n\n return (\n \n \n {status}\n \n
\n );\n};\n","import React, {\n useContext,\n createContext,\n useReducer,\n} from \"react\";\nimport { useStripe, useElements, CardElement } from '@stripe/react-stripe-js';\nimport { StripeSDKLoader } from \"../../utils/StripeSdkLoader\";\nimport axios from \"../../utils/requests\";\n\nconst AddCardContext = createContext(null);\n\nconst initialState = {\n showCard: true,\n loading: false,\n error: false\n}\n\nconst addCardReducer = (state, action) => {\n switch (action.type) {\n case \"TOGGLE_SHOW_CARD\":\n return { ...state, showCard: !state.showCard };\n case \"SET_LOADING\":\n return { ...state, loading: action.loading };\n case \"SET_ERROR\":\n return { ...state, error: action.error };\n default:\n return state;\n }\n};\n\nconst CARD_ELEMENT_OPTIONS = {\n hidePostalCode: false,\n iconStyle: 'solid',\n style: {\n base: {\n color: '#303238',\n fontSize: '16px',\n fontFamily: '\"Rubik\", sans-serif',\n fontSmoothing: 'antialiased',\n '::placeholder': {\n color: '#6B6B6B',\n },\n },\n invalid: {\n color: '#e5424d',\n ':focus': {\n color: '#303238',\n },\n },\n },\n};\n\nconst StripeForm = (props) => {\n const stripe = useStripe();\n const elements = useElements();\n\n const [state, dispatch] = useContext(AddCardContext);\n\n const handleSubmit = async (event) => {\n\n if (!stripe || !elements) {\n // Stripe.js has not yet loaded.\n // Make sure to disable form submission until Stripe.js has loaded.\n return;\n }\n dispatch({ type: \"SET_LOADING\", loading: true });\n\n const card = elements.getElement(CardElement);\n\n const { paymentMethod, error } = await stripe.createPaymentMethod({\n type: 'card',\n card: card,\n });\n\n if (error) {\n // Show error to your customer (for example, insufficient funds)\n dispatch({ type: \"SET_ERROR\", error: error.message });\n dispatch({ type: \"SET_LOADING\", loading: false });\n } else {\n // payment method created, now attach it to the customer.\n try {\n const response = await axios.post(\n state.create_card_response_url,\n {\n payment_method: paymentMethod\n }\n );\n\n window.location.reload();\n } catch (error) {\n dispatch({ type: \"SET_ERROR\", error: error.response.error });\n }\n\n dispatch({ type: \"SET_LOADING\", loading: false });\n\n // if (paymentMethod.status === 'succeeded') {\n // Show a success message to your customer\n // There's a risk of the customer closing the window before callback\n // execution. Set up a webhook or plugin to listen for the\n // payment_intent.succeeded event that handles any business critical\n // post-payment actions.\n // }\n }\n }\n\n // const updateAmount = (value) => {\n // dispatch({ type: \"TOGGLE_SHOW_CARD\" });\n // };\n\n return (\n <>\n \n
\n
\n\n
\n
\n
\n
\n >\n )\n}\n\nconst DashboardAddCardProvider = ({\n stripe_publishable_key,\n customer,\n cancelAction,\n create_card_response_url\n}) => {\n const [store, dispatch] = useReducer(addCardReducer, {\n ...initialState,\n create_card_response_url: create_card_response_url,\n customer: customer,\n cancelAction: cancelAction\n });\n\n const value = React.useMemo(() => [store, dispatch], [store]);\n return (\n \n \n \n \n \n )\n}\n\nexport default DashboardAddCardProvider","function t() {\n for (var _len = arguments.length, r = new Array(_len), _key = 0; _key < _len; _key++) {\n r[_key] = arguments[_key];\n }\n return Array.from(new Set(r.flatMap(function (n) {\n return typeof n == \"string\" ? n.split(\" \") : [];\n }))).filter(Boolean).join(\" \");\n}\nexport { t as classNames };","import t, { createContext as r, useContext as c } from \"react\";\nvar e = /*#__PURE__*/r(!1);\nfunction a() {\n return c(e);\n}\nfunction l(o) {\n return /*#__PURE__*/t.createElement(e.Provider, {\n value: o.force\n }, o.children);\n}\nexport { l as ForcePortalRoot, a as usePortalRoot };","// Used for the address country select field\nexport const COUNTRY_SELECT_OPTIONS = [\n { text: 'United States', value: 'US' },\n { text: 'Australia', value: 'AU' },\n { text: 'Austria', value: 'AT' },\n { text: 'Belgium', value: 'BE' },\n { text: 'Bulgaria', value: 'BG' },\n { text: 'Brazil ', value: 'BR' },\n { text: 'Canada', value: 'CA' },\n { text: 'Cyprus', value: 'CY' },\n { text: 'Czech Republic', value: 'CZ' },\n { text: 'Denmark', value: 'DK' },\n { text: 'Estonia', value: 'EE' },\n { text: 'Finland', value: 'FI' },\n { text: 'France', value: 'FR' },\n { text: 'Germany', value: 'DE' },\n { text: 'Greece', value: 'GR' },\n { text: 'Hong Kong', value: 'HK' },\n { text: 'India', value: 'IN' },\n { text: 'Ireland', value: 'IE' },\n { text: 'Italy', value: 'IT' },\n { text: 'Japan', value: 'JP' },\n { text: 'Latvia', value: 'LV' },\n { text: 'Lithuania', value: 'LT' },\n { text: 'Luxembourg', value: 'LU' },\n { text: 'Malaysia', value: 'MY' },\n { text: 'Malta', value: 'MT' },\n { text: 'Mexico ', value: 'MX' },\n { text: 'Netherlands', value: 'NL' },\n { text: 'New Zealand', value: 'NZ' },\n { text: 'Norway', value: 'NO' },\n { text: 'Poland', value: 'PL' },\n { text: 'Portugal', value: 'PT' },\n { text: 'Romania', value: 'RO' },\n { text: 'Singapore', value: 'SG' },\n { text: 'Slovakia', value: 'SK' },\n { text: 'Slovenia', value: 'SI' },\n { text: 'Spain', value: 'ES' },\n { text: 'Sweden', value: 'SE' },\n { text: 'Switzerland', value: 'CH' },\n { text: 'United Kingdom', value: 'GB' },\n];\n","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { useState as $AWxnT$useState, useRef as $AWxnT$useRef, useEffect as $AWxnT$useEffect, useMemo as $AWxnT$useMemo } from \"react\";\n\n/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */ // Portions of the code in this file are based on code from react.\n// Original licensing for the following can be found in the\n// NOTICE file in the root directory of this source tree.\n// See https://github.com/facebook/react/tree/cc7c1aece46a6b69b41958d731e0fd27c94bfc6c/packages/react-interactions\n\n// iOS fires onPointerEnter twice: once with pointerType=\"touch\" and again with pointerType=\"mouse\".\n// We want to ignore these emulated events so they do not trigger hover behavior.\n// See https://bugs.webkit.org/show_bug.cgi?id=214609.\nvar $6179b936705e76d3$var$globalIgnoreEmulatedMouseEvents = false;\nvar $6179b936705e76d3$var$hoverCount = 0;\nfunction $6179b936705e76d3$var$setGlobalIgnoreEmulatedMouseEvents() {\n $6179b936705e76d3$var$globalIgnoreEmulatedMouseEvents = true;\n // Clear globalIgnoreEmulatedMouseEvents after a short timeout. iOS fires onPointerEnter\n // with pointerType=\"mouse\" immediately after onPointerUp and before onFocus. On other\n // devices that don't have this quirk, we don't want to ignore a mouse hover sometime in\n // the distant future because a user previously touched the element.\n setTimeout(function () {\n $6179b936705e76d3$var$globalIgnoreEmulatedMouseEvents = false;\n }, 50);\n}\nfunction $6179b936705e76d3$var$handleGlobalPointerEvent(e) {\n if (e.pointerType === 'touch') $6179b936705e76d3$var$setGlobalIgnoreEmulatedMouseEvents();\n}\nfunction $6179b936705e76d3$var$setupGlobalTouchEvents() {\n if (typeof document === 'undefined') return;\n if (typeof PointerEvent !== 'undefined') document.addEventListener('pointerup', $6179b936705e76d3$var$handleGlobalPointerEvent);else document.addEventListener('touchend', $6179b936705e76d3$var$setGlobalIgnoreEmulatedMouseEvents);\n $6179b936705e76d3$var$hoverCount++;\n return function () {\n $6179b936705e76d3$var$hoverCount--;\n if ($6179b936705e76d3$var$hoverCount > 0) return;\n if (typeof PointerEvent !== 'undefined') document.removeEventListener('pointerup', $6179b936705e76d3$var$handleGlobalPointerEvent);else document.removeEventListener('touchend', $6179b936705e76d3$var$setGlobalIgnoreEmulatedMouseEvents);\n };\n}\nfunction $6179b936705e76d3$export$ae780daf29e6d456(props) {\n var onHoverStart = props.onHoverStart,\n onHoverChange = props.onHoverChange,\n onHoverEnd = props.onHoverEnd,\n isDisabled = props.isDisabled;\n var _ref = (0, $AWxnT$useState)(false),\n _ref2 = _slicedToArray(_ref, 2),\n isHovered = _ref2[0],\n setHovered = _ref2[1];\n var state = (0, $AWxnT$useRef)({\n isHovered: false,\n ignoreEmulatedMouseEvents: false,\n pointerType: '',\n target: null\n }).current;\n (0, $AWxnT$useEffect)($6179b936705e76d3$var$setupGlobalTouchEvents, []);\n var _ref3 = (0, $AWxnT$useMemo)(function () {\n var triggerHoverStart = function triggerHoverStart(event, pointerType) {\n state.pointerType = pointerType;\n if (isDisabled || pointerType === 'touch' || state.isHovered || !event.currentTarget.contains(event.target)) return;\n state.isHovered = true;\n var target = event.currentTarget;\n state.target = target;\n if (onHoverStart) onHoverStart({\n type: 'hoverstart',\n target: target,\n pointerType: pointerType\n });\n if (onHoverChange) onHoverChange(true);\n setHovered(true);\n };\n var triggerHoverEnd = function triggerHoverEnd(event, pointerType) {\n state.pointerType = '';\n state.target = null;\n if (pointerType === 'touch' || !state.isHovered) return;\n state.isHovered = false;\n var target = event.currentTarget;\n if (onHoverEnd) onHoverEnd({\n type: 'hoverend',\n target: target,\n pointerType: pointerType\n });\n if (onHoverChange) onHoverChange(false);\n setHovered(false);\n };\n var hoverProps = {};\n if (typeof PointerEvent !== 'undefined') {\n hoverProps.onPointerEnter = function (e) {\n if ($6179b936705e76d3$var$globalIgnoreEmulatedMouseEvents && e.pointerType === 'mouse') return;\n triggerHoverStart(e, e.pointerType);\n };\n hoverProps.onPointerLeave = function (e) {\n if (!isDisabled && e.currentTarget.contains(e.target)) triggerHoverEnd(e, e.pointerType);\n };\n } else {\n hoverProps.onTouchStart = function () {\n state.ignoreEmulatedMouseEvents = true;\n };\n hoverProps.onMouseEnter = function (e) {\n if (!state.ignoreEmulatedMouseEvents && !$6179b936705e76d3$var$globalIgnoreEmulatedMouseEvents) triggerHoverStart(e, 'mouse');\n state.ignoreEmulatedMouseEvents = false;\n };\n hoverProps.onMouseLeave = function (e) {\n if (!isDisabled && e.currentTarget.contains(e.target)) triggerHoverEnd(e, 'mouse');\n };\n }\n return {\n hoverProps: hoverProps,\n triggerHoverEnd: triggerHoverEnd\n };\n }, [onHoverStart, onHoverChange, onHoverEnd, isDisabled, state]),\n hoverProps = _ref3.hoverProps,\n triggerHoverEnd = _ref3.triggerHoverEnd;\n (0, $AWxnT$useEffect)(function () {\n // Call the triggerHoverEnd as soon as isDisabled changes to true\n // Safe to call triggerHoverEnd, it will early return if we aren't currently hovering\n if (isDisabled) triggerHoverEnd({\n currentTarget: state.target\n }, state.pointerType);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isDisabled]);\n return {\n hoverProps: hoverProps,\n isHovered: isHovered\n };\n}\nexport { $6179b936705e76d3$export$ae780daf29e6d456 as useHover };","/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */function $c87311424ea30a05$var$testUserAgent(re) {\n var _window_navigator_userAgentData;\n if (typeof window === 'undefined' || window.navigator == null) return false;\n return ((_window_navigator_userAgentData = window.navigator['userAgentData']) === null || _window_navigator_userAgentData === void 0 ? void 0 : _window_navigator_userAgentData.brands.some(function (brand) {\n return re.test(brand.brand);\n })) || re.test(window.navigator.userAgent);\n}\nfunction $c87311424ea30a05$var$testPlatform(re) {\n var _window_navigator_userAgentData;\n return typeof window !== 'undefined' && window.navigator != null ? re.test(((_window_navigator_userAgentData = window.navigator['userAgentData']) === null || _window_navigator_userAgentData === void 0 ? void 0 : _window_navigator_userAgentData.platform) || window.navigator.platform) : false;\n}\nfunction $c87311424ea30a05$var$cached(fn) {\n var res = null;\n return function () {\n if (res == null) res = fn();\n return res;\n };\n}\nvar $c87311424ea30a05$export$9ac100e40613ea10 = $c87311424ea30a05$var$cached(function () {\n return $c87311424ea30a05$var$testPlatform(/^Mac/i);\n});\nvar $c87311424ea30a05$export$186c6964ca17d99 = $c87311424ea30a05$var$cached(function () {\n return $c87311424ea30a05$var$testPlatform(/^iPhone/i);\n});\nvar $c87311424ea30a05$export$7bef049ce92e4224 = $c87311424ea30a05$var$cached(function () {\n return $c87311424ea30a05$var$testPlatform(/^iPad/i) ||\n // iPadOS 13 lies and says it's a Mac, but we can distinguish by detecting touch support.\n $c87311424ea30a05$export$9ac100e40613ea10() && navigator.maxTouchPoints > 1;\n});\nvar $c87311424ea30a05$export$fedb369cb70207f1 = $c87311424ea30a05$var$cached(function () {\n return $c87311424ea30a05$export$186c6964ca17d99() || $c87311424ea30a05$export$7bef049ce92e4224();\n});\nvar $c87311424ea30a05$export$e1865c3bedcd822b = $c87311424ea30a05$var$cached(function () {\n return $c87311424ea30a05$export$9ac100e40613ea10() || $c87311424ea30a05$export$fedb369cb70207f1();\n});\nvar $c87311424ea30a05$export$78551043582a6a98 = $c87311424ea30a05$var$cached(function () {\n return $c87311424ea30a05$var$testUserAgent(/AppleWebKit/i) && !$c87311424ea30a05$export$6446a186d09e379e();\n});\nvar $c87311424ea30a05$export$6446a186d09e379e = $c87311424ea30a05$var$cached(function () {\n return $c87311424ea30a05$var$testUserAgent(/Chrome/i);\n});\nvar $c87311424ea30a05$export$a11b0059900ceec8 = $c87311424ea30a05$var$cached(function () {\n return $c87311424ea30a05$var$testUserAgent(/Android/i);\n});\nvar $c87311424ea30a05$export$b7d78993b74f766d = $c87311424ea30a05$var$cached(function () {\n return $c87311424ea30a05$var$testUserAgent(/Firefox/i);\n});\nexport { $c87311424ea30a05$export$9ac100e40613ea10 as isMac, $c87311424ea30a05$export$186c6964ca17d99 as isIPhone, $c87311424ea30a05$export$7bef049ce92e4224 as isIPad, $c87311424ea30a05$export$fedb369cb70207f1 as isIOS, $c87311424ea30a05$export$e1865c3bedcd822b as isAppleDevice, $c87311424ea30a05$export$78551043582a6a98 as isWebKit, $c87311424ea30a05$export$6446a186d09e379e as isChrome, $c87311424ea30a05$export$a11b0059900ceec8 as isAndroid, $c87311424ea30a05$export$b7d78993b74f766d as isFirefox };","var $431fbd86ca7dc216$export$b204af158042fbac = function $431fbd86ca7dc216$export$b204af158042fbac(el) {\n var _el_ownerDocument;\n return (_el_ownerDocument = el === null || el === void 0 ? void 0 : el.ownerDocument) !== null && _el_ownerDocument !== void 0 ? _el_ownerDocument : document;\n};\nvar $431fbd86ca7dc216$export$f21a1ffae260145a = function $431fbd86ca7dc216$export$f21a1ffae260145a(el) {\n if (el && 'window' in el && el.window === el) return el;\n var doc = $431fbd86ca7dc216$export$b204af158042fbac(el);\n return doc.defaultView || window;\n};\nexport { $431fbd86ca7dc216$export$b204af158042fbac as getOwnerDocument, $431fbd86ca7dc216$export$f21a1ffae260145a as getOwnerWindow };","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport $670gB$react, { useContext as $670gB$useContext, useState as $670gB$useState, useMemo as $670gB$useMemo, useLayoutEffect as $670gB$useLayoutEffect, useRef as $670gB$useRef } from \"react\";\n\n/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */ // We must avoid a circular dependency with @react-aria/utils, and this useLayoutEffect is\n// guarded by a check that it only runs on the client side.\n// eslint-disable-next-line rulesdir/useLayoutEffectRule\n\n// Default context value to use in case there is no SSRProvider. This is fine for\n// client-only apps. In order to support multiple copies of React Aria potentially\n// being on the page at once, the prefix is set to a random number. SSRProvider\n// will reset this to zero for consistency between server and client, so in the\n// SSR case multiple copies of React Aria is not supported.\nvar $b5e257d569688ac6$var$defaultContext = {\n prefix: String(Math.round(Math.random() * 10000000000)),\n current: 0\n};\nvar $b5e257d569688ac6$var$SSRContext = /*#__PURE__*/(0, $670gB$react).createContext($b5e257d569688ac6$var$defaultContext);\nvar $b5e257d569688ac6$var$IsSSRContext = /*#__PURE__*/(0, $670gB$react).createContext(false);\n// This is only used in React < 18.\nfunction $b5e257d569688ac6$var$LegacySSRProvider(props) {\n var cur = (0, $670gB$useContext)($b5e257d569688ac6$var$SSRContext);\n var counter = $b5e257d569688ac6$var$useCounter(cur === $b5e257d569688ac6$var$defaultContext);\n var _ref = (0, $670gB$useState)(true),\n _ref2 = _slicedToArray(_ref, 2),\n isSSR = _ref2[0],\n setIsSSR = _ref2[1];\n var value = (0, $670gB$useMemo)(function () {\n return {\n // If this is the first SSRProvider, start with an empty string prefix, otherwise\n // append and increment the counter.\n prefix: cur === $b5e257d569688ac6$var$defaultContext ? '' : \"\".concat(cur.prefix, \"-\").concat(counter),\n current: 0\n };\n }, [cur, counter]);\n // If on the client, and the component was initially server rendered,\n // then schedule a layout effect to update the component after hydration.\n if (typeof document !== 'undefined')\n // This if statement technically breaks the rules of hooks, but is safe\n // because the condition never changes after mounting.\n // eslint-disable-next-line react-hooks/rules-of-hooks\n (0, $670gB$useLayoutEffect)(function () {\n setIsSSR(false);\n }, []);\n return /*#__PURE__*/(0, $670gB$react).createElement($b5e257d569688ac6$var$SSRContext.Provider, {\n value: value\n }, /*#__PURE__*/(0, $670gB$react).createElement($b5e257d569688ac6$var$IsSSRContext.Provider, {\n value: isSSR\n }, props.children));\n}\nvar $b5e257d569688ac6$var$warnedAboutSSRProvider = false;\nfunction $b5e257d569688ac6$export$9f8ac96af4b1b2ae(props) {\n if (typeof (0, $670gB$react)['useId'] === 'function') {\n if (process.env.NODE_ENV !== 'test' && !$b5e257d569688ac6$var$warnedAboutSSRProvider) {\n console.warn('In React 18, SSRProvider is not necessary and is a noop. You can remove it from your app.');\n $b5e257d569688ac6$var$warnedAboutSSRProvider = true;\n }\n return /*#__PURE__*/(0, $670gB$react).createElement((0, $670gB$react).Fragment, null, props.children);\n }\n return /*#__PURE__*/(0, $670gB$react).createElement($b5e257d569688ac6$var$LegacySSRProvider, props);\n}\nvar $b5e257d569688ac6$var$canUseDOM = Boolean(typeof window !== 'undefined' && window.document && window.document.createElement);\nvar $b5e257d569688ac6$var$componentIds = new WeakMap();\nfunction $b5e257d569688ac6$var$useCounter() {\n var isDisabled = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n var ctx = (0, $670gB$useContext)($b5e257d569688ac6$var$SSRContext);\n var ref = (0, $670gB$useRef)(null);\n // eslint-disable-next-line rulesdir/pure-render\n if (ref.current === null && !isDisabled) {\n var _React___SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED_ReactCurrentOwner, _React___SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;\n // In strict mode, React renders components twice, and the ref will be reset to null on the second render.\n // This means our id counter will be incremented twice instead of once. This is a problem because on the\n // server, components are only rendered once and so ids generated on the server won't match the client.\n // In React 18, useId was introduced to solve this, but it is not available in older versions. So to solve this\n // we need to use some React internals to access the underlying Fiber instance, which is stable between renders.\n // This is exposed as ReactCurrentOwner in development, which is all we need since StrictMode only runs in development.\n // To ensure that we only increment the global counter once, we store the starting id for this component in\n // a weak map associated with the Fiber. On the second render, we reset the global counter to this value.\n // Since React runs the second render immediately after the first, this is safe.\n // @ts-ignore\n var currentOwner = (_React___SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED = (0, $670gB$react).__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED) === null || _React___SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED === void 0 ? void 0 : (_React___SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED_ReactCurrentOwner = _React___SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner) === null || _React___SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED_ReactCurrentOwner === void 0 ? void 0 : _React___SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED_ReactCurrentOwner.current;\n if (currentOwner) {\n var prevComponentValue = $b5e257d569688ac6$var$componentIds.get(currentOwner);\n if (prevComponentValue == null)\n // On the first render, and first call to useId, store the id and state in our weak map.\n $b5e257d569688ac6$var$componentIds.set(currentOwner, {\n id: ctx.current,\n state: currentOwner.memoizedState\n });else if (currentOwner.memoizedState !== prevComponentValue.state) {\n // On the second render, the memoizedState gets reset by React.\n // Reset the counter, and remove from the weak map so we don't\n // do this for subsequent useId calls.\n ctx.current = prevComponentValue.id;\n $b5e257d569688ac6$var$componentIds.delete(currentOwner);\n }\n }\n // eslint-disable-next-line rulesdir/pure-render\n ref.current = ++ctx.current;\n }\n // eslint-disable-next-line rulesdir/pure-render\n return ref.current;\n}\nfunction $b5e257d569688ac6$var$useLegacySSRSafeId(defaultId) {\n var ctx = (0, $670gB$useContext)($b5e257d569688ac6$var$SSRContext);\n // If we are rendering in a non-DOM environment, and there's no SSRProvider,\n // provide a warning to hint to the developer to add one.\n if (ctx === $b5e257d569688ac6$var$defaultContext && !$b5e257d569688ac6$var$canUseDOM) console.warn('When server rendering, you must wrap your application in an to ensure consistent ids are generated between the client and server.');\n var counter = $b5e257d569688ac6$var$useCounter(!!defaultId);\n var prefix = ctx === $b5e257d569688ac6$var$defaultContext && process.env.NODE_ENV === 'test' ? 'react-aria' : \"react-aria\".concat(ctx.prefix);\n return defaultId || \"\".concat(prefix, \"-\").concat(counter);\n}\nfunction $b5e257d569688ac6$var$useModernSSRSafeId(defaultId) {\n // @ts-ignore\n var id = (0, $670gB$react).useId();\n var _ref3 = (0, $670gB$useState)($b5e257d569688ac6$export$535bd6ca7f90a273()),\n _ref4 = _slicedToArray(_ref3, 1),\n didSSR = _ref4[0];\n var prefix = didSSR || process.env.NODE_ENV === 'test' ? 'react-aria' : \"react-aria\".concat($b5e257d569688ac6$var$defaultContext.prefix);\n return defaultId || \"\".concat(prefix, \"-\").concat(id);\n}\nvar $b5e257d569688ac6$export$619500959fc48b26 = typeof (0, $670gB$react)['useId'] === 'function' ? $b5e257d569688ac6$var$useModernSSRSafeId : $b5e257d569688ac6$var$useLegacySSRSafeId;\nfunction $b5e257d569688ac6$var$getSnapshot() {\n return false;\n}\nfunction $b5e257d569688ac6$var$getServerSnapshot() {\n return true;\n}\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nfunction $b5e257d569688ac6$var$subscribe(onStoreChange) {\n // noop\n return function () {};\n}\nfunction $b5e257d569688ac6$export$535bd6ca7f90a273() {\n // In React 18, we can use useSyncExternalStore to detect if we're server rendering or hydrating.\n if (typeof (0, $670gB$react)['useSyncExternalStore'] === 'function') return (0, $670gB$react)['useSyncExternalStore']($b5e257d569688ac6$var$subscribe, $b5e257d569688ac6$var$getSnapshot, $b5e257d569688ac6$var$getServerSnapshot);\n // eslint-disable-next-line react-hooks/rules-of-hooks\n return (0, $670gB$useContext)($b5e257d569688ac6$var$IsSSRContext);\n}\nexport { $b5e257d569688ac6$export$9f8ac96af4b1b2ae as SSRProvider, $b5e257d569688ac6$export$535bd6ca7f90a273 as useIsSSR, $b5e257d569688ac6$export$619500959fc48b26 as useSSRSafeId };","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nfunction _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nimport { isMac as $28AnR$isMac, isVirtualClick as $28AnR$isVirtualClick, getOwnerWindow as $28AnR$getOwnerWindow, getOwnerDocument as $28AnR$getOwnerDocument } from \"@react-aria/utils\";\nimport { useState as $28AnR$useState, useEffect as $28AnR$useEffect } from \"react\";\nimport { useIsSSR as $28AnR$useIsSSR } from \"@react-aria/ssr\";\n\n/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */ // Portions of the code in this file are based on code from react.\n// Original licensing for the following can be found in the\n// NOTICE file in the root directory of this source tree.\n// See https://github.com/facebook/react/tree/cc7c1aece46a6b69b41958d731e0fd27c94bfc6c/packages/react-interactions\n\nvar $507fabe10e71c6fb$var$currentModality = null;\nvar $507fabe10e71c6fb$var$changeHandlers = new Set();\nvar $507fabe10e71c6fb$export$d90243b58daecda7 = new Map(); // We use a map here to support setting event listeners across multiple document objects.\nvar $507fabe10e71c6fb$var$hasEventBeforeFocus = false;\nvar $507fabe10e71c6fb$var$hasBlurredWindowRecently = false;\n// Only Tab or Esc keys will make focus visible on text input elements\nvar $507fabe10e71c6fb$var$FOCUS_VISIBLE_INPUT_KEYS = {\n Tab: true,\n Escape: true\n};\nfunction $507fabe10e71c6fb$var$triggerChangeHandlers(modality, e) {\n var _iterator = _createForOfIteratorHelper($507fabe10e71c6fb$var$changeHandlers),\n _step;\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var handler = _step.value;\n handler(modality, e);\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n}\n/**\n * Helper function to determine if a KeyboardEvent is unmodified and could make keyboard focus styles visible.\n */\nfunction $507fabe10e71c6fb$var$isValidKey(e) {\n // Control and Shift keys trigger when navigating back to the tab with keyboard.\n return !(e.metaKey || !(0, $28AnR$isMac)() && e.altKey || e.ctrlKey || e.key === 'Control' || e.key === 'Shift' || e.key === 'Meta');\n}\nfunction $507fabe10e71c6fb$var$handleKeyboardEvent(e) {\n $507fabe10e71c6fb$var$hasEventBeforeFocus = true;\n if ($507fabe10e71c6fb$var$isValidKey(e)) {\n $507fabe10e71c6fb$var$currentModality = 'keyboard';\n $507fabe10e71c6fb$var$triggerChangeHandlers('keyboard', e);\n }\n}\nfunction $507fabe10e71c6fb$var$handlePointerEvent(e) {\n $507fabe10e71c6fb$var$currentModality = 'pointer';\n if (e.type === 'mousedown' || e.type === 'pointerdown') {\n $507fabe10e71c6fb$var$hasEventBeforeFocus = true;\n $507fabe10e71c6fb$var$triggerChangeHandlers('pointer', e);\n }\n}\nfunction $507fabe10e71c6fb$var$handleClickEvent(e) {\n if ((0, $28AnR$isVirtualClick)(e)) {\n $507fabe10e71c6fb$var$hasEventBeforeFocus = true;\n $507fabe10e71c6fb$var$currentModality = 'virtual';\n }\n}\nfunction $507fabe10e71c6fb$var$handleFocusEvent(e) {\n // Firefox fires two extra focus events when the user first clicks into an iframe:\n // first on the window, then on the document. We ignore these events so they don't\n // cause keyboard focus rings to appear.\n if (e.target === window || e.target === document) return;\n // If a focus event occurs without a preceding keyboard or pointer event, switch to virtual modality.\n // This occurs, for example, when navigating a form with the next/previous buttons on iOS.\n if (!$507fabe10e71c6fb$var$hasEventBeforeFocus && !$507fabe10e71c6fb$var$hasBlurredWindowRecently) {\n $507fabe10e71c6fb$var$currentModality = 'virtual';\n $507fabe10e71c6fb$var$triggerChangeHandlers('virtual', e);\n }\n $507fabe10e71c6fb$var$hasEventBeforeFocus = false;\n $507fabe10e71c6fb$var$hasBlurredWindowRecently = false;\n}\nfunction $507fabe10e71c6fb$var$handleWindowBlur() {\n // When the window is blurred, reset state. This is necessary when tabbing out of the window,\n // for example, since a subsequent focus event won't be fired.\n $507fabe10e71c6fb$var$hasEventBeforeFocus = false;\n $507fabe10e71c6fb$var$hasBlurredWindowRecently = true;\n}\n/**\n * Setup global event listeners to control when keyboard focus style should be visible.\n */\nfunction $507fabe10e71c6fb$var$setupGlobalFocusEvents(element) {\n if (typeof window === 'undefined' || $507fabe10e71c6fb$export$d90243b58daecda7.get((0, $28AnR$getOwnerWindow)(element))) return;\n var windowObject = (0, $28AnR$getOwnerWindow)(element);\n var documentObject = (0, $28AnR$getOwnerDocument)(element);\n // Programmatic focus() calls shouldn't affect the current input modality.\n // However, we need to detect other cases when a focus event occurs without\n // a preceding user event (e.g. screen reader focus). Overriding the focus\n // method on HTMLElement.prototype is a bit hacky, but works.\n var focus = windowObject.HTMLElement.prototype.focus;\n windowObject.HTMLElement.prototype.focus = function () {\n $507fabe10e71c6fb$var$hasEventBeforeFocus = true;\n focus.apply(this, arguments);\n };\n documentObject.addEventListener('keydown', $507fabe10e71c6fb$var$handleKeyboardEvent, true);\n documentObject.addEventListener('keyup', $507fabe10e71c6fb$var$handleKeyboardEvent, true);\n documentObject.addEventListener('click', $507fabe10e71c6fb$var$handleClickEvent, true);\n // Register focus events on the window so they are sure to happen\n // before React's event listeners (registered on the document).\n windowObject.addEventListener('focus', $507fabe10e71c6fb$var$handleFocusEvent, true);\n windowObject.addEventListener('blur', $507fabe10e71c6fb$var$handleWindowBlur, false);\n if (typeof PointerEvent !== 'undefined') {\n documentObject.addEventListener('pointerdown', $507fabe10e71c6fb$var$handlePointerEvent, true);\n documentObject.addEventListener('pointermove', $507fabe10e71c6fb$var$handlePointerEvent, true);\n documentObject.addEventListener('pointerup', $507fabe10e71c6fb$var$handlePointerEvent, true);\n } else {\n documentObject.addEventListener('mousedown', $507fabe10e71c6fb$var$handlePointerEvent, true);\n documentObject.addEventListener('mousemove', $507fabe10e71c6fb$var$handlePointerEvent, true);\n documentObject.addEventListener('mouseup', $507fabe10e71c6fb$var$handlePointerEvent, true);\n }\n // Add unmount handler\n windowObject.addEventListener('beforeunload', function () {\n $507fabe10e71c6fb$var$tearDownWindowFocusTracking(element);\n }, {\n once: true\n });\n $507fabe10e71c6fb$export$d90243b58daecda7.set(windowObject, {\n focus: focus\n });\n}\nvar $507fabe10e71c6fb$var$tearDownWindowFocusTracking = function $507fabe10e71c6fb$var$tearDownWindowFocusTracking(element, loadListener) {\n var windowObject = (0, $28AnR$getOwnerWindow)(element);\n var documentObject = (0, $28AnR$getOwnerDocument)(element);\n if (loadListener) documentObject.removeEventListener('DOMContentLoaded', loadListener);\n if (!$507fabe10e71c6fb$export$d90243b58daecda7.has(windowObject)) return;\n windowObject.HTMLElement.prototype.focus = $507fabe10e71c6fb$export$d90243b58daecda7.get(windowObject).focus;\n documentObject.removeEventListener('keydown', $507fabe10e71c6fb$var$handleKeyboardEvent, true);\n documentObject.removeEventListener('keyup', $507fabe10e71c6fb$var$handleKeyboardEvent, true);\n documentObject.removeEventListener('click', $507fabe10e71c6fb$var$handleClickEvent, true);\n windowObject.removeEventListener('focus', $507fabe10e71c6fb$var$handleFocusEvent, true);\n windowObject.removeEventListener('blur', $507fabe10e71c6fb$var$handleWindowBlur, false);\n if (typeof PointerEvent !== 'undefined') {\n documentObject.removeEventListener('pointerdown', $507fabe10e71c6fb$var$handlePointerEvent, true);\n documentObject.removeEventListener('pointermove', $507fabe10e71c6fb$var$handlePointerEvent, true);\n documentObject.removeEventListener('pointerup', $507fabe10e71c6fb$var$handlePointerEvent, true);\n } else {\n documentObject.removeEventListener('mousedown', $507fabe10e71c6fb$var$handlePointerEvent, true);\n documentObject.removeEventListener('mousemove', $507fabe10e71c6fb$var$handlePointerEvent, true);\n documentObject.removeEventListener('mouseup', $507fabe10e71c6fb$var$handlePointerEvent, true);\n }\n $507fabe10e71c6fb$export$d90243b58daecda7.delete(windowObject);\n};\nfunction $507fabe10e71c6fb$export$2f1888112f558a7d(element) {\n var documentObject = (0, $28AnR$getOwnerDocument)(element);\n var loadListener;\n if (documentObject.readyState !== 'loading') $507fabe10e71c6fb$var$setupGlobalFocusEvents(element);else {\n loadListener = function loadListener() {\n $507fabe10e71c6fb$var$setupGlobalFocusEvents(element);\n };\n documentObject.addEventListener('DOMContentLoaded', loadListener);\n }\n return function () {\n return $507fabe10e71c6fb$var$tearDownWindowFocusTracking(element, loadListener);\n };\n}\n// Server-side rendering does not have the document object defined\n// eslint-disable-next-line no-restricted-globals\nif (typeof document !== 'undefined') $507fabe10e71c6fb$export$2f1888112f558a7d();\nfunction $507fabe10e71c6fb$export$b9b3dfddab17db27() {\n return $507fabe10e71c6fb$var$currentModality !== 'pointer';\n}\nfunction $507fabe10e71c6fb$export$630ff653c5ada6a9() {\n return $507fabe10e71c6fb$var$currentModality;\n}\nfunction $507fabe10e71c6fb$export$8397ddfc504fdb9a(modality) {\n $507fabe10e71c6fb$var$currentModality = modality;\n $507fabe10e71c6fb$var$triggerChangeHandlers(modality, null);\n}\nfunction $507fabe10e71c6fb$export$98e20ec92f614cfe() {\n $507fabe10e71c6fb$var$setupGlobalFocusEvents();\n var _ref = (0, $28AnR$useState)($507fabe10e71c6fb$var$currentModality),\n _ref2 = _slicedToArray(_ref, 2),\n modality = _ref2[0],\n setModality = _ref2[1];\n (0, $28AnR$useEffect)(function () {\n var handler = function handler() {\n setModality($507fabe10e71c6fb$var$currentModality);\n };\n $507fabe10e71c6fb$var$changeHandlers.add(handler);\n return function () {\n $507fabe10e71c6fb$var$changeHandlers.delete(handler);\n };\n }, []);\n return (0, $28AnR$useIsSSR)() ? null : modality;\n}\nvar $507fabe10e71c6fb$var$nonTextInputTypes = new Set(['checkbox', 'radio', 'range', 'color', 'file', 'image', 'button', 'submit', 'reset']);\n/**\n * If this is attached to text input component, return if the event is a focus event (Tab/Escape keys pressed) so that\n * focus visible style can be properly set.\n */\nfunction $507fabe10e71c6fb$var$isKeyboardFocusEvent(isTextInput, modality, e) {\n var _e_target;\n var IHTMLInputElement = typeof window !== 'undefined' ? (0, $28AnR$getOwnerWindow)(e === null || e === void 0 ? void 0 : e.target).HTMLInputElement : HTMLInputElement;\n var IHTMLTextAreaElement = typeof window !== 'undefined' ? (0, $28AnR$getOwnerWindow)(e === null || e === void 0 ? void 0 : e.target).HTMLTextAreaElement : HTMLTextAreaElement;\n var IHTMLElement = typeof window !== 'undefined' ? (0, $28AnR$getOwnerWindow)(e === null || e === void 0 ? void 0 : e.target).HTMLElement : HTMLElement;\n var IKeyboardEvent = typeof window !== 'undefined' ? (0, $28AnR$getOwnerWindow)(e === null || e === void 0 ? void 0 : e.target).KeyboardEvent : KeyboardEvent;\n isTextInput = isTextInput || (e === null || e === void 0 ? void 0 : e.target) instanceof IHTMLInputElement && !$507fabe10e71c6fb$var$nonTextInputTypes.has(e === null || e === void 0 ? void 0 : (_e_target = e.target) === null || _e_target === void 0 ? void 0 : _e_target.type) || (e === null || e === void 0 ? void 0 : e.target) instanceof IHTMLTextAreaElement || (e === null || e === void 0 ? void 0 : e.target) instanceof IHTMLElement && (e === null || e === void 0 ? void 0 : e.target.isContentEditable);\n return !(isTextInput && modality === 'keyboard' && e instanceof IKeyboardEvent && !$507fabe10e71c6fb$var$FOCUS_VISIBLE_INPUT_KEYS[e.key]);\n}\nfunction $507fabe10e71c6fb$export$ffd9e5021c1fb2d6() {\n var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var isTextInput = props.isTextInput,\n autoFocus = props.autoFocus;\n var _ref3 = (0, $28AnR$useState)(autoFocus || $507fabe10e71c6fb$export$b9b3dfddab17db27()),\n _ref4 = _slicedToArray(_ref3, 2),\n isFocusVisibleState = _ref4[0],\n setFocusVisible = _ref4[1];\n $507fabe10e71c6fb$export$ec71b4b83ac08ec3(function (isFocusVisible) {\n setFocusVisible(isFocusVisible);\n }, [isTextInput], {\n isTextInput: isTextInput\n });\n return {\n isFocusVisible: isFocusVisibleState\n };\n}\nfunction $507fabe10e71c6fb$export$ec71b4b83ac08ec3(fn, deps, opts) {\n $507fabe10e71c6fb$var$setupGlobalFocusEvents();\n (0, $28AnR$useEffect)(function () {\n var handler = function handler(modality, e) {\n if (!$507fabe10e71c6fb$var$isKeyboardFocusEvent(!!(opts === null || opts === void 0 ? void 0 : opts.isTextInput), modality, e)) return;\n fn($507fabe10e71c6fb$export$b9b3dfddab17db27());\n };\n $507fabe10e71c6fb$var$changeHandlers.add(handler);\n return function () {\n $507fabe10e71c6fb$var$changeHandlers.delete(handler);\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, deps);\n}\nexport { $507fabe10e71c6fb$export$d90243b58daecda7 as hasSetupGlobalListeners, $507fabe10e71c6fb$export$2f1888112f558a7d as addWindowFocusTracking, $507fabe10e71c6fb$export$b9b3dfddab17db27 as isFocusVisible, $507fabe10e71c6fb$export$630ff653c5ada6a9 as getInteractionModality, $507fabe10e71c6fb$export$8397ddfc504fdb9a as setInteractionModality, $507fabe10e71c6fb$export$98e20ec92f614cfe as useInteractionModality, $507fabe10e71c6fb$export$ffd9e5021c1fb2d6 as useFocusVisible, $507fabe10e71c6fb$export$ec71b4b83ac08ec3 as useFocusVisibleListener };","import { isAndroid as $c87311424ea30a05$export$a11b0059900ceec8 } from \"./platform.module.js\";\n\n/*\n * Copyright 2022 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\nfunction $6a7db85432448f7f$export$60278871457622de(event) {\n // JAWS/NVDA with Firefox.\n if (event.mozInputSource === 0 && event.isTrusted) return true;\n // Android TalkBack's detail value varies depending on the event listener providing the event so we have specific logic here instead\n // If pointerType is defined, event is from a click listener. For events from mousedown listener, detail === 0 is a sufficient check\n // to detect TalkBack virtual clicks.\n if ((0, $c87311424ea30a05$export$a11b0059900ceec8)() && event.pointerType) return event.type === 'click' && event.buttons === 1;\n return event.detail === 0 && !event.pointerType;\n}\nfunction $6a7db85432448f7f$export$29bf1b5f2c56cf63(event) {\n // If the pointer size is zero, then we assume it's from a screen reader.\n // Android TalkBack double tap will sometimes return a event with width and height of 1\n // and pointerType === 'mouse' so we need to check for a specific combination of event attributes.\n // Cannot use \"event.pressure === 0\" as the sole check due to Safari pointer events always returning pressure === 0\n // instead of .5, see https://bugs.webkit.org/show_bug.cgi?id=206216. event.pointerType === 'mouse' is to distingush\n // Talkback double tap from Windows Firefox touch screen press\n return !(0, $c87311424ea30a05$export$a11b0059900ceec8)() && event.width === 0 && event.height === 0 || event.width === 1 && event.height === 1 && event.pressure === 0 && event.detail === 0 && event.pointerType === 'mouse';\n}\nexport { $6a7db85432448f7f$export$60278871457622de as isVirtualClick, $6a7db85432448f7f$export$29bf1b5f2c56cf63 as isVirtualPointerEvent };","import $HgANd$react from \"react\";\n\n/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\nvar $f0a04ccd8dbdd83b$export$e5c5a5f917a5871c = typeof document !== 'undefined' ? (0, $HgANd$react).useLayoutEffect : function () {};\nexport { $f0a04ccd8dbdd83b$export$e5c5a5f917a5871c as useLayoutEffect };","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport { useRef as $6dfIe$useRef, useCallback as $6dfIe$useCallback } from \"react\";\nimport { useLayoutEffect as $6dfIe$useLayoutEffect, useEffectEvent as $6dfIe$useEffectEvent } from \"@react-aria/utils\";\n\n/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\nvar $8a9cb279dc87e130$export$905e7fc544a71f36 = /*#__PURE__*/function () {\n function $8a9cb279dc87e130$export$905e7fc544a71f36(type, nativeEvent) {\n _classCallCheck(this, $8a9cb279dc87e130$export$905e7fc544a71f36);\n this.nativeEvent = nativeEvent;\n this.target = nativeEvent.target;\n this.currentTarget = nativeEvent.currentTarget;\n this.relatedTarget = nativeEvent.relatedTarget;\n this.bubbles = nativeEvent.bubbles;\n this.cancelable = nativeEvent.cancelable;\n this.defaultPrevented = nativeEvent.defaultPrevented;\n this.eventPhase = nativeEvent.eventPhase;\n this.isTrusted = nativeEvent.isTrusted;\n this.timeStamp = nativeEvent.timeStamp;\n this.type = type;\n }\n _createClass($8a9cb279dc87e130$export$905e7fc544a71f36, [{\n key: \"isDefaultPrevented\",\n value: function isDefaultPrevented() {\n return this.nativeEvent.defaultPrevented;\n }\n }, {\n key: \"preventDefault\",\n value: function preventDefault() {\n this.defaultPrevented = true;\n this.nativeEvent.preventDefault();\n }\n }, {\n key: \"stopPropagation\",\n value: function stopPropagation() {\n this.nativeEvent.stopPropagation();\n this.isPropagationStopped = function () {\n return true;\n };\n }\n }, {\n key: \"isPropagationStopped\",\n value: function isPropagationStopped() {\n return false;\n }\n }, {\n key: \"persist\",\n value: function persist() {}\n }]);\n return $8a9cb279dc87e130$export$905e7fc544a71f36;\n}();\nfunction $8a9cb279dc87e130$export$715c682d09d639cc(onBlur) {\n var stateRef = (0, $6dfIe$useRef)({\n isFocused: false,\n observer: null\n });\n // Clean up MutationObserver on unmount. See below.\n // eslint-disable-next-line arrow-body-style\n (0, $6dfIe$useLayoutEffect)(function () {\n var state = stateRef.current;\n return function () {\n if (state.observer) {\n state.observer.disconnect();\n state.observer = null;\n }\n };\n }, []);\n var dispatchBlur = (0, $6dfIe$useEffectEvent)(function (e) {\n onBlur === null || onBlur === void 0 ? void 0 : onBlur(e);\n });\n // This function is called during a React onFocus event.\n return (0, $6dfIe$useCallback)(function (e) {\n // React does not fire onBlur when an element is disabled. https://github.com/facebook/react/issues/9142\n // Most browsers fire a native focusout event in this case, except for Firefox. In that case, we use a\n // MutationObserver to watch for the disabled attribute, and dispatch these events ourselves.\n // For browsers that do, focusout fires before the MutationObserver, so onBlur should not fire twice.\n if (e.target instanceof HTMLButtonElement || e.target instanceof HTMLInputElement || e.target instanceof HTMLTextAreaElement || e.target instanceof HTMLSelectElement) {\n stateRef.current.isFocused = true;\n var target = e.target;\n var onBlurHandler = function onBlurHandler(e) {\n stateRef.current.isFocused = false;\n if (target.disabled)\n // For backward compatibility, dispatch a (fake) React synthetic event.\n dispatchBlur(new $8a9cb279dc87e130$export$905e7fc544a71f36('blur', e));\n // We no longer need the MutationObserver once the target is blurred.\n if (stateRef.current.observer) {\n stateRef.current.observer.disconnect();\n stateRef.current.observer = null;\n }\n };\n target.addEventListener('focusout', onBlurHandler, {\n once: true\n });\n stateRef.current.observer = new MutationObserver(function () {\n if (stateRef.current.isFocused && target.disabled) {\n var _stateRef_current_observer;\n (_stateRef_current_observer = stateRef.current.observer) === null || _stateRef_current_observer === void 0 ? void 0 : _stateRef_current_observer.disconnect();\n var relatedTargetEl = target === document.activeElement ? null : document.activeElement;\n target.dispatchEvent(new FocusEvent('blur', {\n relatedTarget: relatedTargetEl\n }));\n target.dispatchEvent(new FocusEvent('focusout', {\n bubbles: true,\n relatedTarget: relatedTargetEl\n }));\n }\n });\n stateRef.current.observer.observe(target, {\n attributes: true,\n attributeFilter: ['disabled']\n });\n }\n }, [dispatchBlur]);\n}\nexport { $8a9cb279dc87e130$export$905e7fc544a71f36 as SyntheticFocusEvent, $8a9cb279dc87e130$export$715c682d09d639cc as useSyntheticBlurEvent };","import { useLayoutEffect as $f0a04ccd8dbdd83b$export$e5c5a5f917a5871c } from \"./useLayoutEffect.module.js\";\nimport { useRef as $lmaYr$useRef, useCallback as $lmaYr$useCallback } from \"react\";\n\n/*\n * Copyright 2023 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */\n\nfunction $8ae05eaa5c114e9c$export$7f54fc3180508a52(fn) {\n var ref = (0, $lmaYr$useRef)(null);\n (0, $f0a04ccd8dbdd83b$export$e5c5a5f917a5871c)(function () {\n ref.current = fn;\n }, [fn]);\n // @ts-ignore\n return (0, $lmaYr$useCallback)(function () {\n var f = ref.current;\n return f === null || f === void 0 ? void 0 : f.apply(void 0, arguments);\n }, []);\n}\nexport { $8ae05eaa5c114e9c$export$7f54fc3180508a52 as useEffectEvent };","import { useSyntheticBlurEvent as $8a9cb279dc87e130$export$715c682d09d639cc } from \"./utils.module.js\";\nimport { useCallback as $hf0lj$useCallback } from \"react\";\nimport { getOwnerDocument as $hf0lj$getOwnerDocument } from \"@react-aria/utils\";\n\n/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */ // Portions of the code in this file are based on code from react.\n// Original licensing for the following can be found in the\n// NOTICE file in the root directory of this source tree.\n// See https://github.com/facebook/react/tree/cc7c1aece46a6b69b41958d731e0fd27c94bfc6c/packages/react-interactions\n\nfunction $a1ea59d68270f0dd$export$f8168d8dd8fd66e6(props) {\n var isDisabled = props.isDisabled,\n onFocusProp = props.onFocus,\n onBlurProp = props.onBlur,\n onFocusChange = props.onFocusChange;\n var onBlur = (0, $hf0lj$useCallback)(function (e) {\n if (e.target === e.currentTarget) {\n if (onBlurProp) onBlurProp(e);\n if (onFocusChange) onFocusChange(false);\n return true;\n }\n }, [onBlurProp, onFocusChange]);\n var onSyntheticFocus = (0, $8a9cb279dc87e130$export$715c682d09d639cc)(onBlur);\n var onFocus = (0, $hf0lj$useCallback)(function (e) {\n // Double check that document.activeElement actually matches e.target in case a previously chained\n // focus handler already moved focus somewhere else.\n var ownerDocument = (0, $hf0lj$getOwnerDocument)(e.target);\n if (e.target === e.currentTarget && ownerDocument.activeElement === e.target) {\n if (onFocusProp) onFocusProp(e);\n if (onFocusChange) onFocusChange(true);\n onSyntheticFocus(e);\n }\n }, [onFocusChange, onFocusProp, onSyntheticFocus]);\n return {\n focusProps: {\n onFocus: !isDisabled && (onFocusProp || onFocusChange || onBlurProp) ? onFocus : undefined,\n onBlur: !isDisabled && (onBlurProp || onFocusChange) ? onBlur : undefined\n }\n };\n}\nexport { $a1ea59d68270f0dd$export$f8168d8dd8fd66e6 as useFocus };","import { useSyntheticBlurEvent as $8a9cb279dc87e130$export$715c682d09d639cc } from \"./utils.module.js\";\nimport { useRef as $3b9Q0$useRef, useCallback as $3b9Q0$useCallback } from \"react\";\n\n/*\n * Copyright 2020 Adobe. All rights reserved.\n * This file is licensed to you under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License. You may obtain a copy\n * of the License at http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under\n * the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\n * OF ANY KIND, either express or implied. See the License for the specific language\n * governing permissions and limitations under the License.\n */ // Portions of the code in this file are based on code from react.\n// Original licensing for the following can be found in the\n// NOTICE file in the root directory of this source tree.\n// See https://github.com/facebook/react/tree/cc7c1aece46a6b69b41958d731e0fd27c94bfc6c/packages/react-interactions\n\nfunction $9ab94262bd0047c7$export$420e68273165f4ec(props) {\n var isDisabled = props.isDisabled,\n onBlurWithin = props.onBlurWithin,\n onFocusWithin = props.onFocusWithin,\n onFocusWithinChange = props.onFocusWithinChange;\n var state = (0, $3b9Q0$useRef)({\n isFocusWithin: false\n });\n var onBlur = (0, $3b9Q0$useCallback)(function (e) {\n // We don't want to trigger onBlurWithin and then immediately onFocusWithin again\n // when moving focus inside the element. Only trigger if the currentTarget doesn't\n // include the relatedTarget (where focus is moving).\n if (state.current.isFocusWithin && !e.currentTarget.contains(e.relatedTarget)) {\n state.current.isFocusWithin = false;\n if (onBlurWithin) onBlurWithin(e);\n if (onFocusWithinChange) onFocusWithinChange(false);\n }\n }, [onBlurWithin, onFocusWithinChange, state]);\n var onSyntheticFocus = (0, $8a9cb279dc87e130$export$715c682d09d639cc)(onBlur);\n var onFocus = (0, $3b9Q0$useCallback)(function (e) {\n // Double check that document.activeElement actually matches e.target in case a previously chained\n // focus handler already moved focus somewhere else.\n if (!state.current.isFocusWithin && document.activeElement === e.target) {\n if (onFocusWithin) onFocusWithin(e);\n if (onFocusWithinChange) onFocusWithinChange(true);\n state.current.isFocusWithin = true;\n onSyntheticFocus(e);\n }\n }, [onFocusWithin, onFocusWithinChange, onSyntheticFocus]);\n if (isDisabled) return {\n focusWithinProps: {\n // These should not have been null, that would conflict in mergeProps\n onFocus: undefined,\n onBlur: undefined\n }\n };\n return {\n focusWithinProps: {\n onFocus: onFocus,\n onBlur: onBlur\n }\n };\n}\nexport { $9ab94262bd0047c7$export$420e68273165f4ec as useFocusWithin };","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { isFocusVisible as $isWE5$isFocusVisible, useFocusVisibleListener as $isWE5$useFocusVisibleListener, useFocus as $isWE5$useFocus, useFocusWithin as $isWE5$useFocusWithin } from \"@react-aria/interactions\";\nimport { useRef as $isWE5$useRef, useState as $isWE5$useState, useCallback as $isWE5$useCallback } from \"react\";\nfunction $f7dceffc5ad7768b$export$4e328f61c538687f() {\n var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var _props$autoFocus = props.autoFocus,\n autoFocus = _props$autoFocus === void 0 ? false : _props$autoFocus,\n isTextInput = props.isTextInput,\n within = props.within;\n var state = (0, $isWE5$useRef)({\n isFocused: false,\n isFocusVisible: autoFocus || (0, $isWE5$isFocusVisible)()\n });\n var _ref = (0, $isWE5$useState)(false),\n _ref2 = _slicedToArray(_ref, 2),\n isFocused = _ref2[0],\n setFocused = _ref2[1];\n var _ref3 = (0, $isWE5$useState)(function () {\n return state.current.isFocused && state.current.isFocusVisible;\n }),\n _ref4 = _slicedToArray(_ref3, 2),\n isFocusVisibleState = _ref4[0],\n setFocusVisible = _ref4[1];\n var updateState = (0, $isWE5$useCallback)(function () {\n return setFocusVisible(state.current.isFocused && state.current.isFocusVisible);\n }, []);\n var onFocusChange = (0, $isWE5$useCallback)(function (isFocused) {\n state.current.isFocused = isFocused;\n setFocused(isFocused);\n updateState();\n }, [updateState]);\n (0, $isWE5$useFocusVisibleListener)(function (isFocusVisible) {\n state.current.isFocusVisible = isFocusVisible;\n updateState();\n }, [], {\n isTextInput: isTextInput\n });\n var _ref5 = (0, $isWE5$useFocus)({\n isDisabled: within,\n onFocusChange: onFocusChange\n }),\n focusProps = _ref5.focusProps;\n var _ref6 = (0, $isWE5$useFocusWithin)({\n isDisabled: !within,\n onFocusWithinChange: onFocusChange\n }),\n focusWithinProps = _ref6.focusWithinProps;\n return {\n isFocused: isFocused,\n isFocusVisible: isFocusVisibleState,\n focusProps: within ? focusWithinProps : focusProps\n };\n}\nexport { $f7dceffc5ad7768b$export$4e328f61c538687f as useFocusRing };","'use strict';\nvar call = require('../internals/function-call');\nvar isObject = require('../internals/is-object');\nvar isSymbol = require('../internals/is-symbol');\nvar getMethod = require('../internals/get-method');\nvar ordinaryToPrimitive = require('../internals/ordinary-to-primitive');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar $TypeError = TypeError;\nvar TO_PRIMITIVE = wellKnownSymbol('toPrimitive');\n\n// `ToPrimitive` abstract operation\n// https://tc39.es/ecma262/#sec-toprimitive\nmodule.exports = function (input, pref) {\n if (!isObject(input) || isSymbol(input)) return input;\n var exoticToPrim = getMethod(input, TO_PRIMITIVE);\n var result;\n if (exoticToPrim) {\n if (pref === undefined) pref = 'default';\n result = call(exoticToPrim, input, pref);\n if (!isObject(result) || isSymbol(result)) return result;\n throw new $TypeError(\"Can't convert object to primitive value\");\n }\n if (pref === undefined) pref = 'number';\n return ordinaryToPrimitive(input, pref);\n};\n","'use strict';\nvar hasOwn = require('../internals/has-own-property');\nvar ownKeys = require('../internals/own-keys');\nvar getOwnPropertyDescriptorModule = require('../internals/object-get-own-property-descriptor');\nvar definePropertyModule = require('../internals/object-define-property');\n\nmodule.exports = function (target, source, exceptions) {\n var keys = ownKeys(source);\n var defineProperty = definePropertyModule.f;\n var getOwnPropertyDescriptor = getOwnPropertyDescriptorModule.f;\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n if (!hasOwn(target, key) && !(exceptions && hasOwn(exceptions, key))) {\n defineProperty(target, key, getOwnPropertyDescriptor(source, key));\n }\n }\n};\n","'use strict';\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar toAbsoluteIndex = require('../internals/to-absolute-index');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\n\n// `Array.prototype.{ indexOf, includes }` methods implementation\nvar createMethod = function (IS_INCLUDES) {\n return function ($this, el, fromIndex) {\n var O = toIndexedObject($this);\n var length = lengthOfArrayLike(O);\n var index = toAbsoluteIndex(fromIndex, length);\n var value;\n // Array#includes uses SameValueZero equality algorithm\n // eslint-disable-next-line no-self-compare -- NaN check\n if (IS_INCLUDES && el !== el) while (length > index) {\n value = O[index++];\n // eslint-disable-next-line no-self-compare -- NaN check\n if (value !== value) return true;\n // Array#indexOf ignores holes, Array#includes - not\n } else for (;length > index; index++) {\n if ((IS_INCLUDES || index in O) && O[index] === el) return IS_INCLUDES || index || 0;\n } return !IS_INCLUDES && -1;\n };\n};\n\nmodule.exports = {\n // `Array.prototype.includes` method\n // https://tc39.es/ecma262/#sec-array.prototype.includes\n includes: createMethod(true),\n // `Array.prototype.indexOf` method\n // https://tc39.es/ecma262/#sec-array.prototype.indexof\n indexOf: createMethod(false)\n};\n","'use strict';\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\nvar setPrototypeOf = require('../internals/object-set-prototype-of');\n\n// makes subclassing work correct for wrapped built-ins\nmodule.exports = function ($this, dummy, Wrapper) {\n var NewTarget, NewTargetPrototype;\n if (\n // it can work only with native `setPrototypeOf`\n setPrototypeOf &&\n // we haven't completely correct pre-ES6 way for getting `new.target`, so use this\n isCallable(NewTarget = dummy.constructor) &&\n NewTarget !== Wrapper &&\n isObject(NewTargetPrototype = NewTarget.prototype) &&\n NewTargetPrototype !== Wrapper.prototype\n ) setPrototypeOf($this, NewTargetPrototype);\n return $this;\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar $includes = require('../internals/array-includes').includes;\nvar fails = require('../internals/fails');\nvar addToUnscopables = require('../internals/add-to-unscopables');\n\n// FF99+ bug\nvar BROKEN_ON_SPARSE = fails(function () {\n // eslint-disable-next-line es/no-array-prototype-includes -- detection\n return !Array(1).includes();\n});\n\n// `Array.prototype.includes` method\n// https://tc39.es/ecma262/#sec-array.prototype.includes\n$({ target: 'Array', proto: true, forced: BROKEN_ON_SPARSE }, {\n includes: function includes(el /* , fromIndex = 0 */) {\n return $includes(this, el, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\n\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\naddToUnscopables('includes');\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar DESCRIPTORS = require('../internals/descriptors');\n\nvar SPECIES = wellKnownSymbol('species');\n\nmodule.exports = function (CONSTRUCTOR_NAME) {\n var Constructor = getBuiltIn(CONSTRUCTOR_NAME);\n\n if (DESCRIPTORS && Constructor && !Constructor[SPECIES]) {\n defineBuiltInAccessor(Constructor, SPECIES, {\n configurable: true,\n get: function () { return this; }\n });\n }\n};\n","'use strict';\nvar anObject = require('../internals/an-object');\nvar aConstructor = require('../internals/a-constructor');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar SPECIES = wellKnownSymbol('species');\n\n// `SpeciesConstructor` abstract operation\n// https://tc39.es/ecma262/#sec-speciesconstructor\nmodule.exports = function (O, defaultConstructor) {\n var C = anObject(O).constructor;\n var S;\n return C === undefined || isNullOrUndefined(S = anObject(C)[SPECIES]) ? defaultConstructor : aConstructor(S);\n};\n","'use strict';\nvar global = require('../internals/global');\nvar apply = require('../internals/function-apply');\nvar bind = require('../internals/function-bind-context');\nvar isCallable = require('../internals/is-callable');\nvar hasOwn = require('../internals/has-own-property');\nvar fails = require('../internals/fails');\nvar html = require('../internals/html');\nvar arraySlice = require('../internals/array-slice');\nvar createElement = require('../internals/document-create-element');\nvar validateArgumentsLength = require('../internals/validate-arguments-length');\nvar IS_IOS = require('../internals/engine-is-ios');\nvar IS_NODE = require('../internals/engine-is-node');\n\nvar set = global.setImmediate;\nvar clear = global.clearImmediate;\nvar process = global.process;\nvar Dispatch = global.Dispatch;\nvar Function = global.Function;\nvar MessageChannel = global.MessageChannel;\nvar String = global.String;\nvar counter = 0;\nvar queue = {};\nvar ONREADYSTATECHANGE = 'onreadystatechange';\nvar $location, defer, channel, port;\n\nfails(function () {\n // Deno throws a ReferenceError on `location` access without `--location` flag\n $location = global.location;\n});\n\nvar run = function (id) {\n if (hasOwn(queue, id)) {\n var fn = queue[id];\n delete queue[id];\n fn();\n }\n};\n\nvar runner = function (id) {\n return function () {\n run(id);\n };\n};\n\nvar eventListener = function (event) {\n run(event.data);\n};\n\nvar globalPostMessageDefer = function (id) {\n // old engines have not location.origin\n global.postMessage(String(id), $location.protocol + '//' + $location.host);\n};\n\n// Node.js 0.9+ & IE10+ has setImmediate, otherwise:\nif (!set || !clear) {\n set = function setImmediate(handler) {\n validateArgumentsLength(arguments.length, 1);\n var fn = isCallable(handler) ? handler : Function(handler);\n var args = arraySlice(arguments, 1);\n queue[++counter] = function () {\n apply(fn, undefined, args);\n };\n defer(counter);\n return counter;\n };\n clear = function clearImmediate(id) {\n delete queue[id];\n };\n // Node.js 0.8-\n if (IS_NODE) {\n defer = function (id) {\n process.nextTick(runner(id));\n };\n // Sphere (JS game engine) Dispatch API\n } else if (Dispatch && Dispatch.now) {\n defer = function (id) {\n Dispatch.now(runner(id));\n };\n // Browsers with MessageChannel, includes WebWorkers\n // except iOS - https://github.com/zloirock/core-js/issues/624\n } else if (MessageChannel && !IS_IOS) {\n channel = new MessageChannel();\n port = channel.port2;\n channel.port1.onmessage = eventListener;\n defer = bind(port.postMessage, port);\n // Browsers with postMessage, skip WebWorkers\n // IE8 has postMessage, but it's sync & typeof its postMessage is 'object'\n } else if (\n global.addEventListener &&\n isCallable(global.postMessage) &&\n !global.importScripts &&\n $location && $location.protocol !== 'file:' &&\n !fails(globalPostMessageDefer)\n ) {\n defer = globalPostMessageDefer;\n global.addEventListener('message', eventListener, false);\n // IE8-\n } else if (ONREADYSTATECHANGE in createElement('script')) {\n defer = function (id) {\n html.appendChild(createElement('script'))[ONREADYSTATECHANGE] = function () {\n html.removeChild(this);\n run(id);\n };\n };\n // Rest old browsers\n } else {\n defer = function (id) {\n setTimeout(runner(id), 0);\n };\n }\n}\n\nmodule.exports = {\n set: set,\n clear: clear\n};\n","'use strict';\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar checkCorrectnessOfIteration = require('../internals/check-correctness-of-iteration');\nvar FORCED_PROMISE_CONSTRUCTOR = require('../internals/promise-constructor-detection').CONSTRUCTOR;\n\nmodule.exports = FORCED_PROMISE_CONSTRUCTOR || !checkCorrectnessOfIteration(function (iterable) {\n NativePromiseConstructor.all(iterable).then(undefined, function () { /* empty */ });\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar notARegExp = require('../internals/not-a-regexp');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\nvar toString = require('../internals/to-string');\nvar correctIsRegExpLogic = require('../internals/correct-is-regexp-logic');\n\nvar stringIndexOf = uncurryThis(''.indexOf);\n\n// `String.prototype.includes` method\n// https://tc39.es/ecma262/#sec-string.prototype.includes\n$({ target: 'String', proto: true, forced: !correctIsRegExpLogic('includes') }, {\n includes: function includes(searchString /* , position = 0 */) {\n return !!~stringIndexOf(\n toString(requireObjectCoercible(this)),\n toString(notARegExp(searchString)),\n arguments.length > 1 ? arguments[1] : undefined\n );\n }\n});\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar hasOwn = require('../internals/has-own-property');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar CONFIGURABLE_FUNCTION_NAME = require('../internals/function-name').CONFIGURABLE;\nvar inspectSource = require('../internals/inspect-source');\nvar InternalStateModule = require('../internals/internal-state');\n\nvar enforceInternalState = InternalStateModule.enforce;\nvar getInternalState = InternalStateModule.get;\nvar $String = String;\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar defineProperty = Object.defineProperty;\nvar stringSlice = uncurryThis(''.slice);\nvar replace = uncurryThis(''.replace);\nvar join = uncurryThis([].join);\n\nvar CONFIGURABLE_LENGTH = DESCRIPTORS && !fails(function () {\n return defineProperty(function () { /* empty */ }, 'length', { value: 8 }).length !== 8;\n});\n\nvar TEMPLATE = String(String).split('String');\n\nvar makeBuiltIn = module.exports = function (value, name, options) {\n if (stringSlice($String(name), 0, 7) === 'Symbol(') {\n name = '[' + replace($String(name), /^Symbol\\(([^)]*)\\)/, '$1') + ']';\n }\n if (options && options.getter) name = 'get ' + name;\n if (options && options.setter) name = 'set ' + name;\n if (!hasOwn(value, 'name') || (CONFIGURABLE_FUNCTION_NAME && value.name !== name)) {\n if (DESCRIPTORS) defineProperty(value, 'name', { value: name, configurable: true });\n else value.name = name;\n }\n if (CONFIGURABLE_LENGTH && options && hasOwn(options, 'arity') && value.length !== options.arity) {\n defineProperty(value, 'length', { value: options.arity });\n }\n try {\n if (options && hasOwn(options, 'constructor') && options.constructor) {\n if (DESCRIPTORS) defineProperty(value, 'prototype', { writable: false });\n // in V8 ~ Chrome 53, prototypes of some methods, like `Array.prototype.values`, are non-writable\n } else if (value.prototype) value.prototype = undefined;\n } catch (error) { /* empty */ }\n var state = enforceInternalState(value);\n if (!hasOwn(state, 'source')) {\n state.source = join(TEMPLATE, typeof name == 'string' ? name : '');\n } return value;\n};\n\n// add fake Function#toString for correct work wrapped methods / constructors with methods like LoDash isNative\n// eslint-disable-next-line no-extend-native -- required\nFunction.prototype.toString = makeBuiltIn(function toString() {\n return isCallable(this) && getInternalState(this).source || inspectSource(this);\n}, 'toString');\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar V8_PROTOTYPE_DEFINE_BUG = require('../internals/v8-prototype-define-bug');\nvar definePropertyModule = require('../internals/object-define-property');\nvar anObject = require('../internals/an-object');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar objectKeys = require('../internals/object-keys');\n\n// `Object.defineProperties` method\n// https://tc39.es/ecma262/#sec-object.defineproperties\n// eslint-disable-next-line es/no-object-defineproperties -- safe\nexports.f = DESCRIPTORS && !V8_PROTOTYPE_DEFINE_BUG ? Object.defineProperties : function defineProperties(O, Properties) {\n anObject(O);\n var props = toIndexedObject(Properties);\n var keys = objectKeys(Properties);\n var length = keys.length;\n var index = 0;\n var key;\n while (length > index) definePropertyModule.f(O, key = keys[index++], props[key]);\n return O;\n};\n","'use strict';\nvar global = require('../internals/global');\n\nmodule.exports = global;\n","'use strict';\nvar fails = require('../internals/fails');\n\nmodule.exports = !fails(function () {\n function F() { /* empty */ }\n F.prototype.constructor = null;\n // eslint-disable-next-line es/no-object-getprototypeof -- required for testing\n return Object.getPrototypeOf(new F()) !== F.prototype;\n});\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar Iterators = require('../internals/iterators');\n\nvar ITERATOR = wellKnownSymbol('iterator');\nvar ArrayPrototype = Array.prototype;\n\n// check on default Array iterator\nmodule.exports = function (it) {\n return it !== undefined && (Iterators.Array === it || ArrayPrototype[ITERATOR] === it);\n};\n","'use strict';\nvar anObject = require('../internals/an-object');\nvar iteratorClose = require('../internals/iterator-close');\n\n// call something on iterator step with safe closing on error\nmodule.exports = function (iterator, fn, value, ENTRIES) {\n try {\n return ENTRIES ? fn(anObject(value)[0], value[1]) : fn(value);\n } catch (error) {\n iteratorClose(iterator, 'throw', error);\n }\n};\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar ITERATOR = wellKnownSymbol('iterator');\nvar SAFE_CLOSING = false;\n\ntry {\n var called = 0;\n var iteratorWithReturn = {\n next: function () {\n return { done: !!called++ };\n },\n 'return': function () {\n SAFE_CLOSING = true;\n }\n };\n iteratorWithReturn[ITERATOR] = function () {\n return this;\n };\n // eslint-disable-next-line es/no-array-from, no-throw-literal -- required for testing\n Array.from(iteratorWithReturn, function () { throw 2; });\n} catch (error) { /* empty */ }\n\nmodule.exports = function (exec, SKIP_CLOSING) {\n try {\n if (!SKIP_CLOSING && !SAFE_CLOSING) return false;\n } catch (error) { return false; } // workaround of old WebKit + `eval` bug\n var ITERATION_SUPPORT = false;\n try {\n var object = {};\n object[ITERATOR] = function () {\n return {\n next: function () {\n return { done: ITERATION_SUPPORT = true };\n }\n };\n };\n exec(object);\n } catch (error) { /* empty */ }\n return ITERATION_SUPPORT;\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar IS_PURE = require('../internals/is-pure');\nvar FunctionName = require('../internals/function-name');\nvar isCallable = require('../internals/is-callable');\nvar createIteratorConstructor = require('../internals/iterator-create-constructor');\nvar getPrototypeOf = require('../internals/object-get-prototype-of');\nvar setPrototypeOf = require('../internals/object-set-prototype-of');\nvar setToStringTag = require('../internals/set-to-string-tag');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar Iterators = require('../internals/iterators');\nvar IteratorsCore = require('../internals/iterators-core');\n\nvar PROPER_FUNCTION_NAME = FunctionName.PROPER;\nvar CONFIGURABLE_FUNCTION_NAME = FunctionName.CONFIGURABLE;\nvar IteratorPrototype = IteratorsCore.IteratorPrototype;\nvar BUGGY_SAFARI_ITERATORS = IteratorsCore.BUGGY_SAFARI_ITERATORS;\nvar ITERATOR = wellKnownSymbol('iterator');\nvar KEYS = 'keys';\nvar VALUES = 'values';\nvar ENTRIES = 'entries';\n\nvar returnThis = function () { return this; };\n\nmodule.exports = function (Iterable, NAME, IteratorConstructor, next, DEFAULT, IS_SET, FORCED) {\n createIteratorConstructor(IteratorConstructor, NAME, next);\n\n var getIterationMethod = function (KIND) {\n if (KIND === DEFAULT && defaultIterator) return defaultIterator;\n if (!BUGGY_SAFARI_ITERATORS && KIND && KIND in IterablePrototype) return IterablePrototype[KIND];\n\n switch (KIND) {\n case KEYS: return function keys() { return new IteratorConstructor(this, KIND); };\n case VALUES: return function values() { return new IteratorConstructor(this, KIND); };\n case ENTRIES: return function entries() { return new IteratorConstructor(this, KIND); };\n }\n\n return function () { return new IteratorConstructor(this); };\n };\n\n var TO_STRING_TAG = NAME + ' Iterator';\n var INCORRECT_VALUES_NAME = false;\n var IterablePrototype = Iterable.prototype;\n var nativeIterator = IterablePrototype[ITERATOR]\n || IterablePrototype['@@iterator']\n || DEFAULT && IterablePrototype[DEFAULT];\n var defaultIterator = !BUGGY_SAFARI_ITERATORS && nativeIterator || getIterationMethod(DEFAULT);\n var anyNativeIterator = NAME === 'Array' ? IterablePrototype.entries || nativeIterator : nativeIterator;\n var CurrentIteratorPrototype, methods, KEY;\n\n // fix native\n if (anyNativeIterator) {\n CurrentIteratorPrototype = getPrototypeOf(anyNativeIterator.call(new Iterable()));\n if (CurrentIteratorPrototype !== Object.prototype && CurrentIteratorPrototype.next) {\n if (!IS_PURE && getPrototypeOf(CurrentIteratorPrototype) !== IteratorPrototype) {\n if (setPrototypeOf) {\n setPrototypeOf(CurrentIteratorPrototype, IteratorPrototype);\n } else if (!isCallable(CurrentIteratorPrototype[ITERATOR])) {\n defineBuiltIn(CurrentIteratorPrototype, ITERATOR, returnThis);\n }\n }\n // Set @@toStringTag to native iterators\n setToStringTag(CurrentIteratorPrototype, TO_STRING_TAG, true, true);\n if (IS_PURE) Iterators[TO_STRING_TAG] = returnThis;\n }\n }\n\n // fix Array.prototype.{ values, @@iterator }.name in V8 / FF\n if (PROPER_FUNCTION_NAME && DEFAULT === VALUES && nativeIterator && nativeIterator.name !== VALUES) {\n if (!IS_PURE && CONFIGURABLE_FUNCTION_NAME) {\n createNonEnumerableProperty(IterablePrototype, 'name', VALUES);\n } else {\n INCORRECT_VALUES_NAME = true;\n defaultIterator = function values() { return call(nativeIterator, this); };\n }\n }\n\n // export additional methods\n if (DEFAULT) {\n methods = {\n values: getIterationMethod(VALUES),\n keys: IS_SET ? defaultIterator : getIterationMethod(KEYS),\n entries: getIterationMethod(ENTRIES)\n };\n if (FORCED) for (KEY in methods) {\n if (BUGGY_SAFARI_ITERATORS || INCORRECT_VALUES_NAME || !(KEY in IterablePrototype)) {\n defineBuiltIn(IterablePrototype, KEY, methods[KEY]);\n }\n } else $({ target: NAME, proto: true, forced: BUGGY_SAFARI_ITERATORS || INCORRECT_VALUES_NAME }, methods);\n }\n\n // define iterator\n if ((!IS_PURE || FORCED) && IterablePrototype[ITERATOR] !== defaultIterator) {\n defineBuiltIn(IterablePrototype, ITERATOR, defaultIterator, { name: DEFAULT });\n }\n Iterators[NAME] = defaultIterator;\n\n return methods;\n};\n","'use strict';\nvar IteratorPrototype = require('../internals/iterators-core').IteratorPrototype;\nvar create = require('../internals/object-create');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\nvar setToStringTag = require('../internals/set-to-string-tag');\nvar Iterators = require('../internals/iterators');\n\nvar returnThis = function () { return this; };\n\nmodule.exports = function (IteratorConstructor, NAME, next, ENUMERABLE_NEXT) {\n var TO_STRING_TAG = NAME + ' Iterator';\n IteratorConstructor.prototype = create(IteratorPrototype, { next: createPropertyDescriptor(+!ENUMERABLE_NEXT, next) });\n setToStringTag(IteratorConstructor, TO_STRING_TAG, false, true);\n Iterators[TO_STRING_TAG] = returnThis;\n return IteratorConstructor;\n};\n","'use strict';\nvar isConstructor = require('../internals/is-constructor');\nvar tryToString = require('../internals/try-to-string');\n\nvar $TypeError = TypeError;\n\n// `Assert: IsConstructor(argument) is true`\nmodule.exports = function (argument) {\n if (isConstructor(argument)) return argument;\n throw new $TypeError(tryToString(argument) + ' is not a constructor');\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\n// `thisNumberValue` abstract operation\n// https://tc39.es/ecma262/#sec-thisnumbervalue\nmodule.exports = uncurryThis(1.0.valueOf);\n","'use strict';\n// a string of all valid unicode whitespaces\nmodule.exports = '\\u0009\\u000A\\u000B\\u000C\\u000D\\u0020\\u00A0\\u1680\\u2000\\u2001\\u2002' +\n '\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200A\\u202F\\u205F\\u3000\\u2028\\u2029\\uFEFF';\n","'use strict';\n/* global Deno -- Deno case */\nmodule.exports = typeof Deno == 'object' && Deno && typeof Deno.version == 'object';\n","'use strict';\nvar $ = require('../internals/export');\nvar getBuiltIn = require('../internals/get-built-in');\nvar apply = require('../internals/function-apply');\nvar bind = require('../internals/function-bind');\nvar aConstructor = require('../internals/a-constructor');\nvar anObject = require('../internals/an-object');\nvar isObject = require('../internals/is-object');\nvar create = require('../internals/object-create');\nvar fails = require('../internals/fails');\n\nvar nativeConstruct = getBuiltIn('Reflect', 'construct');\nvar ObjectPrototype = Object.prototype;\nvar push = [].push;\n\n// `Reflect.construct` method\n// https://tc39.es/ecma262/#sec-reflect.construct\n// MS Edge supports only 2 arguments and argumentsList argument is optional\n// FF Nightly sets third argument as `new.target`, but does not create `this` from it\nvar NEW_TARGET_BUG = fails(function () {\n function F() { /* empty */ }\n return !(nativeConstruct(function () { /* empty */ }, [], F) instanceof F);\n});\n\nvar ARGS_BUG = !fails(function () {\n nativeConstruct(function () { /* empty */ });\n});\n\nvar FORCED = NEW_TARGET_BUG || ARGS_BUG;\n\n$({ target: 'Reflect', stat: true, forced: FORCED, sham: FORCED }, {\n construct: function construct(Target, args /* , newTarget */) {\n aConstructor(Target);\n anObject(args);\n var newTarget = arguments.length < 3 ? Target : aConstructor(arguments[2]);\n if (ARGS_BUG && !NEW_TARGET_BUG) return nativeConstruct(Target, args, newTarget);\n if (Target === newTarget) {\n // w/o altered newTarget, optimization for 0-4 arguments\n switch (args.length) {\n case 0: return new Target();\n case 1: return new Target(args[0]);\n case 2: return new Target(args[0], args[1]);\n case 3: return new Target(args[0], args[1], args[2]);\n case 4: return new Target(args[0], args[1], args[2], args[3]);\n }\n // w/o altered newTarget, lot of arguments case\n var $args = [null];\n apply(push, $args, args);\n return new (apply(bind, Target, $args))();\n }\n // with altered newTarget, not support built-in constructors\n var proto = newTarget.prototype;\n var instance = create(isObject(proto) ? proto : ObjectPrototype);\n var result = apply(Target, instance, args);\n return isObject(result) ? result : instance;\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar global = require('../internals/global');\nvar setToStringTag = require('../internals/set-to-string-tag');\n\n$({ global: true }, { Reflect: {} });\n\n// Reflect[@@toStringTag] property\n// https://tc39.es/ecma262/#sec-reflect-@@tostringtag\nsetToStringTag(global.Reflect, 'Reflect', true);\n","'use strict';\nvar call = require('../internals/function-call');\nvar hasOwn = require('../internals/has-own-property');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar regExpFlags = require('../internals/regexp-flags');\n\nvar RegExpPrototype = RegExp.prototype;\n\nmodule.exports = function (R) {\n var flags = R.flags;\n return flags === undefined && !('flags' in RegExpPrototype) && !hasOwn(R, 'flags') && isPrototypeOf(RegExpPrototype, R)\n ? call(regExpFlags, R) : flags;\n};\n","'use strict';\nvar anObject = require('../internals/an-object');\n\n// `RegExp.prototype.flags` getter implementation\n// https://tc39.es/ecma262/#sec-get-regexp.prototype.flags\nmodule.exports = function () {\n var that = anObject(this);\n var result = '';\n if (that.hasIndices) result += 'd';\n if (that.global) result += 'g';\n if (that.ignoreCase) result += 'i';\n if (that.multiline) result += 'm';\n if (that.dotAll) result += 's';\n if (that.unicode) result += 'u';\n if (that.unicodeSets) result += 'v';\n if (that.sticky) result += 'y';\n return result;\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar anObject = require('../internals/an-object');\nvar isCallable = require('../internals/is-callable');\nvar classof = require('../internals/classof-raw');\nvar regexpExec = require('../internals/regexp-exec');\n\nvar $TypeError = TypeError;\n\n// `RegExpExec` abstract operation\n// https://tc39.es/ecma262/#sec-regexpexec\nmodule.exports = function (R, S) {\n var exec = R.exec;\n if (isCallable(exec)) {\n var result = call(exec, R, S);\n if (result !== null) anObject(result);\n return result;\n }\n if (classof(R) === 'RegExp') return call(regexpExec, R, S);\n throw new $TypeError('RegExp#exec called on incompatible receiver');\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar global = require('../internals/global');\nvar call = require('../internals/function-call');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar TYPED_ARRAYS_CONSTRUCTORS_REQUIRES_WRAPPERS = require('../internals/typed-array-constructors-require-wrappers');\nvar ArrayBufferViewCore = require('../internals/array-buffer-view-core');\nvar ArrayBufferModule = require('../internals/array-buffer');\nvar anInstance = require('../internals/an-instance');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar isIntegralNumber = require('../internals/is-integral-number');\nvar toLength = require('../internals/to-length');\nvar toIndex = require('../internals/to-index');\nvar toOffset = require('../internals/to-offset');\nvar toUint8Clamped = require('../internals/to-uint8-clamped');\nvar toPropertyKey = require('../internals/to-property-key');\nvar hasOwn = require('../internals/has-own-property');\nvar classof = require('../internals/classof');\nvar isObject = require('../internals/is-object');\nvar isSymbol = require('../internals/is-symbol');\nvar create = require('../internals/object-create');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar setPrototypeOf = require('../internals/object-set-prototype-of');\nvar getOwnPropertyNames = require('../internals/object-get-own-property-names').f;\nvar typedArrayFrom = require('../internals/typed-array-from');\nvar forEach = require('../internals/array-iteration').forEach;\nvar setSpecies = require('../internals/set-species');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar definePropertyModule = require('../internals/object-define-property');\nvar getOwnPropertyDescriptorModule = require('../internals/object-get-own-property-descriptor');\nvar InternalStateModule = require('../internals/internal-state');\nvar inheritIfRequired = require('../internals/inherit-if-required');\n\nvar getInternalState = InternalStateModule.get;\nvar setInternalState = InternalStateModule.set;\nvar enforceInternalState = InternalStateModule.enforce;\nvar nativeDefineProperty = definePropertyModule.f;\nvar nativeGetOwnPropertyDescriptor = getOwnPropertyDescriptorModule.f;\nvar RangeError = global.RangeError;\nvar ArrayBuffer = ArrayBufferModule.ArrayBuffer;\nvar ArrayBufferPrototype = ArrayBuffer.prototype;\nvar DataView = ArrayBufferModule.DataView;\nvar NATIVE_ARRAY_BUFFER_VIEWS = ArrayBufferViewCore.NATIVE_ARRAY_BUFFER_VIEWS;\nvar TYPED_ARRAY_TAG = ArrayBufferViewCore.TYPED_ARRAY_TAG;\nvar TypedArray = ArrayBufferViewCore.TypedArray;\nvar TypedArrayPrototype = ArrayBufferViewCore.TypedArrayPrototype;\nvar aTypedArrayConstructor = ArrayBufferViewCore.aTypedArrayConstructor;\nvar isTypedArray = ArrayBufferViewCore.isTypedArray;\nvar BYTES_PER_ELEMENT = 'BYTES_PER_ELEMENT';\nvar WRONG_LENGTH = 'Wrong length';\n\nvar fromList = function (C, list) {\n aTypedArrayConstructor(C);\n var index = 0;\n var length = list.length;\n var result = new C(length);\n while (length > index) result[index] = list[index++];\n return result;\n};\n\nvar addGetter = function (it, key) {\n defineBuiltInAccessor(it, key, {\n configurable: true,\n get: function () {\n return getInternalState(this)[key];\n }\n });\n};\n\nvar isArrayBuffer = function (it) {\n var klass;\n return isPrototypeOf(ArrayBufferPrototype, it) || (klass = classof(it)) === 'ArrayBuffer' || klass === 'SharedArrayBuffer';\n};\n\nvar isTypedArrayIndex = function (target, key) {\n return isTypedArray(target)\n && !isSymbol(key)\n && key in target\n && isIntegralNumber(+key)\n && key >= 0;\n};\n\nvar wrappedGetOwnPropertyDescriptor = function getOwnPropertyDescriptor(target, key) {\n key = toPropertyKey(key);\n return isTypedArrayIndex(target, key)\n ? createPropertyDescriptor(2, target[key])\n : nativeGetOwnPropertyDescriptor(target, key);\n};\n\nvar wrappedDefineProperty = function defineProperty(target, key, descriptor) {\n key = toPropertyKey(key);\n if (isTypedArrayIndex(target, key)\n && isObject(descriptor)\n && hasOwn(descriptor, 'value')\n && !hasOwn(descriptor, 'get')\n && !hasOwn(descriptor, 'set')\n // TODO: add validation descriptor w/o calling accessors\n && !descriptor.configurable\n && (!hasOwn(descriptor, 'writable') || descriptor.writable)\n && (!hasOwn(descriptor, 'enumerable') || descriptor.enumerable)\n ) {\n target[key] = descriptor.value;\n return target;\n } return nativeDefineProperty(target, key, descriptor);\n};\n\nif (DESCRIPTORS) {\n if (!NATIVE_ARRAY_BUFFER_VIEWS) {\n getOwnPropertyDescriptorModule.f = wrappedGetOwnPropertyDescriptor;\n definePropertyModule.f = wrappedDefineProperty;\n addGetter(TypedArrayPrototype, 'buffer');\n addGetter(TypedArrayPrototype, 'byteOffset');\n addGetter(TypedArrayPrototype, 'byteLength');\n addGetter(TypedArrayPrototype, 'length');\n }\n\n $({ target: 'Object', stat: true, forced: !NATIVE_ARRAY_BUFFER_VIEWS }, {\n getOwnPropertyDescriptor: wrappedGetOwnPropertyDescriptor,\n defineProperty: wrappedDefineProperty\n });\n\n module.exports = function (TYPE, wrapper, CLAMPED) {\n var BYTES = TYPE.match(/\\d+/)[0] / 8;\n var CONSTRUCTOR_NAME = TYPE + (CLAMPED ? 'Clamped' : '') + 'Array';\n var GETTER = 'get' + TYPE;\n var SETTER = 'set' + TYPE;\n var NativeTypedArrayConstructor = global[CONSTRUCTOR_NAME];\n var TypedArrayConstructor = NativeTypedArrayConstructor;\n var TypedArrayConstructorPrototype = TypedArrayConstructor && TypedArrayConstructor.prototype;\n var exported = {};\n\n var getter = function (that, index) {\n var data = getInternalState(that);\n return data.view[GETTER](index * BYTES + data.byteOffset, true);\n };\n\n var setter = function (that, index, value) {\n var data = getInternalState(that);\n data.view[SETTER](index * BYTES + data.byteOffset, CLAMPED ? toUint8Clamped(value) : value, true);\n };\n\n var addElement = function (that, index) {\n nativeDefineProperty(that, index, {\n get: function () {\n return getter(this, index);\n },\n set: function (value) {\n return setter(this, index, value);\n },\n enumerable: true\n });\n };\n\n if (!NATIVE_ARRAY_BUFFER_VIEWS) {\n TypedArrayConstructor = wrapper(function (that, data, offset, $length) {\n anInstance(that, TypedArrayConstructorPrototype);\n var index = 0;\n var byteOffset = 0;\n var buffer, byteLength, length;\n if (!isObject(data)) {\n length = toIndex(data);\n byteLength = length * BYTES;\n buffer = new ArrayBuffer(byteLength);\n } else if (isArrayBuffer(data)) {\n buffer = data;\n byteOffset = toOffset(offset, BYTES);\n var $len = data.byteLength;\n if ($length === undefined) {\n if ($len % BYTES) throw new RangeError(WRONG_LENGTH);\n byteLength = $len - byteOffset;\n if (byteLength < 0) throw new RangeError(WRONG_LENGTH);\n } else {\n byteLength = toLength($length) * BYTES;\n if (byteLength + byteOffset > $len) throw new RangeError(WRONG_LENGTH);\n }\n length = byteLength / BYTES;\n } else if (isTypedArray(data)) {\n return fromList(TypedArrayConstructor, data);\n } else {\n return call(typedArrayFrom, TypedArrayConstructor, data);\n }\n setInternalState(that, {\n buffer: buffer,\n byteOffset: byteOffset,\n byteLength: byteLength,\n length: length,\n view: new DataView(buffer)\n });\n while (index < length) addElement(that, index++);\n });\n\n if (setPrototypeOf) setPrototypeOf(TypedArrayConstructor, TypedArray);\n TypedArrayConstructorPrototype = TypedArrayConstructor.prototype = create(TypedArrayPrototype);\n } else if (TYPED_ARRAYS_CONSTRUCTORS_REQUIRES_WRAPPERS) {\n TypedArrayConstructor = wrapper(function (dummy, data, typedArrayOffset, $length) {\n anInstance(dummy, TypedArrayConstructorPrototype);\n return inheritIfRequired(function () {\n if (!isObject(data)) return new NativeTypedArrayConstructor(toIndex(data));\n if (isArrayBuffer(data)) return $length !== undefined\n ? new NativeTypedArrayConstructor(data, toOffset(typedArrayOffset, BYTES), $length)\n : typedArrayOffset !== undefined\n ? new NativeTypedArrayConstructor(data, toOffset(typedArrayOffset, BYTES))\n : new NativeTypedArrayConstructor(data);\n if (isTypedArray(data)) return fromList(TypedArrayConstructor, data);\n return call(typedArrayFrom, TypedArrayConstructor, data);\n }(), dummy, TypedArrayConstructor);\n });\n\n if (setPrototypeOf) setPrototypeOf(TypedArrayConstructor, TypedArray);\n forEach(getOwnPropertyNames(NativeTypedArrayConstructor), function (key) {\n if (!(key in TypedArrayConstructor)) {\n createNonEnumerableProperty(TypedArrayConstructor, key, NativeTypedArrayConstructor[key]);\n }\n });\n TypedArrayConstructor.prototype = TypedArrayConstructorPrototype;\n }\n\n if (TypedArrayConstructorPrototype.constructor !== TypedArrayConstructor) {\n createNonEnumerableProperty(TypedArrayConstructorPrototype, 'constructor', TypedArrayConstructor);\n }\n\n enforceInternalState(TypedArrayConstructorPrototype).TypedArrayConstructor = TypedArrayConstructor;\n\n if (TYPED_ARRAY_TAG) {\n createNonEnumerableProperty(TypedArrayConstructorPrototype, TYPED_ARRAY_TAG, CONSTRUCTOR_NAME);\n }\n\n var FORCED = TypedArrayConstructor !== NativeTypedArrayConstructor;\n\n exported[CONSTRUCTOR_NAME] = TypedArrayConstructor;\n\n $({ global: true, constructor: true, forced: FORCED, sham: !NATIVE_ARRAY_BUFFER_VIEWS }, exported);\n\n if (!(BYTES_PER_ELEMENT in TypedArrayConstructor)) {\n createNonEnumerableProperty(TypedArrayConstructor, BYTES_PER_ELEMENT, BYTES);\n }\n\n if (!(BYTES_PER_ELEMENT in TypedArrayConstructorPrototype)) {\n createNonEnumerableProperty(TypedArrayConstructorPrototype, BYTES_PER_ELEMENT, BYTES);\n }\n\n setSpecies(CONSTRUCTOR_NAME);\n };\n} else module.exports = function () { /* empty */ };\n","'use strict';\nvar fails = require('../internals/fails');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar IS_PURE = require('../internals/is-pure');\n\nvar ITERATOR = wellKnownSymbol('iterator');\n\nmodule.exports = !fails(function () {\n // eslint-disable-next-line unicorn/relative-url-style -- required for testing\n var url = new URL('b?a=1&b=2&c=3', 'http://a');\n var params = url.searchParams;\n var params2 = new URLSearchParams('a=1&a=2&b=3');\n var result = '';\n url.pathname = 'c%20d';\n params.forEach(function (value, key) {\n params['delete']('b');\n result += key + value;\n });\n params2['delete']('a', 2);\n // `undefined` case is a Chromium 117 bug\n // https://bugs.chromium.org/p/v8/issues/detail?id=14222\n params2['delete']('b', undefined);\n return (IS_PURE && (!url.toJSON || !params2.has('a', 1) || params2.has('a', 2) || !params2.has('a', undefined) || params2.has('b')))\n || (!params.size && (IS_PURE || !DESCRIPTORS))\n || !params.sort\n || url.href !== 'http://a/c%20d?a=1&c=3'\n || params.get('c') !== '3'\n || String(new URLSearchParams('?a=1')) !== 'a=1'\n || !params[ITERATOR]\n // throws in Edge\n || new URL('https://a@b').username !== 'a'\n || new URLSearchParams(new URLSearchParams('a=b')).get('a') !== 'b'\n // not punycoded in Edge\n || new URL('http://тест').host !== 'xn--e1aybc'\n // not escaped in Chrome 62-\n || new URL('http://a#б').hash !== '#%D0%B1'\n // fails in Chrome 66-\n || result !== 'a1c3'\n // throws in Safari\n || new URL('http://x', undefined).host !== 'x';\n});\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout() {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n})();\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch (e) {\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch (e) {\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e) {\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e) {\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n var len = queue.length;\n while (len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\nfunction noop() {}\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\nprocess.listeners = function (name) {\n return [];\n};\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\nprocess.cwd = function () {\n return '/';\n};\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function () {\n return 0;\n};","'use strict';\nvar call = require('../internals/function-call');\nvar getBuiltIn = require('../internals/get-built-in');\nvar getMethod = require('../internals/get-method');\n\nmodule.exports = function (iterator, method, argument, reject) {\n try {\n var returnMethod = getMethod(iterator, 'return');\n if (returnMethod) {\n return getBuiltIn('Promise').resolve(call(returnMethod, iterator)).then(function () {\n method(argument);\n }, function (error) {\n reject(error);\n });\n }\n } catch (error2) {\n return reject(error2);\n } method(argument);\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar _exportNames = {\n createDragDropActions: true,\n manager: true\n};\nexports.createDragDropActions = createDragDropActions;\nvar _beginDragJs = require(\"./beginDrag.js\");\nvar _publishDragSourceJs = require(\"./publishDragSource.js\");\nvar _hoverJs = require(\"./hover.js\");\nvar _dropJs = require(\"./drop.js\");\nvar _endDragJs = require(\"./endDrag.js\");\nvar _typesJs = _interopRequireWildcard(require(\"./types.js\"));\nObject.keys(_typesJs).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _typesJs[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _typesJs[key];\n }\n });\n});\nfunction _interopRequireWildcard(obj) {\n if (obj && obj.__esModule) {\n return obj;\n } else {\n var newObj = {};\n if (obj != null) {\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {};\n if (desc.get || desc.set) {\n Object.defineProperty(newObj, key, desc);\n } else {\n newObj[key] = obj[key];\n }\n }\n }\n }\n newObj.default = obj;\n return newObj;\n }\n}\nfunction createDragDropActions(manager) {\n return {\n beginDrag: (0, _beginDragJs).createBeginDrag(manager),\n publishDragSource: (0, _publishDragSourceJs).createPublishDragSource(manager),\n hover: (0, _hoverJs).createHover(manager),\n drop: (0, _dropJs).createDrop(manager),\n endDrag: (0, _endDragJs).createEndDrag(manager)\n };\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.addSource = addSource;\nexports.addTarget = addTarget;\nexports.removeSource = removeSource;\nexports.removeTarget = removeTarget;\nexports.REMOVE_TARGET = exports.REMOVE_SOURCE = exports.ADD_TARGET = exports.ADD_SOURCE = void 0;\nvar ADD_SOURCE = 'dnd-core/ADD_SOURCE';\nexports.ADD_SOURCE = ADD_SOURCE;\nvar ADD_TARGET = 'dnd-core/ADD_TARGET';\nexports.ADD_TARGET = ADD_TARGET;\nvar REMOVE_SOURCE = 'dnd-core/REMOVE_SOURCE';\nexports.REMOVE_SOURCE = REMOVE_SOURCE;\nvar REMOVE_TARGET = 'dnd-core/REMOVE_TARGET';\nexports.REMOVE_TARGET = REMOVE_TARGET;\nfunction addSource(sourceId) {\n return {\n type: ADD_SOURCE,\n payload: {\n sourceId: sourceId\n }\n };\n}\nfunction addTarget(targetId) {\n return {\n type: ADD_TARGET,\n payload: {\n targetId: targetId\n }\n };\n}\nfunction removeSource(sourceId) {\n return {\n type: REMOVE_SOURCE,\n payload: {\n sourceId: sourceId\n }\n };\n}\nfunction removeTarget(targetId) {\n return {\n type: REMOVE_TARGET,\n payload: {\n targetId: targetId\n }\n };\n}","import React, { useState, useEffect, useRef } from 'react';\nimport Datepicker from \"react-tailwindcss-datepicker\";\nimport moment from 'moment';\n\nconst TransactionFilterForm = (props) => {\n const {\n startDate,\n endDate,\n searchValue = \"\",\n basePath = '/dashboard/reports',\n } = props;\n\n const [startDateVal, setStartDateVal] = useState((!!startDate ? moment.unix(Number(startDate)).format(\"YYYY-MM-DD\") : null));\n const [endDateVal, setEndDateVal] = useState((!!endDate ? moment.unix(Number(endDate)).format(\"YYYY-MM-DD\") : null));\n // console.log(\"startdate\", (!!startDate ? moment.unix(Number(startDate)).format(\"YYYY-MM-DD\") : null))\n\n const handleDatesChanged = ({ startDate, endDate }) => {\n if (!!startDate && !!endDate) {\n setStartDateVal(moment(startDate).utc(true).startOf('day').format(\"YYYY-MM-DD\"));\n setEndDateVal(moment(endDate).utc(true).endOf('day').format(\"YYYY-MM-DD\"));\n } else {\n setStartDateVal(null);\n setEndDateVal(null);\n }\n };\n\n const setUnixStart = (date) => {\n if (!date) return null\n return moment(date).utc(true).startOf('day').format('X')\n }\n const setUnixEnd = (date) => {\n if (!date) return null\n return moment(date).utc(true).endOf('day').format('X')\n }\n\n // ?charge_time_end=1676159999&charge_time_start=1675814400&search_value=asdfsdf\n return (\n \n );\n};\n\nexport default TransactionFilterForm;\n","import React, { useCallback, useState, useMemo, useRef } from 'react'\nimport { useDrop } from 'react-dnd'\nimport { NativeTypes } from 'react-dnd-html5-backend'\nimport { generateId } from '../../utils/genIds';\n\nconst Container = (props) => {\n const id = generateId();\n const isActive = canDrop && isOver\n const fileInput = useRef(null);\n const { buttonText, name, acceptedTypes } = props\n const [error, setError] = useState('');\n const [fileName, setFileName] = useState('');\n\n const validateFileType = (file) => {\n if (!acceptedTypes.length) return true; // Any file type is valid if we don't pass an array of accepted types..\n return acceptedTypes.includes(file.name.split('.').pop());\n };\n\n const [droppedFiles, setDroppedFiles] = useState([])\n\n const handleFileDrop = useCallback(\n (item) => {\n if (item) {\n const files = item.files\n fileInput.current.files = item.dataTransfer.files\n setFileName(files[0].name)\n setDroppedFiles(files)\n }\n },\n [setDroppedFiles],\n )\n\n const [{ canDrop, isOver }, drop] = useDrop(\n () => ({\n accept: [NativeTypes.FILE],\n drop(item) {\n handleFileDrop(item)\n },\n canDrop(item) {\n // console.log('canDrop', item.files, item.items)\n return true\n },\n hover(item) {\n // console.log('hover', item.files, item.items)\n },\n collect: (monitor) => {\n const item = monitor.getItem()\n if (item) {\n // console.log('collect', item.files, item.items)\n }\n return {\n isOver: monitor.isOver(),\n canDrop: monitor.canDrop(),\n }\n },\n }),\n [props],\n )\n\n\n const handleClick = () => {\n fileInput.current.click();\n };\n\n // max file size in bytes (10MB)\n const MAX_FILE_SIZE = 10000000;\n const handleChange = (e) => {\n if (e.target.files[0].size > MAX_FILE_SIZE) {\n setError('File is too large. Please resize image before uploading.');\n return;\n }\n\n if (!validateFileType(e.target.files[0])) {\n setError(`File type must be one of ${acceptedTypes.join(', ')}.`);\n return;\n }\n setDroppedFiles(e.target.files)\n // setDroppedFiles(fileInput.current.files)\n\n setFileName(e.target.files[0].name);\n\n\n // if (previewType === 'name') setFileName(e.target.files[0].name);\n\n // if (!!error) setError('');\n\n // setImage({\n // preview: URL.createObjectURL(e.target.files[0]),\n // raw: e.target.files[0],\n // });\n };\n\n\n return (\n <>\n \n\n \n\n {fileName}
\n\n {error && (\n \n {error}\n
\n )}\n >\n )\n}\n\nfunction list(files) {\n const label = (file) =>\n `'${file.name}' of size '${file.size}' and type '${file.type}'`\n return files.map((file) => {label(file)})\n}\n\nconst FileList = ({ files }) => {\n if (files.length > 0) {\n const fileList = useMemo(() => list(files), [files])\n return {fileList}
\n } else {\n return \n }\n}\n\n\nexport default Container","import React, { useState, useEffect, useRef } from 'react';\nimport { generateId } from '../utils/genIds';\nimport { ToolTip } from './FormInput';\n\n// max file size in bytes (5MB)\nconst MAX_FILE_SIZE = 5000000;\n\nconst FileField = (props) => {\n const {\n label,\n initialValue,\n errors,\n name,\n hasMaxSize = true,\n buttonText = 'Change',\n previewType = 'image',\n acceptedTypes = [],\n toolTip,\n } = props;\n const id = generateId();\n const [image, setImage] = useState({ preview: initialValue, raw: '' });\n const [error, setError] = useState('');\n const [fileName, setFileName] = useState('');\n const fileInput = useRef(null);\n\n useEffect(() => {\n if (initialValue) {\n setImage({ preview: initialValue, raw: '' });\n }\n }, []);\n\n const handleClick = () => {\n fileInput.current.click();\n };\n\n const handleChange = (e) => {\n if (hasMaxSize && e.target.files[0].size > MAX_FILE_SIZE) {\n setError('File is too large. Please resize image before uploading.');\n return;\n }\n\n if (!validateFileType(e.target.files[0])) {\n setError(`File type must be one of ${acceptedTypes.join(', ')}.`);\n return;\n }\n\n if (previewType === 'name') setFileName(e.target.files[0].name);\n\n if (!!error) setError('');\n\n setImage({\n preview: URL.createObjectURL(e.target.files[0]),\n raw: e.target.files[0],\n });\n };\n\n const validateFileType = (file) => {\n if (!acceptedTypes.length) return true; // Any file type is valid if we don't pass an array of accepted types..\n\n return acceptedTypes.includes(file.name.split('.').pop());\n };\n\n const renderPreviewImage = () => {\n return image.preview ? (\n
\n ) : (\n \n \n \n );\n };\n\n const renderPreviewName = () => {\n return {fileName};\n };\n\n return (\n <>\n \n \n {previewType === 'image' && renderPreviewImage()}\n\n
\n \n \n \n\n {previewType === 'name' && renderPreviewName()}\n\n {errors.map((e, i) => {\n return (\n
\n {e}\n
\n );\n })}\n
\n {!!error && (\n \n )}\n >\n );\n};\n\nexport default FileField;\n","import React, { useState } from \"react\";\n\nconst Icon = ({ type }) => {\n if (type == \"notice\") {\n return (\n \n );\n } else if (type == \"error\") {\n return (\n \n );\n }\n return (\n \n );\n};\n\nconst FlashNotice = (props) => {\n const { type, msg } = props;\n const [show, setShow] = useState(true);\n\n let classNames = \"border-gray-500\";\n\n if (type === \"error\") {\n classNames = \"border-red-500 bg-red-100\";\n }\n\n if (type === \"notice\") {\n classNames = \"border-green-500 bg-green-100\";\n }\n\n const styles = {\n zIndex: 9999,\n };\n\n if (!show) {\n return <>>;\n }\n\n return (\n <>\n \n
\n
\n
\n
\n
\n \n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n >\n );\n};\n\nexport default FlashNotice;\n","import React from 'react';\nimport { FormSettingsProvider, useFields } from './State';\nimport FormInput from '../FormInput';\n\nexport default (props) => {\n const { fund, form_setting, errors } = props;\n\n return (\n \n \n
\n
\n Form Settings\n
\n
\n Configure your form with default fields and settings.\n
\n
\n\n
\n {!!form_setting.id && (\n
\n )}\n\n
\n Leave this blank to use the default text.\"\n errors={errors['form_setting.form_submit_text']}\n />\n
\n\n
\n
\n {(fund.fund_type === 'dues' || fund.fund_type === 'misc_dues') && (\n
\n )}\n
\n
\n
\n \n );\n};\n\nconst AddAddressFields = () => {\n const {\n state,\n toggleAddressFields,\n toggleRequireAddressFields,\n } = useFields();\n const { formSetting } = state;\n\n const onIncludeAddress = (e) => {\n toggleAddressFields(e.target.checked);\n };\n\n const onRequireAddress = (e) => {\n toggleRequireAddressFields(e.target.checked);\n };\n\n return (\n \n
\n
\n\n
\n {formSetting.include_address_fields && (\n
\n
\n \n \n
\n
\n )}\n
\n );\n};\n\nconst AddMembershipIdField = () => {\n const {\n state,\n toggleMembershipIdField,\n toggleRequireMembershipIdField,\n } = useFields();\n const { formSetting } = state;\n\n const onIncludeMembershipId = (e) => {\n toggleMembershipIdField(e.target.checked);\n };\n\n const onRequireMembershipId = (e) => {\n toggleRequireMembershipIdField(e.target.checked);\n };\n\n return (\n \n
\n
\n\n
\n {formSetting.include_membership_id_field && (\n
\n
\n \n \n
\n
\n )}\n
\n );\n};\n","import React from 'react';\nimport { useFields } from './State';\n\nimport { DropDownOptions } from './DropDownOptions';\n\nexport const FieldSetContainer = (props) => {\n const { removeField, setFieldType, state } = useFields();\n const { field, index } = props;\n const namePrefix = `${state.resource_name}[form_fields_attributes][${index}]`;\n\n const handleRemoveClick = (e) => {\n e.preventDefault();\n removeField(field);\n };\n\n const handleInputTypeChange = (e) => {\n e.preventDefault();\n\n if (e.target.value === 'drop down') setFieldType(field, e.target.value);\n };\n\n return (\n <>\n {field.destroy ? (\n <>\n \n \n >\n ) : (\n <>\n {field.id ? (\n \n ) : (\n ''\n )}\n \n
\n
\n \n \n
\n\n {field.input_type !== 'checkbox' ? (\n
\n
\n
\n
\n Optionally use this to show an example to help your users\n
\n
\n ) : (\n ''\n )}\n\n
\n \n \n
\n\n
\n\n {field.input_type === 'drop down' && (\n
\n )}\n
\n
\n >\n )}\n >\n );\n};\n","import React from 'react';\nimport { useFields } from './State';\n\nconst Option = (props) => {\n const { removeOption, state } = useFields();\n const { dropdownOption, index, fieldIndex } = props;\n const namePrefix = `${state.resource_name}[form_fields_attributes][${fieldIndex}][form_select_options_attributes][${index}]`;\n\n const handleRemoveClick = (e) => {\n e.preventDefault();\n removeOption(dropdownOption);\n };\n\n return (\n <>\n {dropdownOption.destroy ? (\n <>\n \n \n >\n ) : (\n <>\n {dropdownOption.id ? (\n \n ) : (\n ''\n )}\n \n
\n
\n \n \n
\n\n
\n
\n
\n >\n )}\n >\n );\n};\n\nexport const DropDownOptions = (props) => {\n const { addOption, state } = useFields();\n const { field, fieldIndex } = props;\n\n const options = state.dropdown_options.filter(\n (o) => o?.form_field_id === field.id || o?.fieldObjectId == field.objectId\n );\n\n const handleAddOption = (e) => {\n e.preventDefault();\n addOption(field);\n };\n\n return (\n \n
\n
\n \n Configure dropdown options below\n \n\n \n \n \n
\n {options.length > 0 &&\n options.map((o, idx) => (\n
\n ))}\n
\n );\n};\n","import React, { useState, useContext, createContext, useReducer } from \"react\";\nimport { generateId } from \"../utils/genIds\";\n\nconst newDueLevel = {\n id: null,\n objectId: null,\n name: \"\",\n description: \"\",\n amount: \"\",\n destroy: false,\n status: \"active\",\n};\n\nconst initialState = {\n fund: {},\n dueLevels: [],\n};\n\nconst dueLevelsReducer = (state, action) => {\n switch (action.type) {\n case \"ADD_DUE_LEVEL\":\n return { ...state, dueLevels: [...state.dueLevels, action.dueLevel] };\n case \"SET_DUE_LEVELS\":\n return { ...state, dueLevels: action.dueLevels };\n default:\n return state;\n }\n};\n\nconst DueLevelsContext = createContext(null);\n\nconst useDueLevels = () => {\n const [state, dispatch] = useContext(DueLevelsContext);\n\n const addDueLevel = () => {\n dispatch({\n type: \"ADD_DUE_LEVEL\",\n dueLevel: { ...newDueLevel, objectId: generateId() },\n });\n };\n\n const removeDueLevel = (dueLevel) => {\n // const dueLevels = state.dueLevels\n // remove a due level if it does exist\n // toggle destroy a due level if it does exist\n if (dueLevel.id === null) {\n const newduelevels = state.dueLevels.filter(\n (dl) => dl.objectId != dueLevel.objectId\n );\n dispatch({ type: \"SET_DUE_LEVELS\", dueLevels: newduelevels });\n } else {\n const newduelevels = state.dueLevels.map((dl) => {\n if (dl.objectId === dueLevel.objectId) {\n return { ...dl, destroy: true };\n } else {\n return { ...dl };\n }\n });\n dispatch({ type: \"SET_DUE_LEVELS\", dueLevels: newduelevels });\n }\n };\n\n return { state, dispatch, addDueLevel, removeDueLevel };\n};\n\nconst DueLevelsProvider = (props) => {\n // added the form state\n\n const [state, dispatch] = useReducer(dueLevelsReducer, {\n ...initialState,\n fund: props.fund,\n dueLevels: props.dueLevels || [],\n dueLevelStatuses: props.dueLevelStatuses,\n intervalOptions: props.intervalOptions,\n });\n\n const value = React.useMemo(() => [state, dispatch], [state]);\n\n return ;\n};\n\nconst DueLevelFields = (props) => {\n const { removeDueLevel, state } = useDueLevels();\n const { dueLevelStatuses, intervalOptions } = state;\n const { dueLevel, index } = props;\n const [recurring, setRecurring] = useState(dueLevel.recurring);\n const namePrefix = `fund[due_levels_attributes][${index}]`;\n\n const handleRemoveClick = (e) => {\n e.preventDefault();\n removeDueLevel(dueLevel);\n };\n\n const handleSetRecurring = (e) => {\n const { checked } = e.target;\n\n setRecurring(checked);\n };\n\n return (\n <>\n {dueLevel.destroy ? (\n <>\n \n \n >\n ) : (\n <>\n {dueLevel.id ? (\n \n ) : (\n \"\"\n )}\n \n
\n
\n \n \n
\n\n
\n \n \n
\n\n
\n \n \n
\n\n
\n
\n Note: The recurring schedule cannot be changed once saved.\n
\n
\n \n \n \n\n {recurring && (\n \n )}\n
\n\n
\n
\n
\n
\n >\n )}\n >\n );\n};\n\nconst DueLevelsContainer = () => {\n const { state } = useDueLevels();\n return (\n <>\n {state.dueLevels.map((dueLevel, index) => {\n return (\n \n );\n })}\n >\n );\n};\n\nconst AddDueLevel = () => {\n const { addDueLevel } = useDueLevels();\n\n const handleClick = (e) => {\n e.preventDefault();\n addDueLevel();\n };\n\n return (\n <>\n \n \n \n >\n );\n};\n\nconst NestedDueLevelsFields = ({\n fund,\n dueLevels,\n dueLevelStatuses,\n intervalOptions,\n}) => {\n return (\n <>\n \n \n
\n
\n Dues Levels\n
\n
\n Make sure to update at the bottom once you've added, removed, or\n edited your dues.\n
\n
\n
\n
\n\n \n \n \n \n
\n\n \n \n >\n );\n};\nexport default NestedDueLevelsFields;\n","import React, { useRef } from 'react';\nimport { useFunds } from './StateManagement';\nimport { ItemTypes } from './ItemTypes';\n\nimport { FundHeading, FundStats, FundFooter } from './CardElements';\n\nexport const FundCard = ({ fund, index }) => {\n const { state, useDrag, useDrop, moveFund, updatePositions } = useFunds();\n const { draggable } = state;\n\n const ref = useRef(null);\n\n const [{ opacity }, drag] = useDrag({\n item: { id: fund.id, index },\n type: ItemTypes.FUND,\n collect: (monitor) => ({\n opacity: monitor.isDragging() ? 0 : 1,\n }),\n canDrag: () => draggable,\n });\n\n const [, drop] = useDrop({\n accept: ItemTypes.FUND,\n hover(item, monitor) {\n if (!ref.current) return;\n\n const dragIndex = item.index;\n const hoverIndex = index;\n\n // Don't replace items with themselves\n if (dragIndex === hoverIndex) return;\n\n // Determine rectangle on screen\n const hoverBoundingRect = ref.current?.getBoundingClientRect();\n\n // Get vertical middle\n const hoverMiddleY =\n (hoverBoundingRect.bottom - hoverBoundingRect.top) / 2;\n\n // Determine mouse position\n const clientOffset = monitor.getClientOffset();\n // Get pixels to the top\n const hoverClientY = clientOffset.y - hoverBoundingRect.top;\n // Only perform the move when the mouse has crossed half of the items height\n // When dragging downwards, only move when the cursor is below 50%\n // When dragging upwards, only move when the cursor is above 50%\n // Dragging downwards\n if (dragIndex < hoverIndex && hoverClientY < hoverMiddleY - 100) return;\n\n // Dragging upwards\n if (dragIndex > hoverIndex && hoverClientY > hoverMiddleY + 100) return;\n\n // Time to actually perform the action\n moveFund(dragIndex, hoverIndex);\n // Note: we're mutating the monitor item here!\n // Generally it's better to avoid mutations,\n // but it's good here for the sake of performance\n // to avoid expensive index searches.\n item.index = hoverIndex;\n },\n drop(item) {\n updatePositions(item);\n },\n });\n\n drag(drop(ref));\n\n return (\n \n );\n};\n","import React from \"react\";\nimport { useForm, singleChargeSubmit } from \"./provider\";\n// import { PaymentMethodSection } from \"./StripeComponents\";\nimport axios from \"../../utils/requests\";\nimport { prettyDate } from \"../../utils/formatters\";\n\n\nexport const CardPaymentPage = (props) => {\n const { state, dispatch, chargeData, stripe, elements } = useForm();\n\n const handleSubmit = async (event) => {\n event.preventDefault();\n const resp = await singleChargeSubmit({ dispatch, state, chargeData, stripe, elements, })\n\n if (resp.success) {\n // go to the create payment step\n props.goToNamedStep('success_page')\n }\n if (resp.error) {\n dispatch({ type: \"SET_ERRORS\", errors: { base: resp.error.response.data.error } });\n }\n };\n\n const handleBackClick = () => {\n dispatch({ type: \"SET_OFFLINE_PAYMENT\", offlinePayment: false })\n props.goToNamedStep(\"pick_payment_method\")\n }\n return (\n <>\n \n \n Confirm Payment\n
\n \n >\n );\n};\n\nconst OfflinePaymentNotes = () => {\n const { state, dispatch } = useForm();\n const { notes } = state;\n\n const handleChange = (e) => {\n dispatch({ type: \"SET_NOTES\", notes: e.target.value })\n }\n\n return <>\n \n (IE: check number)
\n \n >\n}\n\nconst SubmitBtn = () => {\n const { state, chargeData, stripe } = useForm();\n const { fund, loading } = state;\n const currentChargeData = chargeData()\n\n const btnLoading = !stripe || loading;\n let buttonStyles = \"w-full mt-2 text-center text-xl px-3 py-4 mx-auto border border-transparent text-md leading-4 font-body font-medium rounded-md text-white ease-in-out transition focus:outline-none \"\n if (btnLoading || currentChargeData.amount < 1 || isNaN(currentChargeData.amount)) {\n buttonStyles = buttonStyles.concat(\"bg-indigo-200\")\n } else {\n buttonStyles = buttonStyles.concat(\"bg-indigo-600 hover:bg-indigo-800 focus:border-indigo-700 focus:ring-indigo active:bg-indigo-700 duration-150\")\n }\n\n // const buttonText = fund.form_submit_text;\n const buttonText = `Pay ${currentChargeData.amount > 0 ? '$' + currentChargeData.total : \"\"} ${fund.amount_currency != \"USD\" ? fund.amount_currency : \"\"}`\n\n return (\n \n );\n};\n\nconst Summary = () => {\n const { state, setInvoices, chargeData } = useForm();\n const { invoices, fund } = state;\n const currentChargeData = chargeData()\n\n return (\n <>\n\n \n\n \n \n
- Subtotal
\n - \n {currentChargeData.amount > 0 ? `$` + currentChargeData.amount.toFixed(2) : \"\"}\n {fund.amount_currency != \"USD\" && ` ${fund.amount_currency}`}\n
\n \n\n \n
- Processing Fee
\n - \n {currentChargeData.amount > 0 ? `$` + currentChargeData.totalFee : \"\"}\n {fund.amount_currency != \"USD\" && ` ${fund.amount_currency}`}\n
\n \n \n
- Total
\n - \n {currentChargeData.amount > 0 ? `$` + currentChargeData.total : \"\"}\n {fund.amount_currency != \"USD\" && ` ${fund.amount_currency}`}\n
\n \n
\n >\n );\n};\n\nconst LegalCopy = () => {\n const { autoPay } = useForm();\n return (\n <>\n \n >\n );\n};\n\n","import React from 'react';\nimport { useForm } from \"./provider\";\nimport { CheckCircleIcon, TrashIcon } from '@heroicons/react/20/solid'\n\nexport const PickPaymentMethodPage = (props) => {\n const { state } = useForm();\n const { offline_payments_enabled } = state;\n return (\n <>\n \n amount due: ${state.chargeData.total} \n
\n \n Pick a Payment Method\n
\n \n {offline_payments_enabled && }\n \n {state.paymentMethods.length > 0 ? (\n state.paymentMethods.map((paymentMethod, index) => { return })\n ) : null}\n
\n >\n )\n}\n\n\nconst OfflineCard = ({ goToNamedStep }) => {\n const { dispatch } = useForm();\n const handleClick = () => {\n dispatch({type: \"SET_OFFLINE_PAYMENT\", offlinePayment: true })\n goToNamedStep(\"card_payment_page\")\n }\n\n return (\n \n \n \n Make Offline Payment\n ie: check or money order\n {/* $5.00 */}\n \n \n {/* */}\n \n
\n )\n}\n\nconst CreateNewCard = ({ goToNamedStep }) => {\n return (\n goToNamedStep(\"create_payment_method_page\")} className=\"relative hover:bg-gray-50 flex cursor-pointer rounded-lg border bg-white p-4 shadow-sm focus:outline-none border-transparent undefined transition ease-in-out transform hover:scale-105\">\n
\n \n New Payment Method\n add a card to make the payment\n {/* $5.00 */}\n \n \n
\n\n
\n
\n )\n}\n\n\nconst Card = ({ paymentMethod, goToNamedStep }) => {\n const { card } = paymentMethod\n\n const { setPaymentMethod } = useForm();\n const handleSubmit = (e) => {\n setPaymentMethod(paymentMethod)\n goToNamedStep(\"card_payment_page\")\n }\n return (\n \n
\n \n \n {card.brand === \"visa\" ? (\n \n ) :\n \n {card.brand}\n
\n }\n \n ending in {card.last4}\n {card.exp_month}/{card.exp_year} \n \n \n {/*
*/}\n
\n
\n )\n}\n","import React from 'react';\nimport { useForm } from './provider';\n\nexport const OfflinePaymentPage = (props) => {\n const { state, dispatch } = useForm();\n const onSubmit = (event) => {\n event.preventDefault();\n // dispatch({ type: \"SET_LOADING\", payload: true });\n // dispatch({ type: \"SET_ERROR\", payload: null });\n // dispatch({ type: \"SET_SUCCESS\", payload: null });\n // const { stripe, elements } = state;\n // singleChargeSubmit({ state, dispatch, stripe, elements });\n };\n\n return (\n <>\n \n\n\n \n >\n )\n}\n","import React, { useState } from 'react';\nimport { createPaymentMethod, useForm } from './provider';\nimport { CardElement } from '@stripe/react-stripe-js';\nimport axios from \"../../utils/requests\";\n\nconst CARD_OPTIONS = {\n hidePostalCode: false,\n iconStyle: 'solid',\n style: {\n base: {\n color: '#303238',\n fontSize: '16px',\n fontFamily: '\"Rubik\", sans-serif',\n fontSmoothing: 'antialiased',\n '::placeholder': {\n color: '#6B6B6B',\n },\n },\n invalid: {\n color: '#e5424d',\n ':focus': {\n color: '#303238',\n },\n },\n },\n};\n\nexport const NewPaymentMethodSection = (props) => {\n const { state, dispatch, stripe, elements } = useForm();\n const { errors } = state;\n const [errorClass, setErrorClass] = useState('');\n\n const handleChange = (event) => {\n // could show the error here if we wanted to\n const { error } = event;\n\n if (!!error) {\n setErrorClass('border-red-600');\n } else {\n setErrorClass('');\n }\n };\n\n const handleSubmit = async (event) => {\n event.preventDefault();\n dispatch({ type: \"TOGGLE_LOADING\" });\n const resp = await createPaymentMethod({ state, dispatch, stripe, elements });\n // return early and show errors if payment method doesnt create on stripe\n if (resp.error) {\n dispatch({ type: \"TOGGLE_LOADING\" });\n dispatch({\n type: \"SET_ERRORS\",\n errors: { base: [resp.error.message] },\n });\n return;\n }\n\n try {\n await axios.post(\n state.create_card_path,\n {\n payment_method: resp.paymentMethod\n }\n );\n } catch (error) {\n dispatch({ type: \"TOGGLE_LOADING\" });\n dispatch({ type: \"SET_ERRORS\", errors: { base: error.response.data.error } });\n return\n }\n dispatch({ type: \"TOGGLE_LOADING\" });\n // set payment method id on the state so we dont do it again.\n dispatch({\n type: \"SET_PAYMENT_METHOD\",\n paymentMethod: resp.paymentMethod,\n });\n\n // go to the create payment step\n props.goToNamedStep('card_payment_page')\n };\n\n return (\n <>\n \n >\n )\n\n}\n\nconst SubmitBtn = () => {\n const { state, stripe } = useForm();\n const { amount, loading } = state;\n\n const btnLoading = !stripe || loading;\n let buttonStyles = \"w-full text-center py-3 border border-transparent leading-4 rounded-md text-white ease-in-out transition focus:outline-none \"\n if (btnLoading || amount < 1 || isNaN(amount)) {\n buttonStyles = buttonStyles.concat(\"bg-indigo-200\")\n } else {\n buttonStyles = buttonStyles.concat(\"bg-indigo-600 hover:bg-indigo-800 focus:border-indigo-700 focus:ring-indigo active:bg-indigo-700 duration-150\")\n }\n\n const buttonText = \"Save\"\n\n return (\n \n );\n};\n\nexport const CreatePaymentMethodPage = (props) => {\n return (\n <>\n \n \n Create Card\n
\n \n >\n )\n}","import React from 'react';\nimport { PlusIcon } from '@heroicons/react/20/solid'\nimport { useForm } from './provider';\n\nexport const SuccessPage = (props) => {\n const { state } = useForm();\n const { fund, member, success_redirect_path } = state;\n return (\n \n
\n\n
Success!
\n
Payment Was made Successfully.
\n
\n
\n )\n}\n","import React, { useState, useRef, useEffect } from 'react';\nimport { MagnifyingGlassIcon } from '@heroicons/react/20/solid'\nimport axios from \"../../utils/requests\";\n\nexport default function SearchMembers({ setFilteredMembers, fund }) {\n\n const [search, setSearch] = useState('')\n const searchRef = useRef(null);\n\n useEffect(() => {\n const getData = setTimeout(() => {\n axios\n .get(`/dashboard/invoicing/${fund.id}/members.json?search_value=${search}`)\n .then((response) => {\n setFilteredMembers(response.data)\n });\n }, 500)\n\n return () => clearTimeout(getData)\n }, [search]);\n\n const handleSubmit = (e) => {\n e.preventDefault()\n }\n\n\n return (\n \n )\n\n}","import React, { useRef } from \"react\";\nimport { useProducts } from \"./StateManagement\";\nimport { ItemTypes } from \"./ItemTypes\";\n\nimport { ProductHeading, ProductStatus } from \"./CardElements\";\n\nexport const ProductCard = ({ product, index }) => {\n const {\n state,\n useDrag,\n useDrop,\n moveProduct,\n updatePositions,\n } = useProducts();\n const { draggable } = state;\n\n const ref = useRef(null);\n\n const [{ opacity }, drag] = useDrag({\n item: { id: product.id, index },\n type: ItemTypes.PRODUCT,\n collect: (monitor) => ({\n opacity: monitor.isDragging() ? 0 : 1,\n }),\n canDrag: () => draggable,\n });\n\n const [, drop] = useDrop({\n accept: ItemTypes.PRODUCT,\n hover(item, monitor) {\n if (!ref.current) return;\n\n const dragIndex = item.index;\n const hoverIndex = index;\n\n // Don't replace items with themselves\n if (dragIndex === hoverIndex) return;\n\n // Determine rectangle on screen\n const hoverBoundingRect = ref.current?.getBoundingClientRect();\n\n // Get vertical middle\n const hoverMiddleY =\n (hoverBoundingRect.bottom - hoverBoundingRect.top) / 2;\n\n // Determine mouse position\n const clientOffset = monitor.getClientOffset();\n // Get pixels to the top\n const hoverClientY = clientOffset.y - hoverBoundingRect.top;\n // Only perform the move when the mouse has crossed half of the items height\n // When dragging downwards, only move when the cursor is below 50%\n // When dragging upwards, only move when the cursor is above 50%\n // Dragging downwards\n if (dragIndex < hoverIndex && hoverClientY < hoverMiddleY - 100) return;\n\n // Dragging upwards\n if (dragIndex > hoverIndex && hoverClientY > hoverMiddleY + 100) return;\n\n // Time to actually perform the action\n moveProduct(dragIndex, hoverIndex);\n // Note: we're mutating the monitor item here!\n // Generally it's better to avoid mutations,\n // but it's good here for the sake of performance\n // to avoid expensive index searches.\n item.index = hoverIndex;\n },\n drop(item) {\n updatePositions(item);\n },\n });\n\n drag(drop(ref));\n\n return (\n \n \n \n \n \n | \n {product.price_dollars} | \n {product.quantity} | \n \n \n | \n \n \n View\n \n \n Edit\n \n | \n\n {/* 1203 | */}\n
\n );\n};\n","import React from \"react\"\n\nimport { InlineShareButtons } from \"sharethis-reactjs\";\n\n// https://github.com/sharethis-github/sharethis-reactjs#readme\n\n\n// this is a monkey patch of the share loader so the loader runs every time.\n// turbolinks!!!\n// load project wrapper\nconst load = function (component, product) {\n\n // load config\n let config = component.props.config || { enabled: true };\n config = JSON.parse(JSON.stringify(config));\n\n // load buttons\n const _onShareThisLoaded = window.onShareThisLoaded;\n let onload = () => {\n if (!onload.complete) {\n if (!config.id) {\n const id = 'sharethis-' + Date.now();\n config.id = id;\n }\n if (component.buttons.current) {\n component.buttons.current.id = config.id;\n window.__sharethis__.load(product, config);\n }\n if (_onShareThisLoaded) {\n _onShareThisLoaded();\n }\n onload.complete = true;\n }\n };\n window.onShareThisLoaded = onload;\n\n // load sharethis.js\n if (document.getElementById('sharethis-js')) {\n if (window.__sharethis__) {\n window.onShareThisLoaded();\n }\n } else {\n const script = document.createElement(\"script\");\n script.setAttribute('id', 'sharethis-js');\n const params = {\n property: config.property || '',\n product: product,\n source: 'reactjs'\n }\n const query = Object.keys(params).map(key => key + '=' + params[key]).join('&');\n script.src = \"https://platform-api.sharethis.com/js/sharethis.js?\" + query;\n script.async = true;\n document.body.appendChild(script);\n }\n}\n\n\nclass MonkeyPatchButtons extends InlineShareButtons {\n componentDidMount() {\n load(this, 'inline-share-buttons');\n }\n};\n\nconst ShareThis = (props) => {\n const { alignment, url, description, title, emailMessage, emailSubject, networks } = props\n\n return (\n <>\n \n \n
\n\n >\n );\n}\n\nexport default ShareThis\n","import React from 'react';\nimport { CardElement, PaymentElement } from '@stripe/react-stripe-js';\nimport { useCheckout } from './StateManagement';\n\nconst CARD_OPTIONS = {\n iconStyle: 'solid',\n style: {\n base: {\n color: '#303238',\n fontSize: '16px',\n fontFamily: '\"Rubik\", sans-serif',\n fontSmoothing: 'antialiased',\n '::placeholder': {\n color: '#6B6B6B',\n },\n },\n invalid: {\n color: '#e5424d',\n ':focus': {\n color: '#303238',\n },\n },\n },\n};\n\nexport const PaymentMethodSection = () => {\n const {\n setPaymentMethod,\n state: { paymentMethods, paymentMethod, user },\n } = useCheckout();\n\n // console.log(\"Payment Methods \" + paymentMethods);\n\n const handleNewMethod = () => {\n setPaymentMethod({ id: null });\n };\n\n const useCard = () => {\n setPaymentMethod({ id: paymentMethods[0].id });\n };\n\n if (user.id && paymentMethods && paymentMethod) {\n return (\n <>\n \n
\n\n {paymentMethods.map((p, i) => {\n return
;\n })}\n
\n {' '}\n or{' '}\n \n {' '}\n use new card{' '}\n \n
\n\n
\n >\n );\n }\n\n return (\n <>\n \n
\n
\n {paymentMethods ? (\n
{' '}or{' '}\n {' '}use previously saved card{' '}\n \n
\n ) : (\n ''\n )}\n
\n >\n );\n};\n\nconst PaymentMethodCard = ({ method }) => {\n const {\n setPaymentMethod,\n state: { paymentMethod },\n } = useCheckout();\n\n const handleClick = () => {\n setPaymentMethod(method);\n };\n const active = paymentMethod === method.id;\n\n return (\n <>\n \n
\n
\n {!active || }\n
\n\n
{method.card.brand}
\n
**** **** **** {method.card.last4}
\n
\n\n
\n {method.card.exp_month} / {method.card.exp_year}\n
\n
\n >\n );\n};\n\nfunction CheckIcon(props) {\n return (\n \n );\n}\n","import React from \"react\"\nimport { useForm } from \"./StateManagement\"\nimport ShareThis from \"../ShareThis.jsx\"\n\nexport const ReceiptComponent = () => {\n const { state: { chargeData, user, organization, saveBillingInfo, currentDueLevel, autoPay, force_autopay } } = useForm();\n\n let showSubscriptionText = autoPay\n showSubscriptionText = (currentDueLevel && currentDueLevel.recurring && force_autopay)\n\n return <>\n {organization.id == 77 ? : ''}\n {showSubscriptionText ? Success! Subscription Created.
\n :\n Success! Transaction complete.
\n }\n Summary
\n \n
Payment: ${chargeData.amount}
\n
Processing Fee: ${chargeData.totalFee}
\n
\n
Total: ${chargeData.total}
\n
\n\n {saveBillingInfo ?\n A receipt and account confirmation email has been emailed to {user.email}.
\n :\n A receipt has been emailed to {user.email}.
\n }\n >\n}\n\nconst ThankYou = () => {\n return (\n <>\n \n \n
\n \n
\n
Please consider sharing on social media!
\n
\n >\n );\n};\n","import React from 'react';\nimport {\n useForm,\n handleFormSubmit,\n} from './StateManagement';\nimport { DuesAmountInput, AmountInput, Input } from './FormInputs';\n\nexport const DuesForm = ({ children }) => {\n const { state, dispatch, stripe, elements } = useForm();\n const { organization, formSetting } = state;\n\n const handleSubmit = async (event) => {\n event.preventDefault();\n handleFormSubmit({ state, dispatch, stripe, elements });\n };\n\n const memberIdLabel = organization.membership_label\n ? organization.membership_label\n : 'Membership ID';\n\n return (\n \n );\n};\n","import React from 'react';\nimport { useForm, singleChargeSubmit, loggedInSubmit } from './StateManagement';\nimport { AmountInput, Input } from './FormInputs';\n\nexport const SingleChargeForm = ({ children }) => {\n const { state, dispatch, stripe, elements } = useForm();\n const { organization, fund, formSetting } = state;\n\n const handleSubmit = (event) => {\n event.preventDefault();\n singleChargeSubmit({ state, dispatch, stripe, elements });\n };\n\n const memberIdLabel = organization.membership_label\n ? organization.membership_label\n : 'Membership ID';\n\n return (\n \n );\n};\n","import React, { useState } from 'react';\nimport { CardElement } from '@stripe/react-stripe-js';\nimport { useForm } from './StateManagement';\n\nconst CARD_OPTIONS = {\n hidePostalCode: false,\n iconStyle: 'solid',\n style: {\n base: {\n color: '#303238',\n fontSize: '16px',\n fontFamily: '\"Rubik\", sans-serif',\n fontSmoothing: 'antialiased',\n '::placeholder': {\n color: '#6B6B6B',\n },\n },\n invalid: {\n color: '#e5424d',\n ':focus': {\n color: '#303238',\n },\n },\n },\n};\n\nexport const PaymentMethodSection = () => {\n const {\n setPaymentMethod,\n state: { paymentMethods, paymentMethod, user, formSetting },\n } = useForm();\n\n const [errorClass, setErrorClass] = useState('');\n\n const handleNewMethod = () => {\n setPaymentMethod({ id: null });\n };\n\n const useCard = () => {\n setPaymentMethod({ id: paymentMethods[0].id });\n };\n\n const handleChange = (event) => {\n const { error } = event;\n\n if (!!error) {\n setErrorClass('border-red-600');\n } else {\n setErrorClass('');\n }\n };\n\n if (formSetting.include_address_fields) {\n CARD_OPTIONS[\"hidePostalCode\"] = true;\n }\n\n if (user.id && paymentMethods && paymentMethod) {\n return (\n <>\n \n
\n\n {paymentMethods.map((p, i) => {\n return
;\n })}\n
\n {' '}\n or{' '}\n \n {' '}\n use new card{' '}\n \n
\n
\n >\n );\n }\n\n return (\n <>\n \n
\n
\n \n
\n
\n >\n );\n};\n\nconst PaymentMethodCard = ({ method }) => {\n const {\n setPaymentMethod,\n state: { paymentMethod },\n } = useForm();\n\n const handleClick = () => {\n setPaymentMethod(method);\n };\n const active = paymentMethod === method.id;\n\n return (\n <>\n \n
\n
\n {!active || }\n
\n\n
{method.card.brand}
\n
**** **** **** {method.card.last4}
\n
\n\n
\n {method.card.exp_month} / {method.card.exp_year}\n
\n
\n >\n );\n};\n\nfunction CheckIcon(props) {\n return (\n \n );\n}\n","/*\n This example requires some changes to your config:\n\n ```\n // tailwind.config.js\n module.exports = {\n // ...\n plugins: [\n // ...\n require('@tailwindcss/forms'),\n ],\n }\n ```\n*/\n\nimport React, { useState } from 'react'\nimport { CheckIcon, ChevronUpDownIcon } from '@heroicons/react/20/solid'\nimport { Combobox } from '@headlessui/react'\nimport { calcFee } from \"../../utils/stripeFee\";\n\nfunction classNames(...classes) {\n return classes.filter(Boolean).join(' ')\n}\n\nexport default function Dropdown({ due_levels, fee_model, selectedDueLevel, setSelectedDueLevel }) {\n const dueLevels = due_levels\n const [query, setQuery] = useState('')\n\n const filteredDueLevels =\n query === ''\n ? dueLevels\n : dueLevels.filter((dl) => {\n return dl.name.toLowerCase().includes(query.toLowerCase())\n })\n\n return (\n \n Assigned to\n \n setQuery(event.target.value)}\n displayValue={(dueLevel) => {\n if (dueLevel) {\n return `$${calcFee(dueLevel.amount, fee_model, true).total} - ${dueLevel?.name}`\n }\n }\n }\n />\n \n \n \n\n {filteredDueLevels.length > 0 && (\n \n {filteredDueLevels.map((dl) => (\n ))}\n \n )}\n
\n \n )\n}\n\nfunction OptionItem({ due_level, fee_model }) {\n const amount = calcFee(parseFloat(due_level.amount), fee_model, true)\n return (\n \n classNames(\n 'relative cursor-default select-none py-2 pl-3 pr-9',\n active ? 'bg-indigo-600 text-white' : 'text-gray-900'\n )\n }\n >\n {({ active, selected }) => (\n <>\n ${amount.total} - {due_level.name}\n {selected && (\n \n \n \n )}\n >\n )}\n \n )\n\n}","var _excluded = [\"title\", \"titleId\"];\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nimport * as React from \"react\";\nfunction TrashIcon(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 24 24\",\n fill: \"currentColor\",\n \"aria-hidden\": \"true\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n fillRule: \"evenodd\",\n d: \"M16.5 4.478v.227a48.816 48.816 0 013.878.512.75.75 0 11-.256 1.478l-.209-.035-1.005 13.07a3 3 0 01-2.991 2.77H8.084a3 3 0 01-2.991-2.77L4.087 6.66l-.209.035a.75.75 0 01-.256-1.478A48.567 48.567 0 017.5 4.705v-.227c0-1.564 1.213-2.9 2.816-2.951a52.662 52.662 0 013.369 0c1.603.051 2.815 1.387 2.815 2.951zm-6.136-1.452a51.196 51.196 0 013.273 0C14.39 3.05 15 3.684 15 4.478v.113a49.488 49.488 0 00-6 0v-.113c0-.794.609-1.428 1.364-1.452zm-.355 5.945a.75.75 0 10-1.5.058l.347 9a.75.75 0 101.499-.058l-.346-9zm5.48.058a.75.75 0 10-1.498-.058l-.347 9a.75.75 0 001.5.058l.345-9z\",\n clipRule: \"evenodd\"\n }));\n}\nvar ForwardRef = /*#__PURE__*/React.forwardRef(TrashIcon);\nexport default ForwardRef;","export function calcStoreFee(amountCents, feeModel) {\n if (feeModel.fee_type === \"union_pays\") {\n return 0;\n } else {\n const amountWithFees = storeAmountIncludingFeeCents(amountCents, feeModel);\n return amountWithFees - amountCents; \n }\n}\n\nfunction storeUnionlyFeeCents(amountCents, feeModel) {\n const amount = amountCents * (parseFloat(feeModel.ecommerce_percent) / 100);\n return Math.round(amount);\n}\n\nfunction storeAmountIncludingFeeCents(amountCents, feeModel) {\n const amount = (amountCents + storeUnionlyFeeCents(amountCents, feeModel)) / 100;\n return Math.round(((amount + parseFloat(feeModel.fixed)) / (1 - (parseFloat(feeModel.percent) / 100))) * 100);\n}","import React, { useState } from \"react\";\nimport { TrashIcon } from '@heroicons/react/24/solid';\nimport { useCheckout } from './StateManagement';\nimport { useEffect } from 'react';\nimport { NumericFormat } from \"react-number-format\";\nimport { calcStoreFee } from \"../../utils/storeFee\";\n\n/*\nconst cart =\n {\n productVariants:\n [\n 0: {id: 1, name: 'Small', price: {cents: 434, currency_iso: 'USD'}, product: {name: 'Test Product 1', preview_image_url: 'google.com'}}},\n 1: {id: 2, name: 'Small', price: {cents: 1000, currency_iso: 'USD'}, product: {name: 'Test Product 3', preview_image_url: 'google.com'}}}\n ],\n quantity: {1: 1, 2: 1},\n }\n*/\n\nexport const OrderSummarySection = () => {\n const { setOrderSummary, removeCartItem, shippingEnabled, state: { cart, shippingOption, orderSummary, feeModel }, } = useCheckout();\n\n useEffect(() => {\n const calculateSubtotal = () => {\n return cart.productVariants.reduce((sum, pv) => {\n const quantity = cart.quantity[pv.id] || 0;\n return sum + (pv.price.cents * quantity);\n }, 0);\n };\n\n const newSubtotal = calculateSubtotal();\n const shippingCost = shippingOption?.cost_cents || 0;\n const newFees = calcStoreFee((newSubtotal + shippingCost), feeModel);\n const newTotal = newSubtotal + shippingCost + newFees;\n\n setOrderSummary({\n subtotal: newSubtotal,\n shipping_cost: shippingCost,\n fees: newFees,\n total: newTotal,\n });\n\n }, [cart, shippingOption]);\n\n const { subtotal, shipping_cost, fees, total } = orderSummary;\n\n const handleRemoveItem = (pvId, quantity) => {\n removeCartItem(pvId, quantity);\n };\n\n return (\n \n
Order summary
\n\n
\n
Items in your cart
\n
\n {cart.productVariants.map((pv) => (\n - \n
\n

\n
\n\n \n
\n
\n\n
\n \n
\n
\n\n
\n
\n {\n \n }\n
\n\n
\n \n
\n
\n
\n \n ))}\n
\n
\n \n
- Subtotal
\n - \n {}\n
\n \n {shippingEnabled && (\n \n
- Shipping
\n - \n {shippingOption.cost_cents === 0 ? (\n
- Free
\n ) : (\n \n )}\n \n \n )}\n {fees > 0 && (\n \n
- Fees
\n - \n {}\n
\n \n )}\n \n
- Total
\n - \n {}\n
\n \n
\n
\n
\n );\n};\n\n\nconst ChangeQuantityComponent = ({ productVariant }) => {\n const { updateCartQuantity, state: { cart }, } = useCheckout();\n\n const [isChanging, setIsChanging] = useState(false);\n const [quantity, setQuantity] = useState(cart.quantity[productVariant.id] || 1);\n\n const handleUpdate = (q) => {\n if (q < 1) {\n updateCartQuantity(productVariant.id, 1);\n setQuantity(1);\n } else if (productVariant.unlimited_quantity) {\n updateCartQuantity(productVariant.id, q);\n } else if (q > productVariant.quantity) {\n updateCartQuantity(productVariant.id, productVariant.quantity);\n setQuantity(productVariant.quantity);\n } else {\n updateCartQuantity(productVariant.id, q);\n setQuantity(q);\n }\n\n setIsChanging(false);\n }\n\n return (\n \n
\n {isChanging ? (\n
\n \n setQuantity(e.target.value)}\n />\n
\n ) : (\n
\n \n {quantity}\n
\n )}\n
\n )\n}\n// const OrderSummaryCard = () => {\n// }","var _excluded = [\"title\", \"titleId\"];\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nimport * as React from \"react\";\nfunction CheckCircleIcon(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 20 20\",\n fill: \"currentColor\",\n \"aria-hidden\": \"true\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n fillRule: \"evenodd\",\n d: \"M10 18a8 8 0 100-16 8 8 0 000 16zm3.857-9.809a.75.75 0 00-1.214-.882l-3.483 4.79-1.88-1.88a.75.75 0 10-1.06 1.061l2.5 2.5a.75.75 0 001.137-.089l4-5.5z\",\n clipRule: \"evenodd\"\n }));\n}\nvar ForwardRef = /*#__PURE__*/React.forwardRef(CheckCircleIcon);\nexport default ForwardRef;","import React, { createContext, useContext, useRef, useState } from \"react\";\nimport { createStore, useStore } from 'zustand'\nimport ReactToolTip from 'react-tooltip';\nimport { generateId } from '../utils/genIds';\nimport InvoiceScheduleForm from './InvoiceScheduleForm';\nimport { Radio, RadioGroup, Transition } from '@headlessui/react'\nimport { CheckCircleIcon } from '@heroicons/react/20/solid'\n\nexport const FormContext = createContext()\n\nconst duesCalculationOptions = [\n { id: \"flatrate\", title: 'Flatrate', description: 'all members pay the same dues amount' },\n { id: \"individual\", title: 'Individual', description: 'each member pays a different amount' }\n]\n\nconst newScheduledReminder = {\n name: 'Dues Reminder',\n reminder_type: \"overdue\",\n interval: \"monthly\",\n delivery_method: \"email\",\n status: \"active\",\n days_before_or_after: 1,\n time_of_day: '12:00',\n time_zone: 'Eastern Time (US & Canada)',\n message: 'Your invoice is overdue.',\n email_subject: 'Your Union dues are overdue.'\n}\n\nconst createFundStore = (initialProps) => {\n const defaultProps = {\n invoicingFund: {},\n dueDayOptions: [],\n scheduledReminders: [],\n duesCalculationOptions: duesCalculationOptions\n }\n const selectedDuesCalculation = duesCalculationOptions.find(duesCalculation => duesCalculation.id === initialProps.invoicingFund.dues_calculation_type)\n return createStore()(set => (\n {\n ...defaultProps,\n ...initialProps,\n setSelectedDuesCalculation: (duesCalculation) => set({ selectedDuesCalculation: duesCalculation }),\n setAutoRemind: (autoRemind) => set((state) => ({ invoicingFund: { ...state.invoicingFund, auto_remind: autoRemind } })),\n setAutoInvoice: (autoInvoice) => set((state) => ({ invoicingFund: { ...state.invoicingFund, auto_invoice: autoInvoice } })),\n selectedDuesCalculation: selectedDuesCalculation,\n }))\n}\n\nfunction classNames(...classes) {\n return classes.filter(Boolean).join(' ')\n}\n\nconst CreateInvoiceFundFormProvider = (props) => {\n const formStore = useRef(createFundStore(props)).current\n return (\n \n \n \n )\n}\nconst CreateInvoiceFundForm = () => {\n const store = useContext(FormContext)\n const { invoicingFund, organization, dueDayOptions, scheduledReminders, selectedDuesCalculation } = useStore(store)\n return (\n \n {invoicingFund.id &&
}\n {invoicingFund.id &&
}\n
\n {organization.id &&
}\n
\n
\n
\n
\n
\n
\n\n
\n \n
\n
\n\n
\n \n
\n\n\n
\n \n
\n
\n
\n\n
\n
\n );\n};\n\nconst TextInput = (props) => {\n const { label, required, type, name, defaultValue, onChange, toolTip, description, options } = props\n const id = generateId()\n let fundsTypeOptions = [];\n if (type === 'select') {\n fundsTypeOptions = Object.keys(options).map((e, i) => {\n return (\n \n );\n });\n }\n\n return (\n \n
\n {!!description && (\n
{description}
\n )}\n
\n\n {type === \"select\" && (\n \n )}\n\n {type === \"text\" && (\n \n )}\n\n {type === \"textarea\" && (\n \n )}\n
\n
\n )\n}\n\nconst ToolTip = (props) => {\n const { dataForId, dataTip } = props;\n\n return (\n <>\n \n \n \n \n >\n );\n};\n\n\n\nconst RadioInputs = (props) => {\n const store = useContext(FormContext)\n const { duesCalculationOptions, selectedDuesCalculation } = useStore(store)\n const setSelectedDuesCalculation = useStore(store, (s) => s.setSelectedDuesCalculation)\n\n return (\n \n )\n}\n\nexport default CreateInvoiceFundFormProvider;","\"use client\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nvar _excluded = [\"id\", \"disabled\", \"checked\", \"defaultChecked\", \"onChange\", \"name\", \"value\", \"form\", \"autoFocus\"];\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { useFocusRing as z } from \"@react-aria/focus\";\nimport { useHover as Q } from \"@react-aria/interactions\";\nimport i, { Fragment as Y, createContext as Z, useCallback as ee, useContext as te, useMemo as L, useRef as oe, useState as S } from \"react\";\nimport { useActivePress as re } from '../../hooks/use-active-press.js';\nimport { useControllable as ne } from '../../hooks/use-controllable.js';\nimport { useDefaultValue as le } from '../../hooks/use-default-value.js';\nimport { useDisposables as ie } from '../../hooks/use-disposables.js';\nimport { useEvent as m } from '../../hooks/use-event.js';\nimport { useId as ae } from '../../hooks/use-id.js';\nimport { useResolveButtonType as se } from '../../hooks/use-resolve-button-type.js';\nimport { useSyncRefs as pe } from '../../hooks/use-sync-refs.js';\nimport { useDisabled as ce } from '../../internal/disabled.js';\nimport { FormFields as ue } from '../../internal/form-fields.js';\nimport { useProvidedId as de } from '../../internal/id.js';\nimport { isDisabledReactIssue7711 as me } from '../../utils/bugs.js';\nimport { attemptSubmit as fe } from '../../utils/form.js';\nimport { forwardRefWithAs as he, mergeProps as be, render as G } from '../../utils/render.js';\nimport { Description as Te, useDescribedBy as ye, useDescriptions as Se } from '../description/description.js';\nimport { Keys as R } from '../keyboard.js';\nimport { Label as we, useLabelledBy as Ee, useLabels as _e } from '../label/label.js';\nvar w = /*#__PURE__*/Z(null);\nw.displayName = \"GroupContext\";\nvar Pe = Y;\nfunction De(n) {\n var a;\n var _S = S(null),\n _S2 = _slicedToArray(_S, 2),\n o = _S2[0],\n p = _S2[1],\n _e2 = _e(),\n _e3 = _slicedToArray(_e2, 2),\n f = _e3[0],\n h = _e3[1],\n _Se = Se(),\n _Se2 = _slicedToArray(_Se, 2),\n b = _Se2[0],\n t = _Se2[1],\n c = L(function () {\n return {\n switch: o,\n setSwitch: p\n };\n }, [o, p]),\n T = {},\n y = n;\n return /*#__PURE__*/i.createElement(t, {\n name: \"Switch.Description\",\n value: b\n }, /*#__PURE__*/i.createElement(h, {\n name: \"Switch.Label\",\n value: f,\n props: {\n htmlFor: (a = c.switch) == null ? void 0 : a.id,\n onClick: function onClick(u) {\n o && (u.currentTarget instanceof HTMLLabelElement && u.preventDefault(), o.click(), o.focus({\n preventScroll: !0\n }));\n }\n }\n }, /*#__PURE__*/i.createElement(w.Provider, {\n value: c\n }, G({\n ourProps: T,\n theirProps: y,\n slot: {},\n defaultTag: Pe,\n name: \"Switch.Group\"\n }))));\n}\nvar ge = \"button\";\nfunction ve(n, o) {\n var C;\n var p = ae(),\n f = de(),\n h = ce(),\n _n$id = n.id,\n b = _n$id === void 0 ? f || \"headlessui-switch-\".concat(p) : _n$id,\n _n$disabled = n.disabled,\n t = _n$disabled === void 0 ? h || !1 : _n$disabled,\n c = n.checked,\n T = n.defaultChecked,\n y = n.onChange,\n a = n.name,\n u = n.value,\n A = n.form,\n _n$autoFocus = n.autoFocus,\n d = _n$autoFocus === void 0 ? !1 : _n$autoFocus,\n F = _objectWithoutProperties(n, _excluded),\n E = te(w),\n _S3 = S(null),\n _S4 = _slicedToArray(_S3, 2),\n H = _S4[0],\n k = _S4[1],\n M = oe(null),\n U = pe(M, o, E === null ? null : E.setSwitch, k),\n l = le(T),\n _ne = ne(c, y, l != null ? l : !1),\n _ne2 = _slicedToArray(_ne, 2),\n s = _ne2[0],\n r = _ne2[1],\n I = ie(),\n _S5 = S(!1),\n _S6 = _slicedToArray(_S5, 2),\n _ = _S6[0],\n P = _S6[1],\n D = m(function () {\n P(!0), r == null || r(!s), I.nextFrame(function () {\n P(!1);\n });\n }),\n B = m(function (e) {\n if (me(e.currentTarget)) return e.preventDefault();\n e.preventDefault(), D();\n }),\n K = m(function (e) {\n e.key === R.Space ? (e.preventDefault(), D()) : e.key === R.Enter && fe(e.currentTarget);\n }),\n W = m(function (e) {\n return e.preventDefault();\n }),\n O = Ee(),\n N = ye(),\n _z = z({\n autoFocus: d\n }),\n g = _z.isFocusVisible,\n J = _z.focusProps,\n _Q = Q({\n isDisabled: t\n }),\n v = _Q.isHovered,\n V = _Q.hoverProps,\n _re = re({\n disabled: t\n }),\n x = _re.pressed,\n X = _re.pressProps,\n j = L(function () {\n return {\n checked: s,\n disabled: t,\n hover: v,\n focus: g,\n active: x,\n autofocus: d,\n changing: _\n };\n }, [s, v, g, x, t, _, d]),\n $ = be({\n id: b,\n ref: U,\n role: \"switch\",\n type: se(n, H),\n tabIndex: n.tabIndex === -1 ? 0 : (C = n.tabIndex) != null ? C : 0,\n \"aria-checked\": s,\n \"aria-labelledby\": O,\n \"aria-describedby\": N,\n disabled: t || void 0,\n autoFocus: d,\n onClick: B,\n onKeyUp: K,\n onKeyPress: W\n }, J, V, X),\n q = ee(function () {\n if (l !== void 0) return r == null ? void 0 : r(l);\n }, [r, l]);\n return /*#__PURE__*/i.createElement(i.Fragment, null, a != null && /*#__PURE__*/i.createElement(ue, {\n disabled: t,\n data: _defineProperty({}, a, u || \"on\"),\n overrides: {\n type: \"checkbox\",\n checked: s\n },\n form: A,\n onReset: q\n }), G({\n ourProps: $,\n theirProps: F,\n slot: j,\n defaultTag: ge,\n name: \"Switch\"\n }));\n}\nvar xe = he(ve),\n Ce = De,\n Le = we,\n Ge = Te,\n Qe = Object.assign(xe, {\n Group: Ce,\n Label: Le,\n Description: Ge\n });\nexport { Qe as Switch, Ge as SwitchDescription, Ce as SwitchGroup, Le as SwitchLabel };","import React, { useContext, useState } from \"react\";\nimport { Switch, Field, Description, Transition } from '@headlessui/react'\nimport { FormContext } from \"./CreateInvoiceFundForm\";\nimport { useStore } from 'zustand'\n\nfunction classNames(...classes) {\n return classes.filter(Boolean).join(' ')\n}\n\n\n\nconst ReminderForm = (props) => {\n const { reminder, index } = props;\n const [daysBeforeOrAfter, setDaysBeforeOrAfter] = useState(reminder.days_before_or_after);\n return (\n \n {index === 0 &&
Reminder 1
}\n {index === 1 &&
Reminder 2
}\n {index === 2 &&
Overdue Reminder 1
}\n {reminder.id &&
}\n {['name', 'reminder_type', 'interval', 'delivery_method', 'status', 'time_of_day', 'time_zone', 'email_subject'].map((field) => (\n
\n ))}\n
\n {index === 0 && (<> The first reminder be sent out >)}\n {index === 1 && (<> Another reminder will be sent out >)}\n {index === 2 && (<> And an overdue notice will be sent out >)}\n \n {index === 0 && (\"day(s) before the due date.\")}\n {index === 1 && (\"day(s) before the due date.\")}\n {index === 2 && (\"day(s) after the due date.\")}\n
\n\n
\n
\n
\n
\n Add a short message that will appear on the email\n
\n
\n \n
\n
\n
\n
\n );\n};\n\nconst ToggleAutoReminders = ({ autoRemind, setAutoRemind }) => {\n\n return (\n <>\n Communication Schedule
\n \n \n \n This feature automatically sends emails to remind members about their dues.\n \n \n \n \n \n \n \n >\n )\n};\n\nconst ToggleAutoInvoicing = ({ autoInvoice, setAutoInvoice }) => {\n\n return (\n \n \n \n This feature automatically generates invoices for this membership type.\n \n \n \n \n \n \n \n )\n}\n\nconst InvoiceScheduleForm = (props) => {\n const store = useContext(FormContext);\n const { invoicingFund, dueDayOptions, scheduledReminders, setAutoRemind, setAutoInvoice } = useStore(store);\n const [dueDay, setDueDay] = useState(invoicingFund.due_day);\n const autoRemind = invoicingFund.auto_remind;\n const autoInvoice = invoicingFund.auto_invoice;\n return (\n \n
Enable Autopay
\n
\n
\n
\n
\n \n
Billing Schedule
\n
Upcoming dues invoices will be generated 1 month before they are due\n\n
\n\n
\n Invoices for these dues will be due on the\n \n of every month.\n
\n
\n
\n\n \n \n \n {scheduledReminders.map((reminder, index) => {\n return \n })}\n \n
\n \n
\n
\n
\n )\n}\n\nexport default InvoiceScheduleForm;","var _excluded = [\"title\", \"titleId\"];\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nimport * as React from \"react\";\nfunction CheckCircleIcon(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, _excluded);\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 24 24\",\n fill: \"currentColor\",\n \"aria-hidden\": \"true\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n fillRule: \"evenodd\",\n d: \"M2.25 12c0-5.385 4.365-9.75 9.75-9.75s9.75 4.365 9.75 9.75-4.365 9.75-9.75 9.75S2.25 17.385 2.25 12zm13.36-1.814a.75.75 0 10-1.22-.872l-3.236 4.53L9.53 12.22a.75.75 0 00-1.06 1.06l2.25 2.25a.75.75 0 001.14-.094l3.75-5.25z\",\n clipRule: \"evenodd\"\n }));\n}\nvar ForwardRef = /*#__PURE__*/React.forwardRef(CheckCircleIcon);\nexport default ForwardRef;","import React from \"react\";\nimport { RadioGroup } from '@headlessui/react';\nimport { CheckCircleIcon } from '@heroicons/react/24/solid';\nimport { useCheckout } from './StateManagement';\nimport { useState } from 'react';\nimport { NumericFormat } from \"react-number-format\";\n\n\n/* \n {id: 1, name: 'Shipping Option 1', cost: 3, delivery_time: '2-5 days'}\n*/\nexport const ShippingOptionSection = () => {\n const { state: { shippingOptions }, } = useCheckout();\n\n return (\n \n
Delivery Method
\n
\n {shippingOptions.map((s, i) => {\n return ;\n })}\n \n
\n
\n\n\n\n );\n};\n\nconst ShippingOptionCard = ({ method }) => {\n const { setShippingOption, state: { shippingOption }, } = useCheckout();\n\n const handleClick = () => {\n setShippingOption(method);\n };\n\n const active = shippingOption === method;\n\n return (\n \n
\n
\n {method.name}\n {method.cost_cents === 0 ? (\n Free\n ) : (\n \n )}\n \n {method.delivery_time}\n
\n {active && (
) }\n
\n
\n )\n\n}","var V3_URL = 'https://js.stripe.com/v3';\nvar V3_URL_REGEX = /^https:\\/\\/js\\.stripe\\.com\\/v3\\/?(\\?.*)?$/;\nvar EXISTING_SCRIPT_MESSAGE = 'loadStripe.setLoadParameters was called but an existing Stripe.js script already exists in the document; existing script parameters will be used';\nvar findScript = function findScript() {\n var scripts = document.querySelectorAll(\"script[src^=\\\"\".concat(V3_URL, \"\\\"]\"));\n for (var i = 0; i < scripts.length; i++) {\n var script = scripts[i];\n if (!V3_URL_REGEX.test(script.src)) {\n continue;\n }\n return script;\n }\n return null;\n};\nvar injectScript = function injectScript(params) {\n var queryString = params && !params.advancedFraudSignals ? '?advancedFraudSignals=false' : '';\n var script = document.createElement('script');\n script.src = \"\".concat(V3_URL).concat(queryString);\n var headOrBody = document.head || document.body;\n if (!headOrBody) {\n throw new Error('Expected document.body not to be null. Stripe.js requires a element.');\n }\n headOrBody.appendChild(script);\n return script;\n};\nvar registerWrapper = function registerWrapper(stripe, startTime) {\n if (!stripe || !stripe._registerWrapper) {\n return;\n }\n stripe._registerWrapper({\n name: 'stripe-js',\n version: \"1.47.0\",\n startTime: startTime\n });\n};\nvar stripePromise = null;\nvar loadScript = function loadScript(params) {\n // Ensure that we only attempt to load Stripe.js at most once\n if (stripePromise !== null) {\n return stripePromise;\n }\n stripePromise = new Promise(function (resolve, reject) {\n if (typeof window === 'undefined' || typeof document === 'undefined') {\n // Resolve to null when imported server side. This makes the module\n // safe to import in an isomorphic code base.\n resolve(null);\n return;\n }\n if (window.Stripe && params) {\n console.warn(EXISTING_SCRIPT_MESSAGE);\n }\n if (window.Stripe) {\n resolve(window.Stripe);\n return;\n }\n try {\n var script = findScript();\n if (script && params) {\n console.warn(EXISTING_SCRIPT_MESSAGE);\n } else if (!script) {\n script = injectScript(params);\n }\n script.addEventListener('load', function () {\n if (window.Stripe) {\n resolve(window.Stripe);\n } else {\n reject(new Error('Stripe.js not available'));\n }\n });\n script.addEventListener('error', function () {\n reject(new Error('Failed to load Stripe.js'));\n });\n } catch (error) {\n reject(error);\n return;\n }\n });\n return stripePromise;\n};\nvar initStripe = function initStripe(maybeStripe, args, startTime) {\n if (maybeStripe === null) {\n return null;\n }\n var stripe = maybeStripe.apply(undefined, args);\n registerWrapper(stripe, startTime);\n return stripe;\n}; // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n\n// own script injection.\n\nvar stripePromise$1 = Promise.resolve().then(function () {\n return loadScript(null);\n});\nvar loadCalled = false;\nstripePromise$1[\"catch\"](function (err) {\n if (!loadCalled) {\n console.warn(err);\n }\n});\nvar loadStripe = function loadStripe() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n loadCalled = true;\n var startTime = Date.now();\n return stripePromise$1.then(function (maybeStripe) {\n return initStripe(maybeStripe, args, startTime);\n });\n};\nexport { loadStripe };","module.exports = require('./lib/axios');","import { useEffect as u, useRef as n } from \"react\";\nimport { microTask as o } from '../utils/micro-task.js';\nimport { useEvent as f } from './use-event.js';\nfunction c(t) {\n var r = f(t),\n e = n(!1);\n u(function () {\n return e.current = !1, function () {\n e.current = !0, o(function () {\n e.current && r();\n });\n };\n }, [r]);\n}\nexport { c as useOnUnmount };","function a(o, r) {\n var t = o(),\n n = new Set();\n return {\n getSnapshot: function getSnapshot() {\n return t;\n },\n subscribe: function subscribe(e) {\n return n.add(e), function () {\n return n.delete(e);\n };\n },\n dispatch: function dispatch(e) {\n var _r$e;\n for (var _len = arguments.length, s = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n s[_key - 1] = arguments[_key];\n }\n var i = (_r$e = r[e]).call.apply(_r$e, [t].concat(s));\n i && (t = i, n.forEach(function (c) {\n return c();\n }));\n }\n };\n}\nexport { a as createStore };","import { useSyncExternalStore as e } from \"react\";\nfunction o(t) {\n return e(t.subscribe, t.getSnapshot, t.getSnapshot);\n}\nexport { o as useStore };","import { useEffect as a } from \"react\";\nimport { useLatestValue as f } from './use-latest-value.js';\nfunction s(t, e, o, n) {\n var i = f(o);\n a(function () {\n if (!t) return;\n function r(d) {\n i.current(d);\n }\n return window.addEventListener(e, r, n), function () {\n return window.removeEventListener(e, r, n);\n };\n }, [t, e, n]);\n}\nexport { s as useWindowEvent };","\"use client\";\n\nimport r, { createContext as n, useContext as i } from \"react\";\nvar e = /*#__PURE__*/n(function () {});\nfunction u() {\n return i(e);\n}\nfunction C(_ref) {\n var t = _ref.value,\n o = _ref.children;\n return /*#__PURE__*/r.createElement(e.Provider, {\n value: t\n }, o);\n}\nexport { C as CloseProvider, u as useClose };","import { useRef as i } from \"react\";\nimport { useIsoMorphicEffect as u } from './use-iso-morphic-effect.js';\nfunction s(n, t) {\n var e = i({\n left: 0,\n top: 0\n });\n if (u(function () {\n if (!t) return;\n var r = t.getBoundingClientRect();\n r && (e.current = r);\n }, [n, t]), t == null || !n || t === document.activeElement) return !1;\n var o = t.getBoundingClientRect();\n return o.top !== e.current.top || o.left !== e.current.left;\n}\nexport { s as useDidElementMove };","import { useEffect as T, useRef as E } from \"react\";\nimport { getOwnerDocument as d } from '../utils/owner.js';\nimport { useIsoMorphicEffect as N } from './use-iso-morphic-effect.js';\nfunction F(c, _ref) {\n var e = _ref.container,\n t = _ref.accept,\n r = _ref.walk;\n var o = E(t),\n l = E(r);\n T(function () {\n o.current = t, l.current = r;\n }, [t, r]), N(function () {\n if (!e || !c) return;\n var n = d(e);\n if (!n) return;\n var f = o.current,\n p = l.current,\n i = Object.assign(function (m) {\n return f(m);\n }, {\n acceptNode: f\n }),\n u = n.createTreeWalker(e, NodeFilter.SHOW_ELEMENT, i, !1);\n for (; u.nextNode();) p(u.currentNode);\n }, [e, c, o, l]);\n}\nexport { F as useTreeWalker };","import React from \"react\";\n\nconst days = [\n // { date: '2021-12-27' },\n // { date: '2021-12-28' },\n // { date: '2021-12-29' },\n // { date: '2021-12-30' },\n // { date: '2021-12-31' },\n { date: '2022-01-01', isCurrentMonth: true },\n { date: '2022-01-02', isCurrentMonth: true },\n { date: '2022-01-03', isCurrentMonth: true },\n { date: '2022-01-04', isCurrentMonth: true },\n { date: '2022-01-05', isCurrentMonth: true },\n { date: '2022-01-06', isCurrentMonth: true },\n { date: '2022-01-07', isCurrentMonth: true },\n { date: '2022-01-08', isCurrentMonth: true },\n { date: '2022-01-09', isCurrentMonth: true },\n { date: '2022-01-10', isCurrentMonth: true },\n { date: '2022-01-11', isCurrentMonth: true },\n { date: '2022-01-12', isCurrentMonth: true },\n { date: '2022-01-13', isCurrentMonth: true },\n { date: '2022-01-14', isCurrentMonth: true },\n { date: '2022-01-15', isCurrentMonth: true },\n { date: '2022-01-16', isCurrentMonth: true },\n { date: '2022-01-17', isCurrentMonth: true },\n { date: '2022-01-18', isCurrentMonth: true },\n { date: '2022-01-19', isCurrentMonth: true },\n { date: '2022-01-20', isCurrentMonth: true },\n { date: '2022-01-21', isCurrentMonth: true },\n { date: '2022-01-22', isCurrentMonth: true },\n { date: '2022-01-23', isCurrentMonth: true },\n { date: '2022-01-24', isCurrentMonth: true },\n { date: '2022-01-25', isCurrentMonth: true },\n { date: '2022-01-26', isCurrentMonth: true },\n { date: '2022-01-27', isCurrentMonth: true },\n { date: '2022-01-28', isCurrentMonth: true },\n // { date: '2022-01-29', isCurrentMonth: true },\n // { date: '2022-01-30', isCurrentMonth: true },\n // { date: '2022-01-31', isCurrentMonth: true },\n // { date: '2022-02-01' },\n // { date: '2022-02-02' },\n // { date: '2022-02-03' },\n // { date: '2022-02-04' },\n // { date: '2022-02-05' },\n // { date: '2022-02-06' },\n]\n\nfunction classNames(...classes) {\n return classes.filter(Boolean).join(' ')\n}\n\nconst DayPicker = ({ onChange, currentValue }) => {\n\n return (\n \n
\n
\n
\n
M
\n
T
\n
W
\n
T
\n
F
\n
S
\n
S
\n
\n
\n {days.map((day, dayIdx) => {\n const isSelected = day.date.split('-').pop().replace(/^0/, '') === currentValue.toString()\n return (\n \n )\n })}\n
\n
\n
\n
\n )\n}\n\nexport default DayPicker;","function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nvar a = /([\\u2700-\\u27BF]|[\\uE000-\\uF8FF]|\\uD83C[\\uDC00-\\uDFFF]|\\uD83D[\\uDC00-\\uDFFF]|[\\u2011-\\u26FF]|\\uD83E[\\uDD10-\\uDDFF])/g;\nfunction o(e) {\n var r, i;\n var n = (r = e.innerText) != null ? r : \"\",\n t = e.cloneNode(!0);\n if (!(t instanceof HTMLElement)) return n;\n var u = !1;\n var _iterator = _createForOfIteratorHelper(t.querySelectorAll('[hidden],[aria-hidden],[role=\"img\"]')),\n _step;\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var f = _step.value;\n f.remove(), u = !0;\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n var l = u ? (i = t.innerText) != null ? i : \"\" : n;\n return a.test(l) && (l = l.replace(a, \"\")), l;\n}\nfunction g(e) {\n var n = e.getAttribute(\"aria-label\");\n if (typeof n == \"string\") return n.trim();\n var t = e.getAttribute(\"aria-labelledby\");\n if (t) {\n var u = t.split(\" \").map(function (l) {\n var r = document.getElementById(l);\n if (r) {\n var i = r.getAttribute(\"aria-label\");\n return typeof i == \"string\" ? i.trim() : o(r).trim();\n }\n return null;\n }).filter(Boolean);\n if (u.length > 0) return u.join(\", \");\n }\n return o(e).trim();\n}\nexport { g as getTextValue };","import { useRef as l } from \"react\";\nimport { getTextValue as i } from '../utils/get-text-value.js';\nimport { useEvent as o } from './use-event.js';\nfunction s(c) {\n var t = l(\"\"),\n r = l(\"\");\n return o(function () {\n var e = c.current;\n if (!e) return \"\";\n var u = e.innerText;\n if (t.current === u) return r.current;\n var n = i(e).trim().toLowerCase();\n return t.current = u, r.current = n, n;\n });\n}\nexport { s as useTextValue };","'use strict';\nvar documentAll = typeof document == 'object' && document.all;\n\n// https://tc39.es/ecma262/#sec-IsHTMLDDA-internal-slot\n// eslint-disable-next-line unicorn/no-typeof-undefined -- required for testing\nvar IS_HTMLDDA = typeof documentAll == 'undefined' && documentAll !== undefined;\n\nmodule.exports = {\n all: documentAll,\n IS_HTMLDDA: IS_HTMLDDA\n};\n","'use strict';\n/* eslint-disable es/no-symbol -- required for testing */\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\n\nmodule.exports = NATIVE_SYMBOL\n && !Symbol.sham\n && typeof Symbol.iterator == 'symbol';\n","'use strict';\nvar call = require('../internals/function-call');\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\n\nvar $TypeError = TypeError;\n\n// `OrdinaryToPrimitive` abstract operation\n// https://tc39.es/ecma262/#sec-ordinarytoprimitive\nmodule.exports = function (input, pref) {\n var fn, val;\n if (pref === 'string' && isCallable(fn = input.toString) && !isObject(val = call(fn, input))) return val;\n if (isCallable(fn = input.valueOf) && !isObject(val = call(fn, input))) return val;\n if (pref !== 'string' && isCallable(fn = input.toString) && !isObject(val = call(fn, input))) return val;\n throw new $TypeError(\"Can't convert object to primitive value\");\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar fails = require('../internals/fails');\nvar createElement = require('../internals/document-create-element');\n\n// Thanks to IE8 for its funny defineProperty\nmodule.exports = !DESCRIPTORS && !fails(function () {\n // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n return Object.defineProperty(createElement('div'), 'a', {\n get: function () { return 7; }\n }).a !== 7;\n});\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar fails = require('../internals/fails');\n\n// V8 ~ Chrome 36-\n// https://bugs.chromium.org/p/v8/issues/detail?id=3334\nmodule.exports = DESCRIPTORS && fails(function () {\n // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n return Object.defineProperty(function () { /* empty */ }, 'prototype', {\n value: 42,\n writable: false\n }).prototype !== 42;\n});\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar getOwnPropertyNamesModule = require('../internals/object-get-own-property-names');\nvar getOwnPropertySymbolsModule = require('../internals/object-get-own-property-symbols');\nvar anObject = require('../internals/an-object');\n\nvar concat = uncurryThis([].concat);\n\n// all object keys, includes non-enumerable and symbols\nmodule.exports = getBuiltIn('Reflect', 'ownKeys') || function ownKeys(it) {\n var keys = getOwnPropertyNamesModule.f(anObject(it));\n var getOwnPropertySymbols = getOwnPropertySymbolsModule.f;\n return getOwnPropertySymbols ? concat(keys, getOwnPropertySymbols(it)) : keys;\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar hasOwn = require('../internals/has-own-property');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar indexOf = require('../internals/array-includes').indexOf;\nvar hiddenKeys = require('../internals/hidden-keys');\n\nvar push = uncurryThis([].push);\n\nmodule.exports = function (object, names) {\n var O = toIndexedObject(object);\n var i = 0;\n var result = [];\n var key;\n for (key in O) !hasOwn(hiddenKeys, key) && hasOwn(O, key) && push(result, key);\n // Don't enum bug & hidden keys\n while (names.length > i) if (hasOwn(O, key = names[i++])) {\n ~indexOf(result, key) || push(result, key);\n }\n return result;\n};\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\n\nmodule.exports = getBuiltIn('document', 'documentElement');\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nexports.f = wellKnownSymbol;\n","'use strict';\nvar call = require('../internals/function-call');\nvar getBuiltIn = require('../internals/get-built-in');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar defineBuiltIn = require('../internals/define-built-in');\n\nmodule.exports = function () {\n var Symbol = getBuiltIn('Symbol');\n var SymbolPrototype = Symbol && Symbol.prototype;\n var valueOf = SymbolPrototype && SymbolPrototype.valueOf;\n var TO_PRIMITIVE = wellKnownSymbol('toPrimitive');\n\n if (SymbolPrototype && !SymbolPrototype[TO_PRIMITIVE]) {\n // `Symbol.prototype[@@toPrimitive]` method\n // https://tc39.es/ecma262/#sec-symbol.prototype-@@toprimitive\n // eslint-disable-next-line no-unused-vars -- required for .length\n defineBuiltIn(SymbolPrototype, TO_PRIMITIVE, function (hint) {\n return call(valueOf, this);\n }, { arity: 1 });\n }\n};\n","'use strict';\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\n\n/* eslint-disable es/no-symbol -- safe */\nmodule.exports = NATIVE_SYMBOL && !!Symbol['for'] && !!Symbol.keyFor;\n","'use strict';\nvar $ = require('../internals/export');\nvar getBuiltIn = require('../internals/get-built-in');\nvar apply = require('../internals/function-apply');\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar isSymbol = require('../internals/is-symbol');\nvar arraySlice = require('../internals/array-slice');\nvar getReplacerFunction = require('../internals/get-json-replacer-function');\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\n\nvar $String = String;\nvar $stringify = getBuiltIn('JSON', 'stringify');\nvar exec = uncurryThis(/./.exec);\nvar charAt = uncurryThis(''.charAt);\nvar charCodeAt = uncurryThis(''.charCodeAt);\nvar replace = uncurryThis(''.replace);\nvar numberToString = uncurryThis(1.0.toString);\n\nvar tester = /[\\uD800-\\uDFFF]/g;\nvar low = /^[\\uD800-\\uDBFF]$/;\nvar hi = /^[\\uDC00-\\uDFFF]$/;\n\nvar WRONG_SYMBOLS_CONVERSION = !NATIVE_SYMBOL || fails(function () {\n var symbol = getBuiltIn('Symbol')('stringify detection');\n // MS Edge converts symbol values to JSON as {}\n return $stringify([symbol]) !== '[null]'\n // WebKit converts symbol values to JSON as null\n || $stringify({ a: symbol }) !== '{}'\n // V8 throws on boxed symbols\n || $stringify(Object(symbol)) !== '{}';\n});\n\n// https://github.com/tc39/proposal-well-formed-stringify\nvar ILL_FORMED_UNICODE = fails(function () {\n return $stringify('\\uDF06\\uD834') !== '\"\\\\udf06\\\\ud834\"'\n || $stringify('\\uDEAD') !== '\"\\\\udead\"';\n});\n\nvar stringifyWithSymbolsFix = function (it, replacer) {\n var args = arraySlice(arguments);\n var $replacer = getReplacerFunction(replacer);\n if (!isCallable($replacer) && (it === undefined || isSymbol(it))) return; // IE8 returns string on undefined\n args[1] = function (key, value) {\n // some old implementations (like WebKit) could pass numbers as keys\n if (isCallable($replacer)) value = call($replacer, this, $String(key), value);\n if (!isSymbol(value)) return value;\n };\n return apply($stringify, null, args);\n};\n\nvar fixIllFormed = function (match, offset, string) {\n var prev = charAt(string, offset - 1);\n var next = charAt(string, offset + 1);\n if ((exec(low, match) && !exec(hi, next)) || (exec(hi, match) && !exec(low, prev))) {\n return '\\\\u' + numberToString(charCodeAt(match, 0), 16);\n } return match;\n};\n\nif ($stringify) {\n // `JSON.stringify` method\n // https://tc39.es/ecma262/#sec-json.stringify\n $({ target: 'JSON', stat: true, arity: 3, forced: WRONG_SYMBOLS_CONVERSION || ILL_FORMED_UNICODE }, {\n // eslint-disable-next-line no-unused-vars -- required for `.length`\n stringify: function stringify(it, replacer, space) {\n var args = arraySlice(arguments);\n var result = apply(WRONG_SYMBOLS_CONVERSION ? stringifyWithSymbolsFix : $stringify, null, args);\n return ILL_FORMED_UNICODE && typeof result == 'string' ? replace(result, tester, fixIllFormed) : result;\n }\n });\n}\n","'use strict';\nvar userAgent = require('../internals/engine-user-agent');\n\n// eslint-disable-next-line redos/no-vulnerable -- safe\nmodule.exports = /(?:ipad|iphone|ipod).*applewebkit/i.test(userAgent);\n","'use strict';\nvar Queue = function () {\n this.head = null;\n this.tail = null;\n};\n\nQueue.prototype = {\n add: function (item) {\n var entry = { item: item, next: null };\n var tail = this.tail;\n if (tail) tail.next = entry;\n else this.head = entry;\n this.tail = entry;\n },\n get: function () {\n var entry = this.head;\n if (entry) {\n var next = this.head = entry.next;\n if (next === null) this.tail = null;\n return entry.item;\n }\n }\n};\n\nmodule.exports = Queue;\n","'use strict';\nvar fails = require('../internals/fails');\nvar global = require('../internals/global');\n\n// babel-minify and Closure Compiler transpiles RegExp('a', 'y') -> /a/y and it causes SyntaxError\nvar $RegExp = global.RegExp;\n\nvar UNSUPPORTED_Y = fails(function () {\n var re = $RegExp('a', 'y');\n re.lastIndex = 2;\n return re.exec('abcd') !== null;\n});\n\n// UC Browser bug\n// https://github.com/zloirock/core-js/issues/1008\nvar MISSED_STICKY = UNSUPPORTED_Y || fails(function () {\n return !$RegExp('a', 'y').sticky;\n});\n\nvar BROKEN_CARET = UNSUPPORTED_Y || fails(function () {\n // https://bugzilla.mozilla.org/show_bug.cgi?id=773687\n var re = $RegExp('^r', 'gy');\n re.lastIndex = 2;\n return re.exec('str') !== null;\n});\n\nmodule.exports = {\n BROKEN_CARET: BROKEN_CARET,\n MISSED_STICKY: MISSED_STICKY,\n UNSUPPORTED_Y: UNSUPPORTED_Y\n};\n","'use strict';\nvar PROPER_FUNCTION_NAME = require('../internals/function-name').PROPER;\nvar defineBuiltIn = require('../internals/define-built-in');\nvar anObject = require('../internals/an-object');\nvar $toString = require('../internals/to-string');\nvar fails = require('../internals/fails');\nvar getRegExpFlags = require('../internals/regexp-get-flags');\n\nvar TO_STRING = 'toString';\nvar RegExpPrototype = RegExp.prototype;\nvar nativeToString = RegExpPrototype[TO_STRING];\n\nvar NOT_GENERIC = fails(function () { return nativeToString.call({ source: 'a', flags: 'b' }) !== '/a/b'; });\n// FF44- RegExp#toString has a wrong name\nvar INCORRECT_NAME = PROPER_FUNCTION_NAME && nativeToString.name !== TO_STRING;\n\n// `RegExp.prototype.toString` method\n// https://tc39.es/ecma262/#sec-regexp.prototype.tostring\nif (NOT_GENERIC || INCORRECT_NAME) {\n defineBuiltIn(RegExp.prototype, TO_STRING, function toString() {\n var R = anObject(this);\n var pattern = $toString(R.source);\n var flags = $toString(getRegExpFlags(R));\n return '/' + pattern + '/' + flags;\n }, { unsafe: true });\n}\n","'use strict';\n// TODO: Remove from `core-js@4` since it's moved to entry points\nrequire('../modules/es.regexp.exec');\nvar uncurryThis = require('../internals/function-uncurry-this-clause');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar regexpExec = require('../internals/regexp-exec');\nvar fails = require('../internals/fails');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\n\nvar SPECIES = wellKnownSymbol('species');\nvar RegExpPrototype = RegExp.prototype;\n\nmodule.exports = function (KEY, exec, FORCED, SHAM) {\n var SYMBOL = wellKnownSymbol(KEY);\n\n var DELEGATES_TO_SYMBOL = !fails(function () {\n // String methods call symbol-named RegEp methods\n var O = {};\n O[SYMBOL] = function () { return 7; };\n return ''[KEY](O) !== 7;\n });\n\n var DELEGATES_TO_EXEC = DELEGATES_TO_SYMBOL && !fails(function () {\n // Symbol-named RegExp methods call .exec\n var execCalled = false;\n var re = /a/;\n\n if (KEY === 'split') {\n // We can't use real regex here since it causes deoptimization\n // and serious performance degradation in V8\n // https://github.com/zloirock/core-js/issues/306\n re = {};\n // RegExp[@@split] doesn't call the regex's exec method, but first creates\n // a new one. We need to return the patched regex when creating the new one.\n re.constructor = {};\n re.constructor[SPECIES] = function () { return re; };\n re.flags = '';\n re[SYMBOL] = /./[SYMBOL];\n }\n\n re.exec = function () {\n execCalled = true;\n return null;\n };\n\n re[SYMBOL]('');\n return !execCalled;\n });\n\n if (\n !DELEGATES_TO_SYMBOL ||\n !DELEGATES_TO_EXEC ||\n FORCED\n ) {\n var uncurriedNativeRegExpMethod = uncurryThis(/./[SYMBOL]);\n var methods = exec(SYMBOL, ''[KEY], function (nativeMethod, regexp, str, arg2, forceStringMethod) {\n var uncurriedNativeMethod = uncurryThis(nativeMethod);\n var $exec = regexp.exec;\n if ($exec === regexpExec || $exec === RegExpPrototype.exec) {\n if (DELEGATES_TO_SYMBOL && !forceStringMethod) {\n // The native String method already delegates to @@method (this\n // polyfilled function), leasing to infinite recursion.\n // We avoid it by directly calling the native @@method method.\n return { done: true, value: uncurriedNativeRegExpMethod(regexp, str, arg2) };\n }\n return { done: true, value: uncurriedNativeMethod(str, regexp, arg2) };\n }\n return { done: false };\n });\n\n defineBuiltIn(String.prototype, KEY, methods[0]);\n defineBuiltIn(RegExpPrototype, SYMBOL, methods[1]);\n }\n\n if (SHAM) createNonEnumerableProperty(RegExpPrototype[SYMBOL], 'sham', true);\n};\n","'use strict';\nvar charAt = require('../internals/string-multibyte').charAt;\n\n// `AdvanceStringIndex` abstract operation\n// https://tc39.es/ecma262/#sec-advancestringindex\nmodule.exports = function (S, index, unicode) {\n return index + (unicode ? charAt(S, index).length : 1);\n};\n","'use strict';\n// TODO: in core-js@4, move /modules/ dependencies to public entries for better optimization by tools like `preset-env`\nrequire('../modules/es.array.iterator');\nvar $ = require('../internals/export');\nvar global = require('../internals/global');\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar USE_NATIVE_URL = require('../internals/url-constructor-detection');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar defineBuiltIns = require('../internals/define-built-ins');\nvar setToStringTag = require('../internals/set-to-string-tag');\nvar createIteratorConstructor = require('../internals/iterator-create-constructor');\nvar InternalStateModule = require('../internals/internal-state');\nvar anInstance = require('../internals/an-instance');\nvar isCallable = require('../internals/is-callable');\nvar hasOwn = require('../internals/has-own-property');\nvar bind = require('../internals/function-bind-context');\nvar classof = require('../internals/classof');\nvar anObject = require('../internals/an-object');\nvar isObject = require('../internals/is-object');\nvar $toString = require('../internals/to-string');\nvar create = require('../internals/object-create');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\nvar getIterator = require('../internals/get-iterator');\nvar getIteratorMethod = require('../internals/get-iterator-method');\nvar createIterResultObject = require('../internals/create-iter-result-object');\nvar validateArgumentsLength = require('../internals/validate-arguments-length');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar arraySort = require('../internals/array-sort');\n\nvar ITERATOR = wellKnownSymbol('iterator');\nvar URL_SEARCH_PARAMS = 'URLSearchParams';\nvar URL_SEARCH_PARAMS_ITERATOR = URL_SEARCH_PARAMS + 'Iterator';\nvar setInternalState = InternalStateModule.set;\nvar getInternalParamsState = InternalStateModule.getterFor(URL_SEARCH_PARAMS);\nvar getInternalIteratorState = InternalStateModule.getterFor(URL_SEARCH_PARAMS_ITERATOR);\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\n// Avoid NodeJS experimental warning\nvar safeGetBuiltIn = function (name) {\n if (!DESCRIPTORS) return global[name];\n var descriptor = getOwnPropertyDescriptor(global, name);\n return descriptor && descriptor.value;\n};\n\nvar nativeFetch = safeGetBuiltIn('fetch');\nvar NativeRequest = safeGetBuiltIn('Request');\nvar Headers = safeGetBuiltIn('Headers');\nvar RequestPrototype = NativeRequest && NativeRequest.prototype;\nvar HeadersPrototype = Headers && Headers.prototype;\nvar RegExp = global.RegExp;\nvar TypeError = global.TypeError;\nvar decodeURIComponent = global.decodeURIComponent;\nvar encodeURIComponent = global.encodeURIComponent;\nvar charAt = uncurryThis(''.charAt);\nvar join = uncurryThis([].join);\nvar push = uncurryThis([].push);\nvar replace = uncurryThis(''.replace);\nvar shift = uncurryThis([].shift);\nvar splice = uncurryThis([].splice);\nvar split = uncurryThis(''.split);\nvar stringSlice = uncurryThis(''.slice);\n\nvar plus = /\\+/g;\nvar sequences = Array(4);\n\nvar percentSequence = function (bytes) {\n return sequences[bytes - 1] || (sequences[bytes - 1] = RegExp('((?:%[\\\\da-f]{2}){' + bytes + '})', 'gi'));\n};\n\nvar percentDecode = function (sequence) {\n try {\n return decodeURIComponent(sequence);\n } catch (error) {\n return sequence;\n }\n};\n\nvar deserialize = function (it) {\n var result = replace(it, plus, ' ');\n var bytes = 4;\n try {\n return decodeURIComponent(result);\n } catch (error) {\n while (bytes) {\n result = replace(result, percentSequence(bytes--), percentDecode);\n }\n return result;\n }\n};\n\nvar find = /[!'()~]|%20/g;\n\nvar replacements = {\n '!': '%21',\n \"'\": '%27',\n '(': '%28',\n ')': '%29',\n '~': '%7E',\n '%20': '+'\n};\n\nvar replacer = function (match) {\n return replacements[match];\n};\n\nvar serialize = function (it) {\n return replace(encodeURIComponent(it), find, replacer);\n};\n\nvar URLSearchParamsIterator = createIteratorConstructor(function Iterator(params, kind) {\n setInternalState(this, {\n type: URL_SEARCH_PARAMS_ITERATOR,\n target: getInternalParamsState(params).entries,\n index: 0,\n kind: kind\n });\n}, URL_SEARCH_PARAMS, function next() {\n var state = getInternalIteratorState(this);\n var target = state.target;\n var index = state.index++;\n if (!target || index >= target.length) {\n state.target = undefined;\n return createIterResultObject(undefined, true);\n }\n var entry = target[index];\n switch (state.kind) {\n case 'keys': return createIterResultObject(entry.key, false);\n case 'values': return createIterResultObject(entry.value, false);\n } return createIterResultObject([entry.key, entry.value], false);\n}, true);\n\nvar URLSearchParamsState = function (init) {\n this.entries = [];\n this.url = null;\n\n if (init !== undefined) {\n if (isObject(init)) this.parseObject(init);\n else this.parseQuery(typeof init == 'string' ? charAt(init, 0) === '?' ? stringSlice(init, 1) : init : $toString(init));\n }\n};\n\nURLSearchParamsState.prototype = {\n type: URL_SEARCH_PARAMS,\n bindURL: function (url) {\n this.url = url;\n this.update();\n },\n parseObject: function (object) {\n var entries = this.entries;\n var iteratorMethod = getIteratorMethod(object);\n var iterator, next, step, entryIterator, entryNext, first, second;\n\n if (iteratorMethod) {\n iterator = getIterator(object, iteratorMethod);\n next = iterator.next;\n while (!(step = call(next, iterator)).done) {\n entryIterator = getIterator(anObject(step.value));\n entryNext = entryIterator.next;\n if (\n (first = call(entryNext, entryIterator)).done ||\n (second = call(entryNext, entryIterator)).done ||\n !call(entryNext, entryIterator).done\n ) throw new TypeError('Expected sequence with length 2');\n push(entries, { key: $toString(first.value), value: $toString(second.value) });\n }\n } else for (var key in object) if (hasOwn(object, key)) {\n push(entries, { key: key, value: $toString(object[key]) });\n }\n },\n parseQuery: function (query) {\n if (query) {\n var entries = this.entries;\n var attributes = split(query, '&');\n var index = 0;\n var attribute, entry;\n while (index < attributes.length) {\n attribute = attributes[index++];\n if (attribute.length) {\n entry = split(attribute, '=');\n push(entries, {\n key: deserialize(shift(entry)),\n value: deserialize(join(entry, '='))\n });\n }\n }\n }\n },\n serialize: function () {\n var entries = this.entries;\n var result = [];\n var index = 0;\n var entry;\n while (index < entries.length) {\n entry = entries[index++];\n push(result, serialize(entry.key) + '=' + serialize(entry.value));\n } return join(result, '&');\n },\n update: function () {\n this.entries.length = 0;\n this.parseQuery(this.url.query);\n },\n updateURL: function () {\n if (this.url) this.url.update();\n }\n};\n\n// `URLSearchParams` constructor\n// https://url.spec.whatwg.org/#interface-urlsearchparams\nvar URLSearchParamsConstructor = function URLSearchParams(/* init */) {\n anInstance(this, URLSearchParamsPrototype);\n var init = arguments.length > 0 ? arguments[0] : undefined;\n var state = setInternalState(this, new URLSearchParamsState(init));\n if (!DESCRIPTORS) this.size = state.entries.length;\n};\n\nvar URLSearchParamsPrototype = URLSearchParamsConstructor.prototype;\n\ndefineBuiltIns(URLSearchParamsPrototype, {\n // `URLSearchParams.prototype.append` method\n // https://url.spec.whatwg.org/#dom-urlsearchparams-append\n append: function append(name, value) {\n var state = getInternalParamsState(this);\n validateArgumentsLength(arguments.length, 2);\n push(state.entries, { key: $toString(name), value: $toString(value) });\n if (!DESCRIPTORS) this.length++;\n state.updateURL();\n },\n // `URLSearchParams.prototype.delete` method\n // https://url.spec.whatwg.org/#dom-urlsearchparams-delete\n 'delete': function (name /* , value */) {\n var state = getInternalParamsState(this);\n var length = validateArgumentsLength(arguments.length, 1);\n var entries = state.entries;\n var key = $toString(name);\n var $value = length < 2 ? undefined : arguments[1];\n var value = $value === undefined ? $value : $toString($value);\n var index = 0;\n while (index < entries.length) {\n var entry = entries[index];\n if (entry.key === key && (value === undefined || entry.value === value)) {\n splice(entries, index, 1);\n if (value !== undefined) break;\n } else index++;\n }\n if (!DESCRIPTORS) this.size = entries.length;\n state.updateURL();\n },\n // `URLSearchParams.prototype.get` method\n // https://url.spec.whatwg.org/#dom-urlsearchparams-get\n get: function get(name) {\n var entries = getInternalParamsState(this).entries;\n validateArgumentsLength(arguments.length, 1);\n var key = $toString(name);\n var index = 0;\n for (; index < entries.length; index++) {\n if (entries[index].key === key) return entries[index].value;\n }\n return null;\n },\n // `URLSearchParams.prototype.getAll` method\n // https://url.spec.whatwg.org/#dom-urlsearchparams-getall\n getAll: function getAll(name) {\n var entries = getInternalParamsState(this).entries;\n validateArgumentsLength(arguments.length, 1);\n var key = $toString(name);\n var result = [];\n var index = 0;\n for (; index < entries.length; index++) {\n if (entries[index].key === key) push(result, entries[index].value);\n }\n return result;\n },\n // `URLSearchParams.prototype.has` method\n // https://url.spec.whatwg.org/#dom-urlsearchparams-has\n has: function has(name /* , value */) {\n var entries = getInternalParamsState(this).entries;\n var length = validateArgumentsLength(arguments.length, 1);\n var key = $toString(name);\n var $value = length < 2 ? undefined : arguments[1];\n var value = $value === undefined ? $value : $toString($value);\n var index = 0;\n while (index < entries.length) {\n var entry = entries[index++];\n if (entry.key === key && (value === undefined || entry.value === value)) return true;\n }\n return false;\n },\n // `URLSearchParams.prototype.set` method\n // https://url.spec.whatwg.org/#dom-urlsearchparams-set\n set: function set(name, value) {\n var state = getInternalParamsState(this);\n validateArgumentsLength(arguments.length, 1);\n var entries = state.entries;\n var found = false;\n var key = $toString(name);\n var val = $toString(value);\n var index = 0;\n var entry;\n for (; index < entries.length; index++) {\n entry = entries[index];\n if (entry.key === key) {\n if (found) splice(entries, index--, 1);\n else {\n found = true;\n entry.value = val;\n }\n }\n }\n if (!found) push(entries, { key: key, value: val });\n if (!DESCRIPTORS) this.size = entries.length;\n state.updateURL();\n },\n // `URLSearchParams.prototype.sort` method\n // https://url.spec.whatwg.org/#dom-urlsearchparams-sort\n sort: function sort() {\n var state = getInternalParamsState(this);\n arraySort(state.entries, function (a, b) {\n return a.key > b.key ? 1 : -1;\n });\n state.updateURL();\n },\n // `URLSearchParams.prototype.forEach` method\n forEach: function forEach(callback /* , thisArg */) {\n var entries = getInternalParamsState(this).entries;\n var boundFunction = bind(callback, arguments.length > 1 ? arguments[1] : undefined);\n var index = 0;\n var entry;\n while (index < entries.length) {\n entry = entries[index++];\n boundFunction(entry.value, entry.key, this);\n }\n },\n // `URLSearchParams.prototype.keys` method\n keys: function keys() {\n return new URLSearchParamsIterator(this, 'keys');\n },\n // `URLSearchParams.prototype.values` method\n values: function values() {\n return new URLSearchParamsIterator(this, 'values');\n },\n // `URLSearchParams.prototype.entries` method\n entries: function entries() {\n return new URLSearchParamsIterator(this, 'entries');\n }\n}, { enumerable: true });\n\n// `URLSearchParams.prototype[@@iterator]` method\ndefineBuiltIn(URLSearchParamsPrototype, ITERATOR, URLSearchParamsPrototype.entries, { name: 'entries' });\n\n// `URLSearchParams.prototype.toString` method\n// https://url.spec.whatwg.org/#urlsearchparams-stringification-behavior\ndefineBuiltIn(URLSearchParamsPrototype, 'toString', function toString() {\n return getInternalParamsState(this).serialize();\n}, { enumerable: true });\n\n// `URLSearchParams.prototype.size` getter\n// https://github.com/whatwg/url/pull/734\nif (DESCRIPTORS) defineBuiltInAccessor(URLSearchParamsPrototype, 'size', {\n get: function size() {\n return getInternalParamsState(this).entries.length;\n },\n configurable: true,\n enumerable: true\n});\n\nsetToStringTag(URLSearchParamsConstructor, URL_SEARCH_PARAMS);\n\n$({ global: true, constructor: true, forced: !USE_NATIVE_URL }, {\n URLSearchParams: URLSearchParamsConstructor\n});\n\n// Wrap `fetch` and `Request` for correct work with polyfilled `URLSearchParams`\nif (!USE_NATIVE_URL && isCallable(Headers)) {\n var headersHas = uncurryThis(HeadersPrototype.has);\n var headersSet = uncurryThis(HeadersPrototype.set);\n\n var wrapRequestOptions = function (init) {\n if (isObject(init)) {\n var body = init.body;\n var headers;\n if (classof(body) === URL_SEARCH_PARAMS) {\n headers = init.headers ? new Headers(init.headers) : new Headers();\n if (!headersHas(headers, 'content-type')) {\n headersSet(headers, 'content-type', 'application/x-www-form-urlencoded;charset=UTF-8');\n }\n return create(init, {\n body: createPropertyDescriptor(0, $toString(body)),\n headers: createPropertyDescriptor(0, headers)\n });\n }\n } return init;\n };\n\n if (isCallable(nativeFetch)) {\n $({ global: true, enumerable: true, dontCallGetSet: true, forced: true }, {\n fetch: function fetch(input /* , init */) {\n return nativeFetch(input, arguments.length > 1 ? wrapRequestOptions(arguments[1]) : {});\n }\n });\n }\n\n if (isCallable(NativeRequest)) {\n var RequestConstructor = function Request(input /* , init */) {\n anInstance(this, RequestPrototype);\n return new NativeRequest(input, arguments.length > 1 ? wrapRequestOptions(arguments[1]) : {});\n };\n\n RequestPrototype.constructor = RequestConstructor;\n RequestConstructor.prototype = RequestPrototype;\n\n $({ global: true, constructor: true, dontCallGetSet: true, forced: true }, {\n Request: RequestConstructor\n });\n }\n}\n\nmodule.exports = {\n URLSearchParams: URLSearchParamsConstructor,\n getState: getInternalParamsState\n};\n","'use strict';\n/* eslint-disable es/no-object-getownpropertynames -- safe */\nvar classof = require('../internals/classof-raw');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar $getOwnPropertyNames = require('../internals/object-get-own-property-names').f;\nvar arraySlice = require('../internals/array-slice-simple');\n\nvar windowNames = typeof window == 'object' && window && Object.getOwnPropertyNames\n ? Object.getOwnPropertyNames(window) : [];\n\nvar getWindowNames = function (it) {\n try {\n return $getOwnPropertyNames(it);\n } catch (error) {\n return arraySlice(windowNames);\n }\n};\n\n// fallback for IE11 buggy Object.getOwnPropertyNames with iframe and window\nmodule.exports.f = function getOwnPropertyNames(it) {\n return windowNames && classof(it) === 'Window'\n ? getWindowNames(it)\n : $getOwnPropertyNames(toIndexedObject(it));\n};\n","'use strict';\nvar bind = require('../internals/function-bind-context');\nvar call = require('../internals/function-call');\nvar toObject = require('../internals/to-object');\nvar callWithSafeIterationClosing = require('../internals/call-with-safe-iteration-closing');\nvar isArrayIteratorMethod = require('../internals/is-array-iterator-method');\nvar isConstructor = require('../internals/is-constructor');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar createProperty = require('../internals/create-property');\nvar getIterator = require('../internals/get-iterator');\nvar getIteratorMethod = require('../internals/get-iterator-method');\n\nvar $Array = Array;\n\n// `Array.from` method implementation\n// https://tc39.es/ecma262/#sec-array.from\nmodule.exports = function from(arrayLike /* , mapfn = undefined, thisArg = undefined */) {\n var O = toObject(arrayLike);\n var IS_CONSTRUCTOR = isConstructor(this);\n var argumentsLength = arguments.length;\n var mapfn = argumentsLength > 1 ? arguments[1] : undefined;\n var mapping = mapfn !== undefined;\n if (mapping) mapfn = bind(mapfn, argumentsLength > 2 ? arguments[2] : undefined);\n var iteratorMethod = getIteratorMethod(O);\n var index = 0;\n var length, result, step, iterator, next, value;\n // if the target is not iterable or it's an array with the default iterator - use a simple case\n if (iteratorMethod && !(this === $Array && isArrayIteratorMethod(iteratorMethod))) {\n iterator = getIterator(O, iteratorMethod);\n next = iterator.next;\n result = IS_CONSTRUCTOR ? new this() : [];\n for (;!(step = call(next, iterator)).done; index++) {\n value = mapping ? callWithSafeIterationClosing(iterator, mapfn, [step.value, index], true) : step.value;\n createProperty(result, index, value);\n }\n } else {\n length = lengthOfArrayLike(O);\n result = IS_CONSTRUCTOR ? new this(length) : $Array(length);\n for (;length > index; index++) {\n value = mapping ? mapfn(O[index], index) : O[index];\n createProperty(result, index, value);\n }\n }\n result.length = index;\n return result;\n};\n","'use strict';\nvar arraySlice = require('../internals/array-slice-simple');\n\nvar floor = Math.floor;\n\nvar mergeSort = function (array, comparefn) {\n var length = array.length;\n var middle = floor(length / 2);\n return length < 8 ? insertionSort(array, comparefn) : merge(\n array,\n mergeSort(arraySlice(array, 0, middle), comparefn),\n mergeSort(arraySlice(array, middle), comparefn),\n comparefn\n );\n};\n\nvar insertionSort = function (array, comparefn) {\n var length = array.length;\n var i = 1;\n var element, j;\n\n while (i < length) {\n j = i;\n element = array[i];\n while (j && comparefn(array[j - 1], element) > 0) {\n array[j] = array[--j];\n }\n if (j !== i++) array[j] = element;\n } return array;\n};\n\nvar merge = function (array, left, right, comparefn) {\n var llength = left.length;\n var rlength = right.length;\n var lindex = 0;\n var rindex = 0;\n\n while (lindex < llength || rindex < rlength) {\n array[lindex + rindex] = (lindex < llength && rindex < rlength)\n ? comparefn(left[lindex], right[rindex]) <= 0 ? left[lindex++] : right[rindex++]\n : lindex < llength ? left[lindex++] : right[rindex++];\n } return array;\n};\n\nmodule.exports = mergeSort;\n","'use strict';\nvar $ = require('../internals/export');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar hiddenKeys = require('../internals/hidden-keys');\nvar isObject = require('../internals/is-object');\nvar hasOwn = require('../internals/has-own-property');\nvar defineProperty = require('../internals/object-define-property').f;\nvar getOwnPropertyNamesModule = require('../internals/object-get-own-property-names');\nvar getOwnPropertyNamesExternalModule = require('../internals/object-get-own-property-names-external');\nvar isExtensible = require('../internals/object-is-extensible');\nvar uid = require('../internals/uid');\nvar FREEZING = require('../internals/freezing');\n\nvar REQUIRED = false;\nvar METADATA = uid('meta');\nvar id = 0;\n\nvar setMetadata = function (it) {\n defineProperty(it, METADATA, { value: {\n objectID: 'O' + id++, // object ID\n weakData: {} // weak collections IDs\n } });\n};\n\nvar fastKey = function (it, create) {\n // return a primitive with prefix\n if (!isObject(it)) return typeof it == 'symbol' ? it : (typeof it == 'string' ? 'S' : 'P') + it;\n if (!hasOwn(it, METADATA)) {\n // can't set metadata to uncaught frozen object\n if (!isExtensible(it)) return 'F';\n // not necessary to add metadata\n if (!create) return 'E';\n // add missing metadata\n setMetadata(it);\n // return object ID\n } return it[METADATA].objectID;\n};\n\nvar getWeakData = function (it, create) {\n if (!hasOwn(it, METADATA)) {\n // can't set metadata to uncaught frozen object\n if (!isExtensible(it)) return true;\n // not necessary to add metadata\n if (!create) return false;\n // add missing metadata\n setMetadata(it);\n // return the store of weak collections IDs\n } return it[METADATA].weakData;\n};\n\n// add metadata on freeze-family methods calling\nvar onFreeze = function (it) {\n if (FREEZING && REQUIRED && isExtensible(it) && !hasOwn(it, METADATA)) setMetadata(it);\n return it;\n};\n\nvar enable = function () {\n meta.enable = function () { /* empty */ };\n REQUIRED = true;\n var getOwnPropertyNames = getOwnPropertyNamesModule.f;\n var splice = uncurryThis([].splice);\n var test = {};\n test[METADATA] = 1;\n\n // prevent exposing of metadata key\n if (getOwnPropertyNames(test).length) {\n getOwnPropertyNamesModule.f = function (it) {\n var result = getOwnPropertyNames(it);\n for (var i = 0, length = result.length; i < length; i++) {\n if (result[i] === METADATA) {\n splice(result, i, 1);\n break;\n }\n } return result;\n };\n\n $({ target: 'Object', stat: true, forced: true }, {\n getOwnPropertyNames: getOwnPropertyNamesExternalModule.f\n });\n }\n};\n\nvar meta = module.exports = {\n enable: enable,\n fastKey: fastKey,\n getWeakData: getWeakData,\n onFreeze: onFreeze\n};\n\nhiddenKeys[METADATA] = true;\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar call = require('../internals/function-call');\nvar fails = require('../internals/fails');\nvar objectKeys = require('../internals/object-keys');\nvar getOwnPropertySymbolsModule = require('../internals/object-get-own-property-symbols');\nvar propertyIsEnumerableModule = require('../internals/object-property-is-enumerable');\nvar toObject = require('../internals/to-object');\nvar IndexedObject = require('../internals/indexed-object');\n\n// eslint-disable-next-line es/no-object-assign -- safe\nvar $assign = Object.assign;\n// eslint-disable-next-line es/no-object-defineproperty -- required for testing\nvar defineProperty = Object.defineProperty;\nvar concat = uncurryThis([].concat);\n\n// `Object.assign` method\n// https://tc39.es/ecma262/#sec-object.assign\nmodule.exports = !$assign || fails(function () {\n // should have correct order of operations (Edge bug)\n if (DESCRIPTORS && $assign({ b: 1 }, $assign(defineProperty({}, 'a', {\n enumerable: true,\n get: function () {\n defineProperty(this, 'b', {\n value: 3,\n enumerable: false\n });\n }\n }), { b: 2 })).b !== 1) return true;\n // should work with symbols and should have deterministic property order (V8 bug)\n var A = {};\n var B = {};\n // eslint-disable-next-line es/no-symbol -- safe\n var symbol = Symbol('assign detection');\n var alphabet = 'abcdefghijklmnopqrst';\n A[symbol] = 7;\n alphabet.split('').forEach(function (chr) { B[chr] = chr; });\n return $assign({}, A)[symbol] !== 7 || objectKeys($assign({}, B)).join('') !== alphabet;\n}) ? function assign(target, source) { // eslint-disable-line no-unused-vars -- required for `.length`\n var T = toObject(target);\n var argumentsLength = arguments.length;\n var index = 1;\n var getOwnPropertySymbols = getOwnPropertySymbolsModule.f;\n var propertyIsEnumerable = propertyIsEnumerableModule.f;\n while (argumentsLength > index) {\n var S = IndexedObject(arguments[index++]);\n var keys = getOwnPropertySymbols ? concat(objectKeys(S), getOwnPropertySymbols(S)) : objectKeys(S);\n var length = keys.length;\n var j = 0;\n var key;\n while (length > j) {\n key = keys[j++];\n if (!DESCRIPTORS || call(propertyIsEnumerable, S, key)) T[key] = S[key];\n }\n } return T;\n} : $assign;\n","'use strict';\nvar isObject = require('../internals/is-object');\nvar classof = require('../internals/classof-raw');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar MATCH = wellKnownSymbol('match');\n\n// `IsRegExp` abstract operation\n// https://tc39.es/ecma262/#sec-isregexp\nmodule.exports = function (it) {\n var isRegExp;\n return isObject(it) && ((isRegExp = it[MATCH]) !== undefined ? !!isRegExp : classof(it) === 'RegExp');\n};\n","'use strict';\nvar fails = require('../internals/fails');\nvar global = require('../internals/global');\n\n// babel-minify and Closure Compiler transpiles RegExp('.', 's') -> /./s and it causes SyntaxError\nvar $RegExp = global.RegExp;\n\nmodule.exports = fails(function () {\n var re = $RegExp('.', 's');\n return !(re.dotAll && re.test('\\n') && re.flags === 's');\n});\n","'use strict';\n// iterable DOM collections\n// flag - `iterable` interface - 'entries', 'keys', 'values', 'forEach' methods\nmodule.exports = {\n CSSRuleList: 0,\n CSSStyleDeclaration: 0,\n CSSValueList: 0,\n ClientRectList: 0,\n DOMRectList: 0,\n DOMStringList: 0,\n DOMTokenList: 1,\n DataTransferItemList: 0,\n FileList: 0,\n HTMLAllCollection: 0,\n HTMLCollection: 0,\n HTMLFormElement: 0,\n HTMLSelectElement: 0,\n MediaList: 0,\n MimeTypeArray: 0,\n NamedNodeMap: 0,\n NodeList: 1,\n PaintRequestList: 0,\n Plugin: 0,\n PluginArray: 0,\n SVGLengthList: 0,\n SVGNumberList: 0,\n SVGPathSegList: 0,\n SVGPointList: 0,\n SVGStringList: 0,\n SVGTransformList: 0,\n SourceBufferList: 0,\n StyleSheetList: 0,\n TextTrackCueList: 0,\n TextTrackList: 0,\n TouchList: 0\n};\n","'use strict';\n// in old WebKit versions, `element.classList` is not an instance of global `DOMTokenList`\nvar documentCreateElement = require('../internals/document-create-element');\n\nvar classList = documentCreateElement('span').classList;\nvar DOMTokenListPrototype = classList && classList.constructor && classList.constructor.prototype;\n\nmodule.exports = DOMTokenListPrototype === Object.prototype ? undefined : DOMTokenListPrototype;\n","'use strict';\n// https://github.com/tc39/proposal-iterator-helpers\n// https://github.com/tc39/proposal-array-from-async\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar isObject = require('../internals/is-object');\nvar doesNotExceedSafeInteger = require('../internals/does-not-exceed-safe-integer');\nvar getBuiltIn = require('../internals/get-built-in');\nvar getIteratorDirect = require('../internals/get-iterator-direct');\nvar closeAsyncIteration = require('../internals/async-iterator-close');\n\nvar createMethod = function (TYPE) {\n var IS_TO_ARRAY = TYPE === 0;\n var IS_FOR_EACH = TYPE === 1;\n var IS_EVERY = TYPE === 2;\n var IS_SOME = TYPE === 3;\n return function (object, fn, target) {\n anObject(object);\n var MAPPING = fn !== undefined;\n if (MAPPING || !IS_TO_ARRAY) aCallable(fn);\n var record = getIteratorDirect(object);\n var Promise = getBuiltIn('Promise');\n var iterator = record.iterator;\n var next = record.next;\n var counter = 0;\n\n return new Promise(function (resolve, reject) {\n var ifAbruptCloseAsyncIterator = function (error) {\n closeAsyncIteration(iterator, reject, error, reject);\n };\n\n var loop = function () {\n try {\n if (MAPPING) try {\n doesNotExceedSafeInteger(counter);\n } catch (error5) { ifAbruptCloseAsyncIterator(error5); }\n Promise.resolve(anObject(call(next, iterator))).then(function (step) {\n try {\n if (anObject(step).done) {\n if (IS_TO_ARRAY) {\n target.length = counter;\n resolve(target);\n } else resolve(IS_SOME ? false : IS_EVERY || undefined);\n } else {\n var value = step.value;\n try {\n if (MAPPING) {\n var result = fn(value, counter);\n\n var handler = function ($result) {\n if (IS_FOR_EACH) {\n loop();\n } else if (IS_EVERY) {\n $result ? loop() : closeAsyncIteration(iterator, resolve, false, reject);\n } else if (IS_TO_ARRAY) {\n try {\n target[counter++] = $result;\n loop();\n } catch (error4) { ifAbruptCloseAsyncIterator(error4); }\n } else {\n $result ? closeAsyncIteration(iterator, resolve, IS_SOME || value, reject) : loop();\n }\n };\n\n if (isObject(result)) Promise.resolve(result).then(handler, ifAbruptCloseAsyncIterator);\n else handler(result);\n } else {\n target[counter++] = value;\n loop();\n }\n } catch (error3) { ifAbruptCloseAsyncIterator(error3); }\n }\n } catch (error2) { reject(error2); }\n }, reject);\n } catch (error) { reject(error); }\n };\n\n loop();\n });\n };\n};\n\nmodule.exports = {\n toArray: createMethod(0),\n forEach: createMethod(1),\n every: createMethod(2),\n some: createMethod(3),\n find: createMethod(4)\n};\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.HTML = exports.TEXT = exports.URL = exports.FILE = void 0;\nvar FILE = '__NATIVE_FILE__';\nexports.FILE = FILE;\nvar URL = '__NATIVE_URL__';\nexports.URL = URL;\nvar TEXT = '__NATIVE_TEXT__';\nexports.TEXT = TEXT;\nvar HTML = '__NATIVE_HTML__';\nexports.HTML = HTML;","import FinalizeInvoicingSetup from './FinalizeInvoicingSetup/index';\n\nexport default FinalizeInvoicingSetup;\n","import FormableFields from './FormableFields/index';\n\nexport default FormableFields","import FundsGrid from './FundsGrid/index';\nexport default FundsGrid;\n","import InvoicePaymentForm from './InvoicePaymentForm/index';\n\nexport default InvoicePaymentForm;","import MembersListSidebar from './MembersListSidebar/index';\n\n\nexport default MembersListSidebar;","import ProductsGrid from './ProductsGrid/index';\nexport default ProductsGrid;\n","import ScheduledRemindersForm from './ScheduledRemindersForm/index';\n\nexport default ScheduledRemindersForm;","import ScheduledReportForm from './ScheduledReportForm/index';\n\nexport default ScheduledReportForm;\n","import SignupForm from './SignupForm/index';\nexport default SignupForm;\n","import StoreCheckoutForm from \"./StoreCheckoutForm/index\"\nexport default StoreCheckoutForm\n","import StripeForm from \"./StripeForm/index\"\nexport default StripeForm\n","import Index from \"./UnionlyUpdateSubscription/index\";\n\nexport default Index\n\n","import UpdateMembershipModal from \"./UpdateMembershipModal/index\"\nexport default UpdateMembershipModal\n","import { useRef as r } from \"react\";\nimport { useEvent as u } from './use-event.js';\nimport { useEventListener as o } from './use-event-listener.js';\nfunction i(e) {\n var n = r({\n value: \"\",\n selectionStart: null,\n selectionEnd: null\n });\n return o(e, \"blur\", function (l) {\n var t = l.target;\n t instanceof HTMLInputElement && (n.current = {\n value: t.value,\n selectionStart: t.selectionStart,\n selectionEnd: t.selectionEnd\n });\n }), u(function () {\n if (document.activeElement !== e && e instanceof HTMLInputElement && e.isConnected) {\n if (e.focus({\n preventScroll: !0\n }), e.value !== n.current.value) e.setSelectionRange(e.value.length, e.value.length);else {\n var _n$current = n.current,\n l = _n$current.selectionStart,\n t = _n$current.selectionEnd;\n l !== null && t !== null && e.setSelectionRange(l, t);\n }\n n.current = {\n value: \"\",\n selectionStart: null,\n selectionEnd: null\n };\n }\n });\n}\nexport { i as useRefocusableInput };","var g = function (f) {\n return f[f.Left = 0] = \"Left\", f[f.Right = 2] = \"Right\", f;\n}(g || {});\nexport { g as MouseButton };","'use strict';\nvar global = require('../internals/global');\nvar isCallable = require('../internals/is-callable');\n\nvar WeakMap = global.WeakMap;\n\nmodule.exports = isCallable(WeakMap) && /native code/.test(String(WeakMap));\n","'use strict';\nvar ceil = Math.ceil;\nvar floor = Math.floor;\n\n// `Math.trunc` method\n// https://tc39.es/ecma262/#sec-math.trunc\n// eslint-disable-next-line es/no-math-trunc -- safe\nmodule.exports = Math.trunc || function trunc(x) {\n var n = +x;\n return (n > 0 ? floor : ceil)(n);\n};\n","'use strict';\nvar isCallable = require('../internals/is-callable');\n\nvar $String = String;\nvar $TypeError = TypeError;\n\nmodule.exports = function (argument) {\n if (typeof argument == 'object' || isCallable(argument)) return argument;\n throw new $TypeError(\"Can't set \" + $String(argument) + ' as a prototype');\n};\n","'use strict';\nvar tryToString = require('../internals/try-to-string');\n\nvar $TypeError = TypeError;\n\nmodule.exports = function (O, P) {\n if (!delete O[P]) throw new $TypeError('Cannot delete property ' + tryToString(P) + ' of ' + tryToString(O));\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar toObject = require('../internals/to-object');\nvar toAbsoluteIndex = require('../internals/to-absolute-index');\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar setArrayLength = require('../internals/array-set-length');\nvar doesNotExceedSafeInteger = require('../internals/does-not-exceed-safe-integer');\nvar arraySpeciesCreate = require('../internals/array-species-create');\nvar createProperty = require('../internals/create-property');\nvar deletePropertyOrThrow = require('../internals/delete-property-or-throw');\nvar arrayMethodHasSpeciesSupport = require('../internals/array-method-has-species-support');\n\nvar HAS_SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('splice');\n\nvar max = Math.max;\nvar min = Math.min;\n\n// `Array.prototype.splice` method\n// https://tc39.es/ecma262/#sec-array.prototype.splice\n// with adding support of @@species\n$({ target: 'Array', proto: true, forced: !HAS_SPECIES_SUPPORT }, {\n splice: function splice(start, deleteCount /* , ...items */) {\n var O = toObject(this);\n var len = lengthOfArrayLike(O);\n var actualStart = toAbsoluteIndex(start, len);\n var argumentsLength = arguments.length;\n var insertCount, actualDeleteCount, A, k, from, to;\n if (argumentsLength === 0) {\n insertCount = actualDeleteCount = 0;\n } else if (argumentsLength === 1) {\n insertCount = 0;\n actualDeleteCount = len - actualStart;\n } else {\n insertCount = argumentsLength - 2;\n actualDeleteCount = min(max(toIntegerOrInfinity(deleteCount), 0), len - actualStart);\n }\n doesNotExceedSafeInteger(len + insertCount - actualDeleteCount);\n A = arraySpeciesCreate(O, actualDeleteCount);\n for (k = 0; k < actualDeleteCount; k++) {\n from = actualStart + k;\n if (from in O) createProperty(A, k, O[from]);\n }\n A.length = actualDeleteCount;\n if (insertCount < actualDeleteCount) {\n for (k = actualStart; k < len - actualDeleteCount; k++) {\n from = k + actualDeleteCount;\n to = k + insertCount;\n if (from in O) O[to] = O[from];\n else deletePropertyOrThrow(O, to);\n }\n for (k = len; k > len - actualDeleteCount + insertCount; k--) deletePropertyOrThrow(O, k - 1);\n } else if (insertCount > actualDeleteCount) {\n for (k = len - actualDeleteCount; k > actualStart; k--) {\n from = k + actualDeleteCount - 1;\n to = k + insertCount - 1;\n if (from in O) O[to] = O[from];\n else deletePropertyOrThrow(O, to);\n }\n }\n for (k = 0; k < insertCount; k++) {\n O[k + actualStart] = arguments[k + 2];\n }\n setArrayLength(O, len - actualDeleteCount + insertCount);\n return A;\n }\n});\n","'use strict';\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\nvar toString = require('../internals/to-string');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nvar $RangeError = RangeError;\n\n// `String.prototype.repeat` method implementation\n// https://tc39.es/ecma262/#sec-string.prototype.repeat\nmodule.exports = function repeat(count) {\n var str = toString(requireObjectCoercible(this));\n var result = '';\n var n = toIntegerOrInfinity(count);\n if (n < 0 || n === Infinity) throw new $RangeError('Wrong number of repetitions');\n for (;n > 0; (n >>>= 1) && (str += str)) if (n & 1) result += str;\n return result;\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar aCallable = require('../internals/a-callable');\nvar isObject = require('../internals/is-object');\nvar hasOwn = require('../internals/has-own-property');\nvar arraySlice = require('../internals/array-slice');\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar $Function = Function;\nvar concat = uncurryThis([].concat);\nvar join = uncurryThis([].join);\nvar factories = {};\n\nvar construct = function (C, argsLength, args) {\n if (!hasOwn(factories, argsLength)) {\n var list = [];\n var i = 0;\n for (; i < argsLength; i++) list[i] = 'a[' + i + ']';\n factories[argsLength] = $Function('C,a', 'return new C(' + join(list, ',') + ')');\n } return factories[argsLength](C, args);\n};\n\n// `Function.prototype.bind` method implementation\n// https://tc39.es/ecma262/#sec-function.prototype.bind\n// eslint-disable-next-line es/no-function-prototype-bind -- detection\nmodule.exports = NATIVE_BIND ? $Function.bind : function bind(that /* , ...args */) {\n var F = aCallable(this);\n var Prototype = F.prototype;\n var partArgs = arraySlice(arguments, 1);\n var boundFunction = function bound(/* args... */) {\n var args = concat(partArgs, arraySlice(arguments));\n return this instanceof boundFunction ? construct(F, args.length, args) : F.apply(that, args);\n };\n if (isObject(Prototype)) boundFunction.prototype = Prototype;\n return boundFunction;\n};\n","'use strict';\nvar fails = require('../internals/fails');\n\nmodule.exports = !fails(function () {\n // eslint-disable-next-line es/no-object-isextensible, es/no-object-preventextensions -- required for testing\n return Object.isExtensible(Object.preventExtensions({}));\n});\n","'use strict';\nvar global = require('../internals/global');\nvar bind = require('../internals/function-bind-context');\nvar getOwnPropertyDescriptor = require('../internals/object-get-own-property-descriptor').f;\nvar macrotask = require('../internals/task').set;\nvar Queue = require('../internals/queue');\nvar IS_IOS = require('../internals/engine-is-ios');\nvar IS_IOS_PEBBLE = require('../internals/engine-is-ios-pebble');\nvar IS_WEBOS_WEBKIT = require('../internals/engine-is-webos-webkit');\nvar IS_NODE = require('../internals/engine-is-node');\n\nvar MutationObserver = global.MutationObserver || global.WebKitMutationObserver;\nvar document = global.document;\nvar process = global.process;\nvar Promise = global.Promise;\n// Node.js 11 shows ExperimentalWarning on getting `queueMicrotask`\nvar queueMicrotaskDescriptor = getOwnPropertyDescriptor(global, 'queueMicrotask');\nvar microtask = queueMicrotaskDescriptor && queueMicrotaskDescriptor.value;\nvar notify, toggle, node, promise, then;\n\n// modern engines have queueMicrotask method\nif (!microtask) {\n var queue = new Queue();\n\n var flush = function () {\n var parent, fn;\n if (IS_NODE && (parent = process.domain)) parent.exit();\n while (fn = queue.get()) try {\n fn();\n } catch (error) {\n if (queue.head) notify();\n throw error;\n }\n if (parent) parent.enter();\n };\n\n // browsers with MutationObserver, except iOS - https://github.com/zloirock/core-js/issues/339\n // also except WebOS Webkit https://github.com/zloirock/core-js/issues/898\n if (!IS_IOS && !IS_NODE && !IS_WEBOS_WEBKIT && MutationObserver && document) {\n toggle = true;\n node = document.createTextNode('');\n new MutationObserver(flush).observe(node, { characterData: true });\n notify = function () {\n node.data = toggle = !toggle;\n };\n // environments with maybe non-completely correct, but existent Promise\n } else if (!IS_IOS_PEBBLE && Promise && Promise.resolve) {\n // Promise.resolve without an argument throws an error in LG WebOS 2\n promise = Promise.resolve(undefined);\n // workaround of WebKit ~ iOS Safari 10.1 bug\n promise.constructor = Promise;\n then = bind(promise.then, promise);\n notify = function () {\n then(flush);\n };\n // Node.js without promises\n } else if (IS_NODE) {\n notify = function () {\n process.nextTick(flush);\n };\n // for other environments - macrotask based on:\n // - setImmediate\n // - MessageChannel\n // - window.postMessage\n // - onreadystatechange\n // - setTimeout\n } else {\n // `webpack` dev server bug on IE global methods - use bind(fn, global)\n macrotask = bind(macrotask, global);\n notify = function () {\n macrotask(flush);\n };\n }\n\n microtask = function (fn) {\n if (!queue.head) notify();\n queue.add(fn);\n };\n}\n\nmodule.exports = microtask;\n","'use strict';\nvar IS_DENO = require('../internals/engine-is-deno');\nvar IS_NODE = require('../internals/engine-is-node');\n\nmodule.exports = !IS_DENO && !IS_NODE\n && typeof window == 'object'\n && typeof document == 'object';\n","'use strict';\nvar anObject = require('../internals/an-object');\nvar isObject = require('../internals/is-object');\nvar newPromiseCapability = require('../internals/new-promise-capability');\n\nmodule.exports = function (C, x) {\n anObject(C);\n if (isObject(x) && x.constructor === C) return x;\n var promiseCapability = newPromiseCapability.f(C);\n var resolve = promiseCapability.resolve;\n resolve(x);\n return promiseCapability.promise;\n};\n","'use strict';\nvar fails = require('../internals/fails');\nvar global = require('../internals/global');\n\n// babel-minify and Closure Compiler transpiles RegExp('(?b)', 'g') -> /(?b)/g and it causes SyntaxError\nvar $RegExp = global.RegExp;\n\nmodule.exports = fails(function () {\n var re = $RegExp('(?b)', 'g');\n return re.exec('b').groups.a !== 'b' ||\n 'b'.replace(re, '$c') !== 'bc';\n});\n","'use strict';\nvar isRegExp = require('../internals/is-regexp');\n\nvar $TypeError = TypeError;\n\nmodule.exports = function (it) {\n if (isRegExp(it)) {\n throw new $TypeError(\"The method doesn't accept regular expressions\");\n } return it;\n};\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar MATCH = wellKnownSymbol('match');\n\nmodule.exports = function (METHOD_NAME) {\n var regexp = /./;\n try {\n '/./'[METHOD_NAME](regexp);\n } catch (error1) {\n try {\n regexp[MATCH] = false;\n return '/./'[METHOD_NAME](regexp);\n } catch (error2) { /* empty */ }\n } return false;\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toObject = require('../internals/to-object');\n\nvar floor = Math.floor;\nvar charAt = uncurryThis(''.charAt);\nvar replace = uncurryThis(''.replace);\nvar stringSlice = uncurryThis(''.slice);\n// eslint-disable-next-line redos/no-vulnerable -- safe\nvar SUBSTITUTION_SYMBOLS = /\\$([$&'`]|\\d{1,2}|<[^>]*>)/g;\nvar SUBSTITUTION_SYMBOLS_NO_NAMED = /\\$([$&'`]|\\d{1,2})/g;\n\n// `GetSubstitution` abstract operation\n// https://tc39.es/ecma262/#sec-getsubstitution\nmodule.exports = function (matched, str, position, captures, namedCaptures, replacement) {\n var tailPos = position + matched.length;\n var m = captures.length;\n var symbols = SUBSTITUTION_SYMBOLS_NO_NAMED;\n if (namedCaptures !== undefined) {\n namedCaptures = toObject(namedCaptures);\n symbols = SUBSTITUTION_SYMBOLS;\n }\n return replace(replacement, symbols, function (match, ch) {\n var capture;\n switch (charAt(ch, 0)) {\n case '$': return '$';\n case '&': return matched;\n case '`': return stringSlice(str, 0, position);\n case \"'\": return stringSlice(str, tailPos);\n case '<':\n capture = namedCaptures[stringSlice(ch, 1, -1)];\n break;\n default: // \\d\\d?\n var n = +ch;\n if (n === 0) return match;\n if (n > m) {\n var f = floor(n / 10);\n if (f === 0) return match;\n if (f <= m) return captures[f - 1] === undefined ? charAt(ch, 1) : captures[f - 1] + charAt(ch, 1);\n return match;\n }\n capture = captures[n - 1];\n }\n return capture === undefined ? '' : capture;\n });\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar createHTML = require('../internals/create-html');\nvar forcedStringHTMLMethod = require('../internals/string-html-forced');\n\n// `String.prototype.fixed` method\n// https://tc39.es/ecma262/#sec-string.prototype.fixed\n$({ target: 'String', proto: true, forced: forcedStringHTMLMethod('fixed') }, {\n fixed: function fixed() {\n return createHTML(this, 'tt', '', '');\n }\n});\n","'use strict';\n// TODO: Remove this module from `core-js@4` since it's replaced to module below\nrequire('../modules/web.url.constructor');\n","'use strict';\n// TODO: Remove this module from `core-js@4` since it's replaced to module below\nrequire('../modules/web.url-search-params.constructor');\n","'use strict';\nvar $ = require('../internals/export');\nvar global = require('../internals/global');\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar IS_PURE = require('../internals/is-pure');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\nvar fails = require('../internals/fails');\nvar hasOwn = require('../internals/has-own-property');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar anObject = require('../internals/an-object');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar toPropertyKey = require('../internals/to-property-key');\nvar $toString = require('../internals/to-string');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\nvar nativeObjectCreate = require('../internals/object-create');\nvar objectKeys = require('../internals/object-keys');\nvar getOwnPropertyNamesModule = require('../internals/object-get-own-property-names');\nvar getOwnPropertyNamesExternal = require('../internals/object-get-own-property-names-external');\nvar getOwnPropertySymbolsModule = require('../internals/object-get-own-property-symbols');\nvar getOwnPropertyDescriptorModule = require('../internals/object-get-own-property-descriptor');\nvar definePropertyModule = require('../internals/object-define-property');\nvar definePropertiesModule = require('../internals/object-define-properties');\nvar propertyIsEnumerableModule = require('../internals/object-property-is-enumerable');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar shared = require('../internals/shared');\nvar sharedKey = require('../internals/shared-key');\nvar hiddenKeys = require('../internals/hidden-keys');\nvar uid = require('../internals/uid');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar wrappedWellKnownSymbolModule = require('../internals/well-known-symbol-wrapped');\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\nvar defineSymbolToPrimitive = require('../internals/symbol-define-to-primitive');\nvar setToStringTag = require('../internals/set-to-string-tag');\nvar InternalStateModule = require('../internals/internal-state');\nvar $forEach = require('../internals/array-iteration').forEach;\n\nvar HIDDEN = sharedKey('hidden');\nvar SYMBOL = 'Symbol';\nvar PROTOTYPE = 'prototype';\n\nvar setInternalState = InternalStateModule.set;\nvar getInternalState = InternalStateModule.getterFor(SYMBOL);\n\nvar ObjectPrototype = Object[PROTOTYPE];\nvar $Symbol = global.Symbol;\nvar SymbolPrototype = $Symbol && $Symbol[PROTOTYPE];\nvar RangeError = global.RangeError;\nvar TypeError = global.TypeError;\nvar QObject = global.QObject;\nvar nativeGetOwnPropertyDescriptor = getOwnPropertyDescriptorModule.f;\nvar nativeDefineProperty = definePropertyModule.f;\nvar nativeGetOwnPropertyNames = getOwnPropertyNamesExternal.f;\nvar nativePropertyIsEnumerable = propertyIsEnumerableModule.f;\nvar push = uncurryThis([].push);\n\nvar AllSymbols = shared('symbols');\nvar ObjectPrototypeSymbols = shared('op-symbols');\nvar WellKnownSymbolsStore = shared('wks');\n\n// Don't use setters in Qt Script, https://github.com/zloirock/core-js/issues/173\nvar USE_SETTER = !QObject || !QObject[PROTOTYPE] || !QObject[PROTOTYPE].findChild;\n\n// fallback for old Android, https://code.google.com/p/v8/issues/detail?id=687\nvar fallbackDefineProperty = function (O, P, Attributes) {\n var ObjectPrototypeDescriptor = nativeGetOwnPropertyDescriptor(ObjectPrototype, P);\n if (ObjectPrototypeDescriptor) delete ObjectPrototype[P];\n nativeDefineProperty(O, P, Attributes);\n if (ObjectPrototypeDescriptor && O !== ObjectPrototype) {\n nativeDefineProperty(ObjectPrototype, P, ObjectPrototypeDescriptor);\n }\n};\n\nvar setSymbolDescriptor = DESCRIPTORS && fails(function () {\n return nativeObjectCreate(nativeDefineProperty({}, 'a', {\n get: function () { return nativeDefineProperty(this, 'a', { value: 7 }).a; }\n })).a !== 7;\n}) ? fallbackDefineProperty : nativeDefineProperty;\n\nvar wrap = function (tag, description) {\n var symbol = AllSymbols[tag] = nativeObjectCreate(SymbolPrototype);\n setInternalState(symbol, {\n type: SYMBOL,\n tag: tag,\n description: description\n });\n if (!DESCRIPTORS) symbol.description = description;\n return symbol;\n};\n\nvar $defineProperty = function defineProperty(O, P, Attributes) {\n if (O === ObjectPrototype) $defineProperty(ObjectPrototypeSymbols, P, Attributes);\n anObject(O);\n var key = toPropertyKey(P);\n anObject(Attributes);\n if (hasOwn(AllSymbols, key)) {\n if (!Attributes.enumerable) {\n if (!hasOwn(O, HIDDEN)) nativeDefineProperty(O, HIDDEN, createPropertyDescriptor(1, {}));\n O[HIDDEN][key] = true;\n } else {\n if (hasOwn(O, HIDDEN) && O[HIDDEN][key]) O[HIDDEN][key] = false;\n Attributes = nativeObjectCreate(Attributes, { enumerable: createPropertyDescriptor(0, false) });\n } return setSymbolDescriptor(O, key, Attributes);\n } return nativeDefineProperty(O, key, Attributes);\n};\n\nvar $defineProperties = function defineProperties(O, Properties) {\n anObject(O);\n var properties = toIndexedObject(Properties);\n var keys = objectKeys(properties).concat($getOwnPropertySymbols(properties));\n $forEach(keys, function (key) {\n if (!DESCRIPTORS || call($propertyIsEnumerable, properties, key)) $defineProperty(O, key, properties[key]);\n });\n return O;\n};\n\nvar $create = function create(O, Properties) {\n return Properties === undefined ? nativeObjectCreate(O) : $defineProperties(nativeObjectCreate(O), Properties);\n};\n\nvar $propertyIsEnumerable = function propertyIsEnumerable(V) {\n var P = toPropertyKey(V);\n var enumerable = call(nativePropertyIsEnumerable, this, P);\n if (this === ObjectPrototype && hasOwn(AllSymbols, P) && !hasOwn(ObjectPrototypeSymbols, P)) return false;\n return enumerable || !hasOwn(this, P) || !hasOwn(AllSymbols, P) || hasOwn(this, HIDDEN) && this[HIDDEN][P]\n ? enumerable : true;\n};\n\nvar $getOwnPropertyDescriptor = function getOwnPropertyDescriptor(O, P) {\n var it = toIndexedObject(O);\n var key = toPropertyKey(P);\n if (it === ObjectPrototype && hasOwn(AllSymbols, key) && !hasOwn(ObjectPrototypeSymbols, key)) return;\n var descriptor = nativeGetOwnPropertyDescriptor(it, key);\n if (descriptor && hasOwn(AllSymbols, key) && !(hasOwn(it, HIDDEN) && it[HIDDEN][key])) {\n descriptor.enumerable = true;\n }\n return descriptor;\n};\n\nvar $getOwnPropertyNames = function getOwnPropertyNames(O) {\n var names = nativeGetOwnPropertyNames(toIndexedObject(O));\n var result = [];\n $forEach(names, function (key) {\n if (!hasOwn(AllSymbols, key) && !hasOwn(hiddenKeys, key)) push(result, key);\n });\n return result;\n};\n\nvar $getOwnPropertySymbols = function (O) {\n var IS_OBJECT_PROTOTYPE = O === ObjectPrototype;\n var names = nativeGetOwnPropertyNames(IS_OBJECT_PROTOTYPE ? ObjectPrototypeSymbols : toIndexedObject(O));\n var result = [];\n $forEach(names, function (key) {\n if (hasOwn(AllSymbols, key) && (!IS_OBJECT_PROTOTYPE || hasOwn(ObjectPrototype, key))) {\n push(result, AllSymbols[key]);\n }\n });\n return result;\n};\n\n// `Symbol` constructor\n// https://tc39.es/ecma262/#sec-symbol-constructor\nif (!NATIVE_SYMBOL) {\n $Symbol = function Symbol() {\n if (isPrototypeOf(SymbolPrototype, this)) throw new TypeError('Symbol is not a constructor');\n var description = !arguments.length || arguments[0] === undefined ? undefined : $toString(arguments[0]);\n var tag = uid(description);\n var setter = function (value) {\n var $this = this === undefined ? global : this;\n if ($this === ObjectPrototype) call(setter, ObjectPrototypeSymbols, value);\n if (hasOwn($this, HIDDEN) && hasOwn($this[HIDDEN], tag)) $this[HIDDEN][tag] = false;\n var descriptor = createPropertyDescriptor(1, value);\n try {\n setSymbolDescriptor($this, tag, descriptor);\n } catch (error) {\n if (!(error instanceof RangeError)) throw error;\n fallbackDefineProperty($this, tag, descriptor);\n }\n };\n if (DESCRIPTORS && USE_SETTER) setSymbolDescriptor(ObjectPrototype, tag, { configurable: true, set: setter });\n return wrap(tag, description);\n };\n\n SymbolPrototype = $Symbol[PROTOTYPE];\n\n defineBuiltIn(SymbolPrototype, 'toString', function toString() {\n return getInternalState(this).tag;\n });\n\n defineBuiltIn($Symbol, 'withoutSetter', function (description) {\n return wrap(uid(description), description);\n });\n\n propertyIsEnumerableModule.f = $propertyIsEnumerable;\n definePropertyModule.f = $defineProperty;\n definePropertiesModule.f = $defineProperties;\n getOwnPropertyDescriptorModule.f = $getOwnPropertyDescriptor;\n getOwnPropertyNamesModule.f = getOwnPropertyNamesExternal.f = $getOwnPropertyNames;\n getOwnPropertySymbolsModule.f = $getOwnPropertySymbols;\n\n wrappedWellKnownSymbolModule.f = function (name) {\n return wrap(wellKnownSymbol(name), name);\n };\n\n if (DESCRIPTORS) {\n // https://github.com/tc39/proposal-Symbol-description\n defineBuiltInAccessor(SymbolPrototype, 'description', {\n configurable: true,\n get: function description() {\n return getInternalState(this).description;\n }\n });\n if (!IS_PURE) {\n defineBuiltIn(ObjectPrototype, 'propertyIsEnumerable', $propertyIsEnumerable, { unsafe: true });\n }\n }\n}\n\n$({ global: true, constructor: true, wrap: true, forced: !NATIVE_SYMBOL, sham: !NATIVE_SYMBOL }, {\n Symbol: $Symbol\n});\n\n$forEach(objectKeys(WellKnownSymbolsStore), function (name) {\n defineWellKnownSymbol(name);\n});\n\n$({ target: SYMBOL, stat: true, forced: !NATIVE_SYMBOL }, {\n useSetter: function () { USE_SETTER = true; },\n useSimple: function () { USE_SETTER = false; }\n});\n\n$({ target: 'Object', stat: true, forced: !NATIVE_SYMBOL, sham: !DESCRIPTORS }, {\n // `Object.create` method\n // https://tc39.es/ecma262/#sec-object.create\n create: $create,\n // `Object.defineProperty` method\n // https://tc39.es/ecma262/#sec-object.defineproperty\n defineProperty: $defineProperty,\n // `Object.defineProperties` method\n // https://tc39.es/ecma262/#sec-object.defineproperties\n defineProperties: $defineProperties,\n // `Object.getOwnPropertyDescriptor` method\n // https://tc39.es/ecma262/#sec-object.getownpropertydescriptors\n getOwnPropertyDescriptor: $getOwnPropertyDescriptor\n});\n\n$({ target: 'Object', stat: true, forced: !NATIVE_SYMBOL }, {\n // `Object.getOwnPropertyNames` method\n // https://tc39.es/ecma262/#sec-object.getownpropertynames\n getOwnPropertyNames: $getOwnPropertyNames\n});\n\n// `Symbol.prototype[@@toPrimitive]` method\n// https://tc39.es/ecma262/#sec-symbol.prototype-@@toprimitive\ndefineSymbolToPrimitive();\n\n// `Symbol.prototype[@@toStringTag]` property\n// https://tc39.es/ecma262/#sec-symbol.prototype-@@tostringtag\nsetToStringTag($Symbol, SYMBOL);\n\nhiddenKeys[HIDDEN] = true;\n","'use strict';\nvar isArray = require('../internals/is-array');\nvar isConstructor = require('../internals/is-constructor');\nvar isObject = require('../internals/is-object');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar SPECIES = wellKnownSymbol('species');\nvar $Array = Array;\n\n// a part of `ArraySpeciesCreate` abstract operation\n// https://tc39.es/ecma262/#sec-arrayspeciescreate\nmodule.exports = function (originalArray) {\n var C;\n if (isArray(originalArray)) {\n C = originalArray.constructor;\n // cross-realm fallback\n if (isConstructor(C) && (C === $Array || isArray(C.prototype))) C = undefined;\n else if (isObject(C)) {\n C = C[SPECIES];\n if (C === null) C = undefined;\n }\n } return C === undefined ? $Array : C;\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar getBuiltIn = require('../internals/get-built-in');\nvar hasOwn = require('../internals/has-own-property');\nvar toString = require('../internals/to-string');\nvar shared = require('../internals/shared');\nvar NATIVE_SYMBOL_REGISTRY = require('../internals/symbol-registry-detection');\n\nvar StringToSymbolRegistry = shared('string-to-symbol-registry');\nvar SymbolToStringRegistry = shared('symbol-to-string-registry');\n\n// `Symbol.for` method\n// https://tc39.es/ecma262/#sec-symbol.for\n$({ target: 'Symbol', stat: true, forced: !NATIVE_SYMBOL_REGISTRY }, {\n 'for': function (key) {\n var string = toString(key);\n if (hasOwn(StringToSymbolRegistry, string)) return StringToSymbolRegistry[string];\n var symbol = getBuiltIn('Symbol')(string);\n StringToSymbolRegistry[string] = symbol;\n SymbolToStringRegistry[symbol] = string;\n return symbol;\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar hasOwn = require('../internals/has-own-property');\nvar isSymbol = require('../internals/is-symbol');\nvar tryToString = require('../internals/try-to-string');\nvar shared = require('../internals/shared');\nvar NATIVE_SYMBOL_REGISTRY = require('../internals/symbol-registry-detection');\n\nvar SymbolToStringRegistry = shared('symbol-to-string-registry');\n\n// `Symbol.keyFor` method\n// https://tc39.es/ecma262/#sec-symbol.keyfor\n$({ target: 'Symbol', stat: true, forced: !NATIVE_SYMBOL_REGISTRY }, {\n keyFor: function keyFor(sym) {\n if (!isSymbol(sym)) throw new TypeError(tryToString(sym) + ' is not a symbol');\n if (hasOwn(SymbolToStringRegistry, sym)) return SymbolToStringRegistry[sym];\n }\n});\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar isArray = require('../internals/is-array');\nvar isCallable = require('../internals/is-callable');\nvar classof = require('../internals/classof-raw');\nvar toString = require('../internals/to-string');\n\nvar push = uncurryThis([].push);\n\nmodule.exports = function (replacer) {\n if (isCallable(replacer)) return replacer;\n if (!isArray(replacer)) return;\n var rawLength = replacer.length;\n var keys = [];\n for (var i = 0; i < rawLength; i++) {\n var element = replacer[i];\n if (typeof element == 'string') push(keys, element);\n else if (typeof element == 'number' || classof(element) === 'Number' || classof(element) === 'String') push(keys, toString(element));\n }\n var keysLength = keys.length;\n var root = true;\n return function (key, value) {\n if (root) {\n root = false;\n return value;\n }\n if (isArray(this)) return value;\n for (var j = 0; j < keysLength; j++) if (keys[j] === key) return value;\n };\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\nvar fails = require('../internals/fails');\nvar getOwnPropertySymbolsModule = require('../internals/object-get-own-property-symbols');\nvar toObject = require('../internals/to-object');\n\n// V8 ~ Chrome 38 and 39 `Object.getOwnPropertySymbols` fails on primitives\n// https://bugs.chromium.org/p/v8/issues/detail?id=3443\nvar FORCED = !NATIVE_SYMBOL || fails(function () { getOwnPropertySymbolsModule.f(1); });\n\n// `Object.getOwnPropertySymbols` method\n// https://tc39.es/ecma262/#sec-object.getownpropertysymbols\n$({ target: 'Object', stat: true, forced: FORCED }, {\n getOwnPropertySymbols: function getOwnPropertySymbols(it) {\n var $getOwnPropertySymbols = getOwnPropertySymbolsModule.f;\n return $getOwnPropertySymbols ? $getOwnPropertySymbols(toObject(it)) : [];\n }\n});\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar aCallable = require('../internals/a-callable');\n\nmodule.exports = function (object, key, method) {\n try {\n // eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\n return uncurryThis(aCallable(Object.getOwnPropertyDescriptor(object, key)[method]));\n } catch (error) { /* empty */ }\n};\n","'use strict';\nvar toString = require('../internals/to-string');\n\nmodule.exports = function (argument, $default) {\n return argument === undefined ? arguments.length < 2 ? '' : $default : toString(argument);\n};\n","'use strict';\nvar toObject = require('../internals/to-object');\nvar toAbsoluteIndex = require('../internals/to-absolute-index');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\n\n// `Array.prototype.fill` method implementation\n// https://tc39.es/ecma262/#sec-array.prototype.fill\nmodule.exports = function fill(value /* , start = 0, end = @length */) {\n var O = toObject(this);\n var length = lengthOfArrayLike(O);\n var argumentsLength = arguments.length;\n var index = toAbsoluteIndex(argumentsLength > 1 ? arguments[1] : undefined, length);\n var end = argumentsLength > 2 ? arguments[2] : undefined;\n var endPos = end === undefined ? length : toAbsoluteIndex(end, length);\n while (endPos > index) O[index++] = value;\n return O;\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar isArray = require('../internals/is-array');\n\nvar $TypeError = TypeError;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\n// Safari < 13 does not throw an error in this case\nvar SILENT_ON_NON_WRITABLE_LENGTH_SET = DESCRIPTORS && !function () {\n // makes no sense without proper strict mode support\n if (this !== undefined) return true;\n try {\n // eslint-disable-next-line es/no-object-defineproperty -- safe\n Object.defineProperty([], 'length', { writable: false }).length = 1;\n } catch (error) {\n return error instanceof TypeError;\n }\n}();\n\nmodule.exports = SILENT_ON_NON_WRITABLE_LENGTH_SET ? function (O, length) {\n if (isArray(O) && !getOwnPropertyDescriptor(O, 'length').writable) {\n throw new $TypeError('Cannot set read only .length');\n } return O.length = length;\n} : function (O, length) {\n return O.length = length;\n};\n","'use strict';\nvar anObject = require('../internals/an-object');\nvar ordinaryToPrimitive = require('../internals/ordinary-to-primitive');\n\nvar $TypeError = TypeError;\n\n// `Date.prototype[@@toPrimitive](hint)` method implementation\n// https://tc39.es/ecma262/#sec-date.prototype-@@toprimitive\nmodule.exports = function (hint) {\n anObject(this);\n if (hint === 'string' || hint === 'default') hint = 'string';\n else if (hint !== 'number') throw new $TypeError('Incorrect hint');\n return ordinaryToPrimitive(this, hint);\n};\n","'use strict';\nvar TO_STRING_TAG_SUPPORT = require('../internals/to-string-tag-support');\nvar classof = require('../internals/classof');\n\n// `Object.prototype.toString` method implementation\n// https://tc39.es/ecma262/#sec-object.prototype.tostring\nmodule.exports = TO_STRING_TAG_SUPPORT ? {}.toString : function toString() {\n return '[object ' + classof(this) + ']';\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar IS_PURE = require('../internals/is-pure');\nvar IS_NODE = require('../internals/engine-is-node');\nvar global = require('../internals/global');\nvar call = require('../internals/function-call');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar setPrototypeOf = require('../internals/object-set-prototype-of');\nvar setToStringTag = require('../internals/set-to-string-tag');\nvar setSpecies = require('../internals/set-species');\nvar aCallable = require('../internals/a-callable');\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\nvar anInstance = require('../internals/an-instance');\nvar speciesConstructor = require('../internals/species-constructor');\nvar task = require('../internals/task').set;\nvar microtask = require('../internals/microtask');\nvar hostReportErrors = require('../internals/host-report-errors');\nvar perform = require('../internals/perform');\nvar Queue = require('../internals/queue');\nvar InternalStateModule = require('../internals/internal-state');\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar PromiseConstructorDetection = require('../internals/promise-constructor-detection');\nvar newPromiseCapabilityModule = require('../internals/new-promise-capability');\n\nvar PROMISE = 'Promise';\nvar FORCED_PROMISE_CONSTRUCTOR = PromiseConstructorDetection.CONSTRUCTOR;\nvar NATIVE_PROMISE_REJECTION_EVENT = PromiseConstructorDetection.REJECTION_EVENT;\nvar NATIVE_PROMISE_SUBCLASSING = PromiseConstructorDetection.SUBCLASSING;\nvar getInternalPromiseState = InternalStateModule.getterFor(PROMISE);\nvar setInternalState = InternalStateModule.set;\nvar NativePromisePrototype = NativePromiseConstructor && NativePromiseConstructor.prototype;\nvar PromiseConstructor = NativePromiseConstructor;\nvar PromisePrototype = NativePromisePrototype;\nvar TypeError = global.TypeError;\nvar document = global.document;\nvar process = global.process;\nvar newPromiseCapability = newPromiseCapabilityModule.f;\nvar newGenericPromiseCapability = newPromiseCapability;\n\nvar DISPATCH_EVENT = !!(document && document.createEvent && global.dispatchEvent);\nvar UNHANDLED_REJECTION = 'unhandledrejection';\nvar REJECTION_HANDLED = 'rejectionhandled';\nvar PENDING = 0;\nvar FULFILLED = 1;\nvar REJECTED = 2;\nvar HANDLED = 1;\nvar UNHANDLED = 2;\n\nvar Internal, OwnPromiseCapability, PromiseWrapper, nativeThen;\n\n// helpers\nvar isThenable = function (it) {\n var then;\n return isObject(it) && isCallable(then = it.then) ? then : false;\n};\n\nvar callReaction = function (reaction, state) {\n var value = state.value;\n var ok = state.state === FULFILLED;\n var handler = ok ? reaction.ok : reaction.fail;\n var resolve = reaction.resolve;\n var reject = reaction.reject;\n var domain = reaction.domain;\n var result, then, exited;\n try {\n if (handler) {\n if (!ok) {\n if (state.rejection === UNHANDLED) onHandleUnhandled(state);\n state.rejection = HANDLED;\n }\n if (handler === true) result = value;\n else {\n if (domain) domain.enter();\n result = handler(value); // can throw\n if (domain) {\n domain.exit();\n exited = true;\n }\n }\n if (result === reaction.promise) {\n reject(new TypeError('Promise-chain cycle'));\n } else if (then = isThenable(result)) {\n call(then, result, resolve, reject);\n } else resolve(result);\n } else reject(value);\n } catch (error) {\n if (domain && !exited) domain.exit();\n reject(error);\n }\n};\n\nvar notify = function (state, isReject) {\n if (state.notified) return;\n state.notified = true;\n microtask(function () {\n var reactions = state.reactions;\n var reaction;\n while (reaction = reactions.get()) {\n callReaction(reaction, state);\n }\n state.notified = false;\n if (isReject && !state.rejection) onUnhandled(state);\n });\n};\n\nvar dispatchEvent = function (name, promise, reason) {\n var event, handler;\n if (DISPATCH_EVENT) {\n event = document.createEvent('Event');\n event.promise = promise;\n event.reason = reason;\n event.initEvent(name, false, true);\n global.dispatchEvent(event);\n } else event = { promise: promise, reason: reason };\n if (!NATIVE_PROMISE_REJECTION_EVENT && (handler = global['on' + name])) handler(event);\n else if (name === UNHANDLED_REJECTION) hostReportErrors('Unhandled promise rejection', reason);\n};\n\nvar onUnhandled = function (state) {\n call(task, global, function () {\n var promise = state.facade;\n var value = state.value;\n var IS_UNHANDLED = isUnhandled(state);\n var result;\n if (IS_UNHANDLED) {\n result = perform(function () {\n if (IS_NODE) {\n process.emit('unhandledRejection', value, promise);\n } else dispatchEvent(UNHANDLED_REJECTION, promise, value);\n });\n // Browsers should not trigger `rejectionHandled` event if it was handled here, NodeJS - should\n state.rejection = IS_NODE || isUnhandled(state) ? UNHANDLED : HANDLED;\n if (result.error) throw result.value;\n }\n });\n};\n\nvar isUnhandled = function (state) {\n return state.rejection !== HANDLED && !state.parent;\n};\n\nvar onHandleUnhandled = function (state) {\n call(task, global, function () {\n var promise = state.facade;\n if (IS_NODE) {\n process.emit('rejectionHandled', promise);\n } else dispatchEvent(REJECTION_HANDLED, promise, state.value);\n });\n};\n\nvar bind = function (fn, state, unwrap) {\n return function (value) {\n fn(state, value, unwrap);\n };\n};\n\nvar internalReject = function (state, value, unwrap) {\n if (state.done) return;\n state.done = true;\n if (unwrap) state = unwrap;\n state.value = value;\n state.state = REJECTED;\n notify(state, true);\n};\n\nvar internalResolve = function (state, value, unwrap) {\n if (state.done) return;\n state.done = true;\n if (unwrap) state = unwrap;\n try {\n if (state.facade === value) throw new TypeError(\"Promise can't be resolved itself\");\n var then = isThenable(value);\n if (then) {\n microtask(function () {\n var wrapper = { done: false };\n try {\n call(then, value,\n bind(internalResolve, wrapper, state),\n bind(internalReject, wrapper, state)\n );\n } catch (error) {\n internalReject(wrapper, error, state);\n }\n });\n } else {\n state.value = value;\n state.state = FULFILLED;\n notify(state, false);\n }\n } catch (error) {\n internalReject({ done: false }, error, state);\n }\n};\n\n// constructor polyfill\nif (FORCED_PROMISE_CONSTRUCTOR) {\n // 25.4.3.1 Promise(executor)\n PromiseConstructor = function Promise(executor) {\n anInstance(this, PromisePrototype);\n aCallable(executor);\n call(Internal, this);\n var state = getInternalPromiseState(this);\n try {\n executor(bind(internalResolve, state), bind(internalReject, state));\n } catch (error) {\n internalReject(state, error);\n }\n };\n\n PromisePrototype = PromiseConstructor.prototype;\n\n // eslint-disable-next-line no-unused-vars -- required for `.length`\n Internal = function Promise(executor) {\n setInternalState(this, {\n type: PROMISE,\n done: false,\n notified: false,\n parent: false,\n reactions: new Queue(),\n rejection: false,\n state: PENDING,\n value: undefined\n });\n };\n\n // `Promise.prototype.then` method\n // https://tc39.es/ecma262/#sec-promise.prototype.then\n Internal.prototype = defineBuiltIn(PromisePrototype, 'then', function then(onFulfilled, onRejected) {\n var state = getInternalPromiseState(this);\n var reaction = newPromiseCapability(speciesConstructor(this, PromiseConstructor));\n state.parent = true;\n reaction.ok = isCallable(onFulfilled) ? onFulfilled : true;\n reaction.fail = isCallable(onRejected) && onRejected;\n reaction.domain = IS_NODE ? process.domain : undefined;\n if (state.state === PENDING) state.reactions.add(reaction);\n else microtask(function () {\n callReaction(reaction, state);\n });\n return reaction.promise;\n });\n\n OwnPromiseCapability = function () {\n var promise = new Internal();\n var state = getInternalPromiseState(promise);\n this.promise = promise;\n this.resolve = bind(internalResolve, state);\n this.reject = bind(internalReject, state);\n };\n\n newPromiseCapabilityModule.f = newPromiseCapability = function (C) {\n return C === PromiseConstructor || C === PromiseWrapper\n ? new OwnPromiseCapability(C)\n : newGenericPromiseCapability(C);\n };\n\n if (!IS_PURE && isCallable(NativePromiseConstructor) && NativePromisePrototype !== Object.prototype) {\n nativeThen = NativePromisePrototype.then;\n\n if (!NATIVE_PROMISE_SUBCLASSING) {\n // make `Promise#then` return a polyfilled `Promise` for native promise-based APIs\n defineBuiltIn(NativePromisePrototype, 'then', function then(onFulfilled, onRejected) {\n var that = this;\n return new PromiseConstructor(function (resolve, reject) {\n call(nativeThen, that, resolve, reject);\n }).then(onFulfilled, onRejected);\n // https://github.com/zloirock/core-js/issues/640\n }, { unsafe: true });\n }\n\n // make `.constructor === Promise` work for native promise-based APIs\n try {\n delete NativePromisePrototype.constructor;\n } catch (error) { /* empty */ }\n\n // make `instanceof Promise` work for native promise-based APIs\n if (setPrototypeOf) {\n setPrototypeOf(NativePromisePrototype, PromisePrototype);\n }\n }\n}\n\n$({ global: true, constructor: true, wrap: true, forced: FORCED_PROMISE_CONSTRUCTOR }, {\n Promise: PromiseConstructor\n});\n\nsetToStringTag(PromiseConstructor, PROMISE, false, true);\nsetSpecies(PROMISE);\n","'use strict';\nvar userAgent = require('../internals/engine-user-agent');\n\nmodule.exports = /ipad|iphone|ipod/i.test(userAgent) && typeof Pebble != 'undefined';\n","'use strict';\nvar userAgent = require('../internals/engine-user-agent');\n\nmodule.exports = /web0s(?!.*chrome)/i.test(userAgent);\n","'use strict';\nmodule.exports = function (a, b) {\n try {\n // eslint-disable-next-line no-console -- safe\n arguments.length === 1 ? console.error(a) : console.error(a, b);\n } catch (error) { /* empty */ }\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar newPromiseCapabilityModule = require('../internals/new-promise-capability');\nvar perform = require('../internals/perform');\nvar iterate = require('../internals/iterate');\nvar PROMISE_STATICS_INCORRECT_ITERATION = require('../internals/promise-statics-incorrect-iteration');\n\n// `Promise.all` method\n// https://tc39.es/ecma262/#sec-promise.all\n$({ target: 'Promise', stat: true, forced: PROMISE_STATICS_INCORRECT_ITERATION }, {\n all: function all(iterable) {\n var C = this;\n var capability = newPromiseCapabilityModule.f(C);\n var resolve = capability.resolve;\n var reject = capability.reject;\n var result = perform(function () {\n var $promiseResolve = aCallable(C.resolve);\n var values = [];\n var counter = 0;\n var remaining = 1;\n iterate(iterable, function (promise) {\n var index = counter++;\n var alreadyCalled = false;\n remaining++;\n call($promiseResolve, C, promise).then(function (value) {\n if (alreadyCalled) return;\n alreadyCalled = true;\n values[index] = value;\n --remaining || resolve(values);\n }, reject);\n });\n --remaining || resolve(values);\n });\n if (result.error) reject(result.value);\n return capability.promise;\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar IS_PURE = require('../internals/is-pure');\nvar FORCED_PROMISE_CONSTRUCTOR = require('../internals/promise-constructor-detection').CONSTRUCTOR;\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar getBuiltIn = require('../internals/get-built-in');\nvar isCallable = require('../internals/is-callable');\nvar defineBuiltIn = require('../internals/define-built-in');\n\nvar NativePromisePrototype = NativePromiseConstructor && NativePromiseConstructor.prototype;\n\n// `Promise.prototype.catch` method\n// https://tc39.es/ecma262/#sec-promise.prototype.catch\n$({ target: 'Promise', proto: true, forced: FORCED_PROMISE_CONSTRUCTOR, real: true }, {\n 'catch': function (onRejected) {\n return this.then(undefined, onRejected);\n }\n});\n\n// makes sure that native promise-based APIs `Promise#catch` properly works with patched `Promise#then`\nif (!IS_PURE && isCallable(NativePromiseConstructor)) {\n var method = getBuiltIn('Promise').prototype['catch'];\n if (NativePromisePrototype['catch'] !== method) {\n defineBuiltIn(NativePromisePrototype, 'catch', method, { unsafe: true });\n }\n}\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar newPromiseCapabilityModule = require('../internals/new-promise-capability');\nvar perform = require('../internals/perform');\nvar iterate = require('../internals/iterate');\nvar PROMISE_STATICS_INCORRECT_ITERATION = require('../internals/promise-statics-incorrect-iteration');\n\n// `Promise.race` method\n// https://tc39.es/ecma262/#sec-promise.race\n$({ target: 'Promise', stat: true, forced: PROMISE_STATICS_INCORRECT_ITERATION }, {\n race: function race(iterable) {\n var C = this;\n var capability = newPromiseCapabilityModule.f(C);\n var reject = capability.reject;\n var result = perform(function () {\n var $promiseResolve = aCallable(C.resolve);\n iterate(iterable, function (promise) {\n call($promiseResolve, C, promise).then(capability.resolve, reject);\n });\n });\n if (result.error) reject(result.value);\n return capability.promise;\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar newPromiseCapabilityModule = require('../internals/new-promise-capability');\nvar FORCED_PROMISE_CONSTRUCTOR = require('../internals/promise-constructor-detection').CONSTRUCTOR;\n\n// `Promise.reject` method\n// https://tc39.es/ecma262/#sec-promise.reject\n$({ target: 'Promise', stat: true, forced: FORCED_PROMISE_CONSTRUCTOR }, {\n reject: function reject(r) {\n var capability = newPromiseCapabilityModule.f(this);\n call(capability.reject, undefined, r);\n return capability.promise;\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar getBuiltIn = require('../internals/get-built-in');\nvar IS_PURE = require('../internals/is-pure');\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar FORCED_PROMISE_CONSTRUCTOR = require('../internals/promise-constructor-detection').CONSTRUCTOR;\nvar promiseResolve = require('../internals/promise-resolve');\n\nvar PromiseConstructorWrapper = getBuiltIn('Promise');\nvar CHECK_WRAPPER = IS_PURE && !FORCED_PROMISE_CONSTRUCTOR;\n\n// `Promise.resolve` method\n// https://tc39.es/ecma262/#sec-promise.resolve\n$({ target: 'Promise', stat: true, forced: IS_PURE || FORCED_PROMISE_CONSTRUCTOR }, {\n resolve: function resolve(x) {\n return promiseResolve(CHECK_WRAPPER && this === PromiseConstructorWrapper ? NativePromiseConstructor : this, x);\n }\n});\n","'use strict';\nvar PROPER_FUNCTION_NAME = require('../internals/function-name').PROPER;\nvar fails = require('../internals/fails');\nvar whitespaces = require('../internals/whitespaces');\n\nvar non = '\\u200B\\u0085\\u180E';\n\n// check that a method works with the correct list\n// of whitespaces and has a correct name\nmodule.exports = function (METHOD_NAME) {\n return fails(function () {\n return !!whitespaces[METHOD_NAME]()\n || non[METHOD_NAME]() !== non\n || (PROPER_FUNCTION_NAME && whitespaces[METHOD_NAME].name !== METHOD_NAME);\n });\n};\n","'use strict';\n// TODO: in core-js@4, move /modules/ dependencies to public entries for better optimization by tools like `preset-env`\nrequire('../modules/es.string.iterator');\nvar $ = require('../internals/export');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar USE_NATIVE_URL = require('../internals/url-constructor-detection');\nvar global = require('../internals/global');\nvar bind = require('../internals/function-bind-context');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar anInstance = require('../internals/an-instance');\nvar hasOwn = require('../internals/has-own-property');\nvar assign = require('../internals/object-assign');\nvar arrayFrom = require('../internals/array-from');\nvar arraySlice = require('../internals/array-slice-simple');\nvar codeAt = require('../internals/string-multibyte').codeAt;\nvar toASCII = require('../internals/string-punycode-to-ascii');\nvar $toString = require('../internals/to-string');\nvar setToStringTag = require('../internals/set-to-string-tag');\nvar validateArgumentsLength = require('../internals/validate-arguments-length');\nvar URLSearchParamsModule = require('../modules/web.url-search-params.constructor');\nvar InternalStateModule = require('../internals/internal-state');\n\nvar setInternalState = InternalStateModule.set;\nvar getInternalURLState = InternalStateModule.getterFor('URL');\nvar URLSearchParams = URLSearchParamsModule.URLSearchParams;\nvar getInternalSearchParamsState = URLSearchParamsModule.getState;\n\nvar NativeURL = global.URL;\nvar TypeError = global.TypeError;\nvar parseInt = global.parseInt;\nvar floor = Math.floor;\nvar pow = Math.pow;\nvar charAt = uncurryThis(''.charAt);\nvar exec = uncurryThis(/./.exec);\nvar join = uncurryThis([].join);\nvar numberToString = uncurryThis(1.0.toString);\nvar pop = uncurryThis([].pop);\nvar push = uncurryThis([].push);\nvar replace = uncurryThis(''.replace);\nvar shift = uncurryThis([].shift);\nvar split = uncurryThis(''.split);\nvar stringSlice = uncurryThis(''.slice);\nvar toLowerCase = uncurryThis(''.toLowerCase);\nvar unshift = uncurryThis([].unshift);\n\nvar INVALID_AUTHORITY = 'Invalid authority';\nvar INVALID_SCHEME = 'Invalid scheme';\nvar INVALID_HOST = 'Invalid host';\nvar INVALID_PORT = 'Invalid port';\n\nvar ALPHA = /[a-z]/i;\n// eslint-disable-next-line regexp/no-obscure-range -- safe\nvar ALPHANUMERIC = /[\\d+-.a-z]/i;\nvar DIGIT = /\\d/;\nvar HEX_START = /^0x/i;\nvar OCT = /^[0-7]+$/;\nvar DEC = /^\\d+$/;\nvar HEX = /^[\\da-f]+$/i;\n/* eslint-disable regexp/no-control-character -- safe */\nvar FORBIDDEN_HOST_CODE_POINT = /[\\0\\t\\n\\r #%/:<>?@[\\\\\\]^|]/;\nvar FORBIDDEN_HOST_CODE_POINT_EXCLUDING_PERCENT = /[\\0\\t\\n\\r #/:<>?@[\\\\\\]^|]/;\nvar LEADING_C0_CONTROL_OR_SPACE = /^[\\u0000-\\u0020]+/;\nvar TRAILING_C0_CONTROL_OR_SPACE = /(^|[^\\u0000-\\u0020])[\\u0000-\\u0020]+$/;\nvar TAB_AND_NEW_LINE = /[\\t\\n\\r]/g;\n/* eslint-enable regexp/no-control-character -- safe */\nvar EOF;\n\n// https://url.spec.whatwg.org/#ipv4-number-parser\nvar parseIPv4 = function (input) {\n var parts = split(input, '.');\n var partsLength, numbers, index, part, radix, number, ipv4;\n if (parts.length && parts[parts.length - 1] === '') {\n parts.length--;\n }\n partsLength = parts.length;\n if (partsLength > 4) return input;\n numbers = [];\n for (index = 0; index < partsLength; index++) {\n part = parts[index];\n if (part === '') return input;\n radix = 10;\n if (part.length > 1 && charAt(part, 0) === '0') {\n radix = exec(HEX_START, part) ? 16 : 8;\n part = stringSlice(part, radix === 8 ? 1 : 2);\n }\n if (part === '') {\n number = 0;\n } else {\n if (!exec(radix === 10 ? DEC : radix === 8 ? OCT : HEX, part)) return input;\n number = parseInt(part, radix);\n }\n push(numbers, number);\n }\n for (index = 0; index < partsLength; index++) {\n number = numbers[index];\n if (index === partsLength - 1) {\n if (number >= pow(256, 5 - partsLength)) return null;\n } else if (number > 255) return null;\n }\n ipv4 = pop(numbers);\n for (index = 0; index < numbers.length; index++) {\n ipv4 += numbers[index] * pow(256, 3 - index);\n }\n return ipv4;\n};\n\n// https://url.spec.whatwg.org/#concept-ipv6-parser\n// eslint-disable-next-line max-statements -- TODO\nvar parseIPv6 = function (input) {\n var address = [0, 0, 0, 0, 0, 0, 0, 0];\n var pieceIndex = 0;\n var compress = null;\n var pointer = 0;\n var value, length, numbersSeen, ipv4Piece, number, swaps, swap;\n\n var chr = function () {\n return charAt(input, pointer);\n };\n\n if (chr() === ':') {\n if (charAt(input, 1) !== ':') return;\n pointer += 2;\n pieceIndex++;\n compress = pieceIndex;\n }\n while (chr()) {\n if (pieceIndex === 8) return;\n if (chr() === ':') {\n if (compress !== null) return;\n pointer++;\n pieceIndex++;\n compress = pieceIndex;\n continue;\n }\n value = length = 0;\n while (length < 4 && exec(HEX, chr())) {\n value = value * 16 + parseInt(chr(), 16);\n pointer++;\n length++;\n }\n if (chr() === '.') {\n if (length === 0) return;\n pointer -= length;\n if (pieceIndex > 6) return;\n numbersSeen = 0;\n while (chr()) {\n ipv4Piece = null;\n if (numbersSeen > 0) {\n if (chr() === '.' && numbersSeen < 4) pointer++;\n else return;\n }\n if (!exec(DIGIT, chr())) return;\n while (exec(DIGIT, chr())) {\n number = parseInt(chr(), 10);\n if (ipv4Piece === null) ipv4Piece = number;\n else if (ipv4Piece === 0) return;\n else ipv4Piece = ipv4Piece * 10 + number;\n if (ipv4Piece > 255) return;\n pointer++;\n }\n address[pieceIndex] = address[pieceIndex] * 256 + ipv4Piece;\n numbersSeen++;\n if (numbersSeen === 2 || numbersSeen === 4) pieceIndex++;\n }\n if (numbersSeen !== 4) return;\n break;\n } else if (chr() === ':') {\n pointer++;\n if (!chr()) return;\n } else if (chr()) return;\n address[pieceIndex++] = value;\n }\n if (compress !== null) {\n swaps = pieceIndex - compress;\n pieceIndex = 7;\n while (pieceIndex !== 0 && swaps > 0) {\n swap = address[pieceIndex];\n address[pieceIndex--] = address[compress + swaps - 1];\n address[compress + --swaps] = swap;\n }\n } else if (pieceIndex !== 8) return;\n return address;\n};\n\nvar findLongestZeroSequence = function (ipv6) {\n var maxIndex = null;\n var maxLength = 1;\n var currStart = null;\n var currLength = 0;\n var index = 0;\n for (; index < 8; index++) {\n if (ipv6[index] !== 0) {\n if (currLength > maxLength) {\n maxIndex = currStart;\n maxLength = currLength;\n }\n currStart = null;\n currLength = 0;\n } else {\n if (currStart === null) currStart = index;\n ++currLength;\n }\n }\n if (currLength > maxLength) {\n maxIndex = currStart;\n maxLength = currLength;\n }\n return maxIndex;\n};\n\n// https://url.spec.whatwg.org/#host-serializing\nvar serializeHost = function (host) {\n var result, index, compress, ignore0;\n // ipv4\n if (typeof host == 'number') {\n result = [];\n for (index = 0; index < 4; index++) {\n unshift(result, host % 256);\n host = floor(host / 256);\n } return join(result, '.');\n // ipv6\n } else if (typeof host == 'object') {\n result = '';\n compress = findLongestZeroSequence(host);\n for (index = 0; index < 8; index++) {\n if (ignore0 && host[index] === 0) continue;\n if (ignore0) ignore0 = false;\n if (compress === index) {\n result += index ? ':' : '::';\n ignore0 = true;\n } else {\n result += numberToString(host[index], 16);\n if (index < 7) result += ':';\n }\n }\n return '[' + result + ']';\n } return host;\n};\n\nvar C0ControlPercentEncodeSet = {};\nvar fragmentPercentEncodeSet = assign({}, C0ControlPercentEncodeSet, {\n ' ': 1, '\"': 1, '<': 1, '>': 1, '`': 1\n});\nvar pathPercentEncodeSet = assign({}, fragmentPercentEncodeSet, {\n '#': 1, '?': 1, '{': 1, '}': 1\n});\nvar userinfoPercentEncodeSet = assign({}, pathPercentEncodeSet, {\n '/': 1, ':': 1, ';': 1, '=': 1, '@': 1, '[': 1, '\\\\': 1, ']': 1, '^': 1, '|': 1\n});\n\nvar percentEncode = function (chr, set) {\n var code = codeAt(chr, 0);\n return code > 0x20 && code < 0x7F && !hasOwn(set, chr) ? chr : encodeURIComponent(chr);\n};\n\n// https://url.spec.whatwg.org/#special-scheme\nvar specialSchemes = {\n ftp: 21,\n file: null,\n http: 80,\n https: 443,\n ws: 80,\n wss: 443\n};\n\n// https://url.spec.whatwg.org/#windows-drive-letter\nvar isWindowsDriveLetter = function (string, normalized) {\n var second;\n return string.length === 2 && exec(ALPHA, charAt(string, 0))\n && ((second = charAt(string, 1)) === ':' || (!normalized && second === '|'));\n};\n\n// https://url.spec.whatwg.org/#start-with-a-windows-drive-letter\nvar startsWithWindowsDriveLetter = function (string) {\n var third;\n return string.length > 1 && isWindowsDriveLetter(stringSlice(string, 0, 2)) && (\n string.length === 2 ||\n ((third = charAt(string, 2)) === '/' || third === '\\\\' || third === '?' || third === '#')\n );\n};\n\n// https://url.spec.whatwg.org/#single-dot-path-segment\nvar isSingleDot = function (segment) {\n return segment === '.' || toLowerCase(segment) === '%2e';\n};\n\n// https://url.spec.whatwg.org/#double-dot-path-segment\nvar isDoubleDot = function (segment) {\n segment = toLowerCase(segment);\n return segment === '..' || segment === '%2e.' || segment === '.%2e' || segment === '%2e%2e';\n};\n\n// States:\nvar SCHEME_START = {};\nvar SCHEME = {};\nvar NO_SCHEME = {};\nvar SPECIAL_RELATIVE_OR_AUTHORITY = {};\nvar PATH_OR_AUTHORITY = {};\nvar RELATIVE = {};\nvar RELATIVE_SLASH = {};\nvar SPECIAL_AUTHORITY_SLASHES = {};\nvar SPECIAL_AUTHORITY_IGNORE_SLASHES = {};\nvar AUTHORITY = {};\nvar HOST = {};\nvar HOSTNAME = {};\nvar PORT = {};\nvar FILE = {};\nvar FILE_SLASH = {};\nvar FILE_HOST = {};\nvar PATH_START = {};\nvar PATH = {};\nvar CANNOT_BE_A_BASE_URL_PATH = {};\nvar QUERY = {};\nvar FRAGMENT = {};\n\nvar URLState = function (url, isBase, base) {\n var urlString = $toString(url);\n var baseState, failure, searchParams;\n if (isBase) {\n failure = this.parse(urlString);\n if (failure) throw new TypeError(failure);\n this.searchParams = null;\n } else {\n if (base !== undefined) baseState = new URLState(base, true);\n failure = this.parse(urlString, null, baseState);\n if (failure) throw new TypeError(failure);\n searchParams = getInternalSearchParamsState(new URLSearchParams());\n searchParams.bindURL(this);\n this.searchParams = searchParams;\n }\n};\n\nURLState.prototype = {\n type: 'URL',\n // https://url.spec.whatwg.org/#url-parsing\n // eslint-disable-next-line max-statements -- TODO\n parse: function (input, stateOverride, base) {\n var url = this;\n var state = stateOverride || SCHEME_START;\n var pointer = 0;\n var buffer = '';\n var seenAt = false;\n var seenBracket = false;\n var seenPasswordToken = false;\n var codePoints, chr, bufferCodePoints, failure;\n\n input = $toString(input);\n\n if (!stateOverride) {\n url.scheme = '';\n url.username = '';\n url.password = '';\n url.host = null;\n url.port = null;\n url.path = [];\n url.query = null;\n url.fragment = null;\n url.cannotBeABaseURL = false;\n input = replace(input, LEADING_C0_CONTROL_OR_SPACE, '');\n input = replace(input, TRAILING_C0_CONTROL_OR_SPACE, '$1');\n }\n\n input = replace(input, TAB_AND_NEW_LINE, '');\n\n codePoints = arrayFrom(input);\n\n while (pointer <= codePoints.length) {\n chr = codePoints[pointer];\n switch (state) {\n case SCHEME_START:\n if (chr && exec(ALPHA, chr)) {\n buffer += toLowerCase(chr);\n state = SCHEME;\n } else if (!stateOverride) {\n state = NO_SCHEME;\n continue;\n } else return INVALID_SCHEME;\n break;\n\n case SCHEME:\n if (chr && (exec(ALPHANUMERIC, chr) || chr === '+' || chr === '-' || chr === '.')) {\n buffer += toLowerCase(chr);\n } else if (chr === ':') {\n if (stateOverride && (\n (url.isSpecial() !== hasOwn(specialSchemes, buffer)) ||\n (buffer === 'file' && (url.includesCredentials() || url.port !== null)) ||\n (url.scheme === 'file' && !url.host)\n )) return;\n url.scheme = buffer;\n if (stateOverride) {\n if (url.isSpecial() && specialSchemes[url.scheme] === url.port) url.port = null;\n return;\n }\n buffer = '';\n if (url.scheme === 'file') {\n state = FILE;\n } else if (url.isSpecial() && base && base.scheme === url.scheme) {\n state = SPECIAL_RELATIVE_OR_AUTHORITY;\n } else if (url.isSpecial()) {\n state = SPECIAL_AUTHORITY_SLASHES;\n } else if (codePoints[pointer + 1] === '/') {\n state = PATH_OR_AUTHORITY;\n pointer++;\n } else {\n url.cannotBeABaseURL = true;\n push(url.path, '');\n state = CANNOT_BE_A_BASE_URL_PATH;\n }\n } else if (!stateOverride) {\n buffer = '';\n state = NO_SCHEME;\n pointer = 0;\n continue;\n } else return INVALID_SCHEME;\n break;\n\n case NO_SCHEME:\n if (!base || (base.cannotBeABaseURL && chr !== '#')) return INVALID_SCHEME;\n if (base.cannotBeABaseURL && chr === '#') {\n url.scheme = base.scheme;\n url.path = arraySlice(base.path);\n url.query = base.query;\n url.fragment = '';\n url.cannotBeABaseURL = true;\n state = FRAGMENT;\n break;\n }\n state = base.scheme === 'file' ? FILE : RELATIVE;\n continue;\n\n case SPECIAL_RELATIVE_OR_AUTHORITY:\n if (chr === '/' && codePoints[pointer + 1] === '/') {\n state = SPECIAL_AUTHORITY_IGNORE_SLASHES;\n pointer++;\n } else {\n state = RELATIVE;\n continue;\n } break;\n\n case PATH_OR_AUTHORITY:\n if (chr === '/') {\n state = AUTHORITY;\n break;\n } else {\n state = PATH;\n continue;\n }\n\n case RELATIVE:\n url.scheme = base.scheme;\n if (chr === EOF) {\n url.username = base.username;\n url.password = base.password;\n url.host = base.host;\n url.port = base.port;\n url.path = arraySlice(base.path);\n url.query = base.query;\n } else if (chr === '/' || (chr === '\\\\' && url.isSpecial())) {\n state = RELATIVE_SLASH;\n } else if (chr === '?') {\n url.username = base.username;\n url.password = base.password;\n url.host = base.host;\n url.port = base.port;\n url.path = arraySlice(base.path);\n url.query = '';\n state = QUERY;\n } else if (chr === '#') {\n url.username = base.username;\n url.password = base.password;\n url.host = base.host;\n url.port = base.port;\n url.path = arraySlice(base.path);\n url.query = base.query;\n url.fragment = '';\n state = FRAGMENT;\n } else {\n url.username = base.username;\n url.password = base.password;\n url.host = base.host;\n url.port = base.port;\n url.path = arraySlice(base.path);\n url.path.length--;\n state = PATH;\n continue;\n } break;\n\n case RELATIVE_SLASH:\n if (url.isSpecial() && (chr === '/' || chr === '\\\\')) {\n state = SPECIAL_AUTHORITY_IGNORE_SLASHES;\n } else if (chr === '/') {\n state = AUTHORITY;\n } else {\n url.username = base.username;\n url.password = base.password;\n url.host = base.host;\n url.port = base.port;\n state = PATH;\n continue;\n } break;\n\n case SPECIAL_AUTHORITY_SLASHES:\n state = SPECIAL_AUTHORITY_IGNORE_SLASHES;\n if (chr !== '/' || charAt(buffer, pointer + 1) !== '/') continue;\n pointer++;\n break;\n\n case SPECIAL_AUTHORITY_IGNORE_SLASHES:\n if (chr !== '/' && chr !== '\\\\') {\n state = AUTHORITY;\n continue;\n } break;\n\n case AUTHORITY:\n if (chr === '@') {\n if (seenAt) buffer = '%40' + buffer;\n seenAt = true;\n bufferCodePoints = arrayFrom(buffer);\n for (var i = 0; i < bufferCodePoints.length; i++) {\n var codePoint = bufferCodePoints[i];\n if (codePoint === ':' && !seenPasswordToken) {\n seenPasswordToken = true;\n continue;\n }\n var encodedCodePoints = percentEncode(codePoint, userinfoPercentEncodeSet);\n if (seenPasswordToken) url.password += encodedCodePoints;\n else url.username += encodedCodePoints;\n }\n buffer = '';\n } else if (\n chr === EOF || chr === '/' || chr === '?' || chr === '#' ||\n (chr === '\\\\' && url.isSpecial())\n ) {\n if (seenAt && buffer === '') return INVALID_AUTHORITY;\n pointer -= arrayFrom(buffer).length + 1;\n buffer = '';\n state = HOST;\n } else buffer += chr;\n break;\n\n case HOST:\n case HOSTNAME:\n if (stateOverride && url.scheme === 'file') {\n state = FILE_HOST;\n continue;\n } else if (chr === ':' && !seenBracket) {\n if (buffer === '') return INVALID_HOST;\n failure = url.parseHost(buffer);\n if (failure) return failure;\n buffer = '';\n state = PORT;\n if (stateOverride === HOSTNAME) return;\n } else if (\n chr === EOF || chr === '/' || chr === '?' || chr === '#' ||\n (chr === '\\\\' && url.isSpecial())\n ) {\n if (url.isSpecial() && buffer === '') return INVALID_HOST;\n if (stateOverride && buffer === '' && (url.includesCredentials() || url.port !== null)) return;\n failure = url.parseHost(buffer);\n if (failure) return failure;\n buffer = '';\n state = PATH_START;\n if (stateOverride) return;\n continue;\n } else {\n if (chr === '[') seenBracket = true;\n else if (chr === ']') seenBracket = false;\n buffer += chr;\n } break;\n\n case PORT:\n if (exec(DIGIT, chr)) {\n buffer += chr;\n } else if (\n chr === EOF || chr === '/' || chr === '?' || chr === '#' ||\n (chr === '\\\\' && url.isSpecial()) ||\n stateOverride\n ) {\n if (buffer !== '') {\n var port = parseInt(buffer, 10);\n if (port > 0xFFFF) return INVALID_PORT;\n url.port = (url.isSpecial() && port === specialSchemes[url.scheme]) ? null : port;\n buffer = '';\n }\n if (stateOverride) return;\n state = PATH_START;\n continue;\n } else return INVALID_PORT;\n break;\n\n case FILE:\n url.scheme = 'file';\n if (chr === '/' || chr === '\\\\') state = FILE_SLASH;\n else if (base && base.scheme === 'file') {\n switch (chr) {\n case EOF:\n url.host = base.host;\n url.path = arraySlice(base.path);\n url.query = base.query;\n break;\n case '?':\n url.host = base.host;\n url.path = arraySlice(base.path);\n url.query = '';\n state = QUERY;\n break;\n case '#':\n url.host = base.host;\n url.path = arraySlice(base.path);\n url.query = base.query;\n url.fragment = '';\n state = FRAGMENT;\n break;\n default:\n if (!startsWithWindowsDriveLetter(join(arraySlice(codePoints, pointer), ''))) {\n url.host = base.host;\n url.path = arraySlice(base.path);\n url.shortenPath();\n }\n state = PATH;\n continue;\n }\n } else {\n state = PATH;\n continue;\n } break;\n\n case FILE_SLASH:\n if (chr === '/' || chr === '\\\\') {\n state = FILE_HOST;\n break;\n }\n if (base && base.scheme === 'file' && !startsWithWindowsDriveLetter(join(arraySlice(codePoints, pointer), ''))) {\n if (isWindowsDriveLetter(base.path[0], true)) push(url.path, base.path[0]);\n else url.host = base.host;\n }\n state = PATH;\n continue;\n\n case FILE_HOST:\n if (chr === EOF || chr === '/' || chr === '\\\\' || chr === '?' || chr === '#') {\n if (!stateOverride && isWindowsDriveLetter(buffer)) {\n state = PATH;\n } else if (buffer === '') {\n url.host = '';\n if (stateOverride) return;\n state = PATH_START;\n } else {\n failure = url.parseHost(buffer);\n if (failure) return failure;\n if (url.host === 'localhost') url.host = '';\n if (stateOverride) return;\n buffer = '';\n state = PATH_START;\n } continue;\n } else buffer += chr;\n break;\n\n case PATH_START:\n if (url.isSpecial()) {\n state = PATH;\n if (chr !== '/' && chr !== '\\\\') continue;\n } else if (!stateOverride && chr === '?') {\n url.query = '';\n state = QUERY;\n } else if (!stateOverride && chr === '#') {\n url.fragment = '';\n state = FRAGMENT;\n } else if (chr !== EOF) {\n state = PATH;\n if (chr !== '/') continue;\n } break;\n\n case PATH:\n if (\n chr === EOF || chr === '/' ||\n (chr === '\\\\' && url.isSpecial()) ||\n (!stateOverride && (chr === '?' || chr === '#'))\n ) {\n if (isDoubleDot(buffer)) {\n url.shortenPath();\n if (chr !== '/' && !(chr === '\\\\' && url.isSpecial())) {\n push(url.path, '');\n }\n } else if (isSingleDot(buffer)) {\n if (chr !== '/' && !(chr === '\\\\' && url.isSpecial())) {\n push(url.path, '');\n }\n } else {\n if (url.scheme === 'file' && !url.path.length && isWindowsDriveLetter(buffer)) {\n if (url.host) url.host = '';\n buffer = charAt(buffer, 0) + ':'; // normalize windows drive letter\n }\n push(url.path, buffer);\n }\n buffer = '';\n if (url.scheme === 'file' && (chr === EOF || chr === '?' || chr === '#')) {\n while (url.path.length > 1 && url.path[0] === '') {\n shift(url.path);\n }\n }\n if (chr === '?') {\n url.query = '';\n state = QUERY;\n } else if (chr === '#') {\n url.fragment = '';\n state = FRAGMENT;\n }\n } else {\n buffer += percentEncode(chr, pathPercentEncodeSet);\n } break;\n\n case CANNOT_BE_A_BASE_URL_PATH:\n if (chr === '?') {\n url.query = '';\n state = QUERY;\n } else if (chr === '#') {\n url.fragment = '';\n state = FRAGMENT;\n } else if (chr !== EOF) {\n url.path[0] += percentEncode(chr, C0ControlPercentEncodeSet);\n } break;\n\n case QUERY:\n if (!stateOverride && chr === '#') {\n url.fragment = '';\n state = FRAGMENT;\n } else if (chr !== EOF) {\n if (chr === \"'\" && url.isSpecial()) url.query += '%27';\n else if (chr === '#') url.query += '%23';\n else url.query += percentEncode(chr, C0ControlPercentEncodeSet);\n } break;\n\n case FRAGMENT:\n if (chr !== EOF) url.fragment += percentEncode(chr, fragmentPercentEncodeSet);\n break;\n }\n\n pointer++;\n }\n },\n // https://url.spec.whatwg.org/#host-parsing\n parseHost: function (input) {\n var result, codePoints, index;\n if (charAt(input, 0) === '[') {\n if (charAt(input, input.length - 1) !== ']') return INVALID_HOST;\n result = parseIPv6(stringSlice(input, 1, -1));\n if (!result) return INVALID_HOST;\n this.host = result;\n // opaque host\n } else if (!this.isSpecial()) {\n if (exec(FORBIDDEN_HOST_CODE_POINT_EXCLUDING_PERCENT, input)) return INVALID_HOST;\n result = '';\n codePoints = arrayFrom(input);\n for (index = 0; index < codePoints.length; index++) {\n result += percentEncode(codePoints[index], C0ControlPercentEncodeSet);\n }\n this.host = result;\n } else {\n input = toASCII(input);\n if (exec(FORBIDDEN_HOST_CODE_POINT, input)) return INVALID_HOST;\n result = parseIPv4(input);\n if (result === null) return INVALID_HOST;\n this.host = result;\n }\n },\n // https://url.spec.whatwg.org/#cannot-have-a-username-password-port\n cannotHaveUsernamePasswordPort: function () {\n return !this.host || this.cannotBeABaseURL || this.scheme === 'file';\n },\n // https://url.spec.whatwg.org/#include-credentials\n includesCredentials: function () {\n return this.username !== '' || this.password !== '';\n },\n // https://url.spec.whatwg.org/#is-special\n isSpecial: function () {\n return hasOwn(specialSchemes, this.scheme);\n },\n // https://url.spec.whatwg.org/#shorten-a-urls-path\n shortenPath: function () {\n var path = this.path;\n var pathSize = path.length;\n if (pathSize && (this.scheme !== 'file' || pathSize !== 1 || !isWindowsDriveLetter(path[0], true))) {\n path.length--;\n }\n },\n // https://url.spec.whatwg.org/#concept-url-serializer\n serialize: function () {\n var url = this;\n var scheme = url.scheme;\n var username = url.username;\n var password = url.password;\n var host = url.host;\n var port = url.port;\n var path = url.path;\n var query = url.query;\n var fragment = url.fragment;\n var output = scheme + ':';\n if (host !== null) {\n output += '//';\n if (url.includesCredentials()) {\n output += username + (password ? ':' + password : '') + '@';\n }\n output += serializeHost(host);\n if (port !== null) output += ':' + port;\n } else if (scheme === 'file') output += '//';\n output += url.cannotBeABaseURL ? path[0] : path.length ? '/' + join(path, '/') : '';\n if (query !== null) output += '?' + query;\n if (fragment !== null) output += '#' + fragment;\n return output;\n },\n // https://url.spec.whatwg.org/#dom-url-href\n setHref: function (href) {\n var failure = this.parse(href);\n if (failure) throw new TypeError(failure);\n this.searchParams.update();\n },\n // https://url.spec.whatwg.org/#dom-url-origin\n getOrigin: function () {\n var scheme = this.scheme;\n var port = this.port;\n if (scheme === 'blob') try {\n return new URLConstructor(scheme.path[0]).origin;\n } catch (error) {\n return 'null';\n }\n if (scheme === 'file' || !this.isSpecial()) return 'null';\n return scheme + '://' + serializeHost(this.host) + (port !== null ? ':' + port : '');\n },\n // https://url.spec.whatwg.org/#dom-url-protocol\n getProtocol: function () {\n return this.scheme + ':';\n },\n setProtocol: function (protocol) {\n this.parse($toString(protocol) + ':', SCHEME_START);\n },\n // https://url.spec.whatwg.org/#dom-url-username\n getUsername: function () {\n return this.username;\n },\n setUsername: function (username) {\n var codePoints = arrayFrom($toString(username));\n if (this.cannotHaveUsernamePasswordPort()) return;\n this.username = '';\n for (var i = 0; i < codePoints.length; i++) {\n this.username += percentEncode(codePoints[i], userinfoPercentEncodeSet);\n }\n },\n // https://url.spec.whatwg.org/#dom-url-password\n getPassword: function () {\n return this.password;\n },\n setPassword: function (password) {\n var codePoints = arrayFrom($toString(password));\n if (this.cannotHaveUsernamePasswordPort()) return;\n this.password = '';\n for (var i = 0; i < codePoints.length; i++) {\n this.password += percentEncode(codePoints[i], userinfoPercentEncodeSet);\n }\n },\n // https://url.spec.whatwg.org/#dom-url-host\n getHost: function () {\n var host = this.host;\n var port = this.port;\n return host === null ? ''\n : port === null ? serializeHost(host)\n : serializeHost(host) + ':' + port;\n },\n setHost: function (host) {\n if (this.cannotBeABaseURL) return;\n this.parse(host, HOST);\n },\n // https://url.spec.whatwg.org/#dom-url-hostname\n getHostname: function () {\n var host = this.host;\n return host === null ? '' : serializeHost(host);\n },\n setHostname: function (hostname) {\n if (this.cannotBeABaseURL) return;\n this.parse(hostname, HOSTNAME);\n },\n // https://url.spec.whatwg.org/#dom-url-port\n getPort: function () {\n var port = this.port;\n return port === null ? '' : $toString(port);\n },\n setPort: function (port) {\n if (this.cannotHaveUsernamePasswordPort()) return;\n port = $toString(port);\n if (port === '') this.port = null;\n else this.parse(port, PORT);\n },\n // https://url.spec.whatwg.org/#dom-url-pathname\n getPathname: function () {\n var path = this.path;\n return this.cannotBeABaseURL ? path[0] : path.length ? '/' + join(path, '/') : '';\n },\n setPathname: function (pathname) {\n if (this.cannotBeABaseURL) return;\n this.path = [];\n this.parse(pathname, PATH_START);\n },\n // https://url.spec.whatwg.org/#dom-url-search\n getSearch: function () {\n var query = this.query;\n return query ? '?' + query : '';\n },\n setSearch: function (search) {\n search = $toString(search);\n if (search === '') {\n this.query = null;\n } else {\n if (charAt(search, 0) === '?') search = stringSlice(search, 1);\n this.query = '';\n this.parse(search, QUERY);\n }\n this.searchParams.update();\n },\n // https://url.spec.whatwg.org/#dom-url-searchparams\n getSearchParams: function () {\n return this.searchParams.facade;\n },\n // https://url.spec.whatwg.org/#dom-url-hash\n getHash: function () {\n var fragment = this.fragment;\n return fragment ? '#' + fragment : '';\n },\n setHash: function (hash) {\n hash = $toString(hash);\n if (hash === '') {\n this.fragment = null;\n return;\n }\n if (charAt(hash, 0) === '#') hash = stringSlice(hash, 1);\n this.fragment = '';\n this.parse(hash, FRAGMENT);\n },\n update: function () {\n this.query = this.searchParams.serialize() || null;\n }\n};\n\n// `URL` constructor\n// https://url.spec.whatwg.org/#url-class\nvar URLConstructor = function URL(url /* , base */) {\n var that = anInstance(this, URLPrototype);\n var base = validateArgumentsLength(arguments.length, 1) > 1 ? arguments[1] : undefined;\n var state = setInternalState(that, new URLState(url, false, base));\n if (!DESCRIPTORS) {\n that.href = state.serialize();\n that.origin = state.getOrigin();\n that.protocol = state.getProtocol();\n that.username = state.getUsername();\n that.password = state.getPassword();\n that.host = state.getHost();\n that.hostname = state.getHostname();\n that.port = state.getPort();\n that.pathname = state.getPathname();\n that.search = state.getSearch();\n that.searchParams = state.getSearchParams();\n that.hash = state.getHash();\n }\n};\n\nvar URLPrototype = URLConstructor.prototype;\n\nvar accessorDescriptor = function (getter, setter) {\n return {\n get: function () {\n return getInternalURLState(this)[getter]();\n },\n set: setter && function (value) {\n return getInternalURLState(this)[setter](value);\n },\n configurable: true,\n enumerable: true\n };\n};\n\nif (DESCRIPTORS) {\n // `URL.prototype.href` accessors pair\n // https://url.spec.whatwg.org/#dom-url-href\n defineBuiltInAccessor(URLPrototype, 'href', accessorDescriptor('serialize', 'setHref'));\n // `URL.prototype.origin` getter\n // https://url.spec.whatwg.org/#dom-url-origin\n defineBuiltInAccessor(URLPrototype, 'origin', accessorDescriptor('getOrigin'));\n // `URL.prototype.protocol` accessors pair\n // https://url.spec.whatwg.org/#dom-url-protocol\n defineBuiltInAccessor(URLPrototype, 'protocol', accessorDescriptor('getProtocol', 'setProtocol'));\n // `URL.prototype.username` accessors pair\n // https://url.spec.whatwg.org/#dom-url-username\n defineBuiltInAccessor(URLPrototype, 'username', accessorDescriptor('getUsername', 'setUsername'));\n // `URL.prototype.password` accessors pair\n // https://url.spec.whatwg.org/#dom-url-password\n defineBuiltInAccessor(URLPrototype, 'password', accessorDescriptor('getPassword', 'setPassword'));\n // `URL.prototype.host` accessors pair\n // https://url.spec.whatwg.org/#dom-url-host\n defineBuiltInAccessor(URLPrototype, 'host', accessorDescriptor('getHost', 'setHost'));\n // `URL.prototype.hostname` accessors pair\n // https://url.spec.whatwg.org/#dom-url-hostname\n defineBuiltInAccessor(URLPrototype, 'hostname', accessorDescriptor('getHostname', 'setHostname'));\n // `URL.prototype.port` accessors pair\n // https://url.spec.whatwg.org/#dom-url-port\n defineBuiltInAccessor(URLPrototype, 'port', accessorDescriptor('getPort', 'setPort'));\n // `URL.prototype.pathname` accessors pair\n // https://url.spec.whatwg.org/#dom-url-pathname\n defineBuiltInAccessor(URLPrototype, 'pathname', accessorDescriptor('getPathname', 'setPathname'));\n // `URL.prototype.search` accessors pair\n // https://url.spec.whatwg.org/#dom-url-search\n defineBuiltInAccessor(URLPrototype, 'search', accessorDescriptor('getSearch', 'setSearch'));\n // `URL.prototype.searchParams` getter\n // https://url.spec.whatwg.org/#dom-url-searchparams\n defineBuiltInAccessor(URLPrototype, 'searchParams', accessorDescriptor('getSearchParams'));\n // `URL.prototype.hash` accessors pair\n // https://url.spec.whatwg.org/#dom-url-hash\n defineBuiltInAccessor(URLPrototype, 'hash', accessorDescriptor('getHash', 'setHash'));\n}\n\n// `URL.prototype.toJSON` method\n// https://url.spec.whatwg.org/#dom-url-tojson\ndefineBuiltIn(URLPrototype, 'toJSON', function toJSON() {\n return getInternalURLState(this).serialize();\n}, { enumerable: true });\n\n// `URL.prototype.toString` method\n// https://url.spec.whatwg.org/#URL-stringification-behavior\ndefineBuiltIn(URLPrototype, 'toString', function toString() {\n return getInternalURLState(this).serialize();\n}, { enumerable: true });\n\nif (NativeURL) {\n var nativeCreateObjectURL = NativeURL.createObjectURL;\n var nativeRevokeObjectURL = NativeURL.revokeObjectURL;\n // `URL.createObjectURL` method\n // https://developer.mozilla.org/en-US/docs/Web/API/URL/createObjectURL\n if (nativeCreateObjectURL) defineBuiltIn(URLConstructor, 'createObjectURL', bind(nativeCreateObjectURL, NativeURL));\n // `URL.revokeObjectURL` method\n // https://developer.mozilla.org/en-US/docs/Web/API/URL/revokeObjectURL\n if (nativeRevokeObjectURL) defineBuiltIn(URLConstructor, 'revokeObjectURL', bind(nativeRevokeObjectURL, NativeURL));\n}\n\nsetToStringTag(URLConstructor, 'URL');\n\n$({ global: true, constructor: true, forced: !USE_NATIVE_URL, sham: !DESCRIPTORS }, {\n URL: URLConstructor\n});\n","'use strict';\n// based on https://github.com/bestiejs/punycode.js/blob/master/punycode.js\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nvar maxInt = 2147483647; // aka. 0x7FFFFFFF or 2^31-1\nvar base = 36;\nvar tMin = 1;\nvar tMax = 26;\nvar skew = 38;\nvar damp = 700;\nvar initialBias = 72;\nvar initialN = 128; // 0x80\nvar delimiter = '-'; // '\\x2D'\nvar regexNonASCII = /[^\\0-\\u007E]/; // non-ASCII chars\nvar regexSeparators = /[.\\u3002\\uFF0E\\uFF61]/g; // RFC 3490 separators\nvar OVERFLOW_ERROR = 'Overflow: input needs wider integers to process';\nvar baseMinusTMin = base - tMin;\n\nvar $RangeError = RangeError;\nvar exec = uncurryThis(regexSeparators.exec);\nvar floor = Math.floor;\nvar fromCharCode = String.fromCharCode;\nvar charCodeAt = uncurryThis(''.charCodeAt);\nvar join = uncurryThis([].join);\nvar push = uncurryThis([].push);\nvar replace = uncurryThis(''.replace);\nvar split = uncurryThis(''.split);\nvar toLowerCase = uncurryThis(''.toLowerCase);\n\n/**\n * Creates an array containing the numeric code points of each Unicode\n * character in the string. While JavaScript uses UCS-2 internally,\n * this function will convert a pair of surrogate halves (each of which\n * UCS-2 exposes as separate characters) into a single code point,\n * matching UTF-16.\n */\nvar ucs2decode = function (string) {\n var output = [];\n var counter = 0;\n var length = string.length;\n while (counter < length) {\n var value = charCodeAt(string, counter++);\n if (value >= 0xD800 && value <= 0xDBFF && counter < length) {\n // It's a high surrogate, and there is a next character.\n var extra = charCodeAt(string, counter++);\n if ((extra & 0xFC00) === 0xDC00) { // Low surrogate.\n push(output, ((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n } else {\n // It's an unmatched surrogate; only append this code unit, in case the\n // next code unit is the high surrogate of a surrogate pair.\n push(output, value);\n counter--;\n }\n } else {\n push(output, value);\n }\n }\n return output;\n};\n\n/**\n * Converts a digit/integer into a basic code point.\n */\nvar digitToBasic = function (digit) {\n // 0..25 map to ASCII a..z or A..Z\n // 26..35 map to ASCII 0..9\n return digit + 22 + 75 * (digit < 26);\n};\n\n/**\n * Bias adaptation function as per section 3.4 of RFC 3492.\n * https://tools.ietf.org/html/rfc3492#section-3.4\n */\nvar adapt = function (delta, numPoints, firstTime) {\n var k = 0;\n delta = firstTime ? floor(delta / damp) : delta >> 1;\n delta += floor(delta / numPoints);\n while (delta > baseMinusTMin * tMax >> 1) {\n delta = floor(delta / baseMinusTMin);\n k += base;\n }\n return floor(k + (baseMinusTMin + 1) * delta / (delta + skew));\n};\n\n/**\n * Converts a string of Unicode symbols (e.g. a domain name label) to a\n * Punycode string of ASCII-only symbols.\n */\nvar encode = function (input) {\n var output = [];\n\n // Convert the input in UCS-2 to an array of Unicode code points.\n input = ucs2decode(input);\n\n // Cache the length.\n var inputLength = input.length;\n\n // Initialize the state.\n var n = initialN;\n var delta = 0;\n var bias = initialBias;\n var i, currentValue;\n\n // Handle the basic code points.\n for (i = 0; i < input.length; i++) {\n currentValue = input[i];\n if (currentValue < 0x80) {\n push(output, fromCharCode(currentValue));\n }\n }\n\n var basicLength = output.length; // number of basic code points.\n var handledCPCount = basicLength; // number of code points that have been handled;\n\n // Finish the basic string with a delimiter unless it's empty.\n if (basicLength) {\n push(output, delimiter);\n }\n\n // Main encoding loop:\n while (handledCPCount < inputLength) {\n // All non-basic code points < n have been handled already. Find the next larger one:\n var m = maxInt;\n for (i = 0; i < input.length; i++) {\n currentValue = input[i];\n if (currentValue >= n && currentValue < m) {\n m = currentValue;\n }\n }\n\n // Increase `delta` enough to advance the decoder's state to , but guard against overflow.\n var handledCPCountPlusOne = handledCPCount + 1;\n if (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) {\n throw new $RangeError(OVERFLOW_ERROR);\n }\n\n delta += (m - n) * handledCPCountPlusOne;\n n = m;\n\n for (i = 0; i < input.length; i++) {\n currentValue = input[i];\n if (currentValue < n && ++delta > maxInt) {\n throw new $RangeError(OVERFLOW_ERROR);\n }\n if (currentValue === n) {\n // Represent delta as a generalized variable-length integer.\n var q = delta;\n var k = base;\n while (true) {\n var t = k <= bias ? tMin : k >= bias + tMax ? tMax : k - bias;\n if (q < t) break;\n var qMinusT = q - t;\n var baseMinusT = base - t;\n push(output, fromCharCode(digitToBasic(t + qMinusT % baseMinusT)));\n q = floor(qMinusT / baseMinusT);\n k += base;\n }\n\n push(output, fromCharCode(digitToBasic(q)));\n bias = adapt(delta, handledCPCountPlusOne, handledCPCount === basicLength);\n delta = 0;\n handledCPCount++;\n }\n }\n\n delta++;\n n++;\n }\n return join(output, '');\n};\n\nmodule.exports = function (input) {\n var encoded = [];\n var labels = split(replace(toLowerCase(input), regexSeparators, '\\u002E'), '.');\n var i, label;\n for (i = 0; i < labels.length; i++) {\n label = labels[i];\n push(encoded, exec(regexNonASCII, label) ? 'xn--' + encode(label) : label);\n }\n return join(encoded, '.');\n};\n","// Assume className is simple and can be found at top-level (window).\n// Fallback to eval to handle cases like 'My.React.ComponentName'.\n// Also, try to gracefully import Babel 6 style default exports\nvar topLevel = typeof window === \"undefined\" ? this : window;\nmodule.exports = function (className) {\n var constructor;\n // Try to access the class globally first\n constructor = topLevel[className];\n\n // If that didn't work, try eval\n if (!constructor) {\n constructor = eval(className);\n }\n\n // Lastly, if there is a default attribute try that\n if (constructor && constructor['default']) {\n constructor = constructor['default'];\n }\n return constructor;\n};","import React, {\n useContext,\n createContext,\n useReducer,\n useCallback,\n} from \"react\";\nimport { useStripe, useElements, CardElement } from '@stripe/react-stripe-js';\nimport { StripeSDKLoader } from \"../utils/StripeSdkLoader\";\nimport axios from \"../utils/requests\";\n\n\nconst AddCardContext = createContext(null);\n\nconst initialState = {\n showCard: false,\n loading: false,\n error: false\n}\n\nconst addCardReducer = (state, action) => {\n switch (action.type) {\n case \"TOGGLE_SHOW_CARD\":\n return { ...state, showCard: !state.showCard };\n case \"SET_LOADING\":\n return { ...state, loading: action.loading };\n case \"SET_ERROR\":\n return { ...state, error: action.error };\n default:\n return state;\n }\n};\n\nconst CARD_ELEMENT_OPTIONS = {\n hidePostalCode: false,\n iconStyle: 'solid',\n style: {\n base: {\n color: '#303238',\n fontSize: '16px',\n fontFamily: '\"Rubik\", sans-serif',\n fontSmoothing: 'antialiased',\n '::placeholder': {\n color: '#6B6B6B',\n },\n },\n invalid: {\n color: '#e5424d',\n ':focus': {\n color: '#303238',\n },\n },\n },\n};\n\nconst StripeForm = ({ customer, response_url }) => {\n const stripe = useStripe();\n const elements = useElements();\n\n const [state, dispatch] = useContext(AddCardContext);\n\n const handleSubmit = async (event) => {\n\n if (!stripe || !elements) {\n // Stripe.js has not yet loaded.\n // Make sure to disable form submission until Stripe.js has loaded.\n return;\n }\n dispatch({ type: \"SET_LOADING\", loading: true });\n\n const card = elements.getElement(CardElement);\n\n const { paymentMethod, error } = await stripe.createPaymentMethod({\n type: 'card',\n card: card,\n billing_details: {\n name: `${customer.name}`,\n email: customer.email\n }\n });\n\n if (error) {\n // Show error to your customer (for example, insufficient funds)\n dispatch({ type: \"SET_ERROR\", error: error.message });\n dispatch({ type: \"SET_LOADING\", loading: false });\n } else {\n // payment method created, now attach it to the customer.\n try {\n const response = await axios.post(\n response_url,\n {\n payment_method: paymentMethod\n }\n );\n\n // dispatch({ type: \"TOGGLE_COMPLETED\" });\n // dispatch({ type: \"TOGGLE_LOADING\" });\n // dispatch({ type: 'SET_SUBSCRIPTION_ID', subscription_id: response.data.subscription_id })\n window.location.reload();\n } catch (error) {\n // dispatch({ type: \"TOGGLE_LOADING\" });\n dispatch({ type: \"SET_ERROR\", error: error.response.error });\n }\n\n dispatch({ type: \"SET_LOADING\", loading: false });\n\n // if (paymentMethod.status === 'succeeded') {\n // Show a success message to your customer\n // There's a risk of the customer closing the window before callback\n // execution. Set up a webhook or plugin to listen for the\n // payment_intent.succeeded event that handles any business critical\n // post-payment actions.\n // }\n }\n }\n\n // const updateAmount = (value) => {\n // dispatch({ type: \"TOGGLE_SHOW_CARD\" });\n // };\n\n return (\n <>\n \n Add New Payment Method\n
\n \n {state.showCard ?\n <>\n
\n
\n\n
\n
\n
\n >\n :\n <>\n
\n >\n }\n
\n >\n )\n}\n\nconst AddCardProvider = ({\n stripe_publishable_key,\n customer,\n showCard = false,\n response_url = \"/profile/create_card\"\n}) => {\n const [store, dispatch] = useReducer(addCardReducer, {\n ...initialState,\n showCard: showCard\n });\n\n const value = React.useMemo(() => [store, dispatch], [store]);\n return (\n \n \n \n \n \n )\n}\n\nexport default AddCardProvider","'use strict';\nvar call = require('../internals/function-call');\nvar perform = require('../internals/perform');\nvar anObject = require('../internals/an-object');\nvar create = require('../internals/object-create');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar defineBuiltIns = require('../internals/define-built-ins');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar InternalStateModule = require('../internals/internal-state');\nvar getBuiltIn = require('../internals/get-built-in');\nvar getMethod = require('../internals/get-method');\nvar AsyncIteratorPrototype = require('../internals/async-iterator-prototype');\nvar createIterResultObject = require('../internals/create-iter-result-object');\nvar iteratorClose = require('../internals/iterator-close');\n\nvar Promise = getBuiltIn('Promise');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\nvar ASYNC_ITERATOR_HELPER = 'AsyncIteratorHelper';\nvar WRAP_FOR_VALID_ASYNC_ITERATOR = 'WrapForValidAsyncIterator';\nvar setInternalState = InternalStateModule.set;\n\nvar createAsyncIteratorProxyPrototype = function (IS_ITERATOR) {\n var IS_GENERATOR = !IS_ITERATOR;\n var getInternalState = InternalStateModule.getterFor(IS_ITERATOR ? WRAP_FOR_VALID_ASYNC_ITERATOR : ASYNC_ITERATOR_HELPER);\n\n var getStateOrEarlyExit = function (that) {\n var stateCompletion = perform(function () {\n return getInternalState(that);\n });\n\n var stateError = stateCompletion.error;\n var state = stateCompletion.value;\n\n if (stateError || (IS_GENERATOR && state.done)) {\n return { exit: true, value: stateError ? Promise.reject(state) : Promise.resolve(createIterResultObject(undefined, true)) };\n } return { exit: false, value: state };\n };\n\n return defineBuiltIns(create(AsyncIteratorPrototype), {\n next: function next() {\n var stateCompletion = getStateOrEarlyExit(this);\n var state = stateCompletion.value;\n if (stateCompletion.exit) return state;\n var handlerCompletion = perform(function () {\n return anObject(state.nextHandler(Promise));\n });\n var handlerError = handlerCompletion.error;\n var value = handlerCompletion.value;\n if (handlerError) state.done = true;\n return handlerError ? Promise.reject(value) : Promise.resolve(value);\n },\n 'return': function () {\n var stateCompletion = getStateOrEarlyExit(this);\n var state = stateCompletion.value;\n if (stateCompletion.exit) return state;\n state.done = true;\n var iterator = state.iterator;\n var returnMethod, result;\n var completion = perform(function () {\n if (state.inner) try {\n iteratorClose(state.inner.iterator, 'normal');\n } catch (error) {\n return iteratorClose(iterator, 'throw', error);\n }\n return getMethod(iterator, 'return');\n });\n returnMethod = result = completion.value;\n if (completion.error) return Promise.reject(result);\n if (returnMethod === undefined) return Promise.resolve(createIterResultObject(undefined, true));\n completion = perform(function () {\n return call(returnMethod, iterator);\n });\n result = completion.value;\n if (completion.error) return Promise.reject(result);\n return IS_ITERATOR ? Promise.resolve(result) : Promise.resolve(result).then(function (resolved) {\n anObject(resolved);\n return createIterResultObject(undefined, true);\n });\n }\n });\n};\n\nvar WrapForValidAsyncIteratorPrototype = createAsyncIteratorProxyPrototype(true);\nvar AsyncIteratorHelperPrototype = createAsyncIteratorProxyPrototype(false);\n\ncreateNonEnumerableProperty(AsyncIteratorHelperPrototype, TO_STRING_TAG, 'Async Iterator Helper');\n\nmodule.exports = function (nextHandler, IS_ITERATOR) {\n var AsyncIteratorProxy = function AsyncIterator(record, state) {\n if (state) {\n state.iterator = record.iterator;\n state.next = record.next;\n } else state = record;\n state.type = IS_ITERATOR ? WRAP_FOR_VALID_ASYNC_ITERATOR : ASYNC_ITERATOR_HELPER;\n state.nextHandler = nextHandler;\n state.counter = 0;\n state.done = false;\n setInternalState(this, state);\n };\n\n AsyncIteratorProxy.prototype = IS_ITERATOR ? WrapForValidAsyncIteratorPrototype : AsyncIteratorHelperPrototype;\n\n return AsyncIteratorProxy;\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar create = require('../internals/object-create');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar defineBuiltIns = require('../internals/define-built-ins');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar InternalStateModule = require('../internals/internal-state');\nvar getMethod = require('../internals/get-method');\nvar IteratorPrototype = require('../internals/iterators-core').IteratorPrototype;\nvar createIterResultObject = require('../internals/create-iter-result-object');\nvar iteratorClose = require('../internals/iterator-close');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\nvar ITERATOR_HELPER = 'IteratorHelper';\nvar WRAP_FOR_VALID_ITERATOR = 'WrapForValidIterator';\nvar setInternalState = InternalStateModule.set;\n\nvar createIteratorProxyPrototype = function (IS_ITERATOR) {\n var getInternalState = InternalStateModule.getterFor(IS_ITERATOR ? WRAP_FOR_VALID_ITERATOR : ITERATOR_HELPER);\n\n return defineBuiltIns(create(IteratorPrototype), {\n next: function next() {\n var state = getInternalState(this);\n // for simplification:\n // for `%WrapForValidIteratorPrototype%.next` our `nextHandler` returns `IterResultObject`\n // for `%IteratorHelperPrototype%.next` - just a value\n if (IS_ITERATOR) return state.nextHandler();\n try {\n var result = state.done ? undefined : state.nextHandler();\n return createIterResultObject(result, state.done);\n } catch (error) {\n state.done = true;\n throw error;\n }\n },\n 'return': function () {\n var state = getInternalState(this);\n var iterator = state.iterator;\n state.done = true;\n if (IS_ITERATOR) {\n var returnMethod = getMethod(iterator, 'return');\n return returnMethod ? call(returnMethod, iterator) : createIterResultObject(undefined, true);\n }\n if (state.inner) try {\n iteratorClose(state.inner.iterator, 'normal');\n } catch (error) {\n return iteratorClose(iterator, 'throw', error);\n }\n iteratorClose(iterator, 'normal');\n return createIterResultObject(undefined, true);\n }\n });\n};\n\nvar WrapForValidIteratorPrototype = createIteratorProxyPrototype(true);\nvar IteratorHelperPrototype = createIteratorProxyPrototype(false);\n\ncreateNonEnumerableProperty(IteratorHelperPrototype, TO_STRING_TAG, 'Iterator Helper');\n\nmodule.exports = function (nextHandler, IS_ITERATOR) {\n var IteratorProxy = function Iterator(record, state) {\n if (state) {\n state.iterator = record.iterator;\n state.next = record.next;\n } else state = record;\n state.type = IS_ITERATOR ? WRAP_FOR_VALID_ITERATOR : ITERATOR_HELPER;\n state.nextHandler = nextHandler;\n state.counter = 0;\n state.done = false;\n setInternalState(this, state);\n };\n\n IteratorProxy.prototype = IS_ITERATOR ? WrapForValidIteratorPrototype : IteratorHelperPrototype;\n\n return IteratorProxy;\n};\n","'use strict';\n\nmodule.exports = function bind(fn, thisArg) {\n return function wrap() {\n var args = new Array(arguments.length);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i];\n }\n return fn.apply(thisArg, args);\n };\n};","'use strict';\n\nvar utils = require('./../utils');\nfunction encode(val) {\n return encodeURIComponent(val).replace(/%40/gi, '@').replace(/%3A/gi, ':').replace(/%24/g, '$').replace(/%2C/gi, ',').replace(/%20/g, '+').replace(/%5B/gi, '[').replace(/%5D/gi, ']');\n}\n\n/**\n * Build a URL by appending params to the end\n *\n * @param {string} url The base of the url (e.g., http://www.google.com)\n * @param {object} [params] The params to be appended\n * @returns {string} The formatted url\n */\nmodule.exports = function buildURL(url, params, paramsSerializer) {\n /*eslint no-param-reassign:0*/\n if (!params) {\n return url;\n }\n var serializedParams;\n if (paramsSerializer) {\n serializedParams = paramsSerializer(params);\n } else if (utils.isURLSearchParams(params)) {\n serializedParams = params.toString();\n } else {\n var parts = [];\n utils.forEach(params, function serialize(val, key) {\n if (val === null || typeof val === 'undefined') {\n return;\n }\n if (utils.isArray(val)) {\n key = key + '[]';\n } else {\n val = [val];\n }\n utils.forEach(val, function parseValue(v) {\n if (utils.isDate(v)) {\n v = v.toISOString();\n } else if (utils.isObject(v)) {\n v = JSON.stringify(v);\n }\n parts.push(encode(key) + '=' + encode(v));\n });\n });\n serializedParams = parts.join('&');\n }\n if (serializedParams) {\n var hashmarkIndex = url.indexOf('#');\n if (hashmarkIndex !== -1) {\n url = url.slice(0, hashmarkIndex);\n }\n url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;\n }\n return url;\n};","'use strict';\n\nmodule.exports = function isCancel(value) {\n return !!(value && value.__CANCEL__);\n};","'use strict';\n\nvar utils = require('./utils');\nvar normalizeHeaderName = require('./helpers/normalizeHeaderName');\nvar DEFAULT_CONTENT_TYPE = {\n 'Content-Type': 'application/x-www-form-urlencoded'\n};\nfunction setContentTypeIfUnset(headers, value) {\n if (!utils.isUndefined(headers) && utils.isUndefined(headers['Content-Type'])) {\n headers['Content-Type'] = value;\n }\n}\nfunction getDefaultAdapter() {\n var adapter;\n if (typeof XMLHttpRequest !== 'undefined') {\n // For browsers use XHR adapter\n adapter = require('./adapters/xhr');\n } else if (typeof process !== 'undefined' && Object.prototype.toString.call(process) === '[object process]') {\n // For node use HTTP adapter\n adapter = require('./adapters/http');\n }\n return adapter;\n}\nvar defaults = {\n adapter: getDefaultAdapter(),\n transformRequest: [function transformRequest(data, headers) {\n normalizeHeaderName(headers, 'Accept');\n normalizeHeaderName(headers, 'Content-Type');\n if (utils.isFormData(data) || utils.isArrayBuffer(data) || utils.isBuffer(data) || utils.isStream(data) || utils.isFile(data) || utils.isBlob(data)) {\n return data;\n }\n if (utils.isArrayBufferView(data)) {\n return data.buffer;\n }\n if (utils.isURLSearchParams(data)) {\n setContentTypeIfUnset(headers, 'application/x-www-form-urlencoded;charset=utf-8');\n return data.toString();\n }\n if (utils.isObject(data)) {\n setContentTypeIfUnset(headers, 'application/json;charset=utf-8');\n return JSON.stringify(data);\n }\n return data;\n }],\n transformResponse: [function transformResponse(data) {\n /*eslint no-param-reassign:0*/\n if (typeof data === 'string') {\n try {\n data = JSON.parse(data);\n } catch (e) {/* Ignore */}\n }\n return data;\n }],\n /**\n * A timeout in milliseconds to abort a request. If set to 0 (default) a\n * timeout is not created.\n */\n timeout: 0,\n xsrfCookieName: 'XSRF-TOKEN',\n xsrfHeaderName: 'X-XSRF-TOKEN',\n maxContentLength: -1,\n validateStatus: function validateStatus(status) {\n return status >= 200 && status < 300;\n }\n};\ndefaults.headers = {\n common: {\n 'Accept': 'application/json, text/plain, */*'\n }\n};\nutils.forEach(['delete', 'get', 'head'], function forEachMethodNoData(method) {\n defaults.headers[method] = {};\n});\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n defaults.headers[method] = utils.merge(DEFAULT_CONTENT_TYPE);\n});\nmodule.exports = defaults;","'use strict';\n\nvar utils = require('./../utils');\nvar settle = require('./../core/settle');\nvar buildURL = require('./../helpers/buildURL');\nvar buildFullPath = require('../core/buildFullPath');\nvar parseHeaders = require('./../helpers/parseHeaders');\nvar isURLSameOrigin = require('./../helpers/isURLSameOrigin');\nvar createError = require('../core/createError');\nmodule.exports = function xhrAdapter(config) {\n return new Promise(function dispatchXhrRequest(resolve, reject) {\n var requestData = config.data;\n var requestHeaders = config.headers;\n if (utils.isFormData(requestData)) {\n delete requestHeaders['Content-Type']; // Let the browser set it\n }\n\n var request = new XMLHttpRequest();\n\n // HTTP basic authentication\n if (config.auth) {\n var username = config.auth.username || '';\n var password = config.auth.password || '';\n requestHeaders.Authorization = 'Basic ' + btoa(username + ':' + password);\n }\n var fullPath = buildFullPath(config.baseURL, config.url);\n request.open(config.method.toUpperCase(), buildURL(fullPath, config.params, config.paramsSerializer), true);\n\n // Set the request timeout in MS\n request.timeout = config.timeout;\n\n // Listen for ready state\n request.onreadystatechange = function handleLoad() {\n if (!request || request.readyState !== 4) {\n return;\n }\n\n // The request errored out and we didn't get a response, this will be\n // handled by onerror instead\n // With one exception: request that using file: protocol, most browsers\n // will return status as 0 even though it's a successful request\n if (request.status === 0 && !(request.responseURL && request.responseURL.indexOf('file:') === 0)) {\n return;\n }\n\n // Prepare the response\n var responseHeaders = 'getAllResponseHeaders' in request ? parseHeaders(request.getAllResponseHeaders()) : null;\n var responseData = !config.responseType || config.responseType === 'text' ? request.responseText : request.response;\n var response = {\n data: responseData,\n status: request.status,\n statusText: request.statusText,\n headers: responseHeaders,\n config: config,\n request: request\n };\n settle(resolve, reject, response);\n\n // Clean up request\n request = null;\n };\n\n // Handle browser request cancellation (as opposed to a manual cancellation)\n request.onabort = function handleAbort() {\n if (!request) {\n return;\n }\n reject(createError('Request aborted', config, 'ECONNABORTED', request));\n\n // Clean up request\n request = null;\n };\n\n // Handle low level network errors\n request.onerror = function handleError() {\n // Real errors are hidden from us by the browser\n // onerror should only fire if it's a network error\n reject(createError('Network Error', config, null, request));\n\n // Clean up request\n request = null;\n };\n\n // Handle timeout\n request.ontimeout = function handleTimeout() {\n var timeoutErrorMessage = 'timeout of ' + config.timeout + 'ms exceeded';\n if (config.timeoutErrorMessage) {\n timeoutErrorMessage = config.timeoutErrorMessage;\n }\n reject(createError(timeoutErrorMessage, config, 'ECONNABORTED', request));\n\n // Clean up request\n request = null;\n };\n\n // Add xsrf header\n // This is only done if running in a standard browser environment.\n // Specifically not if we're in a web worker, or react-native.\n if (utils.isStandardBrowserEnv()) {\n var cookies = require('./../helpers/cookies');\n\n // Add xsrf header\n var xsrfValue = (config.withCredentials || isURLSameOrigin(fullPath)) && config.xsrfCookieName ? cookies.read(config.xsrfCookieName) : undefined;\n if (xsrfValue) {\n requestHeaders[config.xsrfHeaderName] = xsrfValue;\n }\n }\n\n // Add headers to the request\n if ('setRequestHeader' in request) {\n utils.forEach(requestHeaders, function setRequestHeader(val, key) {\n if (typeof requestData === 'undefined' && key.toLowerCase() === 'content-type') {\n // Remove Content-Type if data is undefined\n delete requestHeaders[key];\n } else {\n // Otherwise add header to the request\n request.setRequestHeader(key, val);\n }\n });\n }\n\n // Add withCredentials to request if needed\n if (!utils.isUndefined(config.withCredentials)) {\n request.withCredentials = !!config.withCredentials;\n }\n\n // Add responseType to request if needed\n if (config.responseType) {\n try {\n request.responseType = config.responseType;\n } catch (e) {\n // Expected DOMException thrown by browsers not compatible XMLHttpRequest Level 2.\n // But, this can be suppressed for 'json' type as it can be parsed by default 'transformResponse' function.\n if (config.responseType !== 'json') {\n throw e;\n }\n }\n }\n\n // Handle progress if needed\n if (typeof config.onDownloadProgress === 'function') {\n request.addEventListener('progress', config.onDownloadProgress);\n }\n\n // Not all browsers support upload events\n if (typeof config.onUploadProgress === 'function' && request.upload) {\n request.upload.addEventListener('progress', config.onUploadProgress);\n }\n if (config.cancelToken) {\n // Handle cancellation\n config.cancelToken.promise.then(function onCanceled(cancel) {\n if (!request) {\n return;\n }\n request.abort();\n reject(cancel);\n // Clean up request\n request = null;\n });\n }\n if (requestData === undefined) {\n requestData = null;\n }\n\n // Send the request\n request.send(requestData);\n });\n};","'use strict';\n\nvar enhanceError = require('./enhanceError');\n\n/**\n * Create an Error with the specified message, config, error code, request and response.\n *\n * @param {string} message The error message.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The created error.\n */\nmodule.exports = function createError(message, config, code, request, response) {\n var error = new Error(message);\n return enhanceError(error, config, code, request, response);\n};","'use strict';\n\nvar utils = require('../utils');\n\n/**\n * Config-specific merge-function which creates a new config-object\n * by merging two configuration objects together.\n *\n * @param {Object} config1\n * @param {Object} config2\n * @returns {Object} New object resulting from merging config2 to config1\n */\nmodule.exports = function mergeConfig(config1, config2) {\n // eslint-disable-next-line no-param-reassign\n config2 = config2 || {};\n var config = {};\n var valueFromConfig2Keys = ['url', 'method', 'params', 'data'];\n var mergeDeepPropertiesKeys = ['headers', 'auth', 'proxy'];\n var defaultToConfig2Keys = ['baseURL', 'url', 'transformRequest', 'transformResponse', 'paramsSerializer', 'timeout', 'withCredentials', 'adapter', 'responseType', 'xsrfCookieName', 'xsrfHeaderName', 'onUploadProgress', 'onDownloadProgress', 'maxContentLength', 'validateStatus', 'maxRedirects', 'httpAgent', 'httpsAgent', 'cancelToken', 'socketPath'];\n utils.forEach(valueFromConfig2Keys, function valueFromConfig2(prop) {\n if (typeof config2[prop] !== 'undefined') {\n config[prop] = config2[prop];\n }\n });\n utils.forEach(mergeDeepPropertiesKeys, function mergeDeepProperties(prop) {\n if (utils.isObject(config2[prop])) {\n config[prop] = utils.deepMerge(config1[prop], config2[prop]);\n } else if (typeof config2[prop] !== 'undefined') {\n config[prop] = config2[prop];\n } else if (utils.isObject(config1[prop])) {\n config[prop] = utils.deepMerge(config1[prop]);\n } else if (typeof config1[prop] !== 'undefined') {\n config[prop] = config1[prop];\n }\n });\n utils.forEach(defaultToConfig2Keys, function defaultToConfig2(prop) {\n if (typeof config2[prop] !== 'undefined') {\n config[prop] = config2[prop];\n } else if (typeof config1[prop] !== 'undefined') {\n config[prop] = config1[prop];\n }\n });\n var axiosKeys = valueFromConfig2Keys.concat(mergeDeepPropertiesKeys).concat(defaultToConfig2Keys);\n var otherKeys = Object.keys(config2).filter(function filterAxiosKeys(key) {\n return axiosKeys.indexOf(key) === -1;\n });\n utils.forEach(otherKeys, function otherKeysDefaultToConfig2(prop) {\n if (typeof config2[prop] !== 'undefined') {\n config[prop] = config2[prop];\n } else if (typeof config1[prop] !== 'undefined') {\n config[prop] = config1[prop];\n }\n });\n return config;\n};","'use strict';\n\n/**\n * A `Cancel` is an object that is thrown when an operation is canceled.\n *\n * @class\n * @param {string=} message The message.\n */\nfunction Cancel(message) {\n this.message = message;\n}\nCancel.prototype.toString = function toString() {\n return 'Cancel' + (this.message ? ': ' + this.message : '');\n};\nCancel.prototype.__CANCEL__ = true;\nmodule.exports = Cancel;","import React from 'react';\n\nconst AnchorLink = (props) => {\n const { targetId, text, className } = props;\n\n const handleClick = (e) => {\n e.preventDefault;\n const targetEl = document.getElementById(targetId);\n\n if (!!targetEl) targetEl.scrollIntoView({ behavior: 'smooth' });\n };\n\n return (\n \n {text}\n \n );\n};\n\nexport default AnchorLink;\n","\nimport React from \"react\";\nimport {\n CardElement,\n useStripe,\n useElements,\n} from '@stripe/react-stripe-js';\n\nexport default CheckoutForm = () => {\n const stripe = useStripe();\n const elements = useElements();\n\n const handleSubmit = async (event) => {\n event.preventDefault();\n const { error, paymentMethod } = await stripe.createPaymentMethod({\n type: 'card',\n card: elements.getElement(CardElement),\n });\n };\n\n return (\n \n );\n};\n","import React, { useState } from 'react';\nimport { StripeSDKLoader } from \"../utils/StripeSdkLoader\";\nimport axios from \"../utils/requests\";\nimport { CardElement, useStripe, useElements } from \"@stripe/react-stripe-js\"\n\nconst CARD_OPTIONS = {\n hidePostalCode: false,\n iconStyle: 'solid',\n style: {\n base: {\n color: '#303238',\n fontSize: '16px',\n fontFamily: '\"Rubik\", sans-serif',\n fontSmoothing: 'antialiased',\n '::placeholder': {\n color: '#6B6B6B',\n },\n },\n invalid: {\n color: '#e5424d',\n ':focus': {\n color: '#303238',\n },\n },\n },\n};\n\nexport const NewPaymentMethodSection = (props) => {\n const stripe = useStripe()\n const elements = useElements()\n const [errorClass, setErrorClass] = useState('');\n const [errors, setErrors] = useState(null);\n const [loading, setLoading] = useState(false);\n\n const handleChange = (event) => {\n // could show the error here if we wanted to\n const { error } = event;\n\n if (!!error) {\n setErrorClass('border-red-600');\n } else {\n setErrorClass('');\n }\n };\n\n const handleSubmit = async (event) => {\n event.preventDefault();\n setLoading(true);\n const resp = await submitPaymentMethod({ state: props, stripe, elements });\n // return early and show errors if payment method doesnt create on stripe\n if (resp.error) {\n setLoading(false);\n setErrors({ base: [resp.error.message] })\n return;\n }\n\n try {\n await axios.post(\n props.create_card_path,\n {\n payment_method: resp.paymentMethod\n }\n );\n } catch (error) {\n setLoading(false)\n setErrors({ base: error.response.data.error });\n return\n }\n setLoading(false)\n // Redirect to the members page\n window.location = props.success_redirect_path\n };\n\n const btnLoading = !stripe || loading;\n let buttonStyles = \"w-full text-center py-3 border border-transparent leading-4 rounded-md text-white ease-in-out transition focus:outline-none \"\n if (btnLoading) {\n buttonStyles = buttonStyles.concat(\"bg-indigo-200\")\n } else {\n buttonStyles = buttonStyles.concat(\"bg-indigo-600 hover:bg-indigo-800 focus:border-indigo-700 focus:ring-indigo active:bg-indigo-700 duration-150\")\n }\n return (\n <>\n \n >\n )\n\n}\n\nconst submitPaymentMethod = async ({ state, stripe, elements }) => {\n const { organization, fund, member } = state;\n const user = member.user\n return await stripe.createPaymentMethod({\n type: \"card\",\n card: elements.getElement(CardElement),\n metadata: {\n organization_id: organization.id,\n fund_id: fund.id,\n },\n billing_details: {\n name: `${user.first_name} ${user.last_name}`,\n email: user.email,\n phone: user.phone && user.phone.length > 0 ? user.phone : null,\n address: {\n line1: user.line1 && user.line1.length > 0 ? user.line1 : null,\n line2: user.line2 && user.line2.length > 0 ? user.line2 : null,\n city: user.city && user.city.length > 0 ? user.city : null,\n state: user.region && user.region.length > 0 ? user.region : null,\n country: user.country && user.country.length > 0 ? user.country : null,\n postal_code:\n user.postalcode && user.postalcode.length > 0\n ? user.postalcode\n : null,\n },\n },\n });\n};\n\nexport default function CreatePaymentMethod(props) {\n return (\n <>\n \n \n Create Card\n
\n \n \n \n >\n )\n}","import React, { useState } from 'react'\nimport { RadioGroup, Radio, Label } from '@headlessui/react'\nimport { CheckIcon } from '@heroicons/react/20/solid'\n\nconst frequencies = [\n { value: 'month', label: 'Monthly', priceSuffix: '/month' },\n { value: 'year', label: 'Annually', priceSuffix: '/year' },\n]\n\nfunction classNames(...classes) {\n return classes.filter(Boolean).join(' ')\n}\n\nexport default function DashboardPlans(props) {\n const { tiers, current_plan } = props\n const [frequency, setFrequency] = useState(frequencies[(current_plan && current_plan.interval == \"month\" ? 0 : 1)])\n\n return (\n \n
\n
\n \n \n {frequencies.map((option) => (\n \n classNames(\n checked ? 'bg-indigo-600 text-white' : 'text-gray-500',\n 'cursor-pointer rounded-full px-2.5 py-1'\n )\n }\n >\n {option.label}\n \n ))}\n \n
\n
\n {tiers.map((tier) => (\n
\n ))}\n
\n
\n
\n )\n}\n","import React, { useState } from 'react';\nimport { generateId } from '../utils/genIds';\nimport DayPicker from '../utils/daypicker';\n\nconst DayPickerField = (props) => {\n const {\n label,\n description,\n errors = [],\n modelName,\n model,\n attribute,\n value,\n required,\n toolTip,\n } = props;\n\n const id = generateId();\n const name = `${modelName}[${attribute}]`;\n\n const [currentValue, setCurrentValue] = useState(value || model[attribute] || 1);\n const setCurrentDay = (date) => {\n const curr = date.split('-').pop().replace(/^0/, '')\n setCurrentValue(curr);\n };\n\n return (\n <>\n \n {!!description && (\n {description}
\n )}\n \n {errors.map((e, i) => {\n return (\n \n {e}\n
\n );\n })}\n >\n );\n};\n\nexport default DayPickerField;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar _exportNames = {};\nvar _dndContextJs = _interopRequireWildcard(require(\"./DndContext.js\"));\nObject.keys(_dndContextJs).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _dndContextJs[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _dndContextJs[key];\n }\n });\n});\nvar _dndProviderJs = _interopRequireWildcard(require(\"./DndProvider.js\"));\nObject.keys(_dndProviderJs).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _dndProviderJs[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _dndProviderJs[key];\n }\n });\n});\nvar _dragPreviewImageJs = _interopRequireWildcard(require(\"./DragPreviewImage.js\"));\nObject.keys(_dragPreviewImageJs).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n if (key in exports && exports[key] === _dragPreviewImageJs[key]) return;\n Object.defineProperty(exports, key, {\n enumerable: true,\n get: function get() {\n return _dragPreviewImageJs[key];\n }\n });\n});\nfunction _interopRequireWildcard(obj) {\n if (obj && obj.__esModule) {\n return obj;\n } else {\n var newObj = {};\n if (obj != null) {\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {};\n if (desc.get || desc.set) {\n Object.defineProperty(newObj, key, desc);\n } else {\n newObj[key] = obj[key];\n }\n }\n }\n }\n newObj.default = obj;\n return newObj;\n }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.DndContext = void 0;\nvar _react = require(\"react\");\nvar DndContext = (0, _react).createContext({\n dragDropManager: undefined\n});\nexports.DndContext = DndContext;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.HandlerRole = void 0;\nvar HandlerRole;\nexports.HandlerRole = HandlerRole;\n(function (HandlerRole) {\n HandlerRole[\"SOURCE\"] = \"SOURCE\";\n HandlerRole[\"TARGET\"] = \"TARGET\";\n})(HandlerRole || (exports.HandlerRole = HandlerRole = {}));","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.matchesType = matchesType;\nfunction matchesType(targetType, draggedItemType) {\n if (draggedItemType === null) {\n return targetType === null;\n }\n return Array.isArray(targetType) ? targetType.some(function (t) {\n return t === draggedItemType;\n }) : targetType === draggedItemType;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.areCoordsEqual = areCoordsEqual;\nexports.areArraysEqual = areArraysEqual;\nexports.strictEquality = void 0;\nvar strictEquality = function strictEquality(a, b) {\n return a === b;\n};\nexports.strictEquality = strictEquality;\nfunction areCoordsEqual(offsetA, offsetB) {\n if (!offsetA && !offsetB) {\n return true;\n } else if (!offsetA || !offsetB) {\n return false;\n } else {\n return offsetA.x === offsetB.x && offsetA.y === offsetB.y;\n }\n}\nfunction areArraysEqual(a, b) {\n var isEqual = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : strictEquality;\n if (a.length !== b.length) {\n return false;\n }\n for (var i = 0; i < a.length; ++i) {\n if (!isEqual(a[i], b[i])) {\n return false;\n }\n }\n return true;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.areDirty = areDirty;\nexports.ALL = exports.NONE = void 0;\nvar _jsUtilsJs = require(\"./js_utils.js\");\nvar NONE = [];\nexports.NONE = NONE;\nvar ALL = [];\nexports.ALL = ALL;\nNONE.__IS_NONE__ = true;\nALL.__IS_ALL__ = true;\nfunction areDirty(dirtyIds, handlerIds) {\n if (dirtyIds === NONE) {\n return false;\n }\n if (dirtyIds === ALL || typeof handlerIds === 'undefined') {\n return true;\n }\n var commonIds = (0, _jsUtilsJs).intersection(handlerIds, dirtyIds);\n return commonIds.length > 0;\n}","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar _makeRequestCallJs = require(\"./makeRequestCall.js\");\nvar AsapQueue = /*#__PURE__*/function () {\n function AsapQueue() {\n var _this = this;\n _classCallCheck(this, AsapQueue);\n this.queue = [];\n // We queue errors to ensure they are thrown in right order (FIFO).\n // Array-as-queue is good enough here, since we are just dealing with exceptions.\n this.pendingErrors = [];\n // Once a flush has been requested, no further calls to `requestFlush` are\n // necessary until the next `flush` completes.\n // @ts-ignore\n this.flushing = false;\n // The position of the next task to execute in the task queue. This is\n // preserved between calls to `flush` so that it can be resumed if\n // a task throws an exception.\n this.index = 0;\n // If a task schedules additional tasks recursively, the task queue can grow\n // unbounded. To prevent memory exhaustion, the task queue will periodically\n // truncate already-completed tasks.\n this.capacity = 1024;\n // The flush function processes all tasks that have been scheduled with\n // `rawAsap` unless and until one of those tasks throws an exception.\n // If a task throws an exception, `flush` ensures that its state will remain\n // consistent and will resume where it left off when called again.\n // However, `flush` does not make any arrangements to be called again if an\n // exception is thrown.\n this.flush = function () {\n var q = _this.queue;\n while (_this.index < q.length) {\n var currentIndex = _this.index;\n // Advance the index before calling the task. This ensures that we will\n // begin flushing on the next task the task throws an error.\n _this.index++;\n q[currentIndex].call();\n // Prevent leaking memory for long chains of recursive calls to `asap`.\n // If we call `asap` within tasks scheduled by `asap`, the queue will\n // grow, but to avoid an O(n) walk for every task we execute, we don't\n // shift tasks off the queue after they have been executed.\n // Instead, we periodically shift 1024 tasks off the queue.\n if (_this.index > _this.capacity) {\n // Manually shift all values starting at the index back to the\n // beginning of the queue.\n for (var scan = 0, newLength = q.length - _this.index; scan < newLength; scan++) {\n q[scan] = q[scan + _this.index];\n }\n q.length -= _this.index;\n _this.index = 0;\n }\n }\n q.length = 0;\n _this.index = 0;\n _this.flushing = false;\n };\n // In a web browser, exceptions are not fatal. However, to avoid\n // slowing down the queue of pending tasks, we rethrow the error in a\n // lower priority turn.\n this.registerPendingError = function (err) {\n _this.pendingErrors.push(err);\n _this.requestErrorThrow();\n };\n // `requestFlush` requests that the high priority event queue be flushed as\n // soon as possible.\n // This is useful to prevent an error thrown in a task from stalling the event\n // queue if the exception handled by Node.js’s\n // `process.on(\"uncaughtException\")` or by a domain.\n // `requestFlush` is implemented using a strategy based on data collected from\n // every available SauceLabs Selenium web driver worker at time of writing.\n // https://docs.google.com/spreadsheets/d/1mG-5UYGup5qxGdEMWkhP6BWCz053NUb2E1QoUTU16uA/edit#gid=783724593\n this.requestFlush = (0, _makeRequestCallJs).makeRequestCall(this.flush);\n this.requestErrorThrow = (0, _makeRequestCallJs).makeRequestCallFromTimer(function () {\n // Throw first error\n if (_this.pendingErrors.length) {\n throw _this.pendingErrors.shift();\n }\n });\n }\n _createClass(AsapQueue, [{\n key: \"enqueueTask\",\n value:\n // Use the fastest means possible to execute a task in its own turn, with\n // priority over other events including IO, animation, reflow, and redraw\n // events in browsers.\n //\n // An exception thrown by a task will permanently interrupt the processing of\n // subsequent tasks. The higher level `asap` function ensures that if an\n // exception is thrown by a task, that the task queue will continue flushing as\n // soon as possible, but if you use `rawAsap` directly, you are responsible to\n // either ensure that no exceptions are thrown from your task, or to manually\n // call `rawAsap.requestFlush` if an exception is thrown.\n function enqueueTask(task) {\n var q = this.queue,\n requestFlush = this.requestFlush;\n if (!q.length) {\n requestFlush();\n this.flushing = true;\n }\n // Equivalent to push, but avoids a function call.\n q[q.length] = task;\n }\n }]);\n return AsapQueue;\n}(); // The message channel technique was discovered by Malte Ubl and was the\n// original foundation for this library.\n// http://www.nonblocking.io/2011/06/windownexttick.html\n// Safari 6.0.5 (at least) intermittently fails to create message ports on a\n// page's first load. Thankfully, this version of Safari supports\n// MutationObservers, so we don't need to fall back in that case.\n// function makeRequestCallFromMessageChannel(callback) {\n// var channel = new MessageChannel();\n// channel.port1.onmessage = callback;\n// return function requestCall() {\n// channel.port2.postMessage(0);\n// };\n// }\n// For reasons explained above, we are also unable to use `setImmediate`\n// under any circumstances.\n// Even if we were, there is another bug in Internet Explorer 10.\n// It is not sufficient to assign `setImmediate` to `requestFlush` because\n// `setImmediate` must be called *by name* and therefore must be wrapped in a\n// closure.\n// Never forget.\n// function makeRequestCallFromSetImmediate(callback) {\n// return function requestCall() {\n// setImmediate(callback);\n// };\n// }\n// Safari 6.0 has a problem where timers will get lost while the user is\n// scrolling. This problem does not impact ASAP because Safari 6.0 supports\n// mutation observers, so that implementation is used instead.\n// However, if we ever elect to use timers in Safari, the prevalent work-around\n// is to add a scroll event listener that calls for a flush.\n// `setTimeout` does not call the passed callback if the delay is less than\n// approximately 7 in web workers in Firefox 8 through 18, and sometimes not\n// even then.\n// This is for `asap.js` only.\n// Its name will be periodically randomized to break any code that depends on\n// // its existence.\n// rawAsap.makeRequestCallFromTimer = makeRequestCallFromTimer\n// ASAP was originally a nextTick shim included in Q. This was factored out\n// into this ASAP package. It was later adapted to RSVP which made further\n// amendments. These decisions, particularly to marginalize MessageChannel and\n// to capture the MutationObserver implementation in a closure, were integrated\n// back into ASAP proper.\n// https://github.com/tildeio/rsvp.js/blob/cddf7232546a9cf858524b75cde6f9edf72620a7/lib/rsvp/asap.js\nexports.AsapQueue = AsapQueue;","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar _rawTaskJs = require(\"./RawTask.js\");\nvar TaskFactory = /*#__PURE__*/function () {\n function TaskFactory(onError) {\n _classCallCheck(this, TaskFactory);\n this.onError = onError;\n this.freeTasks = [];\n }\n _createClass(TaskFactory, [{\n key: \"create\",\n value: function create(task) {\n var tasks = this.freeTasks;\n var t1 = tasks.length ? tasks.pop() : new _rawTaskJs.RawTask(this.onError, function (t) {\n return tasks[tasks.length] = t;\n });\n t1.task = task;\n return t1;\n }\n }]);\n return TaskFactory;\n}();\nexports.TaskFactory = TaskFactory;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.wrapConnectorHooks = wrapConnectorHooks;\nvar _invariant = require(\"@react-dnd/invariant\");\nvar _react = require(\"react\");\nfunction throwIfCompositeComponentElement(element) {\n // Custom components can no longer be wrapped directly in React DnD 2.0\n // so that we don't need to depend on findDOMNode() from react-dom.\n if (typeof element.type === 'string') {\n return;\n }\n var displayName = element.type.displayName || element.type.name || 'the component';\n throw new Error('Only native element nodes can now be passed to React DnD connectors.' + \"You can either wrap \".concat(displayName, \" into a , or turn it into a \") + 'drag source or a drop target itself.');\n}\nfunction wrapHookToRecognizeElement(hook) {\n return function () {\n var elementOrNode = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n // When passed a node, call the hook straight away.\n if (!(0, _react).isValidElement(elementOrNode)) {\n var node = elementOrNode;\n hook(node, options);\n // return the node so it can be chained (e.g. when within callback refs\n //
connectDragSource(connectDropTarget(node))}/>\n return node;\n }\n // If passed a ReactElement, clone it and attach this function as a ref.\n // This helps us achieve a neat API where user doesn't even know that refs\n // are being used under the hood.\n var element = elementOrNode;\n throwIfCompositeComponentElement(element);\n // When no options are passed, use the hook directly\n var ref = options ? function (node) {\n return hook(node, options);\n } : hook;\n return cloneWithRef(element, ref);\n };\n}\nfunction wrapConnectorHooks(hooks) {\n var wrappedHooks = {};\n Object.keys(hooks).forEach(function (key) {\n var hook = hooks[key];\n // ref objects should be passed straight through without wrapping\n if (key.endsWith('Ref')) {\n wrappedHooks[key] = hooks[key];\n } else {\n var wrappedHook = wrapHookToRecognizeElement(hook);\n wrappedHooks[key] = function () {\n return wrappedHook;\n };\n }\n });\n return wrappedHooks;\n}\nfunction setRef(ref, node) {\n if (typeof ref === 'function') {\n ref(node);\n } else {\n ref.current = node;\n }\n}\nfunction cloneWithRef(element, newRef) {\n var previousRef = element.ref;\n (0, _invariant).invariant(typeof previousRef !== 'string', 'Cannot connect React DnD to an element with an existing string ref. ' + 'Please convert it to use a callback ref instead, or wrap it into a
or . ' + 'Read more: https://reactjs.org/docs/refs-and-the-dom.html#callback-refs');\n if (!previousRef) {\n // When there is no ref on the element, use the new ref directly\n return (0, _react).cloneElement(element, {\n ref: newRef\n });\n } else {\n return (0, _react).cloneElement(element, {\n ref: function ref(node) {\n setRef(previousRef, node);\n setRef(newRef, node);\n }\n });\n }\n}","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.isRef = isRef;\nfunction isRef(obj) {\n return (\n // eslint-disable-next-line no-prototype-builtins\n obj !== null && _typeof(obj) === 'object' && Object.prototype.hasOwnProperty.call(obj, 'current')\n );\n}","\"use strict\";\n\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.shallowEqual = shallowEqual;\nfunction shallowEqual(objA, objB, compare, compareContext) {\n var compareResult = compare ? compare.call(compareContext, objA, objB) : void 0;\n if (compareResult !== void 0) {\n return !!compareResult;\n }\n if (objA === objB) {\n return true;\n }\n if (_typeof(objA) !== 'object' || !objA || _typeof(objB) !== 'object' || !objB) {\n return false;\n }\n var keysA = Object.keys(objA);\n var keysB = Object.keys(objB);\n if (keysA.length !== keysB.length) {\n return false;\n }\n var bHasOwnProperty = Object.prototype.hasOwnProperty.bind(objB);\n // Test for A's keys different from B.\n for (var idx = 0; idx < keysA.length; idx++) {\n var key = keysA[idx];\n if (!bHasOwnProperty(key)) {\n return false;\n }\n var valueA = objA[key];\n var valueB = objB[key];\n compareResult = compare ? compare.call(compareContext, valueA, valueB, key) : void 0;\n if (compareResult === false || compareResult === void 0 && valueA !== valueB) {\n return false;\n }\n }\n return true;\n}","\"use strict\";\n\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.useOptionalFactory = useOptionalFactory;\nvar _react = require(\"react\");\nfunction useOptionalFactory(arg, deps) {\n var memoDeps = _toConsumableArray(deps || []);\n if (deps == null && typeof arg !== 'function') {\n memoDeps.push(arg);\n }\n return (0, _react).useMemo(function () {\n return typeof arg === 'function' ? arg() : arg;\n }, memoDeps);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.useCollectedProps = useCollectedProps;\nvar _useMonitorOutputJs = require(\"./useMonitorOutput.js\");\nfunction useCollectedProps(collector, monitor, connector) {\n return (0, _useMonitorOutputJs).useMonitorOutput(monitor, collector || function () {\n return {};\n }, function () {\n return connector.reconnect();\n });\n}","\"use strict\";\n\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.useCollector = useCollector;\nvar _fastDeepEqual = _interopRequireDefault(require(\"fast-deep-equal\"));\nvar _react = require(\"react\");\nvar _useIsomorphicLayoutEffectJs = require(\"./useIsomorphicLayoutEffect.js\");\nfunction _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n default: obj\n };\n}\nfunction useCollector(monitor, collect, onUpdate) {\n var _useState = (0, _react).useState(function () {\n return collect(monitor);\n }),\n _useState2 = _slicedToArray(_useState, 2),\n collected = _useState2[0],\n setCollected = _useState2[1];\n var updateCollected = (0, _react).useCallback(function () {\n var nextValue = collect(monitor);\n // This needs to be a deep-equality check because some monitor-collected values\n // include XYCoord objects that may be equivalent, but do not have instance equality.\n if (!(0, _fastDeepEqual).default(collected, nextValue)) {\n setCollected(nextValue);\n if (onUpdate) {\n onUpdate();\n }\n }\n }, [collected, monitor, onUpdate]);\n // update the collected properties after react renders.\n // Note that the \"Dustbin Stress Test\" fails if this is not\n // done when the component updates\n (0, _useIsomorphicLayoutEffectJs).useIsomorphicLayoutEffect(updateCollected);\n return [collected, updateCollected];\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.memoize = memoize;\nexports.without = without;\nexports.union = union;\nfunction memoize(fn) {\n var result = null;\n var memoized = function memoized() {\n if (result == null) {\n result = fn();\n }\n return result;\n };\n return memoized;\n}\nfunction without(items, item) {\n return items.filter(function (i) {\n return i !== item;\n });\n}\nfunction union(itemsA, itemsB) {\n var set = new Set();\n var insertItem = function insertItem(item) {\n return set.add(item);\n };\n itemsA.forEach(insertItem);\n itemsB.forEach(insertItem);\n var result = [];\n set.forEach(function (key) {\n return result.push(key);\n });\n return result;\n}","import FormSettings from './FormSettings/Index';\n\nexport default FormSettings;\n","import React, { useState } from 'react';\nimport FormInput from './FormInput';\nimport NestedDueLevelsFields from './NestedDueLevelsFields';\n\nconst FundTypePicker = (props) => {\n const [fundType, setFundType] = useState(props.model.fund_type);\n\n return (\n <>\n
\n {fundType === 'dues' ? (\n
\n ) : (\n ''\n )}\n >\n );\n};\nexport default FundTypePicker;\n","import React, { useState } from 'react';\n\nconst FlashNotice = (props) => {\n const { stringToCopy, buttonText, label } = props;\n\n const handleClick = () => {\n navigator.clipboard.writeText(stringToCopy);\n };\n\n return (\n <>\n
\n
\n
\n \n
\n
\n
\n {label ? (\n
\n ) : (\n ''\n )}\n
\n >\n );\n};\n\nexport default FlashNotice;\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar isObject = require('../internals/is-object');\nvar getBuiltIn = require('../internals/get-built-in');\nvar getIteratorDirect = require('../internals/get-iterator-direct');\nvar closeAsyncIteration = require('../internals/async-iterator-close');\n\nvar Promise = getBuiltIn('Promise');\nvar $TypeError = TypeError;\n\n// `AsyncIterator.prototype.reduce` method\n// https://github.com/tc39/proposal-async-iterator-helpers\n$({ target: 'AsyncIterator', proto: true, real: true }, {\n reduce: function reduce(reducer /* , initialValue */) {\n anObject(this);\n aCallable(reducer);\n var record = getIteratorDirect(this);\n var iterator = record.iterator;\n var next = record.next;\n var noInitial = arguments.length < 2;\n var accumulator = noInitial ? undefined : arguments[1];\n var counter = 0;\n\n return new Promise(function (resolve, reject) {\n var ifAbruptCloseAsyncIterator = function (error) {\n closeAsyncIteration(iterator, reject, error, reject);\n };\n\n var loop = function () {\n try {\n Promise.resolve(anObject(call(next, iterator))).then(function (step) {\n try {\n if (anObject(step).done) {\n noInitial ? reject(new $TypeError('Reduce of empty iterator with no initial value')) : resolve(accumulator);\n } else {\n var value = step.value;\n if (noInitial) {\n noInitial = false;\n accumulator = value;\n loop();\n } else try {\n var result = reducer(accumulator, value, counter);\n\n var handler = function ($result) {\n accumulator = $result;\n loop();\n };\n\n if (isObject(result)) Promise.resolve(result).then(handler, ifAbruptCloseAsyncIterator);\n else handler(result);\n } catch (error3) { ifAbruptCloseAsyncIterator(error3); }\n }\n counter++;\n } catch (error2) { reject(error2); }\n }, reject);\n } catch (error) { reject(error); }\n };\n\n loop();\n });\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar iterate = require('../internals/iterate');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar getIteratorDirect = require('../internals/get-iterator-direct');\n\nvar $TypeError = TypeError;\n\n// `Iterator.prototype.reduce` method\n// https://github.com/tc39/proposal-iterator-helpers\n$({ target: 'Iterator', proto: true, real: true }, {\n reduce: function reduce(reducer /* , initialValue */) {\n anObject(this);\n aCallable(reducer);\n var record = getIteratorDirect(this);\n var noInitial = arguments.length < 2;\n var accumulator = noInitial ? undefined : arguments[1];\n var counter = 0;\n iterate(record, function (value) {\n if (noInitial) {\n noInitial = false;\n accumulator = value;\n } else {\n accumulator = reducer(accumulator, value, counter);\n }\n counter++;\n }, { IS_RECORD: true });\n if (noInitial) throw new $TypeError('Reduce of empty iterator with no initial value');\n return accumulator;\n }\n});\n","import React, { useState } from 'react';\nimport { CardElement } from '@stripe/react-stripe-js';\nimport { useForm } from './provider';\n\nconst CARD_OPTIONS = {\n hidePostalCode: false,\n iconStyle: 'solid',\n style: {\n base: {\n color: '#303238',\n fontSize: '16px',\n fontFamily: '\"Rubik\", sans-serif',\n fontSmoothing: 'antialiased',\n '::placeholder': {\n color: '#6B6B6B',\n },\n },\n invalid: {\n color: '#e5424d',\n ':focus': {\n color: '#303238',\n },\n },\n },\n};\n\nexport const PaymentMethodSection = () => {\n const {\n setPaymentMethod,\n state: { paymentMethods, paymentMethod },\n } = useForm();\n\n const [errorClass, setErrorClass] = useState('');\n\n const handleNewMethod = () => {\n setPaymentMethod({ id: null });\n };\n\n const useCard = () => {\n setPaymentMethod({ id: paymentMethods[0].id });\n };\n\n const handleChange = (event) => {\n const { error } = event;\n\n if (!!error) {\n setErrorClass('border-red-600');\n } else {\n setErrorClass('');\n }\n };\n\n if (paymentMethods && paymentMethod) {\n return (\n <>\n
\n
\n\n {paymentMethods.map((p, i) => {\n return
;\n })}\n
\n {' '}\n or{' '}\n \n {' '}\n use new card{' '}\n \n
\n
\n >\n );\n }\n\n return (\n <>\n
\n
\n
\n \n
\n
\n >\n );\n};\n\nconst PaymentMethodCard = ({ method }) => {\n const {\n setPaymentMethod,\n state: { paymentMethod },\n } = useForm();\n\n const handleClick = () => {\n setPaymentMethod(method);\n };\n const active = paymentMethod === method.id;\n\n return (\n <>\n
\n
\n
\n {!active || }\n
\n\n
{method.card.brand}
\n
**** **** **** {method.card.last4}
\n
\n\n
\n {method.card.exp_month} / {method.card.exp_year}\n
\n
\n >\n );\n};\n\nfunction CheckIcon(props) {\n return (\n
\n );\n}\n","import React, { useState } from 'react';\n\nconst Modal = (props) => {\n const { HeaderText, body, ButtonText, ActionUrl } = props;\n const [modalOpen, setModalOpen] = useState(true);\n\n const handleClick = () => {\n setModalOpen(!modalOpen);\n };\n\n return (\n <>\n {modalOpen ? (\n
\n
\n
\n
\n\n
\n
\n
\n
\n {' '}\n {HeaderText}{' '}\n
\n
\n
\n
\n\n
\n
\n
\n ) : (\n ''\n )}\n >\n );\n};\n\nexport default Modal;\n","import React, { useState, useContext, createContext, useReducer } from \"react\";\nimport { generateId } from \"../utils/genIds\";\n\nconst newProductVariant = {\n id: null,\n objectId: null,\n name: \"\",\n description: \"\",\n price: 10,\n quantity: 0,\n destroy: false,\n};\n\nconst initialState = {\n product: {},\n product_variants: [],\n};\n\nconst productVariantsReducer = (state, action) => {\n switch (action.type) {\n case \"ADD_PRODUCT_VARIANT\":\n return {\n ...state,\n productVariants: [...state.productVariants, action.productVariant],\n };\n case \"SET_PRODUCT_VARIANTS\":\n return { ...state, productVariants: action.productVariants };\n default:\n return state;\n }\n};\n\nconst ProductVariantsContext = createContext(null);\n\nconst useProductVariants = () => {\n const [state, dispatch] = useContext(ProductVariantsContext);\n\n const addProductVariant = () => {\n dispatch({\n type: \"ADD_PRODUCT_VARIANT\",\n productVariant: { ...newProductVariant, objectId: generateId() },\n });\n };\n\n const removeProductVariant = (productVariant) => {\n // const productVariants = state.productVariants\n // remove a product variant if it does exist\n // toggle destroy a product variant if it does exist\n if (productVariant.id === null) {\n const newProductVariants = state.productVariants.filter(\n (dl) => dl.objectId != productVariant.objectId\n );\n dispatch({\n type: \"SET_PRODUCT_VARIANTS\",\n productVariants: newProductVariants,\n });\n } else {\n const newProductVariants = state.productVariants.map((dl) => {\n if (dl.objectId === productVariant.objectId) {\n return { ...dl, destroy: true };\n } else {\n return { ...dl };\n }\n });\n dispatch({\n type: \"SET_PRODUCT_VARIANTS\",\n productVariants: newProductVariants,\n });\n }\n };\n\n return { state, dispatch, addProductVariant, removeProductVariant };\n};\n\nconst ProductVariantsProvider = (props) => {\n // added the form state\n\n const [state, dispatch] = useReducer(productVariantsReducer, {\n ...initialState,\n product: props.product,\n productVariants: props.productVariants || [],\n productVariantStatuses: props.productVariantStatuses,\n intervalOptions: props.intervalOptions,\n });\n\n const value = React.useMemo(() => [state, dispatch], [state]);\n\n return
;\n};\n\nconst ProductVariantFields = (props) => {\n const { removeProductVariant, state } = useProductVariants();\n const { productVariant, index } = props;\n const namePrefix = `product[product_variants_attributes][${index}]`;\n\n const handleRemoveClick = (e) => {\n e.preventDefault();\n removeProductVariant(productVariant);\n };\n\n const disabled = !!productVariant.id && !productVariant.editable;\n\n return (\n <>\n {productVariant.destroy ? (\n <>\n
\n
\n >\n ) : (\n <>\n {productVariant.id ? (\n
\n ) : (\n \"\"\n )}\n
\n >\n )}\n >\n );\n};\n\nconst ProductVariantsContainer = () => {\n const { state } = useProductVariants();\n return (\n <>\n {state.productVariants.map((productVariant, index) => {\n return (\n
\n );\n })}\n >\n );\n};\n\nconst AddProductVariant = () => {\n const { addProductVariant } = useProductVariants();\n\n const handleClick = (e) => {\n e.preventDefault();\n addProductVariant();\n };\n\n return (\n <>\n
\n \n \n >\n );\n};\n\nconst NestedProductVariantsFields = ({\n product,\n productVariants,\n productVariantStatuses,\n intervalOptions,\n}) => {\n return (\n <>\n
\n \n
\n
\n Product Variants\n
\n
\n add Variants of your products. for instance, if you are selling a\n t-shirt, this is where you add the sizes and quantities of each\n size.\n
\n
\n
\n
\n\n \n \n >\n );\n};\nexport default NestedProductVariantsFields;\n","import React, { useState, useRef, useEffect } from 'react';\nimport { MagnifyingGlassIcon } from '@heroicons/react/20/solid';\nimport axios from \"../utils/requests\";\n\nconst OrgSwitcher = (props) => {\n const { current_organization, organizations } = props;\n const containerRef = useRef(null);\n const [open, setOpen] = useState(false);\n const [filteredOrgs, setFilteredOrgs] = useState(organizations);\n\n const handleClickOutside = (e) => {\n if (containerRef.current.contains(e.target)) return;\n\n setOpen(false);\n };\n\n useEffect(() => {\n if (open) {\n document.addEventListener('click', handleClickOutside);\n } else {\n document.removeEventListener('click', handleClickOutside);\n }\n\n return () => {\n document.removeEventListener('click', handleClickOutside);\n };\n }, [open]);\n\n return (\n <>\n {organizations.length > 1 ? (\n
\n
\n {open ? (\n
\n ) : (\n ''\n )}\n
\n ) : (\n
\n {current_organization.name}\n
\n )}\n >\n );\n};\n\n\nconst OrgList = (props) => {\n const { organizations, current_organization } = props;\n return (\n <>\n {organizations.map((org, index) => {\n return org.id != current_organization.id && (\n
\n {org.name}
\n \n )\n })\n }\n >\n )\n}\n\n\nconst SearchForm = ({ setFilteredOrgs }) => {\n const [search, setSearch] = useState('')\n const searchRef = useRef(null);\n\n useEffect(() => {\n const getData = setTimeout(() => {\n if (search.length < 2) return;\n axios\n .get(`/dashboard/organizations?search_value=${search}`)\n .then((response) => {\n setFilteredOrgs(response.data)\n });\n }, 500)\n\n return () => clearTimeout(getData)\n }, [search]);\n\n const handleSubmit = (e) => {\n e.preventDefault()\n }\n\n return (\n
\n )\n\n}\n\nexport default OrgSwitcher;\n","\nimport React, { useState } from \"react\";\n\n\n\nconst PaymentMethodManager = ({ payment_methods, customer, organization }) => {\n\n const defaultPaymentMethod = payment_methods.find((pm) => {\n return pm.id == customer.invoice_settings.default_payment_method\n })\n\n const otherPaymentMethods = payment_methods.filter((pm) => {\n return pm.id != customer.invoice_settings.default_payment_method\n })\n\n return (\n <>\n
\n {defaultPaymentMethod && <>\n\n \n Default Payment Method\n
\n \n >\n }\n\n {otherPaymentMethods.length > 0 && <>\n \n Other Payment Methods\n
\n {otherPaymentMethods.map(payment_method => (\n \n ))}\n >}\n
\n >\n )\n}\n\n\nconst PaymentMethod = ({ payment_method, customer, organization }) => {\n const isDefault = payment_method.id == customer.invoice_settings.default_payment_method\n\n return <>\n
\n \n
\n
\n
{payment_method.card.brand}
\n {isDefault &&\n \n Default Payment Method\n \n }\n \n
**** **** **** {payment_method.card.last4}
\n
Expires: {payment_method.card.exp_month}/{payment_method.card.exp_year}
\n
\n
\n {!isDefault &&\n \n }\n \n >\n}\n\nexport default PaymentMethodManager","import React, { createContext, useContext, useRef, useState } from \"react\";\n// import { create } from \"zustand\";\nimport { createStore, useStore } from 'zustand'\nimport FlashNotice from \"./FlashNotice\";\n\nconst ProductStoreContext = createContext()\n\n\n\nconst createProductStore = (initialProps) => {\n const defaultProps = {\n product: {},\n productVariants: [],\n selectedProductVariant: null,\n quantity: 1,\n addToCartPath: \"\"\n }\n // only show the product variants that are available to purchase\n const filteredProductVariants = initialProps.productVariants.filter((pv) => pv.quantity > 0);\n return createStore()(set => (\n {\n ...defaultProps,\n ...initialProps,\n productVariants: filteredProductVariants,\n setQuantity: (quantity) => set({ quantity }),\n setProductVariant: (productVariant) => set({ selectedProductVariant: productVariant })\n }))\n}\n\nconst ProductPageProvider = (props) => {\n const productStore = useRef(createProductStore(props)).current\n return (\n
\n \n \n )\n}\n\nconst ProductPage = (props) => {\n const store = useContext(ProductStoreContext)\n const { product, addToCartPath, productVariants, selectedProductVariant, privateProduct, supportEmail, orgName } = useStore(store)\n\n const [showFlash, setShowFlash] = useState(false);\n const [flashMessage, setFlashMessage] = useState('');\n\n const setProductVariant = useStore(store, (s) => s.setProductVariant)\n const quantity = useStore(store, (s) => s.quantity)\n const setQuantity = useStore(store, (s) => s.setQuantity)\n\n const changeProductVariant = (productVariant) => {\n setProductVariant(productVariant)\n setQuantity(1)\n }\n\n\n const setProductQuantity = (quantity) => {\n if (quantity < 1) {\n return;\n }\n if (selectedProductVariant.unlimited_quantity) {\n setQuantity(quantity)\n } else if (quantity <= selectedProductVariant.quantity) {\n setQuantity(quantity)\n }\n }\n\n\n const fullAddToCartPath = addToCartPath + \"?product_variant_id=\" + selectedProductVariant.id + \"&product_variant_qty=\" + quantity\n const checkoutPath = addToCartPath + \"?product_variant_id=\" + selectedProductVariant.id + \"&product_variant_qty=\" + quantity + \"&checkout=true\"\n\n const handleClick = (event) => {\n event.preventDefault();\n setShowFlash(false);\n setTimeout(() => {\n if (privateProduct) {\n setFlashMessage(\"In order to purchase this product, you must be a member of \" + orgName + \". Please contact \" + supportEmail + \" for questions.\");\n setShowFlash(true);\n }\n }, 0);\n }\n\n return (\n <>\n
\n {product.imageUrl ? (\n

\n\n ) : (\n

\n )\n }\n
\n
\n
{product.name}
\n
\n ${selectedProductVariant.price}\n \n
\n
\n
\n
\n
\n
\n
\n setProductQuantity(e.target.value)} />\n \n
\n
\n
\n
\n \n \n
\n
\n
\n\n >\n );\n};\n\nexport default ProductPageProvider;\n","import React, { Fragment } from 'react'\nimport { Menu, MenuButton, MenuItems, MenuItem, Transition } from '@headlessui/react'\nimport { ChevronDownIcon } from '@heroicons/react/20/solid'\n\nfunction classNames(...classes) {\n return classes.filter(Boolean).join(' ')\n}\n\nexport default function ProfileFundUserSwitcher(props) {\n const { current_fund_user, fund_users } = props\n return (\n
\n )\n}\n","import React, { Fragment } from 'react'\nimport { Menu, MenuButton, MenuItems, MenuItem, Transition } from '@headlessui/react'\nimport { ChevronDownIcon } from '@heroicons/react/20/solid'\n\nfunction classNames(...classes) {\n return classes.filter(Boolean).join(' ')\n}\n\nexport default function ProfileOrgSwitcher(props) {\n const { organizations, current_organization } = props\n return (\n
\n )\n}\n","import React, { useState, useRef } from 'react';\n// import { QRCodeCanvas } from \"qrcode.react\"\n// import html2canvas from \"html2canvas\"\nimport { QRCode } from 'react-qrcode-logo';\n\n\n\nexport default function ({ url, logoUrl }) {\n // const url = props.url\n const downloadCode = () => {\n const canvas = document.getElementById(\"code_id\");\n\n if (canvas) {\n const pngUrl = canvas\n .toDataURL(\"image/png\")\n .replace(\"image/png\", \"image/octet-stream\");\n let downloadLink = document.createElement(\"a\");\n downloadLink.href = pngUrl\n downloadLink.download = `your_name.png`;\n document.body.appendChild(downloadLink);\n downloadLink.click();\n document.body.removeChild(downloadLink);\n }\n }\n\n return (\n
\n
\n\n \n
\n\n
\n \n
\n
\n );\n};\n\n// export default function (props) {\n// const url = props.url\n\n// const getCanvas = () => {\n// const qr = document.getElementById(\"fancy-qr-code\")\n// if (!qr) return\n\n// return html2canvas(qr, {\n// onclone: snapshot => {\n// const qrElement = snapshot.getElementById(\"fancy-qr-code\")\n// if (!qrElement) return\n// // Make element visible for cloning\n// qrElement.style.display = \"block\"\n// },\n// })\n// }\n\n// const downloadQRCode = async () => {\n// const canvas = await getCanvas()\n// if (!canvas) throw new Error(\"