add new Fieldfy class to manage forms (minimal), new user 'info' form
[brisk.git] / web / fieldify.js
1
2 // fieldsdescr = { name: { type: 'typename' }, ... }
3 function Fieldify(ancestor, fieldsdescr)
4 {
5     this.ancestor = ancestor;
6     
7     this.field = new Array();
8     for (k in fieldsdescr) {
9         this.field[k] = fieldsdescr[k];
10     }
11 }
12
13 Fieldify.prototype = {
14     ancestor: null,
15     field: null,
16     
17     visible: function(is_visible) {
18         this.ancestor.style.visibility = (is_visible ? "visible" : "hidden" );
19     },
20
21     // { 'name': 'value' }
22     populate: function(field_values)
23     {
24         for (k in this.field) {
25             if (this.field[k].type == 'value') {
26                 this.fld_value_set(k, field_values[k]);
27             }
28             else if (this.field[k].type == 'radio') {
29                 this.fld_radio_set(k, field_values[k]);
30             }
31         }
32     },
33
34     fld_value_set: function(name, value)
35     {
36         console.log(name + "=" + value);
37         this.ancestor.getElementsByClassName(name + '_id')[0].innerHTML = value;
38     },
39     
40     fld_radio_set: function(name, value)
41     {
42         var arr = this.ancestor.getElementsByClassName(name + '_id');
43
44         console.log(name + "=" + value);
45
46         for (k in arr) {
47             if (arr[k].value == value)
48                 arr[k].checked = true;
49             else 
50                 arr[k].checked = false;
51         }
52     },
53     tap: null
54 }