mtangoo / yii2-fullcalendar
Yii2 fullcalendar Widgets
Installs: 130
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:yii2-extension
Requires
- php: >=7.4
- bower-asset/fullcalendar: 3.10.*
- yiisoft/yii2: *
Requires (Dev)
This package is auto-updated.
Last update: 2024-11-24 16:10:56 UTC
README
JQuery Fullcalendar Yii2 Extension JQuery from: http://arshaw.com/fullcalendar/ Version 2.1.1 License MIT
JQuery Documentation: http://arshaw.com/fullcalendar/docs/ This is a fork of Yii2 Extension by philipp@frenzel.net
Installation
Package is although registered at packagist.org - so you can just add one line of code, to let it run!
add the following line to your composer.json require section:
"mtangoo/yii2-fullcalendar":"*",
or run:
composer require mtangoo/yii2-fullcalendar,
Usage
Quickstart Looks like this:
use hosannahighertech\calendar\Calendar; use hosannahighertech\calendar\models\Event; $events = []; //Testing $items = [ [ 'id' => 1, 'title' => 'Event 1', 'start' => date('Y-m-d\TH:i:s\Z'), 'nonstandard' => [ 'field1' => 'Something I want to be included in object #1', 'field2' => 'Something I want to be included in object #2', ] ], [ 'id' => 1, 'title' => 'Event 2', 'start' => date('Y-m-d\TH:i:s\Z',strtotime('tomorrow 6am')), ] ]; foreach($items as $item){ $events[] = new Event($item); } ?> <?= Calendar::widget(['events'=> $events]) ?>
Note, that this will only view the events without any detailed view or option to add a new event.. etc.
Non-Standard fields
You can add non-standard fields via the non-standard fields array, for which you can pass any key/value pair, as described in the Event Fields documentation.
So, using the Quick Start example above, you can read field1
and fields2
in your JavaScript using notation similar to event.nonstandard.field1
and event.nonstandard.field2
.
AJAX Usage
If you wanna use ajax loader, this could look like this:
20171023 ajaxEvents are replaced by events - pls. check fullcalendar io documentation for details
<?= Calendar::widget([ 'options' => [ 'lang' => 'de', //... more options to be defined here! ], 'events' => Url::to(['/timetrack/default/jsoncalendar']) ]); ?>
and inside your referenced controller, the action should look like this:
public function actionJsoncalendar($start=NULL,$end=NULL,$_=NULL){ \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON; $times = \app\modules\timetrack\models\Timetable::find()->where(array('category'=>\app\modules\timetrack\models\Timetable::CAT_TIMETRACK))->all(); $events = array(); foreach ($times AS $time){ //Testing $Event = new Event(); $Event->id = $time->id; $Event->title = $time->categoryAsString; $Event->start = date('Y-m-d\TH:i:s\Z',strtotime($time->date_start.' '.$time->time_start)); $Event->end = date('Y-m-d\TH:i:s\Z',strtotime($time->date_end.' '.$time->time_end)); $events[] = $Event; } return $events; }