palmier 0.9.21 → 0.9.22

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 CHANGED
@@ -6,28 +6,26 @@
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
- You already have AI agents running on your machine. Palmier is an agent-agnostic bridge between those agents and your phone.
9
+ **Free AI agents, right from your phone.**
10
10
 
11
- From your phone, you can start sessions, schedule tasks, approve requests, and review results. From your machine, your agents can use phone-side capabilities like notifications, location, SMS, contacts, and calendar — so they can react to the real world, not just the terminal.
11
+ Palmier runs AI agents on your computer using the AI subscriptions you already have, then lets you start or schedule tasks, check progress, and respond to requests from your phone. It also gives your agents access to phone-side capabilities calendar, contacts, notifications, location, SMS, alarms — so they can react to the real world, not just the terminal.
12
12
 
13
- It runs on your machine as a background daemon and pairs with a mobile-friendly PWA.
13
+ Palmier is free, open source, and requires no account or API key. It runs as a background daemon on your machine and pairs with a mobile-friendly PWA or the Android app (iOS coming soon).
14
14
 
15
- ## What Palmier is
15
+ ## What Palmier does
16
16
 
17
- Palmier is an **agent-agnostic phone bridge and mobile control layer** for the agents you already use.
17
+ * **Your phone becomes an agent remote** start, schedule, monitor, and respond to agent tasks without being at your computer. On the same network, the Android app connects over LAN automatically for lower latency.
18
+ * **Agent access to your phone data** — give agents access to your phone's location, calendar, contacts, notifications, and SMS. They can also send email on your behalf, send you push notifications, and ask for your input when needed. (Phone capabilities require the Android app.)
19
+ * **Free with your existing AI subscriptions** — Palmier installs/detects agent CLIs and invokes them, so Claude Pro, Gemini, ChatGPT Plus, and [more](https://www.palmier.me/agents) just work. No extra account, no extra API key.
20
+ * **Task scheduling** — run tasks on a schedule, on demand, or in response to events (e.g. when a push notification arrives), using native OS schedulers (systemd, launchd, Task Scheduler).
21
+ * **You stay in control** — agents can only access phone capabilities you enable; approve requests from your phone, or enable yolo mode to auto-approve.
22
+ * **Your agents, your machine** — agents run on your hardware, not ours. Your data stays on your machine. No account required.
18
23
 
19
24
  It is not:
20
25
 
21
26
  * an agent runtime itself
22
- * a replacement for Claude Code / Codex CLI / Gemini CLI / OpenClaw / Hermes
23
27
  * a system for driving your phone UI like a human tapping through apps
24
28
 
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
30
-
31
29
  ## Quick Start
32
30
 
33
31
  1. Install a supported agent CLI — [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).
@@ -53,7 +51,7 @@ Instead, Palmier focuses on:
53
51
  ```
54
52
  This detects your agents, configures access, installs the background daemon, and starts pairing.
55
53
  4. Open `http://localhost:7256` to access the app locally — no pairing needed.
56
- 5. To access from other devices, enter the pairing code shown after init into the [PWA](https://app.palmier.me).
54
+ 5. 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
55
 
58
56
  ### Prerequisites
59
57
 
@@ -132,9 +130,11 @@ Three ways to reach your host, ordered by setup effort:
132
130
 
133
131
  | Mode | Where | Pairing | Notes |
134
132
  |------|-------|---------|-------|
135
- | **Local** | `http://localhost:7256` in a browser on the host machine | Not required | Loopback only. No internet needed. |
136
- | **Remote (web)** | [https://app.palmier.me](https://app.palmier.me) in any browser | Required | Always goes through the cloud relay. |
137
- | **Remote (app)** | [Android APK](https://github.com/caihongxu/palmier-android/releases/latest/download/palmier.apk) | Required | Push notifications, device capabilities, and **auto-LAN**. |
133
+ | **Local (browser)** | `http://localhost:7256` in a browser on the host machine | Not required | Loopback only. No internet or Palmier server connection needed. |
134
+ | **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. |
135
+ | **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**. |
136
+
137
+ iOS app coming soon.
138
138
 
139
139
  **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
140
 
@@ -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;
@@ -227,8 +227,21 @@ export async function runCommand(taskId) {
227
227
  transientPermissions: [],
228
228
  };
229
229
  if (task.frontmatter.command) {
230
- const result = await runCommandTriggeredMode(ctx);
231
- const outcome = resolveOutcome(taskDir, result.outcome);
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).`);
@@ -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-kjOWpVKd.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
+ 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-kjOWpVKd.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
+ 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-kjOWpVKd.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};
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};
@@ -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-kjOWpVKd.js"></script>
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>
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "palmier",
3
- "version": "0.9.21",
3
+ "version": "0.9.22",
4
4
  "description": "Palmier host CLI - provisions, executes tasks, and serves NATS RPC",
5
5
  "license": "Apache-2.0",
6
6
  "author": "Hongxu Cai",