X7ROOT File Manager
Current Path:
/home/cbholdings/pasukulu/reportbuilder/amd/src/local/editor
home
/
cbholdings
/
pasukulu
/
reportbuilder
/
amd
/
src
/
local
/
editor
/
📁
..
📄
card_view.js
(2.49 KB)
📄
columns.js
(8.56 KB)
📄
conditions.js
(10.15 KB)
📄
filters.js
(7.2 KB)
📄
sorting.js
(7.61 KB)
Editing: filters.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/>. /** * Report builder filters editor * * @module core_reportbuilder/local/editor/filters * @copyright 2021 David Matamoros <davidmc@moodle.com> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ "use strict"; import $ from 'jquery'; import CustomEvents from 'core/custom_interaction_events'; import 'core/inplace_editable'; import Notification from 'core/notification'; import Pending from 'core/pending'; import {prefetchStrings} from 'core/prefetch'; import SortableList from 'core/sortable_list'; import {get_string as getString} from 'core/str'; import Templates from 'core/templates'; import {add as addToast} from 'core/toast'; import * as reportSelectors from 'core_reportbuilder/local/selectors'; import {addFilter, deleteFilter, reorderFilter} from 'core_reportbuilder/local/repository/filters'; /** * Reload filters settings region * * @param {Element} reportElement * @param {Object} templateContext * @return {Promise} */ const reloadSettingsFiltersRegion = (reportElement, templateContext) => { const pendingPromise = new Pending('core_reportbuilder/filters:reload'); const settingsFiltersRegion = reportElement.querySelector(reportSelectors.regions.settingsFilters); return Templates.renderForPromise('core_reportbuilder/local/settings/filters', {filters: templateContext}) .then(({html, js}) => { Templates.replaceNode(settingsFiltersRegion, html, js); initFiltersForm(); // Re-focus the add filter element after reloading the region. const reportAddFilter = reportElement.querySelector(reportSelectors.actions.reportAddFilter); reportAddFilter?.focus(); return pendingPromise.resolve(); }); }; /** * Initialise filters form, must be called on each init because the form container is re-created when switching editor modes */ const initFiltersForm = () => { CustomEvents.define(reportSelectors.actions.reportAddFilter, [CustomEvents.events.accessibleChange]); }; /** * Initialise module, prefetch all required strings * * @param {Boolean} initialized Ensure we only add our listeners once */ export const init = initialized => { prefetchStrings('core_reportbuilder', [ 'deletefilter', 'deletefilterconfirm', 'filteradded', 'filterdeleted', 'filtermoved', ]); prefetchStrings('core', [ 'delete', ]); initFiltersForm(); if (initialized) { return; } // Add filter to report. Use custom events helper to ensure consistency across platforms. $(document).on(CustomEvents.events.accessibleChange, reportSelectors.actions.reportAddFilter, event => { const reportAddFilter = event.target.closest(reportSelectors.actions.reportAddFilter); if (reportAddFilter) { event.preventDefault(); // Check if dropdown is closed with no filter selected. if (reportAddFilter.selectedIndex === 0) { return; } const reportElement = reportAddFilter.closest(reportSelectors.regions.report); const pendingPromise = new Pending('core_reportbuilder/filters:add'); addFilter(reportElement.dataset.reportId, reportAddFilter.value) .then(data => reloadSettingsFiltersRegion(reportElement, data)) .then(() => getString('filteradded', 'core_reportbuilder', reportAddFilter.options[reportAddFilter.selectedIndex].text)) .then(addToast) .then(() => pendingPromise.resolve()) .catch(Notification.exception); } }); document.addEventListener('click', event => { // Remove filter from report. const reportRemoveFilter = event.target.closest(reportSelectors.actions.reportRemoveFilter); if (reportRemoveFilter) { event.preventDefault(); const reportElement = reportRemoveFilter.closest(reportSelectors.regions.report); const filterContainer = reportRemoveFilter.closest(reportSelectors.regions.activeFilter); const filterName = filterContainer.dataset.filterName; Notification.saveCancelPromise( getString('deletefilter', 'core_reportbuilder', filterName), getString('deletefilterconfirm', 'core_reportbuilder', filterName), getString('delete', 'core'), {triggerElement: reportRemoveFilter} ).then(() => { const pendingPromise = new Pending('core_reportbuilder/filters:remove'); return deleteFilter(reportElement.dataset.reportId, filterContainer.dataset.filterId) .then(data => reloadSettingsFiltersRegion(reportElement, data)) .then(() => addToast(getString('filterdeleted', 'core_reportbuilder', filterName))) .then(() => pendingPromise.resolve()) .catch(Notification.exception); }).catch(() => { return; }); } }); // Initialize sortable list to handle active filters moving (note JQuery dependency, see MDL-72293 for resolution). var activeFiltersSortableList = new SortableList(`${reportSelectors.regions.activeFilters} ul`, {isHorizontal: false}); activeFiltersSortableList.getElementName = element => Promise.resolve(element.data('filterName')); $(document).on(SortableList.EVENTS.DROP, `${reportSelectors.regions.report} li[data-filter-id]`, (event, info) => { if (info.positionChanged) { const pendingPromise = new Pending('core_reportbuilder/filters:reorder'); const reportElement = event.target.closest(reportSelectors.regions.report); const filterId = info.element.data('filterId'); const filterPosition = info.element.data('filterPosition'); // Select target position, if moving to the end then count number of element siblings. let targetFilterPosition = info.targetNextElement.data('filterPosition') || info.element.siblings().length + 2; if (targetFilterPosition > filterPosition) { targetFilterPosition--; } reorderFilter(reportElement.dataset.reportId, filterId, targetFilterPosition) .then(data => reloadSettingsFiltersRegion(reportElement, data)) .then(() => getString('filtermoved', 'core_reportbuilder', info.element.data('filterName'))) .then(addToast) .then(() => pendingPromise.resolve()) .catch(Notification.exception); } }); };
Upload File
Create Folder