@data-slot/hover-card 0.2.93 → 0.2.95

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/README.md CHANGED
@@ -235,6 +235,7 @@ When one hover-card closes, another hovered shortly after can open immediately (
235
235
  - Set to `0` to disable warm-up behavior
236
236
  - Warm-up applies across hover-card instances
237
237
  - Warm-up opens add `data-instant` (root/content/positioner) for that open cycle, so CSS can disable animations
238
+ - During warm handoff to another hover-card trigger, the stale popup closes immediately (bypasses `closeDelay`) and that close cycle is marked with `data-instant`
238
239
 
239
240
  ## Accessibility
240
241
 
package/dist/index.cjs CHANGED
@@ -1 +1 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});let e=require(`@data-slot/core`);const t=[`top`,`right`,`bottom`,`left`],n=[`start`,`center`,`end`];let r=0;function i(i,a={}){let o=(0,e.getPart)(i,`hover-card-trigger`),s=(0,e.getPart)(i,`hover-card-content`),c=(0,e.getPart)(i,`hover-card-positioner`),l=c&&s&&c.contains(s)?c:null,u=(0,e.getPart)(i,`hover-card-portal`),d=u&&l&&u.contains(l)?u:null;if(!o||!s)throw Error(`Hover-card requires trigger and content slots`);let ee=a.open!==void 0,f=a.defaultOpen??(0,e.getDataBool)(i,`defaultOpen`)??!1,p=a.delay??(0,e.getDataNumber)(i,`delay`)??700,m=a.skipDelayDuration??(0,e.getDataNumber)(i,`skipDelayDuration`)??300,h=a.closeDelay??(0,e.getDataNumber)(i,`closeDelay`)??300,g=a.onOpenChange,_=a.closeOnClickOutside??(0,e.getDataBool)(i,`closeOnClickOutside`)??!0,v=a.closeOnEscape??(0,e.getDataBool)(i,`closeOnEscape`)??!0,y=a.portal??(0,e.getDataBool)(s,`portal`)??(0,e.getDataBool)(i,`portal`)??!0,b=(t,n)=>(0,e.getDataEnum)(s,t,n)??(l?(0,e.getDataEnum)(l,t,n):void 0)??(0,e.getDataEnum)(i,t,n),x=t=>(0,e.getDataNumber)(s,t)??(l?(0,e.getDataNumber)(l,t):void 0)??(0,e.getDataNumber)(i,t),te=t=>(0,e.getDataBool)(s,t)??(l?(0,e.getDataBool)(l,t):void 0)??(0,e.getDataBool)(i,t),S=a.side??b(`side`,t)??`bottom`,C=a.align??b(`align`,n)??`center`,w=a.sideOffset??x(`sideOffset`)??4,T=a.alignOffset??x(`alignOffset`)??0,ne=a.avoidCollisions??te(`avoidCollisions`)??!0,E=a.collisionPadding??x(`collisionPadding`)??8,D=a.open??f,O=!1,k=!1,A=!1,j=!1,M=!1,N=null,P=null,F=-1/0,I=-1/0,L=[],R=(0,e.createPortalLifecycle)({content:s,root:i,enabled:y,wrapperSlot:l?void 0:`hover-card-positioner`,container:l??void 0,mountTarget:l?d??l:void 0}),z=(0,e.ensureId)(s,`hover-card-content`);o.setAttribute(`aria-haspopup`,`dialog`),o.setAttribute(`aria-controls`,z),s.setAttribute(`data-side`,S),s.setAttribute(`data-align`,C);let B=()=>o.hasAttribute(`disabled`)||o.getAttribute(`aria-disabled`)===`true`,V=()=>{N&&=(clearTimeout(N),null)},H=()=>{P&&=(clearTimeout(P),null)},U=()=>{V(),H()},W=(t,n)=>{(0,e.emit)(i,`hover-card:change`,{open:t,reason:n,trigger:o,content:s}),g?.(t)},G=()=>{let t=R.container,n=i.ownerDocument.defaultView??window,r=o.getBoundingClientRect(),a=(0,e.computeFloatingPosition)({anchorRect:r,contentRect:(0,e.measurePopupContentRect)(s),side:S,align:C,sideOffset:w,alignOffset:T,avoidCollisions:ne,collisionPadding:E}),c=(0,e.computeFloatingTransformOrigin)({side:a.side,align:a.align,anchorRect:r,popupX:a.x,popupY:a.y});t.style.position=`absolute`,t.style.top=`0px`,t.style.left=`0px`,t.style.transform=`translate3d(${a.x+n.scrollX}px, ${a.y+n.scrollY}px, 0)`,t.style.setProperty(`--transform-origin`,c),t.style.willChange=`transform`,t.style.margin=`0`,s.setAttribute(`data-side`,a.side),s.setAttribute(`data-align`,a.align),t!==s&&(t.setAttribute(`data-side`,a.side),t.setAttribute(`data-align`,a.align))},K=e=>{let t=R.container;if(i.setAttribute(`data-state`,e),s.setAttribute(`data-state`,e),t!==s&&t.setAttribute(`data-state`,e),e===`open`){i.setAttribute(`data-open`,``),s.setAttribute(`data-open`,``),t!==s&&t.setAttribute(`data-open`,``),O?(i.setAttribute(`data-instant`,``),s.setAttribute(`data-instant`,``),t!==s&&t.setAttribute(`data-instant`,``)):(i.removeAttribute(`data-instant`),s.removeAttribute(`data-instant`),t!==s&&t.removeAttribute(`data-instant`)),i.removeAttribute(`data-closed`),s.removeAttribute(`data-closed`),t!==s&&t.removeAttribute(`data-closed`);return}i.setAttribute(`data-closed`,``),s.setAttribute(`data-closed`,``),t!==s&&t.setAttribute(`data-closed`,``),i.removeAttribute(`data-instant`),s.removeAttribute(`data-instant`),t!==s&&t.removeAttribute(`data-instant`),i.removeAttribute(`data-open`),s.removeAttribute(`data-open`),t!==s&&t.removeAttribute(`data-open`)},q=(0,e.createPresenceLifecycle)({element:s,onExitComplete:()=>{k||(R.restore(),s.hidden=!0)}}),J=(0,e.createPositionSync)({observedElements:[o,s],isActive:()=>D,ancestorScroll:!1,onUpdate:G}),Y=(t,n,i=!1)=>{D!==t&&(!t&&D&&m>0&&(r=Date.now()+m),O=t?i:!1,D=t,(0,e.setAria)(o,`expanded`,D),t?(R.mount(),s.hidden=!1,K(`open`),q.enter(),G(),J.start(),J.update()):(K(`closed`),q.exit(),J.stop()),W(D,n))},X=(e,t,n=!1)=>{if(D!==e){if(ee){W(e,t);return}Y(e,t,n)}},Z=(e,t,n=!1)=>{Y(e,t,n)},Q=e=>{if(H(),V(),m>0&&Date.now()<r){X(!0,e,!0);return}if(p<=0){X(!0,e);return}N=setTimeout(()=>{N=null,X(!0,e)},p)},re=e=>{if(V(),H(),h<=0){X(!1,e);return}P=setTimeout(()=>{P=null,X(!1,e)},h)},$=e=>{A||j||M||re(e)};return(0,e.setAria)(o,`expanded`,D),K(D?`open`:`closed`),s.hidden=!D,D&&(R.mount(),q.enter(),s.hidden=!1,G(),J.start(),J.update()),L.push((0,e.on)(i.ownerDocument,`keydown`,e=>{e.key===`Tab`&&(F=Date.now())},{capture:!0}),(0,e.on)(i.ownerDocument,`pointerdown`,()=>{F=-1/0,I=-1/0},{capture:!0}),(0,e.on)(i.ownerDocument,`pointermove`,e=>{e.pointerType!==`touch`&&(I=Date.now())},{capture:!0}),(0,e.on)(o,`pointerenter`,e=>{e.pointerType!==`touch`&&(A=!0,!B()&&(Date.now()-I>250||Q(`pointer`)))}),(0,e.on)(o,`pointermove`,e=>{e.pointerType!==`touch`&&(!A||B()||D||N||Q(`pointer`))}),(0,e.on)(o,`pointerleave`,e=>{if(e.pointerType===`touch`)return;A=!1;let t=e.relatedTarget;t&&s.contains(t)||$(`pointer`)})),L.push((0,e.on)(s,`pointerenter`,e=>{e.pointerType!==`touch`&&(j=!0,H())}),(0,e.on)(s,`pointerleave`,e=>{if(e.pointerType===`touch`)return;j=!1;let t=e.relatedTarget;t&&o.contains(t)||$(`pointer`)})),L.push((0,e.on)(o,`focusin`,()=>{B()||Date.now()-F>750||(M=!0,Q(`focus`))}),(0,e.on)(o,`focusout`,e=>{let t=e.relatedTarget;t&&(o.contains(t)||s.contains(t))||(M=!1,$(`blur`))}),(0,e.on)(s,`focusin`,()=>{M=!0,H()}),(0,e.on)(s,`focusout`,e=>{let t=e.relatedTarget;t&&(o.contains(t)||s.contains(t))||(M=!1,$(`blur`))})),L.push((0,e.createDismissLayer)({root:i,isOpen:()=>D,onDismiss:()=>X(!1,`dismiss`),closeOnClickOutside:_,closeOnEscape:v})),L.push((0,e.on)(i,`hover-card:set`,e=>{let t=e.detail,n;t?.open===void 0?t?.value!==void 0&&(n=t.value):n=t.open,typeof n==`boolean`&&Z(n,`api`)})),{open:()=>{B()||(U(),X(!0,`api`))},close:()=>{U(),X(!1,`api`)},toggle:()=>{U(),!(!D&&B())&&X(!D,`api`)},setOpen:e=>{U(),Z(e,`api`)},get isOpen(){return D},destroy:()=>{k=!0,U(),J.stop(),q.cleanup(),R.cleanup(),L.forEach(e=>e()),L.length=0}}}const a=new WeakSet;function o(t=document){let n=[];for(let r of(0,e.getRoots)(t,`hover-card`))a.has(r)||(a.add(r),n.push(i(r)));return n}exports.create=o,exports.createHoverCard=i;
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});let e=require(`@data-slot/core`);const t=[`top`,`right`,`bottom`,`left`],n=[`start`,`center`,`end`];let r=0;const i=new Set,a=new Set,o=(e,t)=>{if(!e)return!1;for(let n of i)if(n!==t&&n.contains(e))return!0;return!1},s=(e,t)=>{for(let n of a)n(e,t)};function c(c,l={}){let u=(0,e.getPart)(c,`hover-card-trigger`),d=(0,e.getPart)(c,`hover-card-content`),f=(0,e.getPart)(c,`hover-card-positioner`),p=f&&d&&f.contains(d)?f:null,m=(0,e.getPart)(c,`hover-card-portal`),ee=m&&p&&m.contains(p)?m:null;if(!u||!d)throw Error(`Hover-card requires trigger and content slots`);let te=l.open!==void 0,ne=l.defaultOpen??(0,e.getDataBool)(c,`defaultOpen`)??!1,h=l.delay??(0,e.getDataNumber)(c,`delay`)??700,g=l.skipDelayDuration??(0,e.getDataNumber)(c,`skipDelayDuration`)??300,_=l.closeDelay??(0,e.getDataNumber)(c,`closeDelay`)??300,re=l.onOpenChange,ie=l.closeOnClickOutside??(0,e.getDataBool)(c,`closeOnClickOutside`)??!0,v=l.closeOnEscape??(0,e.getDataBool)(c,`closeOnEscape`)??!0,y=l.portal??(0,e.getDataBool)(d,`portal`)??(0,e.getDataBool)(c,`portal`)??!0,b=(t,n)=>(0,e.getDataEnum)(d,t,n)??(p?(0,e.getDataEnum)(p,t,n):void 0)??(0,e.getDataEnum)(c,t,n),x=t=>(0,e.getDataNumber)(d,t)??(p?(0,e.getDataNumber)(p,t):void 0)??(0,e.getDataNumber)(c,t),ae=t=>(0,e.getDataBool)(d,t)??(p?(0,e.getDataBool)(p,t):void 0)??(0,e.getDataBool)(c,t),S=l.side??b(`side`,t)??`bottom`,C=l.align??b(`align`,n)??`center`,w=l.sideOffset??x(`sideOffset`)??4,oe=l.alignOffset??x(`alignOffset`)??0,T=l.avoidCollisions??ae(`avoidCollisions`)??!0,E=l.collisionPadding??x(`collisionPadding`)??8,D=l.open??ne,O=!1,k=!1,A=!1,j=!1,M=!1,N=null,P=null,F=-1/0,I=-1/0,L=[],R=(0,e.createPortalLifecycle)({content:d,root:c,enabled:y,wrapperSlot:p?void 0:`hover-card-positioner`,container:p??void 0,mountTarget:p?ee??p:void 0}),se=(0,e.ensureId)(d,`hover-card-content`);u.setAttribute(`aria-haspopup`,`dialog`),u.setAttribute(`aria-controls`,se),d.setAttribute(`data-side`,S),d.setAttribute(`data-align`,C);let z=()=>u.hasAttribute(`disabled`)||u.getAttribute(`aria-disabled`)===`true`,B=()=>{N&&=(clearTimeout(N),null)},V=()=>{P&&=(clearTimeout(P),null)},H=()=>{B(),V()},U=(t,n)=>{(0,e.emit)(c,`hover-card:change`,{open:t,reason:n,trigger:u,content:d}),re?.(t)},W=()=>{let t=R.container,n=c.ownerDocument.defaultView??window,r=u.getBoundingClientRect(),i=(0,e.computeFloatingPosition)({anchorRect:r,contentRect:(0,e.measurePopupContentRect)(d),side:S,align:C,sideOffset:w,alignOffset:oe,avoidCollisions:T,collisionPadding:E}),a=(0,e.computeFloatingTransformOrigin)({side:i.side,align:i.align,anchorRect:r,popupX:i.x,popupY:i.y});t.style.position=`absolute`,t.style.top=`0px`,t.style.left=`0px`,t.style.transform=`translate3d(${i.x+n.scrollX}px, ${i.y+n.scrollY}px, 0)`,t.style.setProperty(`--transform-origin`,a),t.style.willChange=`transform`,t.style.margin=`0`,d.setAttribute(`data-side`,i.side),d.setAttribute(`data-align`,i.align),t!==d&&(t.setAttribute(`data-side`,i.side),t.setAttribute(`data-align`,i.align))},G=e=>{let t=R.container;if(c.setAttribute(`data-state`,e),d.setAttribute(`data-state`,e),t!==d&&t.setAttribute(`data-state`,e),e===`open`){c.setAttribute(`data-open`,``),d.setAttribute(`data-open`,``),t!==d&&t.setAttribute(`data-open`,``),O?(c.setAttribute(`data-instant`,``),d.setAttribute(`data-instant`,``),t!==d&&t.setAttribute(`data-instant`,``)):(c.removeAttribute(`data-instant`),d.removeAttribute(`data-instant`),t!==d&&t.removeAttribute(`data-instant`)),c.removeAttribute(`data-closed`),d.removeAttribute(`data-closed`),t!==d&&t.removeAttribute(`data-closed`);return}c.setAttribute(`data-closed`,``),d.setAttribute(`data-closed`,``),t!==d&&t.setAttribute(`data-closed`,``),O?(c.setAttribute(`data-instant`,``),d.setAttribute(`data-instant`,``),t!==d&&t.setAttribute(`data-instant`,``)):(c.removeAttribute(`data-instant`),d.removeAttribute(`data-instant`),t!==d&&t.removeAttribute(`data-instant`)),c.removeAttribute(`data-open`),d.removeAttribute(`data-open`),t!==d&&t.removeAttribute(`data-open`)},K=(0,e.createPresenceLifecycle)({element:d,onExitComplete:()=>{k||(R.restore(),d.hidden=!0)}}),q=(0,e.createPositionSync)({observedElements:[u,d],isActive:()=>D,ancestorScroll:!1,onUpdate:W}),J=(t,n,i=!1)=>{D!==t&&(!t&&D&&g>0&&(r=Date.now()+g),O=i,D=t,(0,e.setAria)(u,`expanded`,D),t?(R.mount(),d.hidden=!1,G(`open`),K.enter(),W(),q.start(),q.update()):(G(`closed`),K.exit(),q.stop()),U(D,n))},Y=(e,t,n=!1)=>{if(D!==e){if(te){U(e,t);return}J(e,t,n)}},X=(e,t,n=!1)=>{J(e,t,n)},Z=(e,t)=>{e===u||!D||(H(),A=!1,j=!1,M=!1,Y(!1,t,!0))};i.add(u),a.add(Z),L.push(()=>{a.delete(Z),i.delete(u)});let Q=e=>{if(V(),B(),g>0&&Date.now()<r){Y(!0,e,!0);return}if(h<=0){Y(!0,e);return}N=setTimeout(()=>{N=null,Y(!0,e)},h)},ce=e=>{if(B(),V(),_<=0){Y(!1,e);return}P=setTimeout(()=>{P=null,Y(!1,e)},_)},$=e=>{A||j||M||ce(e)};return(0,e.setAria)(u,`expanded`,D),G(D?`open`:`closed`),d.hidden=!D,D&&(R.mount(),K.enter(),d.hidden=!1,W(),q.start(),q.update()),L.push((0,e.on)(c.ownerDocument,`keydown`,e=>{e.key===`Tab`&&(F=Date.now())},{capture:!0}),(0,e.on)(c.ownerDocument,`pointerdown`,()=>{F=-1/0,I=-1/0},{capture:!0}),(0,e.on)(c.ownerDocument,`pointermove`,e=>{e.pointerType!==`touch`&&(I=Date.now())},{capture:!0}),(0,e.on)(u,`pointerenter`,e=>{e.pointerType!==`touch`&&(A=!0,!z()&&(Date.now()-I>250||(s(u,`pointer`),Q(`pointer`))))}),(0,e.on)(u,`pointermove`,e=>{e.pointerType!==`touch`&&(!A||z()||D||N||(s(u,`pointer`),Q(`pointer`)))}),(0,e.on)(u,`pointerleave`,e=>{if(e.pointerType===`touch`)return;A=!1;let t=e.relatedTarget;if(!(t&&d.contains(t))){if(o(t,u)){Y(!1,`pointer`,!0);return}$(`pointer`)}})),L.push((0,e.on)(d,`pointerenter`,e=>{e.pointerType!==`touch`&&(j=!0,V())}),(0,e.on)(d,`pointerleave`,e=>{if(e.pointerType===`touch`)return;j=!1;let t=e.relatedTarget;if(!(t&&u.contains(t))){if(o(t,u)){Y(!1,`pointer`,!0);return}$(`pointer`)}})),L.push((0,e.on)(u,`focusin`,()=>{z()||Date.now()-F>750||(M=!0,s(u,`focus`),Q(`focus`))}),(0,e.on)(u,`focusout`,e=>{let t=e.relatedTarget;if(!(t&&(u.contains(t)||d.contains(t)))){if(M=!1,o(t,u)){Y(!1,`blur`,!0);return}$(`blur`)}}),(0,e.on)(d,`focusin`,()=>{M=!0,V()}),(0,e.on)(d,`focusout`,e=>{let t=e.relatedTarget;if(!(t&&(u.contains(t)||d.contains(t)))){if(M=!1,o(t,u)){Y(!1,`blur`,!0);return}$(`blur`)}})),L.push((0,e.createDismissLayer)({root:c,isOpen:()=>D,onDismiss:()=>Y(!1,`dismiss`),closeOnClickOutside:ie,closeOnEscape:v})),L.push((0,e.on)(c,`hover-card:set`,e=>{let t=e.detail,n;t?.open===void 0?t?.value!==void 0&&(n=t.value):n=t.open,typeof n==`boolean`&&X(n,`api`)})),{open:()=>{z()||(H(),Y(!0,`api`))},close:()=>{H(),Y(!1,`api`)},toggle:()=>{H(),!(!D&&z())&&Y(!D,`api`)},setOpen:e=>{H(),X(e,`api`)},get isOpen(){return D},destroy:()=>{k=!0,H(),q.stop(),K.cleanup(),R.cleanup(),L.forEach(e=>e()),L.length=0}}}const l=new WeakSet;function u(t=document){let n=[];for(let r of(0,e.getRoots)(t,`hover-card`))l.has(r)||(l.add(r),n.push(c(r)));return n}exports.create=u,exports.createHoverCard=c;
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- import{computeFloatingPosition as e,computeFloatingTransformOrigin as t,createDismissLayer as n,createPortalLifecycle as r,createPositionSync as i,createPresenceLifecycle as a,emit as o,ensureId as ee,getDataBool as s,getDataEnum as c,getDataNumber as l,getPart as u,getRoots as d,measurePopupContentRect as te,on as f,setAria as p}from"@data-slot/core";const ne=[`top`,`right`,`bottom`,`left`],re=[`start`,`center`,`end`];let m=0;function h(d,h={}){let g=u(d,`hover-card-trigger`),_=u(d,`hover-card-content`),v=u(d,`hover-card-positioner`),y=v&&_&&v.contains(_)?v:null,b=u(d,`hover-card-portal`),ie=b&&y&&b.contains(y)?b:null;if(!g||!_)throw Error(`Hover-card requires trigger and content slots`);let ae=h.open!==void 0,oe=h.defaultOpen??s(d,`defaultOpen`)??!1,x=h.delay??l(d,`delay`)??700,S=h.skipDelayDuration??l(d,`skipDelayDuration`)??300,C=h.closeDelay??l(d,`closeDelay`)??300,se=h.onOpenChange,ce=h.closeOnClickOutside??s(d,`closeOnClickOutside`)??!0,le=h.closeOnEscape??s(d,`closeOnEscape`)??!0,ue=h.portal??s(_,`portal`)??s(d,`portal`)??!0,w=(e,t)=>c(_,e,t)??(y?c(y,e,t):void 0)??c(d,e,t),T=e=>l(_,e)??(y?l(y,e):void 0)??l(d,e),de=e=>s(_,e)??(y?s(y,e):void 0)??s(d,e),E=h.side??w(`side`,ne)??`bottom`,D=h.align??w(`align`,re)??`center`,fe=h.sideOffset??T(`sideOffset`)??4,pe=h.alignOffset??T(`alignOffset`)??0,me=h.avoidCollisions??de(`avoidCollisions`)??!0,he=h.collisionPadding??T(`collisionPadding`)??8,O=h.open??oe,k=!1,A=!1,j=!1,M=!1,N=!1,P=null,F=null,I=-1/0,L=-1/0,R=[],z=r({content:_,root:d,enabled:ue,wrapperSlot:y?void 0:`hover-card-positioner`,container:y??void 0,mountTarget:y?ie??y:void 0}),ge=ee(_,`hover-card-content`);g.setAttribute(`aria-haspopup`,`dialog`),g.setAttribute(`aria-controls`,ge),_.setAttribute(`data-side`,E),_.setAttribute(`data-align`,D);let B=()=>g.hasAttribute(`disabled`)||g.getAttribute(`aria-disabled`)===`true`,V=()=>{P&&=(clearTimeout(P),null)},H=()=>{F&&=(clearTimeout(F),null)},U=()=>{V(),H()},W=(e,t)=>{o(d,`hover-card:change`,{open:e,reason:t,trigger:g,content:_}),se?.(e)},G=()=>{let n=z.container,r=d.ownerDocument.defaultView??window,i=g.getBoundingClientRect(),a=e({anchorRect:i,contentRect:te(_),side:E,align:D,sideOffset:fe,alignOffset:pe,avoidCollisions:me,collisionPadding:he}),o=t({side:a.side,align:a.align,anchorRect:i,popupX:a.x,popupY:a.y});n.style.position=`absolute`,n.style.top=`0px`,n.style.left=`0px`,n.style.transform=`translate3d(${a.x+r.scrollX}px, ${a.y+r.scrollY}px, 0)`,n.style.setProperty(`--transform-origin`,o),n.style.willChange=`transform`,n.style.margin=`0`,_.setAttribute(`data-side`,a.side),_.setAttribute(`data-align`,a.align),n!==_&&(n.setAttribute(`data-side`,a.side),n.setAttribute(`data-align`,a.align))},K=e=>{let t=z.container;if(d.setAttribute(`data-state`,e),_.setAttribute(`data-state`,e),t!==_&&t.setAttribute(`data-state`,e),e===`open`){d.setAttribute(`data-open`,``),_.setAttribute(`data-open`,``),t!==_&&t.setAttribute(`data-open`,``),k?(d.setAttribute(`data-instant`,``),_.setAttribute(`data-instant`,``),t!==_&&t.setAttribute(`data-instant`,``)):(d.removeAttribute(`data-instant`),_.removeAttribute(`data-instant`),t!==_&&t.removeAttribute(`data-instant`)),d.removeAttribute(`data-closed`),_.removeAttribute(`data-closed`),t!==_&&t.removeAttribute(`data-closed`);return}d.setAttribute(`data-closed`,``),_.setAttribute(`data-closed`,``),t!==_&&t.setAttribute(`data-closed`,``),d.removeAttribute(`data-instant`),_.removeAttribute(`data-instant`),t!==_&&t.removeAttribute(`data-instant`),d.removeAttribute(`data-open`),_.removeAttribute(`data-open`),t!==_&&t.removeAttribute(`data-open`)},q=a({element:_,onExitComplete:()=>{A||(z.restore(),_.hidden=!0)}}),J=i({observedElements:[g,_],isActive:()=>O,ancestorScroll:!1,onUpdate:G}),Y=(e,t,n=!1)=>{O!==e&&(!e&&O&&S>0&&(m=Date.now()+S),k=e?n:!1,O=e,p(g,`expanded`,O),e?(z.mount(),_.hidden=!1,K(`open`),q.enter(),G(),J.start(),J.update()):(K(`closed`),q.exit(),J.stop()),W(O,t))},X=(e,t,n=!1)=>{if(O!==e){if(ae){W(e,t);return}Y(e,t,n)}},Z=(e,t,n=!1)=>{Y(e,t,n)},Q=e=>{if(H(),V(),S>0&&Date.now()<m){X(!0,e,!0);return}if(x<=0){X(!0,e);return}P=setTimeout(()=>{P=null,X(!0,e)},x)},_e=e=>{if(V(),H(),C<=0){X(!1,e);return}F=setTimeout(()=>{F=null,X(!1,e)},C)},$=e=>{j||M||N||_e(e)};return p(g,`expanded`,O),K(O?`open`:`closed`),_.hidden=!O,O&&(z.mount(),q.enter(),_.hidden=!1,G(),J.start(),J.update()),R.push(f(d.ownerDocument,`keydown`,e=>{e.key===`Tab`&&(I=Date.now())},{capture:!0}),f(d.ownerDocument,`pointerdown`,()=>{I=-1/0,L=-1/0},{capture:!0}),f(d.ownerDocument,`pointermove`,e=>{e.pointerType!==`touch`&&(L=Date.now())},{capture:!0}),f(g,`pointerenter`,e=>{e.pointerType!==`touch`&&(j=!0,!B()&&(Date.now()-L>250||Q(`pointer`)))}),f(g,`pointermove`,e=>{e.pointerType!==`touch`&&(!j||B()||O||P||Q(`pointer`))}),f(g,`pointerleave`,e=>{if(e.pointerType===`touch`)return;j=!1;let t=e.relatedTarget;t&&_.contains(t)||$(`pointer`)})),R.push(f(_,`pointerenter`,e=>{e.pointerType!==`touch`&&(M=!0,H())}),f(_,`pointerleave`,e=>{if(e.pointerType===`touch`)return;M=!1;let t=e.relatedTarget;t&&g.contains(t)||$(`pointer`)})),R.push(f(g,`focusin`,()=>{B()||Date.now()-I>750||(N=!0,Q(`focus`))}),f(g,`focusout`,e=>{let t=e.relatedTarget;t&&(g.contains(t)||_.contains(t))||(N=!1,$(`blur`))}),f(_,`focusin`,()=>{N=!0,H()}),f(_,`focusout`,e=>{let t=e.relatedTarget;t&&(g.contains(t)||_.contains(t))||(N=!1,$(`blur`))})),R.push(n({root:d,isOpen:()=>O,onDismiss:()=>X(!1,`dismiss`),closeOnClickOutside:ce,closeOnEscape:le})),R.push(f(d,`hover-card:set`,e=>{let t=e.detail,n;t?.open===void 0?t?.value!==void 0&&(n=t.value):n=t.open,typeof n==`boolean`&&Z(n,`api`)})),{open:()=>{B()||(U(),X(!0,`api`))},close:()=>{U(),X(!1,`api`)},toggle:()=>{U(),!(!O&&B())&&X(!O,`api`)},setOpen:e=>{U(),Z(e,`api`)},get isOpen(){return O},destroy:()=>{A=!0,U(),J.stop(),q.cleanup(),z.cleanup(),R.forEach(e=>e()),R.length=0}}}const g=new WeakSet;function _(e=document){let t=[];for(let n of d(e,`hover-card`))g.has(n)||(g.add(n),t.push(h(n)));return t}export{_ as create,h as createHoverCard};
1
+ import{computeFloatingPosition as e,computeFloatingTransformOrigin as t,createDismissLayer as n,createPortalLifecycle as r,createPositionSync as i,createPresenceLifecycle as a,emit as o,ensureId as ee,getDataBool as s,getDataEnum as c,getDataNumber as l,getPart as u,getRoots as d,measurePopupContentRect as te,on as f,setAria as p}from"@data-slot/core";const ne=[`top`,`right`,`bottom`,`left`],re=[`start`,`center`,`end`];let m=0;const h=new Set,g=new Set,_=(e,t)=>{if(!e)return!1;for(let n of h)if(n!==t&&n.contains(e))return!0;return!1},v=(e,t)=>{for(let n of g)n(e,t)};function y(d,y={}){let b=u(d,`hover-card-trigger`),x=u(d,`hover-card-content`),S=u(d,`hover-card-positioner`),C=S&&x&&S.contains(x)?S:null,w=u(d,`hover-card-portal`),ie=w&&C&&w.contains(C)?w:null;if(!b||!x)throw Error(`Hover-card requires trigger and content slots`);let ae=y.open!==void 0,oe=y.defaultOpen??s(d,`defaultOpen`)??!1,T=y.delay??l(d,`delay`)??700,E=y.skipDelayDuration??l(d,`skipDelayDuration`)??300,D=y.closeDelay??l(d,`closeDelay`)??300,se=y.onOpenChange,ce=y.closeOnClickOutside??s(d,`closeOnClickOutside`)??!0,le=y.closeOnEscape??s(d,`closeOnEscape`)??!0,ue=y.portal??s(x,`portal`)??s(d,`portal`)??!0,O=(e,t)=>c(x,e,t)??(C?c(C,e,t):void 0)??c(d,e,t),k=e=>l(x,e)??(C?l(C,e):void 0)??l(d,e),de=e=>s(x,e)??(C?s(C,e):void 0)??s(d,e),fe=y.side??O(`side`,ne)??`bottom`,pe=y.align??O(`align`,re)??`center`,me=y.sideOffset??k(`sideOffset`)??4,he=y.alignOffset??k(`alignOffset`)??0,ge=y.avoidCollisions??de(`avoidCollisions`)??!0,_e=y.collisionPadding??k(`collisionPadding`)??8,A=y.open??oe,j=!1,M=!1,N=!1,P=!1,F=!1,I=null,L=null,R=-1/0,z=-1/0,B=[],V=r({content:x,root:d,enabled:ue,wrapperSlot:C?void 0:`hover-card-positioner`,container:C??void 0,mountTarget:C?ie??C:void 0}),ve=ee(x,`hover-card-content`);b.setAttribute(`aria-haspopup`,`dialog`),b.setAttribute(`aria-controls`,ve),x.setAttribute(`data-side`,fe),x.setAttribute(`data-align`,pe);let H=()=>b.hasAttribute(`disabled`)||b.getAttribute(`aria-disabled`)===`true`,U=()=>{I&&=(clearTimeout(I),null)},W=()=>{L&&=(clearTimeout(L),null)},G=()=>{U(),W()},K=(e,t)=>{o(d,`hover-card:change`,{open:e,reason:t,trigger:b,content:x}),se?.(e)},q=()=>{let n=V.container,r=d.ownerDocument.defaultView??window,i=b.getBoundingClientRect(),a=e({anchorRect:i,contentRect:te(x),side:fe,align:pe,sideOffset:me,alignOffset:he,avoidCollisions:ge,collisionPadding:_e}),o=t({side:a.side,align:a.align,anchorRect:i,popupX:a.x,popupY:a.y});n.style.position=`absolute`,n.style.top=`0px`,n.style.left=`0px`,n.style.transform=`translate3d(${a.x+r.scrollX}px, ${a.y+r.scrollY}px, 0)`,n.style.setProperty(`--transform-origin`,o),n.style.willChange=`transform`,n.style.margin=`0`,x.setAttribute(`data-side`,a.side),x.setAttribute(`data-align`,a.align),n!==x&&(n.setAttribute(`data-side`,a.side),n.setAttribute(`data-align`,a.align))},J=e=>{let t=V.container;if(d.setAttribute(`data-state`,e),x.setAttribute(`data-state`,e),t!==x&&t.setAttribute(`data-state`,e),e===`open`){d.setAttribute(`data-open`,``),x.setAttribute(`data-open`,``),t!==x&&t.setAttribute(`data-open`,``),j?(d.setAttribute(`data-instant`,``),x.setAttribute(`data-instant`,``),t!==x&&t.setAttribute(`data-instant`,``)):(d.removeAttribute(`data-instant`),x.removeAttribute(`data-instant`),t!==x&&t.removeAttribute(`data-instant`)),d.removeAttribute(`data-closed`),x.removeAttribute(`data-closed`),t!==x&&t.removeAttribute(`data-closed`);return}d.setAttribute(`data-closed`,``),x.setAttribute(`data-closed`,``),t!==x&&t.setAttribute(`data-closed`,``),j?(d.setAttribute(`data-instant`,``),x.setAttribute(`data-instant`,``),t!==x&&t.setAttribute(`data-instant`,``)):(d.removeAttribute(`data-instant`),x.removeAttribute(`data-instant`),t!==x&&t.removeAttribute(`data-instant`)),d.removeAttribute(`data-open`),x.removeAttribute(`data-open`),t!==x&&t.removeAttribute(`data-open`)},Y=a({element:x,onExitComplete:()=>{M||(V.restore(),x.hidden=!0)}}),X=i({observedElements:[b,x],isActive:()=>A,ancestorScroll:!1,onUpdate:q}),ye=(e,t,n=!1)=>{A!==e&&(!e&&A&&E>0&&(m=Date.now()+E),j=n,A=e,p(b,`expanded`,A),e?(V.mount(),x.hidden=!1,J(`open`),Y.enter(),q(),X.start(),X.update()):(J(`closed`),Y.exit(),X.stop()),K(A,t))},Z=(e,t,n=!1)=>{if(A!==e){if(ae){K(e,t);return}ye(e,t,n)}},be=(e,t,n=!1)=>{ye(e,t,n)},xe=(e,t)=>{e===b||!A||(G(),N=!1,P=!1,F=!1,Z(!1,t,!0))};h.add(b),g.add(xe),B.push(()=>{g.delete(xe),h.delete(b)});let Q=e=>{if(W(),U(),E>0&&Date.now()<m){Z(!0,e,!0);return}if(T<=0){Z(!0,e);return}I=setTimeout(()=>{I=null,Z(!0,e)},T)},Se=e=>{if(U(),W(),D<=0){Z(!1,e);return}L=setTimeout(()=>{L=null,Z(!1,e)},D)},$=e=>{N||P||F||Se(e)};return p(b,`expanded`,A),J(A?`open`:`closed`),x.hidden=!A,A&&(V.mount(),Y.enter(),x.hidden=!1,q(),X.start(),X.update()),B.push(f(d.ownerDocument,`keydown`,e=>{e.key===`Tab`&&(R=Date.now())},{capture:!0}),f(d.ownerDocument,`pointerdown`,()=>{R=-1/0,z=-1/0},{capture:!0}),f(d.ownerDocument,`pointermove`,e=>{e.pointerType!==`touch`&&(z=Date.now())},{capture:!0}),f(b,`pointerenter`,e=>{e.pointerType!==`touch`&&(N=!0,!H()&&(Date.now()-z>250||(v(b,`pointer`),Q(`pointer`))))}),f(b,`pointermove`,e=>{e.pointerType!==`touch`&&(!N||H()||A||I||(v(b,`pointer`),Q(`pointer`)))}),f(b,`pointerleave`,e=>{if(e.pointerType===`touch`)return;N=!1;let t=e.relatedTarget;if(!(t&&x.contains(t))){if(_(t,b)){Z(!1,`pointer`,!0);return}$(`pointer`)}})),B.push(f(x,`pointerenter`,e=>{e.pointerType!==`touch`&&(P=!0,W())}),f(x,`pointerleave`,e=>{if(e.pointerType===`touch`)return;P=!1;let t=e.relatedTarget;if(!(t&&b.contains(t))){if(_(t,b)){Z(!1,`pointer`,!0);return}$(`pointer`)}})),B.push(f(b,`focusin`,()=>{H()||Date.now()-R>750||(F=!0,v(b,`focus`),Q(`focus`))}),f(b,`focusout`,e=>{let t=e.relatedTarget;if(!(t&&(b.contains(t)||x.contains(t)))){if(F=!1,_(t,b)){Z(!1,`blur`,!0);return}$(`blur`)}}),f(x,`focusin`,()=>{F=!0,W()}),f(x,`focusout`,e=>{let t=e.relatedTarget;if(!(t&&(b.contains(t)||x.contains(t)))){if(F=!1,_(t,b)){Z(!1,`blur`,!0);return}$(`blur`)}})),B.push(n({root:d,isOpen:()=>A,onDismiss:()=>Z(!1,`dismiss`),closeOnClickOutside:ce,closeOnEscape:le})),B.push(f(d,`hover-card:set`,e=>{let t=e.detail,n;t?.open===void 0?t?.value!==void 0&&(n=t.value):n=t.open,typeof n==`boolean`&&be(n,`api`)})),{open:()=>{H()||(G(),Z(!0,`api`))},close:()=>{G(),Z(!1,`api`)},toggle:()=>{G(),!(!A&&H())&&Z(!A,`api`)},setOpen:e=>{G(),be(e,`api`)},get isOpen(){return A},destroy:()=>{M=!0,G(),X.stop(),Y.cleanup(),V.cleanup(),B.forEach(e=>e()),B.length=0}}}const b=new WeakSet;function x(e=document){let t=[];for(let n of d(e,`hover-card`))b.has(n)||(b.add(n),t.push(y(n)));return t}export{x as create,y as createHoverCard};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@data-slot/hover-card",
3
- "version": "0.2.93",
3
+ "version": "0.2.95",
4
4
  "type": "module",
5
5
  "sideEffects": false,
6
6
  "main": "./dist/index.cjs",
@@ -39,6 +39,6 @@
39
39
  ],
40
40
  "license": "MIT",
41
41
  "dependencies": {
42
- "@data-slot/core": "0.2.93"
42
+ "@data-slot/core": "0.2.95"
43
43
  }
44
44
  }