@popmelt.com/core 0.5.18 → 0.5.20

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/dist/index.mjs CHANGED
@@ -1,19 +1,21 @@
1
1
  "use client";
2
- var ka=Object.defineProperty,Ca=Object.defineProperties;var Ma=Object.getOwnPropertyDescriptors;var qo=Object.getOwnPropertySymbols;var hs=Object.prototype.hasOwnProperty,ys=Object.prototype.propertyIsEnumerable;var ms=(e,t,o)=>t in e?ka(e,t,{enumerable:!0,configurable:!0,writable:!0,value:o}):e[t]=o,f=(e,t)=>{for(var o in t||(t={}))hs.call(t,o)&&ms(e,o,t[o]);if(qo)for(var o of qo(t))ys.call(t,o)&&ms(e,o,t[o]);return e},h=(e,t)=>Ca(e,Ma(t));var Qo=e=>typeof e=="symbol"?e:e+"",Hn=(e,t)=>{var o={};for(var r in e)hs.call(e,r)&&t.indexOf(r)<0&&(o[r]=e[r]);if(e!=null&&qo)for(var r of qo(e))t.indexOf(r)<0&&ys.call(e,r)&&(o[r]=e[r]);return o};import{createContext as Pp,useCallback as Gt,useContext as Bp,useEffect as zt,useMemo as Ao,useRef as Xt,useState as Ut}from"react";import{useCallback as Ts,useEffect as Ta,useSyncExternalStore as La}from"react";var Cn="http://localhost:1111";function kn(e,t={},o=15e3){let r=new AbortController;t.signal&&t.signal.addEventListener("abort",()=>r.abort());let n=setTimeout(()=>r.abort(),o);return fetch(e,h(f({},t),{signal:r.signal})).finally(()=>clearTimeout(n))}async function xs(e=Cn){try{let t=await kn(`${e}/capabilities`,{},5e3);return t.ok?await t.json():null}catch(t){return null}}async function er(e=Cn){try{let t=new AbortController,o=setTimeout(()=>t.abort(),2e3),r=await fetch(`${e}/status`,{signal:t.signal});return clearTimeout(o),r.ok?await r.json():null}catch(t){return null}}async function bs(e){try{let t=new AbortController,o=setTimeout(()=>t.abort(),500),r=await fetch(`http://localhost:${e}/status`,{signal:t.signal});return clearTimeout(o),r.ok?await r.json():null}catch(t){return null}}async function vs(e){if(e&&e!=="http://localhost:1111")try{let c=new URL(e);return{url:e,port:parseInt(c.port,10)||1111}}catch(c){return null}let n=typeof window!="undefined"?window.location.origin:null,i=await bs(1111);if(i&&i.devOrigin&&n&&i.devOrigin===n)return{url:"http://localhost:1111",port:1111};let s=Array.from({length:8},(c,d)=>{let u=1112+d;return bs(u).then(p=>p?{status:p,port:u}:null)}),l=(await Promise.all(s)).filter(c=>c!==null),a=[];i&&a.push({port:1111,devOrigin:i.devOrigin});for(let c of l)a.push({port:c.port,devOrigin:c.status.devOrigin});if(n){let c=a.find(d=>d.devOrigin===n);if(c)return{url:`http://localhost:${c.port}`,port:c.port}}return a.length===1?{url:`http://localhost:${a[0].port}`,port:a[0].port}:i?{url:"http://localhost:1111",port:1111}:a.length>0?{url:`http://localhost:${a[0].port}`,port:a[0].port}:null}async function Ss(e,t,o=Cn,r,n,i,s,l){let a=new FormData;if(a.append("screenshot",e,"screenshot.png"),a.append("feedback",t),r&&a.append("color",r),n&&a.append("provider",n),i&&a.append("model",i),l&&a.append("sourceId",l),s)for(let[d,u]of s)for(let p=0;p<u.length;p++)a.append(`image-${d}-${p}`,u[p],`image-${d}-${p}.png`);let c=await kn(`${o}/send`,{method:"POST",body:a},3e4);if(!c.ok){let d=await c.text();throw new Error(`Bridge returned ${c.status}: ${d}`)}return c.json()}async function ws(e=Cn,t){try{let o=await kn(`${e}/mcp/install`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(t?{serverUrl:t}:{})},15e3);return o.ok?await o.json():null}catch(o){return null}}async function Es(e,t=Cn){let o=await kn(`${t}/model/component`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({name:e})},1e4);if(!o.ok){let r=await o.text();throw new Error(`Bridge returned ${o.status}: ${r}`)}return o.json()}async function ks(e,t=Cn){let o=await kn(`${t}/model/component`,{method:"DELETE",headers:{"Content-Type":"application/json"},body:JSON.stringify({name:e})},1e4);if(!o.ok){let r=await o.text();throw new Error(`Bridge returned ${o.status}: ${r}`)}return o.json()}async function Ar(e,t,o=Cn){let r=await kn(`${o}/model/token`,{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({path:e,value:t})},1e4);if(!r.ok){let n=await r.text();throw new Error(`Bridge returned ${r.status}: ${n}`)}return r.json()}async function Cs(e,t=Cn){let o=await kn(`${t}/model/token`,{method:"DELETE",headers:{"Content-Type":"application/json"},body:JSON.stringify({path:e})},1e4);if(!o.ok){let r=await o.text();throw new Error(`Bridge returned ${o.status}: ${r}`)}return o.json()}async function io(e=Cn){var t;try{let o=await kn(`${e}/model`,{},5e3);return o.ok&&(t=(await o.json()).model)!=null?t:null}catch(o){return null}}async function Ms(e,t,o=Cn,r,n,i,s,l){let a;if(s&&s.length>0){let c=new FormData,d=new Blob([new Uint8Array([137,80,78,71,13,10,26,10,0,0,0,13,73,72,68,82,0,0,0,1,0,0,0,1,8,6,0,0,0,31,21,196,137,0,0,0,10,73,68,65,84,120,156,98,0,0,0,2,0,1,229,39,222,252,0,0,0,0,73,69,78,68,174,66,96,130])],{type:"image/png"});c.append("screenshot",d,"screenshot.png"),c.append("feedback",JSON.stringify({threadId:e,reply:t,color:r,provider:n,model:i,sourceId:l}));for(let u=0;u<s.length;u++)c.append(`image-reply-${u}`,s[u],`reply-image-${u}.png`);a=await kn(`${o}/reply`,{method:"POST",body:c},3e4)}else a=await kn(`${o}/reply`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({threadId:e,reply:t,color:r,provider:n,model:i,sourceId:l})},3e4);if(!a.ok){let c=await a.text();throw new Error(`Bridge returned ${a.status}: ${c}`)}return a.json()}var As=typeof crypto!="undefined"&&typeof crypto.randomUUID=="function"?crypto.randomUUID():Math.random().toString(36).slice(2);function Br(){return As}var Ia={isConnected:!1,status:"disconnected",jobResponses:{},jobThinking:{},activeJobIds:[],currentResponse:"",currentThinking:"",events:[],activeJobId:null,lastCompletedJobId:null,lastResponseText:null,lastThreadId:null,lastErrorByJob:{},pendingQuestions:[],incrementalResolutions:[],capabilitiesVersion:0},tr=f({},Ia),Pr=new Set,so=null,Ls=null,Yn=null,Is=0,ao=null,lo=null;async function Ra(e){return e&&e!=="http://localhost:1111"?(ao=e,e):ao||lo||(lo=vs(e).then(o=>{var r;return ao=(r=o==null?void 0:o.url)!=null?r:null,lo=null,ao}).catch(()=>(lo=null,null)),lo)}function Ps(){return ao}function Rs(){return tr}function Aa(e){return Pr.add(e),()=>{Pr.delete(e)}}function tn(e){tr=e(tr);for(let t of Pr)t()}function Bs(e){if(so&&so.readyState!==EventSource.CLOSED&&Ls===e)return;so&&(so.close(),so=null),Yn&&(clearTimeout(Yn),Yn=null),Ls=e;let t=++Is,o=new EventSource(`${e}/events?sourceId=${As}`);so=o;let r=()=>t!==Is;o.addEventListener("connected",()=>{r()||er(e).then(n=>{var d,u;if(r())return;let i=(d=n==null?void 0:n.activeJobs)!=null?d:n!=null&&n.activeJob?[n.activeJob]:[],s=new Set(i.map(p=>p.id)),l=(u=n==null?void 0:n.recentJobs)!=null?u:[],a=new Map(l.map(p=>[p.id,p])),c=i.length>0;tn(p=>{let g=f({},p.lastErrorByJob),S=p.activeJobIds.filter(b=>!s.has(b));for(let b of S){let w=a.get(b);(w==null?void 0:w.status)==="error"&&w.error&&(g[b]=w.error)}let v=p.activeJobIds.filter(b=>s.has(b));for(let b of s)v.includes(b)||v.push(b);return h(f({},p),{isConnected:!0,status:c?"streaming":S.length>0||p.status==="disconnected"?"idle":p.status,activeJobId:c?i[i.length-1].id:v.length>0?v[v.length-1]:null,activeJobIds:v,lastErrorByJob:g,lastCompletedJobId:S.length>0?S[S.length-1]:p.lastCompletedJobId})})})}),o.addEventListener("job_started",n=>{if(r())return;let i=JSON.parse(n.data),s=i.jobId;tn(l=>h(f({},l),{status:"streaming",activeJobId:s,activeJobIds:[...l.activeJobIds,s],jobResponses:h(f({},l.jobResponses),{[s]:""}),jobThinking:h(f({},l.jobThinking),{[s]:""}),currentResponse:"",currentThinking:"",lastResponseText:null,lastThreadId:null,events:[...l.events,{type:"job_started",data:i,timestamp:Date.now()}]}))}),o.addEventListener("delta",n=>{if(r())return;let i=JSON.parse(n.data),s=i.jobId,l=i.text||"";tn(a=>h(f({},a),{jobResponses:s?h(f({},a.jobResponses),{[s]:(a.jobResponses[s]||"")+l}):a.jobResponses,currentResponse:!s||s===a.activeJobId?a.currentResponse+l:a.currentResponse,events:[...a.events,{type:"delta",data:i,timestamp:Date.now()}]}))}),o.addEventListener("thinking",n=>{if(r())return;let i=JSON.parse(n.data),s=i.jobId,l=i.text||"";tn(a=>h(f({},a),{jobThinking:s?h(f({},a.jobThinking),{[s]:(a.jobThinking[s]||"")+l}):a.jobThinking,currentThinking:!s||s===a.activeJobId?a.currentThinking+l:a.currentThinking,events:[...a.events,{type:"thinking",data:i,timestamp:Date.now()}]}))}),o.addEventListener("tool_use",n=>{if(r())return;let i=JSON.parse(n.data);tn(s=>h(f({},s),{events:[...s.events,{type:"tool_use",data:i,timestamp:Date.now()}]}))}),o.addEventListener("done",n=>{if(r())return;let i=JSON.parse(n.data),s=i.jobId;tn(l=>{var g;let a=s?l.activeJobIds.filter(S=>S!==s):l.activeJobIds,c=f({},l.jobResponses),d=f({},l.jobThinking),u=s?c[s]:void 0;s&&(delete c[s],delete d[s]);let p=s===l.activeJobId?a.length>0?a[a.length-1]:null:l.activeJobId;return h(f(h(f({},l),{activeJobIds:a,activeJobId:p,jobResponses:c,jobThinking:d,lastCompletedJobId:s!=null?s:l.activeJobId,lastResponseText:u||l.currentResponse||i.responseText||null,lastThreadId:(g=i.threadId)!=null?g:null}),s===l.activeJobId?{currentResponse:p&&c[p]||"",currentThinking:p&&d[p]||""}:{}),{events:[...l.events,{type:"done",data:i,timestamp:Date.now()}]})})}),o.addEventListener("question",n=>{if(r())return;let i=JSON.parse(n.data);tn(s=>h(f({},s),{pendingQuestions:[...s.pendingQuestions,{jobId:i.jobId,threadId:i.threadId,question:i.question,annotationIds:i.annotationIds,timestamp:Date.now()}],events:[...s.events,{type:"question",data:i,timestamp:Date.now()}]}))}),o.addEventListener("capabilities_changed",()=>{r()||tn(n=>h(f({},n),{capabilitiesVersion:n.capabilitiesVersion+1}))}),o.addEventListener("queue_drained",()=>{r()||tn(n=>h(f({},n),{status:n.status==="error"?"error":"idle",activeJobId:null,activeJobIds:[],currentResponse:"",currentThinking:"",jobResponses:{},jobThinking:{},lastErrorByJob:{},incrementalResolutions:[]}))}),o.addEventListener("error",n=>{var i,s;if(!r()){if(o.readyState===EventSource.CLOSED)tn(l=>h(f({},l),{isConnected:!1,status:"disconnected"})),Yn&&(clearTimeout(Yn),Yn=null),Yn=setTimeout(()=>{er(e).then(l=>{l&&Bs(e)})},5e3);else if(n instanceof MessageEvent){let l=JSON.parse(n.data),a=(i=l.jobId)!=null?i:null,c=(s=l.message)!=null?s:"";tn(d=>{let u=a?d.activeJobIds.filter(g=>g!==a):d.activeJobIds,p=u.length>0?d.status:"error";return h(f({},d),{status:p,activeJobIds:u,lastCompletedJobId:a!=null?a:d.activeJobId,lastErrorByJob:a&&c?h(f({},d.lastErrorByJob),{[a]:c}):d.lastErrorByJob,events:[...d.events,{type:"error",data:l,timestamp:Date.now()}]})})}}}),o.onerror=()=>{r()||o.readyState===EventSource.CLOSED&&tn(n=>h(f({},n),{isConnected:!1,status:"disconnected"}))}}function Os(e="http://localhost:1111"){let t=La(Aa,Rs,Rs);Ta(()=>{Ra(e).then(n=>{n&&er(n).then(i=>{i&&Bs(n)})})},[e]);let o=Ts(()=>{tn(()=>h(f({},tr),{events:[],currentResponse:"",currentThinking:"",jobResponses:{},jobThinking:{},lastResponseText:null,lastThreadId:null,lastErrorByJob:{},incrementalResolutions:[]}))},[]),r=Ts(n=>{tn(i=>h(f({},i),{pendingQuestions:i.pendingQuestions.filter(s=>s.threadId!==n)}))},[]);return h(f({},t),{clearEvents:o,dismissQuestion:r})}import{useEffect as Pa,useReducer as Ba}from"react";var Oa={isAnnotating:!1,activeTool:"inspector",activeColor:"#ff0000",strokeWidth:3,annotations:[],undoStack:[],redoStack:[],currentPath:[],selectedAnnotationIds:[],lastSelectedId:null,inspectedElement:null,styleModifications:[],spacingTokenChanges:[],spacingTokenMods:[]};function nr(){return Math.random().toString(36).substring(2,9)}function Ds(e){return e.status?e:e.captured?h(f({},e),{status:"in_flight"}):h(f({},e),{status:"pending"})}function Zt(e){return h(f({},e),{undoStack:[...e.undoStack,{annotations:e.annotations,styleModifications:e.styleModifications,spacingTokenMods:e.spacingTokenMods}],redoStack:[]})}function Da(e,t){return h(f({},e),{isAnnotating:t})}function Ha(e,t){return h(f({},e),{activeTool:t,inspectedElement:null})}function Fa(e,t){return h(f({},e),{activeColor:t})}function Na(e,t){return h(f({},e),{strokeWidth:t})}function _a(e,t){return h(f({},e),{currentPath:[t]})}function za(e,t){return h(f({},e),{currentPath:[...e.currentPath,t]})}function $a(e){return h(f({},e),{currentPath:[]})}function Wa(e,t){if(e.currentPath.length<2&&e.activeTool!=="text")return h(f({},e),{currentPath:[]});let o={id:nr(),type:e.activeTool,points:e.currentPath,color:e.activeColor,strokeWidth:e.strokeWidth,timestamp:Date.now(),status:"pending",groupId:t==null?void 0:t.groupId,elements:t==null?void 0:t.elements},r=Zt(e);return h(f({},r),{annotations:[...e.annotations,o],currentPath:[]})}function Ya(e,t){var n;let o=f({id:(n=t.id)!=null?n:nr(),type:"text",points:[t.point],text:t.text,fontSize:t.fontSize||12,color:e.activeColor,strokeWidth:e.strokeWidth,timestamp:Date.now(),status:"pending",groupId:t.groupId,linkedSelector:t.linkedSelector,linkedAnchor:t.linkedAnchor,elements:t.elements},t.imageCount?{imageCount:t.imageCount}:{}),r=t.groupId?e:Zt(e);return h(f({},r),{annotations:[...e.annotations,o]})}function ja(e,t){let o=Zt(e);return h(f({},o),{annotations:e.annotations.map(r=>r.id===t.id?f(h(f({},r),{text:t.text}),t.imageCount!=null?{imageCount:t.imageCount}:{}):r)})}function Ga(e,t){return h(f({},e),{annotations:e.annotations.map(o=>o.id===t.id?h(f({},o),{fontSize:Math.max(12,Math.min(72,t.fontSize))}):o)})}function Va(e,t){let o=Zt(e),r=e.annotations.find(i=>i.id===t.id),n=r==null?void 0:r.groupId;return h(f({},o),{annotations:e.annotations.filter(i=>i.id!==t.id&&!(n&&i.groupId===n))})}function Ua(e,t){let o=t.saveUndo?Zt(e):e,r=e.annotations.find(i=>i.id===t.id),n=r==null?void 0:r.groupId;return h(f({},o),{annotations:e.annotations.map(i=>{if(!(i.id===t.id||n&&i.groupId===n))return i;let l=t.delta.x,a=t.delta.y;return h(f({},i),{points:i.points.map(c=>({x:c.x+l,y:c.y+a}))})})})}function Ja(e,t){let o=t.saveUndo?Zt(e):e,r=e.annotations.find(s=>s.id===t.id);if(!r||r.type==="text"||r.points.length<2)return e;let n=0,i=0;if(r.type==="rectangle"&&r.groupId){let s=t.points,l=Math.min(s[0].x,s[1].x),a=Math.max(s[0].y,s[1].y),c=r.points[0],d=r.points[r.points.length-1],u=Math.min(c.x,d.x),p=Math.max(c.y,d.y);n=l-u,i=a-p}return h(f({},o),{annotations:e.annotations.map(s=>s.id===t.id?h(f({},s),{points:t.points}):r.groupId&&s.groupId===r.groupId&&s.type==="text"?h(f({},s),{points:s.points.map(l=>({x:l.x+n,y:l.y+i}))}):s)})}function Xa(e,t){let o=Zt(e);return h(f({},o),{annotations:[...e.annotations,...t.annotations.map(Ds)]})}function Ka(e,t){let o=new Set,r=[];for(let n of t.annotations)o.has(n.id)||(o.add(n.id),r.push(Ds(n)));return h(f({},e),{annotations:r})}function Za(e){if(e.undoStack.length===0)return e;let t=e.undoStack[e.undoStack.length-1];return h(f({},e),{annotations:(t==null?void 0:t.annotations)||[],styleModifications:(t==null?void 0:t.styleModifications)||[],spacingTokenMods:(t==null?void 0:t.spacingTokenMods)||[],undoStack:e.undoStack.slice(0,-1),redoStack:[...e.redoStack,{annotations:e.annotations,styleModifications:e.styleModifications,spacingTokenMods:e.spacingTokenMods}]})}function qa(e){if(e.redoStack.length===0)return e;let t=e.redoStack[e.redoStack.length-1];return h(f({},e),{annotations:(t==null?void 0:t.annotations)||[],styleModifications:(t==null?void 0:t.styleModifications)||[],spacingTokenMods:(t==null?void 0:t.spacingTokenMods)||[],redoStack:e.redoStack.slice(0,-1),undoStack:[...e.undoStack,{annotations:e.annotations,styleModifications:e.styleModifications,spacingTokenMods:e.spacingTokenMods}]})}function Qa(e,t){let{id:o,addToSelection:r}=t;if(o===null)return h(f({},e),{selectedAnnotationIds:[],lastSelectedId:null});if(r)if(e.selectedAnnotationIds.includes(o)){let i=e.selectedAnnotationIds.filter(s=>s!==o);return h(f({},e),{selectedAnnotationIds:i,lastSelectedId:i.length>0?i[i.length-1]:null})}else return h(f({},e),{selectedAnnotationIds:[...e.selectedAnnotationIds,o],lastSelectedId:o});return h(f({},e),{selectedAnnotationIds:[o],lastSelectedId:o})}function ec(e,t){let o=new Set;for(let r of e.selectedAnnotationIds){let n=e.annotations.find(i=>i.id===r);n!=null&&n.groupId&&o.add(n.groupId)}return h(f({},e),{annotations:e.annotations.map(r=>{let n=e.selectedAnnotationIds.includes(r.id),i=r.groupId&&o.has(r.groupId);return!n&&!i?r:h(f({},r),{color:t.color})})})}function tc(e){return h(f({},e),{annotations:e.annotations.map(t=>h(f({},t),{captured:!0,status:t.status==="pending"||!t.status?"in_flight":t.status})),styleModifications:e.styleModifications.map(t=>h(f({},t),{captured:!0})),spacingTokenChanges:e.spacingTokenChanges.map(t=>h(f({},t),{captured:!0}))})}function nc(e){return h(f({},e),{annotations:[],undoStack:[],redoStack:[],currentPath:[],selectedAnnotationIds:[],lastSelectedId:null,spacingTokenChanges:[],spacingTokenMods:[]})}function oc(e,t){return h(f({},e),{inspectedElement:t})}function rc(e,t){let{selector:o,element:r,property:n,original:i,modified:s}=t,l=e.styleModifications.findIndex(a=>a.selector===o);if(i===s&&l<0)return e;if(l>=0){let a=e.styleModifications[l];if(a.captured){let g=Zt(e),S=g.styleModifications.map((v,b)=>b===l?h(f({},v),{changes:[{property:n,original:i,modified:s}],captured:!1}):v);return h(f({},g),{styleModifications:S})}let c=a.changes.findIndex(g=>g.property===n),d,u=e;if(c>=0){let g=a.changes[c];s===g.original?d=a.changes.filter((S,v)=>v!==c):d=a.changes.map((S,v)=>v===c?h(f({},S),{modified:s}):S)}else{if(i===s)return e;u=Zt(e),d=[...a.changes,{property:n,original:i,modified:s}]}if(d.length===0)return h(f({},u),{styleModifications:u.styleModifications.filter((g,S)=>S!==l)});let p=u.styleModifications.map((g,S)=>S===l?h(f({},g),{changes:d}):g);return h(f({},u),{styleModifications:p})}else{let a=Zt(e),c={selector:o,element:r,changes:[{property:n,original:i,modified:s}]};return h(f({},a),{styleModifications:[...a.styleModifications,c]})}}function ic(e,t){let{selector:o,durableSelector:r,element:n,changes:i}=t,s=i.filter(c=>c.original!==c.modified);if(s.length===0)return e;let l=Zt(e),a=l.styleModifications.findIndex(c=>c.selector===o);if(a>=0){let c=l.styleModifications[a],d=c.captured?[]:[...c.changes];for(let u of s){let p=d.findIndex(g=>g.property===u.property);p>=0?u.modified===d[p].original?d=d.filter((g,S)=>S!==p):d=d.map((g,S)=>S===p?h(f({},g),{modified:u.modified}):g):d.push(u)}return d.length===0?h(f({},l),{styleModifications:l.styleModifications.filter((u,p)=>p!==a)}):h(f({},l),{styleModifications:l.styleModifications.map((u,p)=>p===a?h(f({},u),{changes:d,captured:!1}):u)})}else return h(f({},l),{styleModifications:[...l.styleModifications,{selector:o,durableSelector:r,element:n,changes:s}]})}function sc(e,t){let{selector:o,property:r}=t,n=Zt(e),i=n.styleModifications.map(s=>s.selector!==o?s:h(f({},s),{changes:s.changes.filter(l=>l.property!==r)})).filter(s=>s.changes.length>0);return h(f({},n),{styleModifications:i})}function lc(e){if(e.styleModifications.length===0)return h(f({},e),{inspectedElement:null});let t=Zt(e);return h(f({},t),{styleModifications:[],inspectedElement:null})}function ac(e,t){return h(f({},e),{styleModifications:t})}function cc(e,t){let{updates:o}=t,r=new Map(o.map(n=>[n.id,n]));return h(f({},e),{annotations:e.annotations.map(n=>{let i=r.get(n.id);return i?f(h(f({},n),{points:[i.point,...n.points.slice(1)]}),i.linkedAnchor?{linkedAnchor:i.linkedAnchor}:{}):n})})}function dc(e,t){let o=new Set(t.ids);return h(f({},e),{annotations:e.annotations.map(r=>o.has(r.id)?h(f({},r),{status:t.status}):r)})}function uc(e,t){let o=new Set(t.ids),r=new Set;for(let n of e.annotations)o.has(n.id)&&n.groupId&&r.add(n.groupId);return h(f({},e),{annotations:e.annotations.map(n=>o.has(n.id)||n.groupId&&r.has(n.groupId)?h(f({},n),{threadId:t.threadId}):n)})}function pc(e,t){let o=new Set(t.ids),r=new Set;for(let n of e.annotations)o.has(n.id)&&n.groupId&&r.add(n.groupId);return h(f({},e),{annotations:e.annotations.map(n=>o.has(n.id)||n.groupId&&r.has(n.groupId)?h(f({},n),{status:"waiting_input",question:t.question,threadId:t.threadId}):n)})}function fc(e,t){let o=new Map(t.resolutions.map(n=>[n.annotationId,n])),r=new Map;for(let n of e.annotations){let i=o.get(n.id);i&&n.groupId&&r.set(n.groupId,i)}return h(f({},e),{annotations:e.annotations.map(n=>{var s,l,a;let i=o.get(n.id)||(n.groupId?r.get(n.groupId):void 0);return i?h(f({},n),{status:i.status,resolutionSummary:i.summary,scope:(l=(s=i.finalScope)!=null?s:i.inferredScope)!=null?l:null,replyCount:((a=n.replyCount)!=null?a:0)+1,question:void 0,threadId:n.threadId||t.threadId}):n})})}function gc(e,t){let{linkedSelectors:o,styleSelectors:r}=t,n=new Set(o),i=new Set(r),s=new Set,l=new Set;for(let p of e.annotations)p.linkedSelector&&n.has(p.linkedSelector)&&(s.add(p.id),p.groupId&&l.add(p.groupId));for(let p of e.annotations)p.groupId&&l.has(p.groupId)&&s.add(p.id);let a=e.annotations.filter(p=>!s.has(p.id)),c=e.styleModifications.filter(p=>!i.has(p.selector));if(a.length===e.annotations.length&&c.length===e.styleModifications.length)return e;let d=e.selectedAnnotationIds.filter(p=>!s.has(p)),u=e.inspectedElement&&i.has(e.inspectedElement.info.selector)?null:e.inspectedElement;return h(f({},e),{annotations:a,styleModifications:c,selectedAnnotationIds:d,lastSelectedId:d.length>0?d[d.length-1]:null,inspectedElement:u})}function mc(e,t){let o=e.spacingTokenChanges.findIndex(r=>r.tokenPath===t.tokenPath);return o>=0?h(f({},e),{spacingTokenChanges:e.spacingTokenChanges.map((r,n)=>n===o?t:r)}):h(f({},e),{spacingTokenChanges:[...e.spacingTokenChanges,t]})}function hc(e,t){return h(f({},e),{spacingTokenChanges:t})}function yc(e,t){let o=Zt(e),r=e.spacingTokenMods.findIndex(i=>i.tokenPath===t.tokenPath),n;if(r>=0){let i=e.spacingTokenMods[r],s=h(f({},t),{originalValue:i.originalValue,originalPx:i.originalPx});n=e.spacingTokenMods.map((l,a)=>a===r?s:l)}else n=[...e.spacingTokenMods,t];return h(f({},o),{spacingTokenMods:n})}function bc(e,t){let o=Zt(e),r=e.spacingTokenMods.findIndex(a=>a.tokenPath===t.tokenPath),n=r>=0?e.spacingTokenMods[r].originalValue:t.originalValue,i=r>=0?e.spacingTokenMods[r].originalPx:parseFloat(t.originalValue)||0,s={tokenPath:t.tokenPath,originalValue:n,currentValue:"__deleted__",targets:r>=0?e.spacingTokenMods[r].targets:[],originalPx:i,currentPx:0},l;return r>=0?l=e.spacingTokenMods.map((a,c)=>c===r?s:a):l=[...e.spacingTokenMods,s],h(f({},o),{spacingTokenMods:l})}var xc={SET_ANNOTATING:Da,SET_TOOL:Ha,SET_COLOR:Fa,SET_STROKE_WIDTH:Na,START_PATH:_a,CONTINUE_PATH:za,CANCEL_PATH:$a,FINISH_PATH:Wa,ADD_TEXT:Ya,UPDATE_TEXT:ja,UPDATE_TEXT_SIZE:Ga,DELETE_ANNOTATION:Va,MOVE_ANNOTATION:Ua,RESIZE_ANNOTATION:Ja,PASTE_ANNOTATIONS:Xa,RESTORE_ANNOTATIONS:Ka,UNDO:Za,REDO:qa,SELECT_ANNOTATION:Qa,UPDATE_ANNOTATION_COLOR:ec,MARK_CAPTURED:tc,CLEAR:nc,SELECT_ELEMENT:oc,MODIFY_STYLE:rc,MODIFY_STYLES_BATCH:ic,CLEAR_STYLE:sc,CLEAR_ALL_STYLES:lc,RESTORE_STYLE_MODIFICATIONS:ac,UPDATE_LINKED_POSITIONS:cc,CLEANUP_ORPHANED:gc,SET_ANNOTATION_STATUS:dc,SET_ANNOTATION_THREAD:uc,SET_ANNOTATION_QUESTION:pc,APPLY_RESOLUTIONS:fc,ADD_SPACING_TOKEN_CHANGE:mc,RESTORE_SPACING_TOKEN_CHANGES:hc,MODIFY_SPACING_TOKEN:yc,DELETE_SPACING_TOKEN:bc};function vc(e,t){let o=xc[t.type];return o?o(e,t.payload):e}function Hs(){let[e,t]=Ba(vc,Oa);return Pa(()=>{let o=r=>{(r.metaKey||r.ctrlKey)&&r.key==="z"&&(r.preventDefault(),r.shiftKey?t({type:"REDO"}):t({type:"UNDO"}))};return window.addEventListener("keydown",o),()=>window.removeEventListener("keydown",o)},[]),[e,t]}import{domToCanvas as Sc}from"modern-screenshot";function Or(e){let t=document.createElement("canvas").getContext("2d");return t?(t.fillStyle=e,t.fillStyle):"#888888"}function Dr(e,t=[],o,r){let n=new Map,i=[];for(let l of e)if(l.groupId){let a=n.get(l.groupId)||[];a.push(l),n.set(l.groupId,a)}else i.push(l);let s=[];for(let[l,a]of n){let c=a.find(u=>u.type!=="text"),d=a.find(u=>u.type==="text");if(c){let u=c.linkedSelector||(d==null?void 0:d.linkedSelector),p=(d==null?void 0:d.imageCount)||c.imageCount;s.push(f(h(f({id:c.id,type:c.type,instruction:d==null?void 0:d.text},u?{linkedSelector:u}:{}),{elements:c.elements||[]}),p?{imageCount:p}:{}))}}for(let l of i)s.push(f(h(f({id:l.id,type:l.type,instruction:l.type==="text"?l.text:void 0},l.linkedSelector?{linkedSelector:l.linkedSelector}:{}),{elements:l.elements||[]}),l.imageCount?{imageCount:l.imageCount}:{}));return f(f({timestamp:new Date().toISOString(),url:window.location.href,viewport:{width:window.innerWidth,height:window.innerHeight},scrollPosition:{x:window.scrollX,y:window.scrollY},annotations:s,styleModifications:t},o?{inspectedElement:o}:{}),r&&r.length>0?{spacingTokenChanges:r}:{})}function wc(e){if(!e.points||e.points.length===0)return null;let t=e.points.map(r=>r.x),o=e.points.map(r=>r.y);return{minX:Math.min(...t),minY:Math.min(...o),maxX:Math.max(...t),maxY:Math.max(...o)}}function Ec(e,t){if(e.length===0)return[];let o=e.map(d=>({annotation:d,bounds:wc(d)})).filter(d=>d.bounds!==null);if(o.length===0)return[];o.sort((d,u)=>d.bounds.minY-u.bounds.minY);let r=Math.min(...o.map(d=>d.bounds.minY)),n=Math.max(...o.map(d=>d.bounds.maxY));if(n-r<=t){let d=(r+n)/2,u=Math.max(0,d-t/2);return[{top:u,bottom:u+t,annotations:e}]}let i=[],s=50,l=Math.max(0,r-s),a=[],c=l;for(let{annotation:d,bounds:u}of o){let p=u.maxY+s;if(p-l<=t)a.push(d),c=Math.max(c,p);else{if(a.length>0){let g=(l+c)/2,S=Math.max(0,g-t/2);i.push({top:S,bottom:S+t,annotations:a})}l=Math.max(0,u.minY-s),a=[d],c=u.maxY+s}}if(a.length>0){let d=(l+c)/2,u=Math.max(0,d-t/2);i.push({top:u,bottom:u+t,annotations:a})}return i}function kc(e,t,o,r){e.save(),e.scale(r,r);for(let n of t){let i=n.points.map(s=>({x:s.x,y:s.y-o}));switch(e.strokeStyle=n.color,e.fillStyle=n.color,e.lineWidth=n.strokeWidth,e.lineCap="round",e.lineJoin="round",n.type){case"freehand":if(i.length<2)break;e.beginPath(),e.moveTo(i[0].x,i[0].y);for(let s=1;s<i.length;s++)e.lineTo(i[s].x,i[s].y);e.stroke();break;case"line":if(i.length<2)break;e.beginPath(),e.moveTo(i[0].x,i[0].y),e.lineTo(i[i.length-1].x,i[i.length-1].y),e.stroke();break;case"rectangle":{if(i.length<2)break;let s=i[0],l=i[i.length-1],a=Math.min(s.x,l.x),c=Math.min(s.y,l.y),d=Math.abs(l.x-s.x),u=Math.abs(l.y-s.y);e.strokeRect(a,c,d,u);break}case"circle":{if(i.length<2)break;let s=i[0],l=i[i.length-1],a=(s.x+l.x)/2,c=(s.y+l.y)/2,d=Math.abs(l.x-s.x)/2,u=Math.abs(l.y-s.y)/2;e.beginPath(),e.ellipse(a,c,d,u,0,0,Math.PI*2),e.stroke();break}case"text":{if(!n.text||i.length<1)break;let s=i[0],l=n.fontSize||16;e.font=`${l}px -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif`,e.fillStyle=n.color;let c=(n.imageCount&&n.imageCount>0?`[${n.imageCount} image${n.imageCount>1?"s":""}] ${n.text}`:n.text).split(`
3
- `),d=l*1.2,u=4,p=0;for(let g of c)p=Math.max(p,e.measureText(g).width);e.fillRect(s.x-u,s.y-u,p+u*2,c.length*d+u*2),e.fillStyle="#ffffff",c.forEach((g,S)=>{e.fillText(g,s.x,s.y+l+S*d)});break}}}e.restore()}async function Hr(e,t,o=[]){try{let r=window.devicePixelRatio||1,n=window.innerWidth,i=window.innerHeight,s=o.filter(c=>{var d;return((d=c.status)!=null?d:"pending")==="pending"});console.log("[Screenshot] Starting capture with",s.length,"active annotations (filtered",o.length-s.length,"captured)");let l=Ec(s,i);if(l.length===0){let c=await Fs(e,[],window.scrollY,n,i,r);return c?[c]:[]}let a=[];for(let c=0;c<l.length;c++){let d=l[c],u=await Fs(e,d.annotations,d.top,n,i,r);u?a.push(u):console.warn(`[Screenshot] Region ${c+1} failed to capture`)}return console.log("[Screenshot] Capture complete"),a}catch(r){return console.error("[Screenshot] Capture failed:",r),[]}}async function Fs(e,t,o,r,n,i){try{let s=await Sc(e,{filter:c=>!(c instanceof HTMLElement&&(c.id==="devtools-canvas"||c.id==="devtools-toolbar"||c.id==="devtools-scrim"||c.dataset.devtools!==void 0)),scale:i,backgroundColor:"#ffffff",width:r,height:n,style:{transform:`translate(${-window.scrollX}px, ${-o}px)`}}),l=document.createElement("canvas");l.width=r*i,l.height=n*i;let a=l.getContext("2d");return a?(a.drawImage(s,0,0,r*i,n*i,0,0,r*i,n*i),kc(a,t,o,i),new Promise(c=>{l.toBlob(d=>c(d),"image/png")})):null}catch(s){return console.error("Region capture failed:",s),null}}async function Fr(e){if(e.length===0)return null;if(e.length===1)return e[0];let t=await Promise.all(e.map(l=>new Promise((a,c)=>{let d=new Image;d.onload=()=>a(d),d.onerror=c,d.src=URL.createObjectURL(l)}))),o=t[0].width,r=t.reduce((l,a)=>l+a.height,0),n=document.createElement("canvas");n.width=o,n.height=r;let i=n.getContext("2d");if(!i)return null;let s=0;for(let l of t)i.drawImage(l,0,s),s+=l.height,URL.revokeObjectURL(l.src);return new Promise(l=>{n.toBlob(a=>l(a),"image/png")})}async function Ns(e,t,o){try{let r=Array.isArray(e)?e:[e];if(r.length===0)return!1;let n=await Fr(r);if(!n)return!1;let i={"image/png":n},s=t&&t.length>0,l=o&&o.length>0;if(s||l){let a=t?t.filter(c=>{var d;return((d=c.status)!=null?d:"pending")==="pending"}):[];if(a.length>0||l){let c=Dr(a,o||[]),d=new Blob([JSON.stringify(c,null,2)],{type:"text/plain"});i["text/plain"]=d}}return await navigator.clipboard.write([new ClipboardItem(i)]),!0}catch(r){return console.warn("Clipboard write failed:",r),!1}}import{useCallback as Pt,useEffect as Vt,useMemo as Li,useRef as Ct,useState as it}from"react";import{useCallback as uo,useRef as Mc}from"react";function Nr(e,t,o,r){if(t.length<2)return;let n=t[0],i=t[t.length-1];if(!n||!i)return;let s=(n.x+i.x)/2,l=(n.y+i.y)/2,a=Math.abs(i.x-n.x)/2,c=Math.abs(i.y-n.y)/2;e.beginPath(),e.strokeStyle=o,e.lineWidth=r,e.ellipse(s,l,a,c,0,0,Math.PI*2),e.stroke()}function _r(e,t,o,r){if(t.length<2)return;let n=t[0],i=t[t.length-1];if(!(!n||!i)){e.beginPath(),e.strokeStyle=o,e.lineWidth=r,e.lineCap="round",e.lineJoin="round",e.moveTo(n.x,n.y);for(let s=1;s<t.length-1;s++){let l=t[s],a=t[s+1];if(!l||!a)continue;let c=(l.x+a.x)/2,d=(l.y+a.y)/2;e.quadraticCurveTo(l.x,l.y,c,d)}e.lineTo(i.x,i.y),e.stroke()}}function zr(e,t,o,r){if(t.length<2)return;let n=t[0],i=t[t.length-1];!n||!i||(e.beginPath(),e.strokeStyle=o,e.lineWidth=r,e.lineCap="round",e.moveTo(n.x,n.y),e.lineTo(i.x,i.y),e.stroke())}function $r(e,t,o,r){if(t.length<2)return;let n=t[0],i=t[t.length-1];if(!n||!i)return;let s=Math.min(n.x,i.x),l=Math.min(n.y,i.y),a=Math.abs(i.x-n.x),c=Math.abs(i.y-n.y);e.beginPath(),e.strokeStyle=o,e.lineWidth=r,e.lineCap="round",e.lineJoin="round",e.strokeRect(s,l,a,c)}var Wt='"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace';function Cc(e,t,o){if(!t||e.measureText(t).width<=o)return[t];let r=t.split(/\s+/),n=[],i="";for(let s of r){let l=i?i+" "+s:s;i&&e.measureText(l).width>o?(n.push(i),i=s):i=l}return i&&n.push(i),n.length>0?n:[t]}function co(e){let t=window.innerWidth-e-16;if(t<400)return Math.max(60,t)}function jn(e,t,o){let r=[];for(let n of t)r.push(...Cc(e,n,o));return r}function _s(e,t,o,r,n=12,i,s){if(!o)return;let l=n*1.4,a=o.split(`
4
- `),c=i!==void 0?[i+". "+(a[0]||""),...a.slice(1)]:a;e.font=`${n}px ${Wt}`,e.textBaseline="middle";let d=s!==void 0?Math.min(400,Math.max(60,window.innerWidth-s-16)):400,u=jn(e,c,d),p=Math.min(d,Math.max(...u.map(w=>e.measureText(w).width))),g=u.length*l,S=c.length*l,v=g-S,b=t.y-v;e.fillStyle=r,e.fillRect(t.x-4,b-4,p+8,g+8),e.fillStyle="#ffffff",u.forEach((w,O)=>{e.fillText(w,t.x,b+O*l+l/2)})}var zs=11,Wr=4,Tc=`600 ${zs}px system-ui, -apple-system, sans-serif`;function Yr(e,t,o){return e.map(r=>({x:r.x-t,y:r.y-o}))}function Lc(e,t,o,r,n,i){let s=String(r);e.font=Tc;let a=e.measureText(s).width+Wr*2,c=zs+Wr*2,d=t-a/2,u=o+i/2+2;e.fillStyle=n,e.fillRect(d,u,a,c),e.fillStyle="#ffffff",e.textBaseline="middle",e.fillText(s,d+Wr,u+c/2)}function Ic(e,t){if(e.points.length<2&&e.type!=="text")return null;switch(e.type){case"rectangle":case"freehand":{let o,r;if(e.type==="freehand")o=Math.min(...e.points.map(n=>n.x)),r=Math.max(...e.points.map(n=>n.y));else{let n=e.points[0],i=e.points[e.points.length-1];o=Math.min(n.x,i.x),r=Math.max(n.y,i.y)}return{x:o,y:r}}case"circle":{let o=e.points[0],r=e.points[e.points.length-1],n=Math.min(o.x,r.x),i=(Math.min(o.y,r.y)+Math.max(o.y,r.y))/2;return{x:n,y:i}}case"line":{let o=e.points[0],r=e.points[e.points.length-1],n=o.y>r.y?o:r;return{x:n.x,y:n.y}}default:return null}}function $s(){let e=Mc(null),t=uo(()=>{let l=e.current;if(!l)return;let a=l.getContext("2d");a&&a.clearRect(0,0,l.width,l.height)},[]),o=uo((l,a,c)=>{var S;let d=e.current;if(!d)return;let u=d.getContext("2d");if(!u)return;let g=((S=l.status)!=null?S:l.captured?"in_flight":"pending")==="pending"||c?l.color:"#999999";switch(l.type){case"freehand":_r(u,l.points,g,l.strokeWidth);break;case"line":zr(u,l.points,g,l.strokeWidth);break;case"rectangle":$r(u,l.points,g,l.strokeWidth);break;case"circle":Nr(u,l.points,g,l.strokeWidth);break;case"text":l.text&&l.points[0]&&_s(u,l.points[0],l.text,g,l.fontSize,a,l.points[0].x);break}},[]),r=uo((l,a,c,d)=>{let u=e.current;if(!u||l.length<2)return;let p=u.getContext("2d");if(p)switch(a){case"freehand":_r(p,l,c,d);break;case"line":zr(p,l,c,d);break;case"rectangle":$r(p,l,c,d);break;case"circle":Nr(p,l,c,d);break}},[]),n=uo((l,a)=>{let c=e.current;if(!c||l.points.length<2)return;let d=c.getContext("2d");if(d){if(d.fillStyle="#ffffff",d.strokeStyle=l.color,d.lineWidth=1.5,l.type==="line"){let u=l.points[0],p=l.points[l.points.length-1];[u,p].forEach(g=>{d.beginPath(),d.arc(g.x,g.y,a/2,0,Math.PI*2),d.fill(),d.stroke()});return}if(l.type==="circle"){let u=l.points[0],p=l.points[l.points.length-1],g=Math.min(u.x,p.x),S=Math.max(u.x,p.x),v=Math.min(u.y,p.y),b=Math.max(u.y,p.y),w=(g+S)/2,O=(v+b)/2;[{x:w,y:v},{x:w,y:b},{x:g,y:O},{x:S,y:O}].forEach(k=>{d.beginPath(),d.rect(k.x-a/2,k.y-a/2,a,a),d.fill(),d.stroke()});return}if(l.type==="rectangle"||l.type==="freehand"){let u,p,g,S;if(l.type==="freehand")u=Math.min(...l.points.map(b=>b.x)),p=Math.max(...l.points.map(b=>b.x)),g=Math.min(...l.points.map(b=>b.y)),S=Math.max(...l.points.map(b=>b.y));else{let b=l.points[0],w=l.points[l.points.length-1];u=Math.min(b.x,w.x),p=Math.max(b.x,w.x),g=Math.min(b.y,w.y),S=Math.max(b.y,w.y)}[{x:u,y:g},{x:p,y:g},{x:u,y:S},{x:p,y:S}].forEach(b=>{d.beginPath(),d.rect(b.x-a/2,b.y-a/2,a,a),d.fill(),d.stroke()})}}},[]),i=uo((l,a,c,d,u,p,g,S=0,v=0,b,w)=>{var O;if(t(),l.forEach(A=>{var $;let k=h(f({},A),{points:Yr(A.points,S,v)}),E=b==null?void 0:b.get(A.id),I=($=w==null?void 0:w.has(A.id))!=null?$:!1;o(k,E,I)}),a.length>0){let A=Yr(a,S,v);r(A,c,d,u)}if(p&&p.length>0&&g){let A=e.current,k=A==null?void 0:A.getContext("2d");for(let E of p){let I=l.find($=>$.id===E);if(I){let $=h(f({},I),{points:Yr(I.points,S,v)});if(n($,g),k&&I.type!=="text"&&b&&!(I.groupId&&l.some(j=>j.groupId===I.groupId&&j.type==="text"))){let j=b.get(I.id);if(j!==void 0){let T=Ic($,g);if(T){let K=((O=I.status)!=null?O:I.captured?"in_flight":"pending")==="pending"?I.color:"#999999";Lc(k,T.x,T.y,j,K,g)}}}}}}},[t,o,r,n]),s=uo(()=>{let l=e.current;if(!l)return;let a=window.devicePixelRatio||1;l.width=window.innerWidth*a,l.height=window.innerHeight*a;let c=l.getContext("2d");c&&c.scale(a,a)},[]);return{canvasRef:e,clearCanvas:t,drawAnnotation:o,drawCurrentPath:r,redrawAll:i,resizeCanvas:s}}import{useEffect as Rc,useRef as Ac}from"react";function Ws(){let e=Ac({shift:!1,cmd:!1});return Rc(()=>{let t=n=>{n.key==="Shift"&&(e.current.shift=!0),(n.key==="Meta"||n.key==="Control")&&(e.current.cmd=!0)},o=n=>{n.key==="Shift"&&(e.current.shift=!1),(n.key==="Meta"||n.key==="Control")&&(e.current.cmd=!1)},r=()=>{e.current={shift:!1,cmd:!1}};return window.addEventListener("keydown",t,!0),window.addEventListener("keyup",o,!0),window.addEventListener("blur",r),()=>{window.removeEventListener("keydown",t,!0),window.removeEventListener("keyup",o,!0),window.removeEventListener("blur",r)}},[]),e}import{useEffect as Pc}from"react";function Ys(e,t,o,r,n){Pc(()=>{let i=s=>{if(e){if(e.linkedSelector)return;s.preventDefault(),s.stopPropagation();let a=s.deltaY>0?-2:2;t(c=>c?h(f({},c),{fontSize:Math.max(12,Math.min(72,c.fontSize+a))}):null);return}if(!o)return;s.preventDefault();let l=r.find(a=>a.id===o);if(l&&l.type==="text"&&!l.linkedSelector){let a=l.fontSize||12,c=s.deltaY>0?-2:2;n({type:"UPDATE_TEXT_SIZE",payload:{id:o,fontSize:a+c}})}};return window.addEventListener("wheel",i,{passive:!1}),()=>{window.removeEventListener("wheel",i)}},[o,e,r,n,t])}import{useCallback as ol,useEffect as pr,useRef as rl,useState as $o}from"react";function or(e){let t=Object.keys(e).find(n=>n.startsWith("__reactFiber$")||n.startsWith("__reactInternalInstance$"));if(!t)return null;let o=e[t],r=[];for(;o;){let n=o.type,i=(n==null?void 0:n.displayName)||(n==null?void 0:n.name);i&&typeof i=="string"&&/^[A-Z]/.test(i)&&!i.startsWith("_")&&i!=="Fragment"&&r.unshift(i),o=o.return}return r.length>0?{name:r[r.length-1],path:r}:null}function jr(e){let t=Object.keys(e).find(n=>n.startsWith("__reactFiber$")||n.startsWith("__reactInternalInstance$"));if(!t)return[];let o=e[t],r=[];for(;o;){let n=o.type,i=typeof n=="function"||typeof n=="object"?(n==null?void 0:n.displayName)||(n==null?void 0:n.name):null;i&&typeof i=="string"&&/^[A-Z]/.test(i)&&!i.startsWith("_")&&i!=="Fragment"&&r.push({name:i,fiber:o}),o=o.return}return r.reverse(),r}function rr(e){let t=e,o=new Set;for(;t&&!o.has(t);){if(o.add(t),t.stateNode instanceof Element)return t.stateNode;t.child?t=t.child:t=null}return null}function js(e){if(e.id)return`#${e.id}`;let t=e.tagName.toLowerCase(),o=Array.from(e.classList).slice(0,3).join(".");return o?`${t}.${o}`:t}function sn(e){if(e.id&&!e.id.startsWith("radix-")&&!e.id.startsWith(":"))return`#${CSS.escape(e.id)}`;let t=[],o=e;for(;o&&o!==document.documentElement;){let r=o.tagName.toLowerCase();if(o.id&&!o.id.startsWith("radix-")&&!o.id.startsWith(":")){t.unshift(`#${CSS.escape(o.id)}`);break}let n=Array.from(o.classList).filter(s=>!s.startsWith("_")&&s.length<30).slice(0,2);n.length>0&&(r+="."+n.map(s=>CSS.escape(s)).join("."));let i=o.parentElement;if(i){let s=Array.from(i.children).filter(l=>l.tagName===o.tagName);if(s.length>1){let l=s.indexOf(o)+1;r+=`:nth-of-type(${l})`}}t.unshift(r),o=i}return t.join(" > ")}function Jt(e){try{return document.querySelector(e)}catch(t){return null}}function ir(e,t=0){var a;let o=jr(e);if(o.length===0)return null;let r=o.map(c=>c.name),n=o.length-1,i=Math.max(0,Math.min(o.length-1,n-t)),s=o[i],l=(a=rr(s.fiber))!=null?a:e;return{name:s.name,path:r,depthIndex:i,rootElement:l}}function Gs(e,t){var i,s;let o=jr(e),r=t.toLowerCase(),n=-1;for(let l=o.length-1;l>=0;l--){let a=o[l].name;if(a===t){let c=(i=rr(o[l].fiber))!=null?i:e;return{name:t,path:o.map(d=>d.name),depthIndex:l,rootElement:c}}if(n===-1){let c=a.toLowerCase();(c.length>=4&&r.includes(c)||r.length>=4&&c.includes(r))&&(n=l)}}if(n>=0){let l=(s=rr(o[n].fiber))!=null?s:e;return{name:t,path:o.map(a=>a.name),depthIndex:n,rootElement:l}}return null}function po(e){let t=fo(),o=[],r=new Set,n=t.currentNode;for(;n=t.nextNode();){let i=Gs(n,e);i&&!r.has(i.rootElement)&&(r.add(i.rootElement),o.push(i))}return o}function Gr(e){let t=new Map;if(e.size===0)return t;let o=new Set(e),r=fo(),n=new Set,i=r.currentNode;for(;(i=r.nextNode())&&o.size>0;)for(let s of o){let l=Gs(i,s);if(!l||n.has(l.rootElement))continue;n.add(l.rootElement);let a=l.rootElement.getBoundingClientRect();t.set(s,a.top+window.scrollY),o.delete(s);break}for(let s of o)t.set(s,1/0);return t}function fo(){return document.createTreeWalker(document.body,NodeFilter.SHOW_ELEMENT,{acceptNode(e){return e.closest("#devtools-toolbar, #devtools-canvas, #devtools-scrim, [data-popmelt-panel]")?NodeFilter.FILTER_REJECT:NodeFilter.FILTER_ACCEPT}})}function qt(e){let t={selector:js(e),tagName:e.tagName.toLowerCase()};e.id&&(t.id=e.id),e.classList.length>0&&(t.className=Array.from(e.classList).join(" "));let o=Vs(e);o&&o.length>0&&o.length<200&&(t.textContent=o);let r={};for(let s of e.attributes)s.name.startsWith("data-")&&(r[s.name]=s.value);Object.keys(r).length>0&&(t.dataAttributes=r);let n=or(e);n&&(t.reactComponent=n.name);let i=Bc(e);return i&&(t.context=i),t}function Vs(e){let t="";for(let o of e.childNodes)o.nodeType===Node.TEXT_NODE&&(t+=o.textContent||"");return t.trim()}function Gn(e,t){let o=document.elementsFromPoint(e,t);for(let r of o)if(r instanceof HTMLElement&&!(r.id==="devtools-canvas"||r.id==="devtools-toolbar"||r.id==="devtools-scrim")&&!r.closest("#devtools-toolbar")&&!(r.dataset.devtools||r.closest("[data-devtools]"))&&!["html","body"].includes(r.tagName.toLowerCase()))return r;return null}function Bc(e){let t=e.parentElement,o=["section","article","nav","aside","header","footer","main"];for(;t&&t!==document.body;){let r=t.tagName.toLowerCase();if(o.includes(r)&&t.id)return`${r}#${t.id}`;if(t.id&&!t.id.startsWith("radix-")&&!t.id.startsWith(":"))return`${r}#${t.id}`;t=t.parentElement}return null}function Us(e){let t=new Set,o=[],r=window.scrollX,n=window.scrollY,i=[{x:(e.minX+e.maxX)/2,y:(e.minY+e.maxY)/2},{x:e.minX,y:e.minY},{x:e.maxX,y:e.minY},{x:e.minX,y:e.maxY},{x:e.maxX,y:e.maxY}];for(let s of i){let l=s.x-r,a=s.y-n;if(l<0||a<0||l>window.innerWidth||a>window.innerHeight)continue;let c=Gn(l,a);c&&!t.has(c)&&(t.add(c),o.push(qt(c)))}return o.slice(0,3)}function Vr(e){if(e.length===0)return[];let t=e.map(r=>r.x),o=e.map(r=>r.y);return Us({minX:Math.min(...t),minY:Math.min(...o),maxX:Math.max(...t),maxY:Math.max(...o)})}function At(e,t){return e.style.getPropertyValue(t)!==""}function Oc(e,t=30){if(e<=0)return[];let o=[],r=fo(),n=.5,i=r.currentNode;for(;(i=r.nextNode())&&o.length<t;){let s=i,l=s.getBoundingClientRect();if(l.bottom<-50||l.top>window.innerHeight+50||l.right<-50||l.left>window.innerWidth+50||l.width<1||l.height<1)continue;let a=getComputedStyle(s);!At(s,"padding-top")&&Math.abs((parseFloat(a.paddingTop)||0)-e)<n&&o.push({element:s,property:"padding-top"}),!At(s,"padding-bottom")&&Math.abs((parseFloat(a.paddingBottom)||0)-e)<n&&o.length<t&&o.push({element:s,property:"padding-bottom"}),!At(s,"padding-left")&&Math.abs((parseFloat(a.paddingLeft)||0)-e)<n&&o.length<t&&o.push({element:s,property:"padding-left"}),!At(s,"padding-right")&&Math.abs((parseFloat(a.paddingRight)||0)-e)<n&&o.length<t&&o.push({element:s,property:"padding-right"}),!At(s,"margin-top")&&Math.abs((parseFloat(a.marginTop)||0)-e)<n&&o.length<t&&o.push({element:s,property:"margin-top"}),!At(s,"margin-bottom")&&Math.abs((parseFloat(a.marginBottom)||0)-e)<n&&o.length<t&&o.push({element:s,property:"margin-bottom"}),!At(s,"margin-left")&&Math.abs((parseFloat(a.marginLeft)||0)-e)<n&&o.length<t&&o.push({element:s,property:"margin-left"}),!At(s,"margin-right")&&Math.abs((parseFloat(a.marginRight)||0)-e)<n&&o.length<t&&o.push({element:s,property:"margin-right"});let c=a.display;if((c.includes("flex")||c.includes("grid"))&&o.length<t){let d=At(s,"gap"),u=parseFloat(a.gap)||0,p=parseFloat(a.rowGap)||0,g=parseFloat(a.columnGap)||0;!d&&Math.abs(u-e)<n?o.push({element:s,property:"gap"}):!At(s,"row-gap")&&Math.abs(p-e)<n?o.push({element:s,property:"row-gap"}):!At(s,"column-gap")&&Math.abs(g-e)<n&&o.push({element:s,property:"column-gap"})}}return o}function Ur(e,t=30){if(e<=0)return[];let o=[],r=fo(),n=.5,i=r.currentNode;for(;(i=r.nextNode())&&o.length<t;){let s=i,l=s.getBoundingClientRect();if(l.bottom<-50||l.top>window.innerHeight+50||l.right<-50||l.left>window.innerWidth+50||l.width<1||l.height<1)continue;let a=getComputedStyle(s),c=parseFloat(a.borderTopWidth)||0,d=parseFloat(a.borderRightWidth)||0,u=parseFloat(a.borderBottomWidth)||0,p=parseFloat(a.borderLeftWidth)||0,g=s.clientWidth,S=s.clientHeight,v=parseFloat(a.paddingTop)||0;!At(s,"padding-top")&&Math.abs(v-e)<n&&o.push({x:l.left+p,y:l.top+c,width:g,height:e,direction:"vertical",property:"padding-top"});let b=parseFloat(a.paddingBottom)||0;!At(s,"padding-bottom")&&Math.abs(b-e)<n&&o.length<t&&o.push({x:l.left+p,y:l.top+c+S-e,width:g,height:e,direction:"vertical",property:"padding-bottom"});let w=parseFloat(a.paddingLeft)||0;!At(s,"padding-left")&&Math.abs(w-e)<n&&o.length<t&&o.push({x:l.left+p,y:l.top+c,width:e,height:S,direction:"horizontal",property:"padding-left"});let O=parseFloat(a.paddingRight)||0;!At(s,"padding-right")&&Math.abs(O-e)<n&&o.length<t&&o.push({x:l.left+p+g-e,y:l.top+c,width:e,height:S,direction:"horizontal",property:"padding-right"});let A=parseFloat(a.marginTop)||0;!At(s,"margin-top")&&Math.abs(A-e)<n&&o.length<t&&o.push({x:l.left,y:l.top-e,width:l.width,height:e,direction:"vertical",property:"margin-top"});let k=parseFloat(a.marginBottom)||0;!At(s,"margin-bottom")&&Math.abs(k-e)<n&&o.length<t&&o.push({x:l.left,y:l.bottom,width:l.width,height:e,direction:"vertical",property:"margin-bottom"});let E=parseFloat(a.marginLeft)||0;!At(s,"margin-left")&&Math.abs(E-e)<n&&o.length<t&&o.push({x:l.left-e,y:l.top,width:e,height:l.height,direction:"horizontal",property:"margin-left"});let I=parseFloat(a.marginRight)||0;!At(s,"margin-right")&&Math.abs(I-e)<n&&o.length<t&&o.push({x:l.right,y:l.top,width:e,height:l.height,direction:"horizontal",property:"margin-right"});let $=a.display;if(($.includes("flex")||$.includes("grid"))&&o.length<t&&!At(s,"gap")){let j=Array.from(s.children).filter(T=>{let D=getComputedStyle(T);return D.display!=="none"&&D.position!=="absolute"&&D.position!=="fixed"});if(j.length>=2)for(let T=0;T<j.length-1&&o.length<t;T++){let D=j[T].getBoundingClientRect(),K=j[T+1].getBoundingClientRect(),ee=K.top-D.bottom;Math.abs(ee-e)<n&&ee>.5&&o.push({x:Math.min(D.left,K.left),y:D.bottom,width:Math.max(D.right,K.right)-Math.min(D.left,K.left),height:ee,direction:"vertical",property:"gap"});let me=K.left-D.right;Math.abs(me-e)<n&&me>.5&&o.push({x:D.right,y:Math.min(D.top,K.top),width:me,height:Math.max(D.bottom,K.bottom)-Math.min(D.top,K.top),direction:"horizontal",property:"gap"})}}}return o}function sr(e){return typeof e=="string"?{value:e}:e}var Xs={gap:["gap","row-gap","column-gap"],padding:["padding-top","padding-bottom","padding-left","padding-right"],margin:["margin-top","margin-bottom","margin-left","margin-right"]};function Js(e,t){let o=Xs[t];return o?o.includes(e):!1}function Dc(e,t){let o=e.split(/\s+/);for(let r of o){if(r===t)return!0;let n=r.lastIndexOf(":");if(n>=0&&r.slice(n+1)===t)return!0}return!1}function Hc(e){var l,a;let t=e.lastIndexOf(":"),o=t>=0?e.slice(t+1):e,r=o.indexOf("-");if(r<0)return null;let n=o.slice(0,r),i={gap:"gap","gap-x":"column-gap","gap-y":"row-gap",p:"padding",pt:"padding-top",pb:"padding-bottom",pl:"padding-left",pr:"padding-right",px:"padding-left",py:"padding-top",m:"margin",mt:"margin-top",mb:"margin-bottom",ml:"margin-left",mr:"margin-right",mx:"margin-left",my:"margin-top"},s=o.slice(0,o.indexOf("-",r+1)>0?o.indexOf("-",r+1):r);return(a=(l=i[s])!=null?l:i[n])!=null?a:null}function Jr(e,t=30){let o=parseFloat(e.value);if(isNaN(o)||o<=0)return[];if(e.bindings&&e.bindings.length>0){let n=[],i=fo(),s=i.currentNode;for(;(s=i.nextNode())&&n.length<t;){let l=s,a=l.getBoundingClientRect();if(a.bottom<-50||a.top>window.innerHeight+50||a.right<-50||a.left>window.innerWidth+50||a.width<1||a.height<1)continue;let c=l.className;if(typeof c=="string")for(let d of e.bindings){if(!Dc(c,d))continue;let u=Hc(d);if(u&&!(e.property&&!Js(u,e.property))){n.push({element:l,property:u});break}}}return n}let r=Oc(o,t*2);return e.property?r.filter(n=>Js(n.property,e.property)).slice(0,t):r.slice(0,t)}function Xr(e,t=30){let o=Jr(e,t),r=[];for(let n of o){let i=n.element,s=i.getBoundingClientRect(),l=getComputedStyle(i),a=parseFloat(l.borderTopWidth)||0,c=parseFloat(l.borderRightWidth)||0,d=parseFloat(l.borderLeftWidth)||0,u=i.clientWidth,p=i.clientHeight;switch(n.property){case"padding-top":{let g=parseFloat(l.paddingTop)||0;r.push({x:s.left+d,y:s.top+a,width:u,height:g,direction:"vertical",property:n.property});break}case"padding-bottom":{let g=parseFloat(l.paddingBottom)||0;r.push({x:s.left+d,y:s.top+a+p-g,width:u,height:g,direction:"vertical",property:n.property});break}case"padding-left":{let g=parseFloat(l.paddingLeft)||0;r.push({x:s.left+d,y:s.top+a,width:g,height:p,direction:"horizontal",property:n.property});break}case"padding-right":{let g=parseFloat(l.paddingRight)||0;r.push({x:s.left+d+u-g,y:s.top+a,width:g,height:p,direction:"horizontal",property:n.property});break}case"margin-top":{let g=parseFloat(l.marginTop)||0;r.push({x:s.left,y:s.top-g,width:s.width,height:g,direction:"vertical",property:n.property});break}case"margin-bottom":{let g=parseFloat(l.marginBottom)||0;r.push({x:s.left,y:s.bottom,width:s.width,height:g,direction:"vertical",property:n.property});break}case"margin-left":{let g=parseFloat(l.marginLeft)||0;r.push({x:s.left-g,y:s.top,width:g,height:s.height,direction:"horizontal",property:n.property});break}case"margin-right":{let g=parseFloat(l.marginRight)||0;r.push({x:s.right,y:s.top,width:g,height:s.height,direction:"horizontal",property:n.property});break}case"gap":case"row-gap":case"column-gap":{let g=Array.from(i.children).filter(S=>{let v=getComputedStyle(S);return v.display!=="none"&&v.position!=="absolute"&&v.position!=="fixed"});for(let S=0;S<g.length-1&&r.length<t;S++){let v=g[S].getBoundingClientRect(),b=g[S+1].getBoundingClientRect(),w=b.top-v.bottom;w>.5&&r.push({x:Math.min(v.left,b.left),y:v.bottom,width:Math.max(v.right,b.right)-Math.min(v.left,b.left),height:w,direction:"vertical",property:"gap"});let O=b.left-v.right;O>.5&&r.push({x:v.right,y:Math.min(v.top,b.top),width:O,height:Math.max(v.bottom,b.bottom)-Math.min(v.top,b.top),direction:"horizontal",property:"gap"})}break}}}return r}function Ks(e,t){let o=new Set,r=Do(t);for(let n of e){let i=qs[n.property];if(!i)continue;let s=n.element.className;if(typeof s=="string")for(let l of i){let a=`${l}-${r}`;for(let c of s.split(/\s+/)){let d=c.lastIndexOf(":"),u=d>=0?c.slice(d+1):c;if(u===a){o.add(u);break}}}}return[...o]}function Zs(e){let t=new Set;for(let o of e)for(let[r,n]of Object.entries(Xs))if(n.includes(o.property)){t.add(r);break}if(t.size===1)return[...t][0]}function Kr(e,t,o){if(t===o)return e;let r=Do(t),n=Do(o);return e.map(i=>{let s=i.lastIndexOf("-");if(s<0)return i;let l=i.slice(0,s),a=i.slice(s+1);return a===r||a===`[${t}px]`?`${l}-${n}`:i})}var Fc={0:"0",1:"px",2:"0.5",4:"1",6:"1.5",8:"2",12:"3",16:"4",20:"5",24:"6",28:"7",32:"8",40:"10",48:"12",64:"16",80:"20",96:"24"};function Do(e){var t;return(t=Fc[e])!=null?t:`[${e}px]`}var qs={"padding-top":["pt","py","p"],"padding-bottom":["pb","py","p"],"padding-left":["pl","px","p"],"padding-right":["pr","px","p"],"margin-top":["mt","my","m"],"margin-bottom":["mb","my","m"],"margin-left":["ml","mx","m"],"margin-right":["mr","mx","m"],gap:["gap"],"row-gap":["gap-y","gap"],"column-gap":["gap-x","gap"]};function Nc(e,t,o,r){let n=qs[t];if(!n)return null;let i=Do(o);for(let s of n){let l=new RegExp("(?:^|\\s)((?:[\\w-]+:)*"+s+"-(?:"+_c(i)+"|\\["+o+"px\\]))(?:\\s|$)"),a=e.match(l);if(a!=null&&a[1]){let c=Do(r),d=a[1].lastIndexOf(":"),u=d>=0?a[1].slice(0,d+1):"";return{matched:a[1],suggested:`${u}${s}-${c}`}}}return null}function _c(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Qs(e,t,o){let r=new Set,n=[];for(let i of e){let s=sn(i.element),l=`${s}::${i.property}`;if(r.has(l))continue;r.add(l);let a=or(i.element),c=i.element.className||"",d=Nc(c,i.property,t,o);n.push({selector:s,reactComponent:a==null?void 0:a.name,className:c,property:i.property,matchedClass:d==null?void 0:d.matched,suggestedClass:d==null?void 0:d.suggested})}return n}function Ho(e,t){return window.getComputedStyle(e).getPropertyValue(t)}function Zr(e,t){if(e instanceof HTMLElement){let r=e.style.getPropertyValue(t);if(r)return r}let o=zc(e,t);return o&&o.includes("var(")?o:Ho(e,t)}function zc(e,t){let o=t.replace(/-([a-z])/g,(r,n)=>n.toUpperCase());try{for(let r of document.styleSheets)try{let n=r.cssRules||r.rules;for(let i of n)if(i instanceof CSSStyleRule&&e.matches(i.selectorText)){let s=i.style.getPropertyValue(t);if(s&&s.includes("var("))return s;let l=i.style[o];if(l&&l.includes("var("))return l}}catch(n){}}catch(r){}return null}function lr(e,t){if(e instanceof HTMLElement){let r=e.style.getPropertyValue(t);if(r)return r}let o=t.replace(/-([a-z])/g,(r,n)=>n.toUpperCase());try{for(let r of document.styleSheets)try{let n=r.cssRules||r.rules;for(let i of n)if(i instanceof CSSStyleRule&&e.matches(i.selectorText)){let s=i.style.getPropertyValue(t);if(s)return s;let l=i.style[o];if(l)return l}}catch(n){}}catch(r){}return null}function ar(e){let t=window.getComputedStyle(e).display;return t==="flex"||t==="inline-flex"||t==="grid"||t==="inline-grid"}function Fo(e){let t=window.getComputedStyle(e);return{row:parseFloat(t.rowGap)||0,column:parseFloat(t.columnGap)||0}}function $c(e){let t=[];for(let o of e){let r=t.find(n=>n.axis!==o.axis?!1:o.axis==="row"?Math.abs(n.y-o.y)<2&&Math.abs(n.h-o.h)<2:Math.abs(n.x-o.x)<2&&Math.abs(n.w-o.w)<2);if(r)if(o.axis==="row"){let n=Math.min(r.x,o.x),i=Math.max(r.x+r.w,o.x+o.w);r.x=n,r.w=i-n}else{let n=Math.min(r.y,o.y),i=Math.max(r.y+r.h,o.y+o.h);r.y=n,r.h=i-n}else t.push(f({},o))}return t}function Vn(e){let t=Array.from(e.children).filter(a=>{if(!(a instanceof HTMLElement))return!1;let c=window.getComputedStyle(a);return c.display!=="none"&&c.position!=="absolute"&&c.position!=="fixed"});if(t.length<2)return[];let o=[],r=e.getBoundingClientRect(),i=window.getComputedStyle(e).flexDirection,s=i==="column"||i==="column-reverse",l=6;for(let a=0;a<t.length-1;a++){let c=t[a].getBoundingClientRect(),d=t[a+1].getBoundingClientRect();if(d.left>c.right+.5&&o.push({axis:"column",x:c.right,y:r.top,w:d.left-c.right,h:r.height}),d.top>c.bottom+.5&&o.push({axis:"row",x:r.left,y:c.bottom,w:r.width,h:d.top-c.bottom}),!(d.left>c.right+.5)&&!(d.top>c.bottom+.5))if(s){let u=(c.bottom+d.top)/2;o.push({axis:"row",x:r.left,y:u-l/2,w:r.width,h:l})}else{let u=(c.right+d.left)/2;o.push({axis:"column",x:u-l/2,y:r.top,w:l,h:r.height})}}return $c(o)}function qr(e,t){let o=window.getComputedStyle(e),r=o.display;if(r!=="flex"&&r!=="inline-flex")return!1;let n=o.justifyContent;if(n!=="space-between"&&n!=="space-around"&&n!=="space-evenly"&&n!=="stretch")return!1;let i=o.flexDirection;return!(t!==(i==="column"||i==="column-reverse"?"row":"column")||parseFloat(t==="row"?o.rowGap:o.columnGap)>0)}function go(e){let t=window.getComputedStyle(e);return{top:parseFloat(t.paddingTop)||0,right:parseFloat(t.paddingRight)||0,bottom:parseFloat(t.paddingBottom)||0,left:parseFloat(t.paddingLeft)||0}}function Un(e){let t=window.getComputedStyle(e);return{"top-left":parseFloat(t.borderTopLeftRadius)||0,"top-right":parseFloat(t.borderTopRightRadius)||0,"bottom-right":parseFloat(t.borderBottomRightRadius)||0,"bottom-left":parseFloat(t.borderBottomLeftRadius)||0}}function Qr(e){for(let t of e.childNodes)if(t.nodeType===Node.TEXT_NODE&&(t.textContent||"").trim().length>0)return!0;return!1}function mo(e){var d,u;let t=document.createRange(),o=!1;for(let p of e.childNodes)p.nodeType===Node.TEXT_NODE&&(p.textContent||"").trim().length>0&&(o||(t.setStart(p,0),o=!0),t.setEnd(p,(u=(d=p.textContent)==null?void 0:d.length)!=null?u:0));if(!o)return null;let r=t.getBoundingClientRect(),n=window.getComputedStyle(e),i=parseFloat(n.fontSize)||16,s=parseFloat(n.lineHeight);isNaN(s)&&(s=i*1.2);let l=Math.max(1,t.getClientRects().length),a=Math.max(r.height,l*s),c=(a-r.height)/2;return new DOMRect(r.x,r.y-c,r.width,a)}function No(e){let t=window.getComputedStyle(e),o=parseFloat(t.fontSize)||16,r=parseFloat(t.lineHeight);return isNaN(r)&&(r=o*1.2),{fontSize:o,lineHeight:r}}function _e(e,t,o){e instanceof HTMLElement&&e.style.setProperty(t,o,"important")}function ei(e,t,o){e instanceof HTMLElement&&e.style.removeProperty(t)}function cr(e){var t;for(let o of e){let r=Jt(o.selector);if(!r&&o.durableSelector&&(r=Jt(o.durableSelector),r)){let n=(t=o.selector.match(/\[data-pm="([^"]+)"\]/))==null?void 0:t[1];n&&r.setAttribute("data-pm",n)}if(r)for(let n of o.changes)_e(r,n.property,n.modified)}}function ti(e,t){let o=Jt(e);if(!o)return;let r=t.find(n=>n.selector===e);if(r)for(let n of r.changes)ei(o,n.property,n.original)}function dr(e){for(let t of e){let o=Jt(t.selector);if(o)for(let r of t.changes)ei(o,r.property,r.original)}}function tl(e,t,o,r){if(e)for(let n of e){if(n instanceof CSSGroupingRule){tl(n.cssRules,t,o,r);continue}if(n instanceof CSSStyleRule){let i=n.selectorText.toLowerCase();(i===":root"||i==="html"||i==="*"||i.includes(":root"))&&Wc(n.style,t,o,r)}}}function Wc(e,t,o,r){for(let n=0;n<e.length;n++){let i=e[n];if(i!=null&&i.startsWith("--")){if(o.has(i))continue;o.add(i);let s=t.getPropertyValue(i).trim();nl(s)&&r.push({name:i,value:s,usage:`var(${i})`})}}}var ur=null,Yc=5e3;function ni(){if(ur&&Date.now()-ur.timestamp<Yc)return ur.variables;let e=[],t=new Set,o=getComputedStyle(document.documentElement);try{for(let i of document.styleSheets)try{tl(i.cssRules||i.rules,o,t,e)}catch(s){}}catch(i){}let r=document.documentElement.style;for(let i=0;i<r.length;i++){let s=r[i];if(s!=null&&s.startsWith("--")&&!t.has(s)){t.add(s);let l=o.getPropertyValue(s).trim();nl(l)&&e.push({name:s,value:l,usage:`var(${s})`})}}let n=e.sort((i,s)=>i.name.localeCompare(s.name));return ur={variables:n,timestamp:Date.now()},n}function nl(e){if(!e)return!1;let t=e.toLowerCase().trim();return!!(/^#([0-9a-f]{3}|[0-9a-f]{4}|[0-9a-f]{6}|[0-9a-f]{8})$/i.test(t)||t.startsWith("rgb")||t.startsWith("hsl")||t.startsWith("oklch")||t.startsWith("oklab")||t.startsWith("lch")||t.startsWith("lab")||["transparent","currentcolor","inherit","white","black","red","green","blue","yellow","orange","purple","pink","gray","grey"].includes(t))}function _o(e,t){let o=t.match(/var\((--[^,)]+)(?:,\s*([^)]+))?\)/);if(o){let r=o[1],n=o[2];return getComputedStyle(document.documentElement).getPropertyValue(r).trim()||n||t}return t}function zo(e,t){if(!e)return null;let o=el(e);if(!o)return null;for(let r of t){let n=el(r.value);if(n&&o===n)return r}return null}function el(e){if(!e)return null;let t=e.trim().toLowerCase();if(t.startsWith("oklch(")){let o=t.match(/oklch\(\s*([\d.]+%?)\s+([\d.]+%?)\s+([\d.]+)/);if(o){let r=o[1].endsWith("%")?parseFloat(o[1])/100:parseFloat(o[1]),n=o[2].endsWith("%")?parseFloat(o[2])/100:parseFloat(o[2]),i=parseFloat(o[3]);r=Math.round(r*100)/100,n=Math.round(n*1e3)/1e3;let s=Math.round(i);return`oklch(${r} ${n} ${s})`}}if(t.startsWith("rgb")){let o=t.match(/rgba?\(\s*(\d+)[,\s]+(\d+)[,\s]+(\d+)/);if(o)return`rgb(${o[1]},${o[2]},${o[3]})`}return t.startsWith("#")?t.length===4?`#${t[1]}${t[1]}${t[2]}${t[2]}${t[3]}${t[3]}`:t.slice(0,7):t}import{Fragment as Jn,jsx as Xe,jsxs as pn}from"react/jsx-runtime";var Xn=22,ho=12,jc=3,Gc=250,oi=["reviewing","considering","thinking","zhuzhing","iterating","tweaking","reflecting","noodling","pondering","finessing","polishing","riffing"],Vc=3e3;function Uc(i){var s=i,{left:e,top:t,style:o,children:r}=s,n=Hn(s,["left","top","style","children"]);return Xe("div",h(f({"data-devtools":"badge-hit-area"},n),{style:f({position:"fixed",left:`max(0px, ${e}px)`,top:`max(0px, ${t}px)`,padding:ho,transform:`translate(min(0px, calc(100vw - max(0px, ${e}px) - 100%)), min(0px, calc(100vh - max(0px, ${t}px) - 100%)))`},o),children:r}))}function il({annotations:e,supersededAnnotations:t,inFlightIds:o,scrollX:r,scrollY:n,annotationGroupMap:i,onViewThread:s,onSelectAnnotation:l,canvasRef:a}){var b,w,O,A;let[c,d]=$o(0),[u,p]=$o(()=>Math.floor(Math.random()*oi.length)),g=!!(o&&o.size>0);pr(()=>{if(!g)return;let k=setInterval(()=>{d(I=>(I+1)%jc)},Gc),E=setInterval(()=>{p(I=>(I+1)%oi.length)},Vc);return()=>{clearInterval(k),clearInterval(E)}},[g]);let S=[];for(let k of e){if(k.type!=="text"||!k.text||!k.points[0]||t.has(k))continue;let E=k.groupId?e.filter(xe=>xe.groupId===k.groupId):[k],I=!!(o&&(o.has(k.id)||E.some(xe=>o.has(xe.id)))),$=(b=k.status)!=null?b:"pending",q=E.some(xe=>xe.status==="resolved"||xe.status==="needs_review"),j=E.some(xe=>xe.threadId);if(!I&&$!=="resolved"&&$!=="needs_review"&&!q&&!j)continue;let T=k.threadId||((w=E.find(xe=>xe.threadId))==null?void 0:w.threadId),D=$==="needs_review"||E.some(xe=>xe.status==="needs_review"),K=E.reduce((xe,ge)=>{var Ge;return xe+((Ge=ge.replyCount)!=null?Ge:0)},0),ee=k.points[0],me=k.fontSize||12,ve=me*1.4,ae=k.text.split(`
5
- `),Re=i.get(k.id),We=Re!==void 0?[Re+". "+(ae[0]||""),...ae.slice(1)]:ae,Me=(A=(O=a==null?void 0:a.current)==null?void 0:O.getContext("2d"))!=null?A:document.createElement("canvas").getContext("2d");if(!Me)continue;Me.font=`${me}px ${Wt}`;let ne=ee.x-r,Ae=co(ne),G=Ae!==void 0?Math.min(400,Ae):400,oe=jn(Me,We,G),Ee=Math.min(G,Math.max(...oe.map(xe=>Me.measureText(xe).width))),ce=oe.length*ve,Ke=We.length*ve,Te=ce-Ke;S.push({id:k.id,threadId:T,x:ee.x+Ee+4,y:ee.y-4-Te,size:ce+8,color:k.color,isInFlight:I,isNeedsReview:D,replyCount:K})}if(S.length===0)return null;let v=!!s;return Xe(Jn,{children:S.map(k=>Xe(Uc,{left:k.x-r-ho,top:k.y-n-ho,onClick:v&&k.threadId?()=>{l==null||l(k.id),s(k.threadId)}:void 0,style:{pointerEvents:v?"auto":"none",cursor:v&&k.threadId?"pointer":void 0,zIndex:9999},children:Xe("div",{"data-devtools":"annotation-badge",style:{height:k.size,display:"flex",alignItems:"center",backgroundColor:k.color,fontFamily:Wt,fontSize:12,color:"#ffffff",userSelect:"none",padding:`0 ${4}px`,gap:4,whiteSpace:"nowrap"},children:k.isInFlight?pn(Jn,{children:[Xe("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"currentColor",style:{verticalAlign:"middle"},children:c===1?pn(Jn,{children:[Xe("circle",{cx:"7",cy:"7",r:"2"}),Xe("circle",{cx:"17",cy:"7",r:"2"}),Xe("circle",{cx:"7",cy:"17",r:"2"}),Xe("circle",{cx:"17",cy:"17",r:"2"})]}):pn(Jn,{children:[Xe("circle",{cx:"12",cy:"6",r:"2"}),Xe("circle",{cx:"6",cy:"12",r:"2"}),Xe("circle",{cx:"18",cy:"12",r:"2"}),Xe("circle",{cx:"12",cy:"18",r:"2"})]})}),Xe("span",{style:{opacity:.7},children:oi[u]})]}):pn(Jn,{children:[k.isNeedsReview?Xe("span",{style:{fontWeight:700},children:"?"}):pn("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",children:[Xe("line",{x1:"12",y1:"3",x2:"12",y2:"9"}),Xe("line",{x1:"12",y1:"15",x2:"12",y2:"21"}),Xe("line",{x1:"3",y1:"12",x2:"9",y2:"12"}),Xe("line",{x1:"15",y1:"12",x2:"21",y2:"12"})]}),Xe("span",{style:{opacity:.7},children:k.replyCount>0?`${k.replyCount} ${k.replyCount===1?"reply":"replies"}`:"Cancelled"})]})})},k.id))})}function ri({inFlightSelectorColors:e,animated:t=!0}){let[o,r]=$o([]);if(pr(()=>{if(e.size===0){r([]);return}let i=null,s=()=>{let c=[];for(let[d,u]of e){let p=Jt(d);if(!p)continue;let g=p.getBoundingClientRect();c.push({selector:d,top:g.top,left:g.left,width:g.width,height:g.height,color:u})}r(c)},l=()=>{i&&cancelAnimationFrame(i),i=requestAnimationFrame(s)};s(),window.addEventListener("scroll",l,!0),window.addEventListener("resize",l,!0);let a=new MutationObserver(l);return a.observe(document.body,{attributes:!0,childList:!0,subtree:!0,attributeFilter:["style","class"]}),()=>{window.removeEventListener("scroll",l,!0),window.removeEventListener("resize",l,!0),a.disconnect(),i&&cancelAnimationFrame(i)}},[e]),o.length===0)return null;let n={position:"absolute",width:2,height:2,pointerEvents:"none"};return pn(Jn,{children:[t&&Xe("style",{children:"@keyframes popmelt-march { to { stroke-dashoffset: -6; } }"}),o.map(i=>pn("div",{"data-devtools":"marching-ants",style:{position:"fixed",top:i.top,left:i.left,width:i.width,height:i.height,pointerEvents:"none",zIndex:9995,overflow:"visible"},children:[Xe("svg",{style:{position:"absolute",inset:0,width:"100%",height:"100%",overflow:"visible"},children:Xe("rect",{x:"0.5",y:"0.5",width:Math.max(0,i.width-1),height:Math.max(0,i.height-1),fill:"none",stroke:i.color,strokeWidth:"1",strokeDasharray:"2 4",style:t?{animation:"popmelt-march 0.5s steps(2) infinite"}:void 0})}),Xe("div",{style:h(f({},n),{top:-1,left:-1,backgroundColor:i.color})}),Xe("div",{style:h(f({},n),{top:-1,right:-1,backgroundColor:i.color})}),Xe("div",{style:h(f({},n),{bottom:-1,left:-1,backgroundColor:i.color})}),Xe("div",{style:h(f({},n),{bottom:-1,right:-1,backgroundColor:i.color})})]},i.selector))]})}function sl({annotations:e,supersededAnnotations:t,scrollX:o,scrollY:r,onReply:n,annotationGroupMap:i,canvasRef:s}){let l=e.filter(d=>t.has(d)?!1:d.status==="waiting_input"&&d.question&&d.threadId);if(l.length===0)return null;let a=new Set,c=[];for(let d of l){if(!d.threadId||a.has(d.threadId))continue;a.add(d.threadId);let u=d.type==="text"?d:e.find(p=>p.groupId&&p.groupId===d.groupId&&p.type==="text")||d;if(u.type==="text"&&u.text&&u.points[0]){let p=u.points[0],g=u.fontSize||12,S=g*1.4,v=u.text.split(`
6
- `),b=i.get(u.id),w=b!==void 0?[b+". "+(v[0]||""),...v.slice(1)]:v,A=document.createElement("canvas").getContext("2d");if(!A)continue;A.font=`${g}px ${Wt}`;let k=p.x-o,E=co(k),I=E!==void 0?Math.min(400,E):400,$=jn(A,w,I),q=Math.min(I,Math.max(...$.map(ee=>A.measureText(ee).width))),j=$.length*S,T=w.length*S,D=j-T,K=j+8;c.push({annotation:d,x:p.x+q+4,y:p.y-4-D,size:K})}}return c.length===0?null:Xe(Jn,{children:c.map(({annotation:d,x:u,y:p,size:g})=>Xe(Jc,{annotation:d,x:u-o,y:p-r,size:g,onReply:n},`question-${d.threadId}`))})}function Jc({annotation:e,x:t,y:o,size:r,onReply:n}){let[i,s]=$o(!1),[l,a]=$o(""),c=rl(null),d=rl(null);pr(()=>{i&&c.current&&c.current.focus()},[i]),pr(()=>{if(!i)return;let v=w=>{d.current&&!w.composedPath().includes(d.current)&&s(!1)},b=w=>{w.key==="Escape"&&s(!1)};return document.addEventListener("mousedown",v),document.addEventListener("keydown",b),()=>{document.removeEventListener("mousedown",v),document.removeEventListener("keydown",b)}},[i]);let u=ol(()=>{!l.trim()||!e.threadId||(n(e.threadId,l.trim()),a(""),s(!1))},[l,e.threadId,n]),p=ol(v=>{v.key==="Enter"&&(v.metaKey||v.ctrlKey)&&(v.preventDefault(),u())},[u]),g=i?t:t-ho,S=i?o:o-ho;return pn("div",{ref:d,"data-devtools":"question-badge",style:{position:"fixed",left:`max(0px, ${g}px)`,top:`max(0px, ${S}px)`,padding:i?0:ho,transform:`translate(min(0px, calc(100vw - max(0px, ${g}px) - 100%)), min(0px, calc(100vh - max(0px, ${S}px) - 100%)))`,zIndex:i?10002:9999,pointerEvents:"auto",cursor:i?void 0:"pointer"},children:[!i&&pn("div",{onClick:()=>s(!0),style:{height:r,display:"flex",alignItems:"center",backgroundColor:e.color,padding:`0 ${4}px`,gap:4,fontFamily:Wt,fontSize:12,color:"#ffffff",whiteSpace:"nowrap"},children:[pn("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",children:[Xe("line",{x1:"12",y1:"3",x2:"12",y2:"9"}),Xe("line",{x1:"12",y1:"15",x2:"12",y2:"21"}),Xe("line",{x1:"3",y1:"12",x2:"9",y2:"12"}),Xe("line",{x1:"15",y1:"12",x2:"21",y2:"12"})]}),Xe("span",{style:{opacity:.7},children:"reply?"})]}),i&&pn("div",{style:{minWidth:260,maxWidth:360,backgroundColor:"#ffffff",fontFamily:Wt,fontSize:12,color:"#1f2937",border:"1px solid rgba(0, 0, 0, 0.1)"},children:[Xe("div",{style:{padding:`${6}px ${8}px`,lineHeight:1.4},children:e.question}),pn("div",{style:{padding:`0 ${4}px ${4}px`},children:[Xe("textarea",{ref:c,value:l,onChange:v=>a(v.target.value),onKeyDown:p,placeholder:"Type your reply...",style:{width:"100%",minHeight:40,padding:4,fontSize:12,fontFamily:Wt,backgroundColor:"rgba(0, 0, 0, 0.04)",color:"#1f2937",border:"1px solid rgba(0, 0, 0, 0.1)",borderRadius:0,outline:"none",resize:"vertical",lineHeight:1.4,boxSizing:"border-box"}}),Xe("div",{style:{display:"flex",justifyContent:"flex-end",marginTop:4},children:Xe("button",{onClick:u,disabled:!l.trim(),style:{padding:"4px 12px",fontSize:11,fontFamily:Wt,fontWeight:600,backgroundColor:l.trim()?e.color:"rgba(0,0,0,0.1)",color:l.trim()?"#ffffff":"rgba(0,0,0,0.3)",border:"none",cursor:l.trim()?"pointer":"default"},children:"Send \u2318\u23CE"})})]})]})]})}function fr(e){var i;let t=new Set,o=new Map;for(let s of e){if(!s.linkedSelector)continue;let l=o.get(s.linkedSelector)||[];l.push(s),o.set(s.linkedSelector,l)}let r=new Set,n=new Set;for(let s of o.values()){if(s.length<=1){(i=s[0])!=null&&i.groupId&&n.add(s[0].groupId);continue}s.sort((a,c)=>c.timestamp-a.timestamp);let l=s[0];l.groupId&&n.add(l.groupId);for(let a=1;a<s.length;a++){let c=s[a];t.add(c),c.groupId&&r.add(c.groupId)}}for(let s of e)s.groupId&&r.has(s.groupId)&&!n.has(s.groupId)&&t.add(s);return t}import{useEffect as ll,useLayoutEffect as Xc,useState as al}from"react";import{jsx as ii,jsxs as dl}from"react/jsx-runtime";function Kc(e,t){let o=e.match(/^oklch\(([^)]+)\)$/i);return o?`oklch(${o[1]} / ${t})`:`color-mix(in srgb, ${e} ${Math.round(t*100)}%, transparent)`}var cl=["top-left","top-right","bottom-right","bottom-left"];function ul({element:e,radius:t,accentColor:o,hoveredCorner:r,draggingCorner:n,cursorViewport:i}){let[s,l]=al(null),[a,c]=al(!1);if(ll(()=>{let w=k=>{(k.key==="Meta"||k.key==="Control")&&c(!0)},O=k=>{(k.key==="Meta"||k.key==="Control")&&c(!1)},A=()=>c(!1);return window.addEventListener("keydown",w,!0),window.addEventListener("keyup",O,!0),window.addEventListener("blur",A),()=>{window.removeEventListener("keydown",w,!0),window.removeEventListener("keyup",O,!0),window.removeEventListener("blur",A)}},[]),ll(()=>{if(!e){l(null);return}let w=()=>{l(e.getBoundingClientRect())};return w(),window.addEventListener("scroll",w,{passive:!0}),window.addEventListener("resize",w,{passive:!0}),()=>{window.removeEventListener("scroll",w),window.removeEventListener("resize",w)}},[e]),Xc(()=>{e&&l(e.getBoundingClientRect())},[e,t["top-left"],t["top-right"],t["bottom-right"],t["bottom-left"]]),!s)return null;let d=s.width,u=s.height,p=Kc(o,.2),g={"top-left":{x:0,y:t["top-left"]},"top-right":{x:d,y:t["top-right"]},"bottom-right":{x:d,y:u-t["bottom-right"]},"bottom-left":{x:0,y:u-t["bottom-left"]}},S=new Set,v=n!=null?n:r;if(v)if(a)S.add(v);else for(let w of cl)S.add(w);let b={position:"fixed",top:s.top,left:s.left,width:d,height:u,pointerEvents:"none",zIndex:9996,overflow:"visible"};return dl("div",{"data-devtools":"border-radius-handles",style:b,children:[dl("svg",{style:{position:"absolute",inset:0,width:"100%",height:"100%",overflow:"visible",pointerEvents:"none"},viewBox:`0 0 ${d} ${u}`,children:[ii("rect",{x:"0.5",y:"0.5",width:Math.max(0,d-1),height:Math.max(0,u-1),fill:"none",stroke:p,strokeWidth:"1"}),cl.map(w=>{let O=g[w],A=S.has(w);return ii("circle",{cx:O.x,cy:O.y,r:w===(n!=null?n:r)?3:2.5,fill:o,stroke:"#ffffff",strokeWidth:w===(n!=null?n:r)?4:2,paintOrder:"stroke"},w)})]}),i&&v&&(()=>{let w=Math.round(t[v]);return ii("div",{style:{position:"fixed",left:i.x+8,top:i.y-28,background:o,color:"#fff",fontSize:11,fontWeight:600,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',lineHeight:1,padding:"4px 4px",borderRadius:0,whiteSpace:"nowrap",pointerEvents:"none",zIndex:9997},children:w})})()]})}import{useEffect as Zc,useState as qc}from"react";function Kn(e,t){let o=e.match(/^oklch\(([^)]+)\)$/i);if(o)return`oklch(${o[1]} / ${t})`;let r=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(r){let n=parseInt(r[1],16),i=parseInt(r[2],16),s=parseInt(r[3],16);return`rgba(${n}, ${i}, ${s}, ${t})`}return`color-mix(in srgb, ${e} ${Math.round(t*100)}%, transparent)`}import{Fragment as Qc,jsx as Zn,jsxs as Wo}from"react/jsx-runtime";function bo({element:e,isSelected:t=!1,elementInfo:o,color:r="#3b82f6",annotationNumber:n,changeCount:i,hideTooltip:s=!1}){let[l,a]=qc(null);if(Zc(()=>{if(!e){a(null);return}let I=()=>{let $=e.getBoundingClientRect();a($)};return I(),window.addEventListener("scroll",I,{passive:!0}),window.addEventListener("resize",I,{passive:!0}),()=>{window.removeEventListener("scroll",I),window.removeEventListener("resize",I)}},[e]),!l||!e)return null;let c={position:"fixed",top:l.top,left:l.left,width:l.width,height:l.height,pointerEvents:"none",zIndex:9996,backgroundColor:t?Kn(r,.1):Kn(r,.05),overflow:"visible"},d={position:"absolute",width:2,height:2,backgroundColor:r,pointerEvents:"none"},u=e.tagName.toLowerCase(),p=e.id?`#${e.id}`:"",g=e.classList.length>0?"."+Array.from(e.classList).slice(0,2).join("."):"",S=o==null?void 0:o.reactComponent,v=S?`<${S}> ${u}${p}${g}`:`${u}${p}${g}`,b=22,w=l.height>=window.innerHeight,O=w?0:l.top>=b?l.top-b:l.bottom,A=w?{position:"absolute",top:8,left:8,zIndex:9997,display:"flex",alignItems:"center",gap:6,backgroundColor:r,color:"#fff",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',padding:"4px 8px",borderRadius:0,pointerEvents:"none",whiteSpace:"nowrap",maxWidth:400}:{position:"fixed",top:O,left:l.left,zIndex:9997,display:"flex",alignItems:"center",gap:6,backgroundColor:r,color:"#fff",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',padding:"4px 8px",borderRadius:0,pointerEvents:"none",whiteSpace:"nowrap",maxWidth:400},E=!s&&Wo("div",{"data-devtools":"tooltip",style:A,children:[n!==void 0&&Wo("span",{children:[n,"."]}),Zn("span",{style:{overflow:"hidden",textOverflow:"ellipsis",flex:1,minWidth:0},children:v}),i!==void 0&&i>0&&Wo("span",{style:{opacity:.8},children:["(",i," ",i===1?"change":"changes",")"]})]});return Wo(Qc,{children:[Wo("div",{"data-devtools":"highlight",style:c,children:[Zn("svg",{style:{position:"absolute",inset:0,width:"100%",height:"100%",overflow:"visible",pointerEvents:"none"},children:Zn("rect",f({x:"0.5",y:"0.5",width:Math.max(0,l.width-1),height:Math.max(0,l.height-1),fill:"none",stroke:r,strokeWidth:"1"},!t&&{strokeDasharray:"2 4"}))}),Zn("div",{style:h(f({},d),{top:-1,left:-1})}),Zn("div",{style:h(f({},d),{top:-1,right:-1})}),Zn("div",{style:h(f({},d),{bottom:-1,left:-1})}),Zn("div",{style:h(f({},d),{bottom:-1,right:-1})}),w&&E]}),!w&&E]})}import{useEffect as pl,useLayoutEffect as ed,useState as si}from"react";import{jsx as In,jsxs as ai}from"react/jsx-runtime";function li(e,t){let o=e.match(/^oklch\(([^)]+)\)$/i);return o?`oklch(${o[1]} / ${t})`:`color-mix(in srgb, ${e} ${Math.round(t*100)}%, transparent)`}function ci({element:e,gap:t,accentColor:o,hoveredAxis:r,draggingAxis:n,cursorViewport:i,isAutoGap:s=!1,refreshKey:l=0}){let[a,c]=si(null),[d,u]=si([]),[p,g]=si(!1);if(pl(()=>{let q=D=>{(D.key==="Meta"||D.key==="Control")&&g(!0)},j=D=>{(D.key==="Meta"||D.key==="Control")&&g(!1)},T=()=>g(!1);return window.addEventListener("keydown",q,!0),window.addEventListener("keyup",j,!0),window.addEventListener("blur",T),()=>{window.removeEventListener("keydown",q,!0),window.removeEventListener("keyup",j,!0),window.removeEventListener("blur",T)}},[]),pl(()=>{if(!e){c(null),u([]);return}let q=()=>{c(e.getBoundingClientRect()),u(Vn(e))};return q(),window.addEventListener("scroll",q,{passive:!0}),window.addEventListener("resize",q,{passive:!0}),()=>{window.removeEventListener("scroll",q),window.removeEventListener("resize",q)}},[e]),ed(()=>{e&&(c(e.getBoundingClientRect()),u(Vn(e)))},[e,t.row,t.column,l]),!a||d.length===0)return null;let S=a.width,v=a.height,b="pm-gap-stripe-pattern",w=li(o,.25),O=li(o,.1),A=li(o,.2),k=8,E=2,I={position:"fixed",top:a.top,left:a.left,width:S,height:v,pointerEvents:"none",zIndex:9996,overflow:"visible"},$=n!=null?n:r;return ai("div",{"data-devtools":"gap-handles",style:I,children:[ai("svg",{style:{position:"absolute",inset:0,width:"100%",height:"100%",overflow:"visible",pointerEvents:"none"},viewBox:`0 0 ${S} ${v}`,children:[In("defs",{children:In("pattern",{id:b,patternUnits:"userSpaceOnUse",width:"4",height:"4",patternTransform:"rotate(45)",children:In("line",{x1:"0",y1:"0",x2:"0",y2:"4",stroke:w,strokeWidth:"1.5"})})}),In("rect",{x:"0.5",y:"0.5",width:Math.max(0,S-1),height:Math.max(0,v-1),fill:"none",stroke:A,strokeWidth:"1"}),d.map((q,j)=>{let T=q.x-a.left,D=q.y-a.top,K=q.w,ee=q.h,me=p?q.axis===$:!0;return(q.axis==="row"?t.row:t.column)===0?null:ai("g",{opacity:me?1:.6,children:[In("rect",{x:T,y:D,width:K,height:ee,fill:O}),In("rect",{x:T,y:D,width:K,height:ee,fill:`url(#${b})`})]},j)}),$&&(()=>{let q=d.filter(Ae=>Ae.axis===$);if(q.length===0)return null;let j=q[0];if(i&&q.length>1){let Ae=1/0;for(let G of q){let oe=G.x+G.w/2,Ee=G.y+G.h/2,ce=Math.abs(i.x-oe)+Math.abs(i.y-Ee);ce<Ae&&(Ae=ce,j=G)}}let T=j.x-a.left,D=j.y-a.top,K=j.w,ee=j.h,me=T+K/2,ve=D+ee/2;if(s)return In("circle",{cx:me,cy:ve,r:1.5,fill:o,stroke:"#ffffff",strokeWidth:4,paintOrder:"stroke"});let ae=$==="column",Re=ae?E:k,We=ae?k:E,Me=me-Re/2,ne=ve-We/2;return In("rect",{x:Me,y:ne,width:Re,height:We,fill:o,stroke:"#ffffff",strokeWidth:4,paintOrder:"stroke"})})()]}),i&&$&&(()=>{let q=s?"auto":String(Math.round($==="row"?t.row:t.column));return In("div",{style:{position:"fixed",left:i.x+8,top:i.y-28,background:o,color:"#fff",fontSize:11,fontWeight:600,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',lineHeight:1,padding:"4px 4px",borderRadius:0,whiteSpace:"nowrap",pointerEvents:"none",zIndex:9997},children:q})})()]})}import{useCallback as id,useEffect as sd,useState as ld}from"react";import{useEffect as td,useState as fl}from"react";var nd=3,od=250,di=["reviewing","considering","thinking","zhuzhing","iterating","tweaking","reflecting","noodling","pondering","finessing","polishing","riffing"],rd=3e3;function gr(e){let[t,o]=fl(0),[r,n]=fl(()=>Math.floor(Math.random()*di.length));return td(()=>{if(!e)return;let i=setInterval(()=>o(l=>(l+1)%nd),od),s=setInterval(()=>n(l=>(l+1)%di.length),rd);return()=>{clearInterval(i),clearInterval(s)}},[e]),{charIndex:t,word:di[r]}}import{Fragment as ui,jsx as ln,jsxs as xo}from"react/jsx-runtime";function ad(e){let{element:t}=e,o=t.tagName,r=t.id?`#${t.id}`:"",n=t.className?"."+t.className.split(" ").slice(0,2).join("."):"",i=t.reactComponent;return i?`<${i}> ${o}${r}${n}`:`${o}${r}${n}`}var gl=22,pi=12;function cd(i){var s=i,{left:e,top:t,style:o,children:r}=s,n=Hn(s,["left","top","style","children"]);return ln("div",h(f({"data-devtools":"badge-hit-area"},n),{style:f({position:"fixed",left:`max(0px, ${e}px)`,top:`max(0px, ${t}px)`,padding:pi,transform:`translate(min(0px, calc(100vw - max(0px, ${e}px) - 100%)), min(0px, calc(100vh - max(0px, ${t}px) - 100%)))`},o),children:r}))}function ml({styleModifications:e,isInspecting:t,accentColor:o,annotationGroupCount:r,dispatch:n,inFlightSelectors:i}){let[s,l]=ld([]),a=i&&i.size>0,{charIndex:c,word:d}=gr(!!a);sd(()=>{if(t){l([]);return}let S=null,v=()=>{let O=[];e.forEach((A,k)=>{let E=Jt(A.selector);if(!E)return;let I=E.getBoundingClientRect();O.push({selector:A.selector,modIndex:k,top:I.top>=gl?I.top-gl:I.bottom,left:I.left,label:ad(A),changeCount:A.changes.length,annotationNumber:r+k+1})}),l(O)},b=()=>{S&&cancelAnimationFrame(S),S=requestAnimationFrame(v)};v(),window.addEventListener("scroll",b,!0),window.addEventListener("resize",b,!0);let w=new MutationObserver(b);return w.observe(document.body,{attributes:!0,childList:!0,subtree:!0,attributeFilter:["style","class"]}),window.addEventListener("load",b),document.fonts.ready.then(b),()=>{window.removeEventListener("scroll",b,!0),window.removeEventListener("resize",b,!0),window.removeEventListener("load",b),w.disconnect(),S&&cancelAnimationFrame(S)}},[e,t,r]);let u=id(S=>{let v=e[S];if(!v)return;let b=Jt(v.selector);b&&(n({type:"SELECT_ANNOTATION",payload:{id:null}}),n({type:"SET_TOOL",payload:"inspector"}),n({type:"SELECT_ELEMENT",payload:{el:b,info:v.element}}))},[e,n]);if(s.length===0)return null;let p={display:"flex",alignItems:"center",gap:6,backgroundColor:o,color:"#fff",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',padding:"4px 8px",borderRadius:0,whiteSpace:"nowrap",maxWidth:400},g={overflow:"hidden",textOverflow:"ellipsis",flex:1,minWidth:0};return ln(ui,{children:s.map(S=>{let v=i==null?void 0:i.has(S.selector);return ln(cd,{left:S.left-pi,top:S.top-pi,onClick:()=>u(S.modIndex),style:{zIndex:1e4,cursor:"pointer",pointerEvents:"auto"},children:xo("div",{"data-devtools":"badge",style:h(f({},p),{backgroundColor:v?"#999999":o}),children:[xo("span",{children:[S.annotationNumber,"."]}),ln("span",{style:g,children:S.label}),xo("span",{style:{opacity:.8},children:["(",S.changeCount," ",S.changeCount===1?"change":"changes",")"]}),v&&xo("span",{style:{opacity:.8,marginLeft:4,display:"inline-flex",alignItems:"center",gap:4},children:[ln("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"currentColor",style:{verticalAlign:"middle"},children:c===1?xo(ui,{children:[ln("circle",{cx:"7",cy:"7",r:"2"}),ln("circle",{cx:"17",cy:"7",r:"2"}),ln("circle",{cx:"7",cy:"17",r:"2"}),ln("circle",{cx:"17",cy:"17",r:"2"})]}):xo(ui,{children:[ln("circle",{cx:"12",cy:"6",r:"2"}),ln("circle",{cx:"6",cy:"12",r:"2"}),ln("circle",{cx:"18",cy:"12",r:"2"}),ln("circle",{cx:"12",cy:"18",r:"2"})]})}),d]})]})},S.selector)})})}import{useEffect as dd,useState as ud}from"react";import{Fragment as fd,jsx as hl}from"react/jsx-runtime";function pd(e,t){let o=e.match(/^oklch\(([^)]+)\)$/i);return o?`oklch(${o[1]} / ${t})`:`color-mix(in srgb, ${e} ${Math.round(t*100)}%, transparent)`}function yl({styleModifications:e,accentColor:t}){let[o,r]=ud([]);if(dd(()=>{let i=null,s=()=>{let c=[];for(let d of e){let u=Jt(d.selector);if(!u)continue;let p=u.getBoundingClientRect();if(p.width===0&&p.height===0)continue;let g=Un(u);c.push({selector:d.selector,top:p.top,left:p.left,width:p.width,height:p.height,borderRadius:`${g["top-left"]}px ${g["top-right"]}px ${g["bottom-right"]}px ${g["bottom-left"]}px`})}r(c)},l=()=>{i&&cancelAnimationFrame(i),i=requestAnimationFrame(s)};s(),window.addEventListener("scroll",l,{passive:!0}),window.addEventListener("resize",l,{passive:!0});let a=new MutationObserver(l);return a.observe(document.body,{attributes:!0,childList:!0,subtree:!0,attributeFilter:["style","class"]}),()=>{window.removeEventListener("scroll",l),window.removeEventListener("resize",l),a.disconnect(),i&&cancelAnimationFrame(i)}},[e]),o.length===0)return null;let n=pd(t,.2);return hl(fd,{children:o.map(i=>{let s={position:"fixed",top:i.top,left:i.left,width:i.width,height:i.height,pointerEvents:"none",zIndex:9995,border:`1px solid ${n}`,borderRadius:i.borderRadius,boxSizing:"border-box"};return hl("div",{"data-devtools":"mod-border",style:s},i.selector)})})}import{useEffect as bl,useLayoutEffect as gd,useState as xl}from"react";import{jsx as Fn,jsxs as gi}from"react/jsx-runtime";function fi(e,t){let o=e.match(/^oklch\(([^)]+)\)$/i);return o?`oklch(${o[1]} / ${t})`:`color-mix(in srgb, ${e} ${Math.round(t*100)}%, transparent)`}var md={top:"bottom",bottom:"top",left:"right",right:"left"};function mi({element:e,padding:t,accentColor:o,hoveredSide:r,draggingSide:n,cursorViewport:i,refreshKey:s}){let[l,a]=xl(null),[c,d]=xl(!1);if(bl(()=>{let K=ve=>{(ve.key==="Meta"||ve.key==="Control")&&d(!0)},ee=ve=>{(ve.key==="Meta"||ve.key==="Control")&&d(!1)},me=()=>d(!1);return window.addEventListener("keydown",K,!0),window.addEventListener("keyup",ee,!0),window.addEventListener("blur",me),()=>{window.removeEventListener("keydown",K,!0),window.removeEventListener("keyup",ee,!0),window.removeEventListener("blur",me)}},[]),bl(()=>{if(!e){a(null);return}let K=()=>{a(e.getBoundingClientRect())};return K(),window.addEventListener("scroll",K,{passive:!0}),window.addEventListener("resize",K,{passive:!0}),()=>{window.removeEventListener("scroll",K),window.removeEventListener("resize",K)}},[e]),gd(()=>{e&&a(e.getBoundingClientRect())},[e,t.top,t.right,t.bottom,t.left,s]),!l)return null;let u=l.width,p=l.height,{top:g,right:S,bottom:v,left:b}=t,w="pm-stripe-pattern",O=fi(o,.25),A=fi(o,.1),k=fi(o,.2),E=8,I=2,$={position:"fixed",top:l.top,left:l.left,width:u,height:p,pointerEvents:"none",zIndex:9996,overflow:"visible"},q=["top","right","bottom","left"],j={top:`0,0 ${u},0 ${u-S},${g} ${b},${g}`,right:`${u},0 ${u},${p} ${u-S},${p-v} ${u-S},${g}`,bottom:`0,${p} ${b},${p-v} ${u-S},${p-v} ${u},${p}`,left:`0,0 ${b},${g} ${b},${p-v} 0,${p}`},T={top:{x:u/2-E/2,y:g/2-I/2,w:E,h:I},bottom:{x:u/2-E/2,y:p-v/2-I/2,w:E,h:I},left:{x:b/2-I/2,y:p/2-E/2,w:I,h:E},right:{x:u-S/2-I/2,y:p/2-E/2,w:I,h:E}},D=new Set;return n?D.add(n):r&&(D.add(r),c||D.add(md[r])),gi("div",{"data-devtools":"padding-handles",style:$,children:[gi("svg",{style:{position:"absolute",inset:0,width:"100%",height:"100%",overflow:"visible",pointerEvents:"none"},viewBox:`0 0 ${u} ${p}`,children:[Fn("defs",{children:Fn("pattern",{id:w,patternUnits:"userSpaceOnUse",width:"4",height:"4",patternTransform:"rotate(45)",children:Fn("line",{x1:"0",y1:"0",x2:"0",y2:"4",stroke:O,strokeWidth:"1.5"})})}),Fn("rect",{x:"0.5",y:"0.5",width:Math.max(0,u-1),height:Math.max(0,p-1),fill:"none",stroke:k,strokeWidth:"1"}),q.map(K=>{if(t[K]<=0)return null;let me=D.has(K);return gi("g",{opacity:me?1:.6,children:[Fn("polygon",{points:j[K],fill:A}),Fn("polygon",{points:j[K],fill:`url(#${w})`})]},K)}),q.map(K=>{let ee=T[K],me=D.has(K);return Fn("rect",{x:ee.x,y:ee.y,width:ee.w,height:ee.h,fill:o,stroke:"#ffffff",strokeWidth:me?4:2,paintOrder:"stroke"},`handle-${K}`)})]}),i&&(r||n)&&(()=>{let K=n!=null?n:r,ee=Math.round(t[K]);return Fn("div",{style:{position:"fixed",left:i.x+8,top:i.y-28,background:o,color:"#fff",fontSize:11,fontWeight:600,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',lineHeight:1,padding:"4px 4px",borderRadius:0,whiteSpace:"nowrap",pointerEvents:"none",zIndex:9997},children:ee})})()]})}import{useCallback as Mn,useEffect as gn,useMemo as Sr,useRef as on,useState as jt}from"react";import{Check as vr,ChevronDown as Ei,MoveHorizontal as Al,RotateCcw as zd,Shrink as $d,X as Wd}from"lucide-react";var hd="data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHdpZHRoPScxMicgaGVpZ2h0PScxMic+PGRlZnM+PHBhdHRlcm4gaWQ9J2QnIHdpZHRoPSc0JyBoZWlnaHQ9JzQnIHBhdHRlcm5Vbml0cz0ndXNlclNwYWNlT25Vc2UnPjxwYXRoIGQ9J00tMSwxIGwyLC0yIE0wLDQgbDQsLTQgTTMsNSBsMiwtMicgc3Ryb2tlPSdibGFjaycgc3Ryb2tlLXdpZHRoPScuNScvPjwvcGF0dGVybj48L2RlZnM+PHJlY3Qgd2lkdGg9JzEyJyBoZWlnaHQ9JzEyJyBmaWxsPSd1cmwoI2QpJy8+PC9zdmc+",bn={borderWidth:3,borderStyle:"solid",borderImage:`url("${hd}") 4 / 1.9 / 0 round`};var mr={"font-size":["rem","px","em"],"line-height":["","rem","px","em"],"letter-spacing":["rem","px","em"],gap:["rem","px","em"],"column-gap":["rem","px","em"],"row-gap":["rem","px","em"],padding:["rem","px","em","%"],margin:["rem","px","em","%"],width:["rem","px","%","em"],height:["rem","px","%","em"],"min-width":["rem","px","%","em"],"max-width":["rem","px","%","em"],"min-height":["rem","px","%","em"],"max-height":["rem","px","%","em"],"border-width":["px","rem","em"],"border-radius":["rem","px","%","em"]};function vo(e){var t,o;return(o=(t=mr[e])==null?void 0:t[0])!=null?o:"px"}function Nn(e){let t=e.match(/^([\d.-]+)(.*)$/);return t?{num:parseFloat(t[1]),unit:t[2]||""}:{num:0,unit:""}}function hr(e,t,o,r){let n=e.trim();if(!n)return"";let i=n.match(/^(-?[\d.]+)\s*(rem|em|px|%)$/i);if(i)return`${parseFloat(i[1])}${i[2].toLowerCase()}`;let s=parseFloat(n);if(!isNaN(s)){if(r){let{unit:l}=Nn(o);return`${s}${l||vo(t)}`}return`${s}${vo(t)}`}return n}function hi(e,t){if(!t||t==="px")return e;if(t==="rem"){let o=parseFloat(getComputedStyle(document.documentElement).fontSize)||16;return Math.round(e/o*1e3)/1e3}return e}import{useCallback as yd,useEffect as bd,useRef as vl,useState as xd}from"react";import{Plus as Sl,X as vd}from"lucide-react";import{jsx as nn,jsxs as qn}from"react/jsx-runtime";var yr=[{name:"blur",label:"Blur",unit:"px",defaultValue:10,min:0,max:100,step:1},{name:"brightness",label:"Brightness",unit:"",defaultValue:1,min:0,max:3,step:.05},{name:"contrast",label:"Contrast",unit:"",defaultValue:1,min:0,max:3,step:.05},{name:"saturate",label:"Saturate",unit:"",defaultValue:1,min:0,max:3,step:.05},{name:"grayscale",label:"Grayscale",unit:"",defaultValue:0,min:0,max:1,step:.05},{name:"sepia",label:"Sepia",unit:"",defaultValue:0,min:0,max:1,step:.05},{name:"invert",label:"Invert",unit:"",defaultValue:0,min:0,max:1,step:.05},{name:"hue-rotate",label:"Hue Rotate",unit:"deg",defaultValue:0,min:0,max:360,step:1},{name:"opacity",label:"Opacity",unit:"",defaultValue:1,min:0,max:1,step:.05}];function Sd(e){if(!e||e==="none")return[];let t=[],o=/([\w-]+)\(([^)]+)\)/g,r;for(;(r=o.exec(e))!==null;){let n=r[1],i=r[2],s=parseFloat(i);isNaN(s)||t.push({name:n,value:s})}return t}function yi(e){return e.length===0?"none":e.map(t=>{var n;let o=yr.find(i=>i.name===t.name),r=(n=o==null?void 0:o.unit)!=null?n:"";return`${t.name}(${t.value}${r})`}).join(" ")}function wl({value:e,onChange:t,accentColor:o,modified:r,panelContentRef:n}){let i=Sd(e),[s,l]=xd(!1),a=vl(null),c=vl(null);bd(()=>{if(!s)return;let A=k=>{a.current&&!k.composedPath().includes(a.current)&&l(!1)};return document.addEventListener("mousedown",A,!0),()=>document.removeEventListener("mousedown",A,!0)},[s]);let d=yr.filter(A=>!i.some(k=>k.name===A.name)),u=A=>{let k=[...i,{name:A.name,value:A.defaultValue}];t(yi(k)),l(!1)},p=A=>{let k=i.filter((E,I)=>I!==A);t(yi(k))},g=(A,k)=>{let E=i.map((I,$)=>$===A?h(f({},I),{value:k}):I);t(yi(E))},S={width:"100%",padding:"4px 8px",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',border:"none",borderRadius:2,outline:"none",backgroundColor:"transparent"},v=yd(A=>{var D;if(!c.current)return{position:"fixed",top:0,left:0};let k=c.current.getBoundingClientRect(),E=c.current.closest('[data-devtools="panel"]'),I=E?E.getBoundingClientRect():{top:0,left:0,bottom:9999},$=(D=n==null?void 0:n.current)==null?void 0:D.getBoundingClientRect(),q=A*24+8,T=I.bottom-k.bottom<q;return h(f({position:"fixed"},T?{bottom:I.bottom-k.top+2-I.top}:{top:k.bottom+2-I.top}),{left:$?$.left+4-I.left:k.left-I.left,width:$?$.width-8:140,zIndex:10001})},[n]),b={backgroundColor:"rgba(255, 255, 255, 0.95)",backdropFilter:"blur(16px)",WebkitBackdropFilter:"blur(16px)",border:"1px solid rgba(0,0,0,0.1)",borderRadius:4,padding:"4px 0",boxShadow:"0 4px 12px rgba(0,0,0,0.1)"},w={display:"block",width:"100%",padding:"4px 10px",border:"none",backgroundColor:"transparent",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#334155",cursor:"pointer",textAlign:"left"},O=A=>nn("div",{ref:a,style:f(f({},v(A.length)),b),children:A.map(k=>nn("button",{type:"button",onClick:()=>u(k),style:w,onMouseEnter:E=>{E.currentTarget.style.backgroundColor="rgba(0,0,0,0.05)"},onMouseLeave:E=>{E.currentTarget.style.backgroundColor="transparent"},children:k.label},k.name))});return i.length===0?qn("div",{children:[qn("div",{style:{display:"flex",alignItems:"center",gap:4},children:[nn(Rn,{modified:!1,children:nn("input",{type:"text",value:"",placeholder:"\u2014",readOnly:!0,style:h(f({},S),{color:"#999",cursor:"default"})})}),nn("button",{ref:c,type:"button",onClick:()=>l(!s),style:{display:"flex",alignItems:"center",justifyContent:"center",width:20,height:20,padding:0,border:"none",borderRadius:2,backgroundColor:"transparent",color:"#94a3b8",cursor:"pointer",flexShrink:0},children:nn(Sl,{size:12})})]}),s&&O(yr)]}):qn("div",{style:{display:"flex",flexDirection:"column",gap:4,position:"relative"},children:[i.map((A,k)=>{let E=yr.find(I=>I.name===A.name);return E?qn("div",{style:{display:"flex",alignItems:"center",gap:4},children:[nn("span",{style:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:r?o:"#94a3b8",fontWeight:r?600:400,width:56,flexShrink:0,whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"},children:E.label}),nn(Rn,{modified:r,children:qn("div",{style:{display:"flex",alignItems:"center",gap:4,padding:"0 4px"},children:[nn("input",{type:"range",min:E.min,max:E.max,step:E.step,value:A.value,onChange:I=>g(k,parseFloat(I.target.value)),style:{flex:1,height:2,appearance:"none",WebkitAppearance:"none",background:`linear-gradient(to right, ${o} ${(A.value-E.min)/(E.max-E.min)*100}%, rgba(0,0,0,0.1) ${(A.value-E.min)/(E.max-E.min)*100}%)`,borderRadius:1,outline:"none",cursor:"pointer"}}),nn("input",{type:"number",min:E.min,max:E.max,step:E.step,value:E.unit==="px"||E.unit==="deg"?Math.round(A.value):Math.round(A.value*100)/100,onChange:I=>g(k,parseFloat(I.target.value)||0),style:h(f({},S),{width:44,padding:"2px 4px",textAlign:"right",flexShrink:0})}),E.unit&&nn("span",{style:{fontSize:9,color:"#94a3b8",fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',flexShrink:0,width:16},children:E.unit})]})}),nn("button",{type:"button",onClick:()=>p(k),style:{display:"flex",alignItems:"center",justifyContent:"center",width:16,height:16,padding:0,border:"none",borderRadius:2,backgroundColor:"transparent",color:"#94a3b8",cursor:"pointer",flexShrink:0},children:nn(vd,{size:10})})]},A.name):null}),d.length>0&&qn("div",{children:[qn("button",{ref:c,type:"button",onClick:()=>l(!s),style:{display:"flex",alignItems:"center",gap:4,padding:"2px 4px",border:"none",borderRadius:2,backgroundColor:"transparent",fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#94a3b8",cursor:"pointer"},children:[nn(Sl,{size:10}),"Add filter"]}),s&&O(d)]})]})}import{useCallback as wo,useEffect as Cd,useRef as br,useState as El}from"react";import{AlignHorizontalSpaceAround as Md,AlignVerticalSpaceAround as Td,Columns3 as Ld,Grid2x2 as Id,RectangleHorizontal as Rd,Rows3 as Ad,UnfoldHorizontal as kl,UnfoldVertical as Cl}from"lucide-react";import{useCallback as wd,useEffect as Ed,useRef as Yo}from"react";import{jsx as kd}from"react/jsx-runtime";var bi=[0,1,2,4,8,12,16,20,24,28,32];function So({value:e,onChange:t,onPreview:o,onScrubEnd:r,onReset:n,isModified:i,accentColor:s,defaultUnit:l="rem",snapSteps:a,color:c,style:d,children:u}){let p=Yo(null),g=Yo(null),S=Yo(n),v=Yo(i),b=Yo(!1);S.current=n,v.current=i,Ed(()=>{let O=k=>{let E=g.current;if(!E)return;E.hasMoved=!0,b.current=k.shiftKey;let I=E.unit==="rem"||E.unit==="em"?.1:1;E.accum+=k.movementX*I;let $=Math.max(0,Math.round((E.startValue+E.accum)*10)/10);if(k.shiftKey&&a){let q=E.unit==="rem"||E.unit==="em"?parseFloat(getComputedStyle(document.documentElement).fontSize)||16:1,j=E.unit==="rem"||E.unit==="em"?$*q:$,T=a[a.length-1];for(let D=0;D<a.length-1;D++){let K=a[D],ee=a[D+1];if(j<=(K+ee)/2){T=K;break}if(j<ee){T=ee;break}}j>a[a.length-1]&&(T=Math.round(j/8)*8),$=E.unit==="rem"||E.unit==="em"?Math.round(T/q*1e3)/1e3:T}o==null||o(`${$}${E.unit}`)},A=()=>{let k=g.current;if(!k)return;let E=Math.max(0,Math.round((k.startValue+k.accum)*10)/10);if(b.current&&a){let $=k.unit==="rem"||k.unit==="em"?parseFloat(getComputedStyle(document.documentElement).fontSize)||16:1,q=k.unit==="rem"||k.unit==="em"?E*$:E,j=a[a.length-1];for(let T=0;T<a.length-1;T++){let D=a[T],K=a[T+1];if(q<=(D+K)/2){j=D;break}if(q<K){j=K;break}}q>a[a.length-1]&&(j=Math.round(q/8)*8),E=k.unit==="rem"||k.unit==="em"?Math.round(j/$*1e3)/1e3:j}let I=k.hasMoved&&E!==k.startValue;g.current=null,document.exitPointerLock(),I?t(`${E}${k.unit}`):k.hasMoved?o==null||o(`${k.startValue}${k.unit}`):v.current&&S.current&&S.current(),r==null||r()};return document.addEventListener("mousemove",O),document.addEventListener("mouseup",A),()=>{document.removeEventListener("mousemove",O),document.removeEventListener("mouseup",A)}},[t,o,r]);let w=wd(O=>{var E;if(O.button!==0)return;O.preventDefault();let A=Nn(e),k=A.unit&&A.unit!=="px"?A.unit:l;g.current={startValue:A.num,unit:k,accum:0,hasMoved:!1},(E=p.current)==null||E.requestPointerLock()},[e,l]);return kd("span",{ref:p,onMouseDown:w,title:i?"Click to reset \xB7 Drag to scrub":"Drag to scrub",style:f({color:i?s||"#3b82f6":c||"#999",padding:"0 4px",display:"flex",alignItems:"center",cursor:"ew-resize"},d),children:u})}import{Fragment as xi,jsx as Ce,jsxs as Nt}from"react/jsx-runtime";function Pd({gridCols:e,gridRows:t,gridModified:o,accentColor:r,onColsChange:n,onRowsChange:i}){return Ce(an,{style:{width:100},children:Nt("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",padding:"8px 4px"},children:[Ce("input",{type:"number",min:1,max:12,value:e,onChange:s=>n(parseInt(s.target.value)||1),style:h(f({},Yt),{width:32,textAlign:"center",padding:2})}),Ce("span",{style:{fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:o?r:"#999",fontWeight:o?600:400,fontSize:11,margin:"0 4px"},children:"\xD7"}),Ce("input",{type:"number",min:1,max:12,value:t,onChange:s=>i(parseInt(s.target.value)||1),style:h(f({},Yt),{width:32,textAlign:"center",padding:2})})]})})}function Ml({element:e,getValue:t,getOriginalValue:o,handleChange:r,isModified:n,onResetProperty:i,isCollapsed:s,onToggle:l,sectionHeaderStyle:a,activeDropdown:c,onDropdownChange:d,panelContentRef:u,accentColor:p,onFieldHover:g,preferredUnit:S,onUnitCycle:v}){let b=d,w=t("display"),O=t("flex-direction"),A=Tl(w,O),k=w==="flex"||w==="inline-flex",E=w==="grid",I=k||E,$=t("width"),q=t("height"),j=n("width")?$:lr(e,"width"),T=n("height")?q:lr(e,"height"),D=vi($,j),K=vi(q,T),ee=t("min-width"),me=t("max-width"),ve=t("min-height"),ae=t("max-height"),Re=Eo(t("padding")),We=t("gap"),Me=t("row-gap"),ne=t("column-gap"),Ae=t("grid-template-columns"),G=t("grid-template-rows"),oe=t("overflow"),Ee=Ae.split(/\s+/).filter(J=>J&&J!=="none").length||1,ce=G.split(/\s+/).filter(J=>J&&J!=="none").length||1,[Ke,Te]=El(!1),xe=c!==null,ge=xe||Ke,Ge=xe?.3:Ke?.65:1,xt=({mode:J,icon:Ie,active:Fe})=>Ce("button",{type:"button",onClick:()=>Ll(J,r),style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center",padding:"6px 8px",border:"none",borderRadius:2,backgroundColor:Fe?Kn(p,.15):"transparent",color:Fe?p:"#64748b",cursor:"pointer",fontSize:14},children:Ie}),dt=(J,Ie,Fe)=>{Fe==="fixed"?r(J,Ie):r(J,xr(Fe,Ie))},Ve=J=>{let Ie=Eo(t("padding")),Fe=J||"0";r("padding",`${Ie.top} ${Fe} ${Ie.bottom} ${Fe}`)},z=J=>{let Ie=Eo(t("padding")),Fe=J||"0";r("padding",`${Fe} ${Ie.right} ${Fe} ${Ie.left}`)},[ie,Q]=El({}),Se=wo((J,Ie)=>Fe=>{Ie(Fe),Q(ft=>h(f({},ft),{[J]:Fe}))},[]),Le=wo(J=>{Q(Ie=>{let Fe=f({},Ie);return delete Fe[J],Fe})},[]),Ze=wo(J=>{let Ie=Eo(t("padding"));_e(e,"padding",`${Ie.top} ${J} ${Ie.bottom} ${J}`)},[e,t]),fe=wo(J=>{let Ie=Eo(t("padding"));_e(e,"padding",`${J} ${Ie.right} ${J} ${Ie.left}`)},[e,t]),lt=wo(J=>Ie=>{_e(e,J,Ie)},[e]),Qe=O==="column"||O==="column-reverse",Tt=J=>J==="center"?1:J==="flex-end"||J==="end"?2:0,Ot=Tt(t("justify-content")),st=Tt(t("align-items")),at=Qe?st:Ot,Dt=Qe?Ot:st,tt=br(null),vt=br({x:0,y:0}),$e=br({col:at,row:Dt});$e.current={col:at,row:Dt};let en=wo((J,Ie)=>{let Fe=["flex-start","center","flex-end"];Qe?(r("justify-content",Fe[Ie]),r("align-items",Fe[J])):(r("justify-content",Fe[J]),r("align-items",Fe[Ie]))},[Qe,r]),Kt=br(en);Kt.current=en,Cd(()=>{let Ie=Fe=>{let ft=tt.current;if(!ft||!Fe.composedPath().includes(ft))return;Fe.preventDefault(),Fe.stopPropagation(),vt.current.x+=Fe.deltaX,vt.current.y+=Fe.deltaY;let{col:Lt,row:pt}=$e.current,bt=!1;Math.abs(vt.current.x)>=30&&(Lt=Math.max(0,Math.min(2,Lt+(vt.current.x>0?1:-1))),vt.current.x=0,vt.current.y=0,bt=!0),!bt&&Math.abs(vt.current.y)>=30&&(pt=Math.max(0,Math.min(2,pt+(vt.current.y>0?1:-1))),vt.current.x=0,vt.current.y=0,bt=!0),bt&&(Lt!==$e.current.col||pt!==$e.current.row)&&Kt.current(Lt,pt)};return document.addEventListener("wheel",Ie,{passive:!1,capture:!0}),()=>document.removeEventListener("wheel",Ie,{capture:!0})},[]);let rn=()=>Ce("div",{ref:tt,onMouseEnter:()=>{Te(!0),u.current&&(u.current.style.overflowY="hidden")},onMouseLeave:()=>{Te(!1),u.current&&(u.current.style.overflowY="auto")},style:{width:56,height:56,backgroundColor:vn,borderRadius:2,display:"grid",gridTemplateColumns:"repeat(3, 1fr)",gridTemplateRows:"repeat(3, 1fr)",padding:6,gap:2,touchAction:"none"},children:[0,1,2].map(J=>[0,1,2].map(Ie=>Ce("button",{type:"button",onClick:()=>en(Ie,J),style:{width:"100%",height:"100%",display:"flex",alignItems:"center",justifyContent:"center",border:"none",backgroundColor:"transparent",cursor:"pointer",padding:0},children:Ie===at&&J===Dt?Ce("svg",{width:"10",height:"10",viewBox:"0 0 10 10",fill:"none",style:{flexShrink:0},children:Ie===0?Nt(xi,{children:[Ce("rect",{x:"1",y:"1.5",width:"8",height:"1.2",rx:"0.5",fill:p}),Ce("rect",{x:"1",y:"4.4",width:"5",height:"1.2",rx:"0.5",fill:p}),Ce("rect",{x:"1",y:"7.3",width:"7",height:"1.2",rx:"0.5",fill:p})]}):Ie===1?Nt(xi,{children:[Ce("rect",{x:"1",y:"1.5",width:"8",height:"1.2",rx:"0.5",fill:p}),Ce("rect",{x:"2.5",y:"4.4",width:"5",height:"1.2",rx:"0.5",fill:p}),Ce("rect",{x:"1.5",y:"7.3",width:"7",height:"1.2",rx:"0.5",fill:p})]}):Nt(xi,{children:[Ce("rect",{x:"1",y:"1.5",width:"8",height:"1.2",rx:"0.5",fill:p}),Ce("rect",{x:"4",y:"4.4",width:"5",height:"1.2",rx:"0.5",fill:p}),Ce("rect",{x:"2",y:"7.3",width:"7",height:"1.2",rx:"0.5",fill:p})]})}):Ce("div",{style:{width:5,height:5,borderRadius:"50%",backgroundColor:"#aaa"}})},`${J}-${Ie}`)))}),mn=n("grid-template-columns")||n("grid-template-rows");return Nt("div",{style:{borderBottom:"1px solid rgba(0,0,0,0.08)"},children:[Ce("div",{style:a,children:Ce("span",{children:I?"Auto layout":"Layout"})}),Nt("div",{style:{padding:"8px 12px"},children:[Nt("div",{style:{display:"flex",gap:2,marginBottom:8,backgroundColor:vn,borderRadius:2,padding:2,opacity:Ge,transition:"opacity 150ms ease"},children:[Ce(xt,{mode:"block",icon:Ce(Rd,{size:16}),active:A==="block"}),Ce(xt,{mode:"flex-col",icon:Ce(Ad,{size:16}),active:A==="flex-col"}),Ce(xt,{mode:"flex-row",icon:Ce(Ld,{size:16}),active:A==="flex-row"}),Ce(xt,{mode:"grid",icon:Ce(Id,{size:16}),active:A==="grid"})]}),Nt("div",{style:{display:"flex",gap:4,marginBottom:8},children:[Ce(Si,{label:"W",property:"width",cssValue:D==="fixed"?$:`${Math.round(e.getBoundingClientRect().width)}px`,mode:D,onValueChange:J=>r("width",J),onModeChange:J=>{if(J==="fixed"){let Ie=e.getBoundingClientRect();r("width",`${Math.round(Ie.width)}px`)}else r("width",xr(J,$))},modified:n("width"),dimmed:xe&&c!=="width",dropdownOpen:c==="width",onDropdownChange:J=>b(J?"width":null),panelContentRef:u,accentColor:p,onReset:()=>i("width"),minValue:ee!=="none"&&ee!=="0px"&&ee!=="auto"?ee:"",maxValue:me!=="none"&&me!=="auto"?me:"",onMinChange:J=>r("min-width",J||"0"),onMaxChange:J=>r("max-width",J||"none"),onMinReset:()=>i("min-width"),onMaxReset:()=>i("max-width"),minModified:n("min-width"),maxModified:n("max-width")}),Ce(Si,{label:"H",property:"height",cssValue:K==="fixed"?q:`${Math.round(e.getBoundingClientRect().height)}px`,mode:K,onValueChange:J=>r("height",J),onModeChange:J=>{if(J==="fixed"){let Ie=e.getBoundingClientRect();r("height",`${Math.round(Ie.height)}px`)}else r("height",xr(J,q))},modified:n("height"),dimmed:xe&&c!=="height",dropdownOpen:c==="height",onDropdownChange:J=>b(J?"height":null),panelContentRef:u,minValue:ve!=="none"&&ve!=="0px"&&ve!=="auto"?ve:"",maxValue:ae!=="none"&&ae!=="auto"?ae:"",onMinChange:J=>r("min-height",J||"0"),onMaxChange:J=>r("max-height",J||"none"),onMinReset:()=>i("min-height"),onMaxReset:()=>i("max-height"),minModified:n("min-height"),maxModified:n("max-height"),accentColor:p,onReset:()=>i("height")})]}),k&&Nt("div",{onMouseEnter:()=>g==null?void 0:g("gap"),onMouseLeave:()=>g==null?void 0:g("element"),style:{display:"flex",gap:8,marginBottom:8},children:[Ce("div",{style:{opacity:xe?.3:1,transition:"opacity 150ms ease"},children:rn()}),Nt("div",{style:{flex:1,opacity:Ge,transition:"opacity 150ms ease"},children:[Ce("div",{onClick:n("gap")?()=>i("gap"):void 0,title:n("gap")?"Click to reset":void 0,style:{fontSize:9,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:n("gap")?p:"#999",fontWeight:n("gap")?600:400,marginBottom:2,cursor:n("gap")?"pointer":"default"},children:"Gap"}),Ce(an,{dimmed:xe,children:Nt("div",{style:{display:"flex",alignItems:"center"},children:[Ce(So,{value:We,onChange:J=>{Le("gap"),r("gap",J)},onPreview:Se("gap",lt("gap")),onScrubEnd:()=>Le("gap"),onReset:()=>i("gap"),isModified:n("gap"),accentColor:p,defaultUnit:S,children:O==="column"||O==="column-reverse"?Ce(Cl,{size:12,strokeWidth:n("gap")?2.5:1.5}):Ce(kl,{size:12,strokeWidth:n("gap")?2.5:1.5})}),Ce(xn,{property:"gap",value:ie.gap||We,onChange:J=>r("gap",J),isModified:n("gap")||"gap"in ie,style:h(f({},Yt),{flex:1,minWidth:0}),unitStyle:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999",padding:"0 8px"},preferredUnit:S,onUnitCycle:v})]})})]})]}),E&&Nt("div",{onMouseEnter:()=>g==null?void 0:g("gap"),onMouseLeave:()=>g==null?void 0:g("element"),style:{display:"flex",gap:8,marginBottom:8,opacity:Ge,transition:"opacity 150ms ease"},children:[Ce(Pd,{gridCols:Ee,gridRows:ce,gridModified:mn,accentColor:p,onColsChange:J=>r("grid-template-columns",`repeat(${J}, 1fr)`),onRowsChange:J=>r("grid-template-rows",`repeat(${J}, 1fr)`)}),Nt("div",{style:{flex:1,display:"flex",flexDirection:"column",gap:4},children:[Ce(an,{dimmed:xe,children:Nt("div",{style:{display:"flex",alignItems:"center"},children:[Ce(So,{value:ne||We,onChange:J=>{Le("column-gap"),r("column-gap",J)},onPreview:Se("column-gap",lt("column-gap")),onScrubEnd:()=>Le("column-gap"),onReset:()=>i("column-gap"),isModified:n("column-gap"),accentColor:p,defaultUnit:S,children:Ce(kl,{size:12,strokeWidth:n("column-gap")?2.5:1.5})}),Ce(xn,{property:"column-gap",value:ie["column-gap"]||ne||We,onChange:J=>r("column-gap",J),isModified:n("column-gap")||"column-gap"in ie,placeholder:"col",style:h(f({},Yt),{flex:1,minWidth:0}),unitStyle:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999",padding:"0 8px"},preferredUnit:S,onUnitCycle:v})]})}),Ce(an,{dimmed:xe,children:Nt("div",{style:{display:"flex",alignItems:"center"},children:[Ce(So,{value:Me||We,onChange:J=>{Le("row-gap"),r("row-gap",J)},onPreview:Se("row-gap",lt("row-gap")),onScrubEnd:()=>Le("row-gap"),onReset:()=>i("row-gap"),isModified:n("row-gap"),accentColor:p,defaultUnit:S,children:Ce(Cl,{size:12,strokeWidth:n("row-gap")?2.5:1.5})}),Ce(xn,{property:"row-gap",value:ie["row-gap"]||Me||We,onChange:J=>r("row-gap",J),isModified:n("row-gap")||"row-gap"in ie,placeholder:"row",style:h(f({},Yt),{flex:1,minWidth:0}),unitStyle:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999",padding:"0 8px"},preferredUnit:S,onUnitCycle:v})]})})]})]}),I&&Nt("div",{onMouseEnter:()=>g==null?void 0:g("padding"),onMouseLeave:()=>g==null?void 0:g("element"),style:{display:"flex",gap:4,marginBottom:8,opacity:Ge,transition:"opacity 150ms ease"},children:[Ce(an,{style:{flex:1},dimmed:xe,children:Nt("div",{style:{display:"flex",alignItems:"center"},children:[Ce(So,{value:Re.left,onChange:J=>{Le("padding-h"),Ve(J)},onPreview:Se("padding-h",Ze),onScrubEnd:()=>Le("padding-h"),onReset:()=>i("padding"),isModified:n("padding"),accentColor:p,defaultUnit:S,snapSteps:bi,children:Ce(Md,{size:12,strokeWidth:n("padding")?2.5:1.5})}),Ce(xn,{property:"padding",value:ie["padding-h"]||Re.left,onChange:J=>Ve(J),isModified:n("padding")||"padding-h"in ie,placeholder:"H pad",style:h(f({},Yt),{flex:1,minWidth:0}),unitStyle:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999",padding:"0 8px"},preferredUnit:S,onUnitCycle:v})]})}),Ce(an,{style:{flex:1},dimmed:xe,children:Nt("div",{style:{display:"flex",alignItems:"center"},children:[Ce(So,{value:Re.top,onChange:J=>{Le("padding-v"),z(J)},onPreview:Se("padding-v",fe),onScrubEnd:()=>Le("padding-v"),onReset:()=>i("padding"),isModified:n("padding"),accentColor:p,defaultUnit:S,snapSteps:bi,children:Ce(Td,{size:12,strokeWidth:n("padding")?2.5:1.5})}),Ce(xn,{property:"padding",value:ie["padding-v"]||Re.top,onChange:J=>z(J),isModified:n("padding")||"padding-v"in ie,placeholder:"V pad",style:h(f({},Yt),{flex:1,minWidth:0}),unitStyle:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999",padding:"0 8px"},preferredUnit:S,onUnitCycle:v})]})})]}),Nt("label",{style:{display:"flex",alignItems:"center",gap:8,cursor:"pointer",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#64748b",opacity:Ge,transition:"opacity 150ms ease"},children:[Ce("input",{type:"checkbox",checked:oe==="hidden",onChange:J=>r("overflow",J.target.checked?"hidden":"visible"),style:{margin:0,accentColor:p}}),"Clip content"]})]})]})}import{AlignCenter as Bd,AlignJustify as Od,AlignLeft as Dd,AlignRight as Hd,Baseline as Fd,ChevronDown as Nd,WholeWord as _d}from"lucide-react";import{jsx as ct,jsxs as An}from"react/jsx-runtime";var Il={100:"Thin",200:"Extra Light",300:"Light",400:"Regular",500:"Medium",600:"Semi Bold",700:"Bold",800:"Extra Bold",900:"Black"};function Rl({element:e,getValue:t,handleChange:o,isModified:r,onResetProperty:n,isCollapsed:i,onToggle:s,sectionHeaderStyle:l,accentColor:a,colorVariables:c,activeColorDropdown:d,onColorDropdownChange:u,panelContentRef:p,preferredUnit:g,onUnitCycle:S}){var K;let v=t("font-family"),b=t("font-size"),w=t("font-weight"),O=t("line-height"),A=t("letter-spacing"),k=t("text-align"),E=t("color"),I=String(w),$=Il[I]||I,q=_o(e,E),j=E.includes("var(")?null:zo(q,c),T=({align:ee,icon:me})=>{let ve=k===ee;return ct("button",{type:"button",onClick:()=>o("text-align",ee),style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center",padding:"6px 8px",border:"none",borderRadius:2,backgroundColor:ve?Kn(a,.15):"transparent",color:ve?a:"#64748b",cursor:"pointer"},children:me})},D=((K=v.split(",")[0])==null?void 0:K.trim().replace(/^["']|["']$/g,""))||"System";return An("div",{style:{borderBottom:"1px solid rgba(0,0,0,0.08)"},children:[ct("div",{style:l,children:ct("span",{children:"Typography"})}),An("div",{style:{padding:"8px 12px",display:"flex",flexDirection:"column",gap:4},children:[ct(an,{children:An("div",{style:{display:"flex",alignItems:"center",padding:"6px 8px"},children:[ct("input",{type:"text",value:v,onChange:ee=>o("font-family",ee.target.value),style:h(f({},Yt),{flex:1,minWidth:0,padding:0,fontWeight:r("font-family")?600:400,color:r("font-family")?a:"inherit"}),title:v}),ct(Nd,{size:12,style:{color:"#999",flexShrink:0,marginLeft:4}})]})}),An("div",{style:{display:"flex",gap:4},children:[ct(an,{style:{flex:1},children:ct("select",{value:I,onChange:ee=>o("font-weight",ee.target.value),style:h(f({},Yt),{padding:"6px 8px",paddingLeft:4,paddingRight:20,cursor:"pointer",fontWeight:r("font-weight")?600:400,color:r("font-weight")?a:"inherit"}),children:Object.entries(Il).map(([ee,me])=>ct("option",{value:ee,children:me},ee))})}),ct(an,{style:{flex:1},children:ct("div",{style:{display:"flex",alignItems:"center",position:"relative"},children:ct(xn,{property:"font-size",value:b,onChange:ee=>o("font-size",ee),isModified:r("font-size"),min:1,max:999,style:h(f({},Yt),{padding:"6px 8px",paddingRight:24,fontWeight:r("font-size")?600:400,color:r("font-size")?a:"inherit"}),unitStyle:{position:"absolute",right:8,top:"50%",transform:"translateY(-50%)",fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999"},preferredUnit:g,onUnitCycle:S})})})]}),An("div",{style:{display:"flex",gap:4},children:[ct(an,{style:{flex:1},children:An("div",{style:{display:"flex",alignItems:"center",padding:"6px 8px",gap:4},children:[ct(Fd,{size:12,style:{color:r("line-height")?a:"#999",flexShrink:0}}),ct(xn,{property:"line-height",value:O,onChange:ee=>o("line-height",ee),isModified:r("line-height"),step:.1,min:0,placeholder:"Auto",style:h(f({},Yt),{flex:1,minWidth:0,padding:0,fontWeight:r("line-height")?600:400,color:r("line-height")?a:"inherit"}),showUnit:!1})]})}),ct(an,{style:{flex:1},children:An("div",{style:{display:"flex",alignItems:"center",padding:"6px 8px",gap:4},children:[ct(_d,{size:12,style:{color:r("letter-spacing")?a:"#999",flexShrink:0}}),ct(xn,{property:"letter-spacing",value:A,onChange:ee=>o("letter-spacing",ee),isModified:r("letter-spacing"),step:.1,placeholder:"\u2014",style:h(f({},Yt),{flex:1,minWidth:0,padding:0,fontWeight:r("letter-spacing")?600:400,color:r("letter-spacing")?a:"inherit"}),showUnit:!1})]})})]}),An("div",{style:{display:"flex",gap:2,backgroundColor:vn,borderRadius:2,padding:2},children:[ct(T,{align:"left",icon:ct(Dd,{size:14})}),ct(T,{align:"center",icon:ct(Bd,{size:14})}),ct(T,{align:"right",icon:ct(Hd,{size:14})}),ct(T,{align:"justify",icon:ct(Od,{size:14})})]}),An("div",{style:{display:"flex",alignItems:"center",gap:8,padding:"4px 0"},children:[ct("span",{onClick:r("color")?()=>n("color"):void 0,title:r("color")?"Click to reset":void 0,style:{fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:r("color")?a:"#64748b",fontWeight:r("color")?600:400,cursor:r("color")?"pointer":"default",width:40,flexShrink:0},children:"Color"}),ct("div",{style:{flex:1,minWidth:0},children:ct(wi,{value:E,resolvedValue:q,colorVariables:c,matchingVariable:j,onChange:ee=>o("color",ee),accentColor:a,modified:r("color"),panelContentRef:p,isDropdownOpen:d==="color",onDropdownChange:ee=>u(ee?"color":null)})})]})]})]})}import{Fragment as jd,jsx as pe,jsxs as ht}from"react/jsx-runtime";var Pl=[{name:"Background",properties:[{property:"background-color",label:"Color",type:"color"},{property:"opacity",label:"Opacity",type:"number",step:.1,min:0,max:1}]},{name:"Borders",properties:[{property:"border-width",label:"Width",type:"number",min:0,max:20},{property:"border-color",label:"Color",type:"color"},{property:"border-radius",label:"Radius",type:"number",min:0,max:100},{property:"border-style",label:"Style",type:"select",options:["none","solid","dashed","dotted","double"]}]},{name:"Effects",properties:[{property:"box-shadow",label:"Box Shadow",type:"text"},{property:"backdrop-filter",label:"Backdrop Filter",type:"backdrop-filter"},{property:"transform",label:"Transform",type:"text"}]}];function Yd(e,t){let o=t.trim().toLowerCase();switch(e){case"opacity":return o==="1";case"border-width":return o==="0px"||o==="0"||o==="medium";case"border-radius":return o==="0px"||o==="0";case"border-style":return o==="none";case"box-shadow":return o==="none";case"backdrop-filter":return o==="none"||o==="";case"letter-spacing":return o==="normal"||o==="0px"||o==="0";case"background-color":return o==="rgba(0, 0, 0, 0)"||o==="transparent";default:return!1}}function vi(e,t){return!t||e==="auto"||e==="fit-content"||e==="max-content"||e==="min-content"?"hug":e==="100%"||t==="100%"?"fill":"fixed"}function xr(e,t){switch(e){case"hug":return"fit-content";case"fill":return"100%";case"fixed":{let o=Nn(t);if(typeof o.num=="number"&&!isNaN(o.num)){let r=o.unit==="%"?"px":o.unit||"px";return`${o.num}${r}`}return"auto"}}}function Eo(e){let t=e.split(/\s+/).filter(Boolean);return t.length===1?{top:t[0],right:t[0],bottom:t[0],left:t[0]}:t.length===2?{top:t[0],right:t[1],bottom:t[0],left:t[1]}:t.length===3?{top:t[0],right:t[1],bottom:t[2],left:t[1]}:t.length>=4?{top:t[0],right:t[1],bottom:t[2],left:t[3]}:{top:"0px",right:"0px",bottom:"0px",left:"0px"}}function Tl(e,t){return e==="grid"?"grid":e==="flex"||e==="inline-flex"?t==="column"||t==="column-reverse"?"flex-col":"flex-row":"block"}function Ll(e,t){switch(e){case"block":t("display","block");break;case"flex-row":t("display","flex"),t("flex-direction","row");break;case"flex-col":t("display","flex"),t("flex-direction","column");break;case"grid":t("display","grid");break}}var vn="rgba(0, 0, 0, 0.04)",Yt={width:"100%",padding:"4px 8px",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',border:"none",borderRadius:2,outline:"none",backgroundColor:"transparent"};function Si({label:e,property:t,cssValue:o,mode:r,onValueChange:n,onModeChange:i,modified:s,dimmed:l,dropdownOpen:a,onDropdownChange:c,panelContentRef:d,accentColor:u="#3b82f6",onReset:p,minValue:g,maxValue:S,onMinChange:v,onMaxChange:b,onMinReset:w,onMaxReset:O,minModified:A,maxModified:k}){let E=Nn(o),I=s?E.unit||vo(t):vo(t),$=!s&&E.unit&&E.unit!==I?hi(E.num,I):E.num,[q,j]=jt(!1),[T,D]=jt(String($)),[K,ee]=jt(!1),me=on(null),ve=on(null),ae=on(null),Re=on(!1);gn(()=>{q||D(String($))},[$,q]),gn(()=>{if(!a)return;let ce=Te=>{ve.current&&!Te.composedPath().includes(ve.current)&&ae.current&&!Te.composedPath().includes(ae.current)&&(c==null||c(!1))},Ke=Te=>{Te.key==="Escape"&&(c==null||c(!1))};return document.addEventListener("mousedown",ce),document.addEventListener("keydown",Ke),()=>{document.removeEventListener("mousedown",ce),document.removeEventListener("keydown",Ke)}},[a,c]),gn(()=>{q&&me.current&&(me.current.focus(),me.current.select())},[q]);let We=()=>{let ce=hr(T,t,o,s);n(ce||`${Math.max(0,parseFloat(T)||0)}${I}`),j(!1)},Me=()=>{if(Re.current){Re.current=!1;return}We()},ne=ce=>{if(ce.key==="Enter"){We();return}if(ce.key==="Escape"){Re.current=!0,D(String($)),j(!1);return}if(ce.key==="ArrowUp"||ce.key==="ArrowDown"){ce.preventDefault();let Ke=ce.key==="ArrowUp"?1:-1,Te=ce.shiftKey?8:ce.altKey?.1:1,xe=parseFloat(T)||0,ge=Math.round(Math.max(0,xe+Ke*Te)*1e3)/1e3;D(String(ge)),n(`${ge}${I}`)}},Ae={fixed:"Fixed",hug:"Hug",fill:"Fill"},G={fixed:pe(Al,{size:12}),hug:pe($d,{size:12}),fill:pe(Al,{size:12})},oe=()=>{c==null||c(!a)},Ee=()=>{if(!ae.current||!(d!=null&&d.current))return{position:"absolute",top:"100%",left:-4,right:-4,width:"calc(100% + 8px)",marginTop:4};let ce=ae.current.getBoundingClientRect(),Ke=d.current.getBoundingClientRect(),Te=d.current.closest('[data-devtools="panel"]'),xe=Te?Te.getBoundingClientRect():{top:0,left:0};return{position:"fixed",top:ce.bottom+4-xe.top,left:Ke.left+4-xe.left,width:Ke.width-8}};return ht("div",{ref:ae,onMouseEnter:()=>ee(!0),onMouseLeave:()=>ee(!1),style:{flex:1,display:"flex",alignItems:"center",position:"relative",borderRadius:2,border:"1px solid",borderColor:q?u:K?"rgba(0,0,0,0.15)":"transparent",backgroundColor:vn,transition:"border-color 100ms ease, opacity 150ms ease",opacity:l?.3:1},children:[pe("span",{onClick:s&&p?p:void 0,title:s?"Click to reset":void 0,style:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:s?u:"#999",fontWeight:s?600:400,padding:"0 8px",flexShrink:0,cursor:s?"pointer":"default"},children:e}),r==="fixed"?q?pe("input",{ref:me,type:"text",inputMode:"numeric",value:T,onChange:ce=>D(ce.target.value),onKeyDown:ne,onBlur:Me,style:h(f({},Yt),{flex:1,minWidth:0,padding:"4px 2px"})}):pe("span",{onClick:()=>j(!0),style:{flex:1,padding:"4px 2px",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',cursor:"text"},children:$}):pe("span",{style:{flex:1}}),ht("button",{type:"button",onClick:oe,style:{display:"flex",alignItems:"center",gap:2,padding:"4px 8px",border:"none",outline:"none",backgroundColor:"transparent",color:"#999",fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',cursor:"pointer",flexShrink:0},children:[Ae[r],pe(Ei,{size:12})]}),a&&ht("div",{ref:ve,style:h(f({},Ee()),{backgroundColor:"#ffffff",border:"1px solid rgba(0,0,0,0.1)",borderRadius:0,zIndex:10001,overflow:"hidden",fontSize:12,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace'}),children:[ht("button",{type:"button",onClick:()=>{i("fixed"),c==null||c(!1)},style:{width:"100%",display:"flex",alignItems:"center",gap:8,padding:"10px 12px",border:"none",outline:"none",backgroundColor:r==="fixed"?"#f1f5f9":"transparent",color:"#1e293b",fontWeight:r==="fixed"?600:400,cursor:"pointer",textAlign:"left"},children:[G.fixed,ht("span",{children:["Fixed ",t," (",o,")"]}),r==="fixed"&&pe(vr,{size:14,style:{marginLeft:"auto"}})]}),ht("button",{type:"button",onClick:()=>{i("hug"),c==null||c(!1)},style:{width:"100%",display:"flex",alignItems:"center",gap:8,padding:"10px 12px",border:"none",outline:"none",backgroundColor:r==="hug"?"#f1f5f9":"transparent",color:"#1e293b",fontWeight:r==="hug"?600:400,cursor:"pointer",textAlign:"left"},children:[G.hug,pe("span",{children:"Hug contents"}),r==="hug"&&pe(vr,{size:14,style:{marginLeft:"auto"}})]}),ht("button",{type:"button",onClick:()=>{i("fill"),c==null||c(!1)},style:{width:"100%",display:"flex",alignItems:"center",gap:8,padding:"10px 12px",border:"none",outline:"none",backgroundColor:r==="fill"?"#f1f5f9":"transparent",color:"#1e293b",fontWeight:r==="fill"?600:400,cursor:"pointer",textAlign:"left"},children:[G.fill,pe("span",{children:"Fill container"}),r==="fill"&&pe(vr,{size:14,style:{marginLeft:"auto"}})]}),pe("div",{style:{borderTop:"1px solid rgba(0,0,0,0.08)",margin:"4px 0"}}),ht("div",{style:{padding:"8px 12px",display:"flex",flexDirection:"column",gap:4},children:[ht("div",{style:{display:"flex",alignItems:"center",backgroundColor:vn,borderRadius:2,padding:"4px 8px"},children:[pe("span",{onClick:A?ce=>{ce.stopPropagation(),w==null||w()}:void 0,title:A?"Click to reset":void 0,style:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:A?u:"#999",fontWeight:A?600:400,marginRight:8,flexShrink:0,cursor:A?"pointer":"default"},children:"Min"}),pe("input",{type:"text",value:g||"",placeholder:"\u2014",onChange:ce=>v==null?void 0:v(ce.target.value),onClick:ce=>ce.stopPropagation(),style:h(f({},Yt),{flex:1,minWidth:0,padding:0,textAlign:"right",color:A?u:"inherit",fontWeight:A?600:400})})]}),ht("div",{style:{display:"flex",alignItems:"center",backgroundColor:vn,borderRadius:2,padding:"4px 8px"},children:[pe("span",{onClick:k?ce=>{ce.stopPropagation(),O==null||O()}:void 0,title:k?"Click to reset":void 0,style:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:k?u:"#999",fontWeight:k?600:400,marginRight:8,flexShrink:0,cursor:k?"pointer":"default"},children:"Max"}),pe("input",{type:"text",value:S||"",placeholder:"\u2014",onChange:ce=>b==null?void 0:b(ce.target.value),onClick:ce=>ce.stopPropagation(),style:h(f({},Yt),{flex:1,minWidth:0,padding:0,textAlign:"right",color:k?u:"inherit",fontWeight:k?600:400})})]})]})]})]})}function an({children:e,style:t,dimmed:o}){let[r,n]=jt(!1);return pe("div",{onMouseEnter:()=>n(!0),onMouseLeave:()=>n(!1),style:f({position:"relative",borderRadius:2,border:"1px solid",borderColor:r?"rgba(0,0,0,0.15)":"transparent",backgroundColor:vn,transition:"border-color 100ms ease, opacity 150ms ease",opacity:o?.3:1},t),children:e})}function Rn({children:e}){let[t,o]=jt(!1);return pe("div",{onMouseEnter:()=>o(!0),onMouseLeave:()=>o(!1),style:{position:"relative",borderRadius:2,border:"1px solid",borderColor:t?"rgba(0,0,0,0.15)":"transparent",backgroundColor:vn,transition:"border-color 100ms ease"},children:e})}function xn({property:e,value:t,onChange:o,isModified:r=!1,step:n=1,min:i,max:s,style:l,placeholder:a,showUnit:c=!0,unitStyle:d,preferredUnit:u,onUnitCycle:p}){let g=Nn(t),S=vo(e),v=mr[e],w=u&&v&&v.includes(u)?u:S,O=r&&g.unit||w,A=!r&&g.unit&&g.unit!==O?hi(g.num,O):g.num,[k,E]=jt(!1),[I,$]=jt(""),q=Me=>{E(!0),$(String(A||"")),requestAnimationFrame(()=>Me.target.select())},j=()=>{if(E(!1),I.trim()){let Me=hr(I,e,t,r);Me&&o(Me)}},T=Me=>{let ne=Me.target.value;$(ne);let Ae=ne.trim(),G=Ae.match(/^(-?[\d.]+)\s*(rem|em|px|%)$/i),oe=Ae.match(/^(-?[\d.]+)$/);if(G){let Ee=parseFloat(G[1]);isNaN(Ee)||o(`${Ee}${G[2].toLowerCase()}`)}else if(oe){let Ee=parseFloat(oe[1]);isNaN(Ee)||o(`${Ee}${O}`)}},D=Me=>{if(Me.key==="Enter"){if(I.trim()){let ne=hr(I,e,t,r);ne&&o(ne)}Me.target.blur();return}if(Me.key==="ArrowUp"||Me.key==="ArrowDown"){Me.preventDefault();let ne=Me.shiftKey?10:Me.altKey?.1:1,Ae=(Me.key==="ArrowUp"?1:-1)*n*ne,G=parseFloat(I)||A||0,oe=Math.round((G+Ae)*1e3)/1e3;i!==void 0&&(oe=Math.max(i,oe)),s!==void 0&&(oe=Math.min(s,oe)),$(String(oe)),o(`${oe}${O}`)}},K=/^-?[\d.]/.test(t.trim()),ee=k?I:K?String(A):"",ve=k&&/\s*(rem|em|px|%)\s*$/i.test(I)?"":O,ae=p&&(ve==="rem"||ve==="px"),Re={fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999",pointerEvents:"none"},We=h(f({},d!=null?d:Re),{pointerEvents:"auto",cursor:"pointer"});return ht(jd,{children:[pe("input",{type:"text",inputMode:"decimal",value:ee,onFocus:q,onBlur:j,onChange:T,onKeyDown:D,placeholder:a,style:l}),c&&ve&&pe("span",{style:ae?We:d!=null?d:Re,onClick:ae?p:void 0,title:ae?"Click to switch units":void 0,children:ve})]})}function wi({value:e,resolvedValue:t,colorVariables:o,matchingVariable:r,onChange:n,accentColor:i="#3b82f6",modified:s,panelContentRef:l,isDropdownOpen:a,onDropdownChange:c}){let[d,u]=jt(!1),p=!e.includes("var(")&&r?r.usage:e,[g,S]=jt(p),[v,b]=jt(!1),[w,O]=jt(!1),[A,k]=jt(!1),E=on(null),I=on(null),$=on(null),q=a!==void 0?a:v,j=c||b,T=Mn(()=>{if(!$.current)return{position:"fixed",top:0,left:0,width:200};let ne=$.current.getBoundingClientRect(),Ae=$.current.closest('[data-devtools="panel"]'),G=Ae?Ae.getBoundingClientRect():{top:0,left:0};if(l!=null&&l.current){let oe=l.current.getBoundingClientRect();return{position:"fixed",top:ne.bottom+4-G.top,left:oe.left+4-G.left,width:oe.width-8}}return{position:"fixed",top:ne.bottom+4-G.top,left:ne.left-G.left,width:ne.width}},[l]);gn(()=>{if(!d){let ne=!e.includes("var(")&&r?r.usage:e;S(ne)}},[e,d,r]),gn(()=>{if(!q&&!w)return;let ne=G=>{$.current&&!G.composedPath().includes($.current)&&(j(!1),O(!1))},Ae=G=>{G.key==="Escape"&&(j(!1),O(!1))};return document.addEventListener("mousedown",ne),document.addEventListener("keydown",Ae),()=>{document.removeEventListener("mousedown",ne),document.removeEventListener("keydown",Ae)}},[q,w]),gn(()=>{d&&E.current&&(E.current.focus(),E.current.select())},[d]);let D=Sr(()=>{if(!g||g.startsWith("#")||g.startsWith("rgb")||g.startsWith("hsl")||g.startsWith("oklch"))return[];let ne=g.toLowerCase();return o.filter(Ae=>Ae.name.toLowerCase().includes(ne)||Ae.usage.toLowerCase().includes(ne)).slice(0,8)},[g,o]),K=()=>{n(g),u(!1),O(!1)},ee=ne=>{S(ne),ne.includes("var")||ne.includes("--")||ne.length>0&&!ne.startsWith("#")?O(!0):O(!1)},me=ne=>{S(ne.usage),n(ne.usage),j(!1),O(!1),u(!1)},ve=()=>{setTimeout(()=>{!q&&!w&&K()},150)},ae=ne=>{ne.key==="Enter"?K():ne.key==="Escape"&&(S(e),u(!1),O(!1))},Re=Sr(()=>{let ne=t.trim().toLowerCase();if(ne.startsWith("#"))return ne.length===4?`#${ne[1]}${ne[1]}${ne[2]}${ne[2]}${ne[3]}${ne[3]}`:ne.slice(0,7);let Ae=ne.match(/rgba?\((\d+),?\s*(\d+),?\s*(\d+)/);if(Ae){let oe=parseInt(Ae[1],10).toString(16).padStart(2,"0"),Ee=parseInt(Ae[2],10).toString(16).padStart(2,"0"),ce=parseInt(Ae[3],10).toString(16).padStart(2,"0");return`#${oe}${Ee}${ce}`}let G=ne.match(/oklch\(\s*([\d.]+)/);if(G){let oe=Math.max(0,Math.min(1,parseFloat(G[1]))),Ee=Math.round(oe*255).toString(16).padStart(2,"0");return`#${Ee}${Ee}${Ee}`}return"#000000"},[t]),We=ne=>{let Ae=ne.target.value;S(Ae),n(Ae)},Me=e.includes("var(");return ht("div",{ref:$,onMouseEnter:()=>k(!0),onMouseLeave:()=>k(!1),style:{position:"relative",borderRadius:2,border:"1px solid",borderColor:d?i:A?"rgba(0,0,0,0.15)":"transparent",backgroundColor:vn,transition:"border-color 100ms ease",overflow:"hidden"},children:[ht("div",{style:{display:"flex",alignItems:"center",minWidth:0},children:[ht("div",{style:{position:"relative",marginLeft:8,flexShrink:0},children:[pe("input",{type:"color",value:Re,onChange:We,style:{width:12,height:12,padding:0,border:"none",cursor:"pointer",opacity:0,position:"absolute",top:0,left:0}}),pe("div",{style:{width:12,height:12,borderRadius:2,backgroundColor:t,border:"1px solid rgba(0,0,0,0.1)",pointerEvents:"none"}})]}),d?pe("input",{ref:E,type:"text",value:g,onChange:ne=>ee(ne.target.value),onKeyDown:ae,onBlur:ve,style:h(f({},Yt),{flex:1,minWidth:0})}):pe("span",{onClick:()=>u(!0),style:{flex:1,minWidth:0,padding:"4px 8px",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',cursor:"text",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",color:s?i:"inherit"},title:p,children:p}),o.length>0&&pe("button",{type:"button",onClick:()=>j(!q),style:{display:"flex",alignItems:"center",justifyContent:"center",width:20,height:24,border:"none",background:"none",cursor:"pointer",color:"#999",flexShrink:0},children:pe(Ei,{size:12})})]}),w&&D.length>0&&pe("div",{style:h(f({},T()),{backgroundColor:"#ffffff",border:"1px solid rgba(0,0,0,0.1)",borderRadius:0,zIndex:10001,maxHeight:200,overflowY:"auto",fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace'}),children:D.map(ne=>ht("button",{type:"button",onClick:()=>me(ne),style:{width:"100%",display:"flex",alignItems:"center",gap:8,padding:"10px 12px",border:"none",backgroundColor:"transparent",color:"#1e293b",cursor:"pointer",textAlign:"left",fontSize:12},children:[pe("div",{style:{width:14,height:14,borderRadius:2,backgroundColor:ne.value,border:"1px solid rgba(0,0,0,0.1)",flexShrink:0}}),pe("span",{style:{flex:1,overflow:"hidden",textOverflow:"ellipsis"},children:ne.name})]},ne.name))}),q&&pe("div",{ref:I,style:h(f({},T()),{backgroundColor:"#ffffff",border:"1px solid rgba(0,0,0,0.1)",borderRadius:0,zIndex:10001,maxHeight:280,overflowY:"auto",fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace'}),children:o.map(ne=>ht("button",{type:"button",onClick:()=>me(ne),style:{width:"100%",display:"flex",alignItems:"center",gap:8,padding:"10px 12px",border:"none",backgroundColor:p===ne.usage||e===ne.usage?"#f1f5f9":"transparent",color:"#1e293b",fontWeight:p===ne.usage||e===ne.usage?600:400,cursor:"pointer",textAlign:"left",fontSize:12},children:[pe("div",{style:{width:14,height:14,borderRadius:2,backgroundColor:ne.value,border:"1px solid rgba(0,0,0,0.1)",flexShrink:0}}),pe("span",{style:{flex:1,overflow:"hidden",textOverflow:"ellipsis"},children:ne.name}),(p===ne.usage||e===ne.usage)&&pe(vr,{size:14,style:{marginLeft:"auto",flexShrink:0}})]},ne.name))})]})}function Bl({element:e,elementInfo:t,selector:o,styleModifications:r,dispatch:n,onClose:i,onHover:s,accentColor:l="#3b82f6",toolbarRef:a}){var dt,Ve;let c=on(null),d=on(null),[u,p]=jt(()=>{try{return!!localStorage.getItem("devtools-panel-position")}catch(z){return!1}});gn(()=>{if(u)return;let z=setTimeout(()=>p(!0),50);return()=>clearTimeout(z)},[u]);let[g,S]=jt(null),[v,b]=jt(null),w=g!==null||v!==null,[O,A]=jt("rem"),k=Mn(()=>{A(z=>z==="rem"?"px":"rem")},[]),E=on(new Map),[I,$]=jt(""),q=Sr(()=>ni(),[]);gn(()=>{let z=ie=>{var Se;if(ie.key!=="Escape")return;let Q=document.activeElement;Q&&((Se=c.current)!=null&&Se.contains(Q))||i()};return window.addEventListener("keydown",z),()=>window.removeEventListener("keydown",z)},[i]);let j=on({top:0,left:0,maxHeight:400}),[,T]=jt(0),D="devtools-panel-position",K=on({x:0,y:0}),ee=on(null),me=on(!1);gn(()=>{try{let z=localStorage.getItem(D);if(z){let ie=JSON.parse(z);typeof ie.top=="number"&&typeof ie.left=="number"&&(me.current=!0,j.current=h(f({},j.current),{top:ie.top,left:ie.left}))}}catch(z){}},[]),gn(()=>{let z=Q=>{var $e;let Se=ee.current;if(!Se)return;let Le=Se.startOffsetX+(Q.clientX-Se.startX),Ze=Se.startOffsetY+(Q.clientY-Se.startY),fe=280,lt=16,Qe=Math.max(lt,Math.min(window.innerWidth-fe-lt,j.current.left+Le)),Tt=Math.max(lt,j.current.top+Ze);K.current={x:Qe-j.current.left,y:Tt-j.current.top};let Ot=c.current,st=Ot==null?void 0:Ot.parentElement;if(!st)return;st.style.top=`${Tt}px`,st.style.left=`${Qe}px`;let at=($e=a==null?void 0:a.current)==null?void 0:$e.getBoundingClientRect(),Dt=window.innerHeight-16;at&&Qe+fe>at.left&&(Dt=at.top-8);let tt=Math.max(0,Tt),vt=Math.max(200,Dt-tt);Ot&&(Ot.style.maxHeight=`${vt}px`)},ie=()=>{if(!ee.current)return;let Q=j.current.top+K.current.y,Se=j.current.left+K.current.x;j.current=h(f({},j.current),{top:Q,left:Se}),K.current={x:0,y:0},me.current=!0;try{localStorage.setItem(D,JSON.stringify({top:Q,left:Se}))}catch(Le){}ee.current=null};return window.addEventListener("mousemove",z),window.addEventListener("mouseup",ie),()=>{window.removeEventListener("mousemove",z),window.removeEventListener("mouseup",ie)}},[]);let ve=Mn(z=>{z.button!==0||z.target.closest("button")||(z.preventDefault(),ee.current={startX:z.clientX,startY:z.clientY,startOffsetX:K.current.x,startOffsetY:K.current.y})},[]);gn(()=>{K.current={x:0,y:0};let z=(Se=!1)=>{var Dt;let Le=c.current,Ze=280,fe=8,lt,Qe;if(me.current)lt=j.current.top,Qe=j.current.left;else{let tt=e.getBoundingClientRect();Qe=tt.right+fe,lt=tt.top,Qe+Ze>window.innerWidth-fe&&(Qe=tt.left-Ze-fe),Qe<fe&&(Qe=Math.max(fe,(window.innerWidth-Ze)/2))}let Tt=(Dt=a==null?void 0:a.current)==null?void 0:Dt.getBoundingClientRect(),Ot=window.innerHeight-16;Tt&&Qe+Ze>Tt.left&&(Ot=Tt.top-fe);let st=Math.max(0,lt),at=Math.max(200,Ot-st);if(j.current={top:lt,left:Qe,maxHeight:at},Se&&Le){let tt=Le.parentElement;tt&&!me.current&&(tt.style.top=`${lt+K.current.y}px`,tt.style.left=`${Qe+K.current.x}px`),Le.style.maxHeight=`${at}px`}else T(tt=>tt+1)};z(!1);let ie=()=>z(!0),Q=()=>z(!1);return window.addEventListener("scroll",ie,{passive:!0}),window.addEventListener("resize",Q,{passive:!0}),()=>{window.removeEventListener("scroll",ie),window.removeEventListener("resize",Q)}},[e]),gn(()=>{let z=c.current;if(!z)return;let ie=Q=>{let Se=d.current;if(!Se){Q.preventDefault();return}let{scrollTop:Le,scrollHeight:Ze,clientHeight:fe}=Se,lt=Le<=0&&Q.deltaY<0,Qe=Le+fe>=Ze&&Q.deltaY>0;(lt||Qe)&&Q.preventDefault()};return z.addEventListener("wheel",ie,{passive:!1}),()=>z.removeEventListener("wheel",ie)},[]);let ae=Sr(()=>r.find(z=>z.selector===o),[r,o]),Re=Mn(z=>{let ie=ae==null?void 0:ae.changes.find(Q=>Q.property===z);if(ie)return ie.modified;if(z.includes("color")){let Q=Zr(e,z);if(Q&&Q.includes("var("))return Q}return Ho(e,z)},[e,ae]),We=Mn(z=>{if(E.current.has(z))return E.current.get(z);let ie=ae==null?void 0:ae.changes.find(Se=>Se.property===z);if(ie)return ie.original;let Q=Ho(e,z);return E.current.set(z,Q),Q},[e,ae]),Me=Mn((z,ie)=>{let Q=We(z);_e(e,z,ie),z==="backdrop-filter"&&_e(e,"-webkit-backdrop-filter",ie),n({type:"MODIFY_STYLE",payload:{selector:o,element:t,property:z,original:Q,modified:ie}})},[e,o,t,n,We]),ne=Mn(()=>{ti(o,r);let z=r.find(ie=>ie.selector===o);if(z)for(let ie of z.changes)n({type:"CLEAR_STYLE",payload:{selector:o,property:ie.property}});E.current.clear()},[o,r,n]),Ae=Mn(z=>{let ie=r.find(Se=>Se.selector===o);ie!=null&&ie.changes.find(Se=>Se.property===z)&&e instanceof HTMLElement&&(e.style.removeProperty(z),n({type:"CLEAR_STYLE",payload:{selector:o,property:z}}),E.current.delete(z))},[e,o,r,n]),G=Mn(()=>{let z=I.split(";").map(ie=>ie.trim()).filter(ie=>ie);for(let ie of z){let Q=ie.indexOf(":");if(Q>0){let Se=ie.slice(0,Q).trim(),Le=ie.slice(Q+1).trim();Se&&Le&&Me(Se,Le)}}$("")},[I,Me]),oe=Mn(z=>{var ie;return(ie=ae==null?void 0:ae.changes.some(Q=>Q.property===z))!=null?ie:!1},[ae]),Ee=z=>{var Ze;let ie=Re(z.property),Q=oe(z.property),Se=!Q&&Yd(z.property,ie),Le={width:"100%",padding:"4px 8px",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',border:"none",borderRadius:2,outline:"none",backgroundColor:"transparent"};if(Se&&z.type!=="backdrop-filter")return pe(Rn,{modified:!1,children:pe("input",{type:"text",value:"",placeholder:"\u2014",onFocus:()=>{},onChange:fe=>Me(z.property,fe.target.value),style:h(f({},Le),{color:"#999"})})});switch(z.type){case"color":{let fe=_o(e,ie),lt=ie.includes("var(")?null:zo(fe,q);return pe(wi,{value:ie,resolvedValue:fe,colorVariables:q,matchingVariable:lt,onChange:Qe=>Me(z.property,Qe),accentColor:l,modified:Q,panelContentRef:d,isDropdownOpen:v===z.property,onDropdownChange:Qe=>b(Qe?z.property:null)})}case"number":{if(!!mr[z.property])return pe(Rn,{modified:Q,children:pe(xn,{property:z.property,value:ie,onChange:Qe=>Me(z.property,Qe),isModified:Q,min:z.min,max:z.max,step:z.step||1,style:h(f({},Le),{paddingRight:32}),unitStyle:{position:"absolute",right:8,top:"50%",transform:"translateY(-50%)",fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999"},preferredUnit:O,onUnitCycle:k})});let{num:lt}=Nn(ie);return pe(Rn,{modified:Q,children:pe("input",{type:"number",value:lt,min:z.min,max:z.max,step:z.step||1,onChange:Qe=>Me(z.property,Qe.target.value),style:Le})})}case"select":return pe(Rn,{modified:Q,children:ht("div",{style:{position:"relative",display:"flex",alignItems:"center"},children:[pe("select",{value:ie,onChange:fe=>Me(z.property,fe.target.value),style:h(f({},Le),{cursor:"pointer",paddingLeft:4,paddingRight:24,appearance:"none",WebkitAppearance:"none"}),children:(Ze=z.options)==null?void 0:Ze.map(fe=>pe("option",{value:fe,children:fe},fe))}),pe("div",{style:{position:"absolute",right:4,top:"50%",transform:"translateY(-50%)",pointerEvents:"none",color:"#999",display:"flex",alignItems:"center"},children:pe(Ei,{size:12})})]})});case"spacing":return pe(Rn,{modified:Q,children:pe("input",{type:"text",value:ie,onChange:fe=>Me(z.property,fe.target.value),placeholder:"e.g., 10px or 10px 20px",style:Le})});case"backdrop-filter":return pe(wl,{value:ie,onChange:fe=>Me(z.property,fe),accentColor:l,modified:Q,panelContentRef:d});default:return pe(Rn,{modified:Q,children:pe("input",{type:"text",value:ie,onChange:fe=>Me(z.property,fe.target.value),style:Le})})}},ce=(dt=ae==null?void 0:ae.changes.length)!=null?dt:0,Ke=(Ve=ae==null?void 0:ae.captured)!=null?Ve:!1,Te=h(f({position:"fixed",top:j.current.top,left:j.current.left,width:280,maxHeight:j.current.maxHeight,backgroundColor:"rgba(255, 255, 255, 0.85)",backdropFilter:"blur(32px)",WebkitBackdropFilter:"blur(32px)"},bn),{zIndex:1e4,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',fontSize:12,overflow:"hidden",display:"flex",flexDirection:"column",opacity:u?1:0,transition:"opacity 150ms ease"}),xe={display:"flex",alignItems:"center",justifyContent:"space-between",margin:"3px 3px 0",padding:"8px 7px 8px 12px",borderBottom:"1px solid rgba(0,0,0,0.1)",backgroundColor:"#f8fafc",cursor:ee.current?"grabbing":"grab"},ge={display:"flex",alignItems:"center",justifyContent:"space-between",padding:"12px 12px 6px",userSelect:"none",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',fontWeight:600,color:"#475569"},Ge={display:"flex",alignItems:"center",padding:"4px 12px",gap:8},xt={width:80,fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#64748b",flexShrink:0};return pe("div",{"data-devtools":"panel-wrapper",style:{position:"fixed",top:j.current.top+K.current.y,left:j.current.left+K.current.x,zIndex:1e4,pointerEvents:"none"},children:ht("div",{ref:c,"data-devtools":"panel",style:h(f({},Te),{position:"relative",top:0,left:0,zIndex:0,pointerEvents:"auto"}),onMouseEnter:()=>s==null?void 0:s("element"),onMouseLeave:()=>s==null?void 0:s(null),children:[ht("div",{style:xe,onMouseDown:ve,children:[ht("div",{style:{display:"flex",alignItems:"center",gap:8,overflow:"hidden"},children:[pe("span",{style:{fontWeight:600,fontSize:11,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:t.tagName}),ce>0&&pe("span",{style:{backgroundColor:Ke?"#999999":l,color:"#fff",fontSize:9,padding:"1px 4px",borderRadius:2},children:ce})]}),ht("div",{style:{display:"flex",gap:4},children:[ce>0&&pe("button",{type:"button",onClick:ne,title:"Reset all changes",style:{display:"flex",alignItems:"center",justifyContent:"center",width:24,height:24,border:"none",background:"none",cursor:"pointer",color:"#64748b",borderRadius:2},children:pe(zd,{size:14})}),pe("button",{type:"button",onClick:i,title:"Close",style:{display:"flex",alignItems:"center",justifyContent:"center",width:24,height:24,border:"none",background:"none",cursor:"pointer",color:"#64748b",borderRadius:2},children:pe(Wd,{size:14})})]})]}),ht("div",{ref:d,style:{flex:1,overflowY:"auto",margin:"0 3px 3px"},children:[pe("div",{style:{opacity:v?.3:1,transition:"opacity 150ms ease"},children:pe(Ml,{element:e,getValue:Re,getOriginalValue:We,handleChange:Me,isModified:oe,onResetProperty:Ae,isCollapsed:!1,onToggle:()=>{},sectionHeaderStyle:ge,activeDropdown:g,onDropdownChange:S,panelContentRef:d,accentColor:l,onFieldHover:s,preferredUnit:O,onUnitCycle:k})}),pe("div",{style:{opacity:g?.3:1,transition:"opacity 150ms ease"},children:pe(Rl,{element:e,getValue:Re,handleChange:Me,isModified:oe,onResetProperty:Ae,isCollapsed:!1,onToggle:()=>{},sectionHeaderStyle:ge,accentColor:l,colorVariables:q,activeColorDropdown:v,onColorDropdownChange:b,panelContentRef:d,preferredUnit:O,onUnitCycle:k})}),Pl.map((z,ie)=>{let Q=ie===Pl.length-1,Se=v&&z.properties.some(Ze=>Ze.property===v);return ht("div",{style:{borderBottom:Q?"none":"1px solid rgba(0,0,0,0.08)",opacity:w&&!Se?.3:1,transition:"opacity 150ms ease"},children:[pe("div",{style:ge,children:pe("span",{children:z.name})}),pe("div",{style:{padding:"4px 0"},children:z.properties.map(Ze=>{let fe=oe(Ze.property),lt=Se&&Ze.property!==v;return ht("div",{style:h(f({},Ge),{opacity:lt?.3:1,transition:"opacity 150ms ease"}),children:[pe("span",{onClick:fe?()=>Ae(Ze.property):void 0,title:fe?"Click to reset":void 0,style:h(f({},xt),{color:fe?l:"#64748b",fontWeight:fe?600:400,cursor:fe?"pointer":"default"}),children:Ze.label}),pe("div",{style:{flex:1,minWidth:0,overflow:"hidden"},children:Ee(Ze)})]},Ze.property)})})]},z.name)}),ht("div",{style:{opacity:w?.3:1,transition:"opacity 150ms ease"},children:[pe("div",{style:ge,children:pe("span",{children:"Raw CSS"})}),ht("div",{style:{padding:"8px 12px"},children:[pe("textarea",{value:I,onChange:z=>$(z.target.value),placeholder:"property: value; ...",style:{width:"100%",height:60,padding:8,fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',border:"1px solid rgba(0,0,0,0.1)",borderRadius:2,resize:"vertical",outline:"none"}}),I.trim()&&pe("button",{type:"button",onClick:G,style:{marginTop:4,padding:"4px 8px",width:"100%",fontSize:11,border:"none",borderRadius:2,backgroundColor:l,color:"#fff",cursor:"pointer",opacity:I.trim()?1:.5},children:"Apply"})]})]})]})]})})}import{useEffect as Gd,useLayoutEffect as Vd,useState as Ud}from"react";import{Fragment as Zd,jsx as Qn,jsxs as Kd}from"react/jsx-runtime";var ki=["flex-start","center","flex-end"],Ci=["flex-start","center","flex-end"];function Jd(e){return e==="normal"||e==="flex-start"||e==="start"?"flex-start":e==="flex-end"||e==="end"?"flex-end":e==="center"?"center":null}function Xd(e){return e==="normal"||e==="stretch"||e==="flex-start"||e==="start"?"flex-start":e==="flex-end"||e==="end"?"flex-end":e==="center"?"center":null}function Ol(e){let t=Array.from(e.children);if(t.length===0)return null;let o=1/0,r=1/0,n=-1/0,i=-1/0;for(let s of t){let l=s.getBoundingClientRect();l.width===0&&l.height===0||(l.top<o&&(o=l.top),l.left<r&&(r=l.left),l.bottom>n&&(n=l.bottom),l.right>i&&(i=l.right))}return o===1/0?null:new DOMRect(r,o,i-r,n-o)}function Dl({element:e,modifier:t,accentColor:o,refreshKey:r=0}){let[n,i]=Ud(null);if(Gd(()=>{if(!e){i(null);return}let v=()=>i(Ol(e));return v(),window.addEventListener("scroll",v,{passive:!0}),window.addEventListener("resize",v,{passive:!0}),()=>{window.removeEventListener("scroll",v),window.removeEventListener("resize",v)}},[e]),Vd(()=>{e&&i(Ol(e))},[e,r]),!n)return null;let s=n,l=window.getComputedStyle(e),a=l.display;if(a!=="flex"&&a!=="inline-flex")return null;let c=l.flexDirection,d=c==="column"||c==="column-reverse"?"vertical":"horizontal",u=d==="horizontal"?"vertical":"horizontal",p=[];if(t==="shift"){let v=Jd(l.justifyContent);if(v){let b=ki.indexOf(v);d==="horizontal"?(b>0&&p.push("left"),b<ki.length-1&&p.push("right")):(b>0&&p.push("up"),b<ki.length-1&&p.push("down"))}}else{let v=Xd(l.alignItems);if(v){let b=Ci.indexOf(v);u==="horizontal"?(b>0&&p.push("left"),b<Ci.length-1&&p.push("right")):(b>0&&p.push("up"),b<Ci.length-1&&p.push("down"))}}if(p.length===0)return null;let g=14,S=7;return Qn(Zd,{children:p.map(v=>{let b,w;switch(v){case"right":b=s.right+g,w=s.top+s.height/2;break;case"left":b=s.left-g,w=s.top+s.height/2;break;case"down":b=s.left+s.width/2,w=s.bottom+g;break;case"up":b=s.left+s.width/2,w=s.top-g;break}let O=v==="right"?0:v==="left"?180:v==="down"?90:-90,A={position:"fixed",left:b-S,top:w-S,width:S*2,height:S*2,pointerEvents:"none",zIndex:9997};return Qn("div",{"data-devtools":"swipe-hint",style:A,children:Qn("svg",{width:S*2,height:S*2,viewBox:"-7 -7 14 14",style:{overflow:"visible"},children:Kd("g",{transform:`rotate(${O})`,children:[Qn("line",{x1:"-5",y1:"0",x2:"3",y2:"0",stroke:"#fff",strokeWidth:"4",strokeLinecap:"round"}),Qn("polyline",{points:"0,-4 5,0 0,4",fill:"none",stroke:"#fff",strokeWidth:"4",strokeLinecap:"round",strokeLinejoin:"round"}),Qn("line",{x1:"-5",y1:"0",x2:"3",y2:"0",stroke:o,strokeWidth:"1.5",strokeLinecap:"round"}),Qn("polyline",{points:"0,-4 5,0 0,4",fill:"none",stroke:o,strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})]})})},v)})})}import{useEffect as qd,useLayoutEffect as Qd,useState as eu}from"react";import{jsx as Mi,jsxs as Ti}from"react/jsx-runtime";function tu(e,t){let o=e.match(/^oklch\(([^)]+)\)$/i);return o?`oklch(${o[1]} / ${t})`:`color-mix(in srgb, ${e} ${Math.round(t*100)}%, transparent)`}function Hl({element:e,fontSize:t,lineHeight:o,accentColor:r,hoveredProperty:n,draggingProperty:i,cursorViewport:s}){let[l,a]=eu(null);if(qd(()=>{if(!e){a(null);return}let w=()=>{a(mo(e))};return w(),window.addEventListener("scroll",w,{passive:!0}),window.addEventListener("resize",w,{passive:!0}),()=>{window.removeEventListener("scroll",w),window.removeEventListener("resize",w)}},[e]),Qd(()=>{e&&a(mo(e))},[e,t,o]),!l)return null;let c=l.width,d=l.height,u=tu(r,.2),p=i!=null?i:n,g=8,S=2,v={position:"fixed",top:l.top,left:l.left,width:c,height:d,pointerEvents:"none",zIndex:9996,overflow:"visible"},b=w=>w==="font-size"?`${Math.round(t)}`:(t>0?o/t:1.2).toFixed(2).replace(/\.?0+$/,"");return Ti("div",{"data-devtools":"text-handles",style:v,children:[Ti("svg",{style:{position:"absolute",inset:0,width:"100%",height:"100%",overflow:"visible",pointerEvents:"none"},viewBox:`0 0 ${c} ${d}`,children:[Mi("rect",{x:"0.5",y:"0.5",width:Math.max(0,c-1),height:Math.max(0,d-1),fill:"none",stroke:u,strokeWidth:"1"}),(p==="font-size"||!p)&&Mi("rect",{x:c-S/2,y:d/2-g/2,width:S,height:g,fill:r,stroke:"#ffffff",strokeWidth:p==="font-size"?4:2,paintOrder:"stroke"}),(p==="line-height"||!p)&&Mi("rect",{x:c/2-g/2,y:d-S/2,width:g,height:S,fill:r,stroke:"#ffffff",strokeWidth:p==="line-height"?4:2,paintOrder:"stroke"})]}),s&&p&&(()=>{let w=p==="font-size"?"Aa":"Lh",O=b(p);return Ti("div",{style:{position:"fixed",left:s.x+8,top:s.y-28,background:r,color:"#fff",fontSize:11,fontWeight:600,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',lineHeight:1,padding:"4px 4px",borderRadius:0,whiteSpace:"nowrap",pointerEvents:"none",zIndex:9997},children:[w," ",O]})})()]})}import{Fragment as Co,jsx as ot,jsxs as ko}from"react/jsx-runtime";var Fl=8,Ii=[0,1,2,4,8,12,16,20,24,28,32],Ri="devtools-active-text";function Nl(e,t,o=0){let r=e.left+window.scrollX+4,n=t==="top-left"?e.top+window.scrollY-Xn-o*Xn+4:e.bottom+window.scrollY+4-1+o*Xn,i=window.scrollY+4,s=window.scrollY+window.innerHeight-Xn-4;return n<i?n=e.top+window.scrollY+4:n>s&&(n=Math.max(e.top+window.scrollY+4,s)),{x:r,y:n}}function _l({state:e,dispatch:t,onScreenshot:o,inFlightAnnotationIds:r,inFlightStyleSelectors:n,inFlightSelectorColors:i,onAttachImages:s,onReply:l,onViewThread:a,onCloseThread:c,onModelComponentsAdd:d,onModelComponentFocus:u,onModelComponentHover:p,modelComponentNames:g,modelPanelHoveredComponent:S,modelSpacingTokenHover:v,highlightedAnnotationIds:b,externalCanvasRef:w,toolbarRef:O}){var ss,ls,as,cs,ds,us,ps,fs,gs;let{canvasRef:A,redrawAll:k,resizeCanvas:E}=$s(),I=Pt(y=>{A.current=y,w&&(w.current=y)},[w,A]),$=Ct(!1);Vt(()=>{let y=A.current;if(!y)return;let x=()=>{$.current&&($.current=!1,y.style.pointerEvents="")},X=M=>{M.button===0&&$.current&&x()};return window.addEventListener("mousedown",X),()=>window.removeEventListener("mousedown",X)},[A]);let[q,j]=it(!1),[T,D]=it(()=>{if(typeof window=="undefined")return null;try{let y=localStorage.getItem(Ri);return y?JSON.parse(y):null}catch(y){return null}}),[K,ee]=it(null),[me,ve]=it(null),[ae,Re]=it(null),We=Ct(null),Me=Ct(null),ne=Ct({x:0,y:0}),Ae=Ct([]),G=Ct(0),[oe,Ee]=it(null),[ce,Ke]=it(new Map),Te=Ct(0),xe=Ct(null),[ge,Ge]=it(null),[xt,dt]=it(null),Ve=Ct({isDragging:!1,side:null,startX:0,startY:0,original:{top:0,right:0,bottom:0,left:0},element:null,elementInfo:null,selector:null,durableSelector:null}),[z,ie]=it(null),[Q,Se]=it(null),[Le,Ze]=it(null),[fe,lt]=it(null),Qe=Ct({x:0,y:0}),[Tt,Ot]=it({x:0,y:0}),st=Ct({isDragging:!1,hasMoved:!1,axis:null,startX:0,startY:0,originalRow:0,originalColumn:0,element:null,elementInfo:null,selector:null,durableSelector:null,isAuto:!1,originalJustifyContent:"",visualGap:0}),[at,Dt]=it(null),[tt,vt]=it(null),[$e,en]=it(null),[Kt,rn]=it(!1),[mn,En]=it(0),[J,Ie]=it(null),Fe=Ct({isDragging:!1,corner:null,startY:0,original:{"top-left":0,"top-right":0,"bottom-right":0,"bottom-left":0},maxRadius:0,element:null,elementInfo:null,selector:null,durableSelector:null}),[ft,Lt]=it(null),[pt,bt]=it(null),[St,dn]=it(null),$t=Ct({isDragging:!1,property:null,startX:0,startY:0,originalFontSize:0,originalLineHeight:0,originalRatio:1.2,element:null,elementInfo:null,selector:null,durableSelector:null}),[kt,hn]=it(null),[W,te]=it(null),[U,Pe]=it(null),Be=Ws(),he=Ct(i);he.current=i;let It=Pt(y=>{let x=he.current;if(!x||x.size===0)return!1;for(let X of x.keys())try{if(y.matches(X))return!0}catch(M){}return!1},[]),R=Ct(e);R.current=e;let Z=Ct(T);Z.current=T;let de=Ct([]),Oe=Ct(o);Oe.current=o;let[ye,ke]=it(null),Ne=e.selectedAnnotationIds;de.current=Ne;let gt=Pt((y,x=!1)=>{t({type:"SELECT_ANNOTATION",payload:{id:y,addToSelection:x}})},[t]),Ue=Pt(()=>{t({type:"SELECT_ANNOTATION",payload:{id:null}})},[t]),[et,Ht]=it(null),[wt,Tr]=it({x:window.scrollX,y:window.scrollY});Vt(()=>(E(),window.addEventListener("resize",E),()=>window.removeEventListener("resize",E)),[E]),Vt(()=>{let y=()=>{Tr({x:window.scrollX,y:window.scrollY})};return window.addEventListener("scroll",y,{passive:!0}),()=>window.removeEventListener("scroll",y)},[]),Vt(()=>{T?localStorage.setItem(Ri,JSON.stringify(T)):localStorage.removeItem(Ri)},[T]),Ys(T,D,K,e.annotations,t);let zn=Ct(oe);zn.current=oe,Vt(()=>{if(e.activeTool!=="model"||!e.isAnnotating)return;let y=x=>{if(!x.altKey||!zn.current)return;x.preventDefault();let X=x.deltaY>0?-1:1;Te.current=Math.max(0,Te.current+X);let M=xe.current;if(M){let B=ir(M,Te.current);Ee(B)}};return window.addEventListener("wheel",y,{passive:!1}),()=>window.removeEventListener("wheel",y)},[e.activeTool,e.isAnnotating]),Vt(()=>{e.activeTool!=="model"&&(Ee(null),Ke(new Map),Te.current=0,xe.current=null)},[e.activeTool]),Vt(()=>{var X;let y=(X=oe==null?void 0:oe.name)!=null?X:null,x=y&&(g!=null&&g.has(y))?y:null;p==null||p(x)},[oe,g,p]);let[Bo,Uo]=it(null);Vt(()=>{var X;if(!S){Uo(null);return}let y=po(S.name),x=S.instanceIndex;Uo((X=y[x%y.length])!=null?X:null)},[S]);let[un,Lr]=it([]);Vt(()=>{var y,x;if(!v){Lr([]);return}(x=(y=v.token)==null?void 0:y.bindings)!=null&&x.length?Lr(Xr(v.token)):Lr(Ur(v.px))},[v]);let ua=Ct(null),pa=Ct(null);ua.current=at,pa.current=tt,Vt(()=>{let y=["flex-start","center","flex-end"],x=["flex-start","center","flex-end"],M=null,B=!1,H=null,se=null,F=(ue,we)=>{let je=Gn(ue,we);for(;je&&je!==document.documentElement;){let rt=window.getComputedStyle(je).display;if(rt==="flex"||rt==="inline-flex")return je;je=je.parentElement}return null},V=ue=>{let we=window.getComputedStyle(ue).flexDirection;return we==="column"||we==="column-reverse"?"vertical":"horizontal"},m=ue=>{let we=ue.getAttribute("data-pm");return we||(we=Math.random().toString(36).substring(2,8),ue.setAttribute("data-pm",we)),{selector:`[data-pm="${we}"]`,durableSelector:sn(ue)}},C=()=>{B=!0,M&&clearTimeout(M),M=setTimeout(()=>{B=!1,M=null},300)},Y=(ue,we,Je)=>{let je=V(ue);if(we===je){let De=window.getComputedStyle(ue).justifyContent,mt=De==="normal"||De==="flex-start"||De==="start"?"flex-start":De==="flex-end"||De==="end"?"flex-end":De==="center"?"center":null;if(!mt)return;let Ft=y.indexOf(mt)+Je;if(Ft<0||Ft>=y.length)return;let Ln=y[Ft],{selector:Wn,durableSelector:Rr}=m(ue);_e(ue,"justify-content",Ln),t({type:"MODIFY_STYLES_BATCH",payload:{selector:Wn,durableSelector:Rr,element:qt(ue),changes:[{property:"justify-content",original:De,modified:Ln}]}})}else{let De=window.getComputedStyle(ue).flexDirection,mt=je==="horizontal"?"column":"row",{selector:yn,durableSelector:Ft}=m(ue);_e(ue,"flex-direction",mt),t({type:"MODIFY_STYLES_BATCH",payload:{selector:yn,durableSelector:Ft,element:qt(ue),changes:[{property:"flex-direction",original:De,modified:mt}]}})}En(rt=>rt+1)},L=(ue,we,Je)=>{let rt=V(ue)==="horizontal"?"vertical":"horizontal";if(we!==rt)return;let mt=window.getComputedStyle(ue).alignItems,yn=mt==="normal"||mt==="stretch"||mt==="flex-start"||mt==="start"?"flex-start":mt==="flex-end"||mt==="end"?"flex-end":mt==="center"?"center":null;if(!yn)return;let Ln=x.indexOf(yn)+Je;if(Ln<0||Ln>=x.length)return;let Wn=x[Ln],{selector:Rr,durableSelector:wa}=m(ue);_e(ue,"align-items",Wn),t({type:"MODIFY_STYLES_BATCH",payload:{selector:Rr,durableSelector:wa,element:qt(ue),changes:[{property:"align-items",original:mt,modified:Wn}]}}),En(Ea=>Ea+1)},P=20,N=null,_=null,le=0,be=(ue,we,Je)=>{let je=F(we,Je);Ie(je?{modifier:ue,target:je}:null)},nt=ue=>{if(!(e.activeTool!=="hand"||!e.isAnnotating)){if(ue.key==="Shift"&&!ue.altKey){let we=Qe.current;be("shift",we.x,we.y)}else if(ue.key==="Alt"&&!ue.shiftKey){let we=Qe.current;be("alt",we.x,we.y)}}},Ye=ue=>{if(e.activeTool!=="hand"||!e.isAnnotating)return;let we=ue.shiftKey&&!ue.altKey,Je=ue.altKey&&!ue.shiftKey;if(!we&&!Je||ue.buttons!==0){N=null,_=null,le=0,H=null,se=null,Ie(null);return}if(H===null&&(H=ue.clientX,se=ue.clientY,be(we?"shift":"alt",ue.clientX,ue.clientY)),B)return;N===null&&(N=ue.clientX,_=ue.clientY,le=0);let je=ue.clientX-N,rt=ue.clientY-_,De=Math.abs(je)>=Math.abs(rt)?je:rt;if(Math.abs(De)>3){let Wn=De>0?1:-1;if(le!==0&&Wn!==le){N=ue.clientX,_=ue.clientY,le=0;return}le=Wn}if(Math.abs(je)<P&&Math.abs(rt)<P)return;let mt=F(H,se);if(!mt)return;let yn=Math.abs(je)>=Math.abs(rt)?"horizontal":"vertical",Ln=(yn==="horizontal"?je:rt)>0?1:-1;N=null,_=null,le=0,we?Y(mt,yn,Ln):L(mt,yn,Ln),C()},Rt=ue=>{(ue.key==="Shift"||ue.key==="Alt")&&(H=null,se=null,N=null,_=null,le=0,Ie(null))},ut=()=>{Ie(null),N=null,_=null,le=0};return window.addEventListener("keydown",nt),window.addEventListener("mousemove",Ye),window.addEventListener("mousedown",ut),window.addEventListener("keyup",Rt),()=>{window.removeEventListener("keydown",nt),window.removeEventListener("mousemove",Ye),window.removeEventListener("mousedown",ut),window.removeEventListener("keyup",Rt),M&&clearTimeout(M)}},[e.activeTool,e.isAnnotating,t]),Vt(()=>{let y=x=>{var H,se,F,V;if(x.key==="Escape"){if(Z.current)return;if(e.activeTool==="model"&&ce.size>0){x.preventDefault(),Ke(new Map);return}if(de.current.length>0){x.preventDefault(),Ue();return}}if(x.key==="Enter"&&e.activeTool==="model"&&ce.size>0&&d){x.preventDefault();let m=[...ce.keys()].filter(C=>!(g!=null&&g.has(C)));m.length>0&&d(m),Ke(new Map);return}if((x.metaKey||x.ctrlKey)&&x.key==="v"&&Ae.current.length>0&&!Z.current){x.preventDefault(),G.current++;let m=G.current*20,Y=((H=Ae.current[0])==null?void 0:H.groupId)?Math.random().toString(36).substring(2,9):void 0,L=Ae.current.map(N=>h(f({},N),{id:Math.random().toString(36).substring(2,9),groupId:N.groupId?Y:void 0,timestamp:Date.now(),points:N.points.map(_=>({x:_.x+m,y:_.y+m}))}));t({type:"PASTE_ANNOTATIONS",payload:{annotations:L}});let P=L.find(N=>N.type!=="text")||L[0];P&&gt(P.id);return}let X=de.current;if(X.length===0||Z.current)return;let M=(F=(se=x.composedPath)==null?void 0:se.call(x)[0])!=null?F:x.target,B=M==null?void 0:M.tagName;if(!(B==="INPUT"||B==="TEXTAREA"||M!=null&&M.isContentEditable)&&(x.key==="Delete"||x.key==="Backspace")){if(x.preventDefault(),c){let m=R.current.annotations;for(let C of X){let Y=m.find(P=>P.id===C);if(!Y)continue;let L=Y.threadId||Y.groupId&&((V=m.find(P=>P.groupId===Y.groupId&&P.threadId))==null?void 0:V.threadId);L&&c(L)}}for(let m of X)t({type:"DELETE_ANNOTATION",payload:{id:m}});Ue()}};return window.addEventListener("keydown",y),()=>window.removeEventListener("keydown",y)},[t,Ue,gt,e.activeTool,ce,g,d,c]);let Dn=Li(()=>fr(e.annotations),[e.annotations]),Jo=Li(()=>{let y=new Map,x=new Set,X=1;for(let M of e.annotations)if(!Dn.has(M))if(M.groupId){if(!x.has(M.groupId)){x.add(M.groupId);let B=e.annotations.filter(H=>H.groupId===M.groupId);for(let H of B)y.set(H.id,X);X++}}else y.set(M.id,X),X++;return y},[e.annotations,Dn]),Qi=Li(()=>{if(Ne.length===0)return null;let y=new Map;for(let x of Ne){let X=e.annotations.find(B=>B.id===x);if(!X)continue;let M=X.groupId?e.annotations.filter(B=>B.groupId===X.groupId):[X];for(let B of M)if(B.linkedSelector&&!(i!=null&&i.has(B.linkedSelector))){let H=B.color||e.activeColor;y.set(B.linkedSelector,H)}}return y.size>0?y:null},[Ne,e.annotations,e.activeColor,i]);Vt(()=>{let y=e.annotations.filter(x=>!(Dn.has(x)||T&&!T.isNew&&x.id===T.id));k(y,e.currentPath,e.activeTool,e.activeColor,e.strokeWidth,Ne,Fl,wt.x,wt.y,Jo,b)},[e.annotations,e.currentPath,e.activeTool,e.activeColor,e.strokeWidth,k,T,Ne,wt,Jo,Dn,b]),Vt(()=>{if(me){let y=Math.random().toString(36).substring(2,9);D({id:y,point:me.point,text:"",fontSize:12,isNew:!0,groupId:me.groupId}),ve(null)}},[me]),Vt(()=>{ae&&(D({id:Math.random().toString(36).substring(2,9),point:ae.point,text:"",fontSize:12,isNew:!0,linkedSelector:ae.linkedSelector,linkedAnchor:ae.linkedAnchor,elements:ae.elements}),Re(null))},[ae]);let Xo=Ct(null),Ko=(ss=T==null?void 0:T.id)!=null?ss:null;Vt(()=>{Ko&&We.current?requestAnimationFrame(()=>{var X;let y=We.current;if(!y||(y.focus(),Me.current===Ko))return;Me.current=Ko;let x=Z.current;if(x){if(Xo.current!==null){let M=Math.min(Xo.current,y.value.length);y.setSelectionRange(M,M);return}if(!x.isNew&&x.clickPoint){let M=A.current;if(!M)return;let B=M.getContext("2d");if(!B)return;B.font=`${x.fontSize}px ${Wt}`;let H=x.fontSize*1.4,se=x.text.split(`
7
- `),F=x.clickPoint.y-x.point.y,V=Math.max(0,Math.min(se.length-1,Math.floor(F/H))),m=x.clickPoint.x-x.point.x,C=se[V]||"",Y=0;for(let P=0;P<=C.length;P++){let N=B.measureText(C.substring(0,P)).width;if(N>m){let _=P>0?B.measureText(C.substring(0,P-1)).width:0;Y=m-_<N-m?P-1:P;break}Y=P}let L=Y;for(let P=0;P<V;P++)L+=(((X=se[P])==null?void 0:X.length)||0)+1;y.setSelectionRange(L,L)}}}):(Me.current=null,Xo.current=null)},[Ko,A]);let oo=Pt(y=>{let x=A.current;if(!x)return{x:0,y:0};let X=x.getBoundingClientRect(),M,B;if("touches"in y&&y.touches[0])M=y.touches[0].clientX,B=y.touches[0].clientY;else if("clientX"in y)M=y.clientX,B=y.clientY;else return{x:0,y:0};return{x:M-X.left+window.scrollX,y:B-X.top+window.scrollY}},[A]),$n=Pt((y,x,X,M)=>{let B=X.x-x.x,H=X.y-x.y,se=B*B+H*H;if(se===0)return Math.sqrt((y.x-x.x)**2+(y.y-x.y)**2)<=M;let F=Math.max(0,Math.min(1,((y.x-x.x)*B+(y.y-x.y)*H)/se)),V=x.x+F*B,m=x.y+F*H;return Math.sqrt((y.x-V)**2+(y.y-m)**2)<=M},[]),Zo=Pt(y=>{for(let X=e.annotations.length-1;X>=0;X--){let M=e.annotations[X];if(!M||Dn.has(M))continue;let B=(M.strokeWidth||3)+4;switch(M.type){case"text":{if(!M.points[0]||!M.text)continue;let H=M.points[0],se=M.fontSize||12,F=A.current;if(F){let V=F.getContext("2d");if(V){V.font=`${se}px ${Wt}`;let m=M.text.split(`
8
- `),C=H.x-wt.x,Y=co(C),L=Y!==void 0?Math.min(400,Y):void 0,P=L?jn(V,m,L):m,N=L?Math.min(L,Math.max(...P.map(nt=>V.measureText(nt).width))):Math.max(...m.map(nt=>V.measureText(nt).width)),_=P.length*(se*1.4),le=m.length*(se*1.4),be=_-le;if(y.x>=H.x-4-4&&y.x<=H.x+N+4+4&&y.y>=H.y-4-4-be&&y.y<=H.y+le+4+4)return M}}break}case"rectangle":{if(M.points.length<2)continue;let H=M.points[0],se=M.points[M.points.length-1],F=Math.min(H.x,se.x),V=Math.max(H.x,se.x),m=Math.min(H.y,se.y),C=Math.max(H.y,se.y),Y=$n(y,{x:F,y:m},{x:V,y:m},B),L=$n(y,{x:F,y:C},{x:V,y:C},B),P=$n(y,{x:F,y:m},{x:F,y:C},B),N=$n(y,{x:V,y:m},{x:V,y:C},B);if(Y||L||P||N)return M;break}case"circle":{if(M.points.length<2)continue;let H=M.points[0],se=M.points[M.points.length-1],F=(H.x+se.x)/2,V=(H.y+se.y)/2,m=Math.abs(se.x-H.x)/2,C=Math.abs(se.y-H.y)/2,Y=y.x-F,L=y.y-V,P=Math.sqrt((Y/m)**2+(L/C)**2);if(Math.abs(P-1)*Math.max(m,C)<=B)return M;break}case"line":{if(M.points.length<2)continue;let H=M.points[0],se=M.points[M.points.length-1];if($n(y,H,se,B))return M;break}case"freehand":{if(M.points.length<2)continue;for(let H=0;H<M.points.length-1;H++){let se=M.points[H],F=M.points[H+1];if($n(y,se,F,B))return M}break}}}return null},[e.annotations,A,$n,Dn,wt.x]),es=Pt(y=>{let x=Zo(y);return(x==null?void 0:x.type)==="text"?x:null},[Zo]),ts=Pt(y=>{if(Ne.length===0)return null;let x=Fl/2+4;for(let X of Ne){let M=e.annotations.find(B=>B.id===X);if(!(!M||M.points.length<2)){if(M.type==="line"){let B=M.points[0],H=M.points[M.points.length-1];if(Math.sqrt((y.x-B.x)**2+(y.y-B.y)**2)<=x)return{handle:"start",annotationId:X};if(Math.sqrt((y.x-H.x)**2+(y.y-H.y)**2)<=x)return{handle:"end",annotationId:X};continue}if(M.type==="circle"){let B=M.points[0],H=M.points[M.points.length-1],se=Math.min(B.x,H.x),F=Math.max(B.x,H.x),V=Math.min(B.y,H.y),m=Math.max(B.y,H.y),C=(se+F)/2,Y=(V+m)/2,L=[{handle:"top",x:C,y:V},{handle:"bottom",x:C,y:m},{handle:"left",x:se,y:Y},{handle:"right",x:F,y:Y}];for(let{handle:P,x:N,y:_}of L)if(Math.sqrt((y.x-N)**2+(y.y-_)**2)<=x)return{handle:P,annotationId:X};continue}if(M.type==="rectangle"||M.type==="freehand"){let B=M.points[0],H=M.points[M.points.length-1],se,F,V,m;M.type==="freehand"?(se=Math.min(...M.points.map(Y=>Y.x)),F=Math.max(...M.points.map(Y=>Y.x)),V=Math.min(...M.points.map(Y=>Y.y)),m=Math.max(...M.points.map(Y=>Y.y))):(se=Math.min(B.x,H.x),F=Math.max(B.x,H.x),V=Math.min(B.y,H.y),m=Math.max(B.y,H.y));let C=[{corner:"topLeft",x:se,y:V},{corner:"topRight",x:F,y:V},{corner:"bottomLeft",x:se,y:m},{corner:"bottomRight",x:F,y:m}];for(let{corner:Y,x:L,y:P}of C)if(Math.sqrt((y.x-L)**2+(y.y-P)**2)<=x)return{handle:Y,annotationId:X}}}}return null},[Ne,e.annotations]);Vt(()=>{let y=x=>{if(ne.current={x:x.clientX+window.scrollX,y:x.clientY+window.scrollY},!T){let X=es(ne.current);ee((X==null?void 0:X.id)||null)}};return window.addEventListener("mousemove",y),()=>window.removeEventListener("mousemove",y)},[T,es]);let ro=Pt(()=>{var x;if(!T)return;let y=((x=T.images)==null?void 0:x.length)||0;if(T.text.trim()||y>0)if(T.isNew){let X=nr();t({type:"ADD_TEXT",payload:f({point:T.point,text:T.text||(y>0?`[${y} image${y>1?"s":""}]`:""),fontSize:T.fontSize,id:X,groupId:T.groupId,linkedSelector:T.linkedSelector,linkedAnchor:T.linkedAnchor,elements:T.elements},y>0?{imageCount:y}:{})}),y>0&&T.images&&s&&s(X,T.images)}else t({type:"UPDATE_TEXT",payload:f({id:T.id,text:T.text||(y>0?`[${y} image${y>1?"s":""}]`:"")},y>0?{imageCount:y}:{})}),y>0&&T.images&&s&&s(T.id,T.images);else T.isNew||t({type:"DELETE_ANNOTATION",payload:{id:T.id}});D(null)},[T,t,s]),Tn=Pt(y=>{for(let x=0;x<Ii.length-1;x++){let X=Ii[x],M=Ii[x+1];if(y<=(X+M)/2)return X;if(y<M)return M}return Math.round(y/8)*8},[]),ns=Pt((y,x,X,M)=>{let B=X.top+Math.max(M.top,4),H=X.bottom-Math.max(M.bottom,4),se=X.left+Math.max(M.left,4),F=X.right-Math.max(M.right,4);if(y<X.left||y>X.right||x<X.top||x>X.bottom)return null;let V=x<B,m=x>H,C=y<se,Y=y>F;return V&&C?M.top>=M.left?"top":"left":V&&Y?M.top>=M.right?"top":"right":m&&C?M.bottom>=M.left?"bottom":"left":m&&Y?M.bottom>=M.right?"bottom":"right":V?"top":m?"bottom":C?"left":Y?"right":null},[]),os=Pt(y=>{var H,se;if(!e.isAnnotating)return;if(e.inspectedElement&&e.activeTool==="hand"&&!("button"in y&&y.button===2)){y.preventDefault(),y.stopPropagation(),t({type:"SELECT_ELEMENT",payload:null});return}let x=oo(y),X="shiftKey"in y&&y.shiftKey;if(e.activeTool==="inspector"){if("button"in y&&y.button===2)return;if(ge&&!It(ge)){let F=qt(ge),V=sn(ge),m=ge.getBoundingClientRect(),C=ge.getAttribute("data-pm");C||(C=Math.random().toString(36).substring(2,8),ge.setAttribute("data-pm",C));let Y=`[data-pm="${C}"]`,L=e.styleModifications.some(be=>{try{return ge.matches(be.selector)}catch(nt){return!1}}),P=e.annotations.filter(be=>{if(!be.linkedSelector)return!1;try{return ge.matches(be.linkedSelector)}catch(nt){return!1}}).length,N=(L?1:0)+P,_=m.top>=Xn*(1+N)?"top-left":"bottom-left",le=Nl(m,_,N);Re({point:le,linkedSelector:Y,linkedAnchor:_,elements:[h(f({},F),{selector:V})]})}return}if(e.activeTool==="model"){if("button"in y&&y.button===2)return;if(oe){let F=oe.name;if(g!=null&&g.has(F)){u==null||u(F);return}"shiftKey"in y&&y.shiftKey?Ke(m=>{let C=new Map(m);return C.has(F)?C.delete(F):C.set(F,oe),C}):ce.size===1&&ce.has(F)?(d&&d([F]),Ke(new Map)):Ke(new Map([[F,oe]]))}return}if(e.activeTool==="hand"&&at&&tt){let F=at,V=F.getAttribute("data-pm");V||(V=Math.random().toString(36).substring(2,8),F.setAttribute("data-pm",V));let m=sn(F),C=`[data-pm="${V}"]`,Y=qt(F),L=Fo(F),P=x.x-window.scrollX,N=x.y-window.scrollY,_=Kt,le=window.getComputedStyle(F).justifyContent,be=0;if(_){let Ye=Vn(F).find(Rt=>Rt.axis===tt);be=Ye?tt==="column"?Ye.w:Ye.h:0}_e(F,"transition","none"),st.current={isDragging:!0,hasMoved:!1,axis:tt,startX:P,startY:N,originalRow:_?be:L.row,originalColumn:_?be:L.column,element:F,elementInfo:h(f({},Y),{selector:C}),selector:C,durableSelector:m,isAuto:_,originalJustifyContent:le,visualGap:be},en({axis:tt,row:_?be:L.row,column:_?be:L.column});return}if(e.activeTool==="hand"&&kt&&W){let F=kt,V=F.getAttribute("data-pm");V||(V=Math.random().toString(36).substring(2,8),F.setAttribute("data-pm",V));let m=`[data-pm="${V}"]`,C=qt(F),{fontSize:Y,lineHeight:L}=No(F),P=Y>0?L/Y:1.2,N=x.x-window.scrollX,_=x.y-window.scrollY;_e(F,"transition","none");let le=sn(F);$t.current={isDragging:!0,property:W,startX:N,startY:_,originalFontSize:Y,originalLineHeight:L,originalRatio:P,element:F,elementInfo:h(f({},C),{selector:m}),selector:m,durableSelector:le},Pe({property:W,fontSize:Y,lineHeight:L});return}if(e.activeTool==="hand"&&ft&&pt){let F=ft,V=F.getAttribute("data-pm");V||(V=Math.random().toString(36).substring(2,8),F.setAttribute("data-pm",V));let m=`[data-pm="${V}"]`,C=sn(F),Y=qt(F),L=Un(F),P=F.getBoundingClientRect(),N=Math.floor(P.height/2),_=x.y-window.scrollY;_e(F,"transition","none"),Fe.current={isDragging:!0,corner:pt,startY:_,original:L,maxRadius:N,element:F,elementInfo:h(f({},Y),{selector:m}),selector:m,durableSelector:C},dn({corner:pt,radius:f({},L)});return}if(e.activeTool==="hand"&&z&&Q){let F=z,V=F.getAttribute("data-pm");V||(V=Math.random().toString(36).substring(2,8),F.setAttribute("data-pm",V));let m=`[data-pm="${V}"]`,C=sn(F),Y=qt(F),L=go(F),P=x.x-window.scrollX,N=x.y-window.scrollY;_e(F,"transition","none"),Ve.current={isDragging:!0,side:Q,startX:P,startY:N,original:L,element:F,elementInfo:h(f({},Y),{selector:m}),selector:m,durableSelector:C},lt({side:Q,padding:f({},L)});return}let M=ts(x);if(M){let F=e.annotations.find(V=>V.id===M.annotationId);if(F&&F.type!=="text"&&((H=F.status)!=null?H:"pending")==="pending"){Ht({annotationId:M.annotationId,handle:M.handle,startPoint:x,originalPoints:[...F.points],hasMoved:!1});return}}let B=Zo(x);if(B&&B.points[0]){if(T&&ro(),B.type!=="text"?(gt(B.id,X),B.color&&t({type:"SET_COLOR",payload:B.color})):X||Ue(),a){let F=B.threadId||(B.groupId?(se=e.annotations.find(V=>V.groupId===B.groupId&&V.threadId))==null?void 0:se.threadId:void 0);F&&a(F)}ke({annotation:B,startPoint:x,hasMoved:!1});return}if(X||Ue(),e.activeTool==="text"){T&&ro();let F=Math.random().toString(36).substring(2,9);D({id:F,point:x,text:"",fontSize:12,isNew:!0});return}j(!0),t({type:"START_PATH",payload:x})},[e.isAnnotating,e.activeTool,e.inspectedElement,e.annotations,T,Ne,ge,z,Q,ft,pt,at,tt,Kt,kt,W,oe,ce,g,d,u,a,oo,Zo,ts,t,gt,Ue,ro]),rs=Pt(y=>{var X,M;let x=oo(y);if(e.activeTool==="inspector"&&e.isAnnotating){let B=x.x-window.scrollX,H=x.y-window.scrollY,se=Gn(B,H),F=se&&It(se)?null:se;F!==ge&&(Ge(F),dt(F?qt(F):null));return}if(e.activeTool==="model"&&e.isAnnotating){let B=x.x-window.scrollX,H=x.y-window.scrollY,se=Gn(B,H);if(se!==xe.current&&(xe.current=se,Te.current=0),se){let F=ir(se,Te.current);Ee(F)}else Ee(null);return}if(e.activeTool==="hand"&&e.isAnnotating){let B=x.x-window.scrollX,H=x.y-window.scrollY;Qe.current={x:B,y:H},Ot({x:B,y:H});let se=Be.current.cmd,F=Be.current.shift;if(st.current.isDragging){let m=st.current,C=m.element;if(!C)return;if(!m.hasMoved){let N=Math.abs(B-m.startX),_=Math.abs(H-m.startY);if(N<=2&&_<=2)return;m.hasMoved=!0,m.isAuto&&(_e(C,"justify-content","normal"),_e(C,"row-gap",`${m.visualGap}px`),_e(C,"column-gap",`${m.visualGap}px`),rn(!1))}let Y=m.axis,L=m.originalRow,P=m.originalColumn;if(Y==="column"){let N=B-m.startX;P=m.originalColumn+N,se||(L=m.originalRow+N)}else{let N=H-m.startY;L=m.originalRow+N,se||(P=m.originalColumn+N)}L=Math.max(0,L),P=Math.max(0,P),F&&(L=Tn(L),P=Tn(P)),L=Math.round(L),P=Math.round(P),_e(C,"row-gap",`${L}px`),_e(C,"column-gap",`${P}px`),en({axis:Y,row:L,column:P});return}if(Fe.current.isDragging){let m=Fe.current,C=m.element;if(!C)return;let Y=H-m.startY,L=m.corner,P=m.original,N=f({},P);if(se){let _=P[L]+Y;_=Math.max(0,Math.min(m.maxRadius,_)),F&&(_=Tn(_)),_=Math.round(_),N[L]=_}else{let _=P[L]+Y;_=Math.max(0,Math.min(m.maxRadius,_)),F&&(_=Tn(_)),_=Math.round(_),N={"top-left":_,"top-right":_,"bottom-right":_,"bottom-left":_}}_e(C,"border-top-left-radius",`${N["top-left"]}px`),_e(C,"border-top-right-radius",`${N["top-right"]}px`),_e(C,"border-bottom-right-radius",`${N["bottom-right"]}px`),_e(C,"border-bottom-left-radius",`${N["bottom-left"]}px`),dn({corner:L,radius:N});return}if($t.current.isDragging){let m=$t.current,C=m.element;if(!C)return;let Y=m.property,L=m.originalFontSize,P=m.originalLineHeight,N=[8,10,11,12,13,14,16,18,20,22,24,28,32,36,40,48,56,64,72,80,96];if(Y==="font-size"){let le=B-m.startX;L=m.originalFontSize+le,L=Math.max(1,L)}else{let le=H-m.startY;P=m.originalLineHeight+le,P=Math.max(L,P)}if(F)if(Y==="font-size"){let le=N[0],be=Math.abs(L-le);for(let nt of N){let Ye=Math.abs(L-nt);Ye<be&&(le=nt,be=Ye)}L=le}else{let le=L>0?P/L:1.2,be=Math.round(le*2)/2;P=L*Math.max(1,be)}L=Math.round(L),P=Math.round(P*10)/10,_e(C,"font-size",`${L}px`);let _=L>0?Math.round(P/L*1e3)/1e3:1.2;_e(C,"line-height",`${_}`),Pe({property:Y,fontSize:L,lineHeight:P});return}if(Ve.current.isDragging){let m=Ve.current,C=m.element;if(!C)return;let Y=m.side,L=m.original,P=L.top,N=L.right,_=L.bottom,le=L.left;if(Y==="top"){let be=m.startY-H;P=L.top+be,se||(_=L.bottom+be)}else if(Y==="bottom"){let be=H-m.startY;_=L.bottom+be,se||(P=L.top+be)}else if(Y==="left"){let be=m.startX-B;le=L.left+be,se||(N=L.right+be)}else if(Y==="right"){let be=B-m.startX;N=L.right+be,se||(le=L.left+be)}P=Math.max(0,P),N=Math.max(0,N),_=Math.max(0,_),le=Math.max(0,le),F&&(P=Tn(P),N=Tn(N),_=Tn(_),le=Tn(le)),P=Math.round(P),N=Math.round(N),_=Math.round(_),le=Math.round(le),_e(C,"padding",`${P}px ${N}px ${_}px ${le}px`),lt({side:Y,padding:{top:P,right:N,bottom:_,left:le}});return}let V=Gn(B,H);for(;V&&V.tagName==="A";)V=V.parentElement;{let C=[];V&&C.push(V),ft&&ft!==V&&C.push(ft);let Y=null,L=16,P=null;for(let N of C){let _=N.getBoundingClientRect(),le=Un(N),be=[["top-left",_.left,_.top+le["top-left"]],["top-right",_.right,_.top+le["top-right"]],["bottom-right",_.right,_.bottom-le["bottom-right"]],["bottom-left",_.left,_.bottom-le["bottom-left"]]];for(let[nt,Ye,Rt]of be){let ut=Math.hypot(B-Ye,H-Rt);ut<L&&(L=ut,Y=nt,P=N)}}if(Y&&P){Lt(P),bt(Y),z&&ie(null),Q&&Se(null),at&&Dt(null),tt&&vt(null),rn(!1),kt&&hn(null),W&&te(null);return}}ft&&Lt(null),pt&&bt(null);{let m=[];V&&ar(V)&&m.push(V);let C=(X=V==null?void 0:V.parentElement)!=null?X:null;for(;C&&C!==document.body&&m.length<3;)ar(C)&&m.push(C),C=C.parentElement;for(let Y of m){let P=Vn(Y).find(N=>B>=N.x&&B<=N.x+N.w&&H>=N.y&&H<=N.y+N.h);if(P){Dt(Y),vt(P.axis),rn(qr(Y,P.axis)),z&&ie(null),Q&&Se(null),kt&&hn(null),W&&te(null);return}}}at&&Dt(null),tt&&vt(null),rn(!1);{let C=[];V&&C.push(V),kt&&kt!==V&&C.push(kt);let Y=null,L=1/0,P=null;for(let N of C){if(!Qr(N))continue;let _=mo(N);if(!_)continue;let le=B>=_.left&&B<=_.right&&H>=_.top&&H<=_.bottom,be=[["font-size",_.right,_.top+_.height/2],["line-height",_.left+_.width/2,_.bottom]];for(let[nt,Ye,Rt]of be){let ut=Math.hypot(B-Ye,H-Rt);(le||ut<12)&&ut<L&&(L=ut,Y=nt,P=N)}}Y&&P?(hn(P),te(Y)):(kt&&hn(null),W&&te(null))}if(V!==z&&ie(V),V){let m=go(V),C=V.getBoundingClientRect(),Y=ns(B,H,C,m);Se(Y)}else Se(null);return}if(et){let{handle:B,originalPoints:H,hasMoved:se}=et,F=e.annotations.find(L=>L.id===et.annotationId);if(!F)return;let V="metaKey"in y,m=V&&(y.metaKey||y.ctrlKey),C=V&&y.shiftKey,Y;if(F.type==="line"){let L=H[0],P=H[H.length-1];B==="start"?Y=[x,P]:Y=[L,x]}else if(F.type==="freehand"){let L=Math.min(...H.map(De=>De.x)),P=Math.max(...H.map(De=>De.x)),N=Math.min(...H.map(De=>De.y)),_=Math.max(...H.map(De=>De.y)),le=(L+P)/2,be=(N+_)/2,nt=P-L||1,Ye=_-N||1,Rt=nt/Ye,ut=L,ue=P,we=N,Je=_;switch(B){case"topLeft":ut=x.x,we=x.y;break;case"topRight":ue=x.x,we=x.y;break;case"bottomLeft":ut=x.x,Je=x.y;break;case"bottomRight":ue=x.x,Je=x.y;break}if(m)switch(B){case"topLeft":ue=P+(L-ut),Je=_+(N-we);break;case"topRight":ut=L-(ue-P),Je=_+(N-we);break;case"bottomLeft":ue=P+(L-ut),we=N-(Je-_);break;case"bottomRight":ut=L-(ue-P),we=N-(Je-_);break}if(C){let De=ue-ut,mt=Je-we;if(Math.abs(De/mt)>Rt){let Ft=Math.abs(mt)*Rt*Math.sign(De);B==="topLeft"||B==="bottomLeft"?ut=ue-Ft:ue=ut+Ft}else{let Ft=Math.abs(De)/Rt*Math.sign(mt);B==="topLeft"||B==="topRight"?we=Je-Ft:Je=we+Ft}}let je=ue-ut||1,rt=Je-we||1;Y=H.map(De=>({x:ut+(De.x-L)/nt*je,y:we+(De.y-N)/Ye*rt}))}else if(F.type==="circle"){let L=H[0],P=H[H.length-1],N=Math.min(L.x,P.x),_=Math.max(L.x,P.x),le=Math.min(L.y,P.y),be=Math.max(L.y,P.y),nt=(N+_)/2,Ye=(le+be)/2,Rt=_-N,ut=be-le,ue=N,we=_,Je=le,je=be;switch(B){case"top":if(Je=x.y,m&&(je=Ye+(Ye-x.y)),C){let De=(je-Je)*(Rt/ut)/2;ue=nt-De,we=nt+De}break;case"bottom":if(je=x.y,m&&(Je=Ye-(x.y-Ye)),C){let De=(je-Je)*(Rt/ut)/2;ue=nt-De,we=nt+De}break;case"left":if(ue=x.x,m&&(we=nt+(nt-x.x)),C){let De=(we-ue)*(ut/Rt)/2;Je=Ye-De,je=Ye+De}break;case"right":if(we=x.x,m&&(ue=nt-(x.x-nt)),C){let De=(we-ue)*(ut/Rt)/2;Je=Ye-De,je=Ye+De}break}Y=[{x:ue,y:Je},{x:we,y:je}]}else{let L=H[0],P=H[H.length-1],N=Math.min(L.x,P.x),_=Math.max(L.x,P.x),le=Math.min(L.y,P.y),be=Math.max(L.y,P.y),nt=(N+_)/2,Ye=(le+be)/2,Rt=_-N||1,ut=be-le||1,ue=Rt/ut,we=N,Je=_,je=le,rt=be;switch(B){case"topLeft":we=x.x,je=x.y;break;case"topRight":Je=x.x,je=x.y;break;case"bottomLeft":we=x.x,rt=x.y;break;case"bottomRight":Je=x.x,rt=x.y;break}if(m)switch(B){case"topLeft":Je=_+(N-we),rt=be+(le-je);break;case"topRight":we=N-(Je-_),rt=be+(le-je);break;case"bottomLeft":Je=_+(N-we),je=le-(rt-be);break;case"bottomRight":we=N-(Je-_),je=le-(rt-be);break}if(C){let De=Je-we,mt=rt-je;if(Math.abs(De/mt)>ue){let Ft=Math.abs(mt)*ue*Math.sign(De);B==="topLeft"||B==="bottomLeft"?we=Je-Ft:Je=we+Ft}else{let Ft=Math.abs(De)/ue*Math.sign(mt);B==="topLeft"||B==="topRight"?je=rt-Ft:rt=je+Ft}}Y=[{x:we,y:je},{x:Je,y:rt}]}t({type:"RESIZE_ANNOTATION",payload:{id:et.annotationId,points:Y,saveUndo:!se}}),se||Ht(h(f({},et),{hasMoved:!0}));return}if(ye&&((M=ye.annotation.status)!=null?M:"pending")==="pending"){let B=x.x-ye.startPoint.x,H=x.y-ye.startPoint.y;if((Math.abs(B)>2||Math.abs(H)>2)&&!ye.hasMoved)ke(h(f({},ye),{hasMoved:!0,startPoint:x})),t({type:"MOVE_ANNOTATION",payload:{id:ye.annotation.id,delta:{x:B,y:H},saveUndo:!0}});else if(ye.hasMoved){let F=x.x-ye.startPoint.x,V=x.y-ye.startPoint.y;ke(h(f({},ye),{startPoint:x})),t({type:"MOVE_ANNOTATION",payload:{id:ye.annotation.id,delta:{x:F,y:V}}})}return}!q||!e.isAnnotating||t({type:"CONTINUE_PATH",payload:x})},[q,e.isAnnotating,e.activeTool,ye,et,ge,z,Q,ft,pt,at,tt,kt,W,oo,t,Tn,ns]),Ir=Pt(y=>{var M,B,H,se,F,V;if($t.current.isDragging){let m=$t.current,C=m.element;if(C&&m.selector&&m.elementInfo&&U){C instanceof HTMLElement&&(C.style.removeProperty("font-size"),C.style.removeProperty("line-height"),C.style.removeProperty("transition"));let Y=[];if(m.originalFontSize!==U.fontSize&&(_e(C,"font-size",`${U.fontSize}px`),Y.push({property:"font-size",original:`${m.originalFontSize}px`,modified:`${U.fontSize}px`})),m.originalLineHeight!==U.lineHeight){let L=m.originalFontSize>0?Math.round(m.originalLineHeight/m.originalFontSize*1e3)/1e3:1.2,P=U.fontSize>0?Math.round(U.lineHeight/U.fontSize*1e3)/1e3:1.2;_e(C,"line-height",`${P}`),Y.push({property:"line-height",original:`${L}`,modified:`${P}`})}Y.length>0&&t({type:"MODIFY_STYLES_BATCH",payload:{selector:m.selector,durableSelector:(M=m.durableSelector)!=null?M:void 0,element:m.elementInfo,changes:Y}})}$t.current={isDragging:!1,property:null,startX:0,startY:0,originalFontSize:0,originalLineHeight:0,originalRatio:1.2,element:null,elementInfo:null,selector:null,durableSelector:null},Pe(null);return}if(st.current.isDragging){let m=st.current,C=m.element,Y="button"in y&&y.button===2;if(!m.hasMoved&&!Y&&C&&m.selector&&m.elementInfo){C instanceof HTMLElement&&C.style.removeProperty("transition");let L=["space-between","space-around","stretch","normal"],P=m.originalJustifyContent||"normal",N=L.indexOf(P),_=L[(N+1)%L.length],le=[];_==="normal"?(_e(C,"justify-content","normal"),le.push({property:"justify-content",original:m.originalJustifyContent,modified:"normal"})):_==="stretch"?(_e(C,"justify-content",_),_e(C,"row-gap","8px"),_e(C,"column-gap","8px"),le.push({property:"justify-content",original:m.originalJustifyContent||"normal",modified:_}),m.originalRow!==8&&le.push({property:"row-gap",original:`${m.originalRow}px`,modified:"8px"}),m.originalColumn!==8&&le.push({property:"column-gap",original:`${m.originalColumn}px`,modified:"8px"})):(C instanceof HTMLElement&&(C.style.removeProperty("row-gap"),C.style.removeProperty("column-gap")),_e(C,"justify-content",_),le.push({property:"justify-content",original:m.originalJustifyContent||"normal",modified:_}),m.originalRow>0&&le.push({property:"row-gap",original:`${m.originalRow}px`,modified:"0px"}),m.originalColumn>0&&le.push({property:"column-gap",original:`${m.originalColumn}px`,modified:"0px"})),le.length>0&&t({type:"MODIFY_STYLES_BATCH",payload:{selector:m.selector,durableSelector:(B=m.durableSelector)!=null?B:void 0,element:m.elementInfo,changes:le}})}else if(m.hasMoved&&C&&m.selector&&m.elementInfo&&$e){C instanceof HTMLElement&&(C.style.removeProperty("row-gap"),C.style.removeProperty("column-gap"),C.style.removeProperty("transition"));let L=[];m.isAuto?(C instanceof HTMLElement&&C.style.removeProperty("justify-content"),_e(C,"justify-content","normal"),_e(C,"row-gap",`${$e.row}px`),_e(C,"column-gap",`${$e.column}px`),L.push({property:"justify-content",original:m.originalJustifyContent,modified:"normal"}),L.push({property:"row-gap",original:"0px",modified:`${$e.row}px`}),L.push({property:"column-gap",original:"0px",modified:`${$e.column}px`})):(m.originalRow!==$e.row&&(_e(C,"row-gap",`${$e.row}px`),L.push({property:"row-gap",original:`${m.originalRow}px`,modified:`${$e.row}px`})),m.originalColumn!==$e.column&&(_e(C,"column-gap",`${$e.column}px`),L.push({property:"column-gap",original:`${m.originalColumn}px`,modified:`${$e.column}px`}))),L.length>0&&t({type:"MODIFY_STYLES_BATCH",payload:{selector:m.selector,durableSelector:(H=m.durableSelector)!=null?H:void 0,element:m.elementInfo,changes:L}})}st.current={isDragging:!1,hasMoved:!1,axis:null,startX:0,startY:0,originalRow:0,originalColumn:0,element:null,elementInfo:null,selector:null,durableSelector:null,isAuto:!1,originalJustifyContent:"",visualGap:0},en(null);return}if(Fe.current.isDragging){let m=Fe.current,C=m.element;if(C&&m.selector&&m.elementInfo&&St){C instanceof HTMLElement&&(C.style.removeProperty("border-top-left-radius"),C.style.removeProperty("border-top-right-radius"),C.style.removeProperty("border-bottom-right-radius"),C.style.removeProperty("border-bottom-left-radius"),C.style.removeProperty("transition"));let Y=["top-left","top-right","bottom-right","bottom-left"],L={"top-left":"border-top-left-radius","top-right":"border-top-right-radius","bottom-right":"border-bottom-right-radius","bottom-left":"border-bottom-left-radius"},P=[];for(let N of Y)m.original[N]!==St.radius[N]&&(_e(C,L[N],`${St.radius[N]}px`),P.push({property:L[N],original:`${m.original[N]}px`,modified:`${St.radius[N]}px`}));P.length>0&&t({type:"MODIFY_STYLES_BATCH",payload:{selector:m.selector,durableSelector:(se=m.durableSelector)!=null?se:void 0,element:m.elementInfo,changes:P}})}Fe.current={isDragging:!1,corner:null,startY:0,original:{"top-left":0,"top-right":0,"bottom-right":0,"bottom-left":0},maxRadius:0,element:null,elementInfo:null,selector:null,durableSelector:null},dn(null);return}if(Ve.current.isDragging){let m=Ve.current,C=m.element,Y=m.selector,L=m.elementInfo;if(C&&Y&&L&&fe){let P=m.original,N=fe.padding;C instanceof HTMLElement&&(C.style.removeProperty("padding"),C.style.removeProperty("transition"));let _=[],le=[{prop:"padding-top",origVal:P.top,newVal:N.top},{prop:"padding-right",origVal:P.right,newVal:N.right},{prop:"padding-bottom",origVal:P.bottom,newVal:N.bottom},{prop:"padding-left",origVal:P.left,newVal:N.left}];for(let{prop:be,origVal:nt,newVal:Ye}of le)nt!==Ye&&(_e(C,be,`${Ye}px`),_.push({property:be,original:`${nt}px`,modified:`${Ye}px`}));_.length>0&&t({type:"MODIFY_STYLES_BATCH",payload:{selector:Y,durableSelector:(F=m.durableSelector)!=null?F:void 0,element:L,changes:_}})}Ve.current={isDragging:!1,side:null,startX:0,startY:0,original:{top:0,right:0,bottom:0,left:0},element:null,elementInfo:null,selector:null,durableSelector:null},lt(null);return}if(et){Ht(null);return}if(ye){if(!ye.hasMoved&&ye.annotation.type==="text"&&((V=ye.annotation.status)!=null?V:"pending")==="pending"){let m=oo(y);D({id:ye.annotation.id,point:ye.annotation.points[0],text:ye.annotation.text||"",fontSize:ye.annotation.fontSize||12,isNew:!1,clickPoint:m,groupId:ye.annotation.groupId})}ke(null);return}if(!q)return;let x=5;if(e.currentPath.length>=2){let m=e.currentPath[0],C=e.currentPath[e.currentPath.length-1],Y=Math.abs(C.x-m.x),L=Math.abs(C.y-m.y);if((e.activeTool==="line"?Math.sqrt(Y*Y+L*L)<x:Y<x&&L<x)&&["rectangle","circle","line"].includes(e.activeTool)){j(!1),t({type:"CANCEL_PATH"});return}}let X=Vr(e.currentPath);if(e.activeTool==="rectangle"&&e.currentPath.length>=2){let m=e.currentPath[0],C=e.currentPath[e.currentPath.length-1],Y=Math.min(m.x,C.x),L=Math.max(m.y,C.y),P=e.strokeWidth/2,N=Math.random().toString(36).substring(2,9);ve({point:{x:Y-P+4,y:L+P+4},groupId:N}),j(!1),t({type:"FINISH_PATH",payload:{groupId:N,elements:X}});return}j(!1),t({type:"FINISH_PATH",payload:{elements:X}})},[q,ye,et,fe,St,$e,U,oo,t,e.activeTool,e.currentPath,e.strokeWidth]),fa=Pt(y=>{let x=y.target.value;Xo.current=y.target.selectionStart,D(X=>X&&h(f({},X),{text:x}))},[]),ga=Pt(y=>{y.key==="Escape"?D(null):y.key==="Enter"&&!y.shiftKey&&(y.preventDefault(),ro())},[ro]),ma=Pt(y=>{if(!T)return;let x=y.clipboardData.items,X=[];for(let M=0;M<x.length;M++){let B=x[M];if(B.type.startsWith("image/")){let H=B.getAsFile();H&&X.push(H)}}X.length>0&&(y.preventDefault(),D(M=>M?h(f({},M),{images:[...M.images||[],...X]}):null))},[T]),ha=Pt(y=>{if(!e.isAnnotating)return;if(e.activeTool==="hand"){y.preventDefault();let X=z||at||ft||kt;if(X&&!It(X)){let M=qt(X),B=sn(X);t({type:"SELECT_ELEMENT",payload:{el:X,info:h(f({},M),{selector:B})}})}return}y.preventDefault();let x=A.current;x&&($.current=!0,x.style.pointerEvents="none",setTimeout(()=>{$.current&&($.current=!1,x.style.pointerEvents="")},4e3))},[e.activeTool,e.isAnnotating,z,at,ft,kt,t,It,A]);Vt(()=>{let y=e.annotations.filter(H=>H.linkedSelector);if(y.length===0)return;let x=null,X=()=>{var se,F,V;let H=[];for(let m of y){let C=document.querySelector(m.linkedSelector);if(!C&&((F=(se=m.elements)==null?void 0:se[0])!=null&&F.selector)&&m.linkedSelector.startsWith("[data-pm=")){try{C=document.querySelector(m.elements[0].selector)}catch(Ye){}if(C){let Ye=(V=m.linkedSelector.match(/data-pm="([^"]+)"/))==null?void 0:V[1];Ye&&C.setAttribute("data-pm",Ye)}}if(!C)continue;let Y=C.getBoundingClientRect(),L=e.styleModifications.some(Ye=>{try{return C.matches(Ye.selector)}catch(Rt){return!1}}),P=y.filter(Ye=>Ye.id!==m.id&&Ye.timestamp<m.timestamp&&Ye.linkedSelector===m.linkedSelector).length,N=(L?1:0)+P,_=Y.top>=Xn*(1+N)?"top-left":"bottom-left",le=Nl(Y,_,N),be=m.points[0],nt=_!==m.linkedAnchor;be&&(nt||Math.abs(le.x-be.x)>1||Math.abs(le.y-be.y)>1)&&H.push({id:m.id,point:le,linkedAnchor:nt?_:void 0})}H.length>0&&t({type:"UPDATE_LINKED_POSITIONS",payload:{updates:H}})},M=()=>{x&&cancelAnimationFrame(x),x=requestAnimationFrame(X)};X(),window.addEventListener("scroll",M,!0),window.addEventListener("resize",M,!0),window.addEventListener("load",M),document.fonts.ready.then(M);let B=new MutationObserver(M);return B.observe(document.body,{attributes:!0,childList:!0,subtree:!0,attributeFilter:["style","class"]}),()=>{window.removeEventListener("scroll",M,!0),window.removeEventListener("resize",M,!0),window.removeEventListener("load",M),B.disconnect(),x&&cancelAnimationFrame(x)}},[e.annotations,t]);let ya=()=>{var y,x,X;if(!e.isAnnotating)return"default";if(et){let{handle:M}=et;return M==="start"||M==="end"?"move":M==="top"||M==="bottom"?"ns-resize":M==="left"||M==="right"?"ew-resize":M==="topLeft"||M==="bottomRight"?"nwse-resize":"nesw-resize"}if(e.activeTool==="text")return"text";if(e.activeTool==="hand"){let M=(y=$e==null?void 0:$e.axis)!=null?y:tt;if(M==="row")return"ns-resize";if(M==="column")return"ew-resize";if(St||pt)return"ns-resize";let B=(x=U==null?void 0:U.property)!=null?x:W;if(B==="font-size")return"ew-resize";if(B==="line-height")return"ns-resize";let H=(X=fe==null?void 0:fe.side)!=null?X:Q;return H==="top"||H==="bottom"?"ns-resize":H==="left"||H==="right"?"ew-resize":"default"}return"crosshair"},ba={position:"fixed",top:0,left:0,width:"100vw",height:"100vh",zIndex:9998,pointerEvents:e.isAnnotating?"auto":"none",visibility:e.isAnnotating?"visible":"hidden",cursor:ya()},Oo=Pt(()=>{let y=A.current;if(!y||!T)return{width:100,height:12*1.4,isWrapped:!1};let x=y.getContext("2d");if(!x)return{width:100,height:T.fontSize*1.4,isWrapped:!1};x.font=`${T.fontSize}px ${Wt}`;let M=x.measureText("Type here...").width,B=T.text.split(`
9
- `),H=B.length>0?Math.max(M,...B.map(C=>x.measureText(C||" ").width)):M,se=T.point.x-wt.x,F=co(se);if(F!==void 0&&H>F){let C=jn(x,B,F),Y=Math.min(F,Math.max(M,...C.map(P=>x.measureText(P).width))),L=Math.max(1,C.length)*T.fontSize*1.4;return{width:Y,height:L,isWrapped:!0}}let m=Math.max(1,B.length)*T.fontSize*1.4;return{width:H,height:m,isWrapped:!1}},[T,A,wt.x])(),xa=T?Math.max(1,T.text.split(`
10
- `).length)*T.fontSize*1.4+8:0,is=Oo.height+8,va=Oo.isWrapped?is-xa:0,Sa=T?{position:"fixed",left:T.point.x-4-wt.x,top:T.point.y-4-wt.y-va,zIndex:9999,width:Oo.width+8,height:is,padding:4,fontSize:T.fontSize,fontFamily:Wt,color:"#ffffff",backgroundColor:e.activeColor,border:"none",borderRadius:0,outline:"none",boxShadow:"none",lineHeight:1.4,resize:"none",overflow:"hidden",whiteSpace:Oo.isWrapped?"pre-wrap":"pre",wordBreak:Oo.isWrapped?"break-word":void 0}:{};return ko(Co,{children:[ot("canvas",{ref:I,id:"devtools-canvas",style:ba,onMouseDown:os,onMouseMove:rs,onMouseUp:y=>Ir(y),onMouseLeave:y=>{Ir(y),Ge(null),dt(null)},onTouchStart:os,onTouchMove:rs,onTouchEnd:y=>Ir(y),onContextMenu:ha}),T&&ko(Co,{children:[ot("style",{children:"#devtools-text-input::placeholder { color: rgba(255, 255, 255, 0.5); }"}),ot("textarea",{id:"devtools-text-input",ref:We,value:T.text,onChange:fa,onKeyDown:ga,onPaste:ma,onBlur:ro,placeholder:"Type here...",style:Sa}),T.images&&T.images.length>0&&ko("div",{"data-devtools":!0,style:{position:"fixed",left:T.point.x-4-wt.x,top:T.point.y-4-wt.y-20,zIndex:1e4,fontSize:11,fontFamily:"system-ui, sans-serif",color:"#fff",backgroundColor:"rgba(0,0,0,0.7)",padding:"2px 6px",borderRadius:3,whiteSpace:"nowrap"},children:[T.images.length," image",T.images.length>1?"s":""," attached"]})]}),e.isAnnotating&&e.activeTool!=="hand"&&e.styleModifications.length>0&&ot(ml,{styleModifications:e.styleModifications,isInspecting:!!e.inspectedElement,accentColor:e.activeColor,annotationGroupCount:new Set(e.annotations.map(y=>y.groupId||y.id)).size,dispatch:t,inFlightSelectors:n}),e.activeTool==="hand"&&e.isAnnotating&&e.styleModifications.length>0&&ot(yl,{styleModifications:e.styleModifications,accentColor:e.activeColor}),e.isAnnotating&&ot(il,{annotations:e.annotations,supersededAnnotations:Dn,inFlightIds:r,scrollX:wt.x,scrollY:wt.y,annotationGroupMap:Jo,onViewThread:a,onSelectAnnotation:gt,canvasRef:A}),e.isAnnotating&&l&&ot(sl,{annotations:e.annotations,supersededAnnotations:Dn,scrollX:wt.x,scrollY:wt.y,onReply:l,annotationGroupMap:Jo,canvasRef:A}),e.isAnnotating&&i&&i.size>0&&ot(ri,{inFlightSelectorColors:i}),e.isAnnotating&&Qi&&ot(ri,{inFlightSelectorColors:Qi,animated:!1}),e.activeTool==="hand"&&e.isAnnotating&&($e?st.current.element:at)&&ot(ci,{element:$e?st.current.element:at,gap:$e?{row:$e.row,column:$e.column}:Fo(at),accentColor:e.activeColor,hoveredAxis:tt,draggingAxis:(ls=$e==null?void 0:$e.axis)!=null?ls:null,cursorViewport:Tt,isAutoGap:Kt,refreshKey:mn}),e.activeTool==="hand"&&e.isAnnotating&&J&&ot(Dl,{element:J.target,modifier:J.modifier,accentColor:e.activeColor,refreshKey:mn}),e.activeTool==="hand"&&e.isAnnotating&&!J&&(St?Fe.current.element:ft)&&ot(ul,{element:St?Fe.current.element:ft,radius:(as=St==null?void 0:St.radius)!=null?as:Un(ft),accentColor:e.activeColor,hoveredCorner:pt,draggingCorner:(cs=St==null?void 0:St.corner)!=null?cs:null,cursorViewport:Tt}),e.activeTool==="hand"&&e.isAnnotating&&!J&&(U?$t.current.element:kt)&&ot(Hl,{element:U?$t.current.element:kt,fontSize:(ds=U==null?void 0:U.fontSize)!=null?ds:No(kt).fontSize,lineHeight:(us=U==null?void 0:U.lineHeight)!=null?us:No(kt).lineHeight,accentColor:e.activeColor,hoveredProperty:W,draggingProperty:(ps=U==null?void 0:U.property)!=null?ps:null,cursorViewport:Tt}),e.activeTool==="hand"&&e.isAnnotating&&!J&&(fe?Ve.current.element:z)&&ot(mi,{element:fe?Ve.current.element:z,padding:(fs=fe==null?void 0:fe.padding)!=null?fs:go(z),accentColor:e.activeColor,hoveredSide:Q,draggingSide:(gs=fe==null?void 0:fe.side)!=null?gs:null,cursorViewport:Tt,refreshKey:U?U.fontSize+U.lineHeight*1e3:0}),e.activeTool==="inspector"&&e.isAnnotating&&ot(Co,{children:ge&&!e.inspectedElement&&(()=>{let y=!!ae||!!(T!=null&&T.linkedSelector)||e.annotations.some(x=>{if(!x.linkedSelector)return!1;try{return ge.matches(x.linkedSelector)}catch(X){return!1}});return ot(bo,{element:ge,isSelected:!1,elementInfo:xt,color:e.activeColor,hideTooltip:y})})()}),e.activeTool==="model"&&e.isAnnotating&&ce.size>0&&[...ce.entries()].map(([y,x])=>ot(bo,{element:x.rootElement,isSelected:!0,elementInfo:{selector:"",tagName:x.rootElement.tagName.toLowerCase(),reactComponent:y},color:"#8b5cf6"},y)),e.activeTool==="model"&&e.isAnnotating&&Bo&&ot(bo,{element:Bo.rootElement,isSelected:!0,elementInfo:{selector:"",tagName:Bo.rootElement.tagName.toLowerCase(),reactComponent:Bo.name},color:"#22c55e"}),e.activeTool==="model"&&e.isAnnotating&&un.length>0&&un.map((y,x)=>ot("div",{style:{position:"absolute",left:y.x,top:y.y,width:y.width,height:y.height,backgroundColor:"rgba(255, 0, 0, 0.08)",pointerEvents:"none",zIndex:9998},children:y.direction==="vertical"?ko(Co,{children:[ot("div",{style:{position:"absolute",left:"50%",top:0,width:6,height:1,backgroundColor:"#FF0000",transform:"translateX(-50%)"}}),ot("div",{style:{position:"absolute",left:"50%",top:0,bottom:0,width:1,backgroundColor:"#FF0000",transform:"translateX(-50%)"}}),ot("div",{style:{position:"absolute",left:"50%",bottom:0,width:6,height:1,backgroundColor:"#FF0000",transform:"translateX(-50%)"}}),ot("div",{style:{position:"absolute",left:"calc(50% + 6px)",top:y.height<16?-6:"50%",transform:y.height<16?"none":"translateY(-50%)",fontSize:11,fontWeight:600,color:"#fff",backgroundColor:"#FF0000",padding:"2px 4px",whiteSpace:"nowrap",fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',lineHeight:1},children:Math.round(y.height)})]}):ko(Co,{children:[ot("div",{style:{position:"absolute",left:0,top:"50%",width:1,height:6,backgroundColor:"#FF0000",transform:"translateY(-50%)"}}),ot("div",{style:{position:"absolute",left:0,right:0,top:"50%",height:1,backgroundColor:"#FF0000",transform:"translateY(-50%)"}}),ot("div",{style:{position:"absolute",right:0,top:"50%",width:1,height:6,backgroundColor:"#FF0000",transform:"translateY(-50%)"}}),ot("div",{style:{position:"absolute",left:y.width<30?0:"50%",top:(y.width<30,void 0),bottom:"calc(50% + 4px)",transform:y.width<30?"none":"translateX(-50%)",fontSize:11,fontWeight:600,color:"#fff",backgroundColor:"#FF0000",padding:"2px 4px",whiteSpace:"nowrap",fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',lineHeight:1},children:Math.round(y.width)})]})},x)),e.activeTool==="model"&&e.isAnnotating&&oe&&ot(bo,{element:oe.rootElement,isSelected:!1,elementInfo:{selector:"",tagName:oe.rootElement.tagName.toLowerCase(),reactComponent:oe.name},color:g!=null&&g.has(oe.name)?"#22c55e":"#8b5cf6"}),e.activeTool==="hand"&&e.isAnnotating&&e.inspectedElement&&ko(Co,{children:[Le&&Le!=="padding"&&Le!=="gap"&&(()=>{var F;let y=new Set(e.annotations.map(V=>V.groupId||V.id)).size,x=e.inspectedElement.info.selector,X=e.styleModifications.findIndex(V=>V.selector===x),M=X>=0?y+X+1:y+e.styleModifications.length+1,B=e.styleModifications.find(V=>V.selector===x),H=(F=B==null?void 0:B.changes.length)!=null?F:0,se=!!(B!=null&&B.captured);return ot(bo,{element:e.inspectedElement.el,isSelected:!0,elementInfo:e.inspectedElement.info,color:se?"#999999":e.activeColor,annotationNumber:M,changeCount:H})})(),Le==="padding"&&ot(mi,{element:e.inspectedElement.el,padding:go(e.inspectedElement.el),accentColor:e.activeColor,hoveredSide:null,draggingSide:null}),Le==="gap"&&ot(ci,{element:e.inspectedElement.el,gap:Fo(e.inspectedElement.el),accentColor:e.activeColor,hoveredAxis:null,draggingAxis:null}),ot(Bl,{element:e.inspectedElement.el,elementInfo:e.inspectedElement.info,selector:e.inspectedElement.info.selector,styleModifications:e.styleModifications,dispatch:t,onClose:()=>t({type:"SELECT_ELEMENT",payload:null}),onHover:Ze,accentColor:e.activeColor,toolbarRef:O})]})]})}import{useCallback as cn,useEffect as wn,useMemo as Di,useRef as Bt,useState as jo}from"react";import{Circle as Tu,Component as Lu,Hand as Iu,MessageCircle as Ru,Pen as Au,Slash as Pu,Square as Bu,Trash2 as Ou,Type as Du}from"lucide-react";import{useEffect as nu,useRef as ou}from"react";function zl(e,t,o,r,n){let i=ou(0);nu(()=>{if(!o.current||(localStorage.setItem(n.expanded,String(e)),!e))return;let s=t.annotations.length;(s>=i.current||s===0||!r)&&(localStorage.setItem(n.annotations,JSON.stringify(t.annotations)),i.current=s),localStorage.setItem(n.styleMods,JSON.stringify(t.styleModifications)),localStorage.setItem(n.spacingChanges,JSON.stringify(t.spacingTokenChanges)),localStorage.setItem(n.tool,t.activeTool),localStorage.setItem(n.color,t.activeColor),localStorage.setItem(n.stroke,String(t.strokeWidth)),t.inspectedElement?localStorage.setItem(n.inspected,JSON.stringify({selector:t.inspectedElement.info.selector,info:t.inspectedElement.info})):localStorage.removeItem(n.inspected)},[e,t.annotations,t.styleModifications,t.spacingTokenChanges,t.activeTool,t.activeColor,t.strokeWidth,t.inspectedElement,r,o,n])}import{Component as ru,createElement as iu,useCallback as Er,useEffect as To,useRef as Mo,useState as Sn}from"react";import{Fragment as Lo,jsx as He,jsxs as Qt}from"react/jsx-runtime";var $l="popmelt-library-tab",su=/^#[0-9a-fA-F]{3,8}$/,lu=/^(?:rgba?|hsla?|oklch)\([^)]+\)$/,au=new Set(["black","white","red","blue","green","yellow","orange","purple","pink","gray","grey","cyan","magenta","brown","navy","teal","maroon","olive","silver","aqua","fuchsia","lime"]),cu=/^-?\d+(\.\d+)?(px|rem|em|%)$/;function Wl(e){let t=e.trim();return su.test(t)||lu.test(t)||au.has(t.toLowerCase())}function du(e){return cu.test(e.trim())}function uu(e){let t=e.trim().match(/^(-?\d+(?:\.\d+)?)px$/);return t?parseFloat(t[1]):null}function Pi(e,t=""){if(e==null)return[];if(typeof e!="object")return[[t,String(e)]];if(Array.isArray(e))return[[t,e.map(String).join(", ")]];let o=[];for(let[r,n]of Object.entries(e)){let i=t?`${t}.${r}`:r;if(n!==null&&typeof n=="object"&&!Array.isArray(n)){let s=n;typeof s.value=="string"?o.push([i,s.value]):o.push(...Pi(n,i))}else o.push([i,Array.isArray(n)?n.map(String).join(", "):String(n!=null?n:"")])}return o}function pu(e){return e.length===0?"generic":e.filter(([,r])=>Wl(r)).length>e.length/2?"colors":e.filter(([,r])=>du(r)).length>e.length/2?"spacing":"generic"}var fu=h(f({position:"fixed",top:16,right:16,bottom:80,width:300,backgroundColor:"#ffffff"},bn),{boxSizing:"content-box",zIndex:10001,display:"flex",flexDirection:"column",overflow:"hidden",fontFamily:"ui-monospace, SFMono-Regular, Menlo, Consolas, monospace",fontSize:12,color:"#1f2937",padding:12,pointerEvents:"auto"}),Yl={border:"none",background:"none",cursor:"pointer",fontFamily:"inherit",fontSize:11,fontWeight:600,padding:"2px 0",color:"#9ca3af"},gu=h(f({},Yl),{color:"#1f2937",borderBottom:"1.5px solid #1f2937"});function mu({entries:e}){let t=[],o=[];for(let r of e)Wl(r[1])?t.push(r):o.push(r);return Qt(Lo,{children:[t.length>0&&He("div",{style:{display:"flex",flexWrap:"wrap",gap:2,marginBottom:o.length>0?6:0},children:t.map(([r,n])=>He("div",{title:`${r.split(".").pop()}: ${n}`,style:{width:28,height:28,backgroundColor:n,outline:"1px solid rgba(0,0,0,0.08)",outlineOffset:-1}},r))}),o.length>0&&He(Bi,{entries:o})]})}var wr=[0,1,2,4,8,12,16,20,24,28,32];function hu(e){if(e<=32){let t=wr[0],o=Math.abs(e-t);for(let r=1;r<wr.length;r++){let n=Math.abs(e-wr[r]);n<o&&(t=wr[r],o=n)}return t}return Math.round(e/8)*8}function yu({label:e,value:t,px:o,tokenPath:r,rawToken:n,onHover:i,onModify:s,onDelete:l}){let[a,c]=Sn(!1),[d,u]=Sn(null),p=Mo(!1),g=Mo(0),S=Mo(0),v=Mo([]),b=d!==null?d:o,w=d!==null?`${d}px`:t,O=d!==null,A=Er(E=>{E.preventDefault(),p.current=!0,g.current=E.clientX,S.current=o;let I=sr(n);v.current=Jr(I);let $=j=>{let T=j.clientX-g.current,D=Math.max(0,Math.round(S.current+T));j.shiftKey&&(D=hu(D));for(let K of v.current)K.element.style.setProperty(K.property,D+"px","important");u(D),i==null||i({name:e,px:D,token:I})},q=()=>{window.removeEventListener("mousemove",$),window.removeEventListener("mouseup",q),document.body.style.cursor="",p.current=!1,u(j=>{if(j!==null&&j!==o&&s){let T=sr(n),D=T.bindings&&T.bindings.length>0,K;if(D){let ae=Kr(T.bindings,S.current,j);K=JSON.stringify(h(f({},T),{value:`${j}px`,bindings:ae}))}else{let ae=Ks(v.current,S.current),Re=Zs(v.current);if(ae.length>0){let We=Kr(ae,S.current,j);K=JSON.stringify({value:`${j}px`,property:Re,bindings:We})}else K=`${j}px`}let ee=typeof n=="string"?n:JSON.stringify(n),me=v.current.map(ae=>({selector:sn(ae.element),property:ae.property})),ve=Qs(v.current,S.current,j);s({tokenPath:r,originalValue:ee,currentValue:K,targets:me,originalPx:S.current,currentPx:j},{id:Math.random().toString(36).substring(2,9),tokenPath:r,tokenName:e,originalPx:S.current,newPx:j,affectedElements:ve})}return j})};document.body.style.cursor="ew-resize",window.addEventListener("mousemove",$),window.addEventListener("mouseup",q)},[o,e,r,n,i,s]),k=sr(n);return Qt("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",fontSize:11,padding:"1px 0",cursor:"ew-resize",userSelect:"none"},onMouseEnter:()=>{p.current||(c(!0),i==null||i({name:e,px:b,token:k}))},onMouseLeave:()=>{p.current||(c(!1),i==null||i(null))},onMouseDown:A,children:[He("span",{style:{color:a||O?"#FF0000":"#9ca3af"},children:e}),Qt("span",{style:{display:"flex",alignItems:"center",gap:4},children:[He("span",{style:{color:a||O?"#FF0000":"#6b7280",fontWeight:600},children:w}),l&&a&&!O&&He("button",{type:"button",title:"Remove token",onMouseDown:E=>{E.stopPropagation();let I=typeof n=="string"?n:JSON.stringify(n);l(r,I)},style:{border:"none",background:"none",cursor:"pointer",padding:0,fontSize:10,lineHeight:1,color:"#9ca3af"},onMouseEnter:E=>{E.currentTarget.style.color="#FF0000"},onMouseLeave:E=>{E.currentTarget.style.color="#9ca3af"},children:"\u2715"})]})]})}function bu({entries:e,categoryKey:t,rawTokens:o,onHover:r,onModify:n,onDelete:i}){let s=[],l=[];for(let a of e){let c=uu(a[1]);c!==null?s.push([a[0],a[1],c]):l.push(a)}return Qt(Lo,{children:[s.length>0&&He("div",{style:{display:"flex",flexDirection:"column",gap:2},children:s.map(([a,c,d])=>{let u=a.split(".").pop(),p=o?xu(o,a):c,g=p&&typeof p=="object"&&"value"in p?p:c;return He(yu,{label:u,value:c,px:d,tokenPath:`tokens.${t}.${a}`,rawToken:g,onHover:r,onModify:n,onDelete:i},a)})}),l.length>0&&He(Bi,{entries:l})]})}function xu(e,t){let o=t.split("."),r=e;for(let n of o){if(r==null||typeof r!="object")return;r=r[n]}return r}function Bi({entries:e}){return He("div",{style:{display:"flex",flexDirection:"column",gap:3},children:e.map(([t,o])=>Qt("div",{style:{fontSize:11},children:[He("div",{style:{color:"#9ca3af",fontSize:10,marginBottom:1},children:t}),He("div",{style:{color:"#1f2937",lineHeight:1.4,paddingLeft:8},children:o})]},t))})}function jl({entries:e,categoryKey:t,rawTokens:o,onSpacingHover:r,onModifyToken:n,onDeleteToken:i}){let s=pu(e);return s==="colors"?He(mu,{entries:e}):s==="spacing"?He(bu,{entries:e,categoryKey:t,rawTokens:o,onHover:r,onModify:n,onDelete:i}):He(Bi,{entries:e})}function vu(e){let t=e.toLowerCase(),o=null,r=document.createTreeWalker(document.body,NodeFilter.SHOW_ELEMENT,{acceptNode(i){return i.closest("#devtools-toolbar, #devtools-canvas, #devtools-scrim, [data-popmelt-panel]")?NodeFilter.FILTER_REJECT:NodeFilter.FILTER_ACCEPT}}),n=r.currentNode;for(;n=r.nextNode();){let i=n,s=Object.keys(i).find(a=>a.startsWith("__reactFiber$")||a.startsWith("__reactInternalInstance$"));if(!s)continue;let l=i[s];for(;l;){let a=l.type,c=typeof a=="function"||typeof a=="object"?(a==null?void 0:a.displayName)||(a==null?void 0:a.name):null;if(typeof c=="string"){let d=c.toLowerCase();if(d===t){let u=f({},l.memoizedProps);return delete u.ref,{type:a,props:u}}if(!o){if(d.length>=4&&t.includes(d)){let u=f({},l.memoizedProps);delete u.ref,o={type:a,props:u}}else if(t.length>=4&&d.includes(t)){let u=f({},l.memoizedProps);delete u.ref,o={type:a,props:u}}}}l=l.return}}return o}var Ai=class extends ru{constructor(){super(...arguments);this.state={hasError:!1}}static getDerivedStateFromError(){return{hasError:!0}}componentDidCatch(){this.props.onError()}render(){return this.state.hasError?null:this.props.children}};function Su({children:e}){return He("div",{style:{fontWeight:700,fontSize:11,color:"#6b7280",letterSpacing:"0.05em",marginBottom:6},children:e})}function wu({tokens:e,onSpacingTokenHover:t,onModifyToken:o,onDeleteToken:r}){return!e||Object.keys(e).length===0?He("div",{style:{color:"#9ca3af",fontSize:11},children:"No tokens defined yet."}):He(Lo,{children:Object.entries(e).map(([n,i])=>Qt("div",{style:{marginBottom:14},children:[He(Su,{children:n}),He(jl,{entries:Pi(i),categoryKey:n,rawTokens:i,onSpacingHover:t,onModifyToken:o,onDeleteToken:r})]},n))})}function Eu({rules:e}){return!e||e.length===0?He("div",{style:{color:"#9ca3af",fontSize:11},children:"No rules defined yet."}):He(Lo,{children:e.map((t,o)=>Qt("div",{style:{display:"flex",gap:6,marginBottom:4,lineHeight:1.4,fontSize:11},children:[Qt("span",{style:{color:"#9ca3af",flexShrink:0},children:[o+1,"."]}),He("span",{children:t})]},o))})}function ku({name:e,value:t,selected:o,highlighted:r,onRemove:n,onHover:i}){var j;let[s,l]=Sn(!1),[a,c]=Sn(!1),d=Mo(null),u=Mo(0),[p,g]=Sn(0),[S,v]=Sn(0),b=Pi(t),w=(j=b.find(([T])=>T==="description"))==null?void 0:j[1];To(()=>{if(!a&&!r){g(0),v(0),u.current=0;return}let T=po(e);g(T.length)},[a,r,e]),To(()=>{o&&d.current&&d.current.scrollIntoView({behavior:"smooth",block:"nearest"})},[o]);let O=o||r||a,A=o?"139,92,246":"34,197,94",k=o?"#8b5cf6":"#22c55e",E=O?`rgba(${A},0.06)`:void 0,I=O?`inset 0 0 0 1.5px rgba(${A},0.35)`:void 0,$=r||a,q=Er(()=>{let T=po(e);if(T.length===0)return;let D=u.current%T.length;T[D].rootElement.scrollIntoView({behavior:"smooth",block:"center"}),v(D),u.current=D+1,i==null||i({name:e,instanceIndex:D})},[e,i]);return Qt("div",{ref:d,onClick:q,onMouseEnter:()=>{c(!0),i==null||i({name:e,instanceIndex:0})},onMouseLeave:()=>{c(!1),i==null||i(null)},style:{marginBottom:8,background:E,padding:6,boxShadow:I,cursor:"pointer"},children:[Qt("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between"},children:[Qt("div",{style:{display:"flex",alignItems:"center",gap:6,marginBottom:6},children:[He("div",{style:{fontWeight:700,fontSize:11,letterSpacing:"0.05em",padding:"2px 6px",backgroundColor:$?k:"transparent",color:$?"#fff":"#6b7280"},children:e}),$&&p>1&&Qt("span",{style:{fontSize:10,fontWeight:600,color:"#9ca3af"},children:[S+1,"/",p]})]}),n&&a&&He("button",{type:"button",title:"Remove from model",onClick:T=>{T.stopPropagation(),n(e)},style:{border:"none",background:"none",cursor:"pointer",padding:"0 2px",fontSize:14,lineHeight:1,color:"#9ca3af",marginTop:-4},onMouseEnter:T=>{T.currentTarget.style.color="#FF0000"},onMouseLeave:T=>{T.currentTarget.style.color="#9ca3af"},children:"\u2715"})]}),w&&He("div",{style:{fontSize:11,color:$?"#1f2937":"#9ca3af",marginBottom:6,lineHeight:1.4},children:w}),s?He(jl,{entries:b.filter(([T])=>T!=="description"),categoryKey:""}):He(Cu,{name:e,onNotFound:()=>l(!0),entries:b})]})}function Cu({name:e,onNotFound:t}){let[o,r]=Sn(null),[n,i]=Sn(!1);return To(()=>{let s=vu(e);s||t(),r(s),i(!0)},[e,t]),!n||!o?null:He(Ai,{onError:t,children:He("div",{"data-popmelt-panel":!0,onClick:s=>{s.preventDefault(),s.stopPropagation()},style:{width:"100%",overflowY:"auto",overflowX:"hidden",maxHeight:150,padding:"1rem",outline:"1px solid rgba(0,0,0,0.06)",backgroundColor:"rgb(250,250,250)",boxSizing:"border-box",marginBottom:4,display:"flex",flexDirection:"column",justifyContent:"stretch",alignItems:"center",contain:"layout paint",position:"relative",isolation:"isolate"},children:He("div",{style:{zoom:.5,pointerEvents:"none"},children:iu(o.type,o.props)})})})}function Mu({components:e,selectedComponent:t,hoveredComponent:o,onRemove:r,onHover:n}){if(!e||Object.keys(e).length===0)return He("div",{style:{color:"#9ca3af",fontSize:11},children:"No component patterns defined yet."});let i=new Set(Object.keys(e)),s=Gr(i),l=Object.entries(e).sort(([a],[c])=>{var d,u;return((d=s.get(a))!=null?d:1/0)-((u=s.get(c))!=null?u:1/0)});return He(Lo,{children:l.map(([a,c])=>He(ku,{name:a,value:c,selected:t===a,highlighted:o===a,onRemove:r,onHover:n},a))})}function Gl({bridgeUrl:e,modelRefreshKey:t,onMouseEnter:o,onMouseLeave:r,selectedComponent:n,hoveredComponent:i,onComponentHover:s,onSpacingTokenHover:l,onModifySpacingToken:a,onDeleteSpacingToken:c,onComponentAdded:d,onComponentRemoved:u}){let[p,g]=Sn(void 0),[S,v]=Sn(!0),[b,w]=Sn(()=>{try{let D=localStorage.getItem($l);if(D==="tokens"||D==="components"||D==="rules")return D}catch(D){}return"components"});To(()=>{io(e).then(D=>{g(D),v(!1)})},[e,t]),To(()=>{try{localStorage.setItem($l,b)}catch(D){}},[b]),To(()=>{n&&(w("components"),io(e).then(D=>{D&&g(D)}))},[n,e]);let O=Er((D,K)=>{g(ee=>{if(!(ee!=null&&ee.tokens))return ee;let me=JSON.parse(JSON.stringify(ee.tokens)),ve=D.split("."),ae=me;for(let Re=1;Re<ve.length-1;Re++)if(ae=ae[ve[Re]],!ae)return ee;return delete ae[ve[ve.length-1]],h(f({},ee),{tokens:me})}),c==null||c(D,K)},[c]),A=Er(D=>{g(K=>{if(!(K!=null&&K.components))return K;let ve=K.components,{[D]:ee}=ve,me=Hn(ve,[Qo(D)]);return h(f({},K),{components:me})}),u==null||u(D)},[u]),k=p==null?void 0:p.tokens,E=p==null?void 0:p.components,I=p==null?void 0:p.rules,$=k&&Object.keys(k).length>0,q=E&&Object.keys(E).length>0,j=I&&I.length>0,T=!p||!$&&!q&&!j;return Qt("div",{style:fu,onMouseEnter:o,onMouseLeave:r,children:[Qt("div",{style:{display:"flex",alignItems:"center",gap:6,fontWeight:700,fontSize:13,marginBottom:6},children:[He("span",{children:"Model"}),He("code",{style:{fontSize:10,fontWeight:500,backgroundColor:"rgba(0,0,0,0.06)",padding:"1px 4px",color:"#6b7280"},children:"M"})]}),He("div",{style:{display:"flex",gap:12,marginBottom:10,borderBottom:"1px solid rgba(0,0,0,0.08)",paddingBottom:6},children:["components","rules"].map(D=>He("button",{type:"button",style:b===D?gu:Yl,onClick:()=>w(D),children:D.charAt(0).toUpperCase()+D.slice(1)},D))}),He("div",{style:{flex:1,overflowY:"auto",minHeight:0},children:S?He("div",{style:{color:"#9ca3af",fontSize:11},children:"Loading..."}):T?He("div",{style:{color:"#9ca3af",lineHeight:1.5},children:"No design model yet. Pattern-scoped annotations will build one automatically."}):Qt(Lo,{children:[b==="components"&&He(Mu,{components:E,selectedComponent:n,hoveredComponent:i,onRemove:A,onHover:s}),b==="tokens"&&He(wu,{tokens:k,onSpacingTokenHover:l,onModifyToken:a,onDeleteToken:c?O:void 0}),b==="rules"&&He(Eu,{rules:I})]})})]})}import{jsx as Vl}from"react/jsx-runtime";var Pn={iconDefault:"#1f2937",iconActive:"#1f2937",bgActive:"#f3f4f6",bgHover:"#f9fafb",separator:"#e5e7eb"};function Bn({children:e,active:t,siblingActive:o,disabled:r,onClick:n,title:i}){let s=()=>r?.4:o&&!t?.5:1,l={position:"relative",display:"flex",alignItems:"center",justifyContent:"center",width:32,height:32,borderRadius:0,border:"none",cursor:r?"default":"pointer",transition:"background-color 150ms ease, color 150ms ease, transform 100ms ease, opacity 150ms ease",backgroundColor:t?Pn.bgActive:"transparent",color:t?Pn.iconActive:Pn.iconDefault,opacity:s()};return Vl("button",{type:"button",onClick:r?void 0:n,title:i,disabled:r,style:l,onMouseEnter:a=>{r||(a.currentTarget.style.opacity="1",t||(a.currentTarget.style.backgroundColor=Pn.bgHover))},onMouseLeave:a=>{r||(a.currentTarget.style.opacity=String(s()),t||(a.currentTarget.style.backgroundColor="transparent"))},onMouseDown:a=>{r||(a.currentTarget.style.transform="scale(0.95)")},onMouseUp:a=>{r||(a.currentTarget.style.transform="scale(1)")},children:e})}function Oi(){return Vl("div",{style:{width:1,height:20,backgroundColor:"rgba(0, 0, 0, 0.05)",margin:"0 8px"}})}import{Fragment as eo,jsx as re,jsxs as yt}from"react/jsx-runtime";var to=[{type:"rectangle",icon:Bu,label:"Rectangle",shortcut:"R"},{type:"circle",icon:Tu,label:"Oval",shortcut:"O"},{type:"line",icon:Pu,label:"Line",shortcut:"L"},{type:"freehand",icon:Au,label:"Pen",shortcut:"P"}],Hu=new Set(to.map(e=>e.type));function Fu(e,t,o,r,n,i,s,l){let a=(e-n)*(r-i)-(o-n)*(t-i),c=(e-s)*(i-l)-(n-s)*(t-l),d=(e-o)*(l-r)-(s-o)*(t-r),u=a<0||c<0||d<0,p=a>0||c>0||d>0;return!(u&&p)}function Nu(){let e=window.innerWidth-16,t=e-326,o=window.innerHeight-80;return{left:t,right:e,y:o}}var _u=[{type:"text",icon:Du,label:"Text",shortcut:"T"}],Ul={inspector:{name:"Comment",desc:"Pin feedback to specific elements on the page.",usage:["Click any element to attach a comment","Type your note, then hand off to your AI","Your AI may ask clarifying questions","Replies get threaded"],keys:[{key:"C",desc:"Select tool"},{key:"Click",desc:"Pin comment to element"},{key:"Esc",desc:"Deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},hand:{name:"Handle",desc:"Quickly finetune layout and typescale.",usage:["Edges \u2192 padding","Between items \u2192 spacing","Corners \u2192 rounding","Right of text \u2192 font size","Below text \u2192 line height","Click a spacing handle to cycle distribution","Right-click \u2192 inspect element styles"],keys:[{key:"H",desc:"Select tool"},{key:"Shift",desc:"Snap to scale"},{key:"\u2325 + swipe",desc:"Cycle justify / flip direction"},{key:"\u21E7 + swipe",desc:"Cycle align-items"},{key:"Right-click",desc:"Inspect styles"},{key:"Esc",desc:"Deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},rectangle:{name:"Rectangle",desc:"Draw rectangular highlights to mark areas of interest.",usage:["Click and drag to draw","Cycle between shapes with the dot selector"],keys:[{key:"R",desc:"Rectangle"},{key:"O",desc:"Oval"},{key:"L",desc:"Line"},{key:"P",desc:"Pen"},{key:"Esc",desc:"Cancel or deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},circle:{name:"Oval",desc:"Draw oval highlights to mark areas of interest.",usage:["Click and drag to draw","Cycle between shapes with the dot selector"],keys:[{key:"O",desc:"Oval"},{key:"R",desc:"Rectangle"},{key:"L",desc:"Line"},{key:"P",desc:"Pen"},{key:"Esc",desc:"Cancel or deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},line:{name:"Line",desc:"Draw line annotations to point at or connect elements.",usage:["Click and drag to draw","Cycle between shapes with the dot selector"],keys:[{key:"L",desc:"Line"},{key:"R",desc:"Rectangle"},{key:"O",desc:"Oval"},{key:"P",desc:"Pen"},{key:"Esc",desc:"Cancel or deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},freehand:{name:"Pen",desc:"Draw freehand paths to annotate freely.",usage:["Click and drag to draw","Cycle between shapes with the dot selector"],keys:[{key:"P",desc:"Pen"},{key:"R",desc:"Rectangle"},{key:"O",desc:"Oval"},{key:"L",desc:"Line"},{key:"Esc",desc:"Cancel or deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},text:{name:"Text",desc:"Place text labels anywhere on the page.",usage:["Click to place, then start typing","Click away or press Enter to finish","Scroll while hovering a label to resize it"],keys:[{key:"T",desc:"Select tool"},{key:"Esc",desc:"Cancel text or deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},model:{name:"Model",desc:"Promote components into the local design model.",usage:["Hover to highlight component boundaries","Scroll to walk up/down the component tree","Click to add to model.json","Green = already in model"],keys:[{key:"M",desc:"Select tool"},{key:"Scroll",desc:"Walk tree depth"},{key:"Click",desc:"Promote component"},{key:"Esc",desc:"Deselect"}]},counter:{name:"Annotations",desc:"Click to cycle, scroll to change color, long press to reset.",usage:[],keys:[{key:"Click",desc:"Cycle annotations"},{key:"Scroll",desc:"Change color"},{key:"Hold",desc:"Reset to red"}]},clear:{name:"Clear",desc:"Remove all annotations and style changes.",usage:[],keys:[{key:"\u2318 \u232B",desc:"Clear all"},{key:"\u232B",desc:"Delete selected annotation"},{key:"\u2318 Z",desc:"Undo"},{key:"\u2318 \u21E7 Z",desc:"Redo"}]},collapse:{name:"Popmelt",desc:`Comment and zhuzh, then hand off.
2
+ var sc=Object.defineProperty,lc=Object.defineProperties;var ac=Object.getOwnPropertyDescriptors;var cr=Object.getOwnPropertySymbols;var Ns=Object.prototype.hasOwnProperty,Hs=Object.prototype.propertyIsEnumerable;var Ds=(e,t,n)=>t in e?sc(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,f=(e,t)=>{for(var n in t||(t={}))Ns.call(t,n)&&Ds(e,n,t[n]);if(cr)for(var n of cr(t))Hs.call(t,n)&&Ds(e,n,t[n]);return e},y=(e,t)=>lc(e,ac(t));var dr=e=>typeof e=="symbol"?e:e+"",Yn=(e,t)=>{var n={};for(var r in e)Ns.call(e,r)&&t.indexOf(r)<0&&(n[r]=e[r]);if(e!=null&&cr)for(var r of cr(e))t.indexOf(r)<0&&Hs.call(e,r)&&(n[r]=e[r]);return n};import{createContext as $f,useCallback as Vt,useContext as Wf,useEffect as Dt,useMemo as zo,useRef as Xt,useState as Kt}from"react";import{useCallback as Us,useEffect as cc,useSyncExternalStore as dc}from"react";var Rn="http://localhost:1111";function In(e,t={},n=15e3){let r=new AbortController;t.signal&&t.signal.addEventListener("abort",()=>r.abort());let o=setTimeout(()=>r.abort(),n);return fetch(e,y(f({},t),{signal:r.signal})).finally(()=>clearTimeout(o))}async function _s(e=Rn){try{let t=await In(`${e}/capabilities`,{},5e3);return t.ok?await t.json():null}catch(t){return null}}async function bo(e=Rn){try{let t=new AbortController,n=setTimeout(()=>t.abort(),2e3),r=await fetch(`${e}/status`,{signal:t.signal});return clearTimeout(n),r.ok?await r.json():null}catch(t){return null}}async function Fs(e){try{let t=new AbortController,n=setTimeout(()=>t.abort(),500),r=await fetch(`http://localhost:${e}/status`,{signal:t.signal});return clearTimeout(n),r.ok?await r.json():null}catch(t){return null}}async function zs(e){if(e&&e!=="http://localhost:1111")try{let c=new URL(e);return{url:e,port:parseInt(c.port,10)||1111}}catch(c){return null}let o=typeof window!="undefined"?window.location.origin:null,i=await Fs(1111);if(i&&i.devOrigin&&o&&i.devOrigin===o)return{url:"http://localhost:1111",port:1111};let s=Array.from({length:8},(c,d)=>{let u=1112+d;return Fs(u).then(p=>p?{status:p,port:u}:null)}),l=(await Promise.all(s)).filter(c=>c!==null),a=[];i&&a.push({port:1111,devOrigin:i.devOrigin});for(let c of l)a.push({port:c.port,devOrigin:c.status.devOrigin});if(o){let c=a.find(d=>d.devOrigin===o);if(c)return{url:`http://localhost:${c.port}`,port:c.port}}return a.length===1?{url:`http://localhost:${a[0].port}`,port:a[0].port}:i?{url:"http://localhost:1111",port:1111}:a.length>0?{url:`http://localhost:${a[0].port}`,port:a[0].port}:null}async function $s(e,t,n=Rn,r,o,i,s,l){let a=new FormData;if(a.append("screenshot",e,"screenshot.png"),a.append("feedback",t),r&&a.append("color",r),o&&a.append("provider",o),i&&a.append("model",i),l&&a.append("sourceId",l),s)for(let[d,u]of s)for(let p=0;p<u.length;p++)a.append(`image-${d}-${p}`,u[p],`image-${d}-${p}.png`);let c=await In(`${n}/send`,{method:"POST",body:a},3e4);if(!c.ok){let d=await c.text();throw new Error(`Bridge returned ${c.status}: ${d}`)}return c.json()}async function Ws(e=Rn,t){try{let n=await In(`${e}/mcp/install`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(t?{serverUrl:t}:{})},15e3);return n.ok?await n.json():null}catch(n){return null}}async function Ys(e,t=Rn){let n=await In(`${t}/model/component`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({name:e})},1e4);if(!n.ok){let r=await n.text();throw new Error(`Bridge returned ${n.status}: ${r}`)}return n.json()}async function js(e,t=Rn){let n=await In(`${t}/model/component`,{method:"DELETE",headers:{"Content-Type":"application/json"},body:JSON.stringify({name:e})},1e4);if(!n.ok){let r=await n.text();throw new Error(`Bridge returned ${n.status}: ${r}`)}return n.json()}async function Ur(e,t,n=Rn){let r=await In(`${n}/model/token`,{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({path:e,value:t})},1e4);if(!r.ok){let o=await r.text();throw new Error(`Bridge returned ${r.status}: ${o}`)}return r.json()}async function Gs(e,t=Rn){let n=await In(`${t}/model/token`,{method:"DELETE",headers:{"Content-Type":"application/json"},body:JSON.stringify({path:e})},1e4);if(!n.ok){let r=await n.text();throw new Error(`Bridge returned ${n.status}: ${r}`)}return n.json()}async function xo(e=Rn){var t;try{let n=await In(`${e}/model`,{},5e3);return n.ok&&(t=(await n.json()).model)!=null?t:null}catch(n){return null}}async function Vs(e,t,n=Rn,r,o,i,s,l){let a;if(s&&s.length>0){let c=new FormData,d=new Blob([new Uint8Array([137,80,78,71,13,10,26,10,0,0,0,13,73,72,68,82,0,0,0,1,0,0,0,1,8,6,0,0,0,31,21,196,137,0,0,0,10,73,68,65,84,120,156,98,0,0,0,2,0,1,229,39,222,252,0,0,0,0,73,69,78,68,174,66,96,130])],{type:"image/png"});c.append("screenshot",d,"screenshot.png"),c.append("feedback",JSON.stringify({threadId:e,reply:t,color:r,provider:o,model:i,sourceId:l}));for(let u=0;u<s.length;u++)c.append(`image-reply-${u}`,s[u],`reply-image-${u}.png`);a=await In(`${n}/reply`,{method:"POST",body:c},3e4)}else a=await In(`${n}/reply`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({threadId:e,reply:t,color:r,provider:o,model:i,sourceId:l})},3e4);if(!a.ok){let c=await a.text();throw new Error(`Bridge returned ${a.status}: ${c}`)}return a.json()}var pr={};var eo=typeof pr!="undefined"?pr.hot:void 0,Xs,Ks,Kr=(Ks=(Xs=eo==null?void 0:eo.data)==null?void 0:Xs.sourceId)!=null?Ks:typeof crypto!="undefined"&&typeof crypto.randomUUID=="function"?crypto.randomUUID():Math.random().toString(36).slice(2);eo!=null&&eo.data&&(eo.data.sourceId=Kr);function qr(){return Kr}var to=typeof pr!="undefined"?pr.hot:void 0,Wt=to==null?void 0:to.data,uc={isConnected:!1,status:"disconnected",jobResponses:{},jobThinking:{},activeJobIds:[],currentResponse:"",currentThinking:"",events:[],activeJobId:null,lastCompletedJobId:null,lastResponseText:null,lastThreadId:null,lastErrorByJob:{},pendingQuestions:[],incrementalResolutions:[],capabilitiesVersion:0},qs,Yo=(qs=Wt==null?void 0:Wt.store)!=null?qs:f({},uc),Zs,ur=(Zs=Wt==null?void 0:Wt.listeners)!=null?Zs:new Set,Qs,Zn=(Qs=Wt==null?void 0:Wt.activeEs)!=null?Qs:null,el,Jr=(el=Wt==null?void 0:Wt.activeBridgeUrl)!=null?el:null,qn=null,tl,Xr=(tl=Wt==null?void 0:Wt.connectionGeneration)!=null?tl:0;to!=null&&to.data&&Object.defineProperties(to.data,{store:{get:()=>Yo,configurable:!0},listeners:{get:()=>ur,configurable:!0},activeEs:{get:()=>Zn,configurable:!0},activeBridgeUrl:{get:()=>Jr,configurable:!0},connectionGeneration:{get:()=>Xr,configurable:!0},discoveredBridgeUrl:{get:()=>Qn,configurable:!0}});var nl,Qn=(nl=Wt==null?void 0:Wt.discoveredBridgeUrl)!=null?nl:null,So=null;async function pc(e){return e&&e!=="http://localhost:1111"?(Qn=e,e):Qn||So||(So=zs(e).then(n=>{var r;return Qn=(r=n==null?void 0:n.url)!=null?r:null,So=null,Qn}).catch(()=>(So=null,null)),So)}function ol(){return Qn}function Js(){return Yo}function fc(e){return ur.add(e),()=>{ur.delete(e)}}function rn(e){Yo=e(Yo);for(let t of ur)t()}function rl(e){if(Zn&&Zn.readyState!==EventSource.CLOSED&&Jr===e)return;Zn&&(Zn.close(),Zn=null),qn&&(clearTimeout(qn),qn=null),Jr=e;let t=++Xr,n=new EventSource(`${e}/events?sourceId=${Kr}`);Zn=n;let r=()=>t!==Xr;n.addEventListener("connected",()=>{r()||bo(e).then(o=>{var d,u;if(r())return;let i=(d=o==null?void 0:o.activeJobs)!=null?d:o!=null&&o.activeJob?[o.activeJob]:[],s=new Set(i.map(p=>p.id)),l=(u=o==null?void 0:o.recentJobs)!=null?u:[],a=new Map(l.map(p=>[p.id,p])),c=i.length>0;rn(p=>{let g=f({},p.lastErrorByJob),k=p.activeJobIds.filter(b=>!s.has(b));for(let b of k){let E=a.get(b);(E==null?void 0:E.status)==="error"&&E.error&&(g[b]=E.error)}let w=p.activeJobIds.filter(b=>s.has(b));for(let b of s)w.includes(b)||w.push(b);return y(f({},p),{isConnected:!0,status:c?"streaming":k.length>0||p.status==="disconnected"?"idle":p.status,activeJobId:c?i[i.length-1].id:w.length>0?w[w.length-1]:null,activeJobIds:w,lastErrorByJob:g,lastCompletedJobId:k.length>0?k[k.length-1]:p.lastCompletedJobId})})})}),n.addEventListener("job_started",o=>{if(r())return;let i=JSON.parse(o.data),s=i.jobId;rn(l=>y(f({},l),{status:"streaming",activeJobId:s,activeJobIds:[...l.activeJobIds,s],jobResponses:y(f({},l.jobResponses),{[s]:""}),jobThinking:y(f({},l.jobThinking),{[s]:""}),currentResponse:"",currentThinking:"",lastResponseText:null,lastThreadId:null,events:[...l.events,{type:"job_started",data:i,timestamp:Date.now()}]}))}),n.addEventListener("delta",o=>{if(r())return;let i=JSON.parse(o.data),s=i.jobId,l=i.text||"";rn(a=>y(f({},a),{jobResponses:s?y(f({},a.jobResponses),{[s]:(a.jobResponses[s]||"")+l}):a.jobResponses,currentResponse:!s||s===a.activeJobId?a.currentResponse+l:a.currentResponse,events:[...a.events,{type:"delta",data:i,timestamp:Date.now()}]}))}),n.addEventListener("thinking",o=>{if(r())return;let i=JSON.parse(o.data),s=i.jobId,l=i.text||"";rn(a=>y(f({},a),{jobThinking:s?y(f({},a.jobThinking),{[s]:(a.jobThinking[s]||"")+l}):a.jobThinking,currentThinking:!s||s===a.activeJobId?a.currentThinking+l:a.currentThinking,events:[...a.events,{type:"thinking",data:i,timestamp:Date.now()}]}))}),n.addEventListener("tool_use",o=>{if(r())return;let i=JSON.parse(o.data);rn(s=>y(f({},s),{events:[...s.events,{type:"tool_use",data:i,timestamp:Date.now()}]}))}),n.addEventListener("done",o=>{if(r())return;let i=JSON.parse(o.data),s=i.jobId;rn(l=>{var g;let a=s?l.activeJobIds.filter(k=>k!==s):l.activeJobIds,c=f({},l.jobResponses),d=f({},l.jobThinking),u=s?c[s]:void 0;s&&(delete c[s],delete d[s]);let p=s===l.activeJobId?a.length>0?a[a.length-1]:null:l.activeJobId;return y(f(y(f({},l),{activeJobIds:a,activeJobId:p,jobResponses:c,jobThinking:d,lastCompletedJobId:s!=null?s:l.activeJobId,lastResponseText:u||l.currentResponse||i.responseText||null,lastThreadId:(g=i.threadId)!=null?g:null}),s===l.activeJobId?{currentResponse:p&&c[p]||"",currentThinking:p&&d[p]||""}:{}),{events:[...l.events,{type:"done",data:i,timestamp:Date.now()}]})})}),n.addEventListener("question",o=>{if(r())return;let i=JSON.parse(o.data);rn(s=>y(f({},s),{pendingQuestions:[...s.pendingQuestions,{jobId:i.jobId,threadId:i.threadId,question:i.question,annotationIds:i.annotationIds,timestamp:Date.now()}],events:[...s.events,{type:"question",data:i,timestamp:Date.now()}]}))}),n.addEventListener("capabilities_changed",()=>{r()||rn(o=>y(f({},o),{capabilitiesVersion:o.capabilitiesVersion+1}))}),n.addEventListener("queue_drained",()=>{r()||rn(o=>y(f({},o),{status:o.status==="error"?"error":"idle",activeJobId:null,activeJobIds:[],currentResponse:"",currentThinking:"",jobResponses:{},jobThinking:{},lastErrorByJob:{},incrementalResolutions:[]}))}),n.addEventListener("error",o=>{var i,s;if(!r()){if(n.readyState===EventSource.CLOSED)rn(l=>y(f({},l),{isConnected:!1,status:"disconnected"})),qn&&(clearTimeout(qn),qn=null),qn=setTimeout(()=>{bo(e).then(l=>{l&&rl(e)})},5e3);else if(o instanceof MessageEvent){let l=JSON.parse(o.data),a=(i=l.jobId)!=null?i:null,c=(s=l.message)!=null?s:"";rn(d=>{let u=a?d.activeJobIds.filter(g=>g!==a):d.activeJobIds,p=u.length>0?d.status:"error";return y(f({},d),{status:p,activeJobIds:u,lastCompletedJobId:a!=null?a:d.activeJobId,lastErrorByJob:a&&c?y(f({},d.lastErrorByJob),{[a]:c}):d.lastErrorByJob,events:[...d.events,{type:"error",data:l,timestamp:Date.now()}]})})}}}),n.onerror=()=>{r()||n.readyState===EventSource.CLOSED&&rn(o=>y(f({},o),{isConnected:!1,status:"disconnected"}))}}function il(e="http://localhost:1111"){let t=dc(fc,Js,Js);cc(()=>{pc(e).then(o=>{o&&bo(o).then(i=>{i&&rl(o)})})},[e]);let n=Us(()=>{rn(()=>y(f({},Yo),{events:[],currentResponse:"",currentThinking:"",jobResponses:{},jobThinking:{},lastResponseText:null,lastThreadId:null,lastErrorByJob:{},incrementalResolutions:[]}))},[]),r=Us(o=>{rn(i=>y(f({},i),{pendingQuestions:i.pendingQuestions.filter(s=>s.threadId!==o)}))},[]);return y(f({},t),{clearEvents:n,dismissQuestion:r})}import{useEffect as gc,useReducer as mc}from"react";var hc={isAnnotating:!1,activeTool:"inspector",activeColor:"#ff0000",strokeWidth:3,annotations:[],undoStack:[],redoStack:[],currentPath:[],selectedAnnotationIds:[],lastSelectedId:null,inspectedElement:null,styleModifications:[],spacingTokenChanges:[],spacingTokenMods:[]};function fr(){return Math.random().toString(36).substring(2,9)}function sl(e){return e.status?e:e.captured?y(f({},e),{status:"in_flight"}):y(f({},e),{status:"pending"})}function tn(e){return y(f({},e),{undoStack:[...e.undoStack,{annotations:e.annotations,styleModifications:e.styleModifications,spacingTokenMods:e.spacingTokenMods}],redoStack:[]})}function yc(e,t){return y(f({},e),{isAnnotating:t})}function bc(e,t){return y(f({},e),{activeTool:t,inspectedElement:null})}function xc(e,t){return y(f({},e),{activeColor:t})}function Sc(e,t){return y(f({},e),{strokeWidth:t})}function vc(e,t){return y(f({},e),{currentPath:[t]})}function wc(e,t){return y(f({},e),{currentPath:[...e.currentPath,t]})}function Ec(e){return y(f({},e),{currentPath:[]})}function Cc(e,t){if(e.currentPath.length<2&&e.activeTool!=="text")return y(f({},e),{currentPath:[]});let n={id:fr(),type:e.activeTool,points:e.currentPath,color:e.activeColor,strokeWidth:e.strokeWidth,timestamp:Date.now(),status:"pending",groupId:t==null?void 0:t.groupId,elements:t==null?void 0:t.elements},r=tn(e);return y(f({},r),{annotations:[...e.annotations,n],currentPath:[]})}function kc(e,t){var o;let n=f({id:(o=t.id)!=null?o:fr(),type:"text",points:[t.point],text:t.text,fontSize:t.fontSize||12,color:e.activeColor,strokeWidth:e.strokeWidth,timestamp:Date.now(),status:"pending",groupId:t.groupId,linkedSelector:t.linkedSelector,linkedAnchor:t.linkedAnchor,elements:t.elements},t.imageCount?{imageCount:t.imageCount}:{}),r=t.groupId?e:tn(e);return y(f({},r),{annotations:[...e.annotations,n]})}function Mc(e,t){let n=tn(e);return y(f({},n),{annotations:e.annotations.map(r=>r.id===t.id?f(y(f({},r),{text:t.text}),t.imageCount!=null?{imageCount:t.imageCount}:{}):r)})}function Tc(e,t){return y(f({},e),{annotations:e.annotations.map(n=>n.id===t.id?y(f({},n),{fontSize:Math.max(12,Math.min(72,t.fontSize))}):n)})}function Ic(e,t){let n=tn(e),r=e.annotations.find(i=>i.id===t.id),o=r==null?void 0:r.groupId;return y(f({},n),{annotations:e.annotations.filter(i=>i.id!==t.id&&!(o&&i.groupId===o))})}function Rc(e,t){let n=t.saveUndo?tn(e):e,r=e.annotations.find(i=>i.id===t.id),o=r==null?void 0:r.groupId;return y(f({},n),{annotations:e.annotations.map(i=>{if(!(i.id===t.id||o&&i.groupId===o))return i;let l=t.delta.x,a=t.delta.y;return y(f({},i),{points:i.points.map(c=>({x:c.x+l,y:c.y+a}))})})})}function Lc(e,t){let n=t.saveUndo?tn(e):e,r=e.annotations.find(s=>s.id===t.id);if(!r||r.type==="text"||r.points.length<2)return e;let o=0,i=0;if(r.type==="rectangle"&&r.groupId){let s=t.points,l=Math.min(s[0].x,s[1].x),a=Math.max(s[0].y,s[1].y),c=r.points[0],d=r.points[r.points.length-1],u=Math.min(c.x,d.x),p=Math.max(c.y,d.y);o=l-u,i=a-p}return y(f({},n),{annotations:e.annotations.map(s=>s.id===t.id?y(f({},s),{points:t.points}):r.groupId&&s.groupId===r.groupId&&s.type==="text"?y(f({},s),{points:s.points.map(l=>({x:l.x+o,y:l.y+i}))}):s)})}function Ac(e,t){let n=tn(e);return y(f({},n),{annotations:[...e.annotations,...t.annotations.map(sl)]})}function Pc(e,t){let n=new Set,r=[];for(let o of t.annotations)n.has(o.id)||(n.add(o.id),r.push(sl(o)));return y(f({},e),{annotations:r})}function Bc(e){if(e.undoStack.length===0)return e;let t=e.undoStack[e.undoStack.length-1];return y(f({},e),{annotations:(t==null?void 0:t.annotations)||[],styleModifications:(t==null?void 0:t.styleModifications)||[],spacingTokenMods:(t==null?void 0:t.spacingTokenMods)||[],undoStack:e.undoStack.slice(0,-1),redoStack:[...e.redoStack,{annotations:e.annotations,styleModifications:e.styleModifications,spacingTokenMods:e.spacingTokenMods}]})}function Oc(e){if(e.redoStack.length===0)return e;let t=e.redoStack[e.redoStack.length-1];return y(f({},e),{annotations:(t==null?void 0:t.annotations)||[],styleModifications:(t==null?void 0:t.styleModifications)||[],spacingTokenMods:(t==null?void 0:t.spacingTokenMods)||[],redoStack:e.redoStack.slice(0,-1),undoStack:[...e.undoStack,{annotations:e.annotations,styleModifications:e.styleModifications,spacingTokenMods:e.spacingTokenMods}]})}function Dc(e,t){let{id:n,addToSelection:r}=t;if(n===null)return y(f({},e),{selectedAnnotationIds:[],lastSelectedId:null});if(r)if(e.selectedAnnotationIds.includes(n)){let i=e.selectedAnnotationIds.filter(s=>s!==n);return y(f({},e),{selectedAnnotationIds:i,lastSelectedId:i.length>0?i[i.length-1]:null})}else return y(f({},e),{selectedAnnotationIds:[...e.selectedAnnotationIds,n],lastSelectedId:n});return y(f({},e),{selectedAnnotationIds:[n],lastSelectedId:n})}function Nc(e,t){let n=new Set;for(let r of e.selectedAnnotationIds){let o=e.annotations.find(i=>i.id===r);o!=null&&o.groupId&&n.add(o.groupId)}return y(f({},e),{annotations:e.annotations.map(r=>{let o=e.selectedAnnotationIds.includes(r.id),i=r.groupId&&n.has(r.groupId);return!o&&!i?r:y(f({},r),{color:t.color})})})}function Hc(e){return y(f({},e),{annotations:e.annotations.map(t=>y(f({},t),{captured:!0,status:t.status==="pending"||!t.status?"in_flight":t.status})),styleModifications:e.styleModifications.map(t=>y(f({},t),{captured:!0})),spacingTokenChanges:e.spacingTokenChanges.map(t=>y(f({},t),{captured:!0}))})}function Fc(e){return y(f({},e),{annotations:[],undoStack:[],redoStack:[],currentPath:[],selectedAnnotationIds:[],lastSelectedId:null,spacingTokenChanges:[],spacingTokenMods:[]})}function _c(e,t){return y(f({},e),{inspectedElement:t})}function zc(e,t){let{selector:n,element:r,property:o,original:i,modified:s}=t,l=e.styleModifications.findIndex(a=>a.selector===n);if(i===s&&l<0)return e;if(l>=0){let a=e.styleModifications[l];if(a.captured){let g=tn(e),k=g.styleModifications.map((w,b)=>b===l?y(f({},w),{changes:[{property:o,original:i,modified:s}],captured:!1}):w);return y(f({},g),{styleModifications:k})}let c=a.changes.findIndex(g=>g.property===o),d,u=e;if(c>=0){let g=a.changes[c];s===g.original?d=a.changes.filter((k,w)=>w!==c):d=a.changes.map((k,w)=>w===c?y(f({},k),{modified:s}):k)}else{if(i===s)return e;u=tn(e),d=[...a.changes,{property:o,original:i,modified:s}]}if(d.length===0)return y(f({},u),{styleModifications:u.styleModifications.filter((g,k)=>k!==l)});let p=u.styleModifications.map((g,k)=>k===l?y(f({},g),{changes:d}):g);return y(f({},u),{styleModifications:p})}else{let a=tn(e),c={selector:n,element:r,changes:[{property:o,original:i,modified:s}]};return y(f({},a),{styleModifications:[...a.styleModifications,c]})}}function $c(e,t){let{selector:n,durableSelector:r,element:o,changes:i}=t,s=i.filter(c=>c.original!==c.modified);if(s.length===0)return e;let l=tn(e),a=l.styleModifications.findIndex(c=>c.selector===n);if(a>=0){let c=l.styleModifications[a],d=c.captured?[]:[...c.changes];for(let u of s){let p=d.findIndex(g=>g.property===u.property);p>=0?u.modified===d[p].original?d=d.filter((g,k)=>k!==p):d=d.map((g,k)=>k===p?y(f({},g),{modified:u.modified}):g):d.push(u)}return d.length===0?y(f({},l),{styleModifications:l.styleModifications.filter((u,p)=>p!==a)}):y(f({},l),{styleModifications:l.styleModifications.map((u,p)=>p===a?y(f({},u),{changes:d,captured:!1}):u)})}else return y(f({},l),{styleModifications:[...l.styleModifications,{selector:n,durableSelector:r,element:o,changes:s}]})}function Wc(e,t){let{selector:n,property:r}=t,o=tn(e),i=o.styleModifications.map(s=>s.selector!==n?s:y(f({},s),{changes:s.changes.filter(l=>l.property!==r)})).filter(s=>s.changes.length>0);return y(f({},o),{styleModifications:i})}function Yc(e){if(e.styleModifications.length===0)return y(f({},e),{inspectedElement:null});let t=tn(e);return y(f({},t),{styleModifications:[],inspectedElement:null})}function jc(e,t){return y(f({},e),{styleModifications:t})}function Gc(e,t){let{updates:n}=t,r=new Map(n.map(o=>[o.id,o]));return y(f({},e),{annotations:e.annotations.map(o=>{let i=r.get(o.id);return i?f(y(f({},o),{points:[i.point,...o.points.slice(1)]}),i.linkedAnchor?{linkedAnchor:i.linkedAnchor}:{}):o})})}function Vc(e,t){let n=new Set(t.ids);return y(f({},e),{annotations:e.annotations.map(r=>n.has(r.id)?y(f({},r),{status:t.status}):r)})}function Uc(e,t){let n=new Set(t.ids),r=new Set;for(let o of e.annotations)n.has(o.id)&&o.groupId&&r.add(o.groupId);return y(f({},e),{annotations:e.annotations.map(o=>n.has(o.id)||o.groupId&&r.has(o.groupId)?y(f({},o),{threadId:t.threadId}):o)})}function Jc(e,t){let n=new Set(t.ids),r=new Set;for(let o of e.annotations)n.has(o.id)&&o.groupId&&r.add(o.groupId);return y(f({},e),{annotations:e.annotations.map(o=>n.has(o.id)||o.groupId&&r.has(o.groupId)?y(f({},o),{status:"waiting_input",question:t.question,threadId:t.threadId}):o)})}function Xc(e,t){let n=new Map(t.resolutions.map(o=>[o.annotationId,o])),r=new Map;for(let o of e.annotations){let i=n.get(o.id);i&&o.groupId&&r.set(o.groupId,i)}return y(f({},e),{annotations:e.annotations.map(o=>{var s,l,a;let i=n.get(o.id)||(o.groupId?r.get(o.groupId):void 0);return i?y(f({},o),{status:i.status,resolutionSummary:i.summary,scope:(l=(s=i.finalScope)!=null?s:i.inferredScope)!=null?l:null,replyCount:((a=o.replyCount)!=null?a:0)+1,question:void 0,threadId:o.threadId||t.threadId}):o})})}function Kc(e,t){let{linkedSelectors:n,styleSelectors:r}=t,o=new Set(n),i=new Set(r),s=new Set,l=new Set;for(let p of e.annotations)p.linkedSelector&&o.has(p.linkedSelector)&&(s.add(p.id),p.groupId&&l.add(p.groupId));for(let p of e.annotations)p.groupId&&l.has(p.groupId)&&s.add(p.id);let a=e.annotations.filter(p=>!s.has(p.id)),c=e.styleModifications.filter(p=>!i.has(p.selector));if(a.length===e.annotations.length&&c.length===e.styleModifications.length)return e;let d=e.selectedAnnotationIds.filter(p=>!s.has(p)),u=e.inspectedElement&&i.has(e.inspectedElement.info.selector)?null:e.inspectedElement;return y(f({},e),{annotations:a,styleModifications:c,selectedAnnotationIds:d,lastSelectedId:d.length>0?d[d.length-1]:null,inspectedElement:u})}function qc(e,t){let n=e.spacingTokenChanges.findIndex(r=>r.tokenPath===t.tokenPath);return n>=0?y(f({},e),{spacingTokenChanges:e.spacingTokenChanges.map((r,o)=>o===n?t:r)}):y(f({},e),{spacingTokenChanges:[...e.spacingTokenChanges,t]})}function Zc(e,t){return y(f({},e),{spacingTokenChanges:t})}function Qc(e,t){let n=tn(e),r=e.spacingTokenMods.findIndex(i=>i.tokenPath===t.tokenPath),o;if(r>=0){let i=e.spacingTokenMods[r],s=y(f({},t),{originalValue:i.originalValue,originalPx:i.originalPx});o=e.spacingTokenMods.map((l,a)=>a===r?s:l)}else o=[...e.spacingTokenMods,t];return y(f({},n),{spacingTokenMods:o})}function ed(e,t){let n=tn(e),r=e.spacingTokenMods.findIndex(a=>a.tokenPath===t.tokenPath),o=r>=0?e.spacingTokenMods[r].originalValue:t.originalValue,i=r>=0?e.spacingTokenMods[r].originalPx:parseFloat(t.originalValue)||0,s={tokenPath:t.tokenPath,originalValue:o,currentValue:"__deleted__",targets:r>=0?e.spacingTokenMods[r].targets:[],originalPx:i,currentPx:0},l;return r>=0?l=e.spacingTokenMods.map((a,c)=>c===r?s:a):l=[...e.spacingTokenMods,s],y(f({},n),{spacingTokenMods:l})}var td={SET_ANNOTATING:yc,SET_TOOL:bc,SET_COLOR:xc,SET_STROKE_WIDTH:Sc,START_PATH:vc,CONTINUE_PATH:wc,CANCEL_PATH:Ec,FINISH_PATH:Cc,ADD_TEXT:kc,UPDATE_TEXT:Mc,UPDATE_TEXT_SIZE:Tc,DELETE_ANNOTATION:Ic,MOVE_ANNOTATION:Rc,RESIZE_ANNOTATION:Lc,PASTE_ANNOTATIONS:Ac,RESTORE_ANNOTATIONS:Pc,UNDO:Bc,REDO:Oc,SELECT_ANNOTATION:Dc,UPDATE_ANNOTATION_COLOR:Nc,MARK_CAPTURED:Hc,CLEAR:Fc,SELECT_ELEMENT:_c,MODIFY_STYLE:zc,MODIFY_STYLES_BATCH:$c,CLEAR_STYLE:Wc,CLEAR_ALL_STYLES:Yc,RESTORE_STYLE_MODIFICATIONS:jc,UPDATE_LINKED_POSITIONS:Gc,CLEANUP_ORPHANED:Kc,SET_ANNOTATION_STATUS:Vc,SET_ANNOTATION_THREAD:Uc,SET_ANNOTATION_QUESTION:Jc,APPLY_RESOLUTIONS:Xc,ADD_SPACING_TOKEN_CHANGE:qc,RESTORE_SPACING_TOKEN_CHANGES:Zc,MODIFY_SPACING_TOKEN:Qc,DELETE_SPACING_TOKEN:ed};function nd(e,t){let n=td[t.type];return n?n(e,t.payload):e}function ll(){let[e,t]=mc(nd,hc);return gc(()=>{let n=r=>{(r.metaKey||r.ctrlKey)&&r.key==="z"&&(r.preventDefault(),r.shiftKey?t({type:"REDO"}):t({type:"UNDO"}))};return window.addEventListener("keydown",n),()=>window.removeEventListener("keydown",n)},[]),[e,t]}import{domToCanvas as od}from"modern-screenshot";function Zr(e){let t=document.createElement("canvas").getContext("2d");return t?(t.fillStyle=e,t.fillStyle):"#888888"}function Qr(e,t=[],n,r){let o=new Map,i=[];for(let l of e)if(l.groupId){let a=o.get(l.groupId)||[];a.push(l),o.set(l.groupId,a)}else i.push(l);let s=[];for(let[l,a]of o){let c=a.find(u=>u.type!=="text"),d=a.find(u=>u.type==="text");if(c){let u=c.linkedSelector||(d==null?void 0:d.linkedSelector),p=(d==null?void 0:d.imageCount)||c.imageCount;s.push(f(y(f({id:c.id,type:c.type,instruction:d==null?void 0:d.text},u?{linkedSelector:u}:{}),{elements:c.elements||[]}),p?{imageCount:p}:{}))}}for(let l of i)s.push(f(y(f({id:l.id,type:l.type,instruction:l.type==="text"?l.text:void 0},l.linkedSelector?{linkedSelector:l.linkedSelector}:{}),{elements:l.elements||[]}),l.imageCount?{imageCount:l.imageCount}:{}));return f(f({timestamp:new Date().toISOString(),url:window.location.href,viewport:{width:window.innerWidth,height:window.innerHeight},scrollPosition:{x:window.scrollX,y:window.scrollY},annotations:s,styleModifications:t},n?{inspectedElement:n}:{}),r&&r.length>0?{spacingTokenChanges:r}:{})}function rd(e){if(!e.points||e.points.length===0)return null;let t=e.points.map(r=>r.x),n=e.points.map(r=>r.y);return{minX:Math.min(...t),minY:Math.min(...n),maxX:Math.max(...t),maxY:Math.max(...n)}}function id(e,t){if(e.length===0)return[];let n=e.map(d=>({annotation:d,bounds:rd(d)})).filter(d=>d.bounds!==null);if(n.length===0)return[];n.sort((d,u)=>d.bounds.minY-u.bounds.minY);let r=Math.min(...n.map(d=>d.bounds.minY)),o=Math.max(...n.map(d=>d.bounds.maxY));if(o-r<=t){let d=(r+o)/2,u=Math.max(0,d-t/2);return[{top:u,bottom:u+t,annotations:e}]}let i=[],s=50,l=Math.max(0,r-s),a=[],c=l;for(let{annotation:d,bounds:u}of n){let p=u.maxY+s;if(p-l<=t)a.push(d),c=Math.max(c,p);else{if(a.length>0){let g=(l+c)/2,k=Math.max(0,g-t/2);i.push({top:k,bottom:k+t,annotations:a})}l=Math.max(0,u.minY-s),a=[d],c=u.maxY+s}}if(a.length>0){let d=(l+c)/2,u=Math.max(0,d-t/2);i.push({top:u,bottom:u+t,annotations:a})}return i}function sd(e,t,n,r){e.save(),e.scale(r,r);for(let o of t){let i=o.points.map(s=>({x:s.x,y:s.y-n}));switch(e.strokeStyle=o.color,e.fillStyle=o.color,e.lineWidth=o.strokeWidth,e.lineCap="round",e.lineJoin="round",o.type){case"freehand":if(i.length<2)break;e.beginPath(),e.moveTo(i[0].x,i[0].y);for(let s=1;s<i.length;s++)e.lineTo(i[s].x,i[s].y);e.stroke();break;case"line":if(i.length<2)break;e.beginPath(),e.moveTo(i[0].x,i[0].y),e.lineTo(i[i.length-1].x,i[i.length-1].y),e.stroke();break;case"rectangle":{if(i.length<2)break;let s=i[0],l=i[i.length-1],a=Math.min(s.x,l.x),c=Math.min(s.y,l.y),d=Math.abs(l.x-s.x),u=Math.abs(l.y-s.y);e.strokeRect(a,c,d,u);break}case"circle":{if(i.length<2)break;let s=i[0],l=i[i.length-1],a=(s.x+l.x)/2,c=(s.y+l.y)/2,d=Math.abs(l.x-s.x)/2,u=Math.abs(l.y-s.y)/2;e.beginPath(),e.ellipse(a,c,d,u,0,0,Math.PI*2),e.stroke();break}case"text":{if(!o.text||i.length<1)break;let s=i[0],l=o.fontSize||16;e.font=`${l}px -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif`,e.fillStyle=o.color;let c=(o.imageCount&&o.imageCount>0?`[${o.imageCount} image${o.imageCount>1?"s":""}] ${o.text}`:o.text).split(`
3
+ `),d=l*1.2,u=4,p=0;for(let g of c)p=Math.max(p,e.measureText(g).width);e.fillRect(s.x-u,s.y-u,p+u*2,c.length*d+u*2),e.fillStyle="#ffffff",c.forEach((g,k)=>{e.fillText(g,s.x,s.y+l+k*d)});break}}}e.restore()}async function ei(e,t,n=[]){try{let r=window.devicePixelRatio||1,o=window.innerWidth,i=window.innerHeight,s=n.filter(c=>{var d;return((d=c.status)!=null?d:"pending")==="pending"});console.log("[Screenshot] Starting capture with",s.length,"active annotations (filtered",n.length-s.length,"captured)");let l=id(s,i);if(l.length===0){let c=await al(e,[],window.scrollY,o,i,r);return c?[c]:[]}let a=[];for(let c=0;c<l.length;c++){let d=l[c],u=await al(e,d.annotations,d.top,o,i,r);u?a.push(u):console.warn(`[Screenshot] Region ${c+1} failed to capture`)}return console.log("[Screenshot] Capture complete"),a}catch(r){return console.error("[Screenshot] Capture failed:",r),[]}}async function al(e,t,n,r,o,i){try{let s=await od(e,{filter:c=>!(c instanceof HTMLElement&&(c.id==="devtools-canvas"||c.id==="devtools-toolbar"||c.id==="devtools-scrim"||c.dataset.devtools!==void 0)),scale:i,backgroundColor:"#ffffff",width:r,height:o,style:{transform:`translate(${-window.scrollX}px, ${-n}px)`}}),l=document.createElement("canvas");l.width=r*i,l.height=o*i;let a=l.getContext("2d");return a?(a.drawImage(s,0,0,r*i,o*i,0,0,r*i,o*i),sd(a,t,n,i),new Promise(c=>{l.toBlob(d=>c(d),"image/png")})):null}catch(s){return console.error("Region capture failed:",s),null}}async function ti(e){if(e.length===0)return null;if(e.length===1)return e[0];let t=await Promise.all(e.map(l=>new Promise((a,c)=>{let d=new Image;d.onload=()=>a(d),d.onerror=c,d.src=URL.createObjectURL(l)}))),n=t[0].width,r=t.reduce((l,a)=>l+a.height,0),o=document.createElement("canvas");o.width=n,o.height=r;let i=o.getContext("2d");if(!i)return null;let s=0;for(let l of t)i.drawImage(l,0,s),s+=l.height,URL.revokeObjectURL(l.src);return new Promise(l=>{o.toBlob(a=>l(a),"image/png")})}async function cl(e,t,n){try{let r=Array.isArray(e)?e:[e];if(r.length===0)return!1;let o=await ti(r);if(!o)return!1;let i={"image/png":o},s=t&&t.length>0,l=n&&n.length>0;if(s||l){let a=t?t.filter(c=>{var d;return((d=c.status)!=null?d:"pending")==="pending"}):[];if(a.length>0||l){let c=Qr(a,n||[]),d=new Blob([JSON.stringify(c,null,2)],{type:"text/plain"});i["text/plain"]=d}}return await navigator.clipboard.write([new ClipboardItem(i)]),!0}catch(r){return console.warn("Clipboard write failed:",r),!1}}import{useCallback as Pt,useEffect as Jt,useMemo as Gi,useRef as Tt,useState as ct}from"react";import{useCallback as wo,useRef as ad}from"react";function ni(e,t,n,r){if(t.length<2)return;let o=t[0],i=t[t.length-1];if(!o||!i)return;let s=(o.x+i.x)/2,l=(o.y+i.y)/2,a=Math.abs(i.x-o.x)/2,c=Math.abs(i.y-o.y)/2;e.beginPath(),e.strokeStyle=n,e.lineWidth=r,e.ellipse(s,l,a,c,0,0,Math.PI*2),e.stroke()}function oi(e,t,n,r){if(t.length<2)return;let o=t[0],i=t[t.length-1];if(!(!o||!i)){e.beginPath(),e.strokeStyle=n,e.lineWidth=r,e.lineCap="round",e.lineJoin="round",e.moveTo(o.x,o.y);for(let s=1;s<t.length-1;s++){let l=t[s],a=t[s+1];if(!l||!a)continue;let c=(l.x+a.x)/2,d=(l.y+a.y)/2;e.quadraticCurveTo(l.x,l.y,c,d)}e.lineTo(i.x,i.y),e.stroke()}}function ri(e,t,n,r){if(t.length<2)return;let o=t[0],i=t[t.length-1];!o||!i||(e.beginPath(),e.strokeStyle=n,e.lineWidth=r,e.lineCap="round",e.moveTo(o.x,o.y),e.lineTo(i.x,i.y),e.stroke())}function ii(e,t,n,r){if(t.length<2)return;let o=t[0],i=t[t.length-1];if(!o||!i)return;let s=Math.min(o.x,i.x),l=Math.min(o.y,i.y),a=Math.abs(i.x-o.x),c=Math.abs(i.y-o.y);e.beginPath(),e.strokeStyle=n,e.lineWidth=r,e.lineCap="round",e.lineJoin="round",e.strokeRect(s,l,a,c)}var zt='"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace';function ld(e,t,n){if(!t||e.measureText(t).width<=n)return[t];let r=t.split(/\s+/),o=[],i="";for(let s of r){let l=i?i+" "+s:s;i&&e.measureText(l).width>n?(o.push(i),i=s):i=l}return i&&o.push(i),o.length>0?o:[t]}function vo(e){let t=window.innerWidth-e-16;if(t<400)return Math.max(60,t)}function no(e,t,n){let r=[];for(let o of t)r.push(...ld(e,o,n));return r}function dl(e,t,n,r,o=12,i,s){if(!n)return;let l=o*1.4,a=n.split(`
4
+ `),c=i!==void 0?[i+". "+(a[0]||""),...a.slice(1)]:a;e.font=`${o}px ${zt}`,e.textBaseline="middle";let d=s!==void 0?Math.min(400,Math.max(60,window.innerWidth-s-16)):400,u=no(e,c,d),p=Math.min(d,Math.max(...u.map(E=>e.measureText(E).width))),g=u.length*l,k=c.length*l,w=g-k,b=t.y-w;e.fillStyle=r,e.fillRect(t.x-4,b-4,p+8,g+8),e.fillStyle="#ffffff",u.forEach((E,B)=>{e.fillText(E,t.x,b+B*l+l/2)})}var ul=11,si=4,cd=`600 ${ul}px system-ui, -apple-system, sans-serif`;function li(e,t,n){return e.map(r=>({x:r.x-t,y:r.y-n}))}function dd(e,t,n,r,o,i){let s=String(r);e.font=cd;let a=e.measureText(s).width+si*2,c=ul+si*2,d=t-a/2,u=n+i/2+2;e.fillStyle=o,e.fillRect(d,u,a,c),e.fillStyle="#ffffff",e.textBaseline="middle",e.fillText(s,d+si,u+c/2)}function ud(e,t){if(e.points.length<2&&e.type!=="text")return null;switch(e.type){case"rectangle":case"freehand":{let n,r;if(e.type==="freehand")n=Math.min(...e.points.map(o=>o.x)),r=Math.max(...e.points.map(o=>o.y));else{let o=e.points[0],i=e.points[e.points.length-1];n=Math.min(o.x,i.x),r=Math.max(o.y,i.y)}return{x:n,y:r}}case"circle":{let n=e.points[0],r=e.points[e.points.length-1],o=Math.min(n.x,r.x),i=(Math.min(n.y,r.y)+Math.max(n.y,r.y))/2;return{x:o,y:i}}case"line":{let n=e.points[0],r=e.points[e.points.length-1],o=n.y>r.y?n:r;return{x:o.x,y:o.y}}default:return null}}function pl(){let e=ad(null),t=wo(()=>{let l=e.current;if(!l)return;let a=l.getContext("2d");a&&a.clearRect(0,0,l.width,l.height)},[]),n=wo((l,a,c)=>{var k;let d=e.current;if(!d)return;let u=d.getContext("2d");if(!u)return;let g=((k=l.status)!=null?k:l.captured?"in_flight":"pending")==="pending"||c?l.color:"#999999";switch(l.type){case"freehand":oi(u,l.points,g,l.strokeWidth);break;case"line":ri(u,l.points,g,l.strokeWidth);break;case"rectangle":ii(u,l.points,g,l.strokeWidth);break;case"circle":ni(u,l.points,g,l.strokeWidth);break;case"text":l.text&&l.points[0]&&dl(u,l.points[0],l.text,g,l.fontSize,a,l.points[0].x);break}},[]),r=wo((l,a,c,d)=>{let u=e.current;if(!u||l.length<2)return;let p=u.getContext("2d");if(p)switch(a){case"freehand":oi(p,l,c,d);break;case"line":ri(p,l,c,d);break;case"rectangle":ii(p,l,c,d);break;case"circle":ni(p,l,c,d);break}},[]),o=wo((l,a)=>{let c=e.current;if(!c||l.points.length<2)return;let d=c.getContext("2d");if(d){if(d.fillStyle="#ffffff",d.strokeStyle=l.color,d.lineWidth=1.5,l.type==="line"){let u=l.points[0],p=l.points[l.points.length-1];[u,p].forEach(g=>{d.beginPath(),d.arc(g.x,g.y,a/2,0,Math.PI*2),d.fill(),d.stroke()});return}if(l.type==="circle"){let u=l.points[0],p=l.points[l.points.length-1],g=Math.min(u.x,p.x),k=Math.max(u.x,p.x),w=Math.min(u.y,p.y),b=Math.max(u.y,p.y),E=(g+k)/2,B=(w+b)/2;[{x:E,y:w},{x:E,y:b},{x:g,y:B},{x:k,y:B}].forEach(T=>{d.beginPath(),d.rect(T.x-a/2,T.y-a/2,a,a),d.fill(),d.stroke()});return}if(l.type==="rectangle"||l.type==="freehand"){let u,p,g,k;if(l.type==="freehand")u=Math.min(...l.points.map(b=>b.x)),p=Math.max(...l.points.map(b=>b.x)),g=Math.min(...l.points.map(b=>b.y)),k=Math.max(...l.points.map(b=>b.y));else{let b=l.points[0],E=l.points[l.points.length-1];u=Math.min(b.x,E.x),p=Math.max(b.x,E.x),g=Math.min(b.y,E.y),k=Math.max(b.y,E.y)}[{x:u,y:g},{x:p,y:g},{x:u,y:k},{x:p,y:k}].forEach(b=>{d.beginPath(),d.rect(b.x-a/2,b.y-a/2,a,a),d.fill(),d.stroke()})}}},[]),i=wo((l,a,c,d,u,p,g,k=0,w=0,b,E)=>{var B;if(t(),l.forEach(L=>{var H;let T=y(f({},L),{points:li(L.points,k,w)}),v=b==null?void 0:b.get(L.id),O=(H=E==null?void 0:E.has(L.id))!=null?H:!1;n(T,v,O)}),a.length>0){let L=li(a,k,w);r(L,c,d,u)}if(p&&p.length>0&&g){let L=e.current,T=L==null?void 0:L.getContext("2d");for(let v of p){let O=l.find(H=>H.id===v);if(O){let H=y(f({},O),{points:li(O.points,k,w)});if(o(H,g),T&&O.type!=="text"&&b&&!(O.groupId&&l.some(G=>G.groupId===O.groupId&&G.type==="text"))){let G=b.get(O.id);if(G!==void 0){let X=ud(H,g);if(X){let I=((B=O.status)!=null?B:O.captured?"in_flight":"pending")==="pending"?O.color:"#999999";dd(T,X.x,X.y,G,I,g)}}}}}}},[t,n,r,o]),s=wo(()=>{let l=e.current;if(!l)return;let a=window.devicePixelRatio||1;l.width=window.innerWidth*a,l.height=window.innerHeight*a;let c=l.getContext("2d");c&&c.scale(a,a)},[]);return{canvasRef:e,clearCanvas:t,drawAnnotation:n,drawCurrentPath:r,redrawAll:i,resizeCanvas:s}}import{useEffect as pd,useRef as fd}from"react";function fl(){let e=fd({shift:!1,cmd:!1});return pd(()=>{let t=o=>{o.key==="Shift"&&(e.current.shift=!0),(o.key==="Meta"||o.key==="Control")&&(e.current.cmd=!0)},n=o=>{o.key==="Shift"&&(e.current.shift=!1),(o.key==="Meta"||o.key==="Control")&&(e.current.cmd=!1)},r=()=>{e.current={shift:!1,cmd:!1}};return window.addEventListener("keydown",t,!0),window.addEventListener("keyup",n,!0),window.addEventListener("blur",r),()=>{window.removeEventListener("keydown",t,!0),window.removeEventListener("keyup",n,!0),window.removeEventListener("blur",r)}},[]),e}import{useEffect as gd}from"react";function gl(e,t,n,r,o){gd(()=>{let i=s=>{if(e){if(e.linkedSelector)return;s.preventDefault(),s.stopPropagation();let a=s.deltaY>0?-2:2;t(c=>c?y(f({},c),{fontSize:Math.max(12,Math.min(72,c.fontSize+a))}):null);return}if(!n)return;s.preventDefault();let l=r.find(a=>a.id===n);if(l&&l.type==="text"&&!l.linkedSelector){let a=l.fontSize||12,c=s.deltaY>0?-2:2;o({type:"UPDATE_TEXT_SIZE",payload:{id:n,fontSize:a+c}})}};return window.addEventListener("wheel",i,{passive:!1}),()=>{window.removeEventListener("wheel",i)}},[n,e,r,o,t])}import{useCallback as Il,useEffect as Cr,useRef as Rl,useState as Ko}from"react";function gr(e){let t=Object.keys(e).find(o=>o.startsWith("__reactFiber$")||o.startsWith("__reactInternalInstance$"));if(!t)return null;let n=e[t],r=[];for(;n;){let o=n.type,i=(o==null?void 0:o.displayName)||(o==null?void 0:o.name);i&&typeof i=="string"&&/^[A-Z]/.test(i)&&!i.startsWith("_")&&i!=="Fragment"&&r.unshift(i),n=n.return}return r.length>0?{name:r[r.length-1],path:r}:null}function ai(e){let t=Object.keys(e).find(o=>o.startsWith("__reactFiber$")||o.startsWith("__reactInternalInstance$"));if(!t)return[];let n=e[t],r=[];for(;n;){let o=n.type,i=typeof o=="function"||typeof o=="object"?(o==null?void 0:o.displayName)||(o==null?void 0:o.name):null;i&&typeof i=="string"&&/^[A-Z]/.test(i)&&!i.startsWith("_")&&i!=="Fragment"&&r.push({name:i,fiber:n}),n=n.return}return r.reverse(),r}function mr(e){let t=e,n=new Set;for(;t&&!n.has(t);){if(n.add(t),t.stateNode instanceof Element)return t.stateNode;t.child?t=t.child:t=null}return null}function ml(e){if(e.id)return`#${e.id}`;let t=e.tagName.toLowerCase(),n=Array.from(e.classList).slice(0,3).join(".");return n?`${t}.${n}`:t}function un(e){if(e.id&&!e.id.startsWith("radix-")&&!e.id.startsWith(":"))return`#${CSS.escape(e.id)}`;let t=[],n=e;for(;n&&n!==document.documentElement;){let r=n.tagName.toLowerCase();if(n.id&&!n.id.startsWith("radix-")&&!n.id.startsWith(":")){t.unshift(`#${CSS.escape(n.id)}`);break}let o=Array.from(n.classList).filter(s=>!s.startsWith("_")&&s.length<30).slice(0,2);o.length>0&&(r+="."+o.map(s=>CSS.escape(s)).join("."));let i=n.parentElement;if(i){let s=Array.from(i.children).filter(l=>l.tagName===n.tagName);if(s.length>1){let l=s.indexOf(n)+1;r+=`:nth-of-type(${l})`}}t.unshift(r),n=i}return t.join(" > ")}function Qt(e){try{return document.querySelector(e)}catch(t){return null}}function hr(e,t=0){var a;let n=ai(e);if(n.length===0)return null;let r=n.map(c=>c.name),o=n.length-1,i=Math.max(0,Math.min(n.length-1,o-t)),s=n[i],l=(a=mr(s.fiber))!=null?a:e;return{name:s.name,path:r,depthIndex:i,rootElement:l}}function hl(e,t){var i,s;let n=ai(e),r=t.toLowerCase(),o=-1;for(let l=n.length-1;l>=0;l--){let a=n[l].name;if(a===t){let c=(i=mr(n[l].fiber))!=null?i:e;return{name:t,path:n.map(d=>d.name),depthIndex:l,rootElement:c}}if(o===-1){let c=a.toLowerCase();(c.length>=4&&r.includes(c)||r.length>=4&&c.includes(r))&&(o=l)}}if(o>=0){let l=(s=mr(n[o].fiber))!=null?s:e;return{name:t,path:n.map(a=>a.name),depthIndex:o,rootElement:l}}return null}function Eo(e){let t=Co(),n=[],r=new Set,o=t.currentNode;for(;o=t.nextNode();){let i=hl(o,e);i&&!r.has(i.rootElement)&&(r.add(i.rootElement),n.push(i))}return n}function ci(e){let t=new Map;if(e.size===0)return t;let n=new Set(e),r=Co(),o=new Set,i=r.currentNode;for(;(i=r.nextNode())&&n.size>0;)for(let s of n){let l=hl(i,s);if(!l||o.has(l.rootElement))continue;o.add(l.rootElement);let a=l.rootElement.getBoundingClientRect();t.set(s,a.top+window.scrollY),n.delete(s);break}for(let s of n)t.set(s,1/0);return t}function Co(){return document.createTreeWalker(document.body,NodeFilter.SHOW_ELEMENT,{acceptNode(e){return e.closest("#devtools-toolbar, #devtools-canvas, #devtools-scrim, [data-popmelt-panel]")?NodeFilter.FILTER_REJECT:NodeFilter.FILTER_ACCEPT}})}function nn(e){let t={selector:ml(e),tagName:e.tagName.toLowerCase()};e.id&&(t.id=e.id),e.classList.length>0&&(t.className=Array.from(e.classList).join(" "));let n=yl(e);n&&n.length>0&&n.length<200&&(t.textContent=n);let r={};for(let s of e.attributes)s.name.startsWith("data-")&&(r[s.name]=s.value);Object.keys(r).length>0&&(t.dataAttributes=r);let o=gr(e);o&&(t.reactComponent=o.name);let i=md(e);return i&&(t.context=i),t}function yl(e){let t="";for(let n of e.childNodes)n.nodeType===Node.TEXT_NODE&&(t+=n.textContent||"");return t.trim()}function oo(e,t){let n=document.elementsFromPoint(e,t);for(let r of n)if(r instanceof HTMLElement&&!(r.id==="devtools-canvas"||r.id==="devtools-toolbar"||r.id==="devtools-scrim")&&!r.closest("#devtools-toolbar")&&!(r.dataset.devtools||r.closest("[data-devtools]"))&&!["html","body"].includes(r.tagName.toLowerCase()))return r;return null}function md(e){let t=e.parentElement,n=["section","article","nav","aside","header","footer","main"];for(;t&&t!==document.body;){let r=t.tagName.toLowerCase();if(n.includes(r)&&t.id)return`${r}#${t.id}`;if(t.id&&!t.id.startsWith("radix-")&&!t.id.startsWith(":"))return`${r}#${t.id}`;t=t.parentElement}return null}function bl(e){let t=new Set,n=[],r=window.scrollX,o=window.scrollY,i=[{x:(e.minX+e.maxX)/2,y:(e.minY+e.maxY)/2},{x:e.minX,y:e.minY},{x:e.maxX,y:e.minY},{x:e.minX,y:e.maxY},{x:e.maxX,y:e.maxY}];for(let s of i){let l=s.x-r,a=s.y-o;if(l<0||a<0||l>window.innerWidth||a>window.innerHeight)continue;let c=oo(l,a);c&&!t.has(c)&&(t.add(c),n.push(nn(c)))}return n.slice(0,3)}function di(e){if(e.length===0)return[];let t=e.map(r=>r.x),n=e.map(r=>r.y);return bl({minX:Math.min(...t),minY:Math.min(...n),maxX:Math.max(...t),maxY:Math.max(...n)})}function At(e,t){return e.style.getPropertyValue(t)!==""}function hd(e,t=30){if(e<=0)return[];let n=[],r=Co(),o=.5,i=r.currentNode;for(;(i=r.nextNode())&&n.length<t;){let s=i,l=s.getBoundingClientRect();if(l.bottom<-50||l.top>window.innerHeight+50||l.right<-50||l.left>window.innerWidth+50||l.width<1||l.height<1)continue;let a=getComputedStyle(s);!At(s,"padding-top")&&Math.abs((parseFloat(a.paddingTop)||0)-e)<o&&n.push({element:s,property:"padding-top"}),!At(s,"padding-bottom")&&Math.abs((parseFloat(a.paddingBottom)||0)-e)<o&&n.length<t&&n.push({element:s,property:"padding-bottom"}),!At(s,"padding-left")&&Math.abs((parseFloat(a.paddingLeft)||0)-e)<o&&n.length<t&&n.push({element:s,property:"padding-left"}),!At(s,"padding-right")&&Math.abs((parseFloat(a.paddingRight)||0)-e)<o&&n.length<t&&n.push({element:s,property:"padding-right"}),!At(s,"margin-top")&&Math.abs((parseFloat(a.marginTop)||0)-e)<o&&n.length<t&&n.push({element:s,property:"margin-top"}),!At(s,"margin-bottom")&&Math.abs((parseFloat(a.marginBottom)||0)-e)<o&&n.length<t&&n.push({element:s,property:"margin-bottom"}),!At(s,"margin-left")&&Math.abs((parseFloat(a.marginLeft)||0)-e)<o&&n.length<t&&n.push({element:s,property:"margin-left"}),!At(s,"margin-right")&&Math.abs((parseFloat(a.marginRight)||0)-e)<o&&n.length<t&&n.push({element:s,property:"margin-right"});let c=a.display;if((c.includes("flex")||c.includes("grid"))&&n.length<t){let d=At(s,"gap"),u=parseFloat(a.gap)||0,p=parseFloat(a.rowGap)||0,g=parseFloat(a.columnGap)||0;!d&&Math.abs(u-e)<o?n.push({element:s,property:"gap"}):!At(s,"row-gap")&&Math.abs(p-e)<o?n.push({element:s,property:"row-gap"}):!At(s,"column-gap")&&Math.abs(g-e)<o&&n.push({element:s,property:"column-gap"})}}return n}function ui(e,t=30){if(e<=0)return[];let n=[],r=Co(),o=.5,i=r.currentNode;for(;(i=r.nextNode())&&n.length<t;){let s=i,l=s.getBoundingClientRect();if(l.bottom<-50||l.top>window.innerHeight+50||l.right<-50||l.left>window.innerWidth+50||l.width<1||l.height<1)continue;let a=getComputedStyle(s),c=parseFloat(a.borderTopWidth)||0,d=parseFloat(a.borderRightWidth)||0,u=parseFloat(a.borderBottomWidth)||0,p=parseFloat(a.borderLeftWidth)||0,g=s.clientWidth,k=s.clientHeight,w=parseFloat(a.paddingTop)||0;!At(s,"padding-top")&&Math.abs(w-e)<o&&n.push({x:l.left+p,y:l.top+c,width:g,height:e,direction:"vertical",property:"padding-top"});let b=parseFloat(a.paddingBottom)||0;!At(s,"padding-bottom")&&Math.abs(b-e)<o&&n.length<t&&n.push({x:l.left+p,y:l.top+c+k-e,width:g,height:e,direction:"vertical",property:"padding-bottom"});let E=parseFloat(a.paddingLeft)||0;!At(s,"padding-left")&&Math.abs(E-e)<o&&n.length<t&&n.push({x:l.left+p,y:l.top+c,width:e,height:k,direction:"horizontal",property:"padding-left"});let B=parseFloat(a.paddingRight)||0;!At(s,"padding-right")&&Math.abs(B-e)<o&&n.length<t&&n.push({x:l.left+p+g-e,y:l.top+c,width:e,height:k,direction:"horizontal",property:"padding-right"});let L=parseFloat(a.marginTop)||0;!At(s,"margin-top")&&Math.abs(L-e)<o&&n.length<t&&n.push({x:l.left,y:l.top-e,width:l.width,height:e,direction:"vertical",property:"margin-top"});let T=parseFloat(a.marginBottom)||0;!At(s,"margin-bottom")&&Math.abs(T-e)<o&&n.length<t&&n.push({x:l.left,y:l.bottom,width:l.width,height:e,direction:"vertical",property:"margin-bottom"});let v=parseFloat(a.marginLeft)||0;!At(s,"margin-left")&&Math.abs(v-e)<o&&n.length<t&&n.push({x:l.left-e,y:l.top,width:e,height:l.height,direction:"horizontal",property:"margin-left"});let O=parseFloat(a.marginRight)||0;!At(s,"margin-right")&&Math.abs(O-e)<o&&n.length<t&&n.push({x:l.right,y:l.top,width:e,height:l.height,direction:"horizontal",property:"margin-right"});let H=a.display;if((H.includes("flex")||H.includes("grid"))&&n.length<t&&!At(s,"gap")){let G=Array.from(s.children).filter(X=>{let S=getComputedStyle(X);return S.display!=="none"&&S.position!=="absolute"&&S.position!=="fixed"});if(G.length>=2)for(let X=0;X<G.length-1&&n.length<t;X++){let S=G[X].getBoundingClientRect(),I=G[X+1].getBoundingClientRect(),K=I.top-S.bottom;Math.abs(K-e)<o&&K>.5&&n.push({x:Math.min(S.left,I.left),y:S.bottom,width:Math.max(S.right,I.right)-Math.min(S.left,I.left),height:K,direction:"vertical",property:"gap"});let ge=I.left-S.right;Math.abs(ge-e)<o&&ge>.5&&n.push({x:S.right,y:Math.min(S.top,I.top),width:ge,height:Math.max(S.bottom,I.bottom)-Math.min(S.top,I.top),direction:"horizontal",property:"gap"})}}}return n}function yr(e){return typeof e=="string"?{value:e}:e}var Sl={gap:["gap","row-gap","column-gap"],padding:["padding-top","padding-bottom","padding-left","padding-right"],margin:["margin-top","margin-bottom","margin-left","margin-right"]};function xl(e,t){let n=Sl[t];return n?n.includes(e):!1}function yd(e,t){let n=e.split(/\s+/);for(let r of n){if(r===t)return!0;let o=r.lastIndexOf(":");if(o>=0&&r.slice(o+1)===t)return!0}return!1}function bd(e){var l,a;let t=e.lastIndexOf(":"),n=t>=0?e.slice(t+1):e,r=n.indexOf("-");if(r<0)return null;let o=n.slice(0,r),i={gap:"gap","gap-x":"column-gap","gap-y":"row-gap",p:"padding",pt:"padding-top",pb:"padding-bottom",pl:"padding-left",pr:"padding-right",px:"padding-left",py:"padding-top",m:"margin",mt:"margin-top",mb:"margin-bottom",ml:"margin-left",mr:"margin-right",mx:"margin-left",my:"margin-top"},s=n.slice(0,n.indexOf("-",r+1)>0?n.indexOf("-",r+1):r);return(a=(l=i[s])!=null?l:i[o])!=null?a:null}function pi(e,t=30){let n=parseFloat(e.value);if(isNaN(n)||n<=0)return[];if(e.bindings&&e.bindings.length>0){let o=[],i=Co(),s=i.currentNode;for(;(s=i.nextNode())&&o.length<t;){let l=s,a=l.getBoundingClientRect();if(a.bottom<-50||a.top>window.innerHeight+50||a.right<-50||a.left>window.innerWidth+50||a.width<1||a.height<1)continue;let c=l.className;if(typeof c=="string")for(let d of e.bindings){if(!yd(c,d))continue;let u=bd(d);if(u&&!(e.property&&!xl(u,e.property))){o.push({element:l,property:u});break}}}return o}let r=hd(n,t*2);return e.property?r.filter(o=>xl(o.property,e.property)).slice(0,t):r.slice(0,t)}function fi(e,t=30){let n=pi(e,t),r=[];for(let o of n){let i=o.element,s=i.getBoundingClientRect(),l=getComputedStyle(i),a=parseFloat(l.borderTopWidth)||0,c=parseFloat(l.borderRightWidth)||0,d=parseFloat(l.borderLeftWidth)||0,u=i.clientWidth,p=i.clientHeight;switch(o.property){case"padding-top":{let g=parseFloat(l.paddingTop)||0;r.push({x:s.left+d,y:s.top+a,width:u,height:g,direction:"vertical",property:o.property});break}case"padding-bottom":{let g=parseFloat(l.paddingBottom)||0;r.push({x:s.left+d,y:s.top+a+p-g,width:u,height:g,direction:"vertical",property:o.property});break}case"padding-left":{let g=parseFloat(l.paddingLeft)||0;r.push({x:s.left+d,y:s.top+a,width:g,height:p,direction:"horizontal",property:o.property});break}case"padding-right":{let g=parseFloat(l.paddingRight)||0;r.push({x:s.left+d+u-g,y:s.top+a,width:g,height:p,direction:"horizontal",property:o.property});break}case"margin-top":{let g=parseFloat(l.marginTop)||0;r.push({x:s.left,y:s.top-g,width:s.width,height:g,direction:"vertical",property:o.property});break}case"margin-bottom":{let g=parseFloat(l.marginBottom)||0;r.push({x:s.left,y:s.bottom,width:s.width,height:g,direction:"vertical",property:o.property});break}case"margin-left":{let g=parseFloat(l.marginLeft)||0;r.push({x:s.left-g,y:s.top,width:g,height:s.height,direction:"horizontal",property:o.property});break}case"margin-right":{let g=parseFloat(l.marginRight)||0;r.push({x:s.right,y:s.top,width:g,height:s.height,direction:"horizontal",property:o.property});break}case"gap":case"row-gap":case"column-gap":{let g=Array.from(i.children).filter(k=>{let w=getComputedStyle(k);return w.display!=="none"&&w.position!=="absolute"&&w.position!=="fixed"});for(let k=0;k<g.length-1&&r.length<t;k++){let w=g[k].getBoundingClientRect(),b=g[k+1].getBoundingClientRect(),E=b.top-w.bottom;E>.5&&r.push({x:Math.min(w.left,b.left),y:w.bottom,width:Math.max(w.right,b.right)-Math.min(w.left,b.left),height:E,direction:"vertical",property:"gap"});let B=b.left-w.right;B>.5&&r.push({x:w.right,y:Math.min(w.top,b.top),width:B,height:Math.max(w.bottom,b.bottom)-Math.min(w.top,b.top),direction:"horizontal",property:"gap"})}break}}}return r}function vl(e,t){let n=new Set,r=jo(t);for(let o of e){let i=El[o.property];if(!i)continue;let s=o.element.className;if(typeof s=="string")for(let l of i){let a=`${l}-${r}`;for(let c of s.split(/\s+/)){let d=c.lastIndexOf(":"),u=d>=0?c.slice(d+1):c;if(u===a){n.add(u);break}}}}return[...n]}function wl(e){let t=new Set;for(let n of e)for(let[r,o]of Object.entries(Sl))if(o.includes(n.property)){t.add(r);break}if(t.size===1)return[...t][0]}function gi(e,t,n){if(t===n)return e;let r=jo(t),o=jo(n);return e.map(i=>{let s=i.lastIndexOf("-");if(s<0)return i;let l=i.slice(0,s),a=i.slice(s+1);return a===r||a===`[${t}px]`?`${l}-${o}`:i})}var xd={0:"0",1:"px",2:"0.5",4:"1",6:"1.5",8:"2",12:"3",16:"4",20:"5",24:"6",28:"7",32:"8",40:"10",48:"12",64:"16",80:"20",96:"24"};function jo(e){var t;return(t=xd[e])!=null?t:`[${e}px]`}var El={"padding-top":["pt","py","p"],"padding-bottom":["pb","py","p"],"padding-left":["pl","px","p"],"padding-right":["pr","px","p"],"margin-top":["mt","my","m"],"margin-bottom":["mb","my","m"],"margin-left":["ml","mx","m"],"margin-right":["mr","mx","m"],gap:["gap"],"row-gap":["gap-y","gap"],"column-gap":["gap-x","gap"]};function Sd(e,t,n,r){let o=El[t];if(!o)return null;let i=jo(n);for(let s of o){let l=new RegExp("(?:^|\\s)((?:[\\w-]+:)*"+s+"-(?:"+vd(i)+"|\\["+n+"px\\]))(?:\\s|$)"),a=e.match(l);if(a!=null&&a[1]){let c=jo(r),d=a[1].lastIndexOf(":"),u=d>=0?a[1].slice(0,d+1):"";return{matched:a[1],suggested:`${u}${s}-${c}`}}}return null}function vd(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Cl(e,t,n){let r=new Set,o=[];for(let i of e){let s=un(i.element),l=`${s}::${i.property}`;if(r.has(l))continue;r.add(l);let a=gr(i.element),c=i.element.className||"",d=Sd(c,i.property,t,n);o.push({selector:s,reactComponent:a==null?void 0:a.name,className:c,property:i.property,matchedClass:d==null?void 0:d.matched,suggestedClass:d==null?void 0:d.suggested})}return o}function Go(e,t){return window.getComputedStyle(e).getPropertyValue(t)}function mi(e,t){if(e instanceof HTMLElement){let r=e.style.getPropertyValue(t);if(r)return r}let n=wd(e,t);return n&&n.includes("var(")?n:Go(e,t)}function wd(e,t){let n=t.replace(/-([a-z])/g,(r,o)=>o.toUpperCase());try{for(let r of document.styleSheets)try{let o=r.cssRules||r.rules;for(let i of o)if(i instanceof CSSStyleRule&&e.matches(i.selectorText)){let s=i.style.getPropertyValue(t);if(s&&s.includes("var("))return s;let l=i.style[n];if(l&&l.includes("var("))return l}}catch(o){}}catch(r){}return null}function br(e,t){if(e instanceof HTMLElement){let r=e.style.getPropertyValue(t);if(r)return r}let n=t.replace(/-([a-z])/g,(r,o)=>o.toUpperCase());try{for(let r of document.styleSheets)try{let o=r.cssRules||r.rules;for(let i of o)if(i instanceof CSSStyleRule&&e.matches(i.selectorText)){let s=i.style.getPropertyValue(t);if(s)return s;let l=i.style[n];if(l)return l}}catch(o){}}catch(r){}return null}function xr(e){let t=window.getComputedStyle(e).display;return t==="flex"||t==="inline-flex"||t==="grid"||t==="inline-grid"}function Vo(e){let t=window.getComputedStyle(e);return{row:parseFloat(t.rowGap)||0,column:parseFloat(t.columnGap)||0}}function Ed(e){let t=[];for(let n of e){let r=t.find(o=>o.axis!==n.axis?!1:n.axis==="row"?Math.abs(o.y-n.y)<2&&Math.abs(o.h-n.h)<2:Math.abs(o.x-n.x)<2&&Math.abs(o.w-n.w)<2);if(r)if(n.axis==="row"){let o=Math.min(r.x,n.x),i=Math.max(r.x+r.w,n.x+n.w);r.x=o,r.w=i-o}else{let o=Math.min(r.y,n.y),i=Math.max(r.y+r.h,n.y+n.h);r.y=o,r.h=i-o}else t.push(f({},n))}return t}function ro(e){let t=Array.from(e.children).filter(a=>{if(!(a instanceof HTMLElement))return!1;let c=window.getComputedStyle(a);return c.display!=="none"&&c.position!=="absolute"&&c.position!=="fixed"});if(t.length<2)return[];let n=[],r=e.getBoundingClientRect(),i=window.getComputedStyle(e).flexDirection,s=i==="column"||i==="column-reverse",l=6;for(let a=0;a<t.length-1;a++){let c=t[a].getBoundingClientRect(),d=t[a+1].getBoundingClientRect();if(d.left>c.right+.5&&n.push({axis:"column",x:c.right,y:r.top,w:d.left-c.right,h:r.height}),d.top>c.bottom+.5&&n.push({axis:"row",x:r.left,y:c.bottom,w:r.width,h:d.top-c.bottom}),!(d.left>c.right+.5)&&!(d.top>c.bottom+.5))if(s){let u=(c.bottom+d.top)/2;n.push({axis:"row",x:r.left,y:u-l/2,w:r.width,h:l})}else{let u=(c.right+d.left)/2;n.push({axis:"column",x:u-l/2,y:r.top,w:l,h:r.height})}}return Ed(n)}function hi(e,t){let n=window.getComputedStyle(e),r=n.display;if(r!=="flex"&&r!=="inline-flex")return!1;let o=n.justifyContent;if(o!=="space-between"&&o!=="space-around"&&o!=="space-evenly"&&o!=="stretch")return!1;let i=n.flexDirection;return!(t!==(i==="column"||i==="column-reverse"?"row":"column")||parseFloat(t==="row"?n.rowGap:n.columnGap)>0)}function ko(e){let t=window.getComputedStyle(e);return{top:parseFloat(t.paddingTop)||0,right:parseFloat(t.paddingRight)||0,bottom:parseFloat(t.paddingBottom)||0,left:parseFloat(t.paddingLeft)||0}}function io(e){let t=window.getComputedStyle(e);return{"top-left":parseFloat(t.borderTopLeftRadius)||0,"top-right":parseFloat(t.borderTopRightRadius)||0,"bottom-right":parseFloat(t.borderBottomRightRadius)||0,"bottom-left":parseFloat(t.borderBottomLeftRadius)||0}}function yi(e){for(let t of e.childNodes)if(t.nodeType===Node.TEXT_NODE&&(t.textContent||"").trim().length>0)return!0;return!1}function Mo(e){var d,u;let t=document.createRange(),n=!1;for(let p of e.childNodes)p.nodeType===Node.TEXT_NODE&&(p.textContent||"").trim().length>0&&(n||(t.setStart(p,0),n=!0),t.setEnd(p,(u=(d=p.textContent)==null?void 0:d.length)!=null?u:0));if(!n)return null;let r=t.getBoundingClientRect(),o=window.getComputedStyle(e),i=parseFloat(o.fontSize)||16,s=parseFloat(o.lineHeight);isNaN(s)&&(s=i*1.2);let l=Math.max(1,t.getClientRects().length),a=Math.max(r.height,l*s),c=(a-r.height)/2;return new DOMRect(r.x,r.y-c,r.width,a)}function Uo(e){let t=window.getComputedStyle(e),n=parseFloat(t.fontSize)||16,r=parseFloat(t.lineHeight);return isNaN(r)&&(r=n*1.2),{fontSize:n,lineHeight:r}}function $e(e,t,n){e instanceof HTMLElement&&e.style.setProperty(t,n,"important")}function bi(e,t,n){e instanceof HTMLElement&&e.style.removeProperty(t)}function Sr(e){var t;for(let n of e){let r=Qt(n.selector);if(!r&&n.durableSelector&&(r=Qt(n.durableSelector),r)){let o=(t=n.selector.match(/\[data-pm="([^"]+)"\]/))==null?void 0:t[1];o&&r.setAttribute("data-pm",o)}if(r)for(let o of n.changes)$e(r,o.property,o.modified)}}function xi(e,t){let n=Qt(e);if(!n)return;let r=t.find(o=>o.selector===e);if(r)for(let o of r.changes)bi(n,o.property,o.original)}function vr(e){for(let t of e){let n=Qt(t.selector);if(n)for(let r of t.changes)bi(n,r.property,r.original)}}function Ml(e,t,n,r){if(e)for(let o of e){if(o instanceof CSSGroupingRule){Ml(o.cssRules,t,n,r);continue}if(o instanceof CSSStyleRule){let i=o.selectorText.toLowerCase();(i===":root"||i==="html"||i==="*"||i.includes(":root"))&&Cd(o.style,t,n,r)}}}function Cd(e,t,n,r){for(let o=0;o<e.length;o++){let i=e[o];if(i!=null&&i.startsWith("--")){if(n.has(i))continue;n.add(i);let s=t.getPropertyValue(i).trim();Tl(s)&&r.push({name:i,value:s,usage:`var(${i})`})}}}var wr=null,kd=5e3;function Si(){if(wr&&Date.now()-wr.timestamp<kd)return wr.variables;let e=[],t=new Set,n=getComputedStyle(document.documentElement);try{for(let i of document.styleSheets)try{Ml(i.cssRules||i.rules,n,t,e)}catch(s){}}catch(i){}let r=document.documentElement.style;for(let i=0;i<r.length;i++){let s=r[i];if(s!=null&&s.startsWith("--")&&!t.has(s)){t.add(s);let l=n.getPropertyValue(s).trim();Tl(l)&&e.push({name:s,value:l,usage:`var(${s})`})}}let o=e.sort((i,s)=>i.name.localeCompare(s.name));return wr={variables:o,timestamp:Date.now()},o}function Tl(e){if(!e)return!1;let t=e.toLowerCase().trim();return!!(/^#([0-9a-f]{3}|[0-9a-f]{4}|[0-9a-f]{6}|[0-9a-f]{8})$/i.test(t)||t.startsWith("rgb")||t.startsWith("hsl")||t.startsWith("oklch")||t.startsWith("oklab")||t.startsWith("lch")||t.startsWith("lab")||["transparent","currentcolor","inherit","white","black","red","green","blue","yellow","orange","purple","pink","gray","grey"].includes(t))}function Jo(e,t){let n=t.match(/var\((--[^,)]+)(?:,\s*([^)]+))?\)/);if(n){let r=n[1],o=n[2];return getComputedStyle(document.documentElement).getPropertyValue(r).trim()||o||t}return t}function Xo(e,t){if(!e)return null;let n=kl(e);if(!n)return null;for(let r of t){let o=kl(r.value);if(o&&n===o)return r}return null}function kl(e){if(!e)return null;let t=e.trim().toLowerCase();if(t.startsWith("oklch(")){let n=t.match(/oklch\(\s*([\d.]+%?)\s+([\d.]+%?)\s+([\d.]+)/);if(n){let r=n[1].endsWith("%")?parseFloat(n[1])/100:parseFloat(n[1]),o=n[2].endsWith("%")?parseFloat(n[2])/100:parseFloat(n[2]),i=parseFloat(n[3]);r=Math.round(r*100)/100,o=Math.round(o*1e3)/1e3;let s=Math.round(i);return`oklch(${r} ${o} ${s})`}}if(t.startsWith("rgb")){let n=t.match(/rgba?\(\s*(\d+)[,\s]+(\d+)[,\s]+(\d+)/);if(n)return`rgb(${n[1]},${n[2]},${n[3]})`}return t.startsWith("#")?t.length===4?`#${t[1]}${t[1]}${t[2]}${t[2]}${t[3]}${t[3]}`:t.slice(0,7):t}import{Fragment as so,jsx as Qe,jsxs as wn}from"react/jsx-runtime";var bn=22,jn=12,Md=3,Td=250,Er=["reviewing","considering","thinking","zhuzhing","iterating","tweaking","reflecting","noodling","pondering","finessing","polishing","riffing"],Id=3e3;function Rd(s){var l=s,{left:e,top:t,avoidBottom:n,style:r,children:o}=l,i=Yn(l,["left","top","avoidBottom","style","children"]);let a=e+jn,c=t+jn,d=n!==void 0?`${n}px`:"100vh";return Qe("div",y(f({"data-devtools":"badge-hit-area"},i),{style:f({position:"fixed",left:e,top:t,padding:jn},r),children:Qe("div",{style:{transform:`translate(min(0px, calc(100vw - ${a}px - 100%)), min(0px, calc(${d} - ${c}px - 100%)))`},children:o})}))}function Ll({annotations:e,supersededAnnotations:t,inFlightIds:n,scrollX:r,scrollY:o,annotationGroupMap:i,onViewThread:s,onSelectAnnotation:l,onHoverAnnotation:a,canvasRef:c}){var v,O,H,U,G,X,S;let[d,u]=Ko(0),[p,g]=Ko(()=>Math.floor(Math.random()*Er.length)),k=!!(n&&n.size>0);Cr(()=>{if(!k)return;let I=setInterval(()=>{u(ge=>(ge+1)%Md)},Td),K=setInterval(()=>{g(ge=>(ge+1)%Er.length)},Id);return()=>{clearInterval(I),clearInterval(K)}},[k]);let w=[];for(let I of e){if(I.type!=="text"||!I.text||!I.points[0]||t.has(I))continue;let K=I.groupId?e.filter(j=>j.groupId===I.groupId):[I],ge=!!(n&&(n.has(I.id)||K.some(j=>n.has(j.id)))),be=(v=I.status)!=null?v:"pending",de=K.some(j=>j.status==="resolved"||j.status==="needs_review"),ue=K.some(j=>j.threadId);if(!ge&&be!=="resolved"&&be!=="needs_review"&&!de&&!ue)continue;let Fe=I.threadId||((O=K.find(j=>j.threadId))==null?void 0:O.threadId),Te=be==="needs_review"||K.some(j=>j.status==="needs_review"),ee=K.reduce((j,he)=>{var xe;return j+((xe=he.replyCount)!=null?xe:0)},0),Le=I.points[0],Ae=I.fontSize||12,_e=Ae*1.4,Pe=I.text.split(`
5
+ `),Me=i.get(I.id),q=Me!==void 0?[Me+". "+(Pe[0]||""),...Pe.slice(1)]:Pe,me=(U=(H=c==null?void 0:c.current)==null?void 0:H.getContext("2d"))!=null?U:document.createElement("canvas").getContext("2d");if(!me)continue;me.font=`${Ae}px ${zt}`;let Ee=Le.x-r,ye=vo(Ee),Ie=ye!==void 0?Math.min(400,ye):400,We=no(me,q,Ie),lt=Math.min(Ie,Math.max(...We.map(j=>me.measureText(j).width))),dt=We.length*_e,W=q.length*_e,te=dt-W;w.push({id:I.id,threadId:Fe,linkedSelector:I.linkedSelector||((G=K.find(j=>j.linkedSelector))==null?void 0:G.linkedSelector),x:Le.x+lt+4,y:Le.y-4-te,size:dt+8,color:I.color,isInFlight:ge,isNeedsReview:Te,replyCount:ee})}if(w.length===0)return null;let b=2,E=(S=(X=c==null?void 0:c.current)==null?void 0:X.getContext("2d"))!=null?S:document.createElement("canvas").getContext("2d"),B=w.map(I=>{var ue;let K;I.isInFlight?K=(ue=Er[p])!=null?ue:"thinking":I.replyCount>0?K=`${I.replyCount} ${I.replyCount===1?"reply":"replies"}`:I.threadId?K="1 reply":K="Cancelled";let ge=11,be=4,de=K.length*7.2;return E&&(E.font=`12px ${zt}`,de=E.measureText(K).width),4+ge+be+de+4}),L=typeof window!="undefined"?window.innerHeight:9999,T=[];for(let I=0;I<w.length;I++){let K=w[I].y-o,ge=Math.min(K,L-bn),be=ge+bn,ue=w[I].x-r;for(let Fe=0;Fe<I;Fe++){let Te=w[Fe].y-o,ee=Math.min(Te,L-bn),Le=ee+bn;if(!(ge<Le&&be>ee))continue;let _e=T[Fe]+B[Fe];ue<_e+b&&(ue=_e+b)}T.push(ue)}return Qe(so,{children:w.map((I,K)=>{let ge=!!I.threadId;return Qe(Rd,{left:T[K]-jn,top:I.y-o-jn,onMouseDown:ge?be=>be.stopPropagation():void 0,onClick:ge?be=>{if(be.stopPropagation(),l==null||l(I.id),s==null||s(I.threadId),I.linkedSelector)try{let de=document.querySelector(I.linkedSelector);if(de){let ue=de.getBoundingClientRect();(ue.bottom<0||ue.top>window.innerHeight)&&de.scrollIntoView({behavior:"smooth",block:"center"})}}catch(de){}}:void 0,onMouseEnter:a?()=>a(I.id):void 0,onMouseLeave:a?()=>a(null):void 0,style:{pointerEvents:ge?"auto":"none",cursor:ge?"pointer":void 0,zIndex:9999},children:Qe("div",{"data-devtools":"annotation-badge",style:{height:I.size,display:"flex",alignItems:"center",backgroundColor:I.color,fontFamily:zt,fontSize:12,color:"#ffffff",userSelect:"none",padding:`0 ${4}px`,gap:4,whiteSpace:"nowrap"},children:I.isInFlight?wn(so,{children:[Qe("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"currentColor",style:{verticalAlign:"middle"},children:d===1?wn(so,{children:[Qe("circle",{cx:"7",cy:"7",r:"2"}),Qe("circle",{cx:"17",cy:"7",r:"2"}),Qe("circle",{cx:"7",cy:"17",r:"2"}),Qe("circle",{cx:"17",cy:"17",r:"2"})]}):wn(so,{children:[Qe("circle",{cx:"12",cy:"6",r:"2"}),Qe("circle",{cx:"6",cy:"12",r:"2"}),Qe("circle",{cx:"18",cy:"12",r:"2"}),Qe("circle",{cx:"12",cy:"18",r:"2"})]})}),Qe("span",{style:{opacity:.7},children:Er[p]})]}):wn(so,{children:[I.isNeedsReview?Qe("span",{style:{fontWeight:700},children:"?"}):Qe("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",children:Qe("polyline",{points:"4 12 10 18 20 6"})}),Qe("span",{style:{opacity:.7},children:I.replyCount>0?`${I.replyCount} ${I.replyCount===1?"reply":"replies"}`:I.threadId?"1 reply":"Cancelled"})]})})},I.id)})})}function vi({inFlightSelectorColors:e,animated:t=!0}){let[n,r]=Ko([]);if(Cr(()=>{if(e.size===0){r([]);return}let i=null,s=()=>{let c=[];for(let[d,u]of e){let p=Qt(d);if(!p)continue;let g=p.getBoundingClientRect();c.push({selector:d,top:g.top,left:g.left,width:g.width,height:g.height,color:u})}r(c)},l=()=>{i&&cancelAnimationFrame(i),i=requestAnimationFrame(s)};s(),window.addEventListener("scroll",l,!0),window.addEventListener("resize",l,!0);let a=new MutationObserver(l);return a.observe(document.body,{attributes:!0,childList:!0,subtree:!0,attributeFilter:["style","class"]}),()=>{window.removeEventListener("scroll",l,!0),window.removeEventListener("resize",l,!0),a.disconnect(),i&&cancelAnimationFrame(i)}},[e]),n.length===0)return null;let o={position:"absolute",width:2,height:2,pointerEvents:"none"};return wn(so,{children:[t&&Qe("style",{children:"@keyframes popmelt-march { to { stroke-dashoffset: -6; } }"}),n.map(i=>wn("div",{"data-devtools":"marching-ants",style:{position:"fixed",top:i.top,left:i.left,width:i.width,height:i.height,pointerEvents:"none",zIndex:9995,overflow:"visible"},children:[Qe("svg",{style:{position:"absolute",inset:0,width:"100%",height:"100%",overflow:"visible"},children:Qe("rect",{x:"0.5",y:"0.5",width:Math.max(0,i.width-1),height:Math.max(0,i.height-1),fill:"none",stroke:i.color,strokeWidth:"1",strokeDasharray:"2 4",style:t?{animation:"popmelt-march 0.5s steps(2) infinite"}:void 0})}),Qe("div",{style:y(f({},o),{top:-1,left:-1,backgroundColor:i.color})}),Qe("div",{style:y(f({},o),{top:-1,right:-1,backgroundColor:i.color})}),Qe("div",{style:y(f({},o),{bottom:-1,left:-1,backgroundColor:i.color})}),Qe("div",{style:y(f({},o),{bottom:-1,right:-1,backgroundColor:i.color})})]},i.selector))]})}function Al({annotations:e,supersededAnnotations:t,scrollX:n,scrollY:r,onReply:o,annotationGroupMap:i,canvasRef:s,onHoverAnnotation:l}){let a=e.filter(u=>t.has(u)?!1:u.status==="waiting_input"&&u.question&&u.threadId);if(a.length===0)return null;let c=new Set,d=[];for(let u of a){if(!u.threadId||c.has(u.threadId))continue;c.add(u.threadId);let p=u.type==="text"?u:e.find(g=>g.groupId&&g.groupId===u.groupId&&g.type==="text")||u;if(p.type==="text"&&p.text&&p.points[0]){let g=p.points[0],k=p.fontSize||12,w=k*1.4,b=p.text.split(`
6
+ `),E=i.get(p.id),B=E!==void 0?[E+". "+(b[0]||""),...b.slice(1)]:b,T=document.createElement("canvas").getContext("2d");if(!T)continue;T.font=`${k}px ${zt}`;let v=g.x-n,O=vo(v),H=O!==void 0?Math.min(400,O):400,U=no(T,B,H),G=Math.min(H,Math.max(...U.map(ge=>T.measureText(ge).width))),X=U.length*w,S=B.length*w,I=X-S,K=X+8;d.push({annotation:u,x:g.x+G+4,y:g.y-4-I,size:K})}}return d.length===0?null:Qe(so,{children:d.map(({annotation:u,x:p,y:g,size:k})=>Qe(Ld,{annotation:u,x:p-n,y:g-r,size:k,onReply:o,onHoverAnnotation:l},`question-${u.threadId}`))})}function Ld({annotation:e,x:t,y:n,size:r,onReply:o,onHoverAnnotation:i}){let[s,l]=Ko(!1),[a,c]=Ko(""),d=Rl(null),u=Rl(null);Cr(()=>{s&&d.current&&d.current.focus()},[s]),Cr(()=>{if(!s)return;let b=B=>{u.current&&!B.composedPath().includes(u.current)&&l(!1)},E=B=>{B.key==="Escape"&&l(!1)};return document.addEventListener("mousedown",b),document.addEventListener("keydown",E),()=>{document.removeEventListener("mousedown",b),document.removeEventListener("keydown",E)}},[s]);let p=Il(()=>{!a.trim()||!e.threadId||(o(e.threadId,a.trim()),c(""),l(!1))},[a,e.threadId,o]),g=Il(b=>{b.key==="Enter"&&(b.metaKey||b.ctrlKey)&&(b.preventDefault(),p())},[p]),k=s?t:t-jn,w=s?n:n-jn;return wn("div",{ref:u,"data-devtools":"question-badge",onMouseEnter:i?()=>i(e.id):void 0,onMouseLeave:i?()=>i(null):void 0,style:{position:"fixed",left:`max(0px, ${k}px)`,top:`max(0px, ${w}px)`,padding:s?0:jn,transform:`translate(min(0px, calc(100vw - max(0px, ${k}px) - 100%)), min(0px, calc(100vh - max(0px, ${w}px) - 100%)))`,zIndex:s?10002:9999,pointerEvents:"auto",cursor:s?void 0:"pointer"},children:[!s&&wn("div",{onClick:()=>l(!0),style:{height:r,display:"flex",alignItems:"center",backgroundColor:e.color,padding:`0 ${4}px`,gap:4,fontFamily:zt,fontSize:12,color:"#ffffff",whiteSpace:"nowrap"},children:[wn("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",children:[Qe("line",{x1:"12",y1:"3",x2:"12",y2:"9"}),Qe("line",{x1:"12",y1:"15",x2:"12",y2:"21"}),Qe("line",{x1:"3",y1:"12",x2:"9",y2:"12"}),Qe("line",{x1:"15",y1:"12",x2:"21",y2:"12"})]}),Qe("span",{style:{opacity:.7},children:"reply?"})]}),s&&wn("div",{style:{minWidth:260,maxWidth:360,backgroundColor:"#eaeaea",fontFamily:zt,fontSize:12,color:"#1f2937",border:"1px solid rgba(0, 0, 0, 0.1)"},children:[Qe("div",{style:{padding:`${6}px ${8}px`,lineHeight:1.4},children:e.question}),wn("div",{style:{padding:`0 ${4}px ${4}px`},children:[Qe("textarea",{ref:d,value:a,onChange:b=>c(b.target.value),onKeyDown:g,placeholder:"Type your reply...",style:{width:"100%",minHeight:40,padding:4,fontSize:12,fontFamily:zt,backgroundColor:"rgba(0, 0, 0, 0.04)",color:"#1f2937",border:"1px solid rgba(0, 0, 0, 0.1)",borderRadius:0,outline:"none",resize:"vertical",lineHeight:1.4,boxSizing:"border-box"}}),Qe("div",{style:{display:"flex",justifyContent:"flex-end",marginTop:4},children:Qe("button",{onClick:p,disabled:!a.trim(),style:{padding:"4px 12px",fontSize:11,fontFamily:zt,fontWeight:600,backgroundColor:a.trim()?e.color:"rgba(0,0,0,0.1)",color:a.trim()?"#ffffff":"rgba(0,0,0,0.3)",border:"none",cursor:a.trim()?"pointer":"default"},children:"Send \u2318\u23CE"})})]})]})]})}function kr(e){var i;let t=new Set,n=new Map;for(let s of e){if(!s.linkedSelector)continue;let l=n.get(s.linkedSelector)||[];l.push(s),n.set(s.linkedSelector,l)}let r=new Set,o=new Set;for(let s of n.values()){if(s.length<=1){(i=s[0])!=null&&i.groupId&&o.add(s[0].groupId);continue}s.sort((a,c)=>c.timestamp-a.timestamp);let l=s[0];l.groupId&&o.add(l.groupId);for(let a=1;a<s.length;a++){let c=s[a];t.add(c),c.groupId&&r.add(c.groupId)}}for(let s of e)s.groupId&&r.has(s.groupId)&&!o.has(s.groupId)&&t.add(s);return t}import{useEffect as Pl,useLayoutEffect as Ad,useState as Bl}from"react";import{jsx as wi,jsxs as Dl}from"react/jsx-runtime";function Pd(e,t){let n=e.match(/^oklch\(([^)]+)\)$/i);return n?`oklch(${n[1]} / ${t})`:`color-mix(in srgb, ${e} ${Math.round(t*100)}%, transparent)`}var Ol=["top-left","top-right","bottom-right","bottom-left"];function Nl({element:e,radius:t,accentColor:n,hoveredCorner:r,draggingCorner:o,cursorViewport:i}){let[s,l]=Bl(null),[a,c]=Bl(!1);if(Pl(()=>{let E=T=>{(T.key==="Meta"||T.key==="Control")&&c(!0)},B=T=>{(T.key==="Meta"||T.key==="Control")&&c(!1)},L=()=>c(!1);return window.addEventListener("keydown",E,!0),window.addEventListener("keyup",B,!0),window.addEventListener("blur",L),()=>{window.removeEventListener("keydown",E,!0),window.removeEventListener("keyup",B,!0),window.removeEventListener("blur",L)}},[]),Pl(()=>{if(!e){l(null);return}let E=()=>{l(e.getBoundingClientRect())};return E(),window.addEventListener("scroll",E,{passive:!0}),window.addEventListener("resize",E,{passive:!0}),()=>{window.removeEventListener("scroll",E),window.removeEventListener("resize",E)}},[e]),Ad(()=>{e&&l(e.getBoundingClientRect())},[e,t["top-left"],t["top-right"],t["bottom-right"],t["bottom-left"]]),!s)return null;let d=s.width,u=s.height,p=Pd(n,.2),g={"top-left":{x:0,y:t["top-left"]},"top-right":{x:d,y:t["top-right"]},"bottom-right":{x:d,y:u-t["bottom-right"]},"bottom-left":{x:0,y:u-t["bottom-left"]}},k=new Set,w=o!=null?o:r;if(w)if(a)k.add(w);else for(let E of Ol)k.add(E);let b={position:"fixed",top:s.top,left:s.left,width:d,height:u,pointerEvents:"none",zIndex:9996,overflow:"visible"};return Dl("div",{"data-devtools":"border-radius-handles",style:b,children:[Dl("svg",{style:{position:"absolute",inset:0,width:"100%",height:"100%",overflow:"visible",pointerEvents:"none"},viewBox:`0 0 ${d} ${u}`,children:[wi("rect",{x:"0.5",y:"0.5",width:Math.max(0,d-1),height:Math.max(0,u-1),fill:"none",stroke:p,strokeWidth:"1"}),Ol.map(E=>{let B=g[E],L=k.has(E);return wi("circle",{cx:B.x,cy:B.y,r:E===(o!=null?o:r)?3:2.5,fill:n,stroke:"#ffffff",strokeWidth:E===(o!=null?o:r)?4:2,paintOrder:"stroke"},E)})]}),i&&w&&(()=>{let E=Math.round(t[w]);return wi("div",{style:{position:"fixed",left:i.x+8,top:i.y-28,background:n,color:"#fff",fontSize:11,fontWeight:600,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',lineHeight:1,padding:"4px 4px",borderRadius:0,whiteSpace:"nowrap",pointerEvents:"none",zIndex:9997},children:E})})()]})}import{useEffect as Bd,useState as Od}from"react";function lo(e,t){let n=e.match(/^oklch\(([^)]+)\)$/i);if(n)return`oklch(${n[1]} / ${t})`;let r=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(r){let o=parseInt(r[1],16),i=parseInt(r[2],16),s=parseInt(r[3],16);return`rgba(${o}, ${i}, ${s}, ${t})`}return`color-mix(in srgb, ${e} ${Math.round(t*100)}%, transparent)`}import{Fragment as Dd,jsx as ao,jsxs as qo}from"react/jsx-runtime";function Ln({element:e,isSelected:t=!1,elementInfo:n,color:r="#3b82f6",annotationNumber:o,changeCount:i,hideTooltip:s=!1}){let[l,a]=Od(null);if(Bd(()=>{if(!e){a(null);return}let O=()=>{let H=e.getBoundingClientRect();a(H)};return O(),window.addEventListener("scroll",O,{passive:!0}),window.addEventListener("resize",O,{passive:!0}),()=>{window.removeEventListener("scroll",O),window.removeEventListener("resize",O)}},[e]),!l||!e)return null;let c={position:"fixed",top:l.top,left:l.left,width:l.width,height:l.height,pointerEvents:"none",zIndex:9996,backgroundColor:t?lo(r,.1):lo(r,.05),overflow:"visible"},d={position:"absolute",width:2,height:2,backgroundColor:r,pointerEvents:"none"},u=e.tagName.toLowerCase(),p=e.id?`#${e.id}`:"",g=e.classList.length>0?"."+Array.from(e.classList).slice(0,2).join("."):"",k=n==null?void 0:n.reactComponent,w=k?`<${k}> ${u}${p}${g}`:`${u}${p}${g}`,b=22,E=l.height>=window.innerHeight,B=E?0:l.top>=b?l.top-b:l.bottom,L=E?{position:"absolute",top:8,left:8,zIndex:9997,display:"flex",alignItems:"center",gap:6,backgroundColor:r,color:"#fff",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',padding:"4px 8px",borderRadius:0,pointerEvents:"none",whiteSpace:"nowrap",maxWidth:400}:{position:"fixed",top:B,left:l.left,zIndex:9997,display:"flex",alignItems:"center",gap:6,backgroundColor:r,color:"#fff",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',padding:"4px 8px",borderRadius:0,pointerEvents:"none",whiteSpace:"nowrap",maxWidth:400},v=!s&&qo("div",{"data-devtools":"tooltip",style:L,children:[o!==void 0&&qo("span",{children:[o,"."]}),ao("span",{style:{overflow:"hidden",textOverflow:"ellipsis",flex:1,minWidth:0},children:w}),i!==void 0&&i>0&&qo("span",{style:{opacity:.8},children:["(",i," ",i===1?"change":"changes",")"]})]});return qo(Dd,{children:[qo("div",{"data-devtools":"highlight",style:c,children:[ao("svg",{style:{position:"absolute",inset:0,width:"100%",height:"100%",overflow:"visible",pointerEvents:"none"},children:ao("rect",f({x:"0.5",y:"0.5",width:Math.max(0,l.width-1),height:Math.max(0,l.height-1),fill:"none",stroke:r,strokeWidth:"1"},!t&&{strokeDasharray:"2 4"}))}),ao("div",{style:y(f({},d),{top:-1,left:-1})}),ao("div",{style:y(f({},d),{top:-1,right:-1})}),ao("div",{style:y(f({},d),{bottom:-1,left:-1})}),ao("div",{style:y(f({},d),{bottom:-1,right:-1})}),E&&v]}),!E&&v]})}import{useEffect as Hl,useLayoutEffect as Nd,useState as Ei}from"react";import{jsx as Dn,jsxs as ki}from"react/jsx-runtime";function Ci(e,t){let n=e.match(/^oklch\(([^)]+)\)$/i);return n?`oklch(${n[1]} / ${t})`:`color-mix(in srgb, ${e} ${Math.round(t*100)}%, transparent)`}function Mi({element:e,gap:t,accentColor:n,hoveredAxis:r,draggingAxis:o,cursorViewport:i,isAutoGap:s=!1,refreshKey:l=0}){let[a,c]=Ei(null),[d,u]=Ei([]),[p,g]=Ei(!1);if(Hl(()=>{let U=S=>{(S.key==="Meta"||S.key==="Control")&&g(!0)},G=S=>{(S.key==="Meta"||S.key==="Control")&&g(!1)},X=()=>g(!1);return window.addEventListener("keydown",U,!0),window.addEventListener("keyup",G,!0),window.addEventListener("blur",X),()=>{window.removeEventListener("keydown",U,!0),window.removeEventListener("keyup",G,!0),window.removeEventListener("blur",X)}},[]),Hl(()=>{if(!e){c(null),u([]);return}let U=()=>{c(e.getBoundingClientRect()),u(ro(e))};return U(),window.addEventListener("scroll",U,{passive:!0}),window.addEventListener("resize",U,{passive:!0}),()=>{window.removeEventListener("scroll",U),window.removeEventListener("resize",U)}},[e]),Nd(()=>{e&&(c(e.getBoundingClientRect()),u(ro(e)))},[e,t.row,t.column,l]),!a||d.length===0)return null;let k=a.width,w=a.height,b="pm-gap-stripe-pattern",E=Ci(n,.25),B=Ci(n,.1),L=Ci(n,.2),T=8,v=2,O={position:"fixed",top:a.top,left:a.left,width:k,height:w,pointerEvents:"none",zIndex:9996,overflow:"visible"},H=o!=null?o:r;return ki("div",{"data-devtools":"gap-handles",style:O,children:[ki("svg",{style:{position:"absolute",inset:0,width:"100%",height:"100%",overflow:"visible",pointerEvents:"none"},viewBox:`0 0 ${k} ${w}`,children:[Dn("defs",{children:Dn("pattern",{id:b,patternUnits:"userSpaceOnUse",width:"4",height:"4",patternTransform:"rotate(45)",children:Dn("line",{x1:"0",y1:"0",x2:"0",y2:"4",stroke:E,strokeWidth:"1.5"})})}),Dn("rect",{x:"0.5",y:"0.5",width:Math.max(0,k-1),height:Math.max(0,w-1),fill:"none",stroke:L,strokeWidth:"1"}),d.map((U,G)=>{let X=U.x-a.left,S=U.y-a.top,I=U.w,K=U.h,ge=p?U.axis===H:!0;return(U.axis==="row"?t.row:t.column)===0?null:ki("g",{opacity:ge?1:.6,children:[Dn("rect",{x:X,y:S,width:I,height:K,fill:B}),Dn("rect",{x:X,y:S,width:I,height:K,fill:`url(#${b})`})]},G)}),H&&(()=>{let U=d.filter(Le=>Le.axis===H);if(U.length===0)return null;let G=U[0];if(i&&U.length>1){let Le=1/0;for(let Ae of U){let _e=Ae.x+Ae.w/2,Pe=Ae.y+Ae.h/2,Me=Math.abs(i.x-_e)+Math.abs(i.y-Pe);Me<Le&&(Le=Me,G=Ae)}}let X=G.x-a.left,S=G.y-a.top,I=G.w,K=G.h,ge=X+I/2,be=S+K/2;if(s)return Dn("circle",{cx:ge,cy:be,r:1.5,fill:n,stroke:"#ffffff",strokeWidth:4,paintOrder:"stroke"});let de=H==="column",ue=de?v:T,Fe=de?T:v,Te=ge-ue/2,ee=be-Fe/2;return Dn("rect",{x:Te,y:ee,width:ue,height:Fe,fill:n,stroke:"#ffffff",strokeWidth:4,paintOrder:"stroke"})})()]}),i&&H&&(()=>{let U=s?"auto":String(Math.round(H==="row"?t.row:t.column));return Dn("div",{style:{position:"fixed",left:i.x+8,top:i.y-28,background:n,color:"#fff",fontSize:11,fontWeight:600,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',lineHeight:1,padding:"4px 4px",borderRadius:0,whiteSpace:"nowrap",pointerEvents:"none",zIndex:9997},children:U})})()]})}import{useCallback as $d,useEffect as Wd,useState as Yd}from"react";import{useEffect as Hd,useState as Fl}from"react";var Fd=3,_d=250,Ti=["reviewing","considering","thinking","zhuzhing","iterating","tweaking","reflecting","noodling","pondering","finessing","polishing","riffing"],zd=3e3;function Mr(e){let[t,n]=Fl(0),[r,o]=Fl(()=>Math.floor(Math.random()*Ti.length));return Hd(()=>{if(!e)return;let i=setInterval(()=>n(l=>(l+1)%Fd),_d),s=setInterval(()=>o(l=>(l+1)%Ti.length),zd);return()=>{clearInterval(i),clearInterval(s)}},[e]),{charIndex:t,word:Ti[r]}}import{Fragment as Ii,jsx as pn,jsxs as Io}from"react/jsx-runtime";function jd(e){let{element:t}=e,n=t.tagName,r=t.id?`#${t.id}`:"",o=t.className?"."+t.className.split(" ").slice(0,2).join("."):"",i=t.reactComponent;return i?`<${i}> ${n}${r}${o}`:`${n}${r}${o}`}var _l=22,Ri=12;function Gd(s){var l=s,{left:e,top:t,avoidBottom:n,style:r,children:o}=l,i=Yn(l,["left","top","avoidBottom","style","children"]);let a=n!==void 0?`${n}px`:"100vh";return pn("div",y(f({"data-devtools":"badge-hit-area"},i),{style:f({position:"fixed",left:`max(0px, ${e}px)`,top:`max(0px, ${t}px)`,padding:Ri,transform:`translate(min(0px, calc(100vw - max(0px, ${e}px) - 100%)), min(0px, calc(${a} - max(0px, ${t}px) - 100%)))`},r),children:o}))}function zl({styleModifications:e,isInspecting:t,accentColor:n,annotationGroupCount:r,dispatch:o,inFlightSelectors:i,toolbarRef:s,onHoverSelector:l}){var B;let[a,c]=Yd([]),d=i&&i.size>0,{charIndex:u,word:p}=Mr(!!d);Wd(()=>{if(t){c([]);return}let L=null,T=()=>{let H=[];e.forEach((U,G)=>{let X=Qt(U.selector);if(!X)return;let S=X.getBoundingClientRect();H.push({selector:U.selector,modIndex:G,top:S.top>=_l?S.top-_l:S.bottom,left:S.left,label:jd(U),changeCount:U.changes.length,annotationNumber:r+G+1})}),c(H)},v=()=>{L&&cancelAnimationFrame(L),L=requestAnimationFrame(T)};T(),window.addEventListener("scroll",v,!0),window.addEventListener("resize",v,!0);let O=new MutationObserver(v);return O.observe(document.body,{attributes:!0,childList:!0,subtree:!0,attributeFilter:["style","class"]}),window.addEventListener("load",v),document.fonts.ready.then(v),()=>{window.removeEventListener("scroll",v,!0),window.removeEventListener("resize",v,!0),window.removeEventListener("load",v),O.disconnect(),L&&cancelAnimationFrame(L)}},[e,t,r]);let g=$d(L=>{let T=e[L];if(!T)return;let v=Qt(T.selector);v&&(o({type:"SELECT_ANNOTATION",payload:{id:null}}),o({type:"SET_TOOL",payload:"inspector"}),o({type:"SELECT_ELEMENT",payload:{el:v,info:T.element}}))},[e,o]);if(a.length===0)return null;let k=(B=s==null?void 0:s.current)==null?void 0:B.getBoundingClientRect(),w=k?k.top-8:void 0,b={display:"flex",alignItems:"center",gap:6,backgroundColor:n,color:"#fff",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',padding:"4px 8px",borderRadius:0,whiteSpace:"nowrap",maxWidth:400},E={overflow:"hidden",textOverflow:"ellipsis",flex:1,minWidth:0};return pn(Ii,{children:a.map(L=>{let T=i==null?void 0:i.has(L.selector);return pn(Gd,{left:L.left-Ri,top:L.top-Ri,avoidBottom:w,onClick:()=>g(L.modIndex),onMouseEnter:l?()=>l(L.selector):void 0,onMouseLeave:l?()=>l(null):void 0,style:{zIndex:1e4,cursor:"pointer",pointerEvents:"auto"},children:Io("div",{"data-devtools":"badge",style:y(f({},b),{backgroundColor:T?"#999999":n}),children:[Io("span",{children:[L.annotationNumber,"."]}),pn("span",{style:E,children:L.label}),Io("span",{style:{opacity:.8},children:["(",L.changeCount," ",L.changeCount===1?"change":"changes",")"]}),T&&Io("span",{style:{opacity:.8,marginLeft:4,display:"inline-flex",alignItems:"center",gap:4},children:[pn("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"currentColor",style:{verticalAlign:"middle"},children:u===1?Io(Ii,{children:[pn("circle",{cx:"7",cy:"7",r:"2"}),pn("circle",{cx:"17",cy:"7",r:"2"}),pn("circle",{cx:"7",cy:"17",r:"2"}),pn("circle",{cx:"17",cy:"17",r:"2"})]}):Io(Ii,{children:[pn("circle",{cx:"12",cy:"6",r:"2"}),pn("circle",{cx:"6",cy:"12",r:"2"}),pn("circle",{cx:"18",cy:"12",r:"2"}),pn("circle",{cx:"12",cy:"18",r:"2"})]})}),p]})]})},L.selector)})})}import{useEffect as Vd,useState as Ud}from"react";import{Fragment as Xd,jsx as $l}from"react/jsx-runtime";function Jd(e,t){let n=e.match(/^oklch\(([^)]+)\)$/i);return n?`oklch(${n[1]} / ${t})`:`color-mix(in srgb, ${e} ${Math.round(t*100)}%, transparent)`}function Wl({styleModifications:e,accentColor:t}){let[n,r]=Ud([]);if(Vd(()=>{let i=null,s=()=>{let c=[];for(let d of e){let u=Qt(d.selector);if(!u)continue;let p=u.getBoundingClientRect();if(p.width===0&&p.height===0)continue;let g=io(u);c.push({selector:d.selector,top:p.top,left:p.left,width:p.width,height:p.height,borderRadius:`${g["top-left"]}px ${g["top-right"]}px ${g["bottom-right"]}px ${g["bottom-left"]}px`})}r(c)},l=()=>{i&&cancelAnimationFrame(i),i=requestAnimationFrame(s)};s(),window.addEventListener("scroll",l,{passive:!0}),window.addEventListener("resize",l,{passive:!0});let a=new MutationObserver(l);return a.observe(document.body,{attributes:!0,childList:!0,subtree:!0,attributeFilter:["style","class"]}),()=>{window.removeEventListener("scroll",l),window.removeEventListener("resize",l),a.disconnect(),i&&cancelAnimationFrame(i)}},[e]),n.length===0)return null;let o=Jd(t,.2);return $l(Xd,{children:n.map(i=>{let s={position:"fixed",top:i.top,left:i.left,width:i.width,height:i.height,pointerEvents:"none",zIndex:9995,border:`1px solid ${o}`,borderRadius:i.borderRadius,boxSizing:"border-box"};return $l("div",{"data-devtools":"mod-border",style:s},i.selector)})})}import{useEffect as Yl,useLayoutEffect as Kd,useState as jl}from"react";import{jsx as Gn,jsxs as Ai}from"react/jsx-runtime";function Li(e,t){let n=e.match(/^oklch\(([^)]+)\)$/i);return n?`oklch(${n[1]} / ${t})`:`color-mix(in srgb, ${e} ${Math.round(t*100)}%, transparent)`}var qd={top:"bottom",bottom:"top",left:"right",right:"left"};function Pi({element:e,padding:t,accentColor:n,hoveredSide:r,draggingSide:o,cursorViewport:i,refreshKey:s}){let[l,a]=jl(null),[c,d]=jl(!1);if(Yl(()=>{let I=be=>{(be.key==="Meta"||be.key==="Control")&&d(!0)},K=be=>{(be.key==="Meta"||be.key==="Control")&&d(!1)},ge=()=>d(!1);return window.addEventListener("keydown",I,!0),window.addEventListener("keyup",K,!0),window.addEventListener("blur",ge),()=>{window.removeEventListener("keydown",I,!0),window.removeEventListener("keyup",K,!0),window.removeEventListener("blur",ge)}},[]),Yl(()=>{if(!e){a(null);return}let I=()=>{a(e.getBoundingClientRect())};return I(),window.addEventListener("scroll",I,{passive:!0}),window.addEventListener("resize",I,{passive:!0}),()=>{window.removeEventListener("scroll",I),window.removeEventListener("resize",I)}},[e]),Kd(()=>{e&&a(e.getBoundingClientRect())},[e,t.top,t.right,t.bottom,t.left,s]),!l)return null;let u=l.width,p=l.height,{top:g,right:k,bottom:w,left:b}=t,E="pm-stripe-pattern",B=Li(n,.25),L=Li(n,.1),T=Li(n,.2),v=8,O=2,H={position:"fixed",top:l.top,left:l.left,width:u,height:p,pointerEvents:"none",zIndex:9996,overflow:"visible"},U=["top","right","bottom","left"],G={top:`0,0 ${u},0 ${u-k},${g} ${b},${g}`,right:`${u},0 ${u},${p} ${u-k},${p-w} ${u-k},${g}`,bottom:`0,${p} ${b},${p-w} ${u-k},${p-w} ${u},${p}`,left:`0,0 ${b},${g} ${b},${p-w} 0,${p}`},X={top:{x:u/2-v/2,y:g/2-O/2,w:v,h:O},bottom:{x:u/2-v/2,y:p-w/2-O/2,w:v,h:O},left:{x:b/2-O/2,y:p/2-v/2,w:O,h:v},right:{x:u-k/2-O/2,y:p/2-v/2,w:O,h:v}},S=new Set;return o?S.add(o):r&&(S.add(r),c||S.add(qd[r])),Ai("div",{"data-devtools":"padding-handles",style:H,children:[Ai("svg",{style:{position:"absolute",inset:0,width:"100%",height:"100%",overflow:"visible",pointerEvents:"none"},viewBox:`0 0 ${u} ${p}`,children:[Gn("defs",{children:Gn("pattern",{id:E,patternUnits:"userSpaceOnUse",width:"4",height:"4",patternTransform:"rotate(45)",children:Gn("line",{x1:"0",y1:"0",x2:"0",y2:"4",stroke:B,strokeWidth:"1.5"})})}),Gn("rect",{x:"0.5",y:"0.5",width:Math.max(0,u-1),height:Math.max(0,p-1),fill:"none",stroke:T,strokeWidth:"1"}),U.map(I=>{if(t[I]<=0)return null;let ge=S.has(I);return Ai("g",{opacity:ge?1:.6,children:[Gn("polygon",{points:G[I],fill:L}),Gn("polygon",{points:G[I],fill:`url(#${E})`})]},I)}),U.map(I=>{let K=X[I],ge=S.has(I);return Gn("rect",{x:K.x,y:K.y,width:K.w,height:K.h,fill:n,stroke:"#ffffff",strokeWidth:ge?4:2,paintOrder:"stroke"},`handle-${I}`)})]}),i&&(r||o)&&(()=>{let I=o!=null?o:r,K=Math.round(t[I]);return Gn("div",{style:{position:"fixed",left:i.x+8,top:i.y-28,background:n,color:"#fff",fontSize:11,fontWeight:600,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',lineHeight:1,padding:"4px 4px",borderRadius:0,whiteSpace:"nowrap",pointerEvents:"none",zIndex:9997},children:K})})()]})}import{useCallback as An,useEffect as Sn,useMemo as Br,useRef as ln,useState as jt}from"react";import{Check as Pr,ChevronDown as zi,MoveHorizontal as na,RotateCcw as wu,Shrink as Eu,X as Cu}from"lucide-react";var Zd="data:image/svg+xml;base64,PHN2ZyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHdpZHRoPScxMicgaGVpZ2h0PScxMic+PGRlZnM+PHBhdHRlcm4gaWQ9J2QnIHdpZHRoPSc0JyBoZWlnaHQ9JzQnIHBhdHRlcm5Vbml0cz0ndXNlclNwYWNlT25Vc2UnPjxwYXRoIGQ9J00tMSwxIGwyLC0yIE0wLDQgbDQsLTQgTTMsNSBsMiwtMicgc3Ryb2tlPSdibGFjaycgc3Ryb2tlLXdpZHRoPScuNScvPjwvcGF0dGVybj48L2RlZnM+PHJlY3Qgd2lkdGg9JzEyJyBoZWlnaHQ9JzEyJyBmaWxsPSd1cmwoI2QpJy8+PC9zdmc+",En={borderWidth:3,borderStyle:"solid",borderImage:`url("${Zd}") 4 / 1.9 / 0 round`};var Tr={"font-size":["rem","px","em"],"line-height":["","rem","px","em"],"letter-spacing":["rem","px","em"],gap:["rem","px","em"],"column-gap":["rem","px","em"],"row-gap":["rem","px","em"],padding:["rem","px","em","%"],margin:["rem","px","em","%"],width:["rem","px","%","em"],height:["rem","px","%","em"],"min-width":["rem","px","%","em"],"max-width":["rem","px","%","em"],"min-height":["rem","px","%","em"],"max-height":["rem","px","%","em"],"border-width":["px","rem","em"],"border-radius":["rem","px","%","em"]};function Ro(e){var t,n;return(n=(t=Tr[e])==null?void 0:t[0])!=null?n:"px"}function Vn(e){let t=e.match(/^([\d.-]+)(.*)$/);return t?{num:parseFloat(t[1]),unit:t[2]||""}:{num:0,unit:""}}function Ir(e,t,n,r){let o=e.trim();if(!o)return"";let i=o.match(/^(-?[\d.]+)\s*(rem|em|px|%)$/i);if(i)return`${parseFloat(i[1])}${i[2].toLowerCase()}`;let s=parseFloat(o);if(!isNaN(s)){if(r){let{unit:l}=Vn(n);return`${s}${l||Ro(t)}`}return`${s}${Ro(t)}`}return o}function Bi(e,t){if(!t||t==="px")return e;if(t==="rem"){let n=parseFloat(getComputedStyle(document.documentElement).fontSize)||16;return Math.round(e/n*1e3)/1e3}return e}import{useCallback as Qd,useEffect as eu,useRef as Gl,useState as tu}from"react";import{Plus as Vl,X as nu}from"lucide-react";import{jsx as sn,jsxs as co}from"react/jsx-runtime";var Rr=[{name:"blur",label:"Blur",unit:"px",defaultValue:10,min:0,max:100,step:1},{name:"brightness",label:"Brightness",unit:"",defaultValue:1,min:0,max:3,step:.05},{name:"contrast",label:"Contrast",unit:"",defaultValue:1,min:0,max:3,step:.05},{name:"saturate",label:"Saturate",unit:"",defaultValue:1,min:0,max:3,step:.05},{name:"grayscale",label:"Grayscale",unit:"",defaultValue:0,min:0,max:1,step:.05},{name:"sepia",label:"Sepia",unit:"",defaultValue:0,min:0,max:1,step:.05},{name:"invert",label:"Invert",unit:"",defaultValue:0,min:0,max:1,step:.05},{name:"hue-rotate",label:"Hue Rotate",unit:"deg",defaultValue:0,min:0,max:360,step:1},{name:"opacity",label:"Opacity",unit:"",defaultValue:1,min:0,max:1,step:.05}];function ou(e){if(!e||e==="none")return[];let t=[],n=/([\w-]+)\(([^)]+)\)/g,r;for(;(r=n.exec(e))!==null;){let o=r[1],i=r[2],s=parseFloat(i);isNaN(s)||t.push({name:o,value:s})}return t}function Oi(e){return e.length===0?"none":e.map(t=>{var o;let n=Rr.find(i=>i.name===t.name),r=(o=n==null?void 0:n.unit)!=null?o:"";return`${t.name}(${t.value}${r})`}).join(" ")}function Ul({value:e,onChange:t,accentColor:n,modified:r,panelContentRef:o}){let i=ou(e),[s,l]=tu(!1),a=Gl(null),c=Gl(null);eu(()=>{if(!s)return;let L=T=>{a.current&&!T.composedPath().includes(a.current)&&l(!1)};return document.addEventListener("mousedown",L,!0),()=>document.removeEventListener("mousedown",L,!0)},[s]);let d=Rr.filter(L=>!i.some(T=>T.name===L.name)),u=L=>{let T=[...i,{name:L.name,value:L.defaultValue}];t(Oi(T)),l(!1)},p=L=>{let T=i.filter((v,O)=>O!==L);t(Oi(T))},g=(L,T)=>{let v=i.map((O,H)=>H===L?y(f({},O),{value:T}):O);t(Oi(v))},k={width:"100%",padding:"4px 8px",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',border:"none",borderRadius:2,outline:"none",backgroundColor:"transparent"},w=Qd(L=>{var S;if(!c.current)return{position:"fixed",top:0,left:0};let T=c.current.getBoundingClientRect(),v=c.current.closest('[data-devtools="panel"]'),O=v?v.getBoundingClientRect():{top:0,left:0,bottom:9999},H=(S=o==null?void 0:o.current)==null?void 0:S.getBoundingClientRect(),U=L*24+8,X=O.bottom-T.bottom<U;return y(f({position:"fixed"},X?{bottom:O.bottom-T.top+2-O.top}:{top:T.bottom+2-O.top}),{left:H?H.left+4-O.left:T.left-O.left,width:H?H.width-8:140,zIndex:10001})},[o]),b={backgroundColor:"rgba(255, 255, 255, 0.95)",backdropFilter:"blur(16px)",WebkitBackdropFilter:"blur(16px)",border:"1px solid rgba(0,0,0,0.1)",borderRadius:4,padding:"4px 0",boxShadow:"0 4px 12px rgba(0,0,0,0.1)"},E={display:"block",width:"100%",padding:"4px 10px",border:"none",backgroundColor:"transparent",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#334155",cursor:"pointer",textAlign:"left"},B=L=>sn("div",{ref:a,style:f(f({},w(L.length)),b),children:L.map(T=>sn("button",{type:"button",onClick:()=>u(T),style:E,onMouseEnter:v=>{v.currentTarget.style.backgroundColor="rgba(0,0,0,0.05)"},onMouseLeave:v=>{v.currentTarget.style.backgroundColor="transparent"},children:T.label},T.name))});return i.length===0?co("div",{children:[co("div",{style:{display:"flex",alignItems:"center",gap:4},children:[sn(Nn,{modified:!1,children:sn("input",{type:"text",value:"",placeholder:"\u2014",readOnly:!0,style:y(f({},k),{color:"#999",cursor:"default"})})}),sn("button",{ref:c,type:"button",onClick:()=>l(!s),style:{display:"flex",alignItems:"center",justifyContent:"center",width:20,height:20,padding:0,border:"none",borderRadius:2,backgroundColor:"transparent",color:"#94a3b8",cursor:"pointer",flexShrink:0},children:sn(Vl,{size:12})})]}),s&&B(Rr)]}):co("div",{style:{display:"flex",flexDirection:"column",gap:4,position:"relative"},children:[i.map((L,T)=>{let v=Rr.find(O=>O.name===L.name);return v?co("div",{style:{display:"flex",alignItems:"center",gap:4},children:[sn("span",{style:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:r?n:"#94a3b8",fontWeight:r?600:400,width:56,flexShrink:0,whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"},children:v.label}),sn(Nn,{modified:r,children:co("div",{style:{display:"flex",alignItems:"center",gap:4,padding:"0 4px"},children:[sn("input",{type:"range",min:v.min,max:v.max,step:v.step,value:L.value,onChange:O=>g(T,parseFloat(O.target.value)),style:{flex:1,height:2,appearance:"none",WebkitAppearance:"none",background:`linear-gradient(to right, ${n} ${(L.value-v.min)/(v.max-v.min)*100}%, rgba(0,0,0,0.1) ${(L.value-v.min)/(v.max-v.min)*100}%)`,borderRadius:1,outline:"none",cursor:"pointer"}}),sn("input",{type:"number",min:v.min,max:v.max,step:v.step,value:v.unit==="px"||v.unit==="deg"?Math.round(L.value):Math.round(L.value*100)/100,onChange:O=>g(T,parseFloat(O.target.value)||0),style:y(f({},k),{width:44,padding:"2px 4px",textAlign:"right",flexShrink:0})}),v.unit&&sn("span",{style:{fontSize:9,color:"#94a3b8",fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',flexShrink:0,width:16},children:v.unit})]})}),sn("button",{type:"button",onClick:()=>p(T),style:{display:"flex",alignItems:"center",justifyContent:"center",width:16,height:16,padding:0,border:"none",borderRadius:2,backgroundColor:"transparent",color:"#94a3b8",cursor:"pointer",flexShrink:0},children:sn(nu,{size:10})})]},L.name):null}),d.length>0&&co("div",{children:[co("button",{ref:c,type:"button",onClick:()=>l(!s),style:{display:"flex",alignItems:"center",gap:4,padding:"2px 4px",border:"none",borderRadius:2,backgroundColor:"transparent",fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#94a3b8",cursor:"pointer"},children:[sn(Vl,{size:10}),"Add filter"]}),s&&B(d)]})]})}import{useCallback as Ao,useEffect as lu,useRef as Lr,useState as Jl}from"react";import{AlignHorizontalSpaceAround as au,AlignVerticalSpaceAround as cu,Columns3 as du,Grid2x2 as uu,RectangleHorizontal as pu,Rows3 as fu,UnfoldHorizontal as Xl,UnfoldVertical as Kl}from"lucide-react";import{useCallback as ru,useEffect as iu,useRef as Zo}from"react";import{jsx as su}from"react/jsx-runtime";var Di=[0,1,2,4,8,12,16,20,24,28,32];function Lo({value:e,onChange:t,onPreview:n,onScrubEnd:r,onReset:o,isModified:i,accentColor:s,defaultUnit:l="rem",snapSteps:a,color:c,style:d,children:u}){let p=Zo(null),g=Zo(null),k=Zo(o),w=Zo(i),b=Zo(!1);k.current=o,w.current=i,iu(()=>{let B=T=>{let v=g.current;if(!v)return;v.hasMoved=!0,b.current=T.shiftKey;let O=v.unit==="rem"||v.unit==="em"?.1:1;v.accum+=T.movementX*O;let H=Math.max(0,Math.round((v.startValue+v.accum)*10)/10);if(T.shiftKey&&a){let U=v.unit==="rem"||v.unit==="em"?parseFloat(getComputedStyle(document.documentElement).fontSize)||16:1,G=v.unit==="rem"||v.unit==="em"?H*U:H,X=a[a.length-1];for(let S=0;S<a.length-1;S++){let I=a[S],K=a[S+1];if(G<=(I+K)/2){X=I;break}if(G<K){X=K;break}}G>a[a.length-1]&&(X=Math.round(G/8)*8),H=v.unit==="rem"||v.unit==="em"?Math.round(X/U*1e3)/1e3:X}n==null||n(`${H}${v.unit}`)},L=()=>{let T=g.current;if(!T)return;let v=Math.max(0,Math.round((T.startValue+T.accum)*10)/10);if(b.current&&a){let H=T.unit==="rem"||T.unit==="em"?parseFloat(getComputedStyle(document.documentElement).fontSize)||16:1,U=T.unit==="rem"||T.unit==="em"?v*H:v,G=a[a.length-1];for(let X=0;X<a.length-1;X++){let S=a[X],I=a[X+1];if(U<=(S+I)/2){G=S;break}if(U<I){G=I;break}}U>a[a.length-1]&&(G=Math.round(U/8)*8),v=T.unit==="rem"||T.unit==="em"?Math.round(G/H*1e3)/1e3:G}let O=T.hasMoved&&v!==T.startValue;g.current=null,document.exitPointerLock(),O?t(`${v}${T.unit}`):T.hasMoved?n==null||n(`${T.startValue}${T.unit}`):w.current&&k.current&&k.current(),r==null||r()};return document.addEventListener("mousemove",B),document.addEventListener("mouseup",L),()=>{document.removeEventListener("mousemove",B),document.removeEventListener("mouseup",L)}},[t,n,r]);let E=ru(B=>{var v;if(B.button!==0)return;B.preventDefault();let L=Vn(e),T=L.unit&&L.unit!=="px"?L.unit:l;g.current={startValue:L.num,unit:T,accum:0,hasMoved:!1},(v=p.current)==null||v.requestPointerLock()},[e,l]);return su("span",{ref:p,onMouseDown:E,title:i?"Click to reset \xB7 Drag to scrub":"Drag to scrub",style:f({color:i?s||"#3b82f6":c||"#999",padding:"0 4px",display:"flex",alignItems:"center",cursor:"ew-resize"},d),children:u})}import{Fragment as Ni,jsx as ke,jsxs as $t}from"react/jsx-runtime";function gu({gridCols:e,gridRows:t,gridModified:n,accentColor:r,onColsChange:o,onRowsChange:i}){return ke(fn,{style:{width:100},children:$t("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",padding:"8px 4px"},children:[ke("input",{type:"number",min:1,max:12,value:e,onChange:s=>o(parseInt(s.target.value)||1),style:y(f({},Yt),{width:32,textAlign:"center",padding:2})}),ke("span",{style:{fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:n?r:"#999",fontWeight:n?600:400,fontSize:11,margin:"0 4px"},children:"\xD7"}),ke("input",{type:"number",min:1,max:12,value:t,onChange:s=>i(parseInt(s.target.value)||1),style:y(f({},Yt),{width:32,textAlign:"center",padding:2})})]})})}function ql({element:e,getValue:t,getOriginalValue:n,handleChange:r,isModified:o,onResetProperty:i,isCollapsed:s,onToggle:l,sectionHeaderStyle:a,activeDropdown:c,onDropdownChange:d,panelContentRef:u,accentColor:p,onFieldHover:g,preferredUnit:k,onUnitCycle:w}){let b=d,E=t("display"),B=t("flex-direction"),L=Zl(E,B),T=E==="flex"||E==="inline-flex",v=E==="grid",O=T||v,H=t("width"),U=t("height"),G=o("width")?H:br(e,"width"),X=o("height")?U:br(e,"height"),S=Hi(H,G),I=Hi(U,X),K=t("min-width"),ge=t("max-width"),be=t("min-height"),de=t("max-height"),ue=Po(t("padding")),Fe=t("gap"),Te=t("row-gap"),ee=t("column-gap"),Le=t("grid-template-columns"),Ae=t("grid-template-rows"),_e=t("overflow"),Pe=Le.split(/\s+/).filter(Z=>Z&&Z!=="none").length||1,Me=Ae.split(/\s+/).filter(Z=>Z&&Z!=="none").length||1,[q,me]=Jl(!1),Ee=c!==null,ye=Ee||q,Ie=Ee?.3:q?.65:1,We=({mode:Z,icon:Re,active:Xe})=>ke("button",{type:"button",onClick:()=>Ql(Z,r),style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center",padding:"6px 8px",border:"none",borderRadius:2,backgroundColor:Xe?lo(p,.15):"transparent",color:Xe?p:"#64748b",cursor:"pointer",fontSize:14},children:Re}),lt=(Z,Re,Xe)=>{Xe==="fixed"?r(Z,Re):r(Z,Ar(Xe,Re))},dt=Z=>{let Re=Po(t("padding")),Xe=Z||"0";r("padding",`${Re.top} ${Xe} ${Re.bottom} ${Xe}`)},W=Z=>{let Re=Po(t("padding")),Xe=Z||"0";r("padding",`${Xe} ${Re.right} ${Xe} ${Re.left}`)},[te,j]=Jl({}),he=Ao((Z,Re)=>Xe=>{Re(Xe),j(cn=>y(f({},cn),{[Z]:Xe}))},[]),xe=Ao(Z=>{j(Re=>{let Xe=f({},Re);return delete Xe[Z],Xe})},[]),Be=Ao(Z=>{let Re=Po(t("padding"));$e(e,"padding",`${Re.top} ${Z} ${Re.bottom} ${Z}`)},[e,t]),Ce=Ao(Z=>{let Re=Po(t("padding"));$e(e,"padding",`${Z} ${Re.right} ${Z} ${Re.left}`)},[e,t]),it=Ao(Z=>Re=>{$e(e,Z,Re)},[e]),qe=B==="column"||B==="column-reverse",Ct=Z=>Z==="center"?1:Z==="flex-end"||Z==="end"?2:0,Nt=Ct(t("justify-content")),et=Ct(t("align-items")),Rt=qe?et:Nt,Ht=qe?Nt:et,bt=Lr(null),wt=Lr({x:0,y:0}),mt=Lr({col:Rt,row:Ht});mt.current={col:Rt,row:Ht};let vt=Ao((Z,Re)=>{let Xe=["flex-start","center","flex-end"];qe?(r("justify-content",Xe[Re]),r("align-items",Xe[Z])):(r("justify-content",Xe[Z]),r("align-items",Xe[Re]))},[qe,r]),en=Lr(vt);en.current=vt,lu(()=>{let Re=Xe=>{let cn=bt.current;if(!cn||!Xe.composedPath().includes(cn))return;Xe.preventDefault(),Xe.stopPropagation(),wt.current.x+=Xe.deltaX,wt.current.y+=Xe.deltaY;let{col:qt,row:pt}=mt.current,tt=!1;Math.abs(wt.current.x)>=30&&(qt=Math.max(0,Math.min(2,qt+(wt.current.x>0?1:-1))),wt.current.x=0,wt.current.y=0,tt=!0),!tt&&Math.abs(wt.current.y)>=30&&(pt=Math.max(0,Math.min(2,pt+(wt.current.y>0?1:-1))),wt.current.x=0,wt.current.y=0,tt=!0),tt&&(qt!==mt.current.col||pt!==mt.current.row)&&en.current(qt,pt)};return document.addEventListener("wheel",Re,{passive:!1,capture:!0}),()=>document.removeEventListener("wheel",Re,{capture:!0})},[]);let Ft=()=>ke("div",{ref:bt,onMouseEnter:()=>{me(!0),u.current&&(u.current.style.overflowY="hidden")},onMouseLeave:()=>{me(!1),u.current&&(u.current.style.overflowY="auto")},style:{width:56,height:56,backgroundColor:kn,borderRadius:2,display:"grid",gridTemplateColumns:"repeat(3, 1fr)",gridTemplateRows:"repeat(3, 1fr)",padding:6,gap:2,touchAction:"none"},children:[0,1,2].map(Z=>[0,1,2].map(Re=>ke("button",{type:"button",onClick:()=>vt(Re,Z),style:{width:"100%",height:"100%",display:"flex",alignItems:"center",justifyContent:"center",border:"none",backgroundColor:"transparent",cursor:"pointer",padding:0},children:Re===Rt&&Z===Ht?ke("svg",{width:"10",height:"10",viewBox:"0 0 10 10",fill:"none",style:{flexShrink:0},children:Re===0?$t(Ni,{children:[ke("rect",{x:"1",y:"1.5",width:"8",height:"1.2",rx:"0.5",fill:p}),ke("rect",{x:"1",y:"4.4",width:"5",height:"1.2",rx:"0.5",fill:p}),ke("rect",{x:"1",y:"7.3",width:"7",height:"1.2",rx:"0.5",fill:p})]}):Re===1?$t(Ni,{children:[ke("rect",{x:"1",y:"1.5",width:"8",height:"1.2",rx:"0.5",fill:p}),ke("rect",{x:"2.5",y:"4.4",width:"5",height:"1.2",rx:"0.5",fill:p}),ke("rect",{x:"1.5",y:"7.3",width:"7",height:"1.2",rx:"0.5",fill:p})]}):$t(Ni,{children:[ke("rect",{x:"1",y:"1.5",width:"8",height:"1.2",rx:"0.5",fill:p}),ke("rect",{x:"4",y:"4.4",width:"5",height:"1.2",rx:"0.5",fill:p}),ke("rect",{x:"2",y:"7.3",width:"7",height:"1.2",rx:"0.5",fill:p})]})}):ke("div",{style:{width:5,height:5,borderRadius:"50%",backgroundColor:"#aaa"}})},`${Z}-${Re}`)))}),an=o("grid-template-columns")||o("grid-template-rows");return $t("div",{style:{borderBottom:"1px solid rgba(0,0,0,0.08)"},children:[ke("div",{style:a,children:ke("span",{children:O?"Auto layout":"Layout"})}),$t("div",{style:{padding:"8px 12px"},children:[$t("div",{style:{display:"flex",gap:2,marginBottom:8,backgroundColor:kn,borderRadius:2,padding:2,opacity:Ie,transition:"opacity 150ms ease"},children:[ke(We,{mode:"block",icon:ke(pu,{size:16}),active:L==="block"}),ke(We,{mode:"flex-col",icon:ke(fu,{size:16}),active:L==="flex-col"}),ke(We,{mode:"flex-row",icon:ke(du,{size:16}),active:L==="flex-row"}),ke(We,{mode:"grid",icon:ke(uu,{size:16}),active:L==="grid"})]}),$t("div",{style:{display:"flex",gap:4,marginBottom:8},children:[ke(Fi,{label:"W",property:"width",cssValue:S==="fixed"?H:`${Math.round(e.getBoundingClientRect().width)}px`,mode:S,onValueChange:Z=>r("width",Z),onModeChange:Z=>{if(Z==="fixed"){let Re=e.getBoundingClientRect();r("width",`${Math.round(Re.width)}px`)}else r("width",Ar(Z,H))},modified:o("width"),dimmed:Ee&&c!=="width",dropdownOpen:c==="width",onDropdownChange:Z=>b(Z?"width":null),panelContentRef:u,accentColor:p,onReset:()=>i("width"),minValue:K!=="none"&&K!=="0px"&&K!=="auto"?K:"",maxValue:ge!=="none"&&ge!=="auto"?ge:"",onMinChange:Z=>r("min-width",Z||"0"),onMaxChange:Z=>r("max-width",Z||"none"),onMinReset:()=>i("min-width"),onMaxReset:()=>i("max-width"),minModified:o("min-width"),maxModified:o("max-width")}),ke(Fi,{label:"H",property:"height",cssValue:I==="fixed"?U:`${Math.round(e.getBoundingClientRect().height)}px`,mode:I,onValueChange:Z=>r("height",Z),onModeChange:Z=>{if(Z==="fixed"){let Re=e.getBoundingClientRect();r("height",`${Math.round(Re.height)}px`)}else r("height",Ar(Z,U))},modified:o("height"),dimmed:Ee&&c!=="height",dropdownOpen:c==="height",onDropdownChange:Z=>b(Z?"height":null),panelContentRef:u,minValue:be!=="none"&&be!=="0px"&&be!=="auto"?be:"",maxValue:de!=="none"&&de!=="auto"?de:"",onMinChange:Z=>r("min-height",Z||"0"),onMaxChange:Z=>r("max-height",Z||"none"),onMinReset:()=>i("min-height"),onMaxReset:()=>i("max-height"),minModified:o("min-height"),maxModified:o("max-height"),accentColor:p,onReset:()=>i("height")})]}),T&&$t("div",{onMouseEnter:()=>g==null?void 0:g("gap"),onMouseLeave:()=>g==null?void 0:g("element"),style:{display:"flex",gap:8,marginBottom:8},children:[ke("div",{style:{opacity:Ee?.3:1,transition:"opacity 150ms ease"},children:Ft()}),$t("div",{style:{flex:1,opacity:Ie,transition:"opacity 150ms ease"},children:[ke("div",{onClick:o("gap")?()=>i("gap"):void 0,title:o("gap")?"Click to reset":void 0,style:{fontSize:9,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:o("gap")?p:"#999",fontWeight:o("gap")?600:400,marginBottom:2,cursor:o("gap")?"pointer":"default"},children:"Gap"}),ke(fn,{dimmed:Ee,children:$t("div",{style:{display:"flex",alignItems:"center"},children:[ke(Lo,{value:Fe,onChange:Z=>{xe("gap"),r("gap",Z)},onPreview:he("gap",it("gap")),onScrubEnd:()=>xe("gap"),onReset:()=>i("gap"),isModified:o("gap"),accentColor:p,defaultUnit:k,children:B==="column"||B==="column-reverse"?ke(Kl,{size:12,strokeWidth:o("gap")?2.5:1.5}):ke(Xl,{size:12,strokeWidth:o("gap")?2.5:1.5})}),ke(Cn,{property:"gap",value:te.gap||Fe,onChange:Z=>r("gap",Z),isModified:o("gap")||"gap"in te,style:y(f({},Yt),{flex:1,minWidth:0}),unitStyle:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999",padding:"0 8px"},preferredUnit:k,onUnitCycle:w})]})})]})]}),v&&$t("div",{onMouseEnter:()=>g==null?void 0:g("gap"),onMouseLeave:()=>g==null?void 0:g("element"),style:{display:"flex",gap:8,marginBottom:8,opacity:Ie,transition:"opacity 150ms ease"},children:[ke(gu,{gridCols:Pe,gridRows:Me,gridModified:an,accentColor:p,onColsChange:Z=>r("grid-template-columns",`repeat(${Z}, 1fr)`),onRowsChange:Z=>r("grid-template-rows",`repeat(${Z}, 1fr)`)}),$t("div",{style:{flex:1,display:"flex",flexDirection:"column",gap:4},children:[ke(fn,{dimmed:Ee,children:$t("div",{style:{display:"flex",alignItems:"center"},children:[ke(Lo,{value:ee||Fe,onChange:Z=>{xe("column-gap"),r("column-gap",Z)},onPreview:he("column-gap",it("column-gap")),onScrubEnd:()=>xe("column-gap"),onReset:()=>i("column-gap"),isModified:o("column-gap"),accentColor:p,defaultUnit:k,children:ke(Xl,{size:12,strokeWidth:o("column-gap")?2.5:1.5})}),ke(Cn,{property:"column-gap",value:te["column-gap"]||ee||Fe,onChange:Z=>r("column-gap",Z),isModified:o("column-gap")||"column-gap"in te,placeholder:"col",style:y(f({},Yt),{flex:1,minWidth:0}),unitStyle:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999",padding:"0 8px"},preferredUnit:k,onUnitCycle:w})]})}),ke(fn,{dimmed:Ee,children:$t("div",{style:{display:"flex",alignItems:"center"},children:[ke(Lo,{value:Te||Fe,onChange:Z=>{xe("row-gap"),r("row-gap",Z)},onPreview:he("row-gap",it("row-gap")),onScrubEnd:()=>xe("row-gap"),onReset:()=>i("row-gap"),isModified:o("row-gap"),accentColor:p,defaultUnit:k,children:ke(Kl,{size:12,strokeWidth:o("row-gap")?2.5:1.5})}),ke(Cn,{property:"row-gap",value:te["row-gap"]||Te||Fe,onChange:Z=>r("row-gap",Z),isModified:o("row-gap")||"row-gap"in te,placeholder:"row",style:y(f({},Yt),{flex:1,minWidth:0}),unitStyle:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999",padding:"0 8px"},preferredUnit:k,onUnitCycle:w})]})})]})]}),O&&$t("div",{onMouseEnter:()=>g==null?void 0:g("padding"),onMouseLeave:()=>g==null?void 0:g("element"),style:{display:"flex",gap:4,marginBottom:8,opacity:Ie,transition:"opacity 150ms ease"},children:[ke(fn,{style:{flex:1},dimmed:Ee,children:$t("div",{style:{display:"flex",alignItems:"center"},children:[ke(Lo,{value:ue.left,onChange:Z=>{xe("padding-h"),dt(Z)},onPreview:he("padding-h",Be),onScrubEnd:()=>xe("padding-h"),onReset:()=>i("padding"),isModified:o("padding"),accentColor:p,defaultUnit:k,snapSteps:Di,children:ke(au,{size:12,strokeWidth:o("padding")?2.5:1.5})}),ke(Cn,{property:"padding",value:te["padding-h"]||ue.left,onChange:Z=>dt(Z),isModified:o("padding")||"padding-h"in te,placeholder:"H pad",style:y(f({},Yt),{flex:1,minWidth:0}),unitStyle:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999",padding:"0 8px"},preferredUnit:k,onUnitCycle:w})]})}),ke(fn,{style:{flex:1},dimmed:Ee,children:$t("div",{style:{display:"flex",alignItems:"center"},children:[ke(Lo,{value:ue.top,onChange:Z=>{xe("padding-v"),W(Z)},onPreview:he("padding-v",Ce),onScrubEnd:()=>xe("padding-v"),onReset:()=>i("padding"),isModified:o("padding"),accentColor:p,defaultUnit:k,snapSteps:Di,children:ke(cu,{size:12,strokeWidth:o("padding")?2.5:1.5})}),ke(Cn,{property:"padding",value:te["padding-v"]||ue.top,onChange:Z=>W(Z),isModified:o("padding")||"padding-v"in te,placeholder:"V pad",style:y(f({},Yt),{flex:1,minWidth:0}),unitStyle:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999",padding:"0 8px"},preferredUnit:k,onUnitCycle:w})]})})]}),$t("label",{style:{display:"flex",alignItems:"center",gap:8,cursor:"pointer",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#64748b",opacity:Ie,transition:"opacity 150ms ease"},children:[ke("input",{type:"checkbox",checked:_e==="hidden",onChange:Z=>r("overflow",Z.target.checked?"hidden":"visible"),style:{margin:0,accentColor:p}}),"Clip content"]})]})]})}import{AlignCenter as mu,AlignJustify as hu,AlignLeft as yu,AlignRight as bu,Baseline as xu,ChevronDown as Su,WholeWord as vu}from"lucide-react";import{jsx as gt,jsxs as Hn}from"react/jsx-runtime";var ea={100:"Thin",200:"Extra Light",300:"Light",400:"Regular",500:"Medium",600:"Semi Bold",700:"Bold",800:"Extra Bold",900:"Black"};function ta({element:e,getValue:t,handleChange:n,isModified:r,onResetProperty:o,isCollapsed:i,onToggle:s,sectionHeaderStyle:l,accentColor:a,colorVariables:c,activeColorDropdown:d,onColorDropdownChange:u,panelContentRef:p,preferredUnit:g,onUnitCycle:k}){var I;let w=t("font-family"),b=t("font-size"),E=t("font-weight"),B=t("line-height"),L=t("letter-spacing"),T=t("text-align"),v=t("color"),O=String(E),H=ea[O]||O,U=Jo(e,v),G=v.includes("var(")?null:Xo(U,c),X=({align:K,icon:ge})=>{let be=T===K;return gt("button",{type:"button",onClick:()=>n("text-align",K),style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center",padding:"6px 8px",border:"none",borderRadius:2,backgroundColor:be?lo(a,.15):"transparent",color:be?a:"#64748b",cursor:"pointer"},children:ge})},S=((I=w.split(",")[0])==null?void 0:I.trim().replace(/^["']|["']$/g,""))||"System";return Hn("div",{style:{borderBottom:"1px solid rgba(0,0,0,0.08)"},children:[gt("div",{style:l,children:gt("span",{children:"Typography"})}),Hn("div",{style:{padding:"8px 12px",display:"flex",flexDirection:"column",gap:4},children:[gt(fn,{children:Hn("div",{style:{display:"flex",alignItems:"center",padding:"6px 8px"},children:[gt("input",{type:"text",value:w,onChange:K=>n("font-family",K.target.value),style:y(f({},Yt),{flex:1,minWidth:0,padding:0,fontWeight:r("font-family")?600:400,color:r("font-family")?a:"inherit"}),title:w}),gt(Su,{size:12,style:{color:"#999",flexShrink:0,marginLeft:4}})]})}),Hn("div",{style:{display:"flex",gap:4},children:[gt(fn,{style:{flex:1},children:gt("select",{value:O,onChange:K=>n("font-weight",K.target.value),style:y(f({},Yt),{padding:"6px 8px",paddingLeft:4,paddingRight:20,cursor:"pointer",fontWeight:r("font-weight")?600:400,color:r("font-weight")?a:"inherit"}),children:Object.entries(ea).map(([K,ge])=>gt("option",{value:K,children:ge},K))})}),gt(fn,{style:{flex:1},children:gt("div",{style:{display:"flex",alignItems:"center",position:"relative"},children:gt(Cn,{property:"font-size",value:b,onChange:K=>n("font-size",K),isModified:r("font-size"),min:1,max:999,style:y(f({},Yt),{padding:"6px 8px",paddingRight:24,fontWeight:r("font-size")?600:400,color:r("font-size")?a:"inherit"}),unitStyle:{position:"absolute",right:8,top:"50%",transform:"translateY(-50%)",fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999"},preferredUnit:g,onUnitCycle:k})})})]}),Hn("div",{style:{display:"flex",gap:4},children:[gt(fn,{style:{flex:1},children:Hn("div",{style:{display:"flex",alignItems:"center",padding:"6px 8px",gap:4},children:[gt(xu,{size:12,style:{color:r("line-height")?a:"#999",flexShrink:0}}),gt(Cn,{property:"line-height",value:B,onChange:K=>n("line-height",K),isModified:r("line-height"),step:.1,min:0,placeholder:"Auto",style:y(f({},Yt),{flex:1,minWidth:0,padding:0,fontWeight:r("line-height")?600:400,color:r("line-height")?a:"inherit"}),showUnit:!1})]})}),gt(fn,{style:{flex:1},children:Hn("div",{style:{display:"flex",alignItems:"center",padding:"6px 8px",gap:4},children:[gt(vu,{size:12,style:{color:r("letter-spacing")?a:"#999",flexShrink:0}}),gt(Cn,{property:"letter-spacing",value:L,onChange:K=>n("letter-spacing",K),isModified:r("letter-spacing"),step:.1,placeholder:"\u2014",style:y(f({},Yt),{flex:1,minWidth:0,padding:0,fontWeight:r("letter-spacing")?600:400,color:r("letter-spacing")?a:"inherit"}),showUnit:!1})]})})]}),Hn("div",{style:{display:"flex",gap:2,backgroundColor:kn,borderRadius:2,padding:2},children:[gt(X,{align:"left",icon:gt(yu,{size:14})}),gt(X,{align:"center",icon:gt(mu,{size:14})}),gt(X,{align:"right",icon:gt(bu,{size:14})}),gt(X,{align:"justify",icon:gt(hu,{size:14})})]}),Hn("div",{style:{display:"flex",alignItems:"center",gap:8,padding:"4px 0"},children:[gt("span",{onClick:r("color")?()=>o("color"):void 0,title:r("color")?"Click to reset":void 0,style:{fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:r("color")?a:"#64748b",fontWeight:r("color")?600:400,cursor:r("color")?"pointer":"default",width:40,flexShrink:0},children:"Color"}),gt("div",{style:{flex:1,minWidth:0},children:gt(_i,{value:v,resolvedValue:U,colorVariables:c,matchingVariable:G,onChange:K=>n("color",K),accentColor:a,modified:r("color"),panelContentRef:p,isDropdownOpen:d==="color",onDropdownChange:K=>u(K?"color":null)})})]})]})]})}import{Fragment as Mu,jsx as ce,jsxs as yt}from"react/jsx-runtime";var oa=[{name:"Background",properties:[{property:"background-color",label:"Color",type:"color"},{property:"opacity",label:"Opacity",type:"number",step:.1,min:0,max:1}]},{name:"Borders",properties:[{property:"border-width",label:"Width",type:"number",min:0,max:20},{property:"border-color",label:"Color",type:"color"},{property:"border-radius",label:"Radius",type:"number",min:0,max:100},{property:"border-style",label:"Style",type:"select",options:["none","solid","dashed","dotted","double"]}]},{name:"Effects",properties:[{property:"box-shadow",label:"Box Shadow",type:"text"},{property:"backdrop-filter",label:"Backdrop Filter",type:"backdrop-filter"},{property:"transform",label:"Transform",type:"text"}]}];function ku(e,t){let n=t.trim().toLowerCase();switch(e){case"opacity":return n==="1";case"border-width":return n==="0px"||n==="0"||n==="medium";case"border-radius":return n==="0px"||n==="0";case"border-style":return n==="none";case"box-shadow":return n==="none";case"backdrop-filter":return n==="none"||n==="";case"letter-spacing":return n==="normal"||n==="0px"||n==="0";case"background-color":return n==="rgba(0, 0, 0, 0)"||n==="transparent";default:return!1}}function Hi(e,t){return!t||e==="auto"||e==="fit-content"||e==="max-content"||e==="min-content"?"hug":e==="100%"||t==="100%"?"fill":"fixed"}function Ar(e,t){switch(e){case"hug":return"fit-content";case"fill":return"100%";case"fixed":{let n=Vn(t);if(typeof n.num=="number"&&!isNaN(n.num)){let r=n.unit==="%"?"px":n.unit||"px";return`${n.num}${r}`}return"auto"}}}function Po(e){let t=e.split(/\s+/).filter(Boolean);return t.length===1?{top:t[0],right:t[0],bottom:t[0],left:t[0]}:t.length===2?{top:t[0],right:t[1],bottom:t[0],left:t[1]}:t.length===3?{top:t[0],right:t[1],bottom:t[2],left:t[1]}:t.length>=4?{top:t[0],right:t[1],bottom:t[2],left:t[3]}:{top:"0px",right:"0px",bottom:"0px",left:"0px"}}function Zl(e,t){return e==="grid"?"grid":e==="flex"||e==="inline-flex"?t==="column"||t==="column-reverse"?"flex-col":"flex-row":"block"}function Ql(e,t){switch(e){case"block":t("display","block");break;case"flex-row":t("display","flex"),t("flex-direction","row");break;case"flex-col":t("display","flex"),t("flex-direction","column");break;case"grid":t("display","grid");break}}var kn="rgba(0, 0, 0, 0.04)",Yt={width:"100%",padding:"4px 8px",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',border:"none",borderRadius:2,outline:"none",backgroundColor:"transparent"};function Fi({label:e,property:t,cssValue:n,mode:r,onValueChange:o,onModeChange:i,modified:s,dimmed:l,dropdownOpen:a,onDropdownChange:c,panelContentRef:d,accentColor:u="#3b82f6",onReset:p,minValue:g,maxValue:k,onMinChange:w,onMaxChange:b,onMinReset:E,onMaxReset:B,minModified:L,maxModified:T}){let v=Vn(n),O=s?v.unit||Ro(t):Ro(t),H=!s&&v.unit&&v.unit!==O?Bi(v.num,O):v.num,[U,G]=jt(!1),[X,S]=jt(String(H)),[I,K]=jt(!1),ge=ln(null),be=ln(null),de=ln(null),ue=ln(!1);Sn(()=>{U||S(String(H))},[H,U]),Sn(()=>{if(!a)return;let Me=me=>{be.current&&!me.composedPath().includes(be.current)&&de.current&&!me.composedPath().includes(de.current)&&(c==null||c(!1))},q=me=>{me.key==="Escape"&&(c==null||c(!1))};return document.addEventListener("mousedown",Me),document.addEventListener("keydown",q),()=>{document.removeEventListener("mousedown",Me),document.removeEventListener("keydown",q)}},[a,c]),Sn(()=>{U&&ge.current&&(ge.current.focus(),ge.current.select())},[U]);let Fe=()=>{let Me=Ir(X,t,n,s);o(Me||`${Math.max(0,parseFloat(X)||0)}${O}`),G(!1)},Te=()=>{if(ue.current){ue.current=!1;return}Fe()},ee=Me=>{if(Me.key==="Enter"){Fe();return}if(Me.key==="Escape"){ue.current=!0,S(String(H)),G(!1);return}if(Me.key==="ArrowUp"||Me.key==="ArrowDown"){Me.preventDefault();let q=Me.key==="ArrowUp"?1:-1,me=Me.shiftKey?8:Me.altKey?.1:1,Ee=parseFloat(X)||0,ye=Math.round(Math.max(0,Ee+q*me)*1e3)/1e3;S(String(ye)),o(`${ye}${O}`)}},Le={fixed:"Fixed",hug:"Hug",fill:"Fill"},Ae={fixed:ce(na,{size:12}),hug:ce(Eu,{size:12}),fill:ce(na,{size:12})},_e=()=>{c==null||c(!a)},Pe=()=>{if(!de.current||!(d!=null&&d.current))return{position:"absolute",top:"100%",left:-4,right:-4,width:"calc(100% + 8px)",marginTop:4};let Me=de.current.getBoundingClientRect(),q=d.current.getBoundingClientRect(),me=d.current.closest('[data-devtools="panel"]'),Ee=me?me.getBoundingClientRect():{top:0,left:0};return{position:"fixed",top:Me.bottom+4-Ee.top,left:q.left+4-Ee.left,width:q.width-8}};return yt("div",{ref:de,onMouseEnter:()=>K(!0),onMouseLeave:()=>K(!1),style:{flex:1,display:"flex",alignItems:"center",position:"relative",borderRadius:2,border:"1px solid",borderColor:U?u:I?"rgba(0,0,0,0.15)":"transparent",backgroundColor:kn,transition:"border-color 100ms ease, opacity 150ms ease",opacity:l?.3:1},children:[ce("span",{onClick:s&&p?p:void 0,title:s?"Click to reset":void 0,style:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:s?u:"#999",fontWeight:s?600:400,padding:"0 8px",flexShrink:0,cursor:s?"pointer":"default"},children:e}),r==="fixed"?U?ce("input",{ref:ge,type:"text",inputMode:"numeric",value:X,onChange:Me=>S(Me.target.value),onKeyDown:ee,onBlur:Te,style:y(f({},Yt),{flex:1,minWidth:0,padding:"4px 2px"})}):ce("span",{onClick:()=>G(!0),style:{flex:1,padding:"4px 2px",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',cursor:"text"},children:H}):ce("span",{style:{flex:1}}),yt("button",{type:"button",onClick:_e,style:{display:"flex",alignItems:"center",gap:2,padding:"4px 8px",border:"none",outline:"none",backgroundColor:"transparent",color:"#999",fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',cursor:"pointer",flexShrink:0},children:[Le[r],ce(zi,{size:12})]}),a&&yt("div",{ref:be,style:y(f({},Pe()),{backgroundColor:"#eaeaea",border:"1px solid rgba(0,0,0,0.1)",borderRadius:0,zIndex:10001,overflow:"hidden",fontSize:12,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace'}),children:[yt("button",{type:"button",onClick:()=>{i("fixed"),c==null||c(!1)},style:{width:"100%",display:"flex",alignItems:"center",gap:8,padding:"10px 12px",border:"none",outline:"none",backgroundColor:r==="fixed"?"#f1f5f9":"transparent",color:"#1e293b",fontWeight:r==="fixed"?600:400,cursor:"pointer",textAlign:"left"},children:[Ae.fixed,yt("span",{children:["Fixed ",t," (",n,")"]}),r==="fixed"&&ce(Pr,{size:14,style:{marginLeft:"auto"}})]}),yt("button",{type:"button",onClick:()=>{i("hug"),c==null||c(!1)},style:{width:"100%",display:"flex",alignItems:"center",gap:8,padding:"10px 12px",border:"none",outline:"none",backgroundColor:r==="hug"?"#f1f5f9":"transparent",color:"#1e293b",fontWeight:r==="hug"?600:400,cursor:"pointer",textAlign:"left"},children:[Ae.hug,ce("span",{children:"Hug contents"}),r==="hug"&&ce(Pr,{size:14,style:{marginLeft:"auto"}})]}),yt("button",{type:"button",onClick:()=>{i("fill"),c==null||c(!1)},style:{width:"100%",display:"flex",alignItems:"center",gap:8,padding:"10px 12px",border:"none",outline:"none",backgroundColor:r==="fill"?"#f1f5f9":"transparent",color:"#1e293b",fontWeight:r==="fill"?600:400,cursor:"pointer",textAlign:"left"},children:[Ae.fill,ce("span",{children:"Fill container"}),r==="fill"&&ce(Pr,{size:14,style:{marginLeft:"auto"}})]}),ce("div",{style:{borderTop:"1px solid rgba(0,0,0,0.08)",margin:"4px 0"}}),yt("div",{style:{padding:"8px 12px",display:"flex",flexDirection:"column",gap:4},children:[yt("div",{style:{display:"flex",alignItems:"center",backgroundColor:kn,borderRadius:2,padding:"4px 8px"},children:[ce("span",{onClick:L?Me=>{Me.stopPropagation(),E==null||E()}:void 0,title:L?"Click to reset":void 0,style:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:L?u:"#999",fontWeight:L?600:400,marginRight:8,flexShrink:0,cursor:L?"pointer":"default"},children:"Min"}),ce("input",{type:"text",value:g||"",placeholder:"\u2014",onChange:Me=>w==null?void 0:w(Me.target.value),onClick:Me=>Me.stopPropagation(),style:y(f({},Yt),{flex:1,minWidth:0,padding:0,textAlign:"right",color:L?u:"inherit",fontWeight:L?600:400})})]}),yt("div",{style:{display:"flex",alignItems:"center",backgroundColor:kn,borderRadius:2,padding:"4px 8px"},children:[ce("span",{onClick:T?Me=>{Me.stopPropagation(),B==null||B()}:void 0,title:T?"Click to reset":void 0,style:{fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:T?u:"#999",fontWeight:T?600:400,marginRight:8,flexShrink:0,cursor:T?"pointer":"default"},children:"Max"}),ce("input",{type:"text",value:k||"",placeholder:"\u2014",onChange:Me=>b==null?void 0:b(Me.target.value),onClick:Me=>Me.stopPropagation(),style:y(f({},Yt),{flex:1,minWidth:0,padding:0,textAlign:"right",color:T?u:"inherit",fontWeight:T?600:400})})]})]})]})]})}function fn({children:e,style:t,dimmed:n}){let[r,o]=jt(!1);return ce("div",{onMouseEnter:()=>o(!0),onMouseLeave:()=>o(!1),style:f({position:"relative",borderRadius:2,border:"1px solid",borderColor:r?"rgba(0,0,0,0.15)":"transparent",backgroundColor:kn,transition:"border-color 100ms ease, opacity 150ms ease",opacity:n?.3:1},t),children:e})}function Nn({children:e}){let[t,n]=jt(!1);return ce("div",{onMouseEnter:()=>n(!0),onMouseLeave:()=>n(!1),style:{position:"relative",borderRadius:2,border:"1px solid",borderColor:t?"rgba(0,0,0,0.15)":"transparent",backgroundColor:kn,transition:"border-color 100ms ease"},children:e})}function Cn({property:e,value:t,onChange:n,isModified:r=!1,step:o=1,min:i,max:s,style:l,placeholder:a,showUnit:c=!0,unitStyle:d,preferredUnit:u,onUnitCycle:p}){let g=Vn(t),k=Ro(e),w=Tr[e],E=u&&w&&w.includes(u)?u:k,B=r&&g.unit||E,L=!r&&g.unit&&g.unit!==B?Bi(g.num,B):g.num,[T,v]=jt(!1),[O,H]=jt(""),U=Te=>{v(!0),H(String(L||"")),requestAnimationFrame(()=>Te.target.select())},G=()=>{if(v(!1),O.trim()){let Te=Ir(O,e,t,r);Te&&n(Te)}},X=Te=>{let ee=Te.target.value;H(ee);let Le=ee.trim(),Ae=Le.match(/^(-?[\d.]+)\s*(rem|em|px|%)$/i),_e=Le.match(/^(-?[\d.]+)$/);if(Ae){let Pe=parseFloat(Ae[1]);isNaN(Pe)||n(`${Pe}${Ae[2].toLowerCase()}`)}else if(_e){let Pe=parseFloat(_e[1]);isNaN(Pe)||n(`${Pe}${B}`)}},S=Te=>{if(Te.key==="Enter"){if(O.trim()){let ee=Ir(O,e,t,r);ee&&n(ee)}Te.target.blur();return}if(Te.key==="ArrowUp"||Te.key==="ArrowDown"){Te.preventDefault();let ee=Te.shiftKey?10:Te.altKey?.1:1,Le=(Te.key==="ArrowUp"?1:-1)*o*ee,Ae=parseFloat(O)||L||0,_e=Math.round((Ae+Le)*1e3)/1e3;i!==void 0&&(_e=Math.max(i,_e)),s!==void 0&&(_e=Math.min(s,_e)),H(String(_e)),n(`${_e}${B}`)}},I=/^-?[\d.]/.test(t.trim()),K=T?O:I?String(L):"",be=T&&/\s*(rem|em|px|%)\s*$/i.test(O)?"":B,de=p&&(be==="rem"||be==="px"),ue={fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999",pointerEvents:"none"},Fe=y(f({},d!=null?d:ue),{pointerEvents:"auto",cursor:"pointer"});return yt(Mu,{children:[ce("input",{type:"text",inputMode:"decimal",value:K,onFocus:U,onBlur:G,onChange:X,onKeyDown:S,placeholder:a,style:l}),c&&be&&ce("span",{style:de?Fe:d!=null?d:ue,onClick:de?p:void 0,title:de?"Click to switch units":void 0,children:be})]})}function _i({value:e,resolvedValue:t,colorVariables:n,matchingVariable:r,onChange:o,accentColor:i="#3b82f6",modified:s,panelContentRef:l,isDropdownOpen:a,onDropdownChange:c}){let[d,u]=jt(!1),p=!e.includes("var(")&&r?r.usage:e,[g,k]=jt(p),[w,b]=jt(!1),[E,B]=jt(!1),[L,T]=jt(!1),v=ln(null),O=ln(null),H=ln(null),U=a!==void 0?a:w,G=c||b,X=An(()=>{if(!H.current)return{position:"fixed",top:0,left:0,width:200};let ee=H.current.getBoundingClientRect(),Le=H.current.closest('[data-devtools="panel"]'),Ae=Le?Le.getBoundingClientRect():{top:0,left:0};if(l!=null&&l.current){let _e=l.current.getBoundingClientRect();return{position:"fixed",top:ee.bottom+4-Ae.top,left:_e.left+4-Ae.left,width:_e.width-8}}return{position:"fixed",top:ee.bottom+4-Ae.top,left:ee.left-Ae.left,width:ee.width}},[l]);Sn(()=>{if(!d){let ee=!e.includes("var(")&&r?r.usage:e;k(ee)}},[e,d,r]),Sn(()=>{if(!U&&!E)return;let ee=Ae=>{H.current&&!Ae.composedPath().includes(H.current)&&(G(!1),B(!1))},Le=Ae=>{Ae.key==="Escape"&&(G(!1),B(!1))};return document.addEventListener("mousedown",ee),document.addEventListener("keydown",Le),()=>{document.removeEventListener("mousedown",ee),document.removeEventListener("keydown",Le)}},[U,E]),Sn(()=>{d&&v.current&&(v.current.focus(),v.current.select())},[d]);let S=Br(()=>{if(!g||g.startsWith("#")||g.startsWith("rgb")||g.startsWith("hsl")||g.startsWith("oklch"))return[];let ee=g.toLowerCase();return n.filter(Le=>Le.name.toLowerCase().includes(ee)||Le.usage.toLowerCase().includes(ee)).slice(0,8)},[g,n]),I=()=>{o(g),u(!1),B(!1)},K=ee=>{k(ee),ee.includes("var")||ee.includes("--")||ee.length>0&&!ee.startsWith("#")?B(!0):B(!1)},ge=ee=>{k(ee.usage),o(ee.usage),G(!1),B(!1),u(!1)},be=()=>{setTimeout(()=>{!U&&!E&&I()},150)},de=ee=>{ee.key==="Enter"?I():ee.key==="Escape"&&(k(e),u(!1),B(!1))},ue=Br(()=>{let ee=t.trim().toLowerCase();if(ee.startsWith("#"))return ee.length===4?`#${ee[1]}${ee[1]}${ee[2]}${ee[2]}${ee[3]}${ee[3]}`:ee.slice(0,7);let Le=ee.match(/rgba?\((\d+),?\s*(\d+),?\s*(\d+)/);if(Le){let _e=parseInt(Le[1],10).toString(16).padStart(2,"0"),Pe=parseInt(Le[2],10).toString(16).padStart(2,"0"),Me=parseInt(Le[3],10).toString(16).padStart(2,"0");return`#${_e}${Pe}${Me}`}let Ae=ee.match(/oklch\(\s*([\d.]+)/);if(Ae){let _e=Math.max(0,Math.min(1,parseFloat(Ae[1]))),Pe=Math.round(_e*255).toString(16).padStart(2,"0");return`#${Pe}${Pe}${Pe}`}return"#000000"},[t]),Fe=ee=>{let Le=ee.target.value;k(Le),o(Le)},Te=e.includes("var(");return yt("div",{ref:H,onMouseEnter:()=>T(!0),onMouseLeave:()=>T(!1),style:{position:"relative",borderRadius:2,border:"1px solid",borderColor:d?i:L?"rgba(0,0,0,0.15)":"transparent",backgroundColor:kn,transition:"border-color 100ms ease",overflow:"hidden"},children:[yt("div",{style:{display:"flex",alignItems:"center",minWidth:0},children:[yt("div",{style:{position:"relative",marginLeft:8,flexShrink:0},children:[ce("input",{type:"color",value:ue,onChange:Fe,style:{width:12,height:12,padding:0,border:"none",cursor:"pointer",opacity:0,position:"absolute",top:0,left:0}}),ce("div",{style:{width:12,height:12,borderRadius:2,backgroundColor:t,border:"1px solid rgba(0,0,0,0.1)",pointerEvents:"none"}})]}),d?ce("input",{ref:v,type:"text",value:g,onChange:ee=>K(ee.target.value),onKeyDown:de,onBlur:be,style:y(f({},Yt),{flex:1,minWidth:0})}):ce("span",{onClick:()=>u(!0),style:{flex:1,minWidth:0,padding:"4px 8px",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',cursor:"text",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",color:s?i:"inherit"},title:p,children:p}),n.length>0&&ce("button",{type:"button",onClick:()=>G(!U),style:{display:"flex",alignItems:"center",justifyContent:"center",width:20,height:24,border:"none",background:"none",cursor:"pointer",color:"#999",flexShrink:0},children:ce(zi,{size:12})})]}),E&&S.length>0&&ce("div",{style:y(f({},X()),{backgroundColor:"#eaeaea",border:"1px solid rgba(0,0,0,0.1)",borderRadius:0,zIndex:10001,maxHeight:200,overflowY:"auto",fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace'}),children:S.map(ee=>yt("button",{type:"button",onClick:()=>ge(ee),style:{width:"100%",display:"flex",alignItems:"center",gap:8,padding:"10px 12px",border:"none",backgroundColor:"transparent",color:"#1e293b",cursor:"pointer",textAlign:"left",fontSize:12},children:[ce("div",{style:{width:14,height:14,borderRadius:2,backgroundColor:ee.value,border:"1px solid rgba(0,0,0,0.1)",flexShrink:0}}),ce("span",{style:{flex:1,overflow:"hidden",textOverflow:"ellipsis"},children:ee.name})]},ee.name))}),U&&ce("div",{ref:O,style:y(f({},X()),{backgroundColor:"#eaeaea",border:"1px solid rgba(0,0,0,0.1)",borderRadius:0,zIndex:10001,maxHeight:280,overflowY:"auto",fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace'}),children:n.map(ee=>yt("button",{type:"button",onClick:()=>ge(ee),style:{width:"100%",display:"flex",alignItems:"center",gap:8,padding:"10px 12px",border:"none",backgroundColor:p===ee.usage||e===ee.usage?"#f1f5f9":"transparent",color:"#1e293b",fontWeight:p===ee.usage||e===ee.usage?600:400,cursor:"pointer",textAlign:"left",fontSize:12},children:[ce("div",{style:{width:14,height:14,borderRadius:2,backgroundColor:ee.value,border:"1px solid rgba(0,0,0,0.1)",flexShrink:0}}),ce("span",{style:{flex:1,overflow:"hidden",textOverflow:"ellipsis"},children:ee.name}),(p===ee.usage||e===ee.usage)&&ce(Pr,{size:14,style:{marginLeft:"auto",flexShrink:0}})]},ee.name))})]})}function ra({element:e,elementInfo:t,selector:n,styleModifications:r,dispatch:o,onClose:i,onHover:s,accentColor:l="#3b82f6",toolbarRef:a}){var lt,dt;let c=ln(null),d=ln(null),[u,p]=jt(()=>{try{return!!localStorage.getItem("devtools-panel-position")}catch(W){return!1}});Sn(()=>{if(u)return;let W=setTimeout(()=>p(!0),50);return()=>clearTimeout(W)},[u]);let[g,k]=jt(null),[w,b]=jt(null),E=g!==null||w!==null,[B,L]=jt("rem"),T=An(()=>{L(W=>W==="rem"?"px":"rem")},[]),v=ln(new Map),[O,H]=jt(""),U=Br(()=>Si(),[]);Sn(()=>{let W=te=>{var he;if(te.key!=="Escape")return;let j=document.activeElement;j&&((he=c.current)!=null&&he.contains(j))||i()};return window.addEventListener("keydown",W),()=>window.removeEventListener("keydown",W)},[i]);let G=ln({top:0,left:0,maxHeight:400}),[,X]=jt(0),S="devtools-panel-position",I=ln({x:0,y:0}),K=ln(null),ge=ln(!1);Sn(()=>{try{let W=localStorage.getItem(S);if(W){let te=JSON.parse(W);typeof te.top=="number"&&typeof te.left=="number"&&(ge.current=!0,G.current=y(f({},G.current),{top:te.top,left:te.left}))}}catch(W){}},[]),Sn(()=>{let W=j=>{var mt;let he=K.current;if(!he)return;let xe=he.startOffsetX+(j.clientX-he.startX),Be=he.startOffsetY+(j.clientY-he.startY),Ce=280,it=16,qe=Math.max(it,Math.min(window.innerWidth-Ce-it,G.current.left+xe)),Ct=Math.max(it,G.current.top+Be);I.current={x:qe-G.current.left,y:Ct-G.current.top};let Nt=c.current,et=Nt==null?void 0:Nt.parentElement;if(!et)return;et.style.top=`${Ct}px`,et.style.left=`${qe}px`;let Rt=(mt=a==null?void 0:a.current)==null?void 0:mt.getBoundingClientRect(),Ht=window.innerHeight-16;Rt&&qe+Ce>Rt.left&&(Ht=Rt.top-8);let bt=Math.max(0,Ct),wt=Math.max(200,Ht-bt);Nt&&(Nt.style.maxHeight=`${wt}px`)},te=()=>{if(!K.current)return;let j=G.current.top+I.current.y,he=G.current.left+I.current.x;G.current=y(f({},G.current),{top:j,left:he}),I.current={x:0,y:0},ge.current=!0;try{localStorage.setItem(S,JSON.stringify({top:j,left:he}))}catch(xe){}K.current=null};return window.addEventListener("mousemove",W),window.addEventListener("mouseup",te),()=>{window.removeEventListener("mousemove",W),window.removeEventListener("mouseup",te)}},[]);let be=An(W=>{W.button!==0||W.target.closest("button")||(W.preventDefault(),K.current={startX:W.clientX,startY:W.clientY,startOffsetX:I.current.x,startOffsetY:I.current.y})},[]);Sn(()=>{I.current={x:0,y:0};let W=(he=!1)=>{var Ht;let xe=c.current,Be=280,Ce=8,it,qe;if(ge.current)it=G.current.top,qe=G.current.left;else{let bt=e.getBoundingClientRect();qe=bt.right+Ce,it=bt.top,qe+Be>window.innerWidth-Ce&&(qe=bt.left-Be-Ce),qe<Ce&&(qe=Math.max(Ce,(window.innerWidth-Be)/2))}let Ct=(Ht=a==null?void 0:a.current)==null?void 0:Ht.getBoundingClientRect(),Nt=window.innerHeight-16;Ct&&qe+Be>Ct.left&&(Nt=Ct.top-Ce);let et=Math.max(0,it),Rt=Math.max(200,Nt-et);if(G.current={top:it,left:qe,maxHeight:Rt},he&&xe){let bt=xe.parentElement;bt&&!ge.current&&(bt.style.top=`${it+I.current.y}px`,bt.style.left=`${qe+I.current.x}px`),xe.style.maxHeight=`${Rt}px`}else X(bt=>bt+1)};W(!1);let te=()=>W(!0),j=()=>W(!1);return window.addEventListener("scroll",te,{passive:!0}),window.addEventListener("resize",j,{passive:!0}),()=>{window.removeEventListener("scroll",te),window.removeEventListener("resize",j)}},[e]),Sn(()=>{let W=c.current;if(!W)return;let te=j=>{let he=d.current;if(!he){j.preventDefault();return}let{scrollTop:xe,scrollHeight:Be,clientHeight:Ce}=he,it=xe<=0&&j.deltaY<0,qe=xe+Ce>=Be&&j.deltaY>0;(it||qe)&&j.preventDefault()};return W.addEventListener("wheel",te,{passive:!1}),()=>W.removeEventListener("wheel",te)},[]);let de=Br(()=>r.find(W=>W.selector===n),[r,n]),ue=An(W=>{let te=de==null?void 0:de.changes.find(j=>j.property===W);if(te)return te.modified;if(W.includes("color")){let j=mi(e,W);if(j&&j.includes("var("))return j}return Go(e,W)},[e,de]),Fe=An(W=>{if(v.current.has(W))return v.current.get(W);let te=de==null?void 0:de.changes.find(he=>he.property===W);if(te)return te.original;let j=Go(e,W);return v.current.set(W,j),j},[e,de]),Te=An((W,te)=>{let j=Fe(W);$e(e,W,te),W==="backdrop-filter"&&$e(e,"-webkit-backdrop-filter",te),o({type:"MODIFY_STYLE",payload:{selector:n,element:t,property:W,original:j,modified:te}})},[e,n,t,o,Fe]),ee=An(()=>{xi(n,r);let W=r.find(te=>te.selector===n);if(W)for(let te of W.changes)o({type:"CLEAR_STYLE",payload:{selector:n,property:te.property}});v.current.clear()},[n,r,o]),Le=An(W=>{let te=r.find(he=>he.selector===n);te!=null&&te.changes.find(he=>he.property===W)&&e instanceof HTMLElement&&(e.style.removeProperty(W),o({type:"CLEAR_STYLE",payload:{selector:n,property:W}}),v.current.delete(W))},[e,n,r,o]),Ae=An(()=>{let W=O.split(";").map(te=>te.trim()).filter(te=>te);for(let te of W){let j=te.indexOf(":");if(j>0){let he=te.slice(0,j).trim(),xe=te.slice(j+1).trim();he&&xe&&Te(he,xe)}}H("")},[O,Te]),_e=An(W=>{var te;return(te=de==null?void 0:de.changes.some(j=>j.property===W))!=null?te:!1},[de]),Pe=W=>{var Be;let te=ue(W.property),j=_e(W.property),he=!j&&ku(W.property,te),xe={width:"100%",padding:"4px 8px",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',border:"none",borderRadius:2,outline:"none",backgroundColor:"transparent"};if(he&&W.type!=="backdrop-filter")return ce(Nn,{modified:!1,children:ce("input",{type:"text",value:"",placeholder:"\u2014",onFocus:()=>{},onChange:Ce=>Te(W.property,Ce.target.value),style:y(f({},xe),{color:"#999"})})});switch(W.type){case"color":{let Ce=Jo(e,te),it=te.includes("var(")?null:Xo(Ce,U);return ce(_i,{value:te,resolvedValue:Ce,colorVariables:U,matchingVariable:it,onChange:qe=>Te(W.property,qe),accentColor:l,modified:j,panelContentRef:d,isDropdownOpen:w===W.property,onDropdownChange:qe=>b(qe?W.property:null)})}case"number":{if(!!Tr[W.property])return ce(Nn,{modified:j,children:ce(Cn,{property:W.property,value:te,onChange:qe=>Te(W.property,qe),isModified:j,min:W.min,max:W.max,step:W.step||1,style:y(f({},xe),{paddingRight:32}),unitStyle:{position:"absolute",right:8,top:"50%",transform:"translateY(-50%)",fontSize:10,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#999"},preferredUnit:B,onUnitCycle:T})});let{num:it}=Vn(te);return ce(Nn,{modified:j,children:ce("input",{type:"number",value:it,min:W.min,max:W.max,step:W.step||1,onChange:qe=>Te(W.property,qe.target.value),style:xe})})}case"select":return ce(Nn,{modified:j,children:yt("div",{style:{position:"relative",display:"flex",alignItems:"center"},children:[ce("select",{value:te,onChange:Ce=>Te(W.property,Ce.target.value),style:y(f({},xe),{cursor:"pointer",paddingLeft:4,paddingRight:24,appearance:"none",WebkitAppearance:"none"}),children:(Be=W.options)==null?void 0:Be.map(Ce=>ce("option",{value:Ce,children:Ce},Ce))}),ce("div",{style:{position:"absolute",right:4,top:"50%",transform:"translateY(-50%)",pointerEvents:"none",color:"#999",display:"flex",alignItems:"center"},children:ce(zi,{size:12})})]})});case"spacing":return ce(Nn,{modified:j,children:ce("input",{type:"text",value:te,onChange:Ce=>Te(W.property,Ce.target.value),placeholder:"e.g., 10px or 10px 20px",style:xe})});case"backdrop-filter":return ce(Ul,{value:te,onChange:Ce=>Te(W.property,Ce),accentColor:l,modified:j,panelContentRef:d});default:return ce(Nn,{modified:j,children:ce("input",{type:"text",value:te,onChange:Ce=>Te(W.property,Ce.target.value),style:xe})})}},Me=(lt=de==null?void 0:de.changes.length)!=null?lt:0,q=(dt=de==null?void 0:de.captured)!=null?dt:!1,me=y(f({position:"fixed",top:G.current.top,left:G.current.left,width:280,maxHeight:G.current.maxHeight,backgroundColor:"rgba(255, 255, 255, 0.85)",backdropFilter:"blur(32px)",WebkitBackdropFilter:"blur(32px)"},En),{zIndex:1e4,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',fontSize:12,overflow:"hidden",display:"flex",flexDirection:"column",opacity:u?1:0,transition:"opacity 150ms ease"}),Ee={display:"flex",alignItems:"center",justifyContent:"space-between",margin:"3px 3px 0",padding:"8px 7px 8px 12px",borderBottom:"1px solid rgba(0,0,0,0.1)",backgroundColor:"#f8fafc",cursor:K.current?"grabbing":"grab"},ye={display:"flex",alignItems:"center",justifyContent:"space-between",padding:"12px 12px 6px",userSelect:"none",fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',fontWeight:600,color:"#475569"},Ie={display:"flex",alignItems:"center",padding:"4px 12px",gap:8},We={width:80,fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',color:"#64748b",flexShrink:0};return ce("div",{"data-devtools":"panel-wrapper",style:{position:"fixed",top:G.current.top+I.current.y,left:G.current.left+I.current.x,zIndex:1e4,pointerEvents:"none"},children:yt("div",{ref:c,"data-devtools":"panel",style:y(f({},me),{position:"relative",top:0,left:0,zIndex:0,pointerEvents:"auto"}),onMouseEnter:()=>s==null?void 0:s("element"),onMouseLeave:()=>s==null?void 0:s(null),children:[yt("div",{style:Ee,onMouseDown:be,children:[yt("div",{style:{display:"flex",alignItems:"center",gap:8,overflow:"hidden"},children:[ce("span",{style:{fontWeight:600,fontSize:11,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:t.tagName}),Me>0&&ce("span",{style:{backgroundColor:q?"#999999":l,color:"#fff",fontSize:9,padding:"1px 4px",borderRadius:2},children:Me})]}),yt("div",{style:{display:"flex",gap:4},children:[Me>0&&ce("button",{type:"button",onClick:ee,title:"Reset all changes",style:{display:"flex",alignItems:"center",justifyContent:"center",width:24,height:24,border:"none",background:"none",cursor:"pointer",color:"#64748b",borderRadius:2},children:ce(wu,{size:14})}),ce("button",{type:"button",onClick:i,title:"Close",style:{display:"flex",alignItems:"center",justifyContent:"center",width:24,height:24,border:"none",background:"none",cursor:"pointer",color:"#64748b",borderRadius:2},children:ce(Cu,{size:14})})]})]}),yt("div",{ref:d,style:{flex:1,overflowY:"auto",margin:"0 3px 3px"},children:[ce("div",{style:{opacity:w?.3:1,transition:"opacity 150ms ease"},children:ce(ql,{element:e,getValue:ue,getOriginalValue:Fe,handleChange:Te,isModified:_e,onResetProperty:Le,isCollapsed:!1,onToggle:()=>{},sectionHeaderStyle:ye,activeDropdown:g,onDropdownChange:k,panelContentRef:d,accentColor:l,onFieldHover:s,preferredUnit:B,onUnitCycle:T})}),ce("div",{style:{opacity:g?.3:1,transition:"opacity 150ms ease"},children:ce(ta,{element:e,getValue:ue,handleChange:Te,isModified:_e,onResetProperty:Le,isCollapsed:!1,onToggle:()=>{},sectionHeaderStyle:ye,accentColor:l,colorVariables:U,activeColorDropdown:w,onColorDropdownChange:b,panelContentRef:d,preferredUnit:B,onUnitCycle:T})}),oa.map((W,te)=>{let j=te===oa.length-1,he=w&&W.properties.some(Be=>Be.property===w);return yt("div",{style:{borderBottom:j?"none":"1px solid rgba(0,0,0,0.08)",opacity:E&&!he?.3:1,transition:"opacity 150ms ease"},children:[ce("div",{style:ye,children:ce("span",{children:W.name})}),ce("div",{style:{padding:"4px 0"},children:W.properties.map(Be=>{let Ce=_e(Be.property),it=he&&Be.property!==w;return yt("div",{style:y(f({},Ie),{opacity:it?.3:1,transition:"opacity 150ms ease"}),children:[ce("span",{onClick:Ce?()=>Le(Be.property):void 0,title:Ce?"Click to reset":void 0,style:y(f({},We),{color:Ce?l:"#64748b",fontWeight:Ce?600:400,cursor:Ce?"pointer":"default"}),children:Be.label}),ce("div",{style:{flex:1,minWidth:0,overflow:"hidden"},children:Pe(Be)})]},Be.property)})})]},W.name)}),yt("div",{style:{opacity:E?.3:1,transition:"opacity 150ms ease"},children:[ce("div",{style:ye,children:ce("span",{children:"Raw CSS"})}),yt("div",{style:{padding:"8px 12px"},children:[ce("textarea",{value:O,onChange:W=>H(W.target.value),placeholder:"property: value; ...",style:{width:"100%",height:60,padding:8,fontSize:11,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',border:"1px solid rgba(0,0,0,0.1)",borderRadius:2,resize:"vertical",outline:"none"}}),O.trim()&&ce("button",{type:"button",onClick:Ae,style:{marginTop:4,padding:"4px 8px",width:"100%",fontSize:11,border:"none",borderRadius:2,backgroundColor:l,color:"#fff",cursor:"pointer",opacity:O.trim()?1:.5},children:"Apply"})]})]})]})]})})}import{useEffect as Tu,useLayoutEffect as Iu,useState as Ru}from"react";import{Fragment as Bu,jsx as uo,jsxs as Pu}from"react/jsx-runtime";var $i=["flex-start","center","flex-end"],Wi=["flex-start","center","flex-end"];function Lu(e){return e==="normal"||e==="flex-start"||e==="start"?"flex-start":e==="flex-end"||e==="end"?"flex-end":e==="center"?"center":null}function Au(e){return e==="normal"||e==="stretch"||e==="flex-start"||e==="start"?"flex-start":e==="flex-end"||e==="end"?"flex-end":e==="center"?"center":null}function ia(e){let t=Array.from(e.children);if(t.length===0)return null;let n=1/0,r=1/0,o=-1/0,i=-1/0;for(let s of t){let l=s.getBoundingClientRect();l.width===0&&l.height===0||(l.top<n&&(n=l.top),l.left<r&&(r=l.left),l.bottom>o&&(o=l.bottom),l.right>i&&(i=l.right))}return n===1/0?null:new DOMRect(r,n,i-r,o-n)}function sa({element:e,modifier:t,accentColor:n,refreshKey:r=0}){let[o,i]=Ru(null);if(Tu(()=>{if(!e){i(null);return}let w=()=>i(ia(e));return w(),window.addEventListener("scroll",w,{passive:!0}),window.addEventListener("resize",w,{passive:!0}),()=>{window.removeEventListener("scroll",w),window.removeEventListener("resize",w)}},[e]),Iu(()=>{e&&i(ia(e))},[e,r]),!o)return null;let s=o,l=window.getComputedStyle(e),a=l.display;if(a!=="flex"&&a!=="inline-flex")return null;let c=l.flexDirection,d=c==="column"||c==="column-reverse"?"vertical":"horizontal",u=d==="horizontal"?"vertical":"horizontal",p=[];if(t==="shift"){let w=Lu(l.justifyContent);if(w){let b=$i.indexOf(w);d==="horizontal"?(b>0&&p.push("left"),b<$i.length-1&&p.push("right")):(b>0&&p.push("up"),b<$i.length-1&&p.push("down"))}}else{let w=Au(l.alignItems);if(w){let b=Wi.indexOf(w);u==="horizontal"?(b>0&&p.push("left"),b<Wi.length-1&&p.push("right")):(b>0&&p.push("up"),b<Wi.length-1&&p.push("down"))}}if(p.length===0)return null;let g=14,k=7;return uo(Bu,{children:p.map(w=>{let b,E;switch(w){case"right":b=s.right+g,E=s.top+s.height/2;break;case"left":b=s.left-g,E=s.top+s.height/2;break;case"down":b=s.left+s.width/2,E=s.bottom+g;break;case"up":b=s.left+s.width/2,E=s.top-g;break}let B=w==="right"?0:w==="left"?180:w==="down"?90:-90,L={position:"fixed",left:b-k,top:E-k,width:k*2,height:k*2,pointerEvents:"none",zIndex:9997};return uo("div",{"data-devtools":"swipe-hint",style:L,children:uo("svg",{width:k*2,height:k*2,viewBox:"-7 -7 14 14",style:{overflow:"visible"},children:Pu("g",{transform:`rotate(${B})`,children:[uo("line",{x1:"-5",y1:"0",x2:"3",y2:"0",stroke:"#fff",strokeWidth:"4",strokeLinecap:"round"}),uo("polyline",{points:"0,-4 5,0 0,4",fill:"none",stroke:"#fff",strokeWidth:"4",strokeLinecap:"round",strokeLinejoin:"round"}),uo("line",{x1:"-5",y1:"0",x2:"3",y2:"0",stroke:n,strokeWidth:"1.5",strokeLinecap:"round"}),uo("polyline",{points:"0,-4 5,0 0,4",fill:"none",stroke:n,strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})]})})},w)})})}import{useEffect as Ou,useLayoutEffect as Du,useState as Nu}from"react";import{jsx as Yi,jsxs as ji}from"react/jsx-runtime";function Hu(e,t){let n=e.match(/^oklch\(([^)]+)\)$/i);return n?`oklch(${n[1]} / ${t})`:`color-mix(in srgb, ${e} ${Math.round(t*100)}%, transparent)`}function la({element:e,fontSize:t,lineHeight:n,accentColor:r,hoveredProperty:o,draggingProperty:i,cursorViewport:s}){let[l,a]=Nu(null);if(Ou(()=>{if(!e){a(null);return}let E=()=>{a(Mo(e))};return E(),window.addEventListener("scroll",E,{passive:!0}),window.addEventListener("resize",E,{passive:!0}),()=>{window.removeEventListener("scroll",E),window.removeEventListener("resize",E)}},[e]),Du(()=>{e&&a(Mo(e))},[e,t,n]),!l)return null;let c=l.width,d=l.height,u=Hu(r,.2),p=i!=null?i:o,g=8,k=2,w={position:"fixed",top:l.top,left:l.left,width:c,height:d,pointerEvents:"none",zIndex:9996,overflow:"visible"},b=E=>E==="font-size"?`${Math.round(t)}`:(t>0?n/t:1.2).toFixed(2).replace(/\.?0+$/,"");return ji("div",{"data-devtools":"text-handles",style:w,children:[ji("svg",{style:{position:"absolute",inset:0,width:"100%",height:"100%",overflow:"visible",pointerEvents:"none"},viewBox:`0 0 ${c} ${d}`,children:[Yi("rect",{x:"0.5",y:"0.5",width:Math.max(0,c-1),height:Math.max(0,d-1),fill:"none",stroke:u,strokeWidth:"1"}),(p==="font-size"||!p)&&Yi("rect",{x:c-k/2,y:d/2-g/2,width:k,height:g,fill:r,stroke:"#ffffff",strokeWidth:p==="font-size"?4:2,paintOrder:"stroke"}),(p==="line-height"||!p)&&Yi("rect",{x:c/2-g/2,y:d-k/2,width:g,height:k,fill:r,stroke:"#ffffff",strokeWidth:p==="line-height"?4:2,paintOrder:"stroke"})]}),s&&p&&(()=>{let E=p==="font-size"?"Aa":"Lh",B=b(p);return ji("div",{style:{position:"fixed",left:s.x+8,top:s.y-28,background:r,color:"#fff",fontSize:11,fontWeight:600,fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',lineHeight:1,padding:"4px 4px",borderRadius:0,whiteSpace:"nowrap",pointerEvents:"none",zIndex:9997},children:[E," ",B]})})()]})}import{Fragment as Oo,jsx as rt,jsxs as Bo}from"react/jsx-runtime";var aa=8,Vi=[0,1,2,4,8,12,16,20,24,28,32],Ui="devtools-active-text";function ca(e,t,n=0,r,o){let i=e.left+window.scrollX+4,s=t==="top-left"?e.top+window.scrollY-bn-n*bn+4:e.bottom+window.scrollY+4-1+n*bn,l=window.scrollY+4,a=window.scrollY+window.innerHeight-bn-4,c=90,d=!1;if(r&&o!==void 0){let u=r.getBoundingClientRect();if(e.left+4+o+4+c>u.left){let g=window.scrollY+u.top-bn-4;g<a&&(a=g,d=!0)}}return s<l?s=e.top+window.scrollY+4:s>a&&(s=d?a:Math.max(e.top+window.scrollY+4,a)),{x:i,y:s}}function da({state:e,dispatch:t,onScreenshot:n,inFlightAnnotationIds:r,inFlightStyleSelectors:o,inFlightSelectorColors:i,onAttachImages:s,onReply:l,onViewThread:a,onCloseThread:c,onModelComponentsAdd:d,onModelComponentFocus:u,onModelComponentHover:p,modelComponentNames:g,modelPanelHoveredComponent:k,modelSpacingTokenHover:w,highlightedAnnotationIds:b,focusedThreadAnnotationId:E,externalCanvasRef:B,toolbarRef:L}){var Ms,Ts,Is,Rs,Ls,As,Ps,Bs,Os;let{canvasRef:T,redrawAll:v,resizeCanvas:O}=pl(),H=Pt(m=>{T.current=m,B&&(B.current=m)},[B,T]),U=Tt(!1);Jt(()=>{let m=T.current;if(!m)return;let h=()=>{U.current&&(U.current=!1,m.style.pointerEvents="")},V=M=>{M.button===0&&U.current&&h()};return window.addEventListener("mousedown",V),()=>window.removeEventListener("mousedown",V)},[T]);let[G,X]=ct(!1),[S,I]=ct(()=>{if(typeof window=="undefined")return null;try{let m=localStorage.getItem(Ui);return m?JSON.parse(m):null}catch(m){return null}}),[K,ge]=ct(null),[be,de]=ct(null),[ue,Fe]=ct(null),Te=Tt(null),ee=Tt(null),Le=Tt({x:0,y:0}),Ae=Tt([]),_e=Tt(0),[Pe,Me]=ct(null),[q,me]=ct(new Map),Ee=Tt(0),ye=Tt(null),[Ie,We]=ct(null),[lt,dt]=ct(null),[W,te]=ct(null),[j,he]=ct(null),xe=Tt({isDragging:!1,side:null,startX:0,startY:0,original:{top:0,right:0,bottom:0,left:0},element:null,elementInfo:null,selector:null,durableSelector:null}),[Be,Ce]=ct(null),[it,qe]=ct(null),[Ct,Nt]=ct(null),[et,Rt]=ct(null),Ht=Tt({x:0,y:0}),[bt,wt]=ct({x:0,y:0}),mt=Tt({isDragging:!1,hasMoved:!1,axis:null,startX:0,startY:0,originalRow:0,originalColumn:0,element:null,elementInfo:null,selector:null,durableSelector:null,isAuto:!1,originalJustifyContent:"",visualGap:0}),[vt,en]=ct(null),[Ft,an]=ct(null),[ut,Z]=ct(null),[Re,Xe]=ct(!1),[cn,qt]=ct(0),[pt,tt]=ct(null),Ut=Tt({isDragging:!1,corner:null,startY:0,original:{"top-left":0,"top-right":0,"bottom-right":0,"bottom-left":0},maxRadius:0,element:null,elementInfo:null,selector:null,durableSelector:null}),[kt,Jn]=ct(null),[dn,Pn]=ct(null),[F,ne]=ct(null),oe=Tt({isDragging:!1,property:null,startX:0,startY:0,originalFontSize:0,originalLineHeight:0,originalRatio:1.2,element:null,elementInfo:null,selector:null,durableSelector:null}),[Se,Oe]=ct(null),[pe,xt]=ct(null),[Je,Tn]=ct(null),P=fl(),Q=Tt(i);Q.current=i;let se=Pt(m=>{let h=Q.current;if(!h||h.size===0)return!1;for(let V of h.keys())try{if(m.matches(V))return!0}catch(M){}return!1},[]),fe=Tt(e);fe.current=e;let He=Tt(S);He.current=S;let Ze=Tt([]),at=Tt(n);at.current=n;let[Ne,je]=ct(null),nt=e.selectedAnnotationIds;Ze.current=nt;let Lt=Pt((m,h=!1)=>{t({type:"SELECT_ANNOTATION",payload:{id:m,addToSelection:h}})},[t]),on=Pt(()=>{t({type:"SELECT_ANNOTATION",payload:{id:null}})},[t]),[hn,$n]=ct(null),[Zt,Yr]=ct({x:window.scrollX,y:window.scrollY});Jt(()=>(O(),window.addEventListener("resize",O),()=>window.removeEventListener("resize",O)),[O]),Jt(()=>{let m=()=>{Yr({x:window.scrollX,y:window.scrollY})};return window.addEventListener("scroll",m,{passive:!0}),()=>window.removeEventListener("scroll",m)},[]),Jt(()=>{S?localStorage.setItem(Ui,JSON.stringify(S)):localStorage.removeItem(Ui)},[S]),gl(S,I,K,e.annotations,t);let yn=Tt(Pe);yn.current=Pe,Jt(()=>{if(e.activeTool!=="model"||!e.isAnnotating)return;let m=h=>{if(!h.altKey||!yn.current)return;h.preventDefault();let V=h.deltaY>0?-1:1;Ee.current=Math.max(0,Ee.current+V);let M=ye.current;if(M){let A=hr(M,Ee.current);Me(A)}};return window.addEventListener("wheel",m,{passive:!1}),()=>window.removeEventListener("wheel",m)},[e.activeTool,e.isAnnotating]),Jt(()=>{e.activeTool!=="model"&&(Me(null),me(new Map),Ee.current=0,ye.current=null)},[e.activeTool]),Jt(()=>{var V;let m=(V=Pe==null?void 0:Pe.name)!=null?V:null,h=m&&(g!=null&&g.has(m))?m:null;p==null||p(h)},[Pe,g,p]);let[rr,ys]=ct(null);Jt(()=>{var V;if(!k){ys(null);return}let m=Eo(k.name),h=k.instanceIndex;ys((V=m[h%m.length])!=null?V:null)},[k]);let[bs,jr]=ct([]);Jt(()=>{var m,h;if(!w){jr([]);return}(h=(m=w.token)==null?void 0:m.bindings)!=null&&h.length?jr(fi(w.token)):jr(ui(w.px))},[w]);let Ua=Tt(null),Ja=Tt(null);Ua.current=vt,Ja.current=Ft,Jt(()=>{let m=["flex-start","center","flex-end"],h=["flex-start","center","flex-end"],M=null,A=!1,z=null,ie=null,N=(ae,we)=>{let Ve=oo(ae,we);for(;Ve&&Ve!==document.documentElement;){let ft=window.getComputedStyle(Ve).display;if(ft==="flex"||ft==="inline-flex")return Ve;Ve=Ve.parentElement}return null},J=ae=>{let we=window.getComputedStyle(ae).flexDirection;return we==="column"||we==="column-reverse"?"vertical":"horizontal"},x=ae=>{let we=ae.getAttribute("data-pm");return we||(we=Math.random().toString(36).substring(2,8),ae.setAttribute("data-pm",we)),{selector:`[data-pm="${we}"]`,durableSelector:un(ae)}},C=()=>{A=!0,M&&clearTimeout(M),M=setTimeout(()=>{A=!1,M=null},300)},Y=(ae,we,Ke)=>{let Ve=J(ae);if(we===Ve){let ze=window.getComputedStyle(ae).justifyContent,ht=ze==="normal"||ze==="flex-start"||ze==="start"?"flex-start":ze==="flex-end"||ze==="end"?"flex-end":ze==="center"?"center":null;if(!ht)return;let _t=m.indexOf(ht)+Ke;if(_t<0||_t>=m.length)return;let On=m[_t],{selector:Kn,durableSelector:Vr}=x(ae);$e(ae,"justify-content",On),t({type:"MODIFY_STYLES_BATCH",payload:{selector:Kn,durableSelector:Vr,element:nn(ae),changes:[{property:"justify-content",original:ze,modified:On}]}})}else{let ze=window.getComputedStyle(ae).flexDirection,ht=Ve==="horizontal"?"column":"row",{selector:vn,durableSelector:_t}=x(ae);$e(ae,"flex-direction",ht),t({type:"MODIFY_STYLES_BATCH",payload:{selector:vn,durableSelector:_t,element:nn(ae),changes:[{property:"flex-direction",original:ze,modified:ht}]}})}qt(ft=>ft+1)},R=(ae,we,Ke)=>{let ft=J(ae)==="horizontal"?"vertical":"horizontal";if(we!==ft)return;let ht=window.getComputedStyle(ae).alignItems,vn=ht==="normal"||ht==="stretch"||ht==="flex-start"||ht==="start"?"flex-start":ht==="flex-end"||ht==="end"?"flex-end":ht==="center"?"center":null;if(!vn)return;let On=h.indexOf(vn)+Ke;if(On<0||On>=h.length)return;let Kn=h[On],{selector:Vr,durableSelector:rc}=x(ae);$e(ae,"align-items",Kn),t({type:"MODIFY_STYLES_BATCH",payload:{selector:Vr,durableSelector:rc,element:nn(ae),changes:[{property:"align-items",original:ht,modified:Kn}]}}),qt(ic=>ic+1)},D=20,_=null,$=null,le=0,ve=(ae,we,Ke)=>{let Ve=N(we,Ke);tt(Ve?{modifier:ae,target:Ve}:null)},ot=ae=>{if(!(e.activeTool!=="hand"||!e.isAnnotating)){if(ae.key==="Shift"&&!ae.altKey){let we=Ht.current;ve("shift",we.x,we.y)}else if(ae.key==="Alt"&&!ae.shiftKey){let we=Ht.current;ve("alt",we.x,we.y)}}},st=ae=>{if(e.activeTool!=="hand"||!e.isAnnotating)return;let we=ae.shiftKey&&!ae.altKey,Ke=ae.altKey&&!ae.shiftKey;if(!we&&!Ke||ae.buttons!==0){_=null,$=null,le=0,z=null,ie=null,tt(null);return}if(z===null&&(z=ae.clientX,ie=ae.clientY,ve(we?"shift":"alt",ae.clientX,ae.clientY)),A)return;_===null&&(_=ae.clientX,$=ae.clientY,le=0);let Ve=ae.clientX-_,ft=ae.clientY-$,ze=Math.abs(Ve)>=Math.abs(ft)?Ve:ft;if(Math.abs(ze)>3){let Kn=ze>0?1:-1;if(le!==0&&Kn!==le){_=ae.clientX,$=ae.clientY,le=0;return}le=Kn}if(Math.abs(Ve)<D&&Math.abs(ft)<D)return;let ht=N(z,ie);if(!ht)return;let vn=Math.abs(Ve)>=Math.abs(ft)?"horizontal":"vertical",On=(vn==="horizontal"?Ve:ft)>0?1:-1;_=null,$=null,le=0,we?Y(ht,vn,On):R(ht,vn,On),C()},Mt=ae=>{(ae.key==="Shift"||ae.key==="Alt")&&(z=null,ie=null,_=null,$=null,le=0,tt(null))},Ge=()=>{tt(null),_=null,$=null,le=0};return window.addEventListener("keydown",ot),window.addEventListener("mousemove",st),window.addEventListener("mousedown",Ge),window.addEventListener("keyup",Mt),()=>{window.removeEventListener("keydown",ot),window.removeEventListener("mousemove",st),window.removeEventListener("mousedown",Ge),window.removeEventListener("keyup",Mt),M&&clearTimeout(M)}},[e.activeTool,e.isAnnotating,t]),Jt(()=>{let m=h=>{var z,ie,N,J;if(h.key==="Escape"){if(He.current)return;if(e.activeTool==="model"&&q.size>0){h.preventDefault(),me(new Map);return}if(Ze.current.length>0){h.preventDefault(),on();return}}if(h.key==="Enter"&&e.activeTool==="model"&&q.size>0&&d){h.preventDefault();let x=[...q.keys()].filter(C=>!(g!=null&&g.has(C)));x.length>0&&d(x),me(new Map);return}if((h.metaKey||h.ctrlKey)&&h.key==="v"&&Ae.current.length>0&&!He.current){h.preventDefault(),_e.current++;let x=_e.current*20,Y=((z=Ae.current[0])==null?void 0:z.groupId)?Math.random().toString(36).substring(2,9):void 0,R=Ae.current.map(_=>y(f({},_),{id:Math.random().toString(36).substring(2,9),groupId:_.groupId?Y:void 0,timestamp:Date.now(),points:_.points.map($=>({x:$.x+x,y:$.y+x}))}));t({type:"PASTE_ANNOTATIONS",payload:{annotations:R}});let D=R.find(_=>_.type!=="text")||R[0];D&&Lt(D.id);return}let V=Ze.current;if(V.length===0||He.current)return;let M=(N=(ie=h.composedPath)==null?void 0:ie.call(h)[0])!=null?N:h.target,A=M==null?void 0:M.tagName;if(!(A==="INPUT"||A==="TEXTAREA"||M!=null&&M.isContentEditable)&&(h.key==="Delete"||h.key==="Backspace")){if(h.preventDefault(),c){let x=fe.current.annotations;for(let C of V){let Y=x.find(D=>D.id===C);if(!Y)continue;let R=Y.threadId||Y.groupId&&((J=x.find(D=>D.groupId===Y.groupId&&D.threadId))==null?void 0:J.threadId);R&&c(R)}}for(let x of V)t({type:"DELETE_ANNOTATION",payload:{id:x}});on()}};return window.addEventListener("keydown",m),()=>window.removeEventListener("keydown",m)},[t,on,Lt,e.activeTool,q,g,d,c]);let Wn=Gi(()=>kr(e.annotations),[e.annotations]),ir=Gi(()=>{let m=new Map,h=new Set,V=1;for(let M of e.annotations)if(!Wn.has(M))if(M.groupId){if(!h.has(M.groupId)){h.add(M.groupId);let A=e.annotations.filter(z=>z.groupId===M.groupId);for(let z of A)m.set(z.id,V);V++}}else m.set(M.id,V),V++;return m},[e.annotations,Wn]),xs=Gi(()=>{if(nt.length===0)return null;let m=new Map;for(let h of nt){let V=e.annotations.find(A=>A.id===h);if(!V)continue;let M=V.groupId?e.annotations.filter(A=>A.groupId===V.groupId):[V];for(let A of M)if(A.linkedSelector&&!(i!=null&&i.has(A.linkedSelector))){let z=A.color||e.activeColor;m.set(A.linkedSelector,z)}}return m.size>0?m:null},[nt,e.annotations,e.activeColor,i]);Jt(()=>{let m=e.annotations.filter(h=>!(Wn.has(h)||S&&!S.isNew&&h.id===S.id));v(m,e.currentPath,e.activeTool,e.activeColor,e.strokeWidth,nt,aa,Zt.x,Zt.y,ir,b)},[e.annotations,e.currentPath,e.activeTool,e.activeColor,e.strokeWidth,v,S,nt,Zt,ir,Wn,b]),Jt(()=>{if(be){let m=Math.random().toString(36).substring(2,9);I({id:m,point:be.point,text:"",fontSize:12,isNew:!0,groupId:be.groupId}),de(null)}},[be]),Jt(()=>{ue&&(I({id:Math.random().toString(36).substring(2,9),point:ue.point,text:"",fontSize:12,isNew:!0,linkedSelector:ue.linkedSelector,linkedAnchor:ue.linkedAnchor,elements:ue.elements}),Fe(null))},[ue]);let sr=Tt(null),lr=(Ms=S==null?void 0:S.id)!=null?Ms:null;Jt(()=>{lr&&Te.current?requestAnimationFrame(()=>{var V;let m=Te.current;if(!m||(m.focus(),ee.current===lr))return;ee.current=lr;let h=He.current;if(h){if(sr.current!==null){let M=Math.min(sr.current,m.value.length);m.setSelectionRange(M,M);return}if(!h.isNew&&h.clickPoint){let M=T.current;if(!M)return;let A=M.getContext("2d");if(!A)return;A.font=`${h.fontSize}px ${zt}`;let z=h.fontSize*1.4,ie=h.text.split(`
7
+ `),N=h.clickPoint.y-h.point.y,J=Math.max(0,Math.min(ie.length-1,Math.floor(N/z))),x=h.clickPoint.x-h.point.x,C=ie[J]||"",Y=0;for(let D=0;D<=C.length;D++){let _=A.measureText(C.substring(0,D)).width;if(_>x){let $=D>0?A.measureText(C.substring(0,D-1)).width:0;Y=x-$<_-x?D-1:D;break}Y=D}let R=Y;for(let D=0;D<J;D++)R+=(((V=ie[D])==null?void 0:V.length)||0)+1;m.setSelectionRange(R,R)}}}):(ee.current=null,sr.current=null)},[lr,T]);let ho=Pt(m=>{let h=T.current;if(!h)return{x:0,y:0};let V=h.getBoundingClientRect(),M,A;if("touches"in m&&m.touches[0])M=m.touches[0].clientX,A=m.touches[0].clientY;else if("clientX"in m)M=m.clientX,A=m.clientY;else return{x:0,y:0};return{x:M-V.left+window.scrollX,y:A-V.top+window.scrollY}},[T]),Xn=Pt((m,h,V,M)=>{let A=V.x-h.x,z=V.y-h.y,ie=A*A+z*z;if(ie===0)return Math.sqrt((m.x-h.x)**2+(m.y-h.y)**2)<=M;let N=Math.max(0,Math.min(1,((m.x-h.x)*A+(m.y-h.y)*z)/ie)),J=h.x+N*A,x=h.y+N*z;return Math.sqrt((m.x-J)**2+(m.y-x)**2)<=M},[]),ar=Pt(m=>{for(let V=e.annotations.length-1;V>=0;V--){let M=e.annotations[V];if(!M||Wn.has(M))continue;let A=(M.strokeWidth||3)+4;switch(M.type){case"text":{if(!M.points[0]||!M.text)continue;let z=M.points[0],ie=M.fontSize||12,N=T.current;if(N){let J=N.getContext("2d");if(J){J.font=`${ie}px ${zt}`;let x=M.text.split(`
8
+ `),C=z.x-Zt.x,Y=vo(C),R=Y!==void 0?Math.min(400,Y):void 0,D=R?no(J,x,R):x,_=R?Math.min(R,Math.max(...D.map(ot=>J.measureText(ot).width))):Math.max(...x.map(ot=>J.measureText(ot).width)),$=D.length*(ie*1.4),le=x.length*(ie*1.4),ve=$-le;if(m.x>=z.x-4-4&&m.x<=z.x+_+4+4&&m.y>=z.y-4-4-ve&&m.y<=z.y+le+4+4)return M}}break}case"rectangle":{if(M.points.length<2)continue;let z=M.points[0],ie=M.points[M.points.length-1],N=Math.min(z.x,ie.x),J=Math.max(z.x,ie.x),x=Math.min(z.y,ie.y),C=Math.max(z.y,ie.y),Y=Xn(m,{x:N,y:x},{x:J,y:x},A),R=Xn(m,{x:N,y:C},{x:J,y:C},A),D=Xn(m,{x:N,y:x},{x:N,y:C},A),_=Xn(m,{x:J,y:x},{x:J,y:C},A);if(Y||R||D||_)return M;break}case"circle":{if(M.points.length<2)continue;let z=M.points[0],ie=M.points[M.points.length-1],N=(z.x+ie.x)/2,J=(z.y+ie.y)/2,x=Math.abs(ie.x-z.x)/2,C=Math.abs(ie.y-z.y)/2,Y=m.x-N,R=m.y-J,D=Math.sqrt((Y/x)**2+(R/C)**2);if(Math.abs(D-1)*Math.max(x,C)<=A)return M;break}case"line":{if(M.points.length<2)continue;let z=M.points[0],ie=M.points[M.points.length-1];if(Xn(m,z,ie,A))return M;break}case"freehand":{if(M.points.length<2)continue;for(let z=0;z<M.points.length-1;z++){let ie=M.points[z],N=M.points[z+1];if(Xn(m,ie,N,A))return M}break}}}return null},[e.annotations,T,Xn,Wn,Zt.x]),Ss=Pt(m=>{let h=ar(m);return(h==null?void 0:h.type)==="text"?h:null},[ar]),vs=Pt(m=>{if(nt.length===0)return null;let h=aa/2+4;for(let V of nt){let M=e.annotations.find(A=>A.id===V);if(!(!M||M.points.length<2)){if(M.type==="line"){let A=M.points[0],z=M.points[M.points.length-1];if(Math.sqrt((m.x-A.x)**2+(m.y-A.y)**2)<=h)return{handle:"start",annotationId:V};if(Math.sqrt((m.x-z.x)**2+(m.y-z.y)**2)<=h)return{handle:"end",annotationId:V};continue}if(M.type==="circle"){let A=M.points[0],z=M.points[M.points.length-1],ie=Math.min(A.x,z.x),N=Math.max(A.x,z.x),J=Math.min(A.y,z.y),x=Math.max(A.y,z.y),C=(ie+N)/2,Y=(J+x)/2,R=[{handle:"top",x:C,y:J},{handle:"bottom",x:C,y:x},{handle:"left",x:ie,y:Y},{handle:"right",x:N,y:Y}];for(let{handle:D,x:_,y:$}of R)if(Math.sqrt((m.x-_)**2+(m.y-$)**2)<=h)return{handle:D,annotationId:V};continue}if(M.type==="rectangle"||M.type==="freehand"){let A=M.points[0],z=M.points[M.points.length-1],ie,N,J,x;M.type==="freehand"?(ie=Math.min(...M.points.map(Y=>Y.x)),N=Math.max(...M.points.map(Y=>Y.x)),J=Math.min(...M.points.map(Y=>Y.y)),x=Math.max(...M.points.map(Y=>Y.y))):(ie=Math.min(A.x,z.x),N=Math.max(A.x,z.x),J=Math.min(A.y,z.y),x=Math.max(A.y,z.y));let C=[{corner:"topLeft",x:ie,y:J},{corner:"topRight",x:N,y:J},{corner:"bottomLeft",x:ie,y:x},{corner:"bottomRight",x:N,y:x}];for(let{corner:Y,x:R,y:D}of C)if(Math.sqrt((m.x-R)**2+(m.y-D)**2)<=h)return{handle:Y,annotationId:V}}}}return null},[nt,e.annotations]);Jt(()=>{let m=h=>{if(Le.current={x:h.clientX+window.scrollX,y:h.clientY+window.scrollY},!S){let V=Ss(Le.current);ge((V==null?void 0:V.id)||null)}};return window.addEventListener("mousemove",m),()=>window.removeEventListener("mousemove",m)},[S,Ss]);let yo=Pt(()=>{var h;if(!S)return;let m=((h=S.images)==null?void 0:h.length)||0;if(S.text.trim()||m>0)if(S.isNew){let V=fr();t({type:"ADD_TEXT",payload:f({point:S.point,text:S.text||(m>0?`[${m} image${m>1?"s":""}]`:""),fontSize:S.fontSize,id:V,groupId:S.groupId,linkedSelector:S.linkedSelector,linkedAnchor:S.linkedAnchor,elements:S.elements},m>0?{imageCount:m}:{})}),m>0&&S.images&&s&&s(V,S.images)}else t({type:"UPDATE_TEXT",payload:f({id:S.id,text:S.text||(m>0?`[${m} image${m>1?"s":""}]`:"")},m>0?{imageCount:m}:{})}),m>0&&S.images&&s&&s(S.id,S.images);else S.isNew||t({type:"DELETE_ANNOTATION",payload:{id:S.id}});I(null)},[S,t,s]),Bn=Pt(m=>{for(let h=0;h<Vi.length-1;h++){let V=Vi[h],M=Vi[h+1];if(m<=(V+M)/2)return V;if(m<M)return M}return Math.round(m/8)*8},[]),ws=Pt((m,h,V,M)=>{let A=V.top+Math.max(M.top,4),z=V.bottom-Math.max(M.bottom,4),ie=V.left+Math.max(M.left,4),N=V.right-Math.max(M.right,4);if(m<V.left||m>V.right||h<V.top||h>V.bottom)return null;let J=h<A,x=h>z,C=m<ie,Y=m>N;return J&&C?M.top>=M.left?"top":"left":J&&Y?M.top>=M.right?"top":"right":x&&C?M.bottom>=M.left?"bottom":"left":x&&Y?M.bottom>=M.right?"bottom":"right":J?"top":x?"bottom":C?"left":Y?"right":null},[]),Es=Pt(m=>{var z,ie;if(!e.isAnnotating)return;if(e.inspectedElement&&e.activeTool==="hand"&&!("button"in m&&m.button===2)){m.preventDefault(),m.stopPropagation(),t({type:"SELECT_ELEMENT",payload:null});return}let h=ho(m),V="shiftKey"in m&&m.shiftKey;if(e.activeTool==="inspector"){if("button"in m&&m.button===2)return;if(Ie&&!se(Ie)){let N=nn(Ie),J=un(Ie),x=Ie.getBoundingClientRect(),C=Ie.getAttribute("data-pm");C||(C=Math.random().toString(36).substring(2,8),Ie.setAttribute("data-pm",C));let Y=`[data-pm="${C}"]`,R=e.styleModifications.some(ve=>{try{return Ie.matches(ve.selector)}catch(ot){return!1}}),D=e.annotations.filter(ve=>{if(!ve.linkedSelector)return!1;try{return Ie.matches(ve.linkedSelector)}catch(ot){return!1}}).length,_=(R?1:0)+D,$=x.top>=bn*(1+_)?"top-left":"bottom-left",le=ca(x,$,_,L==null?void 0:L.current);Fe({point:le,linkedSelector:Y,linkedAnchor:$,elements:[y(f({},N),{selector:J})]})}return}if(e.activeTool==="model"){if("button"in m&&m.button===2)return;if(Pe){let N=Pe.name;if(g!=null&&g.has(N)){u==null||u(N);return}"shiftKey"in m&&m.shiftKey?me(x=>{let C=new Map(x);return C.has(N)?C.delete(N):C.set(N,Pe),C}):q.size===1&&q.has(N)?(d&&d([N]),me(new Map)):me(new Map([[N,Pe]]))}return}if(e.activeTool==="hand"&&vt&&Ft){let N=vt,J=N.getAttribute("data-pm");J||(J=Math.random().toString(36).substring(2,8),N.setAttribute("data-pm",J));let x=un(N),C=`[data-pm="${J}"]`,Y=nn(N),R=Vo(N),D=h.x-window.scrollX,_=h.y-window.scrollY,$=Re,le=window.getComputedStyle(N).justifyContent,ve=0;if($){let st=ro(N).find(Mt=>Mt.axis===Ft);ve=st?Ft==="column"?st.w:st.h:0}$e(N,"transition","none"),mt.current={isDragging:!0,hasMoved:!1,axis:Ft,startX:D,startY:_,originalRow:$?ve:R.row,originalColumn:$?ve:R.column,element:N,elementInfo:y(f({},Y),{selector:C}),selector:C,durableSelector:x,isAuto:$,originalJustifyContent:le,visualGap:ve},Z({axis:Ft,row:$?ve:R.row,column:$?ve:R.column});return}if(e.activeTool==="hand"&&Se&&pe){let N=Se,J=N.getAttribute("data-pm");J||(J=Math.random().toString(36).substring(2,8),N.setAttribute("data-pm",J));let x=`[data-pm="${J}"]`,C=nn(N),{fontSize:Y,lineHeight:R}=Uo(N),D=Y>0?R/Y:1.2,_=h.x-window.scrollX,$=h.y-window.scrollY;$e(N,"transition","none");let le=un(N);oe.current={isDragging:!0,property:pe,startX:_,startY:$,originalFontSize:Y,originalLineHeight:R,originalRatio:D,element:N,elementInfo:y(f({},C),{selector:x}),selector:x,durableSelector:le},Tn({property:pe,fontSize:Y,lineHeight:R});return}if(e.activeTool==="hand"&&kt&&dn){let N=kt,J=N.getAttribute("data-pm");J||(J=Math.random().toString(36).substring(2,8),N.setAttribute("data-pm",J));let x=`[data-pm="${J}"]`,C=un(N),Y=nn(N),R=io(N),D=N.getBoundingClientRect(),_=Math.floor(D.height/2),$=h.y-window.scrollY;$e(N,"transition","none"),Ut.current={isDragging:!0,corner:dn,startY:$,original:R,maxRadius:_,element:N,elementInfo:y(f({},Y),{selector:x}),selector:x,durableSelector:C},ne({corner:dn,radius:f({},R)});return}if(e.activeTool==="hand"&&Be&&it){let N=Be,J=N.getAttribute("data-pm");J||(J=Math.random().toString(36).substring(2,8),N.setAttribute("data-pm",J));let x=`[data-pm="${J}"]`,C=un(N),Y=nn(N),R=ko(N),D=h.x-window.scrollX,_=h.y-window.scrollY;$e(N,"transition","none"),xe.current={isDragging:!0,side:it,startX:D,startY:_,original:R,element:N,elementInfo:y(f({},Y),{selector:x}),selector:x,durableSelector:C},Rt({side:it,padding:f({},R)});return}let M=vs(h);if(M){let N=e.annotations.find(J=>J.id===M.annotationId);if(N&&N.type!=="text"&&((z=N.status)!=null?z:"pending")==="pending"){$n({annotationId:M.annotationId,handle:M.handle,startPoint:h,originalPoints:[...N.points],hasMoved:!1});return}}let A=ar(h);if(A&&A.points[0]){if(S&&yo(),A.type!=="text"?(Lt(A.id,V),A.color&&t({type:"SET_COLOR",payload:A.color})):V||on(),a){let N=A.threadId||(A.groupId?(ie=e.annotations.find(J=>J.groupId===A.groupId&&J.threadId))==null?void 0:ie.threadId:void 0);N&&a(N)}je({annotation:A,startPoint:h,hasMoved:!1});return}if(V||on(),e.activeTool==="text"){S&&yo();let N=Math.random().toString(36).substring(2,9);I({id:N,point:h,text:"",fontSize:12,isNew:!0});return}X(!0),t({type:"START_PATH",payload:h})},[e.isAnnotating,e.activeTool,e.inspectedElement,e.annotations,S,nt,Ie,Be,it,kt,dn,vt,Ft,Re,Se,pe,Pe,q,g,d,u,a,ho,ar,vs,t,Lt,on,yo]),Cs=Pt(m=>{var V,M;let h=ho(m);if(e.activeTool==="inspector"&&e.isAnnotating){let A=h.x-window.scrollX,z=h.y-window.scrollY,ie=oo(A,z),N=ie&&se(ie)?null:ie;N!==Ie&&(We(N),dt(N?nn(N):null));return}if(e.activeTool==="model"&&e.isAnnotating){let A=h.x-window.scrollX,z=h.y-window.scrollY,ie=oo(A,z);if(ie!==ye.current&&(ye.current=ie,Ee.current=0),ie){let N=hr(ie,Ee.current);Me(N)}else Me(null);return}if(e.activeTool==="hand"&&e.isAnnotating){let A=h.x-window.scrollX,z=h.y-window.scrollY;Ht.current={x:A,y:z},wt({x:A,y:z});let ie=P.current.cmd,N=P.current.shift;if(mt.current.isDragging){let x=mt.current,C=x.element;if(!C)return;if(!x.hasMoved){let _=Math.abs(A-x.startX),$=Math.abs(z-x.startY);if(_<=2&&$<=2)return;x.hasMoved=!0,x.isAuto&&($e(C,"justify-content","normal"),$e(C,"row-gap",`${x.visualGap}px`),$e(C,"column-gap",`${x.visualGap}px`),Xe(!1))}let Y=x.axis,R=x.originalRow,D=x.originalColumn;if(Y==="column"){let _=A-x.startX;D=x.originalColumn+_,ie||(R=x.originalRow+_)}else{let _=z-x.startY;R=x.originalRow+_,ie||(D=x.originalColumn+_)}R=Math.max(0,R),D=Math.max(0,D),N&&(R=Bn(R),D=Bn(D)),R=Math.round(R),D=Math.round(D),$e(C,"row-gap",`${R}px`),$e(C,"column-gap",`${D}px`),Z({axis:Y,row:R,column:D});return}if(Ut.current.isDragging){let x=Ut.current,C=x.element;if(!C)return;let Y=z-x.startY,R=x.corner,D=x.original,_=f({},D);if(ie){let $=D[R]+Y;$=Math.max(0,Math.min(x.maxRadius,$)),N&&($=Bn($)),$=Math.round($),_[R]=$}else{let $=D[R]+Y;$=Math.max(0,Math.min(x.maxRadius,$)),N&&($=Bn($)),$=Math.round($),_={"top-left":$,"top-right":$,"bottom-right":$,"bottom-left":$}}$e(C,"border-top-left-radius",`${_["top-left"]}px`),$e(C,"border-top-right-radius",`${_["top-right"]}px`),$e(C,"border-bottom-right-radius",`${_["bottom-right"]}px`),$e(C,"border-bottom-left-radius",`${_["bottom-left"]}px`),ne({corner:R,radius:_});return}if(oe.current.isDragging){let x=oe.current,C=x.element;if(!C)return;let Y=x.property,R=x.originalFontSize,D=x.originalLineHeight,_=[8,10,11,12,13,14,16,18,20,22,24,28,32,36,40,48,56,64,72,80,96];if(Y==="font-size"){let le=A-x.startX;R=x.originalFontSize+le,R=Math.max(1,R)}else{let le=z-x.startY;D=x.originalLineHeight+le,D=Math.max(R,D)}if(N)if(Y==="font-size"){let le=_[0],ve=Math.abs(R-le);for(let ot of _){let st=Math.abs(R-ot);st<ve&&(le=ot,ve=st)}R=le}else{let le=R>0?D/R:1.2,ve=Math.round(le*2)/2;D=R*Math.max(1,ve)}R=Math.round(R),D=Math.round(D*10)/10,$e(C,"font-size",`${R}px`);let $=R>0?Math.round(D/R*1e3)/1e3:1.2;$e(C,"line-height",`${$}`),Tn({property:Y,fontSize:R,lineHeight:D});return}if(xe.current.isDragging){let x=xe.current,C=x.element;if(!C)return;let Y=x.side,R=x.original,D=R.top,_=R.right,$=R.bottom,le=R.left;if(Y==="top"){let ve=x.startY-z;D=R.top+ve,ie||($=R.bottom+ve)}else if(Y==="bottom"){let ve=z-x.startY;$=R.bottom+ve,ie||(D=R.top+ve)}else if(Y==="left"){let ve=x.startX-A;le=R.left+ve,ie||(_=R.right+ve)}else if(Y==="right"){let ve=A-x.startX;_=R.right+ve,ie||(le=R.left+ve)}D=Math.max(0,D),_=Math.max(0,_),$=Math.max(0,$),le=Math.max(0,le),N&&(D=Bn(D),_=Bn(_),$=Bn($),le=Bn(le)),D=Math.round(D),_=Math.round(_),$=Math.round($),le=Math.round(le),$e(C,"padding",`${D}px ${_}px ${$}px ${le}px`),Rt({side:Y,padding:{top:D,right:_,bottom:$,left:le}});return}let J=oo(A,z);for(;J&&J.tagName==="A";)J=J.parentElement;{let C=[];J&&C.push(J),kt&&kt!==J&&C.push(kt);let Y=null,R=16,D=null;for(let _ of C){let $=_.getBoundingClientRect(),le=io(_),ve=[["top-left",$.left,$.top+le["top-left"]],["top-right",$.right,$.top+le["top-right"]],["bottom-right",$.right,$.bottom-le["bottom-right"]],["bottom-left",$.left,$.bottom-le["bottom-left"]]];for(let[ot,st,Mt]of ve){let Ge=Math.hypot(A-st,z-Mt);Ge<R&&(R=Ge,Y=ot,D=_)}}if(Y&&D){Jn(D),Pn(Y),Be&&Ce(null),it&&qe(null),vt&&en(null),Ft&&an(null),Xe(!1),Se&&Oe(null),pe&&xt(null);return}}kt&&Jn(null),dn&&Pn(null);{let x=[];J&&xr(J)&&x.push(J);let C=(V=J==null?void 0:J.parentElement)!=null?V:null;for(;C&&C!==document.body&&x.length<3;)xr(C)&&x.push(C),C=C.parentElement;for(let Y of x){let D=ro(Y).find(_=>A>=_.x&&A<=_.x+_.w&&z>=_.y&&z<=_.y+_.h);if(D){en(Y),an(D.axis),Xe(hi(Y,D.axis)),Be&&Ce(null),it&&qe(null),Se&&Oe(null),pe&&xt(null);return}}}vt&&en(null),Ft&&an(null),Xe(!1);{let C=[];J&&C.push(J),Se&&Se!==J&&C.push(Se);let Y=null,R=1/0,D=null;for(let _ of C){if(!yi(_))continue;let $=Mo(_);if(!$)continue;let le=A>=$.left&&A<=$.right&&z>=$.top&&z<=$.bottom,ve=[["font-size",$.right,$.top+$.height/2],["line-height",$.left+$.width/2,$.bottom]];for(let[ot,st,Mt]of ve){let Ge=Math.hypot(A-st,z-Mt);(le||Ge<12)&&Ge<R&&(R=Ge,Y=ot,D=_)}}Y&&D?(Oe(D),xt(Y)):(Se&&Oe(null),pe&&xt(null))}if(J!==Be&&Ce(J),J){let x=ko(J),C=J.getBoundingClientRect(),Y=ws(A,z,C,x);qe(Y)}else qe(null);return}if(hn){let{handle:A,originalPoints:z,hasMoved:ie}=hn,N=e.annotations.find(R=>R.id===hn.annotationId);if(!N)return;let J="metaKey"in m,x=J&&(m.metaKey||m.ctrlKey),C=J&&m.shiftKey,Y;if(N.type==="line"){let R=z[0],D=z[z.length-1];A==="start"?Y=[h,D]:Y=[R,h]}else if(N.type==="freehand"){let R=Math.min(...z.map(ze=>ze.x)),D=Math.max(...z.map(ze=>ze.x)),_=Math.min(...z.map(ze=>ze.y)),$=Math.max(...z.map(ze=>ze.y)),le=(R+D)/2,ve=(_+$)/2,ot=D-R||1,st=$-_||1,Mt=ot/st,Ge=R,ae=D,we=_,Ke=$;switch(A){case"topLeft":Ge=h.x,we=h.y;break;case"topRight":ae=h.x,we=h.y;break;case"bottomLeft":Ge=h.x,Ke=h.y;break;case"bottomRight":ae=h.x,Ke=h.y;break}if(x)switch(A){case"topLeft":ae=D+(R-Ge),Ke=$+(_-we);break;case"topRight":Ge=R-(ae-D),Ke=$+(_-we);break;case"bottomLeft":ae=D+(R-Ge),we=_-(Ke-$);break;case"bottomRight":Ge=R-(ae-D),we=_-(Ke-$);break}if(C){let ze=ae-Ge,ht=Ke-we;if(Math.abs(ze/ht)>Mt){let _t=Math.abs(ht)*Mt*Math.sign(ze);A==="topLeft"||A==="bottomLeft"?Ge=ae-_t:ae=Ge+_t}else{let _t=Math.abs(ze)/Mt*Math.sign(ht);A==="topLeft"||A==="topRight"?we=Ke-_t:Ke=we+_t}}let Ve=ae-Ge||1,ft=Ke-we||1;Y=z.map(ze=>({x:Ge+(ze.x-R)/ot*Ve,y:we+(ze.y-_)/st*ft}))}else if(N.type==="circle"){let R=z[0],D=z[z.length-1],_=Math.min(R.x,D.x),$=Math.max(R.x,D.x),le=Math.min(R.y,D.y),ve=Math.max(R.y,D.y),ot=(_+$)/2,st=(le+ve)/2,Mt=$-_,Ge=ve-le,ae=_,we=$,Ke=le,Ve=ve;switch(A){case"top":if(Ke=h.y,x&&(Ve=st+(st-h.y)),C){let ze=(Ve-Ke)*(Mt/Ge)/2;ae=ot-ze,we=ot+ze}break;case"bottom":if(Ve=h.y,x&&(Ke=st-(h.y-st)),C){let ze=(Ve-Ke)*(Mt/Ge)/2;ae=ot-ze,we=ot+ze}break;case"left":if(ae=h.x,x&&(we=ot+(ot-h.x)),C){let ze=(we-ae)*(Ge/Mt)/2;Ke=st-ze,Ve=st+ze}break;case"right":if(we=h.x,x&&(ae=ot-(h.x-ot)),C){let ze=(we-ae)*(Ge/Mt)/2;Ke=st-ze,Ve=st+ze}break}Y=[{x:ae,y:Ke},{x:we,y:Ve}]}else{let R=z[0],D=z[z.length-1],_=Math.min(R.x,D.x),$=Math.max(R.x,D.x),le=Math.min(R.y,D.y),ve=Math.max(R.y,D.y),ot=(_+$)/2,st=(le+ve)/2,Mt=$-_||1,Ge=ve-le||1,ae=Mt/Ge,we=_,Ke=$,Ve=le,ft=ve;switch(A){case"topLeft":we=h.x,Ve=h.y;break;case"topRight":Ke=h.x,Ve=h.y;break;case"bottomLeft":we=h.x,ft=h.y;break;case"bottomRight":Ke=h.x,ft=h.y;break}if(x)switch(A){case"topLeft":Ke=$+(_-we),ft=ve+(le-Ve);break;case"topRight":we=_-(Ke-$),ft=ve+(le-Ve);break;case"bottomLeft":Ke=$+(_-we),Ve=le-(ft-ve);break;case"bottomRight":we=_-(Ke-$),Ve=le-(ft-ve);break}if(C){let ze=Ke-we,ht=ft-Ve;if(Math.abs(ze/ht)>ae){let _t=Math.abs(ht)*ae*Math.sign(ze);A==="topLeft"||A==="bottomLeft"?we=Ke-_t:Ke=we+_t}else{let _t=Math.abs(ze)/ae*Math.sign(ht);A==="topLeft"||A==="topRight"?Ve=ft-_t:ft=Ve+_t}}Y=[{x:we,y:Ve},{x:Ke,y:ft}]}t({type:"RESIZE_ANNOTATION",payload:{id:hn.annotationId,points:Y,saveUndo:!ie}}),ie||$n(y(f({},hn),{hasMoved:!0}));return}if(Ne&&((M=Ne.annotation.status)!=null?M:"pending")==="pending"){let A=h.x-Ne.startPoint.x,z=h.y-Ne.startPoint.y;if((Math.abs(A)>2||Math.abs(z)>2)&&!Ne.hasMoved)je(y(f({},Ne),{hasMoved:!0,startPoint:h})),t({type:"MOVE_ANNOTATION",payload:{id:Ne.annotation.id,delta:{x:A,y:z},saveUndo:!0}});else if(Ne.hasMoved){let N=h.x-Ne.startPoint.x,J=h.y-Ne.startPoint.y;je(y(f({},Ne),{startPoint:h})),t({type:"MOVE_ANNOTATION",payload:{id:Ne.annotation.id,delta:{x:N,y:J}}})}return}!G||!e.isAnnotating||t({type:"CONTINUE_PATH",payload:h})},[G,e.isAnnotating,e.activeTool,Ne,hn,Ie,Be,it,kt,dn,vt,Ft,Se,pe,ho,t,Bn,ws]),Gr=Pt(m=>{var M,A,z,ie,N,J;if(oe.current.isDragging){let x=oe.current,C=x.element;if(C&&x.selector&&x.elementInfo&&Je){C instanceof HTMLElement&&(C.style.removeProperty("font-size"),C.style.removeProperty("line-height"),C.style.removeProperty("transition"));let Y=[];if(x.originalFontSize!==Je.fontSize&&($e(C,"font-size",`${Je.fontSize}px`),Y.push({property:"font-size",original:`${x.originalFontSize}px`,modified:`${Je.fontSize}px`})),x.originalLineHeight!==Je.lineHeight){let R=x.originalFontSize>0?Math.round(x.originalLineHeight/x.originalFontSize*1e3)/1e3:1.2,D=Je.fontSize>0?Math.round(Je.lineHeight/Je.fontSize*1e3)/1e3:1.2;$e(C,"line-height",`${D}`),Y.push({property:"line-height",original:`${R}`,modified:`${D}`})}Y.length>0&&t({type:"MODIFY_STYLES_BATCH",payload:{selector:x.selector,durableSelector:(M=x.durableSelector)!=null?M:void 0,element:x.elementInfo,changes:Y}})}oe.current={isDragging:!1,property:null,startX:0,startY:0,originalFontSize:0,originalLineHeight:0,originalRatio:1.2,element:null,elementInfo:null,selector:null,durableSelector:null},Tn(null);return}if(mt.current.isDragging){let x=mt.current,C=x.element,Y="button"in m&&m.button===2;if(!x.hasMoved&&!Y&&C&&x.selector&&x.elementInfo){C instanceof HTMLElement&&C.style.removeProperty("transition");let R=["space-between","space-around","stretch","normal"],D=x.originalJustifyContent||"normal",_=R.indexOf(D),$=R[(_+1)%R.length],le=[];$==="normal"?($e(C,"justify-content","normal"),le.push({property:"justify-content",original:x.originalJustifyContent,modified:"normal"})):$==="stretch"?($e(C,"justify-content",$),$e(C,"row-gap","8px"),$e(C,"column-gap","8px"),le.push({property:"justify-content",original:x.originalJustifyContent||"normal",modified:$}),x.originalRow!==8&&le.push({property:"row-gap",original:`${x.originalRow}px`,modified:"8px"}),x.originalColumn!==8&&le.push({property:"column-gap",original:`${x.originalColumn}px`,modified:"8px"})):(C instanceof HTMLElement&&(C.style.removeProperty("row-gap"),C.style.removeProperty("column-gap")),$e(C,"justify-content",$),le.push({property:"justify-content",original:x.originalJustifyContent||"normal",modified:$}),x.originalRow>0&&le.push({property:"row-gap",original:`${x.originalRow}px`,modified:"0px"}),x.originalColumn>0&&le.push({property:"column-gap",original:`${x.originalColumn}px`,modified:"0px"})),le.length>0&&t({type:"MODIFY_STYLES_BATCH",payload:{selector:x.selector,durableSelector:(A=x.durableSelector)!=null?A:void 0,element:x.elementInfo,changes:le}})}else if(x.hasMoved&&C&&x.selector&&x.elementInfo&&ut){C instanceof HTMLElement&&(C.style.removeProperty("row-gap"),C.style.removeProperty("column-gap"),C.style.removeProperty("transition"));let R=[];x.isAuto?(C instanceof HTMLElement&&C.style.removeProperty("justify-content"),$e(C,"justify-content","normal"),$e(C,"row-gap",`${ut.row}px`),$e(C,"column-gap",`${ut.column}px`),R.push({property:"justify-content",original:x.originalJustifyContent,modified:"normal"}),R.push({property:"row-gap",original:"0px",modified:`${ut.row}px`}),R.push({property:"column-gap",original:"0px",modified:`${ut.column}px`})):(x.originalRow!==ut.row&&($e(C,"row-gap",`${ut.row}px`),R.push({property:"row-gap",original:`${x.originalRow}px`,modified:`${ut.row}px`})),x.originalColumn!==ut.column&&($e(C,"column-gap",`${ut.column}px`),R.push({property:"column-gap",original:`${x.originalColumn}px`,modified:`${ut.column}px`}))),R.length>0&&t({type:"MODIFY_STYLES_BATCH",payload:{selector:x.selector,durableSelector:(z=x.durableSelector)!=null?z:void 0,element:x.elementInfo,changes:R}})}mt.current={isDragging:!1,hasMoved:!1,axis:null,startX:0,startY:0,originalRow:0,originalColumn:0,element:null,elementInfo:null,selector:null,durableSelector:null,isAuto:!1,originalJustifyContent:"",visualGap:0},Z(null);return}if(Ut.current.isDragging){let x=Ut.current,C=x.element;if(C&&x.selector&&x.elementInfo&&F){C instanceof HTMLElement&&(C.style.removeProperty("border-top-left-radius"),C.style.removeProperty("border-top-right-radius"),C.style.removeProperty("border-bottom-right-radius"),C.style.removeProperty("border-bottom-left-radius"),C.style.removeProperty("transition"));let Y=["top-left","top-right","bottom-right","bottom-left"],R={"top-left":"border-top-left-radius","top-right":"border-top-right-radius","bottom-right":"border-bottom-right-radius","bottom-left":"border-bottom-left-radius"},D=[];for(let _ of Y)x.original[_]!==F.radius[_]&&($e(C,R[_],`${F.radius[_]}px`),D.push({property:R[_],original:`${x.original[_]}px`,modified:`${F.radius[_]}px`}));D.length>0&&t({type:"MODIFY_STYLES_BATCH",payload:{selector:x.selector,durableSelector:(ie=x.durableSelector)!=null?ie:void 0,element:x.elementInfo,changes:D}})}Ut.current={isDragging:!1,corner:null,startY:0,original:{"top-left":0,"top-right":0,"bottom-right":0,"bottom-left":0},maxRadius:0,element:null,elementInfo:null,selector:null,durableSelector:null},ne(null);return}if(xe.current.isDragging){let x=xe.current,C=x.element,Y=x.selector,R=x.elementInfo;if(C&&Y&&R&&et){let D=x.original,_=et.padding;C instanceof HTMLElement&&(C.style.removeProperty("padding"),C.style.removeProperty("transition"));let $=[],le=[{prop:"padding-top",origVal:D.top,newVal:_.top},{prop:"padding-right",origVal:D.right,newVal:_.right},{prop:"padding-bottom",origVal:D.bottom,newVal:_.bottom},{prop:"padding-left",origVal:D.left,newVal:_.left}];for(let{prop:ve,origVal:ot,newVal:st}of le)ot!==st&&($e(C,ve,`${st}px`),$.push({property:ve,original:`${ot}px`,modified:`${st}px`}));$.length>0&&t({type:"MODIFY_STYLES_BATCH",payload:{selector:Y,durableSelector:(N=x.durableSelector)!=null?N:void 0,element:R,changes:$}})}xe.current={isDragging:!1,side:null,startX:0,startY:0,original:{top:0,right:0,bottom:0,left:0},element:null,elementInfo:null,selector:null,durableSelector:null},Rt(null);return}if(hn){$n(null);return}if(Ne){if(!Ne.hasMoved&&Ne.annotation.type==="text"&&((J=Ne.annotation.status)!=null?J:"pending")==="pending"){let x=ho(m);I({id:Ne.annotation.id,point:Ne.annotation.points[0],text:Ne.annotation.text||"",fontSize:Ne.annotation.fontSize||12,isNew:!1,clickPoint:x,groupId:Ne.annotation.groupId})}je(null);return}if(!G)return;let h=5;if(e.currentPath.length>=2){let x=e.currentPath[0],C=e.currentPath[e.currentPath.length-1],Y=Math.abs(C.x-x.x),R=Math.abs(C.y-x.y);if((e.activeTool==="line"?Math.sqrt(Y*Y+R*R)<h:Y<h&&R<h)&&["rectangle","circle","line"].includes(e.activeTool)){X(!1),t({type:"CANCEL_PATH"});return}}let V=di(e.currentPath);if(e.activeTool==="rectangle"&&e.currentPath.length>=2){let x=e.currentPath[0],C=e.currentPath[e.currentPath.length-1],Y=Math.min(x.x,C.x),R=Math.max(x.y,C.y),D=e.strokeWidth/2,_=Math.random().toString(36).substring(2,9);de({point:{x:Y-D+4,y:R+D+4},groupId:_}),X(!1),t({type:"FINISH_PATH",payload:{groupId:_,elements:V}});return}X(!1),t({type:"FINISH_PATH",payload:{elements:V}})},[G,Ne,hn,et,F,ut,Je,ho,t,e.activeTool,e.currentPath,e.strokeWidth]),Xa=Pt(m=>{let h=m.target.value;sr.current=m.target.selectionStart,I(V=>V&&y(f({},V),{text:h}))},[]),Ka=Pt(m=>{m.key==="Escape"?I(null):m.key==="Enter"&&!m.shiftKey&&(m.preventDefault(),yo())},[yo]),qa=Pt(m=>{if(!S)return;let h=m.clipboardData.items,V=[];for(let M=0;M<h.length;M++){let A=h[M];if(A.type.startsWith("image/")){let z=A.getAsFile();z&&V.push(z)}}V.length>0&&(m.preventDefault(),I(M=>M?y(f({},M),{images:[...M.images||[],...V]}):null))},[S]),Za=Pt(m=>{if(!e.isAnnotating)return;if(e.activeTool==="hand"){m.preventDefault();let V=Be||vt||kt||Se;if(V&&!se(V)){let M=nn(V),A=un(V);t({type:"SELECT_ELEMENT",payload:{el:V,info:y(f({},M),{selector:A})}})}return}m.preventDefault();let h=T.current;h&&(U.current=!0,h.style.pointerEvents="none",setTimeout(()=>{U.current&&(U.current=!1,h.style.pointerEvents="")},4e3))},[e.activeTool,e.isAnnotating,Be,vt,kt,Se,t,se,T]);Jt(()=>{let m=e.annotations.filter(ie=>ie.linkedSelector);if(m.length===0)return;let h=null,V=document.createElement("canvas").getContext("2d"),M=()=>{var N,J,x;let ie=[];for(let C of m){let Y=document.querySelector(C.linkedSelector);if(!Y&&((J=(N=C.elements)==null?void 0:N[0])!=null&&J.selector)&&C.linkedSelector.startsWith("[data-pm=")){try{Y=document.querySelector(C.elements[0].selector)}catch(Ge){}if(Y){let Ge=(x=C.linkedSelector.match(/data-pm="([^"]+)"/))==null?void 0:x[1];Ge&&Y.setAttribute("data-pm",Ge)}}if(!Y)continue;let R=Y.getBoundingClientRect(),D=e.styleModifications.some(Ge=>{try{return Y.matches(Ge.selector)}catch(ae){return!1}}),_=m.filter(Ge=>Ge.id!==C.id&&Ge.timestamp<C.timestamp&&Ge.linkedSelector===C.linkedSelector).length,$=(D?1:0)+_,le;if(C.text&&V){let Ge=C.fontSize||12;V.font=`${Ge}px ${zt}`,le=Math.max(...C.text.split(`
9
+ `).map(ae=>V.measureText(ae).width))}let ve=R.top>=bn*(1+$)?"top-left":"bottom-left",ot=ca(R,ve,$,L==null?void 0:L.current,le),st=C.points[0],Mt=ve!==C.linkedAnchor;st&&(Mt||Math.abs(ot.x-st.x)>1||Math.abs(ot.y-st.y)>1)&&ie.push({id:C.id,point:ot,linkedAnchor:Mt?ve:void 0})}ie.length>0&&t({type:"UPDATE_LINKED_POSITIONS",payload:{updates:ie}})},A=()=>{h&&cancelAnimationFrame(h),h=requestAnimationFrame(M)};M(),window.addEventListener("scroll",A,!0),window.addEventListener("resize",A,!0),window.addEventListener("load",A),document.fonts.ready.then(A);let z=new MutationObserver(A);return z.observe(document.body,{attributes:!0,childList:!0,subtree:!0,attributeFilter:["style","class"]}),()=>{window.removeEventListener("scroll",A,!0),window.removeEventListener("resize",A,!0),window.removeEventListener("load",A),z.disconnect(),h&&cancelAnimationFrame(h)}},[e.annotations,t]);let Qa=()=>{var m,h,V;if(!e.isAnnotating)return"default";if(hn){let{handle:M}=hn;return M==="start"||M==="end"?"move":M==="top"||M==="bottom"?"ns-resize":M==="left"||M==="right"?"ew-resize":M==="topLeft"||M==="bottomRight"?"nwse-resize":"nesw-resize"}if(e.activeTool==="text")return"text";if(e.activeTool==="hand"){let M=(m=ut==null?void 0:ut.axis)!=null?m:Ft;if(M==="row")return"ns-resize";if(M==="column")return"ew-resize";if(F||dn)return"ns-resize";let A=(h=Je==null?void 0:Je.property)!=null?h:pe;if(A==="font-size")return"ew-resize";if(A==="line-height")return"ns-resize";let z=(V=et==null?void 0:et.side)!=null?V:it;return z==="top"||z==="bottom"?"ns-resize":z==="left"||z==="right"?"ew-resize":"default"}return"crosshair"},ec={position:"fixed",top:0,left:0,width:"100vw",height:"100vh",zIndex:9998,pointerEvents:e.isAnnotating?"auto":"none",visibility:e.isAnnotating?"visible":"hidden",cursor:Qa()},Wo=Pt(()=>{let m=T.current;if(!m||!S)return{width:100,height:12*1.4,isWrapped:!1};let h=m.getContext("2d");if(!h)return{width:100,height:S.fontSize*1.4,isWrapped:!1};h.font=`${S.fontSize}px ${zt}`;let M=h.measureText("Type here...").width,A=S.text.split(`
10
+ `),z=A.length>0?Math.max(M,...A.map(C=>h.measureText(C||" ").width)):M,ie=S.point.x-Zt.x,N=vo(ie);if(N!==void 0&&z>N){let C=no(h,A,N),Y=Math.min(N,Math.max(M,...C.map(D=>h.measureText(D).width))),R=Math.max(1,C.length)*S.fontSize*1.4;return{width:Y,height:R,isWrapped:!0}}let x=Math.max(1,A.length)*S.fontSize*1.4;return{width:z,height:x,isWrapped:!1}},[S,T,Zt.x])(),tc=S?Math.max(1,S.text.split(`
11
+ `).length)*S.fontSize*1.4+8:0,ks=Wo.height+8,nc=Wo.isWrapped?ks-tc:0,oc=S?{position:"fixed",left:S.point.x-4-Zt.x,top:S.point.y-4-Zt.y-nc,zIndex:9999,width:Wo.width+8,height:ks,padding:4,fontSize:S.fontSize,fontFamily:zt,color:"#ffffff",backgroundColor:e.activeColor,border:"none",borderRadius:0,outline:"none",boxShadow:"none",lineHeight:1.4,resize:"none",overflow:"hidden",whiteSpace:Wo.isWrapped?"pre-wrap":"pre",wordBreak:Wo.isWrapped?"break-word":void 0}:{};return Bo(Oo,{children:[rt("canvas",{ref:H,id:"devtools-canvas",style:ec,onMouseDown:Es,onMouseMove:Cs,onMouseUp:m=>Gr(m),onMouseLeave:m=>{Gr(m),We(null),dt(null)},onTouchStart:Es,onTouchMove:Cs,onTouchEnd:m=>Gr(m),onContextMenu:Za}),S&&Bo(Oo,{children:[rt("style",{children:"#devtools-text-input::placeholder { color: rgba(255, 255, 255, 0.5); }"}),rt("textarea",{id:"devtools-text-input",ref:Te,value:S.text,onChange:Xa,onKeyDown:Ka,onPaste:qa,onBlur:yo,placeholder:"Type here...",style:oc}),S.images&&S.images.length>0&&Bo("div",{"data-devtools":!0,style:{position:"fixed",left:S.point.x-4-Zt.x,top:S.point.y-4-Zt.y-20,zIndex:1e4,fontSize:11,fontFamily:"system-ui, sans-serif",color:"#fff",backgroundColor:"rgba(0,0,0,0.7)",padding:"2px 6px",borderRadius:3,whiteSpace:"nowrap"},children:[S.images.length," image",S.images.length>1?"s":""," attached"]})]}),e.isAnnotating&&e.activeTool!=="hand"&&e.styleModifications.length>0&&rt(zl,{styleModifications:e.styleModifications,isInspecting:!!e.inspectedElement,accentColor:e.activeColor,annotationGroupCount:new Set(e.annotations.map(m=>m.groupId||m.id)).size,dispatch:t,inFlightSelectors:o,toolbarRef:L,onHoverSelector:he}),e.activeTool==="hand"&&e.isAnnotating&&e.styleModifications.length>0&&rt(Wl,{styleModifications:e.styleModifications,accentColor:e.activeColor}),e.isAnnotating&&rt(Ll,{annotations:e.annotations,supersededAnnotations:Wn,inFlightIds:r,scrollX:Zt.x,scrollY:Zt.y,annotationGroupMap:ir,onViewThread:a,onSelectAnnotation:Lt,onHoverAnnotation:te,canvasRef:T}),e.isAnnotating&&l&&rt(Al,{annotations:e.annotations,supersededAnnotations:Wn,scrollX:Zt.x,scrollY:Zt.y,onReply:l,annotationGroupMap:ir,canvasRef:T,onHoverAnnotation:te}),e.isAnnotating&&i&&i.size>0&&rt(vi,{inFlightSelectorColors:i}),e.isAnnotating&&xs&&rt(vi,{inFlightSelectorColors:xs,animated:!1}),e.activeTool==="hand"&&e.isAnnotating&&(ut?mt.current.element:vt)&&rt(Mi,{element:ut?mt.current.element:vt,gap:ut?{row:ut.row,column:ut.column}:Vo(vt),accentColor:e.activeColor,hoveredAxis:Ft,draggingAxis:(Ts=ut==null?void 0:ut.axis)!=null?Ts:null,cursorViewport:bt,isAutoGap:Re,refreshKey:cn}),e.activeTool==="hand"&&e.isAnnotating&&pt&&rt(sa,{element:pt.target,modifier:pt.modifier,accentColor:e.activeColor,refreshKey:cn}),e.activeTool==="hand"&&e.isAnnotating&&!pt&&(F?Ut.current.element:kt)&&rt(Nl,{element:F?Ut.current.element:kt,radius:(Is=F==null?void 0:F.radius)!=null?Is:io(kt),accentColor:e.activeColor,hoveredCorner:dn,draggingCorner:(Rs=F==null?void 0:F.corner)!=null?Rs:null,cursorViewport:bt}),e.activeTool==="hand"&&e.isAnnotating&&!pt&&(Je?oe.current.element:Se)&&rt(la,{element:Je?oe.current.element:Se,fontSize:(Ls=Je==null?void 0:Je.fontSize)!=null?Ls:Uo(Se).fontSize,lineHeight:(As=Je==null?void 0:Je.lineHeight)!=null?As:Uo(Se).lineHeight,accentColor:e.activeColor,hoveredProperty:pe,draggingProperty:(Ps=Je==null?void 0:Je.property)!=null?Ps:null,cursorViewport:bt}),e.activeTool==="hand"&&e.isAnnotating&&!pt&&(et?xe.current.element:Be)&&rt(Pi,{element:et?xe.current.element:Be,padding:(Bs=et==null?void 0:et.padding)!=null?Bs:ko(Be),accentColor:e.activeColor,hoveredSide:it,draggingSide:(Os=et==null?void 0:et.side)!=null?Os:null,cursorViewport:bt,refreshKey:Je?Je.fontSize+Je.lineHeight*1e3:0}),e.activeTool==="inspector"&&e.isAnnotating&&rt(Oo,{children:Ie&&!e.inspectedElement&&(()=>{let m=!!ue||!!(S!=null&&S.linkedSelector)||e.annotations.some(h=>{if(!h.linkedSelector)return!1;try{return Ie.matches(h.linkedSelector)}catch(V){return!1}});return rt(Ln,{element:Ie,isSelected:!1,elementInfo:lt,color:e.activeColor,hideTooltip:m})})()}),((S==null?void 0:S.linkedSelector)||(ue==null?void 0:ue.linkedSelector))&&(()=>{let m=(S==null?void 0:S.linkedSelector)||(ue==null?void 0:ue.linkedSelector);if(!m)return null;let h=null;try{h=document.querySelector(m)}catch(V){}return h?rt(Ln,{element:h,isSelected:!0,color:e.activeColor,hideTooltip:!0}):null})(),E&&(()=>{let m=e.annotations.find(M=>M.id===E);if(!(m!=null&&m.linkedSelector))return null;let h=null;try{h=document.querySelector(m.linkedSelector)}catch(M){}if(!h)return null;let V=!!(r&&r.has(m.id));return rt(Ln,{element:h,isSelected:!V,color:m.color,hideTooltip:!0})})(),W&&(()=>{let m=e.annotations.find(A=>A.id===W);if(!(m!=null&&m.linkedSelector))return null;let h=null;try{h=document.querySelector(m.linkedSelector)}catch(A){}if(!h)return null;let V=m.groupId?e.annotations.filter(A=>A.groupId===m.groupId):[m],M=!!(r&&V.some(A=>r.has(A.id)));return rt(Ln,{element:h,isSelected:!M,color:m.color,hideTooltip:!0})})(),j&&(()=>{let m=null;try{m=document.querySelector(j)}catch(V){}if(!m)return null;let h=!!(o&&o.has(j));return rt(Ln,{element:m,isSelected:!h,color:e.activeColor,hideTooltip:!0})})(),e.activeTool==="model"&&e.isAnnotating&&q.size>0&&[...q.entries()].map(([m,h])=>rt(Ln,{element:h.rootElement,isSelected:!0,elementInfo:{selector:"",tagName:h.rootElement.tagName.toLowerCase(),reactComponent:m},color:"#8b5cf6"},m)),e.activeTool==="model"&&e.isAnnotating&&rr&&rt(Ln,{element:rr.rootElement,isSelected:!0,elementInfo:{selector:"",tagName:rr.rootElement.tagName.toLowerCase(),reactComponent:rr.name},color:"#22c55e"}),e.activeTool==="model"&&e.isAnnotating&&bs.length>0&&bs.map((m,h)=>rt("div",{style:{position:"absolute",left:m.x,top:m.y,width:m.width,height:m.height,backgroundColor:"rgba(255, 0, 0, 0.08)",pointerEvents:"none",zIndex:9998},children:m.direction==="vertical"?Bo(Oo,{children:[rt("div",{style:{position:"absolute",left:"50%",top:0,width:6,height:1,backgroundColor:"#FF0000",transform:"translateX(-50%)"}}),rt("div",{style:{position:"absolute",left:"50%",top:0,bottom:0,width:1,backgroundColor:"#FF0000",transform:"translateX(-50%)"}}),rt("div",{style:{position:"absolute",left:"50%",bottom:0,width:6,height:1,backgroundColor:"#FF0000",transform:"translateX(-50%)"}}),rt("div",{style:{position:"absolute",left:"calc(50% + 6px)",top:m.height<16?-6:"50%",transform:m.height<16?"none":"translateY(-50%)",fontSize:11,fontWeight:600,color:"#fff",backgroundColor:"#FF0000",padding:"2px 4px",whiteSpace:"nowrap",fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',lineHeight:1},children:Math.round(m.height)})]}):Bo(Oo,{children:[rt("div",{style:{position:"absolute",left:0,top:"50%",width:1,height:6,backgroundColor:"#FF0000",transform:"translateY(-50%)"}}),rt("div",{style:{position:"absolute",left:0,right:0,top:"50%",height:1,backgroundColor:"#FF0000",transform:"translateY(-50%)"}}),rt("div",{style:{position:"absolute",right:0,top:"50%",width:1,height:6,backgroundColor:"#FF0000",transform:"translateY(-50%)"}}),rt("div",{style:{position:"absolute",left:m.width<30?0:"50%",top:(m.width<30,void 0),bottom:"calc(50% + 4px)",transform:m.width<30?"none":"translateX(-50%)",fontSize:11,fontWeight:600,color:"#fff",backgroundColor:"#FF0000",padding:"2px 4px",whiteSpace:"nowrap",fontFamily:'ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace',lineHeight:1},children:Math.round(m.width)})]})},h)),e.activeTool==="model"&&e.isAnnotating&&Pe&&rt(Ln,{element:Pe.rootElement,isSelected:!1,elementInfo:{selector:"",tagName:Pe.rootElement.tagName.toLowerCase(),reactComponent:Pe.name},color:g!=null&&g.has(Pe.name)?"#22c55e":"#8b5cf6"}),e.activeTool==="hand"&&e.isAnnotating&&e.inspectedElement&&Bo(Oo,{children:[Ct&&Ct!=="padding"&&Ct!=="gap"&&(()=>{var N;let m=new Set(e.annotations.map(J=>J.groupId||J.id)).size,h=e.inspectedElement.info.selector,V=e.styleModifications.findIndex(J=>J.selector===h),M=V>=0?m+V+1:m+e.styleModifications.length+1,A=e.styleModifications.find(J=>J.selector===h),z=(N=A==null?void 0:A.changes.length)!=null?N:0,ie=!!(A!=null&&A.captured);return rt(Ln,{element:e.inspectedElement.el,isSelected:!0,elementInfo:e.inspectedElement.info,color:ie?"#999999":e.activeColor,annotationNumber:M,changeCount:z})})(),Ct==="padding"&&rt(Pi,{element:e.inspectedElement.el,padding:ko(e.inspectedElement.el),accentColor:e.activeColor,hoveredSide:null,draggingSide:null}),Ct==="gap"&&rt(Mi,{element:e.inspectedElement.el,gap:Vo(e.inspectedElement.el),accentColor:e.activeColor,hoveredAxis:null,draggingAxis:null}),rt(ra,{element:e.inspectedElement.el,elementInfo:e.inspectedElement.info,selector:e.inspectedElement.info.selector,styleModifications:e.styleModifications,dispatch:t,onClose:()=>t({type:"SELECT_ELEMENT",payload:null}),onHover:Nt,accentColor:e.activeColor,toolbarRef:L})]})]})}import{useCallback as mn,useEffect as Mn,useMemo as ts,useRef as Bt,useState as tr}from"react";import{Circle as Op,Component as Dp,Hand as Np,MessageCircle as Hp,Pen as Fp,Slash as _p,Square as zp,Trash2 as $p,Type as Wp}from"lucide-react";import{useEffect as Fu,useRef as _u}from"react";function ua(e,t,n,r,o){let i=_u(0);Fu(()=>{if(!n.current||(localStorage.setItem(o.expanded,String(e)),!e))return;let s=t.annotations.length;(s>=i.current||s===0||!r)&&(localStorage.setItem(o.annotations,JSON.stringify(t.annotations)),i.current=s),localStorage.setItem(o.styleMods,JSON.stringify(t.styleModifications)),localStorage.setItem(o.spacingChanges,JSON.stringify(t.spacingTokenChanges)),localStorage.setItem(o.tool,t.activeTool),localStorage.setItem(o.color,t.activeColor),localStorage.setItem(o.stroke,String(t.strokeWidth)),t.inspectedElement?localStorage.setItem(o.inspected,JSON.stringify({selector:t.inspectedElement.info.selector,info:t.inspectedElement.info})):localStorage.removeItem(o.inspected)},[e,t.annotations,t.styleModifications,t.spacingTokenChanges,t.activeTool,t.activeColor,t.strokeWidth,t.inspectedElement,r,n,o])}import{Component as op,createElement as rp,useCallback as Fr,useEffect as po,useRef as Do,useState as gn}from"react";import{Link2 as ip}from"lucide-react";var zu={colors:[],fonts:[],typeScale:[],spacing:[],radii:[],shadows:[],other:[],references:{}},$u=/^#[0-9a-fA-F]{3,8}$/,Wu=/^(?:rgba?|hsla?|oklch|oklab|lch|lab)\(/,Yu=new Set(["transparent","currentcolor","inherit","white","black","red","green","blue","yellow","orange","purple","pink","gray","grey","cyan","magenta","brown","navy","teal","maroon","olive","silver","aqua","fuchsia","lime"]);function fa(e){let t=e.trim().toLowerCase();return $u.test(t)||Wu.test(t)||Yu.has(t)}var ju=/^-?\d+(\.\d+)?(px|rem|em|%)$/;function Ji(e){return ju.test(e.trim())}var pa=new Set(["serif","sans-serif","monospace","cursive","fantasy","system-ui","ui-serif","ui-sans-serif","ui-monospace","ui-rounded"]);function Gu(e){let t=e.trim().toLowerCase();return!!(pa.has(t)||t.includes(",")&&t.split(",").some(n=>pa.has(n.trim().replace(/['"]/g,""))))}function Vu(e){let t=e.trim().toLowerCase(),n=t.match(/\d+(\.\d+)?px/g);return!!(n&&n.length>=2&&(fa(t.replace(/[^#()\w,.\s/%]/g,"").split(/\s+/).pop()||"")||t.includes("rgb")||t.includes("hsl")||t.includes("#")))}var Uu=/(?:^--(color|bg|fg|accent|border-color|text-color|surface|background|foreground))|(?:-(color|bg|fg)$)/i,Ju=/^--(font-family|font|ff|family)/i,Xu=/^--(font-size|text-size|fs|text-(?:xs|sm|base|md|lg|xl|2xl|3xl|4xl|5xl))/i,Ku=/^--(space|gap|padding|margin|inset)/i,qu=/^--(radius|rounded|br|border-radius)/i,Zu=/^--(shadow|elevation|drop-shadow)/i;function ga(e,t){let n=e.toLowerCase();return Zu.test(n)?"shadows":qu.test(n)?"radii":Ju.test(n)?"fonts":Xu.test(n)&&Ji(t)?"typeScale":Uu.test(n)||fa(t)?"colors":Gu(t)?"fonts":Vu(t)?"shadows":Ku.test(n)&&Ji(t)||Ji(t)?"spacing":"other"}function ma(e,t,n,r){if(e)for(let o of e){if(o instanceof CSSGroupingRule){ma(o.cssRules,t,n,r);continue}if(o instanceof CSSStyleRule){let i=o.selectorText.toLowerCase();(i===":root"||i==="html"||i==="*"||i.includes(":root"))&&Qu(o.style,t,n,r)}}}var ha=/var\((--[^,)]+)/;function Qu(e,t,n,r){for(let o=0;o<e.length;o++){let i=e[o];if(!(i!=null&&i.startsWith("--"))||n.has(i))continue;n.add(i);let s=t.getPropertyValue(i).trim();if(!s)continue;let l=ga(i,s);r[l].push([i,s]);let c=e.getPropertyValue(i).trim().match(ha);c&&(r.references[i]=c[1])}}function Or(e){let t=e.trim().match(/^(-?\d+(?:\.\d+)?)/);return t?parseFloat(t[1]):null}function Nr(e){let t=e.trim().toLowerCase(),n=t.match(/oklch\(\s*([\d.]+%?)/);if(n){let i=n[1];return i.endsWith("%")?parseFloat(i)/100:parseFloat(i)}let r=t.match(/rgba?\(\s*(\d+)[,\s]+(\d+)[,\s]+(\d+)/);if(r){let[i,s,l]=[parseInt(r[1],10),parseInt(r[2],10),parseInt(r[3],10)];return(.2126*i+.7152*s+.0722*l)/255}let o=t.match(/hsla?\(\s*[\d.]+[,\s]+[\d.]+%?[,\s]+([\d.]+)%?/);if(o)return parseFloat(o[1])/100;if(t.startsWith("#")){let i=t.slice(1);(i.length===3||i.length===4)&&(i=i[0]+i[0]+i[1]+i[1]+i[2]+i[2]);let s=parseInt(i.slice(0,2),16),l=parseInt(i.slice(2,4),16),a=parseInt(i.slice(4,6),16);if(!isNaN(s))return(.2126*s+.7152*l+.0722*a)/255}return null}function ya(e){return e==="colors"?(t,n)=>{let r=Nr(t[1]),o=Nr(n[1]);return r!==null&&o!==null?r-o:t[0].localeCompare(n[0])}:e==="typeScale"||e==="spacing"||e==="radii"?(t,n)=>{let r=Or(t[1]),o=Or(n[1]);return r!==null&&o!==null?r-o:t[0].localeCompare(n[0])}:e==="other"?(t,n)=>{let r=Or(t[1]),o=Or(n[1]);return r!==null&&o!==null?r-o:t[0].localeCompare(n[0])}:(t,n)=>t[0].localeCompare(n[0])}function ep(e){let t=e.replace(/^--/,"");t=t.replace(/^(?:color|clr)-/,"");let n=t.split("-");return n.length>1&&/^\d+$/.test(n[n.length-1])&&n.pop(),n.join("-")}function ba(e){let t=new Map;for(let o of e){let i=ep(o[0]),s=t.get(i);s||(s=[],t.set(i,s)),s.push(o)}let n=ya("colors");for(let o of t.values())o.sort(n);let r=[...t.entries()];return r.sort((o,i)=>{var a,c;let s=(a=Nr(o[1][0][1]))!=null?a:0,l=(c=Nr(i[1][0][1]))!=null?c:0;return s-l}),r}var tp=["colors","fonts","typeScale","spacing","radii","shadows","other"],Dr=null,np=5e3;function xa(){if(typeof document=="undefined")return zu;if(Dr&&Date.now()-Dr.timestamp<np)return Dr.tokens;let e={colors:[],fonts:[],typeScale:[],spacing:[],radii:[],shadows:[],other:[],references:{}},t=new Set,n=getComputedStyle(document.documentElement);try{for(let o of document.styleSheets)try{ma(o.cssRules||o.rules,n,t,e)}catch(i){}}catch(o){}let r=document.documentElement.style;for(let o=0;o<r.length;o++){let i=r[o];if(!(i!=null&&i.startsWith("--"))||t.has(i))continue;t.add(i);let s=n.getPropertyValue(i).trim();if(!s)continue;let l=ga(i,s);e[l].push([i,s]);let c=r.getPropertyValue(i).trim().match(ha);c&&(e.references[i]=c[1])}for(let o of tp)e[o].sort(ya(o));return Dr={tokens:e,timestamp:Date.now()},e}import{Fragment as No,jsx as De,jsxs as Gt}from"react/jsx-runtime";var Sa="popmelt-library-tab",sp=/^#[0-9a-fA-F]{3,8}$/,lp=/^(?:rgba?|hsla?|oklch)\([^)]+\)$/,ap=new Set(["black","white","red","blue","green","yellow","orange","purple","pink","gray","grey","cyan","magenta","brown","navy","teal","maroon","olive","silver","aqua","fuchsia","lime"]),cp=/^-?\d+(\.\d+)?(px|rem|em|%)$/;function wa(e){let t=e.trim();return sp.test(t)||lp.test(t)||ap.has(t.toLowerCase())}function dp(e){return cp.test(e.trim())}function up(e){let t=e.trim().match(/^(-?\d+(?:\.\d+)?)px$/);return t?parseFloat(t[1]):null}function Ea(e,t=""){if(e==null)return[];if(typeof e!="object")return[[t,String(e)]];if(Array.isArray(e))return[[t,e.map(String).join(", ")]];let n=[];for(let[r,o]of Object.entries(e)){let i=t?`${t}.${r}`:r;if(o!==null&&typeof o=="object"&&!Array.isArray(o)){let s=o;typeof s.value=="string"?n.push([i,s.value]):n.push(...Ea(o,i))}else n.push([i,Array.isArray(o)?o.map(String).join(", "):String(o!=null?o:"")])}return n}function pp(e){return e.length===0?"generic":e.filter(([,r])=>wa(r)).length>e.length/2?"colors":e.filter(([,r])=>dp(r)).length>e.length/2?"spacing":"generic"}var fp=y(f({position:"fixed",top:16,right:16,bottom:80,width:300,backgroundColor:"#eaeaea"},En),{boxSizing:"content-box",zIndex:10001,display:"flex",flexDirection:"column",overflow:"hidden",fontFamily:"ui-monospace, SFMono-Regular, Menlo, Consolas, monospace",fontSize:12,color:"#1f2937",padding:12,pointerEvents:"auto"}),Ca={border:"none",background:"none",cursor:"pointer",fontFamily:"inherit",fontSize:11,fontWeight:600,padding:"2px 0",color:"#9ca3af"},gp=y(f({},Ca),{color:"#1f2937",borderBottom:"1.5px solid #1f2937"});function mp({varName:e,value:t,reference:n}){return De("div",{title:n?`${e} \u2192 ${n}
12
+ ${t}`:`${e}: ${t}`,style:{width:28,height:28,backgroundColor:t,outline:"1px solid rgba(0,0,0,0.08)",outlineOffset:-1,position:"relative"},children:n&&De(ip,{size:10,strokeWidth:2.5,style:{position:"absolute",top:"50%",left:"50%",transform:"translate(-50%, -50%)",color:"white",filter:"drop-shadow(0 0 1px rgba(0,0,0,0.5))"}})})}function ka({entries:e,references:t}){let n=[],r=[];for(let i of e)wa(i[1])?n.push(i):r.push(i);let o=ba(n);return Gt(No,{children:[o.map(([i,s])=>Gt("div",{style:{marginBottom:4},children:[Gt("div",{style:{fontSize:10,color:"#9ca3af",marginBottom:2},children:[i,s.length>1?` (${s.length})`:""]}),De("div",{style:{display:"flex",flexWrap:"wrap",gap:2},children:s.map(([l,a])=>De(mp,{varName:l,value:a,reference:t[l]},l))})]},i)),r.length>0&&De(_r,{entries:r})]})}var Hr=[0,1,2,4,8,12,16,20,24,28,32];function hp(e){if(e<=32){let t=Hr[0],n=Math.abs(e-t);for(let r=1;r<Hr.length;r++){let o=Math.abs(e-Hr[r]);o<n&&(t=Hr[r],n=o)}return t}return Math.round(e/8)*8}function yp({label:e,value:t,px:n,tokenPath:r,rawToken:o,onHover:i,onModify:s,onDelete:l}){let[a,c]=gn(!1),[d,u]=gn(null),p=Do(!1),g=Do(0),k=Do(0),w=Do([]),b=d!==null?d:n,E=d!==null?`${d}px`:t,B=d!==null,L=Fr(v=>{v.preventDefault(),p.current=!0,g.current=v.clientX,k.current=n;let O=yr(o);w.current=pi(O);let H=G=>{let X=G.clientX-g.current,S=Math.max(0,Math.round(k.current+X));G.shiftKey&&(S=hp(S));for(let I of w.current)I.element.style.setProperty(I.property,S+"px","important");u(S),i==null||i({name:e,px:S,token:O})},U=()=>{window.removeEventListener("mousemove",H),window.removeEventListener("mouseup",U),document.body.style.cursor="",p.current=!1,u(G=>{if(G!==null&&G!==n&&s){let X=yr(o),S=X.bindings&&X.bindings.length>0,I;if(S){let de=gi(X.bindings,k.current,G);I=JSON.stringify(y(f({},X),{value:`${G}px`,bindings:de}))}else{let de=vl(w.current,k.current),ue=wl(w.current);if(de.length>0){let Fe=gi(de,k.current,G);I=JSON.stringify({value:`${G}px`,property:ue,bindings:Fe})}else I=`${G}px`}let K=typeof o=="string"?o:JSON.stringify(o),ge=w.current.map(de=>({selector:un(de.element),property:de.property})),be=Cl(w.current,k.current,G);s({tokenPath:r,originalValue:K,currentValue:I,targets:ge,originalPx:k.current,currentPx:G},{id:Math.random().toString(36).substring(2,9),tokenPath:r,tokenName:e,originalPx:k.current,newPx:G,affectedElements:be})}return G})};document.body.style.cursor="ew-resize",window.addEventListener("mousemove",H),window.addEventListener("mouseup",U)},[n,e,r,o,i,s]),T=yr(o);return Gt("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",fontSize:11,padding:"1px 0",cursor:"ew-resize",userSelect:"none"},onMouseEnter:()=>{p.current||(c(!0),i==null||i({name:e,px:b,token:T}))},onMouseLeave:()=>{p.current||(c(!1),i==null||i(null))},onMouseDown:L,children:[De("span",{style:{color:a||B?"#FF0000":"#9ca3af"},children:e}),Gt("span",{style:{display:"flex",alignItems:"center",gap:4},children:[De("span",{style:{color:a||B?"#FF0000":"#6b7280",fontWeight:600},children:E}),l&&a&&!B&&De("button",{type:"button",title:"Remove token",onMouseDown:v=>{v.stopPropagation();let O=typeof o=="string"?o:JSON.stringify(o);l(r,O)},style:{border:"none",background:"none",cursor:"pointer",padding:0,fontSize:10,lineHeight:1,color:"#9ca3af"},onMouseEnter:v=>{v.currentTarget.style.color="#FF0000"},onMouseLeave:v=>{v.currentTarget.style.color="#9ca3af"},children:"\u2715"})]})]})}function bp({entries:e,categoryKey:t,rawTokens:n,onHover:r,onModify:o,onDelete:i}){let s=[],l=[];for(let a of e){let c=up(a[1]);c!==null?s.push([a[0],a[1],c]):l.push(a)}return Gt(No,{children:[s.length>0&&De("div",{style:{display:"flex",flexDirection:"column",gap:2},children:s.map(([a,c,d])=>{let u=a.split(".").pop(),p=n?xp(n,a):c,g=p&&typeof p=="object"&&"value"in p?p:c;return De(yp,{label:u,value:c,px:d,tokenPath:`tokens.${t}.${a}`,rawToken:g,onHover:r,onModify:o,onDelete:i},a)})}),l.length>0&&De(_r,{entries:l})]})}function xp(e,t){let n=t.split("."),r=e;for(let o of n){if(r==null||typeof r!="object")return;r=r[o]}return r}function _r({entries:e}){return De("div",{style:{display:"flex",flexDirection:"column",gap:3},children:e.map(([t,n])=>Gt("div",{style:{fontSize:11},children:[De("div",{style:{color:"#9ca3af",fontSize:10,marginBottom:1},children:t}),De("div",{style:{color:"#1f2937",lineHeight:1.4,paddingLeft:8},children:n})]},t))})}function Sp({entries:e,categoryKey:t,rawTokens:n,onSpacingHover:r,onModifyToken:o,onDeleteToken:i}){let s=pp(e);return s==="colors"?De(ka,{entries:e}):s==="spacing"?De(bp,{entries:e,categoryKey:t,rawTokens:n,onHover:r,onModify:o,onDelete:i}):De(_r,{entries:e})}function vp(e){let t=e.toLowerCase(),n=null,r=document.createTreeWalker(document.body,NodeFilter.SHOW_ELEMENT,{acceptNode(i){return i.closest("#devtools-toolbar, #devtools-canvas, #devtools-scrim, [data-popmelt-panel]")?NodeFilter.FILTER_REJECT:NodeFilter.FILTER_ACCEPT}}),o=r.currentNode;for(;o=r.nextNode();){let i=o,s=Object.keys(i).find(a=>a.startsWith("__reactFiber$")||a.startsWith("__reactInternalInstance$"));if(!s)continue;let l=i[s];for(;l;){let a=l.type,c=typeof a=="function"||typeof a=="object"?(a==null?void 0:a.displayName)||(a==null?void 0:a.name):null;if(typeof c=="string"){let d=c.toLowerCase();if(d===t){let u=f({},l.memoizedProps);return delete u.ref,{type:a,props:u}}if(!n){if(d.length>=4&&t.includes(d)){let u=f({},l.memoizedProps);delete u.ref,n={type:a,props:u}}else if(t.length>=4&&d.includes(t)){let u=f({},l.memoizedProps);delete u.ref,n={type:a,props:u}}}}l=l.return}}return n}var Xi=class extends op{constructor(){super(...arguments);this.state={hasError:!1}}static getDerivedStateFromError(){return{hasError:!0}}componentDidCatch(){this.props.onError()}render(){return this.state.hasError?null:this.props.children}},Ma="popmelt-principles-collapsed";function wp(){try{let e=localStorage.getItem(Ma);if(e)return new Set(JSON.parse(e))}catch(e){}return new Set}function Ep(e){try{localStorage.setItem(Ma,JSON.stringify([...e]))}catch(t){}}function Cp({id:e,label:t,count:n,children:r,collapsed:o,onToggle:i}){return Gt("div",{style:{marginBottom:14},children:[Gt("div",{onClick:()=>i(e),style:{fontWeight:700,fontSize:11,color:"#6b7280",letterSpacing:"0.05em",marginBottom:o?0:6,cursor:"pointer",display:"flex",alignItems:"center",gap:4,userSelect:"none"},children:[De("span",{style:{display:"inline-flex",alignItems:"center",justifyContent:"center",width:10,fontSize:9,color:"#9ca3af",transform:o?"rotate(-90deg)":"rotate(0deg)"},children:"\u25BC"}),t,De("span",{style:{fontWeight:400,color:"#9ca3af"},children:n})]}),!o&&r]})}var kp={colors:"Colors",fonts:"Fonts",typeScale:"Type Scale",spacing:"Spacing",radii:"Radii",shadows:"Shadows",other:"Other"},va=["colors","fonts","typeScale","spacing","radii","shadows","other"];function Mp(){let[e,t]=gn(null),[n,r]=gn(wp);po(()=>{t(xa())},[]);let o=Fr(s=>{r(l=>{let a=new Set(l);return a.has(s)?a.delete(s):a.add(s),Ep(a),a})},[]);return e?va.some(s=>e[s].length>0)?De(No,{children:va.map(s=>{let l=e[s];return l.length===0?null:De(Cp,{id:s,label:kp[s],count:l.length,collapsed:n.has(s),onToggle:o,children:s==="colors"?De(ka,{entries:l,references:e.references}):De(_r,{entries:l})},s)})}):De("div",{style:{color:"#9ca3af",fontSize:11},children:"No :root tokens found."}):null}function Tp({rules:e}){return!e||e.length===0?De("div",{style:{color:"#9ca3af",fontSize:11},children:"No rules defined yet."}):De(No,{children:e.map((t,n)=>Gt("div",{style:{display:"flex",gap:6,marginBottom:4,lineHeight:1.4,fontSize:11},children:[Gt("span",{style:{color:"#9ca3af",flexShrink:0},children:[n+1,"."]}),De("span",{children:t})]},n))})}function Ip({name:e,value:t,selected:n,highlighted:r,onRemove:o,onHover:i}){var G;let[s,l]=gn(!1),[a,c]=gn(!1),d=Do(null),u=Do(0),[p,g]=gn(0),[k,w]=gn(0),b=Ea(t),E=(G=b.find(([X])=>X==="description"))==null?void 0:G[1];po(()=>{if(!a&&!r){g(0),w(0),u.current=0;return}let X=Eo(e);g(X.length)},[a,r,e]),po(()=>{n&&d.current&&d.current.scrollIntoView({behavior:"smooth",block:"nearest"})},[n]);let B=n||r||a,L=n?"139,92,246":"34,197,94",T=n?"#8b5cf6":"#22c55e",v=B?`rgba(${L},0.06)`:void 0,O=B?`inset 0 0 0 1.5px rgba(${L},0.35)`:void 0,H=r||a,U=Fr(()=>{let X=Eo(e);if(X.length===0)return;let S=u.current%X.length;X[S].rootElement.scrollIntoView({behavior:"smooth",block:"center"}),w(S),u.current=S+1,i==null||i({name:e,instanceIndex:S})},[e,i]);return Gt("div",{ref:d,onClick:U,onMouseEnter:()=>{c(!0),i==null||i({name:e,instanceIndex:0})},onMouseLeave:()=>{c(!1),i==null||i(null)},style:{marginBottom:8,background:v,padding:6,boxShadow:O,cursor:"pointer"},children:[Gt("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between"},children:[Gt("div",{style:{display:"flex",alignItems:"center",gap:6,marginBottom:6},children:[De("div",{style:{fontWeight:700,fontSize:11,letterSpacing:"0.05em",padding:"2px 6px",backgroundColor:H?T:"transparent",color:H?"#fff":"#6b7280"},children:e}),H&&p>1&&Gt("span",{style:{fontSize:10,fontWeight:600,color:"#9ca3af"},children:[k+1,"/",p]})]}),o&&a&&De("button",{type:"button",title:"Remove from model",onClick:X=>{X.stopPropagation(),o(e)},style:{border:"none",background:"none",cursor:"pointer",padding:"0 2px",fontSize:14,lineHeight:1,color:"#9ca3af",marginTop:-4},onMouseEnter:X=>{X.currentTarget.style.color="#FF0000"},onMouseLeave:X=>{X.currentTarget.style.color="#9ca3af"},children:"\u2715"})]}),E&&De("div",{style:{fontSize:11,color:H?"#1f2937":"#9ca3af",marginBottom:6,lineHeight:1.4},children:E}),s?De(Sp,{entries:b.filter(([X])=>X!=="description"),categoryKey:""}):De(Rp,{name:e,onNotFound:()=>l(!0),entries:b})]})}function Rp({name:e,onNotFound:t}){let[n,r]=gn(null),[o,i]=gn(!1);return po(()=>{let s=vp(e);s||t(),r(s),i(!0)},[e,t]),!o||!n?null:De(Xi,{onError:t,children:De("div",{"data-popmelt-panel":!0,onClick:s=>{s.preventDefault(),s.stopPropagation()},style:{width:"100%",overflowY:"auto",overflowX:"hidden",maxHeight:150,padding:"1rem",outline:"1px solid rgba(0,0,0,0.06)",backgroundColor:"rgb(250,250,250)",boxSizing:"border-box",marginBottom:4,display:"flex",flexDirection:"column",justifyContent:"stretch",alignItems:"center",contain:"layout paint",position:"relative",isolation:"isolate"},children:De("div",{style:{zoom:.5,pointerEvents:"none"},children:rp(n.type,n.props)})})})}function Lp({components:e,selectedComponent:t,hoveredComponent:n,onRemove:r,onHover:o}){if(!e||Object.keys(e).length===0)return De("div",{style:{color:"#9ca3af",fontSize:11},children:"No component patterns defined yet."});let i=new Set(Object.keys(e)),s=ci(i),l=Object.entries(e).sort(([a],[c])=>{var d,u;return((d=s.get(a))!=null?d:1/0)-((u=s.get(c))!=null?u:1/0)});return De(No,{children:l.map(([a,c])=>De(Ip,{name:a,value:c,selected:t===a,highlighted:n===a,onRemove:r,onHover:o},a))})}function Ta({bridgeUrl:e,modelRefreshKey:t,onMouseEnter:n,onMouseLeave:r,selectedComponent:o,hoveredComponent:i,onComponentHover:s,onSpacingTokenHover:l,onModifySpacingToken:a,onDeleteSpacingToken:c,onComponentAdded:d,onComponentRemoved:u}){let[p,g]=gn(void 0),[k,w]=gn(!0),[b,E]=gn(()=>{try{let H=localStorage.getItem(Sa);if(H==="patterns"||H==="principles"||H==="rules")return H}catch(H){}return"patterns"});po(()=>{xo(e).then(H=>{g(H),w(!1)})},[e,t]),po(()=>{try{localStorage.setItem(Sa,b)}catch(H){}},[b]),po(()=>{o&&(E("patterns"),xo(e).then(H=>{H&&g(H)}))},[o,e]);let B=Fr(H=>{g(U=>{if(!(U!=null&&U.components))return U;let S=U.components,{[H]:G}=S,X=Yn(S,[dr(H)]);return y(f({},U),{components:X})}),u==null||u(H)},[u]),L=p==null?void 0:p.components,T=p==null?void 0:p.rules,v=L&&Object.keys(L).length>0,O=T&&T.length>0;return Gt("div",{style:fp,onMouseEnter:n,onMouseLeave:r,children:[Gt("div",{style:{display:"flex",alignItems:"center",gap:6,fontWeight:700,fontSize:13,marginBottom:6},children:[De("span",{children:"Model"}),De("code",{style:{fontSize:10,fontWeight:500,backgroundColor:"rgba(0,0,0,0.06)",padding:"1px 4px",color:"#6b7280"},children:"M"})]}),De("div",{style:{display:"flex",gap:12,marginBottom:10,borderBottom:"1px solid rgba(0,0,0,0.08)",paddingBottom:6},children:["patterns","principles","rules"].map(H=>De("button",{type:"button",style:b===H?gp:Ca,onClick:()=>E(H),children:H.charAt(0).toUpperCase()+H.slice(1)},H))}),De("div",{style:{flex:1,overflowY:"auto",minHeight:0},children:b==="principles"?De(Mp,{}):k?De("div",{style:{color:"#9ca3af",fontSize:11},children:"Loading..."}):!p||!v&&!O?De("div",{style:{color:"#9ca3af",lineHeight:1.5},children:"No design model yet. Pattern-scoped annotations will build one automatically."}):Gt(No,{children:[b==="patterns"&&De(Lp,{components:L,selectedComponent:o,hoveredComponent:i,onRemove:B,onHover:s}),b==="rules"&&De(Tp,{rules:T})]})})]})}import{jsx as Ho}from"react/jsx-runtime";var Ap="M 233.959793 800.214905 L 468.644287 668.536987 L 472.590637 657.100647 L 468.644287 650.738403 L 457.208069 650.738403 L 417.986633 648.322144 L 283.892639 644.69812 L 167.597321 639.865845 L 54.926208 633.825623 L 26.577238 627.785339 L 3.3e-05 592.751709 L 2.73832 575.27533 L 26.577238 559.248352 L 60.724873 562.228149 L 136.187973 567.382629 L 249.422867 575.194763 L 331.570496 580.026978 L 453.261841 592.671082 L 472.590637 592.671082 L 475.328857 584.859009 L 468.724915 580.026978 L 463.570557 575.194763 L 346.389313 495.785217 L 219.543671 411.865906 L 153.100723 363.543762 L 117.181267 339.060425 L 99.060455 316.107361 L 91.248367 266.01355 L 123.865784 230.093994 L 167.677887 233.073853 L 178.872513 236.053772 L 223.248367 270.201477 L 318.040283 343.570496 L 441.825592 434.738342 L 459.946411 449.798706 L 467.194672 444.64447 L 468.080597 441.020203 L 459.946411 427.409485 L 392.617493 305.718323 L 320.778564 181.932983 L 288.80542 130.630859 L 280.348999 99.865845 C 277.369171 87.221436 275.194641 76.590698 275.194641 63.624268 L 312.322174 13.20813 L 332.8591 6.604126 L 382.389313 13.20813 L 403.248352 31.328979 L 434.013519 101.71814 L 483.865753 212.537048 L 561.181274 363.221497 L 583.812134 407.919434 L 595.892639 449.315491 L 600.40271 461.959839 L 608.214783 461.959839 L 608.214783 454.711609 L 614.577271 369.825623 L 626.335632 265.61084 L 637.771851 131.516846 L 641.718201 93.745117 L 660.402832 48.483276 L 697.530334 24.000122 L 726.52356 37.852417 L 750.362549 72 L 747.060486 94.067139 L 732.886047 186.201416 L 705.100708 330.52356 L 686.979919 427.167847 L 697.530334 427.167847 L 709.61084 415.087341 L 758.496704 350.174561 L 840.644348 247.490051 L 876.885925 206.738342 L 919.167847 161.71814 L 946.308838 140.29541 L 997.61084 140.29541 L 1035.38269 196.429626 L 1018.469849 254.416199 L 965.637634 321.422852 L 921.825562 378.201538 L 859.006714 462.765259 L 819.785278 530.41626 L 823.409424 535.812073 L 832.75177 534.92627 L 974.657776 504.724915 L 1051.328979 490.872559 L 1142.818848 475.167786 L 1184.214844 494.496582 L 1188.724854 514.147644 L 1172.456421 554.335693 L 1074.604126 578.496765 L 959.838989 601.449829 L 788.939636 641.879272 L 786.845764 643.409485 L 789.261841 646.389343 L 866.255127 653.637634 L 899.194702 655.409424 L 979.812134 655.409424 L 1129.932861 666.604187 L 1169.154419 692.537109 L 1192.671265 724.268677 L 1188.724854 748.429688 L 1128.322144 779.194641 L 1046.818848 759.865845 L 856.590759 714.604126 L 791.355774 698.335754 L 782.335693 698.335754 L 782.335693 703.731567 L 836.69812 756.885986 L 936.322205 846.845581 L 1061.073975 962.81897 L 1067.436279 991.490112 L 1051.409424 1014.120911 L 1034.496704 1011.704712 L 924.885986 929.234924 L 882.604126 892.107544 L 786.845764 811.48999 L 780.483276 811.48999 L 780.483276 819.946289 L 802.550415 852.241699 L 919.087341 1027.409424 L 925.127625 1081.127686 L 916.671204 1098.604126 L 886.469849 1109.154419 L 853.288696 1103.114136 L 785.073914 1007.355835 L 714.684631 899.516785 L 657.906067 802.872498 L 650.979858 806.81897 L 617.476624 1167.704834 L 601.771851 1186.147705 L 565.530212 1200 L 535.328857 1177.046997 L 519.302124 1139.919556 L 535.328857 1066.550537 L 554.657776 970.792053 L 570.362488 894.68457 L 584.536926 800.134277 L 592.993347 768.724976 L 592.429626 766.630859 L 585.503479 767.516968 L 514.22821 865.369263 L 405.825531 1011.865906 L 320.053711 1103.677979 L 299.516815 1111.812256 L 263.919525 1093.369263 L 267.221497 1060.429688 L 287.114136 1031.114136 L 405.825531 880.107361 L 477.422913 786.52356 L 523.651062 732.483276 L 523.328918 724.671265 L 520.590698 724.671265 L 205.288605 929.395935 L 149.154434 936.644409 L 124.993355 914.01355 L 127.973183 876.885986 L 139.409409 864.80542 L 234.201385 799.570435 L 233.879227 799.8927 Z",Pp="M60.8734,57.2556v-14.9432c0-1.2586.4722-2.2029,1.5728-2.8314l30.0443-17.3023c4.0899-2.3593,8.9662-3.4599,13.9988-3.4599,18.8759,0,30.8307,14.6289,30.8307,30.2006,0,1.1007,0,2.3593-.158,3.6178l-31.1446-18.2467c-1.8872-1.1006-3.7754-1.1006-5.6629,0l-39.4812,22.9651ZM131.0276,115.4561v-35.7074c0-2.2028-.9446-3.7756-2.8318-4.8763l-39.481-22.9651,12.8982-7.3934c1.1007-.6285,2.0453-.6285,3.1458,0l30.0441,17.3024c8.6523,5.0341,14.4708,15.7296,14.4708,26.1107,0,11.9539-7.0769,22.965-18.2461,27.527v.0021ZM51.593,83.9964l-12.8982-7.5497c-1.1007-.6285-1.5728-1.5728-1.5728-2.8314v-34.6048c0-16.8303,12.8982-29.5722,30.3585-29.5722,6.607,0,12.7403,2.2029,17.9324,6.1349l-30.987,17.9324c-1.8871,1.1007-2.8314,2.6735-2.8314,4.8764v45.6159l-.0014-.0015ZM79.3562,100.0403l-18.4829-10.3811v-22.0209l18.4829-10.3811,18.4812,10.3811v22.0209l-18.4812,10.3811ZM91.2319,147.8591c-6.607,0-12.7403-2.2031-17.9324-6.1344l30.9866-17.9333c1.8872-1.1005,2.8318-2.6728,2.8318-4.8759v-45.616l13.0564,7.5498c1.1005.6285,1.5723,1.5728,1.5723,2.8314v34.6051c0,16.8297-13.0564,29.5723-30.5147,29.5723v.001ZM53.9522,112.7822l-30.0443-17.3024c-8.652-5.0343-14.471-15.7296-14.471-26.1107,0-12.1119,7.2356-22.9652,18.403-27.5272v35.8634c0,2.2028.9443,3.7756,2.8314,4.8763l39.3248,22.8068-12.8982,7.3938c-1.1007.6287-2.045.6287-3.1456,0ZM52.2229,138.5791c-17.7745,0-30.8306-13.3713-30.8306-29.8871,0-1.2585.1578-2.5169.3143-3.7754l30.987,17.9323c1.8871,1.1005,3.7757,1.1005,5.6628,0l39.4811-22.807v14.9435c0,1.2585-.4721,2.2021-1.5728,2.8308l-30.0443,17.3025c-4.0898,2.359-8.9662,3.4605-13.9989,3.4605h.0014ZM91.2319,157.296c19.0327,0,34.9188-13.5272,38.5383-31.4594,17.6164-4.562,28.9425-21.0779,28.9425-37.908,0-11.0112-4.719-21.7066-13.2133-29.4143.7867-3.3035,1.2595-6.607,1.2595-9.909,0-22.4929-18.2471-39.3247-39.3251-39.3247-4.2461,0-8.3363.6285-12.4262,2.045-7.0792-6.9213-16.8318-11.3254-27.5271-11.3254-19.0331,0-34.9191,13.5268-38.5384,31.4591C11.3255,36.0212,0,52.5373,0,69.3675c0,11.0112,4.7184,21.7065,13.2125,29.4142-.7865,3.3035-1.2586,6.6067-1.2586,9.9092,0,22.4923,18.2466,39.3241,39.3248,39.3241,4.2462,0,8.3362-.6277,12.426-2.0441,7.0776,6.921,16.8302,11.3251,27.5271,11.3251Z";function Ki({size:e=16,style:t}){return Ho("svg",{width:e,height:e,viewBox:"0 0 1200 1200",fill:"currentColor",stroke:"none",style:f({flexShrink:0},t),children:Ho("path",{d:Ap})})}function qi({size:e=16,style:t}){return Ho("svg",{width:e,height:e,viewBox:"0 0 158.7128 157.296",fill:"currentColor",stroke:"none",style:f({flexShrink:0},t),children:Ho("path",{d:Pp})})}function Zi({provider:e,size:t=16,style:n}){return e==="codex"?Ho(qi,{size:t,style:n}):Ho(Ki,{size:t,style:n})}var Qo=[{id:"claude-opus-4-6",label:"Opus 4.6"},{id:"claude-sonnet-4-6",label:"Sonn 4.6"}],er=[{id:"gpt-5.3-codex",label:"Codex 5.3"},{id:"gpt-5.3-codex-spark",label:"Spark 5.3"},{id:"gpt-5.1-codex-mini",label:"Mini 5.1"}];var Bp=[...Qo,...er];function Qi(e,t){if(!e)return t==="codex"?"Codex":"Claude Code";let n=Bp.find(r=>r.id===e);return n?n.label:e.replace(/-\d{8,}$/,"")}import{jsx as Ia}from"react/jsx-runtime";var Fn={iconDefault:"#1f2937",iconActive:"#1f2937",bgActive:"#dedede",bgHover:"#e2e2e2",separator:"#e5e7eb"};function _n({children:e,active:t,siblingActive:n,disabled:r,onClick:o,title:i}){let s=()=>r?.4:n&&!t?.5:1,l={position:"relative",display:"flex",alignItems:"center",justifyContent:"center",width:32,height:32,borderRadius:0,border:"none",cursor:r?"default":"pointer",transition:"background-color 150ms ease, color 150ms ease, transform 100ms ease, opacity 150ms ease",backgroundColor:t?Fn.bgActive:"transparent",color:t?Fn.iconActive:Fn.iconDefault,opacity:s()};return Ia("button",{type:"button",onClick:r?void 0:o,title:i,disabled:r,style:l,onMouseEnter:a=>{r||(a.currentTarget.style.opacity="1",t||(a.currentTarget.style.backgroundColor=Fn.bgHover))},onMouseLeave:a=>{r||(a.currentTarget.style.opacity=String(s()),t||(a.currentTarget.style.backgroundColor="transparent"))},onMouseDown:a=>{r||(a.currentTarget.style.transform="scale(0.95)")},onMouseUp:a=>{r||(a.currentTarget.style.transform="scale(1)")},children:e})}function es(){return Ia("div",{style:{width:1,height:20,backgroundColor:"rgba(0, 0, 0, 0.05)",margin:"0 8px"}})}import{Fragment as fo,jsx as re,jsxs as St}from"react/jsx-runtime";var go=[{type:"rectangle",icon:zp,label:"Rectangle",shortcut:"R"},{type:"circle",icon:Op,label:"Oval",shortcut:"O"},{type:"line",icon:_p,label:"Line",shortcut:"L"},{type:"freehand",icon:Fp,label:"Pen",shortcut:"P"}],Yp=new Set(go.map(e=>e.type));function jp(e,t,n,r,o,i,s,l){let a=(e-o)*(r-i)-(n-o)*(t-i),c=(e-s)*(i-l)-(o-s)*(t-l),d=(e-n)*(l-r)-(s-n)*(t-r),u=a<0||c<0||d<0,p=a>0||c>0||d>0;return!(u&&p)}function Gp(){let e=window.innerWidth-16,t=e-326,n=window.innerHeight-80;return{left:t,right:e,y:n}}var Vp=[{type:"text",icon:Wp,label:"Text",shortcut:"T"}],Ra={inspector:{name:"Comment",desc:"Pin feedback to specific elements on the page.",usage:["Click any element to attach a comment","Type your note, then hand off to your AI","Your AI may ask clarifying questions","Replies get threaded"],keys:[{key:"C",desc:"Select tool"},{key:"Click",desc:"Pin comment to element"},{key:"Esc",desc:"Deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},hand:{name:"Handle",desc:"Quickly finetune layout and typescale.",usage:["Edges \u2192 padding","Between items \u2192 spacing","Corners \u2192 rounding","Right of text \u2192 font size","Below text \u2192 line height","Click a spacing handle to cycle distribution","Right-click \u2192 inspect element styles"],keys:[{key:"H",desc:"Select tool"},{key:"Shift",desc:"Snap to scale"},{key:"\u2325 + swipe",desc:"Cycle justify / flip direction"},{key:"\u21E7 + swipe",desc:"Cycle align-items"},{key:"Right-click",desc:"Inspect styles"},{key:"Esc",desc:"Deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},rectangle:{name:"Rectangle",desc:"Draw rectangular highlights to mark areas of interest.",usage:["Click and drag to draw","Cycle between shapes with the dot selector"],keys:[{key:"R",desc:"Rectangle"},{key:"O",desc:"Oval"},{key:"L",desc:"Line"},{key:"P",desc:"Pen"},{key:"Esc",desc:"Cancel or deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},circle:{name:"Oval",desc:"Draw oval highlights to mark areas of interest.",usage:["Click and drag to draw","Cycle between shapes with the dot selector"],keys:[{key:"O",desc:"Oval"},{key:"R",desc:"Rectangle"},{key:"L",desc:"Line"},{key:"P",desc:"Pen"},{key:"Esc",desc:"Cancel or deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},line:{name:"Line",desc:"Draw line annotations to point at or connect elements.",usage:["Click and drag to draw","Cycle between shapes with the dot selector"],keys:[{key:"L",desc:"Line"},{key:"R",desc:"Rectangle"},{key:"O",desc:"Oval"},{key:"P",desc:"Pen"},{key:"Esc",desc:"Cancel or deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},freehand:{name:"Pen",desc:"Draw freehand paths to annotate freely.",usage:["Click and drag to draw","Cycle between shapes with the dot selector"],keys:[{key:"P",desc:"Pen"},{key:"R",desc:"Rectangle"},{key:"O",desc:"Oval"},{key:"L",desc:"Line"},{key:"Esc",desc:"Cancel or deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},text:{name:"Text",desc:"Place text labels anywhere on the page.",usage:["Click to place, then start typing","Click away or press Enter to finish","Scroll while hovering a label to resize it"],keys:[{key:"T",desc:"Select tool"},{key:"Esc",desc:"Cancel text or deselect"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]},model:{name:"Model",desc:"Promote components into the local design model.",usage:["Hover to highlight component boundaries","Scroll to walk up/down the component tree","Click to add to model.json","Green = already in model"],keys:[{key:"M",desc:"Select tool"},{key:"Scroll",desc:"Walk tree depth"},{key:"Click",desc:"Promote component"},{key:"Esc",desc:"Deselect"}]},counter:{name:"Annotations",desc:"Click to cycle, scroll to change color, long press to reset.",usage:[],keys:[{key:"Click",desc:"Cycle annotations"},{key:"Scroll",desc:"Change color"},{key:"Hold",desc:"Reset to red"}]},clear:{name:"Clear",desc:"Remove all annotations and style changes.",usage:[],keys:[{key:"\u2318 \u232B",desc:"Clear all"},{key:"\u232B",desc:"Delete selected annotation"},{key:"\u2318 Z",desc:"Undo"},{key:"\u2318 \u21E7 Z",desc:"Redo"}]},collapse:{name:"Popmelt",desc:`Comment and zhuzh, then hand off.
11
13
 
12
- Your AI gets the visual and technical context it needs to act.`,usage:[],keys:[{key:"\u2318\u2318",desc:"Toggle toolbar"}]}},zu=h(f({position:"fixed",bottom:16,right:16,zIndex:9999,display:"flex",alignItems:"center",backgroundColor:"#ffffff"},bn),{fontFamily:"ui-monospace, SFMono-Regular, Menlo, Consolas, monospace",cursor:"pointer",overflow:"visible",boxSizing:"content-box",transition:"all 0ms cubic-bezier(0.4, 0, 0.2, 1)"}),Hi="devtools-toolbar-expanded",Fi="devtools-annotations",Ni="devtools-style-modifications",_i="devtools-active-tool",Jl="devtools-active-color",Xl="devtools-stroke-width",Kl="devtools-inspected-element",zi="devtools-spacing-changes",$u={expanded:Hi,annotations:Fi,styleMods:Ni,spacingChanges:zi,tool:_i,color:Jl,stroke:Xl,inspected:Kl};function Wu(){return re("svg",{width:"16",height:"16",viewBox:"0 0 1200 1200",fill:"currentColor",stroke:"none",children:re("path",{d:"M 233.959793 800.214905 L 468.644287 668.536987 L 472.590637 657.100647 L 468.644287 650.738403 L 457.208069 650.738403 L 417.986633 648.322144 L 283.892639 644.69812 L 167.597321 639.865845 L 54.926208 633.825623 L 26.577238 627.785339 L 3.3e-05 592.751709 L 2.73832 575.27533 L 26.577238 559.248352 L 60.724873 562.228149 L 136.187973 567.382629 L 249.422867 575.194763 L 331.570496 580.026978 L 453.261841 592.671082 L 472.590637 592.671082 L 475.328857 584.859009 L 468.724915 580.026978 L 463.570557 575.194763 L 346.389313 495.785217 L 219.543671 411.865906 L 153.100723 363.543762 L 117.181267 339.060425 L 99.060455 316.107361 L 91.248367 266.01355 L 123.865784 230.093994 L 167.677887 233.073853 L 178.872513 236.053772 L 223.248367 270.201477 L 318.040283 343.570496 L 441.825592 434.738342 L 459.946411 449.798706 L 467.194672 444.64447 L 468.080597 441.020203 L 459.946411 427.409485 L 392.617493 305.718323 L 320.778564 181.932983 L 288.80542 130.630859 L 280.348999 99.865845 C 277.369171 87.221436 275.194641 76.590698 275.194641 63.624268 L 312.322174 13.20813 L 332.8591 6.604126 L 382.389313 13.20813 L 403.248352 31.328979 L 434.013519 101.71814 L 483.865753 212.537048 L 561.181274 363.221497 L 583.812134 407.919434 L 595.892639 449.315491 L 600.40271 461.959839 L 608.214783 461.959839 L 608.214783 454.711609 L 614.577271 369.825623 L 626.335632 265.61084 L 637.771851 131.516846 L 641.718201 93.745117 L 660.402832 48.483276 L 697.530334 24.000122 L 726.52356 37.852417 L 750.362549 72 L 747.060486 94.067139 L 732.886047 186.201416 L 705.100708 330.52356 L 686.979919 427.167847 L 697.530334 427.167847 L 709.61084 415.087341 L 758.496704 350.174561 L 840.644348 247.490051 L 876.885925 206.738342 L 919.167847 161.71814 L 946.308838 140.29541 L 997.61084 140.29541 L 1035.38269 196.429626 L 1018.469849 254.416199 L 965.637634 321.422852 L 921.825562 378.201538 L 859.006714 462.765259 L 819.785278 530.41626 L 823.409424 535.812073 L 832.75177 534.92627 L 974.657776 504.724915 L 1051.328979 490.872559 L 1142.818848 475.167786 L 1184.214844 494.496582 L 1188.724854 514.147644 L 1172.456421 554.335693 L 1074.604126 578.496765 L 959.838989 601.449829 L 788.939636 641.879272 L 786.845764 643.409485 L 789.261841 646.389343 L 866.255127 653.637634 L 899.194702 655.409424 L 979.812134 655.409424 L 1129.932861 666.604187 L 1169.154419 692.537109 L 1192.671265 724.268677 L 1188.724854 748.429688 L 1128.322144 779.194641 L 1046.818848 759.865845 L 856.590759 714.604126 L 791.355774 698.335754 L 782.335693 698.335754 L 782.335693 703.731567 L 836.69812 756.885986 L 936.322205 846.845581 L 1061.073975 962.81897 L 1067.436279 991.490112 L 1051.409424 1014.120911 L 1034.496704 1011.704712 L 924.885986 929.234924 L 882.604126 892.107544 L 786.845764 811.48999 L 780.483276 811.48999 L 780.483276 819.946289 L 802.550415 852.241699 L 919.087341 1027.409424 L 925.127625 1081.127686 L 916.671204 1098.604126 L 886.469849 1109.154419 L 853.288696 1103.114136 L 785.073914 1007.355835 L 714.684631 899.516785 L 657.906067 802.872498 L 650.979858 806.81897 L 617.476624 1167.704834 L 601.771851 1186.147705 L 565.530212 1200 L 535.328857 1177.046997 L 519.302124 1139.919556 L 535.328857 1066.550537 L 554.657776 970.792053 L 570.362488 894.68457 L 584.536926 800.134277 L 592.993347 768.724976 L 592.429626 766.630859 L 585.503479 767.516968 L 514.22821 865.369263 L 405.825531 1011.865906 L 320.053711 1103.677979 L 299.516815 1111.812256 L 263.919525 1093.369263 L 267.221497 1060.429688 L 287.114136 1031.114136 L 405.825531 880.107361 L 477.422913 786.52356 L 523.651062 732.483276 L 523.328918 724.671265 L 520.590698 724.671265 L 205.288605 929.395935 L 149.154434 936.644409 L 124.993355 914.01355 L 127.973183 876.885986 L 139.409409 864.80542 L 234.201385 799.570435 L 233.879227 799.8927 Z"})})}function Yu(){return re("svg",{width:"16",height:"16",viewBox:"0 0 158.7128 157.296",fill:"currentColor",stroke:"none",children:re("path",{d:"M60.8734,57.2556v-14.9432c0-1.2586.4722-2.2029,1.5728-2.8314l30.0443-17.3023c4.0899-2.3593,8.9662-3.4599,13.9988-3.4599,18.8759,0,30.8307,14.6289,30.8307,30.2006,0,1.1007,0,2.3593-.158,3.6178l-31.1446-18.2467c-1.8872-1.1006-3.7754-1.1006-5.6629,0l-39.4812,22.9651ZM131.0276,115.4561v-35.7074c0-2.2028-.9446-3.7756-2.8318-4.8763l-39.481-22.9651,12.8982-7.3934c1.1007-.6285,2.0453-.6285,3.1458,0l30.0441,17.3024c8.6523,5.0341,14.4708,15.7296,14.4708,26.1107,0,11.9539-7.0769,22.965-18.2461,27.527v.0021ZM51.593,83.9964l-12.8982-7.5497c-1.1007-.6285-1.5728-1.5728-1.5728-2.8314v-34.6048c0-16.8303,12.8982-29.5722,30.3585-29.5722,6.607,0,12.7403,2.2029,17.9324,6.1349l-30.987,17.9324c-1.8871,1.1007-2.8314,2.6735-2.8314,4.8764v45.6159l-.0014-.0015ZM79.3562,100.0403l-18.4829-10.3811v-22.0209l18.4829-10.3811,18.4812,10.3811v22.0209l-18.4812,10.3811ZM91.2319,147.8591c-6.607,0-12.7403-2.2031-17.9324-6.1344l30.9866-17.9333c1.8872-1.1005,2.8318-2.6728,2.8318-4.8759v-45.616l13.0564,7.5498c1.1005.6285,1.5723,1.5728,1.5723,2.8314v34.6051c0,16.8297-13.0564,29.5723-30.5147,29.5723v.001ZM53.9522,112.7822l-30.0443-17.3024c-8.652-5.0343-14.471-15.7296-14.471-26.1107,0-12.1119,7.2356-22.9652,18.403-27.5272v35.8634c0,2.2028.9443,3.7756,2.8314,4.8763l39.3248,22.8068-12.8982,7.3938c-1.1007.6287-2.045.6287-3.1456,0ZM52.2229,138.5791c-17.7745,0-30.8306-13.3713-30.8306-29.8871,0-1.2585.1578-2.5169.3143-3.7754l30.987,17.9323c1.8871,1.1005,3.7757,1.1005,5.6628,0l39.4811-22.807v14.9435c0,1.2585-.4721,2.2021-1.5728,2.8308l-30.0443,17.3025c-4.0898,2.359-8.9662,3.4605-13.9989,3.4605h.0014ZM91.2319,157.296c19.0327,0,34.9188-13.5272,38.5383-31.4594,17.6164-4.562,28.9425-21.0779,28.9425-37.908,0-11.0112-4.719-21.7066-13.2133-29.4143.7867-3.3035,1.2595-6.607,1.2595-9.909,0-22.4929-18.2471-39.3247-39.3251-39.3247-4.2461,0-8.3363.6285-12.4262,2.045-7.0792-6.9213-16.8318-11.3254-27.5271-11.3254-19.0331,0-34.9191,13.5268-38.5384,31.4591C11.3255,36.0212,0,52.5373,0,69.3675c0,11.0112,4.7184,21.7065,13.2125,29.4142-.7865,3.3035-1.2586,6.6067-1.2586,9.9092,0,22.4923,18.2466,39.3241,39.3248,39.3241,4.2462,0,8.3362-.6277,12.426-2.0441,7.0776,6.921,16.8302,11.3251,27.5271,11.3251Z"})})}function Zl({state:e,dispatch:t,onScreenshot:o,onSendToClaude:r,hasActiveJobs:n,activeJobColor:i,onCrosshairHover:s,onClear:l,provider:a="claude",onProviderChange:c,availableProviders:d,modelIndex:u=0,modelCount:p=2,modelLabel:g="Opus 4.6",onModelChange:S,onViewThread:v,isThreadPanelOpen:b,mcpStatus:w,onInstallMcp:O,mcpJustInstalled:A,bridgeUrl:k,isBridgeConnected:E,modelSelectedComponent:I,modelCanvasHoveredComponent:$,onModelComponentHover:q,onSpacingTokenHover:j,onModifySpacingToken:T,onDeleteSpacingToken:D,modelRefreshKey:K,onModelComponentAdded:ee,onModelComponentRemoved:me,onMouseEnter:ve,toolbarRef:ae}){let[Re,We]=jo(()=>typeof window=="undefined"?!1:localStorage.getItem(Hi)==="true"),[Me,ne]=jo(0),Ae=Bt(0),G=Bt(0),oe=Bt(e.isAnnotating),Ee=Bt(!1),ce=Bt(typeof window!="undefined"?localStorage.getItem(_i):null),Ke=Bt(typeof window!="undefined"?localStorage.getItem(Jl):null),Te=Bt(typeof window!="undefined"?localStorage.getItem(Xl):null),{charIndex:xe}=gr(!!n),[ge,Ge]=jo(null),xt=Bt(!1),dt=Bt(null),Ve=Bt(null),z=Bt({x:0,y:0}),ie=Bt(null),Q=Bt(null),Se=Bt(null),Le=cn(()=>{ie.current=null,Q.current=null,Se.current&&(clearTimeout(Se.current),Se.current=null)},[]),Ze=cn(W=>{Ve.current&&(clearTimeout(Ve.current),Ve.current=null),xt.current?(ie.current=W,Q.current=f({},z.current),Se.current&&clearTimeout(Se.current),Se.current=setTimeout(()=>{ie.current&&(Ge(ie.current),Le())},300)):(dt.current&&clearTimeout(dt.current),dt.current=setTimeout(()=>{xt.current=!0,Ge(W),dt.current=null},500))},[Le]),fe=cn(()=>{Le(),dt.current&&(clearTimeout(dt.current),dt.current=null),Ve.current=setTimeout(()=>{xt.current=!1,Ge(null)},150)},[Le]),lt=cn(W=>{if(z.current={x:W.clientX,y:W.clientY},ie.current&&Q.current){let te=Q.current,U=Nu();Fu(W.clientX,W.clientY,te.x,te.y,U.left,U.y,U.right,U.y)||(Ge(ie.current),Le())}},[Le]),Qe=Di(()=>{let W=(d!=null?d:[]).map(te=>te==="claude"?"Claude":te==="codex"?"Codex":te);return{name:"AI Model",desc:W.length>1?`${W.join(" and ")} are available.`:W.length===1?`Connected to ${W[0]}.`:"No AI providers detected.",usage:W.length>1?["Click the logo to switch between providers","Click the model name to switch tiers"]:["Click the model name to switch tiers"],keys:W.length>1?[{key:"Click",desc:"Switch"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]:[{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]}},[d]);zl(Re,e,Ee,!!n,$u),wn(()=>{if(localStorage.getItem(Hi)==="true"&&!e.isAnnotating){if(Re||We(!0),t({type:"SET_TOOL",payload:ce.current||"inspector"}),t({type:"SET_ANNOTATING",payload:!0}),Ke.current&&t({type:"SET_COLOR",payload:Ke.current}),Te.current){let he=parseFloat(Te.current);isNaN(he)||t({type:"SET_STROKE_WIDTH",payload:he})}let te=localStorage.getItem(Fi);if(te)try{let he=JSON.parse(te);Array.isArray(he)&&he.length>0&&t({type:"RESTORE_ANNOTATIONS",payload:{annotations:he}})}catch(he){}let U=localStorage.getItem(Ni);if(U)try{let he=JSON.parse(U);Array.isArray(he)&&he.length>0&&(t({type:"RESTORE_STYLE_MODIFICATIONS",payload:he}),cr(he))}catch(he){}let Pe=localStorage.getItem(zi);if(Pe)try{let he=JSON.parse(Pe);Array.isArray(he)&&he.length>0&&t({type:"RESTORE_SPACING_TOKEN_CHANGES",payload:he})}catch(he){}let Be=localStorage.getItem(Kl);if(Be)try{let{selector:he,info:It}=JSON.parse(Be);if(he){let R=Jt(he);if(R){let Z=It||h(f({},qt(R)),{selector:he});t({type:"SELECT_ELEMENT",payload:{el:R,info:Z}})}}}catch(he){}}return Ee.current=!0,()=>{Ee.current=!1}},[]);let Tt=Bt(e.styleModifications);wn(()=>{let W=Tt.current,te=e.styleModifications;W!==te&&(dr(W),cr(te),Tt.current=te)},[e.styleModifications]),wn(()=>{let W=oe.current;oe.current=e.isAnnotating,W&&!e.isAnnotating&&Re&&We(!1)},[e.isAnnotating,Re]);let Ot=Bt(Re);Ot.current=Re,wn(()=>{let W=U=>{if(U.key==="Meta"||U.key==="Control"){let Pe=Date.now();if(Pe-Ae.current<300){if(G.current++,G.current>=2){if(Ot.current)t({type:"SET_ANNOTATING",payload:!1}),We(!1);else{let It=localStorage.getItem(_i);t({type:"SET_TOOL",payload:It||"inspector"}),t({type:"SET_ANNOTATING",payload:!0}),We(!0)}G.current=0}}else G.current=1;Ae.current=Pe}else G.current=0},te=U=>{U.key!=="Meta"&&U.key!=="Control"&&(G.current=0)};return window.addEventListener("keydown",W),window.addEventListener("keyup",te),()=>{window.removeEventListener("keydown",W),window.removeEventListener("keyup",te)}},[t]);let st=cn(W=>{Le(),t({type:"SET_TOOL",payload:W}),e.isAnnotating||t({type:"SET_ANNOTATING",payload:!0}),xt.current=!1,Ge(null),dt.current&&(clearTimeout(dt.current),dt.current=null),Ve.current&&(clearTimeout(Ve.current),Ve.current=null)},[t,e.isAnnotating,Le]),at=cn(async()=>{window.focus(),await o()},[o]),Dt=cn(async()=>{r&&await r()},[r]),tt=cn(()=>{t({type:"SET_ANNOTATING",payload:!1}),We(!1)},[t]),vt=cn(()=>{dr(e.styleModifications),document.querySelectorAll("[data-pm]").forEach(W=>W.removeAttribute("data-pm")),t({type:"CLEAR"}),t({type:"CLEAR_ALL_STYLES"}),localStorage.removeItem(Fi),localStorage.removeItem(Ni),localStorage.removeItem(zi),St(null),l==null||l()},[t,e.styleModifications,l]),[$e,en]=jo(29),Kt=Bt(null),rn=Bt(null),mn=Bt(!1),En=cn(W=>{let te=W.match(/oklch\([^)]*\s+([\d.]+)\s*\)/);return te&&te[1]?parseFloat(te[1]):null},[]);wn(()=>{mn.current=!0;let W=`oklch(0.628 0.258 ${$e})`;t({type:"SET_COLOR",payload:W}),requestAnimationFrame(()=>{mn.current=!1})},[$e,t]),wn(()=>{if(mn.current)return;let W=En(e.activeColor);W!==null&&Math.abs(W-$e)>.5&&en(W)},[e.activeColor,En,$e]);let J=e.annotations.length>0;wn(()=>{let W=rn.current;if(!W||!J)return;let te=U=>{U.preventDefault(),U.stopPropagation();let Pe=U.deltaY>0?-1:1,Be=(($e+Pe)%360+360)%360,he=`oklch(0.628 0.258 ${Be})`;en(Be),e.selectedAnnotationIds.length>0&&t({type:"UPDATE_ANNOTATION_COLOR",payload:{id:e.lastSelectedId||e.selectedAnnotationIds[0],color:he}})};return W.addEventListener("wheel",te,{passive:!1}),()=>W.removeEventListener("wheel",te)},[J,e.selectedAnnotationIds,e.lastSelectedId,$e,t]);let Ie=Bt(!1),Fe=cn(()=>{Ie.current=!1,Kt.current=setTimeout(()=>{Ie.current=!0,en(29)},500)},[]),ft=cn(()=>{Kt.current&&(clearTimeout(Kt.current),Kt.current=null)},[]);wn(()=>()=>{Kt.current&&clearTimeout(Kt.current),Se.current&&clearTimeout(Se.current)},[]);let Lt=Di(()=>fr(e.annotations),[e.annotations]),pt=Di(()=>{let W=[],te=new Set;for(let U of e.annotations)if(!Lt.has(U))if(U.groupId){if(!te.has(U.groupId)){te.add(U.groupId);let Pe=e.annotations.filter(he=>he.groupId===U.groupId&&!Lt.has(he)),Be=Pe.find(he=>he.type!=="text")||Pe[0];W.push({id:Be.id,annotations:Pe})}}else W.push({id:U.id,annotations:[U]});return W},[e.annotations,Lt]),[bt,St]=jo(null),dn=pt.length+e.styleModifications.length;wn(()=>{(dn===0||bt!==null&&bt>=dn)&&St(null)},[dn,bt]),wn(()=>{if(e.selectedAnnotationIds.length===0&&!e.inspectedElement){St(null);return}if(e.selectedAnnotationIds.length>0){let W=e.selectedAnnotationIds[0],te=pt.findIndex(U=>U.id===W||U.annotations.some(Pe=>Pe.id===W));te>=0&&te!==bt&&St(te)}},[e.selectedAnnotationIds,e.inspectedElement,pt]);let $t=cn(()=>{var te;if(dn===0)return;let W;if(bt===null?W=0:W=(bt+1)%dn,St(W),W<pt.length){let U=pt[W];if(!U)return;t({type:"SELECT_ELEMENT",payload:null}),t({type:"SELECT_ANNOTATION",payload:{id:U.id}});let Pe=U.annotations.find(ke=>ke.type!=="text")||U.annotations[0];if(U.annotations.some(ke=>ke.linkedSelector))t({type:"SET_TOOL",payload:"inspector"});else if(Pe!=null&&Pe.type&&Pe.type!=="text"&&Pe.type!=="inspector"){t({type:"SET_TOOL",payload:Pe.type});let ke=to.findIndex(Ne=>Ne.type===Pe.type);ke>=0&&ne(ke)}if(Pe!=null&&Pe.color){t({type:"SET_COLOR",payload:Pe.color});let ke=En(Pe.color);ke!==null&&en(ke)}let he=U.annotations.flatMap(ke=>ke.points);if(he.length===0)return;let It=Math.min(...he.map(ke=>ke.x)),R=Math.max(...he.map(ke=>ke.x)),Z=Math.min(...he.map(ke=>ke.y)),de=Math.max(...he.map(ke=>ke.y)),Oe=(It+R)/2,ye=(Z+de)/2;if(window.scrollTo({left:Oe-window.innerWidth/2,top:ye-window.innerHeight/2,behavior:"smooth"}),b&&v){let ke=(te=U.annotations.find(Ne=>Ne.threadId))==null?void 0:te.threadId;ke&&v(ke)}}else{let U=W-pt.length,Pe=e.styleModifications[U];if(!Pe)return;let Be=Jt(Pe.selector);if(!Be)return;t({type:"SELECT_ANNOTATION",payload:{id:null}}),t({type:"SET_TOOL",payload:"inspector"}),t({type:"SELECT_ELEMENT",payload:{el:Be,info:Pe.element}});let he=Be.getBoundingClientRect(),It=he.left+he.width/2+window.scrollX,R=he.top+he.height/2+window.scrollY;window.scrollTo({left:It-window.innerWidth/2,top:R-window.innerHeight/2,behavior:"smooth"})}},[pt,e.styleModifications,dn,bt,t,En,b,v]);wn(()=>{if(!Re)return;let W=te=>{var he;let U=document.activeElement;for(;(he=U==null?void 0:U.shadowRoot)!=null&&he.activeElement;)U=U.shadowRoot.activeElement;if((U==null?void 0:U.tagName)==="INPUT"||(U==null?void 0:U.tagName)==="TEXTAREA"||U!=null&&U.isContentEditable)return;if((te.metaKey||te.ctrlKey)&&te.key==="Enter"){r&&(e.annotations.length>0||e.styleModifications.length>0||e.spacingTokenChanges.filter(It=>!It.captured).length>0)&&(te.preventDefault(),Dt());return}if((te.metaKey||te.ctrlKey)&&(te.key==="c"||te.key==="C"||te.code==="KeyC")){(e.annotations.length>0||e.styleModifications.length>0)&&(te.preventDefault(),window.focus(),at());return}if((te.metaKey||te.ctrlKey)&&(te.key==="Backspace"||te.key==="Delete")){te.preventDefault(),vt();return}if(te.metaKey||te.ctrlKey||te.altKey)return;let Pe={p:"freehand",l:"line",r:"rectangle",o:"circle",t:"text",c:"inspector",h:"hand"};if(te.key.toLowerCase()==="m"){te.preventDefault(),st("model");return}let Be=Pe[te.key.toLowerCase()];if(Be){te.preventDefault();let It=to.findIndex(R=>R.type===Be);It>=0&&ne(It),st(Be)}};return window.addEventListener("keydown",W),()=>window.removeEventListener("keydown",W)},[Re,st,at,Dt,r,vt,e.annotations.length,e.styleModifications.length,e.spacingTokenChanges,ge]);let kt=h(f({},zu),{borderRadius:0,padding:Re?"0 8px":"0",width:Re?"auto":48,height:48,gap:0,justifyContent:Re?"flex-start":"center"}),hn=E===!1?"rgba(239, 68, 68, 0.4)":n&&i?i:Pn.iconActive;return Re?yt(eo,{children:[re("style",{children:`
14
+ Your AI gets the visual and technical context it needs to act.`,usage:[],keys:[{key:"\u2318\u2318",desc:"Toggle toolbar"}]}},Up=y(f({position:"fixed",bottom:16,right:16,zIndex:9999,display:"flex",alignItems:"center",backgroundColor:"#eaeaea"},En),{fontFamily:"ui-monospace, SFMono-Regular, Menlo, Consolas, monospace",cursor:"pointer",overflow:"visible",boxSizing:"content-box",transition:"all 0ms cubic-bezier(0.4, 0, 0.2, 1)"}),ns="devtools-toolbar-expanded",os="devtools-annotations",rs="devtools-style-modifications",is="devtools-active-tool",La="devtools-active-color",Aa="devtools-stroke-width",Pa="devtools-inspected-element",ss="devtools-spacing-changes",Jp={expanded:ns,annotations:os,styleMods:rs,spacingChanges:ss,tool:is,color:La,stroke:Aa,inspected:Pa};function Ba({state:e,dispatch:t,onScreenshot:n,onSendToClaude:r,hasActiveJobs:o,activeJobColor:i,onCrosshairHover:s,onClear:l,provider:a="claude",onProviderChange:c,availableProviders:d,modelIndex:u=0,modelCount:p=2,modelLabel:g="Opus 4.6",onModelChange:k,onViewThread:w,isThreadPanelOpen:b,mcpStatus:E,onInstallMcp:B,mcpJustInstalled:L,bridgeUrl:T,isBridgeConnected:v,modelSelectedComponent:O,modelCanvasHoveredComponent:H,onModelComponentHover:U,onSpacingTokenHover:G,onModifySpacingToken:X,onDeleteSpacingToken:S,modelRefreshKey:I,onModelComponentAdded:K,onModelComponentRemoved:ge,onMouseEnter:be,toolbarRef:de}){let[ue,Fe]=tr(()=>typeof window=="undefined"?!1:localStorage.getItem(ns)==="true"),[Te,ee]=tr(0),Le=Bt(0),Ae=Bt(0),_e=Bt(e.isAnnotating),Pe=Bt(!1),Me=Bt(typeof window!="undefined"?localStorage.getItem(is):null),q=Bt(typeof window!="undefined"?localStorage.getItem(La):null),me=Bt(typeof window!="undefined"?localStorage.getItem(Aa):null),{charIndex:Ee}=Mr(!!o),[ye,Ie]=tr(null),We=Bt(!1),lt=Bt(null),dt=Bt(null),W=Bt({x:0,y:0}),te=Bt(null),j=Bt(null),he=Bt(null),xe=mn(()=>{te.current=null,j.current=null,he.current&&(clearTimeout(he.current),he.current=null)},[]),Be=mn(F=>{dt.current&&(clearTimeout(dt.current),dt.current=null),We.current?(te.current=F,j.current=f({},W.current),he.current&&clearTimeout(he.current),he.current=setTimeout(()=>{te.current&&(Ie(te.current),xe())},300)):(lt.current&&clearTimeout(lt.current),lt.current=setTimeout(()=>{We.current=!0,Ie(F),lt.current=null},500))},[xe]),Ce=mn(()=>{xe(),lt.current&&(clearTimeout(lt.current),lt.current=null),dt.current=setTimeout(()=>{We.current=!1,Ie(null)},150)},[xe]),it=mn(F=>{if(W.current={x:F.clientX,y:F.clientY},te.current&&j.current){let ne=j.current,oe=Gp();jp(F.clientX,F.clientY,ne.x,ne.y,oe.left,oe.y,oe.right,oe.y)||(Ie(te.current),xe())}},[xe]),qe=ts(()=>{let F=(d!=null?d:[]).map(ne=>ne==="claude"?"Claude":ne==="codex"?"Codex":ne);return{name:"AI Model",desc:F.length>1?`${F.join(" and ")} are available.`:F.length===1?`Connected to ${F[0]}.`:"No AI providers detected.",usage:F.length>1?["Click the logo to switch between providers","Click the model name to switch tiers"]:["Click the model name to switch tiers"],keys:F.length>1?[{key:"Click",desc:"Switch"},{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]:[{key:"\u2318 Enter",desc:"Hand off to your AI",accent:!0}]}},[d]);ua(ue,e,Pe,!!o,Jp),Mn(()=>{if(localStorage.getItem(ns)==="true"&&!e.isAnnotating){if(ue||Fe(!0),t({type:"SET_TOOL",payload:Me.current||"inspector"}),t({type:"SET_ANNOTATING",payload:!0}),q.current&&t({type:"SET_COLOR",payload:q.current}),me.current){let pe=parseFloat(me.current);isNaN(pe)||t({type:"SET_STROKE_WIDTH",payload:pe})}let ne=localStorage.getItem(os);if(ne)try{let pe=JSON.parse(ne);if(Array.isArray(pe)&&pe.length>0){for(let xt of pe)(xt.status==="waiting_input"||xt.status==="in_flight")&&(xt.status=xt.threadId?"resolved":"pending");t({type:"RESTORE_ANNOTATIONS",payload:{annotations:pe}})}}catch(pe){}let oe=localStorage.getItem(rs);if(oe)try{let pe=JSON.parse(oe);Array.isArray(pe)&&pe.length>0&&(t({type:"RESTORE_STYLE_MODIFICATIONS",payload:pe}),Sr(pe))}catch(pe){}let Se=localStorage.getItem(ss);if(Se)try{let pe=JSON.parse(Se);Array.isArray(pe)&&pe.length>0&&t({type:"RESTORE_SPACING_TOKEN_CHANGES",payload:pe})}catch(pe){}let Oe=localStorage.getItem(Pa);if(Oe)try{let{selector:pe,info:xt}=JSON.parse(Oe);if(pe){let Je=Qt(pe);if(Je){let Tn=xt||y(f({},nn(Je)),{selector:pe});t({type:"SELECT_ELEMENT",payload:{el:Je,info:Tn}})}}}catch(pe){}}return Pe.current=!0,()=>{Pe.current=!1}},[]);let Ct=Bt(e.styleModifications);Mn(()=>{let F=Ct.current,ne=e.styleModifications;F!==ne&&(vr(F),Sr(ne),Ct.current=ne)},[e.styleModifications]),Mn(()=>{let F=_e.current;_e.current=e.isAnnotating,F&&!e.isAnnotating&&ue&&Fe(!1)},[e.isAnnotating,ue]);let Nt=Bt(ue);Nt.current=ue,Mn(()=>{let F=oe=>{if(oe.key==="Meta"||oe.key==="Control"){let Se=Date.now();if(Se-Le.current<300){if(Ae.current++,Ae.current>=2){if(Nt.current)t({type:"SET_ANNOTATING",payload:!1}),Fe(!1);else{let xt=localStorage.getItem(is);t({type:"SET_TOOL",payload:xt||"inspector"}),t({type:"SET_ANNOTATING",payload:!0}),Fe(!0)}Ae.current=0}}else Ae.current=1;Le.current=Se}else Ae.current=0},ne=oe=>{oe.key!=="Meta"&&oe.key!=="Control"&&(Ae.current=0)};return window.addEventListener("keydown",F),window.addEventListener("keyup",ne),()=>{window.removeEventListener("keydown",F),window.removeEventListener("keyup",ne)}},[t]);let et=mn(F=>{xe(),t({type:"SET_TOOL",payload:F}),e.isAnnotating||t({type:"SET_ANNOTATING",payload:!0}),We.current=!1,Ie(null),lt.current&&(clearTimeout(lt.current),lt.current=null),dt.current&&(clearTimeout(dt.current),dt.current=null)},[t,e.isAnnotating,xe]),Rt=mn(async()=>{window.focus(),await n()},[n]),Ht=mn(async()=>{r&&await r()},[r]),bt=mn(()=>{t({type:"SET_ANNOTATING",payload:!1}),Fe(!1)},[t]),wt=mn(()=>{vr(e.styleModifications),document.querySelectorAll("[data-pm]").forEach(F=>F.removeAttribute("data-pm")),t({type:"CLEAR"}),t({type:"CLEAR_ALL_STYLES"}),localStorage.removeItem(os),localStorage.removeItem(rs),localStorage.removeItem(ss),Ut(null),l==null||l()},[t,e.styleModifications,l]),[mt,vt]=tr(29),en=Bt(null),Ft=Bt(null),an=Bt(!1),ut=mn(F=>{let ne=F.match(/oklch\([^)]*\s+([\d.]+)\s*\)/);return ne&&ne[1]?parseFloat(ne[1]):null},[]);Mn(()=>{an.current=!0;let F=`oklch(0.628 0.258 ${mt})`;t({type:"SET_COLOR",payload:F}),requestAnimationFrame(()=>{an.current=!1})},[mt,t]),Mn(()=>{if(an.current)return;let F=ut(e.activeColor);F!==null&&Math.abs(F-mt)>.5&&vt(F)},[e.activeColor,ut,mt]);let Z=e.annotations.length>0;Mn(()=>{let F=Ft.current;if(!F||!Z)return;let ne=oe=>{oe.preventDefault(),oe.stopPropagation();let Se=oe.deltaY>0?-1:1,Oe=((mt+Se)%360+360)%360,pe=`oklch(0.628 0.258 ${Oe})`;vt(Oe),e.selectedAnnotationIds.length>0&&t({type:"UPDATE_ANNOTATION_COLOR",payload:{id:e.lastSelectedId||e.selectedAnnotationIds[0],color:pe}})};return F.addEventListener("wheel",ne,{passive:!1}),()=>F.removeEventListener("wheel",ne)},[Z,e.selectedAnnotationIds,e.lastSelectedId,mt,t]);let Re=Bt(!1),Xe=mn(()=>{Re.current=!1,en.current=setTimeout(()=>{Re.current=!0,vt(29)},500)},[]),cn=mn(()=>{en.current&&(clearTimeout(en.current),en.current=null)},[]);Mn(()=>()=>{en.current&&clearTimeout(en.current),he.current&&clearTimeout(he.current)},[]);let qt=ts(()=>kr(e.annotations),[e.annotations]),pt=ts(()=>{let F=[],ne=new Set;for(let oe of e.annotations)if(!qt.has(oe))if(oe.groupId){if(!ne.has(oe.groupId)){ne.add(oe.groupId);let Se=e.annotations.filter(pe=>pe.groupId===oe.groupId&&!qt.has(pe)),Oe=Se.find(pe=>pe.type!=="text")||Se[0];F.push({id:Oe.id,annotations:Se})}}else F.push({id:oe.id,annotations:[oe]});return F},[e.annotations,qt]),[tt,Ut]=tr(null),kt=pt.length+e.styleModifications.length;Mn(()=>{(kt===0||tt!==null&&tt>=kt)&&Ut(null)},[kt,tt]),Mn(()=>{if(e.selectedAnnotationIds.length===0&&!e.inspectedElement){Ut(null);return}if(e.selectedAnnotationIds.length>0){let F=e.selectedAnnotationIds[0],ne=pt.findIndex(oe=>oe.id===F||oe.annotations.some(Se=>Se.id===F));ne>=0&&ne!==tt&&Ut(ne)}},[e.selectedAnnotationIds,e.inspectedElement,pt]);let Jn=mn(()=>{var ne;if(kt===0)return;let F;if(tt===null?F=0:F=(tt+1)%kt,Ut(F),F<pt.length){let oe=pt[F];if(!oe)return;t({type:"SELECT_ELEMENT",payload:null}),t({type:"SELECT_ANNOTATION",payload:{id:oe.id}});let Se=oe.annotations.find(fe=>fe.type!=="text")||oe.annotations[0];if(oe.annotations.some(fe=>fe.linkedSelector))t({type:"SET_TOOL",payload:"inspector"});else if(Se!=null&&Se.type&&Se.type!=="text"&&Se.type!=="inspector"){t({type:"SET_TOOL",payload:Se.type});let fe=go.findIndex(He=>He.type===Se.type);fe>=0&&ee(fe)}if(Se!=null&&Se.color){t({type:"SET_COLOR",payload:Se.color});let fe=ut(Se.color);fe!==null&&vt(fe)}let pe=oe.annotations.flatMap(fe=>fe.points);if(pe.length===0)return;let xt=Math.min(...pe.map(fe=>fe.x)),Je=Math.max(...pe.map(fe=>fe.x)),Tn=Math.min(...pe.map(fe=>fe.y)),P=Math.max(...pe.map(fe=>fe.y)),Q=(xt+Je)/2,se=(Tn+P)/2;if(window.scrollTo({left:Q-window.innerWidth/2,top:se-window.innerHeight/2,behavior:"smooth"}),b&&w){let fe=(ne=oe.annotations.find(He=>He.threadId))==null?void 0:ne.threadId;fe&&w(fe)}}else{let oe=F-pt.length,Se=e.styleModifications[oe];if(!Se)return;let Oe=Qt(Se.selector);if(!Oe)return;t({type:"SELECT_ANNOTATION",payload:{id:null}}),t({type:"SET_TOOL",payload:"inspector"}),t({type:"SELECT_ELEMENT",payload:{el:Oe,info:Se.element}});let pe=Oe.getBoundingClientRect(),xt=pe.left+pe.width/2+window.scrollX,Je=pe.top+pe.height/2+window.scrollY;window.scrollTo({left:xt-window.innerWidth/2,top:Je-window.innerHeight/2,behavior:"smooth"})}},[pt,e.styleModifications,kt,tt,t,ut,b,w]);Mn(()=>{if(!ue)return;let F=ne=>{var pe;let oe=document.activeElement;for(;(pe=oe==null?void 0:oe.shadowRoot)!=null&&pe.activeElement;)oe=oe.shadowRoot.activeElement;if((oe==null?void 0:oe.tagName)==="INPUT"||(oe==null?void 0:oe.tagName)==="TEXTAREA"||oe!=null&&oe.isContentEditable)return;if((ne.metaKey||ne.ctrlKey)&&ne.key==="Enter"){r&&(e.annotations.length>0||e.styleModifications.length>0||e.spacingTokenChanges.filter(xt=>!xt.captured).length>0)&&(ne.preventDefault(),Ht());return}if((ne.metaKey||ne.ctrlKey)&&(ne.key==="c"||ne.key==="C"||ne.code==="KeyC")){(e.annotations.length>0||e.styleModifications.length>0)&&(ne.preventDefault(),window.focus(),Rt());return}if((ne.metaKey||ne.ctrlKey)&&(ne.key==="Backspace"||ne.key==="Delete")){ne.preventDefault(),wt();return}if(ne.metaKey||ne.ctrlKey||ne.altKey)return;let Se={p:"freehand",l:"line",r:"rectangle",o:"circle",t:"text",c:"inspector",h:"hand"};if(ne.key.toLowerCase()==="m"){ne.preventDefault(),et("model");return}let Oe=Se[ne.key.toLowerCase()];if(Oe){ne.preventDefault();let xt=go.findIndex(Je=>Je.type===Oe);xt>=0&&ee(xt),et(Oe)}};return window.addEventListener("keydown",F),()=>window.removeEventListener("keydown",F)},[ue,et,Rt,Ht,r,wt,e.annotations.length,e.styleModifications.length,e.spacingTokenChanges,ye]);let dn=y(f({},Up),{borderRadius:0,padding:ue?"0 8px":"0",width:ue?"auto":48,height:48,gap:0,justifyContent:ue?"flex-start":"center"}),Pn=v===!1?"rgba(239, 68, 68, 0.4)":o&&i?i:Fn.iconActive;return ue?St(fo,{children:[re("style",{children:`
13
15
  @keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
14
- `}),re("div",{id:"devtools-scrim",style:{position:"fixed",inset:0,backgroundColor:"rgba(0, 0, 0, 0.06)",zIndex:9997,pointerEvents:"none"}}),!b&&(ge==="model"||e.activeTool==="model")&&re(Gl,{bridgeUrl:k,selectedComponent:I,hoveredComponent:$,onComponentHover:q,onSpacingTokenHover:j,onModifySpacingToken:T,onDeleteSpacingToken:D,modelRefreshKey:K,onComponentAdded:ee,onComponentRemoved:me,onMouseEnter:()=>{Le(),Ve.current&&(clearTimeout(Ve.current),Ve.current=null)},onMouseLeave:e.activeTool==="model"?void 0:fe}),ge&&ge!=="model"&&(ge==="provider"||Ul[ge])&&(()=>{let W=ge==="provider"?Qe:Ul[ge];return yt("div",{onMouseEnter:ge==="collapse"?()=>{Le(),Ve.current&&(clearTimeout(Ve.current),Ve.current=null)}:void 0,onMouseLeave:ge==="collapse"?fe:void 0,style:f(h(f({position:"fixed",bottom:80,right:16,width:300,backgroundColor:"#ffffff"},bn),{boxSizing:"content-box",zIndex:10001,fontFamily:"ui-monospace, SFMono-Regular, Menlo, Consolas, monospace",fontSize:12,color:"#1f2937",padding:12}),ge!=="collapse"?{pointerEvents:"none"}:{}),children:[ge==="collapse"&&re("div",{style:{marginBottom:10},children:re("svg",{width:"48",height:"48",viewBox:"0 0 40 40",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:re("path",{d:"M11.1406 31.2559C11.2407 31.3875 11.351 31.5132 11.4697 31.6338L3.10449 40H2.39746L11.1406 31.2559ZM8.05371 40H7.34668L14.5498 32.7959C14.8554 32.7706 15.1541 32.7063 15.4414 32.6113L8.05371 40ZM18.2197 34.0762C18.3788 34.1569 18.5445 34.2272 18.7168 34.2861L13.0039 40H12.2969L18.2197 34.0762ZM17.9531 40H17.2461L26.1338 31.1113C26.438 31.0829 26.7427 31.0148 27.0439 30.9082L17.9531 40ZM40 22.9023L22.9033 40H22.1963L40 22.1953V22.9023ZM40 27.8525L27.8525 40H27.1455L40 27.1455V27.8525ZM40 32.8027L32.8027 40H32.0957L40 32.0957V32.8027ZM40 37.752L37.752 40H37.0449L40 37.0449V37.752ZM9.06543 28.3809C9.25255 28.4332 9.45183 28.4715 9.66504 28.4883L0 38.1543V37.4473L9.06543 28.3809ZM6.59375 25.9023C6.65822 26.0626 6.73171 26.2263 6.81445 26.3896L0 33.2041V32.4971L6.59375 25.9023ZM20.25 8.00293H20.249C21.5098 8.0286 22.7219 8.25094 23.8584 8.63672L23.8604 8.63574C23.8961 8.64787 23.9312 8.66145 23.9668 8.67383C24.0611 8.70686 24.1548 8.74106 24.248 8.77637C24.2915 8.79273 24.3357 8.80727 24.3789 8.82422L24.376 8.82617C27.6145 10.0955 30.1646 12.7301 31.3213 16.0234L31.3232 16.0225C31.3327 16.0493 31.3404 16.0766 31.3496 16.1035C31.7691 17.3256 32 18.6356 32 20C32 20.8726 31.9366 21.6706 31.7598 22.4902L31.7197 22.6328C31.6412 23.0066 31.5136 23.6108 31.3408 24.2217L31.3398 24.2246C31.2967 24.377 31.251 24.5299 31.2021 24.6797C30.9215 25.5403 30.5473 26.2998 30.0879 26.2998C29.7613 26.2996 29.5995 25.9674 29.4316 25.6221C29.2501 25.2487 29.0614 24.8605 28.6484 24.8604C27.8532 24.8604 27.2081 25.5046 27.208 26.2998V27.0771C27.2079 27.6079 26.9661 28.112 26.5205 28.4004C25.9146 28.7925 25.2357 28.6462 24.7959 28.2061L24.7949 28.208C24.7897 28.2028 24.7854 28.1967 24.7803 28.1914C24.7654 28.1761 24.7507 28.1606 24.7363 28.1445C24.7105 28.1156 24.6858 28.0857 24.6621 28.0547C24.6461 28.0339 24.6302 28.013 24.6152 27.9912C24.5931 27.9591 24.5726 27.9257 24.5527 27.8916C24.5392 27.8685 24.5261 27.8452 24.5137 27.8213C24.5093 27.8128 24.5043 27.8045 24.5 27.7959L24.501 27.7939C24.3932 27.5763 24.3282 27.3276 24.3281 27.0576V26.2998C24.328 25.5993 23.8278 25.0158 23.165 24.8867V24.8877C23.0752 24.8702 22.9826 24.8604 22.8877 24.8604C22.8446 24.8604 22.8019 24.8624 22.7598 24.8662C22.0247 24.9312 21.4483 25.5479 21.4482 26.2998C21.4482 26.9127 21.4608 27.5305 21.4736 28.1494L21.4951 29.3135C21.5 29.7013 21.5015 30.089 21.4971 30.4756C21.4874 31.3103 20.8426 32 20.0078 32C19.1732 31.9998 18.5292 31.3102 18.5195 30.4756C18.5159 30.1613 18.5176 29.8464 18.5205 29.5312V29.5322C18.5212 29.4593 18.5206 29.3864 18.5215 29.3135L18.5303 28.8154V28.8145C18.5343 28.5927 18.5384 28.371 18.543 28.1494C18.5558 27.5305 18.5684 28.1129 18.5684 27.5C18.5684 26.7047 17.9232 26.0596 17.1279 26.0596C16.907 26.0596 16.6978 26.1103 16.5107 26.1992C16.2161 26.3393 15.9767 26.5769 15.834 26.8701C15.8269 26.8846 15.8201 26.8993 15.8135 26.9141C15.7821 26.9845 15.7562 27.0579 15.7363 27.1338C15.7243 27.1798 15.7155 27.2267 15.708 27.2744C15.7012 27.3175 15.6953 27.361 15.6924 27.4053C15.6903 27.4366 15.6885 27.4681 15.6885 27.5V28.7383C15.6883 29.9234 14.4911 30.7248 13.4961 30.0811C13.0505 29.7926 12.8086 29.2886 12.8086 28.7578V26.2998C12.8086 25.9737 12.6984 25.674 12.5156 25.4326C12.4437 25.3381 12.3612 25.2521 12.2686 25.1777V25.1768C12.0219 24.9788 11.709 24.8604 11.3682 24.8604C10.9892 24.8604 10.8622 24.8872 10.7295 25.2295C10.5837 25.6055 10.4302 26 9.92773 26C9.33081 25.9996 8.95963 25.2403 8.71484 24.3799C8.5591 23.8325 8.45907 23.571 8.3623 23.0107C8.3501 22.9401 8.33284 22.8403 8.31738 22.7529C8.12812 21.9466 8.02043 21.1089 8.00293 20.249V20.25L8 20C8 19.8617 8.00317 19.724 8.00781 19.5869C8.00837 19.5703 8.00816 19.5537 8.00879 19.5371L8.00977 19.5352C8.0998 17.1716 8.87444 14.9844 10.1396 13.1631C10.1488 13.1499 10.1587 13.1372 10.168 13.124C12.255 10.1453 15.6582 8.15745 19.5352 8.00977L19.5371 8.00879C19.5537 8.00816 19.5703 8.00837 19.5869 8.00781C19.724 8.00317 19.8617 8 20 8L20.25 8.00293ZM5.72266 22.5303L0 28.2539V27.5469L5.62793 21.918C5.6553 22.1234 5.6868 22.3275 5.72266 22.5303ZM16.2637 26.8398L16.2617 26.8408C16.2784 26.8013 16.2954 26.7627 16.3135 26.7256C16.3203 26.7116 16.3275 26.6982 16.334 26.6855C16.3125 26.7277 16.289 26.7808 16.2637 26.8398ZM40 17.9531L33.9854 23.9668C34.051 23.6832 34.1043 23.4321 34.1445 23.2412L34.1641 23.1748L34.1865 23.0967L34.1963 23.0488L40 17.2461V17.9531ZM5.87012 16.7266C5.80321 17.0165 5.74649 17.3101 5.69727 17.6064L0 23.3047V22.5977L5.87012 16.7266ZM40 13.0039L34.4297 18.5732C34.409 18.3615 34.3832 18.1513 34.3535 17.9424L40 12.2969V13.0039ZM0 18.3555V17.6484L17.6484 0H18.3555L0 18.3555ZM40 8.05371L33.458 14.5947C33.3909 14.4277 33.3202 14.2625 33.2471 14.0986L40 7.34668V8.05371ZM0 13.4053V12.6982L12.6992 0H13.4062L0 13.4053ZM40 3.10352L31.6865 11.416C31.5868 11.2805 31.4851 11.1465 31.3809 11.0146L40 2.39648V3.10352ZM29.2881 8.86523C29.1595 8.75783 29.0288 8.65278 28.8965 8.5498L37.4473 0H38.1543L29.2881 8.86523ZM0 8.45508V7.74805L7.74805 0H8.45508L0 8.45508ZM26.2783 6.92578C26.1183 6.84878 25.9562 6.77534 25.793 6.7041L32.498 0H33.2051L26.2783 6.92578ZM17.6064 5.69727C17.3101 5.74649 17.0165 5.80321 16.7266 5.87012L22.5977 0H23.3047L17.6064 5.69727ZM22.5322 5.7207C22.3295 5.685 22.1254 5.65316 21.9199 5.62598L27.5469 0H28.2539L22.5322 5.7207ZM0 3.50586V2.79883L2.79883 0H3.50586L0 3.50586Z",fill:"currentColor"})})}),yt("div",{style:{display:"flex",alignItems:"center",gap:6,fontWeight:700,fontSize:13,marginBottom:6},children:[re("span",{children:W.name}),W.keys[0]&&re("code",{style:{fontSize:10,fontWeight:500,backgroundColor:"rgba(0,0,0,0.06)",padding:"1px 4px",color:"#6b7280"},children:W.keys[0].key})]}),re("div",{style:{color:"#6b7280",lineHeight:1.5,marginBottom:ge==="collapse"?0:10},children:W.desc.split(`
16
+ `}),re("div",{id:"devtools-scrim",style:{position:"fixed",inset:0,backgroundColor:"rgba(0, 0, 0, 0.06)",zIndex:9997,pointerEvents:"none"}}),!b&&(ye==="model"||e.activeTool==="model")&&re(Ta,{bridgeUrl:T,selectedComponent:O,hoveredComponent:H,onComponentHover:U,onSpacingTokenHover:G,onModifySpacingToken:X,onDeleteSpacingToken:S,modelRefreshKey:I,onComponentAdded:K,onComponentRemoved:ge,onMouseEnter:()=>{xe(),dt.current&&(clearTimeout(dt.current),dt.current=null)},onMouseLeave:e.activeTool==="model"?void 0:Ce}),ye&&ye!=="model"&&(ye==="provider"||Ra[ye])&&(()=>{let F=ye==="provider"?qe:Ra[ye];return St("div",{onMouseEnter:ye==="collapse"?()=>{xe(),dt.current&&(clearTimeout(dt.current),dt.current=null)}:void 0,onMouseLeave:ye==="collapse"?Ce:void 0,style:f(y(f({position:"fixed",bottom:80,right:16,width:300,backgroundColor:"#eaeaea"},En),{boxSizing:"content-box",zIndex:10001,fontFamily:"ui-monospace, SFMono-Regular, Menlo, Consolas, monospace",fontSize:12,color:"#1f2937",padding:12}),ye!=="collapse"?{pointerEvents:"none"}:{}),children:[ye==="collapse"&&re("div",{style:{marginBottom:10},children:re("svg",{width:"48",height:"48",viewBox:"0 0 40 40",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:re("path",{d:"M11.1406 31.2559C11.2407 31.3875 11.351 31.5132 11.4697 31.6338L3.10449 40H2.39746L11.1406 31.2559ZM8.05371 40H7.34668L14.5498 32.7959C14.8554 32.7706 15.1541 32.7063 15.4414 32.6113L8.05371 40ZM18.2197 34.0762C18.3788 34.1569 18.5445 34.2272 18.7168 34.2861L13.0039 40H12.2969L18.2197 34.0762ZM17.9531 40H17.2461L26.1338 31.1113C26.438 31.0829 26.7427 31.0148 27.0439 30.9082L17.9531 40ZM40 22.9023L22.9033 40H22.1963L40 22.1953V22.9023ZM40 27.8525L27.8525 40H27.1455L40 27.1455V27.8525ZM40 32.8027L32.8027 40H32.0957L40 32.0957V32.8027ZM40 37.752L37.752 40H37.0449L40 37.0449V37.752ZM9.06543 28.3809C9.25255 28.4332 9.45183 28.4715 9.66504 28.4883L0 38.1543V37.4473L9.06543 28.3809ZM6.59375 25.9023C6.65822 26.0626 6.73171 26.2263 6.81445 26.3896L0 33.2041V32.4971L6.59375 25.9023ZM20.25 8.00293H20.249C21.5098 8.0286 22.7219 8.25094 23.8584 8.63672L23.8604 8.63574C23.8961 8.64787 23.9312 8.66145 23.9668 8.67383C24.0611 8.70686 24.1548 8.74106 24.248 8.77637C24.2915 8.79273 24.3357 8.80727 24.3789 8.82422L24.376 8.82617C27.6145 10.0955 30.1646 12.7301 31.3213 16.0234L31.3232 16.0225C31.3327 16.0493 31.3404 16.0766 31.3496 16.1035C31.7691 17.3256 32 18.6356 32 20C32 20.8726 31.9366 21.6706 31.7598 22.4902L31.7197 22.6328C31.6412 23.0066 31.5136 23.6108 31.3408 24.2217L31.3398 24.2246C31.2967 24.377 31.251 24.5299 31.2021 24.6797C30.9215 25.5403 30.5473 26.2998 30.0879 26.2998C29.7613 26.2996 29.5995 25.9674 29.4316 25.6221C29.2501 25.2487 29.0614 24.8605 28.6484 24.8604C27.8532 24.8604 27.2081 25.5046 27.208 26.2998V27.0771C27.2079 27.6079 26.9661 28.112 26.5205 28.4004C25.9146 28.7925 25.2357 28.6462 24.7959 28.2061L24.7949 28.208C24.7897 28.2028 24.7854 28.1967 24.7803 28.1914C24.7654 28.1761 24.7507 28.1606 24.7363 28.1445C24.7105 28.1156 24.6858 28.0857 24.6621 28.0547C24.6461 28.0339 24.6302 28.013 24.6152 27.9912C24.5931 27.9591 24.5726 27.9257 24.5527 27.8916C24.5392 27.8685 24.5261 27.8452 24.5137 27.8213C24.5093 27.8128 24.5043 27.8045 24.5 27.7959L24.501 27.7939C24.3932 27.5763 24.3282 27.3276 24.3281 27.0576V26.2998C24.328 25.5993 23.8278 25.0158 23.165 24.8867V24.8877C23.0752 24.8702 22.9826 24.8604 22.8877 24.8604C22.8446 24.8604 22.8019 24.8624 22.7598 24.8662C22.0247 24.9312 21.4483 25.5479 21.4482 26.2998C21.4482 26.9127 21.4608 27.5305 21.4736 28.1494L21.4951 29.3135C21.5 29.7013 21.5015 30.089 21.4971 30.4756C21.4874 31.3103 20.8426 32 20.0078 32C19.1732 31.9998 18.5292 31.3102 18.5195 30.4756C18.5159 30.1613 18.5176 29.8464 18.5205 29.5312V29.5322C18.5212 29.4593 18.5206 29.3864 18.5215 29.3135L18.5303 28.8154V28.8145C18.5343 28.5927 18.5384 28.371 18.543 28.1494C18.5558 27.5305 18.5684 28.1129 18.5684 27.5C18.5684 26.7047 17.9232 26.0596 17.1279 26.0596C16.907 26.0596 16.6978 26.1103 16.5107 26.1992C16.2161 26.3393 15.9767 26.5769 15.834 26.8701C15.8269 26.8846 15.8201 26.8993 15.8135 26.9141C15.7821 26.9845 15.7562 27.0579 15.7363 27.1338C15.7243 27.1798 15.7155 27.2267 15.708 27.2744C15.7012 27.3175 15.6953 27.361 15.6924 27.4053C15.6903 27.4366 15.6885 27.4681 15.6885 27.5V28.7383C15.6883 29.9234 14.4911 30.7248 13.4961 30.0811C13.0505 29.7926 12.8086 29.2886 12.8086 28.7578V26.2998C12.8086 25.9737 12.6984 25.674 12.5156 25.4326C12.4437 25.3381 12.3612 25.2521 12.2686 25.1777V25.1768C12.0219 24.9788 11.709 24.8604 11.3682 24.8604C10.9892 24.8604 10.8622 24.8872 10.7295 25.2295C10.5837 25.6055 10.4302 26 9.92773 26C9.33081 25.9996 8.95963 25.2403 8.71484 24.3799C8.5591 23.8325 8.45907 23.571 8.3623 23.0107C8.3501 22.9401 8.33284 22.8403 8.31738 22.7529C8.12812 21.9466 8.02043 21.1089 8.00293 20.249V20.25L8 20C8 19.8617 8.00317 19.724 8.00781 19.5869C8.00837 19.5703 8.00816 19.5537 8.00879 19.5371L8.00977 19.5352C8.0998 17.1716 8.87444 14.9844 10.1396 13.1631C10.1488 13.1499 10.1587 13.1372 10.168 13.124C12.255 10.1453 15.6582 8.15745 19.5352 8.00977L19.5371 8.00879C19.5537 8.00816 19.5703 8.00837 19.5869 8.00781C19.724 8.00317 19.8617 8 20 8L20.25 8.00293ZM5.72266 22.5303L0 28.2539V27.5469L5.62793 21.918C5.6553 22.1234 5.6868 22.3275 5.72266 22.5303ZM16.2637 26.8398L16.2617 26.8408C16.2784 26.8013 16.2954 26.7627 16.3135 26.7256C16.3203 26.7116 16.3275 26.6982 16.334 26.6855C16.3125 26.7277 16.289 26.7808 16.2637 26.8398ZM40 17.9531L33.9854 23.9668C34.051 23.6832 34.1043 23.4321 34.1445 23.2412L34.1641 23.1748L34.1865 23.0967L34.1963 23.0488L40 17.2461V17.9531ZM5.87012 16.7266C5.80321 17.0165 5.74649 17.3101 5.69727 17.6064L0 23.3047V22.5977L5.87012 16.7266ZM40 13.0039L34.4297 18.5732C34.409 18.3615 34.3832 18.1513 34.3535 17.9424L40 12.2969V13.0039ZM0 18.3555V17.6484L17.6484 0H18.3555L0 18.3555ZM40 8.05371L33.458 14.5947C33.3909 14.4277 33.3202 14.2625 33.2471 14.0986L40 7.34668V8.05371ZM0 13.4053V12.6982L12.6992 0H13.4062L0 13.4053ZM40 3.10352L31.6865 11.416C31.5868 11.2805 31.4851 11.1465 31.3809 11.0146L40 2.39648V3.10352ZM29.2881 8.86523C29.1595 8.75783 29.0288 8.65278 28.8965 8.5498L37.4473 0H38.1543L29.2881 8.86523ZM0 8.45508V7.74805L7.74805 0H8.45508L0 8.45508ZM26.2783 6.92578C26.1183 6.84878 25.9562 6.77534 25.793 6.7041L32.498 0H33.2051L26.2783 6.92578ZM17.6064 5.69727C17.3101 5.74649 17.0165 5.80321 16.7266 5.87012L22.5977 0H23.3047L17.6064 5.69727ZM22.5322 5.7207C22.3295 5.685 22.1254 5.65316 21.9199 5.62598L27.5469 0H28.2539L22.5322 5.7207ZM0 3.50586V2.79883L2.79883 0H3.50586L0 3.50586Z",fill:"currentColor"})})}),St("div",{style:{display:"flex",alignItems:"center",gap:6,fontWeight:700,fontSize:13,marginBottom:6},children:[re("span",{children:F.name}),F.keys[0]&&re("code",{style:{fontSize:10,fontWeight:500,backgroundColor:"rgba(0,0,0,0.06)",padding:"1px 4px",color:"#6b7280"},children:F.keys[0].key})]}),re("div",{style:{color:"#6b7280",lineHeight:1.5,marginBottom:ye==="collapse"?0:10},children:F.desc.split(`
15
17
 
16
- `).map((te,U)=>re("p",{style:{margin:0,marginTop:U>0?8:0},children:te},U))}),W.usage.map((te,U)=>yt("div",{style:{display:"flex",gap:6,marginBottom:3,lineHeight:1.4},children:[re("span",{style:{color:"#9ca3af",flexShrink:0},children:"\u2013"}),re("span",{children:te})]},U)),ge==="collapse"&&w&&Object.keys(w).length>0&&(()=>{let te=Object.entries(w).filter(([,Be])=>Be.found&&!Be.disabled).map(([Be])=>Be.charAt(0).toUpperCase()+Be.slice(1)),U=Object.entries(w).filter(([,Be])=>!Be.found).map(([Be])=>Be);if(te.length===0&&U.length===0)return null;let Pe=U.map(Be=>Be.charAt(0).toUpperCase()+Be.slice(1));return yt("div",{style:{borderTop:"1px solid rgba(0,0,0,0.08)",marginTop:10,paddingTop:8,display:"flex",alignItems:"center",gap:6,fontSize:11},children:[re("span",{style:{width:6,height:6,borderRadius:"50%",backgroundColor:te.length>0?"#22c55e":"rgba(0,0,0,0.2)",flexShrink:0}}),te.length>0?yt("span",{style:{color:"#6b7280",display:"flex",alignItems:"center",gap:6},children:[yt("span",{children:["Taste library ready in ",te.join(", "),A&&" \u2014 restart CLI to activate"]}),U.length>0&&O&&!A&&yt("button",{type:"button",onClick:Be=>{Be.stopPropagation(),O()},style:{border:"none",background:"transparent",color:"#3b82f6",fontSize:10,fontWeight:500,fontFamily:"inherit",padding:0,cursor:"pointer",pointerEvents:"auto",textDecoration:"underline",textUnderlineOffset:2},children:["+ ",Pe.join(", ")]})]}):U.length>0&&O?yt("span",{style:{color:"#6b7280",display:"flex",alignItems:"center",gap:6},children:[re("span",{children:"Connect Popmelt MCP"}),re("button",{type:"button",onClick:Be=>{Be.stopPropagation(),O()},style:{border:"none",background:"#1f2937",color:"#fff",fontSize:10,fontWeight:600,fontFamily:"inherit",padding:"2px 8px",cursor:"pointer",pointerEvents:"auto"},children:"Connect"})]}):null]})})(),W.keys.length>1&&re("div",{style:{borderTop:"1px solid rgba(0,0,0,0.08)",marginTop:8,paddingTop:8,display:"flex",flexDirection:"column",gap:4},children:W.keys.slice(1).map((te,U)=>yt("div",{style:{display:"flex",alignItems:"center",gap:8,fontSize:11,color:te.accent?"#fff":"#6b7280"},children:[re("code",{style:{fontSize:10,backgroundColor:te.accent?e.activeColor:"rgba(0,0,0,0.06)",color:te.accent?"#fff":void 0,padding:"1px 4px",whiteSpace:"nowrap"},children:te.key}),re("span",{style:{color:te.accent?e.activeColor:void 0,fontWeight:te.accent?600:void 0},children:te.desc})]},U))})]})})(),yt("div",{ref:W=>{ae&&(ae.current=W)},id:"devtools-toolbar",style:kt,onMouseEnter:ve,onMouseMove:lt,children:[(e.annotations.length>0||e.styleModifications.length>0)&&yt(eo,{children:[re("span",{onMouseEnter:()=>Ze("clear"),onMouseLeave:fe,children:re(Bn,{onClick:vt,title:"Clear all (\u2318\u232B)",children:re(Ou,{size:17,strokeWidth:1.5})})}),re(Oi,{})]}),yt("div",{style:{display:"flex",flexDirection:"row",gap:4,alignItems:"center"},children:[re("span",{onMouseEnter:()=>Ze("inspector"),onMouseLeave:fe,children:re(Bn,{active:e.isAnnotating&&e.activeTool==="inspector",siblingActive:e.isAnnotating,onClick:()=>st("inspector"),children:re(Ru,{size:20,strokeWidth:1.5})})}),re("span",{onMouseEnter:()=>Ze("hand"),onMouseLeave:fe,children:re(Bn,{active:e.isAnnotating&&e.activeTool==="hand",siblingActive:e.isAnnotating,onClick:()=>st("hand"),children:yt("div",{style:{position:"relative",display:"flex",alignItems:"center",justifyContent:"center"},children:[re(Iu,{size:20,strokeWidth:1.5}),e.styleModifications.filter(W=>!W.captured).length>0&&re("div",{style:{position:"absolute",top:-7,right:-9,minWidth:14,height:14,borderRadius:0,backgroundColor:e.activeColor,color:"#fff",fontSize:9,fontWeight:700,display:"flex",alignItems:"center",justifyContent:"center",padding:"0 2px",lineHeight:1},children:e.styleModifications.filter(W=>!W.captured).length})]})})}),(()=>{let W=to[Me],te=W.icon,U=e.isAnnotating&&Hu.has(e.activeTool);return re("span",{onMouseEnter:()=>Ze(W.type),onMouseLeave:fe,children:yt("div",{style:{display:"flex",alignItems:"center",gap:0},children:[re(Bn,{active:U,siblingActive:e.isAnnotating,onClick:()=>st(W.type),children:re(te,{size:20,strokeWidth:1.5})}),re("button",{type:"button",onClick:()=>{let Pe=(Me+1)%to.length;ne(Pe),st(to[Pe].type)},title:"Cycle shape tool",style:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",gap:2,width:12,height:32,border:"none",background:"none",cursor:"pointer",padding:"0 2px",opacity:e.isAnnotating&&!U?.5:1,transition:"opacity 150ms ease"},children:to.map((Pe,Be)=>re("div",{style:{width:3,height:3,borderRadius:"50%",backgroundColor:Be===Me?Pn.iconDefault:"rgba(0,0,0,0.2)",transition:"background-color 150ms ease"}},Be))})]})})})(),_u.map(({type:W,icon:te,label:U,shortcut:Pe})=>re("span",{onMouseEnter:()=>Ze(W),onMouseLeave:fe,children:re(Bn,{active:e.isAnnotating&&e.activeTool===W,siblingActive:e.isAnnotating,onClick:()=>st(W),children:re(te,{size:20,strokeWidth:1.5})})},W)),re("span",{onMouseEnter:()=>Ze("model"),onMouseLeave:fe,children:re(Bn,{active:e.isAnnotating&&e.activeTool==="model",siblingActive:e.isAnnotating,onClick:()=>st("model"),children:re(Lu,{size:17,strokeWidth:1.5})})})]}),re(Oi,{}),yt("div",{style:{display:"flex",flexDirection:"row",gap:4,alignItems:"center"},children:[(pt.length>0||e.styleModifications.length>0||e.spacingTokenChanges.filter(W=>!W.captured).length>0)&&(()=>{var Be;let W=bt!==null&&bt<pt.length?pt[bt]:null,te=e.annotations.length>0&&e.annotations.every(he=>he.status&&he.status!=="pending"),U=bt!==null?(Be=W==null?void 0:W.annotations.some(he=>he.status&&he.status!=="pending"))!=null?Be:!1:te,Pe=`oklch(0.628 0.258 ${$e})`;return re("span",{onMouseEnter:()=>Ze("counter"),onMouseLeave:fe,children:re("button",{ref:rn,type:"button",onClick:()=>{if(Ie.current){Ie.current=!1;return}$t()},onMouseDown:Fe,onMouseUp:ft,onMouseLeave:ft,title:"Cycle through annotations \u2022 Scroll to change color \u2022 Long press to reset",style:{display:"flex",alignItems:"center",justifyContent:"center",width:20,height:20,padding:0,marginRight:4,border:"none",borderRadius:0,background:U?"#999999":Pe,cursor:"pointer",fontFamily:"ui-monospace, SFMono-Regular, Menlo, Consolas, monospace",fontSize:11,fontWeight:600,color:"#ffffff",transition:"background 150ms ease"},children:bt!==null?bt+1:pt.length+e.styleModifications.length+e.spacingTokenChanges.filter(he=>!he.captured).length})})})(),c&&re("span",{onMouseEnter:()=>Ze("provider"),onMouseLeave:fe,style:{display:"contents"},children:yt("div",{style:{display:"flex",alignItems:"center",gap:0},children:[re(Bn,{onClick:()=>c(a==="claude"?"codex":"claude"),children:a==="claude"?re(Wu,{}):re(Yu,{})}),yt("button",{type:"button",onClick:()=>{let W=(u+1)%p;S==null||S(W)},style:{display:"flex",alignItems:"center",gap:6,height:32,border:"none",background:"none",cursor:"pointer",padding:"0 4px 0 0",fontFamily:"ui-monospace, SFMono-Regular, Menlo, Consolas, monospace",fontSize:10,fontWeight:500,color:Pn.iconDefault,whiteSpace:"nowrap"},children:[re("span",{children:g}),re("span",{style:{display:"flex",flexDirection:"column",gap:2},children:Array.from({length:p},(W,te)=>re("div",{style:{width:3,height:3,borderRadius:"50%",backgroundColor:te===u?Pn.iconDefault:"rgba(0,0,0,0.2)",transition:"background-color 150ms ease"}},te))})]})]})}),re("div",{onMouseEnter:W=>{s==null||s(!0),W.currentTarget.style.opacity="1",Ze("collapse")},onMouseLeave:W=>{s==null||s(!1),W.currentTarget.style.opacity=n?"1":"0.3",fe()},style:{display:"inline-flex",opacity:n?1:.3,transition:"opacity 150ms ease"},children:re(Bn,{onClick:tt,title:"Collapse (\u2318\u2318)",children:n?re("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:hn,children:xe===1?yt(eo,{children:[re("circle",{cx:"7",cy:"7",r:"2"}),re("circle",{cx:"17",cy:"7",r:"2"}),re("circle",{cx:"7",cy:"17",r:"2"}),re("circle",{cx:"17",cy:"17",r:"2"})]}):yt(eo,{children:[re("circle",{cx:"12",cy:"6",r:"2"}),re("circle",{cx:"6",cy:"12",r:"2"}),re("circle",{cx:"18",cy:"12",r:"2"}),re("circle",{cx:"12",cy:"18",r:"2"})]})}):yt("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:hn,strokeWidth:"1.5",strokeLinecap:"round",style:{transform:"rotate(45deg)"},children:[re("line",{x1:"12",y1:"3",x2:"12",y2:"9"}),re("line",{x1:"12",y1:"15",x2:"12",y2:"21"}),re("line",{x1:"3",y1:"12",x2:"9",y2:"12"}),re("line",{x1:"15",y1:"12",x2:"21",y2:"12"})]})})})]})]})]}):yt(eo,{children:[re("style",{children:"@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }"}),re("div",{ref:W=>{ae&&(ae.current=W)},id:"devtools-toolbar",style:h(f({},kt),{overflow:"visible",opacity:.5,transition:"opacity 150ms ease"}),onMouseEnter:W=>{W.currentTarget.style.opacity="1",ve==null||ve()},onMouseLeave:W=>W.currentTarget.style.opacity="0.5",children:re("button",{type:"button",style:{display:"flex",alignItems:"center",justifyContent:"center",width:48,height:48,border:"none",background:"none",cursor:"pointer",padding:0},onClick:()=>{We(!0),t({type:"SET_TOOL",payload:"inspector"}),t({type:"SET_ANNOTATING",payload:!0})},onMouseEnter:()=>s==null?void 0:s(!0),onMouseLeave:()=>s==null?void 0:s(!1),title:"Open annotation toolbar (\u2318\u2318)",children:n?re("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:hn,children:xe===1?yt(eo,{children:[re("circle",{cx:"7",cy:"7",r:"2"}),re("circle",{cx:"17",cy:"7",r:"2"}),re("circle",{cx:"7",cy:"17",r:"2"}),re("circle",{cx:"17",cy:"17",r:"2"})]}):yt(eo,{children:[re("circle",{cx:"12",cy:"6",r:"2"}),re("circle",{cx:"6",cy:"12",r:"2"}),re("circle",{cx:"18",cy:"12",r:"2"}),re("circle",{cx:"12",cy:"18",r:"2"})]})}):yt("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:hn,strokeWidth:"1.5",strokeLinecap:"round",children:[re("line",{x1:"12",y1:"3",x2:"12",y2:"9"}),re("line",{x1:"12",y1:"15",x2:"12",y2:"21"}),re("line",{x1:"3",y1:"12",x2:"9",y2:"12"}),re("line",{x1:"15",y1:"12",x2:"21",y2:"12"})]})})})]})}import{useEffect as Io,useRef as ju,useState as $i}from"react";import{Fragment as Ql,jsx as Mt,jsxs as Go}from"react/jsx-runtime";var Gu={position:"fixed",bottom:86,right:16,zIndex:9999,display:"flex",flexDirection:"column"},Vu=24,Uu=6,Ju=Vu-Uu,Xu=8,ql=h(f({display:"flex",alignItems:"center",gap:6,padding:"4px 10px",backgroundColor:"rgba(255, 255, 255, 0.85)"},bn),{backdropFilter:"blur(32px)",fontFamily:"ui-monospace, SFMono-Regular, Menlo, monospace",fontSize:11,color:"#1f2937",whiteSpace:"nowrap",transition:"transform 200ms ease, opacity 200ms ease"});function Ku(e){var s;let t=e.filter(l=>l.type==="tool_use");if(t.length===0)return"Starting\u2026";let o=t[t.length-1],r=String(o.data.tool||""),n=o.data.file?String(o.data.file):null,i=n?(s=n.split("/").pop())!=null?s:n:null;switch(r){case"Read":return i?`Reading ${i}`:"Reading file";case"Edit":return i?`Editing ${i}`:"Editing file";case"Write":return i?`Writing ${i}`:"Writing file";case"Bash":return"Running command";case"Glob":return"Searching files";case"Grep":return"Searching code";default:return r?`Using ${r}`:"Working\u2026"}}function Zu(e,t){if(e.some(n=>n.type==="question"&&n.data.jobId===t))return"Has a question";let r=e.find(n=>n.type==="done"&&n.data.jobId===t);if(r){let n=r.data.resolutions;if(Array.isArray(n)&&n.length>0)return"Applied changes"}return"Replied"}function qu({color:e}){let[t,o]=$i(0);return Io(()=>{let r=setInterval(()=>{o(n=>(n+1)%2)},250);return()=>clearInterval(r)},[]),Mt("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:e,style:{verticalAlign:"middle",flexShrink:0},children:t===1?Go(Ql,{children:[Mt("circle",{cx:"7",cy:"7",r:"2"}),Mt("circle",{cx:"17",cy:"7",r:"2"}),Mt("circle",{cx:"7",cy:"17",r:"2"}),Mt("circle",{cx:"17",cy:"17",r:"2"})]}):Go(Ql,{children:[Mt("circle",{cx:"12",cy:"6",r:"2"}),Mt("circle",{cx:"6",cy:"12",r:"2"}),Mt("circle",{cx:"18",cy:"12",r:"2"}),Mt("circle",{cx:"12",cy:"18",r:"2"})]})})}function Qu({color:e}){return Mt("span",{style:{display:"inline-block",width:8,height:8,backgroundColor:e,opacity:.6}})}function ep({color:e}){return Mt("span",{style:{color:e,fontSize:12,lineHeight:1,width:10,display:"inline-block"},children:"\u2713"})}function tp(){return Mt("span",{style:{display:"inline-block",width:8,height:8,borderRadius:"50%",backgroundColor:"#ef4444"}})}function ea({bridge:e,inFlightJobs:t,isVisible:o,onHover:r,clearSignal:n,onViewThread:i,onCancel:s,onHoverJob:l,isConnected:a,dismissedThreadIds:c}){let[d,u]=$i([]),[p,g]=$i(!1);Io(()=>{n>0&&u([])},[n]),Io(()=>{!c||c.size===0||u(b=>{let w=b.filter(O=>!O.threadId||!c.has(O.threadId));return w.length===b.length?b:w})},[c]),Io(()=>{u(b=>{var k;let w=new Set(b.map(E=>E.jobId)),O=!1,A=b.map(E=>{let I=t[E.jobId];return I&&(!E.threadId||E.color==="#888")?(O=!0,h(f({},E),{threadId:E.threadId||I.threadId,color:E.color==="#888"?I.color:E.color})):E});for(let[E,I]of Object.entries(t))w.has(E)||(A.push({jobId:E,color:I.color,status:"queued",threadId:I.threadId}),O=!0);for(let E of e.activeJobIds)if(!w.has(E)&&!A.some(I=>I.jobId===E)){let I=e.events.find($=>$.type==="job_started"&&$.data.jobId===E);A.push({jobId:E,color:"#888",status:"working",threadId:(k=I==null?void 0:I.data)==null?void 0:k.threadId}),O=!0}return O?A:b})},[t,e.activeJobIds]),Io(()=>{if(e.activeJobIds.length===0)return;let b=new Set(e.activeJobIds);u(w=>w.map(O=>b.has(O.jobId)&&O.status!=="done"&&O.status!=="error"?h(f({},O),{status:"working"}):O))},[e.activeJobIds]);let S=ju(null);if(Io(()=>{let b=e.lastCompletedJobId;if(!b||b===S.current)return;S.current=b;let w=e.events.find(I=>I.type==="error"&&(I.data.jobId===b||e.status==="error")),O=!!w,A=O?void 0:Zu(e.events,b),k=w?String(w.data.message||""):void 0,E=w?!!w.data.cancelled:void 0;u(I=>I.map($=>$.jobId===b?h(f({},$),{status:O?"error":"done",doneLabel:A,errorMessage:k,cancelled:E}):$))},[e.lastCompletedJobId,e.events,e.status]),!o||d.length===0&&a!==!1)return null;let v=!p&&d.length>1;return Go("div",{style:Gu,"data-devtools":!0,onMouseEnter:()=>{g(!0),r(!0)},onMouseLeave:()=>{g(!1),r(!1),l==null||l(null)},children:[[...d].reverse().map((b,w)=>{var E;let O=w===d.length-1,A=d.length-1-w,k=b.status==="working"?Ku(e.events.filter(I=>I.data.jobId===b.jobId)):b.status==="queued"?"Queued":b.status==="done"?b.doneLabel||"Done":b.cancelled?"Cancelled":(E=b.errorMessage)!=null&&E.includes("Timed out")?"Timed out":"Error";return Mt("div",{style:{position:"relative",zIndex:w,marginBottom:v?O?0:-Ju:O?0:Xu,transform:v?`scale(${Math.max(.94,1-A*.02)})`:"scale(1)",opacity:v?Math.max(.5,1-A*.15):1,transformOrigin:"bottom right",transition:"margin-bottom 250ms ease, transform 250ms ease, opacity 250ms ease"},children:Go("div",{style:h(f({},ql),{cursor:b.threadId&&i?"pointer":void 0}),onClick:b.threadId&&i?()=>i(b.threadId):void 0,onMouseEnter:l?()=>l(b.jobId):void 0,onMouseLeave:l?()=>l(null):void 0,title:b.errorMessage||void 0,children:[b.status==="working"&&Mt(qu,{color:b.color}),b.status==="queued"&&Mt(Qu,{color:b.color}),b.status==="done"&&Mt(ep,{color:b.color}),b.status==="error"&&Mt(tp,{}),Mt("span",{style:{color:b.status==="queued"?"#9ca3af":"#1f2937"},children:k}),b.status==="working"&&s&&Mt("button",{onClick:I=>{I.stopPropagation(),s(b.jobId)},style:{background:"none",border:"none",cursor:"pointer",color:"#9ca3af",fontSize:14,padding:"0 4px",lineHeight:1},title:"Cancel",children:"\xD7"}),(b.status==="done"||b.status==="error")&&Mt("button",{onClick:I=>{I.stopPropagation(),u($=>$.filter(q=>q.jobId!==b.jobId))},style:{background:"none",border:"none",cursor:"pointer",color:"#9ca3af",fontSize:14,padding:"0 4px",lineHeight:1},title:"Dismiss",children:"\xD7"})]})},b.jobId)}),a===!1&&d.length>0&&Go("div",{style:h(f({},ql),{color:"#9ca3af"}),children:[Mt("span",{style:{display:"inline-block",width:8,height:8,borderRadius:"50%",backgroundColor:"#f59e0b"}}),Mt("span",{children:"Reconnecting\u2026"})]})]})}import{Fragment as rp,jsx as op,jsxs as ip}from"react/jsx-runtime";var np=`
18
+ `).map((ne,oe)=>re("p",{style:{margin:0,marginTop:oe>0?8:0},children:ne},oe))}),F.usage.map((ne,oe)=>St("div",{style:{display:"flex",gap:6,marginBottom:3,lineHeight:1.4},children:[re("span",{style:{color:"#9ca3af",flexShrink:0},children:"\u2013"}),re("span",{children:ne})]},oe)),ye==="collapse"&&E&&Object.keys(E).length>0&&(()=>{let ne=Object.entries(E).filter(([,Oe])=>Oe.found&&!Oe.disabled).map(([Oe])=>Oe.charAt(0).toUpperCase()+Oe.slice(1)),oe=Object.entries(E).filter(([,Oe])=>!Oe.found).map(([Oe])=>Oe);if(ne.length===0&&oe.length===0)return null;let Se=oe.map(Oe=>Oe.charAt(0).toUpperCase()+Oe.slice(1));return St("div",{style:{borderTop:"1px solid rgba(0,0,0,0.08)",marginTop:10,paddingTop:8,display:"flex",alignItems:"center",gap:6,fontSize:11},children:[re("span",{style:{width:6,height:6,borderRadius:"50%",backgroundColor:ne.length>0?"#22c55e":"rgba(0,0,0,0.2)",flexShrink:0}}),ne.length>0?St("span",{style:{color:"#6b7280",display:"flex",alignItems:"center",gap:6},children:[St("span",{children:["Registry available in ",ne.join(", "),L&&" \u2014 restart CLI to activate"]}),oe.length>0&&B&&!L&&St("button",{type:"button",onClick:Oe=>{Oe.stopPropagation(),B()},style:{border:"none",background:"transparent",color:"#3b82f6",fontSize:10,fontWeight:500,fontFamily:"inherit",padding:0,cursor:"pointer",pointerEvents:"auto",textDecoration:"underline",textUnderlineOffset:2},children:["+ ",Se.join(", ")]})]}):oe.length>0&&B?St("span",{style:{color:"#6b7280",display:"flex",alignItems:"center",gap:6},children:[re("span",{children:"Connect Popmelt MCP"}),re("button",{type:"button",onClick:Oe=>{Oe.stopPropagation(),B()},style:{border:"none",background:"#1f2937",color:"#fff",fontSize:10,fontWeight:600,fontFamily:"inherit",padding:"2px 8px",cursor:"pointer",pointerEvents:"auto"},children:"Connect"})]}):null]})})(),F.keys.length>1&&re("div",{style:{borderTop:"1px solid rgba(0,0,0,0.08)",marginTop:8,paddingTop:8,display:"flex",flexDirection:"column",gap:4},children:F.keys.slice(1).map((ne,oe)=>St("div",{style:{display:"flex",alignItems:"center",gap:8,fontSize:11,color:ne.accent?"#fff":"#6b7280"},children:[re("code",{style:{fontSize:10,backgroundColor:ne.accent?e.activeColor:"rgba(0,0,0,0.06)",color:ne.accent?"#fff":void 0,padding:"1px 4px",whiteSpace:"nowrap"},children:ne.key}),re("span",{style:{color:ne.accent?e.activeColor:void 0,fontWeight:ne.accent?600:void 0},children:ne.desc})]},oe))})]})})(),St("div",{ref:F=>{de&&(de.current=F)},id:"devtools-toolbar",style:dn,onMouseEnter:be,onMouseMove:it,children:[(e.annotations.length>0||e.styleModifications.length>0)&&St(fo,{children:[re("span",{onMouseEnter:()=>Be("clear"),onMouseLeave:Ce,children:re(_n,{onClick:wt,title:"Clear all (\u2318\u232B)",children:re($p,{size:17,strokeWidth:1.5})})}),re(es,{})]}),St("div",{style:{display:"flex",flexDirection:"row",gap:4,alignItems:"center"},children:[re("span",{onMouseEnter:()=>Be("inspector"),onMouseLeave:Ce,children:re(_n,{active:e.isAnnotating&&e.activeTool==="inspector",siblingActive:e.isAnnotating,onClick:()=>et("inspector"),children:re(Hp,{size:20,strokeWidth:1.5})})}),re("span",{onMouseEnter:()=>Be("hand"),onMouseLeave:Ce,children:re(_n,{active:e.isAnnotating&&e.activeTool==="hand",siblingActive:e.isAnnotating,onClick:()=>et("hand"),children:St("div",{style:{position:"relative",display:"flex",alignItems:"center",justifyContent:"center"},children:[re(Np,{size:20,strokeWidth:1.5}),e.styleModifications.filter(F=>!F.captured).length>0&&re("div",{style:{position:"absolute",top:-7,right:-9,minWidth:14,height:14,borderRadius:0,backgroundColor:e.activeColor,color:"#fff",fontSize:9,fontWeight:700,display:"flex",alignItems:"center",justifyContent:"center",padding:"0 2px",lineHeight:1},children:e.styleModifications.filter(F=>!F.captured).length})]})})}),(()=>{let F=go[Te],ne=F.icon,oe=e.isAnnotating&&Yp.has(e.activeTool);return re("span",{onMouseEnter:()=>Be(F.type),onMouseLeave:Ce,children:St("div",{style:{display:"flex",alignItems:"center",gap:0},children:[re(_n,{active:oe,siblingActive:e.isAnnotating,onClick:()=>et(F.type),children:re(ne,{size:20,strokeWidth:1.5})}),re("button",{type:"button",onClick:()=>{let Se=(Te+1)%go.length;ee(Se),et(go[Se].type)},title:"Cycle shape tool",style:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",gap:2,width:12,height:32,border:"none",background:"none",cursor:"pointer",padding:"0 2px",opacity:e.isAnnotating&&!oe?.5:1,transition:"opacity 150ms ease"},children:go.map((Se,Oe)=>re("div",{style:{width:3,height:3,borderRadius:"50%",backgroundColor:Oe===Te?Fn.iconDefault:"rgba(0,0,0,0.2)",transition:"background-color 150ms ease"}},Oe))})]})})})(),Vp.map(({type:F,icon:ne,label:oe,shortcut:Se})=>re("span",{onMouseEnter:()=>Be(F),onMouseLeave:Ce,children:re(_n,{active:e.isAnnotating&&e.activeTool===F,siblingActive:e.isAnnotating,onClick:()=>et(F),children:re(ne,{size:20,strokeWidth:1.5})})},F)),re("span",{onMouseEnter:()=>Be("model"),onMouseLeave:Ce,children:re(_n,{active:e.isAnnotating&&e.activeTool==="model",siblingActive:e.isAnnotating,onClick:()=>et("model"),children:re(Dp,{size:17,strokeWidth:1.5})})})]}),re(es,{}),St("div",{style:{display:"flex",flexDirection:"row",gap:4,alignItems:"center"},children:[(pt.length>0||e.styleModifications.length>0||e.spacingTokenChanges.filter(F=>!F.captured).length>0)&&(()=>{var Oe;let F=tt!==null&&tt<pt.length?pt[tt]:null,ne=e.annotations.length>0&&e.annotations.every(pe=>pe.status&&pe.status!=="pending"),oe=tt!==null?(Oe=F==null?void 0:F.annotations.some(pe=>pe.status&&pe.status!=="pending"))!=null?Oe:!1:ne,Se=`oklch(0.628 0.258 ${mt})`;return re("span",{onMouseEnter:()=>Be("counter"),onMouseLeave:Ce,children:re("button",{ref:Ft,type:"button",onClick:()=>{if(Re.current){Re.current=!1;return}Jn()},onMouseDown:Xe,onMouseUp:cn,onMouseLeave:cn,title:"Cycle through annotations \u2022 Scroll to change color \u2022 Long press to reset",style:{display:"flex",alignItems:"center",justifyContent:"center",width:20,height:20,padding:0,marginRight:4,border:"none",borderRadius:0,background:oe?"#999999":Se,cursor:"pointer",fontFamily:"ui-monospace, SFMono-Regular, Menlo, Consolas, monospace",fontSize:11,fontWeight:600,color:"#ffffff",transition:"background 150ms ease"},children:tt!==null?tt+1:pt.length+e.styleModifications.length+e.spacingTokenChanges.filter(pe=>!pe.captured).length})})})(),c&&re("span",{onMouseEnter:()=>Be("provider"),onMouseLeave:Ce,style:{display:"contents"},children:St("div",{style:{display:"flex",alignItems:"center",gap:0},children:[re(_n,{onClick:()=>c(a==="claude"?"codex":"claude"),children:a==="claude"?re(Ki,{}):re(qi,{})}),St("button",{type:"button",onClick:()=>{let F=(u+1)%p;k==null||k(F)},style:{display:"flex",alignItems:"center",gap:6,height:32,border:"none",background:"none",cursor:"pointer",padding:"0 4px 0 0",fontFamily:"ui-monospace, SFMono-Regular, Menlo, Consolas, monospace",fontSize:10,fontWeight:500,color:Fn.iconDefault,whiteSpace:"nowrap"},children:[re("span",{children:g}),re("span",{style:{display:"flex",flexDirection:"column",gap:2},children:Array.from({length:p},(F,ne)=>re("div",{style:{width:3,height:3,borderRadius:"50%",backgroundColor:ne===u?Fn.iconDefault:"rgba(0,0,0,0.2)",transition:"background-color 150ms ease"}},ne))})]})]})}),re("div",{onMouseEnter:F=>{s==null||s(!0),F.currentTarget.style.opacity="1",Be("collapse")},onMouseLeave:F=>{s==null||s(!1),F.currentTarget.style.opacity=o?"1":"0.3",Ce()},style:{display:"inline-flex",opacity:o?1:.3,transition:"opacity 150ms ease"},children:re(_n,{onClick:bt,title:"Collapse (\u2318\u2318)",children:o?re("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:Pn,children:Ee===1?St(fo,{children:[re("circle",{cx:"7",cy:"7",r:"2"}),re("circle",{cx:"17",cy:"7",r:"2"}),re("circle",{cx:"7",cy:"17",r:"2"}),re("circle",{cx:"17",cy:"17",r:"2"})]}):St(fo,{children:[re("circle",{cx:"12",cy:"6",r:"2"}),re("circle",{cx:"6",cy:"12",r:"2"}),re("circle",{cx:"18",cy:"12",r:"2"}),re("circle",{cx:"12",cy:"18",r:"2"})]})}):St("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:Pn,strokeWidth:"1.5",strokeLinecap:"round",style:{transform:"rotate(45deg)"},children:[re("line",{x1:"12",y1:"3",x2:"12",y2:"9"}),re("line",{x1:"12",y1:"15",x2:"12",y2:"21"}),re("line",{x1:"3",y1:"12",x2:"9",y2:"12"}),re("line",{x1:"15",y1:"12",x2:"21",y2:"12"})]})})})]})]})]}):St(fo,{children:[re("style",{children:"@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }"}),re("div",{ref:F=>{de&&(de.current=F)},id:"devtools-toolbar",style:y(f({},dn),{overflow:"visible",opacity:.5,transition:"opacity 150ms ease"}),onMouseEnter:F=>{F.currentTarget.style.opacity="1",be==null||be()},onMouseLeave:F=>F.currentTarget.style.opacity="0.5",children:re("button",{type:"button",style:{display:"flex",alignItems:"center",justifyContent:"center",width:48,height:48,border:"none",background:"none",cursor:"pointer",padding:0},onClick:()=>{Fe(!0),t({type:"SET_TOOL",payload:"inspector"}),t({type:"SET_ANNOTATING",payload:!0})},onMouseEnter:()=>s==null?void 0:s(!0),onMouseLeave:()=>s==null?void 0:s(!1),title:"Open annotation toolbar (\u2318\u2318)",children:o?re("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:Pn,children:Ee===1?St(fo,{children:[re("circle",{cx:"7",cy:"7",r:"2"}),re("circle",{cx:"17",cy:"7",r:"2"}),re("circle",{cx:"7",cy:"17",r:"2"}),re("circle",{cx:"17",cy:"17",r:"2"})]}):St(fo,{children:[re("circle",{cx:"12",cy:"6",r:"2"}),re("circle",{cx:"6",cy:"12",r:"2"}),re("circle",{cx:"18",cy:"12",r:"2"}),re("circle",{cx:"12",cy:"18",r:"2"})]})}):St("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:Pn,strokeWidth:"1.5",strokeLinecap:"round",children:[re("line",{x1:"12",y1:"3",x2:"12",y2:"9"}),re("line",{x1:"12",y1:"15",x2:"12",y2:"21"}),re("line",{x1:"3",y1:"12",x2:"9",y2:"12"}),re("line",{x1:"15",y1:"12",x2:"21",y2:"12"})]})})})]})}import{useEffect as Fo,useRef as Xp,useState as ls}from"react";import{Fragment as Da,jsx as It,jsxs as nr}from"react/jsx-runtime";var Kp={position:"fixed",bottom:86,right:16,zIndex:9999,display:"flex",flexDirection:"column"},qp=24,Zp=6,Qp=qp-Zp,ef=8,Oa=y(f({display:"flex",alignItems:"center",gap:6,padding:"4px 10px",backgroundColor:"rgba(255, 255, 255, 0.85)"},En),{backdropFilter:"blur(32px)",fontFamily:"ui-monospace, SFMono-Regular, Menlo, monospace",fontSize:11,color:"#1f2937",whiteSpace:"nowrap",transition:"transform 200ms ease, opacity 200ms ease"});function tf(e){var s;let t=e.filter(l=>l.type==="tool_use");if(t.length===0)return"Starting\u2026";let n=t[t.length-1],r=String(n.data.tool||""),o=n.data.file?String(n.data.file):null,i=o?(s=o.split("/").pop())!=null?s:o:null;switch(r){case"Read":return i?`Reading ${i}`:"Reading file";case"Edit":return i?`Editing ${i}`:"Editing file";case"Write":return i?`Writing ${i}`:"Writing file";case"Bash":return"Running command";case"Glob":return"Searching files";case"Grep":return"Searching code";default:return r?`Using ${r}`:"Working\u2026"}}function nf(e){let t=e.replace(/^Error:\s*/i,"");return t.length>40?t.slice(0,37)+"...":t}function of(e,t){if(e.some(o=>o.type==="question"&&o.data.jobId===t))return"Has a question";let r=e.find(o=>o.type==="done"&&o.data.jobId===t);if(r){let o=r.data.resolutions;if(Array.isArray(o)&&o.length>0)return"Applied changes"}return"Replied"}function rf({color:e}){let[t,n]=ls(0);return Fo(()=>{let r=setInterval(()=>{n(o=>(o+1)%2)},250);return()=>clearInterval(r)},[]),It("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:e,style:{verticalAlign:"middle",flexShrink:0},children:t===1?nr(Da,{children:[It("circle",{cx:"7",cy:"7",r:"2"}),It("circle",{cx:"17",cy:"7",r:"2"}),It("circle",{cx:"7",cy:"17",r:"2"}),It("circle",{cx:"17",cy:"17",r:"2"})]}):nr(Da,{children:[It("circle",{cx:"12",cy:"6",r:"2"}),It("circle",{cx:"6",cy:"12",r:"2"}),It("circle",{cx:"18",cy:"12",r:"2"}),It("circle",{cx:"12",cy:"18",r:"2"})]})})}function sf({color:e}){return It("span",{style:{display:"inline-block",width:8,height:8,backgroundColor:e,opacity:.6}})}function lf({color:e}){return It("span",{style:{color:e,fontSize:12,lineHeight:1,width:10,display:"inline-block"},children:"\u2713"})}function af(){return It("span",{style:{display:"inline-block",width:8,height:8,borderRadius:"50%",backgroundColor:"#ef4444"}})}function Na({bridge:e,inFlightJobs:t,isVisible:n,onHover:r,clearSignal:o,onViewThread:i,onCancel:s,onHoverJob:l,isConnected:a,dismissedThreadIds:c}){let[d,u]=ls([]),[p,g]=ls(!1);Fo(()=>{o>0&&u([])},[o]),Fo(()=>{!c||c.size===0||u(b=>{let E=b.filter(B=>!B.threadId||!c.has(B.threadId));return E.length===b.length?b:E})},[c]),Fo(()=>{u(b=>{var T;let E=new Set(b.map(v=>v.jobId)),B=!1,L=b.map(v=>{let O=t[v.jobId];return O&&(!v.threadId||v.color==="#888")?(B=!0,y(f({},v),{threadId:v.threadId||O.threadId,color:v.color==="#888"?O.color:v.color})):v});for(let[v,O]of Object.entries(t))E.has(v)||(L.push({jobId:v,color:O.color,status:"queued",threadId:O.threadId}),B=!0);for(let v of e.activeJobIds)if(!E.has(v)&&!L.some(O=>O.jobId===v)){let O=e.events.find(H=>H.type==="job_started"&&H.data.jobId===v);L.push({jobId:v,color:"#888",status:"working",threadId:(T=O==null?void 0:O.data)==null?void 0:T.threadId}),B=!0}return B?L:b})},[t,e.activeJobIds]),Fo(()=>{if(e.activeJobIds.length===0)return;let b=new Set(e.activeJobIds);u(E=>E.map(B=>b.has(B.jobId)&&B.status!=="done"&&B.status!=="error"?y(f({},B),{status:"working"}):B))},[e.activeJobIds]);let k=Xp(null);if(Fo(()=>{let b=e.lastCompletedJobId;if(!b||b===k.current)return;k.current=b;let E=e.events.find(H=>H.type==="error"&&(H.data.jobId===b||e.status==="error")),B=!!E,L=B?void 0:of(e.events,b),T=E?String(E.data.message||""):void 0,v=E?!!E.data.cancelled:void 0,O=E==null?void 0:E.data.threadId;u(H=>H.map(U=>U.jobId===b?y(f({},U),{status:B?"error":"done",doneLabel:L,errorMessage:T,cancelled:v,threadId:U.threadId||O}):U))},[e.lastCompletedJobId,e.events,e.status]),!n||d.length===0&&a!==!1)return null;let w=!p&&d.length>1;return nr("div",{style:Kp,"data-devtools":!0,onMouseEnter:()=>{g(!0),r(!0)},onMouseLeave:()=>{g(!1),r(!1),l==null||l(null)},children:[[...d].reverse().map((b,E)=>{let B=E===d.length-1,L=d.length-1-E,T=b.status==="working"?tf(e.events.filter(v=>v.data.jobId===b.jobId)):b.status==="queued"?"Queued":b.status==="done"?b.doneLabel||"Done":b.cancelled?"Cancelled":b.errorMessage?nf(b.errorMessage):"Error";return It("div",{style:{position:"relative",zIndex:E,marginBottom:w?B?0:-Qp:B?0:ef,transform:w?`scale(${Math.max(.94,1-L*.02)})`:"scale(1)",opacity:w?Math.max(.5,1-L*.15):1,transformOrigin:"bottom right",transition:"margin-bottom 250ms ease, transform 250ms ease, opacity 250ms ease"},children:nr("div",{style:y(f({},Oa),{cursor:b.threadId&&i?"pointer":void 0}),onClick:b.threadId&&i?()=>i(b.threadId):void 0,onMouseEnter:l?()=>l(b.jobId):void 0,onMouseLeave:l?()=>l(null):void 0,title:b.errorMessage||void 0,children:[b.status==="working"&&It(rf,{color:b.color}),b.status==="queued"&&It(sf,{color:b.color}),b.status==="done"&&It(lf,{color:b.color}),b.status==="error"&&It(af,{}),It("span",{style:{color:b.status==="queued"?"#9ca3af":"#1f2937"},children:T}),b.status==="working"&&s&&It("button",{onClick:v=>{v.stopPropagation(),s(b.jobId)},style:{background:"none",border:"none",cursor:"pointer",color:"#9ca3af",fontSize:14,padding:"0 4px",lineHeight:1},title:"Cancel",children:"\xD7"}),(b.status==="done"||b.status==="error")&&It("button",{onClick:v=>{v.stopPropagation(),u(O=>O.filter(H=>H.jobId!==b.jobId))},style:{background:"none",border:"none",cursor:"pointer",color:"#9ca3af",fontSize:14,padding:"0 4px",lineHeight:1},title:"Dismiss",children:"\xD7"})]})},b.jobId)}),a===!1&&d.length>0&&nr("div",{style:y(f({},Oa),{color:"#9ca3af"}),children:[It("span",{style:{display:"inline-block",width:8,height:8,borderRadius:"50%",backgroundColor:"#f59e0b"}}),It("span",{children:"Reconnecting\u2026"})]})]})}import{Fragment as uf,jsx as df,jsxs as pf}from"react/jsx-runtime";var cf=`
17
19
  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
18
20
  :host {
19
21
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
@@ -22,9 +24,16 @@ Your AI gets the visual and technical context it needs to act.`,usage:[],keys:[{
22
24
  line-height: 1.5;
23
25
  -webkit-font-smoothing: antialiased;
24
26
  }
25
- `;function ta({children:e}){return ip(rp,{children:[op("style",{children:np}),e]})}import{useLayoutEffect as sp,useRef as lp,useState as ap}from"react";import{createPortal as cp}from"react-dom";import{Fragment as up,jsx as dp,jsxs as pp}from"react/jsx-runtime";function na({children:e}){let t=lp(null),[o,r]=ap(null);return sp(()=>{let n=t.current;if(!n||n.shadowRoot)return;let i=n.attachShadow({mode:"open"}),s=document.createElement("div");s.setAttribute("data-popmelt-root",""),i.appendChild(s),r(s)},[]),pp(up,{children:[dp("div",{ref:t,"data-popmelt-shadow-host":!0,style:{position:"absolute",width:0,height:0,overflow:"visible"}}),o&&cp(e,o)]})}import{useCallback as Cr,useEffect as _n,useRef as On,useState as no}from"react";import{Fragment as yp,jsx as Et}from"react/jsx-runtime";var oa="ui-monospace, SFMono-Regular, Menlo, monospace",fp=/^#[0-9a-fA-F]{3,8}$/,gp=/^(?:rgba?|hsla?|oklch)\([^)]+\)$/,mp=new Set(["black","white","red","blue","green","yellow","orange","purple","pink","gray","grey","cyan","magenta","brown","navy","teal","maroon","olive","silver","aqua","fuchsia","lime"]);function hp(e){let t=e.trim();return fp.test(t)||gp.test(t)||mp.has(t.toLowerCase())}function Wi(e,t){return Et("span",{style:{display:"inline-block",width:10,height:10,backgroundColor:e,border:"1px solid rgba(0,0,0,0.15)",borderRadius:2,verticalAlign:"middle",marginRight:3}},t)}function Vo(e){let t=[],o=/(`[^`]+`)|(\*\*\*(.+?)\*\*\*)|(\*\*(.+?)\*\*)|(\*(.+?)\*)|(_([^_]+?)_)|(\[([^\]]+)\]\(([^)]+)\))|(#[0-9a-fA-F]{3,8})(?![0-9a-fA-F])|((?:rgba?|hsla?|oklch)\([^)]+\))/g,r=0,n;for(;(n=o.exec(e))!==null;){if(n.index>r&&t.push(e.slice(r,n.index)),n[1]){let i=n[1].slice(1,-1);hp(i)&&t.push(Wi(i,`sw-${n.index}`)),t.push(Et("code",{style:{fontFamily:oa,fontSize:"0.9em",backgroundColor:"rgba(0,0,0,0.06)",padding:"1px 4px",borderRadius:2},children:i},n.index))}else n[3]!==void 0?t.push(Et("strong",{children:Et("em",{children:n[3]})},n.index)):n[5]!==void 0?t.push(Et("strong",{children:n[5]},n.index)):n[7]!==void 0?t.push(Et("em",{children:n[7]},n.index)):n[9]!==void 0?t.push(Et("em",{children:n[9]},n.index)):n[11]!==void 0&&n[12]!==void 0?t.push(Et("a",{href:n[12],target:"_blank",rel:"noopener noreferrer",style:{color:"inherit",textDecoration:"underline"},children:n[11]},n.index)):n[13]!==void 0?(t.push(Wi(n[13],`sw-${n.index}`)),t.push(n[13])):n[14]!==void 0&&(t.push(Wi(n[14],`sw-${n.index}`)),t.push(n[14]));r=n.index+n[0].length}return r<e.length&&t.push(e.slice(r)),t}function kr(e){var n;let t=e.split(`
26
- `),o=[],r=0;for(;r<t.length;){let i=t[r];if(i.trimStart().startsWith("```")){let c=[];for(r++;r<t.length&&!t[r].trimStart().startsWith("```");)c.push(t[r]),r++;r++,o.push(Et("pre",{style:{fontFamily:oa,fontSize:"0.9em",lineHeight:1.4,backgroundColor:"rgba(0,0,0,0.04)",padding:"6px 8px",margin:"4px 0",overflowX:"auto",whiteSpace:"pre"},children:c.join(`
27
- `)},o.length));continue}if(/^(-{3,}|\*{3,}|_{3,})\s*$/.test(i)){o.push(Et("hr",{style:{border:"none",borderTop:"1px solid rgba(0,0,0,0.1)",margin:"6px 0"}},o.length)),r++;continue}let s=i.match(/^(#{1,4})\s+(.+)/);if(s){let c=s[1].length,d={1:16,2:14,3:13,4:12};o.push(Et("div",{style:{fontWeight:700,fontSize:(n=d[c])!=null?n:12,margin:"8px 0 2px"},children:Vo(s[2])},o.length)),r++;continue}if(i.trimStart().startsWith("|")&&i.trimEnd().endsWith("|")){let c=[];for(;r<t.length&&t[r].trimStart().startsWith("|")&&t[r].trimEnd().endsWith("|");)c.push(t[r]),r++;let d=w=>/^\|[\s\-:|]+\|$/.test(w),u=c.filter(w=>!d(w)),p=w=>w.split("|").slice(1,-1).map(O=>O.trim()),g=w=>/^\*\*.+\*\*$/.test(w)||/^__.+__$/.test(w),S=u.map(p),v=S.length>1&&S.slice(1).every(w=>w[0]&&g(w[0])),b=S.length>0&&S[0].every(w=>g(w));o.push(Et("div",{style:{overflowX:"auto",margin:"4px 0",paddingBottom:4},children:Et("table",{style:{borderCollapse:"separate",borderSpacing:0,fontSize:"0.95em",width:"max-content",minWidth:"100%"},children:Et("tbody",{children:u.map((w,O)=>Et("tr",{children:p(w).map((A,k)=>Et(O===0?"th":"td",{style:f({border:"1px solid rgba(0,0,0,0.1)",padding:"3px 6px",textAlign:"left",fontWeight:O===0?600:400,minWidth:60,whiteSpace:"nowrap"},k===0&&v||O===0&&b?h(f(f({position:"sticky"},k===0&&v?{left:0}:{}),O===0&&b?{top:0}:{}),{background:"#fff",zIndex:k===0&&v&&O===0&&b?2:1}):{}),children:Vo(A)},k))},O))})})},o.length));continue}if(i.match(/^(\s*)([-*])\s+(.+)/)){let c=[];for(;r<t.length&&/^\s*[-*]\s+/.test(t[r]);){let d=t[r].match(/^\s*[-*]\s+(.+)/);d&&c.push(Et("li",{children:Vo(d[1])},c.length)),r++}o.push(Et("ul",{style:{margin:"2px 0",paddingLeft:20},children:c},o.length));continue}if(i.match(/^(\s*)\d+\.\s+(.+)/)){let c=[];for(;r<t.length&&/^\s*\d+\.\s+/.test(t[r]);){let d=t[r].match(/^\s*\d+\.\s+(.+)/);d&&c.push(Et("li",{children:Vo(d[1])},c.length)),r++}o.push(Et("ol",{style:{margin:"2px 0",paddingLeft:20},children:c},o.length));continue}if(i.trim()===""){o.push(Et("div",{style:{height:4}},o.length)),r++;continue}o.push(Et("div",{style:{margin:"2px 0"},children:Vo(i)},o.length)),r++}return Et(yp,{children:o})}import{Fragment as Vi,jsx as ze,jsxs as _t}from"react/jsx-runtime";var Mr=400,Ro=16,Ui=3,bp=16,Yi="devtools-thread-panel-position";function ji(){return{top:Ro,left:window.innerWidth-Mr-2*Ui-Ro}}function ra(e,t,o){let r=o==null?void 0:o.getBoundingClientRect(),n=window.innerHeight-Ro;return r&&t+Mr+2*Ui>r.left&&(n=r.top-bp),Math.max(200,n-Math.max(0,e))}var xp=h(f({width:Mr,backgroundColor:"#ffffff"},bn),{boxSizing:"content-box",display:"flex",flexDirection:"column",overflow:"hidden",fontFamily:Wt,fontSize:12,color:"#1f2937",pointerEvents:"auto"}),vp={display:"flex",alignItems:"center",justifyContent:"space-between",padding:"4px 5px 4px 10px",margin:"3px 3px 0",fontWeight:600,fontSize:12},Sp={flex:1,overflowY:"auto",padding:"8px 0",scrollbarWidth:"none"},wp=`
27
+ /* Break :host font inheritance for component previews \u2014 let mirrored host
28
+ page styles (Tailwind, globals) apply instead of Popmelt's monospace. */
29
+ [data-popmelt-panel] {
30
+ font: 16px / 1.5 system-ui, -apple-system, sans-serif;
31
+ color: initial;
32
+ -webkit-font-smoothing: auto;
33
+ }
34
+ `;function Ha({children:e}){return pf(uf,{children:[df("style",{children:cf}),e]})}import{useEffect as ff,useLayoutEffect as gf,useRef as mf,useState as Fa}from"react";import{createPortal as hf}from"react-dom";import{Fragment as Sf,jsx as xf,jsxs as vf}from"react/jsx-runtime";function yf(e){return e.tagName==="STYLE"||e.tagName==="LINK"&&e.rel==="stylesheet"}function bf(e){let t=new Map,n=e.firstChild;function r(s){if(t.has(s)||s.hasAttribute("data-pm-mirror"))return;let l=s.cloneNode(!0);l.setAttribute("data-pm-mirror",""),e.insertBefore(l,n),t.set(s,l)}function o(s){let l=t.get(s);l&&(l.remove(),t.delete(s))}for(let s of document.querySelectorAll('link[rel="stylesheet"], style'))s.getRootNode()===document&&r(s);try{document.adoptedStyleSheets.length>0&&(e.adoptedStyleSheets=[...document.adoptedStyleSheets,...e.adoptedStyleSheets])}catch(s){}let i=new MutationObserver(s=>{for(let l of s)if(l.type==="childList"){for(let a of l.addedNodes)a instanceof Element&&yf(a)&&r(a);for(let a of l.removedNodes)a instanceof Element&&o(a)}});return i.observe(document.head,{childList:!0}),document.body&&i.observe(document.body,{childList:!0}),()=>{i.disconnect();for(let s of t.values())s.remove();t.clear()}}function _a({children:e}){let t=mf(null),[n,r]=Fa(null),[o,i]=Fa(null);return gf(()=>{let s=t.current;if(!s||s.shadowRoot)return;let l=s.attachShadow({mode:"open"}),a=document.createElement("div");a.setAttribute("data-popmelt-root",""),l.appendChild(a),r(l),i(a)},[]),ff(()=>{if(n)return bf(n)},[n]),vf(Sf,{children:[xf("div",{ref:t,"data-popmelt-shadow-host":!0,style:{position:"absolute",width:0,height:0,overflow:"visible"}}),o&&hf(e,o)]})}import{useCallback as $r,useEffect as Un,useRef as zn,useState as mo}from"react";import{Fragment as Mf,jsx as Et}from"react/jsx-runtime";var za="ui-monospace, SFMono-Regular, Menlo, monospace",wf=/^#[0-9a-fA-F]{3,8}$/,Ef=/^(?:rgba?|hsla?|oklch)\([^)]+\)$/,Cf=new Set(["black","white","red","blue","green","yellow","orange","purple","pink","gray","grey","cyan","magenta","brown","navy","teal","maroon","olive","silver","aqua","fuchsia","lime"]);function kf(e){let t=e.trim();return wf.test(t)||Ef.test(t)||Cf.has(t.toLowerCase())}function as(e,t){return Et("span",{style:{display:"inline-block",width:10,height:10,backgroundColor:e,border:"1px solid rgba(0,0,0,0.15)",borderRadius:2,verticalAlign:"middle",marginRight:3}},t)}function or(e){let t=[],n=/(`[^`]+`)|(\*\*\*(.+?)\*\*\*)|(\*\*(.+?)\*\*)|(\*(.+?)\*)|(_([^_]+?)_)|(\[([^\]]+)\]\(([^)]+)\))|(#[0-9a-fA-F]{3,8})(?![0-9a-fA-F])|((?:rgba?|hsla?|oklch)\([^)]+\))/g,r=0,o;for(;(o=n.exec(e))!==null;){if(o.index>r&&t.push(e.slice(r,o.index)),o[1]){let i=o[1].slice(1,-1);kf(i)&&t.push(as(i,`sw-${o.index}`)),t.push(Et("code",{style:{fontFamily:za,fontSize:"0.9em",backgroundColor:"rgba(0,0,0,0.06)",padding:"1px 4px",borderRadius:2},children:i},o.index))}else o[3]!==void 0?t.push(Et("strong",{children:Et("em",{children:o[3]})},o.index)):o[5]!==void 0?t.push(Et("strong",{children:o[5]},o.index)):o[7]!==void 0?t.push(Et("em",{children:o[7]},o.index)):o[9]!==void 0?t.push(Et("em",{children:o[9]},o.index)):o[11]!==void 0&&o[12]!==void 0?t.push(Et("a",{href:o[12],target:"_blank",rel:"noopener noreferrer",style:{color:"inherit",textDecoration:"underline"},children:o[11]},o.index)):o[13]!==void 0?(t.push(as(o[13],`sw-${o.index}`)),t.push(o[13])):o[14]!==void 0&&(t.push(as(o[14],`sw-${o.index}`)),t.push(o[14]));r=o.index+o[0].length}return r<e.length&&t.push(e.slice(r)),t}function zr(e){var o;let t=e.split(`
35
+ `),n=[],r=0;for(;r<t.length;){let i=t[r];if(i.trimStart().startsWith("```")){let c=[];for(r++;r<t.length&&!t[r].trimStart().startsWith("```");)c.push(t[r]),r++;r++,n.push(Et("pre",{style:{fontFamily:za,fontSize:"0.9em",lineHeight:1.4,backgroundColor:"rgba(0,0,0,0.04)",padding:"6px 8px",margin:"4px 0",overflowX:"auto",whiteSpace:"pre"},children:c.join(`
36
+ `)},n.length));continue}if(/^(-{3,}|\*{3,}|_{3,})\s*$/.test(i)){n.push(Et("hr",{style:{border:"none",borderTop:"1px solid rgba(0,0,0,0.1)",margin:"6px 0"}},n.length)),r++;continue}let s=i.match(/^(#{1,4})\s+(.+)/);if(s){let c=s[1].length,d={1:16,2:14,3:13,4:12};n.push(Et("div",{style:{fontWeight:700,fontSize:(o=d[c])!=null?o:12,margin:"8px 0 2px"},children:or(s[2])},n.length)),r++;continue}if(i.trimStart().startsWith("|")&&i.trimEnd().endsWith("|")){let c=[];for(;r<t.length&&t[r].trimStart().startsWith("|")&&t[r].trimEnd().endsWith("|");)c.push(t[r]),r++;let d=E=>/^\|[\s\-:|]+\|$/.test(E),u=c.filter(E=>!d(E)),p=E=>E.split("|").slice(1,-1).map(B=>B.trim()),g=E=>/^\*\*.+\*\*$/.test(E)||/^__.+__$/.test(E),k=u.map(p),w=k.length>1&&k.slice(1).every(E=>E[0]&&g(E[0])),b=k.length>0&&k[0].every(E=>g(E));n.push(Et("div",{style:{overflowX:"auto",margin:"4px 0",paddingBottom:4},children:Et("table",{style:{borderCollapse:"separate",borderSpacing:0,fontSize:"0.95em",width:"max-content",minWidth:"100%"},children:Et("tbody",{children:u.map((E,B)=>Et("tr",{children:p(E).map((L,T)=>Et(B===0?"th":"td",{style:f({border:"1px solid rgba(0,0,0,0.1)",padding:"3px 6px",textAlign:"left",fontWeight:B===0?600:400,minWidth:60,whiteSpace:"nowrap"},T===0&&w||B===0&&b?y(f(f({position:"sticky"},T===0&&w?{left:0}:{}),B===0&&b?{top:0}:{}),{background:"#fff",zIndex:T===0&&w&&B===0&&b?2:1}):{}),children:or(L)},T))},B))})})},n.length));continue}if(i.match(/^(\s*)([-*])\s+(.+)/)){let c=[];for(;r<t.length&&/^\s*[-*]\s+/.test(t[r]);){let d=t[r].match(/^\s*[-*]\s+(.+)/);d&&c.push(Et("li",{children:or(d[1])},c.length)),r++}n.push(Et("ul",{style:{margin:"2px 0",paddingLeft:20},children:c},n.length));continue}if(i.match(/^(\s*)\d+\.\s+(.+)/)){let c=[];for(;r<t.length&&/^\s*\d+\.\s+/.test(t[r]);){let d=t[r].match(/^\s*\d+\.\s+(.+)/);d&&c.push(Et("li",{children:or(d[1])},c.length)),r++}n.push(Et("ol",{style:{margin:"2px 0",paddingLeft:20},children:c},n.length));continue}if(i.trim()===""){n.push(Et("div",{style:{height:4}},n.length)),r++;continue}n.push(Et("div",{style:{margin:"2px 0"},children:or(i)},n.length)),r++}return Et(Mf,{children:n})}import{Fragment as ps,jsx as Ye,jsxs as Ot}from"react/jsx-runtime";var Wr=400,_o=16,fs=3,Tf=16,cs="devtools-thread-panel-position";function ds(){return{top:_o,left:window.innerWidth-Wr-2*fs-_o}}function $a(e,t,n){let r=n==null?void 0:n.getBoundingClientRect(),o=window.innerHeight-_o;return r&&t+Wr+2*fs>r.left&&(o=r.top-Tf),Math.max(200,o-Math.max(0,e))}var If=y(f({width:Wr,backgroundColor:"#eaeaea"},En),{boxSizing:"content-box",display:"flex",flexDirection:"column",overflow:"hidden",fontFamily:zt,fontSize:12,color:"#1f2937",pointerEvents:"auto"}),Rf={display:"flex",alignItems:"center",justifyContent:"space-between",padding:"4px 5px 4px 10px",margin:"3px 3px 0",fontWeight:600,fontSize:12,overflow:"hidden"},Lf={flex:1,overflowY:"auto",padding:"8px 0",scrollbarWidth:"none"},Af=`
28
37
  [data-devtools="thread-panel-messages"]:hover {
29
38
  scrollbar-width: thin !important;
30
39
  }
@@ -38,4 +47,4 @@ Your AI gets the visual and technical context it needs to act.`,usage:[],keys:[{
38
47
  background: rgba(0,0,0,0.15);
39
48
  border-radius: 3px;
40
49
  }
41
- `,Ep={borderTop:"1px solid rgba(0, 0, 0, 0.08)",padding:12};function ia(e){return e.replace(/<resolution>[\s\S]*?<\/resolution>/g,"").replace(/<question>[\s\S]*?<\/question>/g,"").replace(/<plan>[\s\S]*?<\/plan>/g,"").replace(/<review>[\s\S]*?<\/review>/g,"").trim()}function sa(e){return new Date(e).toLocaleTimeString([],{hour:"2-digit",minute:"2-digit"})}var Gi=["reviewing","considering","thinking","zhuzhing","iterating","tweaking","reflecting","noodling","pondering","finessing","polishing","riffing"],kp=3e3,Cp=250;function la({size:e=14}){return ze("svg",{width:e,height:e,viewBox:"0 0 1200 1200",fill:"#6b7280",stroke:"none",style:{flexShrink:0},children:ze("path",{d:"M 233.959793 800.214905 L 468.644287 668.536987 L 472.590637 657.100647 L 468.644287 650.738403 L 457.208069 650.738403 L 417.986633 648.322144 L 283.892639 644.69812 L 167.597321 639.865845 L 54.926208 633.825623 L 26.577238 627.785339 L 3.3e-05 592.751709 L 2.73832 575.27533 L 26.577238 559.248352 L 60.724873 562.228149 L 136.187973 567.382629 L 249.422867 575.194763 L 331.570496 580.026978 L 453.261841 592.671082 L 472.590637 592.671082 L 475.328857 584.859009 L 468.724915 580.026978 L 463.570557 575.194763 L 346.389313 495.785217 L 219.543671 411.865906 L 153.100723 363.543762 L 117.181267 339.060425 L 99.060455 316.107361 L 91.248367 266.01355 L 123.865784 230.093994 L 167.677887 233.073853 L 178.872513 236.053772 L 223.248367 270.201477 L 318.040283 343.570496 L 441.825592 434.738342 L 459.946411 449.798706 L 467.194672 444.64447 L 468.080597 441.020203 L 459.946411 427.409485 L 392.617493 305.718323 L 320.778564 181.932983 L 288.80542 130.630859 L 280.348999 99.865845 C 277.369171 87.221436 275.194641 76.590698 275.194641 63.624268 L 312.322174 13.20813 L 332.8591 6.604126 L 382.389313 13.20813 L 403.248352 31.328979 L 434.013519 101.71814 L 483.865753 212.537048 L 561.181274 363.221497 L 583.812134 407.919434 L 595.892639 449.315491 L 600.40271 461.959839 L 608.214783 461.959839 L 608.214783 454.711609 L 614.577271 369.825623 L 626.335632 265.61084 L 637.771851 131.516846 L 641.718201 93.745117 L 660.402832 48.483276 L 697.530334 24.000122 L 726.52356 37.852417 L 750.362549 72 L 747.060486 94.067139 L 732.886047 186.201416 L 705.100708 330.52356 L 686.979919 427.167847 L 697.530334 427.167847 L 709.61084 415.087341 L 758.496704 350.174561 L 840.644348 247.490051 L 876.885925 206.738342 L 919.167847 161.71814 L 946.308838 140.29541 L 997.61084 140.29541 L 1035.38269 196.429626 L 1018.469849 254.416199 L 965.637634 321.422852 L 921.825562 378.201538 L 859.006714 462.765259 L 819.785278 530.41626 L 823.409424 535.812073 L 832.75177 534.92627 L 974.657776 504.724915 L 1051.328979 490.872559 L 1142.818848 475.167786 L 1184.214844 494.496582 L 1188.724854 514.147644 L 1172.456421 554.335693 L 1074.604126 578.496765 L 959.838989 601.449829 L 788.939636 641.879272 L 786.845764 643.409485 L 789.261841 646.389343 L 866.255127 653.637634 L 899.194702 655.409424 L 979.812134 655.409424 L 1129.932861 666.604187 L 1169.154419 692.537109 L 1192.671265 724.268677 L 1188.724854 748.429688 L 1128.322144 779.194641 L 1046.818848 759.865845 L 856.590759 714.604126 L 791.355774 698.335754 L 782.335693 698.335754 L 782.335693 703.731567 L 836.69812 756.885986 L 936.322205 846.845581 L 1061.073975 962.81897 L 1067.436279 991.490112 L 1051.409424 1014.120911 L 1034.496704 1011.704712 L 924.885986 929.234924 L 882.604126 892.107544 L 786.845764 811.48999 L 780.483276 811.48999 L 780.483276 819.946289 L 802.550415 852.241699 L 919.087341 1027.409424 L 925.127625 1081.127686 L 916.671204 1098.604126 L 886.469849 1109.154419 L 853.288696 1103.114136 L 785.073914 1007.355835 L 714.684631 899.516785 L 657.906067 802.872498 L 650.979858 806.81897 L 617.476624 1167.704834 L 601.771851 1186.147705 L 565.530212 1200 L 535.328857 1177.046997 L 519.302124 1139.919556 L 535.328857 1066.550537 L 554.657776 970.792053 L 570.362488 894.68457 L 584.536926 800.134277 L 592.993347 768.724976 L 592.429626 766.630859 L 585.503479 767.516968 L 514.22821 865.369263 L 405.825531 1011.865906 L 320.053711 1103.677979 L 299.516815 1111.812256 L 263.919525 1093.369263 L 267.221497 1060.429688 L 287.114136 1031.114136 L 405.825531 880.107361 L 477.422913 786.52356 L 523.651062 732.483276 L 523.328918 724.671265 L 520.590698 724.671265 L 205.288605 929.395935 L 149.154434 936.644409 L 124.993355 914.01355 L 127.973183 876.885986 L 139.409409 864.80542 L 234.201385 799.570435 L 233.879227 799.8927 Z"})})}function Mp({color:e}){let[t,o]=no(0),[r,n]=no(()=>Math.floor(Math.random()*Gi.length));return _n(()=>{let i=setInterval(()=>o(l=>(l+1)%2),Cp),s=setInterval(()=>n(l=>(l+1)%Gi.length),kp);return()=>{clearInterval(i),clearInterval(s)}},[]),_t("span",{style:{display:"inline-flex",alignItems:"center",gap:4},children:[ze("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:e,style:{verticalAlign:"middle",flexShrink:0},children:t===1?_t(Vi,{children:[ze("circle",{cx:"7",cy:"7",r:"2"}),ze("circle",{cx:"17",cy:"7",r:"2"}),ze("circle",{cx:"7",cy:"17",r:"2"}),ze("circle",{cx:"17",cy:"17",r:"2"})]}):_t(Vi,{children:[ze("circle",{cx:"12",cy:"6",r:"2"}),ze("circle",{cx:"6",cy:"12",r:"2"}),ze("circle",{cx:"18",cy:"12",r:"2"}),ze("circle",{cx:"12",cy:"18",r:"2"})]})}),ze("span",{style:{fontSize:11,color:"#9ca3af",fontStyle:"italic"},children:Gi[r]})]})}function Tp(e){var n;let t=String(e.data.tool||""),o=e.data.file?String(e.data.file):null,r=o?(n=o.split("/").pop())!=null?n:o:null;switch(t){case"Read":return r?`Reading ${r}`:"Reading file";case"Edit":return r?`Editing ${r}`:"Editing file";case"Write":return r?`Writing ${r}`:"Writing file";case"Bash":return"Running command";case"Glob":return"Searching files";case"Grep":return"Searching code";case"WebFetch":return"Fetching page";case"WebSearch":return"Searching web";default:return t?`Using ${t}`:null}}var Lp=new Set(["Read","Glob","Grep","WebFetch","WebSearch"]),Ip=new Set(["Edit","Write","Bash"]);function Rp(e){let t=0,o=!1;for(let r of e){if(r.type!=="tool_use")continue;let n=String(r.data.tool||"");Ip.has(n)?o=!0:Lp.has(n)&&t++}return!o&&t>=3?"researching":o?"applying changes":null}function Ap(e){let t=[];for(let o of e)if(o.type==="tool_use"){let r=Tp(o);r&&t.push({kind:"tool",label:r})}else if(o.type==="delta"){let r=String(o.data.text||"");if(!r)continue;let n=t[t.length-1];n&&n.kind==="text"?n.text+=r:t.push({kind:"text",text:r})}else if(o.type==="thinking"){let r=String(o.data.text||"");if(!r)continue;let n=t[t.length-1];n&&n.kind==="thinking"?n.text+=r:t.push({kind:"thinking",text:r})}return t}function aa({threadId:e,bridgeUrl:t,accentColor:o,isStreaming:r,streamingEvents:n,onClose:i,onReply:s,onCancel:l,lastError:a,onMouseEnter:c,toolbarRef:d}){let[u,p]=no([]),[g,S]=no(!0),[v,b]=no(""),[w,O]=no([]),A=On(null),k=On(null),E=On(null),I=On(r),$=On(ji()),q=On({x:0,y:0}),j=On(!1),T=On({x:0,y:0,offsetX:0,offsetY:0}),D=On(!1),[,K]=no(0);_n(()=>{try{let G=localStorage.getItem(Yi);if(G){let oe=JSON.parse(G);typeof oe.top=="number"&&typeof oe.left=="number"&&(D.current=!0,$.current={top:oe.top,left:oe.left},K(Ee=>Ee+1))}}catch(G){}},[]),_n(()=>{let G=()=>{D.current||($.current=ji()),K(oe=>oe+1)};return window.addEventListener("resize",G,{passive:!0}),()=>window.removeEventListener("resize",G)},[]),_n(()=>{let G=E.current;if(!G)return;let oe=Te=>{Te.button!==0||Te.target.closest("button")||(Te.preventDefault(),Te.stopPropagation(),j.current=!0,T.current={x:Te.clientX,y:Te.clientY,offsetX:q.current.x,offsetY:q.current.y})},Ee=Te=>{if(!j.current)return;let xe=T.current,ge=xe.offsetX+(Te.clientX-xe.x),Ge=xe.offsetY+(Te.clientY-xe.y),xt=Math.max(Ro,Math.min(window.innerWidth-Mr-2*Ui-Ro,$.current.left+ge)),dt=Math.max(Ro,$.current.top+Ge);q.current={x:xt-$.current.left,y:dt-$.current.top};let Ve=k.current;Ve&&(Ve.style.top=`${dt}px`,Ve.style.left=`${xt}px`,Ve.style.height=`${ra(dt,xt,d==null?void 0:d.current)}px`)},ce=()=>{if(!j.current)return;let Te=$.current.top+q.current.y,xe=$.current.left+q.current.x;$.current={top:Te,left:xe},q.current={x:0,y:0},D.current=!0;try{localStorage.setItem(Yi,JSON.stringify({top:Te,left:xe}))}catch(ge){}j.current=!1},Ke=()=>{$.current=ji(),q.current={x:0,y:0},D.current=!1;try{localStorage.removeItem(Yi)}catch(Te){}K(Te=>Te+1)};return G.addEventListener("mousedown",oe),window.addEventListener("mousemove",Ee),window.addEventListener("mouseup",ce),G.addEventListener("dblclick",Ke),()=>{G.removeEventListener("mousedown",oe),window.removeEventListener("mousemove",Ee),window.removeEventListener("mouseup",ce),G.removeEventListener("dblclick",Ke)}},[]);let ee=Cr(()=>{fetch(`${t}/thread/${e}`).then(G=>G.json()).then(G=>{var oe;p((oe=G.messages)!=null?oe:[]),S(!1)}).catch(()=>S(!1))},[t,e]);_n(()=>{S(!0),ee()},[ee]),_n(()=>{I.current&&!r&&ee(),I.current=r},[r,ee]);let me=n?Ap(n):[],ve=n?Rp(n):null;_n(()=>{A.current&&(A.current.scrollTop=A.current.scrollHeight)},[u,me.length,r]),_n(()=>{let G=oe=>{oe.key==="Escape"&&(oe.stopPropagation(),i())};return document.addEventListener("keydown",G),()=>document.removeEventListener("keydown",G)},[i]);let ae=Cr(()=>{if(!v.trim()||!s)return;let G=v.trim(),oe=w.length>0?w:void 0;p(Ee=>[...Ee,{role:"human",timestamp:Date.now(),jobId:"pending",replyToQuestion:oe?`${G} [${oe.length} image${oe.length>1?"s":""}]`:G}]),s(e,G,oe),b(""),O([])},[v,w,e,s]),Re=Cr(G=>{let oe=G.clipboardData.items,Ee=[];for(let ce=0;ce<oe.length;ce++){let Ke=oe[ce];if(Ke.type.startsWith("image/")){let Te=Ke.getAsFile();Te&&Ee.push(Te)}}Ee.length>0&&(G.preventDefault(),O(ce=>[...ce,...Ee]))},[]),We=Cr(G=>{G.key==="Enter"&&(G.metaKey||G.ctrlKey)&&(G.preventDefault(),ae())},[ae]),Me=$.current.top+q.current.y,ne=$.current.left+q.current.x,Ae=ra(Me,ne,d==null?void 0:d.current);return _t(Vi,{children:[ze("div",{"data-devtools":"thread-panel-backdrop",onMouseDown:G=>{G.target===G.currentTarget&&i()},style:{position:"fixed",inset:0,zIndex:9999}}),_t("div",{ref:k,style:h(f({},xp),{height:Ae,position:"fixed",top:Me,left:ne,zIndex:1e4}),"data-devtools":"thread-panel",onMouseEnter:c,children:[_t("div",{ref:E,style:h(f({},vp),{backgroundColor:o,color:"#ffffff",cursor:"grab",userSelect:"none",WebkitUserSelect:"none"}),children:[ze("span",{children:"Conversation"}),ze("button",{onClick:i,style:{background:"none",border:"none",cursor:"pointer",fontSize:16,color:"#ffffff",padding:"0 4px",lineHeight:1},children:"\xD7"})]}),ze("style",{dangerouslySetInnerHTML:{__html:wp}}),_t("div",{ref:A,style:Sp,"data-devtools":"thread-panel-messages",children:[g&&ze("div",{style:{padding:16,color:"#9ca3af",textAlign:"center"},children:"Loading..."}),!g&&u.length===0&&!r&&ze("div",{style:{padding:16,color:"#9ca3af",textAlign:"center"},children:"No messages yet."}),u.map((G,oe)=>{let Ee=G.role==="human";if(G.cancelled)return ze("div",{style:{padding:"8px 16px",borderBottom:"1px solid rgba(0, 0, 0, 0.04)",opacity:oe===u.length-1?1:.5},children:_t("div",{style:{display:"flex",alignItems:"center",gap:4},children:[ze("span",{style:{fontSize:11,color:"#9ca3af",fontStyle:"italic"},children:"Cancelled"}),ze("span",{style:{fontSize:10,color:"#9ca3af",marginLeft:"auto"},children:sa(G.timestamp)})]})},`${G.jobId}-${oe}`);let ce=Ee?G.replyToQuestion||G.feedbackSummary||"(annotation)":ia(G.responseText||""),Ke=Ee?void 0:G.question,Te=!Ee&&G.resolutions&&G.resolutions.length>0,xe=!Ee&&G.toolsUsed&&G.toolsUsed.length>0;if(!ce&&!Ke&&!Te)return null;let ge=oe===u.length-1;return _t("div",{style:{padding:"8px 16px",borderBottom:"1px solid rgba(0, 0, 0, 0.04)",opacity:ge?1:.5},children:[_t("div",{style:{display:"flex",alignItems:"center",gap:4,marginBottom:4},children:[!Ee&&ze(la,{size:11}),ze("span",{style:{fontWeight:600,fontSize:11,color:Ee?o:"#6b7280"},children:Ee?"You":"Claude Code"}),ze("span",{style:{fontSize:10,color:"#9ca3af",marginLeft:"auto"},children:sa(G.timestamp)})]}),ce&&ze("div",{style:{lineHeight:1.5,wordBreak:"break-word"},children:Ee?ce:kr(ce)}),Ke&&ze("div",{style:{marginTop:ce?4:0,lineHeight:1.5,wordBreak:"break-word"},children:kr(Ke)}),(xe||Te)&&_t("div",{style:{marginTop:ce||Ke?6:0,padding:"4px 8px",backgroundColor:"rgba(0, 0, 0, 0.03)",fontSize:11,lineHeight:1.5,color:"#6b7280"},children:[xe&&ze("div",{style:{fontFamily:"ui-monospace, SFMono-Regular, Menlo, monospace",fontSize:10},children:G.toolsUsed.map((Ge,xt)=>ze("div",{children:Ge},xt))}),Te&&G.resolutions.map((Ge,xt)=>{var z;let dt=(z=Ge.finalScope)!=null?z:Ge.inferredScope,Ve=dt?`${dt.breadth} \xB7 ${dt.target}`:null;return _t("div",{style:{marginTop:xe?4:0},children:[ze("span",{style:{color:Ge.status==="resolved"?"#10b981":"#f59e0b"},children:Ge.status==="resolved"?"Done":"Needs review"}),Ve&&ze("span",{style:{marginLeft:6,padding:"1px 5px",backgroundColor:"rgba(0, 0, 0, 0.06)",fontSize:10,fontFamily:"ui-monospace, SFMono-Regular, Menlo, monospace"},children:Ve}),Ge.summary?` \u2014 ${Ge.summary}`:""]},xt)})]})]},`${G.jobId}-${oe}`)}),r&&_t("div",{style:{padding:"8px 16px",borderBottom:"1px solid rgba(0, 0, 0, 0.04)"},children:[_t("div",{style:{display:"flex",alignItems:"center",gap:4,marginBottom:4},children:[ze(la,{size:11}),ze("span",{style:{fontWeight:600,fontSize:11,color:"#6b7280"},children:"Claude Code"}),ve&&ze("span",{style:{fontSize:10,color:"#b0b7c3",fontStyle:"italic"},children:ve}),_t("span",{style:{marginLeft:"auto",display:"flex",alignItems:"center",gap:6},children:[ze(Mp,{color:o}),l&&ze("button",{onClick:l,style:{background:"none",border:"1px solid rgba(0,0,0,0.1)",color:"#6b7280",fontSize:10,padding:"2px 8px",cursor:"pointer",fontFamily:"inherit"},children:"Cancel"})]})]}),me.map((G,oe)=>{if(G.kind==="tool")return ze("div",{style:{paddingLeft:12,fontSize:11,color:"#9ca3af",fontFamily:"ui-monospace, SFMono-Regular, Menlo, monospace",lineHeight:1.6},children:G.label},oe);if(G.kind==="thinking")return ze("div",{style:{paddingLeft:12,marginTop:2,marginBottom:2,fontSize:11,color:"#9ca3af",fontStyle:"italic",lineHeight:1.4,whiteSpace:"pre-wrap",wordBreak:"break-word",maxHeight:80,overflowY:"auto"},children:G.text},oe);let Ee=ia(G.text);return Ee?ze("div",{style:{paddingLeft:12,marginTop:2,marginBottom:2,lineHeight:1.5,wordBreak:"break-word"},children:kr(Ee)},oe):null})]})]}),!r&&a&&_t("div",{style:{padding:"8px 16px",backgroundColor:"rgba(239, 68, 68, 0.06)",borderBottom:"1px solid rgba(0,0,0,0.04)",fontSize:11,color:"#dc2626",lineHeight:1.4},children:[ze("span",{style:{fontWeight:600},children:"Error: "}),a]}),s&&_t("div",{style:Ep,children:[w.length>0&&_t("div",{style:{fontSize:11,color:"#6b7280",marginBottom:4,display:"flex",alignItems:"center",gap:4},children:[_t("span",{children:[w.length," image",w.length>1?"s":""," attached"]}),ze("button",{onClick:()=>O([]),style:{background:"none",border:"none",cursor:"pointer",fontSize:11,color:"#9ca3af",padding:"0 2px"},children:"\xD7"})]}),ze("textarea",{value:v,onChange:G=>b(G.target.value),onKeyDown:We,onPaste:Re,placeholder:"Reply... (Cmd+Enter to send)",style:{width:"100%",minHeight:60,padding:4,fontSize:12,fontFamily:Wt,backgroundColor:"rgba(0, 0, 0, 0.03)",color:"#1f2937",border:"1px solid rgba(0, 0, 0, 0.1)",borderRadius:0,outline:"none",resize:"vertical",lineHeight:1.4,boxSizing:"border-box"}}),ze("div",{style:{display:"flex",justifyContent:"flex-end",marginTop:6},children:ze("button",{onClick:ae,disabled:!v.trim(),style:{padding:"5px 14px",fontSize:11,fontFamily:Wt,fontWeight:600,backgroundColor:v.trim()?o:"rgba(0,0,0,0.1)",color:v.trim()?"#ffffff":"rgba(0,0,0,0.3)",border:"none",cursor:v.trim()?"pointer":"default"},children:"Send \u2318\u23CE"})})]})]})]})}import{Fragment as Fp,jsx as Po,jsxs as ca}from"react/jsx-runtime";var da=Pp(null),Ji="devtools-provider",Xi="devtools-model",Ki="devtools-open-thread-id",Zi=[{id:"claude-opus-4-6",label:"Opus 4.6"},{id:"claude-sonnet-4-6",label:"Sonn 4.6"}],qi=[{id:"gpt-5.3-codex",label:"Codex 5.3"},{id:"gpt-5.3-codex-spark",label:"Spark 5.3"},{id:"gpt-5.1-codex-mini",label:"Mini 5.1"}];function Op(e,t,o){let r=e==="codex"?qi:Zi;return Math.min(o,(t==="codex"?qi:Zi).length-1)}function Dp({children:e,enabled:t=process.env.NODE_ENV==="development",bridgeUrl:o=typeof window!="undefined"?(r=>(r=window.__POPMELT_BRIDGE_URL__)!=null?r:"http://localhost:1111")():"http://localhost:1111"}){var te,U,Pe,Be,he,It;let[n,i]=Hs(),s=Os(o),l=Xt(null),a=Xt(null),c=(te=Ps())!=null?te:o,d=Xt(new Map),[u,p]=Ut(()=>typeof window=="undefined"?"claude":localStorage.getItem(Ji)||"claude"),[g,S]=Ut(()=>{if(typeof window=="undefined")return 0;let R=localStorage.getItem(Xi);return R&&parseInt(R,10)||0}),[v,b]=Ut(["claude","codex"]),[w,O]=Ut({}),[A,k]=Ut(!1);zt(()=>{s.isConnected&&xs(c).then(R=>{if(!R)return;let Z=Object.entries(R.providers).filter(([,ye])=>ye.available).map(([ye])=>ye);Z.length>0&&b(Z);let de={};for(let[ye,ke]of Object.entries(R.providers))ke.mcp&&(de[ye]=ke.mcp);O(de),Object.values(de).every(ye=>ye.found)&&k(!1)})},[s.isConnected,s.capabilitiesVersion,c]),zt(()=>{if(v.length>0&&!v.includes(u)){let R=v[0];p(R),localStorage.setItem(Ji,R)}},[v,u]);let E=u==="codex"?qi:Zi,I=(U=E[g])!=null?U:E[0],$=Gt(R=>{let Z=u;p(R),localStorage.setItem(Ji,R);let de=Op(Z,R,g);S(de),localStorage.setItem(Xi,String(de))},[u,g]),q=Gt(R=>{S(R),localStorage.setItem(Xi,String(R))},[]),j=Gt(async()=>{let R=await ws(c);if(!R)return;let Z={};for(let[de,Oe]of Object.entries(R.capabilities.providers))Oe.mcp&&(Z[de]=Oe.mcp);O(Z),R.results.some(de=>de.installed)&&k(!0)},[c]),[T,D]=Ut(new Set),[K,ee]=Ut(null),[me,ve]=Ut(null),[ae,Re]=Ut(null),[We,Me]=Ut(null);zt(()=>{s.isConnected&&io(c).then(R=>{R!=null&&R.components&&D(new Set(Object.keys(R.components)))})},[s.isConnected,c]);let ne=Gt(async R=>{let Z=[];for(let de of R)try{(await Es(de,c)).added&&Z.push(de)}catch(Oe){console.error("[Popmelt] Failed to add component to model:",de,Oe)}Z.length>0&&(D(de=>{let Oe=new Set(de);for(let ye of Z)Oe.add(ye);return Oe}),ee(Z[Z.length-1]))},[c]),Ae=Gt(R=>{ee(R)},[]),G=Gt(()=>{io(c).then(R=>{R!=null&&R.components&&D(new Set(Object.keys(R.components)))})},[c]),oe=Gt(async R=>{try{(await ks(R,c)).removed&&D(de=>{let Oe=new Set(de);return Oe.delete(R),Oe})}catch(Z){console.error("[Popmelt] Failed to remove component from model:",Z)}},[c]),Ee=Gt((R,Z)=>{i({type:"MODIFY_SPACING_TOKEN",payload:R}),i({type:"ADD_SPACING_TOKEN_CHANGE",payload:Z})},[i]),ce=Gt((R,Z)=>{i({type:"DELETE_SPACING_TOKEN",payload:{tokenPath:R,originalValue:Z}})},[i]),[Ke,Te]=Ut(0),xe=Xt([]);zt(()=>{let R=xe.current,Z=n.spacingTokenMods;xe.current=Z;let de=new Map(R.map(ke=>[ke.tokenPath,ke])),Oe=new Map(Z.map(ke=>[ke.tokenPath,ke])),ye=!1;for(let[ke,Ne]of Oe){let gt=de.get(ke);if(!(gt&&gt.currentValue===Ne.currentValue)){ye=!0,Ne.currentValue==="__deleted__"?Cs(ke,c).catch(Ue=>console.error("[Popmelt] Failed to sync token delete:",Ue)):Ar(ke,Ne.currentValue,c).catch(Ue=>console.error("[Popmelt] Failed to sync token update:",Ue));for(let Ue of Ne.targets){let et=document.querySelector(Ue.selector);if(et)if(Ne.currentValue==="__deleted__")et.style.removeProperty(Ue.property);else{let Ht=Ne.currentPx;Ht>0&&et.style.setProperty(Ue.property,`${Ht}px`,"important")}}}}for(let[ke,Ne]of de)if(!Oe.has(ke)){ye=!0,Ar(ke,Ne.originalValue,c).catch(gt=>console.error("[Popmelt] Failed to restore token on undo:",gt));for(let gt of Ne.targets){let Ue=document.querySelector(gt.selector);Ue&&Ue.style.removeProperty(gt.property)}}ye&&Te(ke=>ke+1)},[n.spacingTokenMods,c]);let[ge,Ge]=Ut(()=>typeof window=="undefined"?null:localStorage.getItem(Ki)||null),[xt,dt]=Ut(new Set),[Ve,z]=Ut(null);zt(()=>{ge?localStorage.setItem(Ki,ge):localStorage.removeItem(Ki)},[ge]);let ie="popmelt-in-flight-jobs",[Q,Se]=Ut(()=>{try{let R=sessionStorage.getItem(ie);return R?JSON.parse(R):{}}catch(R){return{}}});zt(()=>{try{Object.keys(Q).length>0?sessionStorage.setItem(ie,JSON.stringify(Q)):sessionStorage.removeItem(ie)}catch(R){}},[Q]);let Le=Xt(new Map);zt(()=>{for(let[R,Z]of Object.entries(Q))Z.annotationIds.length>0&&Le.current.set(R,Z.annotationIds)},[Q]);let Ze=Xt(!1);zt(()=>{if(Ze.current||n.annotations.length===0)return;Ze.current=!0;let R=new Set;for(let de of Object.values(Q))for(let Oe of de.annotationIds)R.add(Oe);let Z=n.annotations.filter(de=>R.has(de.id)?!1:!!(de.status==="in_flight"||(de.status==="pending"||!de.status)&&(de.captured||de.threadId))).map(de=>de.id);Z.length>0&&i({type:"SET_ANNOTATION_STATUS",payload:{ids:Z,status:"dismissed"}})},[n.annotations,Q,i]);let fe=Ao(()=>{let R=new Set;for(let Z of Object.values(Q))for(let de of Z.annotationIds)R.add(de);return R},[Q]),lt=Ao(()=>{let R=new Set;for(let Z of Object.values(Q))for(let de of Z.styleSelectors)R.add(de);return R},[Q]),Qe=Ao(()=>{let R=new Map;for(let Z of Object.values(Q)){for(let de of Z.styleSelectors)R.set(de,Z.color);for(let de of Z.annotationIds){let Oe=n.annotations.find(ye=>ye.id===de);if(Oe&&(Oe.linkedSelector&&R.set(Oe.linkedSelector,Z.color),Oe.groupId))for(let ye of n.annotations)ye.groupId===Oe.groupId&&ye.linkedSelector&&R.set(ye.linkedSelector,Z.color)}}return R},[Q,n.annotations]),Tt=Xt(n.annotations);Tt.current=n.annotations;let Ot=Xt(n.styleModifications);Ot.current=n.styleModifications;let st=Xt(Q);st.current=Q,zt(()=>{let R=null,Z=()=>{var gt,Ue;if(Object.keys(st.current).length>0)return;let Oe=Tt.current,ye=Ot.current,ke=[],Ne=[];for(let et of Oe){if(!et.linkedSelector||!et.linkedSelector.startsWith("[data-pm=")||et.captured||et.status&&et.status!=="pending")continue;let Ht=document.querySelector(et.linkedSelector);!Ht&&((Ue=(gt=et.elements)==null?void 0:gt[0])!=null&&Ue.selector)&&(Ht=document.querySelector(et.elements[0].selector)),Ht||ke.push(et.linkedSelector)}for(let et of ye)document.querySelector(et.selector)||Ne.push(et.selector);(ke.length>0||Ne.length>0)&&i({type:"CLEANUP_ORPHANED",payload:{linkedSelectors:ke,styleSelectors:Ne}})},de=new MutationObserver(Oe=>{Oe.some(ye=>ye.removedNodes.length>0)&&(R&&clearTimeout(R),R=setTimeout(Z,3e3))});return de.observe(document.body,{childList:!0,subtree:!0}),()=>{de.disconnect(),R&&clearTimeout(R)}},[i]),zt(()=>{s.lastCompletedJobId&&s.lastCompletedJobId in Q&&Se(R=>{var Oe;let ye=R,{[Oe=s.lastCompletedJobId]:Z}=ye;return Hn(ye,[Qo(Oe)])})},[s.lastCompletedJobId]);let at=Xt(new Set);zt(()=>{let R=s.events.filter(Z=>Z.type==="done"&&Z.data.resolutions);for(let Z of R){let de=Z.data.jobId;at.current.has(de)||(at.current.add(de),Array.isArray(Z.data.resolutions)&&i({type:"APPLY_RESOLUTIONS",payload:{resolutions:Z.data.resolutions,threadId:Z.data.threadId}}))}},[s.events,i]);let Dt=Xt(new Set);zt(()=>{let R=s.events.filter(Z=>Z.type==="error"&&Z.data.cancelled);for(let Z of R){let de=Z.data.jobId;if(!de||Dt.current.has(de))continue;Dt.current.add(de);let Oe=Q[de];Oe&&Oe.annotationIds.length>0&&i({type:"SET_ANNOTATION_STATUS",payload:{ids:Oe.annotationIds,status:"dismissed"}})}},[s.events,Q,i]);let tt=Xt(0);zt(()=>{let R=s.incrementalResolutions;if(R.length<=tt.current)return;let Z=R.slice(tt.current);tt.current=R.length,i({type:"APPLY_RESOLUTIONS",payload:{resolutions:Z}})},[s.incrementalResolutions,i]),zt(()=>{s.incrementalResolutions.length===0&&(tt.current=0)},[s.incrementalResolutions.length]);let vt=Xt(s.status);zt(()=>{let R=vt.current;vt.current=s.status,R==="disconnected"&&s.status==="idle"&&Se({})},[s.status]);let $e=Gt(async()=>{let R=l.current;if(!R)return!1;let Z=await Hr(document.body,R,n.annotations);if(Z.length===0)return!1;let de=await Ns(Z,n.annotations,n.styleModifications);return de&&i({type:"MARK_CAPTURED"}),de},[n.annotations,n.styleModifications,i]),en=Gt((R,Z)=>{let de=d.current.get(R)||[];d.current.set(R,[...de,...Z])},[]),Kt=Gt(async()=>{let R=l.current;if(!R)return!1;let Z=n.annotations.filter(Ue=>{var et;return((et=Ue.status)!=null?et:"pending")==="pending"}),de=n.spacingTokenChanges.filter(Ue=>!Ue.captured);if(Z.length===0&&n.styleModifications.filter(Ue=>!Ue.captured).length===0&&de.length===0)return!1;let Oe=await Hr(document.body,R,n.annotations);if(Oe.length===0)return!1;let ye=await Fr(Oe);if(!ye)return!1;let ke=Dr(Z,n.styleModifications,void 0,de.length>0?de:void 0),Ne=JSON.stringify(ke),gt=new Map;for(let Ue of Z){let et=d.current.get(Ue.id);if(et&&et.length>0&&gt.set(Ue.id,et),Ue.groupId){for(let Ht of Z)if(Ht.groupId===Ue.groupId&&Ht.id!==Ue.id){let wt=d.current.get(Ht.id);wt&&wt.length>0&&gt.set(Ht.id,wt)}}}try{let Ue=Or(n.activeColor),{jobId:et,threadId:Ht}=await Ss(ye,Ne,c,Ue,u,I.id,gt.size>0?gt:void 0,Br());for(let un of gt.keys())d.current.delete(un);let wt=Z.map(un=>un.id),Tr=n.styleModifications.filter(un=>!un.captured).map(un=>un.selector);Se(un=>h(f({},un),{[et]:{annotationIds:wt,styleSelectors:Tr,color:n.activeColor,threadId:Ht}})),i({type:"MARK_CAPTURED"}),Ht&&wt.length>0&&i({type:"SET_ANNOTATION_THREAD",payload:{ids:wt,threadId:Ht}});let zn=n.activeColor.match(/oklch\([^)]*\s+([\d.]+)\s*\)/),Uo=((zn!=null&&zn[1]?parseFloat(zn[1]):29)+60)%360;return i({type:"SET_COLOR",payload:`oklch(0.628 0.258 ${Uo})`}),!0}catch(Ue){return console.error("[Pare] Failed to send to bridge:",Ue),!1}},[n.annotations,n.styleModifications,n.spacingTokenChanges,n.activeColor,i,c,u,I.id]),rn=Gt(async(R,Z,de)=>{try{let Oe=Or(n.activeColor),{jobId:ye}=await Ms(R,Z,c,Oe,u,I.id,de,Br());Se(Ne=>h(f({},Ne),{[ye]:{annotationIds:[],styleSelectors:[],color:n.activeColor,threadId:R}}));let ke=n.annotations.filter(Ne=>Ne.threadId===R&&(Ne.status==="waiting_input"||Ne.status==="resolved"||Ne.status==="needs_review"));ke.length>0&&(i({type:"SET_ANNOTATION_STATUS",payload:{ids:ke.map(Ne=>Ne.id),status:"in_flight"}}),Se(Ne=>{let gt=Ne[ye];return gt?h(f({},Ne),{[ye]:h(f({},gt),{annotationIds:[...gt.annotationIds,...ke.map(Ue=>Ue.id)]})}):Ne})),s.dismissQuestion(R)}catch(Oe){console.error("[Pare] Failed to send reply:",Oe)}},[n.activeColor,n.annotations,c,s.dismissQuestion,i,u,I.id]),mn=Xt(new Set);zt(()=>{for(let R of s.pendingQuestions){if(mn.current.has(R.jobId))continue;mn.current.add(R.jobId);let Z=R.annotationIds&&R.annotationIds.length>0?R.annotationIds:void 0;!Z&&R.threadId&&(Z=n.annotations.filter(de=>de.threadId===R.threadId).map(de=>de.id)),Z&&Z.length>0&&i({type:"SET_ANNOTATION_QUESTION",payload:{ids:Z,question:R.question,threadId:R.threadId}})}},[s.pendingQuestions,i,n.annotations]);let En=Ao(()=>{if(s.activeJobId&&s.activeJobId in Q)return Q[s.activeJobId].color;let R=Object.values(Q);return R.length>0?R[R.length-1].color:void 0},[s.activeJobId,Q]),J=Gt(R=>{Ge(R)},[]),Ie=Gt(R=>{if(!R){z(null);return}let Z=Le.current.get(R);Z&&Z.length>0?z(new Set(Z)):z(null)},[]),Fe=Gt(async R=>{try{let Z=R?`${c}/cancel?jobId=${R}`:`${c}/cancel`;await fetch(Z,{method:"POST"})}catch(Z){}},[c]);zt(()=>{n.activeTool==="model"&&ge&&Ge(null)},[n.activeTool]);let ft=Xt(null);zt(()=>{n.isAnnotating?ft.current&&(Ge(ft.current),ft.current=null):ge&&(ft.current=ge,Ge(null))},[n.isAnnotating]);let Lt=Ao(()=>{if(!ge)return null;for(let[R,Z]of Object.entries(Q))if(Z.threadId===ge)return R;return null},[ge,Q]),[pt,bt]=Ut(!1),[St,dn]=Ut(0),$t=Xt(null),kt=Gt(R=>{R?($t.current&&(clearTimeout($t.current),$t.current=null),bt(!0)):$t.current=setTimeout(()=>{bt(!1),$t.current=null},150)},[]),hn=Gt(()=>{dn(R=>R+1),s.clearEvents(),Ge(null),dt(new Set)},[s.clearEvents]);zt(()=>()=>{$t.current&&clearTimeout($t.current)},[]);let W=Ao(()=>({isEnabled:t}),[t]);return t?ca(da.Provider,{value:W,children:[e,Po(_l,{state:n,dispatch:i,onScreenshot:$e,inFlightAnnotationIds:fe,inFlightStyleSelectors:lt,inFlightSelectorColors:Qe,onAttachImages:en,onReply:s.isConnected?rn:void 0,onViewThread:s.isConnected?J:void 0,onCloseThread:R=>{Ge(null),R&&dt(Z=>new Set(Z).add(R))},onModelComponentsAdd:s.isConnected?ne:void 0,onModelComponentFocus:s.isConnected?Ae:void 0,onModelComponentHover:ve,modelComponentNames:T,modelPanelHoveredComponent:ae,modelSpacingTokenHover:We,highlightedAnnotationIds:Ve,externalCanvasRef:l,toolbarRef:a}),Po(na,{children:ca(ta,{children:[Po(Zl,{state:n,dispatch:i,onScreenshot:$e,onSendToClaude:s.isConnected?Kt:void 0,hasActiveJobs:Object.keys(Q).length>0||s.activeJobIds.length>0,activeJobColor:En,onCrosshairHover:kt,onClear:hn,provider:u,onProviderChange:s.isConnected&&v.length>1?$:void 0,availableProviders:v,modelIndex:g,modelCount:E.length,modelLabel:I.label,onModelChange:s.isConnected?q:void 0,onViewThread:s.isConnected?J:void 0,isThreadPanelOpen:ge!==null,mcpStatus:w,onInstallMcp:s.isConnected?j:void 0,mcpJustInstalled:A,bridgeUrl:c,isBridgeConnected:s.isConnected,modelSelectedComponent:K,modelCanvasHoveredComponent:me,onModelComponentHover:Re,onSpacingTokenHover:Me,onModifySpacingToken:s.isConnected?Ee:void 0,onDeleteSpacingToken:s.isConnected?ce:void 0,modelRefreshKey:Ke,onModelComponentAdded:G,onModelComponentRemoved:oe,toolbarRef:a}),ge&&s.isConnected&&Po(aa,{threadId:ge,bridgeUrl:c,accentColor:(Be=(Pe=n.annotations.find(R=>R.threadId===ge))==null?void 0:Pe.color)!=null?Be:n.activeColor,isStreaming:Lt!==null,streamingEvents:Lt?s.events.filter(R=>R.data.jobId===Lt):[],onClose:()=>Ge(null),onReply:rn,onCancel:Lt?()=>Fe(Lt):void 0,lastError:(It=(he=s.lastErrorByJob)==null?void 0:he[Lt!=null?Lt:""])!=null?It:void 0,toolbarRef:a}),Po(ea,{bridge:s,bridgeUrl:c,inFlightJobs:Q,isVisible:pt||s.lastResponseText!==null||s.activeJobIds.length>0,onHover:kt,clearSignal:St,onReply:rn,onViewThread:J,onCancel:Fe,onHoverJob:Ie,isConnected:s.isConnected,dismissedThreadIds:xt})]})})]}):Po(Fp,{children:e})}function Hp(){let e=Bp(da);if(!e)throw new Error("usePopmelt must be used within PopmeltProvider");return e}export{Dp as PopmeltProvider,Hp as usePopmelt};
50
+ `,Pf={borderTop:"1px solid rgba(0, 0, 0, 0.12)",display:"flex",alignItems:"center",gap:4,padding:"0 4px 0 10px"};function Wa(e){return e.replace(/<resolution>[\s\S]*?<\/resolution>/g,"").replace(/<question>[\s\S]*?<\/question>/g,"").replace(/<plan>[\s\S]*?<\/plan>/g,"").replace(/<review>[\s\S]*?<\/review>/g,"").trim()}function Ya(e){return new Date(e).toLocaleTimeString([],{hour:"2-digit",minute:"2-digit"})}var us=["reviewing","considering","thinking","zhuzhing","iterating","tweaking","reflecting","noodling","pondering","finessing","polishing","riffing"],Bf=3e3,Of=250;function Df({color:e}){let[t,n]=mo(0),[r,o]=mo(()=>Math.floor(Math.random()*us.length));return Un(()=>{let i=setInterval(()=>n(l=>(l+1)%2),Of),s=setInterval(()=>o(l=>(l+1)%us.length),Bf);return()=>{clearInterval(i),clearInterval(s)}},[]),Ot("span",{style:{display:"inline-flex",alignItems:"center",gap:4},children:[Ye("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:e,style:{verticalAlign:"middle",flexShrink:0},children:t===1?Ot(ps,{children:[Ye("circle",{cx:"7",cy:"7",r:"2"}),Ye("circle",{cx:"17",cy:"7",r:"2"}),Ye("circle",{cx:"7",cy:"17",r:"2"}),Ye("circle",{cx:"17",cy:"17",r:"2"})]}):Ot(ps,{children:[Ye("circle",{cx:"12",cy:"6",r:"2"}),Ye("circle",{cx:"6",cy:"12",r:"2"}),Ye("circle",{cx:"18",cy:"12",r:"2"}),Ye("circle",{cx:"12",cy:"18",r:"2"})]})}),Ye("span",{style:{fontSize:11,color:"#9ca3af",fontStyle:"italic"},children:us[r]})]})}function Nf(e){var o;let t=String(e.data.tool||""),n=e.data.file?String(e.data.file):null,r=n?(o=n.split("/").pop())!=null?o:n:null;switch(t){case"Read":return r?`Reading ${r}`:"Reading file";case"Edit":return r?`Editing ${r}`:"Editing file";case"Write":return r?`Writing ${r}`:"Writing file";case"Bash":return"Running command";case"Glob":return"Searching files";case"Grep":return"Searching code";case"WebFetch":return"Fetching page";case"WebSearch":return"Searching web";default:return t?`Using ${t}`:null}}var Hf=new Set(["Read","Glob","Grep","WebFetch","WebSearch"]),Ff=new Set(["Edit","Write","Bash"]);function _f(e){let t=0,n=!1;for(let r of e){if(r.type!=="tool_use")continue;let o=String(r.data.tool||"");Ff.has(o)?n=!0:Hf.has(o)&&t++}return!n&&t>=3?"researching":n?"applying changes":null}function zf(e){let t=[];for(let n of e)if(n.type==="tool_use"){let r=Nf(n);r&&t.push({kind:"tool",label:r})}else if(n.type==="delta"){let r=String(n.data.text||"");if(!r)continue;let o=t[t.length-1];o&&o.kind==="text"?o.text+=r:t.push({kind:"text",text:r})}else if(n.type==="thinking"){let r=String(n.data.text||"");if(!r)continue;let o=t[t.length-1];o&&o.kind==="thinking"?o.text+=r:t.push({kind:"thinking",text:r})}return t}function ja({threadId:e,bridgeUrl:t,accentColor:n,isStreaming:r,streamingEvents:o,onClose:i,onReply:s,onCancel:l,lastError:a,onMouseEnter:c,toolbarRef:d,currentModel:u,currentProvider:p,annotationNumber:g,annotationText:k}){let[w,b]=mo([]),[E,B]=mo(!0),[L,T]=mo(""),[v,O]=mo([]),H=zn(null),U=zn(null),G=zn(null),X=zn(r),S=zn(ds()),I=zn({x:0,y:0}),K=zn(!1),ge=zn({x:0,y:0,offsetX:0,offsetY:0}),be=zn(!1),[,de]=mo(0);Un(()=>{try{let q=localStorage.getItem(cs);if(q){let me=JSON.parse(q);typeof me.top=="number"&&typeof me.left=="number"&&(be.current=!0,S.current={top:me.top,left:me.left},de(Ee=>Ee+1))}}catch(q){}},[]),Un(()=>{let q=()=>{be.current||(S.current=ds()),de(me=>me+1)};return window.addEventListener("resize",q,{passive:!0}),()=>window.removeEventListener("resize",q)},[]),Un(()=>{let q=G.current;if(!q)return;let me=We=>{We.button!==0||We.target.closest("button")||(We.preventDefault(),We.stopPropagation(),K.current=!0,ge.current={x:We.clientX,y:We.clientY,offsetX:I.current.x,offsetY:I.current.y})},Ee=We=>{if(!K.current)return;let lt=ge.current,dt=lt.offsetX+(We.clientX-lt.x),W=lt.offsetY+(We.clientY-lt.y),te=Math.max(_o,Math.min(window.innerWidth-Wr-2*fs-_o,S.current.left+dt)),j=Math.max(_o,S.current.top+W);I.current={x:te-S.current.left,y:j-S.current.top};let he=U.current;he&&(he.style.top=`${j}px`,he.style.left=`${te}px`,he.style.height=`${$a(j,te,d==null?void 0:d.current)}px`)},ye=()=>{if(!K.current)return;let We=S.current.top+I.current.y,lt=S.current.left+I.current.x;S.current={top:We,left:lt},I.current={x:0,y:0},be.current=!0;try{localStorage.setItem(cs,JSON.stringify({top:We,left:lt}))}catch(dt){}K.current=!1},Ie=()=>{S.current=ds(),I.current={x:0,y:0},be.current=!1;try{localStorage.removeItem(cs)}catch(We){}de(We=>We+1)};return q.addEventListener("mousedown",me),window.addEventListener("mousemove",Ee),window.addEventListener("mouseup",ye),q.addEventListener("dblclick",Ie),()=>{q.removeEventListener("mousedown",me),window.removeEventListener("mousemove",Ee),window.removeEventListener("mouseup",ye),q.removeEventListener("dblclick",Ie)}},[]);let ue=$r(()=>{fetch(`${t}/thread/${e}`).then(q=>q.json()).then(q=>{var me;b((me=q.messages)!=null?me:[]),B(!1)}).catch(()=>B(!1))},[t,e]);Un(()=>{B(!0),ue()},[ue]),Un(()=>{X.current&&!r&&ue(),X.current=r},[r,ue]);let Fe=o?zf(o):[],Te=o?_f(o):null;Un(()=>{H.current&&(H.current.scrollTop=H.current.scrollHeight)},[w,Fe.length,r]),Un(()=>{let q=me=>{me.key==="Escape"&&(me.stopPropagation(),i())};return document.addEventListener("keydown",q),()=>document.removeEventListener("keydown",q)},[i]);let ee=$r(()=>{if(!L.trim()||!s)return;let q=L.trim(),me=v.length>0?v:void 0;b(Ee=>[...Ee,{role:"human",timestamp:Date.now(),jobId:"pending",replyToQuestion:me?`${q} [${me.length} image${me.length>1?"s":""}]`:q}]),s(e,q,me),T(""),O([])},[L,v,e,s]),Le=$r(q=>{let me=q.clipboardData.items,Ee=[];for(let ye=0;ye<me.length;ye++){let Ie=me[ye];if(Ie.type.startsWith("image/")){let We=Ie.getAsFile();We&&Ee.push(We)}}Ee.length>0&&(q.preventDefault(),O(ye=>[...ye,...Ee]))},[]),Ae=$r(q=>{q.key==="Enter"&&(q.metaKey||q.ctrlKey)&&(q.preventDefault(),ee())},[ee]),_e=S.current.top+I.current.y,Pe=S.current.left+I.current.x,Me=$a(_e,Pe,d==null?void 0:d.current);return Ot(ps,{children:[Ye("div",{"data-devtools":"thread-panel-backdrop",onMouseDown:q=>{q.target===q.currentTarget&&i()},style:{position:"fixed",inset:0,zIndex:9999}}),Ot("div",{ref:U,style:y(f({},If),{height:Me,position:"fixed",top:_e,left:Pe,zIndex:1e4}),"data-devtools":"thread-panel",onMouseEnter:c,children:[Ot("div",{ref:G,style:y(f({},Rf),{backgroundColor:n,color:"#ffffff",cursor:"grab",userSelect:"none",WebkitUserSelect:"none"}),children:[Ot("span",{style:{display:"flex",alignItems:"center",gap:6,minWidth:0},children:[Ye("span",{style:{flexShrink:0},children:g?`${g}.`:"Conversation"}),k&&Ye("span",{style:{opacity:.7,fontSize:11,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",minWidth:0},children:k})]}),Ye("button",{onClick:i,style:{background:"none",border:"none",cursor:"pointer",fontSize:16,color:"#ffffff",padding:"0 4px",lineHeight:1},children:"\xD7"})]}),Ye("style",{dangerouslySetInnerHTML:{__html:Af}}),Ot("div",{ref:H,style:Lf,"data-devtools":"thread-panel-messages",children:[E&&Ye("div",{style:{padding:16,color:"#9ca3af",textAlign:"center"},children:"Loading..."}),!E&&w.length===0&&!r&&Ye("div",{style:{padding:16,color:"#9ca3af",textAlign:"center"},children:"No messages yet."}),w.map((q,me)=>{let Ee=q.role==="human";if(q.cancelled||q.error)return Ot("div",{style:{padding:"8px 16px",borderBottom:"1px solid rgba(0, 0, 0, 0.04)",opacity:me===w.length-1?1:.5},children:[Ot("div",{style:{display:"flex",alignItems:"center",gap:4},children:[Ye("span",{style:{fontSize:11,color:q.error?"#dc2626":"#9ca3af",fontStyle:"italic"},children:q.error?"Error":"Cancelled"}),Ye("span",{style:{fontSize:10,color:"#9ca3af",marginLeft:"auto"},children:Ya(q.timestamp)})]}),q.error&&Ye("div",{style:{fontSize:12,color:"#6b7280",marginTop:4,lineHeight:1.4},children:q.error})]},`${q.jobId}-${me}`);let ye=Ee?q.replyToQuestion||q.feedbackSummary||"(annotation)":Wa(q.responseText||""),Ie=Ee?void 0:q.question,We=!Ee&&q.resolutions&&q.resolutions.length>0,lt=!Ee&&q.toolsUsed&&q.toolsUsed.length>0;if(!ye&&!Ie&&!We)return null;let dt=me===w.length-1;return Ot("div",{style:{padding:"8px 16px",borderBottom:"1px solid rgba(0, 0, 0, 0.04)",opacity:dt?1:.5},children:[Ot("div",{style:{display:"flex",alignItems:"center",gap:4,marginBottom:4},children:[!Ee&&Ye(Zi,{provider:q.provider,size:11,style:{color:"#6b7280"}}),Ye("span",{style:{fontWeight:600,fontSize:11,color:Ee?n:"#6b7280"},children:Ee?"You":Qi(q.model,q.provider)}),Ye("span",{style:{fontSize:10,color:"#9ca3af",marginLeft:"auto"},children:Ya(q.timestamp)})]}),ye&&Ye("div",{style:{lineHeight:1.5,wordBreak:"break-word"},children:Ee?ye:zr(ye)}),Ie&&Ye("div",{style:{marginTop:ye?4:0,lineHeight:1.5,wordBreak:"break-word"},children:zr(Ie)}),(lt||We)&&Ot("div",{style:{marginTop:ye||Ie?6:0,padding:"4px 8px",backgroundColor:"rgba(0, 0, 0, 0.03)",fontSize:11,lineHeight:1.5,color:"#6b7280"},children:[lt&&Ye("div",{style:{fontFamily:"ui-monospace, SFMono-Regular, Menlo, monospace",fontSize:10},children:q.toolsUsed.map((W,te)=>Ye("div",{children:W},te))}),We&&q.resolutions.map((W,te)=>{var xe;let j=(xe=W.finalScope)!=null?xe:W.inferredScope,he=j?`${j.breadth} \xB7 ${j.target}`:null;return Ot("div",{style:{marginTop:lt?4:0},children:[Ye("span",{style:{color:W.status==="resolved"?"#10b981":"#f59e0b"},children:W.status==="resolved"?"Done":"Needs review"}),he&&Ye("span",{style:{marginLeft:6,padding:"1px 5px",backgroundColor:"rgba(0, 0, 0, 0.06)",fontSize:10,fontFamily:"ui-monospace, SFMono-Regular, Menlo, monospace"},children:he}),W.summary?` \u2014 ${W.summary}`:""]},te)})]})]},`${q.jobId}-${me}`)}),r&&Ot("div",{style:{padding:"8px 16px",borderBottom:"1px solid rgba(0, 0, 0, 0.04)"},children:[Ot("div",{style:{display:"flex",alignItems:"center",gap:4,marginBottom:4},children:[Ye(Zi,{provider:p,size:11,style:{color:"#6b7280"}}),Ye("span",{style:{fontWeight:600,fontSize:11,color:"#6b7280"},children:Qi(u,p)}),Te&&Ye("span",{style:{fontSize:10,color:"#b0b7c3",fontStyle:"italic"},children:Te}),Ot("span",{style:{marginLeft:"auto",display:"flex",alignItems:"center",gap:6},children:[Ye(Df,{color:n}),l&&Ye("button",{onClick:l,style:{background:"none",border:"1px solid rgba(0,0,0,0.1)",color:"#6b7280",fontSize:10,padding:"2px 8px",cursor:"pointer",fontFamily:"inherit"},children:"Cancel"})]})]}),Fe.map((q,me)=>{if(q.kind==="tool")return Ye("div",{style:{paddingLeft:12,fontSize:11,color:"#9ca3af",fontFamily:"ui-monospace, SFMono-Regular, Menlo, monospace",lineHeight:1.6},children:q.label},me);if(q.kind==="thinking")return Ye("div",{style:{paddingLeft:12,marginTop:2,marginBottom:2,fontSize:11,color:"#9ca3af",fontStyle:"italic",lineHeight:1.4,whiteSpace:"pre-wrap",wordBreak:"break-word",maxHeight:80,overflowY:"auto"},children:q.text},me);let Ee=Wa(q.text);return Ee?Ye("div",{style:{paddingLeft:12,marginTop:2,marginBottom:2,lineHeight:1.5,wordBreak:"break-word"},children:zr(Ee)},me):null})]})]}),!r&&a&&Ot("div",{style:{padding:"8px 16px",backgroundColor:"rgba(239, 68, 68, 0.06)",borderBottom:"1px solid rgba(0,0,0,0.04)",fontSize:11,color:"#dc2626",lineHeight:1.4},children:[Ye("span",{style:{fontWeight:600},children:"Error: "}),a]}),s&&Ot("div",{style:Pf,children:[Ye("input",{value:L,onChange:q=>T(q.target.value),onKeyDown:Ae,onPaste:Le,placeholder:"Reply (cmd enter)",style:{flex:1,minWidth:0,height:32,padding:"0 4px",fontSize:12,fontFamily:zt,backgroundColor:"transparent",color:"#1f2937",border:"none",outline:"none",lineHeight:"32px",boxSizing:"border-box"}}),Ye("button",{onClick:ee,disabled:!L.trim(),style:{display:"flex",alignItems:"center",justifyContent:"center",width:28,height:28,padding:0,background:"none",border:"none",cursor:L.trim()?"pointer":"default",color:L.trim()?"#1f2937":"rgba(0,0,0,0.2)",flexShrink:0},children:Ot("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round",children:[Ye("path",{d:"M22 2 11 13"}),Ye("path",{d:"M22 2 15 22 11 13 2 9z"})]})})]})]})]})}import{Fragment as Vf,jsx as $o,jsxs as Ga}from"react/jsx-runtime";var Va=$f(null),gs="devtools-provider",ms="devtools-model",hs="devtools-open-thread-id";function Yf(e,t,n){let r=e==="codex"?er:Qo;return Math.min(n,(t==="codex"?er:Qo).length-1)}function jf({children:e,enabled:t=process.env.NODE_ENV==="development",bridgeUrl:n=typeof window!="undefined"?(r=>(r=window.__POPMELT_BRIDGE_URL__)!=null?r:"http://localhost:1111")():"http://localhost:1111"}){var Oe,pe,xt,Je,Tn;let[o,i]=ll(),s=il(n),l=Xt(null),a=Xt(null),c=(Oe=ol())!=null?Oe:n,d=Xt(new Map),[u,p]=Kt(()=>typeof window=="undefined"?"claude":localStorage.getItem(gs)||"claude"),[g,k]=Kt(()=>{if(typeof window=="undefined")return 0;let P=localStorage.getItem(ms);return P&&parseInt(P,10)||0}),[w,b]=Kt(["claude","codex"]),[E,B]=Kt({}),[L,T]=Kt(!1);Dt(()=>{s.isConnected&&_s(c).then(P=>{if(!P)return;let Q=Object.entries(P.providers).filter(([,He])=>He.available).map(([He])=>He);Q.length>0&&b(Q);let se={};for(let[He,Ze]of Object.entries(P.providers))Ze.mcp&&(se[He]=Ze.mcp);B(se),Object.values(se).every(He=>He.found)&&T(!1)})},[s.isConnected,s.capabilitiesVersion,c]),Dt(()=>{if(w.length>0&&!w.includes(u)){let P=w[0];p(P),localStorage.setItem(gs,P)}},[w,u]);let v=u==="codex"?er:Qo,O=(pe=v[g])!=null?pe:v[0],H=Vt(P=>{let Q=u;p(P),localStorage.setItem(gs,P);let se=Yf(Q,P,g);k(se),localStorage.setItem(ms,String(se))},[u,g]),U=Vt(P=>{k(P),localStorage.setItem(ms,String(P))},[]),G=Vt(async()=>{let P=await Ws(c);if(!P)return;let Q={};for(let[se,fe]of Object.entries(P.capabilities.providers))fe.mcp&&(Q[se]=fe.mcp);B(Q),P.results.some(se=>se.installed)&&T(!0)},[c]),[X,S]=Kt(new Set),[I,K]=Kt(null),[ge,be]=Kt(null),[de,ue]=Kt(null),[Fe,Te]=Kt(null);Dt(()=>{s.isConnected&&xo(c).then(P=>{P!=null&&P.components&&S(new Set(Object.keys(P.components)))})},[s.isConnected,c]);let ee=Vt(async P=>{let Q=[];for(let se of P)try{(await Ys(se,c)).added&&Q.push(se)}catch(fe){console.error("[Popmelt] Failed to add component to model:",se,fe)}Q.length>0&&(S(se=>{let fe=new Set(se);for(let He of Q)fe.add(He);return fe}),K(Q[Q.length-1]))},[c]),Le=Vt(P=>{K(P)},[]),Ae=Vt(()=>{xo(c).then(P=>{P!=null&&P.components&&S(new Set(Object.keys(P.components)))})},[c]),_e=Vt(async P=>{try{(await js(P,c)).removed&&S(se=>{let fe=new Set(se);return fe.delete(P),fe})}catch(Q){console.error("[Popmelt] Failed to remove component from model:",Q)}},[c]),Pe=Vt((P,Q)=>{i({type:"MODIFY_SPACING_TOKEN",payload:P}),i({type:"ADD_SPACING_TOKEN_CHANGE",payload:Q})},[i]),Me=Vt((P,Q)=>{i({type:"DELETE_SPACING_TOKEN",payload:{tokenPath:P,originalValue:Q}})},[i]),[q,me]=Kt(0),Ee=Xt([]);Dt(()=>{let P=Ee.current,Q=o.spacingTokenMods;Ee.current=Q;let se=new Map(P.map(Ze=>[Ze.tokenPath,Ze])),fe=new Map(Q.map(Ze=>[Ze.tokenPath,Ze])),He=!1;for(let[Ze,at]of fe){let Ne=se.get(Ze);if(!(Ne&&Ne.currentValue===at.currentValue)){He=!0,at.currentValue==="__deleted__"?Gs(Ze,c).catch(je=>console.error("[Popmelt] Failed to sync token delete:",je)):Ur(Ze,at.currentValue,c).catch(je=>console.error("[Popmelt] Failed to sync token update:",je));for(let je of at.targets){let nt=document.querySelector(je.selector);if(nt)if(at.currentValue==="__deleted__")nt.style.removeProperty(je.property);else{let Lt=at.currentPx;Lt>0&&nt.style.setProperty(je.property,`${Lt}px`,"important")}}}}for(let[Ze,at]of se)if(!fe.has(Ze)){He=!0,Ur(Ze,at.originalValue,c).catch(Ne=>console.error("[Popmelt] Failed to restore token on undo:",Ne));for(let Ne of at.targets){let je=document.querySelector(Ne.selector);je&&je.style.removeProperty(Ne.property)}}He&&me(Ze=>Ze+1)},[o.spacingTokenMods,c]);let[ye,Ie]=Kt(()=>typeof window=="undefined"?null:localStorage.getItem(hs)||null),[We,lt]=Kt(new Set),[dt,W]=Kt(null);Dt(()=>{ye?localStorage.setItem(hs,ye):localStorage.removeItem(hs)},[ye]);let te="popmelt-in-flight-jobs",[j,he]=Kt(()=>{try{let P=sessionStorage.getItem(te);return P?JSON.parse(P):{}}catch(P){return{}}});Dt(()=>{try{Object.keys(j).length>0?sessionStorage.setItem(te,JSON.stringify(j)):sessionStorage.removeItem(te)}catch(P){}},[j]);let xe=Xt(new Map);Dt(()=>{for(let[P,Q]of Object.entries(j))Q.annotationIds.length>0&&xe.current.set(P,Q.annotationIds)},[j]);let Be=Xt(!1);Dt(()=>{if(Be.current||o.annotations.length===0)return;Be.current=!0;let P=new Set;for(let se of Object.values(j))for(let fe of se.annotationIds)P.add(fe);let Q=o.annotations.filter(se=>P.has(se.id)?!1:!!(se.status==="in_flight"||(se.status==="pending"||!se.status)&&(se.captured||se.threadId))).map(se=>se.id);Q.length>0&&i({type:"SET_ANNOTATION_STATUS",payload:{ids:Q,status:"dismissed"}})},[o.annotations,j,i]);let Ce=zo(()=>{let P=new Set;for(let Q of Object.values(j))for(let se of Q.annotationIds)P.add(se);return P},[j]),it=zo(()=>{let P=new Set;for(let Q of Object.values(j))for(let se of Q.styleSelectors)P.add(se);return P},[j]),qe=zo(()=>{let P=new Map;for(let Q of Object.values(j)){for(let se of Q.styleSelectors)P.set(se,Q.color);for(let se of Q.annotationIds){let fe=o.annotations.find(He=>He.id===se);if(fe&&(fe.linkedSelector&&P.set(fe.linkedSelector,Q.color),fe.groupId))for(let He of o.annotations)He.groupId===fe.groupId&&He.linkedSelector&&P.set(He.linkedSelector,Q.color)}}return P},[j,o.annotations]),Ct=Xt(o.annotations);Ct.current=o.annotations;let Nt=Xt(o.styleModifications);Nt.current=o.styleModifications;let et=Xt(j);et.current=j,Dt(()=>{let P=null,Q=()=>{var Ne,je;if(Object.keys(et.current).length>0)return;let fe=Ct.current,He=Nt.current,Ze=[],at=[];for(let nt of fe){if(!nt.linkedSelector||!nt.linkedSelector.startsWith("[data-pm=")||nt.captured||nt.status&&nt.status!=="pending")continue;let Lt=document.querySelector(nt.linkedSelector);!Lt&&((je=(Ne=nt.elements)==null?void 0:Ne[0])!=null&&je.selector)&&(Lt=document.querySelector(nt.elements[0].selector)),Lt||Ze.push(nt.linkedSelector)}for(let nt of He)document.querySelector(nt.selector)||at.push(nt.selector);(Ze.length>0||at.length>0)&&i({type:"CLEANUP_ORPHANED",payload:{linkedSelectors:Ze,styleSelectors:at}})},se=new MutationObserver(fe=>{fe.some(He=>He.removedNodes.length>0)&&(P&&clearTimeout(P),P=setTimeout(Q,3e3))});return se.observe(document.body,{childList:!0,subtree:!0}),()=>{se.disconnect(),P&&clearTimeout(P)}},[i]),Dt(()=>{s.lastCompletedJobId&&s.lastCompletedJobId in j&&he(P=>{var fe;let He=P,{[fe=s.lastCompletedJobId]:Q}=He;return Yn(He,[dr(fe)])})},[s.lastCompletedJobId]);let Rt=Xt(!1);Dt(()=>{if(!s.isConnected){Rt.current=!1;return}if(Rt.current||(Rt.current=!0,Object.keys(j).length===0))return;let Q=setTimeout(()=>{bo(c).then(se=>{var He;if(!se)return;let fe=new Set(((He=se.activeJobs)!=null?He:[]).map(Ze=>Ze.id));he(Ze=>{let at=Object.keys(Ze).filter(je=>!fe.has(je));if(at.length===0)return Ze;let Ne=f({},Ze);for(let je of at)delete Ne[je];return Ne})})},500);return()=>clearTimeout(Q)},[s.isConnected,c]);let Ht=Xt(new Set);Dt(()=>{let P=s.events.filter(Q=>Q.type==="done"&&Q.data.resolutions);for(let Q of P){let se=Q.data.jobId;Ht.current.has(se)||(Ht.current.add(se),Array.isArray(Q.data.resolutions)&&i({type:"APPLY_RESOLUTIONS",payload:{resolutions:Q.data.resolutions,threadId:Q.data.threadId}}))}},[s.events,i]);let bt=Xt(new Set);Dt(()=>{let P=s.events.filter(Q=>Q.type==="error"&&Q.data.cancelled);for(let Q of P){let se=Q.data.jobId;if(!se||bt.current.has(se))continue;bt.current.add(se);let fe=j[se];fe&&fe.annotationIds.length>0&&i({type:"SET_ANNOTATION_STATUS",payload:{ids:fe.annotationIds,status:"dismissed"}})}},[s.events,j,i]);let wt=Xt(0);Dt(()=>{let P=s.incrementalResolutions;if(P.length<=wt.current)return;let Q=P.slice(wt.current);wt.current=P.length,i({type:"APPLY_RESOLUTIONS",payload:{resolutions:Q}})},[s.incrementalResolutions,i]),Dt(()=>{s.incrementalResolutions.length===0&&(wt.current=0)},[s.incrementalResolutions.length]);let mt=Xt(s.status);Dt(()=>{let P=mt.current;mt.current=s.status,P==="disconnected"&&s.status==="idle"&&he({})},[s.status]);let vt=Vt(async()=>{let P=l.current;if(!P)return!1;let Q=await ei(document.body,P,o.annotations);if(Q.length===0)return!1;let se=await cl(Q,o.annotations,o.styleModifications);return se&&i({type:"MARK_CAPTURED"}),se},[o.annotations,o.styleModifications,i]),en=Vt((P,Q)=>{let se=d.current.get(P)||[];d.current.set(P,[...se,...Q])},[]),Ft=Vt(async()=>{let P=l.current;if(!P)return!1;let Q=o.annotations.filter(je=>{var nt;return((nt=je.status)!=null?nt:"pending")==="pending"}),se=o.spacingTokenChanges.filter(je=>!je.captured);if(Q.length===0&&o.styleModifications.filter(je=>!je.captured).length===0&&se.length===0)return!1;let fe=await ei(document.body,P,o.annotations);if(fe.length===0)return!1;let He=await ti(fe);if(!He)return!1;let Ze=Qr(Q,o.styleModifications,void 0,se.length>0?se:void 0),at=JSON.stringify(Ze),Ne=new Map;for(let je of Q){let nt=d.current.get(je.id);if(nt&&nt.length>0&&Ne.set(je.id,nt),je.groupId){for(let Lt of Q)if(Lt.groupId===je.groupId&&Lt.id!==je.id){let on=d.current.get(Lt.id);on&&on.length>0&&Ne.set(Lt.id,on)}}}try{let je=Zr(o.activeColor),{jobId:nt,threadId:Lt}=await $s(He,at,c,je,u,O.id,Ne.size>0?Ne:void 0,qr());for(let yn of Ne.keys())d.current.delete(yn);let on=Q.map(yn=>yn.id),hn=o.styleModifications.filter(yn=>!yn.captured).map(yn=>yn.selector);he(yn=>y(f({},yn),{[nt]:{annotationIds:on,styleSelectors:hn,color:o.activeColor,threadId:Lt}})),i({type:"MARK_CAPTURED"}),Lt&&on.length>0&&i({type:"SET_ANNOTATION_THREAD",payload:{ids:on,threadId:Lt}});let $n=o.activeColor.match(/oklch\([^)]*\s+([\d.]+)\s*\)/),Yr=(($n!=null&&$n[1]?parseFloat($n[1]):29)+60)%360;return i({type:"SET_COLOR",payload:`oklch(0.628 0.258 ${Yr})`}),!0}catch(je){return console.error("[Pare] Failed to send to bridge:",je),!1}},[o.annotations,o.styleModifications,o.spacingTokenChanges,o.activeColor,i,c,u,O.id]),an=Vt(async(P,Q,se)=>{try{let fe=Zr(o.activeColor),{jobId:He}=await Vs(P,Q,c,fe,u,O.id,se,qr());he(at=>y(f({},at),{[He]:{annotationIds:[],styleSelectors:[],color:o.activeColor,threadId:P}}));let Ze=o.annotations.filter(at=>at.threadId===P&&(at.status==="waiting_input"||at.status==="resolved"||at.status==="needs_review"));Ze.length>0&&(i({type:"SET_ANNOTATION_STATUS",payload:{ids:Ze.map(at=>at.id),status:"in_flight"}}),he(at=>{let Ne=at[He];return Ne?y(f({},at),{[He]:y(f({},Ne),{annotationIds:[...Ne.annotationIds,...Ze.map(je=>je.id)]})}):at})),s.dismissQuestion(P)}catch(fe){console.error("[Pare] Failed to send reply:",fe)}},[o.activeColor,o.annotations,c,s.dismissQuestion,i,u,O.id]),ut=Xt(new Set);Dt(()=>{for(let P of s.pendingQuestions){if(ut.current.has(P.jobId))continue;ut.current.add(P.jobId);let Q=P.annotationIds&&P.annotationIds.length>0?P.annotationIds:void 0;!Q&&P.threadId&&(Q=o.annotations.filter(se=>se.threadId===P.threadId).map(se=>se.id)),Q&&Q.length>0&&i({type:"SET_ANNOTATION_QUESTION",payload:{ids:Q,question:P.question,threadId:P.threadId}})}},[s.pendingQuestions,i,o.annotations]);let Z=zo(()=>{if(s.activeJobId&&s.activeJobId in j)return j[s.activeJobId].color;let P=Object.values(j);return P.length>0?P[P.length-1].color:void 0},[s.activeJobId,j]),Re=Vt(P=>{Ie(P)},[]),Xe=Vt(P=>{if(!P){W(null);return}let Q=xe.current.get(P);Q&&Q.length>0?W(new Set(Q)):W(null)},[]),cn=Vt(async P=>{try{let Q=P?`${c}/cancel?jobId=${P}`:`${c}/cancel`;await fetch(Q,{method:"POST"})}catch(Q){}},[c]);Dt(()=>{o.activeTool==="model"&&ye&&Ie(null)},[o.activeTool]);let qt=Xt(null);Dt(()=>{o.isAnnotating?qt.current&&(Ie(qt.current),qt.current=null):ye&&(qt.current=ye,Ie(null))},[o.isAnnotating]);let pt=zo(()=>{if(!ye)return null;for(let[P,Q]of Object.entries(j))if(Q.threadId===ye)return P;return null},[ye,j]),tt=ye?o.annotations.find(P=>P.threadId===ye):void 0,Ut=tt?o.annotations.indexOf(tt)+1:void 0,[kt,Jn]=Kt(!1),[dn,Pn]=Kt(0),F=Xt(null),ne=Vt(P=>{P?(F.current&&(clearTimeout(F.current),F.current=null),Jn(!0)):F.current=setTimeout(()=>{Jn(!1),F.current=null},150)},[]),oe=Vt(()=>{Pn(P=>P+1),s.clearEvents(),Ie(null),lt(new Set)},[s.clearEvents]);Dt(()=>()=>{F.current&&clearTimeout(F.current)},[]);let Se=zo(()=>({isEnabled:t}),[t]);return t?Ga(Va.Provider,{value:Se,children:[e,$o(da,{state:o,dispatch:i,onScreenshot:vt,inFlightAnnotationIds:Ce,inFlightStyleSelectors:it,inFlightSelectorColors:qe,onAttachImages:en,onReply:s.isConnected?an:void 0,onViewThread:s.isConnected?Re:void 0,onCloseThread:P=>{Ie(null),P&&lt(Q=>new Set(Q).add(P))},onModelComponentsAdd:s.isConnected?ee:void 0,onModelComponentFocus:s.isConnected?Le:void 0,onModelComponentHover:be,modelComponentNames:X,modelPanelHoveredComponent:de,modelSpacingTokenHover:Fe,highlightedAnnotationIds:dt,focusedThreadAnnotationId:tt==null?void 0:tt.id,externalCanvasRef:l,toolbarRef:a}),$o(_a,{children:Ga(Ha,{children:[$o(Ba,{state:o,dispatch:i,onScreenshot:vt,onSendToClaude:s.isConnected?Ft:void 0,hasActiveJobs:Object.keys(j).length>0||s.activeJobIds.length>0,activeJobColor:Z,onCrosshairHover:ne,onClear:oe,provider:u,onProviderChange:s.isConnected&&w.length>1?H:void 0,availableProviders:w,modelIndex:g,modelCount:v.length,modelLabel:O.label,onModelChange:s.isConnected?U:void 0,onViewThread:s.isConnected?Re:void 0,isThreadPanelOpen:ye!==null,mcpStatus:E,onInstallMcp:s.isConnected?G:void 0,mcpJustInstalled:L,bridgeUrl:c,isBridgeConnected:s.isConnected,modelSelectedComponent:I,modelCanvasHoveredComponent:ge,onModelComponentHover:ue,onSpacingTokenHover:Te,onModifySpacingToken:s.isConnected?Pe:void 0,onDeleteSpacingToken:s.isConnected?Me:void 0,modelRefreshKey:q,onModelComponentAdded:Ae,onModelComponentRemoved:_e,toolbarRef:a}),ye&&s.isConnected&&$o(ja,{threadId:ye,bridgeUrl:c,accentColor:(xt=tt==null?void 0:tt.color)!=null?xt:o.activeColor,isStreaming:pt!==null,streamingEvents:pt?s.events.filter(P=>P.data.jobId===pt):[],onClose:()=>Ie(null),onReply:an,onCancel:pt?()=>cn(pt):void 0,lastError:(Tn=(Je=s.lastErrorByJob)==null?void 0:Je[pt!=null?pt:""])!=null?Tn:void 0,toolbarRef:a,currentModel:O.id,currentProvider:u,annotationNumber:Ut,annotationText:tt==null?void 0:tt.text}),$o(Na,{bridge:s,bridgeUrl:c,inFlightJobs:j,isVisible:kt||s.lastResponseText!==null||s.activeJobIds.length>0,onHover:ne,clearSignal:dn,onReply:an,onViewThread:Re,onCancel:cn,onHoverJob:Xe,isConnected:s.isConnected,dismissedThreadIds:We})]})})]}):$o(Vf,{children:e})}function Gf(){let e=Wf(Va);if(!e)throw new Error("usePopmelt must be used within PopmeltProvider");return e}export{jf as PopmeltProvider,Gf as usePopmelt};