I this post, I want you to show how you can add clickable "button" in a column. In fact is it not a real button, but it will allow you to take track which cell is clicked and to take actions then.
First we need a grid with some columns in it. The column which needs action should be a template column so you can style it like you want. Something like this:
Ext.define('SiteCockpit.view.ExampleGrid', { extend: 'Ext.grid.Grid', alias: 'widget.examplegrid', requires: [ 'Ext.grid.column.Template', 'Ext.XTemplate', 'Ext.grid.plugin.MultiSelection', 'Ext.grid.plugin.Editable' ], config: { itemId: 'exampleGrid', store: 'dummyStore', title: 'Example Grid', columns: [ { xtype: 'templatecolumn', tpl: [ '<tpl>', ' <div class="button1-field"></div>', '<tpl>' ], width: 50 }, { xtype: 'templatecolumn', tpl: [ '<tpl>', ' <div class="button2-field"></div>', '<tpl>' ], width: 50 }, { xtype: 'column', fdname: 'exidv', width: 150, align: 'center', dataIndex: 'exidv', text: 'exidv' } ] } })
As you can see the first and the second column do not have any text just a class. If you want some text just add by yourself.
Now we need to declare these classes in the sass to get a button like style. It is up to you how you want to style it. I just added 2 icons.
//// //.button1-field { content: ""; height: 2.5em; width: 2.5em; background-image: url(); background-size: 1.5em; background-size: 1.5em; display: block; background-repeat: no-repeat; background-position: bottom; } .button2-field { content: ""; height: 2.5em; width: 2.5em; background-image: url(); display: block; background-size: 2em; background-size: 2em; background-repeat: no-repeat; background-position: bottom; }
Next we need to know when and more important which cell was tapped! I took this logic in a separate controller. We use the classes to know which one was tapped. It sounds pretty simple and it even is :)
Ext.define('SiteCockpit.controller.gridController', { extend: 'Ext.app.Controller', config: { control: { "grid": { itemtap: 'onDetailGridTap' } } }, onDetailGridTap: function(dataview, index, target, record, e, eOpts) { var me = this; switch (e.target.className) { case 'button1-field': // First row was tapped! break; case 'button2-field': // Second row was tapped! break; } } })
I hope it is all clear and will help you a bit until the action column is supported :)
Keine Kommentare:
Kommentar veröffentlichen