Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dmitrybtn/yii2-yimp
YIMP - Dashboard for Yii 2 based on Bootstrap 4
https://github.com/dmitrybtn/yii2-yimp
bootstrap4 yii yii2
Last synced: 4 months ago
JSON representation
YIMP - Dashboard for Yii 2 based on Bootstrap 4
- Host: GitHub
- URL: https://github.com/dmitrybtn/yii2-yimp
- Owner: dmitrybtn
- License: mit
- Created: 2019-09-06T06:54:19.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2019-11-05T15:43:49.000Z (about 5 years ago)
- Last Synced: 2024-09-30T22:17:00.613Z (4 months ago)
- Topics: bootstrap4, yii, yii2
- Language: PHP
- Size: 64.5 KB
- Stars: 14
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.md
Awesome Lists containing this project
README
## YIMP - Панель управления для Yii 2 на Bootstrap 4
### Концепция
YIMP - это панель управления, предназначенная для быстрого создания пользовательского интерфейса. Это не готовая админка, не CMS и даже не CMF. Код представлений нужно писать самостоятельно или с использованием Gii (шаблоны прилагаются).
YIMP представляет собой лейаут, адаптированный для мобильных устройств и включающий в себя заголовок приложения, заголовок страницы, хлебные крошки, три меню (верхнее, левое и правое) а также виджеты в боковых панелях. Эти свойства настраиваются в контроллерах и передаются в лейаут через специальный объект - навигатор.
Полезные ссылки: [Live demo](http://yimp.ru), [API documentation](http://yimp.ru/api/).
### Установка через Composer
Предпочтительным способом установки YIMP является Composer. Для установки введите введите в командной строке:
```bash
php composer.phar require dmitrybtn/yii2-yimp:"~1.0.0"
```или добавьте
```
"dmitrybtn/yii2-yimp": "~1.0.0"
```в секцию **require** вашего `composer.json`.
### Быстрый старт
#### Подключение лейаута
Лейаут хранится в папке `vendor/dmitrybtn/yii2-yimp/views/layout`. Для подключения лейаута
**рекомендуется скопировать его код в приложение**. Тем не менее, в простейших случаях можно подключить лейаут из пакета, для этого в настройках приложения нужно указать:```php
'layout' => '@dmitrybtn/yimp/views/layout',
```#### Подключение навигатора
В приложении необходимо определить класс, унаследованный от [\dmitrybtn\yimp\Navigator](http://yimp.ru/api/dmitrybtn-yimp-navigator.html). Этот класс будет использоваться для передачи данных из контроллера в лейаут. Он включает в себя набор свойств (полный перечень лучше посмотреть в API документации), которые задаются в контроллере и выводятся в лейауте. Унаследовав этот класс в своем приложении, рекомендуется сразу настроить меню, которые не будут зависеть от конкретного действия. Например, так:
```php
namespace app\components;class Navigator extends \dmitrybtn\yimp\Navigator
{
public function init()
{
parent::init();$this->menuLeft = [
['label' => 'Main menu'],
['label' => 'About', 'url' => ['/site/about']],
];
}
}
```В контроллере нужно определить свойство `nav`, являющееся объектом класса Navigator. В действиях контроллера нужно настроить своство `nav` желаемым образом. Например, так:
```php
class SiteController extends \yii\web\Controller
{
public $nav;public function init()
{
parent::init();$this->nav = new Navigator();
}public function actionAbout()
{
$this->nav->title = 'About';...
}
}
```#### Подключение Gii
В состав YIMP входят шаблоны для CRUD и контроллеров. Для их подключения в настройках приложения нужно указать:
```php
'modules' => [
...
'gii' => [
'class' => 'yii\gii\Module',
'allowedIPs' => ['127.0.0.1', '::1'],
'generators' => [
'crud' => [
'class' => 'yii\gii\generators\crud\Generator',
'templates' => [
'yimp' => '@dmitrybtn/yimp/gii/crud'
]
],
'controller' => [
'class' => 'yii\gii\generators\controller\Generator',
'templates' => [
'yimp' => '@dmitrybtn/yimp/gii/controller'
]
]
],
...
]
```Эти шаблоны переопределяют шаблоны, используемые Gii по умолчанию, причем изменения были по возможности минимальными. При необходимости, вы можете переопределить эти шаблоны согласно документации на Gii.
#### Подключение ErrorAction
В состав YIMP входит ErrorAction, который можно подключить согласно [соответствующему разделу документации на Yii](https://www.yiiframework.com/doc/guide/2.0/ru/runtime-handling-errors#using-error-actions).
### Рекомендации
Левое меню рекомендуется использовать как главное меню приложения. Верхнее меню - для опций текущего пользователя (логин, логаут, настройки профиля). Правое меню - для опций текущего действия (например, для действия View там будут пункты Update и Delete). Левое и верхнее меню рекомендуется настроить в вашей реализации класса Navigator, а правое меню - в коде действий.
Заголовки действий и хлебные крошки рекомендуется определять через статические методы контроллеров. Например, так:
```php
class OrderController extends \yii\web\Controller
{
public $nav;public function init()
{
parent::init();$this->nav = new Navigator();
}public static function titleIndex()
{
return 'Заказы';
}public static function titleView($order)
{
return 'Заказ № ' . $order->id;
}public static function crumbsToIndex()
{
return [
['label' => static::titleIndex(), 'url' => ['index']]
];
}public function actionIndex()
{
...
$this->nav->title = static::titleIndex();...
}public function actionView()
{
...
$this->nav->title = static::titleView();
$this->nav->crumbs = static::crumbsToIndex();...
}}
```В этом примере класс OrderController отвечает за заказы. Действие order/index будет имеет заголовок "Заказы". Логично, что слово "Заказы" также должно быть пунктом главного меню приложения, а также частью хлебных крошек для других действий. Как видите, это слово можно получить из любого места приложения, вызвав метод `OrderController::titleIndex()`.
Аналогично с хлебными крошками. Например, если появляется класс ItemController, отвечающий за товары в заказе, то действие `item/create` может иметь хлебные крошки "Главная / Заказы / Заказ № 1 / Добавить товар". Для формирования таких хлебных крошек в классе ItemController достаточно будет вызвать `$this->nav->crumbs = OrderController::crumbsToView($item->order)`.
Подобный подход реализован в шаблонах Gii, входящих в состав YIMP.
### Дополнительно
#### Виджеты
Свободное место в футере и боковых панелях может быть использовано для виджетов. Если вам нужно вывести виджет только для одного действия, вы можете в представлении для этого действия определить [блок](https://www.yiiframework.com/doc/guide/2.0/ru/structure-views#using-blocks):
```php
beginBlock(Yimp::SIDEBAR_RIGHT); ?>
Caption
Your widget HTML
endBlock(); ?>
```Для использования блоков в YIMP определены константы `Yimp::SIDEBAR_LEFT`, `Yimp::SIDEBAR_RIGHT`, `Yimp::FOOTER`.
Обратите внимание, что боковые панели с виджетами отображаются только на больших экранах (xl). Для меньших экранов рекомендуется переопределить виджеты подобно тому, как это сделано для [элементов управления формой](https://github.com/dmitrybtn/yii2-yimp/blob/master/src/widgets/views/controls.php).
#### Иконки
Поскольку Bootstrap 4 не поддерживает иконки, в YIMP используются иконки от [FontAwesome](https://fontawesome.com/icons). Они подключаются в момент регистрации ресурсов YIMP, поэтому вы можете использовать их в своем приложении согласно документации к FontAwesome.
#### Меню
Для настройки левого, правого и верхнего меню используются свойства навигатора `menuLeft`, `menuRight` и `menuTop`. В этих свойствах необходимо указать настройки для свойства [yiisoft/bootstrap4/Nav::items](https://www.yiiframework.com/extension/yiisoft/yii2-bootstrap4/doc/api/2.0/yii-bootstrap4-nav#$items-detail), например так:
```php
public function actionIndex()
{
...$this->nav->menuRight = [
['label' => 'Options'],
['label' => static::titleCreate(), 'url' => ['create']],
];...
}```
Помимо известных настроек, могут быть указаны также следующие настройки:
- `active`: В оригинальном виджете он имеет тип bool. В YIMP можно также использовать строку, соответствующую маске маршрута. Например, если для главного меню указать `'active' => 'order/*'`, пункт будет активен для любого действия из OrderController. Подробности см. [MenuAdapter](http://yimp.ru/api/dmitrybtn-yimp-menuadapter.html), [RouteHelper](http://yimp.ru/api/dmitrybtn-yimp-routehelper.html).
- `visibleMode`: YIMP рендерит каждое меню дважды - для десктопов и для мобильных устройств. Если вы хотите вывести элемент только для одного типа устройств, укажите здесь `Yimp::DESKTOP` или `YIMP::MOBILE`. Обратите внимание, что эта настройка никак не связана с CSS.#### Стилизация
YIMP написан с расчетом на максимальное использование возможностей Bootstrap 4. Все, что можно было сделать классами Bootstrap 4, сделано именно так. Тем не менее, для части элементов пришлось определять собственные стили, которые используют переменные Bootstrap 4 в основном для определения цветов. Стили Yimp хранятся в файле vendor\dmitrybtn\yii2-yimp\assets\css\yimp.scss.
Если вы решите использовать собственную таблицу стилей, то нужно [отключить стили Bootstrap](https://www.yiiframework.com/extension/yiisoft/yii2-bootstrap4/doc/guide/2.0/ru/topics-sass)
и стили Yimp, указав в настройках приложения:```php
'assetManager' => [
'bundles' => [
'yii\bootstrap4\BootstrapAsset' => [
'css' => [],
],
'dmitrybtn\yimp\Asset' => [
'css' => [],
]
]
]
```