pluto/core/static/js/magnet.min.js

2 lines
157 KiB
JavaScript

(()=>{"use strict";const t=function(t,e){return t instanceof DOMPoint?DOMPoint.fromPoint(t):t instanceof DOMRect?new DOMPoint(t.x,t.y):new DOMPoint(t,e)},e=t;function n(e){const{best:n}=e;return t(n.x?.rawDistance??0,n.y?.rawDistance??0)}const a=/[|;,\s]/;function s(t,e){if(null===t)return[];const n=t.split(a);return void 0===e?n:Object.values(e).filter((t=>n.includes(t)))}function o(t,e){const n=Array.isArray(t)?t:[t];return void 0===e?n.join("|"):Object.values(e).filter((t=>n.includes(t))).join("|")}const r=function(t,e){return customElements.get(e)?Promise.reject(new Error(`Already defined <${e}>`)):(customElements.define(e,t),customElements.whenDefined(e))};var i;!function(t){t.topToTop="topToTop",t.topToBottom="topToBottom",t.rightToRight="rightToRight",t.rightToLeft="rightToLeft",t.bottomToTop="bottomToTop",t.bottomToBottom="bottomToBottom",t.leftToRight="leftToRight",t.leftToLeft="leftToLeft",t.xCenterToXCenter="xCenterToXCenter",t.yCenterToYCenter="yCenterToYCenter"}(i||(i={}));const c=[i.rightToRight,i.rightToLeft,i.leftToRight,i.leftToLeft,i.xCenterToXCenter],l=[i.topToTop,i.topToBottom,i.bottomToTop,i.bottomToBottom,i.yCenterToYCenter],u=i;var g;let h;!function(t){t.outer="outer",t.inner="inner",t.center="center",t.extend="extend"}(g||(g={})),function(t){t.inner="inner",t.center="center"}(h||(h={}));const f=g;var d;!function(t){t.disabled="disabled",t.group="group",t.unattractable="unattractable",t.unmovable="unmovable",t.attractDistance="attract-distance",t.alignTo="align-to",t.alignToParent="align-to-parent",t.crossPrevent="cross-prevent",t.offsetUnit="offset-unit"}(d||(d={}));const m=d;var b;!function(t){t.parent="parent"}(b||(b={}));const p=b;var T;!function(t){t.magnetstart="magnetstart",t.magnetmove="magnetmove",t.magnetend="magnetend",t.attract="attract",t.attracted="attracted",t.attractmove="attractmove",t.attractedmove="attractedmove",t.unattract="unattract",t.unattracted="unattracted"}(T||(T={}));const y=T;var D;!function(t){t.pixel="px",t.px="px",t.percentage="%",t["%"]="%"}(D||(D={}));const x=D,{isNaN:v}=globalThis,{abs:P}=Math,A=document.createElement("template"),M={[m.disabled]:!1,[m.group]:null,[m.attractDistance]:10,[m.unattractable]:!1,[m.unmovable]:!1,get[m.alignTo](){return[f.outer,f.center,f.extend]},get[m.alignToParent](){return[]},get[m.crossPrevent](){return[]},[m.offsetUnit]:x.pixel};A.innerHTML="\n <style>\n :host {\n position: relative;\n display: inline-block;\n }\n </style>\n <slot>\n </slot>\n";class w extends HTMLElement{constructor(){super(),this.attachShadow({mode:"open"}),this.shadowRoot.append(A.content.cloneNode(!0))}static get ALIGNMENT(){return{...u}}static get ALIGN_TO(){return{...f}}static get ALIGN_TO_PARENT(){return{...h}}static get CROSS_PREVENT(){return{...p}}static get EVENT(){return{...y}}static getAlignmentsFromAlignTo(t){const e=Array.isArray(t)?t:[t],n=[];return e.includes(f.outer)&&n.push(u.topToBottom,u.rightToLeft,u.bottomToTop,u.leftToRight),e.includes(f.inner)&&n.push(u.topToTop,u.rightToRight,u.bottomToBottom,u.leftToLeft),e.includes(f.center)&&n.push(u.xCenterToXCenter,u.yCenterToYCenter),n}static getMagnetAttractionOffset=n;get disabled(){return null!==this.traceMagnetAttributeValue(m.disabled)}set disabled(t){t?this.setAttribute(m.disabled,""):this.removeAttribute(m.disabled)}get group(){return this.traceMagnetAttributeValue(m.group)}set group(t){null===t||0===t.length?this.removeAttribute(m.group):this.setAttribute(m.group,t)}get parentMagnet(){const t=this.getAttribute(m.group);let e=this.parentElement;for(;e;){if(e instanceof w){const n=e.getAttribute(m.group);if(null===t||null===n||t===n)return e}e=e.parentElement}return null}get unattractable(){return null!==this.traceMagnetAttributeValue(m.unattractable)}set unattractable(t){t?this.setAttribute(m.unattractable,""):this.removeAttribute(m.unattractable)}get unmovable(){return null!==this.traceMagnetAttributeValue(m.unmovable)}set unmovable(t){t?this.setAttribute(m.unmovable,""):this.removeAttribute(m.unmovable)}get attractDistance(){const t=this.traceMagnetAttributeValue(m.attractDistance);return null===t?M[m.attractDistance]:Number(t)}set attractDistance(t){if(null===t)this.removeAttribute(m.attractDistance);else{if(v(t))throw new TypeError(`Invalid attraction distance: ${t}`);if(t<0)throw new RangeError(`Attraction distance should be greater than 0: ${t}`);t!==this.attractDistance&&this.setAttribute(m.attractDistance,`${t}`)}}get alignTos(){const t=this.traceMagnetAttributeValue(m.alignTo);return null===t?M[m.alignTo]:s(t,f)}set alignTos(t){this.setAttribute(m.alignTo,o(Array.isArray(t)?t:s(t,f)))}get alignToParents(){const t=this.traceMagnetAttributeValue(m.alignToParent);return null===t?M[m.alignToParent]:s(t,h)}set alignToParents(t){this.setAttribute(m.alignToParent,o(Array.isArray(t)?t:s(t,h)))}get alignments(){return w.getAlignmentsFromAlignTo(this.alignTos)}get parentAlignments(){return w.getAlignmentsFromAlignTo(this.alignToParents)}get crossPrevents(){const t=this.traceMagnetAttributeValue(m.crossPrevent);return null===t?M[m.crossPrevent]:s(t,p)}set crossPrevents(t){this.setAttribute(m.crossPrevent,o(Array.isArray(t)?t:s(t,p)))}get offsetUnit(){const t=this.traceMagnetAttributeValue(m.offsetUnit);return null===t?M[m.offsetUnit]:t}set offsetUnit(t){if(null===t)this.removeAttribute(m.offsetUnit);else{if(!Object.values(x).includes(t))throw new Error(`Invalid offset unit: ${t}`);t!==this.offsetUnit&&this.setAttribute(m.offsetUnit,t)}}traceMagnetAttributeValue(t){const e=this.getAttribute(t);if(null!==e)return e;const{parentMagnet:n}=this;return n?n.traceMagnetAttributeValue(t):null}}r(w,"magnet-pack");const C=w;function R(t,...e){if(t instanceof Window)return new DOMRect(0,0,t.innerWidth,t.innerHeight);if(t instanceof Document)return document.body.getBoundingClientRect();if(t instanceof Element)return t.getBoundingClientRect();if(E.isPack(t))return DOMRect.fromRect(t.rect);if("object"!=typeof t){const n=t,[a,s,o]=e;return new DOMRect(n,a,s,o)}const{top:n,right:a,bottom:s,left:o,x:r=o,y:i=n,width:c=a-r,height:l=s-i}=t;return new DOMRect(r,i,c,l)}function k(t){return E.isPack(t)?t.rect:t instanceof DOMRect?t:R(t)}const B=R;class J{constructor(t,e=k(t)){const n=J.isPack(t)?t.raw:t;this.raw=n,this.rect=e,Object.freeze(this)}static isPack(t){return t instanceof J}}function O(t){return J.isPack(t)?t:new J(t)}const E=J,L=function(t,e,n){switch(n){default:return 1/0;case u.topToTop:return e.top-t.top;case u.topToBottom:return e.bottom-t.top;case u.rightToRight:return e.right-t.right;case u.rightToLeft:return e.left-t.right;case u.bottomToTop:return e.top-t.bottom;case u.bottomToBottom:return e.bottom-t.bottom;case u.leftToRight:return e.right-t.left;case u.leftToLeft:return e.left-t.left;case u.xCenterToXCenter:return(e.right+e.left-(t.right+t.left))/2;case u.yCenterToYCenter:return(e.top+e.bottom-(t.top+t.bottom))/2}},j=()=>!0,F=()=>!1;function N(t,e){const n=t.right+t.left,a=e.right+e.left;return P(n-a)/2}function X(t,e){const n=t.top+t.bottom,a=e.top+e.bottom;return P(n-a)/2}const Y=function(t,e,n={}){const a=O(t),s=e.map((t=>O(t))),{attractDistance:o=M[m.attractDistance],alignTos:r=M[m.alignTo],alignments:i=C.getAlignmentsFromAlignTo(r),onJudgeDistance:c=j,onJudgeAttraction:l=j,attractionBest:g={}}=n,h={attractDistance:o,alignTos:r,alignments:i,onJudgeDistance:c};return s.reduce(((t,e)=>{const n=it.prototype.attractionTo.call(a,e,h),{best:s,results:r}=n,i=l({source:a,target:e,results:[...r],best:{x:s.x,y:s.y}});if(t.target.push(e),i){const{results:e,best:n}=t;if(e.push(...r),s.x)if(void 0===n.x||s.x.absDistance<n.x.absDistance)n.x=s.x;else if(n.x.absDistance===s.x.absDistance){const t=k(a),e=s.x.target.rect,r=n.x.target.rect,i=X(t,e),c=X(t,r);if(i<c)n.x=s.x;else if(i===c){const e=o/3;if(s.x.rawDistance>e)s.x.alignment===u.leftToLeft&&(n.x=s.x);else if(s.x.rawDistance<-e)s.x.alignment===u.rightToRight&&(n.x=s.x);else if(s.x.alignment===u.xCenterToXCenter){const e=s.x.target.rect,a=n.x.target.rect,o=e.top+e.bottom,r=a.top+a.bottom,i=t.top+t.bottom,c=P(o-i);P(r-i)<c&&(n.x=s.x)}}}if(s.y)if(void 0===n.y||s.y.absDistance<n.y.absDistance)n.y=s.y;else if(n.y.absDistance===s.y.absDistance){const t=k(a),e=s.y.target.rect,r=n.y.target.rect,i=N(t,e),c=N(t,r);if(i<c)n.y=s.y;else if(i===c){const e=o/3;if(s.y.rawDistance<-e)s.y.alignment===u.bottomToBottom&&(n.y=s.y);else if(s.y.rawDistance>e)s.y.alignment===u.topToTop&&(n.y=s.y);else if(s.y.alignment===u.yCenterToYCenter){const e=s.y.target.rect,a=n.y.target.rect,o=e.right+e.left,r=a.right+a.left,i=t.right+t.left,c=P(o-i);P(r-i)<c&&(n.y=s.y)}}}}return t}),{source:a,target:[],results:[],best:{...g}})},V=function(t,e,n={}){const a=O(t),s=O(e),{attractDistance:o=M[m.attractDistance],alignTos:r=M[m.alignTo],alignments:i=it.getAlignmentsFromAlignTo(r),onJudgeDistance:g=j}=n;return i.reduce(((t,e)=>{const n=it.prototype.distanceTo.call(a,s,e);if(g({...n},{attractDistance:o,alignTos:r})){const{results:a,best:s}=t;if(a.push(n),c.includes(e)){if(void 0===s.x||n.absDistance<s.x.absDistance)s.x=n;else if(s.x.absDistance===n.absDistance){const t=o/3;n.rawDistance>t?n.alignment===u.leftToLeft&&(s.x=n):n.rawDistance<-t?n.alignment===u.rightToRight&&(s.x=n):n.alignment===u.xCenterToXCenter&&(s.x=n)}}else if(l.includes(e))if(void 0===s.y||n.absDistance<s.y.absDistance)s.y=n;else if(s.y.absDistance===n.absDistance){const t=o/3;n.rawDistance<-t?n.alignment===u.bottomToBottom&&(s.y=n):n.rawDistance>t?n.alignment===u.topToTop&&(s.y=n):n.alignment===u.yCenterToYCenter&&(s.y=n)}}return t}),{source:a,target:s,results:[],best:{}})},I=function(t){return Boolean(t.best.x??t.best.y)},$=function(){return!0};function U(t,e,n,a){e.forEach((e=>{!function(t,e,n,a){t.addEventListener(e,n,a)}(t,e,n,a)}))}function S(t,e,n,a){e.forEach((e=>{t.removeEventListener(e,n,a)}))}function W(t,e,n){return t.dispatchEvent(new CustomEvent(e,n))}const H=function(t,n){let a=0,s=0;return t.left<n.left?a=n.left-t.left:t.right>n.right&&(a=n.right-t.right),t.top<n.top?s=n.top-t.top:t.bottom>n.bottom&&(s=n.bottom-t.bottom),e(a,s)},z=function(t,a,s={}){const o=t.raw,{ignoreEvent:r=!(o instanceof HTMLElement),alignToParents:i=M[m.alignToParent],crossPrevents:c=M[m.crossPrevent],parentPack:l,lastAttractionBest:u,onJudgeMovement:g=j}=s,h=u?.x,f=u?.y,d=it.getAlignmentsFromAlignTo(i).length>0,b=c.includes(p.parent)&&l,T=k(t),{width:D,height:x}=T,v=k(l??T),P=T,A=b?H(P,v):e(0,0),w=B(P.x+A.x,P.y+A.y,D,x),C=new E(o,w),R=g(C),J=[],O=[],L=[],N=t=>{r||O.forEach((e=>{const n=e.target,a=n.raw,s={source:C,target:n,sourceNextRect:t};W(a,y.unattracted,{bubbles:!0,cancelable:!1,composed:!0,detail:s})}))};if(!R)return h&&O.push(h),f&&O.push(f),N(w),{position:null,attractionBest:null};const X={},{unattractable:I=M[m.unattractable],attractDistance:$=M[m.attractDistance],alignTos:U=M[m.alignTo],alignments:S=it.getAlignmentsFromAlignTo(U),onJudgeDistanceInParent:z=j}=s,_=new E(o,P),G=I?F:s.onJudgeDistance??j;if(d&&l){const{best:t}=V(_,l,{attractDistance:$,alignTos:U,alignments:S,onJudgeDistance:G});X.x=t.x,X.y=t.y}const q=b?t=>z(t,{attractDistance:$,alignTos:U,parent:l,onJudgeDistance:G}):G,K=I?F:s.onJudgeAttraction??j,Q=Y(_,a,{attractDistance:$,alignTos:U,alignments:S,onJudgeDistance:q,onJudgeAttraction:K,attractionBest:X}),Z=Q.best,tt=n(Q),et=B(P.x+tt.x,P.y+tt.y,D,x),nt=b?H(et,v):e(0,0),at=B(et.x+nt.x,et.y+nt.y,D,x);if(!r){const{x:t,y:n}=Z,a=h?.target,s=f?.target,r=t?.target,i=n?.target,c=i!==s;if(r!==a)a&&O.push(h),r&&J.push(t);else if(r){const e=h?.alignment;e!==t.alignment?J.push(t):L.push(t)}if(c)s&&O.push(f),i&&J.push(n);else if(i){const t=f?.alignment;t!==n.alignment?J.push(n):L.push(n)}if(J.length>0){const t={source:C,nextRect:at,attraction:Q};if(!W(o,y.attract,{bubbles:!0,cancelable:!0,composed:!0,detail:t}))return h&&O.push(h),f&&O.push(f),{position:e(P.x+A.x,P.y+A.y),attractionBest:null}}if(O.length>0){const t={source:C,nextRect:at,attraction:Q};W(o,y.unattract,{bubbles:!0,cancelable:!1,composed:!0,detail:t})}if(L.length>0){const t={source:C,nextRect:at,attraction:Q};W(o,y.attractmove,{bubbles:!0,cancelable:!1,composed:!0,detail:t})}}var st;return st=at,r||J.forEach((t=>{const e=t.target,n=e.raw,a={source:C,target:e,sourceNextRect:st,distance:t};W(n,y.attracted,{bubbles:!0,cancelable:!1,composed:!0,detail:a})})),N(at),(t=>{r||L.forEach((e=>{const n=e.target,a=n.raw,s={source:C,target:n,sourceNextRect:t,distance:e};W(a,y.attractedmove,{bubbles:!0,cancelable:!1,composed:!0,detail:s})}))})(at),{position:e(P.x+tt.x+nt.x,P.y+tt.y+nt.y),attractionBest:Z}},_=function(e){const{clientX:n,clientY:a}=e;return t(n,a)},G=["pointerdown"],q=["pointermove"],K=["pointerup"];function Q(t){t.resetMagnetRect(),t.resetParentPack(),t.resetTargetMagnetPacks()}function Z(t,n,a){const{magnetRect:s,targetMagnetPacks:o,judgeMagnetMovement:r}=this,{position:i,attractionBest:c}=z(new E(this,B(s.x+a.x-t.x,s.y+a.y-t.y,s.width,s.height)),o,{unattractable:this.unattractable,attractDistance:this.attractDistance,alignTos:this.alignTos,alignToParents:this.alignToParents,crossPrevents:this.crossPrevents,parentPack:this.parentPack,lastAttractionBest:this.lastAttractionBest,onJudgeDistance:this.judgeMagnetDistance,onJudgeDistanceInParent:this.judgeMagnetDistanceInParent,onJudgeAttraction:this.judgeMagnetAttraction,onJudgeMovement:n=>{if(!r(n))return!1;const s={source:n,targets:o,startPoint:e(t),movePoint:e(a)};return W(this,y.magnetmove,{bubbles:!0,cancelable:!0,composed:!0,detail:s})}});return this.setMagnetOffset((i?.x??s.x)-s.x+n.x,(i?.y??s.y)-s.y+n.y),this.lastAttractionBest=c,a}function tt(t){if(this.disabled||this.unmovable)return;const n=_(t);this.isMoving=!1,Q(this);const{magnetRect:a,targetMagnetPacks:s}=this,o={source:new E(this,a),targets:s,startPoint:e(n)};if(!W(this,y.magnetstart,{bubbles:!0,cancelable:!0,composed:!0,detail:o}))return;let r=n;const i=Z.bind(this,n,this.lastOffset),c=t=>{const e=_(t);r=i(e)},l=new MutationObserver((()=>{i(r)})),u=()=>{this.isMoving=!1,this.style.removeProperty("z-index"),S(document,q,c),S(document,K,u),l.disconnect(),Q(this),W(this,y.magnetend,{bubbles:!0,cancelable:!1,composed:!0})};this.isMoving=!0,this.style.setProperty("z-index",`${Date.now()}`),t.preventDefault(),U(document,q,c),U(document,K,u),l.observe(this,{attributes:!0,attributeFilter:Object.values(m)}),i(r)}function et(t){t.disabled||t.unmovable?function(t){S(t,G,tt)}(t):function(t){U(t,G,tt)}(t)}var nt;!function(t){t.offsetX="--offset-x",t.offsetY="--offset-y"}(nt||(nt={}));const at=nt,st="magnet-block",ot=document.createElement("template");ot.innerHTML=`\n <style>\n :host {\n --x: var(${at.offsetX}, 0);\n --y: var(${at.offsetY}, 0);\n\n position: relative;\n transform: translate(var(--x), var(--y));\n touch-action: none;\n display: inline-block;\n }\n </style>\n <slot>\n </slot>\n`;class rt extends C{rectCache=null;parentPackCache=null;targetMagnetPacksCache=null;isMoving=!1;lastOffset=e(0,0);lastAttractionBest=null;constructor(){super(),this.shadowRoot.append(ot.content.cloneNode(!0)),et(this)}get disabled(){return super.disabled}set disabled(t){super.disabled=t,et(this)}get unmovable(){return super.unmovable}set unmovable(t){super.unmovable=t,et(this)}get magnetRect(){return this.rectCache||(this.rectCache=k(this)),this.rectCache}resetMagnetRect(){this.isMoving||(this.rectCache=null)}get parentPack(){const t=this.parentElement??document.body;return this.parentPackCache||(this.parentPackCache=O(t)),this.parentPackCache}resetParentPack(){this.isMoving||(this.parentPackCache=null)}get targetMagnetPacks(){return this.targetMagnetPacksCache||(this.targetMagnetPacksCache=this.getAttractableMagnets().map((t=>O(t)))),this.targetMagnetPacksCache}resetTargetMagnetPacks(){this.isMoving||(this.targetMagnetPacksCache=null)}getOtherMagnets(){return Array.from(document.querySelectorAll(st)).filter((t=>t!==this))}getAttractableMagnets(){if(this.disabled||this.unattractable)return[];const{group:t}=this,e=null!==t,n=`magnet-block:not([${m.disabled}]):not([${m.unattractable}])`;return Array.from(document.querySelectorAll(n)).filter((n=>!(n===this||this.contains(n)||e&&t!==n.group)))}judgeMagnetDistance(...[t,e={}]){const{attractDistance:n=this.attractDistance,alignTos:a=this.alignTos}=e;return function(t,e={}){const{attractDistance:n=M[m.attractDistance]}=e;if(t.absDistance>n)return!1;const{alignTos:a=M[m.alignTo]}=e;if(a.includes(f.extend))return!0;const{source:{rect:s},target:{rect:o}}=t;switch(t.alignment){default:return!1;case u.topToTop:case u.topToBottom:case u.bottomToTop:case u.bottomToBottom:case u.yCenterToYCenter:return!(s.right+n<o.left||s.left-n>o.right);case u.rightToRight:case u.rightToLeft:case u.leftToRight:case u.leftToLeft:case u.xCenterToXCenter:return!(s.top-n>o.bottom||s.bottom+n<o.top)}}(t,{attractDistance:n,alignTos:a})}judgeMagnetDistanceInParent(...[t,e={}]){const{attractDistance:n=this.attractDistance,alignTos:a=this.alignTos,onJudgeDistance:s=this.judgeMagnetDistance}=e;return function(t,e={}){const{onJudgeDistance:n=j,...a}=e;if(!n(t,a))return!1;const s=k(e.parent??document.body),{alignment:o,rawDistance:r,source:i}=t,{rect:c}=i;switch(o){default:return!0;case"topToTop":case"topToBottom":case"bottomToTop":case"bottomToBottom":case"yCenterToYCenter":return c.top+r>=s.top&&c.bottom+r<=s.bottom;case"rightToRight":case"rightToLeft":case"leftToRight":case"leftToLeft":case"xCenterToXCenter":return c.right+r<=s.right&&c.left+r>=s.left}}(t,{attractDistance:n,alignTos:a,parent:e.parent??this.parentPack,onJudgeDistance:s})}judgeMagnetAttraction=I;judgeMagnetMovement=$;rawDistanceTo(t,e){const n=k(this),a=k(t);return L(n,a,e)}distanceTo(t,e){return function(t,e,n){const a=O(t),s=O(e),o=k(t),r=k(e),i=L(o,r,n);return{source:a,target:s,alignment:n,rawDistance:i,absDistance:P(i)}}(this,t,e)}attractionTo(t,e={}){const{attractDistance:n=this.attractDistance,alignTos:a=this.alignTos,alignments:s,onJudgeDistance:o=this.judgeMagnetDistance}=e;return V(this,t,{attractDistance:n,alignTos:a,alignments:s,onJudgeDistance:o})}attractionToParent(t={}){const{attractDistance:e=this.attractDistance,alignTos:n=this.alignToParents,alignments:a,onJudgeDistance:s=this.judgeMagnetDistance}=t;return V(this,this.parentPack,{attractDistance:e,alignTos:n,alignments:a,onJudgeDistance:s})}multiAttractionsTo(t,e={}){const{attractDistance:n=this.attractDistance,alignTos:a=this.alignTos,alignToParents:s=this.alignToParents,alignments:o,onJudgeDistance:r=this.judgeMagnetDistance,attractionBest:i,onJudgeAttraction:c=this.judgeMagnetAttraction}=e,l=rt.prototype.attractionToParent.call(this,{attractDistance:n,alignTos:s,alignments:o,onJudgeDistance:r,attractionBest:i});return Y(this,t,{attractDistance:n,alignTos:a,alignments:o,onJudgeDistance:r,onJudgeAttraction:c,attractionBest:l?.best})}getMagnetAttractionResultOfPosition(t,n,a){const s=e(t,n),o=(t instanceof DOMPoint?n:a)??{},{width:r,height:i}=this.magnetRect,c=B(s.x,s.y,r,i),l=new E(this,c),{ignoreEvent:u,unattractable:g=this.unattractable,attractDistance:h=this.attractDistance,alignTos:f=this.alignTos,alignments:d,alignToParents:m=this.alignToParents,crossPrevents:b=this.crossPrevents,parentPack:p=this.parentPack,lastAttractionBest:T=this.lastAttractionBest,onJudgeDistance:y=this.judgeMagnetDistance,onJudgeDistanceInParent:D=this.judgeMagnetDistanceInParent,onJudgeAttraction:x=this.judgeMagnetAttraction,onJudgeMovement:v=this.judgeMagnetMovement}=o,P=z(l,this.targetMagnetPacks,{ignoreEvent:u,unattractable:g,attractDistance:h,alignTos:f,alignments:d,alignToParents:m,crossPrevents:b,parentPack:p,lastAttractionBest:T,onJudgeDistance:y,onJudgeDistanceInParent:D,onJudgeAttraction:x,onJudgeMovement:v});return this.resetMagnetRect(),this.resetParentPack(),this.resetTargetMagnetPacks(),P}get lastMagnetOffset(){const{offsetUnit:t,lastOffset:n}=this;switch(t){default:case x.pixel:return e(n);case x.percentage:{const{offsetParent:t}=this,a=B(t??document);return e(n.x/a.width,n.y/a.height)}}}resetMagnetOffset(){this.style.removeProperty(at.offsetX),this.style.removeProperty(at.offsetY),this.lastOffset=e(0,0)}setMagnetOffset(t=this.lastOffset,n){const a=e(t,n),{offsetUnit:s}=this;switch(s){default:case x.pixel:this.style.setProperty(at.offsetX,`${a.x}px`),this.style.setProperty(at.offsetY,`${a.y}px`);break;case x.percentage:{const t=this.offsetParent??document.body,n=globalThis.getComputedStyle(t),{boxSizing:s,width:o,height:r}=n;let i=parseFloat(o),c=parseFloat(r);if("border-box"===s){const{paddingTop:t,paddingRight:e,paddingBottom:a,paddingLeft:s,borderTopWidth:o,borderRightWidth:r,borderBottomWidth:l,borderLeftWidth:u}=n,g=parseFloat(t),h=parseFloat(e),f=parseFloat(a),d=parseFloat(s),m=parseFloat(o),b=parseFloat(r),p=parseFloat(l);i-=h+d+b+parseFloat(u),c-=g+f+m+p}const l=e(a.x/i,a.y/c);this.style.setProperty(at.offsetX,100*l.x+"%"),this.style.setProperty(at.offsetY,100*l.y+"%");break}}this.lastOffset=e(a)}setMagnetPosition(t=e(this.magnetRect),n){const a=e(t,n),{lastOffset:s,magnetRect:o}=this,r=e(o.x-s.x,o.y-s.y);this.setMagnetOffset(a.x-r.x,a.y-r.y),this.resetMagnetRect()}get bestAttraction(){const{lastAttractionBest:t}=this,e=t?.x,n=t?.y,a={};if(e){const{source:t,target:n}=e;a.x={...e,source:new E(t.raw,B(t.rect)),target:new E(n.raw,B(n.rect))}}else a.x=void 0;if(n){const{source:t,target:e}=n;a.y={...n,source:new E(t.raw,B(t.rect)),target:new E(e.raw,B(e.rect))}}else a.y=void 0;return a}}r(rt,st);const it=rt})();
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"magnet.min.js","mappings":"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","sources":["webpack://@lf2com/magnet.js/./src/types/Point.ts","webpack://@lf2com/magnet.js/./src/types/Attraction.ts","webpack://@lf2com/magnet.js/./src/utils/multiAttributeValues.ts","webpack://@lf2com/magnet.js/./src/utils/registerElement.ts","webpack://@lf2com/magnet.js/./src/values/alignment.ts","webpack://@lf2com/magnet.js/./src/values/alignTo.ts","webpack://@lf2com/magnet.js/./src/values/attribute.ts","webpack://@lf2com/magnet.js/./src/values/crossPrevent.ts","webpack://@lf2com/magnet.js/./src/values/event.ts","webpack://@lf2com/magnet.js/./src/values/offsetUnit.ts","webpack://@lf2com/magnet.js/./src/utils/numeric.ts","webpack://@lf2com/magnet.js/./src/core.ts","webpack://@lf2com/magnet.js/./src/types/Rect.ts","webpack://@lf2com/magnet.js/./src/types/Pack.ts","webpack://@lf2com/magnet.js/./src/methods/rawDistanceTo.ts","webpack://@lf2com/magnet.js/./src/utils/returnTrueFalse.ts","webpack://@lf2com/magnet.js/./src/utils/distanceBetweenRects.ts","webpack://@lf2com/magnet.js/./src/methods/multiAttractionsTo.ts","webpack://@lf2com/magnet.js/./src/methods/singleAttractionTo.ts","webpack://@lf2com/magnet.js/./src/methods/judgeAttraction.ts","webpack://@lf2com/magnet.js/./src/methods/judgeMovement.ts","webpack://@lf2com/magnet.js/./src/utils/eventHandler.ts","webpack://@lf2com/magnet.js/./src/utils/getOffsetToBeInRect.ts","webpack://@lf2com/magnet.js/./src/methods/attractionResultOfPosition.ts","webpack://@lf2com/magnet.js/./src/utils/getEventXY.ts","webpack://@lf2com/magnet.js/./src/utils/dragListener.ts","webpack://@lf2com/magnet.js/./src/values/style.ts","webpack://@lf2com/magnet.js/./src/block.ts","webpack://@lf2com/magnet.js/./src/methods/judgeDistance.ts","webpack://@lf2com/magnet.js/./src/methods/judgeDistanceInParent.ts","webpack://@lf2com/magnet.js/./src/methods/distanceTo.ts"],"sourcesContent":["import Pack, { Rectable } from './Pack';\nimport { getRect } from './Rect';\n\ninterface CreatePoint {\n  (x: number, y: number): DOMPoint;\n  (point: DOMPoint): DOMPoint;\n  (rect: DOMRect): DOMPoint;\n}\n\n/**\n * Returns point object from a point or (x, y).\n */\nexport const createPoint: CreatePoint = function createPoint(\n  x: number | DOMPoint | DOMRect,\n  y?: number,\n) {\n  if (x instanceof DOMPoint) {\n    return DOMPoint.fromPoint(x);\n  }\n  if (x instanceof DOMRect) {\n    return new DOMPoint(x.x, x.y);\n  }\n\n  return new DOMPoint(x, y);\n};\n\n/**\n * Returns point object from source.\n */\nexport function getPoint(source: Rectable | Pack | DOMPoint): DOMPoint {\n  return (source instanceof DOMPoint\n    ? source\n    : DOMPoint.fromPoint(getRect(source))\n  );\n}\n\nexport default createPoint;\n","import Distance from './Distance';\nimport Pack from './Pack';\nimport { createPoint } from './Point';\n\nexport interface AttractionBest {\n  x?: Distance;\n  y?: Distance;\n}\n\ninterface Attraction<T> {\n  source: Pack;\n  target: T;\n  results: Distance[];\n  best: AttractionBest;\n}\n\n/**\n * Returns the offset of attraction result.\n */\nexport function getAttractionOffset(attraction: Attraction<unknown>): DOMPoint {\n  const { best } = attraction;\n\n  return createPoint(\n    best.x?.rawDistance ?? 0,\n    best.y?.rawDistance ?? 0,\n  );\n}\n\nexport default Attraction;\n","const SPLITTER = /[|;,\\s]/;\n\n/**\n * Returns splitted values from attribute value.\n */\nexport function getArrayFromAttributeValue<V extends string>(\n  value: string | null,\n  indexObject?: Record<string, V>,\n): V[] {\n  if (value === null) {\n    return [];\n  }\n\n  const values = value.split(SPLITTER);\n\n  if (indexObject === undefined) {\n    return values as V[];\n  }\n\n  const indexs = Object.values(indexObject);\n\n  return indexs\n    .filter((index) => values.includes(index));\n}\n\n/**\n * Returns combined value from array of values.\n */\nexport function getAttributeValueFromArray<T>(\n  value: string | string[],\n  indexObject?: T,\n): string {\n  const values = Array.isArray(value) ? value : [value];\n\n  if (indexObject === undefined) {\n    return values.join('|');\n  }\n\n  const indexs = Object.values(indexObject);\n\n  return indexs\n    .filter((index) => values.includes(index))\n    .join('|');\n}\n","/**\n * Registers Knob element.\n */\nfunction registerElement(\n  Node: typeof HTMLElement,\n  nodeName: string,\n): ReturnType<typeof customElements.whenDefined> {\n  if (customElements.get(nodeName)) {\n    return Promise.reject(\n      new Error(`Already defined <${nodeName}>`),\n    );\n  }\n\n  customElements.define(nodeName, Node);\n\n  return customElements.whenDefined(nodeName);\n}\n\nexport default registerElement;\n","enum Alignment {\n  topToTop = 'topToTop',\n  topToBottom = 'topToBottom',\n  rightToRight = 'rightToRight',\n  rightToLeft = 'rightToLeft',\n  bottomToTop = 'bottomToTop',\n  bottomToBottom = 'bottomToBottom',\n  leftToRight = 'leftToRight',\n  leftToLeft = 'leftToLeft',\n  xCenterToXCenter = 'xCenterToXCenter',\n  yCenterToYCenter = 'yCenterToYCenter',\n}\n\nexport const AlignmentXs: Alignment[] = [\n  Alignment.rightToRight,\n  Alignment.rightToLeft,\n  Alignment.leftToRight,\n  Alignment.leftToLeft,\n  Alignment.xCenterToXCenter,\n];\n\nexport const AlignmentYs: Alignment[] = [\n  Alignment.topToTop,\n  Alignment.topToBottom,\n  Alignment.bottomToTop,\n  Alignment.bottomToBottom,\n  Alignment.yCenterToYCenter,\n];\n\nexport default Alignment;\n","enum AlignTo {\n  outer = 'outer',\n  inner = 'inner',\n  center = 'center',\n  extend = 'extend',\n}\n\nexport enum AlignToParent {\n  inner = 'inner',\n  center = 'center',\n}\n\nexport default AlignTo;\n","enum Attribute {\n  disabled = 'disabled',\n  group = 'group',\n  unattractable = 'unattractable',\n  unmovable = 'unmovable',\n  attractDistance = 'attract-distance',\n  alignTo = 'align-to',\n  alignToParent = 'align-to-parent',\n  crossPrevent = 'cross-prevent',\n  offsetUnit = 'offset-unit',\n}\n\nexport default Attribute;\n","enum CrossPrevent {\n  parent = 'parent',\n}\n\nexport default CrossPrevent;\n","enum Event {\n  magnetstart = 'magnetstart',\n  magnetmove = 'magnetmove',\n  magnetend = 'magnetend',\n  attract = 'attract',\n  attracted = 'attracted',\n  attractmove = 'attractmove',\n  attractedmove = 'attractedmove',\n  unattract = 'unattract',\n  unattracted = 'unattracted',\n}\n\nexport default Event;\n","enum OffsetUnit {\n  pixel = 'px',\n  px = 'px',\n  percentage = '%',\n  '%' = '%',\n}\n\nexport default OffsetUnit;\n","const { isNaN } = globalThis;\nconst { abs } = Math;\n\nexport { isNaN, abs };\n\n/**\n * Returns true if source is a number.\n */\nexport function isnum(n: unknown): n is number {\n  return typeof n === 'number';\n}\n\n/**\n * Returns number.\n */\nexport function stdNum(n: number): number {\n  if (isNaN(n)) {\n    throw new TypeError(`Invalid number: ${n}`);\n  }\n\n  return (isnum(n) ? n : Number(n));\n}\n","import { getAttractionOffset } from './types/Attraction';\nimport { getArrayFromAttributeValue, getAttributeValueFromArray } from './utils/multiAttributeValues';\nimport registerElement from './utils/registerElement';\nimport Alignment from './values/alignment';\nimport AlignTo, { AlignToParent } from './values/alignTo';\nimport Attribute from './values/attribute';\nimport CrossPrevent from './values/crossPrevent';\nimport Event from './values/event';\nimport OffsetUnit from './values/offsetUnit';\nimport { isNaN } from './utils/numeric';\n\nconst nodeName = 'magnet-pack';\nconst template = document.createElement('template');\n\nexport const defaultAttributeValues = {\n  [Attribute.disabled]: false,\n  [Attribute.group]: null,\n  [Attribute.attractDistance]: 10,\n  [Attribute.unattractable]: false,\n  [Attribute.unmovable]: false,\n  get [Attribute.alignTo]() {\n    return [\n      AlignTo.outer,\n      AlignTo.center,\n      AlignTo.extend,\n    ];\n  },\n  get [Attribute.alignToParent]() {\n    return [];\n  },\n  get [Attribute.crossPrevent]() {\n    return [\n      // CrossPrevents.parent,\n    ];\n  },\n  [Attribute.offsetUnit]: OffsetUnit.pixel,\n};\n\ntemplate.innerHTML = `\n  <style>\n    :host {\n      position: relative;\n      display: inline-block;\n    }\n  </style>\n  <slot>\n  </slot>\n`;\n\nclass MagnetPack extends HTMLElement {\n  constructor() {\n    super();\n\n    this.attachShadow({ mode: 'open' });\n    (this.shadowRoot as ShadowRoot).append(template.content.cloneNode(true));\n  }\n\n  static get ALIGNMENT() {\n    return { ...Alignment };\n  }\n\n  static get ALIGN_TO() {\n    return { ...AlignTo };\n  }\n\n  static get ALIGN_TO_PARENT() {\n    return { ...AlignToParent };\n  }\n\n  static get CROSS_PREVENT() {\n    return { ...CrossPrevent };\n  }\n\n  static get EVENT() {\n    return { ...Event };\n  }\n\n  /**\n   * Returns alignment values converted from sides of aligning.\n   */\n  static getAlignmentsFromAlignTo(source: string[]): Alignment[] {\n    const alignTos = Array.isArray(source) ? source : [source];\n    const alignments: Alignment[] = [];\n\n    if (alignTos.includes(AlignTo.outer)) {\n      alignments.push(\n        Alignment.topToBottom,\n        Alignment.rightToLeft,\n        Alignment.bottomToTop,\n        Alignment.leftToRight,\n      );\n    }\n    if (alignTos.includes(AlignTo.inner)) {\n      alignments.push(\n        Alignment.topToTop,\n        Alignment.rightToRight,\n        Alignment.bottomToBottom,\n        Alignment.leftToLeft,\n      );\n    }\n    if (alignTos.includes(AlignTo.center)) {\n      alignments.push(\n        Alignment.xCenterToXCenter,\n        Alignment.yCenterToYCenter,\n      );\n    }\n\n    return alignments;\n  }\n\n  /**\n   * Returns the offset of attraction result.\n   */\n  static getMagnetAttractionOffset = getAttractionOffset\n\n  /**\n   * Returns true if magnet is disabled.\n   */\n  get disabled(): boolean {\n    return this.traceMagnetAttributeValue(Attribute.disabled) !== null;\n  }\n\n  /**\n   * Sets disabled of magnet.\n   */\n  set disabled(disabled: boolean) {\n    if (disabled) {\n      this.setAttribute(Attribute.disabled, '');\n    } else {\n      this.removeAttribute(Attribute.disabled);\n    }\n  }\n\n  /**\n   * Returns magnet group.\n   */\n  get group(): string | null {\n    return this.traceMagnetAttributeValue(Attribute.group);\n  }\n\n  /**\n   * Sets magnet group.\n   */\n  set group(group: string | null) {\n    if (group === null || group.length === 0) {\n      this.removeAttribute(Attribute.group);\n    } else {\n      this.setAttribute(Attribute.group, group);\n    }\n  }\n\n  /**\n   * Returns the nearest parent magnet element.\n   */\n  get parentMagnet(): MagnetPack | null {\n    const group = this.getAttribute(Attribute.group);\n\n    let parent = this.parentElement;\n\n    while (parent) {\n      if (parent instanceof MagnetPack) {\n        const parentGroup = parent.getAttribute(Attribute.group);\n\n        if (group === null\n          || parentGroup === null\n          || group === parentGroup\n        ) {\n          return parent;\n        }\n      }\n\n      parent = parent.parentElement;\n    }\n\n    return null;\n  }\n\n  /**\n   * Returns true if the magnet has no attraction.\n   */\n  get unattractable(): boolean {\n    return this.traceMagnetAttributeValue(Attribute.unattractable) !== null;\n  }\n\n  /**\n   * Sets unattractable of magnet.\n   */\n  set unattractable(unattractable: boolean) {\n    if (unattractable) {\n      this.setAttribute(Attribute.unattractable, '');\n    } else {\n      this.removeAttribute(Attribute.unattractable);\n    }\n  }\n\n  /**\n   * Returns true if the magnet is unable to be dragged.\n   */\n  get unmovable(): boolean {\n    return this.traceMagnetAttributeValue(Attribute.unmovable) !== null;\n  }\n\n  /**\n   * Sets unmovable of magnet.\n   */\n  set unmovable(unmovable: boolean) {\n    if (unmovable) {\n      this.setAttribute(Attribute.unmovable, '');\n    } else {\n      this.removeAttribute(Attribute.unmovable);\n    }\n  }\n\n  /**\n   * Returns the distance of attraction.\n   */\n  get attractDistance(): number {\n    const value = this.traceMagnetAttributeValue(Attribute.attractDistance);\n\n    return (value === null\n      ? defaultAttributeValues[Attribute.attractDistance]\n      : Number(value)\n    );\n  }\n\n  /**\n   * Sets the distance of attraction.\n   */\n  set attractDistance(attractDistance: number | null) {\n    if (attractDistance === null) {\n      this.removeAttribute(Attribute.attractDistance);\n    } else if (isNaN(attractDistance)) {\n      throw new TypeError(`Invalid attraction distance: ${attractDistance}`);\n    } else if (attractDistance < 0) {\n      throw new RangeError(`Attraction distance should be greater than 0: ${attractDistance}`);\n    } else if (attractDistance !== this.attractDistance) {\n      this.setAttribute(Attribute.attractDistance, `${attractDistance}`);\n    }\n  }\n\n  /**\n   * Returns magnet attraction sides.\n   */\n  get alignTos(): AlignTo[] {\n    const value = this.traceMagnetAttributeValue(Attribute.alignTo);\n\n    return (value === null\n      ? defaultAttributeValues[Attribute.alignTo]\n      : getArrayFromAttributeValue(value, AlignTo)\n    );\n  }\n\n  /**\n   * Sets magnet attraction sides.\n   */\n  set alignTos(alignTos: string | string[]) {\n    this.setAttribute(\n      Attribute.alignTo,\n      getAttributeValueFromArray((Array.isArray(alignTos)\n        ? alignTos\n        : getArrayFromAttributeValue(alignTos, AlignTo)\n      )),\n    );\n  }\n\n  /**\n   * Returns the attraction sides for its parent element.\n   */\n  get alignToParents(): AlignToParent[] {\n    const value = this.traceMagnetAttributeValue(Attribute.alignToParent);\n\n    return (value === null\n      ? defaultAttributeValues[Attribute.alignToParent]\n      : getArrayFromAttributeValue(value, AlignToParent)\n    );\n  }\n\n  /**\n   * Sets the attraction sides for its parent element.\n   */\n  set alignToParents(alignToParents: string | string[]) {\n    this.setAttribute(\n      Attribute.alignToParent,\n      getAttributeValueFromArray((Array.isArray(alignToParents)\n        ? alignToParents\n        : getArrayFromAttributeValue(alignToParents, AlignToParent)\n      )),\n    );\n  }\n\n  /**\n   * Returns magnet alignments for attraction.\n   */\n  get alignments(): Alignment[] {\n    return MagnetPack.getAlignmentsFromAlignTo(this.alignTos);\n  }\n\n  /**\n   * Returns magnet alignments for parent attraction.\n   */\n  get parentAlignments(): Alignment[] {\n    return MagnetPack.getAlignmentsFromAlignTo(this.alignToParents);\n  }\n\n  /**\n   * Returns targets that the magnet would prevent from crossing.\n   */\n  get crossPrevents(): CrossPrevent[] {\n    const value = this.traceMagnetAttributeValue(Attribute.crossPrevent);\n\n    return (value === null\n      ? defaultAttributeValues[Attribute.crossPrevent]\n      : getArrayFromAttributeValue(value, CrossPrevent)\n    );\n  }\n\n  /**\n   * Sets targets that the magnet would prevent from crossing.\n   */\n  set crossPrevents(crossPrevents: string | string[]) {\n    this.setAttribute(\n      Attribute.crossPrevent,\n      getAttributeValueFromArray((Array.isArray(crossPrevents)\n        ? crossPrevents\n        : getArrayFromAttributeValue(crossPrevents, CrossPrevent)\n      )),\n    );\n  }\n\n  /**\n   * Returns unit of offset.\n   */\n  protected get offsetUnit(): string {\n    const value = this.traceMagnetAttributeValue(Attribute.offsetUnit);\n\n    return (value === null\n      ? defaultAttributeValues[Attribute.offsetUnit]\n      : value\n    );\n  }\n\n  /**\n   * Sets the unit of offset.\n   */\n  protected set offsetUnit(offsetUnit: string | null) {\n    if (offsetUnit === null) {\n      this.removeAttribute(Attribute.offsetUnit);\n    } else if (!Object.values(OffsetUnit).includes(offsetUnit as OffsetUnit)) {\n      throw new Error(`Invalid offset unit: ${offsetUnit}`);\n    } else if (offsetUnit !== this.offsetUnit) {\n      this.setAttribute(Attribute.offsetUnit, offsetUnit);\n    }\n  }\n\n  /**\n   * Returns the value of specific attribute name.\n   */\n  traceMagnetAttributeValue(attrName: string): string | null {\n    const value = this.getAttribute(attrName);\n\n    if (value !== null) {\n      return value;\n    }\n\n    const { parentMagnet } = this;\n\n    return (parentMagnet\n      ? parentMagnet.traceMagnetAttributeValue(attrName)\n      : null\n    );\n  }\n}\n\nregisterElement(MagnetPack, nodeName);\n\nexport default MagnetPack;\n","import Pack, { Rectable } from './Pack';\n\nexport interface Rectlike extends Partial<DOMRect> {\n  top?: number;\n  right?: number;\n  bottom?: number;\n  left?: number;\n}\n\n/**\n * Returns a completed rect object from rectable source.\n */\nexport function createRect(\n  source: Rectable | Pack | number,\n  ...args: [number?, number?, number?]\n): DOMRect {\n  if (source instanceof Window) {\n    return new DOMRect(0, 0, source.innerWidth, source.innerHeight);\n  }\n\n  if (source instanceof Document) {\n    return document.body.getBoundingClientRect();\n  }\n\n  if (source instanceof Element) {\n    return source.getBoundingClientRect();\n  }\n\n  if (Pack.isPack(source)) {\n    return DOMRect.fromRect(source.rect);\n  }\n\n  if (typeof source !== 'object') {\n    const x = source;\n    const [y, width, height] = args;\n\n    return new DOMRect(x, y, width, height);\n  }\n\n  const {\n    top, right, bottom, left,\n    x = left as number,\n    y = top as number,\n    width = (right as number) - x,\n    height = (bottom as number) - y,\n  } = source;\n\n  return new DOMRect(x, y, width, height);\n}\n\n/**\n * Returns rect object from source.\n */\nexport function getRect(source: Rectable | Pack): DOMRect {\n  if (Pack.isPack(source)) {\n    return source.rect;\n  }\n\n  if (source instanceof DOMRect) {\n    return source;\n  }\n\n  return createRect(source);\n}\n\nexport default createRect;\n","import { getRect, Rectlike } from './Rect';\n\nexport type Rectable = Rectlike | DOMRect | Element | Document | Window;\n\nclass Pack {\n  readonly raw: Rectable;\n\n  readonly rect: DOMRect;\n\n  constructor(source: Rectable | Pack, rect: DOMRect = getRect(source)) {\n    const raw = Pack.isPack(source) ? source.raw : source;\n\n    this.raw = raw;\n    this.rect = rect;\n\n    Object.freeze(this);\n  }\n\n  /**\n   * Returns true if source is pack obejct.\n   */\n  static isPack(source: unknown): source is Pack {\n    return source instanceof Pack;\n  }\n}\n\n/**\n * Returns pack object from source.\n */\nexport function getPack(source: Rectable | Pack): Pack {\n  return Pack.isPack(source) ? source : new Pack(source);\n}\n\nexport default Pack;\n","import Alignment from '../values/alignment';\n\n/**\n * Returns distance between source to target on specific alignment.\n */\nfunction rawDistanceTo(\n  sourceRect: DOMRect,\n  targetRect: DOMRect,\n  alignment: Alignment,\n): number {\n  switch (alignment) {\n    default:\n      return Infinity;\n\n    case Alignment.topToTop:\n      return targetRect.top - sourceRect.top;\n\n    case Alignment.topToBottom:\n      return targetRect.bottom - sourceRect.top;\n\n    case Alignment.rightToRight:\n      return targetRect.right - sourceRect.right;\n\n    case Alignment.rightToLeft:\n      return targetRect.left - sourceRect.right;\n\n    case Alignment.bottomToTop:\n      return targetRect.top - sourceRect.bottom;\n\n    case Alignment.bottomToBottom:\n      return targetRect.bottom - sourceRect.bottom;\n\n    case Alignment.leftToRight:\n      return targetRect.right - sourceRect.left;\n\n    case Alignment.leftToLeft:\n      return targetRect.left - sourceRect.left;\n\n    case Alignment.xCenterToXCenter:\n      return (\n        (targetRect.right + targetRect.left) - (sourceRect.right + sourceRect.left)\n      ) / 2;\n\n    case Alignment.yCenterToYCenter:\n      return (\n        (targetRect.top + targetRect.bottom) - (sourceRect.top + sourceRect.bottom)\n      ) / 2;\n  }\n}\n\nexport default rawDistanceTo;\n","export const returnTrue = () => true;\n\nexport const returnFalse = () => false;\n","import createPoint from '../types/Point';\nimport { abs } from './numeric';\n\n/**\n * Returns the distance on x-axis of centers from source to target.\n */\nexport function distanceBetweenXCentersOfRects(\n  sourceRect: DOMRect,\n  targetRect: DOMRect,\n): number {\n  const sourceRectXCenter = sourceRect.right + sourceRect.left;\n  const targetRectXCenter = targetRect.right + targetRect.left;\n\n  return abs(sourceRectXCenter - targetRectXCenter) / 2;\n}\n\n/**\n * Returns the distance on y-axis of centers from source to target.\n */\nexport function distanceBetweenYCentersOfRects(\n  sourceRect: DOMRect,\n  targetRect: DOMRect,\n): number {\n  const sourceRectYCenter = sourceRect.top + sourceRect.bottom;\n  const targetRectYCenter = targetRect.top + targetRect.bottom;\n\n  return abs(sourceRectYCenter - targetRectYCenter) / 2;\n}\n\n/**\n * Returns the distance on x-axis of centers from source to target.\n */\nfunction distanceBetweenCentersOfRects(\n  sourceRect: DOMRect,\n  targetRect: DOMRect,\n): DOMPoint {\n  return createPoint(\n    distanceBetweenXCentersOfRects(sourceRect, targetRect),\n    distanceBetweenYCentersOfRects(sourceRect, targetRect),\n  );\n}\n\nexport default distanceBetweenCentersOfRects;\n","import Magnet from '../block';\nimport MagnetPack, { defaultAttributeValues } from '../core';\nimport Attraction, { AttractionBest } from '../types/Attraction';\nimport Pack, { getPack, Rectable } from '../types/Pack';\nimport { getRect } from '../types/Rect';\nimport { abs } from '../utils/numeric';\nimport Alignment from '../values/alignment';\nimport { SingleAttractionToOptions } from './singleAttractionTo';\nimport { OnJudgeAttraction } from './judgeAttraction';\nimport { returnTrue } from '../utils/returnTrueFalse';\nimport Attribute from '../values/attribute';\nimport { distanceBetweenXCentersOfRects, distanceBetweenYCentersOfRects } from '../utils/distanceBetweenRects';\n\nexport type MultiAttraction = Attraction<Pack[]>;\n\nexport interface MultiAttractionsToOptions extends SingleAttractionToOptions {\n  attractionBest?: AttractionBest;\n  onJudgeAttraction?: OnJudgeAttraction;\n}\n\n/**\n * Returns result of attractions from source to targets on alignments.\n */\nfunction multiAttractionsTo(\n  source: Rectable | Pack,\n  targets: (Rectable | Pack)[],\n  options: MultiAttractionsToOptions = {},\n): MultiAttraction {\n  const sourcePack = getPack(source);\n  const targetPacks = targets.map((target) => getPack(target));\n  const {\n    attractDistance = defaultAttributeValues[Attribute.attractDistance],\n    alignTos = defaultAttributeValues[Attribute.alignTo],\n    alignments = MagnetPack.getAlignmentsFromAlignTo(alignTos),\n    onJudgeDistance = returnTrue,\n    onJudgeAttraction = returnTrue,\n    attractionBest = {},\n  } = options;\n  const singleAttractionOptions: SingleAttractionToOptions = {\n    attractDistance,\n    alignTos,\n    alignments,\n    onJudgeDistance,\n  };\n  const multiAttraction = targetPacks.reduce<MultiAttraction>(\n    (attraction, targetPack) => {\n      const singleAttraction = Magnet.prototype.attractionTo.call(\n        sourcePack,\n        targetPack,\n        singleAttractionOptions,\n      );\n      const {\n        best: currentBest,\n        results: currentResults,\n      } = singleAttraction;\n      const passJudgement = onJudgeAttraction({\n        source: sourcePack,\n        target: targetPack,\n        results: [...currentResults],\n        best: {\n          x: currentBest.x,\n          y: currentBest.y,\n        },\n      });\n\n      attraction.target.push(targetPack);\n\n      if (passJudgement) {\n        const { results, best } = attraction;\n\n        results.push(...currentResults);\n\n        if (currentBest.x) {\n          if (best.x === undefined || currentBest.x.absDistance < best.x.absDistance\n          ) {\n            best.x = currentBest.x;\n          } else if (best.x.absDistance === currentBest.x.absDistance) {\n            const sourceRect = getRect(sourcePack);\n            const targetRect = currentBest.x.target.rect;\n            const lastBestRect = best.x.target.rect;\n            const currentDiffY = distanceBetweenYCentersOfRects(sourceRect, targetRect);\n            const diffY = distanceBetweenYCentersOfRects(sourceRect, lastBestRect);\n\n            if (currentDiffY < diffY) {\n              best.x = currentBest.x;\n            } else if (currentDiffY === diffY) {\n              const gap = attractDistance / 3;\n\n              if (currentBest.x.rawDistance > gap) {\n                if (currentBest.x.alignment === Alignment.leftToLeft) {\n                  best.x = currentBest.x;\n                }\n              } else if (currentBest.x.rawDistance < -gap) {\n                if (currentBest.x.alignment === Alignment.rightToRight) {\n                  best.x = currentBest.x;\n                }\n              } else if (currentBest.x.alignment === Alignment.xCenterToXCenter) {\n                const lastRect = currentBest.x.target.rect;\n                const currentRect = best.x.target.rect;\n                const lastYBase = lastRect.top + lastRect.bottom;\n                const currentYBase = currentRect.top + currentRect.bottom;\n                const sourceYBase = sourceRect.top + sourceRect.bottom;\n                const lastYDistance = abs(lastYBase - sourceYBase);\n                const currentYDistance = abs(currentYBase - sourceYBase);\n\n                if (currentYDistance < lastYDistance) {\n                  best.x = currentBest.x;\n                }\n              }\n            }\n          }\n        }\n\n        if (currentBest.y) {\n          if (best.y === undefined || currentBest.y.absDistance < best.y.absDistance\n          ) {\n            best.y = currentBest.y;\n          } else if (best.y.absDistance === currentBest.y.absDistance) {\n            const sourceRect = getRect(sourcePack);\n            const targetRect = currentBest.y.target.rect;\n            const lastBestRect = best.y.target.rect;\n            const currentDiffX = distanceBetweenXCentersOfRects(sourceRect, targetRect);\n            const diffX = distanceBetweenXCentersOfRects(sourceRect, lastBestRect);\n\n            if (currentDiffX < diffX) {\n              best.y = currentBest.y;\n            } else if (currentDiffX === diffX) {\n              const gap = attractDistance / 3;\n\n              if (currentBest.y.rawDistance < -gap) {\n                if (currentBest.y.alignment === Alignment.bottomToBottom) {\n                  best.y = currentBest.y;\n                }\n              } else if (currentBest.y.rawDistance > gap) {\n                if (currentBest.y.alignment === Alignment.topToTop) {\n                  best.y = currentBest.y;\n                }\n              } else if (currentBest.y.alignment === Alignment.yCenterToYCenter) {\n                const lastRect = currentBest.y.target.rect;\n                const currentRect = best.y.target.rect;\n                const lastXBase = lastRect.right + lastRect.left;\n                const currentXBase = currentRect.right + currentRect.left;\n                const sourceXBase = sourceRect.right + sourceRect.left;\n                const lastXDistance = abs(lastXBase - sourceXBase);\n                const currentXDistance = abs(currentXBase - sourceXBase);\n\n                if (currentXDistance < lastXDistance) {\n                  best.y = currentBest.y;\n                }\n              }\n            }\n          }\n        }\n      }\n\n      return attraction;\n    },\n    {\n      source: sourcePack,\n      target: [],\n      results: [],\n      best: { ...attractionBest },\n    },\n  );\n\n  return multiAttraction;\n}\n\nexport default multiAttractionsTo;\n","import Attraction from '../types/Attraction';\nimport Pack, { getPack, Rectable } from '../types/Pack';\nimport Alignment, { AlignmentXs, AlignmentYs } from '../values/alignment';\nimport AlignTo, { AlignToParent } from '../values/alignTo';\nimport { OnJudgeDistance } from './judgeDistance';\nimport Magnet from '../block';\nimport { returnTrue } from '../utils/returnTrueFalse';\nimport { defaultAttributeValues } from '../core';\nimport Attribute from '../values/attribute';\n\nexport type SingleAttraction = Attraction<Pack>;\n\nexport interface SingleAttractionToOptions {\n  attractDistance?: number;\n  alignTos?: (AlignTo | AlignToParent)[];\n  alignments?: Alignment[];\n  onJudgeDistance?: OnJudgeDistance;\n}\n\n/**\n * Returns result of attractions from source to target on alignments.\n */\nfunction singleAttractionTo(\n  source: Rectable | Pack,\n  target: Rectable | Pack,\n  options: SingleAttractionToOptions = {},\n): SingleAttraction {\n  const sourcePack = getPack(source);\n  const targetPack = getPack(target);\n  const {\n    attractDistance = defaultAttributeValues[Attribute.attractDistance],\n    alignTos = defaultAttributeValues[Attribute.alignTo],\n    alignments = Magnet.getAlignmentsFromAlignTo(alignTos),\n    onJudgeDistance = returnTrue,\n  } = options;\n  const singleAttraction = alignments.reduce<SingleAttraction>(\n    (attraction, alignment) => {\n      const distance = Magnet.prototype.distanceTo.call(sourcePack, targetPack, alignment);\n      const passJudgement = onJudgeDistance(\n        { ...distance },\n        {\n          attractDistance,\n          alignTos,\n        },\n      );\n\n      if (passJudgement) {\n        const { results, best } = attraction;\n\n        results.push(distance);\n\n        if (AlignmentXs.includes(alignment)) {\n          if (best.x === undefined || distance.absDistance < best.x.absDistance) {\n            best.x = distance;\n          } else if (best.x.absDistance === distance.absDistance) {\n            const gap = attractDistance / 3;\n\n            if (distance.rawDistance > gap) {\n              if (distance.alignment === Alignment.leftToLeft) {\n                best.x = distance;\n              }\n            } else if (distance.rawDistance < -gap) {\n              if (distance.alignment === Alignment.rightToRight) {\n                best.x = distance;\n              }\n            } else if (distance.alignment === Alignment.xCenterToXCenter) {\n              best.x = distance;\n            }\n          }\n        } else if (AlignmentYs.includes(alignment)) {\n          if (best.y === undefined || distance.absDistance < best.y.absDistance) {\n            best.y = distance;\n          } else if (best.y.absDistance === distance.absDistance) {\n            const gap = attractDistance / 3;\n\n            if (distance.rawDistance < -gap) {\n              if (distance.alignment === Alignment.bottomToBottom) {\n                best.y = distance;\n              }\n            } else if (distance.rawDistance > gap) {\n              if (distance.alignment === Alignment.topToTop) {\n                best.y = distance;\n              }\n            } else if (distance.alignment === Alignment.yCenterToYCenter) {\n              best.y = distance;\n            }\n          }\n        }\n      }\n\n      return attraction;\n    },\n    {\n      source: sourcePack,\n      target: targetPack,\n      results: [],\n      best: {},\n    },\n  );\n\n  return singleAttraction;\n}\n\nexport default singleAttractionTo;\n","import { SingleAttraction } from './singleAttractionTo';\n\nexport type OnJudgeAttraction = (\n  attraction: SingleAttraction,\n) => boolean;\n\n/**\n * Returns true if the attraction passes the judgement. Otherwise the\n * attraction would not be on the result list of attractions.\n */\nconst judgeAttraction: OnJudgeAttraction = function judgeAttraction(\n  attraction,\n): boolean {\n  return Boolean(attraction.best.x ?? attraction.best.y);\n};\n\nexport default judgeAttraction;\n","import Pack from '../types/Pack';\n\nexport type OnJudgeMovement = (pack: Pack) => boolean;\n\n/**\n * Returns true if the distance passes the judgement. Otherwise the\n * distance would not be on the result list of attraction.\n */\nconst judgeMovement: OnJudgeMovement = function judgeMovement(): boolean {\n  return true;\n};\n\nexport default judgeMovement;\n","type EventHolder = HTMLElement | Document | Window;\ntype EventListener = (...args: any[]) => void;\n\ninterface EventListenerOptions {\n  capture?: boolean;\n  once?: boolean;\n  passive?: boolean;\n}\n\n/**\n * Adds event of type to element.\n */\nexport function addEventListener(\n  ref: EventHolder,\n  type: string,\n  listener: EventListener,\n  options?: EventListenerOptions,\n): void {\n  ref.addEventListener(type, listener, options);\n}\n\n/**\n * Adds events of types to element.\n */\nexport function addEventListeners(\n  ref: EventHolder,\n  types: string[],\n  listener: EventListener,\n  options?: EventListenerOptions,\n): void {\n  types.forEach((type) => {\n    addEventListener(ref, type, listener, options);\n  });\n}\n\n/**\n * Removes event of type from element.\n */\nexport function removeEventListener(\n  ref: EventHolder,\n  type: string,\n  listener: EventListener,\n  options?: EventListenerOptions,\n): void {\n  ref.removeEventListener(type, listener, options);\n}\n\n/**\n * Removes events of types from element.\n */\nexport function removeEventListeners(\n  ref: EventHolder,\n  types: string[],\n  listener: EventListener,\n  options?: EventListenerOptions,\n): void {\n  types.forEach((type) => {\n    ref.removeEventListener(type, listener, options);\n  });\n}\n\ninterface CustomEventInit<T> {\n  detail?: T;\n  bubbles?: boolean;\n  cancelable?: boolean;\n  composed?: boolean;\n}\n\n/**\n * Triggers event and returns false if the event is cancelled.\n */\nexport function triggerEvent<T = undefined>(\n  ref: EventHolder,\n  type: string,\n  options?: CustomEventInit<T>,\n): boolean {\n  return ref.dispatchEvent(new CustomEvent(type, options));\n}\n\n/**\n * Triggers events and returns false if any of the event is\n * cancelled.\n */\nexport function triggerEvents<T>(\n  ref: EventHolder,\n  types: string[],\n  options?: CustomEventInit<T>,\n): boolean {\n  return types.every((type) => triggerEvent(ref, type, options));\n}\n","import createPoint from '../types/Point';\n\n/**\n * Returns offset to keep source rect in target rect.\n */\nfunction getOffsetToBeInRect(sourceRect: DOMRect, targetRect: DOMRect): DOMPoint {\n  let x = 0;\n  let y = 0;\n\n  if (sourceRect.left < targetRect.left) {\n    x = targetRect.left - sourceRect.left;\n  } else if (sourceRect.right > targetRect.right) {\n    x = targetRect.right - sourceRect.right;\n  }\n\n  if (sourceRect.top < targetRect.top) {\n    y = targetRect.top - sourceRect.top;\n  } else if (sourceRect.bottom > targetRect.bottom) {\n    y = targetRect.bottom - sourceRect.bottom;\n  }\n\n  return createPoint(x, y);\n}\n\nexport default getOffsetToBeInRect;\n","import Magnet from '../block';\nimport { defaultAttributeValues } from '../core';\nimport { AttractionBest, getAttractionOffset } from '../types/Attraction';\nimport Distance from '../types/Distance';\nimport {\n  AttractedEventDetail, AttractedmoveEventDetail, AttractEventDetail,\n  AttractmoveEventDetail, UnattractedEventDetail, UnattractEventDetail,\n} from '../types/EventDetail';\nimport Pack from '../types/Pack';\nimport createPoint from '../types/Point';\nimport createRect, { getRect } from '../types/Rect';\nimport { triggerEvent } from '../utils/eventHandler';\nimport getOffsetToBeInRect from '../utils/getOffsetToBeInRect';\nimport { returnFalse, returnTrue } from '../utils/returnTrueFalse';\nimport Alignment from '../values/alignment';\nimport AlignTo, { AlignToParent } from '../values/alignTo';\nimport Attribute from '../values/attribute';\nimport CrossPrevent from '../values/crossPrevent';\nimport Event from '../values/event';\nimport { OnJudgeAttraction } from './judgeAttraction';\nimport { OnJudgeDistance } from './judgeDistance';\nimport { OnJudgeDistanceInParent } from './judgeDistanceInParent';\nimport { OnJudgeMovement } from './judgeMovement';\nimport multiAttractionsTo from './multiAttractionsTo';\nimport singleAttractionTo from './singleAttractionTo';\n\nexport interface AttractionResultOfPositionOptions {\n  ignoreEvent?: boolean;\n  unattractable?: boolean;\n  attractDistance?: number;\n  alignTos?: AlignTo[];\n  alignments?: Alignment[];\n  alignToParents?: AlignToParent[];\n  crossPrevents?: CrossPrevent[];\n  parentPack?: Pack;\n  lastAttractionBest?: AttractionBest | null;\n  onJudgeDistance?: OnJudgeDistance;\n  onJudgeDistanceInParent?: OnJudgeDistanceInParent;\n  onJudgeAttraction?: OnJudgeAttraction;\n  onJudgeMovement?: OnJudgeMovement;\n}\n\ninterface AttractionResultOfPositionResult {\n  position: DOMPoint | null;\n  attractionBest: AttractionBest | null;\n}\n\nfunction attractionResultOfPosition(\n  sourcePack: Pack,\n  targetPacks: Pack[],\n  options: AttractionResultOfPositionOptions = {},\n): AttractionResultOfPositionResult {\n  const sourceRaw = sourcePack.raw as HTMLElement;\n  const {\n    ignoreEvent = !(sourceRaw instanceof HTMLElement),\n    alignToParents = defaultAttributeValues[Attribute.alignToParent],\n    crossPrevents = defaultAttributeValues[Attribute.crossPrevent],\n    parentPack,\n    lastAttractionBest,\n    onJudgeMovement = returnTrue,\n  } = options;\n  const lastBestX = lastAttractionBest?.x;\n  const lastBestY = lastAttractionBest?.y;\n  const parentAlignments = Magnet.getAlignmentsFromAlignTo(alignToParents);\n  const alignToParent = parentAlignments.length > 0;\n  const crossPreventParent = crossPrevents.includes(CrossPrevent.parent);\n  const keepInParent = crossPreventParent && parentPack;\n  const sourceRect = getRect(sourcePack);\n  const {\n    width: sourceWidth,\n    height: sourceHeight,\n  } = sourceRect;\n  const parentRect = getRect(\n    parentPack\n    ?? sourceRect, // hack for tslint because `parentRect` would be needless\n  );\n\n  /**\n   * Need to consider the dragging force when the magnet is prevented\n   * from crossing parent element. The attraction of the near magnets\n   * should be ignored if the force is greater than the attracting\n   * distances.\n   */\n  const sourceRawRect = sourceRect;\n  const sourceInParentOffset = (keepInParent\n    ? getOffsetToBeInRect(sourceRawRect, parentRect)\n    : createPoint(0, 0)\n  );\n  const sourceInParentRect = createRect(\n    sourceRawRect.x + sourceInParentOffset.x,\n    sourceRawRect.y + sourceInParentOffset.y,\n    sourceWidth,\n    sourceHeight,\n  );\n  const sourceInParentPack = new Pack(sourceRaw, sourceInParentRect);\n  const passJudgeMovement = onJudgeMovement(sourceInParentPack);\n\n  /**\n   * Records for those targets need to dispatch event.\n   */\n  const attractResults: Distance[] = [];\n  const unattractResults: Distance[] = [];\n  const attractmoveResults: Distance[] = [];\n\n  const dispatchAttractEvents = (sourceNextRect: DOMRect) => {\n    if (ignoreEvent) {\n      return;\n    }\n\n    attractResults.forEach((attractResult) => {\n      const targetPack = attractResult.target;\n      const targetElem = targetPack.raw as HTMLElement;\n      const attractedEventDetail: AttractedEventDetail = {\n        source: sourceInParentPack,\n        target: targetPack,\n        sourceNextRect,\n        distance: attractResult,\n      };\n\n      triggerEvent<AttractedEventDetail>(\n        targetElem,\n        Event.attracted,\n        {\n          bubbles: true,\n          cancelable: false,\n          composed: true,\n          detail: attractedEventDetail,\n        },\n      );\n    });\n  };\n  const dispatchUnattractEvents = (sourceNextRect: DOMRect) => {\n    if (ignoreEvent) {\n      return;\n    }\n\n    unattractResults.forEach((unattractResult) => {\n      const targetPack = unattractResult.target;\n      const targetElem = targetPack.raw as HTMLElement;\n      const unattractedEventDetail: UnattractedEventDetail = {\n        source: sourceInParentPack,\n        target: targetPack,\n        sourceNextRect,\n      };\n\n      triggerEvent<UnattractedEventDetail>(\n        targetElem,\n        Event.unattracted,\n        {\n          bubbles: true,\n          cancelable: false,\n          composed: true,\n          detail: unattractedEventDetail,\n        },\n      );\n    });\n  };\n  const dispatchAttractmoveEvents = (sourceNextRect: DOMRect) => {\n    if (ignoreEvent) {\n      return;\n    }\n\n    attractmoveResults.forEach((attractmoveResult) => {\n      const targetPack = attractmoveResult.target;\n      const targetElem = targetPack.raw as HTMLElement;\n      const attractedmoveEventDetail: AttractedmoveEventDetail = {\n        source: sourceInParentPack,\n        target: targetPack,\n        sourceNextRect,\n        distance: attractmoveResult,\n      };\n\n      triggerEvent<AttractedmoveEventDetail>(\n        targetElem,\n        Event.attractedmove,\n        {\n          bubbles: true,\n          cancelable: false,\n          composed: true,\n          detail: attractedmoveEventDetail,\n        },\n      );\n    });\n  };\n\n  if (!passJudgeMovement) {\n    if (lastBestX) {\n      unattractResults.push(lastBestX);\n    }\n    if (lastBestY) {\n      unattractResults.push(lastBestY);\n    }\n\n    dispatchUnattractEvents(sourceInParentRect);\n\n    return {\n      position: null,\n      attractionBest: null,\n    };\n  }\n\n  /**\n   * Records best attraction result if magnet aligns to parent.\n   */\n  const attractionBest: AttractionBest = {};\n\n  const {\n    unattractable = defaultAttributeValues[Attribute.unattractable],\n    attractDistance = defaultAttributeValues[Attribute.attractDistance],\n    alignTos = defaultAttributeValues[Attribute.alignTo],\n    alignments = Magnet.getAlignmentsFromAlignTo(alignTos),\n    onJudgeDistanceInParent = returnTrue,\n  } = options;\n  const sourceRawPack = new Pack(sourceRaw, sourceRawRect);\n  const onJudgeDistance = (unattractable\n    ? returnFalse\n    : (options.onJudgeDistance ?? returnTrue)\n  );\n\n  if (alignToParent && parentPack) {\n    const { best } = singleAttractionTo(\n      sourceRawPack,\n      parentPack,\n      {\n        attractDistance,\n        alignTos,\n        alignments,\n        onJudgeDistance,\n      },\n    );\n\n    attractionBest.x = best.x;\n    attractionBest.y = best.y;\n  }\n\n  const onJudgeMultiDistance: OnJudgeDistance = (keepInParent\n    ? ((distance) => (\n      onJudgeDistanceInParent(distance, {\n        attractDistance,\n        alignTos,\n        parent: parentPack,\n        onJudgeDistance,\n      })\n    ))\n    : onJudgeDistance\n  );\n  const onJudgeAttraction = (unattractable\n    ? returnFalse\n    : (options.onJudgeAttraction ?? returnTrue)\n  );\n  const sourceAttraction = multiAttractionsTo(\n    sourceRawPack,\n    targetPacks,\n    {\n      attractDistance,\n      alignTos,\n      alignments,\n      onJudgeDistance: onJudgeMultiDistance,\n      onJudgeAttraction,\n      attractionBest,\n    },\n  );\n  const sourceAttractionBest = sourceAttraction.best;\n  const sourceAttractionOffset = getAttractionOffset(sourceAttraction);\n  const sourceAttractionRect = createRect(\n    sourceRawRect.x + sourceAttractionOffset.x,\n    sourceRawRect.y + sourceAttractionOffset.y,\n    sourceWidth,\n    sourceHeight,\n  );\n  const sourceAttractionInParentOffset = (keepInParent\n    ? getOffsetToBeInRect(sourceAttractionRect, parentRect)\n    : createPoint(0, 0)\n  );\n  const sourceAttractionInParentRect = createRect(\n    sourceAttractionRect.x + sourceAttractionInParentOffset.x,\n    sourceAttractionRect.y + sourceAttractionInParentOffset.y,\n    sourceWidth,\n    sourceHeight,\n  );\n\n  if (!ignoreEvent) {\n    const {\n      x: currentBestX,\n      y: currentBestY,\n    } = sourceAttractionBest;\n    const lastTargetX = lastBestX?.target;\n    const lastTargetY = lastBestY?.target;\n    const currentTargetX = currentBestX?.target;\n    const currentTargetY = currentBestY?.target;\n    const diffTargetX = currentTargetX !== lastTargetX;\n    const diffTargetY = currentTargetY !== lastTargetY;\n\n    /**\n     * Records and dispatches events on x/y packs.\n     */\n    if (diffTargetX) {\n      if (lastTargetX) {\n        unattractResults.push(lastBestX);\n      }\n      if (currentTargetX) {\n        attractResults.push(currentBestX);\n      }\n    } else if (currentTargetX) {\n      const lastAlignmentX = lastBestX?.alignment;\n      const currentAlignmentX = currentBestX.alignment;\n\n      if (lastAlignmentX !== currentAlignmentX) {\n        attractResults.push(currentBestX);\n      } else {\n        attractmoveResults.push(currentBestX);\n      }\n    }\n\n    if (diffTargetY) {\n      if (lastTargetY) {\n        unattractResults.push(lastBestY);\n      }\n      if (currentTargetY) {\n        attractResults.push(currentBestY);\n      }\n    } else if (currentTargetY) {\n      const lastAlignmentY = lastBestY?.alignment;\n      const currentAlignmentY = currentBestY.alignment;\n\n      if (lastAlignmentY !== currentAlignmentY) {\n        attractResults.push(currentBestY);\n      } else {\n        attractmoveResults.push(currentBestY);\n      }\n    }\n\n    /**\n     * Attraction happens.\n     */\n    if (attractResults.length > 0) {\n      const attractEventDetail: AttractEventDetail = {\n        source: sourceInParentPack,\n        nextRect: sourceAttractionInParentRect,\n        attraction: sourceAttraction,\n      };\n      const passAttractEvent = triggerEvent<AttractEventDetail>(\n        sourceRaw,\n        Event.attract,\n        {\n          bubbles: true,\n          cancelable: true,\n          composed: true,\n          detail: attractEventDetail,\n        },\n      );\n\n      if (!passAttractEvent) {\n        if (lastBestX) {\n          unattractResults.push(lastBestX);\n        }\n        if (lastBestY) {\n          unattractResults.push(lastBestY);\n        }\n\n        return {\n          position: createPoint(\n            sourceRawRect.x + sourceInParentOffset.x,\n            sourceRawRect.y + sourceInParentOffset.y,\n          ),\n          attractionBest: null,\n        };\n      }\n    }\n\n    if (unattractResults.length > 0) {\n      const unattractEventDetail: UnattractEventDetail = {\n        source: sourceInParentPack,\n        nextRect: sourceAttractionInParentRect,\n        attraction: sourceAttraction,\n      };\n\n      triggerEvent<UnattractEventDetail>(\n        sourceRaw,\n        Event.unattract,\n        {\n          bubbles: true,\n          cancelable: false,\n          composed: true,\n          detail: unattractEventDetail,\n        },\n      );\n    }\n\n    if (attractmoveResults.length > 0) {\n      const attractmoveEventDetail: AttractmoveEventDetail = {\n        source: sourceInParentPack,\n        nextRect: sourceAttractionInParentRect,\n        attraction: sourceAttraction,\n      };\n\n      triggerEvent<AttractmoveEventDetail>(\n        sourceRaw,\n        Event.attractmove,\n        {\n          bubbles: true,\n          cancelable: false,\n          composed: true,\n          detail: attractmoveEventDetail,\n        },\n      );\n    }\n  }\n\n  dispatchAttractEvents(sourceAttractionInParentRect);\n  dispatchUnattractEvents(sourceAttractionInParentRect);\n  dispatchAttractmoveEvents(sourceAttractionInParentRect);\n\n  return {\n    position: createPoint(\n      sourceRawRect.x + sourceAttractionOffset.x + sourceAttractionInParentOffset.x,\n      sourceRawRect.y + sourceAttractionOffset.y + sourceAttractionInParentOffset.y,\n    ),\n    attractionBest: sourceAttractionBest,\n  };\n}\n\nexport default attractionResultOfPosition;\n","import { createPoint } from '../types/Point';\n\n/**\n * Returns (x, y) of moust/touch event.\n */\nfunction getEventXY(event: PointerEvent): DOMPoint {\n  const { clientX, clientY } = event;\n\n  return createPoint(clientX, clientY);\n}\n\nexport default getEventXY;\n","import Magnet from '../block';\nimport attractionResultOfPosition from '../methods/attractionResultOfPosition';\nimport { OnJudgeMovement } from '../methods/judgeMovement';\nimport { MoveEventDetail, StartEventDetail } from '../types/EventDetail';\nimport Pack from '../types/Pack';\nimport createPoint from '../types/Point';\nimport createRect from '../types/Rect';\nimport Attribute from '../values/attribute';\nimport Event from '../values/event';\nimport { addEventListeners, removeEventListeners, triggerEvent } from './eventHandler';\nimport getEventXY from './getEventXY';\n\nconst EVENT_DRAG_START = ['pointerdown'];\nconst EVENT_DRAG_MOVE = ['pointermove'];\nconst EVENT_DRAG_END = ['pointerup'];\n\n/**\n * Resets magnet caches.\n */\nfunction resetMagnetCaches(magnet: Magnet): void {\n  magnet.resetMagnetRect();\n  magnet.resetParentPack();\n  magnet.resetTargetMagnetPacks();\n}\n\n/**\n * Event listener of drag move event.\n */\nfunction moveListener(\n  this: Magnet,\n  startPoint: DOMPoint,\n  startLastOffset: DOMPoint,\n  movePoint: DOMPoint,\n): DOMPoint {\n  const {\n    magnetRect: sourceRect,\n    targetMagnetPacks: targetPacks,\n    judgeMagnetMovement,\n  } = this;\n  const onJudgeMovement: OnJudgeMovement = (nextSourcePack) => {\n    if (!judgeMagnetMovement(nextSourcePack)) {\n      return false;\n    }\n\n    const moveEventDetail: MoveEventDetail = {\n      source: nextSourcePack,\n      targets: targetPacks,\n      startPoint: createPoint(startPoint),\n      movePoint: createPoint(movePoint),\n    };\n    const passMoveEvent = triggerEvent<MoveEventDetail>(\n      this,\n      Event.magnetmove,\n      {\n        bubbles: true,\n        cancelable: true,\n        composed: true,\n        detail: moveEventDetail,\n      },\n    );\n\n    return passMoveEvent;\n  };\n  const { position, attractionBest } = attractionResultOfPosition(\n    new Pack(this, createRect(\n      sourceRect.x + movePoint.x - startPoint.x,\n      sourceRect.y + movePoint.y - startPoint.y,\n      sourceRect.width,\n      sourceRect.height,\n    )),\n    targetPacks,\n    {\n      unattractable: this.unattractable,\n      attractDistance: this.attractDistance,\n      alignTos: this.alignTos,\n      alignToParents: this.alignToParents,\n      crossPrevents: this.crossPrevents,\n      parentPack: this.parentPack,\n      lastAttractionBest: this.lastAttractionBest,\n      onJudgeDistance: this.judgeMagnetDistance,\n      onJudgeDistanceInParent: this.judgeMagnetDistanceInParent,\n      onJudgeAttraction: this.judgeMagnetAttraction,\n      onJudgeMovement,\n    },\n  );\n  this.setMagnetOffset(\n    (position?.x ?? sourceRect.x) - sourceRect.x + startLastOffset.x,\n    (position?.y ?? sourceRect.y) - sourceRect.y + startLastOffset.y,\n  );\n  this.lastAttractionBest = attractionBest;\n\n  return movePoint;\n}\n\n/**\n * Event listener of drag start event.\n */\nfunction startListener(\n  this: Magnet,\n  event: PointerEvent,\n): void {\n  if (this.disabled || this.unmovable) {\n    return;\n  }\n\n  const startPoint = getEventXY(event);\n\n  this.isMoving = false;\n  resetMagnetCaches(this);\n\n  const {\n    magnetRect: sourceRect,\n    targetMagnetPacks: targetPacks,\n  } = this;\n  const sourcePack = new Pack(this, sourceRect);\n  const startEventDetail: StartEventDetail = {\n    source: sourcePack,\n    targets: targetPacks,\n    startPoint: createPoint(startPoint),\n  };\n  const passStartEvent = triggerEvent<StartEventDetail>(\n    this,\n    Event.magnetstart,\n    {\n      bubbles: true,\n      cancelable: true,\n      composed: true,\n      detail: startEventDetail,\n    },\n  );\n\n  if (!passStartEvent) {\n    return;\n  }\n\n  let lastMovePoint: DOMPoint = startPoint;\n  const dragMoveHandler = moveListener.bind(this, startPoint, this.lastOffset);\n  const dragMoveListener = (evt: PointerEvent) => {\n    const movePoint = getEventXY(evt);\n\n    lastMovePoint = dragMoveHandler(movePoint);\n  };\n  const attributeObserver = new MutationObserver(() => {\n    dragMoveHandler(lastMovePoint);\n  });\n  const dragEndListener = () => {\n    this.isMoving = false;\n    this.style.removeProperty('z-index');\n    removeEventListeners(document, EVENT_DRAG_MOVE, dragMoveListener);\n    removeEventListeners(document, EVENT_DRAG_END, dragEndListener);\n    attributeObserver.disconnect();\n    resetMagnetCaches(this);\n    triggerEvent(this, Event.magnetend, {\n      bubbles: true,\n      cancelable: false,\n      composed: true,\n    });\n  };\n\n  this.isMoving = true;\n  this.style.setProperty('z-index', `${Date.now()}`);\n  event.preventDefault();\n  addEventListeners(document, EVENT_DRAG_MOVE, dragMoveListener);\n  addEventListeners(document, EVENT_DRAG_END, dragEndListener);\n  attributeObserver.observe(this, {\n    attributes: true,\n    attributeFilter: Object.values(Attribute),\n  });\n  dragMoveHandler(lastMovePoint);\n}\n\n/**\n * Adds basic drag event listeners of magnet.\n */\nfunction addBasicDragListeners(magnet: Magnet): void {\n  addEventListeners(magnet, EVENT_DRAG_START, startListener);\n}\n\n/**\n * Removes basic drag event listeners of magnet.\n */\nfunction removeBasicDragListeners(magnet: Magnet): void {\n  removeEventListeners(magnet, EVENT_DRAG_START, startListener);\n}\n\n/**\n * Adds or removes drag event listeners of magnet.\n */\nexport function checkDragListeners(magnet: Magnet): void {\n  if (magnet.disabled || magnet.unmovable) {\n    removeBasicDragListeners(magnet);\n  } else {\n    addBasicDragListeners(magnet);\n  }\n}\n\nexport default startListener;\n","enum Style {\n  offsetX = '--offset-x',\n  offsetY = '--offset-y',\n}\n\nexport default Style;\n","import MagnetPack from './core';\nimport distanceTo from './methods/distanceTo';\nimport rawDistanceTo from './methods/rawDistanceTo';\nimport multiAttractionsTo, { MultiAttractionsToOptions } from './methods/multiAttractionsTo';\nimport singleAttractionTo, { SingleAttractionToOptions } from './methods/singleAttractionTo';\nimport judgeAttraction from './methods/judgeAttraction';\nimport judgeDistance from './methods/judgeDistance';\nimport judgeDistanceInParent from './methods/judgeDistanceInParent';\nimport judgeMovement from './methods/judgeMovement';\nimport { AttractionBest } from './types/Attraction';\nimport Pack, { getPack, Rectable } from './types/Pack';\nimport createPoint from './types/Point';\nimport createRect, { getRect } from './types/Rect';\nimport { checkDragListeners } from './utils/dragListener';\nimport registerElement from './utils/registerElement';\nimport Alignment from './values/alignment';\nimport Attribute from './values/attribute';\nimport OffsetUnit from './values/offsetUnit';\nimport Style from './values/style';\nimport { AlignToParent } from './values/alignTo';\nimport attractionResultOfPosition, { AttractionResultOfPositionOptions } from './methods/attractionResultOfPosition';\n\nconst nodeName = 'magnet-block';\nconst template = document.createElement('template');\n\ntemplate.innerHTML = `\n  <style>\n    :host {\n      --x: var(${Style.offsetX}, 0);\n      --y: var(${Style.offsetY}, 0);\n\n      position: relative;\n      transform: translate(var(--x), var(--y));\n      touch-action: none;\n      display: inline-block;\n    }\n  </style>\n  <slot>\n  </slot>\n`;\n\nclass Magnet extends MagnetPack {\n  protected rectCache: DOMRect | null = null;\n\n  protected parentPackCache: Pack | null = null;\n\n  protected targetMagnetPacksCache: Pack[] | null = null;\n\n  protected isMoving: boolean = false;\n\n  protected lastOffset: DOMPoint = createPoint(0, 0);\n\n  protected lastAttractionBest: AttractionBest | null = null;\n\n  constructor() {\n    super();\n\n    (this.shadowRoot as ShadowRoot).append(template.content.cloneNode(true));\n    checkDragListeners(this);\n  }\n\n  /**\n   * Returns true if magnet is disabled.\n   */\n  get disabled(): boolean {\n    return super.disabled;\n  }\n\n  /**\n   * Sets disabled of magnet.\n   */\n  set disabled(disabled: boolean) {\n    super.disabled = disabled;\n    checkDragListeners(this);\n  }\n\n  /**\n   * Returns true if the magnet is unable to be dragged.\n   */\n  get unmovable(): boolean {\n    return super.unmovable;\n  }\n\n  /**\n   * Sets unmovable of magnet.\n   */\n  set unmovable(unmovable: boolean) {\n    super.unmovable = unmovable;\n    checkDragListeners(this);\n  }\n\n  /**\n   * Returns rect object of this magnet.\n   */\n  get magnetRect(): DOMRect {\n    if (!this.rectCache) {\n      this.rectCache = getRect(this);\n    }\n\n    return this.rectCache;\n  }\n\n  /**\n   * Resets the rect object of this magnet.\n   */\n  resetMagnetRect(): void {\n    if (!this.isMoving) {\n      this.rectCache = null;\n    }\n  }\n\n  /**\n   * Returns pack object of parent if existing.\n   */\n  get parentPack(): Pack {\n    const parent = this.parentElement ?? document.body;\n\n    if (!this.parentPackCache) {\n      this.parentPackCache = getPack(parent);\n    }\n\n    return this.parentPackCache;\n  }\n\n  /**\n   * Resets the pack object of the parent of magnet.\n   */\n  resetParentPack(): void {\n    if (!this.isMoving) {\n      this.parentPackCache = null;\n    }\n  }\n\n  /**\n   * Returns pack objects of target magnets.\n   */\n  get targetMagnetPacks(): Pack[] {\n    if (!this.targetMagnetPacksCache) {\n      this.targetMagnetPacksCache = this.getAttractableMagnets()\n        .map((target) => getPack(target));\n    }\n\n    return this.targetMagnetPacksCache;\n  }\n\n  /**\n   * Resets the pack objects of target magnets.\n   */\n  resetTargetMagnetPacks(): void {\n    if (!this.isMoving) {\n      this.targetMagnetPacksCache = null;\n    }\n  }\n\n  /**\n   * Returns an array of other magnet elements.\n   */\n  getOtherMagnets(): Magnet[] {\n    return (Array.from(document.querySelectorAll(nodeName)) as Magnet[])\n      .filter((magnet) => magnet !== this);\n  }\n\n  /**\n   * Returns an array of attractable magnet elements.\n   */\n  getAttractableMagnets(): Magnet[] {\n    if (this.disabled || this.unattractable) {\n      return [];\n    }\n\n    const { group } = this;\n    const hasGroup = group !== null;\n    const nonDisabledSelector = `:not([${Attribute.disabled}])`;\n    const nonUnattractableSelector = `:not([${Attribute.unattractable}])`;\n    const selector = `${nodeName}${nonDisabledSelector}${nonUnattractableSelector}`;\n    const magnets = (Array.from(document.querySelectorAll(selector)) as Magnet[])\n      .filter((magnet) => (\n        magnet !== this\n        && !this.contains(magnet)\n        && (hasGroup ? group === magnet.group : true)\n      ));\n\n    return magnets;\n  }\n\n  /**\n   * Returns true if the distance passes the judgement. Otherwise the\n   * distance would not be listed on the attraction result.\n   */\n  judgeMagnetDistance(...[\n    distance,\n    options = {},\n  ]: Parameters<typeof judgeDistance>) {\n    const {\n      attractDistance = this.attractDistance,\n      alignTos = this.alignTos,\n    } = options;\n\n    return judgeDistance(distance, {\n      attractDistance,\n      alignTos,\n    });\n  }\n\n  /**\n   * The same as .judgeMagnetDisance but consider a wrapper element.\n   */\n  judgeMagnetDistanceInParent(...[\n    distance,\n    options = {},\n  ]: Parameters<typeof judgeDistanceInParent>) {\n    const {\n      attractDistance = this.attractDistance,\n      alignTos = this.alignTos,\n      onJudgeDistance = this.judgeMagnetDistance,\n    } = options;\n    const parent = options.parent ?? this.parentPack;\n\n    return judgeDistanceInParent(distance, {\n      attractDistance,\n      alignTos,\n      parent,\n      onJudgeDistance,\n    });\n  }\n\n  /**\n   * Returns true if the attraction passes the judgement. Otherwise the\n   * distance results of attraction would not be listed on the result of\n   * attractions.\n   */\n  judgeMagnetAttraction = judgeAttraction\n\n  /**\n  * Returns true if the offset of pack passes the judgement. Otherwise\n  * the magnet would not be applied the movement.\n  */\n  judgeMagnetMovement = judgeMovement\n\n  /**\n   * Returns distance value to target on specific alignment.\n   */\n  rawDistanceTo(\n    target: Rectable | Pack,\n    alignment: Alignment,\n  ) {\n    const sourceRect = getRect(this);\n    const targetRect = getRect(target);\n\n    return rawDistanceTo(sourceRect, targetRect, alignment);\n  }\n\n  /**\n   * Returns distance object to target on alignment.\n   */\n  distanceTo(\n    target: Rectable | Pack,\n    alignment: Alignment,\n  ) {\n    return distanceTo(this, target, alignment);\n  }\n\n  /**\n   * Returns result of attractions to target on alignments.\n   */\n  attractionTo(\n    target: Rectable | Pack,\n    options: SingleAttractionToOptions = {},\n  ) {\n    const {\n      attractDistance = this.attractDistance,\n      alignTos = this.alignTos,\n      alignments,\n      onJudgeDistance = this.judgeMagnetDistance,\n    } = options;\n\n    return singleAttractionTo(\n      this,\n      target,\n      {\n        attractDistance,\n        alignTos,\n        alignments,\n        onJudgeDistance,\n      },\n    );\n  }\n\n  /**\n   * Returns result of attractions to parent on alignments.\n   */\n  attractionToParent(\n    options: SingleAttractionToOptions = {},\n  ) {\n    const {\n      attractDistance = this.attractDistance,\n      alignTos = this.alignToParents,\n      alignments,\n      onJudgeDistance = this.judgeMagnetDistance,\n    } = options;\n\n    return singleAttractionTo(\n      this,\n      this.parentPack,\n      {\n        attractDistance,\n        alignTos,\n        alignments,\n        onJudgeDistance,\n      },\n    );\n  }\n\n  /**\n   * Returns result of attractions from source to targets on alignments.\n   */\n  multiAttractionsTo(\n    targets: (Rectable | Pack)[],\n    options: MultiAttractionsToOptions & {\n      alignToParents?: AlignToParent[];\n    } = {},\n  ) {\n    const {\n      attractDistance = this.attractDistance,\n      alignTos = this.alignTos,\n      alignToParents = this.alignToParents,\n      alignments,\n      onJudgeDistance = this.judgeMagnetDistance,\n      attractionBest,\n      onJudgeAttraction = this.judgeMagnetAttraction,\n    } = options;\n    const parentAttraction = Magnet.prototype.attractionToParent.call(\n      this,\n      {\n        attractDistance,\n        alignTos: alignToParents,\n        alignments,\n        onJudgeDistance,\n        attractionBest,\n      },\n    );\n\n    return multiAttractionsTo(\n      this,\n      targets,\n      {\n        attractDistance,\n        alignTos,\n        alignments,\n        onJudgeDistance,\n        onJudgeAttraction,\n        attractionBest: parentAttraction?.best,\n      },\n    );\n  }\n\n  /**\n   * Returns final available position and attraction on specific position.\n   */\n  getMagnetAttractionResultOfPosition(\n    position: DOMPoint,\n    options?: AttractionResultOfPositionOptions,\n  ): ReturnType<typeof attractionResultOfPosition>\n\n  getMagnetAttractionResultOfPosition(\n    x: number,\n    y: number,\n    options?: AttractionResultOfPositionOptions,\n  ): ReturnType<typeof attractionResultOfPosition>\n\n  getMagnetAttractionResultOfPosition<A0 extends DOMPoint | number>(\n    arg0: A0,\n    arg1?: A0 extends DOMPoint ? AttractionResultOfPositionOptions : number,\n    arg2?: A0 extends DOMPoint ? undefined : AttractionResultOfPositionOptions,\n  ) {\n    const position = createPoint(arg0 as number, arg1 as number);\n    const options = (\n      (arg0 instanceof DOMPoint ? arg1 : arg2) ?? {}\n    ) as AttractionResultOfPositionOptions;\n    const { width, height } = this.magnetRect;\n    const sourceRect = createRect(\n      position.x,\n      position.y,\n      width,\n      height,\n    );\n    const sourcePack = new Pack(this, sourceRect);\n    const {\n      ignoreEvent,\n      unattractable = this.unattractable,\n      attractDistance = this.attractDistance,\n      alignTos = this.alignTos,\n      alignments,\n      alignToParents = this.alignToParents,\n      crossPrevents = this.crossPrevents,\n      parentPack = this.parentPack,\n      lastAttractionBest = this.lastAttractionBest,\n      onJudgeDistance = this.judgeMagnetDistance,\n      onJudgeDistanceInParent = this.judgeMagnetDistanceInParent,\n      onJudgeAttraction = this.judgeMagnetAttraction,\n      onJudgeMovement = this.judgeMagnetMovement,\n    } = options;\n    const result = attractionResultOfPosition(\n      sourcePack,\n      this.targetMagnetPacks,\n      {\n        ignoreEvent,\n        unattractable,\n        attractDistance,\n        alignTos,\n        alignments,\n        alignToParents,\n        crossPrevents,\n        parentPack,\n        lastAttractionBest,\n        onJudgeDistance,\n        onJudgeDistanceInParent,\n        onJudgeAttraction,\n        onJudgeMovement,\n      },\n    );\n\n    this.resetMagnetRect();\n    this.resetParentPack();\n    this.resetTargetMagnetPacks();\n\n    return result;\n  }\n\n  /**\n   * Returns a point object of magnet offset.\n   */\n  get lastMagnetOffset(): DOMPoint {\n    const { offsetUnit, lastOffset } = this;\n\n    switch (offsetUnit) {\n      default:\n      case OffsetUnit.pixel:\n        return createPoint(lastOffset);\n\n      case OffsetUnit.percentage: {\n        const { offsetParent } = this;\n        const parentRect = createRect(offsetParent ?? document);\n        const offset = createPoint(\n          lastOffset.x / parentRect.width,\n          lastOffset.y / parentRect.height,\n        );\n\n        return offset;\n      }\n    }\n  }\n\n  /**\n   * Resets the offset of magnet movement.\n   */\n  resetMagnetOffset(): void {\n    this.style.removeProperty(Style.offsetX);\n    this.style.removeProperty(Style.offsetY);\n    this.lastOffset = createPoint(0, 0);\n  }\n\n  /**\n   * Offsets magnet movement with (dx, dy).\n   */\n  setMagnetOffset(dx: number, dy: number): void\n\n  setMagnetOffset(offset?: DOMPoint): void\n\n  setMagnetOffset<DX extends DOMPoint | number>(\n    dx: DX = this.lastOffset as DX,\n    dy?: DX extends DOMPoint ? undefined : number,\n  ): void {\n    const offset = createPoint(dx as number, dy as number);\n    const { offsetUnit } = this;\n\n    switch (offsetUnit) {\n      default:\n      case OffsetUnit.pixel:\n        this.style.setProperty(Style.offsetX, `${offset.x}px`);\n        this.style.setProperty(Style.offsetY, `${offset.y}px`);\n        break;\n\n      case OffsetUnit.percentage: {\n        const parent = this.offsetParent ?? document.body;\n        const styles = globalThis.getComputedStyle(parent);\n        const { boxSizing, width, height } = styles;\n        let finalWidth = parseFloat(width);\n        let finalHeight = parseFloat(height);\n\n        if (boxSizing === 'border-box') {\n          const {\n            paddingTop, paddingRight, paddingBottom, paddingLeft,\n            borderTopWidth, borderRightWidth, borderBottomWidth, borderLeftWidth,\n          } = styles;\n          const top = parseFloat(paddingTop);\n          const right = parseFloat(paddingRight);\n          const bottom = parseFloat(paddingBottom);\n          const left = parseFloat(paddingLeft);\n          const borderTop = parseFloat(borderTopWidth);\n          const borderRight = parseFloat(borderRightWidth);\n          const borderBottom = parseFloat(borderBottomWidth);\n          const borderLeft = parseFloat(borderLeftWidth);\n\n          finalWidth -= right + left + borderRight + borderLeft;\n          finalHeight -= top + bottom + borderTop + borderBottom;\n        }\n\n        const relativeOffset = createPoint(\n          offset.x / finalWidth,\n          offset.y / finalHeight,\n        );\n\n        this.style.setProperty(Style.offsetX, `${100 * relativeOffset.x}%`);\n        this.style.setProperty(Style.offsetY, `${100 * relativeOffset.y}%`);\n        break;\n      }\n    }\n\n    this.lastOffset = createPoint(offset);\n  }\n\n  /**\n   * Moves magnet movement to (x, y).\n   */\n  setMagnetPosition(x: number, y: number): void\n\n  setMagnetPosition(position?: DOMPoint): void\n\n  setMagnetPosition<X extends DOMPoint | number>(\n    x: X = createPoint(this.magnetRect) as X,\n    y?: X extends DOMPoint ? undefined : number,\n  ) {\n    const position = createPoint(x as number, y as number);\n    const {\n      lastOffset,\n      magnetRect: sourceRect,\n    } = this;\n    const origin = createPoint(\n      sourceRect.x - lastOffset.x,\n      sourceRect.y - lastOffset.y,\n    );\n\n    this.setMagnetOffset(\n      position.x - origin.x,\n      position.y - origin.y,\n    );\n    this.resetMagnetRect();\n  }\n\n  /**\n   * Returns the best attraction of last move.\n   */\n  get bestAttraction(): AttractionBest {\n    const { lastAttractionBest } = this;\n    const x = lastAttractionBest?.x;\n    const y = lastAttractionBest?.y;\n    const attractionBest: AttractionBest = {};\n\n    if (x) {\n      const { source, target } = x;\n\n      attractionBest.x = {\n        ...x,\n        source: new Pack(source.raw, createRect(source.rect)),\n        target: new Pack(target.raw, createRect(target.rect)),\n      };\n    } else {\n      attractionBest.x = undefined;\n    }\n\n    if (y) {\n      const { source, target } = y;\n\n      attractionBest.y = {\n        ...y,\n        source: new Pack(source.raw, createRect(source.rect)),\n        target: new Pack(target.raw, createRect(target.rect)),\n      };\n    } else {\n      attractionBest.y = undefined;\n    }\n\n    return attractionBest;\n  }\n}\n\nregisterElement(Magnet, nodeName);\n\nexport default Magnet;\n","import { defaultAttributeValues } from '../core';\nimport Distance from '../types/Distance';\nimport Alignment from '../values/alignment';\nimport AlignTo, { AlignToParent } from '../values/alignTo';\nimport Attribute from '../values/attribute';\n\nexport interface JudgeDistanceOptions {\n  attractDistance?: number;\n  alignTos?: (AlignTo | AlignToParent)[];\n}\n\nexport type OnJudgeDistance = (\n  distance: Distance,\n  options?: JudgeDistanceOptions,\n) => boolean;\n\n/**\n * Returns true if the distance passes the judgement. Otherwise the\n * distance would not be on the result list of attraction.\n */\nconst judgeDistance: OnJudgeDistance = function judgeDistance(\n  distance,\n  options = {},\n): boolean {\n  const {\n    attractDistance = defaultAttributeValues[Attribute.attractDistance],\n  } = options;\n\n  if (distance.absDistance > attractDistance) {\n    // too far, no consider\n    return false;\n  }\n\n  const {\n    alignTos = defaultAttributeValues[Attribute.alignTo],\n  } = options;\n\n  if (alignTos.includes(AlignTo.extend)) {\n    // align to extended edges\n    return true;\n  }\n\n  const {\n    source: {\n      rect: sourceRect,\n    },\n    target: {\n      rect: targetRect,\n    },\n  } = distance;\n\n  // only pass when source overlaps target\n  switch (distance.alignment) {\n    default:\n      return false;\n\n    case Alignment.topToTop:\n    case Alignment.topToBottom:\n    case Alignment.bottomToTop:\n    case Alignment.bottomToBottom:\n    case Alignment.yCenterToYCenter:\n      if (\n        (sourceRect.right + attractDistance) < targetRect.left\n        || (sourceRect.left - attractDistance) > targetRect.right\n      ) {\n        return false;\n      }\n\n      return true;\n\n    case Alignment.rightToRight:\n    case Alignment.rightToLeft:\n    case Alignment.leftToRight:\n    case Alignment.leftToLeft:\n    case Alignment.xCenterToXCenter:\n      if (\n        (sourceRect.top - attractDistance) > targetRect.bottom\n        || (sourceRect.bottom + attractDistance) < targetRect.top\n      ) {\n        return false;\n      }\n\n      return true;\n  }\n};\n\nexport default judgeDistance;\n","import Distance from '../types/Distance';\nimport Pack, { Rectable } from '../types/Pack';\nimport { getRect } from '../types/Rect';\nimport { returnTrue } from '../utils/returnTrueFalse';\nimport { JudgeDistanceOptions, OnJudgeDistance } from './judgeDistance';\n\nexport interface JudgeDistanceInParentOptions extends JudgeDistanceOptions {\n  parent?: Pack | Rectable | null;\n  onJudgeDistance?: OnJudgeDistance;\n}\n\nexport type OnJudgeDistanceInParent = (\n  distance: Distance,\n  options?: JudgeDistanceInParentOptions,\n) => boolean;\n\n/**\n * Returns true if the distance passes the judgement. Otherwise the\n * distance would not be on the result list of attraction.\n */\nconst judgeDistanceInParent: OnJudgeDistanceInParent = function judgeDistanceInParent(\n  distance,\n  options = {},\n) {\n  const {\n    onJudgeDistance = returnTrue,\n    ...judgeDistanceOptions\n  } = options;\n  const passJudgeDistance = onJudgeDistance(distance, judgeDistanceOptions);\n\n  if (!passJudgeDistance) {\n    return false;\n  }\n\n  /**\n   * If options.parent is `null`, use `document.body` instead.\n   */\n  const parent = options.parent ?? document.body;\n\n  const parentRect = getRect(parent);\n  const { alignment, rawDistance, source } = distance;\n  const {\n    rect: sourceRect,\n  } = source;\n\n  switch (alignment) {\n    default:\n      return true;\n\n    case 'topToTop':\n    case 'topToBottom':\n    case 'bottomToTop':\n    case 'bottomToBottom':\n      return (\n        sourceRect.top + rawDistance >= parentRect.top\n        && sourceRect.bottom + rawDistance <= parentRect.bottom\n      );\n\n    case 'rightToRight':\n    case 'rightToLeft':\n    case 'leftToRight':\n    case 'leftToLeft':\n      return (\n        sourceRect.right + rawDistance <= parentRect.right\n        && sourceRect.left + rawDistance >= parentRect.left\n      );\n\n    case 'xCenterToXCenter':\n      return (\n        sourceRect.right + rawDistance <= parentRect.right\n        && sourceRect.left + rawDistance >= parentRect.left\n      );\n\n    case 'yCenterToYCenter':\n      return (\n        sourceRect.top + rawDistance >= parentRect.top\n        && sourceRect.bottom + rawDistance <= parentRect.bottom\n      );\n  }\n};\n\nexport default judgeDistanceInParent;\n","import Distance from '../types/Distance';\nimport Pack, { getPack, Rectable } from '../types/Pack';\nimport { getRect } from '../types/Rect';\nimport { abs } from '../utils/numeric';\nimport Alignment from '../values/alignment';\nimport rawDistanceTo from './rawDistanceTo';\n\n/**\n * Returns distance object from source to target on alignment.\n */\nfunction distanceTo(\n  source: Rectable | Pack,\n  target: Rectable | Pack,\n  alignment: Alignment,\n): Distance {\n  const sourcePack = getPack(source);\n  const targetPack = getPack(target);\n  const sourceRect = getRect(source);\n  const targetRect = getRect(target);\n  const rawDistance = rawDistanceTo(sourceRect, targetRect, alignment);\n  const absDistance = abs(rawDistance);\n\n  return {\n    source: sourcePack,\n    target: targetPack,\n    alignment,\n    rawDistance,\n    absDistance,\n  };\n}\n\nexport default distanceTo;\n"],"names":["createPoint","x","y","DOMPoint","fromPoint","DOMRect","getAttractionOffset","attraction","best","rawDistance","SPLITTER","getArrayFromAttributeValue","value","indexObject","values","split","undefined","Object","filter","index","includes","getAttributeValueFromArray","Array","isArray","join","Node","nodeName","customElements","get","Promise","reject","Error","define","whenDefined","Alignment","AlignmentXs","rightToRight","rightToLeft","leftToRight","leftToLeft","xCenterToXCenter","AlignmentYs","topToTop","topToBottom","bottomToTop","bottomToBottom","yCenterToYCenter","AlignTo","AlignToParent","Attribute","CrossPrevent","Event","OffsetUnit","isNaN","globalThis","abs","Math","template","document","createElement","defaultAttributeValues","innerHTML","MagnetPack","HTMLElement","constructor","super","this","attachShadow","mode","shadowRoot","append","content","cloneNode","ALIGNMENT","ALIGN_TO","ALIGN_TO_PARENT","CROSS_PREVENT","EVENT","source","alignTos","alignments","push","disabled","traceMagnetAttributeValue","setAttribute","removeAttribute","group","length","parentMagnet","getAttribute","parent","parentElement","parentGroup","unattractable","unmovable","attractDistance","Number","TypeError","RangeError","alignToParents","getAlignmentsFromAlignTo","parentAlignments","crossPrevents","offsetUnit","attrName","registerElement","createRect","args","Window","innerWidth","innerHeight","Document","body","getBoundingClientRect","Element","Pack","fromRect","rect","width","height","top","right","bottom","left","getRect","raw","isPack","freeze","getPack","sourceRect","targetRect","alignment","Infinity","returnTrue","returnFalse","distanceBetweenXCentersOfRects","sourceRectXCenter","targetRectXCenter","distanceBetweenYCentersOfRects","sourceRectYCenter","targetRectYCenter","targets","options","sourcePack","targetPacks","map","target","onJudgeDistance","onJudgeAttraction","attractionBest","singleAttractionOptions","reduce","targetPack","singleAttraction","Magnet","currentBest","results","currentResults","passJudgement","absDistance","lastBestRect","currentDiffY","diffY","gap","lastRect","currentRect","lastYBase","currentYBase","sourceYBase","lastYDistance","currentDiffX","diffX","lastXBase","currentXBase","sourceXBase","lastXDistance","distance","Boolean","addEventListeners","ref","types","listener","forEach","type","addEventListener","removeEventListeners","removeEventListener","triggerEvent","dispatchEvent","CustomEvent","sourceRaw","ignoreEvent","parentPack","lastAttractionBest","onJudgeMovement","lastBestX","lastBestY","alignToParent","keepInParent","sourceWidth","sourceHeight","parentRect","sourceRawRect","sourceInParentOffset","getOffsetToBeInRect","sourceInParentRect","sourceInParentPack","passJudgeMovement","attractResults","unattractResults","attractmoveResults","dispatchUnattractEvents","sourceNextRect","unattractResult","targetElem","unattractedEventDetail","bubbles","cancelable","composed","detail","position","onJudgeDistanceInParent","sourceRawPack","singleAttractionTo","onJudgeMultiDistance","sourceAttraction","multiAttractionsTo","sourceAttractionBest","sourceAttractionOffset","sourceAttractionRect","sourceAttractionInParentOffset","sourceAttractionInParentRect","currentBestX","currentBestY","lastTargetX","lastTargetY","currentTargetX","currentTargetY","diffTargetY","lastAlignmentX","lastAlignmentY","attractEventDetail","nextRect","unattractEventDetail","attractmoveEventDetail","attractResult","attractedEventDetail","attractmoveResult","attractedmoveEventDetail","dispatchAttractmoveEvents","event","clientX","clientY","EVENT_DRAG_START","EVENT_DRAG_MOVE","EVENT_DRAG_END","resetMagnetCaches","magnet","resetMagnetRect","resetParentPack","resetTargetMagnetPacks","moveListener","startPoint","startLastOffset","movePoint","magnetRect","targetMagnetPacks","judgeMagnetMovement","attractionResultOfPosition","judgeMagnetDistance","judgeMagnetDistanceInParent","judgeMagnetAttraction","nextSourcePack","moveEventDetail","setMagnetOffset","startListener","getEventXY","isMoving","startEventDetail","lastMovePoint","dragMoveHandler","bind","lastOffset","dragMoveListener","evt","attributeObserver","MutationObserver","dragEndListener","style","removeProperty","disconnect","setProperty","Date","now","preventDefault","observe","attributes","attributeFilter","checkDragListeners","removeBasicDragListeners","addBasicDragListeners","Style","rectCache","parentPackCache","targetMagnetPacksCache","getAttractableMagnets","getOtherMagnets","from","querySelectorAll","hasGroup","selector","contains","judgeDistance","judgeDistanceOptions","judgeDistanceInParent","judgeAttraction","judgeMovement","rawDistanceTo","distanceTo","attractionTo","attractionToParent","parentAttraction","prototype","call","getMagnetAttractionResultOfPosition","arg0","arg1","arg2","result","lastMagnetOffset","offsetParent","resetMagnetOffset","dx","dy","offset","styles","getComputedStyle","boxSizing","finalWidth","parseFloat","finalHeight","paddingTop","paddingRight","paddingBottom","paddingLeft","borderTopWidth","borderRightWidth","borderBottomWidth","borderLeftWidth","borderTop","borderRight","borderBottom","relativeOffset","setMagnetPosition","origin","bestAttraction"],"sourceRoot":""}