I am now building a web application with Ext-JS 4.0.2, and I am using a editable grid to control the data to be shown for a table on the same page.
To make the grid editable, I followed the API documentation and used the following:
selType: 'cellmodel',
plugins: [
Ext.create('Ext.grid.plugin.CellEditing', {
clicksToEdit: 2
})
]
However, for this grid, there are several cells that are not supposed to be changed.
I could simply let the event handler change the data back to the right state once it is changed in the grid, but this seems to be hacky, hard to maintain, and unreadable. Is there any better way to do this? I read the API but cannot find any useful attributes.
UPDATE
As for this particular app, just disable the first row would work. But I am also interested in choose several grid and make them not editable (imagine a Sudoku game with a grid).
As I’ve understand from comments you want to make first row not editable. There is ugly but quick solution. Assign to your plugin
beforeedithandler. And when event is being fired check what row is being edited. If first –return false:Check out docs for
beforeedit.UPDATE
Docs say that
beforeedithas such set of params:But there is mistake. The correct sequance is:
I’ve updated example due to this fact.