I'm trying to override a few methods related to tree nodes and dragging. I don't have regular tree labels. They are HTML with images, etc.
I have the following overrides working properly:
Code:
Ext.override(Ext.tree.TreeNodeUI, {
onSelectedChange : function(state) {
if (state){
this.focus();
this.addClass("x-tree-selected");
// 20101120 MB - added this call to remove stale row selection colors
this.onOut(null);
} else {
//this.blur();
this.removeClass("x-tree-selected");
}
}
});
Ext.override(Ext.tree.TreeDragZone, {
onInitDrag : function(e) {
var data = this.dragData;
// 20101120 MB - removed next two calls - selection handled by controller
//this.tree.getSelectionModel().select(data.node);
//this.tree.eventModel.disable();
this.proxy.update("");
data.node.ui.appendDDGhost(this.proxy.ghost.dom);
this.tree.fireEvent("startdrag", this.tree, data.node, e);
}
});
I'd like to override Ext.dd.Registry.getHandleFromEvent as follows:
Code:
Ext.override(Ext.dd.Registry, {
getHandleFromEvent : function(e) {
var t = Ext.lib.Event.getTarget(e);
// 20101120 MB - added this while loop to handle tree labels with html children instead of raw text
while (!t.id && t.parentNode) {
t = t.parentNode;
}
return t ? handles[t.id] : null;
}
});
However, this does not take effect (working code below). I'm stuck with replacing the entire Ext.dd.Registry object. It seems like this object does not follow the standard Ext prototyping scheme. Am I missing something?
Code:
Ext.dd.Registry = function(){
var elements = {};
var handles = {};
var autoIdSeed = 0;
var getId = function(el, autogen){
if(typeof el == "string"){
return el;
}
var id = el.id;
if(!id && autogen !== false){
id = "extdd-" + (++autoIdSeed);
el.id = id;
}
return id;
};
return {
register : function(el, data){
data = data || {};
if(typeof el == "string"){
el = document.getElementById(el);
}
data.ddel = el;
elements[getId(el)] = data;
if(data.isHandle !== false){
handles[data.ddel.id] = data;
}
if(data.handles){
var hs = data.handles;
for(var i = 0, len = hs.length; i < len; i++){
handles[getId(hs[i])] = data;
}
}
},
unregister : function(el){
var id = getId(el, false);
var data = elements[id];
if(data){
delete elements[id];
if(data.handles){
var hs = data.handles;
for(var i = 0, len = hs.length; i < len; i++){
delete handles[getId(hs[i], false)];
}
}
}
},
getHandle : function(id){
if(typeof id != "string"){
id = id.id;
}
return handles[id];
},
getHandleFromEvent : function(e){
var t = Ext.lib.Event.getTarget(e);
// 20101120 MB - added this while loop to handle tree labels with html children instead of raw text
while (!t.id && t.parentNode) {
t = t.parentNode;
}
return t ? handles[t.id] : null;
},
getTarget : function(id){
if(typeof id != "string"){
id = id.id;
}
return elements[id];
},
getTargetFromEvent : function(e){
var t = Ext.lib.Event.getTarget(e);
return t ? elements[t.id] || handles[t.id] : null;
}
};
}();