Proyectos de Subversion Moodle

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 1
// This file is part of Moodle - http://moodle.org/
2
//
3
// Moodle is free software: you can redistribute it and/or modify
4
// it under the terms of the GNU General Public License as published by
5
// the Free Software Foundation, either version 3 of the License, or
6
// (at your option) any later version.
7
//
8
// Moodle is distributed in the hope that it will be useful,
9
// but WITHOUT ANY WARRANTY; without even the implied warranty of
10
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
// GNU General Public License for more details.
12
//
13
// You should have received a copy of the GNU General Public License
14
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
15
 
16
/**
17
 * Tiny H5P Content configuration.
18
 *
19
 * @module      tiny_h5p/filtercontent
20
 * @copyright   2022 Andrew Lyons <andrew@nicols.co.uk>
21
 * @license     http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
22
 */
23
 
24
import {registerPlaceholderSelectors} from 'editor_tiny/options';
25
 
26
export const setup = async(editor) => {
27
    const className = 'h5p-placeholder';
28
    const classSelector = `.${className}`;
29
    // Register the H5P Formatter to the placeholder selector list.
30
    registerPlaceholderSelectors(editor, [classSelector]);
31
    // Register the H5P Formatter for use in all buttons.
32
    editor.on('PreInit', () => {
33
        editor.formatter.register('h5p', {
34
            inline: 'div',
35
            classes: className,
36
        });
37
    });
38
 
39
    editor.on('SetContent', () => {
40
        // Listen to the SetContent event on the editor and update any h5p-placeholder to not be editable.
41
        // Doing this means that the inner content of the placeholder cannot be changed without using the dialogue.
42
        // The SetContent event is called whenever content is changed by actions such as initial load, paste, undo, etc.
43
        editor.getBody().querySelectorAll(`${classSelector}:not([contenteditable])`).forEach((node) => {
44
            node.contentEditable = false;
45
        });
46
    });
47
};