📄 layout-debug.js
字号:
Ext.callback(cb);
return;
}
this.isSlid = false;
this.beforeSlide();
this.el.slideOut(this.getSlideAnchor(), {
callback: function(){
this.el.setLeftTop(-10000, -10000);
this.afterSlide();
this.afterSlideIn();
Ext.callback(cb);
},
scope: this,
block: true
});
},
slideInIf : function(e){
if(!e.within(this.el)){
this.slideIn();
}
},
animateCollapse : function(){
this.beforeSlide();
this.el.setStyle("z-index", 20000);
var anchor = this.getSlideAnchor();
this.el.slideOut(anchor, {
callback : function(){
this.el.setStyle("z-index", "");
this.collapsedEl.slideIn(anchor, {duration:.3});
this.afterSlide();
this.el.setLocation(-10000,-10000);
this.el.hide();
this.fireEvent("collapsed", this);
},
scope: this,
block: true
});
},
animateExpand : function(){
this.beforeSlide();
this.el.alignTo(this.collapsedEl, this.getCollapseAnchor(), this.getExpandAdj());
this.el.setStyle("z-index", 20000);
this.collapsedEl.hide({
duration:.1
});
this.el.slideIn(this.getSlideAnchor(), {
callback : function(){
this.el.setStyle("z-index", "");
this.afterSlide();
if(this.split){
this.split.el.show();
}
this.fireEvent("invalidated", this);
this.fireEvent("expanded", this);
},
scope: this,
block: true
});
},
anchors : {
"west" : "left",
"east" : "right",
"north" : "top",
"south" : "bottom"
},
sanchors : {
"west" : "l",
"east" : "r",
"north" : "t",
"south" : "b"
},
canchors : {
"west" : "tl-tr",
"east" : "tr-tl",
"north" : "tl-bl",
"south" : "bl-tl"
},
getAnchor : function(){
return this.anchors[this.position];
},
getCollapseAnchor : function(){
return this.canchors[this.position];
},
getSlideAnchor : function(){
return this.sanchors[this.position];
},
getAlignAdj : function(){
var cm = this.cmargins;
switch(this.position){
case "west":
return [0, 0];
break;
case "east":
return [0, 0];
break;
case "north":
return [0, 0];
break;
case "south":
return [0, 0];
break;
}
},
getExpandAdj : function(){
var c = this.collapsedEl, cm = this.cmargins;
switch(this.position){
case "west":
return [-(cm.right+c.getWidth()+cm.left), 0];
break;
case "east":
return [cm.right+c.getWidth()+cm.left, 0];
break;
case "north":
return [0, -(cm.top+cm.bottom+c.getHeight())];
break;
case "south":
return [0, cm.top+cm.bottom+c.getHeight()];
break;
}
}
});
Ext.CenterLayoutRegion = function(mgr, config){
Ext.CenterLayoutRegion.superclass.constructor.call(this, mgr, config, "center");
this.visible = true;
this.minWidth = config.minWidth || 20;
this.minHeight = config.minHeight || 20;
};
Ext.extend(Ext.CenterLayoutRegion, Ext.LayoutRegion, {
hide : function(){
},
show : function(){
},
getMinWidth: function(){
return this.minWidth;
},
getMinHeight: function(){
return this.minHeight;
}
});
Ext.NorthLayoutRegion = function(mgr, config){
Ext.NorthLayoutRegion.superclass.constructor.call(this, mgr, config, "north", "n-resize");
if(this.split){
this.split.placement = Ext.SplitBar.TOP;
this.split.orientation = Ext.SplitBar.VERTICAL;
this.split.el.addClass("x-layout-split-v");
}
var size = config.initialSize || config.height;
if(typeof size != "undefined"){
this.el.setHeight(size);
}
};
Ext.extend(Ext.NorthLayoutRegion, Ext.SplitLayoutRegion, {
orientation: Ext.SplitBar.VERTICAL,
getBox : function(){
if(this.collapsed){
return this.collapsedEl.getBox();
}
var box = this.el.getBox();
if(this.split){
box.height += this.split.el.getHeight();
}
return box;
},
updateBox : function(box){
if(this.split && !this.collapsed){
box.height -= this.split.el.getHeight();
this.split.el.setLeft(box.x);
this.split.el.setTop(box.y+box.height);
this.split.el.setWidth(box.width);
}
if(this.collapsed){
this.updateBody(box.width, null);
}
Ext.NorthLayoutRegion.superclass.updateBox.call(this, box);
}
});
Ext.SouthLayoutRegion = function(mgr, config){
Ext.SouthLayoutRegion.superclass.constructor.call(this, mgr, config, "south", "s-resize");
if(this.split){
this.split.placement = Ext.SplitBar.BOTTOM;
this.split.orientation = Ext.SplitBar.VERTICAL;
this.split.el.addClass("x-layout-split-v");
}
var size = config.initialSize || config.height;
if(typeof size != "undefined"){
this.el.setHeight(size);
}
};
Ext.extend(Ext.SouthLayoutRegion, Ext.SplitLayoutRegion, {
orientation: Ext.SplitBar.VERTICAL,
getBox : function(){
if(this.collapsed){
return this.collapsedEl.getBox();
}
var box = this.el.getBox();
if(this.split){
var sh = this.split.el.getHeight();
box.height += sh;
box.y -= sh;
}
return box;
},
updateBox : function(box){
if(this.split && !this.collapsed){
var sh = this.split.el.getHeight();
box.height -= sh;
box.y += sh;
this.split.el.setLeft(box.x);
this.split.el.setTop(box.y-sh);
this.split.el.setWidth(box.width);
}
if(this.collapsed){
this.updateBody(box.width, null);
}
Ext.SouthLayoutRegion.superclass.updateBox.call(this, box);
}
});
Ext.EastLayoutRegion = function(mgr, config){
Ext.EastLayoutRegion.superclass.constructor.call(this, mgr, config, "east", "e-resize");
if(this.split){
this.split.placement = Ext.SplitBar.RIGHT;
this.split.orientation = Ext.SplitBar.HORIZONTAL;
this.split.el.addClass("x-layout-split-h");
}
var size = config.initialSize || config.width;
if(typeof size != "undefined"){
this.el.setWidth(size);
}
};
Ext.extend(Ext.EastLayoutRegion, Ext.SplitLayoutRegion, {
orientation: Ext.SplitBar.HORIZONTAL,
getBox : function(){
if(this.collapsed){
return this.collapsedEl.getBox();
}
var box = this.el.getBox();
if(this.split){
var sw = this.split.el.getWidth();
box.width += sw;
box.x -= sw;
}
return box;
},
updateBox : function(box){
if(this.split && !this.collapsed){
var sw = this.split.el.getWidth();
box.width -= sw;
this.split.el.setLeft(box.x);
this.split.el.setTop(box.y);
this.split.el.setHeight(box.height);
box.x += sw;
}
if(this.collapsed){
this.updateBody(null, box.height);
}
Ext.EastLayoutRegion.superclass.updateBox.call(this, box);
}
});
Ext.WestLayoutRegion = function(mgr, config){
Ext.WestLayoutRegion.superclass.constructor.call(this, mgr, config, "west", "w-resize");
if(this.split){
this.split.placement = Ext.SplitBar.LEFT;
this.split.orientation = Ext.SplitBar.HORIZONTAL;
this.split.el.addClass("x-layout-split-h");
}
var size = config.initialSize || config.width;
if(typeof size != "undefined"){
this.el.setWidth(size);
}
};
Ext.extend(Ext.WestLayoutRegion, Ext.SplitLayoutRegion, {
orientation: Ext.SplitBar.HORIZONTAL,
getBox : function(){
if(this.collapsed){
return this.collapsedEl.getBox();
}
var box = this.el.getBox();
if(this.split){
box.width += this.split.el.getWidth();
}
return box;
},
updateBox : function(box){
if(this.split && !this.collapsed){
var sw = this.split.el.getWidth();
box.width -= sw;
this.split.el.setLeft(box.x+box.width);
this.split.el.setTop(box.y);
this.split.el.setHeight(box.height);
}
if(this.collapsed){
this.updateBody(null, box.height);
}
Ext.WestLayoutRegion.superclass.updateBox.call(this, box);
}
});
Ext.LayoutStateManager = function(layout){
this.state = {
north: {},
south: {},
east: {},
west: {}
};
};
Ext.LayoutStateManager.prototype = {
init : function(layout, provider){
this.provider = provider;
var state = provider.get(layout.id+"-layout-state");
if(state){
var wasUpdating = layout.isUpdating();
if(!wasUpdating){
layout.beginUpdate();
}
for(var key in state){
if(typeof state[key] != "function"){
var rstate = state[key];
var r = layout.getRegion(key);
if(r && rstate){
if(rstate.size){
r.resizeTo(rstate.size);
}
if(rstate.collapsed == true){
r.collapse(true);
}else{
r.expand(null, true);
}
}
}
}
if(!wasUpdating){
layout.endUpdate();
}
this.state = state;
}
this.layout = layout;
layout.on("regionresized", this.onRegionResized, this);
layout.on("regioncollapsed", this.onRegionCollapsed, this);
layout.on("regionexpanded", this.onRegionExpanded, this);
},
storeState : function(){
this.provider.set(this.layout.id+"-layout-state", this.state);
},
onRegionResized : function(region, newSize){
this.state[region.getPosition()].size = newSize;
this.storeState();
},
onRegionCollapsed : function(region){
this.state[region.getPosition()].collapsed = true;
this.storeState();
},
onRegionExpanded : function(region){
this.state[region.getPosition()].collapsed = false;
this.storeState();
}
};
Ext.ContentPanel = function(el, config, content){
if(el.autoCreate){
config = el;
el = Ext.id();
}
this.el = Ext.get(el);
if(!this.el && config && config.autoCreate){
if(typeof config.autoCreate == "object"){
if(!config.autoCreate.id){
config.autoCreate.id = config.id||el;
}
this.el = Ext.DomHelper.append(document.body,
config.autoCreate, true);
}else{
this.el = Ext.DomHelper.append(document.body,
{tag: "div", cls: "x-layout-inactive-content", id: config.id||el}, true);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -