@base-framework/base 2.6.0 → 2.6.1
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/base.min.js +1 -0
- package/es5/base.js +2968 -0
- package/es5/modules/ajax.js +663 -0
- package/es5/modules/animation.js +188 -0
- package/es5/modules/animations.js +1080 -0
- package/es5/modules/atom.js +65 -0
- package/es5/modules/component.js +1310 -0
- package/es5/modules/data-binder.js +1131 -0
- package/es5/modules/data.js +1808 -0
- package/es5/modules/date.js +525 -0
- package/es5/modules/form-validator.js +324 -0
- package/es5/modules/history.js +126 -0
- package/es5/modules/html-builder.js +461 -0
- package/es5/modules/layout.js +1679 -0
- package/es5/modules/mouse.js +124 -0
- package/es5/modules/nav-link.js +123 -0
- package/es5/modules/olderversions/animations-ease.js +1095 -0
- package/es5/modules/olderversions/animations-update.js +1048 -0
- package/es5/modules/olderversions/base-animations.js +636 -0
- package/es5/modules/olderversions/base-component-class.js +100 -0
- package/es5/modules/olderversions/base-data-binder-1.js +407 -0
- package/es5/modules/olderversions/base-data-binder-class.js +358 -0
- package/es5/modules/olderversions/base-layout-parser-class.js +172 -0
- package/es5/modules/olderversions/base-mode-1.js +777 -0
- package/es5/modules/olderversions/base-model-class.js +585 -0
- package/es5/modules/olderversions/data-binder/element-binding/base-data-binder-class.js +358 -0
- package/es5/modules/olderversions/data-binder/element-binding/base-model-class.js +585 -0
- package/es5/modules/olderversions/data-binder/model-binding/base-data-binder-class.js +353 -0
- package/es5/modules/olderversions/data-binder/model-binding/base-model-class.js +604 -0
- package/es5/modules/olderversions/data-binder-update-watcher.js +640 -0
- package/es5/modules/olderversions/data-tracker.js +187 -0
- package/es5/modules/olderversions/event-update.js +666 -0
- package/es5/modules/olderversions/nav-link.js +119 -0
- package/es5/modules/olderversions/router-with-templates-1.js +785 -0
- package/es5/modules/olderversions/router-with-templates.js +701 -0
- package/es5/modules/prototypes/ajax.js +657 -0
- package/es5/modules/prototypes/atom.js +65 -0
- package/es5/modules/prototypes/component.js +972 -0
- package/es5/modules/prototypes/data-binder.js +1089 -0
- package/es5/modules/prototypes/data.js +1290 -0
- package/es5/modules/prototypes/html-builder.js +414 -0
- package/es5/modules/prototypes/layout.js +879 -0
- package/es5/modules/router.js +1680 -0
- package/es5/modules/state.js +274 -0
- package/es6/.jshintrc +3 -0
- package/es6/base.js +41 -0
- package/es6/core.js +1 -0
- package/es6/data-tracker.js +351 -0
- package/es6/events.js +602 -0
- package/es6/legacy/es5/base.js +2968 -0
- package/es6/legacy/es5/modules/ajax.js +663 -0
- package/es6/legacy/es5/modules/animation.js +188 -0
- package/es6/legacy/es5/modules/animations.js +1080 -0
- package/es6/legacy/es5/modules/atom.js +65 -0
- package/es6/legacy/es5/modules/component.js +1310 -0
- package/es6/legacy/es5/modules/data-binder.js +1131 -0
- package/es6/legacy/es5/modules/data.js +1808 -0
- package/es6/legacy/es5/modules/date.js +525 -0
- package/es6/legacy/es5/modules/form-validator.js +324 -0
- package/es6/legacy/es5/modules/history.js +126 -0
- package/es6/legacy/es5/modules/html-builder.js +461 -0
- package/es6/legacy/es5/modules/layout.js +1679 -0
- package/es6/legacy/es5/modules/mouse.js +124 -0
- package/es6/legacy/es5/modules/nav-link.js +123 -0
- package/es6/legacy/es5/modules/olderversions/animations-ease.js +1095 -0
- package/es6/legacy/es5/modules/olderversions/animations-update.js +1048 -0
- package/es6/legacy/es5/modules/olderversions/base-animations.js +636 -0
- package/es6/legacy/es5/modules/olderversions/base-component-class.js +100 -0
- package/es6/legacy/es5/modules/olderversions/base-data-binder-1.js +407 -0
- package/es6/legacy/es5/modules/olderversions/base-data-binder-class.js +358 -0
- package/es6/legacy/es5/modules/olderversions/base-layout-parser-class.js +172 -0
- package/es6/legacy/es5/modules/olderversions/base-mode-1.js +777 -0
- package/es6/legacy/es5/modules/olderversions/base-model-class.js +585 -0
- package/es6/legacy/es5/modules/olderversions/data-binder/element-binding/base-data-binder-class.js +358 -0
- package/es6/legacy/es5/modules/olderversions/data-binder/element-binding/base-model-class.js +585 -0
- package/es6/legacy/es5/modules/olderversions/data-binder/model-binding/base-data-binder-class.js +353 -0
- package/es6/legacy/es5/modules/olderversions/data-binder/model-binding/base-model-class.js +604 -0
- package/es6/legacy/es5/modules/olderversions/data-binder-update-watcher.js +640 -0
- package/es6/legacy/es5/modules/olderversions/data-tracker.js +187 -0
- package/es6/legacy/es5/modules/olderversions/event-update.js +666 -0
- package/es6/legacy/es5/modules/olderversions/nav-link.js +119 -0
- package/es6/legacy/es5/modules/olderversions/router-with-templates-1.js +785 -0
- package/es6/legacy/es5/modules/olderversions/router-with-templates.js +701 -0
- package/es6/legacy/es5/modules/prototypes/ajax.js +657 -0
- package/es6/legacy/es5/modules/prototypes/atom.js +65 -0
- package/es6/legacy/es5/modules/prototypes/component.js +972 -0
- package/es6/legacy/es5/modules/prototypes/data-binder.js +1089 -0
- package/es6/legacy/es5/modules/prototypes/data.js +1290 -0
- package/es6/legacy/es5/modules/prototypes/html-builder.js +414 -0
- package/es6/legacy/es5/modules/prototypes/layout.js +879 -0
- package/es6/legacy/es5/modules/router.js +1680 -0
- package/es6/legacy/es5/modules/state.js +274 -0
- package/es6/main.js +1331 -0
- package/es6/modules/ajax/ajax.js +514 -0
- package/es6/modules/animation/animation.js +236 -0
- package/es6/modules/animations/animation-controller.js +231 -0
- package/es6/modules/animations/animation.js +64 -0
- package/es6/modules/animations/attr-movement.js +66 -0
- package/es6/modules/animations/css-movement.js +170 -0
- package/es6/modules/animations/movement.js +131 -0
- package/es6/modules/animations/value.js +187 -0
- package/es6/modules/atom/atom.js +54 -0
- package/es6/modules/component/component.js +230 -0
- package/es6/modules/component/event-helper.js +119 -0
- package/es6/modules/component/jot.js +144 -0
- package/es6/modules/component/state-helper.js +262 -0
- package/es6/modules/component/unit.js +551 -0
- package/es6/modules/data/attrs.js +40 -0
- package/es6/modules/data/basic-data.js +500 -0
- package/es6/modules/data/data-utils.js +29 -0
- package/es6/modules/data/data.js +3 -0
- package/es6/modules/data/deep-data.js +541 -0
- package/es6/modules/data/model-service.js +528 -0
- package/es6/modules/data/model.js +133 -0
- package/es6/modules/data/simple-data.js +33 -0
- package/es6/modules/data-binder/connection-tracker.js +113 -0
- package/es6/modules/data-binder/connection.js +16 -0
- package/es6/modules/data-binder/data-binder.js +352 -0
- package/es6/modules/data-binder/data-pub-sub.js +141 -0
- package/es6/modules/data-binder/data-source.js +56 -0
- package/es6/modules/data-binder/element-source.js +219 -0
- package/es6/modules/data-binder/one-way-connection.js +46 -0
- package/es6/modules/data-binder/one-way-source.js +43 -0
- package/es6/modules/data-binder/source.js +36 -0
- package/es6/modules/data-binder/two-way-connection.js +75 -0
- package/es6/modules/data-binder/two-way-source.js +41 -0
- package/es6/modules/date/date.js +544 -0
- package/es6/modules/history/history.js +89 -0
- package/es6/modules/html-builder/html-builder.js +434 -0
- package/es6/modules/import/import.js +390 -0
- package/es6/modules/layout/layout-builder.js +1269 -0
- package/es6/modules/layout/layout-parser.js +134 -0
- package/es6/modules/layout/watcher-helper.js +282 -0
- package/es6/modules/mouse/mouse.js +114 -0
- package/es6/modules/router/component-helper.js +163 -0
- package/es6/modules/router/history-controller.js +216 -0
- package/es6/modules/router/nav-link.js +124 -0
- package/es6/modules/router/route.js +401 -0
- package/es6/modules/router/router.js +789 -0
- package/es6/modules/router/utils.js +31 -0
- package/es6/modules/state/state-target.js +91 -0
- package/es6/modules/state/state.js +171 -0
- package/es6/package-lock.json +13 -0
- package/es6/package.json +28 -0
- package/es6/shared/objects.js +99 -0
- package/legacy/es5/base.js +2968 -0
- package/legacy/es5/modules/ajax.js +663 -0
- package/legacy/es5/modules/animation.js +188 -0
- package/legacy/es5/modules/animations.js +1080 -0
- package/legacy/es5/modules/atom.js +65 -0
- package/legacy/es5/modules/component.js +1310 -0
- package/legacy/es5/modules/data-binder.js +1131 -0
- package/legacy/es5/modules/data.js +1808 -0
- package/legacy/es5/modules/date.js +525 -0
- package/legacy/es5/modules/form-validator.js +324 -0
- package/legacy/es5/modules/history.js +126 -0
- package/legacy/es5/modules/html-builder.js +461 -0
- package/legacy/es5/modules/layout.js +1679 -0
- package/legacy/es5/modules/mouse.js +124 -0
- package/legacy/es5/modules/nav-link.js +123 -0
- package/legacy/es5/modules/olderversions/animations-ease.js +1095 -0
- package/legacy/es5/modules/olderversions/animations-update.js +1048 -0
- package/legacy/es5/modules/olderversions/base-animations.js +636 -0
- package/legacy/es5/modules/olderversions/base-component-class.js +100 -0
- package/legacy/es5/modules/olderversions/base-data-binder-1.js +407 -0
- package/legacy/es5/modules/olderversions/base-data-binder-class.js +358 -0
- package/legacy/es5/modules/olderversions/base-layout-parser-class.js +172 -0
- package/legacy/es5/modules/olderversions/base-mode-1.js +777 -0
- package/legacy/es5/modules/olderversions/base-model-class.js +585 -0
- package/legacy/es5/modules/olderversions/data-binder/element-binding/base-data-binder-class.js +358 -0
- package/legacy/es5/modules/olderversions/data-binder/element-binding/base-model-class.js +585 -0
- package/legacy/es5/modules/olderversions/data-binder/model-binding/base-data-binder-class.js +353 -0
- package/legacy/es5/modules/olderversions/data-binder/model-binding/base-model-class.js +604 -0
- package/legacy/es5/modules/olderversions/data-binder-update-watcher.js +640 -0
- package/legacy/es5/modules/olderversions/data-tracker.js +187 -0
- package/legacy/es5/modules/olderversions/event-update.js +666 -0
- package/legacy/es5/modules/olderversions/nav-link.js +119 -0
- package/legacy/es5/modules/olderversions/router-with-templates-1.js +785 -0
- package/legacy/es5/modules/olderversions/router-with-templates.js +701 -0
- package/legacy/es5/modules/prototypes/ajax.js +657 -0
- package/legacy/es5/modules/prototypes/atom.js +65 -0
- package/legacy/es5/modules/prototypes/component.js +972 -0
- package/legacy/es5/modules/prototypes/data-binder.js +1089 -0
- package/legacy/es5/modules/prototypes/data.js +1290 -0
- package/legacy/es5/modules/prototypes/html-builder.js +414 -0
- package/legacy/es5/modules/prototypes/layout.js +879 -0
- package/legacy/es5/modules/router.js +1680 -0
- package/legacy/es5/modules/state.js +274 -0
- package/package.json +8 -3
- package/update +16 -0
|
@@ -0,0 +1,528 @@
|
|
|
1
|
+
import {ajax} from '../ajax/ajax.js';
|
|
2
|
+
import {base} from '../../core.js';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* ModelService
|
|
6
|
+
*
|
|
7
|
+
* This will create a new model service.
|
|
8
|
+
* @class
|
|
9
|
+
*/
|
|
10
|
+
export class ModelService
|
|
11
|
+
{
|
|
12
|
+
/**
|
|
13
|
+
* @constructor
|
|
14
|
+
* @param {object} model
|
|
15
|
+
*/
|
|
16
|
+
constructor(model)
|
|
17
|
+
{
|
|
18
|
+
/**
|
|
19
|
+
* @member {object} model
|
|
20
|
+
*/
|
|
21
|
+
this.model = model;
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* @member {string} objectType The return type.
|
|
25
|
+
*/
|
|
26
|
+
this.objectType = this.objectType || 'item';
|
|
27
|
+
|
|
28
|
+
this.url = '';
|
|
29
|
+
this.validateCallBack = null;
|
|
30
|
+
this.init();
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
init()
|
|
34
|
+
{
|
|
35
|
+
let model = this.model;
|
|
36
|
+
if(model && model.url)
|
|
37
|
+
{
|
|
38
|
+
this.url = model.url;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* This will check if the model is valid.
|
|
44
|
+
*
|
|
45
|
+
* @return {boolean}
|
|
46
|
+
*/
|
|
47
|
+
isValid()
|
|
48
|
+
{
|
|
49
|
+
let result = this.validate();
|
|
50
|
+
if(result !== false)
|
|
51
|
+
{
|
|
52
|
+
let callBack = this.validateCallBack;
|
|
53
|
+
if(typeof callBack === 'function')
|
|
54
|
+
{
|
|
55
|
+
callBack(result);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
return result;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* This should be overriden to validate the model
|
|
63
|
+
* before submitting.
|
|
64
|
+
*
|
|
65
|
+
* @return {boolean}
|
|
66
|
+
*/
|
|
67
|
+
validate()
|
|
68
|
+
{
|
|
69
|
+
return true;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* This can be overriden to add default params
|
|
74
|
+
* with each request.
|
|
75
|
+
*
|
|
76
|
+
* @protected
|
|
77
|
+
* @return {string}
|
|
78
|
+
*/
|
|
79
|
+
getDefaultParams()
|
|
80
|
+
{
|
|
81
|
+
return '';
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
/**
|
|
85
|
+
* This will setup the request params.
|
|
86
|
+
*
|
|
87
|
+
* @protected
|
|
88
|
+
* @param {(string|object)} params
|
|
89
|
+
* @return {(string|object)}
|
|
90
|
+
*/
|
|
91
|
+
setupParams(params)
|
|
92
|
+
{
|
|
93
|
+
let defaults = this.getDefaultParams();
|
|
94
|
+
params = this.addParams(params, defaults);
|
|
95
|
+
return params;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
/**
|
|
99
|
+
* This will convert an object to a string.
|
|
100
|
+
*
|
|
101
|
+
* @protected
|
|
102
|
+
* @param {object} object
|
|
103
|
+
* @return {string}
|
|
104
|
+
*/
|
|
105
|
+
objectToString(object)
|
|
106
|
+
{
|
|
107
|
+
const params = [];
|
|
108
|
+
for (var prop in object)
|
|
109
|
+
{
|
|
110
|
+
if(object.hasOwnProperty(prop))
|
|
111
|
+
{
|
|
112
|
+
params.push(prop + '=' + object[prop]);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
return params.join('&');
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
/**
|
|
119
|
+
* This will add the params.
|
|
120
|
+
*
|
|
121
|
+
* @protected
|
|
122
|
+
* @param {*} params
|
|
123
|
+
* @param {*} addingParams
|
|
124
|
+
* @return {(string|object)}
|
|
125
|
+
*/
|
|
126
|
+
addParams(params, addingParams)
|
|
127
|
+
{
|
|
128
|
+
params = params || {};
|
|
129
|
+
if(typeof params === 'string')
|
|
130
|
+
{
|
|
131
|
+
params = base.parseQueryString(params, false);
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
if(!addingParams)
|
|
135
|
+
{
|
|
136
|
+
return (!this._isFormData(params))? this.objectToString(params) : params;
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
if(typeof addingParams === 'string')
|
|
140
|
+
{
|
|
141
|
+
addingParams = base.parseQueryString(addingParams, false);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
if(this._isFormData(params))
|
|
145
|
+
{
|
|
146
|
+
for(var key in addingParams)
|
|
147
|
+
{
|
|
148
|
+
if(addingParams.hasOwnProperty(key))
|
|
149
|
+
{
|
|
150
|
+
params.append(key, addingParams[key]);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
else
|
|
155
|
+
{
|
|
156
|
+
params = Object.assign(params, addingParams);
|
|
157
|
+
params = this.objectToString(params);
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
return params;
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
/**
|
|
164
|
+
* This will get the model by id.
|
|
165
|
+
*
|
|
166
|
+
* @param {string} [instanceParams]
|
|
167
|
+
* @param {function} [callBack]
|
|
168
|
+
* @return {object}
|
|
169
|
+
*/
|
|
170
|
+
get(instanceParams, callBack)
|
|
171
|
+
{
|
|
172
|
+
let id = this.model.get('id'),
|
|
173
|
+
params = 'op=get' +
|
|
174
|
+
'&id=' + id;
|
|
175
|
+
|
|
176
|
+
let model = this.model;
|
|
177
|
+
return this._get('', params, instanceParams, callBack, (response) =>
|
|
178
|
+
{
|
|
179
|
+
if(response)
|
|
180
|
+
{
|
|
181
|
+
/* this will update the model with the get request
|
|
182
|
+
response */
|
|
183
|
+
let object = this.getObject(response);
|
|
184
|
+
if(object)
|
|
185
|
+
{
|
|
186
|
+
model.set(object);
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
});
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
/**
|
|
193
|
+
* This will get the object from the response.
|
|
194
|
+
*
|
|
195
|
+
* @protected
|
|
196
|
+
* @param {object} response
|
|
197
|
+
* @return {object}
|
|
198
|
+
*/
|
|
199
|
+
getObject(response)
|
|
200
|
+
{
|
|
201
|
+
/* this will update the model with the get request
|
|
202
|
+
response */
|
|
203
|
+
let object = response[this.objectType] || response;
|
|
204
|
+
return object || false;
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
/**
|
|
208
|
+
* This will return a string with the model data json encoded.
|
|
209
|
+
*
|
|
210
|
+
* @protected
|
|
211
|
+
* @return {string}
|
|
212
|
+
*/
|
|
213
|
+
setupObjectData()
|
|
214
|
+
{
|
|
215
|
+
let item = this.model.get();
|
|
216
|
+
return this.objectType + '=' + base.prepareJsonUrl(item);
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
/**
|
|
220
|
+
* This will add or update the model.
|
|
221
|
+
*
|
|
222
|
+
* @param {string} [instanceParams]
|
|
223
|
+
* @param {function} [callBack]
|
|
224
|
+
* @return {object}
|
|
225
|
+
*/
|
|
226
|
+
setup(instanceParams, callBack)
|
|
227
|
+
{
|
|
228
|
+
if(!this.isValid())
|
|
229
|
+
{
|
|
230
|
+
return false;
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
let params = 'op=setup' +
|
|
234
|
+
'&' + this.setupObjectData();
|
|
235
|
+
|
|
236
|
+
/* this will add the instance params with the
|
|
237
|
+
method params */
|
|
238
|
+
params = this.addParams(params, instanceParams, instanceParams);
|
|
239
|
+
|
|
240
|
+
return this._put('', params, callBack);
|
|
241
|
+
}
|
|
242
|
+
|
|
243
|
+
/**
|
|
244
|
+
* This will add the model.
|
|
245
|
+
*
|
|
246
|
+
* @param {string} [instanceParams]
|
|
247
|
+
* @param {function} [callBack]
|
|
248
|
+
* @return {object}
|
|
249
|
+
*/
|
|
250
|
+
add(instanceParams, callBack)
|
|
251
|
+
{
|
|
252
|
+
if(!this.isValid())
|
|
253
|
+
{
|
|
254
|
+
return false;
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
let params = 'op=add' +
|
|
258
|
+
'&' + this.setupObjectData();
|
|
259
|
+
|
|
260
|
+
return this._post('', params, instanceParams, callBack);
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
/**
|
|
264
|
+
* This will update the model.
|
|
265
|
+
*
|
|
266
|
+
* @param {string} [instanceParams]
|
|
267
|
+
* @param {function} [callBack]
|
|
268
|
+
* @return {object}
|
|
269
|
+
*/
|
|
270
|
+
update(instanceParams, callBack)
|
|
271
|
+
{
|
|
272
|
+
if(!this.isValid())
|
|
273
|
+
{
|
|
274
|
+
return false;
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
let params = 'op=update' +
|
|
278
|
+
'&' + this.setupObjectData();
|
|
279
|
+
|
|
280
|
+
return this._patch('', params, instanceParams, callBack);
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
/**
|
|
284
|
+
* This will delete the model.
|
|
285
|
+
*
|
|
286
|
+
* @param {string} [instanceParams]
|
|
287
|
+
* @param {function} [callBack]
|
|
288
|
+
* @return {object}
|
|
289
|
+
*/
|
|
290
|
+
delete(instanceParams, callBack)
|
|
291
|
+
{
|
|
292
|
+
let id = this.model.get('id'),
|
|
293
|
+
params = 'op=delete' +
|
|
294
|
+
'&id=' + id;
|
|
295
|
+
|
|
296
|
+
return this._delete('', params, instanceParams, callBack);
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
/**
|
|
300
|
+
* This will list rows of the model.
|
|
301
|
+
*
|
|
302
|
+
* @param {string} [instanceParams]
|
|
303
|
+
* @param {function} [callBack]
|
|
304
|
+
* @param {int} start
|
|
305
|
+
* @param {int} count
|
|
306
|
+
* @param {string} filter
|
|
307
|
+
* @return {object}
|
|
308
|
+
*/
|
|
309
|
+
all(instanceParams, callBack, start, count, filter)
|
|
310
|
+
{
|
|
311
|
+
filter = filter || '';
|
|
312
|
+
start = !isNaN(start)? start : 0;
|
|
313
|
+
count = !isNaN(count)? count : 50;
|
|
314
|
+
|
|
315
|
+
let params = 'op=all' +
|
|
316
|
+
'&option=' + filter +
|
|
317
|
+
'&start=' + start +
|
|
318
|
+
'&stop=' + count;
|
|
319
|
+
|
|
320
|
+
return this._get('', params, instanceParams, callBack);
|
|
321
|
+
}
|
|
322
|
+
|
|
323
|
+
getUrl(url)
|
|
324
|
+
{
|
|
325
|
+
let baseUrl = this.url;
|
|
326
|
+
if(!url)
|
|
327
|
+
{
|
|
328
|
+
return baseUrl;
|
|
329
|
+
}
|
|
330
|
+
|
|
331
|
+
if(url[0] === '?')
|
|
332
|
+
{
|
|
333
|
+
return baseUrl + url;
|
|
334
|
+
}
|
|
335
|
+
|
|
336
|
+
return baseUrl += '/' + url;
|
|
337
|
+
}
|
|
338
|
+
|
|
339
|
+
/**
|
|
340
|
+
* This will make an ajax request.
|
|
341
|
+
*
|
|
342
|
+
* @param {string} url
|
|
343
|
+
* @param {string} method
|
|
344
|
+
* @param {(string|object)} params
|
|
345
|
+
* @param {function} callBack
|
|
346
|
+
* @param {function} [requestCallBack]
|
|
347
|
+
* @param {object}
|
|
348
|
+
*/
|
|
349
|
+
setupRequest(url, method, params, callBack, requestCallBack)
|
|
350
|
+
{
|
|
351
|
+
let settings = {
|
|
352
|
+
url: this.getUrl(url),
|
|
353
|
+
method,
|
|
354
|
+
params,
|
|
355
|
+
completed: (response, xhr) =>
|
|
356
|
+
{
|
|
357
|
+
if(typeof requestCallBack === 'function')
|
|
358
|
+
{
|
|
359
|
+
requestCallBack(response);
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
this.getResponse(response, callBack, xhr);
|
|
363
|
+
}
|
|
364
|
+
};
|
|
365
|
+
|
|
366
|
+
let overrideHeader = this._isFormData(params);
|
|
367
|
+
if(overrideHeader)
|
|
368
|
+
{
|
|
369
|
+
settings.headers = {};
|
|
370
|
+
}
|
|
371
|
+
|
|
372
|
+
return ajax(settings);
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
_isFormData(data)
|
|
376
|
+
{
|
|
377
|
+
return data instanceof FormData;
|
|
378
|
+
}
|
|
379
|
+
|
|
380
|
+
/**
|
|
381
|
+
* This will make an ajax request.
|
|
382
|
+
*
|
|
383
|
+
* @param {(string|object)} params
|
|
384
|
+
* @param {string} instanceParams
|
|
385
|
+
* @param {function} callBack
|
|
386
|
+
* @param {function} [requestCallBack]
|
|
387
|
+
* @param {object}
|
|
388
|
+
*/
|
|
389
|
+
request(params, instanceParams, callBack, requestCallBack)
|
|
390
|
+
{
|
|
391
|
+
return this._request('', 'POST', params, instanceParams, callBack, requestCallBack);
|
|
392
|
+
}
|
|
393
|
+
|
|
394
|
+
/**
|
|
395
|
+
* This will make a GET request.
|
|
396
|
+
*
|
|
397
|
+
* @param {string} url
|
|
398
|
+
* @param {(string|object)} params
|
|
399
|
+
* @param {string} instanceParams
|
|
400
|
+
* @param {function} callBack
|
|
401
|
+
* @param {function} [requestCallBack]
|
|
402
|
+
* @param {object}
|
|
403
|
+
*/
|
|
404
|
+
_get(url, params, instanceParams, callBack, requestCallBack)
|
|
405
|
+
{
|
|
406
|
+
params = this.setupParams(params);
|
|
407
|
+
params = this.addParams(params, instanceParams);
|
|
408
|
+
|
|
409
|
+
url = url || '';
|
|
410
|
+
|
|
411
|
+
if(params)
|
|
412
|
+
{
|
|
413
|
+
url += '?' + params;
|
|
414
|
+
}
|
|
415
|
+
|
|
416
|
+
return this.setupRequest(url, "GET", '', callBack, requestCallBack);
|
|
417
|
+
}
|
|
418
|
+
|
|
419
|
+
/**
|
|
420
|
+
* This will make a POST request.
|
|
421
|
+
*
|
|
422
|
+
* @param {string} url
|
|
423
|
+
* @param {(string|object)} params
|
|
424
|
+
* @param {string} instanceParams
|
|
425
|
+
* @param {function} callBack
|
|
426
|
+
* @param {function} [requestCallBack]
|
|
427
|
+
* @param {object}
|
|
428
|
+
*/
|
|
429
|
+
_post(url, params, instanceParams, callBack, requestCallBack)
|
|
430
|
+
{
|
|
431
|
+
return this._request(url, 'POST', params, instanceParams, callBack, requestCallBack);
|
|
432
|
+
}
|
|
433
|
+
|
|
434
|
+
/**
|
|
435
|
+
* This will make a PUT request.
|
|
436
|
+
*
|
|
437
|
+
* @param {string} url
|
|
438
|
+
* @param {(string|object)} params
|
|
439
|
+
* @param {string} instanceParams
|
|
440
|
+
* @param {function} callBack
|
|
441
|
+
* @param {function} [requestCallBack]
|
|
442
|
+
* @param {object}
|
|
443
|
+
*/
|
|
444
|
+
_put(url, params, instanceParams, callBack, requestCallBack)
|
|
445
|
+
{
|
|
446
|
+
return this._request(url, 'PUT', params, instanceParams, callBack, requestCallBack);
|
|
447
|
+
}
|
|
448
|
+
|
|
449
|
+
/**
|
|
450
|
+
* This will make a PATCH request.
|
|
451
|
+
*
|
|
452
|
+
* @param {string} url
|
|
453
|
+
* @param {(string|object)} params
|
|
454
|
+
* @param {string} instanceParams
|
|
455
|
+
* @param {function} callBack
|
|
456
|
+
* @param {function} [requestCallBack]
|
|
457
|
+
* @param {object}
|
|
458
|
+
*/
|
|
459
|
+
_patch(url, params, instanceParams, callBack, requestCallBack)
|
|
460
|
+
{
|
|
461
|
+
return this._request(url, 'PATCH', params, instanceParams, callBack, requestCallBack);
|
|
462
|
+
}
|
|
463
|
+
|
|
464
|
+
/**
|
|
465
|
+
* This will make a DELETE request.
|
|
466
|
+
*
|
|
467
|
+
* @param {string} url
|
|
468
|
+
* @param {(string|object)} params
|
|
469
|
+
* @param {string} instanceParams
|
|
470
|
+
* @param {function} callBack
|
|
471
|
+
* @param {function} [requestCallBack]
|
|
472
|
+
* @param {object}
|
|
473
|
+
*/
|
|
474
|
+
_delete(url, params, instanceParams, callBack, requestCallBack)
|
|
475
|
+
{
|
|
476
|
+
return this._request(url, 'DELETE', params, instanceParams, callBack, requestCallBack);
|
|
477
|
+
}
|
|
478
|
+
|
|
479
|
+
/**
|
|
480
|
+
* This will make an ajax request.
|
|
481
|
+
*
|
|
482
|
+
* @param {string} url
|
|
483
|
+
* @param {string} method
|
|
484
|
+
* @param {(string|object)} params
|
|
485
|
+
* @param {string} instanceParams
|
|
486
|
+
* @param {function} callBack
|
|
487
|
+
* @param {function} [requestCallBack]
|
|
488
|
+
* @param {object}
|
|
489
|
+
*/
|
|
490
|
+
_request(url, method, params, instanceParams, callBack, requestCallBack)
|
|
491
|
+
{
|
|
492
|
+
params = this.setupParams(params);
|
|
493
|
+
params = this.addParams(params, instanceParams);
|
|
494
|
+
|
|
495
|
+
return this.setupRequest(url, method, params, callBack, requestCallBack);
|
|
496
|
+
}
|
|
497
|
+
|
|
498
|
+
getResponse(response, callBack, xhr)
|
|
499
|
+
{
|
|
500
|
+
/* this will check to return the response
|
|
501
|
+
to the callBack function */
|
|
502
|
+
if(typeof callBack === 'function')
|
|
503
|
+
{
|
|
504
|
+
callBack(response, xhr);
|
|
505
|
+
}
|
|
506
|
+
}
|
|
507
|
+
|
|
508
|
+
static extend(child)
|
|
509
|
+
{
|
|
510
|
+
if(!child)
|
|
511
|
+
{
|
|
512
|
+
return false;
|
|
513
|
+
}
|
|
514
|
+
|
|
515
|
+
var parent = this;
|
|
516
|
+
class service extends parent
|
|
517
|
+
{
|
|
518
|
+
constructor(model)
|
|
519
|
+
{
|
|
520
|
+
super(model);
|
|
521
|
+
}
|
|
522
|
+
}
|
|
523
|
+
|
|
524
|
+
Object.assign(service.prototype, child);
|
|
525
|
+
|
|
526
|
+
return service;
|
|
527
|
+
}
|
|
528
|
+
}
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import {Data} from './deep-data.js';
|
|
2
|
+
import {ModelService} from './model-service.js';
|
|
3
|
+
import {setupAttrSettings} from './attrs.js';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* This will get the defaults from the settings.
|
|
7
|
+
*
|
|
8
|
+
* @param {object} settings
|
|
9
|
+
* @return {object}
|
|
10
|
+
*/
|
|
11
|
+
const setupDefaultAttr = (settings) =>
|
|
12
|
+
{
|
|
13
|
+
let attributes = {};
|
|
14
|
+
if(!settings || typeof settings !== 'object')
|
|
15
|
+
{
|
|
16
|
+
return attributes;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
let defaults = settings.defaults;
|
|
20
|
+
if(!defaults)
|
|
21
|
+
{
|
|
22
|
+
return attributes;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
for(var prop in defaults)
|
|
26
|
+
{
|
|
27
|
+
if(defaults.hasOwnProperty(prop))
|
|
28
|
+
{
|
|
29
|
+
var attr = defaults[prop];
|
|
30
|
+
if(typeof attr !== 'function')
|
|
31
|
+
{
|
|
32
|
+
attributes[prop] = attr;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
delete settings.defaults;
|
|
37
|
+
return attributes;
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* This will get the xhr settings.
|
|
42
|
+
*
|
|
43
|
+
* @param {object} settings
|
|
44
|
+
* @return {object}
|
|
45
|
+
*/
|
|
46
|
+
const getXhr = (settings) =>
|
|
47
|
+
{
|
|
48
|
+
if(!settings || typeof settings.xhr !== 'object')
|
|
49
|
+
{
|
|
50
|
+
return {};
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
let settingsXhr = settings.xhr,
|
|
54
|
+
xhr = Object.assign({}, settingsXhr);
|
|
55
|
+
delete settings.xhr;
|
|
56
|
+
return xhr;
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
/* this will track the number of model types */
|
|
60
|
+
let modelTypeNumber = 0;
|
|
61
|
+
|
|
62
|
+
/**
|
|
63
|
+
* Model
|
|
64
|
+
*
|
|
65
|
+
* This will extend Data to add a model that can specify
|
|
66
|
+
* a service that connects to a remote source.
|
|
67
|
+
*/
|
|
68
|
+
export class Model extends Data
|
|
69
|
+
{
|
|
70
|
+
/**
|
|
71
|
+
* @constructor
|
|
72
|
+
* @param {object} [settings]
|
|
73
|
+
*/
|
|
74
|
+
constructor(settings)
|
|
75
|
+
{
|
|
76
|
+
super(settings);
|
|
77
|
+
this.initialize();
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
/**
|
|
81
|
+
* This adds a method to call if you want the model
|
|
82
|
+
* to do something when its initialized.
|
|
83
|
+
*/
|
|
84
|
+
initialize()
|
|
85
|
+
{
|
|
86
|
+
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/**
|
|
90
|
+
* This will extend the model to a child model.
|
|
91
|
+
*
|
|
92
|
+
* @param {object} [settings]
|
|
93
|
+
* @return {class}
|
|
94
|
+
*/
|
|
95
|
+
static extend(settings = {})
|
|
96
|
+
{
|
|
97
|
+
const parent = this,
|
|
98
|
+
xhr = getXhr(settings),
|
|
99
|
+
service = this.prototype.service.extend(xhr);
|
|
100
|
+
|
|
101
|
+
/* this will setup the default attribute settings for
|
|
102
|
+
the model */
|
|
103
|
+
let defaultAttributes = setupDefaultAttr(settings);
|
|
104
|
+
class model extends parent
|
|
105
|
+
{
|
|
106
|
+
constructor(instanceSettings)
|
|
107
|
+
{
|
|
108
|
+
/* this will get the instance attributes that
|
|
109
|
+
the model will set as attribute data */
|
|
110
|
+
let instanceAttr = setupAttrSettings(instanceSettings);
|
|
111
|
+
|
|
112
|
+
/* we want to extend the default attr with the
|
|
113
|
+
instance attr before we set the data and call
|
|
114
|
+
the parent constructor */
|
|
115
|
+
instanceAttr = Object.assign({}, defaultAttributes, instanceAttr);
|
|
116
|
+
super(instanceAttr);
|
|
117
|
+
|
|
118
|
+
/* this will setup the model service and
|
|
119
|
+
pass the new model instance to the service */
|
|
120
|
+
this.xhr = new service(this);
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
dataTypeId = 'bm' + (modelTypeNumber++);
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
Object.assign(model.prototype, settings);
|
|
127
|
+
model.prototype.service = service;
|
|
128
|
+
|
|
129
|
+
return model;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
Model.prototype.service = ModelService;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import {BasicData} from './basic-data.js';
|
|
2
|
+
import {dataBinder} from '../data-binder/data-binder.js';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* SimpleData
|
|
6
|
+
*
|
|
7
|
+
* This will extend Data to add a simple data object
|
|
8
|
+
* that doesn't allow deep nested data.
|
|
9
|
+
* @class
|
|
10
|
+
* @augments BasicData
|
|
11
|
+
*/
|
|
12
|
+
export class SimpleData extends BasicData
|
|
13
|
+
{
|
|
14
|
+
/**
|
|
15
|
+
* This will publish an update to the data binder.
|
|
16
|
+
*
|
|
17
|
+
* @override
|
|
18
|
+
* @protected
|
|
19
|
+
* @param {string} attr
|
|
20
|
+
* @param {*} val
|
|
21
|
+
* @param {*} committer
|
|
22
|
+
* @param {*} prevValue
|
|
23
|
+
*/
|
|
24
|
+
_publish(attr, val, committer, prevValue)
|
|
25
|
+
{
|
|
26
|
+
let message = attr + ':change';
|
|
27
|
+
this.eventSub.publish(message, val, committer);
|
|
28
|
+
|
|
29
|
+
committer = committer || this;
|
|
30
|
+
|
|
31
|
+
dataBinder.publish(this._dataId + attr, val, committer);
|
|
32
|
+
}
|
|
33
|
+
}
|