diff --git a/theme/boost/amd/build/drawers.min.js b/theme/boost/amd/build/drawers.min.js index e1095510583..1dd28577f21 100644 --- a/theme/boost/amd/build/drawers.min.js +++ b/theme/boost/amd/build/drawers.min.js @@ -1,2 +1,2 @@ -function _typeof(a){"@babel/helpers - typeof";if("function"==typeof Symbol&&"symbol"==typeof Symbol.iterator){_typeof=function(a){return typeof a}}else{_typeof=function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a}}return _typeof(a)}define ("theme_boost/drawers",["exports","core/modal_backdrop","core/templates","core/aria","core/event_dispatcher","core/utils"],function(a,b,c,d,e,f){"use strict";Object.defineProperty(a,"__esModule",{value:!0});a.default=void 0;b=i(b);c=i(c);d=h(d);function g(){if("function"!=typeof WeakMap)return null;var a=new WeakMap;g=function(){return a};return a}function h(a){if(a&&a.__esModule){return a}if(null===a||"object"!==_typeof(a)&&"function"!=typeof a){return{default:a}}var b=g();if(b&&b.has(a)){return b.get(a)}var c={},d=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var e in a){if(Object.prototype.hasOwnProperty.call(a,e)){var f=d?Object.getOwnPropertyDescriptor(a,e):null;if(f&&(f.get||f.set)){Object.defineProperty(c,e,f)}else{c[e]=a[e]}}}c.default=a;if(b){b.set(a,c)}return c}function i(a){return a&&a.__esModule?a:{default:a}}function j(a,b){if(!(a instanceof b)){throw new TypeError("Cannot call a class as a function")}}function k(a,b){for(var c=0,d;c=p.medium&&a=p.large},u=function(){if(!n){n=c.default.render("core/modal_backdrop",{}).then(function(a){return new b.default(a)}).then(function(a){a.getAttachmentPoint().get(0).addEventListener("click",function(a){a.preventDefault();v.closeAllDrawers()});return a}).catch()}return n},v=function(){function a(b){j(this,a);m(this,"drawerNode",null);this.drawerNode=b;if(this.drawerNode.classList.contains("show")){this.openDrawer()}else{d.hide(this.drawerNode)}o.set(b,this)}l(a,[{key:"dispatchEvent",value:function dispatchEvent(a){var b=1=window.innerHeight){a.classList.add("scrolled")}else{a.classList.remove("scrolled")}})})();(function registerListeners(){document.addEventListener("click",function(a){var b=a.target.closest("[data-toggle=\"drawers\"][data-action=\"toggle\"]");if(b&&b.dataset.target){a.preventDefault();var c=document.getElementById(b.dataset.target),d=v.getDrawerInstanceForNode(c);w(b);d.toggleVisibility()}var e=a.target.closest("[data-toggle=\"drawers\"][data-action=\"opendrawer\"]");if(e&&e.dataset.target){a.preventDefault();var f=document.getElementById(e.dataset.target),g=v.getDrawerInstanceForNode(f);w(b);g.openDrawer()}var h=a.target.closest("[data-toggle=\"drawers\"][data-action=\"closedrawer\"]");if(h&&h.dataset.target){a.preventDefault();var i=document.getElementById(h.dataset.target),j=v.getDrawerInstanceForNode(i);j.closeDrawer();x(h.dataset.target)}});document.addEventListener(v.eventTypes.drawerShow,function(a){if(t()){return}v.closeOtherDrawers(a.detail.drawerInstance)});window.addEventListener("resize",(0,f.debounce)(function closeOnResizeListener(){if(r()){var a=!1;o.forEach(function(b){if(b.isOpen){if(b.closeOnResize){b.closeDrawer()}else{a=!0}}});if(a){u().then(function(a){return a.show()}).catch()}}else{u().then(function(a){return a.hide()}).catch()}},400))})();var y=document.querySelectorAll("[data-region=\"fixed-drawer\"]");y.forEach(function(a){return v.getDrawerInstanceForNode(a)});return a.default}); +function _typeof(a){"@babel/helpers - typeof";if("function"==typeof Symbol&&"symbol"==typeof Symbol.iterator){_typeof=function(a){return typeof a}}else{_typeof=function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a}}return _typeof(a)}define ("theme_boost/drawers",["exports","core/modal_backdrop","core/templates","core/aria","core/event_dispatcher","core/utils"],function(a,b,c,d,e,f){"use strict";Object.defineProperty(a,"__esModule",{value:!0});a.default=void 0;b=i(b);c=i(c);d=h(d);function g(){if("function"!=typeof WeakMap)return null;var a=new WeakMap;g=function(){return a};return a}function h(a){if(a&&a.__esModule){return a}if(null===a||"object"!==_typeof(a)&&"function"!=typeof a){return{default:a}}var b=g();if(b&&b.has(a)){return b.get(a)}var c={},d=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var e in a){if(Object.prototype.hasOwnProperty.call(a,e)){var f=d?Object.getOwnPropertyDescriptor(a,e):null;if(f&&(f.get||f.set)){Object.defineProperty(c,e,f)}else{c[e]=a[e]}}}c.default=a;if(b){b.set(a,c)}return c}function i(a){return a&&a.__esModule?a:{default:a}}function j(a,b){if(!(a instanceof b)){throw new TypeError("Cannot call a class as a function")}}function k(a,b){for(var c=0,d;c=p.large},t=function(){if(!n){n=c.default.render("core/modal_backdrop",{}).then(function(a){return new b.default(a)}).then(function(a){a.getAttachmentPoint().get(0).addEventListener("click",function(a){a.preventDefault();u.closeAllDrawers()});return a}).catch()}return n},u=function(){function a(b){j(this,a);m(this,"drawerNode",null);this.drawerNode=b;if(this.drawerNode.classList.contains("show")){this.openDrawer()}else{d.hide(this.drawerNode)}o.set(b,this)}l(a,[{key:"dispatchEvent",value:function dispatchEvent(a){var b=1=window.innerHeight){a.classList.add("scrolled")}else{a.classList.remove("scrolled")}})})();(function registerListeners(){document.addEventListener("click",function(a){var b=a.target.closest("[data-toggle=\"drawers\"][data-action=\"toggle\"]");if(b&&b.dataset.target){a.preventDefault();var c=document.getElementById(b.dataset.target),d=u.getDrawerInstanceForNode(c);v(b);d.toggleVisibility()}var e=a.target.closest("[data-toggle=\"drawers\"][data-action=\"opendrawer\"]");if(e&&e.dataset.target){a.preventDefault();var f=document.getElementById(e.dataset.target),g=u.getDrawerInstanceForNode(f);v(b);g.openDrawer()}var h=a.target.closest("[data-toggle=\"drawers\"][data-action=\"closedrawer\"]");if(h&&h.dataset.target){a.preventDefault();var i=document.getElementById(h.dataset.target),j=u.getDrawerInstanceForNode(i);j.closeDrawer();w(h.dataset.target)}});document.addEventListener(u.eventTypes.drawerShow,function(a){if(s()){return}u.closeOtherDrawers(a.detail.drawerInstance)});window.addEventListener("resize",(0,f.debounce)(function closeOnResizeListener(){if(r()){var a=!1;o.forEach(function(b){if(b.isOpen){if(b.closeOnResize){b.closeDrawer()}else{a=!0}}});if(a){t().then(function(a){return a.show()}).catch()}}else{t().then(function(a){return a.hide()}).catch()}},400))})();var x=document.querySelectorAll("[data-region=\"fixed-drawer\"]");x.forEach(function(a){return u.getDrawerInstanceForNode(a)});return a.default}); //# sourceMappingURL=drawers.min.js.map diff --git a/theme/boost/amd/build/drawers.min.js.map b/theme/boost/amd/build/drawers.min.js.map index 3c452fbe9c2..1c2b860e093 100644 --- a/theme/boost/amd/build/drawers.min.js.map +++ b/theme/boost/amd/build/drawers.min.js.map @@ -1 +1 @@ -{"version":3,"sources":["../src/drawers.js"],"names":["backdropPromise","drawerMap","Map","sizes","medium","large","getCurrentWidth","DomRect","document","body","getBoundingClientRect","x","width","isSmall","browserWidth","isMedium","isLarge","getBackdrop","Templates","render","then","html","ModalBackdrop","modalBackdrop","getAttachmentPoint","get","addEventListener","e","preventDefault","Drawers","closeAllDrawers","catch","drawerNode","classList","contains","openDrawer","Aria","hide","set","eventname","cancelable","drawerInstance","showEvent","dispatchEvent","eventTypes","drawerShow","defaultPrevented","unhide","add","preference","dataset","M","util","set_user_preference","state","page","getElementById","backdrop","show","pageWrapper","style","overflow","closeButton","querySelector","focus","drawerShown","hideEvent","drawerHide","remove","drawerHidden","closeDrawer","parseInt","closeOnResize","has","forEach","comparisonInstance","setLastUsedToggle","toggleButton","target","querySelectorAll","btn","lastused","focusLastUsedToggle","lastUsedButton","scroller","drawerLayout","scrollTop","window","innerHeight","registerListeners","closest","targetDrawer","getDrawerInstanceForNode","toggleVisibility","openDrawerButton","closeDrawerButton","closeOtherDrawers","detail","closeOnResizeListener","anyOpen","isOpen","drawers"],"mappings":"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","sourcesContent":["// This file is part of Moodle - http://moodle.org/\n//\n// Moodle is free software: you can redistribute it and/or modify\n// it under the terms of the GNU General Public License as published by\n// the Free Software Foundation, either version 3 of the License, or\n// (at your option) any later version.\n//\n// Moodle is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU General Public License for more details.\n//\n// You should have received a copy of the GNU General Public License\n// along with Moodle. If not, see .\n\n/**\n * Toggling the visibility of the secondary navigation on mobile.\n *\n * @module theme_boost/drawers\n * @copyright 2021 Bas Brands\n * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later\n */\nimport ModalBackdrop from 'core/modal_backdrop';\nimport Templates from 'core/templates';\nimport * as Aria from 'core/aria';\nimport {dispatchEvent} from 'core/event_dispatcher';\nimport {debounce} from 'core/utils';\n\nlet backdropPromise = null;\n\nconst drawerMap = new Map();\n\n/**\n * Maximum sizes for breakpoints. This needs to correspond with Bootstrap\n * Breakpoints\n *\n * @private\n */\nconst sizes = {\n medium: 991,\n large: 1400\n};\n\n/**\n * Get the current body width.\n *\n * @returns {number} the current body width.\n * @private\n */\nconst getCurrentWidth = () => {\n const DomRect = document.body.getBoundingClientRect();\n return DomRect.x + DomRect.width;\n};\n\n/**\n * Check if the user uses a small size browser.\n *\n * @returns {boolean} true if the body is smaller than sizes.medium max size.\n * @private\n */\nconst isSmall = () => {\n const browserWidth = getCurrentWidth();\n return browserWidth < sizes.medium;\n};\n\n/**\n * Check if the user uses a medium size browser.\n *\n * @returns {boolean} true if the body is smaller than sizes.medium max size.\n * @private\n */\nconst isMedium = () => {\n const browserWidth = getCurrentWidth();\n return (browserWidth >= sizes.medium) && (browserWidth < sizes.large);\n};\n\n/**\n * Check if the user uses a large size browser.\n *\n * @returns {boolean} true if the body is smaller than sizes.large max size.\n * @private\n */\nconst isLarge = () => {\n const browserWidth = getCurrentWidth();\n return browserWidth >= sizes.large;\n};\n\n/**\n * Add a backdrop to the page.\n *\n * @returns {Promise} rendering of modal backdrop.\n * @private\n */\nconst getBackdrop = () => {\n if (!backdropPromise) {\n backdropPromise = Templates.render('core/modal_backdrop', {})\n .then(html => new ModalBackdrop(html))\n .then(modalBackdrop => {\n modalBackdrop.getAttachmentPoint().get(0).addEventListener('click', e => {\n e.preventDefault();\n Drawers.closeAllDrawers();\n });\n return modalBackdrop;\n })\n .catch();\n }\n return backdropPromise;\n};\n\n/**\n * The Drawers class is used to control on-screen drawer elements.\n *\n * It handles opening, and closing of drawer elements, as well as more detailed behaviours such as closing a drawer when\n * another drawer is opened, and supports closing a drawer when the screen is resized.\n *\n * Drawers are instantiated on page load, and can also be toggled lazily when toggling any drawer toggle, open button,\n * or close button.\n *\n * A range of show and hide events are also dispatched as detailed in the class\n * {@link module:theme_boost/drawers#eventTypes eventTypes} object.\n *\n * @example Standard usage\n *\n * // The module just needs to be included to add drawer support.\n * import 'theme_boost/drawers';\n *\n * @example Manually open or close any drawer\n *\n * import Drawers from 'theme_boost/drawers';\n *\n * const myDrawer = Drawers.getDrawerInstanceForNode(document.querySelector('.myDrawerNode');\n * myDrawer.closeDrawer();\n *\n * @example Listen to the before show event and cancel it\n *\n * import Drawers from 'theme_boost/drawers';\n *\n * document.addEventListener(Drawers.eventTypes.drawerShow, e => {\n * // The drawer which will be shown.\n * window.console.log(e.target);\n *\n * // The instance of the Drawers class for this drawer.\n * window.console.log(e.detail.drawerInstance);\n *\n * // Prevent this drawer from being shown.\n * e.preventDefault();\n * });\n *\n * @example Listen to the shown event\n *\n * document.addEventListener(Drawers.eventTypes.drawerShown, e => {\n * // The drawer which was shown.\n * window.console.log(e.target);\n *\n * // The instance of the Drawers class for this drawer.\n * window.console.log(e.detail.drawerInstance);\n * });\n */\nexport default class Drawers {\n /**\n * The underlying HTMLElement which is controlled.\n */\n drawerNode = null;\n\n constructor(drawerNode) {\n this.drawerNode = drawerNode;\n\n if (this.drawerNode.classList.contains('show')) {\n this.openDrawer();\n } else {\n Aria.hide(this.drawerNode);\n }\n\n drawerMap.set(drawerNode, this);\n }\n\n /**\n * Whether the drawer is open.\n *\n * @returns {boolean}\n */\n get isOpen() {\n return this.drawerNode.classList.contains('show');\n }\n\n /**\n * Whether the drawer should close when the window is resized\n *\n * @returns {boolean}\n */\n get closeOnResize() {\n return !!parseInt(this.drawerNode.dataset.closeOnResize);\n }\n\n /**\n * The list of event types.\n *\n * @static\n * @property {String} drawerShow See {@link event:theme_boost/drawers:show}\n * @property {String} drawerShown See {@link event:theme_boost/drawers:shown}\n * @property {String} drawerHide See {@link event:theme_boost/drawers:hide}\n * @property {String} drawerHidden See {@link event:theme_boost/drawers:hidden}\n */\n static eventTypes = {\n /**\n * An event triggered before a drawer is shown.\n *\n * @event theme_boost/drawers:show\n * @type {CustomEvent}\n * @property {HTMLElement} target The drawer that will be opened.\n */\n drawerShow: 'theme_boost/drawers:show',\n\n /**\n * An event triggered after a drawer is shown.\n *\n * @event theme_boost/drawers:shown\n * @type {CustomEvent}\n * @property {HTMLElement} target The drawer that was be opened.\n */\n drawerShown: 'theme_boost/drawers:shown',\n\n /**\n * An event triggered before a drawer is hidden.\n *\n * @event theme_boost/drawers:hide\n * @type {CustomEvent}\n * @property {HTMLElement} target The drawer that will be hidden.\n */\n drawerHide: 'theme_boost/drawers:hide',\n\n /**\n * An event triggered after a drawer is hidden.\n *\n * @event theme_boost/drawers:hidden\n * @type {CustomEvent}\n * @property {HTMLElement} target The drawer that was be hidden.\n */\n drawerHidden: 'theme_boost/drawers:hidden',\n };\n\n\n /**\n * Get the drawer instance for the specified node\n *\n * @param {HTMLElement} drawerNode\n * @returns {module:theme_boost/drawers}\n */\n static getDrawerInstanceForNode(drawerNode) {\n if (!drawerMap.has(drawerNode)) {\n new Drawers(drawerNode);\n }\n\n return drawerMap.get(drawerNode);\n }\n\n /**\n * Dispatch a drawer event.\n *\n * @param {string} eventname the event name\n * @param {boolean} cancelable if the event is cancelable\n * @returns {CustomEvent} the resulting custom event\n */\n dispatchEvent(eventname, cancelable = false) {\n return dispatchEvent(\n eventname,\n {\n drawerInstance: this,\n },\n this.drawerNode,\n {\n cancelable,\n }\n );\n }\n\n /**\n * Open the drawer.\n */\n openDrawer() {\n const showEvent = this.dispatchEvent(Drawers.eventTypes.drawerShow, true);\n if (showEvent.defaultPrevented) {\n return;\n }\n\n Aria.unhide(this.drawerNode);\n this.drawerNode.classList.add('show');\n\n const preference = this.drawerNode.dataset.preference;\n if (preference) {\n M.util.set_user_preference(preference, true);\n }\n\n const state = this.drawerNode.dataset.state;\n if (state) {\n const page = document.getElementById('page');\n page.classList.add(state);\n }\n\n if (isSmall()) {\n getBackdrop().then(backdrop => {\n backdrop.show();\n\n const pageWrapper = document.getElementById('page-wrapper');\n pageWrapper.style.overflow = 'hidden';\n return backdrop;\n })\n .catch();\n }\n\n const closeButton = this.drawerNode.querySelector('[data-toggle=\"drawers\"][data-action=\"closedrawer\"]');\n closeButton.focus();\n\n this.dispatchEvent(Drawers.eventTypes.drawerShown);\n }\n\n /**\n * Close the drawer.\n */\n closeDrawer() {\n const hideEvent = this.dispatchEvent(Drawers.eventTypes.drawerHide, true);\n if (hideEvent.defaultPrevented) {\n return;\n }\n\n const preference = this.drawerNode.dataset.preference;\n if (preference) {\n M.util.set_user_preference(preference, false);\n }\n\n const state = this.drawerNode.dataset.state;\n if (state) {\n const page = document.getElementById('page');\n page.classList.remove(state);\n }\n\n Aria.hide(this.drawerNode);\n this.drawerNode.classList.remove('show');\n\n getBackdrop().then(backdrop => {\n backdrop.hide();\n\n if (isMedium()) {\n const pageWrapper = document.getElementById('page-wrapper');\n pageWrapper.style.overflow = 'auto';\n }\n return backdrop;\n })\n .catch();\n\n this.dispatchEvent(Drawers.eventTypes.drawerHidden);\n }\n\n /**\n * Toggle visibility of the drawer.\n */\n toggleVisibility() {\n if (this.drawerNode.classList.contains('show')) {\n this.closeDrawer();\n } else {\n this.openDrawer();\n }\n }\n\n /**\n * Close all drawers.\n */\n static closeAllDrawers() {\n drawerMap.forEach(drawerInstance => {\n drawerInstance.closeDrawer();\n });\n }\n\n /**\n * Close all drawers except for the specified drawer.\n *\n * @param {module:theme_boost/drawers} comparisonInstance\n */\n static closeOtherDrawers(comparisonInstance) {\n drawerMap.forEach(drawerInstance => {\n if (drawerInstance === comparisonInstance) {\n return;\n }\n\n drawerInstance.closeDrawer();\n });\n }\n}\n\n/**\n * Activate the scroller helper for the drawer layout.\n *\n * @private\n */\nconst scroller = () => {\n const body = document.querySelector('body');\n const drawerLayout = document.querySelector('#page.drawers');\n drawerLayout.addEventListener(\"scroll\", () => {\n if (drawerLayout.scrollTop >= window.innerHeight) {\n body.classList.add('scrolled');\n } else {\n body.classList.remove('scrolled');\n }\n });\n};\n\n/**\n * Set the last used attribute for the last used toggle button for a drawer.\n *\n * @param {object} toggleButton The clicked button.\n */\nconst setLastUsedToggle = (toggleButton) => {\n if (toggleButton.dataset.target) {\n document.querySelectorAll('[data-toggle=\"drawers\"][data-target=\"' + toggleButton.dataset.target + '\"]')\n .forEach(btn => {\n btn.dataset.lastused = false;\n });\n toggleButton.dataset.lastused = true;\n }\n};\n\n/**\n * Set the focus to the last used button to open this drawer.\n * @param {string} target The drawer target.\n */\nconst focusLastUsedToggle = (target) => {\n const lastUsedButton = document.querySelector('[data-toggle=\"drawers\"][data-target=\"' + target + '\"][data-lastused=\"true\"');\n if (lastUsedButton) {\n lastUsedButton.focus();\n }\n};\n\n/**\n * Register the event listeners for the drawer.\n *\n * @private\n */\nconst registerListeners = () => {\n // Listen for show/hide events.\n document.addEventListener('click', e => {\n const toggleButton = e.target.closest('[data-toggle=\"drawers\"][data-action=\"toggle\"]');\n if (toggleButton && toggleButton.dataset.target) {\n e.preventDefault();\n const targetDrawer = document.getElementById(toggleButton.dataset.target);\n const drawerInstance = Drawers.getDrawerInstanceForNode(targetDrawer);\n setLastUsedToggle(toggleButton);\n\n drawerInstance.toggleVisibility();\n }\n\n const openDrawerButton = e.target.closest('[data-toggle=\"drawers\"][data-action=\"opendrawer\"]');\n if (openDrawerButton && openDrawerButton.dataset.target) {\n e.preventDefault();\n const targetDrawer = document.getElementById(openDrawerButton.dataset.target);\n const drawerInstance = Drawers.getDrawerInstanceForNode(targetDrawer);\n setLastUsedToggle(toggleButton);\n\n drawerInstance.openDrawer();\n }\n\n const closeDrawerButton = e.target.closest('[data-toggle=\"drawers\"][data-action=\"closedrawer\"]');\n if (closeDrawerButton && closeDrawerButton.dataset.target) {\n e.preventDefault();\n const targetDrawer = document.getElementById(closeDrawerButton.dataset.target);\n const drawerInstance = Drawers.getDrawerInstanceForNode(targetDrawer);\n\n drawerInstance.closeDrawer();\n focusLastUsedToggle(closeDrawerButton.dataset.target);\n }\n });\n\n // Close drawer when another drawer opens.\n document.addEventListener(Drawers.eventTypes.drawerShow, e => {\n if (isLarge()) {\n return;\n }\n Drawers.closeOtherDrawers(e.detail.drawerInstance);\n });\n\n const closeOnResizeListener = () => {\n if (isSmall()) {\n let anyOpen = false;\n drawerMap.forEach(drawerInstance => {\n if (drawerInstance.isOpen) {\n if (drawerInstance.closeOnResize) {\n drawerInstance.closeDrawer();\n } else {\n anyOpen = true;\n }\n }\n });\n\n if (anyOpen) {\n getBackdrop().then(backdrop => backdrop.show()).catch();\n }\n } else {\n getBackdrop().then(backdrop => backdrop.hide()).catch();\n }\n };\n\n window.addEventListener('resize', debounce(closeOnResizeListener, 400));\n};\n\nscroller();\nregisterListeners();\n\nconst drawers = document.querySelectorAll('[data-region=\"fixed-drawer\"]');\ndrawers.forEach(drawerNode => Drawers.getDrawerInstanceForNode(drawerNode));\n"],"file":"drawers.min.js"} \ No newline at end of file +{"version":3,"sources":["../src/drawers.js"],"names":["backdropPromise","drawerMap","Map","sizes","medium","large","getCurrentWidth","DomRect","document","body","getBoundingClientRect","x","width","isSmall","browserWidth","isLarge","getBackdrop","Templates","render","then","html","ModalBackdrop","modalBackdrop","getAttachmentPoint","get","addEventListener","e","preventDefault","Drawers","closeAllDrawers","catch","drawerNode","classList","contains","openDrawer","Aria","hide","set","eventname","cancelable","drawerInstance","showEvent","dispatchEvent","eventTypes","drawerShow","defaultPrevented","unhide","add","preference","dataset","M","util","set_user_preference","state","page","getElementById","backdrop","show","pageWrapper","style","overflow","closeButton","querySelector","focus","drawerShown","hideEvent","drawerHide","remove","drawerHidden","closeDrawer","parseInt","closeOnResize","has","forEach","comparisonInstance","setLastUsedToggle","toggleButton","target","querySelectorAll","btn","lastused","focusLastUsedToggle","lastUsedButton","scroller","drawerLayout","scrollTop","window","innerHeight","registerListeners","closest","targetDrawer","getDrawerInstanceForNode","toggleVisibility","openDrawerButton","closeDrawerButton","closeOtherDrawers","detail","closeOnResizeListener","anyOpen","isOpen","drawers"],"mappings":"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","sourcesContent":["// This file is part of Moodle - http://moodle.org/\n//\n// Moodle is free software: you can redistribute it and/or modify\n// it under the terms of the GNU General Public License as published by\n// the Free Software Foundation, either version 3 of the License, or\n// (at your option) any later version.\n//\n// Moodle is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU General Public License for more details.\n//\n// You should have received a copy of the GNU General Public License\n// along with Moodle. If not, see .\n\n/**\n * Toggling the visibility of the secondary navigation on mobile.\n *\n * @module theme_boost/drawers\n * @copyright 2021 Bas Brands\n * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later\n */\nimport ModalBackdrop from 'core/modal_backdrop';\nimport Templates from 'core/templates';\nimport * as Aria from 'core/aria';\nimport {dispatchEvent} from 'core/event_dispatcher';\nimport {debounce} from 'core/utils';\n\nlet backdropPromise = null;\n\nconst drawerMap = new Map();\n\n/**\n * Maximum sizes for breakpoints. This needs to correspond with Bootstrap\n * Breakpoints\n *\n * @private\n */\nconst sizes = {\n medium: 991,\n large: 1400\n};\n\n/**\n * Get the current body width.\n *\n * @returns {number} the current body width.\n * @private\n */\nconst getCurrentWidth = () => {\n const DomRect = document.body.getBoundingClientRect();\n return DomRect.x + DomRect.width;\n};\n\n/**\n * Check if the user uses a small size browser.\n *\n * @returns {boolean} true if the body is smaller than sizes.medium max size.\n * @private\n */\nconst isSmall = () => {\n const browserWidth = getCurrentWidth();\n return browserWidth < sizes.medium;\n};\n\n/**\n * Check if the user uses a large size browser.\n *\n * @returns {boolean} true if the body is smaller than sizes.large max size.\n * @private\n */\nconst isLarge = () => {\n const browserWidth = getCurrentWidth();\n return browserWidth >= sizes.large;\n};\n\n/**\n * Add a backdrop to the page.\n *\n * @returns {Promise} rendering of modal backdrop.\n * @private\n */\nconst getBackdrop = () => {\n if (!backdropPromise) {\n backdropPromise = Templates.render('core/modal_backdrop', {})\n .then(html => new ModalBackdrop(html))\n .then(modalBackdrop => {\n modalBackdrop.getAttachmentPoint().get(0).addEventListener('click', e => {\n e.preventDefault();\n Drawers.closeAllDrawers();\n });\n return modalBackdrop;\n })\n .catch();\n }\n return backdropPromise;\n};\n\n/**\n * The Drawers class is used to control on-screen drawer elements.\n *\n * It handles opening, and closing of drawer elements, as well as more detailed behaviours such as closing a drawer when\n * another drawer is opened, and supports closing a drawer when the screen is resized.\n *\n * Drawers are instantiated on page load, and can also be toggled lazily when toggling any drawer toggle, open button,\n * or close button.\n *\n * A range of show and hide events are also dispatched as detailed in the class\n * {@link module:theme_boost/drawers#eventTypes eventTypes} object.\n *\n * @example Standard usage\n *\n * // The module just needs to be included to add drawer support.\n * import 'theme_boost/drawers';\n *\n * @example Manually open or close any drawer\n *\n * import Drawers from 'theme_boost/drawers';\n *\n * const myDrawer = Drawers.getDrawerInstanceForNode(document.querySelector('.myDrawerNode');\n * myDrawer.closeDrawer();\n *\n * @example Listen to the before show event and cancel it\n *\n * import Drawers from 'theme_boost/drawers';\n *\n * document.addEventListener(Drawers.eventTypes.drawerShow, e => {\n * // The drawer which will be shown.\n * window.console.log(e.target);\n *\n * // The instance of the Drawers class for this drawer.\n * window.console.log(e.detail.drawerInstance);\n *\n * // Prevent this drawer from being shown.\n * e.preventDefault();\n * });\n *\n * @example Listen to the shown event\n *\n * document.addEventListener(Drawers.eventTypes.drawerShown, e => {\n * // The drawer which was shown.\n * window.console.log(e.target);\n *\n * // The instance of the Drawers class for this drawer.\n * window.console.log(e.detail.drawerInstance);\n * });\n */\nexport default class Drawers {\n /**\n * The underlying HTMLElement which is controlled.\n */\n drawerNode = null;\n\n constructor(drawerNode) {\n this.drawerNode = drawerNode;\n\n if (this.drawerNode.classList.contains('show')) {\n this.openDrawer();\n } else {\n Aria.hide(this.drawerNode);\n }\n\n drawerMap.set(drawerNode, this);\n }\n\n /**\n * Whether the drawer is open.\n *\n * @returns {boolean}\n */\n get isOpen() {\n return this.drawerNode.classList.contains('show');\n }\n\n /**\n * Whether the drawer should close when the window is resized\n *\n * @returns {boolean}\n */\n get closeOnResize() {\n return !!parseInt(this.drawerNode.dataset.closeOnResize);\n }\n\n /**\n * The list of event types.\n *\n * @static\n * @property {String} drawerShow See {@link event:theme_boost/drawers:show}\n * @property {String} drawerShown See {@link event:theme_boost/drawers:shown}\n * @property {String} drawerHide See {@link event:theme_boost/drawers:hide}\n * @property {String} drawerHidden See {@link event:theme_boost/drawers:hidden}\n */\n static eventTypes = {\n /**\n * An event triggered before a drawer is shown.\n *\n * @event theme_boost/drawers:show\n * @type {CustomEvent}\n * @property {HTMLElement} target The drawer that will be opened.\n */\n drawerShow: 'theme_boost/drawers:show',\n\n /**\n * An event triggered after a drawer is shown.\n *\n * @event theme_boost/drawers:shown\n * @type {CustomEvent}\n * @property {HTMLElement} target The drawer that was be opened.\n */\n drawerShown: 'theme_boost/drawers:shown',\n\n /**\n * An event triggered before a drawer is hidden.\n *\n * @event theme_boost/drawers:hide\n * @type {CustomEvent}\n * @property {HTMLElement} target The drawer that will be hidden.\n */\n drawerHide: 'theme_boost/drawers:hide',\n\n /**\n * An event triggered after a drawer is hidden.\n *\n * @event theme_boost/drawers:hidden\n * @type {CustomEvent}\n * @property {HTMLElement} target The drawer that was be hidden.\n */\n drawerHidden: 'theme_boost/drawers:hidden',\n };\n\n\n /**\n * Get the drawer instance for the specified node\n *\n * @param {HTMLElement} drawerNode\n * @returns {module:theme_boost/drawers}\n */\n static getDrawerInstanceForNode(drawerNode) {\n if (!drawerMap.has(drawerNode)) {\n new Drawers(drawerNode);\n }\n\n return drawerMap.get(drawerNode);\n }\n\n /**\n * Dispatch a drawer event.\n *\n * @param {string} eventname the event name\n * @param {boolean} cancelable if the event is cancelable\n * @returns {CustomEvent} the resulting custom event\n */\n dispatchEvent(eventname, cancelable = false) {\n return dispatchEvent(\n eventname,\n {\n drawerInstance: this,\n },\n this.drawerNode,\n {\n cancelable,\n }\n );\n }\n\n /**\n * Open the drawer.\n */\n openDrawer() {\n const showEvent = this.dispatchEvent(Drawers.eventTypes.drawerShow, true);\n if (showEvent.defaultPrevented) {\n return;\n }\n\n Aria.unhide(this.drawerNode);\n this.drawerNode.classList.add('show');\n\n const preference = this.drawerNode.dataset.preference;\n if (preference) {\n M.util.set_user_preference(preference, true);\n }\n\n const state = this.drawerNode.dataset.state;\n if (state) {\n const page = document.getElementById('page');\n page.classList.add(state);\n }\n\n if (isSmall()) {\n getBackdrop().then(backdrop => {\n backdrop.show();\n\n const pageWrapper = document.getElementById('page-wrapper');\n pageWrapper.style.overflow = 'hidden';\n return backdrop;\n })\n .catch();\n }\n\n const closeButton = this.drawerNode.querySelector('[data-toggle=\"drawers\"][data-action=\"closedrawer\"]');\n closeButton.focus();\n\n this.dispatchEvent(Drawers.eventTypes.drawerShown);\n }\n\n /**\n * Close the drawer.\n */\n closeDrawer() {\n const hideEvent = this.dispatchEvent(Drawers.eventTypes.drawerHide, true);\n if (hideEvent.defaultPrevented) {\n return;\n }\n\n const preference = this.drawerNode.dataset.preference;\n if (preference) {\n M.util.set_user_preference(preference, false);\n }\n\n const state = this.drawerNode.dataset.state;\n if (state) {\n const page = document.getElementById('page');\n page.classList.remove(state);\n }\n\n Aria.hide(this.drawerNode);\n this.drawerNode.classList.remove('show');\n\n getBackdrop().then(backdrop => {\n backdrop.hide();\n\n if (isSmall()) {\n const pageWrapper = document.getElementById('page-wrapper');\n pageWrapper.style.overflow = 'auto';\n }\n return backdrop;\n })\n .catch();\n\n this.dispatchEvent(Drawers.eventTypes.drawerHidden);\n }\n\n /**\n * Toggle visibility of the drawer.\n */\n toggleVisibility() {\n if (this.drawerNode.classList.contains('show')) {\n this.closeDrawer();\n } else {\n this.openDrawer();\n }\n }\n\n /**\n * Close all drawers.\n */\n static closeAllDrawers() {\n drawerMap.forEach(drawerInstance => {\n drawerInstance.closeDrawer();\n });\n }\n\n /**\n * Close all drawers except for the specified drawer.\n *\n * @param {module:theme_boost/drawers} comparisonInstance\n */\n static closeOtherDrawers(comparisonInstance) {\n drawerMap.forEach(drawerInstance => {\n if (drawerInstance === comparisonInstance) {\n return;\n }\n\n drawerInstance.closeDrawer();\n });\n }\n}\n\n/**\n * Activate the scroller helper for the drawer layout.\n *\n * @private\n */\nconst scroller = () => {\n const body = document.querySelector('body');\n const drawerLayout = document.querySelector('#page.drawers');\n drawerLayout.addEventListener(\"scroll\", () => {\n if (drawerLayout.scrollTop >= window.innerHeight) {\n body.classList.add('scrolled');\n } else {\n body.classList.remove('scrolled');\n }\n });\n};\n\n/**\n * Set the last used attribute for the last used toggle button for a drawer.\n *\n * @param {object} toggleButton The clicked button.\n */\nconst setLastUsedToggle = (toggleButton) => {\n if (toggleButton.dataset.target) {\n document.querySelectorAll('[data-toggle=\"drawers\"][data-target=\"' + toggleButton.dataset.target + '\"]')\n .forEach(btn => {\n btn.dataset.lastused = false;\n });\n toggleButton.dataset.lastused = true;\n }\n};\n\n/**\n * Set the focus to the last used button to open this drawer.\n * @param {string} target The drawer target.\n */\nconst focusLastUsedToggle = (target) => {\n const lastUsedButton = document.querySelector('[data-toggle=\"drawers\"][data-target=\"' + target + '\"][data-lastused=\"true\"');\n if (lastUsedButton) {\n lastUsedButton.focus();\n }\n};\n\n/**\n * Register the event listeners for the drawer.\n *\n * @private\n */\nconst registerListeners = () => {\n // Listen for show/hide events.\n document.addEventListener('click', e => {\n const toggleButton = e.target.closest('[data-toggle=\"drawers\"][data-action=\"toggle\"]');\n if (toggleButton && toggleButton.dataset.target) {\n e.preventDefault();\n const targetDrawer = document.getElementById(toggleButton.dataset.target);\n const drawerInstance = Drawers.getDrawerInstanceForNode(targetDrawer);\n setLastUsedToggle(toggleButton);\n\n drawerInstance.toggleVisibility();\n }\n\n const openDrawerButton = e.target.closest('[data-toggle=\"drawers\"][data-action=\"opendrawer\"]');\n if (openDrawerButton && openDrawerButton.dataset.target) {\n e.preventDefault();\n const targetDrawer = document.getElementById(openDrawerButton.dataset.target);\n const drawerInstance = Drawers.getDrawerInstanceForNode(targetDrawer);\n setLastUsedToggle(toggleButton);\n\n drawerInstance.openDrawer();\n }\n\n const closeDrawerButton = e.target.closest('[data-toggle=\"drawers\"][data-action=\"closedrawer\"]');\n if (closeDrawerButton && closeDrawerButton.dataset.target) {\n e.preventDefault();\n const targetDrawer = document.getElementById(closeDrawerButton.dataset.target);\n const drawerInstance = Drawers.getDrawerInstanceForNode(targetDrawer);\n\n drawerInstance.closeDrawer();\n focusLastUsedToggle(closeDrawerButton.dataset.target);\n }\n });\n\n // Close drawer when another drawer opens.\n document.addEventListener(Drawers.eventTypes.drawerShow, e => {\n if (isLarge()) {\n return;\n }\n Drawers.closeOtherDrawers(e.detail.drawerInstance);\n });\n\n const closeOnResizeListener = () => {\n if (isSmall()) {\n let anyOpen = false;\n drawerMap.forEach(drawerInstance => {\n if (drawerInstance.isOpen) {\n if (drawerInstance.closeOnResize) {\n drawerInstance.closeDrawer();\n } else {\n anyOpen = true;\n }\n }\n });\n\n if (anyOpen) {\n getBackdrop().then(backdrop => backdrop.show()).catch();\n }\n } else {\n getBackdrop().then(backdrop => backdrop.hide()).catch();\n }\n };\n\n window.addEventListener('resize', debounce(closeOnResizeListener, 400));\n};\n\nscroller();\nregisterListeners();\n\nconst drawers = document.querySelectorAll('[data-region=\"fixed-drawer\"]');\ndrawers.forEach(drawerNode => Drawers.getDrawerInstanceForNode(drawerNode));\n"],"file":"drawers.min.js"} \ No newline at end of file diff --git a/theme/boost/amd/src/drawers.js b/theme/boost/amd/src/drawers.js index be690e0cc90..df1581cbff9 100644 --- a/theme/boost/amd/src/drawers.js +++ b/theme/boost/amd/src/drawers.js @@ -63,17 +63,6 @@ const isSmall = () => { return browserWidth < sizes.medium; }; -/** - * Check if the user uses a medium size browser. - * - * @returns {boolean} true if the body is smaller than sizes.medium max size. - * @private - */ -const isMedium = () => { - const browserWidth = getCurrentWidth(); - return (browserWidth >= sizes.medium) && (browserWidth < sizes.large); -}; - /** * Check if the user uses a large size browser. * @@ -340,7 +329,7 @@ export default class Drawers { getBackdrop().then(backdrop => { backdrop.hide(); - if (isMedium()) { + if (isSmall()) { const pageWrapper = document.getElementById('page-wrapper'); pageWrapper.style.overflow = 'auto'; } diff --git a/theme/boost/scss/moodle/layout.scss b/theme/boost/scss/moodle/layout.scss index a975ded7686..8cb7284aca6 100644 --- a/theme/boost/scss/moodle/layout.scss +++ b/theme/boost/scss/moodle/layout.scss @@ -35,8 +35,8 @@ #page.drawers { margin-top: calc(#{$navbar-height} + 2rem); - padding-left: 10px; - padding-right: 10px; + padding-left: 15px; + padding-right: 15px; .main-inner { max-width: 100%; width: 100%; diff --git a/theme/boost/style/moodle.css b/theme/boost/style/moodle.css index 3c9a90d90bf..e04c0ba950e 100644 --- a/theme/boost/style/moodle.css +++ b/theme/boost/style/moodle.css @@ -19461,8 +19461,8 @@ span[data-flexitour="container"][x-placement="right"], span[data-flexitour="cont #page.drawers { margin-top: calc(50px + 2rem); - padding-left: 10px; - padding-right: 10px; } + padding-left: 15px; + padding-right: 15px; } #page.drawers .main-inner { max-width: 100%; width: 100%; diff --git a/theme/classic/style/moodle.css b/theme/classic/style/moodle.css index 9acfe6c3df9..23a06e33456 100644 --- a/theme/classic/style/moodle.css +++ b/theme/classic/style/moodle.css @@ -19651,8 +19651,8 @@ span[data-flexitour="container"][x-placement="right"], span[data-flexitour="cont #page.drawers { margin-top: calc(50px + 2rem); - padding-left: 10px; - padding-right: 10px; } + padding-left: 15px; + padding-right: 15px; } #page.drawers .main-inner { max-width: 100%; width: 100%;