When i use the below code it overrides the action-column delete/update links.
\'rowOptions\' => function ($model, $key, $index, $grid) {
return [
You could try this. It will make the whole row clickable as long as the user clicks on a td element that is not covered from another element. So also the action column is part of the clickable row, however, not the glyphicons.
<?= GridView::widget([
...
'rowOptions' => function ($model, $key, $index, $grid) {
return ['data-id' => $model->id];
},
...
]); ?>
<?php
$this->registerJs("
$('td').click(function (e) {
var id = $(this).closest('tr').data('id');
if(e.target == this)
location.href = '" . Url::to(['accountinfo/update']) . "?id=' + id;
});
");
See also documentation for event.target:
The target property can be the element that registered for the event or a descendant of it. It is often useful to compare event.target to this in order to determine if the event is being handled due to event bubbling. This property is very useful in event delegation, when events bubble.
User 'filterPosition'=>' ',
<?=
GridView::widget([
'dataProvider' => $dataProvider,
'filterModel' => $searchModel,
'resizableColumns' => true,
'containerOptions' => ['style' => 'overflow: auto'], // only set when $responsive = false
'headerRowOptions' => ['class' => 'kartik-sheet-style'],
'filterRowOptions' => ['class' => 'kartik-sheet-style'],
'pjax' => true,
'hover' => true,
'export' => false,
'columns' => $gridColumns,
'filterPosition'=>' ',
]);
?>