@apia/ai 0.3.4

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/.eslintrc.cjs ADDED
@@ -0,0 +1,128 @@
1
+ module.exports = {
2
+ env: {
3
+ browser: true,
4
+ node: true
5
+ },
6
+ overrides: [
7
+ {
8
+ extends: [
9
+ 'plugin:react/recommended',
10
+ 'plugin:prettier/recommended',
11
+ 'plugin:@typescript-eslint/recommended',
12
+ 'plugin:@typescript-eslint/recommended-requiring-type-checking',
13
+ 'plugin:@typescript-eslint/strict',
14
+ 'plugin:comment-length/recommended',
15
+ ],
16
+ files: ['*.ts', '*.tsx'],
17
+ parserOptions: {
18
+ project: `${__dirname}/tsconfig.json`,
19
+ },
20
+ rules: {
21
+ "@typescript-eslint/no-extraneous-class": 0,
22
+ "no-undef": "off",
23
+ "react/display-name": 0,
24
+ "@typescript-eslint/no-unsafe-assignment": 0,
25
+ "@typescript-eslint/no-misused-promises": 0,
26
+ "import/export": 0,
27
+ "@typescript-eslint/no-invalid-void-type": 0,
28
+ "no-redeclare": 0,
29
+ "no-restricted-imports": ["error", {
30
+ "patterns": ["dist"]
31
+ }],
32
+ "import/no-default-export": 0,
33
+ "import/no-cycle": 0,
34
+ "import/no-unresolved": "error",
35
+ curly: 0,
36
+ "comment-length/limit-single-line-comments": [
37
+ "error",
38
+ {
39
+ "maxLength": 80,
40
+ "ignoreUrls": true
41
+ }
42
+ ],
43
+ "no-shadow": 0,
44
+ "brace-style": 0,
45
+ "comment-length/limit-multi-line-comments": [
46
+ "warn",
47
+ {
48
+ "maxLength": 80,
49
+ "ignoreUrls": true
50
+ }
51
+ ],
52
+ 'nonblock-statement-body-position': 0,
53
+ '@typescript-eslint/no-unnecessary-condition': 0,
54
+ 'no-use-before-define': 0,
55
+ 'no-plusplus': 0,
56
+ 'react/prop-types': 0,
57
+ 'import/no-unresolved': 0,
58
+ 'import/no-extraneous-dependencies': 0,
59
+ indent: 'off',
60
+ quotes: 0,
61
+ semi: ['error', 'always'],
62
+ 'react-hooks/rules-of-hooks': 'error',
63
+ 'react-hooks/exhaustive-deps': 'warn',
64
+ 'no-console': 'off',
65
+ 'prefer-object-spread': 'off',
66
+ 'no-unused-vars': 'off',
67
+ '@typescript-eslint/no-unused-vars': ["error", { "ignoreRestSiblings": true }],
68
+ 'wrap-iife': 0,
69
+ 'import/extensions': ['error', 'never'],
70
+ 'no-void': 'off',
71
+ 'no-restricted-globals': ['error', 'event'],
72
+ '@typescript-eslint/no-unnecessary-type-assertion': 'off',
73
+ '@typescript-eslint/no-non-null-assertion': 'off',
74
+ 'react/react-in-jsx-scope': 'off',
75
+ 'class-methods-use-this': 'off',
76
+ '@typescript-eslint/non-nullable-type-assertion-style': 'off',
77
+ 'linebreak-style': ['off'],
78
+ 'no-dupe-class-members': 'off',
79
+ "@typescript-eslint/consistent-type-definitions": 0,
80
+ "@typescript-eslint/consistent-indexed-object-style": 0,
81
+ "arrow-body-style": 0,
82
+ 'no-param-reassign': [
83
+ 'error',
84
+ {
85
+ props: true,
86
+ ignorePropertyModificationsFor: ['state'],
87
+ },
88
+ ],
89
+ 'import/prefer-default-export': 'off',
90
+ 'no-confusing-arrow': 'off',
91
+ 'implicit-arrow-linebreak': 'off',
92
+ 'function-paren-newline': 'off',
93
+ 'object-curly-newline': 'off',
94
+ 'no-underscore-dangle': 'off',
95
+ 'operator-linebreak': 'off',
96
+ '@typescript-eslint/no-empty-function': 'off',
97
+ 'import/no-relative-packages': 'off',
98
+ 'max-len': 0, /* [ 'error',
99
+ {
100
+ ignoreComments: true,
101
+ ignoreStrings: true,
102
+ ignoreTemplateLiterals: true,
103
+ ignoreRegExpLiterals: true,
104
+ },
105
+ ] */
106
+ 'prettier/prettier': [
107
+ 'error',
108
+ {
109
+ endOfLine: 'auto',
110
+ singleQuote: true,
111
+ trailingComma: 'all',
112
+ },
113
+ ],
114
+ 'no-multiple-empty-lines': 'off',
115
+ 'react/no-unknown-property': ['error', { ignore: ['sx'] }],
116
+ },
117
+ },
118
+ ],
119
+ parser: '@typescript-eslint/parser',
120
+ plugins: ['react-hooks', '@typescript-eslint', "import"],
121
+ ignorePatterns: ['dist', 'lib', 'node_modules'],
122
+ settings: {
123
+ react: {
124
+ version: 'detect',
125
+ },
126
+ },
127
+ root: true,
128
+ };
package/LICENSE.md ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) [year] [fullname]
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,28 @@
1
+ # Initiator
2
+
3
+ Este package se creĂł con la Ășnica utilidad de copiarlo entero y pegarlo a la hora de crear un nuevo package.
4
+
5
+ Este iniciador permite crear un paquete que compila typescript y puede ser importado desde otros packages.
6
+
7
+ ## IMPORTANTE
8
+
9
+ Los archivos **tsconfig.json** y **tsup.config.ts** no son archivos Ășnicos sino symlinks a archivos de configuraciĂłn comunes a todos los packages. En caso de que sea necesario modificar alguno de ellos **que en la gran mayorĂ­a de los casos no serĂ­a necesario**, es necesario eliminar el archivo a modificar y crear uno nuevo.
10
+
11
+ ## Procedimiento
12
+
13
+ - Copiar la carpeta initiator y pegarla con otro nombre dentro de packages.
14
+ - Modificar el package.json:
15
+ - Eliminar la lĂ­nea ```private: true```.
16
+ - Cambiar la ocurrencia `initiator` por el nombre del nuevo paquete.
17
+ - Agregar los scripts convenientes: dev, build, etc.
18
+ - Ejecutar el comando lerna bootstrap desde la carpeta raĂ­z.
19
+
20
+ Luego de ejecutar estos pasos, el package estarĂ­a listo para comenzar a usarse.
21
+
22
+ Este package trae como dependencias por defecto theme-ui y react. Si se desea agregar mĂĄs dependencias se debe ejecutar el comando ```lerna add --scope="@apia/packageName" dependencyName```. Ejemplo, si creamos un paquete con el nombre @apia/myPackage y queremos agregar lodash como dependencia, ejecutamos el comando ```lerna add --scope="@apia/myPackage" lodash```.
23
+
24
+ **Importante 1**: Dado que estamos desarrollando packages, es importante determinar si las dependencias que vamos a agregar son de tipo dependency o de tipo peerDependency.
25
+
26
+ **Importante 2**: lerna no permite instalar de a varias dependencias a la vez como lo hace npm, por lo tanto, si se desea agregar varias dependencias se debe ejecutar el comando anterior tantas veces como dependencias se quiera agregar.
27
+
28
+ **Importante 3**: React y theme-ui vienen instalados como peerDependencies. En caso de no ser necesarios pueden ser removidos, pero en cualquier caso asegurarse de que estas dependencias no sean instaladas como dependencies puesto que esto causarĂ­a comportamientos indeseados en la aplicaciĂłn.
package/cleanDist.json ADDED
@@ -0,0 +1,3 @@
1
+ {
2
+ "cleanDist": 0.2318938201855587
3
+ }
@@ -0,0 +1,41 @@
1
+ import * as react from 'react';
2
+ import { ReactNode } from 'react';
3
+ import { EventEmitter } from '@apia/util';
4
+
5
+ type TMessageType = 'user' | 'system' | 'warning' | 'error' | 'information' | 'response';
6
+ declare class ChatMessage {
7
+ message: ReactNode;
8
+ messageType: TMessageType;
9
+ id: number;
10
+ parseMessage(message: string): string;
11
+ constructor(message: ReactNode, messageType: TMessageType);
12
+ }
13
+ declare class ChatController extends EventEmitter<{
14
+ listChange: ChatMessage[];
15
+ messageSubmited: string;
16
+ }> {
17
+ #private;
18
+ id: string;
19
+ constructor(id: string);
20
+ components: {
21
+ MessageHistory: () => react.JSX.Element;
22
+ Textarea: {
23
+ ({ onSubmit, }: {
24
+ onSubmit: (text: string) => Promise<void>;
25
+ }): react.JSX.Element;
26
+ displayName: string;
27
+ };
28
+ };
29
+ history: {
30
+ add: (prompt: string) => void;
31
+ next: () => string;
32
+ previous: () => string | undefined;
33
+ useList: () => ChatMessage[];
34
+ };
35
+ messages: {
36
+ add: (message: ChatMessage) => void;
37
+ clear: () => void;
38
+ };
39
+ }
40
+
41
+ export { ChatController, ChatMessage };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
package/dist/index.js ADDED
@@ -0,0 +1,542 @@
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
+ import { Box, getVariant, Textarea } from '@apia/theme';
3
+ import { EventEmitter } from '@apia/util';
4
+ import { useRef, useCallback, useState, useEffect } from 'react';
5
+ import { IconButton, SimpleButton } from '@apia/components';
6
+
7
+ var __defProp$1 = Object.defineProperty;
8
+ var __defProps$1 = Object.defineProperties;
9
+ var __getOwnPropDescs$1 = Object.getOwnPropertyDescriptors;
10
+ var __getOwnPropSymbols$1 = Object.getOwnPropertySymbols;
11
+ var __hasOwnProp$1 = Object.prototype.hasOwnProperty;
12
+ var __propIsEnum$1 = Object.prototype.propertyIsEnumerable;
13
+ var __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
14
+ var __spreadValues$1 = (a, b) => {
15
+ for (var prop in b || (b = {}))
16
+ if (__hasOwnProp$1.call(b, prop))
17
+ __defNormalProp$1(a, prop, b[prop]);
18
+ if (__getOwnPropSymbols$1)
19
+ for (var prop of __getOwnPropSymbols$1(b)) {
20
+ if (__propIsEnum$1.call(b, prop))
21
+ __defNormalProp$1(a, prop, b[prop]);
22
+ }
23
+ return a;
24
+ };
25
+ var __spreadProps$1 = (a, b) => __defProps$1(a, __getOwnPropDescs$1(b));
26
+ const AutoscrollContainer = ({ children }) => {
27
+ const observer = useRef(null);
28
+ const unsuscribe = useRef(null);
29
+ const isFullScrolled = useRef(false);
30
+ const hasInited = useRef(false);
31
+ const ref = useCallback((el) => {
32
+ var _a, _b;
33
+ if (!el)
34
+ return;
35
+ if (!hasInited.current) {
36
+ hasInited.current = true;
37
+ el.scrollTo({
38
+ top: el.getBoundingClientRect().height,
39
+ behavior: "auto"
40
+ });
41
+ isFullScrolled.current = true;
42
+ }
43
+ (_a = observer.current) == null ? void 0 : _a.disconnect();
44
+ (_b = unsuscribe.current) == null ? void 0 : _b.call(unsuscribe);
45
+ observer.current = new MutationObserver(([mutation]) => {
46
+ if (mutation && mutation.target instanceof HTMLElement && mutation.target === el) {
47
+ if (isFullScrolled.current && mutation.target.scrollTop !== mutation.target.scrollHeight - mutation.target.offsetHeight) {
48
+ mutation.target.scrollTop = mutation.target.scrollHeight;
49
+ }
50
+ }
51
+ });
52
+ observer.current.observe(el, { childList: true, subtree: true });
53
+ const handleScroll = (ev) => {
54
+ if (ev.target === el && el instanceof HTMLElement) {
55
+ setTimeout(() => {
56
+ isFullScrolled.current = Math.abs(el.scrollTop - (el.scrollHeight - el.offsetHeight)) < 150;
57
+ }, 100);
58
+ }
59
+ };
60
+ el.addEventListener("scroll", handleScroll);
61
+ unsuscribe.current = () => {
62
+ el.removeEventListener("scroll", handleScroll);
63
+ };
64
+ }, []);
65
+ return /* @__PURE__ */ jsx(
66
+ Box,
67
+ __spreadProps$1(__spreadValues$1({}, getVariant("layout.common.components.autoscrollContainer")), {
68
+ className: "autoscrollContainer",
69
+ ref,
70
+ children
71
+ })
72
+ );
73
+ };
74
+
75
+ var __async$2 = (__this, __arguments, generator) => {
76
+ return new Promise((resolve, reject) => {
77
+ var fulfilled = (value) => {
78
+ try {
79
+ step(generator.next(value));
80
+ } catch (e) {
81
+ reject(e);
82
+ }
83
+ };
84
+ var rejected = (value) => {
85
+ try {
86
+ step(generator.throw(value));
87
+ } catch (e) {
88
+ reject(e);
89
+ }
90
+ };
91
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
92
+ step((generator = generator.apply(__this, __arguments)).next());
93
+ });
94
+ };
95
+ function isImageFile(file) {
96
+ const IMAGE_EXTENSIONS = [
97
+ "jpg",
98
+ "jpeg",
99
+ "png",
100
+ "gif",
101
+ "bmp",
102
+ "webp",
103
+ "tiff",
104
+ "svg",
105
+ "jfif"
106
+ ];
107
+ return IMAGE_EXTENSIONS.includes(file.name.split(".").pop());
108
+ }
109
+ function getImageOcrMaker(lang) {
110
+ return new class ImageOcrMaker {
111
+ processFile(file, onProgress) {
112
+ return __async$2(this, null, function* () {
113
+ const tesseract = yield import('tesseract.js');
114
+ const worker = yield tesseract.createWorker(lang, 1, {
115
+ logger(arg) {
116
+ onProgress == null ? void 0 : onProgress(arg.progress * 100);
117
+ }
118
+ });
119
+ const result = (yield worker.recognize(file)).data.text;
120
+ return [result];
121
+ });
122
+ }
123
+ willProcessFile(file) {
124
+ return isImageFile(file);
125
+ }
126
+ }();
127
+ }
128
+
129
+ var __async$1 = (__this, __arguments, generator) => {
130
+ return new Promise((resolve, reject) => {
131
+ var fulfilled = (value) => {
132
+ try {
133
+ step(generator.next(value));
134
+ } catch (e) {
135
+ reject(e);
136
+ }
137
+ };
138
+ var rejected = (value) => {
139
+ try {
140
+ step(generator.throw(value));
141
+ } catch (e) {
142
+ reject(e);
143
+ }
144
+ };
145
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
146
+ step((generator = generator.apply(__this, __arguments)).next());
147
+ });
148
+ };
149
+ function isPdfFile(file) {
150
+ const IMAGE_EXTENSIONS = ["pdf"];
151
+ return IMAGE_EXTENSIONS.includes(file.name.split(".").pop());
152
+ }
153
+ function getPdfReader() {
154
+ return new class PdfReader {
155
+ processFile(file, onProgress) {
156
+ return __async$1(this, null, function* () {
157
+ onProgress == null ? void 0 : onProgress(0);
158
+ const { getDocument, GlobalWorkerOptions } = yield import('pdfjs-dist');
159
+ function getPdfTextFromArrayBuffer(buffer) {
160
+ return __async$1(this, null, function* () {
161
+ GlobalWorkerOptions.workerSrc = "react/includes/pdf.worker.min.js";
162
+ const pdf = yield getDocument({ data: buffer }).promise;
163
+ const pages = [];
164
+ for (let i = 1; i <= pdf.numPages; i++) {
165
+ const page = yield pdf.getPage(i);
166
+ const textContent = yield page.getTextContent();
167
+ pages.push(
168
+ textContent.items.map((item) => item.str).join(" ")
169
+ );
170
+ }
171
+ return pages;
172
+ });
173
+ }
174
+ return new Promise((resolve) => {
175
+ const reader = new FileReader();
176
+ reader.onload = function(event) {
177
+ return __async$1(this, null, function* () {
178
+ var _a;
179
+ if (!((_a = event.target) == null ? void 0 : _a.result)) {
180
+ alert("Error al leer el archivo.");
181
+ return;
182
+ }
183
+ const buffer = event.target.result;
184
+ const text = yield getPdfTextFromArrayBuffer(buffer);
185
+ onProgress == null ? void 0 : onProgress(100);
186
+ resolve(text);
187
+ });
188
+ };
189
+ reader.readAsArrayBuffer(file);
190
+ });
191
+ });
192
+ }
193
+ willProcessFile(file) {
194
+ return isPdfFile(file);
195
+ }
196
+ }();
197
+ }
198
+
199
+ var __async = (__this, __arguments, generator) => {
200
+ return new Promise((resolve, reject) => {
201
+ var fulfilled = (value) => {
202
+ try {
203
+ step(generator.next(value));
204
+ } catch (e) {
205
+ reject(e);
206
+ }
207
+ };
208
+ var rejected = (value) => {
209
+ try {
210
+ step(generator.throw(value));
211
+ } catch (e) {
212
+ reject(e);
213
+ }
214
+ };
215
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
216
+ step((generator = generator.apply(__this, __arguments)).next());
217
+ });
218
+ };
219
+ function useHandleFileUpload({
220
+ onContent
221
+ }) {
222
+ const [progress, setProgress] = useState(100);
223
+ const handleFileUpload = useCallback(
224
+ (ev) => {
225
+ setProgress(0);
226
+ const imageProcessor = getImageOcrMaker();
227
+ const pdfProcessor = getPdfReader();
228
+ void (() => __async(this, null, function* () {
229
+ var _a, _b;
230
+ const obtainedText = [];
231
+ const files = ev.target.files;
232
+ const filesLength = (_b = (_a = ev.target.files) == null ? void 0 : _a.length) != null ? _b : 0;
233
+ if (files) {
234
+ for (let i = 0; i < filesLength; i++) {
235
+ const file = files[i];
236
+ const handleProgress = (progress2) => {
237
+ setProgress(
238
+ i / filesLength * 100 + 1 / filesLength * 100 * (progress2 / 100)
239
+ );
240
+ };
241
+ let result = "";
242
+ if (imageProcessor.willProcessFile(file)) {
243
+ try {
244
+ result = (yield imageProcessor.processFile(file, handleProgress))[0];
245
+ } catch (e) {
246
+ console.error(e);
247
+ }
248
+ } else if (pdfProcessor.willProcessFile(file)) {
249
+ result = (yield pdfProcessor.processFile(file, handleProgress)).join("\n\n");
250
+ }
251
+ if (result) {
252
+ obtainedText.push(result);
253
+ }
254
+ setProgress((i + 1) / filesLength * 100);
255
+ }
256
+ }
257
+ onContent(obtainedText);
258
+ }))();
259
+ ev.target.value = "";
260
+ },
261
+ [onContent]
262
+ );
263
+ return { progress, handleFileUpload };
264
+ }
265
+
266
+ const makeTextarea = (gptController) => {
267
+ const NewTextarea = ({
268
+ onSubmit
269
+ }) => {
270
+ const [isLoading, setIsLoading] = useState(false);
271
+ const submit = useCallback(
272
+ (text) => {
273
+ gptController.history.add(text);
274
+ gptController.messages.add(new ChatMessage(text, "user"));
275
+ onSubmit(text).finally(() => {
276
+ setIsLoading(false);
277
+ });
278
+ },
279
+ [onSubmit]
280
+ );
281
+ const handleSubmit = useCallback(
282
+ (ev) => {
283
+ ev.preventDefault();
284
+ const textarea = document.getElementById(
285
+ `GPTMessage${gptController.id}`
286
+ );
287
+ if (textarea.value) {
288
+ setIsLoading(true);
289
+ submit(textarea.value);
290
+ }
291
+ textarea.focus();
292
+ textarea.value = "";
293
+ },
294
+ [submit]
295
+ );
296
+ const onKeyDown = useCallback((ev) => {
297
+ var _a, _b;
298
+ if (ev.target.readOnly)
299
+ return;
300
+ if (ev.code === "Enter" && !ev.shiftKey) {
301
+ ev.preventDefault();
302
+ (_b = (_a = ev.target.closest("form")) == null ? void 0 : _a.querySelector('button[type="submit"]')) == null ? void 0 : _b.click();
303
+ }
304
+ }, []);
305
+ const { progress, handleFileUpload } = useHandleFileUpload({
306
+ onContent(content) {
307
+ document.getElementById(
308
+ `GPTMessage${gptController.id}`
309
+ ).value = content.join("\n\n");
310
+ }
311
+ });
312
+ const actualIsLoading = isLoading || progress !== 100;
313
+ return /* @__PURE__ */ jsxs("form", { onSubmit: handleSubmit, action: "", children: [
314
+ /* @__PURE__ */ jsx(
315
+ Textarea,
316
+ {
317
+ onKeyDown,
318
+ id: `GPTMessage${gptController.id}`,
319
+ readOnly: actualIsLoading
320
+ }
321
+ ),
322
+ /* @__PURE__ */ jsxs(Box, { className: "gpt__buttonsContainer", children: [
323
+ /* @__PURE__ */ jsx(
324
+ "input",
325
+ {
326
+ type: "file",
327
+ id: `gptUploadFile__${gptController.id}`,
328
+ sx: { display: "none" },
329
+ onChange: handleFileUpload
330
+ }
331
+ ),
332
+ /* @__PURE__ */ jsx(
333
+ IconButton,
334
+ {
335
+ icon: "File",
336
+ variant: "icon-outline",
337
+ isLoading: progress !== 100,
338
+ disabled: isLoading,
339
+ onClick: () => {
340
+ document.getElementById(
341
+ `gptUploadFile__${gptController.id}`
342
+ ).click();
343
+ },
344
+ size: "Lg"
345
+ }
346
+ ),
347
+ /* @__PURE__ */ jsx(
348
+ SimpleButton,
349
+ {
350
+ variant: "outline",
351
+ type: "button",
352
+ onClick: () => {
353
+ const historyValue = gptController.history.previous();
354
+ if (historyValue)
355
+ document.getElementById(
356
+ `GPTMessage${gptController.id}`
357
+ ).value = historyValue;
358
+ },
359
+ size: "sm",
360
+ children: "Previo"
361
+ }
362
+ ),
363
+ /* @__PURE__ */ jsx(
364
+ SimpleButton,
365
+ {
366
+ variant: "outline",
367
+ type: "button",
368
+ onClick: () => {
369
+ const historyValue = gptController.history.next();
370
+ document.getElementById(
371
+ `GPTMessage${gptController.id}`
372
+ ).value = historyValue != null ? historyValue : "";
373
+ },
374
+ size: "sm",
375
+ children: "Siguiente"
376
+ }
377
+ ),
378
+ /* @__PURE__ */ jsx(
379
+ SimpleButton,
380
+ {
381
+ variant: "outline",
382
+ type: "button",
383
+ onClick: () => gptController.messages.clear(),
384
+ size: "sm",
385
+ children: "Borrar"
386
+ }
387
+ ),
388
+ /* @__PURE__ */ jsx(SimpleButton, { isLoading: actualIsLoading, type: "submit", size: "sm", children: "Enviar" })
389
+ ] })
390
+ ] });
391
+ };
392
+ NewTextarea.displayName = "";
393
+ return NewTextarea;
394
+ };
395
+
396
+ var __defProp = Object.defineProperty;
397
+ var __defProps = Object.defineProperties;
398
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
399
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
400
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
401
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
402
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
403
+ var __spreadValues = (a, b) => {
404
+ for (var prop in b || (b = {}))
405
+ if (__hasOwnProp.call(b, prop))
406
+ __defNormalProp(a, prop, b[prop]);
407
+ if (__getOwnPropSymbols)
408
+ for (var prop of __getOwnPropSymbols(b)) {
409
+ if (__propIsEnum.call(b, prop))
410
+ __defNormalProp(a, prop, b[prop]);
411
+ }
412
+ return a;
413
+ };
414
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
415
+ var __accessCheck = (obj, member, msg) => {
416
+ if (!member.has(obj))
417
+ throw TypeError("Cannot " + msg);
418
+ };
419
+ var __privateGet = (obj, member, getter) => {
420
+ __accessCheck(obj, member, "read from private field");
421
+ return getter ? getter.call(obj) : member.get(obj);
422
+ };
423
+ var __privateAdd = (obj, member, value) => {
424
+ if (member.has(obj))
425
+ throw TypeError("Cannot add the same private member more than once");
426
+ member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
427
+ };
428
+ var __privateSet = (obj, member, value, setter) => {
429
+ __accessCheck(obj, member, "write to private field");
430
+ setter ? setter.call(obj, value) : member.set(obj, value);
431
+ return value;
432
+ };
433
+ var __privateWrapper = (obj, member, setter, getter) => ({
434
+ set _(value) {
435
+ __privateSet(obj, member, value, setter);
436
+ },
437
+ get _() {
438
+ return __privateGet(obj, member, getter);
439
+ }
440
+ });
441
+ var _messages, _promptsHistory, _currentHistoryIndex;
442
+ let maxId = 0;
443
+ class ChatMessage {
444
+ constructor(message, messageType) {
445
+ this.message = message;
446
+ this.messageType = messageType;
447
+ this.id = maxId++;
448
+ if (messageType === "response")
449
+ this.messageType = "system";
450
+ if (typeof message === "string")
451
+ this.message = this.parseMessage(message);
452
+ }
453
+ parseMessage(message) {
454
+ let result = message;
455
+ result = result.replaceAll("[strong]", "<strong>");
456
+ result = result.replaceAll("[/strong]", "</strong>");
457
+ return result;
458
+ }
459
+ }
460
+ class ChatController extends EventEmitter {
461
+ constructor(id) {
462
+ super();
463
+ this.id = id;
464
+ __privateAdd(this, _messages, [
465
+ new ChatMessage(
466
+ "Bienvenido, esta interfaz intenta ofrecer una forma alternativa de acceso a las distintas acciones disponibles en el sistema. Interact\xFAa directamente desde el chat o escribe [strong]ayuda[/strong] para conocer las opciones disponibles.",
467
+ "system"
468
+ )
469
+ ]);
470
+ this.components = {
471
+ MessageHistory: () => {
472
+ const messages = this.history.useList();
473
+ return /* @__PURE__ */ jsx(
474
+ Box,
475
+ __spreadProps(__spreadValues({}, getVariant("layout.panels.gpt.chat.history")), {
476
+ className: "history",
477
+ children: /* @__PURE__ */ jsx(AutoscrollContainer, { children: messages.map((current) => /* @__PURE__ */ jsx(
478
+ Box,
479
+ __spreadValues({
480
+ as: "pre",
481
+ className: `history__message ${current.messageType}`
482
+ }, typeof current.message === "string" ? { dangerouslySetInnerHTML: { __html: current.message } } : { children: current.message }),
483
+ current.id
484
+ )) })
485
+ })
486
+ );
487
+ },
488
+ Textarea: makeTextarea(this)
489
+ };
490
+ __privateAdd(this, _promptsHistory, []);
491
+ __privateAdd(this, _currentHistoryIndex, -1);
492
+ this.history = {
493
+ add: (prompt) => {
494
+ __privateSet(this, _currentHistoryIndex, -1);
495
+ if (prompt === __privateGet(this, _promptsHistory)[__privateGet(this, _promptsHistory).length]) {
496
+ return;
497
+ }
498
+ __privateSet(this, _promptsHistory, [
499
+ prompt,
500
+ ...__privateGet(this, _promptsHistory).slice(
501
+ Math.max(0, __privateGet(this, _promptsHistory).length - 10)
502
+ )
503
+ ]);
504
+ },
505
+ next: () => {
506
+ if (__privateGet(this, _promptsHistory)[__privateGet(this, _currentHistoryIndex) - 1])
507
+ return __privateGet(this, _promptsHistory)[--__privateWrapper(this, _currentHistoryIndex)._];
508
+ else {
509
+ __privateSet(this, _currentHistoryIndex, -1);
510
+ return "";
511
+ }
512
+ },
513
+ previous: () => {
514
+ if (__privateGet(this, _promptsHistory)[__privateGet(this, _currentHistoryIndex) + 1]) {
515
+ return __privateGet(this, _promptsHistory)[++__privateWrapper(this, _currentHistoryIndex)._];
516
+ }
517
+ },
518
+ useList: () => {
519
+ const [messages, setMessages] = useState(__privateGet(this, _messages));
520
+ useEffect(() => {
521
+ return this.on("listChange", (messages2) => setMessages(messages2));
522
+ }, []);
523
+ return messages;
524
+ }
525
+ };
526
+ this.messages = {
527
+ add: (message) => {
528
+ __privateGet(this, _messages).push(message);
529
+ this.emit("listChange", [...__privateGet(this, _messages)]);
530
+ },
531
+ clear: () => {
532
+ __privateSet(this, _messages, []);
533
+ this.emit("listChange", []);
534
+ }
535
+ };
536
+ }
537
+ }
538
+ _messages = new WeakMap();
539
+ _promptsHistory = new WeakMap();
540
+ _currentHistoryIndex = new WeakMap();
541
+
542
+ export { ChatController, ChatMessage };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../src/components/chat/AutoscrollContainer.tsx","../src/files/ocr/getImageOcrMaker.ts","../src/files/pdf/getPdfReader.ts","../src/components/chat/files/useHandleFileUpload.ts","../src/components/chat/Textarea.tsx","../src/components/chat/ChatController.tsx"],"sourcesContent":["import { getVariant } from '@apia/theme';\nimport { ReactNode, useCallback, useRef } from 'react';\nimport { Box } from '@apia/theme';\n\nexport const AutoscrollContainer = ({ children }: { children: ReactNode }) => {\n const observer = useRef<MutationObserver | null>(null);\n const unsuscribe = useRef<(() => void) | null>(null);\n const isFullScrolled = useRef(false);\n const hasInited = useRef(false);\n\n const ref = useCallback((el: HTMLElement) => {\n if (!el) return;\n\n if (!hasInited.current) {\n hasInited.current = true;\n el.scrollTo({\n top: el.getBoundingClientRect().height,\n behavior: 'auto',\n });\n isFullScrolled.current = true;\n }\n\n observer.current?.disconnect();\n unsuscribe.current?.();\n\n observer.current = new MutationObserver(([mutation]) => {\n if (\n mutation &&\n mutation.target instanceof HTMLElement &&\n mutation.target === el\n ) {\n if (\n isFullScrolled.current &&\n mutation.target.scrollTop !==\n mutation.target.scrollHeight - mutation.target.offsetHeight\n ) {\n // eslint-disable-next-line no-param-reassign\n mutation.target.scrollTop = mutation.target.scrollHeight;\n }\n }\n });\n observer.current.observe(el, { childList: true, subtree: true });\n\n const handleScroll = (ev: Event) => {\n if (ev.target === el && el instanceof HTMLElement) {\n setTimeout(() => {\n isFullScrolled.current =\n Math.abs(el.scrollTop - (el.scrollHeight - el.offsetHeight)) < 150;\n }, 100);\n }\n };\n el.addEventListener('scroll', handleScroll);\n unsuscribe.current = () => {\n el.removeEventListener('scroll', handleScroll);\n };\n }, []);\n\n return (\n <Box\n {...getVariant('layout.common.components.autoscrollContainer')}\n className=\"autoscrollContainer\"\n ref={ref}\n >\n {children}\n </Box>\n );\n};\n","import { FileProcessor } from '../FileProcessor';\n\nexport function isImageFile(file: File) {\n const IMAGE_EXTENSIONS = [\n 'jpg',\n 'jpeg',\n 'png',\n 'gif',\n 'bmp',\n 'webp',\n 'tiff',\n 'svg',\n 'jfif',\n ];\n\n return IMAGE_EXTENSIONS.includes(file.name.split('.').pop() as string);\n}\n\nexport default function getImageOcrMaker(lang: 'eng' | 'spa') {\n return new (class ImageOcrMaker implements FileProcessor {\n async processFile(\n file: File,\n onProgress?: (progress: number) => unknown,\n ): Promise<string[]> {\n const tesseract = await import('tesseract.js');\n\n const worker = await tesseract.createWorker(lang, 1, {\n logger(arg) {\n onProgress?.(arg.progress * 100);\n },\n });\n\n const result = (await worker.recognize(file)).data.text;\n return [result];\n }\n\n willProcessFile(file: File) {\n return isImageFile(file);\n }\n })();\n}\n","import { FileProcessor } from '../FileProcessor';\n\nexport function isPdfFile(file: File) {\n const IMAGE_EXTENSIONS = ['pdf'];\n\n return IMAGE_EXTENSIONS.includes(file.name.split('.').pop() as string);\n}\n\nexport default function getPdfReader() {\n return new (class PdfReader implements FileProcessor {\n async processFile(\n file: File,\n onProgress?: (progress: number) => void,\n ): Promise<string[]> {\n onProgress?.(0);\n const { getDocument, GlobalWorkerOptions } = await import('pdfjs-dist');\n\n async function getPdfTextFromArrayBuffer(\n buffer: ArrayBuffer,\n ): Promise<string[]> {\n GlobalWorkerOptions.workerSrc = 'react/includes/pdf.worker.min.js';\n\n const pdf = await getDocument({ data: buffer }).promise;\n\n const pages: string[] = [];\n\n for (let i = 1; i <= pdf.numPages; i++) {\n const page = await pdf.getPage(i);\n const textContent = await page.getTextContent();\n\n // Concatenar texto de cada pĂĄgina\n pages.push(\n textContent.items\n .map((item) => (item as { str: string }).str)\n .join(' '),\n );\n }\n\n return pages;\n }\n\n return new Promise((resolve) => {\n const reader = new FileReader();\n\n reader.onload = async function (event: ProgressEvent<FileReader>) {\n if (!event.target?.result) {\n alert('Error al leer el archivo.');\n return;\n }\n\n const buffer: ArrayBuffer = event.target.result as ArrayBuffer;\n const text = await getPdfTextFromArrayBuffer(buffer);\n\n onProgress?.(100);\n resolve(text);\n };\n\n reader.readAsArrayBuffer(file);\n });\n }\n\n willProcessFile(file: File) {\n return isPdfFile(file);\n }\n })();\n}\n","/* eslint-disable no-param-reassign */\nimport { ChangeEvent, useCallback, useState } from 'react';\nimport getImageOcrMaker from '../../../files/ocr/getImageOcrMaker';\nimport getPdfReader from '../../../files/pdf/getPdfReader';\n\nexport default function useHandleFileUpload({\n onContent,\n}: {\n onContent: (content: string[]) => unknown;\n}) {\n const [progress, setProgress] = useState(100);\n\n const handleFileUpload = useCallback(\n (ev: ChangeEvent<HTMLInputElement>) => {\n setProgress(0);\n\n const imageProcessor = getImageOcrMaker();\n const pdfProcessor = getPdfReader();\n\n void (async () => {\n const obtainedText: string[] = [];\n const files = ev.target.files;\n const filesLength = ev.target.files?.length ?? 0;\n if (files) {\n for (let i = 0; i < filesLength; i++) {\n const file = files[i];\n\n const handleProgress = (progress: number) => {\n setProgress(\n (i / filesLength) * 100 +\n (1 / filesLength) * 100 * (progress / 100),\n );\n };\n\n let result = '';\n if (imageProcessor.willProcessFile(file)) {\n try {\n result = (\n await imageProcessor.processFile(file, handleProgress)\n )[0];\n } catch (e) {\n console.error(e);\n }\n } else if (pdfProcessor.willProcessFile(file)) {\n result = (\n await pdfProcessor.processFile(file, handleProgress)\n ).join('\\n\\n');\n try {\n } catch (e) {\n console.error(e);\n }\n }\n\n if (result) {\n obtainedText.push(result);\n }\n\n setProgress(((i + 1) / filesLength) * 100);\n }\n }\n onContent(obtainedText);\n })();\n\n ev.target.value = '';\n },\n [onContent],\n );\n\n return { progress, handleFileUpload };\n}\n","/* eslint-disable no-param-reassign */\nimport { FormEvent, KeyboardEvent, useCallback, useState } from 'react';\nimport { ChatMessage, ChatController } from './ChatController';\nimport { IconButton, SimpleButton } from '@apia/components';\nimport { Box, Textarea } from '@apia/theme';\nimport useHandleFileUpload from './files/useHandleFileUpload';\n\nexport const makeTextarea = (gptController: ChatController) => {\n const NewTextarea = ({\n onSubmit,\n }: {\n onSubmit: (text: string) => Promise<void>;\n }) => {\n const [isLoading, setIsLoading] = useState(false);\n\n const submit = useCallback(\n (text: string) => {\n gptController.history.add(text);\n gptController.messages.add(new ChatMessage(text, 'user'));\n\n onSubmit(text).finally(() => {\n setIsLoading(false);\n });\n },\n [onSubmit],\n );\n\n const handleSubmit = useCallback(\n (ev: FormEvent<HTMLFormElement>) => {\n ev.preventDefault();\n //setIsLoading(true);\n const textarea = document.getElementById(\n `GPTMessage${gptController.id}`,\n ) as HTMLTextAreaElement;\n\n if (textarea.value) {\n setIsLoading(true);\n submit(textarea.value);\n }\n\n textarea.focus();\n textarea.value = '';\n },\n [submit],\n );\n\n const onKeyDown = useCallback((ev: KeyboardEvent) => {\n if ((ev.target as HTMLTextAreaElement).readOnly) return;\n\n if (ev.code === 'Enter' && !ev.shiftKey) {\n ev.preventDefault();\n (ev.target as HTMLElement)\n .closest('form')\n ?.querySelector<HTMLButtonElement>('button[type=\"submit\"]')\n ?.click();\n }\n }, []);\n\n const { progress, handleFileUpload } = useHandleFileUpload({\n onContent(content) {\n (\n document.getElementById(\n `GPTMessage${gptController.id}`,\n ) as HTMLTextAreaElement\n ).value = content.join('\\n\\n');\n },\n });\n\n const actualIsLoading = isLoading || progress !== 100;\n\n return (\n <form onSubmit={handleSubmit} action=\"\">\n <Textarea\n onKeyDown={onKeyDown}\n id={`GPTMessage${gptController.id}`}\n readOnly={actualIsLoading}\n />\n <Box className=\"gpt__buttonsContainer\">\n <input\n type=\"file\"\n id={`gptUploadFile__${gptController.id}`}\n sx={{ display: 'none' }}\n onChange={handleFileUpload}\n />\n <IconButton\n icon=\"File\"\n variant=\"icon-outline\"\n isLoading={progress !== 100}\n disabled={isLoading}\n onClick={() => {\n (\n document.getElementById(\n `gptUploadFile__${gptController.id}`,\n ) as HTMLElement\n ).click();\n }}\n size=\"Lg\"\n />\n <SimpleButton\n variant=\"outline\"\n type=\"button\"\n onClick={() => {\n const historyValue = gptController.history.previous();\n if (historyValue)\n (\n document.getElementById(\n `GPTMessage${gptController.id}`,\n ) as HTMLTextAreaElement\n ).value = historyValue;\n }}\n size=\"sm\"\n >\n Previo\n </SimpleButton>\n <SimpleButton\n variant=\"outline\"\n type=\"button\"\n onClick={() => {\n const historyValue = gptController.history.next();\n (\n document.getElementById(\n `GPTMessage${gptController.id}`,\n ) as HTMLTextAreaElement\n ).value = historyValue ?? '';\n }}\n size=\"sm\"\n >\n Siguiente\n </SimpleButton>\n <SimpleButton\n variant=\"outline\"\n type=\"button\"\n onClick={() => gptController.messages.clear()}\n size=\"sm\"\n >\n Borrar\n </SimpleButton>\n <SimpleButton isLoading={actualIsLoading} type=\"submit\" size=\"sm\">\n Enviar\n </SimpleButton>\n </Box>\n </form>\n );\n };\n\n NewTextarea.displayName = '';\n\n return NewTextarea;\n};\n","/* eslint-disable no-param-reassign */\nimport { getVariant } from '@apia/theme';\nimport { EventEmitter } from '@apia/util';\nimport { ReactNode, useEffect, useState } from 'react';\nimport { Box } from '@apia/theme';\nimport { AutoscrollContainer } from './AutoscrollContainer';\nimport { makeTextarea } from './Textarea';\n\nexport type TMessageType =\n | 'user'\n | 'system'\n | 'warning'\n | 'error'\n | 'information'\n | 'response';\n\nlet maxId = 0;\n\nexport class ChatMessage {\n id: number;\n\n parseMessage(message: string) {\n let result = message;\n\n result = result.replaceAll('[strong]', '<strong>');\n result = result.replaceAll('[/strong]', '</strong>');\n\n return result;\n }\n\n constructor(public message: ReactNode, public messageType: TMessageType) {\n this.id = maxId++;\n\n if (messageType === 'response') this.messageType = 'system';\n if (typeof message === 'string') this.message = this.parseMessage(message);\n }\n}\n\nexport class ChatController extends EventEmitter<{\n listChange: ChatMessage[];\n messageSubmited: string;\n}> {\n #messages: ChatMessage[] = [\n new ChatMessage(\n 'Bienvenido, esta interfaz intenta ofrecer una forma alternativa de acceso a las distintas acciones disponibles en el sistema. InteractĂșa directamente desde el chat o escribe [strong]ayuda[/strong] para conocer las opciones disponibles.',\n 'system',\n ),\n ];\n\n constructor(public id: string) {\n super();\n }\n\n components = {\n MessageHistory: () => {\n const messages = this.history.useList();\n\n return (\n <Box\n {...getVariant('layout.panels.gpt.chat.history')}\n className=\"history\"\n >\n <AutoscrollContainer>\n {messages.map((current) => (\n <Box\n as=\"pre\"\n className={`history__message ${current.messageType}`}\n key={current.id}\n {...(typeof current.message === 'string'\n ? { dangerouslySetInnerHTML: { __html: current.message } }\n : { children: current.message })}\n />\n ))}\n </AutoscrollContainer>\n </Box>\n );\n },\n Textarea: makeTextarea(this),\n };\n\n #promptsHistory: string[] = [];\n #currentHistoryIndex = -1;\n\n history = {\n add: (prompt: string) => {\n this.#currentHistoryIndex = -1;\n\n if (prompt === this.#promptsHistory[this.#promptsHistory.length]) {\n return;\n }\n\n this.#promptsHistory = [\n prompt,\n ...this.#promptsHistory.slice(\n Math.max(0, this.#promptsHistory.length - 10),\n ),\n ];\n },\n next: () => {\n if (this.#promptsHistory[this.#currentHistoryIndex - 1])\n return this.#promptsHistory[--this.#currentHistoryIndex];\n else {\n this.#currentHistoryIndex = -1;\n return '';\n }\n },\n previous: () => {\n if (this.#promptsHistory[this.#currentHistoryIndex + 1]) {\n return this.#promptsHistory[++this.#currentHistoryIndex];\n }\n },\n useList: () => {\n const [messages, setMessages] = useState<ChatMessage[]>(this.#messages);\n\n useEffect(() => {\n return this.on('listChange', (messages) => setMessages(messages));\n }, []);\n\n return messages;\n },\n };\n\n messages = {\n add: (message: ChatMessage) => {\n this.#messages.push(message);\n this.emit('listChange', [...this.#messages]);\n },\n clear: () => {\n this.#messages = [];\n this.emit('listChange', []);\n },\n };\n}\n"],"names":["__spreadProps","__spreadValues","__async","progress","messages"],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,49 @@
1
+ {
2
+ "author": "alexisleite <alexisleite@live.com>",
3
+ "homepage": "",
4
+ "license": "MIT",
5
+ "name": "@apia/ai",
6
+ "sideEffects": false,
7
+ "main": "./dist/index.js",
8
+ "types": "./dist/index.d.ts",
9
+ "version": "0.3.4",
10
+ "scripts": {
11
+ "build": "rollup -c rollup.config.esb.mjs",
12
+ "buildDev": "rollup -c rollup.config.esb.mjs --dev",
13
+ "watch": "rollup -c rollup.config.esb.mjs --dev --watch"
14
+ },
15
+ "devDependencies": {
16
+ "@rollup/plugin-commonjs": "^24.0.1",
17
+ "@rollup/plugin-json": "^6.0.0",
18
+ "@rollup/plugin-node-resolve": "^15.0.1",
19
+ "@rollup/plugin-terser": "^0.4.0",
20
+ "@rollup/plugin-typescript": "^11.0.0",
21
+ "esbuild": "^0.17.14",
22
+ "rollup": "^3.20.2",
23
+ "rollup-plugin-bundle-analyzer": "^1.6.6",
24
+ "rollup-plugin-dts": "^5.3.0",
25
+ "rollup-plugin-esbuild": "^5.0.0",
26
+ "typescript": "^4.9.5"
27
+ },
28
+ "peerDependencies": {
29
+ "react": "^18.2.0",
30
+ "react-dom": "^18.2.0"
31
+ },
32
+ "publishConfig": {
33
+ "access": "public",
34
+ "registry": "https://registry.npmjs.org/"
35
+ },
36
+ "repository": {
37
+ "type": "git",
38
+ "url": "http://corp-gitlab-01.domst.st.net/products/apia/ApiaNPMPackages.git",
39
+ "directory": "packages/initiator"
40
+ },
41
+ "dependencies": {
42
+ "@apia/components": "^0.3.4",
43
+ "@apia/theme": "^0.3.4",
44
+ "@apia/util": "^0.3.4",
45
+ "pdfjs-dist": "^4.0.189",
46
+ "tesseract.js": "^5.0.3"
47
+ },
48
+ "gitHead": "c85594050cd0abfe6550184ba6d65753a2e1004e"
49
+ }
@@ -0,0 +1,56 @@
1
+ import bundleAnalyzer from "rollup-plugin-bundle-analyzer";
2
+ import commonjs from '@rollup/plugin-commonjs';
3
+ import dts from "rollup-plugin-dts";
4
+ import esbuild from 'rollup-plugin-esbuild';
5
+ import fs from 'fs';
6
+
7
+ const entriesFile = './entries.json';
8
+ let localEntries = ['src/index.ts'];
9
+ if (fs.existsSync(entriesFile)) {
10
+ localEntries = JSON.parse(
11
+ fs.readFileSync(entriesFile).toString(),
12
+ );
13
+ }
14
+
15
+ const isDevelopment = process.argv.includes('--dev');
16
+ const shouldWatch = process.argv.includes('--watch');
17
+ const shouldAnalyze = process.argv.includes('--analyze');
18
+
19
+ const onwarn = (current, warn) => {
20
+ if (!['UNRESOLVED_IMPORT', 'UNKNOWN_OPTION'].includes(current.code))
21
+ warn(current);
22
+ }
23
+
24
+ export default [{
25
+ input: localEntries,
26
+ onwarn,
27
+ watch: shouldWatch,
28
+ output: [{
29
+ dir: 'dist',
30
+ format: 'es',
31
+ sourcemap: isDevelopment
32
+ }],
33
+ plugins: [
34
+ dts()
35
+ ].filter(Boolean),
36
+ }, {
37
+ input: localEntries,
38
+ onwarn,
39
+ watch: shouldWatch,
40
+ output: [{
41
+ dir: 'dist',
42
+ format: 'es',
43
+ sourcemap: isDevelopment
44
+ }],
45
+ plugins: [
46
+ commonjs(),
47
+ esbuild({
48
+ include: /\.[jt]sx?$/,
49
+ exclude: /node_modules/,
50
+ sourceMap: isDevelopment,
51
+ minify: false,
52
+ tsconfig: 'tsconfig.json'
53
+ }),
54
+ shouldAnalyze && bundleAnalyzer()
55
+ ].filter(Boolean),
56
+ }];