orbitchat 2.2.8 → 2.2.10
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/bin/orbitchat.js +45 -36
- package/dist/assets/_basePickBy-0t-1TdXj-DH4J1m8V.js +1 -0
- package/dist/assets/_baseUniq-DZ7Bpu3I-Co9egLVD.js +1 -0
- package/dist/assets/{api-L84wIOvt.js → api-0NuHuopb.js} +1 -1
- package/dist/assets/arc-CsV8WDj2-C9VadXC6.js +1 -0
- package/dist/assets/{architectureDiagram-VXUJARFQ-BuSDV2Do-_okKpoAJ.js → architectureDiagram-VXUJARFQ-5Jt_APG9-BoVNR4UV.js} +3 -3
- package/dist/assets/{blockDiagram-VD42YOAC-jQHtez-j-rtzBv-vF.js → blockDiagram-VD42YOAC-DTiW7a-n-CSp1ALjf.js} +4 -4
- package/dist/assets/{c4Diagram-YG6GDRKO-_5giM-EA-DjRoFacG.js → c4Diagram-YG6GDRKO-DfrzrMnC-CkCuHyrT.js} +4 -4
- package/dist/assets/channel-C1GZ9yWj-DYugq-sa.js +1 -0
- package/dist/assets/{chunk-4BX2VUAB-BeuiUsbc-DN2rdYji.js → chunk-4BX2VUAB-DP6WsS5b-DmFzjHyq.js} +1 -1
- package/dist/assets/chunk-55IACEB6-DcZAWW2t-DPyoMeFz.js +1 -0
- package/dist/assets/{chunk-B4BG7PRW-CnUkcto7-DHe7ngzh.js → chunk-B4BG7PRW-BVaRFjbY-BdpIBFL7.js} +3 -3
- package/dist/assets/{chunk-DI55MBZ5-CSd59tsh-DFg8M9sN.js → chunk-DI55MBZ5-NwybRWU6-D93ibRgN.js} +4 -4
- package/dist/assets/{chunk-FMBD7UC4-C6VImbBX-ip_5_GPo.js → chunk-FMBD7UC4-D0AjqgJd-BqUKvjQH.js} +1 -1
- package/dist/assets/{chunk-QN33PNHL-DrWWTLTH-tpIkWiz1.js → chunk-QN33PNHL-cmS1bOzt-B1tGHIDu.js} +1 -1
- package/dist/assets/{chunk-QZHKN3VN-C6_I39By-ZQp0I6tE.js → chunk-QZHKN3VN-DehtyeGo-BsFo-AuY.js} +1 -1
- package/dist/assets/chunk-TZMSLE5B-BILiPuwH-DOft2nRu.js +1 -0
- package/dist/assets/classDiagram-2ON5EDUG-_7dtGwsA-C3Nhy3w6.js +1 -0
- package/dist/assets/classDiagram-v2-WZHVMYZB-_7dtGwsA-C3Nhy3w6.js +1 -0
- package/dist/assets/clone-D8_vOzkg-D9aZREI4.js +1 -0
- package/dist/assets/{cose-bilkent-S5V4N54A-DcyCVH6S-zMMT3oqX.js → cose-bilkent-S5V4N54A-CDJ5hD7Q-BcxkEWNp.js} +1 -1
- package/dist/assets/{dagre-6UL2VRFP-B799wmhr-DuXOlM7I.js → dagre-6UL2VRFP-D6cOp6Da-xpk1mIcg.js} +2 -2
- package/dist/assets/{diagram-PSM6KHXK-Dxp2wzKk-CmF_yeQm.js → diagram-PSM6KHXK-C0ItMhu6-BHHxSZE4.js} +1 -1
- package/dist/assets/diagram-QEK2KX5R-CEsgotfL-F-1j8qO7.js +43 -0
- package/dist/assets/{diagram-S2PKOQOG-tSpHqt0k-Dhi7ufxY.js → diagram-S2PKOQOG-B6d1S6_G-Zzv-O9xk.js} +1 -1
- package/dist/assets/{erDiagram-Q2GNP2WA-DF6ylQ7o-CjIoFnUJ.js → erDiagram-Q2GNP2WA-B-w3sS7V-2nanwMJ6.js} +4 -4
- package/dist/assets/{flowDiagram-NV44I4VS-BQUYJeB--D2fTwlvO.js → flowDiagram-NV44I4VS-DssRq_2c-BffMgd28.js} +7 -7
- package/dist/assets/ganttDiagram-JELNMOA3-IIlGW_kJ-Dxu3SgAH.js +267 -0
- package/dist/assets/gitGraphDiagram-NY62KEGX-D9Tl4KHH--tnJGvul.js +65 -0
- package/dist/assets/{graph-aRt77rZZ-Dq9dkNsk.js → graph-BZqzM_VI-BBLTPB3S.js} +1 -1
- package/dist/assets/{index-p0knuDQ9.js → index-DodYl3VC.js} +194 -166
- package/dist/assets/index-V1hWOL-o.css +1 -0
- package/dist/assets/{index-rW5EEHFR-Cm6Gxbor.js → index-rkYlv_42-Bg0V1tPP.js} +1 -1
- package/dist/assets/{infoDiagram-ER5ION4S-ozjqEnsq-D0PwL9B_.js → infoDiagram-WHAUD3N6-CjmJiQNf-YInQHfWX.js} +1 -1
- package/dist/assets/{journeyDiagram-XKPGCS4Q-C6JuEafR-BSuib8Wf.js → journeyDiagram-XKPGCS4Q-D6S72Oe9-iYQx9Mof.js} +3 -3
- package/dist/assets/{kanban-definition-3W4ZIXB7-Ci4U3NR--Bxb6Yi8G.js → kanban-definition-3W4ZIXB7--JZpAUKg-C2LOftDm.js} +6 -6
- package/dist/assets/{layout-BKjRgLFe-WihuzEZg.js → layout-DHdXRoe5-CY2O2SIL.js} +1 -1
- package/dist/assets/{mindmap-definition-VGOIOE7T-DveejCtl-DXLxEnp4.js → mindmap-definition-VGOIOE7T-I33kejqp-b66KO8Rt.js} +3 -3
- package/dist/assets/{pieDiagram-ADFJNKIX-DAbSGtae-BruonBFZ.js → pieDiagram-ADFJNKIX-69ywrIzx-ceXn0a9Q.js} +3 -3
- package/dist/assets/{quadrantDiagram-AYHSOK5B-DnnzUQMW-DzWXEz5-.js → quadrantDiagram-AYHSOK5B-CySBol3o-CltGpVzM.js} +4 -4
- package/dist/assets/{requirementDiagram-UZGBJVZJ-BB9jagBx-q21wBQ9N.js → requirementDiagram-UZGBJVZJ-BL-LwQUQ-DM_SSY8F.js} +4 -4
- package/dist/assets/{sankeyDiagram-TZEHDZUN-BttZx2-h-Cr53tHP7.js → sankeyDiagram-TZEHDZUN-D3rAZVzY-BAAQukCD.js} +1 -1
- package/dist/assets/{sequenceDiagram-WL72ISMW-DA6yVs26-B4W8xwkp.js → sequenceDiagram-WL72ISMW-BfBBVBjh-C993xDQ0.js} +1 -1
- package/dist/assets/{stateDiagram-FKZM4ZOC-BD8xEcbc-BWOiPxZu.js → stateDiagram-FKZM4ZOC-CioTL1ci-eXs9ZVMI.js} +1 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-CNXUSYFj-C88PWSf5.js +1 -0
- package/dist/assets/{timeline-definition-IT6M3QCI-XN-D5T3b-l0nKzR1k.js → timeline-definition-IT6M3QCI-DJ1oTa68-Cp1nvAUx.js} +4 -4
- package/dist/assets/{treemap-KMMF4GRG-C4GHjB3F-_nPgBK22.js → treemap-KMMF4GRG-BLuW6hva-CvNDnceM.js} +1 -1
- package/dist/assets/{xychartDiagram-PRI3JC2R-BL53__6J-XcAq-Lxf.js → xychartDiagram-PRI3JC2R-BahWB4u4-B6_eZy6F.js} +5 -5
- package/dist/index.html +2 -2
- package/package.json +2 -2
- package/dist/assets/_basePickBy-1MakYQmz-ydNwd1l_.js +0 -1
- package/dist/assets/_baseUniq-Cd4llU-Q-Cdw60MU4.js +0 -1
- package/dist/assets/arc-b8oyw-lz-1LLYREoj.js +0 -1
- package/dist/assets/channel-BLPbvVT2-CnJJPuZ5.js +0 -1
- package/dist/assets/chunk-55IACEB6-C4OH5_NF-DrgL4Tv-.js +0 -1
- package/dist/assets/chunk-TZMSLE5B-DGddLgNl-CifiGjd6.js +0 -1
- package/dist/assets/classDiagram-2ON5EDUG-BngjTxOv-2Y-76rXt.js +0 -1
- package/dist/assets/classDiagram-v2-WZHVMYZB-BngjTxOv-2Y-76rXt.js +0 -1
- package/dist/assets/clone-DH1Kq5Y6-DxQT_fR1.js +0 -1
- package/dist/assets/diagram-QEK2KX5R-Km_liL9n-DiDvLC9k.js +0 -43
- package/dist/assets/ganttDiagram-LVOFAZNH-BidPm1xz-D_x48jVE.js +0 -267
- package/dist/assets/gitGraphDiagram-NY62KEGX-zbMOFVrv-DTVFadEr.js +0 -65
- package/dist/assets/index-42QQgFVq.css +0 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-DINzAoyF-DshiRv7Q.js +0 -1
package/bin/orbitchat.js
CHANGED
|
@@ -16,7 +16,6 @@ import { homedir } from 'os';
|
|
|
16
16
|
import { execSync } from 'child_process';
|
|
17
17
|
import { fileURLToPath } from 'url';
|
|
18
18
|
import { dirname } from 'path';
|
|
19
|
-
import yaml from 'js-yaml';
|
|
20
19
|
import { createProxyMiddleware } from 'http-proxy-middleware';
|
|
21
20
|
|
|
22
21
|
const __filename = fileURLToPath(import.meta.url);
|
|
@@ -44,34 +43,45 @@ const DEFAULT_CONFIG = {
|
|
|
44
43
|
};
|
|
45
44
|
|
|
46
45
|
/**
|
|
47
|
-
* Load adapter mappings from
|
|
48
|
-
*
|
|
46
|
+
* Load adapter mappings from environment variable
|
|
47
|
+
* Format: JSON array of adapter objects
|
|
48
|
+
* Example: ORBIT_ADAPTERS='[{"name":"Simple Chat","apiKey":"key1","apiUrl":"https://api.example.com"}]'
|
|
49
|
+
* @returns {object|null} - Adapters object or null if not found/invalid
|
|
49
50
|
*/
|
|
50
|
-
function loadAdaptersConfig(
|
|
51
|
-
const
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
51
|
+
function loadAdaptersConfig() {
|
|
52
|
+
const envValue = process.env.ORBIT_ADAPTERS || process.env.VITE_ADAPTERS;
|
|
53
|
+
if (!envValue) {
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
try {
|
|
58
|
+
const parsed = JSON.parse(envValue);
|
|
59
|
+
if (!Array.isArray(parsed)) {
|
|
60
|
+
console.warn('Warning: ORBIT_ADAPTERS/VITE_ADAPTERS must be a JSON array');
|
|
61
|
+
return null;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
// Convert array to object format expected by the rest of the code
|
|
65
|
+
const adapters = {};
|
|
66
|
+
for (const adapter of parsed) {
|
|
67
|
+
if (!adapter.name) {
|
|
68
|
+
console.warn('Warning: Each adapter must have a "name" property');
|
|
69
|
+
continue;
|
|
68
70
|
}
|
|
69
|
-
|
|
70
|
-
|
|
71
|
+
adapters[adapter.name] = {
|
|
72
|
+
apiKey: adapter.apiKey || 'default-key',
|
|
73
|
+
apiUrl: adapter.apiUrl || 'http://localhost:3000',
|
|
74
|
+
};
|
|
71
75
|
}
|
|
72
|
-
}
|
|
73
76
|
|
|
74
|
-
|
|
77
|
+
if (Object.keys(adapters).length > 0) {
|
|
78
|
+
return adapters;
|
|
79
|
+
}
|
|
80
|
+
return null;
|
|
81
|
+
} catch (error) {
|
|
82
|
+
console.warn('Warning: Could not parse ORBIT_ADAPTERS/VITE_ADAPTERS:', error.message);
|
|
83
|
+
return null;
|
|
84
|
+
}
|
|
75
85
|
}
|
|
76
86
|
|
|
77
87
|
/**
|
|
@@ -85,7 +95,6 @@ function parseArgs() {
|
|
|
85
95
|
host: 'localhost',
|
|
86
96
|
open: false,
|
|
87
97
|
configFile: null,
|
|
88
|
-
adaptersConfig: null,
|
|
89
98
|
};
|
|
90
99
|
|
|
91
100
|
for (let i = 0; i < args.length; i++) {
|
|
@@ -153,9 +162,6 @@ function parseArgs() {
|
|
|
153
162
|
case '--config':
|
|
154
163
|
serverConfig.configFile = args[++i];
|
|
155
164
|
break;
|
|
156
|
-
case '--adapters-config':
|
|
157
|
-
serverConfig.adaptersConfig = args[++i];
|
|
158
|
-
break;
|
|
159
165
|
case '--help':
|
|
160
166
|
case '-h':
|
|
161
167
|
// Handled in main() function
|
|
@@ -295,9 +301,9 @@ function injectConfig(html, config) {
|
|
|
295
301
|
/**
|
|
296
302
|
* Create Express server to serve the built app
|
|
297
303
|
*/
|
|
298
|
-
function createServer(distPath, config
|
|
304
|
+
function createServer(distPath, config) {
|
|
299
305
|
const app = express();
|
|
300
|
-
const adapters = config.enableApiMiddleware ? loadAdaptersConfig(
|
|
306
|
+
const adapters = config.enableApiMiddleware ? loadAdaptersConfig() : null;
|
|
301
307
|
|
|
302
308
|
// API endpoints for middleware mode - MUST be before body parsers
|
|
303
309
|
if (config.enableApiMiddleware && adapters) {
|
|
@@ -529,7 +535,6 @@ Options:
|
|
|
529
535
|
--enable-audio Enable audio button (default: false)
|
|
530
536
|
--enable-feedback Enable feedback buttons (default: false)
|
|
531
537
|
--enable-api-middleware Enable API middleware mode (default: false)
|
|
532
|
-
--adapters-config PATH Path to adapters.yaml for middleware mode
|
|
533
538
|
--max-files-per-conversation N Max files per conversation (default: 5)
|
|
534
539
|
--max-file-size-mb N Max file size in MB (default: 50)
|
|
535
540
|
--max-total-files N Max total files (default: 100, 0 = unlimited)
|
|
@@ -550,12 +555,16 @@ Configuration Priority:
|
|
|
550
555
|
3. Environment variables (VITE_*)
|
|
551
556
|
4. Default values
|
|
552
557
|
|
|
558
|
+
Environment Variables for Middleware Mode:
|
|
559
|
+
ORBIT_ADAPTERS or VITE_ADAPTERS JSON array of adapter configurations
|
|
560
|
+
Example: '[{"name":"Chat","apiKey":"key1","apiUrl":"https://api.example.com"}]'
|
|
561
|
+
|
|
553
562
|
Examples:
|
|
554
563
|
orbitchat --api-url http://localhost:3000 --port 8080
|
|
555
564
|
orbitchat --api-key my-key --open
|
|
556
565
|
orbitchat --enable-audio --enable-upload --console-debug
|
|
557
566
|
orbitchat --config /path/to/config.json
|
|
558
|
-
orbitchat --enable-api-middleware
|
|
567
|
+
ORBIT_ADAPTERS='[{"name":"Chat","apiKey":"mykey","apiUrl":"https://api.example.com"}]' orbitchat --enable-api-middleware
|
|
559
568
|
`);
|
|
560
569
|
|
|
561
570
|
}
|
|
@@ -589,7 +598,7 @@ function main() {
|
|
|
589
598
|
}
|
|
590
599
|
|
|
591
600
|
// Create and start server
|
|
592
|
-
const app = createServer(distPath, config
|
|
601
|
+
const app = createServer(distPath, config);
|
|
593
602
|
|
|
594
603
|
app.listen(serverConfig.port, serverConfig.host, () => {
|
|
595
604
|
const url = `http://${serverConfig.host}:${serverConfig.port}`;
|
|
@@ -601,11 +610,11 @@ function main() {
|
|
|
601
610
|
console.debug(` Host: ${serverConfig.host}`);
|
|
602
611
|
if (config.enableApiMiddleware) {
|
|
603
612
|
console.debug(` API Middleware: Enabled`);
|
|
604
|
-
const adapters = loadAdaptersConfig(
|
|
613
|
+
const adapters = loadAdaptersConfig();
|
|
605
614
|
if (adapters) {
|
|
606
615
|
console.debug(` Available Adapters: ${Object.keys(adapters).join(', ')}`);
|
|
607
616
|
} else {
|
|
608
|
-
console.debug(` Warning: No adapters
|
|
617
|
+
console.debug(` Warning: No adapters configured. Set ORBIT_ADAPTERS or VITE_ADAPTERS environment variable.`);
|
|
609
618
|
}
|
|
610
619
|
}
|
|
611
620
|
console.debug('');
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{b as m,L as s,Y as d,O as $,t as j,N as h,y as Q,A as b,M as A,d as G,Q as _}from"./_baseUniq-DZ7Bpu3I-Co9egLVD.js";import{aJ as x,br as O,aE as J,aF as L,aQ as N,bs as S,bt as c,bu as Y,aO as w,aK as F}from"./index-DodYl3VC.js";var K=/\s/;function M(r){for(var t=r.length;t--&&K.test(r.charAt(t)););return t}var P=/^\s+/;function k(r){return r&&r.slice(0,M(r)+1).replace(P,"")}var p=NaN,q=/^[-+]0x[0-9a-f]+$/i,z=/^0b[01]+$/i,C=/^0o[0-7]+$/i,D=parseInt;function E(r){if(typeof r=="number")return r;if(h(r))return p;if(c(r)){var t=typeof r.valueOf=="function"?r.valueOf():r;r=c(t)?t+"":t}if(typeof r!="string")return r===0?r:+r;r=k(r);var a=z.test(r);return a||C.test(r)?D(r.slice(2),a?2:8):q.test(r)?p:+r}var g=1/0,H=17976931348623157e292;function I(r){if(!r)return r===0?r:0;if(r=E(r),r===g||r===-g){var t=r<0?-1:1;return t*H}return r===r?r:0}function R(r){var t=I(r),a=t%1;return t===t?a?t-a:t:0}function ur(r){var t=r==null?0:r.length;return t?$(r):[]}var y=Object.prototype,U=y.hasOwnProperty,fr=J(function(r,t){r=Object(r);var a=-1,o=t.length,e=o>2?t[2]:void 0;for(e&&L(t[0],t[1],e)&&(o=1);++a<o;)for(var f=t[a],n=N(f),u=-1,i=n.length;++u<i;){var v=n[u],l=r[v];(l===void 0||S(l,y[v])&&!U.call(r,v))&&(r[v]=f[v])}return r});function ir(r){var t=r==null?0:r.length;return t?r[t-1]:void 0}function V(r){return function(t,a,o){var e=Object(t);if(!O(t)){var f=s(a);t=G(t),a=function(u){return f(e[u],u,e)}}var n=r(t,a,o);return n>-1?e[f?t[n]:n]:void 0}}var W=Math.max;function X(r,t,a){var o=r==null?0:r.length;if(!o)return-1;var e=a==null?0:R(a);return e<0&&(e=W(o+e,0)),_(r,s(t),e)}var vr=V(X);function Z(r,t){var a=-1,o=O(r)?Array(r.length):[];return d(r,function(e,f,n){o[++a]=t(e,f,n)}),o}function lr(r,t){var a=x(r)?m:Z;return a(r,s(t))}var B=Object.prototype,T=B.hasOwnProperty;function rr(r,t){return r!=null&&T.call(r,t)}function cr(r,t){return r!=null&&j(r,t,rr)}function tr(r,t){return r<t}function ar(r,t,a){for(var o=-1,e=r.length;++o<e;){var f=r[o],n=t(f);if(n!=null&&(u===void 0?n===n&&!h(n):a(n,u)))var u=n,i=f}return i}function sr(r){return r&&r.length?ar(r,F,tr):void 0}function er(r,t,a,o){if(!c(r))return r;t=b(t,r);for(var e=-1,f=t.length,n=f-1,u=r;u!=null&&++e<f;){var i=A(t[e]),v=a;if(i==="__proto__"||i==="constructor"||i==="prototype")return r;if(e!=n){var l=u[i];v=void 0,v===void 0&&(v=c(l)?l:Y(t[e+1])?[]:{})}w(u,i,v),u=u[i]}return r}function pr(r,t,a){for(var o=-1,e=t.length,f={};++o<e;){var n=t[o],u=Q(r,n);a(u,n)&&er(f,b(n,r),u)}return f}export{Z as V,I as X,R as Y,lr as b,fr as d,ur as f,cr as g,vr as h,sr as m,pr as o,tr as r,ar as t,ir as u};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{bv as Lr,bw as Mr,br as or,aJ as p,aK as cr,bt as fr,bx as $r,by as m,bz as P,bA as zr,bB as kr,bC as O,aL as sr,aO as Dr,bD as k,bE as Fr,bF as $,aQ as B,bG as Pr,bH as ir,bI as M,bJ as S,bK as Ur,bL as w,bM as Br,bN as Gr,bu as Qr,bO as lr,bP as Vr,bs as Cr,bQ as K,bR as Hr,aP as Nr}from"./index-DodYl3VC.js";var Rr="[object Symbol]";function G(r){return typeof r=="symbol"||S(r)&&Br(r)==Rr}function br(r,e){for(var t=-1,a=r==null?0:r.length,n=Array(a);++t<a;)n[t]=e(r[t],t,r);return n}var T=w?w.prototype:void 0,W=T?T.toString:void 0;function vr(r){if(typeof r=="string")return r;if(p(r))return br(r,vr)+"";if(G(r))return W?W.call(r):"";var e=r+"";return e=="0"&&1/r==-1/0?"-0":e}function Jr(){}function jr(r,e){for(var t=-1,a=r==null?0:r.length;++t<a&&e(r[t],t,r)!==!1;);return r}function Kr(r,e,t,a){for(var n=r.length,u=t+-1;++u<n;)if(e(r[u],u,r))return u;return-1}function Tr(r){return r!==r}function Wr(r,e,t){for(var a=t-1,n=r.length;++a<n;)if(r[a]===e)return a;return-1}function Xr(r,e,t){return e===e?Wr(r,e,t):Kr(r,Tr,t)}function qr(r,e){var t=r==null?0:r.length;return!!t&&Xr(r,e,0)>-1}function _(r){return or(r)?Lr(r):Mr(r)}var Yr=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,Zr=/^\w*$/;function Q(r,e){if(p(r))return!1;var t=typeof r;return t=="number"||t=="symbol"||t=="boolean"||r==null||G(r)?!0:Zr.test(r)||!Yr.test(r)||e!=null&&r in Object(e)}var re=500;function ee(r){var e=Hr(r,function(a){return t.size===re&&t.clear(),a}),t=e.cache;return e}var te=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,ae=/\\(\\)?/g,ue=ee(function(r){var e=[];return r.charCodeAt(0)===46&&e.push(""),r.replace(te,function(t,a,n,u){e.push(n?u.replace(ae,"$1"):a||t)}),e});function ne(r){return r==null?"":vr(r)}function yr(r,e){return p(r)?r:Q(r,e)?[r]:ue(ne(r))}function z(r){if(typeof r=="string"||G(r))return r;var e=r+"";return e=="0"&&1/r==-1/0?"-0":e}function hr(r,e){e=yr(e,r);for(var t=0,a=e.length;r!=null&&t<a;)r=r[z(e[t++])];return t&&t==a?r:void 0}function oe(r,e,t){var a=r==null?void 0:hr(r,e);return a===void 0?t:a}function V(r,e){for(var t=-1,a=e.length,n=r.length;++t<a;)r[n+t]=e[t];return r}var X=w?w.isConcatSpreadable:void 0;function ce(r){return p(r)||lr(r)||!!(X&&r&&r[X])}function wa(r,e,t,a,n){var u=-1,o=r.length;for(t||(t=ce),n||(n=[]);++u<o;){var c=r[u];t(c)?V(n,c):a||(n[n.length]=c)}return n}function fe(r,e,t,a){var n=-1,u=r==null?0:r.length;for(a&&u&&(t=r[++n]);++n<u;)t=e(t,r[n],n,r);return t}function se(r,e){return r&&$(e,_(e),r)}function ie(r,e){return r&&$(e,B(e),r)}function gr(r,e){for(var t=-1,a=r==null?0:r.length,n=0,u=[];++t<a;){var o=r[t];e(o,t,r)&&(u[n++]=o)}return u}function pr(){return[]}var le=Object.prototype,be=le.propertyIsEnumerable,q=Object.getOwnPropertySymbols,C=q?function(r){return r==null?[]:(r=Object(r),gr(q(r),function(e){return be.call(r,e)}))}:pr;function ve(r,e){return $(r,C(r),e)}var je=Object.getOwnPropertySymbols,dr=je?function(r){for(var e=[];r;)V(e,C(r)),r=Ur(r);return e}:pr;function ye(r,e){return $(r,dr(r),e)}function wr(r,e,t){var a=e(r);return p(r)?a:V(a,t(r))}function U(r){return wr(r,_,C)}function he(r){return wr(r,B,dr)}var ge=Object.prototype,pe=ge.hasOwnProperty;function de(r){var e=r.length,t=new r.constructor(e);return e&&typeof r[0]=="string"&&pe.call(r,"index")&&(t.index=r.index,t.input=r.input),t}function we(r,e){var t=e?ir(r.buffer):r.buffer;return new r.constructor(t,r.byteOffset,r.byteLength)}var Ae=/\w*$/;function _e(r){var e=new r.constructor(r.source,Ae.exec(r));return e.lastIndex=r.lastIndex,e}var Y=w?w.prototype:void 0,Z=Y?Y.valueOf:void 0;function Oe(r){return Z?Object(Z.call(r)):{}}var me="[object Boolean]",Se="[object Date]",Ee="[object Map]",Ie="[object Number]",xe="[object RegExp]",Le="[object Set]",Me="[object String]",$e="[object Symbol]",ze="[object ArrayBuffer]",ke="[object DataView]",De="[object Float32Array]",Fe="[object Float64Array]",Pe="[object Int8Array]",Ue="[object Int16Array]",Be="[object Int32Array]",Ge="[object Uint8Array]",Qe="[object Uint8ClampedArray]",Ve="[object Uint16Array]",Ce="[object Uint32Array]";function He(r,e,t){var a=r.constructor;switch(e){case ze:return ir(r);case me:case Se:return new a(+r);case ke:return we(r,t);case De:case Fe:case Pe:case Ue:case Be:case Ge:case Qe:case Ve:case Ce:return Pr(r,t);case Ee:return new a;case Ie:case Me:return new a(r);case xe:return _e(r);case Le:return new a;case $e:return Oe(r)}}var Ne="[object Map]";function Re(r){return S(r)&&m(r)==Ne}var rr=M&&M.isMap,Je=rr?sr(rr):Re,Ke="[object Set]";function Te(r){return S(r)&&m(r)==Ke}var er=M&&M.isSet,We=er?sr(er):Te,Xe=1,qe=2,Ye=4,Ar="[object Arguments]",Ze="[object Array]",rt="[object Boolean]",et="[object Date]",tt="[object Error]",_r="[object Function]",at="[object GeneratorFunction]",ut="[object Map]",nt="[object Number]",Or="[object Object]",ot="[object RegExp]",ct="[object Set]",ft="[object String]",st="[object Symbol]",it="[object WeakMap]",lt="[object ArrayBuffer]",bt="[object DataView]",vt="[object Float32Array]",jt="[object Float64Array]",yt="[object Int8Array]",ht="[object Int16Array]",gt="[object Int32Array]",pt="[object Uint8Array]",dt="[object Uint8ClampedArray]",wt="[object Uint16Array]",At="[object Uint32Array]",i={};i[Ar]=i[Ze]=i[lt]=i[bt]=i[rt]=i[et]=i[vt]=i[jt]=i[yt]=i[ht]=i[gt]=i[ut]=i[nt]=i[Or]=i[ot]=i[ct]=i[ft]=i[st]=i[pt]=i[dt]=i[wt]=i[At]=!0;i[tt]=i[_r]=i[it]=!1;function D(r,e,t,a,n,u){var o,c=e&Xe,f=e&qe,v=e&Ye;if(o!==void 0)return o;if(!fr(r))return r;var l=p(r);if(l){if(o=de(r),!c)return $r(r,o)}else{var s=m(r),b=s==_r||s==at;if(P(r))return zr(r,c);if(s==Or||s==Ar||b&&!n){if(o=f||b?{}:kr(r),!c)return f?ye(r,ie(o,r)):ve(r,se(o,r))}else{if(!i[s])return n?r:{};o=He(r,s,c)}}u||(u=new O);var d=u.get(r);if(d)return d;u.set(r,o),We(r)?r.forEach(function(j){o.add(D(j,e,t,j,r,u))}):Je(r)&&r.forEach(function(j,y){o.set(y,D(j,e,t,y,r,u))});var h=v?f?he:U:f?B:_,g=l?void 0:h(r);return jr(g||r,function(j,y){g&&(y=j,j=r[y]),Dr(o,y,D(j,e,t,y,r,u))}),o}var _t="__lodash_hash_undefined__";function Ot(r){return this.__data__.set(r,_t),this}function mt(r){return this.__data__.has(r)}function E(r){var e=-1,t=r==null?0:r.length;for(this.__data__=new Fr;++e<t;)this.add(r[e])}E.prototype.add=E.prototype.push=Ot;E.prototype.has=mt;function St(r,e){for(var t=-1,a=r==null?0:r.length;++t<a;)if(e(r[t],t,r))return!0;return!1}function mr(r,e){return r.has(e)}var Et=1,It=2;function Sr(r,e,t,a,n,u){var o=t&Et,c=r.length,f=e.length;if(c!=f&&!(o&&f>c))return!1;var v=u.get(r),l=u.get(e);if(v&&l)return v==e&&l==r;var s=-1,b=!0,d=t&It?new E:void 0;for(u.set(r,e),u.set(e,r);++s<c;){var h=r[s],g=e[s];if(a)var j=o?a(g,h,s,e,r,u):a(h,g,s,r,e,u);if(j!==void 0){if(j)continue;b=!1;break}if(d){if(!St(e,function(y,A){if(!mr(d,A)&&(h===y||n(h,y,t,a,u)))return d.push(A)})){b=!1;break}}else if(!(h===g||n(h,g,t,a,u))){b=!1;break}}return u.delete(r),u.delete(e),b}function xt(r){var e=-1,t=Array(r.size);return r.forEach(function(a,n){t[++e]=[n,a]}),t}function H(r){var e=-1,t=Array(r.size);return r.forEach(function(a){t[++e]=a}),t}var Lt=1,Mt=2,$t="[object Boolean]",zt="[object Date]",kt="[object Error]",Dt="[object Map]",Ft="[object Number]",Pt="[object RegExp]",Ut="[object Set]",Bt="[object String]",Gt="[object Symbol]",Qt="[object ArrayBuffer]",Vt="[object DataView]",tr=w?w.prototype:void 0,F=tr?tr.valueOf:void 0;function Ct(r,e,t,a,n,u,o){switch(t){case Vt:if(r.byteLength!=e.byteLength||r.byteOffset!=e.byteOffset)return!1;r=r.buffer,e=e.buffer;case Qt:return!(r.byteLength!=e.byteLength||!u(new K(r),new K(e)));case $t:case zt:case Ft:return Cr(+r,+e);case kt:return r.name==e.name&&r.message==e.message;case Pt:case Bt:return r==e+"";case Dt:var c=xt;case Ut:var f=a≪if(c||(c=H),r.size!=e.size&&!f)return!1;var v=o.get(r);if(v)return v==e;a|=Mt,o.set(r,e);var l=Sr(c(r),c(e),a,n,u,o);return o.delete(r),l;case Gt:if(F)return F.call(r)==F.call(e)}return!1}var Ht=1,Nt=Object.prototype,Rt=Nt.hasOwnProperty;function Jt(r,e,t,a,n,u){var o=t&Ht,c=U(r),f=c.length,v=U(e),l=v.length;if(f!=l&&!o)return!1;for(var s=f;s--;){var b=c[s];if(!(o?b in e:Rt.call(e,b)))return!1}var d=u.get(r),h=u.get(e);if(d&&h)return d==e&&h==r;var g=!0;u.set(r,e),u.set(e,r);for(var j=o;++s<f;){b=c[s];var y=r[b],A=e[b];if(a)var J=o?a(A,y,b,e,r,u):a(y,A,b,r,e,u);if(!(J===void 0?y===A||n(y,A,t,a,u):J)){g=!1;break}j||(j=b=="constructor")}if(g&&!j){var I=r.constructor,x=e.constructor;I!=x&&"constructor"in r&&"constructor"in e&&!(typeof I=="function"&&I instanceof I&&typeof x=="function"&&x instanceof x)&&(g=!1)}return u.delete(r),u.delete(e),g}var Kt=1,ar="[object Arguments]",ur="[object Array]",L="[object Object]",Tt=Object.prototype,nr=Tt.hasOwnProperty;function Wt(r,e,t,a,n,u){var o=p(r),c=p(e),f=o?ur:m(r),v=c?ur:m(e);f=f==ar?L:f,v=v==ar?L:v;var l=f==L,s=v==L,b=f==v;if(b&&P(r)){if(!P(e))return!1;o=!0,l=!1}if(b&&!l)return u||(u=new O),o||Vr(r)?Sr(r,e,t,a,n,u):Ct(r,e,f,t,a,n,u);if(!(t&Kt)){var d=l&&nr.call(r,"__wrapped__"),h=s&&nr.call(e,"__wrapped__");if(d||h){var g=d?r.value():r,j=h?e.value():e;return u||(u=new O),n(g,j,t,a,u)}}return b?(u||(u=new O),Jt(r,e,t,a,n,u)):!1}function N(r,e,t,a,n){return r===e?!0:r==null||e==null||!S(r)&&!S(e)?r!==r&&e!==e:Wt(r,e,t,a,N,n)}var Xt=1,qt=2;function Yt(r,e,t,a){var n=t.length,u=n;if(r==null)return!u;for(r=Object(r);n--;){var o=t[n];if(o[2]?o[1]!==r[o[0]]:!(o[0]in r))return!1}for(;++n<u;){o=t[n];var c=o[0],f=r[c],v=o[1];if(o[2]){if(f===void 0&&!(c in r))return!1}else{var l=new O,s;if(!(s===void 0?N(v,f,Xt|qt,a,l):s))return!1}}return!0}function Er(r){return r===r&&!fr(r)}function Zt(r){for(var e=_(r),t=e.length;t--;){var a=e[t],n=r[a];e[t]=[a,n,Er(n)]}return e}function Ir(r,e){return function(t){return t==null?!1:t[r]===e&&(e!==void 0||r in Object(t))}}function ra(r){var e=Zt(r);return e.length==1&&e[0][2]?Ir(e[0][0],e[0][1]):function(t){return t===r||Yt(t,r,e)}}function ea(r,e){return r!=null&&e in Object(r)}function ta(r,e,t){e=yr(e,r);for(var a=-1,n=e.length,u=!1;++a<n;){var o=z(e[a]);if(!(u=r!=null&&t(r,o)))break;r=r[o]}return u||++a!=n?u:(n=r==null?0:r.length,!!n&&Gr(n)&&Qr(o,n)&&(p(r)||lr(r)))}function aa(r,e){return r!=null&&ta(r,e,ea)}var ua=1,na=2;function oa(r,e){return Q(r)&&Er(e)?Ir(z(r),e):function(t){var a=oe(t,r);return a===void 0&&a===e?aa(t,r):N(e,a,ua|na)}}function ca(r){return function(e){return e==null?void 0:e[r]}}function fa(r){return function(e){return hr(e,r)}}function sa(r){return Q(r)?ca(z(r)):fa(r)}function xr(r){return typeof r=="function"?r:r==null?cr:typeof r=="object"?p(r)?oa(r[0],r[1]):ra(r):sa(r)}function ia(r,e){return r&&Nr(r,e,_)}function la(r,e){return function(t,a){if(t==null)return t;if(!or(t))return r(t,a);for(var n=t.length,u=-1,o=Object(t);++u<n&&a(o[u],u,o)!==!1;);return t}}var R=la(ia);function ba(r){return typeof r=="function"?r:cr}function Aa(r,e){var t=p(r)?jr:R;return t(r,ba(e))}function va(r,e){var t=[];return R(r,function(a,n,u){e(a,n,u)&&t.push(a)}),t}function _a(r,e){var t=p(r)?gr:va;return t(r,xr(e))}function ja(r,e){return br(e,function(t){return r[t]})}function Oa(r){return r==null?[]:ja(r,_(r))}function ma(r){return r===void 0}function ya(r,e,t,a,n){return n(r,function(u,o,c){t=a?(a=!1,u):e(t,u,o,c)}),t}function Sa(r,e,t){var a=p(r)?fe:ya,n=arguments.length<3;return a(r,xr(e),t,n,R)}var ha=1/0,ga=k&&1/H(new k([,-0]))[1]==ha?function(r){return new k(r)}:Jr,pa=200;function Ea(r,e,t){var a=-1,n=qr,u=r.length,o=!0,c=[],f=c;if(u>=pa){var v=e?null:ga(r);if(v)return H(v);o=!1,n=mr,f=new E}else f=e?[]:c;r:for(;++a<u;){var l=r[a],s=e?e(l):l;if(l=l!==0?l:0,o&&s===s){for(var b=f.length;b--;)if(f[b]===s)continue r;e&&f.push(s),c.push(l)}else n(f,s,t)||(f!==c&&f.push(s),c.push(l))}return c}export{Aa as $,yr as A,Oa as E,Sa as I,Jr as J,xr as L,z as M,G as N,wa as O,Ea as P,Kr as Q,ma as S,gr as T,qr as V,R as Y,_a as _,ne as a,br as b,ba as c,_ as d,E as e,he as f,va as g,St as h,aa as i,mr as j,ia as l,D as m,ta as t,hr as y,Xr as z};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{_ as K}from"./index-
|
|
1
|
+
import{_ as K}from"./index-DodYl3VC.js";var j=Object.defineProperty,q=(l,i,e)=>i in l?j(l,i,{enumerable:!0,configurable:!0,writable:!0,value:e}):l[i]=e,I=(l,i,e)=>q(l,typeof i!="symbol"?i+"":i,e);let F=null,$=null;typeof window>"u"&&Promise.all([K(()=>import("./__vite-browser-external-BIHI7g3E.js"),[]).catch(()=>null),K(()=>import("./__vite-browser-external-BIHI7g3E.js"),[]).catch(()=>null)]).then(([l,i])=>{var e,t;(e=l==null?void 0:l.default)!=null&&e.Agent?F=new l.default.Agent({keepAlive:!0}):l!=null&&l.Agent&&(F=new l.Agent({keepAlive:!0})),(t=i==null?void 0:i.default)!=null&&t.Agent?$=new i.default.Agent({keepAlive:!0}):i!=null&&i.Agent&&($=new i.Agent({keepAlive:!0}))}).catch(l=>{console.warn("Failed to initialize HTTP agents:",l.message)});class D{constructor(i){if(I(this,"apiUrl"),I(this,"apiKey"),I(this,"sessionId"),!i.apiUrl||typeof i.apiUrl!="string")throw new Error("API URL must be a valid string");if(i.apiKey!==void 0&&i.apiKey!==null&&typeof i.apiKey!="string")throw new Error("API key must be a valid string or null");if(i.sessionId!==void 0&&i.sessionId!==null&&typeof i.sessionId!="string")throw new Error("Session ID must be a valid string or null");this.apiUrl=i.apiUrl,this.apiKey=i.apiKey??null,this.sessionId=i.sessionId??null}setSessionId(i){if(i!==null&&typeof i!="string")throw new Error("Session ID must be a valid string or null");this.sessionId=i}getSessionId(){return this.sessionId}async validateApiKey(){var i;if(!this.apiKey)throw new Error("API key is required for validation");try{const e=await fetch(`${this.apiUrl}/admin/api-keys/${this.apiKey}/status`,{...this.getFetchOptions({method:"GET"})}).catch(r=>{throw r.name==="TypeError"&&r.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):r});if(!e.ok){let r="";try{r=await e.text()}catch{r=`HTTP ${e.status}`}let s,o;try{const a=JSON.parse(r);s=a.detail||a.message||r}catch{s=r||`HTTP ${e.status}`}switch(e.status){case 401:o="API key is invalid or expired";break;case 403:o="Access denied: API key does not have required permissions";break;case 404:o="API key not found";break;case 503:o="API key management is not available in inference-only mode";break;default:o=`Failed to validate API key: ${s}`;break}throw new Error(o)}const t=await e.json();if(!t.exists){const r="API key does not exist";throw new Error(r)}if(!t.active){const r="API key is inactive";throw new Error(r)}return t}catch(e){let t;throw e instanceof Error&&e.message?e.message.includes("API key")||e.message.includes("Access denied")||e.message.includes("invalid")||e.message.includes("expired")||e.message.includes("inactive")||e.message.includes("not found")||e.message.includes("Could not connect")?t=e.message:t=`API key validation failed: ${e.message}`:e.name==="TypeError"&&(i=e.message)!=null&&i.includes("Failed to fetch")?t="Could not connect to the server. Please check if the server is running.":t="API key validation failed. Please check your API key and try again.",console.warn(`[ApiClient] ${t}`),new Error(t)}}async getAdapterInfo(){var i;if(!this.apiKey)throw new Error("API key is required to get adapter information");try{const e=await fetch(`${this.apiUrl}/admin/api-keys/info`,{...this.getFetchOptions({method:"GET"})}).catch(t=>{throw t.name==="TypeError"&&t.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):t});if(!e.ok){let t="";try{t=await e.text()}catch{t=`HTTP ${e.status}`}let r,s;try{const o=JSON.parse(t);r=o.detail||o.message||t}catch{r=t||`HTTP ${e.status}`}switch(e.status){case 401:s="API key is invalid, disabled, or has no associated adapter";break;case 404:s="Adapter configuration not found";break;case 503:s="Service is not available";break;default:s=`Failed to get adapter info: ${r}`;break}throw new Error(s)}return await e.json()}catch(e){let t;throw e instanceof Error&&e.message?e.message.includes("API key")||e.message.includes("Adapter")||e.message.includes("invalid")||e.message.includes("disabled")||e.message.includes("not found")||e.message.includes("Could not connect")?t=e.message:t=`Failed to get adapter info: ${e.message}`:e.name==="TypeError"&&(i=e.message)!=null&&i.includes("Failed to fetch")?t="Could not connect to the server. Please check if the server is running.":t="Failed to get adapter information. Please try again.",console.warn(`[ApiClient] ${t}`),new Error(t)}}getFetchOptions(i={}){const e={};if(typeof window>"u"){const r=this.apiUrl.startsWith("https:")?$:F;r&&(e.agent=r)}else e.headers={Connection:"keep-alive"};const t={"X-Request-ID":Date.now().toString(36)+Math.random().toString(36).substring(2)};if(e.headers&&Object.assign(t,e.headers),i.headers){const r=i.headers;for(const[s,o]of Object.entries(r))(s.toLowerCase()!=="x-api-key"||!this.apiKey)&&(t[s]=o)}return this.apiKey&&(t["X-API-Key"]=this.apiKey),this.sessionId&&(t["X-Session-ID"]=this.sessionId),{...i,...e,headers:t}}createChatRequest(i,e=!0,t,r,s,o,a,h,p,y,v){const c={messages:[{role:"user",content:i}],stream:e};return t&&t.length>0&&(c.file_ids=t),r&&(c.thread_id=r),s&&(c.audio_input=s),o&&(c.audio_format=o),a&&(c.language=a),h!==void 0&&(c.return_audio=h),p&&(c.tts_voice=p),y&&(c.source_language=y),v&&(c.target_language=v),c}async*streamChat(i,e=!0,t,r,s,o,a,h,p,y,v){var c,C;try{const w=new AbortController,O=setTimeout(()=>w.abort(),6e4),g=await fetch(`${this.apiUrl}/v1/chat`,{...this.getFetchOptions({method:"POST",headers:{"Content-Type":"application/json",Accept:e?"text/event-stream":"application/json"},body:JSON.stringify(this.createChatRequest(i,e,t,r,s,o,a,h,p,y,v))}),signal:w.signal});if(clearTimeout(O),!g.ok){const f=await g.text();throw new Error(`Network response was not ok: ${g.status} ${f}`)}if(!e){const f=await g.json();f.response&&(yield{text:f.response,done:!0,audio:f.audio,audioFormat:f.audio_format});return}const A=(c=g.body)==null?void 0:c.getReader();if(!A)throw new Error("No reader available");const _=new TextDecoder;let u="",E=!1;try{for(;;){const{done:f,value:S}=await A.read();if(f)break;const U=_.decode(S,{stream:!0});u+=U;let k=0,P;for(;(P=u.indexOf(`
|
|
2
2
|
`,k))!==-1;){const m=u.slice(k,P).trim();if(k=P+1,m&&m.startsWith("data: ")){const d=m.slice(6).trim();if(!d||d==="[DONE]"){yield{text:"",done:!0};return}try{const n=JSON.parse(d);if(n.error){const x=`Server error: ${((C=n.error)==null?void 0:C.message)||n.error||"Unknown server error"}`;throw console.warn(`[ApiClient] ${x}`),new Error(x)}if(n.done===!0){E=!0,yield{text:"",done:!0,audio:n.audio,audioFormat:n.audio_format||n.audioFormat,threading:n.threading};return}const b=n.response||"";n.audio_chunk!==void 0&&(yield{text:"",done:!1,audio_chunk:n.audio_chunk,audioFormat:n.audioFormat||n.audio_format||"opus",chunk_index:n.chunk_index??0}),(b||n.audio)&&(E=!0,yield{text:b,done:n.done||!1,audio:n.audio,audioFormat:n.audio_format||n.audioFormat,threading:n.threading})}catch(n){console.warn("[ApiClient] Unable to parse server response. This may be a temporary issue."),console.warn("[ApiClient] Parse error details:",n==null?void 0:n.message),console.warn("[ApiClient] JSON text length:",d==null?void 0:d.length),console.warn("[ApiClient] JSON text preview (first 200 chars):",d==null?void 0:d.substring(0,200)),console.warn("[ApiClient] JSON text preview (last 200 chars):",d==null?void 0:d.substring(d.length-200))}}else m&&(E=!0,yield{text:m,done:!1})}u=u.slice(k),u.length>1e6&&(console.warn("[ApiClient] Buffer too large, truncating..."),u=u.slice(-5e5))}E&&(yield{text:"",done:!0})}finally{A.releaseLock()}}catch(w){throw w.name==="AbortError"?new Error("Connection timed out. Please check if the server is running."):w.name==="TypeError"&&w.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):w}}async clearConversationHistory(i){const e=i||this.sessionId;if(!e)throw new Error("No session ID provided and no current session available");if(!this.apiKey)throw new Error("API key is required for clearing conversation history");const t={"Content-Type":"application/json","X-Session-ID":e,"X-API-Key":this.apiKey};try{const r=await fetch(`${this.apiUrl}/admin/chat-history/${e}`,{...this.getFetchOptions({method:"DELETE",headers:t})});if(!r.ok){const s=await r.text();throw new Error(`Failed to clear conversation history: ${r.status} ${s}`)}return await r.json()}catch(r){throw r.name==="TypeError"&&r.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):r}}async deleteConversationWithFiles(i,e){const t=i||this.sessionId;if(!t)throw new Error("No session ID provided and no current session available");if(!this.apiKey)throw new Error("API key is required for deleting conversation");const r={"Content-Type":"application/json","X-Session-ID":t,"X-API-Key":this.apiKey},s=e&&e.length>0?`?file_ids=${e.join(",")}`:"",o=`${this.apiUrl}/admin/conversations/${t}${s}`;try{const a=await fetch(o,{...this.getFetchOptions({method:"DELETE",headers:r})});if(!a.ok){const h=await a.text();throw new Error(`Failed to delete conversation: ${a.status} ${h}`)}return await a.json()}catch(a){throw a.name==="TypeError"&&a.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):a}}async createThread(i,e){if(!this.apiKey)throw new Error("API key is required for creating threads");const t={"Content-Type":"application/json","X-API-Key":this.apiKey};try{const r=await fetch(`${this.apiUrl}/api/threads`,{...this.getFetchOptions({method:"POST",headers:t,body:JSON.stringify({message_id:i,session_id:e})})});if(!r.ok){const s=await r.text();throw new Error(`Failed to create thread: ${r.status} ${s}`)}return await r.json()}catch(r){throw r.name==="TypeError"&&r.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):r}}async getThreadInfo(i){if(!this.apiKey)throw new Error("API key is required for getting thread info");const e={"X-API-Key":this.apiKey};try{const t=await fetch(`${this.apiUrl}/api/threads/${i}`,{...this.getFetchOptions({method:"GET",headers:e})});if(!t.ok){const r=await t.text();throw new Error(`Failed to get thread info: ${t.status} ${r}`)}return await t.json()}catch(t){throw t.name==="TypeError"&&t.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):t}}async deleteThread(i){if(!this.apiKey)throw new Error("API key is required for deleting threads");const e={"X-API-Key":this.apiKey};try{const t=await fetch(`${this.apiUrl}/api/threads/${i}`,{...this.getFetchOptions({method:"DELETE",headers:e})});if(!t.ok){const r=await t.text();throw new Error(`Failed to delete thread: ${t.status} ${r}`)}return await t.json()}catch(t){throw t.name==="TypeError"&&t.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):t}}async uploadFile(i){if(!this.apiKey)throw new Error("API key is required for file upload");const e=new FormData;e.append("file",i);try{const t=await fetch(`${this.apiUrl}/api/files/upload`,{...this.getFetchOptions({method:"POST",body:e})});if(!t.ok){const r=await t.text();throw new Error(`Failed to upload file: ${t.status} ${r}`)}return await t.json()}catch(t){throw t.name==="TypeError"&&t.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):t}}async listFiles(){if(!this.apiKey)throw new Error("API key is required for listing files");try{const i=await fetch(`${this.apiUrl}/api/files`,{...this.getFetchOptions({method:"GET"})});if(!i.ok){const e=await i.text();throw new Error(`Failed to list files: ${i.status} ${e}`)}return await i.json()}catch(i){throw i.name==="TypeError"&&i.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):i}}async getFileInfo(i){if(!this.apiKey)throw new Error("API key is required for getting file info");try{const e=await fetch(`${this.apiUrl}/api/files/${i}`,{...this.getFetchOptions({method:"GET"})});if(!e.ok){const t=await e.text();throw new Error(`Failed to get file info: ${e.status} ${t}`)}return await e.json()}catch(e){throw e.name==="TypeError"&&e.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):e}}async queryFile(i,e,t=10){if(!this.apiKey)throw new Error("API key is required for querying files");try{const r=await fetch(`${this.apiUrl}/api/files/${i}/query`,{...this.getFetchOptions({method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({query:e,max_results:t})})});if(!r.ok){const s=await r.text();throw new Error(`Failed to query file: ${r.status} ${s}`)}return await r.json()}catch(r){throw r.name==="TypeError"&&r.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):r}}async deleteFile(i){if(!this.apiKey)throw new Error("API key is required for deleting files");const e=`${this.apiUrl}/api/files/${i}`,t=this.getFetchOptions({method:"DELETE"});try{const r=await fetch(e,t);if(!r.ok){const s=await r.text();let o;try{const a=JSON.parse(s);o=a.detail||a.message||`Failed to delete file (HTTP ${r.status})`}catch{o=`Failed to delete file (HTTP ${r.status})`}throw console.warn(`[ApiClient] ${o}`),new Error(o)}return await r.json()}catch(r){let s;throw r.name==="TypeError"&&r.message.includes("Failed to fetch")?s="Could not connect to the server. Please check if the server is running.":r.message&&!r.message.includes("Failed to delete file")?s=r.message:s="Failed to delete file. Please try again.",console.warn(`[ApiClient] ${s}`),new Error(s)}}}let T=null;const J=(l,i=null,e=null)=>{T=new D({apiUrl:l,apiKey:i,sessionId:e})};async function*L(l,i=!0,e,t,r,s,o,a,h,p,y){if(!T)throw new Error("API not configured. Please call configureApi() with your server URL before using any API functions.");yield*T.streamChat(l,i,e,t,r,s,o,a,h,p,y)}export{D as ApiClient,J as configureApi,L as streamChat};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{aY as sn,aZ as an,a_ as l,as as on,a$ as L,b0 as F,b1 as E,b2 as un,aq as z,b3 as cn,b4 as M,b5 as e,b6 as rn,b7 as en,b8 as yn}from"./index-DodYl3VC.js";function fn(i){return i.innerRadius}function ln(i){return i.outerRadius}function gn(i){return i.startAngle}function pn(i){return i.endAngle}function xn(i){return i&&i.padAngle}function mn(i,d,C,R,v,b,B,a){var H=C-i,r=R-d,n=B-v,p=a-b,u=p*H-n*r;if(!(u*u<l))return u=(n*(d-b)-p*(i-v))/u,[i+u*H,d+u*r]}function X(i,d,C,R,v,b,B){var a=i-C,H=d-R,r=(B?b:-b)/M(a*a+H*H),n=r*H,p=-r*a,u=i+n,s=d+p,y=C+n,f=R+p,D=(u+y)/2,o=(s+f)/2,x=y-u,g=f-s,j=x*x+g*g,T=v-b,A=u*f-y*s,W=(g<0?-1:1)*M(en(0,T*T*j-A*A)),_=(A*g-x*W)/j,$=(-A*x-g*W)/j,O=(A*g+x*W)/j,m=(-A*x+g*W)/j,h=_-D,t=$-o,c=O-D,I=m-o;return h*h+t*t>c*c+I*I&&(_=O,$=m),{cx:_,cy:$,x01:-n,y01:-p,x11:_*(v/T-1),y11:$*(v/T-1)}}function dn(){var i=fn,d=ln,C=z(0),R=null,v=gn,b=pn,B=xn,a=null,H=sn(r);function r(){var n,p,u=+i.apply(this,arguments),s=+d.apply(this,arguments),y=v.apply(this,arguments)-an,f=b.apply(this,arguments)-an,D=un(f-y),o=f>y;if(a||(a=n=H()),s<u&&(p=s,s=u,u=p),!(s>l))a.moveTo(0,0);else if(D>on-l)a.moveTo(s*L(y),s*F(y)),a.arc(0,0,s,y,f,!o),u>l&&(a.moveTo(u*L(f),u*F(f)),a.arc(0,0,u,f,y,o));else{var x=y,g=f,j=y,T=f,A=D,W=D,_=B.apply(this,arguments)/2,$=_>l&&(R?+R.apply(this,arguments):M(u*u+s*s)),O=E(un(s-u)/2,+C.apply(this,arguments)),m=O,h=O,t,c;if($>l){var I=rn($/u*F(_)),S=rn($/s*F(_));(A-=I*2)>l?(I*=o?1:-1,j+=I,T-=I):(A=0,j=T=(y+f)/2),(W-=S*2)>l?(S*=o?1:-1,x+=S,g-=S):(W=0,x=g=(y+f)/2)}var P=s*L(x),Y=s*F(x),Z=u*L(T),k=u*F(T);if(O>l){var G=s*L(g),U=s*F(g),N=u*L(j),Q=u*F(j),q;if(D<cn)if(q=mn(P,Y,N,Q,G,U,Z,k)){var V=P-q[0],w=Y-q[1],J=G-q[0],K=U-q[1],nn=1/F(yn((V*J+w*K)/(M(V*V+w*w)*M(J*J+K*K)))/2),tn=M(q[0]*q[0]+q[1]*q[1]);m=E(O,(u-tn)/(nn-1)),h=E(O,(s-tn)/(nn+1))}else m=h=0}W>l?h>l?(t=X(N,Q,P,Y,s,h,o),c=X(G,U,Z,k,s,h,o),a.moveTo(t.cx+t.x01,t.cy+t.y01),h<O?a.arc(t.cx,t.cy,h,e(t.y01,t.x01),e(c.y01,c.x01),!o):(a.arc(t.cx,t.cy,h,e(t.y01,t.x01),e(t.y11,t.x11),!o),a.arc(0,0,s,e(t.cy+t.y11,t.cx+t.x11),e(c.cy+c.y11,c.cx+c.x11),!o),a.arc(c.cx,c.cy,h,e(c.y11,c.x11),e(c.y01,c.x01),!o))):(a.moveTo(P,Y),a.arc(0,0,s,x,g,!o)):a.moveTo(P,Y),!(u>l)||!(A>l)?a.lineTo(Z,k):m>l?(t=X(Z,k,G,U,u,-m,o),c=X(P,Y,N,Q,u,-m,o),a.lineTo(t.cx+t.x01,t.cy+t.y01),m<O?a.arc(t.cx,t.cy,m,e(t.y01,t.x01),e(c.y01,c.x01),!o):(a.arc(t.cx,t.cy,m,e(t.y01,t.x01),e(t.y11,t.x11),!o),a.arc(0,0,u,e(t.cy+t.y11,t.cx+t.x11),e(c.cy+c.y11,c.cx+c.x11),o),a.arc(c.cx,c.cy,m,e(c.y11,c.x11),e(c.y01,c.x01),!o))):a.arc(0,0,u,T,j,o)}if(a.closePath(),n)return a=null,n+""||null}return r.centroid=function(){var n=(+i.apply(this,arguments)+ +d.apply(this,arguments))/2,p=(+v.apply(this,arguments)+ +b.apply(this,arguments))/2-cn/2;return[L(p)*n,F(p)*n]},r.innerRadius=function(n){return arguments.length?(i=typeof n=="function"?n:z(+n),r):i},r.outerRadius=function(n){return arguments.length?(d=typeof n=="function"?n:z(+n),r):d},r.cornerRadius=function(n){return arguments.length?(C=typeof n=="function"?n:z(+n),r):C},r.padRadius=function(n){return arguments.length?(R=n==null?null:typeof n=="function"?n:z(+n),r):R},r.startAngle=function(n){return arguments.length?(v=typeof n=="function"?n:z(+n),r):v},r.endAngle=function(n){return arguments.length?(b=typeof n=="function"?n:z(+n),r):b},r.padAngle=function(n){return arguments.length?(B=typeof n=="function"?n:z(+n),r):B},r.context=function(n){return arguments.length?(a=n??null,r):a},r}export{dn as h};
|