Allow updating the filters separately
[misc/kostenrechnung] / lib / functions.js
index 07af498..2de1400 100644 (file)
@@ -6,7 +6,13 @@ function ajax_request_callback(req)
     if (req.readyState == 4 && req.status == 200) {
        var data = json_parse(req.responseText);
 
-       if (req.oncomplete)
+       if (typeof data.error == 'string') {
+           if (typeof data.errormsg == 'string')
+               error(data.errormsg);
+           else
+               error('Fehler im AJAX-Backend');
+           alert("Fehler im AJAX-Backend:\n" + data.error);
+       } else if (req.oncomplete)
            req.oncomplete(data);
     }
 }
@@ -21,11 +27,29 @@ function ajax_request(func,params,oncomplete)
     req.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
     req.setRequestHeader("Content-length", params.length);
     req.setRequestHeader("Connection", "close");
-    if (typeof oncomplete == 'function') {
-       req.onreadystatechange = function() { ajax_request_callback(req); }
+    req.onreadystatechange = function() { ajax_request_callback(req); }
+    if (typeof oncomplete == 'function')
        req.oncomplete = oncomplete;
-    }
     req.send(params);
+    info('');
+}
+
+function info(msg)
+{
+    var status = document.getElementById('status');
+    if (!status) return;
+
+    status.innerHTML = msg;
+    status.className = 'status_ok';
+}
+
+function error(msg)
+{
+    var status = document.getElementById('status');
+    if (!status) return;
+
+    status.innerHTML = msg;
+    status.className = 'status_error';
 }
 
 function set_value(id, value)
@@ -34,30 +58,123 @@ function set_value(id, value)
     if (!obj) return;
 
     if (obj.nodeName.toLowerCase() == 'input'
+       && obj.type.toLowerCase() == 'checkbox')
+       if (value) obj.checked = true;
+       else obj.checked = false;
+    else if (obj.nodeName.toLowerCase() == 'input'
        || obj.nodeName.toLowerCase() == 'textarea')
        obj.value = value;
     else if (obj.nodeName.toLowerCase() == 'span')
        obj.innerHTML = value;
-    else if (obj.nodeName.toLowerCase() == 'select')
+    else if (obj.nodeName.toLowerCase() == 'select') {
        for (var i=0; i < obj.options.length; i++)
            if (obj.options[i].value == value)
                obj.selectedIndex = i;
+    } else
+       obj.innerHTML = value;
+}
+
+function setvar(obj, name, callback, status)
+{
+    if (!obj.options[obj.selectedIndex].value.length)
+       value = -1;
+    else
+       value = obj.options[obj.selectedIndex].value;
+
+    var source = document.getElementById('source');
+
+    if (!source) return false;
+
+    var parms = 'source=' + source.innerHTML + '&name=' + name + '&value=' + value;
+
+    ajax_request('setvar', parms, callback);
+
+    if (typeof status == 'function')
+       status(obj,value,obj.options[obj.selectedIndex].innerHTML);
+}
+
+function get_info(name, values, callback)
+{
+    var source = document.getElementById('source');
+
+    if (!source) return false;
+
+    var parms = 'source=' + source.innerHTML + '&name=' + name;
+    for (key in values)
+       parms += '&' + key + '=' + values[key];
+
+    ajax_request('info', parms, callback);
 }
 
 /*
  * Form functions
  */
+function form_init()
+{
+    var form = document.getElementById('form_edit');
+
+    if (!form) return;
+
+    for (var i=0; i<form.children.length; i++)
+       if (form.children[i].tagName.toLowerCase() == 'input'
+           && form.children[i].type.toLowerCase() == 'password')
+           form.children[i].value = '';
+}
+
+function save_callback(data)
+{
+    info('Datensatz gespeichert');
+    grid_update(grid);
+}
+
+function delete_callback(data)
+{
+    info('Datensatz gelöscht');
+    grid_update(grid);
+}
+
 function form_save(obj)
 {
+    info('');
+    ajax_request('save', Form.serialize(obj.form), save_callback);
     return false;
 }
 
