wok-current rev 17794
wikiss: update wkp_Calc from tazwikiss
author | Pascal Bellard <pascal.bellard@slitaz.org> |
---|---|
date | Tue Mar 17 18:44:10 2015 +0100 (2015-03-17) |
parents | 73858bb3d112 |
children | d11fd3e3b9d3 |
files | wikiss/stuff/plugins/wkp_Calc.css wikiss/stuff/plugins/wkp_Calc.php |
line diff
1.1 --- a/wikiss/stuff/plugins/wkp_Calc.css Mon Mar 16 13:06:40 2015 +0100 1.2 +++ b/wikiss/stuff/plugins/wkp_Calc.css Tue Mar 17 18:44:10 2015 +0100 1.3 @@ -9,7 +9,7 @@ 1.4 .inputcalc { 1.5 border: none; 1.6 width: 80px; 1.7 - font-size: 14px; 1.8 + font-size: inherit; 1.9 padding: 2px; 1.10 } 1.11 1.12 @@ -28,4 +28,5 @@ 1.13 .cellcalc { 1.14 border: 1px solid #999; 1.15 padding: 0; 1.16 + font-size: 14px; 1.17 }
2.1 --- a/wikiss/stuff/plugins/wkp_Calc.php Mon Mar 16 13:06:40 2015 +0100 2.2 +++ b/wikiss/stuff/plugins/wkp_Calc.php Tue Mar 17 18:44:10 2015 +0100 2.3 @@ -61,6 +61,24 @@ 2.4 alert(data); 2.5 } 2.6 2.7 +function cnt(from,to) { 2.8 + return (to.charCodeAt(0) - from.charCodeAt(0) + 1) * 2.9 + (parseInt(to.substring(1)) - parseInt(from.substring(1)) + 1) 2.10 +} 2.11 + 2.12 +function zone(id,from,to,init,func) { 2.13 + var result=init 2.14 + for (var l=from.charCodeAt(0);;l++) { 2.15 + for (var n=parseInt(from.substring(1)); 2.16 + n <= parseInt(to.substring(1));n++) { 2.17 + var e=document.getElementById(id+String.fromCharCode(l)+n) 2.18 + result=func(result,parseFloat(e.value)) 2.19 + } 2.20 + if (l == to.charCodeAt(0)) break 2.21 + } 2.22 + return result; 2.23 +} 2.24 + 2.25 var DATA={}; 2.26 function buildCalc(id, rows, cols) { 2.27 DATA[id] = {}; 2.28 @@ -77,6 +95,13 @@ 2.29 function(n){var x=1;while(n>1)x*=n--;return x;}; 2.30 DATA[id].fib = DATA[id].FIB = 2.31 function(n){var c=0,p=1;while(n-->0){var x=c;c+=p;p=x};return c;}; 2.32 + DATA[id].sum = DATA[id].SUM = 2.33 + function(a,b){return zone(id,a,b,0,function(a,b){return a+b});}; 2.34 + DATA[id].min = DATA[id].MIN = 2.35 + function(a,b){return zone(id,a,b,Number.MAX_VALUE,Math.min);}; 2.36 + DATA[id].max = DATA[id].MAX = 2.37 + function(a,b){return zone(id,a,b,Number.MIN_VALUE,Math.max);}; 2.38 + DATA[id].cnt = DATA[id].CNT = cnt 2.39 for (var i=0; i<=rows; i++) { 2.40 var row = document.getElementById(id).insertRow(-1); 2.41 for (var j=0; j<=cols && j<=26; j++) { 2.42 @@ -99,7 +124,7 @@ 2.43 function getWidth(s) 2.44 { 2.45 var e = document.getElementById("widthcalc"); 2.46 - e.innerHTML = s+" :"; 2.47 + e.innerHTML = s; 2.48 return (e.offsetWidth < 80 || s.charAt(0) == "=") ? 80 : e.offsetWidth; 2.49 } 2.50 2.51 @@ -145,7 +170,7 @@ 2.52 var value = elm.title || ""; 2.53 if (value.charAt(0) == "=") 2.54 with (DATA[calcid]) return eval(value.substring(1)); 2.55 - else return isNaN(parseFloat(value)) ? value : parseFloat(value); 2.56 + else return (value == "" || isNaN(value)) ? value : parseFloat(value); 2.57 }; 2.58 Object.defineProperty(DATA[calcid], cellid, {get:getter}); 2.59 Object.defineProperty(DATA[calcid], cellid.toLowerCase(), {get:getter});