This extension provides actions, widgets and other tools for admin panel creation in Yii2 project.
For license information check the LICENSE-file.
The preferred way to install this extension is through composer.
Either run
php composer.phar require --prefer-dist yii2tech/admin
or add
"yii2tech/admin": "*"
to the require section of your composer.json.
This extension provides actions, widgets and other tools for admin panel creation in Yii2 project. These tools are meant to be used together for the rapid web application administration panel composition.
This extension provides several independent action classes, which provides particular operation support:
- [[yii2tech\admin\actions\Index]] - displays the models listing with search support.
- [[yii2tech\admin\actions\Create]] - supports creation of the new model using web form.
- [[yii2tech\admin\actions\Update]] - supports updating of the existing model using web form.
- [[yii2tech\admin\actions\Delete]] - performs the deleting of the existing record.
- [[yii2tech\admin\actions\View]] - displays an existing model.
- [[yii2tech\admin\actions\SoftDelete]] - performs the "soft" deleting of the existing record.
- [[yii2tech\admin\actions\Restore]] - performs the restoration of the "soft" deleted record.
- [[yii2tech\admin\actions\Callback]] - allows invocation of specified method of the model.
Please refer to the particular action class for more details.
For example CRUD controller based on provided actions may look like following:
namespace app\controllers;
use yii\web\Controller;
class ItemController extends Controller
{
public function actions()
{
return [
'index' => [
'class' => 'yii2tech\admin\actions\Index',
'modelClass' => $this->modelClass,
'searchModelClass' => 'app\models\ItemSearch',
],
'view' => [
'class' => 'yii2tech\admin\actions\View',
'modelClass' => 'app\models\Item',
],
'create' => [
'class' => 'yii2tech\admin\actions\Create',
'modelClass' => 'app\models\Item',
],
'update' => [
'class' => 'yii2tech\admin\actions\Update',
'modelClass' => 'app\models\Item',
],
'delete' => [
'class' => 'yii2tech\admin\actions\Delete',
'modelClass' => 'app\models\Item',
],
];
}
}
This extension provides several predefined controllers, which can be used as a base controller classes while creating particular controllers:
- [[yii2tech\admin\CrudController]] - implements a common set of actions for supporting CRUD for ActiveRecord.
Please refer to the particular controller class for more details.
This extension provides several widgets, which simplifies view composition for the typical use cases:
- [[yii2tech\admin\widgets\Alert]] - renders a message from session flash.
- [[yii2tech\admin\widgets\ButtonContextMenu]] - simplifies rendering of the context links such as 'update', 'view', 'delete' etc.
- [[yii2tech\admin\widgets\Nav]] - enhanced version of [[\yii\bootstrap\Nav]], which simplifies icon rendering.
This extension provides a code generators, which can be integrated with yii 'gii' module. In order to enable them, you should adjust your application configuration in following way:
return [
//....
'modules' => [
// ...
'gii' => [
'class' => 'yii\gii\Module',
'generators' => [
'adminMainFrame' => [
'class' => 'yii2tech\admin\gii\mainframe\Generator'
],
'adminCrud' => [
'class' => 'yii2tech\admin\gii\crud\Generator'
]
],
],
]
];
"MainFrame" generator creates a basic admin panel code, which includes layout files, main controller file and basic view files. The created structure is necessary for the correct rendering of the code created by "Admin CRUD" generator.
"Admin CRUD" generator is similar to regular "CRUD" generator, but it generates code, which use tools from this extension, so the result code is much more easier.