ActionBar: separator implementiert und ScriptButton in Submit gemergt
[kivitendo-erp.git] / js / kivi.ActionBar.js
1 namespace('kivi', function(k){
2   'use strict';
3
4   var CLASSES = {
5     disabled: 'layout-actionbar-action-disabled'
6   }
7
8    k.ActionBarAction = function(e) {
9      var data = $(e).data('action');
10      if (undefined === data) return;
11
12      if (data.disabled) {
13        $(e).addClass(CLASSES.disabled);
14      }
15
16      if (data.call || data.submit) {
17        $(e).click(function(event) {
18          var $hidden, key, func, check;
19          if ($(e).hasClass(CLASSES.disabled)) return;
20          if (data.checks) {
21            for (var i=0; i < data.checks.length; i++) {
22              check = data.checks[i];
23              func = kivi.get_function_by_name(check);
24              if (!func) console.log('Cannot find check function: ' + check);
25              if (!func()) return;
26            }
27          }
28          if (data.confirm && !confirm(data.confirm)) return;
29          if (data.call) {
30            func = kivi.get_function_by_name(data.call[0]);
31            func.apply(document, data.call.slice(1))
32          }
33          if (data.submit) {
34            var form   = data.submit[0];
35            var params = data.submit[1];
36            for (key in params) {
37              $hidden = $('<input type=hidden>')
38              $hidden.attr('name', key)
39              $hidden.attr('value', params[key])
40              $(form).append($hidden)
41            }
42            $(form).submit();
43          }
44        });
45      }
46    }
47 });
48
49 $(function(){
50   $('div.layout-actionbar .layout-actionbar-action').each(function(_, e) {
51     kivi.ActionBarAction(e);
52   });
53 });