yii2fullcalendar eventDrop删除event.color和event.description

问题描述 投票:0回答:2

我有yii2fullcalendar eventDrop的问题。我为eventDrop和eventRender创建了一个JsExpression,如下所示。

问题是,当我将事件拖放到另一天并刷新页面时,它会丢失它的颜色,描述将变为未定义。

使用eventRender,我将颜色和描述属性添加到事件类。

我尝试修改fullcalendar.css和fullcalendar.min.css .fc-event但没有成功

这是代码

<?php
            $JsEventRender = 'function(event, element) {
                element.addClass(event.description);
                element.addClass(event.color);
            }'
        ?>

<?php
            $JsEventDrop = 'function(event, delta, revertFunc) {
                    var event_data = {
                        id: event.id,
                        titulo: event.title,
                        descripcion: event.description,
                        fecha_inicio: $.fullCalendar.formatDate(event.start, "YYYY-MM-DD"),
                        hora_inicio: $.fullCalendar.formatDate(event.start, "HH:mm"),
                        hora_termino: $.fullCalendar.formatDate(event.end, "HH:mm"),
                        fecha_termino: $.fullCalendar.formatDate(event.end, "YYYY-MM-DD"),
                        color: event.color,
                    };
                    if (!confirm("¿Está seguro que desea modificar la fecha y/o hora?")) {
                        revertFunc();
                    }
                    else {
                        $.ajax({
                            type: "POST",
                            url: "index.php?r=calendario/update" + "&id=" + event_data.id 
                            + "&titulo=" + event_data.titulo + "&descripcion=" + event_data.description
                            + "&fecha_inicio=" + event_data.fecha_inicio + "&hora_inicio=" + event_data.hora_inicio 
                            + "&hora_termino=" + event_data.hora_termino + "&fecha_termino=" + event_data.fecha_termino
                            + "&color=" + event_data.color,
                            success: function(json) {
                                alert("Fecha y/o hora modificada correctamente");
                            }
                        });

                    }
                }'
        ?>

<?= yii2fullcalendar\yii2fullcalendar::widget([
            'events' => $events,
            'id' => 'calendar',
            'options' => [
                      'lang' => 'es',
                    ],
            'clientOptions' => [
                    'selectable' => false,
                    'editable' => true,
                    'droppable' => true,
                    'header' => [
                        'left' => 'prev,next,today',
                        'center' => 'title',
                        'right' => 'month,agendaWeek,agendaDay,listDay',
                        ],
                'minTime' => '08:00',
                'maxTime' => '21:00',
                'height' => 'auto',
                'snapDuration' => '00:05:00',
                'eventRender' => new JsExpression($JsEventRender),
                'eventClick' => new JsExpression($JsEventClick),
                'eventDrop' => new JsExpression($JsEventDrop),
                'eventResize' => new JsExpression($JsEventResize),
                    ],
            ]);
        ?>

<?php
public function actionCreate($fecha_inicio, $fecha_termino)
    {   
        $model = new Calendario();
        $model->fecha_inicio = $fecha_inicio;
        $model->fecha_termino = $fecha_termino;
        if ($model->load(Yii::$app->request->post()) && $model->save()) {
            return $this->redirect(['index']);
        }

        return $this->renderAjax('create', [
            'model' => $model,
        ]);
    }

public function actionUpdate($id, $titulo, $descripcion, $fecha_inicio, $hora_inicio, $hora_termino, $fecha_termino, $color)
    {
        $model = $this->findModel($id);
        $model->id = $id;
        $model->titulo = $titulo;
        $model->descripcion = $descripcion;
        $model->fecha_inicio = $fecha_inicio;
        $model->hora_inicio = $hora_inicio;
        $model->hora_termino = $hora_termino;
        $model->fecha_termino = $fecha_termino;
        $model->color = $color;
        $model->save();

        if ($model->load(Yii::$app->request->post()) && $model->save()) {
            return $this->redirect(['index']);
        }

        return $this->renderAjax('update', [
            'model' => $model,
        ]);
    }

起初我认为这是一个Url问题,但事实并非如此。我在Yii Framework的论坛https://forum.yiiframework.com/t/fullcalendar-eventdrop-removes-event-color-and-event-description/125790上发布了同样的问题

yii2 fullcalendar
2个回答
0
投票

去做

根据讨论,您需要使用eventSources动态加载事件,然后在事件更新后重新获取事件。

如何

