123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324 |
- import $kY93V$babelruntimehelpersesmextends from "@babel/runtime/helpers/esm/extends";
- import {useState as $kY93V$useState, createElement as $kY93V$createElement, forwardRef as $kY93V$forwardRef, useRef as $kY93V$useRef, useEffect as $kY93V$useEffect} from "react";
- import {useFloating as $kY93V$useFloating, autoUpdate as $kY93V$autoUpdate, offset as $kY93V$offset, shift as $kY93V$shift, limitShift as $kY93V$limitShift, flip as $kY93V$flip, size as $kY93V$size, arrow as $kY93V$arrow, hide as $kY93V$hide} from "@floating-ui/react-dom";
- import {Root as $kY93V$Root} from "@radix-ui/react-arrow";
- import {useComposedRefs as $kY93V$useComposedRefs} from "@radix-ui/react-compose-refs";
- import {createContextScope as $kY93V$createContextScope} from "@radix-ui/react-context";
- import {Primitive as $kY93V$Primitive} from "@radix-ui/react-primitive";
- import {useCallbackRef as $kY93V$useCallbackRef} from "@radix-ui/react-use-callback-ref";
- import {useLayoutEffect as $kY93V$useLayoutEffect} from "@radix-ui/react-use-layout-effect";
- import {useSize as $kY93V$useSize} from "@radix-ui/react-use-size";
- const $cf1ac5d9fe0e8206$export$36f0086da09c4b9f = [
- 'top',
- 'right',
- 'bottom',
- 'left'
- ];
- const $cf1ac5d9fe0e8206$export$3671ffab7b302fc9 = [
- 'start',
- 'center',
- 'end'
- ];
- /* -------------------------------------------------------------------------------------------------
- * Popper
- * -----------------------------------------------------------------------------------------------*/ const $cf1ac5d9fe0e8206$var$POPPER_NAME = 'Popper';
- const [$cf1ac5d9fe0e8206$var$createPopperContext, $cf1ac5d9fe0e8206$export$722aac194ae923] = $kY93V$createContextScope($cf1ac5d9fe0e8206$var$POPPER_NAME);
- const [$cf1ac5d9fe0e8206$var$PopperProvider, $cf1ac5d9fe0e8206$var$usePopperContext] = $cf1ac5d9fe0e8206$var$createPopperContext($cf1ac5d9fe0e8206$var$POPPER_NAME);
- const $cf1ac5d9fe0e8206$export$badac9ada3a0bdf9 = (props)=>{
- const { __scopePopper: __scopePopper , children: children } = props;
- const [anchor, setAnchor] = $kY93V$useState(null);
- return /*#__PURE__*/ $kY93V$createElement($cf1ac5d9fe0e8206$var$PopperProvider, {
- scope: __scopePopper,
- anchor: anchor,
- onAnchorChange: setAnchor
- }, children);
- };
- /*#__PURE__*/ Object.assign($cf1ac5d9fe0e8206$export$badac9ada3a0bdf9, {
- displayName: $cf1ac5d9fe0e8206$var$POPPER_NAME
- });
- /* -------------------------------------------------------------------------------------------------
- * PopperAnchor
- * -----------------------------------------------------------------------------------------------*/ const $cf1ac5d9fe0e8206$var$ANCHOR_NAME = 'PopperAnchor';
- const $cf1ac5d9fe0e8206$export$ecd4e1ccab6ed6d = /*#__PURE__*/ $kY93V$forwardRef((props, forwardedRef)=>{
- const { __scopePopper: __scopePopper , virtualRef: virtualRef , ...anchorProps } = props;
- const context = $cf1ac5d9fe0e8206$var$usePopperContext($cf1ac5d9fe0e8206$var$ANCHOR_NAME, __scopePopper);
- const ref = $kY93V$useRef(null);
- const composedRefs = $kY93V$useComposedRefs(forwardedRef, ref);
- $kY93V$useEffect(()=>{
- // Consumer can anchor the popper to something that isn't
- // a DOM node e.g. pointer position, so we override the
- // `anchorRef` with their virtual ref in this case.
- context.onAnchorChange((virtualRef === null || virtualRef === void 0 ? void 0 : virtualRef.current) || ref.current);
- });
- return virtualRef ? null : /*#__PURE__*/ $kY93V$createElement($kY93V$Primitive.div, $kY93V$babelruntimehelpersesmextends({}, anchorProps, {
- ref: composedRefs
- }));
- });
- /*#__PURE__*/ Object.assign($cf1ac5d9fe0e8206$export$ecd4e1ccab6ed6d, {
- displayName: $cf1ac5d9fe0e8206$var$ANCHOR_NAME
- });
- /* -------------------------------------------------------------------------------------------------
- * PopperContent
- * -----------------------------------------------------------------------------------------------*/ const $cf1ac5d9fe0e8206$var$CONTENT_NAME = 'PopperContent';
- const [$cf1ac5d9fe0e8206$var$PopperContentProvider, $cf1ac5d9fe0e8206$var$useContentContext] = $cf1ac5d9fe0e8206$var$createPopperContext($cf1ac5d9fe0e8206$var$CONTENT_NAME);
- const $cf1ac5d9fe0e8206$export$bc4ae5855d3c4fc = /*#__PURE__*/ $kY93V$forwardRef((props, forwardedRef)=>{
- var _arrowSize$width, _arrowSize$height, _middlewareData$arrow, _middlewareData$arrow2, _middlewareData$arrow3, _middlewareData$trans, _middlewareData$trans2, _middlewareData$hide;
- const { __scopePopper: __scopePopper , side: side = 'bottom' , sideOffset: sideOffset = 0 , align: align = 'center' , alignOffset: alignOffset = 0 , arrowPadding: arrowPadding = 0 , avoidCollisions: avoidCollisions = true , collisionBoundary: collisionBoundary = [] , collisionPadding: collisionPaddingProp = 0 , sticky: sticky = 'partial' , hideWhenDetached: hideWhenDetached = false , updatePositionStrategy: updatePositionStrategy = 'optimized' , onPlaced: onPlaced , ...contentProps } = props;
- const context = $cf1ac5d9fe0e8206$var$usePopperContext($cf1ac5d9fe0e8206$var$CONTENT_NAME, __scopePopper);
- const [content, setContent] = $kY93V$useState(null);
- const composedRefs = $kY93V$useComposedRefs(forwardedRef, (node)=>setContent(node)
- );
- const [arrow, setArrow] = $kY93V$useState(null);
- const arrowSize = $kY93V$useSize(arrow);
- const arrowWidth = (_arrowSize$width = arrowSize === null || arrowSize === void 0 ? void 0 : arrowSize.width) !== null && _arrowSize$width !== void 0 ? _arrowSize$width : 0;
- const arrowHeight = (_arrowSize$height = arrowSize === null || arrowSize === void 0 ? void 0 : arrowSize.height) !== null && _arrowSize$height !== void 0 ? _arrowSize$height : 0;
- const desiredPlacement = side + (align !== 'center' ? '-' + align : '');
- const collisionPadding = typeof collisionPaddingProp === 'number' ? collisionPaddingProp : {
- top: 0,
- right: 0,
- bottom: 0,
- left: 0,
- ...collisionPaddingProp
- };
- const boundary = Array.isArray(collisionBoundary) ? collisionBoundary : [
- collisionBoundary
- ];
- const hasExplicitBoundaries = boundary.length > 0;
- const detectOverflowOptions = {
- padding: collisionPadding,
- boundary: boundary.filter($cf1ac5d9fe0e8206$var$isNotNull),
- // with `strategy: 'fixed'`, this is the only way to get it to respect boundaries
- altBoundary: hasExplicitBoundaries
- };
- const { refs: refs , floatingStyles: floatingStyles , placement: placement , isPositioned: isPositioned , middlewareData: middlewareData } = $kY93V$useFloating({
- // default to `fixed` strategy so users don't have to pick and we also avoid focus scroll issues
- strategy: 'fixed',
- placement: desiredPlacement,
- whileElementsMounted: (...args)=>{
- const cleanup = $kY93V$autoUpdate(...args, {
- animationFrame: updatePositionStrategy === 'always'
- });
- return cleanup;
- },
- elements: {
- reference: context.anchor
- },
- middleware: [
- $kY93V$offset({
- mainAxis: sideOffset + arrowHeight,
- alignmentAxis: alignOffset
- }),
- avoidCollisions && $kY93V$shift({
- mainAxis: true,
- crossAxis: false,
- limiter: sticky === 'partial' ? $kY93V$limitShift() : undefined,
- ...detectOverflowOptions
- }),
- avoidCollisions && $kY93V$flip({
- ...detectOverflowOptions
- }),
- $kY93V$size({
- ...detectOverflowOptions,
- apply: ({ elements: elements , rects: rects , availableWidth: availableWidth , availableHeight: availableHeight })=>{
- const { width: anchorWidth , height: anchorHeight } = rects.reference;
- const contentStyle = elements.floating.style;
- contentStyle.setProperty('--radix-popper-available-width', `${availableWidth}px`);
- contentStyle.setProperty('--radix-popper-available-height', `${availableHeight}px`);
- contentStyle.setProperty('--radix-popper-anchor-width', `${anchorWidth}px`);
- contentStyle.setProperty('--radix-popper-anchor-height', `${anchorHeight}px`);
- }
- }),
- arrow && $kY93V$arrow({
- element: arrow,
- padding: arrowPadding
- }),
- $cf1ac5d9fe0e8206$var$transformOrigin({
- arrowWidth: arrowWidth,
- arrowHeight: arrowHeight
- }),
- hideWhenDetached && $kY93V$hide({
- strategy: 'referenceHidden',
- ...detectOverflowOptions
- })
- ]
- });
- const [placedSide, placedAlign] = $cf1ac5d9fe0e8206$var$getSideAndAlignFromPlacement(placement);
- const handlePlaced = $kY93V$useCallbackRef(onPlaced);
- $kY93V$useLayoutEffect(()=>{
- if (isPositioned) handlePlaced === null || handlePlaced === void 0 || handlePlaced();
- }, [
- isPositioned,
- handlePlaced
- ]);
- const arrowX = (_middlewareData$arrow = middlewareData.arrow) === null || _middlewareData$arrow === void 0 ? void 0 : _middlewareData$arrow.x;
- const arrowY = (_middlewareData$arrow2 = middlewareData.arrow) === null || _middlewareData$arrow2 === void 0 ? void 0 : _middlewareData$arrow2.y;
- const cannotCenterArrow = ((_middlewareData$arrow3 = middlewareData.arrow) === null || _middlewareData$arrow3 === void 0 ? void 0 : _middlewareData$arrow3.centerOffset) !== 0;
- const [contentZIndex, setContentZIndex] = $kY93V$useState();
- $kY93V$useLayoutEffect(()=>{
- if (content) setContentZIndex(window.getComputedStyle(content).zIndex);
- }, [
- content
- ]);
- return /*#__PURE__*/ $kY93V$createElement("div", {
- ref: refs.setFloating,
- "data-radix-popper-content-wrapper": "",
- style: {
- ...floatingStyles,
- transform: isPositioned ? floatingStyles.transform : 'translate(0, -200%)',
- // keep off the page when measuring
- minWidth: 'max-content',
- zIndex: contentZIndex,
- ['--radix-popper-transform-origin']: [
- (_middlewareData$trans = middlewareData.transformOrigin) === null || _middlewareData$trans === void 0 ? void 0 : _middlewareData$trans.x,
- (_middlewareData$trans2 = middlewareData.transformOrigin) === null || _middlewareData$trans2 === void 0 ? void 0 : _middlewareData$trans2.y
- ].join(' ')
- } // Floating UI interally calculates logical alignment based the `dir` attribute on
- ,
- dir: props.dir
- }, /*#__PURE__*/ $kY93V$createElement($cf1ac5d9fe0e8206$var$PopperContentProvider, {
- scope: __scopePopper,
- placedSide: placedSide,
- onArrowChange: setArrow,
- arrowX: arrowX,
- arrowY: arrowY,
- shouldHideArrow: cannotCenterArrow
- }, /*#__PURE__*/ $kY93V$createElement($kY93V$Primitive.div, $kY93V$babelruntimehelpersesmextends({
- "data-side": placedSide,
- "data-align": placedAlign
- }, contentProps, {
- ref: composedRefs,
- style: {
- ...contentProps.style,
- // if the PopperContent hasn't been placed yet (not all measurements done)
- // we prevent animations so that users's animation don't kick in too early referring wrong sides
- animation: !isPositioned ? 'none' : undefined,
- // hide the content if using the hide middleware and should be hidden
- opacity: (_middlewareData$hide = middlewareData.hide) !== null && _middlewareData$hide !== void 0 && _middlewareData$hide.referenceHidden ? 0 : undefined
- }
- }))));
- });
- /*#__PURE__*/ Object.assign($cf1ac5d9fe0e8206$export$bc4ae5855d3c4fc, {
- displayName: $cf1ac5d9fe0e8206$var$CONTENT_NAME
- });
- /* -------------------------------------------------------------------------------------------------
- * PopperArrow
- * -----------------------------------------------------------------------------------------------*/ const $cf1ac5d9fe0e8206$var$ARROW_NAME = 'PopperArrow';
- const $cf1ac5d9fe0e8206$var$OPPOSITE_SIDE = {
- top: 'bottom',
- right: 'left',
- bottom: 'top',
- left: 'right'
- };
- const $cf1ac5d9fe0e8206$export$79d62cd4e10a3fd0 = /*#__PURE__*/ $kY93V$forwardRef(function $cf1ac5d9fe0e8206$export$79d62cd4e10a3fd0(props, forwardedRef) {
- const { __scopePopper: __scopePopper , ...arrowProps } = props;
- const contentContext = $cf1ac5d9fe0e8206$var$useContentContext($cf1ac5d9fe0e8206$var$ARROW_NAME, __scopePopper);
- const baseSide = $cf1ac5d9fe0e8206$var$OPPOSITE_SIDE[contentContext.placedSide];
- return(/*#__PURE__*/ // we have to use an extra wrapper because `ResizeObserver` (used by `useSize`)
- // doesn't report size as we'd expect on SVG elements.
- // it reports their bounding box which is effectively the largest path inside the SVG.
- $kY93V$createElement("span", {
- ref: contentContext.onArrowChange,
- style: {
- position: 'absolute',
- left: contentContext.arrowX,
- top: contentContext.arrowY,
- [baseSide]: 0,
- transformOrigin: {
- top: '',
- right: '0 0',
- bottom: 'center 0',
- left: '100% 0'
- }[contentContext.placedSide],
- transform: {
- top: 'translateY(100%)',
- right: 'translateY(50%) rotate(90deg) translateX(-50%)',
- bottom: `rotate(180deg)`,
- left: 'translateY(50%) rotate(-90deg) translateX(50%)'
- }[contentContext.placedSide],
- visibility: contentContext.shouldHideArrow ? 'hidden' : undefined
- }
- }, /*#__PURE__*/ $kY93V$createElement($kY93V$Root, $kY93V$babelruntimehelpersesmextends({}, arrowProps, {
- ref: forwardedRef,
- style: {
- ...arrowProps.style,
- // ensures the element can be measured correctly (mostly for if SVG)
- display: 'block'
- }
- }))));
- });
- /*#__PURE__*/ Object.assign($cf1ac5d9fe0e8206$export$79d62cd4e10a3fd0, {
- displayName: $cf1ac5d9fe0e8206$var$ARROW_NAME
- });
- /* -----------------------------------------------------------------------------------------------*/ function $cf1ac5d9fe0e8206$var$isNotNull(value) {
- return value !== null;
- }
- const $cf1ac5d9fe0e8206$var$transformOrigin = (options)=>({
- name: 'transformOrigin',
- options: options,
- fn (data) {
- var _middlewareData$arrow4, _middlewareData$arrow5, _middlewareData$arrow6, _middlewareData$arrow7, _middlewareData$arrow8;
- const { placement: placement , rects: rects , middlewareData: middlewareData } = data;
- const cannotCenterArrow = ((_middlewareData$arrow4 = middlewareData.arrow) === null || _middlewareData$arrow4 === void 0 ? void 0 : _middlewareData$arrow4.centerOffset) !== 0;
- const isArrowHidden = cannotCenterArrow;
- const arrowWidth = isArrowHidden ? 0 : options.arrowWidth;
- const arrowHeight = isArrowHidden ? 0 : options.arrowHeight;
- const [placedSide, placedAlign] = $cf1ac5d9fe0e8206$var$getSideAndAlignFromPlacement(placement);
- const noArrowAlign = {
- start: '0%',
- center: '50%',
- end: '100%'
- }[placedAlign];
- const arrowXCenter = ((_middlewareData$arrow5 = (_middlewareData$arrow6 = middlewareData.arrow) === null || _middlewareData$arrow6 === void 0 ? void 0 : _middlewareData$arrow6.x) !== null && _middlewareData$arrow5 !== void 0 ? _middlewareData$arrow5 : 0) + arrowWidth / 2;
- const arrowYCenter = ((_middlewareData$arrow7 = (_middlewareData$arrow8 = middlewareData.arrow) === null || _middlewareData$arrow8 === void 0 ? void 0 : _middlewareData$arrow8.y) !== null && _middlewareData$arrow7 !== void 0 ? _middlewareData$arrow7 : 0) + arrowHeight / 2;
- let x = '';
- let y = '';
- if (placedSide === 'bottom') {
- x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`;
- y = `${-arrowHeight}px`;
- } else if (placedSide === 'top') {
- x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`;
- y = `${rects.floating.height + arrowHeight}px`;
- } else if (placedSide === 'right') {
- x = `${-arrowHeight}px`;
- y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`;
- } else if (placedSide === 'left') {
- x = `${rects.floating.width + arrowHeight}px`;
- y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`;
- }
- return {
- data: {
- x: x,
- y: y
- }
- };
- }
- })
- ;
- function $cf1ac5d9fe0e8206$var$getSideAndAlignFromPlacement(placement) {
- const [side, align = 'center'] = placement.split('-');
- return [
- side,
- align
- ];
- }
- const $cf1ac5d9fe0e8206$export$be92b6f5f03c0fe9 = $cf1ac5d9fe0e8206$export$badac9ada3a0bdf9;
- const $cf1ac5d9fe0e8206$export$b688253958b8dfe7 = $cf1ac5d9fe0e8206$export$ecd4e1ccab6ed6d;
- const $cf1ac5d9fe0e8206$export$7c6e2c02157bb7d2 = $cf1ac5d9fe0e8206$export$bc4ae5855d3c4fc;
- const $cf1ac5d9fe0e8206$export$21b07c8f274aebd5 = $cf1ac5d9fe0e8206$export$79d62cd4e10a3fd0;
- export {$cf1ac5d9fe0e8206$export$722aac194ae923 as createPopperScope, $cf1ac5d9fe0e8206$export$badac9ada3a0bdf9 as Popper, $cf1ac5d9fe0e8206$export$ecd4e1ccab6ed6d as PopperAnchor, $cf1ac5d9fe0e8206$export$bc4ae5855d3c4fc as PopperContent, $cf1ac5d9fe0e8206$export$79d62cd4e10a3fd0 as PopperArrow, $cf1ac5d9fe0e8206$export$be92b6f5f03c0fe9 as Root, $cf1ac5d9fe0e8206$export$b688253958b8dfe7 as Anchor, $cf1ac5d9fe0e8206$export$7c6e2c02157bb7d2 as Content, $cf1ac5d9fe0e8206$export$21b07c8f274aebd5 as Arrow, $cf1ac5d9fe0e8206$export$36f0086da09c4b9f as SIDE_OPTIONS, $cf1ac5d9fe0e8206$export$3671ffab7b302fc9 as ALIGN_OPTIONS};
- //# sourceMappingURL=index.mjs.map
|