obc-cli2 0.2.3 → 0.2.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.next/standalone/.next/BUILD_ID +1 -1
- package/.next/standalone/.next/build-manifest.json +3 -3
- package/.next/standalone/.next/prerender-manifest.json +3 -3
- package/.next/standalone/.next/server/app/_global-error.html +1 -1
- package/.next/standalone/.next/server/app/_global-error.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found.html +1 -1
- package/.next/standalone/.next/server/app/_not-found.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/index.html +1 -1
- package/.next/standalone/.next/server/app/index.rsc +2 -2
- package/.next/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/index.segments/_full.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/page/react-loadable-manifest.json +3 -3
- package/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/middleware-build-manifest.js +3 -3
- package/.next/standalone/.next/server/pages/404.html +1 -1
- package/.next/standalone/.next/server/pages/500.html +1 -1
- package/.next/standalone/.next/server/server-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/server-reference-manifest.json +1 -1
- package/.next/standalone/.next/static/chunks/002jt~~cq5_aa.js +1 -0
- package/.next/standalone/.next/static/chunks/{0.8j.kvn8ne6d.js → 09.y860--~17v.js} +1 -1
- package/.next/standalone/.next/static/chunks/0bvf78r89wjl0.js +88 -0
- package/.next/standalone/.next/static/chunks/{0~7hzg1mmjrhy.js → 0fv113zapqty~.js} +1 -1
- package/.next/standalone/.next/static/chunks/{0eb83nyqnlhcr.js → 0rggo3n729593.js} +1 -1
- package/.next/standalone/.next/static/chunks/{0jukf_wt2bw41.js → 0yrtklf4iuj86.js} +2 -2
- package/.next/standalone/.next/static/chunks/{0cwgfx0s41pzw.js → 18bi.u.xl8oib.js} +1 -1
- package/.next/standalone/.openboard/excalidraw-guide.md +314 -314
- package/.next/standalone/.openboard/hooks/pretool-guide.mjs +59 -59
- package/.next/standalone/.openboard/hooks/session-hint.mjs +12 -12
- package/.next/standalone/package.json +5 -23
- package/package.json +4 -23
- package/.next/standalone/.next/static/chunks/0r~o4w97q5-v9.js +0 -1
- package/.next/standalone/.next/static/chunks/0wh72i_pn1gx6.js +0 -88
- /package/.next/standalone/.next/static/{K6al_r4r7ce0W379tfIk2 → 9p_qtnWU8_sxf8umL_DVQ}/_buildManifest.js +0 -0
- /package/.next/standalone/.next/static/{K6al_r4r7ce0W379tfIk2 → 9p_qtnWU8_sxf8umL_DVQ}/_clientMiddlewareManifest.js +0 -0
- /package/.next/standalone/.next/static/{K6al_r4r7ce0W379tfIk2 → 9p_qtnWU8_sxf8umL_DVQ}/_ssgManifest.js +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
(globalThis.TURBOPACK||(globalThis.TURBOPACK=[])).push(["object"==typeof document?document.currentScript:void 0,22125,(e,t,n)=>{var i;t.exports=i={},i.simpleFilter=function(e,t){return t.filter(function(t){return i.test(e,t)})},i.test=function(e,t){return null!==i.match(e,t)},i.match=function(e,t,n){n=n||{};var i,a=0,l=[],r=t.length,s=0,o=0,c=n.pre||"",d=n.post||"",h=n.caseSensitive&&t||t.toLowerCase();e=n.caseSensitive&&e||e.toLowerCase();for(var u=0;u<r;u++)i=t[u],h[u]===e[a]?(i=c+i+d,a+=1,o+=1+o):o=0,s+=o,l[l.length]=i;return a===e.length?(s=h===e?1/0:s,{rendered:l.join(""),score:s}):null},i.filter=function(e,t,n){return t&&0!==t.length?"string"!=typeof e?t:(n=n||{},t.reduce(function(t,a,l,r){var s=a;n.extract&&(s=n.extract(a));var o=i.match(e,s,n);return null!=o&&(t[t.length]={string:o.rendered,score:o.score,index:l,original:a}),t},[]).sort(function(e,t){var n=t.score-e.score;return n||e.index-t.index})):[]}},55838,(e,t,n)=>{"use strict";var i=e.r(71645),a="function"==typeof Object.is?Object.is:function(e,t){return e===t&&(0!==e||1/e==1/t)||e!=e&&t!=t},l=i.useState,r=i.useEffect,s=i.useLayoutEffect,o=i.useDebugValue;function c(e){var t=e.getSnapshot;e=e.value;try{var n=t();return!a(e,n)}catch(e){return!0}}var d="u"<typeof window||void 0===window.document||void 0===window.document.createElement?function(e,t){return t()}:function(e,t){var n=t(),i=l({inst:{value:n,getSnapshot:t}}),a=i[0].inst,d=i[1];return s(function(){a.value=n,a.getSnapshot=t,c(a)&&d({inst:a})},[e,n,t]),r(function(){return c(a)&&d({inst:a}),e(function(){c(a)&&d({inst:a})})},[e]),o(n),n};n.useSyncExternalStore=void 0!==i.useSyncExternalStore?i.useSyncExternalStore:d},2239,(e,t,n)=>{"use strict";t.exports=e.r(55838)},52822,(e,t,n)=>{"use strict";var i=e.r(71645),a=e.r(2239),l="function"==typeof Object.is?Object.is:function(e,t){return e===t&&(0!==e||1/e==1/t)||e!=e&&t!=t},r=a.useSyncExternalStore,s=i.useRef,o=i.useEffect,c=i.useMemo,d=i.useDebugValue;n.useSyncExternalStoreWithSelector=function(e,t,n,i,a){var h=s(null);if(null===h.current){var u={hasValue:!1,value:null};h.current=u}else u=h.current;var p=r(e,(h=c(function(){function e(e){if(!o){if(o=!0,r=e,e=i(e),void 0!==a&&u.hasValue){var t=u.value;if(a(t,e))return s=t}return s=e}if(t=s,l(r,e))return t;var n=i(e);return void 0!==a&&a(t,n)?(r=e,t):(r=e,s=n)}var r,s,o=!1,c=void 0===n?null:n;return[function(){return e(t())},null===c?void 0:function(){return e(c())}]},[t,n,i,a]))[0],h[1]);return o(function(){u.hasValue=!0,u.value=p},[p]),d(p),p}},30224,(e,t,n)=>{"use strict";t.exports=e.r(52822)},78333,(e,t,n)=>{var i=0/0,a=/^\s+|\s+$/g,l=/^[-+]0x[0-9a-f]+$/i,r=/^0b[01]+$/i,s=/^0o[0-7]+$/i,o=parseInt,c=e.g&&e.g.Object===Object&&e.g,d="object"==typeof self&&self&&self.Object===Object&&self,h=c||d||Function("return this")(),u=Object.prototype.toString,p=Math.max,m=Math.min,g=function(){return h.Date.now()};function f(e){var t=typeof e;return!!e&&("object"==t||"function"==t)}function b(e){if("number"==typeof e)return e;if("symbol"==typeof(t=e)||t&&"object"==typeof t&&"[object Symbol]"==u.call(t))return i;if(f(e)){var t,n="function"==typeof e.valueOf?e.valueOf():e;e=f(n)?n+"":n}if("string"!=typeof e)return 0===e?e:+e;e=e.replace(a,"");var c=r.test(e);return c||s.test(e)?o(e.slice(2),c?2:8):l.test(e)?i:+e}t.exports=function(e,t,n){var i,a,l,r,s,o,c=0,d=!1,h=!1,u=!0;if("function"!=typeof e)throw TypeError("Expected a function");function v(t){var n=i,l=a;return i=a=void 0,c=t,r=e.apply(l,n)}function y(e){var n=e-o,i=e-c;return void 0===o||n>=t||n<0||h&&i>=l}function E(){var e,n,i,a=g();if(y(a))return x(a);s=setTimeout(E,(e=a-o,n=a-c,i=t-e,h?m(i,l-n):i))}function x(e){return(s=void 0,u&&i)?v(e):(i=a=void 0,r)}function w(){var e,n=g(),l=y(n);if(i=arguments,a=this,o=n,l){if(void 0===s)return c=e=o,s=setTimeout(E,t),d?v(e):r;if(h)return s=setTimeout(E,t),v(o)}return void 0===s&&(s=setTimeout(E,t)),r}return t=b(t)||0,f(n)&&(d=!!n.leading,l=(h="maxWait"in n)?p(b(n.maxWait)||0,t):l,u="trailing"in n?!!n.trailing:u),w.cancel=function(){void 0!==s&&clearTimeout(s),c=0,i=o=a=s=void 0},w.flush=function(){return void 0===s?r:x(g())},w}},86869,e=>{"use strict";let t,n,i;var a,l,r,s,o,c,d,h,u,p,m=e.i(5948),g=e.i(55252),g=g,f=e.i(18094),b=e.i(30406),v=e.i(8908),y=e.i(11017),E=e.i(71645);let x={get url(){return`file://${e.P("node_modules/jotai/esm/vanilla.mjs")}`}},w=0;function S(e,t){let n=`atom${++w}`,i={toString(){return(x.env?x.env.MODE:void 0)!=="production"&&this.debugLabel?n+":"+this.debugLabel:n}};return"function"==typeof e?i.read=e:(i.init=e,i.read=C,i.write=k),t&&(i.write=t),i}function C(e){return e(this)}function k(e,t,n){return t(this,"function"==typeof n?n(e(this)):n)}let I=(e,t)=>e.unstable_is?e.unstable_is(t):t===e,j=e=>"init"in e,T=new WeakMap,M=e=>{var t;return L(e)&&!(null==(t=T.get(e))?void 0:t[1])},L=e=>"function"==typeof(null==e?void 0:e.then),D=e=>"v"in e||"e"in e,N=e=>{if("e"in e)throw e.e;if((x.env?x.env.MODE:void 0)!=="production"&&!("v"in e))throw Error("[Bug] atom state is not initialized");return e.v},A=(e,t,n)=>{n.p.has(e)||(n.p.add(e),t.then(()=>{n.p.delete(e)},()=>{n.p.delete(e)}))},P=(e,t,n,i,a)=>{var l;if((x.env?x.env.MODE:void 0)!=="production"&&i===t)throw Error("[Bug] atom cannot depend on itself");n.d.set(i,a.n),M(n.v)&&A(t,n.v,a),null==(l=a.m)||l.t.add(t),e&&F(e,i,t)},R=()=>({D:new Map,H:new Set,M:new Set,L:new Set}),_=(e,t,n)=>{e[t].add(n)},O=(e,t,n)=>{e.D.has(t)||(e.D.set(t,new Set),_(e,"M",()=>{var t;null==(t=n.m)||t.l.forEach(t=>_(e,"M",t))}))},F=(e,t,n)=>{let i=e.D.get(t);i&&i.add(n)},z=e=>{let t,n=!1,i=e=>{try{e()}catch(e){n||(t=e,n=!0)}};for(;e.H.size||e.M.size||e.L.size;)e.D.clear(),e.H.forEach(i),e.H.clear(),e.M.forEach(i),e.M.clear(),e.L.forEach(i),e.L.clear();if(n)throw t},U=(...[e,t,n,i])=>{let a=(t,n,i)=>{let a="v"in n,l=n.v,r=M(n.v)?n.v:null;if(L(i)){for(let a of((e=>{if(T.has(e))return;let t=[new Set,!1];T.set(e,t);let n=()=>{t[1]=!0};e.then(n,n),e.onCancel=e=>{t[0].add(e)}})(i),n.d.keys()))A(t,i,e(a));n.v=i}else n.v=i;delete n.e,delete n.x,a&&Object.is(l,n.v)||(++n.n,r&&((e,t)=>{let n=T.get(e);if(n)n[1]=!0,n[0].forEach(e=>e(t));else if((x.env?x.env.MODE:void 0)!=="production")throw Error("[Bug] cancelable promise not found")})(r,i))},l=(n,i)=>{var r;let s,d,h=e(i);if(D(h)&&(h.m&&!h.x||Array.from(h.d).every(([e,t])=>l(n,e).n===t)))return h;h.d.clear();let u=!0;try{let p=t(i,t=>{if(I(i,t)){let n=e(t);if(!D(n))if(j(t))a(t,n,t.init);else throw Error("no atom init");return N(n)}let r=l(n,t);try{return N(r)}finally{if(u)P(n,i,h,t,r);else{let e=R();P(e,i,h,t,r),c(e,i,h),z(e)}}},{get signal(){return s||(s=new AbortController),s.signal},get setSelf(){return(x.env?x.env.MODE:void 0)==="production"||i.write||console.warn("setSelf function cannot be used with read-only atom"),!d&&i.write&&(d=(...e)=>{if((x.env?x.env.MODE:void 0)!=="production"&&u&&console.warn("setSelf function cannot be called in sync"),!u)return o(i,...e)}),d}});if(a(i,h,p),L(p)){null==(r=p.onCancel)||r.call(p,()=>null==s?void 0:s.abort());let e=()=>{if(h.m){let e=R();c(e,i,h),z(e)}};p.then(e,e)}return h}catch(e){return delete h.v,h.e=e,delete h.x,++h.n,h}finally{u=!1}},r=(t,n,i)=>{var a,l;let r=new Map;for(let t of(null==(a=i.m)?void 0:a.t)||[]){let n=e(t);n.m&&r.set(t,n)}for(let t of i.p)r.set(t,e(t));return null==(l=t.D.get(n))||l.forEach(t=>{r.set(t,e(t))}),r},s=(t,i,...o)=>{let d=!0;try{return n(i,e=>N(l(t,e)),(n,...o)=>{let h=e(n);try{if(!I(i,n))return s(t,n,...o);{if(!j(n))throw Error("atom not writable");let e=h.n,i=o[0];a(n,h,i),c(t,n,h),e!==h.n&&(O(t,n,h),((e,t,n)=>{let i=[],a=new Set,s=new Set,o=[[t,n]];for(;o.length>0;){let[t,n]=o[o.length-1];if(s.has(t)){o.pop();continue}if(a.has(t)){i.push([t,n,n.n]),s.add(t),n.x=!0,o.pop();continue}for(let[i,l]of(a.add(t),r(e,t,n)))t===i||a.has(i)||o.push([i,l])}_(e,"H",()=>{let n=new Set([t]);for(let t=i.length-1;t>=0;--t){let[a,r,s]=i[t],o=!1;for(let e of r.d.keys())if(e!==a&&n.has(e)){o=!0;break}o&&(l(e,a),c(e,a,r),s!==r.n&&(O(e,a,r),n.add(a))),delete r.x}})})(t,n,h));return}}finally{d||z(t)}},...o)}finally{d=!1}},o=(e,...t)=>{let n=R();try{return s(n,e,...t)}finally{z(n)}},c=(t,n,i)=>{if(i.m&&!M(i.v)){for(let a of i.d.keys())i.m.d.has(a)||(d(t,a,e(a)).t.add(n),i.m.d.add(a));for(let a of i.m.d||[])if(!i.d.has(a)){i.m.d.delete(a);let l=h(t,a,e(a));null==l||l.t.delete(n)}}},d=(t,n,a)=>{if(!a.m){for(let i of(l(t,n),a.d.keys()))d(t,i,e(i)).t.add(n);if(a.m={l:new Set,d:new Set(a.d.keys()),t:new Set},n.write){let e,l=a.m,r=(t,i)=>{let a=!0;e=(...e)=>{try{return s(t,n,...e)}finally{a||z(t)}};try{return i()}finally{a=!1}};_(t,"L",()=>{let a=r(t,()=>i(n,(...t)=>e(...t)));a&&(l.u=e=>r(e,a))})}}return a.m},h=(t,n,i)=>{if(i.m&&!i.m.l.size&&!Array.from(i.m.t).some(t=>{var i;return null==(i=e(t).m)?void 0:i.d.has(n)})){let a=i.m.u;for(let l of(a&&_(t,"L",()=>a(t)),delete i.m,i.d.keys())){let i=h(t,l,e(l));null==i||i.t.delete(n)}return}return i.m};return{get:e=>N(l(void 0,e)),set:o,sub:(t,n)=>{let i=R(),a=e(t),l=d(i,t,a).l;return l.add(n),z(i),()=>{l.delete(n);let e=R();h(e,t,a),z(e)}},unstable_derive:a=>U(...a(e,t,n,i))}},B=()=>{let e=new WeakMap,t=U(t=>{if((x.env?x.env.MODE:void 0)!=="production"&&!t)throw Error("Atom is undefined or null");let n=e.get(t);return n||(n={d:new Map,p:new Set,n:0},e.set(t,n)),n},(e,...t)=>e.read(...t),(e,...t)=>e.write(...t),(e,...t)=>{var n;return null==(n=e.onMount)?void 0:n.call(e,...t)});if((x.env?x.env.MODE:void 0)!=="production"){let e,n,i,a,l,r;return n=new WeakMap,i=new Set,a=0,r=(l=t.unstable_derive((t,l,r,s)=>(e=t,[e=>{let a=n.get(e);return a||(a=new Proxy(t(e),{set:(t,n,a)=>("m"===n&&i.add(e),Reflect.set(t,n,a)),deleteProperty:(t,n)=>("m"===n&&i.delete(e),Reflect.deleteProperty(t,n))}),n.set(e,a)),a},l,(e,t,n,...i)=>a?n(e,...i):r(e,t,n,...i),s]))).set,Object.assign(l,{dev4_get_internal_weak_map:()=>({get:t=>{let n=e(t);if(0!==n.n)return n}}),dev4_get_mounted_atoms:()=>i,dev4_restore_atoms:e=>{r({read:()=>null,write:(t,n)=>{++a;try{for(let[t,i]of e)j(t)&&n(t,i)}finally{--a}}})}})}return t};e.i(47167);var W=e.i(43476);let H={get url(){return`file://${e.P("node_modules/jotai/esm/react.mjs")}`}},$=(0,E.createContext)(void 0),Y=e=>{let n=(0,E.useContext)($);return(null==e?void 0:e.store)||n||(t||(t=B(),(x.env?x.env.MODE:void 0)!=="production"&&(globalThis.__JOTAI_DEFAULT_STORE__||(globalThis.__JOTAI_DEFAULT_STORE__=t),globalThis.__JOTAI_DEFAULT_STORE__!==t&&console.warn("Detected multiple Jotai instances. It may cause unexpected behavior with the default store. https://github.com/pmndrs/jotai/discussions/2044"))),t)},V=e=>"function"==typeof(null==e?void 0:e.then),G=e=>{e.status="pending",e.then(t=>{e.status="fulfilled",e.value=t},t=>{e.status="rejected",e.reason=t})},K=E.default.use||(e=>{if("pending"===e.status)throw e;if("fulfilled"===e.status)return e.value;if("rejected"===e.status)throw e.reason;throw G(e),e}),Z=new WeakMap,X=e=>{let t=Z.get(e);return t||(t=new Promise((n,i)=>{let a=e,l=e=>t=>{a===e&&n(t)},r=e=>t=>{a===e&&i(t)},s=e=>{"onCancel"in e&&"function"==typeof e.onCancel&&e.onCancel(i=>{if((H.env?H.env.MODE:void 0)!=="production"&&i===e)throw Error("[Bug] p is not updated even after cancelation");V(i)?(Z.set(i,t),a=i,i.then(l(i),r(i)),s(i)):n(i)})};e.then(l(e),r(e)),s(e)}),Z.set(e,t)),t};function Q(e,t){let n=Y(t),[[i,a,l],r]=(0,E.useReducer)(t=>{let i=n.get(e);return Object.is(t[0],i)&&t[1]===n&&t[2]===e?t:[i,n,e]},void 0,()=>[n.get(e),n,e]),s=i;(a!==n||l!==e)&&(r(),s=n.get(e));let o=null==t?void 0:t.delay;return((0,E.useEffect)(()=>{let t=n.sub(e,()=>{if("number"==typeof o){let t=n.get(e);V(t)&&G(X(t)),setTimeout(r,o);return}r()});return r(),t},[n,e,o]),(0,E.useDebugValue)(s),V(s))?K(X(s)):s}function q(e,t){let n=Y(t);return(0,E.useCallback)((...t)=>{if((H.env?H.env.MODE:void 0)!=="production"&&!("write"in e))throw Error("not writable atom");return n.set(e,...t)},[n,e])}let J={get url(){return`file://${e.P("node_modules/jotai/esm/vanilla/utils.mjs")}`}};Symbol((J.env?J.env.MODE:void 0)!=="production"?"RESET":""),!function(e=()=>{try{return window.localStorage}catch(e){(J.env?J.env.MODE:void 0)!=="production"&&"u">typeof window&&console.warn(e);return}}){var t;let n,i;try{n=null==(t=e())?void 0:t.subscribe}catch(e){}!n&&"u">typeof window&&"function"==typeof window.addEventListener&&window.Storage&&(n=(t,n)=>{if(!(e()instanceof window.Storage))return()=>{};let i=i=>{i.storageArea===e()&&i.key===t&&n(i.newValue)};return window.addEventListener("storage",i),()=>{window.removeEventListener("storage",i)}}),n&&(i=n,(e,t,n)=>i(e,e=>{let i;try{i=JSON.parse(e||"")}catch(e){i=n}t(i)}))}();let ee=new WeakMap;function et(){return(et=Object.assign.bind()).apply(this,arguments)}function en(){let e=(0,E.createContext)(null),t=t=>{let n=(0,E.useContext)(e);if(!n)throw Error("Missing Provider from createIsolation");return Y(et({store:n},t))};return{Provider:function({store:t,initialValues:n=[],children:i}){let a,l=(0,E.useRef)(t);l.current||(l.current=B());var r,s={store:l.current};let o=Y(s),c=(r=o,(a=ee.get(r))||(a=new WeakSet,ee.set(r,a)),a);for(let[e,t]of n)(!c.has(e)||(null==s?void 0:s.dangerouslyForceHydrate))&&(c.add(e),o.set(e,t));return(0,W.jsx)(e.Provider,{value:l.current,children:i})},useStore:t,useAtom:(e,n)=>{var i;let a=t();return[Q(e,i=et({store:a},n)),q(e,i)]},useAtomValue:(e,n)=>{let i=t();return Q(e,et({store:i},n))},useSetAtom:(e,n)=>{let i=t();return q(e,et({store:i},n))}}}let{read:ei,write:ea}=S(null);(0,E.createContext)({scope:void 0,baseStore:void 0});var el=e.i(2305),er=e.i(74080),es=e.i(90294),eo=e.i(25891);function ec(e,t,{checkForDefaultPrevented:n=!0}={}){return function(i){if(e?.(i),!1===n||!i.defaultPrevented)return t?.(i)}}function ed(e,t){if("function"==typeof e)return e(t);null!=e&&(e.current=t)}function eh(...e){return t=>{let n=!1,i=e.map(e=>{let i=ed(e,t);return n||"function"!=typeof i||(n=!0),i});if(n)return()=>{for(let t=0;t<i.length;t++){let n=i[t];"function"==typeof n?n():ed(e[t],null)}}}}function eu(...e){return E.useCallback(eh(...e),e)}function ep(e,t=[]){let n=[],i=()=>{let t=n.map(e=>E.createContext(e));return function(n){let i=n?.[e]||t;return E.useMemo(()=>({[`__scope${e}`]:{...n,[e]:i}}),[n,i])}};return i.scopeName=e,[function(t,i){let a=E.createContext(i),l=n.length;n=[...n,i];let r=t=>{let{scope:n,children:i,...r}=t,s=n?.[e]?.[l]||a,o=E.useMemo(()=>r,Object.values(r));return(0,W.jsx)(s.Provider,{value:o,children:i})};return r.displayName=t+"Provider",[r,function(n,r){let s=r?.[e]?.[l]||a,o=E.useContext(s);if(o)return o;if(void 0!==i)return i;throw Error(`\`${n}\` must be used within \`${t}\``)}]},function(...e){let t=e[0];if(1===e.length)return t;let n=()=>{let n=e.map(e=>({useScope:e(),scopeName:e.scopeName}));return function(e){let i=n.reduce((t,{useScope:n,scopeName:i})=>{let a=n(e)[`__scope${i}`];return{...t,...a}},{});return E.useMemo(()=>({[`__scope${t.scopeName}`]:i}),[i])}};return n.scopeName=t.scopeName,n}(i,...t)]}var em=E.forwardRef((e,t)=>{let{children:n,...i}=e,a=E.Children.toArray(n),l=a.find(eb);if(l){let e=l.props.children,n=a.map(t=>t!==l?t:E.Children.count(e)>1?E.Children.only(null):E.isValidElement(e)?e.props.children:null);return(0,W.jsx)(eg,{...i,ref:t,children:E.isValidElement(e)?E.cloneElement(e,void 0,n):null})}return(0,W.jsx)(eg,{...i,ref:t,children:n})});em.displayName="Slot";var eg=E.forwardRef((e,t)=>{let{children:n,...i}=e;if(E.isValidElement(n)){var a;let e,l,r=(a=n,(l=(e=Object.getOwnPropertyDescriptor(a.props,"ref")?.get)&&"isReactWarning"in e&&e.isReactWarning)?a.ref:(l=(e=Object.getOwnPropertyDescriptor(a,"ref")?.get)&&"isReactWarning"in e&&e.isReactWarning)?a.props.ref:a.props.ref||a.ref),s=function(e,t){let n={...t};for(let i in t){let a=e[i],l=t[i];/^on[A-Z]/.test(i)?a&&l?n[i]=(...e)=>{l(...e),a(...e)}:a&&(n[i]=a):"style"===i?n[i]={...a,...l}:"className"===i&&(n[i]=[a,l].filter(Boolean).join(" "))}return{...e,...n}}(i,n.props);return n.type!==E.Fragment&&(s.ref=t?eh(t,r):r),E.cloneElement(n,s)}return E.Children.count(n)>1?E.Children.only(null):null});eg.displayName="SlotClone";var ef=({children:e})=>(0,W.jsx)(W.Fragment,{children:e});function eb(e){return E.isValidElement(e)&&e.type===ef}var ev=["a","button","div","form","h2","h3","img","input","label","li","nav","ol","p","span","svg","ul"].reduce((e,t)=>{let n=E.forwardRef((e,n)=>{let{asChild:i,...a}=e,l=i?em:t;return"u">typeof window&&(window[Symbol.for("radix-ui")]=!0),(0,W.jsx)(l,{...a,ref:n})});return n.displayName=`Primitive.${t}`,{...e,[t]:n}},{});function ey(e){let t=E.useRef(e);return E.useEffect(()=>{t.current=e}),E.useMemo(()=>(...e)=>t.current?.(...e),[])}var eE="dismissableLayer.update",ex=E.createContext({layers:new Set,layersWithOutsidePointerEventsDisabled:new Set,branches:new Set}),ew=E.forwardRef((e,t)=>{let{disableOutsidePointerEvents:n=!1,onEscapeKeyDown:i,onPointerDownOutside:a,onFocusOutside:l,onInteractOutside:r,onDismiss:s,...o}=e,c=E.useContext(ex),[h,u]=E.useState(null),p=h?.ownerDocument??globalThis?.document,[,m]=E.useState({}),g=eu(t,e=>u(e)),f=Array.from(c.layers),[b]=[...c.layersWithOutsidePointerEventsDisabled].slice(-1),v=f.indexOf(b),y=h?f.indexOf(h):-1,x=c.layersWithOutsidePointerEventsDisabled.size>0,w=y>=v,S=function(e,t=globalThis?.document){let n=ey(e),i=E.useRef(!1),a=E.useRef(()=>{});return E.useEffect(()=>{let e=e=>{if(e.target&&!i.current){let i=function(){eC("dismissableLayer.pointerDownOutside",n,l,{discrete:!0})},l={originalEvent:e};"touch"===e.pointerType?(t.removeEventListener("click",a.current),a.current=i,t.addEventListener("click",a.current,{once:!0})):i()}else t.removeEventListener("click",a.current);i.current=!1},l=window.setTimeout(()=>{t.addEventListener("pointerdown",e)},0);return()=>{window.clearTimeout(l),t.removeEventListener("pointerdown",e),t.removeEventListener("click",a.current)}},[t,n]),{onPointerDownCapture:()=>i.current=!0}}(e=>{let t=e.target,n=[...c.branches].some(e=>e.contains(t));w&&!n&&(a?.(e),r?.(e),e.defaultPrevented||s?.())},p),C=function(e,t=globalThis?.document){let n=ey(e),i=E.useRef(!1);return E.useEffect(()=>{let e=e=>{e.target&&!i.current&&eC("dismissableLayer.focusOutside",n,{originalEvent:e},{discrete:!1})};return t.addEventListener("focusin",e),()=>t.removeEventListener("focusin",e)},[t,n]),{onFocusCapture:()=>i.current=!0,onBlurCapture:()=>i.current=!1}}(e=>{let t=e.target;![...c.branches].some(e=>e.contains(t))&&(l?.(e),r?.(e),e.defaultPrevented||s?.())},p);return!function(e,t=globalThis?.document){let n=ey(e);E.useEffect(()=>{let e=e=>{"Escape"===e.key&&n(e)};return t.addEventListener("keydown",e,{capture:!0}),()=>t.removeEventListener("keydown",e,{capture:!0})},[n,t])}(e=>{y===c.layers.size-1&&(i?.(e),!e.defaultPrevented&&s&&(e.preventDefault(),s()))},p),E.useEffect(()=>{if(h)return n&&(0===c.layersWithOutsidePointerEventsDisabled.size&&(d=p.body.style.pointerEvents,p.body.style.pointerEvents="none"),c.layersWithOutsidePointerEventsDisabled.add(h)),c.layers.add(h),eS(),()=>{n&&1===c.layersWithOutsidePointerEventsDisabled.size&&(p.body.style.pointerEvents=d)}},[h,p,n,c]),E.useEffect(()=>()=>{h&&(c.layers.delete(h),c.layersWithOutsidePointerEventsDisabled.delete(h),eS())},[h,c]),E.useEffect(()=>{let e=()=>m({});return document.addEventListener(eE,e),()=>document.removeEventListener(eE,e)},[]),(0,W.jsx)(ev.div,{...o,ref:g,style:{pointerEvents:x?w?"auto":"none":void 0,...e.style},onFocusCapture:ec(e.onFocusCapture,C.onFocusCapture),onBlurCapture:ec(e.onBlurCapture,C.onBlurCapture),onPointerDownCapture:ec(e.onPointerDownCapture,S.onPointerDownCapture)})});function eS(){let e=new CustomEvent(eE);document.dispatchEvent(e)}function eC(e,t,n,{discrete:i}){let a=n.originalEvent.target,l=new CustomEvent(e,{bubbles:!1,cancelable:!0,detail:n});if(t&&a.addEventListener(e,t,{once:!0}),i)a&&er.flushSync(()=>a.dispatchEvent(l));else a.dispatchEvent(l)}ew.displayName="DismissableLayer",E.forwardRef((e,t)=>{let n=E.useContext(ex),i=E.useRef(null),a=eu(t,i);return E.useEffect(()=>{let e=i.current;if(e)return n.branches.add(e),()=>{n.branches.delete(e)}},[n.branches]),(0,W.jsx)(ev.div,{...e,ref:a})}).displayName="DismissableLayerBranch";var ek=0;function eI(){let e=document.createElement("span");return e.setAttribute("data-radix-focus-guard",""),e.tabIndex=0,e.style.outline="none",e.style.opacity="0",e.style.position="fixed",e.style.pointerEvents="none",e}var ej="focusScope.autoFocusOnMount",eT="focusScope.autoFocusOnUnmount",eM={bubbles:!1,cancelable:!0},eL=E.forwardRef((e,t)=>{let{loop:n=!1,trapped:i=!1,onMountAutoFocus:a,onUnmountAutoFocus:l,...r}=e,[s,o]=E.useState(null),c=ey(a),d=ey(l),h=E.useRef(null),u=eu(t,e=>o(e)),p=E.useRef({paused:!1,pause(){this.paused=!0},resume(){this.paused=!1}}).current;E.useEffect(()=>{if(i){let e=function(e){if(p.paused||!s)return;let t=e.target;s.contains(t)?h.current=t:eA(h.current,{select:!0})},t=function(e){if(p.paused||!s)return;let t=e.relatedTarget;null!==t&&(s.contains(t)||eA(h.current,{select:!0}))};document.addEventListener("focusin",e),document.addEventListener("focusout",t);let n=new MutationObserver(function(e){if(document.activeElement===document.body)for(let t of e)t.removedNodes.length>0&&eA(s)});return s&&n.observe(s,{childList:!0,subtree:!0}),()=>{document.removeEventListener("focusin",e),document.removeEventListener("focusout",t),n.disconnect()}}},[i,s,p.paused]),E.useEffect(()=>{if(s){eP.add(p);let e=document.activeElement;if(!s.contains(e)){let t=new CustomEvent(ej,eM);s.addEventListener(ej,c),s.dispatchEvent(t),t.defaultPrevented||(function(e,{select:t=!1}={}){let n=document.activeElement;for(let i of e)if(eA(i,{select:t}),document.activeElement!==n)return}(eD(s).filter(e=>"A"!==e.tagName),{select:!0}),document.activeElement===e&&eA(s))}return()=>{s.removeEventListener(ej,c),setTimeout(()=>{let t=new CustomEvent(eT,eM);s.addEventListener(eT,d),s.dispatchEvent(t),t.defaultPrevented||eA(e??document.body,{select:!0}),s.removeEventListener(eT,d),eP.remove(p)},0)}}},[s,c,d,p]);let m=E.useCallback(e=>{if(!n&&!i||p.paused)return;let t="Tab"===e.key&&!e.altKey&&!e.ctrlKey&&!e.metaKey,a=document.activeElement;if(t&&a){var l;let t,i=e.currentTarget,[r,s]=[eN(t=eD(l=i),l),eN(t.reverse(),l)];r&&s?e.shiftKey||a!==s?e.shiftKey&&a===r&&(e.preventDefault(),n&&eA(s,{select:!0})):(e.preventDefault(),n&&eA(r,{select:!0})):a===i&&e.preventDefault()}},[n,i,p.paused]);return(0,W.jsx)(ev.div,{tabIndex:-1,...r,ref:u,onKeyDown:m})});function eD(e){let t=[],n=document.createTreeWalker(e,NodeFilter.SHOW_ELEMENT,{acceptNode:e=>{let t="INPUT"===e.tagName&&"hidden"===e.type;return e.disabled||e.hidden||t?NodeFilter.FILTER_SKIP:e.tabIndex>=0?NodeFilter.FILTER_ACCEPT:NodeFilter.FILTER_SKIP}});for(;n.nextNode();)t.push(n.currentNode);return t}function eN(e,t){for(let n of e)if(!function(e,{upTo:t}){if("hidden"===getComputedStyle(e).visibility)return!0;for(;e&&(void 0===t||e!==t);){if("none"===getComputedStyle(e).display)return!0;e=e.parentElement}return!1}(n,{upTo:t}))return n}function eA(e,{select:t=!1}={}){if(e&&e.focus){var n;let i=document.activeElement;e.focus({preventScroll:!0}),e!==i&&(n=e)instanceof HTMLInputElement&&"select"in n&&t&&e.select()}}eL.displayName="FocusScope";var eP=(i=[],{add(e){let t=i[0];e!==t&&t?.pause(),(i=eR(i,e)).unshift(e)},remove(e){i=eR(i,e),i[0]?.resume()}});function eR(e,t){let n=[...e],i=n.indexOf(t);return -1!==i&&n.splice(i,1),n}var e_=globalThis?.document?E.useLayoutEffect:()=>{},eO=E["useId".toString()]||(()=>void 0),eF=0;let ez=["top","right","bottom","left"],eU=Math.min,eB=Math.max,eW=Math.round,eH=Math.floor,e$=e=>({x:e,y:e}),eY={left:"right",right:"left",bottom:"top",top:"bottom"};function eV(e,t){return"function"==typeof e?e(t):e}function eG(e){return e.split("-")[0]}function eK(e){return e.split("-")[1]}function eZ(e){return"x"===e?"y":"x"}function eX(e){return"y"===e?"height":"width"}function eQ(e){let t=e[0];return"t"===t||"b"===t?"y":"x"}function eq(e){return e.includes("start")?e.replace("start","end"):e.replace("end","start")}let eJ=["left","right"],e0=["right","left"],e1=["top","bottom"],e2=["bottom","top"];function e3(e){let t=eG(e);return eY[t]+e.slice(t.length)}function e5(e){return"number"!=typeof e?{top:0,right:0,bottom:0,left:0,...e}:{top:e,right:e,bottom:e,left:e}}function e4(e){let{x:t,y:n,width:i,height:a}=e;return{width:i,height:a,top:n,left:t,right:t+i,bottom:n+a,x:t,y:n}}function e6(e,t,n){let i,{reference:a,floating:l}=e,r=eQ(t),s=eZ(eQ(t)),o=eX(s),c=eG(t),d="y"===r,h=a.x+a.width/2-l.width/2,u=a.y+a.height/2-l.height/2,p=a[o]/2-l[o]/2;switch(c){case"top":i={x:h,y:a.y-l.height};break;case"bottom":i={x:h,y:a.y+a.height};break;case"right":i={x:a.x+a.width,y:u};break;case"left":i={x:a.x-l.width,y:u};break;default:i={x:a.x,y:a.y}}switch(eK(t)){case"start":i[s]-=p*(n&&d?-1:1);break;case"end":i[s]+=p*(n&&d?-1:1)}return i}async function e8(e,t){var n;void 0===t&&(t={});let{x:i,y:a,platform:l,rects:r,elements:s,strategy:o}=e,{boundary:c="clippingAncestors",rootBoundary:d="viewport",elementContext:h="floating",altBoundary:u=!1,padding:p=0}=eV(t,e),m=e5(p),g=s[u?"floating"===h?"reference":"floating":h],f=e4(await l.getClippingRect({element:null==(n=await (null==l.isElement?void 0:l.isElement(g)))||n?g:g.contextElement||await (null==l.getDocumentElement?void 0:l.getDocumentElement(s.floating)),boundary:c,rootBoundary:d,strategy:o})),b="floating"===h?{x:i,y:a,width:r.floating.width,height:r.floating.height}:r.reference,v=await (null==l.getOffsetParent?void 0:l.getOffsetParent(s.floating)),y=await (null==l.isElement?void 0:l.isElement(v))&&await (null==l.getScale?void 0:l.getScale(v))||{x:1,y:1},E=e4(l.convertOffsetParentRelativeRectToViewportRelativeRect?await l.convertOffsetParentRelativeRectToViewportRelativeRect({elements:s,rect:b,offsetParent:v,strategy:o}):b);return{top:(f.top-E.top+m.top)/y.y,bottom:(E.bottom-f.bottom+m.bottom)/y.y,left:(f.left-E.left+m.left)/y.x,right:(E.right-f.right+m.right)/y.x}}let e7=async(e,t,n)=>{let{placement:i="bottom",strategy:a="absolute",middleware:l=[],platform:r}=n,s=r.detectOverflow?r:{...r,detectOverflow:e8},o=await (null==r.isRTL?void 0:r.isRTL(t)),c=await r.getElementRects({reference:e,floating:t,strategy:a}),{x:d,y:h}=e6(c,i,o),u=i,p=0,m={};for(let n=0;n<l.length;n++){let g=l[n];if(!g)continue;let{name:f,fn:b}=g,{x:v,y:y,data:E,reset:x}=await b({x:d,y:h,initialPlacement:i,placement:u,strategy:a,middlewareData:m,rects:c,platform:s,elements:{reference:e,floating:t}});d=null!=v?v:d,h=null!=y?y:h,m[f]={...m[f],...E},x&&p<50&&(p++,"object"==typeof x&&(x.placement&&(u=x.placement),x.rects&&(c=!0===x.rects?await r.getElementRects({reference:e,floating:t,strategy:a}):x.rects),{x:d,y:h}=e6(c,u,o)),n=-1)}return{x:d,y:h,placement:u,strategy:a,middlewareData:m}};function e9(e,t){return{top:e.top-t.height,right:e.right-t.width,bottom:e.bottom-t.height,left:e.left-t.width}}function te(e){return ez.some(t=>e[t]>=0)}let tt=new Set(["left","top"]);async function tn(e,t){let{placement:n,platform:i,elements:a}=e,l=await (null==i.isRTL?void 0:i.isRTL(a.floating)),r=eG(n),s=eK(n),o="y"===eQ(n),c=tt.has(r)?-1:1,d=l&&o?-1:1,h=eV(t,e),{mainAxis:u,crossAxis:p,alignmentAxis:m}="number"==typeof h?{mainAxis:h,crossAxis:0,alignmentAxis:null}:{mainAxis:h.mainAxis||0,crossAxis:h.crossAxis||0,alignmentAxis:h.alignmentAxis};return s&&"number"==typeof m&&(p="end"===s?-1*m:m),o?{x:p*d,y:u*c}:{x:u*c,y:p*d}}function ti(){return"u">typeof window}function ta(e){return ts(e)?(e.nodeName||"").toLowerCase():"#document"}function tl(e){var t;return(null==e||null==(t=e.ownerDocument)?void 0:t.defaultView)||window}function tr(e){var t;return null==(t=(ts(e)?e.ownerDocument:e.document)||window.document)?void 0:t.documentElement}function ts(e){return!!ti()&&(e instanceof Node||e instanceof tl(e).Node)}function to(e){return!!ti()&&(e instanceof Element||e instanceof tl(e).Element)}function tc(e){return!!ti()&&(e instanceof HTMLElement||e instanceof tl(e).HTMLElement)}function td(e){return!(!ti()||"u"<typeof ShadowRoot)&&(e instanceof ShadowRoot||e instanceof tl(e).ShadowRoot)}function th(e){let{overflow:t,overflowX:n,overflowY:i,display:a}=ty(e);return/auto|scroll|overlay|hidden|clip/.test(t+i+n)&&"inline"!==a&&"contents"!==a}function tu(e){try{if(e.matches(":popover-open"))return!0}catch(e){}try{return e.matches(":modal")}catch(e){return!1}}let tp=/transform|translate|scale|rotate|perspective|filter/,tm=/paint|layout|strict|content/,tg=e=>!!e&&"none"!==e;function tf(e){let t=to(e)?ty(e):e;return tg(t.transform)||tg(t.translate)||tg(t.scale)||tg(t.rotate)||tg(t.perspective)||!tb()&&(tg(t.backdropFilter)||tg(t.filter))||tp.test(t.willChange||"")||tm.test(t.contain||"")}function tb(){return null==n&&(n="u">typeof CSS&&CSS.supports&&CSS.supports("-webkit-backdrop-filter","none")),n}function tv(e){return/^(html|body|#document)$/.test(ta(e))}function ty(e){return tl(e).getComputedStyle(e)}function tE(e){return to(e)?{scrollLeft:e.scrollLeft,scrollTop:e.scrollTop}:{scrollLeft:e.scrollX,scrollTop:e.scrollY}}function tx(e){if("html"===ta(e))return e;let t=e.assignedSlot||e.parentNode||td(e)&&e.host||tr(e);return td(t)?t.host:t}function tw(e,t,n){var i;void 0===t&&(t=[]),void 0===n&&(n=!0);let a=function e(t){let n=tx(t);return tv(n)?t.ownerDocument?t.ownerDocument.body:t.body:tc(n)&&th(n)?n:e(n)}(e),l=a===(null==(i=e.ownerDocument)?void 0:i.body),r=tl(a);if(!l)return t.concat(a,tw(a,[],n));{let e=tS(r);return t.concat(r,r.visualViewport||[],th(a)?a:[],e&&n?tw(e):[])}}function tS(e){return e.parent&&Object.getPrototypeOf(e.parent)?e.frameElement:null}function tC(e){let t=ty(e),n=parseFloat(t.width)||0,i=parseFloat(t.height)||0,a=tc(e),l=a?e.offsetWidth:n,r=a?e.offsetHeight:i,s=eW(n)!==l||eW(i)!==r;return s&&(n=l,i=r),{width:n,height:i,$:s}}function tk(e){return to(e)?e:e.contextElement}function tI(e){let t=tk(e);if(!tc(t))return e$(1);let n=t.getBoundingClientRect(),{width:i,height:a,$:l}=tC(t),r=(l?eW(n.width):n.width)/i,s=(l?eW(n.height):n.height)/a;return r&&Number.isFinite(r)||(r=1),s&&Number.isFinite(s)||(s=1),{x:r,y:s}}let tj=e$(0);function tT(e){let t=tl(e);return tb()&&t.visualViewport?{x:t.visualViewport.offsetLeft,y:t.visualViewport.offsetTop}:tj}function tM(e,t,n,i){var a;void 0===t&&(t=!1),void 0===n&&(n=!1);let l=e.getBoundingClientRect(),r=tk(e),s=e$(1);t&&(i?to(i)&&(s=tI(i)):s=tI(e));let o=(void 0===(a=n)&&(a=!1),i&&(!a||i===tl(r))&&a)?tT(r):e$(0),c=(l.left+o.x)/s.x,d=(l.top+o.y)/s.y,h=l.width/s.x,u=l.height/s.y;if(r){let e=tl(r),t=i&&to(i)?tl(i):i,n=e,a=tS(n);for(;a&&i&&t!==n;){let e=tI(a),t=a.getBoundingClientRect(),i=ty(a),l=t.left+(a.clientLeft+parseFloat(i.paddingLeft))*e.x,r=t.top+(a.clientTop+parseFloat(i.paddingTop))*e.y;c*=e.x,d*=e.y,h*=e.x,u*=e.y,c+=l,d+=r,a=tS(n=tl(a))}}return e4({width:h,height:u,x:c,y:d})}function tL(e,t){let n=tE(e).scrollLeft;return t?t.left+n:tM(tr(e)).left+n}function tD(e,t){let n=e.getBoundingClientRect();return{x:n.left+t.scrollLeft-tL(e,n),y:n.top+t.scrollTop}}function tN(e,t,n){var i;let a;if("viewport"===t)a=function(e,t){let n=tl(e),i=tr(e),a=n.visualViewport,l=i.clientWidth,r=i.clientHeight,s=0,o=0;if(a){l=a.width,r=a.height;let e=tb();(!e||e&&"fixed"===t)&&(s=a.offsetLeft,o=a.offsetTop)}let c=tL(i);if(c<=0){let e=i.ownerDocument,t=e.body,n=getComputedStyle(t),a="CSS1Compat"===e.compatMode&&parseFloat(n.marginLeft)+parseFloat(n.marginRight)||0,r=Math.abs(i.clientWidth-t.clientWidth-a);r<=25&&(l-=r)}else c<=25&&(l+=c);return{width:l,height:r,x:s,y:o}}(e,n);else if("document"===t){let t,n,l,r,s,o,c;i=tr(e),t=tr(i),n=tE(i),l=i.ownerDocument.body,r=eB(t.scrollWidth,t.clientWidth,l.scrollWidth,l.clientWidth),s=eB(t.scrollHeight,t.clientHeight,l.scrollHeight,l.clientHeight),o=-n.scrollLeft+tL(i),c=-n.scrollTop,"rtl"===ty(l).direction&&(o+=eB(t.clientWidth,l.clientWidth)-r),a={width:r,height:s,x:o,y:c}}else if(to(t)){let e,i,l,r,s,o;i=(e=tM(t,!0,"fixed"===n)).top+t.clientTop,l=e.left+t.clientLeft,r=tc(t)?tI(t):e$(1),s=t.clientWidth*r.x,o=t.clientHeight*r.y,a={width:s,height:o,x:l*r.x,y:i*r.y}}else{let n=tT(e);a={x:t.x-n.x,y:t.y-n.y,width:t.width,height:t.height}}return e4(a)}function tA(e){return"static"===ty(e).position}function tP(e,t){if(!tc(e)||"fixed"===ty(e).position)return null;if(t)return t(e);let n=e.offsetParent;return tr(e)===n&&(n=n.ownerDocument.body),n}function tR(e,t){var n;let i=tl(e);if(tu(e))return i;if(!tc(e)){let t=tx(e);for(;t&&!tv(t);){if(to(t)&&!tA(t))return t;t=tx(t)}return i}let a=tP(e,t);for(;a&&(n=a,/^(table|td|th)$/.test(ta(n)))&&tA(a);)a=tP(a,t);return a&&tv(a)&&tA(a)&&!tf(a)?i:a||function(e){let t=tx(e);for(;tc(t)&&!tv(t);){if(tf(t))return t;if(tu(t))break;t=tx(t)}return null}(e)||i}let t_=async function(e){let t=this.getOffsetParent||tR,n=this.getDimensions,i=await n(e.floating);return{reference:function(e,t,n){let i=tc(t),a=tr(t),l="fixed"===n,r=tM(e,!0,l,t),s={scrollLeft:0,scrollTop:0},o=e$(0);if(i||!i&&!l)if(("body"!==ta(t)||th(a))&&(s=tE(t)),i){let e=tM(t,!0,l,t);o.x=e.x+t.clientLeft,o.y=e.y+t.clientTop}else a&&(o.x=tL(a));l&&!i&&a&&(o.x=tL(a));let c=!a||i||l?e$(0):tD(a,s);return{x:r.left+s.scrollLeft-o.x-c.x,y:r.top+s.scrollTop-o.y-c.y,width:r.width,height:r.height}}(e.reference,await t(e.floating),e.strategy),floating:{x:0,y:0,width:i.width,height:i.height}}},tO={convertOffsetParentRelativeRectToViewportRelativeRect:function(e){let{elements:t,rect:n,offsetParent:i,strategy:a}=e,l="fixed"===a,r=tr(i),s=!!t&&tu(t.floating);if(i===r||s&&l)return n;let o={scrollLeft:0,scrollTop:0},c=e$(1),d=e$(0),h=tc(i);if((h||!h&&!l)&&(("body"!==ta(i)||th(r))&&(o=tE(i)),h)){let e=tM(i);c=tI(i),d.x=e.x+i.clientLeft,d.y=e.y+i.clientTop}let u=!r||h||l?e$(0):tD(r,o);return{width:n.width*c.x,height:n.height*c.y,x:n.x*c.x-o.scrollLeft*c.x+d.x+u.x,y:n.y*c.y-o.scrollTop*c.y+d.y+u.y}},getDocumentElement:tr,getClippingRect:function(e){let{element:t,boundary:n,rootBoundary:i,strategy:a}=e,l=[..."clippingAncestors"===n?tu(t)?[]:function(e,t){let n=t.get(e);if(n)return n;let i=tw(e,[],!1).filter(e=>to(e)&&"body"!==ta(e)),a=null,l="fixed"===ty(e).position,r=l?tx(e):e;for(;to(r)&&!tv(r);){let t=ty(r),n=tf(r);n||"fixed"!==t.position||(a=null),(l?n||a:!(!n&&"static"===t.position&&a&&("absolute"===a.position||"fixed"===a.position)||th(r)&&!n&&function e(t,n){let i=tx(t);return!(i===n||!to(i)||tv(i))&&("fixed"===ty(i).position||e(i,n))}(e,r)))?a=t:i=i.filter(e=>e!==r),r=tx(r)}return t.set(e,i),i}(t,this._c):[].concat(n),i],r=tN(t,l[0],a),s=r.top,o=r.right,c=r.bottom,d=r.left;for(let e=1;e<l.length;e++){let n=tN(t,l[e],a);s=eB(n.top,s),o=eU(n.right,o),c=eU(n.bottom,c),d=eB(n.left,d)}return{width:o-d,height:c-s,x:d,y:s}},getOffsetParent:tR,getElementRects:t_,getClientRects:function(e){return Array.from(e.getClientRects())},getDimensions:function(e){let{width:t,height:n}=tC(e);return{width:t,height:n}},getScale:tI,isElement:to,isRTL:function(e){return"rtl"===ty(e).direction}};function tF(e,t){return e.x===t.x&&e.y===t.y&&e.width===t.width&&e.height===t.height}let tz=e=>({name:"arrow",options:e,async fn(t){let{x:n,y:i,placement:a,rects:l,platform:r,elements:s,middlewareData:o}=t,{element:c,padding:d=0}=eV(e,t)||{};if(null==c)return{};let h=e5(d),u={x:n,y:i},p=eZ(eQ(a)),m=eX(p),g=await r.getDimensions(c),f="y"===p,b=f?"clientHeight":"clientWidth",v=l.reference[m]+l.reference[p]-u[p]-l.floating[m],y=u[p]-l.reference[p],E=await (null==r.getOffsetParent?void 0:r.getOffsetParent(c)),x=E?E[b]:0;x&&await (null==r.isElement?void 0:r.isElement(E))||(x=s.floating[b]||l.floating[m]);let w=x/2-g[m]/2-1,S=eU(h[f?"top":"left"],w),C=eU(h[f?"bottom":"right"],w),k=x-g[m]-C,I=x/2-g[m]/2+(v/2-y/2),j=eB(S,eU(I,k)),T=!o.arrow&&null!=eK(a)&&I!==j&&l.reference[m]/2-(I<S?S:C)-g[m]/2<0,M=T?I<S?I-S:I-k:0;return{[p]:u[p]+M,data:{[p]:j,centerOffset:I-j-M,...T&&{alignmentOffset:M}},reset:T}}});var tU="u">typeof document?E.useLayoutEffect:function(){};function tB(e,t){let n,i,a;if(e===t)return!0;if(typeof e!=typeof t)return!1;if("function"==typeof e&&e.toString()===t.toString())return!0;if(e&&t&&"object"==typeof e){if(Array.isArray(e)){if((n=e.length)!==t.length)return!1;for(i=n;0!=i--;)if(!tB(e[i],t[i]))return!1;return!0}if((n=(a=Object.keys(e)).length)!==Object.keys(t).length)return!1;for(i=n;0!=i--;)if(!({}).hasOwnProperty.call(t,a[i]))return!1;for(i=n;0!=i--;){let n=a[i];if(("_owner"!==n||!e.$$typeof)&&!tB(e[n],t[n]))return!1}return!0}return e!=e&&t!=t}function tW(e){return"u"<typeof window?1:(e.ownerDocument.defaultView||window).devicePixelRatio||1}function tH(e,t){let n=tW(e);return Math.round(t*n)/n}function t$(e){let t=E.useRef(e);return tU(()=>{t.current=e}),t}var tY=E.forwardRef((e,t)=>{let{children:n,width:i=10,height:a=5,...l}=e;return(0,W.jsx)(ev.svg,{...l,ref:t,width:i,height:a,viewBox:"0 0 30 10",preserveAspectRatio:"none",children:e.asChild?n:(0,W.jsx)("polygon",{points:"0,0 30,0 15,10"})})});tY.displayName="Arrow";var tV="Popper",[tG,tK]=ep(tV),[tZ,tX]=tG(tV),tQ=e=>{let{__scopePopper:t,children:n}=e,[i,a]=E.useState(null);return(0,W.jsx)(tZ,{scope:t,anchor:i,onAnchorChange:a,children:n})};tQ.displayName=tV;var tq="PopperAnchor",tJ=E.forwardRef((e,t)=>{let{__scopePopper:n,virtualRef:i,...a}=e,l=tX(tq,n),r=E.useRef(null),s=eu(t,r);return E.useEffect(()=>{l.onAnchorChange(i?.current||r.current)}),i?null:(0,W.jsx)(ev.div,{...a,ref:s})});tJ.displayName=tq;var t0="PopperContent",[t1,t2]=tG(t0),t3=E.forwardRef((e,t)=>{var n,i,a,l,r,s,o,c,d,h,u,p,m,g,f,b,v,y,x,w,S;let C,k,I,j,T,M,{__scopePopper:L,side:D="bottom",sideOffset:N=0,align:A="center",alignOffset:P=0,arrowPadding:R=0,avoidCollisions:_=!0,collisionBoundary:O=[],collisionPadding:F=0,sticky:z="partial",hideWhenDetached:U=!1,updatePositionStrategy:B="optimized",onPlaced:H,...$}=e,Y=tX(t0,L),[V,G]=E.useState(null),K=eu(t,e=>G(e)),[Z,X]=E.useState(null),Q=function(e){let[t,n]=E.useState(void 0);return e_(()=>{if(e){n({width:e.offsetWidth,height:e.offsetHeight});let t=new ResizeObserver(t=>{let i,a;if(!Array.isArray(t)||!t.length)return;let l=t[0];if("borderBoxSize"in l){let e=l.borderBoxSize,t=Array.isArray(e)?e[0]:e;i=t.inlineSize,a=t.blockSize}else i=e.offsetWidth,a=e.offsetHeight;n({width:i,height:a})});return t.observe(e,{box:"border-box"}),()=>t.unobserve(e)}n(void 0)},[e]),t}(Z),q=Q?.width??0,J=Q?.height??0,ee="number"==typeof F?F:{top:0,right:0,bottom:0,left:0,...F},et=Array.isArray(O)?O:[O],en=et.length>0,ei={padding:ee,boundary:et.filter(t8),altBoundary:en},{refs:ea,floatingStyles:el,placement:es,isPositioned:eo,middlewareData:ec}=function(e){void 0===e&&(e={});let{placement:t="bottom",strategy:n="absolute",middleware:i=[],platform:a,elements:{reference:l,floating:r}={},transform:s=!0,whileElementsMounted:o,open:c}=e,[d,h]=E.useState({x:0,y:0,strategy:n,placement:t,middlewareData:{},isPositioned:!1}),[u,p]=E.useState(i);tB(u,i)||p(i);let[m,g]=E.useState(null),[f,b]=E.useState(null),v=E.useCallback(e=>{e!==S.current&&(S.current=e,g(e))},[]),y=E.useCallback(e=>{e!==C.current&&(C.current=e,b(e))},[]),x=l||m,w=r||f,S=E.useRef(null),C=E.useRef(null),k=E.useRef(d),I=null!=o,j=t$(o),T=t$(a),M=t$(c),L=E.useCallback(()=>{var e,i;let a,l,r;if(!S.current||!C.current)return;let s={placement:t,strategy:n,middleware:u};T.current&&(s.platform=T.current),(e=S.current,i=C.current,a=new Map,r={...(l={platform:tO,...s}).platform,_c:a},e7(e,i,{...l,platform:r})).then(e=>{let t={...e,isPositioned:!1!==M.current};D.current&&!tB(k.current,t)&&(k.current=t,er.flushSync(()=>{h(t)}))})},[u,t,n,T,M]);tU(()=>{!1===c&&k.current.isPositioned&&(k.current.isPositioned=!1,h(e=>({...e,isPositioned:!1})))},[c]);let D=E.useRef(!1);tU(()=>(D.current=!0,()=>{D.current=!1}),[]),tU(()=>{if(x&&(S.current=x),w&&(C.current=w),x&&w){if(j.current)return j.current(x,w,L);L()}},[x,w,L,j,I]);let N=E.useMemo(()=>({reference:S,floating:C,setReference:v,setFloating:y}),[v,y]),A=E.useMemo(()=>({reference:x,floating:w}),[x,w]),P=E.useMemo(()=>{let e={position:n,left:0,top:0};if(!A.floating)return e;let t=tH(A.floating,d.x),i=tH(A.floating,d.y);return s?{...e,transform:"translate("+t+"px, "+i+"px)",...tW(A.floating)>=1.5&&{willChange:"transform"}}:{position:n,left:t,top:i}},[n,s,A.floating,d.x,d.y]);return E.useMemo(()=>({...d,update:L,refs:N,elements:A,floatingStyles:P}),[d,L,N,A,P])}({strategy:"fixed",placement:D+("center"!==A?"-"+A:""),whileElementsMounted:(...e)=>(function(e,t,n,i){let a;void 0===i&&(i={});let{ancestorScroll:l=!0,ancestorResize:r=!0,elementResize:s="function"==typeof ResizeObserver,layoutShift:o="function"==typeof IntersectionObserver,animationFrame:c=!1}=i,d=tk(e),h=l||r?[...d?tw(d):[],...t?tw(t):[]]:[];h.forEach(e=>{l&&e.addEventListener("scroll",n,{passive:!0}),r&&e.addEventListener("resize",n)});let u=d&&o?function(e,t){let n,i=null,a=tr(e);function l(){var e;clearTimeout(n),null==(e=i)||e.disconnect(),i=null}return!function r(s,o){void 0===s&&(s=!1),void 0===o&&(o=1),l();let c=e.getBoundingClientRect(),{left:d,top:h,width:u,height:p}=c;if(s||t(),!u||!p)return;let m={rootMargin:-eH(h)+"px "+-eH(a.clientWidth-(d+u))+"px "+-eH(a.clientHeight-(h+p))+"px "+-eH(d)+"px",threshold:eB(0,eU(1,o))||1},g=!0;function f(t){let i=t[0].intersectionRatio;if(i!==o){if(!g)return r();i?r(!1,i):n=setTimeout(()=>{r(!1,1e-7)},1e3)}1!==i||tF(c,e.getBoundingClientRect())||r(),g=!1}try{i=new IntersectionObserver(f,{...m,root:a.ownerDocument})}catch(e){i=new IntersectionObserver(f,m)}i.observe(e)}(!0),l}(d,n):null,p=-1,m=null;s&&(m=new ResizeObserver(e=>{let[i]=e;i&&i.target===d&&m&&t&&(m.unobserve(t),cancelAnimationFrame(p),p=requestAnimationFrame(()=>{var e;null==(e=m)||e.observe(t)})),n()}),d&&!c&&m.observe(d),t&&m.observe(t));let g=c?tM(e):null;return c&&function t(){let i=tM(e);g&&!tF(g,i)&&n(),g=i,a=requestAnimationFrame(t)}(),n(),()=>{var e;h.forEach(e=>{l&&e.removeEventListener("scroll",n),r&&e.removeEventListener("resize",n)}),null==u||u(),null==(e=m)||e.disconnect(),m=null,c&&cancelAnimationFrame(a)}})(...e,{animationFrame:"always"===B}),elements:{reference:Y.anchor},middleware:[{name:(C={name:"offset",options:a=n={mainAxis:N+J,alignmentAxis:P},async fn(e){var t,n;let{x:i,y:l,placement:r,middlewareData:s}=e,o=await tn(e,a);return r===(null==(t=s.offset)?void 0:t.placement)&&null!=(n=s.arrow)&&n.alignmentOffset?{}:{x:i+o.x,y:l+o.y,data:{...o,placement:r}}}}).name,fn:C.fn,options:[n,i]},_&&{name:(k={name:"shift",options:d=o={mainAxis:!0,crossAxis:!1,limiter:"partial"===z?{fn:(void 0===(s=l)&&(s={}),{options:s,fn(e){let{x:t,y:n,placement:i,rects:a,middlewareData:l}=e,{offset:r=0,mainAxis:o=!0,crossAxis:c=!0}=eV(s,e),d={x:t,y:n},h=eQ(i),u=eZ(h),p=d[u],m=d[h],g=eV(r,e),f="number"==typeof g?{mainAxis:g,crossAxis:0}:{mainAxis:0,crossAxis:0,...g};if(o){let e="y"===u?"height":"width",t=a.reference[u]-a.floating[e]+f.mainAxis,n=a.reference[u]+a.reference[e]-f.mainAxis;p<t?p=t:p>n&&(p=n)}if(c){var b,v;let e="y"===u?"width":"height",t=tt.has(eG(i)),n=a.reference[h]-a.floating[e]+(t&&(null==(b=l.offset)?void 0:b[h])||0)+(t?0:f.crossAxis),r=a.reference[h]+a.reference[e]+(t?0:(null==(v=l.offset)?void 0:v[h])||0)-(t?f.crossAxis:0);m<n?m=n:m>r&&(m=r)}return{[u]:p,[h]:m}}}).fn,options:[l,r]}:void 0,...ei},async fn(e){let{x:t,y:n,placement:i,platform:a}=e,{mainAxis:l=!0,crossAxis:r=!1,limiter:s={fn:e=>{let{x:t,y:n}=e;return{x:t,y:n}}},...o}=eV(d,e),c={x:t,y:n},h=await a.detectOverflow(e,o),u=eQ(eG(i)),p=eZ(u),m=c[p],g=c[u];if(l){let e="y"===p?"top":"left",t="y"===p?"bottom":"right",n=m+h[e],i=m-h[t];m=eB(n,eU(m,i))}if(r){let e="y"===u?"top":"left",t="y"===u?"bottom":"right",n=g+h[e],i=g-h[t];g=eB(n,eU(g,i))}let f=s.fn({...e,[p]:m,[u]:g});return{...f,data:{x:f.x-t,y:f.y-n,enabled:{[p]:l,[u]:r}}}}}).name,fn:k.fn,options:[o,c]},_&&{name:(I={name:"flip",options:p=h={...ei},async fn(e){var t,n,i,a,l,r,s,o;let c,d,h,{placement:u,middlewareData:m,rects:g,initialPlacement:f,platform:b,elements:v}=e,{mainAxis:y=!0,crossAxis:E=!0,fallbackPlacements:x,fallbackStrategy:w="bestFit",fallbackAxisSideDirection:S="none",flipAlignment:C=!0,...k}=eV(p,e);if(null!=(t=m.arrow)&&t.alignmentOffset)return{};let I=eG(u),j=eQ(f),T=eG(f)===f,M=await (null==b.isRTL?void 0:b.isRTL(v.floating)),L=x||(T||!C?[e3(f)]:(c=e3(f),[eq(f),c,eq(c)])),D="none"!==S;!x&&D&&L.push(...(d=eK(f),h=function(e,t,n){switch(e){case"top":case"bottom":if(n)return t?e0:eJ;return t?eJ:e0;case"left":case"right":return t?e1:e2;default:return[]}}(eG(f),"start"===S,M),d&&(h=h.map(e=>e+"-"+d),C&&(h=h.concat(h.map(eq)))),h));let N=[f,...L],A=await b.detectOverflow(e,k),P=[],R=(null==(n=m.flip)?void 0:n.overflows)||[];if(y&&P.push(A[I]),E){let e,t,n,i,a=(r=u,s=g,void 0===(o=M)&&(o=!1),e=eK(r),n=eX(t=eZ(eQ(r))),i="x"===t?e===(o?"end":"start")?"right":"left":"start"===e?"bottom":"top",s.reference[n]>s.floating[n]&&(i=e3(i)),[i,e3(i)]);P.push(A[a[0]],A[a[1]])}if(R=[...R,{placement:u,overflows:P}],!P.every(e=>e<=0)){let e=((null==(i=m.flip)?void 0:i.index)||0)+1,t=N[e];if(t&&("alignment"!==E||j===eQ(t)||R.every(e=>eQ(e.placement)!==j||e.overflows[0]>0)))return{data:{index:e,overflows:R},reset:{placement:t}};let n=null==(a=R.filter(e=>e.overflows[0]<=0).sort((e,t)=>e.overflows[1]-t.overflows[1])[0])?void 0:a.placement;if(!n)switch(w){case"bestFit":{let e=null==(l=R.filter(e=>{if(D){let t=eQ(e.placement);return t===j||"y"===t}return!0}).map(e=>[e.placement,e.overflows.filter(e=>e>0).reduce((e,t)=>e+t,0)]).sort((e,t)=>e[1]-t[1])[0])?void 0:l[0];e&&(n=e);break}case"initialPlacement":n=f}if(u!==n)return{reset:{placement:n}}}return{}}}).name,fn:I.fn,options:[h,u]},{name:(j={name:"size",options:f=m={...ei,apply:({elements:e,rects:t,availableWidth:n,availableHeight:i})=>{let{width:a,height:l}=t.reference,r=e.floating.style;r.setProperty("--radix-popper-available-width",`${n}px`),r.setProperty("--radix-popper-available-height",`${i}px`),r.setProperty("--radix-popper-anchor-width",`${a}px`),r.setProperty("--radix-popper-anchor-height",`${l}px`)}},async fn(e){var t,n;let i,a,{placement:l,rects:r,platform:s,elements:o}=e,{apply:c=()=>{},...d}=eV(f,e),h=await s.detectOverflow(e,d),u=eG(l),p=eK(l),m="y"===eQ(l),{width:g,height:b}=r.floating;"top"===u||"bottom"===u?(i=u,a=p===(await (null==s.isRTL?void 0:s.isRTL(o.floating))?"start":"end")?"left":"right"):(a=u,i="end"===p?"top":"bottom");let v=b-h.top-h.bottom,y=g-h.left-h.right,E=eU(b-h[i],v),x=eU(g-h[a],y),w=!e.middlewareData.shift,S=E,C=x;if(null!=(t=e.middlewareData.shift)&&t.enabled.x&&(C=y),null!=(n=e.middlewareData.shift)&&n.enabled.y&&(S=v),w&&!p){let e=eB(h.left,0),t=eB(h.right,0),n=eB(h.top,0),i=eB(h.bottom,0);m?C=g-2*(0!==e||0!==t?e+t:eB(h.left,h.right)):S=b-2*(0!==n||0!==i?n+i:eB(h.top,h.bottom))}await c({...e,availableWidth:C,availableHeight:S});let k=await s.getDimensions(o.floating);return g!==k.width||b!==k.height?{reset:{rects:!0}}:{}}}).name,fn:j.fn,options:[m,g]},Z&&{name:(T={name:"arrow",options:y=b={element:Z,padding:R},fn(e){let{element:t,padding:n}="function"==typeof y?y(e):y;return t&&({}).hasOwnProperty.call(t,"current")?null!=t.current?tz({element:t.current,padding:n}).fn(e):{}:t?tz({element:t,padding:n}).fn(e):{}}}).name,fn:T.fn,options:[b,v]},t7({arrowWidth:q,arrowHeight:J}),U&&{name:(M={name:"hide",options:S=x={strategy:"referenceHidden",...ei},async fn(e){let{rects:t,platform:n}=e,{strategy:i="referenceHidden",...a}=eV(S,e);switch(i){case"referenceHidden":{let i=e9(await n.detectOverflow(e,{...a,elementContext:"reference"}),t.reference);return{data:{referenceHiddenOffsets:i,referenceHidden:te(i)}}}case"escaped":{let i=e9(await n.detectOverflow(e,{...a,altBoundary:!0}),t.floating);return{data:{escapedOffsets:i,escaped:te(i)}}}default:return{}}}}).name,fn:M.fn,options:[x,w]}]}),[ed,eh]=t9(es),ep=ey(H);e_(()=>{eo&&ep?.()},[eo,ep]);let em=ec.arrow?.x,eg=ec.arrow?.y,ef=ec.arrow?.centerOffset!==0,[eb,eE]=E.useState();return e_(()=>{V&&eE(window.getComputedStyle(V).zIndex)},[V]),(0,W.jsx)("div",{ref:ea.setFloating,"data-radix-popper-content-wrapper":"",style:{...el,transform:eo?el.transform:"translate(0, -200%)",minWidth:"max-content",zIndex:eb,"--radix-popper-transform-origin":[ec.transformOrigin?.x,ec.transformOrigin?.y].join(" "),...ec.hide?.referenceHidden&&{visibility:"hidden",pointerEvents:"none"}},dir:e.dir,children:(0,W.jsx)(t1,{scope:L,placedSide:ed,onArrowChange:X,arrowX:em,arrowY:eg,shouldHideArrow:ef,children:(0,W.jsx)(ev.div,{"data-side":ed,"data-align":eh,...$,ref:K,style:{...$.style,animation:eo?void 0:"none"}})})})});t3.displayName=t0;var t5="PopperArrow",t4={top:"bottom",right:"left",bottom:"top",left:"right"},t6=E.forwardRef(function(e,t){let{__scopePopper:n,...i}=e,a=t2(t5,n),l=t4[a.placedSide];return(0,W.jsx)("span",{ref:a.onArrowChange,style:{position:"absolute",left:a.arrowX,top:a.arrowY,[l]:0,transformOrigin:{top:"",right:"0 0",bottom:"center 0",left:"100% 0"}[a.placedSide],transform:{top:"translateY(100%)",right:"translateY(50%) rotate(90deg) translateX(-50%)",bottom:"rotate(180deg)",left:"translateY(50%) rotate(-90deg) translateX(50%)"}[a.placedSide],visibility:a.shouldHideArrow?"hidden":void 0},children:(0,W.jsx)(tY,{...i,ref:t,style:{...i.style,display:"block"}})})});function t8(e){return null!==e}t6.displayName=t5;var t7=e=>({name:"transformOrigin",options:e,fn(t){let{placement:n,rects:i,middlewareData:a}=t,l=a.arrow?.centerOffset!==0,r=l?0:e.arrowWidth,s=l?0:e.arrowHeight,[o,c]=t9(n),d={start:"0%",center:"50%",end:"100%"}[c],h=(a.arrow?.x??0)+r/2,u=(a.arrow?.y??0)+s/2,p="",m="";return"bottom"===o?(p=l?d:`${h}px`,m=`${-s}px`):"top"===o?(p=l?d:`${h}px`,m=`${i.floating.height+s}px`):"right"===o?(p=`${-s}px`,m=l?d:`${u}px`):"left"===o&&(p=`${i.floating.width+s}px`,m=l?d:`${u}px`),{data:{x:p,y:m}}}});function t9(e){let[t,n="center"]=e.split("-");return[t,n]}var ne=E.forwardRef((e,t)=>{let{container:n,...i}=e,[a,l]=E.useState(!1);e_(()=>l(!0),[]);let r=n||a&&globalThis?.document?.body;return r?er.default.createPortal((0,W.jsx)(ev.div,{...i,ref:t}),r):null});ne.displayName="Portal";var nt=e=>{var t;let n,i,{present:a,children:l}=e,r=function(e){var t,n;let[i,a]=E.useState(),l=E.useRef({}),r=E.useRef(e),s=E.useRef("none"),[o,c]=(t=e?"mounted":"unmounted",n={mounted:{UNMOUNT:"unmounted",ANIMATION_OUT:"unmountSuspended"},unmountSuspended:{MOUNT:"mounted",ANIMATION_END:"unmounted"},unmounted:{MOUNT:"mounted"}},E.useReducer((e,t)=>n[e][t]??e,t));return E.useEffect(()=>{let e=nn(l.current);s.current="mounted"===o?e:"none"},[o]),e_(()=>{let t=l.current,n=r.current;if(n!==e){let i=s.current,a=nn(t);e?c("MOUNT"):"none"===a||t?.display==="none"?c("UNMOUNT"):n&&i!==a?c("ANIMATION_OUT"):c("UNMOUNT"),r.current=e}},[e,c]),e_(()=>{if(i){let e,t=i.ownerDocument.defaultView??window,n=n=>{let a=nn(l.current).includes(n.animationName);if(n.target===i&&a&&(c("ANIMATION_END"),!r.current)){let n=i.style.animationFillMode;i.style.animationFillMode="forwards",e=t.setTimeout(()=>{"forwards"===i.style.animationFillMode&&(i.style.animationFillMode=n)})}},a=e=>{e.target===i&&(s.current=nn(l.current))};return i.addEventListener("animationstart",a),i.addEventListener("animationcancel",n),i.addEventListener("animationend",n),()=>{t.clearTimeout(e),i.removeEventListener("animationstart",a),i.removeEventListener("animationcancel",n),i.removeEventListener("animationend",n)}}c("ANIMATION_END")},[i,c]),{isPresent:["mounted","unmountSuspended"].includes(o),ref:E.useCallback(e=>{e&&(l.current=getComputedStyle(e)),a(e)},[])}}(a),s="function"==typeof l?l({present:r.isPresent}):E.Children.only(l),o=eu(r.ref,(t=s,(i=(n=Object.getOwnPropertyDescriptor(t.props,"ref")?.get)&&"isReactWarning"in n&&n.isReactWarning)?t.ref:(i=(n=Object.getOwnPropertyDescriptor(t,"ref")?.get)&&"isReactWarning"in n&&n.isReactWarning)?t.props.ref:t.props.ref||t.ref));return"function"==typeof l||r.isPresent?E.cloneElement(s,{ref:o}):null};function nn(e){return e?.animationName||"none"}nt.displayName="Presence";var ni=new WeakMap,na=new WeakMap,nl={},nr=0,ns=function(e){return e&&(e.host||ns(e.parentNode))},no=function(e,t,n,i){var a=(Array.isArray(e)?e:[e]).map(function(e){if(t.contains(e))return e;var n=ns(e);return n&&t.contains(n)?n:(console.error("aria-hidden",e,"in not contained inside",t,". Doing nothing"),null)}).filter(function(e){return!!e});nl[n]||(nl[n]=new WeakMap);var l=nl[n],r=[],s=new Set,o=new Set(a),c=function(e){!e||s.has(e)||(s.add(e),c(e.parentNode))};a.forEach(c);var d=function(e){!e||o.has(e)||Array.prototype.forEach.call(e.children,function(e){if(s.has(e))d(e);else try{var t=e.getAttribute(i),a=null!==t&&"false"!==t,o=(ni.get(e)||0)+1,c=(l.get(e)||0)+1;ni.set(e,o),l.set(e,c),r.push(e),1===o&&a&&na.set(e,!0),1===c&&e.setAttribute(n,"true"),a||e.setAttribute(i,"true")}catch(t){console.error("aria-hidden: cannot operate on ",e,t)}})};return d(t),s.clear(),nr++,function(){r.forEach(function(e){var t=ni.get(e)-1,a=l.get(e)-1;ni.set(e,t),l.set(e,a),t||(na.has(e)||e.removeAttribute(i),na.delete(e)),a||e.removeAttribute(n)}),--nr||(ni=new WeakMap,ni=new WeakMap,na=new WeakMap,nl={})}},nc=function(e,t,n){void 0===n&&(n="data-aria-hidden");var i=Array.from(Array.isArray(e)?e:[e]),a=t||("u"<typeof document?null:(Array.isArray(e)?e[0]:e).ownerDocument.body);return a?(i.push.apply(i,Array.from(a.querySelectorAll("[aria-live], script"))),no(i,a,n,"aria-hidden")):function(){return null}},nd=function(){return(nd=Object.assign||function(e){for(var t,n=1,i=arguments.length;n<i;n++)for(var a in t=arguments[n])Object.prototype.hasOwnProperty.call(t,a)&&(e[a]=t[a]);return e}).apply(this,arguments)};function nh(e,t){var n={};for(var i in e)Object.prototype.hasOwnProperty.call(e,i)&&0>t.indexOf(i)&&(n[i]=e[i]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols)for(var a=0,i=Object.getOwnPropertySymbols(e);a<i.length;a++)0>t.indexOf(i[a])&&Object.prototype.propertyIsEnumerable.call(e,i[a])&&(n[i[a]]=e[i[a]]);return n}var nu=("function"==typeof SuppressedError&&SuppressedError,"right-scroll-bar-position"),np="width-before-scroll-bar";function nm(e,t){return"function"==typeof e?e(t):e&&(e.current=t),e}var ng="u">typeof window?E.useLayoutEffect:E.useEffect,nf=new WeakMap,nb=(void 0===a&&(a={}),(void 0===l&&(l=function(e){return e}),r=[],s=!1,o={read:function(){if(s)throw Error("Sidecar: could not `read` from an `assigned` medium. `read` could be used only with `useMedium`.");return r.length?r[r.length-1]:null},useMedium:function(e){var t=l(e,s);return r.push(t),function(){r=r.filter(function(e){return e!==t})}},assignSyncMedium:function(e){for(s=!0;r.length;){var t=r;r=[],t.forEach(e)}r={push:function(t){return e(t)},filter:function(){return r}}},assignMedium:function(e){s=!0;var t=[];if(r.length){var n=r;r=[],n.forEach(e),t=r}var i=function(){var n=t;t=[],n.forEach(e)},a=function(){return Promise.resolve().then(i)};a(),r={push:function(e){t.push(e),a()},filter:function(e){return t=t.filter(e),r}}}}).options=nd({async:!0,ssr:!1},a),o),nv=function(){},ny=E.forwardRef(function(e,t){var n,i,a,l,r=E.useRef(null),s=E.useState({onScrollCapture:nv,onWheelCapture:nv,onTouchMoveCapture:nv}),o=s[0],c=s[1],d=e.forwardProps,h=e.children,u=e.className,p=e.removeScrollBar,m=e.enabled,g=e.shards,f=e.sideCar,b=e.noRelative,v=e.noIsolation,y=e.inert,x=e.allowPinchZoom,w=e.as,S=e.gapMode,C=nh(e,["forwardProps","children","className","removeScrollBar","enabled","shards","sideCar","noRelative","noIsolation","inert","allowPinchZoom","as","gapMode"]),k=(n=[r,t],i=function(e){return n.forEach(function(t){return nm(t,e)})},(a=(0,E.useState)(function(){return{value:null,callback:i,facade:{get current(){return a.value},set current(value){var e=a.value;e!==value&&(a.value=value,a.callback(value,e))}}}})[0]).callback=i,l=a.facade,ng(function(){var e=nf.get(l);if(e){var t=new Set(e),i=new Set(n),a=l.current;t.forEach(function(e){i.has(e)||nm(e,null)}),i.forEach(function(e){t.has(e)||nm(e,a)})}nf.set(l,n)},[n]),l),I=nd(nd({},C),o);return E.createElement(E.Fragment,null,m&&E.createElement(f,{sideCar:nb,removeScrollBar:p,shards:g,noRelative:b,noIsolation:v,inert:y,setCallbacks:c,allowPinchZoom:!!x,lockRef:r,gapMode:S}),d?E.cloneElement(E.Children.only(h),nd(nd({},I),{ref:k})):E.createElement(void 0===w?"div":w,nd({},I,{className:u,ref:k}),h))});ny.defaultProps={enabled:!0,removeScrollBar:!0,inert:!1},ny.classNames={fullWidth:np,zeroRight:nu};var nE=function(e){var t=e.sideCar,n=nh(e,["sideCar"]);if(!t)throw Error("Sidecar: please provide `sideCar` property to import the right car");var i=t.read();if(!i)throw Error("Sidecar medium not found");return E.createElement(i,nd({},n))};nE.isSideCarExport=!0;var nx=function(){var e=0,t=null;return{add:function(n){if(0==e&&(t=function(){if(!document)return null;var e=document.createElement("style");e.type="text/css";var t=h||("u">typeof __webpack_nonce__?__webpack_nonce__:void 0);return t&&e.setAttribute("nonce",t),e}())){var i,a;(i=t).styleSheet?i.styleSheet.cssText=n:i.appendChild(document.createTextNode(n)),a=t,(document.head||document.getElementsByTagName("head")[0]).appendChild(a)}e++},remove:function(){--e||!t||(t.parentNode&&t.parentNode.removeChild(t),t=null)}}},nw=function(){var e=nx();return function(t,n){E.useEffect(function(){return e.add(t),function(){e.remove()}},[t&&n])}},nS=function(){var e=nw();return function(t){return e(t.styles,t.dynamic),null}},nC={left:0,top:0,right:0,gap:0},nk=function(e){return parseInt(e||"",10)||0},nI=function(e){var t=window.getComputedStyle(document.body),n=t["padding"===e?"paddingLeft":"marginLeft"],i=t["padding"===e?"paddingTop":"marginTop"],a=t["padding"===e?"paddingRight":"marginRight"];return[nk(n),nk(i),nk(a)]},nj=function(e){if(void 0===e&&(e="margin"),"u"<typeof window)return nC;var t=nI(e),n=document.documentElement.clientWidth,i=window.innerWidth;return{left:t[0],top:t[1],right:t[2],gap:Math.max(0,i-n+t[2]-t[0])}},nT=nS(),nM="data-scroll-locked",nL=function(e,t,n,i){var a=e.left,l=e.top,r=e.right,s=e.gap;return void 0===n&&(n="margin"),"\n .".concat("with-scroll-bars-hidden"," {\n overflow: hidden ").concat(i,";\n padding-right: ").concat(s,"px ").concat(i,";\n }\n body[").concat(nM,"] {\n overflow: hidden ").concat(i,";\n overscroll-behavior: contain;\n ").concat([t&&"position: relative ".concat(i,";"),"margin"===n&&"\n padding-left: ".concat(a,"px;\n padding-top: ").concat(l,"px;\n padding-right: ").concat(r,"px;\n margin-left:0;\n margin-top:0;\n margin-right: ").concat(s,"px ").concat(i,";\n "),"padding"===n&&"padding-right: ".concat(s,"px ").concat(i,";")].filter(Boolean).join(""),"\n }\n \n .").concat(nu," {\n right: ").concat(s,"px ").concat(i,";\n }\n \n .").concat(np," {\n margin-right: ").concat(s,"px ").concat(i,";\n }\n \n .").concat(nu," .").concat(nu," {\n right: 0 ").concat(i,";\n }\n \n .").concat(np," .").concat(np," {\n margin-right: 0 ").concat(i,";\n }\n \n body[").concat(nM,"] {\n ").concat("--removed-body-scroll-bar-size",": ").concat(s,"px;\n }\n")},nD=function(){var e=parseInt(document.body.getAttribute(nM)||"0",10);return isFinite(e)?e:0},nN=function(){E.useEffect(function(){return document.body.setAttribute(nM,(nD()+1).toString()),function(){var e=nD()-1;e<=0?document.body.removeAttribute(nM):document.body.setAttribute(nM,e.toString())}},[])},nA=function(e){var t=e.noRelative,n=e.noImportant,i=e.gapMode,a=void 0===i?"margin":i;nN();var l=E.useMemo(function(){return nj(a)},[a]);return E.createElement(nT,{styles:nL(l,!t,a,n?"":"!important")})},nP=!1;if("u">typeof window)try{var nR=Object.defineProperty({},"passive",{get:function(){return nP=!0,!0}});window.addEventListener("test",nR,nR),window.removeEventListener("test",nR,nR)}catch(e){nP=!1}var n_=!!nP&&{passive:!1},nO=function(e,t){if(!(e instanceof Element))return!1;var n=window.getComputedStyle(e);return"hidden"!==n[t]&&(n.overflowY!==n.overflowX||"TEXTAREA"===e.tagName||"visible"!==n[t])},nF=function(e,t){var n=t.ownerDocument,i=t;do{if("u">typeof ShadowRoot&&i instanceof ShadowRoot&&(i=i.host),nz(e,i)){var a=nU(e,i);if(a[1]>a[2])return!0}i=i.parentNode}while(i&&i!==n.body)return!1},nz=function(e,t){return"v"===e?nO(t,"overflowY"):nO(t,"overflowX")},nU=function(e,t){return"v"===e?[t.scrollTop,t.scrollHeight,t.clientHeight]:[t.scrollLeft,t.scrollWidth,t.clientWidth]},nB=function(e,t,n,i,a){var l,r=(l=window.getComputedStyle(t).direction,"h"===e&&"rtl"===l?-1:1),s=r*i,o=n.target,c=t.contains(o),d=!1,h=s>0,u=0,p=0;do{if(!o)break;var m=nU(e,o),g=m[0],f=m[1]-m[2]-r*g;(g||f)&&nz(e,o)&&(u+=f,p+=g);var b=o.parentNode;o=b&&b.nodeType===Node.DOCUMENT_FRAGMENT_NODE?b.host:b}while(!c&&o!==document.body||c&&(t.contains(o)||t===o))return h&&(a&&1>Math.abs(u)||!a&&s>u)?d=!0:!h&&(a&&1>Math.abs(p)||!a&&-s>p)&&(d=!0),d},nW=function(e){return"changedTouches"in e?[e.changedTouches[0].clientX,e.changedTouches[0].clientY]:[0,0]},nH=function(e){return[e.deltaX,e.deltaY]},n$=function(e){return e&&"current"in e?e.current:e},nY=0,nV=[];let nG=(c=function(e){var t=E.useRef([]),n=E.useRef([0,0]),i=E.useRef(),a=E.useState(nY++)[0],l=E.useState(nS)[0],r=E.useRef(e);E.useEffect(function(){r.current=e},[e]),E.useEffect(function(){if(e.inert){document.body.classList.add("block-interactivity-".concat(a));var t=(function(e,t,n){if(n||2==arguments.length)for(var i,a=0,l=t.length;a<l;a++)!i&&a in t||(i||(i=Array.prototype.slice.call(t,0,a)),i[a]=t[a]);return e.concat(i||Array.prototype.slice.call(t))})([e.lockRef.current],(e.shards||[]).map(n$),!0).filter(Boolean);return t.forEach(function(e){return e.classList.add("allow-interactivity-".concat(a))}),function(){document.body.classList.remove("block-interactivity-".concat(a)),t.forEach(function(e){return e.classList.remove("allow-interactivity-".concat(a))})}}},[e.inert,e.lockRef.current,e.shards]);var s=E.useCallback(function(e,t){if("touches"in e&&2===e.touches.length||"wheel"===e.type&&e.ctrlKey)return!r.current.allowPinchZoom;var a,l=nW(e),s=n.current,o="deltaX"in e?e.deltaX:s[0]-l[0],c="deltaY"in e?e.deltaY:s[1]-l[1],d=e.target,h=Math.abs(o)>Math.abs(c)?"h":"v";if("touches"in e&&"h"===h&&"range"===d.type)return!1;var u=window.getSelection(),p=u&&u.anchorNode;if(p&&(p===d||p.contains(d)))return!1;var m=nF(h,d);if(!m)return!0;if(m?a=h:(a="v"===h?"h":"v",m=nF(h,d)),!m)return!1;if(!i.current&&"changedTouches"in e&&(o||c)&&(i.current=a),!a)return!0;var g=i.current||a;return nB(g,t,e,"h"===g?o:c,!0)},[]),o=E.useCallback(function(e){if(nV.length&&nV[nV.length-1]===l){var n="deltaY"in e?nH(e):nW(e),i=t.current.filter(function(t){var i;return t.name===e.type&&(t.target===e.target||e.target===t.shadowParent)&&(i=t.delta,i[0]===n[0]&&i[1]===n[1])})[0];if(i&&i.should){e.cancelable&&e.preventDefault();return}if(!i){var a=(r.current.shards||[]).map(n$).filter(Boolean).filter(function(t){return t.contains(e.target)});(a.length>0?s(e,a[0]):!r.current.noIsolation)&&e.cancelable&&e.preventDefault()}}},[]),c=E.useCallback(function(e,n,i,a){var l={name:e,delta:n,target:i,should:a,shadowParent:function(e){for(var t=null;null!==e;)e instanceof ShadowRoot&&(t=e.host,e=e.host),e=e.parentNode;return t}(i)};t.current.push(l),setTimeout(function(){t.current=t.current.filter(function(e){return e!==l})},1)},[]),d=E.useCallback(function(e){n.current=nW(e),i.current=void 0},[]),h=E.useCallback(function(t){c(t.type,nH(t),t.target,s(t,e.lockRef.current))},[]),u=E.useCallback(function(t){c(t.type,nW(t),t.target,s(t,e.lockRef.current))},[]);E.useEffect(function(){return nV.push(l),e.setCallbacks({onScrollCapture:h,onWheelCapture:h,onTouchMoveCapture:u}),document.addEventListener("wheel",o,n_),document.addEventListener("touchmove",o,n_),document.addEventListener("touchstart",d,n_),function(){nV=nV.filter(function(e){return e!==l}),document.removeEventListener("wheel",o,n_),document.removeEventListener("touchmove",o,n_),document.removeEventListener("touchstart",d,n_)}},[]);var p=e.removeScrollBar,m=e.inert;return E.createElement(E.Fragment,null,m?E.createElement(l,{styles:"\n .block-interactivity-".concat(a," {pointer-events: none;}\n .allow-interactivity-").concat(a," {pointer-events: all;}\n")}):null,p?E.createElement(nA,{noRelative:e.noRelative,gapMode:e.gapMode}):null)},nb.useMedium(c),nE);var nK=E.forwardRef(function(e,t){return E.createElement(ny,nd({},e,{ref:t,sideCar:nG}))});nK.classNames=ny.classNames;var nZ="Popover",[nX,nQ]=ep(nZ,[tK]),nq=tK(),[nJ,n0]=nX(nZ),n1=e=>{let{__scopePopover:t,children:n,open:i,defaultOpen:a,onOpenChange:l,modal:r=!1}=e,s=nq(t),o=E.useRef(null),[c,d]=E.useState(!1),[h=!1,u]=function({prop:e,defaultProp:t,onChange:n=()=>{}}){let[i,a]=function({defaultProp:e,onChange:t}){let n=E.useState(e),[i]=n,a=E.useRef(i),l=ey(t);return E.useEffect(()=>{a.current!==i&&(l(i),a.current=i)},[i,a,l]),n}({defaultProp:t,onChange:n}),l=void 0!==e,r=l?e:i,s=ey(n);return[r,E.useCallback(t=>{if(l){let n="function"==typeof t?t(e):t;n!==e&&s(n)}else a(t)},[l,e,a,s])]}({prop:i,defaultProp:a,onChange:l});return(0,W.jsx)(tQ,{...s,children:(0,W.jsx)(nJ,{scope:t,contentId:function(){let[e,t]=E.useState(eO());return e_(()=>{t(e=>e??String(eF++))},[void 0]),e?`radix-${e}`:""}(),triggerRef:o,open:h,onOpenChange:u,onOpenToggle:E.useCallback(()=>u(e=>!e),[u]),hasCustomAnchor:c,onCustomAnchorAdd:E.useCallback(()=>d(!0),[]),onCustomAnchorRemove:E.useCallback(()=>d(!1),[]),modal:r,children:n})})};n1.displayName=nZ;var n2="PopoverAnchor";E.forwardRef((e,t)=>{let{__scopePopover:n,...i}=e,a=n0(n2,n),l=nq(n),{onCustomAnchorAdd:r,onCustomAnchorRemove:s}=a;return E.useEffect(()=>(r(),()=>s()),[r,s]),(0,W.jsx)(tJ,{...l,...i,ref:t})}).displayName=n2;var n3="PopoverTrigger",n5=E.forwardRef((e,t)=>{let{__scopePopover:n,...i}=e,a=n0(n3,n),l=nq(n),r=eu(t,a.triggerRef),s=(0,W.jsx)(ev.button,{type:"button","aria-haspopup":"dialog","aria-expanded":a.open,"aria-controls":a.contentId,"data-state":is(a.open),...i,ref:r,onClick:ec(e.onClick,a.onOpenToggle)});return a.hasCustomAnchor?s:(0,W.jsx)(tJ,{asChild:!0,...l,children:s})});n5.displayName=n3;var n4="PopoverPortal",[n6,n8]=nX(n4,{forceMount:void 0}),n7=e=>{let{__scopePopover:t,forceMount:n,children:i,container:a}=e,l=n0(n4,t);return(0,W.jsx)(n6,{scope:t,forceMount:n,children:(0,W.jsx)(nt,{present:n||l.open,children:(0,W.jsx)(ne,{asChild:!0,container:a,children:i})})})};n7.displayName=n4;var n9="PopoverContent",ie=E.forwardRef((e,t)=>{let n=n8(n9,e.__scopePopover),{forceMount:i=n.forceMount,...a}=e,l=n0(n9,e.__scopePopover);return(0,W.jsx)(nt,{present:i||l.open,children:l.modal?(0,W.jsx)(it,{...a,ref:t}):(0,W.jsx)(ii,{...a,ref:t})})});ie.displayName=n9;var it=E.forwardRef((e,t)=>{let n=n0(n9,e.__scopePopover),i=E.useRef(null),a=eu(t,i),l=E.useRef(!1);return E.useEffect(()=>{let e=i.current;if(e)return nc(e)},[]),(0,W.jsx)(nK,{as:em,allowPinchZoom:!0,children:(0,W.jsx)(ia,{...e,ref:a,trapFocus:n.open,disableOutsidePointerEvents:!0,onCloseAutoFocus:ec(e.onCloseAutoFocus,e=>{e.preventDefault(),l.current||n.triggerRef.current?.focus()}),onPointerDownOutside:ec(e.onPointerDownOutside,e=>{let t=e.detail.originalEvent,n=0===t.button&&!0===t.ctrlKey;l.current=2===t.button||n},{checkForDefaultPrevented:!1}),onFocusOutside:ec(e.onFocusOutside,e=>e.preventDefault(),{checkForDefaultPrevented:!1})})})}),ii=E.forwardRef((e,t)=>{let n=n0(n9,e.__scopePopover),i=E.useRef(!1),a=E.useRef(!1);return(0,W.jsx)(ia,{...e,ref:t,trapFocus:!1,disableOutsidePointerEvents:!1,onCloseAutoFocus:t=>{e.onCloseAutoFocus?.(t),t.defaultPrevented||(i.current||n.triggerRef.current?.focus(),t.preventDefault()),i.current=!1,a.current=!1},onInteractOutside:t=>{e.onInteractOutside?.(t),t.defaultPrevented||(i.current=!0,"pointerdown"===t.detail.originalEvent.type&&(a.current=!0));let l=t.target;n.triggerRef.current?.contains(l)&&t.preventDefault(),"focusin"===t.detail.originalEvent.type&&a.current&&t.preventDefault()}})}),ia=E.forwardRef((e,t)=>{let{__scopePopover:n,trapFocus:i,onOpenAutoFocus:a,onCloseAutoFocus:l,disableOutsidePointerEvents:r,onEscapeKeyDown:s,onPointerDownOutside:o,onFocusOutside:c,onInteractOutside:d,...h}=e,u=n0(n9,n),p=nq(n);return E.useEffect(()=>{let e=document.querySelectorAll("[data-radix-focus-guard]");return document.body.insertAdjacentElement("afterbegin",e[0]??eI()),document.body.insertAdjacentElement("beforeend",e[1]??eI()),ek++,()=>{1===ek&&document.querySelectorAll("[data-radix-focus-guard]").forEach(e=>e.remove()),ek--}},[]),(0,W.jsx)(eL,{asChild:!0,loop:!0,trapped:i,onMountAutoFocus:a,onUnmountAutoFocus:l,children:(0,W.jsx)(ew,{asChild:!0,disableOutsidePointerEvents:r,onInteractOutside:d,onEscapeKeyDown:s,onPointerDownOutside:o,onFocusOutside:c,onDismiss:()=>u.onOpenChange(!1),children:(0,W.jsx)(t3,{"data-state":is(u.open),role:"dialog",id:u.contentId,...p,...h,ref:t,style:{...h.style,"--radix-popover-content-transform-origin":"var(--radix-popper-transform-origin)","--radix-popover-content-available-width":"var(--radix-popper-available-width)","--radix-popover-content-available-height":"var(--radix-popper-available-height)","--radix-popover-trigger-width":"var(--radix-popper-anchor-width)","--radix-popover-trigger-height":"var(--radix-popper-anchor-height)"}})})})}),il="PopoverClose";E.forwardRef((e,t)=>{let{__scopePopover:n,...i}=e,a=n0(il,n);return(0,W.jsx)(ev.button,{type:"button",...i,ref:t,onClick:ec(e.onClick,()=>a.onOpenChange(!1))})}).displayName=il;var ir=E.forwardRef((e,t)=>{let{__scopePopover:n,...i}=e,a=nq(n);return(0,W.jsx)(t6,{...a,...i,ref:t})});function is(e){return e?"open":"closed"}ir.displayName="PopoverArrow";var io=e.i(11660),ic=e.i(54479),id=e.i(22125);let ih={get url(){return`file://${e.P("node_modules/zustand/esm/vanilla.mjs")}`}},iu=e=>{let t,n=new Set,i=(e,i)=>{let a="function"==typeof e?e(t):e;if(!Object.is(a,t)){let e=t;t=(null!=i?i:"object"!=typeof a||null===a)?a:Object.assign({},t,a),n.forEach(n=>n(t,e))}},a=()=>t,l={setState:i,getState:a,getInitialState:()=>r,subscribe:e=>(n.add(e),()=>n.delete(e)),destroy:()=>{(ih.env?ih.env.MODE:void 0)!=="production"&&console.warn("[DEPRECATED] The `destroy` method will be unsupported in a future version. Instead use unsubscribe function returned by subscribe. Everything will be garbage-collected if store is garbage-collected."),n.clear()}},r=t=e(i,a,l);return l};var ip=e.i(30224);let im={get url(){return`file://${e.P("node_modules/zustand/esm/index.mjs")}`}},{useDebugValue:ig}=E.default,{useSyncExternalStoreWithSelector:ib}=ip.default,iv=!1,iy=e=>{(im.env?im.env.MODE:void 0)!=="production"&&"function"!=typeof e&&console.warn("[DEPRECATED] Passing a vanilla store will be unsupported in a future version. Instead use `import { useStore } from 'zustand'`.");let t="function"==typeof e?e?iu(e):iu:e,n=(e,n)=>(function(e,t=e=>e,n){(im.env?im.env.MODE:void 0)!=="production"&&n&&!iv&&(console.warn("[DEPRECATED] Use `createWithEqualityFn` instead of `create` or use `useStoreWithEqualityFn` instead of `useStore`. They can be imported from 'zustand/traditional'. https://github.com/pmndrs/zustand/discussions/1937"),iv=!0);let i=ib(e.subscribe,e.getState,e.getServerState||e.getInitialState,t,n);return ig(i),i})(t,e,n);return Object.assign(n,t),n},iE="u">typeof window&&(null!=(u=window.document)&&u.createElement||(null==(p=window.navigator)?void 0:p.product)==="ReactNative")?E.default.useLayoutEffect:E.default.useEffect;function ix(){let e,t=(e=e=>({current:[],version:0,set:e}))?iy(e):iy;return{In:({children:e})=>{let n=t(e=>e.set),i=t(e=>e.version);return iE(()=>{n(e=>({version:e.version+1}))},[]),iE(()=>(n(({current:t})=>({current:[...t,e]})),()=>n(({current:t})=>({current:t.filter(t=>t!==e)}))),[e,i]),null},Out:()=>{let e=t(e=>e.current);return E.default.createElement(E.default.Fragment,null,e)}}}function iw(){return(iw=Object.assign.bind()).apply(null,arguments)}function iS(e,t,{checkForDefaultPrevented:n=!0}={}){return function(i){if(null==e||e(i),!1===n||!i.defaultPrevented)return null==t?void 0:t(i)}}function iC(e,t=[]){let n=[],i=()=>{let t=n.map(e=>(0,E.createContext)(e));return function(n){let i=(null==n?void 0:n[e])||t;return(0,E.useMemo)(()=>({[`__scope${e}`]:{...n,[e]:i}}),[n,i])}};return i.scopeName=e,[function(t,i){let a=(0,E.createContext)(i),l=n.length;function r(t){let{scope:n,children:i,...r}=t,s=(null==n?void 0:n[e][l])||a,o=(0,E.useMemo)(()=>r,Object.values(r));return(0,E.createElement)(s.Provider,{value:o},i)}return n=[...n,i],r.displayName=t+"Provider",[r,function(n,r){let s=(null==r?void 0:r[e][l])||a,o=(0,E.useContext)(s);if(o)return o;if(void 0!==i)return i;throw Error(`\`${n}\` must be used within \`${t}\``)}]},function(...e){let t=e[0];if(1===e.length)return t;let n=()=>{let n=e.map(e=>({useScope:e(),scopeName:e.scopeName}));return function(e){let i=n.reduce((t,{useScope:n,scopeName:i})=>{let a=n(e)[`__scope${i}`];return{...t,...a}},{});return(0,E.useMemo)(()=>({[`__scope${t.scopeName}`]:i}),[i])}};return n.scopeName=t.scopeName,n}(i,...t)]}function ik(...e){return t=>e.forEach(e=>{"function"==typeof e?e(t):null!=e&&(e.current=t)})}function iI(...e){return(0,E.useCallback)(ik(...e),e)}let ij=(0,E.forwardRef)((e,t)=>{let{children:n,...i}=e,a=E.Children.toArray(n),l=a.find(iL);if(l){let e=l.props.children,n=a.map(t=>t!==l?t:E.Children.count(e)>1?E.Children.only(null):(0,E.isValidElement)(e)?e.props.children:null);return(0,E.createElement)(iT,iw({},i,{ref:t}),(0,E.isValidElement)(e)?(0,E.cloneElement)(e,void 0,n):null)}return(0,E.createElement)(iT,iw({},i,{ref:t}),n)});ij.displayName="Slot";let iT=(0,E.forwardRef)((e,t)=>{let{children:n,...i}=e;return(0,E.isValidElement)(n)?(0,E.cloneElement)(n,{...function(e,t){let n={...t};for(let i in t){let a=e[i],l=t[i];/^on[A-Z]/.test(i)?a&&l?n[i]=(...e)=>{l(...e),a(...e)}:a&&(n[i]=a):"style"===i?n[i]={...a,...l}:"className"===i&&(n[i]=[a,l].filter(Boolean).join(" "))}return{...e,...n}}(i,n.props),ref:ik(t,n.ref)}):E.Children.count(n)>1?E.Children.only(null):null});iT.displayName="SlotClone";let iM=({children:e})=>(0,E.createElement)(E.Fragment,null,e);function iL(e){return(0,E.isValidElement)(e)&&e.type===iM}let iD=(null==globalThis?void 0:globalThis.document)?E.useLayoutEffect:()=>{},iN=E["useId".toString()]||(()=>void 0),iA=0;function iP(e){let[t,n]=E.useState(iN());return iD(()=>{e||n(e=>null!=e?e:String(iA++))},[e]),e||(t?`radix-${t}`:"")}let iR=(0,E.forwardRef)((e,t)=>{let{children:n,...i}=e,a=E.Children.toArray(n),l=a.find(iF);if(l){let e=l.props.children,n=a.map(t=>t!==l?t:E.Children.count(e)>1?E.Children.only(null):(0,E.isValidElement)(e)?e.props.children:null);return(0,E.createElement)(i_,iw({},i,{ref:t}),(0,E.isValidElement)(e)?(0,E.cloneElement)(e,void 0,n):null)}return(0,E.createElement)(i_,iw({},i,{ref:t}),n)});iR.displayName="Slot";let i_=(0,E.forwardRef)((e,t)=>{let{children:n,...i}=e;return(0,E.isValidElement)(n)?(0,E.cloneElement)(n,{...function(e,t){let n={...t};for(let i in t){let a=e[i],l=t[i];/^on[A-Z]/.test(i)?a&&l?n[i]=(...e)=>{l(...e),a(...e)}:a&&(n[i]=a):"style"===i?n[i]={...a,...l}:"className"===i&&(n[i]=[a,l].filter(Boolean).join(" "))}return{...e,...n}}(i,n.props),ref:function(...e){return t=>e.forEach(e=>{"function"==typeof e?e(t):null!=e&&(e.current=t)})}(t,n.ref)}):E.Children.count(n)>1?E.Children.only(null):null});i_.displayName="SlotClone";let iO=({children:e})=>(0,E.createElement)(E.Fragment,null,e);function iF(e){return(0,E.isValidElement)(e)&&e.type===iO}let iz=["a","button","div","h2","h3","img","label","li","nav","ol","p","span","svg","ul"].reduce((e,t)=>{let n=(0,E.forwardRef)((e,n)=>{let{asChild:i,...a}=e,l=i?iR:t;return(0,E.useEffect)(()=>{window[Symbol.for("radix-ui")]=!0},[]),(0,E.createElement)(l,iw({},a,{ref:n}))});return n.displayName=`Primitive.${t}`,{...e,[t]:n}},{});function iU(e){let t=(0,E.useRef)(e);return(0,E.useEffect)(()=>{t.current=e}),(0,E.useMemo)(()=>(...e)=>{var n;return null==(n=t.current)?void 0:n.call(t,...e)},[])}function iB({prop:e,defaultProp:t,onChange:n=()=>{}}){let[i,a]=function({defaultProp:e,onChange:t}){let n=(0,E.useState)(e),[i]=n,a=(0,E.useRef)(i),l=iU(t);return(0,E.useEffect)(()=>{a.current!==i&&(l(i),a.current=i)},[i,a,l]),n}({defaultProp:t,onChange:n}),l=void 0!==e,r=l?e:i,s=iU(n);return[r,(0,E.useCallback)(t=>{if(l){let n="function"==typeof t?t(e):t;n!==e&&s(n)}else a(t)},[l,e,a,s])]}let iW=(0,E.createContext)(void 0);function iH(e){let t=(0,E.useContext)(iW);return e||t||"ltr"}let i$="rovingFocusGroup.onEntryFocus",iY={bubbles:!1,cancelable:!0},iV="RovingFocusGroup",[iG,iK,iZ]=function(e){let t=e+"CollectionProvider",[n,i]=iC(t),[a,l]=n(t,{collectionRef:{current:null},itemMap:new Map}),r=e+"CollectionSlot",s=E.default.forwardRef((e,t)=>{let{scope:n,children:i}=e,a=iI(t,l(r,n).collectionRef);return E.default.createElement(ij,{ref:a},i)}),o=e+"CollectionItemSlot",c="data-radix-collection-item";return[{Provider:e=>{let{scope:t,children:n}=e,i=E.default.useRef(null),l=E.default.useRef(new Map).current;return E.default.createElement(a,{scope:t,itemMap:l,collectionRef:i},n)},Slot:s,ItemSlot:E.default.forwardRef((e,t)=>{let{scope:n,children:i,...a}=e,r=E.default.useRef(null),s=iI(t,r),d=l(o,n);return E.default.useEffect(()=>(d.itemMap.set(r,{ref:r,...a}),()=>void d.itemMap.delete(r))),E.default.createElement(ij,{[c]:"",ref:s},i)})},function(t){let n=l(e+"CollectionConsumer",t);return E.default.useCallback(()=>{let e=n.collectionRef.current;if(!e)return[];let t=Array.from(e.querySelectorAll(`[${c}]`));return Array.from(n.itemMap.values()).sort((e,n)=>t.indexOf(e.ref.current)-t.indexOf(n.ref.current))},[n.collectionRef,n.itemMap])},i]}(iV),[iX,iQ]=iC(iV,[iZ]),[iq,iJ]=iX(iV),i0=(0,E.forwardRef)((e,t)=>(0,E.createElement)(iG.Provider,{scope:e.__scopeRovingFocusGroup},(0,E.createElement)(iG.Slot,{scope:e.__scopeRovingFocusGroup},(0,E.createElement)(i1,iw({},e,{ref:t}))))),i1=(0,E.forwardRef)((e,t)=>{let n,{__scopeRovingFocusGroup:i,orientation:a,loop:l=!1,dir:r,currentTabStopId:s,defaultCurrentTabStopId:o,onCurrentTabStopIdChange:c,onEntryFocus:d,...h}=e,u=(0,E.useRef)(null),p=iI(t,u),m=iH(r),[g=null,f]=iB({prop:s,defaultProp:o,onChange:c}),[b,v]=(0,E.useState)(!1),y=(n=(0,E.useRef)(d),(0,E.useEffect)(()=>{n.current=d}),(0,E.useMemo)(()=>(...e)=>{var t;return null==(t=n.current)?void 0:t.call(n,...e)},[])),x=iK(i),w=(0,E.useRef)(!1),[S,C]=(0,E.useState)(0);return(0,E.useEffect)(()=>{let e=u.current;if(e)return e.addEventListener(i$,y),()=>e.removeEventListener(i$,y)},[y]),(0,E.createElement)(iq,{scope:i,orientation:a,dir:m,loop:l,currentTabStopId:g,onItemFocus:(0,E.useCallback)(e=>f(e),[f]),onItemShiftTab:(0,E.useCallback)(()=>v(!0),[]),onFocusableItemAdd:(0,E.useCallback)(()=>C(e=>e+1),[]),onFocusableItemRemove:(0,E.useCallback)(()=>C(e=>e-1),[])},(0,E.createElement)(iz.div,iw({tabIndex:b||0===S?-1:0,"data-orientation":a},h,{ref:p,style:{outline:"none",...e.style},onMouseDown:iS(e.onMouseDown,()=>{w.current=!0}),onFocus:iS(e.onFocus,e=>{let t=!w.current;if(e.target===e.currentTarget&&t&&!b){let t=new CustomEvent(i$,iY);if(e.currentTarget.dispatchEvent(t),!t.defaultPrevented){let e=x().filter(e=>e.focusable);i5([e.find(e=>e.active),e.find(e=>e.id===g),...e].filter(Boolean).map(e=>e.ref.current))}}w.current=!1}),onBlur:iS(e.onBlur,()=>v(!1))})))}),i2=(0,E.forwardRef)((e,t)=>{let{__scopeRovingFocusGroup:n,focusable:i=!0,active:a=!1,tabStopId:l,...r}=e,s=iP(),o=l||s,c=iJ("RovingFocusGroupItem",n),d=c.currentTabStopId===o,h=iK(n),{onFocusableItemAdd:u,onFocusableItemRemove:p}=c;return(0,E.useEffect)(()=>{if(i)return u(),()=>p()},[i,u,p]),(0,E.createElement)(iG.ItemSlot,{scope:n,id:o,focusable:i,active:a},(0,E.createElement)(iz.span,iw({tabIndex:d?0:-1,"data-orientation":c.orientation},r,{ref:t,onMouseDown:iS(e.onMouseDown,e=>{i?c.onItemFocus(o):e.preventDefault()}),onFocus:iS(e.onFocus,()=>c.onItemFocus(o)),onKeyDown:iS(e.onKeyDown,e=>{if("Tab"===e.key&&e.shiftKey)return void c.onItemShiftTab();if(e.target!==e.currentTarget)return;let t=function(e,t,n){var i;let a=(i=e.key,"rtl"!==n?i:"ArrowLeft"===i?"ArrowRight":"ArrowRight"===i?"ArrowLeft":i);if(!("vertical"===t&&["ArrowLeft","ArrowRight"].includes(a))&&!("horizontal"===t&&["ArrowUp","ArrowDown"].includes(a)))return i3[a]}(e,c.orientation,c.dir);if(void 0!==t){e.preventDefault();let a=h().filter(e=>e.focusable).map(e=>e.ref.current);if("last"===t)a.reverse();else if("prev"===t||"next"===t){var n,i;"prev"===t&&a.reverse();let l=a.indexOf(e.currentTarget);a=c.loop?(n=a,i=l+1,n.map((e,t)=>n[(i+t)%n.length])):a.slice(l+1)}setTimeout(()=>i5(a))}})})))}),i3={ArrowLeft:"prev",ArrowUp:"prev",ArrowRight:"next",ArrowDown:"next",PageUp:"first",Home:"first",PageDown:"last",End:"last"};function i5(e){let t=document.activeElement;for(let n of e)if(n===t||(n.focus(),document.activeElement!==t))return}let i4=(null==globalThis?void 0:globalThis.document)?E.useLayoutEffect:()=>{},i6=e=>{let{present:t,children:n}=e,i=function(e){var t,n;let[i,a]=(0,E.useState)(),l=(0,E.useRef)({}),r=(0,E.useRef)(e),s=(0,E.useRef)("none"),[o,c]=(t=e?"mounted":"unmounted",n={mounted:{UNMOUNT:"unmounted",ANIMATION_OUT:"unmountSuspended"},unmountSuspended:{MOUNT:"mounted",ANIMATION_END:"unmounted"},unmounted:{MOUNT:"mounted"}},(0,E.useReducer)((e,t)=>{let i=n[e][t];return null!=i?i:e},t));return(0,E.useEffect)(()=>{let e=i8(l.current);s.current="mounted"===o?e:"none"},[o]),i4(()=>{let t=l.current,n=r.current;if(n!==e){let i=s.current,a=i8(t);e?c("MOUNT"):"none"===a||(null==t?void 0:t.display)==="none"?c("UNMOUNT"):n&&i!==a?c("ANIMATION_OUT"):c("UNMOUNT"),r.current=e}},[e,c]),i4(()=>{if(i){let e=e=>{let t=i8(l.current).includes(e.animationName);e.target===i&&t&&(0,er.flushSync)(()=>c("ANIMATION_END"))},t=e=>{e.target===i&&(s.current=i8(l.current))};return i.addEventListener("animationstart",t),i.addEventListener("animationcancel",e),i.addEventListener("animationend",e),()=>{i.removeEventListener("animationstart",t),i.removeEventListener("animationcancel",e),i.removeEventListener("animationend",e)}}c("ANIMATION_END")},[i,c]),{isPresent:["mounted","unmountSuspended"].includes(o),ref:(0,E.useCallback)(e=>{e&&(l.current=getComputedStyle(e)),a(e)},[])}}(t),a="function"==typeof n?n({present:i.isPresent}):E.Children.only(n),l=function(...e){return(0,E.useCallback)(function(...e){return t=>e.forEach(e=>{"function"==typeof e?e(t):null!=e&&(e.current=t)})}(...e),e)}(i.ref,a.ref);return"function"==typeof n||i.isPresent?(0,E.cloneElement)(a,{ref:l}):null};function i8(e){return(null==e?void 0:e.animationName)||"none"}i6.displayName="Presence";let i7="Tabs",[i9,ae]=iC(i7,[iQ]),at=iQ(),[an,ai]=i9(i7),aa=(0,E.forwardRef)((e,t)=>{let{__scopeTabs:n,value:i,onValueChange:a,defaultValue:l,orientation:r="horizontal",dir:s,activationMode:o="automatic",...c}=e,d=iH(s),[h,u]=iB({prop:i,onChange:a,defaultProp:l});return(0,E.createElement)(an,{scope:n,baseId:iP(),value:h,onValueChange:u,orientation:r,dir:d,activationMode:o},(0,E.createElement)(iz.div,iw({dir:d,"data-orientation":r},c,{ref:t})))}),al=(0,E.forwardRef)((e,t)=>{let{__scopeTabs:n,loop:i=!0,...a}=e,l=ai("TabsList",n),r=at(n);return(0,E.createElement)(i0,iw({asChild:!0},r,{orientation:l.orientation,dir:l.dir,loop:i}),(0,E.createElement)(iz.div,iw({role:"tablist","aria-orientation":l.orientation},a,{ref:t})))}),ar=(0,E.forwardRef)((e,t)=>{let{__scopeTabs:n,value:i,disabled:a=!1,...l}=e,r=ai("TabsTrigger",n),s=at(n),o=ao(r.baseId,i),c=ac(r.baseId,i),d=i===r.value;return(0,E.createElement)(i2,iw({asChild:!0},s,{focusable:!a,active:d}),(0,E.createElement)(iz.button,iw({type:"button",role:"tab","aria-selected":d,"aria-controls":c,"data-state":d?"active":"inactive","data-disabled":a?"":void 0,disabled:a,id:o},l,{ref:t,onMouseDown:iS(e.onMouseDown,e=>{a||0!==e.button||!1!==e.ctrlKey?e.preventDefault():r.onValueChange(i)}),onKeyDown:iS(e.onKeyDown,e=>{[" ","Enter"].includes(e.key)&&r.onValueChange(i)}),onFocus:iS(e.onFocus,()=>{let e="manual"!==r.activationMode;d||a||!e||r.onValueChange(i)})})))}),as=(0,E.forwardRef)((e,t)=>{let{__scopeTabs:n,value:i,forceMount:a,children:l,...r}=e,s=ai("TabsContent",n),o=ao(s.baseId,i),c=ac(s.baseId,i),d=i===s.value,h=(0,E.useRef)(d);return(0,E.useEffect)(()=>{let e=requestAnimationFrame(()=>h.current=!1);return()=>cancelAnimationFrame(e)},[]),(0,E.createElement)(i6,{present:a||d},({present:n})=>(0,E.createElement)(iz.div,iw({"data-state":d?"active":"inactive","data-orientation":s.orientation,role:"tabpanel","aria-labelledby":o,hidden:!n,id:c,tabIndex:0},r,{ref:t,style:{...e.style,animationDuration:h.current?"0s":void 0}}),n&&l))});function ao(e,t){return`${e}-trigger-${t}`}function ac(e,t){return`${e}-content-${t}`}var ad=e.i(78333);function ah([e,t,n],[i,a,l]){return[e+i,t+a,n+l]}function au([e,t,n],[i,a,l]){return[e-i,t-a,n-l]}function ap([e,t,n],i){return[e*i,t*i,n*i]}function am([e,t,n]){return[e/Math.sqrt(e**2+t**2),t/Math.sqrt(e**2+t**2),n]}function ag([e,t,n],i){return[Math.cos(i)*e-Math.sin(i)*t,Math.sin(i)*e+Math.cos(i)*t,n]}function af(e,t,n){return Math.atan2(n[1]-e[1],n[0]-e[0])-Math.atan2(t[1]-e[1],t[0]-e[0])}function ab(e){return Math.atan2(Math.sin(e),Math.cos(e))}function av([e,t]){return Math.sqrt(e**2+t**2)}function ay([e,t],[n,i]){return Math.sqrt((n-e)**2+(i-t)**2)}function aE(e,t){if(0===t||e.length<=2)return e;let n=e[0],i=e[e.length-1],[a,l]=e.reduce(([e,t],a,l)=>{let r=function(e,t,n){let i=ay(t,n);if(0===i)return ay(e,t);let a=Math.max(0,Math.min(1,((e[0]-t[0])*(n[0]-t[0])+(e[1]-t[1])*(n[1]-t[1]))/i**2));return ay([t[0]+a*(n[0]-t[0]),t[1]+a*(n[1]-t[1]),e[2]],e)}(a,n,i);return r>e?[r,l]:[e,t]},[0,-1]);if(!(a>=t))return[n,i];{let a=e[l];return[...aE([n,...e.slice(1,l),a],t).slice(0,-1),a,...aE([a,...e.slice(l,-1),i],t).slice(1)]}}Object.defineProperty({},"LaserPointer",{get:()=>ax,set:void 0,enumerable:!0,configurable:!0});class ax{static{this.defaults={size:2,streamline:.45,simplify:.1,simplifyPhase:"output",keepHead:!1,sizeMapping:()=>1}}static{this.constants={cornerDetectionMaxAngle:75,cornerDetectionVariance:e=>e>35?.5:1,maxTailLength:50}}constructor(e){this.originalPoints=[],this.stablePoints=[],this.tailPoints=[],this.isFresh=!0,this.options=Object.assign({},ax.defaults,e)}get lastPoint(){return this.tailPoints[this.tailPoints.length-1]??this.stablePoints[this.stablePoints.length-1]}addPoint(e){let t=this.originalPoints[this.originalPoints.length-1];if(!t||t[0]!==e[0]||t[1]!==e[1]){var n,i,a;if(this.originalPoints.push(e),this.isFresh){this.isFresh=!1,this.stablePoints.push(e);return}this.options.streamline>0&&(n=this.lastPoint,i=e,a=1-this.options.streamline,e=ah(n,ap(au(i,n),a))),this.tailPoints.push(e),function(e){if(e.length<2)return 0;let t=0;for(let n=1;n<=e.length-1;n++)t+=ay(e[n-1],e[n]);return t+ay(e[e.length-2],e[e.length-1])}(this.tailPoints)>ax.constants.maxTailLength&&this.stabilizeTail()}}close(){this.stabilizeTail()}stabilizeTail(){if(this.options.simplify>0&&"tail"==this.options.simplifyPhase)throw Error("Not implemented yet");this.stablePoints.push(...this.tailPoints),this.tailPoints=[]}getSize(e,t,n,i,a){return(e??this.options.size)*this.options.sizeMapping({pressure:t,runningLength:a,currentIndex:n,totalLength:i})}getStrokeOutline(e){if(this.isFresh)return[];let t=[...this.stablePoints,...this.tailPoints];this.options.simplify>0&&"input"===this.options.simplifyPhase&&(t=aE(t,this.options.simplify));let n=t.length;if(0===n)return[];if(1===n){let i=t[0],a=this.getSize(e,i[2],0,n,0);if(a<.5)return[];let l=[];for(let e=0;e<=2*Math.PI;e+=Math.PI/16)l.push(ah(i,ap(ag([1,0,0],e),a)));return l.push(ah(i,ap([1,0,0],this.getSize(e,i[2],0,n,0)))),l}if(2===n){let i=t[0],a=t[1],l=this.getSize(e,i[2],0,n,0),r=this.getSize(e,a[2],0,n,0);if(l<.5||r<.5)return[];let s=[],o=af(i,[i[0],i[1]-100,i[2]],a);for(let e=o;e<=Math.PI+o;e+=Math.PI/16)s.push(ah(i,ap(ag([1,0,0],e),l)));for(let e=Math.PI+o;e<=2*Math.PI+o;e+=Math.PI/16)s.push(ah(a,ap(ag([1,0,0],e),r)));return s.push(s[0]),s}let i=[],a=[],l=0,r=0,s=0,o=0;for(let c=1;c<n-1;c++){let d=t[c-1],h=t[c],u=t[c+1],p=h[2],m=ay(d,h);o+=m,l=r+(m-r)*.2;let g=this.getSize(e,p,c,n,o);if(0===g){s=c+1;continue}let f=am(au(d,h)),b=am(au(u,h)),v=ag(f,Math.PI/2),y=ag(f,-Math.PI/2),E=ag(b,Math.PI/2),x=ag(b,-Math.PI/2),w=ah(h,ap(v,g)),S=ah(h,ap(y,g)),C=ah(h,ap(E,g)),k=ah(h,ap(x,g)),I=ah(v,x),j=ah(y,E),T=ah(h,ap(0===av(I)?f:am(I),g)),M=ah(h,ap(0===av(j)?b:am(j),g)),L=ab(af(h,d,u));if(Math.abs(L)<ax.constants.cornerDetectionMaxAngle/180*Math.PI*ax.constants.cornerDetectionVariance(l)){let e=Math.abs(ab(Math.PI-L));if(0===e)continue;if(L<0){a.push(S,M);for(let t=0;t<=e;t+=e/4)i.push(ah(h,ag(ap(v,g),t)));for(let t=e;t>=0;t-=e/4)a.push(ah(h,ag(ap(v,g),t)));a.push(M,C)}else{i.push(w,T);for(let t=0;t<=e;t+=e/4)a.push(ah(h,ag(ap(v,-g),-t)));for(let t=e;t>=0;t-=e/4)i.push(ah(h,ag(ap(v,-g),-t)));i.push(T,k)}}else i.push(T),a.push(M);r=l}if(s>=n-2)if(!this.options.keepHead)return[];else{let e=t[n-1],i=[];for(let t=0;t<=2*Math.PI;t+=Math.PI/16)i.push(ah(e,ap(ag([1,0,0],t),this.options.size)));return i.push(ah(e,ap([1,0,0],this.options.size))),i}let c=t[s],d=t[s+1],h=t[n-2],u=t[n-1],p=am(au(d,c)),m=am(au(h,u)),g=ag(p,-Math.PI/2),f=ag(m,Math.PI/2),b=this.getSize(e,c[2],0,n,0),v=[],y=this.options.keepHead?this.options.size:this.getSize(e,h[2],n-2,n,o),E=[];if(b>1){for(let e=0;e<=Math.PI;e+=Math.PI/16)v.unshift(ah(c,ag(ap(g,b),-e)));v.unshift(ah(c,ap(g,-b)))}else v.push(c);for(let e=0;e<=3*Math.PI;e+=Math.PI/16)E.push(ah(u,ag(ap(f,-y),-e)));let x=[...v,...i,...E.reverse(),...a.reverse()];return(v.length>0&&x.push(v[0]),this.options.simplify>0&&"output"===this.options.simplifyPhase)?aE(x,this.options.simplify):x}}var aw=en(),{useAtom:aS,useSetAtom:aC,useAtomValue:ak,useStore:aI}=aw,aj=aw.Provider,aT=B(),aM=(0,y.b)({"./locales/ar-SA.json":()=>e.A(99868),"./locales/az-AZ.json":()=>e.A(37828),"./locales/bg-BG.json":()=>e.A(59250),"./locales/bn-BD.json":()=>e.A(42875),"./locales/ca-ES.json":()=>e.A(69688),"./locales/cs-CZ.json":()=>e.A(74062),"./locales/da-DK.json":()=>e.A(90084),"./locales/de-DE.json":()=>e.A(55035),"./locales/el-GR.json":()=>e.A(22655),"./locales/en.json":()=>e.A(84108),"./locales/es-ES.json":()=>e.A(42483),"./locales/eu-ES.json":()=>e.A(52686),"./locales/fa-IR.json":()=>e.A(82293),"./locales/fi-FI.json":()=>e.A(46686),"./locales/fr-FR.json":()=>e.A(72687),"./locales/gl-ES.json":()=>e.A(8852),"./locales/he-IL.json":()=>e.A(880),"./locales/hi-IN.json":()=>e.A(72129),"./locales/hu-HU.json":()=>e.A(40050),"./locales/id-ID.json":()=>e.A(19355),"./locales/it-IT.json":()=>e.A(37719),"./locales/ja-JP.json":()=>e.A(8229),"./locales/kaa.json":()=>e.A(58490),"./locales/kab-KAB.json":()=>e.A(59320),"./locales/kk-KZ.json":()=>e.A(41356),"./locales/km-KH.json":()=>e.A(38202),"./locales/ko-KR.json":()=>e.A(22648),"./locales/ku-TR.json":()=>e.A(64187),"./locales/lt-LT.json":()=>e.A(45143),"./locales/lv-LV.json":()=>e.A(73406),"./locales/mr-IN.json":()=>e.A(12002),"./locales/my-MM.json":()=>e.A(34615),"./locales/nb-NO.json":()=>e.A(54282),"./locales/nl-NL.json":()=>e.A(31474),"./locales/nn-NO.json":()=>e.A(71945),"./locales/oc-FR.json":()=>e.A(29178),"./locales/pa-IN.json":()=>e.A(66177),"./locales/percentages.json":()=>e.A(55582),"./locales/pl-PL.json":()=>e.A(38776),"./locales/pt-BR.json":()=>e.A(14015),"./locales/pt-PT.json":()=>e.A(36995),"./locales/ro-RO.json":()=>e.A(40145),"./locales/ru-RU.json":()=>e.A(9747),"./locales/si-LK.json":()=>e.A(4187),"./locales/sk-SK.json":()=>e.A(73855),"./locales/sl-SI.json":()=>e.A(12926),"./locales/sv-SE.json":()=>e.A(17928),"./locales/ta-IN.json":()=>e.A(75245),"./locales/th-TH.json":()=>e.A(46432),"./locales/tr-TR.json":()=>e.A(35061),"./locales/uk-UA.json":()=>e.A(60411),"./locales/vi-VN.json":()=>e.A(75992),"./locales/zh-CN.json":()=>e.A(68072),"./locales/zh-HK.json":()=>e.A(37721),"./locales/zh-TW.json":()=>e.A(75005)}),aL={code:"en",label:"English"},aD=[aL,...[{code:"ar-SA",label:"العربية",rtl:!0},{code:"bg-BG",label:"Български"},{code:"ca-ES",label:"Català"},{code:"cs-CZ",label:"Česky"},{code:"de-DE",label:"Deutsch"},{code:"el-GR",label:"Ελληνικά"},{code:"es-ES",label:"Español"},{code:"eu-ES",label:"Euskara"},{code:"fa-IR",label:"فارسی",rtl:!0},{code:"fi-FI",label:"Suomi"},{code:"fr-FR",label:"Français"},{code:"gl-ES",label:"Galego"},{code:"he-IL",label:"עברית",rtl:!0},{code:"hi-IN",label:"हिन्दी"},{code:"hu-HU",label:"Magyar"},{code:"id-ID",label:"Bahasa Indonesia"},{code:"it-IT",label:"Italiano"},{code:"ja-JP",label:"日本語"},{code:"kab-KAB",label:"Taqbaylit"},{code:"kk-KZ",label:"Қазақ тілі"},{code:"ko-KR",label:"한국어"},{code:"ku-TR",label:"Kurdî"},{code:"lt-LT",label:"Lietuvių"},{code:"lv-LV",label:"Latviešu"},{code:"my-MM",label:"Burmese"},{code:"nb-NO",label:"Norsk bokmål"},{code:"nl-NL",label:"Nederlands"},{code:"nn-NO",label:"Norsk nynorsk"},{code:"oc-FR",label:"Occitan"},{code:"pa-IN",label:"ਪੰਜਾਬੀ"},{code:"pl-PL",label:"Polski"},{code:"pt-BR",label:"Português Brasileiro"},{code:"pt-PT",label:"Português"},{code:"ro-RO",label:"Română"},{code:"ru-RU",label:"Русский"},{code:"sk-SK",label:"Slovenčina"},{code:"sv-SE",label:"Svenska"},{code:"sl-SI",label:"Slovenščina"},{code:"tr-TR",label:"Türkçe"},{code:"uk-UA",label:"Українська"},{code:"zh-CN",label:"简体中文"},{code:"zh-TW",label:"繁體中文"},{code:"vi-VN",label:"Tiếng Việt"},{code:"mr-IN",label:"मराठी"}].filter(e=>v.c[e.code]>=85).sort((e,t)=>e.label>t.label?1:-1)],aN="__test__";f.a.DEV&&aD.unshift({code:aN,label:"test language"},{code:`${aN}.rtl`,label:"test language (rtl)",rtl:!0});var aA=aL,aP={},aR=async e=>{if(aA=e,document.documentElement.dir=aA.rtl?"rtl":"ltr",document.documentElement.lang=aA.code,e.code.startsWith(aN))aP={};else try{aP=await aM(`./locales/${aA.code}.json`)}catch(t){console.error(`Failed to load language ${e.code}:`,t.message),aP=b.J}aT.set(aF,e.code)},a_=(e,t)=>{for(let n=0;n<t.length;++n){let i=t[n];if(void 0===e[i])return;e=e[i]}if("string"==typeof e)return e},aO=(e,t,n)=>{if(aA.code.startsWith(aN))return`\u202A[[${t?`${e}(${JSON.stringify(t).slice(1,-1)})`:e}]]\u202C`;let i=e.split("."),a=a_(aP,i)||a_(b.J,i)||n;if(void 0===a){let t=`Can't find translation for ${e}`;if(f.a.PROD)return console.warn(t),"";throw Error(t)}if(t)for(let e in t)a=a.replace(`{{${e}}}`,String(t[e]));return a},aF=S(aL.code),az=()=>({t:aO,langCode:ak(aF)}),aU=({size:e="1em",circleWidth:t=8,synchronized:n=!1,className:i=""})=>{let a=-(E.default.useRef(Date.now()).current%1600);return(0,W.jsx)("div",{className:`Spinner ${i}`,children:(0,W.jsx)("svg",{viewBox:"0 0 100 100",style:{width:e,height:e,"--spinner-delay":n?`${a}ms`:0},children:(0,W.jsx)("circle",{cx:"50",cy:"50",r:50-t/2,strokeWidth:t,fill:"none",strokeMiterlimit:"10"})})})},aB=({delay:e,theme:t})=>{let[n,i]=(0,E.useState)(!!e);return(0,E.useEffect)(()=>{if(!e)return;let t=setTimeout(()=>{i(!1)},e);return()=>clearTimeout(t)},[e]),n?null:(0,W.jsxs)("div",{className:(0,el.default)("LoadingMessage",{"LoadingMessage--dark":t===m.G.DARK}),children:[(0,W.jsx)("div",{children:(0,W.jsx)(aU,{})}),(0,W.jsx)("div",{className:"LoadingMessage-text",children:aO("labels.loadingScene")})]})},aW=e=>{let[t,n]=(0,E.useState)(!0);return(0,E.useEffect)(()=>{let t=async()=>{await aR(i),n(!1)},i=aD.find(t=>t.code===e.langCode)||aL;t()},[e.langCode]),t?(0,W.jsx)(aB,{theme:e.theme}):e.children},aH=E.default.forwardRef(({size:e="medium",visible:t=!0,className:n="",...i},a)=>{let{id:l}=hX(),r=E.default.useRef(null);E.default.useImperativeHandle(a,()=>r.current);let s=`ToolIcon_size_${e}`,[o,c]=(0,E.useState)(!1),d=(0,E.useRef)(!0),h=async e=>{let t="onClick"in i&&i.onClick?.(e);if((0,m.Fb)(t))try{c(!0),await t}catch(e){if(e instanceof m.tc)console.warn(e);else throw e}finally{d.current&&c(!1)}};(0,E.useEffect)(()=>(d.current=!0,()=>{d.current=!1}),[]);let u=(0,E.useRef)(null);if("button"===i.type||"icon"===i.type||"submit"===i.type){let e="icon"===i.type?"button":i.type;return(0,W.jsxs)("button",{className:(0,el.default)("ToolIcon_type_button",s,n,t&&!i.hidden?"ToolIcon_type_button--show":"ToolIcon_type_button--hide",{ToolIcon:!i.hidden,"ToolIcon--selected":i.selected,"ToolIcon--plain":"icon"===i.type}),style:i.style,"data-testid":i["data-testid"],hidden:i.hidden,title:i.title,"aria-label":i["aria-label"],type:e,onClick:h,ref:r,disabled:o||i.isLoading||!!i.disabled,children:[(i.icon||i.label)&&(0,W.jsxs)("div",{className:"ToolIcon__icon","aria-hidden":"true","aria-disabled":!!i.disabled,children:[i.icon||i.label,i.keyBindingLabel&&(0,W.jsx)("span",{className:"ToolIcon__keybinding",children:i.keyBindingLabel}),i.isLoading&&(0,W.jsx)(aU,{})]}),i.showAriaLabel&&(0,W.jsxs)("div",{className:"ToolIcon__label",children:[i["aria-label"]," ",o&&(0,W.jsx)(aU,{})]}),i.children]})}return(0,W.jsxs)("label",{className:(0,el.default)("ToolIcon",n),title:i.title,onPointerDown:e=>{u.current=e.pointerType||null,i.onPointerDown?.({pointerType:e.pointerType||null})},onPointerUp:()=>{requestAnimationFrame(()=>{u.current=null})},children:[(0,W.jsx)("input",{className:`ToolIcon_type_radio ${s}`,type:"radio",name:i.name,"aria-label":i["aria-label"],"aria-keyshortcuts":i["aria-keyshortcuts"],"data-testid":i["data-testid"],id:`${l}-${i.id}`,onChange:()=>{i.onChange?.({pointerType:u.current})},checked:i.checked,ref:r}),(0,W.jsxs)("div",{className:"ToolIcon__icon",children:[i.icon,i.keyBindingLabel&&(0,W.jsx)("span",{className:"ToolIcon__keybinding",children:i.keyBindingLabel})]})]})});aH.displayName="ToolButton";var a$=(e,t)=>{if(e.editingGroupId){let n=(0,m.Qc)((0,m.pk)(t),e.editingGroupId);if(n.length)return{...e,selectedElementIds:{[n[0].id]:!0}}}return e},aY=(0,m.$c)({name:"deleteSelectedElements",label:"labels.delete",icon:m.ud,trackEvent:{category:"element",action:"delete"},perform:(e,t,n,i)=>{if(t.editingLinearElement){let{elementId:n,selectedPointsIndices:a,startBindingElement:l,endBindingElement:r}=t.editingLinearElement,s=i.scene.getNonDeletedElementsMap(),o=m.pj.getElement(n,s);if(!o||null==a)return!1;if(o.points.length<2){let n=e.map(e=>e.id===o.id?(0,m.Qj)(e,{isDeleted:!0}):e),i=a$(t,n);return{elements:n,appState:{...i,editingLinearElement:null},captureUpdate:m.Wg.IMMEDIATELY}}let c={startBindingElement:a?.includes(0)?null:l,endBindingElement:a?.includes(o.points.length-1)?null:r};return m.pj.deletePoints(o,a),{elements:e,appState:{...t,editingLinearElement:{...t.editingLinearElement,...c,selectedPointsIndices:a?.[0]>0?[a[0]-1]:[0]}},captureUpdate:m.Wg.IMMEDIATELY}}let{elements:a,appState:l}=((e,t,n)=>{let i=new Set((0,m.vk)(e.filter(e=>(0,m.bc)(e)),t).map(e=>e.id)),a={},l=n.scene.getNonDeletedElementsMap(),r=new Set;for(let t of i)for(let n of(0,m.Bi)(e,t))if(!r.has(n.id)){if((0,m.nc)(n)){let e=(0,m.Aj)(n,l);e&&(a[e.id]=!0)}else a[n.id]=!0;r.add(n.id)}let s=!0,o=e.map(e=>{if(t.selectedElementIds[e.id]){let t=(0,m.nc)(e)?(0,m.Aj)(e,l):null;return e.frameId&&i.has(e.frameId)?(s=!1,a[e.id]=!0,e):t?.frameId&&i.has(t?.frameId)?e:(e.boundElements&&e.boundElements.forEach(t=>{let i=n.scene.getNonDeletedElementsMap().get(t.id);i&&(0,m.ec)(i)&&((0,m.Pj)(i,{startBinding:e.id===i.startBinding?.elementId?null:i.startBinding,endBinding:e.id===i.endBinding?.elementId?null:i.endBinding}),(0,m.Pj)(i,{points:i.points}))}),(0,m.Qj)(e,{isDeleted:!0}))}return e.frameId&&i.has(e.frameId)?(s=!1,(0,m.nc)(e)||(a[e.id]=!0),(0,m.Qj)(e,{frameId:null})):(0,m.nc)(e)&&t.selectedElementIds[e.containerId]?(0,m.Qj)(e,{isDeleted:!0}):e}),c=t.editingGroupId;if(s&&t.editingGroupId){let e=(0,m.Qc)(o,t.editingGroupId).filter(e=>!e.isDeleted);if(e.length>1)e[0]&&(a[e[0].id]=!0);else{c=null,e[0]&&(a[e[0].id]=!0);let n=e[0];if(n){let e=n.groupIds.findIndex(e=>e===t.editingGroupId),i=n.groupIds[e+1];if(i){let e=(0,m.Qc)(o,i).filter(e=>!e.isDeleted);e.length>1&&(c=i,e.forEach(e=>{a[e.id]=!0}))}}}}return{elements:o,appState:{...t,...(0,m.Jc)({selectedElementIds:a,editingGroupId:c},o,t,null)}}})(e,t,i);return(0,m.Tg)(a,a.filter(e=>e.isDeleted)),l=a$(l,a),{elements:a,appState:{...l,activeTool:(0,m.jb)(t,{type:"selection"}),multiElement:null,activeEmbeddable:null},captureUpdate:(0,m.tk)((0,m.pk)(e),t)?m.Wg.IMMEDIATELY:m.Wg.EVENTUALLY}},keyTest:(e,t,n)=>(e.key===m.hg.BACKSPACE||e.key===m.hg.DELETE)&&!e[m.hg.CTRL_OR_CMD],PanelComponent:({elements:e,appState:t,updateData:n})=>(0,W.jsx)(aH,{type:"button",icon:m.ud,title:aO("labels.delete"),"aria-label":aO("labels.delete"),onClick:()=>n(null),visible:(0,m.tk)((0,m.pk)(e),t)})}),aV=(e,t)=>e.frameId===t||e.id===t,aG=(e,t,n)=>{let i=[],a=[],l=null,r=-1,s=(0,m.xb)(n||(0,m.vk)(e,t,{includeBoundTextElement:!0,includeElementsInFrames:!0}));for(;++r<e.length;){let t=e[r];s.get(t.id)?(a.length&&(i=i.concat(a),a=[]),i.push(r),l=r+1):t.isDeleted&&l===r?(l=r+1,a.push(r)):a=[]}return i},aK=(e,t,n)=>{if("containerId"in e&&e.containerId){let i=m.Oj.getScene(e).getElement(e.containerId);if(i)return"left"===n?Math.min(t.indexOf(i),t.indexOf(e)):Math.max(t.indexOf(i),t.indexOf(e))}else{let i=e.boundElements?.find(e=>"arrow"!==e.type)?.id;if(i){let a=m.Oj.getScene(e).getElement(i);if(a)return"left"===n?Math.min(t.indexOf(a),t.indexOf(e)):Math.max(t.indexOf(a),t.indexOf(e))}}},aZ=(e,t)=>t.reduce((t,n)=>{let i=e[n];return t.set(i.id,i),t},new Map),aX=(e,t,n)=>{let i,a=aG(e,t),l=aZ(e,a),r=(i=0,a.reduce((e,t,n)=>(n>0&&a[n-1]!==t-1&&(i=++i),(e[i]||(e[i]=[])).push(t),e),[]));"right"===n&&(r=r.reverse());let s=new Set(a.filter(t=>(0,m.bc)(e[t])).map(t=>e[t].id));return r.forEach((i,a)=>{let l=i[0],r=i[i.length-1],o="left"===n?l:r,c=i.some(t=>{let n=e[t];return n.frameId&&s.has(n.frameId)})?null:e[o]?.frameId,d=((e,t,n,i,a)=>{let l=t[n],r=t=>!t.isDeleted&&(a?t.frameId===a:!e.editingGroupId||t.groupIds.includes(e.editingGroupId)),s="left"===i?(0,m.rb)(t,e=>r(e),Math.max(0,n-1)):(0,m.qb)(t,e=>r(e),n+1),o=t[s];if(!o)return -1;if(e.editingGroupId){if(l?.groupIds.join("")===o?.groupIds.join(""))return aK(o,t,i)??s;if(!o?.groupIds.includes(e.editingGroupId))return -1}if(!a&&(o.frameId||(0,m.bc)(o))){var c;let e,n,a=(c=o.frameId||o.id,e=-1,n=-1,t.forEach((t,i)=>{aV(t,c)&&(-1===e&&(e=i),n=i)}),-1===e?[]:t.slice(e,n+1));return"left"===i?t.indexOf(a[0]):t.indexOf(a[a.length-1])}if(!o.groupIds.length)return aK(o,t,i)??s;let d=e.editingGroupId?o.groupIds[o.groupIds.indexOf(e.editingGroupId)-1]:o.groupIds[o.groupIds.length-1],h=(0,m.Qc)(t,d);return h.length?"left"===i?t.indexOf(h[0]):t.indexOf(h[h.length-1]):s})(t,e,o,n,c);if(-1===d||o===d)return;let h="left"===n?e.slice(0,d):e.slice(0,l),u=e.slice(l,r+1),p="left"===n?e.slice(d,l):e.slice(r+1,d+1),g="left"===n?e.slice(r+1):e.slice(d+1);e="left"===n?[...h,...u,...p,...g]:[...h,...p,...u,...g]}),(0,m.Mj)(e,l),e},aQ=(e,t,n,i,a)=>{let l=aG(e,t,a),r=aZ(e,l),s=[],o,c;if("left"===n){if(i)o=(0,m.qb)(e,e=>aV(e,i));else if(t.editingGroupId){let n=(0,m.Qc)(e,t.editingGroupId);if(!n.length)return e;o=e.indexOf(n[0])}else o=0;c=l[l.length-1]}else{if(i)c=(0,m.rb)(e,e=>aV(e,i));else if(t.editingGroupId){let n=(0,m.Qc)(e,t.editingGroupId);if(!n.length)return e;c=e.indexOf(n[n.length-1])}else c=e.length-1;o=l[0]}-1===o&&(o=0);for(let t=o;t<c+1;t++)l.includes(t)||s.push(e[t]);let d=Array.from(r.values()),h=e.slice(0,o),u=e.slice(c+1),p="left"===n?[...h,...d,...s,...u]:[...h,...s,...d,...u];return(0,m.Mj)(p,r),p};function aq(e,t,n,i){let a=(0,m.xb)((0,m.vk)(e,t,{includeBoundTextElement:!0,includeElementsInFrames:!0})),l={regularElements:[],frameChildren:new Map},r=new Set;for(let t of e)a.has(t.id)&&(0,m.bc)(t)&&r.add(t.id);for(let t of e)if(a.has(t.id))if((0,m.bc)(t)||t.frameId&&r.has(t.frameId))l.regularElements.push(t);else if(t.frameId){let e=l.frameChildren.get(t.frameId)||[];e.push(t),l.frameChildren.set(t.frameId,e)}else l.regularElements.push(t);let s=e;for(let[a,r]of Array.from(l.frameChildren.entries()))s=i(e,t,n,a,r);return i(s,t,n,null,l.regularElements)}var aJ=(0,m.$c)({name:"sendBackward",label:"labels.sendBackward",keywords:["move down","zindex","layer"],icon:m.Wd,trackEvent:{category:"element"},perform:(e,t)=>({elements:aX(e,t,"left"),appState:t,captureUpdate:m.Wg.IMMEDIATELY}),keyPriority:40,keyTest:e=>e[m.hg.CTRL_OR_CMD]&&!e.shiftKey&&e.code===m.gg.BRACKET_LEFT,PanelComponent:({updateData:e,appState:t})=>(0,W.jsx)("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${aO("labels.sendBackward")} \u2014 ${(0,m.kb)("CtrlOrCmd+[")}`,children:m.Wd})}),a0=(0,m.$c)({name:"bringForward",label:"labels.bringForward",keywords:["move up","zindex","layer"],icon:m.Vd,trackEvent:{category:"element"},perform:(e,t)=>({elements:aX(e,t,"right"),appState:t,captureUpdate:m.Wg.IMMEDIATELY}),keyPriority:40,keyTest:e=>e[m.hg.CTRL_OR_CMD]&&!e.shiftKey&&e.code===m.gg.BRACKET_RIGHT,PanelComponent:({updateData:e,appState:t})=>(0,W.jsx)("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${aO("labels.bringForward")} \u2014 ${(0,m.kb)("CtrlOrCmd+]")}`,children:m.Vd})}),a1=(0,m.$c)({name:"sendToBack",label:"labels.sendToBack",keywords:["move down","zindex","layer"],icon:m.Yd,trackEvent:{category:"element"},perform:(e,t)=>({elements:aq(e,t,"left",aQ),appState:t,captureUpdate:m.Wg.IMMEDIATELY}),keyTest:e=>m.l?e[m.hg.CTRL_OR_CMD]&&e.altKey&&e.code===m.gg.BRACKET_LEFT:e[m.hg.CTRL_OR_CMD]&&e.shiftKey&&e.code===m.gg.BRACKET_LEFT,PanelComponent:({updateData:e,appState:t})=>(0,W.jsx)("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${aO("labels.sendToBack")} \u2014 ${m.l?(0,m.kb)("CtrlOrCmd+Alt+["):(0,m.kb)("CtrlOrCmd+Shift+[")}`,children:m.Yd})}),a2=(0,m.$c)({name:"bringToFront",label:"labels.bringToFront",keywords:["move up","zindex","layer"],icon:m.Xd,trackEvent:{category:"element"},perform:(e,t)=>({elements:aq(e,t,"right",aQ),appState:t,captureUpdate:m.Wg.IMMEDIATELY}),keyTest:e=>m.l?e[m.hg.CTRL_OR_CMD]&&e.altKey&&e.code===m.gg.BRACKET_RIGHT:e[m.hg.CTRL_OR_CMD]&&e.shiftKey&&e.code===m.gg.BRACKET_RIGHT,PanelComponent:({updateData:e,appState:t})=>(0,W.jsx)("button",{type:"button",className:"zIndexButton",onClick:t=>e(null),title:`${aO("labels.bringToFront")} \u2014 ${m.l?(0,m.kb)("CtrlOrCmd+Alt+]"):(0,m.kb)("CtrlOrCmd+Shift+]")}`,children:m.Xd})}),a3=(0,m.$c)({name:"selectAll",label:"labels.selectAll",icon:m.uf,trackEvent:{category:"canvas"},viewMode:!1,perform:(e,t,n,i)=>{if(t.editingLinearElement)return!1;let a=e.filter(e=>!e.isDeleted&&!((0,m._b)(e)&&e.containerId)&&!e.locked).reduce((e,t)=>(e[t.id]=!0,e),{});return{appState:{...t,...(0,m.Jc)({editingGroupId:null,selectedElementIds:a},(0,m.pk)(e),t,i),selectedLinearElement:1===Object.keys(a).length&&(0,m.cc)(e[0])?new m.pj(e[0]):null},captureUpdate:m.Wg.IMMEDIATELY}},keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.key===m.hg.A}),a5=(0,m.$c)({name:"duplicateSelection",label:"labels.duplicateSelection",icon:m.wd,trackEvent:{category:"element"},perform:(e,t,n,i)=>{if(t.editingLinearElement)try{let n=m.pj.duplicateSelectedPoints(t,i.scene.getNonDeletedElementsMap());return{elements:e,appState:n,captureUpdate:m.Wg.IMMEDIATELY}}catch{return!1}let a=a4(e,t);if(i.props.onDuplicate&&a.elements){let t=i.props.onDuplicate(a.elements,e);t&&(a.elements=t)}return{...a,captureUpdate:m.Wg.IMMEDIATELY}},keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.key===m.hg.D,PanelComponent:({elements:e,appState:t,updateData:n})=>(0,W.jsx)(aH,{type:"button",icon:m.wd,title:`${aO("labels.duplicateSelection")} \u2014 ${(0,m.kb)("CtrlOrCmd+D")}`,"aria-label":aO("labels.duplicateSelection"),onClick:()=>n(null),visible:(0,m.tk)((0,m.pk)(e),t)})}),a4=(e,t)=>{var n,i;let a,l,r,s,o,c,d,h=new Map,u=[],p=[],g=new Map,f=new Map,b=(0,m.xb)(e),v=e=>{let n=(0,m.Ub)(e).reduce((e,n)=>{if(E.has(n.id))return e;E.set(n.id,!0);let i=(0,m.cg)(t.editingGroupId,h,n,{x:n.x+m.R/2,y:n.y+m.R/2});return E.set(i.id,!0),f.set(i.id,i),g.set(n.id,i.id),p.push(n),u.push(i),e.push(i),e},[]);return Array.isArray(e)?n:n[0]||null};a=(n=e).slice(),l=new Set,r=e=>{let t=e[0]?.groupIds?.join(""),n=[e[0]],i=[];for(let a of e.slice(1))a.groupIds?.join("")===t?n.push(a):i.push(a);return i.length?[...n,...r(i)]:n},s=new Map,a.forEach((e,t)=>{if(!s.has(e.id))if(e.groupIds?.length){let n=e.groupIds[e.groupIds.length-1];for(let e of r(a.slice(t).filter(e=>{let t=e?.groupIds?.some(e=>e===n);return t&&s.set(e.id,!0),t})))l.add(e)}else l.add(e)}),i=l.size!==n.length?(console.error("normalizeGroupElementOrder: lost some elements... bailing!"),n):[...l],o=(0,m.yb)(i),c=i.slice(),d=new Set,c.forEach((e,t)=>{e&&(e.boundElements?.length?(d.add(e),c[t]=null,e.boundElements.forEach(e=>{let t=o.get(e.id);t&&"text"===e.type&&(d.add(t[0]),c[t[1]]=null)})):"text"===e.type&&e.containerId&&o.get(e.containerId)?.[0].boundElements?.find(t=>t.id===e.id)||(d.add(e),c[t]=null))}),e=d.size!==i.length?(console.error("normalizeBoundElementsOrder: lost some elements... bailing!"),i):[...d];let y=(0,m.xb)((0,m.vk)(e,t,{includeBoundTextElement:!0,includeElementsInFrames:!0})),E=new Map,x=e.slice(),w=(e,t)=>{(0,m.Kb)(-1!==e,"targetIndex === -1 "),(Array.isArray(t)||t)&&x.splice(e+1,0,...(0,m.Ub)(t))},S=new Set(e.filter(e=>y.has(e.id)&&(0,m.bc)(e)).map(e=>e.id));for(let n of e){if(E.has(n.id)||!y.has(n.id))continue;let i=(0,m.Lc)(t,n);if(i){let t=(0,m.Qc)(e,i).flatMap(t=>(0,m.bc)(t)?[...(0,m.Bi)(e,t.id),t]:[t]);w((0,m.rb)(x,e=>e.groupIds?.includes(i)),v(t));continue}if(!(n.frameId&&S.has(n.frameId))){if((0,m.bc)(n)){let t=n.id,i=(0,m.Bi)(e,t);w((0,m.rb)(x,e=>e.frameId===t||e.id===t),v([...i,n]));continue}if((0,m.mc)(n)){let e=(0,m.zj)(n,b);w((0,m.rb)(x,e=>e.id===n.id||"containerId"in e&&e.containerId===n.id),v(e?[n,e]:n));continue}if((0,m.nc)(n)){let e=(0,m.Aj)(n,b);w((0,m.rb)(x,t=>t.id===n.id||t.id===e?.id),v(e?[e,n]:n));continue}w((0,m.rb)(x,e=>e.id===n.id),v(n))}}(0,m.vj)(x,p,g),(0,m.Sg)(x,p,g),(0,m.wi)(x,p,g);let C=(0,m.rk)(u);return{elements:x,appState:{...t,...(0,m.Jc)({editingGroupId:t.editingGroupId,selectedElementIds:C.reduce((e,t)=>((0,m.nc)(t)||(e[t.id]=!0),e),{})},(0,m.pk)(x),t,null)}}},a6=new Set(["command_palette","export"]),a8=(e,t,n,i)=>{try{if(f.a.VITE_WORKER_ID||"true"!==f.a.VITE_APP_ENABLE_TRACKING||!a6.has(e)||f.a.DEV)return;f.a.PROD||console.info("trackEvent",{category:e,action:t,label:n,value:i}),window.sa_event&&window.sa_event(t,{category:e,label:n,value:i})}catch(e){console.error("error during analytics",e)}},a7=(0,E.forwardRef)((e,t)=>{let{title:n,className:i,testId:a,active:l,standalone:r,icon:s,onClick:o}=e;return(0,W.jsx)("button",{type:"button",ref:t,title:n,"data-testid":a,className:(0,el.default)(i,{standalone:r,active:l}),onClick:o,children:s},n)}),a9=e=>(0,W.jsx)("div",{className:"buttonList",children:e.options.map(t=>"button"===e.type?(0,W.jsx)(a7,{icon:t.icon,title:t.text,testId:t.testId,active:t.active??e.value===t.value,onClick:n=>e.onClick(t.value,n)},t.text):(0,W.jsxs)("label",{className:(0,el.default)({active:e.value===t.value}),title:t.text,children:[(0,W.jsx)("input",{type:"radio",name:e.group,onChange:()=>e.onChange(t.value),checked:e.value===t.value,"data-testid":t.testId}),t.icon]},t.text))}),le=({onChange:e,type:t,activeColor:n,topPicks:i})=>{let a;return"elementStroke"===t&&(a=m.f),"elementBackground"===t&&(a=m.g),"canvasBackground"===t&&(a=m.h),i&&(a=i),a?(0,W.jsx)("div",{className:"color-picker__top-picks",children:a.map(t=>(0,W.jsx)("button",{className:(0,el.default)("color-picker__button",{active:t===n,"is-transparent":"transparent"===t||!t}),style:{"--swatch-color":t},type:"button",title:t,onClick:()=>e(t),"data-testid":`color-top-pick-${t}`,children:(0,W.jsx)("div",{className:"color-picker__button-outline"})},t))}):(console.error("Invalid type for TopPicks"),null)},lt=()=>(0,W.jsx)("div",{style:{width:1,height:"1rem",backgroundColor:"var(--default-border-color)",margin:"0 auto"}}),ln=({palette:e,color:t})=>{for(let[n,i]of Object.entries(e))if(Array.isArray(i)){let e=i.indexOf(t);if(e>-1)return{colorName:n,shade:e}}else if(i===t)return{colorName:n,shade:null};return null},li=[["q","w","e","r","t"],["a","s","d","f","g"],["z","x","c","v","b"]].flat(),la=({color:e,palette:t})=>!Object.values(t).flat().includes(e),ll=S(null),lr=(e,t,n)=>(299*e+587*t+114*n)/1e3>=160?"black":"white",ls=({color:e,keyLabel:t,isCustomColor:n=!1,isShade:i=!1})=>(0,W.jsxs)("div",{className:"color-picker__button__hotkey-label",style:{color:((e,t)=>{if(t){let t=new Option().style;if(t.color=e,t.color){let e=t.color.replace(/^(rgb|rgba)\(/,"").replace(/\)$/,"").replace(/\s/g,"").split(",");return lr(parseInt(e[0]),parseInt(e[1]),parseInt(e[2]))}}return"transparent"===e?"black":lr(parseInt(e.substring(1,3),16),parseInt(e.substring(3,5),16),parseInt(e.substring(5,7),16))})(e,n)},children:[i&&"⇧",t]}),lo=({hex:e,onChange:t,palette:n})=>{let i=ln({color:e||"transparent",palette:n}),[a,l]=aS(ll),r=(0,E.useRef)(null);if((0,E.useEffect)(()=>{r.current&&"shades"===a&&r.current.focus()},[i,a]),i){let{colorName:e,shade:s}=i,o=n[e];if(Array.isArray(o))return(0,W.jsx)("div",{className:"color-picker-content--default shades",children:o.map((n,i)=>(0,W.jsxs)("button",{ref:i===s&&"shades"===a?r:void 0,tabIndex:-1,type:"button",className:(0,el.default)("color-picker__button color-picker__button--large",{active:i===s}),"aria-label":"Shade",title:`${e} - ${i+1}`,style:n?{"--swatch-color":n}:void 0,onClick:()=>{t(n),l("shades")},children:[(0,W.jsx)("div",{className:"color-picker__button-outline"}),(0,W.jsx)(ls,{color:n,keyLabel:i+1,isShade:!0})]},i))})}return(0,W.jsxs)("div",{className:"color-picker-content--default",style:{position:"relative"},tabIndex:-1,children:[(0,W.jsx)("button",{type:"button",tabIndex:-1,className:"color-picker__button color-picker__button--large color-picker__button--no-focus-visible"}),(0,W.jsx)("div",{tabIndex:-1,style:{position:"absolute",top:0,left:0,right:0,bottom:0,display:"flex",alignItems:"center",justifyContent:"center",textAlign:"center",fontSize:"0.75rem"},children:aO("colorPicker.noShades")})]})},lc=({palette:e,color:t,onChange:n,label:i,activeShade:a})=>{let l=ln({color:t||"transparent",palette:e}),[r,s]=aS(ll),o=(0,E.useRef)(null);return(0,E.useEffect)(()=>{o.current&&"baseColors"===r&&o.current.focus()},[l?.colorName,r]),(0,W.jsx)("div",{className:"color-picker-content--default",children:Object.entries(e).map(([e,t],i)=>{let r=(Array.isArray(t)?t[a]:t)||"transparent",c=li[i],d=aO(`colors.${e.replace(/\d+/,"")}`,null,"");return(0,W.jsxs)("button",{ref:l?.colorName===e?o:void 0,tabIndex:-1,type:"button",className:(0,el.default)("color-picker__button color-picker__button--large",{active:l?.colorName===e,"is-transparent":"transparent"===r||!r}),onClick:()=>{n(r),s("baseColors")},title:`${d}${r.startsWith("#")?` ${r}`:""} \u2014 ${c}`,"aria-label":`${d} \u2014 ${c}`,style:{"--swatch-color":r},"data-testid":`color-${e}`,children:[(0,W.jsx)("div",{className:"color-picker__button-outline"}),(0,W.jsx)(ls,{color:r,keyLabel:c})]},e)})})},ld=({colors:e,color:t,onChange:n,label:i})=>{let[a,l]=aS(ll),r=(0,E.useRef)(null);return(0,E.useEffect)(()=>{r.current&&r.current.focus()},[t,a]),(0,W.jsx)("div",{className:"color-picker-content--default",children:e.map((e,a)=>(0,W.jsxs)("button",{ref:t===e?r:void 0,tabIndex:-1,type:"button",className:(0,el.default)("color-picker__button color-picker__button--large",{active:t===e,"is-transparent":"transparent"===e||!e}),onClick:()=>{n(e),l("custom")},title:e,"aria-label":i,style:{"--swatch-color":e},children:[(0,W.jsx)("div",{className:"color-picker__button-outline"}),(0,W.jsx)(ls,{color:e,keyLabel:a+1,isCustomColor:!0})]},a))})},lh=(e,t,n)=>{let i=Math.ceil(n/m.b);switch(t=t??-1,e){case"ArrowLeft":{let e=t-1;return e<0?n-1:e}case"ArrowRight":return(t+1)%n;case"ArrowDown":{let e=t+m.b;return e>=n?t%m.b:e}case"ArrowUp":{let e=t-m.b,a=e<0?m.b*i+e:e;return a>=n?void 0:a}}},lu=({children:e})=>(0,W.jsx)("div",{className:"color-picker__heading",children:e}),lp=({color:e,onChange:t,label:n,type:i,elements:a,palette:l,updateData:r,children:s,onEyeDropperToggle:o,onEscape:c})=>{let[d]=E.default.useState(()=>{let e,t,n;return"canvasBackground"===i?[]:(e={elementBackground:"backgroundColor",elementStroke:"strokeColor"},t=a.filter(t=>!t.isDeleted&&la({color:t[e[i]],palette:l})),n=new Map,t.forEach(t=>{let a=t[e[i]];n.has(a)?n.set(a,n.get(a)+1):n.set(a,1)}),[...n.entries()].sort((e,t)=>t[1]-e[1]).map(e=>e[0]).slice(0,m.a))}),[h,u]=aS(ll),p=ln({color:e,palette:l});(0,E.useEffect)(()=>{if(!h){let t=la({color:e,palette:l});u(t&&!d.includes(e)?"hex":t?"custom":p?.shade!=null?"shades":"baseColors")}},[h,e,l,u,p,d]);let[g,f]=(0,E.useState)(p?.shade??("elementBackground"===i?m.d:m.c));(0,E.useEffect)(()=>{p?.shade!=null&&f(p.shade);let e=e=>{e.key===m.hg.ALT&&o(!1)};return document.addEventListener("keyup",e,{capture:!0}),()=>{document.removeEventListener("keyup",e,{capture:!0})}},[p,o]);let b=E.default.useRef(null);return(0,W.jsx)("div",{role:"dialog","aria-modal":"true","aria-label":aO("labels.colorPicker"),children:(0,W.jsxs)("div",{ref:b,onKeyDown:n=>{(({event:e,activeColorPickerSection:t,palette:n,color:i,onChange:a,customColors:l,setActiveColorPickerSection:r,updateData:s,activeShade:o,onEyeDropperToggle:c,onEscape:d})=>{if(e[m.hg.CTRL_OR_CMD])return!1;if(e.key===m.hg.ESCAPE)return d(e),!0;if(e.key===m.hg.ALT)return c(!0),!0;if(e.key===m.hg.I)return c(),!0;let h=ln({color:i,palette:n});if(e.key===m.hg.TAB){let s=Object.entries({custom:!!l.length,baseColors:!0,shades:h?.shade!=null,hex:!0}).reduce((e,[t,n])=>(n&&e.push(t),e),[]),o=s.indexOf(t),c=e.shiftKey?-1:1,d=o+c>s.length-1?0:o+c<0?s.length-1:o+c,u=s[d];return u&&r(u),"custom"===u?a(l[0]):"baseColors"===u&&(Object.entries(n).find(([e,t])=>Array.isArray(t)?t.includes(i):t===i?e:null)||a(m.e.black)),e.preventDefault(),e.stopPropagation(),!0}if((({e,colorObj:t,onChange:n,palette:i,customColors:a,setActiveColorPickerSection:l,activeShade:r})=>{if(t?.shade!=null&&["Digit1","Digit2","Digit3","Digit4","Digit5"].includes(e.code)&&e.shiftKey){let a=Number(e.code.slice(-1))-1;return n(i[t.colorName][a]),l("shades"),!0}if(["1","2","3","4","5"].includes(e.key)&&a[Number(e.key)-1])return n(a[Number(e.key)-1]),l("custom"),!0;if(li.includes(e.key)){let t=li.indexOf(e.key),a=Object.keys(i)[t],s=i[a];return n(Array.isArray(s)?s[r]:s),l("baseColors"),!0}return!1})({e,colorObj:h,onChange:a,palette:n,customColors:l,setActiveColorPickerSection:r,activeShade:o}))return!0;if("shades"===t&&h){let{shade:t}=h,i=lh(e.key,t,m.b);if(void 0!==i)return a(n[h.colorName][i]),!0}if("baseColors"===t&&h){let{colorName:t}=h,i=Object.keys(n),l=i.indexOf(t),r=lh(e.key,l,i.length);if(void 0!==r){let e=n[i[r]];return a(Array.isArray(e)?e[o]:e),!0}}if("custom"===t){let t=l.indexOf(i),n=lh(e.key,t,l.length);if(void 0!==n)return a(l[n]),!0}return!1})({event:n,activeColorPickerSection:h,palette:l,color:e,onChange:t,onEyeDropperToggle:o,customColors:d,setActiveColorPickerSection:u,updateData:r,activeShade:g,onEscape:c})&&(n.preventDefault(),n.stopPropagation())},className:"color-picker-content properties-content",tabIndex:-1,children:[!!d.length&&(0,W.jsxs)("div",{children:[(0,W.jsx)(lu,{children:aO("colorPicker.mostUsedCustomColors")}),(0,W.jsx)(ld,{colors:d,color:e,label:aO("colorPicker.mostUsedCustomColors"),onChange:t})]}),(0,W.jsxs)("div",{children:[(0,W.jsx)(lu,{children:aO("colorPicker.colors")}),(0,W.jsx)(lc,{color:e,label:n,palette:l,onChange:t,activeShade:g})]}),(0,W.jsxs)("div",{children:[(0,W.jsx)(lu,{children:aO("colorPicker.shades")}),(0,W.jsx)(lo,{hex:e,onChange:t,palette:l})]}),s]})})},lm=E.default.createContext(null),lg=e=>{let[t,n]=(0,E.useState)(null),i=hZ(),{theme:a}=E.default.useContext(lm),{container:l}=hX();return(0,E.useLayoutEffect)(()=>{t&&(t.className="",t.classList.add("excalidraw",...e?.className?.split(/\s+/)||[]),t.classList.toggle("excalidraw--mobile",i.editor.isMobile),t.classList.toggle("theme--dark",a===m.G.DARK))},[t,a,i.editor.isMobile,e?.className]),(0,E.useLayoutEffect)(()=>{let t=e?.parentSelector?l?.querySelector(e.parentSelector):document.body;if(!t)return;let i=document.createElement("div");return t.appendChild(i),n(i),()=>{t.removeChild(i)}},[l,e?.parentSelector]),t};function lf(e,t,n){(0,E.useEffect)(()=>{function i(i){if(!e.current)return;let a=n?.(i,e.current);if(!0!==a){if(!1===a)return t(i);e.current.contains(i.target)||!document.documentElement.contains(i.target)||i.target.closest("[data-radix-portal]")||i.target===document.documentElement&&"none"===document.body.style.pointerEvents||i.target.closest("[data-prevent-outside-click]")||t(i)}}return document.addEventListener("pointerdown",i),document.addEventListener("touchstart",i),()=>{document.removeEventListener("pointerdown",i),document.removeEventListener("touchstart",i)}},[e,t,n])}var lb=e=>{let t=(0,E.useRef)(e);return Object.assign(t.current,e),t.current},lv=S(null),ly=({onCancel:e,onChange:t,onSelect:n,colorPickerType:i})=>{let a=lg({className:"excalidraw-eye-dropper-backdrop",parentSelector:".excalidraw-eye-dropper-container"}),l=E.default.useContext(lm),r=hQ(),s=hG(),o=lb({app:s,onCancel:e,onChange:t,onSelect:n,selectedElements:(0,m.vk)(r,l)}),{container:c}=hX();(0,E.useEffect)(()=>{let e=d.current;if(!e||!s.canvas||!a)return;let t=!1,n=s.canvas.getContext("2d"),r=({clientX:e,clientY:t})=>{let i=n.getImageData((e-l.offsetLeft)*window.devicePixelRatio,(t-l.offsetTop)*window.devicePixelRatio,1,1).data;return(0,m.k)(i[0],i[1],i[2])},h=({clientX:n,clientY:a,altKey:l})=>{e.style.top=`${a+20}px`,e.style.left=`${n+20}px`;let s=r({clientX:n,clientY:a});t&&o.onChange(i,s,o.selectedElements,{altKey:l}),e.style.background=s},u=()=>{o.onCancel()},p=e=>{t=!0,e.stopImmediatePropagation()},g=e=>{var n;t=!1,c?.focus(),e.stopImmediatePropagation(),e.preventDefault(),n=r(e),o.onSelect(n,e)},f=e=>{e.key===m.hg.ESCAPE&&(e.preventDefault(),e.stopImmediatePropagation(),u())};return a.tabIndex=-1,a.focus(),h({clientX:o.app.lastViewportPosition.x,clientY:o.app.lastViewportPosition.y,altKey:!1}),a.addEventListener("keydown",f),a.addEventListener("pointerdown",p),a.addEventListener("pointerup",g),window.addEventListener("pointermove",h,{passive:!0}),window.addEventListener("blur",u),()=>{t=!1,a.removeEventListener("keydown",f),a.removeEventListener("pointerdown",p),a.removeEventListener("pointerup",g),window.removeEventListener("pointermove",h),window.removeEventListener("blur",u)}},[o,s.canvas,a,i,c,l.offsetLeft,l.offsetTop]);let d=(0,E.useRef)(null);return lf(d,()=>{e()},e=>!!e.target.closest(".excalidraw-eye-dropper-trigger, .excalidraw-eye-dropper-backdrop")),a?(0,er.createPortal)((0,W.jsx)("div",{ref:d,className:"excalidraw-eye-dropper-preview"}),a):null},lE=({color:e,onChange:t,label:n,colorPickerType:i})=>{let a=hZ(),[l,r]=(0,E.useState)(e),[s,o]=aS(ll);(0,E.useEffect)(()=>{r(e)},[e]);let c=(0,E.useCallback)(e=>{let n=e.toLowerCase(),i=lC(n);i&&t(i),r(n)},[t]),d=(0,E.useRef)(null),h=(0,E.useRef)(null);(0,E.useEffect)(()=>{d.current&&d.current.focus()},[s]);let[u,p]=aS(lv);return(0,E.useEffect)(()=>()=>{p(null)},[p]),(0,W.jsxs)("div",{className:"color-picker__input-label",children:[(0,W.jsx)("div",{className:"color-picker__input-hash",children:"#"}),(0,W.jsx)("input",{ref:"hex"===s?d:void 0,style:{border:0,padding:0},spellCheck:!1,className:"color-picker-input","aria-label":n,onChange:e=>{c(e.target.value)},value:(l||"").replace(/^#/,""),onBlur:()=>{r(e)},tabIndex:-1,onFocus:()=>o("hex"),onKeyDown:e=>{e.key!==m.hg.TAB&&(e.key===m.hg.ESCAPE&&h.current?.focus(),e.stopPropagation())}}),!a.editor.isMobile&&(0,W.jsxs)(W.Fragment,{children:[(0,W.jsx)("div",{style:{width:"1px",height:"1.25rem",backgroundColor:"var(--default-border-color)"}}),(0,W.jsx)("div",{ref:h,className:(0,el.default)("excalidraw-eye-dropper-trigger",{selected:u}),onClick:()=>p(e=>e?null:{keepOpenOnAlt:!1,onSelect:e=>t(e),colorPickerType:i}),title:`${aO("labels.eyeDropper")} \u2014 ${m.hg.I.toLocaleUpperCase()} or ${(0,m.kb)("Alt")} `,children:m.df})]})]})},lx=E.default.forwardRef(({children:e,padding:t,className:n,style:i},a)=>(0,W.jsx)("div",{className:(0,el.default)("Island",n),style:{"--padding":t,...i},ref:a,children:e})),lw=E.default.forwardRef(({className:e,container:t,children:n,style:i,onClose:a,onKeyDown:l,onFocusOutside:r,onPointerLeave:s,onPointerDownOutside:o},c)=>{let d=hZ();return(0,W.jsx)(n7,{container:t,children:(0,W.jsxs)(ie,{ref:c,className:(0,el.default)("focus-visible-none",e),"data-prevent-outside-click":!0,side:d.editor.isMobile&&!d.viewport.isLandscape?"bottom":"right",align:d.editor.isMobile&&!d.viewport.isLandscape?"center":"start",alignOffset:-16,sideOffset:20,style:{zIndex:"var(--zIndex-popup)"},onPointerLeave:s,onKeyDown:l,onFocusOutside:r,onPointerDownOutside:o,onCloseAutoFocus:e=>{e.stopPropagation(),e.preventDefault(),t&&!(0,m.$a)(document.activeElement)&&t.focus(),a()},children:[(0,W.jsx)(lx,{padding:3,style:i,children:n}),(0,W.jsx)(ir,{width:20,height:10,style:{fill:"var(--popup-bg-color)",filter:"drop-shadow(rgba(0, 0, 0, 0.05) 0px 3px 2px)"}})]})})}),lS=e=>{let t=new Option().style;return t.color=e,!!t.color},lC=e=>(0,m.sb)(e)?e:lS(`#${e}`)?`#${e}`:lS(e)?e:null,lk=({type:e,color:t,onChange:n,label:i,elements:a,palette:l=m.e,updateData:r})=>{let{container:s}=hX(),[,o]=aS(ll),[c,d]=aS(lv),h=(0,W.jsxs)("div",{children:[(0,W.jsx)(lu,{children:aO("colorPicker.hexCode")}),(0,W.jsx)(lE,{color:t,label:i,onChange:e=>{n(e)},colorPickerType:e})]}),u=(0,E.useRef)(null);return(0,W.jsx)(lw,{container:s,style:{maxWidth:"13rem"},onFocusOutside:e=>{u.current?.querySelector(".color-picker-content")?.focus(),e.preventDefault()},onPointerDownOutside:e=>{c&&e.preventDefault()},onClose:()=>{r({openPopup:null}),o(null)},children:l?(0,W.jsx)(lp,{palette:l,color:t,onChange:e=>{n(e)},onEyeDropperToggle:t=>{d(i=>t?((i=i||{keepOpenOnAlt:!0,onSelect:n,colorPickerType:e}).keepOpenOnAlt=!0,i):!1===t||i?null:{keepOpenOnAlt:!1,onSelect:n,colorPickerType:e})},onEscape:e=>{c?d(null):r({openPopup:null})},label:i,type:e,elements:a,updateData:r,children:h}):h})},lI=({label:e,color:t,type:n})=>(0,W.jsx)(n5,{type:"button",className:(0,el.default)("color-picker__button active-color properties-trigger",{"is-transparent":"transparent"===t||!t}),"aria-label":e,style:t?{"--swatch-color":t}:void 0,title:"elementStroke"===n?aO("labels.showStroke"):aO("labels.showBackground"),children:(0,W.jsx)("div",{className:"color-picker__button-outline"})}),lj=({type:e,color:t,onChange:n,label:i,elements:a,palette:l=m.e,topPicks:r,updateData:s,appState:o})=>(0,W.jsx)("div",{children:(0,W.jsxs)("div",{role:"dialog","aria-modal":"true",className:"color-picker-container",children:[(0,W.jsx)(le,{activeColor:t,onChange:n,type:e,topPicks:r}),(0,W.jsx)(lt,{}),(0,W.jsxs)(n1,{open:o.openPopup===e,onOpenChange:t=>{s({openPopup:t?e:null})},children:[(0,W.jsx)(lI,{color:t,label:i,type:e}),o.openPopup===e&&(0,W.jsx)(lk,{type:e,color:t,onChange:n,label:i,elements:a,palette:l,updateData:s})]})]})}),lT=({icon:e})=>(0,W.jsx)("span",{style:{width:"1em",margin:"0 0.5ex 0 0.5ex",display:"inline-block",lineHeight:0,verticalAlign:"middle"},children:e}),lM=({label:e,open:t,openTrigger:n,children:i,className:a})=>(0,W.jsxs)(W.Fragment,{children:[(0,W.jsxs)("div",{style:{cursor:"pointer",display:"flex",justifyContent:"space-between",alignItems:"center"},className:a,onClick:n,children:[e,(0,W.jsx)(lT,{icon:t?m.Mf:m.Lf})]}),t&&(0,W.jsx)("div",{style:{display:"flex",flexDirection:"column"},children:i})]}),lL=S(!1);function lD({options:e,value:t,label:n,onChange:i,onClose:a,numberOfOptionsToAlwaysShow:l=e.length}){let r=hZ(),[s,o]=aS(lL),c=E.default.useMemo(()=>e.slice(0,l),[e,l]),d=E.default.useMemo(()=>e.slice(l),[e,l]);(0,E.useEffect)(()=>{c.some(e=>e.value===t)||o(!0)},[t,c,o]);let h=e=>(0,W.jsx)("div",{className:"picker-content",children:e.map((e,n)=>(0,W.jsxs)("button",{type:"button",className:(0,el.default)("picker-option",{active:t===e.value}),onClick:t=>{i(e.value)},title:`${e.text} ${e.keyBinding&&`\u2014 ${e.keyBinding.toUpperCase()}`}`,"aria-label":e.text||"none","aria-keyshortcuts":e.keyBinding||void 0,ref:n=>{t===e.value&&setTimeout(()=>{n?.focus()},0)},children:[e.icon,e.keyBinding&&(0,W.jsx)("span",{className:"picker-keybinding",children:e.keyBinding})]},e.text))});return(0,W.jsx)(ie,{side:r.editor.isMobile&&!r.viewport.isLandscape?"top":"bottom",align:"start",sideOffset:12,style:{zIndex:"var(--zIndex-popup)"},onKeyDown:n=>{let r=e.find(e=>e.keyBinding===n.key.toLowerCase());if(!(n.metaKey||n.altKey||n.ctrlKey)&&r)i(r.value),n.preventDefault();else if(n.key===m.hg.TAB){let a=e.findIndex(e=>e.value===t),l=n.shiftKey?(e.length+a-1)%e.length:(a+1)%e.length;i(e[l].value)}else if((0,m.jg)(n.key)){let a=aA.rtl,r=e.findIndex(e=>e.value===t);if(-1!==r){let t=e.length,s=r;switch(n.key){case a?m.hg.ARROW_LEFT:m.hg.ARROW_RIGHT:s=(r+1)%t;break;case a?m.hg.ARROW_RIGHT:m.hg.ARROW_LEFT:s=(t+r-1)%t;break;case m.hg.ARROW_DOWN:s=(r+(l??1))%t;break;case m.hg.ARROW_UP:s=(t+r-(l??1))%t}i(e[s].value)}n.preventDefault()}else(n.key===m.hg.ESCAPE||n.key===m.hg.ENTER)&&(n.preventDefault(),a());n.nativeEvent.stopImmediatePropagation(),n.stopPropagation()},children:(0,W.jsxs)("div",{className:"picker",role:"dialog","aria-modal":"true","aria-label":n,children:[h(c),d.length>0&&(0,W.jsx)(lM,{label:aO("labels.more_options"),open:s,openTrigger:()=>{o(e=>!e)},className:"picker-collapsible",children:h(d)})]})})}function lN({value:e,label:t,options:n,onChange:i,group:a="",numberOfOptionsToAlwaysShow:l}){let[r,s]=E.default.useState(!1),o=E.default.useRef(null);return(0,W.jsx)("div",{children:(0,W.jsxs)(n1,{open:r,onOpenChange:e=>s(e),children:[(0,W.jsx)(n5,{name:a,type:"button","aria-label":t,onClick:()=>s(!r),ref:o,className:r?"active":"",children:n.find(t=>t.value===e)?.icon}),r&&(0,W.jsx)(lD,{options:n,value:e,label:t,onChange:i,onClose:()=>{s(!1)},numberOfOptionsToAlwaysShow:l})]})})}var lA=E.default.forwardRef(({className:e,placeholder:t,onChange:n},i)=>(0,W.jsxs)("div",{className:(0,el.default)("QuickSearch__wrapper",e),children:[m.pf,(0,W.jsx)("input",{ref:i,className:"QuickSearch__input",type:"text",placeholder:t,onChange:e=>n(e.target.value.trim().toLowerCase())})]})),lP=({className:e,placeholder:t,children:n})=>{let i=!E.Children.count(n);return(0,W.jsx)("div",{className:(0,el.default)("ScrollableList__wrapper",e),role:"menu",children:i?(0,W.jsx)("div",{className:"empty",children:t}):n})},lR=({children:e,className:t="",style:n,title:i})=>(0,W.jsxs)("div",{className:`dropdown-menu-group ${t}`,style:n,children:[i&&(0,W.jsx)("p",{className:"dropdown-menu-group-title",children:i}),e]});lR.displayName="DropdownMenuGroup";var l_=E.default.createContext({}),lO=(e="",t=!1,n=!1)=>`dropdown-menu-item dropdown-menu-item-base ${e}
|
|
1
|
+
(globalThis.TURBOPACK||(globalThis.TURBOPACK=[])).push(["object"==typeof document?document.currentScript:void 0,22125,(e,t,n)=>{var i;t.exports=i={},i.simpleFilter=function(e,t){return t.filter(function(t){return i.test(e,t)})},i.test=function(e,t){return null!==i.match(e,t)},i.match=function(e,t,n){n=n||{};var i,a=0,l=[],r=t.length,s=0,o=0,c=n.pre||"",d=n.post||"",h=n.caseSensitive&&t||t.toLowerCase();e=n.caseSensitive&&e||e.toLowerCase();for(var u=0;u<r;u++)i=t[u],h[u]===e[a]?(i=c+i+d,a+=1,o+=1+o):o=0,s+=o,l[l.length]=i;return a===e.length?(s=h===e?1/0:s,{rendered:l.join(""),score:s}):null},i.filter=function(e,t,n){return t&&0!==t.length?"string"!=typeof e?t:(n=n||{},t.reduce(function(t,a,l,r){var s=a;n.extract&&(s=n.extract(a));var o=i.match(e,s,n);return null!=o&&(t[t.length]={string:o.rendered,score:o.score,index:l,original:a}),t},[]).sort(function(e,t){var n=t.score-e.score;return n||e.index-t.index})):[]}},55838,(e,t,n)=>{"use strict";var i=e.r(71645),a="function"==typeof Object.is?Object.is:function(e,t){return e===t&&(0!==e||1/e==1/t)||e!=e&&t!=t},l=i.useState,r=i.useEffect,s=i.useLayoutEffect,o=i.useDebugValue;function c(e){var t=e.getSnapshot;e=e.value;try{var n=t();return!a(e,n)}catch(e){return!0}}var d="u"<typeof window||void 0===window.document||void 0===window.document.createElement?function(e,t){return t()}:function(e,t){var n=t(),i=l({inst:{value:n,getSnapshot:t}}),a=i[0].inst,d=i[1];return s(function(){a.value=n,a.getSnapshot=t,c(a)&&d({inst:a})},[e,n,t]),r(function(){return c(a)&&d({inst:a}),e(function(){c(a)&&d({inst:a})})},[e]),o(n),n};n.useSyncExternalStore=void 0!==i.useSyncExternalStore?i.useSyncExternalStore:d},2239,(e,t,n)=>{"use strict";t.exports=e.r(55838)},52822,(e,t,n)=>{"use strict";var i=e.r(71645),a=e.r(2239),l="function"==typeof Object.is?Object.is:function(e,t){return e===t&&(0!==e||1/e==1/t)||e!=e&&t!=t},r=a.useSyncExternalStore,s=i.useRef,o=i.useEffect,c=i.useMemo,d=i.useDebugValue;n.useSyncExternalStoreWithSelector=function(e,t,n,i,a){var h=s(null);if(null===h.current){var u={hasValue:!1,value:null};h.current=u}else u=h.current;var p=r(e,(h=c(function(){function e(e){if(!o){if(o=!0,r=e,e=i(e),void 0!==a&&u.hasValue){var t=u.value;if(a(t,e))return s=t}return s=e}if(t=s,l(r,e))return t;var n=i(e);return void 0!==a&&a(t,n)?(r=e,t):(r=e,s=n)}var r,s,o=!1,c=void 0===n?null:n;return[function(){return e(t())},null===c?void 0:function(){return e(c())}]},[t,n,i,a]))[0],h[1]);return o(function(){u.hasValue=!0,u.value=p},[p]),d(p),p}},30224,(e,t,n)=>{"use strict";t.exports=e.r(52822)},78333,(e,t,n)=>{var i=0/0,a=/^\s+|\s+$/g,l=/^[-+]0x[0-9a-f]+$/i,r=/^0b[01]+$/i,s=/^0o[0-7]+$/i,o=parseInt,c=e.g&&e.g.Object===Object&&e.g,d="object"==typeof self&&self&&self.Object===Object&&self,h=c||d||Function("return this")(),u=Object.prototype.toString,p=Math.max,m=Math.min,g=function(){return h.Date.now()};function f(e){var t=typeof e;return!!e&&("object"==t||"function"==t)}function b(e){if("number"==typeof e)return e;if("symbol"==typeof(t=e)||t&&"object"==typeof t&&"[object Symbol]"==u.call(t))return i;if(f(e)){var t,n="function"==typeof e.valueOf?e.valueOf():e;e=f(n)?n+"":n}if("string"!=typeof e)return 0===e?e:+e;e=e.replace(a,"");var c=r.test(e);return c||s.test(e)?o(e.slice(2),c?2:8):l.test(e)?i:+e}t.exports=function(e,t,n){var i,a,l,r,s,o,c=0,d=!1,h=!1,u=!0;if("function"!=typeof e)throw TypeError("Expected a function");function v(t){var n=i,l=a;return i=a=void 0,c=t,r=e.apply(l,n)}function y(e){var n=e-o,i=e-c;return void 0===o||n>=t||n<0||h&&i>=l}function E(){var e,n,i,a=g();if(y(a))return x(a);s=setTimeout(E,(e=a-o,n=a-c,i=t-e,h?m(i,l-n):i))}function x(e){return(s=void 0,u&&i)?v(e):(i=a=void 0,r)}function w(){var e,n=g(),l=y(n);if(i=arguments,a=this,o=n,l){if(void 0===s)return c=e=o,s=setTimeout(E,t),d?v(e):r;if(h)return s=setTimeout(E,t),v(o)}return void 0===s&&(s=setTimeout(E,t)),r}return t=b(t)||0,f(n)&&(d=!!n.leading,l=(h="maxWait"in n)?p(b(n.maxWait)||0,t):l,u="trailing"in n?!!n.trailing:u),w.cancel=function(){void 0!==s&&clearTimeout(s),c=0,i=o=a=s=void 0},w.flush=function(){return void 0===s?r:x(g())},w}},86869,e=>{"use strict";let t,n,i;var a,l,r,s,o,c,d,h,u,p,m=e.i(5948),g=e.i(55252),g=g,f=e.i(18094),b=e.i(30406),v=e.i(8908),y=e.i(11017),E=e.i(71645);let x={get url(){return`file://${e.P("node_modules/jotai/esm/vanilla.mjs")}`}},w=0;function S(e,t){let n=`atom${++w}`,i={toString(){return(x.env?x.env.MODE:void 0)!=="production"&&this.debugLabel?n+":"+this.debugLabel:n}};return"function"==typeof e?i.read=e:(i.init=e,i.read=C,i.write=k),t&&(i.write=t),i}function C(e){return e(this)}function k(e,t,n){return t(this,"function"==typeof n?n(e(this)):n)}let I=(e,t)=>e.unstable_is?e.unstable_is(t):t===e,j=e=>"init"in e,T=new WeakMap,M=e=>{var t;return L(e)&&!(null==(t=T.get(e))?void 0:t[1])},L=e=>"function"==typeof(null==e?void 0:e.then),D=e=>"v"in e||"e"in e,N=e=>{if("e"in e)throw e.e;if((x.env?x.env.MODE:void 0)!=="production"&&!("v"in e))throw Error("[Bug] atom state is not initialized");return e.v},A=(e,t,n)=>{n.p.has(e)||(n.p.add(e),t.then(()=>{n.p.delete(e)},()=>{n.p.delete(e)}))},P=(e,t,n,i,a)=>{var l;if((x.env?x.env.MODE:void 0)!=="production"&&i===t)throw Error("[Bug] atom cannot depend on itself");n.d.set(i,a.n),M(n.v)&&A(t,n.v,a),null==(l=a.m)||l.t.add(t),e&&F(e,i,t)},R=()=>({D:new Map,H:new Set,M:new Set,L:new Set}),_=(e,t,n)=>{e[t].add(n)},O=(e,t,n)=>{e.D.has(t)||(e.D.set(t,new Set),_(e,"M",()=>{var t;null==(t=n.m)||t.l.forEach(t=>_(e,"M",t))}))},F=(e,t,n)=>{let i=e.D.get(t);i&&i.add(n)},z=e=>{let t,n=!1,i=e=>{try{e()}catch(e){n||(t=e,n=!0)}};for(;e.H.size||e.M.size||e.L.size;)e.D.clear(),e.H.forEach(i),e.H.clear(),e.M.forEach(i),e.M.clear(),e.L.forEach(i),e.L.clear();if(n)throw t},U=(...[e,t,n,i])=>{let a=(t,n,i)=>{let a="v"in n,l=n.v,r=M(n.v)?n.v:null;if(L(i)){for(let a of((e=>{if(T.has(e))return;let t=[new Set,!1];T.set(e,t);let n=()=>{t[1]=!0};e.then(n,n),e.onCancel=e=>{t[0].add(e)}})(i),n.d.keys()))A(t,i,e(a));n.v=i}else n.v=i;delete n.e,delete n.x,a&&Object.is(l,n.v)||(++n.n,r&&((e,t)=>{let n=T.get(e);if(n)n[1]=!0,n[0].forEach(e=>e(t));else if((x.env?x.env.MODE:void 0)!=="production")throw Error("[Bug] cancelable promise not found")})(r,i))},l=(n,i)=>{var r;let s,d,h=e(i);if(D(h)&&(h.m&&!h.x||Array.from(h.d).every(([e,t])=>l(n,e).n===t)))return h;h.d.clear();let u=!0;try{let p=t(i,t=>{if(I(i,t)){let n=e(t);if(!D(n))if(j(t))a(t,n,t.init);else throw Error("no atom init");return N(n)}let r=l(n,t);try{return N(r)}finally{if(u)P(n,i,h,t,r);else{let e=R();P(e,i,h,t,r),c(e,i,h),z(e)}}},{get signal(){return s||(s=new AbortController),s.signal},get setSelf(){return(x.env?x.env.MODE:void 0)==="production"||i.write||console.warn("setSelf function cannot be used with read-only atom"),!d&&i.write&&(d=(...e)=>{if((x.env?x.env.MODE:void 0)!=="production"&&u&&console.warn("setSelf function cannot be called in sync"),!u)return o(i,...e)}),d}});if(a(i,h,p),L(p)){null==(r=p.onCancel)||r.call(p,()=>null==s?void 0:s.abort());let e=()=>{if(h.m){let e=R();c(e,i,h),z(e)}};p.then(e,e)}return h}catch(e){return delete h.v,h.e=e,delete h.x,++h.n,h}finally{u=!1}},r=(t,n,i)=>{var a,l;let r=new Map;for(let t of(null==(a=i.m)?void 0:a.t)||[]){let n=e(t);n.m&&r.set(t,n)}for(let t of i.p)r.set(t,e(t));return null==(l=t.D.get(n))||l.forEach(t=>{r.set(t,e(t))}),r},s=(t,i,...o)=>{let d=!0;try{return n(i,e=>N(l(t,e)),(n,...o)=>{let h=e(n);try{if(!I(i,n))return s(t,n,...o);{if(!j(n))throw Error("atom not writable");let e=h.n,i=o[0];a(n,h,i),c(t,n,h),e!==h.n&&(O(t,n,h),((e,t,n)=>{let i=[],a=new Set,s=new Set,o=[[t,n]];for(;o.length>0;){let[t,n]=o[o.length-1];if(s.has(t)){o.pop();continue}if(a.has(t)){i.push([t,n,n.n]),s.add(t),n.x=!0,o.pop();continue}for(let[i,l]of(a.add(t),r(e,t,n)))t===i||a.has(i)||o.push([i,l])}_(e,"H",()=>{let n=new Set([t]);for(let t=i.length-1;t>=0;--t){let[a,r,s]=i[t],o=!1;for(let e of r.d.keys())if(e!==a&&n.has(e)){o=!0;break}o&&(l(e,a),c(e,a,r),s!==r.n&&(O(e,a,r),n.add(a))),delete r.x}})})(t,n,h));return}}finally{d||z(t)}},...o)}finally{d=!1}},o=(e,...t)=>{let n=R();try{return s(n,e,...t)}finally{z(n)}},c=(t,n,i)=>{if(i.m&&!M(i.v)){for(let a of i.d.keys())i.m.d.has(a)||(d(t,a,e(a)).t.add(n),i.m.d.add(a));for(let a of i.m.d||[])if(!i.d.has(a)){i.m.d.delete(a);let l=h(t,a,e(a));null==l||l.t.delete(n)}}},d=(t,n,a)=>{if(!a.m){for(let i of(l(t,n),a.d.keys()))d(t,i,e(i)).t.add(n);if(a.m={l:new Set,d:new Set(a.d.keys()),t:new Set},n.write){let e,l=a.m,r=(t,i)=>{let a=!0;e=(...e)=>{try{return s(t,n,...e)}finally{a||z(t)}};try{return i()}finally{a=!1}};_(t,"L",()=>{let a=r(t,()=>i(n,(...t)=>e(...t)));a&&(l.u=e=>r(e,a))})}}return a.m},h=(t,n,i)=>{if(i.m&&!i.m.l.size&&!Array.from(i.m.t).some(t=>{var i;return null==(i=e(t).m)?void 0:i.d.has(n)})){let a=i.m.u;for(let l of(a&&_(t,"L",()=>a(t)),delete i.m,i.d.keys())){let i=h(t,l,e(l));null==i||i.t.delete(n)}return}return i.m};return{get:e=>N(l(void 0,e)),set:o,sub:(t,n)=>{let i=R(),a=e(t),l=d(i,t,a).l;return l.add(n),z(i),()=>{l.delete(n);let e=R();h(e,t,a),z(e)}},unstable_derive:a=>U(...a(e,t,n,i))}},B=()=>{let e=new WeakMap,t=U(t=>{if((x.env?x.env.MODE:void 0)!=="production"&&!t)throw Error("Atom is undefined or null");let n=e.get(t);return n||(n={d:new Map,p:new Set,n:0},e.set(t,n)),n},(e,...t)=>e.read(...t),(e,...t)=>e.write(...t),(e,...t)=>{var n;return null==(n=e.onMount)?void 0:n.call(e,...t)});if((x.env?x.env.MODE:void 0)!=="production"){let e,n,i,a,l,r;return n=new WeakMap,i=new Set,a=0,r=(l=t.unstable_derive((t,l,r,s)=>(e=t,[e=>{let a=n.get(e);return a||(a=new Proxy(t(e),{set:(t,n,a)=>("m"===n&&i.add(e),Reflect.set(t,n,a)),deleteProperty:(t,n)=>("m"===n&&i.delete(e),Reflect.deleteProperty(t,n))}),n.set(e,a)),a},l,(e,t,n,...i)=>a?n(e,...i):r(e,t,n,...i),s]))).set,Object.assign(l,{dev4_get_internal_weak_map:()=>({get:t=>{let n=e(t);if(0!==n.n)return n}}),dev4_get_mounted_atoms:()=>i,dev4_restore_atoms:e=>{r({read:()=>null,write:(t,n)=>{++a;try{for(let[t,i]of e)j(t)&&n(t,i)}finally{--a}}})}})}return t};e.i(47167);var W=e.i(43476);let H={get url(){return`file://${e.P("node_modules/jotai/esm/react.mjs")}`}},$=(0,E.createContext)(void 0),Y=e=>{let n=(0,E.useContext)($);return(null==e?void 0:e.store)||n||(t||(t=B(),(x.env?x.env.MODE:void 0)!=="production"&&(globalThis.__JOTAI_DEFAULT_STORE__||(globalThis.__JOTAI_DEFAULT_STORE__=t),globalThis.__JOTAI_DEFAULT_STORE__!==t&&console.warn("Detected multiple Jotai instances. It may cause unexpected behavior with the default store. https://github.com/pmndrs/jotai/discussions/2044"))),t)},V=e=>"function"==typeof(null==e?void 0:e.then),G=e=>{e.status="pending",e.then(t=>{e.status="fulfilled",e.value=t},t=>{e.status="rejected",e.reason=t})},K=E.default.use||(e=>{if("pending"===e.status)throw e;if("fulfilled"===e.status)return e.value;if("rejected"===e.status)throw e.reason;throw G(e),e}),Z=new WeakMap,X=e=>{let t=Z.get(e);return t||(t=new Promise((n,i)=>{let a=e,l=e=>t=>{a===e&&n(t)},r=e=>t=>{a===e&&i(t)},s=e=>{"onCancel"in e&&"function"==typeof e.onCancel&&e.onCancel(i=>{if((H.env?H.env.MODE:void 0)!=="production"&&i===e)throw Error("[Bug] p is not updated even after cancelation");V(i)?(Z.set(i,t),a=i,i.then(l(i),r(i)),s(i)):n(i)})};e.then(l(e),r(e)),s(e)}),Z.set(e,t)),t};function Q(e,t){let n=Y(t),[[i,a,l],r]=(0,E.useReducer)(t=>{let i=n.get(e);return Object.is(t[0],i)&&t[1]===n&&t[2]===e?t:[i,n,e]},void 0,()=>[n.get(e),n,e]),s=i;(a!==n||l!==e)&&(r(),s=n.get(e));let o=null==t?void 0:t.delay;return((0,E.useEffect)(()=>{let t=n.sub(e,()=>{if("number"==typeof o){let t=n.get(e);V(t)&&G(X(t)),setTimeout(r,o);return}r()});return r(),t},[n,e,o]),(0,E.useDebugValue)(s),V(s))?K(X(s)):s}function q(e,t){let n=Y(t);return(0,E.useCallback)((...t)=>{if((H.env?H.env.MODE:void 0)!=="production"&&!("write"in e))throw Error("not writable atom");return n.set(e,...t)},[n,e])}let J={get url(){return`file://${e.P("node_modules/jotai/esm/vanilla/utils.mjs")}`}};Symbol((J.env?J.env.MODE:void 0)!=="production"?"RESET":""),!function(e=()=>{try{return window.localStorage}catch(e){(J.env?J.env.MODE:void 0)!=="production"&&"u">typeof window&&console.warn(e);return}}){var t;let n,i;try{n=null==(t=e())?void 0:t.subscribe}catch(e){}!n&&"u">typeof window&&"function"==typeof window.addEventListener&&window.Storage&&(n=(t,n)=>{if(!(e()instanceof window.Storage))return()=>{};let i=i=>{i.storageArea===e()&&i.key===t&&n(i.newValue)};return window.addEventListener("storage",i),()=>{window.removeEventListener("storage",i)}}),n&&(i=n,(e,t,n)=>i(e,e=>{let i;try{i=JSON.parse(e||"")}catch(e){i=n}t(i)}))}();let ee=new WeakMap;function et(){return(et=Object.assign.bind()).apply(this,arguments)}function en(){let e=(0,E.createContext)(null),t=t=>{let n=(0,E.useContext)(e);if(!n)throw Error("Missing Provider from createIsolation");return Y(et({store:n},t))};return{Provider:function({store:t,initialValues:n=[],children:i}){let a,l=(0,E.useRef)(t);l.current||(l.current=B());var r,s={store:l.current};let o=Y(s),c=(r=o,(a=ee.get(r))||(a=new WeakSet,ee.set(r,a)),a);for(let[e,t]of n)(!c.has(e)||(null==s?void 0:s.dangerouslyForceHydrate))&&(c.add(e),o.set(e,t));return(0,W.jsx)(e.Provider,{value:l.current,children:i})},useStore:t,useAtom:(e,n)=>{var i;let a=t();return[Q(e,i=et({store:a},n)),q(e,i)]},useAtomValue:(e,n)=>{let i=t();return Q(e,et({store:i},n))},useSetAtom:(e,n)=>{let i=t();return q(e,et({store:i},n))}}}let{read:ei,write:ea}=S(null);(0,E.createContext)({scope:void 0,baseStore:void 0});var el=e.i(2305),er=e.i(74080),es=e.i(90294),eo=e.i(48077);function ec(e,t,{checkForDefaultPrevented:n=!0}={}){return function(i){if(e?.(i),!1===n||!i.defaultPrevented)return t?.(i)}}function ed(e,t){if("function"==typeof e)return e(t);null!=e&&(e.current=t)}function eh(...e){return t=>{let n=!1,i=e.map(e=>{let i=ed(e,t);return n||"function"!=typeof i||(n=!0),i});if(n)return()=>{for(let t=0;t<i.length;t++){let n=i[t];"function"==typeof n?n():ed(e[t],null)}}}}function eu(...e){return E.useCallback(eh(...e),e)}function ep(e,t=[]){let n=[],i=()=>{let t=n.map(e=>E.createContext(e));return function(n){let i=n?.[e]||t;return E.useMemo(()=>({[`__scope${e}`]:{...n,[e]:i}}),[n,i])}};return i.scopeName=e,[function(t,i){let a=E.createContext(i),l=n.length;n=[...n,i];let r=t=>{let{scope:n,children:i,...r}=t,s=n?.[e]?.[l]||a,o=E.useMemo(()=>r,Object.values(r));return(0,W.jsx)(s.Provider,{value:o,children:i})};return r.displayName=t+"Provider",[r,function(n,r){let s=r?.[e]?.[l]||a,o=E.useContext(s);if(o)return o;if(void 0!==i)return i;throw Error(`\`${n}\` must be used within \`${t}\``)}]},function(...e){let t=e[0];if(1===e.length)return t;let n=()=>{let n=e.map(e=>({useScope:e(),scopeName:e.scopeName}));return function(e){let i=n.reduce((t,{useScope:n,scopeName:i})=>{let a=n(e)[`__scope${i}`];return{...t,...a}},{});return E.useMemo(()=>({[`__scope${t.scopeName}`]:i}),[i])}};return n.scopeName=t.scopeName,n}(i,...t)]}var em=E.forwardRef((e,t)=>{let{children:n,...i}=e,a=E.Children.toArray(n),l=a.find(eb);if(l){let e=l.props.children,n=a.map(t=>t!==l?t:E.Children.count(e)>1?E.Children.only(null):E.isValidElement(e)?e.props.children:null);return(0,W.jsx)(eg,{...i,ref:t,children:E.isValidElement(e)?E.cloneElement(e,void 0,n):null})}return(0,W.jsx)(eg,{...i,ref:t,children:n})});em.displayName="Slot";var eg=E.forwardRef((e,t)=>{let{children:n,...i}=e;if(E.isValidElement(n)){var a;let e,l,r=(a=n,(l=(e=Object.getOwnPropertyDescriptor(a.props,"ref")?.get)&&"isReactWarning"in e&&e.isReactWarning)?a.ref:(l=(e=Object.getOwnPropertyDescriptor(a,"ref")?.get)&&"isReactWarning"in e&&e.isReactWarning)?a.props.ref:a.props.ref||a.ref),s=function(e,t){let n={...t};for(let i in t){let a=e[i],l=t[i];/^on[A-Z]/.test(i)?a&&l?n[i]=(...e)=>{l(...e),a(...e)}:a&&(n[i]=a):"style"===i?n[i]={...a,...l}:"className"===i&&(n[i]=[a,l].filter(Boolean).join(" "))}return{...e,...n}}(i,n.props);return n.type!==E.Fragment&&(s.ref=t?eh(t,r):r),E.cloneElement(n,s)}return E.Children.count(n)>1?E.Children.only(null):null});eg.displayName="SlotClone";var ef=({children:e})=>(0,W.jsx)(W.Fragment,{children:e});function eb(e){return E.isValidElement(e)&&e.type===ef}var ev=["a","button","div","form","h2","h3","img","input","label","li","nav","ol","p","span","svg","ul"].reduce((e,t)=>{let n=E.forwardRef((e,n)=>{let{asChild:i,...a}=e,l=i?em:t;return"u">typeof window&&(window[Symbol.for("radix-ui")]=!0),(0,W.jsx)(l,{...a,ref:n})});return n.displayName=`Primitive.${t}`,{...e,[t]:n}},{});function ey(e){let t=E.useRef(e);return E.useEffect(()=>{t.current=e}),E.useMemo(()=>(...e)=>t.current?.(...e),[])}var eE="dismissableLayer.update",ex=E.createContext({layers:new Set,layersWithOutsidePointerEventsDisabled:new Set,branches:new Set}),ew=E.forwardRef((e,t)=>{let{disableOutsidePointerEvents:n=!1,onEscapeKeyDown:i,onPointerDownOutside:a,onFocusOutside:l,onInteractOutside:r,onDismiss:s,...o}=e,c=E.useContext(ex),[h,u]=E.useState(null),p=h?.ownerDocument??globalThis?.document,[,m]=E.useState({}),g=eu(t,e=>u(e)),f=Array.from(c.layers),[b]=[...c.layersWithOutsidePointerEventsDisabled].slice(-1),v=f.indexOf(b),y=h?f.indexOf(h):-1,x=c.layersWithOutsidePointerEventsDisabled.size>0,w=y>=v,S=function(e,t=globalThis?.document){let n=ey(e),i=E.useRef(!1),a=E.useRef(()=>{});return E.useEffect(()=>{let e=e=>{if(e.target&&!i.current){let i=function(){eC("dismissableLayer.pointerDownOutside",n,l,{discrete:!0})},l={originalEvent:e};"touch"===e.pointerType?(t.removeEventListener("click",a.current),a.current=i,t.addEventListener("click",a.current,{once:!0})):i()}else t.removeEventListener("click",a.current);i.current=!1},l=window.setTimeout(()=>{t.addEventListener("pointerdown",e)},0);return()=>{window.clearTimeout(l),t.removeEventListener("pointerdown",e),t.removeEventListener("click",a.current)}},[t,n]),{onPointerDownCapture:()=>i.current=!0}}(e=>{let t=e.target,n=[...c.branches].some(e=>e.contains(t));w&&!n&&(a?.(e),r?.(e),e.defaultPrevented||s?.())},p),C=function(e,t=globalThis?.document){let n=ey(e),i=E.useRef(!1);return E.useEffect(()=>{let e=e=>{e.target&&!i.current&&eC("dismissableLayer.focusOutside",n,{originalEvent:e},{discrete:!1})};return t.addEventListener("focusin",e),()=>t.removeEventListener("focusin",e)},[t,n]),{onFocusCapture:()=>i.current=!0,onBlurCapture:()=>i.current=!1}}(e=>{let t=e.target;![...c.branches].some(e=>e.contains(t))&&(l?.(e),r?.(e),e.defaultPrevented||s?.())},p);return!function(e,t=globalThis?.document){let n=ey(e);E.useEffect(()=>{let e=e=>{"Escape"===e.key&&n(e)};return t.addEventListener("keydown",e,{capture:!0}),()=>t.removeEventListener("keydown",e,{capture:!0})},[n,t])}(e=>{y===c.layers.size-1&&(i?.(e),!e.defaultPrevented&&s&&(e.preventDefault(),s()))},p),E.useEffect(()=>{if(h)return n&&(0===c.layersWithOutsidePointerEventsDisabled.size&&(d=p.body.style.pointerEvents,p.body.style.pointerEvents="none"),c.layersWithOutsidePointerEventsDisabled.add(h)),c.layers.add(h),eS(),()=>{n&&1===c.layersWithOutsidePointerEventsDisabled.size&&(p.body.style.pointerEvents=d)}},[h,p,n,c]),E.useEffect(()=>()=>{h&&(c.layers.delete(h),c.layersWithOutsidePointerEventsDisabled.delete(h),eS())},[h,c]),E.useEffect(()=>{let e=()=>m({});return document.addEventListener(eE,e),()=>document.removeEventListener(eE,e)},[]),(0,W.jsx)(ev.div,{...o,ref:g,style:{pointerEvents:x?w?"auto":"none":void 0,...e.style},onFocusCapture:ec(e.onFocusCapture,C.onFocusCapture),onBlurCapture:ec(e.onBlurCapture,C.onBlurCapture),onPointerDownCapture:ec(e.onPointerDownCapture,S.onPointerDownCapture)})});function eS(){let e=new CustomEvent(eE);document.dispatchEvent(e)}function eC(e,t,n,{discrete:i}){let a=n.originalEvent.target,l=new CustomEvent(e,{bubbles:!1,cancelable:!0,detail:n});if(t&&a.addEventListener(e,t,{once:!0}),i)a&&er.flushSync(()=>a.dispatchEvent(l));else a.dispatchEvent(l)}ew.displayName="DismissableLayer",E.forwardRef((e,t)=>{let n=E.useContext(ex),i=E.useRef(null),a=eu(t,i);return E.useEffect(()=>{let e=i.current;if(e)return n.branches.add(e),()=>{n.branches.delete(e)}},[n.branches]),(0,W.jsx)(ev.div,{...e,ref:a})}).displayName="DismissableLayerBranch";var ek=0;function eI(){let e=document.createElement("span");return e.setAttribute("data-radix-focus-guard",""),e.tabIndex=0,e.style.outline="none",e.style.opacity="0",e.style.position="fixed",e.style.pointerEvents="none",e}var ej="focusScope.autoFocusOnMount",eT="focusScope.autoFocusOnUnmount",eM={bubbles:!1,cancelable:!0},eL=E.forwardRef((e,t)=>{let{loop:n=!1,trapped:i=!1,onMountAutoFocus:a,onUnmountAutoFocus:l,...r}=e,[s,o]=E.useState(null),c=ey(a),d=ey(l),h=E.useRef(null),u=eu(t,e=>o(e)),p=E.useRef({paused:!1,pause(){this.paused=!0},resume(){this.paused=!1}}).current;E.useEffect(()=>{if(i){let e=function(e){if(p.paused||!s)return;let t=e.target;s.contains(t)?h.current=t:eA(h.current,{select:!0})},t=function(e){if(p.paused||!s)return;let t=e.relatedTarget;null!==t&&(s.contains(t)||eA(h.current,{select:!0}))};document.addEventListener("focusin",e),document.addEventListener("focusout",t);let n=new MutationObserver(function(e){if(document.activeElement===document.body)for(let t of e)t.removedNodes.length>0&&eA(s)});return s&&n.observe(s,{childList:!0,subtree:!0}),()=>{document.removeEventListener("focusin",e),document.removeEventListener("focusout",t),n.disconnect()}}},[i,s,p.paused]),E.useEffect(()=>{if(s){eP.add(p);let e=document.activeElement;if(!s.contains(e)){let t=new CustomEvent(ej,eM);s.addEventListener(ej,c),s.dispatchEvent(t),t.defaultPrevented||(function(e,{select:t=!1}={}){let n=document.activeElement;for(let i of e)if(eA(i,{select:t}),document.activeElement!==n)return}(eD(s).filter(e=>"A"!==e.tagName),{select:!0}),document.activeElement===e&&eA(s))}return()=>{s.removeEventListener(ej,c),setTimeout(()=>{let t=new CustomEvent(eT,eM);s.addEventListener(eT,d),s.dispatchEvent(t),t.defaultPrevented||eA(e??document.body,{select:!0}),s.removeEventListener(eT,d),eP.remove(p)},0)}}},[s,c,d,p]);let m=E.useCallback(e=>{if(!n&&!i||p.paused)return;let t="Tab"===e.key&&!e.altKey&&!e.ctrlKey&&!e.metaKey,a=document.activeElement;if(t&&a){var l;let t,i=e.currentTarget,[r,s]=[eN(t=eD(l=i),l),eN(t.reverse(),l)];r&&s?e.shiftKey||a!==s?e.shiftKey&&a===r&&(e.preventDefault(),n&&eA(s,{select:!0})):(e.preventDefault(),n&&eA(r,{select:!0})):a===i&&e.preventDefault()}},[n,i,p.paused]);return(0,W.jsx)(ev.div,{tabIndex:-1,...r,ref:u,onKeyDown:m})});function eD(e){let t=[],n=document.createTreeWalker(e,NodeFilter.SHOW_ELEMENT,{acceptNode:e=>{let t="INPUT"===e.tagName&&"hidden"===e.type;return e.disabled||e.hidden||t?NodeFilter.FILTER_SKIP:e.tabIndex>=0?NodeFilter.FILTER_ACCEPT:NodeFilter.FILTER_SKIP}});for(;n.nextNode();)t.push(n.currentNode);return t}function eN(e,t){for(let n of e)if(!function(e,{upTo:t}){if("hidden"===getComputedStyle(e).visibility)return!0;for(;e&&(void 0===t||e!==t);){if("none"===getComputedStyle(e).display)return!0;e=e.parentElement}return!1}(n,{upTo:t}))return n}function eA(e,{select:t=!1}={}){if(e&&e.focus){var n;let i=document.activeElement;e.focus({preventScroll:!0}),e!==i&&(n=e)instanceof HTMLInputElement&&"select"in n&&t&&e.select()}}eL.displayName="FocusScope";var eP=(i=[],{add(e){let t=i[0];e!==t&&t?.pause(),(i=eR(i,e)).unshift(e)},remove(e){i=eR(i,e),i[0]?.resume()}});function eR(e,t){let n=[...e],i=n.indexOf(t);return -1!==i&&n.splice(i,1),n}var e_=globalThis?.document?E.useLayoutEffect:()=>{},eO=E["useId".toString()]||(()=>void 0),eF=0;let ez=["top","right","bottom","left"],eU=Math.min,eB=Math.max,eW=Math.round,eH=Math.floor,e$=e=>({x:e,y:e}),eY={left:"right",right:"left",bottom:"top",top:"bottom"};function eV(e,t){return"function"==typeof e?e(t):e}function eG(e){return e.split("-")[0]}function eK(e){return e.split("-")[1]}function eZ(e){return"x"===e?"y":"x"}function eX(e){return"y"===e?"height":"width"}function eQ(e){let t=e[0];return"t"===t||"b"===t?"y":"x"}function eq(e){return e.includes("start")?e.replace("start","end"):e.replace("end","start")}let eJ=["left","right"],e0=["right","left"],e1=["top","bottom"],e2=["bottom","top"];function e3(e){let t=eG(e);return eY[t]+e.slice(t.length)}function e5(e){return"number"!=typeof e?{top:0,right:0,bottom:0,left:0,...e}:{top:e,right:e,bottom:e,left:e}}function e4(e){let{x:t,y:n,width:i,height:a}=e;return{width:i,height:a,top:n,left:t,right:t+i,bottom:n+a,x:t,y:n}}function e6(e,t,n){let i,{reference:a,floating:l}=e,r=eQ(t),s=eZ(eQ(t)),o=eX(s),c=eG(t),d="y"===r,h=a.x+a.width/2-l.width/2,u=a.y+a.height/2-l.height/2,p=a[o]/2-l[o]/2;switch(c){case"top":i={x:h,y:a.y-l.height};break;case"bottom":i={x:h,y:a.y+a.height};break;case"right":i={x:a.x+a.width,y:u};break;case"left":i={x:a.x-l.width,y:u};break;default:i={x:a.x,y:a.y}}switch(eK(t)){case"start":i[s]-=p*(n&&d?-1:1);break;case"end":i[s]+=p*(n&&d?-1:1)}return i}async function e8(e,t){var n;void 0===t&&(t={});let{x:i,y:a,platform:l,rects:r,elements:s,strategy:o}=e,{boundary:c="clippingAncestors",rootBoundary:d="viewport",elementContext:h="floating",altBoundary:u=!1,padding:p=0}=eV(t,e),m=e5(p),g=s[u?"floating"===h?"reference":"floating":h],f=e4(await l.getClippingRect({element:null==(n=await (null==l.isElement?void 0:l.isElement(g)))||n?g:g.contextElement||await (null==l.getDocumentElement?void 0:l.getDocumentElement(s.floating)),boundary:c,rootBoundary:d,strategy:o})),b="floating"===h?{x:i,y:a,width:r.floating.width,height:r.floating.height}:r.reference,v=await (null==l.getOffsetParent?void 0:l.getOffsetParent(s.floating)),y=await (null==l.isElement?void 0:l.isElement(v))&&await (null==l.getScale?void 0:l.getScale(v))||{x:1,y:1},E=e4(l.convertOffsetParentRelativeRectToViewportRelativeRect?await l.convertOffsetParentRelativeRectToViewportRelativeRect({elements:s,rect:b,offsetParent:v,strategy:o}):b);return{top:(f.top-E.top+m.top)/y.y,bottom:(E.bottom-f.bottom+m.bottom)/y.y,left:(f.left-E.left+m.left)/y.x,right:(E.right-f.right+m.right)/y.x}}let e7=async(e,t,n)=>{let{placement:i="bottom",strategy:a="absolute",middleware:l=[],platform:r}=n,s=r.detectOverflow?r:{...r,detectOverflow:e8},o=await (null==r.isRTL?void 0:r.isRTL(t)),c=await r.getElementRects({reference:e,floating:t,strategy:a}),{x:d,y:h}=e6(c,i,o),u=i,p=0,m={};for(let n=0;n<l.length;n++){let g=l[n];if(!g)continue;let{name:f,fn:b}=g,{x:v,y:y,data:E,reset:x}=await b({x:d,y:h,initialPlacement:i,placement:u,strategy:a,middlewareData:m,rects:c,platform:s,elements:{reference:e,floating:t}});d=null!=v?v:d,h=null!=y?y:h,m[f]={...m[f],...E},x&&p<50&&(p++,"object"==typeof x&&(x.placement&&(u=x.placement),x.rects&&(c=!0===x.rects?await r.getElementRects({reference:e,floating:t,strategy:a}):x.rects),{x:d,y:h}=e6(c,u,o)),n=-1)}return{x:d,y:h,placement:u,strategy:a,middlewareData:m}};function e9(e,t){return{top:e.top-t.height,right:e.right-t.width,bottom:e.bottom-t.height,left:e.left-t.width}}function te(e){return ez.some(t=>e[t]>=0)}let tt=new Set(["left","top"]);async function tn(e,t){let{placement:n,platform:i,elements:a}=e,l=await (null==i.isRTL?void 0:i.isRTL(a.floating)),r=eG(n),s=eK(n),o="y"===eQ(n),c=tt.has(r)?-1:1,d=l&&o?-1:1,h=eV(t,e),{mainAxis:u,crossAxis:p,alignmentAxis:m}="number"==typeof h?{mainAxis:h,crossAxis:0,alignmentAxis:null}:{mainAxis:h.mainAxis||0,crossAxis:h.crossAxis||0,alignmentAxis:h.alignmentAxis};return s&&"number"==typeof m&&(p="end"===s?-1*m:m),o?{x:p*d,y:u*c}:{x:u*c,y:p*d}}function ti(){return"u">typeof window}function ta(e){return ts(e)?(e.nodeName||"").toLowerCase():"#document"}function tl(e){var t;return(null==e||null==(t=e.ownerDocument)?void 0:t.defaultView)||window}function tr(e){var t;return null==(t=(ts(e)?e.ownerDocument:e.document)||window.document)?void 0:t.documentElement}function ts(e){return!!ti()&&(e instanceof Node||e instanceof tl(e).Node)}function to(e){return!!ti()&&(e instanceof Element||e instanceof tl(e).Element)}function tc(e){return!!ti()&&(e instanceof HTMLElement||e instanceof tl(e).HTMLElement)}function td(e){return!(!ti()||"u"<typeof ShadowRoot)&&(e instanceof ShadowRoot||e instanceof tl(e).ShadowRoot)}function th(e){let{overflow:t,overflowX:n,overflowY:i,display:a}=ty(e);return/auto|scroll|overlay|hidden|clip/.test(t+i+n)&&"inline"!==a&&"contents"!==a}function tu(e){try{if(e.matches(":popover-open"))return!0}catch(e){}try{return e.matches(":modal")}catch(e){return!1}}let tp=/transform|translate|scale|rotate|perspective|filter/,tm=/paint|layout|strict|content/,tg=e=>!!e&&"none"!==e;function tf(e){let t=to(e)?ty(e):e;return tg(t.transform)||tg(t.translate)||tg(t.scale)||tg(t.rotate)||tg(t.perspective)||!tb()&&(tg(t.backdropFilter)||tg(t.filter))||tp.test(t.willChange||"")||tm.test(t.contain||"")}function tb(){return null==n&&(n="u">typeof CSS&&CSS.supports&&CSS.supports("-webkit-backdrop-filter","none")),n}function tv(e){return/^(html|body|#document)$/.test(ta(e))}function ty(e){return tl(e).getComputedStyle(e)}function tE(e){return to(e)?{scrollLeft:e.scrollLeft,scrollTop:e.scrollTop}:{scrollLeft:e.scrollX,scrollTop:e.scrollY}}function tx(e){if("html"===ta(e))return e;let t=e.assignedSlot||e.parentNode||td(e)&&e.host||tr(e);return td(t)?t.host:t}function tw(e,t,n){var i;void 0===t&&(t=[]),void 0===n&&(n=!0);let a=function e(t){let n=tx(t);return tv(n)?t.ownerDocument?t.ownerDocument.body:t.body:tc(n)&&th(n)?n:e(n)}(e),l=a===(null==(i=e.ownerDocument)?void 0:i.body),r=tl(a);if(!l)return t.concat(a,tw(a,[],n));{let e=tS(r);return t.concat(r,r.visualViewport||[],th(a)?a:[],e&&n?tw(e):[])}}function tS(e){return e.parent&&Object.getPrototypeOf(e.parent)?e.frameElement:null}function tC(e){let t=ty(e),n=parseFloat(t.width)||0,i=parseFloat(t.height)||0,a=tc(e),l=a?e.offsetWidth:n,r=a?e.offsetHeight:i,s=eW(n)!==l||eW(i)!==r;return s&&(n=l,i=r),{width:n,height:i,$:s}}function tk(e){return to(e)?e:e.contextElement}function tI(e){let t=tk(e);if(!tc(t))return e$(1);let n=t.getBoundingClientRect(),{width:i,height:a,$:l}=tC(t),r=(l?eW(n.width):n.width)/i,s=(l?eW(n.height):n.height)/a;return r&&Number.isFinite(r)||(r=1),s&&Number.isFinite(s)||(s=1),{x:r,y:s}}let tj=e$(0);function tT(e){let t=tl(e);return tb()&&t.visualViewport?{x:t.visualViewport.offsetLeft,y:t.visualViewport.offsetTop}:tj}function tM(e,t,n,i){var a;void 0===t&&(t=!1),void 0===n&&(n=!1);let l=e.getBoundingClientRect(),r=tk(e),s=e$(1);t&&(i?to(i)&&(s=tI(i)):s=tI(e));let o=(void 0===(a=n)&&(a=!1),i&&(!a||i===tl(r))&&a)?tT(r):e$(0),c=(l.left+o.x)/s.x,d=(l.top+o.y)/s.y,h=l.width/s.x,u=l.height/s.y;if(r){let e=tl(r),t=i&&to(i)?tl(i):i,n=e,a=tS(n);for(;a&&i&&t!==n;){let e=tI(a),t=a.getBoundingClientRect(),i=ty(a),l=t.left+(a.clientLeft+parseFloat(i.paddingLeft))*e.x,r=t.top+(a.clientTop+parseFloat(i.paddingTop))*e.y;c*=e.x,d*=e.y,h*=e.x,u*=e.y,c+=l,d+=r,a=tS(n=tl(a))}}return e4({width:h,height:u,x:c,y:d})}function tL(e,t){let n=tE(e).scrollLeft;return t?t.left+n:tM(tr(e)).left+n}function tD(e,t){let n=e.getBoundingClientRect();return{x:n.left+t.scrollLeft-tL(e,n),y:n.top+t.scrollTop}}function tN(e,t,n){var i;let a;if("viewport"===t)a=function(e,t){let n=tl(e),i=tr(e),a=n.visualViewport,l=i.clientWidth,r=i.clientHeight,s=0,o=0;if(a){l=a.width,r=a.height;let e=tb();(!e||e&&"fixed"===t)&&(s=a.offsetLeft,o=a.offsetTop)}let c=tL(i);if(c<=0){let e=i.ownerDocument,t=e.body,n=getComputedStyle(t),a="CSS1Compat"===e.compatMode&&parseFloat(n.marginLeft)+parseFloat(n.marginRight)||0,r=Math.abs(i.clientWidth-t.clientWidth-a);r<=25&&(l-=r)}else c<=25&&(l+=c);return{width:l,height:r,x:s,y:o}}(e,n);else if("document"===t){let t,n,l,r,s,o,c;i=tr(e),t=tr(i),n=tE(i),l=i.ownerDocument.body,r=eB(t.scrollWidth,t.clientWidth,l.scrollWidth,l.clientWidth),s=eB(t.scrollHeight,t.clientHeight,l.scrollHeight,l.clientHeight),o=-n.scrollLeft+tL(i),c=-n.scrollTop,"rtl"===ty(l).direction&&(o+=eB(t.clientWidth,l.clientWidth)-r),a={width:r,height:s,x:o,y:c}}else if(to(t)){let e,i,l,r,s,o;i=(e=tM(t,!0,"fixed"===n)).top+t.clientTop,l=e.left+t.clientLeft,r=tc(t)?tI(t):e$(1),s=t.clientWidth*r.x,o=t.clientHeight*r.y,a={width:s,height:o,x:l*r.x,y:i*r.y}}else{let n=tT(e);a={x:t.x-n.x,y:t.y-n.y,width:t.width,height:t.height}}return e4(a)}function tA(e){return"static"===ty(e).position}function tP(e,t){if(!tc(e)||"fixed"===ty(e).position)return null;if(t)return t(e);let n=e.offsetParent;return tr(e)===n&&(n=n.ownerDocument.body),n}function tR(e,t){var n;let i=tl(e);if(tu(e))return i;if(!tc(e)){let t=tx(e);for(;t&&!tv(t);){if(to(t)&&!tA(t))return t;t=tx(t)}return i}let a=tP(e,t);for(;a&&(n=a,/^(table|td|th)$/.test(ta(n)))&&tA(a);)a=tP(a,t);return a&&tv(a)&&tA(a)&&!tf(a)?i:a||function(e){let t=tx(e);for(;tc(t)&&!tv(t);){if(tf(t))return t;if(tu(t))break;t=tx(t)}return null}(e)||i}let t_=async function(e){let t=this.getOffsetParent||tR,n=this.getDimensions,i=await n(e.floating);return{reference:function(e,t,n){let i=tc(t),a=tr(t),l="fixed"===n,r=tM(e,!0,l,t),s={scrollLeft:0,scrollTop:0},o=e$(0);if(i||!i&&!l)if(("body"!==ta(t)||th(a))&&(s=tE(t)),i){let e=tM(t,!0,l,t);o.x=e.x+t.clientLeft,o.y=e.y+t.clientTop}else a&&(o.x=tL(a));l&&!i&&a&&(o.x=tL(a));let c=!a||i||l?e$(0):tD(a,s);return{x:r.left+s.scrollLeft-o.x-c.x,y:r.top+s.scrollTop-o.y-c.y,width:r.width,height:r.height}}(e.reference,await t(e.floating),e.strategy),floating:{x:0,y:0,width:i.width,height:i.height}}},tO={convertOffsetParentRelativeRectToViewportRelativeRect:function(e){let{elements:t,rect:n,offsetParent:i,strategy:a}=e,l="fixed"===a,r=tr(i),s=!!t&&tu(t.floating);if(i===r||s&&l)return n;let o={scrollLeft:0,scrollTop:0},c=e$(1),d=e$(0),h=tc(i);if((h||!h&&!l)&&(("body"!==ta(i)||th(r))&&(o=tE(i)),h)){let e=tM(i);c=tI(i),d.x=e.x+i.clientLeft,d.y=e.y+i.clientTop}let u=!r||h||l?e$(0):tD(r,o);return{width:n.width*c.x,height:n.height*c.y,x:n.x*c.x-o.scrollLeft*c.x+d.x+u.x,y:n.y*c.y-o.scrollTop*c.y+d.y+u.y}},getDocumentElement:tr,getClippingRect:function(e){let{element:t,boundary:n,rootBoundary:i,strategy:a}=e,l=[..."clippingAncestors"===n?tu(t)?[]:function(e,t){let n=t.get(e);if(n)return n;let i=tw(e,[],!1).filter(e=>to(e)&&"body"!==ta(e)),a=null,l="fixed"===ty(e).position,r=l?tx(e):e;for(;to(r)&&!tv(r);){let t=ty(r),n=tf(r);n||"fixed"!==t.position||(a=null),(l?n||a:!(!n&&"static"===t.position&&a&&("absolute"===a.position||"fixed"===a.position)||th(r)&&!n&&function e(t,n){let i=tx(t);return!(i===n||!to(i)||tv(i))&&("fixed"===ty(i).position||e(i,n))}(e,r)))?a=t:i=i.filter(e=>e!==r),r=tx(r)}return t.set(e,i),i}(t,this._c):[].concat(n),i],r=tN(t,l[0],a),s=r.top,o=r.right,c=r.bottom,d=r.left;for(let e=1;e<l.length;e++){let n=tN(t,l[e],a);s=eB(n.top,s),o=eU(n.right,o),c=eU(n.bottom,c),d=eB(n.left,d)}return{width:o-d,height:c-s,x:d,y:s}},getOffsetParent:tR,getElementRects:t_,getClientRects:function(e){return Array.from(e.getClientRects())},getDimensions:function(e){let{width:t,height:n}=tC(e);return{width:t,height:n}},getScale:tI,isElement:to,isRTL:function(e){return"rtl"===ty(e).direction}};function tF(e,t){return e.x===t.x&&e.y===t.y&&e.width===t.width&&e.height===t.height}let tz=e=>({name:"arrow",options:e,async fn(t){let{x:n,y:i,placement:a,rects:l,platform:r,elements:s,middlewareData:o}=t,{element:c,padding:d=0}=eV(e,t)||{};if(null==c)return{};let h=e5(d),u={x:n,y:i},p=eZ(eQ(a)),m=eX(p),g=await r.getDimensions(c),f="y"===p,b=f?"clientHeight":"clientWidth",v=l.reference[m]+l.reference[p]-u[p]-l.floating[m],y=u[p]-l.reference[p],E=await (null==r.getOffsetParent?void 0:r.getOffsetParent(c)),x=E?E[b]:0;x&&await (null==r.isElement?void 0:r.isElement(E))||(x=s.floating[b]||l.floating[m]);let w=x/2-g[m]/2-1,S=eU(h[f?"top":"left"],w),C=eU(h[f?"bottom":"right"],w),k=x-g[m]-C,I=x/2-g[m]/2+(v/2-y/2),j=eB(S,eU(I,k)),T=!o.arrow&&null!=eK(a)&&I!==j&&l.reference[m]/2-(I<S?S:C)-g[m]/2<0,M=T?I<S?I-S:I-k:0;return{[p]:u[p]+M,data:{[p]:j,centerOffset:I-j-M,...T&&{alignmentOffset:M}},reset:T}}});var tU="u">typeof document?E.useLayoutEffect:function(){};function tB(e,t){let n,i,a;if(e===t)return!0;if(typeof e!=typeof t)return!1;if("function"==typeof e&&e.toString()===t.toString())return!0;if(e&&t&&"object"==typeof e){if(Array.isArray(e)){if((n=e.length)!==t.length)return!1;for(i=n;0!=i--;)if(!tB(e[i],t[i]))return!1;return!0}if((n=(a=Object.keys(e)).length)!==Object.keys(t).length)return!1;for(i=n;0!=i--;)if(!({}).hasOwnProperty.call(t,a[i]))return!1;for(i=n;0!=i--;){let n=a[i];if(("_owner"!==n||!e.$$typeof)&&!tB(e[n],t[n]))return!1}return!0}return e!=e&&t!=t}function tW(e){return"u"<typeof window?1:(e.ownerDocument.defaultView||window).devicePixelRatio||1}function tH(e,t){let n=tW(e);return Math.round(t*n)/n}function t$(e){let t=E.useRef(e);return tU(()=>{t.current=e}),t}var tY=E.forwardRef((e,t)=>{let{children:n,width:i=10,height:a=5,...l}=e;return(0,W.jsx)(ev.svg,{...l,ref:t,width:i,height:a,viewBox:"0 0 30 10",preserveAspectRatio:"none",children:e.asChild?n:(0,W.jsx)("polygon",{points:"0,0 30,0 15,10"})})});tY.displayName="Arrow";var tV="Popper",[tG,tK]=ep(tV),[tZ,tX]=tG(tV),tQ=e=>{let{__scopePopper:t,children:n}=e,[i,a]=E.useState(null);return(0,W.jsx)(tZ,{scope:t,anchor:i,onAnchorChange:a,children:n})};tQ.displayName=tV;var tq="PopperAnchor",tJ=E.forwardRef((e,t)=>{let{__scopePopper:n,virtualRef:i,...a}=e,l=tX(tq,n),r=E.useRef(null),s=eu(t,r);return E.useEffect(()=>{l.onAnchorChange(i?.current||r.current)}),i?null:(0,W.jsx)(ev.div,{...a,ref:s})});tJ.displayName=tq;var t0="PopperContent",[t1,t2]=tG(t0),t3=E.forwardRef((e,t)=>{var n,i,a,l,r,s,o,c,d,h,u,p,m,g,f,b,v,y,x,w,S;let C,k,I,j,T,M,{__scopePopper:L,side:D="bottom",sideOffset:N=0,align:A="center",alignOffset:P=0,arrowPadding:R=0,avoidCollisions:_=!0,collisionBoundary:O=[],collisionPadding:F=0,sticky:z="partial",hideWhenDetached:U=!1,updatePositionStrategy:B="optimized",onPlaced:H,...$}=e,Y=tX(t0,L),[V,G]=E.useState(null),K=eu(t,e=>G(e)),[Z,X]=E.useState(null),Q=function(e){let[t,n]=E.useState(void 0);return e_(()=>{if(e){n({width:e.offsetWidth,height:e.offsetHeight});let t=new ResizeObserver(t=>{let i,a;if(!Array.isArray(t)||!t.length)return;let l=t[0];if("borderBoxSize"in l){let e=l.borderBoxSize,t=Array.isArray(e)?e[0]:e;i=t.inlineSize,a=t.blockSize}else i=e.offsetWidth,a=e.offsetHeight;n({width:i,height:a})});return t.observe(e,{box:"border-box"}),()=>t.unobserve(e)}n(void 0)},[e]),t}(Z),q=Q?.width??0,J=Q?.height??0,ee="number"==typeof F?F:{top:0,right:0,bottom:0,left:0,...F},et=Array.isArray(O)?O:[O],en=et.length>0,ei={padding:ee,boundary:et.filter(t8),altBoundary:en},{refs:ea,floatingStyles:el,placement:es,isPositioned:eo,middlewareData:ec}=function(e){void 0===e&&(e={});let{placement:t="bottom",strategy:n="absolute",middleware:i=[],platform:a,elements:{reference:l,floating:r}={},transform:s=!0,whileElementsMounted:o,open:c}=e,[d,h]=E.useState({x:0,y:0,strategy:n,placement:t,middlewareData:{},isPositioned:!1}),[u,p]=E.useState(i);tB(u,i)||p(i);let[m,g]=E.useState(null),[f,b]=E.useState(null),v=E.useCallback(e=>{e!==S.current&&(S.current=e,g(e))},[]),y=E.useCallback(e=>{e!==C.current&&(C.current=e,b(e))},[]),x=l||m,w=r||f,S=E.useRef(null),C=E.useRef(null),k=E.useRef(d),I=null!=o,j=t$(o),T=t$(a),M=t$(c),L=E.useCallback(()=>{var e,i;let a,l,r;if(!S.current||!C.current)return;let s={placement:t,strategy:n,middleware:u};T.current&&(s.platform=T.current),(e=S.current,i=C.current,a=new Map,r={...(l={platform:tO,...s}).platform,_c:a},e7(e,i,{...l,platform:r})).then(e=>{let t={...e,isPositioned:!1!==M.current};D.current&&!tB(k.current,t)&&(k.current=t,er.flushSync(()=>{h(t)}))})},[u,t,n,T,M]);tU(()=>{!1===c&&k.current.isPositioned&&(k.current.isPositioned=!1,h(e=>({...e,isPositioned:!1})))},[c]);let D=E.useRef(!1);tU(()=>(D.current=!0,()=>{D.current=!1}),[]),tU(()=>{if(x&&(S.current=x),w&&(C.current=w),x&&w){if(j.current)return j.current(x,w,L);L()}},[x,w,L,j,I]);let N=E.useMemo(()=>({reference:S,floating:C,setReference:v,setFloating:y}),[v,y]),A=E.useMemo(()=>({reference:x,floating:w}),[x,w]),P=E.useMemo(()=>{let e={position:n,left:0,top:0};if(!A.floating)return e;let t=tH(A.floating,d.x),i=tH(A.floating,d.y);return s?{...e,transform:"translate("+t+"px, "+i+"px)",...tW(A.floating)>=1.5&&{willChange:"transform"}}:{position:n,left:t,top:i}},[n,s,A.floating,d.x,d.y]);return E.useMemo(()=>({...d,update:L,refs:N,elements:A,floatingStyles:P}),[d,L,N,A,P])}({strategy:"fixed",placement:D+("center"!==A?"-"+A:""),whileElementsMounted:(...e)=>(function(e,t,n,i){let a;void 0===i&&(i={});let{ancestorScroll:l=!0,ancestorResize:r=!0,elementResize:s="function"==typeof ResizeObserver,layoutShift:o="function"==typeof IntersectionObserver,animationFrame:c=!1}=i,d=tk(e),h=l||r?[...d?tw(d):[],...t?tw(t):[]]:[];h.forEach(e=>{l&&e.addEventListener("scroll",n,{passive:!0}),r&&e.addEventListener("resize",n)});let u=d&&o?function(e,t){let n,i=null,a=tr(e);function l(){var e;clearTimeout(n),null==(e=i)||e.disconnect(),i=null}return!function r(s,o){void 0===s&&(s=!1),void 0===o&&(o=1),l();let c=e.getBoundingClientRect(),{left:d,top:h,width:u,height:p}=c;if(s||t(),!u||!p)return;let m={rootMargin:-eH(h)+"px "+-eH(a.clientWidth-(d+u))+"px "+-eH(a.clientHeight-(h+p))+"px "+-eH(d)+"px",threshold:eB(0,eU(1,o))||1},g=!0;function f(t){let i=t[0].intersectionRatio;if(i!==o){if(!g)return r();i?r(!1,i):n=setTimeout(()=>{r(!1,1e-7)},1e3)}1!==i||tF(c,e.getBoundingClientRect())||r(),g=!1}try{i=new IntersectionObserver(f,{...m,root:a.ownerDocument})}catch(e){i=new IntersectionObserver(f,m)}i.observe(e)}(!0),l}(d,n):null,p=-1,m=null;s&&(m=new ResizeObserver(e=>{let[i]=e;i&&i.target===d&&m&&t&&(m.unobserve(t),cancelAnimationFrame(p),p=requestAnimationFrame(()=>{var e;null==(e=m)||e.observe(t)})),n()}),d&&!c&&m.observe(d),t&&m.observe(t));let g=c?tM(e):null;return c&&function t(){let i=tM(e);g&&!tF(g,i)&&n(),g=i,a=requestAnimationFrame(t)}(),n(),()=>{var e;h.forEach(e=>{l&&e.removeEventListener("scroll",n),r&&e.removeEventListener("resize",n)}),null==u||u(),null==(e=m)||e.disconnect(),m=null,c&&cancelAnimationFrame(a)}})(...e,{animationFrame:"always"===B}),elements:{reference:Y.anchor},middleware:[{name:(C={name:"offset",options:a=n={mainAxis:N+J,alignmentAxis:P},async fn(e){var t,n;let{x:i,y:l,placement:r,middlewareData:s}=e,o=await tn(e,a);return r===(null==(t=s.offset)?void 0:t.placement)&&null!=(n=s.arrow)&&n.alignmentOffset?{}:{x:i+o.x,y:l+o.y,data:{...o,placement:r}}}}).name,fn:C.fn,options:[n,i]},_&&{name:(k={name:"shift",options:d=o={mainAxis:!0,crossAxis:!1,limiter:"partial"===z?{fn:(void 0===(s=l)&&(s={}),{options:s,fn(e){let{x:t,y:n,placement:i,rects:a,middlewareData:l}=e,{offset:r=0,mainAxis:o=!0,crossAxis:c=!0}=eV(s,e),d={x:t,y:n},h=eQ(i),u=eZ(h),p=d[u],m=d[h],g=eV(r,e),f="number"==typeof g?{mainAxis:g,crossAxis:0}:{mainAxis:0,crossAxis:0,...g};if(o){let e="y"===u?"height":"width",t=a.reference[u]-a.floating[e]+f.mainAxis,n=a.reference[u]+a.reference[e]-f.mainAxis;p<t?p=t:p>n&&(p=n)}if(c){var b,v;let e="y"===u?"width":"height",t=tt.has(eG(i)),n=a.reference[h]-a.floating[e]+(t&&(null==(b=l.offset)?void 0:b[h])||0)+(t?0:f.crossAxis),r=a.reference[h]+a.reference[e]+(t?0:(null==(v=l.offset)?void 0:v[h])||0)-(t?f.crossAxis:0);m<n?m=n:m>r&&(m=r)}return{[u]:p,[h]:m}}}).fn,options:[l,r]}:void 0,...ei},async fn(e){let{x:t,y:n,placement:i,platform:a}=e,{mainAxis:l=!0,crossAxis:r=!1,limiter:s={fn:e=>{let{x:t,y:n}=e;return{x:t,y:n}}},...o}=eV(d,e),c={x:t,y:n},h=await a.detectOverflow(e,o),u=eQ(eG(i)),p=eZ(u),m=c[p],g=c[u];if(l){let e="y"===p?"top":"left",t="y"===p?"bottom":"right",n=m+h[e],i=m-h[t];m=eB(n,eU(m,i))}if(r){let e="y"===u?"top":"left",t="y"===u?"bottom":"right",n=g+h[e],i=g-h[t];g=eB(n,eU(g,i))}let f=s.fn({...e,[p]:m,[u]:g});return{...f,data:{x:f.x-t,y:f.y-n,enabled:{[p]:l,[u]:r}}}}}).name,fn:k.fn,options:[o,c]},_&&{name:(I={name:"flip",options:p=h={...ei},async fn(e){var t,n,i,a,l,r,s,o;let c,d,h,{placement:u,middlewareData:m,rects:g,initialPlacement:f,platform:b,elements:v}=e,{mainAxis:y=!0,crossAxis:E=!0,fallbackPlacements:x,fallbackStrategy:w="bestFit",fallbackAxisSideDirection:S="none",flipAlignment:C=!0,...k}=eV(p,e);if(null!=(t=m.arrow)&&t.alignmentOffset)return{};let I=eG(u),j=eQ(f),T=eG(f)===f,M=await (null==b.isRTL?void 0:b.isRTL(v.floating)),L=x||(T||!C?[e3(f)]:(c=e3(f),[eq(f),c,eq(c)])),D="none"!==S;!x&&D&&L.push(...(d=eK(f),h=function(e,t,n){switch(e){case"top":case"bottom":if(n)return t?e0:eJ;return t?eJ:e0;case"left":case"right":return t?e1:e2;default:return[]}}(eG(f),"start"===S,M),d&&(h=h.map(e=>e+"-"+d),C&&(h=h.concat(h.map(eq)))),h));let N=[f,...L],A=await b.detectOverflow(e,k),P=[],R=(null==(n=m.flip)?void 0:n.overflows)||[];if(y&&P.push(A[I]),E){let e,t,n,i,a=(r=u,s=g,void 0===(o=M)&&(o=!1),e=eK(r),n=eX(t=eZ(eQ(r))),i="x"===t?e===(o?"end":"start")?"right":"left":"start"===e?"bottom":"top",s.reference[n]>s.floating[n]&&(i=e3(i)),[i,e3(i)]);P.push(A[a[0]],A[a[1]])}if(R=[...R,{placement:u,overflows:P}],!P.every(e=>e<=0)){let e=((null==(i=m.flip)?void 0:i.index)||0)+1,t=N[e];if(t&&("alignment"!==E||j===eQ(t)||R.every(e=>eQ(e.placement)!==j||e.overflows[0]>0)))return{data:{index:e,overflows:R},reset:{placement:t}};let n=null==(a=R.filter(e=>e.overflows[0]<=0).sort((e,t)=>e.overflows[1]-t.overflows[1])[0])?void 0:a.placement;if(!n)switch(w){case"bestFit":{let e=null==(l=R.filter(e=>{if(D){let t=eQ(e.placement);return t===j||"y"===t}return!0}).map(e=>[e.placement,e.overflows.filter(e=>e>0).reduce((e,t)=>e+t,0)]).sort((e,t)=>e[1]-t[1])[0])?void 0:l[0];e&&(n=e);break}case"initialPlacement":n=f}if(u!==n)return{reset:{placement:n}}}return{}}}).name,fn:I.fn,options:[h,u]},{name:(j={name:"size",options:f=m={...ei,apply:({elements:e,rects:t,availableWidth:n,availableHeight:i})=>{let{width:a,height:l}=t.reference,r=e.floating.style;r.setProperty("--radix-popper-available-width",`${n}px`),r.setProperty("--radix-popper-available-height",`${i}px`),r.setProperty("--radix-popper-anchor-width",`${a}px`),r.setProperty("--radix-popper-anchor-height",`${l}px`)}},async fn(e){var t,n;let i,a,{placement:l,rects:r,platform:s,elements:o}=e,{apply:c=()=>{},...d}=eV(f,e),h=await s.detectOverflow(e,d),u=eG(l),p=eK(l),m="y"===eQ(l),{width:g,height:b}=r.floating;"top"===u||"bottom"===u?(i=u,a=p===(await (null==s.isRTL?void 0:s.isRTL(o.floating))?"start":"end")?"left":"right"):(a=u,i="end"===p?"top":"bottom");let v=b-h.top-h.bottom,y=g-h.left-h.right,E=eU(b-h[i],v),x=eU(g-h[a],y),w=!e.middlewareData.shift,S=E,C=x;if(null!=(t=e.middlewareData.shift)&&t.enabled.x&&(C=y),null!=(n=e.middlewareData.shift)&&n.enabled.y&&(S=v),w&&!p){let e=eB(h.left,0),t=eB(h.right,0),n=eB(h.top,0),i=eB(h.bottom,0);m?C=g-2*(0!==e||0!==t?e+t:eB(h.left,h.right)):S=b-2*(0!==n||0!==i?n+i:eB(h.top,h.bottom))}await c({...e,availableWidth:C,availableHeight:S});let k=await s.getDimensions(o.floating);return g!==k.width||b!==k.height?{reset:{rects:!0}}:{}}}).name,fn:j.fn,options:[m,g]},Z&&{name:(T={name:"arrow",options:y=b={element:Z,padding:R},fn(e){let{element:t,padding:n}="function"==typeof y?y(e):y;return t&&({}).hasOwnProperty.call(t,"current")?null!=t.current?tz({element:t.current,padding:n}).fn(e):{}:t?tz({element:t,padding:n}).fn(e):{}}}).name,fn:T.fn,options:[b,v]},t7({arrowWidth:q,arrowHeight:J}),U&&{name:(M={name:"hide",options:S=x={strategy:"referenceHidden",...ei},async fn(e){let{rects:t,platform:n}=e,{strategy:i="referenceHidden",...a}=eV(S,e);switch(i){case"referenceHidden":{let i=e9(await n.detectOverflow(e,{...a,elementContext:"reference"}),t.reference);return{data:{referenceHiddenOffsets:i,referenceHidden:te(i)}}}case"escaped":{let i=e9(await n.detectOverflow(e,{...a,altBoundary:!0}),t.floating);return{data:{escapedOffsets:i,escaped:te(i)}}}default:return{}}}}).name,fn:M.fn,options:[x,w]}]}),[ed,eh]=t9(es),ep=ey(H);e_(()=>{eo&&ep?.()},[eo,ep]);let em=ec.arrow?.x,eg=ec.arrow?.y,ef=ec.arrow?.centerOffset!==0,[eb,eE]=E.useState();return e_(()=>{V&&eE(window.getComputedStyle(V).zIndex)},[V]),(0,W.jsx)("div",{ref:ea.setFloating,"data-radix-popper-content-wrapper":"",style:{...el,transform:eo?el.transform:"translate(0, -200%)",minWidth:"max-content",zIndex:eb,"--radix-popper-transform-origin":[ec.transformOrigin?.x,ec.transformOrigin?.y].join(" "),...ec.hide?.referenceHidden&&{visibility:"hidden",pointerEvents:"none"}},dir:e.dir,children:(0,W.jsx)(t1,{scope:L,placedSide:ed,onArrowChange:X,arrowX:em,arrowY:eg,shouldHideArrow:ef,children:(0,W.jsx)(ev.div,{"data-side":ed,"data-align":eh,...$,ref:K,style:{...$.style,animation:eo?void 0:"none"}})})})});t3.displayName=t0;var t5="PopperArrow",t4={top:"bottom",right:"left",bottom:"top",left:"right"},t6=E.forwardRef(function(e,t){let{__scopePopper:n,...i}=e,a=t2(t5,n),l=t4[a.placedSide];return(0,W.jsx)("span",{ref:a.onArrowChange,style:{position:"absolute",left:a.arrowX,top:a.arrowY,[l]:0,transformOrigin:{top:"",right:"0 0",bottom:"center 0",left:"100% 0"}[a.placedSide],transform:{top:"translateY(100%)",right:"translateY(50%) rotate(90deg) translateX(-50%)",bottom:"rotate(180deg)",left:"translateY(50%) rotate(-90deg) translateX(50%)"}[a.placedSide],visibility:a.shouldHideArrow?"hidden":void 0},children:(0,W.jsx)(tY,{...i,ref:t,style:{...i.style,display:"block"}})})});function t8(e){return null!==e}t6.displayName=t5;var t7=e=>({name:"transformOrigin",options:e,fn(t){let{placement:n,rects:i,middlewareData:a}=t,l=a.arrow?.centerOffset!==0,r=l?0:e.arrowWidth,s=l?0:e.arrowHeight,[o,c]=t9(n),d={start:"0%",center:"50%",end:"100%"}[c],h=(a.arrow?.x??0)+r/2,u=(a.arrow?.y??0)+s/2,p="",m="";return"bottom"===o?(p=l?d:`${h}px`,m=`${-s}px`):"top"===o?(p=l?d:`${h}px`,m=`${i.floating.height+s}px`):"right"===o?(p=`${-s}px`,m=l?d:`${u}px`):"left"===o&&(p=`${i.floating.width+s}px`,m=l?d:`${u}px`),{data:{x:p,y:m}}}});function t9(e){let[t,n="center"]=e.split("-");return[t,n]}var ne=E.forwardRef((e,t)=>{let{container:n,...i}=e,[a,l]=E.useState(!1);e_(()=>l(!0),[]);let r=n||a&&globalThis?.document?.body;return r?er.default.createPortal((0,W.jsx)(ev.div,{...i,ref:t}),r):null});ne.displayName="Portal";var nt=e=>{var t;let n,i,{present:a,children:l}=e,r=function(e){var t,n;let[i,a]=E.useState(),l=E.useRef({}),r=E.useRef(e),s=E.useRef("none"),[o,c]=(t=e?"mounted":"unmounted",n={mounted:{UNMOUNT:"unmounted",ANIMATION_OUT:"unmountSuspended"},unmountSuspended:{MOUNT:"mounted",ANIMATION_END:"unmounted"},unmounted:{MOUNT:"mounted"}},E.useReducer((e,t)=>n[e][t]??e,t));return E.useEffect(()=>{let e=nn(l.current);s.current="mounted"===o?e:"none"},[o]),e_(()=>{let t=l.current,n=r.current;if(n!==e){let i=s.current,a=nn(t);e?c("MOUNT"):"none"===a||t?.display==="none"?c("UNMOUNT"):n&&i!==a?c("ANIMATION_OUT"):c("UNMOUNT"),r.current=e}},[e,c]),e_(()=>{if(i){let e,t=i.ownerDocument.defaultView??window,n=n=>{let a=nn(l.current).includes(n.animationName);if(n.target===i&&a&&(c("ANIMATION_END"),!r.current)){let n=i.style.animationFillMode;i.style.animationFillMode="forwards",e=t.setTimeout(()=>{"forwards"===i.style.animationFillMode&&(i.style.animationFillMode=n)})}},a=e=>{e.target===i&&(s.current=nn(l.current))};return i.addEventListener("animationstart",a),i.addEventListener("animationcancel",n),i.addEventListener("animationend",n),()=>{t.clearTimeout(e),i.removeEventListener("animationstart",a),i.removeEventListener("animationcancel",n),i.removeEventListener("animationend",n)}}c("ANIMATION_END")},[i,c]),{isPresent:["mounted","unmountSuspended"].includes(o),ref:E.useCallback(e=>{e&&(l.current=getComputedStyle(e)),a(e)},[])}}(a),s="function"==typeof l?l({present:r.isPresent}):E.Children.only(l),o=eu(r.ref,(t=s,(i=(n=Object.getOwnPropertyDescriptor(t.props,"ref")?.get)&&"isReactWarning"in n&&n.isReactWarning)?t.ref:(i=(n=Object.getOwnPropertyDescriptor(t,"ref")?.get)&&"isReactWarning"in n&&n.isReactWarning)?t.props.ref:t.props.ref||t.ref));return"function"==typeof l||r.isPresent?E.cloneElement(s,{ref:o}):null};function nn(e){return e?.animationName||"none"}nt.displayName="Presence";var ni=new WeakMap,na=new WeakMap,nl={},nr=0,ns=function(e){return e&&(e.host||ns(e.parentNode))},no=function(e,t,n,i){var a=(Array.isArray(e)?e:[e]).map(function(e){if(t.contains(e))return e;var n=ns(e);return n&&t.contains(n)?n:(console.error("aria-hidden",e,"in not contained inside",t,". Doing nothing"),null)}).filter(function(e){return!!e});nl[n]||(nl[n]=new WeakMap);var l=nl[n],r=[],s=new Set,o=new Set(a),c=function(e){!e||s.has(e)||(s.add(e),c(e.parentNode))};a.forEach(c);var d=function(e){!e||o.has(e)||Array.prototype.forEach.call(e.children,function(e){if(s.has(e))d(e);else try{var t=e.getAttribute(i),a=null!==t&&"false"!==t,o=(ni.get(e)||0)+1,c=(l.get(e)||0)+1;ni.set(e,o),l.set(e,c),r.push(e),1===o&&a&&na.set(e,!0),1===c&&e.setAttribute(n,"true"),a||e.setAttribute(i,"true")}catch(t){console.error("aria-hidden: cannot operate on ",e,t)}})};return d(t),s.clear(),nr++,function(){r.forEach(function(e){var t=ni.get(e)-1,a=l.get(e)-1;ni.set(e,t),l.set(e,a),t||(na.has(e)||e.removeAttribute(i),na.delete(e)),a||e.removeAttribute(n)}),--nr||(ni=new WeakMap,ni=new WeakMap,na=new WeakMap,nl={})}},nc=function(e,t,n){void 0===n&&(n="data-aria-hidden");var i=Array.from(Array.isArray(e)?e:[e]),a=t||("u"<typeof document?null:(Array.isArray(e)?e[0]:e).ownerDocument.body);return a?(i.push.apply(i,Array.from(a.querySelectorAll("[aria-live], script"))),no(i,a,n,"aria-hidden")):function(){return null}},nd=function(){return(nd=Object.assign||function(e){for(var t,n=1,i=arguments.length;n<i;n++)for(var a in t=arguments[n])Object.prototype.hasOwnProperty.call(t,a)&&(e[a]=t[a]);return e}).apply(this,arguments)};function nh(e,t){var n={};for(var i in e)Object.prototype.hasOwnProperty.call(e,i)&&0>t.indexOf(i)&&(n[i]=e[i]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols)for(var a=0,i=Object.getOwnPropertySymbols(e);a<i.length;a++)0>t.indexOf(i[a])&&Object.prototype.propertyIsEnumerable.call(e,i[a])&&(n[i[a]]=e[i[a]]);return n}var nu=("function"==typeof SuppressedError&&SuppressedError,"right-scroll-bar-position"),np="width-before-scroll-bar";function nm(e,t){return"function"==typeof e?e(t):e&&(e.current=t),e}var ng="u">typeof window?E.useLayoutEffect:E.useEffect,nf=new WeakMap,nb=(void 0===a&&(a={}),(void 0===l&&(l=function(e){return e}),r=[],s=!1,o={read:function(){if(s)throw Error("Sidecar: could not `read` from an `assigned` medium. `read` could be used only with `useMedium`.");return r.length?r[r.length-1]:null},useMedium:function(e){var t=l(e,s);return r.push(t),function(){r=r.filter(function(e){return e!==t})}},assignSyncMedium:function(e){for(s=!0;r.length;){var t=r;r=[],t.forEach(e)}r={push:function(t){return e(t)},filter:function(){return r}}},assignMedium:function(e){s=!0;var t=[];if(r.length){var n=r;r=[],n.forEach(e),t=r}var i=function(){var n=t;t=[],n.forEach(e)},a=function(){return Promise.resolve().then(i)};a(),r={push:function(e){t.push(e),a()},filter:function(e){return t=t.filter(e),r}}}}).options=nd({async:!0,ssr:!1},a),o),nv=function(){},ny=E.forwardRef(function(e,t){var n,i,a,l,r=E.useRef(null),s=E.useState({onScrollCapture:nv,onWheelCapture:nv,onTouchMoveCapture:nv}),o=s[0],c=s[1],d=e.forwardProps,h=e.children,u=e.className,p=e.removeScrollBar,m=e.enabled,g=e.shards,f=e.sideCar,b=e.noRelative,v=e.noIsolation,y=e.inert,x=e.allowPinchZoom,w=e.as,S=e.gapMode,C=nh(e,["forwardProps","children","className","removeScrollBar","enabled","shards","sideCar","noRelative","noIsolation","inert","allowPinchZoom","as","gapMode"]),k=(n=[r,t],i=function(e){return n.forEach(function(t){return nm(t,e)})},(a=(0,E.useState)(function(){return{value:null,callback:i,facade:{get current(){return a.value},set current(value){var e=a.value;e!==value&&(a.value=value,a.callback(value,e))}}}})[0]).callback=i,l=a.facade,ng(function(){var e=nf.get(l);if(e){var t=new Set(e),i=new Set(n),a=l.current;t.forEach(function(e){i.has(e)||nm(e,null)}),i.forEach(function(e){t.has(e)||nm(e,a)})}nf.set(l,n)},[n]),l),I=nd(nd({},C),o);return E.createElement(E.Fragment,null,m&&E.createElement(f,{sideCar:nb,removeScrollBar:p,shards:g,noRelative:b,noIsolation:v,inert:y,setCallbacks:c,allowPinchZoom:!!x,lockRef:r,gapMode:S}),d?E.cloneElement(E.Children.only(h),nd(nd({},I),{ref:k})):E.createElement(void 0===w?"div":w,nd({},I,{className:u,ref:k}),h))});ny.defaultProps={enabled:!0,removeScrollBar:!0,inert:!1},ny.classNames={fullWidth:np,zeroRight:nu};var nE=function(e){var t=e.sideCar,n=nh(e,["sideCar"]);if(!t)throw Error("Sidecar: please provide `sideCar` property to import the right car");var i=t.read();if(!i)throw Error("Sidecar medium not found");return E.createElement(i,nd({},n))};nE.isSideCarExport=!0;var nx=function(){var e=0,t=null;return{add:function(n){if(0==e&&(t=function(){if(!document)return null;var e=document.createElement("style");e.type="text/css";var t=h||("u">typeof __webpack_nonce__?__webpack_nonce__:void 0);return t&&e.setAttribute("nonce",t),e}())){var i,a;(i=t).styleSheet?i.styleSheet.cssText=n:i.appendChild(document.createTextNode(n)),a=t,(document.head||document.getElementsByTagName("head")[0]).appendChild(a)}e++},remove:function(){--e||!t||(t.parentNode&&t.parentNode.removeChild(t),t=null)}}},nw=function(){var e=nx();return function(t,n){E.useEffect(function(){return e.add(t),function(){e.remove()}},[t&&n])}},nS=function(){var e=nw();return function(t){return e(t.styles,t.dynamic),null}},nC={left:0,top:0,right:0,gap:0},nk=function(e){return parseInt(e||"",10)||0},nI=function(e){var t=window.getComputedStyle(document.body),n=t["padding"===e?"paddingLeft":"marginLeft"],i=t["padding"===e?"paddingTop":"marginTop"],a=t["padding"===e?"paddingRight":"marginRight"];return[nk(n),nk(i),nk(a)]},nj=function(e){if(void 0===e&&(e="margin"),"u"<typeof window)return nC;var t=nI(e),n=document.documentElement.clientWidth,i=window.innerWidth;return{left:t[0],top:t[1],right:t[2],gap:Math.max(0,i-n+t[2]-t[0])}},nT=nS(),nM="data-scroll-locked",nL=function(e,t,n,i){var a=e.left,l=e.top,r=e.right,s=e.gap;return void 0===n&&(n="margin"),"\n .".concat("with-scroll-bars-hidden"," {\n overflow: hidden ").concat(i,";\n padding-right: ").concat(s,"px ").concat(i,";\n }\n body[").concat(nM,"] {\n overflow: hidden ").concat(i,";\n overscroll-behavior: contain;\n ").concat([t&&"position: relative ".concat(i,";"),"margin"===n&&"\n padding-left: ".concat(a,"px;\n padding-top: ").concat(l,"px;\n padding-right: ").concat(r,"px;\n margin-left:0;\n margin-top:0;\n margin-right: ").concat(s,"px ").concat(i,";\n "),"padding"===n&&"padding-right: ".concat(s,"px ").concat(i,";")].filter(Boolean).join(""),"\n }\n \n .").concat(nu," {\n right: ").concat(s,"px ").concat(i,";\n }\n \n .").concat(np," {\n margin-right: ").concat(s,"px ").concat(i,";\n }\n \n .").concat(nu," .").concat(nu," {\n right: 0 ").concat(i,";\n }\n \n .").concat(np," .").concat(np," {\n margin-right: 0 ").concat(i,";\n }\n \n body[").concat(nM,"] {\n ").concat("--removed-body-scroll-bar-size",": ").concat(s,"px;\n }\n")},nD=function(){var e=parseInt(document.body.getAttribute(nM)||"0",10);return isFinite(e)?e:0},nN=function(){E.useEffect(function(){return document.body.setAttribute(nM,(nD()+1).toString()),function(){var e=nD()-1;e<=0?document.body.removeAttribute(nM):document.body.setAttribute(nM,e.toString())}},[])},nA=function(e){var t=e.noRelative,n=e.noImportant,i=e.gapMode,a=void 0===i?"margin":i;nN();var l=E.useMemo(function(){return nj(a)},[a]);return E.createElement(nT,{styles:nL(l,!t,a,n?"":"!important")})},nP=!1;if("u">typeof window)try{var nR=Object.defineProperty({},"passive",{get:function(){return nP=!0,!0}});window.addEventListener("test",nR,nR),window.removeEventListener("test",nR,nR)}catch(e){nP=!1}var n_=!!nP&&{passive:!1},nO=function(e,t){if(!(e instanceof Element))return!1;var n=window.getComputedStyle(e);return"hidden"!==n[t]&&(n.overflowY!==n.overflowX||"TEXTAREA"===e.tagName||"visible"!==n[t])},nF=function(e,t){var n=t.ownerDocument,i=t;do{if("u">typeof ShadowRoot&&i instanceof ShadowRoot&&(i=i.host),nz(e,i)){var a=nU(e,i);if(a[1]>a[2])return!0}i=i.parentNode}while(i&&i!==n.body)return!1},nz=function(e,t){return"v"===e?nO(t,"overflowY"):nO(t,"overflowX")},nU=function(e,t){return"v"===e?[t.scrollTop,t.scrollHeight,t.clientHeight]:[t.scrollLeft,t.scrollWidth,t.clientWidth]},nB=function(e,t,n,i,a){var l,r=(l=window.getComputedStyle(t).direction,"h"===e&&"rtl"===l?-1:1),s=r*i,o=n.target,c=t.contains(o),d=!1,h=s>0,u=0,p=0;do{if(!o)break;var m=nU(e,o),g=m[0],f=m[1]-m[2]-r*g;(g||f)&&nz(e,o)&&(u+=f,p+=g);var b=o.parentNode;o=b&&b.nodeType===Node.DOCUMENT_FRAGMENT_NODE?b.host:b}while(!c&&o!==document.body||c&&(t.contains(o)||t===o))return h&&(a&&1>Math.abs(u)||!a&&s>u)?d=!0:!h&&(a&&1>Math.abs(p)||!a&&-s>p)&&(d=!0),d},nW=function(e){return"changedTouches"in e?[e.changedTouches[0].clientX,e.changedTouches[0].clientY]:[0,0]},nH=function(e){return[e.deltaX,e.deltaY]},n$=function(e){return e&&"current"in e?e.current:e},nY=0,nV=[];let nG=(c=function(e){var t=E.useRef([]),n=E.useRef([0,0]),i=E.useRef(),a=E.useState(nY++)[0],l=E.useState(nS)[0],r=E.useRef(e);E.useEffect(function(){r.current=e},[e]),E.useEffect(function(){if(e.inert){document.body.classList.add("block-interactivity-".concat(a));var t=(function(e,t,n){if(n||2==arguments.length)for(var i,a=0,l=t.length;a<l;a++)!i&&a in t||(i||(i=Array.prototype.slice.call(t,0,a)),i[a]=t[a]);return e.concat(i||Array.prototype.slice.call(t))})([e.lockRef.current],(e.shards||[]).map(n$),!0).filter(Boolean);return t.forEach(function(e){return e.classList.add("allow-interactivity-".concat(a))}),function(){document.body.classList.remove("block-interactivity-".concat(a)),t.forEach(function(e){return e.classList.remove("allow-interactivity-".concat(a))})}}},[e.inert,e.lockRef.current,e.shards]);var s=E.useCallback(function(e,t){if("touches"in e&&2===e.touches.length||"wheel"===e.type&&e.ctrlKey)return!r.current.allowPinchZoom;var a,l=nW(e),s=n.current,o="deltaX"in e?e.deltaX:s[0]-l[0],c="deltaY"in e?e.deltaY:s[1]-l[1],d=e.target,h=Math.abs(o)>Math.abs(c)?"h":"v";if("touches"in e&&"h"===h&&"range"===d.type)return!1;var u=window.getSelection(),p=u&&u.anchorNode;if(p&&(p===d||p.contains(d)))return!1;var m=nF(h,d);if(!m)return!0;if(m?a=h:(a="v"===h?"h":"v",m=nF(h,d)),!m)return!1;if(!i.current&&"changedTouches"in e&&(o||c)&&(i.current=a),!a)return!0;var g=i.current||a;return nB(g,t,e,"h"===g?o:c,!0)},[]),o=E.useCallback(function(e){if(nV.length&&nV[nV.length-1]===l){var n="deltaY"in e?nH(e):nW(e),i=t.current.filter(function(t){var i;return t.name===e.type&&(t.target===e.target||e.target===t.shadowParent)&&(i=t.delta,i[0]===n[0]&&i[1]===n[1])})[0];if(i&&i.should){e.cancelable&&e.preventDefault();return}if(!i){var a=(r.current.shards||[]).map(n$).filter(Boolean).filter(function(t){return t.contains(e.target)});(a.length>0?s(e,a[0]):!r.current.noIsolation)&&e.cancelable&&e.preventDefault()}}},[]),c=E.useCallback(function(e,n,i,a){var l={name:e,delta:n,target:i,should:a,shadowParent:function(e){for(var t=null;null!==e;)e instanceof ShadowRoot&&(t=e.host,e=e.host),e=e.parentNode;return t}(i)};t.current.push(l),setTimeout(function(){t.current=t.current.filter(function(e){return e!==l})},1)},[]),d=E.useCallback(function(e){n.current=nW(e),i.current=void 0},[]),h=E.useCallback(function(t){c(t.type,nH(t),t.target,s(t,e.lockRef.current))},[]),u=E.useCallback(function(t){c(t.type,nW(t),t.target,s(t,e.lockRef.current))},[]);E.useEffect(function(){return nV.push(l),e.setCallbacks({onScrollCapture:h,onWheelCapture:h,onTouchMoveCapture:u}),document.addEventListener("wheel",o,n_),document.addEventListener("touchmove",o,n_),document.addEventListener("touchstart",d,n_),function(){nV=nV.filter(function(e){return e!==l}),document.removeEventListener("wheel",o,n_),document.removeEventListener("touchmove",o,n_),document.removeEventListener("touchstart",d,n_)}},[]);var p=e.removeScrollBar,m=e.inert;return E.createElement(E.Fragment,null,m?E.createElement(l,{styles:"\n .block-interactivity-".concat(a," {pointer-events: none;}\n .allow-interactivity-").concat(a," {pointer-events: all;}\n")}):null,p?E.createElement(nA,{noRelative:e.noRelative,gapMode:e.gapMode}):null)},nb.useMedium(c),nE);var nK=E.forwardRef(function(e,t){return E.createElement(ny,nd({},e,{ref:t,sideCar:nG}))});nK.classNames=ny.classNames;var nZ="Popover",[nX,nQ]=ep(nZ,[tK]),nq=tK(),[nJ,n0]=nX(nZ),n1=e=>{let{__scopePopover:t,children:n,open:i,defaultOpen:a,onOpenChange:l,modal:r=!1}=e,s=nq(t),o=E.useRef(null),[c,d]=E.useState(!1),[h=!1,u]=function({prop:e,defaultProp:t,onChange:n=()=>{}}){let[i,a]=function({defaultProp:e,onChange:t}){let n=E.useState(e),[i]=n,a=E.useRef(i),l=ey(t);return E.useEffect(()=>{a.current!==i&&(l(i),a.current=i)},[i,a,l]),n}({defaultProp:t,onChange:n}),l=void 0!==e,r=l?e:i,s=ey(n);return[r,E.useCallback(t=>{if(l){let n="function"==typeof t?t(e):t;n!==e&&s(n)}else a(t)},[l,e,a,s])]}({prop:i,defaultProp:a,onChange:l});return(0,W.jsx)(tQ,{...s,children:(0,W.jsx)(nJ,{scope:t,contentId:function(){let[e,t]=E.useState(eO());return e_(()=>{t(e=>e??String(eF++))},[void 0]),e?`radix-${e}`:""}(),triggerRef:o,open:h,onOpenChange:u,onOpenToggle:E.useCallback(()=>u(e=>!e),[u]),hasCustomAnchor:c,onCustomAnchorAdd:E.useCallback(()=>d(!0),[]),onCustomAnchorRemove:E.useCallback(()=>d(!1),[]),modal:r,children:n})})};n1.displayName=nZ;var n2="PopoverAnchor";E.forwardRef((e,t)=>{let{__scopePopover:n,...i}=e,a=n0(n2,n),l=nq(n),{onCustomAnchorAdd:r,onCustomAnchorRemove:s}=a;return E.useEffect(()=>(r(),()=>s()),[r,s]),(0,W.jsx)(tJ,{...l,...i,ref:t})}).displayName=n2;var n3="PopoverTrigger",n5=E.forwardRef((e,t)=>{let{__scopePopover:n,...i}=e,a=n0(n3,n),l=nq(n),r=eu(t,a.triggerRef),s=(0,W.jsx)(ev.button,{type:"button","aria-haspopup":"dialog","aria-expanded":a.open,"aria-controls":a.contentId,"data-state":is(a.open),...i,ref:r,onClick:ec(e.onClick,a.onOpenToggle)});return a.hasCustomAnchor?s:(0,W.jsx)(tJ,{asChild:!0,...l,children:s})});n5.displayName=n3;var n4="PopoverPortal",[n6,n8]=nX(n4,{forceMount:void 0}),n7=e=>{let{__scopePopover:t,forceMount:n,children:i,container:a}=e,l=n0(n4,t);return(0,W.jsx)(n6,{scope:t,forceMount:n,children:(0,W.jsx)(nt,{present:n||l.open,children:(0,W.jsx)(ne,{asChild:!0,container:a,children:i})})})};n7.displayName=n4;var n9="PopoverContent",ie=E.forwardRef((e,t)=>{let n=n8(n9,e.__scopePopover),{forceMount:i=n.forceMount,...a}=e,l=n0(n9,e.__scopePopover);return(0,W.jsx)(nt,{present:i||l.open,children:l.modal?(0,W.jsx)(it,{...a,ref:t}):(0,W.jsx)(ii,{...a,ref:t})})});ie.displayName=n9;var it=E.forwardRef((e,t)=>{let n=n0(n9,e.__scopePopover),i=E.useRef(null),a=eu(t,i),l=E.useRef(!1);return E.useEffect(()=>{let e=i.current;if(e)return nc(e)},[]),(0,W.jsx)(nK,{as:em,allowPinchZoom:!0,children:(0,W.jsx)(ia,{...e,ref:a,trapFocus:n.open,disableOutsidePointerEvents:!0,onCloseAutoFocus:ec(e.onCloseAutoFocus,e=>{e.preventDefault(),l.current||n.triggerRef.current?.focus()}),onPointerDownOutside:ec(e.onPointerDownOutside,e=>{let t=e.detail.originalEvent,n=0===t.button&&!0===t.ctrlKey;l.current=2===t.button||n},{checkForDefaultPrevented:!1}),onFocusOutside:ec(e.onFocusOutside,e=>e.preventDefault(),{checkForDefaultPrevented:!1})})})}),ii=E.forwardRef((e,t)=>{let n=n0(n9,e.__scopePopover),i=E.useRef(!1),a=E.useRef(!1);return(0,W.jsx)(ia,{...e,ref:t,trapFocus:!1,disableOutsidePointerEvents:!1,onCloseAutoFocus:t=>{e.onCloseAutoFocus?.(t),t.defaultPrevented||(i.current||n.triggerRef.current?.focus(),t.preventDefault()),i.current=!1,a.current=!1},onInteractOutside:t=>{e.onInteractOutside?.(t),t.defaultPrevented||(i.current=!0,"pointerdown"===t.detail.originalEvent.type&&(a.current=!0));let l=t.target;n.triggerRef.current?.contains(l)&&t.preventDefault(),"focusin"===t.detail.originalEvent.type&&a.current&&t.preventDefault()}})}),ia=E.forwardRef((e,t)=>{let{__scopePopover:n,trapFocus:i,onOpenAutoFocus:a,onCloseAutoFocus:l,disableOutsidePointerEvents:r,onEscapeKeyDown:s,onPointerDownOutside:o,onFocusOutside:c,onInteractOutside:d,...h}=e,u=n0(n9,n),p=nq(n);return E.useEffect(()=>{let e=document.querySelectorAll("[data-radix-focus-guard]");return document.body.insertAdjacentElement("afterbegin",e[0]??eI()),document.body.insertAdjacentElement("beforeend",e[1]??eI()),ek++,()=>{1===ek&&document.querySelectorAll("[data-radix-focus-guard]").forEach(e=>e.remove()),ek--}},[]),(0,W.jsx)(eL,{asChild:!0,loop:!0,trapped:i,onMountAutoFocus:a,onUnmountAutoFocus:l,children:(0,W.jsx)(ew,{asChild:!0,disableOutsidePointerEvents:r,onInteractOutside:d,onEscapeKeyDown:s,onPointerDownOutside:o,onFocusOutside:c,onDismiss:()=>u.onOpenChange(!1),children:(0,W.jsx)(t3,{"data-state":is(u.open),role:"dialog",id:u.contentId,...p,...h,ref:t,style:{...h.style,"--radix-popover-content-transform-origin":"var(--radix-popper-transform-origin)","--radix-popover-content-available-width":"var(--radix-popper-available-width)","--radix-popover-content-available-height":"var(--radix-popper-available-height)","--radix-popover-trigger-width":"var(--radix-popper-anchor-width)","--radix-popover-trigger-height":"var(--radix-popper-anchor-height)"}})})})}),il="PopoverClose";E.forwardRef((e,t)=>{let{__scopePopover:n,...i}=e,a=n0(il,n);return(0,W.jsx)(ev.button,{type:"button",...i,ref:t,onClick:ec(e.onClick,()=>a.onOpenChange(!1))})}).displayName=il;var ir=E.forwardRef((e,t)=>{let{__scopePopover:n,...i}=e,a=nq(n);return(0,W.jsx)(t6,{...a,...i,ref:t})});function is(e){return e?"open":"closed"}ir.displayName="PopoverArrow";var io=e.i(11660),ic=e.i(54479),id=e.i(22125);let ih={get url(){return`file://${e.P("node_modules/zustand/esm/vanilla.mjs")}`}},iu=e=>{let t,n=new Set,i=(e,i)=>{let a="function"==typeof e?e(t):e;if(!Object.is(a,t)){let e=t;t=(null!=i?i:"object"!=typeof a||null===a)?a:Object.assign({},t,a),n.forEach(n=>n(t,e))}},a=()=>t,l={setState:i,getState:a,getInitialState:()=>r,subscribe:e=>(n.add(e),()=>n.delete(e)),destroy:()=>{(ih.env?ih.env.MODE:void 0)!=="production"&&console.warn("[DEPRECATED] The `destroy` method will be unsupported in a future version. Instead use unsubscribe function returned by subscribe. Everything will be garbage-collected if store is garbage-collected."),n.clear()}},r=t=e(i,a,l);return l};var ip=e.i(30224);let im={get url(){return`file://${e.P("node_modules/zustand/esm/index.mjs")}`}},{useDebugValue:ig}=E.default,{useSyncExternalStoreWithSelector:ib}=ip.default,iv=!1,iy=e=>{(im.env?im.env.MODE:void 0)!=="production"&&"function"!=typeof e&&console.warn("[DEPRECATED] Passing a vanilla store will be unsupported in a future version. Instead use `import { useStore } from 'zustand'`.");let t="function"==typeof e?e?iu(e):iu:e,n=(e,n)=>(function(e,t=e=>e,n){(im.env?im.env.MODE:void 0)!=="production"&&n&&!iv&&(console.warn("[DEPRECATED] Use `createWithEqualityFn` instead of `create` or use `useStoreWithEqualityFn` instead of `useStore`. They can be imported from 'zustand/traditional'. https://github.com/pmndrs/zustand/discussions/1937"),iv=!0);let i=ib(e.subscribe,e.getState,e.getServerState||e.getInitialState,t,n);return ig(i),i})(t,e,n);return Object.assign(n,t),n},iE="u">typeof window&&(null!=(u=window.document)&&u.createElement||(null==(p=window.navigator)?void 0:p.product)==="ReactNative")?E.default.useLayoutEffect:E.default.useEffect;function ix(){let e,t=(e=e=>({current:[],version:0,set:e}))?iy(e):iy;return{In:({children:e})=>{let n=t(e=>e.set),i=t(e=>e.version);return iE(()=>{n(e=>({version:e.version+1}))},[]),iE(()=>(n(({current:t})=>({current:[...t,e]})),()=>n(({current:t})=>({current:t.filter(t=>t!==e)}))),[e,i]),null},Out:()=>{let e=t(e=>e.current);return E.default.createElement(E.default.Fragment,null,e)}}}function iw(){return(iw=Object.assign.bind()).apply(null,arguments)}function iS(e,t,{checkForDefaultPrevented:n=!0}={}){return function(i){if(null==e||e(i),!1===n||!i.defaultPrevented)return null==t?void 0:t(i)}}function iC(e,t=[]){let n=[],i=()=>{let t=n.map(e=>(0,E.createContext)(e));return function(n){let i=(null==n?void 0:n[e])||t;return(0,E.useMemo)(()=>({[`__scope${e}`]:{...n,[e]:i}}),[n,i])}};return i.scopeName=e,[function(t,i){let a=(0,E.createContext)(i),l=n.length;function r(t){let{scope:n,children:i,...r}=t,s=(null==n?void 0:n[e][l])||a,o=(0,E.useMemo)(()=>r,Object.values(r));return(0,E.createElement)(s.Provider,{value:o},i)}return n=[...n,i],r.displayName=t+"Provider",[r,function(n,r){let s=(null==r?void 0:r[e][l])||a,o=(0,E.useContext)(s);if(o)return o;if(void 0!==i)return i;throw Error(`\`${n}\` must be used within \`${t}\``)}]},function(...e){let t=e[0];if(1===e.length)return t;let n=()=>{let n=e.map(e=>({useScope:e(),scopeName:e.scopeName}));return function(e){let i=n.reduce((t,{useScope:n,scopeName:i})=>{let a=n(e)[`__scope${i}`];return{...t,...a}},{});return(0,E.useMemo)(()=>({[`__scope${t.scopeName}`]:i}),[i])}};return n.scopeName=t.scopeName,n}(i,...t)]}function ik(...e){return t=>e.forEach(e=>{"function"==typeof e?e(t):null!=e&&(e.current=t)})}function iI(...e){return(0,E.useCallback)(ik(...e),e)}let ij=(0,E.forwardRef)((e,t)=>{let{children:n,...i}=e,a=E.Children.toArray(n),l=a.find(iL);if(l){let e=l.props.children,n=a.map(t=>t!==l?t:E.Children.count(e)>1?E.Children.only(null):(0,E.isValidElement)(e)?e.props.children:null);return(0,E.createElement)(iT,iw({},i,{ref:t}),(0,E.isValidElement)(e)?(0,E.cloneElement)(e,void 0,n):null)}return(0,E.createElement)(iT,iw({},i,{ref:t}),n)});ij.displayName="Slot";let iT=(0,E.forwardRef)((e,t)=>{let{children:n,...i}=e;return(0,E.isValidElement)(n)?(0,E.cloneElement)(n,{...function(e,t){let n={...t};for(let i in t){let a=e[i],l=t[i];/^on[A-Z]/.test(i)?a&&l?n[i]=(...e)=>{l(...e),a(...e)}:a&&(n[i]=a):"style"===i?n[i]={...a,...l}:"className"===i&&(n[i]=[a,l].filter(Boolean).join(" "))}return{...e,...n}}(i,n.props),ref:ik(t,n.ref)}):E.Children.count(n)>1?E.Children.only(null):null});iT.displayName="SlotClone";let iM=({children:e})=>(0,E.createElement)(E.Fragment,null,e);function iL(e){return(0,E.isValidElement)(e)&&e.type===iM}let iD=(null==globalThis?void 0:globalThis.document)?E.useLayoutEffect:()=>{},iN=E["useId".toString()]||(()=>void 0),iA=0;function iP(e){let[t,n]=E.useState(iN());return iD(()=>{e||n(e=>null!=e?e:String(iA++))},[e]),e||(t?`radix-${t}`:"")}let iR=(0,E.forwardRef)((e,t)=>{let{children:n,...i}=e,a=E.Children.toArray(n),l=a.find(iF);if(l){let e=l.props.children,n=a.map(t=>t!==l?t:E.Children.count(e)>1?E.Children.only(null):(0,E.isValidElement)(e)?e.props.children:null);return(0,E.createElement)(i_,iw({},i,{ref:t}),(0,E.isValidElement)(e)?(0,E.cloneElement)(e,void 0,n):null)}return(0,E.createElement)(i_,iw({},i,{ref:t}),n)});iR.displayName="Slot";let i_=(0,E.forwardRef)((e,t)=>{let{children:n,...i}=e;return(0,E.isValidElement)(n)?(0,E.cloneElement)(n,{...function(e,t){let n={...t};for(let i in t){let a=e[i],l=t[i];/^on[A-Z]/.test(i)?a&&l?n[i]=(...e)=>{l(...e),a(...e)}:a&&(n[i]=a):"style"===i?n[i]={...a,...l}:"className"===i&&(n[i]=[a,l].filter(Boolean).join(" "))}return{...e,...n}}(i,n.props),ref:function(...e){return t=>e.forEach(e=>{"function"==typeof e?e(t):null!=e&&(e.current=t)})}(t,n.ref)}):E.Children.count(n)>1?E.Children.only(null):null});i_.displayName="SlotClone";let iO=({children:e})=>(0,E.createElement)(E.Fragment,null,e);function iF(e){return(0,E.isValidElement)(e)&&e.type===iO}let iz=["a","button","div","h2","h3","img","label","li","nav","ol","p","span","svg","ul"].reduce((e,t)=>{let n=(0,E.forwardRef)((e,n)=>{let{asChild:i,...a}=e,l=i?iR:t;return(0,E.useEffect)(()=>{window[Symbol.for("radix-ui")]=!0},[]),(0,E.createElement)(l,iw({},a,{ref:n}))});return n.displayName=`Primitive.${t}`,{...e,[t]:n}},{});function iU(e){let t=(0,E.useRef)(e);return(0,E.useEffect)(()=>{t.current=e}),(0,E.useMemo)(()=>(...e)=>{var n;return null==(n=t.current)?void 0:n.call(t,...e)},[])}function iB({prop:e,defaultProp:t,onChange:n=()=>{}}){let[i,a]=function({defaultProp:e,onChange:t}){let n=(0,E.useState)(e),[i]=n,a=(0,E.useRef)(i),l=iU(t);return(0,E.useEffect)(()=>{a.current!==i&&(l(i),a.current=i)},[i,a,l]),n}({defaultProp:t,onChange:n}),l=void 0!==e,r=l?e:i,s=iU(n);return[r,(0,E.useCallback)(t=>{if(l){let n="function"==typeof t?t(e):t;n!==e&&s(n)}else a(t)},[l,e,a,s])]}let iW=(0,E.createContext)(void 0);function iH(e){let t=(0,E.useContext)(iW);return e||t||"ltr"}let i$="rovingFocusGroup.onEntryFocus",iY={bubbles:!1,cancelable:!0},iV="RovingFocusGroup",[iG,iK,iZ]=function(e){let t=e+"CollectionProvider",[n,i]=iC(t),[a,l]=n(t,{collectionRef:{current:null},itemMap:new Map}),r=e+"CollectionSlot",s=E.default.forwardRef((e,t)=>{let{scope:n,children:i}=e,a=iI(t,l(r,n).collectionRef);return E.default.createElement(ij,{ref:a},i)}),o=e+"CollectionItemSlot",c="data-radix-collection-item";return[{Provider:e=>{let{scope:t,children:n}=e,i=E.default.useRef(null),l=E.default.useRef(new Map).current;return E.default.createElement(a,{scope:t,itemMap:l,collectionRef:i},n)},Slot:s,ItemSlot:E.default.forwardRef((e,t)=>{let{scope:n,children:i,...a}=e,r=E.default.useRef(null),s=iI(t,r),d=l(o,n);return E.default.useEffect(()=>(d.itemMap.set(r,{ref:r,...a}),()=>void d.itemMap.delete(r))),E.default.createElement(ij,{[c]:"",ref:s},i)})},function(t){let n=l(e+"CollectionConsumer",t);return E.default.useCallback(()=>{let e=n.collectionRef.current;if(!e)return[];let t=Array.from(e.querySelectorAll(`[${c}]`));return Array.from(n.itemMap.values()).sort((e,n)=>t.indexOf(e.ref.current)-t.indexOf(n.ref.current))},[n.collectionRef,n.itemMap])},i]}(iV),[iX,iQ]=iC(iV,[iZ]),[iq,iJ]=iX(iV),i0=(0,E.forwardRef)((e,t)=>(0,E.createElement)(iG.Provider,{scope:e.__scopeRovingFocusGroup},(0,E.createElement)(iG.Slot,{scope:e.__scopeRovingFocusGroup},(0,E.createElement)(i1,iw({},e,{ref:t}))))),i1=(0,E.forwardRef)((e,t)=>{let n,{__scopeRovingFocusGroup:i,orientation:a,loop:l=!1,dir:r,currentTabStopId:s,defaultCurrentTabStopId:o,onCurrentTabStopIdChange:c,onEntryFocus:d,...h}=e,u=(0,E.useRef)(null),p=iI(t,u),m=iH(r),[g=null,f]=iB({prop:s,defaultProp:o,onChange:c}),[b,v]=(0,E.useState)(!1),y=(n=(0,E.useRef)(d),(0,E.useEffect)(()=>{n.current=d}),(0,E.useMemo)(()=>(...e)=>{var t;return null==(t=n.current)?void 0:t.call(n,...e)},[])),x=iK(i),w=(0,E.useRef)(!1),[S,C]=(0,E.useState)(0);return(0,E.useEffect)(()=>{let e=u.current;if(e)return e.addEventListener(i$,y),()=>e.removeEventListener(i$,y)},[y]),(0,E.createElement)(iq,{scope:i,orientation:a,dir:m,loop:l,currentTabStopId:g,onItemFocus:(0,E.useCallback)(e=>f(e),[f]),onItemShiftTab:(0,E.useCallback)(()=>v(!0),[]),onFocusableItemAdd:(0,E.useCallback)(()=>C(e=>e+1),[]),onFocusableItemRemove:(0,E.useCallback)(()=>C(e=>e-1),[])},(0,E.createElement)(iz.div,iw({tabIndex:b||0===S?-1:0,"data-orientation":a},h,{ref:p,style:{outline:"none",...e.style},onMouseDown:iS(e.onMouseDown,()=>{w.current=!0}),onFocus:iS(e.onFocus,e=>{let t=!w.current;if(e.target===e.currentTarget&&t&&!b){let t=new CustomEvent(i$,iY);if(e.currentTarget.dispatchEvent(t),!t.defaultPrevented){let e=x().filter(e=>e.focusable);i5([e.find(e=>e.active),e.find(e=>e.id===g),...e].filter(Boolean).map(e=>e.ref.current))}}w.current=!1}),onBlur:iS(e.onBlur,()=>v(!1))})))}),i2=(0,E.forwardRef)((e,t)=>{let{__scopeRovingFocusGroup:n,focusable:i=!0,active:a=!1,tabStopId:l,...r}=e,s=iP(),o=l||s,c=iJ("RovingFocusGroupItem",n),d=c.currentTabStopId===o,h=iK(n),{onFocusableItemAdd:u,onFocusableItemRemove:p}=c;return(0,E.useEffect)(()=>{if(i)return u(),()=>p()},[i,u,p]),(0,E.createElement)(iG.ItemSlot,{scope:n,id:o,focusable:i,active:a},(0,E.createElement)(iz.span,iw({tabIndex:d?0:-1,"data-orientation":c.orientation},r,{ref:t,onMouseDown:iS(e.onMouseDown,e=>{i?c.onItemFocus(o):e.preventDefault()}),onFocus:iS(e.onFocus,()=>c.onItemFocus(o)),onKeyDown:iS(e.onKeyDown,e=>{if("Tab"===e.key&&e.shiftKey)return void c.onItemShiftTab();if(e.target!==e.currentTarget)return;let t=function(e,t,n){var i;let a=(i=e.key,"rtl"!==n?i:"ArrowLeft"===i?"ArrowRight":"ArrowRight"===i?"ArrowLeft":i);if(!("vertical"===t&&["ArrowLeft","ArrowRight"].includes(a))&&!("horizontal"===t&&["ArrowUp","ArrowDown"].includes(a)))return i3[a]}(e,c.orientation,c.dir);if(void 0!==t){e.preventDefault();let a=h().filter(e=>e.focusable).map(e=>e.ref.current);if("last"===t)a.reverse();else if("prev"===t||"next"===t){var n,i;"prev"===t&&a.reverse();let l=a.indexOf(e.currentTarget);a=c.loop?(n=a,i=l+1,n.map((e,t)=>n[(i+t)%n.length])):a.slice(l+1)}setTimeout(()=>i5(a))}})})))}),i3={ArrowLeft:"prev",ArrowUp:"prev",ArrowRight:"next",ArrowDown:"next",PageUp:"first",Home:"first",PageDown:"last",End:"last"};function i5(e){let t=document.activeElement;for(let n of e)if(n===t||(n.focus(),document.activeElement!==t))return}let i4=(null==globalThis?void 0:globalThis.document)?E.useLayoutEffect:()=>{},i6=e=>{let{present:t,children:n}=e,i=function(e){var t,n;let[i,a]=(0,E.useState)(),l=(0,E.useRef)({}),r=(0,E.useRef)(e),s=(0,E.useRef)("none"),[o,c]=(t=e?"mounted":"unmounted",n={mounted:{UNMOUNT:"unmounted",ANIMATION_OUT:"unmountSuspended"},unmountSuspended:{MOUNT:"mounted",ANIMATION_END:"unmounted"},unmounted:{MOUNT:"mounted"}},(0,E.useReducer)((e,t)=>{let i=n[e][t];return null!=i?i:e},t));return(0,E.useEffect)(()=>{let e=i8(l.current);s.current="mounted"===o?e:"none"},[o]),i4(()=>{let t=l.current,n=r.current;if(n!==e){let i=s.current,a=i8(t);e?c("MOUNT"):"none"===a||(null==t?void 0:t.display)==="none"?c("UNMOUNT"):n&&i!==a?c("ANIMATION_OUT"):c("UNMOUNT"),r.current=e}},[e,c]),i4(()=>{if(i){let e=e=>{let t=i8(l.current).includes(e.animationName);e.target===i&&t&&(0,er.flushSync)(()=>c("ANIMATION_END"))},t=e=>{e.target===i&&(s.current=i8(l.current))};return i.addEventListener("animationstart",t),i.addEventListener("animationcancel",e),i.addEventListener("animationend",e),()=>{i.removeEventListener("animationstart",t),i.removeEventListener("animationcancel",e),i.removeEventListener("animationend",e)}}c("ANIMATION_END")},[i,c]),{isPresent:["mounted","unmountSuspended"].includes(o),ref:(0,E.useCallback)(e=>{e&&(l.current=getComputedStyle(e)),a(e)},[])}}(t),a="function"==typeof n?n({present:i.isPresent}):E.Children.only(n),l=function(...e){return(0,E.useCallback)(function(...e){return t=>e.forEach(e=>{"function"==typeof e?e(t):null!=e&&(e.current=t)})}(...e),e)}(i.ref,a.ref);return"function"==typeof n||i.isPresent?(0,E.cloneElement)(a,{ref:l}):null};function i8(e){return(null==e?void 0:e.animationName)||"none"}i6.displayName="Presence";let i7="Tabs",[i9,ae]=iC(i7,[iQ]),at=iQ(),[an,ai]=i9(i7),aa=(0,E.forwardRef)((e,t)=>{let{__scopeTabs:n,value:i,onValueChange:a,defaultValue:l,orientation:r="horizontal",dir:s,activationMode:o="automatic",...c}=e,d=iH(s),[h,u]=iB({prop:i,onChange:a,defaultProp:l});return(0,E.createElement)(an,{scope:n,baseId:iP(),value:h,onValueChange:u,orientation:r,dir:d,activationMode:o},(0,E.createElement)(iz.div,iw({dir:d,"data-orientation":r},c,{ref:t})))}),al=(0,E.forwardRef)((e,t)=>{let{__scopeTabs:n,loop:i=!0,...a}=e,l=ai("TabsList",n),r=at(n);return(0,E.createElement)(i0,iw({asChild:!0},r,{orientation:l.orientation,dir:l.dir,loop:i}),(0,E.createElement)(iz.div,iw({role:"tablist","aria-orientation":l.orientation},a,{ref:t})))}),ar=(0,E.forwardRef)((e,t)=>{let{__scopeTabs:n,value:i,disabled:a=!1,...l}=e,r=ai("TabsTrigger",n),s=at(n),o=ao(r.baseId,i),c=ac(r.baseId,i),d=i===r.value;return(0,E.createElement)(i2,iw({asChild:!0},s,{focusable:!a,active:d}),(0,E.createElement)(iz.button,iw({type:"button",role:"tab","aria-selected":d,"aria-controls":c,"data-state":d?"active":"inactive","data-disabled":a?"":void 0,disabled:a,id:o},l,{ref:t,onMouseDown:iS(e.onMouseDown,e=>{a||0!==e.button||!1!==e.ctrlKey?e.preventDefault():r.onValueChange(i)}),onKeyDown:iS(e.onKeyDown,e=>{[" ","Enter"].includes(e.key)&&r.onValueChange(i)}),onFocus:iS(e.onFocus,()=>{let e="manual"!==r.activationMode;d||a||!e||r.onValueChange(i)})})))}),as=(0,E.forwardRef)((e,t)=>{let{__scopeTabs:n,value:i,forceMount:a,children:l,...r}=e,s=ai("TabsContent",n),o=ao(s.baseId,i),c=ac(s.baseId,i),d=i===s.value,h=(0,E.useRef)(d);return(0,E.useEffect)(()=>{let e=requestAnimationFrame(()=>h.current=!1);return()=>cancelAnimationFrame(e)},[]),(0,E.createElement)(i6,{present:a||d},({present:n})=>(0,E.createElement)(iz.div,iw({"data-state":d?"active":"inactive","data-orientation":s.orientation,role:"tabpanel","aria-labelledby":o,hidden:!n,id:c,tabIndex:0},r,{ref:t,style:{...e.style,animationDuration:h.current?"0s":void 0}}),n&&l))});function ao(e,t){return`${e}-trigger-${t}`}function ac(e,t){return`${e}-content-${t}`}var ad=e.i(78333);function ah([e,t,n],[i,a,l]){return[e+i,t+a,n+l]}function au([e,t,n],[i,a,l]){return[e-i,t-a,n-l]}function ap([e,t,n],i){return[e*i,t*i,n*i]}function am([e,t,n]){return[e/Math.sqrt(e**2+t**2),t/Math.sqrt(e**2+t**2),n]}function ag([e,t,n],i){return[Math.cos(i)*e-Math.sin(i)*t,Math.sin(i)*e+Math.cos(i)*t,n]}function af(e,t,n){return Math.atan2(n[1]-e[1],n[0]-e[0])-Math.atan2(t[1]-e[1],t[0]-e[0])}function ab(e){return Math.atan2(Math.sin(e),Math.cos(e))}function av([e,t]){return Math.sqrt(e**2+t**2)}function ay([e,t],[n,i]){return Math.sqrt((n-e)**2+(i-t)**2)}function aE(e,t){if(0===t||e.length<=2)return e;let n=e[0],i=e[e.length-1],[a,l]=e.reduce(([e,t],a,l)=>{let r=function(e,t,n){let i=ay(t,n);if(0===i)return ay(e,t);let a=Math.max(0,Math.min(1,((e[0]-t[0])*(n[0]-t[0])+(e[1]-t[1])*(n[1]-t[1]))/i**2));return ay([t[0]+a*(n[0]-t[0]),t[1]+a*(n[1]-t[1]),e[2]],e)}(a,n,i);return r>e?[r,l]:[e,t]},[0,-1]);if(!(a>=t))return[n,i];{let a=e[l];return[...aE([n,...e.slice(1,l),a],t).slice(0,-1),a,...aE([a,...e.slice(l,-1),i],t).slice(1)]}}Object.defineProperty({},"LaserPointer",{get:()=>ax,set:void 0,enumerable:!0,configurable:!0});class ax{static{this.defaults={size:2,streamline:.45,simplify:.1,simplifyPhase:"output",keepHead:!1,sizeMapping:()=>1}}static{this.constants={cornerDetectionMaxAngle:75,cornerDetectionVariance:e=>e>35?.5:1,maxTailLength:50}}constructor(e){this.originalPoints=[],this.stablePoints=[],this.tailPoints=[],this.isFresh=!0,this.options=Object.assign({},ax.defaults,e)}get lastPoint(){return this.tailPoints[this.tailPoints.length-1]??this.stablePoints[this.stablePoints.length-1]}addPoint(e){let t=this.originalPoints[this.originalPoints.length-1];if(!t||t[0]!==e[0]||t[1]!==e[1]){var n,i,a;if(this.originalPoints.push(e),this.isFresh){this.isFresh=!1,this.stablePoints.push(e);return}this.options.streamline>0&&(n=this.lastPoint,i=e,a=1-this.options.streamline,e=ah(n,ap(au(i,n),a))),this.tailPoints.push(e),function(e){if(e.length<2)return 0;let t=0;for(let n=1;n<=e.length-1;n++)t+=ay(e[n-1],e[n]);return t+ay(e[e.length-2],e[e.length-1])}(this.tailPoints)>ax.constants.maxTailLength&&this.stabilizeTail()}}close(){this.stabilizeTail()}stabilizeTail(){if(this.options.simplify>0&&"tail"==this.options.simplifyPhase)throw Error("Not implemented yet");this.stablePoints.push(...this.tailPoints),this.tailPoints=[]}getSize(e,t,n,i,a){return(e??this.options.size)*this.options.sizeMapping({pressure:t,runningLength:a,currentIndex:n,totalLength:i})}getStrokeOutline(e){if(this.isFresh)return[];let t=[...this.stablePoints,...this.tailPoints];this.options.simplify>0&&"input"===this.options.simplifyPhase&&(t=aE(t,this.options.simplify));let n=t.length;if(0===n)return[];if(1===n){let i=t[0],a=this.getSize(e,i[2],0,n,0);if(a<.5)return[];let l=[];for(let e=0;e<=2*Math.PI;e+=Math.PI/16)l.push(ah(i,ap(ag([1,0,0],e),a)));return l.push(ah(i,ap([1,0,0],this.getSize(e,i[2],0,n,0)))),l}if(2===n){let i=t[0],a=t[1],l=this.getSize(e,i[2],0,n,0),r=this.getSize(e,a[2],0,n,0);if(l<.5||r<.5)return[];let s=[],o=af(i,[i[0],i[1]-100,i[2]],a);for(let e=o;e<=Math.PI+o;e+=Math.PI/16)s.push(ah(i,ap(ag([1,0,0],e),l)));for(let e=Math.PI+o;e<=2*Math.PI+o;e+=Math.PI/16)s.push(ah(a,ap(ag([1,0,0],e),r)));return s.push(s[0]),s}let i=[],a=[],l=0,r=0,s=0,o=0;for(let c=1;c<n-1;c++){let d=t[c-1],h=t[c],u=t[c+1],p=h[2],m=ay(d,h);o+=m,l=r+(m-r)*.2;let g=this.getSize(e,p,c,n,o);if(0===g){s=c+1;continue}let f=am(au(d,h)),b=am(au(u,h)),v=ag(f,Math.PI/2),y=ag(f,-Math.PI/2),E=ag(b,Math.PI/2),x=ag(b,-Math.PI/2),w=ah(h,ap(v,g)),S=ah(h,ap(y,g)),C=ah(h,ap(E,g)),k=ah(h,ap(x,g)),I=ah(v,x),j=ah(y,E),T=ah(h,ap(0===av(I)?f:am(I),g)),M=ah(h,ap(0===av(j)?b:am(j),g)),L=ab(af(h,d,u));if(Math.abs(L)<ax.constants.cornerDetectionMaxAngle/180*Math.PI*ax.constants.cornerDetectionVariance(l)){let e=Math.abs(ab(Math.PI-L));if(0===e)continue;if(L<0){a.push(S,M);for(let t=0;t<=e;t+=e/4)i.push(ah(h,ag(ap(v,g),t)));for(let t=e;t>=0;t-=e/4)a.push(ah(h,ag(ap(v,g),t)));a.push(M,C)}else{i.push(w,T);for(let t=0;t<=e;t+=e/4)a.push(ah(h,ag(ap(v,-g),-t)));for(let t=e;t>=0;t-=e/4)i.push(ah(h,ag(ap(v,-g),-t)));i.push(T,k)}}else i.push(T),a.push(M);r=l}if(s>=n-2)if(!this.options.keepHead)return[];else{let e=t[n-1],i=[];for(let t=0;t<=2*Math.PI;t+=Math.PI/16)i.push(ah(e,ap(ag([1,0,0],t),this.options.size)));return i.push(ah(e,ap([1,0,0],this.options.size))),i}let c=t[s],d=t[s+1],h=t[n-2],u=t[n-1],p=am(au(d,c)),m=am(au(h,u)),g=ag(p,-Math.PI/2),f=ag(m,Math.PI/2),b=this.getSize(e,c[2],0,n,0),v=[],y=this.options.keepHead?this.options.size:this.getSize(e,h[2],n-2,n,o),E=[];if(b>1){for(let e=0;e<=Math.PI;e+=Math.PI/16)v.unshift(ah(c,ag(ap(g,b),-e)));v.unshift(ah(c,ap(g,-b)))}else v.push(c);for(let e=0;e<=3*Math.PI;e+=Math.PI/16)E.push(ah(u,ag(ap(f,-y),-e)));let x=[...v,...i,...E.reverse(),...a.reverse()];return(v.length>0&&x.push(v[0]),this.options.simplify>0&&"output"===this.options.simplifyPhase)?aE(x,this.options.simplify):x}}var aw=en(),{useAtom:aS,useSetAtom:aC,useAtomValue:ak,useStore:aI}=aw,aj=aw.Provider,aT=B(),aM=(0,y.b)({"./locales/ar-SA.json":()=>e.A(99868),"./locales/az-AZ.json":()=>e.A(37828),"./locales/bg-BG.json":()=>e.A(59250),"./locales/bn-BD.json":()=>e.A(42875),"./locales/ca-ES.json":()=>e.A(69688),"./locales/cs-CZ.json":()=>e.A(74062),"./locales/da-DK.json":()=>e.A(90084),"./locales/de-DE.json":()=>e.A(55035),"./locales/el-GR.json":()=>e.A(22655),"./locales/en.json":()=>e.A(84108),"./locales/es-ES.json":()=>e.A(42483),"./locales/eu-ES.json":()=>e.A(52686),"./locales/fa-IR.json":()=>e.A(82293),"./locales/fi-FI.json":()=>e.A(46686),"./locales/fr-FR.json":()=>e.A(72687),"./locales/gl-ES.json":()=>e.A(8852),"./locales/he-IL.json":()=>e.A(880),"./locales/hi-IN.json":()=>e.A(72129),"./locales/hu-HU.json":()=>e.A(40050),"./locales/id-ID.json":()=>e.A(19355),"./locales/it-IT.json":()=>e.A(37719),"./locales/ja-JP.json":()=>e.A(8229),"./locales/kaa.json":()=>e.A(58490),"./locales/kab-KAB.json":()=>e.A(59320),"./locales/kk-KZ.json":()=>e.A(41356),"./locales/km-KH.json":()=>e.A(38202),"./locales/ko-KR.json":()=>e.A(22648),"./locales/ku-TR.json":()=>e.A(64187),"./locales/lt-LT.json":()=>e.A(45143),"./locales/lv-LV.json":()=>e.A(73406),"./locales/mr-IN.json":()=>e.A(12002),"./locales/my-MM.json":()=>e.A(34615),"./locales/nb-NO.json":()=>e.A(54282),"./locales/nl-NL.json":()=>e.A(31474),"./locales/nn-NO.json":()=>e.A(71945),"./locales/oc-FR.json":()=>e.A(29178),"./locales/pa-IN.json":()=>e.A(66177),"./locales/percentages.json":()=>e.A(55582),"./locales/pl-PL.json":()=>e.A(38776),"./locales/pt-BR.json":()=>e.A(14015),"./locales/pt-PT.json":()=>e.A(36995),"./locales/ro-RO.json":()=>e.A(40145),"./locales/ru-RU.json":()=>e.A(9747),"./locales/si-LK.json":()=>e.A(4187),"./locales/sk-SK.json":()=>e.A(73855),"./locales/sl-SI.json":()=>e.A(12926),"./locales/sv-SE.json":()=>e.A(17928),"./locales/ta-IN.json":()=>e.A(75245),"./locales/th-TH.json":()=>e.A(46432),"./locales/tr-TR.json":()=>e.A(35061),"./locales/uk-UA.json":()=>e.A(60411),"./locales/vi-VN.json":()=>e.A(75992),"./locales/zh-CN.json":()=>e.A(68072),"./locales/zh-HK.json":()=>e.A(37721),"./locales/zh-TW.json":()=>e.A(75005)}),aL={code:"en",label:"English"},aD=[aL,...[{code:"ar-SA",label:"العربية",rtl:!0},{code:"bg-BG",label:"Български"},{code:"ca-ES",label:"Català"},{code:"cs-CZ",label:"Česky"},{code:"de-DE",label:"Deutsch"},{code:"el-GR",label:"Ελληνικά"},{code:"es-ES",label:"Español"},{code:"eu-ES",label:"Euskara"},{code:"fa-IR",label:"فارسی",rtl:!0},{code:"fi-FI",label:"Suomi"},{code:"fr-FR",label:"Français"},{code:"gl-ES",label:"Galego"},{code:"he-IL",label:"עברית",rtl:!0},{code:"hi-IN",label:"हिन्दी"},{code:"hu-HU",label:"Magyar"},{code:"id-ID",label:"Bahasa Indonesia"},{code:"it-IT",label:"Italiano"},{code:"ja-JP",label:"日本語"},{code:"kab-KAB",label:"Taqbaylit"},{code:"kk-KZ",label:"Қазақ тілі"},{code:"ko-KR",label:"한국어"},{code:"ku-TR",label:"Kurdî"},{code:"lt-LT",label:"Lietuvių"},{code:"lv-LV",label:"Latviešu"},{code:"my-MM",label:"Burmese"},{code:"nb-NO",label:"Norsk bokmål"},{code:"nl-NL",label:"Nederlands"},{code:"nn-NO",label:"Norsk nynorsk"},{code:"oc-FR",label:"Occitan"},{code:"pa-IN",label:"ਪੰਜਾਬੀ"},{code:"pl-PL",label:"Polski"},{code:"pt-BR",label:"Português Brasileiro"},{code:"pt-PT",label:"Português"},{code:"ro-RO",label:"Română"},{code:"ru-RU",label:"Русский"},{code:"sk-SK",label:"Slovenčina"},{code:"sv-SE",label:"Svenska"},{code:"sl-SI",label:"Slovenščina"},{code:"tr-TR",label:"Türkçe"},{code:"uk-UA",label:"Українська"},{code:"zh-CN",label:"简体中文"},{code:"zh-TW",label:"繁體中文"},{code:"vi-VN",label:"Tiếng Việt"},{code:"mr-IN",label:"मराठी"}].filter(e=>v.c[e.code]>=85).sort((e,t)=>e.label>t.label?1:-1)],aN="__test__";f.a.DEV&&aD.unshift({code:aN,label:"test language"},{code:`${aN}.rtl`,label:"test language (rtl)",rtl:!0});var aA=aL,aP={},aR=async e=>{if(aA=e,document.documentElement.dir=aA.rtl?"rtl":"ltr",document.documentElement.lang=aA.code,e.code.startsWith(aN))aP={};else try{aP=await aM(`./locales/${aA.code}.json`)}catch(t){console.error(`Failed to load language ${e.code}:`,t.message),aP=b.J}aT.set(aF,e.code)},a_=(e,t)=>{for(let n=0;n<t.length;++n){let i=t[n];if(void 0===e[i])return;e=e[i]}if("string"==typeof e)return e},aO=(e,t,n)=>{if(aA.code.startsWith(aN))return`\u202A[[${t?`${e}(${JSON.stringify(t).slice(1,-1)})`:e}]]\u202C`;let i=e.split("."),a=a_(aP,i)||a_(b.J,i)||n;if(void 0===a){let t=`Can't find translation for ${e}`;if(f.a.PROD)return console.warn(t),"";throw Error(t)}if(t)for(let e in t)a=a.replace(`{{${e}}}`,String(t[e]));return a},aF=S(aL.code),az=()=>({t:aO,langCode:ak(aF)}),aU=({size:e="1em",circleWidth:t=8,synchronized:n=!1,className:i=""})=>{let a=-(E.default.useRef(Date.now()).current%1600);return(0,W.jsx)("div",{className:`Spinner ${i}`,children:(0,W.jsx)("svg",{viewBox:"0 0 100 100",style:{width:e,height:e,"--spinner-delay":n?`${a}ms`:0},children:(0,W.jsx)("circle",{cx:"50",cy:"50",r:50-t/2,strokeWidth:t,fill:"none",strokeMiterlimit:"10"})})})},aB=({delay:e,theme:t})=>{let[n,i]=(0,E.useState)(!!e);return(0,E.useEffect)(()=>{if(!e)return;let t=setTimeout(()=>{i(!1)},e);return()=>clearTimeout(t)},[e]),n?null:(0,W.jsxs)("div",{className:(0,el.default)("LoadingMessage",{"LoadingMessage--dark":t===m.G.DARK}),children:[(0,W.jsx)("div",{children:(0,W.jsx)(aU,{})}),(0,W.jsx)("div",{className:"LoadingMessage-text",children:aO("labels.loadingScene")})]})},aW=e=>{let[t,n]=(0,E.useState)(!0);return(0,E.useEffect)(()=>{let t=async()=>{await aR(i),n(!1)},i=aD.find(t=>t.code===e.langCode)||aL;t()},[e.langCode]),t?(0,W.jsx)(aB,{theme:e.theme}):e.children},aH=E.default.forwardRef(({size:e="medium",visible:t=!0,className:n="",...i},a)=>{let{id:l}=hX(),r=E.default.useRef(null);E.default.useImperativeHandle(a,()=>r.current);let s=`ToolIcon_size_${e}`,[o,c]=(0,E.useState)(!1),d=(0,E.useRef)(!0),h=async e=>{let t="onClick"in i&&i.onClick?.(e);if((0,m.Fb)(t))try{c(!0),await t}catch(e){if(e instanceof m.tc)console.warn(e);else throw e}finally{d.current&&c(!1)}};(0,E.useEffect)(()=>(d.current=!0,()=>{d.current=!1}),[]);let u=(0,E.useRef)(null);if("button"===i.type||"icon"===i.type||"submit"===i.type){let e="icon"===i.type?"button":i.type;return(0,W.jsxs)("button",{className:(0,el.default)("ToolIcon_type_button",s,n,t&&!i.hidden?"ToolIcon_type_button--show":"ToolIcon_type_button--hide",{ToolIcon:!i.hidden,"ToolIcon--selected":i.selected,"ToolIcon--plain":"icon"===i.type}),style:i.style,"data-testid":i["data-testid"],hidden:i.hidden,title:i.title,"aria-label":i["aria-label"],type:e,onClick:h,ref:r,disabled:o||i.isLoading||!!i.disabled,children:[(i.icon||i.label)&&(0,W.jsxs)("div",{className:"ToolIcon__icon","aria-hidden":"true","aria-disabled":!!i.disabled,children:[i.icon||i.label,i.keyBindingLabel&&(0,W.jsx)("span",{className:"ToolIcon__keybinding",children:i.keyBindingLabel}),i.isLoading&&(0,W.jsx)(aU,{})]}),i.showAriaLabel&&(0,W.jsxs)("div",{className:"ToolIcon__label",children:[i["aria-label"]," ",o&&(0,W.jsx)(aU,{})]}),i.children]})}return(0,W.jsxs)("label",{className:(0,el.default)("ToolIcon",n),title:i.title,onPointerDown:e=>{u.current=e.pointerType||null,i.onPointerDown?.({pointerType:e.pointerType||null})},onPointerUp:()=>{requestAnimationFrame(()=>{u.current=null})},children:[(0,W.jsx)("input",{className:`ToolIcon_type_radio ${s}`,type:"radio",name:i.name,"aria-label":i["aria-label"],"aria-keyshortcuts":i["aria-keyshortcuts"],"data-testid":i["data-testid"],id:`${l}-${i.id}`,onChange:()=>{i.onChange?.({pointerType:u.current})},checked:i.checked,ref:r}),(0,W.jsxs)("div",{className:"ToolIcon__icon",children:[i.icon,i.keyBindingLabel&&(0,W.jsx)("span",{className:"ToolIcon__keybinding",children:i.keyBindingLabel})]})]})});aH.displayName="ToolButton";var a$=(e,t)=>{if(e.editingGroupId){let n=(0,m.Qc)((0,m.pk)(t),e.editingGroupId);if(n.length)return{...e,selectedElementIds:{[n[0].id]:!0}}}return e},aY=(0,m.$c)({name:"deleteSelectedElements",label:"labels.delete",icon:m.ud,trackEvent:{category:"element",action:"delete"},perform:(e,t,n,i)=>{if(t.editingLinearElement){let{elementId:n,selectedPointsIndices:a,startBindingElement:l,endBindingElement:r}=t.editingLinearElement,s=i.scene.getNonDeletedElementsMap(),o=m.pj.getElement(n,s);if(!o||null==a)return!1;if(o.points.length<2){let n=e.map(e=>e.id===o.id?(0,m.Qj)(e,{isDeleted:!0}):e),i=a$(t,n);return{elements:n,appState:{...i,editingLinearElement:null},captureUpdate:m.Wg.IMMEDIATELY}}let c={startBindingElement:a?.includes(0)?null:l,endBindingElement:a?.includes(o.points.length-1)?null:r};return m.pj.deletePoints(o,a),{elements:e,appState:{...t,editingLinearElement:{...t.editingLinearElement,...c,selectedPointsIndices:a?.[0]>0?[a[0]-1]:[0]}},captureUpdate:m.Wg.IMMEDIATELY}}let{elements:a,appState:l}=((e,t,n)=>{let i=new Set((0,m.vk)(e.filter(e=>(0,m.bc)(e)),t).map(e=>e.id)),a={},l=n.scene.getNonDeletedElementsMap(),r=new Set;for(let t of i)for(let n of(0,m.Bi)(e,t))if(!r.has(n.id)){if((0,m.nc)(n)){let e=(0,m.Aj)(n,l);e&&(a[e.id]=!0)}else a[n.id]=!0;r.add(n.id)}let s=!0,o=e.map(e=>{if(t.selectedElementIds[e.id]){let t=(0,m.nc)(e)?(0,m.Aj)(e,l):null;return e.frameId&&i.has(e.frameId)?(s=!1,a[e.id]=!0,e):t?.frameId&&i.has(t?.frameId)?e:(e.boundElements&&e.boundElements.forEach(t=>{let i=n.scene.getNonDeletedElementsMap().get(t.id);i&&(0,m.ec)(i)&&((0,m.Pj)(i,{startBinding:e.id===i.startBinding?.elementId?null:i.startBinding,endBinding:e.id===i.endBinding?.elementId?null:i.endBinding}),(0,m.Pj)(i,{points:i.points}))}),(0,m.Qj)(e,{isDeleted:!0}))}return e.frameId&&i.has(e.frameId)?(s=!1,(0,m.nc)(e)||(a[e.id]=!0),(0,m.Qj)(e,{frameId:null})):(0,m.nc)(e)&&t.selectedElementIds[e.containerId]?(0,m.Qj)(e,{isDeleted:!0}):e}),c=t.editingGroupId;if(s&&t.editingGroupId){let e=(0,m.Qc)(o,t.editingGroupId).filter(e=>!e.isDeleted);if(e.length>1)e[0]&&(a[e[0].id]=!0);else{c=null,e[0]&&(a[e[0].id]=!0);let n=e[0];if(n){let e=n.groupIds.findIndex(e=>e===t.editingGroupId),i=n.groupIds[e+1];if(i){let e=(0,m.Qc)(o,i).filter(e=>!e.isDeleted);e.length>1&&(c=i,e.forEach(e=>{a[e.id]=!0}))}}}}return{elements:o,appState:{...t,...(0,m.Jc)({selectedElementIds:a,editingGroupId:c},o,t,null)}}})(e,t,i);return(0,m.Tg)(a,a.filter(e=>e.isDeleted)),l=a$(l,a),{elements:a,appState:{...l,activeTool:(0,m.jb)(t,{type:"selection"}),multiElement:null,activeEmbeddable:null},captureUpdate:(0,m.tk)((0,m.pk)(e),t)?m.Wg.IMMEDIATELY:m.Wg.EVENTUALLY}},keyTest:(e,t,n)=>(e.key===m.hg.BACKSPACE||e.key===m.hg.DELETE)&&!e[m.hg.CTRL_OR_CMD],PanelComponent:({elements:e,appState:t,updateData:n})=>(0,W.jsx)(aH,{type:"button",icon:m.ud,title:aO("labels.delete"),"aria-label":aO("labels.delete"),onClick:()=>n(null),visible:(0,m.tk)((0,m.pk)(e),t)})}),aV=(e,t)=>e.frameId===t||e.id===t,aG=(e,t,n)=>{let i=[],a=[],l=null,r=-1,s=(0,m.xb)(n||(0,m.vk)(e,t,{includeBoundTextElement:!0,includeElementsInFrames:!0}));for(;++r<e.length;){let t=e[r];s.get(t.id)?(a.length&&(i=i.concat(a),a=[]),i.push(r),l=r+1):t.isDeleted&&l===r?(l=r+1,a.push(r)):a=[]}return i},aK=(e,t,n)=>{if("containerId"in e&&e.containerId){let i=m.Oj.getScene(e).getElement(e.containerId);if(i)return"left"===n?Math.min(t.indexOf(i),t.indexOf(e)):Math.max(t.indexOf(i),t.indexOf(e))}else{let i=e.boundElements?.find(e=>"arrow"!==e.type)?.id;if(i){let a=m.Oj.getScene(e).getElement(i);if(a)return"left"===n?Math.min(t.indexOf(a),t.indexOf(e)):Math.max(t.indexOf(a),t.indexOf(e))}}},aZ=(e,t)=>t.reduce((t,n)=>{let i=e[n];return t.set(i.id,i),t},new Map),aX=(e,t,n)=>{let i,a=aG(e,t),l=aZ(e,a),r=(i=0,a.reduce((e,t,n)=>(n>0&&a[n-1]!==t-1&&(i=++i),(e[i]||(e[i]=[])).push(t),e),[]));"right"===n&&(r=r.reverse());let s=new Set(a.filter(t=>(0,m.bc)(e[t])).map(t=>e[t].id));return r.forEach((i,a)=>{let l=i[0],r=i[i.length-1],o="left"===n?l:r,c=i.some(t=>{let n=e[t];return n.frameId&&s.has(n.frameId)})?null:e[o]?.frameId,d=((e,t,n,i,a)=>{let l=t[n],r=t=>!t.isDeleted&&(a?t.frameId===a:!e.editingGroupId||t.groupIds.includes(e.editingGroupId)),s="left"===i?(0,m.rb)(t,e=>r(e),Math.max(0,n-1)):(0,m.qb)(t,e=>r(e),n+1),o=t[s];if(!o)return -1;if(e.editingGroupId){if(l?.groupIds.join("")===o?.groupIds.join(""))return aK(o,t,i)??s;if(!o?.groupIds.includes(e.editingGroupId))return -1}if(!a&&(o.frameId||(0,m.bc)(o))){var c;let e,n,a=(c=o.frameId||o.id,e=-1,n=-1,t.forEach((t,i)=>{aV(t,c)&&(-1===e&&(e=i),n=i)}),-1===e?[]:t.slice(e,n+1));return"left"===i?t.indexOf(a[0]):t.indexOf(a[a.length-1])}if(!o.groupIds.length)return aK(o,t,i)??s;let d=e.editingGroupId?o.groupIds[o.groupIds.indexOf(e.editingGroupId)-1]:o.groupIds[o.groupIds.length-1],h=(0,m.Qc)(t,d);return h.length?"left"===i?t.indexOf(h[0]):t.indexOf(h[h.length-1]):s})(t,e,o,n,c);if(-1===d||o===d)return;let h="left"===n?e.slice(0,d):e.slice(0,l),u=e.slice(l,r+1),p="left"===n?e.slice(d,l):e.slice(r+1,d+1),g="left"===n?e.slice(r+1):e.slice(d+1);e="left"===n?[...h,...u,...p,...g]:[...h,...p,...u,...g]}),(0,m.Mj)(e,l),e},aQ=(e,t,n,i,a)=>{let l=aG(e,t,a),r=aZ(e,l),s=[],o,c;if("left"===n){if(i)o=(0,m.qb)(e,e=>aV(e,i));else if(t.editingGroupId){let n=(0,m.Qc)(e,t.editingGroupId);if(!n.length)return e;o=e.indexOf(n[0])}else o=0;c=l[l.length-1]}else{if(i)c=(0,m.rb)(e,e=>aV(e,i));else if(t.editingGroupId){let n=(0,m.Qc)(e,t.editingGroupId);if(!n.length)return e;c=e.indexOf(n[n.length-1])}else c=e.length-1;o=l[0]}-1===o&&(o=0);for(let t=o;t<c+1;t++)l.includes(t)||s.push(e[t]);let d=Array.from(r.values()),h=e.slice(0,o),u=e.slice(c+1),p="left"===n?[...h,...d,...s,...u]:[...h,...s,...d,...u];return(0,m.Mj)(p,r),p};function aq(e,t,n,i){let a=(0,m.xb)((0,m.vk)(e,t,{includeBoundTextElement:!0,includeElementsInFrames:!0})),l={regularElements:[],frameChildren:new Map},r=new Set;for(let t of e)a.has(t.id)&&(0,m.bc)(t)&&r.add(t.id);for(let t of e)if(a.has(t.id))if((0,m.bc)(t)||t.frameId&&r.has(t.frameId))l.regularElements.push(t);else if(t.frameId){let e=l.frameChildren.get(t.frameId)||[];e.push(t),l.frameChildren.set(t.frameId,e)}else l.regularElements.push(t);let s=e;for(let[a,r]of Array.from(l.frameChildren.entries()))s=i(e,t,n,a,r);return i(s,t,n,null,l.regularElements)}var aJ=(0,m.$c)({name:"sendBackward",label:"labels.sendBackward",keywords:["move down","zindex","layer"],icon:m.Wd,trackEvent:{category:"element"},perform:(e,t)=>({elements:aX(e,t,"left"),appState:t,captureUpdate:m.Wg.IMMEDIATELY}),keyPriority:40,keyTest:e=>e[m.hg.CTRL_OR_CMD]&&!e.shiftKey&&e.code===m.gg.BRACKET_LEFT,PanelComponent:({updateData:e,appState:t})=>(0,W.jsx)("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${aO("labels.sendBackward")} \u2014 ${(0,m.kb)("CtrlOrCmd+[")}`,children:m.Wd})}),a0=(0,m.$c)({name:"bringForward",label:"labels.bringForward",keywords:["move up","zindex","layer"],icon:m.Vd,trackEvent:{category:"element"},perform:(e,t)=>({elements:aX(e,t,"right"),appState:t,captureUpdate:m.Wg.IMMEDIATELY}),keyPriority:40,keyTest:e=>e[m.hg.CTRL_OR_CMD]&&!e.shiftKey&&e.code===m.gg.BRACKET_RIGHT,PanelComponent:({updateData:e,appState:t})=>(0,W.jsx)("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${aO("labels.bringForward")} \u2014 ${(0,m.kb)("CtrlOrCmd+]")}`,children:m.Vd})}),a1=(0,m.$c)({name:"sendToBack",label:"labels.sendToBack",keywords:["move down","zindex","layer"],icon:m.Yd,trackEvent:{category:"element"},perform:(e,t)=>({elements:aq(e,t,"left",aQ),appState:t,captureUpdate:m.Wg.IMMEDIATELY}),keyTest:e=>m.l?e[m.hg.CTRL_OR_CMD]&&e.altKey&&e.code===m.gg.BRACKET_LEFT:e[m.hg.CTRL_OR_CMD]&&e.shiftKey&&e.code===m.gg.BRACKET_LEFT,PanelComponent:({updateData:e,appState:t})=>(0,W.jsx)("button",{type:"button",className:"zIndexButton",onClick:()=>e(null),title:`${aO("labels.sendToBack")} \u2014 ${m.l?(0,m.kb)("CtrlOrCmd+Alt+["):(0,m.kb)("CtrlOrCmd+Shift+[")}`,children:m.Yd})}),a2=(0,m.$c)({name:"bringToFront",label:"labels.bringToFront",keywords:["move up","zindex","layer"],icon:m.Xd,trackEvent:{category:"element"},perform:(e,t)=>({elements:aq(e,t,"right",aQ),appState:t,captureUpdate:m.Wg.IMMEDIATELY}),keyTest:e=>m.l?e[m.hg.CTRL_OR_CMD]&&e.altKey&&e.code===m.gg.BRACKET_RIGHT:e[m.hg.CTRL_OR_CMD]&&e.shiftKey&&e.code===m.gg.BRACKET_RIGHT,PanelComponent:({updateData:e,appState:t})=>(0,W.jsx)("button",{type:"button",className:"zIndexButton",onClick:t=>e(null),title:`${aO("labels.bringToFront")} \u2014 ${m.l?(0,m.kb)("CtrlOrCmd+Alt+]"):(0,m.kb)("CtrlOrCmd+Shift+]")}`,children:m.Xd})}),a3=(0,m.$c)({name:"selectAll",label:"labels.selectAll",icon:m.uf,trackEvent:{category:"canvas"},viewMode:!1,perform:(e,t,n,i)=>{if(t.editingLinearElement)return!1;let a=e.filter(e=>!e.isDeleted&&!((0,m._b)(e)&&e.containerId)&&!e.locked).reduce((e,t)=>(e[t.id]=!0,e),{});return{appState:{...t,...(0,m.Jc)({editingGroupId:null,selectedElementIds:a},(0,m.pk)(e),t,i),selectedLinearElement:1===Object.keys(a).length&&(0,m.cc)(e[0])?new m.pj(e[0]):null},captureUpdate:m.Wg.IMMEDIATELY}},keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.key===m.hg.A}),a5=(0,m.$c)({name:"duplicateSelection",label:"labels.duplicateSelection",icon:m.wd,trackEvent:{category:"element"},perform:(e,t,n,i)=>{if(t.editingLinearElement)try{let n=m.pj.duplicateSelectedPoints(t,i.scene.getNonDeletedElementsMap());return{elements:e,appState:n,captureUpdate:m.Wg.IMMEDIATELY}}catch{return!1}let a=a4(e,t);if(i.props.onDuplicate&&a.elements){let t=i.props.onDuplicate(a.elements,e);t&&(a.elements=t)}return{...a,captureUpdate:m.Wg.IMMEDIATELY}},keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.key===m.hg.D,PanelComponent:({elements:e,appState:t,updateData:n})=>(0,W.jsx)(aH,{type:"button",icon:m.wd,title:`${aO("labels.duplicateSelection")} \u2014 ${(0,m.kb)("CtrlOrCmd+D")}`,"aria-label":aO("labels.duplicateSelection"),onClick:()=>n(null),visible:(0,m.tk)((0,m.pk)(e),t)})}),a4=(e,t)=>{var n,i;let a,l,r,s,o,c,d,h=new Map,u=[],p=[],g=new Map,f=new Map,b=(0,m.xb)(e),v=e=>{let n=(0,m.Ub)(e).reduce((e,n)=>{if(E.has(n.id))return e;E.set(n.id,!0);let i=(0,m.cg)(t.editingGroupId,h,n,{x:n.x+m.R/2,y:n.y+m.R/2});return E.set(i.id,!0),f.set(i.id,i),g.set(n.id,i.id),p.push(n),u.push(i),e.push(i),e},[]);return Array.isArray(e)?n:n[0]||null};a=(n=e).slice(),l=new Set,r=e=>{let t=e[0]?.groupIds?.join(""),n=[e[0]],i=[];for(let a of e.slice(1))a.groupIds?.join("")===t?n.push(a):i.push(a);return i.length?[...n,...r(i)]:n},s=new Map,a.forEach((e,t)=>{if(!s.has(e.id))if(e.groupIds?.length){let n=e.groupIds[e.groupIds.length-1];for(let e of r(a.slice(t).filter(e=>{let t=e?.groupIds?.some(e=>e===n);return t&&s.set(e.id,!0),t})))l.add(e)}else l.add(e)}),i=l.size!==n.length?(console.error("normalizeGroupElementOrder: lost some elements... bailing!"),n):[...l],o=(0,m.yb)(i),c=i.slice(),d=new Set,c.forEach((e,t)=>{e&&(e.boundElements?.length?(d.add(e),c[t]=null,e.boundElements.forEach(e=>{let t=o.get(e.id);t&&"text"===e.type&&(d.add(t[0]),c[t[1]]=null)})):"text"===e.type&&e.containerId&&o.get(e.containerId)?.[0].boundElements?.find(t=>t.id===e.id)||(d.add(e),c[t]=null))}),e=d.size!==i.length?(console.error("normalizeBoundElementsOrder: lost some elements... bailing!"),i):[...d];let y=(0,m.xb)((0,m.vk)(e,t,{includeBoundTextElement:!0,includeElementsInFrames:!0})),E=new Map,x=e.slice(),w=(e,t)=>{(0,m.Kb)(-1!==e,"targetIndex === -1 "),(Array.isArray(t)||t)&&x.splice(e+1,0,...(0,m.Ub)(t))},S=new Set(e.filter(e=>y.has(e.id)&&(0,m.bc)(e)).map(e=>e.id));for(let n of e){if(E.has(n.id)||!y.has(n.id))continue;let i=(0,m.Lc)(t,n);if(i){let t=(0,m.Qc)(e,i).flatMap(t=>(0,m.bc)(t)?[...(0,m.Bi)(e,t.id),t]:[t]);w((0,m.rb)(x,e=>e.groupIds?.includes(i)),v(t));continue}if(!(n.frameId&&S.has(n.frameId))){if((0,m.bc)(n)){let t=n.id,i=(0,m.Bi)(e,t);w((0,m.rb)(x,e=>e.frameId===t||e.id===t),v([...i,n]));continue}if((0,m.mc)(n)){let e=(0,m.zj)(n,b);w((0,m.rb)(x,e=>e.id===n.id||"containerId"in e&&e.containerId===n.id),v(e?[n,e]:n));continue}if((0,m.nc)(n)){let e=(0,m.Aj)(n,b);w((0,m.rb)(x,t=>t.id===n.id||t.id===e?.id),v(e?[e,n]:n));continue}w((0,m.rb)(x,e=>e.id===n.id),v(n))}}(0,m.vj)(x,p,g),(0,m.Sg)(x,p,g),(0,m.wi)(x,p,g);let C=(0,m.rk)(u);return{elements:x,appState:{...t,...(0,m.Jc)({editingGroupId:t.editingGroupId,selectedElementIds:C.reduce((e,t)=>((0,m.nc)(t)||(e[t.id]=!0),e),{})},(0,m.pk)(x),t,null)}}},a6=new Set(["command_palette","export"]),a8=(e,t,n,i)=>{try{if(f.a.VITE_WORKER_ID||"true"!==f.a.VITE_APP_ENABLE_TRACKING||!a6.has(e)||f.a.DEV)return;f.a.PROD||console.info("trackEvent",{category:e,action:t,label:n,value:i}),window.sa_event&&window.sa_event(t,{category:e,label:n,value:i})}catch(e){console.error("error during analytics",e)}},a7=(0,E.forwardRef)((e,t)=>{let{title:n,className:i,testId:a,active:l,standalone:r,icon:s,onClick:o}=e;return(0,W.jsx)("button",{type:"button",ref:t,title:n,"data-testid":a,className:(0,el.default)(i,{standalone:r,active:l}),onClick:o,children:s},n)}),a9=e=>(0,W.jsx)("div",{className:"buttonList",children:e.options.map(t=>"button"===e.type?(0,W.jsx)(a7,{icon:t.icon,title:t.text,testId:t.testId,active:t.active??e.value===t.value,onClick:n=>e.onClick(t.value,n)},t.text):(0,W.jsxs)("label",{className:(0,el.default)({active:e.value===t.value}),title:t.text,children:[(0,W.jsx)("input",{type:"radio",name:e.group,onChange:()=>e.onChange(t.value),checked:e.value===t.value,"data-testid":t.testId}),t.icon]},t.text))}),le=({onChange:e,type:t,activeColor:n,topPicks:i})=>{let a;return"elementStroke"===t&&(a=m.f),"elementBackground"===t&&(a=m.g),"canvasBackground"===t&&(a=m.h),i&&(a=i),a?(0,W.jsx)("div",{className:"color-picker__top-picks",children:a.map(t=>(0,W.jsx)("button",{className:(0,el.default)("color-picker__button",{active:t===n,"is-transparent":"transparent"===t||!t}),style:{"--swatch-color":t},type:"button",title:t,onClick:()=>e(t),"data-testid":`color-top-pick-${t}`,children:(0,W.jsx)("div",{className:"color-picker__button-outline"})},t))}):(console.error("Invalid type for TopPicks"),null)},lt=()=>(0,W.jsx)("div",{style:{width:1,height:"1rem",backgroundColor:"var(--default-border-color)",margin:"0 auto"}}),ln=({palette:e,color:t})=>{for(let[n,i]of Object.entries(e))if(Array.isArray(i)){let e=i.indexOf(t);if(e>-1)return{colorName:n,shade:e}}else if(i===t)return{colorName:n,shade:null};return null},li=[["q","w","e","r","t"],["a","s","d","f","g"],["z","x","c","v","b"]].flat(),la=({color:e,palette:t})=>!Object.values(t).flat().includes(e),ll=S(null),lr=(e,t,n)=>(299*e+587*t+114*n)/1e3>=160?"black":"white",ls=({color:e,keyLabel:t,isCustomColor:n=!1,isShade:i=!1})=>(0,W.jsxs)("div",{className:"color-picker__button__hotkey-label",style:{color:((e,t)=>{if(t){let t=new Option().style;if(t.color=e,t.color){let e=t.color.replace(/^(rgb|rgba)\(/,"").replace(/\)$/,"").replace(/\s/g,"").split(",");return lr(parseInt(e[0]),parseInt(e[1]),parseInt(e[2]))}}return"transparent"===e?"black":lr(parseInt(e.substring(1,3),16),parseInt(e.substring(3,5),16),parseInt(e.substring(5,7),16))})(e,n)},children:[i&&"⇧",t]}),lo=({hex:e,onChange:t,palette:n})=>{let i=ln({color:e||"transparent",palette:n}),[a,l]=aS(ll),r=(0,E.useRef)(null);if((0,E.useEffect)(()=>{r.current&&"shades"===a&&r.current.focus()},[i,a]),i){let{colorName:e,shade:s}=i,o=n[e];if(Array.isArray(o))return(0,W.jsx)("div",{className:"color-picker-content--default shades",children:o.map((n,i)=>(0,W.jsxs)("button",{ref:i===s&&"shades"===a?r:void 0,tabIndex:-1,type:"button",className:(0,el.default)("color-picker__button color-picker__button--large",{active:i===s}),"aria-label":"Shade",title:`${e} - ${i+1}`,style:n?{"--swatch-color":n}:void 0,onClick:()=>{t(n),l("shades")},children:[(0,W.jsx)("div",{className:"color-picker__button-outline"}),(0,W.jsx)(ls,{color:n,keyLabel:i+1,isShade:!0})]},i))})}return(0,W.jsxs)("div",{className:"color-picker-content--default",style:{position:"relative"},tabIndex:-1,children:[(0,W.jsx)("button",{type:"button",tabIndex:-1,className:"color-picker__button color-picker__button--large color-picker__button--no-focus-visible"}),(0,W.jsx)("div",{tabIndex:-1,style:{position:"absolute",top:0,left:0,right:0,bottom:0,display:"flex",alignItems:"center",justifyContent:"center",textAlign:"center",fontSize:"0.75rem"},children:aO("colorPicker.noShades")})]})},lc=({palette:e,color:t,onChange:n,label:i,activeShade:a})=>{let l=ln({color:t||"transparent",palette:e}),[r,s]=aS(ll),o=(0,E.useRef)(null);return(0,E.useEffect)(()=>{o.current&&"baseColors"===r&&o.current.focus()},[l?.colorName,r]),(0,W.jsx)("div",{className:"color-picker-content--default",children:Object.entries(e).map(([e,t],i)=>{let r=(Array.isArray(t)?t[a]:t)||"transparent",c=li[i],d=aO(`colors.${e.replace(/\d+/,"")}`,null,"");return(0,W.jsxs)("button",{ref:l?.colorName===e?o:void 0,tabIndex:-1,type:"button",className:(0,el.default)("color-picker__button color-picker__button--large",{active:l?.colorName===e,"is-transparent":"transparent"===r||!r}),onClick:()=>{n(r),s("baseColors")},title:`${d}${r.startsWith("#")?` ${r}`:""} \u2014 ${c}`,"aria-label":`${d} \u2014 ${c}`,style:{"--swatch-color":r},"data-testid":`color-${e}`,children:[(0,W.jsx)("div",{className:"color-picker__button-outline"}),(0,W.jsx)(ls,{color:r,keyLabel:c})]},e)})})},ld=({colors:e,color:t,onChange:n,label:i})=>{let[a,l]=aS(ll),r=(0,E.useRef)(null);return(0,E.useEffect)(()=>{r.current&&r.current.focus()},[t,a]),(0,W.jsx)("div",{className:"color-picker-content--default",children:e.map((e,a)=>(0,W.jsxs)("button",{ref:t===e?r:void 0,tabIndex:-1,type:"button",className:(0,el.default)("color-picker__button color-picker__button--large",{active:t===e,"is-transparent":"transparent"===e||!e}),onClick:()=>{n(e),l("custom")},title:e,"aria-label":i,style:{"--swatch-color":e},children:[(0,W.jsx)("div",{className:"color-picker__button-outline"}),(0,W.jsx)(ls,{color:e,keyLabel:a+1,isCustomColor:!0})]},a))})},lh=(e,t,n)=>{let i=Math.ceil(n/m.b);switch(t=t??-1,e){case"ArrowLeft":{let e=t-1;return e<0?n-1:e}case"ArrowRight":return(t+1)%n;case"ArrowDown":{let e=t+m.b;return e>=n?t%m.b:e}case"ArrowUp":{let e=t-m.b,a=e<0?m.b*i+e:e;return a>=n?void 0:a}}},lu=({children:e})=>(0,W.jsx)("div",{className:"color-picker__heading",children:e}),lp=({color:e,onChange:t,label:n,type:i,elements:a,palette:l,updateData:r,children:s,onEyeDropperToggle:o,onEscape:c})=>{let[d]=E.default.useState(()=>{let e,t,n;return"canvasBackground"===i?[]:(e={elementBackground:"backgroundColor",elementStroke:"strokeColor"},t=a.filter(t=>!t.isDeleted&&la({color:t[e[i]],palette:l})),n=new Map,t.forEach(t=>{let a=t[e[i]];n.has(a)?n.set(a,n.get(a)+1):n.set(a,1)}),[...n.entries()].sort((e,t)=>t[1]-e[1]).map(e=>e[0]).slice(0,m.a))}),[h,u]=aS(ll),p=ln({color:e,palette:l});(0,E.useEffect)(()=>{if(!h){let t=la({color:e,palette:l});u(t&&!d.includes(e)?"hex":t?"custom":p?.shade!=null?"shades":"baseColors")}},[h,e,l,u,p,d]);let[g,f]=(0,E.useState)(p?.shade??("elementBackground"===i?m.d:m.c));(0,E.useEffect)(()=>{p?.shade!=null&&f(p.shade);let e=e=>{e.key===m.hg.ALT&&o(!1)};return document.addEventListener("keyup",e,{capture:!0}),()=>{document.removeEventListener("keyup",e,{capture:!0})}},[p,o]);let b=E.default.useRef(null);return(0,W.jsx)("div",{role:"dialog","aria-modal":"true","aria-label":aO("labels.colorPicker"),children:(0,W.jsxs)("div",{ref:b,onKeyDown:n=>{(({event:e,activeColorPickerSection:t,palette:n,color:i,onChange:a,customColors:l,setActiveColorPickerSection:r,updateData:s,activeShade:o,onEyeDropperToggle:c,onEscape:d})=>{if(e[m.hg.CTRL_OR_CMD])return!1;if(e.key===m.hg.ESCAPE)return d(e),!0;if(e.key===m.hg.ALT)return c(!0),!0;if(e.key===m.hg.I)return c(),!0;let h=ln({color:i,palette:n});if(e.key===m.hg.TAB){let s=Object.entries({custom:!!l.length,baseColors:!0,shades:h?.shade!=null,hex:!0}).reduce((e,[t,n])=>(n&&e.push(t),e),[]),o=s.indexOf(t),c=e.shiftKey?-1:1,d=o+c>s.length-1?0:o+c<0?s.length-1:o+c,u=s[d];return u&&r(u),"custom"===u?a(l[0]):"baseColors"===u&&(Object.entries(n).find(([e,t])=>Array.isArray(t)?t.includes(i):t===i?e:null)||a(m.e.black)),e.preventDefault(),e.stopPropagation(),!0}if((({e,colorObj:t,onChange:n,palette:i,customColors:a,setActiveColorPickerSection:l,activeShade:r})=>{if(t?.shade!=null&&["Digit1","Digit2","Digit3","Digit4","Digit5"].includes(e.code)&&e.shiftKey){let a=Number(e.code.slice(-1))-1;return n(i[t.colorName][a]),l("shades"),!0}if(["1","2","3","4","5"].includes(e.key)&&a[Number(e.key)-1])return n(a[Number(e.key)-1]),l("custom"),!0;if(li.includes(e.key)){let t=li.indexOf(e.key),a=Object.keys(i)[t],s=i[a];return n(Array.isArray(s)?s[r]:s),l("baseColors"),!0}return!1})({e,colorObj:h,onChange:a,palette:n,customColors:l,setActiveColorPickerSection:r,activeShade:o}))return!0;if("shades"===t&&h){let{shade:t}=h,i=lh(e.key,t,m.b);if(void 0!==i)return a(n[h.colorName][i]),!0}if("baseColors"===t&&h){let{colorName:t}=h,i=Object.keys(n),l=i.indexOf(t),r=lh(e.key,l,i.length);if(void 0!==r){let e=n[i[r]];return a(Array.isArray(e)?e[o]:e),!0}}if("custom"===t){let t=l.indexOf(i),n=lh(e.key,t,l.length);if(void 0!==n)return a(l[n]),!0}return!1})({event:n,activeColorPickerSection:h,palette:l,color:e,onChange:t,onEyeDropperToggle:o,customColors:d,setActiveColorPickerSection:u,updateData:r,activeShade:g,onEscape:c})&&(n.preventDefault(),n.stopPropagation())},className:"color-picker-content properties-content",tabIndex:-1,children:[!!d.length&&(0,W.jsxs)("div",{children:[(0,W.jsx)(lu,{children:aO("colorPicker.mostUsedCustomColors")}),(0,W.jsx)(ld,{colors:d,color:e,label:aO("colorPicker.mostUsedCustomColors"),onChange:t})]}),(0,W.jsxs)("div",{children:[(0,W.jsx)(lu,{children:aO("colorPicker.colors")}),(0,W.jsx)(lc,{color:e,label:n,palette:l,onChange:t,activeShade:g})]}),(0,W.jsxs)("div",{children:[(0,W.jsx)(lu,{children:aO("colorPicker.shades")}),(0,W.jsx)(lo,{hex:e,onChange:t,palette:l})]}),s]})})},lm=E.default.createContext(null),lg=e=>{let[t,n]=(0,E.useState)(null),i=hZ(),{theme:a}=E.default.useContext(lm),{container:l}=hX();return(0,E.useLayoutEffect)(()=>{t&&(t.className="",t.classList.add("excalidraw",...e?.className?.split(/\s+/)||[]),t.classList.toggle("excalidraw--mobile",i.editor.isMobile),t.classList.toggle("theme--dark",a===m.G.DARK))},[t,a,i.editor.isMobile,e?.className]),(0,E.useLayoutEffect)(()=>{let t=e?.parentSelector?l?.querySelector(e.parentSelector):document.body;if(!t)return;let i=document.createElement("div");return t.appendChild(i),n(i),()=>{t.removeChild(i)}},[l,e?.parentSelector]),t};function lf(e,t,n){(0,E.useEffect)(()=>{function i(i){if(!e.current)return;let a=n?.(i,e.current);if(!0!==a){if(!1===a)return t(i);e.current.contains(i.target)||!document.documentElement.contains(i.target)||i.target.closest("[data-radix-portal]")||i.target===document.documentElement&&"none"===document.body.style.pointerEvents||i.target.closest("[data-prevent-outside-click]")||t(i)}}return document.addEventListener("pointerdown",i),document.addEventListener("touchstart",i),()=>{document.removeEventListener("pointerdown",i),document.removeEventListener("touchstart",i)}},[e,t,n])}var lb=e=>{let t=(0,E.useRef)(e);return Object.assign(t.current,e),t.current},lv=S(null),ly=({onCancel:e,onChange:t,onSelect:n,colorPickerType:i})=>{let a=lg({className:"excalidraw-eye-dropper-backdrop",parentSelector:".excalidraw-eye-dropper-container"}),l=E.default.useContext(lm),r=hQ(),s=hG(),o=lb({app:s,onCancel:e,onChange:t,onSelect:n,selectedElements:(0,m.vk)(r,l)}),{container:c}=hX();(0,E.useEffect)(()=>{let e=d.current;if(!e||!s.canvas||!a)return;let t=!1,n=s.canvas.getContext("2d"),r=({clientX:e,clientY:t})=>{let i=n.getImageData((e-l.offsetLeft)*window.devicePixelRatio,(t-l.offsetTop)*window.devicePixelRatio,1,1).data;return(0,m.k)(i[0],i[1],i[2])},h=({clientX:n,clientY:a,altKey:l})=>{e.style.top=`${a+20}px`,e.style.left=`${n+20}px`;let s=r({clientX:n,clientY:a});t&&o.onChange(i,s,o.selectedElements,{altKey:l}),e.style.background=s},u=()=>{o.onCancel()},p=e=>{t=!0,e.stopImmediatePropagation()},g=e=>{var n;t=!1,c?.focus(),e.stopImmediatePropagation(),e.preventDefault(),n=r(e),o.onSelect(n,e)},f=e=>{e.key===m.hg.ESCAPE&&(e.preventDefault(),e.stopImmediatePropagation(),u())};return a.tabIndex=-1,a.focus(),h({clientX:o.app.lastViewportPosition.x,clientY:o.app.lastViewportPosition.y,altKey:!1}),a.addEventListener("keydown",f),a.addEventListener("pointerdown",p),a.addEventListener("pointerup",g),window.addEventListener("pointermove",h,{passive:!0}),window.addEventListener("blur",u),()=>{t=!1,a.removeEventListener("keydown",f),a.removeEventListener("pointerdown",p),a.removeEventListener("pointerup",g),window.removeEventListener("pointermove",h),window.removeEventListener("blur",u)}},[o,s.canvas,a,i,c,l.offsetLeft,l.offsetTop]);let d=(0,E.useRef)(null);return lf(d,()=>{e()},e=>!!e.target.closest(".excalidraw-eye-dropper-trigger, .excalidraw-eye-dropper-backdrop")),a?(0,er.createPortal)((0,W.jsx)("div",{ref:d,className:"excalidraw-eye-dropper-preview"}),a):null},lE=({color:e,onChange:t,label:n,colorPickerType:i})=>{let a=hZ(),[l,r]=(0,E.useState)(e),[s,o]=aS(ll);(0,E.useEffect)(()=>{r(e)},[e]);let c=(0,E.useCallback)(e=>{let n=e.toLowerCase(),i=lC(n);i&&t(i),r(n)},[t]),d=(0,E.useRef)(null),h=(0,E.useRef)(null);(0,E.useEffect)(()=>{d.current&&d.current.focus()},[s]);let[u,p]=aS(lv);return(0,E.useEffect)(()=>()=>{p(null)},[p]),(0,W.jsxs)("div",{className:"color-picker__input-label",children:[(0,W.jsx)("div",{className:"color-picker__input-hash",children:"#"}),(0,W.jsx)("input",{ref:"hex"===s?d:void 0,style:{border:0,padding:0},spellCheck:!1,className:"color-picker-input","aria-label":n,onChange:e=>{c(e.target.value)},value:(l||"").replace(/^#/,""),onBlur:()=>{r(e)},tabIndex:-1,onFocus:()=>o("hex"),onKeyDown:e=>{e.key!==m.hg.TAB&&(e.key===m.hg.ESCAPE&&h.current?.focus(),e.stopPropagation())}}),!a.editor.isMobile&&(0,W.jsxs)(W.Fragment,{children:[(0,W.jsx)("div",{style:{width:"1px",height:"1.25rem",backgroundColor:"var(--default-border-color)"}}),(0,W.jsx)("div",{ref:h,className:(0,el.default)("excalidraw-eye-dropper-trigger",{selected:u}),onClick:()=>p(e=>e?null:{keepOpenOnAlt:!1,onSelect:e=>t(e),colorPickerType:i}),title:`${aO("labels.eyeDropper")} \u2014 ${m.hg.I.toLocaleUpperCase()} or ${(0,m.kb)("Alt")} `,children:m.df})]})]})},lx=E.default.forwardRef(({children:e,padding:t,className:n,style:i},a)=>(0,W.jsx)("div",{className:(0,el.default)("Island",n),style:{"--padding":t,...i},ref:a,children:e})),lw=E.default.forwardRef(({className:e,container:t,children:n,style:i,onClose:a,onKeyDown:l,onFocusOutside:r,onPointerLeave:s,onPointerDownOutside:o},c)=>{let d=hZ();return(0,W.jsx)(n7,{container:t,children:(0,W.jsxs)(ie,{ref:c,className:(0,el.default)("focus-visible-none",e),"data-prevent-outside-click":!0,side:d.editor.isMobile&&!d.viewport.isLandscape?"bottom":"right",align:d.editor.isMobile&&!d.viewport.isLandscape?"center":"start",alignOffset:-16,sideOffset:20,style:{zIndex:"var(--zIndex-popup)"},onPointerLeave:s,onKeyDown:l,onFocusOutside:r,onPointerDownOutside:o,onCloseAutoFocus:e=>{e.stopPropagation(),e.preventDefault(),t&&!(0,m.$a)(document.activeElement)&&t.focus(),a()},children:[(0,W.jsx)(lx,{padding:3,style:i,children:n}),(0,W.jsx)(ir,{width:20,height:10,style:{fill:"var(--popup-bg-color)",filter:"drop-shadow(rgba(0, 0, 0, 0.05) 0px 3px 2px)"}})]})})}),lS=e=>{let t=new Option().style;return t.color=e,!!t.color},lC=e=>(0,m.sb)(e)?e:lS(`#${e}`)?`#${e}`:lS(e)?e:null,lk=({type:e,color:t,onChange:n,label:i,elements:a,palette:l=m.e,updateData:r})=>{let{container:s}=hX(),[,o]=aS(ll),[c,d]=aS(lv),h=(0,W.jsxs)("div",{children:[(0,W.jsx)(lu,{children:aO("colorPicker.hexCode")}),(0,W.jsx)(lE,{color:t,label:i,onChange:e=>{n(e)},colorPickerType:e})]}),u=(0,E.useRef)(null);return(0,W.jsx)(lw,{container:s,style:{maxWidth:"13rem"},onFocusOutside:e=>{u.current?.querySelector(".color-picker-content")?.focus(),e.preventDefault()},onPointerDownOutside:e=>{c&&e.preventDefault()},onClose:()=>{r({openPopup:null}),o(null)},children:l?(0,W.jsx)(lp,{palette:l,color:t,onChange:e=>{n(e)},onEyeDropperToggle:t=>{d(i=>t?((i=i||{keepOpenOnAlt:!0,onSelect:n,colorPickerType:e}).keepOpenOnAlt=!0,i):!1===t||i?null:{keepOpenOnAlt:!1,onSelect:n,colorPickerType:e})},onEscape:e=>{c?d(null):r({openPopup:null})},label:i,type:e,elements:a,updateData:r,children:h}):h})},lI=({label:e,color:t,type:n})=>(0,W.jsx)(n5,{type:"button",className:(0,el.default)("color-picker__button active-color properties-trigger",{"is-transparent":"transparent"===t||!t}),"aria-label":e,style:t?{"--swatch-color":t}:void 0,title:"elementStroke"===n?aO("labels.showStroke"):aO("labels.showBackground"),children:(0,W.jsx)("div",{className:"color-picker__button-outline"})}),lj=({type:e,color:t,onChange:n,label:i,elements:a,palette:l=m.e,topPicks:r,updateData:s,appState:o})=>(0,W.jsx)("div",{children:(0,W.jsxs)("div",{role:"dialog","aria-modal":"true",className:"color-picker-container",children:[(0,W.jsx)(le,{activeColor:t,onChange:n,type:e,topPicks:r}),(0,W.jsx)(lt,{}),(0,W.jsxs)(n1,{open:o.openPopup===e,onOpenChange:t=>{s({openPopup:t?e:null})},children:[(0,W.jsx)(lI,{color:t,label:i,type:e}),o.openPopup===e&&(0,W.jsx)(lk,{type:e,color:t,onChange:n,label:i,elements:a,palette:l,updateData:s})]})]})}),lT=({icon:e})=>(0,W.jsx)("span",{style:{width:"1em",margin:"0 0.5ex 0 0.5ex",display:"inline-block",lineHeight:0,verticalAlign:"middle"},children:e}),lM=({label:e,open:t,openTrigger:n,children:i,className:a})=>(0,W.jsxs)(W.Fragment,{children:[(0,W.jsxs)("div",{style:{cursor:"pointer",display:"flex",justifyContent:"space-between",alignItems:"center"},className:a,onClick:n,children:[e,(0,W.jsx)(lT,{icon:t?m.Mf:m.Lf})]}),t&&(0,W.jsx)("div",{style:{display:"flex",flexDirection:"column"},children:i})]}),lL=S(!1);function lD({options:e,value:t,label:n,onChange:i,onClose:a,numberOfOptionsToAlwaysShow:l=e.length}){let r=hZ(),[s,o]=aS(lL),c=E.default.useMemo(()=>e.slice(0,l),[e,l]),d=E.default.useMemo(()=>e.slice(l),[e,l]);(0,E.useEffect)(()=>{c.some(e=>e.value===t)||o(!0)},[t,c,o]);let h=e=>(0,W.jsx)("div",{className:"picker-content",children:e.map((e,n)=>(0,W.jsxs)("button",{type:"button",className:(0,el.default)("picker-option",{active:t===e.value}),onClick:t=>{i(e.value)},title:`${e.text} ${e.keyBinding&&`\u2014 ${e.keyBinding.toUpperCase()}`}`,"aria-label":e.text||"none","aria-keyshortcuts":e.keyBinding||void 0,ref:n=>{t===e.value&&setTimeout(()=>{n?.focus()},0)},children:[e.icon,e.keyBinding&&(0,W.jsx)("span",{className:"picker-keybinding",children:e.keyBinding})]},e.text))});return(0,W.jsx)(ie,{side:r.editor.isMobile&&!r.viewport.isLandscape?"top":"bottom",align:"start",sideOffset:12,style:{zIndex:"var(--zIndex-popup)"},onKeyDown:n=>{let r=e.find(e=>e.keyBinding===n.key.toLowerCase());if(!(n.metaKey||n.altKey||n.ctrlKey)&&r)i(r.value),n.preventDefault();else if(n.key===m.hg.TAB){let a=e.findIndex(e=>e.value===t),l=n.shiftKey?(e.length+a-1)%e.length:(a+1)%e.length;i(e[l].value)}else if((0,m.jg)(n.key)){let a=aA.rtl,r=e.findIndex(e=>e.value===t);if(-1!==r){let t=e.length,s=r;switch(n.key){case a?m.hg.ARROW_LEFT:m.hg.ARROW_RIGHT:s=(r+1)%t;break;case a?m.hg.ARROW_RIGHT:m.hg.ARROW_LEFT:s=(t+r-1)%t;break;case m.hg.ARROW_DOWN:s=(r+(l??1))%t;break;case m.hg.ARROW_UP:s=(t+r-(l??1))%t}i(e[s].value)}n.preventDefault()}else(n.key===m.hg.ESCAPE||n.key===m.hg.ENTER)&&(n.preventDefault(),a());n.nativeEvent.stopImmediatePropagation(),n.stopPropagation()},children:(0,W.jsxs)("div",{className:"picker",role:"dialog","aria-modal":"true","aria-label":n,children:[h(c),d.length>0&&(0,W.jsx)(lM,{label:aO("labels.more_options"),open:s,openTrigger:()=>{o(e=>!e)},className:"picker-collapsible",children:h(d)})]})})}function lN({value:e,label:t,options:n,onChange:i,group:a="",numberOfOptionsToAlwaysShow:l}){let[r,s]=E.default.useState(!1),o=E.default.useRef(null);return(0,W.jsx)("div",{children:(0,W.jsxs)(n1,{open:r,onOpenChange:e=>s(e),children:[(0,W.jsx)(n5,{name:a,type:"button","aria-label":t,onClick:()=>s(!r),ref:o,className:r?"active":"",children:n.find(t=>t.value===e)?.icon}),r&&(0,W.jsx)(lD,{options:n,value:e,label:t,onChange:i,onClose:()=>{s(!1)},numberOfOptionsToAlwaysShow:l})]})})}var lA=E.default.forwardRef(({className:e,placeholder:t,onChange:n},i)=>(0,W.jsxs)("div",{className:(0,el.default)("QuickSearch__wrapper",e),children:[m.pf,(0,W.jsx)("input",{ref:i,className:"QuickSearch__input",type:"text",placeholder:t,onChange:e=>n(e.target.value.trim().toLowerCase())})]})),lP=({className:e,placeholder:t,children:n})=>{let i=!E.Children.count(n);return(0,W.jsx)("div",{className:(0,el.default)("ScrollableList__wrapper",e),role:"menu",children:i?(0,W.jsx)("div",{className:"empty",children:t}):n})},lR=({children:e,className:t="",style:n,title:i})=>(0,W.jsxs)("div",{className:`dropdown-menu-group ${t}`,style:n,children:[i&&(0,W.jsx)("p",{className:"dropdown-menu-group-title",children:i}),e]});lR.displayName="DropdownMenuGroup";var l_=E.default.createContext({}),lO=(e="",t=!1,n=!1)=>`dropdown-menu-item dropdown-menu-item-base ${e}
|
|
2
2
|
${t?"dropdown-menu-item--selected":""} ${n?"dropdown-menu-item--hovered":""}`.trim(),lF=(e,t)=>{let n=(0,E.useContext)(l_);return(0,m.Ib)(e,e=>{let i=new CustomEvent("menu.itemSelect",{bubbles:!0,cancelable:!0});t?.(i),i.defaultPrevented||n.onSelect?.(i)})},lz=({textStyle:e,icon:t,shortcut:n,children:i})=>{let a=hZ();return(0,W.jsxs)(W.Fragment,{children:[t&&(0,W.jsx)("div",{className:"dropdown-menu-item__icon",children:t}),(0,W.jsx)("div",{style:e,className:"dropdown-menu-item__text",children:i}),n&&!a.editor.isMobile&&(0,W.jsx)("div",{className:"dropdown-menu-item__shortcut",children:n})]})},lU=({icon:e,value:t,order:n,children:i,shortcut:a,className:l,hovered:r,selected:s,textStyle:o,onSelect:c,onClick:d,...h})=>{let u=lF(d,c),p=(0,E.useRef)(null);return(0,E.useEffect)(()=>{r&&(0===n?p.current?.scrollIntoView({block:"end"}):p.current?.scrollIntoView({block:"nearest"}))},[r,n]),(0,W.jsx)("button",{...h,ref:p,value:t,onClick:u,className:lO(l,s,r),title:h.title??h["aria-label"],children:(0,W.jsx)(lz,{textStyle:o,icon:e,shortcut:a,children:i})})};lU.displayName="DropdownMenuItem";var lB="blue",lW=({type:e=lB,children:t})=>{let{theme:n}=hq(),i={display:"inline-flex",marginLeft:"auto",padding:"2px 4px",borderRadius:6,fontSize:9,fontFamily:"Cascadia, monospace",border:n===m.G.LIGHT?"1.5px solid white":"none"};switch(e){case"green":Object.assign(i,{backgroundColor:"var(--background-color-badge)",color:"var(--color-badge)"});break;case"red":Object.assign(i,{backgroundColor:"pink",color:"darkred"});break;default:Object.assign(i,{background:"var(--color-promo)",color:"var(--color-surface-lowest)"})}return(0,W.jsx)("div",{className:"DropDownMenuItemBadge",style:i,children:t})};lW.displayName="DropdownMenuItemBadge",lU.Badge=lW;var lH=E.default.memo(({selectedFontFamily:e,hoveredFontFamily:t,onSelect:n,onHover:i,onLeave:a,onOpen:l,onClose:r})=>{let{container:s}=hX(),{fonts:o}=hG(),{showDeprecatedFonts:c}=hK(),[d,h]=(0,E.useState)(""),u=(0,E.useRef)(null),p=(0,E.useMemo)(()=>Array.from(m.Qf.registered.entries()).filter(([e,{metadata:t}])=>!t.serverSide&&!t.fallback).map(([e,{metadata:t,fontFaces:n}])=>{let i={value:e,icon:t.icon??m.Oe,text:n[0]?.fontFace?.family??"Unknown"};return t.deprecated&&Object.assign(i,{deprecated:t.deprecated,badge:{type:"red",placeholder:aO("fontList.badge.old")}}),i}).sort((e,t)=>e.text.toLowerCase()>t.text.toLowerCase()?1:-1),[]),g=(0,E.useMemo)(()=>new Set(o.getSceneFamilies()),[e]),f=(0,E.useMemo)(()=>p.filter(e=>g.has(e.value)),[p,g]),b=(0,E.useMemo)(()=>p.filter(e=>!g.has(e.value)&&(c||!e.deprecated)),[p,g,c]),v=(0,E.useMemo)(()=>(0,m.zb)([...f,...b].filter(e=>e.text?.toLowerCase().includes(d))),[f,b,d]),y=(0,E.useMemo)(()=>{let n;return t?n=v.find(e=>e.value===t):e&&(n=v.find(t=>t.value===e)),!n&&d&&(v[0]?.value?i(v[0].value):a()),n},[t,e,d,v,i,a]),x=(0,E.useCallback)(e=>{(({event:e,inputRef:t,hoveredFont:n,filteredFonts:i,onClose:a,onSelect:l,onHover:r})=>!e[m.hg.CTRL_OR_CMD]&&e.shiftKey&&e.key.toLowerCase()===m.hg.F?(t.current?.focus(),!0):e.key===m.hg.ESCAPE?(a(),!0):e.key===m.hg.ENTER?(n?.value&&l(n.value),!0):e.key===m.hg.ARROW_DOWN?(n?.next?r(n.next.value):i[0]?.value&&r(i[0].value),!0):e.key===m.hg.ARROW_UP?(n?.prev?r(n.prev.value):i[i.length-1]?.value&&r(i[i.length-1].value),!0):void 0)({event:e,inputRef:u,hoveredFont:y,filteredFonts:v,onSelect:n,onHover:i,onClose:r})&&(e.preventDefault(),e.stopPropagation())},[y,v,n,i,r]);(0,E.useEffect)(()=>(l(),()=>{r()}),[]);let w=(0,E.useMemo)(()=>v.filter(e=>g.has(e.value)),[v,g]),S=(0,E.useMemo)(()=>v.filter(e=>!g.has(e.value)),[v,g]),C=(t,a)=>(0,W.jsxs)(lU,{icon:t.icon,value:t.value,order:a,textStyle:{fontFamily:(0,m.bb)({fontFamily:t.value})},hovered:t.value===y?.value,selected:t.value===e,tabIndex:t.value===e?0:-1,onClick:e=>{n(Number(e.currentTarget.value))},onMouseMove:()=>{y?.value!==t.value&&i(t.value)},children:[t.text,t.badge&&(0,W.jsx)(lW,{type:t.badge.type,children:t.badge.placeholder})]},t.value),k=[];return w.length&&k.push((0,W.jsx)(lR,{title:aO("fontList.sceneFonts"),children:w.map(C)},"group_1")),S.length&&k.push((0,W.jsx)(lR,{title:aO("fontList.availableFonts"),children:S.map((e,t)=>C(e,t+w.length))},"group_2")),(0,W.jsxs)(lw,{className:"properties-content",container:s,style:{width:"15rem"},onClose:r,onPointerLeave:a,onKeyDown:x,children:[(0,W.jsx)(lA,{ref:u,placeholder:aO("quickSearch.placeholder"),onChange:(0,m.db)(h,20)}),(0,W.jsx)(lP,{className:"dropdown-menu fonts manual-hover",placeholder:aO("fontList.empty"),children:k.length?k:null})]})},(e,t)=>e.selectedFontFamily===t.selectedFontFamily&&e.hoveredFontFamily===t.hoveredFontFamily),l$=({selectedFontFamily:e})=>{let t=(0,E.useMemo)(()=>!!(e&&!lG(e)),[e]);return(0,W.jsx)(n5,{asChild:!0,children:(0,W.jsx)("div",{children:(0,W.jsx)(a7,{standalone:!0,icon:m.qd,title:aO("labels.showFonts"),className:"properties-trigger",testId:"font-family-show-fonts",active:t,onClick:()=>{}})})})},lY=[{value:m.F.Excalifont,icon:m.pd,text:aO("labels.handDrawn"),testId:"font-family-hand-drawn"},{value:m.F.Nunito,icon:m.Oe,text:aO("labels.normal"),testId:"font-family-normal"},{value:m.F["Comic Shanns"],icon:m.Pe,text:aO("labels.code"),testId:"font-family-code"}],lV=new Set(lY.map(e=>e.value)),lG=e=>!!e&&lV.has(e),lK=E.default.memo(({isOpened:e,selectedFontFamily:t,hoveredFontFamily:n,onSelect:i,onHover:a,onLeave:l,onPopupChange:r})=>{let s=(0,E.useMemo)(()=>lY,[]),o=(0,E.useCallback)(e=>{e&&i(e)},[i]);return(0,W.jsxs)("div",{role:"dialog","aria-modal":"true",className:"FontPicker__container",children:[(0,W.jsx)(a9,{type:"button",options:s,value:t,onClick:o}),(0,W.jsx)(lt,{}),(0,W.jsxs)(n1,{open:e,onOpenChange:r,children:[(0,W.jsx)(l$,{selectedFontFamily:t}),e&&(0,W.jsx)(lH,{selectedFontFamily:t,hoveredFontFamily:n,onSelect:o,onHover:a,onLeave:l,onOpen:()=>r(!0),onClose:()=>r(!1)})]})]})},(e,t)=>e.isOpened===t.isOpened&&e.selectedFontFamily===t.selectedFontFamily&&e.hoveredFontFamily===t.hoveredFontFamily),lZ=({updateData:e,appState:t,elements:n,testId:i})=>{let a=E.default.useRef(null),l=E.default.useRef(null),r=lQ(n,t,e=>e.opacity,!0,t.currentItemOpacity);return(0,E.useEffect)(()=>{if(a.current&&l.current){let e=a.current,t=l.current,n=r/100*(e.offsetWidth-15)+7.5;t.style.left=`${n}px`,e.style.background=`linear-gradient(to right, var(--color-slider-track) 0%, var(--color-slider-track) ${r}%, var(--button-bg) ${r}%, var(--button-bg) 100%)`}},[r]),(0,W.jsxs)("label",{className:"control-label",children:[aO("labels.opacity"),(0,W.jsxs)("div",{className:"range-wrapper",children:[(0,W.jsx)("input",{ref:a,type:"range",min:"0",max:"100",step:"10",onChange:t=>{e(+t.target.value)},value:r,className:"range-input","data-testid":i}),(0,W.jsx)("div",{className:"value-bubble",ref:l,children:0!==r?r:null}),(0,W.jsx)("div",{className:"zero-label",children:"0"})]})]})},lX=(e,t,n,i=!1)=>{let a=(0,m.xb)((0,m.vk)(e,t,{includeBoundTextElement:i}));return e.map(e=>a.get(e.id)||e.id===t.editingTextElement?.id?n(e):e)},lQ=function(e,t,n,i,a){let l=t.editingTextElement,r=(0,m.pk)(e),s=null;return l&&(s=n(l)),s||(s=(0,m.tk)(r,t)?(0,m.uk)(!0===i?r:r.filter(e=>i(e)),t,n)??("function"==typeof a?a(!0):a):"function"==typeof a?a(!1):a),s},lq=(e,t,n,i,a)=>{let l=new Set,r=lX(e,t,e=>{if((0,m._b)(e)){let t,a=i(e);l.add(a);let r=(0,m.Qj)(e,{fontSize:a});return(0,m.uj)(r,n.scene.getContainerElement(e),n.scene.getNonDeletedElementsMap()),t=r,r=(0,m.nc)(t)||!t.autoResize?t:(0,m.Pj)(t,{x:"left"===e.textAlign?e.x:e.x+(e.width-t.width)/("center"===e.textAlign?2:1),y:e.y+(e.height-t.height)/2},!1)}return e},!0),s=(0,m.xb)(r);return(0,m.vk)(e,t,{includeBoundTextElement:!0}).forEach(e=>{(0,m._b)(e)&&(0,m.Pg)(e,s)}),{elements:r,appState:{...t,currentItemFontSize:1===l.size?[...l][0]:a??t.currentItemFontSize},captureUpdate:m.Wg.IMMEDIATELY}},lJ=((0,m.$c)({name:"changeStrokeColor",label:"labels.stroke",trackEvent:!1,perform:(e,t,n)=>({...n.currentItemStrokeColor&&{elements:lX(e,t,e=>(0,m.Wi)(e.type)?(0,m.Qj)(e,{strokeColor:n.currentItemStrokeColor}):e,!0)},appState:{...t,...n},captureUpdate:n.currentItemStrokeColor?m.Wg.IMMEDIATELY:m.Wg.EVENTUALLY}),PanelComponent:({elements:e,appState:t,updateData:n,appProps:i})=>(0,W.jsxs)(W.Fragment,{children:[(0,W.jsx)("h3",{"aria-hidden":"true",children:aO("labels.stroke")}),(0,W.jsx)(lj,{topPicks:m.f,palette:m.i,type:"elementStroke",label:aO("labels.stroke"),color:lQ(e,t,e=>e.strokeColor,!0,t.currentItemStrokeColor),onChange:e=>n({currentItemStrokeColor:e}),elements:e,appState:t,updateData:n})]})}),(0,m.$c)({name:"changeBackgroundColor",label:"labels.changeBackground",trackEvent:!1,perform:(e,t,n)=>({...n.currentItemBackgroundColor&&{elements:lX(e,t,e=>(0,m.Qj)(e,{backgroundColor:n.currentItemBackgroundColor}))},appState:{...t,...n},captureUpdate:n.currentItemBackgroundColor?m.Wg.IMMEDIATELY:m.Wg.EVENTUALLY}),PanelComponent:({elements:e,appState:t,updateData:n,appProps:i})=>(0,W.jsxs)(W.Fragment,{children:[(0,W.jsx)("h3",{"aria-hidden":"true",children:aO("labels.background")}),(0,W.jsx)(lj,{topPicks:m.g,palette:m.j,type:"elementBackground",label:aO("labels.background"),color:lQ(e,t,e=>e.backgroundColor,!0,t.currentItemBackgroundColor),onChange:e=>n({currentItemBackgroundColor:e}),elements:e,appState:t,updateData:n})]})}),(0,m.$c)({name:"changeFillStyle",label:"labels.fill",trackEvent:!1,perform:(e,t,n,i)=>(a8("element","changeFillStyle",`${n} (${i.device.editor.isMobile?"mobile":"desktop"})`),{elements:lX(e,t,e=>(0,m.Qj)(e,{fillStyle:n})),appState:{...t,currentItemFillStyle:n},captureUpdate:m.Wg.IMMEDIATELY}),PanelComponent:({elements:e,appState:t,updateData:n})=>{let i=(0,m.vk)(e,t),a=i.length>0&&i.every(e=>"zigzag"===e.fillStyle);return(0,W.jsxs)("fieldset",{children:[(0,W.jsx)("legend",{children:aO("labels.fill")}),(0,W.jsx)(a9,{type:"button",options:[{value:"hachure",text:`${a?aO("labels.zigzag"):aO("labels.hachure")} (${(0,m.kb)("Alt-Click")})`,icon:a?m.je:m.ke,active:!!a||void 0,testId:"fill-hachure"},{value:"cross-hatch",text:aO("labels.crossHatch"),icon:m.le,testId:"fill-cross-hatch"},{value:"solid",text:aO("labels.solid"),icon:m.me,testId:"fill-solid"}],value:lQ(e,t,e=>e.fillStyle,e=>e.hasOwnProperty("fillStyle"),e=>e?null:t.currentItemFillStyle),onClick:(e,t)=>{n(t.altKey&&"hachure"===e&&i.every(e=>"hachure"===e.fillStyle)?"zigzag":e)}})]})}}),(0,m.$c)({name:"changeStrokeWidth",label:"labels.strokeWidth",trackEvent:!1,perform:(e,t,n)=>({elements:lX(e,t,e=>(0,m.Qj)(e,{strokeWidth:n})),appState:{...t,currentItemStrokeWidth:n},captureUpdate:m.Wg.IMMEDIATELY}),PanelComponent:({elements:e,appState:t,updateData:n})=>(0,W.jsxs)("fieldset",{children:[(0,W.jsx)("legend",{children:aO("labels.strokeWidth")}),(0,W.jsx)(a9,{group:"stroke-width",options:[{value:m.va.thin,text:aO("labels.thin"),icon:m.ne,testId:"strokeWidth-thin"},{value:m.va.bold,text:aO("labels.bold"),icon:m.oe,testId:"strokeWidth-bold"},{value:m.va.extraBold,text:aO("labels.extraBold"),icon:m.pe,testId:"strokeWidth-extraBold"}],value:lQ(e,t,e=>e.strokeWidth,e=>e.hasOwnProperty("strokeWidth"),e=>e?null:t.currentItemStrokeWidth),onChange:e=>n(e)})]})}),(0,m.$c)({name:"changeSloppiness",label:"labels.sloppiness",trackEvent:!1,perform:(e,t,n)=>({elements:lX(e,t,e=>(0,m.Qj)(e,{seed:(0,m.rc)(),roughness:n})),appState:{...t,currentItemRoughness:n},captureUpdate:m.Wg.IMMEDIATELY}),PanelComponent:({elements:e,appState:t,updateData:n})=>(0,W.jsxs)("fieldset",{children:[(0,W.jsx)("legend",{children:aO("labels.sloppiness")}),(0,W.jsx)(a9,{group:"sloppiness",options:[{value:0,text:aO("labels.architect"),icon:m.se},{value:1,text:aO("labels.artist"),icon:m.te},{value:2,text:aO("labels.cartoonist"),icon:m.ue}],value:lQ(e,t,e=>e.roughness,e=>e.hasOwnProperty("roughness"),e=>e?null:t.currentItemRoughness),onChange:e=>n(e)})]})}),(0,m.$c)({name:"changeStrokeStyle",label:"labels.strokeStyle",trackEvent:!1,perform:(e,t,n)=>({elements:lX(e,t,e=>(0,m.Qj)(e,{strokeStyle:n})),appState:{...t,currentItemStrokeStyle:n},captureUpdate:m.Wg.IMMEDIATELY}),PanelComponent:({elements:e,appState:t,updateData:n})=>(0,W.jsxs)("fieldset",{children:[(0,W.jsx)("legend",{children:aO("labels.strokeStyle")}),(0,W.jsx)(a9,{group:"strokeStyle",options:[{value:"solid",text:aO("labels.strokeStyle_solid"),icon:m.ne},{value:"dashed",text:aO("labels.strokeStyle_dashed"),icon:m.qe},{value:"dotted",text:aO("labels.strokeStyle_dotted"),icon:m.re}],value:lQ(e,t,e=>e.strokeStyle,e=>e.hasOwnProperty("strokeStyle"),e=>e?null:t.currentItemStrokeStyle),onChange:e=>n(e)})]})}),(0,m.$c)({name:"changeOpacity",label:"labels.opacity",trackEvent:!1,perform:(e,t,n)=>({elements:lX(e,t,e=>(0,m.Qj)(e,{opacity:n}),!0),appState:{...t,currentItemOpacity:n},captureUpdate:m.Wg.IMMEDIATELY}),PanelComponent:({elements:e,appState:t,updateData:n})=>(0,W.jsx)(lZ,{updateData:n,elements:e,appState:t,testId:"opacity"})}),(0,m.$c)({name:"changeFontSize",label:"labels.fontSize",trackEvent:!1,perform:(e,t,n,i)=>lq(e,t,i,()=>n,n),PanelComponent:({elements:e,appState:t,updateData:n,app:i})=>(0,W.jsxs)("fieldset",{children:[(0,W.jsx)("legend",{children:aO("labels.fontSize")}),(0,W.jsx)(a9,{group:"font-size",options:[{value:16,text:aO("labels.small"),icon:m.Je,testId:"fontSize-small"},{value:20,text:aO("labels.medium"),icon:m.Ke,testId:"fontSize-medium"},{value:28,text:aO("labels.large"),icon:m.Le,testId:"fontSize-large"},{value:36,text:aO("labels.veryLarge"),icon:m.Me,testId:"fontSize-veryLarge"}],value:lQ(e,t,e=>{if((0,m._b)(e))return e.fontSize;let t=(0,m.zj)(e,i.scene.getNonDeletedElementsMap());return t?t.fontSize:null},e=>(0,m._b)(e)||null!==(0,m.zj)(e,i.scene.getNonDeletedElementsMap()),e=>e?null:t.currentItemFontSize||m.I),onChange:e=>n(e)})]})}),(0,m.$c)({name:"decreaseFontSize",label:"labels.decreaseFontSize",icon:m.Ne,trackEvent:!1,perform:(e,t,n,i)=>lq(e,t,i,e=>Math.round(1/1.1*e.fontSize)),keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.shiftKey&&(e.key===m.hg.CHEVRON_LEFT||e.key===m.hg.COMMA)})),l0=(0,m.$c)({name:"increaseFontSize",label:"labels.increaseFontSize",icon:m.Ne,trackEvent:!1,perform:(e,t,n,i)=>lq(e,t,i,e=>Math.round(1.1*e.fontSize)),keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.shiftKey&&(e.key===m.hg.CHEVRON_RIGHT||e.key===m.hg.PERIOD)}),l1=((0,m.$c)({name:"changeFontFamily",label:"labels.fontFamily",trackEvent:!1,perform:(e,t,n,i)=>{let{cachedElements:a,resetAll:l,resetContainers:r,...s}=n;if(l)return{elements:lX(e,t,e=>{let t=a?.get(e.id);return t?(0,m.Qj)(e,{...t}):e},!0),appState:{...t,...s},captureUpdate:m.Wg.NEVER};let{currentItemFontFamily:o,currentHoveredFontFamily:c}=n,d=m.Wg.EVENTUALLY,h,u=!1;if(o)h=o,d=m.Wg.IMMEDIATELY;else if(c){h=c,d=m.Wg.EVENTUALLY;let n=(0,m.vk)(e,t,{includeBoundTextElement:!0}).filter(e=>(0,m._b)(e));if(n.length>200)u=!0;else{let e=0,t=0;for(;e<n.length&&t<5e3;){let i=n[e];t+=i?.originalText.length||0,e++}t>5e3&&(u=!0)}}let p={appState:{...t,...s},captureUpdate:d};if(h&&!u){let n=new Map,l=new Set,s=!1,d=Array.from(m.Qf.loadedFontsCache.values()),u=Object.entries(m.F).find(([e,t])=>t===h)?.[0];c&&u&&d.some(e=>e.startsWith(u))&&(s=!0),Object.assign(p,{elements:lX(e,t,e=>{if((0,m._b)(e)&&(e.fontFamily!==h||o)){let t=(0,m.Qj)(e,{fontFamily:h,lineHeight:(0,m.Rf)(h)}),o=a?.get(e.containerId||"")||{},c=i.scene.getContainerElement(e);return r&&c&&o&&(0,m.Pj)(c,{...o},!1),s||(l=new Set([...l,...Array.from(t.originalText)])),n.set(t,c),t}return e},!0)});let g=`10px ${(0,m.bb)({fontFamily:h})}`,f=Array.from(l.values()).join();if(s||window.document.fonts.check(g,f))for(let[e,t]of n)(0,m.uj)(e,t,i.scene.getNonDeletedElementsMap(),!1);else window.document.fonts.load(g,f).then(e=>{for(let[e,t]of n){let n=i.scene.getElement(e.id),a=t?i.scene.getElement(t.id):null;n&&(0,m.uj)(n,a,i.scene.getNonDeletedElementsMap(),!1)}i.fonts.onLoaded(e)})}return p},PanelComponent:({elements:e,appState:t,app:n,updateData:i})=>{let a=(0,E.useRef)(new Map),l=(0,E.useRef)(null),[r,s]=(0,E.useState)({}),o=(0,E.useRef)(!0),c=(0,E.useMemo)(()=>{let i=(e,n)=>lQ(e,t,e=>{if((0,m._b)(e))return e.fontFamily;let t=(0,m.zj)(e,n);return t?t.fontFamily:null},e=>(0,m._b)(e)||null!==(0,m.zj)(e,n),e=>e?null:t.currentItemFontFamily||m.J);return"fontFamily"===r.openPopup&&"fontFamily"===t.openPopup?i(Array.from(a.current?.values()??[]),a.current):r.openPopup||"fontFamily"===t.openPopup?l.current:i(e,n.scene.getNonDeletedElementsMap())},[r.openPopup,t,e,n.scene]);return(0,E.useEffect)(()=>{l.current=c},[c]),(0,E.useEffect)(()=>{Object.keys(r).length&&(i(r),s({}))},[r]),(0,E.useEffect)(()=>(o.current=!1,()=>{o.current=!0}),[]),(0,W.jsxs)("fieldset",{children:[(0,W.jsx)("legend",{children:aO("labels.fontFamily")}),(0,W.jsx)(lK,{isOpened:"fontFamily"===t.openPopup,selectedFontFamily:c,hoveredFontFamily:t.currentHoveredFontFamily,onSelect:e=>{s({openPopup:null,currentHoveredFontFamily:null,currentItemFontFamily:e}),a.current.clear()},onHover:e=>{s({currentHoveredFontFamily:e,cachedElements:new Map(a.current),resetContainers:!0})},onLeave:()=>{s({currentHoveredFontFamily:null,cachedElements:new Map(a.current),resetAll:!0})},onPopupChange:l=>{if(l){a.current.clear();let{editingTextElement:i}=t;if(i?.type==="text"){let e=n.scene.getElement(i.id);a.current.set(i.id,(0,m.Qj)(e||i,{},!0))}else for(let n of(0,m.vk)(e,t,{includeBoundTextElement:!0}))a.current.set(n.id,(0,m.Qj)(n,{},!0));s({openPopup:"fontFamily"})}else{let e={openPopup:null,currentHoveredFontFamily:null,cachedElements:new Map(a.current),resetAll:!0};o.current?i({...r,...e}):s(e),a.current.clear()}}})]})}}),(0,m.$c)({name:"changeTextAlign",label:"Change text alignment",trackEvent:!1,perform:(e,t,n,i)=>({elements:lX(e,t,e=>{if((0,m._b)(e)){let t=(0,m.Qj)(e,{textAlign:n});return(0,m.uj)(t,i.scene.getContainerElement(e),i.scene.getNonDeletedElementsMap()),t}return e},!0),appState:{...t,currentItemTextAlign:n},captureUpdate:m.Wg.IMMEDIATELY}),PanelComponent:({elements:e,appState:t,updateData:n,app:i})=>{let a=i.scene.getNonDeletedElementsMap();return(0,W.jsxs)("fieldset",{children:[(0,W.jsx)("legend",{children:aO("labels.textAlign")}),(0,W.jsx)(a9,{group:"text-align",options:[{value:"left",text:aO("labels.left"),icon:m.Qe,testId:"align-left"},{value:"center",text:aO("labels.center"),icon:m.Re,testId:"align-horizontal-center"},{value:"right",text:aO("labels.right"),icon:m.Se,testId:"align-right"}],value:lQ(e,t,e=>{if((0,m._b)(e))return e.textAlign;let t=(0,m.zj)(e,a);return t?t.textAlign:null},e=>(0,m._b)(e)||null!==(0,m.zj)(e,a),e=>e?null:t.currentItemTextAlign),onChange:e=>n(e)})]})}}),(0,m.$c)({name:"changeVerticalAlign",label:"Change vertical alignment",trackEvent:{category:"element"},perform:(e,t,n,i)=>({elements:lX(e,t,e=>{if((0,m._b)(e)){let t=(0,m.Qj)(e,{verticalAlign:n});return(0,m.uj)(t,i.scene.getContainerElement(e),i.scene.getNonDeletedElementsMap()),t}return e},!0),appState:{...t},captureUpdate:m.Wg.IMMEDIATELY}),PanelComponent:({elements:e,appState:t,updateData:n,app:i})=>(0,W.jsx)("fieldset",{children:(0,W.jsx)(a9,{group:"text-align",options:[{value:m.sa.TOP,text:aO("labels.alignTop"),icon:(0,W.jsx)(m.Te,{theme:t.theme}),testId:"align-top"},{value:m.sa.MIDDLE,text:aO("labels.centerVertically"),icon:(0,W.jsx)(m.Ve,{theme:t.theme}),testId:"align-middle"},{value:m.sa.BOTTOM,text:aO("labels.alignBottom"),icon:(0,W.jsx)(m.Ue,{theme:t.theme}),testId:"align-bottom"}],value:lQ(e,t,e=>{if((0,m._b)(e)&&e.containerId)return e.verticalAlign;let t=(0,m.zj)(e,i.scene.getNonDeletedElementsMap());return t?t.verticalAlign:null},e=>(0,m._b)(e)||null!==(0,m.zj)(e,i.scene.getNonDeletedElementsMap()),e=>e?null:m.sa.MIDDLE),onChange:e=>n(e)})})}),(0,m.$c)({name:"changeRoundness",label:"Change edge roundness",trackEvent:!1,perform:(e,t,n)=>({elements:lX(e,t,e=>(0,m.ec)(e)?e:(0,m.Qj)(e,{roundness:"round"===n?{type:(0,m.oc)(e.type)?m.ua.ADAPTIVE_RADIUS:m.ua.PROPORTIONAL_RADIUS}:null})),appState:{...t,currentItemRoundness:n},captureUpdate:m.Wg.IMMEDIATELY}),PanelComponent:({elements:e,appState:t,updateData:n})=>{let i=(0,m.wk)((0,m.pk)(e),t).some(e=>e.roundness?.type===m.ua.LEGACY);return(0,W.jsxs)("fieldset",{children:[(0,W.jsx)("legend",{children:aO("labels.edges")}),(0,W.jsx)(a9,{group:"edges",options:[{value:"sharp",text:aO("labels.sharp"),icon:m.ve},{value:"round",text:aO("labels.round"),icon:m.we}],value:lQ(e,t,e=>i?null:e.roundness?"round":"sharp",e=>!(0,m.dc)(e)&&e.hasOwnProperty("roundness"),e=>e?null:t.currentItemRoundness),onChange:e=>n(e)})]})}}),e=>[{value:null,text:aO("labels.arrowhead_none"),keyBinding:"q",icon:m.xe},{value:"arrow",text:aO("labels.arrowhead_arrow"),keyBinding:"w",icon:(0,W.jsx)(m.ye,{flip:e})},{value:"triangle",text:aO("labels.arrowhead_triangle"),icon:(0,W.jsx)(m.Ce,{flip:e}),keyBinding:"e"},{value:"triangle_outline",text:aO("labels.arrowhead_triangle_outline"),icon:(0,W.jsx)(m.De,{flip:e}),keyBinding:"r"},{value:"circle",text:aO("labels.arrowhead_circle"),keyBinding:"a",icon:(0,W.jsx)(m.ze,{flip:e})},{value:"circle_outline",text:aO("labels.arrowhead_circle_outline"),keyBinding:"s",icon:(0,W.jsx)(m.Ae,{flip:e})},{value:"diamond",text:aO("labels.arrowhead_diamond"),icon:(0,W.jsx)(m.Ee,{flip:e}),keyBinding:"d"},{value:"diamond_outline",text:aO("labels.arrowhead_diamond_outline"),icon:(0,W.jsx)(m.Fe,{flip:e}),keyBinding:"f"},{value:"bar",text:aO("labels.arrowhead_bar"),keyBinding:"z",icon:(0,W.jsx)(m.Be,{flip:e})},{value:"crowfoot_one",text:aO("labels.arrowhead_crowfoot_one"),icon:(0,W.jsx)(m.He,{flip:e}),keyBinding:"c"},{value:"crowfoot_many",text:aO("labels.arrowhead_crowfoot_many"),icon:(0,W.jsx)(m.Ge,{flip:e}),keyBinding:"x"},{value:"crowfoot_one_or_many",text:aO("labels.arrowhead_crowfoot_one_or_many"),icon:(0,W.jsx)(m.Ie,{flip:e}),keyBinding:"v"}]);(0,m.$c)({name:"changeArrowhead",label:"Change arrowheads",trackEvent:!1,perform:(e,t,n)=>({elements:lX(e,t,e=>{if((0,m.cc)(e)){let{position:t,type:i}=n;if("start"===t)return(0,m.Qj)(e,{startArrowhead:i});if("end"===t)return(0,m.Qj)(e,{endArrowhead:i})}return e}),appState:{...t,["start"===n.position?"currentItemStartArrowhead":"currentItemEndArrowhead"]:n.type},captureUpdate:m.Wg.IMMEDIATELY}),PanelComponent:({elements:e,appState:t,updateData:n})=>{let i=aA.rtl;return(0,W.jsxs)("fieldset",{children:[(0,W.jsx)("legend",{children:aO("labels.arrowheads")}),(0,W.jsxs)("div",{className:"iconSelectList buttonList",children:[(0,W.jsx)(lN,{label:"arrowhead_start",options:l1(!i),value:lQ(e,t,e=>(0,m.cc)(e)&&(0,m.$i)(e.type)?e.startArrowhead:t.currentItemStartArrowhead,!0,t.currentItemStartArrowhead),onChange:e=>n({position:"start",type:e}),numberOfOptionsToAlwaysShow:4}),(0,W.jsx)(lN,{label:"arrowhead_end",group:"arrowheads",options:l1(!!i),value:lQ(e,t,e=>(0,m.cc)(e)&&(0,m.$i)(e.type)?e.endArrowhead:t.currentItemEndArrowhead,!0,t.currentItemEndArrowhead),onChange:e=>n({position:"end",type:e}),numberOfOptionsToAlwaysShow:4})]})]})}}),(0,m.$c)({name:"changeArrowType",label:"Change arrow types",trackEvent:!1,perform:(e,t,n,i)=>{let a=lX(e,t,a=>{if(!(0,m.dc)(a))return a;let l=(0,m.Qj)(a,{roundness:n===m.Fa.round?{type:m.ua.PROPORTIONAL_RADIUS}:null,elbowed:n===m.Fa.elbow,points:n===m.Fa.elbow||a.elbowed?[a.points[0],a.points[a.points.length-1]]:a.points});if((0,m.ec)(l)){let n=i.scene.getNonDeletedElementsMap();i.dismissLinearEditor();let a=m.pj.getPointAtIndexGlobalCoordinates(l,0,n),r=m.pj.getPointAtIndexGlobalCoordinates(l,-1,n),s=!l.startBinding&&(0,m.Og)((0,m.ob)(a),e,n,t.zoom,!1,!0),o=!l.endBinding&&(0,m.Og)((0,m.ob)(r),e,n,t.zoom,!1,!0),c=s||l.startBinding&&n.get(l.startBinding.elementId),d=o||l.endBinding&&n.get(l.endBinding.elementId),h=s?(0,m.Qg)(l,s,"start"):a,u=o?(0,m.Qg)(l,o,"end"):r;s&&(0,m.Mg)(l,s,"start",n),o&&(0,m.Mg)(l,o,"end",n),(0,m.Pj)(l,{points:[h,u].map(e=>(0,m.Ua)(e[0]-l.x,e[1]-l.y)),...c&&l.startBinding?{startBinding:{...l.startBinding,...(0,m.Rg)(l,c,"start",n)}}:{},...d&&l.endBinding?{endBinding:{...l.endBinding,...(0,m.Rg)(l,d,"end",n)}}:{}}),m.pj.updateEditorMidPointsCache(l,n,i.state)}return l}),l={...t,currentItemArrowType:n},r=t.selectedLinearElement?.elementId;if(r){let e=a.find(e=>e.id===r);e&&(l.selectedLinearElement=new m.pj(e))}return{elements:a,appState:l,captureUpdate:m.Wg.IMMEDIATELY}},PanelComponent:({elements:e,appState:t,updateData:n})=>(0,W.jsxs)("fieldset",{children:[(0,W.jsx)("legend",{children:aO("labels.arrowtypes")}),(0,W.jsx)(a9,{group:"arrowtypes",options:[{value:m.Fa.sharp,text:aO("labels.arrowtype_sharp"),icon:m.If,testId:"sharp-arrow"},{value:m.Fa.round,text:aO("labels.arrowtype_round"),icon:m.Kf,testId:"round-arrow"},{value:m.Fa.elbow,text:aO("labels.arrowtype_elbowed"),icon:m.Jf,testId:"elbow-arrow"}],value:lQ(e,t,e=>(0,m.dc)(e)?e.elbowed?m.Fa.elbow:e.roundness?m.Fa.round:m.Fa.sharp:null,e=>(0,m.dc)(e),e=>e?null:t.currentItemArrowType),onChange:e=>n(e)})]})});var l2=({viewportX:e,viewportY:t,nextZoom:n},i)=>{let a=e-i.offsetLeft,l=t-i.offsetTop,r=i.zoom.value;return{scrollX:i.scrollX+(a-a/r)+-(a-a/n),scrollY:i.scrollY+(l-l/r)+-(l-l/n),zoom:{value:n}}},l3=()=>{let e=document.querySelector(".excalidraw-tooltip");if(e)return e;let t=document.createElement("div");return document.body.appendChild(t),t.classList.add("excalidraw-tooltip"),t},l5=(e,t,n="bottom")=>{let i,a=e.getBoundingClientRect(),l=window.innerWidth,r=window.innerHeight,s=t.left+t.width/2-a.width/2;s<0?s=5:s+a.width>=l&&(s=l-a.width-5),"bottom"===n?(i=t.top+t.height+5)+a.height>=r&&(i=t.top-a.height-5):(i=t.top-a.height-5)<0&&(i=t.top+t.height+5),Object.assign(e.style,{top:`${i}px`,left:`${s}px`})},l4=({children:e,label:t,long:n=!1,style:i,disabled:a})=>((0,E.useEffect)(()=>()=>l3().classList.remove("excalidraw-tooltip--visible"),[]),a?null:(0,W.jsx)("div",{className:"excalidraw-tooltip-wrapper",onPointerEnter:e=>{var i,a;return i=e.currentTarget,a=l3(),void(a.classList.add("excalidraw-tooltip--visible"),a.style.minWidth=n?"50ch":"10ch",a.style.maxWidth=n?"50ch":"15ch",a.textContent=t,l5(a,i.getBoundingClientRect()))},onPointerLeave:()=>l3().classList.remove("excalidraw-tooltip--visible"),style:i,children:e}));(0,m.$c)({name:"changeViewBackgroundColor",label:"labels.canvasBackground",paletteName:"Change canvas background color",trackEvent:!1,predicate:(e,t,n,i)=>!!i.props.UIOptions.canvasActions.changeViewBackgroundColor&&!t.viewModeEnabled,perform:(e,t,n)=>({appState:{...t,...n},captureUpdate:n.viewBackgroundColor?m.Wg.IMMEDIATELY:m.Wg.EVENTUALLY}),PanelComponent:({elements:e,appState:t,updateData:n,appProps:i})=>(0,W.jsx)(lj,{palette:null,topPicks:m.h,label:aO("labels.canvasBackground"),type:"canvasBackground",color:t.viewBackgroundColor,onChange:e=>n({viewBackgroundColor:e}),"data-testid":"canvas-background-picker",elements:e,appState:t,updateData:n})});var l6=(0,m.$c)({name:"clearCanvas",label:"labels.clearCanvas",paletteName:"Clear canvas",icon:m.ud,trackEvent:{category:"canvas"},predicate:(e,t,n,i)=>!!i.props.UIOptions.canvasActions.clearCanvas&&!t.viewModeEnabled&&t.openDialog?.name!=="elementLinkSelector",perform:(e,t,n,i)=>(i.imageCache.clear(),{elements:e.map(e=>(0,m.Qj)(e,{isDeleted:!0})),appState:{...(0,m.Fc)(),files:{},theme:t.theme,penMode:t.penMode,penDetected:t.penDetected,exportBackground:t.exportBackground,exportEmbedScene:t.exportEmbedScene,gridSize:t.gridSize,gridStep:t.gridStep,gridModeEnabled:t.gridModeEnabled,stats:t.stats,pasteDialog:t.pasteDialog,activeTool:"image"===t.activeTool.type?{...t.activeTool,type:"selection"}:t.activeTool},captureUpdate:m.Wg.IMMEDIATELY})}),l8=(0,m.$c)({name:"zoomIn",label:"buttons.zoomIn",viewMode:!0,icon:m.rd,trackEvent:{category:"canvas"},perform:(e,t,n,i)=>({appState:{...t,...l2({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:(0,m.Ak)(t.zoom.value+m.$)},t),userToFollow:null},captureUpdate:m.Wg.EVENTUALLY}),PanelComponent:({updateData:e,appState:t})=>(0,W.jsx)(aH,{type:"button",className:"zoom-in-button zoom-button",icon:m.rd,title:`${aO("buttons.zoomIn")} \u2014 ${(0,m.kb)("CtrlOrCmd++")}`,"aria-label":aO("buttons.zoomIn"),disabled:t.zoom.value>=m.ba,onClick:()=>{e(null)}}),keyTest:e=>(e.code===m.gg.EQUAL||e.code===m.gg.NUM_ADD)&&(e[m.hg.CTRL_OR_CMD]||e.shiftKey)}),l7=(0,m.$c)({name:"zoomOut",label:"buttons.zoomOut",icon:m.sd,viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,n,i)=>({appState:{...t,...l2({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:(0,m.Ak)(t.zoom.value-m.$)},t),userToFollow:null},captureUpdate:m.Wg.EVENTUALLY}),PanelComponent:({updateData:e,appState:t})=>(0,W.jsx)(aH,{type:"button",className:"zoom-out-button zoom-button",icon:m.sd,title:`${aO("buttons.zoomOut")} \u2014 ${(0,m.kb)("CtrlOrCmd+-")}`,"aria-label":aO("buttons.zoomOut"),disabled:t.zoom.value<=m.aa,onClick:()=>{e(null)}}),keyTest:e=>(e.code===m.gg.MINUS||e.code===m.gg.NUM_SUBTRACT)&&(e[m.hg.CTRL_OR_CMD]||e.shiftKey)}),l9=(0,m.$c)({name:"resetZoom",label:"buttons.resetZoom",icon:m.td,viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,n,i)=>({appState:{...t,...l2({viewportX:t.width/2+t.offsetLeft,viewportY:t.height/2+t.offsetTop,nextZoom:(0,m.Ak)(1)},t),userToFollow:null},captureUpdate:m.Wg.EVENTUALLY}),PanelComponent:({updateData:e,appState:t})=>(0,W.jsx)(l4,{label:aO("buttons.resetZoom"),style:{height:"100%"},children:(0,W.jsxs)(aH,{type:"button",className:"reset-zoom-button zoom-button",title:aO("buttons.resetZoom"),"aria-label":aO("buttons.resetZoom"),onClick:()=>{e(null)},children:[(100*t.zoom.value).toFixed(0),"%"]})}),keyTest:e=>(e.code===m.gg.ZERO||e.code===m.gg.NUM_ZERO)&&(e[m.hg.CTRL_OR_CMD]||e.shiftKey)}),re=({bounds:e,appState:t,canvasOffsets:n,fitToViewport:i=!1,viewportZoomFactor:a=1,minZoom:l=-1/0,maxZoom:r=1/0})=>{a=(0,m.Ia)(a,m.aa,m.ba);let[s,o,c,d]=e,h=n?.left??0,u=n?.top??0,p=n?.right??0,g=n?.bottom??0,f=t.width-h-p,b=t.height-u-g,v;v=i?Math.min(f/(c-s),b/(d-o))*a:((e,t,n=1)=>{let[i,a,l,r]=e;return Math.min(Math.min(t.width/(l-i),t.height/(r-a))*(0,m.Ia)(n,.1,1),1)})(e,{width:f,height:b},a);let y=(0,m.Ak)((0,m.Ia)((0,m.Ka)(v,m.$,"floor"),l,r)),E=(0,m.yk)({scenePoint:{x:(s+c)/2,y:(o+d)/2},viewportDimensions:{width:t.width,height:t.height},offsets:n,zoom:{value:y}});return{appState:{...t,scrollX:E.scrollX,scrollY:E.scrollY,zoom:{value:y}},captureUpdate:m.Wg.EVENTUALLY}},rt=({canvasOffsets:e,targetElements:t,appState:n,fitToViewport:i,viewportZoomFactor:a,minZoom:l,maxZoom:r})=>re({canvasOffsets:e,bounds:(0,m.bj)((0,m.pk)(t)),appState:n,fitToViewport:i,viewportZoomFactor:a,minZoom:l,maxZoom:r}),rn=((0,m.$c)({name:"zoomToFitSelectionInViewport",label:"labels.zoomToFitViewport",icon:m.zf,trackEvent:{category:"canvas"},perform:(e,t,n,i)=>{let a=i.scene.getSelectedElements(t);return rt({targetElements:a.length?a:e,appState:{...t,userToFollow:null},fitToViewport:!1,canvasOffsets:i.getEditorUIOffsets()})},keyTest:e=>e.code===m.gg.TWO&&e.shiftKey&&!e.altKey&&!e[m.hg.CTRL_OR_CMD]}),(0,m.$c)({name:"zoomToFitSelection",label:"helpDialog.zoomToSelection",icon:m.zf,trackEvent:{category:"canvas"},perform:(e,t,n,i)=>{let a=i.scene.getSelectedElements(t);return rt({targetElements:a.length?a:e,appState:{...t,userToFollow:null},fitToViewport:!0,canvasOffsets:i.getEditorUIOffsets()})},keyTest:e=>e.code===m.gg.THREE&&e.shiftKey&&!e.altKey&&!e[m.hg.CTRL_OR_CMD]}),(0,m.$c)({name:"zoomToFit",label:"helpDialog.zoomToFit",icon:m.zf,viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,n,i)=>rt({targetElements:e,appState:{...t,userToFollow:null},fitToViewport:!1,canvasOffsets:i.getEditorUIOffsets()}),keyTest:e=>e.code===m.gg.ONE&&e.shiftKey&&!e.altKey&&!e[m.hg.CTRL_OR_CMD]}),(0,m.$c)({name:"toggleTheme",label:(e,t)=>t.theme===m.G.DARK?"buttons.lightMode":"buttons.darkMode",keywords:["toggle","dark","light","mode","theme"],icon:e=>e.theme===m.G.LIGHT?m.xd:m.yd,viewMode:!0,trackEvent:{category:"canvas"},perform:(e,t,n)=>({appState:{...t,theme:n||(t.theme===m.G.LIGHT?m.G.DARK:m.G.LIGHT)},captureUpdate:m.Wg.EVENTUALLY}),keyTest:e=>e.altKey&&e.shiftKey&&e.code===m.gg.D,predicate:(e,t,n,i)=>!!i.props.UIOptions.canvasActions.toggleTheme})),ri=((0,m.$c)({name:"toggleEraserTool",label:"toolBar.eraser",trackEvent:{category:"toolbar"},perform:(e,t)=>{let n;return n=(0,m.Gc)(t)?(0,m.jb)(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):(0,m.jb)(t,{type:"eraser",lastActiveToolBeforeEraser:t.activeTool}),{appState:{...t,selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null,activeTool:n},captureUpdate:m.Wg.IMMEDIATELY}},keyTest:e=>e.key===m.hg.E}),(0,m.$c)({name:"toggleHandTool",label:"toolBar.hand",paletteName:"Toggle hand tool",trackEvent:{category:"toolbar"},icon:m.Ye,viewMode:!1,perform:(e,t,n,i)=>{let a;return(0,m.Hc)(t)?a=(0,m.jb)(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):(a=(0,m.jb)(t,{type:"hand",lastActiveToolBeforeEraser:t.activeTool}),(0,m.bd)(i.interactiveCanvas,m.z.GRAB)),{appState:{...t,selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null,activeTool:a},captureUpdate:m.Wg.IMMEDIATELY}},keyTest:e=>!e.altKey&&!e[m.hg.CTRL_OR_CMD]&&e.key===m.hg.H})),ra=(0,m.$c)({name:"finalize",label:"",trackEvent:!1,perform:(e,t,n,i)=>{let a,{interactiveCanvas:l,focusContainer:r,scene:s}=i,o=s.getNonDeletedElementsMap();if(t.editingLinearElement){let{elementId:n,startBindingElement:i,endBindingElement:a}=t.editingLinearElement,l=m.pj.getElement(n,o);if(l)return(0,m.gc)(l)&&(0,m.Ig)(l,i,a,o,s),{elements:l.points.length<2||(0,m.Sj)(l)?e.filter(e=>e.id!==l.id):void 0,appState:{...t,cursorButton:"up",editingLinearElement:null},captureUpdate:m.Wg.IMMEDIATELY}}let c=e,d=t.pendingImageElementId&&s.getElement(t.pendingImageElementId);d&&(0,m.Pj)(d,{isDeleted:!0},!1),window.document.activeElement instanceof HTMLElement&&r();let h=t.multiElement?t.multiElement:t.newElement?.type==="freedraw"?t.newElement:null;if(h){if("freedraw"!==h.type&&"touch"!==t.lastPointerDownWith){let{points:e,lastCommittedPoint:t}=h;t&&e[e.length-1]===t||(0,m.Pj)(h,{points:h.points.slice(0,-1)})}(0,m.Sj)(h)&&(c=c.filter(e=>e.id!==h.id));let n=(0,m.xg)(h.points,t.zoom.value);if(("line"===h.type||"freedraw"===h.type)&&n){let e=h.points,t=e[0];(0,m.Pj)(h,{points:e.map((n,i)=>i===e.length-1?(0,m.Ua)(t[0],t[1]):n)})}if((0,m.gc)(h)&&!n&&h.points.length>1){let[n,i]=m.pj.getPointAtIndexGlobalCoordinates(h,-1,(0,m.xb)(e));(0,m.Lg)(h,t,{x:n,y:i},o,e)}}return(t.activeTool.locked||"freedraw"===t.activeTool.type)&&h||(0,m.ad)(l),a="eraser"===t.activeTool.type?(0,m.jb)(t,{...t.activeTool.lastActiveTool||{type:"selection"},lastActiveToolBeforeEraser:null}):(0,m.jb)(t,{type:"selection"}),{elements:c,appState:{...t,cursorButton:"up",activeTool:(t.activeTool.locked||"freedraw"===t.activeTool.type)&&h?t.activeTool:a,activeEmbeddable:null,newElement:null,selectionElement:null,multiElement:null,editingTextElement:null,startBoundElement:null,suggestedBindings:[],selectedElementIds:h&&!t.activeTool.locked&&"freedraw"!==t.activeTool.type?{...t.selectedElementIds,[h.id]:!0}:t.selectedElementIds,selectedLinearElement:h&&(0,m.cc)(h)?new m.pj(h):t.selectedLinearElement,pendingImageElementId:null},captureUpdate:m.Wg.IMMEDIATELY}},keyTest:(e,t)=>e.key===m.hg.ESCAPE&&(null!==t.editingLinearElement||!t.newElement&&null===t.multiElement)||(e.key===m.hg.ESCAPE||e.key===m.hg.ENTER)&&null!==t.multiElement,PanelComponent:({appState:e,updateData:t,data:n})=>(0,W.jsx)(aH,{type:"button",icon:m.Qd,title:aO("buttons.done"),"aria-label":aO("buttons.done"),onClick:t,visible:null!=e.multiElement,size:n?.size||"medium",style:{pointerEvents:"all"}})}),rl=e=>{let{id:t}=hX(),[n,i]=(0,E.useState)(e.value);return(0,W.jsxs)("div",{className:"ProjectName",children:[(0,W.jsx)("label",{className:"ProjectName-label",htmlFor:"filename",children:`${e.label}:`}),(0,W.jsx)("input",{type:"text",className:"TextInput",onBlur:t=>{e.ignoreFocus||(0,m.vb)(t.target);let n=t.target.value;n!==e.value&&e.onChange(n)},onKeyDown:e=>{e.key===m.hg.ENTER&&(e.preventDefault(),e.nativeEvent.isComposing||229===e.keyCode||e.currentTarget.blur())},id:`${t}-filename`,value:n,onChange:e=>i(e.target.value)})]})},rr=e=>{let t=e.title||(e.value===m.G.DARK?aO("buttons.lightMode"):aO("buttons.darkMode"));return(0,W.jsx)(aH,{type:"icon",icon:e.value===m.G.LIGHT?rs.MOON:rs.SUN,title:t,"aria-label":t,onClick:()=>e.onChange(e.value===m.G.DARK?m.G.LIGHT:m.G.DARK),"data-testid":"toggle-dark-mode"})},rs={SUN:(0,W.jsx)("svg",{width:"512",height:"512",className:"rtl-mirror",viewBox:"0 0 512 512",children:(0,W.jsx)("path",{fill:"currentColor",d:"M256 160c-52.9 0-96 43.1-96 96s43.1 96 96 96 96-43.1 96-96-43.1-96-96-96zm246.4 80.5l-94.7-47.3 33.5-100.4c4.5-13.6-8.4-26.5-21.9-21.9l-100.4 33.5-47.4-94.8c-6.4-12.8-24.6-12.8-31 0l-47.3 94.7L92.7 70.8c-13.6-4.5-26.5 8.4-21.9 21.9l33.5 100.4-94.7 47.4c-12.8 6.4-12.8 24.6 0 31l94.7 47.3-33.5 100.5c-4.5 13.6 8.4 26.5 21.9 21.9l100.4-33.5 47.3 94.7c6.4 12.8 24.6 12.8 31 0l47.3-94.7 100.4 33.5c13.6 4.5 26.5-8.4 21.9-21.9l-33.5-100.4 94.7-47.3c13-6.5 13-24.7.2-31.1zm-155.9 106c-49.9 49.9-131.1 49.9-181 0-49.9-49.9-49.9-131.1 0-181 49.9-49.9 131.1-49.9 181 0 49.9 49.9 49.9 131.1 0 181z"})}),MOON:(0,W.jsx)("svg",{width:"512",height:"512",className:"rtl-mirror",viewBox:"0 0 512 512",children:(0,W.jsx)("path",{fill:"currentColor",d:"M283.211 512c78.962 0 151.079-35.925 198.857-94.792 7.068-8.708-.639-21.43-11.562-19.35-124.203 23.654-238.262-71.576-238.262-196.954 0-72.222 38.662-138.635 101.498-174.394 9.686-5.512 7.25-20.197-3.756-22.23A258.156 258.156 0 0 0 283.211 0c-141.309 0-256 114.511-256 256 0 141.309 114.511 256 256 256z"})})},ro=(e,{selectedElementIds:t},n)=>{e=(0,m.pk)(e);let i=n&&(0,m.tk)(e,{selectedElementIds:t}),a=null,l=i?(0,m.vk)(e,{selectedElementIds:t},{includeBoundTextElement:!0}):e;return i&&(1===l.length&&(0,m.bc)(l[0])?(a=l[0],l=(0,m.Pi)(e,a)):l.length>1&&(l=(0,m.vk)(e,{selectedElementIds:t},{includeBoundTextElement:!0,includeElementsInFrames:!0}))),{exportingFrame:a,exportedElements:(0,m.Nb)(l)}},rc=async(t,n,i,a,{exportBackground:l,exportPadding:r=m.ma,viewBackgroundColor:s,name:o=i.name||m.Ca,fileHandle:c=null,exportingFrame:d=null})=>{if(0===n.length)throw Error(aO("alerts.cannotExportEmptyCanvas"));if("svg"===t||"clipboard-svg"===t){let e=(0,m.ei)(n,{exportBackground:l,exportWithDarkMode:i.exportWithDarkMode,viewBackgroundColor:s,exportPadding:r,exportScale:i.exportScale,exportEmbedScene:i.exportEmbedScene&&"svg"===t},a,{exportingFrame:d});if("svg"===t)return(0,m.gh)(e.then(e=>new Blob([e.outerHTML],{type:m.T.svg})),{description:"Export to SVG",name:o,extension:i.exportEmbedScene?"excalidraw.svg":"svg",mimeTypes:[m.S.svg],fileHandle:c});if("clipboard-svg"===t){let t=await e.then(e=>e.outerHTML);try{await (0,m.oi)(t)}catch{throw Error(aO("errors.copyToSystemClipboardFailed"))}return}}let h=(0,m.di)(n,i,a,{exportBackground:l,viewBackgroundColor:s,exportPadding:r,exportingFrame:d});if("png"===t){let t=(0,m.yh)(h);return i.exportEmbedScene&&(t=t.then(t=>e.A(3689).then(({encodePngMetadata:e})=>e({blob:t,metadata:(0,m.Jh)(n,i,a,"local")})))),(0,m.gh)(t,{description:"Export to PNG",name:o,extension:i.exportEmbedScene?"excalidraw.png":"png",mimeTypes:[m.S.png],fileHandle:c})}if("clipboard"===t)try{let e=(0,m.yh)(h);await (0,m.ni)(e)}catch(e){throw console.warn(e),"CANVAS_POSSIBLY_TOO_BIG"===e.name?Error(aO("canvasError.canvasTooBig")):m.n&&"TypeError"===e.name?Error(`${aO("alerts.couldNotCopyToClipboard")}
|
|
3
3
|
|
|
4
4
|
${aO("hints.firefox_clipboard_write")}`):Error(aO("alerts.couldNotCopyToClipboard"))}else throw Error("Unsupported export type")},rd=async(e,t,n,i)=>{let{exportBackground:a,viewBackgroundColor:l,fileHandle:r}=t,s=(0,m.qh)(r);if(!r||!(0,m.rh)(s))throw Error("fileHandle should exist and should be of type svg or png when resaving");let{exportedElements:o,exportingFrame:c}=ro(e,t={...t,exportEmbedScene:!0},!1);return await rc(s,o,t,n,{exportBackground:a,viewBackgroundColor:l,name:i,fileHandle:r,exportingFrame:c}),{fileHandle:r}},rh=({children:e,checked:t,onChange:n,className:i})=>(0,W.jsxs)("div",{className:(0,el.default)("Checkbox",i,{"is-checked":t}),onClick:e=>{n(!t,e),e.currentTarget.querySelector(".Checkbox-box").focus()},children:[(0,W.jsx)("button",{type:"button",className:"Checkbox-box",role:"checkbox","aria-checked":t,children:m.Hd}),(0,W.jsx)("div",{className:"Checkbox-label",children:e})]}),ru=(0,m.$c)({name:"changeProjectName",label:"labels.fileTitle",trackEvent:!1,perform:(e,t,n)=>({appState:{...t,name:n},captureUpdate:m.Wg.EVENTUALLY}),PanelComponent:({appState:e,updateData:t,appProps:n,data:i,app:a})=>(0,W.jsx)(rl,{label:aO("labels.fileTitle"),value:a.getName(),onChange:e=>t(e),ignoreFocus:i?.ignoreFocus??!1})}),rp=(0,m.$c)({name:"changeExportScale",label:"imageExportDialog.scale",trackEvent:{category:"export",action:"scale"},perform:(e,t,n)=>({appState:{...t,exportScale:n},captureUpdate:m.Wg.EVENTUALLY}),PanelComponent:({elements:e,appState:t,updateData:n})=>{let i=(0,m.pk)(e),a=(0,m.tk)(i,t)?(0,m.vk)(i,t):i;return(0,W.jsx)(W.Fragment,{children:m.la.map(e=>{let[i,l]=(0,m.fi)(a,m.ma,e),r=`${aO("imageExportDialog.label.scale")} ${e}x (${i}x${l})`;return(0,W.jsx)(aH,{size:"small",type:"radio",icon:`${e}x`,name:"export-canvas-scale",title:r,"aria-label":r,id:"export-canvas-scale",checked:e===t.exportScale,onChange:()=>n(e)},e)})})}}),rm=(0,m.$c)({name:"changeExportBackground",label:"imageExportDialog.label.withBackground",trackEvent:{category:"export",action:"toggleBackground"},perform:(e,t,n)=>({appState:{...t,exportBackground:n},captureUpdate:m.Wg.EVENTUALLY}),PanelComponent:({appState:e,updateData:t})=>(0,W.jsx)(rh,{checked:e.exportBackground,onChange:e=>t(e),children:aO("imageExportDialog.label.withBackground")})}),rg=(0,m.$c)({name:"changeExportEmbedScene",label:"imageExportDialog.tooltip.embedScene",trackEvent:{category:"export",action:"embedScene"},perform:(e,t,n)=>({appState:{...t,exportEmbedScene:n},captureUpdate:m.Wg.EVENTUALLY}),PanelComponent:({appState:e,updateData:t})=>(0,W.jsxs)(rh,{checked:e.exportEmbedScene,onChange:e=>t(e),children:[aO("imageExportDialog.label.embedScene"),(0,W.jsx)(l4,{label:aO("imageExportDialog.tooltip.embedScene"),long:!0,children:(0,W.jsx)("div",{className:"excalidraw-tooltip-icon",children:m.Td})})]})}),rf=(0,m.$c)({name:"saveToActiveFile",label:"buttons.save",icon:m.Ad,trackEvent:{category:"export"},predicate:(e,t,n,i)=>!!i.props.UIOptions.canvasActions.saveToActiveFile&&!!t.fileHandle&&!t.viewModeEnabled,perform:async(e,t,n,i)=>{let a=!!t.fileHandle;try{let{fileHandle:n}=(0,m.sh)(t.fileHandle)?await rd(e,t,i.files,i.getName()):await (0,m.Kh)(e,t,i.files,i.getName());return{captureUpdate:m.Wg.EVENTUALLY,appState:{...t,fileHandle:n,toast:a?{message:n?.name?aO("toast.fileSavedToFilename").replace("{filename}",`"${n.name}"`):aO("toast.fileSaved")}:null}}}catch(e){return e?.name!=="AbortError"?console.error(e):console.warn(e),{captureUpdate:m.Wg.EVENTUALLY}}},keyTest:e=>e.key===m.hg.S&&e[m.hg.CTRL_OR_CMD]&&!e.shiftKey}),rb=(0,m.$c)({name:"saveFileToDisk",label:"exportDialog.disk_title",icon:m.Ad,viewMode:!0,trackEvent:{category:"export"},perform:async(e,t,n,i)=>{try{let{fileHandle:n}=await (0,m.Kh)(e,{...t,fileHandle:null},i.files,i.getName());return{captureUpdate:m.Wg.EVENTUALLY,appState:{...t,openDialog:null,fileHandle:n,toast:{message:aO("toast.fileSaved")}}}}catch(e){return e?.name!=="AbortError"?console.error(e):console.warn(e),{captureUpdate:m.Wg.EVENTUALLY}}},keyTest:e=>e.key===m.hg.S&&e.shiftKey&&e[m.hg.CTRL_OR_CMD],PanelComponent:({updateData:e})=>(0,W.jsx)(aH,{type:"button",icon:m.Kd,title:aO("buttons.saveAs"),"aria-label":aO("buttons.saveAs"),showAriaLabel:hZ().editor.isMobile,hidden:!g.supported,onClick:()=>e(null),"data-testid":"save-as-button"})}),rv=(0,m.$c)({name:"loadScene",label:"buttons.load",trackEvent:{category:"export"},predicate:(e,t,n,i)=>!!i.props.UIOptions.canvasActions.loadScene&&!t.viewModeEnabled,perform:async(e,t,n,i)=>{try{let{elements:n,appState:i,files:a}=await (0,m.Lh)(t,e);return{elements:n,appState:i,files:a,captureUpdate:m.Wg.IMMEDIATELY}}catch(n){return n?.name==="AbortError"?(console.warn(n),!1):{elements:e,appState:{...t,errorMessage:n.message},files:i.files,captureUpdate:m.Wg.EVENTUALLY}}},keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.key===m.hg.O}),ry=(0,m.$c)({name:"exportWithDarkMode",label:"imageExportDialog.label.darkMode",trackEvent:{category:"export",action:"toggleTheme"},perform:(e,t,n)=>({appState:{...t,exportWithDarkMode:n},captureUpdate:m.Wg.EVENTUALLY}),PanelComponent:({appState:e,updateData:t})=>(0,W.jsx)("div",{style:{display:"flex",justifyContent:"flex-end",marginTop:"-45px",marginBottom:"10px"},children:(0,W.jsx)(rr,{value:e.exportWithDarkMode?m.G.DARK:m.G.LIGHT,onChange:e=>{t(e===m.G.DARK)},title:aO("imageExportDialog.label.darkMode")})})}),rE="{}",rx=(0,m.$c)({name:"copyStyles",label:"labels.copyStyles",icon:m.yf,trackEvent:{category:"element"},perform:(e,t,n,i)=>{let a=[],l=e.find(e=>t.selectedElementIds[e.id]);if(a.push(l),l&&(0,m.mc)(l)){let e=(0,m.zj)(l,i.scene.getNonDeletedElementsMap());a.push(e)}return l&&(rE=JSON.stringify(a)),{appState:{...t,toast:{message:aO("toast.copyStyles")}},captureUpdate:m.Wg.EVENTUALLY}},keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.altKey&&e.code===m.gg.C}),rw=(0,m.$c)({name:"pasteStyles",label:"labels.pasteStyles",icon:m.yf,trackEvent:{category:"element"},perform:(e,t,n,i)=>{let a=JSON.parse(rE),l=a[0],r=a[1];if(!(0,m.kc)(l))return{elements:e,captureUpdate:m.Wg.EVENTUALLY};let s=(0,m.vk)(e,t,{includeBoundTextElement:!0}),o=s.map(e=>e.id);return{elements:e.map(e=>{if(o.includes(e.id)){let t=l;if((0,m._b)(e)&&e.containerId&&(t=r),!t)return e;let n=(0,m.Qj)(e,{backgroundColor:t?.backgroundColor,strokeWidth:t?.strokeWidth,strokeColor:t?.strokeColor,strokeStyle:t?.strokeStyle,fillStyle:t?.fillStyle,opacity:t?.opacity,roughness:t?.roughness,roundness:t.roundness?(0,m.pc)(t.roundness.type,e)?t.roundness:(0,m.qc)(e):null});if((0,m._b)(n)){let e=t.fontSize||m.I,a=t.fontFamily||m.J;n=(0,m.Qj)(n,{fontSize:e,fontFamily:a,textAlign:t.textAlign||m.K,lineHeight:t.lineHeight||(0,m.Rf)(a)});let l=null;n.containerId&&(l=s.find(e=>(0,m._b)(n)&&e.id===n.containerId)||null),(0,m.uj)(n,l,i.scene.getNonDeletedElementsMap())}return"arrow"===n.type&&(0,m.dc)(t)&&(n=(0,m.Qj)(n,{startArrowhead:t.startArrowhead,endArrowhead:t.endArrowhead})),(0,m.bc)(e)&&(n=(0,m.Qj)(n,{roundness:null,backgroundColor:"transparent"})),n}return e}),captureUpdate:m.Wg.IMMEDIATELY}},keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.altKey&&e.code===m.gg.V});(0,m.$c)({name:"toggleCanvasMenu",label:"buttons.menu",trackEvent:{category:"menu"},perform:(e,t)=>({appState:{...t,openMenu:"canvas"===t.openMenu?null:"canvas"},captureUpdate:m.Wg.EVENTUALLY}),PanelComponent:({appState:e,updateData:t})=>(0,W.jsx)(aH,{type:"button",icon:m.zd,"aria-label":aO("buttons.menu"),onClick:t,selected:"canvas"===e.openMenu})}),(0,m.$c)({name:"toggleEditMenu",label:"buttons.edit",trackEvent:{category:"menu"},perform:(e,t)=>({appState:{...t,openMenu:"shape"===t.openMenu?null:"shape"},captureUpdate:m.Wg.EVENTUALLY}),PanelComponent:({elements:e,appState:t,updateData:n})=>(0,W.jsx)(aH,{visible:(0,m.lk)(t,(0,m.pk)(e)),type:"button",icon:m.Md,"aria-label":aO("buttons.edit"),onClick:n,selected:"shape"===t.openMenu})});var rS=(0,m.$c)({name:"toggleShortcuts",label:"welcomeScreen.defaults.helpHint",icon:m.Cd,viewMode:!0,trackEvent:{category:"menu",action:"toggleHelpDialog"},perform:(e,t,n,{focusContainer:i})=>(t.openDialog?.name==="help"&&i(),{appState:{...t,openDialog:t.openDialog?.name==="help"?null:{name:"help"}},captureUpdate:m.Wg.EVENTUALLY}),keyTest:e=>e.key===m.hg.QUESTION_MARK}),rC=(e,t,n)=>{let i=n.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0});return i.length>=2&&!(e=>{if(e.length>=2){for(let t of e[0].groupIds)if(e.reduce((e,n)=>e&&(0,m.Pc)(n,t),!0))return!0}return!1})(i)&&!(0,m.Qi)(i)},rk=(0,m.$c)({name:"group",label:"labels.group",icon:e=>(0,W.jsx)(m.he,{theme:e.theme}),trackEvent:{category:"element"},perform:(e,t,n,i)=>{let a=(0,m.Di)(i.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0}));if(a.length<2)return{appState:t,elements:e,captureUpdate:m.Wg.EVENTUALLY};let l=(0,m.Mc)(t);if(1===l.length){let n=l[0],i=new Set((0,m.Qc)(e,n).map(e=>e.id)),r=new Set(a.map(e=>e.id));if(new Set([...Array.from(i),...Array.from(r)]).size===i.size)return{appState:t,elements:e,captureUpdate:m.Wg.EVENTUALLY}}let r=[...e];new Set(a.map(e=>e.frameId)).size>1&&(0,m.Ai)(a).forEach((e,t)=>{(0,m.Ji)(e,i.scene.getNonDeletedElementsMap())});let s=(0,m.sc)(),o=(0,m.xb)(a);r=r.map(e=>o.get(e.id)?(0,m.Qj)(e,{groupIds:(0,m.Sc)(e.groupIds,s,t.editingGroupId)}):e);let c=(0,m.Qc)(r,s),d=c[c.length-1],h=r.lastIndexOf(d),u=r.slice(h+1),p=r.slice(0,h).filter(e=>!(0,m.Pc)(e,s)),g=(0,m.Mj)([...p,...c,...u],(0,m.xb)(c));return{appState:{...t,...(0,m.Ic)(s,{...t,selectedGroupIds:{}},(0,m.pk)(r))},elements:g,captureUpdate:m.Wg.IMMEDIATELY}},predicate:(e,t,n,i)=>rC(e,t,i),keyTest:e=>!e.shiftKey&&e[m.hg.CTRL_OR_CMD]&&e.key===m.hg.G,PanelComponent:({elements:e,appState:t,updateData:n,app:i})=>(0,W.jsx)(aH,{hidden:!rC(e,t,i),type:"button",icon:(0,W.jsx)(m.he,{theme:t.theme}),onClick:()=>n(null),title:`${aO("labels.group")} \u2014 ${(0,m.kb)("CtrlOrCmd+G")}`,"aria-label":aO("labels.group"),visible:(0,m.tk)((0,m.pk)(e),t)})}),rI=(0,m.$c)({name:"ungroup",label:"labels.ungroup",icon:e=>(0,W.jsx)(m.ie,{theme:e.theme}),trackEvent:{category:"element"},perform:(e,t,n,i)=>{let a=(0,m.Mc)(t),l=(0,m.xb)(e);if(0===a.length)return{appState:t,elements:e,captureUpdate:m.Wg.EVENTUALLY};let r=[...e],s=[];r=r.map(e=>{(0,m.nc)(e)&&s.push(e.id);let n=(0,m.Tc)(e.groupIds,t.selectedGroupIds);return n.length===e.groupIds.length?e:(0,m.Qj)(e,{groupIds:n})});let o=(0,m.Jc)(t,(0,m.pk)(r),t,null),c=new Set(i.scene.getSelectedElements(t).filter(e=>e.frameId).map(e=>e.frameId));return(0,m.Ci)(e).filter(e=>c.has(e.id)).forEach(e=>{e&&(r=(0,m.Li)(r,(0,m.Ei)(r,e,t,l),e,i))}),o.selectedElementIds=Object.entries(o.selectedElementIds).reduce((e,[t,n])=>(n&&!s.includes(t)&&(e[t]=!0),e),{}),{appState:{...t,...o},elements:r,captureUpdate:m.Wg.IMMEDIATELY}},keyTest:e=>e.shiftKey&&e[m.hg.CTRL_OR_CMD]&&e.key===m.hg.G.toUpperCase(),predicate:(e,t)=>(0,m.Mc)(t).length>0,PanelComponent:({elements:e,appState:t,updateData:n})=>(0,W.jsx)(aH,{type:"button",hidden:0===(0,m.Mc)(t).length,icon:(0,W.jsx)(m.ie,{theme:t.theme}),onClick:()=>n(null),title:`${aO("labels.ungroup")} \u2014 ${(0,m.kb)("CtrlOrCmd+Shift+G")}`,"aria-label":aO("labels.ungroup"),visible:(0,m.tk)((0,m.pk)(e),t)})}),rj=(e,t,n,i,a,l,r)=>{e.beginPath(),e.moveTo(t+l,n),e.lineTo(t+i-l,n),e.quadraticCurveTo(t+i,n,t+i,n+l),e.lineTo(t+i,n+a-l),e.quadraticCurveTo(t+i,n+a,t+i-l,n+a),e.lineTo(t+l,n+a),e.quadraticCurveTo(t,n+a,t,n+a-l),e.lineTo(t,n+l),e.quadraticCurveTo(t,n,t+l,n),e.closePath(),e.fill(),r&&(e.strokeStyle=r),e.stroke()},rT=(e,t)=>`hsl(${Math.abs(function(e){let t=0;if(0===e.length)return t;for(let n=0;n<e.length;n++)t=(t<<5)-t+e.charCodeAt(n);return t}(t?.id||e))%37*10}, 100%, 83%)`,rM=({color:e,onClick:t,name:n,src:i,className:a})=>{let l,r=((l=n?.trim()?.codePointAt(0))?String.fromCodePoint(l):"?").toUpperCase(),[s,o]=(0,E.useState)(!1),c=!s&&i;return(0,W.jsx)("div",{className:(0,el.default)("Avatar",a),style:c?void 0:{background:e},onClick:t,children:c?(0,W.jsx)("img",{className:"Avatar-img",src:i,alt:r,referrerPolicy:"no-referrer",onError:()=>o(!0)}):r})};(0,m.$c)({name:"goToCollaborator",label:"Go to a collaborator",viewMode:!0,trackEvent:{category:"collab"},perform:(e,t,n)=>!n.socketId||t.userToFollow?.socketId===n.socketId||n.isCurrentUser?{appState:{...t,userToFollow:null},captureUpdate:m.Wg.EVENTUALLY}:{appState:{...t,userToFollow:{socketId:n.socketId,username:n.username||""},openMenu:"canvas"===t.openMenu?null:t.openMenu},captureUpdate:m.Wg.EVENTUALLY},PanelComponent:({updateData:e,data:t,appState:n})=>{let{socketId:i,collaborator:a,withName:l,isBeingFollowed:r}=t,s=rT(i,a),o=(0,el.default)({"is-followed":r,"is-current-user":!0===a.isCurrentUser,"is-speaking":a.isSpeaking,"is-in-call":a.isInCall,"is-muted":a.isMuted}),c=a.isInCall?a.isSpeaking?(0,W.jsxs)("div",{className:"UserList__collaborator-status-icon-speaking-indicator",title:aO("userList.hint.isSpeaking"),children:[(0,W.jsx)("div",{}),(0,W.jsx)("div",{}),(0,W.jsx)("div",{})]}):a.isMuted?(0,W.jsx)("div",{className:"UserList__collaborator-status-icon-microphone-muted",title:aO("userList.hint.micMuted"),children:m.sf}):(0,W.jsx)("div",{title:aO("userList.hint.inCall"),children:m.rf}):null;return l?(0,W.jsxs)("div",{className:`dropdown-menu-item dropdown-menu-item-base UserList__collaborator ${o}`,style:{"--avatar-size":"1.5rem"},onClick:()=>e(a),children:[(0,W.jsx)(rM,{color:s,onClick:()=>{},name:a.username||"",src:a.avatarUrl,className:o}),(0,W.jsx)("div",{className:"UserList__collaborator-name",children:a.username}),(0,W.jsxs)("div",{className:"UserList__collaborator-status-icons","aria-hidden":!0,children:[r&&(0,W.jsx)("div",{className:"UserList__collaborator-status-icon-is-followed",title:aO("userList.hint.followStatus"),children:m.lf}),c]})]}):(0,W.jsxs)("div",{className:`UserList__collaborator UserList__collaborator--avatar-only ${o}`,children:[(0,W.jsx)(rM,{color:s,onClick:()=>{e(a)},name:a.username||"",src:a.avatarUrl,className:o}),c&&(0,W.jsx)("div",{className:"UserList__collaborator-status-icon",children:c})]})}});var rL=(0,m.$c)({name:"addToLibrary",trackEvent:{category:"element"},perform:(e,t,n,i)=>{let a=i.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});for(let e of m.za)if(a.some(t=>t.type===e))return{captureUpdate:m.Wg.EVENTUALLY,appState:{...t,errorMessage:aO(`errors.libraryElementTypeError.${e}`)}};return i.library.getLatestLibrary().then(e=>i.library.setLibrary([{id:(0,m.sc)(),status:"unpublished",elements:a.map(m.bg),created:Date.now()},...e])).then(()=>({captureUpdate:m.Wg.EVENTUALLY,appState:{...t,toast:{message:aO("toast.addedToLibrary")}}})).catch(e=>({captureUpdate:m.Wg.EVENTUALLY,appState:{...t,errorMessage:e.message}}))},label:"labels.addToLibrary"}),rD=(e,t)=>{let n=t.scene.getSelectedElements(e);return n.length>1&&!n.some(e=>(0,m.bc)(e))},rN=(e,t,n,i)=>{var a;let l,r,s=n.scene.getSelectedElements(t),o=(0,m.xb)(e),c=(a=n.scene,l=(0,m.Uc)(s,o),r=(0,m.cj)(s),l.flatMap(e=>{let t=((e,t,{axis:n,position:i})=>{let a=(0,m.cj)(e),[l,r]="x"===n?["minX","maxX"]:["minY","maxY"],s={x:0,y:0};return"start"===i?{...s,[n]:t[l]-a[l]}:"end"===i?{...s,[n]:t[r]-a[r]}:{...s,[n]:(t[l]+t[r])/2-(a[l]+a[r])/2}})(e,r,i);return e.map(n=>{let i=(0,m.Pj)(n,{x:n.x+t.x,y:n.y+t.y});return(0,m.Pg)(n,a.getNonDeletedElementsMap(),{simultaneouslyUpdated:e}),i})})),d=(0,m.xb)(c);return(0,m.Mi)(e.map(e=>d.get(e.id)||e),t,n)};(0,m.$c)({name:"alignTop",label:"labels.alignTop",icon:m.Zd,trackEvent:{category:"element"},predicate:(e,t,n,i)=>rD(t,i),perform:(e,t,n,i)=>({appState:t,elements:rN(e,t,i,{position:"start",axis:"y"}),captureUpdate:m.Wg.IMMEDIATELY}),keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.shiftKey&&e.key===m.hg.ARROW_UP,PanelComponent:({elements:e,appState:t,updateData:n,app:i})=>(0,W.jsx)(aH,{hidden:!rD(t,i),type:"button",icon:m.Zd,onClick:()=>n(null),title:`${aO("labels.alignTop")} \u2014 ${(0,m.kb)("CtrlOrCmd+Shift+Up")}`,"aria-label":aO("labels.alignTop"),visible:(0,m.tk)((0,m.pk)(e),t)})}),(0,m.$c)({name:"alignBottom",label:"labels.alignBottom",icon:m._d,trackEvent:{category:"element"},predicate:(e,t,n,i)=>rD(t,i),perform:(e,t,n,i)=>({appState:t,elements:rN(e,t,i,{position:"end",axis:"y"}),captureUpdate:m.Wg.IMMEDIATELY}),keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.shiftKey&&e.key===m.hg.ARROW_DOWN,PanelComponent:({elements:e,appState:t,updateData:n,app:i})=>(0,W.jsx)(aH,{hidden:!rD(t,i),type:"button",icon:m._d,onClick:()=>n(null),title:`${aO("labels.alignBottom")} \u2014 ${(0,m.kb)("CtrlOrCmd+Shift+Down")}`,"aria-label":aO("labels.alignBottom"),visible:(0,m.tk)((0,m.pk)(e),t)})}),(0,m.$c)({name:"alignLeft",label:"labels.alignLeft",icon:m.$d,trackEvent:{category:"element"},predicate:(e,t,n,i)=>rD(t,i),perform:(e,t,n,i)=>({appState:t,elements:rN(e,t,i,{position:"start",axis:"x"}),captureUpdate:m.Wg.IMMEDIATELY}),keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.shiftKey&&e.key===m.hg.ARROW_LEFT,PanelComponent:({elements:e,appState:t,updateData:n,app:i})=>(0,W.jsx)(aH,{hidden:!rD(t,i),type:"button",icon:m.$d,onClick:()=>n(null),title:`${aO("labels.alignLeft")} \u2014 ${(0,m.kb)("CtrlOrCmd+Shift+Left")}`,"aria-label":aO("labels.alignLeft"),visible:(0,m.tk)((0,m.pk)(e),t)})}),(0,m.$c)({name:"alignRight",label:"labels.alignRight",icon:m.ae,trackEvent:{category:"element"},predicate:(e,t,n,i)=>rD(t,i),perform:(e,t,n,i)=>({appState:t,elements:rN(e,t,i,{position:"end",axis:"x"}),captureUpdate:m.Wg.IMMEDIATELY}),keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.shiftKey&&e.key===m.hg.ARROW_RIGHT,PanelComponent:({elements:e,appState:t,updateData:n,app:i})=>(0,W.jsx)(aH,{hidden:!rD(t,i),type:"button",icon:m.ae,onClick:()=>n(null),title:`${aO("labels.alignRight")} \u2014 ${(0,m.kb)("CtrlOrCmd+Shift+Right")}`,"aria-label":aO("labels.alignRight"),visible:(0,m.tk)((0,m.pk)(e),t)})}),(0,m.$c)({name:"alignVerticallyCentered",label:"labels.centerVertically",icon:m.de,trackEvent:{category:"element"},predicate:(e,t,n,i)=>rD(t,i),perform:(e,t,n,i)=>({appState:t,elements:rN(e,t,i,{position:"center",axis:"y"}),captureUpdate:m.Wg.IMMEDIATELY}),PanelComponent:({elements:e,appState:t,updateData:n,app:i})=>(0,W.jsx)(aH,{hidden:!rD(t,i),type:"button",icon:m.de,onClick:()=>n(null),title:aO("labels.centerVertically"),"aria-label":aO("labels.centerVertically"),visible:(0,m.tk)((0,m.pk)(e),t)})}),(0,m.$c)({name:"alignHorizontallyCentered",label:"labels.centerHorizontally",icon:m.ee,trackEvent:{category:"element"},predicate:(e,t,n,i)=>rD(t,i),perform:(e,t,n,i)=>({appState:t,elements:rN(e,t,i,{position:"center",axis:"x"}),captureUpdate:m.Wg.IMMEDIATELY}),PanelComponent:({elements:e,appState:t,updateData:n,app:i})=>(0,W.jsx)(aH,{hidden:!rD(t,i),type:"button",icon:m.ee,onClick:()=>n(null),title:aO("labels.centerHorizontally"),"aria-label":aO("labels.centerHorizontally"),visible:(0,m.tk)((0,m.pk)(e),t)})});var rA=(e,t)=>{let n=t.scene.getSelectedElements(e);return n.length>1&&!n.some(e=>(0,m.bc)(e))},rP=(e,t,n,i)=>{let a=((e,t,n)=>{let[i,a,l,r]="x"===n.axis?["minX","midX","maxX","width"]:["minY","midY","maxY","height"],s=(0,m.cj)(e),o=(0,m.Uc)(e,t).map(e=>[e,(0,m.cj)(e)]).sort((e,t)=>e[1][a]-t[1][a]),c=0;for(let e of o)c+=e[1][r];let d=(s[r]-c)/(o.length-1);if(d<0){let e=o.findIndex(e=>e[1][i]===s[i]),t=o.findIndex(e=>e[1][l]===s[l]),r=(o[t][1][a]-o[e][1][a])/(o.length-1),c=o[e][1][a];return o.flatMap(([i,l],s)=>{let o={x:0,y:0};return s!==e&&s!==t&&(c+=r,o[n.axis]=c-l[a]),i.map(e=>(0,m.Qj)(e,{x:e.x+o.x,y:e.y+o.y}))})}let h=s[i];return o.flatMap(([e,t])=>{let a={x:0,y:0};return a[n.axis]=h-t[i],h+=d,h+=t[r],e.map(e=>(0,m.Qj)(e,{x:e.x+a.x,y:e.y+a.y}))})})(n.scene.getSelectedElements(t),n.scene.getNonDeletedElementsMap(),i),l=(0,m.xb)(a);return(0,m.Mi)(e.map(e=>l.get(e.id)||e),t,n)};(0,m.$c)({name:"distributeHorizontally",label:"labels.distributeHorizontally",trackEvent:{category:"element"},perform:(e,t,n,i)=>({appState:t,elements:rP(e,t,i,{space:"between",axis:"x"}),captureUpdate:m.Wg.IMMEDIATELY}),keyTest:e=>!e[m.hg.CTRL_OR_CMD]&&e.altKey&&e.code===m.gg.H,PanelComponent:({elements:e,appState:t,updateData:n,app:i})=>(0,W.jsx)(aH,{hidden:!rA(t,i),type:"button",icon:m.be,onClick:()=>n(null),title:`${aO("labels.distributeHorizontally")} \u2014 ${(0,m.kb)("Alt+H")}`,"aria-label":aO("labels.distributeHorizontally"),visible:(0,m.tk)((0,m.pk)(e),t)})}),(0,m.$c)({name:"distributeVertically",label:"labels.distributeVertically",trackEvent:{category:"element"},perform:(e,t,n,i)=>({appState:t,elements:rP(e,t,i,{space:"between",axis:"y"}),captureUpdate:m.Wg.IMMEDIATELY}),keyTest:e=>!e[m.hg.CTRL_OR_CMD]&&e.altKey&&e.code===m.gg.V,PanelComponent:({elements:e,appState:t,updateData:n,app:i})=>(0,W.jsx)(aH,{hidden:!rA(t,i),type:"button",icon:m.ce,onClick:()=>n(null),title:`${aO("labels.distributeVertically")} \u2014 ${(0,m.kb)("Alt+V")}`,"aria-label":aO("labels.distributeVertically"),visible:(0,m.tk)((0,m.pk)(e),t)})});var rR=(0,m.$c)({name:"flipHorizontal",label:"labels.flipHorizontal",icon:m.xf,trackEvent:{category:"element"},perform:(e,t,n,i)=>({elements:(0,m.Mi)(rO(e,i.scene.getNonDeletedElementsMap(),t,"horizontal",i),t,i),appState:t,captureUpdate:m.Wg.IMMEDIATELY}),keyTest:e=>e.shiftKey&&e.code===m.gg.H}),r_=(0,m.$c)({name:"flipVertical",label:"labels.flipVertical",icon:m.wf,trackEvent:{category:"element"},perform:(e,t,n,i)=>({elements:(0,m.Mi)(rO(e,i.scene.getNonDeletedElementsMap(),t,"vertical",i),t,i),appState:t,captureUpdate:m.Wg.IMMEDIATELY}),keyTest:e=>e.shiftKey&&e.code===m.gg.V&&!e[m.hg.CTRL_OR_CMD]}),rO=(e,t,n,i,a)=>{let l=rF((0,m.vk)((0,m.pk)(e),n,{includeBoundTextElement:!0,includeElementsInFrames:!0}),t,n,i,a),r=(0,m.xb)(l);return e.map(e=>r.get(e.id)||e)},rF=(e,t,n,i,a)=>{if(e.every(e=>(0,m.dc)(e)&&(e.startBinding||e.endBinding)))return e.map(e=>(0,m.Qj)(e,{startArrowhead:e.endArrowhead,endArrowhead:e.startArrowhead}));let{midX:l,midY:r}=(0,m.cj)(e);(0,m.hk)(e,t,"nw",a.scene,new Map(Array.from(t.values()).map(e=>[e.id,(0,m.bg)(e)])),{flipByX:"horizontal"===i,flipByY:"vertical"===i,shouldResizeFromCenter:!0,shouldMaintainAspectRatio:!0}),(0,m.Jg)(e.filter(m.cc),t,a.scene.getNonDeletedElements(),a.scene,(0,m.Fg)(n),[],n.zoom);let{elbowArrows:s,otherElements:o}=e.reduce((e,t)=>(0,m.ec)(t)?{...e,elbowArrows:e.elbowArrows.concat(t)}:{...e,otherElements:e.otherElements.concat(t)},{elbowArrows:[],otherElements:[]}),{midX:c,midY:d}=(0,m.cj)(e),[h,u]=[l-c,r-d];return o.forEach(e=>(0,m.Pj)(e,{x:e.x+h,y:e.y+u})),s.forEach(e=>(0,m.Pj)(e,{x:e.x+h,y:e.y+u})),e},rz=(0,m.$c)({name:"copy",label:"labels.copy",icon:m.wd,trackEvent:{category:"element"},perform:async(e,t,n,i)=>{let a=i.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});try{await (0,m.ki)(a,i.files,n)}catch(e){return{captureUpdate:m.Wg.EVENTUALLY,appState:{...t,errorMessage:e.message}}}return{captureUpdate:m.Wg.EVENTUALLY}},keyTest:void 0}),rU=(0,m.$c)({name:"paste",label:"labels.paste",trackEvent:{category:"element"},perform:async(e,t,n,i)=>{let a;try{a=await (0,m.li)()}catch(e){return"AbortError"!==e.name&&"NotAllowedError"!==e.name&&(console.error(`actionPaste ${e.name}: ${e.message}`),m.n?{captureUpdate:m.Wg.EVENTUALLY,appState:{...t,errorMessage:aO("hints.firefox_clipboard_write")}}:{captureUpdate:m.Wg.EVENTUALLY,appState:{...t,errorMessage:aO("errors.asyncPasteFailedOnRead")}})}try{i.pasteFromClipboard((0,m.ji)({types:a}))}catch(e){return console.error(e),{captureUpdate:m.Wg.EVENTUALLY,appState:{...t,errorMessage:aO("errors.asyncPasteFailedOnParse")}}}return{captureUpdate:m.Wg.EVENTUALLY}},keyTest:void 0}),rB=(0,m.$c)({name:"cut",label:"labels.cut",icon:m.$e,trackEvent:{category:"element"},perform:(e,t,n,i)=>(rz.perform(e,t,n,i),aY.perform(e,t,null,i)),keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.key===m.hg.X}),rW=(0,m.$c)({name:"copyAsSvg",label:"labels.copyAsSvg",icon:m.Af,trackEvent:{category:"element"},perform:async(e,t,n,i)=>{if(!i.canvas)return{captureUpdate:m.Wg.EVENTUALLY};let{exportedElements:a,exportingFrame:l}=ro(e,t,!0);try{await rc("clipboard-svg",a,t,i.files,{...t,exportingFrame:l,name:i.getName()});let e=i.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});return{appState:{toast:{message:aO("toast.copyToClipboardAsSvg",{exportSelection:e.length?aO("toast.selection"):aO("toast.canvas"),exportColorScheme:t.exportWithDarkMode?aO("buttons.darkMode"):aO("buttons.lightMode")})}},captureUpdate:m.Wg.EVENTUALLY}}catch(e){return console.error(e),{appState:{errorMessage:e.message},captureUpdate:m.Wg.EVENTUALLY}}},predicate:e=>m.hi&&e.length>0,keywords:["svg","clipboard","copy"]}),rH=(0,m.$c)({name:"copyAsPng",label:"labels.copyAsPng",icon:m.Bf,trackEvent:{category:"element"},perform:async(e,t,n,i)=>{if(!i.canvas)return{captureUpdate:m.Wg.EVENTUALLY};let a=i.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0}),{exportedElements:l,exportingFrame:r}=ro(e,t,!0);try{return await rc("clipboard",l,t,i.files,{...t,exportingFrame:r,name:i.getName()}),{appState:{...t,toast:{message:aO("toast.copyToClipboardAsPng",{exportSelection:a.length?aO("toast.selection"):aO("toast.canvas"),exportColorScheme:t.exportWithDarkMode?aO("buttons.darkMode"):aO("buttons.lightMode")})}},captureUpdate:m.Wg.EVENTUALLY}}catch(e){return console.error(e),{appState:{...t,errorMessage:e.message},captureUpdate:m.Wg.EVENTUALLY}}},predicate:e=>m.ii&&e.length>0,keyTest:e=>e.code===m.gg.C&&e.altKey&&e.shiftKey,keywords:["png","clipboard","copy"]}),r$=(0,m.$c)({name:"copyText",label:"labels.copyText",trackEvent:{category:"element"},perform:(e,t,n,i)=>{let a=i.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0});try{(0,m.oi)((0,m.Jj)(a))}catch{throw Error(aO("errors.copyToSystemClipboardFailed"))}return{captureUpdate:m.Wg.EVENTUALLY}},predicate:(e,t,n,i)=>m.hi&&i.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0}).some(m._b),keywords:["text","clipboard","copy"]}),rY=(0,m.$c)({name:"gridMode",icon:m.Gf,keywords:["snap"],label:"labels.toggleGrid",viewMode:!0,trackEvent:{category:"canvas",predicate:e=>e.gridModeEnabled},perform(e,t){return{appState:{...t,gridModeEnabled:!this.checked(t),objectsSnapModeEnabled:!1},captureUpdate:m.Wg.EVENTUALLY}},checked:e=>e.gridModeEnabled,predicate:(e,t,n)=>void 0===n.gridModeEnabled,keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.code===m.gg.QUOTE}),rV=(0,m.$c)({name:"zenMode",label:"buttons.zenMode",icon:m.Df,paletteName:"Toggle zen mode",viewMode:!0,trackEvent:{category:"canvas",predicate:e=>!e.zenModeEnabled},perform(e,t){return{appState:{...t,zenModeEnabled:!this.checked(t)},captureUpdate:m.Wg.EVENTUALLY}},checked:e=>e.zenModeEnabled,predicate:(e,t,n)=>typeof n.zenModeEnabled>"u",keyTest:e=>!e[m.hg.CTRL_OR_CMD]&&e.altKey&&e.code===m.gg.Z}),rG=(0,m.$c)({name:"objectsSnapMode",label:"buttons.objectsSnapMode",icon:m.Cf,viewMode:!1,trackEvent:{category:"canvas",predicate:e=>!e.objectsSnapModeEnabled},perform(e,t){return{appState:{...t,objectsSnapModeEnabled:!this.checked(t),gridModeEnabled:!1},captureUpdate:m.Wg.EVENTUALLY}},checked:e=>e.objectsSnapModeEnabled,predicate:(e,t,n)=>typeof n.objectsSnapModeEnabled>"u",keyTest:e=>!e[m.hg.CTRL_OR_CMD]&&e.altKey&&e.code===m.gg.S}),rK=(0,m.$c)({name:"stats",label:"stats.fullTitle",icon:m.vf,paletteName:"Toggle stats",viewMode:!0,trackEvent:{category:"menu"},keywords:["edit","attributes","customize"],perform(e,t){return{appState:{...t,stats:{...t.stats,open:!this.checked(t)}},captureUpdate:m.Wg.EVENTUALLY}},checked:e=>e.stats.open,keyTest:e=>!e[m.hg.CTRL_OR_CMD]&&e.altKey&&e.code===m.gg.SLASH}),rZ=(0,m.$c)({name:"unbindText",label:"labels.unbindText",trackEvent:{category:"element"},predicate:(e,t,n,i)=>i.scene.getSelectedElements(t).some(e=>(0,m.mc)(e)),perform:(e,t,n,i)=>{let a=i.scene.getSelectedElements(t),l=i.scene.getNonDeletedElementsMap();return a.forEach(e=>{let t=(0,m.zj)(e,l);if(t){let{width:n,height:i}=(0,m.vc)(t.originalText,(0,m.cb)(t),t.lineHeight),a=(0,m.tj)(e.id);(0,m.sj)(e.id);let{x:r,y:s}=(0,m.xj)(e,t,l);(0,m.Pj)(t,{containerId:null,width:n,height:i,text:t.originalText,x:r,y:s}),(0,m.Pj)(e,{boundElements:e.boundElements?.filter(e=>e.id!==t.id),height:a||e.height})}}),{elements:e,appState:t,captureUpdate:m.Wg.IMMEDIATELY}}}),rX=(0,m.$c)({name:"bindText",label:"labels.bindText",trackEvent:{category:"element"},predicate:(e,t,n,i)=>{let a=i.scene.getSelectedElements(t);if(2===a.length){let e=(0,m._b)(a[0])||(0,m._b)(a[1]),t;if((0,m.jc)(a[0])?t=a[0]:(0,m.jc)(a[1])&&(t=a[1]),e&&t&&null===(0,m.zj)(t,i.scene.getNonDeletedElementsMap()))return!0}return!1},perform:(e,t,n,i)=>{let a=i.scene.getSelectedElements(t),l,r;(0,m._b)(a[0])&&(0,m.jc)(a[1])?(l=a[0],r=a[1]):(l=a[1],r=a[0]),(0,m.Pj)(l,{containerId:r.id,verticalAlign:m.sa.MIDDLE,textAlign:m.ta.CENTER,autoResize:!0}),(0,m.Pj)(r,{boundElements:(r.boundElements||[]).concat({type:"text",id:l.id})});let s=r.height;return(0,m.uj)(l,r,i.scene.getNonDeletedElementsMap()),(0,m.rj)(r.id,s),{elements:rQ(e,r,l),appState:{...t,selectedElementIds:{[r.id]:!0}},captureUpdate:m.Wg.IMMEDIATELY}}}),rQ=(e,t,n)=>{let i=e.slice(),a=i.findIndex(e=>e.id===n.id);i.splice(a,1);let l=i.findIndex(e=>e.id===t.id);return i.splice(l+1,0,n),(0,m.Mj)(i,(0,m.xb)([t,n])),i},rq=(e,t,n)=>{let i=e.slice(),a=i.findIndex(e=>e.id===t.id);i.splice(a,1);let l=i.findIndex(e=>e.id===n.id);return i.splice(l,0,t),(0,m.Mj)(i,(0,m.xb)([t,n])),i},rJ=(0,m.$c)({name:"wrapTextInContainer",label:"labels.createContainerFromText",trackEvent:{category:"element"},predicate:(e,t,n,i)=>{let a=i.scene.getSelectedElements(t),l=a.every(e=>(0,m._b)(e));return a.length>0&&l},perform:(e,t,n,i)=>{let a=i.scene.getSelectedElements(t),l=e.slice(),r={};for(let e of a)if((0,m._b)(e)){let n=(0,m.Sf)({type:"rectangle",backgroundColor:t.currentItemBackgroundColor,boundElements:[...e.boundElements||[],{id:e.id,type:"text"}],angle:e.angle,fillStyle:t.currentItemFillStyle,strokeColor:t.currentItemStrokeColor,roughness:t.currentItemRoughness,strokeWidth:t.currentItemStrokeWidth,strokeStyle:t.currentItemStrokeStyle,roundness:"round"===t.currentItemRoundness?{type:(0,m.oc)("rectangle")?m.ua.ADAPTIVE_RADIUS:m.ua.PROPORTIONAL_RADIUS}:null,opacity:100,locked:!1,x:e.x-m.ra,y:e.y-m.ra,width:(0,m.Gj)(e.width,"rectangle"),height:(0,m.Gj)(e.height,"rectangle"),groupIds:e.groupIds,frameId:e.frameId});if(e.boundElements?.length){let t=e.boundElements.filter(e=>"arrow"===e.type).map(e=>e.id);l.filter(e=>t.includes(e.id)).forEach(t=>{let i=t.startBinding,a=t.endBinding;i?.elementId===e.id&&(i={...i,elementId:n.id}),a?.elementId===e.id&&(a={...a,elementId:n.id}),(i||a)&&(0,m.Pj)(t,{startBinding:i,endBinding:a},!1)})}(0,m.Pj)(e,{containerId:n.id,verticalAlign:m.sa.MIDDLE,boundElements:null,textAlign:m.ta.CENTER,autoResize:!0},!1),(0,m.uj)(e,n,i.scene.getNonDeletedElementsMap()),l=rq([...l,n],n,e),r[n.id]=!0}return{elements:l,appState:{...t,selectedElementIds:r},captureUpdate:m.Wg.IMMEDIATELY}}}),r0=!1,r1=new Map,r2=({element:e,elementsMap:t,setAppState:n,onLinkOpen:i,setToast:a,updateEmbedValidationStatus:l})=>{let r=hq(),s=hK(),o=hZ(),c=e.link||"",[d,h]=(0,E.useState)(c),u=(0,E.useRef)(null),p="editor"===r.showHyperlinkPopup,g=(0,E.useCallback)(()=>{if(!u.current)return;let t=(0,m.Xc)(u.current.value)||null;if(!e.link&&t&&a8("hyperlink","create"),(0,m.Xb)(e)){if(r.activeEmbeddable?.element===e&&n({activeEmbeddable:null}),!t){(0,m.Pj)(e,{link:null}),l(e,!1);return}if((0,m.$g)(t,s.validateEmbeddable)){let{width:n,height:i}=e,r=(0,m.Zg)(t);r?.error instanceof URIError&&a({message:aO("toast.unrecognizedLinkFormat"),closable:!0});let s=r?r.intrinsicSize.w/r.intrinsicSize.h:1,o=r1.get(e.id)!==e.link;(0,m.Pj)(e,{...o?{width:r?.type==="video"?n>i?n:i*s:n,height:r?.type==="video"&&n>i?n/s:i}:{},link:t}),l(e,!0),r1.has(e.id)&&r1.delete(e.id)}else t&&a({message:aO("toast.unableToEmbed"),closable:!0}),e.link&&r1.set(e.id,e.link),(0,m.Pj)(e,{link:t}),l(e,!1)}else(0,m.Pj)(e,{link:t})},[e,a,s.validateEmbeddable,r.activeEmbeddable,n,l]);(0,E.useLayoutEffect)(()=>()=>{g()},[g]),(0,E.useEffect)(()=>{p&&u?.current&&!(o.viewport.isMobile||o.isTouchScreen)&&u.current.select()},[p,o.viewport.isMobile,o.isTouchScreen]),(0,E.useEffect)(()=>{let i=null,a=a=>{!p&&(i&&clearTimeout(i),r8(e,t,r,(0,m.Ua)(a.clientX,a.clientY))&&(i=window.setTimeout(()=>{n({showHyperlinkPopup:!1})},500)))};return window.addEventListener("pointermove",a,!1),()=>{window.removeEventListener("pointermove",a,!1),i&&clearTimeout(i)}},[r,e,p,n,t]);let f=(0,E.useCallback)(()=>{a8("hyperlink","delete"),(0,m.Pj)(e,{link:null}),n({showHyperlinkPopup:!1})},[n,e]),{x:b,y:v}=r3(e,r,t);return r.contextMenu||r.selectedElementsAreBeingDragged||r.resizingElement||r.isRotating||r.openMenu||r.viewModeEnabled?null:(0,W.jsxs)("div",{className:"excalidraw-hyperlinkContainer",style:{top:`${v}px`,left:`${b}px`,width:380,padding:5},children:[p?(0,W.jsx)("input",{className:(0,el.default)("excalidraw-hyperlinkContainer-input"),placeholder:aO("labels.link.hint"),ref:u,value:d,onChange:e=>h(e.target.value),autoFocus:!0,onKeyDown:e=>{e.stopPropagation(),e[m.hg.CTRL_OR_CMD]&&e.key===m.hg.K&&e.preventDefault(),(e.key===m.hg.ENTER||e.key===m.hg.ESCAPE)&&(g(),n({showHyperlinkPopup:"info"}))}}):e.link?(0,W.jsx)("a",{href:(0,m.Xc)(e.link||""),className:"excalidraw-hyperlinkContainer-link",target:(0,m.Yc)(e.link)?"_self":"_blank",onClick:t=>{if(e.link&&i){let n=(0,m.Cb)("excalidraw-link",t.nativeEvent);i({...e,link:(0,m.Xc)(e.link)},n),n.defaultPrevented&&t.preventDefault()}},rel:"noopener noreferrer",children:e.link}):(0,W.jsx)("div",{className:"excalidraw-hyperlinkContainer-link",children:aO("labels.link.empty")}),(0,W.jsxs)("div",{className:"excalidraw-hyperlinkContainer__buttons",children:[!p&&(0,W.jsx)(aH,{type:"button",title:aO("buttons.edit"),"aria-label":aO("buttons.edit"),label:aO("buttons.edit"),onClick:()=>{a8("hyperlink","edit","popup-ui"),n({showHyperlinkPopup:"editor"})},className:"excalidraw-hyperlinkContainer--edit",icon:m.pd}),(0,W.jsx)(aH,{type:"button",title:aO("labels.linkToElement"),"aria-label":aO("labels.linkToElement"),label:aO("labels.linkToElement"),onClick:()=>{n({openDialog:{name:"elementLinkSelector",sourceElementId:e.id}})},icon:m.Pf}),c&&!(0,m.Xb)(e)&&(0,W.jsx)(aH,{type:"button",title:aO("buttons.remove"),"aria-label":aO("buttons.remove"),label:aO("buttons.remove"),onClick:f,className:"excalidraw-hyperlinkContainer--remove",icon:m.ud})]})]})},r3=(e,t,n)=>{let[i,a]=(0,m.aj)(e,n),{x:l,y:r}=(0,m.mb)({sceneX:i+e.width/2,sceneY:a},t);return{x:l-t.offsetLeft-190,y:r-t.offsetTop-85}},r5=(e,t)=>{let n=(0,m.vk)(e,t);return(0,m.Xb)(n[0])?"labels.link.editEmbed":n[0]?.link?"labels.link.edit":"labels.link.create"},r4=null,r6=()=>{r4&&clearTimeout(r4),r0&&(r0=!1,l3().classList.remove("excalidraw-tooltip--visible"))},r8=(e,t,n,[i,a])=>{let{x:l,y:r}=(0,m.lb)({clientX:i,clientY:a},n),s=15/n.zoom.value;if((0,m.og)(l,r,e,t))return!1;let[o,c,d]=(0,m.aj)(e,t);if(l>=o&&l<=d&&r>=c-85&&r<=c)return!1;let{x:h,y:u}=r3(e,n,t);return!(i>=h-s&&i<=h+380+10+s&&a>=u-s&&a<=u+s+10+42)},r7=(0,m.$c)({name:"hyperlink",label:(e,t)=>r5(e,t),icon:m.Id,perform:(e,t)=>"editor"!==t.showHyperlinkPopup&&{elements:e,appState:{...t,showHyperlinkPopup:"editor",openMenu:null},captureUpdate:m.Wg.IMMEDIATELY},trackEvent:{category:"hyperlink",action:"click"},keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.key===m.hg.K,predicate:(e,t)=>1===(0,m.vk)(e,t).length,PanelComponent:({elements:e,appState:t,updateData:n})=>{let i=(0,m.vk)(e,t);return(0,W.jsx)(aH,{type:"button",icon:m.Id,"aria-label":aO(r5(e,t)),title:`${(0,m.Xb)(e[0])?aO("labels.link.labelEmbed"):aO("labels.link.label")} - ${(0,m.kb)("CtrlOrCmd+K")}`,onClick:()=>n(null),selected:1===i.length&&!!i[0].link})}}),r9=e=>e.every(e=>!e.locked),se=(0,m.$c)({name:"toggleElementLock",label:(e,t,n)=>{let i=n.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!1});return 1!==i.length||(0,m.bc)(i[0])?r9(i)?"labels.elementLock.lockAll":"labels.elementLock.unlockAll":i[0].locked?"labels.elementLock.unlock":"labels.elementLock.lock"},icon:(e,t)=>r9((0,m.vk)(t,e))?m.kd:m.jd,trackEvent:{category:"element"},predicate:(e,t,n,i)=>{let a=i.scene.getSelectedElements(t);return a.length>0&&!a.some(e=>e.locked&&e.frameId)},perform:(e,t,n,i)=>{let a=i.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0,includeElementsInFrames:!0});if(!a.length)return!1;let l=r9(a),r=(0,m.xb)(a);return{elements:e.map(e=>r.has(e.id)?(0,m.Qj)(e,{locked:l}):e),appState:{...t,selectedLinearElement:l?null:t.selectedLinearElement},captureUpdate:m.Wg.IMMEDIATELY}},keyTest:(e,t,n,i)=>e.key.toLocaleLowerCase()===m.hg.L&&e[m.hg.CTRL_OR_CMD]&&e.shiftKey&&i.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!1}).length>0}),st=(0,m.$c)({name:"unlockAllElements",paletteName:"Unlock all elements",trackEvent:{category:"canvas"},viewMode:!1,icon:m.jd,predicate:(e,t)=>0===(0,m.vk)(e,t).length&&e.some(e=>e.locked),perform:(e,t)=>{let n=e.filter(e=>e.locked);return{elements:e.map(e=>e.locked?(0,m.Qj)(e,{locked:!1}):e),appState:{...t,selectedElementIds:Object.fromEntries(n.map(e=>[e.id,!0]))},captureUpdate:m.Wg.IMMEDIATELY}},label:"labels.elementLock.unlockAll"}),sn=e=>{let{closeOnClickOutside:t=!0}=e,n=lg({className:"excalidraw-modal-container"}),i=(0,E.useRef)(document.body.classList.contains("excalidraw-animations-disabled"));return n?(0,er.createPortal)((0,W.jsxs)("div",{className:(0,el.default)("Modal",e.className,{"animations-disabled":i.current}),role:"dialog","aria-modal":"true",onKeyDown:t=>{t.key===m.hg.ESCAPE&&(t.nativeEvent.stopImmediatePropagation(),t.stopPropagation(),e.onCloseRequest())},"aria-labelledby":e.labelledBy,"data-prevent-outside-click":!0,children:[(0,W.jsx)("div",{className:"Modal__background",onClick:t?e.onCloseRequest:void 0}),(0,W.jsx)("div",{className:"Modal__content",style:{"--max-width":`${e.maxWidth}px`},tabIndex:0,children:e.children})]}),n):null},si=S(new Map),sa=async e=>await (0,m.ri)({elements:e,appState:{exportBackground:!1,viewBackgroundColor:m.e.white},files:null,renderEmbeddables:!1,skipInliningFonts:!0}),sl=()=>{let[e]=aS(si);return{clearLibraryCache:()=>e.clear(),deleteItemsFromLibraryCache:t=>{t.forEach(t=>e.delete(t))},svgCache:e}},sr=class{constructor(){(0,y.d)(this,"jobs",[]),(0,y.d)(this,"running",!1)}tick(){if(this.running)return;let e=this.jobs.shift();e?(this.running=!0,e.promise.resolve((0,m.Tb)(e.jobFactory,...e.args).finally(()=>{this.running=!1,this.tick()}))):this.running=!1}push(e,...t){let n=(0,m.tb)();return this.jobs.push({jobFactory:e,promise:n,args:t}),this.tick(),n}},ss=["excalidraw.com","raw.githubusercontent.com/excalidraw/excalidraw-libraries"],so=new m.Vg,sc=S({status:"loaded",isInitialized:!1,libraryItems:[]}),sd=e=>(0,m.Nb)(e),sh=(e,t)=>!e.find(e=>e.elements.length===t.elements.length&&e.elements.every((e,n)=>e.id===t.elements[n].id&&e.versionNonce===t.elements[n].versionNonce)),su=(e,t)=>{let n=[];for(let i of t)sh(e,i)&&n.push(i);return[...n,...e]},sp=(e,t)=>{let n=(0,m.xb)(t),i={deletedItems:new Map,addedItems:new Map};for(let t of e)n.has(t.id)||i.deletedItems.set(t.id,t);let a=(0,m.xb)(e);for(let e of t)a.has(e.id)||i.addedItems.set(e.id,e);return i},sm=class{constructor(e){(0,y.d)(this,"currLibraryItems",[]),(0,y.d)(this,"prevLibraryItems",sd(this.currLibraryItems)),(0,y.d)(this,"app"),(0,y.d)(this,"updateQueue",[]),(0,y.d)(this,"getLastUpdateTask",()=>this.updateQueue[this.updateQueue.length-1]),(0,y.d)(this,"notifyListeners",()=>{if(this.updateQueue.length>0)aT.set(sc,e=>({status:"loading",libraryItems:this.currLibraryItems,isInitialized:e.isInitialized}));else{aT.set(sc,{status:"loaded",libraryItems:this.currLibraryItems,isInitialized:!0});try{let e=this.prevLibraryItems;this.prevLibraryItems=sd(this.currLibraryItems);let t=sd(this.currLibraryItems);this.app.props.onLibraryChange?.(t),so.trigger(sp(e,t),t)}catch(e){console.error(e)}}}),(0,y.d)(this,"destroy",()=>{this.updateQueue=[],this.currLibraryItems=[],aT.set(si,new Map)}),(0,y.d)(this,"resetLibrary",()=>this.setLibrary([])),(0,y.d)(this,"getLatestLibrary",()=>new Promise(async e=>{try{let t=await (this.getLastUpdateTask()||this.currLibraryItems);e(this.updateQueue.length>0?this.getLatestLibrary():sd(t))}catch{return e(this.currLibraryItems)}})),(0,y.d)(this,"updateLibrary",async({libraryItems:e,prompt:t=!1,merge:n=!1,openLibraryMenu:i=!1,defaultStatus:a="unpublished"})=>(i&&this.app.setState({openSidebar:{name:m.ya.name,tab:m.wa}}),this.setLibrary(()=>new Promise(async(i,l)=>{try{let r=await ("function"==typeof e&&!(e instanceof Blob)?e(this.currLibraryItems):e),s;s=r instanceof Blob?await (0,m.xh)(r,a):(0,m.mh)(r,a),!t||window.confirm(aO("alerts.confirmAddLibrary",{numShapes:s.length}))?(t&&this.app.focusContainer(),i(n?su(this.currLibraryItems,s):s)):l(new m.tc)}catch(e){l(e)}})))),(0,y.d)(this,"setLibrary",e=>{let t=new Promise(async(t,n)=>{try{await this.getLastUpdateTask(),"function"==typeof e&&(e=e(this.currLibraryItems)),this.currLibraryItems=sd(await e),t(this.currLibraryItems)}catch(e){n(e)}}).catch(e=>{if("AbortError"===e.name)return console.warn("Library update aborted by user"),this.currLibraryItems;throw e}).finally(()=>{this.updateQueue=this.updateQueue.filter(e=>e!==t),this.notifyListeners()});return this.updateQueue.push(t),this.notifyListeners(),t}),this.app=e}},sg=e=>{let t=Math.ceil(Math.sqrt(e.length)),n=[],i=n=>e.slice(n*t,n*t+t).reduce((e,t)=>{let{height:n}=(0,m.cj)(t.elements);return Math.max(e,n)},0),a=n=>{let i=0,a=0,l=0;for(let r of e){if(i%t==0&&(a=0),a===n){let{width:e}=(0,m.cj)(r.elements);l=Math.max(l,e)}i++,a++}return l},l=0,r=0,s=0,o=0,c=0,d=0,h=0;for(let u of e){c&&c%t==0&&(r+=s+50,l=0,d=0,h++),0===d&&(s=i(h)),o=a(d);let{minX:e,minY:p,width:g,height:f}=(0,m.cj)(u.elements),b=(o-g)/2,v=(s-f)/2;n.push(...u.elements.map(t=>({...t,x:t.x+l+b-e,y:t.y+r+v-p}))),l+=o+50,c++,d++}return n},sf=()=>{let e=new URLSearchParams(window.location.hash.slice(1)).get(m.fa.addLibrary)||new URLSearchParams(window.location.search).get(m.ea.addLibrary),t=e?new URLSearchParams(window.location.hash.slice(1)).get("token"):null;return e?{libraryUrl:e,idToken:t}:null},sb=class e{constructor(e){(0,y.d)(this,"adapter"),this.adapter=e}static async getLibraryItems(t,n,i=!0){let a=()=>new Promise(async(e,i)=>{try{let i=await t.load({source:n});e((0,m.mh)(i?.libraryItems||[],"published"))}catch(e){i(e)}});return i?e.queue.push(a):a()}getLibraryItems(t){return e.getLibraryItems(this.adapter,t,!1)}};(0,y.d)(sb,"queue",new sr),(0,y.d)(sb,"run",async(e,t)=>{let n=new sb(e);return sb.queue.push(()=>t(n))});var sv=0,sy=0,sE=e=>(0,m.ok)(e.map(e=>`${e.id}:${(0,m.nk)(e.elements)}`).sort().join()),sx=async(e,t)=>{try{return sy++,await sb.run(e,async n=>{let i=(0,m.xb)(await n.getLibraryItems("save"));for(let[e]of t.deletedItems)i.delete(e);let a=[];for(let[e,n]of t.addedItems)i.has(e)?i.set(e,n):a.push(n);let l=a.concat(Array.from(i.values())),r=sE(l);return r!==sv&&await e.save({libraryItems:l}),sv=r,l})}finally{sy--}},sw=e=>{let{excalidrawAPI:t}=e,n=(0,E.useRef)(e);n.current=e;let i=(0,E.useRef)(!1);(0,E.useEffect)(()=>{if(!t)return;i.current=!1;let e=async({libraryUrl:e,idToken:i})=>{let a=new Promise(async(t,i)=>{try{e=decodeURIComponent(e),e=(0,m.Zc)(e),((e,t=ss)=>{if("function"==typeof t?!t(e):!t.some(t=>{let n=new URL(`https://${t.replace(/^https?:\/\//,"")}`),{hostname:i,pathname:a}=new URL(e);return RegExp(`(^|\\.)${n.hostname}$`).test(i)&&RegExp(`^${n.pathname.replace(/\/+$/,"")}(/+|$)`).test(a)}))throw Error(`Invalid or disallowed library URL: "${e}"`)})(e,n.current.validateLibraryUrl);let i=await (await fetch(e)).blob();t(i)}catch(e){i(e)}}),l=i!==t.id;await (l&&document.hidden?new Promise(e=>{window.addEventListener("focus",()=>e(),{once:!0})}):null);try{await t.updateLibrary({libraryItems:a,prompt:l,merge:!0,defaultStatus:"published",openLibraryMenu:!0})}catch(e){throw t.updateScene({appState:{errorMessage:e.message}}),e}finally{if(window.location.hash.includes(m.fa.addLibrary)){let e=new URLSearchParams(window.location.hash.slice(1));e.delete(m.fa.addLibrary),window.history.replaceState({},m.s,`#${e.toString()}`)}else if(window.location.search.includes(m.ea.addLibrary)){let e=new URLSearchParams(window.location.search);e.delete(m.ea.addLibrary),window.history.replaceState({},m.s,`?${e.toString()}`)}}},a=t=>{t.preventDefault();let n=sf();n&&(t.stopImmediatePropagation(),window.history.replaceState({},"",t.oldURL),e(n))},l=sf();if(l&&e(l),"getInitialLibraryItems"in n.current&&n.current.getInitialLibraryItems&&(console.warn("useHandleLibrar `opts.getInitialLibraryItems` is deprecated. Use `opts.adapter` instead."),Promise.resolve(n.current.getInitialLibraryItems()).then(e=>{t.updateLibrary({libraryItems:e,merge:!0})}).catch(e=>{console.error(`UseHandeLibrary getInitialLibraryItems failed: ${e?.message}`)})),"adapter"in n.current&&n.current.adapter){let e=n.current.adapter,a=n.current.migrationAdapter,l=(0,m.tb)();a?l.resolve((0,m.Tb)(a.load).then(async t=>{let n=null;try{if(!t)return sb.getLibraryItems(e,"load");n=(0,m.mh)(t.libraryItems||[],"published");let i=await sx(e,sp([],n));try{await a.clear()}catch(e){console.error(`couldn't delete legacy library data: ${e.message}`)}return i}catch(e){return console.error(`couldn't migrate legacy library data: ${e.message}`),n}}).catch(t=>(console.error(`error during library migration: ${t.message}`),sb.getLibraryItems(e,"load")))):l.resolve((0,m.Tb)(sb.getLibraryItems,e,"load")),t.updateLibrary({libraryItems:l.then(e=>{let t=e||[];return sv=sE(t),t}),merge:!0}).finally(()=>{i.current=!0})}return window.addEventListener("hashchange",a),()=>{window.removeEventListener("hashchange",a)}},[t]),(0,E.useEffect)(()=>{let e=so.on(async(e,t)=>{let a=i.current,l="adapter"in n.current&&n.current.adapter||null;try{l&&sv!==sE(t)&&await sx(l,e)}catch(t){console.error(`couldn't persist library update: ${t.message}`,e),a&&n.current.excalidrawAPI&&n.current.excalidrawAPI.updateScene({appState:{errorMessage:aO("errors.saveLibraryError")}})}}),t=e=>{sy&&(0,m.wb)(e)};return window.addEventListener("beforeunload",t),()=>{window.removeEventListener("beforeunload",t),e(),sv=0,sy=0}},[])},sS=(0,E.forwardRef)(({children:e,gap:t,align:n,justifyContent:i,className:a,style:l},r)=>(0,W.jsx)("div",{className:(0,el.default)("Stack Stack_horizontal",a),style:{"--gap":t,alignItems:n,justifyContent:i,...l},ref:r,children:e})),sC=(0,E.forwardRef)(({children:e,gap:t,align:n,justifyContent:i,className:a,style:l},r)=>(0,W.jsx)("div",{className:(0,el.default)("Stack Stack_vertical",a),style:{"--gap":t,justifyItems:n,justifyContent:i,...l},ref:r,children:e})),sk=({theme:e,id:t,libraryReturnUrl:n})=>{let i=n||window.location.origin+window.location.pathname;return(0,W.jsx)("a",{className:"library-menu-browse-button",href:`${f.a.VITE_APP_LIBRARY_URL}?target=${window.name||"_blank"}&referrer=${i}&useHash=true&token=${t}&theme=${e}&version=${m.qa.excalidrawLibrary}`,target:"_excalidraw_libraries",children:aO("labels.libraries")})},sI=({libraryReturnUrl:e,theme:t,id:n,style:i,children:a,className:l})=>(0,W.jsxs)("div",{className:(0,el.default)("library-menu-control-buttons",l),style:i,children:[(0,W.jsx)(sk,{id:n,libraryReturnUrl:e,theme:t}),a]}),sj=/({{[\w-]+}})|(<[\w-]+>)|(<\/[\w-]+>)/g,sT=/{{([\w-]+)}}/,sM=/<([\w-]+)>/,sL=/<\/([\w-]+)>/,sD=({i18nKey:e,children:t,...n})=>{var i;let a,{t:l}=az();return E.default.createElement(E.default.Fragment,{},...(i=l(e),a=[{name:"",children:[]}],i.split(sj).filter(Boolean).forEach(e=>{let t=e.match(sM),l=e.match(sL),r=e.match(sT);if(null!==t){let e=t[1];n.hasOwnProperty(e)?a.push({name:e,children:[]}):console.warn(`Trans: missed to pass in prop ${e} for interpolating ${i}`)}else if(null!==l)if(l[1]===a[a.length-1].name){let e=a.pop(),t=E.default.createElement(E.default.Fragment,{},...e.children),i=n[e.name];"function"==typeof i&&a[a.length-1].children.push(i(t))}else console.warn(`Trans: unexpected end tag ${e} for interpolating ${i}`);else if(null!==r){let e=r[1];n.hasOwnProperty(e)?a[a.length-1].children.push(n[e]):console.warn(`Trans: key ${e} not in props for interpolating ${i}`)}else a[a.length-1].children.push(e)}),1!==a.length&&console.warn(`Trans: stack not empty for interpolating ${i}`),a[0].children))},sN=({label:e,onClick:t,className:n,children:i,actionType:a,type:l="button",isLoading:r,...s})=>{let o=a?`Dialog__action-button--${a}`:"";return(0,W.jsxs)("button",{className:(0,el.default)("Dialog__action-button",o,n),type:l,"aria-label":e,onClick:t,...s,children:[i&&(0,W.jsx)("div",{style:r?{visibility:"hidden"}:{},children:i}),(0,W.jsx)("div",{style:r?{visibility:"hidden"}:{},children:e}),r&&(0,W.jsx)("div",{style:{position:"absolute",inset:0},children:(0,W.jsx)(aU,{})})]})},sA=e=>{let{onConfirm:t,onCancel:n,children:i,confirmText:a=aO("buttons.confirm"),cancelText:l=aO("buttons.cancel"),className:r="",...s}=e,o=hJ(),c=aC(sq),{container:d}=hX();return(0,W.jsxs)(s3,{onCloseRequest:n,size:"small",...s,className:`confirm-dialog ${r}`,children:[i,(0,W.jsxs)("div",{className:"confirm-dialog-buttons",children:[(0,W.jsx)(sN,{label:l,onClick:()=>{o({openMenu:null}),c(!1),(0,er.flushSync)(()=>{n()}),d?.focus()}}),(0,W.jsx)(sN,{label:a,onClick:()=>{o({openMenu:null}),c(!1),(0,er.flushSync)(()=>{t()}),d?.focus()},actionType:"danger"})]})]})},sP=class{static has(e){try{return!!window.localStorage.getItem(e)}catch(e){return console.warn(`localStorage.getItem error: ${e.message}`),!1}}static get(e){try{let t=window.localStorage.getItem(e);return t?JSON.parse(t):null}catch(e){return console.warn(`localStorage.getItem error: ${e.message}`),null}}};(0,y.d)(sP,"set",(e,t)=>{try{return window.localStorage.setItem(e,JSON.stringify(t)),!0}catch(e){return console.warn(`localStorage.setItem error: ${e.message}`),!1}}),(0,y.d)(sP,"delete",e=>{try{window.localStorage.removeItem(e)}catch(e){console.warn(`localStorage.removeItem error: ${e.message}`)}});var sR=async e=>{let t=Math.round(8),n=Math.max(Math.round(2),2),i=(0,m.hb)(e,6),a=document.createElement("canvas");a.width=128*i[0].length+(i[0].length+1)*(2*t)-2*t,a.height=128*i.length+(i.length+1)*(2*t)-2*t;let l=a.getContext("2d");for(let[i,r]of(l.fillStyle=io.default.white,l.fillRect(0,0,a.width,a.height),e.entries())){let e=await (0,m.pi)({elements:r.elements,files:null,maxWidthOrHeight:128}),{width:a,height:s}=e,o=Math.floor(i/6)*(128+2*t),c=i%6*(128+2*t);l.drawImage(e,c+(128-a)/2+t,o+(128-s)/2+t),l.lineWidth=n,l.strokeStyle=io.default.gray[4],l.strokeRect(c+t/2,o+t/2,128+t,128+t)}return await (0,m.Eh)(new File([await (0,m.yh)(a)],"preview",{type:m.T.png}),{outputType:m.T.jpg,maxWidthOrHeight:5e3})},s_=({libItem:e,appState:t,index:n,onChange:i,onRemove:a})=>{let l=(0,E.useRef)(null),r=(0,E.useRef)(null);return(0,E.useEffect)(()=>{let n=l.current;n&&(async()=>{n.innerHTML=(await (0,m.ri)({elements:e.elements,appState:{...t,viewBackgroundColor:io.default.white,exportBackground:!0},files:null,skipInliningFonts:!0})).outerHTML})()},[e.elements,t]),(0,W.jsxs)("div",{className:"single-library-item",children:["published"===e.status&&(0,W.jsx)("span",{className:"single-library-item-status",children:aO("labels.statusPublished")}),(0,W.jsx)("div",{ref:l,className:"single-library-item__svg"}),(0,W.jsx)(aH,{"aria-label":aO("buttons.remove"),type:"button",icon:m.ge,className:"single-library-item--remove",onClick:a.bind(null,e.id),title:aO("buttons.remove")}),(0,W.jsxs)("div",{style:{display:"flex",margin:"0.8rem 0",width:"100%",fontSize:"14px",fontWeight:500,flexDirection:"column"},children:[(0,W.jsxs)("label",{style:{display:"flex",justifyContent:"space-between",flexDirection:"column"},children:[(0,W.jsxs)("div",{style:{padding:"0.5em 0"},children:[(0,W.jsx)("span",{style:{fontWeight:500,color:io.default.gray[6]},children:aO("publishDialog.itemName")}),(0,W.jsx)("span",{"aria-hidden":"true",className:"required",children:"*"})]}),(0,W.jsx)("input",{type:"text",ref:r,style:{width:"80%",padding:"0.2rem"},defaultValue:e.name,placeholder:"Item name",onChange:e=>{i(e.target.value,n)}})]}),(0,W.jsx)("span",{className:"error",children:e.error})]})]})},sO=({onClose:e,libraryItems:t,appState:n,onSuccess:i,onError:a,updateItemsInStorage:l,onRemove:r})=>{let s,[o,c]=(0,E.useState)({authorName:"",githubHandle:"",name:"",description:"",twitterHandle:"",website:""}),[d,h]=(0,E.useState)(!1);(0,E.useEffect)(()=>{let e=sP.get(m.Ba.PUBLISH_LIBRARY);e&&c(e)},[]);let[u,p]=(0,E.useState)(t.slice());(0,E.useEffect)(()=>{p(t.slice())},[t]);let g=e=>{c({...o,[e.target.name]:e.target.value})},b=async e=>{e.preventDefault(),h(!0);let t=[],n=!1;if(u.forEach(e=>{let i="";e.name||(i=aO("publishDialog.errors.required"),n=!0),t.push({...e,error:i})}),n){p(t),h(!1);return}let l=await sR(u),r=new Blob([JSON.stringify({type:m.V.excalidrawLibrary,version:m.qa.excalidrawLibrary,source:m.W,libraryItems:u},null,2)],{type:"application/json"}),s=new FormData;s.append("excalidrawLib",r),s.append("previewImage",l),s.append("previewImageType",l.type),s.append("title",o.name),s.append("authorName",o.authorName),s.append("githubHandle",o.githubHandle),s.append("name",o.name),s.append("description",o.description),s.append("twitterHandle",o.twitterHandle),s.append("website",o.website),fetch(`${f.a.VITE_APP_LIBRARY_BACKEND}/submit`,{method:"post",body:s}).then(e=>e.ok?e.json().then(({url:e})=>{sP.delete(m.Ba.PUBLISH_LIBRARY),i({url:e,authorName:o.authorName,items:u})}):e.json().catch(()=>{throw Error(e.statusText||"something went wrong")}).then(t=>{throw Error(t.message||e.statusText||"something went wrong")}),e=>{console.error(e),a(e),h(!1)}).catch(e=>{console.error(e),a(e),h(!1)})},v=(0,E.useCallback)(()=>{l(u),sP.set(m.Ba.PUBLISH_LIBRARY,o),e()},[u,e,l,o]),y=!!t.length,x=t.some(e=>"published"===e.status);return(0,W.jsx)(s3,{onCloseRequest:v,title:aO("publishDialog.title"),className:"publish-library",children:y?(0,W.jsxs)("form",{onSubmit:b,children:[(0,W.jsx)("div",{className:"publish-library-note",children:(0,W.jsx)(sD,{i18nKey:"publishDialog.noteDescription",link:e=>(0,W.jsx)("a",{href:"https://libraries.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:e})})}),(0,W.jsx)("span",{className:"publish-library-note",children:(0,W.jsx)(sD,{i18nKey:"publishDialog.noteGuidelines",link:e=>(0,W.jsx)("a",{href:"https://github.com/excalidraw/excalidraw-libraries#guidelines",target:"_blank",rel:"noopener noreferrer",children:e})})}),(0,W.jsx)("div",{className:"publish-library-note",children:aO("publishDialog.noteItems")}),x&&(0,W.jsx)("span",{className:"publish-library-note publish-library-warning",children:aO("publishDialog.republishWarning")}),(s=[],u.forEach((e,t)=>{s.push((0,W.jsx)("div",{className:"single-library-item-wrapper",children:(0,W.jsx)(s_,{libItem:e,appState:n,index:t,onChange:(e,t)=>{let n=u.slice();n[t].name=e,p(n)},onRemove:r})},t))}),(0,W.jsx)("div",{className:"selected-library-items",children:s})),(0,W.jsxs)("div",{className:"publish-library__fields",children:[(0,W.jsxs)("label",{children:[(0,W.jsxs)("div",{children:[(0,W.jsx)("span",{children:aO("publishDialog.libraryName")}),(0,W.jsx)("span",{"aria-hidden":"true",className:"required",children:"*"})]}),(0,W.jsx)("input",{type:"text",name:"name",required:!0,value:o.name,onChange:g,placeholder:aO("publishDialog.placeholder.libraryName")})]}),(0,W.jsxs)("label",{style:{alignItems:"flex-start"},children:[(0,W.jsxs)("div",{children:[(0,W.jsx)("span",{children:aO("publishDialog.libraryDesc")}),(0,W.jsx)("span",{"aria-hidden":"true",className:"required",children:"*"})]}),(0,W.jsx)("textarea",{name:"description",rows:4,required:!0,value:o.description,onChange:g,placeholder:aO("publishDialog.placeholder.libraryDesc")})]}),(0,W.jsxs)("label",{children:[(0,W.jsxs)("div",{children:[(0,W.jsx)("span",{children:aO("publishDialog.authorName")}),(0,W.jsx)("span",{"aria-hidden":"true",className:"required",children:"*"})]}),(0,W.jsx)("input",{type:"text",name:"authorName",required:!0,value:o.authorName,onChange:g,placeholder:aO("publishDialog.placeholder.authorName")})]}),(0,W.jsxs)("label",{children:[(0,W.jsx)("span",{children:aO("publishDialog.githubUsername")}),(0,W.jsx)("input",{type:"text",name:"githubHandle",value:o.githubHandle,onChange:g,placeholder:aO("publishDialog.placeholder.githubHandle")})]}),(0,W.jsxs)("label",{children:[(0,W.jsx)("span",{children:aO("publishDialog.twitterUsername")}),(0,W.jsx)("input",{type:"text",name:"twitterHandle",value:o.twitterHandle,onChange:g,placeholder:aO("publishDialog.placeholder.twitterHandle")})]}),(0,W.jsxs)("label",{children:[(0,W.jsx)("span",{children:aO("publishDialog.website")}),(0,W.jsx)("input",{type:"text",name:"website",pattern:"https?://.+",title:aO("publishDialog.errors.website"),value:o.website,onChange:g,placeholder:aO("publishDialog.placeholder.website")})]}),(0,W.jsx)("span",{className:"publish-library-note",children:(0,W.jsx)(sD,{i18nKey:"publishDialog.noteLicense",link:e=>(0,W.jsx)("a",{href:"https://github.com/excalidraw/excalidraw-libraries/blob/main/LICENSE",target:"_blank",rel:"noopener noreferrer",children:e})})})]}),(0,W.jsxs)("div",{className:"publish-library__buttons",children:[(0,W.jsx)(sN,{label:aO("buttons.cancel"),onClick:v,"data-testid":"cancel-clear-canvas-button"}),(0,W.jsx)(sN,{type:"submit",label:aO("buttons.submit"),actionType:"primary",isLoading:d})]})]}):(0,W.jsx)("p",{style:{padding:"1em",textAlign:"center",fontWeight:500},children:aO("publishDialog.atleastOneLibItem")})})},sF=({className:e="",children:t,onToggle:n,title:i,...a})=>{let l=hZ(),r=(0,el.default)(`dropdown-menu-button ${e}`,"zen-mode-transition",{"dropdown-menu-button--mobile":l.editor.isMobile}).trim();return(0,W.jsx)("button",{"data-prevent-outside-click":!0,className:r,onClick:n,type:"button","data-testid":"dropdown-menu-button",title:i,...a,children:t})};sF.displayName="DropdownMenuTrigger";var sz=()=>(0,W.jsx)("div",{style:{height:"1px",backgroundColor:"var(--default-border-color)",margin:".5rem 0"}});sz.displayName="DropdownMenuSeparator";var sU=({children:e,onClickOutside:t,className:n="",onSelect:i,style:a})=>{let l=hZ(),r=(0,E.useRef)(null),s=lb({onClickOutside:t});lf(r,()=>{s.onClickOutside?.()}),(0,E.useEffect)(()=>{let e=e=>{e.key===m.hg.ESCAPE&&(e.stopImmediatePropagation(),s.onClickOutside?.())},t={capture:!0};return document.addEventListener("keydown",e,t),()=>{document.removeEventListener("keydown",e,t)}},[s]);let o=(0,el.default)(`dropdown-menu ${n}`,{"dropdown-menu--mobile":l.editor.isMobile}).trim();return(0,W.jsx)(l_.Provider,{value:{onSelect:i},children:(0,W.jsx)("div",{ref:r,className:o,style:a,"data-testid":"dropdown-menu",children:l.editor.isMobile?(0,W.jsx)(sC,{className:"dropdown-menu-container",children:e}):(0,W.jsx)(lx,{className:"dropdown-menu-container",padding:2,style:{zIndex:2},children:e})})})};sU.displayName="DropdownMenuContent";var sB=({icon:e,shortcut:t,href:n,children:i,onSelect:a,className:l="",selected:r,rel:s="noreferrer",...o})=>{let c=lF(o.onClick,a);return(0,W.jsx)("a",{...o,href:n,target:"_blank",rel:"noreferrer",className:lO(l,r),title:o.title??o["aria-label"],onClick:c,children:(0,W.jsx)(lz,{icon:e,shortcut:t,children:i})})};sB.displayName="DropdownMenuItemLink";var sW=({children:e,open:t})=>{let n=E.default.Children.toArray(e).find(e=>E.default.isValidElement(e)&&"string"!=typeof e.type&&e?.type.displayName&&"DropdownMenuTrigger"===e.type.displayName)||null,i=E.default.Children.toArray(e).find(e=>E.default.isValidElement(e)&&"string"!=typeof e.type&&e?.type.displayName&&"DropdownMenuContent"===e.type.displayName)||null;return(0,W.jsxs)(W.Fragment,{children:[n,t&&i]})};sW.Trigger=sF,sW.Content=sU,sW.Item=lU,sW.ItemLink=sB,sW.ItemCustom=({children:e,className:t="",selected:n,...i})=>(0,W.jsx)("div",{...i,className:`dropdown-menu-item-base dropdown-menu-item-custom ${t} ${n?"dropdown-menu-item--selected":""}`.trim(),children:e}),sW.Group=lR,sW.Separator=sz,sW.displayName="DropdownMenu";var sH=({setAppState:e,selectedItems:t,library:n,onRemoveFromLibrary:i,resetLibrary:a,onSelectItems:l,appState:r,className:s})=>{let o,c,d,[h]=aS(sc),[u,p]=aS(sq),[g,f]=(0,E.useState)(!1),b=!!t.length,v=b?h.libraryItems.filter(e=>t.includes(e.id)):h.libraryItems,y=b?aO("buttons.remove"):aO("buttons.resetLibrary"),[x,w]=(0,E.useState)(!1),[S,C]=(0,E.useState)(null),k=(0,E.useCallback)(()=>(0,W.jsxs)(s3,{onCloseRequest:()=>C(null),title:aO("publishSuccessDialog.title"),className:"publish-library-success",size:"small",children:[(0,W.jsx)("p",{children:(0,W.jsx)(sD,{i18nKey:"publishSuccessDialog.content",authorName:S.authorName,link:e=>(0,W.jsx)("a",{href:S?.url,target:"_blank",rel:"noopener noreferrer",children:e})})}),(0,W.jsx)(aH,{type:"button",title:aO("buttons.close"),"aria-label":aO("buttons.close"),label:aO("buttons.close"),onClick:()=>C(null),"data-testid":"publish-library-success-close",className:"publish-library-success-close"})]}),[C,S]),I=async()=>{try{await n.updateLibrary({libraryItems:(0,m.fh)({description:"Excalidraw library files"}),merge:!0,openLibraryMenu:!0})}catch(t){if(t?.name==="AbortError")return void console.warn(t);e({errorMessage:aO("errors.importLibraryError")})}},j=async()=>{let t=b?v:await n.getLatestLibrary();(0,m.Nh)(t).catch(m.pb).catch(t=>{e({errorMessage:t.message})})};return(0,W.jsxs)("div",{className:(0,el.default)("library-menu-dropdown-container",s),children:[(0,W.jsxs)(sW,{open:u,children:[(0,W.jsx)(sW.Trigger,{onToggle:()=>p(!u),children:m.hd}),(0,W.jsxs)(sW.Content,{onClickOutside:()=>p(!1),onSelect:()=>p(!1),className:"library-menu",children:[!b&&(0,W.jsx)(sW.Item,{onSelect:I,icon:m.Ld,"data-testid":"lib-dropdown--load",children:aO("buttons.load")}),!!v.length&&(0,W.jsx)(sW.Item,{onSelect:j,icon:m.Ad,"data-testid":"lib-dropdown--export",children:aO("buttons.export")}),!!v.length&&(0,W.jsx)(sW.Item,{onSelect:()=>f(!0),icon:m.ud,children:y}),b&&(0,W.jsx)(sW.Item,{icon:m.Xe,onSelect:()=>w(!0),"data-testid":"lib-dropdown--remove",children:aO("buttons.publishLibrary")})]})]}),t.length>0&&(0,W.jsx)("div",{className:"library-actions-counter",children:t.length}),g&&(o=t.length?aO("alerts.removeItemsFromsLibrary",{count:t.length}):aO("alerts.resetLibrary"),c=t.length?aO("confirmDialog.removeItemsFromLib"):aO("confirmDialog.resetLibrary"),(0,W.jsx)(sA,{onConfirm:()=>{t.length?i():a(),f(!1)},onCancel:()=>{f(!1)},title:c,children:(0,W.jsx)("p",{children:o})})),x&&(0,W.jsx)(sO,{onClose:()=>w(!1),libraryItems:(d=h.libraryItems,d.filter(e=>t.includes(e.id))),appState:r,onSuccess:e=>{var i;let a;return i=h.libraryItems,w(!1),C({url:e.url,authorName:e.authorName}),void((a=i.slice()).forEach(e=>{t.includes(e.id)&&(e.status="published")}),n.setLibrary(a))},onError:e=>window.alert(e),updateItemsInStorage:()=>n.setLibrary(h.libraryItems),onRemove:e=>l(t.filter(t=>t!==e))}),S&&k()]})},s$=({selectedItems:e,onSelectItems:t,className:n})=>{let{library:i}=hG(),{clearLibraryCache:a,deleteItemsFromLibraryCache:l}=sl(),r=E.default.useContext(lm),s=hJ(),[o]=aS(sc),c=async n=>{let a=n.filter(t=>!e.includes(t.id));i.setLibrary(a).catch(()=>{s({errorMessage:aO("alerts.errorRemovingFromLibrary")})}),l(e),t([])};return(0,W.jsx)(sH,{appState:r,setAppState:s,selectedItems:e,onSelectItems:t,library:i,onRemoveFromLibrary:()=>c(o.libraryItems),resetLibrary:()=>{i.resetLibrary(),a()},className:n})},sY=(0,E.memo)(({id:e,elements:t,isPending:n,onClick:i,selected:a,onToggle:l,onDrag:r,svgCache:s})=>{let o=(0,E.useRef)(null),c=((e,t,n)=>{let[i,a]=(0,E.useState)();return(0,E.useEffect)(()=>{if(t)if(e){let i=n.get(e);i?a(i):(async()=>{let i=await sa(t);i.querySelector(".style-fonts")?.remove(),i&&(n.set(e,i),a(i))})()}else(async()=>{a(await sa(t))})()},[e,t,n,a]),i})(e,t,s);(0,E.useEffect)(()=>{let e=o.current;if(e)return c&&(e.innerHTML=c.outerHTML),()=>{e.innerHTML=""}},[c]);let[d,h]=(0,E.useState)(!1),u=hZ().editor.isMobile,p=n&&(0,W.jsx)("div",{className:"library-unit__adder",children:m.gd});return(0,W.jsxs)("div",{className:(0,el.default)("library-unit",{"library-unit__active":t,"library-unit--hover":t&&d,"library-unit--selected":a,"library-unit--skeleton":!c}),onMouseEnter:()=>h(!0),onMouseLeave:()=>h(!1),children:[(0,W.jsx)("div",{className:(0,el.default)("library-unit__dragger",{"library-unit__pulse":!!n}),ref:o,draggable:!!t,onClick:t||n?t=>{e&&t.shiftKey?l(e,t):i(e)}:void 0,onDragStart:t=>{e?(h(!1),r(e,t)):t.preventDefault()}}),p,e&&t&&(d||u||a)&&(0,W.jsx)(rh,{checked:a,onChange:(t,n)=>l(e,n),className:"library-unit__checkbox"})]})}),sV=()=>(0,W.jsx)("div",{className:"library-unit library-unit--skeleton"}),sG=E.default.useTransition||function(){return[!1,(0,E.useCallback)(e=>e(),[])]},sK=({children:e})=>(0,W.jsx)("div",{className:"library-menu-items-container__grid",children:e}),sZ=(0,E.memo)(({items:e,onItemSelectToggle:t,onItemDrag:n,isItemSelected:i,onClick:a,svgCache:l,itemsRenderedPerBatch:r})=>{let[,s]=sG(),[o,c]=(0,E.useState)(0);return(0,E.useEffect)(()=>{o<e.length&&s(()=>{c(o+r)})},[o,e.length,s,r]),(0,W.jsx)(W.Fragment,{children:e.map((e,r)=>r<o?(0,W.jsx)(sY,{elements:e?.elements,isPending:!e?.id&&!!e?.elements,onClick:a,svgCache:l,id:e?.id,selected:i(e.id),onToggle:t,onDrag:n},e?.id??r):(0,W.jsx)(sV,{},r))})}),sX=S(0);function sQ({isLoading:e,libraryItems:t,onAddToLibrary:n,onInsertLibraryItems:i,pendingElements:a,theme:l,id:r,libraryReturnUrl:s,onSelectItems:o,selectedItems:c}){let d=(0,E.useRef)(null),h=(e=>{let[t,n]=aS(sX);return(0,E.useEffect)(()=>{let{current:t}=e;if(!t)return;let i=(0,ic.default)(()=>{let{scrollTop:e}=t;n(e)},200);return t.addEventListener("scroll",i),()=>{i.cancel(),t.removeEventListener("scroll",i)}},[e,n]),t})(d);(0,E.useEffect)(()=>{h>0&&d.current?.scrollTo(0,h)},[]);let{svgCache:u}=sl(),p=(0,E.useMemo)(()=>t.filter(e=>"published"!==e.status),[t]),g=(0,E.useMemo)(()=>t.filter(e=>"published"===e.status),[t]),f=!t.length&&!a.length,b=!a.length&&!p.length&&!g.length,[v,y]=(0,E.useState)(null),x=(0,E.useCallback)((e,t)=>{let n=!c.includes(e),i=[...p,...g];if(n){if(t.shiftKey&&v){let t=i.findIndex(e=>e.id===v),n=i.findIndex(t=>t.id===e);if(-1===t||-1===n)return void o([...c,e]);let a=(0,m.xb)(c);o(i.reduce((e,i,l)=>((l>=t&&l<=n||a.has(i.id))&&e.push(i.id),e),[]))}else o([...c,e]);y(e)}else y(null),o(c.filter(t=>t!==e))},[v,o,g,c,p]),w=(0,E.useCallback)(e=>(c.includes(e)?t.filter(e=>c.includes(e.id)):t.filter(t=>t.id===e)).map(e=>({...e,elements:(0,m.dg)(e.elements,{randomizeSeed:!0})})),[t,c]),S=(0,E.useCallback)((e,t)=>{t.dataTransfer.setData(m.T.excalidrawlib,(0,m.Mh)(w(e)))},[w]),C=(0,E.useCallback)(e=>!!e&&c.includes(e),[c]),k=(0,E.useCallback)(()=>{n(a)},[a,n]),I=(0,E.useCallback)(e=>{e&&i(w(e))},[w,i]),j=u.size>=t.length?64:17;return(0,W.jsxs)("div",{className:"library-menu-items-container",style:a.length||p.length||g.length?{justifyContent:"flex-start"}:{borderBottom:0},children:[!b&&(0,W.jsx)(s$,{selectedItems:c,onSelectItems:o,className:"library-menu-dropdown-container--in-heading"}),(0,W.jsxs)(sC,{className:"library-menu-items-container__items",align:"start",gap:1,style:{flex:g.length>0?1:"0 1 auto",marginBottom:0},ref:d,children:[(0,W.jsxs)(W.Fragment,{children:[!b&&(0,W.jsx)("div",{className:"library-menu-items-container__header",children:aO("labels.personalLib")}),e&&(0,W.jsx)("div",{style:{position:"absolute",top:"var(--container-padding-y)",right:"var(--container-padding-x)",transform:"translateY(50%)"},children:(0,W.jsx)(aU,{})}),a.length||p.length?(0,W.jsxs)(sK,{children:[a.length>0&&(0,W.jsx)(sZ,{itemsRenderedPerBatch:j,items:[{id:null,elements:a}],onItemSelectToggle:x,onItemDrag:S,onClick:k,isItemSelected:C,svgCache:u}),(0,W.jsx)(sZ,{itemsRenderedPerBatch:j,items:p,onItemSelectToggle:x,onItemDrag:S,onClick:I,isItemSelected:C,svgCache:u})]}):(0,W.jsxs)("div",{className:"library-menu-items__no-items",children:[(0,W.jsx)("div",{className:"library-menu-items__no-items__label",children:aO("library.noItems")}),(0,W.jsx)("div",{className:"library-menu-items__no-items__hint",children:g.length>0?aO("library.hint_emptyPrivateLibrary"):aO("library.hint_emptyLibrary")})]})]}),(0,W.jsxs)(W.Fragment,{children:[(g.length>0||a.length>0||p.length>0)&&(0,W.jsx)("div",{className:"library-menu-items-container__header library-menu-items-container__header--excal",children:aO("labels.excalidrawLib")}),g.length>0?(0,W.jsx)(sK,{children:(0,W.jsx)(sZ,{itemsRenderedPerBatch:j,items:g,onItemSelectToggle:x,onItemDrag:S,onClick:I,isItemSelected:C,svgCache:u})}):p.length>0?(0,W.jsx)("div",{style:{margin:"1rem 0",display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",width:"100%",fontSize:".9rem"},children:aO("library.noItems")}):null]}),f&&(0,W.jsx)(sI,{style:{padding:"16px 0",width:"100%"},id:r,libraryReturnUrl:s,theme:l,children:(0,W.jsx)(s$,{selectedItems:c,onSelectItems:o})})]})]})}var sq=S(!1),sJ=({children:e})=>(0,W.jsx)("div",{className:"layer-ui__library",children:e}),s0=(0,E.memo)(({onInsertLibraryItems:e,pendingElements:t,onAddToLibrary:n,setAppState:i,libraryReturnUrl:a,library:l,id:r,theme:s,selectedItems:o,onSelectItems:c})=>{let[d]=aS(sc),h=(0,E.useCallback)(e=>{(async(e,t)=>{for(let t of(a8("element","addToLibrary","ui"),m.za))if(e.some(e=>e.type===t))return i({errorMessage:aO(`errors.libraryElementTypeError.${t}`)});let a=[{status:"unpublished",elements:e,id:(0,m.sc)(),created:Date.now()},...t];n(),l.setLibrary(a).catch(()=>{i({errorMessage:aO("alerts.errorAddingToLibrary")})})})(e,d.libraryItems)},[n,l,i,d.libraryItems]),u=(0,E.useMemo)(()=>d.libraryItems,[d]);if("loading"===d.status&&!d.isInitialized)return(0,W.jsx)(sJ,{children:(0,W.jsx)("div",{className:"layer-ui__library-message",children:(0,W.jsxs)("div",{children:[(0,W.jsx)(aU,{size:"2em"}),(0,W.jsx)("span",{children:aO("labels.libraryLoadingMessage")})]})})});let p=d.libraryItems.length>0||t.length>0;return(0,W.jsxs)(sJ,{children:[(0,W.jsx)(sQ,{isLoading:"loading"===d.status,libraryItems:u,onAddToLibrary:h,onInsertLibraryItems:e,pendingElements:t,id:r,libraryReturnUrl:a,theme:s,onSelectItems:c,selectedItems:o}),p&&(0,W.jsx)(sI,{className:"library-menu-control-buttons--at-bottom",style:{padding:"16px 12px 0 12px"},id:r,libraryReturnUrl:a,theme:s})]})}),s1=(e,t)=>({elements:e,pending:(0,m.vk)(e,{selectedElementIds:t},{includeBoundTextElement:!0,includeElementsInFrames:!0}),selectedElementIds:t}),s2=(0,E.memo)(()=>{let e=hG(),{onInsertElements:t}=e,n=hK(),i=E.default.useContext(lm),a=hJ(),[l,r]=(0,E.useState)([]),s=(0,E.useMemo)(()=>e.library,[e.library]),o=((e,t)=>{let n=hQ(),[i,a]=(0,E.useState)(()=>s1(n,e.selectedElementIds)),l=(0,E.useRef)(new Map);return(0,E.useEffect)(()=>{for(let e of i.pending)l.current.set(e.id,e.version)},[i.pending]),(0,E.useEffect)(()=>{"up"===t.state.cursorButton&&"selection"===t.state.activeTool.type&&a(i=>{if(!(0,m.Hb)(i.selectedElementIds,e.selectedElementIds))return l.current.clear(),s1(n,e.selectedElementIds);let a=t.scene.getNonDeletedElementsMap();for(let t of Object.keys(e.selectedElementIds)){let i=a.get(t)?.version;if(i&&i!==l.current.get(t))return s1(n,e.selectedElementIds)}return i})},[t,t.state.cursorButton,t.state.activeTool.type,e.selectedElementIds,n]),i.pending})(i,e),c=(0,E.useCallback)(e=>{t(sg(e))},[t]),d=(0,E.useCallback)(()=>{a({selectedElementIds:{},selectedGroupIds:{},activeEmbeddable:null})},[a]);return(0,W.jsx)(s0,{pendingElements:o,onInsertLibraryItems:c,onAddToLibrary:d,setAppState:a,libraryReturnUrl:n.libraryReturnUrl,library:s,id:e.id,theme:i.theme,selectedItems:l,onSelectItems:r})}),s3=e=>{let[t,n]=(()=>{let[e,t]=(0,E.useState)(null);return[e,(0,E.useCallback)(e=>t(e),[])]})(),[i]=(0,E.useState)(document.activeElement),{id:a}=hX(),l=hZ().viewport.isMobile;(0,E.useEffect)(()=>{if(!t)return;let n=(0,m.Gb)(t);setTimeout(()=>{n.length>0&&!1!==e.autofocus&&(n[1]||n[0]).focus()});let i=e=>{if(e.key===m.hg.TAB){let n=(0,m.Gb)(t),{activeElement:i}=document,a=n.findIndex(e=>e===i);0===a&&e.shiftKey?(n[n.length-1].focus(),e.preventDefault()):a!==n.length-1||e.shiftKey||(n[0].focus(),e.preventDefault())}};return t.addEventListener("keydown",i),()=>t.removeEventListener("keydown",i)},[t,e.autofocus]);let r=hJ(),s=aC(sq),o=()=>{r({openMenu:null}),s(!1),i.focus(),e.onCloseRequest()};return(0,W.jsx)(sn,{className:(0,el.default)("Dialog",e.className,{"Dialog--fullscreen":l}),labelledBy:"dialog-title",maxWidth:function(e){if(e&&"number"==typeof e)return e;switch(e){case"small":return 550;case"wide":return 1024;default:return 800}}(e.size),onCloseRequest:o,closeOnClickOutside:e.closeOnClickOutside,children:(0,W.jsxs)(lx,{ref:n,children:[e.title&&(0,W.jsx)("h2",{id:`${a}-dialog-title`,className:"Dialog__title",children:(0,W.jsx)("span",{className:"Dialog__titleContent",children:e.title})}),l&&(0,W.jsx)("button",{className:"Dialog__close",onClick:o,title:aO("buttons.close"),"aria-label":aO("buttons.close"),type:"button",children:m.ge}),(0,W.jsx)("div",{className:"Dialog__content",children:e.children})]})})},s5=({type:e="button",onSelect:t,selected:n,children:i,className:a="",...l})=>(0,W.jsx)("button",{onClick:(0,m.Ib)(l.onClick,e=>{t()}),type:e,className:(0,el.default)("excalidraw-button",a,{selected:n}),...l,children:i}),s4=(0,E.forwardRef)(({onChange:e,label:t,fullWidth:n,placeholder:i,readonly:a,selectOnRender:l,onKeyDown:r,isRedacted:s=!1,icon:o,className:c,...d},h)=>{let u=(0,E.useRef)(null);(0,E.useImperativeHandle)(h,()=>u.current),(0,E.useLayoutEffect)(()=>{l&&(u.current?.focus(),u.current?.select())},[l]);let[p,g]=(0,E.useState)(!1);return(0,W.jsxs)("div",{className:(0,el.default)("ExcTextField",c,{"ExcTextField--fullWidth":n,"ExcTextField--hasIcon":!!o}),onClick:()=>{u.current?.focus()},children:[o,t&&(0,W.jsx)("div",{className:"ExcTextField__label",children:t}),(0,W.jsxs)("div",{className:(0,el.default)("ExcTextField__input",{"ExcTextField__input--readonly":a}),children:[(0,W.jsx)("input",{className:(0,el.default)({"is-redacted":"value"in d&&d.value&&s&&!p}),readOnly:a,value:"value"in d?d.value:void 0,defaultValue:"defaultValue"in d?d.defaultValue:void 0,placeholder:i,ref:u,onChange:t=>e?.(t.target.value),onKeyDown:r}),s&&(0,W.jsx)(s5,{onSelect:()=>g(!p),style:{border:0,userSelect:"none"},children:p?m.mf:m.lf})]})]})}),s6={toggleTheme:[(0,m.kb)("Shift+Alt+D")],saveScene:[(0,m.kb)("CtrlOrCmd+S")],loadScene:[(0,m.kb)("CtrlOrCmd+O")],clearCanvas:[(0,m.kb)("CtrlOrCmd+Delete")],imageExport:[(0,m.kb)("CtrlOrCmd+Shift+E")],commandPalette:[(0,m.kb)("CtrlOrCmd+/"),(0,m.kb)("CtrlOrCmd+Shift+P")],cut:[(0,m.kb)("CtrlOrCmd+X")],copy:[(0,m.kb)("CtrlOrCmd+C")],paste:[(0,m.kb)("CtrlOrCmd+V")],copyStyles:[(0,m.kb)("CtrlOrCmd+Alt+C")],pasteStyles:[(0,m.kb)("CtrlOrCmd+Alt+V")],selectAll:[(0,m.kb)("CtrlOrCmd+A")],deleteSelectedElements:[(0,m.kb)("Delete")],duplicateSelection:[(0,m.kb)("CtrlOrCmd+D"),(0,m.kb)(`Alt+${aO("helpDialog.drag")}`)],sendBackward:[(0,m.kb)("CtrlOrCmd+[")],bringForward:[(0,m.kb)("CtrlOrCmd+]")],sendToBack:[m.l?(0,m.kb)("CtrlOrCmd+Alt+["):(0,m.kb)("CtrlOrCmd+Shift+[")],bringToFront:[m.l?(0,m.kb)("CtrlOrCmd+Alt+]"):(0,m.kb)("CtrlOrCmd+Shift+]")],copyAsPng:[(0,m.kb)("Shift+Alt+C")],group:[(0,m.kb)("CtrlOrCmd+G")],ungroup:[(0,m.kb)("CtrlOrCmd+Shift+G")],gridMode:[(0,m.kb)("CtrlOrCmd+'")],zenMode:[(0,m.kb)("Alt+Z")],objectsSnapMode:[(0,m.kb)("Alt+S")],stats:[(0,m.kb)("Alt+/")],addToLibrary:[],flipHorizontal:[(0,m.kb)("Shift+H")],flipVertical:[(0,m.kb)("Shift+V")],viewMode:[(0,m.kb)("Alt+R")],hyperlink:[(0,m.kb)("CtrlOrCmd+K")],toggleElementLock:[(0,m.kb)("CtrlOrCmd+Shift+L")],resetZoom:[(0,m.kb)("CtrlOrCmd+0")],zoomOut:[(0,m.kb)("CtrlOrCmd+-")],zoomIn:[(0,m.kb)("CtrlOrCmd++")],zoomToFitSelection:[(0,m.kb)("Shift+3")],zoomToFit:[(0,m.kb)("Shift+1")],zoomToFitSelectionInViewport:[(0,m.kb)("Shift+2")],toggleEraserTool:[(0,m.kb)("E")],toggleHandTool:[(0,m.kb)("H")],setFrameAsActiveTool:[(0,m.kb)("F")],saveFileToDisk:[(0,m.kb)("CtrlOrCmd+S")],saveToActiveFile:[(0,m.kb)("CtrlOrCmd+S")],toggleShortcuts:[(0,m.kb)("?")],searchMenu:[(0,m.kb)("CtrlOrCmd+F")],wrapSelectionInFrame:[]},s8=(e,t=0)=>{let n=s6[e];return n&&n.length>0?n[t]||n[0]:""},s7=RegExp("[\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff]","g"),s9=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g,oe={À:"A",Á:"A",Â:"A",Ã:"A",Ä:"A",Å:"A",à:"a",á:"a",â:"a",ã:"a",ä:"a",å:"a",Ç:"C",ç:"c",Ð:"D",ð:"d",È:"E",É:"E",Ê:"E",Ë:"E",è:"e",é:"e",ê:"e",ë:"e",Ì:"I",Í:"I",Î:"I",Ï:"I",ì:"i",í:"i",î:"i",ï:"i",Ñ:"N",ñ:"n",Ò:"O",Ó:"O",Ô:"O",Õ:"O",Ö:"O",Ø:"O",ò:"o",ó:"o",ô:"o",õ:"o",ö:"o",ø:"o",Ù:"U",Ú:"U",Û:"U",Ü:"U",ù:"u",ú:"u",û:"u",ü:"u",Ý:"Y",ý:"y",ÿ:"y",Æ:"E",æ:"e",Þ:"T",þ:"t",ß:"s",Ā:"A",Ă:"A",Ą:"A",ā:"a",ă:"a",ą:"a",Ć:"C",Ĉ:"C",Ċ:"C",Č:"C",ć:"c",ĉ:"c",ċ:"c",č:"c",Ď:"D",Đ:"D",ď:"d",đ:"d",Ē:"E",Ĕ:"E",Ė:"E",Ę:"E",Ě:"E",ē:"e",ĕ:"e",ė:"e",ę:"e",ě:"e",Ĝ:"G",Ğ:"G",Ġ:"G",Ģ:"G",ĝ:"g",ğ:"g",ġ:"g",ģ:"g",Ĥ:"H",Ħ:"H",ĥ:"h",ħ:"h",Ĩ:"I",Ī:"I",Ĭ:"I",Į:"I",İ:"I",ĩ:"i",ī:"i",ĭ:"i",į:"i",ı:"i",Ĵ:"J",ĵ:"j",Ķ:"K",ķ:"k",ĸ:"k",Ĺ:"L",Ļ:"L",Ľ:"L",Ŀ:"L",Ł:"L",ĺ:"l",ļ:"l",ľ:"l",ŀ:"l",ł:"l",Ń:"N",Ņ:"N",Ň:"N",Ŋ:"N",ń:"n",ņ:"n",ň:"n",ŋ:"n",Ō:"O",Ŏ:"O",Ő:"O",ō:"o",ŏ:"o",ő:"o",Ŕ:"R",Ŗ:"R",Ř:"R",ŕ:"r",ŗ:"r",ř:"r",Ś:"S",Ŝ:"S",Ş:"S",Š:"S",ś:"s",ŝ:"s",ş:"s",š:"s",Ţ:"T",Ť:"T",Ŧ:"T",ţ:"t",ť:"t",ŧ:"t",Ũ:"U",Ū:"U",Ŭ:"U",Ů:"U",Ű:"U",Ų:"U",ũ:"u",ū:"u",ŭ:"u",ů:"u",ű:"u",ų:"u",Ŵ:"W",ŵ:"w",Ŷ:"Y",ŷ:"y",Ÿ:"Y",Ź:"Z",Ż:"Z",Ž:"Z",ź:"z",ż:"z",ž:"z",IJ:"I",ij:"i",Œ:"E",œ:"e",ʼn:"n",ſ:"s"},ot=e=>e.replace(s9,e=>oe[e]||e).replace(s7,""),on=E.default.createContext(null),oi=en(),oa=(e,t)=>{let n=t[0]?.type||null;for(let e of t)if(e.type!==n){n=null;break}return(0,m.Wi)(e.activeTool.type)&&"image"!==e.activeTool.type&&"image"!==n&&"frame"!==n&&"magicframe"!==n||t.some(e=>(0,m.Wi)(e.type))},ol=(e,t)=>(0,m.Vi)(e.activeTool.type)||t.some(e=>(0,m.Vi)(e.type)),or=({appState:e,elementsMap:t,renderAction:n,app:i})=>{let a=(0,m.wk)(t,e),l=!1;2===a.length&&((0,m.mc)(a[0])||(0,m.mc)(a[1]))&&(l=!0);let r=!!(e.editingTextElement||e.newElement),s=hZ(),o="rtl"===document.documentElement.getAttribute("dir"),c=(0,m.Vi)(e.activeTool.type)&&!(0,m.sb)(e.currentItemBackgroundColor)||a.some(e=>(0,m.Vi)(e.type)&&!(0,m.sb)(e.backgroundColor)),d=1===a.length||l,h=!e.editingLinearElement&&1===a.length&&(0,m.cc)(a[0])&&!(0,m.ec)(a[0]),u=!e.croppingElementId&&1===a.length&&(0,m.Wb)(a[0]),p=!l&&rD(e,i);return(0,W.jsxs)("div",{className:"panelColumn",children:[(0,W.jsx)("div",{children:oa(e,a)&&n("changeStrokeColor")}),ol(e,a)&&(0,W.jsx)("div",{children:n("changeBackgroundColor")}),c&&n("changeFillStyle"),((0,m.Xi)(e.activeTool.type)||a.some(e=>(0,m.Xi)(e.type)))&&n("changeStrokeWidth"),("freedraw"===e.activeTool.type||a.some(e=>"freedraw"===e.type))&&n("changeStrokeShape"),((0,m.Yi)(e.activeTool.type)||a.some(e=>(0,m.Yi)(e.type)))&&(0,W.jsxs)(W.Fragment,{children:[n("changeStrokeStyle"),n("changeSloppiness")]}),((0,m.Zi)(e.activeTool.type)||a.some(e=>(0,m.Zi)(e.type)))&&(0,W.jsx)(W.Fragment,{children:n("changeRoundness")}),((0,m._i)(e.activeTool.type)||a.some(e=>(0,m._i)(e.type)))&&(0,W.jsx)(W.Fragment,{children:n("changeArrowType")}),("text"===e.activeTool.type||a.some(m._b))&&(0,W.jsxs)(W.Fragment,{children:[n("changeFontFamily"),n("changeFontSize"),("text"===e.activeTool.type||(0,m.Ej)(a,t))&&n("changeTextAlign")]}),(0,m.Dj)(a,t)&&n("changeVerticalAlign"),((0,m.$i)(e.activeTool.type)||a.some(e=>(0,m.$i)(e.type)))&&(0,W.jsx)(W.Fragment,{children:n("changeArrowhead")}),n("changeOpacity"),(0,W.jsxs)("fieldset",{children:[(0,W.jsx)("legend",{children:aO("labels.layers")}),(0,W.jsxs)("div",{className:"buttonList",children:[n("sendToBack"),n("sendBackward"),n("bringForward"),n("bringToFront")]})]}),p&&!l&&(0,W.jsxs)("fieldset",{children:[(0,W.jsx)("legend",{children:aO("labels.align")}),(0,W.jsxs)("div",{className:"buttonList",children:[o?(0,W.jsxs)(W.Fragment,{children:[n("alignRight"),n("alignHorizontallyCentered"),n("alignLeft")]}):(0,W.jsxs)(W.Fragment,{children:[n("alignLeft"),n("alignHorizontallyCentered"),n("alignRight")]}),a.length>2&&n("distributeHorizontally"),(0,W.jsx)("div",{style:{flexBasis:"100%",height:0}}),(0,W.jsxs)("div",{style:{display:"flex",flexWrap:"wrap",gap:".5rem",marginTop:"-0.5rem"},children:[n("alignTop"),n("alignVerticallyCentered"),n("alignBottom"),a.length>2&&n("distributeVertically")]})]})]}),!r&&a.length>0&&(0,W.jsxs)("fieldset",{children:[(0,W.jsx)("legend",{children:aO("labels.actions")}),(0,W.jsxs)("div",{className:"buttonList",children:[!s.editor.isMobile&&n("duplicateSelection"),!s.editor.isMobile&&n("deleteSelectedElements"),n("group"),n("ungroup"),d&&n("hyperlink"),u&&n("cropEditor"),h&&n("toggleLinearEditor")]})]})]})},os=({activeTool:e,appState:t,app:n,UIOptions:i})=>{let[a,l]=(0,E.useState)(!1),r="frame"===e.type,s="laser"===e.type,o="embeddable"===e.type,{TTDDialogTriggerTunnel:c}=E.default.useContext(on);return(0,W.jsxs)(W.Fragment,{children:[m.rg.map(({value:a,icon:l,key:r,numericKey:s,fillable:o},c)=>{if(i.tools?.[a]===!1)return null;let d=aO(`toolBar.${a}`),h=r&&(0,m.Ya)("string"==typeof r?r:r[0]),u=h?`${h} ${aO("helpDialog.or")} ${s}`:`${s}`;return(0,W.jsx)(aH,{className:(0,el.default)("Shape",{fillable:o}),type:"radio",icon:l,checked:e.type===a,name:"editor-current-shape",title:`${(0,m.Ya)(d)} \u2014 ${u}`,keyBindingLabel:s||h,"aria-label":(0,m.Ya)(d),"aria-keyshortcuts":u,"data-testid":`toolbar-${a}`,onPointerDown:({pointerType:e})=>{t.penDetected||"pen"!==e||n.togglePenMode(!0)},onChange:({pointerType:e})=>{t.activeTool.type!==a&&a8("toolbar",a,"ui"),"image"===a?n.setActiveTool({type:a,insertOnCanvasDirectly:"mouse"!==e}):n.setActiveTool({type:a})}},a)}),(0,W.jsx)("div",{className:"App-toolbar__divider"}),(0,W.jsxs)(sW,{open:a,children:[(0,W.jsx)(sW.Trigger,{className:(0,el.default)("App-toolbar__extra-tools-trigger",{"App-toolbar__extra-tools-trigger--selected":r||o||s&&!n.props.isCollaborating}),onToggle:()=>l(!a),title:aO("toolBar.extraTools"),children:m.ef}),(0,W.jsxs)(sW.Content,{onClickOutside:()=>l(!1),onSelect:()=>l(!1),className:"App-toolbar__extra-tools-dropdown",children:[(0,W.jsx)(sW.Item,{onSelect:()=>n.setActiveTool({type:"frame"}),icon:m.ff,shortcut:m.hg.F.toLocaleUpperCase(),"data-testid":"toolbar-frame",selected:r,children:aO("toolBar.frame")}),(0,W.jsx)(sW.Item,{onSelect:()=>n.setActiveTool({type:"embeddable"}),icon:m.vd,"data-testid":"toolbar-embeddable",selected:o,children:aO("toolBar.embeddable")}),(0,W.jsx)(sW.Item,{onSelect:()=>n.setActiveTool({type:"laser"}),icon:m.if,"data-testid":"toolbar-laser",selected:s,shortcut:m.hg.K.toLocaleUpperCase(),children:aO("toolBar.laser")}),(0,W.jsx)("div",{style:{margin:"6px 0",fontSize:14,fontWeight:600},children:"Generate"}),!1!==n.props.aiEnabled&&(0,W.jsx)(c.Out,{}),(0,W.jsx)(sW.Item,{onSelect:()=>n.setOpenDialog({name:"ttd",tab:"mermaid"}),icon:m.gf,"data-testid":"toolbar-embeddable",children:aO("toolBar.mermaidToExcalidraw")}),!1!==n.props.aiEnabled&&n.plugins.diagramToCode&&(0,W.jsx)(W.Fragment,{children:(0,W.jsxs)(sW.Item,{onSelect:()=>n.onMagicframeToolSelect(),icon:m.jf,"data-testid":"toolbar-magicframe",children:[aO("toolBar.magicframe"),(0,W.jsx)(sW.Item.Badge,{children:"AI"})]})})]})]})]})},oo=({renderAction:e,zoom:t})=>(0,W.jsx)(sC,{gap:1,className:m.E.ZOOM_ACTIONS,children:(0,W.jsxs)(sS,{align:"center",children:[e("zoomOut"),e("resetZoom"),e("zoomIn")]})}),oc=({renderAction:e,className:t})=>(0,W.jsxs)("div",{className:`undo-redo-buttons ${t}`,children:[(0,W.jsx)("div",{className:"undo-button-container",children:(0,W.jsx)(l4,{label:aO("buttons.undo"),children:e("undo")})}),(0,W.jsx)("div",{className:"redo-button-container",children:(0,W.jsxs)(l4,{label:aO("buttons.redo"),children:[" ",e("redo")]})})]}),od=({actionManager:e,showExitZenModeBtn:t})=>(0,W.jsx)("button",{type:"button",className:(0,el.default)("disable-zen-mode",{"disable-zen-mode--visible":t}),onClick:()=>e.executeAction(rV),children:aO("buttons.exitZenMode")}),oh=({renderAction:e,className:t})=>(0,W.jsx)("div",{className:`finalize-button ${t}`,children:e("finalize",{size:"small"})}),ou=e=>{let t=(0,E.useRef)({userFn:e});return t.current.userFn=e,t.current.stableFn||(t.current.stableFn=(...e)=>t.current.userFn(...e)),t.current.stableFn},op=S(null),om=()=>{let[e,t]=aS(op),n=h0();return e&&"clearCanvas"===e?(0,W.jsx)(sA,{onConfirm:()=>{n.executeAction(l6),t(null)},onCancel:()=>t(null),title:aO("clearCanvasDialog.title"),children:(0,W.jsxs)("p",{className:"clear-canvas__content",children:[" ",aO("alerts.clearReset")]})}):null},og={};(0,y.c)(og,{toggleTheme:()=>of});var of={...rn,category:"App",label:"Toggle theme",perform:({actionManager:e})=>{e.executeAction(rn,"commandPalette")}},ob=(0,m.$c)({name:"copyElementLink",label:"labels.copyElementLink",icon:m._e,trackEvent:{category:"element"},perform:async(e,t,n,i)=>{let a=(0,m.vk)(e,t);try{if(window.location){let n=(0,m.Zh)(a,t);return n?(await (0,m.oi)(i.props.generateLinkForSelection?i.props.generateLinkForSelection(n.id,n.type):(0,m.Yh)(n.id,n.type)),{appState:{toast:{message:aO("toast.elementLinkCopied"),closable:!0}},captureUpdate:m.Wg.EVENTUALLY}):{appState:t,elements:e,app:i,captureUpdate:m.Wg.EVENTUALLY}}}catch(e){console.error(e)}return{appState:t,elements:e,app:i,captureUpdate:m.Wg.EVENTUALLY}},predicate:(e,t)=>(0,m._h)((0,m.vk)(e,t))}),ov=(0,m.$c)({name:"linkToElement",label:"labels.linkToElement",icon:m.Pf,perform:(e,t,n,i)=>{let a=(0,m.vk)(e,t);return 1===a.length&&(0,m._h)(a)?{appState:{...t,openDialog:{name:"elementLinkSelector",sourceElementId:(0,m.vk)(e,t)[0].id}},captureUpdate:m.Wg.IMMEDIATELY}:{elements:e,appState:t,app:i,captureUpdate:m.Wg.EVENTUALLY}},predicate:(e,t,n,i)=>{let a=(0,m.vk)(e,t);return t.openDialog?.name!=="elementLinkSelector"&&1===a.length&&(0,m._h)(a)},trackEvent:!1}),oy=S(null),oE="Export",ox="Tools",ow="Editor",oS="Elements",oC=({shortcut:e,className:t,children:n})=>{let i=e.replace("++","+$").split("+");return(0,W.jsxs)("div",{className:(0,el.default)("shortcut",t),children:[i.map((e,t)=>(0,W.jsx)("div",{className:"shortcut-wrapper",children:(0,W.jsx)("div",{className:"shortcut-key",children:"$"===e?"+":e})},e)),(0,W.jsx)("div",{className:"shortcut-desc",children:n})]})},ok=e=>!e.altKey&&e[m.hg.CTRL_OR_CMD]&&(e.shiftKey&&e.key.toLowerCase()===m.hg.P||e.key===m.hg.SLASH);function oI({customCommandPaletteItems:e}){let t=hG(),n=E.default.useContext(lm),i=hJ(),a=hK(),l=h0(),[r,s]=aS(oy),[o,c]=(0,E.useState)(null),d=(0,E.useRef)(null),h=lb({uiAppState:n,customCommandPaletteItems:e,appProps:a});(0,E.useEffect)(()=>{let{uiAppState:e,customCommandPaletteItems:n,appProps:a}=h,o=n=>{let i="";return n.label&&(i="function"==typeof n.label?aO(n.label(t.scene.getNonDeletedElements(),e,t)):aO(n.label)),i},d=n=>"function"==typeof n.icon?n.icon(e,t.scene.getNonDeletedElements()):n.icon,u=(e,t,n)=>{let i={label:o(e),icon:d(e),category:t,shortcut:s8(e.name),keywords:e.keywords,predicate:e.predicate,viewMode:e.viewMode,perform:()=>{l.executeAction(e,"commandPalette")}};return n?n(i,e):i};if(e&&t.scene&&l){let h=[l.actions.group,l.actions.ungroup,l.actions.cut,l.actions.copy,l.actions.deleteSelectedElements,l.actions.wrapSelectionInFrame,l.actions.copyStyles,l.actions.pasteStyles,l.actions.bringToFront,l.actions.bringForward,l.actions.sendBackward,l.actions.sendToBack,l.actions.alignTop,l.actions.alignBottom,l.actions.alignLeft,l.actions.alignRight,l.actions.alignVerticallyCentered,l.actions.alignHorizontallyCentered,l.actions.duplicateSelection,l.actions.flipHorizontal,l.actions.flipVertical,l.actions.zoomToFitSelection,l.actions.zoomToFitSelectionInViewport,l.actions.increaseFontSize,l.actions.decreaseFontSize,l.actions.toggleLinearEditor,l.actions.cropEditor,r7,ob,ov].map(e=>u(e,oS,(e,t)=>({...e,predicate:t.predicate?t.predicate:(e,t,n,i)=>(0,m.vk)(e,t).length>0}))),p=[l.actions.toggleHandTool,l.actions.setFrameAsActiveTool].map(e=>u(e,ox)),g=[l.actions.undo,l.actions.redo,l.actions.zoomIn,l.actions.zoomOut,l.actions.resetZoom,l.actions.zoomToFit,l.actions.zenMode,l.actions.viewMode,l.actions.gridMode,l.actions.objectsSnapMode,l.actions.toggleShortcuts,l.actions.selectAll,l.actions.toggleElementLock,l.actions.unlockAllElements,l.actions.stats].map(e=>u(e,ow)),f=[l.actions.saveToActiveFile,l.actions.saveFileToDisk,l.actions.copyAsPng,l.actions.copyAsSvg].map(e=>u(e,oE)),b=[...h,...g,{label:o(l6),icon:d(l6),shortcut:s8(l6.name),category:ow,keywords:["delete","destroy"],viewMode:!1,perform:()=>{aT.set(op,"clearCanvas")}},{label:aO("buttons.exportImage"),category:oE,icon:m.Od,shortcut:s8("imageExport"),keywords:["export","image","png","jpeg","svg","clipboard","picture"],perform:()=>{i({openDialog:{name:"imageExport"}})}},...f,{label:aO("toolBar.library"),category:"App",icon:m.fd,viewMode:!1,perform:()=>{e.openSidebar?i({openSidebar:null}):i({openSidebar:{name:m.ya.name,tab:m.ya.defaultTab}})}},{label:aO("search.title"),category:"App",icon:m.pf,viewMode:!0,perform:()=>{l.executeAction(oM)}},{label:aO("labels.changeStroke"),keywords:["color","outline"],category:oS,icon:m.Nd,viewMode:!1,predicate:(e,t)=>{let n=(0,m.vk)(e,t);return n.length>0&&oa(t,n)},perform:()=>{i(e=>({openMenu:"shape"===e.openMenu?null:"shape",openPopup:"elementStroke"}))}},{label:aO("labels.changeBackground"),keywords:["color","fill"],icon:m.Nd,category:oS,viewMode:!1,predicate:(e,t)=>{let n=(0,m.vk)(e,t);return n.length>0&&ol(t,n)},perform:()=>{i(e=>({openMenu:"shape"===e.openMenu?null:"shape",openPopup:"elementBackground"}))}},{label:aO("labels.canvasBackground"),keywords:["color"],icon:m.Nd,category:ow,viewMode:!1,perform:()=>{i(e=>({openMenu:"canvas"===e.openMenu?null:"canvas",openPopup:"canvasBackground"}))}},...m.rg.reduce((e,n)=>{let{value:i,icon:l,key:r,numericKey:s}=n;if(a.UIOptions.tools?.[i]===!1)return e;let o=r&&(0,m.Ya)("string"==typeof r?r:r[0])||s,c={label:aO(`toolBar.${i}`),category:ox,shortcut:o,icon:l,keywords:["toolbar"],viewMode:!1,perform:({event:e})=>{"image"===i?t.setActiveTool({type:i,insertOnCanvasDirectly:"keydown"===e.type}):t.setActiveTool({type:i})}};return e.push(c),e},[]),...p,{label:aO("toolBar.lock"),category:ox,icon:e.activeTool.locked?m.kd:m.jd,shortcut:m.hg.Q.toLocaleUpperCase(),viewMode:!1,perform:()=>{t.toggleLock()}},{label:`${aO("labels.textToDiagram")}...`,category:ox,icon:m.of,viewMode:!1,predicate:a.aiEnabled,perform:()=>{i(e=>({...e,openDialog:{name:"ttd",tab:"text-to-diagram"}}))}},{label:`${aO("toolBar.mermaidToExcalidraw")}...`,category:ox,icon:m.gf,viewMode:!1,predicate:a.aiEnabled,perform:()=>{i(e=>({...e,openDialog:{name:"ttd",tab:"mermaid"}}))}},...n||[]].map(e=>({...e,icon:e.icon||m.tf,order:e.order??(e=>{switch(e){case"App":return 1;case oE:return 2;case ow:return 3;case ox:return 4;case oS:return 5;case"Links":return 6;default:return 10}})(e.category),haystack:`${ot(e.label.toLocaleLowerCase())} ${e.keywords?.join(" ")||""}`}));c(b),s(b.find(e=>e.label===r?.label)??null)}},[h,t,l,c,r?.label,s,i]);let[u,p]=(0,E.useState)(""),[g,f]=(0,E.useState)(null),[b,v]=(0,E.useState)({}),y=e=>{i({openDialog:null},e),p("")},x=(e,t)=>{n.openDialog?.name==="commandPalette"&&(t.stopPropagation(),t.preventDefault(),document.body.classList.add("excalidraw-animations-disabled"),y(()=>{e.perform({actionManager:l,event:t}),s(e),requestAnimationFrame(()=>{document.body.classList.remove("excalidraw-animations-disabled")})}))},w=ou(e=>(!1!==e.viewMode||!n.viewModeEnabled)&&("function"==typeof e.predicate?e.predicate(t.scene.getNonDeletedElements(),n,a,t):void 0===e.predicate||e.predicate)),S=ou(e=>{let t=(0,m.ab)(e.target)||ok(e)||e.key===m.hg.ESCAPE;if(t&&e.key!==m.hg.ARROW_UP&&e.key!==m.hg.ARROW_DOWN&&e.key!==m.hg.ENTER)return;let n=Object.values(b).flat(),i=r&&!u&&w(r);if(e.key===m.hg.ARROW_UP){let t;e.preventDefault();let a=n.findIndex(e=>e.label===g?.label);if(i){if(0===a)return void f(r);if(g===r){let e=n[n.length-1];e&&f(e);return}}t=-1===a||0===a?n.length-1:(a-1)%n.length;let l=n[t];l&&f(l);return}if(e.key===m.hg.ARROW_DOWN){e.preventDefault();let t=n.findIndex(e=>e.label===g?.label);if(i){if(!g||t===n.length-1)return void f(r);if(g===r){let e=n[0];e&&f(e);return}}let a=(t+1)%n.length,l=n[a];l&&f(l);return}if(e.key===m.hg.ENTER&&g&&setTimeout(()=>{x(g,e)}),!t){if(e.stopPropagation(),/^[a-zA-Z0-9]$/.test(e.key))return void d?.current?.focus();e.preventDefault()}});return(0,E.useEffect)(()=>(window.addEventListener("keydown",S,{capture:!0}),()=>window.removeEventListener("keydown",S,{capture:!0})),[S]),(0,E.useEffect)(()=>{if(!o)return;let e=e=>{let t={};for(let n of e)t[n.category]?t[n.category].push(n):t[n.category]=[n];return t},t=o.filter(w).sort((e,t)=>e.order-t.order),n=!u&&r&&w(r);if(!u){v(e(n?t.filter(e=>e.label!==r?.label):t)),f(n?r:t[0]||null);return}let i=ot(u.toLocaleLowerCase().replace(/[<>_| -]/g,""));v(e(t=id.default.filter(i,t,{extract:e=>e.haystack}).sort((e,t)=>t.score-e.score).map(e=>e.original))),f(t[0]??null)},[u,o,w,r]),(0,W.jsxs)(s3,{onCloseRequest:()=>y(),closeOnClickOutside:!0,title:!1,size:720,autofocus:!0,className:"command-palette-dialog",children:[(0,W.jsx)(s4,{value:u,placeholder:aO("commandPalette.search.placeholder"),onChange:e=>{p(e)},selectOnRender:!0,ref:d}),!t.device.viewport.isMobile&&(0,W.jsxs)("div",{className:"shortcuts-wrapper",children:[(0,W.jsx)(oC,{shortcut:"↑↓",children:aO("commandPalette.shortcuts.select")}),(0,W.jsx)(oC,{shortcut:"↵",children:aO("commandPalette.shortcuts.confirm")}),(0,W.jsx)(oC,{shortcut:(0,m.kb)("Esc"),children:aO("commandPalette.shortcuts.close")})]}),(0,W.jsxs)("div",{className:"commands",children:[r&&!u&&(0,W.jsxs)("div",{className:"command-category",children:[(0,W.jsxs)("div",{className:"command-category-title",children:[aO("commandPalette.recents"),(0,W.jsx)("div",{className:"icon",style:{marginLeft:"6px"},children:m.qf})]}),(0,W.jsx)(oj,{command:r,isSelected:r.label===g?.label,onClick:e=>x(r,e),disabled:!w(r),onMouseMove:()=>f(r),showShortcut:!t.device.viewport.isMobile,appState:n})]}),Object.keys(b).length>0?Object.keys(b).map((e,i)=>(0,W.jsxs)("div",{className:"command-category",children:[(0,W.jsx)("div",{className:"command-category-title",children:e}),b[e].map(e=>(0,W.jsx)(oj,{command:e,isSelected:e.label===g?.label,onClick:t=>x(e,t),onMouseMove:()=>f(e),showShortcut:!t.device.viewport.isMobile,appState:n},e.label))]},e)):o?(0,W.jsxs)("div",{className:"no-match",children:[(0,W.jsx)("div",{className:"icon",children:m.pf})," ",aO("commandPalette.search.noMatch")]}):null]})]})}Object.assign(e=>{let t=E.default.useContext(lm),n=hJ();return(0,E.useEffect)(()=>{let e=e=>{ok(e)&&(e.preventDefault(),e.stopPropagation(),n(e=>{let t=e.openDialog?.name==="commandPalette"?null:{name:"commandPalette"};return t&&a8("command_palette","open","shortcut"),{openDialog:t}}))};return window.addEventListener("keydown",e,{capture:!0}),()=>window.removeEventListener("keydown",e,{capture:!0})},[n]),t.openDialog?.name!=="commandPalette"?null:(0,W.jsx)(oI,{...e})},{defaultItems:og});var oj=({command:e,isSelected:t,disabled:n,onMouseMove:i,onClick:a,showShortcut:l,appState:r})=>{let s=()=>{};return(0,W.jsxs)("div",{className:(0,el.default)("command-item",{"item-selected":t,"item-disabled":n}),ref:e=>{t&&!n&&e?.scrollIntoView?.({block:"nearest"})},onClick:n?s:a,onMouseMove:n?s:i,title:n?aO("commandPalette.itemNotAvailable"):"",children:[(0,W.jsxs)("div",{className:"name",children:[e.icon&&(0,W.jsx)(lT,{icon:"function"==typeof e.icon?e.icon(r):e.icon}),e.label]}),l&&e.shortcut&&(0,W.jsx)(oC,{shortcut:e.shortcut})]})},oT=(0,m.$c)({name:"toggleLinearEditor",category:oS,label:(e,t,n)=>n.scene.getSelectedElements({selectedElementIds:t.selectedElementIds})[0]?.type==="arrow"?"labels.lineEditor.editArrow":"labels.lineEditor.edit",keywords:["line"],trackEvent:{category:"element"},predicate:(e,t,n,i)=>{let a=i.scene.getSelectedElements(t);return!!(!t.editingLinearElement&&1===a.length&&(0,m.cc)(a[0])&&!(0,m.ec)(a[0]))},perform(e,t,n,i){let a=i.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0})[0],l=t.editingLinearElement?.elementId===a.id?null:new m.pj(a);return{appState:{...t,editingLinearElement:l},captureUpdate:m.Wg.IMMEDIATELY}},PanelComponent:({appState:e,updateData:t,app:n})=>{let i=aO("arrow"===n.scene.getSelectedElements({selectedElementIds:e.selectedElementIds})[0].type?"labels.lineEditor.editArrow":"labels.lineEditor.edit");return(0,W.jsx)(aH,{type:"button",icon:m.Hf,title:i,"aria-label":i,onClick:()=>t(null)})}}),oM=(0,m.$c)({name:"searchMenu",icon:m.pf,keywords:["search","find"],label:"search.title",viewMode:!0,trackEvent:{category:"search_menu",action:"toggle",predicate:e=>e.gridModeEnabled},perform(e,t,n,i){if(t.openSidebar?.name===m.ya.name&&t.openSidebar.tab===m.xa){let e=i.excalidrawContainerValue.container?.querySelector(`.${m.E.SEARCH_MENU_INPUT_WRAPPER} input`);return e?.matches(":focus")?{appState:{...t,openSidebar:null},captureUpdate:m.Wg.EVENTUALLY}:(e?.focus(),e?.select(),!1)}return{appState:{...t,openSidebar:{name:m.ya.name,tab:m.xa},openDialog:null},captureUpdate:m.Wg.EVENTUALLY}},checked:e=>e.gridModeEnabled,predicate:(e,t,n)=>void 0===n.gridModeEnabled,keyTest:e=>e[m.hg.CTRL_OR_CMD]&&e.key===m.hg.F}),oL=(0,m.$c)({name:"cropEditor",label:"helpDialog.cropStart",icon:m.Of,viewMode:!0,trackEvent:{category:"menu"},keywords:["image","crop"],perform(e,t,n,i){let a=i.scene.getSelectedElements({selectedElementIds:t.selectedElementIds,includeBoundTextElement:!0})[0];return{appState:{...t,isCropping:!1,croppingElementId:a.id},captureUpdate:m.Wg.IMMEDIATELY}},predicate:(e,t,n,i)=>{let a=i.scene.getSelectedElements(t);return!!(!t.croppingElementId&&1===a.length&&(0,m.Wb)(a[0]))},PanelComponent:({appState:e,updateData:t,app:n})=>{let i=aO("helpDialog.cropStart");return(0,W.jsx)(aH,{type:"button",icon:m.Of,title:i,"aria-label":i,onClick:()=>t(null)})}}),oD=class{constructor(e=!0,t=!0){this.isUndoStackEmpty=e,this.isRedoStackEmpty=t}},oN=class e{constructor(){(0,y.d)(this,"onHistoryChangedEmitter",new m.Vg),(0,y.d)(this,"undoStack",[]),(0,y.d)(this,"redoStack",[])}get isUndoStackEmpty(){return 0===this.undoStack.length}get isRedoStackEmpty(){return 0===this.redoStack.length}clear(){this.undoStack.length=0,this.redoStack.length=0}record(e,t){let n=oA.create(t,e);n.isEmpty()||(this.undoStack.push(n.inverse()),n.elementsChange.isEmpty()||(this.redoStack.length=0),this.onHistoryChangedEmitter.trigger(new oD(this.isUndoStackEmpty,this.isRedoStackEmpty)))}undo(t,n,i){return this.perform(t,n,i,()=>e.pop(this.undoStack),n=>e.push(this.redoStack,n,t))}redo(t,n,i){return this.perform(t,n,i,()=>e.pop(this.redoStack),n=>e.push(this.undoStack,n,t))}perform(e,t,n,i,a){try{let l=i();if(null===l)return;let r=e,s=t,o=!1;for(;l;){try{[r,s,o]=l.applyTo(r,s,n)}finally{a(l)}if(o)break;l=i()}return[r,s]}finally{this.onHistoryChangedEmitter.trigger(new oD(this.isUndoStackEmpty,this.isRedoStackEmpty))}}static pop(e){if(!e.length)return null;let t=e.pop();return void 0!==t?t:null}static push(e,t,n){let i=t.inverse().applyLatestChanges(n);return e.push(i)}},oA=class e{constructor(e,t){this.appStateChange=e,this.elementsChange=t}static create(t,n){return new e(t,n)}inverse(){return new e(this.appStateChange.inverse(),this.elementsChange.inverse())}applyTo(e,t,n){let[i,a]=this.elementsChange.applyTo(e,n.elements),[l,r]=this.appStateChange.applyTo(t,i);return[i,l,a||r]}applyLatestChanges(t){let n=this.elementsChange.applyLatestChanges(t);return e.create(this.appStateChange,n)}isEmpty(){return this.appStateChange.isEmpty()&&this.elementsChange.isEmpty()}},oP=(e,t)=>{let[n,i]=(0,E.useState)(t);return(0,E.useEffect)(()=>{let t=e.on(e=>{i(e)});return()=>{t()}},[e]),n},oR=(e,t,n)=>{if(!t.multiElement&&!t.resizingElement&&!t.editingTextElement&&!t.newElement&&!t.selectedElementsAreBeingDragged&&!t.selectionElement&&!e.flowChartCreator.isCreatingChart){let e=n();if(!e)return{captureUpdate:m.Wg.EVENTUALLY};let[t,i]=e;return{appState:i,elements:Array.from(t.values()),captureUpdate:m.Wg.NEVER}}return{captureUpdate:m.Wg.EVENTUALLY}},o_=(e,t,n,i,a,l)=>{if(e.trackEvent)try{"object"==typeof e.trackEvent&&(!e.trackEvent.predicate||e.trackEvent.predicate(n,i,l))&&a8(e.trackEvent.category,e.trackEvent.action||e.name,`${t} (${a.device.editor.isMobile?"mobile":"desktop"})`)}catch(e){console.error("error while logging action:",e)}},oO=class{constructor(e,t,n,i){(0,y.d)(this,"actions",{}),(0,y.d)(this,"updater"),(0,y.d)(this,"getAppState"),(0,y.d)(this,"getElementsIncludingDeleted"),(0,y.d)(this,"app"),(0,y.d)(this,"renderAction",(e,t)=>{let n=this.app.props.UIOptions.canvasActions;if(this.actions[e]&&"PanelComponent"in this.actions[e]&&(!(e in n)||n[e])){let n=this.actions[e],i=n.PanelComponent;i.displayName="PanelComponent";let a=this.getElementsIncludingDeleted(),l=this.getAppState(),r=e=>{o_(n,"ui",l,a,this.app,e),this.updater(n.perform(this.getElementsIncludingDeleted(),this.getAppState(),e,this.app))};return(0,W.jsx)(i,{elements:this.getElementsIncludingDeleted(),appState:this.getAppState(),updateData:r,appProps:this.app.props,app:this.app,data:t})}return null}),(0,y.d)(this,"isActionEnabled",e=>{let t=this.getElementsIncludingDeleted(),n=this.getAppState();return!e.predicate||e.predicate(t,n,this.app.props,this.app)}),this.updater=t=>{if(!(0,m.Fb)(t))return e(t);t.then(t=>e(t))},this.getAppState=t,this.getElementsIncludingDeleted=n,this.app=i}registerAction(e){this.actions[e.name]=e}registerAll(e){e.forEach(e=>this.registerAction(e))}handleKeyDown(e){let t=this.app.props.UIOptions.canvasActions,n=Object.values(this.actions).sort((e,t)=>(t.keyPriority||0)-(e.keyPriority||0)).filter(n=>(!(n.name in t)||t[n.name])&&n.keyTest&&n.keyTest(e,this.getAppState(),this.getElementsIncludingDeleted(),this.app));if(1!==n.length)return n.length>1&&console.warn("Canceling as multiple actions match this shortcut",n),!1;let i=n[0];if(this.getAppState().viewModeEnabled&&!0!==i.viewMode)return!1;let a=this.getElementsIncludingDeleted(),l=this.getAppState();return o_(i,"keyboard",l,a,this.app,null),e.preventDefault(),e.stopPropagation(),this.updater(n[0].perform(a,l,null,this.app)),!0}executeAction(e,t="api",n=null){let i=this.getElementsIncludingDeleted(),a=this.getAppState();o_(e,t,a,i,this.app,n),this.updater(e.perform(i,a,n,this.app))}},oF=e=>{let t=Array.from(e.values());return{x:oU(t,e=>e.x)/t.length,y:oU(t,e=>e.y)/t.length}},oz=([e,t])=>Math.hypot(e.x-t.x,e.y-t.y),oU=(e,t)=>e.reduce((e,n)=>e+t(n),0),oB=({children:e,left:t,top:n,onCloseRequest:i,fitInViewport:a=!1,offsetLeft:l=0,offsetTop:r=0,viewportWidth:s=window.innerWidth,viewportHeight:o=window.innerHeight})=>{let c=(0,E.useRef)(null);(0,E.useEffect)(()=>{let e=c.current;if(!e)return;e.contains(document.activeElement)||e.focus();let t=t=>{if(t.key===m.hg.TAB){let n=(0,m.Gb)(e),{activeElement:i}=document,a=n.findIndex(e=>e===i);i===e?(t.shiftKey?n[n.length-1]?.focus():n[0].focus(),t.preventDefault(),t.stopImmediatePropagation()):0===a&&t.shiftKey?(n[n.length-1]?.focus(),t.preventDefault(),t.stopImmediatePropagation()):a!==n.length-1||t.shiftKey||(n[0]?.focus(),t.preventDefault(),t.stopImmediatePropagation())}};return e.addEventListener("keydown",t),()=>e.removeEventListener("keydown",t)},[]);let d=(0,E.useRef)(null);return(0,E.useLayoutEffect)(()=>{if(a&&c.current&&null!=n&&null!=t){let e=c.current,{width:i,height:a}=e.getBoundingClientRect();(d.current?.top!==n||d.current?.left!==t)&&(d.current={top:n,left:t},i>=s?(e.style.width=`${s}px`,e.style.left="0px",e.style.overflowX="scroll"):t+i-l>s?e.style.left=`${s-i-10}px`:e.style.left=`${t}px`,a>=o?(e.style.height=`${o-20}px`,e.style.top="10px",e.style.overflowY="scroll"):n+a-r>o?e.style.top=`${o-a}px`:e.style.top=`${n}px`)}},[n,t,a,s,o,l,r]),(0,E.useEffect)(()=>{if(i){let e=e=>{c.current?.contains(e.target)||(0,er.unstable_batchedUpdates)(()=>i(e))};return document.addEventListener("pointerdown",e,!1),()=>document.removeEventListener("pointerdown",e,!1)}},[i]),(0,W.jsx)("div",{className:"popover",ref:c,tabIndex:-1,children:e})},oW="separator",oH=E.default.memo(({actionManager:e,items:t,top:n,left:i,onClose:a})=>{let l=hq(),r=hQ(),s=t.reduce((t,n)=>(n&&(n===oW||!n.predicate||n.predicate(r,l,e.app.props,e.app))&&t.push(n),t),[]);return(0,W.jsx)(oB,{onCloseRequest:()=>{a()},top:n,left:i,fitInViewport:!0,offsetLeft:l.offsetLeft,offsetTop:l.offsetTop,viewportWidth:l.width,viewportHeight:l.height,children:(0,W.jsx)("ul",{className:"context-menu",onContextMenu:e=>e.preventDefault(),children:s.map((t,n)=>{if(t===oW)return s[n-1]&&s[n-1]!==oW?(0,W.jsx)("hr",{className:"context-menu-item-separator"},n):null;let i=t.name,o="";return t.label&&(o="function"==typeof t.label?aO(t.label(r,l,e.app)):aO(t.label)),(0,W.jsx)("li",{"data-testid":i,onClick:()=>{a(()=>{e.executeAction(t,"contextMenu")})},children:(0,W.jsxs)("button",{type:"button",className:(0,el.default)("context-menu-item",{dangerous:"deleteSelectedElements"===i,checkmark:t.checked?.(l)}),children:[(0,W.jsx)("div",{className:"context-menu-item__label",children:o}),(0,W.jsx)("kbd",{className:"context-menu-item__shortcut",children:i?s8(i):""})]})},n)})})})}),o$=({children:e,onClose:t})=>{let[n,i]=(0,E.useState)(!!e),{container:a}=hX(),l=E.default.useCallback(()=>{i(!1),t&&t(),a?.focus()},[t,a]);return(0,W.jsx)(W.Fragment,{children:n&&(0,W.jsx)(s3,{size:"small",onCloseRequest:l,title:aO("errorDialog.title"),children:(0,W.jsx)("div",{style:{whiteSpace:"pre-wrap"},children:e})})})},oY=function({onChange:e,value:t,choices:n,name:i}){return(0,W.jsx)("div",{className:"RadioGroup",children:n.map(n=>(0,W.jsxs)("div",{className:(0,el.default)("RadioGroup__choice",{active:n.value===t}),title:n.ariaLabel,children:[(0,W.jsx)("input",{name:i,type:"radio",checked:n.value===t,onChange:()=>e(n.value),"aria-label":n.ariaLabel}),n.label]},String(n.value)))})},oV=({title:e,name:t,checked:n,onChange:i,disabled:a=!1})=>(0,W.jsx)("div",{className:(0,el.default)("Switch",{toggled:n,disabled:a}),children:(0,W.jsx)("input",{name:t,id:t,title:e,type:"checkbox",checked:n,disabled:a,onChange:()=>i(!n),onKeyDown:e=>{" "===e.key&&i(!n)}})}),oG=(0,E.forwardRef)(({children:e,icon:t,onClick:n,label:i,variant:a="filled",color:l="primary",size:r="medium",fullWidth:s,className:o,status:c},d)=>{let[h,u]=(0,E.useState)(!1),p=async e=>{let t=n?.(e);if((0,m.Fb)(t)){let e=window.setTimeout(()=>{u(!0)},50);try{await t}catch(e){if(e instanceof m.tc)console.warn(e);else throw e}finally{clearTimeout(e),u(!1)}}},g=h?"loading":c;return l="success"===g?"success":l,(0,W.jsx)("button",{className:(0,el.default)("ExcButton",`ExcButton--color-${l}`,`ExcButton--variant-${a}`,`ExcButton--size-${r}`,`ExcButton--status-${g}`,{"ExcButton--fullWidth":s},o),onClick:p,type:"button","aria-label":i,ref:d,disabled:"loading"===g||"success"===g,children:(0,W.jsxs)("div",{className:"ExcButton__contents",children:["loading"===g?(0,W.jsx)(aU,{className:"ExcButton__statusIcon"}):"success"===g&&(0,W.jsx)("div",{className:"ExcButton__statusIcon",children:m.bf}),t&&(0,W.jsx)("div",{className:"ExcButton__icon","aria-hidden":!0,children:t}),"icon"!==a&&(e??i)]})})}),oK="filter"in document.createElement("canvas").getContext("2d"),oZ=()=>(0,W.jsxs)("div",{children:[(0,W.jsx)("h3",{children:aO("canvasError.cannotShowPreview")}),(0,W.jsx)("p",{children:(0,W.jsx)("span",{children:aO("canvasError.canvasTooBig")})}),(0,W.jsxs)("em",{children:["(",aO("canvasError.canvasTooBigTip"),")"]})]}),oX=({appStateSnapshot:e,elementsSnapshot:t,files:n,actionManager:i,onExportImage:a,name:l})=>{let r=(0,m.tk)(t,e),[s,o]=(0,E.useState)(l),[c,d]=(0,E.useState)(r),[h,u]=(0,E.useState)(e.exportBackground),[p,f]=(0,E.useState)(e.exportWithDarkMode),[b,v]=(0,E.useState)(e.exportEmbedScene),[y,x]=(0,E.useState)(e.exportScale),w=(0,E.useRef)(null),[S,C]=(0,E.useState)(null),{onCopy:k,copyStatus:I,resetCopyStatus:j}=(()=>{let[e,t]=(0,E.useState)(null),n=(0,E.useRef)(0);return{copyStatus:e,resetCopyStatus:(0,E.useCallback)(()=>{t(null)},[]),onCopy:()=>{clearTimeout(n.current),t("success"),n.current=window.setTimeout(()=>{t(null)},2e3)}}})();(0,E.useEffect)(()=>{j()},[s,h,p,y,b,j]);let{exportedElements:T,exportingFrame:M}=ro(t,e,c);return(0,E.useEffect)(()=>{let t=w.current;if(!t)return;let i=t.offsetWidth,a=t.offsetHeight;i&&(0,m.pi)({elements:T,appState:{...e,name:s,exportBackground:h,exportWithDarkMode:p,exportScale:y,exportEmbedScene:b},files:n,exportPadding:m.ma,maxWidthOrHeight:Math.max(i,a),exportingFrame:M}).then(e=>(C(null),(0,m.yh)(e).then(()=>{t.replaceChildren(e)}).catch(e=>{throw"CANVAS_POSSIBLY_TOO_BIG"===e.name?Error(aO("canvasError.canvasTooBig")):e}))).catch(e=>{console.error(e),C(e)})},[e,n,T,M,s,h,p,y,b]),(0,W.jsxs)("div",{className:"ImageExportModal",children:[(0,W.jsx)("h3",{children:aO("imageExportDialog.header")}),(0,W.jsxs)("div",{className:"ImageExportModal__preview",children:[(0,W.jsx)("div",{className:"ImageExportModal__preview__canvas",ref:w,children:S&&(0,W.jsx)(oZ,{})}),(0,W.jsx)("div",{className:"ImageExportModal__preview__filename",children:!g.supported&&(0,W.jsx)("input",{type:"text",className:"TextInput",value:s,style:{width:"30ch"},onChange:e=>{o(e.target.value),i.executeAction(ru,"ui",e.target.value)}})})]}),(0,W.jsxs)("div",{className:"ImageExportModal__settings",children:[(0,W.jsx)("h3",{children:aO("imageExportDialog.header")}),r&&(0,W.jsx)(oQ,{label:aO("imageExportDialog.label.onlySelected"),name:"exportOnlySelected",children:(0,W.jsx)(oV,{name:"exportOnlySelected",checked:c,onChange:e=>{d(e)}})}),(0,W.jsx)(oQ,{label:aO("imageExportDialog.label.withBackground"),name:"exportBackgroundSwitch",children:(0,W.jsx)(oV,{name:"exportBackgroundSwitch",checked:h,onChange:e=>{u(e),i.executeAction(rm,"ui",e)}})}),oK&&(0,W.jsx)(oQ,{label:aO("imageExportDialog.label.darkMode"),name:"exportDarkModeSwitch",children:(0,W.jsx)(oV,{name:"exportDarkModeSwitch",checked:p,onChange:e=>{f(e),i.executeAction(ry,"ui",e)}})}),(0,W.jsx)(oQ,{label:aO("imageExportDialog.label.embedScene"),tooltip:aO("imageExportDialog.tooltip.embedScene"),name:"exportEmbedSwitch",children:(0,W.jsx)(oV,{name:"exportEmbedSwitch",checked:b,onChange:e=>{v(e),i.executeAction(rg,"ui",e)}})}),(0,W.jsx)(oQ,{label:aO("imageExportDialog.label.scale"),name:"exportScale",children:(0,W.jsx)(oY,{name:"exportScale",value:y,onChange:e=>{x(e),i.executeAction(rp,"ui",e)},choices:m.la.map(e=>({value:e,label:`${e}\xd7`}))})}),(0,W.jsxs)("div",{className:"ImageExportModal__settings__buttons",children:[(0,W.jsx)(oG,{className:"ImageExportModal__settings__buttons__button",label:aO("imageExportDialog.title.exportToPng"),onClick:()=>a(m.U.png,T,{exportingFrame:M}),icon:m.Ze,children:aO("imageExportDialog.button.exportToPng")}),(0,W.jsx)(oG,{className:"ImageExportModal__settings__buttons__button",label:aO("imageExportDialog.title.exportToSvg"),onClick:()=>a(m.U.svg,T,{exportingFrame:M}),icon:m.Ze,children:aO("imageExportDialog.button.exportToSvg")}),(m.ii||m.n)&&(0,W.jsx)(oG,{className:"ImageExportModal__settings__buttons__button",label:aO("imageExportDialog.title.copyPngToClipboard"),status:I,onClick:async()=>{await a(m.U.clipboard,T,{exportingFrame:M}),k()},icon:m._e,children:aO("imageExportDialog.button.copyPngToClipboard")})]})]})]})},oQ=({label:e,children:t,tooltip:n,name:i})=>(0,W.jsxs)("div",{className:"ImageExportModal__settings__setting",title:e,children:[(0,W.jsxs)("label",{htmlFor:i,className:"ImageExportModal__settings__setting__label",children:[e,n&&(0,W.jsx)(l4,{label:n,long:!0,children:m.af})]}),(0,W.jsx)("div",{className:"ImageExportModal__settings__setting__content",children:t})]}),oq=({elements:e,appState:t,files:n,actionManager:i,onExportImage:a,onCloseRequest:l,name:r})=>{let[{appStateSnapshot:s,elementsSnapshot:o}]=(0,E.useState)(()=>({appStateSnapshot:(0,m.Nb)(t),elementsSnapshot:(0,m.Nb)(e)}));return(0,W.jsx)(s3,{onCloseRequest:l,size:"wide",title:!1,children:(0,W.jsx)(oX,{elementsSnapshot:o,appStateSnapshot:s,files:n,actionManager:i,onExportImage:a,name:r})})},oJ=({children:e,side:t,className:n})=>(0,W.jsx)("div",{className:(0,el.default)("FixedSideContainer",`FixedSideContainer_side_${t}`,n),children:e}),o0=e=>{switch(e){case m.hg.ARROW_UP:return"up";case m.hg.ARROW_DOWN:return"down";case m.hg.ARROW_RIGHT:return"right";case m.hg.ARROW_LEFT:return"left";default:return"right"}},o1=(e,t,n,i)=>{let a=[...n.values()].reduce((i,a)=>{let l;if((0,m.ec)(a)&&(l=a["predecessors"===e?"startBinding":"endBinding"])&&a["predecessors"===e?"endBinding":"startBinding"]?.elementId===t.id){let r=n.get(l.elementId);if(!r)return i;(0,m.Kb)((0,m.ic)(r),"not an ExcalidrawBindableElement");let s="predecessors"===e?a.points[a.points.length-1]:[0,0],o=(0,m.Dg)(t,(0,m.vg)(t),[s[0]+a.x,s[1]+a.y]);i.push({relative:r,heading:o})}return i},[]);switch(i){case"up":return a.filter(e=>(0,m.Cg)(e.heading,m.Bg)).map(e=>e.relative);case"down":return a.filter(e=>(0,m.Cg)(e.heading,m.zg)).map(e=>e.relative);case"right":return a.filter(e=>(0,m.Cg)(e.heading,m.yg)).map(e=>e.relative);case"left":return a.filter(e=>(0,m.Cg)(e.heading,m.Ag)).map(e=>e.relative)}},o2=(e,t,n,i,a)=>{let l,r,s,o;switch(i){case"up":l=e.x+e.width/2,r=e.y-6;break;case"down":l=e.x+e.width/2,r=e.y+e.height+6;break;case"right":l=e.x+e.width+6,r=e.y+e.height/2;break;case"left":l=e.x-6,r=e.y+e.height/2}switch(i){case"up":s=t.x+t.width/2-l,o=t.y+t.height-r+6;break;case"down":s=t.x+t.width/2-l,o=t.y-r-6;break;case"right":s=t.x-l-6,o=t.y-r+t.height/2;break;case"left":s=t.x+t.width-l+6,o=t.y-r+t.height/2}let c=(0,m.$f)({type:"arrow",x:l,y:r,startArrowhead:null,endArrowhead:a.currentItemEndArrowhead,strokeColor:e.strokeColor,strokeStyle:e.strokeStyle,strokeWidth:e.strokeWidth,opacity:e.opacity,roughness:e.roughness,points:[(0,m.Ua)(0,0),(0,m.Ua)(s,o)],elbowed:!0});(0,m.Mg)(c,e,"start",n),(0,m.Mg)(c,t,"end",n);let d=new Map;d.set(e.id,e),d.set(t.id,t),d.set(c.id,c),m.pj.movePoints(c,[{index:1,point:c.points[1]}]);let h=(0,m.ih)(c,(0,m.Sb)(new Map([...n.entries(),[e.id,e],[t.id,t],[c.id,c]])),{points:c.points});return{...c,...h}},o3=class{constructor(){(0,y.d)(this,"isExploring",!1),(0,y.d)(this,"sameLevelNodes",[]),(0,y.d)(this,"sameLevelIndex",0),(0,y.d)(this,"direction",null),(0,y.d)(this,"visitedNodes",new Set)}clear(){this.isExploring=!1,this.sameLevelNodes=[],this.sameLevelIndex=0,this.direction=null,this.visitedNodes.clear()}exploreByDirection(e,t,n){if(!(0,m.ic)(e))return null;if(n!==this.direction&&this.clear(),this.visitedNodes.has(e.id)||this.visitedNodes.add(e.id),this.isExploring&&n===this.direction&&this.sameLevelNodes.length>1)return this.sameLevelIndex=(this.sameLevelIndex+1)%this.sameLevelNodes.length,this.sameLevelNodes[this.sameLevelIndex].id;let i=[...o1("successors",e,t,n),...o1("predecessors",e,t,n)];if(i.length>0)return this.sameLevelIndex=0,this.isExploring=!0,this.sameLevelNodes=i,this.direction=n,this.visitedNodes.add(i[0].id),i[0].id;if(n===this.direction||!this.isExploring){for(let i of(this.isExploring||this.visitedNodes.add(e.id),["up","right","down","left"].filter(e=>e!==n).map(n=>[...o1("successors",e,t,n),...o1("predecessors",e,t,n)]).flat().filter(e=>!this.visitedNodes.has(e.id))))if(!this.visitedNodes.has(i.id))return this.visitedNodes.add(i.id),this.isExploring=!0,this.direction=n,i.id}return null}},o5=class{constructor(){(0,y.d)(this,"isCreatingChart",!1),(0,y.d)(this,"numberOfNodes",0),(0,y.d)(this,"direction","right"),(0,y.d)(this,"pendingNodes",null)}createNodes(e,t,n,i){if(i!==this.direction){var a,l,r,s;let o,c,d,h,u,{nextNode:p,bindingArrow:g}=(a=e,l=t,r=n,o=o1("successors",a,l,s=i),c=o1("predecessors",a,l,s),d=((e,t,n)=>{let i=100+e.width;if("up"===n||"down"===n){let i=100+e.height,a=e.x,l=e.x+e.width;if(t.every(e=>e.x+e.width<a||e.x>l))return{x:0,y:i*("up"===n?-1:1)}}else if("right"===n||"left"===n){let i=e.y,a=e.y+e.height;if(t.every(e=>e.y+e.height<i||e.y>a))return{x:(100+e.width)*("left"===n?-1:1),y:0}}if("up"===n||"down"===n){let a=(t.length,100+e.height),l=0===t.length?0:(t.length+1)%2==0?(t.length+1)/2*i:-(t.length/2*i*1);return"up"===n?{x:l,y:-1*a}:{x:l,y:a}}let a=100+e.height,l=(t.length,100+e.width),r=0===t.length?0:(t.length+1)%2==0?(t.length+1)/2*a:-(t.length/2*a*1);return"left"===n?{x:-1*l,y:r}:{x:l,y:r}})(a,[...o,...c],s),h=(0,m.Sf)({type:a.type,x:a.x+d.x,y:a.y+d.y,width:a.width,height:a.height,roundness:a.roundness,roughness:a.roughness,backgroundColor:a.backgroundColor,strokeColor:a.strokeColor,strokeWidth:a.strokeWidth,opacity:a.opacity,fillStyle:a.fillStyle,strokeStyle:a.strokeStyle}),(0,m.Kb)((0,m.lc)(h),"not an ExcalidrawFlowchartNodeElement"),u=o2(a,h,l,s,r),{nextNode:h,bindingArrow:u});this.numberOfNodes=1,this.isCreatingChart=!0,this.direction=i,this.pendingNodes=[p,g]}else{this.numberOfNodes+=1;let a=((e,t,n,i,a)=>{let l=[];for(let r=0;r<a;r++){let s,o;if("left"===i||"right"===i){let t=100*(a-1)+a*e.height,n=e.y+e.height/2-t/2,l=100+e.width;"left"===i&&(l*=-1),s=e.x+l,o=n+(100+e.height)*r}else{let t=100*(a-1)+a*e.width,n=e.x+e.width/2-t/2,l=100+e.height;"up"===i&&(l*=-1),o=e.y+l,s=n+(100+e.width)*r}let c=(0,m.Sf)({type:e.type,x:s,y:o,width:e.width,height:e.height,roundness:e.roundness,roughness:e.roughness,backgroundColor:e.backgroundColor,strokeColor:e.strokeColor,strokeWidth:e.strokeWidth,opacity:e.opacity,fillStyle:e.fillStyle,strokeStyle:e.strokeStyle});(0,m.Kb)((0,m.lc)(c),"not an ExcalidrawFlowchartNodeElement");let d=o2(e,c,t,i,n);l.push(c),l.push(d)}return l})(e,t,n,i,this.numberOfNodes);this.isCreatingChart=!0,this.direction=i,this.pendingNodes=a}if(e.frameId){let n=t.get(e.frameId);(0,m.Kb)(n&&(0,m.$b)(n),"not an ExcalidrawFrameElement"),n&&this.pendingNodes.every(e=>(0,m.xi)([e],n,t)||(0,m.yi)(e,n,t))&&(this.pendingNodes=this.pendingNodes.map(t=>(0,m.Pj)(t,{frameId:e.frameId},!1)))}}clear(){this.isCreatingChart=!1,this.pendingNodes=null,this.direction=null,this.numberOfNodes=0}},o4=({appState:e,isMobile:t,device:n,app:i})=>{let a=(({appState:e,isMobile:t,device:n,app:i})=>{let{activeTool:a,isResizing:l,isRotating:r,lastPointerDownWith:s}=e,o=null!==e.multiElement;if(e.openSidebar?.name===m.ya.name&&e.openSidebar.tab===m.xa&&e.searchMatches?.length)return aO("hints.dismissSearch");if(e.openSidebar&&!n.editor.canFitSidebar)return null;if((0,m.Gc)(e))return aO("hints.eraserRevert");if("arrow"===a.type||"line"===a.type)return o?aO("hints.linearElementMulti"):"arrow"===a.type?aO("hints.arrowTool",{arrowShortcut:(0,m.kb)("A")}):aO("hints.linearElement");if("freedraw"===a.type)return aO("hints.freeDraw");if("text"===a.type)return aO("hints.text");if("embeddable"===a.type)return aO("hints.embeddable");if("image"===e.activeTool.type&&e.pendingImageElementId)return aO("hints.placeImage");let c=i.scene.getSelectedElements(e);if(l&&"mouse"===s&&1===c.length){let e=c[0];return(0,m.cc)(e)&&2===e.points.length?aO("hints.lockAngle"):(0,m.Wb)(e)?aO("hints.resizeImage"):aO("hints.resize")}if(r&&"mouse"===s)return aO("hints.rotate");if(1===c.length&&(0,m._b)(c[0]))return aO("hints.text_selected");if(e.editingTextElement)return aO("hints.text_editing");if(e.croppingElementId)return aO("hints.leaveCropEditor");if(1===c.length&&(0,m.Wb)(c[0]))return aO("hints.enterCropEditor");if("selection"===a.type){if(e.selectionElement&&!c.length&&!e.editingTextElement&&!e.editingLinearElement)return aO("hints.deepBoxSelect");if((0,m.fj)(i)&&e.selectedElementsAreBeingDragged)return aO("hints.disableSnapping");if(!c.length&&!t)return aO("hints.canvasPanning");if(1===c.length){if((0,m.cc)(c[0]))return e.editingLinearElement?e.editingLinearElement.selectedPointsIndices?aO("hints.lineEditor_pointSelected"):aO("hints.lineEditor_nothingSelected"):aO("hints.lineEditor_info");if(!e.newElement&&!e.selectedElementsAreBeingDragged&&(0,m.jc)(c[0]))return(0,m.lc)(c[0])?(((e,t)=>{for(let[,n]of t)if("arrow"===n.type&&(n.startBinding?.elementId===e.id||n.endBinding?.elementId===e.id))return!0})(c[0],i.scene.getNonDeletedElementsMap()),[aO("hints.bindTextToElement"),aO("hints.createFlowchart")]):aO("hints.bindTextToElement")}}return null})({appState:e,isMobile:t,device:n,app:i});if(!a)return null;let l=Array.isArray(a)?a.map(e=>(0,m.kb)(e).replace(/\. ?$/,"")).join(". "):(0,m.kb)(a);return(0,W.jsx)("div",{className:"HintViewer",children:(0,W.jsx)("span",{children:l})})},o6={CHECKED:m.kd,UNCHECKED:m.jd},o8=e=>(0,W.jsxs)("label",{className:(0,el.default)("ToolIcon ToolIcon__lock","ToolIcon_size_medium",{"is-mobile":e.isMobile}),title:`${e.title} \u2014 Q`,children:[(0,W.jsx)("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title,"data-testid":"toolbar-lock"}),(0,W.jsx)("div",{className:"ToolIcon__icon",children:e.checked?o6.CHECKED:o6.UNCHECKED})]}),o7=({heading:e,children:t,...n})=>{let{id:i}=hX(),a=(0,W.jsx)("h2",{className:"visually-hidden",id:`${i}-${e}-title`,children:aO(`headings.${e}`)});return(0,W.jsx)("section",{...n,"aria-labelledby":`${i}-${e}-title`,children:"function"==typeof t?t(a):(0,W.jsxs)(W.Fragment,{children:[a,t]})})},o9=(e,t,n)=>{let[i,a]=[e.horizontal,e.vertical].map(e=>null!=e&&e.x<=t&&t<=e.x+e.width&&e.y<=n&&n<=e.y+e.height);return{isOverEither:i||a,isOverHorizontal:i,isOverVertical:a}},ce=e=>e.penDetected?(0,W.jsxs)("label",{className:(0,el.default)("ToolIcon ToolIcon__penMode","ToolIcon_size_medium",{"is-mobile":e.isMobile}),title:`${e.title}`,children:[(0,W.jsx)("input",{className:"ToolIcon_type_checkbox",type:"checkbox",name:e.name,onChange:e.onChange,checked:e.checked,"aria-label":e.title}),(0,W.jsx)("div",{className:"ToolIcon__icon",children:m.od})]}):null,ct=e=>(0,W.jsx)(aH,{className:(0,el.default)("Shape",{fillable:!1}),type:"radio",icon:m.Ye,name:"editor-current-shape",checked:e.checked,title:`${e.title} \u2014 H`,keyBindingLabel:e.isMobile?void 0:m.hg.H.toLocaleUpperCase(),"aria-label":`${e.title} \u2014 H`,"aria-keyshortcuts":m.hg.H,"data-testid":"toolbar-hand",onChange:()=>e.onChange?.()}),cn=({appState:e,elements:t,actionManager:n,setAppState:i,onLockToggle:a,onHandToolToggle:l,onPenModeToggle:r,renderTopRightUI:s,renderCustomStats:o,renderSidebars:c,device:d,renderWelcomeScreen:h,UIOptions:u,app:p})=>{let{WelcomeScreenCenterTunnel:g,MainMenuTunnel:f,DefaultSidebarTriggerTunnel:b}=E.default.useContext(on);return(0,W.jsxs)(W.Fragment,{children:[c(),!e.viewModeEnabled&&e.openDialog?.name!=="elementLinkSelector"&&(0,W.jsxs)(oJ,{side:"top",className:"App-top-bar",children:[h&&(0,W.jsx)(g.Out,{}),(0,W.jsx)(o7,{heading:"shapes",children:t=>(0,W.jsx)(sC,{gap:4,align:"center",children:(0,W.jsxs)(sS,{gap:1,className:"App-toolbar-container",children:[(0,W.jsxs)(lx,{padding:1,className:"App-toolbar App-toolbar--mobile",children:[t,(0,W.jsx)(sS,{gap:1,children:(0,W.jsx)(os,{appState:e,activeTool:e.activeTool,UIOptions:u,app:p})})]}),s&&s(!0,e),(0,W.jsxs)("div",{className:"mobile-misc-tools-container",children:[!e.viewModeEnabled&&e.openDialog?.name!=="elementLinkSelector"&&(0,W.jsx)(b.Out,{}),(0,W.jsx)(ce,{checked:e.penMode,onChange:()=>r(null),title:aO("toolBar.penMode"),isMobile:!0,penDetected:e.penDetected}),(0,W.jsx)(o8,{checked:e.activeTool.locked,onChange:a,title:aO("toolBar.lock"),isMobile:!0}),(0,W.jsx)(ct,{checked:(0,m.Hc)(e),onChange:()=>l(),title:aO("toolBar.hand"),isMobile:!0})]})]})})}),(0,W.jsx)(o4,{appState:e,isMobile:!0,device:d,app:p})]}),(0,W.jsx)("div",{className:"App-bottom-bar",style:{marginBottom:14,marginLeft:14,marginRight:14},children:(0,W.jsxs)(lx,{padding:0,children:["shape"===e.openMenu&&!e.viewModeEnabled&&e.openDialog?.name!=="elementLinkSelector"&&(0,m.lk)(e,t)?(0,W.jsx)(o7,{className:"App-mobile-menu",heading:"selectedShapeActions",children:(0,W.jsx)(or,{appState:e,elementsMap:p.scene.getNonDeletedElementsMap(),renderAction:n.renderAction,app:p})}):null,(0,W.jsxs)("footer",{className:"App-toolbar",children:[e.viewModeEnabled||e.openDialog?.name==="elementLinkSelector"?(0,W.jsx)("div",{className:"App-toolbar-content",children:(0,W.jsx)(f.Out,{})}):(0,W.jsxs)("div",{className:"App-toolbar-content",children:[(0,W.jsx)(f.Out,{}),n.renderAction("toggleEditMenu"),n.renderAction(e.multiElement?"finalize":"duplicateSelection"),n.renderAction("deleteSelectedElements"),(0,W.jsxs)("div",{children:[n.renderAction("undo"),n.renderAction("redo")]})]}),e.scrolledOutside&&!e.openMenu&&!e.openSidebar&&(0,W.jsx)("button",{type:"button",className:"scroll-back-to-content",onClick:()=>{i(e=>({...(0,m.zk)(t,e)}))},children:aO("buttons.scrollBackToContent")})]})]})})]})},ci=e=>{let t=(0,E.useRef)(null),[n,i]=(0,E.useState)(null);return(0,E.useLayoutEffect)(()=>{if(!e.spreadsheet)return;let n=(0,m.gi)(e.chartType,e.spreadsheet,0,0);i(n);let a,l=t.current;return(async()=>(a=await (0,m.ei)(n,{exportBackground:!1,viewBackgroundColor:io.default.white},null,{skipInliningFonts:!0}),a.querySelector(".style-fonts")?.remove(),l.replaceChildren(),l.appendChild(a),e.selected&&l.parentNode.focus()))(),()=>{l.replaceChildren()}},[e.spreadsheet,e.chartType,e.selected]),(0,W.jsx)("button",{type:"button",className:"ChartPreview",onClick:()=>{n&&e.onClick(e.chartType,n)},children:(0,W.jsx)("div",{ref:t})})},ca=({setAppState:e,appState:t,onClose:n})=>{let{onInsertElements:i}=hG(),a=E.default.useCallback(()=>{n&&n()},[n]),l=(t,n)=>{i(n),a8("paste","chart",t),e({currentChartType:t,pasteDialog:{shown:!1,data:null}})};return(0,W.jsx)(s3,{size:"small",onCloseRequest:a,title:aO("labels.pasteCharts"),className:"PasteChartDialog",autofocus:!1,children:(0,W.jsxs)("div",{className:"container",children:[(0,W.jsx)(ci,{chartType:"bar",spreadsheet:t.pasteDialog.data,selected:"bar"===t.currentChartType,onClick:l}),(0,W.jsx)(ci,{chartType:"line",spreadsheet:t.pasteDialog.data,selected:"line"===t.currentChartType,onClick:l})]})})},cl=()=>(0,W.jsxs)("div",{className:"HelpDialog__header",children:[(0,W.jsxs)("a",{className:"HelpDialog__btn",href:"https://docs.excalidraw.com",target:"_blank",rel:"noopener noreferrer",children:[(0,W.jsx)("div",{className:"HelpDialog__link-icon",children:m.Dd}),aO("helpDialog.documentation")]}),(0,W.jsxs)("a",{className:"HelpDialog__btn",href:"https://plus.excalidraw.com/blog",target:"_blank",rel:"noopener noreferrer",children:[(0,W.jsx)("div",{className:"HelpDialog__link-icon",children:m.Dd}),aO("helpDialog.blog")]}),(0,W.jsxs)("a",{className:"HelpDialog__btn",href:"https://github.com/excalidraw/excalidraw/issues",target:"_blank",rel:"noopener noreferrer",children:[(0,W.jsx)("div",{className:"HelpDialog__link-icon",children:m.Ed}),aO("helpDialog.github")]}),(0,W.jsxs)("a",{className:"HelpDialog__btn",href:"https://youtube.com/@excalidraw",target:"_blank",rel:"noopener noreferrer",children:[(0,W.jsx)("div",{className:"HelpDialog__link-icon",children:m.Ff}),"YouTube"]})]}),cr=e=>(0,W.jsxs)(W.Fragment,{children:[(0,W.jsx)("h3",{children:e.title}),(0,W.jsx)("div",{className:"HelpDialog__islands-container",children:e.children})]}),cs=e=>(0,W.jsxs)("div",{className:`HelpDialog__island ${e.className}`,children:[(0,W.jsx)("h4",{className:"HelpDialog__island-title",children:e.caption}),(0,W.jsx)("div",{className:"HelpDialog__island-content",children:e.children})]}),co=({label:e,shortcuts:t,isOr:n=!0})=>{let i=t.map(e=>(e.endsWith("++")?[...e.slice(0,-2).split("+"),"+"]:e.split("+")).map(e=>(0,W.jsx)(cc,{children:e.replace(/\b[a-z]\b/,e=>e.toUpperCase())},e)));return(0,W.jsxs)("div",{className:"HelpDialog__shortcut",children:[(0,W.jsx)("div",{children:e}),(0,W.jsx)("div",{className:"HelpDialog__key-container",children:[...function*(e,t){let n=!0;for(let i of e)n||(yield t),n=!1,yield i}(i,n?aO("helpDialog.or"):null)]})]})},cc=e=>(0,W.jsx)("kbd",{className:"HelpDialog__key",...e}),cd=({onClose:e})=>{let t=E.default.useCallback(()=>{e&&e()},[e]);return(0,W.jsx)(W.Fragment,{children:(0,W.jsxs)(s3,{onCloseRequest:t,title:aO("helpDialog.title"),className:"HelpDialog",children:[(0,W.jsx)(cl,{}),(0,W.jsxs)(cr,{title:aO("helpDialog.shortcuts"),children:[(0,W.jsxs)(cs,{className:"HelpDialog__island--tools",caption:aO("helpDialog.tools"),children:[(0,W.jsx)(co,{label:aO("toolBar.hand"),shortcuts:[m.hg.H]}),(0,W.jsx)(co,{label:aO("toolBar.selection"),shortcuts:[m.hg.V,m.hg[1]]}),(0,W.jsx)(co,{label:aO("toolBar.rectangle"),shortcuts:[m.hg.R,m.hg[2]]}),(0,W.jsx)(co,{label:aO("toolBar.diamond"),shortcuts:[m.hg.D,m.hg[3]]}),(0,W.jsx)(co,{label:aO("toolBar.ellipse"),shortcuts:[m.hg.O,m.hg[4]]}),(0,W.jsx)(co,{label:aO("toolBar.arrow"),shortcuts:[m.hg.A,m.hg[5]]}),(0,W.jsx)(co,{label:aO("toolBar.line"),shortcuts:[m.hg.L,m.hg[6]]}),(0,W.jsx)(co,{label:aO("toolBar.freedraw"),shortcuts:[m.hg.P,m.hg[7]]}),(0,W.jsx)(co,{label:aO("toolBar.text"),shortcuts:[m.hg.T,m.hg[8]]}),(0,W.jsx)(co,{label:aO("toolBar.image"),shortcuts:[m.hg[9]]}),(0,W.jsx)(co,{label:aO("toolBar.eraser"),shortcuts:[m.hg.E,m.hg[0]]}),(0,W.jsx)(co,{label:aO("toolBar.frame"),shortcuts:[m.hg.F]}),(0,W.jsx)(co,{label:aO("toolBar.laser"),shortcuts:[m.hg.K]}),(0,W.jsx)(co,{label:aO("labels.eyeDropper"),shortcuts:[m.hg.I,"Shift+S","Shift+G"]}),(0,W.jsx)(co,{label:aO("helpDialog.editLineArrowPoints"),shortcuts:[(0,m.kb)("CtrlOrCmd+Enter")]}),(0,W.jsx)(co,{label:aO("helpDialog.editText"),shortcuts:[(0,m.kb)("Enter")]}),(0,W.jsx)(co,{label:aO("helpDialog.textNewLine"),shortcuts:[(0,m.kb)("Enter"),(0,m.kb)("Shift+Enter")]}),(0,W.jsx)(co,{label:aO("helpDialog.textFinish"),shortcuts:[(0,m.kb)("Esc"),(0,m.kb)("CtrlOrCmd+Enter")]}),(0,W.jsx)(co,{label:aO("helpDialog.curvedArrow"),shortcuts:["A",aO("helpDialog.click"),aO("helpDialog.click"),aO("helpDialog.click")],isOr:!1}),(0,W.jsx)(co,{label:aO("helpDialog.curvedLine"),shortcuts:["L",aO("helpDialog.click"),aO("helpDialog.click"),aO("helpDialog.click")],isOr:!1}),(0,W.jsx)(co,{label:aO("helpDialog.cropStart"),shortcuts:[aO("helpDialog.doubleClick"),(0,m.kb)("Enter")],isOr:!0}),(0,W.jsx)(co,{label:aO("helpDialog.cropFinish"),shortcuts:[(0,m.kb)("Enter"),(0,m.kb)("Escape")],isOr:!0}),(0,W.jsx)(co,{label:aO("toolBar.lock"),shortcuts:[m.hg.Q]}),(0,W.jsx)(co,{label:aO("helpDialog.preventBinding"),shortcuts:[(0,m.kb)("CtrlOrCmd")]}),(0,W.jsx)(co,{label:aO("toolBar.link"),shortcuts:[(0,m.kb)("CtrlOrCmd+K")]})]}),(0,W.jsxs)(cs,{className:"HelpDialog__island--view",caption:aO("helpDialog.view"),children:[(0,W.jsx)(co,{label:aO("buttons.zoomIn"),shortcuts:[(0,m.kb)("CtrlOrCmd++")]}),(0,W.jsx)(co,{label:aO("buttons.zoomOut"),shortcuts:[(0,m.kb)("CtrlOrCmd+-")]}),(0,W.jsx)(co,{label:aO("buttons.resetZoom"),shortcuts:[(0,m.kb)("CtrlOrCmd+0")]}),(0,W.jsx)(co,{label:aO("helpDialog.zoomToFit"),shortcuts:["Shift+1"]}),(0,W.jsx)(co,{label:aO("helpDialog.zoomToSelection"),shortcuts:["Shift+2"]}),(0,W.jsx)(co,{label:aO("helpDialog.movePageUpDown"),shortcuts:["PgUp/PgDn"]}),(0,W.jsx)(co,{label:aO("helpDialog.movePageLeftRight"),shortcuts:["Shift+PgUp/PgDn"]}),(0,W.jsx)(co,{label:aO("buttons.zenMode"),shortcuts:[(0,m.kb)("Alt+Z")]}),(0,W.jsx)(co,{label:aO("buttons.objectsSnapMode"),shortcuts:[(0,m.kb)("Alt+S")]}),(0,W.jsx)(co,{label:aO("labels.toggleGrid"),shortcuts:[(0,m.kb)("CtrlOrCmd+'")]}),(0,W.jsx)(co,{label:aO("labels.viewMode"),shortcuts:[(0,m.kb)("Alt+R")]}),(0,W.jsx)(co,{label:aO("labels.toggleTheme"),shortcuts:[(0,m.kb)("Alt+Shift+D")]}),(0,W.jsx)(co,{label:aO("stats.fullTitle"),shortcuts:[(0,m.kb)("Alt+/")]}),(0,W.jsx)(co,{label:aO("search.title"),shortcuts:[s8("searchMenu")]}),(0,W.jsx)(co,{label:aO("commandPalette.title"),shortcuts:m.n?[s8("commandPalette")]:[s8("commandPalette"),s8("commandPalette",1)]})]}),(0,W.jsxs)(cs,{className:"HelpDialog__island--editor",caption:aO("helpDialog.editor"),children:[(0,W.jsx)(co,{label:aO("helpDialog.createFlowchart"),shortcuts:[(0,m.kb)("CtrlOrCmd+Arrow Key")],isOr:!0}),(0,W.jsx)(co,{label:aO("helpDialog.navigateFlowchart"),shortcuts:[(0,m.kb)("Alt+Arrow Key")],isOr:!0}),(0,W.jsx)(co,{label:aO("labels.moveCanvas"),shortcuts:[(0,m.kb)(`Space+${aO("helpDialog.drag")}`),(0,m.kb)(`Wheel+${aO("helpDialog.drag")}`)],isOr:!0}),(0,W.jsx)(co,{label:aO("buttons.clearReset"),shortcuts:[(0,m.kb)("CtrlOrCmd+Delete")]}),(0,W.jsx)(co,{label:aO("labels.delete"),shortcuts:[(0,m.kb)("Delete")]}),(0,W.jsx)(co,{label:aO("labels.cut"),shortcuts:[(0,m.kb)("CtrlOrCmd+X")]}),(0,W.jsx)(co,{label:aO("labels.copy"),shortcuts:[(0,m.kb)("CtrlOrCmd+C")]}),(0,W.jsx)(co,{label:aO("labels.paste"),shortcuts:[(0,m.kb)("CtrlOrCmd+V")]}),(0,W.jsx)(co,{label:aO("labels.pasteAsPlaintext"),shortcuts:[(0,m.kb)("CtrlOrCmd+Shift+V")]}),(0,W.jsx)(co,{label:aO("labels.selectAll"),shortcuts:[(0,m.kb)("CtrlOrCmd+A")]}),(0,W.jsx)(co,{label:aO("labels.multiSelect"),shortcuts:[(0,m.kb)(`Shift+${aO("helpDialog.click")}`)]}),(0,W.jsx)(co,{label:aO("helpDialog.deepSelect"),shortcuts:[(0,m.kb)(`CtrlOrCmd+${aO("helpDialog.click")}`)]}),(0,W.jsx)(co,{label:aO("helpDialog.deepBoxSelect"),shortcuts:[(0,m.kb)(`CtrlOrCmd+${aO("helpDialog.drag")}`)]}),(m.ii||m.n)&&(0,W.jsx)(co,{label:aO("labels.copyAsPng"),shortcuts:[(0,m.kb)("Shift+Alt+C")]}),(0,W.jsx)(co,{label:aO("labels.copyStyles"),shortcuts:[(0,m.kb)("CtrlOrCmd+Alt+C")]}),(0,W.jsx)(co,{label:aO("labels.pasteStyles"),shortcuts:[(0,m.kb)("CtrlOrCmd+Alt+V")]}),(0,W.jsx)(co,{label:aO("labels.sendToBack"),shortcuts:[m.l?(0,m.kb)("CtrlOrCmd+Alt+["):(0,m.kb)("CtrlOrCmd+Shift+[")]}),(0,W.jsx)(co,{label:aO("labels.bringToFront"),shortcuts:[m.l?(0,m.kb)("CtrlOrCmd+Alt+]"):(0,m.kb)("CtrlOrCmd+Shift+]")]}),(0,W.jsx)(co,{label:aO("labels.sendBackward"),shortcuts:[(0,m.kb)("CtrlOrCmd+[")]}),(0,W.jsx)(co,{label:aO("labels.bringForward"),shortcuts:[(0,m.kb)("CtrlOrCmd+]")]}),(0,W.jsx)(co,{label:aO("labels.alignTop"),shortcuts:[(0,m.kb)("CtrlOrCmd+Shift+Up")]}),(0,W.jsx)(co,{label:aO("labels.alignBottom"),shortcuts:[(0,m.kb)("CtrlOrCmd+Shift+Down")]}),(0,W.jsx)(co,{label:aO("labels.alignLeft"),shortcuts:[(0,m.kb)("CtrlOrCmd+Shift+Left")]}),(0,W.jsx)(co,{label:aO("labels.alignRight"),shortcuts:[(0,m.kb)("CtrlOrCmd+Shift+Right")]}),(0,W.jsx)(co,{label:aO("labels.duplicateSelection"),shortcuts:[(0,m.kb)("CtrlOrCmd+D"),(0,m.kb)(`Alt+${aO("helpDialog.drag")}`)]}),(0,W.jsx)(co,{label:aO("helpDialog.toggleElementLock"),shortcuts:[(0,m.kb)("CtrlOrCmd+Shift+L")]}),(0,W.jsx)(co,{label:aO("buttons.undo"),shortcuts:[(0,m.kb)("CtrlOrCmd+Z")]}),(0,W.jsx)(co,{label:aO("buttons.redo"),shortcuts:m.m?[(0,m.kb)("CtrlOrCmd+Y"),(0,m.kb)("CtrlOrCmd+Shift+Z")]:[(0,m.kb)("CtrlOrCmd+Shift+Z")]}),(0,W.jsx)(co,{label:aO("labels.group"),shortcuts:[(0,m.kb)("CtrlOrCmd+G")]}),(0,W.jsx)(co,{label:aO("labels.ungroup"),shortcuts:[(0,m.kb)("CtrlOrCmd+Shift+G")]}),(0,W.jsx)(co,{label:aO("labels.flipHorizontal"),shortcuts:[(0,m.kb)("Shift+H")]}),(0,W.jsx)(co,{label:aO("labels.flipVertical"),shortcuts:[(0,m.kb)("Shift+V")]}),(0,W.jsx)(co,{label:aO("labels.showStroke"),shortcuts:[(0,m.kb)("S")]}),(0,W.jsx)(co,{label:aO("labels.showBackground"),shortcuts:[(0,m.kb)("G")]}),(0,W.jsx)(co,{label:aO("labels.showFonts"),shortcuts:[(0,m.kb)("Shift+F")]}),(0,W.jsx)(co,{label:aO("labels.decreaseFontSize"),shortcuts:[(0,m.kb)("CtrlOrCmd+Shift+<")]}),(0,W.jsx)(co,{label:aO("labels.increaseFontSize"),shortcuts:[(0,m.kb)("CtrlOrCmd+Shift+>")]})]})]})]})})},ch=({shouldWrap:e,children:t,username:n})=>e?(0,W.jsx)(l4,{label:n||"Unknown user",children:t}):(0,W.jsx)(W.Fragment,{children:t}),cu=({actionManager:e,collaborator:t,socketId:n,withName:i=!1,shouldWrapWithTooltip:a=!1,isBeingFollowed:l})=>{let r=e.renderAction("goToCollaborator",{socketId:n,collaborator:t,withName:i,isBeingFollowed:l});return(0,W.jsx)(ch,{username:t.username,shouldWrap:a,children:r},n)},cp=["avatarUrl","id","socketId","username","isInCall","isSpeaking","isMuted"],cm=E.default.memo(({className:e,mobile:t,collaborators:n,userToFollow:i})=>{let a=h0(),l=new Map;n.forEach((e,t)=>{let n=e.id||t;l.set(n,{...e,socketId:t})});let r=Array.from(l.values()).filter(e=>e.username?.trim()),[s,o]=E.default.useState(""),c=r.filter(e=>e.username?.toLowerCase().includes(s)),d=E.default.useRef(null);(0,E.useLayoutEffect)(()=>{if(d.current){let e=e=>{u(Math.max(1,Math.min(8,Math.floor(e/38))))};if(e(d.current.clientWidth),!m.r)return;let t=new ResizeObserver(t=>{for(let n of t){let{width:t}=n.contentRect;e(t)}});return t.observe(d.current),()=>{t.disconnect()}}},[]);let[h,u]=E.default.useState(4),p=r.slice(0,h-1).map(e=>cu({actionManager:a,collaborator:e,socketId:e.socketId,shouldWrapWithTooltip:!0,isBeingFollowed:e.socketId===i}));return t?(0,W.jsx)("div",{className:(0,el.default)("UserList UserList_mobile",e),children:r.map(e=>cu({actionManager:a,collaborator:e,socketId:e.socketId,shouldWrapWithTooltip:!0,isBeingFollowed:e.socketId===i}))}):(0,W.jsx)("div",{className:"UserList__wrapper",ref:d,children:(0,W.jsxs)("div",{className:(0,el.default)("UserList",e),style:{"--max-avatars":h},children:[p,r.length>h-1&&(0,W.jsxs)(n1,{children:[(0,W.jsxs)(n5,{className:"UserList__more",children:["+",r.length-h+1]}),(0,W.jsx)(ie,{style:{zIndex:2,width:"15rem",textAlign:"left"},align:"end",sideOffset:10,children:(0,W.jsxs)(lx,{padding:2,children:[r.length>=8&&(0,W.jsx)(lA,{placeholder:aO("quickSearch.placeholder"),onChange:o}),(0,W.jsx)(lP,{className:"dropdown-menu UserList__collaborators",placeholder:aO("userList.empty"),children:c.length>0?[(0,W.jsx)("div",{className:"hint",children:aO("userList.hint.text")}),c.map(e=>cu({actionManager:a,collaborator:e,socketId:e.socketId,withName:!0,isBeingFollowed:e.socketId===i}))]:[]}),(0,W.jsx)(ir,{width:20,height:10,style:{fill:"var(--popup-bg-color)",filter:"drop-shadow(rgba(0, 0, 0, 0.05) 0px 3px 2px)"}})]})})]})]})})},(e,t)=>{if(e.collaborators.size!==t.collaborators.size||e.mobile!==t.mobile||e.className!==t.className||e.userToFollow!==t.userToFollow)return!1;let n=t.collaborators.keys();for(let[i,a]of e.collaborators){let e=t.collaborators.get(i);if(!e||i!==n.next().value||!(0,m.Hb)(a,e,cp))return!1}return!0}),cg=({children:e,color:t})=>(0,W.jsx)("div",{className:"Card",style:{"--card-color":"primary"===t?"var(--color-primary)":io.default[t][7],"--card-color-darker":"primary"===t?"var(--color-primary-darker)":io.default[t][8],"--card-color-darkest":"primary"===t?"var(--color-primary-darkest)":io.default[t][9]},children:e}),cf=({elements:e,appState:t,setAppState:n,files:i,actionManager:a,exportOpts:l,canvas:r,onCloseRequest:s})=>{let{onExportToBackend:o}=l;return(0,W.jsx)("div",{className:"ExportDialog ExportDialog--json",children:(0,W.jsxs)("div",{className:"ExportDialog-cards",children:[l.saveFileToDisk&&(0,W.jsxs)(cg,{color:"lime",children:[(0,W.jsx)("div",{className:"Card-icon",children:m.Pd}),(0,W.jsx)("h2",{children:aO("exportDialog.disk_title")}),(0,W.jsxs)("div",{className:"Card-details",children:[aO("exportDialog.disk_details"),!g.supported&&a.renderAction("changeProjectName")]}),(0,W.jsx)(aH,{className:"Card-button",type:"button",title:aO("exportDialog.disk_button"),"aria-label":aO("exportDialog.disk_button"),showAriaLabel:!0,onClick:()=>{a.executeAction(rb,"ui")}})]}),o&&(0,W.jsxs)(cg,{color:"pink",children:[(0,W.jsx)("div",{className:"Card-icon",children:m.Id}),(0,W.jsx)("h2",{children:aO("exportDialog.link_title")}),(0,W.jsx)("div",{className:"Card-details",children:aO("exportDialog.link_details")}),(0,W.jsx)(aH,{className:"Card-button",type:"button",title:aO("exportDialog.link_button"),"aria-label":aO("exportDialog.link_button"),showAriaLabel:!0,onClick:async()=>{try{a8("export","link",`ui (${(0,m.Eb)()})`),await o(e,t,i),s()}catch(e){n({errorMessage:e.message})}}})]}),l.renderCustomUI&&l.renderCustomUI(e,t,i,r)]})})},cb=({elements:e,appState:t,files:n,actionManager:i,exportOpts:a,canvas:l,setAppState:r})=>{let s=E.default.useCallback(()=>{r({openDialog:null})},[r]);return(0,W.jsx)(W.Fragment,{children:t.openDialog?.name==="jsonExport"&&(0,W.jsx)(s3,{onCloseRequest:s,title:aO("buttons.export"),children:(0,W.jsx)(cf,{elements:e,appState:t,setAppState:r,files:n,actionManager:i,onCloseRequest:s,exportOpts:a,canvas:l})})})},cv=e=>(0,W.jsx)("button",{className:"help-icon",onClick:e.onClick,type:"button",title:`${aO("helpDialog.title")} \u2014 ?`,"aria-label":aO("helpDialog.title"),children:m.Bd}),cy=({appState:e,actionManager:t,showExitZenModeBtn:n,renderWelcomeScreen:i})=>{let{FooterCenterTunnel:a,WelcomeScreenHelpHintTunnel:l}=E.default.useContext(on),r=hZ(),s=!e.viewModeEnabled&&e.multiElement&&r.isTouchScreen;return(0,W.jsxs)("footer",{role:"contentinfo",className:"layer-ui__wrapper__footer App-menu App-menu_bottom",children:[(0,W.jsx)("div",{className:(0,el.default)("layer-ui__wrapper__footer-left zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-left":e.zenModeEnabled}),children:(0,W.jsx)(sC,{gap:2,children:(0,W.jsxs)(o7,{heading:"canvasActions",children:[(0,W.jsx)(oo,{renderAction:t.renderAction,zoom:e.zoom}),!e.viewModeEnabled&&(0,W.jsx)(oc,{renderAction:t.renderAction,className:(0,el.default)("zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-bottom":e.zenModeEnabled})}),s&&(0,W.jsx)(oh,{renderAction:t.renderAction,className:(0,el.default)("zen-mode-transition",{"layer-ui__wrapper__footer-left--transition-left":e.zenModeEnabled})})]})})}),(0,W.jsx)(a.Out,{}),(0,W.jsx)("div",{className:(0,el.default)("layer-ui__wrapper__footer-right zen-mode-transition",{"transition-right":e.zenModeEnabled}),children:(0,W.jsxs)("div",{style:{position:"relative"},children:[i&&(0,W.jsx)(l.Out,{}),(0,W.jsx)(cv,{onClick:()=>t.executeAction(rS)})]})}),(0,W.jsx)(od,{actionManager:t,showExitZenModeBtn:n})]})};cy.displayName="Footer";var cE=E.default.createContext({}),cx=({children:e,className:t})=>{let n=hZ(),i=(0,E.useContext)(cE),a=!!(n.editor.canFitSidebar&&i.shouldRenderDockButton);return(0,W.jsxs)("div",{className:(0,el.default)("sidebar__header",t),"data-testid":"sidebar-header",children:[e,(0,W.jsxs)("div",{className:"sidebar__header__buttons",children:[a&&(0,W.jsx)(l4,{label:aO("labels.sidebarLock"),children:(0,W.jsx)(s5,{onSelect:()=>i.onDock?.(!i.docked),selected:!!i.docked,className:"sidebar__dock","data-testid":"sidebar-dock","aria-label":aO("labels.sidebarLock"),children:m.id})}),(0,W.jsx)(s5,{"data-testid":"sidebar-close",className:"sidebar__close",onSelect:i.onCloseRequest,"aria-label":aO("buttons.close"),children:m.ge})]})]})};cx.displayName="SidebarHeader";var cw=({name:e,tab:t,icon:n,title:i,children:a,onToggle:l,className:r,style:s})=>{let o=hJ(),c=E.default.useContext(lm);return(0,W.jsxs)("label",{title:i,className:"sidebar-trigger__label-element",children:[(0,W.jsx)("input",{className:"ToolIcon_type_checkbox",type:"checkbox",onChange:n=>{document.querySelector(".layer-ui__wrapper")?.classList.remove("animate");let i=n.target.checked;o({openSidebar:i?{name:e,tab:t}:null}),l?.(i)},checked:c.openSidebar?.name===e,"aria-label":i,"aria-keyshortcuts":"0"}),(0,W.jsxs)("div",{className:(0,el.default)("sidebar-trigger",r),style:s,children:[n&&(0,W.jsx)("div",{children:n}),a&&(0,W.jsx)("div",{className:"sidebar-trigger__label",children:a})]})]})};cw.displayName="SidebarTrigger";var cS=({children:e,...t})=>(0,W.jsx)(al,{className:"sidebar-triggers",...t,children:e});cS.displayName="SidebarTabTriggers";var cC=({children:e,tab:t,onSelect:n,...i})=>(0,W.jsx)(ar,{value:t,asChild:!0,onSelect:n,children:(0,W.jsx)("button",{type:"button",className:"excalidraw-button sidebar-tab-trigger",...i,children:e})});cC.displayName="SidebarTabTrigger";var ck=({children:e,...t})=>{let n=E.default.useContext(lm),i=hJ();if(!n.openSidebar)return null;let{name:a}=n.openSidebar;return(0,W.jsx)(aa,{className:"sidebar-tabs-root",value:n.openSidebar.tab,onValueChange:e=>i(t=>({...t,openSidebar:{...t.openSidebar,name:a,tab:e}})),...t,children:e})};ck.displayName="SidebarTabs";var cI=({tab:e,children:t,...n})=>(0,W.jsx)(as,{...n,value:e,"data-testid":e,children:t});cI.displayName="SidebarTab";var cj=S(!1),cT=(0,E.forwardRef)(({name:e,children:t,onDock:n,docked:i,className:a,...l},r)=>{f.a.DEV&&n&&null==i&&console.warn("Sidebar: `docked` must be set when `onDock` is supplied for the sidebar to be user-dockable. To hide this message, either pass `docked` or remove `onDock`");let s=hJ(),o=aC(cj);(0,E.useLayoutEffect)(()=>(o(!!i),()=>{o(!1)}),[o,i]);let c=(0,E.useRef)({});c.current.onCloseRequest=()=>{s({openSidebar:null})},c.current.onDock=e=>n?.(e),c.current=(0,m.Db)(c.current,{docked:i,shouldRenderDockButton:!!n&&null!=i});let d=(0,E.useRef)(null);(0,E.useImperativeHandle)(r,()=>d.current);let h=hZ(),u=(0,E.useCallback)(()=>{document.querySelector(".Dialog")||s({openSidebar:null})},[s]);return lf(d,(0,E.useCallback)(e=>{e.target.closest(".sidebar-trigger")||i&&h.editor.canFitSidebar||u()},[u,i,h.editor.canFitSidebar])),(0,E.useEffect)(()=>{let e=e=>{e.key!==m.hg.ESCAPE||i&&h.editor.canFitSidebar||u()};return document.addEventListener("keydown",e),()=>{document.removeEventListener("keydown",e)}},[u,i,h.editor.canFitSidebar]),(0,W.jsx)(lx,{...l,className:(0,el.default)("sidebar",{"sidebar--docked":i},a),ref:d,children:(0,W.jsx)(cE.Provider,{value:c.current,children:t})})});cT.displayName="SidebarInner";var cM=Object.assign((0,E.forwardRef)((e,t)=>{let n=E.default.useContext(lm),{onStateChange:i}=e,a=(0,E.useRef)(n.openSidebar);(0,E.useEffect)(()=>{(n.openSidebar||a?.current?.name!==e.name)&&(n.openSidebar?.name!==e.name||a?.current?.name===e.name)&&a.current?.name!==e.name||n.openSidebar===a.current||i?.(n.openSidebar?.name!==e.name?null:n.openSidebar),a.current=n.openSidebar},[n.openSidebar,i,e.name]);let[l,r]=(0,E.useState)(!1);return(0,E.useLayoutEffect)(()=>(r(!0),()=>r(!1)),[]),l&&n.openSidebar?.name===e.name?(0,E.createElement)(cT,{...e,ref:t,key:e.name}):null}),{Header:cx,TabTriggers:cS,TabTrigger:cC,Tabs:ck,Tab:cI,Trigger:cw});cM.displayName="Sidebar";var cL={};(0,y.c)(cL,{ChangeCanvasBackground:()=>cW,ClearCanvas:()=>cU,CommandPalette:()=>cO,Export:()=>cH,Help:()=>cz,LiveCollaborationTrigger:()=>cY,LoadScene:()=>cP,SaveAsImage:()=>c_,SaveToActiveFile:()=>cR,SearchMenu:()=>cF,Socials:()=>c$,ToggleTheme:()=>cB});var cD=S({active:!1});async function cN({title:e,description:t,actionLabel:n,color:i}){return new Promise(a=>{aT.set(cD,{active:!0,onConfirm:()=>a(!0),onClose:()=>a(!1),onReject:()=>a(!1),title:e,description:t,actionLabel:n,color:i})})}var cA=({value:e,shortcut:t,onChange:n,choices:i,children:a,name:l})=>{let r=hZ();return(0,W.jsxs)(W.Fragment,{children:[(0,W.jsxs)("div",{className:"dropdown-menu-item-base dropdown-menu-item-bare",children:[(0,W.jsx)("label",{className:"dropdown-menu-item__text",htmlFor:l,children:a}),(0,W.jsx)(oY,{name:l,value:e,onChange:n,choices:i})]}),t&&!r.editor.isMobile&&(0,W.jsx)("div",{className:"dropdown-menu-item__shortcut dropdown-menu-item__shortcut--orphaned",children:t})]})};cA.displayName="DropdownMenuItemContentRadio";var cP=()=>{let{t:e}=az(),t=h0(),n=hQ();return t.isActionEnabled(rv)?(0,W.jsx)(lU,{icon:m.Ld,onSelect:async()=>{(!n.length||await cN({title:e("overwriteConfirm.modal.loadFromFile.title"),actionLabel:e("overwriteConfirm.modal.loadFromFile.button"),color:"warning",description:(0,W.jsx)(sD,{i18nKey:"overwriteConfirm.modal.loadFromFile.description",bold:e=>(0,W.jsx)("strong",{children:e}),br:()=>(0,W.jsx)("br",{})})}))&&t.executeAction(rv)},"data-testid":"load-button",shortcut:s8("loadScene"),"aria-label":e("buttons.load"),children:e("buttons.load")}):null};cP.displayName="LoadScene";var cR=()=>{let{t:e}=az(),t=h0();return t.isActionEnabled(rf)?(0,W.jsx)(lU,{shortcut:s8("saveScene"),"data-testid":"save-button",onSelect:()=>t.executeAction(rf),icon:m.Jd,"aria-label":`${e("buttons.save")}`,children:`${e("buttons.save")}`}):null};cR.displayName="SaveToActiveFile";var c_=()=>{let e=hJ(),{t:t}=az();return(0,W.jsx)(lU,{icon:m.Od,"data-testid":"image-export-button",onSelect:()=>e({openDialog:{name:"imageExport"}}),shortcut:s8("imageExport"),"aria-label":t("buttons.exportImage"),children:t("buttons.exportImage")})};c_.displayName="SaveAsImage";var cO=e=>{let t=hJ(),{t:n}=az();return(0,W.jsx)(lU,{icon:m.tf,"data-testid":"command-palette-button",onSelect:()=>{a8("command_palette","open","menu"),t({openDialog:{name:"commandPalette"}})},shortcut:s8("commandPalette"),"aria-label":n("commandPalette.title"),className:e?.className,children:n("commandPalette.title")})};cO.displayName="CommandPalette";var cF=e=>{let{t:t}=az(),n=h0();return(0,W.jsx)(lU,{icon:m.pf,"data-testid":"search-menu-button",onSelect:()=>{n.executeAction(oM)},shortcut:s8("searchMenu"),"aria-label":t("search.title"),className:e?.className,children:t("search.title")})};cF.displayName="SearchMenu";var cz=()=>{let{t:e}=az(),t=h0();return(0,W.jsx)(lU,{"data-testid":"help-menu-item",icon:m.Bd,onSelect:()=>t.executeAction(rS),shortcut:"?","aria-label":e("helpDialog.title"),children:e("helpDialog.title")})};cz.displayName="Help";var cU=()=>{let{t:e}=az(),t=aC(op);return h0().isActionEnabled(l6)?(0,W.jsx)(lU,{icon:m.ud,onSelect:()=>t("clearCanvas"),"data-testid":"clear-canvas-button","aria-label":e("buttons.clearReset"),children:e("buttons.clearReset")}):null};cU.displayName="ClearCanvas";var cB=e=>{let{t:t}=az(),n=E.default.useContext(lm),i=h0(),a=s8("toggleTheme");return i.isActionEnabled(rn)?e?.allowSystemTheme?(0,W.jsx)(cA,{name:"theme",value:e.theme,onChange:t=>e.onSelect(t),choices:[{value:m.G.LIGHT,label:m.yd,ariaLabel:`${t("buttons.lightMode")} - ${a}`},{value:m.G.DARK,label:m.xd,ariaLabel:`${t("buttons.darkMode")} - ${a}`},{value:"system",label:m.Ef,ariaLabel:t("buttons.systemMode")}],children:t("labels.theme")}):(0,W.jsx)(lU,{onSelect:t=>{if(t.preventDefault(),!e?.onSelect)return i.executeAction(rn);e.onSelect(n.theme===m.G.DARK?m.G.LIGHT:m.G.DARK)},icon:n.theme===m.G.DARK?m.yd:m.xd,"data-testid":"toggle-dark-mode",shortcut:a,"aria-label":t(n.theme===m.G.DARK?"buttons.lightMode":"buttons.darkMode"),children:t(n.theme===m.G.DARK?"buttons.lightMode":"buttons.darkMode")}):null};cB.displayName="ToggleTheme";var cW=()=>{let{t:e}=az(),t=E.default.useContext(lm),n=h0(),i=hK();return t.viewModeEnabled||!i.UIOptions.canvasActions.changeViewBackgroundColor?null:(0,W.jsxs)("div",{style:{marginTop:"0.5rem"},children:[(0,W.jsx)("div",{"data-testid":"canvas-background-label",style:{fontSize:".75rem",marginBottom:".5rem"},children:e("labels.canvasBackground")}),(0,W.jsx)("div",{style:{padding:"0 0.625rem"},children:n.renderAction("changeViewBackgroundColor")})]})};cW.displayName="ChangeCanvasBackground";var cH=()=>{let{t:e}=az(),t=hJ();return(0,W.jsx)(lU,{icon:m.Ad,onSelect:()=>{t({openDialog:{name:"jsonExport"}})},"data-testid":"json-export-button","aria-label":e("buttons.export"),children:e("buttons.export")})};cH.displayName="Export";var c$=()=>{let{t:e}=az();return(0,W.jsxs)(W.Fragment,{children:[(0,W.jsx)(sB,{icon:m.Ed,href:"https://github.com/excalidraw/excalidraw","aria-label":"GitHub",children:"GitHub"}),(0,W.jsx)(sB,{icon:m.Gd,href:"https://x.com/excalidraw","aria-label":"X",children:e("labels.followUs")}),(0,W.jsx)(sB,{icon:m.Fd,href:"https://discord.gg/UexuTaE","aria-label":"Discord",children:e("labels.discordChat")})]})};c$.displayName="Socials";var cY=({onSelect:e,isCollaborating:t})=>{let{t:n}=az();return(0,W.jsx)(lU,{"data-testid":"collab-button",icon:m.fe,className:(0,el.default)({"active-collab":t}),onSelect:e,children:n("labels.liveCollaboration")})};cY.displayName="LiveCollaborationTrigger";var cV=(e,t)=>{let n=S(0),i=e=>{let{tunnelsJotai:{useAtom:i}}=E.default.useContext(on),[,a]=i(n),l=(0,E.useRef)({preferHost:!1,counter:0});return(0,E.useLayoutEffect)(()=>{let e=l.current;return a(t=>{let n=t+1;return e.counter=n,n}),()=>{a(t=>{let n=t-1;return e.counter=n,n||(e.preferHost=!1),n})}},[a]),e.__fallback||(l.current.preferHost=!0),!l.current.counter&&e.__fallback&&l.current.preferHost||l.current.counter>1&&e.__fallback?null:(0,W.jsx)(t,{...e})};return i.displayName=e,i},cG=Object.assign(cV("MainMenu",({children:e,onSelect:t})=>{let{MainMenuTunnel:n}=E.default.useContext(on),i=hZ(),a=E.default.useContext(lm),l=hJ(),r=i.editor.isMobile?void 0:()=>l({openMenu:null});return(0,W.jsx)(n.In,{children:(0,W.jsxs)(sW,{open:"canvas"===a.openMenu,children:[(0,W.jsx)(sW.Trigger,{onToggle:()=>{l({openMenu:"canvas"===a.openMenu?null:"canvas"})},"data-testid":"main-menu-trigger",className:"main-menu-trigger",children:m.zd}),(0,W.jsxs)(sW.Content,{onClickOutside:r,onSelect:(0,m.Ib)(t,()=>{l({openMenu:null})}),children:[e,i.editor.isMobile&&a.collaborators.size>0&&(0,W.jsxs)("fieldset",{className:"UserList-Wrapper",children:[(0,W.jsx)("legend",{children:aO("labels.collaborators")}),(0,W.jsx)(cm,{mobile:!0,collaborators:a.collaborators,userToFollow:a.userToFollow?.socketId||null})]})]})]})})}),{Trigger:sW.Trigger,Item:sW.Item,ItemLink:sW.ItemLink,ItemCustom:sW.ItemCustom,Group:sW.Group,Separator:sW.Separator,DefaultItems:cL}),cK=({title:e,children:t,actionLabel:n,onClick:i})=>(0,W.jsxs)("div",{className:"OverwriteConfirm__Actions__Action",children:[(0,W.jsx)("h4",{children:e}),(0,W.jsx)("div",{className:"OverwriteConfirm__Actions__Action__content",children:t}),(0,W.jsx)(oG,{variant:"outlined",color:"muted",label:n,size:"large",fullWidth:!0,onClick:i})]}),cZ=Object.assign(({children:e})=>(0,W.jsx)("div",{className:"OverwriteConfirm__Actions",children:e}),{ExportToImage:()=>{let{t:e}=az(),t=h0(),n=hJ();return(0,W.jsx)(cK,{title:e("overwriteConfirm.action.exportToImage.title"),actionLabel:e("overwriteConfirm.action.exportToImage.button"),onClick:()=>{t.executeAction(rg,"ui",!0),n({openDialog:{name:"imageExport"}})},children:e("overwriteConfirm.action.exportToImage.description")})},SaveToDisk:()=>{let{t:e}=az(),t=h0();return(0,W.jsx)(cK,{title:e("overwriteConfirm.action.saveToDisk.title"),actionLabel:e("overwriteConfirm.action.saveToDisk.button"),onClick:()=>{t.executeAction(rb,"ui")},children:e("overwriteConfirm.action.saveToDisk.description")})}}),cX=Object.assign(cV("OverwriteConfirmDialog",({children:e})=>{let{OverwriteConfirmDialogTunnel:t}=E.default.useContext(on),[n,i]=aS(cD);return n.active?(0,W.jsx)(t.In,{children:(0,W.jsx)(s3,{onCloseRequest:()=>{n.onClose(),i(e=>({...e,active:!1}))},title:!1,size:916,children:(0,W.jsxs)("div",{className:"OverwriteConfirm",children:[(0,W.jsx)("h3",{children:n.title}),(0,W.jsxs)("div",{className:`OverwriteConfirm__Description OverwriteConfirm__Description--color-${n.color}`,children:[(0,W.jsx)("div",{className:"OverwriteConfirm__Description__icon",children:m.cf}),(0,W.jsx)("div",{children:n.description}),(0,W.jsx)("div",{className:"OverwriteConfirm__Description__spacer"}),(0,W.jsx)(oG,{color:n.color,size:"large",label:n.actionLabel,onClick:()=>{n.onConfirm(),i(e=>({...e,active:!1}))}})]}),(0,W.jsx)(cZ,{children:e})]})})}):null}),{Actions:cZ,Action:cK}),cQ=S(""),cq=S(null),cJ=()=>{let e=hG(),t=hJ(),n=(0,E.useRef)(null),[i,a]=aS(cQ),l=i.trim(),[r,s]=(0,E.useState)(!1),[o,c]=(0,E.useState)({nonce:null,items:[]}),d=(0,E.useRef)(null),h=(0,E.useRef)(void 0),[u,p]=aS(cq),g=e.scene.getNonDeletedElementsMap();(0,E.useEffect)(()=>{r||(l!==d.current||e.scene.getSceneNonce()!==h.current)&&(d.current=null,c5(l,e,(n,i)=>{c({nonce:(0,m.rc)(),items:n}),d.current=l,h.current=e.scene.getSceneNonce(),t({searchMatches:n.map(e=>({id:e.textElement.id,focus:!1,matchedLines:e.matchedLines}))})}))},[r,l,g,e,t,p,h]);let f=()=>{o.items.length>0&&p(e=>null===e?0:(e+1)%o.items.length)},b=()=>{o.items.length>0&&p(e=>null===e?0:e-1<0?o.items.length-1:e-1)};(0,E.useEffect)(()=>{t(e=>({searchMatches:e.searchMatches.map((e,t)=>t===u?{...e,focus:!0}:{...e,focus:!1})}))},[u,t]),(0,E.useEffect)(()=>{if(o.items.length>0&&null!==u){let t=o.items[u];if(t){let n=e.state.zoom.value,i=(0,m.Xf)({text:t.searchQuery,x:t.textElement.x+(t.matchedLines[0]?.offsetX??0),y:t.textElement.y+(t.matchedLines[0]?.offsetY??0),width:t.matchedLines[0]?.width,height:t.matchedLines[0]?.height,fontSize:t.textElement.fontSize,fontFamily:t.textElement.fontFamily}),a=t.textElement.fontSize,l=a*n<14;if(!(0,m.Uj)([i],e.canvas.width/window.devicePixelRatio,e.canvas.height/window.devicePixelRatio,{offsetLeft:e.state.offsetLeft,offsetTop:e.state.offsetTop,scrollX:e.state.scrollX,scrollY:e.state.scrollY,zoom:e.state.zoom},e.scene.getNonDeletedElementsMap(),e.getEditorUIOffsets())||l){let t;t=l?a>=14?{fitToContent:!0}:{fitToViewport:!0,maxZoom:(0,m.Ja)(14/a,1)}:{fitToContent:!0},e.scrollToContent(i,{animate:!0,duration:300,...t,canvasOffsets:e.getEditorUIOffsets()})}}}},[u,o,e]),(0,E.useEffect)(()=>()=>{p(null),d.current=null,h.current=void 0,t({searchMatches:[]}),s(!1)},[t,p]);let v=lb({goToNextItem:f,goToPreviousItem:b,searchMatches:o});(0,E.useEffect)(()=>(0,m.Pb)(window,"keydown",i=>{if(i.key===m.hg.ESCAPE&&!e.state.openDialog&&!e.state.openPopup){i.preventDefault(),i.stopPropagation(),t({openSidebar:null});return}i[m.hg.CTRL_OR_CMD]&&i.key===m.hg.F&&(i.preventDefault(),i.stopPropagation(),n.current?.matches(":focus")?t({openSidebar:null}):(e.state.openDialog&&t({openDialog:null}),n.current?.focus(),n.current?.select())),i.target instanceof HTMLElement&&i.target.closest(".layer-ui__search")&&v.searchMatches.items.length&&(i.key===m.hg.ENTER&&(i.stopPropagation(),v.goToNextItem()),i.key===m.hg.ARROW_UP?(i.stopPropagation(),v.goToPreviousItem()):i.key===m.hg.ARROW_DOWN&&(i.stopPropagation(),v.goToNextItem()))},{capture:!0,passive:!1}),[t,v,e]);let y=`${o.items.length} ${1===o.items.length?aO("search.singleResult"):aO("search.multipleResults")}`;return(0,W.jsxs)("div",{className:"layer-ui__search",children:[(0,W.jsx)("div",{className:"layer-ui__search-header",children:(0,W.jsx)(s4,{className:m.E.SEARCH_MENU_INPUT_WRAPPER,value:i,ref:n,placeholder:aO("search.placeholder"),icon:m.pf,onChange:n=>{a(n),s(!0);let i=n.trim();c5(i,e,(n,a)=>{c({nonce:(0,m.rc)(),items:n}),p(a),d.current=i,h.current=e.scene.getSceneNonce(),t({searchMatches:n.map(e=>({id:e.textElement.id,focus:!1,matchedLines:e.matchedLines}))}),s(!1)})},selectOnRender:!0})}),(0,W.jsxs)("div",{className:"layer-ui__search-count",children:[o.items.length>0&&(0,W.jsxs)(W.Fragment,{children:[null!==u&&u>-1?(0,W.jsxs)("div",{children:[u+1," / ",y]}):(0,W.jsx)("div",{children:y}),(0,W.jsxs)("div",{className:"result-nav",children:[(0,W.jsx)(s5,{onSelect:()=>{f()},className:"result-nav-btn",children:m.Lf}),(0,W.jsx)(s5,{onSelect:()=>{b()},className:"result-nav-btn",children:m.Nf})]})]}),0===o.items.length&&l&&d.current&&(0,W.jsx)("div",{style:{margin:"1rem auto"},children:aO("search.noMatch")})]}),(0,W.jsx)(c1,{matches:o,onItemClick:p,focusIndex:u,searchQuery:l})]})},c0=e=>{let t=[e.preview.moreBefore?"...":"",e.preview.previewText.slice(0,e.preview.indexInSearchQuery),e.preview.previewText.slice(e.preview.indexInSearchQuery,e.preview.indexInSearchQuery+e.searchQuery.length),e.preview.previewText.slice(e.preview.indexInSearchQuery+e.searchQuery.length),e.preview.moreAfter?"...":""];return(0,W.jsx)("div",{tabIndex:-1,className:(0,el.default)("layer-ui__result-item",{active:e.highlighted}),onClick:e.onClick,ref:t=>{e.highlighted&&t?.scrollIntoView({behavior:"auto",block:"nearest"})},children:(0,W.jsx)("div",{className:"preview-text",children:t.flatMap((e,t)=>(0,W.jsx)(E.Fragment,{children:2===t?(0,W.jsx)("b",{children:e}):e},t))})})},c1=(0,E.memo)(e=>(0,W.jsx)("div",{className:"layer-ui__search-result-container",children:e.matches.items.map((t,n)=>(0,W.jsx)(c0,{searchQuery:e.searchQuery,preview:t.preview,highlighted:n===e.focusIndex,onClick:()=>e.onItemClick(n)},t.textElement.id+t.index))}),(e,t)=>e.matches.nonce===t.matches.nonce&&e.focusIndex===t.focusIndex),c2=(e,t,n)=>{let i=e.slice(0,t),a=i.split(/\s+/),l=i.endsWith(" "),r=a.length-2-1-!l,s=a.slice(r<=0?0:r).join(" ")+(l?" ":"");s=s.length>20?s.slice(-20):s;let o=e.slice(t+n.length),c=o.split(/\s+/),d=!o.startsWith(" "),h=d?6:5,u=(d?"":" ")+c.slice(0,h).join(" ");return{indexInSearchQuery:s.length,previewText:s+n+u,moreBefore:r>0,moreAfter:c.length>h}},c3=(e,t,n)=>{let i=((e,t)=>{let n=e.split(`
|