4 * Copyright (C) 2006-2015 Matteo Nastasi
5 * mailto: nastasi@alternativeoutput.it
6 * matteo.nastasi@milug.org
7 * web: http://www.alternativeoutput.it
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful, but
15 * WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABLILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 * General Public License for more details. You should have received a
18 * copy of the GNU General Public License along with this program; if
19 * not, write to the Free Software Foundation, Inc, 59 Temple Place -
20 * Suite 330, Boston, MA 02111-1307, USA.
25 var EXIT_BAN_TIME = 900;
26 var cookiepath = "/brisk/";
28 var mlang_commons = { 'imgload_a' : { 'it' : 'Immagini caricate ',
29 'en' : 'Loaded images ' },
30 'imgload_b' : { 'it' : '%.',
32 'gamleav' : { 'it' : 'Sei sicuro di volere lasciare questa mano?' ,
33 'en' : 'Are you sure to leave this game?' },
34 'brileav' : { 'it' : ' Vuoi veramente abbandonare la briscola ?\n(clicca annulla o cancel se vuoi ricaricare la briscola)',
35 'en' : ' Are you really sure to leave briscola ?\n(click cancel yo reload it)' },
36 'brireco' : { 'it' : 'Ripristino della briscola fallito, per non perdere la sessione ricaricare la pagina manualmente.',
37 'en' : 'Recovery of briscola failed, to keep the current session reload the page manually.' },
38 'btn_sit' : { 'it' : 'Mi siedo.',
40 'btn_exit' : { 'it' : 'Esco.',
42 'tit_list' : { '0' : { 'it' : '',
44 '1' : { 'it' : '(solo aut.)',
45 'en' : '(only aut.)' },
46 '2' : { 'it' : '(isolam.to)',
47 'en' : '(isolation)' } },
48 'tos_refu' : { 'it' : 'Rifiutando di sottoscrivere i nuovi termini del servizio non ti sarà più possibile accedere come utente registrato al sito, sei proprio sicuro di voler rifiutare le nuove condizioni d\'uso ?',
49 'en' : 'EN Rifiutando di sottoscrivere i nuovi termini del servizio non ti sarà più possibile accedere come utente registrato al sito, sei proprio sicuro di voler rifiutare le nuove condizioni d\'uso ?'
53 function $(id) { return document.getElementById(id); }
55 function dec2hex(d, padding)
57 var hex = Number(d).toString(16);
58 padding = typeof (padding) === "undefined" || padding === null ? padding = 2 : padding;
60 while (hex.length < padding) {
67 function getStyle(x,IEstyleProp, MozStyleProp)
70 var y = x.currentStyle[IEstyleProp];
71 } else if (window.getComputedStyle) {
72 var y = document.defaultView.getComputedStyle(x,null).getPropertyValue(MozStyleProp);
77 /* replacement of setInterval on IE */
79 /*if not IE, do nothing*/
80 if(!document.uniqueID){return;};
82 /*Copy the default setInterval behavior*/
83 var nativeSetInterval = window.setInterval;
84 window.setInterval = function(fn,ms) {
86 if(arguments.length <= 2) {
87 return nativeSetInterval(fn,ms);
90 for(var i=2;i<arguments.length;i+=1) {
91 param[i-2] = arguments[i];
95 if(typeof(fn)=='function') {
97 return (function (fn,ms,param) {
98 var fo = function () {
99 fn.apply(window,param);
101 return nativeSetInterval(fo,ms);
104 else if(typeof(fn)=='string')
106 return nativeSetInterval(fn,ms);
110 throw Error('setInterval Error\nInvalid function type');
114 /*Copy the default setTimeout behavior*/
115 var nativeSetTimeout = window.setTimeout;
116 window.setTimeout = function(fn,ms) {
118 if(arguments.length <= 2) {
119 return nativeSetTimeout(fn,ms);
122 for(var i=2;i<arguments.length;i+=1) {
123 param[i-2] = arguments[i];
127 if(typeof(fn)=='function') {
129 return (function (fn,ms,param) {
130 var fo = function () {
131 fn.apply(window,param);
133 return nativeSetTimeout(fo,ms);
136 else if(typeof(fn)=='string')
138 return nativeSetTimeout(fn,ms);
142 throw Error('setTimeout Error\nInvalid function type');
148 function addEvent(obj, type, fn)
150 if (obj.addEventListener) {
151 obj.addEventListener( type, fn, false);
153 else if (obj.attachEvent) {
154 obj["e"+type+fn] = fn;
155 obj[type+fn] = function() { obj["e"+type+fn]( window.event ); }
156 obj.attachEvent( "on"+type, obj[type+fn] );
159 throw new Error("Event registration not supported");
162 function removeEvent(obj,type,fn)
164 if (obj.removeEventListener) {
165 obj.removeEventListener( type, fn, false );
167 else if (obj.detachEvent) {
168 obj.detachEvent( "on"+type, obj[type+fn] );
170 obj["e"+type+fn] = null;
174 // var card_pos = RANGE 0 <= x < cards_ea_n
176 function show_bigpict(obj, act, x, y)
180 if (arguments.length > 4)
185 big = $(obj.id+"_big"+sfx);
187 big.style.left = obj.offsetLeft + x+"px";
188 big.style.top = obj.offsetTop + y+"px";
189 big.style.visibility = "visible";
192 big.style.visibility = "hidden";
196 function rnd_int(min, max) {
197 return Math.floor(Math.random() * (max - min + 1) + min);
200 function error_images()
202 // alert("GHESEMU!");
203 setTimeout(preload_images, 2000, g_preload_img_arr, g_imgct-1);
206 function abort_images()
208 // alert("ABORTAIMAGES");
209 setTimeout(preload_images, 2000, g_preload_img_arr, g_imgct-1);
212 function unload_images()
214 // alert("ABORTAIMAGES");
215 setTimeout(preload_images, 2000, g_preload_img_arr, g_imgct-1);
218 function reset_images()
220 // alert("ABORTAIMAGES");
221 setTimeout(preload_images, 2000, g_preload_img_arr, g_imgct-1);
224 function update_images()
226 // MLANG "Immagine caricate" + g_preload_imgsz_arr[g_imgct] + "%."
227 $("imgct").innerHTML = mlang_commons['imgload_a'][g_lang]+g_preload_imgsz_arr[g_imgct]+"%.";
228 if (g_imgct+1 < g_preload_img_arr.length) {
230 setTimeout(preload_images, 100, g_preload_img_arr, g_imgct-1);
232 // $("imgct").innerHTML += "U";
235 function preload_images(arr,idx)
239 // $("imgct").innerHTML = "Stiamo caricando "+arr[idx]+"%.<br>";
240 im.onload = update_images;
241 im.onerror = error_images;
242 im.onabort = abort_images;
243 im.onunload = unload_images;
244 im.onreset = reset_images;
246 // $("imgct").innerHTML += "P";
249 function safestatus(a)
257 function createXMLHttpRequest() {
258 if (typeof(ActiveXObject) != 'undefined') { // Konqueror complain as unknown object
259 try { return new ActiveXObject("Msxml2.XMLHTTP"); } catch(e) {}
260 try { return new ActiveXObject("Microsoft.XMLHTTP"); } catch(e) {}
262 try { return new XMLHttpRequest(); } catch(e) {}
263 alert("XMLHttpRequest not supported");
267 function send_mesg(mesg, content)
269 var is_conn = (sess == "not_connected" ? false : true);
271 if (is_conn && xstm && xstm.transp_type.startsWith('websocket')) {
272 if (typeof(content) != 'undefined') {
273 mesg = mesg + content;
275 var target = window.location.href.substring(0,
276 window.location.href.lastIndexOf('/') + 1) + 'index_wr.php';
277 var ws_msg = JSON.stringify({target: target, mesg: mesg, stp:gst.st, sess:sess});
279 xstm.transp.ws.send(ws_msg);
282 var xhr_wr = createXMLHttpRequest();
284 if (typeof(content) != 'undefined') {
285 mesg = mesg + encodeURIComponent(content);
287 // alert("xhr_wr: "+xhr_wr+" is_conn: "+is_conn);
288 xhr_wr.open('GET', 'index_wr.php?&'+(is_conn ? 'sess='+sess : '')+'&stp='+gst.st+'&mesg='+mesg, (is_conn ? true : false));
289 xhr_wr.setRequestHeader("If-Modified-Since", new Date().toUTCString());
290 xhr_wr.onreadystatechange = function() { return; };
291 if (typeof(g_debug) == 'number' && g_debug > 0
292 && typeof(console) == 'object' && typeof(console.log) == 'function') {
293 var ldate = new Date();
294 console.log(ldate.getTime()+':MESG:'+mesg);
299 if (xhr_wr.responseText != null) {
300 eval(xhr_wr.responseText);
307 sync request to server
308 server_request([arg0=arg1[, arg2=arg3[, ...]]])
309 if var name == '__POST__' than all other vars will be managed as POST content
310 and the call will be a POST
312 function server_request()
314 var xhr_wr = createXMLHttpRequest();
315 var i, collect = "", post_collect = null, is_post = false;
317 if (arguments.length > 0) {
318 for (i = 0 ; i < arguments.length ; i+= 2) {
319 if (arguments[i] == "__POST__") {
326 post_collect += (post_collect == "" ? "" : "&") + arguments[i] + "=" + encodeURIComponent(arguments[i+1]);
328 collect += (i == 0 ? "" : "&") + arguments[i] + "=" + encodeURIComponent(arguments[i+1]);
331 // alert("Args: "+arguments.length);
333 var is_conn = (sess == "not_connected" ? false : true);
335 // console.log("server_request:preresp: "+xhr_wr.responseText);
338 xhr_wr.open('POST', 'index_wr.php?'+(is_conn ? 'sess='+sess+'&' : '')+collect, false);
339 xhr_wr.setRequestHeader("Content-type","application/x-www-form-urlencoded");
342 xhr_wr.open('GET', 'index_wr.php?'+(is_conn ? 'sess='+sess+'&' : '')+collect, false);
344 xhr_wr.onreadystatechange = function() { return; };
345 xhr_wr.send(post_collect);
347 if (xhr_wr.responseText != null) {
348 // console.log("server_request:resp: "+xhr_wr.responseText);
349 return (xhr_wr.responseText);
355 /* Stat: CHAT and TABLE */
357 function chatt_checksend(obj,e)
363 if(window.event) { // IE
366 else if(e.which) { // Netscape/Firefox/Opera
369 // alert("OBJ: "+obj);
370 if (keynum == 13 && obj.value != "") { // Enter
371 act_chatt(obj.value);
375 function act_chatt(value)
377 if (value.substring(0, 6) == "/info ") {
378 info_show(value.substring(6));
381 send_mesg("chatt|", value);
386 obj.disabled = false;
398 function act_sitdown(table)
400 send_mesg("sitdown|"+table);
403 function act_wakeup()
408 function act_splash()
418 function act_passwdhowto()
420 send_mesg("passwdhowto");
423 function act_mesgtoadm()
425 send_mesg("mesgtoadm");
430 act_chatt('/tav '+$('txt_in').value);
431 $('txt_in').value = '';
439 function act_placing()
441 send_mesg("placing");
444 function act_roadmap()
446 send_mesg("roadmap");
449 function act_lascio()
454 function safelascio()
457 // MLANG "Sei sicuro di volere lasciare questa mano?"
458 res = window.confirm(mlang_commons['gamleav'][g_lang]);
463 function act_logout(exitlock)
465 send_mesg("logout|"+exitlock);
468 function act_reloadroom()
470 window.onunload = null;
471 window.onbeforeunload = null;
472 document.location.assign("index.php");
475 function act_shutdown()
479 send_mesg("shutdown");
480 // while (xhr_wr.readyState != 4)
484 function postact_logout()
486 // alert("postact_logout");
491 // eraseCookie("sess");
492 document.location.assign("index.php");
496 type - 'hard' or 'soft'
497 code - if soft: accept (0), refuse (1), download (2), later (3)
498 if hard: accept (0), refuse (1), download (2)
500 function act_tosmgr(type, code, tos_curr, tos_vers)
502 if (type != "soft" && type != "hard") {
508 send_mesg("tosmgr|"+type+"|"+code+"|"+tos_curr+"|"+tos_vers);
519 function tos_confirm(val, url)
525 return (window.confirm(mlang_commons['tos_refu'][g_lang]));
528 dlm = new download_mgr(url);
538 function slowimg(img,x1,y1,deltat,free,action,srcend)
540 x1,y1 - destination coords
541 deltat - time for each frame (in msec)
542 free - when the release the local block for other operations (range: 0 - 1)
543 action - function to run when the image is moved
544 srcend - image to switch when the image is moved
547 function sleep(st, delay)
549 // alert("LOC_NEW PRE: "+st.st_loc_new);
553 setTimeout(function(obj){ if (obj.st_loc_new > obj.st_loc) { obj.st_loc++; }},
557 function slowimg(img,x1,y1,deltat,free,action,srcend) {
560 // this.x0 = parseInt(document.defaultView.getComputedStyle(this.img, "").getPropertyValue("left"));
561 this.x0 = parseInt(getStyle(this.img,"left", "left"));
562 // alert("img.x0 = "+this.x0);
563 // this.y0 = parseInt(document.defaultView.getComputedStyle(this.img, "").getPropertyValue("top"));
564 this.y0 = parseInt(getStyle(this.img,"top", "top"));
567 this.deltat = deltat;
569 this.action = action;
570 this.srcend = srcend;
573 slowimg.prototype = {
592 setstart: function(x0,y0)
598 setaction: function(act)
604 settime: function(time)
606 this.time = (time < this.deltat ? this.deltat : time);
607 this.step_n = parseInt(this.time / this.deltat);
608 this.dx = (this.x1 - this.x0) / this.step_n;
609 this.dy = (this.y1 - this.y0) / this.step_n;
610 if (this.step_n * this.deltat == this.time) {
614 this.step_free = parseInt(this.step_n * this.free);
620 // $("logz").innerHTML += " xxxxxxxxxxxxxxxxxxxxxSTART<br>";
622 this.st.st_loc_new++;
624 this.img.style.visibility = "visible";
625 setTimeout(function(obj){ obj.animate(); }, this.deltat, this);
630 // $("log").innerHTML = "Val " + this.step_cur + " N: " + this.step_n + "<br>";
631 if (this.step_cur == 0) {
632 var date = new Date();
633 // $("logz").innerHTML = "Timestart: " + date + "<br>";
635 if (this.step_cur <= this.step_n) {
636 this.img.style.left = this.x0 + this.dx * this.step_cur;
637 this.img.style.top = this.y0 + this.dy * this.step_cur;
639 setTimeout(function(obj){ obj.animate(); }, this.deltat, this);
640 if (this.step_cur == this.step_free && this.st != null) {
641 if (this.st.st_loc < this.st.st_loc_new) {
642 // alert("QUI1 " + this.step_cur + " ZZ "+ this.step_free);
649 this.img.style.left = this.x1;
650 this.img.style.top = this.y1;
651 // $("logz").innerHTML += "xxxxxxxxxxxxxxxCLEAR<br>";
652 var date = new Date();
653 // $("logz").innerHTML += "Timestop: " + date + "<br>";
655 if (this.action != null) {
659 if (this.st != null && this.st.st_loc < this.st.st_loc_new) {
664 if (this.srcend != null) {
665 this.img.src = this.srcend;
671 function div_show(div)
673 div.style.top = parseInt((document.body.clientHeight - parseInt(getStyle(div,"height", "height"))) / 2) + document.body.scrollTop;
674 div.style.visibility = "visible";
680 tout: if < 0 => infinite
688 function notify_document(st, text, tout, butt, confirm_func, confirm_func_args, w, h, is_opa, block_time)
690 var i, clo, clodiv_ctx, clodiv_wai, box;
694 this.ancestor = document.body;
695 this.confirm_func = confirm_func;
696 this.confirm_func_args = confirm_func_args;
697 this.st.st_loc_new++;
699 clodiv_ctx = document.createElement("div");
700 clodiv_ctx.className = "notify_clo";
702 for (i = 0 ; i < butt.length ; i++) {
703 this.input_add(butt[i], i, this.hide, clodiv_ctx);
706 if (block_time > 0) {
707 clodiv_wai = document.createElement("div");
708 clodiv_wai.className = "notify_clo";
710 this.input_add("leggere, prego.", 0, null, clodiv_wai);
711 this.clodiv = clodiv_wai;
712 this.clodiv_pkg = clodiv_ctx;
713 clodiv_ctx.style.display = 'none';
716 this.clodiv = clodiv_ctx;
719 cont = document.createElement("div");
721 cont.style.borderBottomStyle = "solid";
722 cont.style.borderBottomWidth = "1px";
723 cont.style.borderBottomColor = "gray";
724 cont.style.height = (h - 50)+"px";
725 cont.style.overflow = "auto";
726 cont.style.textAlign = "left";
727 cont.style.padding = "8px";
728 cont.style.fontFamily = "monospace";
729 cont.innerHTML = text;
731 box = document.createElement("div");
733 box.className = "notify_opaque";
735 box.className = "notify";
737 box.style.zIndex = 200;
738 box.style.width = w+"px";
739 box.style.marginLeft = -parseInt(w/2)+"px";
740 box.style.height = h+"px";
741 box.style.top = parseInt((document.body.clientHeight - h) / 2) + document.body.scrollTop;
742 box.appendChild(cont);
743 box.appendChild(this.clodiv);
744 box.style.visibility = "visible";
748 this.ancestor.appendChild(box);
751 this.toutid = setTimeout(function(obj){ obj.unblock(); }, tout, this);
754 if (block_time != 0) {
755 this.tblkid = setTimeout(function(obj){ obj.notitag.removeChild(obj.clodiv); obj.clodiv = obj.clodiv_pkg; obj.clodiv.style.display = ''; obj.notitag.appendChild(obj.clodiv); }, block_time, this);
759 notify_document.prototype = {
773 confirm_func_args: [],
780 onclick_cb: name of the onclick callback (with signature f(idx) ) or null
781 anc: parent dom object
783 return new button dom object
785 input_add: function(s, idx, onclick_cb, anc)
789 clo = document.createElement("input");
791 clo.className = "button";
792 clo.style.bottom = "4px";
793 clo.style.margin = "2px";
798 clo.onclick = function () { onclick_cb.call(this.obj, this.obj_idx); };
801 anc.appendChild(clo);
808 // alert("quiz: "+this.rett);
814 if (this.st.st_loc < this.st.st_loc_new) {
821 if (this.confirm_func != null) {
824 args = [ val ].concat(this.confirm_func_args);
826 if (this.confirm_func.apply(null, args) == false) {
831 clearTimeout(this.toutid);
832 this.ancestor.removeChild(this.notitag);
840 function notify_ex(st, text, tout, butt, w, h, is_opa, block_time)
847 this.ancestor = document.body;
849 this.st.st_loc_new++;
851 clo = document.createElement("input");
853 clo.className = "button";
854 clo.style.bottom = "4px";
856 if (block_time > 0) {
857 clo.value = "leggere, prego.";
862 clo.onclick = function () { this.obj.hide() };
865 clodiv = document.createElement("div");
866 clodiv.className = "notify_clo";
868 this.clodiv = clodiv;
870 clodiv.appendChild(clo);
872 cont = document.createElement("div");
874 cont.style.borderBottomStyle = "solid";
875 cont.style.borderBottomWidth = "1px";
876 cont.style.borderBottomColor = "gray";
877 cont.style.height = (h - 30)+"px";
878 cont.style.overflow = "auto";
879 cont.innerHTML = text;
881 box = document.createElement("div");
883 box.className = "notify_opaque";
885 box.className = "notify";
887 box.style.zIndex = 200;
888 box.style.width = w+"px";
889 box.style.marginLeft = -parseInt(w/2)+"px";
890 box.style.height = h+"px";
891 box.style.top = parseInt((document.body.clientHeight - h) / 2) + document.body.scrollTop;
892 box.appendChild(cont);
893 box.appendChild(clodiv);
894 box.style.visibility = "visible";
898 this.ancestor.appendChild(box);
900 this.toutid = setTimeout(function(obj){ obj.unblock(); }, tout, this);
902 if (block_time != 0) {
903 this.tblkid = setTimeout(function(obj){ obj.clo.value = obj.butt; obj.clo.onclick = function () { this.obj.hide() }; formsub_hilite(obj.clo); obj.clo.focus(); }, block_time, this);
913 notify_ex.prototype = {
925 if (this.st.st_loc < this.st.st_loc_new) {
932 clearTimeout(this.toutid);
933 this.ancestor.removeChild(this.notitag);
939 notify.prototype = notify_ex.prototype; // Define sub-class
940 notify.prototype.constructor = notify;
941 notify.baseConstructor = notify_ex;
942 notify.superClass = notify_ex.prototype;
944 function notify(st, text, tout, butt, w, h)
946 notify_ex.call(this, st, text, tout, butt, w, h, false, 0);
952 this.st_loc_new = -1;
953 this.comms = new Array;
963 sleep: function(delay) {
967 this.sleep_hdl = setTimeout(function(obj){ if (obj.st_loc_new > obj.st_loc) { obj.st_loc++; obj.sleep_hdl = null; }},
973 if (this.sleep_hdl != null) {
974 clearTimeout(this.sleep_hdl);
975 this.sleep_hdl = null;
980 function remark_step()
982 var ct = $("remark").l_remct;
988 $("remark").className = "remark"+ct;
989 $("remark").l_remct = ct;
990 setTimeout(remark_step,500);
993 $("remark").className = "remark0";
1000 if ($("remark").l_remct == 0) {
1001 $("remark").l_remct = 1;
1002 setTimeout(remark_step,500);
1006 function remark_off()
1008 $("remark").l_remct = 0;
1009 $("remark").className = "remark0";
1013 function italizer(ga)
1017 return "<i>"+ga[1]+"</i>";
1023 function exitlock_show(num, islock)
1027 num = (num < 3 ? num : 3);
1028 $("exitlock").src = "img/exitlock"+num+(islock ? "n" : "y")+".png";
1029 // alert("EXITLOCK: "+$("exitlock").src);
1030 $("exitlock").style.visibility = "visible";
1035 // exitlock_show(0, true);
1038 var chatt_lines = new Array();
1039 var chatt_lines_n = 0;
1041 var CHATT_MAXLINES = 40;
1043 function user_decorator(user, is_real)
1045 var name, i, sp = "", cl = "";
1046 var flags = user[0] & 0x03 | ((user[0] & 0x0c0000) >> 16);
1048 // console.log(user[1]+" FLAGS: "+flags);
1050 for (i = 0 ; i < 4 ; i++) {
1051 if (flags & (1 << i)) {
1052 cl += sp + "au" + i + (is_real ? "" : "_off");
1058 name = "<span class='" + cl + "'><span class='" +
1059 (is_real && (flags & 0xfffffe && ((flags & 0x01) == 0)) ? "id_usr" : "") +
1060 "'>" + user[1] + "</span></span>";
1069 function user_dec_and_state(el)
1074 content = user_decorator(el, true);
1075 content += state_add(el[0],(typeof(el[2]) != 'undefined' ? el[2] : null));
1082 function chatt_sub(dt,data,str)
1084 var must_scroll = false;
1088 var bolder = [ (data[0] | 1), data[1] ];
1089 name = user_decorator(bolder, false);
1091 if ($("txt").scrollTop + parseInt(getStyle($("txt"),"height", "height")) - $("txt").scrollHeight >= 0)
1094 // alert("ARRIVA NAME: "+ name + " STR:"+str);
1095 if (chatt_lines_n == CHATT_MAXLINES) {
1096 $("txt").innerHTML = "";
1097 for (i = 0 ; i < (CHATT_MAXLINES - 1) ; i++) {
1098 chatt_lines[i] = chatt_lines[i+1];
1099 $("txt").innerHTML += chatt_lines[i];
1101 chatt_lines[i] = dt+name+": "+str+ "<br>";
1102 $("txt").innerHTML += chatt_lines[i];
1105 chatt_lines[chatt_lines_n] = dt+name+": "+str+ "<br>";
1106 $("txt").innerHTML += chatt_lines[chatt_lines_n];
1109 // $("txt").innerHTML;
1113 $("txt").scrollTop = 10000000;
1115 // alert("scTOP "+$("txt").scrollTop+" scHEIGHT: "+$("txt").scrollHeight+" HEIGHT: "+getStyle($("txt"),"height", "height") );
1119 * GESTIONE DEI COOKIES
1121 function createCookie(name,value,hours,path) {
1123 var date = new Date();
1124 date.setTime(date.getTime()+(hours*60*60*1000));
1125 var expires = "; expires="+date.toGMTString();
1127 else var expires = "";
1128 document.cookie = name+"="+value+expires+"; path="+path;
1131 function readCookie(name) {
1132 var nameEQ = name + "=";
1133 var ca = document.cookie.split(';');
1134 for(var i=0;i < ca.length;i++) {
1136 while (c.charAt(0)==' ')
1137 c = c.substring(1,c.length);
1138 if (c.indexOf(nameEQ) == 0)
1139 return c.substring(nameEQ.length,c.length);
1144 function eraseCookie(name) {
1145 createCookie(name,"",-1);
1148 function onbeforeunload_cb () {
1152 function onunload_cb () {
1154 if (typeof(xstm) != "undefined")
1155 xstm.the_end = true;
1162 function room_checkspace(emme,tables,inpe)
1165 for (i = 0 ; i < emme ; i++)
1170 for (i = 0 ; i < 5 ; i++)
1171 alta += nome+"<br>";
1173 for (i = 0 ; i < tables ; i++) {
1174 $("table"+i).innerHTML = alta;
1176 $("table_act"+i).innerHTML = "<input type=\"button\" class=\"button\" name=\"xhenter"+i+"\" value=\""+mlang_commons['btn_sit'][g_lang]+"\" onclick=\"act_sitdown(1);\">";
1179 stand = "<table class=\"table_standup\"><tbody><tr>";
1180 for (i = 0 ; i < inpe ; i++) {
1181 stand += "<td>"+nome+"</td>";
1182 if ((i+1) % 4 == 0) {
1183 stand += "</tr><tr>";
1187 $("standup").innerHTML = stand;
1189 // VERIFY: what is this button ?
1191 $("esco").innerHTML = "<input class=\"button\" name=\"logout\" type=\"button\" value=\""+mlang_commons['btn_exit'][g_lang]+"\" onclick=\"act_logout();\" type=\"button\">";
1194 function unescapeHTML(cont) {
1195 var div = document.createElement('div');
1199 div.innerHTML = cont;
1200 if (div.childNodes[0]) {
1201 if (div.childNodes.length > 1) {
1202 if (div.childNodes.toArray)
1205 var length = div.childNodes.length, results = new Array(length);
1207 results[length] = div.childNodes[length];
1209 for (i=0 ; i<results.length ; i++)
1210 memo = memo + results[i].nodeValue;
1216 return (div.childNodes[0].nodeValue);
1225 samples = [{'name': <name>, 'file': <file>}, ... ]
1227 function jukebox(samples)
1230 this.enable = false;
1233 var pro_audio_el = document.createElement('audio');
1234 this.enable = !!(pro_audio_el.canPlayType && pro_audio_el.canPlayType('audio/mpeg;').replace(/no/, ''));
1236 for (i in samples) {
1237 sample = samples[i];
1239 this.audio[sample['name']] = a = document.createElement('audio');
1241 source = document.createElement('source');
1242 source.setAttribute('src', sample['file']);
1243 source.setAttribute('type', 'audio/mpeg');
1244 a.appendChild(source);
1250 jukebox.prototype = {
1251 is_enabled: function() {
1255 play: function(name) {
1260 if (!(name in this.audio)) {
1263 a = this.audio[name];
1269 function topbanner_init()
1271 setInterval(topbanner_cb, 666);
1275 function topbanner_cb()
1279 a = $('topbanner').style.backgroundColor;
1280 b = $('topbanner').style.borderLeftColor;
1282 $('topbanner').style.backgroundColor = b;
1283 $('topbanner').style.borderColor = a+" "+a+" "+a+" "+a;
1285 // console.log("A: "+a+" B: "+b);
1288 function sidebanner_init(idx)
1290 setInterval(function () { sidebanner_cb(idx); }, 666);
1293 function sidebanner_cb(idx)
1297 a = $('sidebanner'+idx).style.backgroundColor;
1298 b = $('sidebanner'+idx).style.borderLeftColor;
1300 $('sidebanner'+idx).style.backgroundColor = b;
1301 $('sidebanner'+idx).style.borderColor = a+" "+a+" "+a+" "+a;
1303 // console.log("A: "+a+" B: "+b);
1307 function langtolng(lang)
1315 function formtext_hilite(obj)
1317 obj.className = 'input_text';
1318 addEvent(obj, "focus", function () { this.className = 'input_text_hi'; });
1319 addEvent(obj, "blur", function () { this.className = 'input_text'; });
1322 function formsub_hilite(obj)
1324 obj.className = 'input_sub';
1325 addEvent(obj, "focus", function () { this.className = 'input_sub_hi'; });
1326 addEvent(obj, "blur", function () { this.className = 'input_sub'; });
1329 // return the value of the radio button that is checked
1330 // return an empty string if none are checked, or
1331 // there are no radio buttons
1332 function get_checked_value(radioObj) {
1335 var radioLength = radioObj.length;
1336 if(radioLength == undefined)
1337 if(radioObj.checked)
1338 return radioObj.value;
1341 for(var i = 0; i < radioLength; i++) {
1342 if(radioObj[i].checked) {
1343 return radioObj[i].value;
1349 // set the radio button with the given value as being checked
1350 // do nothing if there are no radio buttons
1351 // if the given value does not exist, all the radio buttons
1352 // are reset to unchecked
1353 function set_checked_value(radioObj, newValue) {
1356 var radioLength = radioObj.length;
1357 if(radioLength == undefined) {
1358 radioObj.checked = (radioObj.value == newValue.toString());
1361 for(var i = 0; i < radioLength; i++) {
1362 radioObj[i].checked = false;
1363 if(radioObj[i].value == newValue.toString()) {
1364 radioObj[i].checked = true;
1369 function url_append_arg(url, name, value)
1371 var pos, sep, pref, rest;
1373 if ((pos = url.indexOf('?'+name+'=')) == -1) {
1374 pos = url.indexOf('&'+name+'=');
1377 if ((pos = url.indexOf('?')) != -1)
1382 return (url+sep+name+"="+encodeURIComponent(value));
1385 pref = url.substring(0, pos+1);
1386 rest = url.substring(pos+1);
1387 // alert("rest: "+rest+" pos: "+pos);
1388 if ((pos = rest.indexOf('&')) != -1) {
1389 rest = rest.substring(pos);
1394 return (pref+name+"="+encodeURIComponent(value)+rest);
1398 function url_append_args(url)
1403 for (i = 1 ; i < arguments.length-1 ; i+= 2) {
1404 ret = url_append_arg(ret, arguments[i], arguments[i+1]);
1410 function url_complete(parent, url)
1413 var host = "", path = "";
1416 p = parent.indexOf("://");
1418 rest = parent.substring(p+3);
1419 p2 = rest.indexOf("/");
1421 host = parent.substring(0, p+3+p2);
1422 rest = parent.substring(p+3+p2);
1434 p = rest.lastIndexOf("/");
1436 path = rest.substring(0, p+1);
1439 // alert("host: ["+host+"] path: ["+path+"]");
1440 if (url.substring(0,6) == 'http:/' || url.substring(0,7) == 'https:/' || url.substring(0,4) == 'ws:/' || url.substring(0,5) == 'wss:/') {
1443 else if (url.substring(0,1) == '/') {
1447 return (host+path+url);
1451 function download_mgr(url)
1455 if ((ifra = $('the_downloader')) == null) {
1456 ifra = document.createElement("iframe");
1457 ifra.style.display = "none";
1458 ifra.id = 'the_downloader';
1459 document.body.appendChild(ifra);
1462 ifra.contentWindow.location.href = url;
1467 download_mgr.prototype = {
1471 function submit_click(obj)
1473 obj.form.elements['realsub'].value = obj.id;