我之前写的previous answer可以涵盖一个主要部分,它详细描述了如何使用eventSources选项,因此我不会详细介绍这些细节。唯一与答案不同的是,当您在日历上拖放事件时,您必须重新获取事件,并且您已经在使用选项eventDrop获取事件属性并发送ajax调用要更新数据库中的事件属性,所以您只需要添加

  • 在控制器中创建一个动作,它以我之前提到的上一个答案中描述的格式返回事件列表。
  • eventSources选项中列出该操作的url,该选项包含['/ controller / action']等网址数组。
  • 通过调用refetchEvents方法更新事件后重新获取事件,如下所示。 $('#calendar').fullCalendar('refetchEvents'); 这需要是你为eventDrop编写的脚本的最后一行,所以你完整的javascript代码看起来像 $JsEventDrop = 'function(event, delta, revertFunc) { var event_data = { id: event.id, titulo: event.title, descripcion: event.description, fecha_inicio: $.fullCalendar.formatDate(event.start, "YYYY-MM-DD"), hora_inicio: $.fullCalendar.formatDate(event.start, "HH:mm"), hora_termino: $.fullCalendar.formatDate(event.end, "HH:mm"), fecha_termino: $.fullCalendar.formatDate(event.end, "YYYY-MM-DD"), color: event.color, }; if (!confirm("¿Está seguro que desea modificar la fecha y/o hora?")) { revertFunc(); } else { $.ajax({ type: "POST", url: "index.php?r=calendario/update" + "&id=" + event_data.id + "&titulo=" + event_data.titulo + "&descripcion=" + event_data.description + "&fecha_inicio=" + event_data.fecha_inicio + "&hora_inicio=" + event_data.hora_inicio + "&hora_termino=" + event_data.hora_termino + "&fecha_termino=" + event_data.fecha_termino + "&color=" + event_data.color, success: function(json) { alert("Fecha y/o hora modificada correctamente"); } }); } //this line will refetch the events on the calendar with the newly saved values $("#calendar").fullCalendar("refetchEvents"); }'

0
投票

我通过将actionUpdate更改为默认值并添加了两个名为actionUpdateDrop和actionUpdateResize的新操作来解决这个问题,每个操作分别对应于JsExpressions,JsEventDrop和JsEventResize。我发现eventRender根本不起作用所以我删除了它。我还更改了JsExpressions以调用这些操作而不传递tittle,description和color,因为更新中不需要这些参数。神奇的事件现在保持它的描述和颜色。

//CalendarioController.php

public function actionUpdate($id)
    {
        $model = $this->findModel($id);

        if ($model->load(Yii::$app->request->post()) && $model->save()) {
            return $this->redirect(['index']);
        }

        return $this->renderAjax('update', [
            'model' => $model,
        ]);
    }

    public function actionUpdateDrop($id, $fecha_inicio, $hora_inicio, $hora_termino, $fecha_termino)
    {
        $model = $this->findModel($id);
        $model->fecha_inicio = $fecha_inicio;
        $model->hora_inicio = $hora_inicio;
        $model->hora_termino = $hora_termino;
        $model->fecha_termino = $fecha_termino;
        $model->save();

        if ($model->load(Yii::$app->request->post()) && $model->save()) {
            return $this->redirect(['index']);
        }

        return $this->render('update', [
            'model' => $model,
        ]);
    }

    public function actionUpdateResize($id, $hora_inicio, $hora_termino)
    {
        $model = $this->findModel($id);
        $model->hora_inicio = $hora_inicio;
        $model->hora_termino = $hora_termino;
        $model->save();

        if ($model->load(Yii::$app->request->post()) && $model->save()) {
            return $this->redirect(['index']);
        }

        return $this->render('update', [
            'model' => $model,
        ]);
    }

//Index.php

<p>
        <?php
            $JsEventDrop = 'function(event, delta, revertFunc) {
                    var event_data = {
                        id: event.id,
                        fecha_inicio: $.fullCalendar.formatDate(event.start, "YYYY-MM-DD"),
                        hora_inicio: $.fullCalendar.formatDate(event.start, "HH:mm"),
                        hora_termino: $.fullCalendar.formatDate(event.end, "HH:mm"),
                        fecha_termino: $.fullCalendar.formatDate(event.end, "YYYY-MM-DD"),
                    };
                    if (!confirm("¿Está seguro que desea modificar la fecha y/o hora?")) {
                        revertFunc();
                    }
                    else {
                        $.ajax({
                            type: "POST",
                            url: "index.php?r=calendario/update-drop" + "&id=" + event_data.id 
                            + "&fecha_inicio=" + event_data.fecha_inicio + "&hora_inicio=" + event_data.hora_inicio 
                            + "&hora_termino=" + event_data.hora_termino + "&fecha_termino=" + event_data.fecha_termino,
                            success: function(json) {
                                alert("Fecha y/o hora modificada correctamente");
                            }
                        });

                    }
                }'
        ?>
    </p>

    <p>
        <?php
            $JsEventResize = 'function(event, delta, revertFunc) {
                    var event_data = {
                        id: event.id,
                        hora_inicio: $.fullCalendar.formatDate(event.start, "HH:mm"),
                        hora_termino: $.fullCalendar.formatDate(event.end, "HH:mm"),
                    };
                    if (!confirm("¿Está seguro que desea modificar la hora?")) {
                        revertFunc();
                    }
                    else {
                        $.ajax({
                            type: "POST",
                            url: "index.php?r=calendario/update-resize" + "&id=" + event_data.id 
                            + "&hora_inicio=" + event_data.hora_inicio + "&hora_termino=" + event_data.hora_termino,
                            success: function(json) {
                                alert("Hora modificada correctamente");
                            }
                        });
                    }
               }'
         ?>
   </p>
© www.soinside.com 2019 - 2024. All rights reserved.