%PDF- %PDF-
Direktori : /home/vacivi36/ava/calendar/amd/src/ |
Current File : /home/vacivi36/ava/calendar/amd/src/popover.js |
// This file is part of Moodle - http://moodle.org/ // // Moodle is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Moodle is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with Moodle. If not, see <http://www.gnu.org/licenses/>. /** * Javascript popover for the `core_calendar` subsystem. * * @module core_calendar/popover * @copyright 2021 Huong Nguyen <huongnv13@gmail.com> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @since 4.0 */ import 'theme_boost/popover'; import jQuery from 'jquery'; import * as CalendarSelectors from 'core_calendar/selectors'; /** * Check if we are allowing to enable the popover or not. * @param {Element} dateContainer * @returns {boolean} */ const isPopoverAvailable = (dateContainer) => { return window.getComputedStyle(dateContainer.querySelector(CalendarSelectors.elements.dateContent)).display === 'none'; }; const isPopoverConfigured = new Map(); const showPopover = target => { if (!isPopoverConfigured.has(target)) { const dateEle = jQuery(target); dateEle.popover({ trigger: 'manual', placement: 'top', html: true, content: () => { const source = dateEle.find(CalendarSelectors.elements.dateContent); const content = jQuery('<div>'); if (source.length) { const temptContent = source.find('.hidden').clone(false); content.html(temptContent.html()); } return content.html(); } }); isPopoverConfigured.set(target, true); } if (isPopoverAvailable(target)) { jQuery(target).popover('show'); target.addEventListener('mouseleave', hidePopover); target.addEventListener('focusout', hidePopover); } }; const hidePopover = e => { const target = e.target; const dateContainer = e.target.closest(CalendarSelectors.elements.dateContainer); if (!dateContainer) { return; } if (isPopoverConfigured.has(dateContainer)) { const isTargetActive = target.contains(document.activeElement); const isTargetHover = target.matches(':hover'); if (!isTargetActive && !isTargetHover) { jQuery(dateContainer).popover('hide'); dateContainer.removeEventListener('mouseleave', hidePopover); dateContainer.removeEventListener('focusout', hidePopover); } } }; /** * Register events for date container. */ const registerEventListeners = () => { const showPopoverHandler = (e) => { const dateContainer = e.target.closest(CalendarSelectors.elements.dateContainer); if (!dateContainer) { return; } e.preventDefault(); showPopover(dateContainer); }; document.addEventListener('mouseover', showPopoverHandler); document.addEventListener('focusin', showPopoverHandler); }; let listenersRegistered = false; if (!listenersRegistered) { registerEventListeners(); listenersRegistered = true; }