lib/editor/tiny/plugins/h5p/amd/src/filtercontent.js

// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.

/**
 * 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;
        });
    });
};