AutorÃa | Ultima modificación | Ver Log |
// 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/>./*** Tiny H5P Content configuration.** @module tiny_h5p/filtercontent* @copyright 2022 Andrew Lyons <andrew@nicols.co.uk>* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later*/import {registerPlaceholderSelectors} from 'editor_tiny/options';export const setup = async(editor) => {const className = 'h5p-placeholder';const classSelector = `.${className}`;// Register the H5P Formatter to the placeholder selector list.registerPlaceholderSelectors(editor, [classSelector]);// Register the H5P Formatter for use in all buttons.editor.on('PreInit', () => {editor.formatter.register('h5p', {inline: 'div',classes: className,});});editor.on('SetContent', () => {// Listen to the SetContent event on the editor and update any h5p-placeholder to not be editable.// Doing this means that the inner content of the placeholder cannot be changed without using the dialogue.// The SetContent event is called whenever content is changed by actions such as initial load, paste, undo, etc.editor.getBody().querySelectorAll(`${classSelector}:not([contenteditable])`).forEach((node) => {node.contentEditable = false;});});};