orbitchat 2.5.6 → 2.6.0
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 +19 -0
- package/dist/assets/{_baseUniq-BPMphbq5-DyhKuQ9D.js → _baseUniq-BPMphbq5-DK8uj0iN.js} +1 -1
- package/dist/assets/api-UOder4a5.js +2 -0
- package/dist/assets/{arc-D9rhTKV0-DNQNLJPM.js → arc-D9rhTKV0-C_TU0c8u.js} +1 -1
- package/dist/assets/{architectureDiagram-VXUJARFQ-BiqZtsDe-OAB_WdXP.js → architectureDiagram-VXUJARFQ-BiqZtsDe-Ckz8cTrX.js} +1 -1
- package/dist/assets/{blockDiagram-VD42YOAC-zcRIdFTD-Co_XtUK4.js → blockDiagram-VD42YOAC-zcRIdFTD-5cQzvB99.js} +1 -1
- package/dist/assets/{c4Diagram-YG6GDRKO-DYXNcDX4-CHxegSJq.js → c4Diagram-YG6GDRKO-DYXNcDX4-qMZnFa9N.js} +1 -1
- package/dist/assets/channel-CUIutAfm-DHH2zzA-.js +1 -0
- package/dist/assets/{chunk-4BX2VUAB-DAh9ktmY-BMA6rd4j.js → chunk-4BX2VUAB-DAh9ktmY-Z-hvroUt.js} +1 -1
- package/dist/assets/{chunk-55IACEB6-Cza7pcpr-D7qVo0l1.js → chunk-55IACEB6-Cza7pcpr-BIXxhcfE.js} +1 -1
- package/dist/assets/{chunk-B4BG7PRW-BTUSpeKy-Cv9tn5FL.js → chunk-B4BG7PRW-BTUSpeKy-CA2Ojxjp.js} +1 -1
- package/dist/assets/{chunk-DI55MBZ5-DKt4WII7-CD7PH56S.js → chunk-DI55MBZ5-DKt4WII7-D0Z1Yfx-.js} +1 -1
- package/dist/assets/{chunk-FMBD7UC4-DdcCR8w3-f2kPxnxt.js → chunk-FMBD7UC4-DdcCR8w3-BrAEPIYw.js} +1 -1
- package/dist/assets/{chunk-QN33PNHL-v6AkzOl1-BDN4BA8H.js → chunk-QN33PNHL-v6AkzOl1-DyCbM7qo.js} +1 -1
- package/dist/assets/{chunk-QZHKN3VN-DVJOrqBZ-C9KSl1Oi.js → chunk-QZHKN3VN-DVJOrqBZ-B-17yvPu.js} +1 -1
- package/dist/assets/{chunk-TZMSLE5B-G2jJHqli-BEWUJNAb.js → chunk-TZMSLE5B-G2jJHqli-D4iQseQE.js} +1 -1
- package/dist/assets/{classDiagram-2ON5EDUG-CxmgTanh-D8XJiPRf.js → classDiagram-2ON5EDUG-CxmgTanh-0tZ-fjzP.js} +1 -1
- package/dist/assets/{classDiagram-v2-WZHVMYZB-CxmgTanh-D8XJiPRf.js → classDiagram-v2-WZHVMYZB-CxmgTanh-0tZ-fjzP.js} +1 -1
- package/dist/assets/clone-CsNB4mMi-BsB8G4dn.js +1 -0
- package/dist/assets/{cose-bilkent-S5V4N54A-BRr2Y6dg-D6uw80ha.js → cose-bilkent-S5V4N54A-BRr2Y6dg-BsS62q2A.js} +1 -1
- package/dist/assets/{dagre-6UL2VRFP-DX8gNHmJ-DMpjORIV.js → dagre-6UL2VRFP-DX8gNHmJ-CoOb1GXn.js} +1 -1
- package/dist/assets/{diagram-PSM6KHXK-DNX818To-CxJ9VQrf.js → diagram-PSM6KHXK-DNX818To-y91X1kzM.js} +1 -1
- package/dist/assets/{diagram-QEK2KX5R-BDO6hKtm-J0PP4QNf.js → diagram-QEK2KX5R-BDO6hKtm-RZf2raNH.js} +1 -1
- package/dist/assets/{diagram-S2PKOQOG-IEqaDwzi-CJ60bco2.js → diagram-S2PKOQOG-IEqaDwzi-CGnSaF3y.js} +1 -1
- package/dist/assets/{erDiagram-Q2GNP2WA-DbLpN8Jp-B76YSpnw.js → erDiagram-Q2GNP2WA-DbLpN8Jp-prYYJKbj.js} +1 -1
- package/dist/assets/{flowDiagram-NV44I4VS-pJlHae8Y-V2lN8HRy.js → flowDiagram-NV44I4VS-pJlHae8Y-DMbCCRL8.js} +1 -1
- package/dist/assets/{ganttDiagram-JELNMOA3-J0Tkq5TR-CDnKa5cJ.js → ganttDiagram-JELNMOA3-J0Tkq5TR-FvYspTob.js} +1 -1
- package/dist/assets/{gitGraphDiagram-NY62KEGX-DgYonpsZ-BnPQvCQc.js → gitGraphDiagram-NY62KEGX-DgYonpsZ-D6bO88vd.js} +1 -1
- package/dist/assets/{graph-BpcfrHXY-r8ucjuVo.js → graph-BpcfrHXY-CnHMWDgG.js} +1 -1
- package/dist/assets/{index-BIBo0u38.js → index-CPe_kpcr.js} +209 -211
- package/dist/assets/{index-DvNpGWs7-DSHfKWeY.js → index-DvNpGWs7-Dd8PMLKJ.js} +1 -1
- package/dist/assets/{infoDiagram-WHAUD3N6-C3JLOAnb-DZz70Wlt.js → infoDiagram-WHAUD3N6-C3JLOAnb-CEXRMoiA.js} +1 -1
- package/dist/assets/{journeyDiagram-XKPGCS4Q-CfjB2Qdf-LESHFhGE.js → journeyDiagram-XKPGCS4Q-CfjB2Qdf-CzC6LxVj.js} +1 -1
- package/dist/assets/{kanban-definition-3W4ZIXB7-CrW8yVmd-CS7O7CRH.js → kanban-definition-3W4ZIXB7-CrW8yVmd-CaA_wlGY.js} +1 -1
- package/dist/assets/{layout-bsfAhWjc-0bqYAaFs.js → layout-bsfAhWjc-C7-Zh4zT.js} +1 -1
- package/dist/assets/{min-C2aDz5ZK-DHktDX_3.js → min-C2aDz5ZK-Bk5ngwFA.js} +1 -1
- package/dist/assets/{mindmap-definition-VGOIOE7T-Dj37RkY_-Q2Y5JCNR.js → mindmap-definition-VGOIOE7T-Dj37RkY_-CzgANszm.js} +1 -1
- package/dist/assets/{pieDiagram-ADFJNKIX-BiQvDx8I-Csm4P_6v.js → pieDiagram-ADFJNKIX-BiQvDx8I-CQC3tVW-.js} +1 -1
- package/dist/assets/{quadrantDiagram-AYHSOK5B-D4b-YFzI-DgqYZ4Fj.js → quadrantDiagram-AYHSOK5B-D4b-YFzI-D32ZWyTy.js} +1 -1
- package/dist/assets/{requirementDiagram-UZGBJVZJ-km07nlVd-Czal8CN1.js → requirementDiagram-UZGBJVZJ-km07nlVd-C10EkZ67.js} +1 -1
- package/dist/assets/{sankeyDiagram-TZEHDZUN-LfuSRRbf-DbQtBnKn.js → sankeyDiagram-TZEHDZUN-LfuSRRbf-BrhQ3MTW.js} +1 -1
- package/dist/assets/{sequenceDiagram-WL72ISMW-CQ4J-0_7-DA8azeWg.js → sequenceDiagram-WL72ISMW-CQ4J-0_7-BJEeV0Qq.js} +1 -1
- package/dist/assets/{stateDiagram-FKZM4ZOC-JtogJwt6-CAuan9bg.js → stateDiagram-FKZM4ZOC-JtogJwt6-BI-H-Whv.js} +1 -1
- package/dist/assets/{stateDiagram-v2-4FDKWEC3-DuQ7UaeU-wMtwfJb0.js → stateDiagram-v2-4FDKWEC3-DuQ7UaeU-DER8GNg1.js} +1 -1
- package/dist/assets/{timeline-definition-IT6M3QCI-Cs3NnF2M-CHRQfxoL.js → timeline-definition-IT6M3QCI-Cs3NnF2M-Cv79_UZT.js} +1 -1
- package/dist/assets/{treemap-KMMF4GRG-CkW25-tn-B1iWs4HR.js → treemap-KMMF4GRG-CkW25-tn-CAIo8Xs2.js} +1 -1
- package/dist/assets/{xychartDiagram-PRI3JC2R-JzAaXa5z-0D-bLJ7B.js → xychartDiagram-PRI3JC2R-JzAaXa5z-DmgAzkNT.js} +1 -1
- package/dist/favicon.svg +1 -0
- package/dist/index.html +2 -2
- package/package.json +2 -2
- package/dist/assets/api-CD9Nzq0O.js +0 -2
- package/dist/assets/channel-CUIutAfm-CRfssE8A.js +0 -1
- package/dist/assets/clone-CsNB4mMi-CrH0uuE1.js +0 -1
- package/dist/orbit-icon.svg +0 -1
package/bin/orbitchat.js
CHANGED
|
@@ -26,6 +26,7 @@ const __dirname = dirname(__filename);
|
|
|
26
26
|
const DEFAULT_CONFIG = {
|
|
27
27
|
apiUrl: 'http://localhost:3000',
|
|
28
28
|
defaultKey: 'default-key',
|
|
29
|
+
applicationName: 'ORBIT Chat',
|
|
29
30
|
useLocalApi: false,
|
|
30
31
|
localApiPath: undefined,
|
|
31
32
|
consoleDebug: false,
|
|
@@ -110,6 +111,9 @@ function parseArgs() {
|
|
|
110
111
|
case '--default-key':
|
|
111
112
|
config.defaultKey = args[++i];
|
|
112
113
|
break;
|
|
114
|
+
case '--application-name':
|
|
115
|
+
config.applicationName = args[++i];
|
|
116
|
+
break;
|
|
113
117
|
case '--use-local-api':
|
|
114
118
|
config.useLocalApi = true;
|
|
115
119
|
break;
|
|
@@ -215,6 +219,7 @@ function loadConfigFromEnv() {
|
|
|
215
219
|
const envMap = {
|
|
216
220
|
VITE_API_URL: 'apiUrl',
|
|
217
221
|
VITE_DEFAULT_KEY: 'defaultKey',
|
|
222
|
+
VITE_APPLICATION_NAME: 'applicationName',
|
|
218
223
|
VITE_USE_LOCAL_API: 'useLocalApi',
|
|
219
224
|
VITE_LOCAL_API_PATH: 'localApiPath',
|
|
220
225
|
VITE_CONSOLE_DEBUG: 'consoleDebug',
|
|
@@ -300,6 +305,19 @@ function injectConfig(html, config) {
|
|
|
300
305
|
'<!-- Config injected in head -->'
|
|
301
306
|
);
|
|
302
307
|
|
|
308
|
+
// Replace the title tag with the configured application name
|
|
309
|
+
if (config.applicationName) {
|
|
310
|
+
html = html.replace(
|
|
311
|
+
/<title>.*?<\/title>/i,
|
|
312
|
+
`<title>${config.applicationName}</title>`
|
|
313
|
+
);
|
|
314
|
+
// Also update apple-mobile-web-app-title meta tag
|
|
315
|
+
html = html.replace(
|
|
316
|
+
/<meta name="apple-mobile-web-app-title" content="[^"]*" \/>/i,
|
|
317
|
+
`<meta name="apple-mobile-web-app-title" content="${config.applicationName}" />`
|
|
318
|
+
);
|
|
319
|
+
}
|
|
320
|
+
|
|
303
321
|
// Inject the config script at the START of <head>, before any other scripts
|
|
304
322
|
// This ensures window.ORBIT_CHAT_CONFIG is available when the main JS bundle loads
|
|
305
323
|
return html.replace(
|
|
@@ -559,6 +577,7 @@ Usage: orbitchat [options]
|
|
|
559
577
|
Options:
|
|
560
578
|
--api-url URL API URL (default: http://localhost:3000)
|
|
561
579
|
--api-key KEY Default API key (default: default-key)
|
|
580
|
+
--application-name NAME Application name shown in browser tab (default: ORBIT Chat)
|
|
562
581
|
--use-local-api Use local API build (default: false)
|
|
563
582
|
--local-api-path PATH Path to local API
|
|
564
583
|
--console-debug Enable console debug (default: false)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{bI as cr,bJ as ir,aT as Z,aL as h,aM as U,bK as A,bL as lr,aQ as sr,bx as k,bs as P,bM as vr,bN as br,aR as hr,bO as X,bo as K,bp as N,bP as gr,bz as _,aH as pr,bQ as R,bR as yr,aU as dr}from"./index-
|
|
1
|
+
import{bI as cr,bJ as ir,aT as Z,aL as h,aM as U,bK as A,bL as lr,aQ as sr,bx as k,bs as P,bM as vr,bN as br,aR as hr,bO as X,bo as K,bp as N,bP as gr,bz as _,aH as pr,bQ as R,bR as yr,aU as dr}from"./index-CPe_kpcr.js";var jr="[object Symbol]";function z(r){return typeof r=="symbol"||k(r)&&vr(r)==jr}function _r(r,t){for(var e=-1,n=r==null?0:r.length,a=Array(n);++e<n;)a[e]=t(r[e],e,r);return a}var D=_?_.prototype:void 0,E=D?D.toString:void 0;function V(r){if(typeof r=="string")return r;if(h(r))return _r(r,V)+"";if(z(r))return E?E.call(r):"";var t=r+"";return t=="0"&&1/r==-1/0?"-0":t}function mr(){}function wr(r,t){for(var e=-1,n=r==null?0:r.length;++e<n&&t(r[e],e,r)!==!1;);return r}function Or(r,t,e,n){for(var a=r.length,u=e+-1;++u<a;)if(t(r[u],u,r))return u;return-1}function Lr(r){return r!==r}function Pr(r,t,e){for(var n=e-1,a=r.length;++n<a;)if(r[n]===t)return n;return-1}function Sr(r,t,e){return t===t?Pr(r,t,e):Or(r,Lr,e)}function Ar(r,t){var e=r==null?0:r.length;return!!e&&Sr(r,t,0)>-1}function M(r){return Z(r)?cr(r):ir(r)}var Br=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,kr=/^\w*$/;function $(r,t){if(h(r))return!1;var e=typeof r;return e=="number"||e=="symbol"||e=="boolean"||r==null||z(r)?!0:kr.test(r)||!Br.test(r)||t!=null&&r in Object(t)}var zr=500;function Mr(r){var t=yr(r,function(n){return e.size===zr&&e.clear(),n}),e=t.cache;return t}var $r=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,xr=/\\(\\)?/g,Cr=Mr(function(r){var t=[];return r.charCodeAt(0)===46&&t.push(""),r.replace($r,function(e,n,a,u){t.push(a?u.replace(xr,"$1"):n||e)}),t});function Fr(r){return r==null?"":V(r)}function W(r,t){return h(r)?r:$(r,t)?[r]:Cr(Fr(r))}function S(r){if(typeof r=="string"||z(r))return r;var t=r+"";return t=="0"&&1/r==-1/0?"-0":t}function rr(r,t){t=W(t,r);for(var e=0,n=t.length;r!=null&&e<n;)r=r[S(t[e++])];return e&&e==n?r:void 0}function Jr(r,t,e){var n=r==null?void 0:rr(r,t);return n===void 0?e:n}function tr(r,t){for(var e=-1,n=t.length,a=r.length;++e<n;)r[a+e]=t[e];return r}var H=_?_.isConcatSpreadable:void 0;function Kr(r){return h(r)||X(r)||!!(H&&r&&r[H])}function Et(r,t,e,n,a){var u=-1,o=r.length;for(e||(e=Kr),a||(a=[]);++u<o;){var f=r[u];e(f)?tr(a,f):n||(a[a.length]=f)}return a}function Nr(r,t,e,n){var a=-1,u=r==null?0:r.length;for(n&&u&&(e=r[++a]);++a<u;)e=t(e,r[a],a,r);return e}function er(r,t){for(var e=-1,n=r==null?0:r.length,a=0,u=[];++e<n;){var o=r[e];t(o,e,r)&&(u[a++]=o)}return u}function Rr(){return[]}var Dr=Object.prototype,Er=Dr.propertyIsEnumerable,I=Object.getOwnPropertySymbols,Hr=I?function(r){return r==null?[]:(r=Object(r),er(I(r),function(t){return Er.call(r,t)}))}:Rr;function Ir(r,t,e){var n=t(r);return h(r)?n:tr(n,e(r))}function T(r){return Ir(r,M,Hr)}var Tr="__lodash_hash_undefined__";function Yr(r){return this.__data__.set(r,Tr),this}function qr(r){return this.__data__.has(r)}function m(r){var t=-1,e=r==null?0:r.length;for(this.__data__=new lr;++t<e;)this.add(r[t])}m.prototype.add=m.prototype.push=Yr;m.prototype.has=qr;function Gr(r,t){for(var e=-1,n=r==null?0:r.length;++e<n;)if(t(r[e],e,r))return!0;return!1}function nr(r,t){return r.has(t)}var Qr=1,Zr=2;function ur(r,t,e,n,a,u){var o=e&Qr,f=r.length,c=t.length;if(f!=c&&!(o&&c>f))return!1;var v=u.get(r),l=u.get(t);if(v&&l)return v==t&&l==r;var i=-1,s=!0,p=e&Zr?new m:void 0;for(u.set(r,t),u.set(t,r);++i<f;){var b=r[i],g=t[i];if(n)var y=o?n(g,b,i,t,r,u):n(b,g,i,r,t,u);if(y!==void 0){if(y)continue;s=!1;break}if(p){if(!Gr(t,function(d,j){if(!nr(p,j)&&(b===d||a(b,d,e,n,u)))return p.push(j)})){s=!1;break}}else if(!(b===g||a(b,g,e,n,u))){s=!1;break}}return u.delete(r),u.delete(t),s}function Ur(r){var t=-1,e=Array(r.size);return r.forEach(function(n,a){e[++t]=[a,n]}),e}function x(r){var t=-1,e=Array(r.size);return r.forEach(function(n){e[++t]=n}),e}var Xr=1,Vr=2,Wr="[object Boolean]",rt="[object Date]",tt="[object Error]",et="[object Map]",nt="[object Number]",ut="[object RegExp]",at="[object Set]",ot="[object String]",ft="[object Symbol]",ct="[object ArrayBuffer]",it="[object DataView]",Y=_?_.prototype:void 0,B=Y?Y.valueOf:void 0;function lt(r,t,e,n,a,u,o){switch(e){case it:if(r.byteLength!=t.byteLength||r.byteOffset!=t.byteOffset)return!1;r=r.buffer,t=t.buffer;case ct:return!(r.byteLength!=t.byteLength||!u(new R(r),new R(t)));case Wr:case rt:case nt:return pr(+r,+t);case tt:return r.name==t.name&&r.message==t.message;case ut:case ot:return r==t+"";case et:var f=Ur;case at:var c=n&Xr;if(f||(f=x),r.size!=t.size&&!c)return!1;var v=o.get(r);if(v)return v==t;n|=Vr,o.set(r,t);var l=ur(f(r),f(t),n,a,u,o);return o.delete(r),l;case ft:if(B)return B.call(r)==B.call(t)}return!1}var st=1,vt=Object.prototype,bt=vt.hasOwnProperty;function ht(r,t,e,n,a,u){var o=e&st,f=T(r),c=f.length,v=T(t),l=v.length;if(c!=l&&!o)return!1;for(var i=c;i--;){var s=f[i];if(!(o?s in t:bt.call(t,s)))return!1}var p=u.get(r),b=u.get(t);if(p&&b)return p==t&&b==r;var g=!0;u.set(r,t),u.set(t,r);for(var y=o;++i<c;){s=f[i];var d=r[s],j=t[s];if(n)var J=o?n(j,d,s,t,r,u):n(d,j,s,r,t,u);if(!(J===void 0?d===j||a(d,j,e,n,u):J)){g=!1;break}y||(y=s=="constructor")}if(g&&!y){var w=r.constructor,O=t.constructor;w!=O&&"constructor"in r&&"constructor"in t&&!(typeof w=="function"&&w instanceof w&&typeof O=="function"&&O instanceof O)&&(g=!1)}return u.delete(r),u.delete(t),g}var gt=1,q="[object Arguments]",G="[object Array]",L="[object Object]",pt=Object.prototype,Q=pt.hasOwnProperty;function yt(r,t,e,n,a,u){var o=h(r),f=h(t),c=o?G:K(r),v=f?G:K(t);c=c==q?L:c,v=v==q?L:v;var l=c==L,i=v==L,s=c==v;if(s&&N(r)){if(!N(t))return!1;o=!0,l=!1}if(s&&!l)return u||(u=new P),o||gr(r)?ur(r,t,e,n,a,u):lt(r,t,c,e,n,a,u);if(!(e>)){var p=l&&Q.call(r,"__wrapped__"),b=i&&Q.call(t,"__wrapped__");if(p||b){var g=p?r.value():r,y=b?t.value():t;return u||(u=new P),a(g,y,e,n,u)}}return s?(u||(u=new P),ht(r,t,e,n,a,u)):!1}function C(r,t,e,n,a){return r===t?!0:r==null||t==null||!k(r)&&!k(t)?r!==r&&t!==t:yt(r,t,e,n,C,a)}var dt=1,jt=2;function _t(r,t,e,n){var a=e.length,u=a;if(r==null)return!u;for(r=Object(r);a--;){var o=e[a];if(o[2]?o[1]!==r[o[0]]:!(o[0]in r))return!1}for(;++a<u;){o=e[a];var f=o[0],c=r[f],v=o[1];if(o[2]){if(c===void 0&&!(f in r))return!1}else{var l=new P,i;if(!(i===void 0?C(v,c,dt|jt,n,l):i))return!1}}return!0}function ar(r){return r===r&&!sr(r)}function mt(r){for(var t=M(r),e=t.length;e--;){var n=t[e],a=r[n];t[e]=[n,a,ar(a)]}return t}function or(r,t){return function(e){return e==null?!1:e[r]===t&&(t!==void 0||r in Object(e))}}function wt(r){var t=mt(r);return t.length==1&&t[0][2]?or(t[0][0],t[0][1]):function(e){return e===r||_t(e,r,t)}}function Ot(r,t){return r!=null&&t in Object(r)}function Lt(r,t,e){t=W(t,r);for(var n=-1,a=t.length,u=!1;++n<a;){var o=S(t[n]);if(!(u=r!=null&&e(r,o)))break;r=r[o]}return u||++n!=a?u:(a=r==null?0:r.length,!!a&&br(a)&&hr(o,a)&&(h(r)||X(r)))}function Pt(r,t){return r!=null&&Lt(r,t,Ot)}var St=1,At=2;function Bt(r,t){return $(r)&&ar(t)?or(S(r),t):function(e){var n=Jr(e,r);return n===void 0&&n===t?Pt(e,r):C(t,n,St|At)}}function kt(r){return function(t){return t==null?void 0:t[r]}}function zt(r){return function(t){return rr(t,r)}}function Mt(r){return $(r)?kt(S(r)):zt(r)}function fr(r){return typeof r=="function"?r:r==null?U:typeof r=="object"?h(r)?Bt(r[0],r[1]):wt(r):Mt(r)}function $t(r,t){return r&&dr(r,t,M)}function xt(r,t){return function(e,n){if(e==null)return e;if(!Z(e))return r(e,n);for(var a=e.length,u=-1,o=Object(e);++u<a&&n(o[u],u,o)!==!1;);return e}}var F=xt($t);function Ct(r){return typeof r=="function"?r:U}function Ht(r,t){var e=h(r)?wr:F;return e(r,Ct(t))}function Ft(r,t){var e=[];return F(r,function(n,a,u){t(n,a,u)&&e.push(n)}),e}function It(r,t){var e=h(r)?er:Ft;return e(r,fr(t))}function Jt(r,t,e,n,a){return a(r,function(u,o,f){e=n?(n=!1,u):t(e,u,o,f)}),e}function Tt(r,t,e){var n=h(r)?Nr:Jt,a=arguments.length<3;return n(r,fr(t),e,a,F)}var Kt=1/0,Nt=A&&1/x(new A([,-0]))[1]==Kt?function(r){return new A(r)}:mr,Rt=200;function Yt(r,t,e){var n=-1,a=Ar,u=r.length,o=!0,f=[],c=f;if(u>=Rt){var v=t?null:Nt(r);if(v)return x(v);o=!1,a=nr,c=new m}else c=t?[]:f;r:for(;++n<u;){var l=r[n],i=t?t(l):l;if(l=l!==0?l:0,o&&i===i){for(var s=c.length;s--;)if(c[s]===i)continue r;t&&c.push(i),f.push(l)}else a(c,i,e)||(c!==f&&c.push(i),f.push(l))}return f}export{$t as $,Et as B,wr as E,Ct as F,Fr as G,S as I,Yt as J,Rr as K,M,Lt as T,Tt as Y,It as Z,fr as a,Pt as b,Or as c,T as d,Hr as e,Ir as f,F as g,W as j,rr as n,Ht as q,tr as r,_r as v,z as x};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{_ as O}from"./index-CPe_kpcr.js";var q=Object.defineProperty,D=(c,i,e)=>i in c?q(c,i,{enumerable:!0,configurable:!0,writable:!0,value:e}):c[i]=e,I=(c,i,e)=>D(c,typeof i!="symbol"?i+"":i,e);let F=null,$=null;typeof window>"u"&&Promise.all([O(()=>import("./__vite-browser-external-BIHI7g3E.js"),[]).catch(()=>null),O(()=>import("./__vite-browser-external-BIHI7g3E.js"),[]).catch(()=>null)]).then(([c,i])=>{var e,t;(e=c==null?void 0:c.default)!=null&&e.Agent?F=new c.default.Agent({keepAlive:!0}):c!=null&&c.Agent&&(F=new c.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(c=>{console.warn("Failed to initialize HTTP agents:",c.message)});class N{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,n;try{const o=JSON.parse(r);s=o.detail||o.message||r}catch{s=r||`HTTP ${e.status}`}switch(e.status){case 401:n="API key is invalid or expired";break;case 403:n="Access denied: API key does not have required permissions";break;case 404:n="API key not found";break;case 503:n="API key management is not available in inference-only mode";break;default:n=`Failed to validate API key: ${s}`;break}throw new Error(n)}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/adapters/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 n=JSON.parse(t);r=n.detail||n.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,n]of Object.entries(r))(s.toLowerCase()!=="x-api-key"||!this.apiKey)&&(t[s]=n)}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,n,o,d,u,f,v){const l={messages:[{role:"user",content:i}],stream:e};return t&&t.length>0&&(l.file_ids=t),r&&(l.thread_id=r),s&&(l.audio_input=s),n&&(l.audio_format=n),o&&(l.language=o),d!==void 0&&(l.return_audio=d),u&&(l.tts_voice=u),f&&(l.source_language=f),v&&(l.target_language=v),l}async*streamChat(i,e=!0,t,r,s,n,o,d,u,f,v){var l,C,b;try{const y=new AbortController,_=setTimeout(()=>y.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,n,o,d,u,f,v))}),signal:y.signal});if(clearTimeout(_),!g.ok){const p=await g.text();throw new Error(`Network response was not ok: ${g.status} ${p}`)}if(!e){const p=await g.json();p.response&&(yield{text:p.response,done:!0,audio:p.audio,audioFormat:p.audio_format});return}const A=(l=g.body)==null?void 0:l.getReader();if(!A)throw new Error("No reader available");const S=new TextDecoder;let w="",E=!1;try{for(;;){const{done:p,value:U}=await A.read();if(p)break;const j=S.decode(U,{stream:!0});w+=j;let k=0,P;for(;(P=w.indexOf(`
|
|
2
|
+
`,k))!==-1;){const m=w.slice(k,P).trim();if(k=P+1,m&&m.startsWith("data: ")){const h=m.slice(6).trim();if(!h||h==="[DONE]"){yield{text:"",done:!0};return}try{const a=JSON.parse(h);if(a.error){const x=`Server error: ${((C=a.error)==null?void 0:C.message)||a.error||"Unknown server error"}`;throw console.warn(`[ApiClient] ${x}`),new Error(x)}if(a.done===!0){E=!0,yield{text:"",done:!0,audio:a.audio,audioFormat:a.audio_format||a.audioFormat,threading:a.threading};return}const K=a.response||"";a.audio_chunk!==void 0&&(yield{text:"",done:!1,audio_chunk:a.audio_chunk,audioFormat:a.audioFormat||a.audio_format||"opus",chunk_index:a.chunk_index??0}),(K||a.audio)&&(E=!0,yield{text:K,done:a.done||!1,audio:a.audio,audioFormat:a.audio_format||a.audioFormat,threading:a.threading})}catch(a){if((b=a==null?void 0:a.message)!=null&&b.startsWith("Server error:"))throw a;console.warn("[ApiClient] Unable to parse server response. This may be a temporary issue."),console.warn("[ApiClient] Parse error details:",a==null?void 0:a.message),console.warn("[ApiClient] JSON text length:",h==null?void 0:h.length),console.warn("[ApiClient] JSON text preview (first 200 chars):",h==null?void 0:h.substring(0,200)),console.warn("[ApiClient] JSON text preview (last 200 chars):",h==null?void 0:h.substring(h.length-200))}}else m&&(E=!0,yield{text:m,done:!1})}w=w.slice(k),w.length>1e6&&(console.warn("[ApiClient] Buffer too large, truncating..."),w=w.slice(-5e5))}E&&(yield{text:"",done:!0})}finally{A.releaseLock()}}catch(y){throw y.name==="AbortError"?new Error("Connection timed out. Please check if the server is running."):y.name==="TypeError"&&y.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):y}}async getConversationHistory(i,e){const t=i||this.sessionId;if(!t)throw new Error("No session ID provided and no current session available");const r={};this.apiKey&&(r["X-API-Key"]=this.apiKey);try{const s=new URL(`${this.apiUrl}/admin/chat-history/${t}`);typeof e=="number"&&Number.isFinite(e)&&e>0&&s.searchParams.set("limit",String(Math.floor(e)));const n=await fetch(s.toString(),{...this.getFetchOptions({method:"GET",headers:r})});if(!n.ok){const f=await n.text();throw new Error(`Failed to fetch conversation history: ${n.status} ${f}`)}const o=await n.json(),d=Array.isArray(o==null?void 0:o.messages)?o.messages:[],u=typeof(o==null?void 0:o.count)=="number"?o.count:d.length;return{session_id:(o==null?void 0:o.session_id)||t,messages:d,count:u}}catch(s){throw s.name==="TypeError"&&s.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):s}}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(",")}`:"",n=`${this.apiUrl}/admin/conversations/${t}${s}`;try{const o=await fetch(n,{...this.getFetchOptions({method:"DELETE",headers:r})});if(!o.ok){const d=await o.text();throw new Error(`Failed to delete conversation: ${o.status} ${d}`)}return await o.json()}catch(o){throw o.name==="TypeError"&&o.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):o}}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 n;try{const o=JSON.parse(s);n=o.detail||o.message||`Failed to delete file (HTTP ${r.status})`}catch{n=`Failed to delete file (HTTP ${r.status})`}throw console.warn(`[ApiClient] ${n}`),new Error(n)}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 X=(c,i=null,e=null)=>{T=new N({apiUrl:c,apiKey:i,sessionId:e})};async function*H(c,i=!0,e,t,r,s,n,o,d,u,f){if(!T)throw new Error("API not configured. Please call configureApi() with your server URL before using any API functions.");yield*T.streamChat(c,i,e,t,r,s,n,o,d,u,f)}export{N as ApiClient,X as configureApi,H as streamChat};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{b0 as sn,b1 as an,b2 as l,as as on,b3 as L,b4 as q,b5 as E,b6 as un,aq as D,b7 as cn,b8 as z,b9 as e,ba as rn,bb as en,bc as yn}from"./index-
|
|
1
|
+
import{b0 as sn,b1 as an,b2 as l,as as on,b3 as L,b4 as q,b5 as E,b6 as un,aq as D,b7 as cn,b8 as z,b9 as e,ba as rn,bb as en,bc as yn}from"./index-CPe_kpcr.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,W,B,v,b,G,a){var C=W-i,r=B-d,n=G-v,p=a-b,u=p*C-n*r;if(!(u*u<l))return u=(n*(d-b)-p*(i-v))/u,[i+u*C,d+u*r]}function U(i,d,W,B,v,b,G){var a=i-W,C=d-B,r=(G?b:-b)/z(a*a+C*C),n=r*C,p=-r*a,u=i+n,s=d+p,y=W+n,f=B+p,H=(u+y)/2,o=(s+f)/2,x=y-u,g=f-s,T=x*x+g*g,A=v-b,O=u*f-y*s,J=(g<0?-1:1)*z(en(0,A*A*T-O*O)),P=(O*g-x*J)/T,_=(-O*x-g*J)/T,R=(O*g+x*J)/T,m=(-O*x+g*J)/T,h=P-H,t=_-o,c=R-H,I=m-o;return h*h+t*t>c*c+I*I&&(P=R,_=m),{cx:P,cy:_,x01:-n,y01:-p,x11:P*(v/A-1),y11:_*(v/A-1)}}function dn(){var i=fn,d=ln,W=D(0),B=null,v=gn,b=pn,G=xn,a=null,C=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,H=un(f-y),o=f>y;if(a||(a=n=C()),s<u&&(p=s,s=u,u=p),!(s>l))a.moveTo(0,0);else if(H>on-l)a.moveTo(s*L(y),s*q(y)),a.arc(0,0,s,y,f,!o),u>l&&(a.moveTo(u*L(f),u*q(f)),a.arc(0,0,u,f,y,o));else{var x=y,g=f,T=y,A=f,O=H,J=H,P=G.apply(this,arguments)/2,_=P>l&&(B?+B.apply(this,arguments):z(u*u+s*s)),R=E(un(s-u)/2,+W.apply(this,arguments)),m=R,h=R,t,c;if(_>l){var I=rn(_/u*q(P)),S=rn(_/s*q(P));(O-=I*2)>l?(I*=o?1:-1,T+=I,A-=I):(O=0,T=A=(y+f)/2),(J-=S*2)>l?(S*=o?1:-1,x+=S,g-=S):(J=0,x=g=(y+f)/2)}var $=s*L(x),j=s*q(x),X=u*L(A),Z=u*q(A);if(R>l){var k=s*L(g),N=s*q(g),V=u*L(T),Y=u*q(T),F;if(H<cn)if(F=mn($,j,V,Y,k,N,X,Z)){var K=$-F[0],M=j-F[1],Q=k-F[0],w=N-F[1],nn=1/q(yn((K*Q+M*w)/(z(K*K+M*M)*z(Q*Q+w*w)))/2),tn=z(F[0]*F[0]+F[1]*F[1]);m=E(R,(u-tn)/(nn-1)),h=E(R,(s-tn)/(nn+1))}else m=h=0}J>l?h>l?(t=U(V,Y,$,j,s,h,o),c=U(k,N,X,Z,s,h,o),a.moveTo(t.cx+t.x01,t.cy+t.y01),h<R?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($,j),a.arc(0,0,s,x,g,!o)):a.moveTo($,j),!(u>l)||!(O>l)?a.lineTo(X,Z):m>l?(t=U(X,Z,k,N,u,-m,o),c=U($,j,V,Y,u,-m,o),a.lineTo(t.cx+t.x01,t.cy+t.y01),m<R?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,A,T,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,q(p)*n]},r.innerRadius=function(n){return arguments.length?(i=typeof n=="function"?n:D(+n),r):i},r.outerRadius=function(n){return arguments.length?(d=typeof n=="function"?n:D(+n),r):d},r.cornerRadius=function(n){return arguments.length?(W=typeof n=="function"?n:D(+n),r):W},r.padRadius=function(n){return arguments.length?(B=n==null?null:typeof n=="function"?n:D(+n),r):B},r.startAngle=function(n){return arguments.length?(v=typeof n=="function"?n:D(+n),r):v},r.endAngle=function(n){return arguments.length?(b=typeof n=="function"?n:D(+n),r):b},r.padAngle=function(n){return arguments.length?(G=typeof n=="function"?n:D(+n),r):G},r.context=function(n){return arguments.length?(a=n??null,r):a},r}export{dn as h};
|