understeam / yii2-calendar-widget
Yii2 calendar widget
Installs: 702
Dependents: 0
Suggesters: 0
Security: 0
Stars: 5
Watchers: 5
Forks: 4
Open Issues: 1
Type:extension
Requires
- php: >=5.4
- ext-intl: *
- yiisoft/yii2: ^2.0
- yiisoft/yii2-bootstrap: ^2.0
Requires (Dev)
- phpunit/phpunit: ^5.4
This package is not auto-updated.
Last update: 2025-01-02 02:34:25 UTC
README
Компонент предназначен для отображения данных внутри календаря с разбивкой по неделям или месяцам.
Установка
Установка производится через Composer:
$ composer require understeam/yii2-calendar-widget:^0.1 --prefer-dist
После этого компонент будет установлен в директорию vendor, а его классы будут
доступны в пространстве имён understeam\calendar
.
Настройка
Для начала нужно понять - какую модель вы желаете отображать в календаре. Например,
app\models\Event
. Выбранная модель должна наследовать интерфейс
understeam\calendar\ItemInterface
, а так же использовать примесь (trait)
understeam\calendar\ActiveRecordItemTrait
<?php namespace app\models; use understeam\calendar\ItemInterface; use understeam\calendar\ActiveRecordItemTrait; class Event extends \yii\db\ActiveRecord implements ItemInterface { use ActiveRecordItemTrait; }
Также необходимо добавить компонент в конфигурацию приложения:
'components' => [ 'calendar' => [ 'class' => 'understeam\calendar\ActiveRecordCalendar', // Имя класса календаря 'modelClass' => 'app\models\Event', // Имя класса модели 'dateAttribute' => 'date', // Атрибут модели, в котором хранится дата (тип в БД timestamp или datetime) 'dateRange' => [time() + 86400, time() + 2592000] // период, в который будет доступно событие onClick // Так же в dateRange можно передать функцию, которая должна вернуть нужный массив в случае если нужны динамические вычисления // 'dateRange' => ['app\models\User', 'getCalendarRange'], 'filter' => [ // Фильтр ActiveQuery, который будет применён. Возможно указывать callable для фильтрации 'status' => 1, ], // Пример // 'filter' => function ($query, $startTime, $endTime) { // return $query->andWhere(['userId' => Yii::$app->user->id]); // }, // Или так // 'filter' => ['app\models\User', 'filterCalendarQuery'], ], ],
Подключение в контроллер
Чтобы отобразить календарь на странице достаточно добавить action
в нужный контроллер:
public function actions() { return [ 'calendar' => [ 'class' => 'understeam\calendar\CalendarAction', 'calendar' => 'calendar', // ID компонента календаря (да, можно подключать несколько) 'usePjax' => true, // Использовать ли pjax для ajax загрузки страниц 'widgetOptions' => [ // Опции виджета (см. CalendarWidget) 'clientOptions' => [ // Опции JS плагина виджета 'onClick' => new JsExpression('showPopup'), // JS функция, которая будет выполнена при клике на доступное время 'onFutureClick' => new JsExpression('buyPlan'), 'onPastClick' => new JsExpression('showError'), // Все эти функции принимают 2 параметра: date и time // Для тестирования можно использовать следующий код: // 'onClick' => new JsExpression("function(d,t){alert([d,t].join(' '))}") ], ], ], ]; }
Подключение календаря как виджета
Этот вариант нужно использовать для подключения виджета как часть другой страницы. С этим немного сложнее, т.к. в виджет нужно передавать некоторый набор данных, а именно:
grid
- сформированный массив сетки календаряviewMode
- режим просмотра (неделя / месяц)period
- ОбъектDatePeriod
, где начало и конец - это период, который выбран в календареcalendar
- НаследникCalendarInterface
, компонент календаря
Общую логику можно проследить в CalendarAction
.
Этот момент планируется улучшить путём введения сущности CalendarGrid
, в которую будет
вынесено формирование сетки и методы для определения периодов.
Планы
На данный момент календарь оптимизирован для работы с ActiveRecord
, однако вы можете написать
свой компонент-наследник CalendarInterface
для конфигурации или забора данных. В будущем
планируется разработать простой класс календаря, без привязки к ActiveRecord
.