@zeke-02/docx-editor 0.5.3 → 0.5.4

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.
Files changed (65) hide show
  1. package/dist/{KeyboardShortcutsDialog-5D_FoAp6.d.ts → KeyboardShortcutsDialog-B0UFuR4w.d.ts} +2 -2
  2. package/dist/{KeyboardShortcutsDialog-D7ihAj18.d.mts → KeyboardShortcutsDialog-t6JKL4Aj.d.mts} +2 -2
  3. package/dist/PageSetupDialog-642IAVG2.js +1 -1
  4. package/dist/PageSetupDialog-ERUQDHAY.mjs +1 -1
  5. package/dist/PluginHost-HS31VIuo.d.mts +16 -0
  6. package/dist/PluginHost-zILZO7zX.d.ts +16 -0
  7. package/dist/{agentApi-D4AZmNfB.d.ts → agentApi-B2Y7kexW.d.ts} +1 -1
  8. package/dist/{agentApi-C41hiW-n.d.mts → agentApi-BzUJ_kao.d.mts} +1 -1
  9. package/dist/{chunk-E6MQXELR.js → chunk-HXDMASAR.js} +1 -1
  10. package/dist/chunk-JFRDFK7V.mjs +260 -0
  11. package/dist/{chunk-LUJ6HCMH.mjs → chunk-LWOHVYKW.mjs} +1 -1
  12. package/dist/chunk-MDTA25AN.mjs +60 -0
  13. package/dist/chunk-NOLMVQNN.mjs +40 -0
  14. package/dist/chunk-SGTUE33R.js +260 -0
  15. package/dist/chunk-WO3FIV4B.js +40 -0
  16. package/dist/{chunk-ONNHQWAX.mjs → chunk-XGJ2EORY.mjs} +1 -1
  17. package/dist/{chunk-AYMGSTNG.js → chunk-Y3SEHWZ2.js} +1 -1
  18. package/dist/chunk-YBEVHQCT.js +60 -0
  19. package/dist/{content-B2MzIMwA.d.mts → content-REFGFfEH.d.mts} +1 -1
  20. package/dist/{content-B2MzIMwA.d.ts → content-REFGFfEH.d.ts} +1 -1
  21. package/dist/dialogs.d.mts +4 -4
  22. package/dist/dialogs.d.ts +4 -4
  23. package/dist/dialogs.js +1 -1
  24. package/dist/dialogs.mjs +1 -1
  25. package/dist/{document-Di1qGqLS.d.mts → document-Cu2vq_wS.d.mts} +1 -1
  26. package/dist/{document-DZ_ZeZEH.d.ts → document-CxOagoLQ.d.ts} +1 -1
  27. package/dist/executor-WBHID2RK.mjs +1 -0
  28. package/dist/{executor-EPEB53SJ.js → executor-Y5VUOAHY.js} +1 -1
  29. package/dist/{findReplace-pkMskVJU.d.ts → findReplace-Bue0JaXh.d.ts} +1 -1
  30. package/dist/{findReplace-CpIoILbP.d.mts → findReplace-shXbOjFQ.d.mts} +1 -1
  31. package/dist/fork.css +1 -0
  32. package/dist/fork.d.mts +535 -0
  33. package/dist/fork.d.ts +535 -0
  34. package/dist/fork.js +1 -0
  35. package/dist/fork.mjs +1 -0
  36. package/dist/hooks.d.mts +6 -6
  37. package/dist/hooks.d.ts +6 -6
  38. package/dist/hooks.js +1 -1
  39. package/dist/hooks.mjs +1 -1
  40. package/dist/index-B5A-J9GC.d.ts +1119 -0
  41. package/dist/index-bw-PaozF.d.mts +1119 -0
  42. package/dist/index.d.mts +11 -1120
  43. package/dist/index.d.ts +11 -1120
  44. package/dist/index.js +1 -40
  45. package/dist/index.mjs +1 -40
  46. package/dist/plugin-api.d.mts +5 -16
  47. package/dist/plugin-api.d.ts +5 -16
  48. package/dist/plugin-api.js +1 -260
  49. package/dist/plugin-api.mjs +1 -260
  50. package/dist/{types-DZUhB7Ao.d.mts → types-BF48VxkC.d.mts} +1 -1
  51. package/dist/{types-DZUhB7Ao.d.ts → types-BF48VxkC.d.ts} +1 -1
  52. package/dist/{types-Bd_YzkhG.d.mts → types-BnIs4sE7.d.mts} +1 -1
  53. package/dist/{types-Bd_YzkhG.d.ts → types-BnIs4sE7.d.ts} +1 -1
  54. package/dist/{types-DcxHFUSc.d.ts → types-CW6HFAX6.d.ts} +1 -1
  55. package/dist/{types-CkfDgB0O.d.mts → types-DIsDCwTG.d.mts} +1 -1
  56. package/dist/ui.d.mts +9 -9
  57. package/dist/ui.d.ts +9 -9
  58. package/dist/ui.js +1 -1
  59. package/dist/ui.mjs +1 -1
  60. package/dist/{useFindReplace-eyhMSZZf.d.ts → useFindReplace-DKy-s3gS.d.ts} +2 -2
  61. package/dist/{useFindReplace-DDs533b-.d.mts → useFindReplace-vuoKpDKE.d.mts} +2 -2
  62. package/package.json +7 -7
  63. package/dist/chunk-47VJOBJD.mjs +0 -60
  64. package/dist/chunk-IP5NAYHL.js +0 -60
  65. package/dist/executor-TVJ6K6MW.mjs +0 -1
