Ext.ux.TabCloseMenu插件的简单扩展
2008-11-03 22:09
363 查看
从网上下了Ext.ux.TabCloseMenu插件试用了一下,发现少了"关闭全部标签"的功能,笔者在Ext.ux.TabCloseMenu插件基础上进行了简单的修改,添加了这个功能,现发出来共享一下.
/*
* Ext JS Library 2.2
* Copyright(c) 2006-2008, Ext JS, LLC.
* licensing@extjs.com
*
* http://extjs.com/license
*/
// Very simple plugin for adding a close context menu to tabs
Ext.ux.TabCloseMenu = function(){
var tabs, menu, ctxItem;
this.init = function(tp){
tabs = tp;
tabs.on('contextmenu', onContextMenu);
}
function onContextMenu(ts, item, e){
if(!menu){ // create context menu on first right click
menu = new Ext.menu.Menu([{
id: tabs.id + '-close',
text: '关闭标签',
handler : function(){
tabs.remove(ctxItem);
}
},{
id: tabs.id + '-close-others',
text: '关闭其他标签',
handler : function(){
tabs.items.each(function(item){
if(item.closable && item != ctxItem){
tabs.remove(item);
}
});
}
},{
id: tabs.id + '-close-all',
text: '关闭全部标签',
handler : function(){
tabs.items.each(function(item){
if(item.closable){
tabs.remove(item);
}
});
}
}]);
}
ctxItem = item;
var items = menu.items;
items.get(tabs.id + '-close').setDisabled(!item.closable);
var disableOthers = true;
tabs.items.each(function(){
if(this != item && this.closable){
disableOthers = false;
return false;
}
});
items.get(tabs.id + '-close-others').setDisabled(disableOthers);
var disableAll = true;
tabs.items.each(function(){
if(this.closable){
disableAll = false;
return false;
}
});
items.get(tabs.id + '-close-all').setDisabled(disableAll);
menu.showAt(e.getPoint());
}
};
/*
* Ext JS Library 2.2
* Copyright(c) 2006-2008, Ext JS, LLC.
* licensing@extjs.com
*
* http://extjs.com/license
*/
// Very simple plugin for adding a close context menu to tabs
Ext.ux.TabCloseMenu = function(){
var tabs, menu, ctxItem;
this.init = function(tp){
tabs = tp;
tabs.on('contextmenu', onContextMenu);
}
function onContextMenu(ts, item, e){
if(!menu){ // create context menu on first right click
menu = new Ext.menu.Menu([{
id: tabs.id + '-close',
text: '关闭标签',
handler : function(){
tabs.remove(ctxItem);
}
},{
id: tabs.id + '-close-others',
text: '关闭其他标签',
handler : function(){
tabs.items.each(function(item){
if(item.closable && item != ctxItem){
tabs.remove(item);
}
});
}
},{
id: tabs.id + '-close-all',
text: '关闭全部标签',
handler : function(){
tabs.items.each(function(item){
if(item.closable){
tabs.remove(item);
}
});
}
}]);
}
ctxItem = item;
var items = menu.items;
items.get(tabs.id + '-close').setDisabled(!item.closable);
var disableOthers = true;
tabs.items.each(function(){
if(this != item && this.closable){
disableOthers = false;
return false;
}
});
items.get(tabs.id + '-close-others').setDisabled(disableOthers);
var disableAll = true;
tabs.items.each(function(){
if(this.closable){
disableAll = false;
return false;
}
});
items.get(tabs.id + '-close-all').setDisabled(disableAll);
menu.showAt(e.getPoint());
}
};
相关文章推荐
- ExtJs TabPanel右键功能插件Ext.ux.TabCloseMenu
- Ext.ux.TabCloseMenu插件的使用(TabPanel右键关闭菜单) 示例
- [OPEN] [4.2.1.883] Ext.ux.TabCloseMenu broken
- 一个不错的扩展:Ext.ux.container.ButtonSegment
- Eclipse 插件开发 -- 深入理解菜单(Menu)功能及其扩展点
- 修改Ext.ux.GroupTabPanel让它支持延迟渲染
- ExtJS 4 在Ext.tab.Panel中使用Ext.ux.IFrame打开url指向的网页
- Windbg Engine—-1.最简单的扩展插件
- (转)一篇很不错的介绍Eclipse插件Menu及其扩展点的文章
- 最简单Ext.Tree扩展CheckBox的方法
- 一个不错的扩展:Ext.ux.container.ButtonSegment
- (转)一篇很不错的介绍Eclipse插件Menu及其扩展点的文章
- 【转】nodejs 如何实现一个简单的插件扩展
- Ext.Net 1.2.0_Ext.UX.GMapPanel Google Map 插件
- 一个不错的扩展:Ext.ux.container.ButtonSegment
- ExtTabMenu 控件
- 简单的Easytabs插件,实现Tab在左侧显示
- jQuery插件扩展extend的简单实现原理
- 基于Ext Core的包含校验功能的表单提交扩展Ext.ux.submit
- 基于Ext Core的包含校验功能的表单提交扩展Ext.ux.submit