@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 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
- _makeRequest(url: string): boolean;
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: 'number',
15
- label: 'period',
16
- name: 'period',
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: 'Plain Text',
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: 'JSON',
31
- value: 'json'
75
+ display: 'application/x-www-form-urlencoded',
76
+ value: 'application/x-www-form-urlencoded'
32
77
  },
33
78
  {
34
- display: 'JSONP',
35
- value: 'jsonp'
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: 'with-credentials',
43
- name: 'withCredentials'
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._startRepeater();
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.callAjax();
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
- _makeRequest(url) {
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
- else if (window.ActiveXObject) {
146
- // IE
147
- try {
148
- // @ts-ignore
149
- this.httpRequest = new ActiveXObject('Msxml2.XMLHTTP');
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
- catch (e) {
152
- try {
153
- // @ts-ignore
154
- this.httpRequest = new ActiveXObject('Microsoft.XMLHTTP');
341
+ jsonp(url, {}, (self, data) => {
342
+ if (this._isStarted && data) {
343
+ this.data = data;
155
344
  }
156
- catch (e) { }
157
- }
345
+ });
346
+ return;
158
347
  }
159
- if (!this.httpRequest) {
160
- warn('Giving up :( Cannot create an XMLHTTP instance');
161
- return false;
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
- this.httpRequest.withCredentials = this.withCredentials;
164
- this.httpRequest.open('GET', url);
165
- this.httpRequest.onreadystatechange = this.onDataReceived.bind(this);
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
- callAjax() {
191
- var { dataFormat = 'text' } = this.state;
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
- else {
197
- // @ts-ignore TODO add substitute property to things-scene.d.ts
198
- if (!this._makeRequest(this.substitute(this.url, this)))
199
- return;
200
- this.httpRequest.send();
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.callAjax();
393
+ this.fetch();
214
394
  }
215
395
  get controls() {
216
396
  return [];
@@ -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
- ## properties
3
+ 브라우저의 Fetch API를 활용해서, HTTP request 기능을 제공하는 컴포넌트이다.
5
4
 
6
- - url : 데이터 조회 URL
7
- - period : 데이터 조회 주기
8
- - data format : Plain Text, JSON, JSONP등 데이터 포멧
9
- - Plain Text : 서버에서 데이터를 Plain Text로 반환할 경우 사용
10
- - JSON : 서버에서 데이터를 JSON으로 제공할 경우
11
- - JSONP : 데이터를 function형태로 전달 받을 경우 해당 function을 받아서 처리해 주는 기능
12
- - with credentials : Cross site request 설정
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
- A component used when a URL is provided and data is retrieved only with a URL.
3
-
4
- ## properties
5
- - url : Data inquiry URL
6
- - period : Data inquiry cycle
7
- - data format : Plain Text, JSON, JSONP Data format
8
- - Plain Text : Used when the server returns data in Plain Text.
9
- - JSON : When the server provides data as JSON
10
- - JSONP : When data is received in the form of a function, the function is received and processed.
11
- - with credentials : Cross site request
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.