@danidoble/webserial 4.3.13 → 4.4.0-beta.2

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.
@@ -1,837 +0,0 @@
1
- class p extends CustomEvent {
2
- constructor(e, t) {
3
- super(e, t);
4
- }
5
- }
6
- class g extends EventTarget {
7
- __listeners__ = {
8
- debug: !1
9
- };
10
- __debug__ = !1;
11
- __listenersCallbacks__ = [];
12
- dispatch(e, t = null) {
13
- const i = new p(e, { detail: t });
14
- this.dispatchEvent(i), this.__debug__ && this.dispatchEvent(new p("debug", { detail: { type: e, data: t } }));
15
- }
16
- dispatchAsync(e, t = null, i = 100) {
17
- const s = this;
18
- setTimeout(() => {
19
- s.dispatch(e, t);
20
- }, i);
21
- }
22
- on(e, t) {
23
- typeof this.__listeners__[e] < "u" && !this.__listeners__[e] && (this.__listeners__[e] = !0), this.__listenersCallbacks__.push({ key: e, callback: t }), this.addEventListener(e, t);
24
- }
25
- off(e, t) {
26
- this.__listenersCallbacks__ = this.__listenersCallbacks__.filter((i) => !(i.key === e && i.callback === t)), this.removeEventListener(e, t);
27
- }
28
- serialRegisterAvailableListener(e) {
29
- this.__listeners__[e] || (this.__listeners__[e] = !1);
30
- }
31
- get availableListeners() {
32
- return Object.keys(this.__listeners__).sort().map((e) => ({
33
- type: e,
34
- listening: this.__listeners__[e]
35
- }));
36
- }
37
- removeAllListeners() {
38
- for (const e of this.__listenersCallbacks__)
39
- ["internal:queue"].includes(e.key) || (this.__listenersCallbacks__ = this.__listenersCallbacks__.filter((t) => !(t.key === e.key && t.callback === e.callback)), this.removeEventListener(e.key, e.callback));
40
- for (const e of Object.keys(this.__listeners__))
41
- this.__listeners__[e] = !1;
42
- }
43
- }
44
- class n extends g {
45
- static instance;
46
- static devices = {};
47
- constructor() {
48
- super(), ["change"].forEach((e) => {
49
- this.serialRegisterAvailableListener(e);
50
- });
51
- }
52
- static $dispatchChange(e = null) {
53
- e && e.$checkAndDispatchConnection(), n.instance.dispatch("change", { devices: n.devices, dispatcher: e });
54
- }
55
- static typeError(e) {
56
- const t = new Error();
57
- throw t.message = `Type ${e} is not supported`, t.name = "DeviceTypeError", t;
58
- }
59
- static registerType(e) {
60
- typeof n.devices[e] > "u" && (n.devices = { ...n.devices, [e]: {} });
61
- }
62
- static add(e) {
63
- const t = e.typeDevice;
64
- typeof n.devices[t] > "u" && n.registerType(t);
65
- const i = e.uuid;
66
- if (typeof n.devices[t] > "u" && n.typeError(t), n.devices[t][i])
67
- throw new Error(`Device with id ${i} already exists`);
68
- return n.devices[t][i] = e, n.$dispatchChange(e), Object.keys(n.devices[t]).indexOf(i);
69
- }
70
- static get(e, t) {
71
- return typeof n.devices[e] > "u" && n.registerType(e), typeof n.devices[e] > "u" && n.typeError(e), n.devices[e][t];
72
- }
73
- static getAll(e = null) {
74
- return e === null ? n.devices : (typeof n.devices[e] > "u" && n.typeError(e), n.devices[e]);
75
- }
76
- static getList() {
77
- return Object.values(n.devices).map((e) => Object.values(e)).flat();
78
- }
79
- static getByNumber(e, t) {
80
- return typeof n.devices[e] > "u" && n.typeError(e), Object.values(n.devices[e]).find((i) => i.deviceNumber === t) ?? null;
81
- }
82
- static getCustom(e, t = 1) {
83
- return typeof n.devices[e] > "u" && n.typeError(e), Object.values(n.devices[e]).find((i) => i.deviceNumber === t) ?? null;
84
- }
85
- static async connectToAll() {
86
- const e = n.getList();
87
- for (const t of e)
88
- t.isConnected || await t.connect().catch(console.warn);
89
- return Promise.resolve(n.areAllConnected());
90
- }
91
- static async disconnectAll() {
92
- const e = n.getList();
93
- for (const t of e)
94
- t.isDisconnected || await t.disconnect().catch(console.warn);
95
- return Promise.resolve(n.areAllDisconnected());
96
- }
97
- static async areAllConnected() {
98
- const e = n.getList();
99
- for (const t of e)
100
- if (!t.isConnected) return Promise.resolve(!1);
101
- return Promise.resolve(!0);
102
- }
103
- static async areAllDisconnected() {
104
- const e = n.getList();
105
- for (const t of e)
106
- if (!t.isDisconnected) return Promise.resolve(!1);
107
- return Promise.resolve(!0);
108
- }
109
- static async getAllConnected() {
110
- const e = n.getList();
111
- return Promise.resolve(e.filter((t) => t.isConnected));
112
- }
113
- static async getAllDisconnected() {
114
- const e = n.getList();
115
- return Promise.resolve(e.filter((t) => t.isDisconnected));
116
- }
117
- }
118
- n.instance || (n.instance = new n());
119
- function f(c = 100) {
120
- return new Promise(
121
- (e) => setTimeout(() => e(), c)
122
- );
123
- }
124
- function y() {
125
- return "serial" in navigator;
126
- }
127
- const u = {
128
- baudRate: 9600,
129
- dataBits: 8,
130
- stopBits: 1,
131
- parity: "none",
132
- bufferSize: 32768,
133
- flowControl: "none"
134
- };
135
- class b extends g {
136
- __internal__ = {
137
- bypassSerialBytesConnection: !1,
138
- auto_response: !1,
139
- device_number: 1,
140
- aux_port_connector: 0,
141
- last_error: {
142
- message: null,
143
- action: null,
144
- code: null,
145
- no_code: 0
146
- },
147
- serial: {
148
- aux_connecting: "idle",
149
- connecting: !1,
150
- connected: !1,
151
- port: null,
152
- last_action: null,
153
- response: {
154
- length: null,
155
- buffer: new Uint8Array([]),
156
- as: "uint8",
157
- replacer: /[\n\r]+/g,
158
- limiter: null,
159
- prefixLimiter: !1,
160
- sufixLimiter: !0,
161
- delimited: !1
162
- },
163
- reader: null,
164
- input_done: null,
165
- output_done: null,
166
- input_stream: null,
167
- output_stream: null,
168
- keep_reading: !0,
169
- time_until_send_bytes: void 0,
170
- delay_first_connection: 200,
171
- bytes_connection: null,
172
- filters: [],
173
- config_port: u,
174
- queue: [],
175
- running_queue: !1,
176
- auto_response: ["DD", "DD"],
177
- free_timeout_ms: 50,
178
- // In previous versions 400 was used
179
- useRTSCTS: !1
180
- // Use RTS/CTS flow control
181
- },
182
- device: {
183
- type: "unknown",
184
- id: window.crypto.randomUUID(),
185
- listen_on_port: null
186
- },
187
- time: {
188
- response_connection: 500,
189
- response_general: 2e3
190
- },
191
- timeout: {
192
- until_response: 0
193
- },
194
- interval: {
195
- reconnection: 0
196
- }
197
- };
198
- #t = null;
199
- constructor({
200
- filters: e = null,
201
- config_port: t = u,
202
- no_device: i = 1,
203
- device_listen_on_channel: s = 1,
204
- bypassSerialBytesConnection: r = !1
205
- } = {
206
- filters: null,
207
- config_port: u,
208
- no_device: 1,
209
- device_listen_on_channel: 1,
210
- bypassSerialBytesConnection: !1
211
- }) {
212
- if (super(), !("serial" in navigator))
213
- throw new Error("Web Serial not supported");
214
- e && (this.serialFilters = e), t && (this.serialConfigPort = t), r && (this.__internal__.bypassSerialBytesConnection = r), i && this.#m(i), s && ["number", "string"].includes(typeof s) && (this.listenOnChannel = s), this.#f(), this.#g();
215
- }
216
- set listenOnChannel(e) {
217
- if (typeof e == "string" && (e = parseInt(e)), isNaN(e) || e < 1 || e > 255)
218
- throw new Error("Invalid port number");
219
- this.__internal__.device.listen_on_port = e, !this.__internal__.bypassSerialBytesConnection && (this.__internal__.serial.bytes_connection = this.serialSetConnectionConstant(e));
220
- }
221
- get lastAction() {
222
- return this.__internal__.serial.last_action;
223
- }
224
- get listenOnChannel() {
225
- return this.__internal__.device.listen_on_port ?? 1;
226
- }
227
- set serialFilters(e) {
228
- if (this.isConnected) throw new Error("Cannot change serial filters while connected");
229
- this.__internal__.serial.filters = e;
230
- }
231
- get serialFilters() {
232
- return this.__internal__.serial.filters;
233
- }
234
- set serialConfigPort(e) {
235
- if (this.isConnected) throw new Error("Cannot change serial filters while connected");
236
- this.__internal__.serial.config_port = e;
237
- }
238
- get serialConfigPort() {
239
- return this.__internal__.serial.config_port;
240
- }
241
- get useRTSCTS() {
242
- return this.__internal__.serial.useRTSCTS;
243
- }
244
- set useRTSCTS(e) {
245
- this.__internal__.serial.useRTSCTS = e;
246
- }
247
- get isConnected() {
248
- const e = this.__internal__.serial.connected, t = this.#i(this.__internal__.serial.port);
249
- return e && !t && this.#s({ error: "Port is closed, not readable or writable." }), this.__internal__.serial.connected = t, this.__internal__.serial.connected;
250
- }
251
- get isConnecting() {
252
- return this.__internal__.serial.connecting;
253
- }
254
- get isDisconnected() {
255
- const e = this.__internal__.serial.connected, t = this.#i(this.__internal__.serial.port);
256
- return !e && t && (this.dispatch("serial:connected"), this.#n(!1), n.$dispatchChange(this)), this.__internal__.serial.connected = t, !this.__internal__.serial.connected;
257
- }
258
- get deviceNumber() {
259
- return this.__internal__.device_number;
260
- }
261
- get uuid() {
262
- return this.__internal__.device.id;
263
- }
264
- get typeDevice() {
265
- return this.__internal__.device.type;
266
- }
267
- get queue() {
268
- return this.__internal__.serial.queue;
269
- }
270
- get responseDelimited() {
271
- return this.__internal__.serial.response.delimited;
272
- }
273
- set responseDelimited(e) {
274
- if (typeof e != "boolean")
275
- throw new Error("responseDelimited must be a boolean");
276
- this.__internal__.serial.response.delimited = e;
277
- }
278
- get responsePrefixLimited() {
279
- return this.__internal__.serial.response.prefixLimiter;
280
- }
281
- set responsePrefixLimited(e) {
282
- if (typeof e != "boolean")
283
- throw new Error("responsePrefixLimited must be a boolean");
284
- this.__internal__.serial.response.prefixLimiter = e;
285
- }
286
- get responseSufixLimited() {
287
- return this.__internal__.serial.response.sufixLimiter;
288
- }
289
- set responseSufixLimited(e) {
290
- if (typeof e != "boolean")
291
- throw new Error("responseSufixLimited must be a boolean");
292
- this.__internal__.serial.response.sufixLimiter = e;
293
- }
294
- get responseLimiter() {
295
- return this.__internal__.serial.response.limiter;
296
- }
297
- set responseLimiter(e) {
298
- if (typeof e != "string" && !(e instanceof RegExp))
299
- throw new Error("responseLimiter must be a string or a RegExp");
300
- this.__internal__.serial.response.limiter = e;
301
- }
302
- get fixedBytesMessage() {
303
- return this.__internal__.serial.response.length;
304
- }
305
- set fixedBytesMessage(e) {
306
- if (e !== null && (typeof e != "number" || e < 1))
307
- throw new Error("Invalid length for fixed bytes message");
308
- this.__internal__.serial.response.length = e;
309
- }
310
- get timeoutBeforeResponseBytes() {
311
- return this.__internal__.serial.free_timeout_ms || 50;
312
- }
313
- set timeoutBeforeResponseBytes(e) {
314
- if (e !== void 0 && (typeof e != "number" || e < 1))
315
- throw new Error("Invalid timeout for response bytes");
316
- this.__internal__.serial.free_timeout_ms = e ?? 50;
317
- }
318
- get bypassSerialBytesConnection() {
319
- return this.__internal__.bypassSerialBytesConnection;
320
- }
321
- set bypassSerialBytesConnection(e) {
322
- if (typeof e != "boolean")
323
- throw new Error("bypassSerialBytesConnection must be a boolean");
324
- this.__internal__.bypassSerialBytesConnection = e;
325
- }
326
- #i(e) {
327
- return !!(e && e.readable && e.writable);
328
- }
329
- async timeout(e, t) {
330
- this.__internal__.last_error.message = "Operation response timed out.", this.__internal__.last_error.action = t, this.__internal__.last_error.code = e, this.__internal__.timeout.until_response && (clearTimeout(this.__internal__.timeout.until_response), this.__internal__.timeout.until_response = 0), t === "connect" ? (this.__internal__.serial.connected = !1, this.dispatch("serial:reconnect", {}), n.$dispatchChange(this)) : t === "connection:start" && (await this.serialDisconnect(), this.__internal__.serial.connected = !1, this.__internal__.aux_port_connector += 1, n.$dispatchChange(this), await this.serialConnect()), this.__internal__.serial.queue.length > 0 && this.dispatch("internal:queue", {}), this.dispatch("serial:timeout", {
331
- ...this.__internal__.last_error,
332
- bytes: e,
333
- action: t
334
- });
335
- }
336
- async disconnect(e = null) {
337
- await this.serialDisconnect(), this.#s(e);
338
- }
339
- #s(e = null) {
340
- this.__internal__.serial.connected = !1, this.__internal__.aux_port_connector = 0, this.dispatch("serial:disconnected", e), n.$dispatchChange(this);
341
- }
342
- #a(e) {
343
- this.__internal__.serial.aux_connecting = e.detail.active ? "connecting" : "finished";
344
- }
345
- async connect() {
346
- return this.isConnected ? !0 : (this.__internal__.serial.aux_connecting = "idle", new Promise((e, t) => {
347
- y() || t("Web Serial not supported"), this.#t || (this.#t = this.#a.bind(this)), this.on("internal:connecting", this.#t);
348
- const i = setInterval(() => {
349
- this.__internal__.serial.aux_connecting === "finished" ? (clearInterval(i), this.__internal__.serial.aux_connecting = "idle", this.#t !== null && this.off("internal:connecting", this.#t), this.isConnected ? e(!0) : t(`${this.typeDevice} device ${this.deviceNumber} not connected`)) : this.__internal__.serial.aux_connecting === "connecting" && (this.__internal__.serial.aux_connecting = "idle", this.dispatch("internal:connecting", { active: !0 }), this.dispatch("serial:connecting", { active: !0 }));
350
- }, 100);
351
- this.serialConnect();
352
- }));
353
- }
354
- async serialDisconnect() {
355
- try {
356
- const e = this.__internal__.serial.reader, t = this.__internal__.serial.output_stream;
357
- e && (await e.cancel().catch((i) => this.serialErrors(i)), await this.__internal__.serial.input_done), t && (await t.getWriter().close(), await this.__internal__.serial.output_done), this.__internal__.serial.connected && this.__internal__.serial && this.__internal__.serial.port && await this.__internal__.serial.port.close();
358
- } catch (e) {
359
- this.serialErrors(e);
360
- } finally {
361
- this.__internal__.serial.reader = null, this.__internal__.serial.input_done = null, this.__internal__.serial.output_stream = null, this.__internal__.serial.output_done = null, this.__internal__.serial.connected = !1, this.__internal__.serial.port = null, n.$dispatchChange(this);
362
- }
363
- }
364
- async #r(e) {
365
- const t = this.__internal__.serial.port;
366
- if (!t || t && (!t.readable || !t.writable))
367
- throw this.#s({ error: "Port is closed, not readable or writable." }), new Error("The port is closed or is not readable/writable");
368
- const i = this.validateBytes(e);
369
- if (this.useRTSCTS && await this.#l(t, 5e3), t.writable === null) return;
370
- const s = t.writable.getWriter();
371
- await s.write(i), s.releaseLock();
372
- }
373
- async #l(e, t = 5e3) {
374
- const i = Date.now();
375
- for (; ; ) {
376
- if (Date.now() - i > t)
377
- throw new Error("Timeout waiting for clearToSend signal");
378
- const { clearToSend: s } = await e.getSignals();
379
- if (s) return;
380
- await f(100);
381
- }
382
- }
383
- #e(e = new Uint8Array([]), t = !1) {
384
- if (e && e.length > 0) {
385
- const i = this.__internal__.serial.connected;
386
- if (this.__internal__.serial.connected = this.#i(this.__internal__.serial.port), n.$dispatchChange(this), !i && this.__internal__.serial.connected && (this.dispatch("serial:connected"), this.#n(!1)), this.__internal__.interval.reconnection && (clearInterval(this.__internal__.interval.reconnection), this.__internal__.interval.reconnection = 0), this.__internal__.timeout.until_response && (clearTimeout(this.__internal__.timeout.until_response), this.__internal__.timeout.until_response = 0), this.__internal__.serial.response.as === "hex")
387
- t ? this.serialCorruptMessage(this.parseUint8ToHex(e)) : this.serialMessage(this.parseUint8ToHex(e));
388
- else if (this.__internal__.serial.response.as === "uint8")
389
- t ? this.serialCorruptMessage(e) : this.serialMessage(e);
390
- else if (this.__internal__.serial.response.as === "string") {
391
- const s = this.parseUint8ArrayToString(e);
392
- if (this.__internal__.serial.response.limiter !== null) {
393
- const r = s.split(this.__internal__.serial.response.limiter);
394
- for (const o in r)
395
- r[o] && (t ? this.serialCorruptMessage(r[o]) : this.serialMessage(r[o]));
396
- } else
397
- t ? this.serialCorruptMessage(s) : this.serialMessage(s);
398
- } else {
399
- const s = this.stringToArrayBuffer(this.parseUint8ArrayToString(e));
400
- t ? this.serialCorruptMessage(s) : this.serialMessage(s);
401
- }
402
- }
403
- if (this.__internal__.serial.queue.length === 0) {
404
- this.__internal__.serial.running_queue = !1;
405
- return;
406
- }
407
- this.dispatch("internal:queue", {});
408
- }
409
- getResponseAsArrayBuffer() {
410
- this.__internal__.serial.response.as = "arraybuffer";
411
- }
412
- getResponseAsArrayHex() {
413
- this.__internal__.serial.response.as = "hex";
414
- }
415
- getResponseAsUint8Array() {
416
- this.__internal__.serial.response.as = "uint8";
417
- }
418
- getResponseAsString() {
419
- this.__internal__.serial.response.as = "string";
420
- }
421
- async #o() {
422
- const e = this.serialFilters, t = await navigator.serial.getPorts({ filters: e });
423
- return e.length === 0 ? t : t.filter((i) => {
424
- const s = i.getInfo();
425
- return e.some((r) => s.usbProductId === r.usbProductId && s.usbVendorId === r.usbVendorId);
426
- }).filter((i) => !this.#i(i));
427
- }
428
- async serialPortsSaved(e) {
429
- const t = this.serialFilters;
430
- if (this.__internal__.aux_port_connector < e.length) {
431
- const i = this.__internal__.aux_port_connector;
432
- this.__internal__.serial.port = e[i];
433
- } else
434
- this.__internal__.aux_port_connector = 0, this.__internal__.serial.port = await navigator.serial.requestPort({
435
- filters: t
436
- });
437
- if (!this.__internal__.serial.port)
438
- throw new Error("Select another port please");
439
- }
440
- serialErrors(e) {
441
- const t = e.toString().toLowerCase();
442
- switch (!0) {
443
- case t.includes("must be handling a user gesture to show a permission request"):
444
- case t.includes("the port is closed."):
445
- case t.includes("the port is closed or is not writable"):
446
- case t.includes("the port is closed or is not readable"):
447
- case t.includes("the port is closed or is not readable/writable"):
448
- case t.includes("select another port please"):
449
- case t.includes("no port selected by the user"):
450
- case t.includes(
451
- "this readable stream reader has been released and cannot be used to cancel its previous owner stream"
452
- ):
453
- this.dispatch("serial:need-permission", {}), n.$dispatchChange(this);
454
- break;
455
- case t.includes("the port is already open."):
456
- case t.includes("failed to open serial port"):
457
- this.serialDisconnect().then(async () => {
458
- this.__internal__.aux_port_connector += 1, await this.serialConnect();
459
- });
460
- break;
461
- case t.includes("cannot read properties of undefined (reading 'writable')"):
462
- case t.includes("cannot read properties of null (reading 'writable')"):
463
- case t.includes("cannot read property 'writable' of null"):
464
- case t.includes("cannot read property 'writable' of undefined"):
465
- this.serialDisconnect().then(async () => {
466
- await this.serialConnect();
467
- });
468
- break;
469
- case t.includes("'close' on 'serialport': a call to close() is already in progress."):
470
- break;
471
- case t.includes("failed to execute 'open' on 'serialport': a call to open() is already in progress."):
472
- break;
473
- case t.includes("the port is already closed."):
474
- break;
475
- case t.includes("the device has been lost"):
476
- this.dispatch("serial:lost", {}), n.$dispatchChange(this);
477
- break;
478
- case t.includes("navigator.serial is undefined"):
479
- this.dispatch("serial:unsupported", {});
480
- break;
481
- default:
482
- console.error(e);
483
- break;
484
- }
485
- this.dispatch("serial:error", e);
486
- }
487
- #_(e) {
488
- if (e) {
489
- const t = this.__internal__.serial.response.buffer, i = new Uint8Array(t.length + e.byteLength);
490
- i.set(t, 0), i.set(new Uint8Array(e), t.length), this.__internal__.serial.response.buffer = i;
491
- }
492
- }
493
- async #c() {
494
- this.__internal__.serial.time_until_send_bytes && (clearTimeout(this.__internal__.serial.time_until_send_bytes), this.__internal__.serial.time_until_send_bytes = 0), this.__internal__.serial.time_until_send_bytes = setTimeout(() => {
495
- this.__internal__.serial.response.buffer && this.#e(this.__internal__.serial.response.buffer), this.__internal__.serial.response.buffer = new Uint8Array(0);
496
- }, this.__internal__.serial.free_timeout_ms || 50);
497
- }
498
- async #h() {
499
- const e = this.__internal__.serial.response.length;
500
- let t = this.__internal__.serial.response.buffer;
501
- if (this.__internal__.serial.time_until_send_bytes && (clearTimeout(this.__internal__.serial.time_until_send_bytes), this.__internal__.serial.time_until_send_bytes = 0), !(e === null || !t || t.length === 0)) {
502
- for (; t.length >= e; ) {
503
- const i = t.slice(0, e);
504
- this.#e(i), t = t.slice(e);
505
- }
506
- this.__internal__.serial.response.buffer = t, t.length > 0 && (this.__internal__.serial.time_until_send_bytes = setTimeout(() => {
507
- this.#e(this.__internal__.serial.response.buffer, !0);
508
- }, this.__internal__.serial.free_timeout_ms || 50));
509
- }
510
- }
511
- async #u() {
512
- const {
513
- limiter: e,
514
- prefixLimiter: t = !1,
515
- sufixLimiter: i = !0
516
- } = this.__internal__.serial.response;
517
- if (!e)
518
- throw new Error("No limiter defined for delimited serial response");
519
- const s = this.__internal__.serial.response.buffer;
520
- if (!e || !s || s.length === 0) return;
521
- this.__internal__.serial.time_until_send_bytes && (clearTimeout(this.__internal__.serial.time_until_send_bytes), this.__internal__.serial.time_until_send_bytes = 0);
522
- let r = new TextDecoder().decode(s);
523
- const o = [];
524
- if (typeof e == "string") {
525
- let a;
526
- if (t && i)
527
- a = new RegExp(`${e}([^${e}]+)${e}`, "g");
528
- else if (t)
529
- a = new RegExp(`${e}([^${e}]*)`, "g");
530
- else if (i)
531
- a = new RegExp(`([^${e}]+)${e}`, "g");
532
- else
533
- return;
534
- let _, l = 0;
535
- for (; (_ = a.exec(r)) !== null; )
536
- o.push(new TextEncoder().encode(_[1])), l = a.lastIndex;
537
- r = r.slice(l);
538
- } else if (e instanceof RegExp) {
539
- let a, _ = 0;
540
- if (t && i) {
541
- const l = new RegExp(`${e.source}(.*?)${e.source}`, "g");
542
- for (; (a = l.exec(r)) !== null; )
543
- o.push(new TextEncoder().encode(a[1])), _ = l.lastIndex;
544
- } else if (i)
545
- for (; (a = e.exec(r)) !== null; ) {
546
- const l = a.index, h = r.slice(_, l);
547
- o.push(new TextEncoder().encode(h)), _ = e.lastIndex;
548
- }
549
- else if (t) {
550
- const l = r.split(e);
551
- l.shift();
552
- for (const h of l)
553
- o.push(new TextEncoder().encode(h));
554
- r = "";
555
- }
556
- r = r.slice(_);
557
- }
558
- for (const a of o)
559
- this.#e(a);
560
- const d = new TextEncoder().encode(r);
561
- this.__internal__.serial.response.buffer = d, d.length > 0 && (this.__internal__.serial.time_until_send_bytes = setTimeout(() => {
562
- this.#e(this.__internal__.serial.response.buffer, !0), this.__internal__.serial.response.buffer = new Uint8Array(0);
563
- }, this.__internal__.serial.free_timeout_ms ?? 50));
564
- }
565
- async #d() {
566
- const e = this.__internal__.serial.port;
567
- if (!e || !e.readable) throw new Error("Port is not readable");
568
- const t = e.readable.getReader();
569
- this.__internal__.serial.reader = t;
570
- try {
571
- for (; this.__internal__.serial.keep_reading; ) {
572
- const { value: i, done: s } = await t.read();
573
- if (s) break;
574
- this.#_(i), this.__internal__.serial.response.delimited ? await this.#u() : this.__internal__.serial.response.length === null ? await this.#c() : await this.#h();
575
- }
576
- } catch (i) {
577
- this.serialErrors(i);
578
- } finally {
579
- t.releaseLock(), this.__internal__.serial.keep_reading = !0, this.__internal__.serial.port && await this.__internal__.serial.port.close();
580
- }
581
- }
582
- #n(e) {
583
- e !== this.__internal__.serial.connecting && (this.__internal__.serial.connecting = e, this.dispatch("serial:connecting", { active: e }), this.dispatch("internal:connecting", { active: e }));
584
- }
585
- async serialConnect() {
586
- try {
587
- this.#n(!0);
588
- const e = await this.#o();
589
- if (e.length > 0)
590
- await this.serialPortsSaved(e);
591
- else {
592
- const s = this.serialFilters;
593
- this.__internal__.serial.port = await navigator.serial.requestPort({
594
- filters: s
595
- });
596
- }
597
- const t = this.__internal__.serial.port;
598
- if (!t)
599
- throw new Error("No port selected by the user");
600
- await t.open(this.serialConfigPort);
601
- const i = this;
602
- t.onconnect = (s) => {
603
- i.dispatch("serial:connected", s), i.#n(!1), n.$dispatchChange(this), i.__internal__.serial.queue.length > 0 ? i.dispatch("internal:queue", {}) : i.__internal__.serial.running_queue = !1;
604
- }, t.ondisconnect = async () => {
605
- await i.disconnect();
606
- }, await f(this.__internal__.serial.delay_first_connection), this.__internal__.timeout.until_response = setTimeout(async () => {
607
- await i.timeout(i.__internal__.serial.bytes_connection ?? [], "connection:start");
608
- }, this.__internal__.time.response_connection), this.__internal__.serial.last_action = "connect", await this.#r(this.__internal__.serial.bytes_connection ?? []), this.dispatch("serial:sent", {
609
- action: "connect",
610
- bytes: this.__internal__.serial.bytes_connection
611
- }), this.__internal__.auto_response && this.#e(this.__internal__.serial.auto_response), await this.#d();
612
- } catch (e) {
613
- this.#n(!1), this.serialErrors(e);
614
- }
615
- }
616
- async #p() {
617
- return typeof window > "u" ? !1 : "serial" in navigator && "forget" in SerialPort.prototype && this.__internal__.serial.port ? (await this.__internal__.serial.port.forget(), !0) : !1;
618
- }
619
- async serialForget() {
620
- return await this.#p();
621
- }
622
- decToHex(e) {
623
- return typeof e == "string" && (e = parseInt(e, 10)), e.toString(16);
624
- }
625
- hexToDec(e) {
626
- return parseInt(e, 16);
627
- }
628
- hexMaker(e = "00", t = 2) {
629
- return e.toString().padStart(t, "0").toLowerCase();
630
- }
631
- add0x(e) {
632
- const t = [];
633
- return e.forEach((i, s) => {
634
- t[s] = "0x" + i;
635
- }), t;
636
- }
637
- bytesToHex(e) {
638
- return this.add0x(Array.from(e, (t) => this.hexMaker(t)));
639
- }
640
- #f() {
641
- [
642
- "serial:connected",
643
- "serial:connecting",
644
- "serial:reconnect",
645
- "serial:timeout",
646
- "serial:disconnected",
647
- "serial:sent",
648
- "serial:soft-reload",
649
- "serial:message",
650
- "serial:corrupt-message",
651
- "unknown",
652
- "serial:need-permission",
653
- "serial:lost",
654
- "serial:unsupported",
655
- "serial:error",
656
- "debug"
657
- ].forEach((e) => {
658
- this.serialRegisterAvailableListener(e);
659
- });
660
- }
661
- #g() {
662
- const e = this;
663
- this.on("internal:queue", async () => {
664
- await e.#b();
665
- }), this.#y();
666
- }
667
- #y() {
668
- const e = this;
669
- navigator.serial.addEventListener("connect", async () => {
670
- e.isDisconnected && await e.serialConnect().catch(() => {
671
- });
672
- });
673
- }
674
- async #b() {
675
- if (!this.#i(this.__internal__.serial.port)) {
676
- this.#s({ error: "Port is closed, not readable or writable." }), await this.serialConnect();
677
- return;
678
- }
679
- if (this.__internal__.timeout.until_response) return;
680
- if (this.__internal__.serial.queue.length === 0) {
681
- this.__internal__.serial.running_queue = !1;
682
- return;
683
- }
684
- this.__internal__.serial.running_queue = !0;
685
- const e = this.__internal__.serial.queue[0];
686
- let t = this.__internal__.time.response_general;
687
- if (e.action === "connect" && (t = this.__internal__.time.response_connection), this.__internal__.timeout.until_response = setTimeout(async () => {
688
- await this.timeout(e.bytes, e.action);
689
- }, t), this.__internal__.serial.last_action = e.action ?? "unknown", await this.#r(e.bytes), this.dispatch("serial:sent", {
690
- action: e.action,
691
- bytes: e.bytes
692
- }), this.__internal__.auto_response) {
693
- let s = new Uint8Array(0);
694
- try {
695
- s = this.validateBytes(this.__internal__.serial.auto_response);
696
- } catch (r) {
697
- this.serialErrors(r);
698
- }
699
- this.#e(s);
700
- }
701
- const i = [...this.__internal__.serial.queue];
702
- this.__internal__.serial.queue = i.splice(1), this.__internal__.serial.queue.length > 0 && (this.__internal__.serial.running_queue = !0);
703
- }
704
- validateBytes(e) {
705
- let t = new Uint8Array(0);
706
- if (e instanceof Uint8Array)
707
- t = e;
708
- else if (typeof e == "string")
709
- t = this.parseStringToTextEncoder(e);
710
- else if (Array.isArray(e) && typeof e[0] == "string")
711
- t = this.stringArrayToUint8Array(e);
712
- else if (Array.isArray(e) && typeof e[0] == "number")
713
- t = new Uint8Array(e);
714
- else
715
- throw new Error("Invalid data type");
716
- return t;
717
- }
718
- async appendToQueue(e, t) {
719
- const i = this.validateBytes(e);
720
- if (["connect", "connection:start"].includes(t)) {
721
- if (this.__internal__.serial.connected) return;
722
- await this.serialConnect();
723
- return;
724
- }
725
- this.__internal__.serial.queue.push({ bytes: i, action: t }), this.dispatch("internal:queue", {});
726
- }
727
- #m(e = 1) {
728
- this.__internal__.device_number = e, !this.__internal__.bypassSerialBytesConnection && (this.__internal__.serial.bytes_connection = this.serialSetConnectionConstant(e));
729
- }
730
- serialSetConnectionConstant(e = 1) {
731
- if (this.__internal__.bypassSerialBytesConnection) return this.__internal__.serial.bytes_connection;
732
- throw new Error(`Method not implemented 'serialSetConnectionConstant' to listen on channel ${e}`);
733
- }
734
- serialMessage(e) {
735
- throw console.log(e), this.dispatch("serial:message", { code: e }), new Error("Method not implemented 'serialMessage'");
736
- }
737
- serialCorruptMessage(e) {
738
- throw console.log(e), this.dispatch("serial:corrupt-message", { code: e }), new Error("Method not implemented 'serialCorruptMessage'");
739
- }
740
- #w() {
741
- this.__internal__.last_error = {
742
- message: null,
743
- action: null,
744
- code: null,
745
- no_code: 0
746
- };
747
- }
748
- clearSerialQueue() {
749
- this.__internal__.serial.queue = [];
750
- }
751
- sumHex(e) {
752
- let t = 0;
753
- return e.forEach((i) => {
754
- t += parseInt(i, 16);
755
- }), t.toString(16);
756
- }
757
- toString() {
758
- return JSON.stringify({
759
- __class: this.typeDevice,
760
- device_number: this.deviceNumber,
761
- uuid: this.uuid,
762
- connected: this.isConnected,
763
- connection: this.__internal__.serial.bytes_connection
764
- });
765
- }
766
- softReload() {
767
- this.#w(), this.dispatch("serial:soft-reload", {});
768
- }
769
- async sendConnect() {
770
- if (!this.__internal__.serial.bytes_connection)
771
- throw new Error("No connection bytes defined");
772
- await this.appendToQueue(this.__internal__.serial.bytes_connection, "connect");
773
- }
774
- async sendCustomCode({ code: e = [] } = { code: [] }) {
775
- if (!e)
776
- throw new Error("No data to send");
777
- this.__internal__.bypassSerialBytesConnection && (this.__internal__.serial.bytes_connection = this.validateBytes(e)), await this.appendToQueue(e, "custom");
778
- }
779
- stringToArrayHex(e) {
780
- return Array.from(e).map((t) => t.charCodeAt(0).toString(16));
781
- }
782
- stringToArrayBuffer(e, t = `
783
- `) {
784
- return this.parseStringToTextEncoder(e, t).buffer;
785
- }
786
- parseStringToTextEncoder(e = "", t = `
787
- `) {
788
- const i = new TextEncoder();
789
- return e += t, i.encode(e);
790
- }
791
- parseStringToBytes(e = "", t = `
792
- `) {
793
- const i = this.parseStringToTextEncoder(e, t);
794
- return Array.from(i).map((s) => s.toString(16));
795
- }
796
- parseUint8ToHex(e) {
797
- return Array.from(e).map((t) => t.toString(16));
798
- }
799
- parseHexToUint8(e) {
800
- return new Uint8Array(e.map((t) => parseInt(t, 16)));
801
- }
802
- stringArrayToUint8Array(e) {
803
- const t = [];
804
- return typeof e == "string" ? this.parseStringToTextEncoder(e).buffer : (e.forEach((i) => {
805
- const s = i.replace("0x", "");
806
- t.push(parseInt(s, 16));
807
- }), new Uint8Array(t));
808
- }
809
- parseUint8ArrayToString(e) {
810
- let t = new Uint8Array(0);
811
- e instanceof Uint8Array ? t = e : t = this.stringArrayToUint8Array(e), e = this.parseUint8ToHex(t);
812
- const i = e.map((s) => parseInt(s, 16));
813
- return this.__internal__.serial.response.replacer ? String.fromCharCode(...i).replace(this.__internal__.serial.response.replacer, "") : String.fromCharCode(...i);
814
- }
815
- hexToAscii(e) {
816
- const t = e.toString();
817
- let i = "";
818
- for (let s = 0; s < t.length; s += 2)
819
- i += String.fromCharCode(parseInt(t.substring(s, 2), 16));
820
- return i;
821
- }
822
- asciiToHex(e) {
823
- const t = [];
824
- for (let i = 0, s = e.length; i < s; i++) {
825
- const r = Number(e.charCodeAt(i)).toString(16);
826
- t.push(r);
827
- }
828
- return t.join("");
829
- }
830
- $checkAndDispatchConnection() {
831
- return this.isConnected;
832
- }
833
- }
834
- export {
835
- b,
836
- n as s
837
- };