mirror of
https://github.com/moodle/moodle.git
synced 2025-08-08 10:26:40 +02:00
Merge branch 'MDL-83869-main' of https://github.com/ferranrecio/moodle
This commit is contained in:
commit
5fbd4b6555
13 changed files with 1031 additions and 0 deletions
19
lib/amd/build/local/collapsable_section/controls.min.js
vendored
Normal file
19
lib/amd/build/local/collapsable_section/controls.min.js
vendored
Normal file
|
@ -0,0 +1,19 @@
|
|||
define("core/local/collapsable_section/controls",["exports","core/local/collapsable_section/events","jquery"],(function(_exports,_events,_jquery){var obj;
|
||||
/**
|
||||
* The collapsable sections controls.
|
||||
*
|
||||
* @module core/local/collapsable_section/controls
|
||||
* @copyright 2024 Ferran Recio <ferran@moodle.com>
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*
|
||||
* @example <caption>Example of controlling a collapsable section.</caption>
|
||||
*
|
||||
* import CollapsableSection from 'core/local/collapsable_section/controls';
|
||||
*
|
||||
* const section = CollapsableSection.instanceFromSelector('#MyCollapsableSection');
|
||||
*
|
||||
* // Use hide, show and toggle methods to control the section.
|
||||
* section.hide();
|
||||
*/Object.defineProperty(_exports,"__esModule",{value:!0}),_exports.default=void 0,_jquery=(obj=_jquery)&&obj.__esModule?obj:{default:obj};let initialized=!1;return _exports.default=class{static instanceFromSelector(selector){const elements=document.querySelector(selector);if(!elements)throw new Error("No elements found with the selector: "+selector);return new this(elements)}static init(){initialized||(initialized=!0,(0,_jquery.default)(document).on(_events.eventTypes.hiddenBsCollapse,(event=>{this.isCollapsableComponent(event.target)&&(0,_events.notifyCollapsableSectionHidden)(event.target)})),(0,_jquery.default)(document).on(_events.eventTypes.shownBsCollapse,(event=>{this.isCollapsableComponent(event.target)&&(0,_events.notifyCollapsableSectionShown)(event.target)})))}static isCollapsableComponent(element){return element.hasAttribute("data-mdl-component")&&"core/local/collapsable_section"===element.getAttribute("data-mdl-component")}constructor(element){this.element=element}hide(){(0,_jquery.default)(this.element).collapse("hide")}show(){(0,_jquery.default)(this.element).collapse("show")}toggle(){(0,_jquery.default)(this.element).collapse("toggle")}isVisible(){return this.element.classList.contains("show")}},_exports.default}));
|
||||
|
||||
//# sourceMappingURL=controls.min.js.map
|
File diff suppressed because one or more lines are too long
20
lib/amd/build/local/collapsable_section/events.min.js
vendored
Normal file
20
lib/amd/build/local/collapsable_section/events.min.js
vendored
Normal file
|
@ -0,0 +1,20 @@
|
|||
define("core/local/collapsable_section/events",["exports","core/event_dispatcher"],(function(_exports,_event_dispatcher){Object.defineProperty(_exports,"__esModule",{value:!0}),_exports.notifyCollapsableSectionShown=_exports.notifyCollapsableSectionHidden=_exports.eventTypes=void 0;
|
||||
/**
|
||||
* The collapsable section events.
|
||||
*
|
||||
* This module wraps the standard bootstrap collapsable events, but for collapsable sections.
|
||||
*
|
||||
* @module core/local/collapsable_section/events
|
||||
* @copyright 2024 Ferran Recio <ferran@moodle.com>
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*
|
||||
* @example <caption>Example of listening to a collapsable section events.</caption>
|
||||
* import {eventTypes as collapsableSectionEventTypes} from 'core/local/collapsable_section/events';
|
||||
*
|
||||
* document.addEventListener(collapsableSectionEventTypes.shown, event => {
|
||||
* window.console.log(event.target); // The HTMLElement relating to the block whose content was updated.
|
||||
* });
|
||||
*/
|
||||
const eventTypes={shown:"core_collapsable_section_shown",hidden:"core_collapsable_section_hidden",hideBsCollapse:"hide.bs.collapse",hiddenBsCollapse:"hidden.bs.collapse",showBsCollapse:"show.bs.collapse",shownBsCollapse:"shown.bs.collapse"};_exports.eventTypes=eventTypes;_exports.notifyCollapsableSectionShown=element=>(0,_event_dispatcher.dispatchEvent)(eventTypes.shown,{},element);_exports.notifyCollapsableSectionHidden=element=>(0,_event_dispatcher.dispatchEvent)(eventTypes.hidden,{},element)}));
|
||||
|
||||
//# sourceMappingURL=events.min.js.map
|
|
@ -0,0 +1 @@
|
|||
{"version":3,"file":"events.min.js","sources":["../../../src/local/collapsable_section/events.js"],"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 <http://www.gnu.org/licenses/>.\n\n/**\n * The collapsable section events.\n *\n * This module wraps the standard bootstrap collapsable events, but for collapsable sections.\n *\n * @module core/local/collapsable_section/events\n * @copyright 2024 Ferran Recio <ferran@moodle.com>\n * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later\n *\n * @example <caption>Example of listening to a collapsable section events.</caption>\n * import {eventTypes as collapsableSectionEventTypes} from 'core/local/collapsable_section/events';\n *\n * document.addEventListener(collapsableSectionEventTypes.shown, event => {\n * window.console.log(event.target); // The HTMLElement relating to the block whose content was updated.\n * });\n */\n\nimport {dispatchEvent} from 'core/event_dispatcher';\n\n/**\n * Events for `core_block`.\n *\n * @constant\n * @property {String} blockContentUpdated See {@link event:blockContentUpdated}\n */\nexport const eventTypes = {\n /**\n * An event triggered when the content of a block has changed.\n *\n * @event blockContentUpdated\n * @type {CustomEvent}\n * @property {HTMLElement} target The block element that was updated\n * @property {object} detail\n * @property {number} detail.instanceId The block instance id\n */\n shown: 'core_collapsable_section_shown',\n hidden: 'core_collapsable_section_hidden',\n // All Bootstrap 4 jQuery events are wrapped while MDL-71979 is not integrated.\n hideBsCollapse: 'hide.bs.collapse',\n hiddenBsCollapse: 'hidden.bs.collapse',\n showBsCollapse: 'show.bs.collapse',\n shownBsCollapse: 'shown.bs.collapse',\n};\n\n/**\n * Trigger an event to indicate that the content of a block was updated.\n *\n * @method notifyBlockContentUpdated\n * @param {HTMLElement} element The HTMLElement containing the updated block.\n * @returns {CustomEvent}\n * @fires blockContentUpdated\n */\nexport const notifyCollapsableSectionShown = element => dispatchEvent(\n eventTypes.shown,\n {},\n element\n);\n\n/**\n * Trigger an event to indicate that the content of a block was updated.\n *\n * @method notifyBlockContentUpdated\n * @param {HTMLElement} element The HTMLElement containing the updated block.\n * @returns {CustomEvent}\n * @fires blockContentUpdated\n */\nexport const notifyCollapsableSectionHidden = element => dispatchEvent(\n eventTypes.hidden,\n {},\n element\n);\n"],"names":["eventTypes","shown","hidden","hideBsCollapse","hiddenBsCollapse","showBsCollapse","shownBsCollapse","element"],"mappings":";;;;;;;;;;;;;;;;;MAwCaA,WAAa,CAUtBC,MAAO,iCACPC,OAAQ,kCAERC,eAAgB,mBAChBC,iBAAkB,qBAClBC,eAAgB,mBAChBC,gBAAiB,2FAWwBC,UAAW,mCACpDP,WAAWC,MACX,GACAM,iDAW0CA,UAAW,mCACrDP,WAAWE,OACX,GACAK"}
|
138
lib/amd/src/local/collapsable_section/controls.js
vendored
Normal file
138
lib/amd/src/local/collapsable_section/controls.js
vendored
Normal file
|
@ -0,0 +1,138 @@
|
|||
// This file is part of Moodle - http://moodle.org/
|
||||
//
|
||||
// Moodle is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
//
|
||||
// Moodle is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
/**
|
||||
* The collapsable sections controls.
|
||||
*
|
||||
* @module core/local/collapsable_section/controls
|
||||
* @copyright 2024 Ferran Recio <ferran@moodle.com>
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*
|
||||
* @example <caption>Example of controlling a collapsable section.</caption>
|
||||
*
|
||||
* import CollapsableSection from 'core/local/collapsable_section/controls';
|
||||
*
|
||||
* const section = CollapsableSection.instanceFromSelector('#MyCollapsableSection');
|
||||
*
|
||||
* // Use hide, show and toggle methods to control the section.
|
||||
* section.hide();
|
||||
*/
|
||||
|
||||
import {
|
||||
eventTypes,
|
||||
notifyCollapsableSectionHidden,
|
||||
notifyCollapsableSectionShown
|
||||
} from 'core/local/collapsable_section/events';
|
||||
|
||||
// The jQuery module is only used for interacting with Boostrap 4. It can we removed when MDL-71979 is integrated.
|
||||
import jQuery from 'jquery';
|
||||
|
||||
let initialized = false;
|
||||
|
||||
export default class {
|
||||
/**
|
||||
* Create a new instance from a query selector.
|
||||
*
|
||||
* @param {String} selector The selector of the collapsable section.
|
||||
* @return {CollapsableSection} The collapsable section controls.
|
||||
* @throws {Error} If no elements are found with the selector.
|
||||
*/
|
||||
static instanceFromSelector(selector) {
|
||||
const elements = document.querySelector(selector);
|
||||
if (!elements) {
|
||||
throw new Error('No elements found with the selector: ' + selector);
|
||||
}
|
||||
return new this(elements);
|
||||
}
|
||||
|
||||
/**
|
||||
* Initialize the collapsable section controls.
|
||||
*/
|
||||
static init() {
|
||||
if (initialized) {
|
||||
return;
|
||||
}
|
||||
initialized = true;
|
||||
|
||||
// We want to add extra events to the standard bootstrap collapsable events.
|
||||
// TODO: change all jquery events to custom events once MDL-71979 is integrated.
|
||||
jQuery(document).on(eventTypes.hiddenBsCollapse, event => {
|
||||
if (!this.isCollapsableComponent(event.target)) {
|
||||
return;
|
||||
}
|
||||
notifyCollapsableSectionHidden(event.target);
|
||||
});
|
||||
jQuery(document).on(eventTypes.shownBsCollapse, event => {
|
||||
if (!this.isCollapsableComponent(event.target)) {
|
||||
return;
|
||||
}
|
||||
notifyCollapsableSectionShown(event.target);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if the element is a collapsable section.
|
||||
*
|
||||
* @private
|
||||
* @param {HTMLElement} element The element to check.
|
||||
* @return {boolean} True if the element is a collapsable section.
|
||||
*/
|
||||
static isCollapsableComponent(element) {
|
||||
return element.hasAttribute('data-mdl-component')
|
||||
&& element.getAttribute('data-mdl-component') === 'core/local/collapsable_section';
|
||||
}
|
||||
|
||||
/**
|
||||
* Creates an instance of the controls for a collapsable section.
|
||||
*
|
||||
* @param {HTMLElement} element - The DOM element that this control will manage.
|
||||
*/
|
||||
constructor(element) {
|
||||
this.element = element;
|
||||
}
|
||||
|
||||
/**
|
||||
* Hides the collapsible section element.
|
||||
*/
|
||||
hide() {
|
||||
// TODO: change all jquery once MDL-71979 is integrated.
|
||||
jQuery(this.element).collapse('hide');
|
||||
}
|
||||
|
||||
/**
|
||||
* Shows the collapsible section element.
|
||||
*/
|
||||
show() {
|
||||
// TODO: change all jquery once MDL-71979 is integrated.
|
||||
jQuery(this.element).collapse('show');
|
||||
}
|
||||
|
||||
/**
|
||||
* Toggle the collapsible section element.
|
||||
*/
|
||||
toggle() {
|
||||
// TODO: change all jquery once MDL-71979 is integrated.
|
||||
jQuery(this.element).collapse('toggle');
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if the collapsable section is visible.
|
||||
*
|
||||
* @return {boolean} True if the collapsable section is visible.
|
||||
*/
|
||||
isVisible() {
|
||||
return this.element.classList.contains('show');
|
||||
}
|
||||
}
|
86
lib/amd/src/local/collapsable_section/events.js
Normal file
86
lib/amd/src/local/collapsable_section/events.js
Normal file
|
@ -0,0 +1,86 @@
|
|||
// This file is part of Moodle - http://moodle.org/
|
||||
//
|
||||
// Moodle is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
//
|
||||
// Moodle is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
/**
|
||||
* The collapsable section events.
|
||||
*
|
||||
* This module wraps the standard bootstrap collapsable events, but for collapsable sections.
|
||||
*
|
||||
* @module core/local/collapsable_section/events
|
||||
* @copyright 2024 Ferran Recio <ferran@moodle.com>
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*
|
||||
* @example <caption>Example of listening to a collapsable section events.</caption>
|
||||
* import {eventTypes as collapsableSectionEventTypes} from 'core/local/collapsable_section/events';
|
||||
*
|
||||
* document.addEventListener(collapsableSectionEventTypes.shown, event => {
|
||||
* window.console.log(event.target); // The HTMLElement relating to the block whose content was updated.
|
||||
* });
|
||||
*/
|
||||
|
||||
import {dispatchEvent} from 'core/event_dispatcher';
|
||||
|
||||
/**
|
||||
* Events for `core_block`.
|
||||
*
|
||||
* @constant
|
||||
* @property {String} blockContentUpdated See {@link event:blockContentUpdated}
|
||||
*/
|
||||
export const eventTypes = {
|
||||
/**
|
||||
* An event triggered when the content of a block has changed.
|
||||
*
|
||||
* @event blockContentUpdated
|
||||
* @type {CustomEvent}
|
||||
* @property {HTMLElement} target The block element that was updated
|
||||
* @property {object} detail
|
||||
* @property {number} detail.instanceId The block instance id
|
||||
*/
|
||||
shown: 'core_collapsable_section_shown',
|
||||
hidden: 'core_collapsable_section_hidden',
|
||||
// All Bootstrap 4 jQuery events are wrapped while MDL-71979 is not integrated.
|
||||
hideBsCollapse: 'hide.bs.collapse',
|
||||
hiddenBsCollapse: 'hidden.bs.collapse',
|
||||
showBsCollapse: 'show.bs.collapse',
|
||||
shownBsCollapse: 'shown.bs.collapse',
|
||||
};
|
||||
|
||||
/**
|
||||
* Trigger an event to indicate that the content of a block was updated.
|
||||
*
|
||||
* @method notifyBlockContentUpdated
|
||||
* @param {HTMLElement} element The HTMLElement containing the updated block.
|
||||
* @returns {CustomEvent}
|
||||
* @fires blockContentUpdated
|
||||
*/
|
||||
export const notifyCollapsableSectionShown = element => dispatchEvent(
|
||||
eventTypes.shown,
|
||||
{},
|
||||
element
|
||||
);
|
||||
|
||||
/**
|
||||
* Trigger an event to indicate that the content of a block was updated.
|
||||
*
|
||||
* @method notifyBlockContentUpdated
|
||||
* @param {HTMLElement} element The HTMLElement containing the updated block.
|
||||
* @returns {CustomEvent}
|
||||
* @fires blockContentUpdated
|
||||
*/
|
||||
export const notifyCollapsableSectionHidden = element => dispatchEvent(
|
||||
eventTypes.hidden,
|
||||
{},
|
||||
element
|
||||
);
|
Loading…
Add table
Add a link
Reference in a new issue