1 function show_message(text, timeout)
3 if (typeof timeout == 'undefined') timeout = 3;
5 var div = $('#message_div');
8 div.attr('id', 'message_div').css('z-index','1000');
10 $(document.body).append(div);
17 window.setTimeout(hide_message,timeout*1000);
20 function hide_message(text)
22 $('#message_div').hide();
25 var errorwindow = false;
26 function show_error(text, timeout)
29 errorwindow = new Popup('Fehler', '500px', false, '<div id="errorbody"></div>');
30 errorwindow.setId('errorwindow');
31 $('#errorwindow').css('z-index','1000');
32 errorwindow.centerPopup();
34 errorwindow.openPopup();
37 $('#errorbody').html(text);
39 if (typeof timeout != 'undefined')
40 window.setTimeout(function(){errorwindow.closePopup()},timeout*1000);
43 function editable_callback(data)
46 var elem = $(data.$el);
47 var route = elem.attr('route');
48 var item_id = elem.attr('item_id');
49 if (typeof(route) == 'string' && typeof(item_id) == 'string')
52 name: elem.attr('name'),
53 content: data.content});
59 function make_editable(selector)
61 var list = $(selector);
66 callback: editable_callback
70 $.fn.ltag = function() {
71 return this.prop("tagName").toLowerCase();
74 $.fn.center = function () {
75 this.css("position","absolute");
76 this.css("top", Math.max(0, (($(window).height() - $(this).outerHeight()) / 2) +
77 $(window).scrollTop()) + "px");
78 this.css("left", Math.max(0, (($(window).width() - $(this).outerWidth()) / 2) +
79 $(window).scrollLeft()) + "px");
83 $.invoke = function(name, parms, callback) {
84 if (typeof(parms) == 'string' && parms.length)
85 parms = 'route='+name+'&'+parms;
86 else if (typeof(parms) == 'object')
87 parms['route'] = name;
89 parms = 'route='+name;
96 if (data.redirect_login) {
97 show_message(data.error, 5);
98 setTimeout(function(){window.location.href = '/';}, 5000);
101 return show_error(data.error);
103 return show_error('Fehler im Backend zu "'+name+'" aufgetreten');
105 if (typeof(data.html) == 'object')
106 for (id in data.html) {
107 var elem = $('#'+id);
109 elem.html(data.html[id]);
112 if (typeof(data.values) == 'object')
113 for (id in data.values) {
114 var elem = $('#'+id);
116 elem.val(data.values[id]);
119 if (typeof(callback) == 'function')
120 return callback(data);
125 function Popup(title, width, height, body) {
126 return this.initialize(title, width, height, body);
130 initialize: function(title, width, height, body)
132 this.createPopup(width, height);
133 if (title) this.setTitle(title);
134 if (body) this.setBody(body);
138 createPopup: function(width, height)
140 this.popup = $('<div class="popup">');
141 this.popup.css('width', width ? width : 'auto');
142 this.popup.css('height', height ? height : 'auto');
143 this.popup.hide().css('z-index', '1000');
144 var titlediv = $('<div class="popup_title" style="position:relative;">');
145 titlediv.append($('<p class="popup_title"></p>'));
147 var closeimg = $('<img src="/pix/close.gif" title="Close">');
148 titlediv.append(closeimg);
150 this.popup.append(titlediv);
152 this.popup.append($('<div class="popup_body" style="clear:both;">'));
153 $('body').append(this.popup);
155 this.popup.udraggable({'handle': 'div.popup_title'});
156 this.popup.find('div.popup_title img').bind('click', this.closePopup.bind(this));
159 openPopup: function()
164 centerPopup: function()
166 this.popup.center().show();
169 closePopup: function()
174 setId: function(name)
176 this.popup.attr('id', name);
179 setTitle: function(title)
181 this.popup.find('div.popup_title p.popup_title').html(title);
184 setBody: function(body)
186 this.popup.find('div.popup_body').html(body);