MediaWiki:Common.js
Aus RI Wiki
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 () {
console.log('ve.activationComplete fired, registering tool...');
// --- Register your tool (same as before) ---
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] }
)
);
}
function HighlightTool(toolGroup, config) {
ve.ui.Tool.call(this, toolGroup, config);
}
OO.inheritClass(HighlightTool, ve.ui.Tool);
HighlightTool.static.name = 'highlight';
HighlightTool.static.group = 'textStyle';
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');
}
// --- Now check the actual toolbar structure ---
setTimeout(function() {
if (ve.init.target && ve.init.target.toolbar) {
console.log('=== TOOLBAR ANALYSIS ===');
console.log('Toolbar groups:', ve.init.target.toolbar.groups);
// Check each group
ve.init.target.toolbar.groups.forEach(function(group, index) {
console.log(`Group ${index}:`, {
name: group.name || 'unnamed',
type: group.constructor.name,
include: group.include || 'not specified',
exclude: group.exclude || 'not specified'
});
// Check if it's a tool group with tools
if (group.items) {
console.log(` Items in group ${index}:`, group.items.map(item => item.constructor.static.name || 'unnamed'));
}
});
// Check what's in the textStyle group specifically
var textStyleGroup = ve.init.target.toolbar.groups.find(g =>
g.include && g.include.includes && g.include.includes('bold')
);
if (textStyleGroup) {
console.log('Found textStyle group:', textStyleGroup);
console.log('textStyle group items:', textStyleGroup.items ? textStyleGroup.items.map(i => i.constructor.static.name) : 'no items');
}
}
}, 2000);
});
});