@eclipse-docks/extension-webllm 0.7.68

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.
@@ -0,0 +1,11 @@
1
+ //#region src/i18n.de.json
2
+ var EXT_WEBLLM_NAME = "WebLLM";
3
+ var EXT_WEBLLM_DESC = "LLM-Inferenz im Browser";
4
+ var i18n_de_default = {
5
+ EXT_WEBLLM_NAME,
6
+ EXT_WEBLLM_DESC
7
+ };
8
+ //#endregion
9
+ export { EXT_WEBLLM_DESC, EXT_WEBLLM_NAME, i18n_de_default as default };
10
+
11
+ //# sourceMappingURL=i18n.de-CQxA5kmG.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i18n.de-CQxA5kmG.js","names":[],"sources":["../src/i18n.de.json"],"sourcesContent":["{\n \"EXT_WEBLLM_NAME\": \"WebLLM\",\n \"EXT_WEBLLM_DESC\": \"LLM-Inferenz im Browser\"\n}\n"],"mappings":""}
@@ -0,0 +1,11 @@
1
+ //#region src/i18n.en.json
2
+ var EXT_WEBLLM_NAME = "WebLLM";
3
+ var EXT_WEBLLM_DESC = "In-Browser LLM inference";
4
+ var i18n_en_default = {
5
+ EXT_WEBLLM_NAME,
6
+ EXT_WEBLLM_DESC
7
+ };
8
+ //#endregion
9
+ export { EXT_WEBLLM_DESC, EXT_WEBLLM_NAME, i18n_en_default as default };
10
+
11
+ //# sourceMappingURL=i18n.en-BIC1ZmXn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i18n.en-BIC1ZmXn.js","names":[],"sources":["../src/i18n.en.json"],"sourcesContent":["{\n \"EXT_WEBLLM_NAME\": \"WebLLM\",\n \"EXT_WEBLLM_DESC\": \"In-Browser LLM inference\"\n}\n"],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":""}
package/dist/index.js ADDED
@@ -0,0 +1,18 @@
1
+ import { extensionRegistry, i18n } from "@eclipse-docks/core";
2
+ import pkg from "../package.json";
3
+ //#region src/index.ts
4
+ var t = await i18n(/* @__PURE__ */ Object.assign({
5
+ "./i18n.de.json": () => import("./i18n.de-CQxA5kmG.js"),
6
+ "./i18n.en.json": () => import("./i18n.en-BIC1ZmXn.js")
7
+ }), true);
8
+ extensionRegistry.registerExtension({
9
+ id: pkg.name,
10
+ name: t.EXT_WEBLLM_NAME,
11
+ description: t.EXT_WEBLLM_DESC,
12
+ loader: () => import("./webllmservice-Bdz7vrud.js"),
13
+ icon: "robot",
14
+ experimental: true
15
+ });
16
+ //#endregion
17
+
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","names":[],"sources":["../src/index.ts"],"sourcesContent":["import { extensionRegistry, i18n } from '@eclipse-docks/core';\nimport pkg from '../package.json';\n\nconst t = await i18n(import.meta.glob('./i18n*.json'), true);\n\nextensionRegistry.registerExtension({\n id: pkg.name,\n name: t.EXT_WEBLLM_NAME,\n description: t.EXT_WEBLLM_DESC,\n loader: () => import(\"./webllmservice\"),\n icon: \"robot\",\n experimental: true,\n\n});\n"],"mappings":";;;AAGA,IAAM,IAAI,MAAM,KAAK,uBAAA,OAAA;CAAA,wBAAA,OAAA;CAAA,wBAAA,OAAA;CAAA,CAAgC,EAAE,KAAK;AAE5D,kBAAkB,kBAAkB;CAClC,IAAI,IAAI;CACR,MAAM,EAAE;CACR,aAAa,EAAE;CACf,cAAc,OAAO;CACrB,MAAM;CACN,cAAc;CAEf,CAAC"}
@@ -0,0 +1,50 @@
1
+ import { createLogger } from "@eclipse-docks/core";
2
+ import { MLCEngine } from "@mlc-ai/web-llm";
3
+ import { aiService } from "@eclipse-docks/extension-ai-system/api";
4
+ //#region src/webllmservice.ts
5
+ var logger = createLogger("WebLLM");
6
+ var WebLLMProvider = class {
7
+ constructor() {
8
+ this.name = "webllm";
9
+ }
10
+ canHandle(chatProvider) {
11
+ return chatProvider.name === "webllm";
12
+ }
13
+ async init(model, parameters) {
14
+ if (this.engine) return;
15
+ const initProgressCallback = (progress) => {
16
+ logger.debug("Model loading progress:", progress);
17
+ };
18
+ this.engine = new MLCEngine({ initProgressCallback });
19
+ await this.engine.reload(model, parameters);
20
+ }
21
+ async *stream(params) {
22
+ if (!this.engine) await this.init(params.model, params.chatConfig.parameters);
23
+ const internalMessages = params.messages.map((message) => {
24
+ return { ...message };
25
+ });
26
+ const message = (await this.engine.chat.completions.create({ messages: internalMessages })).choices[0].message;
27
+ if (message.content) for (const char of message.content) yield {
28
+ type: "token",
29
+ content: char
30
+ };
31
+ yield {
32
+ type: "done",
33
+ content: ""
34
+ };
35
+ }
36
+ async complete(params) {
37
+ if (!this.engine) await this.init(params.model, params.chatConfig.parameters);
38
+ const internalMessages = params.messages.map((message) => {
39
+ return { ...message };
40
+ });
41
+ return (await this.engine.chat.completions.create({ messages: internalMessages })).choices[0].message;
42
+ }
43
+ };
44
+ var webllmservice_default = () => {
45
+ aiService.registerStreamingFetcher(new WebLLMProvider());
46
+ };
47
+ //#endregion
48
+ export { webllmservice_default as default };
49
+
50
+ //# sourceMappingURL=webllmservice-Bdz7vrud.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"webllmservice-Bdz7vrud.js","names":[],"sources":["../src/webllmservice.ts"],"sourcesContent":["import {ChatCompletionMessageParam, MLCEngine} from \"@mlc-ai/web-llm\";\nimport { createLogger } from \"@eclipse-docks/core\";\nimport type {ChatMessage, ChatProvider, StreamChunk} from \"@eclipse-docks/extension-ai-system/api\";\n\nconst logger = createLogger('WebLLM');\nimport type {IProvider, StreamingParams, CompletionParams} from \"@eclipse-docks/extension-ai-system/api\";\nimport {aiService} from \"@eclipse-docks/extension-ai-system/api\";\n\nclass WebLLMProvider implements IProvider {\n name = \"webllm\";\n private engine?: MLCEngine;\n\n canHandle(chatProvider: ChatProvider): boolean {\n return chatProvider.name === \"webllm\";\n }\n\n private async init(model: string, parameters?: any): Promise<void> {\n if (this.engine) return;\n \n const initProgressCallback = (progress: any) => {\n logger.debug(\"Model loading progress:\", progress);\n };\n\n this.engine = new MLCEngine({initProgressCallback});\n await this.engine.reload(model, parameters);\n }\n\n async *stream(params: StreamingParams): AsyncIterable<StreamChunk> {\n if (!this.engine) {\n await this.init(params.model, params.chatConfig.parameters);\n }\n \n const internalMessages = params.messages.map((message) => {\n return {...message} as ChatCompletionMessageParam;\n });\n \n const result = await this.engine!.chat.completions.create({\n messages: internalMessages\n });\n \n const message = result.choices[0].message as ChatMessage;\n \n if (message.content) {\n for (const char of message.content) {\n yield {\n type: 'token',\n content: char\n };\n }\n }\n \n yield {\n type: 'done',\n content: ''\n };\n }\n\n async complete(params: CompletionParams): Promise<ChatMessage> {\n if (!this.engine) {\n await this.init(params.model, params.chatConfig.parameters);\n }\n \n const internalMessages = params.messages.map((message) => {\n return {...message} as ChatCompletionMessageParam;\n });\n \n const result = await this.engine!.chat.completions.create({\n messages: internalMessages\n });\n \n return result.choices[0].message as ChatMessage;\n }\n}\n\nexport default () => {\n aiService.registerStreamingFetcher(new WebLLMProvider());\n}"],"mappings":";;;;AAIA,IAAM,SAAS,aAAa,SAAS;AAIrC,IAAM,iBAAN,MAA0C;;cAC/B;;CAGP,UAAU,cAAqC;AAC3C,SAAO,aAAa,SAAS;;CAGjC,MAAc,KAAK,OAAe,YAAiC;AAC/D,MAAI,KAAK,OAAQ;EAEjB,MAAM,wBAAwB,aAAkB;AAC5C,UAAO,MAAM,2BAA2B,SAAS;;AAGrD,OAAK,SAAS,IAAI,UAAU,EAAC,sBAAqB,CAAC;AACnD,QAAM,KAAK,OAAO,OAAO,OAAO,WAAW;;CAG/C,OAAO,OAAO,QAAqD;AAC/D,MAAI,CAAC,KAAK,OACN,OAAM,KAAK,KAAK,OAAO,OAAO,OAAO,WAAW,WAAW;EAG/D,MAAM,mBAAmB,OAAO,SAAS,KAAK,YAAY;AACtD,UAAO,EAAC,GAAG,SAAQ;IACrB;EAMF,MAAM,WAJS,MAAM,KAAK,OAAQ,KAAK,YAAY,OAAO,EACtD,UAAU,kBACb,CAAC,EAEqB,QAAQ,GAAG;AAElC,MAAI,QAAQ,QACR,MAAK,MAAM,QAAQ,QAAQ,QACvB,OAAM;GACF,MAAM;GACN,SAAS;GACZ;AAIT,QAAM;GACF,MAAM;GACN,SAAS;GACZ;;CAGL,MAAM,SAAS,QAAgD;AAC3D,MAAI,CAAC,KAAK,OACN,OAAM,KAAK,KAAK,OAAO,OAAO,OAAO,WAAW,WAAW;EAG/D,MAAM,mBAAmB,OAAO,SAAS,KAAK,YAAY;AACtD,UAAO,EAAC,GAAG,SAAQ;IACrB;AAMF,UAJe,MAAM,KAAK,OAAQ,KAAK,YAAY,OAAO,EACtD,UAAU,kBACb,CAAC,EAEY,QAAQ,GAAG;;;AAIjC,IAAA,8BAAqB;AACjB,WAAU,yBAAyB,IAAI,gBAAgB,CAAC"}
@@ -0,0 +1,3 @@
1
+ declare const _default: () => void;
2
+ export default _default;
3
+ //# sourceMappingURL=webllmservice.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"webllmservice.d.ts","sourceRoot":"","sources":["../src/webllmservice.ts"],"names":[],"mappings":";AA0EA,wBAEC"}
package/package.json ADDED
@@ -0,0 +1,34 @@
1
+ {
2
+ "name": "@eclipse-docks/extension-webllm",
3
+ "version": "0.7.68",
4
+ "type": "module",
5
+ "main": "./dist/index.js",
6
+ "exports": {
7
+ ".": {
8
+ "types": "./dist/index.d.ts",
9
+ "import": "./dist/index.js"
10
+ }
11
+ },
12
+ "dependencies": {
13
+ "@eclipse-docks/core": "*",
14
+ "@eclipse-docks/extension-ai-system": "*",
15
+ "@mlc-ai/web-llm": "^0.2.79"
16
+ },
17
+ "devDependencies": {
18
+ "typescript": "^6.0.0",
19
+ "vite": "^8.0.0",
20
+ "vite-plugin-dts": "^4.5.4"
21
+ },
22
+ "module": "./dist/index.js",
23
+ "types": "./dist/index.d.ts",
24
+ "files": [
25
+ "dist"
26
+ ],
27
+ "scripts": {
28
+ "build": "vite build"
29
+ },
30
+ "repository": {
31
+ "type": "git",
32
+ "url": "https://github.com/eclipse-docks/core"
33
+ }
34
+ }