@nordhealth/components 1.5.1 → 1.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/custom-elements.json +5019 -4004
- package/lib/Avatar.js +1 -1
- package/lib/Badge.js +1 -1
- package/lib/Banner.js +1 -1
- package/lib/Banner.js.map +1 -1
- package/lib/Button.js +1 -1
- package/lib/Button.js.map +1 -1
- package/lib/{Calendar-a389d216.js → Calendar-a59d353e.js} +2 -2
- package/lib/{Calendar-a389d216.js.map → Calendar-a59d353e.js.map} +1 -1
- package/lib/Calendar.js +1 -1
- package/lib/Card.js +1 -1
- package/lib/Card.js.map +1 -1
- package/lib/Checkbox.js +1 -1
- package/lib/Checkbox.js.map +1 -1
- package/lib/CommandMenu.js +1 -1
- package/lib/CommandMenu.js.map +1 -1
- package/lib/CommandMenuAction.js +1 -1
- package/lib/CommandMenuAction.js.map +1 -1
- package/lib/Component-a61df53a.js +2 -0
- package/lib/Component-a61df53a.js.map +1 -0
- package/lib/DatePicker.js +1 -1
- package/lib/DatePicker.js.map +1 -1
- package/lib/DraftComponentMixin-9e4b7b34.js +2 -0
- package/lib/DraftComponentMixin-9e4b7b34.js.map +1 -0
- package/lib/Dropdown.js +1 -1
- package/lib/Dropdown.js.map +1 -1
- package/lib/DropdownGroup.js +1 -1
- package/lib/DropdownItem.js +1 -1
- package/lib/DropdownItem.js.map +1 -1
- package/lib/EmptyState.js +1 -1
- package/lib/EmptyState.js.map +1 -1
- package/lib/Fieldset.js +1 -1
- package/lib/{FocusableMixin-4c85ced9.js → FocusableMixin-175ea4d7.js} +2 -2
- package/lib/{FocusableMixin-4c85ced9.js.map → FocusableMixin-175ea4d7.js.map} +1 -1
- package/lib/{FormAssociatedMixin-9d38814c.js → FormAssociatedMixin-d3124755.js} +2 -2
- package/lib/{FormAssociatedMixin-9d38814c.js.map → FormAssociatedMixin-d3124755.js.map} +1 -1
- package/lib/{FormField-44e865a4.js → FormField-d3767c2e.js} +2 -2
- package/lib/FormField-d3767c2e.js.map +1 -0
- package/lib/Header.js +1 -1
- package/lib/Header.js.map +1 -1
- package/lib/Icon.js +1 -1
- package/lib/Input.js +1 -1
- package/lib/Input.js.map +1 -1
- package/lib/InputMixin-9334d385.js +2 -0
- package/lib/{InputMixin-84ca72ae.js.map → InputMixin-9334d385.js.map} +1 -1
- package/lib/KeyboardController.js.map +1 -1
- package/lib/Layout.js +1 -1
- package/lib/Layout.js.map +1 -1
- package/lib/{LightDomController-e0762f0d.js → LightDomController-6d26dea2.js} +2 -2
- package/lib/{LightDomController-e0762f0d.js.map → LightDomController-6d26dea2.js.map} +1 -1
- package/lib/LocalizeController.js +1 -1
- package/lib/LocalizeController.js.map +1 -1
- package/lib/Modal.js +2 -0
- package/lib/Modal.js.map +1 -0
- package/lib/NavGroup.js +1 -1
- package/lib/NavGroup.js.map +1 -1
- package/lib/NavItem.js +1 -1
- package/lib/NavItem.js.map +1 -1
- package/lib/Navigation.js +1 -1
- package/lib/Popout.js +1 -1
- package/lib/Popout.js.map +1 -1
- package/lib/ProgressBar.js +1 -1
- package/lib/Radio.js +1 -1
- package/lib/Radio.js.map +1 -1
- package/lib/Select.js +1 -1
- package/lib/ShortcutController-87615e31.js.map +1 -1
- package/lib/Skeleton.js +2 -0
- package/lib/Skeleton.js.map +1 -0
- package/lib/Spinner.js +1 -1
- package/lib/Stack.js +1 -1
- package/lib/Stack.js.map +1 -1
- package/lib/Tab.js +2 -0
- package/lib/Tab.js.map +1 -0
- package/lib/TabGroup.js +2 -0
- package/lib/TabGroup.js.map +1 -0
- package/lib/TabPanel.js +2 -0
- package/lib/TabPanel.js.map +1 -0
- package/lib/Table.js +1 -1
- package/lib/{TextField-f8848f28.js → TextField-93a3922f.js} +2 -2
- package/lib/TextField-93a3922f.js.map +1 -0
- package/lib/Textarea.js +1 -1
- package/lib/Toggle.js +1 -1
- package/lib/Toggle.js.map +1 -1
- package/lib/Tooltip.js +1 -1
- package/lib/Tooltip.js.map +1 -1
- package/lib/VisuallyHidden.js +1 -1
- package/lib/bundle.js +13 -12
- package/lib/bundle.js.map +1 -1
- package/lib/{class-map-9e39244c.js → class-map-f1b6f1fa.js} +2 -2
- package/lib/{class-map-9e39244c.js.map → class-map-f1b6f1fa.js.map} +1 -1
- package/lib/cond-97c45476.js +2 -0
- package/lib/{cond-ed8742b5.js.map → cond-97c45476.js.map} +1 -1
- package/lib/date-adapter.js +1 -1
- package/lib/{dates-56f73760.js → dates-a8de5b83.js} +1 -1
- package/lib/{dates-56f73760.js.map → dates-a8de5b83.js.map} +1 -1
- package/lib/en-us.js +1 -1
- package/lib/en-us.js.map +1 -1
- package/lib/fi-fi.js +1 -1
- package/lib/fi-fi.js.map +1 -1
- package/lib/{if-defined-4d1db15c.js → if-defined-fe1a64e3.js} +2 -2
- package/lib/{if-defined-4d1db15c.js.map → if-defined-fe1a64e3.js.map} +1 -1
- package/lib/index.js +1 -1
- package/lib/{lit-element-e382250e.js → lit-element-67e6cd99.js} +2 -2
- package/lib/{lit-element-e382250e.js.map → lit-element-67e6cd99.js.map} +1 -1
- package/lib/localization4.js +2 -0
- package/lib/localization4.js.map +1 -0
- package/lib/month-view.js +1 -1
- package/lib/month-view.js.map +1 -1
- package/lib/positioning-b660767c.js +2 -0
- package/lib/positioning-b660767c.js.map +1 -0
- package/lib/{ref-adf41565.js → ref-57ff8ffc.js} +2 -2
- package/lib/{ref-adf41565.js.map → ref-57ff8ffc.js.map} +1 -1
- package/lib/{repeat-ed796481.js → repeat-084c4167.js} +3 -3
- package/lib/{repeat-ed796481.js.map → repeat-084c4167.js.map} +1 -1
- package/lib/src/card/Card.d.ts +1 -1
- package/lib/src/common/controllers/FocusTrapController.d.ts +14 -0
- package/lib/src/common/controllers/ScrollbarController.d.ts +11 -0
- package/lib/src/common/form.d.ts +5 -0
- package/lib/src/dropdown/Dropdown.d.ts +2 -1
- package/lib/src/index.d.ts +5 -0
- package/lib/src/input/Input.d.ts +3 -1
- package/lib/src/localization/en-us.d.ts +3 -0
- package/lib/src/modal/Modal.d.ts +84 -0
- package/lib/src/modal/Modal.test.d.ts +6 -0
- package/lib/src/modal/localization.d.ts +4 -0
- package/lib/src/skeleton/Skeleton.d.ts +24 -0
- package/lib/src/skeleton/Skeleton.test.d.ts +3 -0
- package/lib/src/tab/Tab.d.ts +30 -0
- package/lib/src/tab/Tab.test.d.ts +1 -0
- package/lib/src/tab-group/TabGroup.d.ts +77 -0
- package/lib/src/tab-group/TabGroup.test.d.ts +9 -0
- package/lib/src/tab-panel/TabPanel.d.ts +21 -0
- package/lib/src/tab-panel/TabPanel.test.d.ts +1 -0
- package/lib/src/toggle/Toggle.d.ts +1 -1
- package/lib/translation.js +1 -1
- package/lib/translation.js.map +1 -1
- package/lib/{unsafe-html-76575c49.js → unsafe-html-61a04601.js} +2 -2
- package/lib/{unsafe-html-76575c49.js.map → unsafe-html-61a04601.js.map} +1 -1
- package/package.json +41 -32
- package/lib/Component-fa316972.js +0 -2
- package/lib/Component-fa316972.js.map +0 -1
- package/lib/FormField-44e865a4.js.map +0 -1
- package/lib/InputMixin-84ca72ae.js +0 -2
- package/lib/TextField-f8848f28.js.map +0 -1
- package/lib/cond-ed8742b5.js +0 -2
- package/lib/positioning-763efb3a.js +0 -2
- package/lib/positioning-763efb3a.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"positioning-b660767c.js","sources":["../node_modules/@floating-ui/core/dist/floating-ui.core.mjs","../node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs","../src/common/positioning.ts"],"sourcesContent":["function getSide(placement) {\n return placement.split('-')[0];\n}\n\nfunction getAlignment(placement) {\n return placement.split('-')[1];\n}\n\nfunction getMainAxisFromPlacement(placement) {\n return ['top', 'bottom'].includes(getSide(placement)) ? 'x' : 'y';\n}\n\nfunction getLengthFromAxis(axis) {\n return axis === 'y' ? 'height' : 'width';\n}\n\nfunction computeCoordsFromPlacement(_ref, placement, rtl) {\n let {\n reference,\n floating\n } = _ref;\n const commonX = reference.x + reference.width / 2 - floating.width / 2;\n const commonY = reference.y + reference.height / 2 - floating.height / 2;\n const mainAxis = getMainAxisFromPlacement(placement);\n const length = getLengthFromAxis(mainAxis);\n const commonAlign = reference[length] / 2 - floating[length] / 2;\n const side = getSide(placement);\n const isVertical = mainAxis === 'x';\n let coords;\n\n switch (side) {\n case 'top':\n coords = {\n x: commonX,\n y: reference.y - floating.height\n };\n break;\n\n case 'bottom':\n coords = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n\n case 'right':\n coords = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n\n case 'left':\n coords = {\n x: reference.x - floating.width,\n y: commonY\n };\n break;\n\n default:\n coords = {\n x: reference.x,\n y: reference.y\n };\n }\n\n switch (getAlignment(placement)) {\n case 'start':\n coords[mainAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);\n break;\n\n case 'end':\n coords[mainAxis] += commonAlign * (rtl && isVertical ? -1 : 1);\n break;\n }\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 */\n\nconst computePosition = async (reference, floating, config) => {\n const {\n placement = 'bottom',\n strategy = 'absolute',\n middleware = [],\n platform\n } = config;\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));\n\n if (process.env.NODE_ENV !== \"production\") {\n if (platform == null) {\n console.error(['Floating UI: `platform` property was not passed to config. If you', 'want to use Floating UI on the web, install @floating-ui/dom', 'instead of the /core package. Otherwise, you can create your own', '`platform`: https://floating-ui.com/docs/platform'].join(' '));\n }\n\n if (middleware.filter(_ref => {\n let {\n name\n } = _ref;\n return name === 'autoPlacement' || name === 'flip';\n }).length > 1) {\n throw new Error(['Floating UI: duplicate `flip` and/or `autoPlacement`', 'middleware detected. This will lead to an infinite loop. Ensure only', 'one of either has been passed to the `middleware` array.'].join(' '));\n }\n }\n\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\n for (let i = 0; i < middleware.length; i++) {\n const {\n name,\n fn\n } = middleware[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 = { ...middlewareData,\n [name]: { ...middlewareData[name],\n ...data\n }\n };\n\n if (process.env.NODE_ENV !== \"production\") {\n if (resetCount > 50) {\n console.warn(['Floating UI: The middleware lifecycle appears to be running in an', 'infinite loop. This is usually caused by a `reset` continually', 'being returned without a break condition.'].join(' '));\n }\n }\n\n if (reset && resetCount <= 50) {\n resetCount++;\n\n if (typeof reset === 'object') {\n if (reset.placement) {\n statefulPlacement = reset.placement;\n }\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 ({\n x,\n y\n } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));\n }\n\n i = -1;\n continue;\n }\n }\n\n return {\n x,\n y,\n placement: statefulPlacement,\n strategy,\n middlewareData\n };\n};\n\nfunction expandPaddingObject(padding) {\n return {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n ...padding\n };\n}\n\nfunction getSideObjectFromPadding(padding) {\n return typeof padding !== 'number' ? expandPaddingObject(padding) : {\n top: padding,\n right: padding,\n bottom: padding,\n left: padding\n };\n}\n\nfunction rectToClientRect(rect) {\n return { ...rect,\n top: rect.y,\n left: rect.x,\n right: rect.x + rect.width,\n bottom: rect.y + rect.height\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.\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(middlewareArguments, options) {\n var _await$platform$isEle;\n\n if (options === void 0) {\n options = {};\n }\n\n const {\n x,\n y,\n platform,\n rects,\n elements,\n strategy\n } = middlewareArguments;\n const {\n boundary = 'clippingAncestors',\n rootBoundary = 'viewport',\n elementContext = 'floating',\n altBoundary = false,\n padding = 0\n } = options;\n const paddingObject = getSideObjectFromPadding(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 elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({\n rect: elementContext === 'floating' ? { ...rects.floating,\n x,\n y\n } : rects.reference,\n offsetParent: await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating)),\n strategy\n }) : rects[elementContext]);\n return {\n top: clippingClientRect.top - elementClientRect.top + paddingObject.top,\n bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom,\n left: clippingClientRect.left - elementClientRect.left + paddingObject.left,\n right: elementClientRect.right - clippingClientRect.right + paddingObject.right\n };\n}\n\nconst min = Math.min;\nconst max = Math.max;\n\nfunction within(min$1, value, max$1) {\n return max(min$1, min(value, max$1));\n}\n\n/**\n * Positions an inner element of the floating element such that it is centered\n * to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = options => ({\n name: 'arrow',\n options,\n\n async fn(middlewareArguments) {\n // Since `element` is required, we don't Partial<> the type\n const {\n element,\n padding = 0\n } = options != null ? options : {};\n const {\n x,\n y,\n placement,\n rects,\n platform\n } = middlewareArguments;\n\n if (element == null) {\n if (process.env.NODE_ENV !== \"production\") {\n console.warn('Floating UI: No `element` was passed to the `arrow` middleware.');\n }\n\n return {};\n }\n\n const paddingObject = getSideObjectFromPadding(padding);\n const coords = {\n x,\n y\n };\n const axis = getMainAxisFromPlacement(placement);\n const alignment = getAlignment(placement);\n const length = getLengthFromAxis(axis);\n const arrowDimensions = await platform.getDimensions(element);\n const minProp = axis === 'y' ? 'top' : 'left';\n const maxProp = axis === 'y' ? 'bottom' : 'right';\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 ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0;\n\n if (clientSize === 0) {\n clientSize = rects.floating[length];\n }\n\n const centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the floating element if the center\n // point is outside the floating element's bounds\n\n const min = paddingObject[minProp];\n const max = clientSize - arrowDimensions[length] - paddingObject[maxProp];\n const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;\n const offset = within(min, center, max); // Make sure that arrow points at the reference\n\n const alignmentPadding = alignment === 'start' ? paddingObject[minProp] : paddingObject[maxProp];\n const shouldAddOffset = alignmentPadding > 0 && center !== offset && rects.reference[length] <= rects.floating[length];\n const alignmentOffset = shouldAddOffset ? center < min ? min - center : max - center : 0;\n return {\n [axis]: coords[axis] - alignmentOffset,\n data: {\n [axis]: offset,\n centerOffset: center - offset\n }\n };\n }\n\n});\n\nconst hash$1 = {\n left: 'right',\n right: 'left',\n bottom: 'top',\n top: 'bottom'\n};\nfunction getOppositePlacement(placement) {\n return placement.replace(/left|right|bottom|top/g, matched => hash$1[matched]);\n}\n\nfunction getAlignmentSides(placement, rects, rtl) {\n if (rtl === void 0) {\n rtl = false;\n }\n\n const alignment = getAlignment(placement);\n const mainAxis = getMainAxisFromPlacement(placement);\n const length = getLengthFromAxis(mainAxis);\n let mainAlignmentSide = mainAxis === 'x' ? alignment === (rtl ? 'end' : 'start') ? 'right' : 'left' : alignment === 'start' ? 'bottom' : 'top';\n\n if (rects.reference[length] > rects.floating[length]) {\n mainAlignmentSide = getOppositePlacement(mainAlignmentSide);\n }\n\n return {\n main: mainAlignmentSide,\n cross: getOppositePlacement(mainAlignmentSide)\n };\n}\n\nconst hash = {\n start: 'end',\n end: 'start'\n};\nfunction getOppositeAlignmentPlacement(placement) {\n return placement.replace(/start|end/g, matched => hash[matched]);\n}\n\nconst sides = ['top', 'right', 'bottom', 'left'];\nconst allPlacements = /*#__PURE__*/sides.reduce((acc, side) => acc.concat(side, side + \"-start\", side + \"-end\"), []);\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\n return true;\n });\n}\n\n/**\n * Automatically chooses the `placement` which has the most space available.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = function (options) {\n if (options === void 0) {\n options = {};\n }\n\n return {\n name: 'autoPlacement',\n options,\n\n async fn(middlewareArguments) {\n var _middlewareData$autoP, _middlewareData$autoP2, _middlewareData$autoP3, _middlewareData$autoP4, _placementsSortedByLe;\n\n const {\n x,\n y,\n rects,\n middlewareData,\n placement,\n platform,\n elements\n } = middlewareArguments;\n const {\n alignment = null,\n allowedPlacements = allPlacements,\n autoAlignment = true,\n ...detectOverflowOptions\n } = options;\n const placements = getPlacementList(alignment, autoAlignment, allowedPlacements);\n const overflow = await detectOverflow(middlewareArguments, detectOverflowOptions);\n const currentIndex = (_middlewareData$autoP = (_middlewareData$autoP2 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP2.index) != null ? _middlewareData$autoP : 0;\n const currentPlacement = placements[currentIndex];\n\n if (currentPlacement == null) {\n return {};\n }\n\n const {\n main,\n cross\n } = getAlignmentSides(currentPlacement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating))); // Make `computeCoords` start from the right place\n\n if (placement !== currentPlacement) {\n return {\n x,\n y,\n reset: {\n placement: placements[0]\n }\n };\n }\n\n const currentOverflows = [overflow[getSide(currentPlacement)], overflow[main], overflow[cross]];\n const allOverflows = [...((_middlewareData$autoP3 = (_middlewareData$autoP4 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP4.overflows) != null ? _middlewareData$autoP3 : []), {\n placement: currentPlacement,\n overflows: currentOverflows\n }];\n const nextPlacement = placements[currentIndex + 1]; // There are more placements to check\n\n if (nextPlacement) {\n return {\n data: {\n index: currentIndex + 1,\n overflows: allOverflows\n },\n reset: {\n placement: nextPlacement\n }\n };\n }\n\n const placementsSortedByLeastOverflow = allOverflows.slice().sort((a, b) => a.overflows[0] - b.overflows[0]);\n const placementThatFitsOnAllSides = (_placementsSortedByLe = placementsSortedByLeastOverflow.find(_ref => {\n let {\n overflows\n } = _ref;\n return overflows.every(overflow => overflow <= 0);\n })) == null ? void 0 : _placementsSortedByLe.placement;\n const resetPlacement = placementThatFitsOnAllSides != null ? placementThatFitsOnAllSides : placementsSortedByLeastOverflow[0].placement;\n\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\n return {};\n }\n\n };\n};\n\nfunction getExpandedPlacements(placement) {\n const oppositePlacement = getOppositePlacement(placement);\n return [getOppositeAlignmentPlacement(placement), oppositePlacement, getOppositeAlignmentPlacement(oppositePlacement)];\n}\n\n/**\n * Changes the placement of the floating element to one that will fit if the\n * initially specified `placement` does not.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = function (options) {\n if (options === void 0) {\n options = {};\n }\n\n return {\n name: 'flip',\n options,\n\n async fn(middlewareArguments) {\n var _middlewareData$flip;\n\n const {\n placement,\n middlewareData,\n rects,\n initialPlacement,\n platform,\n elements\n } = middlewareArguments;\n const {\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = true,\n fallbackPlacements: specifiedFallbackPlacements,\n fallbackStrategy = 'bestFit',\n flipAlignment = true,\n ...detectOverflowOptions\n } = options;\n const side = getSide(placement);\n const isBasePlacement = side === initialPlacement;\n const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));\n const placements = [initialPlacement, ...fallbackPlacements];\n const overflow = await detectOverflow(middlewareArguments, detectOverflowOptions);\n const overflows = [];\n let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];\n\n if (checkMainAxis) {\n overflows.push(overflow[side]);\n }\n\n if (checkCrossAxis) {\n const {\n main,\n cross\n } = getAlignmentSides(placement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));\n overflows.push(overflow[main], overflow[cross]);\n }\n\n overflowsData = [...overflowsData, {\n placement,\n overflows\n }]; // One or more sides is overflowing\n\n if (!overflows.every(side => side <= 0)) {\n var _middlewareData$flip$, _middlewareData$flip2;\n\n const nextIndex = ((_middlewareData$flip$ = (_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) != null ? _middlewareData$flip$ : 0) + 1;\n const nextPlacement = placements[nextIndex];\n\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 let resetPlacement = 'bottom';\n\n switch (fallbackStrategy) {\n case 'bestFit':\n {\n var _overflowsData$map$so;\n\n const placement = (_overflowsData$map$so = overflowsData.map(d => [d, 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].placement;\n\n if (placement) {\n resetPlacement = placement;\n }\n\n break;\n }\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\n return {};\n }\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}\n\nfunction isAnySideFullyClipped(overflow) {\n return sides.some(side => overflow[side] >= 0);\n}\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 (_temp) {\n let {\n strategy = 'referenceHidden',\n ...detectOverflowOptions\n } = _temp === void 0 ? {} : _temp;\n return {\n name: 'hide',\n\n async fn(middlewareArguments) {\n const {\n rects\n } = middlewareArguments;\n\n switch (strategy) {\n case 'referenceHidden':\n {\n const overflow = await detectOverflow(middlewareArguments, { ...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\n case 'escaped':\n {\n const overflow = await detectOverflow(middlewareArguments, { ...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\n default:\n {\n return {};\n }\n }\n }\n\n };\n};\n\nasync function convertValueToCoords(middlewareArguments, value) {\n const {\n placement,\n platform,\n elements\n } = middlewareArguments;\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 = getMainAxisFromPlacement(placement) === 'x';\n const mainAxisMulti = ['left', 'top'].includes(side) ? -1 : 1;\n const crossAxisMulti = rtl && isVertical ? -1 : 1;\n const rawValue = typeof value === 'function' ? value(middlewareArguments) : value; // eslint-disable-next-line prefer-const\n\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\n if (alignment && typeof alignmentAxis === 'number') {\n crossAxis = alignment === 'end' ? alignmentAxis * -1 : alignmentAxis;\n }\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 * Displaces the floating element from its reference element.\n * @see https://floating-ui.com/docs/offset\n */\n\nconst offset = function (value) {\n if (value === void 0) {\n value = 0;\n }\n\n return {\n name: 'offset',\n options: value,\n\n async fn(middlewareArguments) {\n const {\n x,\n y\n } = middlewareArguments;\n const diffCoords = await convertValueToCoords(middlewareArguments, value);\n return {\n x: x + diffCoords.x,\n y: y + diffCoords.y,\n data: diffCoords\n };\n }\n\n };\n};\n\nfunction getCrossAxis(axis) {\n return axis === 'x' ? 'y' : 'x';\n}\n\n/**\n * Shifts the floating element in order to keep it in view when it will overflow\n * a clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = function (options) {\n if (options === void 0) {\n options = {};\n }\n\n return {\n name: 'shift',\n options,\n\n async fn(middlewareArguments) {\n const {\n x,\n y,\n placement\n } = middlewareArguments;\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 } = options;\n const coords = {\n x,\n y\n };\n const overflow = await detectOverflow(middlewareArguments, detectOverflowOptions);\n const mainAxis = getMainAxisFromPlacement(getSide(placement));\n const crossAxis = getCrossAxis(mainAxis);\n let mainAxisCoord = coords[mainAxis];\n let crossAxisCoord = coords[crossAxis];\n\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 = within(min, mainAxisCoord, max);\n }\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 = within(min, crossAxisCoord, max);\n }\n\n const limitedCoords = limiter.fn({ ...middlewareArguments,\n [mainAxis]: mainAxisCoord,\n [crossAxis]: crossAxisCoord\n });\n return { ...limitedCoords,\n data: {\n x: limitedCoords.x - x,\n y: limitedCoords.y - y\n }\n };\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\n return {\n options,\n\n fn(middlewareArguments) {\n const {\n x,\n y,\n placement,\n rects,\n middlewareData\n } = middlewareArguments;\n const {\n offset = 0,\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = true\n } = options;\n const coords = {\n x,\n y\n };\n const mainAxis = getMainAxisFromPlacement(placement);\n const crossAxis = getCrossAxis(mainAxis);\n let mainAxisCoord = coords[mainAxis];\n let crossAxisCoord = coords[crossAxis];\n const rawOffset = typeof offset === 'function' ? offset({ ...rects,\n placement\n }) : offset;\n const computedOffset = typeof rawOffset === 'number' ? {\n mainAxis: rawOffset,\n crossAxis: 0\n } : {\n mainAxis: 0,\n crossAxis: 0,\n ...rawOffset\n };\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\n if (mainAxisCoord < limitMin) {\n mainAxisCoord = limitMin;\n } else if (mainAxisCoord > limitMax) {\n mainAxisCoord = limitMax;\n }\n }\n\n if (checkCrossAxis) {\n var _middlewareData$offse, _middlewareData$offse2, _middlewareData$offse3, _middlewareData$offse4;\n\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$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) != null ? _middlewareData$offse : 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis);\n const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : (_middlewareData$offse3 = (_middlewareData$offse4 = middlewareData.offset) == null ? void 0 : _middlewareData$offse4[crossAxis]) != null ? _middlewareData$offse3 : 0) - (isOriginSide ? computedOffset.crossAxis : 0);\n\n if (crossAxisCoord < limitMin) {\n crossAxisCoord = limitMin;\n } else if (crossAxisCoord > limitMax) {\n crossAxisCoord = limitMax;\n }\n }\n\n return {\n [mainAxis]: mainAxisCoord,\n [crossAxis]: crossAxisCoord\n };\n }\n\n };\n};\n\n/**\n * Provides data to change the size of the floating element. For instance,\n * prevent it from overflowing its clipping boundary or match the width of the\n * reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = function (options) {\n if (options === void 0) {\n options = {};\n }\n\n return {\n name: 'size',\n options,\n\n async fn(middlewareArguments) {\n const {\n placement,\n rects,\n platform,\n elements\n } = middlewareArguments;\n const {\n apply,\n ...detectOverflowOptions\n } = options;\n const overflow = await detectOverflow(middlewareArguments, detectOverflowOptions);\n const side = getSide(placement);\n const alignment = getAlignment(placement);\n let heightSide;\n let widthSide;\n\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\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 const dimensions = {\n availableHeight: rects.floating.height - (['left', 'right'].includes(placement) ? 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max(overflow.top, overflow.bottom)) : overflow[heightSide]),\n availableWidth: rects.floating.width - (['top', 'bottom'].includes(placement) ? 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max(overflow.left, overflow.right)) : overflow[widthSide])\n };\n const prevDimensions = await platform.getDimensions(elements.floating);\n apply == null ? void 0 : apply({ ...middlewareArguments,\n ...dimensions\n });\n const nextDimensions = await platform.getDimensions(elements.floating);\n\n if (prevDimensions.width !== nextDimensions.width || prevDimensions.height !== nextDimensions.height) {\n return {\n reset: {\n rects: true\n }\n };\n }\n\n return {};\n }\n\n };\n};\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\n return {\n name: 'inline',\n options,\n\n async fn(middlewareArguments) {\n var _await$platform$getCl;\n\n const {\n placement,\n elements,\n rects,\n platform,\n strategy\n } = middlewareArguments; // 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\n const {\n padding = 2,\n x,\n y\n } = options;\n const fallback = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({\n rect: rects.reference,\n offsetParent: await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating)),\n strategy\n }) : rects.reference);\n const clientRects = (_await$platform$getCl = await (platform.getClientRects == null ? void 0 : platform.getClientRects(elements.reference))) != null ? _await$platform$getCl : [];\n const paddingObject = getSideObjectFromPadding(padding);\n\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 var _clientRects$find;\n\n // Find the first rect in which the point is fully inside\n return (_clientRects$find = clientRects.find(rect => x > rect.left - paddingObject.left && x < rect.right + paddingObject.right && y > rect.top - paddingObject.top && y < rect.bottom + paddingObject.bottom)) != null ? _clientRects$find : fallback;\n } // There are 2 or more connected rects\n\n\n if (clientRects.length >= 2) {\n if (getMainAxisFromPlacement(placement) === 'x') {\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\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\n return fallback;\n }\n\n const resetRects = await platform.getElementRects({\n reference: {\n getBoundingClientRect\n },\n floating: elements.floating,\n strategy\n });\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\n return {};\n }\n\n };\n};\n\nexport { arrow, autoPlacement, computePosition, detectOverflow, flip, hide, inline, limitShift, offset, rectToClientRect, shift, size };\n","import { rectToClientRect, computePosition as computePosition$1 } from '@floating-ui/core';\nexport { arrow, autoPlacement, detectOverflow, flip, hide, inline, limitShift, offset, shift, size } from '@floating-ui/core';\n\nfunction isWindow(value) {\n return value && value.document && value.location && value.alert && value.setInterval;\n}\nfunction getWindow(node) {\n if (node == null) {\n return window;\n }\n\n if (!isWindow(node)) {\n const ownerDocument = node.ownerDocument;\n return ownerDocument ? ownerDocument.defaultView || window : window;\n }\n\n return node;\n}\n\nfunction getComputedStyle$1(element) {\n return getWindow(element).getComputedStyle(element);\n}\n\nfunction getNodeName(node) {\n return isWindow(node) ? '' : node ? (node.nodeName || '').toLowerCase() : '';\n}\n\nfunction getUAString() {\n const uaData = navigator.userAgentData;\n\n if (uaData != null && uaData.brands) {\n return uaData.brands.map(item => item.brand + \"/\" + item.version).join(' ');\n }\n\n return navigator.userAgent;\n}\n\nfunction isHTMLElement(value) {\n return value instanceof getWindow(value).HTMLElement;\n}\nfunction isElement(value) {\n return value instanceof getWindow(value).Element;\n}\nfunction isNode(value) {\n return value instanceof getWindow(value).Node;\n}\nfunction isShadowRoot(node) {\n // Browsers without `ShadowRoot` support\n if (typeof ShadowRoot === 'undefined') {\n return false;\n }\n\n const OwnElement = getWindow(node).ShadowRoot;\n return node instanceof OwnElement || node instanceof ShadowRoot;\n}\nfunction isOverflowElement(element) {\n // Firefox wants us to check `-x` and `-y` variations as well\n const {\n overflow,\n overflowX,\n overflowY\n } = getComputedStyle$1(element);\n return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);\n}\nfunction isTableElement(element) {\n return ['table', 'td', 'th'].includes(getNodeName(element));\n}\nfunction isContainingBlock(element) {\n // TODO: Try and use feature detection here instead\n const isFirefox = /firefox/i.test(getUAString());\n const css = getComputedStyle$1(element); // This is non-exhaustive but covers the most common CSS properties that\n // create a containing block.\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n\n return css.transform !== 'none' || css.perspective !== 'none' || // @ts-ignore (TS 4.1 compat)\n css.contain === 'paint' || ['transform', 'perspective'].includes(css.willChange) || isFirefox && css.willChange === 'filter' || isFirefox && (css.filter ? css.filter !== 'none' : false);\n}\nfunction isLayoutViewport() {\n // Not Safari\n return !/^((?!chrome|android).)*safari/i.test(getUAString()); // Feature detection for this fails in various ways\n // • Always-visible scrollbar or not\n // • Width of <html>, etc.\n // const vV = win.visualViewport;\n // return vV ? Math.abs(win.innerWidth / vV.scale - vV.width) < 0.5 : true;\n}\n\nconst min = Math.min;\nconst max = Math.max;\nconst round = Math.round;\n\nfunction getBoundingClientRect(element, includeScale, isFixedStrategy) {\n var _win$visualViewport$o, _win$visualViewport, _win$visualViewport$o2, _win$visualViewport2;\n\n if (includeScale === void 0) {\n includeScale = false;\n }\n\n if (isFixedStrategy === void 0) {\n isFixedStrategy = false;\n }\n\n const clientRect = element.getBoundingClientRect();\n let scaleX = 1;\n let scaleY = 1;\n\n if (includeScale && isHTMLElement(element)) {\n scaleX = element.offsetWidth > 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1;\n scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1;\n }\n\n const win = isElement(element) ? getWindow(element) : window;\n const addVisualOffsets = !isLayoutViewport() && isFixedStrategy;\n const x = (clientRect.left + (addVisualOffsets ? (_win$visualViewport$o = (_win$visualViewport = win.visualViewport) == null ? void 0 : _win$visualViewport.offsetLeft) != null ? _win$visualViewport$o : 0 : 0)) / scaleX;\n const y = (clientRect.top + (addVisualOffsets ? (_win$visualViewport$o2 = (_win$visualViewport2 = win.visualViewport) == null ? void 0 : _win$visualViewport2.offsetTop) != null ? _win$visualViewport$o2 : 0 : 0)) / scaleY;\n const width = clientRect.width / scaleX;\n const height = clientRect.height / scaleY;\n return {\n width,\n height,\n top: y,\n right: x + width,\n bottom: y + height,\n left: x,\n x,\n y\n };\n}\n\nfunction getDocumentElement(node) {\n return ((isNode(node) ? node.ownerDocument : node.document) || window.document).documentElement;\n}\n\nfunction getNodeScroll(element) {\n if (isElement(element)) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n }\n\n return {\n scrollLeft: element.pageXOffset,\n scrollTop: element.pageYOffset\n };\n}\n\nfunction getWindowScrollBarX(element) {\n // If <html> has a CSS width greater than the viewport, then this will be\n // incorrect for RTL.\n return getBoundingClientRect(getDocumentElement(element)).left + getNodeScroll(element).scrollLeft;\n}\n\nfunction isScaled(element) {\n const rect = getBoundingClientRect(element);\n return round(rect.width) !== element.offsetWidth || round(rect.height) !== element.offsetHeight;\n}\n\nfunction getRectRelativeToOffsetParent(element, offsetParent, strategy) {\n const isOffsetParentAnElement = isHTMLElement(offsetParent);\n const documentElement = getDocumentElement(offsetParent);\n const rect = getBoundingClientRect(element, // @ts-ignore - checked above (TS 4.1 compat)\n isOffsetParentAnElement && isScaled(offsetParent), strategy === 'fixed');\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n const offsets = {\n x: 0,\n y: 0\n };\n\n if (isOffsetParentAnElement || !isOffsetParentAnElement && strategy !== 'fixed') {\n if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n\n if (isHTMLElement(offsetParent)) {\n const offsetRect = getBoundingClientRect(offsetParent, true);\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\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}\n\nfunction getParentNode(node) {\n if (getNodeName(node) === 'html') {\n return node;\n }\n\n return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle\n // @ts-ignore\n node.assignedSlot || // step into the shadow DOM of the parent of a slotted node\n node.parentNode || ( // DOM Element detected\n isShadowRoot(node) ? node.host : null) || // ShadowRoot detected\n getDocumentElement(node) // fallback\n\n );\n}\n\nfunction getTrueOffsetParent(element) {\n if (!isHTMLElement(element) || getComputedStyle(element).position === 'fixed') {\n return null;\n }\n\n return element.offsetParent;\n}\n\nfunction getContainingBlock(element) {\n let currentNode = getParentNode(element);\n\n if (isShadowRoot(currentNode)) {\n currentNode = currentNode.host;\n }\n\n while (isHTMLElement(currentNode) && !['html', 'body'].includes(getNodeName(currentNode))) {\n if (isContainingBlock(currentNode)) {\n return currentNode;\n } else {\n currentNode = currentNode.parentNode;\n }\n }\n\n return null;\n} // Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\n\n\nfunction getOffsetParent(element) {\n const window = getWindow(element);\n let offsetParent = getTrueOffsetParent(element);\n\n while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {\n offsetParent = getTrueOffsetParent(offsetParent);\n }\n\n if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static' && !isContainingBlock(offsetParent))) {\n return window;\n }\n\n return offsetParent || getContainingBlock(element) || window;\n}\n\nfunction getDimensions(element) {\n if (isHTMLElement(element)) {\n return {\n width: element.offsetWidth,\n height: element.offsetHeight\n };\n }\n\n const rect = getBoundingClientRect(element);\n return {\n width: rect.width,\n height: rect.height\n };\n}\n\nfunction convertOffsetParentRelativeRectToViewportRelativeRect(_ref) {\n let {\n rect,\n offsetParent,\n strategy\n } = _ref;\n const isOffsetParentAnElement = isHTMLElement(offsetParent);\n const documentElement = getDocumentElement(offsetParent);\n\n if (offsetParent === documentElement) {\n return rect;\n }\n\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n const offsets = {\n x: 0,\n y: 0\n };\n\n if (isOffsetParentAnElement || !isOffsetParentAnElement && strategy !== 'fixed') {\n if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n\n if (isHTMLElement(offsetParent)) {\n const offsetRect = getBoundingClientRect(offsetParent, true);\n offsets.x = offsetRect.x + offsetParent.clientLeft;\n offsets.y = offsetRect.y + offsetParent.clientTop;\n } // This doesn't appear to be need to be negated.\n // else if (documentElement) {\n // offsets.x = getWindowScrollBarX(documentElement);\n // }\n\n }\n\n return { ...rect,\n x: rect.x - scroll.scrollLeft + offsets.x,\n y: rect.y - scroll.scrollTop + offsets.y\n };\n}\n\nfunction getViewportRect(element, strategy) {\n const win = getWindow(element);\n const html = 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\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n const layoutViewport = isLayoutViewport();\n\n if (layoutViewport || !layoutViewport && strategy === 'fixed') {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n\n return {\n width,\n height,\n x,\n y\n };\n}\n\n// of the `<html>` and `<body>` rect bounds if horizontally scrollable\n\nfunction getDocumentRect(element) {\n var _element$ownerDocumen;\n\n const html = getDocumentElement(element);\n const scroll = getNodeScroll(element);\n const body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body;\n const width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0);\n const height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);\n let x = -scroll.scrollLeft + getWindowScrollBarX(element);\n const y = -scroll.scrollTop;\n\n if (getComputedStyle$1(body || html).direction === 'rtl') {\n x += max(html.clientWidth, body ? body.clientWidth : 0) - width;\n }\n\n return {\n width,\n height,\n x,\n y\n };\n}\n\nfunction getNearestOverflowAncestor(node) {\n const parentNode = getParentNode(node);\n\n if (['html', 'body', '#document'].includes(getNodeName(parentNode))) {\n // @ts-ignore assume body is always available\n return node.ownerDocument.body;\n }\n\n if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {\n return parentNode;\n }\n\n return getNearestOverflowAncestor(parentNode);\n}\n\nfunction getOverflowAncestors(node, list) {\n var _node$ownerDocument;\n\n if (list === void 0) {\n list = [];\n }\n\n const scrollableAncestor = getNearestOverflowAncestor(node);\n const isBody = scrollableAncestor === ((_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.body);\n const win = getWindow(scrollableAncestor);\n const target = isBody ? [win].concat(win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : []) : scrollableAncestor;\n const updatedList = list.concat(target);\n return isBody ? updatedList : // @ts-ignore: isBody tells us target will be an HTMLElement here\n updatedList.concat(getOverflowAncestors(target));\n}\n\nfunction contains(parent, child) {\n const rootNode = child.getRootNode == null ? void 0 : child.getRootNode(); // First, attempt with faster native method\n\n if (parent.contains(child)) {\n return true;\n } // then fallback to custom implementation with Shadow DOM support\n else if (rootNode && isShadowRoot(rootNode)) {\n let next = child;\n\n do {\n // use `===` replace node.isSameNode()\n if (next && parent === next) {\n return true;\n } // @ts-ignore: need a better way to handle this...\n\n\n next = next.parentNode || next.host;\n } while (next);\n }\n\n return false;\n}\n\nfunction getInnerBoundingClientRect(element, strategy) {\n const clientRect = getBoundingClientRect(element, false, strategy === 'fixed');\n const top = clientRect.top + element.clientTop;\n const left = clientRect.left + element.clientLeft;\n return {\n top,\n left,\n x: left,\n y: top,\n right: left + element.clientWidth,\n bottom: top + element.clientHeight,\n width: element.clientWidth,\n height: element.clientHeight\n };\n}\n\nfunction getClientRectFromClippingAncestor(element, clippingParent, strategy) {\n if (clippingParent === 'viewport') {\n return rectToClientRect(getViewportRect(element, strategy));\n }\n\n if (isElement(clippingParent)) {\n return getInnerBoundingClientRect(clippingParent, strategy);\n }\n\n return rectToClientRect(getDocumentRect(getDocumentElement(element)));\n} // A \"clipping ancestor\" is an overflowable container with the characteristic of\n// clipping (or hiding) overflowing elements with a position different from\n// `initial`\n\n\nfunction getClippingAncestors(element) {\n const clippingAncestors = getOverflowAncestors(element);\n const canEscapeClipping = ['absolute', 'fixed'].includes(getComputedStyle$1(element).position);\n const clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element;\n\n if (!isElement(clipperElement)) {\n return [];\n } // @ts-ignore isElement check ensures we return Array<Element>\n\n\n return clippingAncestors.filter(clippingAncestors => isElement(clippingAncestors) && contains(clippingAncestors, clipperElement) && getNodeName(clippingAncestors) !== 'body');\n} // Gets the maximum area that the element is visible in due to any number of\n// clipping ancestors\n\n\nfunction getClippingRect(_ref) {\n let {\n element,\n boundary,\n rootBoundary,\n strategy\n } = _ref;\n const mainClippingAncestors = boundary === 'clippingAncestors' ? getClippingAncestors(element) : [].concat(boundary);\n const clippingAncestors = [...mainClippingAncestors, rootBoundary];\n const firstClippingAncestor = clippingAncestors[0];\n const clippingRect = clippingAncestors.reduce((accRect, clippingAncestor) => {\n const rect = getClientRectFromClippingAncestor(element, clippingAncestor, strategy);\n accRect.top = max(rect.top, accRect.top);\n accRect.right = min(rect.right, accRect.right);\n accRect.bottom = min(rect.bottom, accRect.bottom);\n accRect.left = 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}\n\nconst platform = {\n getClippingRect,\n convertOffsetParentRelativeRectToViewportRelativeRect,\n isElement,\n getDimensions,\n getOffsetParent,\n getDocumentElement,\n getElementRects: _ref => {\n let {\n reference,\n floating,\n strategy\n } = _ref;\n return {\n reference: getRectRelativeToOffsetParent(reference, getOffsetParent(floating), strategy),\n floating: { ...getDimensions(floating),\n x: 0,\n y: 0\n }\n };\n },\n getClientRects: element => Array.from(element.getClientRects()),\n isRTL: element => getComputedStyle$1(element).direction === 'rtl'\n};\n\n/**\n * Automatically updates the position of the floating element when necessary.\n * @see https://floating-ui.com/docs/autoUpdate\n */\nfunction autoUpdate(reference, floating, update, options) {\n if (options === void 0) {\n options = {};\n }\n\n const {\n ancestorScroll: _ancestorScroll = true,\n ancestorResize: _ancestorResize = true,\n elementResize = true,\n animationFrame = false\n } = options;\n const ancestorScroll = _ancestorScroll && !animationFrame;\n const ancestorResize = _ancestorResize && !animationFrame;\n const ancestors = ancestorScroll || ancestorResize ? [...(isElement(reference) ? getOverflowAncestors(reference) : []), ...getOverflowAncestors(floating)] : [];\n ancestors.forEach(ancestor => {\n ancestorScroll && ancestor.addEventListener('scroll', update, {\n passive: true\n });\n ancestorResize && ancestor.addEventListener('resize', update);\n });\n let observer = null;\n\n if (elementResize) {\n observer = new ResizeObserver(update);\n isElement(reference) && !animationFrame && observer.observe(reference);\n observer.observe(floating);\n }\n\n let frameId;\n let prevRefRect = animationFrame ? getBoundingClientRect(reference) : null;\n\n if (animationFrame) {\n frameLoop();\n }\n\n function frameLoop() {\n const nextRefRect = getBoundingClientRect(reference);\n\n if (prevRefRect && (nextRefRect.x !== prevRefRect.x || nextRefRect.y !== prevRefRect.y || nextRefRect.width !== prevRefRect.width || nextRefRect.height !== prevRefRect.height)) {\n update();\n }\n\n prevRefRect = nextRefRect;\n frameId = requestAnimationFrame(frameLoop);\n }\n\n if (!elementResize) {\n update();\n }\n\n return () => {\n var _observer;\n\n ancestors.forEach(ancestor => {\n ancestorScroll && ancestor.removeEventListener('scroll', update);\n ancestorResize && ancestor.removeEventListener('resize', update);\n });\n (_observer = observer) == null ? void 0 : _observer.disconnect();\n observer = null;\n\n if (animationFrame) {\n cancelAnimationFrame(frameId);\n }\n };\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 CSS positioning\n * strategy.\n */\n\nconst computePosition = (reference, floating, options) => computePosition$1(reference, floating, {\n platform,\n ...options\n});\n\nexport { autoUpdate, computePosition, getOverflowAncestors };\n","import { Side, Placement, Alignment } from \"@floating-ui/dom\"\n\ntype FullPlacement = Exclude<Placement, Side>\ntype LogicalSide = \"block-end\" | \"block-start\" | \"inline-start\" | \"inline-end\"\ntype LogicalSideAlign = `${LogicalSide}-${Alignment}`\ntype Direction = \"ltr\" | \"rtl\"\n\nconst logicalMapLTR: Record<LogicalSideAlign, FullPlacement> = {\n \"inline-start-start\": \"left-start\",\n \"inline-start-end\": \"left-end\",\n \"inline-end-start\": \"right-start\",\n \"inline-end-end\": \"right-end\",\n \"block-start-start\": \"top-start\",\n \"block-start-end\": \"top-end\",\n \"block-end-start\": \"bottom-start\",\n \"block-end-end\": \"bottom-end\",\n}\n\nconst logicalMapRTL: Record<LogicalSideAlign, FullPlacement> = {\n \"inline-start-start\": \"right-start\",\n \"inline-start-end\": \"right-end\",\n \"inline-end-start\": \"left-start\",\n \"inline-end-end\": \"left-end\",\n \"block-start-start\": \"top-start\",\n \"block-start-end\": \"top-end\",\n \"block-end-start\": \"bottom-start\",\n \"block-end-end\": \"bottom-end\",\n}\n\nconst logicalMap: Record<LogicalSide, Side> = {\n \"block-end\": \"bottom\",\n \"block-start\": \"top\",\n \"inline-start\": \"left\",\n \"inline-end\": \"right\",\n}\n\n/**\n * Converts a single logical position to a physical position\n */\nexport function logicalToPhysical(logicalSide: LogicalSide): Side\n\n/**\n * Converts a logical side and alignment to floating-ui compatible placement\n */\nexport function logicalToPhysical(logicalSide: LogicalSide, alignment: Alignment, dir: Direction): Placement\n\nexport function logicalToPhysical(logicalSide: LogicalSide, alignment?: Alignment, dir?: Direction) {\n if (alignment != null && dir != null) {\n const logicalSideAlign: LogicalSideAlign = `${logicalSide}-${alignment}`\n return dir === \"ltr\" ? logicalMapLTR[logicalSideAlign] : logicalMapRTL[logicalSideAlign]\n }\n\n return logicalMap[logicalSide]\n}\n"],"names":["getSide","placement","split","getAlignment","getMainAxisFromPlacement","includes","getLengthFromAxis","axis","computeCoordsFromPlacement","_ref","rtl","reference","floating","commonX","x","width","commonY","y","height","mainAxis","length","commonAlign","isVertical","coords","rectToClientRect","rect","top","left","right","bottom","async","detectOverflow","middlewareArguments","options","_await$platform$isEle","platform","rects","elements","strategy","boundary","rootBoundary","elementContext","altBoundary","padding","paddingObject","expandPaddingObject","getSideObjectFromPadding","element","clippingClientRect","getClippingRect","isElement","contextElement","getDocumentElement","elementClientRect","convertOffsetParentRelativeRectToViewportRelativeRect","offsetParent","getOffsetParent","min","Math","max","within","min$1","value","max$1","hash$1","getOppositePlacement","replace","matched","hash","start","end","getOppositeAlignmentPlacement","sides","flip","name","_middlewareData$flip","middlewareData","initialPlacement","checkMainAxis","crossAxis","checkCrossAxis","fallbackPlacements","specifiedFallbackPlacements","fallbackStrategy","flipAlignment","detectOverflowOptions","side","oppositePlacement","getExpandedPlacements","placements","overflow","overflows","overflowsData","push","main","cross","alignment","mainAlignmentSide","getAlignmentSides","isRTL","every","_middlewareData$flip$","_middlewareData$flip2","nextIndex","index","nextPlacement","data","reset","resetPlacement","_overflowsData$map$so","map","d","filter","reduce","acc","sort","a","b","getSideOffsets","isAnySideFullyClipped","some","hide","_temp","offsets","referenceHiddenOffsets","referenceHidden","escapedOffsets","escaped","offset","diffCoords","mainAxisMulti","crossAxisMulti","rawValue","alignmentAxis","convertValueToCoords","shift","limiter","fn","mainAxisCoord","crossAxisCoord","maxSide","limitedCoords","isWindow","document","location","alert","setInterval","getWindow","node","window","ownerDocument","defaultView","getComputedStyle$1","getComputedStyle","getNodeName","nodeName","toLowerCase","getUAString","uaData","navigator","userAgentData","brands","item","brand","version","join","userAgent","isHTMLElement","HTMLElement","Element","isShadowRoot","ShadowRoot","isOverflowElement","overflowX","overflowY","test","isTableElement","isContainingBlock","isFirefox","css","transform","perspective","contain","willChange","isLayoutViewport","round","getBoundingClientRect","includeScale","isFixedStrategy","_win$visualViewport$o","_win$visualViewport","_win$visualViewport$o2","_win$visualViewport2","clientRect","scaleX","scaleY","offsetWidth","offsetHeight","win","addVisualOffsets","visualViewport","offsetLeft","offsetTop","Node","documentElement","getNodeScroll","scrollLeft","scrollTop","pageXOffset","pageYOffset","getWindowScrollBarX","getRectRelativeToOffsetParent","isOffsetParentAnElement","isScaled","scroll","offsetRect","clientLeft","clientTop","getParentNode","assignedSlot","parentNode","host","getTrueOffsetParent","position","currentNode","getContainingBlock","getDimensions","getNearestOverflowAncestor","body","getOverflowAncestors","list","_node$ownerDocument","scrollableAncestor","isBody","target","concat","updatedList","getClientRectFromClippingAncestor","clippingParent","html","clientWidth","clientHeight","layoutViewport","getViewportRect","getInnerBoundingClientRect","_element$ownerDocumen","scrollWidth","scrollHeight","direction","getDocumentRect","getClippingAncestors","clippingAncestors","clipperElement","parent","child","rootNode","getRootNode","contains","next","firstClippingAncestor","clippingRect","accRect","clippingAncestor","getElementRects","getClientRects","Array","from","autoUpdate","update","ancestorScroll","_ancestorScroll","ancestorResize","_ancestorResize","elementResize","animationFrame","ancestors","forEach","ancestor","addEventListener","passive","frameId","observer","ResizeObserver","observe","prevRefRect","frameLoop","nextRefRect","requestAnimationFrame","_observer","removeEventListener","disconnect","cancelAnimationFrame","computePosition","config","middleware","statefulPlacement","resetCount","i","nextX","nextY","computePosition$1","logicalMapLTR","logicalMapRTL","logicalMap","logicalToPhysical","logicalSide","dir","logicalSideAlign"],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{R as t,w as i}from"./lit-element-
|
|
1
|
+
import{R as t,w as i}from"./lit-element-67e6cd99.js";import{i as e,t as s,e as o}from"./directive-de55b00a.js";
|
|
2
2
|
/**
|
|
3
3
|
* @license
|
|
4
4
|
* Copyright 2020 Google LLC
|
|
@@ -14,4 +14,4 @@ import{R as t,w as i}from"./lit-element-e382250e.js";import{i as e,t as s,e as o
|
|
|
14
14
|
* Copyright 2020 Google LLC
|
|
15
15
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
16
16
|
*/const g=()=>new m;class m{}const C=new WeakMap,b=o(class extends p{render(t){return i}update(t,[e]){var s;const o=e!==this.U;return o&&void 0!==this.U&&this.ot(void 0),(o||this.rt!==this.lt)&&(this.U=e,this.ht=null===(s=t.options)||void 0===s?void 0:s.host,this.ot(this.lt=t.element)),i}ot(t){var i;if("function"==typeof this.U){const e=null!==(i=this.ht)&&void 0!==i?i:globalThis;let s=C.get(e);void 0===s&&(s=new WeakMap,C.set(e,s)),void 0!==s.get(this.U)&&this.U.call(this.ht,void 0),s.set(this.U,t),void 0!==t&&this.U.call(this.ht,t)}else this.U.value=t}get rt(){var t,i,e;return"function"==typeof this.U?null===(i=C.get(null!==(t=this.ht)&&void 0!==t?t:globalThis))||void 0===i?void 0:i.get(this.U):null===(e=this.U)||void 0===e?void 0:e.value}disconnected(){this.rt===this.lt&&this.ot(void 0)}reconnected(){this.ot(this.lt)}});export{A as a,r as c,g as e,$ as m,b as n,c as s,h as u};
|
|
17
|
-
//# sourceMappingURL=ref-
|
|
17
|
+
//# sourceMappingURL=ref-57ff8ffc.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ref-
|
|
1
|
+
{"version":3,"file":"ref-57ff8ffc.js","sources":["../node_modules/lit-html/directive-helpers.js","../node_modules/lit-html/async-directive.js","../node_modules/lit-html/directives/ref.js"],"sourcesContent":["import{_$LH as o}from\"./lit-html.js\";\n/**\n * @license\n * Copyright 2020 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const{H:i}=o,t=o=>null===o||\"object\"!=typeof o&&\"function\"!=typeof o,n={HTML:1,SVG:2},v=(o,i)=>{var t,n;return void 0===i?void 0!==(null===(t=o)||void 0===t?void 0:t._$litType$):(null===(n=o)||void 0===n?void 0:n._$litType$)===i},l=o=>{var i;return void 0!==(null===(i=o)||void 0===i?void 0:i._$litDirective$)},d=o=>{var i;return null===(i=o)||void 0===i?void 0:i._$litDirective$},r=o=>void 0===o.strings,e=()=>document.createComment(\"\"),u=(o,t,n)=>{var v;const l=o._$AA.parentNode,d=void 0===t?o._$AB:t._$AA;if(void 0===n){const t=l.insertBefore(e(),d),v=l.insertBefore(e(),d);n=new i(t,v,o,o.options)}else{const i=n._$AB.nextSibling,t=n._$AM,r=t!==o;if(r){let i;null===(v=n._$AQ)||void 0===v||v.call(n,o),n._$AM=o,void 0!==n._$AP&&(i=o._$AU)!==t._$AU&&n._$AP(i)}if(i!==d||r){let o=n._$AA;for(;o!==i;){const i=o.nextSibling;l.insertBefore(o,d),o=i}}}return n},c=(o,i,t=o)=>(o._$AI(i,t),o),f={},s=(o,i=f)=>o._$AH=i,a=o=>o._$AH,m=o=>{var i;null===(i=o._$AP)||void 0===i||i.call(o,!1,!0);let t=o._$AA;const n=o._$AB.nextSibling;for(;t!==n;){const o=t.nextSibling;t.remove(),t=o}},p=o=>{o._$AR()};export{n as TemplateResultType,p as clearPart,a as getCommittedValue,d as getDirectiveClass,u as insertPart,l as isDirectiveResult,t as isPrimitive,r as isSingleExpression,v as isTemplateResult,m as removePart,c as setChildPartValue,s as setCommittedValue};\n//# sourceMappingURL=directive-helpers.js.map\n","import{isSingleExpression as i}from\"./directive-helpers.js\";import{Directive as t,PartType as s}from\"./directive.js\";export{directive}from\"./directive.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const e=(i,t)=>{var s,o;const n=i._$AN;if(void 0===n)return!1;for(const i of n)null===(o=(s=i)._$AO)||void 0===o||o.call(s,t,!1),e(i,t);return!0},o=i=>{let t,s;do{if(void 0===(t=i._$AM))break;s=t._$AN,s.delete(i),i=t}while(0===(null==s?void 0:s.size))},n=i=>{for(let t;t=i._$AM;i=t){let s=t._$AN;if(void 0===s)t._$AN=s=new Set;else if(s.has(i))break;s.add(i),l(t)}};function r(i){void 0!==this._$AN?(o(this),this._$AM=i,n(this)):this._$AM=i}function h(i,t=!1,s=0){const n=this._$AH,r=this._$AN;if(void 0!==r&&0!==r.size)if(t)if(Array.isArray(n))for(let i=s;i<n.length;i++)e(n[i],!1),o(n[i]);else null!=n&&(e(n,!1),o(n));else e(this,i)}const l=i=>{var t,e,o,n;i.type==s.CHILD&&(null!==(t=(o=i)._$AP)&&void 0!==t||(o._$AP=h),null!==(e=(n=i)._$AQ)&&void 0!==e||(n._$AQ=r))};class d extends t{constructor(){super(...arguments),this._$AN=void 0}_$AT(i,t,s){super._$AT(i,t,s),n(this),this.isConnected=i._$AU}_$AO(i,t=!0){var s,n;i!==this.isConnected&&(this.isConnected=i,i?null===(s=this.reconnected)||void 0===s||s.call(this):null===(n=this.disconnected)||void 0===n||n.call(this)),t&&(e(this,i),o(this))}setValue(t){if(i(this._$Ct))this._$Ct._$AI(t,this);else{const i=[...this._$Ct._$AH];i[this._$Ci]=t,this._$Ct._$AI(i,this,0)}}disconnected(){}reconnected(){}}export{d as AsyncDirective};\n//# sourceMappingURL=async-directive.js.map\n","import{nothing as i}from\"../lit-html.js\";import{AsyncDirective as t}from\"../async-directive.js\";import{directive as s}from\"../directive.js\";\n/**\n * @license\n * Copyright 2020 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */const e=()=>new o;class o{}const h=new WeakMap,n=s(class extends t{render(t){return i}update(t,[s]){var e;const o=s!==this.U;return o&&void 0!==this.U&&this.ot(void 0),(o||this.rt!==this.lt)&&(this.U=s,this.ht=null===(e=t.options)||void 0===e?void 0:e.host,this.ot(this.lt=t.element)),i}ot(i){var t;if(\"function\"==typeof this.U){const s=null!==(t=this.ht)&&void 0!==t?t:globalThis;let e=h.get(s);void 0===e&&(e=new WeakMap,h.set(s,e)),void 0!==e.get(this.U)&&this.U.call(this.ht,void 0),e.set(this.U,i),void 0!==i&&this.U.call(this.ht,i)}else this.U.value=i}get rt(){var i,t,s;return\"function\"==typeof this.U?null===(t=h.get(null!==(i=this.ht)&&void 0!==i?i:globalThis))||void 0===t?void 0:t.get(this.U):null===(s=this.U)||void 0===s?void 0:s.value}disconnected(){this.rt===this.lt&&this.ot(void 0)}reconnected(){this.ot(this.lt)}});export{e as createRef,n as ref};\n//# sourceMappingURL=ref.js.map\n"],"names":["H","i","o","e","document","createComment","u","t","n","v","l","_$AA","parentNode","d","_$AB","insertBefore","options","nextSibling","_$AM","r","_$AQ","call","_$AP","_$AU","c","_$AI","f","s","_$AH","a","m","remove","_$AN","_$AO","delete","size","Set","has","add","this","h","Array","isArray","length","type","CHILD","constructor","super","arguments","_$AT","isConnected","reconnected","disconnected","setValue","strings","_$Ct","_$Ci","WeakMap","render","update","U","ot","rt","lt","ht","host","element","globalThis","get","set","value"],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import{b as e}from"./lit-element-
|
|
1
|
+
import{b as e}from"./lit-element-67e6cd99.js";import{e as t,i as s,t as r}from"./directive-de55b00a.js";import{a as l,c as o,u as n,m as i,s as f}from"./ref-57ff8ffc.js";
|
|
2
2
|
/**
|
|
3
3
|
* @license
|
|
4
4
|
* Copyright 2017 Google LLC
|
|
5
5
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
6
|
-
*/const
|
|
7
|
-
//# sourceMappingURL=repeat-
|
|
6
|
+
*/const u=(e,t,s)=>{const r=new Map;for(let l=t;l<=s;l++)r.set(e[l],l);return r},c=t(class extends s{constructor(e){if(super(e),e.type!==r.CHILD)throw Error("repeat() can only be used in text expressions")}dt(e,t,s){let r;void 0===s?s=t:void 0!==t&&(r=t);const l=[],o=[];let n=0;for(const t of e)l[n]=r?r(t,n):n,o[n]=s(t,n),n++;return{values:o,keys:l}}render(e,t,s){return this.dt(e,t,s).values}update(t,[s,r,c]){var a;const d=l(t),{values:h,keys:p}=this.dt(s,r,c);if(!Array.isArray(d))return this.ut=p,h;const v=null!==(a=this.ut)&&void 0!==a?a:this.ut=[],m=[];let y,x,g=0,j=d.length-1,b=0,k=h.length-1;for(;g<=j&&b<=k;)if(null===d[g])g++;else if(null===d[j])j--;else if(v[g]===p[b])m[b]=o(d[g],h[b]),g++,b++;else if(v[j]===p[k])m[k]=o(d[j],h[k]),j--,k--;else if(v[g]===p[k])m[k]=o(d[g],h[k]),n(t,m[k+1],d[g]),g++,k--;else if(v[j]===p[b])m[b]=o(d[j],h[b]),n(t,d[g],d[j]),j--,b++;else if(void 0===y&&(y=u(p,b,k),x=u(v,g,j)),y.has(v[g]))if(y.has(v[j])){const e=x.get(p[b]),s=void 0!==e?d[e]:null;if(null===s){const e=n(t,d[g]);o(e,h[b]),m[b]=e}else m[b]=o(s,h[b]),n(t,d[g],s),d[e]=null;b++}else i(d[j]),j--;else i(d[g]),g++;for(;b<=k;){const e=n(t,m[k+1]);o(e,h[b]),m[b++]=e}for(;g<=j;){const e=d[g++];null!==e&&i(e)}return this.ut=p,f(t,m),e}});export{c};
|
|
7
|
+
//# sourceMappingURL=repeat-084c4167.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"repeat-
|
|
1
|
+
{"version":3,"file":"repeat-084c4167.js","sources":["../node_modules/lit-html/directives/repeat.js"],"sourcesContent":["import{noChange as e}from\"../lit-html.js\";import{directive as s,Directive as t,PartType as r}from\"../directive.js\";import{getCommittedValue as l,setChildPartValue as o,insertPart as i,removePart as n,setCommittedValue as f}from\"../directive-helpers.js\";\n/**\n * @license\n * Copyright 2017 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\nconst u=(e,s,t)=>{const r=new Map;for(let l=s;l<=t;l++)r.set(e[l],l);return r},c=s(class extends t{constructor(e){if(super(e),e.type!==r.CHILD)throw Error(\"repeat() can only be used in text expressions\")}dt(e,s,t){let r;void 0===t?t=s:void 0!==s&&(r=s);const l=[],o=[];let i=0;for(const s of e)l[i]=r?r(s,i):i,o[i]=t(s,i),i++;return{values:o,keys:l}}render(e,s,t){return this.dt(e,s,t).values}update(s,[t,r,c]){var d;const a=l(s),{values:p,keys:v}=this.dt(t,r,c);if(!Array.isArray(a))return this.ut=v,p;const h=null!==(d=this.ut)&&void 0!==d?d:this.ut=[],m=[];let y,x,j=0,k=a.length-1,w=0,A=p.length-1;for(;j<=k&&w<=A;)if(null===a[j])j++;else if(null===a[k])k--;else if(h[j]===v[w])m[w]=o(a[j],p[w]),j++,w++;else if(h[k]===v[A])m[A]=o(a[k],p[A]),k--,A--;else if(h[j]===v[A])m[A]=o(a[j],p[A]),i(s,m[A+1],a[j]),j++,A--;else if(h[k]===v[w])m[w]=o(a[k],p[w]),i(s,a[j],a[k]),k--,w++;else if(void 0===y&&(y=u(v,w,A),x=u(h,j,k)),y.has(h[j]))if(y.has(h[k])){const e=x.get(v[w]),t=void 0!==e?a[e]:null;if(null===t){const e=i(s,a[j]);o(e,p[w]),m[w]=e}else m[w]=o(t,p[w]),i(s,a[j],t),a[e]=null;w++}else n(a[k]),k--;else n(a[j]),j++;for(;w<=A;){const e=i(s,m[A+1]);o(e,p[w]),m[w++]=e}for(;j<=k;){const e=a[j++];null!==e&&n(e)}return this.ut=v,f(s,m),e}});export{c as repeat};\n//# sourceMappingURL=repeat.js.map\n"],"names":["u","e","s","t","r","Map","l","set","c","constructor","super","type","CHILD","Error","dt","o","i","values","keys","render","this","update","d","a","p","v","Array","isArray","ut","h","m","y","x","j","k","length","w","A","has","get","n","f"],"mappings":"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"}
|
package/lib/src/card/Card.d.ts
CHANGED
|
@@ -15,7 +15,7 @@ export default class Card extends LitElement {
|
|
|
15
15
|
private headerSlot;
|
|
16
16
|
private footerSlot;
|
|
17
17
|
/**
|
|
18
|
-
* Controls the padding of card component. When set to “none”,
|
|
18
|
+
* Controls the padding of the card component. When set to “none”,
|
|
19
19
|
* the header and footer slots will still have padding.
|
|
20
20
|
*/
|
|
21
21
|
padding: "m" | "l" | "none";
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { ReactiveController, ReactiveControllerHost } from "lit";
|
|
2
|
+
export declare class FocusTrapController implements ReactiveController {
|
|
3
|
+
private boundary;
|
|
4
|
+
private lastScrollY;
|
|
5
|
+
private lastFocused?;
|
|
6
|
+
constructor(host: ReactiveControllerHost & HTMLElement, boundary?: () => HTMLElement);
|
|
7
|
+
hostDisconnected(): void;
|
|
8
|
+
trap(): void;
|
|
9
|
+
release(): void;
|
|
10
|
+
private handleFocusOut;
|
|
11
|
+
private handleFocusIn;
|
|
12
|
+
private recaptureFocus;
|
|
13
|
+
private restoreScroll;
|
|
14
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ReactiveController, ReactiveControllerHost } from "lit";
|
|
2
|
+
export declare class ScrollbarController implements ReactiveController {
|
|
3
|
+
private scroller;
|
|
4
|
+
private resets;
|
|
5
|
+
constructor(host: ReactiveControllerHost);
|
|
6
|
+
constructor(host: ReactiveControllerHost, scroller: HTMLElement);
|
|
7
|
+
hostDisconnected(): void;
|
|
8
|
+
get width(): number;
|
|
9
|
+
hide(): void;
|
|
10
|
+
restore(): void;
|
|
11
|
+
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { LitElement } from "lit";
|
|
2
|
-
import Popout from "../popout/Popout.js";
|
|
2
|
+
import type Popout from "../popout/Popout.js";
|
|
3
|
+
import "../popout/Popout.js";
|
|
3
4
|
/**
|
|
4
5
|
* Dropdown menu displays a list of actions or selectable options for
|
|
5
6
|
* a user. Dropdown uses popout component internally to create
|
package/lib/src/index.d.ts
CHANGED
|
@@ -32,4 +32,9 @@ export { default as DropdownItem } from "./dropdown-item/DropdownItem.js";
|
|
|
32
32
|
export { default as DropdownGroup } from "./dropdown-group/DropdownGroup.js";
|
|
33
33
|
export { registerTranslation, isTranslationRegistered } from "./localization/translation.js";
|
|
34
34
|
export type { Translation } from "./localization/translation.js";
|
|
35
|
+
export { default as TabGroup } from "./tab-group/TabGroup.js";
|
|
36
|
+
export { default as Tab } from "./tab/Tab.js";
|
|
37
|
+
export { default as TabPanel } from "./tab-panel/TabPanel.js";
|
|
35
38
|
export { default as Toggle } from "./toggle/Toggle.js";
|
|
39
|
+
export { default as Modal } from "./modal/Modal.js";
|
|
40
|
+
export { default as Skeleton } from "./skeleton/Skeleton.js";
|
package/lib/src/input/Input.d.ts
CHANGED
|
@@ -9,11 +9,13 @@ declare const Input_base: (new (...args: any[]) => import("../common/mixins/Form
|
|
|
9
9
|
* @slot label - Use when a label requires more than plain text.
|
|
10
10
|
* @slot hint - Optional slot that holds hint text for the input.
|
|
11
11
|
* @slot error - Optional slot that holds error text for the input.
|
|
12
|
-
* @slot start - Optional slot used to place an icon at the start of the input.
|
|
12
|
+
* @slot start - Optional slot used to place an icon or prefix at the start of the input.
|
|
13
|
+
* @slot end - Optional slot used to place an icon or suffix at the end of the input.
|
|
13
14
|
*/
|
|
14
15
|
export default class Input extends Input_base {
|
|
15
16
|
static styles: import("lit").CSSResult[];
|
|
16
17
|
private startSlot;
|
|
18
|
+
private endSlot;
|
|
17
19
|
/**
|
|
18
20
|
* The type of the input.
|
|
19
21
|
*/
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { LitElement } from "lit";
|
|
2
|
+
import "../icon/Icon.js";
|
|
3
|
+
declare const Modal_base: typeof LitElement;
|
|
4
|
+
/**
|
|
5
|
+
* Modal component is used to display content that temporarily blocks interactions
|
|
6
|
+
* with the main view of an application. Modal should be used sparingly and
|
|
7
|
+
* only when necessary.
|
|
8
|
+
*
|
|
9
|
+
* @status draft
|
|
10
|
+
* @category overlay
|
|
11
|
+
* @slot - Default slot
|
|
12
|
+
* @slot header - Slot which holds the header of the modal, positioned next to the close button.
|
|
13
|
+
* @slot footer - Slot which is typically used to hold call to action buttons, but can also be used to build custom footers.
|
|
14
|
+
* @fires cancel - Dispatched before the modal has closed when a user attempts to dismiss a modal. Call `preventDefault()` on the event to prevent the modal closing.
|
|
15
|
+
* @fires close - Dispatched when a modal is closed for any reason.
|
|
16
|
+
*/
|
|
17
|
+
export default class Modal extends Modal_base {
|
|
18
|
+
static styles: import("lit").CSSResult[];
|
|
19
|
+
private modal;
|
|
20
|
+
private backdrop;
|
|
21
|
+
private trigger?;
|
|
22
|
+
private lastButton?;
|
|
23
|
+
private headerSlot;
|
|
24
|
+
private featureSlot;
|
|
25
|
+
private footerSlot;
|
|
26
|
+
private scrollBar;
|
|
27
|
+
private focusTrap;
|
|
28
|
+
private localize;
|
|
29
|
+
private events;
|
|
30
|
+
private lightDismiss;
|
|
31
|
+
/**
|
|
32
|
+
* Controls whether the modal is open or not.
|
|
33
|
+
*/
|
|
34
|
+
open: boolean;
|
|
35
|
+
/**
|
|
36
|
+
* Controls the max-width of the modal when open.
|
|
37
|
+
*/
|
|
38
|
+
size: "s" | "m" | "l";
|
|
39
|
+
/**
|
|
40
|
+
* The reason why the modal was closed. This typically indicates
|
|
41
|
+
* which button the user pressed to close the modal, though any value
|
|
42
|
+
* can be supplied if the modal is programmatically closed.
|
|
43
|
+
*/
|
|
44
|
+
returnValue: string;
|
|
45
|
+
/**
|
|
46
|
+
* By default if a modal is too big for the browser window,
|
|
47
|
+
* the entire modal will scroll. This setting changes that behavior
|
|
48
|
+
* so that the body of the modal scrolls instead, with the modal
|
|
49
|
+
* itself remaining fixed.
|
|
50
|
+
*/
|
|
51
|
+
scrollable: boolean;
|
|
52
|
+
connectedCallback(): void;
|
|
53
|
+
/**
|
|
54
|
+
* Show the modal, automatically moving focus to the modal or a child
|
|
55
|
+
* element with an `autofocus` attribute.
|
|
56
|
+
*/
|
|
57
|
+
showModal(): void;
|
|
58
|
+
/**
|
|
59
|
+
* Programmatically close the modal.
|
|
60
|
+
* @param returnValue An optional value to indicate why the modal was closed.
|
|
61
|
+
*/
|
|
62
|
+
close(returnValue?: string): void;
|
|
63
|
+
/**
|
|
64
|
+
* Programmatically focus the modal.
|
|
65
|
+
* @param options An object which controls aspects of the focusing process.
|
|
66
|
+
*/
|
|
67
|
+
focus(options?: FocusOptions): void;
|
|
68
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
69
|
+
protected handleOpenUpdated(): void;
|
|
70
|
+
private enableScroll;
|
|
71
|
+
private handleDismiss;
|
|
72
|
+
/**
|
|
73
|
+
* capture the last button clicked, so that we can polyfill `submitter` property in submit event
|
|
74
|
+
*/
|
|
75
|
+
private trackLastButton;
|
|
76
|
+
private polyfillSubmitter;
|
|
77
|
+
private handleSubmit;
|
|
78
|
+
}
|
|
79
|
+
declare global {
|
|
80
|
+
interface HTMLElementTagNameMap {
|
|
81
|
+
"nord-modal": Modal;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
export {};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { LitElement } from "lit";
|
|
2
|
+
declare const Skeleton_base: typeof LitElement;
|
|
3
|
+
/**
|
|
4
|
+
* Skeletons are used to provide a low fidelity representation of content
|
|
5
|
+
* before it appears in a view. This improves the perceived loading time
|
|
6
|
+
* for our users.
|
|
7
|
+
*
|
|
8
|
+
* @status draft
|
|
9
|
+
* @category feedback
|
|
10
|
+
*/
|
|
11
|
+
export default class Skeleton extends Skeleton_base {
|
|
12
|
+
static styles: import("lit").CSSResult[];
|
|
13
|
+
/**
|
|
14
|
+
* Determines which animation effect the skeleton will use.
|
|
15
|
+
*/
|
|
16
|
+
effect: "pulse" | "sheen" | "none";
|
|
17
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
18
|
+
}
|
|
19
|
+
declare global {
|
|
20
|
+
interface HTMLElementTagNameMap {
|
|
21
|
+
"nord-skeleton": Skeleton;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
export {};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { LitElement } from "lit";
|
|
2
|
+
declare const Tab_base: typeof LitElement;
|
|
3
|
+
/**
|
|
4
|
+
* The interactive tab button for use within the tab group component.
|
|
5
|
+
*
|
|
6
|
+
* @status draft
|
|
7
|
+
* @category navigation
|
|
8
|
+
* @slot - The tab button content.
|
|
9
|
+
*/
|
|
10
|
+
export default class Tab extends Tab_base {
|
|
11
|
+
static styles: import("lit").CSSResult[];
|
|
12
|
+
private defaultSlot;
|
|
13
|
+
/**
|
|
14
|
+
* Whether the tab item is selected
|
|
15
|
+
*/
|
|
16
|
+
selected: boolean;
|
|
17
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
18
|
+
/**
|
|
19
|
+
* Apply accessible attributes and values to the tab button.
|
|
20
|
+
* Observe the selected property if it changes
|
|
21
|
+
*/
|
|
22
|
+
protected handleSelectionChange(): void;
|
|
23
|
+
connectedCallback(): void;
|
|
24
|
+
}
|
|
25
|
+
declare global {
|
|
26
|
+
interface HTMLElementTagNameMap {
|
|
27
|
+
"nord-tab": Tab;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import "../stack/Stack.js";
|