@operato/scene-restful 1.1.23 → 1.1.27
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/CHANGELOG.md +18 -0
- package/assets/favicon.ico +0 -0
- package/assets/images/spinner.png +0 -0
- package/dist/restful.d.ts +6 -11
- package/dist/restful.js +264 -84
- package/dist/restful.js.map +1 -1
- package/helps/scene/component/restful.ko.md +11 -9
- package/helps/scene/component/restful.md +13 -10
- package/helps/scene/component/restful.zh.md +10 -9
- package/logs/.08636eb59927f12972f6774f5947c8507b3564c2-audit.json +25 -0
- package/logs/.5e5d741d8b7784a2fbad65eedc0fd46946aaf6f2-audit.json +20 -0
- package/logs/application-2023-01-11-06.log +12 -0
- package/logs/application-2023-01-11-09.log +1 -0
- package/logs/application-2023-01-11-10.log +7 -0
- package/logs/connections-2023-01-11-06.log +35 -0
- package/logs/connections-2023-01-11-10.log +35 -0
- package/package.json +2 -2
- package/src/restful.ts +280 -90
- package/translations/en.json +8 -1
- package/translations/ko.json +8 -1
- package/translations/zh.json +8 -1
- package/tsconfig.tsbuildinfo +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,24 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
### [1.1.27](https://github.com/things-scene/operato-scene/compare/v1.1.26...v1.1.27) (2023-01-11)
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
### :bug: Bug Fix
|
|
10
|
+
|
|
11
|
+
* reinvent scene-restful ([52bc04a](https://github.com/things-scene/operato-scene/commit/52bc04a429c7eb6a8c4de010efd6ce2c6d8de7c1))
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
### [1.1.26](https://github.com/things-scene/operato-scene/compare/v1.1.25...v1.1.26) (2023-01-11)
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
### :bug: Bug Fix
|
|
19
|
+
|
|
20
|
+
* reinvent scene-restful component ([91097d0](https://github.com/things-scene/operato-scene/commit/91097d0c20948c0cdfd31e47a24f621613c4870a))
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
|
|
6
24
|
### [1.1.23](https://github.com/things-scene/operato-scene/compare/v1.1.22...v1.1.23) (2022-12-18)
|
|
7
25
|
|
|
8
26
|
|
|
Binary file
|
|
Binary file
|
package/dist/restful.d.ts
CHANGED
|
@@ -7,29 +7,24 @@ declare const Restful_base: (new (...args: any[]) => {
|
|
|
7
7
|
export default class Restful extends Restful_base {
|
|
8
8
|
static _image: HTMLImageElement;
|
|
9
9
|
static get image(): HTMLImageElement;
|
|
10
|
+
private _repeatTimer;
|
|
11
|
+
private _isStarted;
|
|
10
12
|
get url(): any;
|
|
11
13
|
set url(url: any);
|
|
12
14
|
get period(): number;
|
|
13
15
|
set period(period: number);
|
|
16
|
+
get value(): any;
|
|
17
|
+
set value(value: any);
|
|
14
18
|
get withCredentials(): boolean;
|
|
15
19
|
set withCredentials(withCredentials: boolean);
|
|
16
|
-
_repeatTimer: NodeJS.Timeout;
|
|
17
|
-
_httpRequest?: any;
|
|
18
|
-
_isStarted: boolean;
|
|
19
20
|
get repeatTimer(): NodeJS.Timeout;
|
|
20
21
|
set repeatTimer(repeatTimer: NodeJS.Timeout);
|
|
21
|
-
get httpRequest(): any;
|
|
22
|
-
set httpRequest(httpRequest: any);
|
|
23
22
|
ready(): void;
|
|
24
|
-
_initRestful(): void;
|
|
23
|
+
_initRestful(force?: boolean): void;
|
|
25
24
|
dispose(): void;
|
|
26
25
|
_startRepeater(): void;
|
|
27
26
|
_stopRepeater(): void;
|
|
28
|
-
|
|
29
|
-
_makeRequestJsonp(url: string): void;
|
|
30
|
-
_abortRequest(): void;
|
|
31
|
-
onDataReceived(): void;
|
|
32
|
-
callAjax(): void;
|
|
27
|
+
fetch(): Promise<void>;
|
|
33
28
|
_draw(context: CanvasRenderingContext2D): void;
|
|
34
29
|
ondblclick(e: Event): void;
|
|
35
30
|
get controls(): never[];
|
package/dist/restful.js
CHANGED
|
@@ -5,16 +5,40 @@ const NATURE = {
|
|
|
5
5
|
resizable: true,
|
|
6
6
|
rotatable: true,
|
|
7
7
|
properties: [
|
|
8
|
+
{
|
|
9
|
+
type: 'select',
|
|
10
|
+
label: 'method',
|
|
11
|
+
name: 'method',
|
|
12
|
+
property: {
|
|
13
|
+
options: [
|
|
14
|
+
{
|
|
15
|
+
display: 'GET',
|
|
16
|
+
value: 'GET'
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
display: 'POST',
|
|
20
|
+
value: 'POST'
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
display: 'PUT',
|
|
24
|
+
value: 'PUT'
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
display: 'DELETE',
|
|
28
|
+
value: 'DELETE'
|
|
29
|
+
}
|
|
30
|
+
]
|
|
31
|
+
}
|
|
32
|
+
},
|
|
8
33
|
{
|
|
9
34
|
type: 'string',
|
|
10
35
|
label: 'url',
|
|
11
36
|
name: 'url'
|
|
12
37
|
},
|
|
13
38
|
{
|
|
14
|
-
type: '
|
|
15
|
-
label: '
|
|
16
|
-
name: '
|
|
17
|
-
placeholder: 'SECONDS'
|
|
39
|
+
type: 'string',
|
|
40
|
+
label: 'authorization',
|
|
41
|
+
name: 'authorization'
|
|
18
42
|
},
|
|
19
43
|
{
|
|
20
44
|
type: 'select',
|
|
@@ -23,27 +47,194 @@ const NATURE = {
|
|
|
23
47
|
property: {
|
|
24
48
|
options: [
|
|
25
49
|
{
|
|
26
|
-
display: '
|
|
50
|
+
display: 'json',
|
|
51
|
+
value: 'json'
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
display: 'jsonp',
|
|
55
|
+
value: 'jsonp'
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
display: 'text',
|
|
27
59
|
value: 'text'
|
|
60
|
+
}
|
|
61
|
+
]
|
|
62
|
+
}
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
type: 'select',
|
|
66
|
+
label: 'content-type',
|
|
67
|
+
name: 'contentType',
|
|
68
|
+
property: {
|
|
69
|
+
options: [
|
|
70
|
+
{
|
|
71
|
+
display: 'application/json',
|
|
72
|
+
value: 'application/json'
|
|
28
73
|
},
|
|
29
74
|
{
|
|
30
|
-
display: '
|
|
31
|
-
value: '
|
|
75
|
+
display: 'application/x-www-form-urlencoded',
|
|
76
|
+
value: 'application/x-www-form-urlencoded'
|
|
32
77
|
},
|
|
33
78
|
{
|
|
34
|
-
display: '
|
|
35
|
-
value: '
|
|
79
|
+
display: 'text/plain',
|
|
80
|
+
value: 'text/plain'
|
|
81
|
+
}
|
|
82
|
+
]
|
|
83
|
+
}
|
|
84
|
+
},
|
|
85
|
+
{
|
|
86
|
+
type: 'select',
|
|
87
|
+
label: 'mode',
|
|
88
|
+
name: 'mode',
|
|
89
|
+
property: {
|
|
90
|
+
options: [
|
|
91
|
+
{
|
|
92
|
+
display: 'cors',
|
|
93
|
+
value: 'cors'
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
display: 'no-cors',
|
|
97
|
+
value: 'no-cors'
|
|
98
|
+
},
|
|
99
|
+
{
|
|
100
|
+
display: 'same-origin',
|
|
101
|
+
value: 'same-origin'
|
|
102
|
+
}
|
|
103
|
+
]
|
|
104
|
+
}
|
|
105
|
+
},
|
|
106
|
+
{
|
|
107
|
+
type: 'select',
|
|
108
|
+
label: 'credentials',
|
|
109
|
+
name: 'credentials',
|
|
110
|
+
property: {
|
|
111
|
+
options: [
|
|
112
|
+
{
|
|
113
|
+
display: 'same-origin',
|
|
114
|
+
value: 'same-origin'
|
|
115
|
+
},
|
|
116
|
+
{
|
|
117
|
+
display: 'include',
|
|
118
|
+
value: 'include'
|
|
119
|
+
},
|
|
120
|
+
{
|
|
121
|
+
display: 'omit',
|
|
122
|
+
value: 'omit'
|
|
123
|
+
}
|
|
124
|
+
]
|
|
125
|
+
}
|
|
126
|
+
},
|
|
127
|
+
{
|
|
128
|
+
type: 'select',
|
|
129
|
+
label: 'cache',
|
|
130
|
+
name: 'cache',
|
|
131
|
+
property: {
|
|
132
|
+
options: [
|
|
133
|
+
{
|
|
134
|
+
display: 'default',
|
|
135
|
+
value: 'default'
|
|
136
|
+
},
|
|
137
|
+
{
|
|
138
|
+
display: 'no-cache',
|
|
139
|
+
value: 'no-cache'
|
|
140
|
+
},
|
|
141
|
+
{
|
|
142
|
+
display: 'reload',
|
|
143
|
+
value: 'reload'
|
|
144
|
+
},
|
|
145
|
+
{
|
|
146
|
+
display: 'force-cache',
|
|
147
|
+
value: 'force-cache'
|
|
148
|
+
},
|
|
149
|
+
{
|
|
150
|
+
display: 'only-if-cached',
|
|
151
|
+
value: 'only-if-cached'
|
|
152
|
+
}
|
|
153
|
+
]
|
|
154
|
+
}
|
|
155
|
+
},
|
|
156
|
+
{
|
|
157
|
+
type: 'select',
|
|
158
|
+
label: 'redirect',
|
|
159
|
+
name: 'redirect',
|
|
160
|
+
property: {
|
|
161
|
+
options: [
|
|
162
|
+
{
|
|
163
|
+
display: 'follow',
|
|
164
|
+
value: 'follow'
|
|
165
|
+
},
|
|
166
|
+
{
|
|
167
|
+
display: 'manual',
|
|
168
|
+
value: 'manual'
|
|
169
|
+
},
|
|
170
|
+
{
|
|
171
|
+
display: 'error',
|
|
172
|
+
value: 'error'
|
|
173
|
+
}
|
|
174
|
+
]
|
|
175
|
+
}
|
|
176
|
+
},
|
|
177
|
+
{
|
|
178
|
+
type: 'select',
|
|
179
|
+
label: 'referrer-policy',
|
|
180
|
+
name: 'referrerPolicy',
|
|
181
|
+
property: {
|
|
182
|
+
options: [
|
|
183
|
+
{
|
|
184
|
+
display: 'no-referrer-when-downgrade',
|
|
185
|
+
value: 'no-referrer-when-downgrade'
|
|
186
|
+
},
|
|
187
|
+
{
|
|
188
|
+
display: 'no-referrer',
|
|
189
|
+
value: 'no-referrer'
|
|
190
|
+
},
|
|
191
|
+
{
|
|
192
|
+
display: 'origin',
|
|
193
|
+
value: 'origin'
|
|
194
|
+
},
|
|
195
|
+
{
|
|
196
|
+
display: 'origin-when-cross-origin',
|
|
197
|
+
value: 'origin-when-cross-origin'
|
|
198
|
+
},
|
|
199
|
+
{
|
|
200
|
+
display: 'same-origin',
|
|
201
|
+
value: 'same-origin'
|
|
202
|
+
},
|
|
203
|
+
{
|
|
204
|
+
display: 'strict-origin',
|
|
205
|
+
value: 'strict-origin'
|
|
206
|
+
},
|
|
207
|
+
{
|
|
208
|
+
display: 'strict-origin-when-cross-origin',
|
|
209
|
+
value: 'strict-origin-when-cross-origin'
|
|
210
|
+
},
|
|
211
|
+
{
|
|
212
|
+
display: 'unsafe-url',
|
|
213
|
+
value: 'unsafe-url'
|
|
36
214
|
}
|
|
37
215
|
]
|
|
38
216
|
}
|
|
39
217
|
},
|
|
218
|
+
{
|
|
219
|
+
type: 'select',
|
|
220
|
+
label: 'value-usage',
|
|
221
|
+
name: 'valueUsage',
|
|
222
|
+
property: {
|
|
223
|
+
options: ['body', 'url']
|
|
224
|
+
}
|
|
225
|
+
},
|
|
226
|
+
{
|
|
227
|
+
type: 'number',
|
|
228
|
+
label: 'period',
|
|
229
|
+
name: 'period',
|
|
230
|
+
placeholder: 'SECONDS'
|
|
231
|
+
},
|
|
40
232
|
{
|
|
41
233
|
type: 'checkbox',
|
|
42
|
-
label: '
|
|
43
|
-
name: '
|
|
234
|
+
label: 'fetch-on-load',
|
|
235
|
+
name: 'fetchOnLoad'
|
|
44
236
|
}
|
|
45
237
|
],
|
|
46
|
-
'value-property': 'url',
|
|
47
238
|
help: 'scene/component/restful'
|
|
48
239
|
};
|
|
49
240
|
const REST_IMAGE = '';
|
|
@@ -68,12 +259,19 @@ export default class Restful extends DataSource(RectPath(Shape)) {
|
|
|
68
259
|
this._initRestful();
|
|
69
260
|
}
|
|
70
261
|
get period() {
|
|
71
|
-
return this.state.period * 1000;
|
|
262
|
+
return Number(this.state.period) * 1000;
|
|
72
263
|
}
|
|
73
264
|
set period(period) {
|
|
74
|
-
this.setState('period', period);
|
|
265
|
+
this.setState('period', Number(period));
|
|
75
266
|
this._initRestful();
|
|
76
267
|
}
|
|
268
|
+
get value() {
|
|
269
|
+
return this.state.value;
|
|
270
|
+
}
|
|
271
|
+
set value(value) {
|
|
272
|
+
this.setState('value', value);
|
|
273
|
+
this._initRestful(true);
|
|
274
|
+
}
|
|
77
275
|
get withCredentials() {
|
|
78
276
|
return !!this.getState('withCredentials');
|
|
79
277
|
}
|
|
@@ -88,16 +286,10 @@ export default class Restful extends DataSource(RectPath(Shape)) {
|
|
|
88
286
|
this._stopRepeater();
|
|
89
287
|
this._repeatTimer = repeatTimer;
|
|
90
288
|
}
|
|
91
|
-
get httpRequest() {
|
|
92
|
-
return this._httpRequest;
|
|
93
|
-
}
|
|
94
|
-
set httpRequest(httpRequest) {
|
|
95
|
-
this._httpRequest = httpRequest;
|
|
96
|
-
}
|
|
97
289
|
ready() {
|
|
98
|
-
this._initRestful();
|
|
290
|
+
this._initRestful(this.state.fetchOnLoad);
|
|
99
291
|
}
|
|
100
|
-
_initRestful() {
|
|
292
|
+
_initRestful(force = false) {
|
|
101
293
|
if (!this.app.isViewMode)
|
|
102
294
|
return;
|
|
103
295
|
if (!this.url) {
|
|
@@ -105,7 +297,12 @@ export default class Restful extends DataSource(RectPath(Shape)) {
|
|
|
105
297
|
return;
|
|
106
298
|
}
|
|
107
299
|
this._stopRepeater();
|
|
108
|
-
this.
|
|
300
|
+
if (this.period > 0) {
|
|
301
|
+
this._startRepeater();
|
|
302
|
+
}
|
|
303
|
+
else {
|
|
304
|
+
force && this.fetch();
|
|
305
|
+
}
|
|
109
306
|
}
|
|
110
307
|
dispose() {
|
|
111
308
|
super.dispose();
|
|
@@ -114,12 +311,11 @@ export default class Restful extends DataSource(RectPath(Shape)) {
|
|
|
114
311
|
_startRepeater() {
|
|
115
312
|
this._isStarted = true;
|
|
116
313
|
var self = this;
|
|
117
|
-
// requestAnimationFrame 이 호출되지 않을 때는 ajax 호출도 하지 않도록 함.
|
|
118
314
|
function _() {
|
|
119
315
|
if (!self._isStarted) {
|
|
120
316
|
return;
|
|
121
317
|
}
|
|
122
|
-
self.
|
|
318
|
+
self.fetch();
|
|
123
319
|
if (!self.period) {
|
|
124
320
|
self._stopRepeater();
|
|
125
321
|
return;
|
|
@@ -131,73 +327,57 @@ export default class Restful extends DataSource(RectPath(Shape)) {
|
|
|
131
327
|
requestAnimationFrame(_);
|
|
132
328
|
}
|
|
133
329
|
_stopRepeater() {
|
|
134
|
-
this._abortRequest();
|
|
135
|
-
if (this.repeatTimer)
|
|
136
|
-
clearTimeout(this._repeatTimer);
|
|
137
330
|
this._isStarted = false;
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
if (window.XMLHttpRequest) {
|
|
141
|
-
// Mozilla, Safari, ...
|
|
142
|
-
this.httpRequest = new XMLHttpRequest();
|
|
143
|
-
// @ts-ignore
|
|
331
|
+
if (this.repeatTimer) {
|
|
332
|
+
clearTimeout(this._repeatTimer);
|
|
144
333
|
}
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
334
|
+
}
|
|
335
|
+
async fetch() {
|
|
336
|
+
var { url, method = 'GET', mode = 'cors', cache = 'default', credentials = 'same-origin', redirect = 'follow', referrerPolicy = 'no-referrer-when-downgrade', contentType = 'application/json', dataFormat = 'json', value } = this.state;
|
|
337
|
+
if (dataFormat == 'jsonp') {
|
|
338
|
+
if (value && typeof value == 'string') {
|
|
339
|
+
url = value;
|
|
150
340
|
}
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
this.httpRequest = new ActiveXObject('Microsoft.XMLHTTP');
|
|
341
|
+
jsonp(url, {}, (self, data) => {
|
|
342
|
+
if (this._isStarted && data) {
|
|
343
|
+
this.data = data;
|
|
155
344
|
}
|
|
156
|
-
|
|
157
|
-
|
|
345
|
+
});
|
|
346
|
+
return;
|
|
158
347
|
}
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
348
|
+
var options = {
|
|
349
|
+
method,
|
|
350
|
+
mode,
|
|
351
|
+
cache,
|
|
352
|
+
credentials,
|
|
353
|
+
headers: {
|
|
354
|
+
'Content-Type': contentType
|
|
355
|
+
},
|
|
356
|
+
redirect,
|
|
357
|
+
referrerPolicy
|
|
358
|
+
};
|
|
359
|
+
if (method != 'GET' && method != 'HEAD') {
|
|
360
|
+
if (contentType == 'application/json') {
|
|
361
|
+
options.body = JSON.stringify(value);
|
|
362
|
+
}
|
|
363
|
+
else {
|
|
364
|
+
options.body = value;
|
|
365
|
+
}
|
|
162
366
|
}
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
return true;
|
|
167
|
-
}
|
|
168
|
-
_makeRequestJsonp(url) {
|
|
169
|
-
jsonp(url, {}, (self, data) => {
|
|
170
|
-
if (!data)
|
|
171
|
-
return;
|
|
172
|
-
this.data = data;
|
|
173
|
-
});
|
|
174
|
-
}
|
|
175
|
-
_abortRequest() {
|
|
176
|
-
if (this.httpRequest)
|
|
177
|
-
this.httpRequest.abort();
|
|
178
|
-
}
|
|
179
|
-
onDataReceived() {
|
|
180
|
-
var { dataFormat = 'text' } = this.state;
|
|
181
|
-
if (this.httpRequest.readyState === 4) {
|
|
182
|
-
if (this.httpRequest.status === 200) {
|
|
183
|
-
var data = this.httpRequest.responseText;
|
|
184
|
-
if (!data)
|
|
185
|
-
return;
|
|
186
|
-
this.data = this._convertDataFormat(data, dataFormat);
|
|
367
|
+
else {
|
|
368
|
+
if (value && typeof value == 'string') {
|
|
369
|
+
options.url = value;
|
|
187
370
|
}
|
|
188
371
|
}
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
if (dataFormat == 'jsonp') {
|
|
193
|
-
// @ts-ignore TODO add substitute property to things-scene.d.ts
|
|
194
|
-
this._makeRequestJsonp(this.substitute(this.url, this));
|
|
372
|
+
const response = await fetch(url, options);
|
|
373
|
+
if (!this._isStarted) {
|
|
374
|
+
return;
|
|
195
375
|
}
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
this.
|
|
376
|
+
if (dataFormat === 'json') {
|
|
377
|
+
this.data = response.json();
|
|
378
|
+
}
|
|
379
|
+
else if (dataFormat === 'text') {
|
|
380
|
+
this.data = response.text();
|
|
201
381
|
}
|
|
202
382
|
}
|
|
203
383
|
_draw(context) {
|
|
@@ -210,7 +390,7 @@ export default class Restful extends DataSource(RectPath(Shape)) {
|
|
|
210
390
|
warn(WARN_NO_URL);
|
|
211
391
|
return;
|
|
212
392
|
}
|
|
213
|
-
this.
|
|
393
|
+
this.fetch();
|
|
214
394
|
}
|
|
215
395
|
get controls() {
|
|
216
396
|
return [];
|
package/dist/restful.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"restful.js","sourceRoot":"","sources":["../src/restful.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentNature, DataSource, RectPath, Shape, warn } from '@hatiolab/things-scene'\n\nimport jsonp from './jsonp'\n\nconst NATURE: ComponentNature = {\n mutable: false,\n resizable: true,\n rotatable: true,\n properties: [\n {\n type: 'string',\n label: 'url',\n name: 'url'\n },\n {\n type: 'number',\n label: 'period',\n name: 'period',\n placeholder: 'SECONDS'\n },\n {\n type: 'select',\n label: 'data-format',\n name: 'dataFormat',\n property: {\n options: [\n {\n display: 'Plain Text',\n value: 'text'\n },\n {\n display: 'JSON',\n value: 'json'\n },\n {\n display: 'JSONP',\n value: 'jsonp'\n }\n ]\n }\n },\n {\n type: 'checkbox',\n label: 'with-credentials',\n name: 'withCredentials'\n }\n ],\n 'value-property': 'url',\n help: 'scene/component/restful'\n}\n\nconst REST_IMAGE =\n ''\n\nconst WARN_NO_URL = 'Valid URL property required'\n\nexport default class Restful extends DataSource(RectPath(Shape)) {\n static _image: HTMLImageElement\n\n static get image() {\n if (!Restful._image) {\n Restful._image = new Image()\n Restful._image.src = REST_IMAGE\n }\n\n return Restful._image\n }\n\n get url() {\n return this.getState('url')\n }\n\n set url(url) {\n this.setState('url', url)\n this._initRestful()\n }\n\n get period() {\n return this.state.period * 1000\n }\n\n set period(period) {\n this.setState('period', period)\n this._initRestful()\n }\n\n get withCredentials() {\n return !!this.getState('withCredentials')\n }\n\n set withCredentials(withCredentials) {\n this.setState('withCredentials', withCredentials)\n this._initRestful()\n }\n\n _repeatTimer!: NodeJS.Timeout\n _httpRequest?: any\n _isStarted = false\n\n get repeatTimer() {\n return this._repeatTimer\n }\n\n set repeatTimer(repeatTimer) {\n this._stopRepeater()\n this._repeatTimer = repeatTimer\n }\n\n get httpRequest() {\n return this._httpRequest\n }\n\n set httpRequest(httpRequest) {\n this._httpRequest = httpRequest\n }\n\n ready() {\n this._initRestful()\n }\n\n _initRestful() {\n if (!this.app.isViewMode) return\n\n if (!this.url) {\n warn(WARN_NO_URL)\n return\n }\n\n this._stopRepeater()\n this._startRepeater()\n }\n\n dispose() {\n super.dispose()\n this._stopRepeater()\n }\n\n _startRepeater() {\n this._isStarted = true\n\n var self = this\n\n // requestAnimationFrame 이 호출되지 않을 때는 ajax 호출도 하지 않도록 함.\n function _() {\n if (!self._isStarted) {\n return\n }\n self.callAjax()\n\n if (!self.period) {\n self._stopRepeater()\n return\n }\n\n self._repeatTimer = setTimeout(() => {\n requestAnimationFrame(_)\n }, self.period)\n }\n\n requestAnimationFrame(_)\n }\n\n _stopRepeater() {\n this._abortRequest()\n\n if (this.repeatTimer) clearTimeout(this._repeatTimer)\n this._isStarted = false\n }\n\n _makeRequest(url: string) {\n if (window.XMLHttpRequest) {\n // Mozilla, Safari, ...\n this.httpRequest = new XMLHttpRequest()\n // @ts-ignore\n } else if (window.ActiveXObject) {\n // IE\n try {\n // @ts-ignore\n this.httpRequest = new ActiveXObject('Msxml2.XMLHTTP')\n } catch (e) {\n try {\n // @ts-ignore\n this.httpRequest = new ActiveXObject('Microsoft.XMLHTTP')\n } catch (e) {}\n }\n }\n\n if (!this.httpRequest) {\n warn('Giving up :( Cannot create an XMLHTTP instance')\n return false\n }\n this.httpRequest.withCredentials = this.withCredentials\n this.httpRequest.open('GET', url)\n this.httpRequest.onreadystatechange = this.onDataReceived.bind(this)\n\n return true\n }\n\n _makeRequestJsonp(url: string) {\n jsonp(url, {}, (self, data) => {\n if (!data) return\n\n this.data = data\n })\n }\n\n _abortRequest() {\n if (this.httpRequest) this.httpRequest.abort()\n }\n\n onDataReceived() {\n var { dataFormat = 'text' } = this.state\n\n if (this.httpRequest.readyState === 4) {\n if (this.httpRequest.status === 200) {\n var data = this.httpRequest.responseText\n\n if (!data) return\n\n this.data = this._convertDataFormat(data, dataFormat)\n }\n }\n }\n\n callAjax() {\n var { dataFormat = 'text' } = this.state\n\n if (dataFormat == 'jsonp') {\n // @ts-ignore TODO add substitute property to things-scene.d.ts\n this._makeRequestJsonp(this.substitute(this.url, this))\n } else {\n // @ts-ignore TODO add substitute property to things-scene.d.ts\n if (!this._makeRequest(this.substitute(this.url, this))) return\n\n this.httpRequest.send()\n }\n }\n\n _draw(context: CanvasRenderingContext2D) {\n var { left, top, width, height } = this.bounds\n\n context.beginPath()\n this.drawImage(context, Restful.image, left, top, width, height)\n }\n\n ondblclick(e: Event) {\n if (!this.url) {\n warn(WARN_NO_URL)\n return\n }\n\n this.callAjax()\n }\n\n get controls() {\n return []\n }\n\n get nature() {\n return NATURE\n }\n}\n\nComponent.register('restful', Restful)\n"]}
|
|
1
|
+
{"version":3,"file":"restful.js","sourceRoot":"","sources":["../src/restful.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentNature, DataSource, RectPath, Shape, warn } from '@hatiolab/things-scene'\n\nimport jsonp from './jsonp'\n\nconst NATURE: ComponentNature = {\n mutable: false,\n resizable: true,\n rotatable: true,\n properties: [\n {\n type: 'select',\n label: 'method',\n name: 'method',\n property: {\n options: [\n {\n display: 'GET',\n value: 'GET'\n },\n {\n display: 'POST',\n value: 'POST'\n },\n {\n display: 'PUT',\n value: 'PUT'\n },\n {\n display: 'DELETE',\n value: 'DELETE'\n }\n ]\n }\n },\n {\n type: 'string',\n label: 'url',\n name: 'url'\n },\n {\n type: 'string',\n label: 'authorization',\n name: 'authorization'\n },\n {\n type: 'select',\n label: 'data-format',\n name: 'dataFormat',\n property: {\n options: [\n {\n display: 'json',\n value: 'json'\n },\n {\n display: 'jsonp',\n value: 'jsonp'\n },\n {\n display: 'text',\n value: 'text'\n }\n ]\n }\n },\n {\n type: 'select',\n label: 'content-type',\n name: 'contentType',\n property: {\n options: [\n {\n display: 'application/json',\n value: 'application/json'\n },\n {\n display: 'application/x-www-form-urlencoded',\n value: 'application/x-www-form-urlencoded'\n },\n {\n display: 'text/plain',\n value: 'text/plain'\n }\n ]\n }\n },\n {\n type: 'select',\n label: 'mode',\n name: 'mode',\n property: {\n options: [\n {\n display: 'cors',\n value: 'cors'\n },\n {\n display: 'no-cors',\n value: 'no-cors'\n },\n {\n display: 'same-origin',\n value: 'same-origin'\n }\n ]\n }\n },\n {\n type: 'select',\n label: 'credentials',\n name: 'credentials',\n property: {\n options: [\n {\n display: 'same-origin',\n value: 'same-origin'\n },\n {\n display: 'include',\n value: 'include'\n },\n {\n display: 'omit',\n value: 'omit'\n }\n ]\n }\n },\n {\n type: 'select',\n label: 'cache',\n name: 'cache',\n property: {\n options: [\n {\n display: 'default',\n value: 'default'\n },\n {\n display: 'no-cache',\n value: 'no-cache'\n },\n {\n display: 'reload',\n value: 'reload'\n },\n {\n display: 'force-cache',\n value: 'force-cache'\n },\n {\n display: 'only-if-cached',\n value: 'only-if-cached'\n }\n ]\n }\n },\n {\n type: 'select',\n label: 'redirect',\n name: 'redirect',\n property: {\n options: [\n {\n display: 'follow',\n value: 'follow'\n },\n {\n display: 'manual',\n value: 'manual'\n },\n {\n display: 'error',\n value: 'error'\n }\n ]\n }\n },\n {\n type: 'select',\n label: 'referrer-policy',\n name: 'referrerPolicy',\n property: {\n options: [\n {\n display: 'no-referrer-when-downgrade',\n value: 'no-referrer-when-downgrade'\n },\n {\n display: 'no-referrer',\n value: 'no-referrer'\n },\n {\n display: 'origin',\n value: 'origin'\n },\n {\n display: 'origin-when-cross-origin',\n value: 'origin-when-cross-origin'\n },\n {\n display: 'same-origin',\n value: 'same-origin'\n },\n {\n display: 'strict-origin',\n value: 'strict-origin'\n },\n {\n display: 'strict-origin-when-cross-origin',\n value: 'strict-origin-when-cross-origin'\n },\n {\n display: 'unsafe-url',\n value: 'unsafe-url'\n }\n ]\n }\n },\n {\n type: 'select',\n label: 'value-usage',\n name: 'valueUsage',\n property: {\n options: ['body', 'url']\n }\n },\n {\n type: 'number',\n label: 'period',\n name: 'period',\n placeholder: 'SECONDS'\n },\n {\n type: 'checkbox',\n label: 'fetch-on-load',\n name: 'fetchOnLoad'\n }\n ],\n help: 'scene/component/restful'\n}\n\nconst REST_IMAGE =\n ''\n\nconst WARN_NO_URL = 'Valid URL property required'\n\nexport default class Restful extends DataSource(RectPath(Shape)) {\n static _image: HTMLImageElement\n\n static get image() {\n if (!Restful._image) {\n Restful._image = new Image()\n Restful._image.src = REST_IMAGE\n }\n\n return Restful._image\n }\n\n private _repeatTimer!: NodeJS.Timeout\n private _isStarted = false\n\n get url() {\n return this.getState('url')\n }\n\n set url(url) {\n this.setState('url', url)\n this._initRestful()\n }\n\n get period() {\n return Number(this.state.period) * 1000\n }\n\n set period(period) {\n this.setState('period', Number(period))\n this._initRestful()\n }\n\n get value() {\n return this.state.value\n }\n\n set value(value) {\n this.setState('value', value)\n this._initRestful(true)\n }\n\n get withCredentials() {\n return !!this.getState('withCredentials')\n }\n\n set withCredentials(withCredentials) {\n this.setState('withCredentials', withCredentials)\n this._initRestful()\n }\n\n get repeatTimer() {\n return this._repeatTimer\n }\n\n set repeatTimer(repeatTimer) {\n this._stopRepeater()\n this._repeatTimer = repeatTimer\n }\n\n ready() {\n this._initRestful(this.state.fetchOnLoad)\n }\n\n _initRestful(force: boolean = false) {\n if (!this.app.isViewMode) return\n\n if (!this.url) {\n warn(WARN_NO_URL)\n return\n }\n\n this._stopRepeater()\n if (this.period > 0) {\n this._startRepeater()\n } else {\n force && this.fetch()\n }\n }\n\n dispose() {\n super.dispose()\n this._stopRepeater()\n }\n\n _startRepeater() {\n this._isStarted = true\n\n var self = this\n\n function _() {\n if (!self._isStarted) {\n return\n }\n self.fetch()\n\n if (!self.period) {\n self._stopRepeater()\n return\n }\n\n self._repeatTimer = setTimeout(() => {\n requestAnimationFrame(_)\n }, self.period)\n }\n\n requestAnimationFrame(_)\n }\n\n _stopRepeater() {\n this._isStarted = false\n if (this.repeatTimer) {\n clearTimeout(this._repeatTimer)\n }\n }\n\n async fetch() {\n var {\n url,\n method = 'GET',\n mode = 'cors',\n cache = 'default',\n credentials = 'same-origin',\n redirect = 'follow',\n referrerPolicy = 'no-referrer-when-downgrade',\n contentType = 'application/json',\n dataFormat = 'json',\n value\n } = this.state\n\n if (dataFormat == 'jsonp') {\n if (value && typeof value == 'string') {\n url = value\n }\n\n jsonp(url, {}, (self, data) => {\n if (this._isStarted && data) {\n this.data = data\n }\n })\n\n return\n }\n\n var options: any = {\n method,\n mode,\n cache,\n credentials,\n headers: {\n 'Content-Type': contentType\n },\n redirect,\n referrerPolicy\n }\n\n if (method != 'GET' && method != 'HEAD') {\n if (contentType == 'application/json') {\n options.body = JSON.stringify(value)\n } else {\n options.body = value\n }\n } else {\n if (value && typeof value == 'string') {\n options.url = value\n }\n }\n\n const response = await fetch(url, options)\n\n if (!this._isStarted) {\n return\n }\n\n if (dataFormat === 'json') {\n this.data = response.json()\n } else if (dataFormat === 'text') {\n this.data = response.text()\n }\n }\n\n _draw(context: CanvasRenderingContext2D) {\n var { left, top, width, height } = this.bounds\n\n context.beginPath()\n this.drawImage(context, Restful.image, left, top, width, height)\n }\n\n ondblclick(e: Event) {\n if (!this.url) {\n warn(WARN_NO_URL)\n return\n }\n\n this.fetch()\n }\n\n get controls() {\n return []\n }\n\n get nature() {\n return NATURE\n }\n}\n\nComponent.register('restful', Restful)\n"]}
|
|
@@ -1,12 +1,14 @@
|
|
|
1
1
|
# restful
|
|
2
|
-
URL를 제공 받고 URL로만 데이터를 조회할 경우 사용하는 컴포넌트.
|
|
3
2
|
|
|
4
|
-
|
|
3
|
+
브라우저의 Fetch API를 활용해서, HTTP request 기능을 제공하는 컴포넌트이다.
|
|
5
4
|
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
5
|
+
호출 기능과 각 속성값은 아래 링크된 문서에서 참조할 수 있다.
|
|
6
|
+
|
|
7
|
+
https://developer.mozilla.org/ko/docs/Web/API/Fetch_API/Using_Fetch
|
|
8
|
+
|
|
9
|
+
예외) dataFormat이 jsonp(JSON with Padding)인 경우에는, Fetch API를 사용하지 않는다. 이 경우에는 URL 파라미터만 의미를 갖는다.
|
|
10
|
+
|
|
11
|
+
## value property
|
|
12
|
+
|
|
13
|
+
이 컴포넌트의 value 속성은 HTTP request 과정에서 body나 URL로 사용된다.
|
|
14
|
+
GET 메쏘드에서는 URL로 활용되며, 그 밖의 메쏘드에서는 body에 사용된다.
|
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
# restful
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
2
|
+
|
|
3
|
+
"restful" is a component that provides HTTP request function by utilizing the browser's Fetch API.
|
|
4
|
+
|
|
5
|
+
You can refer to the calling function and each property value in the document linked below.
|
|
6
|
+
|
|
7
|
+
https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch
|
|
8
|
+
|
|
9
|
+
Exception case) When dataFormat is jsonp (JSON with Padding), Fetch API is not used. In this case, only the URL parameters have meaning.
|
|
10
|
+
|
|
11
|
+
## value property
|
|
12
|
+
|
|
13
|
+
The value property of this component is used as the body or URL in the HTTP request process.
|
|
14
|
+
In the GET method, it is used as a URL, and in other methods, it is used as the body.
|