Use beforeedit
event:
grid.on('beforeedit', function(editor, e) {
if (e.colIdx === 0 && e.record.get('status') == 4)
return false;
});
UPDATE
The solution above is not working for rowEditor.
However you can make needed field to be disabled on beforeedit
. To do that you should be able to access rowediting plugin. Assign pluginId to plugin:
plugins: [
Ext.create('Ext.grid.plugin.RowEditing', {
clicksToEdit: 1,
pluginId: 'rowEditing'
})
],
Now just disable needed field if some conditions are met:
grid.on('beforeedit', function(editor, e) {
if (e.record.get('status') === 4 ){
grid.getPlugin('rowEditing').editor.form.findField('fieldToDisable').disable();
}
else{
grid.getPlugin('rowEditing').editor.form.findField('fieldToDisable').enable();
});
Here is demo (try to edit first row).
Edit
If the above JSFiddle does not work, try its updated version.