Fullcalendar v3.6.2 startParam и endParam
Как использовать startParam и endParam в fullcaledar? Я не знаю много о jQuery и Javascript. Вид находится в маршруте: example.com/agenda
Затем я подумал, что мне нужно поместить startParam и endParam в мой скрипт следующим образом:
startParam: 'agenda.start',
limitParam : 'agenda.limit',
Идея состоит в том, чтобы избежать медленной загрузки событий (около 10 секунд), ограничивая оба параметра, чтобы загружать только то, что видно на странице в этот момент. Я хорошо это понял? Это не работает, я имею в виду, что он продолжает медленно загружаться, остальное работает отлично. Как я должен это делать? Благодарю.
Это полный файл my-fullcalendar.js, который я собираю из файла json:
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);
}
}
1 ответ
Решение
Я решил это благодаря ADyson за его ответы:
В контроллере я добавил:
$from= $request->start;
$to= $request->end;
$events = Evento::where('active', '1')->whereBetween('start_date', [$from, $to])->get();