palmier 0.9.7 → 0.9.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/agents/agent-instructions.md +5 -3
- package/dist/commands/run.js +59 -16
- package/dist/pwa/assets/{index-DWvRAUiy.js → index-dvjO6dHB.js} +2 -2
- package/dist/pwa/assets/{web-CBFqJGX6.js → web-CYs_8c0k.js} +1 -1
- package/dist/pwa/assets/{web-DL4uXOpS.js → web-DAcCX19l.js} +1 -1
- package/dist/pwa/assets/{web-C4iZbqTC.js → web-DSL9bja4.js} +1 -1
- package/dist/pwa/index.html +1 -1
- package/dist/rpc-handler.js +3 -1
- package/dist/spawn-command.d.ts +4 -0
- package/dist/spawn-command.js +6 -4
- package/dist/task.d.ts +1 -1
- package/dist/task.js +8 -4
- package/dist/types.d.ts +3 -0
- package/package.json +7 -1
- package/dist/pwa/apple-touch-icon.png +0 -0
- package/dist/pwa/manifest.webmanifest +0 -1
- package/dist/pwa/pwa-192x192.png +0 -0
- package/dist/pwa/pwa-512x512.png +0 -0
- package/dist/pwa/registerSW.js +0 -1
- package/dist/pwa/service-worker.js +0 -2
|
@@ -1,19 +1,21 @@
|
|
|
1
1
|
You are an AI agent executing a task on behalf of the user. Follow these instructions carefully.
|
|
2
2
|
|
|
3
|
+
All `[PALMIER_*]` markers below are control signals parsed by the host. They MUST be written to **stdout** (not stderr). Markers on stderr are ignored.
|
|
4
|
+
|
|
3
5
|
## Reporting Output
|
|
4
6
|
|
|
5
|
-
If you generate report or output files, print each file path on its own line using this exact format:
|
|
7
|
+
If you generate report or output files, print each file path on its own line to stdout using this exact format:
|
|
6
8
|
[PALMIER_REPORT] <filename>
|
|
7
9
|
|
|
8
10
|
## Completion
|
|
9
11
|
|
|
10
|
-
When you are done, output exactly one of these markers as the very last line (no other text on the same line):
|
|
12
|
+
When you are done, output exactly one of these markers as the very last line on stdout (no other text on the same line):
|
|
11
13
|
[PALMIER_TASK_SUCCESS]
|
|
12
14
|
[PALMIER_TASK_FAILURE]
|
|
13
15
|
|
|
14
16
|
## Permissions
|
|
15
17
|
|
|
16
|
-
Whenever a tool you are trying to use is denied or you lack the required permissions, print each required permission on its own line using this exact format:
|
|
18
|
+
Whenever a tool you are trying to use is denied or you lack the required permissions, print each required permission on its own line to stdout using this exact format:
|
|
17
19
|
[PALMIER_PERMISSION] <tool_name> | <description>
|
|
18
20
|
|
|
19
21
|
## HTTP Endpoints
|
package/dist/commands/run.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import * as fs from "fs";
|
|
2
2
|
import * as path from "path";
|
|
3
3
|
import * as readline from "readline";
|
|
4
|
+
import { StringCodec } from "nats";
|
|
4
5
|
import { spawnCommand, spawnStreamingCommand } from "../spawn-command.js";
|
|
5
6
|
import { loadConfig } from "../config.js";
|
|
6
7
|
import { connectNats } from "../nats-client.js";
|
|
@@ -9,6 +10,18 @@ import { getAgent } from "../agents/agent.js";
|
|
|
9
10
|
import { getPlatform } from "../platform/index.js";
|
|
10
11
|
import { TASK_SUCCESS_MARKER, TASK_FAILURE_MARKER, TASK_REPORT_PREFIX, TASK_PERMISSION_PREFIX } from "../agents/shared-prompt.js";
|
|
11
12
|
import { publishHostEvent } from "../events.js";
|
|
13
|
+
async function sendPushNotification(nc, hostId, title, body) {
|
|
14
|
+
if (!nc)
|
|
15
|
+
return;
|
|
16
|
+
try {
|
|
17
|
+
const sc = StringCodec();
|
|
18
|
+
const subject = `host.${hostId}.push.send`;
|
|
19
|
+
await nc.request(subject, sc.encode(JSON.stringify({ hostId, title, body })), { timeout: 15_000 });
|
|
20
|
+
}
|
|
21
|
+
catch (err) {
|
|
22
|
+
console.warn(`[push] failed to send notification:`, err);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
12
25
|
/**
|
|
13
26
|
* Invoke the agent CLI in a continuation loop to handle permission requests.
|
|
14
27
|
* `invokeTask` is the ParsedTask whose prompt is passed to the agent (in
|
|
@@ -17,8 +30,9 @@ import { publishHostEvent } from "../events.js";
|
|
|
17
30
|
async function invokeAgentWithRetries(ctx, invokeTask) {
|
|
18
31
|
// eslint-disable-next-line no-constant-condition
|
|
19
32
|
while (true) {
|
|
20
|
-
|
|
21
|
-
let
|
|
33
|
+
let writer = beginStreamingMessage(ctx.taskDir, ctx.runId, Date.now(), "stdout");
|
|
34
|
+
let activeStream = "stdout";
|
|
35
|
+
const lineBufs = { stdout: "", stderr: "" };
|
|
22
36
|
let notifyPending = false;
|
|
23
37
|
let notifyTimer;
|
|
24
38
|
function throttledNotify() {
|
|
@@ -30,6 +44,21 @@ async function invokeAgentWithRetries(ctx, invokeTask) {
|
|
|
30
44
|
publishHostEvent(ctx.nc, ctx.config.hostId, ctx.taskId, { event_type: "result-updated", run_id: ctx.runId });
|
|
31
45
|
}, 500);
|
|
32
46
|
}
|
|
47
|
+
function emit(stream, chunk) {
|
|
48
|
+
lineBufs[stream] += chunk;
|
|
49
|
+
const lines = lineBufs[stream].split("\n");
|
|
50
|
+
lineBufs[stream] = lines.pop() ?? "";
|
|
51
|
+
const filtered = lines.filter((l) => !l.startsWith("[PALMIER"));
|
|
52
|
+
if (filtered.length === 0)
|
|
53
|
+
return;
|
|
54
|
+
if (stream !== activeStream) {
|
|
55
|
+
writer.end();
|
|
56
|
+
writer = beginStreamingMessage(ctx.taskDir, ctx.runId, Date.now(), stream);
|
|
57
|
+
activeStream = stream;
|
|
58
|
+
}
|
|
59
|
+
writer.write(filtered.join("\n") + "\n");
|
|
60
|
+
throttledNotify();
|
|
61
|
+
}
|
|
33
62
|
const { command, args, stdin, env: agentEnv } = ctx.agent.getTaskRunCommandLine(invokeTask, undefined, ctx.task.frontmatter.yolo_mode ? "yolo" : ctx.transientPermissions);
|
|
34
63
|
const result = await spawnCommand(command, args, {
|
|
35
64
|
cwd: getRunDir(ctx.taskDir, ctx.runId),
|
|
@@ -37,29 +66,39 @@ async function invokeAgentWithRetries(ctx, invokeTask) {
|
|
|
37
66
|
echoStdout: true,
|
|
38
67
|
resolveOnFailure: true,
|
|
39
68
|
stdin,
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
const lines = lineBuf.split("\n");
|
|
43
|
-
lineBuf = lines.pop() ?? "";
|
|
44
|
-
const filtered = lines.filter((l) => !l.startsWith("[PALMIER"));
|
|
45
|
-
if (filtered.length > 0) {
|
|
46
|
-
writer.write(filtered.join("\n") + "\n");
|
|
47
|
-
throttledNotify();
|
|
48
|
-
}
|
|
49
|
-
},
|
|
69
|
+
onStdout: (chunk) => emit("stdout", chunk),
|
|
70
|
+
onStderr: (chunk) => emit("stderr", chunk),
|
|
50
71
|
});
|
|
51
72
|
if (notifyTimer)
|
|
52
73
|
clearTimeout(notifyTimer);
|
|
53
74
|
const outcome = result.exitCode !== 0 ? "failed" : parseTaskOutcome(result.output);
|
|
54
75
|
const reportFiles = parseReportFiles(result.output);
|
|
55
76
|
const requiredPermissions = parsePermissions(result.output);
|
|
56
|
-
|
|
57
|
-
|
|
77
|
+
for (const stream of ["stdout", "stderr"]) {
|
|
78
|
+
const trailing = lineBufs[stream];
|
|
79
|
+
if (trailing && !trailing.startsWith("[PALMIER")) {
|
|
80
|
+
if (stream !== activeStream) {
|
|
81
|
+
writer.end();
|
|
82
|
+
writer = beginStreamingMessage(ctx.taskDir, ctx.runId, Date.now(), stream);
|
|
83
|
+
activeStream = stream;
|
|
84
|
+
}
|
|
85
|
+
writer.write(trailing);
|
|
86
|
+
}
|
|
58
87
|
}
|
|
59
88
|
if (requiredPermissions.length > 0) {
|
|
89
|
+
if (activeStream !== "stdout") {
|
|
90
|
+
writer.end();
|
|
91
|
+
writer = beginStreamingMessage(ctx.taskDir, ctx.runId, Date.now(), "stdout");
|
|
92
|
+
activeStream = "stdout";
|
|
93
|
+
}
|
|
60
94
|
const permLines = requiredPermissions.map((p) => `- **${p.name}** ${p.description}`).join("\n");
|
|
61
95
|
writer.write(`\n\n**Permissions requested:**\n${permLines}\n`);
|
|
62
96
|
}
|
|
97
|
+
if (reportFiles.length > 0 && activeStream !== "stdout") {
|
|
98
|
+
writer.end();
|
|
99
|
+
writer = beginStreamingMessage(ctx.taskDir, ctx.runId, Date.now(), "stdout");
|
|
100
|
+
activeStream = "stdout";
|
|
101
|
+
}
|
|
63
102
|
writer.end(reportFiles.length > 0 ? reportFiles : undefined);
|
|
64
103
|
await publishHostEvent(ctx.nc, ctx.config.hostId, ctx.taskId, { event_type: "result-updated", run_id: ctx.runId });
|
|
65
104
|
if (reportFiles.length > 0) {
|
|
@@ -289,6 +328,8 @@ async function runCommandTriggeredMode(ctx) {
|
|
|
289
328
|
}
|
|
290
329
|
else {
|
|
291
330
|
invocationsFailed++;
|
|
331
|
+
const taskLabel = ctx.task.frontmatter.name || ctx.task.frontmatter.user_prompt;
|
|
332
|
+
await sendPushNotification(ctx.nc, ctx.config.hostId, `Task "${taskLabel}" invocation failed`, line.length > 200 ? line.slice(0, 200) + "…" : line);
|
|
292
333
|
}
|
|
293
334
|
appendLog(line, "", result.outcome);
|
|
294
335
|
// Signal "waiting for more input" in the UI.
|
|
@@ -381,6 +422,7 @@ async function runEventTriggeredMode(ctx) {
|
|
|
381
422
|
appendRunMessage(ctx.taskDir, ctx.runId, { role: "status", time: Date.now(), content: "", type: "monitoring" });
|
|
382
423
|
await publishHostEvent(ctx.nc, ctx.config.hostId, ctx.taskId, { event_type: "result-updated", run_id: ctx.runId });
|
|
383
424
|
let eventsProcessed = 0;
|
|
425
|
+
let lastOutcome = "finished";
|
|
384
426
|
try {
|
|
385
427
|
// eslint-disable-next-line no-constant-condition
|
|
386
428
|
while (true) {
|
|
@@ -396,7 +438,8 @@ async function runEventTriggeredMode(ctx) {
|
|
|
396
438
|
const perEventTask = {
|
|
397
439
|
frontmatter: { ...ctx.task.frontmatter, user_prompt: perEventPrompt },
|
|
398
440
|
};
|
|
399
|
-
await invokeAgentWithRetries(ctx, perEventTask);
|
|
441
|
+
const result = await invokeAgentWithRetries(ctx, perEventTask);
|
|
442
|
+
lastOutcome = result.outcome;
|
|
400
443
|
appendRunMessage(ctx.taskDir, ctx.runId, { role: "status", time: Date.now(), content: "", type: "monitoring" });
|
|
401
444
|
await publishHostEvent(ctx.nc, ctx.config.hostId, ctx.taskId, { event_type: "result-updated", run_id: ctx.runId });
|
|
402
445
|
}
|
|
@@ -407,7 +450,7 @@ async function runEventTriggeredMode(ctx) {
|
|
|
407
450
|
await publishHostEvent(ctx.nc, ctx.config.hostId, ctx.taskId, { event_type: "result-updated", run_id: ctx.runId });
|
|
408
451
|
return { outcome: "failed", endTime: Date.now() };
|
|
409
452
|
}
|
|
410
|
-
return { outcome:
|
|
453
|
+
return { outcome: lastOutcome, endTime: Date.now() };
|
|
411
454
|
}
|
|
412
455
|
async function publishTaskEvent(nc, config, taskDir, taskId, eventType, taskName, runId) {
|
|
413
456
|
writeTaskStatus(taskDir, {
|
|
@@ -84,7 +84,7 @@ ${d}`),g(S);return}f(null,T),s.strategy===xr.Count&&(m--,m===0&&g()),s.strategy=
|
|
|
84
84
|
|
|
85
85
|
${f.stack}`),d.unsubscribe(),c.reject(m)):(m=hx(y),m?(f&&(m.stack+=`
|
|
86
86
|
|
|
87
|
-
${f.stack}`),c.reject(m)):c.resolve(y))}});return d.requestSubject=t,this.protocol.publish(t,r,{reply:u,headers:s.headers}),c}else{const u=new px(this.protocol.muxSubscriptions,t,s,l);this.protocol.request(u);try{this.publish(t,r,{reply:`${this.protocol.muxSubscriptions.baseInbox}${u.token}`,headers:s.headers})}catch(f){u.cancel(f)}const c=Promise.race([u.timer,u.deferred]);return c.catch(()=>{u.cancel()}),c}}flush(){return this.isClosed()?Promise.reject(Te.errorForCode(Se.ConnectionClosed)):this.protocol.flush()}drain(){return this.isClosed()?Promise.reject(Te.errorForCode(Se.ConnectionClosed)):this.isDraining()?Promise.reject(Te.errorForCode(Se.ConnectionDraining)):(this.draining=!0,this.protocol.drain())}isClosed(){return this.protocol.isClosed()}isDraining(){return this.draining}getServer(){const t=this.protocol.getServer();return t?t.listen:""}status(){const t=new an;return t.iterClosed.then(()=>{const r=this.listeners.indexOf(t);this.listeners.splice(r,1)}),this.listeners.push(t),t}get info(){return this.protocol.isClosed()?void 0:this.protocol.info}async context(){return(await this.request("$SYS.REQ.USER.INFO")).json((r,s)=>r==="time"?new Date(Date.parse(s)):s)}stats(){return{inBytes:this.protocol.inBytes,outBytes:this.protocol.outBytes,inMsgs:this.protocol.inMsgs,outMsgs:this.protocol.outMsgs}}async jetstreamManager(t={}){const r=new Dk(this,t);if(t.checkAPI!==!1)try{await r.getAccountInfo()}catch(s){const l=s;throw l.code===Se.NoResponders&&(l.code=Se.JetStreamNotEnabled),l}return r}jetstream(t={}){return new Bd(this,t)}getServerVersion(){const t=this.info;return t?ms(t.version):void 0}async rtt(){if(!this.protocol._closed&&!this.protocol.connected)throw Te.errorForCode(Se.Disconnect);const t=Date.now();return await this.flush(),Date.now()-t}get features(){return this.protocol.features}get services(){return this._services||(this._services=new Bk(this)),this._services}reconnect(){return this.isClosed()?Promise.reject(Te.errorForCode(Se.ConnectionClosed)):this.isDraining()?Promise.reject(Te.errorForCode(Se.ConnectionDraining)):this.protocol.reconnect()}}class Bk{constructor(t){C(this,"nc");this.nc=t}add(t){try{return new Yl(this.nc,t).start()}catch(r){return Promise.reject(r)}}client(t,r){return new yk(this.nc,t,r)}}class Pk{constructor(t,r,s){C(this,"bucket");C(this,"sm");C(this,"prefixLen");this.bucket=t,this.prefixLen=r,this.sm=s}get key(){return this.sm.subject.substring(this.prefixLen)}get value(){return this.sm.data}get delta(){return 0}get created(){return this.sm.time}get revision(){return this.sm.seq}get operation(){return this.sm.header.get(zu)||"PUT"}get length(){const t=this.sm.header.get(En.MessageSizeHdr)||"";return t!==""?parseInt(t,10):this.sm.data.length}json(){return this.sm.json()}string(){return this.sm.string()}}class Hk{constructor(t,r,s){C(this,"bucket");C(this,"key");C(this,"sm");this.bucket=t,this.key=r,this.sm=s}get value(){return this.sm.data}get created(){return new Date(Md(this.sm.info.timestampNanos))}get revision(){return this.sm.seq}get operation(){var t;return((t=this.sm.headers)==null?void 0:t.get(zu))||"PUT"}get delta(){return this.sm.info.pending}get length(){var r;const t=((r=this.sm.headers)==null?void 0:r.get(En.MessageSizeHdr))||"";return t!==""?parseInt(t,10):this.sm.data.length}json(){return this.sm.json()}string(){return this.sm.string()}}class jx extends y2{constructor(r,s,l){super(r.nc,s,l);C(this,"js");C(this,"monitor");this.js=r,this.monitor=null,this.sub.closed.then(()=>{this.monitor&&this.monitor.cancel()})}set info(r){this.sub.info=r}get info(){return this.sub.info}_resetOrderedConsumer(r){if(this.info===null||this.sub.isClosed())return;const s=ni(this.js.nc.options.inboxPrefix);this.js.nc._resub(this.sub,s);const u=this.info;u.config.name=Pi.next(),u.ordered_consumer_sequence.delivery_seq=0,u.flow_control.heartbeat_count=0,u.flow_control.fc_count=0,u.flow_control.consumer_restarts++,u.deliver=s,u.config.deliver_subject=s,u.config.deliver_policy=Vt.StartSequence,u.config.opt_start_seq=r;const c={};c.stream_name=this.info.stream,c.config=u.config;const f=`${u.api.prefix}.CONSUMER.CREATE.${u.stream}`;this.js._request(f,c,{retries:-1}).then(d=>{const m=d,y=this.sub.info;y.last=m,this.info.config=m.config,this.info.name=m.name}).catch(d=>{const m=new Te(`unable to recreate ordered consumer ${u.stream} at seq ${r}`,Se.RequestError,d);this.sub.callback(m,{})})}_maybeSetupHbMonitoring(){var s,l;const r=((l=(s=this.info)==null?void 0:s.config)==null?void 0:l.idle_heartbeat)||0;r&&this._setupHbMonitoring(Md(r))}_setupHbMonitoring(r,s=0){const l={cancelAfter:0,maxOut:2};s&&(l.cancelAfter=s);const u=this.sub,c=f=>{var y,g,x,w;const d=Q_(409,`${or.IdleHeartbeatMissed}: ${f}`,this.sub.subject);if(!((y=this.info)==null?void 0:y.ordered))this.sub.callback(null,d);else{if(!this.js.nc.protocol.connected)return!1;const S=((x=(g=this.info)==null?void 0:g.ordered_consumer_sequence)==null?void 0:x.stream_seq)||0;return this._resetOrderedConsumer(S+1),(w=this.monitor)==null||w.restart(),!1}return!u.noIterator};this.monitor=new Ld(r,c,l)}_checkHbOrderConsumer(r){const s=r.headers.get(En.ConsumerStalledHdr);s!==""&&this.js.nc.publish(s);const l=parseInt(r.headers.get(En.LastConsumerSeqHdr),10),u=this.info.ordered_consumer_sequence;return this.info.flow_control.heartbeat_count++,l!==u.delivery_seq&&this._resetOrderedConsumer(u.stream_seq+1),!1}_checkOrderedConsumer(r){const s=this.info.ordered_consumer_sequence,l=r.info.streamSequence,u=r.info.deliverySequence;return u!=s.delivery_seq+1?(this._resetOrderedConsumer(s.stream_seq+1),!1):(s.delivery_seq=u,s.stream_seq=l,!0)}async destroy(){this.isClosed()||await this.drain();const r=this.sub.info,s=r.config.durable_name||r.name,l=`${r.api.prefix}.CONSUMER.DELETE.${r.stream}.${s}`;await r.api._request(l)}async consumerInfo(){const r=this.sub.info,s=r.config.durable_name||r.name,l=`${r.api.prefix}.CONSUMER.INFO.${r.stream}.${s}`,u=await r.api._request(l);return r.last=u,u}}class qk extends jx{constructor(t,r,s){super(t,r,s)}pull(t={batch:1}){const{stream:r,config:s,name:l}=this.sub.info,u=s.durable_name??l,c={};if(c.batch=t.batch||1,c.no_wait=t.no_wait||!1,(t.max_bytes??0)>0){const m=this.js.nc.features.get(mt.JS_PULL_MAX_BYTES);if(!m.ok)throw new Error(`max_bytes is only supported on servers ${m.min} or better`);c.max_bytes=t.max_bytes}let f=0;t.expires&&t.expires>0&&(f=t.expires,c.expires=Ut(f));let d=0;if(t.idle_heartbeat&&t.idle_heartbeat>0&&(d=t.idle_heartbeat,c.idle_heartbeat=Ut(d)),d&&f===0)throw new Error("idle_heartbeat requires expires");if(d>f)throw new Error("expires must be greater than idle_heartbeat");if(this.info){this.monitor&&this.monitor.cancel(),f&&d&&(this.monitor?this.monitor._change(d,f):this._setupHbMonitoring(d,f));const m=this.info.api,y=`${m.prefix}.CONSUMER.MSG.NEXT.${r}.${u}`,g=this.sub.subject;m.nc.publish(y,m.jc.encode(c),{reply:g})}}}function Ik(e,t){return e?$k(t):Fk(t)}function Fk(e){return(t,r)=>t?[t,null]:(t=ua(r),t?[t,null]:[null,Pl(r,e)])}function $k(e){return(t,r)=>{if(t)return[t,null];const s=ua(r);return s!==null?[Tx(s),null]:[null,Pl(r,e)]}}function Tx(e){if(e!==null)switch(e.code){case Se.JetStream404NoMessages:case Se.JetStream408RequestTimeout:return null;case Se.JetStream409:return Z_(e)?e:null;default:return e}return null}function Yk(e){e&&e.ack()}function Gk(e){const t=e.split(".");if(t.length===9&&t.splice(2,0,"_",""),t.length<11||t[0]!=="$JS"||t[1]!=="ACK")throw new Error("not js message");const r={};return r.domain=t[2]==="_"?"":t[2],r.account_hash=t[3],r.stream=t[4],r.consumer=t[5],r.deliveryCount=parseInt(t[6],10),r.redeliveryCount=r.deliveryCount,r.redelivered=r.deliveryCount>1,r.streamSequence=parseInt(t[7],10),r.deliverySequence=parseInt(t[8],10),r.timestampNanos=parseInt(t[9],10),r.pending=parseInt(t[10],10),r}class Vk{constructor(t,r){C(this,"msg");C(this,"di");C(this,"didAck");C(this,"timeout");this.msg=t,this.didAck=!1,this.timeout=r}get subject(){return this.msg.subject}get sid(){return this.msg.sid}get data(){return this.msg.data}get headers(){return this.msg.headers}get info(){return this.di||(this.di=Gk(this.reply)),this.di}get redelivered(){return this.info.deliveryCount>1}get reply(){return this.msg.reply||""}get seq(){return this.info.streamSequence}doAck(t){this.didAck||(this.didAck=!this.isWIP(t),this.msg.respond(t))}isWIP(t){return t.length===4&&t[0]===xl[0]&&t[1]===xl[1]&&t[2]===xl[2]&&t[3]===xl[3]}async ackAck(t){var s;t=t||{},t.timeout=t.timeout||this.timeout;const r=Bt();if(this.didAck)r.resolve(!1);else if(this.didAck=!0,this.msg.reply){const u=this.msg.publisher,c=!((s=u.options)!=null&&s.noAsyncTraces),f=new px(u.muxSubscriptions,this.msg.reply,{timeout:t.timeout},c);u.request(f);try{u.publish(this.msg.reply,M0,{reply:`${u.muxSubscriptions.baseInbox}${f.token}`})}catch(d){f.cancel(d)}try{await Promise.race([f.timer,f.deferred]),r.resolve(!0)}catch(d){f.cancel(d),r.reject(d)}}else r.resolve(!1);return r}ack(){this.doAck(M0)}nak(t){let r=Ak;t&&(r=Nu().encode(`-NAK ${JSON.stringify({delay:Ut(t)})}`)),this.doAck(r)}working(){this.doAck(xl)}next(t,r={batch:1}){const s={};s.batch=r.batch||1,s.no_wait=r.no_wait||!1,r.expires&&r.expires>0&&(s.expires=Ut(r.expires));const l=vr().encode(s),u=ga.concat(jk,Nk,l),c=t?{reply:t}:void 0;this.msg.respond(u,c)}term(t=""){let r=Tk;(t==null?void 0:t.length)>0&&(r=Nu().encode(`+TERM ${t}`)),this.doAck(r)}json(){return this.msg.json()}string(){return this.msg.string()}}const Jk="1.30.3",Xk="nats.ws";class Kk{constructor(){C(this,"version");C(this,"lang");C(this,"closeError");C(this,"connected");C(this,"done");C(this,"socket");C(this,"options");C(this,"socketClosed");C(this,"encrypted");C(this,"peeked");C(this,"yields");C(this,"signal");C(this,"closedNotification");this.version=Jk,this.lang=Xk,this.connected=!1,this.done=!1,this.socketClosed=!1,this.encrypted=!1,this.peeked=!1,this.yields=[],this.signal=Bt(),this.closedNotification=Bt()}async connect(t,r){const s=Bt();if(r.tls)return s.reject(new Te("tls",Se.InvalidOption)),s;this.options=r;const l=t.src;if(r.wsFactory){const{socket:u,encrypted:c}=await r.wsFactory(t.src,r);this.socket=u,this.encrypted=c}else this.encrypted=l.indexOf("wss://")===0,this.socket=new WebSocket(l);return this.socket.binaryType="arraybuffer",this.socket.onopen=()=>{this.isDiscarded()},this.socket.onmessage=u=>{if(this.isDiscarded())return;if(this.yields.push(new Uint8Array(u.data)),this.peeked){this.signal.resolve();return}const c=ga.concat(...this.yields),f=_2(c);if(f!==""){const d=uk.exec(f);if(!d){r.debug&&console.error("!!!",cu(c)),s.reject(new Error("unexpected response from server"));return}try{const m=JSON.parse(d[1]);lk(m,this.options),this.peeked=!0,this.connected=!0,this.signal.resolve(),s.resolve()}catch(m){s.reject(m);return}}},this.socket.onclose=u=>{if(this.isDiscarded())return;this.socketClosed=!0;let c;this.done||(u.wasClean||(c=new Error(u.reason)),this._closed(c))},this.socket.onerror=u=>{if(this.isDiscarded())return;const c=u,f=new Te(c.message,Se.Unknown,new Error(c.error));s.reject(f)},s}disconnect(){this._closed(void 0,!0)}async _closed(t,r=!0){if(!this.isDiscarded()&&this.connected&&!this.done){if(this.closeError=t,!t)for(;!this.socketClosed&&this.socket.bufferedAmount>0;)await Sa(100);this.done=!0;try{this.socket.close(t?1002:1e3,t?t.message:void 0)}catch{}r&&this.closedNotification.resolve(t)}}get isClosed(){return this.done}[Symbol.asyncIterator](){return this.iterate()}async*iterate(){for(;;){if(this.isDiscarded())return;this.yields.length===0&&await this.signal;const t=this.yields;this.yields=[];for(let r=0;r<t.length;r++)this.options.debug&&console.info(`> ${cu(t[r])}`),yield t[r];if(this.done)break;this.yields.length===0&&(t.length=0,this.yields=t,this.signal=Bt())}}isEncrypted(){return this.connected&&this.encrypted}send(t){if(!this.isDiscarded())try{this.socket.send(t.buffer),this.options.debug&&console.info(`< ${cu(t)}`);return}catch(r){this.options.debug&&console.error(`!!! ${cu(t)}: ${r}`)}}close(t){return this._closed(t,!1)}closed(){return this.closedNotification}isDiscarded(){return this.done?(this.discard(),!0):!1}discard(){var t;this.done=!0;try{(t=this.socket)==null||t.close()}catch{}}}function Qk(e,t){/^(.*:\/\/)(.*)/.test(e)||(typeof t=="boolean"?e=`${t===!0?"https":"http"}://${e}`:e=`https://${e}`);let s=new URL(e);const l=s.protocol.toLowerCase();l==="ws:"&&(t=!1),l==="wss:"&&(t=!0),l!=="https:"&&l!=="http"&&(e=e.replace(/^(.*:\/\/)(.*)/gm,"$2"),s=new URL(`http://${e}`));let u,c;const f=s.hostname,d=s.pathname,m=s.search||"";switch(l){case"http:":case"ws:":case"nats:":c=s.port||"80",u="ws:";break;case"https:":case"wss:":case"tls:":c=s.port||"443",u="wss:";break;default:c=s.port||t===!0?"443":"80",u=t===!0?"wss:":"ws:";break}return`${u}//${f}:${c}${d}${m}`}function Nx(e={}){return b2({defaultPort:443,urlParseFn:Qk,factory:()=>new Kk}),Pd.connect(e)}/*! Capacitor: https://capacitorjs.com/ - MIT License */var ya;(function(e){e.Unimplemented="UNIMPLEMENTED",e.Unavailable="UNAVAILABLE"})(ya||(ya={}));class Ah extends Error{constructor(t,r,s){super(t),this.message=t,this.code=r,this.data=s}}const Zk=e=>{var t,r;return e!=null&&e.androidBridge?"android":!((r=(t=e==null?void 0:e.webkit)===null||t===void 0?void 0:t.messageHandlers)===null||r===void 0)&&r.bridge?"ios":"web"},Wk=e=>{const t=e.CapacitorCustomPlatform||null,r=e.Capacitor||{},s=r.Plugins=r.Plugins||{},l=()=>t!==null?t.name:Zk(e),u=()=>l()!=="web",c=g=>{const x=m.get(g);return!!(x!=null&&x.platforms.has(l())||f(g))},f=g=>{var x;return(x=r.PluginHeaders)===null||x===void 0?void 0:x.find(w=>w.name===g)},d=g=>e.console.error(g),m=new Map,y=(g,x={})=>{const w=m.get(g);if(w)return console.warn(`Capacitor plugin "${g}" already registered. Cannot register plugins twice.`),w.proxy;const S=l(),T=f(g);let z;const D=async()=>(!z&&S in x?z=typeof x[S]=="function"?z=await x[S]():z=x[S]:t!==null&&!z&&"web"in x&&(z=typeof x.web=="function"?z=await x.web():z=x.web),z),H=($,q)=>{var R,G;if(T){const J=T==null?void 0:T.methods.find(fe=>q===fe.name);if(J)return J.rtype==="promise"?fe=>r.nativePromise(g,q.toString(),fe):(fe,ie)=>r.nativeCallback(g,q.toString(),fe,ie);if($)return(R=$[q])===null||R===void 0?void 0:R.bind($)}else{if($)return(G=$[q])===null||G===void 0?void 0:G.bind($);throw new Ah(`"${g}" plugin is not implemented on ${S}`,ya.Unimplemented)}},F=$=>{let q;const R=(...G)=>{const J=D().then(fe=>{const ie=H(fe,$);if(ie){const ee=ie(...G);return q=ee==null?void 0:ee.remove,ee}else throw new Ah(`"${g}.${$}()" is not implemented on ${S}`,ya.Unimplemented)});return $==="addListener"&&(J.remove=async()=>q()),J};return R.toString=()=>`${$.toString()}() { [capacitor code] }`,Object.defineProperty(R,"name",{value:$,writable:!1,configurable:!1}),R},oe=F("addListener"),B=F("removeListener"),L=($,q)=>{const R=oe({eventName:$},q),G=async()=>{const fe=await R;B({eventName:$,callbackId:fe},q)},J=new Promise(fe=>R.then(()=>fe({remove:G})));return J.remove=async()=>{console.warn("Using addListener() without 'await' is deprecated."),await G()},J},W=new Proxy({},{get($,q){switch(q){case"$$typeof":return;case"toJSON":return()=>({});case"addListener":return T?L:oe;case"removeListener":return B;default:return F(q)}}});return s[g]=W,m.set(g,{name:g,proxy:W,platforms:new Set([...Object.keys(x),...T?[S]:[]])}),W};return r.convertFileSrc||(r.convertFileSrc=g=>g),r.getPlatform=l,r.handleError=d,r.isNativePlatform=u,r.isPluginAvailable=c,r.registerPlugin=y,r.Exception=Ah,r.DEBUG=!!r.DEBUG,r.isLoggingEnabled=!!r.isLoggingEnabled,r},eE=e=>e.Capacitor=Wk(e),Xn=eE(typeof globalThis<"u"?globalThis:typeof self<"u"?self:typeof window<"u"?window:typeof global<"u"?global:{}),ys=Xn.registerPlugin;class Hd{constructor(){this.listeners={},this.retainedEventArguments={},this.windowListeners={}}addListener(t,r){let s=!1;this.listeners[t]||(this.listeners[t]=[],s=!0),this.listeners[t].push(r);const u=this.windowListeners[t];u&&!u.registered&&this.addWindowListener(u),s&&this.sendRetainedArgumentsForEvent(t);const c=async()=>this.removeListener(t,r);return Promise.resolve({remove:c})}async removeAllListeners(){this.listeners={};for(const t in this.windowListeners)this.removeWindowListener(this.windowListeners[t]);this.windowListeners={}}notifyListeners(t,r,s){const l=this.listeners[t];if(!l){if(s){let u=this.retainedEventArguments[t];u||(u=[]),u.push(r),this.retainedEventArguments[t]=u}return}l.forEach(u=>u(r))}hasListeners(t){var r;return!!(!((r=this.listeners[t])===null||r===void 0)&&r.length)}registerWindowListener(t,r){this.windowListeners[r]={registered:!1,windowEventName:t,pluginEventName:r,handler:s=>{this.notifyListeners(r,s)}}}unimplemented(t="not implemented"){return new Xn.Exception(t,ya.Unimplemented)}unavailable(t="not available"){return new Xn.Exception(t,ya.Unavailable)}async removeListener(t,r){const s=this.listeners[t];if(!s)return;const l=s.indexOf(r);this.listeners[t].splice(l,1),this.listeners[t].length||this.removeWindowListener(this.windowListeners[t])}addWindowListener(t){window.addEventListener(t.windowEventName,t.handler),t.registered=!0}removeWindowListener(t){t&&(window.removeEventListener(t.windowEventName,t.handler),t.registered=!1)}sendRetainedArgumentsForEvent(t){const r=this.retainedEventArguments[t];r&&(delete this.retainedEventArguments[t],r.forEach(s=>{this.notifyListeners(t,s)}))}}const L0=e=>encodeURIComponent(e).replace(/%(2[346B]|5E|60|7C)/g,decodeURIComponent).replace(/[()]/g,escape),z0=e=>e.replace(/(%[\dA-F]{2})+/gi,decodeURIComponent);class tE extends Hd{async getCookies(){const t=document.cookie,r={};return t.split(";").forEach(s=>{if(s.length<=0)return;let[l,u]=s.replace(/=/,"CAP_COOKIE").split("CAP_COOKIE");l=z0(l).trim(),u=z0(u).trim(),r[l]=u}),r}async setCookie(t){try{const r=L0(t.key),s=L0(t.value),l=t.expires?`; expires=${t.expires.replace("expires=","")}`:"",u=(t.path||"/").replace("path=",""),c=t.url!=null&&t.url.length>0?`domain=${t.url}`:"";document.cookie=`${r}=${s||""}${l}; path=${u}; ${c};`}catch(r){return Promise.reject(r)}}async deleteCookie(t){try{document.cookie=`${t.key}=; Max-Age=0`}catch(r){return Promise.reject(r)}}async clearCookies(){try{const t=document.cookie.split(";")||[];for(const r of t)document.cookie=r.replace(/^ +/,"").replace(/=.*/,`=;expires=${new Date().toUTCString()};path=/`)}catch(t){return Promise.reject(t)}}async clearAllCookies(){try{await this.clearCookies()}catch(t){return Promise.reject(t)}}}ys("CapacitorCookies",{web:()=>new tE});const nE=async e=>new Promise((t,r)=>{const s=new FileReader;s.onload=()=>{const l=s.result;t(l.indexOf(",")>=0?l.split(",")[1]:l)},s.onerror=l=>r(l),s.readAsDataURL(e)}),rE=(e={})=>{const t=Object.keys(e);return Object.keys(e).map(l=>l.toLocaleLowerCase()).reduce((l,u,c)=>(l[u]=e[t[c]],l),{})},iE=(e,t=!0)=>e?Object.entries(e).reduce((s,l)=>{const[u,c]=l;let f,d;return Array.isArray(c)?(d="",c.forEach(m=>{f=t?encodeURIComponent(m):m,d+=`${u}=${f}&`}),d.slice(0,-1)):(f=t?encodeURIComponent(c):c,d=`${u}=${f}`),`${s}&${d}`},"").substr(1):null,sE=(e,t={})=>{const r=Object.assign({method:e.method||"GET",headers:e.headers},t),l=rE(e.headers)["content-type"]||"";if(typeof e.data=="string")r.body=e.data;else if(l.includes("application/x-www-form-urlencoded")){const u=new URLSearchParams;for(const[c,f]of Object.entries(e.data||{}))u.set(c,f);r.body=u.toString()}else if(l.includes("multipart/form-data")||e.data instanceof FormData){const u=new FormData;if(e.data instanceof FormData)e.data.forEach((f,d)=>{u.append(d,f)});else for(const f of Object.keys(e.data))u.append(f,e.data[f]);r.body=u;const c=new Headers(r.headers);c.delete("content-type"),r.headers=c}else(l.includes("application/json")||typeof e.data=="object")&&(r.body=JSON.stringify(e.data));return r};class aE extends Hd{async request(t){const r=sE(t,t.webFetchExtra),s=iE(t.params,t.shouldEncodeUrlParams),l=s?`${t.url}?${s}`:t.url,u=await fetch(l,r),c=u.headers.get("content-type")||"";let{responseType:f="text"}=u.ok?t:{};c.includes("application/json")&&(f="json");let d,m;switch(f){case"arraybuffer":case"blob":m=await u.blob(),d=await nE(m);break;case"json":d=await u.json();break;case"document":case"text":default:d=await u.text()}const y={};return u.headers.forEach((g,x)=>{y[x]=g}),{data:d,headers:y,status:u.status,url:u.url}}async get(t){return this.request(Object.assign(Object.assign({},t),{method:"GET"}))}async post(t){return this.request(Object.assign(Object.assign({},t),{method:"POST"}))}async put(t){return this.request(Object.assign(Object.assign({},t),{method:"PUT"}))}async patch(t){return this.request(Object.assign(Object.assign({},t),{method:"PATCH"}))}async delete(t){return this.request(Object.assign(Object.assign({},t),{method:"DELETE"}))}}ys("CapacitorHttp",{web:()=>new aE});var U0;(function(e){e.Dark="DARK",e.Light="LIGHT",e.Default="DEFAULT"})(U0||(U0={}));var B0;(function(e){e.StatusBar="StatusBar",e.NavigationBar="NavigationBar"})(B0||(B0={}));class lE extends Hd{async setStyle(){this.unavailable("not available for web")}async setAnimation(){this.unavailable("not available for web")}async show(){this.unavailable("not available for web")}async hide(){this.unavailable("not available for web")}}ys("SystemBars",{web:()=>new lE});const oE="modulepreload",uE=function(e){return"/"+e},P0={},qd=function(t,r,s){let l=Promise.resolve();if(r&&r.length>0){let c=function(m){return Promise.all(m.map(y=>Promise.resolve(y).then(g=>({status:"fulfilled",value:g}),g=>({status:"rejected",reason:g}))))};document.getElementsByTagName("link");const f=document.querySelector("meta[property=csp-nonce]"),d=(f==null?void 0:f.nonce)||(f==null?void 0:f.getAttribute("nonce"));l=c(r.map(m=>{if(m=uE(m),m in P0)return;P0[m]=!0;const y=m.endsWith(".css"),g=y?'[rel="stylesheet"]':"";if(document.querySelector(`link[href="${m}"]${g}`))return;const x=document.createElement("link");if(x.rel=y?"stylesheet":oE,y||(x.as="script"),x.crossOrigin="",x.href=m,d&&x.setAttribute("nonce",d),document.head.appendChild(x),y)return new Promise((w,S)=>{x.addEventListener("load",w),x.addEventListener("error",()=>S(new Error(`Unable to preload CSS for ${m}`)))})}))}function u(c){const f=new Event("vite:preloadError",{cancelable:!0});if(f.payload=c,window.dispatchEvent(f),!f.defaultPrevented)throw c}return l.then(c=>{for(const f of c||[])f.status==="rejected"&&u(f.reason);return t().catch(u)})},fd=ys("App",{web:()=>qd(()=>import("./web-C4iZbqTC.js"),[]).then(e=>new e.AppWeb)}),cE=ys("Network",{web:()=>qd(()=>import("./web-CBFqJGX6.js"),[]).then(e=>new e.NetworkWeb)}),Uu=Xn.isNativePlatform()?"https://app.palmier.me":"";async function Ox(e,t,r,s){const l=`${Uu}${t}`;console.log(`[API] ${e} ${l}`);const c=await fetch(l,{method:e,headers:{"Content-Type":"application/json"},body:r!=null?JSON.stringify(r):void 0});if(!c.ok){const f=await c.text();let d;try{const m=JSON.parse(f);d=m.error??m.message??f}catch{d=f}throw console.error(`[API] ${e} ${t} failed:`,c.status,d),new Error(d||`Request failed with status ${c.status}`)}return console.log(`[API] ${e} ${t} ->`,c.status),c.json()}function fE(e,t,r){return Ox("POST",e,t)}function hE(e,t){return Ox("GET",e,void 0)}const H0=Xn.isNativePlatform(),Rx=j.createContext(null),dE=2e3,jh=6e3,mE=1500,pE=6e4;function gE({children:e,activeHost:t}){const[r,s]=j.useState(null),[l,u]=j.useState(!1),c=j.useRef(null),[f,d]=j.useState(!1),[m,y]=j.useState(!1),[g,x]=j.useState(!1),[w,S]=j.useState(!1),T=j.useRef(Nu()),z=j.useRef(new Set),D=j.useRef(0),H=!!t.directUrl,F=H0&&!H&&!!t.lanUrl&&w,oe=m||g?"disconnected":H?f?"direct":"connecting":l?F?"lan":"nats":"connecting",B=oe!=="connecting"&&oe!=="disconnected";j.useEffect(()=>{y(!1),x(!1)},[t.hostId,t.clientToken]),j.useEffect(()=>{if(!H0||H||!t.lanUrl){S(!1);return}let $=!1;const q=t.lanUrl,R=t.hostId;async function G(){console.log("[HOST/LAN] probing",q);try{const ee=await fetch(`${q}/health`,{signal:AbortSignal.timeout(mE)});if($)return;if(!ee.ok){console.log("[HOST/LAN] probe got non-ok:",ee.status),S(!1);return}const P=await ee.json(),X=P.hostId===R;X?console.log("[HOST/LAN] reachable"):console.log("[HOST/LAN] hostId mismatch — got:",P.hostId,"expected:",R),S(X)}catch(ee){$||(console.log("[HOST/LAN] probe failed:",ee instanceof Error?ee.message:ee),S(!1))}}G();const J=window.setInterval(G,pE),fe=fd.addListener("appStateChange",ee=>{ee.isActive&&G()}),ie=cE.addListener("networkStatusChange",()=>G());return()=>{$=!0,clearInterval(J),fe.then(ee=>ee.remove()),ie.then(ee=>ee.remove())}},[t.hostId,t.lanUrl,H]),j.useEffect(()=>{if(H){c.current&&(c.current.close().catch(()=>{}),c.current=null,s(null),u(!1));return}let $=!1,q=1e3;const R=3e4;async function G(){for(;!$;)try{const J=await fetch(`${Uu}/api/nats-credentials/${t.hostId}`);if($)return;if(J.status===401||J.status===403||J.status===404){console.error("[NATS] Host not found or rejected by relay:",J.status),x(!0);return}if(!J.ok)throw new Error(`credentials fetch ${J.status}`);const fe=await J.json();if(!fe.natsWsUrl){console.error("[NATS] Relay returned empty natsWsUrl — treating as terminal"),x(!0);return}if($)return;console.log("[NATS] Connecting to",fe.natsWsUrl);const ie=await Nx({servers:fe.natsWsUrl,authenticator:wx(fe.natsJwt,new TextEncoder().encode(fe.natsNkeySeed)),pingInterval:3e4,maxPingOut:2});if($){ie.close().catch(()=>{});return}if(console.log("[NATS] Connected"),c.current=ie,s(ie),u(!0),q=1e3,await ie.closed(),$)return;console.log("[NATS] Connection closed, will reconnect"),c.current=null,s(null),u(!1)}catch(J){if($)return;console.warn(`[NATS] Connect failed, retrying in ${q}ms:`,J),u(!1),await new Promise(fe=>setTimeout(fe,q)),q=Math.min(q*2,R)}}return G(),()=>{$=!0,c.current&&(c.current.close().catch(()=>{}),c.current=null,s(null),u(!1))}},[H,t]),j.useEffect(()=>{if(H)return;const $=fd.addListener("appStateChange",q=>{if(!q.isActive||!c.current)return;const R=c.current;Promise.race([R.flush(),new Promise((G,J)=>setTimeout(()=>J(new Error("ping timeout")),2e3))]).catch(()=>{console.log("[NATS] Resume probe failed — cycling conn"),R.close().catch(()=>{})})});return()=>{$.then(q=>q.remove())}},[H]),j.useEffect(()=>{if(!H){d(!1);return}const $=new AbortController;async function q(){var fe;const G=new AbortController,J=setTimeout(()=>G.abort(),dE);$.signal.addEventListener("abort",()=>G.abort());try{const ie=await fetch(`${t.directUrl}/events`,{headers:{Authorization:`Bearer ${t.clientToken}`},signal:G.signal});return clearTimeout(J),ie.ok?((fe=ie.body)==null?void 0:fe.getReader())??null:null}catch{return clearTimeout(J),null}}async function R(G){d(!0),console.log("[HOST] SSE connected to",t.directUrl),D.current=Date.now();function J(){setTimeout(()=>{$.signal.aborted||Date.now()-D.current<jh||(console.log("[HOST] Heartbeat timeout — no data for",jh/1e3,"s"),$.abort(),d(!1),console.log("[HOST] Direct host unreachable"))},jh)}J();const fe=new TextDecoder;let ie="";try{for(;;){const{done:ee,value:P}=await G.read();if(ee)break;ie+=fe.decode(P,{stream:!0}),D.current=Date.now(),J();const X=ie.split(`
|
|
87
|
+
${f.stack}`),c.reject(m)):c.resolve(y))}});return d.requestSubject=t,this.protocol.publish(t,r,{reply:u,headers:s.headers}),c}else{const u=new px(this.protocol.muxSubscriptions,t,s,l);this.protocol.request(u);try{this.publish(t,r,{reply:`${this.protocol.muxSubscriptions.baseInbox}${u.token}`,headers:s.headers})}catch(f){u.cancel(f)}const c=Promise.race([u.timer,u.deferred]);return c.catch(()=>{u.cancel()}),c}}flush(){return this.isClosed()?Promise.reject(Te.errorForCode(Se.ConnectionClosed)):this.protocol.flush()}drain(){return this.isClosed()?Promise.reject(Te.errorForCode(Se.ConnectionClosed)):this.isDraining()?Promise.reject(Te.errorForCode(Se.ConnectionDraining)):(this.draining=!0,this.protocol.drain())}isClosed(){return this.protocol.isClosed()}isDraining(){return this.draining}getServer(){const t=this.protocol.getServer();return t?t.listen:""}status(){const t=new an;return t.iterClosed.then(()=>{const r=this.listeners.indexOf(t);this.listeners.splice(r,1)}),this.listeners.push(t),t}get info(){return this.protocol.isClosed()?void 0:this.protocol.info}async context(){return(await this.request("$SYS.REQ.USER.INFO")).json((r,s)=>r==="time"?new Date(Date.parse(s)):s)}stats(){return{inBytes:this.protocol.inBytes,outBytes:this.protocol.outBytes,inMsgs:this.protocol.inMsgs,outMsgs:this.protocol.outMsgs}}async jetstreamManager(t={}){const r=new Dk(this,t);if(t.checkAPI!==!1)try{await r.getAccountInfo()}catch(s){const l=s;throw l.code===Se.NoResponders&&(l.code=Se.JetStreamNotEnabled),l}return r}jetstream(t={}){return new Bd(this,t)}getServerVersion(){const t=this.info;return t?ms(t.version):void 0}async rtt(){if(!this.protocol._closed&&!this.protocol.connected)throw Te.errorForCode(Se.Disconnect);const t=Date.now();return await this.flush(),Date.now()-t}get features(){return this.protocol.features}get services(){return this._services||(this._services=new Bk(this)),this._services}reconnect(){return this.isClosed()?Promise.reject(Te.errorForCode(Se.ConnectionClosed)):this.isDraining()?Promise.reject(Te.errorForCode(Se.ConnectionDraining)):this.protocol.reconnect()}}class Bk{constructor(t){C(this,"nc");this.nc=t}add(t){try{return new Yl(this.nc,t).start()}catch(r){return Promise.reject(r)}}client(t,r){return new yk(this.nc,t,r)}}class Pk{constructor(t,r,s){C(this,"bucket");C(this,"sm");C(this,"prefixLen");this.bucket=t,this.prefixLen=r,this.sm=s}get key(){return this.sm.subject.substring(this.prefixLen)}get value(){return this.sm.data}get delta(){return 0}get created(){return this.sm.time}get revision(){return this.sm.seq}get operation(){return this.sm.header.get(zu)||"PUT"}get length(){const t=this.sm.header.get(En.MessageSizeHdr)||"";return t!==""?parseInt(t,10):this.sm.data.length}json(){return this.sm.json()}string(){return this.sm.string()}}class Hk{constructor(t,r,s){C(this,"bucket");C(this,"key");C(this,"sm");this.bucket=t,this.key=r,this.sm=s}get value(){return this.sm.data}get created(){return new Date(Md(this.sm.info.timestampNanos))}get revision(){return this.sm.seq}get operation(){var t;return((t=this.sm.headers)==null?void 0:t.get(zu))||"PUT"}get delta(){return this.sm.info.pending}get length(){var r;const t=((r=this.sm.headers)==null?void 0:r.get(En.MessageSizeHdr))||"";return t!==""?parseInt(t,10):this.sm.data.length}json(){return this.sm.json()}string(){return this.sm.string()}}class jx extends y2{constructor(r,s,l){super(r.nc,s,l);C(this,"js");C(this,"monitor");this.js=r,this.monitor=null,this.sub.closed.then(()=>{this.monitor&&this.monitor.cancel()})}set info(r){this.sub.info=r}get info(){return this.sub.info}_resetOrderedConsumer(r){if(this.info===null||this.sub.isClosed())return;const s=ni(this.js.nc.options.inboxPrefix);this.js.nc._resub(this.sub,s);const u=this.info;u.config.name=Pi.next(),u.ordered_consumer_sequence.delivery_seq=0,u.flow_control.heartbeat_count=0,u.flow_control.fc_count=0,u.flow_control.consumer_restarts++,u.deliver=s,u.config.deliver_subject=s,u.config.deliver_policy=Vt.StartSequence,u.config.opt_start_seq=r;const c={};c.stream_name=this.info.stream,c.config=u.config;const f=`${u.api.prefix}.CONSUMER.CREATE.${u.stream}`;this.js._request(f,c,{retries:-1}).then(d=>{const m=d,y=this.sub.info;y.last=m,this.info.config=m.config,this.info.name=m.name}).catch(d=>{const m=new Te(`unable to recreate ordered consumer ${u.stream} at seq ${r}`,Se.RequestError,d);this.sub.callback(m,{})})}_maybeSetupHbMonitoring(){var s,l;const r=((l=(s=this.info)==null?void 0:s.config)==null?void 0:l.idle_heartbeat)||0;r&&this._setupHbMonitoring(Md(r))}_setupHbMonitoring(r,s=0){const l={cancelAfter:0,maxOut:2};s&&(l.cancelAfter=s);const u=this.sub,c=f=>{var y,g,x,w;const d=Q_(409,`${or.IdleHeartbeatMissed}: ${f}`,this.sub.subject);if(!((y=this.info)==null?void 0:y.ordered))this.sub.callback(null,d);else{if(!this.js.nc.protocol.connected)return!1;const S=((x=(g=this.info)==null?void 0:g.ordered_consumer_sequence)==null?void 0:x.stream_seq)||0;return this._resetOrderedConsumer(S+1),(w=this.monitor)==null||w.restart(),!1}return!u.noIterator};this.monitor=new Ld(r,c,l)}_checkHbOrderConsumer(r){const s=r.headers.get(En.ConsumerStalledHdr);s!==""&&this.js.nc.publish(s);const l=parseInt(r.headers.get(En.LastConsumerSeqHdr),10),u=this.info.ordered_consumer_sequence;return this.info.flow_control.heartbeat_count++,l!==u.delivery_seq&&this._resetOrderedConsumer(u.stream_seq+1),!1}_checkOrderedConsumer(r){const s=this.info.ordered_consumer_sequence,l=r.info.streamSequence,u=r.info.deliverySequence;return u!=s.delivery_seq+1?(this._resetOrderedConsumer(s.stream_seq+1),!1):(s.delivery_seq=u,s.stream_seq=l,!0)}async destroy(){this.isClosed()||await this.drain();const r=this.sub.info,s=r.config.durable_name||r.name,l=`${r.api.prefix}.CONSUMER.DELETE.${r.stream}.${s}`;await r.api._request(l)}async consumerInfo(){const r=this.sub.info,s=r.config.durable_name||r.name,l=`${r.api.prefix}.CONSUMER.INFO.${r.stream}.${s}`,u=await r.api._request(l);return r.last=u,u}}class qk extends jx{constructor(t,r,s){super(t,r,s)}pull(t={batch:1}){const{stream:r,config:s,name:l}=this.sub.info,u=s.durable_name??l,c={};if(c.batch=t.batch||1,c.no_wait=t.no_wait||!1,(t.max_bytes??0)>0){const m=this.js.nc.features.get(mt.JS_PULL_MAX_BYTES);if(!m.ok)throw new Error(`max_bytes is only supported on servers ${m.min} or better`);c.max_bytes=t.max_bytes}let f=0;t.expires&&t.expires>0&&(f=t.expires,c.expires=Ut(f));let d=0;if(t.idle_heartbeat&&t.idle_heartbeat>0&&(d=t.idle_heartbeat,c.idle_heartbeat=Ut(d)),d&&f===0)throw new Error("idle_heartbeat requires expires");if(d>f)throw new Error("expires must be greater than idle_heartbeat");if(this.info){this.monitor&&this.monitor.cancel(),f&&d&&(this.monitor?this.monitor._change(d,f):this._setupHbMonitoring(d,f));const m=this.info.api,y=`${m.prefix}.CONSUMER.MSG.NEXT.${r}.${u}`,g=this.sub.subject;m.nc.publish(y,m.jc.encode(c),{reply:g})}}}function Ik(e,t){return e?$k(t):Fk(t)}function Fk(e){return(t,r)=>t?[t,null]:(t=ua(r),t?[t,null]:[null,Pl(r,e)])}function $k(e){return(t,r)=>{if(t)return[t,null];const s=ua(r);return s!==null?[Tx(s),null]:[null,Pl(r,e)]}}function Tx(e){if(e!==null)switch(e.code){case Se.JetStream404NoMessages:case Se.JetStream408RequestTimeout:return null;case Se.JetStream409:return Z_(e)?e:null;default:return e}return null}function Yk(e){e&&e.ack()}function Gk(e){const t=e.split(".");if(t.length===9&&t.splice(2,0,"_",""),t.length<11||t[0]!=="$JS"||t[1]!=="ACK")throw new Error("not js message");const r={};return r.domain=t[2]==="_"?"":t[2],r.account_hash=t[3],r.stream=t[4],r.consumer=t[5],r.deliveryCount=parseInt(t[6],10),r.redeliveryCount=r.deliveryCount,r.redelivered=r.deliveryCount>1,r.streamSequence=parseInt(t[7],10),r.deliverySequence=parseInt(t[8],10),r.timestampNanos=parseInt(t[9],10),r.pending=parseInt(t[10],10),r}class Vk{constructor(t,r){C(this,"msg");C(this,"di");C(this,"didAck");C(this,"timeout");this.msg=t,this.didAck=!1,this.timeout=r}get subject(){return this.msg.subject}get sid(){return this.msg.sid}get data(){return this.msg.data}get headers(){return this.msg.headers}get info(){return this.di||(this.di=Gk(this.reply)),this.di}get redelivered(){return this.info.deliveryCount>1}get reply(){return this.msg.reply||""}get seq(){return this.info.streamSequence}doAck(t){this.didAck||(this.didAck=!this.isWIP(t),this.msg.respond(t))}isWIP(t){return t.length===4&&t[0]===xl[0]&&t[1]===xl[1]&&t[2]===xl[2]&&t[3]===xl[3]}async ackAck(t){var s;t=t||{},t.timeout=t.timeout||this.timeout;const r=Bt();if(this.didAck)r.resolve(!1);else if(this.didAck=!0,this.msg.reply){const u=this.msg.publisher,c=!((s=u.options)!=null&&s.noAsyncTraces),f=new px(u.muxSubscriptions,this.msg.reply,{timeout:t.timeout},c);u.request(f);try{u.publish(this.msg.reply,M0,{reply:`${u.muxSubscriptions.baseInbox}${f.token}`})}catch(d){f.cancel(d)}try{await Promise.race([f.timer,f.deferred]),r.resolve(!0)}catch(d){f.cancel(d),r.reject(d)}}else r.resolve(!1);return r}ack(){this.doAck(M0)}nak(t){let r=Ak;t&&(r=Nu().encode(`-NAK ${JSON.stringify({delay:Ut(t)})}`)),this.doAck(r)}working(){this.doAck(xl)}next(t,r={batch:1}){const s={};s.batch=r.batch||1,s.no_wait=r.no_wait||!1,r.expires&&r.expires>0&&(s.expires=Ut(r.expires));const l=vr().encode(s),u=ga.concat(jk,Nk,l),c=t?{reply:t}:void 0;this.msg.respond(u,c)}term(t=""){let r=Tk;(t==null?void 0:t.length)>0&&(r=Nu().encode(`+TERM ${t}`)),this.doAck(r)}json(){return this.msg.json()}string(){return this.msg.string()}}const Jk="1.30.3",Xk="nats.ws";class Kk{constructor(){C(this,"version");C(this,"lang");C(this,"closeError");C(this,"connected");C(this,"done");C(this,"socket");C(this,"options");C(this,"socketClosed");C(this,"encrypted");C(this,"peeked");C(this,"yields");C(this,"signal");C(this,"closedNotification");this.version=Jk,this.lang=Xk,this.connected=!1,this.done=!1,this.socketClosed=!1,this.encrypted=!1,this.peeked=!1,this.yields=[],this.signal=Bt(),this.closedNotification=Bt()}async connect(t,r){const s=Bt();if(r.tls)return s.reject(new Te("tls",Se.InvalidOption)),s;this.options=r;const l=t.src;if(r.wsFactory){const{socket:u,encrypted:c}=await r.wsFactory(t.src,r);this.socket=u,this.encrypted=c}else this.encrypted=l.indexOf("wss://")===0,this.socket=new WebSocket(l);return this.socket.binaryType="arraybuffer",this.socket.onopen=()=>{this.isDiscarded()},this.socket.onmessage=u=>{if(this.isDiscarded())return;if(this.yields.push(new Uint8Array(u.data)),this.peeked){this.signal.resolve();return}const c=ga.concat(...this.yields),f=_2(c);if(f!==""){const d=uk.exec(f);if(!d){r.debug&&console.error("!!!",cu(c)),s.reject(new Error("unexpected response from server"));return}try{const m=JSON.parse(d[1]);lk(m,this.options),this.peeked=!0,this.connected=!0,this.signal.resolve(),s.resolve()}catch(m){s.reject(m);return}}},this.socket.onclose=u=>{if(this.isDiscarded())return;this.socketClosed=!0;let c;this.done||(u.wasClean||(c=new Error(u.reason)),this._closed(c))},this.socket.onerror=u=>{if(this.isDiscarded())return;const c=u,f=new Te(c.message,Se.Unknown,new Error(c.error));s.reject(f)},s}disconnect(){this._closed(void 0,!0)}async _closed(t,r=!0){if(!this.isDiscarded()&&this.connected&&!this.done){if(this.closeError=t,!t)for(;!this.socketClosed&&this.socket.bufferedAmount>0;)await Sa(100);this.done=!0;try{this.socket.close(t?1002:1e3,t?t.message:void 0)}catch{}r&&this.closedNotification.resolve(t)}}get isClosed(){return this.done}[Symbol.asyncIterator](){return this.iterate()}async*iterate(){for(;;){if(this.isDiscarded())return;this.yields.length===0&&await this.signal;const t=this.yields;this.yields=[];for(let r=0;r<t.length;r++)this.options.debug&&console.info(`> ${cu(t[r])}`),yield t[r];if(this.done)break;this.yields.length===0&&(t.length=0,this.yields=t,this.signal=Bt())}}isEncrypted(){return this.connected&&this.encrypted}send(t){if(!this.isDiscarded())try{this.socket.send(t.buffer),this.options.debug&&console.info(`< ${cu(t)}`);return}catch(r){this.options.debug&&console.error(`!!! ${cu(t)}: ${r}`)}}close(t){return this._closed(t,!1)}closed(){return this.closedNotification}isDiscarded(){return this.done?(this.discard(),!0):!1}discard(){var t;this.done=!0;try{(t=this.socket)==null||t.close()}catch{}}}function Qk(e,t){/^(.*:\/\/)(.*)/.test(e)||(typeof t=="boolean"?e=`${t===!0?"https":"http"}://${e}`:e=`https://${e}`);let s=new URL(e);const l=s.protocol.toLowerCase();l==="ws:"&&(t=!1),l==="wss:"&&(t=!0),l!=="https:"&&l!=="http"&&(e=e.replace(/^(.*:\/\/)(.*)/gm,"$2"),s=new URL(`http://${e}`));let u,c;const f=s.hostname,d=s.pathname,m=s.search||"";switch(l){case"http:":case"ws:":case"nats:":c=s.port||"80",u="ws:";break;case"https:":case"wss:":case"tls:":c=s.port||"443",u="wss:";break;default:c=s.port||t===!0?"443":"80",u=t===!0?"wss:":"ws:";break}return`${u}//${f}:${c}${d}${m}`}function Nx(e={}){return b2({defaultPort:443,urlParseFn:Qk,factory:()=>new Kk}),Pd.connect(e)}/*! Capacitor: https://capacitorjs.com/ - MIT License */var ya;(function(e){e.Unimplemented="UNIMPLEMENTED",e.Unavailable="UNAVAILABLE"})(ya||(ya={}));class Ah extends Error{constructor(t,r,s){super(t),this.message=t,this.code=r,this.data=s}}const Zk=e=>{var t,r;return e!=null&&e.androidBridge?"android":!((r=(t=e==null?void 0:e.webkit)===null||t===void 0?void 0:t.messageHandlers)===null||r===void 0)&&r.bridge?"ios":"web"},Wk=e=>{const t=e.CapacitorCustomPlatform||null,r=e.Capacitor||{},s=r.Plugins=r.Plugins||{},l=()=>t!==null?t.name:Zk(e),u=()=>l()!=="web",c=g=>{const x=m.get(g);return!!(x!=null&&x.platforms.has(l())||f(g))},f=g=>{var x;return(x=r.PluginHeaders)===null||x===void 0?void 0:x.find(w=>w.name===g)},d=g=>e.console.error(g),m=new Map,y=(g,x={})=>{const w=m.get(g);if(w)return console.warn(`Capacitor plugin "${g}" already registered. Cannot register plugins twice.`),w.proxy;const S=l(),T=f(g);let z;const D=async()=>(!z&&S in x?z=typeof x[S]=="function"?z=await x[S]():z=x[S]:t!==null&&!z&&"web"in x&&(z=typeof x.web=="function"?z=await x.web():z=x.web),z),H=($,q)=>{var R,G;if(T){const J=T==null?void 0:T.methods.find(fe=>q===fe.name);if(J)return J.rtype==="promise"?fe=>r.nativePromise(g,q.toString(),fe):(fe,ie)=>r.nativeCallback(g,q.toString(),fe,ie);if($)return(R=$[q])===null||R===void 0?void 0:R.bind($)}else{if($)return(G=$[q])===null||G===void 0?void 0:G.bind($);throw new Ah(`"${g}" plugin is not implemented on ${S}`,ya.Unimplemented)}},F=$=>{let q;const R=(...G)=>{const J=D().then(fe=>{const ie=H(fe,$);if(ie){const ee=ie(...G);return q=ee==null?void 0:ee.remove,ee}else throw new Ah(`"${g}.${$}()" is not implemented on ${S}`,ya.Unimplemented)});return $==="addListener"&&(J.remove=async()=>q()),J};return R.toString=()=>`${$.toString()}() { [capacitor code] }`,Object.defineProperty(R,"name",{value:$,writable:!1,configurable:!1}),R},oe=F("addListener"),B=F("removeListener"),L=($,q)=>{const R=oe({eventName:$},q),G=async()=>{const fe=await R;B({eventName:$,callbackId:fe},q)},J=new Promise(fe=>R.then(()=>fe({remove:G})));return J.remove=async()=>{console.warn("Using addListener() without 'await' is deprecated."),await G()},J},W=new Proxy({},{get($,q){switch(q){case"$$typeof":return;case"toJSON":return()=>({});case"addListener":return T?L:oe;case"removeListener":return B;default:return F(q)}}});return s[g]=W,m.set(g,{name:g,proxy:W,platforms:new Set([...Object.keys(x),...T?[S]:[]])}),W};return r.convertFileSrc||(r.convertFileSrc=g=>g),r.getPlatform=l,r.handleError=d,r.isNativePlatform=u,r.isPluginAvailable=c,r.registerPlugin=y,r.Exception=Ah,r.DEBUG=!!r.DEBUG,r.isLoggingEnabled=!!r.isLoggingEnabled,r},eE=e=>e.Capacitor=Wk(e),Xn=eE(typeof globalThis<"u"?globalThis:typeof self<"u"?self:typeof window<"u"?window:typeof global<"u"?global:{}),ys=Xn.registerPlugin;class Hd{constructor(){this.listeners={},this.retainedEventArguments={},this.windowListeners={}}addListener(t,r){let s=!1;this.listeners[t]||(this.listeners[t]=[],s=!0),this.listeners[t].push(r);const u=this.windowListeners[t];u&&!u.registered&&this.addWindowListener(u),s&&this.sendRetainedArgumentsForEvent(t);const c=async()=>this.removeListener(t,r);return Promise.resolve({remove:c})}async removeAllListeners(){this.listeners={};for(const t in this.windowListeners)this.removeWindowListener(this.windowListeners[t]);this.windowListeners={}}notifyListeners(t,r,s){const l=this.listeners[t];if(!l){if(s){let u=this.retainedEventArguments[t];u||(u=[]),u.push(r),this.retainedEventArguments[t]=u}return}l.forEach(u=>u(r))}hasListeners(t){var r;return!!(!((r=this.listeners[t])===null||r===void 0)&&r.length)}registerWindowListener(t,r){this.windowListeners[r]={registered:!1,windowEventName:t,pluginEventName:r,handler:s=>{this.notifyListeners(r,s)}}}unimplemented(t="not implemented"){return new Xn.Exception(t,ya.Unimplemented)}unavailable(t="not available"){return new Xn.Exception(t,ya.Unavailable)}async removeListener(t,r){const s=this.listeners[t];if(!s)return;const l=s.indexOf(r);this.listeners[t].splice(l,1),this.listeners[t].length||this.removeWindowListener(this.windowListeners[t])}addWindowListener(t){window.addEventListener(t.windowEventName,t.handler),t.registered=!0}removeWindowListener(t){t&&(window.removeEventListener(t.windowEventName,t.handler),t.registered=!1)}sendRetainedArgumentsForEvent(t){const r=this.retainedEventArguments[t];r&&(delete this.retainedEventArguments[t],r.forEach(s=>{this.notifyListeners(t,s)}))}}const L0=e=>encodeURIComponent(e).replace(/%(2[346B]|5E|60|7C)/g,decodeURIComponent).replace(/[()]/g,escape),z0=e=>e.replace(/(%[\dA-F]{2})+/gi,decodeURIComponent);class tE extends Hd{async getCookies(){const t=document.cookie,r={};return t.split(";").forEach(s=>{if(s.length<=0)return;let[l,u]=s.replace(/=/,"CAP_COOKIE").split("CAP_COOKIE");l=z0(l).trim(),u=z0(u).trim(),r[l]=u}),r}async setCookie(t){try{const r=L0(t.key),s=L0(t.value),l=t.expires?`; expires=${t.expires.replace("expires=","")}`:"",u=(t.path||"/").replace("path=",""),c=t.url!=null&&t.url.length>0?`domain=${t.url}`:"";document.cookie=`${r}=${s||""}${l}; path=${u}; ${c};`}catch(r){return Promise.reject(r)}}async deleteCookie(t){try{document.cookie=`${t.key}=; Max-Age=0`}catch(r){return Promise.reject(r)}}async clearCookies(){try{const t=document.cookie.split(";")||[];for(const r of t)document.cookie=r.replace(/^ +/,"").replace(/=.*/,`=;expires=${new Date().toUTCString()};path=/`)}catch(t){return Promise.reject(t)}}async clearAllCookies(){try{await this.clearCookies()}catch(t){return Promise.reject(t)}}}ys("CapacitorCookies",{web:()=>new tE});const nE=async e=>new Promise((t,r)=>{const s=new FileReader;s.onload=()=>{const l=s.result;t(l.indexOf(",")>=0?l.split(",")[1]:l)},s.onerror=l=>r(l),s.readAsDataURL(e)}),rE=(e={})=>{const t=Object.keys(e);return Object.keys(e).map(l=>l.toLocaleLowerCase()).reduce((l,u,c)=>(l[u]=e[t[c]],l),{})},iE=(e,t=!0)=>e?Object.entries(e).reduce((s,l)=>{const[u,c]=l;let f,d;return Array.isArray(c)?(d="",c.forEach(m=>{f=t?encodeURIComponent(m):m,d+=`${u}=${f}&`}),d.slice(0,-1)):(f=t?encodeURIComponent(c):c,d=`${u}=${f}`),`${s}&${d}`},"").substr(1):null,sE=(e,t={})=>{const r=Object.assign({method:e.method||"GET",headers:e.headers},t),l=rE(e.headers)["content-type"]||"";if(typeof e.data=="string")r.body=e.data;else if(l.includes("application/x-www-form-urlencoded")){const u=new URLSearchParams;for(const[c,f]of Object.entries(e.data||{}))u.set(c,f);r.body=u.toString()}else if(l.includes("multipart/form-data")||e.data instanceof FormData){const u=new FormData;if(e.data instanceof FormData)e.data.forEach((f,d)=>{u.append(d,f)});else for(const f of Object.keys(e.data))u.append(f,e.data[f]);r.body=u;const c=new Headers(r.headers);c.delete("content-type"),r.headers=c}else(l.includes("application/json")||typeof e.data=="object")&&(r.body=JSON.stringify(e.data));return r};class aE extends Hd{async request(t){const r=sE(t,t.webFetchExtra),s=iE(t.params,t.shouldEncodeUrlParams),l=s?`${t.url}?${s}`:t.url,u=await fetch(l,r),c=u.headers.get("content-type")||"";let{responseType:f="text"}=u.ok?t:{};c.includes("application/json")&&(f="json");let d,m;switch(f){case"arraybuffer":case"blob":m=await u.blob(),d=await nE(m);break;case"json":d=await u.json();break;case"document":case"text":default:d=await u.text()}const y={};return u.headers.forEach((g,x)=>{y[x]=g}),{data:d,headers:y,status:u.status,url:u.url}}async get(t){return this.request(Object.assign(Object.assign({},t),{method:"GET"}))}async post(t){return this.request(Object.assign(Object.assign({},t),{method:"POST"}))}async put(t){return this.request(Object.assign(Object.assign({},t),{method:"PUT"}))}async patch(t){return this.request(Object.assign(Object.assign({},t),{method:"PATCH"}))}async delete(t){return this.request(Object.assign(Object.assign({},t),{method:"DELETE"}))}}ys("CapacitorHttp",{web:()=>new aE});var U0;(function(e){e.Dark="DARK",e.Light="LIGHT",e.Default="DEFAULT"})(U0||(U0={}));var B0;(function(e){e.StatusBar="StatusBar",e.NavigationBar="NavigationBar"})(B0||(B0={}));class lE extends Hd{async setStyle(){this.unavailable("not available for web")}async setAnimation(){this.unavailable("not available for web")}async show(){this.unavailable("not available for web")}async hide(){this.unavailable("not available for web")}}ys("SystemBars",{web:()=>new lE});const oE="modulepreload",uE=function(e){return"/"+e},P0={},qd=function(t,r,s){let l=Promise.resolve();if(r&&r.length>0){let c=function(m){return Promise.all(m.map(y=>Promise.resolve(y).then(g=>({status:"fulfilled",value:g}),g=>({status:"rejected",reason:g}))))};document.getElementsByTagName("link");const f=document.querySelector("meta[property=csp-nonce]"),d=(f==null?void 0:f.nonce)||(f==null?void 0:f.getAttribute("nonce"));l=c(r.map(m=>{if(m=uE(m),m in P0)return;P0[m]=!0;const y=m.endsWith(".css"),g=y?'[rel="stylesheet"]':"";if(document.querySelector(`link[href="${m}"]${g}`))return;const x=document.createElement("link");if(x.rel=y?"stylesheet":oE,y||(x.as="script"),x.crossOrigin="",x.href=m,d&&x.setAttribute("nonce",d),document.head.appendChild(x),y)return new Promise((w,S)=>{x.addEventListener("load",w),x.addEventListener("error",()=>S(new Error(`Unable to preload CSS for ${m}`)))})}))}function u(c){const f=new Event("vite:preloadError",{cancelable:!0});if(f.payload=c,window.dispatchEvent(f),!f.defaultPrevented)throw c}return l.then(c=>{for(const f of c||[])f.status==="rejected"&&u(f.reason);return t().catch(u)})},fd=ys("App",{web:()=>qd(()=>import("./web-DSL9bja4.js"),[]).then(e=>new e.AppWeb)}),cE=ys("Network",{web:()=>qd(()=>import("./web-CYs_8c0k.js"),[]).then(e=>new e.NetworkWeb)}),Uu=Xn.isNativePlatform()?"https://app.palmier.me":"";async function Ox(e,t,r,s){const l=`${Uu}${t}`;console.log(`[API] ${e} ${l}`);const c=await fetch(l,{method:e,headers:{"Content-Type":"application/json"},body:r!=null?JSON.stringify(r):void 0});if(!c.ok){const f=await c.text();let d;try{const m=JSON.parse(f);d=m.error??m.message??f}catch{d=f}throw console.error(`[API] ${e} ${t} failed:`,c.status,d),new Error(d||`Request failed with status ${c.status}`)}return console.log(`[API] ${e} ${t} ->`,c.status),c.json()}function fE(e,t,r){return Ox("POST",e,t)}function hE(e,t){return Ox("GET",e,void 0)}const H0=Xn.isNativePlatform(),Rx=j.createContext(null),dE=2e3,jh=6e3,mE=1500,pE=6e4;function gE({children:e,activeHost:t}){const[r,s]=j.useState(null),[l,u]=j.useState(!1),c=j.useRef(null),[f,d]=j.useState(!1),[m,y]=j.useState(!1),[g,x]=j.useState(!1),[w,S]=j.useState(!1),T=j.useRef(Nu()),z=j.useRef(new Set),D=j.useRef(0),H=!!t.directUrl,F=H0&&!H&&!!t.lanUrl&&w,oe=m||g?"disconnected":H?f?"direct":"connecting":l?F?"lan":"nats":"connecting",B=oe!=="connecting"&&oe!=="disconnected";j.useEffect(()=>{y(!1),x(!1)},[t.hostId,t.clientToken]),j.useEffect(()=>{if(!H0||H||!t.lanUrl){S(!1);return}let $=!1;const q=t.lanUrl,R=t.hostId;async function G(){console.log("[HOST/LAN] probing",q);try{const ee=await fetch(`${q}/health`,{signal:AbortSignal.timeout(mE)});if($)return;if(!ee.ok){console.log("[HOST/LAN] probe got non-ok:",ee.status),S(!1);return}const P=await ee.json(),X=P.hostId===R;X?console.log("[HOST/LAN] reachable"):console.log("[HOST/LAN] hostId mismatch — got:",P.hostId,"expected:",R),S(X)}catch(ee){$||(console.log("[HOST/LAN] probe failed:",ee instanceof Error?ee.message:ee),S(!1))}}G();const J=window.setInterval(G,pE),fe=fd.addListener("appStateChange",ee=>{ee.isActive&&G()}),ie=cE.addListener("networkStatusChange",()=>G());return()=>{$=!0,clearInterval(J),fe.then(ee=>ee.remove()),ie.then(ee=>ee.remove())}},[t.hostId,t.lanUrl,H]),j.useEffect(()=>{if(H){c.current&&(c.current.close().catch(()=>{}),c.current=null,s(null),u(!1));return}let $=!1,q=1e3;const R=3e4;async function G(){for(;!$;)try{const J=await fetch(`${Uu}/api/nats-credentials/${t.hostId}`);if($)return;if(J.status===401||J.status===403||J.status===404){console.error("[NATS] Host not found or rejected by relay:",J.status),x(!0);return}if(!J.ok)throw new Error(`credentials fetch ${J.status}`);const fe=await J.json();if(!fe.natsWsUrl){console.error("[NATS] Relay returned empty natsWsUrl — treating as terminal"),x(!0);return}if($)return;console.log("[NATS] Connecting to",fe.natsWsUrl);const ie=await Nx({servers:fe.natsWsUrl,authenticator:wx(fe.natsJwt,new TextEncoder().encode(fe.natsNkeySeed)),pingInterval:3e4,maxPingOut:2});if($){ie.close().catch(()=>{});return}if(console.log("[NATS] Connected"),c.current=ie,s(ie),u(!0),q=1e3,await ie.closed(),$)return;console.log("[NATS] Connection closed, will reconnect"),c.current=null,s(null),u(!1)}catch(J){if($)return;console.warn(`[NATS] Connect failed, retrying in ${q}ms:`,J),u(!1),await new Promise(fe=>setTimeout(fe,q)),q=Math.min(q*2,R)}}return G(),()=>{$=!0,c.current&&(c.current.close().catch(()=>{}),c.current=null,s(null),u(!1))}},[H,t]),j.useEffect(()=>{if(H)return;const $=fd.addListener("appStateChange",q=>{if(!q.isActive||!c.current)return;const R=c.current;Promise.race([R.flush(),new Promise((G,J)=>setTimeout(()=>J(new Error("ping timeout")),2e3))]).catch(()=>{console.log("[NATS] Resume probe failed — cycling conn"),R.close().catch(()=>{})})});return()=>{$.then(q=>q.remove())}},[H]),j.useEffect(()=>{if(!H){d(!1);return}const $=new AbortController;async function q(){var fe;const G=new AbortController,J=setTimeout(()=>G.abort(),dE);$.signal.addEventListener("abort",()=>G.abort());try{const ie=await fetch(`${t.directUrl}/events`,{headers:{Authorization:`Bearer ${t.clientToken}`},signal:G.signal});return clearTimeout(J),ie.ok?((fe=ie.body)==null?void 0:fe.getReader())??null:null}catch{return clearTimeout(J),null}}async function R(G){d(!0),console.log("[HOST] SSE connected to",t.directUrl),D.current=Date.now();function J(){setTimeout(()=>{$.signal.aborted||Date.now()-D.current<jh||(console.log("[HOST] Heartbeat timeout — no data for",jh/1e3,"s"),$.abort(),d(!1),console.log("[HOST] Direct host unreachable"))},jh)}J();const fe=new TextDecoder;let ie="";try{for(;;){const{done:ee,value:P}=await G.read();if(ee)break;ie+=fe.decode(P,{stream:!0}),D.current=Date.now(),J();const X=ie.split(`
|
|
88
88
|
`);ie=X.pop()??"";for(const ae of X)if(ae.startsWith("data: ")){const pe=ae.slice(6);try{const M=JSON.parse(pe);if(M.task_id&&M.event_type){const E=`host-event.${t.hostId}.${M.task_id}`;for(const K of z.current)K({subject:E,data:T.current.encode(pe)})}}catch{}}}}catch{}}return(async()=>{const G=await q();G&&await R(G)})(),()=>{$.abort(),d(!1)}},[t,H]);const L=j.useCallback(async($,q,R)=>{function G(ie){ie&&typeof ie=="object"&&ie.error==="Unauthorized"&&y(!0)}async function J(ie,ee){console.log(`[HOST/${ee}] → ${$}`,q??"");const P=await fetch(`${ie}/rpc/${$}`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t.clientToken}`},body:q!=null?JSON.stringify(q):void 0,signal:R!=null&&R.timeout?AbortSignal.timeout(R.timeout):void 0});if(P.status===401)throw y(!0),new Error("Unauthorized");const X=await P.json();return G(X),console.log(`[HOST/${ee}] ← ${$}`,X),X}async function fe(){if(!c.current)throw new Error("Not connected");const ie=`host.${t.hostId}.rpc.${$}`,ee={...q??{},clientToken:t.clientToken},P=T.current.encode(JSON.stringify(ee));console.log(`[HOST/NATS] → ${$}`,q??"");const X=await c.current.request(ie,P,{timeout:(R==null?void 0:R.timeout)??1e4}),ae=JSON.parse(T.current.decode(X.data));return G(ae),console.log(`[HOST/NATS] ← ${$}`,ae),ae}if(H)return J(t.directUrl,"HTTP");if(F&&t.lanUrl)try{return await J(t.lanUrl,"LAN")}catch(ie){if(ie instanceof Error&&ie.message==="Unauthorized")throw ie;console.log("[HOST/LAN] failed, falling back to NATS:",ie),S(!1)}return fe()},[t,H,F]),W=j.useCallback(($,q)=>{if(H)return z.current.add(q),()=>{z.current.delete(q)};if(c.current){const R=c.current.subscribe(`host-event.${$}.>`);let G=!1;return(async()=>{try{for await(const J of R){if(G)break;q({subject:J.subject,data:J.data})}}catch{}})(),()=>{G=!0,R.unsubscribe()}}return()=>{}},[t,H]);return b.jsx(Rx.Provider,{value:{connected:B,mode:oe,nc:r,request:L,subscribeEvents:W,activeHost:t,unauthorized:m},children:e})}function si(){const e=j.useContext(Rx);if(!e)throw new Error("useHostConnection must be used within HostConnectionProvider");return e}const mn=Xn.isNativePlatform()?ys("Device"):null;function yE(e,t){const r=new Date(e),s=new Date,l=r.toLocaleTimeString(void 0,{hour:"numeric",minute:"2-digit",timeZone:t}),u={year:"numeric",month:"2-digit",day:"2-digit",timeZone:t};return r.toLocaleDateString(void 0,u)===s.toLocaleDateString(void 0,u)?l:`${r.toLocaleDateString(void 0,{month:"short",day:"numeric",timeZone:t})} ${l}`}function Id(){const{activeHost:e}=si(),t=e.timezone;return j.useCallback(r=>yE(r,t),[t])}function bE(e){const t=new Intl.DateTimeFormat("en-CA",{timeZone:e,year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",hour12:!1}).formatToParts(new Date),r=s=>{var l;return((l=t.find(u=>u.type===s))==null?void 0:l.value)??""};return{date:`${r("year")}-${r("month")}-${r("day")}`,time:`${r("hour")}:${r("minute")}`}}const Mx={};function xE(e){for(const t of e)Mx[t.key]=t.label}function hd(e){return Mx[e]??e}const vE=()=>window.matchMedia("(max-width: 600px)").matches;function wE({task:e,lastEvent:t,onEdit:r,onDelete:s,onViewRun:l}){var P;const{request:u,activeHost:c}=si(),f=Id(),d=c.timezone,[m,y]=j.useState(!1),[g,x]=j.useState(!1),[w,S]=j.useState(!1),T=j.useRef(null),z=(t==null?void 0:t.running_state)==="started",D=(((P=e.schedule_values)==null?void 0:P.length)??0)>0,H=e.schedule_type==="on_new_notification"||e.schedule_type==="on_new_sms",oe=!!e.schedule_enabled&&!!e.schedule_type&&(D||H)?z?"var(--color-success)":(t==null?void 0:t.running_state)==="failed"?"var(--color-error)":"var(--color-success)":"var(--color-text-secondary)";j.useEffect(()=>{if(!g)return;function X(ae){T.current&&!T.current.contains(ae.target)&&x(!1)}return document.addEventListener("mousedown",X),()=>document.removeEventListener("mousedown",X)},[g]);function B(){vE()?S(!0):x(X=>!X)}function L(){x(!1),S(!1)}async function W(){if(L(),!!confirm("Abort this task?")){y(!0);try{await u("task.abort",{id:e.id})}catch(X){console.error("Abort failed:",X)}finally{y(!1)}}}async function $(){L();try{const X=await u("task.run",{id:e.id});l(e.id,X.run_id)}catch(X){console.error("Run failed:",X)}}async function q(){if(L(),!!confirm("Delete this task? Results and reports will be kept."))try{await u("task.delete",{id:e.id}),s(e.id)}catch(X){console.error("Delete failed:",X)}}const R={started:"Started",finished:"Finished",aborted:"Aborted",failed:"Failed"};function G(X,ae){if(X==="specific_times"){const Ge=new Date(ae);return{kind:"specific_times",detail:isNaN(Ge.getTime())?ae:`${Ge.toLocaleDateString(void 0,{month:"short",day:"numeric",year:"numeric",timeZone:d})} at ${Ge.toLocaleTimeString(void 0,{hour:"numeric",minute:"2-digit",timeZone:d})}`}}const pe=ae.split(" ");if(pe.length!==5)return{kind:"unknown",detail:ae};const[M,E,K,,A]=pe,be=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"];if(E==="*")return{kind:"hourly",detail:""};const je=Number(E),_e=Number(M),Me=je===0?12:je>12?je-12:je,Ie=je>=12?"PM":"AM",ke=`${Me}:${String(_e).padStart(2,"0")} ${Ie}`;return A!=="*"?{kind:"weekly",detail:`${be[Number(A)]??A} at ${ke}`}:K!=="*"?{kind:"monthly",detail:`day ${K} at ${ke}`}:{kind:"daily",detail:ke}}function J(X,ae){const pe=G(X,ae);return pe.kind==="hourly"?"Every hour":pe.kind==="specific_times"?`Once on ${pe.detail}`:`${pe.kind.charAt(0).toUpperCase()+pe.kind.slice(1)}: ${pe.detail}`}function fe(X,ae){if(!X)return"";if(X==="on_new_notification")return"On new notification";if(X==="on_new_sms")return"On new SMS";if(!ae||ae.length===0)return"";if(ae.length===1)return J(X,ae[0]);const pe=ae.map(E=>G(X,E));if(new Set(pe.map(E=>E.kind)).size===1){const E=pe[0].kind;if(E==="hourly")return"Every hour";const K=pe.map(A=>A.detail);return`${E.charAt(0).toUpperCase()+E.slice(1)}: ${K.join(", ")}`}return ae.map(E=>J(X,E)).join(", ")}const ie=fe(e.schedule_type,e.schedule_values),ee=b.jsxs(b.Fragment,{children:[b.jsxs("button",{onClick:()=>{L(),r(e)},children:[b.jsx("span",{className:"menu-icon",children:"✎"}),"Edit"]}),b.jsxs("button",{onClick:()=>{L(),l(e.id)},children:[b.jsx("span",{className:"menu-icon",children:"📄"}),"View All Runs"]}),z?b.jsxs("button",{className:"menu-item-danger",onClick:W,disabled:m,children:[b.jsx("span",{className:"menu-icon",children:"◼"}),"Abort"]}):b.jsxs(b.Fragment,{children:[b.jsxs("button",{onClick:$,children:[b.jsx("span",{className:"menu-icon",children:"▶"}),"Run Now"]}),b.jsxs("button",{className:"menu-item-danger",onClick:q,children:[b.jsx("span",{className:"menu-icon",children:"🗑"}),"Delete"]})]})]});return b.jsxs(b.Fragment,{children:[b.jsxs("div",{className:"task-card",onClick:()=>l(e.id,"latest"),children:[b.jsxs("div",{className:"task-card-header",children:[b.jsxs("div",{className:"task-card-title-row",children:[z?b.jsx("span",{className:"status-spinner",children:b.jsx("span",{})}):b.jsx("span",{className:"status-dot",style:{backgroundColor:oe}}),b.jsx("h3",{className:"task-card-name",children:e.name||e.user_prompt})]}),b.jsx("div",{className:"task-card-actions",onClick:X=>X.stopPropagation(),children:b.jsxs("div",{className:"task-card-menu",ref:T,children:[b.jsx("button",{className:"task-card-menu-btn",onClick:B,"aria-label":"Task actions",children:"⋮"}),g&&b.jsx("div",{className:"task-card-menu-dropdown",children:ee})]})})]}),b.jsxs("div",{className:"task-card-meta",children:[e.agent&&b.jsx("span",{className:"task-card-agent",children:hd(e.agent)}),t&&R[t.running_state]&&b.jsxs("span",{className:"task-card-last-event",children:[R[t.running_state]," ",f(t.time_stamp)]}),e.schedule_type&&(D||H)&&b.jsx("span",{className:"task-card-triggers",children:e.schedule_enabled?ie:"Schedule disabled"})]})]}),w&&ds.createPortal(b.jsx("div",{className:"bottom-sheet-overlay",onClick:()=>S(!1),children:b.jsxs("div",{className:"bottom-sheet",onClick:X=>X.stopPropagation(),children:[b.jsx("div",{className:"bottom-sheet-handle"}),b.jsx("div",{className:"bottom-sheet-title",children:e.name||e.user_prompt}),b.jsx("div",{className:"bottom-sheet-actions",children:ee})]})}),document.body)]})}function SE({permissions:e}){return b.jsxs("div",{className:"permissions-dialog",children:[b.jsx("h2",{children:"Granted Permissions"}),b.jsx("div",{className:"permissions-dialog-scroll",children:e&&e.length>0?b.jsx("div",{className:"permissions-section",children:b.jsx("ul",{className:"permissions-list",children:e.map((t,r)=>b.jsxs("li",{className:"permission-item",children:[b.jsx("span",{className:"permission-tool",children:t.name}),b.jsx("span",{className:"permission-desc",children:t.description})]},r))})}):b.jsx("p",{className:"permissions-empty",children:"No permissions have been granted for this task."})}),b.jsx("div",{className:"permissions-dialog-actions",children:b.jsx("button",{className:"btn btn-secondary",onClick:()=>history.back(),children:"Back"})})]})}const ra=[];function _E(){const e=ra.pop();e&&(e.pushed.current=!1,e.close())}let q0=!1;function kE(){q0||(q0=!0,window.addEventListener("popstate",_E))}function dd(e,t){const r=j.useRef(!1),s=j.useRef(t);s.current=t;const l=j.useCallback(()=>s.current(),[]),u=j.useRef({close:l,pushed:r});u.current.close=l,j.useEffect(()=>{if(e&&!r.current)kE(),history.pushState({modal:!0},""),ra.push(u.current),r.current=!0;else if(!e&&r.current){r.current=!1;const c=ra.indexOf(u.current);c!==-1&&ra.splice(c,1),history.back()}},[e,l]),j.useEffect(()=>{const c=u.current;return()=>{if(r.current){r.current=!1;const f=ra.indexOf(c);f!==-1&&ra.splice(f,1),history.back()}}},[])}const EE=["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],CE=["specific_times","hourly","daily","weekly","monthly"];function mu(e){return CE.includes(e)}function AE(e){return e==="on_new_notification"||e==="on_new_sms"}function ti(e="daily"){return{schedule:e,time:"00:00",dayOfWeek:"1",dayOfMonth:"1",onceDate:"",onceTime:"00:00"}}function jE(e){const t=e.split(" ");if(t.length!==5)return ti();const[r,s,l,,u]=t;if(s==="*")return ti("hourly");const c=`${s.padStart(2,"0")}:${r.padStart(2,"0")}`;return u!=="*"?{...ti("weekly"),time:c,dayOfWeek:u}:l!=="*"?{...ti("monthly"),time:c,dayOfMonth:l}:{...ti("daily"),time:c}}function Dx(e,t){if(e==="specific_times"){const[r,s]=t.split("T");return{...ti("specific_times"),onceDate:r??"",onceTime:(s??"09:00").slice(0,5)}}return jE(t)}function TE(e){const[t,r]=e.time.split(":").map(Number);switch(e.schedule){case"hourly":return"0 * * * *";case"daily":return`${r} ${t} * * *`;case"weekly":return`${r} ${t} * * ${e.dayOfWeek}`;case"monthly":return`${r} ${t} ${e.dayOfMonth} * *`;default:return"0 * * * *"}}function NE(e){return e.schedule==="specific_times"?e.onceDate?`${e.onceDate}T${e.onceTime}`:null:TE(e)}function Th(e){return e==="specific_times"?"specific_times":e==="on_new_notification"?"on_new_notification":e==="on_new_sms"?"on_new_sms":"crons"}function Nh(e){var s;if(!e)return"daily";if(e.command)return"command";const t=e.schedule_type;if(t==="on_new_notification"||t==="on_new_sms")return t;if(t!=="crons"&&t!=="specific_times")return"ondemand";const r=(s=e.schedule_values)==null?void 0:s[0];return r?Dx(t,r).schedule:"ondemand"}function OE({initial:e,agents:t,hostPlatform:r,isNotificationListener:s,onSaved:l,onRun:u,onCancel:c}){var dt;const{request:f,activeHost:d}=si(),{setHostLastAgent:m}=qi(),y=()=>{var Re;const xe=d.lastAgent,qe=t.map(At=>At.key);return xe&&qe.includes(xe)?xe:((Re=t[0])==null?void 0:Re.key)??""},[g,x]=j.useState((e==null?void 0:e.user_prompt)??""),[w,S]=j.useState((e==null?void 0:e.agent)??y()),T=!!((dt=e==null?void 0:e.permissions)!=null&&dt.length),[z,D]=j.useState(!1),H=j.useCallback(()=>D(!1),[]);dd(z,H);const[F,oe]=j.useState(null),[B,L]=j.useState(()=>Nh(e)),[W,$]=j.useState(()=>{const xe=e==null?void 0:e.schedule_type,qe=e==null?void 0:e.schedule_values;if(qe&&(xe==="crons"||xe==="specific_times"))return qe.map(At=>Dx(xe,At));const Re=Nh(e);return mu(Re)?[ti(Re)]:[]}),[q,R]=j.useState((e==null?void 0:e.requires_confirmation)??!1),[G,J]=j.useState(e!=null&&e.schedule_type?e.schedule_enabled??!0:!0),[fe,ie]=j.useState((e==null?void 0:e.yolo_mode)??!1),[ee,P]=j.useState((e==null?void 0:e.foreground_mode)??!1),[X,ae]=j.useState((e==null?void 0:e.command)??""),[pe,M]=j.useState(!1),E=(e==null?void 0:e.schedule_type)==="on_new_notification"&&e.schedule_values&&e.schedule_values.length>0?e.schedule_values[0]:"",[K,A]=j.useState(E),[be,je]=j.useState([]),[_e,Me]=j.useState(!1),[Ie,ke]=j.useState(!1),[Ge,Ft]=j.useState(""),ze=j.useCallback(()=>ke(!1),[]);dd(Ie,ze),j.useEffect(()=>{if(B!=="on_new_notification"||!s||!Xn.isNativePlatform()||!mn)return;let xe=!1;return Me(!0),mn.getInstalledApps().then(({apps:qe})=>{if(xe)return;const Re="com.palmier.app",At=qe.filter(Lt=>Lt.packageName!==Re).sort((Lt,xn)=>(Lt.appName||Lt.packageName).localeCompare(xn.appName||xn.packageName));je(At)}).catch(()=>{}).finally(()=>{xe||Me(!1)}),()=>{xe=!0}},[B,s]);const Ae=(e==null?void 0:e.schedule_type)==="on_new_sms"&&e.schedule_values&&e.schedule_values.length>0?e.schedule_values[0]:"",[Le,nt]=j.useState(Ae),Ve=j.useRef(null),Je=mu(B),We=B==="command",Fe=AE(B),et=t.find(xe=>xe.key===w),ft=!!(et!=null&&et.supportsYolo);j.useEffect(()=>{!ft&&fe&&ie(!1)},[ft,fe]);const ht=!!e,Wt=Nh(e),$e=!ht||g!==((e==null?void 0:e.user_prompt)??"")||w!==((e==null?void 0:e.agent)??"")||B!==Wt||q!==((e==null?void 0:e.requires_confirmation)??!1)||G!==(e!=null&&e.schedule_type?e.schedule_enabled??!0:!0)||fe!==((e==null?void 0:e.yolo_mode)??!1)||ee!==((e==null?void 0:e.foreground_mode)??!1)||We&&X!==((e==null?void 0:e.command)??"")||Je&&(JSON.stringify(bn())!==JSON.stringify((e==null?void 0:e.schedule_values)??[])||Th(B)!==((e==null?void 0:e.schedule_type)??void 0))||Fe&&B!==(e==null?void 0:e.schedule_type)||B==="on_new_notification"&&K.trim()!==E.trim()||B==="on_new_sms"&&Le.trim()!==Ae.trim(),yn=bE(d.timezone),ce=Je&&W.some(xe=>xe.schedule==="specific_times"&&(!xe.onceDate||xe.onceDate<yn.date||xe.onceDate===yn.date&&(xe.onceTime??"")<=yn.time)),we=$e&&!!g.trim()&&!ce&&(!We||!!X.trim())&&(!Je||W.length>0);function Ue(xe,qe){$(Re=>Re.map((At,Lt)=>Lt===xe?{...At,...qe}:At))}function Ke(xe){$(qe=>qe.filter((Re,At)=>At!==xe))}function ut(){mu(B)&&$(xe=>[...xe,xe.length>0?{...xe[xe.length-1]}:ti(B)])}function ln(xe){L(xe),mu(xe)?$([ti(xe)]):($([]),R(!1)),xe==="command"?setTimeout(()=>{var qe;return(qe=Ve.current)==null?void 0:qe.focus()},0):ae(""),xe!=="on_new_notification"&&A(E),xe!=="on_new_sms"&&nt(Ae)}function bn(){return W.flatMap(xe=>{const qe=NE(xe);return qe?[qe]:[]})}function en(){return fe?confirm(`Yolo mode is enabled. The agent will auto-approve all tool calls — it can read, write, delete files, run arbitrary commands, and access the network without asking for permission.
|
|
89
89
|
|
|
90
90
|
Are you sure you want to continue?`):!0}async function xt(){M(!0),oe(null);try{const xe=Je?bn():B==="on_new_notification"&&K.trim()?[K.trim()]:B==="on_new_sms"&&Le.trim()?[Le.trim()]:[],qe=Je||Fe?Th(B):null,Re={user_prompt:g,agent:w,schedule_type:qe,schedule_values:xe.length>0?xe:null,schedule_enabled:B==="ondemand"?!0:G,requires_confirmation:Je?q:!1,yolo_mode:fe,foreground_mode:ee,command:We?X:""};ht&&(Re.id=e.id);const Lt=await f(ht?"task.update":"task.create",Re,{timeout:45e3});if(Lt.error){oe(Lt.error);return}if(ht||m(d.hostId,w),We&&!ht){l(Lt);try{const xn=await f("task.run",{id:Lt.id});xn.run_id?u(Lt.id,xn.run_id):xn.error||u(Lt.id)}catch{}return}l(Lt)}catch(xe){oe(xe instanceof Error?xe.message:String(xe))}finally{M(!1)}}const $t=ht?"Save":We?"Run":(Je||Fe)&&G?"Schedule":"Save";return b.jsxs("div",{className:"task-form-overlay",children:[b.jsx("div",{className:"task-form",children:z?b.jsx(SE,{permissions:e==null?void 0:e.permissions}):b.jsxs(b.Fragment,{children:[b.jsx("div",{className:"task-form-header",children:b.jsx("h2",{children:e?"Edit Task":"New Task"})}),F&&b.jsx("div",{className:"form-error",children:F}),b.jsx("textarea",{autoFocus:!e,className:"form-textarea",value:g,onChange:xe=>x(xe.target.value),placeholder:We?"If the input email contains an event, create a calendar entry for it.":"Research today's top AI news and write a summary.",rows:4,disabled:pe}),b.jsxs("div",{className:"plan-actions",children:[b.jsxs("div",{className:"agent-picker-section-inline",children:[b.jsx("span",{className:"agent-picker-label",children:"Run with"}),b.jsx("select",{className:"form-select form-select-sm",value:w,onChange:xe=>S(xe.target.value),disabled:pe,children:t.map(xe=>b.jsx("option",{value:xe.key,children:xe.label},xe.key))})]}),ft&&b.jsxs("label",{className:"yolo-inline",style:{marginLeft:"auto"},children:[b.jsx("input",{type:"checkbox",checked:fe,onChange:xe=>ie(xe.target.checked),disabled:pe}),"Yolo"]}),ft&&fe&&b.jsx("p",{className:"yolo-warning",children:"The agent will auto-approve all tool calls without asking for permission."}),T&&b.jsx("div",{className:"granted-permissions-row",children:b.jsx("button",{className:"btn btn-link",onClick:()=>D(!0),children:"Granted Permissions"})})]}),b.jsx("div",{className:"toggles-group",children:b.jsxs("div",{className:"schedule-section",children:[b.jsxs("h3",{className:"schedule-section-title",children:["Schedule ",b.jsx("span",{className:"schedule-section-hint",children:"based on host time"})]}),b.jsxs("select",{className:"form-select",value:B,onChange:xe=>ln(xe.target.value),disabled:pe,children:[b.jsx("option",{value:"ondemand",children:"On Demand"}),b.jsx("option",{value:"specific_times",children:"Specific Times"}),b.jsx("option",{value:"hourly",children:"Hourly"}),b.jsx("option",{value:"daily",children:"Daily"}),b.jsx("option",{value:"weekly",children:"Weekly"}),b.jsx("option",{value:"monthly",children:"Monthly"}),b.jsx("option",{value:"on_new_notification",children:"On New Notification"}),b.jsx("option",{value:"on_new_sms",children:"On New SMS"}),b.jsx("option",{value:"command",children:"Command-triggered"})]}),Fe&&b.jsxs("div",{className:"schedule-reactive",children:[b.jsxs("p",{className:"command-help-text",children:[B==="on_new_notification"?"Runs each time a new push notification arrives on the paired Android device.":"Runs each time a new SMS arrives on the paired Android device."," ","The triggering payload is spliced into your task prompt — reference it as “the new ",B==="on_new_notification"?"notification":"SMS","”."]}),B==="on_new_notification"&&(()=>{const xe=be.find(Re=>Re.packageName===K),qe=(xe==null?void 0:xe.appName)||K;return b.jsxs(b.Fragment,{children:[s?K.trim()?b.jsxs("div",{className:"app-filter-selected",children:[b.jsx("span",{className:"app-filter-selected-name",children:qe}),(xe==null?void 0:xe.appName)&&b.jsx("span",{className:"app-filter-selected-pkg",children:xe.packageName}),b.jsx("button",{type:"button",className:"app-filter-selected-clear",onClick:()=>A(""),"aria-label":"Clear app filter",disabled:pe,children:"✕"})]}):b.jsx("button",{type:"button",className:"btn btn-link app-filter-trigger",onClick:()=>{Ft(""),ke(!0)},disabled:pe,children:"Select app"}):b.jsx("input",{className:"form-input",type:"text",value:K,onChange:Re=>A(Re.target.value),placeholder:"App (optional), e.g. com.google.android.gm",disabled:pe}),b.jsx("p",{className:"command-help-text app-filter-help",children:K.trim()?`Only notifications from ${qe} will trigger this task.`:"Every notification from your device triggers this task."})]})})(),B==="on_new_sms"&&b.jsxs(b.Fragment,{children:[b.jsx("input",{className:"form-input",type:"text",value:Le,onChange:xe=>nt(xe.target.value),placeholder:"From (optional), e.g. +1 555-1234)",disabled:pe}),b.jsx("p",{className:"command-help-text app-filter-help",children:Le.trim()?`Only SMS from ${Le.trim()} will trigger this task. Formatting (spaces, dashes, parens) is ignored.`:"Every SMS that arrives on your device triggers this task."})]})]}),We&&b.jsxs("div",{className:"schedule-reactive",children:[b.jsx("p",{className:"command-help-text",children:"Runs a command and invokes the task for each line of output. Use “the input” in your task description to reference each line."}),b.jsx("input",{ref:Ve,className:"form-input form-input-mono",type:"text",value:X,onChange:xe=>ae(xe.target.value),placeholder:"gws gmail +watch --project my-project",disabled:pe})]}),Je&&B!=="hourly"&&b.jsxs(b.Fragment,{children:[W.map((xe,qe)=>b.jsxs("div",{className:"trigger-row-card",children:[b.jsxs("div",{className:"trigger-row-content",children:[B==="daily"&&b.jsx("input",{className:"form-input",type:"time",value:xe.time,onChange:Re=>Ue(qe,{time:Re.target.value})}),B==="weekly"&&b.jsxs("div",{className:"trigger-row-top",children:[b.jsx("select",{className:"form-select",value:xe.dayOfWeek,onChange:Re=>Ue(qe,{dayOfWeek:Re.target.value}),children:EE.map((Re,At)=>b.jsx("option",{value:String(At),children:Re},At))}),b.jsx("input",{className:"form-input",type:"time",value:xe.time,onChange:Re=>Ue(qe,{time:Re.target.value})})]}),B==="monthly"&&b.jsxs("div",{className:"trigger-row-top",children:[b.jsx("select",{className:"form-select",value:xe.dayOfMonth,onChange:Re=>Ue(qe,{dayOfMonth:Re.target.value}),children:Array.from({length:28},(Re,At)=>At+1).map(Re=>b.jsxs("option",{value:String(Re),children:["Day ",Re]},Re))}),b.jsx("input",{className:"form-input",type:"time",value:xe.time,onChange:Re=>Ue(qe,{time:Re.target.value})})]}),B==="specific_times"&&b.jsxs("div",{className:"trigger-row-top",children:[b.jsx("input",{className:"form-input",type:"date",value:xe.onceDate,min:yn.date,onChange:Re=>Ue(qe,{onceDate:Re.target.value})}),b.jsx("input",{className:"form-input",type:"time",value:xe.onceTime,min:xe.onceDate===yn.date?yn.time:void 0,onChange:Re=>Ue(qe,{onceTime:Re.target.value})})]})]}),W.length>1&&b.jsx("button",{className:"trigger-remove-btn",onClick:()=>Ke(qe),title:"Remove trigger",children:"×"})]},qe)),b.jsx("button",{className:"trigger-add-btn",onClick:ut,children:"+ Add"})]}),r==="win32"&&b.jsxs("label",{className:"toggle-label",children:[b.jsx("input",{type:"checkbox",checked:ee,onChange:xe=>P(xe.target.checked),disabled:pe}),"Run in the foreground (host must login to Windows)"]}),Je&&b.jsxs("label",{className:"toggle-label",children:[b.jsx("input",{type:"checkbox",checked:q,onChange:xe=>R(xe.target.checked),disabled:pe}),"Confirm before each run"]}),B!=="ondemand"&&b.jsxs("label",{className:"toggle-label",children:[b.jsx("input",{type:"checkbox",checked:G,onChange:xe=>J(xe.target.checked),disabled:pe}),"Enabled"]})]})}),!fe&&et&&!et.supportsPermissions&&b.jsxs("div",{className:"form-warning",children:["Palmier does not support runtime permission granting for ",et.label,". The task may fail if required permissions are not pre-configured."]}),b.jsxs("div",{className:"form-actions",children:[b.jsxs("button",{className:"btn btn-primary",onClick:()=>en()&&xt(),disabled:!we||pe,children:[pe&&b.jsx("span",{className:"btn-spinner"}),$t]}),b.jsx("button",{className:"btn btn-secondary",onClick:()=>{$e&&g.trim()&&!confirm("You have unsaved changes. Discard?")||c()},style:{marginLeft:"auto"},children:"Cancel"})]})]})}),Ie&&(()=>{const xe=Ge.trim().toLowerCase(),qe=xe?be.filter(Re=>Re.packageName.toLowerCase().includes(xe)||Re.appName.toLowerCase().includes(xe)):be;return b.jsx("div",{className:"app-filter-overlay",onClick:ze,children:b.jsxs("div",{className:"app-filter-dialog",onClick:Re=>Re.stopPropagation(),children:[b.jsxs("div",{className:"app-filter-header",children:[b.jsx("h2",{children:"Select app"}),b.jsx("button",{className:"app-filter-close",onClick:ze,"aria-label":"Close",children:b.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",children:b.jsx("path",{d:"M4 4L12 12M12 4L4 12",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round"})})})]}),b.jsx("input",{className:"form-input app-filter-search",type:"text",value:Ge,onChange:Re=>Ft(Re.target.value),onKeyDown:Re=>{Re.key==="Enter"&&Ge.trim()&&(A(Ge.trim()),ze())},placeholder:"Search or type a package name",autoFocus:!0}),b.jsxs("ul",{className:"app-filter-list",children:[_e&&be.length===0?Array.from({length:6}).map((Re,At)=>b.jsx("li",{className:"app-filter-row app-filter-skeleton",children:b.jsx("div",{className:"app-filter-skeleton-bar"})},`sk-${At}`)):qe.length===0&&!Ge.trim()?b.jsx("li",{className:"app-filter-empty",children:"No apps"}):qe.map(Re=>b.jsx("li",{className:"app-filter-row",onClick:()=>{A(Re.packageName),ze()},children:b.jsxs("div",{className:"app-filter-row-labels",children:[b.jsx("div",{className:"app-filter-row-name",children:Re.appName||Re.packageName}),Re.appName&&b.jsx("div",{className:"app-filter-row-pkg",children:Re.packageName})]})},Re.packageName)),Ge.trim()&&b.jsx("li",{className:"app-filter-row",onClick:()=>{A(Ge.trim()),ze()},children:b.jsx("div",{className:"app-filter-row-labels",children:b.jsx("div",{className:"app-filter-row-name",children:Ge.trim()})})})]})]})})})()]})}function Lx({pullDistance:e,refreshing:t,threshold:r}){const s=e>0||t,l=e>=r;return b.jsx("div",{className:"pull-to-refresh",style:{transform:`translateY(${e}px)`,opacity:s?Math.min(1,e/30):0},"aria-hidden":!s,children:b.jsx("div",{className:"pull-to-refresh-badge",children:t?b.jsx("div",{className:"spinner"}):b.jsxs("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.25",strokeLinecap:"round",strokeLinejoin:"round",style:{transform:l?"rotate(180deg)":"rotate(0deg)",transition:"transform 0.15s"},children:[b.jsx("line",{x1:"12",y1:"5",x2:"12",y2:"19"}),b.jsx("polyline",{points:"19 12 12 19 5 12"})]})})})}function zx({onRefresh:e,threshold:t=70,maxPull:r=110,enabled:s=!0}){const[l,u]=j.useState(0),[c,f]=j.useState(!1),d=j.useRef(null),m=j.useRef(!1),y=j.useRef(0),g=j.useRef(!1),x=j.useRef(e);return j.useEffect(()=>{x.current=e}),j.useEffect(()=>{if(!s)return;const w=z=>{if(g.current||window.scrollY>0){d.current=null;return}if(RE(z.target)){d.current=null;return}d.current=z.touches[0].clientY,m.current=!1,y.current=0},S=z=>{if(g.current||d.current==null)return;const D=z.touches[0].clientY-d.current;if(D<=0){m.current=!1,y.current=0,u(0);return}m.current=!0;const H=Math.min(r,D*.5);y.current=H,u(H),z.cancelable&&z.preventDefault()},T=()=>{if(!m.current){d.current=null,u(0);return}const z=y.current;d.current=null,m.current=!1,y.current=0,z>=t?(g.current=!0,f(!0),u(t),Promise.resolve(x.current()).catch(()=>{}).finally(()=>{g.current=!1,f(!1),u(0)})):u(0)};return window.addEventListener("touchstart",w,{passive:!0}),window.addEventListener("touchmove",S,{passive:!1}),window.addEventListener("touchend",T,{passive:!0}),window.addEventListener("touchcancel",T,{passive:!0}),()=>{window.removeEventListener("touchstart",w),window.removeEventListener("touchmove",S),window.removeEventListener("touchend",T),window.removeEventListener("touchcancel",T)}},[s,t,r]),{pullDistance:l,refreshing:c,threshold:t}}function RE(e){let t=e;for(;t&&t!==document.body&&t!==document.documentElement;){const r=window.getComputedStyle(t).overflowY;if((r==="auto"||r==="scroll")&&t.scrollHeight>t.clientHeight)return!0;t=t.parentElement}return!1}function ME({connected:e,hostId:t,request:r,subscribeEvents:s,agents:l,hostPlatform:u,isNotificationListener:c,onViewRun:f}){const[d,m]=j.useState([]),[y,g]=j.useState(!1),[x,w]=j.useState(null),[S,T]=j.useState(new Map),[z,D]=j.useState(!1),[H,F]=j.useState(void 0),oe=j.useCallback(()=>{D(!1),F(void 0)},[]),B=j.useCallback(async()=>{if(e){g(!0),w(null);try{const R=(await r("task.list")).tasks??[],G=new Map;for(const J of R)J.status&&G.set(J.id,J.status);T(G),m(R)}catch(q){const R=q instanceof Error?q.message:String(q);R==="Not connected"||R.includes("503")||R.toLowerCase().includes("no responders")?w(null):w(R),m([])}finally{g(!1)}}},[e,t,r]);j.useEffect(()=>{e?B():(m([]),g(!1))},[e,t,B]);const L=zx({onRefresh:B,enabled:e});j.useEffect(()=>!e||!t?void 0:s(t,async R=>{const G=R.subject.split(".");if(G.length<3)return;const J=G.slice(2).join(".");let fe={};try{fe=JSON.parse(new TextDecoder().decode(R.data))}catch{return}const ie=fe.event_type;if(!(ie!=="running-state"&&ie!=="permission-resolved"))try{const ee=await r("task.status",{id:J},{timeout:5e3});if(ee.error)return;T(P=>{const X=new Map(P);return X.set(J,ee),X})}catch{}}),[e,t,s,r]);function W(q){m(R=>{const G=R.findIndex(J=>J.id===q.id);if(G>=0){const J=[...R];return J[G]=q,J}return[q,...R]}),D(!1),F(void 0)}function $(q){m(R=>R.filter(G=>G.id!==q)),T(R=>{const G=new Map(R);return G.delete(q),G})}return b.jsxs(b.Fragment,{children:[b.jsx(Lx,{pullDistance:L.pullDistance,refreshing:L.refreshing,threshold:L.threshold}),x&&b.jsxs("div",{className:"form-error",children:[x,x.toLowerCase().includes("failed to fetch")&&b.jsxs(b.Fragment,{children:[" ",b.jsx("a",{href:"#",onClick:q=>{q.preventDefault(),window.location.reload()},children:"Reload"})]})]}),y&&!d.length?b.jsx("div",{className:"task-list",children:[0,1,2].map(q=>b.jsxs("div",{className:"task-card",style:{pointerEvents:"none"},children:[b.jsx("div",{className:"task-card-header",children:b.jsxs("div",{className:"task-card-title-row",children:[b.jsx("div",{className:"skeleton-line",style:{width:10,height:10,borderRadius:"50%"}}),b.jsx("div",{className:"skeleton-line",style:{width:`${60+q*12}%`}})]})}),b.jsxs("div",{className:"task-card-meta",children:[b.jsx("div",{className:"skeleton-line",style:{width:"30%"}}),b.jsx("div",{className:"skeleton-line",style:{width:"25%"}})]})]},q))}):d.length===0?b.jsxs("div",{className:"empty-state",children:[b.jsx("p",{className:"empty-state-text",children:"No tasks yet"}),b.jsx("p",{className:"empty-state-hint",children:"Tap the + button to create your first task."})]}):b.jsx("div",{className:"task-list",children:d.map(q=>b.jsx(wE,{task:q,lastEvent:S.get(q.id),onEdit:async R=>{try{const G=await r("task.get",{id:R.id});F(G.error?R:G)}catch{F(R)}D(!0)},onDelete:$,onViewRun:f},q.id))}),b.jsx("button",{className:"fab",onClick:()=>{F(void 0),D(!0)},"aria-label":"New task",title:"New task",children:b.jsxs("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",children:[b.jsx("line",{x1:"12",y1:"5",x2:"12",y2:"19"}),b.jsx("line",{x1:"5",y1:"12",x2:"19",y2:"12"})]})}),z&&b.jsx(OE,{initial:H,agents:l,hostPlatform:u,isNotificationListener:c,onSaved:W,onRun:f,onCancel:oe})]})}let ha=null;function I0(e){ha&&(e.preventDefault(),e.returnValue="")}function Oh(e){const t=!!ha;ha=e;const r=!!ha;r&&!t?window.addEventListener("beforeunload",I0):!r&&t&&window.removeEventListener("beforeunload",I0)}function ps(){return ha?window.confirm(ha):!0}function DE(){const e=Mr(),t=cr(),{hostId:r}=$u(),s=t.pathname.endsWith("/tasks"),l=!s;function u(c){ps()&&r&&e(`/hosts/${encodeURIComponent(r)}${c}`)}return b.jsxs(b.Fragment,{children:[b.jsxs("button",{className:`tab-btn ${l?"tab-btn-active":""}`,onClick:()=>u(""),children:[b.jsx("svg",{className:"tab-icon",width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round",children:b.jsx("path",{d:"M2 8H4.5L6 4L8 12L10 6L11.5 8H14"})}),"Sessions"]}),b.jsxs("button",{className:`tab-btn ${s?"tab-btn-active":""}`,onClick:()=>u("/tasks"),children:[b.jsxs("svg",{className:"tab-icon",width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round",children:[b.jsx("rect",{x:"2",y:"2",width:"12",height:"12",rx:"2"}),b.jsx("path",{d:"M5.5 8L7 9.5L10.5 6"})]}),"Tasks"]})]})}function Ux(e){const[t,r]=j.useState(()=>window.matchMedia(e).matches);return j.useEffect(()=>{const s=window.matchMedia(e),l=u=>r(u.matches);return s.addEventListener("change",l),r(s.matches),()=>s.removeEventListener("change",l)},[e]),t}const ku=Xn.isNativePlatform(),LE=["Device","Data","Messaging"],zE=[{capability:"sms-read",label:"Read SMS",group:"Messaging"},{capability:"sms-send",label:"Send SMS",group:"Messaging"},{capability:"send-email",label:"Prompt Email to Send",group:"Messaging"},{capability:"notifications",label:"Notifications from Other Apps",group:"Data"},{capability:"contacts",label:"Manage Contacts",group:"Data"},{capability:"calendar",label:"Manage Calendar",group:"Data"},{capability:"location",label:"Get Location",group:"Device"},{capability:"dnd",label:"Set Ringer Mode",group:"Device"},{capability:"alarm",label:"Trigger Alarms",group:"Device"}];async function UE(){if(!ku||!mn)return new Set;try{const{capabilities:e}=await mn.getCapabilityStatus();return new Set(e.filter(t=>t.enabled).map(t=>t.name))}catch{return new Set}}function Bx({onChange:e,confirmDisable:t=!1}){const[r,s]=j.useState(new Map),[l,u]=j.useState(null),[c,f]=j.useState(null),d=j.useCallback(async()=>{if(!(!ku||!mn))try{const{capabilities:S}=await mn.getCapabilityStatus(),T=new Map;for(const z of S)T.set(z.name,z);s(T),e==null||e(new Set(S.filter(z=>z.enabled).map(z=>z.name)))}catch(S){console.error("Failed to read capability status:",S)}},[e]);j.useEffect(()=>{d()},[d]),j.useEffect(()=>{if(!ku)return;const S=fd.addListener("resume",d);return()=>{S.then(T=>T.remove())}},[d]);async function m(S,T){if(mn){u(S.capability);try{const z=await mn.setCapabilityEnabled({capability:S.capability,enabled:T});!z.enabled&&z.reason==="no-email-client"&&alert("No email app is installed on this device. Install one (e.g. Gmail) before enabling Send Email."),await d()}catch(z){console.error(`Failed to toggle ${S.capability}:`,z)}finally{u(null)}}}function y(S){const T=r.get(S.capability);if(T){if(T.enabled&&t){f(S);return}m(S,!T.enabled)}}function g(){const S=c;S&&(f(null),m(S,!1))}if(!ku)return null;const x=LE.map(S=>({group:S,items:zE.filter(T=>{const z=r.get(T.capability);return T.group===S&&(z==null?void 0:z.supported)})})).filter(S=>S.items.length>0);if(x.length===0)return b.jsx("div",{className:"capability-toggles-loading",children:b.jsx("span",{className:"spinner"})});const w=c&&ds.createPortal(b.jsx("div",{className:"confirm-modal-overlay",onClick:()=>f(null),children:b.jsxs("div",{className:"confirm-modal",onClick:S=>S.stopPropagation(),children:[b.jsxs("h2",{className:"confirm-modal-title",children:["Disable ",c.label,"?"]}),b.jsxs("p",{className:"confirm-modal-message",children:["All hosts linked to this device will no longer be able to use ",c.label,"."]}),b.jsxs("div",{className:"confirm-modal-actions",children:[b.jsx("button",{className:"btn btn-secondary",onClick:()=>f(null),children:"Cancel"}),b.jsx("button",{className:"btn btn-danger",onClick:g,children:"Disable"})]})]})}),document.body);return b.jsxs(b.Fragment,{children:[x.map(({group:S,items:T},z)=>b.jsx("div",{className:z>0?"drawer-toggle-group drawer-toggle-group-divided":"drawer-toggle-group",children:T.map(D=>{const H=r.get(D.capability),F=!!(H!=null&&H.enabled);return b.jsxs("label",{className:"drawer-toggle",children:[b.jsx("span",{className:"drawer-toggle-label",children:D.label}),b.jsx("button",{className:`toggle-switch ${F?"toggle-switch-on":""}`,onClick:()=>y(D),disabled:l===D.capability,role:"switch","aria-checked":F,children:b.jsx("span",{className:"toggle-switch-thumb"})})]},D.capability)})},S)),w]})}const F0=!!window.__PALMIER_SERVE__&&(window.location.hostname==="localhost"||window.location.hostname==="127.0.0.1"),BE=Xn.isNativePlatform();function $0({daemonVersion:e,linkedClientToken:t,request:r,onEnabledCapabilitiesChange:s,onLinkedClientTokenChange:l}){var ze;const{pairedHosts:u,removePairedHost:c,renamePairedHost:f}=qi(),{activeHost:d}=si(),m=Mr(),y=cr(),x=$u().hostId??null,w=d.clientToken||null,S=!!w&&t===w,T=Ux("(min-width: 768px)"),[z,D]=j.useState(!1),[H,F]=j.useState(()=>Date.now());j.useEffect(()=>{const Ae=()=>F(Date.now()),Le=6e4-Date.now()%6e4,nt=setTimeout(()=>{Ae();const Ve=setInterval(Ae,6e4);nt._iv=Ve},Le);return()=>{const Ve=nt._iv;Ve&&clearInterval(Ve),clearTimeout(nt)}},[]);const oe=d.timezone?new Date(H).toLocaleString(void 0,{month:"short",day:"numeric",hour:"numeric",minute:"2-digit",timeZone:d.timezone}):"";async function B(){if(!(!mn||!r||!w)){D(!0);try{const{token:Ae}=await mn.getFcmToken();if(!Ae)return;await r("device.link",{fcmToken:Ae}),l==null||l(w)}catch(Ae){console.error("Failed to make this the linked device:",Ae)}finally{D(!1)}}}async function L(Ae){const Le=Ae===x;if(Le&&r)try{await r("clients.revoke_self")}catch{}c(Ae),X(null),Le&&m("/",{replace:!0})}function W(Ae){const nt=y.pathname.endsWith("/tasks")?"/tasks":"";m(`/hosts/${encodeURIComponent(Ae)}${nt}`)}const[$,q]=j.useState(!1),[R,G]=j.useState(!1),[J,fe]=j.useState(null),[ie,ee]=j.useState(""),[P,X]=j.useState(null),[ae,pe]=j.useState(!1),M=j.useRef(null),E=j.useRef(null),K=j.useCallback(()=>{G(!0)},[]);function A(){R&&(q(!1),G(!1))}function be(){G(!1),q(!0)}function je(Ae,Le){fe(Ae),ee(Le)}function _e(){J&&ie.trim()&&f(J,ie.trim()),fe(null),ee("")}function Me(){fe(null),ee("")}j.useEffect(()=>{J&&E.current&&(E.current.focus(),E.current.select())},[J]),j.useEffect(()=>{if(!$||R)return;function Ae(Le){Le.key==="Escape"&&K()}return document.addEventListener("keydown",Ae),()=>{document.removeEventListener("keydown",Ae)}},[$,R,K]);const Ie=b.jsxs(b.Fragment,{children:[!T&&b.jsx("button",{className:"drawer-close-btn",onClick:K,"aria-label":"Close menu",children:b.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",children:b.jsx("path",{d:"M4 4L12 12M12 4L4 12",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round"})})}),!F0&&u.length>0&&b.jsxs("div",{className:"drawer-section",children:[b.jsx("h3",{className:"drawer-section-label",children:"Hosts"}),b.jsx("div",{className:"host-picker-inline",children:b.jsx("div",{className:"host-picker-list",role:"listbox",children:u.map(Ae=>{const Le=Ae.hostId===x,nt=J===Ae.hostId,Ve=Ae.name||Ae.hostId.slice(0,8);return b.jsx("div",{className:"host-picker-item-wrapper",children:b.jsxs("div",{className:`host-picker-item ${Le?"host-picker-item-active":""}`,onClick:()=>{if(!nt&&!Le){if(!ps())return;W(Ae.hostId),T||K()}},role:"option","aria-selected":Le,children:[nt?b.jsx("input",{ref:E,className:"form-input host-picker-rename-input",type:"text",value:ie,onChange:Je=>ee(Je.target.value),onKeyDown:Je=>{Je.key==="Enter"&&_e(),Je.key==="Escape"&&Me()},onBlur:_e,onClick:Je=>Je.stopPropagation()}):b.jsx("span",{className:"host-picker-item-name",children:Ve}),b.jsxs("div",{className:"host-picker-item-actions",children:[Le&&!nt&&b.jsx("button",{className:"host-picker-edit-btn",onClick:Je=>{Je.stopPropagation(),je(Ae.hostId,Ve)},"aria-label":"Rename host",children:b.jsx("svg",{width:"13",height:"13",viewBox:"0 0 13 13",fill:"none",children:b.jsx("path",{d:"M9.5 1.5L11.5 3.5M1.5 11.5L2 9L9 2L11 4L4 11L1.5 11.5Z",stroke:"currentColor",strokeWidth:"1.2",strokeLinecap:"round",strokeLinejoin:"round"})})}),!Le&&b.jsx("button",{className:"host-picker-delete-btn",onClick:Je=>{Je.stopPropagation(),X(Ae.hostId)},"aria-label":`Unpair ${Ve}`,children:b.jsx("svg",{width:"14",height:"14",viewBox:"0 0 14 14",fill:"none",children:b.jsx("path",{d:"M4 5.5V11C4 11.2761 4.22386 11.5 4.5 11.5H9.5C9.77614 11.5 10 11.2761 10 11V5.5M3 4H11M5.5 4V3C5.5 2.72386 5.72386 2.5 6 2.5H8C8.27614 2.5 8.5 2.72386 8.5 3V4M6.5 6.5V9.5M7.5 6.5V9.5",stroke:"currentColor",strokeWidth:"1.2",strokeLinecap:"round",strokeLinejoin:"round"})})})]})]})},Ae.hostId)})})})]}),!F0&&b.jsxs(b.Fragment,{children:[b.jsx("div",{className:"drawer-divider"}),b.jsx("div",{className:"drawer-section",children:b.jsx("button",{className:"btn btn-primary btn-full",onClick:()=>{ps()&&(m("/pair"),T||K())},children:"Add New Host"})})]}),BE&&r&&b.jsxs(b.Fragment,{children:[b.jsx("div",{className:"drawer-divider"}),b.jsxs("div",{className:"drawer-section",children:[b.jsx("h3",{className:"drawer-section-label",children:"Device Capabilities"}),S?b.jsx(Bx,{onChange:s,confirmDisable:!0}):b.jsxs(b.Fragment,{children:[b.jsx("p",{className:"drawer-section-hint",children:"This device isn't the linked device for the host, so it can't provide capabilities (SMS, contacts, location, etc.)."}),b.jsx("button",{className:"btn btn-secondary btn-full",onClick:()=>{t&&t!==w?pe(!0):B()},disabled:z,children:z?"Linking…":"Link the host to this device"})]})]})]}),b.jsxs("div",{className:"drawer-footer",children:[d.timezone&&b.jsxs("div",{className:"drawer-host-time",children:["Host time: ",oe," · ",d.timezone]}),e&&b.jsxs("div",{className:"drawer-version",children:["Host version: v",e]}),b.jsxs("div",{className:"drawer-legal",children:[b.jsx("a",{href:"https://www.palmier.me/terms",target:"_blank",rel:"noopener noreferrer",children:"Terms"}),b.jsx("span",{className:"drawer-legal-sep",children:"·"}),b.jsx("a",{href:"https://www.palmier.me/privacy",target:"_blank",rel:"noopener noreferrer",children:"Privacy"})]})]})]}),ke=!!P&&P===x&&S,Ge=P&&ds.createPortal(b.jsx("div",{className:"confirm-modal-overlay",onClick:()=>X(null),children:b.jsxs("div",{className:"confirm-modal",onClick:Ae=>Ae.stopPropagation(),children:[b.jsx("h2",{className:"confirm-modal-title",children:"Remove host?"}),b.jsxs("p",{className:"confirm-modal-message",children:['"',((ze=u.find(Ae=>Ae.hostId===P))==null?void 0:ze.name)||P.slice(0,8),'" will be ',ke?"removed and unlinked":"removed",".",ke&&b.jsx(b.Fragment,{children:" This device is currently linked to the host — unlinking will revoke its access to all device capabilities (SMS, contacts, location, etc.) until another device is linked."})]}),b.jsxs("div",{className:"confirm-modal-actions",children:[b.jsx("button",{className:"btn btn-secondary",onClick:()=>X(null),children:"Cancel"}),b.jsx("button",{className:"btn btn-danger",onClick:()=>L(P),children:"Remove"})]})]})}),document.body),Ft=ae&&ds.createPortal(b.jsx("div",{className:"confirm-modal-overlay",onClick:()=>pe(!1),children:b.jsxs("div",{className:"confirm-modal",onClick:Ae=>Ae.stopPropagation(),children:[b.jsx("h2",{className:"confirm-modal-title",children:"Link the host to this device?"}),b.jsx("p",{className:"confirm-modal-message",children:"Another device is already linked to this host. Only one device can be linked to the host — switching will disable those capabilities on the currently linked device."}),b.jsxs("div",{className:"confirm-modal-actions",children:[b.jsx("button",{className:"btn btn-secondary",onClick:()=>pe(!1),children:"Cancel"}),b.jsx("button",{className:"btn btn-primary",onClick:()=>{pe(!1),B()},children:"Link"})]})]})}),document.body);return T?b.jsxs(b.Fragment,{children:[b.jsx("div",{className:"drawer-panel drawer-panel-desktop",ref:M,children:Ie}),Ge,Ft]}):b.jsxs(b.Fragment,{children:[b.jsx("button",{className:"hamburger-btn",onClick:be,"aria-label":"Open menu",children:b.jsx("svg",{width:"20",height:"20",viewBox:"0 0 20 20",fill:"none",children:b.jsx("path",{d:"M3 5H17M3 10H17M3 15H17",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round"})})}),$&&ds.createPortal(b.jsx("div",{className:`drawer-overlay ${R?"drawer-overlay-closing":""}`,onClick:K,onAnimationEnd:A,children:b.jsx("div",{className:`drawer-panel ${R?"drawer-panel-closing":""}`,ref:M,onClick:Ae=>Ae.stopPropagation(),children:Ie})}),document.body),Ge,Ft]})}const PE=Xn.isNativePlatform(),Fd={width:16,height:16,viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round",strokeLinejoin:"round"};function HE(){return b.jsxs("svg",{...Fd,"aria-hidden":"true",children:[b.jsx("path",{d:"M3 11 L12 3 L21 11"}),b.jsx("path",{d:"M5 9.5 V21 H19 V9.5"})]})}function Y0(){return b.jsxs("svg",{...Fd,"aria-hidden":"true",children:[b.jsx("circle",{cx:"12",cy:"12",r:"10"}),b.jsx("line",{x1:"2",y1:"12",x2:"22",y2:"12"}),b.jsx("path",{d:"M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"})]})}function qE(){return b.jsxs("svg",{...Fd,"aria-hidden":"true",children:[b.jsx("path",{d:"M10.29 3.86 1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z"}),b.jsx("line",{x1:"12",y1:"9",x2:"12",y2:"13"}),b.jsx("line",{x1:"12",y1:"17",x2:"12.01",y2:"17"})]})}function IE(){const{mode:e}=si(),[t,r]=j.useState(!1),s=j.useRef(null);if(j.useEffect(()=>{if(!t)return;function f(m){var y;(y=s.current)!=null&&y.contains(m.target)||r(!1)}document.addEventListener("pointerdown",f);const d=window.setTimeout(()=>r(!1),3e3);return()=>{document.removeEventListener("pointerdown",f),clearTimeout(d)}},[t]),e==="direct")return null;let l,u,c;switch(e){case"lan":l=b.jsx(HE,{}),u="Connected via LAN",c="lan";break;case"nats":l=b.jsx(Y0,{}),u=PE?"Connected via relay":"Connected",c="relay";break;case"disconnected":l=b.jsx(qE,{}),u="Disconnected",c="disconnected";break;case"connecting":default:l=b.jsx(Y0,{}),u="Connecting…",c="connecting";break}return b.jsxs("div",{ref:s,className:`conn-status conn-status--${c}`,children:[b.jsx("button",{type:"button",className:"conn-status-btn","aria-label":u,onClick:()=>r(f=>!f),children:l}),b.jsx("div",{className:`conn-status-popover ${t?"conn-status-popover--open":""}`,role:"tooltip",children:u})]})}function G0(e,t){var s;const r=e.map(l=>l.key);return t&&r.includes(t)?t:((s=e[0])==null?void 0:s.key)??""}function FE({agents:e,hostPlatform:t,onStarted:r}){const{request:s,activeHost:l}=si(),{setHostLastAgent:u}=qi(),[c,f]=j.useState(""),[d,m]=j.useState(()=>G0(e,l.lastAgent)),[y,g]=j.useState(!1),[x,w]=j.useState(!1),[S,T]=j.useState(null);j.useEffect(()=>{e.length&&(e.find(L=>L.key===d)||m(G0(e,l.lastAgent)))},[e,d,l.lastAgent]),j.useEffect(()=>{const L=c.trim().length>0;return Oh(L?"Your session draft will be lost. Continue?":null),()=>Oh(null)},[c]);const z=e.find(L=>L.key===d),D=!!(z!=null&&z.supportsYolo);j.useEffect(()=>{!D&&y&&g(!1)},[D,y]);const H=!!c.trim()&&!!d&&!x;function F(){return y?confirm(`Yolo mode is enabled. The agent will auto-approve all tool calls — it can read, write, delete files, run arbitrary commands, and access the network without asking for permission.
|
|
@@ -117,4 +117,4 @@ Are you sure you want to continue?`):!0}async function oe(){if(!(!H||!F())){w(!0
|
|
|
117
117
|
`))+1))}const c="#".repeat(l),f=r.enter("headingAtx"),d=r.enter("phrasing");u.move(c+" ");let m=r.containerPhrasing(e,{before:"# ",after:`
|
|
118
118
|
`,...u.current()});return/^[\t ]/.test(m)&&(m=ql(m.charCodeAt(0))+m.slice(1)),m=m?c+" "+m:c,r.options.closeAtx&&(m+=" "+c),d(),f(),m}C1.peek=r3;function C1(e){return e.value||""}function r3(){return"<"}A1.peek=i3;function A1(e,t,r,s){const l=sm(r),u=l==='"'?"Quote":"Apostrophe",c=r.enter("image");let f=r.enter("label");const d=r.createTracker(s);let m=d.move("![");return m+=d.move(r.safe(e.alt,{before:m,after:"]",...d.current()})),m+=d.move("]("),f(),!e.url&&e.title||/[\0- \u007F]/.test(e.url)?(f=r.enter("destinationLiteral"),m+=d.move("<"),m+=d.move(r.safe(e.url,{before:m,after:">",...d.current()})),m+=d.move(">")):(f=r.enter("destinationRaw"),m+=d.move(r.safe(e.url,{before:m,after:e.title?" ":")",...d.current()}))),f(),e.title&&(f=r.enter(`title${u}`),m+=d.move(" "+l),m+=d.move(r.safe(e.title,{before:m,after:l,...d.current()})),m+=d.move(l),f()),m+=d.move(")"),c(),m}function i3(){return"!"}j1.peek=s3;function j1(e,t,r,s){const l=e.referenceType,u=r.enter("imageReference");let c=r.enter("label");const f=r.createTracker(s);let d=f.move("![");const m=r.safe(e.alt,{before:d,after:"]",...f.current()});d+=f.move(m+"]["),c();const y=r.stack;r.stack=[],c=r.enter("reference");const g=r.safe(r.associationId(e),{before:d,after:"]",...f.current()});return c(),r.stack=y,u(),l==="full"||!m||m!==g?d+=f.move(g+"]"):l==="shortcut"?d=d.slice(0,-1):d+=f.move("]"),d}function s3(){return"!"}T1.peek=a3;function T1(e,t,r){let s=e.value||"",l="`",u=-1;for(;new RegExp("(^|[^`])"+l+"([^`]|$)").test(s);)l+="`";for(/[^ \r\n]/.test(s)&&(/^[ \r\n]/.test(s)&&/[ \r\n]$/.test(s)||/^`|`$/.test(s))&&(s=" "+s+" ");++u<r.unsafe.length;){const c=r.unsafe[u],f=r.compilePattern(c);let d;if(c.atBreak)for(;d=f.exec(s);){let m=d.index;s.charCodeAt(m)===10&&s.charCodeAt(m-1)===13&&m--,s=s.slice(0,m)+" "+s.slice(d.index+1)}}return l+s+l}function a3(){return"`"}function N1(e,t){const r=Kd(e);return!!(!t.options.resourceLink&&e.url&&!e.title&&e.children&&e.children.length===1&&e.children[0].type==="text"&&(r===e.url||"mailto:"+r===e.url)&&/^[a-z][a-z+.-]+:/i.test(e.url)&&!/[\0- <>\u007F]/.test(e.url))}O1.peek=l3;function O1(e,t,r,s){const l=sm(r),u=l==='"'?"Quote":"Apostrophe",c=r.createTracker(s);let f,d;if(N1(e,r)){const y=r.stack;r.stack=[],f=r.enter("autolink");let g=c.move("<");return g+=c.move(r.containerPhrasing(e,{before:g,after:">",...c.current()})),g+=c.move(">"),f(),r.stack=y,g}f=r.enter("link"),d=r.enter("label");let m=c.move("[");return m+=c.move(r.containerPhrasing(e,{before:m,after:"](",...c.current()})),m+=c.move("]("),d(),!e.url&&e.title||/[\0- \u007F]/.test(e.url)?(d=r.enter("destinationLiteral"),m+=c.move("<"),m+=c.move(r.safe(e.url,{before:m,after:">",...c.current()})),m+=c.move(">")):(d=r.enter("destinationRaw"),m+=c.move(r.safe(e.url,{before:m,after:e.title?" ":")",...c.current()}))),d(),e.title&&(d=r.enter(`title${u}`),m+=c.move(" "+l),m+=c.move(r.safe(e.title,{before:m,after:l,...c.current()})),m+=c.move(l),d()),m+=c.move(")"),f(),m}function l3(e,t,r){return N1(e,r)?"<":"["}R1.peek=o3;function R1(e,t,r,s){const l=e.referenceType,u=r.enter("linkReference");let c=r.enter("label");const f=r.createTracker(s);let d=f.move("[");const m=r.containerPhrasing(e,{before:d,after:"]",...f.current()});d+=f.move(m+"]["),c();const y=r.stack;r.stack=[],c=r.enter("reference");const g=r.safe(r.associationId(e),{before:d,after:"]",...f.current()});return c(),r.stack=y,u(),l==="full"||!m||m!==g?d+=f.move(g+"]"):l==="shortcut"?d=d.slice(0,-1):d+=f.move("]"),d}function o3(){return"["}function am(e){const t=e.options.bullet||"*";if(t!=="*"&&t!=="+"&&t!=="-")throw new Error("Cannot serialize items with `"+t+"` for `options.bullet`, expected `*`, `+`, or `-`");return t}function u3(e){const t=am(e),r=e.options.bulletOther;if(!r)return t==="*"?"-":"*";if(r!=="*"&&r!=="+"&&r!=="-")throw new Error("Cannot serialize items with `"+r+"` for `options.bulletOther`, expected `*`, `+`, or `-`");if(r===t)throw new Error("Expected `bullet` (`"+t+"`) and `bulletOther` (`"+r+"`) to be different");return r}function c3(e){const t=e.options.bulletOrdered||".";if(t!=="."&&t!==")")throw new Error("Cannot serialize items with `"+t+"` for `options.bulletOrdered`, expected `.` or `)`");return t}function M1(e){const t=e.options.rule||"*";if(t!=="*"&&t!=="-"&&t!=="_")throw new Error("Cannot serialize rules with `"+t+"` for `options.rule`, expected `*`, `-`, or `_`");return t}function f3(e,t,r,s){const l=r.enter("list"),u=r.bulletCurrent;let c=e.ordered?c3(r):am(r);const f=e.ordered?c==="."?")":".":u3(r);let d=t&&r.bulletLastUsed?c===r.bulletLastUsed:!1;if(!e.ordered){const y=e.children?e.children[0]:void 0;if((c==="*"||c==="-")&&y&&(!y.children||!y.children[0])&&r.stack[r.stack.length-1]==="list"&&r.stack[r.stack.length-2]==="listItem"&&r.stack[r.stack.length-3]==="list"&&r.stack[r.stack.length-4]==="listItem"&&r.indexStack[r.indexStack.length-1]===0&&r.indexStack[r.indexStack.length-2]===0&&r.indexStack[r.indexStack.length-3]===0&&(d=!0),M1(r)===c&&y){let g=-1;for(;++g<e.children.length;){const x=e.children[g];if(x&&x.type==="listItem"&&x.children&&x.children[0]&&x.children[0].type==="thematicBreak"){d=!0;break}}}}d&&(c=f),r.bulletCurrent=c;const m=r.containerFlow(e,s);return r.bulletLastUsed=c,r.bulletCurrent=u,l(),m}function h3(e){const t=e.options.listItemIndent||"one";if(t!=="tab"&&t!=="one"&&t!=="mixed")throw new Error("Cannot serialize items with `"+t+"` for `options.listItemIndent`, expected `tab`, `one`, or `mixed`");return t}function d3(e,t,r,s){const l=h3(r);let u=r.bulletCurrent||am(r);t&&t.type==="list"&&t.ordered&&(u=(typeof t.start=="number"&&t.start>-1?t.start:1)+(r.options.incrementListMarker===!1?0:t.children.indexOf(e))+u);let c=u.length+1;(l==="tab"||l==="mixed"&&(t&&t.type==="list"&&t.spread||e.spread))&&(c=Math.ceil(c/4)*4);const f=r.createTracker(s);f.move(u+" ".repeat(c-u.length)),f.shift(c);const d=r.enter("listItem"),m=r.indentLines(r.containerFlow(e,f.current()),y);return d(),m;function y(g,x,w){return x?(w?"":" ".repeat(c))+g:(w?u:u+" ".repeat(c-u.length))+g}}function m3(e,t,r,s){const l=r.enter("paragraph"),u=r.enter("phrasing"),c=r.containerPhrasing(e,s);return u(),l(),c}const p3=ec(["break","delete","emphasis","footnote","footnoteReference","image","imageReference","inlineCode","inlineMath","link","linkReference","mdxJsxTextElement","mdxTextExpression","strong","text","textDirective"]);function g3(e,t,r,s){return(e.children.some(function(c){return p3(c)})?r.containerPhrasing:r.containerFlow).call(r,e,s)}function y3(e){const t=e.options.strong||"*";if(t!=="*"&&t!=="_")throw new Error("Cannot serialize strong with `"+t+"` for `options.strong`, expected `*`, or `_`");return t}D1.peek=b3;function D1(e,t,r,s){const l=y3(r),u=r.enter("strong"),c=r.createTracker(s),f=c.move(l+l);let d=c.move(r.containerPhrasing(e,{after:l,before:f,...c.current()}));const m=d.charCodeAt(0),y=qu(s.before.charCodeAt(s.before.length-1),m,l);y.inside&&(d=ql(m)+d.slice(1));const g=d.charCodeAt(d.length-1),x=qu(s.after.charCodeAt(0),g,l);x.inside&&(d=d.slice(0,-1)+ql(g));const w=c.move(l+l);return u(),r.attentionEncodeSurroundingInfo={after:x.outside,before:y.outside},f+d+w}function b3(e,t,r){return r.options.strong||"*"}function x3(e,t,r,s){return r.safe(e.value,s)}function v3(e){const t=e.options.ruleRepetition||3;if(t<3)throw new Error("Cannot serialize rules with repetition `"+t+"` for `options.ruleRepetition`, expected `3` or more");return t}function w3(e,t,r){const s=(M1(r)+(r.options.ruleSpaces?" ":"")).repeat(v3(r));return r.options.ruleSpaces?s.slice(0,-1):s}const L1={blockquote:$N,break:Db,code:KN,definition:ZN,emphasis:E1,hardBreak:Db,heading:n3,html:C1,image:A1,imageReference:j1,inlineCode:T1,link:O1,linkReference:R1,list:f3,listItem:d3,paragraph:m3,root:g3,strong:D1,text:x3,thematicBreak:w3};function S3(){return{enter:{table:_3,tableData:Lb,tableHeader:Lb,tableRow:E3},exit:{codeText:C3,table:k3,tableData:Jh,tableHeader:Jh,tableRow:Jh}}}function _3(e){const t=e._align;this.enter({type:"table",align:t.map(function(r){return r==="none"?null:r}),children:[]},e),this.data.inTable=!0}function k3(e){this.exit(e),this.data.inTable=void 0}function E3(e){this.enter({type:"tableRow",children:[]},e)}function Jh(e){this.exit(e)}function Lb(e){this.enter({type:"tableCell",children:[]},e)}function C3(e){let t=this.resume();this.data.inTable&&(t=t.replace(/\\([\\|])/g,A3));const r=this.stack[this.stack.length-1];r.type,r.value=t,this.exit(e)}function A3(e,t){return t==="|"?t:e}function j3(e){const t=e||{},r=t.tableCellPadding,s=t.tablePipeAlign,l=t.stringLength,u=r?" ":"|";return{unsafe:[{character:"\r",inConstruct:"tableCell"},{character:`
|
|
119
119
|
`,inConstruct:"tableCell"},{atBreak:!0,character:"|",after:"[ :-]"},{character:"|",inConstruct:"tableCell"},{atBreak:!0,character:":",after:"-"},{atBreak:!0,character:"-",after:"[:|-]"}],handlers:{inlineCode:x,table:c,tableCell:d,tableRow:f}};function c(w,S,T,z){return m(y(w,T,z),w.align)}function f(w,S,T,z){const D=g(w,T,z),H=m([D]);return H.slice(0,H.indexOf(`
|
|
120
|
-
`))}function d(w,S,T,z){const D=T.enter("tableCell"),H=T.enter("phrasing"),F=T.containerPhrasing(w,{...z,before:u,after:u});return H(),D(),F}function m(w,S){return IN(w,{align:S,alignDelimiters:s,padding:r,stringLength:l})}function y(w,S,T){const z=w.children;let D=-1;const H=[],F=S.enter("table");for(;++D<z.length;)H[D]=g(z[D],S,T);return F(),H}function g(w,S,T){const z=w.children;let D=-1;const H=[],F=S.enter("tableRow");for(;++D<z.length;)H[D]=d(z[D],w,S,T);return F(),H}function x(w,S,T){let z=L1.inlineCode(w,S,T);return T.stack.includes("tableCell")&&(z=z.replace(/\|/g,"\\$&")),z}}function T3(){return{exit:{taskListCheckValueChecked:zb,taskListCheckValueUnchecked:zb,paragraph:O3}}}function N3(){return{unsafe:[{atBreak:!0,character:"-",after:"[:|-]"}],handlers:{listItem:R3}}}function zb(e){const t=this.stack[this.stack.length-2];t.type,t.checked=e.type==="taskListCheckValueChecked"}function O3(e){const t=this.stack[this.stack.length-2];if(t&&t.type==="listItem"&&typeof t.checked=="boolean"){const r=this.stack[this.stack.length-1];r.type;const s=r.children[0];if(s&&s.type==="text"){const l=t.children;let u=-1,c;for(;++u<l.length;){const f=l[u];if(f.type==="paragraph"){c=f;break}}c===r&&(s.value=s.value.slice(1),s.value.length===0?r.children.shift():r.position&&s.position&&typeof s.position.start.offset=="number"&&(s.position.start.column++,s.position.start.offset++,r.position.start=Object.assign({},s.position.start)))}}this.exit(e)}function R3(e,t,r,s){const l=e.children[0],u=typeof e.checked=="boolean"&&l&&l.type==="paragraph",c="["+(e.checked?"x":" ")+"] ",f=r.createTracker(s);u&&f.move(c);let d=L1.listItem(e,t,r,{...s,...f.current()});return u&&(d=d.replace(/^(?:[*+-]|\d+\.)([\r\n]| {1,3})/,m)),d;function m(y){return y+c}}function M3(){return[fN(),RN(),zN(),S3(),T3()]}function D3(e){return{extensions:[hN(),MN(e),UN(),j3(e),N3()]}}const L3={tokenize:q3,partial:!0},z1={tokenize:I3,partial:!0},U1={tokenize:F3,partial:!0},B1={tokenize:$3,partial:!0},z3={tokenize:Y3,partial:!0},P1={name:"wwwAutolink",tokenize:P3,previous:q1},H1={name:"protocolAutolink",tokenize:H3,previous:I1},ai={name:"emailAutolink",tokenize:B3,previous:F1},Dr={};function U3(){return{text:Dr}}let hs=48;for(;hs<123;)Dr[hs]=ai,hs++,hs===58?hs=65:hs===91&&(hs=97);Dr[43]=ai;Dr[45]=ai;Dr[46]=ai;Dr[95]=ai;Dr[72]=[ai,H1];Dr[104]=[ai,H1];Dr[87]=[ai,P1];Dr[119]=[ai,P1];function B3(e,t,r){const s=this;let l,u;return c;function c(g){return!kd(g)||!F1.call(s,s.previous)||lm(s.events)?r(g):(e.enter("literalAutolink"),e.enter("literalAutolinkEmail"),f(g))}function f(g){return kd(g)?(e.consume(g),f):g===64?(e.consume(g),d):r(g)}function d(g){return g===46?e.check(z3,y,m)(g):g===45||g===95||pn(g)?(u=!0,e.consume(g),d):y(g)}function m(g){return e.consume(g),l=!0,d}function y(g){return u&&l&&kn(s.previous)?(e.exit("literalAutolinkEmail"),e.exit("literalAutolink"),t(g)):r(g)}}function P3(e,t,r){const s=this;return l;function l(c){return c!==87&&c!==119||!q1.call(s,s.previous)||lm(s.events)?r(c):(e.enter("literalAutolink"),e.enter("literalAutolinkWww"),e.check(L3,e.attempt(z1,e.attempt(U1,u),r),r)(c))}function u(c){return e.exit("literalAutolinkWww"),e.exit("literalAutolink"),t(c)}}function H3(e,t,r){const s=this;let l="",u=!1;return c;function c(g){return(g===72||g===104)&&I1.call(s,s.previous)&&!lm(s.events)?(e.enter("literalAutolink"),e.enter("literalAutolinkHttp"),l+=String.fromCodePoint(g),e.consume(g),f):r(g)}function f(g){if(kn(g)&&l.length<5)return l+=String.fromCodePoint(g),e.consume(g),f;if(g===58){const x=l.toLowerCase();if(x==="http"||x==="https")return e.consume(g),d}return r(g)}function d(g){return g===47?(e.consume(g),u?m:(u=!0,d)):r(g)}function m(g){return g===null||Bu(g)||Nt(g)||gs(g)||Qu(g)?r(g):e.attempt(z1,e.attempt(U1,y),r)(g)}function y(g){return e.exit("literalAutolinkHttp"),e.exit("literalAutolink"),t(g)}}function q3(e,t,r){let s=0;return l;function l(c){return(c===87||c===119)&&s<3?(s++,e.consume(c),l):c===46&&s===3?(e.consume(c),u):r(c)}function u(c){return c===null?r(c):t(c)}}function I3(e,t,r){let s,l,u;return c;function c(m){return m===46||m===95?e.check(B1,d,f)(m):m===null||Nt(m)||gs(m)||m!==45&&Qu(m)?d(m):(u=!0,e.consume(m),c)}function f(m){return m===95?s=!0:(l=s,s=void 0),e.consume(m),c}function d(m){return l||s||!u?r(m):t(m)}}function F3(e,t){let r=0,s=0;return l;function l(c){return c===40?(r++,e.consume(c),l):c===41&&s<r?u(c):c===33||c===34||c===38||c===39||c===41||c===42||c===44||c===46||c===58||c===59||c===60||c===63||c===93||c===95||c===126?e.check(B1,t,u)(c):c===null||Nt(c)||gs(c)?t(c):(e.consume(c),l)}function u(c){return c===41&&s++,e.consume(c),l}}function $3(e,t,r){return s;function s(f){return f===33||f===34||f===39||f===41||f===42||f===44||f===46||f===58||f===59||f===63||f===95||f===126?(e.consume(f),s):f===38?(e.consume(f),u):f===93?(e.consume(f),l):f===60||f===null||Nt(f)||gs(f)?t(f):r(f)}function l(f){return f===null||f===40||f===91||Nt(f)||gs(f)?t(f):s(f)}function u(f){return kn(f)?c(f):r(f)}function c(f){return f===59?(e.consume(f),s):kn(f)?(e.consume(f),c):r(f)}}function Y3(e,t,r){return s;function s(u){return e.consume(u),l}function l(u){return pn(u)?r(u):t(u)}}function q1(e){return e===null||e===40||e===42||e===95||e===91||e===93||e===126||Nt(e)}function I1(e){return!kn(e)}function F1(e){return!(e===47||kd(e))}function kd(e){return e===43||e===45||e===46||e===95||pn(e)}function lm(e){let t=e.length,r=!1;for(;t--;){const s=e[t][1];if((s.type==="labelLink"||s.type==="labelImage")&&!s._balanced){r=!0;break}if(s._gfmAutolinkLiteralWalkedInto){r=!1;break}}return e.length>0&&!r&&(e[e.length-1][1]._gfmAutolinkLiteralWalkedInto=!0),r}const G3={tokenize:eO,partial:!0};function V3(){return{document:{91:{name:"gfmFootnoteDefinition",tokenize:Q3,continuation:{tokenize:Z3},exit:W3}},text:{91:{name:"gfmFootnoteCall",tokenize:K3},93:{name:"gfmPotentialFootnoteCall",add:"after",tokenize:J3,resolveTo:X3}}}}function J3(e,t,r){const s=this;let l=s.events.length;const u=s.parser.gfmFootnotes||(s.parser.gfmFootnotes=[]);let c;for(;l--;){const d=s.events[l][1];if(d.type==="labelImage"){c=d;break}if(d.type==="gfmFootnoteCall"||d.type==="labelLink"||d.type==="label"||d.type==="image"||d.type==="link")break}return f;function f(d){if(!c||!c._balanced)return r(d);const m=wr(s.sliceSerialize({start:c.end,end:s.now()}));return m.codePointAt(0)!==94||!u.includes(m.slice(1))?r(d):(e.enter("gfmFootnoteCallLabelMarker"),e.consume(d),e.exit("gfmFootnoteCallLabelMarker"),t(d))}}function X3(e,t){let r=e.length;for(;r--;)if(e[r][1].type==="labelImage"&&e[r][0]==="enter"){e[r][1];break}e[r+1][1].type="data",e[r+3][1].type="gfmFootnoteCallLabelMarker";const s={type:"gfmFootnoteCall",start:Object.assign({},e[r+3][1].start),end:Object.assign({},e[e.length-1][1].end)},l={type:"gfmFootnoteCallMarker",start:Object.assign({},e[r+3][1].end),end:Object.assign({},e[r+3][1].end)};l.end.column++,l.end.offset++,l.end._bufferIndex++;const u={type:"gfmFootnoteCallString",start:Object.assign({},l.end),end:Object.assign({},e[e.length-1][1].start)},c={type:"chunkString",contentType:"string",start:Object.assign({},u.start),end:Object.assign({},u.end)},f=[e[r+1],e[r+2],["enter",s,t],e[r+3],e[r+4],["enter",l,t],["exit",l,t],["enter",u,t],["enter",c,t],["exit",c,t],["exit",u,t],e[e.length-2],e[e.length-1],["exit",s,t]];return e.splice(r,e.length-r+1,...f),e}function K3(e,t,r){const s=this,l=s.parser.gfmFootnotes||(s.parser.gfmFootnotes=[]);let u=0,c;return f;function f(g){return e.enter("gfmFootnoteCall"),e.enter("gfmFootnoteCallLabelMarker"),e.consume(g),e.exit("gfmFootnoteCallLabelMarker"),d}function d(g){return g!==94?r(g):(e.enter("gfmFootnoteCallMarker"),e.consume(g),e.exit("gfmFootnoteCallMarker"),e.enter("gfmFootnoteCallString"),e.enter("chunkString").contentType="string",m)}function m(g){if(u>999||g===93&&!c||g===null||g===91||Nt(g))return r(g);if(g===93){e.exit("chunkString");const x=e.exit("gfmFootnoteCallString");return l.includes(wr(s.sliceSerialize(x)))?(e.enter("gfmFootnoteCallLabelMarker"),e.consume(g),e.exit("gfmFootnoteCallLabelMarker"),e.exit("gfmFootnoteCall"),t):r(g)}return Nt(g)||(c=!0),u++,e.consume(g),g===92?y:m}function y(g){return g===91||g===92||g===93?(e.consume(g),u++,m):m(g)}}function Q3(e,t,r){const s=this,l=s.parser.gfmFootnotes||(s.parser.gfmFootnotes=[]);let u,c=0,f;return d;function d(S){return e.enter("gfmFootnoteDefinition")._container=!0,e.enter("gfmFootnoteDefinitionLabel"),e.enter("gfmFootnoteDefinitionLabelMarker"),e.consume(S),e.exit("gfmFootnoteDefinitionLabelMarker"),m}function m(S){return S===94?(e.enter("gfmFootnoteDefinitionMarker"),e.consume(S),e.exit("gfmFootnoteDefinitionMarker"),e.enter("gfmFootnoteDefinitionLabelString"),e.enter("chunkString").contentType="string",y):r(S)}function y(S){if(c>999||S===93&&!f||S===null||S===91||Nt(S))return r(S);if(S===93){e.exit("chunkString");const T=e.exit("gfmFootnoteDefinitionLabelString");return u=wr(s.sliceSerialize(T)),e.enter("gfmFootnoteDefinitionLabelMarker"),e.consume(S),e.exit("gfmFootnoteDefinitionLabelMarker"),e.exit("gfmFootnoteDefinitionLabel"),x}return Nt(S)||(f=!0),c++,e.consume(S),S===92?g:y}function g(S){return S===91||S===92||S===93?(e.consume(S),c++,y):y(S)}function x(S){return S===58?(e.enter("definitionMarker"),e.consume(S),e.exit("definitionMarker"),l.includes(u)||l.push(u),ct(e,w,"gfmFootnoteDefinitionWhitespace")):r(S)}function w(S){return t(S)}}function Z3(e,t,r){return e.check(Vl,t,e.attempt(G3,t,r))}function W3(e){e.exit("gfmFootnoteDefinition")}function eO(e,t,r){const s=this;return ct(e,l,"gfmFootnoteDefinitionIndent",5);function l(u){const c=s.events[s.events.length-1];return c&&c[1].type==="gfmFootnoteDefinitionIndent"&&c[2].sliceSerialize(c[1],!0).length===4?t(u):r(u)}}function tO(e){let r=(e||{}).singleTilde;const s={name:"strikethrough",tokenize:u,resolveAll:l};return r==null&&(r=!0),{text:{126:s},insideSpan:{null:[s]},attentionMarkers:{null:[126]}};function l(c,f){let d=-1;for(;++d<c.length;)if(c[d][0]==="enter"&&c[d][1].type==="strikethroughSequenceTemporary"&&c[d][1]._close){let m=d;for(;m--;)if(c[m][0]==="exit"&&c[m][1].type==="strikethroughSequenceTemporary"&&c[m][1]._open&&c[d][1].end.offset-c[d][1].start.offset===c[m][1].end.offset-c[m][1].start.offset){c[d][1].type="strikethroughSequence",c[m][1].type="strikethroughSequence";const y={type:"strikethrough",start:Object.assign({},c[m][1].start),end:Object.assign({},c[d][1].end)},g={type:"strikethroughText",start:Object.assign({},c[m][1].end),end:Object.assign({},c[d][1].start)},x=[["enter",y,f],["enter",c[m][1],f],["exit",c[m][1],f],["enter",g,f]],w=f.parser.constructs.insideSpan.null;w&&Vn(x,x.length,0,Zu(w,c.slice(m+1,d),f)),Vn(x,x.length,0,[["exit",g,f],["enter",c[d][1],f],["exit",c[d][1],f],["exit",y,f]]),Vn(c,m-1,d-m+3,x),d=m+x.length-2;break}}for(d=-1;++d<c.length;)c[d][1].type==="strikethroughSequenceTemporary"&&(c[d][1].type="data");return c}function u(c,f,d){const m=this.previous,y=this.events;let g=0;return x;function x(S){return m===126&&y[y.length-1][1].type!=="characterEscape"?d(S):(c.enter("strikethroughSequenceTemporary"),w(S))}function w(S){const T=ba(m);if(S===126)return g>1?d(S):(c.consume(S),g++,w);if(g<2&&!r)return d(S);const z=c.exit("strikethroughSequenceTemporary"),D=ba(S);return z._open=!D||D===2&&!!T,z._close=!T||T===2&&!!D,f(S)}}}class nO{constructor(){this.map=[]}add(t,r,s){rO(this,t,r,s)}consume(t){if(this.map.sort(function(u,c){return u[0]-c[0]}),this.map.length===0)return;let r=this.map.length;const s=[];for(;r>0;)r-=1,s.push(t.slice(this.map[r][0]+this.map[r][1]),this.map[r][2]),t.length=this.map[r][0];s.push(t.slice()),t.length=0;let l=s.pop();for(;l;){for(const u of l)t.push(u);l=s.pop()}this.map.length=0}}function rO(e,t,r,s){let l=0;if(!(r===0&&s.length===0)){for(;l<e.map.length;){if(e.map[l][0]===t){e.map[l][1]+=r,e.map[l][2].push(...s);return}l+=1}e.map.push([t,r,s])}}function iO(e,t){let r=!1;const s=[];for(;t<e.length;){const l=e[t];if(r){if(l[0]==="enter")l[1].type==="tableContent"&&s.push(e[t+1][1].type==="tableDelimiterMarker"?"left":"none");else if(l[1].type==="tableContent"){if(e[t-1][1].type==="tableDelimiterMarker"){const u=s.length-1;s[u]=s[u]==="left"?"center":"right"}}else if(l[1].type==="tableDelimiterRow")break}else l[0]==="enter"&&l[1].type==="tableDelimiterRow"&&(r=!0);t+=1}return s}function sO(){return{flow:{null:{name:"table",tokenize:aO,resolveAll:lO}}}}function aO(e,t,r){const s=this;let l=0,u=0,c;return f;function f(R){let G=s.events.length-1;for(;G>-1;){const ie=s.events[G][1].type;if(ie==="lineEnding"||ie==="linePrefix")G--;else break}const J=G>-1?s.events[G][1].type:null,fe=J==="tableHead"||J==="tableRow"?L:d;return fe===L&&s.parser.lazy[s.now().line]?r(R):fe(R)}function d(R){return e.enter("tableHead"),e.enter("tableRow"),m(R)}function m(R){return R===124||(c=!0,u+=1),y(R)}function y(R){return R===null?r(R):Pe(R)?u>1?(u=0,s.interrupt=!0,e.exit("tableRow"),e.enter("lineEnding"),e.consume(R),e.exit("lineEnding"),w):r(R):st(R)?ct(e,y,"whitespace")(R):(u+=1,c&&(c=!1,l+=1),R===124?(e.enter("tableCellDivider"),e.consume(R),e.exit("tableCellDivider"),c=!0,y):(e.enter("data"),g(R)))}function g(R){return R===null||R===124||Nt(R)?(e.exit("data"),y(R)):(e.consume(R),R===92?x:g)}function x(R){return R===92||R===124?(e.consume(R),g):g(R)}function w(R){return s.interrupt=!1,s.parser.lazy[s.now().line]?r(R):(e.enter("tableDelimiterRow"),c=!1,st(R)?ct(e,S,"linePrefix",s.parser.constructs.disable.null.includes("codeIndented")?void 0:4)(R):S(R))}function S(R){return R===45||R===58?z(R):R===124?(c=!0,e.enter("tableCellDivider"),e.consume(R),e.exit("tableCellDivider"),T):B(R)}function T(R){return st(R)?ct(e,z,"whitespace")(R):z(R)}function z(R){return R===58?(u+=1,c=!0,e.enter("tableDelimiterMarker"),e.consume(R),e.exit("tableDelimiterMarker"),D):R===45?(u+=1,D(R)):R===null||Pe(R)?oe(R):B(R)}function D(R){return R===45?(e.enter("tableDelimiterFiller"),H(R)):B(R)}function H(R){return R===45?(e.consume(R),H):R===58?(c=!0,e.exit("tableDelimiterFiller"),e.enter("tableDelimiterMarker"),e.consume(R),e.exit("tableDelimiterMarker"),F):(e.exit("tableDelimiterFiller"),F(R))}function F(R){return st(R)?ct(e,oe,"whitespace")(R):oe(R)}function oe(R){return R===124?S(R):R===null||Pe(R)?!c||l!==u?B(R):(e.exit("tableDelimiterRow"),e.exit("tableHead"),t(R)):B(R)}function B(R){return r(R)}function L(R){return e.enter("tableRow"),W(R)}function W(R){return R===124?(e.enter("tableCellDivider"),e.consume(R),e.exit("tableCellDivider"),W):R===null||Pe(R)?(e.exit("tableRow"),t(R)):st(R)?ct(e,W,"whitespace")(R):(e.enter("data"),$(R))}function $(R){return R===null||R===124||Nt(R)?(e.exit("data"),W(R)):(e.consume(R),R===92?q:$)}function q(R){return R===92||R===124?(e.consume(R),$):$(R)}}function lO(e,t){let r=-1,s=!0,l=0,u=[0,0,0,0],c=[0,0,0,0],f=!1,d=0,m,y,g;const x=new nO;for(;++r<e.length;){const w=e[r],S=w[1];w[0]==="enter"?S.type==="tableHead"?(f=!1,d!==0&&(Ub(x,t,d,m,y),y=void 0,d=0),m={type:"table",start:Object.assign({},S.start),end:Object.assign({},S.end)},x.add(r,0,[["enter",m,t]])):S.type==="tableRow"||S.type==="tableDelimiterRow"?(s=!0,g=void 0,u=[0,0,0,0],c=[0,r+1,0,0],f&&(f=!1,y={type:"tableBody",start:Object.assign({},S.start),end:Object.assign({},S.end)},x.add(r,0,[["enter",y,t]])),l=S.type==="tableDelimiterRow"?2:y?3:1):l&&(S.type==="data"||S.type==="tableDelimiterMarker"||S.type==="tableDelimiterFiller")?(s=!1,c[2]===0&&(u[1]!==0&&(c[0]=c[1],g=bu(x,t,u,l,void 0,g),u=[0,0,0,0]),c[2]=r)):S.type==="tableCellDivider"&&(s?s=!1:(u[1]!==0&&(c[0]=c[1],g=bu(x,t,u,l,void 0,g)),u=c,c=[u[1],r,0,0])):S.type==="tableHead"?(f=!0,d=r):S.type==="tableRow"||S.type==="tableDelimiterRow"?(d=r,u[1]!==0?(c[0]=c[1],g=bu(x,t,u,l,r,g)):c[1]!==0&&(g=bu(x,t,c,l,r,g)),l=0):l&&(S.type==="data"||S.type==="tableDelimiterMarker"||S.type==="tableDelimiterFiller")&&(c[3]=r)}for(d!==0&&Ub(x,t,d,m,y),x.consume(t.events),r=-1;++r<t.events.length;){const w=t.events[r];w[0]==="enter"&&w[1].type==="table"&&(w[1]._align=iO(t.events,r))}return e}function bu(e,t,r,s,l,u){const c=s===1?"tableHeader":s===2?"tableDelimiter":"tableData",f="tableContent";r[0]!==0&&(u.end=Object.assign({},ia(t.events,r[0])),e.add(r[0],0,[["exit",u,t]]));const d=ia(t.events,r[1]);if(u={type:c,start:Object.assign({},d),end:Object.assign({},d)},e.add(r[1],0,[["enter",u,t]]),r[2]!==0){const m=ia(t.events,r[2]),y=ia(t.events,r[3]),g={type:f,start:Object.assign({},m),end:Object.assign({},y)};if(e.add(r[2],0,[["enter",g,t]]),s!==2){const x=t.events[r[2]],w=t.events[r[3]];if(x[1].end=Object.assign({},w[1].end),x[1].type="chunkText",x[1].contentType="text",r[3]>r[2]+1){const S=r[2]+1,T=r[3]-r[2]-1;e.add(S,T,[])}}e.add(r[3]+1,0,[["exit",g,t]])}return l!==void 0&&(u.end=Object.assign({},ia(t.events,l)),e.add(l,0,[["exit",u,t]]),u=void 0),u}function Ub(e,t,r,s,l){const u=[],c=ia(t.events,r);l&&(l.end=Object.assign({},c),u.push(["exit",l,t])),s.end=Object.assign({},c),u.push(["exit",s,t]),e.add(r+1,0,u)}function ia(e,t){const r=e[t],s=r[0]==="enter"?"start":"end";return r[1][s]}const oO={name:"tasklistCheck",tokenize:cO};function uO(){return{text:{91:oO}}}function cO(e,t,r){const s=this;return l;function l(d){return s.previous!==null||!s._gfmTasklistFirstContentOfListItem?r(d):(e.enter("taskListCheck"),e.enter("taskListCheckMarker"),e.consume(d),e.exit("taskListCheckMarker"),u)}function u(d){return Nt(d)?(e.enter("taskListCheckValueUnchecked"),e.consume(d),e.exit("taskListCheckValueUnchecked"),c):d===88||d===120?(e.enter("taskListCheckValueChecked"),e.consume(d),e.exit("taskListCheckValueChecked"),c):r(d)}function c(d){return d===93?(e.enter("taskListCheckMarker"),e.consume(d),e.exit("taskListCheckMarker"),e.exit("taskListCheck"),f):r(d)}function f(d){return Pe(d)?t(d):st(d)?e.check({tokenize:fO},t,r)(d):r(d)}}function fO(e,t,r){return ct(e,s,"whitespace");function s(l){return l===null?r(l):t(l)}}function hO(e){return Wx([U3(),V3(),tO(e),sO(),uO()])}const dO={};function Bb(e){const t=this,r=e||dO,s=t.data(),l=s.micromarkExtensions||(s.micromarkExtensions=[]),u=s.fromMarkdownExtensions||(s.fromMarkdownExtensions=[]),c=s.toMarkdownExtensions||(s.toMarkdownExtensions=[]);l.push(hO(r)),u.push(M3()),c.push(D3(r))}function mO(e){v1(e,[/\r?\n|\r/g,pO])}function pO(){return{type:"break"}}function Pb(){return function(e){mO(e)}}function gO({connected:e,hostId:t,request:r,subscribeEvents:s,taskId:l,runId:u}){const c=Mr(),f=Id(),[d,m]=j.useState(!0),[y,g]=j.useState([]),[x,w]=j.useState(),[S,T]=j.useState(),z=x==="started"||x==="monitoring",D=x==="followup",H=x==="started"||x==="followup",[F,oe]=j.useState(null);dd(F!==null,()=>oe(null));const[B,L]=j.useState(!1),[W,$]=j.useState(""),[q,R]=j.useState(!1),G=j.useRef(null),J=j.useRef(null),fe=j.useRef(null),[ie,ee]=j.useState(u==="latest"?void 0:u),P=u==="latest"&&ie===null;j.useEffect(()=>{if(u!=="latest"){ee(u);return}e&&(ee(void 0),r("taskrun.list",{task_id:l,limit:1}).then(E=>{var K,A;return ee(((A=(K=E.entries)==null?void 0:K[0])==null?void 0:A.run_id)??null)}).catch(()=>ee(null)))},[u,l,e,r]);async function X(){if(ie)try{const E=await r("task.result",{id:l,run_id:ie});if(E.error){console.error("No result:",E.error),c(t?`/hosts/${encodeURIComponent(t)}`:"/",{replace:!0});return}g(E.messages??[]),w(E.running_state),T(E.agent)}catch(E){console.error("Failed to load result:",E),c(t?`/hosts/${encodeURIComponent(t)}`:"/",{replace:!0})}finally{m(!1)}}async function ae(E){var K;if(ie)try{const be=(K=(await r("task.reports",{id:l,run_id:ie,report_files:[E]})).reports)==null?void 0:K[0];be!=null&&be.data_url?oe({file:E,data_url:be.data_url}):oe({file:E,content:(be==null?void 0:be.content)??"Report not found."})}catch{oe({file:E,content:"Failed to load report."})}}j.useEffect(()=>{!e||!ie||(m(!0),X())},[e,l,ie]),j.useEffect(()=>!e||!t||!ie?void 0:s(t,async K=>{try{const A=JSON.parse(new TextDecoder().decode(K.data));if(A.event_type!=="running-state"&&A.event_type!=="result-updated"||K.subject.split(".").pop()!==l||A.event_type==="result-updated"&&A.run_id&&A.run_id!==ie)return;X()}catch{}}),[e,t,l,ie,s,r]),j.useEffect(()=>{G.current&&(G.current.scrollTop=G.current.scrollHeight)},[y]),j.useEffect(()=>{d||P||!ie||fe.current!==ie&&(fe.current=ie,requestAnimationFrame(()=>{G.current&&(G.current.scrollTop=G.current.scrollHeight),window.scrollTo({top:document.documentElement.scrollHeight,behavior:"auto"})}))},[d,P,ie]);function pe(E){if(E==="input")return"User Input";if(E==="permission")return"Permission";if(E==="confirmation")return"Confirmation"}function M(E){return E==="started"?"Task started":E==="finished"?"Task finished":E==="failed"?"Task failed":E==="error"?"Command failed":E==="aborted"?"Task aborted":E==="confirmation"?"Task confirmed":E==="stopped"?"Follow-up stopped":E??""}return b.jsxs("div",{className:"run-detail",children:[b.jsxs("button",{className:"run-detail-back",onClick:()=>c(-1),children:[b.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:b.jsx("path",{d:"M15 18l-6-6 6-6"})}),"Back"]}),P?b.jsxs("div",{className:"empty-state",children:[b.jsx("p",{className:"empty-state-text",children:"No runs yet"}),b.jsx("p",{className:"empty-state-hint",children:"This task hasn't been executed yet. Run it from the task menu or wait for its next trigger."})]}):d?b.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"var(--space-sm)",padding:"var(--space-sm) 0"},children:[b.jsx("div",{className:"skeleton-line",style:{width:"40%"}}),b.jsx("div",{className:"skeleton-line",style:{width:"55%"}}),b.jsx("div",{className:"skeleton-line",style:{width:"100%",height:"8rem",marginTop:"var(--space-sm)"}})]}):b.jsxs(b.Fragment,{children:[b.jsxs("div",{className:"chat-thread",ref:G,children:[y.map((E,K)=>{const A=H&&E.role==="assistant"&&!y.slice(K+1).some(be=>be.role==="assistant"||be.role==="user");return E.role==="status"&&E.type==="monitoring"?null:E.role==="status"?b.jsxs("div",{className:`chat-status${E.type==="error"?" chat-status--error":""}`,children:[b.jsxs("div",{children:[M(E.type),E.time>0&&b.jsx("span",{className:"chat-status-time",children:f(E.time)})]}),E.content&&b.jsx("pre",{className:"chat-status-detail",children:E.content})]},K):b.jsxs("div",{className:`chat-message chat-message--${E.role}`,children:[E.role==="assistant"&&S&&b.jsx("div",{className:"chat-message-agent",children:hd(S)}),b.jsxs("div",{className:"chat-message-content",children:[b.jsx(Nb,{remarkPlugins:[Bb,Pb],children:E.content}),A&&b.jsxs("div",{className:"chat-typing-indicator",children:[b.jsx("span",{}),b.jsx("span",{}),b.jsx("span",{})]})]}),E.attachments&&E.attachments.length>0&&b.jsx("div",{className:"chat-message-attachments",children:E.attachments.map(be=>b.jsx("button",{className:"chat-attachment-chip",onClick:()=>ae(be),children:be},be))}),b.jsxs("div",{className:"chat-message-meta",children:[pe(E.type)&&b.jsx("span",{className:"chat-message-type",children:pe(E.type)}),E.time>0&&b.jsx("span",{children:f(E.time)})]})]},K)}),H&&(()=>{const E=y.filter(K=>K.role!=="status");return E.length===0||E[E.length-1].role!=="assistant"})()&&b.jsxs("div",{className:"chat-message chat-message--assistant",children:[S&&b.jsx("div",{className:"chat-message-agent",children:hd(S)}),b.jsxs("div",{className:"chat-typing-indicator",children:[b.jsx("span",{}),b.jsx("span",{}),b.jsx("span",{})]})]}),x==="monitoring"&&b.jsxs("div",{className:"chat-monitoring-indicator",children:[b.jsx("span",{className:"chat-monitoring-dot"}),"Monitoring command output"]})]}),z?b.jsx("div",{className:"chat-abort-bar",children:b.jsx("button",{className:"btn btn-secondary chat-abort-btn",disabled:B,onClick:async()=>{if(confirm("Abort this task?")){L(!0);try{await r("task.abort",{id:l})}catch(E){console.error("Abort failed:",E)}finally{L(!1)}}},children:B?"Aborting...":"Abort Task"})}):D?b.jsx("div",{className:"chat-input-bar",children:b.jsx("button",{className:"btn btn-secondary chat-stop-btn",disabled:B,onClick:async()=>{L(!0);try{await r("task.stop_followup",{id:l,run_id:ie})}catch(E){console.error("Stop failed:",E)}finally{L(!1)}},children:b.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"currentColor",children:b.jsx("rect",{x:"6",y:"6",width:"12",height:"12",rx:"2"})})})}):b.jsxs("form",{className:"chat-input-bar",onSubmit:async E=>{E.preventDefault();const K=W.trim();if(!(!K||q)){R(!0);try{await r("task.followup",{id:l,run_id:ie,message:K}),$("")}catch(A){console.error("Follow-up failed:",A)}finally{R(!1)}}},children:[b.jsx("input",{ref:J,className:"chat-input",type:"text",placeholder:"Follow-up message",value:W,onChange:E=>$(E.target.value),disabled:q}),b.jsx("button",{className:"btn btn-primary chat-send-btn",type:"submit",disabled:!W.trim()||q,children:b.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[b.jsx("line",{x1:"22",y1:"2",x2:"11",y2:"13"}),b.jsx("polygon",{points:"22 2 15 22 11 13 2 9 22 2"})]})})]})]}),F&&b.jsx("div",{className:"report-dialog-overlay",onClick:()=>oe(null),children:b.jsxs("div",{className:"report-dialog",onClick:E=>E.stopPropagation(),children:[b.jsxs("div",{className:"report-dialog-header",children:[b.jsx("span",{className:"report-dialog-title",children:F.file}),b.jsx("button",{className:"report-dialog-close",onClick:()=>oe(null),"aria-label":"Close",children:b.jsxs("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[b.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),b.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})})]}),b.jsx("div",{className:"report-dialog-body",children:F.data_url?b.jsx("img",{src:F.data_url,alt:F.file,style:{maxWidth:"100%",height:"auto"}}):b.jsx(Nb,{remarkPlugins:[Bb,Pb],components:{a:({...E})=>b.jsx("a",{...E,target:"_blank",rel:"noopener noreferrer"})},children:F.content??""})})]})})]})}function yO(){const{activeHost:e}=si(),t=j.useRef(null);j.useEffect(()=>{if(Xn.isNativePlatform()||e.directUrl||t.current===e.hostId)return;async function r(){var s;try{if(!("serviceWorker"in navigator)||!("PushManager"in window)){console.warn("[Push] Push notifications not supported");return}const l=await navigator.serviceWorker.ready;(s=l.active)==null||s.postMessage({type:"set-host-id",hostId:e.hostId});let u=await l.pushManager.getSubscription();if(!u){const{publicKey:f}=await hE("/api/push/vapid-key");if(!f){console.warn("[Push] No VAPID public key configured on server");return}if(await Notification.requestPermission()!=="granted"){console.log("[Push] Permission denied");return}u=await l.pushManager.subscribe({userVisibleOnly:!0,applicationServerKey:f})}const c=u.toJSON();await fE("/api/push/subscribe",{hostId:e.hostId,endpoint:c.endpoint,keys:{p256dh:c.keys.p256dh,auth:c.keys.auth}}),t.current=e.hostId}catch(l){console.error("[Push] Subscription failed:",l)}}r()},[e])}const bO="0.9.6";function xO(e,t){if(e.includes("-"))return!1;const r=e.split(".").map(Number),s=t.split(".").map(Number);for(let l=0;l<3;l++){if((r[l]??0)<(s[l]??0))return!0;if((r[l]??0)>(s[l]??0))return!1}return!1}function xu(){const{removePairedHost:e,setHostLanUrl:t,setHostTimezone:r}=qi(),{connected:s,request:l,subscribeEvents:u,unauthorized:c,activeHost:f}=si(),d=f.hostId,m=f.clientToken||null,y=Mr(),g=cr(),x=$u(),w=Ux("(min-width: 768px)"),S=g.pathname.endsWith("/tasks"),T=x.runId?void 0:x.taskId,z=!!(x.taskId&&x.runId),[D,H]=j.useState(!1),[F,oe]=j.useState(!1),[B,L]=j.useState(null),[W,$]=j.useState(null),[q,R]=j.useState(null),[G,J]=j.useState(new Set),[fe,ie]=j.useState([]),[ee,P]=j.useState(),X=!!m&&q===m,[ae,pe]=j.useState(new Map),[M,E]=j.useState(new Map),[K,A]=j.useState(new Map),[be,je]=j.useState(new Map);yO(),j.useEffect(()=>{window.scrollTo(0,0)},[d]),j.useEffect(()=>{let ze=!1;return UE().then(Ae=>{ze||J(Ae)}),()=>{ze=!0}},[]),j.useEffect(()=>{s&&l("host.info").then(ze=>{var We,Fe,et,ft,ht,Wt;ie(ze.agents??[]),P(ze.host_platform),R(ze.linked_client_token??null),xE(ze.agents??[]);const Ae=ze.version??null;$(Ae),H(!!Ae&&xO(Ae,bO)),t(d,ze.lan_url??void 0),r(d,ze.host_timezone);const Le=new Map,nt=new Map,Ve=new Map,Je=new Map;for(const $e of ze.pending_prompts??[])if($e.type==="confirmation")Le.set($e.key,{description:((We=$e.meta)==null?void 0:We.description)??"",sessionName:(Fe=$e.meta)==null?void 0:Fe.session_name});else if($e.type==="permission")nt.set($e.key,{permissions:$e.params??[],sessionName:(et=$e.meta)==null?void 0:et.session_name});else if($e.type==="input"){const yn=$e.params??((ft=$e.meta)==null?void 0:ft.input_questions)??[];Ve.set($e.key,{questions:yn,description:(ht=$e.meta)==null?void 0:ht.description,sessionName:(Wt=$e.meta)==null?void 0:Wt.session_name}),Je.set($e.key,new Array(yn.length).fill(""))}pe(Le),E(nt),A(Ve),je(Je)}).catch(()=>{})},[s,d,l,t,r]),j.useEffect(()=>s?u(d,Ae=>{const Le=Ae.subject.split(".");if(Le.length<3)return;const nt=Le.slice(2).join(".");let Ve={};try{Ve=JSON.parse(new TextDecoder().decode(Ae.data))}catch{return}const Je=Ve.event_type,We=Ve.session_id;if(Je==="input-request"&&We){const Fe=Ve.input_questions,et=Ve.session_name,ft=Ve.description;Fe!=null&&Fe.length&&(A(ht=>{if(ht.has(We))return ht;const Wt=new Map(ht);return Wt.set(We,{questions:Fe,description:ft,sessionName:et}),Wt}),je(ht=>{if(ht.has(We))return ht;const Wt=new Map(ht);return Wt.set(We,new Array(Fe.length).fill("")),Wt}));return}if(Je==="input-resolved"&&We){A(Fe=>{if(!Fe.has(We))return Fe;const et=new Map(Fe);return et.delete(We),et}),je(Fe=>{const et=new Map(Fe);return et.delete(We),et});return}if(Je==="confirm-request"&&We){const Fe=Ve.description,et=Ve.session_name;Fe&&pe(ft=>{if(ft.has(We))return ft;const ht=new Map(ft);return ht.set(We,{description:Fe,sessionName:et}),ht});return}if(Je==="confirm-resolved"&&We){pe(Fe=>{if(!Fe.has(We))return Fe;const et=new Map(Fe);return et.delete(We),et});return}if(Je==="permission-request"){const Fe=Ve.required_permissions,et=Ve.session_name;Fe!=null&&Fe.length&&E(ft=>{if(ft.has(nt))return ft;const ht=new Map(ft);return ht.set(nt,{permissions:Fe,sessionName:et}),ht});return}if(Je==="permission-resolved"){E(Fe=>{if(!Fe.has(nt))return Fe;const et=new Map(Fe);return et.delete(nt),et});return}}):void 0,[s,d,u]);async function _e(ze,Ae){try{await l("task.user_input",{id:ze,value:[Ae]})}catch(Le){console.error("[Dashboard] Failed to respond to confirmation:",Le)}}async function Me(ze,Ae){try{await l("task.user_input",{id:ze,value:[Ae]})}catch(Le){console.error("[Dashboard] Failed to respond to permission request:",Le)}}async function Ie(ze,Ae){try{await l("task.user_input",{id:ze,value:Ae})}catch(Le){console.error("[Dashboard] Failed to respond to input request:",Le)}}function ke(ze,Ae){if(!ps())return;const Le=`/hosts/${encodeURIComponent(d)}/runs/${encodeURIComponent(ze)}`;y(Ae?`${Le}/${encodeURIComponent(Ae)}`:Le)}async function Ge(){oe(!0),L(null);try{const ze=await l("host.update");if(ze.error){L(ze.error),oe(!1);return}}catch{}setTimeout(()=>window.location.reload(),15e3)}const Ft=s&&!c;return b.jsxs("div",{className:"dashboard",children:[w&&b.jsx($0,{daemonVersion:W,linkedClientToken:q,request:l,onEnabledCapabilitiesChange:J,onLinkedClientTokenChange:R}),b.jsxs("div",{className:"dashboard-content",children:[b.jsxs("header",{className:"app-header",children:[b.jsxs("div",{className:"app-title-bar",children:[!w&&b.jsx($0,{daemonVersion:W,linkedClientToken:q,request:l,onEnabledCapabilitiesChange:J,onLinkedClientTokenChange:R}),b.jsx("h1",{className:"app-title",children:"Palmier"}),b.jsx(IE,{})]}),b.jsx("div",{className:"tab-bar",children:b.jsx(DE,{})})]}),b.jsx("main",{className:"dashboard-main",children:c?b.jsxs("div",{className:"revoked-state",children:[b.jsx("div",{className:"revoked-icon",children:b.jsxs("svg",{width:"32",height:"32",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round",children:[b.jsx("rect",{x:"3",y:"11",width:"18",height:"11",rx:"2",ry:"2"}),b.jsx("path",{d:"M7 11V7a5 5 0 0 1 10 0v4"}),b.jsx("line",{x1:"12",y1:"15",x2:"12",y2:"18"})]})}),b.jsx("h2",{className:"revoked-title",children:"Client Revoked"}),b.jsx("p",{className:"revoked-description",children:"This client was revoked by the host. To reconnect, generate a new pairing code on the host machine."}),b.jsx("div",{className:"revoked-command",children:b.jsx("code",{children:"palmier pair"})}),b.jsxs("div",{className:"revoked-actions",children:[b.jsx("button",{className:"btn btn-primary",onClick:()=>{ps()&&y("/pair")},children:"Re-pair Device"}),b.jsx("button",{className:"btn btn-secondary",onClick:()=>{e(d),y("/",{replace:!0})},children:"Remove Host"})]})]}):Ft?b.jsxs(b.Fragment,{children:[S&&!z&&b.jsx(ME,{connected:s,hostId:d,request:l,subscribeEvents:u,agents:fe,hostPlatform:ee,isNotificationListener:X&&G.has("notifications"),onViewRun:ke}),z?b.jsx(gO,{connected:s,hostId:d,request:l,subscribeEvents:u,taskId:x.taskId,runId:decodeURIComponent(x.runId)}):S?null:b.jsx(GE,{connected:s,hostId:d,request:l,subscribeEvents:u,agents:fe,hostPlatform:ee,filterTaskId:T,onClearFilter:()=>{ps()&&y(`/hosts/${encodeURIComponent(d)}`)}})]}):b.jsx("div",{className:"empty-state",children:b.jsx("p",{children:"Connecting to host..."})})}),D&&!F&&!B&&b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:"Update Required"}),b.jsxs("p",{className:"confirm-modal-message",children:["Your Palmier host",W?` (v${W})`:""," is too old for this version of the app. Please update to continue."]}),b.jsx("div",{className:"confirm-modal-actions",children:b.jsx("button",{className:"btn btn-primary",onClick:Ge,children:"Update Now"})})]})}),F&&b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:"Updating..."}),b.jsx("p",{className:"confirm-modal-message",children:"Installing update and restarting daemon. Please wait..."})]})}),B&&b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:"Update Failed"}),b.jsx("p",{className:"confirm-modal-message",style:{whiteSpace:"pre-line"},children:B}),b.jsx("div",{className:"confirm-modal-actions",children:b.jsx("button",{className:"btn btn-secondary",onClick:()=>{L(null)},children:"Retry"})})]})})]}),ds.createPortal(b.jsxs(b.Fragment,{children:[[...ae.entries()].map(([ze,{description:Ae,sessionName:Le}])=>b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:"Confirmation Required"}),Le&&b.jsx("p",{className:"confirm-modal-subtitle",children:Le}),b.jsx("p",{className:"confirm-modal-message",children:Ae}),b.jsxs("div",{className:"confirm-modal-actions",children:[b.jsx("button",{className:"btn btn-primary",onClick:()=>_e(ze,"confirmed"),children:"Confirm"}),b.jsx("button",{className:"btn btn-secondary",onClick:()=>_e(ze,"aborted"),children:"Abort"})]})]})},ze)),[...M.entries()].map(([ze,{permissions:Ae,sessionName:Le}])=>b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal permission-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:"Permission Required"}),b.jsx("p",{className:"confirm-modal-message",children:b.jsx("strong",{children:Le||ze})}),b.jsx("div",{className:"permission-list",children:Ae.map((nt,Ve)=>b.jsxs("div",{className:"permission-item",children:[b.jsx("span",{className:"permission-name",children:nt.name}),nt.description&&b.jsx("span",{className:"permission-desc",children:nt.description})]},Ve))}),b.jsxs("div",{className:"permission-actions",children:[b.jsx("button",{className:"btn btn-primary",onClick:()=>Me(ze,"granted"),children:"Allow Once"}),b.jsx("button",{className:"btn btn-secondary",onClick:()=>Me(ze,"granted_all"),children:"Allow Always"})]}),b.jsx("button",{className:"permission-abort-link",onClick:()=>Me(ze,"aborted"),children:"Deny & Abort Task"})]})},ze)),[...K.entries()].map(([ze,{questions:Ae,description:Le,sessionName:nt}])=>{const Ve=be.get(ze)??new Array(Ae.length).fill("");return b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal input-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:"Input Required"}),nt&&b.jsx("p",{className:"confirm-modal-subtitle",children:nt}),Le&&b.jsx("p",{className:"confirm-modal-message",children:Le}),b.jsx("div",{className:"input-list",children:Ae.map((Je,We)=>b.jsxs("div",{className:"input-item",children:[b.jsx("label",{className:"input-label",children:Je}),b.jsx("input",{type:"text",className:"input-field",value:Ve[We]??"",onChange:Fe=>{je(et=>{const ft=new Map(et),ht=[...ft.get(ze)??[]];return ht[We]=Fe.target.value,ft.set(ze,ht),ft})},autoFocus:We===0})]},We))}),b.jsx("div",{className:"input-actions",children:b.jsx("button",{className:"btn btn-primary",disabled:Ve.some(Je=>!Je.trim()),onClick:()=>Ie(ze,Ve),children:"Submit"})}),b.jsx("button",{className:"permission-abort-link",onClick:()=>Ie(ze,["aborted"]),children:"Cancel"})]})},ze)})]}),document.body)]})}const vO=ys("Preferences",{web:()=>qd(()=>import("./web-DL4uXOpS.js"),[]).then(e=>new e.PreferencesWeb)}),kl=!!window.__PALMIER_SERVE__&&(window.location.hostname==="localhost"||window.location.hostname==="127.0.0.1"),Hb=Xn.isNativePlatform();function wO(){const[e,t]=j.useState(""),[r,s]=j.useState(!0),[l,u]=j.useState(!1),[c,f]=j.useState(null),{addPairedHost:d}=qi(),m=Mr();async function y(){const g=e.trim().toUpperCase();if(!g){f("Enter a pairing code.");return}u(!0),f(null);try{let x;if(kl){const T=await fetch("/pair",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({code:g,label:navigator.userAgent})});if(!T.ok){const z=await T.json().catch(()=>({error:"Connection failed"}));throw new Error(z.error||`HTTP ${T.status}`)}x=await T.json()}else{const T=await fetch(`${Uu}/api/config`);if(!T.ok)throw new Error("Failed to fetch server config");const z=await T.json();if(!z.natsWsUrl)throw new Error("Server has no NATS WebSocket URL configured");const D=await Nx({servers:z.natsWsUrl,authenticator:wx(z.natsJwt,new TextEncoder().encode(z.natsNkeySeed))}),H=Nu(),F=`pair.${g}`,oe=await D.request(F,H.encode(JSON.stringify({label:navigator.userAgent})),{timeout:1e4});x=JSON.parse(H.decode(oe.data)),await D.close()}const w={hostId:x.hostId,clientToken:x.clientToken,directUrl:kl?window.location.origin:void 0,...x.hostName?{name:x.hostName}:{}};if(d(w),Xn.isNativePlatform()&&mn){await vO.set({key:"hostId",value:x.hostId});try{const{token:T}=await mn.getFcmToken();await fetch(`${Uu}/api/fcm/register`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({hostId:x.hostId,fcmToken:T})})}catch(T){console.warn("FCM token registration failed:",T)}}const S=`/hosts/${encodeURIComponent(x.hostId)}`;m(Hb&&r?`${S}/pair/setup`:S)}catch(x){const w=x instanceof Error?x.message:String(x);w.includes("timeout")||w.includes("TIMEOUT")||w.includes("503")||w.toLowerCase().includes("no responders")?f("Code not found or expired. Check the code and try again."):f(w)}finally{u(!1)}}return b.jsx("div",{className:"pair-page",children:b.jsxs("div",{className:"pair-card",children:[b.jsxs("div",{className:"pair-header",children:[b.jsx("h1",{className:"pair-title",children:kl?"Pair":"Pair with Host"}),b.jsx("p",{className:"pair-subtitle",children:kl?"Enter the pairing code shown in your terminal.":"Connect this device to a Palmier host"})]}),!kl&&b.jsxs("div",{className:"pair-instructions",children:[b.jsxs("div",{className:"pair-instruction-block",children:[b.jsx("h3",{className:"pair-instruction-heading",children:"Setting up a new host?"}),b.jsxs("ol",{className:"pair-steps",children:[b.jsxs("li",{children:["Install at least one agent CLI (e.g., ",b.jsx("a",{href:"https://www.palmier.me/agents",target:"_blank",rel:"noopener noreferrer",children:"Claude Code, Gemini CLI, Codex CLI"}),")"]}),b.jsxs("li",{children:["Install Palmier on your host machine.",b.jsx("span",{className:"pair-platform-label",children:"Linux / macOS:"}),b.jsx("code",{className:"pair-command",children:"curl -fsSL https://palmier.me/install.sh | bash"}),b.jsx("span",{className:"pair-platform-label",children:"Windows (PowerShell):"}),b.jsx("code",{className:"pair-command",children:"irm https://palmier.me/install.ps1 | iex"})]}),b.jsxs("li",{children:["Run the setup wizard:",b.jsx("code",{className:"pair-command",children:"palmier init"})]}),b.jsx("li",{children:"A pairing code will display automatically"})]})]}),b.jsx("div",{className:"pair-instruction-divider"}),b.jsxs("div",{className:"pair-instruction-block",children:[b.jsx("h3",{className:"pair-instruction-heading",children:"Pairing an existing host?"}),b.jsxs("ol",{className:"pair-steps",children:[b.jsxs("li",{children:["Run ",b.jsx("code",{children:"palmier pair"})," on the host machine"]}),b.jsx("li",{children:"Enter the 6-character code below"})]})]})]}),b.jsxs("div",{className:"pair-form",children:[b.jsxs("label",{className:"form-label",htmlFor:"pair-code",children:["Pairing code",b.jsx("input",{id:"pair-code",type:"text",maxLength:6,value:e,onChange:g=>t(g.target.value.toUpperCase()),placeholder:"A7K9M2",className:"form-input form-input-mono pair-code-input",autoFocus:!0,autoComplete:"off",disabled:l})]}),Hb&&b.jsxs("label",{className:"pair-checkbox",children:[b.jsx("input",{type:"checkbox",checked:r,onChange:g=>s(g.target.checked),disabled:l}),b.jsxs("span",{className:"pair-checkbox-text",children:[b.jsx("span",{className:"pair-checkbox-title",children:"Link the host to this device"}),b.jsx("span",{className:"pair-checkbox-hint",children:r?"The host will use this device for SMS, contacts, calendar, location, and alarms. Only one device can be linked to the host.":"This device won't provide SMS, contacts, calendar, location, or alarms to the host. You can link it later from the menu."})]})]}),c&&b.jsx("p",{className:"pair-error",children:c}),b.jsxs("button",{className:"btn btn-primary btn-full",onClick:y,disabled:l||!e.trim(),children:[l&&b.jsx("span",{className:"btn-spinner"}),l?"Pairing...":"Pair"]}),b.jsx("button",{className:"btn btn-secondary btn-full",onClick:()=>m("/"),disabled:l,children:"Cancel"}),b.jsxs("p",{className:"pair-consent",children:["By pairing, you agree to our"," ",b.jsx("a",{href:"https://www.palmier.me/terms",target:"_blank",rel:"noopener noreferrer",children:"Terms of Service"})," and"," ",b.jsx("a",{href:"https://www.palmier.me/privacy",target:"_blank",rel:"noopener noreferrer",children:"Privacy Policy"}),"."]})]})]})})}function SO(){const e=Mr(),{connected:t,request:r,activeHost:s}=si(),{setHostLanUrl:l,pairedHosts:u}=qi(),c=u.length<=1,[f,d]=j.useState("loading"),[m,y]=j.useState(null),[g,x]=j.useState(null);function w(){e(`/hosts/${encodeURIComponent(s.hostId)}`,{replace:!0})}j.useEffect(()=>{if(!t||f!=="loading")return;let H=!1;return r("host.info").catch(()=>({})).then(F=>{if(H)return;l(s.hostId,F.lan_url??void 0);const oe=F.linked_client_token??null;y(oe);const B=!!oe&&oe!==s.clientToken;d(B?"confirming":"linking")}),()=>{H=!0}},[t,f,s,r,l]),j.useEffect(()=>{if(f!=="linking")return;let H=!1;return(async()=>{try{if(mn){const{token:F}=await mn.getFcmToken();if(!F)throw new Error("Could not read FCM token");await r("device.link",{fcmToken:F})}if(H)return;c?d("wizard"):w()}catch(F){if(H)return;x(F instanceof Error?F.message:String(F)),d("linkError")}})(),()=>{H=!0}},[f]);function S(){d("linking")}function T(){w()}function z(){x(null),d("linking")}const D=f==="confirming"&&ds.createPortal(b.jsx("div",{className:"confirm-modal-overlay",onClick:T,children:b.jsxs("div",{className:"confirm-modal",onClick:H=>H.stopPropagation(),children:[b.jsx("h2",{className:"confirm-modal-title",children:"Link the host to this device?"}),b.jsx("p",{className:"confirm-modal-message",children:"Another device is already linked to this host. Only one device can be linked to the host — switching will disable those capabilities on the currently linked device."}),b.jsxs("div",{className:"confirm-modal-actions",children:[b.jsx("button",{className:"btn btn-secondary",onClick:T,children:"Cancel"}),b.jsx("button",{className:"btn btn-primary",onClick:S,children:"Link"})]})]})}),document.body);if(f==="loading"||f==="confirming"||f==="linking"||f==="linkError"){const H=c,F=f==="loading"||f==="confirming"||f==="linking";return b.jsxs("div",{className:"pair-setup",children:[b.jsxs("div",{className:"pair-setup-inner",children:[H&&b.jsx("h1",{className:"pair-setup-title",children:"Device Capabilities"}),b.jsxs("div",{className:"pair-setup-loading",children:[F&&b.jsx("span",{className:"spinner spinner-lg"}),f==="loading"&&b.jsx("span",{children:"Connecting to host…"}),f==="confirming"&&b.jsx("span",{children:"Awaiting confirmation…"}),f==="linking"&&b.jsx("span",{children:"Linking device…"}),f==="linkError"&&b.jsxs(b.Fragment,{children:[b.jsx("p",{className:"pair-error",children:g}),b.jsx("button",{className:"btn btn-primary",onClick:z,children:"Retry"}),b.jsx("button",{className:"btn btn-secondary",onClick:w,children:"Skip linking"})]})]})]}),D]})}return b.jsx("div",{className:"pair-setup",children:b.jsxs("div",{className:"pair-setup-inner",children:[b.jsx("h1",{className:"pair-setup-title",children:"Device Capabilities"}),b.jsx("p",{className:"pair-setup-description",children:"Choose what the host can use this device for. You can change these later from the menu."}),b.jsx(Bx,{}),b.jsx("div",{className:"pair-setup-actions",children:b.jsx("button",{className:"btn btn-primary btn-full",onClick:w,children:"Finish"})})]})})}function _O(){const e=Mr();return j.useEffect(()=>{if(!mn)return;const t=mn.addListener("deepLink",({path:r})=>e(r));return()=>{t.then(r=>r.remove())}},[e]),null}function kO(){const{pairedHosts:e}=qi();return e.length===0?b.jsx(Ll,{to:"/pair",replace:!0}):b.jsx(Ll,{to:`/hosts/${encodeURIComponent(e[0].hostId)}`,replace:!0})}function EO(){const{hostId:e}=$u(),{pairedHosts:t}=qi(),r=t.find(s=>s.hostId===e)??null;return r?b.jsx(gE,{activeHost:r,children:b.jsxs(nx,{children:[b.jsx(br,{index:!0,element:b.jsx(xu,{})}),b.jsx(br,{path:"tasks",element:b.jsx(xu,{})}),b.jsx(br,{path:"runs/:taskId",element:b.jsx(xu,{})}),b.jsx(br,{path:"runs/:taskId/:runId",element:b.jsx(xu,{})}),b.jsx(br,{path:"pair/setup",element:b.jsx(SO,{})}),b.jsx(br,{path:"*",element:b.jsx(Ll,{to:".",replace:!0})})]})}):b.jsx(Ll,{to:"/",replace:!0})}function CO(){return b.jsxs(H_,{children:[b.jsx(_O,{}),b.jsxs(nx,{children:[b.jsx(br,{path:"/",element:b.jsx(kO,{})}),b.jsx(br,{path:"/pair",element:b.jsx(wO,{})}),b.jsx(br,{path:"/hosts/:hostId/*",element:b.jsx(EO,{})}),b.jsx(br,{path:"*",element:b.jsx(Ll,{to:"/",replace:!0})})]})]})}lS.createRoot(document.getElementById("root")).render(b.jsx(j.StrictMode,{children:b.jsx(A_,{children:b.jsx(CO,{})})}));export{Hd as W};
|
|
120
|
+
`))}function d(w,S,T,z){const D=T.enter("tableCell"),H=T.enter("phrasing"),F=T.containerPhrasing(w,{...z,before:u,after:u});return H(),D(),F}function m(w,S){return IN(w,{align:S,alignDelimiters:s,padding:r,stringLength:l})}function y(w,S,T){const z=w.children;let D=-1;const H=[],F=S.enter("table");for(;++D<z.length;)H[D]=g(z[D],S,T);return F(),H}function g(w,S,T){const z=w.children;let D=-1;const H=[],F=S.enter("tableRow");for(;++D<z.length;)H[D]=d(z[D],w,S,T);return F(),H}function x(w,S,T){let z=L1.inlineCode(w,S,T);return T.stack.includes("tableCell")&&(z=z.replace(/\|/g,"\\$&")),z}}function T3(){return{exit:{taskListCheckValueChecked:zb,taskListCheckValueUnchecked:zb,paragraph:O3}}}function N3(){return{unsafe:[{atBreak:!0,character:"-",after:"[:|-]"}],handlers:{listItem:R3}}}function zb(e){const t=this.stack[this.stack.length-2];t.type,t.checked=e.type==="taskListCheckValueChecked"}function O3(e){const t=this.stack[this.stack.length-2];if(t&&t.type==="listItem"&&typeof t.checked=="boolean"){const r=this.stack[this.stack.length-1];r.type;const s=r.children[0];if(s&&s.type==="text"){const l=t.children;let u=-1,c;for(;++u<l.length;){const f=l[u];if(f.type==="paragraph"){c=f;break}}c===r&&(s.value=s.value.slice(1),s.value.length===0?r.children.shift():r.position&&s.position&&typeof s.position.start.offset=="number"&&(s.position.start.column++,s.position.start.offset++,r.position.start=Object.assign({},s.position.start)))}}this.exit(e)}function R3(e,t,r,s){const l=e.children[0],u=typeof e.checked=="boolean"&&l&&l.type==="paragraph",c="["+(e.checked?"x":" ")+"] ",f=r.createTracker(s);u&&f.move(c);let d=L1.listItem(e,t,r,{...s,...f.current()});return u&&(d=d.replace(/^(?:[*+-]|\d+\.)([\r\n]| {1,3})/,m)),d;function m(y){return y+c}}function M3(){return[fN(),RN(),zN(),S3(),T3()]}function D3(e){return{extensions:[hN(),MN(e),UN(),j3(e),N3()]}}const L3={tokenize:q3,partial:!0},z1={tokenize:I3,partial:!0},U1={tokenize:F3,partial:!0},B1={tokenize:$3,partial:!0},z3={tokenize:Y3,partial:!0},P1={name:"wwwAutolink",tokenize:P3,previous:q1},H1={name:"protocolAutolink",tokenize:H3,previous:I1},ai={name:"emailAutolink",tokenize:B3,previous:F1},Dr={};function U3(){return{text:Dr}}let hs=48;for(;hs<123;)Dr[hs]=ai,hs++,hs===58?hs=65:hs===91&&(hs=97);Dr[43]=ai;Dr[45]=ai;Dr[46]=ai;Dr[95]=ai;Dr[72]=[ai,H1];Dr[104]=[ai,H1];Dr[87]=[ai,P1];Dr[119]=[ai,P1];function B3(e,t,r){const s=this;let l,u;return c;function c(g){return!kd(g)||!F1.call(s,s.previous)||lm(s.events)?r(g):(e.enter("literalAutolink"),e.enter("literalAutolinkEmail"),f(g))}function f(g){return kd(g)?(e.consume(g),f):g===64?(e.consume(g),d):r(g)}function d(g){return g===46?e.check(z3,y,m)(g):g===45||g===95||pn(g)?(u=!0,e.consume(g),d):y(g)}function m(g){return e.consume(g),l=!0,d}function y(g){return u&&l&&kn(s.previous)?(e.exit("literalAutolinkEmail"),e.exit("literalAutolink"),t(g)):r(g)}}function P3(e,t,r){const s=this;return l;function l(c){return c!==87&&c!==119||!q1.call(s,s.previous)||lm(s.events)?r(c):(e.enter("literalAutolink"),e.enter("literalAutolinkWww"),e.check(L3,e.attempt(z1,e.attempt(U1,u),r),r)(c))}function u(c){return e.exit("literalAutolinkWww"),e.exit("literalAutolink"),t(c)}}function H3(e,t,r){const s=this;let l="",u=!1;return c;function c(g){return(g===72||g===104)&&I1.call(s,s.previous)&&!lm(s.events)?(e.enter("literalAutolink"),e.enter("literalAutolinkHttp"),l+=String.fromCodePoint(g),e.consume(g),f):r(g)}function f(g){if(kn(g)&&l.length<5)return l+=String.fromCodePoint(g),e.consume(g),f;if(g===58){const x=l.toLowerCase();if(x==="http"||x==="https")return e.consume(g),d}return r(g)}function d(g){return g===47?(e.consume(g),u?m:(u=!0,d)):r(g)}function m(g){return g===null||Bu(g)||Nt(g)||gs(g)||Qu(g)?r(g):e.attempt(z1,e.attempt(U1,y),r)(g)}function y(g){return e.exit("literalAutolinkHttp"),e.exit("literalAutolink"),t(g)}}function q3(e,t,r){let s=0;return l;function l(c){return(c===87||c===119)&&s<3?(s++,e.consume(c),l):c===46&&s===3?(e.consume(c),u):r(c)}function u(c){return c===null?r(c):t(c)}}function I3(e,t,r){let s,l,u;return c;function c(m){return m===46||m===95?e.check(B1,d,f)(m):m===null||Nt(m)||gs(m)||m!==45&&Qu(m)?d(m):(u=!0,e.consume(m),c)}function f(m){return m===95?s=!0:(l=s,s=void 0),e.consume(m),c}function d(m){return l||s||!u?r(m):t(m)}}function F3(e,t){let r=0,s=0;return l;function l(c){return c===40?(r++,e.consume(c),l):c===41&&s<r?u(c):c===33||c===34||c===38||c===39||c===41||c===42||c===44||c===46||c===58||c===59||c===60||c===63||c===93||c===95||c===126?e.check(B1,t,u)(c):c===null||Nt(c)||gs(c)?t(c):(e.consume(c),l)}function u(c){return c===41&&s++,e.consume(c),l}}function $3(e,t,r){return s;function s(f){return f===33||f===34||f===39||f===41||f===42||f===44||f===46||f===58||f===59||f===63||f===95||f===126?(e.consume(f),s):f===38?(e.consume(f),u):f===93?(e.consume(f),l):f===60||f===null||Nt(f)||gs(f)?t(f):r(f)}function l(f){return f===null||f===40||f===91||Nt(f)||gs(f)?t(f):s(f)}function u(f){return kn(f)?c(f):r(f)}function c(f){return f===59?(e.consume(f),s):kn(f)?(e.consume(f),c):r(f)}}function Y3(e,t,r){return s;function s(u){return e.consume(u),l}function l(u){return pn(u)?r(u):t(u)}}function q1(e){return e===null||e===40||e===42||e===95||e===91||e===93||e===126||Nt(e)}function I1(e){return!kn(e)}function F1(e){return!(e===47||kd(e))}function kd(e){return e===43||e===45||e===46||e===95||pn(e)}function lm(e){let t=e.length,r=!1;for(;t--;){const s=e[t][1];if((s.type==="labelLink"||s.type==="labelImage")&&!s._balanced){r=!0;break}if(s._gfmAutolinkLiteralWalkedInto){r=!1;break}}return e.length>0&&!r&&(e[e.length-1][1]._gfmAutolinkLiteralWalkedInto=!0),r}const G3={tokenize:eO,partial:!0};function V3(){return{document:{91:{name:"gfmFootnoteDefinition",tokenize:Q3,continuation:{tokenize:Z3},exit:W3}},text:{91:{name:"gfmFootnoteCall",tokenize:K3},93:{name:"gfmPotentialFootnoteCall",add:"after",tokenize:J3,resolveTo:X3}}}}function J3(e,t,r){const s=this;let l=s.events.length;const u=s.parser.gfmFootnotes||(s.parser.gfmFootnotes=[]);let c;for(;l--;){const d=s.events[l][1];if(d.type==="labelImage"){c=d;break}if(d.type==="gfmFootnoteCall"||d.type==="labelLink"||d.type==="label"||d.type==="image"||d.type==="link")break}return f;function f(d){if(!c||!c._balanced)return r(d);const m=wr(s.sliceSerialize({start:c.end,end:s.now()}));return m.codePointAt(0)!==94||!u.includes(m.slice(1))?r(d):(e.enter("gfmFootnoteCallLabelMarker"),e.consume(d),e.exit("gfmFootnoteCallLabelMarker"),t(d))}}function X3(e,t){let r=e.length;for(;r--;)if(e[r][1].type==="labelImage"&&e[r][0]==="enter"){e[r][1];break}e[r+1][1].type="data",e[r+3][1].type="gfmFootnoteCallLabelMarker";const s={type:"gfmFootnoteCall",start:Object.assign({},e[r+3][1].start),end:Object.assign({},e[e.length-1][1].end)},l={type:"gfmFootnoteCallMarker",start:Object.assign({},e[r+3][1].end),end:Object.assign({},e[r+3][1].end)};l.end.column++,l.end.offset++,l.end._bufferIndex++;const u={type:"gfmFootnoteCallString",start:Object.assign({},l.end),end:Object.assign({},e[e.length-1][1].start)},c={type:"chunkString",contentType:"string",start:Object.assign({},u.start),end:Object.assign({},u.end)},f=[e[r+1],e[r+2],["enter",s,t],e[r+3],e[r+4],["enter",l,t],["exit",l,t],["enter",u,t],["enter",c,t],["exit",c,t],["exit",u,t],e[e.length-2],e[e.length-1],["exit",s,t]];return e.splice(r,e.length-r+1,...f),e}function K3(e,t,r){const s=this,l=s.parser.gfmFootnotes||(s.parser.gfmFootnotes=[]);let u=0,c;return f;function f(g){return e.enter("gfmFootnoteCall"),e.enter("gfmFootnoteCallLabelMarker"),e.consume(g),e.exit("gfmFootnoteCallLabelMarker"),d}function d(g){return g!==94?r(g):(e.enter("gfmFootnoteCallMarker"),e.consume(g),e.exit("gfmFootnoteCallMarker"),e.enter("gfmFootnoteCallString"),e.enter("chunkString").contentType="string",m)}function m(g){if(u>999||g===93&&!c||g===null||g===91||Nt(g))return r(g);if(g===93){e.exit("chunkString");const x=e.exit("gfmFootnoteCallString");return l.includes(wr(s.sliceSerialize(x)))?(e.enter("gfmFootnoteCallLabelMarker"),e.consume(g),e.exit("gfmFootnoteCallLabelMarker"),e.exit("gfmFootnoteCall"),t):r(g)}return Nt(g)||(c=!0),u++,e.consume(g),g===92?y:m}function y(g){return g===91||g===92||g===93?(e.consume(g),u++,m):m(g)}}function Q3(e,t,r){const s=this,l=s.parser.gfmFootnotes||(s.parser.gfmFootnotes=[]);let u,c=0,f;return d;function d(S){return e.enter("gfmFootnoteDefinition")._container=!0,e.enter("gfmFootnoteDefinitionLabel"),e.enter("gfmFootnoteDefinitionLabelMarker"),e.consume(S),e.exit("gfmFootnoteDefinitionLabelMarker"),m}function m(S){return S===94?(e.enter("gfmFootnoteDefinitionMarker"),e.consume(S),e.exit("gfmFootnoteDefinitionMarker"),e.enter("gfmFootnoteDefinitionLabelString"),e.enter("chunkString").contentType="string",y):r(S)}function y(S){if(c>999||S===93&&!f||S===null||S===91||Nt(S))return r(S);if(S===93){e.exit("chunkString");const T=e.exit("gfmFootnoteDefinitionLabelString");return u=wr(s.sliceSerialize(T)),e.enter("gfmFootnoteDefinitionLabelMarker"),e.consume(S),e.exit("gfmFootnoteDefinitionLabelMarker"),e.exit("gfmFootnoteDefinitionLabel"),x}return Nt(S)||(f=!0),c++,e.consume(S),S===92?g:y}function g(S){return S===91||S===92||S===93?(e.consume(S),c++,y):y(S)}function x(S){return S===58?(e.enter("definitionMarker"),e.consume(S),e.exit("definitionMarker"),l.includes(u)||l.push(u),ct(e,w,"gfmFootnoteDefinitionWhitespace")):r(S)}function w(S){return t(S)}}function Z3(e,t,r){return e.check(Vl,t,e.attempt(G3,t,r))}function W3(e){e.exit("gfmFootnoteDefinition")}function eO(e,t,r){const s=this;return ct(e,l,"gfmFootnoteDefinitionIndent",5);function l(u){const c=s.events[s.events.length-1];return c&&c[1].type==="gfmFootnoteDefinitionIndent"&&c[2].sliceSerialize(c[1],!0).length===4?t(u):r(u)}}function tO(e){let r=(e||{}).singleTilde;const s={name:"strikethrough",tokenize:u,resolveAll:l};return r==null&&(r=!0),{text:{126:s},insideSpan:{null:[s]},attentionMarkers:{null:[126]}};function l(c,f){let d=-1;for(;++d<c.length;)if(c[d][0]==="enter"&&c[d][1].type==="strikethroughSequenceTemporary"&&c[d][1]._close){let m=d;for(;m--;)if(c[m][0]==="exit"&&c[m][1].type==="strikethroughSequenceTemporary"&&c[m][1]._open&&c[d][1].end.offset-c[d][1].start.offset===c[m][1].end.offset-c[m][1].start.offset){c[d][1].type="strikethroughSequence",c[m][1].type="strikethroughSequence";const y={type:"strikethrough",start:Object.assign({},c[m][1].start),end:Object.assign({},c[d][1].end)},g={type:"strikethroughText",start:Object.assign({},c[m][1].end),end:Object.assign({},c[d][1].start)},x=[["enter",y,f],["enter",c[m][1],f],["exit",c[m][1],f],["enter",g,f]],w=f.parser.constructs.insideSpan.null;w&&Vn(x,x.length,0,Zu(w,c.slice(m+1,d),f)),Vn(x,x.length,0,[["exit",g,f],["enter",c[d][1],f],["exit",c[d][1],f],["exit",y,f]]),Vn(c,m-1,d-m+3,x),d=m+x.length-2;break}}for(d=-1;++d<c.length;)c[d][1].type==="strikethroughSequenceTemporary"&&(c[d][1].type="data");return c}function u(c,f,d){const m=this.previous,y=this.events;let g=0;return x;function x(S){return m===126&&y[y.length-1][1].type!=="characterEscape"?d(S):(c.enter("strikethroughSequenceTemporary"),w(S))}function w(S){const T=ba(m);if(S===126)return g>1?d(S):(c.consume(S),g++,w);if(g<2&&!r)return d(S);const z=c.exit("strikethroughSequenceTemporary"),D=ba(S);return z._open=!D||D===2&&!!T,z._close=!T||T===2&&!!D,f(S)}}}class nO{constructor(){this.map=[]}add(t,r,s){rO(this,t,r,s)}consume(t){if(this.map.sort(function(u,c){return u[0]-c[0]}),this.map.length===0)return;let r=this.map.length;const s=[];for(;r>0;)r-=1,s.push(t.slice(this.map[r][0]+this.map[r][1]),this.map[r][2]),t.length=this.map[r][0];s.push(t.slice()),t.length=0;let l=s.pop();for(;l;){for(const u of l)t.push(u);l=s.pop()}this.map.length=0}}function rO(e,t,r,s){let l=0;if(!(r===0&&s.length===0)){for(;l<e.map.length;){if(e.map[l][0]===t){e.map[l][1]+=r,e.map[l][2].push(...s);return}l+=1}e.map.push([t,r,s])}}function iO(e,t){let r=!1;const s=[];for(;t<e.length;){const l=e[t];if(r){if(l[0]==="enter")l[1].type==="tableContent"&&s.push(e[t+1][1].type==="tableDelimiterMarker"?"left":"none");else if(l[1].type==="tableContent"){if(e[t-1][1].type==="tableDelimiterMarker"){const u=s.length-1;s[u]=s[u]==="left"?"center":"right"}}else if(l[1].type==="tableDelimiterRow")break}else l[0]==="enter"&&l[1].type==="tableDelimiterRow"&&(r=!0);t+=1}return s}function sO(){return{flow:{null:{name:"table",tokenize:aO,resolveAll:lO}}}}function aO(e,t,r){const s=this;let l=0,u=0,c;return f;function f(R){let G=s.events.length-1;for(;G>-1;){const ie=s.events[G][1].type;if(ie==="lineEnding"||ie==="linePrefix")G--;else break}const J=G>-1?s.events[G][1].type:null,fe=J==="tableHead"||J==="tableRow"?L:d;return fe===L&&s.parser.lazy[s.now().line]?r(R):fe(R)}function d(R){return e.enter("tableHead"),e.enter("tableRow"),m(R)}function m(R){return R===124||(c=!0,u+=1),y(R)}function y(R){return R===null?r(R):Pe(R)?u>1?(u=0,s.interrupt=!0,e.exit("tableRow"),e.enter("lineEnding"),e.consume(R),e.exit("lineEnding"),w):r(R):st(R)?ct(e,y,"whitespace")(R):(u+=1,c&&(c=!1,l+=1),R===124?(e.enter("tableCellDivider"),e.consume(R),e.exit("tableCellDivider"),c=!0,y):(e.enter("data"),g(R)))}function g(R){return R===null||R===124||Nt(R)?(e.exit("data"),y(R)):(e.consume(R),R===92?x:g)}function x(R){return R===92||R===124?(e.consume(R),g):g(R)}function w(R){return s.interrupt=!1,s.parser.lazy[s.now().line]?r(R):(e.enter("tableDelimiterRow"),c=!1,st(R)?ct(e,S,"linePrefix",s.parser.constructs.disable.null.includes("codeIndented")?void 0:4)(R):S(R))}function S(R){return R===45||R===58?z(R):R===124?(c=!0,e.enter("tableCellDivider"),e.consume(R),e.exit("tableCellDivider"),T):B(R)}function T(R){return st(R)?ct(e,z,"whitespace")(R):z(R)}function z(R){return R===58?(u+=1,c=!0,e.enter("tableDelimiterMarker"),e.consume(R),e.exit("tableDelimiterMarker"),D):R===45?(u+=1,D(R)):R===null||Pe(R)?oe(R):B(R)}function D(R){return R===45?(e.enter("tableDelimiterFiller"),H(R)):B(R)}function H(R){return R===45?(e.consume(R),H):R===58?(c=!0,e.exit("tableDelimiterFiller"),e.enter("tableDelimiterMarker"),e.consume(R),e.exit("tableDelimiterMarker"),F):(e.exit("tableDelimiterFiller"),F(R))}function F(R){return st(R)?ct(e,oe,"whitespace")(R):oe(R)}function oe(R){return R===124?S(R):R===null||Pe(R)?!c||l!==u?B(R):(e.exit("tableDelimiterRow"),e.exit("tableHead"),t(R)):B(R)}function B(R){return r(R)}function L(R){return e.enter("tableRow"),W(R)}function W(R){return R===124?(e.enter("tableCellDivider"),e.consume(R),e.exit("tableCellDivider"),W):R===null||Pe(R)?(e.exit("tableRow"),t(R)):st(R)?ct(e,W,"whitespace")(R):(e.enter("data"),$(R))}function $(R){return R===null||R===124||Nt(R)?(e.exit("data"),W(R)):(e.consume(R),R===92?q:$)}function q(R){return R===92||R===124?(e.consume(R),$):$(R)}}function lO(e,t){let r=-1,s=!0,l=0,u=[0,0,0,0],c=[0,0,0,0],f=!1,d=0,m,y,g;const x=new nO;for(;++r<e.length;){const w=e[r],S=w[1];w[0]==="enter"?S.type==="tableHead"?(f=!1,d!==0&&(Ub(x,t,d,m,y),y=void 0,d=0),m={type:"table",start:Object.assign({},S.start),end:Object.assign({},S.end)},x.add(r,0,[["enter",m,t]])):S.type==="tableRow"||S.type==="tableDelimiterRow"?(s=!0,g=void 0,u=[0,0,0,0],c=[0,r+1,0,0],f&&(f=!1,y={type:"tableBody",start:Object.assign({},S.start),end:Object.assign({},S.end)},x.add(r,0,[["enter",y,t]])),l=S.type==="tableDelimiterRow"?2:y?3:1):l&&(S.type==="data"||S.type==="tableDelimiterMarker"||S.type==="tableDelimiterFiller")?(s=!1,c[2]===0&&(u[1]!==0&&(c[0]=c[1],g=bu(x,t,u,l,void 0,g),u=[0,0,0,0]),c[2]=r)):S.type==="tableCellDivider"&&(s?s=!1:(u[1]!==0&&(c[0]=c[1],g=bu(x,t,u,l,void 0,g)),u=c,c=[u[1],r,0,0])):S.type==="tableHead"?(f=!0,d=r):S.type==="tableRow"||S.type==="tableDelimiterRow"?(d=r,u[1]!==0?(c[0]=c[1],g=bu(x,t,u,l,r,g)):c[1]!==0&&(g=bu(x,t,c,l,r,g)),l=0):l&&(S.type==="data"||S.type==="tableDelimiterMarker"||S.type==="tableDelimiterFiller")&&(c[3]=r)}for(d!==0&&Ub(x,t,d,m,y),x.consume(t.events),r=-1;++r<t.events.length;){const w=t.events[r];w[0]==="enter"&&w[1].type==="table"&&(w[1]._align=iO(t.events,r))}return e}function bu(e,t,r,s,l,u){const c=s===1?"tableHeader":s===2?"tableDelimiter":"tableData",f="tableContent";r[0]!==0&&(u.end=Object.assign({},ia(t.events,r[0])),e.add(r[0],0,[["exit",u,t]]));const d=ia(t.events,r[1]);if(u={type:c,start:Object.assign({},d),end:Object.assign({},d)},e.add(r[1],0,[["enter",u,t]]),r[2]!==0){const m=ia(t.events,r[2]),y=ia(t.events,r[3]),g={type:f,start:Object.assign({},m),end:Object.assign({},y)};if(e.add(r[2],0,[["enter",g,t]]),s!==2){const x=t.events[r[2]],w=t.events[r[3]];if(x[1].end=Object.assign({},w[1].end),x[1].type="chunkText",x[1].contentType="text",r[3]>r[2]+1){const S=r[2]+1,T=r[3]-r[2]-1;e.add(S,T,[])}}e.add(r[3]+1,0,[["exit",g,t]])}return l!==void 0&&(u.end=Object.assign({},ia(t.events,l)),e.add(l,0,[["exit",u,t]]),u=void 0),u}function Ub(e,t,r,s,l){const u=[],c=ia(t.events,r);l&&(l.end=Object.assign({},c),u.push(["exit",l,t])),s.end=Object.assign({},c),u.push(["exit",s,t]),e.add(r+1,0,u)}function ia(e,t){const r=e[t],s=r[0]==="enter"?"start":"end";return r[1][s]}const oO={name:"tasklistCheck",tokenize:cO};function uO(){return{text:{91:oO}}}function cO(e,t,r){const s=this;return l;function l(d){return s.previous!==null||!s._gfmTasklistFirstContentOfListItem?r(d):(e.enter("taskListCheck"),e.enter("taskListCheckMarker"),e.consume(d),e.exit("taskListCheckMarker"),u)}function u(d){return Nt(d)?(e.enter("taskListCheckValueUnchecked"),e.consume(d),e.exit("taskListCheckValueUnchecked"),c):d===88||d===120?(e.enter("taskListCheckValueChecked"),e.consume(d),e.exit("taskListCheckValueChecked"),c):r(d)}function c(d){return d===93?(e.enter("taskListCheckMarker"),e.consume(d),e.exit("taskListCheckMarker"),e.exit("taskListCheck"),f):r(d)}function f(d){return Pe(d)?t(d):st(d)?e.check({tokenize:fO},t,r)(d):r(d)}}function fO(e,t,r){return ct(e,s,"whitespace");function s(l){return l===null?r(l):t(l)}}function hO(e){return Wx([U3(),V3(),tO(e),sO(),uO()])}const dO={};function Bb(e){const t=this,r=e||dO,s=t.data(),l=s.micromarkExtensions||(s.micromarkExtensions=[]),u=s.fromMarkdownExtensions||(s.fromMarkdownExtensions=[]),c=s.toMarkdownExtensions||(s.toMarkdownExtensions=[]);l.push(hO(r)),u.push(M3()),c.push(D3(r))}function mO(e){v1(e,[/\r?\n|\r/g,pO])}function pO(){return{type:"break"}}function Pb(){return function(e){mO(e)}}function gO({connected:e,hostId:t,request:r,subscribeEvents:s,taskId:l,runId:u}){const c=Mr(),f=Id(),[d,m]=j.useState(!0),[y,g]=j.useState([]),[x,w]=j.useState(),[S,T]=j.useState(),z=x==="started"||x==="monitoring",D=x==="followup",H=x==="started"||x==="followup",[F,oe]=j.useState(null);dd(F!==null,()=>oe(null));const[B,L]=j.useState(!1),[W,$]=j.useState(""),[q,R]=j.useState(!1),G=j.useRef(null),J=j.useRef(null),fe=j.useRef(null),[ie,ee]=j.useState(u==="latest"?void 0:u),P=u==="latest"&&ie===null;j.useEffect(()=>{if(u!=="latest"){ee(u);return}e&&(ee(void 0),r("taskrun.list",{task_id:l,limit:1}).then(E=>{var K,A;return ee(((A=(K=E.entries)==null?void 0:K[0])==null?void 0:A.run_id)??null)}).catch(()=>ee(null)))},[u,l,e,r]);async function X(){if(ie)try{const E=await r("task.result",{id:l,run_id:ie});if(E.error){console.error("No result:",E.error),c(t?`/hosts/${encodeURIComponent(t)}`:"/",{replace:!0});return}g(E.messages??[]),w(E.running_state),T(E.agent)}catch(E){console.error("Failed to load result:",E),c(t?`/hosts/${encodeURIComponent(t)}`:"/",{replace:!0})}finally{m(!1)}}async function ae(E){var K;if(ie)try{const be=(K=(await r("task.reports",{id:l,run_id:ie,report_files:[E]})).reports)==null?void 0:K[0];be!=null&&be.data_url?oe({file:E,data_url:be.data_url}):oe({file:E,content:(be==null?void 0:be.content)??"Report not found."})}catch{oe({file:E,content:"Failed to load report."})}}j.useEffect(()=>{!e||!ie||(m(!0),X())},[e,l,ie]),j.useEffect(()=>!e||!t||!ie?void 0:s(t,async K=>{try{const A=JSON.parse(new TextDecoder().decode(K.data));if(A.event_type!=="running-state"&&A.event_type!=="result-updated"||K.subject.split(".").pop()!==l||A.event_type==="result-updated"&&A.run_id&&A.run_id!==ie)return;X()}catch{}}),[e,t,l,ie,s,r]),j.useEffect(()=>{G.current&&(G.current.scrollTop=G.current.scrollHeight)},[y]),j.useEffect(()=>{d||P||!ie||fe.current!==ie&&(fe.current=ie,requestAnimationFrame(()=>{G.current&&(G.current.scrollTop=G.current.scrollHeight),window.scrollTo({top:document.documentElement.scrollHeight,behavior:"auto"})}))},[d,P,ie]);function pe(E){if(E==="input")return"User Input";if(E==="permission")return"Permission";if(E==="confirmation")return"Confirmation"}function M(E){return E==="started"?"Task started":E==="finished"?"Task finished":E==="failed"?"Task failed":E==="error"?"Command failed":E==="aborted"?"Task aborted":E==="confirmation"?"Task confirmed":E==="stopped"?"Follow-up stopped":E??""}return b.jsxs("div",{className:"run-detail",children:[b.jsxs("button",{className:"run-detail-back",onClick:()=>c(-1),children:[b.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:b.jsx("path",{d:"M15 18l-6-6 6-6"})}),"Back"]}),P?b.jsxs("div",{className:"empty-state",children:[b.jsx("p",{className:"empty-state-text",children:"No runs yet"}),b.jsx("p",{className:"empty-state-hint",children:"This task hasn't been executed yet. Run it from the task menu or wait for its next trigger."})]}):d?b.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"var(--space-sm)",padding:"var(--space-sm) 0"},children:[b.jsx("div",{className:"skeleton-line",style:{width:"40%"}}),b.jsx("div",{className:"skeleton-line",style:{width:"55%"}}),b.jsx("div",{className:"skeleton-line",style:{width:"100%",height:"8rem",marginTop:"var(--space-sm)"}})]}):b.jsxs(b.Fragment,{children:[b.jsxs("div",{className:"chat-thread",ref:G,children:[y.map((E,K)=>{const A=H&&E.role==="assistant"&&!y.slice(K+1).some(be=>be.role==="assistant"||be.role==="user");return E.role==="status"&&E.type==="monitoring"?null:E.role==="status"?b.jsxs("div",{className:`chat-status${E.type==="error"?" chat-status--error":""}`,children:[b.jsxs("div",{children:[M(E.type),E.time>0&&b.jsx("span",{className:"chat-status-time",children:f(E.time)})]}),E.content&&b.jsx("pre",{className:"chat-status-detail",children:E.content})]},K):b.jsxs("div",{className:`chat-message chat-message--${E.role}`,children:[E.role==="assistant"&&S&&b.jsx("div",{className:"chat-message-agent",children:hd(S)}),b.jsxs("div",{className:"chat-message-content",children:[b.jsx(Nb,{remarkPlugins:[Bb,Pb],children:E.content}),A&&b.jsxs("div",{className:"chat-typing-indicator",children:[b.jsx("span",{}),b.jsx("span",{}),b.jsx("span",{})]})]}),E.attachments&&E.attachments.length>0&&b.jsx("div",{className:"chat-message-attachments",children:E.attachments.map(be=>b.jsx("button",{className:"chat-attachment-chip",onClick:()=>ae(be),children:be},be))}),b.jsxs("div",{className:"chat-message-meta",children:[pe(E.type)&&b.jsx("span",{className:"chat-message-type",children:pe(E.type)}),E.time>0&&b.jsx("span",{children:f(E.time)})]})]},K)}),H&&(()=>{const E=y.filter(K=>K.role!=="status");return E.length===0||E[E.length-1].role!=="assistant"})()&&b.jsxs("div",{className:"chat-message chat-message--assistant",children:[S&&b.jsx("div",{className:"chat-message-agent",children:hd(S)}),b.jsxs("div",{className:"chat-typing-indicator",children:[b.jsx("span",{}),b.jsx("span",{}),b.jsx("span",{})]})]}),x==="monitoring"&&b.jsxs("div",{className:"chat-monitoring-indicator",children:[b.jsx("span",{className:"chat-monitoring-dot"}),"Monitoring command output"]})]}),z?b.jsx("div",{className:"chat-abort-bar",children:b.jsx("button",{className:"btn btn-secondary chat-abort-btn",disabled:B,onClick:async()=>{if(confirm("Abort this task?")){L(!0);try{await r("task.abort",{id:l})}catch(E){console.error("Abort failed:",E)}finally{L(!1)}}},children:B?"Aborting...":"Abort Task"})}):D?b.jsx("div",{className:"chat-input-bar",children:b.jsx("button",{className:"btn btn-secondary chat-stop-btn",disabled:B,onClick:async()=>{L(!0);try{await r("task.stop_followup",{id:l,run_id:ie})}catch(E){console.error("Stop failed:",E)}finally{L(!1)}},children:b.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"currentColor",children:b.jsx("rect",{x:"6",y:"6",width:"12",height:"12",rx:"2"})})})}):b.jsxs("form",{className:"chat-input-bar",onSubmit:async E=>{E.preventDefault();const K=W.trim();if(!(!K||q)){R(!0);try{await r("task.followup",{id:l,run_id:ie,message:K}),$("")}catch(A){console.error("Follow-up failed:",A)}finally{R(!1)}}},children:[b.jsx("input",{ref:J,className:"chat-input",type:"text",placeholder:"Follow-up message",value:W,onChange:E=>$(E.target.value),disabled:q}),b.jsx("button",{className:"btn btn-primary chat-send-btn",type:"submit",disabled:!W.trim()||q,children:b.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[b.jsx("line",{x1:"22",y1:"2",x2:"11",y2:"13"}),b.jsx("polygon",{points:"22 2 15 22 11 13 2 9 22 2"})]})})]})]}),F&&b.jsx("div",{className:"report-dialog-overlay",onClick:()=>oe(null),children:b.jsxs("div",{className:"report-dialog",onClick:E=>E.stopPropagation(),children:[b.jsxs("div",{className:"report-dialog-header",children:[b.jsx("span",{className:"report-dialog-title",children:F.file}),b.jsx("button",{className:"report-dialog-close",onClick:()=>oe(null),"aria-label":"Close",children:b.jsxs("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[b.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),b.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})})]}),b.jsx("div",{className:"report-dialog-body",children:F.data_url?b.jsx("img",{src:F.data_url,alt:F.file,style:{maxWidth:"100%",height:"auto"}}):b.jsx(Nb,{remarkPlugins:[Bb,Pb],components:{a:({...E})=>b.jsx("a",{...E,target:"_blank",rel:"noopener noreferrer"})},children:F.content??""})})]})})]})}function yO(){const{activeHost:e}=si(),t=j.useRef(null);j.useEffect(()=>{if(Xn.isNativePlatform()||e.directUrl||t.current===e.hostId)return;async function r(){var s;try{if(!("serviceWorker"in navigator)||!("PushManager"in window)){console.warn("[Push] Push notifications not supported");return}const l=await navigator.serviceWorker.ready;(s=l.active)==null||s.postMessage({type:"set-host-id",hostId:e.hostId});let u=await l.pushManager.getSubscription();if(!u){const{publicKey:f}=await hE("/api/push/vapid-key");if(!f){console.warn("[Push] No VAPID public key configured on server");return}if(await Notification.requestPermission()!=="granted"){console.log("[Push] Permission denied");return}u=await l.pushManager.subscribe({userVisibleOnly:!0,applicationServerKey:f})}const c=u.toJSON();await fE("/api/push/subscribe",{hostId:e.hostId,endpoint:c.endpoint,keys:{p256dh:c.keys.p256dh,auth:c.keys.auth}}),t.current=e.hostId}catch(l){console.error("[Push] Subscription failed:",l)}}r()},[e])}const bO="0.9.8";function xO(e,t){if(e.includes("-"))return!1;const r=e.split(".").map(Number),s=t.split(".").map(Number);for(let l=0;l<3;l++){if((r[l]??0)<(s[l]??0))return!0;if((r[l]??0)>(s[l]??0))return!1}return!1}function xu(){const{removePairedHost:e,setHostLanUrl:t,setHostTimezone:r}=qi(),{connected:s,request:l,subscribeEvents:u,unauthorized:c,activeHost:f}=si(),d=f.hostId,m=f.clientToken||null,y=Mr(),g=cr(),x=$u(),w=Ux("(min-width: 768px)"),S=g.pathname.endsWith("/tasks"),T=x.runId?void 0:x.taskId,z=!!(x.taskId&&x.runId),[D,H]=j.useState(!1),[F,oe]=j.useState(!1),[B,L]=j.useState(null),[W,$]=j.useState(null),[q,R]=j.useState(null),[G,J]=j.useState(new Set),[fe,ie]=j.useState([]),[ee,P]=j.useState(),X=!!m&&q===m,[ae,pe]=j.useState(new Map),[M,E]=j.useState(new Map),[K,A]=j.useState(new Map),[be,je]=j.useState(new Map);yO(),j.useEffect(()=>{window.scrollTo(0,0)},[d]),j.useEffect(()=>{let ze=!1;return UE().then(Ae=>{ze||J(Ae)}),()=>{ze=!0}},[]),j.useEffect(()=>{s&&l("host.info").then(ze=>{var We,Fe,et,ft,ht,Wt;ie(ze.agents??[]),P(ze.host_platform),R(ze.linked_client_token??null),xE(ze.agents??[]);const Ae=ze.version??null;$(Ae),H(!!Ae&&xO(Ae,bO)),t(d,ze.lan_url??void 0),r(d,ze.host_timezone);const Le=new Map,nt=new Map,Ve=new Map,Je=new Map;for(const $e of ze.pending_prompts??[])if($e.type==="confirmation")Le.set($e.key,{description:((We=$e.meta)==null?void 0:We.description)??"",sessionName:(Fe=$e.meta)==null?void 0:Fe.session_name});else if($e.type==="permission")nt.set($e.key,{permissions:$e.params??[],sessionName:(et=$e.meta)==null?void 0:et.session_name});else if($e.type==="input"){const yn=$e.params??((ft=$e.meta)==null?void 0:ft.input_questions)??[];Ve.set($e.key,{questions:yn,description:(ht=$e.meta)==null?void 0:ht.description,sessionName:(Wt=$e.meta)==null?void 0:Wt.session_name}),Je.set($e.key,new Array(yn.length).fill(""))}pe(Le),E(nt),A(Ve),je(Je)}).catch(()=>{})},[s,d,l,t,r]),j.useEffect(()=>s?u(d,Ae=>{const Le=Ae.subject.split(".");if(Le.length<3)return;const nt=Le.slice(2).join(".");let Ve={};try{Ve=JSON.parse(new TextDecoder().decode(Ae.data))}catch{return}const Je=Ve.event_type,We=Ve.session_id;if(Je==="input-request"&&We){const Fe=Ve.input_questions,et=Ve.session_name,ft=Ve.description;Fe!=null&&Fe.length&&(A(ht=>{if(ht.has(We))return ht;const Wt=new Map(ht);return Wt.set(We,{questions:Fe,description:ft,sessionName:et}),Wt}),je(ht=>{if(ht.has(We))return ht;const Wt=new Map(ht);return Wt.set(We,new Array(Fe.length).fill("")),Wt}));return}if(Je==="input-resolved"&&We){A(Fe=>{if(!Fe.has(We))return Fe;const et=new Map(Fe);return et.delete(We),et}),je(Fe=>{const et=new Map(Fe);return et.delete(We),et});return}if(Je==="confirm-request"&&We){const Fe=Ve.description,et=Ve.session_name;Fe&&pe(ft=>{if(ft.has(We))return ft;const ht=new Map(ft);return ht.set(We,{description:Fe,sessionName:et}),ht});return}if(Je==="confirm-resolved"&&We){pe(Fe=>{if(!Fe.has(We))return Fe;const et=new Map(Fe);return et.delete(We),et});return}if(Je==="permission-request"){const Fe=Ve.required_permissions,et=Ve.session_name;Fe!=null&&Fe.length&&E(ft=>{if(ft.has(nt))return ft;const ht=new Map(ft);return ht.set(nt,{permissions:Fe,sessionName:et}),ht});return}if(Je==="permission-resolved"){E(Fe=>{if(!Fe.has(nt))return Fe;const et=new Map(Fe);return et.delete(nt),et});return}}):void 0,[s,d,u]);async function _e(ze,Ae){try{await l("task.user_input",{id:ze,value:[Ae]})}catch(Le){console.error("[Dashboard] Failed to respond to confirmation:",Le)}}async function Me(ze,Ae){try{await l("task.user_input",{id:ze,value:[Ae]})}catch(Le){console.error("[Dashboard] Failed to respond to permission request:",Le)}}async function Ie(ze,Ae){try{await l("task.user_input",{id:ze,value:Ae})}catch(Le){console.error("[Dashboard] Failed to respond to input request:",Le)}}function ke(ze,Ae){if(!ps())return;const Le=`/hosts/${encodeURIComponent(d)}/runs/${encodeURIComponent(ze)}`;y(Ae?`${Le}/${encodeURIComponent(Ae)}`:Le)}async function Ge(){oe(!0),L(null);try{const ze=await l("host.update");if(ze.error){L(ze.error),oe(!1);return}}catch{}setTimeout(()=>window.location.reload(),15e3)}const Ft=s&&!c;return b.jsxs("div",{className:"dashboard",children:[w&&b.jsx($0,{daemonVersion:W,linkedClientToken:q,request:l,onEnabledCapabilitiesChange:J,onLinkedClientTokenChange:R}),b.jsxs("div",{className:"dashboard-content",children:[b.jsxs("header",{className:"app-header",children:[b.jsxs("div",{className:"app-title-bar",children:[!w&&b.jsx($0,{daemonVersion:W,linkedClientToken:q,request:l,onEnabledCapabilitiesChange:J,onLinkedClientTokenChange:R}),b.jsx("h1",{className:"app-title",children:"Palmier"}),b.jsx(IE,{})]}),b.jsx("div",{className:"tab-bar",children:b.jsx(DE,{})})]}),b.jsx("main",{className:"dashboard-main",children:c?b.jsxs("div",{className:"revoked-state",children:[b.jsx("div",{className:"revoked-icon",children:b.jsxs("svg",{width:"32",height:"32",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round",children:[b.jsx("rect",{x:"3",y:"11",width:"18",height:"11",rx:"2",ry:"2"}),b.jsx("path",{d:"M7 11V7a5 5 0 0 1 10 0v4"}),b.jsx("line",{x1:"12",y1:"15",x2:"12",y2:"18"})]})}),b.jsx("h2",{className:"revoked-title",children:"Client Revoked"}),b.jsx("p",{className:"revoked-description",children:"This client was revoked by the host. To reconnect, generate a new pairing code on the host machine."}),b.jsx("div",{className:"revoked-command",children:b.jsx("code",{children:"palmier pair"})}),b.jsxs("div",{className:"revoked-actions",children:[b.jsx("button",{className:"btn btn-primary",onClick:()=>{ps()&&y("/pair")},children:"Re-pair Device"}),b.jsx("button",{className:"btn btn-secondary",onClick:()=>{e(d),y("/",{replace:!0})},children:"Remove Host"})]})]}):Ft?b.jsxs(b.Fragment,{children:[S&&!z&&b.jsx(ME,{connected:s,hostId:d,request:l,subscribeEvents:u,agents:fe,hostPlatform:ee,isNotificationListener:X&&G.has("notifications"),onViewRun:ke}),z?b.jsx(gO,{connected:s,hostId:d,request:l,subscribeEvents:u,taskId:x.taskId,runId:decodeURIComponent(x.runId)}):S?null:b.jsx(GE,{connected:s,hostId:d,request:l,subscribeEvents:u,agents:fe,hostPlatform:ee,filterTaskId:T,onClearFilter:()=>{ps()&&y(`/hosts/${encodeURIComponent(d)}`)}})]}):b.jsx("div",{className:"empty-state",children:b.jsx("p",{children:"Connecting to host..."})})}),D&&!F&&!B&&b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:"Update Required"}),b.jsxs("p",{className:"confirm-modal-message",children:["Your Palmier host",W?` (v${W})`:""," is too old for this version of the app. Please update to continue."]}),b.jsx("div",{className:"confirm-modal-actions",children:b.jsx("button",{className:"btn btn-primary",onClick:Ge,children:"Update Now"})})]})}),F&&b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:"Updating..."}),b.jsx("p",{className:"confirm-modal-message",children:"Installing update and restarting daemon. Please wait..."})]})}),B&&b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:"Update Failed"}),b.jsx("p",{className:"confirm-modal-message",style:{whiteSpace:"pre-line"},children:B}),b.jsx("div",{className:"confirm-modal-actions",children:b.jsx("button",{className:"btn btn-secondary",onClick:()=>{L(null)},children:"Retry"})})]})})]}),ds.createPortal(b.jsxs(b.Fragment,{children:[[...ae.entries()].map(([ze,{description:Ae,sessionName:Le}])=>b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:"Confirmation Required"}),Le&&b.jsx("p",{className:"confirm-modal-subtitle",children:Le}),b.jsx("p",{className:"confirm-modal-message",children:Ae}),b.jsxs("div",{className:"confirm-modal-actions",children:[b.jsx("button",{className:"btn btn-primary",onClick:()=>_e(ze,"confirmed"),children:"Confirm"}),b.jsx("button",{className:"btn btn-secondary",onClick:()=>_e(ze,"aborted"),children:"Abort"})]})]})},ze)),[...M.entries()].map(([ze,{permissions:Ae,sessionName:Le}])=>b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal permission-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:"Permission Required"}),b.jsx("p",{className:"confirm-modal-message",children:b.jsx("strong",{children:Le||ze})}),b.jsx("div",{className:"permission-list",children:Ae.map((nt,Ve)=>b.jsxs("div",{className:"permission-item",children:[b.jsx("span",{className:"permission-name",children:nt.name}),nt.description&&b.jsx("span",{className:"permission-desc",children:nt.description})]},Ve))}),b.jsxs("div",{className:"permission-actions",children:[b.jsx("button",{className:"btn btn-primary",onClick:()=>Me(ze,"granted"),children:"Allow Once"}),b.jsx("button",{className:"btn btn-secondary",onClick:()=>Me(ze,"granted_all"),children:"Allow Always"})]}),b.jsx("button",{className:"permission-abort-link",onClick:()=>Me(ze,"aborted"),children:"Deny & Abort Task"})]})},ze)),[...K.entries()].map(([ze,{questions:Ae,description:Le,sessionName:nt}])=>{const Ve=be.get(ze)??new Array(Ae.length).fill("");return b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal input-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:"Input Required"}),nt&&b.jsx("p",{className:"confirm-modal-subtitle",children:nt}),Le&&b.jsx("p",{className:"confirm-modal-message",children:Le}),b.jsx("div",{className:"input-list",children:Ae.map((Je,We)=>b.jsxs("div",{className:"input-item",children:[b.jsx("label",{className:"input-label",children:Je}),b.jsx("input",{type:"text",className:"input-field",value:Ve[We]??"",onChange:Fe=>{je(et=>{const ft=new Map(et),ht=[...ft.get(ze)??[]];return ht[We]=Fe.target.value,ft.set(ze,ht),ft})},autoFocus:We===0})]},We))}),b.jsx("div",{className:"input-actions",children:b.jsx("button",{className:"btn btn-primary",disabled:Ve.some(Je=>!Je.trim()),onClick:()=>Ie(ze,Ve),children:"Submit"})}),b.jsx("button",{className:"permission-abort-link",onClick:()=>Ie(ze,["aborted"]),children:"Cancel"})]})},ze)})]}),document.body)]})}const vO=ys("Preferences",{web:()=>qd(()=>import("./web-DAcCX19l.js"),[]).then(e=>new e.PreferencesWeb)}),kl=!!window.__PALMIER_SERVE__&&(window.location.hostname==="localhost"||window.location.hostname==="127.0.0.1"),Hb=Xn.isNativePlatform();function wO(){const[e,t]=j.useState(""),[r,s]=j.useState(!0),[l,u]=j.useState(!1),[c,f]=j.useState(null),{addPairedHost:d}=qi(),m=Mr();async function y(){const g=e.trim().toUpperCase();if(!g){f("Enter a pairing code.");return}u(!0),f(null);try{let x;if(kl){const T=await fetch("/pair",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({code:g,label:navigator.userAgent})});if(!T.ok){const z=await T.json().catch(()=>({error:"Connection failed"}));throw new Error(z.error||`HTTP ${T.status}`)}x=await T.json()}else{const T=await fetch(`${Uu}/api/config`);if(!T.ok)throw new Error("Failed to fetch server config");const z=await T.json();if(!z.natsWsUrl)throw new Error("Server has no NATS WebSocket URL configured");const D=await Nx({servers:z.natsWsUrl,authenticator:wx(z.natsJwt,new TextEncoder().encode(z.natsNkeySeed))}),H=Nu(),F=`pair.${g}`,oe=await D.request(F,H.encode(JSON.stringify({label:navigator.userAgent})),{timeout:1e4});x=JSON.parse(H.decode(oe.data)),await D.close()}const w={hostId:x.hostId,clientToken:x.clientToken,directUrl:kl?window.location.origin:void 0,...x.hostName?{name:x.hostName}:{}};if(d(w),Xn.isNativePlatform()&&mn){await vO.set({key:"hostId",value:x.hostId});try{const{token:T}=await mn.getFcmToken();await fetch(`${Uu}/api/fcm/register`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({hostId:x.hostId,fcmToken:T})})}catch(T){console.warn("FCM token registration failed:",T)}}const S=`/hosts/${encodeURIComponent(x.hostId)}`;m(Hb&&r?`${S}/pair/setup`:S)}catch(x){const w=x instanceof Error?x.message:String(x);w.includes("timeout")||w.includes("TIMEOUT")||w.includes("503")||w.toLowerCase().includes("no responders")?f("Code not found or expired. Check the code and try again."):f(w)}finally{u(!1)}}return b.jsx("div",{className:"pair-page",children:b.jsxs("div",{className:"pair-card",children:[b.jsxs("div",{className:"pair-header",children:[b.jsx("h1",{className:"pair-title",children:kl?"Pair":"Pair with Host"}),b.jsx("p",{className:"pair-subtitle",children:kl?"Enter the pairing code shown in your terminal.":"Connect this device to a Palmier host"})]}),!kl&&b.jsxs("div",{className:"pair-instructions",children:[b.jsxs("div",{className:"pair-instruction-block",children:[b.jsx("h3",{className:"pair-instruction-heading",children:"Setting up a new host?"}),b.jsxs("ol",{className:"pair-steps",children:[b.jsxs("li",{children:["Install at least one agent CLI (e.g., ",b.jsx("a",{href:"https://www.palmier.me/agents",target:"_blank",rel:"noopener noreferrer",children:"Claude Code, Gemini CLI, Codex CLI"}),")"]}),b.jsxs("li",{children:["Install Palmier on your host machine.",b.jsx("span",{className:"pair-platform-label",children:"Linux / macOS:"}),b.jsx("code",{className:"pair-command",children:"curl -fsSL https://palmier.me/install.sh | bash"}),b.jsx("span",{className:"pair-platform-label",children:"Windows (PowerShell):"}),b.jsx("code",{className:"pair-command",children:"irm https://palmier.me/install.ps1 | iex"})]}),b.jsxs("li",{children:["Run the setup wizard:",b.jsx("code",{className:"pair-command",children:"palmier init"})]}),b.jsx("li",{children:"A pairing code will display automatically"})]})]}),b.jsx("div",{className:"pair-instruction-divider"}),b.jsxs("div",{className:"pair-instruction-block",children:[b.jsx("h3",{className:"pair-instruction-heading",children:"Pairing an existing host?"}),b.jsxs("ol",{className:"pair-steps",children:[b.jsxs("li",{children:["Run ",b.jsx("code",{children:"palmier pair"})," on the host machine"]}),b.jsx("li",{children:"Enter the 6-character code below"})]})]})]}),b.jsxs("div",{className:"pair-form",children:[b.jsxs("label",{className:"form-label",htmlFor:"pair-code",children:["Pairing code",b.jsx("input",{id:"pair-code",type:"text",maxLength:6,value:e,onChange:g=>t(g.target.value.toUpperCase()),placeholder:"A7K9M2",className:"form-input form-input-mono pair-code-input",autoFocus:!0,autoComplete:"off",disabled:l})]}),Hb&&b.jsxs("label",{className:"pair-checkbox",children:[b.jsx("input",{type:"checkbox",checked:r,onChange:g=>s(g.target.checked),disabled:l}),b.jsxs("span",{className:"pair-checkbox-text",children:[b.jsx("span",{className:"pair-checkbox-title",children:"Link the host to this device"}),b.jsx("span",{className:"pair-checkbox-hint",children:r?"The host will use this device for SMS, contacts, calendar, location, and alarms. Only one device can be linked to the host.":"This device won't provide SMS, contacts, calendar, location, or alarms to the host. You can link it later from the menu."})]})]}),c&&b.jsx("p",{className:"pair-error",children:c}),b.jsxs("button",{className:"btn btn-primary btn-full",onClick:y,disabled:l||!e.trim(),children:[l&&b.jsx("span",{className:"btn-spinner"}),l?"Pairing...":"Pair"]}),b.jsx("button",{className:"btn btn-secondary btn-full",onClick:()=>m("/"),disabled:l,children:"Cancel"}),b.jsxs("p",{className:"pair-consent",children:["By pairing, you agree to our"," ",b.jsx("a",{href:"https://www.palmier.me/terms",target:"_blank",rel:"noopener noreferrer",children:"Terms of Service"})," and"," ",b.jsx("a",{href:"https://www.palmier.me/privacy",target:"_blank",rel:"noopener noreferrer",children:"Privacy Policy"}),"."]})]})]})})}function SO(){const e=Mr(),{connected:t,request:r,activeHost:s}=si(),{setHostLanUrl:l,pairedHosts:u}=qi(),c=u.length<=1,[f,d]=j.useState("loading"),[m,y]=j.useState(null),[g,x]=j.useState(null);function w(){e(`/hosts/${encodeURIComponent(s.hostId)}`,{replace:!0})}j.useEffect(()=>{if(!t||f!=="loading")return;let H=!1;return r("host.info").catch(()=>({})).then(F=>{if(H)return;l(s.hostId,F.lan_url??void 0);const oe=F.linked_client_token??null;y(oe);const B=!!oe&&oe!==s.clientToken;d(B?"confirming":"linking")}),()=>{H=!0}},[t,f,s,r,l]),j.useEffect(()=>{if(f!=="linking")return;let H=!1;return(async()=>{try{if(mn){const{token:F}=await mn.getFcmToken();if(!F)throw new Error("Could not read FCM token");await r("device.link",{fcmToken:F})}if(H)return;c?d("wizard"):w()}catch(F){if(H)return;x(F instanceof Error?F.message:String(F)),d("linkError")}})(),()=>{H=!0}},[f]);function S(){d("linking")}function T(){w()}function z(){x(null),d("linking")}const D=f==="confirming"&&ds.createPortal(b.jsx("div",{className:"confirm-modal-overlay",onClick:T,children:b.jsxs("div",{className:"confirm-modal",onClick:H=>H.stopPropagation(),children:[b.jsx("h2",{className:"confirm-modal-title",children:"Link the host to this device?"}),b.jsx("p",{className:"confirm-modal-message",children:"Another device is already linked to this host. Only one device can be linked to the host — switching will disable those capabilities on the currently linked device."}),b.jsxs("div",{className:"confirm-modal-actions",children:[b.jsx("button",{className:"btn btn-secondary",onClick:T,children:"Cancel"}),b.jsx("button",{className:"btn btn-primary",onClick:S,children:"Link"})]})]})}),document.body);if(f==="loading"||f==="confirming"||f==="linking"||f==="linkError"){const H=c,F=f==="loading"||f==="confirming"||f==="linking";return b.jsxs("div",{className:"pair-setup",children:[b.jsxs("div",{className:"pair-setup-inner",children:[H&&b.jsx("h1",{className:"pair-setup-title",children:"Device Capabilities"}),b.jsxs("div",{className:"pair-setup-loading",children:[F&&b.jsx("span",{className:"spinner spinner-lg"}),f==="loading"&&b.jsx("span",{children:"Connecting to host…"}),f==="confirming"&&b.jsx("span",{children:"Awaiting confirmation…"}),f==="linking"&&b.jsx("span",{children:"Linking device…"}),f==="linkError"&&b.jsxs(b.Fragment,{children:[b.jsx("p",{className:"pair-error",children:g}),b.jsx("button",{className:"btn btn-primary",onClick:z,children:"Retry"}),b.jsx("button",{className:"btn btn-secondary",onClick:w,children:"Skip linking"})]})]})]}),D]})}return b.jsx("div",{className:"pair-setup",children:b.jsxs("div",{className:"pair-setup-inner",children:[b.jsx("h1",{className:"pair-setup-title",children:"Device Capabilities"}),b.jsx("p",{className:"pair-setup-description",children:"Choose what the host can use this device for. You can change these later from the menu."}),b.jsx(Bx,{}),b.jsx("div",{className:"pair-setup-actions",children:b.jsx("button",{className:"btn btn-primary btn-full",onClick:w,children:"Finish"})})]})})}function _O(){const e=Mr();return j.useEffect(()=>{if(!mn)return;const t=mn.addListener("deepLink",({path:r})=>e(r));return()=>{t.then(r=>r.remove())}},[e]),null}function kO(){const{pairedHosts:e}=qi();return e.length===0?b.jsx(Ll,{to:"/pair",replace:!0}):b.jsx(Ll,{to:`/hosts/${encodeURIComponent(e[0].hostId)}`,replace:!0})}function EO(){const{hostId:e}=$u(),{pairedHosts:t}=qi(),r=t.find(s=>s.hostId===e)??null;return r?b.jsx(gE,{activeHost:r,children:b.jsxs(nx,{children:[b.jsx(br,{index:!0,element:b.jsx(xu,{})}),b.jsx(br,{path:"tasks",element:b.jsx(xu,{})}),b.jsx(br,{path:"runs/:taskId",element:b.jsx(xu,{})}),b.jsx(br,{path:"runs/:taskId/:runId",element:b.jsx(xu,{})}),b.jsx(br,{path:"pair/setup",element:b.jsx(SO,{})}),b.jsx(br,{path:"*",element:b.jsx(Ll,{to:".",replace:!0})})]})}):b.jsx(Ll,{to:"/",replace:!0})}function CO(){return b.jsxs(H_,{children:[b.jsx(_O,{}),b.jsxs(nx,{children:[b.jsx(br,{path:"/",element:b.jsx(kO,{})}),b.jsx(br,{path:"/pair",element:b.jsx(wO,{})}),b.jsx(br,{path:"/hosts/:hostId/*",element:b.jsx(EO,{})}),b.jsx(br,{path:"*",element:b.jsx(Ll,{to:"/",replace:!0})})]})]})}lS.createRoot(document.getElementById("root")).render(b.jsx(j.StrictMode,{children:b.jsx(A_,{children:b.jsx(CO,{})})}));export{Hd as W};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{W as i}from"./index-
|
|
1
|
+
import{W as i}from"./index-dvjO6dHB.js";function o(){const t=window.navigator.connection||window.navigator.mozConnection||window.navigator.webkitConnection;let n="unknown";const e=t?t.type||t.effectiveType:null;if(e&&typeof e=="string")switch(e){case"bluetooth":case"cellular":n="cellular";break;case"none":n="none";break;case"ethernet":case"wifi":case"wimax":n="wifi";break;case"other":case"unknown":n="unknown";break;case"slow-2g":case"2g":case"3g":n="cellular";break;case"4g":n="wifi";break}return n}class s extends i{constructor(){super(),this.handleOnline=()=>{const e={connected:!0,connectionType:o()};this.notifyListeners("networkStatusChange",e)},this.handleOffline=()=>{const n={connected:!1,connectionType:"none"};this.notifyListeners("networkStatusChange",n)},typeof window<"u"&&(window.addEventListener("online",this.handleOnline),window.addEventListener("offline",this.handleOffline))}async getStatus(){if(!window.navigator)throw this.unavailable("Browser does not support the Network Information API");const n=window.navigator.onLine,e=o();return{connected:n,connectionType:n?e:"none"}}}const r=new s;export{r as Network,s as NetworkWeb};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{W as p}from"./index-
|
|
1
|
+
import{W as p}from"./index-dvjO6dHB.js";class f extends p{constructor(){super(...arguments),this.group="CapacitorStorage"}async configure({group:e}){typeof e=="string"&&(this.group=e)}async get(e){return{value:this.impl.getItem(this.applyPrefix(e.key))}}async set(e){this.impl.setItem(this.applyPrefix(e.key),e.value)}async remove(e){this.impl.removeItem(this.applyPrefix(e.key))}async keys(){return{keys:this.rawKeys().map(t=>t.substring(this.prefix.length))}}async clear(){for(const e of this.rawKeys())this.impl.removeItem(e)}async migrate(){var e;const t=[],s=[],n="_cap_",o=Object.keys(this.impl).filter(i=>i.indexOf(n)===0);for(const i of o){const r=i.substring(n.length),a=(e=this.impl.getItem(i))!==null&&e!==void 0?e:"",{value:l}=await this.get({key:r});typeof l=="string"?s.push(r):(await this.set({key:r,value:a}),t.push(r))}return{migrated:t,existing:s}}async removeOld(){const e="_cap_",t=Object.keys(this.impl).filter(s=>s.indexOf(e)===0);for(const s of t)this.impl.removeItem(s)}get impl(){return window.localStorage}get prefix(){return this.group==="NativeStorage"?"":`${this.group}.`}rawKeys(){return Object.keys(this.impl).filter(e=>e.indexOf(this.prefix)===0)}applyPrefix(e){return this.prefix+e}}export{f as PreferencesWeb};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{W as t}from"./index-
|
|
1
|
+
import{W as t}from"./index-dvjO6dHB.js";class s extends t{constructor(){super(),this.handleVisibilityChange=()=>{const e={isActive:document.hidden!==!0};this.notifyListeners("appStateChange",e),document.hidden?this.notifyListeners("pause",null):this.notifyListeners("resume",null)},document.addEventListener("visibilitychange",this.handleVisibilityChange,!1)}exitApp(){throw this.unimplemented("Not implemented on web.")}async getInfo(){throw this.unimplemented("Not implemented on web.")}async getLaunchUrl(){return{url:""}}async getState(){return{isActive:document.hidden!==!0}}async minimizeApp(){throw this.unimplemented("Not implemented on web.")}async toggleBackButtonHandler(){throw this.unimplemented("Not implemented on web.")}async getAppLanguage(){return{value:navigator.language.split("-")[0].toLowerCase()}}}export{s as AppWeb};
|
package/dist/pwa/index.html
CHANGED
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
<link rel="apple-touch-icon" href="/apple-touch-icon.png" />
|
|
9
9
|
<title>Palmier</title>
|
|
10
10
|
<meta name="description" content="Run tasks from anywhere, approve actions on the go, and let your agents use your phone’s built-in capabilities when needed." />
|
|
11
|
-
<script type="module" crossorigin src="/assets/index-
|
|
11
|
+
<script type="module" crossorigin src="/assets/index-dvjO6dHB.js"></script>
|
|
12
12
|
<link rel="stylesheet" crossorigin href="/assets/index-D1bIhEbd.css">
|
|
13
13
|
<link rel="manifest" href="/manifest.webmanifest"><script id="vite-plugin-pwa:register-sw" src="/registerSW.js"></script></head>
|
|
14
14
|
<body>
|
package/dist/rpc-handler.js
CHANGED
|
@@ -75,9 +75,11 @@ function parseConversationMessages(body) {
|
|
|
75
75
|
const role = (parseAttr(attrs, "role") ?? "assistant");
|
|
76
76
|
const time = Number(parseAttr(attrs, "time") ?? "0");
|
|
77
77
|
const type = parseAttr(attrs, "type");
|
|
78
|
+
const streamRaw = parseAttr(attrs, "stream");
|
|
79
|
+
const stream = streamRaw === "stdout" || streamRaw === "stderr" ? streamRaw : undefined;
|
|
78
80
|
const attachmentsRaw = parseAttr(attrs, "attachments");
|
|
79
81
|
const attachments = attachmentsRaw ? attachmentsRaw.split(",").map((f) => f.trim()).filter(Boolean) : undefined;
|
|
80
|
-
messages.push({ role, time, content, ...(type ? { type } : {}), ...(attachments ? { attachments } : {}) });
|
|
82
|
+
messages.push({ role, time, content, ...(type ? { type } : {}), ...(stream ? { stream } : {}), ...(attachments ? { attachments } : {}) });
|
|
81
83
|
}
|
|
82
84
|
return messages;
|
|
83
85
|
}
|
package/dist/spawn-command.d.ts
CHANGED
|
@@ -24,6 +24,10 @@ export interface SpawnCommandOptions {
|
|
|
24
24
|
stdin?: string;
|
|
25
25
|
/** Called on each chunk of output (stdout + stderr combined). */
|
|
26
26
|
onData?: (chunk: string) => void;
|
|
27
|
+
/** Called on each chunk from stdout only. Fires alongside `onData`. */
|
|
28
|
+
onStdout?: (chunk: string) => void;
|
|
29
|
+
/** Called on each chunk from stderr only. Fires alongside `onData`. */
|
|
30
|
+
onStderr?: (chunk: string) => void;
|
|
27
31
|
}
|
|
28
32
|
/**
|
|
29
33
|
* cross-spawn resolves .cmd shims and escapes args on Windows without shell:true
|
package/dist/spawn-command.js
CHANGED
|
@@ -51,13 +51,15 @@ export function spawnCommand(command, args, opts) {
|
|
|
51
51
|
chunks.push(d);
|
|
52
52
|
if (opts.echoStdout)
|
|
53
53
|
process.stdout.write(d);
|
|
54
|
-
|
|
55
|
-
|
|
54
|
+
const s = d.toString("utf-8");
|
|
55
|
+
opts.onData?.(s);
|
|
56
|
+
opts.onStdout?.(s);
|
|
56
57
|
});
|
|
57
58
|
child.stderr.on("data", (d) => {
|
|
58
59
|
process.stderr.write(d);
|
|
59
|
-
|
|
60
|
-
|
|
60
|
+
const s = d.toString("utf-8");
|
|
61
|
+
opts.onData?.(s);
|
|
62
|
+
opts.onStderr?.(s);
|
|
61
63
|
});
|
|
62
64
|
let timer;
|
|
63
65
|
if (opts.timeout) {
|
package/dist/task.d.ts
CHANGED
|
@@ -20,7 +20,7 @@ export declare function deleteFollowupStatus(runDir: string): void;
|
|
|
20
20
|
export declare function createRunDir(taskDir: string, taskName: string, startTime: number, agent?: string): string;
|
|
21
21
|
export declare function getRunDir(taskDir: string, runId: string): string;
|
|
22
22
|
export declare function appendRunMessage(taskDir: string, runId: string, msg: ConversationMessage): void;
|
|
23
|
-
export declare function beginStreamingMessage(taskDir: string, runId: string, time: number): StreamingMessageWriter;
|
|
23
|
+
export declare function beginStreamingMessage(taskDir: string, runId: string, time: number, stream?: "stdout" | "stderr"): StreamingMessageWriter;
|
|
24
24
|
export declare class StreamingMessageWriter {
|
|
25
25
|
private filePath;
|
|
26
26
|
constructor(filePath: string);
|
package/dist/task.js
CHANGED
|
@@ -146,15 +146,17 @@ export function appendRunMessage(taskDir, runId, msg) {
|
|
|
146
146
|
const attrs = [`role="${msg.role}"`, `time="${msg.time}"`];
|
|
147
147
|
if (msg.type)
|
|
148
148
|
attrs.push(`type="${msg.type}"`);
|
|
149
|
+
if (msg.stream)
|
|
150
|
+
attrs.push(`stream="${msg.stream}"`);
|
|
149
151
|
if (msg.attachments?.length)
|
|
150
152
|
attrs.push(`attachments="${msg.attachments.join(",")}"`);
|
|
151
153
|
const delimiter = `<!-- palmier:message ${attrs.join(" ")} -->`;
|
|
152
154
|
const entry = `${delimiter}\n\n${msg.content}\n\n`;
|
|
153
155
|
fs.appendFileSync(path.join(taskDir, runId, "TASKRUN.md"), entry, "utf-8");
|
|
154
156
|
}
|
|
155
|
-
export function beginStreamingMessage(taskDir, runId, time) {
|
|
157
|
+
export function beginStreamingMessage(taskDir, runId, time, stream = "stdout") {
|
|
156
158
|
const filePath = path.join(taskDir, runId, "TASKRUN.md");
|
|
157
|
-
const delimiter = `<!-- palmier:message role="assistant" time="${time}" -->`;
|
|
159
|
+
const delimiter = `<!-- palmier:message role="assistant" time="${time}" stream="${stream}" -->`;
|
|
158
160
|
fs.appendFileSync(filePath, `${delimiter}\n\n`, "utf-8");
|
|
159
161
|
return new StreamingMessageWriter(filePath);
|
|
160
162
|
}
|
|
@@ -173,7 +175,7 @@ export class StreamingMessageWriter {
|
|
|
173
175
|
if (attachments?.length) {
|
|
174
176
|
const raw = fs.readFileSync(this.filePath, "utf-8");
|
|
175
177
|
// spliceUserMessage may have created a newer assistant delimiter.
|
|
176
|
-
const pattern = /<!-- palmier:message role="assistant"
|
|
178
|
+
const pattern = /<!-- palmier:message role="assistant"[^>]*-->/g;
|
|
177
179
|
let lastMatch = null;
|
|
178
180
|
let m;
|
|
179
181
|
while ((m = pattern.exec(raw)) !== null)
|
|
@@ -202,7 +204,7 @@ assistantAppend) {
|
|
|
202
204
|
}
|
|
203
205
|
fs.appendFileSync(filePath, "\n\n", "utf-8");
|
|
204
206
|
appendRunMessage(taskDir, runId, userMsg);
|
|
205
|
-
const delimiter = `<!-- palmier:message role="assistant" time="${Date.now()}" -->`;
|
|
207
|
+
const delimiter = `<!-- palmier:message role="assistant" time="${Date.now()}" stream="stdout" -->`;
|
|
206
208
|
fs.appendFileSync(filePath, `${delimiter}\n\n`, "utf-8");
|
|
207
209
|
}
|
|
208
210
|
export function readRunMessages(taskDir, runId) {
|
|
@@ -225,12 +227,14 @@ export function readRunMessages(taskDir, runId) {
|
|
|
225
227
|
const roleAttr = attrs.match(/role="([^"]*)"/)?.[1] ?? "assistant";
|
|
226
228
|
const timeAttr = attrs.match(/time="([^"]*)"/)?.[1] ?? "0";
|
|
227
229
|
const typeAttr = attrs.match(/type="([^"]*)"/)?.[1];
|
|
230
|
+
const streamAttr = attrs.match(/stream="([^"]*)"/)?.[1];
|
|
228
231
|
const attachmentsAttr = attrs.match(/attachments="([^"]*)"/)?.[1];
|
|
229
232
|
messages.push({
|
|
230
233
|
role: roleAttr,
|
|
231
234
|
time: Number(timeAttr),
|
|
232
235
|
content,
|
|
233
236
|
...(typeAttr ? { type: typeAttr } : {}),
|
|
237
|
+
...(streamAttr === "stdout" || streamAttr === "stderr" ? { stream: streamAttr } : {}),
|
|
234
238
|
...(attachmentsAttr ? { attachments: attachmentsAttr.split(",").map((f) => f.trim()).filter(Boolean) } : {}),
|
|
235
239
|
});
|
|
236
240
|
}
|
package/dist/types.d.ts
CHANGED
|
@@ -72,6 +72,9 @@ export interface ConversationMessage {
|
|
|
72
72
|
content: string;
|
|
73
73
|
type?: "input" | "permission" | "confirmation" | "monitoring" | "started" | "finished" | "failed" | "aborted" | "stopped" | "error";
|
|
74
74
|
attachments?: string[];
|
|
75
|
+
/** For assistant messages, identifies which stream the agent CLI emitted this segment on.
|
|
76
|
+
* Absent on non-assistant messages and on legacy entries written before the split. */
|
|
77
|
+
stream?: "stdout" | "stderr";
|
|
75
78
|
}
|
|
76
79
|
export interface RpcMessage {
|
|
77
80
|
method: string;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "palmier",
|
|
3
|
-
"version": "0.9.
|
|
3
|
+
"version": "0.9.9",
|
|
4
4
|
"description": "Palmier host CLI - provisions, executes tasks, and serves NATS RPC",
|
|
5
5
|
"license": "Apache-2.0",
|
|
6
6
|
"author": "Hongxu Cai",
|
|
@@ -20,6 +20,12 @@
|
|
|
20
20
|
},
|
|
21
21
|
"files": [
|
|
22
22
|
"dist",
|
|
23
|
+
"!dist/pwa/service-worker.js",
|
|
24
|
+
"!dist/pwa/registerSW.js",
|
|
25
|
+
"!dist/pwa/manifest.webmanifest",
|
|
26
|
+
"!dist/pwa/apple-touch-icon.png",
|
|
27
|
+
"!dist/pwa/pwa-192x192.png",
|
|
28
|
+
"!dist/pwa/pwa-512x512.png",
|
|
23
29
|
"DISCLAIMER.md"
|
|
24
30
|
],
|
|
25
31
|
"scripts": {
|
|
Binary file
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"name":"Palmier","short_name":"Palmier","description":"Bridge your AI agents and your phone. Your AI agents use your phone as a tool — GPS, email, calendar, contacts — and you use your phone as an agent remote.","start_url":"/","display":"standalone","background_color":"#ffffff","theme_color":"#2E5CE5","lang":"en","scope":"/","icons":[{"src":"pwa-192x192.png","sizes":"192x192","type":"image/png"},{"src":"pwa-512x512.png","sizes":"512x512","type":"image/png"}]}
|
package/dist/pwa/pwa-192x192.png
DELETED
|
Binary file
|
package/dist/pwa/pwa-512x512.png
DELETED
|
Binary file
|
package/dist/pwa/registerSW.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
if('serviceWorker' in navigator) {window.addEventListener('load', () => {navigator.serviceWorker.register('/service-worker.js', { scope: '/' })})}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
try{self["workbox:core:7.3.0"]&&_()}catch{}const N=(n,...e)=>{let t=n;return e.length>0&&(t+=` :: ${JSON.stringify(e)}`),t},E=N;class h extends Error{constructor(e,t){const s=E(e,t);super(s),this.name=e,this.details=t}}const d={googleAnalytics:"googleAnalytics",precache:"precache-v2",prefix:"workbox",runtime:"runtime",suffix:typeof registration<"u"?registration.scope:""},U=n=>[d.prefix,n,d.suffix].filter(e=>e&&e.length>0).join("-"),O=n=>{for(const e of Object.keys(d))n(e)},L={updateDetails:n=>{O(e=>{typeof n[e]=="string"&&(d[e]=n[e])})},getGoogleAnalyticsName:n=>n||U(d.googleAnalytics),getPrecacheName:n=>n||U(d.precache),getPrefix:()=>d.prefix,getRuntimeName:n=>n||U(d.runtime),getSuffix:()=>d.suffix};function v(n,e){const t=e();return n.waitUntil(t),t}try{self["workbox:precaching:7.3.0"]&&_()}catch{}const A="__WB_REVISION__";function M(n){if(!n)throw new h("add-to-cache-list-unexpected-type",{entry:n});if(typeof n=="string"){const i=new URL(n,location.href);return{cacheKey:i.href,url:i.href}}const{revision:e,url:t}=n;if(!t)throw new h("add-to-cache-list-unexpected-type",{entry:n});if(!e){const i=new URL(t,location.href);return{cacheKey:i.href,url:i.href}}const s=new URL(t,location.href),a=new URL(t,location.href);return s.searchParams.set(A,e),{cacheKey:s.href,url:a.href}}class W{constructor(){this.updatedURLs=[],this.notUpdatedURLs=[],this.handlerWillStart=async({request:e,state:t})=>{t&&(t.originalRequest=e)},this.cachedResponseWillBeUsed=async({event:e,state:t,cachedResponse:s})=>{if(e.type==="install"&&t&&t.originalRequest&&t.originalRequest instanceof Request){const a=t.originalRequest.url;s?this.notUpdatedURLs.push(a):this.updatedURLs.push(a)}return s}}}class q{constructor({precacheController:e}){this.cacheKeyWillBeUsed=async({request:t,params:s})=>{const a=(s==null?void 0:s.cacheKey)||this._precacheController.getCacheKeyForURL(t.url);return a?new Request(a,{headers:t.headers}):t},this._precacheController=e}}let w;function S(){if(w===void 0){const n=new Response("");if("body"in n)try{new Response(n.body),w=!0}catch{w=!1}w=!1}return w}async function j(n,e){let t=null;if(n.url&&(t=new URL(n.url).origin),t!==self.location.origin)throw new h("cross-origin-copy-response",{origin:t});const s=n.clone(),i={headers:new Headers(s.headers),status:s.status,statusText:s.statusText},r=S()?s.body:await s.blob();return new Response(r,i)}const D=n=>new URL(String(n),location.href).href.replace(new RegExp(`^${location.origin}`),"");function x(n,e){const t=new URL(n);for(const s of e)t.searchParams.delete(s);return t.href}async function H(n,e,t,s){const a=x(e.url,t);if(e.url===a)return n.match(e,s);const i=Object.assign(Object.assign({},s),{ignoreSearch:!0}),r=await n.keys(e,i);for(const c of r){const o=x(c.url,t);if(a===o)return n.match(c,s)}}class F{constructor(){this.promise=new Promise((e,t)=>{this.resolve=e,this.reject=t})}}const $=new Set;async function B(){for(const n of $)await n()}function V(n){return new Promise(e=>setTimeout(e,n))}try{self["workbox:strategies:7.3.0"]&&_()}catch{}function C(n){return typeof n=="string"?new Request(n):n}class G{constructor(e,t){this._cacheKeys={},Object.assign(this,t),this.event=t.event,this._strategy=e,this._handlerDeferred=new F,this._extendLifetimePromises=[],this._plugins=[...e.plugins],this._pluginStateMap=new Map;for(const s of this._plugins)this._pluginStateMap.set(s,{});this.event.waitUntil(this._handlerDeferred.promise)}async fetch(e){const{event:t}=this;let s=C(e);if(s.mode==="navigate"&&t instanceof FetchEvent&&t.preloadResponse){const r=await t.preloadResponse;if(r)return r}const a=this.hasCallback("fetchDidFail")?s.clone():null;try{for(const r of this.iterateCallbacks("requestWillFetch"))s=await r({request:s.clone(),event:t})}catch(r){if(r instanceof Error)throw new h("plugin-error-request-will-fetch",{thrownErrorMessage:r.message})}const i=s.clone();try{let r;r=await fetch(s,s.mode==="navigate"?void 0:this._strategy.fetchOptions);for(const c of this.iterateCallbacks("fetchDidSucceed"))r=await c({event:t,request:i,response:r});return r}catch(r){throw a&&await this.runCallbacks("fetchDidFail",{error:r,event:t,originalRequest:a.clone(),request:i.clone()}),r}}async fetchAndCachePut(e){const t=await this.fetch(e),s=t.clone();return this.waitUntil(this.cachePut(e,s)),t}async cacheMatch(e){const t=C(e);let s;const{cacheName:a,matchOptions:i}=this._strategy,r=await this.getCacheKey(t,"read"),c=Object.assign(Object.assign({},i),{cacheName:a});s=await caches.match(r,c);for(const o of this.iterateCallbacks("cachedResponseWillBeUsed"))s=await o({cacheName:a,matchOptions:i,cachedResponse:s,request:r,event:this.event})||void 0;return s}async cachePut(e,t){const s=C(e);await V(0);const a=await this.getCacheKey(s,"write");if(!t)throw new h("cache-put-with-no-response",{url:D(a.url)});const i=await this._ensureResponseSafeToCache(t);if(!i)return!1;const{cacheName:r,matchOptions:c}=this._strategy,o=await self.caches.open(r),l=this.hasCallback("cacheDidUpdate"),u=l?await H(o,a.clone(),["__WB_REVISION__"],c):null;try{await o.put(a,l?i.clone():i)}catch(f){if(f instanceof Error)throw f.name==="QuotaExceededError"&&await B(),f}for(const f of this.iterateCallbacks("cacheDidUpdate"))await f({cacheName:r,oldResponse:u,newResponse:i.clone(),request:a,event:this.event});return!0}async getCacheKey(e,t){const s=`${e.url} | ${t}`;if(!this._cacheKeys[s]){let a=e;for(const i of this.iterateCallbacks("cacheKeyWillBeUsed"))a=C(await i({mode:t,request:a,event:this.event,params:this.params}));this._cacheKeys[s]=a}return this._cacheKeys[s]}hasCallback(e){for(const t of this._strategy.plugins)if(e in t)return!0;return!1}async runCallbacks(e,t){for(const s of this.iterateCallbacks(e))await s(t)}*iterateCallbacks(e){for(const t of this._strategy.plugins)if(typeof t[e]=="function"){const s=this._pluginStateMap.get(t);yield i=>{const r=Object.assign(Object.assign({},i),{state:s});return t[e](r)}}}waitUntil(e){return this._extendLifetimePromises.push(e),e}async doneWaiting(){for(;this._extendLifetimePromises.length;){const e=this._extendLifetimePromises.splice(0),s=(await Promise.allSettled(e)).find(a=>a.status==="rejected");if(s)throw s.reason}}destroy(){this._handlerDeferred.resolve(null)}async _ensureResponseSafeToCache(e){let t=e,s=!1;for(const a of this.iterateCallbacks("cacheWillUpdate"))if(t=await a({request:this.request,response:t,event:this.event})||void 0,s=!0,!t)break;return s||t&&t.status!==200&&(t=void 0),t}}class J{constructor(e={}){this.cacheName=L.getRuntimeName(e.cacheName),this.plugins=e.plugins||[],this.fetchOptions=e.fetchOptions,this.matchOptions=e.matchOptions}handle(e){const[t]=this.handleAll(e);return t}handleAll(e){e instanceof FetchEvent&&(e={event:e,request:e.request});const t=e.event,s=typeof e.request=="string"?new Request(e.request):e.request,a="params"in e?e.params:void 0,i=new G(this,{event:t,request:s,params:a}),r=this._getResponse(i,s,t),c=this._awaitComplete(r,i,s,t);return[r,c]}async _getResponse(e,t,s){await e.runCallbacks("handlerWillStart",{event:s,request:t});let a;try{if(a=await this._handle(t,e),!a||a.type==="error")throw new h("no-response",{url:t.url})}catch(i){if(i instanceof Error){for(const r of e.iterateCallbacks("handlerDidError"))if(a=await r({error:i,event:s,request:t}),a)break}if(!a)throw i}for(const i of e.iterateCallbacks("handlerWillRespond"))a=await i({event:s,request:t,response:a});return a}async _awaitComplete(e,t,s,a){let i,r;try{i=await e}catch{}try{await t.runCallbacks("handlerDidRespond",{event:a,request:s,response:i}),await t.doneWaiting()}catch(c){c instanceof Error&&(r=c)}if(await t.runCallbacks("handlerDidComplete",{event:a,request:s,response:i,error:r}),t.destroy(),r)throw r}}class p extends J{constructor(e={}){e.cacheName=L.getPrecacheName(e.cacheName),super(e),this._fallbackToNetwork=e.fallbackToNetwork!==!1,this.plugins.push(p.copyRedirectedCacheableResponsesPlugin)}async _handle(e,t){const s=await t.cacheMatch(e);return s||(t.event&&t.event.type==="install"?await this._handleInstall(e,t):await this._handleFetch(e,t))}async _handleFetch(e,t){let s;const a=t.params||{};if(this._fallbackToNetwork){const i=a.integrity,r=e.integrity,c=!r||r===i;s=await t.fetch(new Request(e,{integrity:e.mode!=="no-cors"?r||i:void 0})),i&&c&&e.mode!=="no-cors"&&(this._useDefaultCacheabilityPluginIfNeeded(),await t.cachePut(e,s.clone()))}else throw new h("missing-precache-entry",{cacheName:this.cacheName,url:e.url});return s}async _handleInstall(e,t){this._useDefaultCacheabilityPluginIfNeeded();const s=await t.fetch(e);if(!await t.cachePut(e,s.clone()))throw new h("bad-precaching-response",{url:e.url,status:s.status});return s}_useDefaultCacheabilityPluginIfNeeded(){let e=null,t=0;for(const[s,a]of this.plugins.entries())a!==p.copyRedirectedCacheableResponsesPlugin&&(a===p.defaultPrecacheCacheabilityPlugin&&(e=s),a.cacheWillUpdate&&t++);t===0?this.plugins.push(p.defaultPrecacheCacheabilityPlugin):t>1&&e!==null&&this.plugins.splice(e,1)}}p.defaultPrecacheCacheabilityPlugin={async cacheWillUpdate({response:n}){return!n||n.status>=400?null:n}};p.copyRedirectedCacheableResponsesPlugin={async cacheWillUpdate({response:n}){return n.redirected?await j(n):n}};class Q{constructor({cacheName:e,plugins:t=[],fallbackToNetwork:s=!0}={}){this._urlsToCacheKeys=new Map,this._urlsToCacheModes=new Map,this._cacheKeysToIntegrities=new Map,this._strategy=new p({cacheName:L.getPrecacheName(e),plugins:[...t,new q({precacheController:this})],fallbackToNetwork:s}),this.install=this.install.bind(this),this.activate=this.activate.bind(this)}get strategy(){return this._strategy}precache(e){this.addToCacheList(e),this._installAndActiveListenersAdded||(self.addEventListener("install",this.install),self.addEventListener("activate",this.activate),this._installAndActiveListenersAdded=!0)}addToCacheList(e){const t=[];for(const s of e){typeof s=="string"?t.push(s):s&&s.revision===void 0&&t.push(s.url);const{cacheKey:a,url:i}=M(s),r=typeof s!="string"&&s.revision?"reload":"default";if(this._urlsToCacheKeys.has(i)&&this._urlsToCacheKeys.get(i)!==a)throw new h("add-to-cache-list-conflicting-entries",{firstEntry:this._urlsToCacheKeys.get(i),secondEntry:a});if(typeof s!="string"&&s.integrity){if(this._cacheKeysToIntegrities.has(a)&&this._cacheKeysToIntegrities.get(a)!==s.integrity)throw new h("add-to-cache-list-conflicting-integrities",{url:i});this._cacheKeysToIntegrities.set(a,s.integrity)}if(this._urlsToCacheKeys.set(i,a),this._urlsToCacheModes.set(i,r),t.length>0){const c=`Workbox is precaching URLs without revision info: ${t.join(", ")}
|
|
2
|
-
This is generally NOT safe. Learn more at https://bit.ly/wb-precache`;console.warn(c)}}}install(e){return v(e,async()=>{const t=new W;this.strategy.plugins.push(t);for(const[i,r]of this._urlsToCacheKeys){const c=this._cacheKeysToIntegrities.get(r),o=this._urlsToCacheModes.get(i),l=new Request(i,{integrity:c,cache:o,credentials:"same-origin"});await Promise.all(this.strategy.handleAll({params:{cacheKey:r},request:l,event:e}))}const{updatedURLs:s,notUpdatedURLs:a}=t;return{updatedURLs:s,notUpdatedURLs:a}})}activate(e){return v(e,async()=>{const t=await self.caches.open(this.strategy.cacheName),s=await t.keys(),a=new Set(this._urlsToCacheKeys.values()),i=[];for(const r of s)a.has(r.url)||(await t.delete(r),i.push(r.url));return{deletedURLs:i}})}getURLsToCacheKeys(){return this._urlsToCacheKeys}getCachedURLs(){return[...this._urlsToCacheKeys.keys()]}getCacheKeyForURL(e){const t=new URL(e,location.href);return this._urlsToCacheKeys.get(t.href)}getIntegrityForCacheKey(e){return this._cacheKeysToIntegrities.get(e)}async matchPrecache(e){const t=e instanceof Request?e.url:e,s=this.getCacheKeyForURL(t);if(s)return(await self.caches.open(this.strategy.cacheName)).match(s)}createHandlerBoundToURL(e){const t=this.getCacheKeyForURL(e);if(!t)throw new h("non-precached-url",{url:e});return s=>(s.request=new Request(e),s.params=Object.assign({cacheKey:t},s.params),this.strategy.handle(s))}}let k;const T=()=>(k||(k=new Q),k);try{self["workbox:routing:7.3.0"]&&_()}catch{}const I="GET",b=n=>n&&typeof n=="object"?n:{handle:n};class R{constructor(e,t,s=I){this.handler=b(t),this.match=e,this.method=s}setCatchHandler(e){this.catchHandler=b(e)}}class z extends R{constructor(e,t,s){const a=({url:i})=>{const r=e.exec(i.href);if(r&&!(i.origin!==location.origin&&r.index!==0))return r.slice(1)};super(a,t,s)}}class X{constructor(){this._routes=new Map,this._defaultHandlerMap=new Map}get routes(){return this._routes}addFetchListener(){self.addEventListener("fetch",(e=>{const{request:t}=e,s=this.handleRequest({request:t,event:e});s&&e.respondWith(s)}))}addCacheListener(){self.addEventListener("message",(e=>{if(e.data&&e.data.type==="CACHE_URLS"){const{payload:t}=e.data,s=Promise.all(t.urlsToCache.map(a=>{typeof a=="string"&&(a=[a]);const i=new Request(...a);return this.handleRequest({request:i,event:e})}));e.waitUntil(s),e.ports&&e.ports[0]&&s.then(()=>e.ports[0].postMessage(!0))}}))}handleRequest({request:e,event:t}){const s=new URL(e.url,location.href);if(!s.protocol.startsWith("http"))return;const a=s.origin===location.origin,{params:i,route:r}=this.findMatchingRoute({event:t,request:e,sameOrigin:a,url:s});let c=r&&r.handler;const o=e.method;if(!c&&this._defaultHandlerMap.has(o)&&(c=this._defaultHandlerMap.get(o)),!c)return;let l;try{l=c.handle({url:s,request:e,event:t,params:i})}catch(f){l=Promise.reject(f)}const u=r&&r.catchHandler;return l instanceof Promise&&(this._catchHandler||u)&&(l=l.catch(async f=>{if(u)try{return await u.handle({url:s,request:e,event:t,params:i})}catch(g){g instanceof Error&&(f=g)}if(this._catchHandler)return this._catchHandler.handle({url:s,request:e,event:t});throw f})),l}findMatchingRoute({url:e,sameOrigin:t,request:s,event:a}){const i=this._routes.get(s.method)||[];for(const r of i){let c;const o=r.match({url:e,sameOrigin:t,request:s,event:a});if(o)return c=o,(Array.isArray(c)&&c.length===0||o.constructor===Object&&Object.keys(o).length===0||typeof o=="boolean")&&(c=void 0),{route:r,params:c}}return{}}setDefaultHandler(e,t=I){this._defaultHandlerMap.set(t,b(e))}setCatchHandler(e){this._catchHandler=b(e)}registerRoute(e){this._routes.has(e.method)||this._routes.set(e.method,[]),this._routes.get(e.method).push(e)}unregisterRoute(e){if(!this._routes.has(e.method))throw new h("unregister-route-but-not-found-with-method",{method:e.method});const t=this._routes.get(e.method).indexOf(e);if(t>-1)this._routes.get(e.method).splice(t,1);else throw new h("unregister-route-route-not-registered")}}let m;const Y=()=>(m||(m=new X,m.addFetchListener(),m.addCacheListener()),m);function Z(n,e,t){let s;if(typeof n=="string"){const i=new URL(n,location.href),r=({url:c})=>c.href===i.href;s=new R(r,e,t)}else if(n instanceof RegExp)s=new z(n,e,t);else if(typeof n=="function")s=new R(n,e,t);else if(n instanceof R)s=n;else throw new h("unsupported-route-type",{moduleName:"workbox-routing",funcName:"registerRoute",paramName:"capture"});return Y().registerRoute(s),s}function ee(n,e=[]){for(const t of[...n.searchParams.keys()])e.some(s=>s.test(t))&&n.searchParams.delete(t);return n}function*te(n,{ignoreURLParametersMatching:e=[/^utm_/,/^fbclid$/],directoryIndex:t="index.html",cleanURLs:s=!0,urlManipulation:a}={}){const i=new URL(n,location.href);i.hash="",yield i.href;const r=ee(i,e);if(yield r.href,t&&r.pathname.endsWith("/")){const c=new URL(r.href);c.pathname+=t,yield c.href}if(s){const c=new URL(r.href);c.pathname+=".html",yield c.href}if(a){const c=a({url:i});for(const o of c)yield o.href}}class se extends R{constructor(e,t){const s=({request:a})=>{const i=e.getURLsToCacheKeys();for(const r of te(a.url,t)){const c=i.get(r);if(c){const o=e.getIntegrityForCacheKey(c);return{cacheKey:c,integrity:o}}}};super(s,e.strategy)}}function ne(n){const e=T(),t=new se(e,n);Z(t)}function ae(n){T().precache(n)}function ie(n,e){ae(n),ne(e)}ie([{"revision":"38013143dc2183340ede8bc1c5124507","url":"registerSW.js"},{"revision":"c4f507b1bdd3aa2c981e55307125bab0","url":"index.html"},{"revision":null,"url":"assets/web-DL4uXOpS.js"},{"revision":null,"url":"assets/web-CBFqJGX6.js"},{"revision":null,"url":"assets/web-C4iZbqTC.js"},{"revision":null,"url":"assets/index-DWvRAUiy.js"},{"revision":null,"url":"assets/index-D1bIhEbd.css"},{"revision":"52153002d5b9308ba313d435ee6dedcd","url":"apple-touch-icon.png"},{"revision":"438da4214ab645a9c18a515c92cd9dfc","url":"favicon.ico"},{"revision":"7499c65c226796ebfc9674049a757362","url":"pwa-192x192.png"},{"revision":"e0cfcedd3448d33a3e75880e29be3d77","url":"pwa-512x512.png"},{"revision":"50cd09d8b1eba396c10f48577e4e8ae3","url":"manifest.webmanifest"}]);const re="/api/push/respond";self.addEventListener("message",n=>{});self.addEventListener("push",n=>{var r;if(!n.data)return;let e;try{e=n.data.json()}catch{e={title:"Palmier",body:n.data.text()}}const t=e.type??((r=e.data)==null?void 0:r.type);if(t==="confirm-dismiss"||t==="permission-dismiss"||t==="input-dismiss"){const c=e.data??e,o=c.host_id,l=c.session_id,u=c.task_id;n.waitUntil(self.registration.getNotifications().then(f=>{var g,P,K;for(const y of f)if(((g=y.data)==null?void 0:g.host_id)===o){if(l&&((P=y.data)==null?void 0:P.session_id)===l){y.close();continue}u&&((K=y.data)==null?void 0:K.task_id)===u&&y.close()}}));return}const s=e.title??"Palmier";let a=e.body??"";!a&&t==="confirm"&&(a="A task requires confirmation to run."),!a&&t==="permission"&&(a="A task needs additional permissions to continue."),!a&&t==="input"&&(a="A task needs your input to continue.");const i={body:a,icon:"/pwa-192x192.png",badge:"/pwa-192x192.png",data:e.data??e,vibrate:[100,50,100]};t==="confirm"&&(i.actions=[{action:"confirm",title:"Confirm"},{action:"abort",title:"Abort"}]),n.waitUntil(self.registration.showNotification(s,i))});self.addEventListener("notificationclick",n=>{const e=n.notification;e.close();const t=e.data??{},s=n.action;if(s&&t.type==="confirm"&&t.session_id&&t.host_id){const a=s==="confirm"?"confirmed":"aborted";n.waitUntil(fetch(re,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({session_id:t.session_id,host_id:t.host_id,response:a})}).catch(i=>{console.error("Failed to send push response:",i)}))}else{const a=t.host_id,i=t.task_id,r=t.run_id,c=a?`/hosts/${encodeURIComponent(a)}`:"",o=c&&i&&r?`${c}/runs/${encodeURIComponent(i)}/${encodeURIComponent(r)}`:c&&i?`${c}/runs/${encodeURIComponent(i)}/latest`:c||"/";n.waitUntil(self.clients.matchAll({type:"window",includeUncontrolled:!0}).then(l=>{for(const u of l)if(u.url.includes(self.location.origin)&&"focus"in u)return u.navigate(o),u.focus();return self.clients.openWindow(o)}))}});self.addEventListener("install",()=>{self.skipWaiting()});self.addEventListener("activate",n=>{n.waitUntil(self.clients.claim())});
|