« MediaWiki:Common.js » : différence entre les versions
Aucun résumé des modifications |
mAucun résumé des modifications |
||
(53 versions intermédiaires par le même utilisateur non affichées) | |||
Ligne 1 : | Ligne 1 : | ||
var customizeToolbar = function() { | var customizeToolbar = function () | ||
$('#wpTextbox1').wikiEditor('addToToolbar', { | { | ||
$('#wpTextbox1').wikiEditor('addToToolbar', { | |||
section: 'advanced', | section: 'advanced', | ||
group: 'format', | group: 'format', | ||
tools: { | 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 ) { | if ($.inArray(mw.config.get('wgAction'), ['edit', 'submit']) !== -1) | ||
{ | |||
mw.loader.using('ext.wikiEditor.toolbar', function () | |||
{ | |||
$(window).load(customizeToolbar); | |||
}); | |||
} | } | ||
Ligne 42 : | Ligne 45 : | ||
/* jshint strict:false, browser:true */ | /* jshint strict:false, browser:true */ | ||
if ($('#contentSub').has('span').length > 0) | |||
{ | |||
$('#content').addClass('has-redir'); | |||
if ($('#contentSub').has('span').length > 0) { | |||
} | } | ||
Ligne 66 : | Ligne 67 : | ||
var expandCaption = 'show'; | var expandCaption = 'show'; | ||
function collapseTable( tableIndex ) { | function collapseTable(tableIndex) | ||
var Button = document.getElementById( 'collapseButton' + tableIndex ); | { | ||
var Table = document.getElementById( 'collapsibleTable' + tableIndex ); | var Button = document.getElementById('collapseButton' + tableIndex); | ||
var Table = document.getElementById('collapsibleTable' + tableIndex); | |||
if ( !Table || !Button ) { | if (!Table || !Button) | ||
{ | |||
return false; | return false; | ||
} | } | ||
Ligne 77 : | Ligne 80 : | ||
var i; | var i; | ||
if ( Button.firstChild.data === collapseCaption ) { | if (Button.firstChild.data === collapseCaption) | ||
for ( i = 1; i < Rows.length; i++ ) { | { | ||
for (i = 1; i < Rows.length; i++) | |||
{ | |||
Table.classList.add('collapsed'); | |||
Rows[i].style.display = 'none'; | Rows[i].style.display = 'none'; | ||
} | } | ||
Button.firstChild.data = expandCaption; | Button.firstChild.data = expandCaption; | ||
} else { | } else | ||
for ( i = 1; i < Rows.length; i++ ) { | { | ||
for (i = 1; i < Rows.length; i++) | |||
{ | |||
Table.classList.remove('collapsed'); | |||
Rows[i].style.display = Rows[0].style.display; | Rows[i].style.display = Rows[0].style.display; | ||
} | } | ||
Ligne 90 : | Ligne 99 : | ||
} | } | ||
function createClickHandler( tableIndex ) { | function createClickHandler(tableIndex) | ||
return function ( e ) { | { | ||
return function (e) | |||
{ | |||
e.preventDefault(); | e.preventDefault(); | ||
collapseTable( tableIndex ); | collapseTable(tableIndex); | ||
}; | }; | ||
} | } | ||
function createCollapseButtons() { | function createCollapseButtons() | ||
{ | |||
var tableIndex = 0; | var tableIndex = 0; | ||
var NavigationBoxes = {}; | var NavigationBoxes = {}; | ||
var Tables = document.querySelectorAll( '.collapsibleTable' ); | var Tables = document.querySelectorAll('.collapsibleTable'); | ||
var i; | var i; | ||
for ( i = 0; i < Tables.length; i++ ) { | for (i = 0; i < Tables.length; i++) | ||
{ | |||
/* only add button and increment count if there is a header row to work with */ | /* only add button and increment count if there is a header row to work with */ | ||
var HeaderRow = Tables[i].getElementsByTagName( 'tr' )[0]; | var HeaderRow = Tables[i].getElementsByTagName('tr')[0]; | ||
if ( !HeaderRow ) { | if (!HeaderRow) | ||
{ | |||
continue; | continue; | ||
} | } | ||
var Header = HeaderRow.getElementsByTagName( 'th' )[0]; | var Header = HeaderRow.getElementsByTagName('th')[0]; | ||
if ( !Header ) { | if (!Header) | ||
{ | |||
continue; | continue; | ||
} | } | ||
NavigationBoxes[ tableIndex ] = Tables[i]; | NavigationBoxes[tableIndex] = Tables[i]; | ||
Tables[i].setAttribute( 'id', 'collapsibleTable' + tableIndex ); | Tables[i].setAttribute('id', 'collapsibleTable' + tableIndex); | ||
var Button | var Button = document.createElement('span'); | ||
var ButtonLink = document.createElement( 'a' ); | var ButtonLink = document.createElement('a'); | ||
var ButtonText = document.createTextNode( collapseCaption ); | var ButtonText = document.createTextNode(collapseCaption); | ||
// Styles are declared in [[MediaWiki:Common.css]] | // Styles are declared in [[MediaWiki:Common.css]] | ||
Button.className = 'collapseButton'; | Button.className = 'collapseButton'; | ||
ButtonLink.style.color = Header.style.color; | ButtonLink.style.color = Header.style.color; | ||
ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex ); | ButtonLink.setAttribute('id', 'collapseButton' + tableIndex); | ||
ButtonLink.setAttribute( 'href', '#' ); | ButtonLink.setAttribute('href', '#'); | ||
$( ButtonLink ).on( 'click', createClickHandler( tableIndex ) ); | $(ButtonLink).on('click', createClickHandler(tableIndex)); | ||
ButtonLink.appendChild( ButtonText ); | ButtonLink.appendChild(ButtonText); | ||
Button.appendChild( document.createTextNode( '[' ) ); | Button.appendChild(document.createTextNode('[')); | ||
Button.appendChild( ButtonLink ); | Button.appendChild(ButtonLink); | ||
Button.appendChild( document.createTextNode( ']' ) ); | Button.appendChild(document.createTextNode(']')); | ||
Header.insertBefore( Button, Header.firstChild ); | Header.insertBefore(Button, Header.firstChild); | ||
tableIndex++; | tableIndex++; | ||
} | } | ||
for ( i = 0; | for (i = 0; i < tableIndex; i++) | ||
if ( $( NavigationBoxes[i] ).hasClass( 'collapsed' ) || | { | ||
( tableIndex >= autoCollapse && $( NavigationBoxes[i] ).hasClass( 'autocollapse' ) ) | if ($(NavigationBoxes[i]).hasClass('collapsed') || | ||
) { | (tableIndex >= autoCollapse && $(NavigationBoxes[i]).hasClass('autocollapse')) | ||
collapseTable( i ); | ) | ||
{ | |||
collapseTable(i); | |||
} | } | ||
else if ( $( NavigationBoxes[i] ).hasClass ( 'innercollapse' ) ) { | else if ($(NavigationBoxes[i]).hasClass('innercollapse')) | ||
{ | |||
var element = NavigationBoxes[i]; | var element = NavigationBoxes[i]; | ||
while ((element = element.parentNode)) { | while ((element = element.parentNode)) | ||
if ( $( element ).hasClass( 'outercollapse' ) ) { | { | ||
collapseTable ( i ); | if ($(element).hasClass('outercollapse')) | ||
{ | |||
collapseTable(i); | |||
break; | break; | ||
} | } | ||
Ligne 154 : | Ligne 174 : | ||
} | } | ||
} | } | ||
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 */ | |||
console.log('run'); | $(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 */ | /* 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 */