@@ -0,0 +1,260 @@
1
+ 'use strict';var chunkYBEVHQCT_js=require('./chunk-YBEVHQCT.js'),me=require('react'),prosemirrorState=require('prosemirror-state'),jsxRuntime=require('react/jsx-runtime'),prosemirrorView=require('prosemirror-view');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var me__default=/*#__PURE__*/_interopDefault(me);var $={position:"right",defaultSize:280,minSize:200,maxSize:500,resizable:true,collapsible:true,defaultCollapsed:false},te=chunkYBEVHQCT_js.r,ne=`
2
+ .plugin-host {
3
+ display: flex;
4
+ width: 100%;
5
+ height: 100%;
6
+ overflow: visible;
7
+ position: relative;
8
+ }
9
+
10
+ .plugin-host-editor {
11
+ flex: 1;
12
+ display: flex;
13
+ flex-direction: column;
14
+ min-width: 0;
15
+ overflow: visible;
16
+ }
17
+
18
+
19
+ .plugin-panels-left,
20
+ .plugin-panels-right {
21
+ display: flex;
22
+ flex-direction: column;
23
+ flex-shrink: 0;
24
+ background: #f8f9fa;
25
+ border-color: #e9ecef;
26
+ }
27
+
28
+ .plugin-panels-left {
29
+ border-right: 1px solid #e9ecef;
30
+ }
31
+
32
+ .plugin-panels-right {
33
+ border-left: 1px solid #e9ecef;
34
+ }
35
+
36
+ .plugin-panels-bottom {
37
+ border-top: 1px solid #e9ecef;
38
+ background: #f8f9fa;
39
+ }
40
+
41
+ .plugin-panel {
42
+ position: relative;
43
+ display: flex;
44
+ flex-direction: column;
45
+ overflow: hidden;
46
+ transition: width 0.2s ease, height 0.2s ease;
47
+ }
48
+
49
+ .plugin-panel.collapsed {
50
+ overflow: visible;
51
+ }
52
+
53
+ .plugin-panel-toggle {
54
+ display: flex;
55
+ align-items: center;
56
+ gap: 4px;
57
+ padding: 6px 8px;
58
+ background: transparent;
59
+ border: none;
60
+ cursor: pointer;
61
+ font-size: 12px;
62
+ color: #6c757d;
63
+ white-space: nowrap;
64
+ }
65
+
66
+ .plugin-panel.collapsed .plugin-panel-toggle {
67
+ writing-mode: vertical-rl;
68
+ text-orientation: mixed;
69
+ flex-direction: column;
70
+ height: 100%;
71
+ padding: 8px 6px;
72
+ }
73
+
74
+ .plugin-panel-toggle:hover {
75
+ background: #e9ecef;
76
+ color: #495057;
77
+ }
78
+
79
+ .plugin-panel-toggle-icon {
80
+ font-weight: bold;
81
+ font-size: 14px;
82
+ }
83
+
84
+ .plugin-panel.collapsed .plugin-panel-toggle-icon {
85
+ transform: rotate(90deg);
86
+ }
87
+
88
+ .plugin-panel-toggle-label {
89
+ font-weight: 500;
90
+ }
91
+
92
+ .plugin-panel-content {
93
+ flex: 1;
94
+ overflow: auto;
95
+ }
96
+
97
+ /* Right panel rendered inside viewport - scrolls with content */
98
+ .plugin-panel-in-viewport {
99
+ position: absolute;
100
+ top: 0;
101
+ /* Position is set dynamically via inline styles based on page edge */
102
+ width: 220px;
103
+ pointer-events: auto;
104
+ z-index: 10;
105
+ overflow: visible;
106
+ }
107
+
108
+ .plugin-panel-in-viewport.collapsed {
109
+ width: 32px;
110
+ }
111
+
112
+ .plugin-panel-in-viewport .plugin-panel-toggle {
113
+ position: sticky;
114
+ top: 0;
115
+ background: rgba(255, 255, 255, 0.95);
116
+ border-radius: 4px;
117
+ box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
118
+ }
119
+
120
+ .plugin-panel-in-viewport-content {
121
+ overflow: visible;
122
+ position: relative;
123
+ }
124
+
125
+ /* Plugin overlay container for rendering highlights/decorations */
126
+ .plugin-overlays-container {
127
+ position: absolute;
128
+ top: 0;
129
+ left: 0;
130
+ right: 0;
131
+ bottom: 0;
132
+ pointer-events: none;
133
+ overflow: visible;
134
+ z-index: 5;
135
+ }
136
+
137
+ .plugin-overlay {
138
+ position: absolute;
139
+ top: 0;
140
+ left: 0;
141
+ right: 0;
142
+ bottom: 0;
143
+ pointer-events: none;
144
+ }
145
+
146
+ /* Individual overlay children manage their own pointer-events.
147
+ Do NOT set pointer-events: auto here \u2014 it overrides overlay containers
148
+ that need pointer-events: none to let clicks pass through to the editor. */
149
+ `,Ee=me.forwardRef(function({plugins:i,children:s,className:r=""},p){let[t,f]=me.useState(null),m=me.useRef(s.props);m.current=s.props;let[a,u]=me.useState(null),l=me.useMemo(()=>new chunkYBEVHQCT_js.s,[]),x=me.useSyncExternalStore(l.subscribe,l.getSnapshot),[T,h]=me.useState(()=>{let o=new Set;for(let e of i)({...$,...e.panelConfig}).defaultCollapsed&&o.add(e.id);return o}),[v]=me.useState(()=>{let o=new Map;for(let e of i){let d={...$,...e.panelConfig};o.set(e.id,d.defaultSize);}return o});me.useEffect(()=>{if(!t)return;let o=i.map(e=>({id:e.id,styles:e.styles,initialize:e.initialize,onStateChange:e.onStateChange,destroy:e.destroy}));return l.initialize(o,t),()=>{l.destroy();}},[l,t,i]),me.useEffect(()=>{let o=i.filter(e=>e.styles).map(e=>te(e.id,e.styles));return ()=>o.forEach(e=>e())},[i]),me.useEffect(()=>{if(!t?.dom)return;let o=()=>{l.updateStates(t);},e=null,d=()=>{e&&cancelAnimationFrame(e),e=requestAnimationFrame(o);};o();let c=t.dom;c.addEventListener("input",d),c.addEventListener("focus",o),c.addEventListener("click",o);let g=t.dispatch.bind(t);return t.dispatch=y=>{g(y),d();},()=>{c.removeEventListener("input",d),c.removeEventListener("focus",o),c.removeEventListener("click",o),e&&cancelAnimationFrame(e),t.dispatch=g;}},[t,l]),me.useEffect(()=>te("plugin-host-base",ne),[]);let R=me.useCallback(o=>{if(!t)return;if(t.coordsAtPos(o)){t.dom.scrollIntoView({block:"center",inline:"nearest"});let{state:d}=t,c=d.doc.resolve(Math.min(o,d.doc.content.size)),g=d.tr.setSelection(prosemirrorState.TextSelection.near(c));t.dispatch(g),t.focus();}},[t]),P=me.useCallback((o,e)=>{if(!t)return;let{state:d}=t,c=d.doc.content.size,g=Math.max(0,Math.min(o,c)),y=Math.max(0,Math.min(e,c)),L=d.tr.setSelection(prosemirrorState.TextSelection.create(d.doc,g,y));t.dispatch(L),t.focus();},[t]),E=me.useCallback(o=>l.getPluginState(o),[l]),K=me.useCallback((o,e)=>{l.setPluginState(o,e);},[l]),U=me.useCallback(()=>{t&&l.updateStates(t);},[t,l]);me.useImperativeHandle(p,()=>({getPluginState:E,setPluginState:K,getEditorView:()=>t,refreshPluginStates:U}),[E,K,t,U]);let W=me.useMemo(()=>{let o=[];for(let e of i)e.proseMirrorPlugins&&o.push(...e.proseMirrorPlugins);return o},[i]),_=me.useCallback(o=>{h(e=>{let d=new Set(e);return d.has(o)?d.delete(o):d.add(o),d});},[]),[A,F]=me.useState(null);me.useEffect(()=>{if(!a){F(null);return}let o=()=>{let c=a.pagesContainer,g=c.querySelector(".layout-page");if(!g){F(null);return}let y=a.getContainerOffset(),L=g.getBoundingClientRect(),Y=c.getBoundingClientRect(),G=(L.right-Y.left)/a.zoom,xe=y.x+G+5;F(xe);};o();let e=()=>{requestAnimationFrame(o);};window.addEventListener("resize",e);let d=new ResizeObserver(()=>{requestAnimationFrame(o);});return d.observe(a.pagesContainer),()=>{window.removeEventListener("resize",e),d.disconnect();}},[a]);let Z=me.useMemo(()=>{let o=[];if(a){for(let e of i)if(e.renderOverlay){let d=x.states.get(e.id);o.push(jsxRuntime.jsx("div",{className:"plugin-overlay","data-plugin-id":e.id,children:e.renderOverlay(a,d,t)},`overlay-${e.id}`));}}for(let e of i){if(!e.Panel||(e.panelConfig?.position??"right")!=="right")continue;let c={...$,...e.panelConfig},g=T.has(e.id),y=v.get(e.id)??c.defaultSize,L=e.Panel,Y=x.states.get(e.id),G=A!==null?`${A}px`:"calc(50% + 428px)";o.push(jsxRuntime.jsxs("div",{className:`plugin-panel-in-viewport ${g?"collapsed":""}`,style:{width:g?"32px":`${y}px`,left:G},"data-plugin-id":e.id,children:[c.collapsible&&jsxRuntime.jsx("button",{className:"plugin-panel-toggle",onClick:()=>_(e.id),title:g?`Show ${e.name}`:`Hide ${e.name}`,"aria-label":g?`Show ${e.name}`:`Hide ${e.name}`,children:jsxRuntime.jsx("span",{className:"plugin-panel-toggle-icon",children:g?"\u2039":"\u203A"})}),!g&&a&&jsxRuntime.jsx("div",{className:"plugin-panel-in-viewport-content",children:jsxRuntime.jsx(L,{editorView:t,doc:t?.state.doc??null,scrollToPosition:R,selectRange:P,pluginState:Y,panelWidth:y,renderedDomContext:a})})]},`panel-overlay-${e.id}`));}return o.length>0?o:null},[a,i,x.version,t,T,v,R,P,_,A]),j=me.useMemo(()=>{let o=[];for(let e of i){if(!e.getSidebarItems)continue;let d=x.states.get(e.id),c={editorView:t,renderedDomContext:a,anchorPositions:new Map,zoom:a?.zoom??1},g=e.getSidebarItems(d,c);o.push(...g);}return o},[i,x.version,t,a]),B=me.useCallback(o=>{u(o);let e=m.current?.onRenderedDomContextReady;typeof e=="function"&&e(o);},[]),be=me.useMemo(()=>me.cloneElement(s,{externalPlugins:W,pluginOverlays:Z,pluginSidebarItems:j,pluginRenderedDomContext:a,onRenderedDomContextReady:B,onEditorViewReady:o=>{f(o);let e=m.current?.onEditorViewReady;typeof e=="function"&&e(o);}}),[s,W,Z,j,a,B]),O=me.useMemo(()=>{let o=[],e=[],d=[];for(let c of i){if(!c.Panel)continue;let g=c.panelConfig?.position??"right";g==="left"?o.push(c):g==="bottom"?d.push(c):e.push(c);}return {left:o,right:e,bottom:d}},[i]),X=o=>{if(!o.Panel)return null;let e={...$,...o.panelConfig},d=T.has(o.id),c=v.get(o.id)??e.defaultSize,g=o.Panel,y=x.states.get(o.id);return jsxRuntime.jsxs("div",{className:`plugin-panel plugin-panel-${e.position} ${d?"collapsed":""}`,style:{[e.position==="bottom"?"height":"width"]:d?"32px":`${c}px`,minWidth:e.position!=="bottom"?d?"32px":`${e.minSize}px`:void 0,maxWidth:e.position!=="bottom"?`${e.maxSize}px`:void 0,minHeight:e.position==="bottom"?d?"32px":`${e.minSize}px`:void 0,maxHeight:e.position==="bottom"?`${e.maxSize}px`:void 0},"data-plugin-id":o.id,children:[e.collapsible&&jsxRuntime.jsxs("button",{className:"plugin-panel-toggle",onClick:()=>_(o.id),title:d?`Show ${o.name}`:`Hide ${o.name}`,"aria-label":d?`Show ${o.name}`:`Hide ${o.name}`,children:[jsxRuntime.jsx("span",{className:"plugin-panel-toggle-icon",children:d?"\u203A":"\u2039"}),d&&jsxRuntime.jsx("span",{className:"plugin-panel-toggle-label",children:o.name})]}),!d&&jsxRuntime.jsx("div",{className:"plugin-panel-content",children:jsxRuntime.jsx(g,{editorView:t,doc:t?.state.doc??null,scrollToPosition:R,selectRange:P,pluginState:y,panelWidth:c,renderedDomContext:a??null})})]},o.id)};return jsxRuntime.jsxs("div",{className:`plugin-host ${r}`,children:[O.left.length>0&&jsxRuntime.jsx("div",{className:"plugin-panels-left",children:O.left.map(X)}),jsxRuntime.jsxs("div",{className:"plugin-host-editor",children:[be,O.bottom.length>0&&jsxRuntime.jsx("div",{className:"plugin-panels-bottom",children:O.bottom.map(X)})]})]})});var oe=/\{([#/^@]?)([a-zA-Z_][a-zA-Z0-9_]*(?:\.[a-zA-Z_][a-zA-Z0-9_]*)*)\}/g,b=new prosemirrorState.PluginKey("template");function Ce(n,i,s){return `${n}:${i}:${s}`}function ie(n){let i=[];n.descendants((a,u)=>(a.isText&&a.text&&i.push({text:a.text,pos:u}),true));let s="",r=[];for(let a of i){for(let u=0;u<a.text.length;u++)r.push(a.pos+u);s+=a.text;}let p=[],t=[],f=new Map,m;for(oe.lastIndex=0;(m=oe.exec(s))!==null;){let[a,u,l]=m,x=r[m.index],T=r[m.index+a.length-1]+1,h;u==="#"?h="sectionStart":u==="/"?h="sectionEnd":u==="^"?h="invertedStart":u==="@"?h="raw":h="variable";let v=`${h}:${l}`,R=f.get(v)??0;f.set(v,R+1);let P={id:Ce(h,l,R),type:h,name:l,rawTag:a,from:x,to:T};if(h==="sectionStart"||h==="invertedStart")P.nestedVars=[],t.push(P);else if(h==="sectionEnd"){for(let E=t.length-1;E>=0;E--)if(t[E].name===l){t.splice(E,1);break}}else h==="variable"&&t.length>0&&(t[t.length-1].nestedVars?.push(l),P.insideSection=true);p.push(P);}return p}function Le(n){switch(n){case "sectionStart":case "sectionEnd":return "#3b82f6";case "invertedStart":return "#8b5cf6";case "raw":return "#ef4444";default:return "#f59e0b"}}function q(n,i,s,r){let p=[];for(let t of i){let f=t.id===s,m=t.id===r,a=Le(t.type),u=["docx-template-tag"];f&&u.push("hovered"),m&&u.push("selected"),p.push(prosemirrorView.Decoration.inline(t.from,t.to,{class:u.join(" "),"data-tag-id":t.id,style:`background-color: ${a}22; border-radius: 2px;`},{noOverlay:true}));}return prosemirrorView.DecorationSet.create(n,p)}function He(n,i){if(n.length!==i.length)return false;for(let s=0;s<n.length;s++)if(n[s].id!==i[s].id)return false;return true}function N(){return new prosemirrorState.Plugin({key:b,state:{init(n,i){let s=ie(i.doc);return {tags:s,decorations:q(i.doc,s)}},apply(n,i,s,r){if(n.docChanged){let t=ie(r.doc),f=He(i.tags,t);return {tags:t,decorations:f?i.decorations.map(n.mapping,n.doc):q(r.doc,t,i.hoveredId,i.selectedId),hoveredId:i.hoveredId,selectedId:i.selectedId}}let p=n.getMeta(b);if(p){let t=p.hoveredId??i.hoveredId,f=p.selectedId??i.selectedId;return {...i,hoveredId:t,selectedId:f,decorations:q(r.doc,i.tags,t,f)}}return {...i,decorations:i.decorations.map(n.mapping,n.doc)}}},props:{decorations(n){return b.getState(n)?.decorations??prosemirrorView.DecorationSet.empty},handleClick(n,i){let r=(b.getState(n.state)?.tags??[]).find(t=>i>=t.from&&i<=t.to);return r?(n.dispatch(n.state.tr.setMeta(b,{selectedId:r.id})),true):(b.getState(n.state)?.selectedId&&n.dispatch(n.state.tr.setMeta(b,{selectedId:void 0})),false)},handleDOMEvents:{mouseover(n,i){let r=i.target.closest?.("[data-tag-id]")?.getAttribute("data-tag-id")||void 0,p=b.getState(n.state)?.hoveredId;return r!==p&&n.dispatch(n.state.tr.setMeta(b,{hoveredId:r})),false},mouseout(n,i){return i.relatedTarget?.closest?.("[data-tag-id]")||b.getState(n.state)?.hoveredId&&n.dispatch(n.state.tr.setMeta(b,{hoveredId:void 0})),false}}}})}function ae(n){return b.getState(n)?.tags??[]}function z(n,i){n.dispatch(n.state.tr.setMeta(b,{hoveredId:i}));}function D(n,i){n.dispatch(n.state.tr.setMeta(b,{selectedId:i}));}var V=`
150
+ .docx-template-tag {
151
+ cursor: pointer;
152
+ transition: background-color 0.1s;
153
+ }
154
+
155
+ .docx-template-tag:hover,
156
+ .docx-template-tag.hovered {
157
+ filter: brightness(0.95);
158
+ }
159
+
160
+ .docx-template-tag.selected {
161
+ box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.5);
162
+ }
163
+ `;var Oe={variable:"rgba(245, 158, 11, 0.3)",sectionStart:"rgba(59, 130, 246, 0.3)",sectionEnd:"rgba(59, 130, 246, 0.3)",invertedStart:"rgba(139, 92, 246, 0.3)",raw:"rgba(239, 68, 68, 0.3)"},$e={variable:"rgba(245, 158, 11, 0.5)",sectionStart:"rgba(59, 130, 246, 0.5)",sectionEnd:"rgba(59, 130, 246, 0.5)",invertedStart:"rgba(139, 92, 246, 0.5)",raw:"rgba(239, 68, 68, 0.5)"};function de({context:n,tags:i,hoveredId:s,selectedId:r,onHover:p,onSelect:t}){let[f,m]=me.useState(0),a=me.useCallback(()=>{let l=n.getContainerOffset(),x=[];for(let T of i){let h=n.getRectsForRange(T.from,T.to);for(let v of h)x.push({tagId:T.id,tagType:T.type,x:v.x+l.x,y:v.y+l.y,width:v.width,height:v.height});}return x},[n,i]),u=me.useMemo(()=>a(),[a,f]);return me.useEffect(()=>{let l=()=>{requestAnimationFrame(()=>m(x=>x+1));};return window.addEventListener("resize",l),()=>window.removeEventListener("resize",l)},[]),me.useEffect(()=>{let l=new ResizeObserver(()=>{requestAnimationFrame(()=>m(x=>x+1));});return l.observe(n.pagesContainer),()=>l.disconnect()},[n.pagesContainer]),u.length===0?null:jsxRuntime.jsx("div",{className:"template-highlight-overlay",children:u.map((l,x)=>{let T=l.tagId===s,h=l.tagId===r,v=T||h?$e[l.tagType]:Oe[l.tagType];return jsxRuntime.jsx("div",{className:`template-highlight ${T?"hovered":""} ${h?"selected":""}`,style:{position:"absolute",left:l.x,top:l.y,width:l.width,height:l.height,backgroundColor:v,borderRadius:2,cursor:"pointer"},onMouseEnter:()=>p?.(l.tagId),onMouseLeave:()=>p?.(void 0),onClick:()=>t?.(l.tagId)},`${l.tagId}-${x}`)})})}var pe=`
164
+ .template-highlight-overlay {
165
+ position: absolute;
166
+ top: 0;
167
+ left: 0;
168
+ right: 0;
169
+ bottom: 0;
170
+ pointer-events: none;
171
+ overflow: visible;
172
+ }
173
+
174
+ .template-highlight {
175
+ pointer-events: auto;
176
+ transition: background-color 0.1s ease;
177
+ }
178
+
179
+ .template-highlight:hover,
180
+ .template-highlight.hovered {
181
+ filter: brightness(0.9);
182
+ }
183
+
184
+ .template-highlight.selected {
185
+ box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.6);
186
+ }
187
+ `;var Ne={variable:"#f59e0b",sectionStart:"#3b82f6",sectionEnd:"#3b82f6",invertedStart:"#8b5cf6",raw:"#ef4444"};function De(n){switch(n){case "sectionStart":return "LOOP / IF";case "invertedStart":return "IF NOT";case "raw":return "HTML";default:return ""}}var ge=`
188
+ .template-annotation-chip {
189
+ display: inline-flex;
190
+ flex-wrap: wrap;
191
+ align-items: center;
192
+ gap: 4px;
193
+ padding: 5px 10px;
194
+ background: white;
195
+ border: 1px solid #e2e8f0;
196
+ border-left: 3px solid #6c757d;
197
+ border-radius: 4px;
198
+ font-size: 11px;
199
+ cursor: pointer;
200
+ box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
201
+ max-width: 200px;
202
+ }
203
+
204
+ .template-annotation-chip:hover,
205
+ .template-annotation-chip.hovered {
206
+ box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
207
+ border-color: #cbd5e1;
208
+ }
209
+
210
+ .template-annotation-chip.selected {
211
+ box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.5);
212
+ }
213
+
214
+ .template-chip-badge {
215
+ font-size: 9px;
216
+ font-weight: 600;
217
+ padding: 1px 5px;
218
+ border-radius: 3px;
219
+ color: white;
220
+ text-transform: uppercase;
221
+ letter-spacing: 0.3px;
222
+ }
223
+
224
+ .template-chip-dot {
225
+ font-size: 8px;
226
+ }
227
+
228
+ .template-chip-name {
229
+ color: #334155;
230
+ font-weight: 500;
231
+ }
232
+
233
+ .template-chip-nested {
234
+ display: flex;
235
+ flex-wrap: wrap;
236
+ gap: 4px;
237
+ width: 100%;
238
+ margin-top: 4px;
239
+ padding-top: 4px;
240
+ border-top: 1px solid rgba(0, 0, 0, 0.06);
241
+ }
242
+
243
+ .template-nested-var {
244
+ font-size: 10px;
245
+ color: #64748b;
246
+ background: rgba(0, 0, 0, 0.04);
247
+ padding: 2px 6px;
248
+ border-radius: 3px;
249
+ }
250
+
251
+ .template-nested-var:hover {
252
+ background: rgba(59, 130, 246, 0.15);
253
+ color: #1e40af;
254
+ }
255
+ `;function ue({tag:n,isHovered:i,measureRef:s,onHover:r,onSelect:p}){let t=De(n.type),f=Ne[n.type],m=n.type==="sectionStart"||n.type==="invertedStart";return jsxRuntime.jsxs("div",{ref:s,style:{display:"flex",alignItems:"flex-start"},children:[jsxRuntime.jsx("div",{style:{width:20,height:1,background:i?"#3b82f6":"#d0d0d0",marginTop:12,marginRight:4,flexShrink:0}}),jsxRuntime.jsxs("div",{className:`template-annotation-chip ${i?"hovered":""}`,style:{borderLeftColor:f},onMouseEnter:()=>r(n.id),onMouseLeave:()=>r(void 0),onClick:a=>{a.stopPropagation(),p(n.id);},onMouseDown:a=>a.stopPropagation(),title:m?`${n.rawTag}
256
+ Iterates over ${n.name}[]. Access nested properties via ${n.name}.property`:n.rawTag,children:[t&&jsxRuntime.jsx("span",{className:"template-chip-badge",style:{background:f},children:t}),!t&&jsxRuntime.jsx("span",{className:"template-chip-dot",style:{color:f},children:"\u25CF"}),jsxRuntime.jsx("span",{className:"template-chip-name",children:n.name}),m&&n.nestedVars&&n.nestedVars.length>0&&jsxRuntime.jsx("div",{className:"template-chip-nested",children:n.nestedVars.map((a,u)=>jsxRuntime.jsx("span",{className:"template-nested-var",title:`Access: ${n.name}.${a}`,children:a.includes(".")?a.split(".").pop():a},u))})]})]})}function fe(n,i,s){if(!n)return;D(n,s);let r=i.find(p=>p.id===s);if(r){let p=n.state.tr.setSelection(prosemirrorState.TextSelection.near(n.state.doc.resolve(r.from)));n.dispatch(p),n.focus();}}function he(n={}){return {id:"template",name:"Template",proseMirrorPlugins:[N()],onStateChange:s=>{let r=b.getState(s.state);if(r)return {tags:r.tags,hoveredId:r.hoveredId,selectedId:r.selectedId}},initialize:s=>({tags:[]}),getSidebarItems:(s,r)=>!s||s.tags.length===0?[]:s.tags.filter(t=>t.type!=="sectionEnd"&&!t.insideSection).map(t=>({id:`template-${t.id}`,anchorPos:t.from,priority:10,estimatedHeight:32,render:f=>me__default.default.createElement(ue,{...f,tag:t,isHovered:t.id===s.hoveredId,onHover:m=>{r.editorView&&z(r.editorView,m);},onSelect:m=>fe(r.editorView,s.tags,m)})})),renderOverlay:(s,r,p)=>!r||r.tags.length===0?null:me__default.default.createElement(de,{context:s,tags:r.tags,hoveredId:r.hoveredId,selectedId:r.selectedId,onHover:t=>{p&&z(p,t);},onSelect:t=>fe(p,r.tags,t)}),styles:`
257
+ ${V}
258
+ ${ge}
259
+ ${pe}
260
+ `}}var _e=he();exports.a=ne;exports.b=Ee;exports.c=b;exports.d=N;exports.e=ae;exports.f=z;exports.g=D;exports.h=V;exports.i=he;exports.j=_e;