palmier 0.9.21 → 0.9.23
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/README.md +21 -27
- package/dist/agents/wizard.d.ts +5 -0
- package/dist/agents/wizard.js +45 -7
- package/dist/commands/run.js +15 -2
- package/dist/commands/uninstall.js +14 -1
- package/dist/pwa/assets/{index-kjOWpVKd.js → index-DsOLf_o3.js} +2 -2
- package/dist/pwa/assets/{web-CpqzX7Jk.js → web-B0XfObWX.js} +1 -1
- package/dist/pwa/assets/{web-ZSYmpLle.js → web-BYY9thT9.js} +1 -1
- package/dist/pwa/assets/{web-BQQlSLPT.js → web-BZCAN0xX.js} +1 -1
- package/dist/pwa/index.html +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -6,32 +6,23 @@
|
|
|
6
6
|
|
|
7
7
|
**Website:** [palmier.me](https://www.palmier.me) | **Web App:** [app.palmier.me](https://app.palmier.me) | **Android App:** [caihongxu/palmier-android](https://github.com/caihongxu/palmier-android)
|
|
8
8
|
|
|
9
|
-
|
|
9
|
+
Palmier installs, manages, and runs AI agent CLIs (Claude Code, Gemini CLI, Codex, etc.) on your machine using your existing AI subscriptions, and exposes them to your phone through a mobile-friendly PWA and an Android app. It runs as a background daemon and is agent-agnostic — adding support for a new CLI is a config change, not a code change.
|
|
10
10
|
|
|
11
|
-
|
|
11
|
+
The control surface is bidirectional:
|
|
12
12
|
|
|
13
|
-
|
|
13
|
+
* **Phone → host:** start ad-hoc sessions, register schedule- or event-triggered tasks, inspect session output, and respond to agent input/confirmation requests.
|
|
14
|
+
* **Host → phone:** agents can call MCP tools to read device state (location, calendar, contacts, notifications, SMS, battery) and trigger actions (push notifications, full-screen alarms, SMS, email, contact/calendar writes, ringer mode).
|
|
14
15
|
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
Palmier is an **agent-agnostic phone bridge and mobile control layer** for the agents you already use.
|
|
16
|
+
Capability access is opt-in per device: each MCP tool is gated behind an Android permission and a per-host toggle. An optional yolo mode auto-approves agent input/confirmation requests.
|
|
18
17
|
|
|
19
18
|
It is not:
|
|
20
19
|
|
|
21
|
-
* an agent runtime itself
|
|
22
|
-
* a
|
|
23
|
-
* a system for driving your phone UI like a human tapping through apps
|
|
24
|
-
|
|
25
|
-
Instead, Palmier focuses on:
|
|
26
|
-
|
|
27
|
-
* letting agents access phone-side capabilities and context in the background
|
|
28
|
-
* letting you talk to, manage, and schedule your agents from your phone
|
|
29
|
-
* making phone integrations work out of the box without requiring users to wire up separate calendar/email/contact stacks
|
|
20
|
+
* an agent runtime itself — Palmier shells out to the agent CLI and streams its stdio
|
|
21
|
+
* a system for driving phone UI like a human tapping through apps — phone access is via OS-level APIs (FCM data messages, content providers, calendar/contacts APIs), not UI automation
|
|
30
22
|
|
|
31
23
|
## Quick Start
|
|
32
24
|
|
|
33
|
-
1. Install
|
|
34
|
-
2. Install Palmier:
|
|
25
|
+
1. Install Palmier:
|
|
35
26
|
|
|
36
27
|
**Linux / macOS:**
|
|
37
28
|
```bash
|
|
@@ -47,19 +38,18 @@ Instead, Palmier focuses on:
|
|
|
47
38
|
```bash
|
|
48
39
|
npm install -g palmier
|
|
49
40
|
```
|
|
50
|
-
|
|
41
|
+
2. Run the setup wizard from your Palmier root directory (e.g., `~/palmier`):
|
|
51
42
|
```bash
|
|
52
43
|
palmier init
|
|
53
44
|
```
|
|
54
|
-
This detects
|
|
55
|
-
|
|
56
|
-
|
|
45
|
+
This detects existing agent CLIs or offers to install supported ones ([Claude Code](https://docs.anthropic.com/en/docs/claude-code), [Gemini CLI](https://github.com/google-gemini/gemini-cli), [Codex CLI](https://github.com/openai/codex), [GitHub Copilot](https://github.com/github/gh-copilot), [OpenClaw](https://openclaw.ai/), or [others](https://www.palmier.me/agents)), configures access, installs the background daemon, and starts pairing.
|
|
46
|
+
3. Open `http://localhost:7256` to access the app locally — no pairing needed.
|
|
47
|
+
4. To access from other devices, enter the pairing code shown after init into the [PWA](https://app.palmier.me) or the [Android app](https://github.com/caihongxu/palmier-android/releases/latest/download/palmier.apk).
|
|
57
48
|
|
|
58
49
|
### Prerequisites
|
|
59
50
|
|
|
60
51
|
- **Node.js 24+**
|
|
61
52
|
- **Linux with systemd**, **macOS 13+**, or **Windows 10/11**
|
|
62
|
-
- At least one supported agent CLI
|
|
63
53
|
|
|
64
54
|
## How It Works
|
|
65
55
|
|
|
@@ -132,9 +122,11 @@ Three ways to reach your host, ordered by setup effort:
|
|
|
132
122
|
|
|
133
123
|
| Mode | Where | Pairing | Notes |
|
|
134
124
|
|------|-------|---------|-------|
|
|
135
|
-
| **Local** | `http://localhost:7256` in a browser on the host machine | Not required | Loopback only. No internet needed. |
|
|
136
|
-
| **
|
|
137
|
-
| **
|
|
125
|
+
| **Local (browser)** | `http://localhost:7256` in a browser on the host machine | Not required | Loopback only. No internet or Palmier server connection needed. |
|
|
126
|
+
| **PWA** | [https://app.palmier.me](https://app.palmier.me) in any browser | Required | Installable to your home screen; supports web push notifications. Always goes through the cloud relay. |
|
|
127
|
+
| **Android app** | [Android APK](https://github.com/caihongxu/palmier-android/releases/latest/download/palmier.apk) | Required | Unlocks phone capabilities (GPS, email, calendar, contacts, SMS, alarms), push notifications, and **auto-LAN**. |
|
|
128
|
+
|
|
129
|
+
iOS app coming soon.
|
|
138
130
|
|
|
139
131
|
**Auto-LAN (native app only).** When the Android app is on the same network as the host, it transparently routes RPC over direct LAN HTTP (`http://<host-ip>:7256/rpc/...`) instead of through the relay — lower latency, no protocol change. Browser PWAs can't do this (Private Network Access / mixed-content restrictions) and stay on the relay.
|
|
140
132
|
|
|
@@ -220,7 +212,7 @@ The default network interface is detected once during `palmier init` and saved t
|
|
|
220
212
|
| `palmier serve` | Run the persistent RPC handler (default command) |
|
|
221
213
|
| `palmier restart` | Restart the palmier serve daemon |
|
|
222
214
|
| `palmier run <task-id>` | Execute a specific task |
|
|
223
|
-
| `palmier uninstall` | Stop daemon
|
|
215
|
+
| `palmier uninstall` | Stop daemon, remove all scheduled tasks, and uninstall Palmier-managed agent CLIs |
|
|
224
216
|
|
|
225
217
|
## Uninstalling
|
|
226
218
|
|
|
@@ -228,12 +220,14 @@ To fully remove Palmier from a machine:
|
|
|
228
220
|
|
|
229
221
|
1. **Unpair your device** in the PWA (via the host menu).
|
|
230
222
|
|
|
231
|
-
2. **Stop the daemon
|
|
223
|
+
2. **Stop the daemon, remove all scheduled tasks, and uninstall Palmier-managed agent CLIs:**
|
|
232
224
|
|
|
233
225
|
```bash
|
|
234
226
|
palmier uninstall
|
|
235
227
|
```
|
|
236
228
|
|
|
229
|
+
Agents you installed yourself outside Palmier (no managed version stamp) are left in place.
|
|
230
|
+
|
|
237
231
|
3. **Uninstall the package:**
|
|
238
232
|
|
|
239
233
|
```bash
|
package/dist/agents/wizard.d.ts
CHANGED
|
@@ -21,3 +21,8 @@ export declare function pickAndInstallAgent(current: DetectedAgent[], options?:
|
|
|
21
21
|
/** Show the uninstall picker. Runs `npm uninstall -g` for the chosen agent
|
|
22
22
|
* and returns the agent key on success, or null on cancel/failure/no candidates. */
|
|
23
23
|
export declare function pickAndUninstallAgent(current: DetectedAgent[]): Promise<string | null>;
|
|
24
|
+
/** Uninstall a single agent's npm package. Logs success/failure to stdout.
|
|
25
|
+
* Shared between the `palmier agents` interactive picker and the bulk
|
|
26
|
+
* managed-agent removal in `palmier uninstall`. */
|
|
27
|
+
export declare function uninstallAgent(agent: DetectedAgent): boolean;
|
|
28
|
+
export declare function uninstallManagedAgents(agents: DetectedAgent[]): void;
|
package/dist/agents/wizard.js
CHANGED
|
@@ -10,7 +10,7 @@ export const colors = {
|
|
|
10
10
|
red: (s) => `\x1b[31m${s}\x1b[0m`,
|
|
11
11
|
yellow: (s) => `\x1b[33m${s}\x1b[0m`,
|
|
12
12
|
};
|
|
13
|
-
const { bold, dim, green, cyan, red } = colors;
|
|
13
|
+
const { bold, dim, green, cyan, red, yellow } = colors;
|
|
14
14
|
export function printInstalledAgents(agents) {
|
|
15
15
|
if (agents.length === 0) {
|
|
16
16
|
console.log(` ${dim("(none installed)")}`);
|
|
@@ -38,15 +38,21 @@ export async function pickAndInstallAgent(current, options = {}) {
|
|
|
38
38
|
label: a.freeUsage ? `${a.label} ${green(`[${a.freeUsage}]`)}` : a.label,
|
|
39
39
|
hint: a.npmPackage,
|
|
40
40
|
}));
|
|
41
|
+
const othersChoice = { label: "Others", hint: "see all supported agents" };
|
|
41
42
|
const choices = options.allowCancel
|
|
42
|
-
? [{ label: "Cancel", hint: "go back" }, ...installChoices]
|
|
43
|
-
: installChoices;
|
|
43
|
+
? [{ label: "Cancel", hint: "go back" }, ...installChoices, othersChoice]
|
|
44
|
+
: [...installChoices, othersChoice];
|
|
44
45
|
const message = options.message ?? `\n${bold("Select an agent to install:")}`;
|
|
45
46
|
const idx = await selectFromList(message, choices);
|
|
46
47
|
if (idx === null)
|
|
47
48
|
return null;
|
|
48
49
|
if (options.allowCancel && idx === 0)
|
|
49
50
|
return null;
|
|
51
|
+
if (idx === choices.length - 1) {
|
|
52
|
+
console.log(`\n${bold("More agents:")} ${cyan("https://www.palmier.me/agents")}`);
|
|
53
|
+
console.log(`Install one with ${cyan("npm install -g <package>")}, then re-run this command.`);
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
50
56
|
const choice = missing[options.allowCancel ? idx - 1 : idx];
|
|
51
57
|
if (!installAgentPackage(choice))
|
|
52
58
|
return null;
|
|
@@ -91,13 +97,23 @@ export async function pickAndUninstallAgent(current) {
|
|
|
91
97
|
if (idx === null || idx === 0)
|
|
92
98
|
return null;
|
|
93
99
|
const target = uninstallable[idx - 1];
|
|
94
|
-
if (!target
|
|
100
|
+
if (!uninstallAgent(target))
|
|
95
101
|
return null;
|
|
96
|
-
if (!uninstallAgentPackage(target.npmPackage))
|
|
97
|
-
return null;
|
|
98
|
-
console.log(green(` ${target.label} uninstalled.`));
|
|
99
102
|
return target.key;
|
|
100
103
|
}
|
|
104
|
+
/** Uninstall a single agent's npm package. Logs success/failure to stdout.
|
|
105
|
+
* Shared between the `palmier agents` interactive picker and the bulk
|
|
106
|
+
* managed-agent removal in `palmier uninstall`. */
|
|
107
|
+
export function uninstallAgent(agent) {
|
|
108
|
+
if (!agent.npmPackage)
|
|
109
|
+
return false;
|
|
110
|
+
if (!uninstallAgentPackage(agent.npmPackage)) {
|
|
111
|
+
console.log(red(` Skipped ${agent.label}; uninstall it manually with npm uninstall -g ${agent.npmPackage}.`));
|
|
112
|
+
return false;
|
|
113
|
+
}
|
|
114
|
+
console.log(green(` ${agent.label} uninstalled.`));
|
|
115
|
+
return true;
|
|
116
|
+
}
|
|
101
117
|
function installAgentPackage(agent) {
|
|
102
118
|
console.log(`\nInstalling ${cyan(agent.npmPackage)}...\n`);
|
|
103
119
|
const cmd = `npm install -g ${agent.npmPackage}`;
|
|
@@ -120,6 +136,28 @@ function installAgentPackage(agent) {
|
|
|
120
136
|
}
|
|
121
137
|
return true;
|
|
122
138
|
}
|
|
139
|
+
export function uninstallManagedAgents(agents) {
|
|
140
|
+
const managed = agents.filter((a) => a.version && a.npmPackage);
|
|
141
|
+
if (managed.length === 0) {
|
|
142
|
+
console.log(`\n${dim("No Palmier-managed agent CLIs to uninstall.")}`);
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
console.log(`\n${bold(`Uninstalling ${managed.length} Palmier-managed agent ${managed.length === 1 ? "CLI" : "CLIs"}...`)}`);
|
|
146
|
+
let succeeded = 0;
|
|
147
|
+
for (let i = 0; i < managed.length; i++) {
|
|
148
|
+
const agent = managed[i];
|
|
149
|
+
console.log(`\n${dim(`[${i + 1}/${managed.length}]`)} ${agent.label}`);
|
|
150
|
+
if (uninstallAgent(agent))
|
|
151
|
+
succeeded++;
|
|
152
|
+
}
|
|
153
|
+
const failed = managed.length - succeeded;
|
|
154
|
+
if (failed === 0) {
|
|
155
|
+
console.log(`\n${green(`Uninstalled ${succeeded} agent ${succeeded === 1 ? "CLI" : "CLIs"}.`)}`);
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
console.log(`\n${yellow(`Uninstalled ${succeeded} of ${managed.length} agent CLIs (${failed} skipped).`)}`);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
123
161
|
function uninstallAgentPackage(npmPackage) {
|
|
124
162
|
console.log(`\nUninstalling ${cyan(npmPackage)}...\n`);
|
|
125
163
|
const cmd = `npm uninstall -g ${npmPackage}`;
|
package/dist/commands/run.js
CHANGED
|
@@ -227,8 +227,21 @@ export async function runCommand(taskId) {
|
|
|
227
227
|
transientPermissions: [],
|
|
228
228
|
};
|
|
229
229
|
if (task.frontmatter.command) {
|
|
230
|
-
|
|
231
|
-
|
|
230
|
+
let outcome;
|
|
231
|
+
// Command-triggered tasks auto-restart when the underlying command exits
|
|
232
|
+
// on its own — only a user abort breaks the loop.
|
|
233
|
+
while (true) {
|
|
234
|
+
const result = await runCommandTriggeredMode(ctx);
|
|
235
|
+
outcome = resolveOutcome(taskDir, result.outcome);
|
|
236
|
+
if (outcome === "aborted")
|
|
237
|
+
break;
|
|
238
|
+
console.log(`Task ${taskId} command exited (${outcome}); auto-restarting.`);
|
|
239
|
+
await new Promise((r) => setTimeout(r, 1000));
|
|
240
|
+
if (resolveOutcome(taskDir, "finished") === "aborted") {
|
|
241
|
+
outcome = "aborted";
|
|
242
|
+
break;
|
|
243
|
+
}
|
|
244
|
+
}
|
|
232
245
|
appendRunMessage(taskDir, runId, { role: "status", time: Date.now(), content: "", type: outcome });
|
|
233
246
|
await publishTaskEvent(nc, config, taskDir, taskId, outcome, taskName, runId);
|
|
234
247
|
console.log(`Task ${taskId} completed (command-triggered).`);
|
|
@@ -1,7 +1,20 @@
|
|
|
1
1
|
import { getPlatform } from "../platform/index.js";
|
|
2
|
+
import { loadConfig } from "../config.js";
|
|
3
|
+
import { uninstallManagedAgents } from "../agents/wizard.js";
|
|
2
4
|
export async function uninstallCommand() {
|
|
5
|
+
console.log("Stopping daemon and removing scheduled tasks...");
|
|
3
6
|
const platform = getPlatform();
|
|
4
7
|
platform.uninstallDaemon();
|
|
5
|
-
console.log("
|
|
8
|
+
console.log("Daemon stopped and scheduled tasks removed.");
|
|
9
|
+
let config = null;
|
|
10
|
+
try {
|
|
11
|
+
config = loadConfig();
|
|
12
|
+
}
|
|
13
|
+
catch { /* host not initialized */ }
|
|
14
|
+
if (config?.agents) {
|
|
15
|
+
uninstallManagedAgents(config.agents);
|
|
16
|
+
}
|
|
17
|
+
console.log("\nUninstall finished.");
|
|
18
|
+
console.log("To remove the palmier package itself: npm uninstall -g palmier");
|
|
6
19
|
console.log("To also remove configuration and task data, see https://github.com/caihongxu/palmier#uninstalling");
|
|
7
20
|
}
|
|
@@ -84,7 +84,7 @@ ${d}`),g(_);return}f(null,j),s.strategy===xr.Count&&(m--,m===0&&g()),s.strategy=
|
|
|
84
84
|
|
|
85
85
|
${f.stack}`),d.unsubscribe(),c.reject(m)):(m=gx(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 xx(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(Ne.errorForCode(ke.ConnectionClosed)):this.protocol.flush()}drain(){return this.isClosed()?Promise.reject(Ne.errorForCode(ke.ConnectionClosed)):this.isDraining()?Promise.reject(Ne.errorForCode(ke.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 sn;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 Bk(this,t);if(t.checkAPI!==!1)try{await r.getAccountInfo()}catch(s){const l=s;throw l.code===ke.NoResponders&&(l.code=ke.JetStreamNotEnabled),l}return r}jetstream(t={}){return new Hd(this,t)}getServerVersion(){const t=this.info;return t?ms(t.version):void 0}async rtt(){if(!this.protocol._closed&&!this.protocol.connected)throw Ne.errorForCode(ke.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 Ik(this)),this._services}reconnect(){return this.isClosed()?Promise.reject(Ne.errorForCode(ke.ConnectionClosed)):this.isDraining()?Promise.reject(Ne.errorForCode(ke.ConnectionDraining)):this.protocol.reconnect()}}class Ik{constructor(t){C(this,"nc");this.nc=t}add(t){try{return new Vl(this.nc,t).start()}catch(r){return Promise.reject(r)}}client(t,r){return new wk(this.nc,t,r)}}class Fk{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(Uu)||"PUT"}get length(){const t=this.sm.header.get(kn.MessageSizeHdr)||"";return t!==""?parseInt(t,10):this.sm.data.length}json(){return this.sm.json()}string(){return this.sm.string()}}class $k{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(Ld(this.sm.info.timestampNanos))}get revision(){return this.sm.seq}get operation(){var t;return((t=this.sm.headers)==null?void 0:t.get(Uu))||"PUT"}get delta(){return this.sm.info.pending}get length(){var r;const t=((r=this.sm.headers)==null?void 0:r.get(kn.MessageSizeHdr))||"";return t!==""?parseInt(t,10):this.sm.data.length}json(){return this.sm.json()}string(){return this.sm.string()}}class Rx extends w2{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 Ne(`unable to recreate ordered consumer ${u.stream} at seq ${r}`,ke.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(Ld(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=t2(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 _=((x=(g=this.info)==null?void 0:g.ordered_consumer_sequence)==null?void 0:x.stream_seq)||0;return this._resetOrderedConsumer(_+1),(w=this.monitor)==null||w.restart(),!1}return!u.noIterator};this.monitor=new Ud(r,c,l)}_checkHbOrderConsumer(r){const s=r.headers.get(kn.ConsumerStalledHdr);s!==""&&this.js.nc.publish(s);const l=parseInt(r.headers.get(kn.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 Yk extends Rx{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(ht.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=zt(f));let d=0;if(t.idle_heartbeat&&t.idle_heartbeat>0&&(d=t.idle_heartbeat,c.idle_heartbeat=zt(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 Vk(e,t){return e?Jk(t):Gk(t)}function Gk(e){return(t,r)=>t?[t,null]:(t=ua(r),t?[t,null]:[null,Hl(r,e)])}function Jk(e){return(t,r)=>{if(t)return[t,null];const s=ua(r);return s!==null?[Mx(s),null]:[null,Hl(r,e)]}}function Mx(e){if(e!==null)switch(e.code){case ke.JetStream404NoMessages:case ke.JetStream408RequestTimeout:return null;case ke.JetStream409:return n2(e)?e:null;default:return e}return null}function Xk(e){e&&e.ack()}function Kk(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 Qk{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=Kk(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=Ut();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 xx(u.muxSubscriptions,this.msg.reply,{timeout:t.timeout},c);u.request(f);try{u.publish(this.msg.reply,L0,{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(L0)}nak(t){let r=Ok;t&&(r=Ou().encode(`-NAK ${JSON.stringify({delay:zt(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=zt(r.expires));const l=vr().encode(s),u=ga.concat(Rk,Dk,l),c=t?{reply:t}:void 0;this.msg.respond(u,c)}term(t=""){let r=Mk;(t==null?void 0:t.length)>0&&(r=Ou().encode(`+TERM ${t}`)),this.doAck(r)}json(){return this.msg.json()}string(){return this.msg.string()}}const Zk="1.30.3",Wk="nats.ws";class eE{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=Zk,this.lang=Wk,this.connected=!1,this.done=!1,this.socketClosed=!1,this.encrypted=!1,this.peeked=!1,this.yields=[],this.signal=Ut(),this.closedNotification=Ut()}async connect(t,r){const s=Ut();if(r.tls)return s.reject(new Ne("tls",ke.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=A2(c);if(f!==""){const d=dk.exec(f);if(!d){r.debug&&console.error("!!!",fu(c)),s.reject(new Error("unexpected response from server"));return}try{const m=JSON.parse(d[1]);fk(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 Ne(c.message,ke.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(`> ${fu(t[r])}`),yield t[r];if(this.done)break;this.yields.length===0&&(t.length=0,this.yields=t,this.signal=Ut())}}isEncrypted(){return this.connected&&this.encrypted}send(t){if(!this.isDiscarded())try{this.socket.send(t.buffer),this.options.debug&&console.info(`< ${fu(t)}`);return}catch(r){this.options.debug&&console.error(`!!! ${fu(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 tE(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 Dx(e={}){return S2({defaultPort:443,urlParseFn:tE,factory:()=>new eE}),qd.connect(e)}/*! Capacitor: https://capacitorjs.com/ - MIT License */var ya;(function(e){e.Unimplemented="UNIMPLEMENTED",e.Unavailable="UNAVAILABLE"})(ya||(ya={}));class Th extends Error{constructor(t,r,s){super(t),this.message=t,this.code=r,this.data=s}}const nE=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"},rE=e=>{const t=e.CapacitorCustomPlatform||null,r=e.Capacitor||{},s=r.Plugins=r.Plugins||{},l=()=>t!==null?t.name:nE(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 _=l(),j=f(g);let D;const N=async()=>(!D&&_ in x?D=typeof x[_]=="function"?D=await x[_]():D=x[_]:t!==null&&!D&&"web"in x&&(D=typeof x.web=="function"?D=await x.web():D=x.web),D),H=($,q)=>{var L,G;if(j){const J=j==null?void 0:j.methods.find(oe=>q===oe.name);if(J)return J.rtype==="promise"?oe=>r.nativePromise(g,q.toString(),oe):(oe,le)=>r.nativeCallback(g,q.toString(),oe,le);if($)return(L=$[q])===null||L===void 0?void 0:L.bind($)}else{if($)return(G=$[q])===null||G===void 0?void 0:G.bind($);throw new Th(`"${g}" plugin is not implemented on ${_}`,ya.Unimplemented)}},F=$=>{let q;const L=(...G)=>{const J=N().then(oe=>{const le=H(oe,$);if(le){const K=le(...G);return q=K==null?void 0:K.remove,K}else throw new Th(`"${g}.${$}()" is not implemented on ${_}`,ya.Unimplemented)});return $==="addListener"&&(J.remove=async()=>q()),J};return L.toString=()=>`${$.toString()}() { [capacitor code] }`,Object.defineProperty(L,"name",{value:$,writable:!1,configurable:!1}),L},fe=F("addListener"),z=F("removeListener"),R=($,q)=>{const L=fe({eventName:$},q),G=async()=>{const oe=await L;z({eventName:$,callbackId:oe},q)},J=new Promise(oe=>L.then(()=>oe({remove:G})));return J.remove=async()=>{console.warn("Using addListener() without 'await' is deprecated."),await G()},J},ee=new Proxy({},{get($,q){switch(q){case"$$typeof":return;case"toJSON":return()=>({});case"addListener":return j?R:fe;case"removeListener":return z;default:return F(q)}}});return s[g]=ee,m.set(g,{name:g,proxy:ee,platforms:new Set([...Object.keys(x),...j?[_]:[]])}),ee};return r.convertFileSrc||(r.convertFileSrc=g=>g),r.getPlatform=l,r.handleError=d,r.isNativePlatform=u,r.isPluginAvailable=c,r.registerPlugin=y,r.Exception=Th,r.DEBUG=!!r.DEBUG,r.isLoggingEnabled=!!r.isLoggingEnabled,r},iE=e=>e.Capacitor=rE(e),Jn=iE(typeof globalThis<"u"?globalThis:typeof self<"u"?self:typeof window<"u"?window:typeof global<"u"?global:{}),ys=Jn.registerPlugin;class Id{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 Jn.Exception(t,ya.Unimplemented)}unavailable(t="not available"){return new Jn.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 U0=e=>encodeURIComponent(e).replace(/%(2[346B]|5E|60|7C)/g,decodeURIComponent).replace(/[()]/g,escape),B0=e=>e.replace(/(%[\dA-F]{2})+/gi,decodeURIComponent);class sE extends Id{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=B0(l).trim(),u=B0(u).trim(),r[l]=u}),r}async setCookie(t){try{const r=U0(t.key),s=U0(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 sE});const aE=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)}),lE=(e={})=>{const t=Object.keys(e);return Object.keys(e).map(l=>l.toLocaleLowerCase()).reduce((l,u,c)=>(l[u]=e[t[c]],l),{})},oE=(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,uE=(e,t={})=>{const r=Object.assign({method:e.method||"GET",headers:e.headers},t),l=lE(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 cE extends Id{async request(t){const r=uE(t,t.webFetchExtra),s=oE(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 aE(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 cE});var P0;(function(e){e.Dark="DARK",e.Light="LIGHT",e.Default="DEFAULT"})(P0||(P0={}));var H0;(function(e){e.StatusBar="StatusBar",e.NavigationBar="NavigationBar"})(H0||(H0={}));class fE extends Id{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 fE});const hE="modulepreload",dE=function(e){return"/"+e},q0={},Fd=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=dE(m),m in q0)return;q0[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":hE,y||(x.as="script"),x.crossOrigin="",x.href=m,d&&x.setAttribute("nonce",d),document.head.appendChild(x),y)return new Promise((w,_)=>{x.addEventListener("load",w),x.addEventListener("error",()=>_(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)})},dd=ys("App",{web:()=>Fd(()=>import("./web-BQQlSLPT.js"),[]).then(e=>new e.AppWeb)}),mE=ys("Network",{web:()=>Fd(()=>import("./web-CpqzX7Jk.js"),[]).then(e=>new e.NetworkWeb)}),Bu=Jn.isNativePlatform()?"https://app.palmier.me":"";async function Lx(e,t,r,s){const l=`${Bu}${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 pE(e,t,r){return Lx("POST",e,t)}function gE(e,t){return Lx("GET",e,void 0)}const I0=Jn.isNativePlatform(),zx=A.createContext(null),yE=2e3,jh=6e3,bE=1500,xE=6e4;function vE({children:e,activeHost:t}){const[r,s]=A.useState(null),[l,u]=A.useState(!1),c=A.useRef(null),[f,d]=A.useState(!1),[m,y]=A.useState(!1),[g,x]=A.useState(!1),[w,_]=A.useState(!1),j=A.useRef(Ou()),D=A.useRef(new Set),N=A.useRef(0),H=!!t.directUrl,F=I0&&!H&&!!t.lanUrl&&w,fe=m||g?"disconnected":H?f?"direct":"connecting":l?F?"lan":"nats":"connecting",z=fe!=="connecting"&&fe!=="disconnected";A.useEffect(()=>{y(!1),x(!1)},[t.hostId,t.clientToken]),A.useEffect(()=>{if(!I0||H||!t.lanUrl){_(!1);return}let $=!1;const q=t.lanUrl,L=t.hostId;async function G(){console.log("[HOST/LAN] probing",q);try{const K=await fetch(`${q}/health`,{signal:AbortSignal.timeout(bE)});if($)return;if(!K.ok){console.log("[HOST/LAN] probe got non-ok:",K.status),_(!1);return}const U=await K.json(),W=U.hostId===L;W?console.log("[HOST/LAN] reachable"):console.log("[HOST/LAN] hostId mismatch — got:",U.hostId,"expected:",L),_(W)}catch(K){$||(console.log("[HOST/LAN] probe failed:",K instanceof Error?K.message:K),_(!1))}}G();const J=window.setInterval(G,xE),oe=dd.addListener("appStateChange",K=>{K.isActive&&G()}),le=mE.addListener("networkStatusChange",()=>G());return()=>{$=!0,clearInterval(J),oe.then(K=>K.remove()),le.then(K=>K.remove())}},[t.hostId,t.lanUrl,H]),A.useEffect(()=>{if(H){c.current&&(c.current.close().catch(()=>{}),c.current=null,s(null),u(!1));return}let $=!1,q=1e3;const L=3e4;async function G(){for(;!$;)try{const J=await fetch(`${Bu}/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 oe=await J.json();if(!oe.natsWsUrl){console.error("[NATS] Relay returned empty natsWsUrl — treating as terminal"),x(!0);return}if($)return;console.log("[NATS] Connecting to",oe.natsWsUrl);const le=await Dx({servers:oe.natsWsUrl,authenticator:Ex(oe.natsJwt,new TextEncoder().encode(oe.natsNkeySeed)),pingInterval:3e4,maxPingOut:2});if($){le.close().catch(()=>{});return}if(console.log("[NATS] Connected"),c.current=le,s(le),u(!0),q=1e3,await le.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(oe=>setTimeout(oe,q)),q=Math.min(q*2,L)}}return G(),()=>{$=!0,c.current&&(c.current.close().catch(()=>{}),c.current=null,s(null),u(!1))}},[H,t]),A.useEffect(()=>{if(H)return;const $=dd.addListener("appStateChange",q=>{if(!q.isActive||!c.current)return;const L=c.current;Promise.race([L.flush(),new Promise((G,J)=>setTimeout(()=>J(new Error("ping timeout")),2e3))]).catch(()=>{console.log("[NATS] Resume probe failed — cycling conn"),L.close().catch(()=>{})})});return()=>{$.then(q=>q.remove())}},[H]),A.useEffect(()=>{if(!H){d(!1);return}const $=new AbortController;async function q(){var oe;const G=new AbortController,J=setTimeout(()=>G.abort(),yE);$.signal.addEventListener("abort",()=>G.abort());try{const le=await fetch(`${t.directUrl}/events`,{headers:{Authorization:`Bearer ${t.clientToken}`},signal:G.signal});return clearTimeout(J),le.ok?((oe=le.body)==null?void 0:oe.getReader())??null:null}catch{return clearTimeout(J),null}}async function L(G){d(!0),console.log("[HOST] SSE connected to",t.directUrl),N.current=Date.now();function J(){setTimeout(()=>{$.signal.aborted||Date.now()-N.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 oe=new TextDecoder;let le="";try{for(;;){const{done:K,value:U}=await G.read();if(K)break;le+=oe.decode(U,{stream:!0}),N.current=Date.now(),J();const W=le.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 xx(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(Ne.errorForCode(ke.ConnectionClosed)):this.protocol.flush()}drain(){return this.isClosed()?Promise.reject(Ne.errorForCode(ke.ConnectionClosed)):this.isDraining()?Promise.reject(Ne.errorForCode(ke.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 sn;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 Bk(this,t);if(t.checkAPI!==!1)try{await r.getAccountInfo()}catch(s){const l=s;throw l.code===ke.NoResponders&&(l.code=ke.JetStreamNotEnabled),l}return r}jetstream(t={}){return new Hd(this,t)}getServerVersion(){const t=this.info;return t?ms(t.version):void 0}async rtt(){if(!this.protocol._closed&&!this.protocol.connected)throw Ne.errorForCode(ke.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 Ik(this)),this._services}reconnect(){return this.isClosed()?Promise.reject(Ne.errorForCode(ke.ConnectionClosed)):this.isDraining()?Promise.reject(Ne.errorForCode(ke.ConnectionDraining)):this.protocol.reconnect()}}class Ik{constructor(t){C(this,"nc");this.nc=t}add(t){try{return new Vl(this.nc,t).start()}catch(r){return Promise.reject(r)}}client(t,r){return new wk(this.nc,t,r)}}class Fk{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(Uu)||"PUT"}get length(){const t=this.sm.header.get(kn.MessageSizeHdr)||"";return t!==""?parseInt(t,10):this.sm.data.length}json(){return this.sm.json()}string(){return this.sm.string()}}class $k{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(Ld(this.sm.info.timestampNanos))}get revision(){return this.sm.seq}get operation(){var t;return((t=this.sm.headers)==null?void 0:t.get(Uu))||"PUT"}get delta(){return this.sm.info.pending}get length(){var r;const t=((r=this.sm.headers)==null?void 0:r.get(kn.MessageSizeHdr))||"";return t!==""?parseInt(t,10):this.sm.data.length}json(){return this.sm.json()}string(){return this.sm.string()}}class Rx extends w2{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 Ne(`unable to recreate ordered consumer ${u.stream} at seq ${r}`,ke.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(Ld(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=t2(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 _=((x=(g=this.info)==null?void 0:g.ordered_consumer_sequence)==null?void 0:x.stream_seq)||0;return this._resetOrderedConsumer(_+1),(w=this.monitor)==null||w.restart(),!1}return!u.noIterator};this.monitor=new Ud(r,c,l)}_checkHbOrderConsumer(r){const s=r.headers.get(kn.ConsumerStalledHdr);s!==""&&this.js.nc.publish(s);const l=parseInt(r.headers.get(kn.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 Yk extends Rx{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(ht.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=zt(f));let d=0;if(t.idle_heartbeat&&t.idle_heartbeat>0&&(d=t.idle_heartbeat,c.idle_heartbeat=zt(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 Vk(e,t){return e?Jk(t):Gk(t)}function Gk(e){return(t,r)=>t?[t,null]:(t=ua(r),t?[t,null]:[null,Hl(r,e)])}function Jk(e){return(t,r)=>{if(t)return[t,null];const s=ua(r);return s!==null?[Mx(s),null]:[null,Hl(r,e)]}}function Mx(e){if(e!==null)switch(e.code){case ke.JetStream404NoMessages:case ke.JetStream408RequestTimeout:return null;case ke.JetStream409:return n2(e)?e:null;default:return e}return null}function Xk(e){e&&e.ack()}function Kk(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 Qk{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=Kk(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=Ut();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 xx(u.muxSubscriptions,this.msg.reply,{timeout:t.timeout},c);u.request(f);try{u.publish(this.msg.reply,L0,{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(L0)}nak(t){let r=Ok;t&&(r=Ou().encode(`-NAK ${JSON.stringify({delay:zt(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=zt(r.expires));const l=vr().encode(s),u=ga.concat(Rk,Dk,l),c=t?{reply:t}:void 0;this.msg.respond(u,c)}term(t=""){let r=Mk;(t==null?void 0:t.length)>0&&(r=Ou().encode(`+TERM ${t}`)),this.doAck(r)}json(){return this.msg.json()}string(){return this.msg.string()}}const Zk="1.30.3",Wk="nats.ws";class eE{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=Zk,this.lang=Wk,this.connected=!1,this.done=!1,this.socketClosed=!1,this.encrypted=!1,this.peeked=!1,this.yields=[],this.signal=Ut(),this.closedNotification=Ut()}async connect(t,r){const s=Ut();if(r.tls)return s.reject(new Ne("tls",ke.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=A2(c);if(f!==""){const d=dk.exec(f);if(!d){r.debug&&console.error("!!!",fu(c)),s.reject(new Error("unexpected response from server"));return}try{const m=JSON.parse(d[1]);fk(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 Ne(c.message,ke.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(`> ${fu(t[r])}`),yield t[r];if(this.done)break;this.yields.length===0&&(t.length=0,this.yields=t,this.signal=Ut())}}isEncrypted(){return this.connected&&this.encrypted}send(t){if(!this.isDiscarded())try{this.socket.send(t.buffer),this.options.debug&&console.info(`< ${fu(t)}`);return}catch(r){this.options.debug&&console.error(`!!! ${fu(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 tE(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 Dx(e={}){return S2({defaultPort:443,urlParseFn:tE,factory:()=>new eE}),qd.connect(e)}/*! Capacitor: https://capacitorjs.com/ - MIT License */var ya;(function(e){e.Unimplemented="UNIMPLEMENTED",e.Unavailable="UNAVAILABLE"})(ya||(ya={}));class Th extends Error{constructor(t,r,s){super(t),this.message=t,this.code=r,this.data=s}}const nE=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"},rE=e=>{const t=e.CapacitorCustomPlatform||null,r=e.Capacitor||{},s=r.Plugins=r.Plugins||{},l=()=>t!==null?t.name:nE(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 _=l(),j=f(g);let D;const N=async()=>(!D&&_ in x?D=typeof x[_]=="function"?D=await x[_]():D=x[_]:t!==null&&!D&&"web"in x&&(D=typeof x.web=="function"?D=await x.web():D=x.web),D),H=($,q)=>{var L,G;if(j){const J=j==null?void 0:j.methods.find(oe=>q===oe.name);if(J)return J.rtype==="promise"?oe=>r.nativePromise(g,q.toString(),oe):(oe,le)=>r.nativeCallback(g,q.toString(),oe,le);if($)return(L=$[q])===null||L===void 0?void 0:L.bind($)}else{if($)return(G=$[q])===null||G===void 0?void 0:G.bind($);throw new Th(`"${g}" plugin is not implemented on ${_}`,ya.Unimplemented)}},F=$=>{let q;const L=(...G)=>{const J=N().then(oe=>{const le=H(oe,$);if(le){const K=le(...G);return q=K==null?void 0:K.remove,K}else throw new Th(`"${g}.${$}()" is not implemented on ${_}`,ya.Unimplemented)});return $==="addListener"&&(J.remove=async()=>q()),J};return L.toString=()=>`${$.toString()}() { [capacitor code] }`,Object.defineProperty(L,"name",{value:$,writable:!1,configurable:!1}),L},fe=F("addListener"),z=F("removeListener"),R=($,q)=>{const L=fe({eventName:$},q),G=async()=>{const oe=await L;z({eventName:$,callbackId:oe},q)},J=new Promise(oe=>L.then(()=>oe({remove:G})));return J.remove=async()=>{console.warn("Using addListener() without 'await' is deprecated."),await G()},J},ee=new Proxy({},{get($,q){switch(q){case"$$typeof":return;case"toJSON":return()=>({});case"addListener":return j?R:fe;case"removeListener":return z;default:return F(q)}}});return s[g]=ee,m.set(g,{name:g,proxy:ee,platforms:new Set([...Object.keys(x),...j?[_]:[]])}),ee};return r.convertFileSrc||(r.convertFileSrc=g=>g),r.getPlatform=l,r.handleError=d,r.isNativePlatform=u,r.isPluginAvailable=c,r.registerPlugin=y,r.Exception=Th,r.DEBUG=!!r.DEBUG,r.isLoggingEnabled=!!r.isLoggingEnabled,r},iE=e=>e.Capacitor=rE(e),Jn=iE(typeof globalThis<"u"?globalThis:typeof self<"u"?self:typeof window<"u"?window:typeof global<"u"?global:{}),ys=Jn.registerPlugin;class Id{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 Jn.Exception(t,ya.Unimplemented)}unavailable(t="not available"){return new Jn.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 U0=e=>encodeURIComponent(e).replace(/%(2[346B]|5E|60|7C)/g,decodeURIComponent).replace(/[()]/g,escape),B0=e=>e.replace(/(%[\dA-F]{2})+/gi,decodeURIComponent);class sE extends Id{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=B0(l).trim(),u=B0(u).trim(),r[l]=u}),r}async setCookie(t){try{const r=U0(t.key),s=U0(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 sE});const aE=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)}),lE=(e={})=>{const t=Object.keys(e);return Object.keys(e).map(l=>l.toLocaleLowerCase()).reduce((l,u,c)=>(l[u]=e[t[c]],l),{})},oE=(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,uE=(e,t={})=>{const r=Object.assign({method:e.method||"GET",headers:e.headers},t),l=lE(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 cE extends Id{async request(t){const r=uE(t,t.webFetchExtra),s=oE(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 aE(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 cE});var P0;(function(e){e.Dark="DARK",e.Light="LIGHT",e.Default="DEFAULT"})(P0||(P0={}));var H0;(function(e){e.StatusBar="StatusBar",e.NavigationBar="NavigationBar"})(H0||(H0={}));class fE extends Id{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 fE});const hE="modulepreload",dE=function(e){return"/"+e},q0={},Fd=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=dE(m),m in q0)return;q0[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":hE,y||(x.as="script"),x.crossOrigin="",x.href=m,d&&x.setAttribute("nonce",d),document.head.appendChild(x),y)return new Promise((w,_)=>{x.addEventListener("load",w),x.addEventListener("error",()=>_(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)})},dd=ys("App",{web:()=>Fd(()=>import("./web-BZCAN0xX.js"),[]).then(e=>new e.AppWeb)}),mE=ys("Network",{web:()=>Fd(()=>import("./web-B0XfObWX.js"),[]).then(e=>new e.NetworkWeb)}),Bu=Jn.isNativePlatform()?"https://app.palmier.me":"";async function Lx(e,t,r,s){const l=`${Bu}${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 pE(e,t,r){return Lx("POST",e,t)}function gE(e,t){return Lx("GET",e,void 0)}const I0=Jn.isNativePlatform(),zx=A.createContext(null),yE=2e3,jh=6e3,bE=1500,xE=6e4;function vE({children:e,activeHost:t}){const[r,s]=A.useState(null),[l,u]=A.useState(!1),c=A.useRef(null),[f,d]=A.useState(!1),[m,y]=A.useState(!1),[g,x]=A.useState(!1),[w,_]=A.useState(!1),j=A.useRef(Ou()),D=A.useRef(new Set),N=A.useRef(0),H=!!t.directUrl,F=I0&&!H&&!!t.lanUrl&&w,fe=m||g?"disconnected":H?f?"direct":"connecting":l?F?"lan":"nats":"connecting",z=fe!=="connecting"&&fe!=="disconnected";A.useEffect(()=>{y(!1),x(!1)},[t.hostId,t.clientToken]),A.useEffect(()=>{if(!I0||H||!t.lanUrl){_(!1);return}let $=!1;const q=t.lanUrl,L=t.hostId;async function G(){console.log("[HOST/LAN] probing",q);try{const K=await fetch(`${q}/health`,{signal:AbortSignal.timeout(bE)});if($)return;if(!K.ok){console.log("[HOST/LAN] probe got non-ok:",K.status),_(!1);return}const U=await K.json(),W=U.hostId===L;W?console.log("[HOST/LAN] reachable"):console.log("[HOST/LAN] hostId mismatch — got:",U.hostId,"expected:",L),_(W)}catch(K){$||(console.log("[HOST/LAN] probe failed:",K instanceof Error?K.message:K),_(!1))}}G();const J=window.setInterval(G,xE),oe=dd.addListener("appStateChange",K=>{K.isActive&&G()}),le=mE.addListener("networkStatusChange",()=>G());return()=>{$=!0,clearInterval(J),oe.then(K=>K.remove()),le.then(K=>K.remove())}},[t.hostId,t.lanUrl,H]),A.useEffect(()=>{if(H){c.current&&(c.current.close().catch(()=>{}),c.current=null,s(null),u(!1));return}let $=!1,q=1e3;const L=3e4;async function G(){for(;!$;)try{const J=await fetch(`${Bu}/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 oe=await J.json();if(!oe.natsWsUrl){console.error("[NATS] Relay returned empty natsWsUrl — treating as terminal"),x(!0);return}if($)return;console.log("[NATS] Connecting to",oe.natsWsUrl);const le=await Dx({servers:oe.natsWsUrl,authenticator:Ex(oe.natsJwt,new TextEncoder().encode(oe.natsNkeySeed)),pingInterval:3e4,maxPingOut:2});if($){le.close().catch(()=>{});return}if(console.log("[NATS] Connected"),c.current=le,s(le),u(!0),q=1e3,await le.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(oe=>setTimeout(oe,q)),q=Math.min(q*2,L)}}return G(),()=>{$=!0,c.current&&(c.current.close().catch(()=>{}),c.current=null,s(null),u(!1))}},[H,t]),A.useEffect(()=>{if(H)return;const $=dd.addListener("appStateChange",q=>{if(!q.isActive||!c.current)return;const L=c.current;Promise.race([L.flush(),new Promise((G,J)=>setTimeout(()=>J(new Error("ping timeout")),2e3))]).catch(()=>{console.log("[NATS] Resume probe failed — cycling conn"),L.close().catch(()=>{})})});return()=>{$.then(q=>q.remove())}},[H]),A.useEffect(()=>{if(!H){d(!1);return}const $=new AbortController;async function q(){var oe;const G=new AbortController,J=setTimeout(()=>G.abort(),yE);$.signal.addEventListener("abort",()=>G.abort());try{const le=await fetch(`${t.directUrl}/events`,{headers:{Authorization:`Bearer ${t.clientToken}`},signal:G.signal});return clearTimeout(J),le.ok?((oe=le.body)==null?void 0:oe.getReader())??null:null}catch{return clearTimeout(J),null}}async function L(G){d(!0),console.log("[HOST] SSE connected to",t.directUrl),N.current=Date.now();function J(){setTimeout(()=>{$.signal.aborted||Date.now()-N.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 oe=new TextDecoder;let le="";try{for(;;){const{done:K,value:U}=await G.read();if(K)break;le+=oe.decode(U,{stream:!0}),N.current=Date.now(),J();const W=le.split(`
|
|
88
88
|
`);le=W.pop()??"";for(const ue of W)if(ue.startsWith("data: ")){const we=ue.slice(6);try{const M=JSON.parse(we);if(M.task_id&&M.event_type){const P=`host-event.${t.hostId}.${M.task_id}`;for(const te of D.current)te({subject:P,data:j.current.encode(we)})}}catch{}}}}catch{}}return(async()=>{const G=await q();G&&await L(G)})(),()=>{$.abort(),d(!1)}},[t,H]);const R=A.useCallback(async($,q,L)=>{function G(le){le&&typeof le=="object"&&le.error==="Unauthorized"&&y(!0)}async function J(le,K){console.log(`[HOST/${K}] → ${$}`,q??"");const U=await fetch(`${le}/rpc/${$}`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t.clientToken}`},body:q!=null?JSON.stringify(q):void 0,signal:L!=null&&L.timeout?AbortSignal.timeout(L.timeout):void 0});if(U.status===401)throw y(!0),new Error("Unauthorized");const W=await U.json();return G(W),console.log(`[HOST/${K}] ← ${$}`,W),W}async function oe(){if(!c.current)throw new Error("Not connected");const le=`host.${t.hostId}.rpc.${$}`,K={...q??{},clientToken:t.clientToken},U=j.current.encode(JSON.stringify(K));console.log(`[HOST/NATS] → ${$}`,q??"");const W=await c.current.request(le,U,{timeout:(L==null?void 0:L.timeout)??1e4}),ue=JSON.parse(j.current.decode(W.data));return G(ue),console.log(`[HOST/NATS] ← ${$}`,ue),ue}if(H)return J(t.directUrl,"HTTP");if(F&&t.lanUrl)try{return await J(t.lanUrl,"LAN")}catch(le){if(le instanceof Error&&le.message==="Unauthorized")throw le;console.log("[HOST/LAN] failed, falling back to NATS:",le),_(!1)}return oe()},[t,H,F]),ee=A.useCallback(($,q)=>{if(H)return D.current.add(q),()=>{D.current.delete(q)};if(c.current){const L=c.current.subscribe(`host-event.${$}.>`);let G=!1;return(async()=>{try{for await(const J of L){if(G)break;q({subject:J.subject,data:J.data})}}catch{}})(),()=>{G=!0,L.unsubscribe()}}return()=>{}},[t,H]);return b.jsx(zx.Provider,{value:{connected:z,mode:fe,nc:r,request:R,subscribeEvents:ee,activeHost:t,unauthorized:m},children:e})}function si(){const e=A.useContext(zx);if(!e)throw new Error("useHostConnection must be used within HostConnectionProvider");return e}const dn=Jn.isNativePlatform()?ys("Device"):null;function wE(e,t){const r=new Date(e),s=new Date,l={year:"numeric",month:"2-digit",day:"2-digit",timeZone:t};return r.toLocaleDateString(void 0,l)===s.toLocaleDateString(void 0,l)?new Intl.DateTimeFormat(void 0,{timeStyle:"short",timeZone:t}).format(r):new Intl.DateTimeFormat(void 0,{dateStyle:"medium",timeStyle:"short",timeZone:t}).format(r)}function $d(){const{activeHost:e}=si(),t=e.timezone;return A.useCallback(r=>wE(r,t),[t])}function SE(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")}`}}function _E(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 Number(((l=t.find(u=>u.type===s))==null?void 0:l.value)??"0")};return{year:r("year"),month:r("month"),day:r("day"),hour:r("hour")%24,minute:r("minute")}}function kE(e,t,r){return new Date(Date.UTC(e,t-1,r)).getUTCDay()}function EE(e,t){return new Date(Date.UTC(e,t,0)).getUTCDate()}function F0(e,t){const r=new Date(Date.UTC(e.year,e.month-1,e.day));return r.setUTCDate(r.getUTCDate()+t),{year:r.getUTCFullYear(),month:r.getUTCMonth()+1,day:r.getUTCDate(),hour:e.hour,minute:e.minute}}function Ol(e,t){return e.year!==t.year?e.year-t.year:e.month!==t.month?e.month-t.month:e.day!==t.day?e.day-t.day:e.hour!==t.hour?e.hour-t.hour:e.minute-t.minute}function CE(e,t){const r=Date.UTC(e.year,e.month-1,e.day,e.hour,e.minute);if(!t)return r;const s=new Intl.DateTimeFormat("en-CA",{timeZone:t,year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1}).formatToParts(new Date(r)),l=c=>{var f;return Number(((f=s.find(d=>d.type===c))==null?void 0:f.value)??"0")},u=Date.UTC(l("year"),l("month")-1,l("day"),l("hour")%24,l("minute"),l("second"));return r-(u-r)}function AE(e,t){const r=e.split(" ");if(r.length!==5)return null;const[s,l,u,,c]=r;if(l==="*"){const y=Number(s);if(Number.isNaN(y))return null;if(y>t.minute)return{...t,minute:y};const g=new Date(Date.UTC(t.year,t.month-1,t.day,t.hour+1,y));return{year:g.getUTCFullYear(),month:g.getUTCMonth()+1,day:g.getUTCDate(),hour:g.getUTCHours(),minute:g.getUTCMinutes()}}const f=Number(s),d=Number(l);if(Number.isNaN(f)||Number.isNaN(d))return null;if(c!=="*"){const y=Number(c);if(Number.isNaN(y))return null;for(let g=0;g<8;g++){const x=F0({...t,hour:d,minute:f},g);if(kE(x.year,x.month,x.day)===y&&Ol(x,t)>0)return x}return null}if(u!=="*"){const y=Number(u);if(Number.isNaN(y))return null;let g=t.year,x=t.month;for(let w=0;w<24;w++){if(y<=EE(g,x)){const _={year:g,month:x,day:y,hour:d,minute:f};if(Ol(_,t)>0)return _}x++,x>12&&(x=1,g++)}return null}const m={...t,hour:d,minute:f};return Ol(m,t)>0?m:F0(m,1)}function TE(e){const t=/^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2})/.exec(e);return t?{year:Number(t[1]),month:Number(t[2]),day:Number(t[3]),hour:Number(t[4]),minute:Number(t[5])}:null}function jE(e,t,r){if(!e||!t||t.length===0||e==="on_new_notification"||e==="on_new_sms")return null;const s=_E(r),l=[];for(const u of t)if(e==="specific_times"){const c=TE(u);c&&Ol(c,s)>0&&l.push(c)}else{const c=AE(u,s);c&&l.push(c)}return l.length===0?null:(l.sort(Ol),CE(l[0],r))}const Ux={};function NE(e){for(const t of e)Ux[t.key]=t.label}function md(e){return Ux[e]??e}const OE=()=>window.matchMedia("(max-width: 600px)").matches;function RE({task:e,lastEvent:t,onEdit:r,onDelete:s,onViewRun:l}){var le;const{request:u,activeHost:c}=si(),f=$d(),d=c.timezone,[m,y]=A.useState(!1),[g,x]=A.useState(!1),[w,_]=A.useState(!1),j=A.useRef(null),D=(t==null?void 0:t.running_state)==="started",N=(((le=e.schedule_values)==null?void 0:le.length)??0)>0,H=e.schedule_type==="on_new_notification"||e.schedule_type==="on_new_sms",fe=!!e.schedule_enabled&&!!e.schedule_type&&(N||H)?D?"var(--color-success)":(t==null?void 0:t.running_state)==="failed"?"var(--color-error)":"var(--color-success)":"var(--color-text-secondary)";A.useEffect(()=>{if(!g)return;function K(U){j.current&&!j.current.contains(U.target)&&x(!1)}return document.addEventListener("mousedown",K),()=>document.removeEventListener("mousedown",K)},[g]);function z(){OE()?_(!0):x(K=>!K)}function R(){x(!1),_(!1)}async function ee(){if(R(),!!confirm("Abort this task?")){y(!0);try{await u("task.abort",{id:e.id})}catch(K){console.error("Abort failed:",K)}finally{y(!1)}}}async function $(){R();try{const K=await u("task.run",{id:e.id});l(e.id,K.run_id)}catch(K){console.error("Run failed:",K)}}async function q(){if(R(),!!confirm("Delete this task? Results and reports will be kept."))try{await u("task.delete",{id:e.id}),s(e.id)}catch(K){console.error("Delete failed:",K)}}const L={started:"Started",finished:"Finished",aborted:"Aborted",failed:"Failed"};function G(){if(e.schedule_type==="on_new_notification")return"On new notification";if(e.schedule_type==="on_new_sms")return"On new SMS";const K=jE(e.schedule_type,e.schedule_values,d);return K===null?"No upcoming runs":`Next: ${f(K)}`}const J=G(),oe=b.jsxs(b.Fragment,{children:[b.jsxs("button",{onClick:()=>{R(),r(e)},children:[b.jsx("span",{className:"menu-icon",children:"✎"}),"Edit"]}),b.jsxs("button",{onClick:()=>{R(),l(e.id)},children:[b.jsx("span",{className:"menu-icon",children:"📄"}),"View All Runs"]}),D?b.jsxs("button",{className:"menu-item-danger",onClick:ee,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:[D?b.jsx("span",{className:"status-spinner",children:b.jsx("span",{})}):b.jsx("span",{className:"status-dot",style:{backgroundColor:fe}}),b.jsx("h3",{className:"task-card-name",children:e.name||e.user_prompt})]}),b.jsx("div",{className:"task-card-actions",onClick:K=>K.stopPropagation(),children:b.jsxs("div",{className:"task-card-menu",ref:j,children:[b.jsx("button",{className:"task-card-menu-btn",onClick:z,"aria-label":"Task actions",children:"⋮"}),g&&b.jsx("div",{className:"task-card-menu-dropdown",children:oe})]})})]}),b.jsxs("div",{className:"task-card-meta",children:[e.agent&&b.jsx("span",{className:"task-card-agent",children:md(e.agent)}),t&&L[t.running_state]&&b.jsxs("span",{className:"task-card-last-event",children:[L[t.running_state]," ",f(t.time_stamp)]}),e.schedule_type&&(N||H)&&b.jsx("span",{className:"task-card-triggers",children:e.schedule_enabled?J:"Schedule disabled"})]})]}),w&&ds.createPortal(b.jsx("div",{className:"bottom-sheet-overlay",onClick:()=>_(!1),children:b.jsxs("div",{className:"bottom-sheet",onClick:K=>K.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:oe})]})}),document.body)]})}function ME({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 DE(){const e=ra.pop();e&&(e.pushed.current=!1,e.close())}let $0=!1;function LE(){$0||($0=!0,window.addEventListener("popstate",DE))}function pd(e,t){const r=A.useRef(!1),s=A.useRef(t);s.current=t;const l=A.useCallback(()=>s.current(),[]),u=A.useRef({close:l,pushed:r});u.current.close=l,A.useEffect(()=>{if(e&&!r.current)LE(),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]),A.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 zE=["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],UE=["specific_times","hourly","daily","weekly","monthly"];function pu(e){return UE.includes(e)}function BE(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 PE(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 Bx(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 PE(t)}function HE(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 qE(e){return e.schedule==="specific_times"?e.onceDate?`${e.onceDate}T${e.onceTime}`:null:HE(e)}function Nh(e){return e==="specific_times"?"specific_times":e==="on_new_notification"?"on_new_notification":e==="on_new_sms"?"on_new_sms":"crons"}function Oh(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?Bx(t,r).schedule:"ondemand"}function IE({initial:e,agents:t,hostPlatform:r,isNotificationListener:s,onSaved:l,onRun:u,onCancel:c}){var Je;const{request:f,activeHost:d}=si(),{setHostLastAgent:m}=qi(),y=()=>{var Le;const pe=d.lastAgent,Pe=t.map(Ct=>Ct.key);return pe&&Pe.includes(pe)?pe:((Le=t[0])==null?void 0:Le.key)??""},[g,x]=A.useState((e==null?void 0:e.user_prompt)??""),[w,_]=A.useState((e==null?void 0:e.agent)??y()),j=!!((Je=e==null?void 0:e.permissions)!=null&&Je.length)&&w===(e==null?void 0:e.agent),[D,N]=A.useState(!1),H=A.useCallback(()=>N(!1),[]);pd(D,H);const[F,fe]=A.useState(null),[z,R]=A.useState(()=>Oh(e)),[ee,$]=A.useState(()=>{const pe=e==null?void 0:e.schedule_type,Pe=e==null?void 0:e.schedule_values;if(Pe&&(pe==="crons"||pe==="specific_times"))return Pe.map(Ct=>Bx(pe,Ct));const Le=Oh(e);return pu(Le)?[ti(Le)]:[]}),[q,L]=A.useState((e==null?void 0:e.requires_confirmation)??!1),[G,J]=A.useState(e!=null&&e.schedule_type?e.schedule_enabled??!0:!0),[oe,le]=A.useState((e==null?void 0:e.yolo_mode)??!1),[K,U]=A.useState((e==null?void 0:e.foreground_mode)??!1),[W,ue]=A.useState((e==null?void 0:e.command)??""),[we,M]=A.useState(!1),P=(e==null?void 0:e.schedule_type)==="on_new_notification"&&e.schedule_values&&e.schedule_values.length>0?e.schedule_values[0]:"",[te,S]=A.useState(P),[xe,Ae]=A.useState([]),[ve,Ue]=A.useState(!1),[Ve,Te]=A.useState(!1),[et,Pt]=A.useState(""),Gt=A.useCallback(()=>Te(!1),[]);pd(Ve,Gt),A.useEffect(()=>{if(z!=="on_new_notification"||!s||!Jn.isNativePlatform()||!dn)return;let pe=!1;return Ue(!0),dn.getInstalledApps().then(({apps:Pe})=>{if(pe)return;const Le="com.palmier.app",Ct=Pe.filter(Dt=>Dt.packageName!==Le).sort((Dt,bn)=>(Dt.appName||Dt.packageName).localeCompare(bn.appName||bn.packageName));Ae(Ct)}).catch(()=>{}).finally(()=>{pe||Ue(!1)}),()=>{pe=!0}},[z,s]);const Ft=(e==null?void 0:e.schedule_type)==="on_new_sms"&&e.schedule_values&&e.schedule_values.length>0?e.schedule_values[0]:"",[De,ot]=A.useState(Ft),tt=A.useRef(null),vt=pu(z),ft=z==="command",gn=BE(z),an=t.find(pe=>pe.key===w),Wt=!!(an!=null&&an.supportsYolo);A.useEffect(()=>{!Wt&&oe&&le(!1)},[Wt,oe]);const yn=!!e,Kn=Oh(e),pt=!yn||g!==((e==null?void 0:e.user_prompt)??"")||w!==((e==null?void 0:e.agent)??"")||z!==Kn||q!==((e==null?void 0:e.requires_confirmation)??!1)||G!==(e!=null&&e.schedule_type?e.schedule_enabled??!0:!0)||oe!==((e==null?void 0:e.yolo_mode)??!1)||K!==((e==null?void 0:e.foreground_mode)??!1)||ft&&W!==((e==null?void 0:e.command)??"")||vt&&(JSON.stringify(Fe())!==JSON.stringify((e==null?void 0:e.schedule_values)??[])||Nh(z)!==((e==null?void 0:e.schedule_type)??void 0))||gn&&z!==(e==null?void 0:e.schedule_type)||z==="on_new_notification"&&te.trim()!==P.trim()||z==="on_new_sms"&&De.trim()!==Ft.trim(),je=SE(d.timezone),Q=vt&&ee.some(pe=>pe.schedule==="specific_times"&&(!pe.onceDate||pe.onceDate<je.date||pe.onceDate===je.date&&(pe.onceTime??"")<=je.time)),he=pt&&!!g.trim()&&!Q&&(!ft||!!W.trim())&&(!vt||ee.length>0);function _e(pe,Pe){$(Le=>Le.map((Ct,Dt)=>Dt===pe?{...Ct,...Pe}:Ct))}function Oe(pe){$(Pe=>Pe.filter((Le,Ct)=>Ct!==pe))}function Ie(){pu(z)&&$(pe=>[...pe,pe.length>0?{...pe[pe.length-1]}:ti(z)])}function Ke(pe){R(pe),pu(pe)?$([ti(pe)]):($([]),L(!1)),pe==="command"?setTimeout(()=>{var Pe;return(Pe=tt.current)==null?void 0:Pe.focus()},0):ue(""),pe!=="on_new_notification"&&S(P),pe!=="on_new_sms"&&ot(Ft)}function Fe(){return ee.flatMap(pe=>{const Pe=qE(pe);return Pe?[Pe]:[]})}function Ge(){return oe?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 $e(){M(!0),fe(null);try{const pe=vt?Fe():z==="on_new_notification"&&te.trim()?[te.trim()]:z==="on_new_sms"&&De.trim()?[De.trim()]:[],Pe=vt||gn?Nh(z):null,Le={user_prompt:g,agent:w,schedule_type:Pe,schedule_values:pe.length>0?pe:null,schedule_enabled:z==="ondemand"?!0:G,requires_confirmation:vt?q:!1,yolo_mode:oe,foreground_mode:K,command:ft?W:""};yn&&(Le.id=e.id);const Dt=await f(yn?"task.update":"task.create",Le,{timeout:45e3});if(Dt.error){fe(Dt.error);return}if(yn||m(d.hostId,w),ft&&!yn){l(Dt);try{const bn=await f("task.run",{id:Dt.id});bn.run_id?u(Dt.id,bn.run_id):bn.error||u(Dt.id)}catch{}return}l(Dt)}catch(pe){fe(pe instanceof Error?pe.message:String(pe))}finally{M(!1)}}const Qe=yn?"Save":ft?"Run":(vt||gn)&&G?"Schedule":"Save";return b.jsxs("div",{className:"task-form-overlay",children:[b.jsx("div",{className:"task-form",children:D?b.jsx(ME,{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:pe=>x(pe.target.value),placeholder:ft?"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:we}),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:pe=>_(pe.target.value),disabled:we,children:t.map(pe=>b.jsx("option",{value:pe.key,children:pe.label},pe.key))})]}),Wt&&b.jsxs("label",{className:"yolo-inline",style:{marginLeft:"auto"},children:[b.jsx("input",{type:"checkbox",checked:oe,onChange:pe=>le(pe.target.checked),disabled:we}),"Yolo"]}),Wt&&oe&&b.jsx("p",{className:"yolo-warning",children:"The agent will auto-approve all tool calls without asking for permission."}),j&&b.jsx("div",{className:"granted-permissions-row",children:b.jsx("button",{className:"btn btn-link",onClick:()=>N(!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:z,onChange:pe=>Ke(pe.target.value),disabled:we,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"})]}),gn&&b.jsxs("div",{className:"schedule-reactive",children:[b.jsxs("p",{className:"command-help-text",children:[z==="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 ",z==="on_new_notification"?"notification":"SMS","”."]}),z==="on_new_notification"&&(()=>{const pe=xe.find(Le=>Le.packageName===te),Pe=(pe==null?void 0:pe.appName)||te;return b.jsxs(b.Fragment,{children:[s?te.trim()?b.jsxs("div",{className:"app-filter-selected",children:[b.jsx("span",{className:"app-filter-selected-name",children:Pe}),(pe==null?void 0:pe.appName)&&b.jsx("span",{className:"app-filter-selected-pkg",children:pe.packageName}),b.jsx("button",{type:"button",className:"app-filter-selected-clear",onClick:()=>S(""),"aria-label":"Clear app filter",disabled:we,children:"✕"})]}):b.jsx("button",{type:"button",className:"btn btn-link app-filter-trigger",onClick:()=>{Pt(""),Te(!0)},disabled:we,children:"Select app"}):b.jsx("input",{className:"form-input",type:"text",value:te,onChange:Le=>S(Le.target.value),placeholder:"App (optional), e.g. com.google.android.gm",disabled:we}),b.jsx("p",{className:"command-help-text app-filter-help",children:te.trim()?`Only notifications from ${Pe} will trigger this task.`:"Every notification from your device triggers this task."})]})})(),z==="on_new_sms"&&b.jsxs(b.Fragment,{children:[b.jsx("input",{className:"form-input",type:"text",value:De,onChange:pe=>ot(pe.target.value),placeholder:"From (optional), e.g. +1 555-1234)",disabled:we}),b.jsx("p",{className:"command-help-text app-filter-help",children:De.trim()?`Only SMS from ${De.trim()} will trigger this task. Formatting (spaces, dashes, parens) is ignored.`:"Every SMS that arrives on your device triggers this task."})]})]}),ft&&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:tt,className:"form-input form-input-mono",type:"text",value:W,onChange:pe=>ue(pe.target.value),placeholder:"gws gmail +watch --project my-project",disabled:we})]}),vt&&z!=="hourly"&&b.jsxs(b.Fragment,{children:[ee.map((pe,Pe)=>b.jsxs("div",{className:"trigger-row-card",children:[b.jsxs("div",{className:"trigger-row-content",children:[z==="daily"&&b.jsx("input",{className:"form-input",type:"time",value:pe.time,onChange:Le=>_e(Pe,{time:Le.target.value})}),z==="weekly"&&b.jsxs("div",{className:"trigger-row-top",children:[b.jsx("select",{className:"form-select",value:pe.dayOfWeek,onChange:Le=>_e(Pe,{dayOfWeek:Le.target.value}),children:zE.map((Le,Ct)=>b.jsx("option",{value:String(Ct),children:Le},Ct))}),b.jsx("input",{className:"form-input",type:"time",value:pe.time,onChange:Le=>_e(Pe,{time:Le.target.value})})]}),z==="monthly"&&b.jsxs("div",{className:"trigger-row-top",children:[b.jsx("select",{className:"form-select",value:pe.dayOfMonth,onChange:Le=>_e(Pe,{dayOfMonth:Le.target.value}),children:Array.from({length:28},(Le,Ct)=>Ct+1).map(Le=>b.jsxs("option",{value:String(Le),children:["Day ",Le]},Le))}),b.jsx("input",{className:"form-input",type:"time",value:pe.time,onChange:Le=>_e(Pe,{time:Le.target.value})})]}),z==="specific_times"&&b.jsxs("div",{className:"trigger-row-top",children:[b.jsx("input",{className:"form-input",type:"date",value:pe.onceDate,min:je.date,onChange:Le=>_e(Pe,{onceDate:Le.target.value})}),b.jsx("input",{className:"form-input",type:"time",value:pe.onceTime,min:pe.onceDate===je.date?je.time:void 0,onChange:Le=>_e(Pe,{onceTime:Le.target.value})})]})]}),ee.length>1&&b.jsx("button",{className:"trigger-remove-btn",onClick:()=>Oe(Pe),title:"Remove trigger",children:"×"})]},Pe)),b.jsx("button",{className:"trigger-add-btn",onClick:Ie,children:"+ Add"})]}),r==="win32"&&b.jsxs("label",{className:"toggle-label",children:[b.jsx("input",{type:"checkbox",checked:K,onChange:pe=>U(pe.target.checked),disabled:we}),"Run in the foreground (host must login to Windows)"]}),vt&&b.jsxs("label",{className:"toggle-label",children:[b.jsx("input",{type:"checkbox",checked:q,onChange:pe=>L(pe.target.checked),disabled:we}),"Confirm before each run"]}),z!=="ondemand"&&b.jsxs("label",{className:"toggle-label",children:[b.jsx("input",{type:"checkbox",checked:G,onChange:pe=>J(pe.target.checked),disabled:we}),"Enabled"]})]})}),!oe&&an&&!an.supportsPermissions&&b.jsxs("div",{className:"form-warning",children:["Palmier does not support runtime permission granting for ",an.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:()=>Ge()&&$e(),disabled:!he||we,children:[we&&b.jsx("span",{className:"btn-spinner"}),Qe]}),b.jsx("button",{className:"btn btn-secondary",onClick:()=>{pt&&g.trim()&&!confirm("You have unsaved changes. Discard?")||c()},style:{marginLeft:"auto"},children:"Cancel"})]})]})}),Ve&&(()=>{const pe=et.trim().toLowerCase(),Pe=pe?xe.filter(Le=>Le.packageName.toLowerCase().includes(pe)||Le.appName.toLowerCase().includes(pe)):xe;return b.jsx("div",{className:"app-filter-overlay",onClick:Gt,children:b.jsxs("div",{className:"app-filter-dialog",onClick:Le=>Le.stopPropagation(),children:[b.jsxs("div",{className:"app-filter-header",children:[b.jsx("h2",{children:"Select app"}),b.jsx("button",{className:"app-filter-close",onClick:Gt,"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:et,onChange:Le=>Pt(Le.target.value),onKeyDown:Le=>{Le.key==="Enter"&&et.trim()&&(S(et.trim()),Gt())},placeholder:"Search or type a package name",autoFocus:!0}),b.jsxs("ul",{className:"app-filter-list",children:[ve&&xe.length===0?Array.from({length:6}).map((Le,Ct)=>b.jsx("li",{className:"app-filter-row app-filter-skeleton",children:b.jsx("div",{className:"app-filter-skeleton-bar"})},`sk-${Ct}`)):Pe.length===0&&!et.trim()?b.jsx("li",{className:"app-filter-empty",children:"No apps"}):Pe.map(Le=>b.jsx("li",{className:"app-filter-row",onClick:()=>{S(Le.packageName),Gt()},children:b.jsxs("div",{className:"app-filter-row-labels",children:[b.jsx("div",{className:"app-filter-row-name",children:Le.appName||Le.packageName}),Le.appName&&b.jsx("div",{className:"app-filter-row-pkg",children:Le.packageName})]})},Le.packageName)),et.trim()&&b.jsx("li",{className:"app-filter-row",onClick:()=>{S(et.trim()),Gt()},children:b.jsx("div",{className:"app-filter-row-labels",children:b.jsx("div",{className:"app-filter-row-name",children:et.trim()})})})]})]})})})()]})}function Px({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 Hx({onRefresh:e,threshold:t=70,maxPull:r=110,enabled:s=!0}){const[l,u]=A.useState(0),[c,f]=A.useState(!1),d=A.useRef(null),m=A.useRef(!1),y=A.useRef(0),g=A.useRef(!1),x=A.useRef(e);return A.useEffect(()=>{x.current=e}),A.useEffect(()=>{if(!s)return;const w=D=>{if(g.current||window.scrollY>0){d.current=null;return}if(FE(D.target)){d.current=null;return}d.current=D.touches[0].clientY,m.current=!1,y.current=0},_=D=>{if(g.current||d.current==null)return;const N=D.touches[0].clientY-d.current;if(N<=0){m.current=!1,y.current=0,u(0);return}m.current=!0;const H=Math.min(r,N*.5);y.current=H,u(H),D.cancelable&&D.preventDefault()},j=()=>{if(!m.current){d.current=null,u(0);return}const D=y.current;d.current=null,m.current=!1,y.current=0,D>=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",_,{passive:!1}),window.addEventListener("touchend",j,{passive:!0}),window.addEventListener("touchcancel",j,{passive:!0}),()=>{window.removeEventListener("touchstart",w),window.removeEventListener("touchmove",_),window.removeEventListener("touchend",j),window.removeEventListener("touchcancel",j)}},[s,t,r]),{pullDistance:l,refreshing:c,threshold:t}}function FE(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 $E({connected:e,hostId:t,request:r,subscribeEvents:s,agents:l,hostPlatform:u,isNotificationListener:c,onViewRun:f}){const[d,m]=A.useState([]),[y,g]=A.useState(!1),[x,w]=A.useState(null),[_,j]=A.useState(new Map),[D,N]=A.useState(!1),[H,F]=A.useState(void 0),fe=A.useCallback(()=>{N(!1),F(void 0)},[]),z=A.useCallback(async()=>{if(e){g(!0),w(null);try{const L=(await r("task.list")).tasks??[],G=new Map;for(const J of L)J.status&&G.set(J.id,J.status);j(G),m(L)}catch(q){const L=q instanceof Error?q.message:String(q);L==="Not connected"||L.includes("503")||L.toLowerCase().includes("no responders")?w(null):w(L),m([])}finally{g(!1)}}},[e,t,r]);A.useEffect(()=>{e?z():(m([]),g(!1))},[e,t,z]);const R=Hx({onRefresh:z,enabled:e});A.useEffect(()=>!e||!t?void 0:s(t,async L=>{const G=L.subject.split(".");if(G.length<3)return;const J=G.slice(2).join(".");let oe={};try{oe=JSON.parse(new TextDecoder().decode(L.data))}catch{return}const le=oe.event_type;if(!(le!=="running-state"&&le!=="permission-resolved"))try{const K=await r("task.status",{id:J},{timeout:5e3});if(K.error)return;j(U=>{const W=new Map(U);return W.set(J,K),W})}catch{}}),[e,t,s,r]);function ee(q){m(L=>{const G=L.findIndex(J=>J.id===q.id);if(G>=0){const J=[...L];return J[G]=q,J}return[q,...L]}),N(!1),F(void 0)}function $(q){m(L=>L.filter(G=>G.id!==q)),j(L=>{const G=new Map(L);return G.delete(q),G})}return b.jsxs(b.Fragment,{children:[b.jsx(Px,{pullDistance:R.pullDistance,refreshing:R.refreshing,threshold:R.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(RE,{task:q,lastEvent:_.get(q.id),onEdit:async L=>{try{const G=await r("task.get",{id:L.id});F(G.error?L:G)}catch{F(L)}N(!0)},onDelete:$,onViewRun:f},q.id))}),b.jsx("button",{className:"fab",onClick:()=>{F(void 0),N(!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"})]})}),D&&b.jsx(IE,{initial:H,agents:l,hostPlatform:u,isNotificationListener:c,onSaved:ee,onRun:f,onCancel:fe})]})}let ha=null;function Y0(e){ha&&(e.preventDefault(),e.returnValue="")}function Rh(e){const t=!!ha;ha=e;const r=!!ha;r&&!t?window.addEventListener("beforeunload",Y0):!r&&t&&window.removeEventListener("beforeunload",Y0)}function ps(){return ha?window.confirm(ha):!0}function YE(){const e=Mr(),t=cr(),{hostId:r}=Yu(),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 qx(e){const[t,r]=A.useState(()=>window.matchMedia(e).matches);return A.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 Eu=Jn.isNativePlatform(),VE=["Device","Data","Messaging"],GE=[{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 JE(){if(!Eu||!dn)return new Set;try{const{capabilities:e}=await dn.getCapabilityStatus();return new Set(e.filter(t=>t.enabled).map(t=>t.name))}catch{return new Set}}function Ix({onChange:e,confirmDisable:t=!1}){const[r,s]=A.useState(new Map),[l,u]=A.useState(null),[c,f]=A.useState(null),d=A.useCallback(async()=>{if(!(!Eu||!dn))try{const{capabilities:_}=await dn.getCapabilityStatus(),j=new Map;for(const D of _)j.set(D.name,D);s(j),e==null||e(new Set(_.filter(D=>D.enabled).map(D=>D.name)))}catch(_){console.error("Failed to read capability status:",_)}},[e]);A.useEffect(()=>{d()},[d]),A.useEffect(()=>{if(!Eu)return;const _=dd.addListener("resume",d);return()=>{_.then(j=>j.remove())}},[d]);async function m(_,j){if(dn){u(_.capability);try{const D=await dn.setCapabilityEnabled({capability:_.capability,enabled:j});!D.enabled&&D.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(D){console.error(`Failed to toggle ${_.capability}:`,D)}finally{u(null)}}}function y(_){const j=r.get(_.capability);if(j){if(j.enabled&&t){f(_);return}m(_,!j.enabled)}}function g(){const _=c;_&&(f(null),m(_,!1))}if(!Eu)return null;const x=VE.map(_=>({group:_,items:GE.filter(j=>{const D=r.get(j.capability);return j.group===_&&(D==null?void 0:D.supported)})})).filter(_=>_.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:_=>_.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:_,items:j},D)=>b.jsx("div",{className:D>0?"drawer-toggle-group drawer-toggle-group-divided":"drawer-toggle-group",children:j.map(N=>{const H=r.get(N.capability),F=!!(H!=null&&H.enabled);return b.jsxs("label",{className:"drawer-toggle",children:[b.jsx("span",{className:"drawer-toggle-label",children:N.label}),b.jsx("button",{className:`toggle-switch ${F?"toggle-switch-on":""}`,onClick:()=>y(N),disabled:l===N.capability,role:"switch","aria-checked":F,children:b.jsx("span",{className:"toggle-switch-thumb"})})]},N.capability)})},_)),w]})}const V0=!!window.__PALMIER_SERVE__&&(window.location.hostname==="localhost"||window.location.hostname==="127.0.0.1"),XE=Jn.isNativePlatform();function G0({daemonVersion:e,agents:t,linkedClientToken:r,request:s,onEnabledCapabilitiesChange:l,onLinkedClientTokenChange:u}){var Ft;const{pairedHosts:c,removePairedHost:f,renamePairedHost:d}=qi(),{activeHost:m}=si(),y=Mr(),g=cr(),w=Yu().hostId??null,_=m.clientToken||null,j=!!_&&r===_,D=qx("(min-width: 768px)"),[N,H]=A.useState(!1),[F,fe]=A.useState(()=>Date.now());A.useEffect(()=>{const De=()=>fe(Date.now()),ot=6e4-Date.now()%6e4,tt=setTimeout(()=>{De();const vt=setInterval(De,6e4);tt._iv=vt},ot);return()=>{const vt=tt._iv;vt&&clearInterval(vt),clearTimeout(tt)}},[]);const z=m.timezone?new Date(F).toLocaleString(void 0,{month:"short",day:"numeric",hour:"numeric",minute:"2-digit",timeZone:m.timezone}):"";async function R(){if(!(!dn||!s||!_)){H(!0);try{const{token:De}=await dn.getFcmToken();if(!De)return;await s("device.link",{fcmToken:De}),u==null||u(_)}catch(De){console.error("Failed to make this the linked device:",De)}finally{H(!1)}}}async function ee(De){const ot=De===w;if(ot&&s)try{await s("clients.revoke_self")}catch{}f(De),ue(null),ot&&y("/",{replace:!0})}function $(De){const tt=g.pathname.endsWith("/tasks")?"/tasks":"";y(`/hosts/${encodeURIComponent(De)}${tt}`)}const[q,L]=A.useState(!1),[G,J]=A.useState(!1),[oe,le]=A.useState(null),[K,U]=A.useState(""),[W,ue]=A.useState(null),[we,M]=A.useState(!1),P=A.useRef(null),te=A.useRef(null),S=A.useCallback(()=>{J(!0)},[]);function xe(){G&&(L(!1),J(!1))}function Ae(){J(!1),L(!0)}function ve(De,ot){le(De),U(ot)}function Ue(){oe&&K.trim()&&d(oe,K.trim()),le(null),U("")}function Ve(){le(null),U("")}A.useEffect(()=>{oe&&te.current&&(te.current.focus(),te.current.select())},[oe]),A.useEffect(()=>{if(!q||G)return;function De(ot){ot.key==="Escape"&&S()}return document.addEventListener("keydown",De),()=>{document.removeEventListener("keydown",De)}},[q,G,S]);const Te=b.jsxs(b.Fragment,{children:[!D&&b.jsx("button",{className:"drawer-close-btn",onClick:S,"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"})})}),!V0&&c.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:c.map(De=>{const ot=De.hostId===w,tt=oe===De.hostId,vt=De.name||De.hostId.slice(0,8);return b.jsx("div",{className:"host-picker-item-wrapper",children:b.jsxs("div",{className:`host-picker-item ${ot?"host-picker-item-active":""}`,onClick:()=>{if(!tt&&!ot){if(!ps())return;$(De.hostId),D||S()}},role:"option","aria-selected":ot,children:[tt?b.jsx("input",{ref:te,className:"form-input host-picker-rename-input",type:"text",value:K,onChange:ft=>U(ft.target.value),onKeyDown:ft=>{ft.key==="Enter"&&Ue(),ft.key==="Escape"&&Ve()},onBlur:Ue,onClick:ft=>ft.stopPropagation()}):b.jsx("span",{className:"host-picker-item-name",children:vt}),b.jsxs("div",{className:"host-picker-item-actions",children:[ot&&!tt&&b.jsx("button",{className:"host-picker-edit-btn",onClick:ft=>{ft.stopPropagation(),ve(De.hostId,vt)},"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"})})}),!ot&&b.jsx("button",{className:"host-picker-delete-btn",onClick:ft=>{ft.stopPropagation(),ue(De.hostId)},"aria-label":`Unpair ${vt}`,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"})})})]})]})},De.hostId)})})})]}),!V0&&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()&&(y("/pair"),D||S())},children:"Add New Host"})})]}),XE&&s&&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"}),j?b.jsx(Ix,{onChange:l,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:()=>{r&&r!==_?M(!0):R()},disabled:N,children:N?"Linking…":"Link the host to this device"})]})]})]}),b.jsxs("div",{className:"drawer-footer",children:[t&&t.length>0&&(()=>{const De=t.filter(tt=>tt.version),ot=t.filter(tt=>!tt.version);return b.jsxs("div",{className:"drawer-agents",children:[De.length>0&&b.jsxs("div",{className:"drawer-agents-section",children:[b.jsx("div",{className:"drawer-agents-heading",children:"Agents"}),De.map(tt=>b.jsxs("div",{className:"drawer-agents-row",children:[b.jsx("span",{children:tt.label}),b.jsxs("span",{className:"drawer-agents-version",children:["v",tt.version]})]},tt.key))]}),ot.length>0&&b.jsxs("div",{className:"drawer-agents-section",children:[b.jsx("div",{className:"drawer-agents-heading",children:"Version not managed by Palmier"}),ot.map(tt=>b.jsx("div",{className:"drawer-agents-row",children:b.jsx("span",{children:tt.label})},tt.key))]})]})})(),(m.timezone||e)&&b.jsxs("div",{className:"drawer-host-info",children:[b.jsx("div",{className:"drawer-agents-heading",children:"Host"}),m.timezone&&b.jsxs("div",{className:"drawer-host-time",children:[z," · ",m.timezone]}),e&&b.jsxs("div",{className:"drawer-version",children:["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"})]})]})]}),et=!!W&&W===w&&j,Pt=W&&ds.createPortal(b.jsx("div",{className:"confirm-modal-overlay",onClick:()=>ue(null),children:b.jsxs("div",{className:"confirm-modal",onClick:De=>De.stopPropagation(),children:[b.jsx("h2",{className:"confirm-modal-title",children:"Remove host?"}),b.jsxs("p",{className:"confirm-modal-message",children:['"',((Ft=c.find(De=>De.hostId===W))==null?void 0:Ft.name)||W.slice(0,8),'" will be ',et?"removed and unlinked":"removed",".",et&&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:()=>ue(null),children:"Cancel"}),b.jsx("button",{className:"btn btn-danger",onClick:()=>ee(W),children:"Remove"})]})]})}),document.body),Gt=we&&ds.createPortal(b.jsx("div",{className:"confirm-modal-overlay",onClick:()=>M(!1),children:b.jsxs("div",{className:"confirm-modal",onClick:De=>De.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:()=>M(!1),children:"Cancel"}),b.jsx("button",{className:"btn btn-primary",onClick:()=>{M(!1),R()},children:"Link"})]})]})}),document.body);return D?b.jsxs(b.Fragment,{children:[b.jsx("div",{className:"drawer-panel drawer-panel-desktop",ref:P,children:Te}),Pt,Gt]}):b.jsxs(b.Fragment,{children:[b.jsx("button",{className:"hamburger-btn",onClick:Ae,"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"})})}),q&&ds.createPortal(b.jsx("div",{className:`drawer-overlay ${G?"drawer-overlay-closing":""}`,onClick:S,onAnimationEnd:xe,children:b.jsx("div",{className:`drawer-panel ${G?"drawer-panel-closing":""}`,ref:P,onClick:De=>De.stopPropagation(),children:Te})}),document.body),Pt,Gt]})}const KE=Jn.isNativePlatform(),Yd={width:16,height:16,viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:2,strokeLinecap:"round",strokeLinejoin:"round"};function QE(){return b.jsxs("svg",{...Yd,"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 J0(){return b.jsxs("svg",{...Yd,"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 ZE(){return b.jsxs("svg",{...Yd,"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 WE(){const{mode:e}=si(),[t,r]=A.useState(!1),s=A.useRef(null);if(A.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(QE,{}),u="Connected via LAN",c="lan";break;case"nats":l=b.jsx(J0,{}),u=KE?"Connected via relay":"Connected",c="relay";break;case"disconnected":l=b.jsx(ZE,{}),u="Disconnected",c="disconnected";break;case"connecting":default:l=b.jsx(J0,{}),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 X0(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 eC({agents:e,hostPlatform:t,onStarted:r}){const{request:s,activeHost:l}=si(),{setHostLastAgent:u}=qi(),[c,f]=A.useState(""),[d,m]=A.useState(()=>X0(e,l.lastAgent)),[y,g]=A.useState(!1),[x,w]=A.useState(!1),[_,j]=A.useState(null);A.useEffect(()=>{e.length&&(e.find(R=>R.key===d)||m(X0(e,l.lastAgent)))},[e,d,l.lastAgent]),A.useEffect(()=>{const R=c.trim().length>0;return Rh(R?"Your session draft will be lost. Continue?":null),()=>Rh(null)},[c]);const D=e.find(R=>R.key===d),N=!!(D!=null&&D.supportsYolo);A.useEffect(()=>{!N&&y&&g(!1)},[N,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 fe(){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=Il(m.charCodeAt(0))+m.slice(1)),m=m?c+" "+m:c,r.options.closeAtx&&(m+=" "+c),d(),f(),m}N1.peek=m3;function N1(e){return e.value||""}function m3(){return"<"}O1.peek=p3;function O1(e,t,r,s){const l=lm(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 p3(){return"!"}R1.peek=g3;function R1(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 g3(){return"!"}M1.peek=y3;function M1(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 y3(){return"`"}function D1(e,t){const r=Zd(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))}L1.peek=b3;function L1(e,t,r,s){const l=lm(r),u=l==='"'?"Quote":"Apostrophe",c=r.createTracker(s);let f,d;if(D1(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 b3(e,t,r){return D1(e,r)?"<":"["}z1.peek=x3;function z1(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 x3(){return"["}function om(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 v3(e){const t=om(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 w3(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 U1(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 S3(e,t,r,s){const l=r.enter("list"),u=r.bulletCurrent;let c=e.ordered?w3(r):om(r);const f=e.ordered?c==="."?")":".":v3(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),U1(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 _3(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 k3(e,t,r,s){const l=_3(r);let u=r.bulletCurrent||om(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 E3(e,t,r,s){const l=r.enter("paragraph"),u=r.enter("phrasing"),c=r.containerPhrasing(e,s);return u(),l(),c}const C3=tc(["break","delete","emphasis","footnote","footnoteReference","image","imageReference","inlineCode","inlineMath","link","linkReference","mdxJsxTextElement","mdxTextExpression","strong","text","textDirective"]);function A3(e,t,r,s){return(e.children.some(function(c){return C3(c)})?r.containerPhrasing:r.containerFlow).call(r,e,s)}function T3(e){const t=e.options.strong||"*";if(t!=="*"&&t!=="_")throw new Error("Cannot serialize strong with `"+t+"` for `options.strong`, expected `*`, or `_`");return t}B1.peek=j3;function B1(e,t,r,s){const l=T3(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=Iu(s.before.charCodeAt(s.before.length-1),m,l);y.inside&&(d=Il(m)+d.slice(1));const g=d.charCodeAt(d.length-1),x=Iu(s.after.charCodeAt(0),g,l);x.inside&&(d=d.slice(0,-1)+Il(g));const w=c.move(l+l);return u(),r.attentionEncodeSurroundingInfo={after:x.outside,before:y.outside},f+d+w}function j3(e,t,r){return r.options.strong||"*"}function N3(e,t,r,s){return r.safe(e.value,s)}function O3(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 R3(e,t,r){const s=(U1(r)+(r.options.ruleSpaces?" ":"")).repeat(O3(r));return r.options.ruleSpaces?s.slice(0,-1):s}const P1={blockquote:t3,break:Ub,code:l3,definition:u3,emphasis:j1,hardBreak:Ub,heading:d3,html:N1,image:O1,imageReference:R1,inlineCode:M1,link:L1,linkReference:z1,list:S3,listItem:k3,paragraph:E3,root:A3,strong:B1,text:N3,thematicBreak:R3};function M3(){return{enter:{table:D3,tableData:Bb,tableHeader:Bb,tableRow:z3},exit:{codeText:U3,table:L3,tableData:Xh,tableHeader:Xh,tableRow:Xh}}}function D3(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 L3(e){this.exit(e),this.data.inTable=void 0}function z3(e){this.enter({type:"tableRow",children:[]},e)}function Xh(e){this.exit(e)}function Bb(e){this.enter({type:"tableCell",children:[]},e)}function U3(e){let t=this.resume();this.data.inTable&&(t=t.replace(/\\([\\|])/g,B3));const r=this.stack[this.stack.length-1];r.type,r.value=t,this.exit(e)}function B3(e,t){return t==="|"?t:e}function P3(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,_,j,D){return m(y(w,j,D),w.align)}function f(w,_,j,D){const N=g(w,j,D),H=m([N]);return H.slice(0,H.indexOf(`
|
|
120
|
-
`))}function d(w,_,j,D){const N=j.enter("tableCell"),H=j.enter("phrasing"),F=j.containerPhrasing(w,{...D,before:u,after:u});return H(),N(),F}function m(w,_){return WN(w,{align:_,alignDelimiters:s,padding:r,stringLength:l})}function y(w,_,j){const D=w.children;let N=-1;const H=[],F=_.enter("table");for(;++N<D.length;)H[N]=g(D[N],_,j);return F(),H}function g(w,_,j){const D=w.children;let N=-1;const H=[],F=_.enter("tableRow");for(;++N<D.length;)H[N]=d(D[N],w,_,j);return F(),H}function x(w,_,j){let D=P1.inlineCode(w,_,j);return j.stack.includes("tableCell")&&(D=D.replace(/\|/g,"\\$&")),D}}function H3(){return{exit:{taskListCheckValueChecked:Pb,taskListCheckValueUnchecked:Pb,paragraph:I3}}}function q3(){return{unsafe:[{atBreak:!0,character:"-",after:"[:|-]"}],handlers:{listItem:F3}}}function Pb(e){const t=this.stack[this.stack.length-2];t.type,t.checked=e.type==="taskListCheckValueChecked"}function I3(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 F3(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=P1.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 $3(){return[SN(),FN(),GN(),M3(),H3()]}function Y3(e){return{extensions:[_N(),$N(e),JN(),P3(e),q3()]}}const V3={tokenize:Z3,partial:!0},H1={tokenize:W3,partial:!0},q1={tokenize:eO,partial:!0},I1={tokenize:tO,partial:!0},G3={tokenize:nO,partial:!0},F1={name:"wwwAutolink",tokenize:K3,previous:Y1},$1={name:"protocolAutolink",tokenize:Q3,previous:V1},ai={name:"emailAutolink",tokenize:X3,previous:G1},Dr={};function J3(){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,$1];Dr[104]=[ai,$1];Dr[87]=[ai,F1];Dr[119]=[ai,F1];function X3(e,t,r){const s=this;let l,u;return c;function c(g){return!Cd(g)||!G1.call(s,s.previous)||um(s.events)?r(g):(e.enter("literalAutolink"),e.enter("literalAutolinkEmail"),f(g))}function f(g){return Cd(g)?(e.consume(g),f):g===64?(e.consume(g),d):r(g)}function d(g){return g===46?e.check(G3,y,m)(g):g===45||g===95||mn(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&&_n(s.previous)?(e.exit("literalAutolinkEmail"),e.exit("literalAutolink"),t(g)):r(g)}}function K3(e,t,r){const s=this;return l;function l(c){return c!==87&&c!==119||!Y1.call(s,s.previous)||um(s.events)?r(c):(e.enter("literalAutolink"),e.enter("literalAutolinkWww"),e.check(V3,e.attempt(H1,e.attempt(q1,u),r),r)(c))}function u(c){return e.exit("literalAutolinkWww"),e.exit("literalAutolink"),t(c)}}function Q3(e,t,r){const s=this;let l="",u=!1;return c;function c(g){return(g===72||g===104)&&V1.call(s,s.previous)&&!um(s.events)?(e.enter("literalAutolink"),e.enter("literalAutolinkHttp"),l+=String.fromCodePoint(g),e.consume(g),f):r(g)}function f(g){if(_n(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||Pu(g)||jt(g)||gs(g)||Zu(g)?r(g):e.attempt(H1,e.attempt(q1,y),r)(g)}function y(g){return e.exit("literalAutolinkHttp"),e.exit("literalAutolink"),t(g)}}function Z3(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 W3(e,t,r){let s,l,u;return c;function c(m){return m===46||m===95?e.check(I1,d,f)(m):m===null||jt(m)||gs(m)||m!==45&&Zu(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 eO(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(I1,t,u)(c):c===null||jt(c)||gs(c)?t(c):(e.consume(c),l)}function u(c){return c===41&&s++,e.consume(c),l}}function tO(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||jt(f)||gs(f)?t(f):r(f)}function l(f){return f===null||f===40||f===91||jt(f)||gs(f)?t(f):s(f)}function u(f){return _n(f)?c(f):r(f)}function c(f){return f===59?(e.consume(f),s):_n(f)?(e.consume(f),c):r(f)}}function nO(e,t,r){return s;function s(u){return e.consume(u),l}function l(u){return mn(u)?r(u):t(u)}}function Y1(e){return e===null||e===40||e===42||e===95||e===91||e===93||e===126||jt(e)}function V1(e){return!_n(e)}function G1(e){return!(e===47||Cd(e))}function Cd(e){return e===43||e===45||e===46||e===95||mn(e)}function um(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 rO={tokenize:fO,partial:!0};function iO(){return{document:{91:{name:"gfmFootnoteDefinition",tokenize:oO,continuation:{tokenize:uO},exit:cO}},text:{91:{name:"gfmFootnoteCall",tokenize:lO},93:{name:"gfmPotentialFootnoteCall",add:"after",tokenize:sO,resolveTo:aO}}}}function sO(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 aO(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 lO(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||jt(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 jt(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 oO(e,t,r){const s=this,l=s.parser.gfmFootnotes||(s.parser.gfmFootnotes=[]);let u,c=0,f;return d;function d(_){return e.enter("gfmFootnoteDefinition")._container=!0,e.enter("gfmFootnoteDefinitionLabel"),e.enter("gfmFootnoteDefinitionLabelMarker"),e.consume(_),e.exit("gfmFootnoteDefinitionLabelMarker"),m}function m(_){return _===94?(e.enter("gfmFootnoteDefinitionMarker"),e.consume(_),e.exit("gfmFootnoteDefinitionMarker"),e.enter("gfmFootnoteDefinitionLabelString"),e.enter("chunkString").contentType="string",y):r(_)}function y(_){if(c>999||_===93&&!f||_===null||_===91||jt(_))return r(_);if(_===93){e.exit("chunkString");const j=e.exit("gfmFootnoteDefinitionLabelString");return u=wr(s.sliceSerialize(j)),e.enter("gfmFootnoteDefinitionLabelMarker"),e.consume(_),e.exit("gfmFootnoteDefinitionLabelMarker"),e.exit("gfmFootnoteDefinitionLabel"),x}return jt(_)||(f=!0),c++,e.consume(_),_===92?g:y}function g(_){return _===91||_===92||_===93?(e.consume(_),c++,y):y(_)}function x(_){return _===58?(e.enter("definitionMarker"),e.consume(_),e.exit("definitionMarker"),l.includes(u)||l.push(u),ct(e,w,"gfmFootnoteDefinitionWhitespace")):r(_)}function w(_){return t(_)}}function uO(e,t,r){return e.check(Jl,t,e.attempt(rO,t,r))}function cO(e){e.exit("gfmFootnoteDefinition")}function fO(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 hO(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,Wu(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(_){return m===126&&y[y.length-1][1].type!=="characterEscape"?d(_):(c.enter("strikethroughSequenceTemporary"),w(_))}function w(_){const j=ba(m);if(_===126)return g>1?d(_):(c.consume(_),g++,w);if(g<2&&!r)return d(_);const D=c.exit("strikethroughSequenceTemporary"),N=ba(_);return D._open=!N||N===2&&!!j,D._close=!j||j===2&&!!N,f(_)}}}class dO{constructor(){this.map=[]}add(t,r,s){mO(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 mO(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 pO(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 gO(){return{flow:{null:{name:"table",tokenize:yO,resolveAll:bO}}}}function yO(e,t,r){const s=this;let l=0,u=0,c;return f;function f(L){let G=s.events.length-1;for(;G>-1;){const le=s.events[G][1].type;if(le==="lineEnding"||le==="linePrefix")G--;else break}const J=G>-1?s.events[G][1].type:null,oe=J==="tableHead"||J==="tableRow"?R:d;return oe===R&&s.parser.lazy[s.now().line]?r(L):oe(L)}function d(L){return e.enter("tableHead"),e.enter("tableRow"),m(L)}function m(L){return L===124||(c=!0,u+=1),y(L)}function y(L){return L===null?r(L):He(L)?u>1?(u=0,s.interrupt=!0,e.exit("tableRow"),e.enter("lineEnding"),e.consume(L),e.exit("lineEnding"),w):r(L):st(L)?ct(e,y,"whitespace")(L):(u+=1,c&&(c=!1,l+=1),L===124?(e.enter("tableCellDivider"),e.consume(L),e.exit("tableCellDivider"),c=!0,y):(e.enter("data"),g(L)))}function g(L){return L===null||L===124||jt(L)?(e.exit("data"),y(L)):(e.consume(L),L===92?x:g)}function x(L){return L===92||L===124?(e.consume(L),g):g(L)}function w(L){return s.interrupt=!1,s.parser.lazy[s.now().line]?r(L):(e.enter("tableDelimiterRow"),c=!1,st(L)?ct(e,_,"linePrefix",s.parser.constructs.disable.null.includes("codeIndented")?void 0:4)(L):_(L))}function _(L){return L===45||L===58?D(L):L===124?(c=!0,e.enter("tableCellDivider"),e.consume(L),e.exit("tableCellDivider"),j):z(L)}function j(L){return st(L)?ct(e,D,"whitespace")(L):D(L)}function D(L){return L===58?(u+=1,c=!0,e.enter("tableDelimiterMarker"),e.consume(L),e.exit("tableDelimiterMarker"),N):L===45?(u+=1,N(L)):L===null||He(L)?fe(L):z(L)}function N(L){return L===45?(e.enter("tableDelimiterFiller"),H(L)):z(L)}function H(L){return L===45?(e.consume(L),H):L===58?(c=!0,e.exit("tableDelimiterFiller"),e.enter("tableDelimiterMarker"),e.consume(L),e.exit("tableDelimiterMarker"),F):(e.exit("tableDelimiterFiller"),F(L))}function F(L){return st(L)?ct(e,fe,"whitespace")(L):fe(L)}function fe(L){return L===124?_(L):L===null||He(L)?!c||l!==u?z(L):(e.exit("tableDelimiterRow"),e.exit("tableHead"),t(L)):z(L)}function z(L){return r(L)}function R(L){return e.enter("tableRow"),ee(L)}function ee(L){return L===124?(e.enter("tableCellDivider"),e.consume(L),e.exit("tableCellDivider"),ee):L===null||He(L)?(e.exit("tableRow"),t(L)):st(L)?ct(e,ee,"whitespace")(L):(e.enter("data"),$(L))}function $(L){return L===null||L===124||jt(L)?(e.exit("data"),ee(L)):(e.consume(L),L===92?q:$)}function q(L){return L===92||L===124?(e.consume(L),$):$(L)}}function bO(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 dO;for(;++r<e.length;){const w=e[r],_=w[1];w[0]==="enter"?_.type==="tableHead"?(f=!1,d!==0&&(Hb(x,t,d,m,y),y=void 0,d=0),m={type:"table",start:Object.assign({},_.start),end:Object.assign({},_.end)},x.add(r,0,[["enter",m,t]])):_.type==="tableRow"||_.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({},_.start),end:Object.assign({},_.end)},x.add(r,0,[["enter",y,t]])),l=_.type==="tableDelimiterRow"?2:y?3:1):l&&(_.type==="data"||_.type==="tableDelimiterMarker"||_.type==="tableDelimiterFiller")?(s=!1,c[2]===0&&(u[1]!==0&&(c[0]=c[1],g=xu(x,t,u,l,void 0,g),u=[0,0,0,0]),c[2]=r)):_.type==="tableCellDivider"&&(s?s=!1:(u[1]!==0&&(c[0]=c[1],g=xu(x,t,u,l,void 0,g)),u=c,c=[u[1],r,0,0])):_.type==="tableHead"?(f=!0,d=r):_.type==="tableRow"||_.type==="tableDelimiterRow"?(d=r,u[1]!==0?(c[0]=c[1],g=xu(x,t,u,l,r,g)):c[1]!==0&&(g=xu(x,t,c,l,r,g)),l=0):l&&(_.type==="data"||_.type==="tableDelimiterMarker"||_.type==="tableDelimiterFiller")&&(c[3]=r)}for(d!==0&&Hb(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=pO(t.events,r))}return e}function xu(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 _=r[2]+1,j=r[3]-r[2]-1;e.add(_,j,[])}}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 Hb(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 xO={name:"tasklistCheck",tokenize:wO};function vO(){return{text:{91:xO}}}function wO(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 jt(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 He(d)?t(d):st(d)?e.check({tokenize:SO},t,r)(d):r(d)}}function SO(e,t,r){return ct(e,s,"whitespace");function s(l){return l===null?r(l):t(l)}}function _O(e){return r1([J3(),iO(),hO(e),gO(),vO()])}const kO={};function qb(e){const t=this,r=e||kO,s=t.data(),l=s.micromarkExtensions||(s.micromarkExtensions=[]),u=s.fromMarkdownExtensions||(s.fromMarkdownExtensions=[]),c=s.toMarkdownExtensions||(s.toMarkdownExtensions=[]);l.push(_O(r)),u.push($3()),c.push(Y3(r))}function EO(e){k1(e,[/\r?\n|\r/g,CO])}function CO(){return{type:"break"}}function Ib(){return function(e){EO(e)}}function AO({connected:e,hostId:t,request:r,subscribeEvents:s,taskId:l,runId:u}){const c=Mr(),f=$d(),[d,m]=A.useState(!0),[y,g]=A.useState([]),[x,w]=A.useState(),[_,j]=A.useState(),[D,N]=A.useState(),H=x==="started"||x==="monitoring",F=x==="followup",fe=x==="started"||x==="followup",[z,R]=A.useState(null);pd(z!==null,()=>R(null));const[ee,$]=A.useState(!1),[q,L]=A.useState(""),[G,J]=A.useState(!1),oe=A.useRef(null),le=A.useRef(null),K=A.useRef(null),[U,W]=A.useState(u==="latest"?void 0:u),ue=u==="latest"&&U===null;A.useEffect(()=>{if(u!=="latest"){W(u);return}e&&(W(void 0),r("taskrun.list",{task_id:l,limit:1}).then(S=>{var xe,Ae;return W(((Ae=(xe=S.entries)==null?void 0:xe[0])==null?void 0:Ae.run_id)??null)}).catch(()=>W(null)))},[u,l,e,r]);async function we(){if(U)try{const S=await r("task.result",{id:l,run_id:U});if(S.error){console.error("No result:",S.error),c(t?`/hosts/${encodeURIComponent(t)}`:"/",{replace:!0});return}g(S.messages??[]),w(S.running_state),j(S.agent),N(S.agent_version)}catch(S){console.error("Failed to load result:",S),c(t?`/hosts/${encodeURIComponent(t)}`:"/",{replace:!0})}finally{m(!1)}}async function M(S){var xe;if(U)try{const ve=(xe=(await r("task.reports",{id:l,run_id:U,report_files:[S]})).reports)==null?void 0:xe[0];ve!=null&&ve.data_url?R({file:S,data_url:ve.data_url}):R({file:S,content:(ve==null?void 0:ve.content)??"Report not found."})}catch{R({file:S,content:"Failed to load report."})}}A.useEffect(()=>{!e||!U||(m(!0),we())},[e,l,U]),A.useEffect(()=>!e||!t||!U?void 0:s(t,async xe=>{try{const Ae=JSON.parse(new TextDecoder().decode(xe.data));if(Ae.event_type!=="running-state"&&Ae.event_type!=="result-updated"||xe.subject.split(".").pop()!==l||Ae.event_type==="result-updated"&&Ae.run_id&&Ae.run_id!==U)return;we()}catch{}}),[e,t,l,U,s,r]),A.useEffect(()=>{oe.current&&(oe.current.scrollTop=oe.current.scrollHeight)},[y]),A.useEffect(()=>{d||ue||!U||K.current!==U&&(K.current=U,requestAnimationFrame(()=>{oe.current&&(oe.current.scrollTop=oe.current.scrollHeight),window.scrollTo({top:document.documentElement.scrollHeight,behavior:"auto"})}))},[d,ue,U]);function P(S){if(S==="input")return"User Input";if(S==="permission")return"Permission";if(S==="confirmation")return"Confirmation"}function te(S){return S==="started"?"Task started":S==="finished"?"Task finished":S==="failed"?"Task failed":S==="error"?"Command failed":S==="aborted"?"Task aborted":S==="confirmation"?"Task confirmed":S==="stopped"?"Follow-up stopped":S??""}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"]}),ue?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:oe,children:[y.map((S,xe)=>{const Ae=fe&&S.role==="assistant"&&!y.slice(xe+1).some(ve=>ve.role==="assistant"||ve.role==="user");return S.role==="status"&&S.type==="monitoring"?null:S.role==="status"?b.jsxs("div",{className:`chat-status${S.type==="error"?" chat-status--error":""}`,children:[b.jsxs("div",{children:[te(S.type),S.time>0&&b.jsx("span",{className:"chat-status-time",children:f(S.time)})]}),S.content&&b.jsx("pre",{className:"chat-status-detail",children:S.content})]},xe):b.jsxs("div",{className:`chat-message chat-message--${S.role}${S.role==="assistant"&&S.stream==="stderr"?" chat-message--stderr":""}`,children:[S.role==="assistant"&&_&&b.jsxs("div",{className:"chat-message-agent",children:[md(_),D&&b.jsxs("span",{className:"chat-message-agent-version",children:[" v",D]})]}),b.jsxs("div",{className:"chat-message-content",children:[b.jsx(Mb,{remarkPlugins:[qb,Ib],components:{a:({...ve})=>b.jsx("a",{...ve,target:"_blank",rel:"noopener noreferrer"})},children:S.content}),Ae&&b.jsxs("div",{className:"chat-typing-indicator",children:[b.jsx("span",{}),b.jsx("span",{}),b.jsx("span",{})]})]}),S.attachments&&S.attachments.length>0&&b.jsx("div",{className:"chat-message-attachments",children:S.attachments.map(ve=>b.jsx("button",{className:"chat-attachment-chip",onClick:()=>M(ve),children:ve},ve))}),b.jsxs("div",{className:"chat-message-meta",children:[P(S.type)&&b.jsx("span",{className:"chat-message-type",children:P(S.type)}),S.time>0&&b.jsx("span",{children:f(S.time)})]})]},xe)}),fe&&(()=>{const S=y.filter(xe=>xe.role!=="status");return S.length===0||S[S.length-1].role!=="assistant"})()&&b.jsxs("div",{className:"chat-message chat-message--assistant",children:[_&&b.jsxs("div",{className:"chat-message-agent",children:[md(_),D&&b.jsxs("span",{className:"chat-message-agent-version",children:[" v",D]})]}),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"]})]}),H?b.jsx("div",{className:"chat-abort-bar",children:b.jsx("button",{className:"btn btn-secondary chat-abort-btn",disabled:ee,onClick:async()=>{if(confirm("Abort this task?")){$(!0);try{await r("task.abort",{id:l})}catch(S){console.error("Abort failed:",S)}finally{$(!1)}}},children:ee?"Aborting...":"Abort Task"})}):F?b.jsx("div",{className:"chat-input-bar",children:b.jsx("button",{className:"btn btn-secondary chat-stop-btn",disabled:ee,onClick:async()=>{$(!0);try{await r("task.stop_followup",{id:l,run_id:U})}catch(S){console.error("Stop failed:",S)}finally{$(!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 S=>{S.preventDefault();const xe=q.trim();if(!(!xe||G)){J(!0);try{await r("task.followup",{id:l,run_id:U,message:xe}),L("")}catch(Ae){console.error("Follow-up failed:",Ae)}finally{J(!1)}}},children:[b.jsx("input",{ref:le,className:"chat-input",type:"text",placeholder:"Follow-up message",value:q,onChange:S=>L(S.target.value),disabled:G}),b.jsx("button",{className:"btn btn-primary chat-send-btn",type:"submit",disabled:!q.trim()||G,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"})]})})]})]}),z&&b.jsx("div",{className:"report-dialog-overlay",onClick:()=>R(null),children:b.jsxs("div",{className:"report-dialog",onClick:S=>S.stopPropagation(),children:[b.jsxs("div",{className:"report-dialog-header",children:[b.jsx("span",{className:"report-dialog-title",children:z.file}),b.jsx("button",{className:"report-dialog-close",onClick:()=>R(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:z.data_url?b.jsx("img",{src:z.data_url,alt:z.file,style:{maxWidth:"100%",height:"auto"}}):b.jsx(Mb,{remarkPlugins:[qb,Ib],components:{a:({...S})=>b.jsx("a",{...S,target:"_blank",rel:"noopener noreferrer"})},children:z.content??""})})]})})]})}function Fb({title:e,message:t,onUpdate:r,onDismiss:s}){return b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:e}),b.jsx("p",{className:"confirm-modal-message",children:t}),b.jsxs("div",{className:"confirm-modal-actions",children:[b.jsx("button",{className:"btn btn-primary",onClick:r,children:"Update Now"}),s&&b.jsx("button",{className:"btn btn-secondary",onClick:s,children:"Dismiss"})]})]})})}function TO(){const{activeHost:e}=si(),t=A.useRef(null);A.useEffect(()=>{if(Jn.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 gE("/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 pE("/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 jO="0.9.9";function Kh(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 vu(){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=Yu(),w=qx("(min-width: 768px)"),_=g.pathname.endsWith("/tasks"),j=x.runId?void 0:x.taskId,D=!!(x.taskId&&x.runId),[N,H]=A.useState(!1),[F,fe]=A.useState(!1),[z,R]=A.useState(null),[ee,$]=A.useState(null),[q,L]=A.useState(null),[G,J]=A.useState(()=>localStorage.getItem(`palmier.${d}.dismissedUpdateVersion`)),[oe,le]=A.useState({}),[K,U]=A.useState({}),[W,ue]=A.useState(null),[we,M]=A.useState(new Set),[P,te]=A.useState([]),[S,xe]=A.useState(),Ae=!!m&&W===m,[ve,Ue]=A.useState(new Map),[Ve,Te]=A.useState(new Map),[et,Pt]=A.useState(new Map),[Gt,Ft]=A.useState(new Map);TO(),A.useEffect(()=>{window.scrollTo(0,0)},[d]),A.useEffect(()=>{let je=!1;return JE().then(Q=>{je||M(Q)}),()=>{je=!0}},[]),A.useEffect(()=>{s&&l("host.info").then(je=>{var Ke,Fe,Ge,$e,Qe,Je;te(je.agents??[]),xe(je.host_platform),ue(je.linked_client_token??null),NE(je.agents??[]);const Q=je.version??null;$(Q),H(!!Q&&Kh(Q,jO)),t(d,je.lan_url??void 0),r(d,je.host_timezone);const he=new Map,_e=new Map,Oe=new Map,Ie=new Map;for(const pe of je.pending_prompts??[])if(pe.type==="confirmation")he.set(pe.key,{description:((Ke=pe.meta)==null?void 0:Ke.description)??"",sessionName:(Fe=pe.meta)==null?void 0:Fe.session_name});else if(pe.type==="permission")_e.set(pe.key,{permissions:pe.params??[],sessionName:(Ge=pe.meta)==null?void 0:Ge.session_name});else if(pe.type==="input"){const Pe=pe.params??(($e=pe.meta)==null?void 0:$e.input_questions)??[];Oe.set(pe.key,{questions:Pe,description:(Qe=pe.meta)==null?void 0:Qe.description,sessionName:(Je=pe.meta)==null?void 0:Je.session_name}),Ie.set(pe.key,new Array(Pe.length).fill(""))}Ue(he),Te(_e),Pt(Oe),Ft(Ie)}).catch(()=>{})},[s,d,l,t,r]),A.useEffect(()=>s?u(d,Q=>{const he=Q.subject.split(".");if(he.length<3)return;const _e=he.slice(2).join(".");let Oe={};try{Oe=JSON.parse(new TextDecoder().decode(Q.data))}catch{return}const Ie=Oe.event_type,Ke=Oe.session_id;if(Ie==="input-request"&&Ke){const Fe=Oe.input_questions,Ge=Oe.session_name,$e=Oe.description;Fe!=null&&Fe.length&&(Pt(Qe=>{if(Qe.has(Ke))return Qe;const Je=new Map(Qe);return Je.set(Ke,{questions:Fe,description:$e,sessionName:Ge}),Je}),Ft(Qe=>{if(Qe.has(Ke))return Qe;const Je=new Map(Qe);return Je.set(Ke,new Array(Fe.length).fill("")),Je}));return}if(Ie==="input-resolved"&&Ke){Pt(Fe=>{if(!Fe.has(Ke))return Fe;const Ge=new Map(Fe);return Ge.delete(Ke),Ge}),Ft(Fe=>{const Ge=new Map(Fe);return Ge.delete(Ke),Ge});return}if(Ie==="confirm-request"&&Ke){const Fe=Oe.description,Ge=Oe.session_name;Fe&&Ue($e=>{if($e.has(Ke))return $e;const Qe=new Map($e);return Qe.set(Ke,{description:Fe,sessionName:Ge}),Qe});return}if(Ie==="confirm-resolved"&&Ke){Ue(Fe=>{if(!Fe.has(Ke))return Fe;const Ge=new Map(Fe);return Ge.delete(Ke),Ge});return}if(Ie==="permission-request"){const Fe=Oe.required_permissions,Ge=Oe.session_name;Fe!=null&&Fe.length&&Te($e=>{if($e.has(_e))return $e;const Qe=new Map($e);return Qe.set(_e,{permissions:Fe,sessionName:Ge}),Qe});return}if(Ie==="permission-resolved"){Te(Fe=>{if(!Fe.has(_e))return Fe;const Ge=new Map(Fe);return Ge.delete(_e),Ge});return}}):void 0,[s,d,u]);async function De(je,Q){try{await l("task.user_input",{id:je,value:[Q]})}catch(he){console.error("[Dashboard] Failed to respond to confirmation:",he)}}async function ot(je,Q){try{await l("task.user_input",{id:je,value:[Q]})}catch(he){console.error("[Dashboard] Failed to respond to permission request:",he)}}async function tt(je,Q){try{await l("task.user_input",{id:je,value:Q})}catch(he){console.error("[Dashboard] Failed to respond to input request:",he)}}function vt(je,Q){if(!ps())return;const he=`/hosts/${encodeURIComponent(d)}/runs/${encodeURIComponent(je)}`;y(Q?`${he}/${encodeURIComponent(Q)}`:he)}A.useEffect(()=>{if(!ee)return;let je=!1;return fetch("https://registry.npmjs.org/palmier/latest").then(Q=>Q.ok?Q.json():null).then(Q=>{!je&&(Q!=null&&Q.version)&&L(Q.version)}).catch(()=>{}),()=>{je=!0}},[ee]),A.useEffect(()=>{let je=!1;const Q={};for(const he of P){if(!he.version)continue;const _e=localStorage.getItem(`palmier.${d}.dismissedAgentUpdate.${he.key}`);_e&&(Q[he.key]=_e)}U(Q);for(const he of P)!he.version||!he.npmPackage||fetch(`https://registry.npmjs.org/${he.npmPackage}/latest`).then(_e=>_e.ok?_e.json():null).then(_e=>{je||!(_e!=null&&_e.version)||le(Oe=>Oe[he.key]===_e.version?Oe:{...Oe,[he.key]:_e.version})}).catch(()=>{});return()=>{je=!0}},[P]);const ft=P.find(je=>{if(!je.version)return!1;const Q=oe[je.key];return!Q||!Kh(je.version,Q)?!1:K[je.key]!==Q});function gn(je,Q){localStorage.setItem(`palmier.${d}.dismissedAgentUpdate.${je}`,Q),U(he=>({...he,[je]:Q}))}async function an(je){fe(!0),R(null);try{const Q=await l("host.updateAgent",{key:je});if(Q.error){R(Q.error),fe(!1);return}const he=await l("host.info");he.agents&&te(he.agents)}catch(Q){R(Q instanceof Error?Q.message:String(Q))}finally{fe(!1)}}const Wt=!N&&!!ee&&!!q&&Kh(ee,q)&&G!==q;function yn(){q&&(localStorage.setItem(`palmier.${d}.dismissedUpdateVersion`,q),J(q))}async function Kn(){fe(!0),R(null);try{const je=await l("host.update");if(je.error){R(je.error),fe(!1);return}}catch{}setTimeout(()=>window.location.reload(),15e3)}const pt=s&&!c;return b.jsxs("div",{className:"dashboard",children:[w&&b.jsx(G0,{daemonVersion:ee,agents:P,linkedClientToken:W,request:l,onEnabledCapabilitiesChange:M,onLinkedClientTokenChange:ue}),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(G0,{daemonVersion:ee,agents:P,linkedClientToken:W,request:l,onEnabledCapabilitiesChange:M,onLinkedClientTokenChange:ue}),b.jsx("h1",{className:"app-title",children:"Palmier"}),b.jsx(WE,{})]}),b.jsx("div",{className:"tab-bar",children:b.jsx(YE,{})})]}),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"})]})]}):pt?b.jsxs(b.Fragment,{children:[_&&!D&&b.jsx($E,{connected:s,hostId:d,request:l,subscribeEvents:u,agents:P,hostPlatform:S,isNotificationListener:Ae&&we.has("notifications"),onViewRun:vt}),D?b.jsx(AO,{connected:s,hostId:d,request:l,subscribeEvents:u,taskId:x.taskId,runId:decodeURIComponent(x.runId)}):_?null:b.jsx(rC,{connected:s,hostId:d,request:l,subscribeEvents:u,agents:P,hostPlatform:S,filterTaskId:j,onClearFilter:()=>{ps()&&y(`/hosts/${encodeURIComponent(d)}`)}})]}):b.jsx("div",{className:"empty-state",children:b.jsx("p",{children:"Connecting to host..."})})}),(N||Wt)&&!F&&!z&&b.jsx(Fb,{title:N?"Update Required":"Update Available",message:N?`Your Palmier host${ee?` (v${ee})`:""} is too old for this version of the app. Please update to continue.`:`A new version of Palmier (v${q}) is available. You're running v${ee}.`,onUpdate:Kn,onDismiss:N?void 0:yn}),!N&&!Wt&&ft&&!F&&!z&&b.jsx(Fb,{title:"Agent Update Available",message:`A new version of ${ft.label} (v${oe[ft.key]}) is available. You're running v${ft.version}.`,onUpdate:()=>an(ft.key),onDismiss:()=>gn(ft.key,oe[ft.key])}),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..."})]})}),z&&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:z}),b.jsx("div",{className:"confirm-modal-actions",children:b.jsx("button",{className:"btn btn-secondary",onClick:()=>{R(null)},children:"Retry"})})]})})]}),ds.createPortal(b.jsxs(b.Fragment,{children:[[...ve.entries()].map(([je,{description:Q,sessionName:he}])=>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"}),he&&b.jsx("p",{className:"confirm-modal-subtitle",children:he}),b.jsx("p",{className:"confirm-modal-message",children:Q}),b.jsxs("div",{className:"confirm-modal-actions",children:[b.jsx("button",{className:"btn btn-primary",onClick:()=>De(je,"confirmed"),children:"Confirm"}),b.jsx("button",{className:"btn btn-secondary",onClick:()=>De(je,"aborted"),children:"Abort"})]})]})},je)),[...Ve.entries()].map(([je,{permissions:Q,sessionName:he}])=>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:he||je})}),b.jsx("div",{className:"permission-list",children:Q.map((_e,Oe)=>b.jsxs("div",{className:"permission-item",children:[b.jsx("span",{className:"permission-name",children:_e.name}),_e.description&&b.jsx("span",{className:"permission-desc",children:_e.description})]},Oe))}),b.jsxs("div",{className:"permission-actions",children:[b.jsx("button",{className:"btn btn-primary",onClick:()=>ot(je,"granted"),children:"Allow Once"}),b.jsx("button",{className:"btn btn-secondary",onClick:()=>ot(je,"granted_all"),children:"Allow Always"})]}),b.jsx("button",{className:"permission-abort-link",onClick:()=>ot(je,"aborted"),children:"Deny & Abort Task"})]})},je)),[...et.entries()].map(([je,{questions:Q,description:he,sessionName:_e}])=>{const Oe=Gt.get(je)??new Array(Q.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"}),_e&&b.jsx("p",{className:"confirm-modal-subtitle",children:_e}),he&&b.jsx("p",{className:"confirm-modal-message",children:he}),b.jsx("div",{className:"input-list",children:Q.map((Ie,Ke)=>b.jsxs("div",{className:"input-item",children:[b.jsx("label",{className:"input-label",children:Ie}),b.jsx("input",{type:"text",className:"input-field",value:Oe[Ke]??"",onChange:Fe=>{Ft(Ge=>{const $e=new Map(Ge),Qe=[...$e.get(je)??[]];return Qe[Ke]=Fe.target.value,$e.set(je,Qe),$e})},autoFocus:Ke===0})]},Ke))}),b.jsx("div",{className:"input-actions",children:b.jsx("button",{className:"btn btn-primary",disabled:Oe.some(Ie=>!Ie.trim()),onClick:()=>tt(je,Oe),children:"Submit"})}),b.jsx("button",{className:"permission-abort-link",onClick:()=>tt(je,["aborted"]),children:"Cancel"})]})},je)})]}),document.body)]})}const NO=ys("Preferences",{web:()=>Fd(()=>import("./web-ZSYmpLle.js"),[]).then(e=>new e.PreferencesWeb)}),kl=!!window.__PALMIER_SERVE__&&(window.location.hostname==="localhost"||window.location.hostname==="127.0.0.1"),$b=Jn.isNativePlatform();function OO(){const[e,t]=A.useState(""),[r,s]=A.useState(!0),[l,u]=A.useState(!1),[c,f]=A.useState(null),{addPairedHost:d,pairedHosts:m}=qi(),y=Mr();async function g(){const x=e.trim().toUpperCase();if(!x){f("Enter a pairing code.");return}u(!0),f(null);try{let w;if(kl){const D=await fetch("/pair",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({code:x,label:navigator.userAgent})});if(!D.ok){const N=await D.json().catch(()=>({error:"Connection failed"}));throw new Error(N.error||`HTTP ${D.status}`)}w=await D.json()}else{const D=await fetch(`${Bu}/api/config`);if(!D.ok)throw new Error("Failed to fetch server config");const N=await D.json();if(!N.natsWsUrl)throw new Error("Server has no NATS WebSocket URL configured");const H=await Dx({servers:N.natsWsUrl,authenticator:Ex(N.natsJwt,new TextEncoder().encode(N.natsNkeySeed))}),F=Ou(),fe=`pair.${x}`,z=await H.request(fe,F.encode(JSON.stringify({label:navigator.userAgent})),{timeout:1e4});w=JSON.parse(F.decode(z.data)),await H.close()}const _={hostId:w.hostId,clientToken:w.clientToken,directUrl:kl?window.location.origin:void 0,...w.hostName?{name:w.hostName}:{}};if(d(_),Jn.isNativePlatform()&&dn){await NO.set({key:"hostId",value:w.hostId});try{const{token:D}=await dn.getFcmToken();await fetch(`${Bu}/api/fcm/register`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({hostId:w.hostId,fcmToken:D})})}catch(D){console.warn("FCM token registration failed:",D)}}const j=`/hosts/${encodeURIComponent(w.hostId)}`;y($b&&r?`${j}/pair/setup`:j)}catch(w){const _=w instanceof Error?w.message:String(w);_.includes("timeout")||_.includes("TIMEOUT")||_.includes("503")||_.toLowerCase().includes("no responders")?f("Code not found or expired. Check the code and try again."):f(_)}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:x=>t(x.target.value.toUpperCase()),placeholder:"A7K9M2",className:"form-input form-input-mono pair-code-input",autoFocus:!0,autoComplete:"off",disabled:l})]}),$b&&b.jsxs("label",{className:"pair-checkbox",children:[b.jsx("input",{type:"checkbox",checked:r,onChange:x=>s(x.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:g,disabled:l||!e.trim(),children:[l&&b.jsx("span",{className:"btn-spinner"}),l?"Pairing...":"Pair"]}),m.length>0&&b.jsx("button",{className:"btn btn-secondary btn-full",onClick:()=>y("/"),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 RO(){const e=Mr(),{connected:t,request:r,activeHost:s}=si(),{setHostLanUrl:l,pairedHosts:u}=qi(),c=u.length<=1,[f,d]=A.useState("loading"),[m,y]=A.useState(null),[g,x]=A.useState(null);function w(){e(`/hosts/${encodeURIComponent(s.hostId)}`,{replace:!0})}A.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 fe=F.linked_client_token??null;y(fe);const z=!!fe&&fe!==s.clientToken;d(z?"confirming":"linking")}),()=>{H=!0}},[t,f,s,r,l]),A.useEffect(()=>{if(f!=="linking")return;let H=!1;return(async()=>{try{if(dn){const{token:F}=await dn.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 _(){d("linking")}function j(){w()}function D(){x(null),d("linking")}const N=f==="confirming"&&ds.createPortal(b.jsx("div",{className:"confirm-modal-overlay",onClick:j,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:j,children:"Cancel"}),b.jsx("button",{className:"btn btn-primary",onClick:_,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:D,children:"Retry"}),b.jsx("button",{className:"btn btn-secondary",onClick:w,children:"Skip linking"})]})]})]}),N]})}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(Ix,{}),b.jsx("div",{className:"pair-setup-actions",children:b.jsx("button",{className:"btn btn-primary btn-full",onClick:w,children:"Finish"})})]})})}function MO(){const e=Mr();return A.useEffect(()=>{if(!dn)return;const t=dn.addListener("deepLink",({path:r})=>e(r));return()=>{t.then(r=>r.remove())}},[e]),null}function DO(){const{pairedHosts:e}=qi();return e.length===0?b.jsx(zl,{to:"/pair",replace:!0}):b.jsx(zl,{to:`/hosts/${encodeURIComponent(e[0].hostId)}`,replace:!0})}function LO(){const{hostId:e}=Yu(),{pairedHosts:t}=qi(),r=t.find(s=>s.hostId===e)??null;return r?b.jsx(vE,{activeHost:r,children:b.jsxs(ax,{children:[b.jsx(br,{index:!0,element:b.jsx(vu,{})}),b.jsx(br,{path:"tasks",element:b.jsx(vu,{})}),b.jsx(br,{path:"runs/:taskId",element:b.jsx(vu,{})}),b.jsx(br,{path:"runs/:taskId/:runId",element:b.jsx(vu,{})}),b.jsx(br,{path:"pair/setup",element:b.jsx(RO,{})}),b.jsx(br,{path:"*",element:b.jsx(zl,{to:".",replace:!0})})]})}):b.jsx(zl,{to:"/",replace:!0})}function zO(){return b.jsxs($_,{children:[b.jsx(MO,{}),b.jsxs(ax,{children:[b.jsx(br,{path:"/",element:b.jsx(DO,{})}),b.jsx(br,{path:"/pair",element:b.jsx(OO,{})}),b.jsx(br,{path:"/hosts/:hostId/*",element:b.jsx(LO,{})}),b.jsx(br,{path:"*",element:b.jsx(zl,{to:"/",replace:!0})})]})]})}fS.createRoot(document.getElementById("root")).render(b.jsx(A.StrictMode,{children:b.jsx(O_,{children:b.jsx(zO,{})})}));export{Id as W};
|
|
120
|
+
`))}function d(w,_,j,D){const N=j.enter("tableCell"),H=j.enter("phrasing"),F=j.containerPhrasing(w,{...D,before:u,after:u});return H(),N(),F}function m(w,_){return WN(w,{align:_,alignDelimiters:s,padding:r,stringLength:l})}function y(w,_,j){const D=w.children;let N=-1;const H=[],F=_.enter("table");for(;++N<D.length;)H[N]=g(D[N],_,j);return F(),H}function g(w,_,j){const D=w.children;let N=-1;const H=[],F=_.enter("tableRow");for(;++N<D.length;)H[N]=d(D[N],w,_,j);return F(),H}function x(w,_,j){let D=P1.inlineCode(w,_,j);return j.stack.includes("tableCell")&&(D=D.replace(/\|/g,"\\$&")),D}}function H3(){return{exit:{taskListCheckValueChecked:Pb,taskListCheckValueUnchecked:Pb,paragraph:I3}}}function q3(){return{unsafe:[{atBreak:!0,character:"-",after:"[:|-]"}],handlers:{listItem:F3}}}function Pb(e){const t=this.stack[this.stack.length-2];t.type,t.checked=e.type==="taskListCheckValueChecked"}function I3(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 F3(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=P1.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 $3(){return[SN(),FN(),GN(),M3(),H3()]}function Y3(e){return{extensions:[_N(),$N(e),JN(),P3(e),q3()]}}const V3={tokenize:Z3,partial:!0},H1={tokenize:W3,partial:!0},q1={tokenize:eO,partial:!0},I1={tokenize:tO,partial:!0},G3={tokenize:nO,partial:!0},F1={name:"wwwAutolink",tokenize:K3,previous:Y1},$1={name:"protocolAutolink",tokenize:Q3,previous:V1},ai={name:"emailAutolink",tokenize:X3,previous:G1},Dr={};function J3(){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,$1];Dr[104]=[ai,$1];Dr[87]=[ai,F1];Dr[119]=[ai,F1];function X3(e,t,r){const s=this;let l,u;return c;function c(g){return!Cd(g)||!G1.call(s,s.previous)||um(s.events)?r(g):(e.enter("literalAutolink"),e.enter("literalAutolinkEmail"),f(g))}function f(g){return Cd(g)?(e.consume(g),f):g===64?(e.consume(g),d):r(g)}function d(g){return g===46?e.check(G3,y,m)(g):g===45||g===95||mn(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&&_n(s.previous)?(e.exit("literalAutolinkEmail"),e.exit("literalAutolink"),t(g)):r(g)}}function K3(e,t,r){const s=this;return l;function l(c){return c!==87&&c!==119||!Y1.call(s,s.previous)||um(s.events)?r(c):(e.enter("literalAutolink"),e.enter("literalAutolinkWww"),e.check(V3,e.attempt(H1,e.attempt(q1,u),r),r)(c))}function u(c){return e.exit("literalAutolinkWww"),e.exit("literalAutolink"),t(c)}}function Q3(e,t,r){const s=this;let l="",u=!1;return c;function c(g){return(g===72||g===104)&&V1.call(s,s.previous)&&!um(s.events)?(e.enter("literalAutolink"),e.enter("literalAutolinkHttp"),l+=String.fromCodePoint(g),e.consume(g),f):r(g)}function f(g){if(_n(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||Pu(g)||jt(g)||gs(g)||Zu(g)?r(g):e.attempt(H1,e.attempt(q1,y),r)(g)}function y(g){return e.exit("literalAutolinkHttp"),e.exit("literalAutolink"),t(g)}}function Z3(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 W3(e,t,r){let s,l,u;return c;function c(m){return m===46||m===95?e.check(I1,d,f)(m):m===null||jt(m)||gs(m)||m!==45&&Zu(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 eO(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(I1,t,u)(c):c===null||jt(c)||gs(c)?t(c):(e.consume(c),l)}function u(c){return c===41&&s++,e.consume(c),l}}function tO(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||jt(f)||gs(f)?t(f):r(f)}function l(f){return f===null||f===40||f===91||jt(f)||gs(f)?t(f):s(f)}function u(f){return _n(f)?c(f):r(f)}function c(f){return f===59?(e.consume(f),s):_n(f)?(e.consume(f),c):r(f)}}function nO(e,t,r){return s;function s(u){return e.consume(u),l}function l(u){return mn(u)?r(u):t(u)}}function Y1(e){return e===null||e===40||e===42||e===95||e===91||e===93||e===126||jt(e)}function V1(e){return!_n(e)}function G1(e){return!(e===47||Cd(e))}function Cd(e){return e===43||e===45||e===46||e===95||mn(e)}function um(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 rO={tokenize:fO,partial:!0};function iO(){return{document:{91:{name:"gfmFootnoteDefinition",tokenize:oO,continuation:{tokenize:uO},exit:cO}},text:{91:{name:"gfmFootnoteCall",tokenize:lO},93:{name:"gfmPotentialFootnoteCall",add:"after",tokenize:sO,resolveTo:aO}}}}function sO(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 aO(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 lO(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||jt(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 jt(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 oO(e,t,r){const s=this,l=s.parser.gfmFootnotes||(s.parser.gfmFootnotes=[]);let u,c=0,f;return d;function d(_){return e.enter("gfmFootnoteDefinition")._container=!0,e.enter("gfmFootnoteDefinitionLabel"),e.enter("gfmFootnoteDefinitionLabelMarker"),e.consume(_),e.exit("gfmFootnoteDefinitionLabelMarker"),m}function m(_){return _===94?(e.enter("gfmFootnoteDefinitionMarker"),e.consume(_),e.exit("gfmFootnoteDefinitionMarker"),e.enter("gfmFootnoteDefinitionLabelString"),e.enter("chunkString").contentType="string",y):r(_)}function y(_){if(c>999||_===93&&!f||_===null||_===91||jt(_))return r(_);if(_===93){e.exit("chunkString");const j=e.exit("gfmFootnoteDefinitionLabelString");return u=wr(s.sliceSerialize(j)),e.enter("gfmFootnoteDefinitionLabelMarker"),e.consume(_),e.exit("gfmFootnoteDefinitionLabelMarker"),e.exit("gfmFootnoteDefinitionLabel"),x}return jt(_)||(f=!0),c++,e.consume(_),_===92?g:y}function g(_){return _===91||_===92||_===93?(e.consume(_),c++,y):y(_)}function x(_){return _===58?(e.enter("definitionMarker"),e.consume(_),e.exit("definitionMarker"),l.includes(u)||l.push(u),ct(e,w,"gfmFootnoteDefinitionWhitespace")):r(_)}function w(_){return t(_)}}function uO(e,t,r){return e.check(Jl,t,e.attempt(rO,t,r))}function cO(e){e.exit("gfmFootnoteDefinition")}function fO(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 hO(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,Wu(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(_){return m===126&&y[y.length-1][1].type!=="characterEscape"?d(_):(c.enter("strikethroughSequenceTemporary"),w(_))}function w(_){const j=ba(m);if(_===126)return g>1?d(_):(c.consume(_),g++,w);if(g<2&&!r)return d(_);const D=c.exit("strikethroughSequenceTemporary"),N=ba(_);return D._open=!N||N===2&&!!j,D._close=!j||j===2&&!!N,f(_)}}}class dO{constructor(){this.map=[]}add(t,r,s){mO(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 mO(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 pO(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 gO(){return{flow:{null:{name:"table",tokenize:yO,resolveAll:bO}}}}function yO(e,t,r){const s=this;let l=0,u=0,c;return f;function f(L){let G=s.events.length-1;for(;G>-1;){const le=s.events[G][1].type;if(le==="lineEnding"||le==="linePrefix")G--;else break}const J=G>-1?s.events[G][1].type:null,oe=J==="tableHead"||J==="tableRow"?R:d;return oe===R&&s.parser.lazy[s.now().line]?r(L):oe(L)}function d(L){return e.enter("tableHead"),e.enter("tableRow"),m(L)}function m(L){return L===124||(c=!0,u+=1),y(L)}function y(L){return L===null?r(L):He(L)?u>1?(u=0,s.interrupt=!0,e.exit("tableRow"),e.enter("lineEnding"),e.consume(L),e.exit("lineEnding"),w):r(L):st(L)?ct(e,y,"whitespace")(L):(u+=1,c&&(c=!1,l+=1),L===124?(e.enter("tableCellDivider"),e.consume(L),e.exit("tableCellDivider"),c=!0,y):(e.enter("data"),g(L)))}function g(L){return L===null||L===124||jt(L)?(e.exit("data"),y(L)):(e.consume(L),L===92?x:g)}function x(L){return L===92||L===124?(e.consume(L),g):g(L)}function w(L){return s.interrupt=!1,s.parser.lazy[s.now().line]?r(L):(e.enter("tableDelimiterRow"),c=!1,st(L)?ct(e,_,"linePrefix",s.parser.constructs.disable.null.includes("codeIndented")?void 0:4)(L):_(L))}function _(L){return L===45||L===58?D(L):L===124?(c=!0,e.enter("tableCellDivider"),e.consume(L),e.exit("tableCellDivider"),j):z(L)}function j(L){return st(L)?ct(e,D,"whitespace")(L):D(L)}function D(L){return L===58?(u+=1,c=!0,e.enter("tableDelimiterMarker"),e.consume(L),e.exit("tableDelimiterMarker"),N):L===45?(u+=1,N(L)):L===null||He(L)?fe(L):z(L)}function N(L){return L===45?(e.enter("tableDelimiterFiller"),H(L)):z(L)}function H(L){return L===45?(e.consume(L),H):L===58?(c=!0,e.exit("tableDelimiterFiller"),e.enter("tableDelimiterMarker"),e.consume(L),e.exit("tableDelimiterMarker"),F):(e.exit("tableDelimiterFiller"),F(L))}function F(L){return st(L)?ct(e,fe,"whitespace")(L):fe(L)}function fe(L){return L===124?_(L):L===null||He(L)?!c||l!==u?z(L):(e.exit("tableDelimiterRow"),e.exit("tableHead"),t(L)):z(L)}function z(L){return r(L)}function R(L){return e.enter("tableRow"),ee(L)}function ee(L){return L===124?(e.enter("tableCellDivider"),e.consume(L),e.exit("tableCellDivider"),ee):L===null||He(L)?(e.exit("tableRow"),t(L)):st(L)?ct(e,ee,"whitespace")(L):(e.enter("data"),$(L))}function $(L){return L===null||L===124||jt(L)?(e.exit("data"),ee(L)):(e.consume(L),L===92?q:$)}function q(L){return L===92||L===124?(e.consume(L),$):$(L)}}function bO(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 dO;for(;++r<e.length;){const w=e[r],_=w[1];w[0]==="enter"?_.type==="tableHead"?(f=!1,d!==0&&(Hb(x,t,d,m,y),y=void 0,d=0),m={type:"table",start:Object.assign({},_.start),end:Object.assign({},_.end)},x.add(r,0,[["enter",m,t]])):_.type==="tableRow"||_.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({},_.start),end:Object.assign({},_.end)},x.add(r,0,[["enter",y,t]])),l=_.type==="tableDelimiterRow"?2:y?3:1):l&&(_.type==="data"||_.type==="tableDelimiterMarker"||_.type==="tableDelimiterFiller")?(s=!1,c[2]===0&&(u[1]!==0&&(c[0]=c[1],g=xu(x,t,u,l,void 0,g),u=[0,0,0,0]),c[2]=r)):_.type==="tableCellDivider"&&(s?s=!1:(u[1]!==0&&(c[0]=c[1],g=xu(x,t,u,l,void 0,g)),u=c,c=[u[1],r,0,0])):_.type==="tableHead"?(f=!0,d=r):_.type==="tableRow"||_.type==="tableDelimiterRow"?(d=r,u[1]!==0?(c[0]=c[1],g=xu(x,t,u,l,r,g)):c[1]!==0&&(g=xu(x,t,c,l,r,g)),l=0):l&&(_.type==="data"||_.type==="tableDelimiterMarker"||_.type==="tableDelimiterFiller")&&(c[3]=r)}for(d!==0&&Hb(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=pO(t.events,r))}return e}function xu(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 _=r[2]+1,j=r[3]-r[2]-1;e.add(_,j,[])}}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 Hb(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 xO={name:"tasklistCheck",tokenize:wO};function vO(){return{text:{91:xO}}}function wO(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 jt(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 He(d)?t(d):st(d)?e.check({tokenize:SO},t,r)(d):r(d)}}function SO(e,t,r){return ct(e,s,"whitespace");function s(l){return l===null?r(l):t(l)}}function _O(e){return r1([J3(),iO(),hO(e),gO(),vO()])}const kO={};function qb(e){const t=this,r=e||kO,s=t.data(),l=s.micromarkExtensions||(s.micromarkExtensions=[]),u=s.fromMarkdownExtensions||(s.fromMarkdownExtensions=[]),c=s.toMarkdownExtensions||(s.toMarkdownExtensions=[]);l.push(_O(r)),u.push($3()),c.push(Y3(r))}function EO(e){k1(e,[/\r?\n|\r/g,CO])}function CO(){return{type:"break"}}function Ib(){return function(e){EO(e)}}function AO({connected:e,hostId:t,request:r,subscribeEvents:s,taskId:l,runId:u}){const c=Mr(),f=$d(),[d,m]=A.useState(!0),[y,g]=A.useState([]),[x,w]=A.useState(),[_,j]=A.useState(),[D,N]=A.useState(),H=x==="started"||x==="monitoring",F=x==="followup",fe=x==="started"||x==="followup",[z,R]=A.useState(null);pd(z!==null,()=>R(null));const[ee,$]=A.useState(!1),[q,L]=A.useState(""),[G,J]=A.useState(!1),oe=A.useRef(null),le=A.useRef(null),K=A.useRef(null),[U,W]=A.useState(u==="latest"?void 0:u),ue=u==="latest"&&U===null;A.useEffect(()=>{if(u!=="latest"){W(u);return}e&&(W(void 0),r("taskrun.list",{task_id:l,limit:1}).then(S=>{var xe,Ae;return W(((Ae=(xe=S.entries)==null?void 0:xe[0])==null?void 0:Ae.run_id)??null)}).catch(()=>W(null)))},[u,l,e,r]);async function we(){if(U)try{const S=await r("task.result",{id:l,run_id:U});if(S.error){console.error("No result:",S.error),c(t?`/hosts/${encodeURIComponent(t)}`:"/",{replace:!0});return}g(S.messages??[]),w(S.running_state),j(S.agent),N(S.agent_version)}catch(S){console.error("Failed to load result:",S),c(t?`/hosts/${encodeURIComponent(t)}`:"/",{replace:!0})}finally{m(!1)}}async function M(S){var xe;if(U)try{const ve=(xe=(await r("task.reports",{id:l,run_id:U,report_files:[S]})).reports)==null?void 0:xe[0];ve!=null&&ve.data_url?R({file:S,data_url:ve.data_url}):R({file:S,content:(ve==null?void 0:ve.content)??"Report not found."})}catch{R({file:S,content:"Failed to load report."})}}A.useEffect(()=>{!e||!U||(m(!0),we())},[e,l,U]),A.useEffect(()=>!e||!t||!U?void 0:s(t,async xe=>{try{const Ae=JSON.parse(new TextDecoder().decode(xe.data));if(Ae.event_type!=="running-state"&&Ae.event_type!=="result-updated"||xe.subject.split(".").pop()!==l||Ae.event_type==="result-updated"&&Ae.run_id&&Ae.run_id!==U)return;we()}catch{}}),[e,t,l,U,s,r]),A.useEffect(()=>{oe.current&&(oe.current.scrollTop=oe.current.scrollHeight)},[y]),A.useEffect(()=>{d||ue||!U||K.current!==U&&(K.current=U,requestAnimationFrame(()=>{oe.current&&(oe.current.scrollTop=oe.current.scrollHeight),window.scrollTo({top:document.documentElement.scrollHeight,behavior:"auto"})}))},[d,ue,U]);function P(S){if(S==="input")return"User Input";if(S==="permission")return"Permission";if(S==="confirmation")return"Confirmation"}function te(S){return S==="started"?"Task started":S==="finished"?"Task finished":S==="failed"?"Task failed":S==="error"?"Command failed":S==="aborted"?"Task aborted":S==="confirmation"?"Task confirmed":S==="stopped"?"Follow-up stopped":S??""}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"]}),ue?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:oe,children:[y.map((S,xe)=>{const Ae=fe&&S.role==="assistant"&&!y.slice(xe+1).some(ve=>ve.role==="assistant"||ve.role==="user");return S.role==="status"&&S.type==="monitoring"?null:S.role==="status"?b.jsxs("div",{className:`chat-status${S.type==="error"?" chat-status--error":""}`,children:[b.jsxs("div",{children:[te(S.type),S.time>0&&b.jsx("span",{className:"chat-status-time",children:f(S.time)})]}),S.content&&b.jsx("pre",{className:"chat-status-detail",children:S.content})]},xe):b.jsxs("div",{className:`chat-message chat-message--${S.role}${S.role==="assistant"&&S.stream==="stderr"?" chat-message--stderr":""}`,children:[S.role==="assistant"&&_&&b.jsxs("div",{className:"chat-message-agent",children:[md(_),D&&b.jsxs("span",{className:"chat-message-agent-version",children:[" v",D]})]}),b.jsxs("div",{className:"chat-message-content",children:[b.jsx(Mb,{remarkPlugins:[qb,Ib],components:{a:({...ve})=>b.jsx("a",{...ve,target:"_blank",rel:"noopener noreferrer"})},children:S.content}),Ae&&b.jsxs("div",{className:"chat-typing-indicator",children:[b.jsx("span",{}),b.jsx("span",{}),b.jsx("span",{})]})]}),S.attachments&&S.attachments.length>0&&b.jsx("div",{className:"chat-message-attachments",children:S.attachments.map(ve=>b.jsx("button",{className:"chat-attachment-chip",onClick:()=>M(ve),children:ve},ve))}),b.jsxs("div",{className:"chat-message-meta",children:[P(S.type)&&b.jsx("span",{className:"chat-message-type",children:P(S.type)}),S.time>0&&b.jsx("span",{children:f(S.time)})]})]},xe)}),fe&&(()=>{const S=y.filter(xe=>xe.role!=="status");return S.length===0||S[S.length-1].role!=="assistant"})()&&b.jsxs("div",{className:"chat-message chat-message--assistant",children:[_&&b.jsxs("div",{className:"chat-message-agent",children:[md(_),D&&b.jsxs("span",{className:"chat-message-agent-version",children:[" v",D]})]}),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"]})]}),H?b.jsx("div",{className:"chat-abort-bar",children:b.jsx("button",{className:"btn btn-secondary chat-abort-btn",disabled:ee,onClick:async()=>{if(confirm("Abort this task?")){$(!0);try{await r("task.abort",{id:l})}catch(S){console.error("Abort failed:",S)}finally{$(!1)}}},children:ee?"Aborting...":"Abort Task"})}):F?b.jsx("div",{className:"chat-input-bar",children:b.jsx("button",{className:"btn btn-secondary chat-stop-btn",disabled:ee,onClick:async()=>{$(!0);try{await r("task.stop_followup",{id:l,run_id:U})}catch(S){console.error("Stop failed:",S)}finally{$(!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 S=>{S.preventDefault();const xe=q.trim();if(!(!xe||G)){J(!0);try{await r("task.followup",{id:l,run_id:U,message:xe}),L("")}catch(Ae){console.error("Follow-up failed:",Ae)}finally{J(!1)}}},children:[b.jsx("input",{ref:le,className:"chat-input",type:"text",placeholder:"Follow-up message",value:q,onChange:S=>L(S.target.value),disabled:G}),b.jsx("button",{className:"btn btn-primary chat-send-btn",type:"submit",disabled:!q.trim()||G,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"})]})})]})]}),z&&b.jsx("div",{className:"report-dialog-overlay",onClick:()=>R(null),children:b.jsxs("div",{className:"report-dialog",onClick:S=>S.stopPropagation(),children:[b.jsxs("div",{className:"report-dialog-header",children:[b.jsx("span",{className:"report-dialog-title",children:z.file}),b.jsx("button",{className:"report-dialog-close",onClick:()=>R(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:z.data_url?b.jsx("img",{src:z.data_url,alt:z.file,style:{maxWidth:"100%",height:"auto"}}):b.jsx(Mb,{remarkPlugins:[qb,Ib],components:{a:({...S})=>b.jsx("a",{...S,target:"_blank",rel:"noopener noreferrer"})},children:z.content??""})})]})})]})}function Fb({title:e,message:t,onUpdate:r,onDismiss:s}){return b.jsx("div",{className:"confirm-modal-overlay",children:b.jsxs("div",{className:"confirm-modal",children:[b.jsx("h2",{className:"confirm-modal-title",children:e}),b.jsx("p",{className:"confirm-modal-message",children:t}),b.jsxs("div",{className:"confirm-modal-actions",children:[b.jsx("button",{className:"btn btn-primary",onClick:r,children:"Update Now"}),s&&b.jsx("button",{className:"btn btn-secondary",onClick:s,children:"Dismiss"})]})]})})}function TO(){const{activeHost:e}=si(),t=A.useRef(null);A.useEffect(()=>{if(Jn.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 gE("/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 pE("/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 jO="0.9.9";function Kh(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 vu(){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=Yu(),w=qx("(min-width: 768px)"),_=g.pathname.endsWith("/tasks"),j=x.runId?void 0:x.taskId,D=!!(x.taskId&&x.runId),[N,H]=A.useState(!1),[F,fe]=A.useState(!1),[z,R]=A.useState(null),[ee,$]=A.useState(null),[q,L]=A.useState(null),[G,J]=A.useState(()=>localStorage.getItem(`palmier.${d}.dismissedUpdateVersion`)),[oe,le]=A.useState({}),[K,U]=A.useState({}),[W,ue]=A.useState(null),[we,M]=A.useState(new Set),[P,te]=A.useState([]),[S,xe]=A.useState(),Ae=!!m&&W===m,[ve,Ue]=A.useState(new Map),[Ve,Te]=A.useState(new Map),[et,Pt]=A.useState(new Map),[Gt,Ft]=A.useState(new Map);TO(),A.useEffect(()=>{window.scrollTo(0,0)},[d]),A.useEffect(()=>{let je=!1;return JE().then(Q=>{je||M(Q)}),()=>{je=!0}},[]),A.useEffect(()=>{s&&l("host.info").then(je=>{var Ke,Fe,Ge,$e,Qe,Je;te(je.agents??[]),xe(je.host_platform),ue(je.linked_client_token??null),NE(je.agents??[]);const Q=je.version??null;$(Q),H(!!Q&&Kh(Q,jO)),t(d,je.lan_url??void 0),r(d,je.host_timezone);const he=new Map,_e=new Map,Oe=new Map,Ie=new Map;for(const pe of je.pending_prompts??[])if(pe.type==="confirmation")he.set(pe.key,{description:((Ke=pe.meta)==null?void 0:Ke.description)??"",sessionName:(Fe=pe.meta)==null?void 0:Fe.session_name});else if(pe.type==="permission")_e.set(pe.key,{permissions:pe.params??[],sessionName:(Ge=pe.meta)==null?void 0:Ge.session_name});else if(pe.type==="input"){const Pe=pe.params??(($e=pe.meta)==null?void 0:$e.input_questions)??[];Oe.set(pe.key,{questions:Pe,description:(Qe=pe.meta)==null?void 0:Qe.description,sessionName:(Je=pe.meta)==null?void 0:Je.session_name}),Ie.set(pe.key,new Array(Pe.length).fill(""))}Ue(he),Te(_e),Pt(Oe),Ft(Ie)}).catch(()=>{})},[s,d,l,t,r]),A.useEffect(()=>s?u(d,Q=>{const he=Q.subject.split(".");if(he.length<3)return;const _e=he.slice(2).join(".");let Oe={};try{Oe=JSON.parse(new TextDecoder().decode(Q.data))}catch{return}const Ie=Oe.event_type,Ke=Oe.session_id;if(Ie==="input-request"&&Ke){const Fe=Oe.input_questions,Ge=Oe.session_name,$e=Oe.description;Fe!=null&&Fe.length&&(Pt(Qe=>{if(Qe.has(Ke))return Qe;const Je=new Map(Qe);return Je.set(Ke,{questions:Fe,description:$e,sessionName:Ge}),Je}),Ft(Qe=>{if(Qe.has(Ke))return Qe;const Je=new Map(Qe);return Je.set(Ke,new Array(Fe.length).fill("")),Je}));return}if(Ie==="input-resolved"&&Ke){Pt(Fe=>{if(!Fe.has(Ke))return Fe;const Ge=new Map(Fe);return Ge.delete(Ke),Ge}),Ft(Fe=>{const Ge=new Map(Fe);return Ge.delete(Ke),Ge});return}if(Ie==="confirm-request"&&Ke){const Fe=Oe.description,Ge=Oe.session_name;Fe&&Ue($e=>{if($e.has(Ke))return $e;const Qe=new Map($e);return Qe.set(Ke,{description:Fe,sessionName:Ge}),Qe});return}if(Ie==="confirm-resolved"&&Ke){Ue(Fe=>{if(!Fe.has(Ke))return Fe;const Ge=new Map(Fe);return Ge.delete(Ke),Ge});return}if(Ie==="permission-request"){const Fe=Oe.required_permissions,Ge=Oe.session_name;Fe!=null&&Fe.length&&Te($e=>{if($e.has(_e))return $e;const Qe=new Map($e);return Qe.set(_e,{permissions:Fe,sessionName:Ge}),Qe});return}if(Ie==="permission-resolved"){Te(Fe=>{if(!Fe.has(_e))return Fe;const Ge=new Map(Fe);return Ge.delete(_e),Ge});return}}):void 0,[s,d,u]);async function De(je,Q){try{await l("task.user_input",{id:je,value:[Q]})}catch(he){console.error("[Dashboard] Failed to respond to confirmation:",he)}}async function ot(je,Q){try{await l("task.user_input",{id:je,value:[Q]})}catch(he){console.error("[Dashboard] Failed to respond to permission request:",he)}}async function tt(je,Q){try{await l("task.user_input",{id:je,value:Q})}catch(he){console.error("[Dashboard] Failed to respond to input request:",he)}}function vt(je,Q){if(!ps())return;const he=`/hosts/${encodeURIComponent(d)}/runs/${encodeURIComponent(je)}`;y(Q?`${he}/${encodeURIComponent(Q)}`:he)}A.useEffect(()=>{if(!ee)return;let je=!1;return fetch("https://registry.npmjs.org/palmier/latest").then(Q=>Q.ok?Q.json():null).then(Q=>{!je&&(Q!=null&&Q.version)&&L(Q.version)}).catch(()=>{}),()=>{je=!0}},[ee]),A.useEffect(()=>{let je=!1;const Q={};for(const he of P){if(!he.version)continue;const _e=localStorage.getItem(`palmier.${d}.dismissedAgentUpdate.${he.key}`);_e&&(Q[he.key]=_e)}U(Q);for(const he of P)!he.version||!he.npmPackage||fetch(`https://registry.npmjs.org/${he.npmPackage}/latest`).then(_e=>_e.ok?_e.json():null).then(_e=>{je||!(_e!=null&&_e.version)||le(Oe=>Oe[he.key]===_e.version?Oe:{...Oe,[he.key]:_e.version})}).catch(()=>{});return()=>{je=!0}},[P]);const ft=P.find(je=>{if(!je.version)return!1;const Q=oe[je.key];return!Q||!Kh(je.version,Q)?!1:K[je.key]!==Q});function gn(je,Q){localStorage.setItem(`palmier.${d}.dismissedAgentUpdate.${je}`,Q),U(he=>({...he,[je]:Q}))}async function an(je){fe(!0),R(null);try{const Q=await l("host.updateAgent",{key:je});if(Q.error){R(Q.error),fe(!1);return}const he=await l("host.info");he.agents&&te(he.agents)}catch(Q){R(Q instanceof Error?Q.message:String(Q))}finally{fe(!1)}}const Wt=!N&&!!ee&&!!q&&Kh(ee,q)&&G!==q;function yn(){q&&(localStorage.setItem(`palmier.${d}.dismissedUpdateVersion`,q),J(q))}async function Kn(){fe(!0),R(null);try{const je=await l("host.update");if(je.error){R(je.error),fe(!1);return}}catch{}setTimeout(()=>window.location.reload(),15e3)}const pt=s&&!c;return b.jsxs("div",{className:"dashboard",children:[w&&b.jsx(G0,{daemonVersion:ee,agents:P,linkedClientToken:W,request:l,onEnabledCapabilitiesChange:M,onLinkedClientTokenChange:ue}),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(G0,{daemonVersion:ee,agents:P,linkedClientToken:W,request:l,onEnabledCapabilitiesChange:M,onLinkedClientTokenChange:ue}),b.jsx("h1",{className:"app-title",children:"Palmier"}),b.jsx(WE,{})]}),b.jsx("div",{className:"tab-bar",children:b.jsx(YE,{})})]}),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"})]})]}):pt?b.jsxs(b.Fragment,{children:[_&&!D&&b.jsx($E,{connected:s,hostId:d,request:l,subscribeEvents:u,agents:P,hostPlatform:S,isNotificationListener:Ae&&we.has("notifications"),onViewRun:vt}),D?b.jsx(AO,{connected:s,hostId:d,request:l,subscribeEvents:u,taskId:x.taskId,runId:decodeURIComponent(x.runId)}):_?null:b.jsx(rC,{connected:s,hostId:d,request:l,subscribeEvents:u,agents:P,hostPlatform:S,filterTaskId:j,onClearFilter:()=>{ps()&&y(`/hosts/${encodeURIComponent(d)}`)}})]}):b.jsx("div",{className:"empty-state",children:b.jsx("p",{children:"Connecting to host..."})})}),(N||Wt)&&!F&&!z&&b.jsx(Fb,{title:N?"Update Required":"Update Available",message:N?`Your Palmier host${ee?` (v${ee})`:""} is too old for this version of the app. Please update to continue.`:`A new version of Palmier (v${q}) is available. You're running v${ee}.`,onUpdate:Kn,onDismiss:N?void 0:yn}),!N&&!Wt&&ft&&!F&&!z&&b.jsx(Fb,{title:"Agent Update Available",message:`A new version of ${ft.label} (v${oe[ft.key]}) is available. You're running v${ft.version}.`,onUpdate:()=>an(ft.key),onDismiss:()=>gn(ft.key,oe[ft.key])}),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..."})]})}),z&&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:z}),b.jsx("div",{className:"confirm-modal-actions",children:b.jsx("button",{className:"btn btn-secondary",onClick:()=>{R(null)},children:"Retry"})})]})})]}),ds.createPortal(b.jsxs(b.Fragment,{children:[[...ve.entries()].map(([je,{description:Q,sessionName:he}])=>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"}),he&&b.jsx("p",{className:"confirm-modal-subtitle",children:he}),b.jsx("p",{className:"confirm-modal-message",children:Q}),b.jsxs("div",{className:"confirm-modal-actions",children:[b.jsx("button",{className:"btn btn-primary",onClick:()=>De(je,"confirmed"),children:"Confirm"}),b.jsx("button",{className:"btn btn-secondary",onClick:()=>De(je,"aborted"),children:"Abort"})]})]})},je)),[...Ve.entries()].map(([je,{permissions:Q,sessionName:he}])=>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:he||je})}),b.jsx("div",{className:"permission-list",children:Q.map((_e,Oe)=>b.jsxs("div",{className:"permission-item",children:[b.jsx("span",{className:"permission-name",children:_e.name}),_e.description&&b.jsx("span",{className:"permission-desc",children:_e.description})]},Oe))}),b.jsxs("div",{className:"permission-actions",children:[b.jsx("button",{className:"btn btn-primary",onClick:()=>ot(je,"granted"),children:"Allow Once"}),b.jsx("button",{className:"btn btn-secondary",onClick:()=>ot(je,"granted_all"),children:"Allow Always"})]}),b.jsx("button",{className:"permission-abort-link",onClick:()=>ot(je,"aborted"),children:"Deny & Abort Task"})]})},je)),[...et.entries()].map(([je,{questions:Q,description:he,sessionName:_e}])=>{const Oe=Gt.get(je)??new Array(Q.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"}),_e&&b.jsx("p",{className:"confirm-modal-subtitle",children:_e}),he&&b.jsx("p",{className:"confirm-modal-message",children:he}),b.jsx("div",{className:"input-list",children:Q.map((Ie,Ke)=>b.jsxs("div",{className:"input-item",children:[b.jsx("label",{className:"input-label",children:Ie}),b.jsx("input",{type:"text",className:"input-field",value:Oe[Ke]??"",onChange:Fe=>{Ft(Ge=>{const $e=new Map(Ge),Qe=[...$e.get(je)??[]];return Qe[Ke]=Fe.target.value,$e.set(je,Qe),$e})},autoFocus:Ke===0})]},Ke))}),b.jsx("div",{className:"input-actions",children:b.jsx("button",{className:"btn btn-primary",disabled:Oe.some(Ie=>!Ie.trim()),onClick:()=>tt(je,Oe),children:"Submit"})}),b.jsx("button",{className:"permission-abort-link",onClick:()=>tt(je,["aborted"]),children:"Cancel"})]})},je)})]}),document.body)]})}const NO=ys("Preferences",{web:()=>Fd(()=>import("./web-BYY9thT9.js"),[]).then(e=>new e.PreferencesWeb)}),kl=!!window.__PALMIER_SERVE__&&(window.location.hostname==="localhost"||window.location.hostname==="127.0.0.1"),$b=Jn.isNativePlatform();function OO(){const[e,t]=A.useState(""),[r,s]=A.useState(!0),[l,u]=A.useState(!1),[c,f]=A.useState(null),{addPairedHost:d,pairedHosts:m}=qi(),y=Mr();async function g(){const x=e.trim().toUpperCase();if(!x){f("Enter a pairing code.");return}u(!0),f(null);try{let w;if(kl){const D=await fetch("/pair",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({code:x,label:navigator.userAgent})});if(!D.ok){const N=await D.json().catch(()=>({error:"Connection failed"}));throw new Error(N.error||`HTTP ${D.status}`)}w=await D.json()}else{const D=await fetch(`${Bu}/api/config`);if(!D.ok)throw new Error("Failed to fetch server config");const N=await D.json();if(!N.natsWsUrl)throw new Error("Server has no NATS WebSocket URL configured");const H=await Dx({servers:N.natsWsUrl,authenticator:Ex(N.natsJwt,new TextEncoder().encode(N.natsNkeySeed))}),F=Ou(),fe=`pair.${x}`,z=await H.request(fe,F.encode(JSON.stringify({label:navigator.userAgent})),{timeout:1e4});w=JSON.parse(F.decode(z.data)),await H.close()}const _={hostId:w.hostId,clientToken:w.clientToken,directUrl:kl?window.location.origin:void 0,...w.hostName?{name:w.hostName}:{}};if(d(_),Jn.isNativePlatform()&&dn){await NO.set({key:"hostId",value:w.hostId});try{const{token:D}=await dn.getFcmToken();await fetch(`${Bu}/api/fcm/register`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({hostId:w.hostId,fcmToken:D})})}catch(D){console.warn("FCM token registration failed:",D)}}const j=`/hosts/${encodeURIComponent(w.hostId)}`;y($b&&r?`${j}/pair/setup`:j)}catch(w){const _=w instanceof Error?w.message:String(w);_.includes("timeout")||_.includes("TIMEOUT")||_.includes("503")||_.toLowerCase().includes("no responders")?f("Code not found or expired. Check the code and try again."):f(_)}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 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:x=>t(x.target.value.toUpperCase()),placeholder:"A7K9M2",className:"form-input form-input-mono pair-code-input",autoFocus:!0,autoComplete:"off",disabled:l})]}),$b&&b.jsxs("label",{className:"pair-checkbox",children:[b.jsx("input",{type:"checkbox",checked:r,onChange:x=>s(x.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:g,disabled:l||!e.trim(),children:[l&&b.jsx("span",{className:"btn-spinner"}),l?"Pairing...":"Pair"]}),m.length>0&&b.jsx("button",{className:"btn btn-secondary btn-full",onClick:()=>y("/"),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 RO(){const e=Mr(),{connected:t,request:r,activeHost:s}=si(),{setHostLanUrl:l,pairedHosts:u}=qi(),c=u.length<=1,[f,d]=A.useState("loading"),[m,y]=A.useState(null),[g,x]=A.useState(null);function w(){e(`/hosts/${encodeURIComponent(s.hostId)}`,{replace:!0})}A.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 fe=F.linked_client_token??null;y(fe);const z=!!fe&&fe!==s.clientToken;d(z?"confirming":"linking")}),()=>{H=!0}},[t,f,s,r,l]),A.useEffect(()=>{if(f!=="linking")return;let H=!1;return(async()=>{try{if(dn){const{token:F}=await dn.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 _(){d("linking")}function j(){w()}function D(){x(null),d("linking")}const N=f==="confirming"&&ds.createPortal(b.jsx("div",{className:"confirm-modal-overlay",onClick:j,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:j,children:"Cancel"}),b.jsx("button",{className:"btn btn-primary",onClick:_,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:D,children:"Retry"}),b.jsx("button",{className:"btn btn-secondary",onClick:w,children:"Skip linking"})]})]})]}),N]})}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(Ix,{}),b.jsx("div",{className:"pair-setup-actions",children:b.jsx("button",{className:"btn btn-primary btn-full",onClick:w,children:"Finish"})})]})})}function MO(){const e=Mr();return A.useEffect(()=>{if(!dn)return;const t=dn.addListener("deepLink",({path:r})=>e(r));return()=>{t.then(r=>r.remove())}},[e]),null}function DO(){const{pairedHosts:e}=qi();return e.length===0?b.jsx(zl,{to:"/pair",replace:!0}):b.jsx(zl,{to:`/hosts/${encodeURIComponent(e[0].hostId)}`,replace:!0})}function LO(){const{hostId:e}=Yu(),{pairedHosts:t}=qi(),r=t.find(s=>s.hostId===e)??null;return r?b.jsx(vE,{activeHost:r,children:b.jsxs(ax,{children:[b.jsx(br,{index:!0,element:b.jsx(vu,{})}),b.jsx(br,{path:"tasks",element:b.jsx(vu,{})}),b.jsx(br,{path:"runs/:taskId",element:b.jsx(vu,{})}),b.jsx(br,{path:"runs/:taskId/:runId",element:b.jsx(vu,{})}),b.jsx(br,{path:"pair/setup",element:b.jsx(RO,{})}),b.jsx(br,{path:"*",element:b.jsx(zl,{to:".",replace:!0})})]})}):b.jsx(zl,{to:"/",replace:!0})}function zO(){return b.jsxs($_,{children:[b.jsx(MO,{}),b.jsxs(ax,{children:[b.jsx(br,{path:"/",element:b.jsx(DO,{})}),b.jsx(br,{path:"/pair",element:b.jsx(OO,{})}),b.jsx(br,{path:"/hosts/:hostId/*",element:b.jsx(LO,{})}),b.jsx(br,{path:"*",element:b.jsx(zl,{to:"/",replace:!0})})]})]})}fS.createRoot(document.getElementById("root")).render(b.jsx(A.StrictMode,{children:b.jsx(O_,{children:b.jsx(zO,{})})}));export{Id as W};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{W as i}from"./index-
|
|
1
|
+
import{W as i}from"./index-DsOLf_o3.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-DsOLf_o3.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-DsOLf_o3.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-DsOLf_o3.js"></script>
|
|
12
12
|
<link rel="stylesheet" crossorigin href="/assets/index-B9oqDWJv.css">
|
|
13
13
|
<link rel="manifest" href="/manifest.webmanifest"><script id="vite-plugin-pwa:register-sw" src="/registerSW.js"></script></head>
|
|
14
14
|
<body>
|