+function form_insert(obj)
+{
+    info('');
+    ajax_request('insert', Form.serialize(obj.form), save_callback);
+    return false;
+}
+
+function form_delete(obj)
+{
+    var id = document.getElementById('edit_id');
+    var source = document.getElementById('edit_source');
+    info('');
+    var params = 'id='+id.value + '&source='+source.value;
+    ajax_request('delete', params, delete_callback);
+    return false;
+}
+
+/*
+ * Table functions
+ */
 function details_callback(data)
 {
     for (var id in data)
        set_value('detail_'+id, data[id]);
 }
 
+function fetch_callback(data)
+{
+    for (var id in data)
+       set_value('edit_'+id, data[id]);
+
+    var status = document.getElementById('form_status');
+    status.innerHTML = 'Geändert: ' + data.sys_edit + ' von ' + data.sys_user;
+}
+
 /*
  * Rico functions
  */
@@ -73,12 +190,85 @@ function gridDrillDown(e)
     var value = cell.innerHTML;
 
     if (document.getElementById('details')) {
-       var params = 'mask=' + grid.tableId.substr(5) + '&id=' + value;
+       var params = 'source=' + grid.tableId.substr(5) + '&id=' + value;
        ajax_request('details', params, details_callback);
     }
 
     if (document.getElementById('form_edit')) {
-       var params = 'mask=' + grid.tableId.substr(5) + '&id=' + value;
-       ajax_request('fetch', params, false);
+       var params = 'source=' + grid.tableId.substr(5) + '&id=' + value;
+       ajax_request('fetch', params, fetch_callback);
+    }
+}
+
+/* Update an existing grid
+ *
+ * grid is a live grid
+ * filter is the array index of the $table_filters array in mskdef
+ * value is the value applied to the filter
+ */
+function grid_update(grid, filter, value)
+{
+    if (grid === undefined)
+       return;
+
+    if (filter !== undefined && filter !== false)
+               grid.buffer.options.requestParameters = ['w'+filter+'=' + value];
+    grid.buffer.clear();
+    grid.buffer.setTotalRows(0);
+    grid.buffer.foundRowCount = false;
+    grid.cancelMenu();
+    grid.ClearSelection();
+    grid.setImages();
+    if (grid.bookmark) grid.bookmark.innerHTML="&nbsp;";
+    grid.clearRows();
+    grid.buffer.fetch(-1);
+}
+
+function grid_update_filters(grid)
+{
+    var todo = false;
+    for (var c=0; c < grid.headerColCnt; c++) {
+       var fmt = grid.columns[c].format;
+       if (typeof fmt.filterUI != 'string') continue;
+       if (fmt.filterUI != 's') continue;
+       $(grid.filterId(c)).options.length = 1;
+
+       var options = {};
+       Object.extend(options, grid.buffer.ajaxOptions);
+       var colnum = typeof(fmt.filterCol)=='number' ? fmt.filterCol : c;
+
+       options.parameters = 'id='+grid.tableId+'&distinct='+colnum;
+       options.onComplete = grid.filterValuesUpdate.bind(grid,c);
+       new Ajax.Request(grid.buffer.dataSource, options);
+    }
+}
+
+var calendars = new Array();
+function calendar_callback(value)
+{
+    this.input.value = value;
+}
+
+function calendar(name,event)
+{
+    var input = document.getElementById(name);
+    if (!input) return;
+
+    if (calendars[name] == undefined) {
+        calendars[name] = new Rico.CalendarControl('calendar_'+name,
+                                                  {startAt: 1,
+                                                   dateFmt: 'dd.mm.yyyy',
+                                                   showWeekNumber: 1});
+        calendars[name].atLoad();
+        calendars[name].returnValue = calendar_callback;
+        RicoUtil.positionCtlOverIcon(calendars[name].container,input);
+        calendars[name].open(input.value);
+       calendars[name].input = input;
+    } else {
+        if (Element.visible(calendars[name].container))
+            calendars[name].close();
+        else
+            calendars[name].open(input.value);
     }
+    Event.stop(event);
 }