Как установить время начала и окончания в full calendar v4?

#javascript #fullcalendar #fullcalendar-4

#javascript #полный календарь #fullcalendar-4

Вопрос:

здравствуйте, я столкнулся с проблемой при установке времени начала и окончания. Я хочу, чтобы при перетаскивании событий пользователем время также устанавливалось, но в настоящее время оно отображается весь день. Предположим, у меня есть одно событие с 10:00 до 15:00, а другое событие с 15:00 до 18:00. Вот мой приведенный ниже код:-

 <div id="external-events">
      <div class="external-event bg-success" data-event="{"start":"10:00", "end":"15:00"}">Lunch</div>
      <div class="external-event bg-warning" data-event="{"start":"15:00", "end":"18:00"}">Go home</div>
</div>
 <div class="card-body p-0">
                            <!-- THE CALENDAR -->
                            <div id="calendar"></div>
                        </div>
 

Код Javascript:-

 var calevents = <?php print_r(json_encode($calendarEvents)) ?>; 
$(function () {

/* initialize the external events
 -----------------------------------------------------------------*/
function ini_events(ele) {
  ele.each(function () {

    // create an Event Object (http://arshaw.com/fullcalendar/docs/event_data/Event_Object/)
    // it doesn't need to have a start or end
    var eventObject = {
      title: $.trim($(this).text()) // use the element's text as the event title
    }

    // store the Event Object in the DOM element so we can get to it later
    $(this).data('eventObject', eventObject)

    // make the event draggable using jQuery UI
    $(this).draggable({
      zIndex        : 1070,
      revert        : true, // will cause the event to go back to its
      revertDuration: 0  //  original position after the drag
    })

  })
}

ini_events($('#external-events div.external-event'))

/* initialize the calendar
 -----------------------------------------------------------------*/
//Date for the calendar events (dummy data)
var date = new Date()
var d    = date.getDate(),
    m    = date.getMonth(),
    y    = date.getFullYear()

var Calendar = FullCalendar.Calendar;
var Draggable = FullCalendarInteraction.Draggable;

var containerEl = document.getElementById('external-events');
var checkbox = document.getElementById('drop-remove');
var calendarEl = document.getElementById('calendar');

// initialize the external events
// -----------------------------------------------------------------

new Draggable(containerEl, {
  itemSelector: '.external-event',
  eventData: function(eventEl) {
    console.log(eventEl);
    var dragObject = {
      title: eventEl.innerText,
      backgroundColor: window.getComputedStyle( eventEl ,null).getPropertyValue('background-color'),
      borderColor: window.getComputedStyle( eventEl ,null).getPropertyValue('background-color'),
      textColor: window.getComputedStyle( eventEl ,null).getPropertyValue('color'),
    };
    return dragObject;
  }
});

var calendar = new Calendar(calendarEl, {
  plugins: [ 'bootstrap', 'interaction', 'dayGrid', 'timeGrid' ],
  header    : {
    left  : 'prev,next today',
    center: 'title',
    right : 'dayGridMonth,timeGridWeek,timeGridDay'
  },
  'themeSystem': 'bootstrap',
  //Random default events
  events    : calevents,
  editable  : false,
  droppable : true, // this allows things to be dropped onto the calendar !!!
  drop      : function(info) {
    console.log(date.draggedEl.attributes[0]['value']); //here i amd getting the values {"start":"10:00", "end":"15:00"} that i set 

  }, 
});

calendar.render();
 

введите описание изображения здесь

Комментарии:

1. В этом нет никакого смысла. Временем события будет время, в течение которого пользователь сбрасывает его. Если вы хотите предварительно установить время и дату, в которые должно быть включено событие, тогда не разрешайте перетаскивание … потому что по определению этот процесс заключается в предоставлении пользователю выбора

Ответ №1:

Вы можете использовать minTime (для минимального времени начала) и maxTime (для максимального времени окончания)