@things-factory/scene-restful 5.0.0-alpha.44 → 5.0.0-alpha.54

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@things-factory/scene-restful",
3
- "version": "5.0.0-alpha.44",
3
+ "version": "5.0.0-alpha.54",
4
4
  "description": "Restful Client Component for Things Scene",
5
5
  "things-scene": true,
6
6
  "browser": "src/index.js",
@@ -16,7 +16,7 @@
16
16
  "directory": "packages/scene-restful"
17
17
  },
18
18
  "dependencies": {
19
- "@hatiolab/things-scene": "^3.0.6"
19
+ "@hatiolab/things-scene": "^2.8.2"
20
20
  },
21
- "gitHead": "4903eb69beb8e556ceb7438cae9f2cf68945f002"
21
+ "gitHead": "0274aad474b254a6215fdf54d4f553c5b45becd8"
22
22
  }
package/README.md DELETED
@@ -1,13 +0,0 @@
1
- ## build
2
-
3
- `$ yarn build`
4
-
5
- | type | filename | for | tested |
6
- | ---- | -------------------------- | -------------- | ------ |
7
- | UMD | things-scene-restful.js | modern browser | O |
8
- | UMD | things-scene-restful-ie.js | ie 11 | O |
9
- | ESM | things-scene-restful.mjs | modern browser | O |
10
-
11
- ## publish
12
-
13
- `$ yarn publish`
Binary file
@@ -1,12 +0,0 @@
1
- {
2
- "SAMPLE": {
3
- "name": "SAMPLE",
4
- "description": "",
5
- "width": 1920,
6
- "height": 1080,
7
- "updatedAt": 1524117648813,
8
- "createdAt": 1524110268095,
9
- "group": "DEFAULT-GROUP",
10
- "thumbnail": ""
11
- }
12
- }
@@ -1,7 +0,0 @@
1
- {
2
- "DEFAULT-GROUP": {
3
- "name": "DEFAULT-GROUP",
4
- "description": "",
5
- "type": "group"
6
- }
7
- }
@@ -1,70 +0,0 @@
1
- {
2
- "width": 1920,
3
- "height": 1080,
4
- "type": "model-layer",
5
- "translate": {
6
- "x": 0,
7
- "y": 264.53125
8
- },
9
- "scale": {
10
- "x": 0.37864583333333335,
11
- "y": 0.37864583333333335
12
- },
13
- "event": {
14
- "hover": {},
15
- "tap": {
16
- "value": ""
17
- }
18
- },
19
- "components": [
20
- {
21
- "type": "restful",
22
- "xx": 0,
23
- "left": 615.5295735900962,
24
- "top": 281.36176066024746,
25
- "width": 100,
26
- "height": 100,
27
- "hidden": false,
28
- "dataFormat": "json",
29
- "rotation": 0,
30
- "url": "http://services.groupkt.com/country/get/iso2code/IN",
31
- "withCredentials": true,
32
- "period": 10,
33
- "id": "rest"
34
- },
35
- {
36
- "type": "rect",
37
- "xx": 0,
38
- "left": 1183.1636863823933,
39
- "top": 270.79779917469045,
40
- "width": 538.5832187070155,
41
- "height": 100,
42
- "fillStyle": "#fff",
43
- "strokeStyle": "#000",
44
- "alpha": 1,
45
- "hidden": false,
46
- "lineWidth": 1,
47
- "lineDash": "solid",
48
- "lineCap": "butt",
49
- "rotation": 0,
50
- "text": "URL",
51
- "fontSize": 36,
52
- "data": "https://httpbin.org/get",
53
- "mappings": [
54
- {
55
- "rule": "value",
56
- "target": "#rest",
57
- "property": "value"
58
- }
59
- ],
60
- "id": "url",
61
- "event": {
62
- "hover": {},
63
- "tap": {
64
- "target": "$url",
65
- "value": "https://httpbin.org/get"
66
- }
67
- }
68
- }
69
- ]
70
- }
package/demo/index.html DELETED
@@ -1,116 +0,0 @@
1
- <!--
2
- @license
3
- Copyright © HatioLab Inc. All rights reserved.
4
- -->
5
- <!doctype html>
6
- <html>
7
- <head>
8
- <meta charset="utf-8">
9
- <meta name="viewport" content="width=device-width, minimum-scale=1.0, initial-scale=1.0, user-scalable=yes">
10
- <title>restful Demo</title>
11
- <script src="../../webcomponentsjs/webcomponents-lite.min.js"></script>
12
-
13
- <link rel="import" href="../../things-scene-viewer/things-scene-viewer.html">
14
- <link rel="import" href="../../things-scene-viewer/things-scene-layer.html">
15
- <link rel="import" href="../../things-scene-viewer/things-scene-handler.html">
16
-
17
- <link rel="import" href="../../things-designer-elements/things-editor-properties.html">
18
-
19
- <link rel="import" href="./things-scene-restful.html">
20
-
21
- <link rel="import" href="./things-theme.html">
22
-
23
- <style is="custom-style" include="things-theme">
24
- things-scene-viewer {
25
- display: block;
26
- width: 640px;
27
- height: 480px;
28
- }
29
- </style>
30
- </head>
31
- <body unresolved>
32
-
33
- <template is="dom-bind" id="app">
34
- <p>An example of <code>&lt;restful&gt;</code>:</p>
35
-
36
- <things-scene-viewer id='scene'
37
- scene='{{scene}}'
38
- selected='{{selected}}'
39
- model='[[model]]'
40
- mode="0">
41
- <things-scene-layer type="selection-layer"></things-scene-layer>
42
- <things-scene-layer type="modeling-layer"></things-scene-layer>
43
- <things-scene-handler type="text-editor"></things-scene-handler>
44
- <things-scene-handler type="move-handler"></things-scene-handler>
45
- </things-scene-viewer>
46
-
47
- <p>Properties</p>
48
- <things-editor-properties id='props' target="{{props}}" props="[[selected.0.nature.properties]]">
49
- </things-editor-properties>
50
-
51
- </template>
52
-
53
- <script>
54
- window.addEventListener('WebComponentsReady', function(e) {
55
- var app = document.querySelector('#app')
56
-
57
- app.props = {}
58
-
59
- setTimeout(function() {
60
- app.scene.on('selected', function(after) {
61
- var target = after[0]
62
- var props = {}
63
- if(target) {
64
- target.nature.properties.forEach(function(prop) {
65
- var property = prop.property
66
- props[property] = target.model[property]
67
- })
68
- }
69
- app.props = props
70
- });
71
- });
72
-
73
- app.$.props.addEventListener('change', function() {
74
- app.selected[0].set(app.props)
75
- });
76
-
77
- app.model = {
78
- width: 640,
79
- height: 480,
80
- components: [{
81
- type: 'restful',
82
- top: 100,
83
- left: 100,
84
- width:200,
85
- height: 70,
86
- fontSize: 40,
87
- fillStyle: '#00ff00',
88
- fontColor: '#FF0000',
89
- strokeStyle: '#000',
90
- lineWidth: 5,
91
- value: 40,
92
- text: '#{value}',
93
- lineCap: 'round',
94
- url: 'http://factory.hatiolab.com/rest/publishers/initData?subject=/elidom/stomp/topic/hatiolab-hq/smart/SCENE-22',
95
- period: 60
96
- }, {
97
- type: 'rect',
98
- id: 'ss3Text',
99
- top: 100,
100
- left: 100,
101
- width:200,
102
- height: 70,
103
- fontSize: 40,
104
- fillStyle: '#00ff00',
105
- fontColor: '#FF0000',
106
- strokeStyle: '#000',
107
- lineWidth: 5,
108
- value: 40,
109
- text: '#{data}',
110
- lineCap: 'round'
111
- }]
112
- }
113
- });
114
- </script>
115
- </body>
116
- </html>
@@ -1,5 +0,0 @@
1
- <!--
2
- @license
3
- Copyright © HatioLab Inc. All rights reserved.
4
- -->
5
- <script src="../things-scene-restful.js"></script>
@@ -1,178 +0,0 @@
1
- <!--
2
- @license
3
- Copyright © HatioLab Inc. All rights reserved.
4
- -->
5
- <dom-module id="things-theme">
6
- <template>
7
- <style>
8
- :root {
9
- /* element reset style */
10
- --paper-badge-background: rgba(0, 0, 0, 0.2);
11
- --paper-badge-margin-left: -25px;
12
- --paper-fab-background: var(--things-secondary-color);
13
- --paper-fab-background: tomato;
14
- --paper-input-container-focus-color: var(--things-secondary-color);
15
- --paper-toolbar-background: transparent;
16
-
17
- /* common style */
18
- --border-radius-clear: {
19
- -webkit-border-radius: 0px;
20
- -moz-border-radius: 0px;
21
- border-radius: 0px;
22
- }
23
- --things-default-padding: {
24
- padding: 15px;
25
- }
26
- --things-tight-padding: {
27
- padding: 7px;
28
- }
29
- --things-loose-padding: {
30
- padding: 30px;
31
- }
32
- --things-table-padding: {
33
- padding: 15px 15px 0 15px;
34
- }
35
- --things-padding-clear: {
36
- padding: 0;
37
- }
38
- --things-default-margin: {
39
- margin: 15px;
40
- }
41
- --things-margin-clear: {
42
- margin: 0;
43
- }
44
-
45
- /* color style */
46
- --things-primary-color: #826960;
47
- --things-secondary-color: #aa866a;
48
- --things-focus-background-color: #867f7c;
49
- --things-primary-background-color: #826960;
50
- --things-secondary-background-color: #aa866a;
51
- --things-lightgrey-background-color: rgba(0, 0, 0, 0.15);
52
- --things-white-color: #fff;
53
- --things-error-color: var(--paper-deep-orange-700);
54
- --things-primary-text-color: #726765;
55
- --things-green-text-color: var(--paper-green-600);
56
- --things-dark-text-color: #585858;
57
-
58
- /* properties panel style */
59
- --things-properties-panel: {
60
- display: block;
61
- width: 270px;
62
- min-width: 270px;
63
- background-color: var(--paper-blue-grey-50);
64
- }
65
-
66
- /* form style */
67
- --things-label: {
68
- position: relative;
69
- top: -3px;
70
- width: 25%;
71
- min-height: 20px;
72
- display: inline-block;
73
- margin-bottom: 10px;
74
- color: var(--things-primary-text-color);
75
- font-size: 12px;
76
- text-align: right;
77
- font-weight: 100;
78
- line-height: 1.6;
79
- }
80
- --things-input: {
81
- width: 65%;
82
- margin-bottom: 10px;
83
- padding: 3px 5px 2px 5px;
84
- -webkit-border-radius: 4px;
85
- -moz-border-radius: 4px;
86
- border-radius: 4px;
87
- border: 1px solid rgba(0, 0, 0, 0.15);
88
- font-size: 15px;
89
- font-weight: 300;
90
- }
91
- --things-input-readonly-important: {
92
- background-color: transparent;
93
- padding: 0 0 0 3px;
94
- position: relative;
95
- top: -2px;
96
- border-color: transparent;
97
- font-weight: 600;
98
- color: var(--things-primary-text-color);
99
- }
100
- --things-textarea-label-width: 12.25%;
101
- --things-textarea-width: 94.5%;
102
- --things-textarea: {
103
- -webkit-border-radius: 4px;
104
- -moz-border-radius: 4px;
105
- border-radius: 4px;
106
- border: 1px solid rgba(0, 0, 0, 0.2);
107
- color: var(--things-primary-text-color);
108
- font-size: 13px;
109
- width: 100%;
110
- height: 84%;
111
- padding: 1%;
112
- }
113
- --things-fieldset: {
114
- border: none;
115
- margin: 0;
116
- padding: 9px 0 0 0;
117
- border-bottom: 1px solid #cfd8dc;
118
- color: var(--things-primary-text-color);
119
- font-size: 12px;
120
- }
121
- --things-fieldset-legend: {
122
- padding: 9px 0 0 7px;
123
- font-size: 11px;
124
- color: #e46c2e;
125
- font-weight: bold;
126
- text-transform: capitalize;
127
- }
128
- --things-select: {
129
- max-width: 69%;
130
- min-width: 50%;
131
- margin-bottom: 10px;
132
- padding: 3px 20px 2px 5px;
133
- -webkit-border-radius: 4px;
134
- -moz-border-radius: 4px;
135
- border-radius: 4px;
136
- border: 1px solid rgba(0, 0, 0, 0.15);
137
- font-size: 15px;
138
- font-weight: 300;
139
- -webkit-appearance: none;
140
- }
141
- --things-input-color: {
142
- position: relative;
143
- margin-left: -30px;
144
- width: 25px;
145
- height: 21px;
146
- border: none;
147
- padding: 0;
148
- }
149
- --things-properties-icon-only-label: {
150
- width: 30px;
151
- height: 24px;
152
- margin-top: 2px;
153
- margin-bottom: 5px;
154
- }
155
- --things-editor-colorbar: {
156
- border: 1px solid #ccc;
157
- }
158
- --things-editor-color-input-text: {
159
- @apply (--things-input);
160
- }
161
- --things-editor-color-input-color: {
162
- border: none;
163
- background-color: transparent;
164
- margin-left: -27px;
165
- position: relative;
166
- width: 20px;
167
- }
168
- --things-dropdown-item: {
169
- min-height: 30px;
170
- border-bottom: 1px solid rgba(0, 0, 0, 0.1);
171
- padding: 0 10px;
172
- font-size: 13px;
173
- color: var(--things-primary-text-color);
174
- }
175
- }
176
- </style>
177
- </template>
178
- </dom-module>
@@ -1,12 +0,0 @@
1
- # restful
2
- URL를 제공 받고 URL로만 데이터를 조회할 경우 사용하는 컴포넌트.
3
-
4
- ## properties
5
-
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 설정
@@ -1,11 +0,0 @@
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
@@ -1,13 +0,0 @@
1
- # restful
2
- 提供URL且仅通过URL检索数据时使用的组件。
3
-
4
- ## properties
5
-
6
- - 访问地址 : 数据查询网址
7
- - 周期 : 数据查询周期
8
- - 数据格式 : Plain Text,JSON,JSONP数据格式
9
- - Plain Text : 服务器以纯文本格式返回数据时使用。
10
- - JSON : 当服务器以JSON形式提供数据时
11
- - JSONP : 当以函数形式接收数据时,将接收并处理该函数。
12
-
13
- - 允许跨网 : 是否允许跨网
package/src/index.js DELETED
@@ -1,5 +0,0 @@
1
- /*
2
- * Copyright © HatioLab Inc. All rights reserved.
3
- */
4
-
5
- export { default as Restful } from './restful'
package/src/jsonp.js DELETED
@@ -1,79 +0,0 @@
1
- import { debug } from '@hatiolab/things-scene'
2
-
3
- var count = 0;
4
-
5
- function noop(){}
6
-
7
- /**
8
- * JSONP handler
9
- *
10
- * Options:
11
- * - param {String} qs parameter (`callback`)
12
- * - prefix {String} qs parameter (`__jp`)
13
- * - name {String} qs parameter (`prefix` + incr)
14
- * - timeout {Number} how long after a timeout error is emitted (`60000`)
15
- *
16
- * @param {String} url
17
- * @param {Object|Function} optional options / callback
18
- * @param {Function} optional callback
19
- */
20
-
21
- export default function jsonp(url, opts, fn){
22
- if ('function' == typeof opts) {
23
- fn = opts;
24
- opts = {};
25
- }
26
- if (!opts) opts = {};
27
-
28
- var prefix = opts.prefix || '__jp';
29
-
30
- // use the callback name that was passed if one was provided.
31
- // otherwise generate a unique name by incrementing our counter.
32
- var id = opts.name || (prefix + (count++));
33
-
34
- var param = opts.param || 'callback';
35
- var timeout = null != opts.timeout ? opts.timeout : 60000;
36
- var enc = encodeURIComponent;
37
- var target = document.getElementsByTagName('script')[0] || document.head;
38
- var script;
39
- var timer;
40
-
41
-
42
- if (timeout) {
43
- timer = setTimeout(function(){
44
- cleanup();
45
- if (fn) fn(new Error('Timeout'));
46
- }, timeout);
47
- }
48
-
49
- function cleanup(){
50
- if (script.parentNode) script.parentNode.removeChild(script);
51
- window[id] = noop;
52
- if (timer) clearTimeout(timer);
53
- }
54
-
55
- function cancel(){
56
- if (window[id]) {
57
- cleanup();
58
- }
59
- }
60
-
61
- window[id] = function(data){
62
- debug('jsonp got', data);
63
- cleanup();
64
- if (fn) fn(null, data);
65
- };
66
-
67
- // add qs component
68
- url += (~url.indexOf('?') ? '&' : '?') + param + '=' + enc(id);
69
- url = url.replace('?&', '?');
70
-
71
- debug('jsonp req "%s"', url);
72
-
73
- // create script
74
- script = document.createElement('script');
75
- script.src = url;
76
- target.parentNode.insertBefore(script, target);
77
-
78
- return cancel;
79
- }
package/src/restful.js DELETED
@@ -1,254 +0,0 @@
1
- /*
2
- * Copyright © HatioLab Inc. All rights reserved.
3
- */
4
-
5
- const NATURE = {
6
- mutable: false,
7
- resizable: true,
8
- rotatable: true,
9
- properties: [
10
- {
11
- type: 'string',
12
- label: 'url',
13
- name: 'url'
14
- },
15
- {
16
- type: 'number',
17
- label: 'period',
18
- name: 'period',
19
- placeholder: 'SECONDS'
20
- },
21
- {
22
- type: 'select',
23
- label: 'data-format',
24
- name: 'dataFormat',
25
- property: {
26
- options: [
27
- {
28
- display: 'Plain Text',
29
- value: 'text'
30
- },
31
- {
32
- display: 'JSON',
33
- value: 'json'
34
- },
35
- {
36
- display: 'JSONP',
37
- value: 'jsonp'
38
- }
39
- ]
40
- }
41
- },
42
- {
43
- type: 'checkbox',
44
- label: 'with-credentials',
45
- name: 'withCredentials'
46
- }
47
- ],
48
- 'value-property': 'url',
49
- help: 'scene/component/restful'
50
- }
51
-
52
- const REST_IMAGE =
53
- ''
54
-
55
- const WARN_NO_URL = 'Valid URL property required'
56
-
57
- import { Component, DataSource, RectPath, Shape, warn } from '@hatiolab/things-scene'
58
- import jsonp from './jsonp'
59
-
60
- export default class Restful extends DataSource(RectPath(Shape)) {
61
- static get image() {
62
- if (!Restful._image) {
63
- Restful._image = new Image()
64
- Restful._image.src = REST_IMAGE
65
- }
66
-
67
- return Restful._image
68
- }
69
-
70
- get url() {
71
- return this.getState('url')
72
- }
73
-
74
- set url(url) {
75
- this.setState('url', url)
76
- this._initRestful()
77
- }
78
-
79
- get period() {
80
- return this.state.period * 1000
81
- }
82
-
83
- set period(period) {
84
- this.setState('period', period)
85
- this._initRestful()
86
- }
87
-
88
- get withCredentials() {
89
- return !!this.getState('withCredentials')
90
- }
91
-
92
- set withCredentials(withCredentials) {
93
- this.setState('withCredentials', withCredentials)
94
- this._initRestful()
95
- }
96
-
97
- get repeatTimer() {
98
- return this._repeatTimer
99
- }
100
-
101
- set repeatTimer(repeatTimer) {
102
- this._stopRepeater()
103
- this._repeatTimer = repeatTimer
104
- }
105
-
106
- get httpRequest() {
107
- return this._httpRequest
108
- }
109
-
110
- set httpRequest(httpRequest) {
111
- this._httpRequest = httpRequest
112
- }
113
-
114
- ready() {
115
- this._initRestful()
116
- }
117
-
118
- _initRestful() {
119
- if (!this.app.isViewMode) return
120
-
121
- if (!this.url) {
122
- warn(WARN_NO_URL)
123
- return
124
- }
125
-
126
- this._stopRepeater()
127
- this._startRepeater()
128
- }
129
-
130
- dispose() {
131
- super.dispose()
132
- this._stopRepeater()
133
- }
134
-
135
- _startRepeater() {
136
- this._isStarted = true
137
-
138
- var self = this
139
-
140
- // requestAnimationFrame 이 호출되지 않을 때는 ajax 호출도 하지 않도록 함.
141
- function _() {
142
- if (!self._isStarted) {
143
- return
144
- }
145
- self.callAjax()
146
-
147
- if (!self.period) {
148
- self._stopRepeater()
149
- return
150
- }
151
-
152
- self._repeatTimer = setTimeout(() => {
153
- requestAnimationFrame(_)
154
- }, self.period)
155
- }
156
-
157
- requestAnimationFrame(_)
158
- }
159
-
160
- _stopRepeater() {
161
- this._abortRequest()
162
-
163
- if (this.repeatTimer) clearTimeout(this._repeatTimer)
164
- this._isStarted = false
165
- }
166
-
167
- _makeRequest(url) {
168
- if (window.XMLHttpRequest) {
169
- // Mozilla, Safari, ...
170
- this.httpRequest = new XMLHttpRequest()
171
- } else if (window.ActiveXObject) {
172
- // IE
173
- try {
174
- this.httpRequest = new ActiveXObject('Msxml2.XMLHTTP')
175
- } catch (e) {
176
- try {
177
- this.httpRequest = new ActiveXObject('Microsoft.XMLHTTP')
178
- } catch (e) {}
179
- }
180
- }
181
-
182
- if (!this.httpRequest) {
183
- warn('Giving up :( Cannot create an XMLHTTP instance')
184
- return false
185
- }
186
- this.httpRequest.withCredentials = this.withCredentials
187
- this.httpRequest.open('GET', url)
188
- this.httpRequest.onreadystatechange = this.onDataReceived.bind(this)
189
-
190
- return true
191
- }
192
-
193
- _makeRequestJsonp(url) {
194
- jsonp(url, {}, (self, data) => {
195
- if (!data) return
196
-
197
- this.data = data
198
- })
199
- }
200
-
201
- _abortRequest() {
202
- if (this.httpRequest) this.httpRequest.abort()
203
- }
204
-
205
- onDataReceived() {
206
- var { dataFormat = 'text' } = this.state
207
-
208
- if (this.httpRequest.readyState === 4) {
209
- if (this.httpRequest.status === 200) {
210
- var data = this.httpRequest.responseText
211
-
212
- if (!data) return
213
-
214
- this.data = this._convertDataFormat(data, dataFormat)
215
- }
216
- }
217
- }
218
-
219
- callAjax() {
220
- var { dataFormat = 'text' } = this.state
221
-
222
- if (dataFormat == 'jsonp') {
223
- this._makeRequestJsonp(this.substitute(this.url, this))
224
- } else {
225
- if (!this._makeRequest(this.substitute(this.url, this))) return
226
-
227
- this.httpRequest.send()
228
- }
229
- }
230
-
231
- _draw(context) {
232
- var { left, top, width, height } = this.bounds
233
-
234
- context.beginPath()
235
- this.drawImage(context, Restful.image, left, top, width, height)
236
- }
237
-
238
- ondblclick(e) {
239
- if (!this.url) {
240
- warn(WARN_NO_URL)
241
- return
242
- }
243
-
244
- this.callAjax()
245
- }
246
-
247
- get controls() {}
248
-
249
- get nature() {
250
- return NATURE
251
- }
252
- }
253
-
254
- Component.register('restful', Restful)
@@ -1,67 +0,0 @@
1
- <!--
2
- @license
3
- Copyright © HatioLab Inc. All rights reserved.
4
- -->
5
- <!doctype html>
6
- <html>
7
- <head>
8
- <meta charset="utf-8">
9
- <meta name="viewport" content="width=device-width, minimum-scale=1.0, initial-scale=1.0, user-scalable=yes">
10
-
11
- <script src="../../webcomponentsjs/webcomponents-lite.js"></script>
12
- <script src="../../web-component-tester/browser.js"></script>
13
-
14
- <!-- Step 1: import the element to test -->
15
- <link rel="import" href="../things-scene-restful.html">
16
- </head>
17
- <body>
18
-
19
- <!-- You can use the document as a place to set up your fixtures. -->
20
- <test-fixture id="things-scene-restful-fixture">
21
- <template>
22
- <things-scene-restful>
23
- <h2>things-scene-restful</h2>
24
- </things-scene-restful>
25
- </template>
26
- </test-fixture>
27
-
28
- <script>
29
- suite('<things-scene-restful>', function() {
30
-
31
- var myEl;
32
-
33
- setup(function() {
34
- myEl = fixture('things-scene-restful-fixture');
35
- });
36
-
37
- test('defines the "author" property', function() {
38
- assert.equal(myEl.author.name, 'Dimitri Glazkov');
39
- assert.equal(myEl.author.image, 'http://addyosmani.com/blog/wp-content/uploads/2013/04/unicorn.jpg');
40
- });
41
-
42
- test('says hello', function() {
43
- assert.equal(myEl.sayHello(), 'things-scene-restful says, Hello World!');
44
-
45
- var greetings = myEl.sayHello('greetings Earthlings');
46
- assert.equal(greetings, 'things-scene-restful says, greetings Earthlings');
47
- });
48
-
49
- test('fires lasers', function(done) {
50
- myEl.addEventListener('things-scene-restful-lasers', function(event) {
51
- assert.equal(event.detail.sound, 'Pew pew!');
52
- done();
53
- });
54
- myEl.fireLasers();
55
- });
56
-
57
- test('distributed children', function() {
58
- var els = myEl.getContentChildren();
59
- assert.equal(els.length, 1, 'one distributed node');
60
- assert.equal(els[0], myEl.querySelector('h2'), 'content distributed correctly');
61
- });
62
-
63
- });
64
- </script>
65
-
66
- </body>
67
- </html>
package/test/index.html DELETED
@@ -1,24 +0,0 @@
1
- <!--
2
- @license
3
- Copyright © HatioLab Inc. All rights reserved.
4
- -->
5
- <!DOCTYPE html>
6
- <html>
7
- <head>
8
- <meta charset="utf-8">
9
- <meta name="viewport" content="width=device-width, minimum-scale=1.0, initial-scale=1.0, user-scalable=yes">
10
-
11
- <script src="../../webcomponentsjs/webcomponents-lite.js"></script>
12
- <script src="../../web-component-tester/browser.js"></script>
13
- </head>
14
- <body>
15
- <script>
16
- // Load and run all tests (.html, .js):
17
- WCT.loadSuites([
18
- 'basic-test.html',
19
- 'basic-test.html?dom=shadow'
20
- ]);
21
- </script>
22
-
23
- </body>
24
- </html>
@@ -1,33 +0,0 @@
1
- /*
2
- * Copyright © HatioLab Inc. All rights reserved.
3
- */
4
-
5
- import './util'
6
-
7
- import { expect } from 'chai'
8
-
9
- import '../../bower_components/things-scene-core/things-scene-min'
10
- import { Restful } from '../../src/index'
11
-
12
- describe('Restful', function () {
13
-
14
- var board;
15
-
16
- beforeEach(function () {
17
- board = scene.create({
18
- model: {
19
- components: [{
20
- id: 'restful',
21
- type: 'restful'
22
- }]
23
- }
24
- })
25
- });
26
-
27
- it('component should be found by its id.', function () {
28
-
29
- var component = board.findById('restful')
30
-
31
- expect(!!component).not.to.equal(false);
32
- });
33
- });
package/test/unit/util.js DELETED
@@ -1,22 +0,0 @@
1
- /*
2
- * Copyright © HatioLab Inc. All rights reserved.
3
- */
4
-
5
- var noop = () => {}
6
-
7
- global.Canvas = require('canvas');
8
-
9
- Canvas.prototype.setAttribute = noop;
10
- Canvas.prototype.style = {};
11
-
12
- global.Image = Canvas.Image;
13
- global.screen = {
14
- width: 1280,
15
- height: 800
16
- };
17
-
18
- global.window = global;
19
-
20
- global.addEventListener = noop;
21
- global.location = {};
22
- global.getComputedStyle = noop;
@@ -1,21 +0,0 @@
1
- import icon from './assets/restful.png';
2
-
3
- var templates = [{
4
- type: 'restful',
5
- description: 'restful client',
6
- group: 'dataSource', /* line|shape|textAndMedia|chartAndGauge|table|container|dataSource|IoT|3D|warehouse|form|etc */
7
- icon,
8
- model: {
9
- type: "restful",
10
- left: 10,
11
- top: 10,
12
- width: 100,
13
- height: 100,
14
- hidden: true,
15
- dataFormat: 'json'
16
- }
17
- }];
18
-
19
- export default {
20
- templates
21
- };
@@ -1,6 +0,0 @@
1
- {
2
- "label.url": "url",
3
- "label.period": "period",
4
- "label.data-format": "data format",
5
- "label.with-credentials": "with credentials"
6
- }
@@ -1,6 +0,0 @@
1
- {
2
- "label.url": "URL",
3
- "label.period": "Period",
4
- "label.data-format": "데이터 포멧",
5
- "label.with-credentials": "With Credentials"
6
- }
@@ -1,6 +0,0 @@
1
- {
2
- "label.url": "访问地址",
3
- "label.period": "周期",
4
- "label.data-format": "数据格式",
5
- "label.with-credentials": "允许跨域"
6
- }