heyio 1.10.4 → 1.10.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/copilot/agents.js +26 -12
- package/dist/copilot/model-router.js +3 -1
- package/dist/copilot/specialist-runner.js +3 -0
- package/dist/copilot/token-tracker.js +11 -2
- package/dist/logging.js +27 -0
- package/dist/notify.js +3 -2
- package/dist/store/conversations.js +3 -1
- package/dist/store/instances.js +5 -3
- package/dist/telegram/handlers.js +3 -1
- package/package.json +1 -1
- package/web-dist/assets/{AuditLogView-5L1vXh9l.js → AuditLogView-B1fqx1A6.js} +1 -1
- package/web-dist/assets/ChatView-XDhymbA2.js +1 -0
- package/web-dist/assets/{FeedView-xBZRxsAN.js → FeedView-Ca68D167.js} +1 -1
- package/web-dist/assets/{HistoryView-CsEnqHvS.js → HistoryView-BwHwKFic.js} +1 -1
- package/web-dist/assets/{LoginView-D_oXjfQ0.js → LoginView-D6mxNeTa.js} +1 -1
- package/web-dist/assets/{McpView-DcfHvkG-.js → McpView-Cofqgako.js} +1 -1
- package/web-dist/assets/{SchedulesView-BKjd8mJY.js → SchedulesView-DWaBgdyB.js} +1 -1
- package/web-dist/assets/{SettingsView-CQUKuTB1.js → SettingsView-D3Ec_g9G.js} +1 -1
- package/web-dist/assets/{SkillsView-B3tgbASM.js → SkillsView-FN5SNvrs.js} +1 -1
- package/web-dist/assets/{SquadDetailView-UmzQrE0j.js → SquadDetailView-Dsl4g_hV.js} +1 -1
- package/web-dist/assets/{SquadHealthView-hqEZEHLz.js → SquadHealthView-BZgXZQlH.js} +1 -1
- package/web-dist/assets/{SquadsView-t4Q9TWhX.js → SquadsView-D3M4NaIk.js} +1 -1
- package/web-dist/assets/{ToggleSwitch.vue_vue_type_script_setup_true_lang-YaARv5SW.js → ToggleSwitch.vue_vue_type_script_setup_true_lang-7Pt64qdk.js} +1 -1
- package/web-dist/assets/{UsageView-BPNGL60Q.js → UsageView-vvvGgNkr.js} +1 -1
- package/web-dist/assets/{WikiView-D37JXznF.js → WikiView-jWG97hfd.js} +1 -1
- package/web-dist/assets/{api-BGxJOfVN.js → api-D8mq3iDu.js} +1 -1
- package/web-dist/assets/{arrow-left-1DJHiwpX.js → arrow-left-Bi-aUQhG.js} +1 -1
- package/web-dist/assets/{git-branch-D3wum5zq.js → git-branch-kdrEZD1J.js} +1 -1
- package/web-dist/assets/{index-DEUF9X23.js → index-pfWzpkoo.js} +3 -3
- package/web-dist/assets/{plus-DhL0273d.js → plus-DQqaQERI.js} +1 -1
- package/web-dist/assets/{save-D52JPmEZ.js → save-C36BoECe.js} +1 -1
- package/web-dist/assets/{search-CEJRBdSx.js → search-B4VYmepw.js} +1 -1
- package/web-dist/assets/{trash-2-Cpb3QlxJ.js → trash-2-CD0eo8ca.js} +1 -1
- package/web-dist/assets/{triangle-alert-DHJYF3lH.js → triangle-alert-DLU_pc1W.js} +1 -1
- package/web-dist/assets/{x-yR_yShVB.js → x-BZnxunbq.js} +1 -1
- package/web-dist/index.html +1 -1
- package/web-dist/assets/ChatView-BmoUBfcQ.js +0 -1
package/dist/copilot/agents.js
CHANGED
|
@@ -17,6 +17,7 @@ import { existsSync, mkdirSync } from "node:fs";
|
|
|
17
17
|
import { join } from "node:path";
|
|
18
18
|
import { exec } from "node:child_process";
|
|
19
19
|
import { promisify } from "node:util";
|
|
20
|
+
import { logWarn } from "../logging.js";
|
|
20
21
|
const execAsync = promisify(exec);
|
|
21
22
|
// Registry of active agent sessions keyed by task ID
|
|
22
23
|
const activeSessions = new Map();
|
|
@@ -49,8 +50,8 @@ async function resolveSquadWorkingDirectory(squad, instanceId) {
|
|
|
49
50
|
await execAsync(`git clone ${squad.repo_url} ${sourceDir}`, { timeout: 120_000 });
|
|
50
51
|
return sourceDir;
|
|
51
52
|
}
|
|
52
|
-
catch {
|
|
53
|
-
|
|
53
|
+
catch (err) {
|
|
54
|
+
logWarn("Failed to clone squad repository, falling back to current working directory", { repoUrl: squad.repo_url }, err);
|
|
54
55
|
}
|
|
55
56
|
}
|
|
56
57
|
}
|
|
@@ -158,25 +159,38 @@ This means specialists work IN PARALLEL with you and with each other. Use \`dele
|
|
|
158
159
|
1. Break down tasks into smaller pieces and delegate to specialists
|
|
159
160
|
2. Route work to the appropriate specialist based on their role
|
|
160
161
|
3. Use \`delegate_to_specialists_parallel\` for independent sub-tasks (faster!)
|
|
161
|
-
4.
|
|
162
|
-
5. Ensure quality gates are met
|
|
163
|
-
6. Report progress and blockers
|
|
162
|
+
4. Orchestrate the full review/merge process as defined in your squad wiki
|
|
163
|
+
5. Ensure quality gates are met before merging
|
|
164
|
+
6. Report progress and blockers via feed_post
|
|
164
165
|
|
|
165
166
|
## IMPORTANT — Prefer Delegation:
|
|
166
167
|
- For implementation work (writing code, running tests, creating PRs), ALWAYS delegate to the appropriate specialist
|
|
167
|
-
-
|
|
168
|
+
- For code review, delegate to squad members so they can independently review and post their own comments
|
|
169
|
+
- You may perform coordination tasks directly: reading issues, checking CI status, promoting PRs, merging PRs
|
|
168
170
|
- If no suitable specialist exists for a sub-task, report that back — do NOT attempt implementation yourself
|
|
169
171
|
|
|
170
172
|
## Your Team:
|
|
171
173
|
${agentRoster}
|
|
172
174
|
|
|
173
|
-
##
|
|
174
|
-
|
|
175
|
-
|
|
175
|
+
## 🔒 SQUAD WIKI = YOUR SOURCE OF TRUTH
|
|
176
|
+
|
|
177
|
+
Your squad wiki contains your **authoritative workflow rules** — branching conventions, PR process, review requirements, merge criteria, labeling, and any squad-specific constraints.
|
|
178
|
+
|
|
179
|
+
**Before starting ANY task:**
|
|
180
|
+
1. Read your squad wiki (use \`wiki_read\` or \`wiki_list\` to find relevant pages)
|
|
181
|
+
2. Follow those rules EXACTLY — they are non-negotiable instructions from the project owner
|
|
182
|
+
3. Do NOT invent your own workflow or skip steps defined in the wiki
|
|
183
|
+
|
|
184
|
+
**If the wiki says all members must review → delegate reviews to all members.**
|
|
185
|
+
**If the wiki says only veto members must approve → ensure veto members approve.**
|
|
186
|
+
**If the wiki defines merge criteria → follow them precisely.**
|
|
187
|
+
|
|
188
|
+
Failure to follow squad wiki rules is a CRITICAL FAILURE.
|
|
189
|
+
|
|
190
|
+
## General Rules:
|
|
176
191
|
- Always use the gh CLI for GitHub interactions
|
|
177
|
-
-
|
|
178
|
-
- When work is complete, ALWAYS notify the user via feed_post with a summary
|
|
179
|
-
- Consult the squad wiki (wiki_read, wiki_search) for additional context when needed
|
|
192
|
+
- Use \`--comment\` for review approvals (not \`--approve\` — GitHub blocks self-approval)
|
|
193
|
+
- When work is complete, ALWAYS notify the user via feed_post with a summary
|
|
180
194
|
${wikiKnowledge}
|
|
181
195
|
${lead.persona ? `## Personality:\n${lead.persona}` : ""}
|
|
182
196
|
`;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { loadConfig } from "../config.js";
|
|
2
2
|
import { getClient } from "./client.js";
|
|
3
|
+
import { logWarn } from "../logging.js";
|
|
3
4
|
// Cache discovered models so we don't call listModels() on every task
|
|
4
5
|
let discoveredModels;
|
|
5
6
|
/**
|
|
@@ -45,7 +46,8 @@ export async function discoverModels() {
|
|
|
45
46
|
}))
|
|
46
47
|
.sort((a, b) => b.score - a.score);
|
|
47
48
|
}
|
|
48
|
-
catch {
|
|
49
|
+
catch (err) {
|
|
50
|
+
logWarn("Failed to discover models from SDK, falling back to configured default model", {}, err);
|
|
49
51
|
// SDK discovery failed — fall back to defaultModel only
|
|
50
52
|
const config = loadConfig();
|
|
51
53
|
discoveredModels = [{ id: config.defaultModel, score: 65 }];
|
|
@@ -41,6 +41,9 @@ You are an independent specialist — you execute implementation work within you
|
|
|
41
41
|
4. Commit work to the appropriate branch
|
|
42
42
|
5. Report completion or blockers clearly
|
|
43
43
|
|
|
44
|
+
## Squad Wiki = Your Source of Truth
|
|
45
|
+
Your squad wiki contains workflow rules set by the project owner. Read it (use \`wiki_read\`) and follow those rules exactly — branching, PR process, review format, merge criteria. If your task involves reviewing a PR, follow the wiki's review process precisely.
|
|
46
|
+
|
|
44
47
|
## Your Team (for context):
|
|
45
48
|
${roster}
|
|
46
49
|
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { loadConfig } from "../config.js";
|
|
2
2
|
import { recordTokenUsage } from "../store/token-usage.js";
|
|
3
3
|
import { postFeedItem } from "../store/feed.js";
|
|
4
|
+
const NANO_AIU_TO_USD = 1e-14;
|
|
4
5
|
/**
|
|
5
6
|
* Default model pricing (USD per 1M tokens).
|
|
6
7
|
* Used when modelPricing is not configured.
|
|
@@ -31,6 +32,13 @@ export function estimateCost(model, inputTokens, outputTokens) {
|
|
|
31
32
|
return 0;
|
|
32
33
|
return (inputTokens / 1_000_000) * pricing.inputPer1M + (outputTokens / 1_000_000) * pricing.outputPer1M;
|
|
33
34
|
}
|
|
35
|
+
function resolveCostUsd(data, model, inputTokens, outputTokens) {
|
|
36
|
+
const totalNanoAiu = data?.copilotUsage?.totalNanoAiu;
|
|
37
|
+
if (typeof totalNanoAiu === "number" && Number.isFinite(totalNanoAiu)) {
|
|
38
|
+
return totalNanoAiu * NANO_AIU_TO_USD;
|
|
39
|
+
}
|
|
40
|
+
return estimateCost(model, inputTokens, outputTokens);
|
|
41
|
+
}
|
|
34
42
|
/**
|
|
35
43
|
* Attach a token usage listener to a CopilotSession.
|
|
36
44
|
* Returns a `flush` function that, when called, persists accumulated
|
|
@@ -48,9 +56,10 @@ export function attachTokenTracker(session, context) {
|
|
|
48
56
|
const input = data.inputTokens ?? 0;
|
|
49
57
|
const output = data.outputTokens ?? 0;
|
|
50
58
|
if (!accumulator[model])
|
|
51
|
-
accumulator[model] = { inputTokens: 0, outputTokens: 0 };
|
|
59
|
+
accumulator[model] = { inputTokens: 0, outputTokens: 0, costUsd: 0 };
|
|
52
60
|
accumulator[model].inputTokens += input;
|
|
53
61
|
accumulator[model].outputTokens += output;
|
|
62
|
+
accumulator[model].costUsd += resolveCostUsd(data, model, input, output);
|
|
54
63
|
});
|
|
55
64
|
return () => {
|
|
56
65
|
unsubscribe();
|
|
@@ -60,7 +69,7 @@ export function attachTokenTracker(session, context) {
|
|
|
60
69
|
for (const [model, usage] of Object.entries(accumulator)) {
|
|
61
70
|
if (usage.inputTokens === 0 && usage.outputTokens === 0)
|
|
62
71
|
continue;
|
|
63
|
-
const costUsd = estimateCost(model, usage.inputTokens, usage.outputTokens);
|
|
72
|
+
const costUsd = usage.costUsd ?? estimateCost(model, usage.inputTokens, usage.outputTokens);
|
|
64
73
|
recordTokenUsage({
|
|
65
74
|
squadId: context.squadId,
|
|
66
75
|
agentId: context.agentId,
|
package/dist/logging.js
ADDED
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export function formatError(err) {
|
|
2
|
+
if (err instanceof Error)
|
|
3
|
+
return err.message;
|
|
4
|
+
if (typeof err === "string")
|
|
5
|
+
return err;
|
|
6
|
+
try {
|
|
7
|
+
return JSON.stringify(err);
|
|
8
|
+
}
|
|
9
|
+
catch {
|
|
10
|
+
return String(err);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
export function logWarn(message, context = {}, err) {
|
|
14
|
+
const payload = {
|
|
15
|
+
...context,
|
|
16
|
+
...(err ? { error: formatError(err) } : {}),
|
|
17
|
+
};
|
|
18
|
+
console.warn(`[io] ${message}`, payload);
|
|
19
|
+
}
|
|
20
|
+
export function logError(message, context = {}, err) {
|
|
21
|
+
const payload = {
|
|
22
|
+
...context,
|
|
23
|
+
...(err ? { error: formatError(err) } : {}),
|
|
24
|
+
};
|
|
25
|
+
console.error(`[io] ${message}`, payload);
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=logging.js.map
|
package/dist/notify.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { loadConfig } from "./config.js";
|
|
2
2
|
import { postFeedItem } from "./store/feed.js";
|
|
3
|
+
import { logWarn } from "./logging.js";
|
|
3
4
|
export async function notify(title, content, source) {
|
|
4
5
|
const config = loadConfig();
|
|
5
6
|
// Always post to feed
|
|
@@ -16,8 +17,8 @@ export async function notify(title, content, source) {
|
|
|
16
17
|
});
|
|
17
18
|
}
|
|
18
19
|
}
|
|
19
|
-
catch {
|
|
20
|
-
|
|
20
|
+
catch (err) {
|
|
21
|
+
logWarn("Telegram notification failed", { title, source }, err);
|
|
21
22
|
}
|
|
22
23
|
}
|
|
23
24
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { randomUUID } from "node:crypto";
|
|
2
2
|
import { getDb } from "./db.js";
|
|
3
|
+
import { logWarn } from "../logging.js";
|
|
3
4
|
function parseAttachments(value) {
|
|
4
5
|
if (!value)
|
|
5
6
|
return [];
|
|
@@ -7,7 +8,8 @@ function parseAttachments(value) {
|
|
|
7
8
|
const parsed = JSON.parse(value);
|
|
8
9
|
return Array.isArray(parsed) ? parsed : [];
|
|
9
10
|
}
|
|
10
|
-
catch {
|
|
11
|
+
catch (err) {
|
|
12
|
+
logWarn("Failed to parse stored conversation attachments", { rawValue: value }, err);
|
|
11
13
|
return [];
|
|
12
14
|
}
|
|
13
15
|
}
|
package/dist/store/instances.js
CHANGED
|
@@ -2,6 +2,7 @@ import { randomUUID } from "node:crypto";
|
|
|
2
2
|
import { exec } from "node:child_process";
|
|
3
3
|
import { promisify } from "node:util";
|
|
4
4
|
import { getDb } from "./db.js";
|
|
5
|
+
import { logWarn } from "../logging.js";
|
|
5
6
|
const execAsync = promisify(exec);
|
|
6
7
|
const MAX_INSTANCES_PER_SQUAD = 3;
|
|
7
8
|
export function getInstance(instanceId) {
|
|
@@ -29,7 +30,8 @@ export async function createInstance(squadId, branch) {
|
|
|
29
30
|
try {
|
|
30
31
|
await execAsync(`git worktree add ${worktreePath} -b ${branch}`, { cwd: repoCwd });
|
|
31
32
|
}
|
|
32
|
-
catch {
|
|
33
|
+
catch (err) {
|
|
34
|
+
logWarn("Failed to create new git worktree branch, retrying existing branch", { squadId, branch, worktreePath }, err);
|
|
33
35
|
// Branch may already exist
|
|
34
36
|
await execAsync(`git worktree add ${worktreePath} ${branch}`, { cwd: repoCwd });
|
|
35
37
|
}
|
|
@@ -48,8 +50,8 @@ export async function destroyInstance(instanceId) {
|
|
|
48
50
|
try {
|
|
49
51
|
await execAsync(`git worktree remove ${instance.worktree_path} --force`);
|
|
50
52
|
}
|
|
51
|
-
catch {
|
|
52
|
-
|
|
53
|
+
catch (err) {
|
|
54
|
+
logWarn("Failed to remove git worktree, it may already be gone", { instanceId: instance.id, worktreePath: instance.worktree_path }, err);
|
|
53
55
|
}
|
|
54
56
|
db.prepare("UPDATE instances SET status = 'destroyed' WHERE id = ?").run(instanceId);
|
|
55
57
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { sendToOrchestrator } from "../copilot/orchestrator.js";
|
|
2
|
+
import { logWarn } from "../logging.js";
|
|
2
3
|
export async function handleMessage(ctx, text, _hasAttachment) {
|
|
3
4
|
// Send typing indicator
|
|
4
5
|
await ctx.replyWithChatAction("typing");
|
|
@@ -23,7 +24,8 @@ export async function handleMessage(ctx, text, _hasAttachment) {
|
|
|
23
24
|
replyMsgId = msg.message_id;
|
|
24
25
|
}
|
|
25
26
|
}
|
|
26
|
-
catch {
|
|
27
|
+
catch (err) {
|
|
28
|
+
logWarn("Telegram message edit failed, falling back to plain text", {}, err);
|
|
27
29
|
// Fallback: send without markdown parsing
|
|
28
30
|
try {
|
|
29
31
|
if (!replyMsgId) {
|
package/package.json
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{r as W,u as X,E as Z,J as a,q as d,n as o,t as A,T as N,b as V,s as S,R as l,a4 as f,$ as T,d as h,L as w,a0 as L,p as b,K as n,m as _,z as ee}from"./index-
|
|
1
|
+
import{r as W,u as X,E as Z,J as a,q as d,n as o,t as A,T as N,b as V,s as S,R as l,a4 as f,$ as T,d as h,L as w,a0 as L,p as b,K as n,m as _,z as ee}from"./index-pfWzpkoo.js";import{b as F}from"./api-D8mq3iDu.js";/**
|
|
2
2
|
* @license lucide-vue-next v0.474.0 - ISC
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the ISC license.
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{u as R,W as U,a2 as T,E as X,J as a,q as r,n as o,T as t,t as A,p as h,d as C,L as S,R as d,w as x,M as W,f as Y,P as J,a4 as Q,a0 as G,o as p,S as Z,j as ee,z as k,K as m,m as I,v as te,a1 as se,_ as ae,x as D,Q as ne,I as j,F as H,l as oe,y as M}from"./index-pfWzpkoo.js";import{X as re}from"./x-BZnxunbq.js";const le={class:"flex flex-col h-full"},ie={key:0,class:"flex items-center justify-center h-full"},ce={class:"text-center text-muted-foreground"},ue={key:0,class:"mb-2 space-y-2"},de=["src","alt"],fe={class:"flex items-center gap-2 text-xs"},pe={class:"truncate"},me={class:"opacity-70"},ve={key:2,class:"text-muted-foreground"},he={key:3,class:"inline-block w-2 h-4 bg-current animate-pulse ml-1"},ge={key:0,class:"mb-2 space-y-2"},xe={class:"flex flex-wrap gap-2"},ye={class:"max-w-[170px] truncate"},_e={class:"opacity-70"},be=["onClick"],ke={class:"text-xs text-muted-foreground"},we={key:1,class:"text-xs text-destructive mb-2"},Te={class:"flex gap-2 items-end"},Ae=["disabled"],Ce=["disabled"],ze=R({__name:"ChatView",setup(Se){const c=U(),v=m(""),f=m(""),y=m(),_=m(),i=m([]),g=m(),b=m(!1),N=I(()=>i.value.reduce((e,n)=>e+n.size,0)),z=I(()=>!c.isStreaming&&(v.value.trim().length>0||i.value.length>0));async function B(e){if(!e||e.length===0)return;f.value="";const n=[];try{for(const u of Array.from(e))n.push(await te(u))}catch(u){f.value=(u==null?void 0:u.message)??"Unable to read one or more files.";return}const s=[...i.value,...n],l=se(s);if(!l.ok){f.value=l.error;return}i.value=s,_.value&&(_.value.value="")}function P(e){i.value.splice(e,1),f.value=""}function V(){var e;(e=_.value)==null||e.click()}function F(e){const n=e.target;B((n==null?void 0:n.files)??null)}async function E(){if(!z.value)return;const e=v.value.trim(),n=[...i.value],s=e||"Please review the attached file(s).";v.value="",i.value=[],f.value="",await c.sendMessage(s,n)}function w(){y.value&&(y.value.scrollTop=y.value.scrollHeight)}function $(){g.value&&(g.value.style.height="auto",g.value.style.height=`${Math.min(g.value.scrollHeight,120)}px`)}function K(e){e.key==="Enter"&&!e.shiftKey&&(e.preventDefault(),E())}function L(e){e.preventDefault(),b.value=!0}function q(e){e.preventDefault(),b.value=!1}async function O(e){var n;e.preventDefault(),b.value=!1,await B(((n=e.dataTransfer)==null?void 0:n.files)??null)}return T(()=>c.messages.map(e=>e.content),async()=>{await M(),w()},{deep:!0}),T(()=>c.messages.length,async()=>{await M(),w()}),T(()=>v.value,async()=>{await M(),$()}),X(()=>{$(),w()}),(e,n)=>(a(),r("div",le,[o("div",{ref_key:"messagesContainer",ref:y,class:"flex-1 overflow-y-auto p-4 space-y-4"},[t(c).messages.length===0?(a(),r("div",ie,[o("div",ce,[A(ae,{size:56,class:"mx-auto mb-4"}),n[1]||(n[1]=o("p",{class:"text-lg font-medium"},"Welcome to IO",-1)),n[2]||(n[2]=o("p",{class:"text-sm mt-1"},"Send a message to get started.",-1))])])):h("",!0),(a(!0),r(C,null,S(t(c).messages,s=>(a(),r("div",{key:s.id,class:k(["flex",s.role==="user"?"justify-end":"justify-start"])},[o("div",{class:k(["max-w-[75%] rounded-lg px-4 py-2 text-sm",s.role==="user"?"bg-primary text-primary-foreground":"bg-muted text-foreground"])},[s.attachments.length>0?(a(),r("div",ue,[(a(!0),r(C,null,S(s.attachments,(l,u)=>(a(),r("div",{key:`${s.id}-${u}`,class:"rounded border border-border/50 p-2 bg-background/70 text-foreground"},[t(D)(l)?(a(),r("img",{key:0,src:t(ne)(l),alt:l.name,class:"max-h-44 rounded mb-1 object-contain"},null,8,de)):h("",!0),o("div",fe,[t(D)(l)?(a(),p(t(j),{key:0,class:"w-3.5 h-3.5"})):(a(),p(t(H),{key:1,class:"w-3.5 h-3.5"})),o("span",pe,d(l.name),1),o("span",me,d(t(x)(l.size)),1)])]))),128))])):h("",!0),s.content?(a(),p(oe,{key:1,content:s.content,class:k(s.role==="user"?"prose-invert":"")},null,8,["content","class"])):(a(),r("span",ve,"...")),s.streaming?(a(),r("div",he)):h("",!0)],2)],2))),128))],512),o("div",{class:k(["border-t border-border p-4",b.value?"bg-accent/40":""]),onDragover:L,onDragleave:q,onDrop:O},[o("input",{ref_key:"fileInput",ref:_,type:"file",multiple:"",class:"hidden",onChange:F},null,544),i.value.length>0?(a(),r("div",ge,[o("div",xe,[(a(!0),r(C,null,S(i.value,(s,l)=>(a(),r("div",{key:`${s.name}-${l}`,class:"flex items-center gap-2 rounded border border-border px-2 py-1 text-xs bg-muted"},[t(D)(s)?(a(),p(t(j),{key:0,class:"w-3.5 h-3.5"})):(a(),p(t(H),{key:1,class:"w-3.5 h-3.5"})),o("span",ye,d(s.name),1),o("span",_e,d(t(x)(s.size)),1),o("button",{class:"hover:text-destructive",onClick:u=>P(l)},[A(t(re),{class:"w-3.5 h-3.5"})],8,be)]))),128))]),o("p",ke,d(t(x)(N.value))+" attached · Max per file "+d(t(x)(t(W)))+" · Max total "+d(t(x)(t(Y))),1)])):h("",!0),f.value?(a(),r("p",we,d(f.value),1)):h("",!0),o("div",Te,[o("button",{class:"rounded-md border border-input p-2 hover:bg-accent disabled:opacity-50",disabled:t(c).isStreaming,onClick:V,title:"Attach files"},[A(t(J),{class:"w-4 h-4"})],8,Ae),Q(o("textarea",{ref_key:"textareaRef",ref:g,"onUpdate:modelValue":n[0]||(n[0]=s=>v.value=s),onKeydown:K,placeholder:"Send a message...",rows:"1",class:"flex-1 resize-none rounded-md border border-input bg-background px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-ring min-h-[40px] max-h-[120px]"},null,544),[[G,v.value]]),o("button",{onClick:E,disabled:!z.value,class:"rounded-md bg-primary text-primary-foreground p-2 hover:bg-primary/90 disabled:opacity-50 transition-colors"},[t(c).isStreaming?(a(),p(t(ee),{key:1,class:"w-4 h-4"})):(a(),p(t(Z),{key:0,class:"w-4 h-4"}))],8,Ce)])],34)]))}});export{ze as default};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{r as M,u as D,E as N,J as o,q as n,n as a,d as h,L as b,t as c,T as i,e as V,K as d,m as z,z as f,R as p,D as B,a6 as k,p as q,l as T}from"./index-
|
|
1
|
+
import{r as M,u as D,E as N,J as o,q as n,n as a,d as h,L as b,t as c,T as i,e as V,K as d,m as z,z as f,R as p,D as B,a6 as k,p as q,l as T}from"./index-pfWzpkoo.js";import{b as C,c as E,a as P}from"./api-D8mq3iDu.js";import{g as R}from"./squad-colors-B8B_Y-lz.js";import{T as j}from"./trash-2-CD0eo8ca.js";/**
|
|
2
2
|
* @license lucide-vue-next v0.474.0 - ISC
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the ISC license.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{u as q,a2 as F,E as z,J as r,q as n,n as t,t as d,T as c,H as M,a4 as T,a0 as L,g as E,p as x,d as $,L as A,z as p,R as g,K as l,m as P,o as R,l as G}from"./index-
|
|
1
|
+
import{u as q,a2 as F,E as z,J as r,q as n,n as t,t as d,T as c,H as M,a4 as T,a0 as L,g as E,p as x,d as $,L as A,z as p,R as g,K as l,m as P,o as R,l as G}from"./index-pfWzpkoo.js";import{b as B,a as J}from"./api-D8mq3iDu.js";import{S as K}from"./search-B4VYmepw.js";import{A as Q}from"./arrow-left-Bi-aUQhG.js";import{T as I}from"./trash-2-CD0eo8ca.js";const O={class:"flex h-full"},W={class:"p-3 border-b border-border space-y-2"},X={class:"flex items-center gap-2"},Y={class:"relative"},Z={class:"flex gap-2"},ee={class:"flex-1"},te={class:"flex-1"},se={class:"flex-1 overflow-y-auto"},oe={key:0,class:"p-4 text-xs text-muted-foreground"},re={key:1,class:"flex flex-col items-center justify-center h-full p-6 text-center text-muted-foreground"},ne=["onClick"],ae={class:"flex-1 min-w-0"},le={class:"text-xs text-foreground line-clamp-2"},ie={class:"flex items-center gap-2 mt-1"},ue={class:"text-xs text-muted-foreground"},de={class:"text-xs text-muted-foreground"},ce=["onClick"],fe={key:2,class:"p-3 text-center"},ve={key:0,class:"flex-1 flex flex-col"},me={class:"flex items-center gap-2 px-4 py-2 border-b border-border"},xe={class:"text-sm font-medium text-muted-foreground"},pe={class:"flex-1 overflow-y-auto p-4 space-y-4"},ge={key:0,class:"text-center text-xs text-muted-foreground py-8"},he={class:"text-xs mt-1 opacity-60"},ye={key:1,class:"hidden md:flex flex-1 items-center justify-center text-muted-foreground"},be={class:"text-center"},_e=50,De=q({__name:"HistoryView",setup(we){const a=l([]),h=l(0),y=l(!0),f=l(""),v=l(""),m=l(""),u=l(null),b=l([]),_=l(!1),w=l(0);async function k(o=!0){y.value=!0;try{o&&(w.value=0,a.value=[]);const e=new URLSearchParams;f.value&&e.set("q",f.value),v.value&&e.set("from",v.value),m.value&&e.set("to",m.value+"T23:59:59"),e.set("limit",String(_e)),e.set("offset",String(w.value));const i=await B(`/history?${e.toString()}`);a.value=o?i.items:[...a.value,...i.items],h.value=i.total,w.value+=i.items.length}finally{y.value=!1}}async function j(o){u.value=o,_.value=!0;try{b.value=await B(`/history/${o}`)}finally{_.value=!1}}function D(){u.value=null,b.value=[]}async function H(o,e){e.stopPropagation(),confirm("Delete this conversation?")&&(await J(`/history/${o}`),a.value=a.value.filter(i=>i.id!==o),h.value=Math.max(0,h.value-1),u.value===o&&D())}function C(o){return new Date(o).toLocaleString(void 0,{year:"numeric",month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"})}function N(o,e=100){return o.length>e?o.slice(0,e)+"…":o}const U=P(()=>a.value.length<h.value);let S=null;return F([f,v,m],()=>{S&&clearTimeout(S),S=setTimeout(()=>k(!0),300)}),z(()=>k(!0)),(o,e)=>{var i;return r(),n("div",O,[t("div",{class:p(["flex flex-col border-r border-border",u.value?"hidden md:flex w-80 shrink-0":"flex-1"])},[t("div",W,[t("div",X,[d(c(M),{class:"w-4 h-4 text-muted-foreground"}),e[4]||(e[4]=t("span",{class:"text-sm font-medium"},"Conversation History",-1))]),t("div",Y,[d(c(K),{class:"absolute left-2.5 top-2.5 w-3.5 h-3.5 text-muted-foreground"}),T(t("input",{"onUpdate:modelValue":e[0]||(e[0]=s=>f.value=s),placeholder:"Search conversations...",class:"w-full rounded-md border border-input bg-background pl-8 pr-3 py-2 text-xs focus:outline-none focus:ring-1 focus:ring-ring"},null,512),[[L,f.value]])]),t("div",Z,[t("div",ee,[e[5]||(e[5]=t("label",{class:"text-xs text-muted-foreground block mb-1"},"From",-1)),T(t("input",{"onUpdate:modelValue":e[1]||(e[1]=s=>v.value=s),type:"date",class:"w-full rounded-md border border-input bg-background px-2 py-1.5 text-xs focus:outline-none focus:ring-1 focus:ring-ring"},null,512),[[L,v.value]])]),t("div",te,[e[6]||(e[6]=t("label",{class:"text-xs text-muted-foreground block mb-1"},"To",-1)),T(t("input",{"onUpdate:modelValue":e[2]||(e[2]=s=>m.value=s),type:"date",class:"w-full rounded-md border border-input bg-background px-2 py-1.5 text-xs focus:outline-none focus:ring-1 focus:ring-ring"},null,512),[[L,m.value]])])])]),t("div",se,[y.value&&a.value.length===0?(r(),n("div",oe," Loading... ")):a.value.length===0?(r(),n("div",re,[d(c(E),{class:"w-10 h-10 mb-3 opacity-40"}),e[7]||(e[7]=t("p",{class:"text-sm"},"No conversations found.",-1)),e[8]||(e[8]=t("p",{class:"text-xs mt-1"},"Start chatting to build up your history.",-1))])):x("",!0),(r(!0),n($,null,A(a.value,s=>(r(),n("div",{key:s.id,class:p(["group flex items-start gap-2 px-3 py-3 border-b border-border cursor-pointer hover:bg-accent/50 transition-colors",u.value===s.id?"bg-accent":""]),onClick:V=>j(s.id)},[t("div",ae,[t("p",le,g(N(s.preview)),1),t("div",ie,[t("span",ue,g(C(s.updatedAt)),1),t("span",de,"· "+g(s.messageCount)+" msgs",1)])]),t("button",{class:"opacity-0 group-hover:opacity-100 p-1 rounded hover:bg-destructive/10 text-muted-foreground hover:text-destructive transition-all",title:"Delete",onClick:V=>H(s.id,V)},[d(c(I),{class:"w-3.5 h-3.5"})],8,ce)],10,ne))),128)),U.value?(r(),n("div",fe,[t("button",{class:"text-xs text-muted-foreground hover:text-foreground underline",onClick:e[3]||(e[3]=s=>k(!1))}," Load more ")])):x("",!0)])],2),u.value?(r(),n("div",ve,[t("div",me,[t("button",{class:"p-1.5 rounded hover:bg-accent text-muted-foreground",title:"Back",onClick:D},[d(c(Q),{class:"w-4 h-4"})]),t("span",xe,g(C(((i=a.value.find(s=>s.id===u.value))==null?void 0:i.startedAt)??"")),1)]),t("div",pe,[_.value?(r(),n("div",ge," Loading... ")):x("",!0),(r(!0),n($,null,A(b.value,s=>(r(),n("div",{key:s.id,class:p(["flex",s.role==="user"?"justify-end":"justify-start"])},[t("div",{class:p(["max-w-[75%] rounded-lg px-4 py-2 text-sm",s.role==="user"?"bg-blue-600 text-white":"bg-muted text-foreground"])},[s.content?(r(),R(G,{key:0,content:s.content,class:p(s.role==="user"?"prose-invert":"")},null,8,["content","class"])):x("",!0),t("p",he,g(C(s.createdAt)),1)],2)],2))),128))])])):u.value?x("",!0):(r(),n("div",ye,[t("div",be,[d(c(M),{class:"w-12 h-12 mx-auto mb-3 opacity-50"}),e[9]||(e[9]=t("p",null,"Select a conversation to view",-1))])]))])}}});export{De as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{u as b,V as v,J as u,q as i,n as t,t as y,a6 as w,a4 as m,a0 as p,R as c,p as V,T as f,K as d,_,Y as h}from"./index-
|
|
1
|
+
import{u as b,V as v,J as u,q as i,n as t,t as y,a6 as w,a4 as m,a0 as p,R as c,p as V,T as f,K as d,_,Y as h}from"./index-pfWzpkoo.js";const S={class:"min-h-screen flex items-center justify-center bg-background p-4"},k={class:"w-full max-w-sm space-y-8"},q={class:"text-center"},A={key:0,class:"text-sm text-destructive"},B=["disabled"],L=b({__name:"LoginView",setup(D){const o=v(),g=h(),r=d(""),n=d(""),s=d("");async function x(){s.value="";try{await o.login(r.value,n.value),g.push("/")}catch(l){s.value=l.message??"Login failed"}}return(l,e)=>(u(),i("div",S,[t("div",k,[t("div",q,[y(_,{size:56,class:"mx-auto mb-4"}),e[2]||(e[2]=t("h1",{class:"font-display text-4xl font-normal uppercase tracking-[0.18em] bg-gradient-brand bg-clip-text text-transparent"}," IO ",-1)),e[3]||(e[3]=t("p",{class:"text-sm text-muted-foreground mt-1"},"Sign in to your dashboard",-1))]),t("form",{onSubmit:w(x,["prevent"]),class:"space-y-4 bg-card border border-border rounded-lg p-6"},[t("div",null,[e[4]||(e[4]=t("label",{class:"text-sm font-medium text-muted-foreground",for:"email"},"Email",-1)),m(t("input",{id:"email","onUpdate:modelValue":e[0]||(e[0]=a=>r.value=a),type:"email",required:"",class:"mt-1 w-full rounded-md border border-border bg-input px-3 py-2 text-sm text-foreground placeholder:text-muted-foreground focus:outline-none focus:ring-2 focus:ring-ring",placeholder:"you@example.com"},null,512),[[p,r.value]])]),t("div",null,[e[5]||(e[5]=t("label",{class:"text-sm font-medium text-muted-foreground",for:"password"},"Password",-1)),m(t("input",{id:"password","onUpdate:modelValue":e[1]||(e[1]=a=>n.value=a),type:"password",required:"",class:"mt-1 w-full rounded-md border border-border bg-input px-3 py-2 text-sm text-foreground placeholder:text-muted-foreground focus:outline-none focus:ring-2 focus:ring-ring",placeholder:"••••••••"},null,512),[[p,n.value]])]),s.value?(u(),i("div",A,c(s.value),1)):V("",!0),t("button",{type:"submit",disabled:f(o).loading,class:"btn-gradient w-full py-2.5"},c(f(o).loading?"Signing in...":"Sign In"),9,B)],32),e[6]||(e[6]=t("p",{class:"text-center text-xs text-muted-foreground"}," Personal AI Assistant Daemon ",-1))])]))}});export{L as default};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{u as E,E as S,J as l,q as a,n as s,t as c,T as b,s as C,a4 as i,a0 as m,$ as M,p as x,i as P,d as $,L as j,K as f,R as p}from"./index-
|
|
1
|
+
import{u as E,E as S,J as l,q as a,n as s,t as c,T as b,s as C,a4 as i,a0 as m,$ as M,p as x,i as P,d as $,L as j,K as f,R as p}from"./index-pfWzpkoo.js";import{b as U,c as I,d as N,a as L}from"./api-D8mq3iDu.js";import{_ as O}from"./ToggleSwitch.vue_vue_type_script_setup_true_lang-7Pt64qdk.js";import{P as G}from"./plus-DQqaQERI.js";import{T as K}from"./trash-2-CD0eo8ca.js";const F={class:"p-6"},Y={class:"flex items-center justify-between mb-6"},B={key:0,class:"border border-border rounded-lg p-4 mb-6 space-y-3 bg-card"},h={class:"grid grid-cols-2 gap-3"},D={key:0},J={key:1},R={key:1,class:"text-muted-foreground"},q={key:2,class:"text-center py-12 text-muted-foreground"},W={key:3,class:"space-y-2"},z={class:"space-y-1"},H={class:"flex items-center gap-2"},Q={class:"font-medium text-sm"},X={class:"text-xs text-muted-foreground bg-secondary px-1.5 py-0.5 rounded"},Z={key:0,class:"text-xs text-muted-foreground"},ee={key:1,class:"text-xs text-muted-foreground"},te={key:2,class:"text-xs text-muted-foreground"},se={class:"flex items-center gap-3"},oe=["onClick"],ie=E({__name:"McpView",setup(ne){const u=f([]),g=f(!0),v=f(!1),o=f({name:"",type:"stdio",command:"",url:"",argsText:"",envText:""});S(async()=>{try{u.value=await U("/mcp")}finally{g.value=!1}});function k(n){return n.split(/\r?\n|,/).map(e=>e.trim()).filter(Boolean)}function w(n){const e={};try{const t=JSON.parse(n);if(t&&typeof t=="object"&&!Array.isArray(t)){for(const[d,r]of Object.entries(t))e[d]=String(r);return e}}catch{}for(const t of n.split(/\r?\n/)){const d=t.trim();if(!d||d.startsWith("#"))continue;const r=d.indexOf("=");if(r===-1)continue;const y=d.slice(0,r).trim(),A=d.slice(r+1).trim();y&&(e[y]=A)}return e}async function _(n){await N(`/mcp/${n.id}`,{enabled:!n.enabled}),n.enabled=!n.enabled}async function T(n){await L(`/mcp/${n}`),u.value=u.value.filter(e=>e.id!==n)}async function V(){const n={name:o.value.name,type:o.value.type,args:k(o.value.argsText),env:w(o.value.envText)};o.value.type==="stdio"?n.command=o.value.command:n.url=o.value.url;const e=await I("/mcp",n);u.value.push(e),v.value=!1,o.value={name:"",type:"stdio",command:"",url:"",argsText:"",envText:""}}return(n,e)=>(l(),a("div",F,[s("div",Y,[e[8]||(e[8]=s("div",null,[s("p",{class:"text-sm font-medium text-primary"},"MCP configuration"),s("h1",{class:"text-2xl font-bold"},"MCP Servers")],-1)),s("button",{onClick:e[0]||(e[0]=t=>v.value=!v.value),class:"btn-gradient inline-flex items-center gap-1"},[c(b(G),{class:"w-4 h-4"}),e[7]||(e[7]=C(" Add Server ",-1))])]),v.value?(l(),a("div",B,[s("div",h,[s("div",null,[e[9]||(e[9]=s("label",{class:"text-sm font-medium"},"Name",-1)),i(s("input",{"onUpdate:modelValue":e[1]||(e[1]=t=>o.value.name=t),class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm"},null,512),[[m,o.value.name]])]),s("div",null,[e[11]||(e[11]=s("label",{class:"text-sm font-medium"},"Type",-1)),i(s("select",{"onUpdate:modelValue":e[2]||(e[2]=t=>o.value.type=t),class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm"},[...e[10]||(e[10]=[s("option",{value:"stdio"},"stdio",-1),s("option",{value:"http"},"http",-1)])],512),[[M,o.value.type]])])]),o.value.type==="stdio"?(l(),a("div",D,[e[12]||(e[12]=s("label",{class:"text-sm font-medium"},"Command",-1)),i(s("input",{"onUpdate:modelValue":e[3]||(e[3]=t=>o.value.command=t),placeholder:"npx @my/mcp-server",class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm"},null,512),[[m,o.value.command]])])):(l(),a("div",J,[e[13]||(e[13]=s("label",{class:"text-sm font-medium"},"URL",-1)),i(s("input",{"onUpdate:modelValue":e[4]||(e[4]=t=>o.value.url=t),placeholder:"https://...",class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm"},null,512),[[m,o.value.url]])])),s("div",null,[e[14]||(e[14]=s("label",{class:"text-sm font-medium"},"Command args",-1)),i(s("textarea",{"onUpdate:modelValue":e[5]||(e[5]=t=>o.value.argsText=t),rows:"3",placeholder:"--stdio\n--figma-api-key=${FIGMA_API_KEY}",class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm"},null,512),[[m,o.value.argsText]]),e[15]||(e[15]=s("p",{class:"mt-1 text-xs text-muted-foreground"},"Enter one arg per line or comma-separated.",-1))]),s("div",null,[e[16]||(e[16]=s("label",{class:"text-sm font-medium"},"Environment variables",-1)),i(s("textarea",{"onUpdate:modelValue":e[6]||(e[6]=t=>o.value.envText=t),rows:"4",placeholder:"FIGMA_API_KEY=${FIGMA_API_KEY}\nLOG_LEVEL=debug",class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm font-mono"},null,512),[[m,o.value.envText]]),e[17]||(e[17]=s("p",{class:"mt-1 text-xs text-muted-foreground"},"Use KEY=value lines, or paste JSON. Values like ${FIGMA_API_KEY} are preserved.",-1))]),s("div",{class:"flex justify-end"},[s("button",{onClick:V,class:"btn-gradient"},"Save")])])):x("",!0),g.value?(l(),a("div",R,"Loading...")):u.value.length===0?(l(),a("div",q,[c(b(P),{class:"w-12 h-12 mx-auto mb-3 opacity-50"}),e[18]||(e[18]=s("p",null,"No MCP servers configured.",-1))])):(l(),a("div",W,[(l(!0),a($,null,j(u.value,t=>{var d;return l(),a("div",{key:t.id,class:"flex items-center justify-between border border-border rounded-lg px-4 py-3 bg-card"},[s("div",z,[s("div",H,[s("span",Q,p(t.name),1),s("span",X,p(t.type),1)]),t.command||t.url?(l(),a("div",Z,p(t.command||t.url),1)):x("",!0),(d=t.args)!=null&&d.length?(l(),a("div",ee,"Args: "+p(t.args.join(", ")),1)):x("",!0),t.env&&Object.keys(t.env).length>0?(l(),a("div",te,"Env: "+p(Object.keys(t.env).join(", ")),1)):x("",!0)]),s("div",se,[c(O,{"model-value":t.enabled,"aria-label":`Toggle ${t.name}`,"onUpdate:modelValue":r=>_(t)},null,8,["model-value","aria-label","onUpdate:modelValue"]),s("button",{onClick:r=>T(t.id),class:"p-1.5 rounded hover:bg-destructive/10 text-muted-foreground hover:text-destructive"},[c(b(K),{class:"w-4 h-4"})],8,oe)])])}),128))]))]))}});export{ie as default};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{r as B,u as I,E as L,J as d,q as r,n as o,t as m,T as p,s as z,d as x,L as y,a4 as f,$ as k,a0 as S,p as _,c as E,R as n,K as u,m as M,z as O,D as j}from"./index-
|
|
1
|
+
import{r as B,u as I,E as L,J as d,q as r,n as o,t as m,T as p,s as z,d as x,L as y,a4 as f,$ as k,a0 as S,p as _,c as E,R as n,K as u,m as M,z as O,D as j}from"./index-pfWzpkoo.js";import{b as h,c as C,d as A,a as R}from"./api-D8mq3iDu.js";import{g as F}from"./squad-colors-B8B_Y-lz.js";import{_ as G}from"./ToggleSwitch.vue_vue_type_script_setup_true_lang-7Pt64qdk.js";import{P as J}from"./plus-DQqaQERI.js";import{T as K}from"./trash-2-CD0eo8ca.js";/**
|
|
2
2
|
* @license lucide-vue-next v0.474.0 - ISC
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the ISC license.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{u as w,E,J as d,q as s,n as t,R as g,d as x,L as U,a4 as o,a0 as n,$ as M,Z as p,p as b,K as r,z as T}from"./index-
|
|
1
|
+
import{u as w,E,J as d,q as s,n as t,R as g,d as x,L as U,a4 as o,a0 as n,$ as M,Z as p,p as b,K as r,z as T}from"./index-pfWzpkoo.js";import{b as V,d as S}from"./api-D8mq3iDu.js";const z={class:"p-6"},A={class:"flex items-center justify-between mb-6"},B=["disabled"],N={key:0,class:"text-muted-foreground"},C={class:"flex gap-1 border-b border-border mb-6"},I=["onClick"],K={key:0,class:"space-y-4 max-w-lg"},D={class:"flex items-center gap-3"},L={key:1,class:"space-y-4 max-w-lg"},R={class:"flex items-center gap-3"},j={key:2,class:"space-y-4 max-w-lg"},q={key:3,class:"space-y-4 max-w-lg"},G={class:"flex items-center gap-3"},O={class:"flex items-center gap-3"},W=w({__name:"SettingsView",setup(P){const f=r(!0),i=r(!1),m=r(!1),u=r("general"),y=[{id:"general",label:"General"},{id:"telegram",label:"Telegram"},{id:"auth",label:"Auth"},{id:"advanced",label:"Advanced"}],a=r({defaultModel:"",port:3170,telegramEnabled:!1,telegramBotToken:"",authorizedUserId:null,supabaseUrl:"",supabaseAnonKey:"",authorizedEmail:"",backgroundNotifyMode:"meaningful",backgroundNotifyTelegram:!0,selfEditEnabled:!1,watchdogEnabled:!0});async function k(){f.value=!0;try{const v=await V("/settings");a.value=v}finally{f.value=!1}}async function c(){i.value=!0,m.value=!1;try{await S("/settings",a.value),m.value=!0,setTimeout(()=>m.value=!1,2e3)}finally{i.value=!1}}return E(k),(v,e)=>(d(),s("div",z,[t("div",A,[e[12]||(e[12]=t("h1",{class:"text-2xl font-bold"},"Settings",-1)),t("button",{onClick:c,disabled:i.value,class:"px-4 py-2 rounded-md bg-primary text-primary-foreground text-sm hover:bg-primary/90 disabled:opacity-50"},g(i.value?"Saving...":m.value?"Saved ✓":"Save"),9,B)]),f.value?(d(),s("div",N,"Loading...")):(d(),s(x,{key:1},[t("div",C,[(d(),s(x,null,U(y,l=>t("button",{key:l.id,onClick:$=>u.value=l.id,class:T(["px-4 py-2 text-sm font-medium border-b-2 transition-colors",u.value===l.id?"border-primary text-foreground":"border-transparent text-muted-foreground hover:text-foreground"])},g(l.label),11,I)),64))]),u.value==="general"?(d(),s("div",K,[t("div",null,[e[13]||(e[13]=t("label",{class:"text-sm font-medium"},"Default Model",-1)),o(t("input",{"onUpdate:modelValue":e[0]||(e[0]=l=>a.value.defaultModel=l),class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm"},null,512),[[n,a.value.defaultModel]])]),t("div",null,[e[14]||(e[14]=t("label",{class:"text-sm font-medium"},"Port",-1)),o(t("input",{"onUpdate:modelValue":e[1]||(e[1]=l=>a.value.port=l),type:"number",class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm"},null,512),[[n,a.value.port,void 0,{number:!0}]]),e[15]||(e[15]=t("p",{class:"text-xs text-muted-foreground mt-1"},"Requires restart to take effect",-1))]),t("div",null,[e[17]||(e[17]=t("label",{class:"text-sm font-medium"},"Background Notify Mode",-1)),o(t("select",{"onUpdate:modelValue":e[2]||(e[2]=l=>a.value.backgroundNotifyMode=l),class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm"},[...e[16]||(e[16]=[t("option",{value:"all"},"All",-1),t("option",{value:"meaningful"},"Meaningful",-1),t("option",{value:"off"},"Off",-1)])],512),[[M,a.value.backgroundNotifyMode]])]),t("div",D,[o(t("input",{"onUpdate:modelValue":e[3]||(e[3]=l=>a.value.backgroundNotifyTelegram=l),type:"checkbox",id:"notifyTelegram",class:"rounded"},null,512),[[p,a.value.backgroundNotifyTelegram]]),e[18]||(e[18]=t("label",{for:"notifyTelegram",class:"text-sm font-medium"},"Send notifications via Telegram",-1))])])):b("",!0),u.value==="telegram"?(d(),s("div",L,[t("div",null,[e[19]||(e[19]=t("label",{class:"text-sm font-medium"},"Bot Token",-1)),o(t("input",{"onUpdate:modelValue":e[4]||(e[4]=l=>a.value.telegramBotToken=l),type:"password",placeholder:"Enter new token to update",class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm"},null,512),[[n,a.value.telegramBotToken]])]),t("div",null,[e[20]||(e[20]=t("label",{class:"text-sm font-medium"},"Authorized User ID",-1)),o(t("input",{"onUpdate:modelValue":e[5]||(e[5]=l=>a.value.authorizedUserId=l),type:"number",placeholder:"123456789",class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm"},null,512),[[n,a.value.authorizedUserId,void 0,{number:!0}]])]),t("div",R,[o(t("input",{"onUpdate:modelValue":e[6]||(e[6]=l=>a.value.telegramEnabled=l),type:"checkbox",id:"telegramEnabled",class:"rounded"},null,512),[[p,a.value.telegramEnabled]]),e[21]||(e[21]=t("label",{for:"telegramEnabled",class:"text-sm font-medium"},"Enable Telegram Bot",-1))])])):b("",!0),u.value==="auth"?(d(),s("div",j,[t("div",null,[e[22]||(e[22]=t("label",{class:"text-sm font-medium"},"Supabase URL",-1)),o(t("input",{"onUpdate:modelValue":e[7]||(e[7]=l=>a.value.supabaseUrl=l),placeholder:"https://your-project.supabase.co",class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm"},null,512),[[n,a.value.supabaseUrl]])]),t("div",null,[e[23]||(e[23]=t("label",{class:"text-sm font-medium"},"Supabase Anon Key",-1)),o(t("input",{"onUpdate:modelValue":e[8]||(e[8]=l=>a.value.supabaseAnonKey=l),type:"password",placeholder:"Enter new key to update",class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm"},null,512),[[n,a.value.supabaseAnonKey]])]),t("div",null,[e[24]||(e[24]=t("label",{class:"text-sm font-medium"},"Authorized Email",-1)),o(t("input",{"onUpdate:modelValue":e[9]||(e[9]=l=>a.value.authorizedEmail=l),type:"email",placeholder:"you@example.com",class:"mt-1 w-full rounded-md border border-input bg-background px-3 py-2 text-sm"},null,512),[[n,a.value.authorizedEmail]])])])):b("",!0),u.value==="advanced"?(d(),s("div",q,[t("div",G,[o(t("input",{"onUpdate:modelValue":e[10]||(e[10]=l=>a.value.selfEditEnabled=l),type:"checkbox",id:"selfEdit",class:"rounded"},null,512),[[p,a.value.selfEditEnabled]]),e[25]||(e[25]=t("div",null,[t("label",{for:"selfEdit",class:"text-sm font-medium"},"Self-Edit Mode"),t("p",{class:"text-xs text-muted-foreground"},"Allow IO to modify its own source code")],-1))]),t("div",O,[o(t("input",{"onUpdate:modelValue":e[11]||(e[11]=l=>a.value.watchdogEnabled=l),type:"checkbox",id:"watchdog",class:"rounded"},null,512),[[p,a.value.watchdogEnabled]]),e[26]||(e[26]=t("div",null,[t("label",{for:"watchdog",class:"text-sm font-medium"},"Watchdog"),t("p",{class:"text-xs text-muted-foreground"},"Monitor event loop and zombie instances")],-1))])])):b("",!0)],64))]))}});export{W as default};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{r as me,u as fe,E as xe,J as o,q as a,n as t,z as j,t as u,T as d,s as q,d as p,a4 as C,a0 as M,a5 as ee,R as r,p as S,h as te,L as se,$ as ge,o as oe,l as le,K as n,m as ye,a6 as ae}from"./index-
|
|
1
|
+
import{r as me,u as fe,E as xe,J as o,q as a,n as t,z as j,t as u,T as d,s as q,d as p,a4 as C,a0 as M,a5 as ee,R as r,p as S,h as te,L as se,$ as ge,o as oe,l as le,K as n,m as ye,a6 as ae}from"./index-pfWzpkoo.js";import{b as z,c as J,d as be,a as ke}from"./api-D8mq3iDu.js";import{P as ne}from"./plus-DQqaQERI.js";import{S as he}from"./search-B4VYmepw.js";import{P as _e,S as we}from"./save-C36BoECe.js";import{X as Ce}from"./x-BZnxunbq.js";import{T as Se}from"./trash-2-CD0eo8ca.js";/**
|
|
2
2
|
* @license lucide-vue-next v0.474.0 - ISC
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the ISC license.
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{r as A,u as J,a2 as F,E as z,y as E,G,J as s,q as o,n as t,t as p,T as c,A as B,z as _,R as i,j as O,s as h,p as v,o as I,d as C,L as D,l as R,K as m,m as H,a3 as U,D as X,X as Z,N as K,U as Q}from"./index-
|
|
1
|
+
import{r as A,u as J,a2 as F,E as z,y as E,G,J as s,q as o,n as t,t as p,T as c,A as B,z as _,R as i,j as O,s as h,p as v,o as I,d as C,L as D,l as R,K as m,m as H,a3 as U,D as X,X as Z,N as K,U as Q}from"./index-pfWzpkoo.js";import{b as P,e as W,c as V,a as Y}from"./api-D8mq3iDu.js";import{g as ee}from"./squad-colors-B8B_Y-lz.js";import{X as te}from"./x-BZnxunbq.js";import{G as se}from"./git-branch-kdrEZD1J.js";import{T as oe}from"./trash-2-CD0eo8ca.js";import{A as re}from"./arrow-left-Bi-aUQhG.js";/**
|
|
2
2
|
* @license lucide-vue-next v0.474.0 - ISC
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the ISC license.
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{b as L}from"./api-
|
|
1
|
+
import{b as L}from"./api-D8mq3iDu.js";import{r as I,u as T,E as B,J as o,q as n,n as t,t as u,T as l,A as M,s as g,k as _,d as f,L as y,K as v,m as N,z as k,a3 as P,R as a,o as x,p,c as b,N as V}from"./index-pfWzpkoo.js";import{T as w}from"./triangle-alert-DLU_pc1W.js";import{G as $}from"./git-branch-kdrEZD1J.js";/**
|
|
2
2
|
* @license lucide-vue-next v0.474.0 - ISC
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the ISC license.
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{b as y}from"./api-
|
|
1
|
+
import{b as y}from"./api-D8mq3iDu.js";import{g as v}from"./squad-colors-B8B_Y-lz.js";import{r as h,u as k,E as b,J as o,q as r,n as t,t as i,T as l,k as w,d as L,L as C,K as d,o as S,a3 as N,D as f,N as q,R as n,s as _,p as B}from"./index-pfWzpkoo.js";import{G as V}from"./git-branch-kdrEZD1J.js";/**
|
|
2
2
|
* @license lucide-vue-next v0.474.0 - ISC
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the ISC license.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{u as t,J as s,q as r,z as l,n as d}from"./index-
|
|
1
|
+
import{u as t,J as s,q as r,z as l,n as d}from"./index-pfWzpkoo.js";const u=["aria-label","aria-checked","disabled"],m=t({__name:"ToggleSwitch",props:{modelValue:{type:Boolean},ariaLabel:{default:"Toggle"},disabled:{type:Boolean,default:!1}},emits:["update:modelValue"],setup(e,{emit:o}){const a=e,i=o;function n(){a.disabled||i("update:modelValue",!a.modelValue)}return(c,b)=>(s(),r("button",{type:"button",role:"switch","aria-label":e.ariaLabel,"aria-checked":e.modelValue,disabled:e.disabled,class:l(["inline-flex h-6 w-10 shrink-0 items-center rounded-full border border-border p-0.5 transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 focus-visible:ring-offset-background disabled:cursor-not-allowed disabled:opacity-50",e.modelValue?"bg-gradient-brand shadow-[0_0_0_1px_rgba(228,58,156,0.35)]":"bg-muted"]),onClick:n},[d("span",{class:l(["pointer-events-none h-4 w-4 rounded-full bg-white shadow-sm ring-1 ring-black/10 transition-transform duration-200",e.modelValue?"translate-x-5":"translate-x-0"])},null,2)],10,u))}});export{m as _};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{r as L,u as j,E as Q,J as d,q as r,n as t,t as _,T as k,C as W,d as i,L as m,s as w,R as o,k as X,p as u,a4 as F,a0 as O,K as a,z as Y,D as Z,m as tt}from"./index-
|
|
1
|
+
import{r as L,u as j,E as Q,J as d,q as r,n as t,t as _,T as k,C as W,d as i,L as m,s as w,R as o,k as X,p as u,a4 as F,a0 as O,K as a,z as Y,D as Z,m as tt}from"./index-pfWzpkoo.js";import{b as T,d as q}from"./api-D8mq3iDu.js";import{T as et}from"./triangle-alert-DLU_pc1W.js";/**
|
|
2
2
|
* @license lucide-vue-next v0.474.0 - ISC
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the ISC license.
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{r as j,u as se,a2 as oe,J as o,q as a,d as b,L as K,m as A,n as t,o as I,T as d,a as ce,t as v,F as ve,R as N,D as pe,z,a6 as fe,p as B,K as c,E as me,B as H,s as S,a4 as V,a0 as L,a5 as R,l as Z}from"./index-
|
|
1
|
+
import{r as j,u as se,a2 as oe,J as o,q as a,d as b,L as K,m as A,n as t,o as I,T as d,a as ce,t as v,F as ve,R as N,D as pe,z,a6 as fe,p as B,K as c,E as me,B as H,s as S,a4 as V,a0 as L,a5 as R,l as Z}from"./index-pfWzpkoo.js";import{b as T,d as E,a as G}from"./api-D8mq3iDu.js";import{S as xe}from"./search-B4VYmepw.js";import{P as J}from"./plus-DQqaQERI.js";import{P as O,S as X}from"./save-C36BoECe.js";import{T as Y}from"./trash-2-CD0eo8ca.js";import{X as ee}from"./x-BZnxunbq.js";/**
|
|
2
2
|
* @license lucide-vue-next v0.474.0 - ISC
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the ISC license.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{V as i,O as c}from"./index-
|
|
1
|
+
import{V as i,O as c}from"./index-pfWzpkoo.js";const o="/api";function u(t){try{return JSON.parse(atob(t.split(".")[1])).exp*1e3<=Date.now()+6e4}catch{return!0}}async function n(){const t=i(),e={"Content-Type":"application/json"};return t.token&&u(t.token)&&await t.refreshToken(),t.token&&(e.Authorization=`Bearer ${t.token}`),e}async function s(t,e){if(t.status===401){const r=i();try{if(await r.refreshToken(),r.token){const a=await e();if(a.status===401)throw r.logout(),c.push("/login"),new Error("Session expired");return a}}catch{}throw r.logout(),c.push("/login"),new Error("Session expired")}return t}async function w(t){const e=await s(await fetch(`${o}${t}`,{headers:await n()}),async()=>fetch(`${o}${t}`,{headers:await n()}));if(!e.ok)throw new Error(`API error: ${e.status}`);return e.json()}async function f(t,e){const r={method:"POST",headers:await n(),body:e?JSON.stringify(e):void 0},a=await s(await fetch(`${o}${t}`,r),async()=>fetch(`${o}${t}`,{...r,headers:await n()}));if(!a.ok)throw new Error(`API error: ${a.status}`);return a.json()}async function $(t,e){const r={method:"PUT",headers:await n(),body:e?JSON.stringify(e):void 0},a=await s(await fetch(`${o}${t}`,r),async()=>fetch(`${o}${t}`,{...r,headers:await n()}));if(!a.ok)throw new Error(`API error: ${a.status}`);return a.json()}async function d(t){const e={method:"DELETE",headers:await n()},r=await s(await fetch(`${o}${t}`,e),async()=>fetch(`${o}${t}`,{...e,headers:await n()}));if(!r.ok)throw new Error(`API error: ${r.status}`);return r.json()}function p(){const t=i(),e=`${o}/stream?token=${t.token??""}`;return new EventSource(e)}export{d as a,w as b,f as c,$ as d,p as e};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/ChatView-
|
|
1
|
+
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/ChatView-XDhymbA2.js","assets/x-BZnxunbq.js","assets/SquadsView-D3M4NaIk.js","assets/api-D8mq3iDu.js","assets/squad-colors-B8B_Y-lz.js","assets/git-branch-kdrEZD1J.js","assets/SquadHealthView-BZgXZQlH.js","assets/triangle-alert-DLU_pc1W.js","assets/SquadDetailView-Dsl4g_hV.js","assets/trash-2-CD0eo8ca.js","assets/arrow-left-Bi-aUQhG.js","assets/FeedView-Ca68D167.js","assets/SkillsView-FN5SNvrs.js","assets/plus-DQqaQERI.js","assets/search-B4VYmepw.js","assets/save-C36BoECe.js","assets/McpView-Cofqgako.js","assets/ToggleSwitch.vue_vue_type_script_setup_true_lang-7Pt64qdk.js","assets/SchedulesView-DWaBgdyB.js","assets/HistoryView-BwHwKFic.js","assets/WikiView-jWG97hfd.js","assets/UsageView-vvvGgNkr.js","assets/AuditLogView-B1fqx1A6.js","assets/SettingsView-D3Ec_g9G.js"])))=>i.map(i=>d[i]);
|
|
2
2
|
var hh=Object.defineProperty;var dh=(t,e,r)=>e in t?hh(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r;var be=(t,e,r)=>dh(t,typeof e!="symbol"?e+"":e,r);(function(){const e=document.createElement("link").relList;if(e&&e.supports&&e.supports("modulepreload"))return;for(const s of document.querySelectorAll('link[rel="modulepreload"]'))n(s);new MutationObserver(s=>{for(const i of s)if(i.type==="childList")for(const o of i.addedNodes)o.tagName==="LINK"&&o.rel==="modulepreload"&&n(o)}).observe(document,{childList:!0,subtree:!0});function r(s){const i={};return s.integrity&&(i.integrity=s.integrity),s.referrerPolicy&&(i.referrerPolicy=s.referrerPolicy),s.crossOrigin==="use-credentials"?i.credentials="include":s.crossOrigin==="anonymous"?i.credentials="omit":i.credentials="same-origin",i}function n(s){if(s.ep)return;s.ep=!0;const i=r(s);fetch(s.href,i)}})();const fh="modulepreload",ph=function(t){return"/"+t},Jo={},Ke=function(e,r,n){let s=Promise.resolve();if(r&&r.length>0){let o=function(c){return Promise.all(c.map(u=>Promise.resolve(u).then(h=>({status:"fulfilled",value:h}),h=>({status:"rejected",reason:h}))))};document.getElementsByTagName("link");const a=document.querySelector("meta[property=csp-nonce]"),l=(a==null?void 0:a.nonce)||(a==null?void 0:a.getAttribute("nonce"));s=o(r.map(c=>{if(c=ph(c),c in Jo)return;Jo[c]=!0;const u=c.endsWith(".css"),h=u?'[rel="stylesheet"]':"";if(document.querySelector(`link[href="${c}"]${h}`))return;const d=document.createElement("link");if(d.rel=u?"stylesheet":fh,u||(d.as="script"),d.crossOrigin="",d.href=c,l&&d.setAttribute("nonce",l),document.head.appendChild(d),u)return new Promise((f,p)=>{d.addEventListener("load",f),d.addEventListener("error",()=>p(new Error(`Unable to preload CSS for ${c}`)))})}))}function i(o){const a=new Event("vite:preloadError",{cancelable:!0});if(a.payload=o,window.dispatchEvent(a),!a.defaultPrevented)throw o}return s.then(o=>{for(const a of o||[])a.status==="rejected"&&i(a.reason);return e().catch(i)})};/**
|
|
3
3
|
* @vue/shared v3.5.34
|
|
4
4
|
* (c) 2018-present Yuxi (Evan) You and Vue contributors
|
|
@@ -167,7 +167,7 @@ var hh=Object.defineProperty;var dh=(t,e,r)=>e in t?hh(t,e,{enumerable:!0,config
|
|
|
167
167
|
*
|
|
168
168
|
* This source code is licensed under the ISC license.
|
|
169
169
|
* See the LICENSE file in the root directory of this source tree.
|
|
170
|
-
*/const Og=Ae("UsersIcon",[["path",{d:"M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2",key:"1yyitq"}],["circle",{cx:"9",cy:"7",r:"4",key:"nufk8"}],["path",{d:"M22 21v-2a4 4 0 0 0-3-3.87",key:"kshegd"}],["path",{d:"M16 3.13a4 4 0 0 1 0 7.75",key:"1da9ce"}]]),Pg={key:0,class:"font-display text-[1.1rem] font-normal uppercase tracking-[0.18em] bg-gradient-brand bg-clip-text text-transparent"},Ig=["title"],$g={class:"flex-1 p-2 space-y-0.5 overflow-y-auto"},jg={key:0},Ng={class:"border-t border-border p-2 space-y-0.5"},Lg={key:0},Dg=["href"],sl="https://github.com/michaeljolley/io",Ug=pr({__name:"AppSidebar",setup(t){const e=jo(),r=Oe(!1),n=[{name:"History",icon:vg,path:"/history"},{name:"Squads",icon:Og,path:"/squads"},{name:"Health",icon:hg,path:"/squads/health"},{name:"Usage",icon:fg,path:"/usage"},{name:"Audit Log",icon:gg,path:"/audit-log"},{name:"Skills",icon:Eg,path:"/skills"},{name:"MCP Servers",icon:Ag,path:"/mcp"},{name:"Schedules",icon:mg,path:"/schedules"},{name:"Wiki",icon:dg,path:"/wiki"}],s=[{name:"Chat",icon:xu,path:"/"},{name:"Feed",icon:Au,path:"/feed"},{name:"Settings",icon:xg,path:"/settings"}],i="1.10.4",o=$e(()=>{let l="";const c=[...n,...s];for(const u of c){const h=u.path;(h==="/"?e.path==="/":e.path===h||e.path.startsWith(h+"/"))&&h.length>l.length&&(l=h)}return l});function a(){r.value=!r.value}return(l,c)=>{const u=Zs("router-link");return Z(),ue("aside",{class:Ye(["border-r border-border bg-sidebar flex flex-col h-full shrink-0 transition-all duration-200",r.value?"w-16":"w-56"])},[ne("div",{class:Ye(["p-3 border-b border-border flex items-center",r.value?"justify-center":"justify-between"])},[he(u,{to:"/",class:Ye(["flex items-center gap-2",r.value?"justify-center":""])},{default:Yr(()=>[he(Zi,{size:24}),r.value?De("",!0):(Z(),ue("h1",Pg,"IO"))]),_:1},8,["class"]),r.value?De("",!0):(Z(),ue("button",{key:0,onClick:a,class:"p-1 rounded-full hover:bg-accent/70 text-muted-foreground hover:text-foreground transition-colors",title:r.value?"Expand sidebar":"Collapse sidebar"},[he(re(wg),{class:"w-4 h-4"})],8,Ig))],2),r.value?(Z(),ue("button",{key:0,onClick:a,class:"mx-auto mt-2 p-1.5 rounded-full hover:bg-accent/70 text-muted-foreground hover:text-foreground transition-colors",title:"Expand sidebar"},[he(re(kg),{class:"w-4 h-4"})])):De("",!0),ne("nav",$g,[(Z(),ue(Fe,null,zr(n,h=>he(u,{key:h.path,to:h.path,class:Ye(["flex items-center gap-3 rounded-full text-sm transition-colors border border-transparent",[r.value?"justify-center px-2 py-2":"px-3 py-2",o.value===h.path?"bg-accent text-accent-foreground font-medium border border-white/10":"text-muted-foreground hover:bg-white/5 hover:text-foreground"]]),title:r.value?h.name:void 0},{default:Yr(()=>[(Z(),nt(sa(h.icon),{class:"w-4 h-4 shrink-0"})),r.value?De("",!0):(Z(),ue("span",jg,it(h.name),1))]),_:2},1032,["to","class","title"])),64))]),ne("div",Ng,[(Z(),ue(Fe,null,zr(s,h=>he(u,{key:h.path,to:h.path,class:Ye(["flex items-center gap-3 rounded-full text-sm transition-colors border border-transparent",[r.value?"justify-center px-2 py-2":"px-3 py-2",o.value===h.path?"bg-accent text-accent-foreground font-medium border border-white/10":"text-muted-foreground hover:bg-white/5 hover:text-foreground"]]),title:r.value?h.name:void 0},{default:Yr(()=>[(Z(),nt(sa(h.icon),{class:"w-4 h-4 shrink-0"})),r.value?De("",!0):(Z(),ue("span",Lg,it(h.name),1))]),_:2},1032,["to","class","title"])),64)),ne("div",{class:Ye(["flex items-center pt-2 mt-2 border-t border-border",r.value?"justify-center":"justify-between px-3"])},[r.value?De("",!0):(Z(),ue("a",{key:0,href:`${sl}/releases/tag/v${re(i)}`,target:"_blank",class:"text-[10px] text-muted-foreground hover:text-foreground transition-colors",title:"Release notes"}," v"+it(re(i)),9,Dg)),ne("a",{href:sl,target:"_blank",class:"p-1 rounded-full hover:bg-accent/70 text-muted-foreground hover:text-foreground transition-colors",title:"GitHub repository"},[he(re(yg),{class:"w-3.5 h-3.5"})])],2)])],2)}}});function ii(t,e){var r={};for(var n in t)Object.prototype.hasOwnProperty.call(t,n)&&e.indexOf(n)<0&&(r[n]=t[n]);if(t!=null&&typeof Object.getOwnPropertySymbols=="function")for(var s=0,n=Object.getOwnPropertySymbols(t);s<n.length;s++)e.indexOf(n[s])<0&&Object.prototype.propertyIsEnumerable.call(t,n[s])&&(r[n[s]]=t[n[s]]);return r}function Bg(t,e,r,n){function s(i){return i instanceof r?i:new r(function(o){o(i)})}return new(r||(r=Promise))(function(i,o){function a(u){try{c(n.next(u))}catch(h){o(h)}}function l(u){try{c(n.throw(u))}catch(h){o(h)}}function c(u){u.done?i(u.value):s(u.value).then(a,l)}c((n=n.apply(t,e||[])).next())})}const Mg=t=>t?(...e)=>t(...e):(...e)=>fetch(...e);class No extends Error{constructor(e,r="FunctionsError",n){super(e),this.name=r,this.context=n}toJSON(){return{name:this.name,message:this.message,context:this.context}}}class Hg extends No{constructor(e){super("Failed to send a request to the Edge Function","FunctionsFetchError",e)}}class il extends No{constructor(e){super("Relay Error invoking the Edge Function","FunctionsRelayError",e)}}class ol extends No{constructor(e){super("Edge Function returned a non-2xx status code","FunctionsHttpError",e)}}var Qi;(function(t){t.Any="any",t.ApNortheast1="ap-northeast-1",t.ApNortheast2="ap-northeast-2",t.ApSouth1="ap-south-1",t.ApSoutheast1="ap-southeast-1",t.ApSoutheast2="ap-southeast-2",t.CaCentral1="ca-central-1",t.EuCentral1="eu-central-1",t.EuWest1="eu-west-1",t.EuWest2="eu-west-2",t.EuWest3="eu-west-3",t.SaEast1="sa-east-1",t.UsEast1="us-east-1",t.UsWest1="us-west-1",t.UsWest2="us-west-2"})(Qi||(Qi={}));class qg{constructor(e,{headers:r={},customFetch:n,region:s=Qi.Any}={}){this.url=e,this.headers=r,this.region=s,this.fetch=Mg(n)}setAuth(e){this.headers.Authorization=`Bearer ${e}`}invoke(e){return Bg(this,arguments,void 0,function*(r,n={}){var s;let i,o;try{const{headers:a,method:l,body:c,signal:u,timeout:h}=n;let d={},{region:f}=n;f||(f=this.region);const p=new URL(`${this.url}/${r}`);f&&f!=="any"&&(d["x-region"]=f,p.searchParams.set("forceFunctionRegion",f));let y;c&&(a&&!Object.prototype.hasOwnProperty.call(a,"Content-Type")||!a)?typeof Blob<"u"&&c instanceof Blob||c instanceof ArrayBuffer?(d["Content-Type"]="application/octet-stream",y=c):typeof c=="string"?(d["Content-Type"]="text/plain",y=c):typeof FormData<"u"&&c instanceof FormData?y=c:(d["Content-Type"]="application/json",y=JSON.stringify(c)):c&&typeof c!="string"&&!(typeof Blob<"u"&&c instanceof Blob)&&!(c instanceof ArrayBuffer)&&!(typeof FormData<"u"&&c instanceof FormData)?y=JSON.stringify(c):y=c;let w=u;h&&(o=new AbortController,i=setTimeout(()=>o.abort(),h),u?(w=o.signal,u.addEventListener("abort",()=>o.abort())):w=o.signal);const k=yield this.fetch(p.toString(),{method:l||"POST",headers:Object.assign(Object.assign(Object.assign({},d),this.headers),a),body:y,signal:w}).catch(D=>{throw new Hg(D)}),_=k.headers.get("x-relay-error");if(_&&_==="true")throw new il(k);if(!k.ok)throw new ol(k);let b=((s=k.headers.get("Content-Type"))!==null&&s!==void 0?s:"text/plain").split(";")[0].trim(),x;return b==="application/json"?x=yield k.json():b==="application/octet-stream"||b==="application/pdf"?x=yield k.blob():b==="text/event-stream"?x=k:b==="multipart/form-data"?x=yield k.formData():x=yield k.text(),{data:x,error:null,response:k}}catch(a){return{data:null,error:a,response:a instanceof ol||a instanceof il?a.context:void 0}}finally{i&&clearTimeout(i)}})}}const Ru=3,al=t=>Math.min(1e3*2**t,3e4),Fg=[520,503],Cu=["GET","HEAD","OPTIONS"];var Vg=class extends Error{constructor(t){super(t.message),this.name="PostgrestError",this.details=t.details,this.hint=t.hint,this.code=t.code}toJSON(){return{name:this.name,message:this.message,details:this.details,hint:this.hint,code:this.code}}};function ll(t,e){return new Promise(r=>{if(e!=null&&e.aborted){r();return}const n=setTimeout(()=>{e==null||e.removeEventListener("abort",s),r()},t);function s(){clearTimeout(n),r()}e==null||e.addEventListener("abort",s)})}function zg(t,e,r,n){return!(!n||r>=Ru||!Cu.includes(t)||!Fg.includes(e))}var Wg=class{constructor(t){var e,r,n,s,i;this.shouldThrowOnError=!1,this.retryEnabled=!0,this.method=t.method,this.url=t.url,this.headers=new Headers(t.headers),this.schema=t.schema,this.body=t.body,this.shouldThrowOnError=(e=t.shouldThrowOnError)!==null&&e!==void 0?e:!1,this.signal=t.signal,this.isMaybeSingle=(r=t.isMaybeSingle)!==null&&r!==void 0?r:!1,this.shouldStripNulls=(n=t.shouldStripNulls)!==null&&n!==void 0?n:!1,this.urlLengthLimit=(s=t.urlLengthLimit)!==null&&s!==void 0?s:8e3,this.retryEnabled=(i=t.retry)!==null&&i!==void 0?i:!0,t.fetch?this.fetch=t.fetch:this.fetch=fetch}throwOnError(){return this.shouldThrowOnError=!0,this}stripNulls(){if(this.headers.get("Accept")==="text/csv")throw new Error("stripNulls() cannot be used with csv()");return this.shouldStripNulls=!0,this}setHeader(t,e){return this.headers=new Headers(this.headers),this.headers.set(t,e),this}retry(t){return this.retryEnabled=t,this}then(t,e){var r=this;if(this.schema===void 0||(["GET","HEAD"].includes(this.method)?this.headers.set("Accept-Profile",this.schema):this.headers.set("Content-Profile",this.schema)),this.method!=="GET"&&this.method!=="HEAD"&&this.headers.set("Content-Type","application/json"),this.shouldStripNulls){const o=this.headers.get("Accept");o==="application/vnd.pgrst.object+json"?this.headers.set("Accept","application/vnd.pgrst.object+json;nulls=stripped"):(!o||o==="application/json")&&this.headers.set("Accept","application/vnd.pgrst.array+json;nulls=stripped")}const n=this.fetch;let i=(async()=>{let o=0;for(;;){const c=new Headers(r.headers);o>0&&c.set("X-Retry-Count",String(o));let u;try{u=await n(r.url.toString(),{method:r.method,headers:c,body:JSON.stringify(r.body,(h,d)=>typeof d=="bigint"?d.toString():d),signal:r.signal})}catch(h){if((h==null?void 0:h.name)==="AbortError"||(h==null?void 0:h.code)==="ABORT_ERR"||!Cu.includes(r.method))throw h;if(r.retryEnabled&&o<Ru){const d=al(o);o++,await ll(d,r.signal);continue}throw h}if(zg(r.method,u.status,o,r.retryEnabled)){var a,l;const h=(a=(l=u.headers)===null||l===void 0?void 0:l.get("Retry-After"))!==null&&a!==void 0?a:null,d=h!==null?Math.max(0,parseInt(h,10)||0)*1e3:al(o);await u.text(),o++,await ll(d,r.signal);continue}return await r.processResponse(u)}})();return this.shouldThrowOnError||(i=i.catch(o=>{var a;let l="",c="",u="";const h=o==null?void 0:o.cause;if(h){var d,f,p,y;const _=(d=h==null?void 0:h.message)!==null&&d!==void 0?d:"",b=(f=h==null?void 0:h.code)!==null&&f!==void 0?f:"";l=`${(p=o==null?void 0:o.name)!==null&&p!==void 0?p:"FetchError"}: ${o==null?void 0:o.message}`,l+=`
|
|
170
|
+
*/const Og=Ae("UsersIcon",[["path",{d:"M16 21v-2a4 4 0 0 0-4-4H6a4 4 0 0 0-4 4v2",key:"1yyitq"}],["circle",{cx:"9",cy:"7",r:"4",key:"nufk8"}],["path",{d:"M22 21v-2a4 4 0 0 0-3-3.87",key:"kshegd"}],["path",{d:"M16 3.13a4 4 0 0 1 0 7.75",key:"1da9ce"}]]),Pg={key:0,class:"font-display text-[1.1rem] font-normal uppercase tracking-[0.18em] bg-gradient-brand bg-clip-text text-transparent"},Ig=["title"],$g={class:"flex-1 p-2 space-y-0.5 overflow-y-auto"},jg={key:0},Ng={class:"border-t border-border p-2 space-y-0.5"},Lg={key:0},Dg=["href"],sl="https://github.com/michaeljolley/io",Ug=pr({__name:"AppSidebar",setup(t){const e=jo(),r=Oe(!1),n=[{name:"History",icon:vg,path:"/history"},{name:"Squads",icon:Og,path:"/squads"},{name:"Health",icon:hg,path:"/squads/health"},{name:"Usage",icon:fg,path:"/usage"},{name:"Audit Log",icon:gg,path:"/audit-log"},{name:"Skills",icon:Eg,path:"/skills"},{name:"MCP Servers",icon:Ag,path:"/mcp"},{name:"Schedules",icon:mg,path:"/schedules"},{name:"Wiki",icon:dg,path:"/wiki"}],s=[{name:"Chat",icon:xu,path:"/"},{name:"Feed",icon:Au,path:"/feed"},{name:"Settings",icon:xg,path:"/settings"}],i="1.10.6",o=$e(()=>{let l="";const c=[...n,...s];for(const u of c){const h=u.path;(h==="/"?e.path==="/":e.path===h||e.path.startsWith(h+"/"))&&h.length>l.length&&(l=h)}return l});function a(){r.value=!r.value}return(l,c)=>{const u=Zs("router-link");return Z(),ue("aside",{class:Ye(["border-r border-border bg-sidebar flex flex-col h-full shrink-0 transition-all duration-200",r.value?"w-16":"w-56"])},[ne("div",{class:Ye(["p-3 border-b border-border flex items-center",r.value?"justify-center":"justify-between"])},[he(u,{to:"/",class:Ye(["flex items-center gap-2",r.value?"justify-center":""])},{default:Yr(()=>[he(Zi,{size:24}),r.value?De("",!0):(Z(),ue("h1",Pg,"IO"))]),_:1},8,["class"]),r.value?De("",!0):(Z(),ue("button",{key:0,onClick:a,class:"p-1 rounded-full hover:bg-accent/70 text-muted-foreground hover:text-foreground transition-colors",title:r.value?"Expand sidebar":"Collapse sidebar"},[he(re(wg),{class:"w-4 h-4"})],8,Ig))],2),r.value?(Z(),ue("button",{key:0,onClick:a,class:"mx-auto mt-2 p-1.5 rounded-full hover:bg-accent/70 text-muted-foreground hover:text-foreground transition-colors",title:"Expand sidebar"},[he(re(kg),{class:"w-4 h-4"})])):De("",!0),ne("nav",$g,[(Z(),ue(Fe,null,zr(n,h=>he(u,{key:h.path,to:h.path,class:Ye(["flex items-center gap-3 rounded-full text-sm transition-colors border border-transparent",[r.value?"justify-center px-2 py-2":"px-3 py-2",o.value===h.path?"bg-accent text-accent-foreground font-medium border border-white/10":"text-muted-foreground hover:bg-white/5 hover:text-foreground"]]),title:r.value?h.name:void 0},{default:Yr(()=>[(Z(),nt(sa(h.icon),{class:"w-4 h-4 shrink-0"})),r.value?De("",!0):(Z(),ue("span",jg,it(h.name),1))]),_:2},1032,["to","class","title"])),64))]),ne("div",Ng,[(Z(),ue(Fe,null,zr(s,h=>he(u,{key:h.path,to:h.path,class:Ye(["flex items-center gap-3 rounded-full text-sm transition-colors border border-transparent",[r.value?"justify-center px-2 py-2":"px-3 py-2",o.value===h.path?"bg-accent text-accent-foreground font-medium border border-white/10":"text-muted-foreground hover:bg-white/5 hover:text-foreground"]]),title:r.value?h.name:void 0},{default:Yr(()=>[(Z(),nt(sa(h.icon),{class:"w-4 h-4 shrink-0"})),r.value?De("",!0):(Z(),ue("span",Lg,it(h.name),1))]),_:2},1032,["to","class","title"])),64)),ne("div",{class:Ye(["flex items-center pt-2 mt-2 border-t border-border",r.value?"justify-center":"justify-between px-3"])},[r.value?De("",!0):(Z(),ue("a",{key:0,href:`${sl}/releases/tag/v${re(i)}`,target:"_blank",class:"text-[10px] text-muted-foreground hover:text-foreground transition-colors",title:"Release notes"}," v"+it(re(i)),9,Dg)),ne("a",{href:sl,target:"_blank",class:"p-1 rounded-full hover:bg-accent/70 text-muted-foreground hover:text-foreground transition-colors",title:"GitHub repository"},[he(re(yg),{class:"w-3.5 h-3.5"})])],2)])],2)}}});function ii(t,e){var r={};for(var n in t)Object.prototype.hasOwnProperty.call(t,n)&&e.indexOf(n)<0&&(r[n]=t[n]);if(t!=null&&typeof Object.getOwnPropertySymbols=="function")for(var s=0,n=Object.getOwnPropertySymbols(t);s<n.length;s++)e.indexOf(n[s])<0&&Object.prototype.propertyIsEnumerable.call(t,n[s])&&(r[n[s]]=t[n[s]]);return r}function Bg(t,e,r,n){function s(i){return i instanceof r?i:new r(function(o){o(i)})}return new(r||(r=Promise))(function(i,o){function a(u){try{c(n.next(u))}catch(h){o(h)}}function l(u){try{c(n.throw(u))}catch(h){o(h)}}function c(u){u.done?i(u.value):s(u.value).then(a,l)}c((n=n.apply(t,e||[])).next())})}const Mg=t=>t?(...e)=>t(...e):(...e)=>fetch(...e);class No extends Error{constructor(e,r="FunctionsError",n){super(e),this.name=r,this.context=n}toJSON(){return{name:this.name,message:this.message,context:this.context}}}class Hg extends No{constructor(e){super("Failed to send a request to the Edge Function","FunctionsFetchError",e)}}class il extends No{constructor(e){super("Relay Error invoking the Edge Function","FunctionsRelayError",e)}}class ol extends No{constructor(e){super("Edge Function returned a non-2xx status code","FunctionsHttpError",e)}}var Qi;(function(t){t.Any="any",t.ApNortheast1="ap-northeast-1",t.ApNortheast2="ap-northeast-2",t.ApSouth1="ap-south-1",t.ApSoutheast1="ap-southeast-1",t.ApSoutheast2="ap-southeast-2",t.CaCentral1="ca-central-1",t.EuCentral1="eu-central-1",t.EuWest1="eu-west-1",t.EuWest2="eu-west-2",t.EuWest3="eu-west-3",t.SaEast1="sa-east-1",t.UsEast1="us-east-1",t.UsWest1="us-west-1",t.UsWest2="us-west-2"})(Qi||(Qi={}));class qg{constructor(e,{headers:r={},customFetch:n,region:s=Qi.Any}={}){this.url=e,this.headers=r,this.region=s,this.fetch=Mg(n)}setAuth(e){this.headers.Authorization=`Bearer ${e}`}invoke(e){return Bg(this,arguments,void 0,function*(r,n={}){var s;let i,o;try{const{headers:a,method:l,body:c,signal:u,timeout:h}=n;let d={},{region:f}=n;f||(f=this.region);const p=new URL(`${this.url}/${r}`);f&&f!=="any"&&(d["x-region"]=f,p.searchParams.set("forceFunctionRegion",f));let y;c&&(a&&!Object.prototype.hasOwnProperty.call(a,"Content-Type")||!a)?typeof Blob<"u"&&c instanceof Blob||c instanceof ArrayBuffer?(d["Content-Type"]="application/octet-stream",y=c):typeof c=="string"?(d["Content-Type"]="text/plain",y=c):typeof FormData<"u"&&c instanceof FormData?y=c:(d["Content-Type"]="application/json",y=JSON.stringify(c)):c&&typeof c!="string"&&!(typeof Blob<"u"&&c instanceof Blob)&&!(c instanceof ArrayBuffer)&&!(typeof FormData<"u"&&c instanceof FormData)?y=JSON.stringify(c):y=c;let w=u;h&&(o=new AbortController,i=setTimeout(()=>o.abort(),h),u?(w=o.signal,u.addEventListener("abort",()=>o.abort())):w=o.signal);const k=yield this.fetch(p.toString(),{method:l||"POST",headers:Object.assign(Object.assign(Object.assign({},d),this.headers),a),body:y,signal:w}).catch(D=>{throw new Hg(D)}),_=k.headers.get("x-relay-error");if(_&&_==="true")throw new il(k);if(!k.ok)throw new ol(k);let b=((s=k.headers.get("Content-Type"))!==null&&s!==void 0?s:"text/plain").split(";")[0].trim(),x;return b==="application/json"?x=yield k.json():b==="application/octet-stream"||b==="application/pdf"?x=yield k.blob():b==="text/event-stream"?x=k:b==="multipart/form-data"?x=yield k.formData():x=yield k.text(),{data:x,error:null,response:k}}catch(a){return{data:null,error:a,response:a instanceof ol||a instanceof il?a.context:void 0}}finally{i&&clearTimeout(i)}})}}const Ru=3,al=t=>Math.min(1e3*2**t,3e4),Fg=[520,503],Cu=["GET","HEAD","OPTIONS"];var Vg=class extends Error{constructor(t){super(t.message),this.name="PostgrestError",this.details=t.details,this.hint=t.hint,this.code=t.code}toJSON(){return{name:this.name,message:this.message,details:this.details,hint:this.hint,code:this.code}}};function ll(t,e){return new Promise(r=>{if(e!=null&&e.aborted){r();return}const n=setTimeout(()=>{e==null||e.removeEventListener("abort",s),r()},t);function s(){clearTimeout(n),r()}e==null||e.addEventListener("abort",s)})}function zg(t,e,r,n){return!(!n||r>=Ru||!Cu.includes(t)||!Fg.includes(e))}var Wg=class{constructor(t){var e,r,n,s,i;this.shouldThrowOnError=!1,this.retryEnabled=!0,this.method=t.method,this.url=t.url,this.headers=new Headers(t.headers),this.schema=t.schema,this.body=t.body,this.shouldThrowOnError=(e=t.shouldThrowOnError)!==null&&e!==void 0?e:!1,this.signal=t.signal,this.isMaybeSingle=(r=t.isMaybeSingle)!==null&&r!==void 0?r:!1,this.shouldStripNulls=(n=t.shouldStripNulls)!==null&&n!==void 0?n:!1,this.urlLengthLimit=(s=t.urlLengthLimit)!==null&&s!==void 0?s:8e3,this.retryEnabled=(i=t.retry)!==null&&i!==void 0?i:!0,t.fetch?this.fetch=t.fetch:this.fetch=fetch}throwOnError(){return this.shouldThrowOnError=!0,this}stripNulls(){if(this.headers.get("Accept")==="text/csv")throw new Error("stripNulls() cannot be used with csv()");return this.shouldStripNulls=!0,this}setHeader(t,e){return this.headers=new Headers(this.headers),this.headers.set(t,e),this}retry(t){return this.retryEnabled=t,this}then(t,e){var r=this;if(this.schema===void 0||(["GET","HEAD"].includes(this.method)?this.headers.set("Accept-Profile",this.schema):this.headers.set("Content-Profile",this.schema)),this.method!=="GET"&&this.method!=="HEAD"&&this.headers.set("Content-Type","application/json"),this.shouldStripNulls){const o=this.headers.get("Accept");o==="application/vnd.pgrst.object+json"?this.headers.set("Accept","application/vnd.pgrst.object+json;nulls=stripped"):(!o||o==="application/json")&&this.headers.set("Accept","application/vnd.pgrst.array+json;nulls=stripped")}const n=this.fetch;let i=(async()=>{let o=0;for(;;){const c=new Headers(r.headers);o>0&&c.set("X-Retry-Count",String(o));let u;try{u=await n(r.url.toString(),{method:r.method,headers:c,body:JSON.stringify(r.body,(h,d)=>typeof d=="bigint"?d.toString():d),signal:r.signal})}catch(h){if((h==null?void 0:h.name)==="AbortError"||(h==null?void 0:h.code)==="ABORT_ERR"||!Cu.includes(r.method))throw h;if(r.retryEnabled&&o<Ru){const d=al(o);o++,await ll(d,r.signal);continue}throw h}if(zg(r.method,u.status,o,r.retryEnabled)){var a,l;const h=(a=(l=u.headers)===null||l===void 0?void 0:l.get("Retry-After"))!==null&&a!==void 0?a:null,d=h!==null?Math.max(0,parseInt(h,10)||0)*1e3:al(o);await u.text(),o++,await ll(d,r.signal);continue}return await r.processResponse(u)}})();return this.shouldThrowOnError||(i=i.catch(o=>{var a;let l="",c="",u="";const h=o==null?void 0:o.cause;if(h){var d,f,p,y;const _=(d=h==null?void 0:h.message)!==null&&d!==void 0?d:"",b=(f=h==null?void 0:h.code)!==null&&f!==void 0?f:"";l=`${(p=o==null?void 0:o.name)!==null&&p!==void 0?p:"FetchError"}: ${o==null?void 0:o.message}`,l+=`
|
|
171
171
|
|
|
172
172
|
Caused by: ${(y=h==null?void 0:h.name)!==null&&y!==void 0?y:"Error"}: ${_}`,b&&(l+=` (${b})`),h!=null&&h.stack&&(l+=`
|
|
173
173
|
${h.stack}`)}else{var w;l=(w=o==null?void 0:o.stack)!==null&&w!==void 0?w:""}const k=this.url.toString().length;return(o==null?void 0:o.name)==="AbortError"||(o==null?void 0:o.code)==="ABORT_ERR"?(u="",c="Request was aborted (timeout or manual cancellation)",k>this.urlLengthLimit&&(c+=`. Note: Your request URL is ${k} characters, which may exceed server limits. If selecting many fields, consider using views. If filtering with large arrays (e.g., .in('id', [many IDs])), consider using an RPC function to pass values server-side.`)):((h==null?void 0:h.name)==="HeadersOverflowError"||(h==null?void 0:h.code)==="UND_ERR_HEADERS_OVERFLOW")&&(u="",c="HTTP headers exceeded server limits (typically 16KB)",k>this.urlLengthLimit&&(c+=`. Your request URL is ${k} characters. If selecting many fields, consider using views. If filtering with large arrays (e.g., .in('id', [200+ IDs])), consider using an RPC function instead.`)),{success:!1,error:{message:`${(a=o==null?void 0:o.name)!==null&&a!==void 0?a:"FetchError"}: ${o==null?void 0:o.message}`,details:l,hint:c,code:u},data:null,count:null,status:0,statusText:""}})),i.then(t,e)}async processResponse(t){var e=this;let r=null,n=null,s=null,i=t.status,o=t.statusText;if(t.ok){var a,l;if(e.method!=="HEAD"){var c;const d=await t.text();d===""||(e.headers.get("Accept")==="text/csv"||e.headers.get("Accept")&&(!((c=e.headers.get("Accept"))===null||c===void 0)&&c.includes("application/vnd.pgrst.plan+text"))?n=d:n=JSON.parse(d))}const u=(a=e.headers.get("Prefer"))===null||a===void 0?void 0:a.match(/count=(exact|planned|estimated)/),h=(l=t.headers.get("content-range"))===null||l===void 0?void 0:l.split("/");u&&h&&h.length>1&&(s=parseInt(h[1])),e.isMaybeSingle&&Array.isArray(n)&&(n.length>1?(r={code:"PGRST116",details:`Results contain ${n.length} rows, application/vnd.pgrst.object+json requires 1 row`,hint:null,message:"JSON object requested, multiple (or no) rows returned"},n=null,s=null,i=406,o="Not Acceptable"):n.length===1?n=n[0]:n=null)}else{const u=await t.text();try{r=JSON.parse(u),Array.isArray(r)&&t.status===404&&(n=[],r=null,i=200,o="OK")}catch{t.status===404&&u===""?(i=204,o="No Content"):r={message:u}}if(r&&e.shouldThrowOnError)throw new Vg(r)}return{success:r===null,error:r,data:n,count:s,status:i,statusText:o}}returns(){return this}overrideTypes(){return this}},Kg=class extends Wg{select(t){let e=!1;const r=(t??"*").split("").map(n=>/\s/.test(n)&&!e?"":(n==='"'&&(e=!e),n)).join("");return this.url.searchParams.set("select",r),this.headers.append("Prefer","return=representation"),this}order(t,{ascending:e=!0,nullsFirst:r,foreignTable:n,referencedTable:s=n}={}){const i=s?`${s}.order`:"order",o=this.url.searchParams.get(i);return this.url.searchParams.set(i,`${o?`${o},`:""}${t}.${e?"asc":"desc"}${r===void 0?"":r?".nullsfirst":".nullslast"}`),this}limit(t,{foreignTable:e,referencedTable:r=e}={}){const n=typeof r>"u"?"limit":`${r}.limit`;return this.url.searchParams.set(n,`${t}`),this}range(t,e,{foreignTable:r,referencedTable:n=r}={}){const s=typeof n>"u"?"offset":`${n}.offset`,i=typeof n>"u"?"limit":`${n}.limit`;return this.url.searchParams.set(s,`${t}`),this.url.searchParams.set(i,`${e-t+1}`),this}abortSignal(t){return this.signal=t,this}single(){return this.headers.set("Accept","application/vnd.pgrst.object+json"),this}maybeSingle(){return this.isMaybeSingle=!0,this}csv(){return this.headers.set("Accept","text/csv"),this}geojson(){return this.headers.set("Accept","application/geo+json"),this}explain({analyze:t=!1,verbose:e=!1,settings:r=!1,buffers:n=!1,wal:s=!1,format:i="text"}={}){var o;const a=[t?"analyze":null,e?"verbose":null,r?"settings":null,n?"buffers":null,s?"wal":null].filter(Boolean).join("|"),l=(o=this.headers.get("Accept"))!==null&&o!==void 0?o:"application/json";return this.headers.set("Accept",`application/vnd.pgrst.plan+${i}; for="${l}"; options=${a};`),i==="json"?this:this}rollback(){return this.headers.append("Prefer","tx=rollback"),this}returns(){return this}maxAffected(t){return this.headers.append("Prefer","handling=strict"),this.headers.append("Prefer",`max-affected=${t}`),this}};const cl=new RegExp("[,()]");var Hr=class extends Kg{eq(t,e){return this.url.searchParams.append(t,`eq.${e}`),this}neq(t,e){return this.url.searchParams.append(t,`neq.${e}`),this}gt(t,e){return this.url.searchParams.append(t,`gt.${e}`),this}gte(t,e){return this.url.searchParams.append(t,`gte.${e}`),this}lt(t,e){return this.url.searchParams.append(t,`lt.${e}`),this}lte(t,e){return this.url.searchParams.append(t,`lte.${e}`),this}like(t,e){return this.url.searchParams.append(t,`like.${e}`),this}likeAllOf(t,e){return this.url.searchParams.append(t,`like(all).{${e.join(",")}}`),this}likeAnyOf(t,e){return this.url.searchParams.append(t,`like(any).{${e.join(",")}}`),this}ilike(t,e){return this.url.searchParams.append(t,`ilike.${e}`),this}ilikeAllOf(t,e){return this.url.searchParams.append(t,`ilike(all).{${e.join(",")}}`),this}ilikeAnyOf(t,e){return this.url.searchParams.append(t,`ilike(any).{${e.join(",")}}`),this}regexMatch(t,e){return this.url.searchParams.append(t,`match.${e}`),this}regexIMatch(t,e){return this.url.searchParams.append(t,`imatch.${e}`),this}is(t,e){return this.url.searchParams.append(t,`is.${e}`),this}isDistinct(t,e){return this.url.searchParams.append(t,`isdistinct.${e}`),this}in(t,e){const r=Array.from(new Set(e)).map(n=>typeof n=="string"&&cl.test(n)?`"${n}"`:`${n}`).join(",");return this.url.searchParams.append(t,`in.(${r})`),this}notIn(t,e){const r=Array.from(new Set(e)).map(n=>typeof n=="string"&&cl.test(n)?`"${n}"`:`${n}`).join(",");return this.url.searchParams.append(t,`not.in.(${r})`),this}contains(t,e){return typeof e=="string"?this.url.searchParams.append(t,`cs.${e}`):Array.isArray(e)?this.url.searchParams.append(t,`cs.{${e.join(",")}}`):this.url.searchParams.append(t,`cs.${JSON.stringify(e)}`),this}containedBy(t,e){return typeof e=="string"?this.url.searchParams.append(t,`cd.${e}`):Array.isArray(e)?this.url.searchParams.append(t,`cd.{${e.join(",")}}`):this.url.searchParams.append(t,`cd.${JSON.stringify(e)}`),this}rangeGt(t,e){return this.url.searchParams.append(t,`sr.${e}`),this}rangeGte(t,e){return this.url.searchParams.append(t,`nxl.${e}`),this}rangeLt(t,e){return this.url.searchParams.append(t,`sl.${e}`),this}rangeLte(t,e){return this.url.searchParams.append(t,`nxr.${e}`),this}rangeAdjacent(t,e){return this.url.searchParams.append(t,`adj.${e}`),this}overlaps(t,e){return typeof e=="string"?this.url.searchParams.append(t,`ov.${e}`):this.url.searchParams.append(t,`ov.{${e.join(",")}}`),this}textSearch(t,e,{config:r,type:n}={}){let s="";n==="plain"?s="pl":n==="phrase"?s="ph":n==="websearch"&&(s="w");const i=r===void 0?"":`(${r})`;return this.url.searchParams.append(t,`${s}fts${i}.${e}`),this}match(t){return Object.entries(t).filter(([e,r])=>r!==void 0).forEach(([e,r])=>{this.url.searchParams.append(e,`eq.${r}`)}),this}not(t,e,r){return this.url.searchParams.append(t,`not.${e}.${r}`),this}or(t,{foreignTable:e,referencedTable:r=e}={}){const n=r?`${r}.or`:"or";return this.url.searchParams.append(n,`(${t})`),this}filter(t,e,r){return this.url.searchParams.append(t,`${e}.${r}`),this}},Gg=class{constructor(t,{headers:e={},schema:r,fetch:n,urlLengthLimit:s=8e3,retry:i}){this.url=t,this.headers=new Headers(e),this.schema=r,this.fetch=n,this.urlLengthLimit=s,this.retry=i}cloneRequestState(){return{url:new URL(this.url.toString()),headers:new Headers(this.headers)}}select(t,e){const{head:r=!1,count:n}=e??{},s=r?"HEAD":"GET";let i=!1;const o=(t??"*").split("").map(c=>/\s/.test(c)&&!i?"":(c==='"'&&(i=!i),c)).join(""),{url:a,headers:l}=this.cloneRequestState();return a.searchParams.set("select",o),n&&l.append("Prefer",`count=${n}`),new Hr({method:s,url:a,headers:l,schema:this.schema,fetch:this.fetch,urlLengthLimit:this.urlLengthLimit,retry:this.retry})}insert(t,{count:e,defaultToNull:r=!0}={}){var n;const s="POST",{url:i,headers:o}=this.cloneRequestState();if(e&&o.append("Prefer",`count=${e}`),r||o.append("Prefer","missing=default"),Array.isArray(t)){const a=t.reduce((l,c)=>l.concat(Object.keys(c)),[]);if(a.length>0){const l=[...new Set(a)].map(c=>`"${c}"`);i.searchParams.set("columns",l.join(","))}}return new Hr({method:s,url:i,headers:o,schema:this.schema,body:t,fetch:(n=this.fetch)!==null&&n!==void 0?n:fetch,urlLengthLimit:this.urlLengthLimit,retry:this.retry})}upsert(t,{onConflict:e,ignoreDuplicates:r=!1,count:n,defaultToNull:s=!0}={}){var i;const o="POST",{url:a,headers:l}=this.cloneRequestState();if(l.append("Prefer",`resolution=${r?"ignore":"merge"}-duplicates`),e!==void 0&&a.searchParams.set("on_conflict",e),n&&l.append("Prefer",`count=${n}`),s||l.append("Prefer","missing=default"),Array.isArray(t)){const c=t.reduce((u,h)=>u.concat(Object.keys(h)),[]);if(c.length>0){const u=[...new Set(c)].map(h=>`"${h}"`);a.searchParams.set("columns",u.join(","))}}return new Hr({method:o,url:a,headers:l,schema:this.schema,body:t,fetch:(i=this.fetch)!==null&&i!==void 0?i:fetch,urlLengthLimit:this.urlLengthLimit,retry:this.retry})}update(t,{count:e}={}){var r;const n="PATCH",{url:s,headers:i}=this.cloneRequestState();return e&&i.append("Prefer",`count=${e}`),new Hr({method:n,url:s,headers:i,schema:this.schema,body:t,fetch:(r=this.fetch)!==null&&r!==void 0?r:fetch,urlLengthLimit:this.urlLengthLimit,retry:this.retry})}delete({count:t}={}){var e;const r="DELETE",{url:n,headers:s}=this.cloneRequestState();return t&&s.append("Prefer",`count=${t}`),new Hr({method:r,url:n,headers:s,schema:this.schema,fetch:(e=this.fetch)!==null&&e!==void 0?e:fetch,urlLengthLimit:this.urlLengthLimit,retry:this.retry})}};function Vn(t){"@babel/helpers - typeof";return Vn=typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?function(e){return typeof e}:function(e){return e&&typeof Symbol=="function"&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},Vn(t)}function Jg(t,e){if(Vn(t)!="object"||!t)return t;var r=t[Symbol.toPrimitive];if(r!==void 0){var n=r.call(t,e);if(Vn(n)!="object")return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return(e==="string"?String:Number)(t)}function Yg(t){var e=Jg(t,"string");return Vn(e)=="symbol"?e:e+""}function Xg(t,e,r){return(e=Yg(e))in t?Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[e]=r,t}function ul(t,e){var r=Object.keys(t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(t);e&&(n=n.filter(function(s){return Object.getOwnPropertyDescriptor(t,s).enumerable})),r.push.apply(r,n)}return r}function os(t){for(var e=1;e<arguments.length;e++){var r=arguments[e]!=null?arguments[e]:{};e%2?ul(Object(r),!0).forEach(function(n){Xg(t,n,r[n])}):Object.getOwnPropertyDescriptors?Object.defineProperties(t,Object.getOwnPropertyDescriptors(r)):ul(Object(r)).forEach(function(n){Object.defineProperty(t,n,Object.getOwnPropertyDescriptor(r,n))})}return t}var Zg=class Ou{constructor(e,{headers:r={},schema:n,fetch:s,timeout:i,urlLengthLimit:o=8e3,retry:a}={}){this.url=e,this.headers=new Headers(r),this.schemaName=n,this.urlLengthLimit=o;const l=s??globalThis.fetch;i!==void 0&&i>0?this.fetch=(c,u)=>{const h=new AbortController,d=setTimeout(()=>h.abort(),i),f=u==null?void 0:u.signal;if(f){if(f.aborted)return clearTimeout(d),l(c,u);const p=()=>{clearTimeout(d),h.abort()};return f.addEventListener("abort",p,{once:!0}),l(c,os(os({},u),{},{signal:h.signal})).finally(()=>{clearTimeout(d),f.removeEventListener("abort",p)})}return l(c,os(os({},u),{},{signal:h.signal})).finally(()=>clearTimeout(d))}:this.fetch=l,this.retry=a}from(e){if(!e||typeof e!="string"||e.trim()==="")throw new Error("Invalid relation name: relation must be a non-empty string.");return new Gg(new URL(`${this.url}/${e}`),{headers:new Headers(this.headers),schema:this.schemaName,fetch:this.fetch,urlLengthLimit:this.urlLengthLimit,retry:this.retry})}schema(e){return new Ou(this.url,{headers:this.headers,schema:e,fetch:this.fetch,urlLengthLimit:this.urlLengthLimit,retry:this.retry})}rpc(e,r={},{head:n=!1,get:s=!1,count:i}={}){var o;let a;const l=new URL(`${this.url}/rpc/${e}`);let c;const u=f=>f!==null&&typeof f=="object"&&(!Array.isArray(f)||f.some(u)),h=n&&Object.values(r).some(u);h?(a="POST",c=r):n||s?(a=n?"HEAD":"GET",Object.entries(r).filter(([f,p])=>p!==void 0).map(([f,p])=>[f,Array.isArray(p)?`{${p.join(",")}}`:`${p}`]).forEach(([f,p])=>{l.searchParams.append(f,p)})):(a="POST",c=r);const d=new Headers(this.headers);return h?d.set("Prefer",i?`count=${i},return=minimal`:"return=minimal"):i&&d.set("Prefer",`count=${i}`),new Hr({method:a,url:l,headers:d,schema:this.schemaName,body:c,fetch:(o=this.fetch)!==null&&o!==void 0?o:fetch,urlLengthLimit:this.urlLengthLimit,retry:this.retry})}};class Qg{constructor(){}static detectEnvironment(){var e;if(typeof WebSocket<"u")return{type:"native",wsConstructor:WebSocket};const r=globalThis;if(typeof globalThis<"u"&&typeof r.WebSocket<"u")return{type:"native",wsConstructor:r.WebSocket};const n=typeof global<"u"?global:void 0;if(n&&typeof n.WebSocket<"u")return{type:"native",wsConstructor:n.WebSocket};if(typeof globalThis<"u"&&typeof r.WebSocketPair<"u"&&typeof globalThis.WebSocket>"u")return{type:"cloudflare",error:"Cloudflare Workers detected. WebSocket clients are not supported in Cloudflare Workers.",workaround:"Use Cloudflare Workers WebSocket API for server-side WebSocket handling, or deploy to a different runtime."};if(typeof globalThis<"u"&&r.EdgeRuntime||typeof navigator<"u"&&(!((e=navigator.userAgent)===null||e===void 0)&&e.includes("Vercel-Edge")))return{type:"unsupported",error:"Edge runtime detected (Vercel Edge/Netlify Edge). WebSockets are not supported in edge functions.",workaround:"Use serverless functions or a different deployment target for WebSocket functionality."};const s=globalThis.process;if(s){const i=s.versions;if(i&&i.node){const o=i.node,a=parseInt(o.replace(/^v/,"").split(".")[0]);return a>=22?typeof globalThis.WebSocket<"u"?{type:"native",wsConstructor:globalThis.WebSocket}:{type:"unsupported",error:`Node.js ${a} detected but native WebSocket not found.`,workaround:"Provide a WebSocket implementation via the transport option."}:{type:"unsupported",error:`Node.js ${a} detected without native WebSocket support.`,workaround:`For Node.js < 22, install "ws" package and provide it via the transport option:
|
|
@@ -266,4 +266,4 @@ ${t}</tr>
|
|
|
266
266
|
`}tablecell(t){const e=this.parser.parseInline(t.tokens),r=t.header?"th":"td";return(t.align?`<${r} align="${t.align}">`:`<${r}>`)+e+`</${r}>
|
|
267
267
|
`}strong({tokens:t}){return`<strong>${this.parser.parseInline(t)}</strong>`}em({tokens:t}){return`<em>${this.parser.parseInline(t)}</em>`}codespan({text:t}){return`<code>${xt(t,!0)}</code>`}br(t){return"<br>"}del({tokens:t}){return`<del>${this.parser.parseInline(t)}</del>`}link({href:t,title:e,tokens:r}){const n=this.parser.parseInline(r),s=Ml(t);if(s===null)return n;t=s;let i='<a href="'+t+'"';return e&&(i+=' title="'+xt(e)+'"'),i+=">"+n+"</a>",i}image({href:t,title:e,text:r,tokens:n}){n&&(r=this.parser.parseInline(n,this.parser.textRenderer));const s=Ml(t);if(s===null)return xt(r);t=s;let i=`<img src="${t}" alt="${r}"`;return e&&(i+=` title="${xt(e)}"`),i+=">",i}text(t){return"tokens"in t&&t.tokens?this.parser.parseInline(t.tokens):"escaped"in t&&t.escaped?t.text:xt(t.text)}},zo=class{strong({text:t}){return t}em({text:t}){return t}codespan({text:t}){return t}del({text:t}){return t}html({text:t}){return t}text({text:t}){return t}link({text:t}){return""+t}image({text:t}){return""+t}br(){return""}},Jt=class go{constructor(e){be(this,"options");be(this,"renderer");be(this,"textRenderer");this.options=e||Or,this.options.renderer=this.options.renderer||new Us,this.renderer=this.options.renderer,this.renderer.options=this.options,this.renderer.parser=this,this.textRenderer=new zo}static parse(e,r){return new go(r).parse(e)}static parseInline(e,r){return new go(r).parseInline(e)}parse(e,r=!0){var s,i;let n="";for(let o=0;o<e.length;o++){const a=e[o];if((i=(s=this.options.extensions)==null?void 0:s.renderers)!=null&&i[a.type]){const c=a,u=this.options.extensions.renderers[c.type].call({parser:this},c);if(u!==!1||!["space","hr","heading","code","table","blockquote","list","html","paragraph","text"].includes(c.type)){n+=u||"";continue}}const l=a;switch(l.type){case"space":{n+=this.renderer.space(l);continue}case"hr":{n+=this.renderer.hr(l);continue}case"heading":{n+=this.renderer.heading(l);continue}case"code":{n+=this.renderer.code(l);continue}case"table":{n+=this.renderer.table(l);continue}case"blockquote":{n+=this.renderer.blockquote(l);continue}case"list":{n+=this.renderer.list(l);continue}case"html":{n+=this.renderer.html(l);continue}case"paragraph":{n+=this.renderer.paragraph(l);continue}case"text":{let c=l,u=this.renderer.text(c);for(;o+1<e.length&&e[o+1].type==="text";)c=e[++o],u+=`
|
|
268
268
|
`+this.renderer.text(c);r?n+=this.renderer.paragraph({type:"paragraph",raw:u,text:u,tokens:[{type:"text",raw:u,text:u,escaped:!0}]}):n+=u;continue}default:{const c='Token with "'+l.type+'" type was not found.';if(this.options.silent)return console.error(c),"";throw new Error(c)}}}return n}parseInline(e,r=this.renderer){var s,i;let n="";for(let o=0;o<e.length;o++){const a=e[o];if((i=(s=this.options.extensions)==null?void 0:s.renderers)!=null&&i[a.type]){const c=this.options.extensions.renderers[a.type].call({parser:this},a);if(c!==!1||!["escape","html","link","image","strong","em","codespan","br","del","text"].includes(a.type)){n+=c||"";continue}}const l=a;switch(l.type){case"escape":{n+=r.text(l);break}case"html":{n+=r.html(l);break}case"link":{n+=r.link(l);break}case"image":{n+=r.image(l);break}case"strong":{n+=r.strong(l);break}case"em":{n+=r.em(l);break}case"codespan":{n+=r.codespan(l);break}case"br":{n+=r.br(l);break}case"del":{n+=r.del(l);break}case"text":{n+=r.text(l);break}default:{const c='Token with "'+l.type+'" type was not found.';if(this.options.silent)return console.error(c),"";throw new Error(c)}}}return n}},ji,_s=(ji=class{constructor(t){be(this,"options");be(this,"block");this.options=t||Or}preprocess(t){return t}postprocess(t){return t}processAllTokens(t){return t}provideLexer(){return this.block?Gt.lex:Gt.lexInline}provideParser(){return this.block?Jt.parse:Jt.parseInline}},be(ji,"passThroughHooks",new Set(["preprocess","postprocess","processAllTokens"])),ji),Cb=class{constructor(...t){be(this,"defaults",Do());be(this,"options",this.setOptions);be(this,"parse",this.parseMarkdown(!0));be(this,"parseInline",this.parseMarkdown(!1));be(this,"Parser",Jt);be(this,"Renderer",Us);be(this,"TextRenderer",zo);be(this,"Lexer",Gt);be(this,"Tokenizer",Ds);be(this,"Hooks",_s);this.use(...t)}walkTokens(t,e){var n,s;let r=[];for(const i of t)switch(r=r.concat(e.call(this,i)),i.type){case"table":{const o=i;for(const a of o.header)r=r.concat(this.walkTokens(a.tokens,e));for(const a of o.rows)for(const l of a)r=r.concat(this.walkTokens(l.tokens,e));break}case"list":{const o=i;r=r.concat(this.walkTokens(o.items,e));break}default:{const o=i;(s=(n=this.defaults.extensions)==null?void 0:n.childTokens)!=null&&s[o.type]?this.defaults.extensions.childTokens[o.type].forEach(a=>{const l=o[a].flat(1/0);r=r.concat(this.walkTokens(l,e))}):o.tokens&&(r=r.concat(this.walkTokens(o.tokens,e)))}}return r}use(...t){const e=this.defaults.extensions||{renderers:{},childTokens:{}};return t.forEach(r=>{const n={...r};if(n.async=this.defaults.async||n.async||!1,r.extensions&&(r.extensions.forEach(s=>{if(!s.name)throw new Error("extension name required");if("renderer"in s){const i=e.renderers[s.name];i?e.renderers[s.name]=function(...o){let a=s.renderer.apply(this,o);return a===!1&&(a=i.apply(this,o)),a}:e.renderers[s.name]=s.renderer}if("tokenizer"in s){if(!s.level||s.level!=="block"&&s.level!=="inline")throw new Error("extension level must be 'block' or 'inline'");const i=e[s.level];i?i.unshift(s.tokenizer):e[s.level]=[s.tokenizer],s.start&&(s.level==="block"?e.startBlock?e.startBlock.push(s.start):e.startBlock=[s.start]:s.level==="inline"&&(e.startInline?e.startInline.push(s.start):e.startInline=[s.start]))}"childTokens"in s&&s.childTokens&&(e.childTokens[s.name]=s.childTokens)}),n.extensions=e),r.renderer){const s=this.defaults.renderer||new Us(this.defaults);for(const i in r.renderer){if(!(i in s))throw new Error(`renderer '${i}' does not exist`);if(["options","parser"].includes(i))continue;const o=i,a=r.renderer[o],l=s[o];s[o]=(...c)=>{let u=a.apply(s,c);return u===!1&&(u=l.apply(s,c)),u||""}}n.renderer=s}if(r.tokenizer){const s=this.defaults.tokenizer||new Ds(this.defaults);for(const i in r.tokenizer){if(!(i in s))throw new Error(`tokenizer '${i}' does not exist`);if(["options","rules","lexer"].includes(i))continue;const o=i,a=r.tokenizer[o],l=s[o];s[o]=(...c)=>{let u=a.apply(s,c);return u===!1&&(u=l.apply(s,c)),u}}n.tokenizer=s}if(r.hooks){const s=this.defaults.hooks||new _s;for(const i in r.hooks){if(!(i in s))throw new Error(`hook '${i}' does not exist`);if(["options","block"].includes(i))continue;const o=i,a=r.hooks[o],l=s[o];_s.passThroughHooks.has(i)?s[o]=c=>{if(this.defaults.async)return Promise.resolve(a.call(s,c)).then(h=>l.call(s,h));const u=a.call(s,c);return l.call(s,u)}:s[o]=(...c)=>{let u=a.apply(s,c);return u===!1&&(u=l.apply(s,c)),u}}n.hooks=s}if(r.walkTokens){const s=this.defaults.walkTokens,i=r.walkTokens;n.walkTokens=function(o){let a=[];return a.push(i.call(this,o)),s&&(a=a.concat(s.call(this,o))),a}}this.defaults={...this.defaults,...n}}),this}setOptions(t){return this.defaults={...this.defaults,...t},this}lexer(t,e){return Gt.lex(t,e??this.defaults)}parser(t,e){return Jt.parse(t,e??this.defaults)}parseMarkdown(t){return(r,n)=>{const s={...n},i={...this.defaults,...s},o=this.onError(!!i.silent,!!i.async);if(this.defaults.async===!0&&s.async===!1)return o(new Error("marked(): The async option was set to true by an extension. Remove async: false from the parse options object to return a Promise."));if(typeof r>"u"||r===null)return o(new Error("marked(): input parameter is undefined or null"));if(typeof r!="string")return o(new Error("marked(): input parameter is of type "+Object.prototype.toString.call(r)+", string expected"));i.hooks&&(i.hooks.options=i,i.hooks.block=t);const a=i.hooks?i.hooks.provideLexer():t?Gt.lex:Gt.lexInline,l=i.hooks?i.hooks.provideParser():t?Jt.parse:Jt.parseInline;if(i.async)return Promise.resolve(i.hooks?i.hooks.preprocess(r):r).then(c=>a(c,i)).then(c=>i.hooks?i.hooks.processAllTokens(c):c).then(c=>i.walkTokens?Promise.all(this.walkTokens(c,i.walkTokens)).then(()=>c):c).then(c=>l(c,i)).then(c=>i.hooks?i.hooks.postprocess(c):c).catch(o);try{i.hooks&&(r=i.hooks.preprocess(r));let c=a(r,i);i.hooks&&(c=i.hooks.processAllTokens(c)),i.walkTokens&&this.walkTokens(c,i.walkTokens);let u=l(c,i);return i.hooks&&(u=i.hooks.postprocess(u)),u}catch(c){return o(c)}}}onError(t,e){return r=>{if(r.message+=`
|
|
269
|
-
Please report this to https://github.com/markedjs/marked.`,t){const n="<p>An error occurred:</p><pre>"+xt(r.message+"",!0)+"</pre>";return e?Promise.resolve(n):n}if(e)return Promise.reject(r);throw r}}},Cr=new Cb;function ye(t,e){return Cr.parse(t,e)}ye.options=ye.setOptions=function(t){return Cr.setOptions(t),ye.defaults=Cr.defaults,Xu(ye.defaults),ye};ye.getDefaults=Do;ye.defaults=Or;ye.use=function(...t){return Cr.use(...t),ye.defaults=Cr.defaults,Xu(ye.defaults),ye};ye.walkTokens=function(t,e){return Cr.walkTokens(t,e)};ye.parseInline=Cr.parseInline;ye.Parser=Jt;ye.parser=Jt.parse;ye.Renderer=Us;ye.TextRenderer=zo;ye.Lexer=Gt;ye.lexer=Gt.lex;ye.Tokenizer=Ds;ye.Hooks=_s;ye.parse=ye;ye.options;ye.setOptions;ye.use;ye.walkTokens;ye.parseInline;Jt.parse;Gt.lex;const Ob=["innerHTML"],Pb=pr({__name:"MarkdownContent",props:{content:{}},setup(t){const e=t,r=$e(()=>e.content?ye.parse(e.content,{async:!1}):"");return(n,s)=>(Z(),ue("div",{class:"prose prose-sm dark:prose-invert max-w-none",innerHTML:r.value},null,8,Ob))}}),lh=10*1024*1024,ch=25*1024*1024;function yn(t){return t<1024?`${t} B`:t<1024*1024?`${(t/1024).toFixed(1)} KB`:`${(t/(1024*1024)).toFixed(1)} MB`}function $i(t){return t.mimeType.startsWith("image/")}function Ib(t){return`data:${t.mimeType};base64,${t.content}`}async function $b(t){const e=await new Promise((n,s)=>{const i=new FileReader;i.onload=()=>n(String(i.result??"")),i.onerror=()=>s(new Error("Unable to read file")),i.readAsDataURL(t)}),r=e.indexOf(",");if(r===-1)throw new Error(`Unable to parse file content for ${t.name}`);return{name:t.name,mimeType:t.type||"application/octet-stream",size:t.size,content:e.slice(r+1)}}function jb(t){for(const r of t)if(r.size>lh)return{ok:!1,error:`"${r.name}" exceeds the 10MB per-file limit.`};return t.reduce((r,n)=>r+n.size,0)>ch?{ok:!1,error:"Attachments exceed the 25MB per-message limit."}:{ok:!0}}const Nb={class:"overlay-header",style:{background:"linear-gradient(180deg, rgba(216,51,51,0.12) 0%, rgba(240,65,255,0.06) 100%)"}},Lb={key:0,class:"flex h-full items-center justify-center px-5 text-center"},Db={key:0,class:"overlay-avatar-letter"},Ub={key:0,class:"mb-2 space-y-2"},Bb=["src","alt"],Mb={class:"flex items-center gap-2 text-[9px]"},Hb={class:"truncate"},qb={class:"opacity-70"},Fb={key:2,class:"text-zinc-500"},Vb={key:0,class:"overlay-stream-indicator"},zb={class:"overlay-footer"},Wb={key:0,class:"mb-2 space-y-2"},Kb={class:"flex flex-wrap gap-1.5"},Gb={class:"max-w-[120px] truncate"},Jb={class:"opacity-65"},Yb=["onClick"],Xb={class:"overlay-meta text-zinc-500"},Zb={key:1,class:"mb-2 text-[11px] text-[#ef4444]"},Qb={class:"overlay-composer-field"},e_=["disabled"],t_=["disabled","aria-label","title"],r_=pr({__name:"ChatOverlay",setup(t){const e=Kv(),r=ln(),n=jo(),s=Oe(!1),i=Oe(""),o=Oe(""),a=Oe(!1),l=Oe([]),c=Oe(),u=Oe(),h=Oe(),d=Oe(!0),f=Oe(!1),p=[0,110,220],y=$e(()=>e.messages.length>0),w=()=>n.path==="/",k=$e(()=>l.value.reduce((L,se)=>L+se.size,0)),_=$e(()=>{const L=typeof r.email=="string"?r.email.trim():"";return L?L.charAt(0).toUpperCase():"U"}),b=$e(()=>!e.isStreaming&&(i.value.trim().length>0||l.value.length>0));function x(){w()||(s.value=!s.value)}function D(){h.value&&(h.value.style.height="auto",h.value.style.height=`${Math.min(h.value.scrollHeight,136)}px`)}function M(){if(!c.value)return;const L=c.value,se=L.scrollHeight-L.scrollTop-L.clientHeight;d.value=se<40,f.value=!d.value}function U(L=!1){c.value&&(L||d.value)&&(c.value.scrollTop=c.value.scrollHeight,f.value=!1)}async function V(L){if(!L||L.length===0)return;o.value="";const se=[];try{for(const ae of Array.from(L))se.push(await $b(ae))}catch(ae){o.value=(ae==null?void 0:ae.message)??"Unable to read one or more files.";return}const We=[...l.value,...se],ie=jb(We);if(!ie.ok){o.value=ie.error;return}l.value=We,u.value&&(u.value.value="")}function C(L){l.value.splice(L,1),o.value=""}function z(){var L;e.isStreaming||(L=u.value)==null||L.click()}function Q(L){const se=L.target;V((se==null?void 0:se.files)??null)}async function O(){if(!b.value)return;const L=i.value.trim(),se=[...l.value],We=L||"Please review the attached file(s).";i.value="",l.value=[],o.value="",D(),await e.sendMessage(We,se)}function Y(){e.stopStreaming()}function Ee(L){if(L.key==="Enter"&&!L.shiftKey){if(L.preventDefault(),e.isStreaming){Y();return}O()}}function je(L){L.preventDefault(),!e.isStreaming&&(a.value=!0)}function me(L){L.preventDefault(),a.value=!1}async function te(L){var se;L.preventDefault(),a.value=!1,!e.isStreaming&&await V(((se=L.dataTransfer)==null?void 0:se.files)??null)}return Kt(i,()=>D()),Kt(()=>e.messages.map(L=>L.content),async()=>{await hr(),M(),U()},{deep:!0}),Kt(()=>e.messages.length,async()=>{await hr(),M(),U(!0)}),Kt(s,async L=>{L&&(await hr(),D(),M(),U(!0))}),xo(async()=>{await hr(),D()}),(L,se)=>{const We=Zs("X");return Z(),ue(Fe,null,[!s.value&&!w()?(Z(),ue("button",{key:0,onClick:x,class:"overlay-fab",title:"Chat with IO","aria-label":"Open chat overlay"},[he(re(xu),{class:"h-4 w-4 text-white"})])):De("",!0),he(yf,{"enter-active-class":"transition-all duration-200 ease-out","enter-from-class":"opacity-0 translate-y-4 scale-[0.98]","enter-to-class":"opacity-100 translate-y-0 scale-100","leave-active-class":"transition-all duration-150 ease-in","leave-from-class":"opacity-100 translate-y-0 scale-100","leave-to-class":"opacity-0 translate-y-4 scale-[0.98]"},{default:Yr(()=>[s.value?(Z(),ue("section",{key:0,class:Ye(["overlay-panel",a.value?"overlay-panel-dragging":""]),"aria-label":"IO Assistant chat",onDragover:je,onDragleave:me,onDrop:te},[ne("header",Nb,[se[4]||(se[4]=ne("div",{class:"flex items-center gap-2.5"},[ne("div",{class:"overlay-brand-mark","aria-hidden":"true"},[ne("img",{src:Tu,alt:"IO",width:"18",height:"18",class:"shrink-0"})]),ne("div",{class:"flex items-center leading-none"},[ne("span",{class:"overlay-title"},"IO Chat")])],-1)),ne("button",{onClick:se[0]||(se[0]=ie=>s.value=!1),class:"overlay-icon-btn","aria-label":"Minimize chat overlay",title:"Minimize chat"},[he(re(_g),{class:"h-3.5 w-3.5"})])]),ne("div",{ref_key:"messagesContainer",ref:c,class:"overlay-messages",onScroll:M},[y.value?De("",!0):(Z(),ue("div",Lb,[ne("div",null,[he(Zi,{size:32,class:"mx-auto mb-3 shrink-0"}),se[5]||(se[5]=ne("p",{class:"overlay-empty-copy"},"Ask IO about your workspace, agents, or recent changes.",-1))])])),(Z(!0),ue(Fe,null,zr(re(e).messages,ie=>(Z(),ue("div",{key:ie.id,class:Ye(["flex",ie.role==="user"?"justify-end":"justify-start"])},[ne("div",{class:Ye(["flex max-w-full items-start gap-2",ie.role==="user"?"flex-row-reverse":""])},[ne("div",{class:Ye(["overlay-avatar",ie.role==="user"?"overlay-avatar-user":"overlay-avatar-assistant"]),"aria-hidden":"true"},[ie.role==="user"?(Z(),ue("span",Db,it(_.value),1)):(Z(),nt(Zi,{key:1,size:10,class:"shrink-0"}))],2),ne("article",{class:Ye(["overlay-bubble",ie.role==="user"?"overlay-bubble-user rounded-tr-sm":"overlay-bubble-assistant rounded-tl-sm"])},[ie.attachments.length>0?(Z(),ue("div",Ub,[(Z(!0),ue(Fe,null,zr(ie.attachments,(ae,Lt)=>(Z(),ue("div",{key:`${ie.id}-${Lt}`,class:"overlay-attachment"},[re($i)(ae)?(Z(),ue("img",{key:0,src:re(Ib)(ae),alt:ae.name,class:"mb-1 max-h-44 rounded-md object-contain"},null,8,Bb)):De("",!0),ne("div",Mb,[re($i)(ae)?(Z(),nt(re(nl),{key:0,class:"h-3.5 w-3.5"})):(Z(),nt(re(rl),{key:1,class:"h-3.5 w-3.5"})),ne("span",Hb,it(ae.name),1),ne("span",qb,it(re(yn)(ae.size)),1)])]))),128))])):De("",!0),ie.content?(Z(),nt(Pb,{key:1,content:ie.content,class:Ye(["overlay-markdown",ie.role==="user"?"prose-invert":""])},null,8,["content","class"])):(Z(),ue("span",Fb,"..."))],2)],2),ie.streaming&&ie.role==="assistant"?(Z(),ue("div",Vb,[(Z(),ue(Fe,null,zr(p,ae=>ne("span",{key:ae,class:"overlay-stream-dot",style:Ws({animationDelay:`${ae}ms`})},null,4)),64))])):De("",!0)],2))),128))],544),f.value?(Z(),ue("button",{key:0,class:"overlay-scroll-hint",type:"button",onClick:se[1]||(se[1]=ie=>U(!0)),"aria-label":"Scroll to latest message"},[he(re(pg),{class:"h-3.5 w-3.5"}),se[6]||(se[6]=ru(" Latest ",-1))])):De("",!0),ne("footer",zb,[ne("input",{ref_key:"fileInput",ref:u,type:"file",multiple:"",class:"hidden",onChange:Q},null,544),l.value.length>0?(Z(),ue("div",Wb,[ne("div",Kb,[(Z(!0),ue(Fe,null,zr(l.value,(ie,ae)=>(Z(),ue("div",{key:`${ie.name}-${ae}`,class:"overlay-chip"},[re($i)(ie)?(Z(),nt(re(nl),{key:0,class:"h-3.5 w-3.5"})):(Z(),nt(re(rl),{key:1,class:"h-3.5 w-3.5"})),ne("span",Gb,it(ie.name),1),ne("span",Jb,it(re(yn)(ie.size)),1),ne("button",{class:"hover:text-destructive",onClick:Lt=>C(ae)},[he(We,{class:"h-3.5 w-3.5"})],8,Yb)]))),128))]),ne("p",Xb,it(re(yn)(k.value))+" · Max "+it(re(yn)(re(lh)))+" file · "+it(re(yn)(re(ch)))+" total ",1)])):De("",!0),o.value?(Z(),ue("p",Zb,it(o.value),1)):De("",!0),ne("div",Qb,[ne("button",{class:"overlay-attach-btn",disabled:re(e).isStreaming,onClick:z,title:"Attach files","aria-label":"Attach files"},[he(re(Sg),{class:"h-4 w-4"})],8,e_),od(ne("textarea",{ref_key:"textareaRef",ref:h,"onUpdate:modelValue":se[2]||(se[2]=ie=>i.value=ie),onKeydown:Ee,placeholder:"Message IO…",rows:"1",class:"overlay-input"},null,544),[[Mf,i.value]]),ne("button",{onClick:se[3]||(se[3]=ie=>re(e).isStreaming?Y():O()),disabled:!b.value&&!re(e).isStreaming,class:"overlay-send-btn","aria-label":re(e).isStreaming?"Stop generation":"Send message",title:re(e).isStreaming?"Stop generation":"Send message"},[re(e).isStreaming?(Z(),nt(re(Rg),{key:1,class:"h-3 w-3"})):(Z(),nt(re(Tg),{key:0,class:"h-3 w-3"}))],8,t_)])])],34)):De("",!0)]),_:1})],64)}}}),n_=(t,e)=>{const r=t.__vccOpts||t;for(const[n,s]of e)r[n]=s;return r},s_=n_(r_,[["__scopeId","data-v-a7653537"]]),i_={class:"flex h-screen overflow-hidden"},o_={class:"flex-1 flex flex-col overflow-hidden"},a_={class:"flex-1 overflow-auto"},l_=pr({__name:"App",setup(t){const e=ln(),r=jo(),n=$e(()=>e.isAuthenticated&&r.name!=="login");return(s,i)=>{const o=Zs("router-view");return Z(),ue("div",i_,[n.value?(Z(),nt(Ug,{key:0})):De("",!0),ne("div",o_,[n.value?(Z(),nt(Vv,{key:0})):De("",!0),ne("main",a_,[he(o)])]),n.value?(Z(),nt(s_,{key:1})):De("",!0)])}}}),c_=[{path:"/login",name:"login",component:()=>Ke(()=>import("./LoginView-D_oXjfQ0.js"),[]),meta:{public:!0}},{path:"/",name:"chat",component:()=>Ke(()=>import("./ChatView-BmoUBfcQ.js"),__vite__mapDeps([0,1]))},{path:"/squads",name:"squads",component:()=>Ke(()=>import("./SquadsView-t4Q9TWhX.js"),__vite__mapDeps([2,3,4,5]))},{path:"/squads/health",name:"squad-health",component:()=>Ke(()=>import("./SquadHealthView-hqEZEHLz.js"),__vite__mapDeps([6,3,7,5]))},{path:"/squads/:id",name:"squad-detail",component:()=>Ke(()=>import("./SquadDetailView-UmzQrE0j.js"),__vite__mapDeps([8,3,4,1,5,9,10]))},{path:"/feed",name:"feed",component:()=>Ke(()=>import("./FeedView-xBZRxsAN.js"),__vite__mapDeps([11,3,4,9]))},{path:"/skills",name:"skills",component:()=>Ke(()=>import("./SkillsView-B3tgbASM.js"),__vite__mapDeps([12,3,13,14,15,1,9]))},{path:"/mcp",name:"mcp",component:()=>Ke(()=>import("./McpView-DcfHvkG-.js"),__vite__mapDeps([16,3,17,13,9]))},{path:"/schedules",name:"schedules",component:()=>Ke(()=>import("./SchedulesView-BKjd8mJY.js"),__vite__mapDeps([18,3,4,17,13,9]))},{path:"/history",name:"history",component:()=>Ke(()=>import("./HistoryView-CsEnqHvS.js"),__vite__mapDeps([19,3,14,10,9]))},{path:"/wiki",name:"wiki",component:()=>Ke(()=>import("./WikiView-D37JXznF.js"),__vite__mapDeps([20,3,14,13,15,9,1]))},{path:"/usage",name:"usage",component:()=>Ke(()=>import("./UsageView-BPNGL60Q.js"),__vite__mapDeps([21,3,7]))},{path:"/audit-log",name:"audit-log",component:()=>Ke(()=>import("./AuditLogView-5L1vXh9l.js"),__vite__mapDeps([22,3]))},{path:"/settings",name:"settings",component:()=>Ke(()=>import("./SettingsView-CQUKuTB1.js"),__vite__mapDeps([23,3]))}],uh=og({history:Up(),routes:c_});uh.beforeEach(t=>{const e=ln();if(!t.meta.public&&!e.isAuthenticated)return{name:"login"}});async function u_(){await Bv();const t=Wf(l_);t.use(Jf()),t.use(uh);const{useAuthStore:e}=await Ke(async()=>{const{useAuthStore:n}=await Promise.resolve().then(()=>Mv);return{useAuthStore:n}},void 0),r=e();r.initAuthListener(),r.token&&await r.refreshToken(),t.mount("#app")}u_();export{f_ as $,hg as A,dg as B,fg as C,Ws as D,xo as E,rl as F,$c as G,vg as H,nl as I,Z as J,Oe as K,zr as L,lh as M,Zs as N,uh as O,Sg as P,Ib as Q,it as R,Tg as S,re as T,Cg as U,ln as V,Kv as W,jo as X,ag as Y,d_ as Z,Zi as _,pg as a,Mf as a0,jb as a1,Kt as a2,Yr as a3,od as a4,g_ as a5,p_ as a6,gg as b,mg as c,Fe as d,Au as e,ch as f,xu as g,Eg as h,Ag as i,Rg as j,Og as k,Pb as l,$e as m,ne as n,nt as o,De as p,ue as q,Ae as r,ru as s,he as t,pr as u,$b as v,yn as w,$i as x,hr as y,Ye as z};
|
|
269
|
+
Please report this to https://github.com/markedjs/marked.`,t){const n="<p>An error occurred:</p><pre>"+xt(r.message+"",!0)+"</pre>";return e?Promise.resolve(n):n}if(e)return Promise.reject(r);throw r}}},Cr=new Cb;function ye(t,e){return Cr.parse(t,e)}ye.options=ye.setOptions=function(t){return Cr.setOptions(t),ye.defaults=Cr.defaults,Xu(ye.defaults),ye};ye.getDefaults=Do;ye.defaults=Or;ye.use=function(...t){return Cr.use(...t),ye.defaults=Cr.defaults,Xu(ye.defaults),ye};ye.walkTokens=function(t,e){return Cr.walkTokens(t,e)};ye.parseInline=Cr.parseInline;ye.Parser=Jt;ye.parser=Jt.parse;ye.Renderer=Us;ye.TextRenderer=zo;ye.Lexer=Gt;ye.lexer=Gt.lex;ye.Tokenizer=Ds;ye.Hooks=_s;ye.parse=ye;ye.options;ye.setOptions;ye.use;ye.walkTokens;ye.parseInline;Jt.parse;Gt.lex;const Ob=["innerHTML"],Pb=pr({__name:"MarkdownContent",props:{content:{}},setup(t){const e=t,r=$e(()=>e.content?ye.parse(e.content,{async:!1}):"");return(n,s)=>(Z(),ue("div",{class:"prose prose-sm dark:prose-invert max-w-none",innerHTML:r.value},null,8,Ob))}}),lh=10*1024*1024,ch=25*1024*1024;function yn(t){return t<1024?`${t} B`:t<1024*1024?`${(t/1024).toFixed(1)} KB`:`${(t/(1024*1024)).toFixed(1)} MB`}function $i(t){return t.mimeType.startsWith("image/")}function Ib(t){return`data:${t.mimeType};base64,${t.content}`}async function $b(t){const e=await new Promise((n,s)=>{const i=new FileReader;i.onload=()=>n(String(i.result??"")),i.onerror=()=>s(new Error("Unable to read file")),i.readAsDataURL(t)}),r=e.indexOf(",");if(r===-1)throw new Error(`Unable to parse file content for ${t.name}`);return{name:t.name,mimeType:t.type||"application/octet-stream",size:t.size,content:e.slice(r+1)}}function jb(t){for(const r of t)if(r.size>lh)return{ok:!1,error:`"${r.name}" exceeds the 10MB per-file limit.`};return t.reduce((r,n)=>r+n.size,0)>ch?{ok:!1,error:"Attachments exceed the 25MB per-message limit."}:{ok:!0}}const Nb={class:"overlay-header",style:{background:"linear-gradient(180deg, rgba(216,51,51,0.12) 0%, rgba(240,65,255,0.06) 100%)"}},Lb={key:0,class:"flex h-full items-center justify-center px-5 text-center"},Db={key:0,class:"overlay-avatar-letter"},Ub={key:0,class:"mb-2 space-y-2"},Bb=["src","alt"],Mb={class:"flex items-center gap-2 text-[9px]"},Hb={class:"truncate"},qb={class:"opacity-70"},Fb={key:2,class:"text-zinc-500"},Vb={key:0,class:"overlay-stream-indicator"},zb={class:"overlay-footer"},Wb={key:0,class:"mb-2 space-y-2"},Kb={class:"flex flex-wrap gap-1.5"},Gb={class:"max-w-[120px] truncate"},Jb={class:"opacity-65"},Yb=["onClick"],Xb={class:"overlay-meta text-zinc-500"},Zb={key:1,class:"mb-2 text-[11px] text-[#ef4444]"},Qb={class:"overlay-composer-field"},e_=["disabled"],t_=["disabled","aria-label","title"],r_=pr({__name:"ChatOverlay",setup(t){const e=Kv(),r=ln(),n=jo(),s=Oe(!1),i=Oe(""),o=Oe(""),a=Oe(!1),l=Oe([]),c=Oe(),u=Oe(),h=Oe(),d=Oe(!0),f=Oe(!1),p=[0,110,220],y=$e(()=>e.messages.length>0),w=()=>n.path==="/",k=$e(()=>l.value.reduce((L,se)=>L+se.size,0)),_=$e(()=>{const L=typeof r.email=="string"?r.email.trim():"";return L?L.charAt(0).toUpperCase():"U"}),b=$e(()=>!e.isStreaming&&(i.value.trim().length>0||l.value.length>0));function x(){w()||(s.value=!s.value)}function D(){h.value&&(h.value.style.height="auto",h.value.style.height=`${Math.min(h.value.scrollHeight,136)}px`)}function M(){if(!c.value)return;const L=c.value,se=L.scrollHeight-L.scrollTop-L.clientHeight;d.value=se<40,f.value=!d.value}function U(L=!1){c.value&&(L||d.value)&&(c.value.scrollTop=c.value.scrollHeight,f.value=!1)}async function V(L){if(!L||L.length===0)return;o.value="";const se=[];try{for(const ae of Array.from(L))se.push(await $b(ae))}catch(ae){o.value=(ae==null?void 0:ae.message)??"Unable to read one or more files.";return}const We=[...l.value,...se],ie=jb(We);if(!ie.ok){o.value=ie.error;return}l.value=We,u.value&&(u.value.value="")}function C(L){l.value.splice(L,1),o.value=""}function z(){var L;e.isStreaming||(L=u.value)==null||L.click()}function Q(L){const se=L.target;V((se==null?void 0:se.files)??null)}async function O(){if(!b.value)return;const L=i.value.trim(),se=[...l.value],We=L||"Please review the attached file(s).";i.value="",l.value=[],o.value="",D(),await e.sendMessage(We,se)}function Y(){e.stopStreaming()}function Ee(L){if(L.key==="Enter"&&!L.shiftKey){if(L.preventDefault(),e.isStreaming){Y();return}O()}}function je(L){L.preventDefault(),!e.isStreaming&&(a.value=!0)}function me(L){L.preventDefault(),a.value=!1}async function te(L){var se;L.preventDefault(),a.value=!1,!e.isStreaming&&await V(((se=L.dataTransfer)==null?void 0:se.files)??null)}return Kt(i,()=>D()),Kt(()=>e.messages.map(L=>L.content),async()=>{await hr(),M(),U()},{deep:!0}),Kt(()=>e.messages.length,async()=>{await hr(),M(),U(!0)}),Kt(s,async L=>{L&&(await hr(),D(),M(),U(!0))}),xo(async()=>{await hr(),D()}),(L,se)=>{const We=Zs("X");return Z(),ue(Fe,null,[!s.value&&!w()?(Z(),ue("button",{key:0,onClick:x,class:"overlay-fab",title:"Chat with IO","aria-label":"Open chat overlay"},[he(re(xu),{class:"h-4 w-4 text-white"})])):De("",!0),he(yf,{"enter-active-class":"transition-all duration-200 ease-out","enter-from-class":"opacity-0 translate-y-4 scale-[0.98]","enter-to-class":"opacity-100 translate-y-0 scale-100","leave-active-class":"transition-all duration-150 ease-in","leave-from-class":"opacity-100 translate-y-0 scale-100","leave-to-class":"opacity-0 translate-y-4 scale-[0.98]"},{default:Yr(()=>[s.value?(Z(),ue("section",{key:0,class:Ye(["overlay-panel",a.value?"overlay-panel-dragging":""]),"aria-label":"IO Assistant chat",onDragover:je,onDragleave:me,onDrop:te},[ne("header",Nb,[se[4]||(se[4]=ne("div",{class:"flex items-center gap-2.5"},[ne("div",{class:"overlay-brand-mark","aria-hidden":"true"},[ne("img",{src:Tu,alt:"IO",width:"18",height:"18",class:"shrink-0"})]),ne("div",{class:"flex items-center leading-none"},[ne("span",{class:"overlay-title"},"IO Chat")])],-1)),ne("button",{onClick:se[0]||(se[0]=ie=>s.value=!1),class:"overlay-icon-btn","aria-label":"Minimize chat overlay",title:"Minimize chat"},[he(re(_g),{class:"h-3.5 w-3.5"})])]),ne("div",{ref_key:"messagesContainer",ref:c,class:"overlay-messages",onScroll:M},[y.value?De("",!0):(Z(),ue("div",Lb,[ne("div",null,[he(Zi,{size:32,class:"mx-auto mb-3 shrink-0"}),se[5]||(se[5]=ne("p",{class:"overlay-empty-copy"},"Ask IO about your workspace, agents, or recent changes.",-1))])])),(Z(!0),ue(Fe,null,zr(re(e).messages,ie=>(Z(),ue("div",{key:ie.id,class:Ye(["flex",ie.role==="user"?"justify-end":"justify-start"])},[ne("div",{class:Ye(["flex max-w-full items-start gap-2",ie.role==="user"?"flex-row-reverse":""])},[ne("div",{class:Ye(["overlay-avatar",ie.role==="user"?"overlay-avatar-user":"overlay-avatar-assistant"]),"aria-hidden":"true"},[ie.role==="user"?(Z(),ue("span",Db,it(_.value),1)):(Z(),nt(Zi,{key:1,size:10,class:"shrink-0"}))],2),ne("article",{class:Ye(["overlay-bubble",ie.role==="user"?"overlay-bubble-user rounded-tr-sm":"overlay-bubble-assistant rounded-tl-sm"])},[ie.attachments.length>0?(Z(),ue("div",Ub,[(Z(!0),ue(Fe,null,zr(ie.attachments,(ae,Lt)=>(Z(),ue("div",{key:`${ie.id}-${Lt}`,class:"overlay-attachment"},[re($i)(ae)?(Z(),ue("img",{key:0,src:re(Ib)(ae),alt:ae.name,class:"mb-1 max-h-44 rounded-md object-contain"},null,8,Bb)):De("",!0),ne("div",Mb,[re($i)(ae)?(Z(),nt(re(nl),{key:0,class:"h-3.5 w-3.5"})):(Z(),nt(re(rl),{key:1,class:"h-3.5 w-3.5"})),ne("span",Hb,it(ae.name),1),ne("span",qb,it(re(yn)(ae.size)),1)])]))),128))])):De("",!0),ie.content?(Z(),nt(Pb,{key:1,content:ie.content,class:Ye(["overlay-markdown",ie.role==="user"?"prose-invert":""])},null,8,["content","class"])):(Z(),ue("span",Fb,"..."))],2)],2),ie.streaming&&ie.role==="assistant"?(Z(),ue("div",Vb,[(Z(),ue(Fe,null,zr(p,ae=>ne("span",{key:ae,class:"overlay-stream-dot",style:Ws({animationDelay:`${ae}ms`})},null,4)),64))])):De("",!0)],2))),128))],544),f.value?(Z(),ue("button",{key:0,class:"overlay-scroll-hint",type:"button",onClick:se[1]||(se[1]=ie=>U(!0)),"aria-label":"Scroll to latest message"},[he(re(pg),{class:"h-3.5 w-3.5"}),se[6]||(se[6]=ru(" Latest ",-1))])):De("",!0),ne("footer",zb,[ne("input",{ref_key:"fileInput",ref:u,type:"file",multiple:"",class:"hidden",onChange:Q},null,544),l.value.length>0?(Z(),ue("div",Wb,[ne("div",Kb,[(Z(!0),ue(Fe,null,zr(l.value,(ie,ae)=>(Z(),ue("div",{key:`${ie.name}-${ae}`,class:"overlay-chip"},[re($i)(ie)?(Z(),nt(re(nl),{key:0,class:"h-3.5 w-3.5"})):(Z(),nt(re(rl),{key:1,class:"h-3.5 w-3.5"})),ne("span",Gb,it(ie.name),1),ne("span",Jb,it(re(yn)(ie.size)),1),ne("button",{class:"hover:text-destructive",onClick:Lt=>C(ae)},[he(We,{class:"h-3.5 w-3.5"})],8,Yb)]))),128))]),ne("p",Xb,it(re(yn)(k.value))+" · Max "+it(re(yn)(re(lh)))+" file · "+it(re(yn)(re(ch)))+" total ",1)])):De("",!0),o.value?(Z(),ue("p",Zb,it(o.value),1)):De("",!0),ne("div",Qb,[ne("button",{class:"overlay-attach-btn",disabled:re(e).isStreaming,onClick:z,title:"Attach files","aria-label":"Attach files"},[he(re(Sg),{class:"h-4 w-4"})],8,e_),od(ne("textarea",{ref_key:"textareaRef",ref:h,"onUpdate:modelValue":se[2]||(se[2]=ie=>i.value=ie),onKeydown:Ee,placeholder:"Message IO…",rows:"1",class:"overlay-input"},null,544),[[Mf,i.value]]),ne("button",{onClick:se[3]||(se[3]=ie=>re(e).isStreaming?Y():O()),disabled:!b.value&&!re(e).isStreaming,class:"overlay-send-btn","aria-label":re(e).isStreaming?"Stop generation":"Send message",title:re(e).isStreaming?"Stop generation":"Send message"},[re(e).isStreaming?(Z(),nt(re(Rg),{key:1,class:"h-3 w-3"})):(Z(),nt(re(Tg),{key:0,class:"h-3 w-3"}))],8,t_)])])],34)):De("",!0)]),_:1})],64)}}}),n_=(t,e)=>{const r=t.__vccOpts||t;for(const[n,s]of e)r[n]=s;return r},s_=n_(r_,[["__scopeId","data-v-a7653537"]]),i_={class:"flex h-screen overflow-hidden"},o_={class:"flex-1 flex flex-col overflow-hidden"},a_={class:"flex-1 overflow-auto"},l_=pr({__name:"App",setup(t){const e=ln(),r=jo(),n=$e(()=>e.isAuthenticated&&r.name!=="login");return(s,i)=>{const o=Zs("router-view");return Z(),ue("div",i_,[n.value?(Z(),nt(Ug,{key:0})):De("",!0),ne("div",o_,[n.value?(Z(),nt(Vv,{key:0})):De("",!0),ne("main",a_,[he(o)])]),n.value?(Z(),nt(s_,{key:1})):De("",!0)])}}}),c_=[{path:"/login",name:"login",component:()=>Ke(()=>import("./LoginView-D6mxNeTa.js"),[]),meta:{public:!0}},{path:"/",name:"chat",component:()=>Ke(()=>import("./ChatView-XDhymbA2.js"),__vite__mapDeps([0,1]))},{path:"/squads",name:"squads",component:()=>Ke(()=>import("./SquadsView-D3M4NaIk.js"),__vite__mapDeps([2,3,4,5]))},{path:"/squads/health",name:"squad-health",component:()=>Ke(()=>import("./SquadHealthView-BZgXZQlH.js"),__vite__mapDeps([6,3,7,5]))},{path:"/squads/:id",name:"squad-detail",component:()=>Ke(()=>import("./SquadDetailView-Dsl4g_hV.js"),__vite__mapDeps([8,3,4,1,5,9,10]))},{path:"/feed",name:"feed",component:()=>Ke(()=>import("./FeedView-Ca68D167.js"),__vite__mapDeps([11,3,4,9]))},{path:"/skills",name:"skills",component:()=>Ke(()=>import("./SkillsView-FN5SNvrs.js"),__vite__mapDeps([12,3,13,14,15,1,9]))},{path:"/mcp",name:"mcp",component:()=>Ke(()=>import("./McpView-Cofqgako.js"),__vite__mapDeps([16,3,17,13,9]))},{path:"/schedules",name:"schedules",component:()=>Ke(()=>import("./SchedulesView-DWaBgdyB.js"),__vite__mapDeps([18,3,4,17,13,9]))},{path:"/history",name:"history",component:()=>Ke(()=>import("./HistoryView-BwHwKFic.js"),__vite__mapDeps([19,3,14,10,9]))},{path:"/wiki",name:"wiki",component:()=>Ke(()=>import("./WikiView-jWG97hfd.js"),__vite__mapDeps([20,3,14,13,15,9,1]))},{path:"/usage",name:"usage",component:()=>Ke(()=>import("./UsageView-vvvGgNkr.js"),__vite__mapDeps([21,3,7]))},{path:"/audit-log",name:"audit-log",component:()=>Ke(()=>import("./AuditLogView-B1fqx1A6.js"),__vite__mapDeps([22,3]))},{path:"/settings",name:"settings",component:()=>Ke(()=>import("./SettingsView-D3Ec_g9G.js"),__vite__mapDeps([23,3]))}],uh=og({history:Up(),routes:c_});uh.beforeEach(t=>{const e=ln();if(!t.meta.public&&!e.isAuthenticated)return{name:"login"}});async function u_(){await Bv();const t=Wf(l_);t.use(Jf()),t.use(uh);const{useAuthStore:e}=await Ke(async()=>{const{useAuthStore:n}=await Promise.resolve().then(()=>Mv);return{useAuthStore:n}},void 0),r=e();r.initAuthListener(),r.token&&await r.refreshToken(),t.mount("#app")}u_();export{f_ as $,hg as A,dg as B,fg as C,Ws as D,xo as E,rl as F,$c as G,vg as H,nl as I,Z as J,Oe as K,zr as L,lh as M,Zs as N,uh as O,Sg as P,Ib as Q,it as R,Tg as S,re as T,Cg as U,ln as V,Kv as W,jo as X,ag as Y,d_ as Z,Zi as _,pg as a,Mf as a0,jb as a1,Kt as a2,Yr as a3,od as a4,g_ as a5,p_ as a6,gg as b,mg as c,Fe as d,Au as e,ch as f,xu as g,Eg as h,Ag as i,Rg as j,Og as k,Pb as l,$e as m,ne as n,nt as o,De as p,ue as q,Ae as r,ru as s,he as t,pr as u,$b as v,yn as w,$i as x,hr as y,Ye as z};
|
package/web-dist/index.html
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
6
6
|
<title>IO — Dashboard</title>
|
|
7
7
|
<link rel="icon" type="image/svg+xml" href="/favicon.svg" />
|
|
8
|
-
<script type="module" crossorigin src="/assets/index-
|
|
8
|
+
<script type="module" crossorigin src="/assets/index-pfWzpkoo.js"></script>
|
|
9
9
|
<link rel="stylesheet" crossorigin href="/assets/index-vcgp2T40.css">
|
|
10
10
|
</head>
|
|
11
11
|
<body class="bg-background text-foreground">
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{u as H,W as O,a2 as z,E as U,J as a,q as r,n as o,T as t,t as w,p as m,d as T,L as A,R as d,w as g,M as X,f as W,P as Y,a4 as J,a0 as Q,o as f,S as R,j as G,z as b,K as v,m as B,v as Z,a1 as ee,_ as te,x as S,Q as se,I as E,F as I,l as ae,y as $}from"./index-DEUF9X23.js";import{X as ne}from"./x-yR_yShVB.js";const oe={class:"flex flex-col h-full"},re={key:0,class:"flex items-center justify-center h-full"},le={class:"text-center text-muted-foreground"},ie={key:0,class:"mb-2 space-y-2"},ce=["src","alt"],ue={class:"flex items-center gap-2 text-xs"},de={class:"truncate"},pe={class:"opacity-70"},fe={key:2,class:"text-muted-foreground"},me={key:3,class:"inline-block w-2 h-4 bg-current animate-pulse ml-1"},ve={key:0,class:"mb-2 space-y-2"},he={class:"flex flex-wrap gap-2"},ge={class:"max-w-[170px] truncate"},xe={class:"opacity-70"},_e=["onClick"],ye={class:"text-xs text-muted-foreground"},be={key:1,class:"text-xs text-destructive mb-2"},ke={class:"flex gap-2 items-end"},we=["disabled"],Te=["disabled"],De=H({__name:"ChatView",setup(Ae){const c=O(),h=v(""),p=v(""),x=v(),_=v(),i=v([]),y=v(!1),j=B(()=>i.value.reduce((e,n)=>e+n.size,0)),C=B(()=>!c.isStreaming&&(h.value.trim().length>0||i.value.length>0));async function D(e){if(!e||e.length===0)return;p.value="";const n=[];try{for(const u of Array.from(e))n.push(await Z(u))}catch(u){p.value=(u==null?void 0:u.message)??"Unable to read one or more files.";return}const s=[...i.value,...n],l=ee(s);if(!l.ok){p.value=l.error;return}i.value=s,_.value&&(_.value.value="")}function N(e){i.value.splice(e,1),p.value=""}function P(){var e;(e=_.value)==null||e.click()}function V(e){const n=e.target;D((n==null?void 0:n.files)??null)}async function M(){if(!C.value)return;const e=h.value.trim(),n=[...i.value],s=e||"Please review the attached file(s).";h.value="",i.value=[],p.value="",await c.sendMessage(s,n)}function k(){x.value&&(x.value.scrollTop=x.value.scrollHeight)}function F(e){e.key==="Enter"&&!e.shiftKey&&(e.preventDefault(),M())}function K(e){e.preventDefault(),y.value=!0}function L(e){e.preventDefault(),y.value=!1}async function q(e){var n;e.preventDefault(),y.value=!1,await D(((n=e.dataTransfer)==null?void 0:n.files)??null)}return z(()=>c.messages.map(e=>e.content),async()=>{await $(),k()},{deep:!0}),z(()=>c.messages.length,async()=>{await $(),k()}),U(()=>k()),(e,n)=>(a(),r("div",oe,[o("div",{ref_key:"messagesContainer",ref:x,class:"flex-1 overflow-y-auto p-4 space-y-4"},[t(c).messages.length===0?(a(),r("div",re,[o("div",le,[w(te,{size:56,class:"mx-auto mb-4"}),n[1]||(n[1]=o("p",{class:"text-lg font-medium"},"Welcome to IO",-1)),n[2]||(n[2]=o("p",{class:"text-sm mt-1"},"Send a message to get started.",-1))])])):m("",!0),(a(!0),r(T,null,A(t(c).messages,s=>(a(),r("div",{key:s.id,class:b(["flex",s.role==="user"?"justify-end":"justify-start"])},[o("div",{class:b(["max-w-[75%] rounded-lg px-4 py-2 text-sm",s.role==="user"?"bg-primary text-primary-foreground":"bg-muted text-foreground"])},[s.attachments.length>0?(a(),r("div",ie,[(a(!0),r(T,null,A(s.attachments,(l,u)=>(a(),r("div",{key:`${s.id}-${u}`,class:"rounded border border-border/50 p-2 bg-background/70 text-foreground"},[t(S)(l)?(a(),r("img",{key:0,src:t(se)(l),alt:l.name,class:"max-h-44 rounded mb-1 object-contain"},null,8,ce)):m("",!0),o("div",ue,[t(S)(l)?(a(),f(t(E),{key:0,class:"w-3.5 h-3.5"})):(a(),f(t(I),{key:1,class:"w-3.5 h-3.5"})),o("span",de,d(l.name),1),o("span",pe,d(t(g)(l.size)),1)])]))),128))])):m("",!0),s.content?(a(),f(ae,{key:1,content:s.content,class:b(s.role==="user"?"prose-invert":"")},null,8,["content","class"])):(a(),r("span",fe,"...")),s.streaming?(a(),r("div",me)):m("",!0)],2)],2))),128))],512),o("div",{class:b(["border-t border-border p-4",y.value?"bg-accent/40":""]),onDragover:K,onDragleave:L,onDrop:q},[o("input",{ref_key:"fileInput",ref:_,type:"file",multiple:"",class:"hidden",onChange:V},null,544),i.value.length>0?(a(),r("div",ve,[o("div",he,[(a(!0),r(T,null,A(i.value,(s,l)=>(a(),r("div",{key:`${s.name}-${l}`,class:"flex items-center gap-2 rounded border border-border px-2 py-1 text-xs bg-muted"},[t(S)(s)?(a(),f(t(E),{key:0,class:"w-3.5 h-3.5"})):(a(),f(t(I),{key:1,class:"w-3.5 h-3.5"})),o("span",ge,d(s.name),1),o("span",xe,d(t(g)(s.size)),1),o("button",{class:"hover:text-destructive",onClick:u=>N(l)},[w(t(ne),{class:"w-3.5 h-3.5"})],8,_e)]))),128))]),o("p",ye,d(t(g)(j.value))+" attached · Max per file "+d(t(g)(t(X)))+" · Max total "+d(t(g)(t(W))),1)])):m("",!0),p.value?(a(),r("p",be,d(p.value),1)):m("",!0),o("div",ke,[o("button",{class:"rounded-md border border-input p-2 hover:bg-accent disabled:opacity-50",disabled:t(c).isStreaming,onClick:P,title:"Attach files"},[w(t(Y),{class:"w-4 h-4"})],8,we),J(o("textarea",{"onUpdate:modelValue":n[0]||(n[0]=s=>h.value=s),onKeydown:F,placeholder:"Send a message...",rows:"1",class:"flex-1 resize-none rounded-md border border-input bg-background px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-ring min-h-[40px] max-h-[120px]"},null,544),[[Q,h.value]]),o("button",{onClick:M,disabled:!C.value,class:"rounded-md bg-primary text-primary-foreground p-2 hover:bg-primary/90 disabled:opacity-50 transition-colors"},[t(c).isStreaming?(a(),f(t(G),{key:1,class:"w-4 h-4"})):(a(),f(t(R),{key:0,class:"w-4 h-4"}))],8,Te)])],34)]))}});export{De as default};
|