From bcb35d9dbe7c5a016b8d23f5a1a5130b9c6557bd Mon Sep 17 00:00:00 2001 From: Ferran Recio Date: Fri, 22 Oct 2021 12:51:34 +0200 Subject: [PATCH] MDL-72456 theme_boost: detect drawers scroll --- theme/boost/amd/build/drawers.min.js | 2 +- theme/boost/amd/build/drawers.min.js.map | 2 +- theme/boost/amd/src/drawers.js | 30 ++++++++++++++++++++++-- theme/boost/scss/moodle/courseindex.scss | 1 - theme/boost/scss/moodle/drawer.scss | 8 +++++-- theme/boost/style/moodle.css | 11 +++++---- theme/classic/style/moodle.css | 11 +++++---- 7 files changed, 50 insertions(+), 15 deletions(-) diff --git a/theme/boost/amd/build/drawers.min.js b/theme/boost/amd/build/drawers.min.js index 0cb20093c3b..25862b37647 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","core/pending","jquery"],function(a,b,c,d,e,f,g,h){"use strict";Object.defineProperty(a,"__esModule",{value:!0});a.default=void 0;b=k(b);c=k(c);d=j(d);g=k(g);h=k(h);function i(){if("function"!=typeof WeakMap)return null;var a=new WeakMap;i=function(){return a};return a}function j(a){if(a&&a.__esModule){return a}if(null===a||"object"!==_typeof(a)&&"function"!=typeof a){return{default:a}}var b=i();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 k(a){return a&&a.__esModule?a:{default:a}}function l(a,b){if(!(a instanceof b)){throw new TypeError("Cannot call a class as a function")}}function m(a,b){for(var c=0,d;c=s.large},w=function(){if(!p){p=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();A.closeAllDrawers()});return a}).catch()}return p},x=function(a){var b=document.querySelector("".concat(r.OPENBTN,"[data-target=\"").concat(a,"\"]"));if(!b){b=document.querySelector("".concat(r.TOGGLEBTN,"[data-target=\"").concat(a,"\"]"))}return b},y=function(a){var b=[a.querySelector(r.CLOSEBTN),x(a.id)];b.forEach(function(a){if(!a){return}if(a.hasAttribute("data-original-title")){(0,h.default)(a).tooltip("disable")}else{a.dataset.disabledToggle=a.dataset.toggle;a.removeAttribute("data-toggle")}})},z=function(a){var b=[a.querySelector(r.CLOSEBTN),x(a.id)];b.forEach(function(a){if(!a){return}if(a.hasAttribute("data-original-title")){(0,h.default)(a).tooltip("enable")}else if(a.dataset.disabledToggle){a.dataset.toggle=a.dataset.disabledToggle;(0,h.default)(a).tooltip()}})},A=function(){function a(b){l(this,a);o(this,"drawerNode",null);this.drawerNode=b;if(this.drawerNode.classList.contains("show")){this.openDrawer({focusOnCloseButton:!1})}else if(1==this.drawerNode.dataset.forceopen){if(!u()){this.openDrawer({focusOnCloseButton:!1})}}else{d.hide(this.drawerNode)}if(u()){y(this.drawerNode)}q.set(b,this)}n(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(r.TOGGLEBTN);if(b&&b.dataset.target){a.preventDefault();var c=document.getElementById(b.dataset.target),d=A.getDrawerInstanceForNode(c);B(b);d.toggleVisibility()}var e=a.target.closest(r.OPENBTN);if(e&&e.dataset.target){a.preventDefault();var f=document.getElementById(e.dataset.target),g=A.getDrawerInstanceForNode(f);B(b);g.openDrawer()}var h=a.target.closest(r.CLOSEBTN);if(h&&h.dataset.target){a.preventDefault();var i=document.getElementById(h.dataset.target),j=A.getDrawerInstanceForNode(i);j.closeDrawer();C(h.dataset.target)}});document.addEventListener(A.eventTypes.drawerShow,function(a){if(v()){return}A.closeOtherDrawers(a.detail.drawerInstance)});window.addEventListener("resize",(0,f.debounce)(function closeOnResizeListener(){if(u()){var a=!1;q.forEach(function(b){y(b.drawerNode);if(b.isOpen){if(b.closeOnResize){b.closeDrawer()}else{a=!0}}});if(a){w().then(function(a){return a.show()}).catch()}}else{q.forEach(function(a){z(a.drawerNode)});w().then(function(a){return a.hide()}).catch()}},400))})();var D=document.querySelectorAll(r.DRAWERS);D.forEach(function(a){return A.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","core/pending","jquery"],function(a,b,c,d,e,f,g,h){"use strict";Object.defineProperty(a,"__esModule",{value:!0});a.default=void 0;b=k(b);c=k(c);d=j(d);g=k(g);h=k(h);function i(){if("function"!=typeof WeakMap)return null;var a=new WeakMap;i=function(){return a};return a}function j(a){if(a&&a.__esModule){return a}if(null===a||"object"!==_typeof(a)&&"function"!=typeof a){return{default:a}}var b=i();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 k(a){return a&&a.__esModule?a:{default:a}}function l(a,b){if(!(a instanceof b)){throw new TypeError("Cannot call a class as a function")}}function m(a,b){for(var c=0,d;c=t.large},x=function(){if(!p){p=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();C.closeAllDrawers()});return a}).catch()}return p},y=function(a){var b=document.querySelector("".concat(r.OPENBTN,"[data-target=\"").concat(a,"\"]"));if(!b){b=document.querySelector("".concat(r.TOGGLEBTN,"[data-target=\"").concat(a,"\"]"))}return b},z=function(a){var b=[a.querySelector(r.CLOSEBTN),y(a.id)];b.forEach(function(a){if(!a){return}if(a.hasAttribute("data-original-title")){(0,h.default)(a).tooltip("disable")}else{a.dataset.disabledToggle=a.dataset.toggle;a.removeAttribute("data-toggle")}})},A=function(a){var b=[a.querySelector(r.CLOSEBTN),y(a.id)];b.forEach(function(a){if(!a){return}if(a.hasAttribute("data-original-title")){(0,h.default)(a).tooltip("enable")}else if(a.dataset.disabledToggle){a.dataset.toggle=a.dataset.disabledToggle;(0,h.default)(a).tooltip()}})},B=function(a){var b=a.querySelector(r.DRAWERCONTENT);if(!b){return}b.addEventListener("scroll",function(){a.classList.toggle(s.SCROLLED,0!=b.scrollTop)})},C=function(){function a(b){l(this,a);o(this,"drawerNode",null);this.drawerNode=b;if(this.drawerNode.classList.contains("show")){this.openDrawer({focusOnCloseButton:!1})}else if(1==this.drawerNode.dataset.forceopen){if(!v()){this.openDrawer({focusOnCloseButton:!1})}}else{d.hide(this.drawerNode)}if(v()){z(this.drawerNode)}B(this.drawerNode);q.set(b,this)}n(a,[{key:"dispatchEvent",value:function dispatchEvent(a){var b=1=window.innerHeight){a.classList.add(s.SCROLLED)}else{a.classList.remove(s.SCROLLED)}})}})();(function registerListeners(){document.addEventListener("click",function(a){var b=a.target.closest(r.TOGGLEBTN);if(b&&b.dataset.target){a.preventDefault();var c=document.getElementById(b.dataset.target),d=C.getDrawerInstanceForNode(c);D(b);d.toggleVisibility()}var e=a.target.closest(r.OPENBTN);if(e&&e.dataset.target){a.preventDefault();var f=document.getElementById(e.dataset.target),g=C.getDrawerInstanceForNode(f);D(b);g.openDrawer()}var h=a.target.closest(r.CLOSEBTN);if(h&&h.dataset.target){a.preventDefault();var i=document.getElementById(h.dataset.target),j=C.getDrawerInstanceForNode(i);j.closeDrawer();E(h.dataset.target)}});document.addEventListener(C.eventTypes.drawerShow,function(a){if(w()){return}C.closeOtherDrawers(a.detail.drawerInstance)});window.addEventListener("resize",(0,f.debounce)(function closeOnResizeListener(){if(v()){var a=!1;q.forEach(function(b){z(b.drawerNode);if(b.isOpen){if(b.closeOnResize){b.closeDrawer()}else{a=!0}}});if(a){x().then(function(a){return a.show()}).catch()}}else{q.forEach(function(a){A(a.drawerNode)});x().then(function(a){return a.hide()}).catch()}},400))})();var F=document.querySelectorAll(r.DRAWERS);F.forEach(function(a){return C.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 be506d80fe9..bd144ea660a 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","SELECTORS","BUTTONS","CLOSEBTN","OPENBTN","TOGGLEBTN","DRAWERS","CONTAINER","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","getDrawerOpenButton","drawerId","openButton","querySelector","disableDrawerTooltips","drawerNode","buttons","id","forEach","button","hasAttribute","tooltip","dataset","disabledToggle","toggle","removeAttribute","enableDrawerTooltips","classList","contains","openDrawer","focusOnCloseButton","forceopen","Aria","hide","set","eventname","cancelable","drawerInstance","pendingPromise","Pending","showEvent","dispatchEvent","eventTypes","drawerShow","defaultPrevented","unhide","add","preference","M","util","set_user_preference","state","page","getElementById","backdrop","show","pageWrapper","style","overflow","setTimeout","closeButton","focus","resolve","drawerShown","hideEvent","drawerHide","remove","drawerHidden","closeDrawer","parseInt","closeOnResize","has","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":"siBAsBA,OACA,OACA,OAGA,OAEA,O,8hCAEIA,CAAAA,CAAe,CAAG,I,CAEhBC,CAAS,CAAG,GAAIC,CAAAA,G,CAEhBC,CAAS,CAAG,CACdC,OAAO,CAAE,4BADK,CAEdC,QAAQ,CAAE,yDAFI,CAGdC,OAAO,CAAE,wDAHK,CAIdC,SAAS,CAAE,oDAJG,CAKdC,OAAO,CAAE,gCALK,CAMdC,SAAS,CAAE,eANG,C,CAeZC,CAAK,CAAG,CACVC,MAAM,CAAE,GADE,CAEVC,KAAK,CAAE,IAFG,C,CAWRC,CAAe,CAAG,UAAM,CAC1B,GAAMC,CAAAA,CAAO,CAAGC,QAAQ,CAACC,IAAT,CAAcC,qBAAd,EAAhB,CACA,MAAOH,CAAAA,CAAO,CAACI,CAAR,CAAYJ,CAAO,CAACK,KAC9B,C,CAQKC,CAAO,CAAG,UAAM,CAClB,GAAMC,CAAAA,CAAY,CAAGR,CAAe,EAApC,CACA,MAAOQ,CAAAA,CAAY,CAAGX,CAAK,CAACC,MAC/B,C,CAQKW,CAAO,CAAG,UAAM,CAClB,GAAMD,CAAAA,CAAY,CAAGR,CAAe,EAApC,CACA,MAAOQ,CAAAA,CAAY,EAAIX,CAAK,CAACE,KAChC,C,CAQKW,CAAW,CAAG,UAAM,CACtB,GAAI,CAACvB,CAAL,CAAsB,CAClBA,CAAe,CAAGwB,UAAUC,MAAV,CAAiB,qBAAjB,CAAwC,EAAxC,EACjBC,IADiB,CACZ,SAAAC,CAAI,QAAI,IAAIC,UAAJ,CAAkBD,CAAlB,CAAJ,CADQ,EAEjBD,IAFiB,CAEZ,SAAAG,CAAa,CAAI,CACnBA,CAAa,CAACC,kBAAd,GAAmCC,GAAnC,CAAuC,CAAvC,EAA0CC,gBAA1C,CAA2D,OAA3D,CAAoE,SAAAC,CAAC,CAAI,CACrEA,CAAC,CAACC,cAAF,GACAC,CAAO,CAACC,eAAR,EACH,CAHD,EAIA,MAAOP,CAAAA,CACV,CARiB,EASjBQ,KATiB,EAUrB,CACD,MAAOrC,CAAAA,CACV,C,CASKsC,CAAmB,CAAG,SAACC,CAAD,CAAc,CACtC,GAAIC,CAAAA,CAAU,CAAGzB,QAAQ,CAAC0B,aAAT,WAA0BtC,CAAS,CAACG,OAApC,2BAA4DiC,CAA5D,QAAjB,CACA,GAAI,CAACC,CAAL,CAAiB,CACbA,CAAU,CAAGzB,QAAQ,CAAC0B,aAAT,WAA0BtC,CAAS,CAACI,SAApC,2BAA8DgC,CAA9D,QAChB,CACD,MAAOC,CAAAA,CACV,C,CAQKE,CAAqB,CAAG,SAACC,CAAD,CAAgB,CAC1C,GAAMC,CAAAA,CAAO,CAAG,CACZD,CAAU,CAACF,aAAX,CAAyBtC,CAAS,CAACE,QAAnC,CADY,CAEZiC,CAAmB,CAACK,CAAU,CAACE,EAAZ,CAFP,CAAhB,CAIAD,CAAO,CAACE,OAAR,CAAgB,SAAAC,CAAM,CAAI,CACtB,GAAI,CAACA,CAAL,CAAa,CACT,MACH,CACD,GAAIA,CAAM,CAACC,YAAP,CAAoB,qBAApB,CAAJ,CAAgD,CAE5C,cAAOD,CAAP,EAAeE,OAAf,CAAuB,SAAvB,CACH,CAHD,IAGO,CACHF,CAAM,CAACG,OAAP,CAAeC,cAAf,CAAgCJ,CAAM,CAACG,OAAP,CAAeE,MAA/C,CACAL,CAAM,CAACM,eAAP,CAAuB,aAAvB,CACH,CACJ,CAXD,CAYH,C,CAQKC,CAAoB,CAAG,SAACX,CAAD,CAAgB,CACzC,GAAMC,CAAAA,CAAO,CAAG,CACZD,CAAU,CAACF,aAAX,CAAyBtC,CAAS,CAACE,QAAnC,CADY,CAEZiC,CAAmB,CAACK,CAAU,CAACE,EAAZ,CAFP,CAAhB,CAIAD,CAAO,CAACE,OAAR,CAAgB,SAAAC,CAAM,CAAI,CACtB,GAAI,CAACA,CAAL,CAAa,CACT,MACH,CAED,GAAIA,CAAM,CAACC,YAAP,CAAoB,qBAApB,CAAJ,CAAgD,CAC5C,cAAOD,CAAP,EAAeE,OAAf,CAAuB,QAAvB,CACH,CAFD,IAEO,IAAIF,CAAM,CAACG,OAAP,CAAeC,cAAnB,CAAmC,CACtCJ,CAAM,CAACG,OAAP,CAAeE,MAAf,CAAwBL,CAAM,CAACG,OAAP,CAAeC,cAAvC,CACA,cAAOJ,CAAP,EAAeE,OAAf,EACH,CACJ,CAXD,CAYH,C,CAmDoBd,C,YAMjB,WAAYQ,CAAZ,CAAwB,+BAFX,IAEW,EACpB,KAAKA,UAAL,CAAkBA,CAAlB,CAEA,GAAI,KAAKA,UAAL,CAAgBY,SAAhB,CAA0BC,QAA1B,CAAmC,MAAnC,CAAJ,CAAgD,CAC5C,KAAKC,UAAL,CAAgB,CAACC,kBAAkB,GAAnB,CAAhB,CACH,CAFD,IAEO,IAAyC,CAArC,OAAKf,UAAL,CAAgBO,OAAhB,CAAwBS,SAA5B,CAA4C,CAC/C,GAAI,CAACvC,CAAO,EAAZ,CAAgB,CACZ,KAAKqC,UAAL,CAAgB,CAACC,kBAAkB,GAAnB,CAAhB,CACH,CACJ,CAJM,IAIA,CACHE,CAAI,CAACC,IAAL,CAAU,KAAKlB,UAAf,CACH,CAGD,GAAIvB,CAAO,EAAX,CAAe,CACXsB,CAAqB,CAAC,KAAKC,UAAN,CACxB,CAED1C,CAAS,CAAC6D,GAAV,CAAcnB,CAAd,CAA0B,IAA1B,CACH,C,uDAyFaoB,C,CAA+B,IAApBC,CAAAA,CAAoB,2DACzC,MAAO,oBACHD,CADG,CAEH,CACIE,cAAc,CAAE,IADpB,CAFG,CAKH,KAAKtB,UALF,CAMH,CACIqB,UAAU,CAAVA,CADJ,CANG,CAUV,C,+CAY4C,uEAAJ,EAAI,KAAjCN,kBAAiC,CAAjCA,CAAiC,iBAEnCQ,CAAc,CAAG,GAAIC,UAAJ,CAAY,0BAAZ,CAFkB,CAGnCC,CAAS,CAAG,KAAKC,aAAL,CAAmBlC,CAAO,CAACmC,UAAR,CAAmBC,UAAtC,IAHuB,CAIzC,GAAIH,CAAS,CAACI,gBAAd,CAAgC,CAC5B,MACH,CAGD,eAAK7B,UAAL,CAAgBF,aAAhB,CAA8BtC,CAAS,CAACE,QAAxC,wBAAmDkD,SAAnD,CAA6DH,MAA7D,CAAoE,QAApE,KAGA,GAAIZ,CAAAA,CAAU,CAAGF,CAAmB,CAAC,KAAKK,UAAL,CAAgBE,EAAjB,CAApC,CACA,GAAIL,CAAU,EAAIA,CAAU,CAACQ,YAAX,CAAwB,qBAAxB,CAAlB,CAAkE,OAE9D,wBAAOR,CAAP,wBAAoBS,OAApB,CAA4B,MAA5B,CACH,CAEDW,CAAI,CAACa,MAAL,CAAY,KAAK9B,UAAjB,EACA,KAAKA,UAAL,CAAgBY,SAAhB,CAA0BmB,GAA1B,CAA8B,MAA9B,EAEA,GAAMC,CAAAA,CAAU,CAAG,KAAKhC,UAAL,CAAgBO,OAAhB,CAAwByB,UAA3C,CACA,GAAIA,CAAU,EAAI,CAACvD,CAAO,EAAtB,EAAkE,CAArC,OAAKuB,UAAL,CAAgBO,OAAhB,CAAwBS,SAAzD,CAA0E,CACtEiB,CAAC,CAACC,IAAF,CAAOC,mBAAP,CAA2BH,CAA3B,IACH,CAED,GAAMI,CAAAA,CAAK,CAAG,KAAKpC,UAAL,CAAgBO,OAAhB,CAAwB6B,KAAtC,CACA,GAAIA,CAAJ,CAAW,CACP,GAAMC,CAAAA,CAAI,CAAGjE,QAAQ,CAACkE,cAAT,CAAwB,MAAxB,CAAb,CACAD,CAAI,CAACzB,SAAL,CAAemB,GAAf,CAAmBK,CAAnB,CACH,CAED,GAAI3D,CAAO,EAAX,CAAe,CACXG,CAAW,GAAGG,IAAd,CAAmB,SAAAwD,CAAQ,CAAI,CAC3BA,CAAQ,CAACC,IAAT,GAEA,GAAMC,CAAAA,CAAW,CAAGrE,QAAQ,CAACkE,cAAT,CAAwB,cAAxB,CAApB,CACAG,CAAW,CAACC,KAAZ,CAAkBC,QAAlB,CAA6B,QAA7B,CACA,MAAOJ,CAAAA,CACV,CAND,EAOC7C,KAPD,EAQH,CAGDkD,UAAU,CAAC,UAAM,CACb,GAAMC,CAAAA,CAAW,CAAG,CAAI,CAAC7C,UAAL,CAAgBF,aAAhB,CAA8BtC,CAAS,CAACE,QAAxC,CAApB,CACAmF,CAAW,CAACjC,SAAZ,CAAsBH,MAAtB,CAA6B,QAA7B,KACA,GAAIM,CAAJ,CAAwB,CACpB8B,CAAW,CAACC,KAAZ,EACH,CACDvB,CAAc,CAACwB,OAAf,EACH,CAPS,CAOP,GAPO,CAAV,CASA,KAAKrB,aAAL,CAAmBlC,CAAO,CAACmC,UAAR,CAAmBqB,WAAtC,CACH,C,iDAKa,YAEJzB,CAAc,CAAG,GAAIC,UAAJ,CAAY,2BAAZ,CAFb,CAIJyB,CAAS,CAAG,KAAKvB,aAAL,CAAmBlC,CAAO,CAACmC,UAAR,CAAmBuB,UAAtC,IAJR,CAKV,GAAID,CAAS,CAACpB,gBAAd,CAAgC,CAC5B,MACH,CAGD,GAAMgB,CAAAA,CAAW,CAAG,KAAK7C,UAAL,CAAgBF,aAAhB,CAA8BtC,CAAS,CAACE,QAAxC,CAApB,CACA,OAAAmF,CAAW,WAAXA,SAAAA,CAAW,CAAEjC,SAAb,CAAuBH,MAAvB,CAA8B,QAA9B,KAEA,GAAIoC,CAAW,CAACxC,YAAZ,CAAyB,qBAAzB,CAAJ,CAAqD,OAEjD,wBAAOwC,CAAP,wBAAqBvC,OAArB,CAA6B,MAA7B,CACH,CAED,GAAM0B,CAAAA,CAAU,CAAG,KAAKhC,UAAL,CAAgBO,OAAhB,CAAwByB,UAA3C,CACA,GAAIA,CAAJ,CAAgB,CACZC,CAAC,CAACC,IAAF,CAAOC,mBAAP,CAA2BH,CAA3B,IACH,CAED,GAAMI,CAAAA,CAAK,CAAG,KAAKpC,UAAL,CAAgBO,OAAhB,CAAwB6B,KAAtC,CACA,GAAIA,CAAJ,CAAW,CACP,GAAMC,CAAAA,CAAI,CAAGjE,QAAQ,CAACkE,cAAT,CAAwB,MAAxB,CAAb,CACAD,CAAI,CAACzB,SAAL,CAAeuC,MAAf,CAAsBf,CAAtB,CACH,CAEDnB,CAAI,CAACC,IAAL,CAAU,KAAKlB,UAAf,EACA,KAAKA,UAAL,CAAgBY,SAAhB,CAA0BuC,MAA1B,CAAiC,MAAjC,EAEAvE,CAAW,GAAGG,IAAd,CAAmB,SAAAwD,CAAQ,CAAI,CAC3BA,CAAQ,CAACrB,IAAT,GAEA,GAAIzC,CAAO,EAAX,CAAe,CACX,GAAMgE,CAAAA,CAAW,CAAGrE,QAAQ,CAACkE,cAAT,CAAwB,cAAxB,CAApB,CACAG,CAAW,CAACC,KAAZ,CAAkBC,QAAlB,CAA6B,MAChC,CACD,MAAOJ,CAAAA,CACV,CARD,EASC7C,KATD,GAYAkD,UAAU,CAAC,UAAM,CACb,GAAI/C,CAAAA,CAAU,CAAGF,CAAmB,CAAC,CAAI,CAACK,UAAL,CAAgBE,EAAjB,CAApC,CACA,GAAIL,CAAJ,CAAgB,CACZA,CAAU,CAACiD,KAAX,EACH,CACDvB,CAAc,CAACwB,OAAf,EACH,CANS,CAMP,GANO,CAAV,CAQA,KAAKrB,aAAL,CAAmBlC,CAAO,CAACmC,UAAR,CAAmByB,YAAtC,CACH,C,2DAKkB,CACf,GAAI,KAAKpD,UAAL,CAAgBY,SAAhB,CAA0BC,QAA1B,CAAmC,MAAnC,CAAJ,CAAgD,CAC5C,KAAKwC,WAAL,EACH,CAFD,IAEO,CACH,KAAKvC,UAAL,EACH,CACJ,C,kCApOY,CACT,MAAO,MAAKd,UAAL,CAAgBY,SAAhB,CAA0BC,QAA1B,CAAmC,MAAnC,CACV,C,yCAOmB,CAChB,MAAO,CAAC,CAACyC,QAAQ,CAAC,KAAKtD,UAAL,CAAgBO,OAAhB,CAAwBgD,aAAzB,CACpB,C,4EAwD+BvD,C,CAAY,CACxC,GAAI,CAAC1C,CAAS,CAACkG,GAAV,CAAcxD,CAAd,CAAL,CAAgC,CAC5B,GAAIR,CAAAA,CAAJ,CAAYQ,CAAZ,CACH,CAED,MAAO1C,CAAAA,CAAS,CAAC8B,GAAV,CAAcY,CAAd,CACV,C,yDAgKwB,CACrB1C,CAAS,CAAC6C,OAAV,CAAkB,SAAAmB,CAAc,CAAI,CAChCA,CAAc,CAAC+B,WAAf,EACH,CAFD,CAGH,C,4DAOwBI,C,CAAoB,CACzCnG,CAAS,CAAC6C,OAAV,CAAkB,SAAAmB,CAAc,CAAI,CAChC,GAAIA,CAAc,GAAKmC,CAAvB,CAA2C,CACvC,MACH,CAEDnC,CAAc,CAAC+B,WAAf,EACH,CAND,CAOH,C,8BA5RgB7D,C,cAsDG,CAQhBoC,UAAU,CAAE,0BARI,CAiBhBoB,WAAW,CAAE,2BAjBG,CA0BhBE,UAAU,CAAE,0BA1BI,CAmChBE,YAAY,CAAE,4BAnCE,C,KAiQlBM,CAAAA,CAAiB,CAAG,SAACC,CAAD,CAAkB,CACxC,GAAIA,CAAY,CAACpD,OAAb,CAAqBqD,MAAzB,CAAiC,CAC7BxF,QAAQ,CAACyF,gBAAT,WAA6BrG,CAAS,CAACC,OAAvC,2BAA+DkG,CAAY,CAACpD,OAAb,CAAqBqD,MAApF,SACCzD,OADD,CACS,SAAA2D,CAAG,CAAI,CACZA,CAAG,CAACvD,OAAJ,CAAYwD,QAAZ,GACH,CAHD,EAIAJ,CAAY,CAACpD,OAAb,CAAqBwD,QAArB,GACH,CACJ,C,CAMKC,CAAmB,CAAG,SAACJ,CAAD,CAAY,CACpC,GAAMK,CAAAA,CAAc,CAAG7F,QAAQ,CAAC0B,aAAT,WAA0BtC,CAAS,CAACC,OAApC,2BAA4DmG,CAA5D,+BAAvB,CACA,GAAIK,CAAJ,CAAoB,CAChBA,CAAc,CAACnB,KAAf,EACH,CACJ,C,CA6ED,CAnHiB,QAAXoB,CAAAA,QAAW,EAAM,IACb7F,CAAAA,CAAI,CAAGD,QAAQ,CAAC0B,aAAT,CAAuB,MAAvB,CADM,CAEbqE,CAAY,CAAG/F,QAAQ,CAAC0B,aAAT,CAAuBtC,CAAS,CAACM,SAAjC,CAFF,CAGnB,GAAIqG,CAAJ,CAAkB,CACdA,CAAY,CAAC9E,gBAAb,CAA8B,QAA9B,CAAwC,UAAM,CAC1C,GAAI8E,CAAY,CAACC,SAAb,EAA0BC,MAAM,CAACC,WAArC,CAAkD,CAC9CjG,CAAI,CAACuC,SAAL,CAAemB,GAAf,CAAmB,UAAnB,CACH,CAFD,IAEO,CACH1D,CAAI,CAACuC,SAAL,CAAeuC,MAAf,CAAsB,UAAtB,CACH,CACJ,CAND,CAOH,CACJ,CAuGD,IACA,CAvE0B,QAApBoB,CAAAA,iBAAoB,EAAM,CAE5BnG,QAAQ,CAACiB,gBAAT,CAA0B,OAA1B,CAAmC,SAAAC,CAAC,CAAI,CACpC,GAAMqE,CAAAA,CAAY,CAAGrE,CAAC,CAACsE,MAAF,CAASY,OAAT,CAAiBhH,CAAS,CAACI,SAA3B,CAArB,CACA,GAAI+F,CAAY,EAAIA,CAAY,CAACpD,OAAb,CAAqBqD,MAAzC,CAAiD,CAC7CtE,CAAC,CAACC,cAAF,GAD6C,GAEvCkF,CAAAA,CAAY,CAAGrG,QAAQ,CAACkE,cAAT,CAAwBqB,CAAY,CAACpD,OAAb,CAAqBqD,MAA7C,CAFwB,CAGvCtC,CAAc,CAAG9B,CAAO,CAACkF,wBAAR,CAAiCD,CAAjC,CAHsB,CAI7Cf,CAAiB,CAACC,CAAD,CAAjB,CAEArC,CAAc,CAACqD,gBAAf,EACH,CAED,GAAMC,CAAAA,CAAgB,CAAGtF,CAAC,CAACsE,MAAF,CAASY,OAAT,CAAiBhH,CAAS,CAACG,OAA3B,CAAzB,CACA,GAAIiH,CAAgB,EAAIA,CAAgB,CAACrE,OAAjB,CAAyBqD,MAAjD,CAAyD,CACrDtE,CAAC,CAACC,cAAF,GADqD,GAE/CkF,CAAAA,CAAY,CAAGrG,QAAQ,CAACkE,cAAT,CAAwBsC,CAAgB,CAACrE,OAAjB,CAAyBqD,MAAjD,CAFgC,CAG/CtC,CAAc,CAAG9B,CAAO,CAACkF,wBAAR,CAAiCD,CAAjC,CAH8B,CAIrDf,CAAiB,CAACC,CAAD,CAAjB,CAEArC,CAAc,CAACR,UAAf,EACH,CAED,GAAM+D,CAAAA,CAAiB,CAAGvF,CAAC,CAACsE,MAAF,CAASY,OAAT,CAAiBhH,CAAS,CAACE,QAA3B,CAA1B,CACA,GAAImH,CAAiB,EAAIA,CAAiB,CAACtE,OAAlB,CAA0BqD,MAAnD,CAA2D,CACvDtE,CAAC,CAACC,cAAF,GADuD,GAEjDkF,CAAAA,CAAY,CAAGrG,QAAQ,CAACkE,cAAT,CAAwBuC,CAAiB,CAACtE,OAAlB,CAA0BqD,MAAlD,CAFkC,CAGjDtC,CAAc,CAAG9B,CAAO,CAACkF,wBAAR,CAAiCD,CAAjC,CAHgC,CAKvDnD,CAAc,CAAC+B,WAAf,GACAW,CAAmB,CAACa,CAAiB,CAACtE,OAAlB,CAA0BqD,MAA3B,CACtB,CACJ,CA9BD,EAiCAxF,QAAQ,CAACiB,gBAAT,CAA0BG,CAAO,CAACmC,UAAR,CAAmBC,UAA7C,CAAyD,SAAAtC,CAAC,CAAI,CAC1D,GAAIX,CAAO,EAAX,CAAe,CACX,MACH,CACDa,CAAO,CAACsF,iBAAR,CAA0BxF,CAAC,CAACyF,MAAF,CAASzD,cAAnC,CACH,CALD,EAgCA+C,MAAM,CAAChF,gBAAP,CAAwB,QAAxB,CAAkC,eAzBJ,QAAxB2F,CAAAA,qBAAwB,EAAM,CAChC,GAAIvG,CAAO,EAAX,CAAe,CACX,GAAIwG,CAAAA,CAAO,GAAX,CACA3H,CAAS,CAAC6C,OAAV,CAAkB,SAAAmB,CAAc,CAAI,CAChCvB,CAAqB,CAACuB,CAAc,CAACtB,UAAhB,CAArB,CACA,GAAIsB,CAAc,CAAC4D,MAAnB,CAA2B,CACvB,GAAI5D,CAAc,CAACiC,aAAnB,CAAkC,CAC9BjC,CAAc,CAAC+B,WAAf,EACH,CAFD,IAEO,CACH4B,CAAO,GACV,CACJ,CACJ,CATD,EAWA,GAAIA,CAAJ,CAAa,CACTrG,CAAW,GAAGG,IAAd,CAAmB,SAAAwD,CAAQ,QAAIA,CAAAA,CAAQ,CAACC,IAAT,EAAJ,CAA3B,EAAgD9C,KAAhD,EACH,CACJ,CAhBD,IAgBO,CACHpC,CAAS,CAAC6C,OAAV,CAAkB,SAAAmB,CAAc,CAAI,CAChCX,CAAoB,CAACW,CAAc,CAACtB,UAAhB,CACvB,CAFD,EAGApB,CAAW,GAAGG,IAAd,CAAmB,SAAAwD,CAAQ,QAAIA,CAAAA,CAAQ,CAACrB,IAAT,EAAJ,CAA3B,EAAgDxB,KAAhD,EACH,CACJ,CAEiC,CAAgC,GAAhC,CAAlC,CACH,CAGD,IAEA,GAAMyF,CAAAA,CAAO,CAAG/G,QAAQ,CAACyF,gBAAT,CAA0BrG,CAAS,CAACK,OAApC,CAAhB,CACAsH,CAAO,CAAChF,OAAR,CAAgB,SAAAH,CAAU,QAAIR,CAAAA,CAAO,CAACkF,wBAAR,CAAiC1E,CAAjC,CAAJ,CAA1B,E","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';\nimport Pending from 'core/pending';\n// The jQuery module is only used for interacting with Boostrap 4. It can we removed when MDL-71979 is integrated.\nimport jQuery from 'jquery';\n\nlet backdropPromise = null;\n\nconst drawerMap = new Map();\n\nconst SELECTORS = {\n BUTTONS: '[data-toggler=\"drawers\"]',\n CLOSEBTN: '[data-toggler=\"drawers\"][data-action=\"closedrawer\"]',\n OPENBTN: '[data-toggler=\"drawers\"][data-action=\"opendrawer\"]',\n TOGGLEBTN: '[data-toggler=\"drawers\"][data-action=\"toggle\"]',\n DRAWERS: '[data-region=\"fixed-drawer\"]',\n CONTAINER: '#page.drawers',\n};\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 * Get the button element to open a specific drawer.\n *\n * @param {String} drawerId the drawer element Id\n * @return {HTMLElement|undefined} the open button element\n * @private\n */\nconst getDrawerOpenButton = (drawerId) => {\n let openButton = document.querySelector(`${SELECTORS.OPENBTN}[data-target=\"${drawerId}\"]`);\n if (!openButton) {\n openButton = document.querySelector(`${SELECTORS.TOGGLEBTN}[data-target=\"${drawerId}\"]`);\n }\n return openButton;\n};\n\n/**\n * Disable drawer tooltips.\n *\n * @param {HTMLElement} drawerNode the drawer main node\n * @private\n */\nconst disableDrawerTooltips = (drawerNode) => {\n const buttons = [\n drawerNode.querySelector(SELECTORS.CLOSEBTN),\n getDrawerOpenButton(drawerNode.id),\n ];\n buttons.forEach(button => {\n if (!button) {\n return;\n }\n if (button.hasAttribute('data-original-title')) {\n // The jQuery is still used in Boostrap 4. It can we removed when MDL-71979 is integrated.\n jQuery(button).tooltip('disable');\n } else {\n button.dataset.disabledToggle = button.dataset.toggle;\n button.removeAttribute('data-toggle');\n }\n });\n};\n\n/**\n * Enable drawer tooltips.\n *\n * @param {HTMLElement} drawerNode the drawer main node\n * @private\n */\nconst enableDrawerTooltips = (drawerNode) => {\n const buttons = [\n drawerNode.querySelector(SELECTORS.CLOSEBTN),\n getDrawerOpenButton(drawerNode.id),\n ];\n buttons.forEach(button => {\n if (!button) {\n return;\n }\n // The jQuery is still used in Boostrap 4. It can we removed when MDL-71979 is integrated.\n if (button.hasAttribute('data-original-title')) {\n jQuery(button).tooltip('enable');\n } else if (button.dataset.disabledToggle) {\n button.dataset.toggle = button.dataset.disabledToggle;\n jQuery(button).tooltip();\n }\n });\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({focusOnCloseButton: false});\n } else if (this.drawerNode.dataset.forceopen == 1) {\n if (!isSmall()) {\n this.openDrawer({focusOnCloseButton: false});\n }\n } else {\n Aria.hide(this.drawerNode);\n }\n\n // Disable tooltips in small screens.\n if (isSmall()) {\n disableDrawerTooltips(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 * By default, openDrawer sets the page focus to the close drawer button. However, when a drawer is open at page\n * load, this represents an accessibility problem as the initial focus changes without any user interaction. The\n * focusOnCloseButton parameter can be set to false to prevent this behaviour.\n *\n * @param {object} args\n * @param {boolean} [args.focusOnCloseButton=true] Whether to alter page focus when opening the drawer\n */\n openDrawer({focusOnCloseButton = true} = {}) {\n\n const pendingPromise = new Pending('theme_boost/drawers:open');\n const showEvent = this.dispatchEvent(Drawers.eventTypes.drawerShow, true);\n if (showEvent.defaultPrevented) {\n return;\n }\n\n // Hide close button while the drawer is showing to prevent glitchy effects.\n this.drawerNode.querySelector(SELECTORS.CLOSEBTN)?.classList.toggle('hidden', true);\n\n // Remove open tooltip if still visible.\n let openButton = getDrawerOpenButton(this.drawerNode.id);\n if (openButton && openButton.hasAttribute('data-original-title')) {\n // The jQuery is still used in Boostrap 4. It can we removed when MDL-71979 is integrated.\n jQuery(openButton)?.tooltip('hide');\n }\n\n Aria.unhide(this.drawerNode);\n this.drawerNode.classList.add('show');\n\n const preference = this.drawerNode.dataset.preference;\n if (preference && !isSmall() && (this.drawerNode.dataset.forceopen != 1)) {\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 // Show close button once the drawer is fully opened.\n setTimeout(() => {\n const closeButton = this.drawerNode.querySelector(SELECTORS.CLOSEBTN);\n closeButton.classList.toggle('hidden', false);\n if (focusOnCloseButton) {\n closeButton.focus();\n }\n pendingPromise.resolve();\n }, 300);\n\n this.dispatchEvent(Drawers.eventTypes.drawerShown);\n }\n\n /**\n * Close the drawer.\n */\n closeDrawer() {\n\n const pendingPromise = new Pending('theme_boost/drawers:close');\n\n const hideEvent = this.dispatchEvent(Drawers.eventTypes.drawerHide, true);\n if (hideEvent.defaultPrevented) {\n return;\n }\n\n // Hide close button while the drawer is hiding to prevent glitchy effects.\n const closeButton = this.drawerNode.querySelector(SELECTORS.CLOSEBTN);\n closeButton?.classList.toggle('hidden', true);\n // Remove the close button tooltip if visible.\n if (closeButton.hasAttribute('data-original-title')) {\n // The jQuery is still used in Boostrap 4. It can we removed when MDL-71979 is integrated.\n jQuery(closeButton)?.tooltip('hide');\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 // Move focus to the open drawer (or toggler) button once the drawer is hidden.\n setTimeout(() => {\n let openButton = getDrawerOpenButton(this.drawerNode.id);\n if (openButton) {\n openButton.focus();\n }\n pendingPromise.resolve();\n }, 300);\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(SELECTORS.CONTAINER);\n if (drawerLayout) {\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/**\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(`${SELECTORS.BUTTONS}[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(`${SELECTORS.BUTTONS}[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(SELECTORS.TOGGLEBTN);\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(SELECTORS.OPENBTN);\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(SELECTORS.CLOSEBTN);\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 disableDrawerTooltips(drawerInstance.drawerNode);\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 drawerMap.forEach(drawerInstance => {\n enableDrawerTooltips(drawerInstance.drawerNode);\n });\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(SELECTORS.DRAWERS);\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","SELECTORS","BUTTONS","CLOSEBTN","OPENBTN","TOGGLEBTN","DRAWERS","CONTAINER","DRAWERCONTENT","CLASSES","SCROLLED","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","getDrawerOpenButton","drawerId","openButton","querySelector","disableDrawerTooltips","drawerNode","buttons","id","forEach","button","hasAttribute","tooltip","dataset","disabledToggle","toggle","removeAttribute","enableDrawerTooltips","addInnerScrollListener","content","classList","scrollTop","contains","openDrawer","focusOnCloseButton","forceopen","Aria","hide","set","eventname","cancelable","drawerInstance","pendingPromise","Pending","showEvent","dispatchEvent","eventTypes","drawerShow","defaultPrevented","unhide","add","preference","M","util","set_user_preference","state","page","getElementById","backdrop","show","pageWrapper","style","overflow","setTimeout","closeButton","focus","resolve","drawerShown","hideEvent","drawerHide","remove","drawerHidden","closeDrawer","parseInt","closeOnResize","has","comparisonInstance","setLastUsedToggle","toggleButton","target","querySelectorAll","btn","lastused","focusLastUsedToggle","lastUsedButton","scroller","drawerLayout","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';\nimport Pending from 'core/pending';\n// The jQuery module is only used for interacting with Boostrap 4. It can we removed when MDL-71979 is integrated.\nimport jQuery from 'jquery';\n\nlet backdropPromise = null;\n\nconst drawerMap = new Map();\n\nconst SELECTORS = {\n BUTTONS: '[data-toggler=\"drawers\"]',\n CLOSEBTN: '[data-toggler=\"drawers\"][data-action=\"closedrawer\"]',\n OPENBTN: '[data-toggler=\"drawers\"][data-action=\"opendrawer\"]',\n TOGGLEBTN: '[data-toggler=\"drawers\"][data-action=\"toggle\"]',\n DRAWERS: '[data-region=\"fixed-drawer\"]',\n CONTAINER: '#page.drawers',\n DRAWERCONTENT: '.drawercontent',\n};\n\nconst CLASSES = {\n SCROLLED: 'scrolled',\n};\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 * Get the button element to open a specific drawer.\n *\n * @param {String} drawerId the drawer element Id\n * @return {HTMLElement|undefined} the open button element\n * @private\n */\nconst getDrawerOpenButton = (drawerId) => {\n let openButton = document.querySelector(`${SELECTORS.OPENBTN}[data-target=\"${drawerId}\"]`);\n if (!openButton) {\n openButton = document.querySelector(`${SELECTORS.TOGGLEBTN}[data-target=\"${drawerId}\"]`);\n }\n return openButton;\n};\n\n/**\n * Disable drawer tooltips.\n *\n * @param {HTMLElement} drawerNode the drawer main node\n * @private\n */\nconst disableDrawerTooltips = (drawerNode) => {\n const buttons = [\n drawerNode.querySelector(SELECTORS.CLOSEBTN),\n getDrawerOpenButton(drawerNode.id),\n ];\n buttons.forEach(button => {\n if (!button) {\n return;\n }\n if (button.hasAttribute('data-original-title')) {\n // The jQuery is still used in Boostrap 4. It can we removed when MDL-71979 is integrated.\n jQuery(button).tooltip('disable');\n } else {\n button.dataset.disabledToggle = button.dataset.toggle;\n button.removeAttribute('data-toggle');\n }\n });\n};\n\n/**\n * Enable drawer tooltips.\n *\n * @param {HTMLElement} drawerNode the drawer main node\n * @private\n */\nconst enableDrawerTooltips = (drawerNode) => {\n const buttons = [\n drawerNode.querySelector(SELECTORS.CLOSEBTN),\n getDrawerOpenButton(drawerNode.id),\n ];\n buttons.forEach(button => {\n if (!button) {\n return;\n }\n // The jQuery is still used in Boostrap 4. It can we removed when MDL-71979 is integrated.\n if (button.hasAttribute('data-original-title')) {\n jQuery(button).tooltip('enable');\n } else if (button.dataset.disabledToggle) {\n button.dataset.toggle = button.dataset.disabledToggle;\n jQuery(button).tooltip();\n }\n });\n};\n\n/**\n * Add scroll listeners to a drawer element.\n *\n * @param {HTMLElement} drawerNode the drawer main node\n * @private\n */\nconst addInnerScrollListener = (drawerNode) => {\n const content = drawerNode.querySelector(SELECTORS.DRAWERCONTENT);\n if (!content) {\n return;\n }\n content.addEventListener(\"scroll\", () => {\n drawerNode.classList.toggle(\n CLASSES.SCROLLED,\n content.scrollTop != 0\n );\n });\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({focusOnCloseButton: false});\n } else if (this.drawerNode.dataset.forceopen == 1) {\n if (!isSmall()) {\n this.openDrawer({focusOnCloseButton: false});\n }\n } else {\n Aria.hide(this.drawerNode);\n }\n\n // Disable tooltips in small screens.\n if (isSmall()) {\n disableDrawerTooltips(this.drawerNode);\n }\n\n addInnerScrollListener(this.drawerNode);\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 * By default, openDrawer sets the page focus to the close drawer button. However, when a drawer is open at page\n * load, this represents an accessibility problem as the initial focus changes without any user interaction. The\n * focusOnCloseButton parameter can be set to false to prevent this behaviour.\n *\n * @param {object} args\n * @param {boolean} [args.focusOnCloseButton=true] Whether to alter page focus when opening the drawer\n */\n openDrawer({focusOnCloseButton = true} = {}) {\n\n const pendingPromise = new Pending('theme_boost/drawers:open');\n const showEvent = this.dispatchEvent(Drawers.eventTypes.drawerShow, true);\n if (showEvent.defaultPrevented) {\n return;\n }\n\n // Hide close button while the drawer is showing to prevent glitchy effects.\n this.drawerNode.querySelector(SELECTORS.CLOSEBTN)?.classList.toggle('hidden', true);\n\n // Remove open tooltip if still visible.\n let openButton = getDrawerOpenButton(this.drawerNode.id);\n if (openButton && openButton.hasAttribute('data-original-title')) {\n // The jQuery is still used in Boostrap 4. It can we removed when MDL-71979 is integrated.\n jQuery(openButton)?.tooltip('hide');\n }\n\n Aria.unhide(this.drawerNode);\n this.drawerNode.classList.add('show');\n\n const preference = this.drawerNode.dataset.preference;\n if (preference && !isSmall() && (this.drawerNode.dataset.forceopen != 1)) {\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 // Show close button once the drawer is fully opened.\n setTimeout(() => {\n const closeButton = this.drawerNode.querySelector(SELECTORS.CLOSEBTN);\n closeButton.classList.toggle('hidden', false);\n if (focusOnCloseButton) {\n closeButton.focus();\n }\n pendingPromise.resolve();\n }, 300);\n\n this.dispatchEvent(Drawers.eventTypes.drawerShown);\n }\n\n /**\n * Close the drawer.\n */\n closeDrawer() {\n\n const pendingPromise = new Pending('theme_boost/drawers:close');\n\n const hideEvent = this.dispatchEvent(Drawers.eventTypes.drawerHide, true);\n if (hideEvent.defaultPrevented) {\n return;\n }\n\n // Hide close button while the drawer is hiding to prevent glitchy effects.\n const closeButton = this.drawerNode.querySelector(SELECTORS.CLOSEBTN);\n closeButton?.classList.toggle('hidden', true);\n // Remove the close button tooltip if visible.\n if (closeButton.hasAttribute('data-original-title')) {\n // The jQuery is still used in Boostrap 4. It can we removed when MDL-71979 is integrated.\n jQuery(closeButton)?.tooltip('hide');\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 // Move focus to the open drawer (or toggler) button once the drawer is hidden.\n setTimeout(() => {\n let openButton = getDrawerOpenButton(this.drawerNode.id);\n if (openButton) {\n openButton.focus();\n }\n pendingPromise.resolve();\n }, 300);\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(SELECTORS.CONTAINER);\n if (drawerLayout) {\n drawerLayout.addEventListener(\"scroll\", () => {\n if (drawerLayout.scrollTop >= window.innerHeight) {\n body.classList.add(CLASSES.SCROLLED);\n } else {\n body.classList.remove(CLASSES.SCROLLED);\n }\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(`${SELECTORS.BUTTONS}[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(`${SELECTORS.BUTTONS}[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(SELECTORS.TOGGLEBTN);\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(SELECTORS.OPENBTN);\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(SELECTORS.CLOSEBTN);\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 disableDrawerTooltips(drawerInstance.drawerNode);\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 drawerMap.forEach(drawerInstance => {\n enableDrawerTooltips(drawerInstance.drawerNode);\n });\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(SELECTORS.DRAWERS);\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 f91c7a44a61..b6a97dd4ac0 100644 --- a/theme/boost/amd/src/drawers.js +++ b/theme/boost/amd/src/drawers.js @@ -40,6 +40,11 @@ const SELECTORS = { TOGGLEBTN: '[data-toggler="drawers"][data-action="toggle"]', DRAWERS: '[data-region="fixed-drawer"]', CONTAINER: '#page.drawers', + DRAWERCONTENT: '.drawercontent', +}; + +const CLASSES = { + SCROLLED: 'scrolled', }; /** @@ -173,6 +178,25 @@ const enableDrawerTooltips = (drawerNode) => { }); }; +/** + * Add scroll listeners to a drawer element. + * + * @param {HTMLElement} drawerNode the drawer main node + * @private + */ +const addInnerScrollListener = (drawerNode) => { + const content = drawerNode.querySelector(SELECTORS.DRAWERCONTENT); + if (!content) { + return; + } + content.addEventListener("scroll", () => { + drawerNode.classList.toggle( + CLASSES.SCROLLED, + content.scrollTop != 0 + ); + }); +}; + /** * The Drawers class is used to control on-screen drawer elements. * @@ -246,6 +270,8 @@ export default class Drawers { disableDrawerTooltips(this.drawerNode); } + addInnerScrollListener(this.drawerNode); + drawerMap.set(drawerNode, this); } @@ -520,9 +546,9 @@ const scroller = () => { if (drawerLayout) { drawerLayout.addEventListener("scroll", () => { if (drawerLayout.scrollTop >= window.innerHeight) { - body.classList.add('scrolled'); + body.classList.add(CLASSES.SCROLLED); } else { - body.classList.remove('scrolled'); + body.classList.remove(CLASSES.SCROLLED); } }); } diff --git a/theme/boost/scss/moodle/courseindex.scss b/theme/boost/scss/moodle/courseindex.scss index bd6c0fb5250..cc14a47a338 100644 --- a/theme/boost/scss/moodle/courseindex.scss +++ b/theme/boost/scss/moodle/courseindex.scss @@ -102,7 +102,6 @@ $courseindex-item-current: $primary !default; // Completion. .completioninfo { min-width: 24px; - transform: scale(0.7); &.completion_complete { color: $success; diff --git a/theme/boost/scss/moodle/drawer.scss b/theme/boost/scss/moodle/drawer.scss index f595f553365..404946f8df8 100644 --- a/theme/boost/scss/moodle/drawer.scss +++ b/theme/boost/scss/moodle/drawer.scss @@ -124,7 +124,7 @@ $right-drawer-width: 320px; right: 0; height: calc(100% - #{$navbar-height}); width: $right-drawer-width; - box-shadow: -2px 2px 4px rgba(0, 0, 0, .08); + box-shadow: -2px 2px 4px $drawer-shadow-color; padding: 0; visibility: visible; opacity: 1; @@ -158,7 +158,7 @@ $right-drawer-width: 320px; .dir-rtl { [data-region=right-hand-drawer] { - box-shadow: 2px 2px 4px rgba(0, 0, 0, .08); + box-shadow: 2px 2px 4px $drawer-shadow-color; } } @@ -233,6 +233,9 @@ $right-drawer-width: 320px; display: flex; align-items: center; } +.drawer.scrolled .drawerheader { + box-shadow: 0 8px 11px -7px $drawer-shadow-color; +} @include media-breakpoint-down(md) { .drawer-md { @@ -252,6 +255,7 @@ $right-drawer-width: 320px; .drawercontent { position: relative; + z-index: -1; height: calc(100% - #{$navbar-height}); display: flex; flex-direction: column; diff --git a/theme/boost/style/moodle.css b/theme/boost/style/moodle.css index f01240e5349..5918066c568 100644 --- a/theme/boost/style/moodle.css +++ b/theme/boost/style/moodle.css @@ -14712,7 +14712,7 @@ body.drawer-ease { right: 0; height: calc(100% - 60px); width: 320px; - box-shadow: -2px 2px 4px rgba(0, 0, 0, 0.08); + box-shadow: -2px 2px 4px rgba(0, 0, 0, 0.25); padding: 0; visibility: visible; opacity: 1; } @@ -14736,7 +14736,7 @@ body.drawer-ease { overflow: hidden; } } .dir-rtl [data-region=right-hand-drawer] { - box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.08); } + box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25); } .drawer { transition: left 0.2s ease, right 0.2s ease, top 0.2s ease, bottom 0.2s ease; @@ -14781,6 +14781,9 @@ body.drawer-ease { display: flex; align-items: center; } +.drawer.scrolled .drawerheader { + box-shadow: 0 8px 11px -7px rgba(0, 0, 0, 0.25); } + @media (max-width: 991.98px) { .drawer-md { display: block; @@ -14845,6 +14848,7 @@ body.drawer-ease { .drawercontent { position: relative; + z-index: -1; height: calc(100% - 60px); display: flex; flex-direction: column; @@ -20963,8 +20967,7 @@ div.editor_atto_toolbar button .icon { .courseindex .courseindex-item.pageitem a { color: black; } .courseindex .courseindex-item .completioninfo { - min-width: 24px; - transform: scale(0.7); } + min-width: 24px; } .courseindex .courseindex-item .completioninfo.completion_complete { color: #357a32; } .courseindex .courseindex-item .completioninfo.completion_fail { diff --git a/theme/classic/style/moodle.css b/theme/classic/style/moodle.css index 31a7f10a09b..ac01a1fc060 100644 --- a/theme/classic/style/moodle.css +++ b/theme/classic/style/moodle.css @@ -14712,7 +14712,7 @@ body.drawer-ease { right: 0; height: calc(100% - 50px); width: 320px; - box-shadow: -2px 2px 4px rgba(0, 0, 0, 0.08); + box-shadow: -2px 2px 4px rgba(0, 0, 0, 0.25); padding: 0; visibility: visible; opacity: 1; } @@ -14736,7 +14736,7 @@ body.drawer-ease { overflow: hidden; } } .dir-rtl [data-region=right-hand-drawer] { - box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.08); } + box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25); } .drawer { transition: left 0.2s ease, right 0.2s ease, top 0.2s ease, bottom 0.2s ease; @@ -14781,6 +14781,9 @@ body.drawer-ease { display: flex; align-items: center; } +.drawer.scrolled .drawerheader { + box-shadow: 0 8px 11px -7px rgba(0, 0, 0, 0.25); } + @media (max-width: 991.98px) { .drawer-md { display: block; @@ -14845,6 +14848,7 @@ body.drawer-ease { .drawercontent { position: relative; + z-index: -1; height: calc(100% - 50px); display: flex; flex-direction: column; @@ -20909,8 +20913,7 @@ div.editor_atto_toolbar button .icon { .courseindex .courseindex-item.pageitem a { color: black; } .courseindex .courseindex-item .completioninfo { - min-width: 24px; - transform: scale(0.7); } + min-width: 24px; } .courseindex .courseindex-item .completioninfo.completion_complete { color: #357a32; } .courseindex .courseindex-item .completioninfo.completion_fail {