hermes-web-ui 0.3.7 → 0.3.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +21 -2
- package/dist/client/assets/{Add-Cc7cgBoB.js → Add-s316k4Av.js} +1 -1
- package/dist/client/assets/{Button-EoeZgIFH.js → Button-BkA_RI8a.js} +1 -1
- package/dist/client/assets/{ChannelsView-Bfbq3w7n.js → ChannelsView-DPmPn8DW.js} +1 -1
- package/dist/client/assets/ChatView-DEtziOPB.js +127 -0
- package/dist/client/assets/{ChatView-Vfi_jEpI.css → ChatView-DI3XN8vz.css} +1 -1
- package/dist/client/assets/{Close-CKHcXisf.js → Close-CrLD0IXG.js} +1 -1
- package/dist/client/assets/{FormItem-CvZvjrtr.js → FormItem-CQLdFrl9.js} +1 -1
- package/dist/client/assets/{GatewaysView-Dp4-TFPE.js → GatewaysView-CC1Y0tZZ.js} +1 -1
- package/dist/client/assets/{Input-Bk7XdoG-.js → Input-nXKlujwJ.js} +1 -1
- package/dist/client/assets/{InputNumber-Dn0EHi-K.js → InputNumber-DLZwwIyX.js} +1 -1
- package/dist/client/assets/{JobsView-D4JN73Zz.js → JobsView-BC0bBrJO.js} +2 -2
- package/dist/client/assets/{LoginView--hy5CI5O.js → LoginView-PqpFR9bV.js} +1 -1
- package/dist/client/assets/{LogsView-Dz2ZeYad.js → LogsView-DtR88N0b.js} +1 -1
- package/dist/client/assets/{MarkdownRenderer-BbedVxvo.js → MarkdownRenderer-BSLfTurm.js} +1 -1
- package/dist/client/assets/{MemoryView-D2EHM35l.js → MemoryView-CJRWnePL.js} +1 -1
- package/dist/client/assets/{Modal-C5-Iw50K.js → Modal-Bp9RK8LZ.js} +1 -1
- package/dist/client/assets/{ModelsView-CtrRf4vK.js → ModelsView-7Obe34Cz.js} +1 -1
- package/dist/client/assets/{Popconfirm-C-M2anVL.js → Popconfirm-DTdUi7r_.js} +1 -1
- package/dist/client/assets/{Popover-mIRPCy7U.js → Popover-_M3o0B7L.js} +1 -1
- package/dist/client/assets/{ProfilesView-Dy9PivgB.js → ProfilesView-1_GmRx-S.js} +1 -1
- package/dist/client/assets/{Select-uZBC8HC2.js → Select-aHPR3urY.js} +1 -1
- package/dist/client/assets/{SettingRow-D9R65bDj.js → SettingRow-DKasLuS5.js} +1 -1
- package/dist/client/assets/{SettingsView-DWEEXqSY.js → SettingsView-DZCA7_CM.js} +1 -1
- package/dist/client/assets/{SkillsView-CdZSRy9_.js → SkillsView-Dk7O05cK.js} +1 -1
- package/dist/client/assets/{Spin-ChbFBUOD.js → Spin-Bt_9cTiO.js} +1 -1
- package/dist/client/assets/{Suffix-DgzfIwzx.js → Suffix-XaH8SDbR.js} +1 -1
- package/dist/client/assets/{Switch--HhY1uSh.js → Switch-D1_psmjT.js} +1 -1
- package/dist/client/assets/{Tag-B2zrHMmZ.js → Tag-3FaOhoJN.js} +1 -1
- package/dist/client/assets/{TerminalView-BwfnH803.js → TerminalView-DNU7oQxK.js} +1 -1
- package/dist/client/assets/{Tooltip-9tdvSKGi.js → Tooltip-YHrHWGPa.js} +1 -1
- package/dist/client/assets/{UsageView-zL3a7F86.js → UsageView-COCrOiiV.js} +1 -1
- package/dist/client/assets/{Warning-CXXqHzLa.js → Warning-B6CM9aBl.js} +1 -1
- package/dist/client/assets/{_plugin-vue_export-helper-Cnn0Z73x.js → _plugin-vue_export-helper-BGG8ORDx.js} +1 -1
- package/dist/client/assets/{app-BMobzABI.js → app-B7ktf7Fh.js} +1 -1
- package/dist/client/assets/app-BPvTl2-V.js +1 -0
- package/dist/client/assets/{browser-CQRjhbaB.js → browser-f5W8abIG.js} +1 -1
- package/dist/client/assets/chat-6q6pkzEW.js +6 -0
- package/dist/client/assets/composables-xV7dhNpf.js +1 -0
- package/dist/client/assets/{fade-in.cssr-lwO9nLky.js → fade-in.cssr-ifHK7yH1.js} +1 -1
- package/dist/client/assets/{index-Tg6M43Om.js → index-CSCYx7ux.js} +1 -1
- package/dist/client/assets/{jobs-Z2HS0j2d.js → jobs-DObWfhbO.js} +1 -1
- package/dist/client/assets/{light-oE8MEiWL.js → light-CxjyoF0s.js} +1 -1
- package/dist/client/assets/{light-Dx6qj2pM.js → light-D1yfed_s.js} +1 -1
- package/dist/client/assets/{light-DzpNsLai.js → light-DWy-mwyK.js} +1 -1
- package/dist/client/assets/{light-CjCy-Dkn.js → light-D_3MwJj1.js} +1 -1
- package/dist/client/assets/{light-DgIst23O.js → light-DgLcPjgU.js} +1 -1
- package/dist/client/assets/{light-DZ0Ns16h.js → light-TGFKT-UB.js} +1 -1
- package/dist/client/assets/{models-DLQiHB7r.js → models-DQ4CT-vv.js} +1 -1
- package/dist/client/assets/{pinia-Dp_b1vdW.js → pinia-DcAkZ8vx.js} +1 -1
- package/dist/client/assets/{profiles-CNTHYFZE.js → profiles-DzkigJwq.js} +1 -1
- package/dist/client/assets/{router-Dj-Nmg7q.js → router-D8sJ39Io.js} +2 -2
- package/dist/client/assets/{sessions-C0kvgvBm.js → sessions-Dg8n9PBo.js} +1 -1
- package/dist/client/assets/{skills-G7EoEvdS.js → skills-BehzdECn.js} +1 -1
- package/dist/client/assets/{use-message-BgToAqhv.js → use-message-DBz2JSTt.js} +1 -1
- package/dist/client/assets/{useTheme-BUShiwRu.js → useTheme-UdVT814n.js} +1 -1
- package/dist/client/index.html +27 -27
- package/dist/server/index.js +8 -3
- package/dist/server/routes/hermes/group-chat.d.ts +2 -0
- package/dist/server/routes/hermes/group-chat.js +135 -0
- package/dist/server/routes/upload.js +41 -11
- package/dist/server/services/group-chat/coordinator.d.ts +14 -0
- package/dist/server/services/group-chat/coordinator.js +230 -0
- package/dist/server/services/group-chat/index.d.ts +5 -0
- package/dist/server/services/group-chat/index.js +115 -0
- package/dist/server/services/group-chat/rooms-db.d.ts +56 -0
- package/dist/server/services/group-chat/rooms-db.js +199 -0
- package/package.json +1 -1
- package/dist/client/assets/ChatView-CDdyTo72.js +0 -127
- package/dist/client/assets/app-Bqu9Uz-1.js +0 -1
- package/dist/client/assets/chat-BIdq6ZXF.js +0 -6
- package/dist/client/assets/composables-ClIU-Ad1.js +0 -1
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.setupGroupChatSocketIO = setupGroupChatSocketIO;
|
|
37
|
+
exports.getGroupChatIO = getGroupChatIO;
|
|
38
|
+
exports.disconnectGroupChatIO = disconnectGroupChatIO;
|
|
39
|
+
const socket_io_1 = require("socket.io");
|
|
40
|
+
const auth_1 = require("../auth");
|
|
41
|
+
const roomsDb = __importStar(require("./rooms-db"));
|
|
42
|
+
const coordinator = __importStar(require("./coordinator"));
|
|
43
|
+
let io = null;
|
|
44
|
+
function setupGroupChatSocketIO(httpServer) {
|
|
45
|
+
io = new socket_io_1.Server(httpServer, {
|
|
46
|
+
path: '/socket.io/group-chat',
|
|
47
|
+
cors: { origin: '*' },
|
|
48
|
+
});
|
|
49
|
+
// Auth middleware
|
|
50
|
+
io.use(async (socket, next) => {
|
|
51
|
+
const authToken = await (0, auth_1.getToken)();
|
|
52
|
+
if (authToken) {
|
|
53
|
+
const token = socket.handshake.auth.token || socket.handshake.query.token;
|
|
54
|
+
if (token !== authToken) {
|
|
55
|
+
return next(new Error('Unauthorized'));
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
next();
|
|
59
|
+
});
|
|
60
|
+
io.on('connection', (socket) => {
|
|
61
|
+
let currentRoom = null;
|
|
62
|
+
socket.on('room:join', async (roomId) => {
|
|
63
|
+
if (currentRoom) {
|
|
64
|
+
socket.leave(currentRoom);
|
|
65
|
+
}
|
|
66
|
+
currentRoom = roomId;
|
|
67
|
+
socket.join(roomId);
|
|
68
|
+
const messages = roomsDb.getRoomMessages(roomId, 100);
|
|
69
|
+
const agents = roomsDb.getRoomAgents(roomId);
|
|
70
|
+
socket.emit('room:history', { roomId, messages, agents });
|
|
71
|
+
});
|
|
72
|
+
socket.on('room:leave', (roomId) => {
|
|
73
|
+
socket.leave(roomId);
|
|
74
|
+
if (currentRoom === roomId)
|
|
75
|
+
currentRoom = null;
|
|
76
|
+
});
|
|
77
|
+
socket.on('room:message', async (data) => {
|
|
78
|
+
if (!currentRoom || currentRoom !== data.roomId)
|
|
79
|
+
return;
|
|
80
|
+
if (!data.content?.trim())
|
|
81
|
+
return;
|
|
82
|
+
const { roomId, content } = data;
|
|
83
|
+
// Process via coordinator (stores user message internally)
|
|
84
|
+
await coordinator.processMessage(roomId, content, {
|
|
85
|
+
onDelta(rId, agentName, text) {
|
|
86
|
+
io.to(rId).emit('message:delta', { roomId: rId, agentName, text });
|
|
87
|
+
},
|
|
88
|
+
onAgentStatus(rId, agentName, status) {
|
|
89
|
+
io.to(rId).emit('agent:status', { roomId: rId, agentName, status });
|
|
90
|
+
},
|
|
91
|
+
onAgentComplete(rId, agentName, message) {
|
|
92
|
+
io.to(rId).emit('room:message', { roomId: rId, message });
|
|
93
|
+
},
|
|
94
|
+
onAgentError(rId, agentName, error) {
|
|
95
|
+
io.to(rId).emit('agent:status', { roomId: rId, agentName, status: 'error', error });
|
|
96
|
+
},
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
socket.on('disconnect', () => {
|
|
100
|
+
if (currentRoom) {
|
|
101
|
+
socket.leave(currentRoom);
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
});
|
|
105
|
+
return io;
|
|
106
|
+
}
|
|
107
|
+
function getGroupChatIO() {
|
|
108
|
+
return io;
|
|
109
|
+
}
|
|
110
|
+
function disconnectGroupChatIO() {
|
|
111
|
+
if (io) {
|
|
112
|
+
io.disconnectSockets();
|
|
113
|
+
io = null;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
export interface Room {
|
|
2
|
+
id: string;
|
|
3
|
+
name: string;
|
|
4
|
+
settings: string;
|
|
5
|
+
created_at: number;
|
|
6
|
+
updated_at: number;
|
|
7
|
+
}
|
|
8
|
+
export interface RoomAgent {
|
|
9
|
+
room_id: string;
|
|
10
|
+
agent_name: string;
|
|
11
|
+
profile: string;
|
|
12
|
+
session_id: string;
|
|
13
|
+
role_prompt: string;
|
|
14
|
+
}
|
|
15
|
+
export interface RoomMessage {
|
|
16
|
+
id: string;
|
|
17
|
+
room_id: string;
|
|
18
|
+
role: 'user' | 'assistant' | 'system';
|
|
19
|
+
agent_name: string;
|
|
20
|
+
content: string;
|
|
21
|
+
mentions: string;
|
|
22
|
+
round: number;
|
|
23
|
+
created_at: number;
|
|
24
|
+
}
|
|
25
|
+
export interface NewRoomMessage {
|
|
26
|
+
room_id: string;
|
|
27
|
+
role: string;
|
|
28
|
+
agent_name?: string;
|
|
29
|
+
content: string;
|
|
30
|
+
mentions?: string[];
|
|
31
|
+
round?: number;
|
|
32
|
+
}
|
|
33
|
+
export declare function createRoom(name: string): Room;
|
|
34
|
+
export declare function listRooms(): Room[];
|
|
35
|
+
export declare function getRoom(roomId: string): Room | null;
|
|
36
|
+
export declare function updateRoom(roomId: string, updates: Partial<Pick<Room, 'name' | 'settings'>>): boolean;
|
|
37
|
+
export declare function deleteRoom(roomId: string): boolean;
|
|
38
|
+
export declare function addRoomAgent(roomId: string, agent: {
|
|
39
|
+
agent_name: string;
|
|
40
|
+
profile: string;
|
|
41
|
+
role_prompt?: string;
|
|
42
|
+
}): RoomAgent | null;
|
|
43
|
+
export declare function removeRoomAgent(roomId: string, agentName: string): boolean;
|
|
44
|
+
export declare function getRoomAgents(roomId: string): RoomAgent[];
|
|
45
|
+
export declare function updateRoomAgentSession(roomId: string, agentName: string, sessionId: string): void;
|
|
46
|
+
export declare function addMessage(msg: NewRoomMessage): RoomMessage;
|
|
47
|
+
export declare function getRoomMessages(roomId: string, limit?: number, offset?: number): RoomMessage[];
|
|
48
|
+
export declare function getLatestRound(roomId: string): number;
|
|
49
|
+
/**
|
|
50
|
+
* Get recent context messages relevant to a specific agent.
|
|
51
|
+
* Returns messages where:
|
|
52
|
+
* - mentions is empty (public message, no @mentions)
|
|
53
|
+
* - mentions includes agentName
|
|
54
|
+
* - message is FROM this agent
|
|
55
|
+
*/
|
|
56
|
+
export declare function getRecentContext(roomId: string, agentName: string, limit?: number): RoomMessage[];
|
|
@@ -0,0 +1,199 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createRoom = createRoom;
|
|
4
|
+
exports.listRooms = listRooms;
|
|
5
|
+
exports.getRoom = getRoom;
|
|
6
|
+
exports.updateRoom = updateRoom;
|
|
7
|
+
exports.deleteRoom = deleteRoom;
|
|
8
|
+
exports.addRoomAgent = addRoomAgent;
|
|
9
|
+
exports.removeRoomAgent = removeRoomAgent;
|
|
10
|
+
exports.getRoomAgents = getRoomAgents;
|
|
11
|
+
exports.updateRoomAgentSession = updateRoomAgentSession;
|
|
12
|
+
exports.addMessage = addMessage;
|
|
13
|
+
exports.getRoomMessages = getRoomMessages;
|
|
14
|
+
exports.getLatestRound = getLatestRound;
|
|
15
|
+
exports.getRecentContext = getRecentContext;
|
|
16
|
+
const os_1 = require("os");
|
|
17
|
+
const path_1 = require("path");
|
|
18
|
+
// ---------------------------------------------------------------------------
|
|
19
|
+
// Database singleton
|
|
20
|
+
// ---------------------------------------------------------------------------
|
|
21
|
+
const SQLITE_AVAILABLE = (() => {
|
|
22
|
+
const [major, minor] = process.versions.node.split('.').map(Number);
|
|
23
|
+
return major > 22 || (major === 22 && minor >= 5);
|
|
24
|
+
})();
|
|
25
|
+
function dbPath() {
|
|
26
|
+
return (0, path_1.join)((0, os_1.homedir)(), '.hermes-web-ui', 'rooms.db');
|
|
27
|
+
}
|
|
28
|
+
let _db = null;
|
|
29
|
+
function getDb() {
|
|
30
|
+
if (_db)
|
|
31
|
+
return _db;
|
|
32
|
+
if (!SQLITE_AVAILABLE) {
|
|
33
|
+
throw new Error('Group chat requires Node.js >= 22.5 for SQLite support');
|
|
34
|
+
}
|
|
35
|
+
const { DatabaseSync } = require('node:sqlite');
|
|
36
|
+
const dir = (0, path_1.join)((0, os_1.homedir)(), '.hermes-web-ui');
|
|
37
|
+
const { mkdirSync } = require('fs');
|
|
38
|
+
mkdirSync(dir, { recursive: true });
|
|
39
|
+
_db = new DatabaseSync(dbPath(), { open: true });
|
|
40
|
+
_db.exec('PRAGMA journal_mode=WAL');
|
|
41
|
+
_db.exec('PRAGMA foreign_keys=ON');
|
|
42
|
+
initSchema(_db);
|
|
43
|
+
return _db;
|
|
44
|
+
}
|
|
45
|
+
function initSchema(db) {
|
|
46
|
+
db.exec(`
|
|
47
|
+
CREATE TABLE IF NOT EXISTS rooms (
|
|
48
|
+
id TEXT PRIMARY KEY,
|
|
49
|
+
name TEXT NOT NULL,
|
|
50
|
+
settings TEXT DEFAULT '{}',
|
|
51
|
+
created_at INTEGER NOT NULL,
|
|
52
|
+
updated_at INTEGER NOT NULL
|
|
53
|
+
);
|
|
54
|
+
|
|
55
|
+
CREATE TABLE IF NOT EXISTS room_agents (
|
|
56
|
+
room_id TEXT NOT NULL REFERENCES rooms(id) ON DELETE CASCADE,
|
|
57
|
+
agent_name TEXT NOT NULL,
|
|
58
|
+
profile TEXT NOT NULL,
|
|
59
|
+
session_id TEXT DEFAULT '',
|
|
60
|
+
role_prompt TEXT DEFAULT '',
|
|
61
|
+
PRIMARY KEY (room_id, agent_name)
|
|
62
|
+
);
|
|
63
|
+
|
|
64
|
+
CREATE TABLE IF NOT EXISTS room_messages (
|
|
65
|
+
id TEXT PRIMARY KEY,
|
|
66
|
+
room_id TEXT NOT NULL REFERENCES rooms(id) ON DELETE CASCADE,
|
|
67
|
+
role TEXT NOT NULL,
|
|
68
|
+
agent_name TEXT DEFAULT '',
|
|
69
|
+
content TEXT NOT NULL,
|
|
70
|
+
mentions TEXT DEFAULT '[]',
|
|
71
|
+
round INTEGER DEFAULT 0,
|
|
72
|
+
created_at INTEGER NOT NULL
|
|
73
|
+
);
|
|
74
|
+
|
|
75
|
+
CREATE INDEX IF NOT EXISTS idx_room_messages_room
|
|
76
|
+
ON room_messages(room_id, created_at);
|
|
77
|
+
`);
|
|
78
|
+
}
|
|
79
|
+
// ---------------------------------------------------------------------------
|
|
80
|
+
// Room CRUD
|
|
81
|
+
// ---------------------------------------------------------------------------
|
|
82
|
+
function createRoom(name) {
|
|
83
|
+
const db = getDb();
|
|
84
|
+
const now = Date.now();
|
|
85
|
+
const id = crypto.randomUUID();
|
|
86
|
+
db.prepare('INSERT INTO rooms (id, name, settings, created_at, updated_at) VALUES (?, ?, ?, ?, ?)')
|
|
87
|
+
.run(id, name, '{}', now, now);
|
|
88
|
+
return { id, name, settings: '{}', created_at: now, updated_at: now };
|
|
89
|
+
}
|
|
90
|
+
function listRooms() {
|
|
91
|
+
const db = getDb();
|
|
92
|
+
return db.prepare('SELECT * FROM rooms ORDER BY updated_at DESC').all();
|
|
93
|
+
}
|
|
94
|
+
function getRoom(roomId) {
|
|
95
|
+
const db = getDb();
|
|
96
|
+
return db.prepare('SELECT * FROM rooms WHERE id = ?').get(roomId);
|
|
97
|
+
}
|
|
98
|
+
function updateRoom(roomId, updates) {
|
|
99
|
+
const db = getDb();
|
|
100
|
+
const sets = [];
|
|
101
|
+
const values = [];
|
|
102
|
+
if (updates.name !== undefined) {
|
|
103
|
+
sets.push('name = ?');
|
|
104
|
+
values.push(updates.name);
|
|
105
|
+
}
|
|
106
|
+
if (updates.settings !== undefined) {
|
|
107
|
+
sets.push('settings = ?');
|
|
108
|
+
values.push(updates.settings);
|
|
109
|
+
}
|
|
110
|
+
if (sets.length === 0)
|
|
111
|
+
return false;
|
|
112
|
+
sets.push('updated_at = ?');
|
|
113
|
+
values.push(Date.now());
|
|
114
|
+
values.push(roomId);
|
|
115
|
+
const result = db.prepare(`UPDATE rooms SET ${sets.join(', ')} WHERE id = ?`).run(...values);
|
|
116
|
+
return result.changes > 0;
|
|
117
|
+
}
|
|
118
|
+
function deleteRoom(roomId) {
|
|
119
|
+
const db = getDb();
|
|
120
|
+
db.prepare('DELETE FROM room_messages WHERE room_id = ?').run(roomId);
|
|
121
|
+
db.prepare('DELETE FROM room_agents WHERE room_id = ?').run(roomId);
|
|
122
|
+
const result = db.prepare('DELETE FROM rooms WHERE id = ?').run(roomId);
|
|
123
|
+
return result.changes > 0;
|
|
124
|
+
}
|
|
125
|
+
// ---------------------------------------------------------------------------
|
|
126
|
+
// Room Agents
|
|
127
|
+
// ---------------------------------------------------------------------------
|
|
128
|
+
function addRoomAgent(roomId, agent) {
|
|
129
|
+
const db = getDb();
|
|
130
|
+
const row = db.prepare('INSERT OR IGNORE INTO room_agents (room_id, agent_name, profile, session_id, role_prompt) VALUES (?, ?, ?, ?, ?)').run(roomId, agent.agent_name, agent.profile, '', agent.role_prompt || '');
|
|
131
|
+
if (row.changes === 0)
|
|
132
|
+
return null;
|
|
133
|
+
return getRoomAgent(roomId, agent.agent_name);
|
|
134
|
+
}
|
|
135
|
+
function removeRoomAgent(roomId, agentName) {
|
|
136
|
+
const db = getDb();
|
|
137
|
+
const result = db.prepare('DELETE FROM room_agents WHERE room_id = ? AND agent_name = ?')
|
|
138
|
+
.run(roomId, agentName);
|
|
139
|
+
return result.changes > 0;
|
|
140
|
+
}
|
|
141
|
+
function getRoomAgents(roomId) {
|
|
142
|
+
const db = getDb();
|
|
143
|
+
return db.prepare('SELECT * FROM room_agents WHERE room_id = ?').all(roomId);
|
|
144
|
+
}
|
|
145
|
+
function getRoomAgent(roomId, agentName) {
|
|
146
|
+
const db = getDb();
|
|
147
|
+
return db.prepare('SELECT * FROM room_agents WHERE room_id = ? AND agent_name = ?')
|
|
148
|
+
.get(roomId, agentName);
|
|
149
|
+
}
|
|
150
|
+
function updateRoomAgentSession(roomId, agentName, sessionId) {
|
|
151
|
+
const db = getDb();
|
|
152
|
+
db.prepare('UPDATE room_agents SET session_id = ? WHERE room_id = ? AND agent_name = ?')
|
|
153
|
+
.run(sessionId, roomId, agentName);
|
|
154
|
+
}
|
|
155
|
+
// ---------------------------------------------------------------------------
|
|
156
|
+
// Messages
|
|
157
|
+
// ---------------------------------------------------------------------------
|
|
158
|
+
function addMessage(msg) {
|
|
159
|
+
const db = getDb();
|
|
160
|
+
const id = crypto.randomUUID();
|
|
161
|
+
const now = Date.now();
|
|
162
|
+
const mentions = msg.mentions ? JSON.stringify(msg.mentions) : '[]';
|
|
163
|
+
const round = msg.round ?? getLatestRound(msg.room_id);
|
|
164
|
+
db.prepare('INSERT INTO room_messages (id, room_id, role, agent_name, content, mentions, round, created_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?)').run(id, msg.room_id, msg.role, msg.agent_name || '', msg.content, mentions, round, now);
|
|
165
|
+
// Update room timestamp
|
|
166
|
+
db.prepare('UPDATE rooms SET updated_at = ? WHERE id = ?').run(now, msg.room_id);
|
|
167
|
+
return { id, room_id: msg.room_id, role: msg.role, agent_name: msg.agent_name || '', content: msg.content, mentions, round, created_at: now };
|
|
168
|
+
}
|
|
169
|
+
function getRoomMessages(roomId, limit = 100, offset = 0) {
|
|
170
|
+
const db = getDb();
|
|
171
|
+
return db.prepare('SELECT * FROM room_messages WHERE room_id = ? ORDER BY created_at ASC LIMIT ? OFFSET ?').all(roomId, limit, offset);
|
|
172
|
+
}
|
|
173
|
+
function getLatestRound(roomId) {
|
|
174
|
+
const db = getDb();
|
|
175
|
+
const row = db.prepare('SELECT MAX(round) as max_round FROM room_messages WHERE room_id = ?')
|
|
176
|
+
.get(roomId);
|
|
177
|
+
return (row?.max_round ?? -1) + 1;
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* Get recent context messages relevant to a specific agent.
|
|
181
|
+
* Returns messages where:
|
|
182
|
+
* - mentions is empty (public message, no @mentions)
|
|
183
|
+
* - mentions includes agentName
|
|
184
|
+
* - message is FROM this agent
|
|
185
|
+
*/
|
|
186
|
+
function getRecentContext(roomId, agentName, limit = 20) {
|
|
187
|
+
const db = getDb();
|
|
188
|
+
return db.prepare(`
|
|
189
|
+
SELECT * FROM room_messages
|
|
190
|
+
WHERE room_id = ?
|
|
191
|
+
AND (
|
|
192
|
+
json_array_length(mentions) = 0
|
|
193
|
+
OR agent_name = ?
|
|
194
|
+
OR mentions LIKE ?
|
|
195
|
+
)
|
|
196
|
+
ORDER BY created_at DESC
|
|
197
|
+
LIMIT ?
|
|
198
|
+
`).all(roomId, agentName, `%"${agentName}"%`, limit);
|
|
199
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "hermes-web-ui",
|
|
3
|
-
"version": "0.3.
|
|
3
|
+
"version": "0.3.8",
|
|
4
4
|
"description": "Web dashboard for Hermes Agent — multi-platform AI chat, session management, scheduled jobs, usage analytics & channel configuration (Telegram, Discord, Slack, WhatsApp)",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -1,127 +0,0 @@
|
|
|
1
|
-
import{$ as e,A as t,B as n,C as r,D as i,E as a,F as o,G as s,K as c,L as l,N as u,Q as d,R as f,T as p,U as m,V as h,W as g,X as _,_ as v,ct as y,d as b,dt as x,g as S,gt as C,j as w,k as T,m as E,mt as D,ot as O,pt as k,q as A,st as j,w as M,y as N}from"./router-Dj-Nmg7q.js";import{r as P,t as F}from"./_plugin-vue_export-helper-Cnn0Z73x.js";import{t as I}from"./logo-Cd-t_oGE.js";import{$ as L,B as R,X as z,c as B,ct as V,dt as H,ft as U,pt as W,q as G,st as K,tt as q,ut as J,z as ee}from"./browser-CQRjhbaB.js";import{C as te,E as Y,N as ne,S as X,T as Z,c as Q,g as re,k as ie,l as ae,m as oe,n as se,o as ce,r as le,t as ue}from"./Popover-mIRPCy7U.js";import{r as de,t as fe}from"./create-5zWq3BEB.js";import{d as pe,f as me,p as he,r as ge}from"./Suffix-DgzfIwzx.js";import{t as _e}from"./Modal-C5-Iw50K.js";import{t as $}from"./Button-EoeZgIFH.js";import{t as ve}from"./Input-Bk7XdoG-.js";import{i as ye,n as be,t as xe}from"./chat-BIdq6ZXF.js";import{t as Se}from"./Tooltip-9tdvSKGi.js";import{t as Ce}from"./use-message-BgToAqhv.js";import{t as we}from"./Popconfirm-C-M2anVL.js";import{t as Te}from"./useTheme-BUShiwRu.js";import{t as Ee}from"./app-BMobzABI.js";import{t as De}from"./profiles-CNTHYFZE.js";import{i as Oe}from"./sessions-C0kvgvBm.js";import{t as ke}from"./MarkdownRenderer-BbedVxvo.js";function Ae(e={},t){let r=O({ctrl:!1,command:!1,win:!1,shift:!1,tab:!1}),{keydown:i,keyup:a}=e,o=e=>{switch(e.key){case`Control`:r.ctrl=!0;break;case`Meta`:r.command=!0,r.win=!0;break;case`Shift`:r.shift=!0;break;case`Tab`:r.tab=!0;break}i!==void 0&&Object.keys(i).forEach(t=>{if(t!==e.key)return;let n=i[t];if(typeof n==`function`)n(e);else{let{stop:t=!1,prevent:r=!1}=n;t&&e.stopPropagation(),r&&e.preventDefault(),n.handler(e)}})},s=e=>{switch(e.key){case`Control`:r.ctrl=!1;break;case`Meta`:r.command=!1,r.win=!1;break;case`Shift`:r.shift=!1;break;case`Tab`:r.tab=!1;break}a!==void 0&&Object.keys(a).forEach(t=>{if(t!==e.key)return;let n=a[t];if(typeof n==`function`)n(e);else{let{stop:t=!1,prevent:r=!1}=n;t&&e.stopPropagation(),r&&e.preventDefault(),n.handler(e)}})},c=()=>{(t===void 0||t.value)&&(he(`keydown`,document,o),he(`keyup`,document,s)),t!==void 0&&_(t,e=>{e?(he(`keydown`,document,o),he(`keyup`,document,s)):(me(`keydown`,document,o),me(`keyup`,document,s))})};return ne()?(n(c),h(()=>{(t===void 0||t.value)&&(me(`keydown`,document,o),me(`keyup`,document,s))})):c(),j(r)}function je(e,t,n){if(!t)return e;let r=y(e.value),i=null;return _(e,e=>{i!==null&&window.clearTimeout(i),e===!0?n&&!n.value?r.value=!0:i=window.setTimeout(()=>{r.value=!0},t):r.value=!1}),r}function Me(e){return t=>{t?e.value=t.$el:e.value=null}}var Ne=w({name:`ChevronRight`,render(){return u(`svg`,{viewBox:`0 0 16 16`,fill:`none`,xmlns:`http://www.w3.org/2000/svg`},u(`path`,{d:`M5.64645 3.14645C5.45118 3.34171 5.45118 3.65829 5.64645 3.85355L9.79289 8L5.64645 12.1464C5.45118 12.3417 5.45118 12.6583 5.64645 12.8536C5.84171 13.0488 6.15829 13.0488 6.35355 12.8536L10.8536 8.35355C11.0488 8.15829 11.0488 7.84171 10.8536 7.64645L6.35355 3.14645C6.15829 2.95118 5.84171 2.95118 5.64645 3.14645Z`,fill:`currentColor`}))}}),Pe=L(`n-dropdown-menu`),Fe=L(`n-dropdown`),Ie=L(`n-dropdown-option`),Le=w({name:`DropdownDivider`,props:{clsPrefix:{type:String,required:!0}},render(){return u(`div`,{class:`${this.clsPrefix}-dropdown-divider`})}}),Re=w({name:`DropdownGroupHeader`,props:{clsPrefix:{type:String,required:!0},tmNode:{type:Object,required:!0}},setup(){let{showIconRef:e,hasSubmenuRef:t}=o(Pe),{renderLabelRef:n,labelFieldRef:r,nodePropsRef:i,renderOptionRef:a}=o(Fe);return{labelField:r,showIcon:e,hasSubmenu:t,renderLabel:n,nodeProps:i,renderOption:a}},render(){let{clsPrefix:e,hasSubmenu:t,showIcon:n,nodeProps:r,renderLabel:i,renderOption:a}=this,{rawNode:o}=this.tmNode,s=u(`div`,Object.assign({class:`${e}-dropdown-option`},r?.(o)),u(`div`,{class:`${e}-dropdown-option-body ${e}-dropdown-option-body--group`},u(`div`,{"data-dropdown-option":!0,class:[`${e}-dropdown-option-body__prefix`,n&&`${e}-dropdown-option-body__prefix--show-icon`]},Q(o.icon)),u(`div`,{class:`${e}-dropdown-option-body__label`,"data-dropdown-option":!0},i?i(o):Q(o.title??o[this.labelField])),u(`div`,{class:[`${e}-dropdown-option-body__suffix`,t&&`${e}-dropdown-option-body__suffix--has-submenu`],"data-dropdown-option":!0})));return a?a({node:s,option:o}):s}}),ze=V(`icon`,`
|
|
2
|
-
height: 1em;
|
|
3
|
-
width: 1em;
|
|
4
|
-
line-height: 1em;
|
|
5
|
-
text-align: center;
|
|
6
|
-
display: inline-block;
|
|
7
|
-
position: relative;
|
|
8
|
-
fill: currentColor;
|
|
9
|
-
`,[H(`color-transition`,{transition:`color .3s var(--n-bezier)`}),H(`depth`,{color:`var(--n-color)`},[K(`svg`,{opacity:`var(--n-opacity)`,transition:`opacity .3s var(--n-bezier)`})]),K(`svg`,{height:`1em`,width:`1em`})]),Be=w({_n_icon__:!0,name:`Icon`,inheritAttrs:!1,props:Object.assign(Object.assign({},B.props),{depth:[String,Number],size:[Number,String],color:String,component:[Object,Function]}),setup(e){let{mergedClsPrefixRef:t,inlineThemeDisabled:n}=R(e),i=B(`Icon`,`-icon`,ze,be,e,t),a=r(()=>{let{depth:t}=e,{common:{cubicBezierEaseInOut:n},self:r}=i.value;if(t!==void 0){let{color:e,[`opacity${t}Depth`]:i}=r;return{"--n-bezier":n,"--n-color":e,"--n-opacity":i}}return{"--n-bezier":n,"--n-color":``,"--n-opacity":``}}),o=n?ee(`icon`,r(()=>`${e.depth||`d`}`),a,e):void 0;return{mergedClsPrefix:t,mergedStyle:r(()=>{let{size:t,color:n}=e;return{fontSize:oe(t),color:n}}),cssVars:n?void 0:a,themeClass:o?.themeClass,onRender:o?.onRender}},render(){let{$parent:e,depth:t,mergedClsPrefix:n,component:r,onRender:i,themeClass:a}=this;return e?.$options?._n_icon__&&z(`icon`,"don't wrap `n-icon` inside `n-icon`"),i?.(),u(`i`,l(this.$attrs,{role:`img`,class:[`${n}-icon`,a,{[`${n}-icon--depth`]:t,[`${n}-icon--color-transition`]:t!==void 0}],style:[this.cssVars,this.mergedStyle]}),r?u(r):this.$slots)}});function Ve(e,t){return e.type===`submenu`||e.type===void 0&&e[t]!==void 0}function He(e){return e.type===`group`}function Ue(e){return e.type===`divider`}function We(e){return e.type===`render`}var Ge=w({name:`DropdownOption`,props:{clsPrefix:{type:String,required:!0},tmNode:{type:Object,required:!0},parentKey:{type:[String,Number],default:null},placement:{type:String,default:`right-start`},props:Object,scrollable:Boolean},setup(e){let t=o(Fe),{hoverKeyRef:n,keyboardKeyRef:i,lastToggledSubmenuKeyRef:a,pendingKeyPathRef:s,activeKeyPathRef:l,animatedRef:u,mergedShowRef:d,renderLabelRef:f,renderIconRef:p,labelFieldRef:m,childrenFieldRef:h,renderOptionRef:g,nodePropsRef:_,menuPropsRef:v}=t,b=o(Ie,null),x=o(Pe),S=o(Z),C=r(()=>e.tmNode.rawNode),w=r(()=>{let{value:t}=h;return Ve(e.tmNode.rawNode,t)}),T=r(()=>{let{disabled:t}=e.tmNode;return t}),E=je(r(()=>{if(!w.value)return!1;let{key:t,disabled:r}=e.tmNode;if(r)return!1;let{value:o}=n,{value:c}=i,{value:l}=a,{value:u}=s;return o===null?c===null?l===null?!1:u.includes(t):u.includes(t)&&u[u.length-1]!==t:u.includes(t)}),300,r(()=>i.value===null&&!u.value)),D=r(()=>!!b?.enteringSubmenuRef.value),O=y(!1);c(Ie,{enteringSubmenuRef:O});function k(){O.value=!0}function A(){O.value=!1}function j(){let{parentKey:t,tmNode:r}=e;r.disabled||d.value&&(a.value=t,i.value=null,n.value=r.key)}function M(){let{tmNode:t}=e;t.disabled||d.value&&n.value!==t.key&&j()}function N(t){if(e.tmNode.disabled||!d.value)return;let{relatedTarget:r}=t;r&&!de({target:r},`dropdownOption`)&&!de({target:r},`scrollbarRail`)&&(n.value=null)}function P(){let{value:n}=w,{tmNode:r}=e;d.value&&!n&&!r.disabled&&(t.doSelect(r.key,r.rawNode),t.doUpdateShow(!1))}return{labelField:m,renderLabel:f,renderIcon:p,siblingHasIcon:x.showIconRef,siblingHasSubmenu:x.hasSubmenuRef,menuProps:v,popoverBody:S,animated:u,mergedShowSubmenu:r(()=>E.value&&!D.value),rawNode:C,hasSubmenu:w,pending:q(()=>{let{value:t}=s,{key:n}=e.tmNode;return t.includes(n)}),childActive:q(()=>{let{value:t}=l,{key:n}=e.tmNode,r=t.findIndex(e=>n===e);return r===-1?!1:r<t.length-1}),active:q(()=>{let{value:t}=l,{key:n}=e.tmNode,r=t.findIndex(e=>n===e);return r===-1?!1:r===t.length-1}),mergedDisabled:T,renderOption:g,nodeProps:_,handleClick:P,handleMouseMove:M,handleMouseEnter:j,handleMouseLeave:N,handleSubmenuBeforeEnter:k,handleSubmenuAfterEnter:A}},render(){let{animated:e,rawNode:t,mergedShowSubmenu:n,clsPrefix:r,siblingHasIcon:i,siblingHasSubmenu:a,renderLabel:o,renderIcon:s,renderOption:c,nodeProps:d,props:f,scrollable:p}=this,m=null;if(n){let e=this.menuProps?.call(this,t,t.children);m=u(Je,Object.assign({},e,{clsPrefix:r,scrollable:this.scrollable,tmNodes:this.tmNode.children,parentKey:this.tmNode.key}))}let h={class:[`${r}-dropdown-option-body`,this.pending&&`${r}-dropdown-option-body--pending`,this.active&&`${r}-dropdown-option-body--active`,this.childActive&&`${r}-dropdown-option-body--child-active`,this.mergedDisabled&&`${r}-dropdown-option-body--disabled`],onMousemove:this.handleMouseMove,onMouseenter:this.handleMouseEnter,onMouseleave:this.handleMouseLeave,onClick:this.handleClick},g=d?.(t),_=u(`div`,Object.assign({class:[`${r}-dropdown-option`,g?.class],"data-dropdown-option":!0},g),u(`div`,l(h,f),[u(`div`,{class:[`${r}-dropdown-option-body__prefix`,i&&`${r}-dropdown-option-body__prefix--show-icon`]},[s?s(t):Q(t.icon)]),u(`div`,{"data-dropdown-option":!0,class:`${r}-dropdown-option-body__label`},o?o(t):Q(t[this.labelField]??t.title)),u(`div`,{"data-dropdown-option":!0,class:[`${r}-dropdown-option-body__suffix`,a&&`${r}-dropdown-option-body__suffix--has-submenu`]},this.hasSubmenu?u(Be,null,{default:()=>u(Ne,null)}):null)]),this.hasSubmenu?u(te,null,{default:()=>[u(X,null,{default:()=>u(`div`,{class:`${r}-dropdown-offset-container`},u(re,{show:this.mergedShowSubmenu,placement:this.placement,to:p&&this.popoverBody||void 0,teleportDisabled:!p},{default:()=>u(`div`,{class:`${r}-dropdown-menu-wrapper`},e?u(b,{onBeforeEnter:this.handleSubmenuBeforeEnter,onAfterEnter:this.handleSubmenuAfterEnter,name:`fade-in-scale-up-transition`,appear:!0},{default:()=>m}):m)}))})]}):null);return c?c({node:_,option:t}):_}}),Ke=w({name:`NDropdownGroup`,props:{clsPrefix:{type:String,required:!0},tmNode:{type:Object,required:!0},parentKey:{type:[String,Number],default:null}},render(){let{tmNode:e,parentKey:t,clsPrefix:n}=this,{children:r}=e;return u(N,null,u(Re,{clsPrefix:n,tmNode:e,key:e.key}),r?.map(e=>{let{rawNode:r}=e;return r.show===!1?null:Ue(r)?u(Le,{clsPrefix:n,key:e.key}):e.isGroup?(z(`dropdown`,"`group` node is not allowed to be put in `group` node."),null):u(Ge,{clsPrefix:n,tmNode:e,parentKey:t,key:e.key})}))}}),qe=w({name:`DropdownRenderOption`,props:{tmNode:{type:Object,required:!0}},render(){let{rawNode:{render:e,props:t}}=this.tmNode;return u(`div`,t,[e?.()])}}),Je=w({name:`DropdownMenu`,props:{scrollable:Boolean,showArrow:Boolean,arrowStyle:[String,Object],clsPrefix:{type:String,required:!0},tmNodes:{type:Array,default:()=>[]},parentKey:{type:[String,Number],default:null}},setup(e){let{renderIconRef:t,childrenFieldRef:n}=o(Fe);c(Pe,{showIconRef:r(()=>{let n=t.value;return e.tmNodes.some(e=>{if(e.isGroup)return e.children?.some(({rawNode:e})=>n?n(e):e.icon);let{rawNode:t}=e;return n?n(t):t.icon})}),hasSubmenuRef:r(()=>{let{value:t}=n;return e.tmNodes.some(e=>{if(e.isGroup)return e.children?.some(({rawNode:e})=>Ve(e,t));let{rawNode:n}=e;return Ve(n,t)})})});let i=y(null);return c(Y,null),c(ie,null),c(Z,i),{bodyRef:i}},render(){let{parentKey:e,clsPrefix:t,scrollable:n}=this,r=this.tmNodes.map(r=>{let{rawNode:i}=r;return i.show===!1?null:We(i)?u(qe,{tmNode:r,key:r.key}):Ue(i)?u(Le,{clsPrefix:t,key:r.key}):He(i)?u(Ke,{clsPrefix:t,tmNode:r,parentKey:e,key:r.key}):u(Ge,{clsPrefix:t,tmNode:r,parentKey:e,key:r.key,props:i.props,scrollable:n})});return u(`div`,{class:[`${t}-dropdown-menu`,n&&`${t}-dropdown-menu--scrollable`],ref:`bodyRef`},n?u(ge,{contentClass:`${t}-dropdown-menu__content`},{default:()=>r}):r,this.showArrow?le({clsPrefix:t,arrowStyle:this.arrowStyle,arrowClass:void 0,arrowWrapperClass:void 0,arrowWrapperStyle:void 0}):null)}}),Ye=V(`dropdown-menu`,`
|
|
10
|
-
transform-origin: var(--v-transform-origin);
|
|
11
|
-
background-color: var(--n-color);
|
|
12
|
-
border-radius: var(--n-border-radius);
|
|
13
|
-
box-shadow: var(--n-box-shadow);
|
|
14
|
-
position: relative;
|
|
15
|
-
transition:
|
|
16
|
-
background-color .3s var(--n-bezier),
|
|
17
|
-
box-shadow .3s var(--n-bezier);
|
|
18
|
-
`,[ce(),V(`dropdown-option`,`
|
|
19
|
-
position: relative;
|
|
20
|
-
`,[K(`a`,`
|
|
21
|
-
text-decoration: none;
|
|
22
|
-
color: inherit;
|
|
23
|
-
outline: none;
|
|
24
|
-
`,[K(`&::before`,`
|
|
25
|
-
content: "";
|
|
26
|
-
position: absolute;
|
|
27
|
-
left: 0;
|
|
28
|
-
right: 0;
|
|
29
|
-
top: 0;
|
|
30
|
-
bottom: 0;
|
|
31
|
-
`)]),V(`dropdown-option-body`,`
|
|
32
|
-
display: flex;
|
|
33
|
-
cursor: pointer;
|
|
34
|
-
position: relative;
|
|
35
|
-
height: var(--n-option-height);
|
|
36
|
-
line-height: var(--n-option-height);
|
|
37
|
-
font-size: var(--n-font-size);
|
|
38
|
-
color: var(--n-option-text-color);
|
|
39
|
-
transition: color .3s var(--n-bezier);
|
|
40
|
-
`,[K(`&::before`,`
|
|
41
|
-
content: "";
|
|
42
|
-
position: absolute;
|
|
43
|
-
top: 0;
|
|
44
|
-
bottom: 0;
|
|
45
|
-
left: 4px;
|
|
46
|
-
right: 4px;
|
|
47
|
-
transition: background-color .3s var(--n-bezier);
|
|
48
|
-
border-radius: var(--n-border-radius);
|
|
49
|
-
`),U(`disabled`,[H(`pending`,`
|
|
50
|
-
color: var(--n-option-text-color-hover);
|
|
51
|
-
`,[J(`prefix, suffix`,`
|
|
52
|
-
color: var(--n-option-text-color-hover);
|
|
53
|
-
`),K(`&::before`,`background-color: var(--n-option-color-hover);`)]),H(`active`,`
|
|
54
|
-
color: var(--n-option-text-color-active);
|
|
55
|
-
`,[J(`prefix, suffix`,`
|
|
56
|
-
color: var(--n-option-text-color-active);
|
|
57
|
-
`),K(`&::before`,`background-color: var(--n-option-color-active);`)]),H(`child-active`,`
|
|
58
|
-
color: var(--n-option-text-color-child-active);
|
|
59
|
-
`,[J(`prefix, suffix`,`
|
|
60
|
-
color: var(--n-option-text-color-child-active);
|
|
61
|
-
`)])]),H(`disabled`,`
|
|
62
|
-
cursor: not-allowed;
|
|
63
|
-
opacity: var(--n-option-opacity-disabled);
|
|
64
|
-
`),H(`group`,`
|
|
65
|
-
font-size: calc(var(--n-font-size) - 1px);
|
|
66
|
-
color: var(--n-group-header-text-color);
|
|
67
|
-
`,[J(`prefix`,`
|
|
68
|
-
width: calc(var(--n-option-prefix-width) / 2);
|
|
69
|
-
`,[H(`show-icon`,`
|
|
70
|
-
width: calc(var(--n-option-icon-prefix-width) / 2);
|
|
71
|
-
`)])]),J(`prefix`,`
|
|
72
|
-
width: var(--n-option-prefix-width);
|
|
73
|
-
display: flex;
|
|
74
|
-
justify-content: center;
|
|
75
|
-
align-items: center;
|
|
76
|
-
color: var(--n-prefix-color);
|
|
77
|
-
transition: color .3s var(--n-bezier);
|
|
78
|
-
z-index: 1;
|
|
79
|
-
`,[H(`show-icon`,`
|
|
80
|
-
width: var(--n-option-icon-prefix-width);
|
|
81
|
-
`),V(`icon`,`
|
|
82
|
-
font-size: var(--n-option-icon-size);
|
|
83
|
-
`)]),J(`label`,`
|
|
84
|
-
white-space: nowrap;
|
|
85
|
-
flex: 1;
|
|
86
|
-
z-index: 1;
|
|
87
|
-
`),J(`suffix`,`
|
|
88
|
-
box-sizing: border-box;
|
|
89
|
-
flex-grow: 0;
|
|
90
|
-
flex-shrink: 0;
|
|
91
|
-
display: flex;
|
|
92
|
-
justify-content: flex-end;
|
|
93
|
-
align-items: center;
|
|
94
|
-
min-width: var(--n-option-suffix-width);
|
|
95
|
-
padding: 0 8px;
|
|
96
|
-
transition: color .3s var(--n-bezier);
|
|
97
|
-
color: var(--n-suffix-color);
|
|
98
|
-
z-index: 1;
|
|
99
|
-
`,[H(`has-submenu`,`
|
|
100
|
-
width: var(--n-option-icon-suffix-width);
|
|
101
|
-
`),V(`icon`,`
|
|
102
|
-
font-size: var(--n-option-icon-size);
|
|
103
|
-
`)]),V(`dropdown-menu`,`pointer-events: all;`)]),V(`dropdown-offset-container`,`
|
|
104
|
-
pointer-events: none;
|
|
105
|
-
position: absolute;
|
|
106
|
-
left: 0;
|
|
107
|
-
right: 0;
|
|
108
|
-
top: -4px;
|
|
109
|
-
bottom: -4px;
|
|
110
|
-
`)]),V(`dropdown-divider`,`
|
|
111
|
-
transition: background-color .3s var(--n-bezier);
|
|
112
|
-
background-color: var(--n-divider-color);
|
|
113
|
-
height: 1px;
|
|
114
|
-
margin: 4px 0;
|
|
115
|
-
`),V(`dropdown-menu-wrapper`,`
|
|
116
|
-
transform-origin: var(--v-transform-origin);
|
|
117
|
-
width: fit-content;
|
|
118
|
-
`),K(`>`,[V(`scrollbar`,`
|
|
119
|
-
height: inherit;
|
|
120
|
-
max-height: inherit;
|
|
121
|
-
`)]),U(`scrollable`,`
|
|
122
|
-
padding: var(--n-padding);
|
|
123
|
-
`),H(`scrollable`,[J(`content`,`
|
|
124
|
-
padding: var(--n-padding);
|
|
125
|
-
`)])]),Xe={animated:{type:Boolean,default:!0},keyboard:{type:Boolean,default:!0},size:String,inverted:Boolean,placement:{type:String,default:`bottom`},onSelect:[Function,Array],options:{type:Array,default:()=>[]},menuProps:Function,showArrow:Boolean,renderLabel:Function,renderIcon:Function,renderOption:Function,nodeProps:Function,labelField:{type:String,default:`label`},keyField:{type:String,default:`key`},childrenField:{type:String,default:`children`},value:[String,Number]},Ze=Object.keys(se),Qe=w({name:`Dropdown`,inheritAttrs:!1,props:Object.assign(Object.assign(Object.assign({},se),Xe),B.props),setup(e){let t=y(!1),n=pe(x(e,`show`),t),i=r(()=>{let{keyField:t,childrenField:n}=e;return fe(e.options,{getKey(e){return e[t]},getDisabled(e){return e.disabled===!0},getIgnored(e){return e.type===`divider`||e.type===`render`},getChildren(e){return e[n]}})}),a=r(()=>i.value.treeNodes),o=y(null),s=y(null),l=y(null),u=r(()=>o.value??s.value??l.value??null),d=r(()=>i.value.getPath(u.value).keyPath),f=r(()=>i.value.getPath(e.value).keyPath),p=q(()=>e.keyboard&&n.value);Ae({keydown:{ArrowUp:{prevent:!0,handler:O},ArrowRight:{prevent:!0,handler:D},ArrowDown:{prevent:!0,handler:k},ArrowLeft:{prevent:!0,handler:E},Enter:{prevent:!0,handler:A},Escape:T}},p);let{mergedClsPrefixRef:m,inlineThemeDisabled:h,mergedComponentPropsRef:g}=R(e),v=r(()=>e.size||g?.value?.Dropdown?.size||`medium`),b=B(`Dropdown`,`-dropdown`,Ye,ye,e,m);c(Fe,{labelFieldRef:x(e,`labelField`),childrenFieldRef:x(e,`childrenField`),renderLabelRef:x(e,`renderLabel`),renderIconRef:x(e,`renderIcon`),hoverKeyRef:o,keyboardKeyRef:s,lastToggledSubmenuKeyRef:l,pendingKeyPathRef:d,activeKeyPathRef:f,animatedRef:x(e,`animated`),mergedShowRef:n,nodePropsRef:x(e,`nodeProps`),renderOptionRef:x(e,`renderOption`),menuPropsRef:x(e,`menuProps`),doSelect:S,doUpdateShow:C}),_(n,t=>{!e.animated&&!t&&w()});function S(t,n){let{onSelect:r}=e;r&&G(r,t,n)}function C(n){let{"onUpdate:show":r,onUpdateShow:i}=e;r&&G(r,n),i&&G(i,n),t.value=n}function w(){o.value=null,s.value=null,l.value=null}function T(){C(!1)}function E(){M(`left`)}function D(){M(`right`)}function O(){M(`up`)}function k(){M(`down`)}function A(){let e=j();e?.isLeaf&&n.value&&(S(e.key,e.rawNode),C(!1))}function j(){let{value:e}=i,{value:t}=u;return!e||t===null?null:e.getNode(t)??null}function M(e){let{value:t}=u,{value:{getFirstAvailableNode:n}}=i,r=null;if(t===null){let e=n();e!==null&&(r=e.key)}else{let t=j();if(t){let n;switch(e){case`down`:n=t.getNext();break;case`up`:n=t.getPrev();break;case`right`:n=t.getChild();break;case`left`:n=t.getParent();break}n&&(r=n.key)}}r!==null&&(o.value=null,s.value=r)}let N=r(()=>{let{inverted:t}=e,n=v.value,{common:{cubicBezierEaseInOut:r},self:i}=b.value,{padding:a,dividerColor:o,borderRadius:s,optionOpacityDisabled:c,[W(`optionIconSuffixWidth`,n)]:l,[W(`optionSuffixWidth`,n)]:u,[W(`optionIconPrefixWidth`,n)]:d,[W(`optionPrefixWidth`,n)]:f,[W(`fontSize`,n)]:p,[W(`optionHeight`,n)]:m,[W(`optionIconSize`,n)]:h}=i,g={"--n-bezier":r,"--n-font-size":p,"--n-padding":a,"--n-border-radius":s,"--n-option-height":m,"--n-option-prefix-width":f,"--n-option-icon-prefix-width":d,"--n-option-suffix-width":u,"--n-option-icon-suffix-width":l,"--n-option-icon-size":h,"--n-divider-color":o,"--n-option-opacity-disabled":c};return t?(g[`--n-color`]=i.colorInverted,g[`--n-option-color-hover`]=i.optionColorHoverInverted,g[`--n-option-color-active`]=i.optionColorActiveInverted,g[`--n-option-text-color`]=i.optionTextColorInverted,g[`--n-option-text-color-hover`]=i.optionTextColorHoverInverted,g[`--n-option-text-color-active`]=i.optionTextColorActiveInverted,g[`--n-option-text-color-child-active`]=i.optionTextColorChildActiveInverted,g[`--n-prefix-color`]=i.prefixColorInverted,g[`--n-suffix-color`]=i.suffixColorInverted,g[`--n-group-header-text-color`]=i.groupHeaderTextColorInverted):(g[`--n-color`]=i.color,g[`--n-option-color-hover`]=i.optionColorHover,g[`--n-option-color-active`]=i.optionColorActive,g[`--n-option-text-color`]=i.optionTextColor,g[`--n-option-text-color-hover`]=i.optionTextColorHover,g[`--n-option-text-color-active`]=i.optionTextColorActive,g[`--n-option-text-color-child-active`]=i.optionTextColorChildActive,g[`--n-prefix-color`]=i.prefixColor,g[`--n-suffix-color`]=i.suffixColor,g[`--n-group-header-text-color`]=i.groupHeaderTextColor),g}),P=h?ee(`dropdown`,r(()=>`${v.value[0]}${e.inverted?`i`:``}`),N,e):void 0;return{mergedClsPrefix:m,mergedTheme:b,mergedSize:v,tmNodes:a,mergedShow:n,handleAfterLeave:()=>{e.animated&&w()},doUpdateShow:C,cssVars:h?void 0:N,themeClass:P?.themeClass,onRender:P?.onRender}},render(){let e=(e,t,n,r,i)=>{var a;let{mergedClsPrefix:o,menuProps:s}=this;(a=this.onRender)==null||a.call(this);let c=s?.(void 0,this.tmNodes.map(e=>e.rawNode))||{},d={ref:Me(t),class:[e,`${o}-dropdown`,`${o}-dropdown--${this.mergedSize}-size`,this.themeClass],clsPrefix:o,tmNodes:this.tmNodes,style:[...n,this.cssVars],showArrow:this.showArrow,arrowStyle:this.arrowStyle,scrollable:this.scrollable,onMouseenter:r,onMouseleave:i};return u(Je,l(this.$attrs,d,c))},{mergedTheme:t}=this,n={show:this.mergedShow,theme:t.peers.Popover,themeOverrides:t.peerOverrides.Popover,internalOnAfterLeave:this.handleAfterLeave,internalRenderBody:e,onUpdateShow:this.doUpdateShow,"onUpdate:show":void 0};return u(ue,Object.assign({},ae(this.$props,Ze),n),{trigger:()=>{var e;return(e=this.$slots).default?.call(e)}})}}),$e={class:`chat-input-area`},et={key:0,class:`attachment-previews`},tt=[`src`,`alt`],nt={key:1,class:`attachment-file`},rt={class:`file-name`},it={class:`file-size`},at=[`onClick`],ot=[`placeholder`],st={class:`input-actions`},ct=F(w({__name:`ChatInput`,setup(n){let o=xe(),{t:c}=P(),l=y(``),u=y(),f=y(),m=y([]),h=y(!1),g=y(0),_=y(!1),v=r(()=>l.value.trim()||m.value.length>0);function b(e){if(m.value.find(t=>t.name===e.name))return;let t=Date.now().toString(36)+Math.random().toString(36).slice(2,8),n=URL.createObjectURL(e);m.value.push({id:t,name:e.name,type:e.type,size:e.size,url:n,file:e})}function x(){f.value?.click()}function S(e){let t=e.target;if(t.files){for(let e of t.files)b(e);t.value=``}}function w(e){let t=Array.from(e.clipboardData?.items||[]).filter(e=>e.type.startsWith(`image/`));if(t.length){e.preventDefault();for(let e of t){let t=e.getAsFile();if(!t)continue;let n=e.type.split(`/`)[1]||`png`;b(new File([t],`pasted-${Date.now()}.${n}`,{type:e.type}))}}}function O(e){e.preventDefault()}function j(e){e.preventDefault(),e.dataTransfer?.types.includes(`Files`)&&(g.value++,h.value=!0)}function F(){g.value--,g.value<=0&&(g.value=0,h.value=!1)}function I(e){e.preventDefault(),g.value=0,h.value=!1;let t=Array.from(e.dataTransfer?.files||[]);if(t.length){for(let e of t)b(e);u.value?.focus()}}function L(){let e=l.value.trim();!e&&m.value.length===0||(o.sendMessage(e,m.value.length>0?m.value:void 0),l.value=``,m.value=[],u.value&&(u.value.style.height=`auto`))}function R(){_.value=!0}function z(){requestAnimationFrame(()=>{_.value=!1})}function B(e){return _.value||e.isComposing||e.keyCode===229}function V(e){e.key!==`Enter`||e.shiftKey||B(e)||(e.preventDefault(),L())}function H(e){let t=e.target;t.style.height=`auto`,t.style.height=Math.min(t.scrollHeight,100)+`px`}function U(e){let t=m.value.findIndex(t=>t.id===e);t!==-1&&(URL.revokeObjectURL(m.value[t].url),m.value.splice(t,1))}function W(e){return e<1024?e+` B`:e<1024*1024?(e/1024).toFixed(1)+` KB`:(e/(1024*1024)).toFixed(1)+` MB`}function G(e){return e.startsWith(`image/`)}return(n,r)=>(s(),i(`div`,$e,[m.value.length>0?(s(),i(`div`,et,[(s(!0),i(N,null,A(m.value,e=>(s(),i(`div`,{key:e.id,class:D([`attachment-preview`,{image:G(e.type)}])},[G(e.type)?(s(),i(`img`,{key:0,src:e.url,alt:e.name,class:`attachment-thumb`},null,8,tt)):(s(),i(`div`,nt,[r[2]||=M(`svg`,{width:`20`,height:`20`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`1.5`},[M(`path`,{d:`M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z`}),M(`polyline`,{points:`14 2 14 8 20 8`})],-1),M(`span`,rt,C(e.name),1),M(`span`,it,C(W(e.size)),1)])),M(`button`,{class:`attachment-remove`,onClick:t=>U(e.id)},[...r[3]||=[M(`svg`,{width:`12`,height:`12`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`2`},[M(`line`,{x1:`18`,y1:`6`,x2:`6`,y2:`18`}),M(`line`,{x1:`6`,y1:`6`,x2:`18`,y2:`18`})],-1)]],8,at)],2))),128))])):a(``,!0),M(`div`,{class:D([`input-wrapper`,{"drag-over":h.value}]),onDragover:O,onDragenter:j,onDragleave:F,onDrop:I},[M(`input`,{ref_key:`fileInputRef`,ref:f,type:`file`,multiple:``,class:`file-input-hidden`,onChange:S},null,544),e(M(`textarea`,{ref_key:`textareaRef`,ref:u,"onUpdate:modelValue":r[0]||=e=>l.value=e,class:`input-textarea`,placeholder:k(c)(`chat.inputPlaceholder`),rows:`1`,onKeydown:V,onCompositionstart:R,onCompositionend:z,onInput:H,onPaste:w},null,40,ot),[[E,l.value]]),M(`div`,st,[t(k(Se),{trigger:`hover`},{trigger:d(()=>[t(k($),{quaternary:``,size:`small`,onClick:x,circle:``},{icon:d(()=>[...r[4]||=[M(`svg`,{width:`16`,height:`16`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`1.5`},[M(`path`,{d:`M21.44 11.05l-9.19 9.19a6 6 0 0 1-8.49-8.49l9.19-9.19a4 4 0 0 1 5.66 5.66l-9.2 9.19a2 2 0 0 1-2.83-2.83l8.49-8.48`})],-1)]]),_:1})]),default:d(()=>[T(` `+C(k(c)(`chat.attachFiles`)),1)]),_:1}),k(o).isStreaming?(s(),p(k($),{key:0,size:`small`,type:`error`,onClick:r[1]||=e=>k(o).stopStreaming()},{default:d(()=>[T(C(k(c)(`chat.stop`)),1)]),_:1})):a(``,!0),t(k($),{size:`small`,type:`primary`,disabled:!v.value||k(o).isStreaming,onClick:L},{icon:d(()=>[...r[5]||=[M(`svg`,{width:`16`,height:`16`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`2`},[M(`line`,{x1:`22`,y1:`2`,x2:`11`,y2:`13`}),M(`polygon`,{points:`22 2 15 22 11 13 2 9 22 2`})],-1)]]),default:d(()=>[T(` `+C(k(c)(`chat.send`)),1)]),_:1},8,[`disabled`])])],34)]))}}),[[`__scopeId`,`data-v-4c2b3ca2`]]),lt={key:1,width:`12`,height:`12`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`1.5`,class:`tool-icon`},ut={class:`tool-name`},dt={key:2,class:`tool-preview`},ft={key:3,class:`tool-spinner`},pt={key:4,class:`tool-error-badge`},mt={key:0,class:`tool-details`},ht={key:0,class:`tool-detail-section`},gt={class:`tool-detail-label`},_t={class:`tool-detail-code`},vt={key:1,class:`tool-detail-section`},yt={class:`tool-detail-label`},bt={class:`tool-detail-code`},xt={key:1,class:`msg-body`},St={key:0,src:I,alt:`Hermes`,class:`msg-avatar`},Ct={key:0,class:`msg-attachments`},wt=[`src`,`alt`],Tt={key:1,class:`msg-attachment-file`},Et={class:`att-name`},Dt={class:`att-size`},Ot={key:2,class:`streaming-dots`},kt={class:`message-time`},At=F(w({__name:`MessageItem`,props:{message:{}},setup(e){let t=e,{t:n}=P(),o=r(()=>t.message.role===`system`),c=y(!1),l=r(()=>new Date(t.message.timestamp).toLocaleTimeString([],{hour:`2-digit`,minute:`2-digit`}));function u(e){return e.startsWith(`image/`)}function d(e){return e<1024?e+` B`:e<1024*1024?(e/1024).toFixed(1)+` KB`:(e/(1024*1024)).toFixed(1)+` MB`}let f=r(()=>(t.message.attachments?.length??0)>0),m=r(()=>!!(t.message.toolArgs||t.message.toolResult)),h=r(()=>{if(!t.message.toolArgs)return``;try{return JSON.stringify(JSON.parse(t.message.toolArgs),null,2)}catch{return t.message.toolArgs}}),g=r(()=>{if(!t.message.toolResult)return``;try{let e=JSON.parse(t.message.toolResult),r=JSON.stringify(e,null,2);return r.length>2e3?r.slice(0,2e3)+`
|
|
126
|
-
`+n(`chat.truncated`):r}catch{let e=t.message.toolResult;return e.length>2e3?e.slice(0,2e3)+`
|
|
127
|
-
`+n(`chat.truncated`):e}});return(t,r)=>(s(),i(`div`,{class:D([`message`,[e.message.role]])},[e.message.role===`tool`?(s(),i(N,{key:0},[M(`div`,{class:D([`tool-line`,{expandable:m.value}]),onClick:r[0]||=e=>m.value&&(c.value=!c.value)},[m.value?(s(),i(`svg`,{key:0,width:`10`,height:`10`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`2`,class:D([`tool-chevron`,{rotated:c.value}])},[...r[1]||=[M(`polyline`,{points:`9 18 15 12 9 6`},null,-1)]],2)):(s(),i(`svg`,lt,[...r[2]||=[M(`path`,{d:`M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.77-3.77a6 6 0 0 1-7.94 7.94l-6.91 6.91a2.12 2.12 0 0 1-3-3l6.91-6.91a6 6 0 0 1 7.94-7.94l-3.76 3.76z`},null,-1)]])),M(`span`,ut,C(e.message.toolName),1),e.message.toolPreview&&!c.value?(s(),i(`span`,dt,C(e.message.toolPreview),1)):a(``,!0),e.message.toolStatus===`running`?(s(),i(`span`,ft)):a(``,!0),e.message.toolStatus===`error`?(s(),i(`span`,pt,C(k(n)(`chat.error`)),1)):a(``,!0)],2),c.value&&m.value?(s(),i(`div`,mt,[h.value?(s(),i(`div`,ht,[M(`div`,gt,C(k(n)(`chat.arguments`)),1),M(`pre`,_t,C(h.value),1)])):a(``,!0),g.value?(s(),i(`div`,vt,[M(`div`,yt,C(k(n)(`chat.result`)),1),M(`pre`,bt,C(g.value),1)])):a(``,!0)])):a(``,!0)],64)):(s(),i(`div`,xt,[e.message.role===`assistant`?(s(),i(`img`,St)):a(``,!0),M(`div`,{class:D([`msg-content`,e.message.role])},[M(`div`,{class:D([`message-bubble`,{system:o.value}])},[f.value?(s(),i(`div`,Ct,[(s(!0),i(N,null,A(e.message.attachments,e=>(s(),i(`div`,{key:e.id,class:D([`msg-attachment`,{image:u(e.type)}])},[u(e.type)&&e.url?(s(),i(`img`,{key:0,src:e.url,alt:e.name,class:`msg-attachment-thumb`},null,8,wt)):(s(),i(`div`,Tt,[r[3]||=M(`svg`,{width:`16`,height:`16`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`1.5`},[M(`path`,{d:`M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z`}),M(`polyline`,{points:`14 2 14 8 20 8`})],-1),M(`span`,Et,C(e.name),1),M(`span`,Dt,C(d(e.size)),1)]))],2))),128))])):a(``,!0),e.message.content?(s(),p(ke,{key:1,content:e.message.content},null,8,[`content`])):a(``,!0),e.message.isStreaming&&!e.message.content?(s(),i(`span`,Ot,[...r[4]||=[M(`span`,null,null,-1),M(`span`,null,null,-1),M(`span`,null,null,-1)]])):a(``,!0)],2),M(`div`,kt,C(l.value),1)],2)]))],2))}}),[[`__scopeId`,`data-v-5923b714`]]),jt=`/assets/thinking-light-BjeGd2gJ.mp4`,Mt=`/assets/thinking-dark-yYkYRZLs.mp4`,Nt={key:0,class:`empty-state`},Pt={key:0,class:`streaming-indicator`},Ft=[`src`],It={key:0,class:`tool-calls-panel`},Lt={class:`tool-call-name`},Rt={key:0,class:`tool-call-preview`},zt={key:1,class:`tool-call-spinner`},Bt={key:2,class:`tool-call-error`},Vt=F(w({__name:`MessageList`,setup(e){let n=xe(),{t:o}=P(),{isDark:c}=Te(),l=y(),u=r(()=>n.messages.filter(e=>e.role!==`tool`)),m=r(()=>{let e=n.messages,t=-1;for(let n=e.length-1;n>=0;n--)if(e[n].role===`user`){t=n;break}return[...e.filter((e,n)=>e.role===`tool`&&n>t)].reverse()});function h(e=200){let t=l.value;return t?t.scrollHeight-t.scrollTop-t.clientHeight<e:!0}function g(){f(()=>{l.value&&(l.value.scrollTop=l.value.scrollHeight)})}return _(()=>n.activeSessionId,e=>{e&&g()},{immediate:!0}),_(()=>n.isRunActive,e=>{e&&g()}),_(()=>n.messages[n.messages.length-1]?.content,()=>{if(!n.isStreaming){g();return}h()&&g()}),_(m,()=>{if(!n.isStreaming){g();return}h()&&g()}),(e,r)=>(s(),i(`div`,{ref_key:`listRef`,ref:l,class:`message-list`},[k(n).messages.length===0?(s(),i(`div`,Nt,[r[0]||=M(`img`,{src:`/logo.png`,alt:`Hermes`,class:`empty-logo`},null,-1),M(`p`,null,C(k(o)(`chat.emptyState`)),1)])):a(``,!0),(s(!0),i(N,null,A(u.value,e=>(s(),p(At,{key:e.id,message:e},null,8,[`message`]))),128)),t(b,{name:`fade`},{default:d(()=>[k(n).isRunActive?(s(),i(`div`,Pt,[M(`video`,{src:k(c)?k(Mt):k(jt),autoplay:``,loop:``,muted:``,playsinline:``,class:`thinking-video`},null,8,Ft),m.value.length>0?(s(),i(`div`,It,[(s(!0),i(N,null,A(m.value,e=>(s(),i(`div`,{key:e.id,class:`tool-call-item`},[r[1]||=M(`svg`,{width:`12`,height:`12`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`1.5`,class:`tool-call-icon`},[M(`path`,{d:`M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.77-3.77a6 6 0 0 1-7.94 7.94l-6.91 6.91a2.12 2.12 0 0 1-3-3l6.91-6.91a6 6 0 0 1 7.94-7.94l-3.76 3.76z`})],-1),M(`span`,Lt,C(e.toolName),1),e.toolPreview?(s(),i(`span`,Rt,C(e.toolPreview),1)):a(``,!0),e.toolStatus===`running`?(s(),i(`span`,zt)):a(``,!0),e.toolStatus===`error`?(s(),i(`span`,Bt,C(k(o)(`chat.error`)),1)):a(``,!0)]))),128))])):a(``,!0)])):a(``,!0)]),_:1})],512))}}),[[`__scopeId`,`data-v-9cc7b1be`]]),Ht={class:`chat-panel`},Ut={class:`session-list-header`},Wt={key:0,class:`session-list-title`},Gt={class:`session-list-actions`},Kt={key:0,class:`session-items`},qt={key:0,class:`session-loading`},Jt={key:1,class:`session-empty`},Yt=[`onClick`],Xt={class:`session-group-label`},Zt={class:`session-group-count`},Qt=[`onClick`,`onContextmenu`],$t={class:`session-item-content`},en={class:`session-item-title`},tn={class:`session-item-meta`},nn={key:0,class:`session-item-model`},rn={class:`session-item-time`},an={class:`chat-main`},on={class:`chat-header`},sn={class:`header-left`},cn={class:`header-session-title`},ln={key:0,class:`source-badge`},un={class:`header-actions`},dn={key:0,class:`context-info`},fn=F(w({__name:`ChatPanel`,setup(e){let n=xe(),o=Ce(),{t:c}=P(),l=y(typeof window>`u`||!window.matchMedia(`(max-width: 768px)`).matches),u=null;function h(e){n.switchSession(e),u?.matches&&(l.value=!1)}function b(e){e.matches&&l.value&&(l.value=!1)}m(()=>{u=window.matchMedia(`(max-width: 768px)`),b(u),u.addEventListener(`change`,b)}),g(()=>{u?.removeEventListener(`change`,b)});let x=y(!1),w=y(``),E=y(null),O=y(null),j=y(new Set(JSON.parse(localStorage.getItem(`hermes_collapsed_groups`)||`[]`))),F={telegram:`Telegram`,api_server:`API Server`,cli:`CLI`,discord:`Discord`,slack:`Slack`,matrix:`Matrix`,whatsapp:`WhatsApp`,signal:`Signal`,email:`Email`,sms:`SMS`,dingtalk:`DingTalk`,feishu:`Feishu`,wecom:`WeCom`,weixin:`WeChat`,bluebubbles:`iMessage`,mattermost:`Mattermost`,cron:`Cron`};function I(e){return e?F[e]||e:``}function L(e){return e===`api_server`?-1:e===`cron`?999:0}let R=r(()=>{let e=[...n.sessions].sort((e,t)=>t.createdAt-e.createdAt),t=new Map;for(let n of e){let e=n.source||``;t.has(e)||t.set(e,[]),t.get(e).push(n)}return[...t.keys()].sort((e,t)=>{let n=L(e),r=L(t);return n===r?e.localeCompare(t):n-r}).map(e=>({source:e,label:e?I(e):c(`chat.other`),sessions:t.get(e)}))});function z(e){if(!j.value.has(e))j.value=new Set([...j.value,e]);else{j.value=new Set(R.value.map(e=>e.source).filter(t=>t!==e));let t=R.value.find(t=>t.source===e);t?.sessions.length&&n.switchSession(t.sessions[0].id)}localStorage.setItem(`hermes_collapsed_groups`,JSON.stringify([...j.value]))}_(R,e=>{if(localStorage.getItem(`hermes_collapsed_groups`)!==null){let e=n.activeSession?.source;e&&j.value.has(e)&&(j.value=new Set([...j.value].filter(t=>t!==e)),localStorage.setItem(`hermes_collapsed_groups`,JSON.stringify([...j.value])));return}j.value=new Set(e.slice(1).map(e=>e.source)),localStorage.setItem(`hermes_collapsed_groups`,JSON.stringify([...j.value]))},{once:!0});let B=r(()=>n.activeSession?.title||c(`chat.newChat`)),V=r(()=>(n.activeSession?.inputTokens??0)+(n.activeSession?.outputTokens??0)),H={"claude-opus-4":2e5,"claude-sonnet-4":2e5,"claude-haiku-4":2e5,"claude-3.5-sonnet":2e5,"claude-3.5-haiku":2e5,"claude-3-opus":2e5,"claude-3-sonnet":2e5,"claude-3-haiku":2e5,"gpt-4o":128e3,"gpt-4o-mini":128e3,"gpt-4-turbo":128e3,"gpt-4":8192,"gpt-3.5-turbo":16385,o1:2e5,"o1-mini":128e3,o3:2e5,"o3-mini":2e5,"o4-mini":2e5,"deepseek-chat":65536,"deepseek-reasoner":65536,"gemini-2.5-pro":1e6,"gemini-2.5-flash":1e6,"gemini-2.0-flash":1e6,"glm-4-plus":128e3,"glm-4":128e3,"qwen-max":128e3,"qwen-plus":128e3,"qwen-turbo":128e3},U=r(()=>{let e=n.activeSession?.model||``;for(let[t,n]of Object.entries(H))if(e.includes(t))return n;return null});function W(e){return e>=1e6?(e/1e6).toFixed(1)+`M`:e>=1e3?(e/1e3).toFixed(1)+`k`:String(e)}let G=r(()=>n.activeSession?.source||``);function K(){n.newChat()}function q(e){let t=e||n.activeSessionId;t&&(navigator.clipboard.writeText(t),o.success(c(`common.copied`)))}function J(e){n.deleteSession(e),o.success(c(`chat.sessionDeleted`))}function ee(e){let t=new Date(e),n=new Date;return t.toDateString()===n.toDateString()?t.toLocaleTimeString([],{hour:`2-digit`,minute:`2-digit`}):t.toLocaleDateString([],{month:`short`,day:`numeric`})}let te=r(()=>[{label:c(`chat.rename`),key:`rename`},{label:c(`chat.copySessionId`),key:`copy-id`}]),Y=y(null);function ne(e,t){e.preventDefault(),Y.value=t,X.value=!0,Z.value=e.clientX,Q.value=e.clientY}let X=y(!1),Z=y(0),Q=y(0);function re(e){if(X.value=!1,Y.value){if(e===`copy-id`)q(Y.value);else if(e===`rename`){let e=n.sessions.find(e=>e.id===Y.value);E.value=Y.value,w.value=e?.title||``,x.value=!0,f(()=>{O.value?.focus()})}}}function ie(){X.value=!1}async function ae(){if(!(!E.value||!w.value.trim())){if(await Oe(E.value,w.value.trim())){let e=n.sessions.find(e=>e.id===E.value);e&&(e.title=w.value.trim()),n.activeSession?.id===E.value&&(n.activeSession.title=w.value.trim()),o.success(c(`chat.renamed`))}else o.error(c(`chat.renameFailed`));x.value=!1}}return(e,r)=>(s(),i(`div`,Ht,[M(`div`,{class:D([`session-backdrop`,{active:l.value}]),onClick:r[0]||=e=>l.value=!1},null,2),M(`aside`,{class:D([`session-list`,{collapsed:!l.value}])},[M(`div`,Ut,[l.value?(s(),i(`span`,Wt,C(k(c)(`chat.sessions`)),1)):a(``,!0),M(`div`,Gt,[M(`button`,{class:`session-close-btn`,onClick:r[1]||=e=>l.value=!1},[...r[7]||=[M(`svg`,{width:`14`,height:`14`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`2`},[M(`line`,{x1:`18`,y1:`6`,x2:`6`,y2:`18`}),M(`line`,{x1:`6`,y1:`6`,x2:`18`,y2:`18`})],-1)]]),t(k($),{quaternary:``,size:`tiny`,onClick:K,circle:``},{icon:d(()=>[...r[8]||=[M(`svg`,{width:`14`,height:`14`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`2`},[M(`line`,{x1:`12`,y1:`5`,x2:`12`,y2:`19`}),M(`line`,{x1:`5`,y1:`12`,x2:`19`,y2:`12`})],-1)]]),_:1})])]),l.value?(s(),i(`div`,Kt,[k(n).isLoadingSessions&&k(n).sessions.length===0?(s(),i(`div`,qt,C(k(c)(`common.loading`)),1)):k(n).sessions.length===0?(s(),i(`div`,Jt,C(k(c)(`chat.noSessions`)),1)):a(``,!0),(s(!0),i(N,null,A(R.value,e=>(s(),i(N,{key:e.source},[M(`div`,{class:`session-group-header`,onClick:t=>z(e.source)},[(s(),i(`svg`,{width:`10`,height:`10`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`2`,class:D([`group-chevron`,{collapsed:j.value.has(e.source)}])},[...r[9]||=[M(`polyline`,{points:`9 18 15 12 9 6`},null,-1)]],2)),M(`span`,Xt,C(e.label),1),M(`span`,Zt,C(e.sessions.length),1)],8,Yt),j.value.has(e.source)?a(``,!0):(s(!0),i(N,{key:0},A(e.sessions,e=>(s(),i(`button`,{key:e.id,class:D([`session-item`,{active:e.id===k(n).activeSessionId}]),onClick:t=>h(e.id),onContextmenu:t=>ne(t,e.id)},[M(`div`,$t,[M(`span`,en,C(e.title),1),M(`span`,tn,[e.model?(s(),i(`span`,nn,C(e.model),1)):a(``,!0),M(`span`,rn,C(ee(e.createdAt)),1)])]),e.id!==k(n).activeSessionId||k(n).sessions.length>1?(s(),p(k(we),{key:0,onPositiveClick:t=>J(e.id)},{trigger:d(()=>[M(`button`,{class:`session-item-delete`,onClick:r[2]||=v(()=>{},[`stop`])},[...r[10]||=[M(`svg`,{width:`12`,height:`12`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`2`},[M(`line`,{x1:`18`,y1:`6`,x2:`6`,y2:`18`}),M(`line`,{x1:`6`,y1:`6`,x2:`18`,y2:`18`})],-1)]])]),default:d(()=>[T(` `+C(k(c)(`chat.deleteSession`)),1)]),_:1},8,[`onPositiveClick`])):a(``,!0)],42,Qt))),128))],64))),128))])):a(``,!0)],2),t(k(Qe),{placement:`bottom-start`,trigger:`manual`,x:Z.value,y:Q.value,options:te.value,show:X.value,onSelect:re,onClickoutside:ie},null,8,[`x`,`y`,`options`,`show`]),t(k(_e),{show:x.value,"onUpdate:show":r[4]||=e=>x.value=e,preset:`dialog`,title:k(c)(`chat.renameSession`),"positive-text":k(c)(`common.ok`),"negative-text":k(c)(`common.cancel`),onPositiveClick:ae},{default:d(()=>[t(k(ve),{ref_key:`renameInputRef`,ref:O,value:w.value,"onUpdate:value":r[3]||=e=>w.value=e,placeholder:k(c)(`chat.enterNewTitle`),onKeydown:S(ae,[`enter`])},null,8,[`value`,`placeholder`])]),_:1},8,[`show`,`title`,`positive-text`,`negative-text`]),M(`div`,an,[M(`header`,on,[M(`div`,sn,[t(k($),{quaternary:``,size:`small`,onClick:r[5]||=e=>l.value=!l.value,circle:``},{icon:d(()=>[...r[11]||=[M(`svg`,{width:`16`,height:`16`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`1.5`},[M(`rect`,{x:`3`,y:`3`,width:`7`,height:`7`}),M(`rect`,{x:`14`,y:`3`,width:`7`,height:`7`}),M(`rect`,{x:`3`,y:`14`,width:`7`,height:`7`}),M(`rect`,{x:`14`,y:`14`,width:`7`,height:`7`})],-1)]]),_:1}),M(`span`,cn,C(B.value),1),G.value?(s(),i(`span`,ln,C(I(G.value)),1)):a(``,!0)]),M(`div`,un,[t(k(Se),{trigger:`hover`},{trigger:d(()=>[t(k($),{quaternary:``,size:`small`,onClick:r[6]||=e=>q(),circle:``},{icon:d(()=>[...r[12]||=[M(`svg`,{width:`14`,height:`14`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`1.5`},[M(`rect`,{x:`9`,y:`9`,width:`13`,height:`13`,rx:`2`,ry:`2`}),M(`path`,{d:`M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1`})],-1)]]),_:1})]),default:d(()=>[T(` `+C(k(c)(`chat.copySessionId`)),1)]),_:1}),t(k($),{size:`small`,onClick:K},{icon:d(()=>[...r[13]||=[M(`svg`,{width:`14`,height:`14`,viewBox:`0 0 24 24`,fill:`none`,stroke:`currentColor`,"stroke-width":`2`},[M(`line`,{x1:`12`,y1:`5`,x2:`12`,y2:`19`}),M(`line`,{x1:`5`,y1:`12`,x2:`19`,y2:`12`})],-1)]]),default:d(()=>[T(` `+C(k(c)(`chat.newChat`)),1)]),_:1})])]),t(Vt),U.value===null?a(``,!0):(s(),i(`div`,dn,[M(`span`,null,C(W(V.value))+` / `+C(W(U.value)),1)])),t(ct)])]))}}),[[`__scopeId`,`data-v-563d6965`]]),pn={class:`chat-view`},mn=F(w({__name:`ChatView`,setup(e){let n=Ee(),r=xe(),a=De();return m(async()=>{n.loadModels(),await a.fetchProfiles(),r.loadSessions()}),(e,n)=>(s(),i(`div`,pn,[t(fn)]))}}),[[`__scopeId`,`data-v-6dae3628`]]);export{mn as default};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{t as e}from"./app-BMobzABI.js";export{e as useAppStore};
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/app-Bqu9Uz-1.js","assets/app-BMobzABI.js","assets/router-Dj-Nmg7q.js","assets/pinia-Dp_b1vdW.js"])))=>i.map(i=>d[i]);
|
|
2
|
-
import{C as e,ct as t,i as n,n as r,o as i,r as a}from"./router-Dj-Nmg7q.js";import{n as o}from"./pinia-Dp_b1vdW.js";import{n as s,nt as c,s as l}from"./browser-CQRjhbaB.js";import{i as u}from"./Popover-mIRPCy7U.js";import{t as d}from"./app-BMobzABI.js";import{t as f}from"./profiles-CNTHYFZE.js";import{n as p,r as m,t as h}from"./sessions-C0kvgvBm.js";var g={padding:`4px 0`,optionIconSizeSmall:`14px`,optionIconSizeMedium:`16px`,optionIconSizeLarge:`16px`,optionIconSizeHuge:`18px`,optionSuffixWidthSmall:`14px`,optionSuffixWidthMedium:`14px`,optionSuffixWidthLarge:`16px`,optionSuffixWidthHuge:`16px`,optionIconSuffixWidthSmall:`32px`,optionIconSuffixWidthMedium:`32px`,optionIconSuffixWidthLarge:`36px`,optionIconSuffixWidthHuge:`36px`,optionPrefixWidthSmall:`14px`,optionPrefixWidthMedium:`14px`,optionPrefixWidthLarge:`16px`,optionPrefixWidthHuge:`16px`,optionIconPrefixWidthSmall:`36px`,optionIconPrefixWidthMedium:`36px`,optionIconPrefixWidthLarge:`40px`,optionIconPrefixWidthHuge:`40px`};function _(e){let{primaryColor:t,textColor2:n,dividerColor:r,hoverColor:i,popoverColor:a,invertedColor:o,borderRadius:s,fontSizeSmall:l,fontSizeMedium:u,fontSizeLarge:d,fontSizeHuge:f,heightSmall:p,heightMedium:m,heightLarge:h,heightHuge:_,textColor3:v,opacityDisabled:y}=e;return Object.assign(Object.assign({},g),{optionHeightSmall:p,optionHeightMedium:m,optionHeightLarge:h,optionHeightHuge:_,borderRadius:s,fontSizeSmall:l,fontSizeMedium:u,fontSizeLarge:d,fontSizeHuge:f,optionTextColor:n,optionTextColorHover:n,optionTextColorActive:t,optionTextColorChildActive:t,color:a,dividerColor:r,suffixColor:n,prefixColor:n,optionColorHover:i,optionColorActive:c(t,{alpha:.1}),groupHeaderTextColor:v,optionTextColorInverted:`#BBB`,optionTextColorHoverInverted:`#FFF`,optionTextColorActiveInverted:`#FFF`,optionTextColorChildActiveInverted:`#FFF`,colorInverted:o,dividerColorInverted:`#BBB`,suffixColorInverted:`#BBB`,prefixColorInverted:`#BBB`,optionColorHoverInverted:t,optionColorActiveInverted:t,groupHeaderTextColorInverted:`#AAA`,optionOpacityDisabled:y})}var v=l({name:`Dropdown`,common:s,peers:{Popover:u},self:_});function y(e){let{textColorBase:t,opacity1:n,opacity2:r,opacity3:i,opacity4:a,opacity5:o}=e;return{color:t,opacity1Depth:n,opacity2Depth:r,opacity3Depth:i,opacity4Depth:a,opacity5Depth:o}}var b={name:`Icon`,common:s,self:y};async function x(e){return i(`/api/hermes/v1/runs`,{method:`POST`,body:JSON.stringify(e)})}function S(e,t,r,i){let o=n(),s=a(),c=localStorage.getItem(`hermes_active_profile_name`),l=new URLSearchParams;s&&l.set(`token`,s),c&&c!==`default`&&l.set(`profile`,c);let u=l.toString(),d=`${o}/api/hermes/v1/runs/${e}/events${u?`?${u}`:``}`,f=!1,p=new EventSource(d);return p.onmessage=e=>{if(!f)try{let n=JSON.parse(e.data);t(n),(n.event===`run.completed`||n.event===`run.failed`)&&(f=!0,p.close(),r())}catch{t({event:`message`,delta:e.data})}},p.onerror=()=>{f||(f=!0,p.close(),i(Error(`SSE connection error`)))},{abort:()=>{f||(f=!0,p.close())}}}function C(){return Date.now().toString(36)+Math.random().toString(36).slice(2,8)}async function w(e){if(e.length===0)return[];let t=new FormData;for(let n of e)n.file&&t.append(`file`,n.file,n.name);let n=localStorage.getItem(`hermes_api_key`)||``,r=await fetch(`/upload`,{method:`POST`,body:t,headers:n?{Authorization:`Bearer ${n}`}:{}});if(!r.ok)throw Error(`Upload failed: ${r.status}`);return(await r.json()).files}function T(e){let t=new Map,n=new Map;for(let r of e)if(r.role===`assistant`&&r.tool_calls)for(let e of r.tool_calls)e.id&&(e.function?.name&&t.set(e.id,e.function.name),e.function?.arguments&&n.set(e.id,e.function.arguments));let r=[];for(let i of e){if(i.role===`assistant`&&i.tool_calls?.length&&!i.content?.trim()){for(let e of i.tool_calls)r.push({id:String(i.id)+`_`+e.id,role:`tool`,content:``,timestamp:Math.round(i.timestamp*1e3),toolName:e.function?.name||`tool`,toolArgs:e.function?.arguments||void 0,toolStatus:`done`});continue}if(i.role===`tool`){let e=i.tool_call_id||``,a=i.tool_name||t.get(e)||`tool`,o=n.get(e)||void 0,s=``;if(i.content)try{let e=JSON.parse(i.content);s=e.url||e.title||e.preview||e.summary||``}catch{s=i.content.slice(0,80)}let c=r.findIndex(t=>t.role===`tool`&&t.toolName===a&&!t.toolResult&&t.id.includes(`_`+e));c!==-1&&r.splice(c,1),r.push({id:String(i.id),role:`tool`,content:``,timestamp:Math.round(i.timestamp*1e3),toolName:a,toolArgs:o,toolPreview:typeof s==`string`&&s.slice(0,100)||void 0,toolResult:i.content||void 0,toolStatus:`done`});continue}r.push({id:String(i.id),role:i.role,content:i.content||``,timestamp:Math.round(i.timestamp*1e3)})}return r}function E(e){return{id:e.id,title:e.title||``,source:e.source||void 0,messages:[],createdAt:Math.round(e.started_at*1e3),updatedAt:Math.round((e.ended_at||e.started_at)*1e3),model:e.model,provider:e.billing_provider||``,messageCount:e.message_count,inputTokens:e.input_tokens,outputTokens:e.output_tokens}}var D=`hermes_active_session_`,O=`hermes_sessions_cache_v1_`,k=900*1e3,A=2e3,j=3;function M(){try{return f().activeProfileName||`default`}catch{return`default`}}function N(){return D+M()}function P(){return O+M()}function F(e){return`hermes_session_msgs_v1_${M()}_${e}_`}function I(e){return`hermes_in_flight_v1_${M()}_${e}`}function L(e){try{let t=localStorage.getItem(e);return t?JSON.parse(t):null}catch{return null}}function R(e,t){try{localStorage.setItem(e,JSON.stringify(t))}catch{}}function z(e){try{localStorage.removeItem(e)}catch{}}function B(e){return e.map(e=>e.attachments?.length?{...e,attachments:e.attachments.map(e=>({id:e.id,name:e.name,type:e.type,size:e.size,url:e.url}))}:e)}var V=o(`chat`,()=>{let n=t([]),i=t(null),a=t(new Map),o=e(()=>i.value!=null&&a.value.has(i.value)),s=t(!1),c=t(!1),l=t(new Set),u=e(()=>o.value||i.value!=null&&l.value.has(i.value)),f=new Map,g=new Map,_=t(null),v=e(()=>_.value?.messages||[]);function y(){R(P(),n.value.map(e=>({...e,messages:[]})))}function b(){let e=i.value;if(!e)return;let t=n.value.find(t=>t.id===e);t&&R(F(e),B(t.messages))}function D(e,t){R(I(e),{runId:t,startedAt:Date.now()})}function O(e){z(I(e))}function M(e){let t=L(I(e));return t?Date.now()-t.startedAt>k?(z(I(e)),null):t:null}function V(e){let t=f.get(e);t&&(clearInterval(t),f.delete(e)),g.delete(e),l.value=new Set([...l.value].filter(t=>t!==e))}function H(e){if(f.has(e))return;l.value=new Set([...l.value,e]);let t=setInterval(async()=>{if(a.value.has(e)){V(e);return}if(!M(e)){V(e);return}try{let t=await p(e);if(!t)return;let r=T(t.messages||[]),a=n.value.find(t=>t.id===e);if(!a)return;let o=a.messages,s=[...o].reverse().find(e=>e.role===`assistant`),c=[...r].reverse().find(e=>e.role===`assistant`),l=s?.content?.length??0,u=c?.content?.length??0,d=o.filter(e=>e.role===`user`).length,f=r.filter(e=>e.role===`user`).length,m=f>=d;if((f>d||f===d&&u>=l)&&(a.messages=r,a.inputTokens=t.input_tokens,a.outputTokens=t.output_tokens,t.title&&!a.title&&(a.title=t.title),e===i.value&&b()),!m)g.delete(e);else{let n=r[r.length-1],o=`${r.length}|${n?.content?.slice(-40)||``}|${n?.toolStatus||``}`,s=g.get(e);s&&s.sig===o?(s.stableTicks+=1,s.stableTicks>=j&&(a.messages=r,a.inputTokens=t.input_tokens,a.outputTokens=t.output_tokens,t.title&&(a.title=t.title),e===i.value&&b(),O(e),V(e))):g.set(e,{sig:o,stableTicks:0})}}catch{}},A);f.set(e,t)}async function U(){s.value=!0;try{let e=L(P());if(e?.length){n.value=e;let t=localStorage.getItem(N());if(t){let n=e.find(e=>e.id===t)||null;if(n){let e=L(F(t));e&&(n.messages=e),_.value=n,i.value=t}}}let t=(await m()).map(E),r=new Set(t.map(e=>e.id)),a=new Map(n.value.map(e=>[e.id,e.messages]));for(let e of t){let t=a.get(e.id);t&&t.length&&(e.messages=t)}n.value=[...n.value.filter(e=>!r.has(e.id)),...t],y();let o=i.value,s=o&&n.value.some(e=>e.id===o)?o:n.value[0]?.id;s&&await K(s)}catch(e){console.error(`Failed to load sessions:`,e)}finally{s.value=!1}}async function W(){let e=i.value;if(!e)return!1;try{let t=await p(e);if(!t)return!1;let r=n.value.find(t=>t.id===e);return r?(r.messages=T(t.messages||[]),r.inputTokens=t.input_tokens,r.outputTokens=t.output_tokens,t.title&&(r.title=t.title),b(),!0):!1}catch(e){return console.error(`Failed to refresh active session:`,e),!1}}function G(){let e={id:C(),title:``,source:`api_server`,messages:[],createdAt:Date.now(),updatedAt:Date.now()};return n.value.unshift(e),y(),e}async function K(e){if(i.value=e,localStorage.setItem(N(),e),_.value=n.value.find(t=>t.id===e)||null,_.value){if(!(_.value.messages.length>0)){let t=L(F(e));t?.length&&(_.value.messages=t)}_.value.messages.length===0&&(c.value=!0);try{let t=await p(e);if(t&&t.messages){let e=T(t.messages),n=_.value.messages,r=[...n].reverse().find(e=>e.role===`assistant`),i=[...e].reverse().find(e=>e.role===`assistant`),a=r?.content?.length??0,o=i?.content?.length??0,s=n.filter(e=>e.role===`user`).length,c=e.filter(e=>e.role===`user`).length;if((c>s||c===s&&o>=a)&&(_.value.messages=e),_.value.inputTokens=t.input_tokens,_.value.outputTokens=t.output_tokens,t.title)_.value.title=t.title;else if(!_.value.title){let e=_.value.messages.find(e=>e.role===`user`);if(e){let t=e.content.slice(0,40);_.value.title=t+(e.content.length>40?`...`:``)}}b()}}catch(e){console.error(`Failed to load session messages:`,e)}finally{c.value=!1}M(e)&&!a.value.has(e)&&H(e)}}function q(){if(o.value)return;let e=G();e.model=d().selectedModel||void 0,K(e.id)}async function J(e,t){if(_.value&&(_.value.model=e,_.value.provider=t||``,t)){let{useAppStore:n}=await r(async()=>{let{useAppStore:e}=await import(`./app-Bqu9Uz-1.js`);return{useAppStore:e}},__vite__mapDeps([0,1,2,3]));await n().switchModel(e,t)}}async function Y(e){await h(e),n.value=n.value.filter(t=>t.id!==e),z(F(e)),y(),i.value===e&&(n.value.length>0?await K(n.value[0].id):K(G().id))}function X(e){return n.value.find(t=>t.id===e)?.messages||[]}function Z(e,t){let r=n.value.find(t=>t.id===e);r&&r.messages.push(t)}function Q(e,t,r){let i=n.value.find(t=>t.id===e);if(!i)return;let a=i.messages.findIndex(e=>e.id===t);a!==-1&&(i.messages[a]={...i.messages[a],...r})}function $(e){let t=n.value.find(t=>t.id===e);if(t){if(!t.title){let e=t.messages.find(e=>e.role===`user`);if(e){let n=e.attachments?.length?e.attachments.map(e=>e.name).join(`, `):e.content;t.title=n.slice(0,40)+(n.length>40?`...`:``)}}t.updatedAt=Date.now()}}async function ee(e,t){if(!e.trim()&&!(t&&t.length>0)||o.value)return;_.value||K(G().id);let n=i.value;Z(n,{id:C(),role:`user`,content:e.trim(),timestamp:Date.now(),attachments:t&&t.length>0?t:void 0}),$(n),n===i.value&&(b(),y());try{let r=X(n).filter(e=>(e.role===`user`||e.role===`assistant`)&&e.content.trim()).map(e=>({role:e.role,content:e.content})),o=e.trim();if(t&&t.length>0){let e=(await w(t)).map(e=>`[File: ${e.name}](${e.path})`);o=o?o+`
|
|
3
|
-
|
|
4
|
-
`+e.join(`
|
|
5
|
-
`):e.join(`
|
|
6
|
-
`)}let s=d(),c=_.value?.model||s.selectedModel,l=await x({input:o,conversation_history:r,session_id:n,model:c||void 0}),u=l.run_id||l.id;if(!u){Z(n,{id:C(),role:`system`,content:`Error: startRun returned no run ID. Response: ${JSON.stringify(l)}`,timestamp:Date.now()});return}D(n,u),V(n);let f=()=>{a.value.delete(n),p&&=(clearTimeout(p),null)},p=null,m=()=>{n!==i.value||p||(p=setTimeout(()=>{p=null,b()},800))},h=S(u,e=>{switch(e.event){case`run.started`:break;case`message.delta`:{let t=X(n),r=t[t.length-1];r?.role===`assistant`&&r.isStreaming?r.content+=e.delta||``:Z(n,{id:C(),role:`assistant`,content:e.delta||``,timestamp:Date.now(),isStreaming:!0}),m();break}case`tool.started`:{let t=X(n),r=t[t.length-1];r?.isStreaming&&Q(n,r.id,{isStreaming:!1}),Z(n,{id:C(),role:`tool`,content:``,timestamp:Date.now(),toolName:e.tool||e.name,toolPreview:e.preview,toolStatus:`running`}),m();break}case`tool.completed`:{let e=X(n).filter(e=>e.role===`tool`&&e.toolStatus===`running`);if(e.length>0){let t=e[e.length-1];Q(n,t.id,{toolStatus:`done`})}m();break}case`run.completed`:{let e=X(n),t=e[e.length-1];t?.isStreaming&&Q(n,t.id,{isStreaming:!1}),f(),$(n),n===i.value&&b(),O(n),V(n);break}case`run.failed`:{let t=X(n),r=t[t.length-1];r?.isStreaming?Q(n,r.id,{isStreaming:!1,content:e.error?`Error: ${e.error}`:`Run failed`,role:`system`}):Z(n,{id:C(),role:`system`,content:e.error?`Error: ${e.error}`:`Run failed`,timestamp:Date.now()}),t.forEach((e,n)=>{e.role===`tool`&&e.toolStatus===`running`&&(t[n]={...e,toolStatus:`error`})}),f(),n===i.value&&b(),O(n),V(n);break}}},()=>{let e=X(n),t=e[e.length-1];t?.isStreaming&&Q(n,t.id,{isStreaming:!1}),f(),$(n)},e=>{console.warn(`SSE connection dropped, resyncing from server:`,e.message);let t=X(n),r=t[t.length-1];r?.isStreaming&&Q(n,r.id,{isStreaming:!1}),t.forEach((e,n)=>{e.role===`tool`&&e.toolStatus===`running`&&(t[n]={...e,toolStatus:`done`})}),f(),n===i.value&&W(),M(n)&&H(n)});a.value.set(n,h)}catch(e){Z(n,{id:C(),role:`system`,content:`Error: ${e.message}`,timestamp:Date.now()})}}function te(){let e=i.value;if(!e)return;let t=a.value.get(e);if(t){t.abort();let n=X(e),r=n[n.length-1];r?.isStreaming&&Q(e,r.id,{isStreaming:!1}),a.value.delete(e),O(e),V(e)}}return typeof document<`u`&&document.addEventListener(`visibilitychange`,()=>{document.visibilityState===`visible`&&i.value&&!o.value&&(W(),M(i.value)&&H(i.value))}),{sessions:n,activeSessionId:i,activeSession:_,messages:v,isStreaming:o,isRunActive:u,isLoadingSessions:s,isLoadingMessages:c,newChat:q,switchSession:K,switchSessionModel:J,deleteSession:Y,sendMessage:ee,stopStreaming:te,loadSessions:U,refreshActiveSession:W}});export{_ as a,v as i,b as n,y as r,V as t};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{F as e}from"./router-Dj-Nmg7q.js";import{Y as t}from"./browser-CQRjhbaB.js";import{s as n}from"./Modal-C5-Iw50K.js";function r(){let r=e(n,null);return r===null&&t(`use-dialog`,`No outer <n-dialog-provider /> founded.`),r}export{r as t};
|