MediaWiki:Common.js

Aus RI Wiki
Zur Navigation springenZur Suche springen

Hinweis: Leere nach dem Veröffentlichen den Browser-Cache, um die Änderungen sehen zu können.

  • Firefox/Safari: Umschalttaste drücken und gleichzeitig Aktualisieren anklicken oder entweder Strg+F5 oder Strg+R (⌘+R auf dem Mac) drücken
  • Google Chrome: Umschalttaste+Strg+R (⌘+Umschalttaste+R auf dem Mac) drücken
  • Edge: Strg+F5 drücken oder Strg drücken und gleichzeitig Aktualisieren anklicken
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';  // built-in OOUI icon
        HighlightTool.static.title = 'Text hervorheben';  // German label for toolbar
        HighlightTool.static.commandName = commandName;
        HighlightTool.static.group = 'highlightGroup';  // top-level toolbar group

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

        // --- Force-add top-level toolbar group ---
        var toolbar = target.getToolbar();
        if (toolbar) {
            console.log('Adding Highlight button to top-level toolbar...');
            if (!toolbar.getGroup('highlightGroup')) {
                toolbar.addToolbarGroup('highlightGroup', { type: 'bar' });
            }
            toolbar.addTool('highlightGroup', 'highlight');
            toolbar.emit('updateState');  // refresh toolbar
        }
    });
});