« MediaWiki:Common.js » : différence entre les versions
Aucun résumé des modifications |
mAucun résumé des modifications |
||
(96 versions intermédiaires par le même utilisateur non affichées) | |||
Ligne 1 : | Ligne 1 : | ||
/ | var customizeToolbar = function () | ||
{ | |||
$('#wpTextbox1').wikiEditor('addToToolbar', { | |||
section: 'advanced', | |||
group: 'format', | |||
tools: { | |||
"strikethrough": { | |||
label: 'File', | |||
type: 'button', | |||
icon: '//upload.wikimedia.org/wikipedia/commons/thumb/b/b4/Gnome-accessories-text-editor.svg/48px-Gnome-accessories-text-editor.svg.png', | |||
action: { | |||
type: 'encapsulate', | |||
options: { | |||
pre: "<file>", | |||
post: "</file>" | |||
} | |||
} | |||
} | |||
} | |||
}); | |||
}; | |||
if ($.inArray(mw.config.get('wgAction'), ['edit', 'submit']) !== -1) | |||
{ | |||
mw.loader.using('ext.wikiEditor.toolbar', function () | |||
{ | |||
$(window).load(customizeToolbar); | |||
}); | |||
} | |||
/** | |||
* Keep code in MediaWiki:Common.js to a minimum as it is unconditionally | |||
* loaded for all users on every wiki page. If possible create a gadget that is | |||
* enabled by default instead of adding it here (since gadgets are fully | |||
* optimized ResourceLoader modules with possibility to add dependencies etc.) | |||
* | |||
* Since Common.js isn't a gadget, there is no place to declare its | |||
* dependencies, so we have to lazy load them with mw.loader.using on demand and | |||
* then execute the rest in the callback. In most cases these dependencies will | |||
* be loaded (or loading) already and the callback will not be delayed. In case a | |||
* dependency hasn't arrived yet it'll make sure those are loaded before this. | |||
*/ | |||
/* global mw, $, importStylesheet, importScript */ | |||
/* jshint strict:false, browser:true */ | |||
if ($('#contentSub').has('span').length > 0) | |||
{ | |||
$('#content').addClass('has-redir'); | |||
} | |||
/** | |||
* Collapsible tables | |||
* | * | ||
* | * Allows tables to be collapsed, showing only the header. See [[Wikipedia:NavFrame]]. | ||
* | * | ||
* | * @version 2.0.3 (2014-03-14) | ||
* | * @source https://www.mediawiki.org/wiki/MediaWiki:Gadget-collapsibleTables.js | ||
* @author [[User:R. Koot]] | |||
* @author [[User:Krinkle]] | |||
* @deprecated Since MediaWiki 1.20: Use class="mw-collapsible" instead which | |||
* is supported in MediaWiki core. | |||
*/ | */ | ||
var autoCollapse = 2; | |||
var | var collapseCaption = 'hide'; | ||
var | var expandCaption = 'show'; | ||
function collapseTable(tableIndex) | |||
{ | |||
var Button = document.getElementById('collapseButton' + tableIndex); | |||
var Table = document.getElementById('collapsibleTable' + tableIndex); | |||
if (!Table || !Button) | |||
{ | |||
return false; | |||
} | |||
var Rows = Table.rows; | |||
var i; | |||
if (Button.firstChild.data === collapseCaption) | |||
{ | |||
for (i = 1; i < Rows.length; i++) | |||
{ | |||
Table.classList.add('collapsed'); | |||
Rows[i].style.display = 'none'; | |||
} | |||
Button.firstChild.data = expandCaption; | |||
} else | |||
{ | |||
for (i = 1; i < Rows.length; i++) | |||
{ | |||
Table.classList.remove('collapsed'); | |||
Rows[i].style.display = Rows[0].style.display; | |||
} | |||
Button.firstChild.data = collapseCaption; | |||
} | |||
} | |||
function createClickHandler(tableIndex) | |||
{ | |||
return function (e) | |||
{ | |||
e.preventDefault(); | |||
collapseTable(tableIndex); | |||
}; | |||
} | |||
function createCollapseButtons() | |||
{ | |||
var tableIndex = 0; | |||
var NavigationBoxes = {}; | |||
var Tables = document.querySelectorAll('.collapsibleTable'); | |||
var i; | |||
for (i = 0; i < Tables.length; i++) | |||
{ | |||
/* only add button and increment count if there is a header row to work with */ | |||
var HeaderRow = Tables[i].getElementsByTagName('tr')[0]; | |||
if (!HeaderRow) | |||
{ | |||
continue; | |||
} | |||
var Header = HeaderRow.getElementsByTagName('th')[0]; | |||
if (!Header) | |||
{ | |||
continue; | |||
} | |||
NavigationBoxes[tableIndex] = Tables[i]; | |||
Tables[i].setAttribute('id', 'collapsibleTable' + tableIndex); | |||
var Button = document.createElement('span'); | |||
var ButtonLink = document.createElement('a'); | |||
var ButtonText = document.createTextNode(collapseCaption); | |||
// Styles are declared in [[MediaWiki:Common.css]] | |||
Button.className = 'collapseButton'; | |||
ButtonLink.style.color = Header.style.color; | |||
ButtonLink.setAttribute('id', 'collapseButton' + tableIndex); | |||
ButtonLink.setAttribute('href', '#'); | |||
$(ButtonLink).on('click', createClickHandler(tableIndex)); | |||
ButtonLink.appendChild(ButtonText); | |||
Button.appendChild(document.createTextNode('[')); | |||
Button.appendChild(ButtonLink); | |||
Button.appendChild(document.createTextNode(']')); | |||
Header.insertBefore(Button, Header.firstChild); | |||
tableIndex++; | |||
} | |||
for (i = 0; i < tableIndex; i++) | |||
{ | |||
if ($(NavigationBoxes[i]).hasClass('collapsed') || | |||
(tableIndex >= autoCollapse && $(NavigationBoxes[i]).hasClass('autocollapse')) | |||
) | |||
{ | |||
collapseTable(i); | |||
} | |||
else if ($(NavigationBoxes[i]).hasClass('innercollapse')) | |||
{ | |||
var element = NavigationBoxes[i]; | |||
while ((element = element.parentNode)) | |||
{ | |||
if ($(element).hasClass('outercollapse')) | |||
{ | |||
collapseTable(i); | |||
break; | |||
} | |||
} | |||
} | |||
} | |||
} | |||
function selectElementText(el, win) | |||
{ | |||
win = win || window; | |||
var doc = win.document, sel, range; | |||
if (win.getSelection && doc.createRange) | |||
{ | |||
sel = win.getSelection(); | |||
range = doc.createRange(); | |||
range.selectNodeContents(el); | |||
sel.removeAllRanges(); | |||
sel.addRange(range); | |||
return sel.toString(); | |||
} else if (doc.body.createTextRange) | |||
{ | |||
range = doc.body.createTextRange(); | |||
range.moveToElementText(el); | |||
range.select(); | |||
console.log('range', range); | |||
return range; | |||
} | |||
} | |||
function copyElementText(el) | |||
{ | |||
var text = selectElementText(el); | |||
var text2 = text.replace(/\n\n/, '\n'); | |||
// Copy the text inside the text field | |||
navigator.clipboard.writeText(text2); | |||
return text2; | |||
} | } | ||
$('.js-lxterm').on('dblclick', function (c) | |||
function | { | ||
$(this).find('.lxterm-code').toggle(); | |||
$(this).find('.lxterm-txt').toggle(); | |||
if ($(this).find('.lxterm-txt').css('display') != 'none') | |||
{ | |||
var txt = copyElementText($(this).find('.lxterm-txt')[0]); | |||
console.log(txt); | |||
} | |||
}); | |||
mw.loader.using( ['mediawiki.util'], function () { | |||
/* Begin of mw.loader.using callback */ | |||
$(createCollapseButtons); | |||
$('#mw-sidebar-checkbox').attr('checked', 'checked'); | |||
$('.mw-sidebar-action').hide(); | |||
setTimeout(function() {$('.vector-menu-content').each(function() { $(this).show(); } ) } , 100) | |||
$("a[href*='action=']").each( function() {$(this).attr('rel', 'nofollow');} ) | |||
$("a[href*='info=']").each( function() {$(this).attr('rel', 'nofollow');} ) | |||
$("a[href*='oldid=']").each( function() {$(this).attr('rel', 'nofollow');} ) | |||
$('.author').each(function() { | |||
$('#firstHeading').css('padding-bottom', '30px'); | |||
}) | |||
$('.vector-menu-heading').each(function() { $(this).on('click', function() { $(this).siblings('.vector-menu-content').toggle()} ); } ); | |||
if($('#p-cactions .vector-menu-content-list').length > 0 && $('#ca-history').length > 0) $('#p-cactions .vector-menu-content-list')[0].appendChild($('#ca-history')[0]); | |||
console.log('run'); | |||
/* End of mw.loader.using callback */ | |||
}); | |||
if ( mw.config.get( 'wgNamespaceNumber' ) == 3002 ) { | |||
importScript( 'MediaWiki:Contact.js'); | |||
mw.loader.load('/index.php?title=MediaWiki:Contact.css&action=raw&ctype=text/css', 'text/css'); | |||
} | } | ||
/* DO NOT ADD CODE BELOW THIS LINE */ |
Dernière version du 9 février 2023 à 18:36
var customizeToolbar = function ()
{
$('#wpTextbox1').wikiEditor('addToToolbar', {
section: 'advanced',
group: 'format',
tools: {
"strikethrough": {
label: 'File',
type: 'button',
icon: '//upload.wikimedia.org/wikipedia/commons/thumb/b/b4/Gnome-accessories-text-editor.svg/48px-Gnome-accessories-text-editor.svg.png',
action: {
type: 'encapsulate',
options: {
pre: "<file>",
post: "</file>"
}
}
}
}
});
};
if ($.inArray(mw.config.get('wgAction'), ['edit', 'submit']) !== -1)
{
mw.loader.using('ext.wikiEditor.toolbar', function ()
{
$(window).load(customizeToolbar);
});
}
/**
* Keep code in MediaWiki:Common.js to a minimum as it is unconditionally
* loaded for all users on every wiki page. If possible create a gadget that is
* enabled by default instead of adding it here (since gadgets are fully
* optimized ResourceLoader modules with possibility to add dependencies etc.)
*
* Since Common.js isn't a gadget, there is no place to declare its
* dependencies, so we have to lazy load them with mw.loader.using on demand and
* then execute the rest in the callback. In most cases these dependencies will
* be loaded (or loading) already and the callback will not be delayed. In case a
* dependency hasn't arrived yet it'll make sure those are loaded before this.
*/
/* global mw, $, importStylesheet, importScript */
/* jshint strict:false, browser:true */
if ($('#contentSub').has('span').length > 0)
{
$('#content').addClass('has-redir');
}
/**
* Collapsible tables
*
* Allows tables to be collapsed, showing only the header. See [[Wikipedia:NavFrame]].
*
* @version 2.0.3 (2014-03-14)
* @source https://www.mediawiki.org/wiki/MediaWiki:Gadget-collapsibleTables.js
* @author [[User:R. Koot]]
* @author [[User:Krinkle]]
* @deprecated Since MediaWiki 1.20: Use class="mw-collapsible" instead which
* is supported in MediaWiki core.
*/
var autoCollapse = 2;
var collapseCaption = 'hide';
var expandCaption = 'show';
function collapseTable(tableIndex)
{
var Button = document.getElementById('collapseButton' + tableIndex);
var Table = document.getElementById('collapsibleTable' + tableIndex);
if (!Table || !Button)
{
return false;
}
var Rows = Table.rows;
var i;
if (Button.firstChild.data === collapseCaption)
{
for (i = 1; i < Rows.length; i++)
{
Table.classList.add('collapsed');
Rows[i].style.display = 'none';
}
Button.firstChild.data = expandCaption;
} else
{
for (i = 1; i < Rows.length; i++)
{
Table.classList.remove('collapsed');
Rows[i].style.display = Rows[0].style.display;
}
Button.firstChild.data = collapseCaption;
}
}
function createClickHandler(tableIndex)
{
return function (e)
{
e.preventDefault();
collapseTable(tableIndex);
};
}
function createCollapseButtons()
{
var tableIndex = 0;
var NavigationBoxes = {};
var Tables = document.querySelectorAll('.collapsibleTable');
var i;
for (i = 0; i < Tables.length; i++)
{
/* only add button and increment count if there is a header row to work with */
var HeaderRow = Tables[i].getElementsByTagName('tr')[0];
if (!HeaderRow)
{
continue;
}
var Header = HeaderRow.getElementsByTagName('th')[0];
if (!Header)
{
continue;
}
NavigationBoxes[tableIndex] = Tables[i];
Tables[i].setAttribute('id', 'collapsibleTable' + tableIndex);
var Button = document.createElement('span');
var ButtonLink = document.createElement('a');
var ButtonText = document.createTextNode(collapseCaption);
// Styles are declared in [[MediaWiki:Common.css]]
Button.className = 'collapseButton';
ButtonLink.style.color = Header.style.color;
ButtonLink.setAttribute('id', 'collapseButton' + tableIndex);
ButtonLink.setAttribute('href', '#');
$(ButtonLink).on('click', createClickHandler(tableIndex));
ButtonLink.appendChild(ButtonText);
Button.appendChild(document.createTextNode('['));
Button.appendChild(ButtonLink);
Button.appendChild(document.createTextNode(']'));
Header.insertBefore(Button, Header.firstChild);
tableIndex++;
}
for (i = 0; i < tableIndex; i++)
{
if ($(NavigationBoxes[i]).hasClass('collapsed') ||
(tableIndex >= autoCollapse && $(NavigationBoxes[i]).hasClass('autocollapse'))
)
{
collapseTable(i);
}
else if ($(NavigationBoxes[i]).hasClass('innercollapse'))
{
var element = NavigationBoxes[i];
while ((element = element.parentNode))
{
if ($(element).hasClass('outercollapse'))
{
collapseTable(i);
break;
}
}
}
}
}
function selectElementText(el, win)
{
win = win || window;
var doc = win.document, sel, range;
if (win.getSelection && doc.createRange)
{
sel = win.getSelection();
range = doc.createRange();
range.selectNodeContents(el);
sel.removeAllRanges();
sel.addRange(range);
return sel.toString();
} else if (doc.body.createTextRange)
{
range = doc.body.createTextRange();
range.moveToElementText(el);
range.select();
console.log('range', range);
return range;
}
}
function copyElementText(el)
{
var text = selectElementText(el);
var text2 = text.replace(/\n\n/, '\n');
// Copy the text inside the text field
navigator.clipboard.writeText(text2);
return text2;
}
$('.js-lxterm').on('dblclick', function (c)
{
$(this).find('.lxterm-code').toggle();
$(this).find('.lxterm-txt').toggle();
if ($(this).find('.lxterm-txt').css('display') != 'none')
{
var txt = copyElementText($(this).find('.lxterm-txt')[0]);
console.log(txt);
}
});
mw.loader.using( ['mediawiki.util'], function () {
/* Begin of mw.loader.using callback */
$(createCollapseButtons);
$('#mw-sidebar-checkbox').attr('checked', 'checked');
$('.mw-sidebar-action').hide();
setTimeout(function() {$('.vector-menu-content').each(function() { $(this).show(); } ) } , 100)
$("a[href*='action=']").each( function() {$(this).attr('rel', 'nofollow');} )
$("a[href*='info=']").each( function() {$(this).attr('rel', 'nofollow');} )
$("a[href*='oldid=']").each( function() {$(this).attr('rel', 'nofollow');} )
$('.author').each(function() {
$('#firstHeading').css('padding-bottom', '30px');
})
$('.vector-menu-heading').each(function() { $(this).on('click', function() { $(this).siblings('.vector-menu-content').toggle()} ); } );
if($('#p-cactions .vector-menu-content-list').length > 0 && $('#ca-history').length > 0) $('#p-cactions .vector-menu-content-list')[0].appendChild($('#ca-history')[0]);
console.log('run');
/* End of mw.loader.using callback */
});
if ( mw.config.get( 'wgNamespaceNumber' ) == 3002 ) {
importScript( 'MediaWiki:Contact.js');
mw.loader.load('/index.php?title=MediaWiki:Contact.css&action=raw&ctype=text/css', 'text/css');
}
/* DO NOT ADD CODE BELOW THIS LINE */