@kaspernj/api-maker 1.0.2121 → 1.0.2123
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 +45 -0
- package/build/channels-consumer.d.ts +1 -0
- package/build/channels-consumer.d.ts.map +1 -1
- package/build/channels-consumer.js +9 -2
- package/build/command-execution.d.ts +71 -0
- package/build/command-execution.d.ts.map +1 -0
- package/build/command-execution.js +138 -0
- package/build/commands-pool.d.ts +8 -4
- package/build/commands-pool.d.ts.map +1 -1
- package/build/commands-pool.js +58 -40
- package/build/config.d.ts +14 -0
- package/build/config.d.ts.map +1 -1
- package/build/config.js +17 -2
- package/build/devise.d.ts.map +1 -1
- package/build/devise.js +18 -4
- package/build/inputs/attachment.js +11 -3
- package/build/link.js +2 -2
- package/build/model-recipes-model-loader.d.ts.map +1 -1
- package/build/model-recipes-model-loader.js +5 -3
- package/build/session-status-updater.d.ts +5 -0
- package/build/session-status-updater.d.ts.map +1 -1
- package/build/session-status-updater.js +14 -3
- package/build/table/filters/load-search-modal.js +2 -2
- package/build/table/filters/save-search-modal.js +2 -2
- package/build/websocket-request-client.d.ts +55 -0
- package/build/websocket-request-client.d.ts.map +1 -0
- package/build/websocket-request-client.js +192 -0
- package/package.json +15 -5
package/README.md
CHANGED
|
@@ -8,6 +8,10 @@ Client-side library for ApiMaker-powered Rails APIs. It provides model classes,
|
|
|
8
8
|
npm install @kaspernj/api-maker
|
|
9
9
|
```
|
|
10
10
|
|
|
11
|
+
When working on this package locally, `npm install` uses the checked-in [`.npmrc`](/home/dev/Development/api_maker/npm-api-maker/.npmrc) with `legacy-peer-deps=true`. This keeps the ESLint 10 toolchain installable until `eslint-plugin-react` publishes an ESLint 10 peer range.
|
|
12
|
+
|
|
13
|
+
Peer-provided runtime packages that `npm-api-maker` imports in its own source, tests, or linked local/CI builds stay installed in this repo's `devDependencies` as well. For example, `react-native-vector-icons`, `flash-notifications`, `history`, and `i18n-on-steroids` are still peer-facing for consumers, but they must also exist locally when webpack, ESLint, or Jest resolves modules from the package directory itself.
|
|
14
|
+
|
|
11
15
|
## Quick start
|
|
12
16
|
|
|
13
17
|
ApiMaker models are generated from `model-recipes.json` (usually emitted by the Rails gem). Import the models and set up the shared config before making requests.
|
|
@@ -98,6 +102,47 @@ The relationship name is stored in `snake_case`, so `preloadRelationship("Accoun
|
|
|
98
102
|
|
|
99
103
|
`config` is a shared singleton. Some helpers (forms, routing, navigation, and money inputs) require config values like `history`, `linkTo`, `navigation`, and `currenciesCollection` to be set. If a required value is missing, the getter throws an error to avoid silent failures.
|
|
100
104
|
|
|
105
|
+
### Websocket requests
|
|
106
|
+
|
|
107
|
+
ApiMaker can send commands and services over ActionCable instead of the HTTP commands endpoint:
|
|
108
|
+
|
|
109
|
+
```js
|
|
110
|
+
import config from "@kaspernj/api-maker/build/config.js"
|
|
111
|
+
|
|
112
|
+
config.setWebsocketRequests(true)
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
This keeps request/response traffic on the shared websocket connection and lets the client reuse websocket-side request deduping and response caching.
|
|
116
|
+
|
|
117
|
+
When a command runs over websocket, the returned value is an awaitable command handle. It behaves like a promise, so existing code still works:
|
|
118
|
+
|
|
119
|
+
```js
|
|
120
|
+
const result = await User.customCommand({message: "Hello world"})
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
The same handle also exposes progress and log hooks for long-running commands:
|
|
124
|
+
|
|
125
|
+
```js
|
|
126
|
+
const command = User.customCommand({message: "Hello world"})
|
|
127
|
+
|
|
128
|
+
command.onReceived(() => console.log("received"))
|
|
129
|
+
command.onProgress(({progress, count, total}) => console.log(progress, count, total))
|
|
130
|
+
command.onLog((message) => console.log(message))
|
|
131
|
+
|
|
132
|
+
const result = await command
|
|
133
|
+
const latestProgress = await command.progress()
|
|
134
|
+
const logs = command.logs()
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
On the Ruby side, websocket-backed commands and services can report progress through `current_command`:
|
|
138
|
+
|
|
139
|
+
```ruby
|
|
140
|
+
current_command.total = 10
|
|
141
|
+
current_command.log("Starting")
|
|
142
|
+
current_command.increment!
|
|
143
|
+
current_command.progress = 0.5
|
|
144
|
+
```
|
|
145
|
+
|
|
101
146
|
## Realtime model events
|
|
102
147
|
|
|
103
148
|
For model-specific websocket events in React/ShapeComponent UI code, prefer `useModelEvent` over manual `ModelEvents.connect(...)` subscriptions. The hook handles subscription lifecycle automatically and avoids leaked listeners.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"channels-consumer.d.ts","sourceRoot":"/src/","sources":["channels-consumer.js"],"names":[],"mappings":"AAKe,6BADD,GAAG,
|
|
1
|
+
{"version":3,"file":"channels-consumer.d.ts","sourceRoot":"/src/","sources":["channels-consumer.js"],"names":[],"mappings":"AAKe,6BADD,GAAG,CAOhB;;AAGM,yCADO,IAAI,CAQjB"}
|
|
@@ -4,9 +4,16 @@ import { createConsumer } from "@rails/actioncable"; // eslint-disable-line impo
|
|
|
4
4
|
/** @returns {any} */
|
|
5
5
|
export default () => {
|
|
6
6
|
if (!globalThis.apiMakerChannelsConsumer) {
|
|
7
|
-
// @ts-expect-error
|
|
8
7
|
globalThis.apiMakerChannelsConsumer = createConsumer(Config.getCableUrl());
|
|
9
8
|
}
|
|
10
9
|
return globalThis.apiMakerChannelsConsumer;
|
|
11
10
|
};
|
|
12
|
-
|
|
11
|
+
/** @returns {void} */
|
|
12
|
+
export const resetChannelsConsumer = () => {
|
|
13
|
+
if (!globalThis.apiMakerChannelsConsumer) {
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
globalThis.apiMakerChannelsConsumer.disconnect();
|
|
17
|
+
delete globalThis.apiMakerChannelsConsumer;
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhbm5lbHMtY29uc3VtZXIuanMiLCJzb3VyY2VSb290IjoiL3NyYy8iLCJzb3VyY2VzIjpbImNoYW5uZWxzLWNvbnN1bWVyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sTUFBTSxNQUFNLGFBQWEsQ0FBQTtBQUNoQyxtQkFBbUI7QUFDbkIsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLG9CQUFvQixDQUFBLENBQUMsMkNBQTJDO0FBRTdGLHFCQUFxQjtBQUNyQixlQUFlLEdBQUcsRUFBRTtJQUNsQixJQUFJLENBQUMsVUFBVSxDQUFDLHdCQUF3QixFQUFFLENBQUM7UUFDekMsVUFBVSxDQUFDLHdCQUF3QixHQUFHLGNBQWMsQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQTtJQUM1RSxDQUFDO0lBRUQsT0FBTyxVQUFVLENBQUMsd0JBQXdCLENBQUE7QUFDNUMsQ0FBQyxDQUFBO0FBRUQsc0JBQXNCO0FBQ3RCLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLEdBQUcsRUFBRTtJQUN4QyxJQUFJLENBQUMsVUFBVSxDQUFDLHdCQUF3QixFQUFFLENBQUM7UUFDekMsT0FBTTtJQUNSLENBQUM7SUFFRCxVQUFVLENBQUMsd0JBQXdCLENBQUMsVUFBVSxFQUFFLENBQUE7SUFDaEQsT0FBTyxVQUFVLENBQUMsd0JBQXdCLENBQUE7QUFDNUMsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IENvbmZpZyBmcm9tIFwiLi9jb25maWcuanNcIlxuLy8gQHRzLWV4cGVjdC1lcnJvclxuaW1wb3J0IHtjcmVhdGVDb25zdW1lcn0gZnJvbSBcIkByYWlscy9hY3Rpb25jYWJsZVwiIC8vIGVzbGludC1kaXNhYmxlLWxpbmUgaW1wb3J0L25vLXVucmVzb2x2ZWRcblxuLyoqIEByZXR1cm5zIHthbnl9ICovXG5leHBvcnQgZGVmYXVsdCAoKSA9PiB7XG4gIGlmICghZ2xvYmFsVGhpcy5hcGlNYWtlckNoYW5uZWxzQ29uc3VtZXIpIHtcbiAgICBnbG9iYWxUaGlzLmFwaU1ha2VyQ2hhbm5lbHNDb25zdW1lciA9IGNyZWF0ZUNvbnN1bWVyKENvbmZpZy5nZXRDYWJsZVVybCgpKVxuICB9XG5cbiAgcmV0dXJuIGdsb2JhbFRoaXMuYXBpTWFrZXJDaGFubmVsc0NvbnN1bWVyXG59XG5cbi8qKiBAcmV0dXJucyB7dm9pZH0gKi9cbmV4cG9ydCBjb25zdCByZXNldENoYW5uZWxzQ29uc3VtZXIgPSAoKSA9PiB7XG4gIGlmICghZ2xvYmFsVGhpcy5hcGlNYWtlckNoYW5uZWxzQ29uc3VtZXIpIHtcbiAgICByZXR1cm5cbiAgfVxuXG4gIGdsb2JhbFRoaXMuYXBpTWFrZXJDaGFubmVsc0NvbnN1bWVyLmRpc2Nvbm5lY3QoKVxuICBkZWxldGUgZ2xvYmFsVGhpcy5hcGlNYWtlckNoYW5uZWxzQ29uc3VtZXJcbn1cbiJdfQ==
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
/** Shared thenable command handle with progress and log subscriptions. */
|
|
2
|
+
export default class ApiMakerCommandExecution {
|
|
3
|
+
logListeners: any[];
|
|
4
|
+
logsData: any[];
|
|
5
|
+
progressListeners: any[];
|
|
6
|
+
receivedListeners: any[];
|
|
7
|
+
progressPromise: Promise<any>;
|
|
8
|
+
resolveProgressPromise: (value: any) => void;
|
|
9
|
+
receivedPromise: Promise<any>;
|
|
10
|
+
resolveReceivedPromise: (value: any) => void;
|
|
11
|
+
resultPromise: Promise<any>;
|
|
12
|
+
resolveResultPromise: (value: any) => void;
|
|
13
|
+
rejectResultPromise: (reason?: any) => void;
|
|
14
|
+
/**
|
|
15
|
+
* @param {(value: Record<string, any>) => void} callback
|
|
16
|
+
* @returns {() => void}
|
|
17
|
+
*/
|
|
18
|
+
onReceived(callback: (value: Record<string, any>) => void): () => void;
|
|
19
|
+
/**
|
|
20
|
+
* @param {(value: Record<string, any> | undefined) => void} callback
|
|
21
|
+
* @returns {() => void}
|
|
22
|
+
*/
|
|
23
|
+
onProgress(callback: (value: Record<string, any> | undefined) => void): () => void;
|
|
24
|
+
/**
|
|
25
|
+
* @param {(value: string) => void} callback
|
|
26
|
+
* @returns {() => void}
|
|
27
|
+
*/
|
|
28
|
+
onLog(callback: (value: string) => void): () => void;
|
|
29
|
+
/** @returns {Promise<Record<string, any> | undefined>} */
|
|
30
|
+
progress(): Promise<Record<string, any> | undefined>;
|
|
31
|
+
/** @returns {Promise<Record<string, any> | undefined>} */
|
|
32
|
+
received(): Promise<Record<string, any> | undefined>;
|
|
33
|
+
/** @returns {string[]} */
|
|
34
|
+
logs(): string[];
|
|
35
|
+
/** @returns {Promise<any>} */
|
|
36
|
+
result(): Promise<any>;
|
|
37
|
+
/** @returns {Promise<any>} */
|
|
38
|
+
then(...args: any[]): Promise<any>;
|
|
39
|
+
/** @returns {Promise<any>} */
|
|
40
|
+
catch(...args: any[]): Promise<any>;
|
|
41
|
+
/** @returns {Promise<any>} */
|
|
42
|
+
finally(...args: any[]): Promise<any>;
|
|
43
|
+
/**
|
|
44
|
+
* @param {Record<string, any>} data
|
|
45
|
+
* @returns {void}
|
|
46
|
+
*/
|
|
47
|
+
setReceived(data: Record<string, any>): void;
|
|
48
|
+
receivedData: Record<string, any>;
|
|
49
|
+
/**
|
|
50
|
+
* @param {Record<string, any>} data
|
|
51
|
+
* @returns {void}
|
|
52
|
+
*/
|
|
53
|
+
setProgress(data: Record<string, any>): void;
|
|
54
|
+
progressData: Record<string, any>;
|
|
55
|
+
/**
|
|
56
|
+
* @param {string} message
|
|
57
|
+
* @returns {void}
|
|
58
|
+
*/
|
|
59
|
+
addLog(message: string): void;
|
|
60
|
+
/**
|
|
61
|
+
* @param {any} value
|
|
62
|
+
* @returns {void}
|
|
63
|
+
*/
|
|
64
|
+
resolve(value: any): void;
|
|
65
|
+
/**
|
|
66
|
+
* @param {any} error
|
|
67
|
+
* @returns {void}
|
|
68
|
+
*/
|
|
69
|
+
reject(error: any): void;
|
|
70
|
+
}
|
|
71
|
+
//# sourceMappingURL=command-execution.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"command-execution.d.ts","sourceRoot":"/src/","sources":["command-execution.js"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E;IAGI,oBAAsB;IACtB,gBAAkB;IAClB,yBAA2B;IAC3B,yBAA2B;IAE3B,8BAEE;IADA,6CAAqC;IAEvC,8BAEE;IADA,6CAAqC;IAEvC,4BAGE;IAFA,2CAAmC;IACnC,4CAAiC;IAIrC;;;OAGG;IACH,qBAHW,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,IAAI,GAClC,MAAM,IAAI,CAYtB;IAED;;;OAGG;IACH,qBAHW,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,SAAS,KAAK,IAAI,GAC9C,MAAM,IAAI,CAYtB;IAED;;;OAGG;IACH,gBAHW,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,GACrB,MAAM,IAAI,CAYtB;IAED,0DAA0D;IAC1D,YADc,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,SAAS,CAAC,CAGrD;IAED,0DAA0D;IAC1D,YADc,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,SAAS,CAAC,CAGrD;IAED,0BAA0B;IAC1B,QADc,MAAM,EAAE,CAGrB;IAED,8BAA8B;IAC9B,UADc,OAAO,CAAC,GAAG,CAAC,CAGzB;IAED,8BAA8B;IAC9B,sBADc,OAAO,CAAC,GAAG,CAAC,CAGzB;IAED,8BAA8B;IAC9B,uBADc,OAAO,CAAC,GAAG,CAAC,CAGzB;IAED,8BAA8B;IAC9B,yBADc,OAAO,CAAC,GAAG,CAAC,CAGzB;IAED;;;OAGG;IACH,kBAHW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GACjB,IAAI,CAShB;IANC,kCAAwB;IAQ1B;;;OAGG;IACH,kBAHW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GACjB,IAAI,CAShB;IANC,kCAAwB;IAQ1B;;;OAGG;IACH,gBAHW,MAAM,GACJ,IAAI,CAQhB;IAED;;;OAGG;IACH,eAHW,GAAG,GACD,IAAI,CAMhB;IAED;;;OAGG;IACH,cAHW,GAAG,GACD,IAAI,CAMhB;CACF"}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
/** Shared thenable command handle with progress and log subscriptions. */
|
|
2
|
+
export default class ApiMakerCommandExecution {
|
|
3
|
+
/** Constructor. */
|
|
4
|
+
constructor() {
|
|
5
|
+
this.logListeners = [];
|
|
6
|
+
this.logsData = [];
|
|
7
|
+
this.progressListeners = [];
|
|
8
|
+
this.receivedListeners = [];
|
|
9
|
+
this.progressPromise = new Promise((resolve) => {
|
|
10
|
+
this.resolveProgressPromise = resolve;
|
|
11
|
+
});
|
|
12
|
+
this.receivedPromise = new Promise((resolve) => {
|
|
13
|
+
this.resolveReceivedPromise = resolve;
|
|
14
|
+
});
|
|
15
|
+
this.resultPromise = new Promise((resolve, reject) => {
|
|
16
|
+
this.resolveResultPromise = resolve;
|
|
17
|
+
this.rejectResultPromise = reject;
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* @param {(value: Record<string, any>) => void} callback
|
|
22
|
+
* @returns {() => void}
|
|
23
|
+
*/
|
|
24
|
+
onReceived(callback) {
|
|
25
|
+
this.receivedListeners.push(callback);
|
|
26
|
+
if (this.receivedData) {
|
|
27
|
+
callback(this.receivedData);
|
|
28
|
+
}
|
|
29
|
+
return () => {
|
|
30
|
+
this.receivedListeners = this.receivedListeners.filter((listener) => listener !== callback);
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* @param {(value: Record<string, any> | undefined) => void} callback
|
|
35
|
+
* @returns {() => void}
|
|
36
|
+
*/
|
|
37
|
+
onProgress(callback) {
|
|
38
|
+
this.progressListeners.push(callback);
|
|
39
|
+
if (this.progressData) {
|
|
40
|
+
callback(this.progressData);
|
|
41
|
+
}
|
|
42
|
+
return () => {
|
|
43
|
+
this.progressListeners = this.progressListeners.filter((listener) => listener !== callback);
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* @param {(value: string) => void} callback
|
|
48
|
+
* @returns {() => void}
|
|
49
|
+
*/
|
|
50
|
+
onLog(callback) {
|
|
51
|
+
this.logListeners.push(callback);
|
|
52
|
+
for (const message of this.logsData) {
|
|
53
|
+
callback(message);
|
|
54
|
+
}
|
|
55
|
+
return () => {
|
|
56
|
+
this.logListeners = this.logListeners.filter((listener) => listener !== callback);
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
/** @returns {Promise<Record<string, any> | undefined>} */
|
|
60
|
+
progress() {
|
|
61
|
+
return this.progressData ? Promise.resolve(this.progressData) : this.progressPromise;
|
|
62
|
+
}
|
|
63
|
+
/** @returns {Promise<Record<string, any> | undefined>} */
|
|
64
|
+
received() {
|
|
65
|
+
return this.receivedData ? Promise.resolve(this.receivedData) : this.receivedPromise;
|
|
66
|
+
}
|
|
67
|
+
/** @returns {string[]} */
|
|
68
|
+
logs() {
|
|
69
|
+
return [...this.logsData];
|
|
70
|
+
}
|
|
71
|
+
/** @returns {Promise<any>} */
|
|
72
|
+
result() {
|
|
73
|
+
return this.resultPromise;
|
|
74
|
+
}
|
|
75
|
+
/** @returns {Promise<any>} */
|
|
76
|
+
then(...args) {
|
|
77
|
+
return this.resultPromise.then(...args);
|
|
78
|
+
}
|
|
79
|
+
/** @returns {Promise<any>} */
|
|
80
|
+
catch(...args) {
|
|
81
|
+
return this.resultPromise.catch(...args);
|
|
82
|
+
}
|
|
83
|
+
/** @returns {Promise<any>} */
|
|
84
|
+
finally(...args) {
|
|
85
|
+
return this.resultPromise.finally(...args);
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* @param {Record<string, any>} data
|
|
89
|
+
* @returns {void}
|
|
90
|
+
*/
|
|
91
|
+
setReceived(data) {
|
|
92
|
+
this.receivedData = data;
|
|
93
|
+
this.resolveReceivedPromise?.(data);
|
|
94
|
+
for (const listener of this.receivedListeners) {
|
|
95
|
+
listener(data);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* @param {Record<string, any>} data
|
|
100
|
+
* @returns {void}
|
|
101
|
+
*/
|
|
102
|
+
setProgress(data) {
|
|
103
|
+
this.progressData = data;
|
|
104
|
+
this.resolveProgressPromise?.(data);
|
|
105
|
+
for (const listener of this.progressListeners) {
|
|
106
|
+
listener(data);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* @param {string} message
|
|
111
|
+
* @returns {void}
|
|
112
|
+
*/
|
|
113
|
+
addLog(message) {
|
|
114
|
+
this.logsData.push(message);
|
|
115
|
+
for (const listener of this.logListeners) {
|
|
116
|
+
listener(message);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* @param {any} value
|
|
121
|
+
* @returns {void}
|
|
122
|
+
*/
|
|
123
|
+
resolve(value) {
|
|
124
|
+
this.resolveProgressPromise?.(this.progressData);
|
|
125
|
+
this.resolveReceivedPromise?.(this.receivedData);
|
|
126
|
+
this.resolveResultPromise(value);
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* @param {any} error
|
|
130
|
+
* @returns {void}
|
|
131
|
+
*/
|
|
132
|
+
reject(error) {
|
|
133
|
+
this.resolveProgressPromise?.(this.progressData);
|
|
134
|
+
this.resolveReceivedPromise?.(this.receivedData);
|
|
135
|
+
this.rejectResultPromise(error);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"command-execution.js","sourceRoot":"/src/","sources":["command-execution.js"],"names":[],"mappings":"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","sourcesContent":["/** Shared thenable command handle with progress and log subscriptions. */\nexport default class ApiMakerCommandExecution {\n  /** Constructor. */\n  constructor () {\n    this.logListeners = []\n    this.logsData = []\n    this.progressListeners = []\n    this.receivedListeners = []\n\n    this.progressPromise = new Promise((resolve) => {\n      this.resolveProgressPromise = resolve\n    })\n    this.receivedPromise = new Promise((resolve) => {\n      this.resolveReceivedPromise = resolve\n    })\n    this.resultPromise = new Promise((resolve, reject) => {\n      this.resolveResultPromise = resolve\n      this.rejectResultPromise = reject\n    })\n  }\n\n  /**\n   * @param {(value: Record<string, any>) => void} callback\n   * @returns {() => void}\n   */\n  onReceived (callback) {\n    this.receivedListeners.push(callback)\n\n    if (this.receivedData) {\n      callback(this.receivedData)\n    }\n\n    return () => {\n      this.receivedListeners = this.receivedListeners.filter((listener) => listener !== callback)\n    }\n  }\n\n  /**\n   * @param {(value: Record<string, any> | undefined) => void} callback\n   * @returns {() => void}\n   */\n  onProgress (callback) {\n    this.progressListeners.push(callback)\n\n    if (this.progressData) {\n      callback(this.progressData)\n    }\n\n    return () => {\n      this.progressListeners = this.progressListeners.filter((listener) => listener !== callback)\n    }\n  }\n\n  /**\n   * @param {(value: string) => void} callback\n   * @returns {() => void}\n   */\n  onLog (callback) {\n    this.logListeners.push(callback)\n\n    for (const message of this.logsData) {\n      callback(message)\n    }\n\n    return () => {\n      this.logListeners = this.logListeners.filter((listener) => listener !== callback)\n    }\n  }\n\n  /** @returns {Promise<Record<string, any> | undefined>} */\n  progress () {\n    return this.progressData ? Promise.resolve(this.progressData) : this.progressPromise\n  }\n\n  /** @returns {Promise<Record<string, any> | undefined>} */\n  received () {\n    return this.receivedData ? Promise.resolve(this.receivedData) : this.receivedPromise\n  }\n\n  /** @returns {string[]} */\n  logs () {\n    return [...this.logsData]\n  }\n\n  /** @returns {Promise<any>} */\n  result () {\n    return this.resultPromise\n  }\n\n  /** @returns {Promise<any>} */\n  then (...args) {\n    return this.resultPromise.then(...args)\n  }\n\n  /** @returns {Promise<any>} */\n  catch (...args) {\n    return this.resultPromise.catch(...args)\n  }\n\n  /** @returns {Promise<any>} */\n  finally (...args) {\n    return this.resultPromise.finally(...args)\n  }\n\n  /**\n   * @param {Record<string, any>} data\n   * @returns {void}\n   */\n  setReceived (data) {\n    this.receivedData = data\n    this.resolveReceivedPromise?.(data)\n\n    for (const listener of this.receivedListeners) {\n      listener(data)\n    }\n  }\n\n  /**\n   * @param {Record<string, any>} data\n   * @returns {void}\n   */\n  setProgress (data) {\n    this.progressData = data\n    this.resolveProgressPromise?.(data)\n\n    for (const listener of this.progressListeners) {\n      listener(data)\n    }\n  }\n\n  /**\n   * @param {string} message\n   * @returns {void}\n   */\n  addLog (message) {\n    this.logsData.push(message)\n\n    for (const listener of this.logListeners) {\n      listener(message)\n    }\n  }\n\n  /**\n   * @param {any} value\n   * @returns {void}\n   */\n  resolve (value) {\n    this.resolveProgressPromise?.(this.progressData)\n    this.resolveReceivedPromise?.(this.receivedData)\n    this.resolveResultPromise(value)\n  }\n\n  /**\n   * @param {any} error\n   * @returns {void}\n   */\n  reject (error) {\n    this.resolveProgressPromise?.(this.progressData)\n    this.resolveReceivedPromise?.(this.receivedData)\n    this.rejectResultPromise(error)\n  }\n}\n"]}
|
package/build/commands-pool.d.ts
CHANGED
|
@@ -14,19 +14,23 @@ export default class ApiMakerCommandsPool {
|
|
|
14
14
|
currentId: number;
|
|
15
15
|
/** @type {Record<string, any>} */
|
|
16
16
|
globalRequestData: Record<string, any>;
|
|
17
|
+
/** @type {Record<string, any>} */
|
|
18
|
+
requestOptions: Record<string, any>;
|
|
17
19
|
/** addCommand. */
|
|
18
|
-
addCommand(data: any):
|
|
20
|
+
addCommand(data: any): ApiMakerCommandExecution;
|
|
19
21
|
/** @returns {number} */
|
|
20
22
|
commandsCount(): number;
|
|
21
23
|
/**
|
|
22
24
|
* @param {object} args
|
|
23
25
|
* @param {string} args.url
|
|
24
26
|
* @param {CommandSubmitData} args.commandSubmitData
|
|
27
|
+
* @param {ApiMakerCommandExecution} [args.commandExecution]
|
|
25
28
|
* @returns {Promise<Record<string, any>>}
|
|
26
29
|
*/
|
|
27
|
-
sendRequest({ commandSubmitData, url }: {
|
|
30
|
+
sendRequest({ commandExecution, commandSubmitData, url }: {
|
|
28
31
|
url: string;
|
|
29
32
|
commandSubmitData: CommandSubmitData;
|
|
33
|
+
commandExecution?: ApiMakerCommandExecution;
|
|
30
34
|
}): Promise<Record<string, any>>;
|
|
31
35
|
/** flush. */
|
|
32
36
|
flush: () => Promise<void>;
|
|
@@ -48,8 +52,7 @@ export default class ApiMakerCommandsPool {
|
|
|
48
52
|
flushRunLast: RunLast;
|
|
49
53
|
}
|
|
50
54
|
export type CommandDataType = {
|
|
51
|
-
|
|
52
|
-
reject: Function;
|
|
55
|
+
commandExecution: ApiMakerCommandExecution;
|
|
53
56
|
stack: string;
|
|
54
57
|
};
|
|
55
58
|
export type PoolDataType = {
|
|
@@ -65,6 +68,7 @@ export type PoolDataType = {
|
|
|
65
68
|
};
|
|
66
69
|
};
|
|
67
70
|
};
|
|
71
|
+
import ApiMakerCommandExecution from "./command-execution.js";
|
|
68
72
|
import CommandSubmitData from "./command-submit-data.js";
|
|
69
73
|
import RunLast from "./run-last.js";
|
|
70
74
|
//# sourceMappingURL=commands-pool.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"commands-pool.d.ts","sourceRoot":"/src/","sources":["commands-pool.js"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"commands-pool.d.ts","sourceRoot":"/src/","sources":["commands-pool.js"],"names":[],"mappings":"AA6BA,4BAA4B;AAC5B;IACE,kBAAkB;IAClB,6CAqBC;IAED,eAAe;IACf,sBAIC;IAED,aAAa;IACb,qBAEC;IAIC,mBAAmB;IAEnB,8CAA8C;IAC9C,MADW,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAC5B;IAEd,2BAA2B;IAC3B,UADW,YAAY,CACL;IAElB,kBAAkB;IAElB,kCAAkC;IAClC,mBADW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CACH;IAE3B,kCAAkC;IAClC,gBADW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CACN;IAG1B,kBAAkB;IAClB,gDAkCC;IAED,wBAAwB;IACxB,iBADc,MAAM,CAGnB;IAED;;;;;;OAMG;IACH,0DALG;QAAqB,GAAG,EAAhB,MAAM;QACkB,iBAAiB,EAAzC,iBAAiB;QACe,gBAAgB,GAAhD,wBAAwB;KAChC,GAAU,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAiCxC;IAED,aAAa;IACb,2BAyDC;IAED;;;;;;;OAOG;IACH,kCAPW,eAAe,uBAEvB;QAAoC,UAAU,EAAtC,MAAM;QACwB,MAAM,EAApC,MAAM,EAAE;QACsB,iBAAiB,EAA/C,MAAM,EAAE;KAChB,GAAU,IAAI,CA0BhB;IAED,gBAAgB;IAChB,oBAUC;IAED,sBAAsC;CACvC;;sBA/Pa,wBAAwB;WACxB,MAAM;;2BAGN;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG;YAAC,CAAC,GAAG,EAAE,MAAM,GAAG;gBAAC,CAAC,GAAG,EAAE,MAAM,GAAG;oBAAC,IAAI,EAAE,MAAM,CAAC;oBAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAAC;oBAAC,EAAE,EAAE,MAAM,CAAA;iBAAC,CAAA;aAAC,CAAA;SAAC,CAAA;KAAC,CAAA;CAAC;qCAtBrG,wBAAwB;8BAC/B,0BAA0B;oBAQpC,eAAe"}
|