X-Git-Url: https://mop.ddnsfree.com/gitweb/?a=blobdiff_plain;ds=sidebyside;f=web%2Fcommons.js;h=c65dd51a7e2cb1b46753ffa311b1b75415018ac9;hb=8d7cdc537ab4b1329fe0ef8c4d976545c12e14c3;hp=f0a0a9810e8b31b87f752f7ab628ceda81a6e2f4;hpb=5fa01c83781bbb977710f84ec20ff882d59b8034;p=brisk.git
diff --git a/web/commons.js b/web/commons.js
index f0a0a98..c65dd51 100644
--- a/web/commons.js
+++ b/web/commons.js
@@ -1,8 +1,8 @@
/*
* brisk - commons.js
*
- * Copyright (C) 2006-2012 Matteo Nastasi
- * mailto: nastasi@alternativeoutput.it
+ * Copyright (C) 2006-2015 Matteo Nastasi
+ * mailto: nastasi@alternativeoutput.it
* matteo.nastasi@milug.org
* web: http://www.alternativeoutput.it
*
@@ -22,12 +22,12 @@
*/
var PLAYERS_N = 3;
-var EXIT_BAN_TIME = 3600;
+var EXIT_BAN_TIME = 900;
var cookiepath = "/brisk/";
var mlang_commons = { 'imgload_a' : { 'it' : 'Immagini caricate ',
'en' : 'Loaded images ' },
- 'imgload_b' : { 'it' : '%.',
+ 'imgload_b' : { 'it' : '%.',
'en' : '%.' },
'gamleav' : { 'it' : 'Sei sicuro di volere lasciare questa mano?' ,
'en' : 'Are you sure to leave this game?' },
@@ -45,8 +45,8 @@ var mlang_commons = { 'imgload_a' : { 'it' : 'Immagini caricate ',
'en' : '(only aut.)' },
'2' : { 'it' : '(isolam.to)',
'en' : '(isolation)' } },
- 'tos_refu' : { 'it' : 'Rifiutando di sottoscrivere i nuovi termini del servizio non ti sarà più possibile accedere col tuo utente registrato al sito, sei proprio sicuro di non voler accettare le nuove condizioni d\'uso ?',
- 'en' : 'EN Rifiutando di sottoscrivere i nuovi termini del servizio non ti sarà più possibile accedere col tuo utente registrato al sito, sei proprio sicuro di non voler accettare le nuove condizioni d\'uso ?',
+ '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 ?',
+ '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 ?'
}
};
@@ -64,7 +64,7 @@ function dec2hex(d, padding)
return hex;
}
-function getStyle(x,IEstyleProp, MozStyleProp)
+function getStyle(x,IEstyleProp, MozStyleProp)
{
if (x.currentStyle) {
var y = x.currentStyle[IEstyleProp];
@@ -91,14 +91,14 @@ function getStyle(x,IEstyleProp, MozStyleProp)
param[i-2] = arguments[i];
}
}
-
+
if(typeof(fn)=='function') {
-
+
return (function (fn,ms,param) {
var fo = function () {
fn.apply(window,param);
};
- return nativeSetInterval(fo,ms);
+ return nativeSetInterval(fo,ms);
})(fn,ms,param);
}
else if(typeof(fn)=='string')
@@ -123,14 +123,14 @@ function getStyle(x,IEstyleProp, MozStyleProp)
param[i-2] = arguments[i];
}
}
-
+
if(typeof(fn)=='function') {
-
+
return (function (fn,ms,param) {
var fo = function () {
fn.apply(window,param);
};
- return nativeSetTimeout(fo,ms);
+ return nativeSetTimeout(fo,ms);
})(fn,ms,param);
}
else if(typeof(fn)=='string')
@@ -145,7 +145,7 @@ function getStyle(x,IEstyleProp, MozStyleProp)
})()
-function addEvent(obj,type,fn)
+function addEvent(obj, type, fn)
{
if (obj.addEventListener) {
obj.addEventListener( type, fn, false);
@@ -235,7 +235,7 @@ function update_images()
function preload_images(arr,idx)
{
var im = new Image;
-
+
// $("imgct").innerHTML = "Stiamo caricando "+arr[idx]+"%.
";
im.onload = update_images;
im.onerror = error_images;
@@ -264,13 +264,28 @@ function createXMLHttpRequest() {
return null;
}
-function send_mesg(mesg)
+function send_mesg(mesg, content)
{
- var xhr_wr = createXMLHttpRequest();
var is_conn = (sess == "not_connected" ? false : true);
-
+
+ if (is_conn && xstm && xstm.transp_type.startsWith('websocket')) {
+ if (typeof(content) != 'undefined') {
+ mesg = mesg + content;
+ }
+ var target = window.location.href.substring(0,
+ window.location.href.lastIndexOf('/') + 1) + 'index_wr.php';
+ var ws_msg = JSON.stringify({target: target, mesg: mesg, stp:gst.st, sess:sess});
+ console.log(ws_msg);
+ xstm.transp.ws.send(ws_msg);
+ }
+ else {
+ var xhr_wr = createXMLHttpRequest();
+
+ if (typeof(content) != 'undefined') {
+ mesg = mesg + encodeURIComponent(content);
+ }
// alert("xhr_wr: "+xhr_wr+" is_conn: "+is_conn);
- xhr_wr.open('GET', 'index_wr.php?'+(is_conn ? 'sess='+sess+'&' : '')+'mesg='+mesg, (is_conn ? true : false));
+ xhr_wr.open('GET', 'index_wr.php?&'+(is_conn ? 'sess='+sess : '')+'&stp='+gst.st+'&mesg='+mesg, (is_conn ? true : false));
xhr_wr.setRequestHeader("If-Modified-Since", new Date().toUTCString());
xhr_wr.onreadystatechange = function() { return; };
if (typeof(g_debug) == 'number' && g_debug > 0
@@ -285,6 +300,7 @@ function send_mesg(mesg)
eval(xhr_wr.responseText);
}
}
+ }
}
/*
@@ -315,7 +331,7 @@ function server_request()
// alert("Args: "+arguments.length);
var is_conn = (sess == "not_connected" ? false : true);
-
+
// console.log("server_request:preresp: "+xhr_wr.responseText);
if (is_post) {
@@ -327,11 +343,11 @@ function server_request()
}
xhr_wr.onreadystatechange = function() { return; };
xhr_wr.send(post_collect);
-
+
if (xhr_wr.responseText != null) {
// console.log("server_request:resp: "+xhr_wr.responseText);
return (xhr_wr.responseText);
- }
+ }
else
return (null);
}
@@ -358,7 +374,12 @@ function chatt_checksend(obj,e)
}
function act_chatt(value)
{
- send_mesg("chatt|"+encodeURIComponent(value));
+ if (value.substring(0, 6) == "/info ") {
+ info_show(value.substring(6));
+ }
+ else {
+ send_mesg("chatt|", value);
+ }
/*
obj.disabled = true;
obj.value = "";
@@ -406,7 +427,7 @@ function act_mesgtoadm()
function act_tav()
{
- act_chatt('/tav '+$('txt_in').value);
+ act_chatt('/tav '+$('txt_in').value);
$('txt_in').value = '';
}
@@ -425,11 +446,6 @@ function act_roadmap()
send_mesg("roadmap");
}
-function act_whysupport()
-{
- send_mesg("whysupport");
-}
-
function act_lascio()
{
send_mesg("lascio");
@@ -468,8 +484,8 @@ function act_shutdown()
function postact_logout()
{
// alert("postact_logout");
- try {
- hstm.abort();
+ try {
+ xstm.abort();
} catch (e) {}
// eraseCookie("sess");
@@ -478,8 +494,8 @@ function postact_logout()
/*
type - 'hard' or 'soft'
- code - if soft: accept (0), refuse (1), after (2)
- if hard: accept (0), refuse (1)
+ code - if soft: accept (0), refuse (1), download (2), later (3)
+ if hard: accept (0), refuse (1), download (2)
*/
function act_tosmgr(type, code, tos_curr, tos_vers)
{
@@ -496,16 +512,26 @@ function act_tosmgr(type, code, tos_curr, tos_vers)
default:
break;
}
+
return true;
}
-function tos_confirm(val)
+function tos_confirm(val, url)
{
- if (val == 1) {
+ var dlm;
+
+ switch (val) {
+ case 1:
return (window.confirm(mlang_commons['tos_refu'][g_lang]));
+ break;
+ case 2:
+ dlm = new download_mgr(url);
+ return false;
+ break;
+ default:
+ return true;
+ break;
}
-
- return true;
}
/*
@@ -545,7 +571,7 @@ function slowimg(img,x1,y1,deltat,free,action,srcend) {
}
slowimg.prototype = {
- img: null,
+ img: null,
st: null,
x0: 0,
y0: 0,
@@ -562,20 +588,20 @@ slowimg.prototype = {
tout: 0,
action: null,
srcend: null,
-
+
setstart: function(x0,y0)
{
this.x0 = x0;
this.y0 = y0;
},
-
+
setaction: function(act)
{
this.action = act;
},
-
- settime: function(time)
+
+ settime: function(time)
{
this.time = (time < this.deltat ? this.deltat : time);
this.step_n = parseInt(this.time / this.deltat);
@@ -588,17 +614,17 @@ slowimg.prototype = {
this.step_free = parseInt(this.step_n * this.free);
}
},
-
+
start: function(st)
{
// $("logz").innerHTML += " xxxxxxxxxxxxxxxxxxxxxSTART
";
this.st = st;
this.st.st_loc_new++;
-
+
this.img.style.visibility = "visible";
setTimeout(function(obj){ obj.animate(); }, this.deltat, this);
},
-
+
animate: function()
{
// $("log").innerHTML = "Val " + this.step_cur + " N: " + this.step_n + "
";
@@ -659,7 +685,7 @@ function div_show(div)
block_time:
*/
-function notify_document(st, text, tout, butt, confirm_func, w, h, is_opa, block_time)
+function notify_document(st, text, tout, butt, confirm_func, confirm_func_args, w, h, is_opa, block_time)
{
var i, clo, clodiv_ctx, clodiv_wai, box;
@@ -667,7 +693,7 @@ function notify_document(st, text, tout, butt, confirm_func, w, h, is_opa, block
this.ancestor = document.body;
this.confirm_func = confirm_func;
-
+ this.confirm_func_args = confirm_func_args;
this.st.st_loc_new++;
clodiv_ctx = document.createElement("div");
@@ -744,6 +770,7 @@ notify_document.prototype = {
tblkid: null,
confirm_func: null,
+ confirm_func_args: [],
ret: -1,
@@ -792,7 +819,11 @@ notify_document.prototype = {
hide: function(val)
{
if (this.confirm_func != null) {
- if (this.confirm_func(val) == false) {
+ var args;
+
+ args = [ val ].concat(this.confirm_func_args);
+
+ if (this.confirm_func.apply(null, args) == false) {
return false;
}
}
@@ -810,11 +841,11 @@ function notify_ex(st, text, tout, butt, w, h, is_opa, block_time)
{
var clo, box;
var t = this;
-
+
this.st = st;
this.ancestor = document.body;
-
+
this.st.st_loc_new++;
clo = document.createElement("input");
@@ -863,9 +894,9 @@ function notify_ex(st, text, tout, butt, w, h, is_opa, block_time)
box.style.visibility = "visible";
this.notitag = box;
-
+
this.ancestor.appendChild(box);
-
+
this.toutid = setTimeout(function(obj){ obj.unblock(); }, tout, this);
if (block_time != 0) {
@@ -885,7 +916,7 @@ notify_ex.prototype = {
notitag: null,
toutid: null,
clo: null,
- clodiv: null,
+ clodiv: null,
butt: null,
tblkid: null,
@@ -895,7 +926,7 @@ notify_ex.prototype = {
this.st.st_loc++;
}
},
-
+
hide: function()
{
clearTimeout(this.toutid);
@@ -914,12 +945,6 @@ function notify(st, text, tout, butt, w, h)
{
notify_ex.call(this, st, text, tout, butt, w, h, false, 0);
}
-
-
-function $(id) {
- return document.getElementById(id);
-}
-
function globst() {
this.st = -1;
@@ -955,7 +980,7 @@ globst.prototype = {
function remark_step()
{
var ct = $("remark").l_remct;
-
+
if (ct != 0) {
ct++;
if (ct > 2)
@@ -966,7 +991,7 @@ function remark_step()
}
else
$("remark").className = "remark0";
-
+
return;
}
@@ -988,7 +1013,7 @@ function remark_off()
function italizer(ga)
{
var pre, pos;
- if (ga[0] & 2)
+ if (ga[0] & 2)
return ""+ga[1]+"";
else
return ga[1];
@@ -1015,14 +1040,28 @@ var chatt_lines_n = 0;
var CHATT_MAXLINES = 40;
-function user_decorator(user)
+function user_decorator(user, is_real)
{
- var name;
- var flags = user[0];
- if ((flags & 0x03) != 0)
- name = ""+user[1]+"";
- else
+ var name, i, sp = "", cl = "";
+ var flags = user[0] & 0x03 | ((user[0] & 0x0c0000) >> 16);
+
+ // console.log(user[1]+" FLAGS: "+flags);
+
+ for (i = 0 ; i < 4 ; i++) {
+ if (flags & (1 << i)) {
+ cl += sp + "au" + i + (is_real ? "" : "_off");
+ sp = " ";
+ }
+ }
+
+ if (flags != 0) {
+ name = "" + user[1] + "";
+ }
+ else {
name = user[1];
+ }
return (name);
}
@@ -1032,9 +1071,9 @@ function user_dec_and_state(el)
var content = "";
var val_el;
- content = user_decorator(el);
+ content = user_decorator(el, true);
content += state_add(el[0],(typeof(el[2]) != 'undefined' ? el[2] : null));
-
+
return (content);
}
@@ -1047,7 +1086,7 @@ function chatt_sub(dt,data,str)
var flags;
var isauth;
var bolder = [ (data[0] | 1), data[1] ];
- name = user_decorator(bolder);
+ name = user_decorator(bolder, false);
if ($("txt").scrollTop + parseInt(getStyle($("txt"),"height", "height")) - $("txt").scrollHeight >= 0)
must_scroll = true;
@@ -1069,7 +1108,7 @@ function chatt_sub(dt,data,str)
}
// $("txt").innerHTML;
-
+
if (must_scroll) {
$("txt").scrollTop = 10000000;
}
@@ -1094,8 +1133,10 @@ function readCookie(name) {
var ca = document.cookie.split(';');
for(var i=0;i < ca.length;i++) {
var c = ca[i];
- while (c.charAt(0)==' ') c = c.substring(1,c.length);
- if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
+ while (c.charAt(0)==' ')
+ c = c.substring(1,c.length);
+ if (c.indexOf(nameEQ) == 0)
+ return c.substring(nameEQ.length,c.length);
}
return null;
}
@@ -1109,24 +1150,24 @@ function onbeforeunload_cb () {
}
function onunload_cb () {
-
- if (typeof(hstm) != "undefined")
- hstm.the_end = true;
+
+ if (typeof(xstm) != "undefined")
+ xstm.the_end = true;
act_shutdown();
-
+
return(false);
}
function room_checkspace(emme,tables,inpe)
{
nome = "";
- for (i = 0 ; i < emme ; i++)
+ for (i = 0 ; i < emme ; i++)
nome += "m";
nome += "";
alta = "";
- for (i = 0 ; i < 5 ; i++)
+ for (i = 0 ; i < 5 ; i++)
alta += nome+"
";
for (i = 0 ; i < tables ; i++) {
@@ -1164,7 +1205,7 @@ function unescapeHTML(cont) {
var length = div.childNodes.length, results = new Array(length);
while (length--)
results[length] = div.childNodes[length];
-
+
for (i=0 ; i' +
-'' +
-'' +
-'