@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.
Files changed (190) hide show
  1. package/base.min.js +1 -0
  2. package/es5/base.js +2968 -0
  3. package/es5/modules/ajax.js +663 -0
  4. package/es5/modules/animation.js +188 -0
  5. package/es5/modules/animations.js +1080 -0
  6. package/es5/modules/atom.js +65 -0
  7. package/es5/modules/component.js +1310 -0
  8. package/es5/modules/data-binder.js +1131 -0
  9. package/es5/modules/data.js +1808 -0
  10. package/es5/modules/date.js +525 -0
  11. package/es5/modules/form-validator.js +324 -0
  12. package/es5/modules/history.js +126 -0
  13. package/es5/modules/html-builder.js +461 -0
  14. package/es5/modules/layout.js +1679 -0
  15. package/es5/modules/mouse.js +124 -0
  16. package/es5/modules/nav-link.js +123 -0
  17. package/es5/modules/olderversions/animations-ease.js +1095 -0
  18. package/es5/modules/olderversions/animations-update.js +1048 -0
  19. package/es5/modules/olderversions/base-animations.js +636 -0
  20. package/es5/modules/olderversions/base-component-class.js +100 -0
  21. package/es5/modules/olderversions/base-data-binder-1.js +407 -0
  22. package/es5/modules/olderversions/base-data-binder-class.js +358 -0
  23. package/es5/modules/olderversions/base-layout-parser-class.js +172 -0
  24. package/es5/modules/olderversions/base-mode-1.js +777 -0
  25. package/es5/modules/olderversions/base-model-class.js +585 -0
  26. package/es5/modules/olderversions/data-binder/element-binding/base-data-binder-class.js +358 -0
  27. package/es5/modules/olderversions/data-binder/element-binding/base-model-class.js +585 -0
  28. package/es5/modules/olderversions/data-binder/model-binding/base-data-binder-class.js +353 -0
  29. package/es5/modules/olderversions/data-binder/model-binding/base-model-class.js +604 -0
  30. package/es5/modules/olderversions/data-binder-update-watcher.js +640 -0
  31. package/es5/modules/olderversions/data-tracker.js +187 -0
  32. package/es5/modules/olderversions/event-update.js +666 -0
  33. package/es5/modules/olderversions/nav-link.js +119 -0
  34. package/es5/modules/olderversions/router-with-templates-1.js +785 -0
  35. package/es5/modules/olderversions/router-with-templates.js +701 -0
  36. package/es5/modules/prototypes/ajax.js +657 -0
  37. package/es5/modules/prototypes/atom.js +65 -0
  38. package/es5/modules/prototypes/component.js +972 -0
  39. package/es5/modules/prototypes/data-binder.js +1089 -0
  40. package/es5/modules/prototypes/data.js +1290 -0
  41. package/es5/modules/prototypes/html-builder.js +414 -0
  42. package/es5/modules/prototypes/layout.js +879 -0
  43. package/es5/modules/router.js +1680 -0
  44. package/es5/modules/state.js +274 -0
  45. package/es6/.jshintrc +3 -0
  46. package/es6/base.js +41 -0
  47. package/es6/core.js +1 -0
  48. package/es6/data-tracker.js +351 -0
  49. package/es6/events.js +602 -0
  50. package/es6/legacy/es5/base.js +2968 -0
  51. package/es6/legacy/es5/modules/ajax.js +663 -0
  52. package/es6/legacy/es5/modules/animation.js +188 -0
  53. package/es6/legacy/es5/modules/animations.js +1080 -0
  54. package/es6/legacy/es5/modules/atom.js +65 -0
  55. package/es6/legacy/es5/modules/component.js +1310 -0
  56. package/es6/legacy/es5/modules/data-binder.js +1131 -0
  57. package/es6/legacy/es5/modules/data.js +1808 -0
  58. package/es6/legacy/es5/modules/date.js +525 -0
  59. package/es6/legacy/es5/modules/form-validator.js +324 -0
  60. package/es6/legacy/es5/modules/history.js +126 -0
  61. package/es6/legacy/es5/modules/html-builder.js +461 -0
  62. package/es6/legacy/es5/modules/layout.js +1679 -0
  63. package/es6/legacy/es5/modules/mouse.js +124 -0
  64. package/es6/legacy/es5/modules/nav-link.js +123 -0
  65. package/es6/legacy/es5/modules/olderversions/animations-ease.js +1095 -0
  66. package/es6/legacy/es5/modules/olderversions/animations-update.js +1048 -0
  67. package/es6/legacy/es5/modules/olderversions/base-animations.js +636 -0
  68. package/es6/legacy/es5/modules/olderversions/base-component-class.js +100 -0
  69. package/es6/legacy/es5/modules/olderversions/base-data-binder-1.js +407 -0
  70. package/es6/legacy/es5/modules/olderversions/base-data-binder-class.js +358 -0
  71. package/es6/legacy/es5/modules/olderversions/base-layout-parser-class.js +172 -0
  72. package/es6/legacy/es5/modules/olderversions/base-mode-1.js +777 -0
  73. package/es6/legacy/es5/modules/olderversions/base-model-class.js +585 -0
  74. package/es6/legacy/es5/modules/olderversions/data-binder/element-binding/base-data-binder-class.js +358 -0
  75. package/es6/legacy/es5/modules/olderversions/data-binder/element-binding/base-model-class.js +585 -0
  76. package/es6/legacy/es5/modules/olderversions/data-binder/model-binding/base-data-binder-class.js +353 -0
  77. package/es6/legacy/es5/modules/olderversions/data-binder/model-binding/base-model-class.js +604 -0
  78. package/es6/legacy/es5/modules/olderversions/data-binder-update-watcher.js +640 -0
  79. package/es6/legacy/es5/modules/olderversions/data-tracker.js +187 -0
  80. package/es6/legacy/es5/modules/olderversions/event-update.js +666 -0
  81. package/es6/legacy/es5/modules/olderversions/nav-link.js +119 -0
  82. package/es6/legacy/es5/modules/olderversions/router-with-templates-1.js +785 -0
  83. package/es6/legacy/es5/modules/olderversions/router-with-templates.js +701 -0
  84. package/es6/legacy/es5/modules/prototypes/ajax.js +657 -0
  85. package/es6/legacy/es5/modules/prototypes/atom.js +65 -0
  86. package/es6/legacy/es5/modules/prototypes/component.js +972 -0
  87. package/es6/legacy/es5/modules/prototypes/data-binder.js +1089 -0
  88. package/es6/legacy/es5/modules/prototypes/data.js +1290 -0
  89. package/es6/legacy/es5/modules/prototypes/html-builder.js +414 -0
  90. package/es6/legacy/es5/modules/prototypes/layout.js +879 -0
  91. package/es6/legacy/es5/modules/router.js +1680 -0
  92. package/es6/legacy/es5/modules/state.js +274 -0
  93. package/es6/main.js +1331 -0
  94. package/es6/modules/ajax/ajax.js +514 -0
  95. package/es6/modules/animation/animation.js +236 -0
  96. package/es6/modules/animations/animation-controller.js +231 -0
  97. package/es6/modules/animations/animation.js +64 -0
  98. package/es6/modules/animations/attr-movement.js +66 -0
  99. package/es6/modules/animations/css-movement.js +170 -0
  100. package/es6/modules/animations/movement.js +131 -0
  101. package/es6/modules/animations/value.js +187 -0
  102. package/es6/modules/atom/atom.js +54 -0
  103. package/es6/modules/component/component.js +230 -0
  104. package/es6/modules/component/event-helper.js +119 -0
  105. package/es6/modules/component/jot.js +144 -0
  106. package/es6/modules/component/state-helper.js +262 -0
  107. package/es6/modules/component/unit.js +551 -0
  108. package/es6/modules/data/attrs.js +40 -0
  109. package/es6/modules/data/basic-data.js +500 -0
  110. package/es6/modules/data/data-utils.js +29 -0
  111. package/es6/modules/data/data.js +3 -0
  112. package/es6/modules/data/deep-data.js +541 -0
  113. package/es6/modules/data/model-service.js +528 -0
  114. package/es6/modules/data/model.js +133 -0
  115. package/es6/modules/data/simple-data.js +33 -0
  116. package/es6/modules/data-binder/connection-tracker.js +113 -0
  117. package/es6/modules/data-binder/connection.js +16 -0
  118. package/es6/modules/data-binder/data-binder.js +352 -0
  119. package/es6/modules/data-binder/data-pub-sub.js +141 -0
  120. package/es6/modules/data-binder/data-source.js +56 -0
  121. package/es6/modules/data-binder/element-source.js +219 -0
  122. package/es6/modules/data-binder/one-way-connection.js +46 -0
  123. package/es6/modules/data-binder/one-way-source.js +43 -0
  124. package/es6/modules/data-binder/source.js +36 -0
  125. package/es6/modules/data-binder/two-way-connection.js +75 -0
  126. package/es6/modules/data-binder/two-way-source.js +41 -0
  127. package/es6/modules/date/date.js +544 -0
  128. package/es6/modules/history/history.js +89 -0
  129. package/es6/modules/html-builder/html-builder.js +434 -0
  130. package/es6/modules/import/import.js +390 -0
  131. package/es6/modules/layout/layout-builder.js +1269 -0
  132. package/es6/modules/layout/layout-parser.js +134 -0
  133. package/es6/modules/layout/watcher-helper.js +282 -0
  134. package/es6/modules/mouse/mouse.js +114 -0
  135. package/es6/modules/router/component-helper.js +163 -0
  136. package/es6/modules/router/history-controller.js +216 -0
  137. package/es6/modules/router/nav-link.js +124 -0
  138. package/es6/modules/router/route.js +401 -0
  139. package/es6/modules/router/router.js +789 -0
  140. package/es6/modules/router/utils.js +31 -0
  141. package/es6/modules/state/state-target.js +91 -0
  142. package/es6/modules/state/state.js +171 -0
  143. package/es6/package-lock.json +13 -0
  144. package/es6/package.json +28 -0
  145. package/es6/shared/objects.js +99 -0
  146. package/legacy/es5/base.js +2968 -0
  147. package/legacy/es5/modules/ajax.js +663 -0
  148. package/legacy/es5/modules/animation.js +188 -0
  149. package/legacy/es5/modules/animations.js +1080 -0
  150. package/legacy/es5/modules/atom.js +65 -0
  151. package/legacy/es5/modules/component.js +1310 -0
  152. package/legacy/es5/modules/data-binder.js +1131 -0
  153. package/legacy/es5/modules/data.js +1808 -0
  154. package/legacy/es5/modules/date.js +525 -0
  155. package/legacy/es5/modules/form-validator.js +324 -0
  156. package/legacy/es5/modules/history.js +126 -0
  157. package/legacy/es5/modules/html-builder.js +461 -0
  158. package/legacy/es5/modules/layout.js +1679 -0
  159. package/legacy/es5/modules/mouse.js +124 -0
  160. package/legacy/es5/modules/nav-link.js +123 -0
  161. package/legacy/es5/modules/olderversions/animations-ease.js +1095 -0
  162. package/legacy/es5/modules/olderversions/animations-update.js +1048 -0
  163. package/legacy/es5/modules/olderversions/base-animations.js +636 -0
  164. package/legacy/es5/modules/olderversions/base-component-class.js +100 -0
  165. package/legacy/es5/modules/olderversions/base-data-binder-1.js +407 -0
  166. package/legacy/es5/modules/olderversions/base-data-binder-class.js +358 -0
  167. package/legacy/es5/modules/olderversions/base-layout-parser-class.js +172 -0
  168. package/legacy/es5/modules/olderversions/base-mode-1.js +777 -0
  169. package/legacy/es5/modules/olderversions/base-model-class.js +585 -0
  170. package/legacy/es5/modules/olderversions/data-binder/element-binding/base-data-binder-class.js +358 -0
  171. package/legacy/es5/modules/olderversions/data-binder/element-binding/base-model-class.js +585 -0
  172. package/legacy/es5/modules/olderversions/data-binder/model-binding/base-data-binder-class.js +353 -0
  173. package/legacy/es5/modules/olderversions/data-binder/model-binding/base-model-class.js +604 -0
  174. package/legacy/es5/modules/olderversions/data-binder-update-watcher.js +640 -0
  175. package/legacy/es5/modules/olderversions/data-tracker.js +187 -0
  176. package/legacy/es5/modules/olderversions/event-update.js +666 -0
  177. package/legacy/es5/modules/olderversions/nav-link.js +119 -0
  178. package/legacy/es5/modules/olderversions/router-with-templates-1.js +785 -0
  179. package/legacy/es5/modules/olderversions/router-with-templates.js +701 -0
  180. package/legacy/es5/modules/prototypes/ajax.js +657 -0
  181. package/legacy/es5/modules/prototypes/atom.js +65 -0
  182. package/legacy/es5/modules/prototypes/component.js +972 -0
  183. package/legacy/es5/modules/prototypes/data-binder.js +1089 -0
  184. package/legacy/es5/modules/prototypes/data.js +1290 -0
  185. package/legacy/es5/modules/prototypes/html-builder.js +414 -0
  186. package/legacy/es5/modules/prototypes/layout.js +879 -0
  187. package/legacy/es5/modules/router.js +1680 -0
  188. package/legacy/es5/modules/state.js +274 -0
  189. package/package.json +8 -3
  190. package/update +16 -0
