569 lines
13 KiB
JavaScript
Raw Normal View History

2012-06-19 12:07:43 +10:00
//>>built
define(["dijit","dojo","dojox","dojo/require!dojo/fx/easing"],function(_1,_2,_3){
_2.provide("dojox.drawing.stencil._Base");
_2.require("dojo.fx.easing");
_3.drawing.stencil._Base=_3.drawing.util.oo.declare(function(_4){
_2.mixin(this,_4);
this.style=_4.style||_3.drawing.defaults.copy();
if(_4.stencil){
this.stencil=_4.stencil;
this.util=_4.stencil.util;
this.mouse=_4.stencil.mouse;
this.container=_4.stencil.container;
this.style=_4.stencil.style;
}
var _5=/Line|Vector|Axes|Arrow/;
var _6=/Text/;
this.shortType=this.util.abbr(this.type);
this.isText=_6.test(this.type);
this.isLine=_5.test(this.type);
this.renderHit=this.style.renderHitLayer;
if(!this.renderHit&&this.style.renderHitLines&&this.isLine){
this.renderHit=true;
}
if(!this.renderHit&&this.style.useSelectedStyle){
this.useSelectedStyle=true;
this.selCopy=_2.clone(this.style.selected);
for(var nm in this.style.norm){
if(this.style.selected[nm]===undefined){
this.style.selected[nm]=this.style.norm[nm];
}
}
this.textSelected=_2.clone(this.style.text);
this.textSelected.color=this.style.selected.fill;
}
this.angleSnap=this.style.angleSnap||1;
this.marginZero=_4.marginZero||this.style.anchors.marginZero;
this.id=_4.id||this.util.uid(this.type);
this._cons=[];
if(!this.annotation&&!this.subShape){
this.util.attr(this.container,"id",this.id);
}
this.connect(this,"onBeforeRender","preventNegativePos");
this._offX=this.mouse.origin.x;
this._offY=this.mouse.origin.y;
if(this.isText){
this.align=_4.align||this.align;
this.valign=_4.valign||this.valign;
if(_4.data&&_4.data.makeFit){
var _7=this.makeFit(_4.data.text,_4.data.width);
this.textSize=this.style.text.size=_7.size;
this._lineHeight=_7.box.h;
}else{
this.textSize=parseInt(this.style.text.size,10);
this._lineHeight=this.textSize*1.4;
}
this.deleteEmptyCreate=_4.deleteEmptyCreate!==undefined?_4.deleteEmptyCreate:this.style.text.deleteEmptyCreate;
this.deleteEmptyModify=_4.deleteEmptyModify!==undefined?_4.deleteEmptyModify:this.style.text.deleteEmptyModify;
}
this.attr(_4.data);
if(this.noBaseRender){
return;
}
if(_4.points){
if(_4.data&&_4.data.closePath===false){
this.closePath=false;
}
this.setPoints(_4.points);
this.connect(this,"render",this,"onRender",true);
this.baseRender&&this.enabled&&this.render();
_4.label&&this.setLabel(_4.label);
_4.shadow&&this.addShadow(_4.shadow);
}else{
if(_4.data){
_4.data.width=_4.data.width?_4.data.width:this.style.text.minWidth;
_4.data.height=_4.data.height?_4.data.height:this._lineHeight;
this.setData(_4.data);
this.connect(this,"render",this,"onRender",true);
this.baseRender&&this.enabled&&this.render(_4.data.text);
this.baseRender&&_4.label&&this.setLabel(_4.label);
this.baseRender&&_4.shadow&&this.addShadow(_4.shadow);
}else{
if(this.draws){
this.points=[];
this.data={};
this.connectMouse();
this._postRenderCon=_2.connect(this,"render",this,"_onPostRender");
}
}
}
if(this.showAngle){
this.angleLabel=new _3.drawing.annotations.Angle({stencil:this});
}
if(!this.enabled){
this.disable();
this.moveToBack();
this.render(_4.data.text);
}
},{type:"dojox.drawing.stencil",minimumSize:10,enabled:true,drawingType:"stencil",setData:function(_8){
this.data=_8;
this.points=this.dataToPoints();
},setPoints:function(_9){
this.points=_9;
if(this.pointsToData){
this.data=this.pointsToData();
}
},onDelete:function(_a){
},onBeforeRender:function(_b){
},onModify:function(_c){
},onChangeData:function(_d){
},onChangeText:function(_e){
},onRender:function(_f){
this._postRenderCon=_2.connect(this,"render",this,"_onPostRender");
this.created=true;
this.disconnectMouse();
if(this.shape){
this.shape.superClass=this;
}else{
this.container.superClass=this;
}
this._setNodeAtts(this);
},onChangeStyle:function(_10){
this._isBeingModified=true;
if(!this.enabled){
this.style.current=this.style.disabled;
this.style.currentText=this.style.textDisabled;
this.style.currentHit=this.style.hitNorm;
}else{
this.style.current=this.style.norm;
this.style.currentHit=this.style.hitNorm;
this.style.currentText=this.style.text;
}
if(this.selected){
if(this.useSelectedStyle){
this.style.current=this.style.selected;
this.style.currentText=this.textSelected;
}
this.style.currentHit=this.style.hitSelected;
}else{
if(this.highlighted){
this.style.currentHit=this.style.hitHighlighted;
}
}
this.render();
},animate:function(_11,_12){
console.warn("ANIMATE..........................");
var d=_11.d||_11.duration||1000;
var ms=_11.ms||20;
var _13=_11.ease||_2.fx.easing.linear;
var _14=_11.steps;
var ts=new Date().getTime();
var w=100;
var cnt=0;
var _15=true;
var sp,ep;
if(_2.isArray(_11.start)){
sp=_11.start;
ep=_11.end;
}else{
if(_2.isObject(_11.start)){
sp=_11.start;
ep=_11.end;
_15=false;
}else{
console.warn("No data provided to animate");
}
}
var v=setInterval(_2.hitch(this,function(){
var t=new Date().getTime()-ts;
var p=_13(1-t/d);
if(t>d||cnt++>100){
clearInterval(v);
return;
}
if(_15){
var _16=[];
_2.forEach(sp,function(pt,i){
var o={x:(ep[i].x-sp[i].x)*p+sp[i].x,y:(ep[i].y-sp[i].y)*p+sp[i].y};
_16.push(o);
});
this.setPoints(_16);
this.render();
}else{
var o={};
for(var nm in sp){
o[nm]=(ep[nm]-sp[nm])*p+sp[nm];
}
this.attr(o);
}
}),ms);
},attr:function(key,_17){
var n=this.enabled?this.style.norm:this.style.disabled;
var t=this.enabled?this.style.text:this.style.textDisabled;
var ts=this.textSelected||{},o,nm,_18,_19=_2.toJson(n),_1a=_2.toJson(t);
var _1b={x:true,y:true,r:true,height:true,width:true,radius:true,angle:true};
var _1c=false;
if(typeof (key)!="object"){
o={};
o[key]=_17;
}else{
o=_2.clone(key);
}
if(o.width){
_18=o.width;
delete o.width;
}
for(nm in o){
if(nm in n){
n[nm]=o[nm];
}
if(nm in t){
t[nm]=o[nm];
}
if(nm in ts){
ts[nm]=o[nm];
}
if(nm in _1b){
_1b[nm]=o[nm];
_1c=true;
if(nm=="radius"&&o.angle===undefined){
o.angle=_1b.angle=this.getAngle();
}else{
if(nm=="angle"&&o.radius===undefined){
o.radius=_1b.radius=this.getRadius();
}
}
}
if(nm=="text"){
this.setText(o.text);
}
if(nm=="label"){
this.setLabel(o.label);
}
}
if(o.borderWidth!==undefined){
n.width=o.borderWidth;
}
if(this.useSelectedStyle){
for(nm in this.style.norm){
if(this.selCopy[nm]===undefined){
this.style.selected[nm]=this.style.norm[nm];
}
}
this.textSelected.color=this.style.selected.color;
}
if(!this.created){
return;
}
if(o.x!==undefined||o.y!==undefined){
var box=this.getBounds(true);
var mx={dx:0,dy:0};
for(nm in o){
if(nm=="x"||nm=="y"||nm=="r"){
mx["d"+nm]=o[nm]-box[nm];
}
}
this.transformPoints(mx);
}
var p=this.points;
if(o.angle!==undefined){
this.dataToPoints({x:this.data.x1,y:this.data.y1,angle:o.angle,radius:o.radius});
}else{
if(_18!==undefined){
p[1].x=p[2].x=p[0].x+_18;
this.pointsToData(p);
}
}
if(o.height!==undefined&&o.angle===undefined){
p[2].y=p[3].y=p[0].y+o.height;
this.pointsToData(p);
}
if(o.r!==undefined){
this.data.r=Math.max(0,o.r);
}
if(_1c||_1a!=_2.toJson(t)||_19!=_2.toJson(n)){
this.onChangeStyle(this);
}
o.width=_18;
if(o.cosphi!=undefined){
!this.data?this.data={cosphi:o.cosphi}:this.data.cosphi=o.cosphi;
this.style.zAxis=o.cosphi!=0?true:false;
}
},exporter:function(){
var _1d=this.type.substring(this.type.lastIndexOf(".")+1).charAt(0).toLowerCase()+this.type.substring(this.type.lastIndexOf(".")+2);
var o=_2.clone(this.style.norm);
o.borderWidth=o.width;
delete o.width;
if(_1d=="path"){
o.points=this.points;
}else{
o=_2.mixin(o,this.data);
}
o.type=_1d;
if(this.isText){
o.text=this.getText();
o=_2.mixin(o,this.style.text);
delete o.minWidth;
delete o.deleteEmptyCreate;
delete o.deleteEmptyModify;
}
var lbl=this.getLabel();
if(lbl){
o.label=lbl;
}
return o;
},disable:function(){
this.enabled=false;
this.renderHit=false;
this.onChangeStyle(this);
},enable:function(){
this.enabled=true;
this.renderHit=true;
this.onChangeStyle(this);
},select:function(){
this.selected=true;
this.onChangeStyle(this);
},deselect:function(_1e){
if(_1e){
setTimeout(_2.hitch(this,function(){
this.selected=false;
this.onChangeStyle(this);
}),200);
}else{
this.selected=false;
this.onChangeStyle(this);
}
},_toggleSelected:function(){
if(!this.selected){
return;
}
this.deselect();
setTimeout(_2.hitch(this,"select"),0);
},highlight:function(){
this.highlighted=true;
this.onChangeStyle(this);
},unhighlight:function(){
this.highlighted=false;
this.onChangeStyle(this);
},moveToFront:function(){
this.container&&this.container.moveToFront();
},moveToBack:function(){
this.container&&this.container.moveToBack();
},onTransformBegin:function(_1f){
this._isBeingModified=true;
},onTransformEnd:function(_20){
this._isBeingModified=false;
this.onModify(this);
},onTransform:function(_21){
if(!this._isBeingModified){
this.onTransformBegin();
}
this.setPoints(this.points);
this.render();
},transformPoints:function(mx){
if(!mx.dx&&!mx.dy){
return;
}
var _22=_2.clone(this.points),_23=false;
_2.forEach(this.points,function(o){
o.x+=mx.dx;
o.y+=mx.dy;
if(o.x<this.marginZero||o.y<this.marginZero){
_23=true;
}
});
if(_23){
this.points=_22;
console.error("Attempt to set object '"+this.id+"' to less than zero.");
return;
}
this.onTransform();
this.onTransformEnd();
},applyTransform:function(mx){
this.transformPoints(mx);
},setTransform:function(mx){
this.attr({x:mx.dx,y:mx.dy});
},getTransform:function(){
return this.selected?this.container.getParent().getTransform():{dx:0,dy:0};
},addShadow:function(_24){
_24=_24===true?{}:_24;
_24.stencil=this;
this.shadow=new _3.drawing.annotations.BoxShadow(_24);
},removeShadow:function(){
this.shadow.destroy();
},setLabel:function(_25){
if(!this._label){
this._label=new _3.drawing.annotations.Label({text:_25,util:this.util,mouse:this.mouse,stencil:this,annotation:true,container:this.container,labelPosition:this.labelPosition});
}else{
if(_25!=undefined){
this._label.setLabel(_25);
}
}
},getLabel:function(){
if(this._label){
return this._label.getText();
}
return null;
},getAngle:function(){
var d=this.pointsToData();
var obj={start:{x:d.x1,y:d.y1},x:d.x2,y:d.y2};
var _26=this.util.angle(obj,this.angleSnap);
_26<0?_26=360+_26:_26;
return _26;
},getRadius:function(){
var box=this.getBounds(true);
var _27={start:{x:box.x1,y:box.y1},x:box.x2,y:box.y2};
return this.util.length(_27);
},getBounds:function(_28){
var p=this.points,x1,y1,x2,y2;
if(p.length==2){
if(_28){
x1=p[0].x;
y1=p[0].y;
x2=p[1].x;
y2=p[1].y;
}else{
x1=p[0].x<p[1].x?p[0].x:p[1].x;
y1=p[0].y<p[1].y?p[0].y:p[1].y;
x2=p[0].x<p[1].x?p[1].x:p[0].x;
y2=p[0].y<p[1].y?p[1].y:p[0].y;
}
return {x1:x1,y1:y1,x2:x2,y2:y2,x:x1,y:y1,w:x2-x1,h:y2-y1};
}else{
return {x1:p[0].x,y1:p[0].y,x2:p[2].x,y2:p[2].y,x:p[0].x,y:p[0].y,w:p[2].x-p[0].x,h:p[2].y-p[0].y};
}
},preventNegativePos:function(){
if(this._isBeingModified){
return;
}
if(!this.points||!this.points.length){
return;
}
if(this.type=="dojox.drawing.tools.custom.Axes"){
var _29=this.marginZero,_2a=this.marginZero;
_2.forEach(this.points,function(p){
_29=Math.min(p.y,_29);
});
_2.forEach(this.points,function(p){
_2a=Math.min(p.x,_2a);
});
if(_29<this.marginZero){
_2.forEach(this.points,function(p,i){
p.y=p.y+(this.marginZero-_29);
},this);
}
if(_2a<this.marginZero){
_2.forEach(this.points,function(p){
p.x+=(this.marginZero-_2a);
},this);
}
}else{
_2.forEach(this.points,function(p){
p.x=p.x<0?this.marginZero:p.x;
p.y=p.y<0?this.marginZero:p.y;
});
}
this.setPoints(this.points);
},_onPostRender:function(_2b){
if(this._isBeingModified){
this.onModify(this);
this._isBeingModified=false;
}else{
if(!this.created){
}
}
if(!this.editMode&&!this.selected&&this._prevData&&_2.toJson(this._prevData)!=_2.toJson(this.data)){
this.onChangeData(this);
this._prevData=_2.clone(this.data);
}else{
if(!this._prevData&&(!this.isText||this.getText())){
this._prevData=_2.clone(this.data);
}
}
},_setNodeAtts:function(_2c){
var att=this.enabled&&(!this.annotation||this.drawingType=="label")?this.drawingType:"";
this.util.attr(_2c,"drawingType",att);
},destroy:function(){
if(this.destroyed){
return;
}
if(this.data||this.points&&this.points.length){
this.onDelete(this);
}
this.disconnectMouse();
this.disconnect(this._cons);
_2.disconnect(this._postRenderCon);
this.remove(this.shape,this.hit);
this.destroyed=true;
},remove:function(){
var a=arguments;
if(!a.length){
if(!this.shape){
return;
}
a=[this.shape];
}
for(var i=0;i<a.length;i++){
if(a[i]){
a[i].removeShape();
}
}
},connectMult:function(){
if(arguments.length>1){
this._cons.push(this.connect.apply(this,arguments));
}else{
if(_2.isArray(arguments[0][0])){
_2.forEach(arguments[0],function(ar){
this._cons.push(this.connect.apply(this,ar));
},this);
}else{
this._cons.push(this.connect.apply(this,arguments[0]));
}
}
},connect:function(o,e,s,m,_2d){
var c;
if(typeof (o)!="object"){
if(s){
m=s;
s=e;
e=o;
o=this;
}else{
m=e;
e=o;
o=s=this;
}
}else{
if(!m){
m=s;
s=this;
}else{
if(_2d){
c=_2.connect(o,e,function(evt){
_2.hitch(s,m)(evt);
_2.disconnect(c);
});
this._cons.push(c);
return c;
}else{
}
}
}
c=_2.connect(o,e,s,m);
this._cons.push(c);
return c;
},disconnect:function(_2e){
if(!_2e){
return;
}
if(!_2.isArray(_2e)){
_2e=[_2e];
}
_2.forEach(_2e,_2.disconnect,_2);
},connectMouse:function(){
this._mouseHandle=this.mouse.register(this);
},disconnectMouse:function(){
this.mouse.unregister(this._mouseHandle);
},render:function(){
},dataToPoints:function(_2f){
},pointsToData:function(_30){
},onDown:function(obj){
this._downOnCanvas=true;
_2.disconnect(this._postRenderCon);
this._postRenderCon=null;
},onMove:function(obj){
},onDrag:function(obj){
},onUp:function(obj){
}});
});