X7ROOT File Manager
Current Path:
/home/cbholdings/pasukulu/lib/amd/src
home
/
cbholdings
/
pasukulu
/
lib
/
amd
/
src
/
📁
..
📄
adapter.js
(123.08 KB)
📄
addblockmodal.js
(4.4 KB)
📄
ajax.js
(11.97 KB)
📄
aria.js
(1011 B)
📄
auto_rows.js
(3.46 KB)
📄
autoscroll.js
(6.49 KB)
📄
backoff_timer.js
(4.98 KB)
📄
chart_axis.js
(7.39 KB)
📄
chart_bar.js
(3.08 KB)
📄
chart_base.js
(11.36 KB)
📄
chart_builder.js
(1.65 KB)
📄
chart_line.js
(2.08 KB)
📄
chart_output.js
(1.08 KB)
📄
chart_output_base.js
(2.03 KB)
📄
chart_output_chartjs.js
(10.86 KB)
📄
chart_output_htmltable.js
(3.3 KB)
📄
chart_pie.js
(3.03 KB)
📄
chart_series.js
(8.35 KB)
📄
chartjs-lazy.js
(488.32 KB)
📄
chartjs.js
(913 B)
📄
checkbox-toggleall.js
(12.78 KB)
📄
config.js
(1002 B)
📄
copy_to_clipboard.js
(7.39 KB)
📄
custom_interaction_events.js
(22.18 KB)
📁
datafilter
📄
datafilter.js
(15.28 KB)
📄
dragdrop.js
(12.92 KB)
📄
drawer.js
(3.49 KB)
📄
drawer_events.js
(967 B)
📄
dynamic_tabs.js
(6.68 KB)
📄
edit_switch.js
(3.45 KB)
📁
emoji
📄
event.js
(3.11 KB)
📄
event_dispatcher.js
(2.79 KB)
📄
first.js
(1.36 KB)
📄
form-autocomplete.js
(51.21 KB)
📄
form-cohort-selector.js
(2.46 KB)
📄
form-course-selector.js
(3.77 KB)
📄
fragment.js
(5.03 KB)
📄
fullscreen.js
(1.62 KB)
📄
icon_system.js
(2.56 KB)
📄
icon_system_fontawesome.js
(4.01 KB)
📄
icon_system_standard.js
(2.3 KB)
📄
inplace_editable.js
(17.25 KB)
📄
key_codes.js
(1.34 KB)
📄
loadingicon.js
(3.88 KB)
📁
local
📄
localstorage.js
(2.08 KB)
📄
log.js
(1.74 KB)
📄
loglevel.js
(10.63 KB)
📄
menu_navigation.js
(9.2 KB)
📄
modal.js
(31.18 KB)
📄
modal_backdrop.js
(4.46 KB)
📄
modal_cancel.js
(1.49 KB)
📄
modal_copy_to_clipboard.js
(3.82 KB)
📄
modal_delete_cancel.js
(2.22 KB)
📄
modal_events.js
(1.35 KB)
📄
modal_factory.js
(8.97 KB)
📄
modal_registry.js
(2.38 KB)
📄
modal_save_cancel.js
(2.21 KB)
📁
moodlenet
📄
moremenu.js
(10.3 KB)
📄
mustache.js
(28.75 KB)
📄
network.js
(9.66 KB)
📄
normalise.js
(1.9 KB)
📄
notification.js
(11.8 KB)
📄
page_global.js
(5.38 KB)
📄
paged_content.js
(2.87 KB)
📄
paged_content_events.js
(1.17 KB)
📄
paged_content_factory.js
(20.93 KB)
📄
paged_content_pages.js
(11.75 KB)
📄
paged_content_paging_bar.js
(20.36 KB)
📄
paged_content_paging_bar_limit_selector.js
(2.36 KB)
📄
paged_content_paging_dropdown.js
(7.36 KB)
📄
pending.js
(4.48 KB)
📄
permissionmanager.js
(9.77 KB)
📄
popover_region_controller.js
(13.04 KB)
📄
popper.js
(79.2 KB)
📄
prefetch.js
(5.85 KB)
📄
process_monitor.js
(3.55 KB)
📄
pubsub.js
(2.17 KB)
📄
reactive.js
(1.38 KB)
📄
scroll_manager.js
(5.5 KB)
📄
sessionstorage.js
(2.22 KB)
📄
showhidesettings.js
(11.82 KB)
📄
sortable_list.js
(29.51 KB)
📄
sticky-footer.js
(2.58 KB)
📄
storagewrapper.js
(5.21 KB)
📄
str.js
(7.84 KB)
📄
tag.js
(19.84 KB)
📄
templates.js
(51.36 KB)
📄
toast.js
(3.32 KB)
📄
tooltip.js
(4.09 KB)
📄
tree.js
(18.39 KB)
📄
truncate.js
(6.56 KB)
📄
url.js
(3.65 KB)
📄
user_date.js
(9.32 KB)
📄
userfeedback.js
(2.91 KB)
📄
usermenu.js
(5.13 KB)
📄
utility.js
(6.15 KB)
📄
utils.js
(2.73 KB)
📄
yui.js
(1.13 KB)
Editing: scroll_manager.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/>. /** * Scroll manager is a class that help with saving the scroll positing when you * click on an action icon, and then when the page is reloaded after processing * the action, it scrolls you to exactly where you were. This is much nicer for * the user. * * To use this in your code, you need to ensure that: * 1. The button that triggers the action has to have a click event handler that * calls saveScrollPos() * 2. After doing the processing, the redirect() function will add 'mdlscrollto' * parameter into the redirect url automatically. * 3. Finally, on the page that is reloaded (which should be the same as the one * the user started on) you need to call scrollToSavedPosition() * on page load. * * @module core/scroll_manager * @copyright 2021 The Open University * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ /** @property {HTMLElement} scrollingElement the current scrolling element. */ let scrollingElement = null; /** * Is the element scrollable? * * @param {HTMLElement} element Element. * @returns {boolean} */ const isScrollable = (element) => { // Check if the element has scrollable content. const hasScrollableContent = element.scrollHeight > element.clientHeight; // If 'overflow-y' is set to hidden, the scroll bar is't show. const elementOverflow = window.getComputedStyle(element).overflowY; const isOverflowHidden = elementOverflow.indexOf('hidden') !== -1; return hasScrollableContent && !isOverflowHidden; }; /** * Get the scrolling element. * * @returns {HTMLElement} */ const getScrollingElement = () => { if (scrollingElement === null) { const page = document.getElementById('page'); if (isScrollable(page)) { scrollingElement = page; } else { scrollingElement = document.scrollingElement; } } return scrollingElement; }; /** * Get current scroll position. * * @returns {Number} Scroll position. */ const getScrollPos = () => { const scrollingElement = getScrollingElement(); return scrollingElement.scrollTop; }; /** * Get the scroll position for this form. * * @param {HTMLFormElement} form * @returns {HTMLInputElement} */ const getScrollPositionElement = (form) => { const element = form.querySelector('input[name=mdlscrollto]'); if (element) { return element; } const scrollPos = document.createElement('input'); scrollPos.type = 'hidden'; scrollPos.name = 'mdlscrollto'; form.appendChild(scrollPos); return scrollPos; }; /** * In the form that contains the element, set the value of the form field with * name mdlscrollto to the current scroll position. If there is no element with * that name, it creates a hidden form field with that name within the form. * * @param {string} elementId The element in the form. */ export const saveScrollPos = (elementId) => { const element = document.getElementById(elementId); const form = element.closest('form'); if (!form) { return; } saveScrollPositionToForm(form); }; /** * Init event handlers for all links with data-savescrollposition=true. * Set the value to the closest form. */ export const watchScrollButtonSaves = () => { document.addEventListener('click', (e) => { const button = e.target.closest('[data-savescrollposition="true"]'); if (button) { saveScrollPositionToForm(button.form); } }); }; /** * Save the position to form. * * @param {Object} form The form is saved scroll position. */ export const saveScrollPositionToForm = (form) => { getScrollPositionElement(form).value = getScrollPos(); }; /** * Init event handlers for all links with data-save-scroll=true. * Handle to add mdlscrollto parameter to link using js when we click on the link. * */ export const initLinksScrollPos = () => { document.addEventListener('click', (e) => { const link = e.target.closest('a[data-save-scroll=true]'); if (!link) { return; } e.preventDefault(); const url = new URL(e.target.href); url.searchParams.set('mdlscrollto', getScrollPos()); window.location = url; }); }; /** * If there is a parameter like mdlscrollto=123 in the URL, scroll to that saved position. */ export const scrollToSavedPosition = () => { const url = new URL(window.location.href); if (!url.searchParams.has('mdlscrollto')) { return; } const scrollPosition = url.searchParams.get('mdlscrollto'); // Event onDOMReady is the effective one here. I am leaving the immediate call to // window.scrollTo in case it reduces flicker. const scrollingElement = getScrollingElement(); scrollingElement.scrollTo(0, scrollPosition); document.addEventListener('DOMContentLoaded', () => { scrollingElement.scrollTo(0, scrollPosition); }); };
Upload File
Create Folder