Proyectos de Subversion Moodle

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1441 ariadna 1
// This file is part of Moodle - https://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 <https://www.gnu.org/licenses/>.
15
 
16
/**
17
 * Tiny AI Placement for Moodle.
18
 *
19
 * @module      tiny_aiplacement/plugin
20
 * @copyright   2023 Matt Porritt <matt.porritt@moodle.com>
21
 * @license     http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
22
 */
23
 
24
import {getTinyMCE} from 'editor_tiny/loader';
25
import {getPluginMetadata} from 'editor_tiny/utils';
26
 
27
import {component, pluginName} from './common';
28
import {getSetup as getCommandSetup} from './commands';
29
import * as Configuration from './configuration';
30
import * as Options from 'tiny_aiplacement/options';
31
 
32
 
33
// Setup the tiny_aiplacement Plugin.
34
// eslint-disable-next-line no-async-promise-executor
35
export default new Promise(async(resolve) => {
36
    // Note: The PluginManager.add function does not support asynchronous configuration.
37
    // Perform any asynchronous configuration here, and then call the PluginManager.add function.
38
    const [
39
        tinyMCE,
40
        pluginMetadata,
41
        setupCommands,
42
    ] = await Promise.all([
43
        getTinyMCE(),
44
        getPluginMetadata(component, pluginName),
45
        getCommandSetup(),
46
    ]);
47
 
48
    // Reminder: Any asynchronous code must be run before this point.
49
    tinyMCE.PluginManager.add(pluginName, (editor) => {
50
        // Register options.
51
        Options.register(editor);
52
 
53
        // Setup any commands such as buttons, menu items, and so on.
54
        setupCommands(editor);
55
 
56
        // Return the pluginMetadata object. This is used by TinyMCE to display a help link for your plugin.
57
        return pluginMetadata;
58
    });
59
 
60
    resolve([pluginName, Configuration]);
61
});