MediaWiki:Common.js: Unterschied zwischen den Versionen

Aus RI Wiki
Zur Navigation springenZur Suche springen
Keine Bearbeitungszusammenfassung
Markierung: Zurückgesetzt
Keine Bearbeitungszusammenfassung
Markierung: Manuelle Zurücksetzung
 
(8 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
mw.hook('ve.loadModules').add(function (addPlugin) {
mw.hook('ve.loadModules').add(function (addPlugin) {
     addPlugin(function () {
     addPlugin(function () {
         // Define and register the command
         // 1. Define a custom annotation for highlighting
         ve.ui.HighlightCommand = function VeUiHighlightCommand() {
         ve.dm.HighlightAnnotation = function VeDmHighlightAnnotation() {
             ve.ui.HighlightCommand.super.call(this, 'insertHighlight');
             ve.dm.HighlightAnnotation.super.apply(this, arguments);
         };
         };
         OO.inheritClass(ve.ui.HighlightCommand, ve.ui.Command);
         OO.inheritClass(ve.dm.HighlightAnnotation, ve.dm.TextStyleAnnotation);
         ve.ui.HighlightCommand.prototype.execute = function (surface) {
         ve.dm.HighlightAnnotation.static.name = 'textStyle/highlight';
            var fragment = surface.getModel().getFragment();
        ve.dm.HighlightAnnotation.static.matchTagNames = ['mark'];
            var selectedText = fragment.getText();
        ve.dm.annotationFactory.register(ve.dm.HighlightAnnotation);
            if (!selectedText) {
 
                surface.getView().flash();
        // 2. Define the contentEditable view for the annotation
                return false;
        ve.ce.HighlightAnnotation = function VeCeHighlightAnnotation() {
            }
             ve.ce.HighlightAnnotation.super.apply(this, arguments);
            var templateData = [
                {
                    type: 'mwTransclusionInline',
                    attributes: {
                        mw: {
                            parts: [{
                                template: {
                                    target: {
                                        href: 'Template:Highlight',
                                        wt: 'Highlight'
                                    },
                                    params: {
                                        1: { wt: selectedText },
                                        2: { wt: 'yellow' }
                                    }
                                }
                            }]
                        }
                    }
                },
                { type: '/mwTransclusionInline' }
             ];
            fragment.insertContent(templateData);
            return true;
         };
         };
         ve.ui.commandRegistry.register(new ve.ui.HighlightCommand());
         OO.inheritClass(ve.ce.HighlightAnnotation, ve.ce.TextStyleAnnotation);
        ve.ce.HighlightAnnotation.static.name = 'textStyle/highlight';
        ve.ce.HighlightAnnotation.static.tagName = 'mark';
        ve.ce.annotationFactory.register(ve.ce.HighlightAnnotation);


         // Define and register the tool
         // 3. Register the command to toggle the highlight
        ve.ui.commandRegistry.register(
            new ve.ui.Command(
                'insertHighlight',
                'annotation',
                'toggle',
                {
                    args: ['textStyle/highlight'],
                    supportedSelections: ['linear', 'table']
                }
            )
        );
 
        // 4. Register the tool (now inherits from AnnotationTool)
         ve.ui.HighlightTool = function VeUiHighlightTool(toolGroup, config) {
         ve.ui.HighlightTool = function VeUiHighlightTool(toolGroup, config) {
             ve.ui.HighlightTool.super.call(this, toolGroup, config);
             ve.ui.HighlightTool.super.call(this, toolGroup, config);
         };
         };
         OO.inheritClass(ve.ui.HighlightTool, ve.ui.Tool);
         OO.inheritClass(ve.ui.HighlightTool, ve.ui.AnnotationTool);
         ve.ui.HighlightTool.static.name = 'highlight';
         ve.ui.HighlightTool.static.name = 'highlight';
         ve.ui.HighlightTool.static.group = 'style'; // Correct group for formatting
         ve.ui.HighlightTool.static.group = 'style'; // Can now go in style group!
         ve.ui.HighlightTool.static.icon = 'marker'; // Use a standard icon
         ve.ui.HighlightTool.static.icon = 'highlight';
         ve.ui.HighlightTool.static.title = 'Highlight text';
         ve.ui.HighlightTool.static.title = 'Highlight text';
        ve.ui.HighlightTool.static.annotation = { name: 'textStyle/highlight' };
         ve.ui.HighlightTool.static.commandName = 'insertHighlight';
         ve.ui.HighlightTool.static.commandName = 'insertHighlight';
         ve.ui.toolFactory.register(ve.ui.HighlightTool);
         ve.ui.toolFactory.register(ve.ui.HighlightTool);


         console.log('Highlight tool registered in the "style" group.');
         console.log('Highlight tool registered with custom annotation.');
 
        // Debug: Log after a delay to check registration
        setTimeout(function() {
            if (ve.init.target && ve.init.target.toolbar) {
                var styleGroup = ve.init.target.toolbar.groups.find(g => g.name === 'style');
                if (styleGroup) {
                    console.log('Tools in style group:', styleGroup.items.map(item => item.constructor.static.name));
                }
            }
        }, 5000);
     });
     });
});
});

Aktuelle Version vom 5. September 2025, 13:03 Uhr

mw.hook('ve.loadModules').add(function (addPlugin) {
    addPlugin(function () {
        // 1. Define a custom annotation for highlighting
        ve.dm.HighlightAnnotation = function VeDmHighlightAnnotation() {
            ve.dm.HighlightAnnotation.super.apply(this, arguments);
        };
        OO.inheritClass(ve.dm.HighlightAnnotation, ve.dm.TextStyleAnnotation);
        ve.dm.HighlightAnnotation.static.name = 'textStyle/highlight';
        ve.dm.HighlightAnnotation.static.matchTagNames = ['mark'];
        ve.dm.annotationFactory.register(ve.dm.HighlightAnnotation);

        // 2. Define the contentEditable view for the annotation
        ve.ce.HighlightAnnotation = function VeCeHighlightAnnotation() {
            ve.ce.HighlightAnnotation.super.apply(this, arguments);
        };
        OO.inheritClass(ve.ce.HighlightAnnotation, ve.ce.TextStyleAnnotation);
        ve.ce.HighlightAnnotation.static.name = 'textStyle/highlight';
        ve.ce.HighlightAnnotation.static.tagName = 'mark';
        ve.ce.annotationFactory.register(ve.ce.HighlightAnnotation);

        // 3. Register the command to toggle the highlight
        ve.ui.commandRegistry.register(
            new ve.ui.Command(
                'insertHighlight', 
                'annotation', 
                'toggle',
                { 
                    args: ['textStyle/highlight'], 
                    supportedSelections: ['linear', 'table'] 
                }
            )
        );

        // 4. Register the tool (now inherits from AnnotationTool)
        ve.ui.HighlightTool = function VeUiHighlightTool(toolGroup, config) {
            ve.ui.HighlightTool.super.call(this, toolGroup, config);
        };
        OO.inheritClass(ve.ui.HighlightTool, ve.ui.AnnotationTool);
        ve.ui.HighlightTool.static.name = 'highlight';
        ve.ui.HighlightTool.static.group = 'style'; // Can now go in style group!
        ve.ui.HighlightTool.static.icon = 'highlight';
        ve.ui.HighlightTool.static.title = 'Highlight text';
        ve.ui.HighlightTool.static.annotation = { name: 'textStyle/highlight' };
        ve.ui.HighlightTool.static.commandName = 'insertHighlight';
        ve.ui.toolFactory.register(ve.ui.HighlightTool);

        console.log('Highlight tool registered with custom annotation.');
    });
});