likec4 1.56.0 → 1.57.0

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 (154) hide show
  1. package/__app__/chunks/AIChat2.mjs +2 -0
  2. package/__app__/chunks/DiagramActorProvider.mjs +4 -4
  3. package/__app__/chunks/EmbedPage.mjs +1 -0
  4. package/__app__/chunks/ExportPage.mjs +2 -0
  5. package/__app__/chunks/LikeC4Diagram.mjs +5 -5
  6. package/__app__/chunks/LikeC4Styles.mjs +11 -11
  7. package/__app__/chunks/Markdown.mjs +1 -0
  8. package/__app__/chunks/NavigationPanel.mjs +1 -1
  9. package/__app__/chunks/ViewReact.mjs +1 -1
  10. package/__app__/chunks/adhoc-editor.mjs +1 -1
  11. package/__app__/chunks/aichat.mjs +1 -0
  12. package/__app__/chunks/box.mjs +1 -0
  13. package/__app__/chunks/create-style-context.mjs +1 -0
  14. package/__app__/chunks/css.mjs +1 -0
  15. package/__app__/chunks/factory.mjs +1 -0
  16. package/__app__/chunks/hooks.mjs +1 -1
  17. package/__app__/chunks/hstack.mjs +1 -0
  18. package/__app__/chunks/libs/@dagrejs/dagre.mjs +1 -1
  19. package/__app__/chunks/libs/@floating-ui/core.mjs +1 -1
  20. package/__app__/chunks/libs/@floating-ui/dom.mjs +1 -1
  21. package/__app__/chunks/libs/@floating-ui/react.mjs +1 -1
  22. package/__app__/chunks/libs/@mantine/core.mjs +24 -24
  23. package/__app__/chunks/libs/@mantine/hooks.mjs +1 -1
  24. package/__app__/chunks/libs/@nanostores/react.mjs +1 -1
  25. package/__app__/chunks/libs/@react-hookz/web.mjs +1 -1
  26. package/__app__/chunks/libs/@tabler/icons-react.mjs +347 -4
  27. package/__app__/chunks/libs/@tanstack/ai-client.mjs +2 -0
  28. package/__app__/chunks/libs/@tanstack/ai-react-ui.mjs +1 -0
  29. package/__app__/chunks/libs/@tanstack/ai-react.mjs +1 -0
  30. package/__app__/chunks/libs/@tanstack/ai.mjs +2 -0
  31. package/__app__/chunks/libs/@tanstack/history.mjs +1 -1
  32. package/__app__/chunks/libs/@tanstack/react-router.mjs +3 -3
  33. package/__app__/chunks/libs/@tanstack/router-core.mjs +1 -1
  34. package/__app__/chunks/libs/@xstate/react.mjs +1 -1
  35. package/__app__/chunks/libs/@xstate/store.mjs +1 -1
  36. package/__app__/chunks/libs/@xyflow/react.mjs +3 -3
  37. package/__app__/chunks/libs/@zag-js/anatomy.mjs +1 -1
  38. package/__app__/chunks/libs/@zag-js/collection.mjs +1 -1
  39. package/__app__/chunks/libs/@zag-js/core.mjs +1 -1
  40. package/__app__/chunks/libs/@zag-js/react.mjs +1 -1
  41. package/__app__/chunks/libs/@zag-js/tree-view.mjs +1 -1
  42. package/__app__/chunks/libs/bezier-js.mjs +1 -1
  43. package/__app__/chunks/libs/copy-anything.mjs +1 -0
  44. package/__app__/chunks/libs/d3-path.mjs +1 -1
  45. package/__app__/chunks/libs/d3-shape.mjs +1 -1
  46. package/__app__/chunks/libs/fast-equals.mjs +1 -1
  47. package/__app__/chunks/libs/framer-motion.mjs +3 -3
  48. package/__app__/chunks/libs/html-to-image.mjs +2 -2
  49. package/__app__/chunks/libs/motion-dom.mjs +1 -1
  50. package/__app__/chunks/libs/nanostores.mjs +1 -1
  51. package/__app__/chunks/libs/react-error-boundary.mjs +1 -1
  52. package/__app__/chunks/libs/react-resizable-panels.mjs +1 -1
  53. package/__app__/chunks/libs/remeda.mjs +1 -1
  54. package/__app__/chunks/libs/superjson.mjs +1 -0
  55. package/__app__/chunks/libs/zod.mjs +39 -14
  56. package/__app__/chunks/rolldown-runtime.mjs +1 -1
  57. package/__app__/chunks/styles.css.mjs +1 -1
  58. package/__app__/chunks/txt.mjs +1 -0
  59. package/__app__/chunks/useLikeC4Project.mjs +1 -1
  60. package/__app__/codegen/webcomponent.mjs +221 -69
  61. package/__app__/src/aichat/index.mjs +1 -0
  62. package/__app__/src/main.mjs +45 -1
  63. package/__app__/src/pages/AdHocViewEditor.mjs +1 -1
  64. package/__app__/src/pages/EmbedPage.mjs +1 -1
  65. package/__app__/src/pages/ExportPage.mjs +1 -1
  66. package/__app__/src/pages/ProjectsOverview.mjs +1 -1
  67. package/__app__/src/pages/ViewAsD2.mjs +1 -1
  68. package/__app__/src/pages/ViewAsDot.mjs +1 -1
  69. package/__app__/src/pages/ViewAsMmd.mjs +1 -1
  70. package/__app__/src/pages/ViewAsPuml.mjs +1 -1
  71. package/__app__/src/pages/ViewEditor.mjs +1 -1
  72. package/__app__/src/style.css +1 -1
  73. package/config/schema.json +14 -41
  74. package/dist/chunks/enableServer.mjs +1 -0
  75. package/dist/chunks/index2.d.mts +569 -377
  76. package/dist/chunks/libs/@hono/mcp.mjs +33 -8
  77. package/dist/chunks/libs/@hono/node-server.mjs +1 -1
  78. package/dist/chunks/libs/@modelcontextprotocol/sdk.mjs +7 -7
  79. package/dist/chunks/libs/@ts-graphviz/ast.mjs +3 -0
  80. package/dist/chunks/libs/@ts-graphviz/common.d.mts +9 -0
  81. package/dist/chunks/libs/@ts-graphviz/core.mjs +1 -0
  82. package/dist/chunks/libs/ajv.mjs +1 -1
  83. package/dist/chunks/libs/ansi-styles.mjs +1 -1
  84. package/dist/chunks/libs/boxen.mjs +2 -2
  85. package/dist/chunks/libs/chevrotain.mjs +2 -2
  86. package/dist/chunks/libs/conf.mjs +1 -1
  87. package/dist/chunks/libs/langium.d.mts +5 -5
  88. package/dist/chunks/libs/langium.mjs +10 -10
  89. package/dist/chunks/libs/merge-error-cause.mjs +1 -1
  90. package/dist/chunks/libs/pako.mjs +3 -1
  91. package/dist/chunks/libs/remeda.mjs +1 -1
  92. package/dist/chunks/libs/ts-graphviz.mjs +1 -4
  93. package/dist/chunks/libs/unctx.mjs +1 -0
  94. package/dist/chunks/libs/vscode-languageserver.mjs +1 -1
  95. package/dist/chunks/libs/zod.d.mts +60 -25
  96. package/dist/chunks/node.mjs +62 -45
  97. package/dist/chunks/plugin.mjs +234 -41
  98. package/dist/chunks/sequence-view.mjs +1 -1
  99. package/dist/cli/index.mjs +142 -139
  100. package/dist/index.d.mts +1 -130
  101. package/dist/model/index.d.mts +1 -1
  102. package/dist/vite-plugin/index.d.mts +53 -2
  103. package/dist/vite-plugin/internal/index.d.mts +331 -3
  104. package/dist/vite-plugin/internal/index.mjs +1 -1
  105. package/package.json +65 -51
  106. package/react/index.d.mts +82 -50
  107. package/react/index.mjs +34017 -32421
  108. package/vite-plugin-modules.d.ts +4 -0
  109. package/__app__/chunks/ColorSchemeToggle.mjs +0 -1
  110. package/__app__/chunks/Fallback.mjs +0 -1
  111. package/__app__/chunks/Header.mjs +0 -13
  112. package/__app__/chunks/IconRenderer.mjs +0 -1
  113. package/__app__/chunks/LikeC4ModelContext.mjs +0 -1
  114. package/__app__/chunks/LikeC4ModelContext2.mjs +0 -1
  115. package/__app__/chunks/StaticLikeC4Diagram.mjs +0 -1
  116. package/__app__/chunks/__root.mjs +0 -1
  117. package/__app__/chunks/libs/motion.mjs +0 -1
  118. package/__app__/chunks/libs/xstate.mjs +0 -1
  119. package/__app__/chunks/safeCtx.mjs +0 -1
  120. package/__app__/chunks/searchParams.mjs +0 -1
  121. package/__app__/chunks/single-index.mjs +0 -1
  122. package/__app__/chunks/styled-system.mjs +0 -1
  123. package/__app__/chunks/useUpdateEffect.mjs +0 -1
  124. package/__app__/src/routeTree.gen.mjs +0 -1
  125. package/__app__/src/routes/__root.mjs +0 -1
  126. package/__app__/src/routes/_single/adhoc.mjs +0 -1
  127. package/__app__/src/routes/_single/embed._viewId.mjs +0 -1
  128. package/__app__/src/routes/_single/export._viewId.mjs +0 -1
  129. package/__app__/src/routes/_single/route.mjs +0 -1
  130. package/__app__/src/routes/_single/single-index.mjs +0 -1
  131. package/__app__/src/routes/_single/view._viewId.d2.mjs +0 -1
  132. package/__app__/src/routes/_single/view._viewId.dot.mjs +0 -1
  133. package/__app__/src/routes/_single/view._viewId.index.mjs +0 -1
  134. package/__app__/src/routes/_single/view._viewId.mjs +0 -1
  135. package/__app__/src/routes/_single/view._viewId.mmd.mjs +0 -1
  136. package/__app__/src/routes/_single/view._viewId.puml.mjs +0 -1
  137. package/__app__/src/routes/_single/webcomponent._.mjs +0 -33
  138. package/__app__/src/routes/index.mjs +0 -1
  139. package/__app__/src/routes/project._projectId/-components.mjs +0 -1
  140. package/__app__/src/routes/project._projectId/adhoc.mjs +0 -1
  141. package/__app__/src/routes/project._projectId/embed._viewId.mjs +0 -1
  142. package/__app__/src/routes/project._projectId/export._viewId.mjs +0 -1
  143. package/__app__/src/routes/project._projectId/index.mjs +0 -1
  144. package/__app__/src/routes/project._projectId/route.mjs +0 -1
  145. package/__app__/src/routes/project._projectId/view._viewId.d2.mjs +0 -1
  146. package/__app__/src/routes/project._projectId/view._viewId.dot.mjs +0 -1
  147. package/__app__/src/routes/project._projectId/view._viewId.index.mjs +0 -1
  148. package/__app__/src/routes/project._projectId/view._viewId.mjs +0 -1
  149. package/__app__/src/routes/project._projectId/view._viewId.mmd.mjs +0 -1
  150. package/__app__/src/routes/project._projectId/view._viewId.puml.mjs +0 -1
  151. package/__app__/src/routes/projects.mjs +0 -1
  152. package/dist/chunks/libs/ts-graphviz.d.mts +0 -12
  153. package/dist/vite-plugin/internal/chunks/libs/@nanostores/react.d.mts +0 -269
  154. package/dist/vite-plugin/internal/chunks/libs/nanostores.d.mts +0 -59
@@ -178,6 +178,10 @@ declare module 'likec4:rpc' {
178
178
  export const likec4rpc: LikeC4VitePluginRpc
179
179
 
180
180
  export const isRpcAvailable: boolean
181
+
182
+ export const isAIAvailable: boolean
183
+
184
+ export const AIAdapter: string | undefined
181
185
  }
182
186
 
