mickgeek / yii2-actionbar
A control bar with bulk actions for the GridView widget.
Installs: 37 980
Dependents: 0
Suggesters: 0
Security: 0
Stars: 34
Watchers: 3
Forks: 12
Open Issues: 0
Type:yii2-extension
Requires
- yiisoft/yii2: *
This package is not auto-updated.
Last update: 2024-12-23 07:33:50 UTC
README
ActionBar is a Yii 2 widget that render the drop-down list for manipulation selected the GridView items and control buttons. The widget permits you to fully customize elements.
Installation
You can install the widget using Composer. Just run the following command under your application folder:
php composer.phar require --prefer-dist mickgeek/yii2-actionbar
Usage
use mickgeek\actionbar\Widget as ActionBar; <?= ActionBar::widget([ 'grid' => 'user-grid', ]) ?>
But first, add the action to your controller:
public function actions() { return [ 'delete-multiple' => [ 'class' => 'mickgeek\actionbar\DeleteMultipleAction', 'modelClass' => 'app\models\User', ], ]; }
Note: You can write your action without using
DeleteMultipleAction
class.
Tip: For information about properties and methods of the widget, see the bundled
DOCUMENTATION.md
.
Examples
Below are two examples showing some features of the widget.
Advanced Bulk Actions
The code in the view:
use yii\helpers\Url; use mickgeek\actionbar\Widget as ActionBar; <?= ActionBar::widget([ 'grid' => 'user-grid', 'templates' => [ '{bulk-actions}' => ['class' => 'col-xs-4'], '{create}' => ['class' => 'col-xs-8 text-right'], ], 'bulkActionsItems' => [ 'Update Status' => [ 'status-active' => 'Active', 'status-blocked' => 'Blocked', ], 'General' => ['general-delete' => 'Delete'], ], 'bulkActionsOptions' => [ 'options' => [ 'status-active' => [ 'url' => Url::toRoute(['update-status', 'status' => 'active']), 'disabled' => !Yii::$app->user->can('updateUserStatus'), ], 'status-blocked' => [ 'url' => Url::toRoute(['update-status', 'status' => 'blocked']), 'disabled' => !Yii::$app->user->can('updateUserStatus'), ], 'general-delete' => [ 'url' => Url::toRoute('delete-multiple'), 'data-confirm' => 'Are you sure?', 'disabled' => !Yii::$app->user->can('deleteUser'), ], ], 'class' => 'form-control', ], ]) ?>
The code in the User controller:
public function actions() { return [ 'delete-multiple' => [ 'class' => 'mickgeek\actionbar\DeleteMultipleAction', 'modelClass' => 'app\models\User', 'beforeDeleteCallback' => function ($action) { if (!Yii::$app->user->can('deleteOwnAccount', Yii::$app->getRequest()->post('ids'))) { Yii::$app->getSession()->setFlash('error', 'You cannot delete your own account.'); $action->redirect(); Yii::$app->end(); } }, 'afterDeleteCallback' => function ($action) { Yii::$app->getSession()->setFlash('success', 'The selected users have been deleted successfully.'); }, ], ]; } public function actionUpdateStatus($status) { ... }
Custom Buttons
The code:
use mickgeek\actionbar\Widget as ActionBar; /* @var $model app\models\User */ <?= ActionBar::widget([ 'templates' => [ '{back}' => ['class' => 'col-xs-4'], '{update} {delete}' => ['class' => 'col-xs-8 text-right'], ], 'elements' => [ 'back' => Html::a( '<span class="glyphicon glyphicon-chevron-left"></span> ' . 'Back', ['/users/index'], ['class' => 'btn btn-default'] ), 'update' => Html::a( '<span class="glyphicon glyphicon-pencil"></span> ' . 'Update', ['/users/update', 'id' => $model->id], ['class' => 'btn btn-default'] ), 'delete' => Html::a( '<span class="glyphicon glyphicon-trash"></span> ' . 'Delete', ['/users/delete', 'id' => $model->id], ['class' => 'btn btn-default'] ), ], ]) ?>
License
This extension is released under the BSD 3-Clause License. See the bundled LICENSE.md
for details.