227e33269d6bd8fbc40f6bafea335278933fe681
[project/luci.git] / libs / cbi / htdocs / luci-static / resources / cbi.js
1 var cbi_d = [];
2
3 function cbi_d_add(field, dep) {
4 var obj = document.getElementById(field);
5 if (obj) {
6 var entry
7 for (var i=0; i<cbi_d.length; i++) {
8 if (cbi_d[i].id == field) {
9 entry = cbi_d[i];
10 break;
11 }
12 }
13 if (!entry) {
14 entry = {
15 "id": field,
16 "node": obj,
17 "parent": obj.parentNode,
18 "next": obj.nextSibling,
19 "deps": []
20 };
21 cbi_d.unshift(entry);
22 }
23 entry.deps.push(dep)
24 }
25 }
26
27 function cbi_d_value(target) {
28 var t = document.getElementById(target);
29 var value
30
31 if (!t || !t.value) {
32 value = "";
33 } else {
34 value = t.value;
35
36 if (t.type == "checkbox") {
37 value = t.checked ? value : "";
38 }
39 }
40
41 return value
42 }
43
44 function cbi_d_check(deps) {
45 for (var i=0; i<deps.length; i++) {
46 var istat = true
47 for (var j in deps[i]) {
48 istat = (istat && cbi_d_value(j) == deps[i][j])
49 }
50 if (istat) {
51 return true
52 }
53 }
54 }
55
56 function cbi_d_update() {
57 var state = false;
58 for (var i=0; i<cbi_d.length; i++) {
59 var entry = cbi_d[i];
60 if (entry.node.parentNode && !cbi_d_check(entry.deps)) {
61 entry.parent.removeChild(entry.node);
62 state = (state || !entry.node.parentNode)
63 } else if (!entry.node.parentNode && cbi_d_check(entry.deps)) {
64 if (!entry.next) {
65 entry.parent.appendChild(entry.node);
66 } else {
67 entry.parent.insertBefore(entry.node, entry.next);
68 }
69 state = (state || entry.node.parentNode)
70 }
71 }
72 if (state) {
73 cbi_d_update();
74 }
75 }
76
77 function cbi_bind(obj, type, callback, mode) {
78 if (typeof mode == "undefined") {
79 mode = false;
80 }
81 if (!obj.addEventListener) {
82 ieCallback = function(){
83 var e = window.event;
84 if (!e.target && e.srcElement) {
85 e.target = e.srcElement;
86 };
87 e.target['_eCB' + type + callback] = callback;
88 e.target['_eCB' + type + callback](e);
89 e.target['_eCB' + type + callback] = null;
90 };
91 obj.attachEvent('on' + type, ieCallback);
92 } else {
93 obj.addEventListener(type, callback, mode);
94 }
95 return obj;
96 }
97
98 function cbi_combobox(id, values, def, man) {
99 var obj = document.getElementById(id)
100 var sel = document.createElement("select");
101 if (obj.nextSibling) {
102 obj.parentNode.insertBefore(sel, obj.nextSibling);
103 } else {
104 obj.parentNode.appendChild(sel);
105 }
106
107 if (!values[obj.value]) {
108 if (obj.value == "") {
109 var optdef = document.createElement("option");
110 optdef.value = "";
111 optdef.appendChild(document.createTextNode(def));
112 sel.appendChild(optdef);
113 } else {
114 var opt = document.createElement("option");
115 opt.value = obj.value;
116 opt.selected = "selected";
117 opt.appendChild(document.createTextNode(obj.value));
118 sel.appendChild(opt);
119 }
120 }
121
122 for (var i in values) {
123 var opt = document.createElement("option");
124 opt.value = i;
125
126 if (obj.value == i) {
127 opt.selected = "selected";
128 }
129
130 opt.appendChild(document.createTextNode(values[i]));
131 sel.appendChild(opt);
132 }
133
134 var optman = document.createElement("option");
135 optman.value = "";
136 optman.appendChild(document.createTextNode(man));
137 sel.appendChild(optman);
138
139 obj.style.display = "none";
140
141 cbi_bind(sel, "change", function() {
142 if (sel.selectedIndex == sel.options.length - 1) {
143 obj.style.display = "inline";
144 sel.parentNode.removeChild(sel);
145 obj.focus();
146 } else {
147 obj.value = sel.options[sel.selectedIndex].value;
148 }
149 })
150 }
151
152 function cbi_combobox_init(id, values, def, man) {
153 var obj = document.getElementById(id);
154 cbi_bind(obj, "blur", function() {
155 cbi_combobox(id, values, def, man)
156 });
157 cbi_combobox(id, values, def, man);
158 }