183
187
  declare module 'likec4:app-config' {
@@ -1 +0,0 @@
1
- import"./rolldown-runtime.mjs";import{l as e,u as t}from"./libs/@tanstack/react-router.mjs";import{Dt as n,Ot as r,dt as i}from"./libs/@mantine/core.mjs";import{S as a,m as o}from"./libs/@tabler/icons-react.mjs";import{t as s}from"./searchParams.mjs";import{useEffect as c,useRef as l}from"react";import{c as u}from"react/compiler-runtime";import{jsx as d,jsxs as f}from"react/jsx-runtime";function ColorSchemeToggle(){let p=u(21),m;p[0]===Symbol.for(`react.memo_cache_sentinel`)?(m={keepTransitions:!0},p[0]=m):m=p[0];let{setColorScheme:h}=r(m),g=n(`light`),_=e(),v;p[1]===Symbol.for(`react.memo_cache_sentinel`)?(v={from:`__root__`},p[1]=v):v=p[1];let{theme:y}=t(v),b;p[2]===y?b=p[3]:(b=s(y),p[2]=y,p[3]=b);let x=b!=null,S=l(null),t3,C;p[4]!==x||p[5]!==h?(t3=()=>{S.current!=null&&!x&&(h(S.current),S.current=null)},C=[x,h],p[4]=x,p[5]=h,p[6]=t3,p[7]=C):(t3=p[6],C=p[7]),c(t3,C);let t5;p[8]!==g||p[9]!==x||p[10]!==_||p[11]!==h?(t5=()=>{if(S.current!=null)return;let e=g===`light`?`dark`:`light`;x?(S.current=e,_({to:`../`,search:_temp,replace:!0}).catch(()=>{S.current=null})):h(e)},p[8]=g,p[9]=x,p[10]=_,p[11]=h,p[12]=t5):t5=p[12];let w=t5,T=g===`light`?`block`:`none`,E;p[13]===T?E=p[14]:(E=d(a,{stroke:1.5,display:T}),p[13]=T,p[14]=E);let D=g===`dark`?`block`:`none`,O;p[15]===D?O=p[16]:(O=d(o,{stroke:1.5,display:D}),p[15]=D,p[16]=O);let k;return p[17]!==E||p[18]!==O||p[19]!==w?(k=f(i,{size:`md`,variant:`subtle`,color:`gray`,onClick:w,"aria-label":`Toggle color scheme`,children:[E,O]}),p[17]=E,p[18]=O,p[19]=w,p[20]=k):k=p[20],k}function _temp(e){return{...e,theme:void 0}}export{ColorSchemeToggle as t};
@@ -1 +0,0 @@
1
- import"./rolldown-runtime.mjs";import{_ as e,d as t,f as n}from"./libs/@tanstack/react-router.mjs";import{E as r,N as i,O as a}from"./libs/remeda.mjs";import{B as o,H as s,W as c,it as l,lt as u,rt as d}from"./libs/@mantine/core.mjs";import{jsx as f,jsxs as p}from"react/jsx-runtime";function Fallback({error:m,resetErrorBoundary:h}){let g=n(),_=t({strict:!1});if(e(m))return f(o,{my:`md`,children:p(l,{variant:`light`,color:`orange`,children:[p(d,{c:`orange`,fz:`md`,children:[`The diagram`,` `,f(s,{color:`orange`,children:_.viewId??`unknown`}),` `,`does not exist or contains errors`]}),f(c,{onClick:()=>{h(),g.navigate({to:`/`})},variant:`light`,color:`orange`,mt:`lg`,size:`xs`,children:`Go to overview`})]})});let v=m,y=`Unknown error`;try{switch(!0){case a(v):y=`Unknown error`;break;case i(v):y=v.stack??v.message;break;case typeof v==`string`:y=v;break;case r(v):y=v.stack??v.message??`${v}`;break;default:y=`${v}`;break}}catch(e){y=`${e}`}return f(o,{my:`md`,children:p(l,{variant:`filled`,color:`red`,title:`Something went wrong`,children:[f(s,{block:!0,color:`red`,children:y}),p(u,{mt:`lg`,children:[f(c,{onClick:()=>{g.invalidate().finally(()=>{h()})},color:`red`,variant:`white`,size:`xs`,children:`Try again`}),f(c,{onClick:()=>{h(),g.navigate({to:`/`})},color:`red`,size:`xs`,children:`Go to overview`})]})]})})}export{Fallback as t};
@@ -1,13 +0,0 @@
1
- import{i as e}from"./rolldown-runtime.mjs";import{f as t,i as n,r}from"./libs/@tanstack/react-router.mjs";import{C as i,Ct as a,D as o,E as s,Et as c,H as l,Mt as u,O as d,Ot as f,R as p,S as m,T as h,Vt as g,W as _,a as v,b as y,c as b,dt as x,it as S,k as C,l as w,lt as T,o as E,p as D,qt as O,rt as k,s as A,w as j,x as M,z as N}from"./libs/@mantine/core.mjs";import{D as P,k as F,t as I}from"./styled-system.mjs";import{K as L,U as R,X as z,Y as B,g as V,nt as H}from"./libs/@tabler/icons-react.mjs";import{P as U,dr as ee}from"./libs/framer-motion.mjs";import{r as W}from"./useLikeC4Project.mjs";import{t as te}from"./ColorSchemeToggle.mjs";import{n as ne,r as re,t as G}from"./hooks.mjs";import{memo as ie,useCallback as ae,useState as K}from"react";import{c as q}from"react/compiler-runtime";import{Fragment as J,jsx as Y,jsxs as X}from"react/jsx-runtime";import{ComponentName as Z,useHashHistory as oe}from"likec4:app-config";const{withProvider:se,withContext:Q}=P(I),shouldForwardProp=(e,t)=>!t.includes(e)&&(ee(e)||!F(e)),$={Root:se(U,`root`,{shouldForwardProp}),Body:Q(U,`body`,{shouldForwardProp}),Label:Q(U,`label`,{shouldForwardProp}),Dropdown:Q(U,`dropdown`,{shouldForwardProp})};function SelectProject(){let e=q(12),t=W(),n=G();if(t.length<2)return null;let r;e[0]===Symbol.for(`react.memo_cache_sentinel`)?(r=Y(B,{opacity:.5,size:14}),e[0]=r):r=e[0];let i=n.title??n.id,a;e[1]===i?a=e[2]:(a=Y(h,{children:Y(_,{variant:`subtle`,size:`sm`,color:`gray`,px:`sm`,rightSection:r,visibleFrom:`md`,children:i})}),e[1]=i,e[2]=a);let s,c;e[3]===Symbol.for(`react.memo_cache_sentinel`)?(s=Y(o,{renderRoot:_temp$1,children:`Projects overview`}),c=Y(C,{}),e[3]=s,e[4]=c):(s=e[3],c=e[4]);let l;e[5]===t?l=e[6]:(l=t.map(_temp2),e[5]=t,e[6]=l);let u;e[7]===l?u=e[8]:(u=X(d,{children:[s,c,l]}),e[7]=l,e[8]=u);let f;return e[9]!==a||e[10]!==u?(f=X(j,{shadow:`md`,width:200,trigger:`click-hover`,openDelay:200,children:[a,u]}),e[9]=a,e[10]=u,e[11]=f):f=e[11],f}function _temp2(e){let{id:t,title:n}=e;return Y(o,{renderRoot:e=>Y(r,{...e,to:`/project/$projectId/view/$viewId/`,params:{projectId:t,viewId:`index`}}),children:n??t},t)}function _temp$1(e){return Y(r,{...e,to:`/projects`})}e(_temp$1,`_temp`);const AlertLocalhost=()=>{let e=q(2),t;e[0]===Symbol.for(`react.memo_cache_sentinel`)?(t=Y(H,{}),e[0]=t):t=e[0];let n;return e[1]===Symbol.for(`react.memo_cache_sentinel`)?(n=Y(S,{color:`yellow`,icon:t,title:`Localhost URL`,styles:{body:{gap:O(4)}},children:Y(k,{c:`yellow`,size:`sm`,children:`You need to deploy your project to make it available on the internet`})}),e[1]=n):n=e[1],n},CopyButtonChild=e=>{let t=q(7),{copied:n,copy:r}=e,i=n?`teal`:`gray`,a;t[0]===n?a=t[1]:(a=Y(n?z:L,{style:{width:O(16)}}),t[0]=n,t[1]=a);let o=n?`Copied`:`Copy to clipboard`,s;return t[2]!==r||t[3]!==i||t[4]!==a||t[5]!==o?(s=Y(_,{size:`xs`,color:i,variant:`light`,leftSection:a,onClick:r,children:o}),t[2]=r,t[3]=i,t[4]=a,t[5]=o,t[6]=s):s=t[6],s},EmbedPanel=({diagram:e})=>{let n=t(),{colorScheme:r}=f(),[i,o]=K(r),s=n.buildLocation({to:`/embed/$viewId/`,params:{viewId:e.id},search:{padding:20,...i===`auto`?{}:{theme:i}}}).href;s=oe?`#${s}`:s;let c=new URL(s,window.location.href),u=e.bounds.width+40,d=e.bounds.height+40,p=c.href,m=`
2
- <div style="aspect-ratio:${u}/${d};width:100%;height:auto;max-width:${u}px;margin:0 auto">
3
- <iframe src="${p}" width="100%" height="100%" style="border:0;background:transparent;"></iframe>
4
- </div>
5
- `.trim();return X(w,{children:[m.includes(`http://localhost`)&&Y(AlertLocalhost,{}),Y(a,{children:Y(k,{size:`sm`,children:`Embedded view is an iframe with a static diagram`})}),X(w,{gap:`xs`,children:[X(T,{justify:`space-between`,children:[Y(a,{children:Y(k,{fw:`500`,size:`sm`,children:`HTML`})}),X(T,{gap:`xs`,children:[Y(x,{component:`a`,href:p,target:`_blank`,variant:`light`,color:`gray`,children:Y(R,{})}),Y(N,{value:m,timeout:1500,children:CopyButtonChild})]})]}),Y(l,{block:!0,children:m}),Y(a,{style:{alignSelf:`flex-start`},children:Y(D,{label:`Color scheme`,value:i,allowDeselect:!1,onChange:e=>o(e??`auto`),data:[{value:`auto`,label:`Auto`},{value:`light`,label:`Light`},{value:`dark`,label:`Dark`}]})})]})]})};function WebcomponentsPanel(e){let n=q(48),{diagram:r}=e,i=t(),o;n[0]===i.basepath?o=n[1]:(o=i.basepath.endsWith(`/`)?i.basepath:`${i.basepath}/`,n[0]=i.basepath,n[1]=o);let s=`${o}likec4-views.js`,c;n[2]===s?c=n[3]:(c=new URL(s,window.location.href),n[2]=s,n[3]=c);let u=c.href,d,f,p,m,h;if(n[4]!==r.id||n[5]!==u||n[6]!==i){p=`
6
- <script module src="${u}"><\/script>
7
- `.trim();let e=`
8
- <${Z.View}
9
- view-id="${encodeURIComponent(r.id)}"
10
- browser="true"
11
- dynamic-variant="sequence">
12
- </${Z.View}>
13
- `,t;n[12]===e?t=n[13]:(t=e.trim(),n[12]=e,n[13]=t),f=t;let a;n[14]!==r.id||n[15]!==i?(a=i.buildLocation(import.meta.env.DEV?{to:`/webcomponent/$/`,params:{_splat:`/`},hash:r.id,search:!0}:{to:`/webcomponent/$/`,params:{_splat:r.id},search:!0}),n[14]=r.id,n[15]=i,n[16]=a):a=n[16],h=a,d=w,m=p.includes(`http://localhost`)&&Y(AlertLocalhost,{}),n[4]=r.id,n[5]=u,n[6]=i,n[7]=d,n[8]=f,n[9]=p,n[10]=m,n[11]=h}else d=n[7],f=n[8],p=n[9],m=n[10],h=n[11];let g;n[17]===Symbol.for(`react.memo_cache_sentinel`)?(g=Y(a,{children:Y(k,{size:`sm`,children:`Add this script to your page:`})}),n[17]=g):g=n[17];let _;n[18]===Symbol.for(`react.memo_cache_sentinel`)?(_=Y(a,{children:Y(k,{fw:`500`,size:`sm`,children:`JavaScript`})}),n[18]=_):_=n[18];let v;n[19]===Symbol.for(`react.memo_cache_sentinel`)?(v=Y(R,{}),n[19]=v):v=n[19];let y;n[20]===h.href?y=n[21]:(y=Y(x,{component:`a`,href:h.href,target:`_blank`,variant:`light`,color:`gray`,children:v}),n[20]=h.href,n[21]=y);let b;n[22]===p?b=n[23]:(b=Y(N,{value:p,timeout:1500,children:CopyButtonChild}),n[22]=p,n[23]=b);let S;n[24]!==y||n[25]!==b?(S=X(T,{justify:`space-between`,children:[_,X(T,{gap:`xs`,children:[y,b]})]}),n[24]=y,n[25]=b,n[26]=S):S=n[26];let C;n[27]===p?C=n[28]:(C=Y(l,{block:!0,children:p}),n[27]=p,n[28]=C);let E;n[29]===Symbol.for(`react.memo_cache_sentinel`)?(E=Y(`br`,{}),n[29]=E):E=n[29];let D;n[30]===Symbol.for(`react.memo_cache_sentinel`)?(D=Y(`code`,{children:`<head>`}),n[30]=D):D=n[30];let O;n[31]===Symbol.for(`react.memo_cache_sentinel`)?(O=Y(a,{children:X(k,{size:`sm`,c:`dimmed`,children:[`This script defines a custom element (webcomponent) that renders your diagrams.`,E,`Script must be inserted once in the `,D,` or at the end of the `,Y(`code`,{children:`<body>`}),` `,`tag.`]})}),n[31]=O):O=n[31];let A;n[32]!==S||n[33]!==C?(A=X(w,{gap:`xs`,children:[S,C,O]}),n[32]=S,n[33]=C,n[34]=A):A=n[34];let j;n[35]===Symbol.for(`react.memo_cache_sentinel`)?(j=Y(a,{children:Y(k,{fw:`500`,size:`sm`,children:`HTML`})}),n[35]=j):j=n[35];let M,P;n[36]===f?(M=n[37],P=n[38]):(M=X(T,{justify:`space-between`,children:[j,Y(a,{children:Y(N,{value:f,timeout:1500,children:CopyButtonChild})})]}),P=Y(l,{block:!0,children:f}),n[36]=f,n[37]=M,n[38]=P);let F;n[39]===Symbol.for(`react.memo_cache_sentinel`)?(F=Y(a,{children:X(k,{size:`sm`,c:`dimmed`,children:[`Insert this code to your page. Page may have multiple `,Y(`code`,{children:`<likec4-view>`}),`.`]})}),n[39]=F):F=n[39];let I;n[40]!==M||n[41]!==P?(I=X(w,{gap:`xs`,children:[M,P,F]}),n[40]=M,n[41]=P,n[42]=I):I=n[42];let L;return n[43]!==d||n[44]!==A||n[45]!==I||n[46]!==m?(L=X(d,{children:[m,g,A,I]}),n[43]=d,n[44]=A,n[45]=I,n[46]=m,n[47]=L):L=n[47],L}function ShareModal(e){let t=q(19),{onClose:n}=e,[r]=ne(),[a,o]=K(`webcomponent`);if(!r)return null;let s;t[0]===Symbol.for(`react.memo_cache_sentinel`)?(s=Y(M,{backgroundOpacity:.5,blur:3}),t[0]=s):s=t[0];let t2;t[1]===Symbol.for(`react.memo_cache_sentinel`)?(t2=e=>o(e??`webcomponent`),t[1]=t2):t2=t[1];let c;t[2]===Symbol.for(`react.memo_cache_sentinel`)?(c=X(b,{children:[Y(E,{value:`webcomponent`,children:`Webcomponent`}),Y(E,{value:`embed`,children:`Embedded`})]}),t[2]=c):c=t[2];let l;t[3]===r?l=t[4]:(l=Y(A,{value:`embed`,pt:`md`,children:Y(EmbedPanel,{diagram:r})}),t[3]=r,t[4]=l);let u;t[5]===r?u=t[6]:(u=Y(A,{value:`webcomponent`,pt:`md`,children:Y(WebcomponentsPanel,{diagram:r})}),t[5]=r,t[6]=u);let d;t[7]!==a||t[8]!==l||t[9]!==u?(d=X(v,{value:a,onChange:t2,children:[c,l,u]}),t[7]=a,t[8]=l,t[9]=u,t[10]=d):d=t[10];let f;t[11]===n?f=t[12]:(f=Y(T,{justify:`flex-end`,mt:`lg`,children:Y(_,{size:`sm`,onClick:n,children:`Close`})}),t[11]=n,t[12]=f);let p;t[13]!==d||t[14]!==f?(p=Y(m,{children:X(i,{children:[d,f]})}),t[13]=d,t[14]=f,t[15]=p):p=t[15];let h;return t[16]!==n||t[17]!==p?(h=X(y,{size:`xl`,opened:!0,onClose:n,children:[s,p]}),t[16]=n,t[17]=p,t[18]=h):h=t[18],h}const ce=ie(()=>{let e=q(16),t=W(),i;e[0]===Symbol.for(`react.memo_cache_sentinel`)?(i={select(e){return e.some(_temp)}},e[0]=i):i=e[0];let a=n(i),{breakpoints:o}=c(),s=g(`(min-width: ${o.md})`)??!1,[l,d]=u(!1),{open:f,close:m}=d,h;e[1]!==a||e[2]!==s||e[3]!==f||e[4]!==t?(h=a?X(J,{children:[Y(SelectProject,{}),t.length<=1&&Y(_,{size:s?`sm`:`xs`,leftSection:Y(V,{size:14}),onClick:f,children:`Share`}),Y(ExportButton,{})]}):Y(_,{component:r,to:`../`,size:s?`sm`:`xs`,variant:`subtle`,color:`gray`,children:`Back to diagram`}),e[1]=a,e[2]=s,e[3]=f,e[4]=t,e[5]=h):h=e[5];let v,y;e[6]===Symbol.for(`react.memo_cache_sentinel`)?(v=Y(p,{orientation:`vertical`,visibleFrom:`md`}),y=Y(te,{}),e[6]=v,e[7]=y):(v=e[6],y=e[7]);let b;e[8]===h?b=e[9]:(b=Y($.Root,{panelPosition:`right`,hideBelow:`md`,children:X($.Body,{gap:`2`,children:[h,v,y]})}),e[8]=h,e[9]=b);let x;e[10]!==m||e[11]!==l?(x=l&&Y(ShareModal,{onClose:m}),e[10]=m,e[11]=l,e[12]=x):x=e[12];let S;return e[13]!==b||e[14]!==x?(S=X(J,{children:[b,x]}),e[13]=b,e[14]=x,e[15]=S):S=e[15],S}),enableDownload=e=>({...e,download:!0}),enableJpegDownload=e=>({...e,download:!0,format:`jpeg`});function ExportButton(){let e=n({select:e=>e.some(({routeId:e})=>e===`/project/$projectId`)}),[t,i]=K(!1),a=G(),c=re(),l=ae(async()=>{try{i(!0);let{loadDrawioSources:e}=await import(`likec4:drawio`),{drawioEditUrl:t}=await e(a.id),n=t(c);window.open(n,`_blank`,`noopener,noreferrer`)}catch(e){console.error(`Failed to export to Draw.io:`,e)}finally{i(!1)}},[a.id,c]);return X(j,{shadow:`md`,width:200,trigger:`click-hover`,openDelay:200,children:[Y(h,{children:Y(_,{variant:`subtle`,size:`sm`,color:`gray`,px:`sm`,rightSection:Y(B,{opacity:.5,size:14}),visibleFrom:`md`,children:`Export`})}),X(d,{children:[Y(s,{children:`Current view`}),Y(o,{renderRoot:t=>Y(r,{target:`_blank`,to:e?`/project/$projectId/export/$viewId/`:`/export/$viewId/`,search:enableDownload,...t}),children:`Export as .png`}),Y(o,{renderRoot:t=>Y(r,{target:`_blank`,to:e?`/project/$projectId/export/$viewId/`:`/export/$viewId/`,search:enableJpegDownload,...t}),children:`Export as .jpg`}),Y(o,{renderRoot:t=>Y(r,{to:e?`/project/$projectId/view/$viewId/dot/`:`/view/$viewId/dot/`,search:!0,...t}),children:`Export as .dot`}),Y(o,{renderRoot:t=>Y(r,{to:e?`/project/$projectId/view/$viewId/d2`:`/view/$viewId/d2`,search:!0,...t}),children:`Export as .d2`}),Y(o,{renderRoot:t=>Y(r,{to:e?`/project/$projectId/view/$viewId/mmd`:`/view/$viewId/mmd`,search:!0,...t}),children:`Export as .mmd`}),Y(o,{renderRoot:t=>Y(r,{to:e?`/project/$projectId/view/$viewId/puml`:`/view/$viewId/puml`,search:!0,...t}),children:`Export as .puml`}),Y(o,{disabled:t,onClick:l,children:`Export to Draw.io`}),Y(o,{disabled:!0,children:`Export to Miro`}),Y(o,{disabled:!0,children:`Export to Notion`})]})]})}function _temp(e){let{routeId:t}=e;return t===`/_single/view/$viewId/`||t===`/project/$projectId/view/$viewId/`}export{ce as t};
@@ -1 +0,0 @@
1
- import"./rolldown-runtime.mjs";import{M as e}from"./styled-system.mjs";import{B as t,G as n,W as r,Z as i,b as a,u as o,x as s}from"./libs/@tabler/icons-react.mjs";import{createContext as c,useContext as l}from"react";import{c as u}from"react/compiler-runtime";import{Fragment as d,jsx as f}from"react/jsx-runtime";const p=c(null);function IconRendererProvider(e){let t=u(5),{value:n,children:r}=e;if(l(p)){let e;return t[0]===r?e=t[1]:(e=f(d,{children:r}),t[0]=r,t[1]=e),e}let i;return t[2]!==r||t[3]!==n?(i=f(p.Provider,{value:n,children:r}),t[2]=r,t[3]=n,t[4]=i):i=t[4],i}function decodeSvgDataUrl(e){if(!e.startsWith(`data:image/svg+xml`))return null;try{if(e.includes(`;base64,`)){let t=e.split(`;base64,`)[1];if(t)return atob(t)}else{let t=e.split(`,`)[1];if(t)return decodeURIComponent(t)}}catch{}return null}function IconRenderer(t){let n=u(18),{element:r,className:i,style:a}=t,o=l(p);if(!r||!r.icon||r.icon===`none`)return null;let s;if(r.icon.startsWith(`http://`)||r.icon.startsWith(`https://`)||r.icon.startsWith(`data:image`)){let e;n[0]===r.icon?e=n[1]:(e=r.icon.startsWith(`data:image/svg+xml`)?decodeSvgDataUrl(r.icon):null,n[0]=r.icon,n[1]=e);let t=e;if(t){let e;n[2]===Symbol.for(`react.memo_cache_sentinel`)?(e={display:`contents`},n[2]=e):e=n[2];let r;n[3]===t?r=n[4]:(r=f(`span`,{style:e,dangerouslySetInnerHTML:{__html:t}}),n[3]=t,n[4]=r),s=r}else{let e;n[5]!==r.icon||n[6]!==r.title?(e=f(`img`,{src:r.icon,alt:r.title}),n[5]=r.icon,n[6]=r.title,n[7]=e):e=n[7],s=e}}else if(o){let e;n[8]!==o||n[9]!==r?(e=f(o,{node:r}),n[8]=o,n[9]=r,n[10]=e):e=n[10],s=e}if(!s)return null;let c;n[11]===i?c=n[12]:(c=e(i,`likec4-element-icon`),n[11]=i,n[12]=c);let d;return n[13]!==r.icon||n[14]!==s||n[15]!==a||n[16]!==c?(d=f(`div`,{className:c,"data-likec4-icon":r.icon,style:a,children:s}),n[13]=r.icon,n[14]=s,n[15]=a,n[16]=c,n[17]=d):d=n[17],d}const m={browser:i,cylinder:n,mobile:r,person:o,queue:a,rectangle:s,storage:n,bucket:n,document:t,component:s};function IconOrShapeRenderer(t){let n=u(12),{element:r,className:i,style:a}=t;if(!r.icon||r.icon===`none`){let t=m[r.shape],o;n[0]===i?o=n[1]:(o=e(i,`likec4-shape-icon`),n[0]=i,n[1]=o);let s;n[2]===t?s=n[3]:(s=f(t,{}),n[2]=t,n[3]=s);let c;return n[4]!==a||n[5]!==o||n[6]!==s?(c=f(`div`,{className:o,style:a,children:s}),n[4]=a,n[5]=o,n[6]=s,n[7]=c):c=n[7],c}let o;return n[8]!==i||n[9]!==r||n[10]!==a?(o=f(IconRenderer,{element:r,className:i,style:a}),n[8]=i,n[9]=r,n[10]=a,n[11]=o):o=n[11],o}export{IconRenderer as n,IconRendererProvider as r,IconOrShapeRenderer as t};
@@ -1 +0,0 @@
1
- import"./rolldown-runtime.mjs";import{createContext as e,useContext as t}from"react";import"react/compiler-runtime";import"react/jsx-runtime";const n=e(null),r=n.Provider,i=e(null),a=i.Provider;function useOptionalLikeC4Model(){return t(n)}function useOptionalCurrentViewModel(){return t(i)}export{useOptionalLikeC4Model as i,r as n,useOptionalCurrentViewModel as r,a as t};
@@ -1 +0,0 @@
1
- import"./rolldown-runtime.mjs";import{O as e}from"./styled-system.mjs";import{r as t}from"./IconRenderer.mjs";import{t as n}from"./libs/@nanostores/react.mjs";import{n as r}from"./LikeC4ModelContext.mjs";import{t as i}from"./safeCtx.mjs";import"react";import{c as a}from"react/compiler-runtime";import{jsx as o}from"react/jsx-runtime";import{getProjectIcons as s}from"likec4:icons";function LikeC4ModelProvider(e){let t=a(3),{children:n,likec4model:i}=e,s;return t[0]!==n||t[1]!==i?(s=o(r,{value:i,children:n}),t[0]=n,t[1]=i,t[2]=s):s=t[2],s}const c=e(`div`,{base:{padding:`0`,margin:`0`,width:`full`,height:`full`}});function LikeC4IconRendererContext(e){let n=a(5),{children:r,projectId:i}=e,c;n[0]===i?c=n[1]:(c=s(i),n[0]=i,n[1]=c);let l=c,u;return n[2]!==l||n[3]!==r?(u=o(t,{value:l,children:r}),n[2]=l,n[3]=r,n[4]=u):u=n[4],u}function LikeC4ModelContext(e){let t=a(6),{likec4model:r,children:s}=e,c=n(r),l;t[0]!==s||t[1]!==c?(l=o(LikeC4ModelProvider,{likec4model:c,children:s}),t[0]=s,t[1]=c,t[2]=l):l=t[2];let u;return t[3]!==r||t[4]!==l?(u=o(i,{value:r,children:l}),t[3]=r,t[4]=l,t[5]=u):u=t[5],u}export{LikeC4IconRendererContext as n,c as r,LikeC4ModelContext as t};
@@ -1 +0,0 @@
1
- import"./rolldown-runtime.mjs";import{M as e}from"./styled-system.mjs";import{t}from"./LikeC4Diagram.mjs";import{c as n}from"react/compiler-runtime";import{jsx as r}from"react/jsx-runtime";function StaticLikeC4Diagram(i){let a=n(20),o,s,c,l,u,d,f,p;a[0]===i?(o=a[1],s=a[2],c=a[3],l=a[4],u=a[5],d=a[6],f=a[7],p=a[8]):({view:p,fitView:c,fitViewPadding:l,enableRelationshipDetails:u,enableRelationshipBrowser:d,background:f,className:o,...s}=i,a[0]=i,a[1]=o,a[2]=s,a[3]=c,a[4]=l,a[5]=u,a[6]=d,a[7]=f,a[8]=p);let m=c===void 0?!0:c,h=l===void 0?`8px`:l,g=u===void 0?!1:u,_=d===void 0?g:d,v=f===void 0?`transparent`:f,y;a[9]===o?y=a[10]:(y=e(o,`likec4-static-view`),a[9]=o,a[10]=y);let b;return a[11]!==v||a[12]!==_||a[13]!==g||a[14]!==m||a[15]!==h||a[16]!==s||a[17]!==y||a[18]!==p?(b=r(t,{view:p,className:y,fitView:m,fitViewPadding:h,pannable:!1,zoomable:!1,controls:!1,background:v,enableNotations:!1,enableElementDetails:!1,enableRelationshipDetails:g,enableRelationshipBrowser:_,enableDynamicViewWalkthrough:!1,showNavigationButtons:!1,enableCompareWithLatest:!1,enableFocusMode:!1,enableSearch:!1,nodesSelectable:!1,enableElementTags:!1,enableNotes:!1,...s}),a[11]=v,a[12]=_,a[13]=g,a[14]=m,a[15]=h,a[16]=s,a[17]=y,a[18]=p,a[19]=b):b=a[19],b}export{StaticLikeC4Diagram as t};
@@ -1 +0,0 @@
1
- import"./rolldown-runtime.mjs";import{a as e,s as t}from"./libs/@tanstack/react-router.mjs";import{t as n}from"./libs/@tanstack/router-core.mjs";import{v as r}from"./libs/remeda.mjs";import{Tt as i,_t as a,h as o,m as s,wt as c}from"./libs/@mantine/core.mjs";import{n as l,t as u}from"./searchParams.mjs";import{c as d}from"react/compiler-runtime";import{jsx as f}from"react/jsx-runtime";import{defaultTheme as p}from"likec4:app-config";import{projects as m}from"likec4:projects";const h=c({autoContrast:!0,primaryColor:`indigo`,cursorType:`pointer`,fontFamily:`var(--likec4-app-font)`,headings:{fontWeight:`500`,sizes:{h1:{fontWeight:`600`},h2:{}}},fontSizes:{xxs:`var(--font-sizes-xxs)`,xs:`var(--font-sizes-xs)`,sm:`var(--font-sizes-sm)`,md:`var(--font-sizes-md)`,lg:`var(--font-sizes-lg)`,xl:`var(--font-sizes-xl)`},spacing:{xs:`var(--spacing-xs)`,sm:`var(--spacing-sm)`,md:`var(--spacing-md)`,lg:`var(--spacing-lg)`,xl:`var(--spacing-xl)`},components:{SegmentedControl:s.extend({vars:(e,t,n)=>({root:{"--sc-font-size":e.fontSizes[t.fz??t.size]}})}),Portal:a.extend({defaultProps:{reuseTargetNode:!0}}),Tooltip:o.extend({defaultProps:{color:`dark`}})}}),g=t()({validateSearch:l,search:{middlewares:[n({padding:20,theme:void 0,dynamic:`diagram`,relationships:void 0,focusOnElement:void 0})]},beforeLoad:()=>{let e=m.length>0?r(m,e=>e.id):[`default`];return{projects:e,projectId:e[0]}},component:RootComponent});function RootComponent(){let t=d(8),{theme:n}=g.useSearch(),r;t[0]===n?r=t[1]:(r=u(n),t[0]=n,t[1]=r);let a=r,o=n===`auto`?`auto`:p,s;t[2]===a?s=t[3]:(s=a&&{forceColorScheme:a},t[2]=a,t[3]=s);let c;t[4]===Symbol.for(`react.memo_cache_sentinel`)?(c=f(e,{}),t[4]=c):c=t[4];let l;return t[5]!==o||t[6]!==s?(l=f(i,{theme:h,defaultColorScheme:o,...s,children:c}),t[5]=o,t[6]=s,t[7]=l):l=t[7],l}export{g as t};
@@ -1 +0,0 @@
1
- import{r as e}from"../rolldown-runtime.mjs";import{$ as t,$n as n,$t as r,A as i,An as a,At as o,B as s,Bn as c,Bt as l,C as u,Cn as d,Ct as f,D as p,Dn as m,Dt as h,E as g,En as _,Et as v,F as y,Fn as b,Ft as x,G as S,Gn as C,Gt as w,H as T,Hn as E,Ht as D,I as O,In as k,It as A,J as j,Jn as M,Jt as N,K as P,Kn as F,Kt as I,L,Ln as R,Lt as z,M as B,Mn as V,Mt as H,N as U,Nn as W,Nt as G,O as K,On as q,Ot as J,P as Y,Pn as X,Pt as Z,Q,Qn as $,Qt as ee,R as te,Rn as ne,Rt as re,S as ie,Sn as ae,St as oe,T as se,Tn as ce,Tt as le,U as ue,Un as de,Ut as fe,V as pe,Vn as me,Vt as he,W as ge,Wn as _e,Wt as ve,X as ye,Xn as be,Xt as xe,Y as Se,Yn as Ce,Yt as we,Z as Te,Zn as Ee,Zt as De,_ as Oe,_n as ke,_t as Ae,a as je,an as Me,at as Ne,b as Pe,bn as Fe,bt as Ie,c as Le,cn as Re,ct as ze,d as Be,dn as Ve,dt as He,en as Ue,er as We,et as Ge,f as Ke,fn as qe,ft as Je,g as Ye,gn as Xe,gt as Ze,h as Qe,hn as $e,ht as et,i as tt,in as nt,it as rt,j as it,jn as at,jt as ot,k as st,kn as ct,kt as lt,l as ut,ln as dt,lt as ft,m as pt,mn as mt,mt as ht,n as gt,nn as _t,nr as vt,nt as yt,o as bt,on as xt,ot as St,p as Ct,pn as wt,pt as Tt,q as Et,qn as Dt,qt as Ot,r as kt,rn as At,rr as jt,rt as Mt,s as Nt,sn as Pt,st as Ft,t as It,tn as Lt,tr as Rt,tt as zt,u as Bt,un as Vt,ut as Ht,v as Ut,vn as Wt,vt as Gt,w as Kt,wn as qt,wt as Jt,x as Yt,xn as Xt,xt as Zt,y as Qt,yn as $t,yt as en,z as tn,zn as nn,zt as rn}from"./framer-motion.mjs";var an=e({a:()=>It,abbr:()=>gt,address:()=>kt,animate:()=>tt,area:()=>je,article:()=>bt,aside:()=>Nt,audio:()=>Le,b:()=>ut,base:()=>Bt,bdi:()=>Be,bdo:()=>Ke,big:()=>Ct,blockquote:()=>pt,body:()=>Qe,button:()=>Ye,canvas:()=>Oe,caption:()=>Ut,circle:()=>Qt,cite:()=>Pe,clipPath:()=>Yt,code:()=>ie,col:()=>u,colgroup:()=>Kt,create:()=>jt,data:()=>se,datalist:()=>g,dd:()=>p,defs:()=>K,del:()=>st,desc:()=>i,details:()=>it,dfn:()=>B,dialog:()=>U,div:()=>Y,dl:()=>y,dt:()=>O,ellipse:()=>L,em:()=>te,embed:()=>tn,feBlend:()=>s,feColorMatrix:()=>pe,feComponentTransfer:()=>T,feComposite:()=>ue,feConvolveMatrix:()=>ge,feDiffuseLighting:()=>S,feDisplacementMap:()=>P,feDistantLight:()=>Et,feDropShadow:()=>j,feFlood:()=>Se,feFuncA:()=>ye,feFuncB:()=>Te,feFuncG:()=>Q,feFuncR:()=>t,feGaussianBlur:()=>Ge,feImage:()=>zt,feMerge:()=>yt,feMergeNode:()=>Mt,feMorphology:()=>rt,feOffset:()=>Ne,fePointLight:()=>St,feSpecularLighting:()=>Ft,feSpotLight:()=>ze,feTile:()=>ft,feTurbulence:()=>Ht,fieldset:()=>He,figcaption:()=>Je,figure:()=>Tt,filter:()=>ht,footer:()=>et,foreignObject:()=>Ze,form:()=>Ae,g:()=>Gt,h1:()=>en,h2:()=>Ie,h3:()=>Zt,h4:()=>oe,h5:()=>f,h6:()=>Jt,head:()=>le,header:()=>v,hgroup:()=>h,hr:()=>J,html:()=>lt,i:()=>o,iframe:()=>ot,image:()=>H,img:()=>G,input:()=>Z,ins:()=>x,kbd:()=>A,keygen:()=>z,label:()=>re,legend:()=>rn,li:()=>l,line:()=>he,linearGradient:()=>D,link:()=>fe,main:()=>ve,map:()=>w,mark:()=>I,marker:()=>Ot,mask:()=>N,menu:()=>we,menuitem:()=>xe,metadata:()=>De,meter:()=>ee,nav:()=>r,object:()=>Ue,ol:()=>Lt,optgroup:()=>_t,option:()=>At,output:()=>nt,p:()=>Me,param:()=>xt,path:()=>Pt,pattern:()=>Re,picture:()=>dt,polygon:()=>Vt,polyline:()=>Ve,pre:()=>qe,progress:()=>wt,q:()=>mt,radialGradient:()=>$e,rect:()=>Xe,rp:()=>ke,rt:()=>Wt,ruby:()=>$t,s:()=>Fe,samp:()=>Xt,script:()=>ae,section:()=>d,select:()=>qt,small:()=>ce,source:()=>_,span:()=>m,stop:()=>q,strong:()=>ct,style:()=>a,sub:()=>at,summary:()=>V,sup:()=>W,svg:()=>X,symbol:()=>b,table:()=>k,tbody:()=>R,td:()=>ne,text:()=>nn,textPath:()=>c,textarea:()=>me,tfoot:()=>E,th:()=>de,thead:()=>_e,time:()=>C,title:()=>F,tr:()=>Dt,track:()=>M,tspan:()=>Ce,u:()=>be,ul:()=>Ee,use:()=>$,video:()=>n,view:()=>We,wbr:()=>Rt,webview:()=>vt});export{an as t};
@@ -1 +0,0 @@
1
- import{t as e}from"../rolldown-runtime.mjs";import{a as t,i as n,o as r,s as i}from"./@xstate/react.mjs";var a=e((e=>{Object.defineProperty(e,`__esModule`,{value:!0});var t=r();i(),e.and=t.and,e.evaluateGuard=t.evaluateGuard,e.not=t.not,e.or=t.or,e.stateIn=t.stateIn}))(),o=e((e=>{Object.defineProperty(e,`__esModule`,{value:!0});var a=t(),o=r(),s=n();i(),e.assign=a.assign,e.cancel=o.cancel,e.raise=o.raise,e.spawnChild=o.spawnChild,e.stop=o.stop,e.stopChild=o.stopChild,e.emit=s.emit,e.enqueueActions=s.enqueueActions,e.forwardTo=s.forwardTo,e.log=s.log,e.sendParent=s.sendParent,e.sendTo=s.sendTo}))();export{a as n,o as t};
@@ -1 +0,0 @@
1
- import"./rolldown-runtime.mjs";import{createContext as e,useContext as t}from"react";const n=e(null),r=n.Provider,useLikeC4ModelAtom=()=>{let e=t(n);if(e===null)throw Error(`LikeC4ModelAtom is not provided`);return e};export{useLikeC4ModelAtom as n,r as t};
@@ -1 +0,0 @@
1
- import"./rolldown-runtime.mjs";import{a as e,i as t,o as n,r,t as i}from"./libs/zod.mjs";const a=e({theme:r([`light`,`dark`,`auto`]).optional().catch(void 0),dynamic:i([`diagram`,`sequence`]).default(`diagram`).catch(`diagram`),padding:t().min(0).default(20).catch(20),relationships:n().nonempty().optional().catch(void 0).transform(e=>e),focusOnElement:n().nonempty().optional().catch(void 0).transform(e=>e)});function resolveForceColorScheme(e){switch(e){case`light`:case`dark`:return e;default:return}}export{a as n,resolveForceColorScheme as t};
@@ -1 +0,0 @@
1
- import{i as e}from"./rolldown-runtime.mjs";import{i as t,l as n,o as r,r as i}from"./libs/@tanstack/react-router.mjs";import{W as a,s as o}from"./libs/remeda.mjs";import{B as s,Ct as c,Dt as l,G as u,L as d,M as f,N as p,U as m,W as h,bt as g,f as _,i as v,j as y,lt as b,m as x,n as S,qt as C,rt as w,t as T,xt as ee}from"./libs/@mantine/core.mjs";import{d as E,o as D,r as te,u as ne}from"./libs/@mantine/hooks.mjs";import{E as re,M as ie,N as O}from"./styled-system.mjs";import{E as ae,H as oe,R as se,et as ce,h as le,o as ue,t as k,v as de}from"./libs/@tabler/icons-react.mjs";import{S as fe}from"./libs/@xyflow/react.mjs";import{l as pe,x as me}from"./LikeC4Styles.mjs";import{n as A}from"./useUpdateEffect.mjs";import{y as j}from"./DiagramActorProvider.mjs";import{n as M,t as N}from"./libs/nanostores.mjs";import{t as P}from"./libs/@nanostores/react.mjs";import{mr as F}from"./libs/framer-motion.mjs";import{a as I,i as L,n as R,o as z,r as he,s as ge}from"./LikeC4Diagram.mjs";import{t as B}from"./StaticLikeC4Diagram.mjs";import{t as V}from"./NavigationPanel.mjs";import{t as _e}from"./ColorSchemeToggle.mjs";import{i as H,n as ve,t as ye}from"./hooks.mjs";import{memo as U,useEffect as W,useRef as be,useState as G}from"react";import{c as K}from"react/compiler-runtime";import{Fragment as q,jsx as J,jsxs as Y}from"react/jsx-runtime";import{pageTitle as xe}from"likec4:app-config";import{compareNatural as Se,nonexhaustive as Ce}from"@likec4/core/utils";import{RichText as we}from"@likec4/core/types";const Te=O({height:`30px`,paddingLeft:`sm`,paddingRight:`1`,borderRadius:`sm`,border:`1px solid`,borderColor:{base:`default.border`,_light:`mantine.colors.gray[4]`,_dark:`mantine.colors.dark[4]`,_hover:`default.border`},cursor:`pointer`,background:{base:`default`,_light:`white`,_dark:`mantine.colors.dark[6]`,_hover:`default.hover`},width:`100%`,"& .tabler-icon":{color:`text`},transition:{base:`fast`,_whenPanning:`none !important`},boxShadow:{base:`xs`,_hover:`sm`,_whenPanning:`none !important`}}),Ee=O({fontSize:`sm`,fontWeight:`medium`,paddingRight:`2.5`,color:`text.placeholder`,flex:`1`,sm:{paddingRight:`[30px]`},md:{paddingRight:`[50px]`}}),X=O({fontSize:`11px`,fontWeight:`bold`,lineHeight:1,padding:`[4px 7px]`,borderRadius:`sm`,border:`1px solid`,transition:`fast`,_light:{color:`mantine.colors.gray[7]`,borderColor:`mantine.colors.gray[2]`},_dark:{color:`mantine.colors.dark[0]`,borderColor:`mantine.colors.dark[7]`},backgroundColor:{_light:`mantine.colors.gray[2]/70`,_dark:`mantine.colors.dark[8]/70`,_groupHover:{_light:`mantine.colors.gray[2]`,_dark:`mantine.colors.dark[8]`}}});function SearchControl(e){let t=K(11),n,r;t[0]===e?(n=t[1],r=t[2]):({className:n,...r}=e,t[0]=e,t[1]=n,t[2]=r);let i=fe(),a;t[3]===n?a=t[4]:(a=ie(`group`,Te,n),t[3]=n,t[4]=a);let o,s;t[5]===Symbol.for(`react.memo_cache_sentinel`)?(o=J(de,{style:{width:`15px`,height:`15px`},stroke:2}),s=J(w,{component:`div`,className:Ee,children:`Search`}),t[5]=o,t[6]=s):(o=t[5],s=t[6]);let c;t[7]===Symbol.for(`react.memo_cache_sentinel`)?(c=Y(b,{gap:`xs`,children:[o,s,J(w,{component:`div`,className:X,children:i?`⌘ + K`:`Ctrl + K`})]}),t[7]=c):c=t[7];let l;return t[8]!==r||t[9]!==a?(l=J(g,{...r,className:a,children:c}),t[8]=r,t[9]=a,t[10]=l):l=t[10],l}function OverviewSearchAdapter(e){let t=K(16),{onClose:r,children:i}=e,[a,o]=G(``),[s,c]=G(null),l=n(),t1;t[0]!==l||t[1]!==r?(t1=(e,t)=>{r(),l({to:`/view/$viewId/`,params:{viewId:e},search:e=>({...e,...t&&{focusOnElement:t}})})},t[0]=l,t[1]=r,t[2]=t1):t1=t[2];let u=t1,t2;t[3]===Symbol.for(`react.memo_cache_sentinel`)?(t2=e=>{c(e)},t[3]=t2):t2=t[3];let d=t2,t3;t[4]===Symbol.for(`react.memo_cache_sentinel`)?(t3=()=>{c(null)},t[4]=t3):t3=t[4];let f=t3,p;t[5]===a?p=t[6]:(p=z(a),t[5]=a,t[6]=p);let m;t[7]!==u||t[8]!==r||t[9]!==s||t[10]!==a||t[11]!==p?(m={searchValue:a,setSearchValue:o,normalizedSearch:p,navigateTo:u,openPickView:d,closePickView:f,pickViewFor:s,close:r,currentViewId:null,openedWithSearch:null},t[7]=u,t[8]=r,t[9]=s,t[10]=a,t[11]=p,t[12]=m):m=t[12];let h=m,g;return t[13]!==i||t[14]!==h?(g=J(I.Provider,{value:h,children:i}),t[13]=i,t[14]=h,t[15]=g):g=t[15],g}const Z=U(()=>{let e=K(10),[t,n]=G(!1),r=be(null),t0;e[0]===Symbol.for(`react.memo_cache_sentinel`)?(t0=()=>n(!0),e[0]=t0):t0=e[0];let i=t0,t1;e[1]===Symbol.for(`react.memo_cache_sentinel`)?(t1=()=>n(!1),e[1]=t1):t1=e[1];let a=t1,t2;e[2]===Symbol.for(`react.memo_cache_sentinel`)?(t2=e=>{e&&(r.current=e)},e[2]=t2):t2=e[2];let o=t2,t3;e[3]===Symbol.for(`react.memo_cache_sentinel`)?(t3=()=>{r.current?.open&&r.current.close(),r.current=null},e[3]=t3):t3=e[3];let s=t3,c;e[4]===Symbol.for(`react.memo_cache_sentinel`)?(c=[[`mod+k`,i,{preventDefault:!0}]],e[4]=c):c=e[4],D(c);let l;e[5]===Symbol.for(`react.memo_cache_sentinel`)?(l=J(SearchControl,{onClick:i}),e[5]=l):l=e[5];let u;e[6]===t?u=e[7]:(u=t&&J(ge,{ref:o,fullscreen:!0,withBackdrop:!1,backdrop:{opacity:.9},classes:{dialog:L,body:he},openDelay:0,onClose:a,"data-likec4-search":`true`,children:J(OverviewSearchAdapter,{onClose:a,children:J(R,{})})}),e[6]=t,e[7]=u);let d;return e[8]===u?d=e[9]:(d=Y(q,{children:[l,J(me,{children:J(F,{onExitComplete:s,children:u})})]}),e[8]=u,e[9]=d),d});Z.displayName=`OverviewSearch`;const isTreeNodeData=e=>`type`in e&&[`file`,`folder`,`view`,`deployment-view`].includes(e.type);function dropFilename(e){return e===``?``:e.split(`/`).slice(0,-1).join(`/`)}function compareTreeNodes(e,t){return e.children.length===0&&t.children.length>0?1:e.children.length>0&&t.children.length===0?-1:Se(e.label,t.label)}function buildDiagramTreeData(e,t){let n={value:``,label:`Diagrams`,type:`folder`,children:[]},findParent=e=>{let t=n;if(e===``)return t;let r=e.split(`/`),i=[`@fs`];for(;r.length;){let e=r.shift();i.push(e);let n=i.join(`/`),o=a(t.children,e=>e.value===n);o||(o={label:e,value:n,type:`folder`,children:[]},t.children.push(o)),t=o}return t};for(let r of e){let e;switch(t){case`by-files`:e=r.$view.sourcePath??``;break;case`by-folders`:e=dropFilename(r.$view.sourcePath??``);break;case`none`:e=``;break;default:Ce(t)}let i=findParent(e);i.children.push({value:r.id,label:r.title??r.id,type:r.isDeploymentView()?`deployment-view`:`view`,children:[]}),i!==n&&(i.children.sort(compareTreeNodes),t===`by-files`&&i.type!==`file`&&(i.type=`file`))}return n.children.sort(compareTreeNodes)}function useDiagramsTreeData(e){let t=K(3),n=e===void 0?`by-files`:e,r=j(),i;return t[0]!==n||t[1]!==r?(i=buildDiagramTreeData([...r.views()],n),t[0]=n,t[1]=r,t[2]=i):i=t[2],i}const Q=M(!1);N(Q,()=>{Q.set(!1)});const useDrawerOpened=()=>P(Q),$={open:()=>Q.set(!0),close:()=>Q.set(!1)},isFile=e=>isTreeNodeData(e)&&e.type===`file`,FolderIcon=e=>{let t=K(3),{node:n,expanded:r}=e;if(isFile(n)){let e;return t[0]===Symbol.for(`react.memo_cache_sentinel`)?(e=J(v,{size:`sm`,variant:`transparent`,color:`indigo`,children:J(oe,{size:16})}),t[0]=e):e=t[0],e}let i;return t[1]===r?i=t[2]:(i=J(v,{size:`sm`,variant:`transparent`,color:`violet`,children:J(r?se:ue,{size:16})}),t[1]=r,t[2]=i),i},De=U(e=>{let t=K(27),{groupBy:r}=e,i=H(),a=useDiagramsTreeData(r),o=n(),t1;t[0]===o?t1=t[1]:(t1=e=>{$.close(),o({to:`/view/$viewId/`,viewTransition:!1,params:{viewId:e}})},t[0]=o,t[1]=t1);let s=t1,[c]=ve(),u=c?.id??null,d;t[2]===Symbol.for(`react.memo_cache_sentinel`)?(d={multiple:!1},t[2]=d):d=t[2];let f=S(d),p=c?.sourcePath??null,t3;t[3]===f?t3=t[4]:(t3=()=>{f.collapseAllNodes()},t[3]=f,t[4]=t3);let m;t[5]===r?m=t[6]:(m=[r],t[5]=r,t[6]=m),A(t3,m);let t5;t[7]!==p||t[8]!==f?(t5=()=>{if(p){let e=p.split(`/`),t=`@fs`;for(let n of e)t+=`/${n}`,f.expand(t)}},t[7]=p,t[8]=f,t[9]=t5):t5=t[9];let g;t[10]!==r||t[11]!==p?(g=[p,r],t[10]=r,t[11]=p,t[12]=g):g=t[12],W(t5,g);let t7;t[13]!==f||t[14]!==u?(t7=()=>{u&&f.select(u)},t[13]=f,t[14]=u,t[15]=t7):t7=t[15];let _;t[16]===u?_=t[17]:(_=[u],t[16]=u,t[17]=_),W(t7,_);let v=l(),y;t[18]===Symbol.for(`react.memo_cache_sentinel`)?(y={node:{marginTop:2,marginBottom:2}},t[18]=y):y=t[18];let t10;t[19]!==s||t[20]!==v||t[21]!==i?(t10=e=>{let{node:t,selected:n,expanded:r,elementProps:a,hasChildren:o}=e;return J(DiagramPreviewHoverCard,{diagram:o?void 0:i.find(e=>e.id===t.value),children:J(h,{fullWidth:!0,color:v===`light`?`dark`:`gray`,variant:n?`transparent`:`subtle`,size:`sm`,fz:`sm`,fw:o?`600`:`500`,justify:`flex-start`,styles:{section:{opacity:.5}},leftSection:Y(q,{children:[!o&&t.value===`index`&&J(k,{size:14,opacity:.7}),!o&&t.value!==`index`&&isTreeNodeData(t)&&Y(q,{children:[t.type===`deployment-view`&&J(le,{size:14}),t.type===`view`&&J(ae,{size:14})]}),o&&J(FolderIcon,{node:t,expanded:r})]}),...a,...!o&&{onClick:e=>{e.stopPropagation(),s(t.value)}},children:t.label})})},t[19]=s,t[20]=v,t[21]=i,t[22]=t10):t10=t[22];let b;return t[23]!==a||t[24]!==t10||t[25]!==f?(b=J(re,{children:J(T,{allowRangeSelection:!1,tree:f,data:a,styles:y,levelOffset:`md`,renderNode:t10})}),t[23]=a,t[24]=t10,t[25]=f,t[26]=b):b=t[26],b},(e,t)=>e.groupBy===t.groupBy);function DiagramPreviewHoverCard(e){let t=K(14),{diagram:n,children:r}=e,i=n?Math.max(n.bounds.width/400,n.bounds.height/300):1,a;t[0]!==n||t[1]!==i?(a=n?Math.round(n.bounds.width/i):0,t[0]=n,t[1]=i,t[2]=a):a=t[2];let o=a,s;t[3]!==n||t[4]!==i?(s=n?Math.round(n.bounds.height/i):0,t[3]=n,t[4]=i,t[5]=s):s=t[5];let c=s,l;t[6]!==r||t[7]!==n||t[8]!==c||t[9]!==o?(l=n&&Y(y,{position:`right-start`,openDelay:400,closeDelay:100,keepMounted:!1,shadow:`lg`,children:[J(f,{children:r}),J(p,{style:{width:o,height:c},p:`xs`,children:J(Oe,{diagram:n})})]}),t[6]=r,t[7]=n,t[8]=c,t[9]=o,t[10]=l):l=t[10];let u=!n&&r,d;return t[11]!==l||t[12]!==u?(d=Y(q,{children:[l,u]}),t[11]=l,t[12]=u,t[13]=d):d=t[13],d}const Oe=U(e=>{let t=K(10),{diagram:n}=e,r=Math.max(n.bounds.width/400,n.bounds.height/300),i;t[0]!==n.bounds.width||t[1]!==r?(i=Math.round(n.bounds.width/r),t[0]=n.bounds.width,t[1]=r,t[2]=i):i=t[2];let a=i,o;t[3]!==n.bounds.height||t[4]!==r?(o=Math.round(n.bounds.height/r),t[3]=n.bounds.height,t[4]=r,t[5]=o):o=t[5];let s=o,c;return t[6]!==n||t[7]!==s||t[8]!==a?(c=J(B,{view:n,fitView:!0,fitViewPadding:`4px`,enableElementDetails:!1,reduceGraphics:!0,initialWidth:a,initialHeight:s}),t[6]=n,t[7]=s,t[8]=a,t[9]=c):c=t[9],c},(e,t)=>e.diagram.id===t.diagram.id),ke=U(()=>{let e=K(25),n=useDrawerOpened(),r;e[0]===Symbol.for(`react.memo_cache_sentinel`)?(r={key:`sidebar-drawer-grouping`,defaultValue:`by-files`},e[0]=r):r=e[0];let[a,o]=ne(r),s;e[1]===Symbol.for(`react.memo_cache_sentinel`)?(s={select:_temp2$1},e[1]=s):s=e[1];let c=t(s),l;e[2]===Symbol.for(`react.memo_cache_sentinel`)?(l=J(d.Overlay,{blur:2}),e[2]=l):l=e[2];let u;e[3]===Symbol.for(`react.memo_cache_sentinel`)?(u=J(ce,{size:14}),e[3]=u):u=e[3];let f;e[4]===Symbol.for(`react.memo_cache_sentinel`)?(f=J(h,{component:i,to:`/`,leftSection:u,color:`dimmed`,variant:`subtle`,px:C(5),styles:{section:{marginInlineEnd:4}},size:`xs`,children:`Overview`}),e[4]=f):f=e[4];let p=o,m;e[5]===Symbol.for(`react.memo_cache_sentinel`)?(m=[{label:`By files`,value:`by-files`},{label:`By folders`,value:`by-folders`},{label:`List`,value:`none`}],e[5]=m):m=e[5];let g;e[6]!==a||e[7]!==p?(g=J(x,{size:`xs`,withItemsBorders:!1,value:a,onChange:p,data:m}),e[6]=a,e[7]=p,e[8]=g):g=e[8];let _;e[9]===Symbol.for(`react.memo_cache_sentinel`)?(_=J(k,{size:12,stroke:2}),e[9]=_):_=e[9];let v;e[10]===Symbol.for(`react.memo_cache_sentinel`)?(v=J(h,{leftSection:_,color:`dimmed`,variant:`subtle`,px:C(5),styles:{section:{marginInlineEnd:4}},size:`xs`,renderRoot:_temp3,children:`Open index`}),e[10]=v):v=e[10];let y;e[11]===g?y=e[12]:(y=Y(b,{gap:`xs`,children:[f,g,v]}),e[11]=g,e[12]=y);let S;e[13]===Symbol.for(`react.memo_cache_sentinel`)?(S=J(d.CloseButton,{}),e[13]=S):S=e[13];let w;e[14]===y?w=e[15]:(w=Y(d.Header,{children:[y,S]}),e[14]=y,e[15]=w);let T;e[16]===a?T=e[17]:(T=J(d.Body,{children:J(De,{groupBy:a})}),e[16]=a,e[17]=T);let E;e[18]!==w||e[19]!==T?(E=Y(d.Content,{children:[w,T]}),e[18]=w,e[19]=T,e[20]=E):E=e[20];let D;return e[21]!==c||e[22]!==n||e[23]!==E?(D=Y(d.Root,{keepMounted:c,opened:n,scrollAreaComponent:ee.Autosize,onClose:$.close,children:[l,E]}),e[21]=c,e[22]=n,e[23]=E,e[24]=D):D=e[24],D});function _temp$1(e){return e.routeId===`/_single`}e(_temp$1,`_temp`);function _temp2$1(e){return e.some(_temp$1)}e(_temp2$1,`_temp2`);function _temp3(e){return J(i,{to:`/view/$viewId`,params:{viewId:`index`},...e})}function filterLandingPageViews(e,t){return t?`include`in t?e.filter(e=>matchesAny(e,t.include)):`exclude`in t?e.filter(e=>!matchesAny(e,t.exclude)):e:e}function matchesAny(e,t){return t.some(t=>{if(t.startsWith(`#`)){let n=t.slice(1);return e.tags?.some(e=>e===n)??!1}return e.id===t})}O({color:`text.dimmed`}),O({});const Ae=O({position:`relative`,overflow:`hidden`,padding:`0`,margin:`0`,backgroundOrigin:`padding-box`,backgroundImage:`radial-gradient({colors.default.border} 15%, {colors.body} 15%)`,backgroundPosition:`0 0`,backgroundSize:`12px 12px`,_after:{content:`" "`,position:`absolute`,top:`0`,left:`0`,right:`0`,bottom:`0`,zIndex:`1`}}),je=O({position:`absolute`,inset:`0`,zIndex:5}),Me=r(`/_single/single-index`)({component:RouteComponent});function RouteComponent(){let e=K(40);E(xe);let t=H(),{landingPage:n}=ye(),r,i,a,o,c,l,d,f,p,m,h;if(e[0]!==t||e[1]!==n){let g=filterLandingPageViews(t,n);i=s,p=`xl`;let v;e[13]===Symbol.for(`react.memo_cache_sentinel`)?(m=J(ke,{}),v=O({containerName:`likec4-root`,containerType:`inline-size`,display:`flex`,alignItems:`flex-start`,justifyContent:`space-between`,padding:`xs`,gap:`xs`,position:`sticky`,top:`0`,zIndex:`10`,backgroundColor:`likec4.panel.bg/85`,backdropFilter:`blur(8px)`}),e[13]=m,e[14]=v):(m=e[13],v=e[14]);let y;e[15]===Symbol.for(`react.memo_cache_sentinel`)?(y={position:`relative`,width:`max-content`,margin:`0`},e[15]=y):y=e[15];let b,x;e[16]===Symbol.for(`react.memo_cache_sentinel`)?(b=J(`div`,{style:{width:0,height:36},"aria-hidden":!0}),x=J(u,{size:`sm`,onClick:$.open,"aria-label":`Toggle navigation`}),e[16]=b,e[17]=x):(b=e[16],x=e[17]);let S;e[18]===Symbol.for(`react.memo_cache_sentinel`)?(S=J(V.Root,{css:y,children:Y(V.Body,{children:[b,x,J(V.Logo,{css:{flexShrink:0},onClick:_temp}),J(Z,{})]})}),e[18]=S):S=e[18];let C;e[19]===Symbol.for(`react.memo_cache_sentinel`)?(C={position:`relative`,margin:`0`},e[19]=C):C=e[19],e[20]===Symbol.for(`react.memo_cache_sentinel`)?(h=Y(`div`,{className:v,children:[S,J(V.Root,{panelPosition:`right`,css:C,children:J(V.Body,{children:J(`div`,{style:{display:`flex`,alignItems:`center`,minHeight:36},children:J(_e,{})})})})]}),e[20]=h):h=e[20],r=_,e[21]===Symbol.for(`react.memo_cache_sentinel`)?(a={base:`md`,sm:`md`},o={base:`sm`,sm:`sm`},c={base:1,sm:2,md:3,xl:4},l={base:10,sm:`xl`},d={base:`md`,sm:`xl`},e[21]=a,e[22]=o,e[23]=c,e[24]=l,e[25]=d):(a=e[21],o=e[22],c=e[23],l=e[24],d=e[25]),f=g.map(_temp2),e[0]=t,e[1]=n,e[2]=r,e[3]=i,e[4]=a,e[5]=o,e[6]=c,e[7]=l,e[8]=d,e[9]=f,e[10]=p,e[11]=m,e[12]=h}else r=e[2],i=e[3],a=e[4],o=e[5],c=e[6],l=e[7],d=e[8],f=e[9],p=e[10],m=e[11],h=e[12];let g;e[26]!==r||e[27]!==a||e[28]!==o||e[29]!==c||e[30]!==l||e[31]!==d||e[32]!==f?(g=J(r,{p:a,pt:o,cols:c,spacing:l,verticalSpacing:d,children:f}),e[26]=r,e[27]=a,e[28]=o,e[29]=c,e[30]=l,e[31]=d,e[32]=f,e[33]=g):g=e[33];let v;return e[34]!==i||e[35]!==p||e[36]!==m||e[37]!==h||e[38]!==g?(v=Y(i,{size:p,children:[m,h,g]}),e[34]=i,e[35]=p,e[36]=m,e[37]=h,e[38]=g,e[39]=v):v=e[39],v}function _temp2(e){return J(ViewCard,{view:e},e.id)}function _temp(){return window.scrollTo({top:0,behavior:`smooth`})}function ViewCard(e){let t=K(25),{view:n}=e,[r,a]=G(!1),{ref:s,inViewport:l}=te(),t1,u;t[0]!==l||t[1]!==r?(t1=()=>{if(!l||r)return;let e=setTimeout(()=>a(!0),o(30,80));return()=>clearTimeout(e)},u=[l,r],t[0]=l,t[1]=r,t[2]=t1,t[3]=u):(t1=t[2],u=t[3]),W(t1,u);let d;t[4]===Symbol.for(`react.memo_cache_sentinel`)?(d={height:200},t[4]=d):d=t[4];let f;t[5]!==n||t[6]!==r?(f=r&&J(B,{background:`transparent`,view:n,fitView:!0,fitViewPadding:`4px`,reduceGraphics:!0}),t[5]=n,t[6]=r,t[7]=f):f=t[7];let p;t[8]===f?p=t[9]:(p=J(m.Section,{children:J(c,{className:Ae,style:d,children:f})}),t[8]=f,t[9]=p);let h=n.title??n.id,g;t[10]===h?g=t[11]:(g=J(b,{justify:`space-between`,mt:`md`,children:J(w,{fw:500,children:h})}),t[10]=h,t[11]=g);let _;t[12]===n.description?_=t[13]:(_=we.from(n.description),t[12]=n.description,t[13]=_);let v;t[14]===Symbol.for(`react.memo_cache_sentinel`)?(v=O({lineClamp:3,mt:`1`,transition:`fast`,opacity:{base:.8,_groupHover:1}}),t[14]=v):v=t[14];let y;t[15]===_?y=t[16]:(y=J(pe,{value:_,textScale:.75,emptyText:`No description`,className:v}),t[15]=_,t[16]=y);let x;t[17]===n.id?x=t[18]:(x=J(i,{to:`/view/$viewId/`,params:{viewId:n.id},search:!0,className:je}),t[17]=n.id,t[18]=x);let S;return t[19]!==s||t[20]!==y||t[21]!==x||t[22]!==p||t[23]!==g?(S=Y(m,{ref:s,shadow:`xs`,padding:`lg`,radius:`sm`,className:`group`,withBorder:!0,children:[p,g,y,x]}),t[19]=s,t[20]=y,t[21]=x,t[22]=p,t[23]=g,t[24]=S):S=t[24],S}export{Me as t};
@@ -1 +0,0 @@
1
- import{i as e}from"./rolldown-runtime.mjs";import{createContext as t,createElement as n,forwardRef as r,useContext as i,useMemo as a}from"react";function isObject(e){return typeof e==`object`&&!!e&&!Array.isArray(e)}var isObjectOrArray=e=>typeof e==`object`&&!!e;function compact(e){return Object.fromEntries(Object.entries(e??{}).filter(([e,t])=>t!==void 0))}var isBaseCondition=e=>e===`base`;function filterBaseConditions(e){return e.slice().filter(e=>!isBaseCondition(e))}function toChar(e){return String.fromCharCode(e+(e>25?39:97))}function toName(e){let t=``,n;for(n=Math.abs(e);n>52;n=n/52|0)t=toChar(n%52)+t;return toChar(n%52)+t}function toPhash(e,t){let n=t.length;for(;n;)e=e*33^t.charCodeAt(--n);return e}function toHash(e){return toName(toPhash(5381,e)>>>0)}var o=/\s*!(important)?/i;function isImportant(e){return typeof e==`string`?o.test(e):!1}function withoutImportant(e){return typeof e==`string`?e.replace(o,``).trim():e}function withoutSpace(e){return typeof e==`string`?e.replaceAll(` `,`_`):e}var s=e(e=>{let t=new Map,get=(...n)=>{let r=JSON.stringify(n);if(t.has(r))return t.get(r);let i=e(...n);return t.set(r,i),i};return get},`memo`),c=new Set([`__proto__`,`constructor`,`prototype`]);function mergeProps(...e){return e.reduce((e,t)=>(t&&Object.keys(t).forEach(n=>{if(c.has(n))return;let r=e[n],i=t[n];isObject(r)&&isObject(i)?e[n]=mergeProps(r,i):e[n]=i}),e),{})}var isNotNullish=e=>e!=null;function walkObject(e,t,n={}){let{stop:r,getKey:i}=n;function inner(e,n=[]){if(isObjectOrArray(e)){let a={};for(let[o,s]of Object.entries(e)){let c=i?.(o,s)??o,l=[...n,c];if(r?.(e,l))return t(e,n);let u=inner(s,l);isNotNullish(u)&&(a[c]=u)}return a}return t(e,n)}return inner(e)}function mapObject(e,t){return Array.isArray(e)?e.map(e=>t(e)):isObject(e)?walkObject(e,e=>t(e)):t(e)}function toResponsiveObject(e,t){return e.reduce((e,n,r)=>{let i=t[r];return n!=null&&(e[i]=n),e},{})}function normalizeStyleObject(e,t,n=!0){let{utility:r,conditions:i}=t,{hasShorthand:a,resolveShorthand:o}=r;return walkObject(e,e=>Array.isArray(e)?toResponsiveObject(e,i.breakpoints.keys):e,{stop:e=>Array.isArray(e),getKey:n?e=>a?o(e):e:void 0})}var l={shift:e=>e,finalize:e=>e,breakpoints:{keys:[]}},sanitize=e=>typeof e==`string`?e.replaceAll(/[\n\s]+/g,` `):e;function createCss(e){let{utility:t,hash:n,conditions:r=l}=e,formatClassName=e=>[t.prefix,e].filter(Boolean).join(`-`),hashFn=(e,i)=>{let a;if(n){let n=[...r.finalize(e),i];a=formatClassName(t.toHash(n,toHash))}else a=[...r.finalize(e),formatClassName(i)].join(`:`);return a};return s(({base:n,...i}={})=>{let a=normalizeStyleObject(Object.assign(i,n),e),o=new Set;return walkObject(a,(e,n)=>{if(e==null)return;let i=isImportant(e),[a,...s]=r.shift(n),c=hashFn(filterBaseConditions(s),t.transform(a,withoutImportant(sanitize(e))).className);i&&(c=`${c}!`),o.add(c)}),Array.from(o).join(` `)})}function compactStyles(...e){return e.flat().filter(e=>isObject(e)&&Object.keys(compact(e)).length>0)}function createMergeCss(e){function resolve(t){let n=compactStyles(...t);return n.length===1?n:n.map(t=>normalizeStyleObject(t,e))}function mergeCss(...e){return mergeProps(...resolve(e))}function assignCss(...e){return Object.assign({},...resolve(e))}return{mergeCss:s(mergeCss),assignCss}}var u=/([A-Z])/g,d=/^ms-/,f=s(e=>e.startsWith(`--`)?e:e.replace(u,`-$1`).replace(d,`-ms-`).toLowerCase()),p=RegExp(`^(${[`min`,`max`,`clamp`,`calc`].join(`|`)})\\(.*\\)`),isCssFunction=e=>typeof e==`string`&&p.test(e),ee=`(?:${`cm,mm,Q,in,pc,pt,px,em,ex,ch,rem,lh,rlh,vw,vh,vmin,vmax,vb,vi,svw,svh,lvw,lvh,dvw,dvh,cqw,cqh,cqi,cqb,cqmin,cqmax,%`.split(`,`).join(`|`)})`,te=RegExp(`^[+-]?[0-9]*.?[0-9]+(?:[eE][+-]?[0-9]+)?${ee}$`),isCssUnit=e=>typeof e==`string`&&te.test(e),isCssVar=e=>typeof e==`string`&&/^var\(--.+\)$/.test(e),m={map:mapObject,isCssFunction,isCssVar,isCssUnit},getPatternStyles=(e,t)=>{if(!e?.defaultValues)return t;let n=typeof e.defaultValues==`function`?e.defaultValues(t):e.defaultValues;return Object.assign({},n,compact(t))},getSlotRecipes=(e={})=>{let init=t=>({className:[e.className,t].filter(Boolean).join(`__`),base:e.base?.[t]??{},variants:{},defaultVariants:e.defaultVariants??{},compoundVariants:e.compoundVariants?getSlotCompoundVariant(e.compoundVariants,t):[]}),t=(e.slots??[]).map(e=>[e,init(e)]);for(let[n,r]of Object.entries(e.variants??{}))for(let[e,i]of Object.entries(r))t.forEach(([t,r])=>{r.variants[n]??={},r.variants[n][e]=i[t]??{}});return Object.fromEntries(t)},getSlotCompoundVariant=(e,t)=>e.filter(e=>e.css[t]).map(e=>({...e,css:e.css[t]}));function splitProps(e,...t){let n=Object.getOwnPropertyDescriptors(e),r=Object.keys(n),split=e=>{let t={};for(let r=0;r<e.length;r++){let i=e[r];n[i]&&(Object.defineProperty(t,i,n[i]),delete n[i])}return t},fn=e=>split(Array.isArray(e)?e:r.filter(e));return t.map(fn).concat(split(r))}var uniq=(...e)=>{let t=e.reduce((e,t)=>(t&&t.forEach(t=>e.add(t)),e),new Set([]));return Array.from(t)},h=[`htmlSize`,`htmlTranslate`,`htmlWidth`,`htmlHeight`];function convert(e){return h.includes(e)?e.replace(`html`,``).toLowerCase():e}function normalizeHTMLProps(e){return Object.fromEntries(Object.entries(e).map(([e,t])=>[convert(e),t]))}normalizeHTMLProps.keys=h;const g=new Set(`_hover,_focus,_focusWithin,_focusVisible,_disabled,_active,_visited,_target,_readOnly,_readWrite,_empty,_checked,_enabled,_expanded,_highlighted,_complete,_incomplete,_dragging,_before,_after,_firstLetter,_firstLine,_marker,_selection,_file,_backdrop,_first,_last,_only,_even,_odd,_firstOfType,_lastOfType,_onlyOfType,_peerFocus,_peerHover,_peerActive,_peerFocusWithin,_peerFocusVisible,_peerDisabled,_peerChecked,_peerInvalid,_peerExpanded,_peerPlaceholderShown,_groupFocus,_groupHover,_groupActive,_groupFocusWithin,_groupFocusVisible,_groupDisabled,_groupChecked,_groupExpanded,_groupInvalid,_indeterminate,_required,_valid,_invalid,_autofill,_inRange,_outOfRange,_placeholder,_placeholderShown,_pressed,_selected,_grabbed,_underValue,_overValue,_atValue,_default,_optional,_open,_closed,_fullscreen,_loading,_hidden,_current,_currentPage,_currentStep,_today,_unavailable,_rangeStart,_rangeEnd,_now,_topmost,_motionReduce,_motionSafe,_print,_landscape,_portrait,_dark,_light,_osDark,_osLight,_highContrast,_lessContrast,_moreContrast,_ltr,_rtl,_scrollbar,_scrollbarThumb,_scrollbarTrack,_horizontal,_vertical,_icon,_starting,_noscript,_invertedColors,_shapeSizeXs,_shapeSizeSm,_shapeSizeMd,_shapeSizeLg,_shapeSizeXl,_shapeRectangle,_shapePerson,_shapeBrowser,_shapeMobile,_shapeCylinder,_shapeStorage,_shapeQueue,_shapeBucket,_shapeDocument,_shapeComponent,_notDisabled,_reduceGraphics,_reduceGraphicsOnPan,_noReduceGraphics,_whenPanning,_smallZoom,_compoundTransparent,_edgeActive,_whenHovered,_whenSelectable,_whenSelected,_whenDimmed,_whenFocused,_p3,xs,xsOnly,xsDown,sm,smOnly,smDown,md,mdOnly,mdDown,lg,lgOnly,lgDown,xl,xlOnly,xlDown,xsToSm,xsToMd,xsToLg,xsToXl,smToMd,smToLg,smToXl,mdToLg,mdToXl,lgToXl,@/xs,@/sm,@/md,@/lg,@likec4-root/xs,@likec4-root/sm,@likec4-root/md,@likec4-root/lg,@likec4-dialog/xs,@likec4-dialog/sm,@likec4-dialog/md,@likec4-dialog/lg,base`.split(`,`)),ne=/^@|&|&$/;function isCondition(e){return g.has(e)||ne.test(e)}const re=/^_/,ie=/&|@/;function finalizeConditions(e){return e.map(e=>g.has(e)?e.replace(re,``):ie.test(e)?`[${withoutSpace(e.trim())}]`:e)}function sortConditions(e){return e.sort((e,t)=>{let n=isCondition(e),r=isCondition(t);return n&&!r?1:!n&&r?-1:0})}const _=new Map,v=new Map;`aspectRatio:asp,boxDecorationBreak:bx-db,zIndex:z,boxSizing:bx-s,objectPosition:obj-p,objectFit:obj-f,overscrollBehavior:ovs-b,overscrollBehaviorX:ovs-bx,overscrollBehaviorY:ovs-by,position:pos/1,top:top,left:left,inset:inset,insetInline:inset-x/insetX,insetBlock:inset-y/insetY,insetBlockEnd:inset-be,insetBlockStart:inset-bs,insetInlineEnd:inset-e/insetEnd/end,insetInlineStart:inset-s/insetStart/start,right:right,bottom:bottom,float:float,visibility:vis,display:d,hideFrom:hide,hideBelow:show,flexBasis:flex-b,flex:flex,flexDirection:flex-d/flexDir,flexGrow:flex-g,flexShrink:flex-sh,gridTemplateColumns:grid-tc,gridTemplateRows:grid-tr,gridColumn:grid-c,gridRow:grid-r,gridColumnStart:grid-cs,gridColumnEnd:grid-ce,gridAutoFlow:grid-af,gridAutoColumns:grid-ac,gridAutoRows:grid-ar,gap:gap,gridGap:grid-g,gridRowGap:grid-rg,gridColumnGap:grid-cg,rowGap:rg,columnGap:cg,justifyContent:jc,alignContent:ac,alignItems:ai,alignSelf:as,padding:p/1,paddingLeft:pl/1,paddingRight:pr/1,paddingTop:pt/1,paddingBottom:pb/1,paddingBlock:py/1/paddingY,paddingBlockEnd:pbe,paddingBlockStart:pbs,paddingInline:px/paddingX/1,paddingInlineEnd:pe/1/paddingEnd,paddingInlineStart:ps/1/paddingStart,marginLeft:ml/1,marginRight:mr/1,marginTop:mt/1,marginBottom:mb/1,margin:m/1,marginBlock:my/1/marginY,marginBlockEnd:mbe,marginBlockStart:mbs,marginInline:mx/1/marginX,marginInlineEnd:me/1/marginEnd,marginInlineStart:ms/1/marginStart,spaceX:sx,spaceY:sy,outlineWidth:ring-w/ringWidth,outlineColor:ring-c/ringColor,outline:ring/1,outlineOffset:ring-o/ringOffset,focusRing:focus-ring,focusVisibleRing:focus-v-ring,focusRingColor:focus-ring-c,focusRingOffset:focus-ring-o,focusRingWidth:focus-ring-w,focusRingStyle:focus-ring-s,divideX:dvd-x,divideY:dvd-y,divideColor:dvd-c,divideStyle:dvd-s,width:w/1,inlineSize:w-is,minWidth:min-w/minW,minInlineSize:min-w-is,maxWidth:max-w/maxW,maxInlineSize:max-w-is,height:h/1,blockSize:h-bs,minHeight:min-h/minH,minBlockSize:min-h-bs,maxHeight:max-h/maxH,maxBlockSize:max-b,boxSize:size,color:c,fontFamily:ff,fontSize:fs,fontSizeAdjust:fs-a,fontPalette:fp,fontKerning:fk,fontFeatureSettings:ff-s,fontWeight:fw,fontSmoothing:fsmt,fontVariant:fv,fontVariantAlternates:fv-alt,fontVariantCaps:fv-caps,fontVariationSettings:fv-s,fontVariantNumeric:fv-num,letterSpacing:ls,lineHeight:lh,textAlign:ta,textDecoration:td,textDecorationColor:td-c,textEmphasisColor:te-c,textDecorationStyle:td-s,textDecorationThickness:td-t,textUnderlineOffset:tu-o,textTransform:tt,textIndent:ti,textShadow:tsh,textShadowColor:tsh-c/textShadowColor,WebkitTextFillColor:wktf-c,textOverflow:tov,verticalAlign:va,wordBreak:wb,textWrap:tw,truncate:trunc,lineClamp:lc,listStyleType:li-t,listStylePosition:li-pos,listStyleImage:li-img,listStyle:li-s,backgroundPosition:bg-p/bgPosition,backgroundPositionX:bg-p-x/bgPositionX,backgroundPositionY:bg-p-y/bgPositionY,backgroundAttachment:bg-a/bgAttachment,backgroundClip:bg-cp/bgClip,background:bg/1,backgroundColor:bg-c/bgColor,backgroundOrigin:bg-o/bgOrigin,backgroundImage:bg-i/bgImage,backgroundRepeat:bg-r/bgRepeat,backgroundBlendMode:bg-bm/bgBlendMode,backgroundSize:bg-s/bgSize,backgroundGradient:bg-grad/bgGradient,backgroundLinear:bg-linear/bgLinear,backgroundRadial:bg-radial/bgRadial,backgroundConic:bg-conic/bgConic,textGradient:txt-grad,gradientFromPosition:grad-from-pos,gradientToPosition:grad-to-pos,gradientFrom:grad-from,gradientTo:grad-to,gradientVia:grad-via,gradientViaPosition:grad-via-pos,borderRadius:bdr/rounded,borderTopLeftRadius:bdr-tl/roundedTopLeft,borderTopRightRadius:bdr-tr/roundedTopRight,borderBottomRightRadius:bdr-br/roundedBottomRight,borderBottomLeftRadius:bdr-bl/roundedBottomLeft,borderTopRadius:bdr-t/roundedTop,borderRightRadius:bdr-r/roundedRight,borderBottomRadius:bdr-b/roundedBottom,borderLeftRadius:bdr-l/roundedLeft,borderStartStartRadius:bdr-ss/roundedStartStart,borderStartEndRadius:bdr-se/roundedStartEnd,borderStartRadius:bdr-s/roundedStart,borderEndStartRadius:bdr-es/roundedEndStart,borderEndEndRadius:bdr-ee/roundedEndEnd,borderEndRadius:bdr-e/roundedEnd,border:bd,borderWidth:bd-w,borderTopWidth:bd-t-w,borderLeftWidth:bd-l-w,borderRightWidth:bd-r-w,borderBottomWidth:bd-b-w,borderBlockStartWidth:bd-bs-w,borderBlockEndWidth:bd-be-w,borderColor:bd-c,borderInline:bd-x/borderX,borderInlineWidth:bd-x-w/borderXWidth,borderInlineColor:bd-x-c/borderXColor,borderBlock:bd-y/borderY,borderBlockWidth:bd-y-w/borderYWidth,borderBlockColor:bd-y-c/borderYColor,borderLeft:bd-l,borderLeftColor:bd-l-c,borderInlineStart:bd-s/borderStart,borderInlineStartWidth:bd-s-w/borderStartWidth,borderInlineStartColor:bd-s-c/borderStartColor,borderRight:bd-r,borderRightColor:bd-r-c,borderInlineEnd:bd-e/borderEnd,borderInlineEndWidth:bd-e-w/borderEndWidth,borderInlineEndColor:bd-e-c/borderEndColor,borderTop:bd-t,borderTopColor:bd-t-c,borderBottom:bd-b,borderBottomColor:bd-b-c,borderBlockEnd:bd-be,borderBlockEndColor:bd-be-c,borderBlockStart:bd-bs,borderBlockStartColor:bd-bs-c,opacity:op,boxShadow:bx-sh/shadow,boxShadowColor:bx-sh-c/shadowColor,mixBlendMode:mix-bm,filter:filter,brightness:brightness,contrast:contrast,grayscale:grayscale,hueRotate:hue-rotate,invert:invert,saturate:saturate,sepia:sepia,dropShadow:drop-shadow,blur:blur,backdropFilter:bkdp,backdropBlur:bkdp-blur,backdropBrightness:bkdp-brightness,backdropContrast:bkdp-contrast,backdropGrayscale:bkdp-grayscale,backdropHueRotate:bkdp-hue-rotate,backdropInvert:bkdp-invert,backdropOpacity:bkdp-opacity,backdropSaturate:bkdp-saturate,backdropSepia:bkdp-sepia,borderCollapse:bd-cl,borderSpacing:bd-sp,borderSpacingX:bd-sx,borderSpacingY:bd-sy,tableLayout:tbl,transitionTimingFunction:trs-tmf,transitionDelay:trs-dly,transitionDuration:trs-dur,transitionProperty:trs-prop,transition:transition,animation:anim,animationName:anim-n,animationTimingFunction:anim-tmf,animationDuration:anim-dur,animationDelay:anim-dly,animationPlayState:anim-ps,animationComposition:anim-comp,animationFillMode:anim-fm,animationDirection:anim-dir,animationIterationCount:anim-ic,animationRange:anim-r,animationState:anim-s,animationRangeStart:anim-rs,animationRangeEnd:anim-re,animationTimeline:anim-tl,transformOrigin:trf-o,transformBox:trf-b,transformStyle:trf-s,transform:trf,rotate:rotate,rotateX:rotate-x,rotateY:rotate-y,rotateZ:rotate-z,scale:scale,scaleX:scale-x,scaleY:scale-y,translate:translate,translateX:translate-x/x,translateY:translate-y/y,translateZ:translate-z/z,accentColor:ac-c,caretColor:ca-c,scrollBehavior:scr-bhv,scrollbar:scr-bar,scrollbarColor:scr-bar-c,scrollbarGutter:scr-bar-g,scrollbarWidth:scr-bar-w,scrollMargin:scr-m,scrollMarginLeft:scr-ml,scrollMarginRight:scr-mr,scrollMarginTop:scr-mt,scrollMarginBottom:scr-mb,scrollMarginBlock:scr-my/scrollMarginY,scrollMarginBlockEnd:scr-mbe,scrollMarginBlockStart:scr-mbt,scrollMarginInline:scr-mx/scrollMarginX,scrollMarginInlineEnd:scr-me,scrollMarginInlineStart:scr-ms,scrollPadding:scr-p,scrollPaddingBlock:scr-py/scrollPaddingY,scrollPaddingBlockStart:scr-pbs,scrollPaddingBlockEnd:scr-pbe,scrollPaddingInline:scr-px/scrollPaddingX,scrollPaddingInlineEnd:scr-pe,scrollPaddingInlineStart:scr-ps,scrollPaddingLeft:scr-pl,scrollPaddingRight:scr-pr,scrollPaddingTop:scr-pt,scrollPaddingBottom:scr-pb,scrollSnapAlign:scr-sa,scrollSnapStop:scrs-s,scrollSnapType:scrs-t,scrollSnapStrictness:scrs-strt,scrollSnapMargin:scrs-m,scrollSnapMarginTop:scrs-mt,scrollSnapMarginBottom:scrs-mb,scrollSnapMarginLeft:scrs-ml,scrollSnapMarginRight:scrs-mr,scrollSnapCoordinate:scrs-c,scrollSnapDestination:scrs-d,scrollSnapPointsX:scrs-px,scrollSnapPointsY:scrs-py,scrollSnapTypeX:scrs-tx,scrollSnapTypeY:scrs-ty,scrollTimeline:scrtl,scrollTimelineAxis:scrtl-a,scrollTimelineName:scrtl-n,touchAction:tch-a,userSelect:us,overflow:ov,overflowWrap:ov-wrap,overflowX:ov-x,overflowY:ov-y,overflowAnchor:ov-a,overflowBlock:ov-b,overflowInline:ov-i,overflowClipBox:ovcp-bx,overflowClipMargin:ovcp-m,overscrollBehaviorBlock:ovs-bb,overscrollBehaviorInline:ovs-bi,fill:fill,stroke:stk,strokeWidth:stk-w,strokeDasharray:stk-dsh,strokeDashoffset:stk-do,strokeLinecap:stk-lc,strokeLinejoin:stk-lj,strokeMiterlimit:stk-ml,strokeOpacity:stk-op,srOnly:sr,debug:debug,appearance:ap,backfaceVisibility:bfv,clipPath:cp-path,hyphens:hy,mask:msk,maskImage:msk-i,maskSize:msk-s,textSizeAdjust:txt-adj,container:cq,containerName:cq-n,containerType:cq-t,cursor:cursor,textStyle:textStyle,layerStyle:layerStyle,animationStyle:animationStyle`.split(`,`).forEach(e=>{let[t,n]=e.split(`:`),[r,...i]=n.split(`/`);_.set(t,r),i.length&&i.forEach(e=>{v.set(e===`1`?r:e,t)})});const resolveShorthand=e=>v.get(e)||e,y={conditions:{shift:sortConditions,finalize:finalizeConditions,breakpoints:{keys:[`base`,`xs`,`sm`,`md`,`lg`,`xl`]}},utility:{transform:(e,t)=>{let n=resolveShorthand(e);return{className:`${_.get(n)||f(n)}_${withoutSpace(t)}`}},hasShorthand:!0,toHash:(e,t)=>t(e.join(`:`)),resolveShorthand}},ae=createCss(y),css=(...e)=>ae(b(...e));css.raw=(...e)=>b(...e);const{mergeCss:b,assignCss:oe}=createMergeCss(y);function cx(){let e=``,t=0,n;for(;t<arguments.length;)(n=arguments[t++])&&typeof n==`string`&&(e&&(e+=` `),e+=n);return e}const defaults=e=>({base:{},variants:{},defaultVariants:{},compoundVariants:[],...e});function cva(e){let{base:t,variants:n,defaultVariants:r,compoundVariants:i}=defaults(e),getVariantProps=e=>({...r,...compact(e)});function resolve(e={}){let r=getVariantProps(e),a={...t};for(let[e,t]of Object.entries(r))n[e]?.[t]&&(a=b(a,n[e][t]));let o=getCompoundVariantCss(i,r);return b(a,o)}function merge(e){let a=defaults(e.config),o=uniq(e.variantKeys,Object.keys(n));return cva({base:b(t,a.base),variants:Object.fromEntries(o.map(e=>[e,b(n[e],a.variants[e])])),defaultVariants:mergeProps(r,a.defaultVariants),compoundVariants:[...i,...a.compoundVariants]})}function cvaFn(e){return css(resolve(e))}let a=Object.keys(n);function splitVariantProps(e){return splitProps(e,a)}let o=Object.fromEntries(Object.entries(n).map(([e,t])=>[e,Object.keys(t)]));return Object.assign(s(cvaFn),{__cva__:!0,variantMap:o,variantKeys:a,raw:resolve,config:e,merge,splitVariantProps,getVariantProps})}function getCompoundVariantCss(e,t){let n={};return e.forEach(e=>{Object.entries(e).every(([e,n])=>e===`css`?!0:(Array.isArray(n)?n:[n]).some(n=>t[e]===n))&&(n=b(n,e.css))}),n}function assertCompoundVariant(e,t,n,r){if(t.length>0&&typeof n?.[r]==`object`)throw Error(`[recipe:${e}:${r}] Conditions are not supported when using compound variants.`)}function sva(e){let t=Object.entries(getSlotRecipes(e)).map(([e,t])=>[e,cva(t)]),n=e.defaultVariants??{},r=t.reduce((t,[n,r])=>(e.className&&(t[n]=r.config.className),t),{});function svaFn(e){let n=t.map(([t,n])=>[t,cx(n(e),r[t])]);return Object.fromEntries(n)}function raw(e){let n=t.map(([t,n])=>[t,n.raw(e)]);return Object.fromEntries(n)}let i=e.variants??{},a=Object.keys(i);function splitVariantProps(e){return splitProps(e,a)}let getVariantProps=e=>({...n,...compact(e)}),o=Object.fromEntries(Object.entries(i).map(([e,t])=>[e,Object.keys(t)]));return Object.assign(s(svaFn),{__cva__:!1,raw,config:e,variantMap:o,variantKeys:a,classNameMap:r,splitVariantProps,getVariantProps})}var se=`css,pos,insetX,insetY,insetEnd,end,insetStart,start,flexDir,p,pl,pr,pt,pb,py,paddingY,paddingX,px,pe,paddingEnd,ps,paddingStart,ml,mr,mt,mb,m,my,marginY,mx,marginX,me,marginEnd,ms,marginStart,ringWidth,ringColor,ring,ringOffset,w,minW,maxW,h,minH,maxH,textShadowColor,bgPosition,bgPositionX,bgPositionY,bgAttachment,bgClip,bg,bgColor,bgOrigin,bgImage,bgRepeat,bgBlendMode,bgSize,bgGradient,bgLinear,bgRadial,bgConic,rounded,roundedTopLeft,roundedTopRight,roundedBottomRight,roundedBottomLeft,roundedTop,roundedRight,roundedBottom,roundedLeft,roundedStartStart,roundedStartEnd,roundedStart,roundedEndStart,roundedEndEnd,roundedEnd,borderX,borderXWidth,borderXColor,borderY,borderYWidth,borderYColor,borderStart,borderStartWidth,borderStartColor,borderEnd,borderEndWidth,borderEndColor,shadow,shadowColor,x,y,z,scrollMarginY,scrollMarginX,scrollPaddingY,scrollPaddingX,aspectRatio,boxDecorationBreak,zIndex,boxSizing,objectPosition,objectFit,overscrollBehavior,overscrollBehaviorX,overscrollBehaviorY,position,top,left,inset,insetInline,insetBlock,insetBlockEnd,insetBlockStart,insetInlineEnd,insetInlineStart,right,bottom,float,visibility,display,hideFrom,hideBelow,flexBasis,flex,flexDirection,flexGrow,flexShrink,gridTemplateColumns,gridTemplateRows,gridColumn,gridRow,gridColumnStart,gridColumnEnd,gridAutoFlow,gridAutoColumns,gridAutoRows,gap,gridGap,gridRowGap,gridColumnGap,rowGap,columnGap,justifyContent,alignContent,alignItems,alignSelf,padding,paddingLeft,paddingRight,paddingTop,paddingBottom,paddingBlock,paddingBlockEnd,paddingBlockStart,paddingInline,paddingInlineEnd,paddingInlineStart,marginLeft,marginRight,marginTop,marginBottom,margin,marginBlock,marginBlockEnd,marginBlockStart,marginInline,marginInlineEnd,marginInlineStart,spaceX,spaceY,outlineWidth,outlineColor,outline,outlineOffset,focusRing,focusVisibleRing,focusRingColor,focusRingOffset,focusRingWidth,focusRingStyle,divideX,divideY,divideColor,divideStyle,width,inlineSize,minWidth,minInlineSize,maxWidth,maxInlineSize,height,blockSize,minHeight,minBlockSize,maxHeight,maxBlockSize,boxSize,color,fontFamily,fontSize,fontSizeAdjust,fontPalette,fontKerning,fontFeatureSettings,fontWeight,fontSmoothing,fontVariant,fontVariantAlternates,fontVariantCaps,fontVariationSettings,fontVariantNumeric,letterSpacing,lineHeight,textAlign,textDecoration,textDecorationColor,textEmphasisColor,textDecorationStyle,textDecorationThickness,textUnderlineOffset,textTransform,textIndent,textShadow,WebkitTextFillColor,textOverflow,verticalAlign,wordBreak,textWrap,truncate,lineClamp,listStyleType,listStylePosition,listStyleImage,listStyle,backgroundPosition,backgroundPositionX,backgroundPositionY,backgroundAttachment,backgroundClip,background,backgroundColor,backgroundOrigin,backgroundImage,backgroundRepeat,backgroundBlendMode,backgroundSize,backgroundGradient,backgroundLinear,backgroundRadial,backgroundConic,textGradient,gradientFromPosition,gradientToPosition,gradientFrom,gradientTo,gradientVia,gradientViaPosition,borderRadius,borderTopLeftRadius,borderTopRightRadius,borderBottomRightRadius,borderBottomLeftRadius,borderTopRadius,borderRightRadius,borderBottomRadius,borderLeftRadius,borderStartStartRadius,borderStartEndRadius,borderStartRadius,borderEndStartRadius,borderEndEndRadius,borderEndRadius,border,borderWidth,borderTopWidth,borderLeftWidth,borderRightWidth,borderBottomWidth,borderBlockStartWidth,borderBlockEndWidth,borderColor,borderInline,borderInlineWidth,borderInlineColor,borderBlock,borderBlockWidth,borderBlockColor,borderLeft,borderLeftColor,borderInlineStart,borderInlineStartWidth,borderInlineStartColor,borderRight,borderRightColor,borderInlineEnd,borderInlineEndWidth,borderInlineEndColor,borderTop,borderTopColor,borderBottom,borderBottomColor,borderBlockEnd,borderBlockEndColor,borderBlockStart,borderBlockStartColor,opacity,boxShadow,boxShadowColor,mixBlendMode,filter,brightness,contrast,grayscale,hueRotate,invert,saturate,sepia,dropShadow,blur,backdropFilter,backdropBlur,backdropBrightness,backdropContrast,backdropGrayscale,backdropHueRotate,backdropInvert,backdropOpacity,backdropSaturate,backdropSepia,borderCollapse,borderSpacing,borderSpacingX,borderSpacingY,tableLayout,transitionTimingFunction,transitionDelay,transitionDuration,transitionProperty,transition,animation,animationName,animationTimingFunction,animationDuration,animationDelay,animationPlayState,animationComposition,animationFillMode,animationDirection,animationIterationCount,animationRange,animationState,animationRangeStart,animationRangeEnd,animationTimeline,transformOrigin,transformBox,transformStyle,transform,rotate,rotateX,rotateY,rotateZ,scale,scaleX,scaleY,translate,translateX,translateY,translateZ,accentColor,caretColor,scrollBehavior,scrollbar,scrollbarColor,scrollbarGutter,scrollbarWidth,scrollMargin,scrollMarginLeft,scrollMarginRight,scrollMarginTop,scrollMarginBottom,scrollMarginBlock,scrollMarginBlockEnd,scrollMarginBlockStart,scrollMarginInline,scrollMarginInlineEnd,scrollMarginInlineStart,scrollPadding,scrollPaddingBlock,scrollPaddingBlockStart,scrollPaddingBlockEnd,scrollPaddingInline,scrollPaddingInlineEnd,scrollPaddingInlineStart,scrollPaddingLeft,scrollPaddingRight,scrollPaddingTop,scrollPaddingBottom,scrollSnapAlign,scrollSnapStop,scrollSnapType,scrollSnapStrictness,scrollSnapMargin,scrollSnapMarginTop,scrollSnapMarginBottom,scrollSnapMarginLeft,scrollSnapMarginRight,scrollSnapCoordinate,scrollSnapDestination,scrollSnapPointsX,scrollSnapPointsY,scrollSnapTypeX,scrollSnapTypeY,scrollTimeline,scrollTimelineAxis,scrollTimelineName,touchAction,userSelect,overflow,overflowWrap,overflowX,overflowY,overflowAnchor,overflowBlock,overflowInline,overflowClipBox,overflowClipMargin,overscrollBehaviorBlock,overscrollBehaviorInline,fill,stroke,strokeWidth,strokeDasharray,strokeDashoffset,strokeLinecap,strokeLinejoin,strokeMiterlimit,strokeOpacity,srOnly,debug,appearance,backfaceVisibility,clipPath,hyphens,mask,maskImage,maskSize,textSizeAdjust,container,containerName,containerType,cursor,colorPalette,_hover,_focus,_focusWithin,_focusVisible,_disabled,_active,_visited,_target,_readOnly,_readWrite,_empty,_checked,_enabled,_expanded,_highlighted,_complete,_incomplete,_dragging,_before,_after,_firstLetter,_firstLine,_marker,_selection,_file,_backdrop,_first,_last,_only,_even,_odd,_firstOfType,_lastOfType,_onlyOfType,_peerFocus,_peerHover,_peerActive,_peerFocusWithin,_peerFocusVisible,_peerDisabled,_peerChecked,_peerInvalid,_peerExpanded,_peerPlaceholderShown,_groupFocus,_groupHover,_groupActive,_groupFocusWithin,_groupFocusVisible,_groupDisabled,_groupChecked,_groupExpanded,_groupInvalid,_indeterminate,_required,_valid,_invalid,_autofill,_inRange,_outOfRange,_placeholder,_placeholderShown,_pressed,_selected,_grabbed,_underValue,_overValue,_atValue,_default,_optional,_open,_closed,_fullscreen,_loading,_hidden,_current,_currentPage,_currentStep,_today,_unavailable,_rangeStart,_rangeEnd,_now,_topmost,_motionReduce,_motionSafe,_print,_landscape,_portrait,_dark,_light,_osDark,_osLight,_highContrast,_lessContrast,_moreContrast,_ltr,_rtl,_scrollbar,_scrollbarThumb,_scrollbarTrack,_horizontal,_vertical,_icon,_starting,_noscript,_invertedColors,_shapeSizeXs,_shapeSizeSm,_shapeSizeMd,_shapeSizeLg,_shapeSizeXl,_shapeRectangle,_shapePerson,_shapeBrowser,_shapeMobile,_shapeCylinder,_shapeStorage,_shapeQueue,_shapeBucket,_shapeDocument,_shapeComponent,_notDisabled,_reduceGraphics,_reduceGraphicsOnPan,_noReduceGraphics,_whenPanning,_smallZoom,_compoundTransparent,_edgeActive,_whenHovered,_whenSelectable,_whenSelected,_whenDimmed,_whenFocused,_p3,xs,xsOnly,xsDown,sm,smOnly,smDown,md,mdOnly,mdDown,lg,lgOnly,lgDown,xl,xlOnly,xlDown,xsToSm,xsToMd,xsToLg,xsToXl,smToMd,smToLg,smToXl,mdToLg,mdToXl,lgToXl,@/xs,@/sm,@/md,@/lg,@likec4-root/xs,@likec4-root/sm,@likec4-root/md,@likec4-root/lg,@likec4-dialog/xs,@likec4-dialog/sm,@likec4-dialog/md,@likec4-dialog/lg,textStyle,layerStyle,animationStyle`.split(`,`),ce=`WebkitAppearance,WebkitBorderBefore,WebkitBorderBeforeColor,WebkitBorderBeforeStyle,WebkitBorderBeforeWidth,WebkitBoxReflect,WebkitLineClamp,WebkitMask,WebkitMaskAttachment,WebkitMaskClip,WebkitMaskComposite,WebkitMaskImage,WebkitMaskOrigin,WebkitMaskPosition,WebkitMaskPositionX,WebkitMaskPositionY,WebkitMaskRepeat,WebkitMaskRepeatX,WebkitMaskRepeatY,WebkitMaskSize,WebkitOverflowScrolling,WebkitTapHighlightColor,WebkitTextFillColor,WebkitTextStroke,WebkitTextStrokeColor,WebkitTextStrokeWidth,WebkitTouchCallout,WebkitUserModify,WebkitUserSelect,accentColor,alignContent,alignItems,alignSelf,alignTracks,all,anchorName,anchorScope,animation,animationComposition,animationDelay,animationDirection,animationDuration,animationFillMode,animationIterationCount,animationName,animationPlayState,animationRange,animationRangeEnd,animationRangeStart,animationTimeline,animationTimingFunction,appearance,aspectRatio,backdropFilter,backfaceVisibility,background,backgroundAttachment,backgroundBlendMode,backgroundClip,backgroundColor,backgroundImage,backgroundOrigin,backgroundPosition,backgroundPositionX,backgroundPositionY,backgroundRepeat,backgroundSize,blockSize,border,borderBlock,borderBlockColor,borderBlockEnd,borderBlockEndColor,borderBlockEndStyle,borderBlockEndWidth,borderBlockStart,borderBlockStartColor,borderBlockStartStyle,borderBlockStartWidth,borderBlockStyle,borderBlockWidth,borderBottom,borderBottomColor,borderBottomLeftRadius,borderBottomRightRadius,borderBottomStyle,borderBottomWidth,borderCollapse,borderColor,borderEndEndRadius,borderEndStartRadius,borderImage,borderImageOutset,borderImageRepeat,borderImageSlice,borderImageSource,borderImageWidth,borderInline,borderInlineColor,borderInlineEnd,borderInlineEndColor,borderInlineEndStyle,borderInlineEndWidth,borderInlineStart,borderInlineStartColor,borderInlineStartStyle,borderInlineStartWidth,borderInlineStyle,borderInlineWidth,borderLeft,borderLeftColor,borderLeftStyle,borderLeftWidth,borderRadius,borderRight,borderRightColor,borderRightStyle,borderRightWidth,borderSpacing,borderStartEndRadius,borderStartStartRadius,borderStyle,borderTop,borderTopColor,borderTopLeftRadius,borderTopRightRadius,borderTopStyle,borderTopWidth,borderWidth,bottom,boxAlign,boxDecorationBreak,boxDirection,boxFlex,boxFlexGroup,boxLines,boxOrdinalGroup,boxOrient,boxPack,boxShadow,boxSizing,breakAfter,breakBefore,breakInside,captionSide,caret,caretColor,caretShape,clear,clip,clipPath,clipRule,color,colorInterpolationFilters,colorScheme,columnCount,columnFill,columnGap,columnRule,columnRuleColor,columnRuleStyle,columnRuleWidth,columnSpan,columnWidth,columns,contain,containIntrinsicBlockSize,containIntrinsicHeight,containIntrinsicInlineSize,containIntrinsicSize,containIntrinsicWidth,container,containerName,containerType,content,contentVisibility,cornerShape,counterIncrement,counterReset,counterSet,cursor,cx,cy,d,direction,display,dominantBaseline,emptyCells,fieldSizing,fill,fillOpacity,fillRule,filter,flex,flexBasis,flexDirection,flexFlow,flexGrow,flexShrink,flexWrap,float,floodColor,floodOpacity,font,fontFamily,fontFeatureSettings,fontKerning,fontLanguageOverride,fontOpticalSizing,fontPalette,fontSize,fontSizeAdjust,fontSmooth,fontStretch,fontStyle,fontSynthesis,fontSynthesisPosition,fontSynthesisSmallCaps,fontSynthesisStyle,fontSynthesisWeight,fontVariant,fontVariantAlternates,fontVariantCaps,fontVariantEastAsian,fontVariantEmoji,fontVariantLigatures,fontVariantNumeric,fontVariantPosition,fontVariationSettings,fontWeight,forcedColorAdjust,gap,grid,gridArea,gridAutoColumns,gridAutoFlow,gridAutoRows,gridColumn,gridColumnEnd,gridColumnGap,gridColumnStart,gridGap,gridRow,gridRowEnd,gridRowGap,gridRowStart,gridTemplate,gridTemplateAreas,gridTemplateColumns,gridTemplateRows,hangingPunctuation,height,hyphenateCharacter,hyphenateLimitChars,hyphens,imageOrientation,imageRendering,imageResolution,imeMode,initialLetter,initialLetterAlign,inlineSize,inset,insetBlock,insetBlockEnd,insetBlockStart,insetInline,insetInlineEnd,insetInlineStart,interpolateSize,isolation,justifyContent,justifyItems,justifySelf,justifyTracks,left,letterSpacing,lightingColor,lineBreak,lineClamp,lineHeight,lineHeightStep,listStyle,listStyleImage,listStylePosition,listStyleType,margin,marginBlock,marginBlockEnd,marginBlockStart,marginBottom,marginInline,marginInlineEnd,marginInlineStart,marginLeft,marginRight,marginTop,marginTrim,marker,markerEnd,markerMid,markerStart,mask,maskBorder,maskBorderMode,maskBorderOutset,maskBorderRepeat,maskBorderSlice,maskBorderSource,maskBorderWidth,maskClip,maskComposite,maskImage,maskMode,maskOrigin,maskPosition,maskRepeat,maskSize,maskType,masonryAutoFlow,mathDepth,mathShift,mathStyle,maxBlockSize,maxHeight,maxInlineSize,maxLines,maxWidth,minBlockSize,minHeight,minInlineSize,minWidth,mixBlendMode,objectFit,objectPosition,offset,offsetAnchor,offsetDistance,offsetPath,offsetPosition,offsetRotate,opacity,order,orphans,outline,outlineColor,outlineOffset,outlineStyle,outlineWidth,overflow,overflowAnchor,overflowBlock,overflowClipBox,overflowClipMargin,overflowInline,overflowWrap,overflowX,overflowY,overlay,overscrollBehavior,overscrollBehaviorBlock,overscrollBehaviorInline,overscrollBehaviorX,overscrollBehaviorY,padding,paddingBlock,paddingBlockEnd,paddingBlockStart,paddingBottom,paddingInline,paddingInlineEnd,paddingInlineStart,paddingLeft,paddingRight,paddingTop,page,pageBreakAfter,pageBreakBefore,pageBreakInside,paintOrder,perspective,perspectiveOrigin,placeContent,placeItems,placeSelf,pointerEvents,position,positionAnchor,positionArea,positionTry,positionTryFallbacks,positionTryOrder,positionVisibility,printColorAdjust,quotes,r,resize,right,rotate,rowGap,rubyAlign,rubyMerge,rubyPosition,rx,ry,scale,scrollBehavior,scrollMargin,scrollMarginBlock,scrollMarginBlockEnd,scrollMarginBlockStart,scrollMarginBottom,scrollMarginInline,scrollMarginInlineEnd,scrollMarginInlineStart,scrollMarginLeft,scrollMarginRight,scrollMarginTop,scrollPadding,scrollPaddingBlock,scrollPaddingBlockEnd,scrollPaddingBlockStart,scrollPaddingBottom,scrollPaddingInline,scrollPaddingInlineEnd,scrollPaddingInlineStart,scrollPaddingLeft,scrollPaddingRight,scrollPaddingTop,scrollSnapAlign,scrollSnapCoordinate,scrollSnapDestination,scrollSnapPointsX,scrollSnapPointsY,scrollSnapStop,scrollSnapType,scrollSnapTypeX,scrollSnapTypeY,scrollTimeline,scrollTimelineAxis,scrollTimelineName,scrollbarColor,scrollbarGutter,scrollbarWidth,shapeImageThreshold,shapeMargin,shapeOutside,shapeRendering,stopColor,stopOpacity,stroke,strokeDasharray,strokeDashoffset,strokeLinecap,strokeLinejoin,strokeMiterlimit,strokeOpacity,strokeWidth,tabSize,tableLayout,textAlign,textAlignLast,textAnchor,textBox,textBoxEdge,textBoxTrim,textCombineUpright,textDecoration,textDecorationColor,textDecorationLine,textDecorationSkip,textDecorationSkipInk,textDecorationStyle,textDecorationThickness,textEmphasis,textEmphasisColor,textEmphasisPosition,textEmphasisStyle,textIndent,textJustify,textOrientation,textOverflow,textRendering,textShadow,textSizeAdjust,textSpacingTrim,textTransform,textUnderlineOffset,textUnderlinePosition,textWrap,textWrapMode,textWrapStyle,timelineScope,top,touchAction,transform,transformBox,transformOrigin,transformStyle,transition,transitionBehavior,transitionDelay,transitionDuration,transitionProperty,transitionTimingFunction,translate,unicodeBidi,userSelect,vectorEffect,verticalAlign,viewTimeline,viewTimelineAxis,viewTimelineInset,viewTimelineName,viewTransitionName,visibility,whiteSpace,whiteSpaceCollapse,widows,width,willChange,wordBreak,wordSpacing,wordWrap,writingMode,x,y,zIndex,zoom,alignmentBaseline,baselineShift,colorInterpolation,colorRendering,glyphOrientationVertical`.split(`,`).concat(se),le=new Map(ce.map(e=>[e,!0])),ue=/&|@/,x=s(e=>le.has(e)||e.startsWith(`--`)||ue.test(e));const defaultShouldForwardProp=(e,t)=>!t.includes(e)&&!x(e),composeShouldForwardProps=(e,t)=>e.__shouldForwardProps__&&t?n=>e.__shouldForwardProps__(n)&&t(n):t,composeCvaFn=(e,t)=>{if(e&&!t)return e;if(!e&&t)return t;if(e.__cva__&&t.__cva__||e.__recipe__&&t.__recipe__)return e.merge(t);let n=TypeError(`Cannot merge cva with recipe. Please use either cva or recipe.`);throw TypeError.captureStackTrace?.(n),n},getDisplayName=e=>typeof e==`string`?e:e?.displayName||e?.name||`Component`;function styledFn(e,t={},i={}){let o=t.__cva__||t.__recipe__?t:cva(t),s=i.shouldForwardProp||defaultShouldForwardProp,shouldForwardProp=e=>i.forwardProps?.includes(e)?!0:s(e,o.variantKeys),c=Object.assign(i.dataAttr&&t.__name__?{"data-recipe":t.__name__}:{},i.defaultProps),l=composeCvaFn(e.__cva__,o),u=composeShouldForwardProps(e,shouldForwardProp),d=e.__base__||e,f=r(function StyledComponent(e,r){let{as:i=d,unstyled:o,children:s,...f}=e,p=a(()=>Object.assign({},c,f),[f]),[ee,te,m,h,g]=a(()=>splitProps(p,normalizeHTMLProps.keys,u,l.variantKeys,x),[p]);function recipeClass(){let{css:e,...t}=h,n=l.__getCompoundVariantCss__?.(m);return cx(l(m,!1),css(n,t,e),p.className)}function cvaClass(){let{css:e,...t}=h;return cx(css(l.raw(m),t,e),p.className)}let classes=()=>{if(o){let{css:e,...t}=h;return cx(css(t,e),p.className)}return t.__recipe__?recipeClass():cvaClass()};return n(i,{ref:r,...te,...g,...normalizeHTMLProps(ee),className:classes()},s??p.children)});return f.displayName=`styled.${getDisplayName(d)}`,f.__cva__=l,f.__base__=d,f.__shouldForwardProps__=shouldForwardProp,f}function createJsxFactory(){let e=new Map;return new Proxy(styledFn,{apply(e,t,n){return styledFn(...n)},get(t,n){return e.has(n)||e.set(n,styledFn(n)),e.get(n)}})}const S=createJsxFactory();function createSafeContext(e){let n=t(void 0),useStyleContext=(t,r)=>{let a=i(n);if(a===void 0){let n=t?`Component "${t}"`:`A component`,i=r?` (slot: "${r}")`:``;throw Error(`${n}${i} cannot access ${e} because it's missing its Provider.`)}return a};return[n,useStyleContext]}function createStyleContext(e){let t=`__recipe__`in e,i=t&&e.__name__?e.__name__:void 0,[a,o]=createSafeContext(i?`createStyleContext("${i}")`:`createStyleContext`),s=t?e:sva(e.config),getResolvedProps=(e,n)=>{let{unstyled:r,...i}=e;return r?i:t?{...i,className:cx(n,i.className)}:{...n,...i}},withRootProvider=(e,r)=>{let WithRootProvider=i=>{let[o,c]=s.splitVariantProps(i),l=t?s(o):s.raw(o);l._classNameMap=s.classNameMap;let u=r?.defaultProps?{...r.defaultProps,...c}:c;return n(a.Provider,{value:l,children:n(e,u)})};return WithRootProvider.displayName=`withRootProvider(${getDisplayName(e)})`,WithRootProvider},withProvider=(e,i,o)=>{let c=S(e,{},o),l=r((e,r)=>{let[l,u]=s.splitVariantProps(e),d=t?s(l):s.raw(l);d._classNameMap=s.classNameMap;let f=getResolvedProps({...u,className:u.className??o?.defaultProps?.className},d[i]);return n(a.Provider,{value:d,children:n(c,{...f,className:cx(f.className,d._classNameMap[i]),ref:r})})});return l.displayName=`withProvider(${getDisplayName(e)})`,l},withContext=(e,t,i)=>{let a=S(e,{},i),s=getDisplayName(e),c=r((e,r)=>{let c=o(s,t),l=getResolvedProps({...e,className:e.className??i?.defaultProps?.className},c[t]);return n(a,{...l,className:cx(l.className,c._classNameMap[t]),ref:r})});return c.displayName=`withContext(${s})`,c};return{withRootProvider,withProvider,withContext}}const de={transform(e){return e}},getBoxStyle=(e={})=>{let t=getPatternStyles(de,e);return de.transform(t,m)},box=e=>css(getBoxStyle(e));box.raw=getBoxStyle;const fe=r(function Box(e,t){let[r,i]=splitProps(e,[]),a={ref:t,...getBoxStyle(r),...i};return n(S.div,a)}),C={transform(e){let{direction:t,align:n,justify:r,wrap:i,basis:a,grow:o,shrink:s,...c}=e;return{display:`flex`,flexDirection:t,alignItems:n,justifyContent:r,flexWrap:i,flexBasis:a,flexGrow:o,flexShrink:s,...c}}},getFlexStyle=(e={})=>{let t=getPatternStyles(C,e);return C.transform(t,m)},flex=e=>css(getFlexStyle(e));flex.raw=getFlexStyle;const pe=r(function Flex(e,t){let[r,i]=splitProps(e,[`align`,`justify`,`direction`,`wrap`,`basis`,`grow`,`shrink`]),a={ref:t,...getFlexStyle(r),...i};return n(S.div,a)}),w={transform(e){let{justify:t,gap:n,...r}=e;return{display:`flex`,alignItems:`center`,justifyContent:t,gap:n,flexDirection:`column`,...r}},defaultValues:{alignItems:`stretch`,gap:`sm`}},getVstackStyle=(e={})=>{let t=getPatternStyles(w,e);return w.transform(t,m)},vstack=e=>css(getVstackStyle(e));vstack.raw=getVstackStyle;const me=r(function VStack(e,t){let[r,i]=splitProps(e,[`justify`,`gap`]),a={ref:t,...getVstackStyle(r),...i};return n(S.div,a)}),T={transform(e){let{justify:t,gap:n,...r}=e;return{display:`flex`,alignItems:`center`,justifyContent:t,gap:n,flexDirection:`row`,...r}},defaultValues:{gap:`sm`}},getHstackStyle=(e={})=>{let t=getPatternStyles(T,e);return T.transform(t,m)},hstack=e=>css(getHstackStyle(e));hstack.raw=getHstackStyle;const he=r(function HStack(e,t){let[r,i]=splitProps(e,[`justify`,`gap`]),a={ref:t,...getHstackStyle(r),...i};return n(S.div,a)}),E={transform(e){return{position:`relative`,maxWidth:`8xl`,mx:`auto`,px:{base:`4`,md:`6`,lg:`8`},...e}}},getContainerStyle=(e={})=>{let t=getPatternStyles(E,e);return E.transform(t,m)},container=e=>css(getContainerStyle(e));container.raw=getContainerStyle;const D={transform(e,{map:t,isCssUnit:n,isCssVar:r}){let{inline:i,block:a,...o}=e,valueFn=e=>n(e)||r(e)?e:`token(spacing.${e}, ${e})`;return{"--bleed-x":t(i,valueFn),"--bleed-y":t(a,valueFn),marginInline:`calc(var(--bleed-x, 0) * -1)`,marginBlock:`calc(var(--bleed-y, 0) * -1)`,...o}},defaultValues:{inline:`0`,block:`0`}},getBleedStyle=(e={})=>{let t=getPatternStyles(D,e);return D.transform(t,m)},bleed=e=>css(getBleedStyle(e));bleed.raw=getBleedStyle;const O={transform(e,t){let{inline:n,size:r,dimmed:i,lh:a,likec4color:o,...s}=e;if(i&&o)throw Error(`dimmed and likec4color are mutually exclusive`);return{userSelect:`all`,cursor:`default`,textStyle:i?`dimmed.${r}`:r,...n&&{display:`inline-block`},...a&&{lineHeight:a},...o&&{"data-likec4-color":o},...s}},defaultValues:{inline:!1,dimmed:!1,size:`md`}},getTxtStyle=(e={})=>{let t=getPatternStyles(O,e);return O.transform(t,m)},txt=e=>css(getTxtStyle(e));txt.raw=getTxtStyle;const ge=r(function Txt(e,t){let[r,i]=splitProps(e,[`inline`,`dimmed`,`lh`,`size`,`likec4color`]),a={ref:t,...getTxtStyle(r),...i};return n(S.div,a)}),createRecipe=(e,t,n)=>{let getVariantProps=n=>({[e]:`__ignore__`,...t,...compact(n)}),recipeFn=(t,r=!0)=>{let transform=(r,i)=>(assertCompoundVariant(e,n,t,r),i===`__ignore__`?{className:e}:(i=withoutSpace(i),{className:`${e}--${r}_${i}`})),i=createCss({conditions:{shift:sortConditions,finalize:finalizeConditions,breakpoints:{keys:[`base`,`xs`,`sm`,`md`,`lg`,`xl`]}},utility:{toHash:(e,t)=>t(e.join(`:`)),transform}}),a=getVariantProps(t);if(r){let e=getCompoundVariantCss(n,a);return cx(i(a),css(e))}return i(a)};return{recipeFn,getVariantProps,__getCompoundVariantCss__:e=>getCompoundVariantCss(n,getVariantProps(e))}},mergeRecipes=(e,t)=>{if(e&&!t)return e;if(!e&&t)return t;let recipeFn=(...n)=>cx(e(...n),t(...n)),n=uniq(e.variantKeys,t.variantKeys),r=n.reduce((n,r)=>(n[r]=uniq(e.variantMap[r],t.variantMap[r]),n),{});return Object.assign(recipeFn,{__recipe__:!0,__name__:`${e.__name__} ${t.__name__}`,raw:e=>e,variantKeys:n,variantMap:r,splitVariantProps(e){return splitProps(e,n)}})},k=createRecipe(`action-btn`,{size:`md`,radius:`md`,variant:`filled`},[]),A={variant:[`transparent`,`filled`],size:[`sm`,`md`],radius:[`sm`,`md`]},j=Object.keys(A),_e=Object.assign(s(k.recipeFn),{__recipe__:!0,__name__:`actionBtn`,__getCompoundVariantCss__:k.__getCompoundVariantCss__,raw:e=>e,variantKeys:j,variantMap:A,merge(e){return mergeRecipes(this,e)},splitVariantProps(e){return splitProps(e,j)},getVariantProps:k.getVariantProps}),M=createRecipe(`action-buttons`,{},[]),N={},P=Object.keys(N),ve=Object.assign(s(M.recipeFn),{__recipe__:!0,__name__:`actionButtons`,__getCompoundVariantCss__:M.__getCompoundVariantCss__,raw:e=>e,variantKeys:P,variantMap:N,merge(e){return mergeRecipes(this,e)},splitVariantProps(e){return splitProps(e,P)},getVariantProps:M.getVariantProps}),F=createRecipe(`likec4-compound-node`,{isTransparent:!1,inverseColor:!1,borderStyle:`none`},[]),I={isTransparent:[`false`,`true`],inverseColor:[`true`,`false`],borderStyle:[`solid`,`dashed`,`dotted`,`none`]},L=Object.keys(I),ye=Object.assign(s(F.recipeFn),{__recipe__:!0,__name__:`compoundNode`,__getCompoundVariantCss__:F.__getCompoundVariantCss__,raw:e=>e,variantKeys:L,variantMap:I,merge(e){return mergeRecipes(this,e)},splitVariantProps(e){return splitProps(e,L)},getVariantProps:F.getVariantProps}),R=createRecipe(`likec4-edge-action-btn`,{},[]),z={},B=Object.keys(z),be=Object.assign(s(R.recipeFn),{__recipe__:!0,__name__:`edgeActionBtn`,__getCompoundVariantCss__:R.__getCompoundVariantCss__,raw:e=>e,variantKeys:B,variantMap:z,merge(e){return mergeRecipes(this,e)},splitVariantProps(e){return splitProps(e,B)},getVariantProps:R.getVariantProps}),V=createRecipe(`likec4-edge-label`,{pointerEvents:`all`,isStepEdge:!1,cursor:`default`},[]),H={pointerEvents:[`none`,`all`],cursor:[`pointer`,`default`],isStepEdge:[`false`,`true`]},U=Object.keys(H),xe=Object.assign(s(V.recipeFn),{__recipe__:!0,__name__:`edgeLabel`,__getCompoundVariantCss__:V.__getCompoundVariantCss__,raw:e=>e,variantKeys:U,variantMap:H,merge(e){return mergeRecipes(this,e)},splitVariantProps(e){return splitProps(e,U)},getVariantProps:V.getVariantProps}),Se={},Ce=[],we=[[`path`,`likec4-edge__path`],[`pathBg`,`likec4-edge__pathBg`],[`markersCtx`,`likec4-edge__markersCtx`],[`middlePoint`,`likec4-edge__middlePoint`]].map(([e,t])=>[e,createRecipe(t,Se,getSlotCompoundVariant(Ce,e))]),Te=s((e={})=>Object.fromEntries(we.map(([t,n])=>[t,n.recipeFn(e)]))),Ee=[],De=Object.assign(Te,{__recipe__:!1,__name__:`edgePath`,raw:e=>e,classNameMap:{},variantKeys:Ee,variantMap:{},splitVariantProps(e){return splitProps(e,Ee)},getVariantProps:e(e=>({...Se,...compact(e)}),`getVariantProps`)}),W=createRecipe(`likec4-element-node`,{},[]),Oe={},ke=Object.keys(Oe),Ae=Object.assign(s(W.recipeFn),{__recipe__:!0,__name__:`elementNode`,__getCompoundVariantCss__:W.__getCompoundVariantCss__,raw:e=>e,variantKeys:ke,variantMap:Oe,merge(e){return mergeRecipes(this,e)},splitVariantProps(e){return splitProps(e,ke)},getVariantProps:W.getVariantProps}),G=createRecipe(`likec4-element-node-data`,{iconPosition:`left`,withIconColor:!1},[]),je={iconPosition:[`left`,`right`,`top`,`bottom`],withIconColor:[`true`,`false`]},Me=Object.keys(je),Ne=Object.assign(s(G.recipeFn),{__recipe__:!0,__name__:`elementNodeData`,__getCompoundVariantCss__:G.__getCompoundVariantCss__,raw:e=>e,variantKeys:Me,variantMap:je,merge(e){return mergeRecipes(this,e)},splitVariantProps(e){return splitProps(e,Me)},getVariantProps:G.getVariantProps}),K=createRecipe(`likec4-element-shape`,{withBorder:!1,withOutline:!1},[{shapetype:`html`,withBorder:!0,css:{"&":{borderStyle:`solid`,borderWidth:`3px`,borderColor:`var(--likec4-palette-stroke)`,"--likec4-outline-size":`6px`},"& .likec4-shape-outline":{borderRadius:`10px`}}}]),Pe={shapetype:[`html`,`svg`],withBorder:[`true`,`false`],withOutline:[`true`,`false`]},Fe=Object.keys(Pe),Ie=Object.assign(s(K.recipeFn),{__recipe__:!0,__name__:`elementShapeRecipe`,__getCompoundVariantCss__:K.__getCompoundVariantCss__,raw:e=>e,variantKeys:Fe,variantMap:Pe,merge(e){return mergeRecipes(this,e)},splitVariantProps(e){return splitProps(e,Fe)},getVariantProps:K.getVariantProps}),q=createRecipe(`likec4-tag`,{autoTextColor:!1},[]),Le={autoTextColor:[`false`,`true`]},Re=Object.keys(Le),ze=Object.assign(s(q.recipeFn),{__recipe__:!0,__name__:`likec4tag`,__getCompoundVariantCss__:q.__getCompoundVariantCss__,raw:e=>e,variantKeys:Re,variantMap:Le,merge(e){return mergeRecipes(this,e)},splitVariantProps(e){return splitProps(e,Re)},getVariantProps:q.getVariantProps}),J=createRecipe(`likec4-markdown-block`,{uselikec4palette:!1,value:`markdown`},[]),Be={uselikec4palette:[`true`,`false`],value:[`markdown`,`plaintext`]},Ve=Object.keys(Be),He=Object.assign(s(J.recipeFn),{__recipe__:!0,__name__:`markdownBlock`,__getCompoundVariantCss__:J.__getCompoundVariantCss__,raw:e=>e,variantKeys:Ve,variantMap:Be,merge(e){return mergeRecipes(this,e)},splitVariantProps(e){return splitProps(e,Ve)},getVariantProps:J.getVariantProps}),Y=createRecipe(`likec4-navigation-panel-icon`,{variant:`default`,type:`default`},[{type:`warning`,variant:`filled`,css:{backgroundColor:{base:`likec4.panel.action.warning.bg`,_hover:`likec4.panel.action.warning.bg.hover`}}}]),Ue={variant:[`default`,`filled`],type:[`default`,`warning`]},We=Object.keys(Ue),Ge=Object.assign(s(Y.recipeFn),{__recipe__:!0,__name__:`navigationPanelActionIcon`,__getCompoundVariantCss__:Y.__getCompoundVariantCss__,raw:e=>e,variantKeys:We,variantMap:Ue,merge(e){return mergeRecipes(this,e)},splitVariantProps(e){return splitProps(e,We)},getVariantProps:Y.getVariantProps}),X=createRecipe(`likec4-node-notes`,{opened:!1},[]),Ke={opened:[`false`,`true`]},Z=Object.keys(Ke),qe=Object.assign(s(X.recipeFn),{__recipe__:!0,__name__:`nodeNotes`,__getCompoundVariantCss__:X.__getCompoundVariantCss__,raw:e=>e,variantKeys:Z,variantMap:Ke,merge(e){return mergeRecipes(this,e)},splitVariantProps(e){return splitProps(e,Z)},getVariantProps:X.getVariantProps}),Q=createRecipe(`likec4-overlay`,{fullscreen:!1,withBackdrop:!0},[]),Je={fullscreen:[`false`,`true`],withBackdrop:[`false`,`true`]},Ye=Object.keys(Je),Xe=Object.assign(s(Q.recipeFn),{__recipe__:!0,__name__:`overlay`,__getCompoundVariantCss__:Q.__getCompoundVariantCss__,raw:e=>e,variantKeys:Ye,variantMap:Je,merge(e){return mergeRecipes(this,e)},splitVariantProps(e){return splitProps(e,Ye)},getVariantProps:Q.getVariantProps}),Ze={truncateLabel:!1},Qe=[],$e=[[`root`,`likec4-navlink__root`],[`body`,`likec4-navlink__body`],[`section`,`likec4-navlink__section`],[`label`,`likec4-navlink__label`],[`description`,`likec4-navlink__description`]].map(([e,t])=>[e,createRecipe(t,Ze,getSlotCompoundVariant(Qe,e))]),et=s((e={})=>Object.fromEntries($e.map(([t,n])=>[t,n.recipeFn(e)]))),tt=[`truncateLabel`],nt=Object.assign(et,{__recipe__:!1,__name__:`navigationLink`,raw:e=>e,classNameMap:{},variantKeys:tt,variantMap:{truncateLabel:[`true`,`false`]},splitVariantProps(e){return splitProps(e,tt)},getVariantProps:e(e=>({...Ze,...compact(e)}),`getVariantProps`)}),rt={size:`md`,panelPosition:`left`},it=[],at=[[`root`,`likec4-navigation-panel__root`],[`body`,`likec4-navigation-panel__body`],[`logo`,`likec4-navigation-panel__logo`],[`label`,`likec4-navigation-panel__label`],[`dropdown`,`likec4-navigation-panel__dropdown`]].map(([e,t])=>[e,createRecipe(t,rt,getSlotCompoundVariant(it,e))]),ot=s((e={})=>Object.fromEntries(at.map(([t,n])=>[t,n.recipeFn(e)]))),$=[`size`,`panelPosition`],getVariantProps=e=>({...rt,...compact(e)}),st=Object.assign(ot,{__recipe__:!1,__name__:`navigationPanel`,raw:e=>e,classNameMap:{},variantKeys:$,variantMap:{size:[`md`,`lg`],panelPosition:[`left`,`right`]},splitVariantProps(e){return splitProps(e,$)},getVariantProps});export{sva as A,me as C,createStyleContext as D,fe as E,cx as M,css as N,S as O,hstack as S,pe as T,ge as _,Ge as a,container as b,Ie as c,De as d,xe as f,_e as g,ve as h,qe as i,cva as j,x as k,Ne as l,ye as m,nt as n,He as o,be as p,Xe as r,ze as s,st as t,Ae as u,txt as v,vstack as w,he as x,bleed as y};
@@ -1 +0,0 @@
1
- import"./rolldown-runtime.mjs";import{d as e,u as t}from"./libs/@react-hookz/web.mjs";import{n}from"./libs/fast-equals.mjs";const noop=()=>{},depsShallowEqual=(e,t)=>{if(e===t)return!0;if(e.length!==t.length)return!1;for(let[r,i]of e.entries())if(!(i===t[r]||n(i,t[r])))return!1;return!0};function useUpdateEffect(n,r,i,a){e(t()?noop:n,r,i??depsShallowEqual,a)}export{useUpdateEffect as n,depsShallowEqual as t};
@@ -1 +0,0 @@
1
- import"../chunks/rolldown-runtime.mjs";import{t as e}from"../chunks/single-index.mjs";import{t}from"../chunks/__root.mjs";import{Route as n}from"./routes/projects.mjs";import{Route as r}from"./routes/_single/route.mjs";import{Route as i}from"./routes/index.mjs";import{Route as a}from"./routes/_single/adhoc.mjs";import{Route as o}from"./routes/project._projectId/route.mjs";import{Route as s}from"./routes/project._projectId/index.mjs";import{Route as c}from"./routes/project._projectId/adhoc.mjs";import{Route as l}from"./routes/_single/webcomponent._.mjs";import{Route as u}from"./routes/_single/view._viewId.mjs";import{Route as d}from"./routes/_single/export._viewId.mjs";import{Route as f}from"./routes/_single/embed._viewId.mjs";import{Route as p}from"./routes/_single/view._viewId.index.mjs";import{Route as m}from"./routes/project._projectId/view._viewId.mjs";import{Route as h}from"./routes/project._projectId/export._viewId.mjs";import{Route as g}from"./routes/project._projectId/embed._viewId.mjs";import{Route as _}from"./routes/_single/view._viewId.puml.mjs";import{Route as v}from"./routes/_single/view._viewId.mmd.mjs";import{Route as y}from"./routes/_single/view._viewId.dot.mjs";import{Route as b}from"./routes/_single/view._viewId.d2.mjs";import{Route as x}from"./routes/project._projectId/view._viewId.index.mjs";import{Route as S}from"./routes/project._projectId/view._viewId.puml.mjs";import{Route as C}from"./routes/project._projectId/view._viewId.mmd.mjs";import{Route as w}from"./routes/project._projectId/view._viewId.dot.mjs";import{Route as T}from"./routes/project._projectId/view._viewId.d2.mjs";const E=n.update({id:`/projects`,path:`/projects`,getParentRoute:()=>t}),D=r.update({id:`/_single`,getParentRoute:()=>t}),O=i.update({id:`/`,path:`/`,getParentRoute:()=>t}),k=e.update({id:`/single-index`,path:`/single-index`,getParentRoute:()=>D}),ee=a.update({id:`/adhoc`,path:`/adhoc`,getParentRoute:()=>D}),A=o.update({id:`/project/$projectId`,path:`/project/$projectId`,getParentRoute:()=>t}),j=s.update({id:`/`,path:`/`,getParentRoute:()=>A}),M=c.update({id:`/adhoc`,path:`/adhoc`,getParentRoute:()=>A}),N=l.update({id:`/webcomponent/$`,path:`/webcomponent/$`,getParentRoute:()=>D}),P=u.update({id:`/view/$viewId`,path:`/view/$viewId`,getParentRoute:()=>D}),F=d.update({id:`/export/$viewId`,path:`/export/$viewId`,getParentRoute:()=>D}),I=f.update({id:`/embed/$viewId`,path:`/embed/$viewId`,getParentRoute:()=>D}),L=p.update({id:`/`,path:`/`,getParentRoute:()=>P}),R=m.update({id:`/view/$viewId`,path:`/view/$viewId`,getParentRoute:()=>A}),z=h.update({id:`/export/$viewId`,path:`/export/$viewId`,getParentRoute:()=>A}),B=g.update({id:`/embed/$viewId`,path:`/embed/$viewId`,getParentRoute:()=>A}),V=_.update({id:`/puml`,path:`/puml`,getParentRoute:()=>P}),H=v.update({id:`/mmd`,path:`/mmd`,getParentRoute:()=>P}),U=y.update({id:`/dot`,path:`/dot`,getParentRoute:()=>P}),W=b.update({id:`/d2`,path:`/d2`,getParentRoute:()=>P}),G=x.update({id:`/`,path:`/`,getParentRoute:()=>R}),K=S.update({id:`/puml`,path:`/puml`,getParentRoute:()=>R}),q=C.update({id:`/mmd`,path:`/mmd`,getParentRoute:()=>R}),J=w.update({id:`/dot`,path:`/dot`,getParentRoute:()=>R}),Y=T.update({id:`/d2`,path:`/d2`,getParentRoute:()=>R}),X={SingleViewViewIdD2Route:W,SingleViewViewIdDotRoute:U,SingleViewViewIdMmdRoute:H,SingleViewViewIdPumlRoute:V,SingleViewViewIdIndexRoute:L},Z={SingleAdhocRoute:ee,SingleSingleIndexRoute:k,SingleEmbedViewIdRoute:I,SingleExportViewIdRoute:F,SingleViewViewIdRoute:P._addFileChildren(X),SingleWebcomponentSplatRoute:N},Q=D._addFileChildren(Z),$={ProjectProjectIdViewViewIdD2Route:Y,ProjectProjectIdViewViewIdDotRoute:J,ProjectProjectIdViewViewIdMmdRoute:q,ProjectProjectIdViewViewIdPumlRoute:K,ProjectProjectIdViewViewIdIndexRoute:G},te={ProjectProjectIdAdhocRoute:M,ProjectProjectIdIndexRoute:j,ProjectProjectIdEmbedViewIdRoute:B,ProjectProjectIdExportViewIdRoute:z,ProjectProjectIdViewViewIdRoute:R._addFileChildren($)},ne={IndexRoute:O,SingleRouteRoute:Q,ProjectsRoute:E,ProjectProjectIdRouteRoute:A._addFileChildren(te)},re=t._addFileChildren(ne)._addFileTypes();export{re as routeTree};
@@ -1 +0,0 @@
1
- import{t as e}from"../../chunks/__root.mjs";export{e as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{g as e,o as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{AdHocViewEditor as n}from"../../pages/AdHocViewEditor.mjs";import{c as r}from"react/compiler-runtime";import{jsx as i}from"react/jsx-runtime";import{isRpcAvailable as a}from"likec4:rpc";const o=t(`/_single/adhoc`)({beforeLoad:()=>{if(!a)throw e({to:`/single-index/`})},component:Page});function Page(){let e=r(2),{projectId:t}=o.useRouteContext(),a;return e[0]===t?a=e[1]:(a=i(n,{projectId:t}),e[0]=t,e[1]=a),a}export{o as Route};
@@ -1 +0,0 @@
1
- import{o as e}from"../../../chunks/libs/@tanstack/react-router.mjs";import{EmbedPage as t}from"../../pages/EmbedPage.mjs";const n=e(`/_single/embed/$viewId`)({component:t});export{n as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{o as e}from"../../../chunks/libs/@tanstack/react-router.mjs";import{t}from"../../../chunks/libs/@tanstack/router-core.mjs";import{a as n,i as r,n as i,t as a}from"../../../chunks/libs/zod.mjs";import{lazy as o}from"react";const s=o(async()=>{let{ExportPage:e}=await import(`../../pages/ExportPage.mjs`);return{default:e}}),c=e(`/_single/export/$viewId`)({validateSearch:n({download:i().optional().catch(!1),format:a([`png`,`jpeg`]).optional().catch(`png`),quality:r().min(0).max(1).optional().catch(void 0)}),search:{middlewares:[t({download:!1,format:`png`,quality:void 0})]},component:s,wrapInSuspense:!0});export{c as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{a as e,o as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{t as n}from"../../../chunks/Fallback.mjs";import{t as r}from"../../../chunks/libs/react-error-boundary.mjs";import{n as i,r as a,t as o}from"../../../chunks/LikeC4ModelContext2.mjs";import{c as s}from"react/compiler-runtime";import{jsx as c}from"react/jsx-runtime";import{loadModel as l}from"likec4:model";const u=t(`/_single`)({staleTime:1/0,loaderDeps(){return[]},loader:async({context:e})=>{let t=e.projectId;return{$likec4model:(await l(t)).$likec4model,projectId:t}},component:RouteComponent});function RouteComponent(){let t=s(6),{$likec4model:l,projectId:d}=u.useLoaderData(),f;t[0]===Symbol.for(`react.memo_cache_sentinel`)?(f=c(e,{}),t[0]=f):f=t[0];let p;t[1]===l?p=t[2]:(p=c(o,{likec4model:l,children:f}),t[1]=l,t[2]=p);let m;return t[3]!==d||t[4]!==p?(m=c(a,{children:c(r,{FallbackComponent:n,children:c(i,{projectId:d,children:p})})}),t[3]=d,t[4]=p,t[5]=m):m=t[5],m}export{u as Route};
@@ -1 +0,0 @@
1
- import{t as e}from"../../../chunks/single-index.mjs";export{e as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{o as e,v as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{ViewAsD2 as n}from"../../pages/ViewAsD2.mjs";import{c as r}from"react/compiler-runtime";import{jsx as i}from"react/jsx-runtime";import{loadD2Sources as a}from"likec4:d2";const o=e(`/_single/view/$viewId/d2`)({component:Page,staleTime:1/0,loader:async({context:e,params:n})=>{let r=e.projectId,{viewId:i}=n;try{let{d2Source:e}=await a(r);return{source:e(i)}}catch(e){throw console.error(e),t()}}});function Page(){let e=r(2),{source:t}=o.useLoaderData(),a;return e[0]===t?a=e[1]:(a=i(n,{d2Source:t}),e[0]=t,e[1]=a),a}export{o as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{o as e,v as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{ViewAsDot as n}from"../../pages/ViewAsDot.mjs";import{c as r}from"react/compiler-runtime";import{jsx as i}from"react/jsx-runtime";import{loadDotSources as a}from"likec4:dot";const o=e(`/_single/view/$viewId/dot`)({component:Page,staleTime:1/0,loader:async({params:e,context:n})=>{let r=n.projectId,{viewId:i}=e;try{let{dotSource:e,svgSource:t}=await a(r);return{dot:e(i),dotSvg:t(i)}}catch(e){throw console.error(e),t()}}});function Page(){let e=r(3),{dot:t,dotSvg:a}=o.useLoaderData(),s;return e[0]!==t||e[1]!==a?(s=i(n,{dot:t,dotSvg:a}),e[0]=t,e[1]=a,e[2]=s):s=e[2],s}export{o as Route};
@@ -1 +0,0 @@
1
- import{o as e}from"../../../chunks/libs/@tanstack/react-router.mjs";import{i as t}from"../../../chunks/ViewReact.mjs";import{ViewEditor as n}from"../../pages/ViewEditor.mjs";import{isRpcAvailable as r}from"likec4:rpc";const i=e(`/_single/view/$viewId/`)({component:r?n:t});export{i as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{a as e,o as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{t as n}from"../../../chunks/Fallback.mjs";import{t as r}from"../../../chunks/Header.mjs";import{c as i}from"react/compiler-runtime";import{Fragment as a,jsx as o,jsxs as s}from"react/jsx-runtime";const c=t(`/_single/view/$viewId`)({component:ViewLayout,errorComponent:({error:e,reset:t})=>o(n,{error:e,resetErrorBoundary:t})});function ViewLayout(){let t=i(1),n;return t[0]===Symbol.for(`react.memo_cache_sentinel`)?(n=s(a,{children:[o(e,{}),o(r,{})]}),t[0]=n):n=t[0],n}export{c as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{o as e,v as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{ViewAsMmd as n}from"../../pages/ViewAsMmd.mjs";import{c as r}from"react/compiler-runtime";import{jsx as i}from"react/jsx-runtime";import{loadMmdSources as a}from"likec4:mmd";const o=e(`/_single/view/$viewId/mmd`)({component:Page,staleTime:1/0,loader:async({params:e,context:n})=>{let r=n.projectId,{viewId:i}=e;try{let{mmdSource:e}=await a(r);return{source:e(i)}}catch(e){throw console.error(e),t()}}});function Page(){let e=r(3),{viewId:t}=o.useParams(),{source:a}=o.useLoaderData(),s;return e[0]!==a||e[1]!==t?(s=i(n,{viewId:t,mmdSource:a}),e[0]=a,e[1]=t,e[2]=s):s=e[2],s}export{o as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{o as e,v as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{ViewAsPuml as n}from"../../pages/ViewAsPuml.mjs";import{c as r}from"react/compiler-runtime";import{jsx as i}from"react/jsx-runtime";import{loadPumlSources as a}from"likec4:puml";const o=e(`/_single/view/$viewId/puml`)({component:Page,staleTime:1/0,loader:async({params:e,context:n})=>{let r=n.projectId,{viewId:i}=e;try{let{pumlSource:e}=await a(r);return{source:e(i)}}catch(e){throw console.error(e),t()}}});function Page(){let e=r(2),{source:t}=o.useLoaderData(),a;return e[0]===t?a=e[1]:(a=i(n,{pumlSource:t}),e[0]=t,e[1]=a),a}export{o as Route};
@@ -1,33 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{f as e,o as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{Ot as n}from"../../../chunks/libs/@mantine/core.mjs";import{E as r}from"../../../chunks/styled-system.mjs";import{c as i}from"react/compiler-runtime";import{jsx as a}from"react/jsx-runtime";import{ComponentName as o}from"likec4:app-config";const s=t(`/_single/webcomponent/$`)({component:WebcomponentPage});function WebcomponentPage(){let t=i(7),c=e(),l=s.useParams()._splat||`index`,{colorScheme:u}=n(),d;t[0]===c.basepath?d=t[1]:(d=c.basepath.endsWith(`/`)?c.basepath:`${c.basepath}/`,t[0]=c.basepath,t[1]=d);let f=`${d}likec4-views.js`,p;t[2]===f?p=t[3]:(p=new URL(f,window.location.href),t[2]=f,t[3]=p);let m=p,h=`
2
- <!DOCTYPE html>
3
- <html lang="en-US" style="color-scheme: ${u};">
4
- <head>
5
- <meta charset="utf-8" />
6
- <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no, shrink-to-fit=no" />
7
- <style>
8
- * {
9
- border-width: 0px;
10
- border-style: solid;
11
- box-sizing: border-box;
12
- overflow-wrap: break-word;
13
- }
14
- html, body {
15
- margin: 0;
16
- background-color: transparent !important;
17
- width: 100%;
18
- height: 100%;
19
- font-size: 16px;
20
- }
21
- body {
22
- min-height: 100%;
23
- }
24
- </style>
25
- </head>
26
- <body>
27
- <div style="width: 100%; height: 100%; padding: clamp(0.5rem, 5vh, 4rem) clamp(0.5rem, 5vw, 5rem)">
28
- <${o.View} view-id="${encodeURIComponent(l)}"></${o.View}>
29
- </div>
30
- <script type="module" src="${m.href}"><\/script>
31
- </body>
32
- </html>
33
- `,g;t[4]===Symbol.for(`react.memo_cache_sentinel`)?(g={position:`fixed`,inset:`0`,width:`100%`,height:`100%`,overflow:`hidden`,"& iframe":{width:`100%`,height:`100%`,borderStyle:`none`,backgroundColor:`transparent`,overflow:`hidden`}},t[4]=g):g=t[4];let _;return t[5]===h?_=t[6]:(_=a(r,{css:g,children:a(`iframe`,{srcDoc:h,allowtransparency:`true`})}),t[5]=h,t[6]=_),_}export{s as Route};
@@ -1 +0,0 @@
1
- import"../../chunks/rolldown-runtime.mjs";import{g as e,o as t}from"../../chunks/libs/@tanstack/react-router.mjs";import{projects as n}from"likec4:projects";const r=t(`/`)({beforeLoad:({context:t})=>{throw t.projects.length>1?e({to:`/projects/`,mask:{to:`/`,unmaskOnReload:!0}}):n[0]?.landingPage&&`redirect`in n[0].landingPage?e({to:`/view/$viewId/`,params:{viewId:`index`},mask:{to:`/`,unmaskOnReload:!0}}):e({to:`/single-index/`,mask:{to:`/`,unmaskOnReload:!0}})}});export{r as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{Ct as e,Gt as t,bt as n,lt as r}from"../../../chunks/libs/@mantine/core.mjs";import{M as i}from"../../../chunks/styled-system.mjs";import{c as a}from"react/compiler-runtime";import{jsx as o}from"react/jsx-runtime";function ProjectButton(s){let c=a(23),l,u,d,f;c[0]===s?(l=c[1],u=c[2],d=c[3],f=c[4]):({project:d,navigateTo:u,className:l,...f}=s,c[0]=s,c[1]=l,c[2]=u,c[3]=d,c[4]=f);let p;c[5]===l?p=c[6]:(p=i(l),c[5]=l,c[6]=p);let t2;c[7]!==u||c[8]!==d?(t2=e=>{e.stopPropagation(),u(d)},c[7]=u,c[8]=d,c[9]=t2):t2=c[9];let m;c[10]!==u||c[11]!==d?(m=t({siblingSelector:`[data-likec4-project]`,parentSelector:`[data-likec4-projects]`,activateOnFocus:!1,loop:!0,orientation:`vertical`,onKeyDown:e=>{e.nativeEvent.code===`Space`&&(e.stopPropagation(),u(d))}}),c[10]=u,c[11]=d,c[12]=m):m=c[12];let h;c[13]===Symbol.for(`react.memo_cache_sentinel`)?(h={flexGrow:1},c[13]=h):h=c[13];let g;c[14]===d?g=c[15]:(g=o(e,{style:h,children:o(r,{gap:`xs`,wrap:`nowrap`,align:`center`,children:d})}),c[14]=d,c[15]=g);let _;return c[16]!==d||c[17]!==f||c[18]!==p||c[19]!==t2||c[20]!==m||c[21]!==g?(_=o(n,{...f,className:p,"data-likec4-project":d,onClick:t2,onKeyDown:m,children:g}),c[16]=d,c[17]=f,c[18]=p,c[19]=t2,c[20]=m,c[21]=g,c[22]=_):_=c[22],_}export{ProjectButton};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{g as e,o as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{AdHocViewEditor as n}from"../../pages/AdHocViewEditor.mjs";import{c as r}from"react/compiler-runtime";import{jsx as i}from"react/jsx-runtime";import{isRpcAvailable as a}from"likec4:rpc";const o=t(`/project/$projectId/adhoc`)({beforeLoad:({params:t})=>{if(!a)throw e({to:`/project/$projectId/`,params:{projectId:t.projectId}})},component:Page});function Page(){let e=r(2),{projectId:t}=o.useRouteContext(),a;return e[0]===t?a=e[1]:(a=i(n,{projectId:t}),e[0]=t,e[1]=a),a}export{o as Route};
@@ -1 +0,0 @@
1
- import{o as e}from"../../../chunks/libs/@tanstack/react-router.mjs";import{EmbedPage as t}from"../../pages/EmbedPage.mjs";const n=e(`/project/$projectId/embed/$viewId`)({component:t});export{n as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{o as e}from"../../../chunks/libs/@tanstack/react-router.mjs";import{t}from"../../../chunks/libs/@tanstack/router-core.mjs";import{a as n,i as r,n as i,t as a}from"../../../chunks/libs/zod.mjs";import{lazy as o}from"react";const s=o(async()=>{let{ExportPage:e}=await import(`../../pages/ExportPage.mjs`);return{default:e}}),c=e(`/project/$projectId/export/$viewId`)({validateSearch:n({download:i().optional().catch(!1),format:a([`png`,`jpeg`]).optional().catch(`png`),quality:r().min(0).max(1).optional().catch(void 0)}),search:{middlewares:[t({download:!1,format:`png`,quality:void 0})]},component:s,wrapInSuspense:!0});export{c as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{c as e,o as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{jsx as n}from"react/jsx-runtime";const r=t(`/project/$projectId/`)({component:()=>{let{projectId:t}=r.useParams();return n(e,{to:`/project/$projectId/view/$viewId/`,replace:!0,params:{projectId:t,viewId:`index`}})}});export{r as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{a as e,g as t,o as n,r,v as i}from"../../../chunks/libs/@tanstack/react-router.mjs";import{B as a,W as o,l as s,r as c}from"../../../chunks/libs/@mantine/core.mjs";import{t as l}from"../../../chunks/Fallback.mjs";import{t as u}from"../../../chunks/libs/react-error-boundary.mjs";import{n as d,r as f,t as p}from"../../../chunks/LikeC4ModelContext2.mjs";import{c as m}from"react/compiler-runtime";import{jsx as h,jsxs as g}from"react/jsx-runtime";import{loadModel as _}from"likec4:model";const v=n(`/project/$projectId`)({staleTime:1/0,beforeLoad:({params:e})=>({projectId:e.projectId}),loaderDeps(){return[]},loader:async({context:e})=>{let n=e.projectId,r=await _(n),a=r.$likec4data.value;if(!a)throw i();if(a.projectId!==n)throw t({to:`/project/$projectId/`,search:!0,params:{projectId:a.projectId}});return{$likec4model:r.$likec4model,projectId:n}},remountDeps({params:e}){return[e.projectId]},component:RouteComponent,notFoundComponent:()=>h(f,{children:h(a,{py:`xl`,children:g(s,{align:`flex-start`,children:[h(c,{children:`Project not found`}),h(o,{component:r,to:`/`,search:!0,size:`md`,children:`Open overview`})]})})})});function RouteComponent(){let t=m(6),{$likec4model:n,projectId:r}=v.useLoaderData(),i;t[0]===Symbol.for(`react.memo_cache_sentinel`)?(i=h(u,{FallbackComponent:l,children:h(e,{})}),t[0]=i):i=t[0];let a;t[1]===n?a=t[2]:(a=h(p,{likec4model:n,children:i}),t[1]=n,t[2]=a);let o;return t[3]!==r||t[4]!==a?(o=h(f,{children:h(u,{FallbackComponent:l,children:h(d,{projectId:r,children:a})})}),t[3]=r,t[4]=a,t[5]=o):o=t[5],o}export{v as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{o as e,v as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{ViewAsD2 as n}from"../../pages/ViewAsD2.mjs";import{c as r}from"react/compiler-runtime";import{jsx as i}from"react/jsx-runtime";import{loadD2Sources as a}from"likec4:d2";const o=e(`/project/$projectId/view/$viewId/d2`)({loader:async({context:e,params:n})=>{let r=e.projectId,{viewId:i}=n;try{let{d2Source:e}=await a(r);return{source:e(i)}}catch(e){throw console.error(e),t()}},component:Page});function Page(){let e=r(2),{source:t}=o.useLoaderData(),a;return e[0]===t?a=e[1]:(a=i(n,{d2Source:t}),e[0]=t,e[1]=a),a}export{o as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{o as e,v as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{ViewAsDot as n}from"../../pages/ViewAsDot.mjs";import{c as r}from"react/compiler-runtime";import{jsx as i}from"react/jsx-runtime";import{loadDotSources as a}from"likec4:dot";const o=e(`/project/$projectId/view/$viewId/dot`)({component:Page,loader:async({params:e,context:n})=>{let r=n.projectId,{viewId:i}=e;try{let{dotSource:e,svgSource:t}=await a(r);return{dot:e(i),dotSvg:t(i)}}catch(e){throw console.error(e),t()}}});function Page(){let e=r(3),{dot:t,dotSvg:a}=o.useLoaderData(),s;return e[0]!==t||e[1]!==a?(s=i(n,{dot:t,dotSvg:a}),e[0]=t,e[1]=a,e[2]=s):s=e[2],s}export{o as Route};
@@ -1 +0,0 @@
1
- import{o as e}from"../../../chunks/libs/@tanstack/react-router.mjs";import{i as t}from"../../../chunks/ViewReact.mjs";import{ViewEditor as n}from"../../pages/ViewEditor.mjs";import{isRpcAvailable as r}from"likec4:rpc";const i=e(`/project/$projectId/view/$viewId/`)({component:r?n:t});export{i as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{a as e,o as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{t as n}from"../../../chunks/Fallback.mjs";import{t as r}from"../../../chunks/Header.mjs";import{c as i}from"react/compiler-runtime";import{Fragment as a,jsx as o,jsxs as s}from"react/jsx-runtime";const c=t(`/project/$projectId/view/$viewId`)({component:ViewLayout,errorComponent:({error:e,reset:t})=>o(n,{error:e,resetErrorBoundary:t})});function ViewLayout(){let t=i(1),n;return t[0]===Symbol.for(`react.memo_cache_sentinel`)?(n=s(a,{children:[o(e,{}),o(r,{})]}),t[0]=n):n=t[0],n}export{c as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{o as e,v as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{ViewAsMmd as n}from"../../pages/ViewAsMmd.mjs";import{c as r}from"react/compiler-runtime";import{jsx as i}from"react/jsx-runtime";import{loadMmdSources as a}from"likec4:mmd";const o=e(`/project/$projectId/view/$viewId/mmd`)({component:Page,staleTime:1/0,loader:async({params:e,context:n})=>{let r=n.projectId,{viewId:i}=e;try{let{mmdSource:e}=await a(r);return{source:e(i)}}catch(e){throw console.error(e),t()}}});function Page(){let e=r(3),{viewId:t}=o.useParams(),{source:a}=o.useLoaderData(),s;return e[0]!==a||e[1]!==t?(s=i(n,{viewId:t,mmdSource:a}),e[0]=a,e[1]=t,e[2]=s):s=e[2],s}export{o as Route};
@@ -1 +0,0 @@
1
- import"../../../chunks/rolldown-runtime.mjs";import{o as e,v as t}from"../../../chunks/libs/@tanstack/react-router.mjs";import{ViewAsPuml as n}from"../../pages/ViewAsPuml.mjs";import{c as r}from"react/compiler-runtime";import{jsx as i}from"react/jsx-runtime";import{loadPumlSources as a}from"likec4:puml";const o=e(`/project/$projectId/view/$viewId/puml`)({component:Page,staleTime:1/0,loader:async({params:e,context:n})=>{let r=n.projectId,{viewId:i}=e;try{let{pumlSource:e}=await a(r);return{source:e(i)}}catch(e){throw console.error(e),t()}}});function Page(){let e=r(2),{source:t}=o.useLoaderData(),a;return e[0]===t?a=e[1]:(a=i(n,{pumlSource:t}),e[0]=t,e[1]=a),a}export{o as Route};
@@ -1 +0,0 @@
1
- import"../../chunks/rolldown-runtime.mjs";import{g as e,o as t}from"../../chunks/libs/@tanstack/react-router.mjs";import{d as n}from"../../chunks/libs/@mantine/hooks.mjs";import{E as r}from"../../chunks/styled-system.mjs";import{lazy as i}from"react";import{c as a}from"react/compiler-runtime";import{jsx as o}from"react/jsx-runtime";import{pageTitle as s}from"likec4:app-config";const c=i(async()=>{let{ProjectsOverviewPage:e}=await import(`../pages/ProjectsOverview.mjs`);return{default:e}}),l=t(`/projects`)({beforeLoad:async({context:t})=>{if(t.projects.length<2)throw e({to:`/single-index/`})},component:RouteComponent,wrapInSuspense:!0});function RouteComponent(){let e=a(1);n(`Projects - ${s}`);let t;return e[0]===Symbol.for(`react.memo_cache_sentinel`)?(t=o(r,{w:`100%`,h:`100%`,overflow:`hidden`,children:o(c,{})}),e[0]=t):t=e[0],t}export{l as Route};
@@ -1,12 +0,0 @@
1
- import { i as __name } from "../rolldown-runtime.mjs";
2
-
3
- //#region ../../node_modules/.pnpm/ts-graphviz@1.8.2/node_modules/ts-graphviz/lib/utils/index.d.ts
4
- /**
5
- * @hidden
6
- */
7
- type $keywords<T extends string> = { [key in T]: key };
8
- /**
9
- * @hidden
10
- */
11
- //#endregion
12
- export { $keywords as t };