Files
aportil/themes/sources4.0/dhtmlxGrid/codebase/excells/dhtmlxgrid_excell_calck.js

151 lines
6.5 KiB
JavaScript

/*
Product Name: dhtmlxSuite
Version: 4.0.3
Edition: Professional
License: content of this file is covered by DHTMLX Commercial or Enterprise license. Usage without proper license is prohibited. To obtain it contact sales@dhtmlx.com
Copyright UAB Dinamenta http://www.dhtmlx.com
*/
/**
* @desc: calculator editor
* @returns: dhtmlxGrid cell editor object
* @type: public
*/
function eXcell_calck(cell){
try{
this.cell = cell;
this.grid = this.cell.parentNode.grid;
}catch(er){}
this.edit = function(){
this.val = this.getValue();
var arPos = this.grid.getPosition(this.cell);
this.obj = new calcX(arPos[0],arPos[1]+this.cell.offsetHeight,this,this.val);
}
this.getValue = function(){
//this.grid.editStop();
return this.grid._aplNFb(this.cell.innerHTML.toString()._dhx_trim(),this.cell._cellIndex);
}
this.detach = function(){
if (this.obj) {
this.setValue(this.obj.inputZone.value);
this.obj.removeSelf();
}
this.obj=null;
return this.val!=this.getValue();
}
}
eXcell_calck.prototype = new eXcell;
eXcell_calck.prototype.setValue = function(val){
if(!val || val.toString()._dhx_trim()=="")
val="0"
this.setCValue(this.grid._aplNF(val,this.cell._cellIndex),val);
}
function calcX(left,top,onReturnSub,val){
this.top=top||0;
this.left=left||0;
this.onReturnSub=onReturnSub||null;
this.operandA=0;
this.operandB=0;
this.operatorA="";
this.state=0;
this.dotState=0;
this.calckGo=function(){
return (eval(this.operandA+"*1"+this.operatorA+this.operandB+"*1"));
};
this.isNumeric=function(str){
return ((str.search(/[^1234567890]/gi)==-1)?(true):(false));
};
this.isOperation=function(str){
return ((str.search(/[^\+\*\-\/]/gi)==-1)?(true):(false));
}
this.onCalcKey=function(e)
{
that=this.calk;
var z=this.innerHTML;
var rZone=that.inputZone;
if (((that.state==0)||(that.state==2))&&(that.isNumeric(z))) if (rZone.value!="0") rZone.value+=z; else rZone.value=z;
if ((((that.state==0)||(that.state==2))&&(z=='.'))&&(that.dotState==0)) { that.dotState=1; rZone.value+=z; }
if ((z=="C")) { rZone.value=0; that.dotState=0; that.state=0; }
if ((that.state==0)&&(that.isOperation(z))) { that.operatorA=z; that.operandA=rZone.value; that.state=1; }
if ((that.state==2)&&(that.isOperation(z))) { that.operandB=rZone.value; rZone.value=that.calckGo(); that.operatorA=z; that.operandA=rZone.value; that.state=1; }
if ((that.state==2)&&(z=="=")) { that.operandB=rZone.value; rZone.value=that.calckGo(); that.operatorA=z; that.operandA=rZone.value; that.state=3; }
if ((that.state==1)&&(that.isNumeric(z))) { rZone.value=z; that.state=2; that.dotState=0 }
if ((that.state==3)&&(that.isNumeric(z))) { rZone.value=z; that.state=0; }
if ((that.state==3)&&(that.isOperation(z))) { that.operatorA=z; that.operandA=rZone.value; that.state=1; }
if (z=="e") { rZone.value=Math.E; if (that.state==1) that.state=2; that.dotState=0 }
if (z=="p") { rZone.value=Math.PI; if (that.state==1) that.state=2; that.dotState=0 }
if (z=="Off") that.topNod.parentNode.removeChild(that.topNod);
if (e||event) (e||event).cancelBubble=true;
}
this.sendResult=function(){
that=this.calk;
if (that.state==2){
var rZone=that.inputZone;
that.operandB=rZone.value;
rZone.value=that.calckGo();
that.operatorA=z;
that.operandA=rZone.value;
that.state=3; }
var z=that.inputZone.value;
that.topNod.parentNode.removeChild(that.topNod);
that.onReturnSub.grid.editStop(false);
};
this.removeSelf=function(){
if (this.topNod.parentNode)
this.topNod.parentNode.removeChild(this.topNod);
}
this.keyDown=function(){ this.className="calcPressed"; };
this.keyUp=function(){ this.className="calcButton"; };
this.init_table=function(){
var table=this.topNod.childNodes[0];
if ((!table)||(table.tagName!="TABLE")) return;
for (i=1; i<table.childNodes[0].childNodes.length; i++)
for (j=0; j<table.childNodes[0].childNodes[i].childNodes.length; j++)
{
table.childNodes[0].childNodes[i].childNodes[j].onclick=this.onCalcKey;
table.childNodes[0].childNodes[i].childNodes[j].onmousedown=this.keyDown;
table.childNodes[0].childNodes[i].childNodes[j].onmouseout=this.keyUp;
table.childNodes[0].childNodes[i].childNodes[j].onmouseup=this.keyUp;
table.childNodes[0].childNodes[i].childNodes[j].calk=this;
}
this.inputZone=this.topNod.childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0];
if (this.onReturnSub)
{
this.topNod.childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[1].onclick=this.sendResult;
this.topNod.childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[1].calk=this;
}
else this.topNod.childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[0].childNodes[1].innerHTML="";
}
this.drawSelf=function(){
var div=document.createElement("div");
div.className="calcTable";
div.style.position="absolute";
div.style.top=this.top+"px";
div.style.left=this.left+"px";
div.innerHTML="<table cellspacing='0' id='calc_01' class='calcTable'><tr><td colspan='4'><table cellpadding='1' cellspacing='0' width='100%'><tr><td width='100%' style='overflow:hidden;'><input style='width:100%' class='calcInput' value='0' align='right' readonly='true' style='text-align:right'></td><td class='calkSubmit'>=</td></tr></table></td></tr><tr><td class='calcButton' width='25%'>Off</td><td class='calcButton' width='25%'>p</td><td class='calcButton' width='25%'>e</td><td class='calcButton' width='25%'>/</td></tr><tr><td class='calcButton'>7</td><td class='calcButton'>8</td><td class='calcButton'>9</td><td class='calcButton'>*</td></tr><tr><td class='calcButton'>4</td><td class='calcButton'>5</td><td class='calcButton'>6</td><td class='calcButton'>+</td></tr><tr><td class='calcButton'>1</td><td class='calcButton'>2</td><td class='calcButton'>3</td><td class='calcButton'>-</td></tr><tr><td class='calcButton'>0</td><td class='calcButton'>.</td><td class='calcButton'>C</td><td class='calcButton'>=</td></tr></table>";
div.onclick=function(e){ (e||event).cancelBubble=true; };
document.body.appendChild(div);
this.topNod=div;
}
this.drawSelf();
this.init_table();
if (val){
var rZone=this.inputZone;
rZone.value=val*1;
this.operandA=val*1;
this.state=3;
}
return this;
};
//(c)dhtmlx ltd. www.dhtmlx.com