-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdirty-checking.js
87 lines (72 loc) · 2.39 KB
/
dirty-checking.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
// requires jquery
var db = {};
db.model = {};
document.addEventListener('DOMContentLoaded', function() {
var watchList = [];
db.rerender = function() {
watchList.forEach(function(watchedItem) {
if (watchedItem.oldValue !== db.model[watchedItem.modelProperty]) {
watchedItem.element[watchedItem.valueType] = db.model[watchedItem.modelProperty];
watchedItem.oldValue = db.model[watchedItem.modelProperty];
}
});
};
compileDom(document);
function compileDom(root) {
dbBind(root);
dbEvent(root);
dbTemplate(root);
}
function dbBind(root) {
var dbBindElements = root.querySelectorAll('[db-bind]');
Array.prototype.forEach.call(dbBindElements, function(element) {
var modelProperty = element.attributes.getNamedItem('db-bind').value;
var valueType = element.nodeName === 'INPUT' ? 'value' : 'innerHTML';
watchList.push({
oldValue: null,
modelProperty: modelProperty,
element: element,
valueType: valueType
});
if (element.nodeName === 'INPUT') {
element.addEventListener('keydown', function(e) {
setTimeout(function() {
// using setTimeout because the updated value of the element isn't otherwise available
db.model[modelProperty] = element[valueType];
db.rerender();
}, 0);
});
}
});
}
function dbEvent(root) {
var events = ['click', 'dbclick', 'keydown'];
events.forEach(function(event) {
var attributeName = 'db-' + event;
var selector = '[' + attributeName + ']';
var elements = root.querySelectorAll(selector);
Array.prototype.forEach.call(elements, function(element) {
element.addEventListener(event, function(e) {
var cbName = element.attributes.getNamedItem(attributeName).value;
var cb = db.model[cbName];
cb();
db.rerender();
});
});
});
}
function dbTemplate(root) {
var dbTemplateElements = root.querySelectorAll('[db-template]');
Array.prototype.forEach.call(dbTemplateElements, function(element) {
var templateUrl = element.attributes.getNamedItem('db-template').value;
$.get(templateUrl, function(data) {
$(element).html(data);
compileDom(element);
db.rerender();
});
});
}
});
window.addEventListener('load', function() {
db.rerender();
});