"use strict"; /* * ATTENTION: An "eval-source-map" devtool has been used. * This devtool is neither made for production nor for readable output files. * It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools. * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/) * or disable the default devtool with "devtool: false". * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/). */ exports.id = "vendor-chunks/@floating-ui"; exports.ids = ["vendor-chunks/@floating-ui"]; exports.modules = { /***/ "(ssr)/./node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.esm.js": /*!*******************************************************************************!*\ !*** ./node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.esm.js ***! \*******************************************************************************/ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ arrow: () => (/* binding */ arrow),\n/* harmony export */ autoPlacement: () => (/* reexport safe */ _floating_ui_dom__WEBPACK_IMPORTED_MODULE_0__.autoPlacement),\n/* harmony export */ autoUpdate: () => (/* reexport safe */ _floating_ui_dom__WEBPACK_IMPORTED_MODULE_1__.autoUpdate),\n/* harmony export */ computePosition: () => (/* reexport safe */ _floating_ui_dom__WEBPACK_IMPORTED_MODULE_1__.computePosition),\n/* harmony export */ detectOverflow: () => (/* reexport safe */ _floating_ui_dom__WEBPACK_IMPORTED_MODULE_0__.detectOverflow),\n/* harmony export */ flip: () => (/* reexport safe */ _floating_ui_dom__WEBPACK_IMPORTED_MODULE_0__.flip),\n/* harmony export */ getOverflowAncestors: () => (/* reexport safe */ _floating_ui_dom__WEBPACK_IMPORTED_MODULE_2__.getOverflowAncestors),\n/* harmony export */ hide: () => (/* reexport safe */ _floating_ui_dom__WEBPACK_IMPORTED_MODULE_0__.hide),\n/* harmony export */ inline: () => (/* reexport safe */ _floating_ui_dom__WEBPACK_IMPORTED_MODULE_0__.inline),\n/* harmony export */ limitShift: () => (/* reexport safe */ _floating_ui_dom__WEBPACK_IMPORTED_MODULE_0__.limitShift),\n/* harmony export */ offset: () => (/* reexport safe */ _floating_ui_dom__WEBPACK_IMPORTED_MODULE_0__.offset),\n/* harmony export */ platform: () => (/* reexport safe */ _floating_ui_dom__WEBPACK_IMPORTED_MODULE_1__.platform),\n/* harmony export */ shift: () => (/* reexport safe */ _floating_ui_dom__WEBPACK_IMPORTED_MODULE_0__.shift),\n/* harmony export */ size: () => (/* reexport safe */ _floating_ui_dom__WEBPACK_IMPORTED_MODULE_0__.size),\n/* harmony export */ useFloating: () => (/* binding */ useFloating)\n/* harmony export */ });\n/* harmony import */ var _floating_ui_dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @floating-ui/dom */ \"(ssr)/./node_modules/@floating-ui/core/dist/floating-ui.core.mjs\");\n/* harmony import */ var _floating_ui_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @floating-ui/dom */ \"(ssr)/./node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs\");\n/* harmony import */ var _floating_ui_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @floating-ui/dom */ \"(ssr)/./node_modules/@floating-ui/utils/dom/dist/floating-ui.utils.dom.mjs\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! react */ \"(ssr)/./node_modules/next/dist/server/future/route-modules/app-page/vendored/ssr/react.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! react-dom */ \"(ssr)/./node_modules/next/dist/server/future/route-modules/app-page/vendored/ssr/react-dom.js\");\n/* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(react_dom__WEBPACK_IMPORTED_MODULE_4__);\n\n\n\n\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * This wraps the core `arrow` middleware to allow React refs as the element.\n * @see https://floating-ui.com/docs/arrow\n */ const arrow = (options)=>{\n function isRef(value) {\n return ({}).hasOwnProperty.call(value, \"current\");\n }\n return {\n name: \"arrow\",\n options,\n fn (state) {\n const { element, padding } = typeof options === \"function\" ? options(state) : options;\n if (element && isRef(element)) {\n if (element.current != null) {\n return (0,_floating_ui_dom__WEBPACK_IMPORTED_MODULE_0__.arrow)({\n element: element.current,\n padding\n }).fn(state);\n }\n return {};\n } else if (element) {\n return (0,_floating_ui_dom__WEBPACK_IMPORTED_MODULE_0__.arrow)({\n element,\n padding\n }).fn(state);\n }\n return {};\n }\n };\n};\nvar index = typeof document !== \"undefined\" ? react__WEBPACK_IMPORTED_MODULE_3__.useLayoutEffect : react__WEBPACK_IMPORTED_MODULE_3__.useEffect;\n// Fork of `fast-deep-equal` that only does the comparisons we need and compares\n// functions\nfunction deepEqual(a, b) {\n if (a === b) {\n return true;\n }\n if (typeof a !== typeof b) {\n return false;\n }\n if (typeof a === \"function\" && a.toString() === b.toString()) {\n return true;\n }\n let length, i, keys;\n if (a && b && typeof a == \"object\") {\n if (Array.isArray(a)) {\n length = a.length;\n if (length != b.length) return false;\n for(i = length; i-- !== 0;){\n if (!deepEqual(a[i], b[i])) {\n return false;\n }\n }\n return true;\n }\n keys = Object.keys(a);\n length = keys.length;\n if (length !== Object.keys(b).length) {\n return false;\n }\n for(i = length; i-- !== 0;){\n if (!({}).hasOwnProperty.call(b, keys[i])) {\n return false;\n }\n }\n for(i = length; i-- !== 0;){\n const key = keys[i];\n if (key === \"_owner\" && a.$$typeof) {\n continue;\n }\n if (!deepEqual(a[key], b[key])) {\n return false;\n }\n }\n return true;\n }\n return a !== a && b !== b;\n}\nfunction getDPR(element) {\n if (true) {\n return 1;\n }\n const win = element.ownerDocument.defaultView || window;\n return win.devicePixelRatio || 1;\n}\nfunction roundByDPR(element, value) {\n const dpr = getDPR(element);\n return Math.round(value * dpr) / dpr;\n}\nfunction useLatestRef(value) {\n const ref = react__WEBPACK_IMPORTED_MODULE_3__.useRef(value);\n index(()=>{\n ref.current = value;\n });\n return ref;\n}\n/**\n * Provides data to position a floating element.\n * @see https://floating-ui.com/docs/react\n */ function useFloating(options) {\n if (options === void 0) {\n options = {};\n }\n const { placement = \"bottom\", strategy = \"absolute\", middleware = [], platform, elements: { reference: externalReference, floating: externalFloating } = {}, transform = true, whileElementsMounted, open } = options;\n const [data, setData] = react__WEBPACK_IMPORTED_MODULE_3__.useState({\n x: 0,\n y: 0,\n strategy,\n placement,\n middlewareData: {},\n isPositioned: false\n });\n const [latestMiddleware, setLatestMiddleware] = react__WEBPACK_IMPORTED_MODULE_3__.useState(middleware);\n if (!deepEqual(latestMiddleware, middleware)) {\n setLatestMiddleware(middleware);\n }\n const [_reference, _setReference] = react__WEBPACK_IMPORTED_MODULE_3__.useState(null);\n const [_floating, _setFloating] = react__WEBPACK_IMPORTED_MODULE_3__.useState(null);\n const setReference = react__WEBPACK_IMPORTED_MODULE_3__.useCallback((node)=>{\n if (node != referenceRef.current) {\n referenceRef.current = node;\n _setReference(node);\n }\n }, [\n _setReference\n ]);\n const setFloating = react__WEBPACK_IMPORTED_MODULE_3__.useCallback((node)=>{\n if (node !== floatingRef.current) {\n floatingRef.current = node;\n _setFloating(node);\n }\n }, [\n _setFloating\n ]);\n const referenceEl = externalReference || _reference;\n const floatingEl = externalFloating || _floating;\n const referenceRef = react__WEBPACK_IMPORTED_MODULE_3__.useRef(null);\n const floatingRef = react__WEBPACK_IMPORTED_MODULE_3__.useRef(null);\n const dataRef = react__WEBPACK_IMPORTED_MODULE_3__.useRef(data);\n const whileElementsMountedRef = useLatestRef(whileElementsMounted);\n const platformRef = useLatestRef(platform);\n const update = react__WEBPACK_IMPORTED_MODULE_3__.useCallback(()=>{\n if (!referenceRef.current || !floatingRef.current) {\n return;\n }\n const config = {\n placement,\n strategy,\n middleware: latestMiddleware\n };\n if (platformRef.current) {\n config.platform = platformRef.current;\n }\n (0,_floating_ui_dom__WEBPACK_IMPORTED_MODULE_1__.computePosition)(referenceRef.current, floatingRef.current, config).then((data)=>{\n const fullData = {\n ...data,\n isPositioned: true\n };\n if (isMountedRef.current && !deepEqual(dataRef.current, fullData)) {\n dataRef.current = fullData;\n react_dom__WEBPACK_IMPORTED_MODULE_4__.flushSync(()=>{\n setData(fullData);\n });\n }\n });\n }, [\n latestMiddleware,\n placement,\n strategy,\n platformRef\n ]);\n index(()=>{\n if (open === false && dataRef.current.isPositioned) {\n dataRef.current.isPositioned = false;\n setData((data)=>({\n ...data,\n isPositioned: false\n }));\n }\n }, [\n open\n ]);\n const isMountedRef = react__WEBPACK_IMPORTED_MODULE_3__.useRef(false);\n index(()=>{\n isMountedRef.current = true;\n return ()=>{\n isMountedRef.current = false;\n };\n }, []);\n index(()=>{\n if (referenceEl) referenceRef.current = referenceEl;\n if (floatingEl) floatingRef.current = floatingEl;\n if (referenceEl && floatingEl) {\n if (whileElementsMountedRef.current) {\n return whileElementsMountedRef.current(referenceEl, floatingEl, update);\n } else {\n update();\n }\n }\n }, [\n referenceEl,\n floatingEl,\n update,\n whileElementsMountedRef\n ]);\n const refs = react__WEBPACK_IMPORTED_MODULE_3__.useMemo(()=>({\n reference: referenceRef,\n floating: floatingRef,\n setReference,\n setFloating\n }), [\n setReference,\n setFloating\n ]);\n const elements = react__WEBPACK_IMPORTED_MODULE_3__.useMemo(()=>({\n reference: referenceEl,\n floating: floatingEl\n }), [\n referenceEl,\n floatingEl\n ]);\n const floatingStyles = react__WEBPACK_IMPORTED_MODULE_3__.useMemo(()=>{\n const initialStyles = {\n position: strategy,\n left: 0,\n top: 0\n };\n if (!elements.floating) {\n return initialStyles;\n }\n const x = roundByDPR(elements.floating, data.x);\n const y = roundByDPR(elements.floating, data.y);\n if (transform) {\n return {\n ...initialStyles,\n transform: \"translate(\" + x + \"px, \" + y + \"px)\",\n ...getDPR(elements.floating) >= 1.5 && {\n willChange: \"transform\"\n }\n };\n }\n return {\n position: strategy,\n left: x,\n top: y\n };\n }, [\n strategy,\n transform,\n elements.floating,\n data.x,\n data.y\n ]);\n return react__WEBPACK_IMPORTED_MODULE_3__.useMemo(()=>({\n ...data,\n update,\n refs,\n elements,\n floatingStyles\n }), [\n data,\n update,\n refs,\n elements,\n floatingStyles\n ]);\n}\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.esm.js","mappings":"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","sources":["webpack://embedchain-admin/./node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.esm.js?6f00"],"sourcesContent":["import { arrow as arrow$1, computePosition } from '@floating-ui/dom';\nexport { autoPlacement, autoUpdate, computePosition, detectOverflow, flip, getOverflowAncestors, hide, inline, limitShift, offset, platform, shift, size } from '@floating-ui/dom';\nimport * as React from 'react';\nimport { useLayoutEffect, useEffect } from 'react';\nimport * as ReactDOM from 'react-dom';\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * This wraps the core `arrow` middleware to allow React refs as the element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = options => {\n  function isRef(value) {\n    return {}.hasOwnProperty.call(value, 'current');\n  }\n  return {\n    name: 'arrow',\n    options,\n    fn(state) {\n      const {\n        element,\n        padding\n      } = typeof options === 'function' ? options(state) : options;\n      if (element && isRef(element)) {\n        if (element.current != null) {\n          return arrow$1({\n            element: element.current,\n            padding\n          }).fn(state);\n        }\n        return {};\n      } else if (element) {\n        return arrow$1({\n          element,\n          padding\n        }).fn(state);\n      }\n      return {};\n    }\n  };\n};\n\nvar index = typeof document !== 'undefined' ? useLayoutEffect : useEffect;\n\n// Fork of `fast-deep-equal` that only does the comparisons we need and compares\n// functions\nfunction deepEqual(a, b) {\n  if (a === b) {\n    return true;\n  }\n  if (typeof a !== typeof b) {\n    return false;\n  }\n  if (typeof a === 'function' && a.toString() === b.toString()) {\n    return true;\n  }\n  let length, i, keys;\n  if (a && b && typeof a == 'object') {\n    if (Array.isArray(a)) {\n      length = a.length;\n      if (length != b.length) return false;\n      for (i = length; i-- !== 0;) {\n        if (!deepEqual(a[i], b[i])) {\n          return false;\n        }\n      }\n      return true;\n    }\n    keys = Object.keys(a);\n    length = keys.length;\n    if (length !== Object.keys(b).length) {\n      return false;\n    }\n    for (i = length; i-- !== 0;) {\n      if (!{}.hasOwnProperty.call(b, keys[i])) {\n        return false;\n      }\n    }\n    for (i = length; i-- !== 0;) {\n      const key = keys[i];\n      if (key === '_owner' && a.$$typeof) {\n        continue;\n      }\n      if (!deepEqual(a[key], b[key])) {\n        return false;\n      }\n    }\n    return true;\n  }\n  return a !== a && b !== b;\n}\n\nfunction getDPR(element) {\n  if (typeof window === 'undefined') {\n    return 1;\n  }\n  const win = element.ownerDocument.defaultView || window;\n  return win.devicePixelRatio || 1;\n}\n\nfunction roundByDPR(element, value) {\n  const dpr = getDPR(element);\n  return Math.round(value * dpr) / dpr;\n}\n\nfunction useLatestRef(value) {\n  const ref = React.useRef(value);\n  index(() => {\n    ref.current = value;\n  });\n  return ref;\n}\n\n/**\n * Provides data to position a floating element.\n * @see https://floating-ui.com/docs/react\n */\nfunction useFloating(options) {\n  if (options === void 0) {\n    options = {};\n  }\n  const {\n    placement = 'bottom',\n    strategy = 'absolute',\n    middleware = [],\n    platform,\n    elements: {\n      reference: externalReference,\n      floating: externalFloating\n    } = {},\n    transform = true,\n    whileElementsMounted,\n    open\n  } = options;\n  const [data, setData] = React.useState({\n    x: 0,\n    y: 0,\n    strategy,\n    placement,\n    middlewareData: {},\n    isPositioned: false\n  });\n  const [latestMiddleware, setLatestMiddleware] = React.useState(middleware);\n  if (!deepEqual(latestMiddleware, middleware)) {\n    setLatestMiddleware(middleware);\n  }\n  const [_reference, _setReference] = React.useState(null);\n  const [_floating, _setFloating] = React.useState(null);\n  const setReference = React.useCallback(node => {\n    if (node != referenceRef.current) {\n      referenceRef.current = node;\n      _setReference(node);\n    }\n  }, [_setReference]);\n  const setFloating = React.useCallback(node => {\n    if (node !== floatingRef.current) {\n      floatingRef.current = node;\n      _setFloating(node);\n    }\n  }, [_setFloating]);\n  const referenceEl = externalReference || _reference;\n  const floatingEl = externalFloating || _floating;\n  const referenceRef = React.useRef(null);\n  const floatingRef = React.useRef(null);\n  const dataRef = React.useRef(data);\n  const whileElementsMountedRef = useLatestRef(whileElementsMounted);\n  const platformRef = useLatestRef(platform);\n  const update = React.useCallback(() => {\n    if (!referenceRef.current || !floatingRef.current) {\n      return;\n    }\n    const config = {\n      placement,\n      strategy,\n      middleware: latestMiddleware\n    };\n    if (platformRef.current) {\n      config.platform = platformRef.current;\n    }\n    computePosition(referenceRef.current, floatingRef.current, config).then(data => {\n      const fullData = {\n        ...data,\n        isPositioned: true\n      };\n      if (isMountedRef.current && !deepEqual(dataRef.current, fullData)) {\n        dataRef.current = fullData;\n        ReactDOM.flushSync(() => {\n          setData(fullData);\n        });\n      }\n    });\n  }, [latestMiddleware, placement, strategy, platformRef]);\n  index(() => {\n    if (open === false && dataRef.current.isPositioned) {\n      dataRef.current.isPositioned = false;\n      setData(data => ({\n        ...data,\n        isPositioned: false\n      }));\n    }\n  }, [open]);\n  const isMountedRef = React.useRef(false);\n  index(() => {\n    isMountedRef.current = true;\n    return () => {\n      isMountedRef.current = false;\n    };\n  }, []);\n  index(() => {\n    if (referenceEl) referenceRef.current = referenceEl;\n    if (floatingEl) floatingRef.current = floatingEl;\n    if (referenceEl && floatingEl) {\n      if (whileElementsMountedRef.current) {\n        return whileElementsMountedRef.current(referenceEl, floatingEl, update);\n      } else {\n        update();\n      }\n    }\n  }, [referenceEl, floatingEl, update, whileElementsMountedRef]);\n  const refs = React.useMemo(() => ({\n    reference: referenceRef,\n    floating: floatingRef,\n    setReference,\n    setFloating\n  }), [setReference, setFloating]);\n  const elements = React.useMemo(() => ({\n    reference: referenceEl,\n    floating: floatingEl\n  }), [referenceEl, floatingEl]);\n  const floatingStyles = React.useMemo(() => {\n    const initialStyles = {\n      position: strategy,\n      left: 0,\n      top: 0\n    };\n    if (!elements.floating) {\n      return initialStyles;\n    }\n    const x = roundByDPR(elements.floating, data.x);\n    const y = roundByDPR(elements.floating, data.y);\n    if (transform) {\n      return {\n        ...initialStyles,\n        transform: \"translate(\" + x + \"px, \" + y + \"px)\",\n        ...(getDPR(elements.floating) >= 1.5 && {\n          willChange: 'transform'\n        })\n      };\n    }\n    return {\n      position: strategy,\n      left: x,\n      top: y\n    };\n  }, [strategy, transform, elements.floating, data.x, data.y]);\n  return React.useMemo(() => ({\n    ...data,\n    update,\n    refs,\n    elements,\n    floatingStyles\n  }), [data, update, refs, elements, floatingStyles]);\n}\n\nexport { arrow, useFloating };\n"],"names":["arrow","arrow$1","computePosition","autoPlacement","autoUpdate","detectOverflow","flip","getOverflowAncestors","hide","inline","limitShift","offset","platform","shift","size","React","useLayoutEffect","useEffect","ReactDOM","options","isRef","value","hasOwnProperty","call","name","fn","state","element","padding","current","index","document","deepEqual","a","b","toString","length","i","keys","Array","isArray","Object","key","$$typeof","getDPR","win","ownerDocument","defaultView","window","devicePixelRatio","roundByDPR","dpr","Math","round","useLatestRef","ref","useRef","useFloating","placement","strategy","middleware","elements","reference","externalReference","floating","externalFloating","transform","whileElementsMounted","open","data","setData","useState","x","y","middlewareData","isPositioned","latestMiddleware","setLatestMiddleware","_reference","_setReference","_floating","_setFloating","setReference","useCallback","node","referenceRef","setFloating","floatingRef","referenceEl","floatingEl","dataRef","whileElementsMountedRef","platformRef","update","config","then","fullData","isMountedRef","flushSync","refs","useMemo","floatingStyles","initialStyles","position","left","top","willChange"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.esm.js\n"); /***/ }), /***/ "(ssr)/./node_modules/@floating-ui/core/dist/floating-ui.core.mjs": /*!******************************************************************!*\ !*** ./node_modules/@floating-ui/core/dist/floating-ui.core.mjs ***! \******************************************************************/ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ arrow: () => (/* binding */ arrow),\n/* harmony export */ autoPlacement: () => (/* binding */ autoPlacement),\n/* harmony export */ computePosition: () => (/* binding */ computePosition),\n/* harmony export */ detectOverflow: () => (/* binding */ detectOverflow),\n/* harmony export */ flip: () => (/* binding */ flip),\n/* harmony export */ hide: () => (/* binding */ hide),\n/* harmony export */ inline: () => (/* binding */ inline),\n/* harmony export */ limitShift: () => (/* binding */ limitShift),\n/* harmony export */ offset: () => (/* binding */ offset),\n/* harmony export */ rectToClientRect: () => (/* reexport safe */ _floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.rectToClientRect),\n/* harmony export */ shift: () => (/* binding */ shift),\n/* harmony export */ size: () => (/* binding */ size)\n/* harmony export */ });\n/* harmony import */ var _floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @floating-ui/utils */ \"(ssr)/./node_modules/@floating-ui/utils/dist/floating-ui.utils.mjs\");\n\n\nfunction computeCoordsFromPlacement(_ref, placement, rtl) {\n let { reference, floating } = _ref;\n const sideAxis = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSideAxis)(placement);\n const alignmentAxis = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAlignmentAxis)(placement);\n const alignLength = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAxisLength)(alignmentAxis);\n const side = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSide)(placement);\n const isVertical = sideAxis === \"y\";\n const commonX = reference.x + reference.width / 2 - floating.width / 2;\n const commonY = reference.y + reference.height / 2 - floating.height / 2;\n const commonAlign = reference[alignLength] / 2 - floating[alignLength] / 2;\n let coords;\n switch(side){\n case \"top\":\n coords = {\n x: commonX,\n y: reference.y - floating.height\n };\n break;\n case \"bottom\":\n coords = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n case \"right\":\n coords = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n case \"left\":\n coords = {\n x: reference.x - floating.width,\n y: commonY\n };\n break;\n default:\n coords = {\n x: reference.x,\n y: reference.y\n };\n }\n switch((0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAlignment)(placement)){\n case \"start\":\n coords[alignmentAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);\n break;\n case \"end\":\n coords[alignmentAxis] += commonAlign * (rtl && isVertical ? -1 : 1);\n break;\n }\n return coords;\n}\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a reference element when it is given a certain positioning strategy.\n *\n * This export does not have any `platform` interface logic. You will need to\n * write one for the platform you are using Floating UI with.\n */ const computePosition = async (reference, floating, config)=>{\n const { placement = \"bottom\", strategy = \"absolute\", middleware = [], platform } = config;\n const validMiddleware = middleware.filter(Boolean);\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));\n let rects = await platform.getElementRects({\n reference,\n floating,\n strategy\n });\n let { x, y } = computeCoordsFromPlacement(rects, placement, rtl);\n let statefulPlacement = placement;\n let middlewareData = {};\n let resetCount = 0;\n for(let i = 0; i < validMiddleware.length; i++){\n const { name, fn } = validMiddleware[i];\n const { x: nextX, y: nextY, data, reset } = await fn({\n x,\n y,\n initialPlacement: placement,\n placement: statefulPlacement,\n strategy,\n middlewareData,\n rects,\n platform,\n elements: {\n reference,\n floating\n }\n });\n x = nextX != null ? nextX : x;\n y = nextY != null ? nextY : y;\n middlewareData = {\n ...middlewareData,\n [name]: {\n ...middlewareData[name],\n ...data\n }\n };\n if (reset && resetCount <= 50) {\n resetCount++;\n if (typeof reset === \"object\") {\n if (reset.placement) {\n statefulPlacement = reset.placement;\n }\n if (reset.rects) {\n rects = reset.rects === true ? await platform.getElementRects({\n reference,\n floating,\n strategy\n }) : reset.rects;\n }\n ({ x, y } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));\n }\n i = -1;\n continue;\n }\n }\n return {\n x,\n y,\n placement: statefulPlacement,\n strategy,\n middlewareData\n };\n};\n/**\n * Resolves with an object of overflow side offsets that determine how much the\n * element is overflowing a given clipping boundary on each side.\n * - positive = overflowing the boundary by that number of pixels\n * - negative = how many pixels left before it will overflow\n * - 0 = lies flush with the boundary\n * @see https://floating-ui.com/docs/detectOverflow\n */ async function detectOverflow(state, options) {\n var _await$platform$isEle;\n if (options === void 0) {\n options = {};\n }\n const { x, y, platform, rects, elements, strategy } = state;\n const { boundary = \"clippingAncestors\", rootBoundary = \"viewport\", elementContext = \"floating\", altBoundary = false, padding = 0 } = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.evaluate)(options, state);\n const paddingObject = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getPaddingObject)(padding);\n const altContext = elementContext === \"floating\" ? \"reference\" : \"floating\";\n const element = elements[altBoundary ? altContext : elementContext];\n const clippingClientRect = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.rectToClientRect)(await platform.getClippingRect({\n element: ((_await$platform$isEle = await (platform.isElement == null ? void 0 : platform.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || await (platform.getDocumentElement == null ? void 0 : platform.getDocumentElement(elements.floating)),\n boundary,\n rootBoundary,\n strategy\n }));\n const rect = elementContext === \"floating\" ? {\n ...rects.floating,\n x,\n y\n } : rects.reference;\n const offsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating));\n const offsetScale = await (platform.isElement == null ? void 0 : platform.isElement(offsetParent)) ? await (platform.getScale == null ? void 0 : platform.getScale(offsetParent)) || {\n x: 1,\n y: 1\n } : {\n x: 1,\n y: 1\n };\n const elementClientRect = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.rectToClientRect)(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({\n rect,\n offsetParent,\n strategy\n }) : rect);\n return {\n top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y,\n bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y,\n left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x,\n right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x\n };\n}\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */ const arrow = (options)=>({\n name: \"arrow\",\n options,\n async fn (state) {\n const { x, y, placement, rects, platform, elements } = state;\n // Since `element` is required, we don't Partial<> the type.\n const { element, padding = 0 } = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.evaluate)(options, state) || {};\n if (element == null) {\n return {};\n }\n const paddingObject = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getPaddingObject)(padding);\n const coords = {\n x,\n y\n };\n const axis = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAlignmentAxis)(placement);\n const length = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAxisLength)(axis);\n const arrowDimensions = await platform.getDimensions(element);\n const isYAxis = axis === \"y\";\n const minProp = isYAxis ? \"top\" : \"left\";\n const maxProp = isYAxis ? \"bottom\" : \"right\";\n const clientProp = isYAxis ? \"clientHeight\" : \"clientWidth\";\n const endDiff = rects.reference[length] + rects.reference[axis] - coords[axis] - rects.floating[length];\n const startDiff = coords[axis] - rects.reference[axis];\n const arrowOffsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(element));\n let clientSize = arrowOffsetParent ? arrowOffsetParent[clientProp] : 0;\n // DOM platform can return `window` as the `offsetParent`.\n if (!clientSize || !await (platform.isElement == null ? void 0 : platform.isElement(arrowOffsetParent))) {\n clientSize = elements.floating[clientProp] || rects.floating[length];\n }\n const centerToReference = endDiff / 2 - startDiff / 2;\n // If the padding is large enough that it causes the arrow to no longer be\n // centered, modify the padding so that it is centered.\n const largestPossiblePadding = clientSize / 2 - arrowDimensions[length] / 2 - 1;\n const minPadding = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.min)(paddingObject[minProp], largestPossiblePadding);\n const maxPadding = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.min)(paddingObject[maxProp], largestPossiblePadding);\n // Make sure the arrow doesn't overflow the floating element if the center\n // point is outside the floating element's bounds.\n const min$1 = minPadding;\n const max = clientSize - arrowDimensions[length] - maxPadding;\n const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;\n const offset = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.clamp)(min$1, center, max);\n // If the reference is small enough that the arrow's padding causes it to\n // to point to nothing for an aligned placement, adjust the offset of the\n // floating element itself. This stops `shift()` from taking action, but can\n // be worked around by calling it again after the `arrow()` if desired.\n const shouldAddOffset = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAlignment)(placement) != null && center != offset && rects.reference[length] / 2 - (center < min$1 ? minPadding : maxPadding) - arrowDimensions[length] / 2 < 0;\n const alignmentOffset = shouldAddOffset ? center < min$1 ? min$1 - center : max - center : 0;\n return {\n [axis]: coords[axis] - alignmentOffset,\n data: {\n [axis]: offset,\n centerOffset: center - offset + alignmentOffset\n }\n };\n }\n });\nfunction getPlacementList(alignment, autoAlignment, allowedPlacements) {\n const allowedPlacementsSortedByAlignment = alignment ? [\n ...allowedPlacements.filter((placement)=>(0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAlignment)(placement) === alignment),\n ...allowedPlacements.filter((placement)=>(0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAlignment)(placement) !== alignment)\n ] : allowedPlacements.filter((placement)=>(0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSide)(placement) === placement);\n return allowedPlacementsSortedByAlignment.filter((placement)=>{\n if (alignment) {\n return (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAlignment)(placement) === alignment || (autoAlignment ? (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getOppositeAlignmentPlacement)(placement) !== placement : false);\n }\n return true;\n });\n}\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */ const autoPlacement = function(options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: \"autoPlacement\",\n options,\n async fn (state) {\n var _middlewareData$autoP, _middlewareData$autoP2, _placementsThatFitOnE;\n const { rects, middlewareData, placement, platform, elements } = state;\n const { crossAxis = false, alignment, allowedPlacements = _floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.placements, autoAlignment = true, ...detectOverflowOptions } = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.evaluate)(options, state);\n const placements$1 = alignment !== undefined || allowedPlacements === _floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.placements ? getPlacementList(alignment || null, autoAlignment, allowedPlacements) : allowedPlacements;\n const overflow = await detectOverflow(state, detectOverflowOptions);\n const currentIndex = ((_middlewareData$autoP = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP.index) || 0;\n const currentPlacement = placements$1[currentIndex];\n if (currentPlacement == null) {\n return {};\n }\n const alignmentSides = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAlignmentSides)(currentPlacement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));\n // Make `computeCoords` start from the right place.\n if (placement !== currentPlacement) {\n return {\n reset: {\n placement: placements$1[0]\n }\n };\n }\n const currentOverflows = [\n overflow[(0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSide)(currentPlacement)],\n overflow[alignmentSides[0]],\n overflow[alignmentSides[1]]\n ];\n const allOverflows = [\n ...((_middlewareData$autoP2 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP2.overflows) || [],\n {\n placement: currentPlacement,\n overflows: currentOverflows\n }\n ];\n const nextPlacement = placements$1[currentIndex + 1];\n // There are more placements to check.\n if (nextPlacement) {\n return {\n data: {\n index: currentIndex + 1,\n overflows: allOverflows\n },\n reset: {\n placement: nextPlacement\n }\n };\n }\n const placementsSortedByMostSpace = allOverflows.map((d)=>{\n const alignment = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAlignment)(d.placement);\n return [\n d.placement,\n alignment && crossAxis ? // Check along the mainAxis and main crossAxis side.\n d.overflows.slice(0, 2).reduce((acc, v)=>acc + v, 0) : // Check only the mainAxis.\n d.overflows[0],\n d.overflows\n ];\n }).sort((a, b)=>a[1] - b[1]);\n const placementsThatFitOnEachSide = placementsSortedByMostSpace.filter((d)=>d[2].slice(0, // Aligned placements should not check their opposite crossAxis\n // side.\n (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAlignment)(d[0]) ? 2 : 3).every((v)=>v <= 0));\n const resetPlacement = ((_placementsThatFitOnE = placementsThatFitOnEachSide[0]) == null ? void 0 : _placementsThatFitOnE[0]) || placementsSortedByMostSpace[0][0];\n if (resetPlacement !== placement) {\n return {\n data: {\n index: currentIndex + 1,\n overflows: allOverflows\n },\n reset: {\n placement: resetPlacement\n }\n };\n }\n return {};\n }\n };\n};\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */ const flip = function(options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: \"flip\",\n options,\n async fn (state) {\n var _middlewareData$flip;\n const { placement, middlewareData, rects, initialPlacement, platform, elements } = state;\n const { mainAxis: checkMainAxis = true, crossAxis: checkCrossAxis = true, fallbackPlacements: specifiedFallbackPlacements, fallbackStrategy = \"bestFit\", fallbackAxisSideDirection = \"none\", flipAlignment = true, ...detectOverflowOptions } = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.evaluate)(options, state);\n const side = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSide)(placement);\n const isBasePlacement = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSide)(initialPlacement) === initialPlacement;\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [\n (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getOppositePlacement)(initialPlacement)\n ] : (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getExpandedPlacements)(initialPlacement));\n if (!specifiedFallbackPlacements && fallbackAxisSideDirection !== \"none\") {\n fallbackPlacements.push(...(0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getOppositeAxisPlacements)(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl));\n }\n const placements = [\n initialPlacement,\n ...fallbackPlacements\n ];\n const overflow = await detectOverflow(state, detectOverflowOptions);\n const overflows = [];\n let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];\n if (checkMainAxis) {\n overflows.push(overflow[side]);\n }\n if (checkCrossAxis) {\n const sides = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAlignmentSides)(placement, rects, rtl);\n overflows.push(overflow[sides[0]], overflow[sides[1]]);\n }\n overflowsData = [\n ...overflowsData,\n {\n placement,\n overflows\n }\n ];\n // One or more sides is overflowing.\n if (!overflows.every((side)=>side <= 0)) {\n var _middlewareData$flip2, _overflowsData$filter;\n const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1;\n const nextPlacement = placements[nextIndex];\n if (nextPlacement) {\n // Try next placement and re-run the lifecycle.\n return {\n data: {\n index: nextIndex,\n overflows: overflowsData\n },\n reset: {\n placement: nextPlacement\n }\n };\n }\n // First, find the candidates that fit on the mainAxis side of overflow,\n // then find the placement that fits the best on the main crossAxis side.\n let resetPlacement = (_overflowsData$filter = overflowsData.filter((d)=>d.overflows[0] <= 0).sort((a, b)=>a.overflows[1] - b.overflows[1])[0]) == null ? void 0 : _overflowsData$filter.placement;\n // Otherwise fallback.\n if (!resetPlacement) {\n switch(fallbackStrategy){\n case \"bestFit\":\n {\n var _overflowsData$map$so;\n const placement = (_overflowsData$map$so = overflowsData.map((d)=>[\n d.placement,\n d.overflows.filter((overflow)=>overflow > 0).reduce((acc, overflow)=>acc + overflow, 0)\n ]).sort((a, b)=>a[1] - b[1])[0]) == null ? void 0 : _overflowsData$map$so[0];\n if (placement) {\n resetPlacement = placement;\n }\n break;\n }\n case \"initialPlacement\":\n resetPlacement = initialPlacement;\n break;\n }\n }\n if (placement !== resetPlacement) {\n return {\n reset: {\n placement: resetPlacement\n }\n };\n }\n }\n return {};\n }\n };\n};\nfunction getSideOffsets(overflow, rect) {\n return {\n top: overflow.top - rect.height,\n right: overflow.right - rect.width,\n bottom: overflow.bottom - rect.height,\n left: overflow.left - rect.width\n };\n}\nfunction isAnySideFullyClipped(overflow) {\n return _floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.sides.some((side)=>overflow[side] >= 0);\n}\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */ const hide = function(options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: \"hide\",\n options,\n async fn (state) {\n const { rects } = state;\n const { strategy = \"referenceHidden\", ...detectOverflowOptions } = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.evaluate)(options, state);\n switch(strategy){\n case \"referenceHidden\":\n {\n const overflow = await detectOverflow(state, {\n ...detectOverflowOptions,\n elementContext: \"reference\"\n });\n const offsets = getSideOffsets(overflow, rects.reference);\n return {\n data: {\n referenceHiddenOffsets: offsets,\n referenceHidden: isAnySideFullyClipped(offsets)\n }\n };\n }\n case \"escaped\":\n {\n const overflow = await detectOverflow(state, {\n ...detectOverflowOptions,\n altBoundary: true\n });\n const offsets = getSideOffsets(overflow, rects.floating);\n return {\n data: {\n escapedOffsets: offsets,\n escaped: isAnySideFullyClipped(offsets)\n }\n };\n }\n default:\n {\n return {};\n }\n }\n }\n };\n};\nfunction getBoundingRect(rects) {\n const minX = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.min)(...rects.map((rect)=>rect.left));\n const minY = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.min)(...rects.map((rect)=>rect.top));\n const maxX = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.max)(...rects.map((rect)=>rect.right));\n const maxY = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.max)(...rects.map((rect)=>rect.bottom));\n return {\n x: minX,\n y: minY,\n width: maxX - minX,\n height: maxY - minY\n };\n}\nfunction getRectsByLine(rects) {\n const sortedRects = rects.slice().sort((a, b)=>a.y - b.y);\n const groups = [];\n let prevRect = null;\n for(let i = 0; i < sortedRects.length; i++){\n const rect = sortedRects[i];\n if (!prevRect || rect.y - prevRect.y > prevRect.height / 2) {\n groups.push([\n rect\n ]);\n } else {\n groups[groups.length - 1].push(rect);\n }\n prevRect = rect;\n }\n return groups.map((rect)=>(0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.rectToClientRect)(getBoundingRect(rect)));\n}\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */ const inline = function(options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: \"inline\",\n options,\n async fn (state) {\n const { placement, elements, rects, platform, strategy } = state;\n // A MouseEvent's client{X,Y} coords can be up to 2 pixels off a\n // ClientRect's bounds, despite the event listener being triggered. A\n // padding of 2 seems to handle this issue.\n const { padding = 2, x, y } = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.evaluate)(options, state);\n const nativeClientRects = Array.from(await (platform.getClientRects == null ? void 0 : platform.getClientRects(elements.reference)) || []);\n const clientRects = getRectsByLine(nativeClientRects);\n const fallback = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.rectToClientRect)(getBoundingRect(nativeClientRects));\n const paddingObject = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getPaddingObject)(padding);\n function getBoundingClientRect() {\n // There are two rects and they are disjoined.\n if (clientRects.length === 2 && clientRects[0].left > clientRects[1].right && x != null && y != null) {\n // Find the first rect in which the point is fully inside.\n return clientRects.find((rect)=>x > rect.left - paddingObject.left && x < rect.right + paddingObject.right && y > rect.top - paddingObject.top && y < rect.bottom + paddingObject.bottom) || fallback;\n }\n // There are 2 or more connected rects.\n if (clientRects.length >= 2) {\n if ((0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSideAxis)(placement) === \"y\") {\n const firstRect = clientRects[0];\n const lastRect = clientRects[clientRects.length - 1];\n const isTop = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSide)(placement) === \"top\";\n const top = firstRect.top;\n const bottom = lastRect.bottom;\n const left = isTop ? firstRect.left : lastRect.left;\n const right = isTop ? firstRect.right : lastRect.right;\n const width = right - left;\n const height = bottom - top;\n return {\n top,\n bottom,\n left,\n right,\n width,\n height,\n x: left,\n y: top\n };\n }\n const isLeftSide = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSide)(placement) === \"left\";\n const maxRight = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.max)(...clientRects.map((rect)=>rect.right));\n const minLeft = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.min)(...clientRects.map((rect)=>rect.left));\n const measureRects = clientRects.filter((rect)=>isLeftSide ? rect.left === minLeft : rect.right === maxRight);\n const top = measureRects[0].top;\n const bottom = measureRects[measureRects.length - 1].bottom;\n const left = minLeft;\n const right = maxRight;\n const width = right - left;\n const height = bottom - top;\n return {\n top,\n bottom,\n left,\n right,\n width,\n height,\n x: left,\n y: top\n };\n }\n return fallback;\n }\n const resetRects = await platform.getElementRects({\n reference: {\n getBoundingClientRect\n },\n floating: elements.floating,\n strategy\n });\n if (rects.reference.x !== resetRects.reference.x || rects.reference.y !== resetRects.reference.y || rects.reference.width !== resetRects.reference.width || rects.reference.height !== resetRects.reference.height) {\n return {\n reset: {\n rects: resetRects\n }\n };\n }\n return {};\n }\n };\n};\n// For type backwards-compatibility, the `OffsetOptions` type was also\n// Derivable.\nasync function convertValueToCoords(state, options) {\n const { placement, platform, elements } = state;\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n const side = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSide)(placement);\n const alignment = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAlignment)(placement);\n const isVertical = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSideAxis)(placement) === \"y\";\n const mainAxisMulti = [\n \"left\",\n \"top\"\n ].includes(side) ? -1 : 1;\n const crossAxisMulti = rtl && isVertical ? -1 : 1;\n const rawValue = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.evaluate)(options, state);\n // eslint-disable-next-line prefer-const\n let { mainAxis, crossAxis, alignmentAxis } = typeof rawValue === \"number\" ? {\n mainAxis: rawValue,\n crossAxis: 0,\n alignmentAxis: null\n } : {\n mainAxis: 0,\n crossAxis: 0,\n alignmentAxis: null,\n ...rawValue\n };\n if (alignment && typeof alignmentAxis === \"number\") {\n crossAxis = alignment === \"end\" ? alignmentAxis * -1 : alignmentAxis;\n }\n return isVertical ? {\n x: crossAxis * crossAxisMulti,\n y: mainAxis * mainAxisMulti\n } : {\n x: mainAxis * mainAxisMulti,\n y: crossAxis * crossAxisMulti\n };\n}\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */ const offset = function(options) {\n if (options === void 0) {\n options = 0;\n }\n return {\n name: \"offset\",\n options,\n async fn (state) {\n const { x, y } = state;\n const diffCoords = await convertValueToCoords(state, options);\n return {\n x: x + diffCoords.x,\n y: y + diffCoords.y,\n data: diffCoords\n };\n }\n };\n};\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */ const shift = function(options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: \"shift\",\n options,\n async fn (state) {\n const { x, y, placement } = state;\n const { mainAxis: checkMainAxis = true, crossAxis: checkCrossAxis = false, limiter = {\n fn: (_ref)=>{\n let { x, y } = _ref;\n return {\n x,\n y\n };\n }\n }, ...detectOverflowOptions } = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.evaluate)(options, state);\n const coords = {\n x,\n y\n };\n const overflow = await detectOverflow(state, detectOverflowOptions);\n const crossAxis = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSideAxis)((0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSide)(placement));\n const mainAxis = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getOppositeAxis)(crossAxis);\n let mainAxisCoord = coords[mainAxis];\n let crossAxisCoord = coords[crossAxis];\n if (checkMainAxis) {\n const minSide = mainAxis === \"y\" ? \"top\" : \"left\";\n const maxSide = mainAxis === \"y\" ? \"bottom\" : \"right\";\n const min = mainAxisCoord + overflow[minSide];\n const max = mainAxisCoord - overflow[maxSide];\n mainAxisCoord = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.clamp)(min, mainAxisCoord, max);\n }\n if (checkCrossAxis) {\n const minSide = crossAxis === \"y\" ? \"top\" : \"left\";\n const maxSide = crossAxis === \"y\" ? \"bottom\" : \"right\";\n const min = crossAxisCoord + overflow[minSide];\n const max = crossAxisCoord - overflow[maxSide];\n crossAxisCoord = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.clamp)(min, crossAxisCoord, max);\n }\n const limitedCoords = limiter.fn({\n ...state,\n [mainAxis]: mainAxisCoord,\n [crossAxis]: crossAxisCoord\n });\n return {\n ...limitedCoords,\n data: {\n x: limitedCoords.x - x,\n y: limitedCoords.y - y\n }\n };\n }\n };\n};\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */ const limitShift = function(options) {\n if (options === void 0) {\n options = {};\n }\n return {\n options,\n fn (state) {\n const { x, y, placement, rects, middlewareData } = state;\n const { offset = 0, mainAxis: checkMainAxis = true, crossAxis: checkCrossAxis = true } = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.evaluate)(options, state);\n const coords = {\n x,\n y\n };\n const crossAxis = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSideAxis)(placement);\n const mainAxis = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getOppositeAxis)(crossAxis);\n let mainAxisCoord = coords[mainAxis];\n let crossAxisCoord = coords[crossAxis];\n const rawOffset = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.evaluate)(offset, state);\n const computedOffset = typeof rawOffset === \"number\" ? {\n mainAxis: rawOffset,\n crossAxis: 0\n } : {\n mainAxis: 0,\n crossAxis: 0,\n ...rawOffset\n };\n if (checkMainAxis) {\n const len = mainAxis === \"y\" ? \"height\" : \"width\";\n const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis;\n const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis;\n if (mainAxisCoord < limitMin) {\n mainAxisCoord = limitMin;\n } else if (mainAxisCoord > limitMax) {\n mainAxisCoord = limitMax;\n }\n }\n if (checkCrossAxis) {\n var _middlewareData$offse, _middlewareData$offse2;\n const len = mainAxis === \"y\" ? \"width\" : \"height\";\n const isOriginSide = [\n \"top\",\n \"left\"\n ].includes((0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSide)(placement));\n const limitMin = rects.reference[crossAxis] - rects.floating[len] + (isOriginSide ? ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse[crossAxis]) || 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis);\n const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : ((_middlewareData$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) || 0) - (isOriginSide ? computedOffset.crossAxis : 0);\n if (crossAxisCoord < limitMin) {\n crossAxisCoord = limitMin;\n } else if (crossAxisCoord > limitMax) {\n crossAxisCoord = limitMax;\n }\n }\n return {\n [mainAxis]: mainAxisCoord,\n [crossAxis]: crossAxisCoord\n };\n }\n };\n};\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */ const size = function(options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: \"size\",\n options,\n async fn (state) {\n const { placement, rects, platform, elements } = state;\n const { apply = ()=>{}, ...detectOverflowOptions } = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.evaluate)(options, state);\n const overflow = await detectOverflow(state, detectOverflowOptions);\n const side = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSide)(placement);\n const alignment = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getAlignment)(placement);\n const isYAxis = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.getSideAxis)(placement) === \"y\";\n const { width, height } = rects.floating;\n let heightSide;\n let widthSide;\n if (side === \"top\" || side === \"bottom\") {\n heightSide = side;\n widthSide = alignment === (await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)) ? \"start\" : \"end\") ? \"left\" : \"right\";\n } else {\n widthSide = side;\n heightSide = alignment === \"end\" ? \"top\" : \"bottom\";\n }\n const overflowAvailableHeight = height - overflow[heightSide];\n const overflowAvailableWidth = width - overflow[widthSide];\n const noShift = !state.middlewareData.shift;\n let availableHeight = overflowAvailableHeight;\n let availableWidth = overflowAvailableWidth;\n if (isYAxis) {\n const maximumClippingWidth = width - overflow.left - overflow.right;\n availableWidth = alignment || noShift ? (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.min)(overflowAvailableWidth, maximumClippingWidth) : maximumClippingWidth;\n } else {\n const maximumClippingHeight = height - overflow.top - overflow.bottom;\n availableHeight = alignment || noShift ? (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.min)(overflowAvailableHeight, maximumClippingHeight) : maximumClippingHeight;\n }\n if (noShift && !alignment) {\n const xMin = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.max)(overflow.left, 0);\n const xMax = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.max)(overflow.right, 0);\n const yMin = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.max)(overflow.top, 0);\n const yMax = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.max)(overflow.bottom, 0);\n if (isYAxis) {\n availableWidth = width - 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.max)(overflow.left, overflow.right));\n } else {\n availableHeight = height - 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_0__.max)(overflow.top, overflow.bottom));\n }\n }\n await apply({\n ...state,\n availableWidth,\n availableHeight\n });\n const nextDimensions = await platform.getDimensions(elements.floating);\n if (width !== nextDimensions.width || height !== nextDimensions.height) {\n return {\n reset: {\n rects: true\n }\n };\n }\n return {};\n }\n };\n};\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/@floating-ui/core/dist/floating-ui.core.mjs","mappings":"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","sources":["webpack://embedchain-admin/./node_modules/@floating-ui/core/dist/floating-ui.core.mjs?56bf"],"sourcesContent":["import { getSideAxis, getAlignmentAxis, getAxisLength, getSide, getAlignment, evaluate, getPaddingObject, rectToClientRect, min, clamp, placements, getAlignmentSides, getOppositeAlignmentPlacement, getOppositePlacement, getExpandedPlacements, getOppositeAxisPlacements, sides, max, getOppositeAxis } from '@floating-ui/utils';\nexport { rectToClientRect } from '@floating-ui/utils';\n\nfunction computeCoordsFromPlacement(_ref, placement, rtl) {\n  let {\n    reference,\n    floating\n  } = _ref;\n  const sideAxis = getSideAxis(placement);\n  const alignmentAxis = getAlignmentAxis(placement);\n  const alignLength = getAxisLength(alignmentAxis);\n  const side = getSide(placement);\n  const isVertical = sideAxis === 'y';\n  const commonX = reference.x + reference.width / 2 - floating.width / 2;\n  const commonY = reference.y + reference.height / 2 - floating.height / 2;\n  const commonAlign = reference[alignLength] / 2 - floating[alignLength] / 2;\n  let coords;\n  switch (side) {\n    case 'top':\n      coords = {\n        x: commonX,\n        y: reference.y - floating.height\n      };\n      break;\n    case 'bottom':\n      coords = {\n        x: commonX,\n        y: reference.y + reference.height\n      };\n      break;\n    case 'right':\n      coords = {\n        x: reference.x + reference.width,\n        y: commonY\n      };\n      break;\n    case 'left':\n      coords = {\n        x: reference.x - floating.width,\n        y: commonY\n      };\n      break;\n    default:\n      coords = {\n        x: reference.x,\n        y: reference.y\n      };\n  }\n  switch (getAlignment(placement)) {\n    case 'start':\n      coords[alignmentAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);\n      break;\n    case 'end':\n      coords[alignmentAxis] += commonAlign * (rtl && isVertical ? -1 : 1);\n      break;\n  }\n  return coords;\n}\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a reference element when it is given a certain positioning strategy.\n *\n * This export does not have any `platform` interface logic. You will need to\n * write one for the platform you are using Floating UI with.\n */\nconst computePosition = async (reference, floating, config) => {\n  const {\n    placement = 'bottom',\n    strategy = 'absolute',\n    middleware = [],\n    platform\n  } = config;\n  const validMiddleware = middleware.filter(Boolean);\n  const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));\n  let rects = await platform.getElementRects({\n    reference,\n    floating,\n    strategy\n  });\n  let {\n    x,\n    y\n  } = computeCoordsFromPlacement(rects, placement, rtl);\n  let statefulPlacement = placement;\n  let middlewareData = {};\n  let resetCount = 0;\n  for (let i = 0; i < validMiddleware.length; i++) {\n    const {\n      name,\n      fn\n    } = validMiddleware[i];\n    const {\n      x: nextX,\n      y: nextY,\n      data,\n      reset\n    } = await fn({\n      x,\n      y,\n      initialPlacement: placement,\n      placement: statefulPlacement,\n      strategy,\n      middlewareData,\n      rects,\n      platform,\n      elements: {\n        reference,\n        floating\n      }\n    });\n    x = nextX != null ? nextX : x;\n    y = nextY != null ? nextY : y;\n    middlewareData = {\n      ...middlewareData,\n      [name]: {\n        ...middlewareData[name],\n        ...data\n      }\n    };\n    if (reset && resetCount <= 50) {\n      resetCount++;\n      if (typeof reset === 'object') {\n        if (reset.placement) {\n          statefulPlacement = reset.placement;\n        }\n        if (reset.rects) {\n          rects = reset.rects === true ? await platform.getElementRects({\n            reference,\n            floating,\n            strategy\n          }) : reset.rects;\n        }\n        ({\n          x,\n          y\n        } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));\n      }\n      i = -1;\n      continue;\n    }\n  }\n  return {\n    x,\n    y,\n    placement: statefulPlacement,\n    strategy,\n    middlewareData\n  };\n};\n\n/**\n * Resolves with an object of overflow side offsets that determine how much the\n * element is overflowing a given clipping boundary on each side.\n * - positive = overflowing the boundary by that number of pixels\n * - negative = how many pixels left before it will overflow\n * - 0 = lies flush with the boundary\n * @see https://floating-ui.com/docs/detectOverflow\n */\nasync function detectOverflow(state, options) {\n  var _await$platform$isEle;\n  if (options === void 0) {\n    options = {};\n  }\n  const {\n    x,\n    y,\n    platform,\n    rects,\n    elements,\n    strategy\n  } = state;\n  const {\n    boundary = 'clippingAncestors',\n    rootBoundary = 'viewport',\n    elementContext = 'floating',\n    altBoundary = false,\n    padding = 0\n  } = evaluate(options, state);\n  const paddingObject = getPaddingObject(padding);\n  const altContext = elementContext === 'floating' ? 'reference' : 'floating';\n  const element = elements[altBoundary ? altContext : elementContext];\n  const clippingClientRect = rectToClientRect(await platform.getClippingRect({\n    element: ((_await$platform$isEle = await (platform.isElement == null ? void 0 : platform.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || (await (platform.getDocumentElement == null ? void 0 : platform.getDocumentElement(elements.floating))),\n    boundary,\n    rootBoundary,\n    strategy\n  }));\n  const rect = elementContext === 'floating' ? {\n    ...rects.floating,\n    x,\n    y\n  } : rects.reference;\n  const offsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating));\n  const offsetScale = (await (platform.isElement == null ? void 0 : platform.isElement(offsetParent))) ? (await (platform.getScale == null ? void 0 : platform.getScale(offsetParent))) || {\n    x: 1,\n    y: 1\n  } : {\n    x: 1,\n    y: 1\n  };\n  const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({\n    rect,\n    offsetParent,\n    strategy\n  }) : rect);\n  return {\n    top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y,\n    bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y,\n    left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x,\n    right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x\n  };\n}\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = options => ({\n  name: 'arrow',\n  options,\n  async fn(state) {\n    const {\n      x,\n      y,\n      placement,\n      rects,\n      platform,\n      elements\n    } = state;\n    // Since `element` is required, we don't Partial<> the type.\n    const {\n      element,\n      padding = 0\n    } = evaluate(options, state) || {};\n    if (element == null) {\n      return {};\n    }\n    const paddingObject = getPaddingObject(padding);\n    const coords = {\n      x,\n      y\n    };\n    const axis = getAlignmentAxis(placement);\n    const length = getAxisLength(axis);\n    const arrowDimensions = await platform.getDimensions(element);\n    const isYAxis = axis === 'y';\n    const minProp = isYAxis ? 'top' : 'left';\n    const maxProp = isYAxis ? 'bottom' : 'right';\n    const clientProp = isYAxis ? 'clientHeight' : 'clientWidth';\n    const endDiff = rects.reference[length] + rects.reference[axis] - coords[axis] - rects.floating[length];\n    const startDiff = coords[axis] - rects.reference[axis];\n    const arrowOffsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(element));\n    let clientSize = arrowOffsetParent ? arrowOffsetParent[clientProp] : 0;\n\n    // DOM platform can return `window` as the `offsetParent`.\n    if (!clientSize || !(await (platform.isElement == null ? void 0 : platform.isElement(arrowOffsetParent)))) {\n      clientSize = elements.floating[clientProp] || rects.floating[length];\n    }\n    const centerToReference = endDiff / 2 - startDiff / 2;\n\n    // If the padding is large enough that it causes the arrow to no longer be\n    // centered, modify the padding so that it is centered.\n    const largestPossiblePadding = clientSize / 2 - arrowDimensions[length] / 2 - 1;\n    const minPadding = min(paddingObject[minProp], largestPossiblePadding);\n    const maxPadding = min(paddingObject[maxProp], largestPossiblePadding);\n\n    // Make sure the arrow doesn't overflow the floating element if the center\n    // point is outside the floating element's bounds.\n    const min$1 = minPadding;\n    const max = clientSize - arrowDimensions[length] - maxPadding;\n    const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;\n    const offset = clamp(min$1, center, max);\n\n    // If the reference is small enough that the arrow's padding causes it to\n    // to point to nothing for an aligned placement, adjust the offset of the\n    // floating element itself. This stops `shift()` from taking action, but can\n    // be worked around by calling it again after the `arrow()` if desired.\n    const shouldAddOffset = getAlignment(placement) != null && center != offset && rects.reference[length] / 2 - (center < min$1 ? minPadding : maxPadding) - arrowDimensions[length] / 2 < 0;\n    const alignmentOffset = shouldAddOffset ? center < min$1 ? min$1 - center : max - center : 0;\n    return {\n      [axis]: coords[axis] - alignmentOffset,\n      data: {\n        [axis]: offset,\n        centerOffset: center - offset + alignmentOffset\n      }\n    };\n  }\n});\n\nfunction getPlacementList(alignment, autoAlignment, allowedPlacements) {\n  const allowedPlacementsSortedByAlignment = alignment ? [...allowedPlacements.filter(placement => getAlignment(placement) === alignment), ...allowedPlacements.filter(placement => getAlignment(placement) !== alignment)] : allowedPlacements.filter(placement => getSide(placement) === placement);\n  return allowedPlacementsSortedByAlignment.filter(placement => {\n    if (alignment) {\n      return getAlignment(placement) === alignment || (autoAlignment ? getOppositeAlignmentPlacement(placement) !== placement : false);\n    }\n    return true;\n  });\n}\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'autoPlacement',\n    options,\n    async fn(state) {\n      var _middlewareData$autoP, _middlewareData$autoP2, _placementsThatFitOnE;\n      const {\n        rects,\n        middlewareData,\n        placement,\n        platform,\n        elements\n      } = state;\n      const {\n        crossAxis = false,\n        alignment,\n        allowedPlacements = placements,\n        autoAlignment = true,\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      const placements$1 = alignment !== undefined || allowedPlacements === placements ? getPlacementList(alignment || null, autoAlignment, allowedPlacements) : allowedPlacements;\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const currentIndex = ((_middlewareData$autoP = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP.index) || 0;\n      const currentPlacement = placements$1[currentIndex];\n      if (currentPlacement == null) {\n        return {};\n      }\n      const alignmentSides = getAlignmentSides(currentPlacement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));\n\n      // Make `computeCoords` start from the right place.\n      if (placement !== currentPlacement) {\n        return {\n          reset: {\n            placement: placements$1[0]\n          }\n        };\n      }\n      const currentOverflows = [overflow[getSide(currentPlacement)], overflow[alignmentSides[0]], overflow[alignmentSides[1]]];\n      const allOverflows = [...(((_middlewareData$autoP2 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP2.overflows) || []), {\n        placement: currentPlacement,\n        overflows: currentOverflows\n      }];\n      const nextPlacement = placements$1[currentIndex + 1];\n\n      // There are more placements to check.\n      if (nextPlacement) {\n        return {\n          data: {\n            index: currentIndex + 1,\n            overflows: allOverflows\n          },\n          reset: {\n            placement: nextPlacement\n          }\n        };\n      }\n      const placementsSortedByMostSpace = allOverflows.map(d => {\n        const alignment = getAlignment(d.placement);\n        return [d.placement, alignment && crossAxis ?\n        // Check along the mainAxis and main crossAxis side.\n        d.overflows.slice(0, 2).reduce((acc, v) => acc + v, 0) :\n        // Check only the mainAxis.\n        d.overflows[0], d.overflows];\n      }).sort((a, b) => a[1] - b[1]);\n      const placementsThatFitOnEachSide = placementsSortedByMostSpace.filter(d => d[2].slice(0,\n      // Aligned placements should not check their opposite crossAxis\n      // side.\n      getAlignment(d[0]) ? 2 : 3).every(v => v <= 0));\n      const resetPlacement = ((_placementsThatFitOnE = placementsThatFitOnEachSide[0]) == null ? void 0 : _placementsThatFitOnE[0]) || placementsSortedByMostSpace[0][0];\n      if (resetPlacement !== placement) {\n        return {\n          data: {\n            index: currentIndex + 1,\n            overflows: allOverflows\n          },\n          reset: {\n            placement: resetPlacement\n          }\n        };\n      }\n      return {};\n    }\n  };\n};\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'flip',\n    options,\n    async fn(state) {\n      var _middlewareData$flip;\n      const {\n        placement,\n        middlewareData,\n        rects,\n        initialPlacement,\n        platform,\n        elements\n      } = state;\n      const {\n        mainAxis: checkMainAxis = true,\n        crossAxis: checkCrossAxis = true,\n        fallbackPlacements: specifiedFallbackPlacements,\n        fallbackStrategy = 'bestFit',\n        fallbackAxisSideDirection = 'none',\n        flipAlignment = true,\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      const side = getSide(placement);\n      const isBasePlacement = getSide(initialPlacement) === initialPlacement;\n      const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n      const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));\n      if (!specifiedFallbackPlacements && fallbackAxisSideDirection !== 'none') {\n        fallbackPlacements.push(...getOppositeAxisPlacements(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl));\n      }\n      const placements = [initialPlacement, ...fallbackPlacements];\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const overflows = [];\n      let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];\n      if (checkMainAxis) {\n        overflows.push(overflow[side]);\n      }\n      if (checkCrossAxis) {\n        const sides = getAlignmentSides(placement, rects, rtl);\n        overflows.push(overflow[sides[0]], overflow[sides[1]]);\n      }\n      overflowsData = [...overflowsData, {\n        placement,\n        overflows\n      }];\n\n      // One or more sides is overflowing.\n      if (!overflows.every(side => side <= 0)) {\n        var _middlewareData$flip2, _overflowsData$filter;\n        const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1;\n        const nextPlacement = placements[nextIndex];\n        if (nextPlacement) {\n          // Try next placement and re-run the lifecycle.\n          return {\n            data: {\n              index: nextIndex,\n              overflows: overflowsData\n            },\n            reset: {\n              placement: nextPlacement\n            }\n          };\n        }\n\n        // First, find the candidates that fit on the mainAxis side of overflow,\n        // then find the placement that fits the best on the main crossAxis side.\n        let resetPlacement = (_overflowsData$filter = overflowsData.filter(d => d.overflows[0] <= 0).sort((a, b) => a.overflows[1] - b.overflows[1])[0]) == null ? void 0 : _overflowsData$filter.placement;\n\n        // Otherwise fallback.\n        if (!resetPlacement) {\n          switch (fallbackStrategy) {\n            case 'bestFit':\n              {\n                var _overflowsData$map$so;\n                const placement = (_overflowsData$map$so = overflowsData.map(d => [d.placement, d.overflows.filter(overflow => overflow > 0).reduce((acc, overflow) => acc + overflow, 0)]).sort((a, b) => a[1] - b[1])[0]) == null ? void 0 : _overflowsData$map$so[0];\n                if (placement) {\n                  resetPlacement = placement;\n                }\n                break;\n              }\n            case 'initialPlacement':\n              resetPlacement = initialPlacement;\n              break;\n          }\n        }\n        if (placement !== resetPlacement) {\n          return {\n            reset: {\n              placement: resetPlacement\n            }\n          };\n        }\n      }\n      return {};\n    }\n  };\n};\n\nfunction getSideOffsets(overflow, rect) {\n  return {\n    top: overflow.top - rect.height,\n    right: overflow.right - rect.width,\n    bottom: overflow.bottom - rect.height,\n    left: overflow.left - rect.width\n  };\n}\nfunction isAnySideFullyClipped(overflow) {\n  return sides.some(side => overflow[side] >= 0);\n}\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'hide',\n    options,\n    async fn(state) {\n      const {\n        rects\n      } = state;\n      const {\n        strategy = 'referenceHidden',\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      switch (strategy) {\n        case 'referenceHidden':\n          {\n            const overflow = await detectOverflow(state, {\n              ...detectOverflowOptions,\n              elementContext: 'reference'\n            });\n            const offsets = getSideOffsets(overflow, rects.reference);\n            return {\n              data: {\n                referenceHiddenOffsets: offsets,\n                referenceHidden: isAnySideFullyClipped(offsets)\n              }\n            };\n          }\n        case 'escaped':\n          {\n            const overflow = await detectOverflow(state, {\n              ...detectOverflowOptions,\n              altBoundary: true\n            });\n            const offsets = getSideOffsets(overflow, rects.floating);\n            return {\n              data: {\n                escapedOffsets: offsets,\n                escaped: isAnySideFullyClipped(offsets)\n              }\n            };\n          }\n        default:\n          {\n            return {};\n          }\n      }\n    }\n  };\n};\n\nfunction getBoundingRect(rects) {\n  const minX = min(...rects.map(rect => rect.left));\n  const minY = min(...rects.map(rect => rect.top));\n  const maxX = max(...rects.map(rect => rect.right));\n  const maxY = max(...rects.map(rect => rect.bottom));\n  return {\n    x: minX,\n    y: minY,\n    width: maxX - minX,\n    height: maxY - minY\n  };\n}\nfunction getRectsByLine(rects) {\n  const sortedRects = rects.slice().sort((a, b) => a.y - b.y);\n  const groups = [];\n  let prevRect = null;\n  for (let i = 0; i < sortedRects.length; i++) {\n    const rect = sortedRects[i];\n    if (!prevRect || rect.y - prevRect.y > prevRect.height / 2) {\n      groups.push([rect]);\n    } else {\n      groups[groups.length - 1].push(rect);\n    }\n    prevRect = rect;\n  }\n  return groups.map(rect => rectToClientRect(getBoundingRect(rect)));\n}\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'inline',\n    options,\n    async fn(state) {\n      const {\n        placement,\n        elements,\n        rects,\n        platform,\n        strategy\n      } = state;\n      // A MouseEvent's client{X,Y} coords can be up to 2 pixels off a\n      // ClientRect's bounds, despite the event listener being triggered. A\n      // padding of 2 seems to handle this issue.\n      const {\n        padding = 2,\n        x,\n        y\n      } = evaluate(options, state);\n      const nativeClientRects = Array.from((await (platform.getClientRects == null ? void 0 : platform.getClientRects(elements.reference))) || []);\n      const clientRects = getRectsByLine(nativeClientRects);\n      const fallback = rectToClientRect(getBoundingRect(nativeClientRects));\n      const paddingObject = getPaddingObject(padding);\n      function getBoundingClientRect() {\n        // There are two rects and they are disjoined.\n        if (clientRects.length === 2 && clientRects[0].left > clientRects[1].right && x != null && y != null) {\n          // Find the first rect in which the point is fully inside.\n          return clientRects.find(rect => x > rect.left - paddingObject.left && x < rect.right + paddingObject.right && y > rect.top - paddingObject.top && y < rect.bottom + paddingObject.bottom) || fallback;\n        }\n\n        // There are 2 or more connected rects.\n        if (clientRects.length >= 2) {\n          if (getSideAxis(placement) === 'y') {\n            const firstRect = clientRects[0];\n            const lastRect = clientRects[clientRects.length - 1];\n            const isTop = getSide(placement) === 'top';\n            const top = firstRect.top;\n            const bottom = lastRect.bottom;\n            const left = isTop ? firstRect.left : lastRect.left;\n            const right = isTop ? firstRect.right : lastRect.right;\n            const width = right - left;\n            const height = bottom - top;\n            return {\n              top,\n              bottom,\n              left,\n              right,\n              width,\n              height,\n              x: left,\n              y: top\n            };\n          }\n          const isLeftSide = getSide(placement) === 'left';\n          const maxRight = max(...clientRects.map(rect => rect.right));\n          const minLeft = min(...clientRects.map(rect => rect.left));\n          const measureRects = clientRects.filter(rect => isLeftSide ? rect.left === minLeft : rect.right === maxRight);\n          const top = measureRects[0].top;\n          const bottom = measureRects[measureRects.length - 1].bottom;\n          const left = minLeft;\n          const right = maxRight;\n          const width = right - left;\n          const height = bottom - top;\n          return {\n            top,\n            bottom,\n            left,\n            right,\n            width,\n            height,\n            x: left,\n            y: top\n          };\n        }\n        return fallback;\n      }\n      const resetRects = await platform.getElementRects({\n        reference: {\n          getBoundingClientRect\n        },\n        floating: elements.floating,\n        strategy\n      });\n      if (rects.reference.x !== resetRects.reference.x || rects.reference.y !== resetRects.reference.y || rects.reference.width !== resetRects.reference.width || rects.reference.height !== resetRects.reference.height) {\n        return {\n          reset: {\n            rects: resetRects\n          }\n        };\n      }\n      return {};\n    }\n  };\n};\n\n// For type backwards-compatibility, the `OffsetOptions` type was also\n// Derivable.\nasync function convertValueToCoords(state, options) {\n  const {\n    placement,\n    platform,\n    elements\n  } = state;\n  const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n  const side = getSide(placement);\n  const alignment = getAlignment(placement);\n  const isVertical = getSideAxis(placement) === 'y';\n  const mainAxisMulti = ['left', 'top'].includes(side) ? -1 : 1;\n  const crossAxisMulti = rtl && isVertical ? -1 : 1;\n  const rawValue = evaluate(options, state);\n\n  // eslint-disable-next-line prefer-const\n  let {\n    mainAxis,\n    crossAxis,\n    alignmentAxis\n  } = typeof rawValue === 'number' ? {\n    mainAxis: rawValue,\n    crossAxis: 0,\n    alignmentAxis: null\n  } : {\n    mainAxis: 0,\n    crossAxis: 0,\n    alignmentAxis: null,\n    ...rawValue\n  };\n  if (alignment && typeof alignmentAxis === 'number') {\n    crossAxis = alignment === 'end' ? alignmentAxis * -1 : alignmentAxis;\n  }\n  return isVertical ? {\n    x: crossAxis * crossAxisMulti,\n    y: mainAxis * mainAxisMulti\n  } : {\n    x: mainAxis * mainAxisMulti,\n    y: crossAxis * crossAxisMulti\n  };\n}\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = function (options) {\n  if (options === void 0) {\n    options = 0;\n  }\n  return {\n    name: 'offset',\n    options,\n    async fn(state) {\n      const {\n        x,\n        y\n      } = state;\n      const diffCoords = await convertValueToCoords(state, options);\n      return {\n        x: x + diffCoords.x,\n        y: y + diffCoords.y,\n        data: diffCoords\n      };\n    }\n  };\n};\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'shift',\n    options,\n    async fn(state) {\n      const {\n        x,\n        y,\n        placement\n      } = state;\n      const {\n        mainAxis: checkMainAxis = true,\n        crossAxis: checkCrossAxis = false,\n        limiter = {\n          fn: _ref => {\n            let {\n              x,\n              y\n            } = _ref;\n            return {\n              x,\n              y\n            };\n          }\n        },\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      const coords = {\n        x,\n        y\n      };\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const crossAxis = getSideAxis(getSide(placement));\n      const mainAxis = getOppositeAxis(crossAxis);\n      let mainAxisCoord = coords[mainAxis];\n      let crossAxisCoord = coords[crossAxis];\n      if (checkMainAxis) {\n        const minSide = mainAxis === 'y' ? 'top' : 'left';\n        const maxSide = mainAxis === 'y' ? 'bottom' : 'right';\n        const min = mainAxisCoord + overflow[minSide];\n        const max = mainAxisCoord - overflow[maxSide];\n        mainAxisCoord = clamp(min, mainAxisCoord, max);\n      }\n      if (checkCrossAxis) {\n        const minSide = crossAxis === 'y' ? 'top' : 'left';\n        const maxSide = crossAxis === 'y' ? 'bottom' : 'right';\n        const min = crossAxisCoord + overflow[minSide];\n        const max = crossAxisCoord - overflow[maxSide];\n        crossAxisCoord = clamp(min, crossAxisCoord, max);\n      }\n      const limitedCoords = limiter.fn({\n        ...state,\n        [mainAxis]: mainAxisCoord,\n        [crossAxis]: crossAxisCoord\n      });\n      return {\n        ...limitedCoords,\n        data: {\n          x: limitedCoords.x - x,\n          y: limitedCoords.y - y\n        }\n      };\n    }\n  };\n};\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    options,\n    fn(state) {\n      const {\n        x,\n        y,\n        placement,\n        rects,\n        middlewareData\n      } = state;\n      const {\n        offset = 0,\n        mainAxis: checkMainAxis = true,\n        crossAxis: checkCrossAxis = true\n      } = evaluate(options, state);\n      const coords = {\n        x,\n        y\n      };\n      const crossAxis = getSideAxis(placement);\n      const mainAxis = getOppositeAxis(crossAxis);\n      let mainAxisCoord = coords[mainAxis];\n      let crossAxisCoord = coords[crossAxis];\n      const rawOffset = evaluate(offset, state);\n      const computedOffset = typeof rawOffset === 'number' ? {\n        mainAxis: rawOffset,\n        crossAxis: 0\n      } : {\n        mainAxis: 0,\n        crossAxis: 0,\n        ...rawOffset\n      };\n      if (checkMainAxis) {\n        const len = mainAxis === 'y' ? 'height' : 'width';\n        const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis;\n        const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis;\n        if (mainAxisCoord < limitMin) {\n          mainAxisCoord = limitMin;\n        } else if (mainAxisCoord > limitMax) {\n          mainAxisCoord = limitMax;\n        }\n      }\n      if (checkCrossAxis) {\n        var _middlewareData$offse, _middlewareData$offse2;\n        const len = mainAxis === 'y' ? 'width' : 'height';\n        const isOriginSide = ['top', 'left'].includes(getSide(placement));\n        const limitMin = rects.reference[crossAxis] - rects.floating[len] + (isOriginSide ? ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse[crossAxis]) || 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis);\n        const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : ((_middlewareData$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) || 0) - (isOriginSide ? computedOffset.crossAxis : 0);\n        if (crossAxisCoord < limitMin) {\n          crossAxisCoord = limitMin;\n        } else if (crossAxisCoord > limitMax) {\n          crossAxisCoord = limitMax;\n        }\n      }\n      return {\n        [mainAxis]: mainAxisCoord,\n        [crossAxis]: crossAxisCoord\n      };\n    }\n  };\n};\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'size',\n    options,\n    async fn(state) {\n      const {\n        placement,\n        rects,\n        platform,\n        elements\n      } = state;\n      const {\n        apply = () => {},\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const side = getSide(placement);\n      const alignment = getAlignment(placement);\n      const isYAxis = getSideAxis(placement) === 'y';\n      const {\n        width,\n        height\n      } = rects.floating;\n      let heightSide;\n      let widthSide;\n      if (side === 'top' || side === 'bottom') {\n        heightSide = side;\n        widthSide = alignment === ((await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating))) ? 'start' : 'end') ? 'left' : 'right';\n      } else {\n        widthSide = side;\n        heightSide = alignment === 'end' ? 'top' : 'bottom';\n      }\n      const overflowAvailableHeight = height - overflow[heightSide];\n      const overflowAvailableWidth = width - overflow[widthSide];\n      const noShift = !state.middlewareData.shift;\n      let availableHeight = overflowAvailableHeight;\n      let availableWidth = overflowAvailableWidth;\n      if (isYAxis) {\n        const maximumClippingWidth = width - overflow.left - overflow.right;\n        availableWidth = alignment || noShift ? min(overflowAvailableWidth, maximumClippingWidth) : maximumClippingWidth;\n      } else {\n        const maximumClippingHeight = height - overflow.top - overflow.bottom;\n        availableHeight = alignment || noShift ? min(overflowAvailableHeight, maximumClippingHeight) : maximumClippingHeight;\n      }\n      if (noShift && !alignment) {\n        const xMin = max(overflow.left, 0);\n        const xMax = max(overflow.right, 0);\n        const yMin = max(overflow.top, 0);\n        const yMax = max(overflow.bottom, 0);\n        if (isYAxis) {\n          availableWidth = width - 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max(overflow.left, overflow.right));\n        } else {\n          availableHeight = height - 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max(overflow.top, overflow.bottom));\n        }\n      }\n      await apply({\n        ...state,\n        availableWidth,\n        availableHeight\n      });\n      const nextDimensions = await platform.getDimensions(elements.floating);\n      if (width !== nextDimensions.width || height !== nextDimensions.height) {\n        return {\n          reset: {\n            rects: true\n          }\n        };\n      }\n      return {};\n    }\n  };\n};\n\nexport { arrow, autoPlacement, computePosition, detectOverflow, flip, hide, inline, limitShift, offset, shift, size };\n"],"names":["getSideAxis","getAlignmentAxis","getAxisLength","getSide","getAlignment","evaluate","getPaddingObject","rectToClientRect","min","clamp","placements","getAlignmentSides","getOppositeAlignmentPlacement","getOppositePlacement","getExpandedPlacements","getOppositeAxisPlacements","sides","max","getOppositeAxis","computeCoordsFromPlacement","_ref","placement","rtl","reference","floating","sideAxis","alignmentAxis","alignLength","side","isVertical","commonX","x","width","commonY","y","height","commonAlign","coords","computePosition","config","strategy","middleware","platform","validMiddleware","filter","Boolean","isRTL","rects","getElementRects","statefulPlacement","middlewareData","resetCount","i","length","name","fn","nextX","nextY","data","reset","initialPlacement","elements","detectOverflow","state","options","_await$platform$isEle","boundary","rootBoundary","elementContext","altBoundary","padding","paddingObject","altContext","element","clippingClientRect","getClippingRect","isElement","contextElement","getDocumentElement","rect","offsetParent","getOffsetParent","offsetScale","getScale","elementClientRect","convertOffsetParentRelativeRectToViewportRelativeRect","top","bottom","left","right","arrow","axis","arrowDimensions","getDimensions","isYAxis","minProp","maxProp","clientProp","endDiff","startDiff","arrowOffsetParent","clientSize","centerToReference","largestPossiblePadding","minPadding","maxPadding","min$1","center","offset","shouldAddOffset","alignmentOffset","centerOffset","getPlacementList","alignment","autoAlignment","allowedPlacements","allowedPlacementsSortedByAlignment","autoPlacement","_middlewareData$autoP","_middlewareData$autoP2","_placementsThatFitOnE","crossAxis","detectOverflowOptions","placements$1","undefined","overflow","currentIndex","index","currentPlacement","alignmentSides","currentOverflows","allOverflows","overflows","nextPlacement","placementsSortedByMostSpace","map","d","slice","reduce","acc","v","sort","a","b","placementsThatFitOnEachSide","every","resetPlacement","flip","_middlewareData$flip","mainAxis","checkMainAxis","checkCrossAxis","fallbackPlacements","specifiedFallbackPlacements","fallbackStrategy","fallbackAxisSideDirection","flipAlignment","isBasePlacement","push","overflowsData","_middlewareData$flip2","_overflowsData$filter","nextIndex","_overflowsData$map$so","getSideOffsets","isAnySideFullyClipped","some","hide","offsets","referenceHiddenOffsets","referenceHidden","escapedOffsets","escaped","getBoundingRect","minX","minY","maxX","maxY","getRectsByLine","sortedRects","groups","prevRect","inline","nativeClientRects","Array","from","getClientRects","clientRects","fallback","getBoundingClientRect","find","firstRect","lastRect","isTop","isLeftSide","maxRight","minLeft","measureRects","resetRects","convertValueToCoords","mainAxisMulti","includes","crossAxisMulti","rawValue","diffCoords","shift","limiter","mainAxisCoord","crossAxisCoord","minSide","maxSide","limitedCoords","limitShift","rawOffset","computedOffset","len","limitMin","limitMax","_middlewareData$offse","_middlewareData$offse2","isOriginSide","size","apply","heightSide","widthSide","overflowAvailableHeight","overflowAvailableWidth","noShift","availableHeight","availableWidth","maximumClippingWidth","maximumClippingHeight","xMin","xMax","yMin","yMax","nextDimensions"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@floating-ui/core/dist/floating-ui.core.mjs\n"); /***/ }), /***/ "(ssr)/./node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs": /*!****************************************************************!*\ !*** ./node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs ***! \****************************************************************/ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ arrow: () => (/* reexport safe */ _floating_ui_core__WEBPACK_IMPORTED_MODULE_0__.arrow),\n/* harmony export */ autoPlacement: () => (/* reexport safe */ _floating_ui_core__WEBPACK_IMPORTED_MODULE_0__.autoPlacement),\n/* harmony export */ autoUpdate: () => (/* binding */ autoUpdate),\n/* harmony export */ computePosition: () => (/* binding */ computePosition),\n/* harmony export */ detectOverflow: () => (/* reexport safe */ _floating_ui_core__WEBPACK_IMPORTED_MODULE_0__.detectOverflow),\n/* harmony export */ flip: () => (/* reexport safe */ _floating_ui_core__WEBPACK_IMPORTED_MODULE_0__.flip),\n/* harmony export */ getOverflowAncestors: () => (/* reexport safe */ _floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getOverflowAncestors),\n/* harmony export */ hide: () => (/* reexport safe */ _floating_ui_core__WEBPACK_IMPORTED_MODULE_0__.hide),\n/* harmony export */ inline: () => (/* reexport safe */ _floating_ui_core__WEBPACK_IMPORTED_MODULE_0__.inline),\n/* harmony export */ limitShift: () => (/* reexport safe */ _floating_ui_core__WEBPACK_IMPORTED_MODULE_0__.limitShift),\n/* harmony export */ offset: () => (/* reexport safe */ _floating_ui_core__WEBPACK_IMPORTED_MODULE_0__.offset),\n/* harmony export */ platform: () => (/* binding */ platform),\n/* harmony export */ shift: () => (/* reexport safe */ _floating_ui_core__WEBPACK_IMPORTED_MODULE_0__.shift),\n/* harmony export */ size: () => (/* reexport safe */ _floating_ui_core__WEBPACK_IMPORTED_MODULE_0__.size)\n/* harmony export */ });\n/* harmony import */ var _floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @floating-ui/utils */ \"(ssr)/./node_modules/@floating-ui/utils/dist/floating-ui.utils.mjs\");\n/* harmony import */ var _floating_ui_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @floating-ui/core */ \"(ssr)/./node_modules/@floating-ui/core/dist/floating-ui.core.mjs\");\n/* harmony import */ var _floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @floating-ui/utils/dom */ \"(ssr)/./node_modules/@floating-ui/utils/dom/dist/floating-ui.utils.dom.mjs\");\n\n\n\n\n\nfunction getCssDimensions(element) {\n const css = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getComputedStyle)(element);\n // In testing environments, the `width` and `height` properties are empty\n // strings for SVG elements, returning NaN. Fallback to `0` in this case.\n let width = parseFloat(css.width) || 0;\n let height = parseFloat(css.height) || 0;\n const hasOffset = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isHTMLElement)(element);\n const offsetWidth = hasOffset ? element.offsetWidth : width;\n const offsetHeight = hasOffset ? element.offsetHeight : height;\n const shouldFallback = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.round)(width) !== offsetWidth || (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.round)(height) !== offsetHeight;\n if (shouldFallback) {\n width = offsetWidth;\n height = offsetHeight;\n }\n return {\n width,\n height,\n $: shouldFallback\n };\n}\nfunction unwrapElement(element) {\n return !(0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isElement)(element) ? element.contextElement : element;\n}\nfunction getScale(element) {\n const domElement = unwrapElement(element);\n if (!(0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isHTMLElement)(domElement)) {\n return (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.createCoords)(1);\n }\n const rect = domElement.getBoundingClientRect();\n const { width, height, $ } = getCssDimensions(domElement);\n let x = ($ ? (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.round)(rect.width) : rect.width) / width;\n let y = ($ ? (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.round)(rect.height) : rect.height) / height;\n // 0, NaN, or Infinity should always fallback to 1.\n if (!x || !Number.isFinite(x)) {\n x = 1;\n }\n if (!y || !Number.isFinite(y)) {\n y = 1;\n }\n return {\n x,\n y\n };\n}\nconst noOffsets = /*#__PURE__*/ (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.createCoords)(0);\nfunction getVisualOffsets(element) {\n const win = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getWindow)(element);\n if (!(0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isWebKit)() || !win.visualViewport) {\n return noOffsets;\n }\n return {\n x: win.visualViewport.offsetLeft,\n y: win.visualViewport.offsetTop\n };\n}\nfunction shouldAddVisualOffsets(element, isFixed, floatingOffsetParent) {\n if (isFixed === void 0) {\n isFixed = false;\n }\n if (!floatingOffsetParent || isFixed && floatingOffsetParent !== (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getWindow)(element)) {\n return false;\n }\n return isFixed;\n}\nfunction getBoundingClientRect(element, includeScale, isFixedStrategy, offsetParent) {\n if (includeScale === void 0) {\n includeScale = false;\n }\n if (isFixedStrategy === void 0) {\n isFixedStrategy = false;\n }\n const clientRect = element.getBoundingClientRect();\n const domElement = unwrapElement(element);\n let scale = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.createCoords)(1);\n if (includeScale) {\n if (offsetParent) {\n if ((0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isElement)(offsetParent)) {\n scale = getScale(offsetParent);\n }\n } else {\n scale = getScale(element);\n }\n }\n const visualOffsets = shouldAddVisualOffsets(domElement, isFixedStrategy, offsetParent) ? getVisualOffsets(domElement) : (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.createCoords)(0);\n let x = (clientRect.left + visualOffsets.x) / scale.x;\n let y = (clientRect.top + visualOffsets.y) / scale.y;\n let width = clientRect.width / scale.x;\n let height = clientRect.height / scale.y;\n if (domElement) {\n const win = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getWindow)(domElement);\n const offsetWin = offsetParent && (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isElement)(offsetParent) ? (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getWindow)(offsetParent) : offsetParent;\n let currentIFrame = win.frameElement;\n while(currentIFrame && offsetParent && offsetWin !== win){\n const iframeScale = getScale(currentIFrame);\n const iframeRect = currentIFrame.getBoundingClientRect();\n const css = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getComputedStyle)(currentIFrame);\n const left = iframeRect.left + (currentIFrame.clientLeft + parseFloat(css.paddingLeft)) * iframeScale.x;\n const top = iframeRect.top + (currentIFrame.clientTop + parseFloat(css.paddingTop)) * iframeScale.y;\n x *= iframeScale.x;\n y *= iframeScale.y;\n width *= iframeScale.x;\n height *= iframeScale.y;\n x += left;\n y += top;\n currentIFrame = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getWindow)(currentIFrame).frameElement;\n }\n }\n return (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.rectToClientRect)({\n width,\n height,\n x,\n y\n });\n}\nfunction convertOffsetParentRelativeRectToViewportRelativeRect(_ref) {\n let { rect, offsetParent, strategy } = _ref;\n const isOffsetParentAnElement = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isHTMLElement)(offsetParent);\n const documentElement = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getDocumentElement)(offsetParent);\n if (offsetParent === documentElement) {\n return rect;\n }\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n let scale = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.createCoords)(1);\n const offsets = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.createCoords)(0);\n if (isOffsetParentAnElement || !isOffsetParentAnElement && strategy !== \"fixed\") {\n if ((0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getNodeName)(offsetParent) !== \"body\" || (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isOverflowElement)(documentElement)) {\n scroll = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getNodeScroll)(offsetParent);\n }\n if ((0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isHTMLElement)(offsetParent)) {\n const offsetRect = getBoundingClientRect(offsetParent);\n scale = getScale(offsetParent);\n offsets.x = offsetRect.x + offsetParent.clientLeft;\n offsets.y = offsetRect.y + offsetParent.clientTop;\n }\n }\n return {\n width: rect.width * scale.x,\n height: rect.height * scale.y,\n x: rect.x * scale.x - scroll.scrollLeft * scale.x + offsets.x,\n y: rect.y * scale.y - scroll.scrollTop * scale.y + offsets.y\n };\n}\nfunction getClientRects(element) {\n return Array.from(element.getClientRects());\n}\nfunction getWindowScrollBarX(element) {\n // If has a CSS width greater than the viewport, then this will be\n // incorrect for RTL.\n return getBoundingClientRect((0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getDocumentElement)(element)).left + (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getNodeScroll)(element).scrollLeft;\n}\n// Gets the entire size of the scrollable document area, even extending outside\n// of the `` and `` rect bounds if horizontally scrollable.\nfunction getDocumentRect(element) {\n const html = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getDocumentElement)(element);\n const scroll = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getNodeScroll)(element);\n const body = element.ownerDocument.body;\n const width = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.max)(html.scrollWidth, html.clientWidth, body.scrollWidth, body.clientWidth);\n const height = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.max)(html.scrollHeight, html.clientHeight, body.scrollHeight, body.clientHeight);\n let x = -scroll.scrollLeft + getWindowScrollBarX(element);\n const y = -scroll.scrollTop;\n if ((0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getComputedStyle)(body).direction === \"rtl\") {\n x += (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.max)(html.clientWidth, body.clientWidth) - width;\n }\n return {\n width,\n height,\n x,\n y\n };\n}\nfunction getViewportRect(element, strategy) {\n const win = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getWindow)(element);\n const html = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getDocumentElement)(element);\n const visualViewport = win.visualViewport;\n let width = html.clientWidth;\n let height = html.clientHeight;\n let x = 0;\n let y = 0;\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n const visualViewportBased = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isWebKit)();\n if (!visualViewportBased || visualViewportBased && strategy === \"fixed\") {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n return {\n width,\n height,\n x,\n y\n };\n}\n// Returns the inner client rect, subtracting scrollbars if present.\nfunction getInnerBoundingClientRect(element, strategy) {\n const clientRect = getBoundingClientRect(element, true, strategy === \"fixed\");\n const top = clientRect.top + element.clientTop;\n const left = clientRect.left + element.clientLeft;\n const scale = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isHTMLElement)(element) ? getScale(element) : (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.createCoords)(1);\n const width = element.clientWidth * scale.x;\n const height = element.clientHeight * scale.y;\n const x = left * scale.x;\n const y = top * scale.y;\n return {\n width,\n height,\n x,\n y\n };\n}\nfunction getClientRectFromClippingAncestor(element, clippingAncestor, strategy) {\n let rect;\n if (clippingAncestor === \"viewport\") {\n rect = getViewportRect(element, strategy);\n } else if (clippingAncestor === \"document\") {\n rect = getDocumentRect((0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getDocumentElement)(element));\n } else if ((0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isElement)(clippingAncestor)) {\n rect = getInnerBoundingClientRect(clippingAncestor, strategy);\n } else {\n const visualOffsets = getVisualOffsets(element);\n rect = {\n ...clippingAncestor,\n x: clippingAncestor.x - visualOffsets.x,\n y: clippingAncestor.y - visualOffsets.y\n };\n }\n return (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.rectToClientRect)(rect);\n}\nfunction hasFixedPositionAncestor(element, stopNode) {\n const parentNode = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getParentNode)(element);\n if (parentNode === stopNode || !(0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isElement)(parentNode) || (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isLastTraversableNode)(parentNode)) {\n return false;\n }\n return (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getComputedStyle)(parentNode).position === \"fixed\" || hasFixedPositionAncestor(parentNode, stopNode);\n}\n// A \"clipping ancestor\" is an `overflow` element with the characteristic of\n// clipping (or hiding) child elements. This returns all clipping ancestors\n// of the given element up the tree.\nfunction getClippingElementAncestors(element, cache) {\n const cachedResult = cache.get(element);\n if (cachedResult) {\n return cachedResult;\n }\n let result = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getOverflowAncestors)(element).filter((el)=>(0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isElement)(el) && (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getNodeName)(el) !== \"body\");\n let currentContainingBlockComputedStyle = null;\n const elementIsFixed = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getComputedStyle)(element).position === \"fixed\";\n let currentNode = elementIsFixed ? (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getParentNode)(element) : element;\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n while((0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isElement)(currentNode) && !(0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isLastTraversableNode)(currentNode)){\n const computedStyle = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getComputedStyle)(currentNode);\n const currentNodeIsContaining = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isContainingBlock)(currentNode);\n if (!currentNodeIsContaining && computedStyle.position === \"fixed\") {\n currentContainingBlockComputedStyle = null;\n }\n const shouldDropCurrentNode = elementIsFixed ? !currentNodeIsContaining && !currentContainingBlockComputedStyle : !currentNodeIsContaining && computedStyle.position === \"static\" && !!currentContainingBlockComputedStyle && [\n \"absolute\",\n \"fixed\"\n ].includes(currentContainingBlockComputedStyle.position) || (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isOverflowElement)(currentNode) && !currentNodeIsContaining && hasFixedPositionAncestor(element, currentNode);\n if (shouldDropCurrentNode) {\n // Drop non-containing blocks.\n result = result.filter((ancestor)=>ancestor !== currentNode);\n } else {\n // Record last containing block for next iteration.\n currentContainingBlockComputedStyle = computedStyle;\n }\n currentNode = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getParentNode)(currentNode);\n }\n cache.set(element, result);\n return result;\n}\n// Gets the maximum area that the element is visible in due to any number of\n// clipping ancestors.\nfunction getClippingRect(_ref) {\n let { element, boundary, rootBoundary, strategy } = _ref;\n const elementClippingAncestors = boundary === \"clippingAncestors\" ? getClippingElementAncestors(element, this._c) : [].concat(boundary);\n const clippingAncestors = [\n ...elementClippingAncestors,\n rootBoundary\n ];\n const firstClippingAncestor = clippingAncestors[0];\n const clippingRect = clippingAncestors.reduce((accRect, clippingAncestor)=>{\n const rect = getClientRectFromClippingAncestor(element, clippingAncestor, strategy);\n accRect.top = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.max)(rect.top, accRect.top);\n accRect.right = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.min)(rect.right, accRect.right);\n accRect.bottom = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.min)(rect.bottom, accRect.bottom);\n accRect.left = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.max)(rect.left, accRect.left);\n return accRect;\n }, getClientRectFromClippingAncestor(element, firstClippingAncestor, strategy));\n return {\n width: clippingRect.right - clippingRect.left,\n height: clippingRect.bottom - clippingRect.top,\n x: clippingRect.left,\n y: clippingRect.top\n };\n}\nfunction getDimensions(element) {\n return getCssDimensions(element);\n}\nfunction getRectRelativeToOffsetParent(element, offsetParent, strategy) {\n const isOffsetParentAnElement = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isHTMLElement)(offsetParent);\n const documentElement = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getDocumentElement)(offsetParent);\n const isFixed = strategy === \"fixed\";\n const rect = getBoundingClientRect(element, true, isFixed, offsetParent);\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n const offsets = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.createCoords)(0);\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if ((0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getNodeName)(offsetParent) !== \"body\" || (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isOverflowElement)(documentElement)) {\n scroll = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getNodeScroll)(offsetParent);\n }\n if (isOffsetParentAnElement) {\n const offsetRect = getBoundingClientRect(offsetParent, true, isFixed, offsetParent);\n offsets.x = offsetRect.x + offsetParent.clientLeft;\n offsets.y = offsetRect.y + offsetParent.clientTop;\n } else if (documentElement) {\n offsets.x = getWindowScrollBarX(documentElement);\n }\n }\n return {\n x: rect.left + scroll.scrollLeft - offsets.x,\n y: rect.top + scroll.scrollTop - offsets.y,\n width: rect.width,\n height: rect.height\n };\n}\nfunction getTrueOffsetParent(element, polyfill) {\n if (!(0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isHTMLElement)(element) || (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getComputedStyle)(element).position === \"fixed\") {\n return null;\n }\n if (polyfill) {\n return polyfill(element);\n }\n return element.offsetParent;\n}\n// Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\nfunction getOffsetParent(element, polyfill) {\n const window = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getWindow)(element);\n if (!(0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isHTMLElement)(element)) {\n return window;\n }\n let offsetParent = getTrueOffsetParent(element, polyfill);\n while(offsetParent && (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isTableElement)(offsetParent) && (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getComputedStyle)(offsetParent).position === \"static\"){\n offsetParent = getTrueOffsetParent(offsetParent, polyfill);\n }\n if (offsetParent && ((0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getNodeName)(offsetParent) === \"html\" || (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getNodeName)(offsetParent) === \"body\" && (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getComputedStyle)(offsetParent).position === \"static\" && !(0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isContainingBlock)(offsetParent))) {\n return window;\n }\n return offsetParent || (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getContainingBlock)(element) || window;\n}\nconst getElementRects = async function(_ref) {\n let { reference, floating, strategy } = _ref;\n const getOffsetParentFn = this.getOffsetParent || getOffsetParent;\n const getDimensionsFn = this.getDimensions;\n return {\n reference: getRectRelativeToOffsetParent(reference, await getOffsetParentFn(floating), strategy),\n floating: {\n x: 0,\n y: 0,\n ...await getDimensionsFn(floating)\n }\n };\n};\nfunction isRTL(element) {\n return (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getComputedStyle)(element).direction === \"rtl\";\n}\nconst platform = {\n convertOffsetParentRelativeRectToViewportRelativeRect,\n getDocumentElement: _floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getDocumentElement,\n getClippingRect,\n getOffsetParent,\n getElementRects,\n getClientRects,\n getDimensions,\n getScale,\n isElement: _floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.isElement,\n isRTL\n};\n// https://samthor.au/2021/observing-dom/\nfunction observeMove(element, onMove) {\n let io = null;\n let timeoutId;\n const root = (0,_floating_ui_utils_dom__WEBPACK_IMPORTED_MODULE_1__.getDocumentElement)(element);\n function cleanup() {\n clearTimeout(timeoutId);\n io && io.disconnect();\n io = null;\n }\n function refresh(skip, threshold) {\n if (skip === void 0) {\n skip = false;\n }\n if (threshold === void 0) {\n threshold = 1;\n }\n cleanup();\n const { left, top, width, height } = element.getBoundingClientRect();\n if (!skip) {\n onMove();\n }\n if (!width || !height) {\n return;\n }\n const insetTop = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.floor)(top);\n const insetRight = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.floor)(root.clientWidth - (left + width));\n const insetBottom = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.floor)(root.clientHeight - (top + height));\n const insetLeft = (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.floor)(left);\n const rootMargin = -insetTop + \"px \" + -insetRight + \"px \" + -insetBottom + \"px \" + -insetLeft + \"px\";\n const options = {\n rootMargin,\n threshold: (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.max)(0, (0,_floating_ui_utils__WEBPACK_IMPORTED_MODULE_2__.min)(1, threshold)) || 1\n };\n let isFirstUpdate = true;\n function handleObserve(entries) {\n const ratio = entries[0].intersectionRatio;\n if (ratio !== threshold) {\n if (!isFirstUpdate) {\n return refresh();\n }\n if (!ratio) {\n timeoutId = setTimeout(()=>{\n refresh(false, 1e-7);\n }, 100);\n } else {\n refresh(false, ratio);\n }\n }\n isFirstUpdate = false;\n }\n // Older browsers don't support a `document` as the root and will throw an\n // error.\n try {\n io = new IntersectionObserver(handleObserve, {\n ...options,\n // Handle