Полный календарь |Jquery hover больше не работает после смены вида - PullRequest
0 голосов
/ 13 июня 2018

Контекст

Привет всем,

Я использую Полный календарь для отображения доступности и резервирования свойств (домов) в приложении CRM, разработанном в Symfony 3.

Календарь функционален.У нас есть элемент .fc-event-container для отображения бронирований и .fc-bgevent для доступности, как показано ниже.

fullcalendar.png

То, что я добавил после, этовозможность узнать, наведя курсор на ячейку (.fc-bgevent), кто установил доступность и когда.Эти данные извлекаются из базы данных, сохраняются в пользовательском атрибуте «data-informations» во время рендеринга каждой ячейки (.fc-bgevent) и, наконец, отображаются над контейнером представления календаря, как показано ниже.

fullcalendar-hover.png

Чтобы показать вам, как я этого добился, я поместил код используемых файлов ниже.

Контроллер

   //src/LD/PlatformBundle/Controller/Properties/indexController.php
  public
  function viewAction(Request $request, $id) {

      $events = $manager - > getRepository('LDPlatformBundle:Availabilities') - > findBy(array('idProperties' => $id));

      $Availa = array();

      foreach($events as $event) {
          ...
          $Ava['user'] = $event - > getIdUsers();
          $Ava['updateDate'] = $event - > getDateModifAvailabilities();

          if ($Ava['updateDate'] != null) {
              $Ava['updateDate'] = $Ava['updateDate'] - > format('D d-M-y');
          } else {
              $Ava['updateDate'] = "unknonw date";
          }
          if ($Ava['user'] == null) {
              $Ava['user'] = 'unknown user';
          }
          $Ava['informations'] = "Created by ".$Ava['user'].
          " on ".$Ava['updateDate'];
          $Availa[] = $Ava;
      }

      return $this - > render('LDPlatformBundle:Properties:view.html.twig', array(
          'Availa' => $Availa,
      ));
  }

Просмотр

//src/LD/PlatformBundle/Resources/views/Properties/view.html.twig
<script >

    $(document).ready(function() {
        $('#calendar').fullCalendar({
            schedulerLicenseKey: 'GPL-My-Project-Is-Open-Source',
            header: {
                left: 'prev,next today',
                center: 'title',
                right: 'month,agendaWeek,agendaDay,listMonth'
            },
            navLinks: true, // can click day/week names to navigate views
            businessHours: true, // display business hours
            editable: false,
            eventOverlap: false,
            events: [{ % include('FrontBootstrap/ajaxPlanning.html.twig') %
            }],
            eventRender: function(event, element) {
                $(element).attr('data-informations', event.informations);
            },
            nextDayThreshold: "01:00:00"
        });
        $('.fc-view-container').prepend('<div id="informations-date"><span></span></div>');
        $('#informations-date').css('visibility', 'hidden');
        $('.fc-bgevent').hover(function() {
            var informations = $(this).attr('data-informations');
            $('#informations-date span').text(informations);
            $('#informations-date').css('visibility', 'visible');
        }, function() {
            $('#informations-date').css('visibility', 'hidden');
        });
    }); 
</script> 
<style >

    #informations - date {
        height: 20 px;
    }

    /* Disable hover */
    .fc - content - skeleton,
    .fc - bgevent - skeleton {
        pointer - events: none
    }

    /* Enable hover on .fc-bgevent, .fc-bgevent-skeleton child and .fc-event-container */
    .fc - bgevent,
    .fc - event - container {
        pointer - events: auto;
    }
</style>   

События

    //app/Resources/views/FrontBootstrap/ajaxPlanning.html.twig
{ %
    for ava in Availa %
} {
    start: ('{{ ava.start|date("Y") }}-{{ ava.start|date("m") }}-{{ ava.start|date("d") }}'),
    color: '{{ ava.color }}',
    rendering: 'background',
    informations: '{{ava.informations}}',
} { %
    if loop.last %
} { %
    else %
}, { % endif %
} { % endfor %
}

Проблема

Теперь дело в том, когда я меняю вид, выбирая другой месяц (июнь, июль ...)или другой диапазон (неделя, месяц ...), функциональность больше не работает.Я знаю, что проблема связана с Jquery, потому что у меня все еще есть атрибут «data-informations» в ячейках других представлений.Сначала я подумал, что функция hover не работает, потому что ее целевые элементы находятся в DOM при вызове функции.Вот почему я также пытаюсь объявить функцию и вызвать ее в параметре viewRender , но это не решило проблему.

  //src/LD/PlatformBundle/Resources/views/Properties/view.html.twig
 $(document).ready(function() {
     // console.log(items);
     console.log(Availa);
     $('#calendar').fullCalendar({
         schedulerLicenseKey: 'GPL-My-Project-Is-Open-Source',
         header: {
             left: 'prev,next today',
             center: 'title',
             right: 'month,agendaWeek,agendaDay,listMonth'
         },
         navLinks: true, // can click day/week names to navigate views
         businessHours: true, // display business hours
         editable: false,
         eventOverlap: false,
         events: [{ % include('FrontBootstrap/ajaxPlanning.html.twig') %
         }],
         eventRender: function(event, element) {
             $(element).attr('data-informations', event.informations);
         },
         viewRender: function(view, element) {
             console.log('ok');
             $('.fc-bgevent').hover(function() {
                 console.log('ok');
             });
             getDateInformations();
         },
         nextDayThreshold: "01:00:00"
     });
     $('.fc-view-container').prepend('<div id="informations-date"><span></span></div>');
     getDateInformations();

 });

 function getDateInformations() {
     $('#informations-date').css('visibility', 'hidden');
     $('.fc-bgevent').hover(function() {
         console.log('ok');
         var informations = $(this).attr('data-informations');
         console.log(informations);
         $('#informations-date span').text(informations);
         $('#informations-date').css('visibility', 'visible');
     }, function() {
         $('#informations-date').css('visibility', 'hidden');
     });
 }

Я думаю, что есть определенная особенность функции наведения, которую я не знаю.

1 Ответ

0 голосов
/ 13 июня 2018

Вам нужно добавить обработчик событий в eventAfterAllRender fullCalendar вместо viewRender, потому что, как сказано в документации (https://fullcalendar.io/docs/viewRender), viewRender запускается после того, как было нарисовано простое представление, нособытия не обязательно загружаются в это время - это делается асинхронно, так что есть большая вероятность, что ваши события все еще не находятся в DOM в это время.

eventAfterAllRender: function(view)
{
  $('.fc-bgevent').hover(function() {
    console.log('ok');
  });
}

См. также https://fullcalendar.io/docs/eventAfterAllRender

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...