Extend GridView ActionColumn with additional icon

前端 未结 3 929
轻奢々
轻奢々 2020-12-05 05:18

I\'m building a webapp with Yii2 framework that will provide users (logged in) the capability to download pre-uploaded files by administrators.

I\'ve created the act

相关标签:
3条回答
  • 2020-12-05 05:19

    template attribute is important

    echo GridView::widget([
        'dataProvider' => $dataProvider,
        'filterModel' => $searchModel,
        'columns' => [
            ['class' => 'yii\grid\SerialColumn'],
             'id', 
             'title',
            ['class' => 'yii\grid\ActionColumn',
                'buttons' => [
                    'additional_icon' => function ($url, $model, $key) {
                        return Html::a ( '<span class="glyphicon glyphicon-th-list" aria-hidden="true"></span> ', ['controller/action', 'id' => $model->id] );
                    },
                ],
                'template' => '{update} {view} {delete} {additional_icon}'
    
    
            ],
        ],
    ]);
    
    0 讨论(0)
  • 2020-12-05 05:40

    How to add another action button in kartik-v yii2 grid action column?

    Just see following example.I have added copy button.

    [
        'class' => 'kartik\grid\ActionColumn',
        'dropdown' => false,
        'vAlign'=>'middle',
        'template' => '{delete} {view} {update} {copy}',
        'urlCreator' => function($action, $model, $key, $index) { 
                return Url::to([$action,'id'=>$key]);
        },
        'buttons'=>[
            'copy' => function ($url, $model, $key) {
                return Html::a('<span class="glyphicon glyphicon-copy"></span>', ['copy', 'id'=>$model->id],['title'=>'Copy']);
            },
        ],      
        'viewOptions'=>['role'=>'modal-remote','title'=>'View','data-toggle'=>'tooltip'],
        'updateOptions'=>['role'=>'modal-remote','title'=>'Update', 'data-toggle'=>'tooltip'],
        'deleteOptions'=>['role'=>'modal-remote','title'=>'Delete', 
                          'data-confirm'=>false, 'data-method'=>false,// for overide yii data api
                          'data-request-method'=>'post',
                          'data-toggle'=>'tooltip',
                          'data-confirm-title'=>'Are you sure?',
                          'data-confirm-message'=>'Are you sure want to delete this item'], 
    ],
    
    0 讨论(0)
  • 2020-12-05 05:46

    Extend declaration of template and buttons like this:

    [
        'class' => 'yii\grid\ActionColumn',
        'template' => '{download} {view} {update} {delete}',
        'buttons' => [
            'download' => function ($url) {
                return Html::a(
                    '<span class="glyphicon glyphicon-arrow-down"></span>',
                    $url, 
                    [
                        'title' => 'Download',
                        'data-pjax' => '0',
                    ]
                );
            },
        ],
    ],
    

    The download icon with the url will be added to existing set of icons. You can see for example how default icons are rendered here.

    In common case you don't even have to build link manually, it will be constructed based on the button name and model primary key, for example /download?id=1.

    In case you want different url special property exists, it's called $urlCreator, but you can also change it right in the button rendering closure, for example:

    'download' => function ($url, $model) {
        return Html::a(
            '<span class="glyphicon glyphicon-arrow-download"></span>',
            ['another-controller/anotner-action', 'id' => $model->id], 
            [
                'title' => 'Download',
                'data-pjax' => '0',
            ]
        );
    },
    
    0 讨论(0)
提交回复
热议问题