%PDF- %PDF-
Direktori : /home/vacivi36/ava/lib/editor/tiny/plugins/media/amd/src/ |
Current File : /home/vacivi36/ava/lib/editor/tiny/plugins/media/amd/src/configuration.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 Media configuration. * * @module tiny_media/configuration * @copyright 2022 Huong Nguyen <huongnv13@gmail.com> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ import { imageButtonName, videoButtonName, mediaManagerButtonName, } from './common'; import uploadFile from 'editor_tiny/uploader'; import { addContextmenuItem, } from 'editor_tiny/utils'; const configureMenu = (menu) => { // Replace the standard Media plugin with the Moodle embed. if (menu.insert.items.match(/\bmedia\b/)) { menu.insert.items = menu.insert.items.replace(/\bmedia\b/, videoButtonName); } else { menu.insert.items = `${videoButtonName} ${menu.insert.items}`; } // Replace the standard image plugin with the Moodle image. if (menu.insert.items.match(/\bimage\b/)) { menu.insert.items = menu.insert.items.replace(/\bimage\b/, imageButtonName); } else { menu.insert.items = `${imageButtonName} ${menu.insert.items}`; } // Add the Media Manager to the end of the Tools menu. menu.tools.items += ` ${mediaManagerButtonName}`; return menu; }; const configureToolbar = (toolbar) => { // The toolbar contains an array of named sections. // The Moodle integration ensures that there is a section called 'content'. return toolbar.map((section) => { if (section.name === 'content') { // Insert the image, and embed, buttons at the start of it. section.items.unshift(imageButtonName, videoButtonName); } return section; }); }; export const configure = (instanceConfig) => { // Update the instance configuration to add the Media menu option to the menus and toolbars and upload_handler. return { contextmenu: addContextmenuItem(instanceConfig.contextmenu, imageButtonName, videoButtonName), menu: configureMenu(instanceConfig.menu), toolbar: configureToolbar(instanceConfig.toolbar), // eslint-disable-next-line camelcase images_upload_handler: (blobInfo, progress) => uploadFile( window.tinymce.activeEditor, 'image', blobInfo.blob(), blobInfo.filename(), progress ), // eslint-disable-next-line camelcase images_reuse_filename: true, }; };