web-background 0.0.10 → 0.0.12
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/README.md +2 -2
- package/dist/background.d.ts +2 -2
- package/dist/index.js +65 -40
- package/dist/modules/UtilWorker.d.ts +1 -2
- package/dist/modules/workerCleanupRegistry.d.ts +1 -0
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -9,8 +9,8 @@ In most cases, You don't have to use it
|
|
|
9
9
|
Recommended for long task
|
|
10
10
|
대부분의 경우 이 모듈을 사용할 필요는 없으나, long task를 처리해야 할 경우 사용할 것을 추천합니다.
|
|
11
11
|
|
|
12
|
-
Most WebAPIs including DOM APIs are cannot be used
|
|
13
|
-
|
|
12
|
+
Most WebAPIs including DOM APIs are cannot be used.
|
|
13
|
+
DOM API를 포함한 대부분의 WebAPI를 사용하지 못합니다.
|
|
14
14
|
[Read More](https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API)
|
|
15
15
|
|
|
16
16
|
## Example
|
package/dist/background.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
type Result<Payload, ReturnValue> = Payload extends
|
|
2
|
-
export declare function background<Payload
|
|
1
|
+
type Result<Payload, ReturnValue> = Payload extends any[] ? (...payloads: Payload) => ReturnValue : (payload: Payload) => ReturnValue;
|
|
2
|
+
export declare function background<Payload extends any[], ReturnValue = void>(fn: (...payloads: Payload) => ReturnValue): Result<Payload, ReturnValue>;
|
|
3
3
|
export {};
|
package/dist/index.js
CHANGED
|
@@ -1,37 +1,3 @@
|
|
|
1
|
-
class TypedWorker extends Worker {
|
|
2
|
-
postMessage(payload) {
|
|
3
|
-
super.postMessage(payload);
|
|
4
|
-
}
|
|
5
|
-
addEventListener(type, observer) {
|
|
6
|
-
super.addEventListener(type, observer);
|
|
7
|
-
}
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
class UtilWorker extends TypedWorker {
|
|
11
|
-
constructor(scriptURL, options) {
|
|
12
|
-
super(scriptURL, options);
|
|
13
|
-
}
|
|
14
|
-
subscribe(observer) {
|
|
15
|
-
const onMessage = (event) => {
|
|
16
|
-
observer(event.data);
|
|
17
|
-
};
|
|
18
|
-
this.addEventListener('message', onMessage);
|
|
19
|
-
return () => {
|
|
20
|
-
this.removeEventListener('message', onMessage);
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
request(payload) {
|
|
24
|
-
return new Promise(resolve => {
|
|
25
|
-
const onMessage = ({ data }) => {
|
|
26
|
-
resolve(data);
|
|
27
|
-
this.removeEventListener('message', onMessage);
|
|
28
|
-
};
|
|
29
|
-
this.postMessage(payload);
|
|
30
|
-
this.addEventListener('message', onMessage);
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
|
|
35
1
|
/******************************************************************************
|
|
36
2
|
Copyright (c) Microsoft Corporation.
|
|
37
3
|
|
|
@@ -61,39 +27,98 @@ function __rest(s, e) {
|
|
|
61
27
|
return t;
|
|
62
28
|
}
|
|
63
29
|
|
|
30
|
+
function __awaiter(thisArg, _arguments, P, generator) {
|
|
31
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
32
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
33
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
34
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
35
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
36
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
|
|
64
40
|
typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
|
|
65
41
|
var e = new Error(message);
|
|
66
42
|
return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
|
|
67
43
|
};
|
|
68
44
|
|
|
45
|
+
class TypedWorker extends Worker {
|
|
46
|
+
postMessage(payload) {
|
|
47
|
+
super.postMessage(payload);
|
|
48
|
+
}
|
|
49
|
+
addEventListener(type, observer) {
|
|
50
|
+
super.addEventListener(type, observer);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
class UtilWorker extends TypedWorker {
|
|
55
|
+
constructor(scriptURL, options) {
|
|
56
|
+
super(scriptURL, options);
|
|
57
|
+
}
|
|
58
|
+
subscribe(observer) {
|
|
59
|
+
const onMessage = (event) => {
|
|
60
|
+
observer(event.data);
|
|
61
|
+
};
|
|
62
|
+
this.addEventListener('message', onMessage);
|
|
63
|
+
return () => {
|
|
64
|
+
this.removeEventListener('message', onMessage);
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
request(...payloads) {
|
|
68
|
+
return new Promise(resolve => {
|
|
69
|
+
const onMessage = ({ data }) => {
|
|
70
|
+
resolve(data);
|
|
71
|
+
this.removeEventListener('message', onMessage);
|
|
72
|
+
};
|
|
73
|
+
this.postMessage(payloads);
|
|
74
|
+
this.addEventListener('message', onMessage);
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
69
79
|
class WorkerBuilder {
|
|
70
80
|
static fromModule(Worker, _a) {
|
|
71
81
|
var { module } = _a, options = __rest(_a, ["module"]);
|
|
72
82
|
const code = `
|
|
73
83
|
self.addEventListener('message', event => {
|
|
74
|
-
const result = (${module.toString()})(event.data);
|
|
84
|
+
const result = (${module.toString()})(${module.length > 1 ? '...event.data' : 'event.data'});
|
|
75
85
|
|
|
76
86
|
self.postMessage(result);
|
|
77
87
|
});
|
|
78
88
|
`.trim();
|
|
79
89
|
const blob = new Blob([code]);
|
|
80
|
-
|
|
90
|
+
const url = URL.createObjectURL(blob);
|
|
91
|
+
const worker = new Worker(url, options);
|
|
92
|
+
const originTerminate = worker.terminate;
|
|
93
|
+
worker.terminate = () => {
|
|
94
|
+
originTerminate.call(worker);
|
|
95
|
+
URL.revokeObjectURL(url);
|
|
96
|
+
};
|
|
97
|
+
return worker;
|
|
81
98
|
}
|
|
82
99
|
}
|
|
83
100
|
|
|
101
|
+
const workerCleanupRegistry = new FinalizationRegistry((heldWorker) => heldWorker.terminate());
|
|
102
|
+
|
|
84
103
|
function background(fn) {
|
|
85
104
|
function createWorker() {
|
|
86
105
|
return WorkerBuilder.fromModule((UtilWorker), { module: fn });
|
|
87
106
|
}
|
|
88
107
|
if (typeof window === 'undefined') {
|
|
89
|
-
function runWithCreatingWorker(payload) {
|
|
90
|
-
|
|
91
|
-
|
|
108
|
+
function runWithCreatingWorker(...payload) {
|
|
109
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
110
|
+
const worker = createWorker();
|
|
111
|
+
const result = yield worker.request.call(worker, ...payload);
|
|
112
|
+
worker.terminate();
|
|
113
|
+
return result;
|
|
114
|
+
});
|
|
92
115
|
}
|
|
93
116
|
return runWithCreatingWorker;
|
|
94
117
|
}
|
|
95
118
|
const worker = createWorker();
|
|
96
|
-
|
|
119
|
+
const result = worker.request.bind(worker);
|
|
120
|
+
workerCleanupRegistry.register(result, worker);
|
|
121
|
+
return result;
|
|
97
122
|
}
|
|
98
123
|
|
|
99
124
|
export { background };
|
|
@@ -2,6 +2,5 @@ import { TypedWorker } from "./TypedWorker";
|
|
|
2
2
|
export declare class UtilWorker<Payload = never, Result = void> extends TypedWorker<Payload, Result> {
|
|
3
3
|
constructor(scriptURL: string | URL, options?: WorkerOptions);
|
|
4
4
|
subscribe(observer: (response: Result) => void): () => void;
|
|
5
|
-
request(): Promise<Result>;
|
|
6
|
-
request(payload: Payload): Promise<Result>;
|
|
5
|
+
request(...payloads: Payload[]): Promise<Result>;
|
|
7
6
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const workerCleanupRegistry: FinalizationRegistry<Worker>;
|