@@ -0,0 +1,353 @@
1
+ /* base framework module */
2
+ (function()
3
+ {
4
+ "use strict";
5
+
6
+ /*
7
+ DataBinder
8
+
9
+ this create a data bind module to add
10
+ two way data binding to base models.
11
+
12
+ no initialize but removeal needed
13
+ jsfiddle https://jsfiddle.net/kz383fq8/164/
14
+
15
+ */
16
+ var DataBinder = function(attr)
17
+ {
18
+ this.attr = attr || 'data-bind';
19
+ /* this will create a new pub sub object
20
+ that will be used to propagate the changes */
21
+ this.pubSub = new DataPubSub();
22
+ };
23
+
24
+ DataBinder.prototype =
25
+ {
26
+ constructor: DataBinder,
27
+
28
+ setup: function()
29
+ {
30
+ this.setupEvents();
31
+ this.pubSub.callBack = base.bind(this, this.messageChange);
32
+ },
33
+
34
+ /* this will setup the binder events that will
35
+ use the pub sub object to modify the bound elements */
36
+ bind: function(model)
37
+ {
38
+ var modelId = model.getModelId(),
39
+ message = modelId + ":change";
40
+
41
+ /* we need to setup the pub sub on call back
42
+ to modify our elements with the new data value */
43
+ var self = this;
44
+ this.pubSub.on( message, function(evt, prop, value, committer)
45
+ {
46
+ self.updateElements(modelId, prop, value, committer);
47
+ });
48
+ },
49
+
50
+ /* this will setup the binder events that will
51
+ use the pub sub object to modify the bound elements */
52
+ unbind: function(model)
53
+ {
54
+ var id = model.getModelId(),
55
+ message = id + ":change";
56
+
57
+ this.pubSub.remove(message);
58
+ },
59
+
60
+ messageChange: function(message, prop, value, committer)
61
+ {
62
+ var parts = message.split(':');
63
+ var modelId = parts[0];
64
+
65
+ this.updateElements(modelId, prop, value, committer);
66
+ },
67
+
68
+ /* this will update all elements with the model id
69
+ attr.
70
+ @param (string) modelId
71
+ @param (string) prop
72
+ @param (mixed) value
73
+ @param (object) committer */
74
+ updateElements: function(modelId, prop, value, committer)
75
+ {
76
+ var elements = document.querySelectorAll("[" + this.attr + "='" + modelId + '.' + prop + "']");
77
+ if(elements)
78
+ {
79
+ for(var i = 0, len = elements.length; i < len; i++ )
80
+ {
81
+ var element = elements[i];
82
+ if(committer !== element);
83
+ {
84
+ this.set(element, value);
85
+ }
86
+ }
87
+ }
88
+ },
89
+
90
+ /* this will set a value on an elememnt.
91
+ @param (object) element
92
+ @param (mixed) value */
93
+ set: function(element, value)
94
+ {
95
+ if(element && typeof element === 'object')
96
+ {
97
+ var tagName = element.tagName.toLowerCase();
98
+ if (tagName === "input" || tagName === "textarea" || tagName === "select" )
99
+ {
100
+ var type = element.type;
101
+ if(type && (type === 'checkbox' || type === 'radio'))
102
+ {
103
+ element.checked = value;
104
+ }
105
+ else
106
+ {
107
+ element.value = value;
108
+ }
109
+ }
110
+ else
111
+ {
112
+ element.textContent = value;
113
+ }
114
+ }
115
+ },
116
+
117
+ /* this will get a value on an elememnt.
118
+ @param (object) element
119
+ @param (mixed) value
120
+ @return (mixed) the element value */
121
+ get: function(element)
122
+ {
123
+ var value = '';
124
+ if(element && typeof element === 'object')
125
+ {
126
+ var tagName = element.tagName.toLowerCase();
127
+ if (tagName === "input" || tagName === "textarea" || tagName === "select" )
128
+ {
129
+ var type = element.type;
130
+ if(type && (type === 'checkbox' || type === 'radio'))
131
+ {
132
+ value = element.checked;
133
+ }
134
+ else
135
+ {
136
+ value = element.value;
137
+ }
138
+ }
139
+ else
140
+ {
141
+ value = element.textContent;
142
+ }
143
+ }
144
+ return value;
145
+ },
146
+
147
+ /* this will add the data bind attr on an
148
+ element for a model property.
149
+ @param (object) element
150
+ @param (object) model
151
+ @param (string) prop */
152
+ bindElement: function(element, model, prop)
153
+ {
154
+ /* this will add the data binding
155
+ attr to out element so it will subscribe to
156
+ the two model changes */
157
+ var modelId = model.getModelId();
158
+ base.attr(element, this.attr, modelId + '.' + prop);
159
+
160
+ /* we want to get the staring value of the
161
+ model and set it on our element */
162
+ var value = model.get(prop);
163
+ if(typeof value !== 'undefined')
164
+ {
165
+ this.set(element, value);
166
+ }
167
+ },
168
+
169
+ /* this will publish a change to the data binder.
170
+ @param (string) modleId
171
+ @param (string) attrName = the model prop name
172
+ @param (mixed) the prop value
173
+ @param (object) the object committing the change */
174
+ publish: function(modelId, attrName, value, committer)
175
+ {
176
+ var message = modelId + ':change';
177
+ this.pubSub.publish(message, attrName, value, committer);
178
+ },
179
+
180
+ onChange: function(modelId, callBack)
181
+ {
182
+ var message = modelId + ':change';
183
+ this.pubSub.on(message, callBack);
184
+ },
185
+
186
+ /* this will setup the on change handler and
187
+ add the events. this needs to be setup before adding
188
+ the events. */
189
+ changeHandler: null,
190
+ setupEvents: function()
191
+ {
192
+ var dataAttr = this.attr;
193
+ var isDataBound = function(element)
194
+ {
195
+ if(element)
196
+ {
197
+ var value = base.data(element, dataAttr);
198
+ if(value)
199
+ {
200
+ var parts = value.split(".");
201
+ if(parts.length)
202
+ {
203
+ return {
204
+ id: parts[0],
205
+ value: parts[1]
206
+ };
207
+ }
208
+ }
209
+ }
210
+ return false;
211
+ };
212
+
213
+ /* this will create a closure scope to the object
214
+ by using a local call back function. */
215
+ var self = this, pubSub = this.pubSub;
216
+ this.changeHandler = function(evt)
217
+ {
218
+ if(evt.type === 'keyup')
219
+ {
220
+ var blockedKeys = [
221
+ 17, //ctrl
222
+ 9, //tab
223
+ 16, //shift
224
+ 18, //alt
225
+ 20, //caps lock
226
+ 37, //arrows
227
+ 38,
228
+ 39,
229
+ 40
230
+ ];
231
+ /* this will check to block ctrl, shift or alt +
232
+ buttons */
233
+ if(evt.ctrlKey !== false || evt.shiftKey !== false || evt.altKey !== false || base.inArray(blockedKeys, evt.keyCode) !== -1)
234
+ {
235
+ return true;
236
+ }
237
+ }
238
+
239
+ var target = evt.target || evt.srcElement;
240
+ var settings = isDataBound(target);
241
+ if(settings)
242
+ {
243
+ var prop = settings.value;
244
+ if(prop && prop !== "")
245
+ {
246
+ pubSub.publish(settings.id + ':change', prop, self.get(target), target);
247
+ }
248
+ }
249
+ evt.stopPropagation();
250
+ };
251
+
252
+ this.addEvents();
253
+ },
254
+
255
+ /* this will add the binder events */
256
+ addEvents: function()
257
+ {
258
+ base.on(["change", "keyup"], document, this.changeHandler, false);
259
+ },
260
+
261
+ /* this will remove the binder events */
262
+ removeEvents: function()
263
+ {
264
+ base.off(["change", "keyup"], document, this.changeHandler, false);
265
+ }
266
+ };
267
+
268
+ /*
269
+ DataPubSub
270
+
271
+ this will create a pub sub object
272
+ to allow messages to be subscribed to and
273
+ publish changes that will be pushed to the
274
+ subscribers.
275
+ */
276
+ var DataPubSub = function()
277
+ {
278
+ this.callBacks = {};
279
+ };
280
+
281
+ DataPubSub.prototype =
282
+ {
283
+ constructor: DataPubSub,
284
+
285
+ /* this will get the subscriber array for the
286
+ message or create a new subscriber array if none
287
+ is setup already.
288
+ @param (string) msg
289
+ @return (array) subscriber array */
290
+ get: function(msg)
291
+ {
292
+ var callBacks = this.callBacks;
293
+ return (callBacks[msg] = callBacks[msg] || []);
294
+ },
295
+
296
+ reset: function()
297
+ {
298
+ this.callBacks = [];
299
+ },
300
+
301
+ on: function(msg, callBack)
302
+ {
303
+ var list = this.get(msg);
304
+ list.push(callBack);
305
+ },
306
+
307
+ off: function(msg, callBack)
308
+ {
309
+ var list = this.get(msg);
310
+ var index = base.inArray(list, callBack);
311
+ if(index > -1)
312
+ {
313
+ list.splice(index, 1);
314
+ }
315
+ },
316
+
317
+ remove: function(msg)
318
+ {
319
+ var list = this.get(msg);
320
+ var index = base.inArray(this.callBacks, list);
321
+ if(index > -1)
322
+ {
323
+ list.splice(this.callBacks, 1);
324
+ }
325
+ },
326
+
327
+ callBack: null,
328
+
329
+ publish: function(msg)
330
+ {
331
+ var list = this.get(msg);
332
+ for ( var i = 0, len = list.length; i < len; i++ )
333
+ {
334
+ list[i].apply(this, arguments);
335
+ }
336
+
337
+ if(typeof this.callBack === 'function')
338
+ {
339
+ var params = [msg];
340
+ for(var i = 0, length = arguments.length; i < length; i++)
341
+ {
342
+ params[i] = arguments[i];
343
+ }
344
+ this.callBack.apply(null, params);
345
+ }
346
+ }
347
+ };
348
+
349
+ base.extend.DataPubSub = DataPubSub;
350
+
351
+ var dataBinder = base.extend.DataBinder = new DataBinder();
352
+ dataBinder.setup();
353
+ })();