* luci/libs/cbi: implement file browse fields
[project/luci.git] / libs / cbi / htdocs / luci-static / resources / cbi.js
1 var cbi_d = [];
2
3 function cbi_d_add(field, dep, next) {
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                                 "node": obj,
16                                 "id": field,
17                                 "parent": obj.parentNode.id,
18                                 "next": next,
19                                 "deps": []
20                         };
21                         cbi_d.unshift(entry);
22                 }
23                 entry.deps.push(dep)
24         }
25 }
26
27 function cbi_d_checkvalue(target, ref) {
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 == ref)
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_checkvalue(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                 var next  = document.getElementById(entry.next)
61                 var node  = document.getElementById(entry.id)
62                 var parent = document.getElementById(entry.parent)
63
64                 if (node && node.parentNode && !cbi_d_check(entry.deps)) {
65                         node.parentNode.removeChild(node);
66                         state = (state || !node.parentNode)
67                 } else if ((!node || !node.parentNode) && cbi_d_check(entry.deps)) {
68                         if (!next) {
69                                 parent.appendChild(entry.node);
70                         } else {
71                                 next.parentNode.insertBefore(entry.node, next);
72                         }
73                         state = (state || (node && node.parentNode))
74                 }
75         }
76         if (state) {
77                 cbi_d_update();
78         }
79 }
80
81 function cbi_bind(obj, type, callback, mode) {
82         if (typeof mode == "undefined") {
83                 mode = false;
84         }
85         if (!obj.addEventListener) {
86                 ieCallback = function(){
87                         var e = window.event;
88                         if (!e.target && e.srcElement) {
89                                 e.target = e.srcElement;
90                         };
91                         e.target['_eCB' + type + callback] = callback;
92                         e.target['_eCB' + type + callback](e);
93                         e.target['_eCB' + type + callback] = null;
94                 };
95                 obj.attachEvent('on' + type, ieCallback);
96         } else {
97                 obj.addEventListener(type, callback, mode);
98         }
99         return obj;
100 }
101
102 function cbi_combobox(id, values, def, man) {
103         var selid = "cbi.combobox." + id;
104         if (document.getElementById(selid)) {
105                 return
106         }
107
108         var obj = document.getElementById(id)
109         var sel = document.createElement("select");
110         sel.id = selid;
111         sel.className = 'cbi-input-select';
112         if (obj.nextSibling) {
113                 obj.parentNode.insertBefore(sel, obj.nextSibling);
114         } else {
115                 obj.parentNode.appendChild(sel);
116         }
117
118         if (!values[obj.value]) {
119                 if (obj.value == "") {
120                         var optdef = document.createElement("option");
121                         optdef.value = "";
122                         optdef.appendChild(document.createTextNode(def));
123                         sel.appendChild(optdef);
124                 } else {
125                         var opt = document.createElement("option");
126                         opt.value = obj.value;
127                         opt.selected = "selected";
128                         opt.appendChild(document.createTextNode(obj.value));
129                         sel.appendChild(opt);
130                 }
131         }
132
133         for (var i in values) {
134                 var opt = document.createElement("option");
135                 opt.value = i;
136
137                 if (obj.value == i) {
138                         opt.selected = "selected";
139                 }
140
141                 opt.appendChild(document.createTextNode(values[i]));
142                 sel.appendChild(opt);
143         }
144
145         var optman = document.createElement("option");
146         optman.value = "";
147         optman.appendChild(document.createTextNode(man));
148         sel.appendChild(optman);
149
150         obj.style.display = "none";
151
152         cbi_bind(sel, "change", function() {
153                 if (sel.selectedIndex == sel.options.length - 1) {
154                         obj.style.display = "inline";
155                         sel.parentNode.removeChild(sel);
156                         obj.focus();
157                 } else {
158                         obj.value = sel.options[sel.selectedIndex].value;
159                 }
160         })
161 }
162
163 function cbi_combobox_init(id, values, def, man) {
164         var obj = document.getElementById(id);
165         cbi_bind(obj, "blur", function() {
166                 cbi_combobox(id, values, def, man)
167         });
168         cbi_combobox(id, values, def, man);
169 }
170
171 function cbi_filebrowser(id, url, defpath) {
172         var field   = document.getElementById(id);
173         var browser = window.open(
174                 url + ( field.value || defpath || '' ) + '?field=' + id,
175                 "luci_filebrowser", "width=300,height=400,left=100,top=200,scrollbars=yes"
176         );
177
178         browser.focus();
179 }