@pixelzx/genesis 2026.6.21 → 2026.6.24
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +16 -0
- package/dist/.buildstamp +1 -1
- package/dist/build-info.json +3 -3
- package/dist/cli-startup-metadata.json +1 -1
- package/dist/{command-registry-BGb_Uwan.js → command-registry-9isdLVPT.js} +2 -2
- package/dist/{command-registry-DMgJTE4K.js → command-registry-Cz7IG6fj.js} +2 -2
- package/dist/{command-registry-core-nZQMcxbV.js → command-registry-core-YTbOUvAw.js} +2 -2
- package/dist/{completion-cli-BCc1OonY.js → completion-cli-56xGCg11.js} +2 -2
- package/dist/{config-cli-BZaYp_Ui.js → config-cli-D4puIeCQ.js} +1 -1
- package/dist/control-ui/assets/{agents-BoHSZPvB.js → agents-JV9Lrpaq.js} +402 -333
- package/dist/control-ui/assets/canvas-BGheLorj.js +274 -0
- package/dist/control-ui/assets/{channel-config-extras-BmGwfDPL.js → channel-config-extras-BlcntHgk.js} +2 -2
- package/dist/control-ui/assets/channels-D_T7jf1i.js +196 -0
- package/dist/control-ui/assets/cron-C-vhYdn2.js +250 -0
- package/dist/control-ui/assets/{de-ChvNzaWx.js → de-hbyceFeJ.js} +1 -1
- package/dist/control-ui/assets/{debug-CuUlTIAC.js → debug-C_P-kmLV.js} +8 -8
- package/dist/control-ui/assets/{es-CrSDgcQ5.js → es-1Cx1cu-Y.js} +1 -1
- package/dist/control-ui/assets/{fr-BRwXxDjE.js → fr-VgMPipri.js} +1 -1
- package/dist/control-ui/assets/{i18n-Dr_ijwId.js → i18n-DLwqUqi0.js} +2 -2
- package/dist/control-ui/assets/{id-D6SwOJ8N.js → id-BjXuhykW.js} +1 -1
- package/dist/control-ui/assets/index-CtXQ8kx6.css +1 -0
- package/dist/control-ui/assets/index-or46Cf5v.js +5900 -0
- package/dist/control-ui/assets/{instances-BIg5DC8B.js → instances-B2yScyQI.js} +19 -19
- package/dist/control-ui/assets/{ja-JP-COtC4IfH.js → ja-JP-DWb-BMAl.js} +1 -1
- package/dist/control-ui/assets/{ko-BzeSxEM4.js → ko-Dp3UE5m2.js} +1 -1
- package/dist/control-ui/assets/{logs-BYrqUHTd.js → logs-BiUk-w3p.js} +6 -6
- package/dist/control-ui/assets/mcp-Cvo6FOST.js +380 -0
- package/dist/control-ui/assets/{memory-Dxu2hVW_.js → memory-EzZxvhx5.js} +11 -11
- package/dist/control-ui/assets/{models-DmHuwChH.js → models-CHjUP5zU.js} +26 -26
- package/dist/control-ui/assets/{nodes-BAHmvdL1.js → nodes-CINI4_nb.js} +86 -86
- package/dist/control-ui/assets/{pl-BFGaZC1a.js → pl-UrfXg6LL.js} +1 -1
- package/dist/control-ui/assets/plugins-x9HNTykY.js +259 -0
- package/dist/control-ui/assets/presenter-DwZ-RSJ8.js +2 -0
- package/dist/control-ui/assets/{pt-BR-B2QYSEq3.js → pt-BR-Cqsb5BcT.js} +1 -1
- package/dist/control-ui/assets/sessions-DnMfNBmX.js +56 -0
- package/dist/control-ui/assets/skills-B7wdMvcb.js +294 -0
- package/dist/control-ui/assets/skills-shared-C4nHDuFm.js +11 -0
- package/dist/control-ui/assets/{th-CB7L1SFv.js → th-C_U0alhW.js} +1 -1
- package/dist/control-ui/assets/{tr-jlhb5DaE.js → tr-BHgpQnZM.js} +1 -1
- package/dist/control-ui/assets/{uk-BrLj30-c.js → uk-C_GhiUmQ.js} +1 -1
- package/dist/control-ui/assets/wallet-Ds1hW8CM.js +302 -0
- package/dist/control-ui/assets/{zh-CN-BvMSlZSV.js → zh-CN-BNYbiW4p.js} +1 -1
- package/dist/control-ui/assets/{zh-TW-DvNvr4gT.js → zh-TW-DJ7rxwhV.js} +1 -1
- package/dist/control-ui/index.html +3 -4
- package/dist/entry.js +1 -1
- package/dist/extensions/skill-workshop/genesis.plugin.json +2 -1
- package/dist/extensions/skill-workshop/index.js +1 -1
- package/dist/{gateway-cli-CPCS4XTI.js → gateway-cli-CeEdXZHU.js} +1 -1
- package/dist/index.js +1 -1
- package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
- package/dist/postinstall-inventory.json +50 -50
- package/dist/{program-D6Z9HYd5.js → program-0N-JnVM6.js} +1 -1
- package/dist/{register.subclis-CUxlv4Y7.js → register.subclis-D0ogazCL.js} +2 -2
- package/dist/{register.subclis-DPpkGluG.js → register.subclis-DPK0ga6y.js} +1 -1
- package/dist/{register.subclis-core-hOQqRXcI.js → register.subclis-core-DIGnTWFD.js} +1 -1
- package/dist/{run-main-By1VNkmf.js → run-main-kPIaMJwz.js} +4 -4
- package/dist/{runtime-schema-BR36tJn9.js → runtime-schema-CFPgELGN.js} +1 -1
- package/dist/{server-C7yMa7AQ.js → server-HNGA0Ig0.js} +1 -1
- package/dist/{server-plugin-bootstrap-CWHfoBJK.js → server-plugin-bootstrap-BXJURCLA.js} +1 -1
- package/dist/{server-plugin-bootstrap-C2EOYVsD.js → server-plugin-bootstrap-CNJ_xwIU.js} +1 -1
- package/dist/{server.impl-CNE0SpyS.js → server.impl-DuIzmQsq.js} +2 -2
- package/package.json +1 -1
- package/dist/control-ui/assets/canvas-DkuTKNbN.js +0 -269
- package/dist/control-ui/assets/channels-v0P0irqY.js +0 -463
- package/dist/control-ui/assets/cron-DD6CAXar.js +0 -933
- package/dist/control-ui/assets/format-BOO4MheD.js +0 -9
- package/dist/control-ui/assets/index-CYO6b4V3.js +0 -6314
- package/dist/control-ui/assets/index-a2bnKy1Z.css +0 -1
- package/dist/control-ui/assets/mcp-CfklVyVu.js +0 -373
- package/dist/control-ui/assets/plugins-CaVRS7jh.js +0 -273
- package/dist/control-ui/assets/sessions-TU5OCoQU.js +0 -306
- package/dist/control-ui/assets/skills-CC23LxGO.js +0 -323
- package/dist/control-ui/assets/skills-shared-BHZ4ntcf.js +0 -11
- package/dist/control-ui/assets/wallet-DggW1ZUc.js +0 -285
|
@@ -0,0 +1,274 @@
|
|
|
1
|
+
import{d as e,l as t,r as n}from"./i18n-DLwqUqi0.js";import{L as r,R as i,a,d as o,i as s,l as c,u as l,z as u}from"./index-or46Cf5v.js";var d=`/__genesis__/canvas/`,f=`/__genesis__/canvas-upload`,p=`<!doctype html>
|
|
2
|
+
<html>
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="utf-8" />
|
|
5
|
+
<title>Canvas</title>
|
|
6
|
+
<style>
|
|
7
|
+
body { font-family: system-ui, sans-serif; margin: 32px; }
|
|
8
|
+
</style>
|
|
9
|
+
</head>
|
|
10
|
+
<body>
|
|
11
|
+
<h1>Canvas</h1>
|
|
12
|
+
</body>
|
|
13
|
+
</html>`,m=d,h=`file`,g=``,_=``,v=`560`,y=``,b=p,x=``,S=``,C=null,w=[],T=!1,E=!1,D=null,O=!1,k=null,A=0,ee=[{mode:`file`,labelKey:`canvasView.source.file`},{mode:`html`,labelKey:`canvasView.source.html`},{mode:`url`,labelKey:`canvasView.source.url`},{mode:`path`,labelKey:`canvasView.source.path`}],j=[{value:``,label:`Auto`},{value:`html_bundle`,label:`HTML bundle`},{value:`url_embed`,label:`URL embed`},{value:`document`,label:`Document`},{value:`image`,label:`Image`},{value:`video_asset`,label:`Video`},{value:`presentation_asset`,label:`Presentation`},{value:`model_3d`,label:`3D model`},{value:`vector_image`,label:`Vector image`}];function te(){m=d,h=`file`,g=``,_=``,v=`560`,y=``,b=p,x=``,S=``,C=null,w=[],T=!1,E=!1,D=null,O=!1,k=null,A=0}function M(e,t){m=e,t?.()}function N(e){e.onRequestUpdate?.()}function P(e,t){k=e,N(t)}function F(e){return e instanceof Error?e.message:String(e)}function I(e){let t=e?.trim()??``;return!t||t===`/`?``:`/${t.replace(/^\/+|\/+$/g,``)}`}function L(e){let t=I(e.basePath),n=e.gatewayUrl?.trim();if(!n)return`${t}${f}`;try{let e=new URL(n,window.location.href);e.protocol===`ws:`?e.protocol=`http:`:e.protocol===`wss:`&&(e.protocol=`https:`);let r=I(e.pathname);return`${e.origin}${r||t}${f}`}catch{return`${t}${f}`}}async function R(e){let t=e.authToken?.trim()||e.password?.trim();if(t)return t;if(!(typeof crypto>`u`||!crypto.subtle))try{let e=u({deviceId:(await i()).deviceId,role:r}),t=e?.scopes??[];if(e?.token&&(t.includes(`operator.write`)||t.includes(`operator.admin`)))return e.token}catch{}}function z(){return h===`file`?C!==null:h===`html`?b.trim().length>0:h===`url`?x.trim().length>0:S.trim().length>0}function B(){let e=Number(v);return Number.isFinite(e)&&e>0?e:void 0}function V(e,t){_=e.id,m=e.entryUrl,g=e.title??g,v=typeof e.preferredHeight==`number`?String(e.preferredHeight):v,y=e.kind??y,k={tone:`success`,text:n(`canvasView.status.saved`,{id:e.id})},N(t)}async function H(e){if(!e.connected||!e.client||T)return;let t=++A;T=!0,D=e.client,N(e);try{let n=await e.client.request(`canvas.document.list`,{limit:50});t===A&&(w=n.documents??[],E=!0)}catch(e){t===A&&(k={tone:`danger`,text:F(e)})}finally{t===A&&(T=!1,N(e))}}function U(e){e.client!==D&&(E=!1,D=e.client??null),!E&&!T&&e.connected&&e.client&&H(e)}function W(e){let t={},n=_.trim();n&&(t.id=n),e===`update`&&(t.id=n);let r=g.trim();r&&(t.title=r);let i=B();return typeof i==`number`&&(t.preferredHeight=i),y&&(t.kind=y),h===`html`?t.html=b:h===`url`?t.url=x.trim():h===`path`&&(t.path=S.trim()),t}async function G(e,t){if(!e.client)throw Error(n(`canvasView.errors.notConnected`));let r=W(t),i=t===`update`?`canvas.document.update`:`canvas.document.create`;return await e.client.request(i,r)}async function K(e,t){if(!C)throw Error(n(`canvasView.errors.fileRequired`));let r=new URL(L(e),window.location.href);r.searchParams.set(`mode`,t);let i=_.trim();i&&r.searchParams.set(`id`,i);let a=g.trim();a&&r.searchParams.set(`title`,a);let o=B();typeof o==`number`&&r.searchParams.set(`preferredHeight`,String(o)),y&&r.searchParams.set(`kind`,y);let s=new Headers;s.set(`X-Genesis-File-Name`,encodeURIComponent(C.name)),C.type&&s.set(`Content-Type`,C.type);let c=await R(e);c&&s.set(`Authorization`,`Bearer ${c}`);let l=await fetch(r.toString(),{method:`POST`,headers:s,body:C}),u=await l.json().catch(()=>null);if(!l.ok||!u?.ok||!u.document)throw Error(u?.error?.message??l.statusText);return u.document}async function q(e,t){if(!e.connected){P({tone:`danger`,text:n(`canvasView.errors.notConnected`)},e);return}if(!z()){P({tone:`danger`,text:n(`canvasView.errors.sourceRequired`)},e);return}if(t===`update`&&!_.trim()){P({tone:`danger`,text:n(`canvasView.errors.idRequired`)},e);return}O=!0,k={tone:`normal`,text:n(`canvasView.status.saving`)},N(e);try{V(h===`file`?await K(e,t):await G(e,t),e),E=!1,H(e)}catch(t){P({tone:`danger`,text:F(t)},e)}finally{O=!1,N(e)}}function J(e,t){_=e.id,g=e.title??``,v=typeof e.preferredHeight==`number`?String(e.preferredHeight):`560`,y=e.kind??``,m=e.entryUrl,k={tone:`normal`,text:n(`canvasView.status.selected`,{id:e.id})},N(t)}function Y(t,r){return e`
|
|
14
|
+
<button
|
|
15
|
+
class="btn canvas-source-tab ${h===r.mode?`active`:``}"
|
|
16
|
+
type="button"
|
|
17
|
+
@click=${()=>{h=r.mode,N(t)}}
|
|
18
|
+
>
|
|
19
|
+
${n(r.labelKey)}
|
|
20
|
+
</button>
|
|
21
|
+
`}function X(t,n,r=`normal`){return e`
|
|
22
|
+
<div class="canvas-status-item">
|
|
23
|
+
<div class="canvas-status-label">${t}</div>
|
|
24
|
+
<div class="canvas-status-value ${r===`danger`?`is-danger`:``}" title=${n}>
|
|
25
|
+
${n}
|
|
26
|
+
</div>
|
|
27
|
+
</div>
|
|
28
|
+
`}function Z(t,r=n(`canvasView.actions.open`)){return t?e`
|
|
29
|
+
<a class="btn" href=${t} rel=${a()} target=${s}>
|
|
30
|
+
${c.externalLink}<span>${r}</span>
|
|
31
|
+
</a>
|
|
32
|
+
`:e`
|
|
33
|
+
<button class="btn" type="button" disabled>${c.externalLink}<span>${r}</span></button>
|
|
34
|
+
`}function ne(r){return h===`file`?e`
|
|
35
|
+
<label class="field full canvas-file-field">
|
|
36
|
+
<span>${n(`canvasView.fields.file`)}</span>
|
|
37
|
+
<input
|
|
38
|
+
type="file"
|
|
39
|
+
@change=${e=>{C=e.currentTarget.files?.[0]??null,C&&!g.trim()&&(g=C.name.replace(/\.[^.]+$/,``)),N(r)}}
|
|
40
|
+
/>
|
|
41
|
+
</label>
|
|
42
|
+
${C?e`
|
|
43
|
+
<div class="canvas-file-selected full">
|
|
44
|
+
<span>${C.name}</span>
|
|
45
|
+
<span>${Math.ceil(C.size/1024)} KB</span>
|
|
46
|
+
</div>
|
|
47
|
+
`:t}
|
|
48
|
+
`:h===`html`?e`
|
|
49
|
+
<label class="field full">
|
|
50
|
+
<span>${n(`canvasView.fields.html`)}</span>
|
|
51
|
+
<textarea
|
|
52
|
+
class="canvas-source-textarea"
|
|
53
|
+
spellcheck="false"
|
|
54
|
+
.value=${b}
|
|
55
|
+
@input=${e=>{b=e.currentTarget.value,N(r)}}
|
|
56
|
+
></textarea>
|
|
57
|
+
</label>
|
|
58
|
+
`:h===`url`?e`
|
|
59
|
+
<label class="field full">
|
|
60
|
+
<span>${n(`canvasView.fields.url`)}</span>
|
|
61
|
+
<input
|
|
62
|
+
autocomplete="off"
|
|
63
|
+
spellcheck="false"
|
|
64
|
+
type="url"
|
|
65
|
+
.value=${x}
|
|
66
|
+
@input=${e=>{x=e.currentTarget.value,N(r)}}
|
|
67
|
+
placeholder="https://example.com/document.pdf"
|
|
68
|
+
/>
|
|
69
|
+
</label>
|
|
70
|
+
`:e`
|
|
71
|
+
<label class="field full">
|
|
72
|
+
<span>${n(`canvasView.fields.path`)}</span>
|
|
73
|
+
<input
|
|
74
|
+
autocomplete="off"
|
|
75
|
+
spellcheck="false"
|
|
76
|
+
type="text"
|
|
77
|
+
.value=${S}
|
|
78
|
+
@input=${e=>{S=e.currentTarget.value,N(r)}}
|
|
79
|
+
placeholder="/Users/me/Documents/report.pdf"
|
|
80
|
+
/>
|
|
81
|
+
</label>
|
|
82
|
+
`}function Q(){return k?e` <div class=${k.tone===`danger`?`callout danger canvas-workspace-message`:`callout canvas-workspace-message`}>${k.text}</div> `:t}function re(t){return T&&w.length===0?e`<div class="canvas-empty-list muted">${n(`canvasView.status.loading`)}</div>`:w.length===0?e`<div class="canvas-empty-list muted">${n(`canvasView.status.noDocuments`)}</div>`:e`
|
|
83
|
+
<div class="canvas-document-list">
|
|
84
|
+
${w.map(n=>{let r=n.id===_,i=n.updatedAt??n.createdAt;return e`
|
|
85
|
+
<button
|
|
86
|
+
class="canvas-document-row ${r?`active`:``}"
|
|
87
|
+
type="button"
|
|
88
|
+
@click=${()=>J(n,t)}
|
|
89
|
+
>
|
|
90
|
+
<span class="canvas-document-title"
|
|
91
|
+
>${n.title??n.sourceFileName??n.id}</span
|
|
92
|
+
>
|
|
93
|
+
<span class="canvas-document-meta">
|
|
94
|
+
${n.kind} · r${n.revision} · ${i}
|
|
95
|
+
</span>
|
|
96
|
+
</button>
|
|
97
|
+
`})}
|
|
98
|
+
</div>
|
|
99
|
+
`}var $=`font-family: var(--mono); font-size: 11px; letter-spacing: 0.5px; text-transform: uppercase; color: var(--text-tertiary, #6b6b6b); margin-bottom: 12px;`;function ie(t,r,i){let a=t.connected&&!O&&z(),o=a&&_.trim().length>0;return e`
|
|
100
|
+
<aside class="card" style="align-self: start;">
|
|
101
|
+
<div style=${$}>PROPERTIES</div>
|
|
102
|
+
|
|
103
|
+
<div class="canvas-source-tabs">
|
|
104
|
+
${ee.map(e=>Y(t,e))}
|
|
105
|
+
</div>
|
|
106
|
+
|
|
107
|
+
<div class="form-grid canvas-document-form">
|
|
108
|
+
${ne(t)}
|
|
109
|
+
|
|
110
|
+
<label class="field">
|
|
111
|
+
<span>${n(`canvasView.fields.title`)}</span>
|
|
112
|
+
<input
|
|
113
|
+
autocomplete="off"
|
|
114
|
+
type="text"
|
|
115
|
+
.value=${g}
|
|
116
|
+
@input=${e=>{g=e.currentTarget.value,N(t)}}
|
|
117
|
+
/>
|
|
118
|
+
</label>
|
|
119
|
+
|
|
120
|
+
<label class="field">
|
|
121
|
+
<span>${n(`canvasView.fields.id`)}</span>
|
|
122
|
+
<input
|
|
123
|
+
autocomplete="off"
|
|
124
|
+
spellcheck="false"
|
|
125
|
+
type="text"
|
|
126
|
+
.value=${_}
|
|
127
|
+
@input=${e=>{_=e.currentTarget.value,N(t)}}
|
|
128
|
+
/>
|
|
129
|
+
</label>
|
|
130
|
+
|
|
131
|
+
<label class="field">
|
|
132
|
+
<span>${n(`canvasView.fields.height`)}</span>
|
|
133
|
+
<input
|
|
134
|
+
min="120"
|
|
135
|
+
step="20"
|
|
136
|
+
type="number"
|
|
137
|
+
.value=${v}
|
|
138
|
+
@input=${e=>{v=e.currentTarget.value,N(t)}}
|
|
139
|
+
/>
|
|
140
|
+
</label>
|
|
141
|
+
|
|
142
|
+
<label class="field">
|
|
143
|
+
<span>${n(`canvasView.fields.kind`)}</span>
|
|
144
|
+
<select
|
|
145
|
+
.value=${y}
|
|
146
|
+
@change=${e=>{y=e.currentTarget.value,N(t)}}
|
|
147
|
+
>
|
|
148
|
+
${j.map(t=>e`<option value=${t.value}>${t.label}</option>`)}
|
|
149
|
+
</select>
|
|
150
|
+
</label>
|
|
151
|
+
</div>
|
|
152
|
+
|
|
153
|
+
<div class="row canvas-mutation-actions">
|
|
154
|
+
<button
|
|
155
|
+
class="btn primary canvas-create-button"
|
|
156
|
+
type="button"
|
|
157
|
+
?disabled=${!a}
|
|
158
|
+
@click=${()=>void q(t,`create`)}
|
|
159
|
+
>
|
|
160
|
+
${c.plus}<span
|
|
161
|
+
>${n(O?`common.saving`:`canvasView.actions.create`)}</span
|
|
162
|
+
>
|
|
163
|
+
</button>
|
|
164
|
+
<button
|
|
165
|
+
class="btn canvas-update-button"
|
|
166
|
+
type="button"
|
|
167
|
+
?disabled=${!o}
|
|
168
|
+
@click=${()=>void q(t,`update`)}
|
|
169
|
+
>
|
|
170
|
+
${c.refresh}<span>${n(`canvasView.actions.update`)}</span>
|
|
171
|
+
</button>
|
|
172
|
+
</div>
|
|
173
|
+
${Q()}
|
|
174
|
+
|
|
175
|
+
<div style="border-top: 1px solid var(--border); margin-top: 16px; padding-top: 16px;">
|
|
176
|
+
<div style=${$}>STATUS</div>
|
|
177
|
+
<div class="canvas-status-grid">
|
|
178
|
+
${X(n(`canvasView.status.gateway`),t.connected?n(`common.connected`):n(`common.offline`),t.connected?`normal`:`danger`)}
|
|
179
|
+
${X(n(`canvasView.status.host`),r)}
|
|
180
|
+
${X(n(`canvasView.status.sandbox`),i||`strict`)}
|
|
181
|
+
${X(n(`canvasView.status.externalEmbeds`),t.allowExternalEmbedUrls?n(`common.enabled`):n(`common.disabled`))}
|
|
182
|
+
</div>
|
|
183
|
+
</div>
|
|
184
|
+
|
|
185
|
+
<div style="border-top: 1px solid var(--border); margin-top: 16px; padding-top: 16px;">
|
|
186
|
+
<div class="row" style="justify-content: space-between; align-items: center;">
|
|
187
|
+
<div
|
|
188
|
+
style="font-family: var(--mono); font-size: 11px; letter-spacing: 0.5px; text-transform: uppercase; color: var(--text-tertiary, #6b6b6b);"
|
|
189
|
+
>
|
|
190
|
+
RECENT
|
|
191
|
+
</div>
|
|
192
|
+
<button
|
|
193
|
+
class="btn btn--icon"
|
|
194
|
+
type="button"
|
|
195
|
+
title=${n(`common.refresh`)}
|
|
196
|
+
?disabled=${!t.connected||T}
|
|
197
|
+
@click=${()=>void H(t)}
|
|
198
|
+
>
|
|
199
|
+
${c.refresh}
|
|
200
|
+
</button>
|
|
201
|
+
</div>
|
|
202
|
+
${re(t)}
|
|
203
|
+
</div>
|
|
204
|
+
</aside>
|
|
205
|
+
`}function ae(r){U(r);let i=m.trim(),a=o(i,r.canvasHostUrl,r.allowExternalEmbedUrls??!1),s=l(r.embedSandboxMode??`scripts`),u=r.canvasHostUrl?.trim()||`same-origin /__genesis__/canvas`,f=i.length>0&&!a;return e`
|
|
206
|
+
<div class="canvas-page">
|
|
207
|
+
<section class="card" style="border: none; background: transparent; padding: 0;">
|
|
208
|
+
<div
|
|
209
|
+
class="row"
|
|
210
|
+
style="justify-content: space-between; align-items: flex-start; gap: 16px;"
|
|
211
|
+
>
|
|
212
|
+
<div>
|
|
213
|
+
<div class="view-title">${n(`tabs.canvas`)}</div>
|
|
214
|
+
<div class="view-sub">${n(`subtitles.canvas`)}</div>
|
|
215
|
+
</div>
|
|
216
|
+
<div class="row canvas-header-actions">
|
|
217
|
+
<button
|
|
218
|
+
class="btn"
|
|
219
|
+
type="button"
|
|
220
|
+
@click=${()=>M(d,r.onRequestUpdate)}
|
|
221
|
+
>
|
|
222
|
+
${c.refresh}<span>${n(`canvasView.actions.reset`)}</span>
|
|
223
|
+
</button>
|
|
224
|
+
${Z(a)}
|
|
225
|
+
<button class="btn" type="button" @click=${r.onNavigateToChat}>
|
|
226
|
+
${c.messageSquare}<span>${n(`tabs.chat`)}</span>
|
|
227
|
+
</button>
|
|
228
|
+
</div>
|
|
229
|
+
</div>
|
|
230
|
+
</section>
|
|
231
|
+
|
|
232
|
+
<div
|
|
233
|
+
style="display: grid; grid-template-columns: 1fr 380px; gap: 16px; margin-top: 24px; align-items: start;"
|
|
234
|
+
>
|
|
235
|
+
<section class="card" style="padding: 0; overflow: hidden;">
|
|
236
|
+
<div
|
|
237
|
+
class="canvas-preview-toolbar"
|
|
238
|
+
style="padding: 12px 16px; border-bottom: 1px solid var(--border);"
|
|
239
|
+
>
|
|
240
|
+
<label class="field canvas-entry-field">
|
|
241
|
+
<span>${n(`canvasView.fields.entryUrl`)}</span>
|
|
242
|
+
<input
|
|
243
|
+
autocomplete="off"
|
|
244
|
+
spellcheck="false"
|
|
245
|
+
type="text"
|
|
246
|
+
.value=${m}
|
|
247
|
+
@input=${e=>M(e.currentTarget.value,r.onRequestUpdate)}
|
|
248
|
+
placeholder="/__genesis__/canvas/documents/<id>/index.html"
|
|
249
|
+
/>
|
|
250
|
+
</label>
|
|
251
|
+
</div>
|
|
252
|
+
|
|
253
|
+
${f?e`
|
|
254
|
+
<div class="callout danger canvas-preview-error" style="margin: 16px;">
|
|
255
|
+
${n(`canvasView.errors.untrustedUrl`)}
|
|
256
|
+
</div>
|
|
257
|
+
`:t}
|
|
258
|
+
${a?e`
|
|
259
|
+
<iframe
|
|
260
|
+
class="canvas-preview-frame"
|
|
261
|
+
title=${n(`canvasView.previewTitle`)}
|
|
262
|
+
sandbox=${s}
|
|
263
|
+
src=${a}
|
|
264
|
+
></iframe>
|
|
265
|
+
`:e`<div class="canvas-preview-empty muted" style="padding: 48px 16px;">
|
|
266
|
+
${n(`canvasView.status.noPreview`)}
|
|
267
|
+
</div>`}
|
|
268
|
+
</section>
|
|
269
|
+
|
|
270
|
+
${ie(r,u,s)}
|
|
271
|
+
</div>
|
|
272
|
+
</div>
|
|
273
|
+
`}export{ae as renderCanvas,te as resetCanvasViewForTests};
|
|
274
|
+
//# sourceMappingURL=canvas-BGheLorj.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{r as e}from"./i18n-
|
|
2
|
-
//# sourceMappingURL=channel-config-extras-
|
|
1
|
+
import{r as e}from"./i18n-DLwqUqi0.js";function t(e,t){if(!e)return null;let n=(e.channels??{})[t];if(n&&typeof n==`object`)return n;let r=e[t];return r&&typeof r==`object`?r:null}function n(t){if(t==null)return e(`common.na`);if(typeof t==`string`||typeof t==`number`||typeof t==`boolean`)return String(t);try{return JSON.stringify(t)}catch{return e(`common.na`)}}function r(e){let r=t(e.configForm,e.channelId);return r?e.fields.flatMap(e=>e in r?[{label:e,value:n(r[e])}]:[]):[]}export{t as n,r,n as t};
|
|
2
|
+
//# sourceMappingURL=channel-config-extras-BlcntHgk.js.map
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
import{d as e,l as t,r as n}from"./i18n-DLwqUqi0.js";import{I as r,P as i,k as a,l as o,n as s,r as c}from"./index-or46Cf5v.js";import{n as l,t as u}from"./channel-config-extras-BlcntHgk.js";function d(e,t){let n=e;for(let e of t){if(!n)return null;let t=r(n);if(t===`object`){let t=n.properties??{};if(typeof e==`string`&&t[e]){n=t[e];continue}let r=n.additionalProperties;if(typeof e==`string`&&r&&typeof r==`object`){n=r;continue}return null}if(t===`array`){if(typeof e!=`number`)return null;n=(Array.isArray(n.items)?n.items[0]:n.items)??null;continue}return null}return n}function f(e,t){return l(e,t)??{}}var p=[`groupPolicy`,`streamMode`,`dmPolicy`];function m(t){let n=p.flatMap(e=>e in t?[[e,t[e]]]:[]);return n.length===0?null:e`
|
|
2
|
+
<div class="status-list" style="margin-top: 12px;">
|
|
3
|
+
${n.map(([t,n])=>e`
|
|
4
|
+
<div>
|
|
5
|
+
<span class="label">${t}</span>
|
|
6
|
+
<span>${u(n)}</span>
|
|
7
|
+
</div>
|
|
8
|
+
`)}
|
|
9
|
+
</div>
|
|
10
|
+
`}function h(t){let n=s(t.schema),r=n.schema;if(!r)return e` <div class="callout danger">Schema unavailable. Use Raw.</div> `;let i=d(r,[`channels`,t.channelId]);if(!i)return e` <div class="callout danger">Channel config schema unavailable.</div> `;let a=f(t.configValue??{},t.channelId);return e`
|
|
11
|
+
<div class="config-form">
|
|
12
|
+
${c({schema:i,value:a,path:[`channels`,t.channelId],hints:t.uiHints,unsupported:new Set(n.unsupportedPaths),disabled:t.disabled,showLabel:!1,onPatch:t.onPatch})}
|
|
13
|
+
</div>
|
|
14
|
+
${m(a)}
|
|
15
|
+
`}function g(t){let{channelId:r,props:i}=t,a=i.configSchemaLoading&&!i.configSchema,o=i.configSaving||a;return e`
|
|
16
|
+
<div style="margin-top: 16px;">
|
|
17
|
+
${a?e` <div class="muted">Loading config schema…</div> `:h({channelId:r,configValue:i.configForm,schema:i.configSchema,uiHints:i.configUiHints,disabled:o,onPatch:i.onConfigPatch})}
|
|
18
|
+
<div class="row" style="margin-top: 12px;">
|
|
19
|
+
<button
|
|
20
|
+
class="btn primary"
|
|
21
|
+
?disabled=${o||!i.configFormDirty}
|
|
22
|
+
@click=${()=>i.onConfigSave()}
|
|
23
|
+
>
|
|
24
|
+
${i.configSaving?`Saving…`:`Save`}
|
|
25
|
+
</button>
|
|
26
|
+
<button class="btn" ?disabled=${o} @click=${()=>i.onConfigReload()}>
|
|
27
|
+
${n(`common.reload`)}
|
|
28
|
+
</button>
|
|
29
|
+
</div>
|
|
30
|
+
</div>
|
|
31
|
+
`}function _(e,t){return t.snapshot?.channels?.[e]}function v(e,t){let n=t.snapshot?.channelAccounts?.[e]??[],r=t.snapshot?.channelDefaultAccountId?.[e];return(r?n.find(e=>e.accountId===r):void 0)??n[0]??null}function y(e,t){let n=_(e,t),r=t.snapshot?.channelAccounts?.[e]??[],i=v(e,t);return{configured:typeof n?.configured==`boolean`?n.configured:typeof i?.configured==`boolean`?i.configured:null,running:typeof n?.running==`boolean`?n.running:null,connected:typeof n?.connected==`boolean`?n.connected:null,defaultAccount:i,hasAnyActiveAccount:r.some(e=>e.configured||e.running||e.connected),status:n}}function b(e,t){if(!t.snapshot)return!1;let n=y(e,t);return n.configured===!0||n.running===!0||n.connected===!0||n.hasAnyActiveAccount}function x(e,t){return t?.[e]?.length??0}var S=`grid-template-columns: 1.6fr 1fr 0.8fr 1fr 0.9fr;`;function C(e,t){let n=y(e,t);return typeof n.status?.lastError==`string`&&n.status.lastError?{label:`Error`,dot:`status-dot--error`,online:!1}:n.connected===!0||n.running===!0?{label:`Online`,dot:`status-dot--ok`,online:!0}:n.configured===!0||n.hasAnyActiveAccount?{label:`Idle`,dot:`status-dot--idle`,online:!1}:{label:`Offline`,dot:`status-dot--idle`,online:!1}}function w(e){return e.charAt(0).toUpperCase()+e.slice(1)}function T(e){return e?.channelMeta?.length?Object.fromEntries(e.channelMeta.map(e=>[e.id,e])):{}}function E(e,t){return T(e)[t]?.label??e?.channelLabels?.[t]??w(t)}function D(e){return e?.channelMeta?.length?e.channelMeta.map(e=>e.id):e?.channelOrder?.length?e.channelOrder:[`whatsapp`,`telegram`,`discord`,`googlechat`,`slack`,`signal`,`imessage`,`nostr`]}function O(t,r){let a=E(r.snapshot,t),o=C(t,r),s=x(t,r.snapshot?.channelAccounts??null),c=v(t,r),l=c?.lastInboundAt?i(c.lastInboundAt):n(`common.na`);return e`
|
|
32
|
+
<div
|
|
33
|
+
class="table-row"
|
|
34
|
+
style="cursor: pointer; ${S}"
|
|
35
|
+
title=${`Configure ${a}`}
|
|
36
|
+
@click=${()=>r.onChannelSelect(t)}
|
|
37
|
+
>
|
|
38
|
+
<span style="color: var(--text); display: flex; align-items: center; gap: 8px; min-width: 0;">
|
|
39
|
+
<span class="status-dot ${o.dot}" style="flex: none;"></span>
|
|
40
|
+
<span style="overflow: hidden; text-overflow: ellipsis; white-space: nowrap;"
|
|
41
|
+
>${a}</span
|
|
42
|
+
>
|
|
43
|
+
</span>
|
|
44
|
+
<span class="muted">${w(t)}</span>
|
|
45
|
+
<span class="muted" style="font-family: var(--mono);">${s}</span>
|
|
46
|
+
<span class="muted" style="font-family: var(--mono);">${l}</span>
|
|
47
|
+
<span class="muted">${o.label}</span>
|
|
48
|
+
</div>
|
|
49
|
+
`}function k(n){let r=n.selectedChannelId;return r?e`
|
|
50
|
+
<div class="exec-approval-overlay" role="dialog" aria-modal="true">
|
|
51
|
+
<div class="exec-approval-card channel-settings-card">
|
|
52
|
+
<div class="exec-approval-header">
|
|
53
|
+
<div>
|
|
54
|
+
<div class="exec-approval-title">${E(n.snapshot,r)} settings</div>
|
|
55
|
+
<div class="exec-approval-sub">${w(r)}</div>
|
|
56
|
+
</div>
|
|
57
|
+
<button
|
|
58
|
+
class="icon-btn"
|
|
59
|
+
aria-label="Close"
|
|
60
|
+
@click=${()=>n.onChannelSettingsClose()}
|
|
61
|
+
>
|
|
62
|
+
${o.x}
|
|
63
|
+
</button>
|
|
64
|
+
</div>
|
|
65
|
+
${g({channelId:r,props:n})}
|
|
66
|
+
</div>
|
|
67
|
+
</div>
|
|
68
|
+
`:t}function A(r){let i=a(D(r.snapshot).map((e,t)=>({key:e,enabled:b(e,r),order:t})),(e,t)=>e.enabled===t.enabled?e.order-t.order:e.enabled?-1:1),s=i.filter(e=>C(e.key,r).online).length,c=i.length-s;return e`
|
|
69
|
+
<section class="card" style="border: none; background: transparent; padding: 0;">
|
|
70
|
+
<div class="row" style="justify-content: space-between; align-items: flex-start; gap: 16px;">
|
|
71
|
+
<div>
|
|
72
|
+
<div class="view-title">${n(`tabs.channels`)}</div>
|
|
73
|
+
<div class="view-sub">${s} connected · ${c} idle</div>
|
|
74
|
+
</div>
|
|
75
|
+
<button
|
|
76
|
+
class="btn primary"
|
|
77
|
+
?disabled=${!r.connected||r.channelWizardBusy}
|
|
78
|
+
@click=${()=>r.onChannelWizardStart()}
|
|
79
|
+
>
|
|
80
|
+
<span class="btn__icon">${o.plus}</span>
|
|
81
|
+
${r.channelWizardBusy?n(`common.working`):n(`channels.wizard.addChannel`)}
|
|
82
|
+
</button>
|
|
83
|
+
</div>
|
|
84
|
+
|
|
85
|
+
${r.lastError?e`<div class="callout danger" style="margin-top: 16px;">${r.lastError}</div>`:t}
|
|
86
|
+
${i.length===0?e`<div class="muted" style="padding: 16px;">
|
|
87
|
+
${r.loading?n(`common.loading`):n(`common.na`)}
|
|
88
|
+
</div>`:e`
|
|
89
|
+
<div class="table" style="margin-top: 20px;">
|
|
90
|
+
<div class="table-head" style=${S}>
|
|
91
|
+
<span>CHANNEL</span>
|
|
92
|
+
<span>PROVIDER</span>
|
|
93
|
+
<span>ACCOUNTS</span>
|
|
94
|
+
<span>LAST ACTIVITY</span>
|
|
95
|
+
<span>STATUS</span>
|
|
96
|
+
</div>
|
|
97
|
+
${i.map(e=>O(e.key,r))}
|
|
98
|
+
</div>
|
|
99
|
+
`}
|
|
100
|
+
${j(r)} ${k(r)}
|
|
101
|
+
</section>
|
|
102
|
+
`}function j(r){let i=r.channelWizardStep,a=!!(r.channelWizardError||r.channelWizardMessage);if(!i&&!r.channelWizardBusy&&!a)return t;let o=i?.title||(r.channelWizardError?n(`channels.wizard.errorTitle`):r.channelWizardMessage?n(`channels.wizard.doneTitle`):n(`channels.wizard.title`)),s=i?.message??r.channelWizardError??r.channelWizardMessage??``,c=!!i&&!r.channelWizardBusy;return e`
|
|
103
|
+
<div class="exec-approval-overlay" role="dialog" aria-modal="true" aria-live="polite">
|
|
104
|
+
<div class="exec-approval-card channel-wizard-card">
|
|
105
|
+
<div class="exec-approval-header">
|
|
106
|
+
<div>
|
|
107
|
+
<div class="exec-approval-title">${o}</div>
|
|
108
|
+
<div class="exec-approval-sub">${n(`channels.wizard.subtitle`)}</div>
|
|
109
|
+
</div>
|
|
110
|
+
</div>
|
|
111
|
+
${s?e`<div class="channel-wizard-message">${M(s)}</div>`:t}
|
|
112
|
+
${i?F(r,i):t}
|
|
113
|
+
${r.channelWizardError?e`<div class="exec-approval-error">${r.channelWizardError}</div>`:t}
|
|
114
|
+
<div class="exec-approval-actions">
|
|
115
|
+
${i?e`
|
|
116
|
+
<button
|
|
117
|
+
class="btn primary"
|
|
118
|
+
?disabled=${!c}
|
|
119
|
+
@click=${()=>r.onChannelWizardSubmit()}
|
|
120
|
+
>
|
|
121
|
+
${r.channelWizardBusy?n(`common.working`):n(`channels.wizard.continue`)}
|
|
122
|
+
</button>
|
|
123
|
+
<button
|
|
124
|
+
class="btn"
|
|
125
|
+
?disabled=${r.channelWizardBusy}
|
|
126
|
+
@click=${()=>r.onChannelWizardCancel()}
|
|
127
|
+
>
|
|
128
|
+
${n(`common.cancel`)}
|
|
129
|
+
</button>
|
|
130
|
+
`:e`
|
|
131
|
+
<button
|
|
132
|
+
class="btn primary"
|
|
133
|
+
?disabled=${r.channelWizardBusy}
|
|
134
|
+
@click=${()=>r.onChannelWizardClose()}
|
|
135
|
+
>
|
|
136
|
+
${n(`common.ok`)}
|
|
137
|
+
</button>
|
|
138
|
+
`}
|
|
139
|
+
</div>
|
|
140
|
+
</div>
|
|
141
|
+
</div>
|
|
142
|
+
`}function M(n){return n.split(`
|
|
143
|
+
`).map(e=>e.trimEnd()).map((n,r)=>e`${r>0?e`<br />`:t}${n}`)}function N(e){if(typeof e==`string`)return`string:${e}`;try{return`json:${JSON.stringify(e)}`}catch{return String(e)}}function P(e,t){return N(e)===N(t)}function F(r,i){if(i.type===`select`)return e`
|
|
144
|
+
<div class="channel-wizard-options">
|
|
145
|
+
${(i.options??[]).map(n=>e`
|
|
146
|
+
<button
|
|
147
|
+
class=${P(r.channelWizardInput,n.value)?`channel-wizard-option selected`:`channel-wizard-option`}
|
|
148
|
+
?disabled=${r.channelWizardBusy}
|
|
149
|
+
@click=${()=>r.onChannelWizardInput(n.value)}
|
|
150
|
+
>
|
|
151
|
+
<span>${n.label}</span>
|
|
152
|
+
${n.hint?e`<small>${n.hint}</small>`:t}
|
|
153
|
+
</button>
|
|
154
|
+
`)}
|
|
155
|
+
</div>
|
|
156
|
+
`;if(i.type===`multiselect`){let n=Array.isArray(r.channelWizardInput)?r.channelWizardInput:[];return e`
|
|
157
|
+
<div class="channel-wizard-options">
|
|
158
|
+
${(i.options??[]).map(i=>{let a=n.some(e=>P(e,i.value)),o=a?n.filter(e=>!P(e,i.value)):[...n,i.value];return e`
|
|
159
|
+
<button
|
|
160
|
+
class=${a?`channel-wizard-option selected`:`channel-wizard-option`}
|
|
161
|
+
?disabled=${r.channelWizardBusy}
|
|
162
|
+
@click=${()=>r.onChannelWizardInput(o)}
|
|
163
|
+
>
|
|
164
|
+
<span>${i.label}</span>
|
|
165
|
+
${i.hint?e`<small>${i.hint}</small>`:t}
|
|
166
|
+
</button>
|
|
167
|
+
`})}
|
|
168
|
+
</div>
|
|
169
|
+
`}if(i.type===`confirm`)return e`
|
|
170
|
+
<div class="channel-wizard-confirm">
|
|
171
|
+
<button
|
|
172
|
+
class=${r.channelWizardInput===!0?`btn primary`:`btn`}
|
|
173
|
+
?disabled=${r.channelWizardBusy}
|
|
174
|
+
@click=${()=>r.onChannelWizardInput(!0)}
|
|
175
|
+
>
|
|
176
|
+
${n(`common.yes`)}
|
|
177
|
+
</button>
|
|
178
|
+
<button
|
|
179
|
+
class=${r.channelWizardInput===!1?`btn primary`:`btn`}
|
|
180
|
+
?disabled=${r.channelWizardBusy}
|
|
181
|
+
@click=${()=>r.onChannelWizardInput(!1)}
|
|
182
|
+
>
|
|
183
|
+
${n(`common.no`)}
|
|
184
|
+
</button>
|
|
185
|
+
</div>
|
|
186
|
+
`;if(i.type===`text`){let t=typeof r.channelWizardInput==`string`?r.channelWizardInput:``;return e`
|
|
187
|
+
<input
|
|
188
|
+
class="input channel-wizard-text"
|
|
189
|
+
type=${i.sensitive?`password`:`text`}
|
|
190
|
+
.value=${t}
|
|
191
|
+
placeholder=${i.placeholder??``}
|
|
192
|
+
?disabled=${r.channelWizardBusy}
|
|
193
|
+
@input=${e=>r.onChannelWizardInput(e.currentTarget.value)}
|
|
194
|
+
/>
|
|
195
|
+
`}return t}export{A as renderChannels};
|
|
196
|
+
//# sourceMappingURL=channels-D_T7jf1i.js.map
|