345 lines
9.7 KiB
JavaScript
Raw Normal View History

2012-06-19 12:07:43 +10:00
//>>built
define("dojox/mdnd/AreaManager",["dojo/_base/kernel","dojo/_base/declare","dojo/_base/connect","dojo/_base/window","dojo/_base/array","dojo/query","dojo/_base/html","./Moveable"],function(_1){
var am=_1.declare("dojox.mdnd.AreaManager",null,{autoRefresh:true,areaClass:"dojoxDndArea",dragHandleClass:"dojoxDragHandle",constructor:function(){
this._areaList=[];
this.resizeHandler=_1.connect(_1.global,"onresize",this,function(){
this._dropMode.updateAreas(this._areaList);
});
this._oldIndexArea=this._currentIndexArea=this._oldDropIndex=this._currentDropIndex=this._sourceIndexArea=this._sourceDropIndex=-1;
},init:function(){
this.registerByClass();
},registerByNode:function(_2,_3){
var _4=this._getIndexArea(_2);
if(_2&&_4==-1){
var _5=_2.getAttribute("accept");
var _6=(_5)?_5.split(/\s*,\s*/):["text"];
var _7={"node":_2,"items":[],"coords":{},"margin":null,"accept":_6,"initItems":false};
_1.forEach(this._getChildren(_2),function(_8){
this._setMarginArea(_7,_8);
_7.items.push(this._addMoveableItem(_8));
},this);
this._areaList=this._dropMode.addArea(this._areaList,_7);
if(!_3){
this._dropMode.updateAreas(this._areaList);
}
_1.publish("/dojox/mdnd/manager/register",[_2]);
}
},registerByClass:function(){
_1.query("."+this.areaClass).forEach(function(_9){
this.registerByNode(_9,true);
},this);
this._dropMode.updateAreas(this._areaList);
},unregister:function(_a){
var _b=this._getIndexArea(_a);
if(_b!=-1){
_1.forEach(this._areaList[_b].items,function(_c){
this._deleteMoveableItem(_c);
},this);
this._areaList.splice(_b,1);
this._dropMode.updateAreas(this._areaList);
return true;
}
return false;
},_addMoveableItem:function(_d){
_d.setAttribute("tabIndex","0");
var _e=this._searchDragHandle(_d);
var _f=new dojox.mdnd.Moveable({"handle":_e,"skip":true},_d);
_1.addClass(_e||_d,"dragHandle");
var _10=_d.getAttribute("dndType");
var _11={"item":_f,"type":_10?_10.split(/\s*,\s*/):["text"],"handlers":[_1.connect(_f,"onDragStart",this,"onDragStart")]};
if(dijit&&dijit.byNode){
var _12=dijit.byNode(_d);
if(_12){
_11.type=_12.dndType?_12.dndType.split(/\s*,\s*/):["text"];
_11.handlers.push(_1.connect(_12,"uninitialize",this,function(){
this.removeDragItem(_d.parentNode,_f.node);
}));
}
}
return _11;
},_deleteMoveableItem:function(_13){
_1.forEach(_13.handlers,function(_14){
_1.disconnect(_14);
});
var _15=_13.item.node,_16=this._searchDragHandle(_15);
_1.removeClass(_16||_15,"dragHandle");
_13.item.destroy();
},_getIndexArea:function(_17){
if(_17){
for(var i=0;i<this._areaList.length;i++){
if(this._areaList[i].node===_17){
return i;
}
}
}
return -1;
},_searchDragHandle:function(_18){
if(_18){
var _19=this.dragHandleClass.split(" "),_1a=_19.length,_1b="";
_1.forEach(_19,function(css,i){
_1b+="."+css;
if(i!=_1a-1){
_1b+=", ";
}
});
return _1.query(_1b,_18)[0];
}
},addDragItem:function(_1c,_1d,_1e,_1f){
var add=true;
if(!_1f){
add=_1c&&_1d&&(_1d.parentNode===null||(_1d.parentNode&&_1d.parentNode.nodeType!==1));
}
if(add){
var _20=this._getIndexArea(_1c);
if(_20!==-1){
var _21=this._addMoveableItem(_1d),_22=this._areaList[_20].items;
if(0<=_1e&&_1e<_22.length){
var _23=_22.slice(0,_1e),_24=_22.slice(_1e,_22.length);
_23[_23.length]=_21;
this._areaList[_20].items=_23.concat(_24);
_1c.insertBefore(_1d,_22[_1e].item.node);
}else{
this._areaList[_20].items.push(_21);
_1c.appendChild(_1d);
}
this._setMarginArea(this._areaList[_20],_1d);
this._areaList[_20].initItems=false;
return true;
}
}
return false;
},removeDragItem:function(_25,_26){
var _27=this._getIndexArea(_25);
if(_25&&_27!==-1){
var _28=this._areaList[_27].items;
for(var j=0;j<_28.length;j++){
if(_28[j].item.node===_26){
this._deleteMoveableItem(_28[j]);
_28.splice(j,1);
return _25.removeChild(_26);
}
}
}
return null;
},_getChildren:function(_29){
var _2a=[];
_1.forEach(_29.childNodes,function(_2b){
if(_2b.nodeType==1){
if(dijit&&dijit.byNode){
var _2c=dijit.byNode(_2b);
if(_2c){
if(!_2c.dragRestriction){
_2a.push(_2b);
}
}else{
_2a.push(_2b);
}
}else{
_2a.push(_2b);
}
}
});
return _2a;
},_setMarginArea:function(_2d,_2e){
if(_2d&&_2d.margin===null&&_2e){
_2d.margin=_1._getMarginExtents(_2e);
}
},findCurrentIndexArea:function(_2f,_30){
this._oldIndexArea=this._currentIndexArea;
this._currentIndexArea=this._dropMode.getTargetArea(this._areaList,_2f,this._currentIndexArea);
if(this._currentIndexArea!=this._oldIndexArea){
if(this._oldIndexArea!=-1){
this.onDragExit(_2f,_30);
}
if(this._currentIndexArea!=-1){
this.onDragEnter(_2f,_30);
}
}
return this._currentIndexArea;
},_isAccepted:function(_31,_32){
this._accept=false;
for(var i=0;i<_32.length;++i){
for(var j=0;j<_31.length;++j){
if(_31[j]==_32[i]){
this._accept=true;
break;
}
}
}
},onDragStart:function(_33,_34,_35){
if(this.autoRefresh){
this._dropMode.updateAreas(this._areaList);
}
var _36=(_1.isWebKit)?_1.body():_1.body().parentNode;
if(!this._cover){
this._cover=_1.create("div",{"class":"dndCover"});
this._cover2=_1.clone(this._cover);
_1.addClass(this._cover2,"dndCover2");
}
var h=_36.scrollHeight+"px";
this._cover.style.height=this._cover2.style.height=h;
_1.body().appendChild(this._cover);
_1.body().appendChild(this._cover2);
this._dragStartHandler=_1.connect(_33.ownerDocument,"ondragstart",_1,"stopEvent");
this._sourceIndexArea=this._lastValidIndexArea=this._currentIndexArea=this._getIndexArea(_33.parentNode);
var _37=this._areaList[this._sourceIndexArea];
var _38=_37.items;
for(var i=0;i<_38.length;i++){
if(_38[i].item.node==_33){
this._dragItem=_38[i];
this._dragItem.handlers.push(_1.connect(this._dragItem.item,"onDrag",this,"onDrag"));
this._dragItem.handlers.push(_1.connect(this._dragItem.item,"onDragEnd",this,"onDrop"));
_38.splice(i,1);
this._currentDropIndex=this._sourceDropIndex=i;
break;
}
}
var _39=null;
if(this._sourceDropIndex!==_37.items.length){
_39=_37.items[this._sourceDropIndex].item.node;
}
if(_1.isIE>7){
this._eventsIE7=[_1.connect(this._cover,"onmouseover",_1,"stopEvent"),_1.connect(this._cover,"onmouseout",_1,"stopEvent"),_1.connect(this._cover,"onmouseenter",_1,"stopEvent"),_1.connect(this._cover,"onmouseleave",_1,"stopEvent")];
}
var s=_33.style;
s.left=_34.x+"px";
s.top=_34.y+"px";
if(s.position=="relative"||s.position==""){
s.position="absolute";
}
this._cover.appendChild(_33);
this._dropIndicator.place(_37.node,_39,_35);
_1.addClass(_33,"dragNode");
this._accept=true;
_1.publish("/dojox/mdnd/drag/start",[_33,_37,this._sourceDropIndex]);
},onDragEnter:function(_3a,_3b){
if(this._currentIndexArea===this._sourceIndexArea){
this._accept=true;
}else{
this._isAccepted(this._dragItem.type,this._areaList[this._currentIndexArea].accept);
}
},onDragExit:function(_3c,_3d){
this._accept=false;
},onDrag:function(_3e,_3f,_40,_41){
var _42=this._dropMode.getDragPoint(_3f,_40,_41);
this.findCurrentIndexArea(_42,_40);
if(this._currentIndexArea!==-1&&this._accept){
this.placeDropIndicator(_42,_40);
}
},placeDropIndicator:function(_43,_44){
this._oldDropIndex=this._currentDropIndex;
var _45=this._areaList[this._currentIndexArea];
if(!_45.initItems){
this._dropMode.initItems(_45);
}
this._currentDropIndex=this._dropMode.getDropIndex(_45,_43);
if(!(this._currentIndexArea===this._oldIndexArea&&this._oldDropIndex===this._currentDropIndex)){
this._placeDropIndicator(_44);
}
return this._currentDropIndex;
},_placeDropIndicator:function(_46){
var _47=this._areaList[this._lastValidIndexArea];
var _48=this._areaList[this._currentIndexArea];
this._dropMode.refreshItems(_47,this._oldDropIndex,_46,false);
var _49=null;
if(this._currentDropIndex!=-1){
_49=_48.items[this._currentDropIndex].item.node;
}
this._dropIndicator.place(_48.node,_49);
this._lastValidIndexArea=this._currentIndexArea;
this._dropMode.refreshItems(_48,this._currentDropIndex,_46,true);
},onDropCancel:function(){
if(!this._accept){
var _4a=this._getIndexArea(this._dropIndicator.node.parentNode);
if(_4a!=-1){
this._currentIndexArea=_4a;
}else{
this._currentIndexArea=0;
}
}
},onDrop:function(_4b){
this.onDropCancel();
var _4c=this._areaList[this._currentIndexArea];
_1.removeClass(_4b,"dragNode");
var _4d=_4b.style;
_4d.position="relative";
_4d.left="0";
_4d.top="0";
_4d.width="auto";
if(_4c.node==this._dropIndicator.node.parentNode){
_4c.node.insertBefore(_4b,this._dropIndicator.node);
}else{
_4c.node.appendChild(_4b);
this._currentDropIndex=_4c.items.length;
}
var _4e=this._currentDropIndex;
if(_4e==-1){
_4e=_4c.items.length;
}
var _4f=_4c.items;
var _50=_4f.slice(0,_4e);
var _51=_4f.slice(_4e,_4f.length);
_50[_50.length]=this._dragItem;
_4c.items=_50.concat(_51);
this._setMarginArea(_4c,_4b);
_1.forEach(this._areaList,function(obj){
obj.initItems=false;
});
_1.disconnect(this._dragItem.handlers.pop());
_1.disconnect(this._dragItem.handlers.pop());
this._resetAfterDrop();
if(this._cover){
_1.body().removeChild(this._cover);
_1.body().removeChild(this._cover2);
}
_1.publish("/dojox/mdnd/drop",[_4b,_4c,_4e]);
},_resetAfterDrop:function(){
this._accept=false;
this._dragItem=null;
this._currentDropIndex=-1;
this._currentIndexArea=-1;
this._oldDropIndex=-1;
this._sourceIndexArea=-1;
this._sourceDropIndex=-1;
this._dropIndicator.remove();
if(this._dragStartHandler){
_1.disconnect(this._dragStartHandler);
}
if(_1.isIE>7){
_1.forEach(this._eventsIE7,_1.disconnect);
}
},destroy:function(){
while(this._areaList.length>0){
if(!this.unregister(this._areaList[0].node)){
throw new Error("Error while destroying AreaManager");
}
}
_1.disconnect(this.resizeHandler);
this._dropIndicator.destroy();
this._dropMode.destroy();
if(dojox.mdnd.autoScroll){
dojox.mdnd.autoScroll.destroy();
}
if(this.refreshListener){
_1.unsubscribe(this.refreshListener);
}
if(this._cover){
_1._destroyElement(this._cover);
_1._destroyElement(this._cover2);
delete this._cover;
delete this._cover2;
}
}});
if(dijit&&dijit._Widget){
_1.extend(dijit._Widget,{dndType:"text"});
}
dojox.mdnd._areaManager=null;
dojox.mdnd.areaManager=function(){
if(!dojox.mdnd._areaManager){
dojox.mdnd._areaManager=new dojox.mdnd.AreaManager();
}
return dojox.mdnd._areaManager;
};
return am;
});