@anoki/fse-ui
Version:
FSE UI components library
3 lines (2 loc) • 8.98 kB
JavaScript
;Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const C=require("./index.cjs802.js"),a=require("./index.cjs803.js"),i=require("./index.cjs804.js");function H(t){const e=i.getComputedStyle(t);let o=parseFloat(e.width)||0,n=parseFloat(e.height)||0;const s=i.isHTMLElement(t),c=s?t.offsetWidth:o,r=s?t.offsetHeight:n,l=a.round(o)!==c||a.round(n)!==r;return l&&(o=c,n=r),{width:o,height:n,$:l}}function W(t){return i.isElement(t)?t:t.contextElement}function b(t){const e=W(t);if(!i.isHTMLElement(e))return a.createCoords(1);const o=e.getBoundingClientRect(),{width:n,height:s,$:c}=H(e);let r=(c?a.round(o.width):o.width)/n,l=(c?a.round(o.height):o.height)/s;return(!r||!Number.isFinite(r))&&(r=1),(!l||!Number.isFinite(l))&&(l=1),{x:r,y:l}}const q=a.createCoords(0);function A(t){const e=i.getWindow(t);return!i.isWebKit()||!e.visualViewport?q:{x:e.visualViewport.offsetLeft,y:e.visualViewport.offsetTop}}function U(t,e,o){return e===void 0&&(e=!1),!o||e&&o!==i.getWindow(t)?!1:e}function R(t,e,o,n){e===void 0&&(e=!1),o===void 0&&(o=!1);const s=t.getBoundingClientRect(),c=W(t);let r=a.createCoords(1);e&&(n?i.isElement(n)&&(r=b(n)):r=b(t));const l=U(c,o,n)?A(c):a.createCoords(0);let f=(s.left+l.x)/r.x,u=(s.top+l.y)/r.y,d=s.width/r.x,h=s.height/r.y;if(c){const m=i.getWindow(c),g=n&&i.isElement(n)?i.getWindow(n):n;let y=m,w=i.getFrameElement(y);for(;w&&n&&g!==y;){const v=b(w),p=w.getBoundingClientRect(),x=i.getComputedStyle(w),E=p.left+(w.clientLeft+parseFloat(x.paddingLeft))*v.x,L=p.top+(w.clientTop+parseFloat(x.paddingTop))*v.y;f*=v.x,u*=v.y,d*=v.x,h*=v.y,f+=E,u+=L,y=i.getWindow(w),w=i.getFrameElement(y)}}return a.rectToClientRect({width:d,height:h,x:f,y:u})}function O(t,e){const o=i.getNodeScroll(t).scrollLeft;return e?e.left+o:R(i.getDocumentElement(t)).left+o}function z(t,e){const o=t.getBoundingClientRect(),n=o.left+e.scrollLeft-O(t,o),s=o.top+e.scrollTop;return{x:n,y:s}}function k(t){let{elements:e,rect:o,offsetParent:n,strategy:s}=t;const c=s==="fixed",r=i.getDocumentElement(n),l=e?i.isTopLayer(e.floating):!1;if(n===r||l&&c)return o;let f={scrollLeft:0,scrollTop:0},u=a.createCoords(1);const d=a.createCoords(0),h=i.isHTMLElement(n);if((h||!h&&!c)&&((i.getNodeName(n)!=="body"||i.isOverflowElement(r))&&(f=i.getNodeScroll(n)),h)){const g=R(n);u=b(n),d.x=g.x+n.clientLeft,d.y=g.y+n.clientTop}const m=r&&!h&&!c?z(r,f):a.createCoords(0);return{width:o.width*u.x,height:o.height*u.y,x:o.x*u.x-f.scrollLeft*u.x+d.x+m.x,y:o.y*u.y-f.scrollTop*u.y+d.y+m.y}}function X(t){return Array.from(t.getClientRects())}function K(t){const e=i.getDocumentElement(t),o=i.getNodeScroll(t),n=t.ownerDocument.body,s=a.max(e.scrollWidth,e.clientWidth,n.scrollWidth,n.clientWidth),c=a.max(e.scrollHeight,e.clientHeight,n.scrollHeight,n.clientHeight);let r=-o.scrollLeft+O(t);const l=-o.scrollTop;return i.getComputedStyle(n).direction==="rtl"&&(r+=a.max(e.clientWidth,n.clientWidth)-s),{width:s,height:c,x:r,y:l}}const F=25;function $(t,e){const o=i.getWindow(t),n=i.getDocumentElement(t),s=o.visualViewport;let c=n.clientWidth,r=n.clientHeight,l=0,f=0;if(s){c=s.width,r=s.height;const d=i.isWebKit();(!d||d&&e==="fixed")&&(l=s.offsetLeft,f=s.offsetTop)}const u=O(n);if(u<=0){const d=n.ownerDocument,h=d.body,m=getComputedStyle(h),g=d.compatMode==="CSS1Compat"&&parseFloat(m.marginLeft)+parseFloat(m.marginRight)||0,y=Math.abs(n.clientWidth-h.clientWidth-g);y<=F&&(c-=y)}else u<=F&&(c+=u);return{width:c,height:r,x:l,y:f}}function j(t,e){const o=R(t,!0,e==="fixed"),n=o.top+t.clientTop,s=o.left+t.clientLeft,c=i.isHTMLElement(t)?b(t):a.createCoords(1),r=t.clientWidth*c.x,l=t.clientHeight*c.y,f=s*c.x,u=n*c.y;return{width:r,height:l,x:f,y:u}}function M(t,e,o){let n;if(e==="viewport")n=$(t,o);else if(e==="document")n=K(i.getDocumentElement(t));else if(i.isElement(e))n=j(e,o);else{const s=A(t);n={x:e.x-s.x,y:e.y-s.y,width:e.width,height:e.height}}return a.rectToClientRect(n)}function I(t,e){const o=i.getParentNode(t);return o===e||!i.isElement(o)||i.isLastTraversableNode(o)?!1:i.getComputedStyle(o).position==="fixed"||I(o,e)}function G(t,e){const o=e.get(t);if(o)return o;let n=i.getOverflowAncestors(t,[],!1).filter(l=>i.isElement(l)&&i.getNodeName(l)!=="body"),s=null;const c=i.getComputedStyle(t).position==="fixed";let r=c?i.getParentNode(t):t;for(;i.isElement(r)&&!i.isLastTraversableNode(r);){const l=i.getComputedStyle(r),f=i.isContainingBlock(r);!f&&l.position==="fixed"&&(s=null),(c?!f&&!s:!f&&l.position==="static"&&!!s&&(s.position==="absolute"||s.position==="fixed")||i.isOverflowElement(r)&&!f&&I(t,r))?n=n.filter(d=>d!==r):s=l,r=i.getParentNode(r)}return e.set(t,n),n}function J(t){let{element:e,boundary:o,rootBoundary:n,strategy:s}=t;const r=[...o==="clippingAncestors"?i.isTopLayer(e)?[]:G(e,this._c):[].concat(o),n],l=M(e,r[0],s);let f=l.top,u=l.right,d=l.bottom,h=l.left;for(let m=1;m<r.length;m++){const g=M(e,r[m],s);f=a.max(g.top,f),u=a.min(g.right,u),d=a.min(g.bottom,d),h=a.max(g.left,h)}return{width:u-h,height:d-f,x:h,y:f}}function Q(t){const{width:e,height:o}=H(t);return{width:e,height:o}}function Y(t,e,o){const n=i.isHTMLElement(e),s=i.getDocumentElement(e),c=o==="fixed",r=R(t,!0,c,e);let l={scrollLeft:0,scrollTop:0};const f=a.createCoords(0);function u(){f.x=O(s)}if(n||!n&&!c)if((i.getNodeName(e)!=="body"||i.isOverflowElement(s))&&(l=i.getNodeScroll(e)),n){const g=R(e,!0,c,e);f.x=g.x+e.clientLeft,f.y=g.y+e.clientTop}else s&&u();c&&!n&&s&&u();const d=s&&!n&&!c?z(s,l):a.createCoords(0),h=r.left+l.scrollLeft-f.x-d.x,m=r.top+l.scrollTop-f.y-d.y;return{x:h,y:m,width:r.width,height:r.height}}function S(t){return i.getComputedStyle(t).position==="static"}function B(t,e){if(!i.isHTMLElement(t)||i.getComputedStyle(t).position==="fixed")return null;if(e)return e(t);let o=t.offsetParent;return i.getDocumentElement(t)===o&&(o=o.ownerDocument.body),o}function _(t,e){const o=i.getWindow(t);if(i.isTopLayer(t))return o;if(!i.isHTMLElement(t)){let s=i.getParentNode(t);for(;s&&!i.isLastTraversableNode(s);){if(i.isElement(s)&&!S(s))return s;s=i.getParentNode(s)}return o}let n=B(t,e);for(;n&&i.isTableElement(n)&&S(n);)n=B(n,e);return n&&i.isLastTraversableNode(n)&&S(n)&&!i.isContainingBlock(n)?o:n||i.getContainingBlock(t)||o}const Z=async function(t){const e=this.getOffsetParent||_,o=this.getDimensions,n=await o(t.floating);return{reference:Y(t.reference,await e(t.floating),t.strategy),floating:{x:0,y:0,width:n.width,height:n.height}}};function tt(t){return i.getComputedStyle(t).direction==="rtl"}const V={convertOffsetParentRelativeRectToViewportRelativeRect:k,getDocumentElement:i.getDocumentElement,getClippingRect:J,getOffsetParent:_,getElementRects:Z,getClientRects:X,getDimensions:Q,getScale:b,isElement:i.isElement,isRTL:tt};function P(t,e){return t.x===e.x&&t.y===e.y&&t.width===e.width&&t.height===e.height}function et(t,e){let o=null,n;const s=i.getDocumentElement(t);function c(){var l;clearTimeout(n),(l=o)==null||l.disconnect(),o=null}function r(l,f){l===void 0&&(l=!1),f===void 0&&(f=1),c();const u=t.getBoundingClientRect(),{left:d,top:h,width:m,height:g}=u;if(l||e(),!m||!g)return;const y=a.floor(h),w=a.floor(s.clientWidth-(d+m)),v=a.floor(s.clientHeight-(h+g)),p=a.floor(d),E={rootMargin:-y+"px "+-w+"px "+-v+"px "+-p+"px",threshold:a.max(0,a.min(1,f))||1};let L=!0;function N(D){const T=D[0].intersectionRatio;if(T!==f){if(!L)return r();T?r(!1,T):n=setTimeout(()=>{r(!1,1e-7)},1e3)}T===1&&!P(u,t.getBoundingClientRect())&&r(),L=!1}try{o=new IntersectionObserver(N,{...E,root:s.ownerDocument})}catch{o=new IntersectionObserver(N,E)}o.observe(t)}return r(!0),c}function ot(t,e,o,n){n===void 0&&(n={});const{ancestorScroll:s=!0,ancestorResize:c=!0,elementResize:r=typeof ResizeObserver=="function",layoutShift:l=typeof IntersectionObserver=="function",animationFrame:f=!1}=n,u=W(t),d=s||c?[...u?i.getOverflowAncestors(u):[],...e?i.getOverflowAncestors(e):[]]:[];d.forEach(p=>{s&&p.addEventListener("scroll",o,{passive:!0}),c&&p.addEventListener("resize",o)});const h=u&&l?et(u,o):null;let m=-1,g=null;r&&(g=new ResizeObserver(p=>{let[x]=p;x&&x.target===u&&g&&e&&(g.unobserve(e),cancelAnimationFrame(m),m=requestAnimationFrame(()=>{var E;(E=g)==null||E.observe(e)})),o()}),u&&!f&&g.observe(u),e&&g.observe(e));let y,w=f?R(t):null;f&&v();function v(){const p=R(t);w&&!P(w,p)&&o(),w=p,y=requestAnimationFrame(v)}return o(),()=>{var p;d.forEach(x=>{s&&x.removeEventListener("scroll",o),c&&x.removeEventListener("resize",o)}),h==null||h(),(p=g)==null||p.disconnect(),g=null,f&&cancelAnimationFrame(y)}}const nt=C.offset,it=C.shift,st=C.flip,rt=C.size,ct=C.hide,lt=C.arrow,ft=C.limitShift,ut=(t,e,o)=>{const n=new Map,s={platform:V,...o},c={...s.platform,_c:n};return C.computePosition(t,e,{...s,platform:c})};exports.getOverflowAncestors=i.getOverflowAncestors;exports.arrow=lt;exports.autoUpdate=ot;exports.computePosition=ut;exports.flip=st;exports.hide=ct;exports.limitShift=ft;exports.offset=nt;exports.platform=V;exports.shift=it;exports.size=rt;
//# sourceMappingURL=index.cjs729.js.map