1

如何在 fullcaledar 中使用 startParam 和 endParam?我不太了解 jQuery 和 Javascript。视图在 route:example.com/agenda中,然后我认为我必须将startParamendParam按以下方式放在我的脚本中:

    startParam: 'agenda.start',
    limitParam : 'agenda.limit',

这个想法是通过限制这两个参数来避免事件加载缓慢(大约 10 秒),以便只加载当时在页面上看到的内容。我理解的很好吗?这不起作用,我的意思是它继续缓慢加载,其余的工作完美。我该怎么做?谢谢。

这是我从 json 文件收集数据的完整文件my-fullcalendar.js :

var currentLangCode = $("#lang_js").data('value');

$('#calendar').fullCalendar({

    locale:currentLangCode,
    eventColor: '#58C1AB',
    eventTextColor: '#fff',
    startParam: 'agenda.start',
    limitParam : 'agenda.limit',

    eventClick:  function(event, jsEvent, view) {  // when some one click on any event

        if(currentLangCode == 'en'){
            startdate = moment(event.start).format('ddd, MMM D');
            enddate = moment(event.end).format('ddd, MMM D YYYY');
        }else{
            startdate = moment(event.start).format('dddd, D MMMM YYYY');
            enddate = moment(event.end).format('dddd, D MMMM YYYY');
        }

        starttime = moment.utc((event.start), "H:mm");
        endtime = moment.utc((event.end), "H:mm");

        var s_time = starttime.format("H:mm");
        var e_time = endtime.format("H:mm");

        if(s_time == '0:00'){
            var mytime = '';
        }else{
            var mytime = '<img src="images/web/icons/clock.svg" class="icono" width="18"> ' + s_time + ' - ' + e_time;
        }

        if(enddate == startdate){
            var mydate = '<img src="images/web/icons/date.svg" class="icono" width="18"> ' + startdate;
        }else if(event.end == null){
            var mydate = '<img src="images/web/icons/date.svg" class="icono" width="18"> ' + startdate;
        }else{
            var mydate = '<img src="images/web/icons/date.svg" class="icono" width="18"> ' + startdate + ' - ' + enddate;
        }

        if((event.imagen)){
            var myimage = '<img src="'+(event.imagen)+'" width="100%"/>';
        }else{
            var myimage = '';
        }
        var myplace = '<img src="images/web/icons/map-marker.svg" class="icono" width="18"/> ' +(event.lugar);

        $('#modalTitle').html(event.title);
        $('#modalPlace').html(myplace);
        $('#modalDate').html(mydate);
        $('#modalTime').html(mytime);
        $('#modalImage').html(myimage);

        $('#calendarModal').modal();
    },

    header: {
        left: 'prev,next today myCustomButton',
        center: 'title',
        right: 'month,agendaWeek,agendaDay'
    },

    editable: false,
    eventLimit: true,
    events:{
        url:'agenda/evento'
    },


});

这就是控制器。我正在使用 Laravel 5.4:

class EventoController extends Controller
{
public function index()
{
        return view('web.agenda.index', compact('calendar'));
}

public function api(Request $request)
{

    $events = Evento::where('active', '1')->orderBy('start_date')->get();

    $lang = Session::get('lang');
    if($lang == 'en') $lang_id = '2';
    elseif($lang == 'pt') $lang_id = '3';
    else $lang_id = '1';

    $data = [];
    foreach($events as $event){

        foreach($event->langs as $event_lang){
            if($event_lang->lang_id == $lang_id and $event_lang->evento_id == $event->id){

                // title and place
                $title[]=$event_lang->text;
                $place[]=$event_lang->place;

                $id[] = $event->id;

                // start
                if($event->start_time){
                    $start[] = $event->start_date.'T'.$event->start_time;
                } else{
                    $start[] = $event->start_date;
                }

                // end
                if($event->end_time){
                    $end[] = $event->start_date.'T'.$event->end_time;
                }elseif($event->end_date){
                    $end[] = $event->end_date;
                }else{
                    $end[] ='';
                }

                // image
                if(count($event->images)){
                    $imagen = Image::select('path')->where('imageable_type', 'App\Models\Evento')->where('imageable_id', $event->id)->first();
                    $image[] = $imagen->path;
                }else{
                    $image[] = '';
                }
            }
        }

    }

    $count = count($id);

    for($i=0; $i<$count; $i++){
        $data[$i] = array(
            "title"=>$title[$i],
            "lugar"=>$place[$i],
            "start"=>$start[$i],
            "end"=>$end[$i],
            "imagen"=>$image[$i],
        );
    }

    return response()->json($data);

}

}
4

1 回答 1

1

感谢 ADyson 的回答,我已经解决了这个问题:

在控制器中,我添加了:

    $from= $request->start;
    $to= $request->end;

    $events = Evento::where('active', '1')->whereBetween('start_date', [$from, $to])->get();
于 2018-03-26T16:13:53.540 回答