использовать Ext.Editor
(посмотрите это демо ):
var editor = new Ext.Editor({
field: {
xtype: 'textfield'
}
});
tree.menu = Ext.create('Ext.menu.Menu', {
items: [
// ...
{text: 'Edit', action: 'edit'},
// ...
]
});
tree.on('itemcontextmenu', function(view, record, HTMLTarget, i, e) {
// Let's save record and HTMLTarget for further use
tree.menu.record = record;
tree.menu.HTMLTarget = HTMLTarget;
tree.menu.showAt(e.getXY());
e.preventDefault();
});
tree.menu.on('click', function(menu, item, e){
if (!item) return;
switch(item.action) {
// ...
case 'edit':
editor.startEdit(Ext.get(menu.HTMLTarget), menu.record.get('text'));
editor.on('complete', function(me, value) {
this.record.set('text', value);
}, menu, {single: true});
break;
// ...
};
});