MediaWiki:Common.js: Unterschied zwischen den Versionen

Aus RI Wiki
Zur Navigation springenZur Suche springen
Keine Bearbeitungszusammenfassung
Keine Bearbeitungszusammenfassung
Zeile 1: Zeile 1:
mw.loader.using('ext.visualEditor.desktopArticleTarget.init').then(function () {
mw.loader.using('ext.visualEditor.desktopArticleTarget.init').then(function () {
     mw.hook('ve.activationComplete').add(function () {
     mw.hook('ve.activationComplete').add(function (_, target) {
         // --- Define the command ---
 
        console.log('VisualEditor activated, adding Highlight tool...');
 
         // --- Command ---
         function doHighlight(surface) {
         function doHighlight(surface) {
             var fragment = surface.getModel().getFragment();
             var fragment = surface.getModel().getFragment();
Zeile 10: Zeile 13:
             fragment.insertContent('{{Highlight|' + selectedText + '|yellow}}');
             fragment.insertContent('{{Highlight|' + selectedText + '|yellow}}');
         }
         }
       
 
         var commandName = 'insertHighlight';
         var commandName = 'insertHighlight';
       
        // Register command
         if (!ve.ui.commandRegistry.lookup(commandName)) {
         if (!ve.ui.commandRegistry.lookup(commandName)) {
             ve.ui.commandRegistry.register(
             ve.ui.commandRegistry.register(
Zeile 24: Zeile 25:
             );
             );
         }
         }
       
 
         // --- Define the tool ---
         // --- Tool ---
         function HighlightTool(toolGroup, config) {
         function HighlightTool(toolGroup, config) {
             ve.ui.Tool.call(this, toolGroup, config);
             ve.ui.Tool.call(this, toolGroup, config);
         }
         }
       
         OO.inheritClass(HighlightTool, ve.ui.Tool);
         OO.inheritClass(HighlightTool, ve.ui.Tool);
         HighlightTool.static.name = 'highlight';
         HighlightTool.static.name = 'highlight';
        HighlightTool.static.group = 'format'; // Try 'format' group
         HighlightTool.static.icon = 'highlight';
         HighlightTool.static.icon = 'highlight';
         HighlightTool.static.title = 'Highlight text';
         HighlightTool.static.title = 'Highlight text';
         HighlightTool.static.commandName = commandName;
         HighlightTool.static.commandName = commandName;
       
 
         if (!ve.ui.toolFactory.lookup('highlight')) {
         if (!ve.ui.toolFactory.lookup('highlight')) {
             ve.ui.toolFactory.register(HighlightTool);
             ve.ui.toolFactory.register(HighlightTool);
            console.log('Highlight tool registered');
         }
         }


         // Debug: Check if tool is registered
         // --- Force add group to toolbar ---
        console.log('Highlight tool registered:', ve.ui.toolFactory.lookup('highlight'));
        var toolbar = target.getToolbar();
        if (toolbar) {
            console.log('Adding Highlight button to toolbar...');
            toolbar.setup([
                {
                    include: [ 'bold', 'italic', 'highlight' ] // put it next to Bold/Italic
                }
            ]);
            toolbar.emit('updateState'); // refresh toolbar state
        }
     });
     });
});
});

Version vom 3. September 2025, 20:35 Uhr

mw.loader.using('ext.visualEditor.desktopArticleTarget.init').then(function () {
    mw.hook('ve.activationComplete').add(function (_, target) {

        console.log('VisualEditor activated, adding Highlight tool...');

        // --- Command ---
        function doHighlight(surface) {
            var fragment = surface.getModel().getFragment();
            var selectedText = fragment.getText();
            if (!selectedText) {
                return;
            }
            fragment.insertContent('{{Highlight|' + selectedText + '|yellow}}');
        }

        var commandName = 'insertHighlight';
        if (!ve.ui.commandRegistry.lookup(commandName)) {
            ve.ui.commandRegistry.register(
                new ve.ui.Command(
                    commandName,
                    'content',
                    'exec',
                    { args: [doHighlight] }
                )
            );
        }

        // --- Tool ---
        function HighlightTool(toolGroup, config) {
            ve.ui.Tool.call(this, toolGroup, config);
        }
        OO.inheritClass(HighlightTool, ve.ui.Tool);

        HighlightTool.static.name = 'highlight';
        HighlightTool.static.icon = 'highlight';
        HighlightTool.static.title = 'Highlight text';
        HighlightTool.static.commandName = commandName;

        if (!ve.ui.toolFactory.lookup('highlight')) {
            ve.ui.toolFactory.register(HighlightTool);
            console.log('Highlight tool registered');
        }

        // --- Force add group to toolbar ---
        var toolbar = target.getToolbar();
        if (toolbar) {
            console.log('Adding Highlight button to toolbar...');
            toolbar.setup([
                {
                    include: [ 'bold', 'italic', 'highlight' ] // put it next to Bold/Italic
                }
            ]);
            toolbar.emit('updateState'); // refresh toolbar state
        }
    });
});