« MediaWiki:Vaulttec.js » : différence entre les versions
Page créée avec « →── Bandeau Discord ───────────────────────────────────────── : ( function () { 'use strict'; var STORAGE_KEY = 'vtDiscordBannerDismissed'; var DISCORD_URL = 'https://discord.gg/DxFnyyR'; var GUILD_ID = '181800470082355200'; // Ne pas afficher si déjà fermé if ( localStorage.getItem( STORAGE_KEY ) === '1' ) { return; } // Icône Discord SVG var icon... » Balise : Recréé |
Aucun résumé des modifications |
||
| (14 versions intermédiaires par le même utilisateur non affichées) | |||
| Ligne 1 : | Ligne 1 : | ||
/* | /** | ||
* Bandeau Discord — à ajouter dans MediaWiki:Vaulttec.js | |||
*/ | |||
( function () { | ( function () { | ||
'use strict'; | |||
var DISCORD_URL = 'https://discord.gg/DxFnyyR'; | |||
var STORAGE_KEY = 'vt-discord-banner-dismissed'; | |||
var GUILD_ID = '181800470082355200'; | |||
try { | |||
if ( localStorage.getItem( STORAGE_KEY ) === '1' ) return; | |||
} catch ( e ) {} | |||
var banner = document.createElement( 'div' ); | |||
banner.className = 'vt-discord-banner'; | |||
banner.setAttribute( 'role', 'complementary' ); | |||
banner.setAttribute( 'aria-label', 'Invitation Discord' ); | |||
banner.innerHTML = | |||
'<span class="vt-banner-text">' + | |||
'Rejoignez la communauté des <strong>Archives de Vault-Tec</strong> sur Discord pour discuter, contribuer et partager.' + | |||
'</span>' + | |||
'<span class="vt-banner-info">' + | |||
'<span class="vt-banner-icon" aria-hidden="true">' + | |||
'<svg viewBox="0 0 24 24" fill="currentColor" xmlns="http://www.w3.org/2000/svg">' + | |||
'<path d="M20.317 4.37a19.79 19.79 0 0 0-4.885-1.515.074.074 0 0 0-.079.037c-.21.375-.444.864-.608 1.25a18.27 18.27 0 0 0-5.487 0 12.64 12.64 0 0 0-.617-1.25.077.077 0 0 0-.079-.037A19.736 19.736 0 0 0 3.677 4.37a.07.07 0 0 0-.032.027C.533 9.046-.32 13.58.099 18.057a.082.082 0 0 0 .031.057 19.9 19.9 0 0 0 5.993 3.03.078.078 0 0 0 .084-.028c.462-.63.874-1.295 1.226-1.994a.076.076 0 0 0-.041-.106 13.107 13.107 0 0 1-1.872-.892.077.077 0 0 1-.008-.128 10.2 10.2 0 0 0 .372-.292.074.074 0 0 1 .077-.01c3.928 1.793 8.18 1.793 12.062 0a.074.074 0 0 1 .078.01c.12.098.246.198.373.292a.077.077 0 0 1-.006.127 12.299 12.299 0 0 1-1.873.892.077.077 0 0 0-.041.107c.36.698.772 1.362 1.225 1.993a.076.076 0 0 0 .084.028 19.839 19.839 0 0 0 6.002-3.03.077.077 0 0 0 .032-.054c.5-5.177-.838-9.674-3.549-13.66a.061.061 0 0 0-.031-.03zM8.02 15.33c-1.183 0-2.157-1.085-2.157-2.419 0-1.333.956-2.419 2.157-2.419 1.21 0 2.176 1.096 2.157 2.42 0 1.333-.956 2.418-2.157 2.418zm7.975 0c-1.183 0-2.157-1.085-2.157-2.419 0-1.333.955-2.419 2.157-2.419 1.21 0 2.176 1.096 2.157 2.42 0 1.333-.946 2.418-2.157 2.418z"/>' + | |||
'</svg>' + | |||
'</span>' + | |||
'<span class="vt-banner-members" style="display:none" aria-live="polite">' + | |||
'<span id="vt-discord-count"></span> en ligne' + | |||
'</span>' + | |||
'</span>' + | |||
'<a class="vt-banner-btn" href="' + DISCORD_URL + '" target="_blank" rel="noopener noreferrer">' + | |||
'↗ Rejoindre' + | |||
'</a>' + | |||
'<button class="vt-banner-close" aria-label="Fermer">×</button>'; | |||
document.body.appendChild( banner ); | |||
requestAnimationFrame( function () { | |||
banner.style.opacity = '0'; | |||
banner.style.transform = 'translateY(100%)'; | |||
requestAnimationFrame( function () { | |||
banner.style.opacity = ''; | |||
banner.style.transform = ''; | |||
} ); | |||
} ); | |||
banner.querySelector( '.vt-banner-close' ).addEventListener( 'click', function () { | |||
banner.classList.add( 'vt-banner-hidden' ); | |||
try { localStorage.setItem( STORAGE_KEY, '1' ); } catch ( e ) {} | |||
setTimeout( function () { banner.remove(); }, 350 ); | |||
} ); | |||
fetch( 'https://discord.com/api/guilds/' + GUILD_ID + '/widget.json' ) | |||
.then( function ( r ) { return r.ok ? r.json() : null; } ) | |||
.then( function ( data ) { | |||
if ( !data || !data.presence_count ) { return; } | |||
var countEl = document.getElementById( 'vt-discord-count' ); | |||
var membersEl = banner.querySelector( '.vt-banner-members' ); | |||
if ( countEl && membersEl ) { | |||
countEl.textContent = data.presence_count; | |||
membersEl.style.display = ''; | |||
} | |||
} ) | |||
.catch( function () {} ); | |||
}() ); | }() ); | ||
| Ligne 63 : | Ligne 71 : | ||
/* LCP — fetchpriority=high sur la première image de l'article */ | /* LCP — fetchpriority=high sur la première image de l'article */ | ||
( function () { | ( function () { | ||
var img = document.querySelector( '#mw-content-text .mw-file-element' ); | |||
if ( img && !img.complete ) { | |||
img.setAttribute( 'fetchpriority', 'high' ); | |||
} | |||
} )(); | } )(); | ||
/* ============================================================ | |||
* Interrupteur thème clair / sombre — « Parchemin Vault-Tec » | |||
* À AJOUTER dans MediaWiki:Vaulttec.js (ne remplace rien). | |||
* | |||
* Sombre = défaut. Le bouton ajoute/retire la classe html.vt-light, | |||
* mémorisée dans le navigateur (localStorage). Aucune dépendance à | |||
* l'extension DarkMode (qu'on peut désactiver). | |||
* ============================================================ */ | |||
( function () { | |||
var KEY = 'vt-theme'; | |||
var root = document.documentElement; | |||
// Applique l'état mémorisé le plus tôt possible (limite le flash). | |||
try { | |||
if ( localStorage.getItem( KEY ) === 'light' ) { | |||
root.classList.add( 'vt-light' ); | |||
} | |||
} catch ( e ) {} | |||
mw.loader.using( [ 'mediawiki.util' ] ).then( function () { | |||
var label = function () { | |||
return root.classList.contains( 'vt-light' ) ? 'Mode sombre' : 'Mode clair'; | |||
}; | |||
// Ajoute le lien dans le portlet Navigation de la barre latérale. | |||
// Si ta barre utilise un autre id, remplace 'p-navigation'. | |||
var li = mw.util.addPortletLink( | |||
'p-navigation', '#', label(), 'vt-theme-toggle', | |||
'Basculer entre le mode clair et le mode sombre' | |||
); | |||
if ( !li ) { return; } | |||
var a = li.querySelector( 'a' ) || li; | |||
a.addEventListener( 'click', function ( e ) { | |||
e.preventDefault(); | |||
var light = root.classList.toggle( 'vt-light' ); | |||
try { localStorage.setItem( KEY, light ? 'light' : 'dark' ); } catch ( e ) {} | |||
a.textContent = label(); | |||
} ); | |||
} ); | |||
}() ); | |||
Dernière version du 28 mai 2026 à 22:47
/**
* Bandeau Discord — à ajouter dans MediaWiki:Vaulttec.js
*/
( function () {
'use strict';
var DISCORD_URL = 'https://discord.gg/DxFnyyR';
var STORAGE_KEY = 'vt-discord-banner-dismissed';
var GUILD_ID = '181800470082355200';
try {
if ( localStorage.getItem( STORAGE_KEY ) === '1' ) return;
} catch ( e ) {}
var banner = document.createElement( 'div' );
banner.className = 'vt-discord-banner';
banner.setAttribute( 'role', 'complementary' );
banner.setAttribute( 'aria-label', 'Invitation Discord' );
banner.innerHTML =
'<span class="vt-banner-text">' +
'Rejoignez la communauté des <strong>Archives de Vault-Tec</strong> sur Discord pour discuter, contribuer et partager.' +
'</span>' +
'<span class="vt-banner-info">' +
'<span class="vt-banner-icon" aria-hidden="true">' +
'<svg viewBox="0 0 24 24" fill="currentColor" xmlns="http://www.w3.org/2000/svg">' +
'<path d="M20.317 4.37a19.79 19.79 0 0 0-4.885-1.515.074.074 0 0 0-.079.037c-.21.375-.444.864-.608 1.25a18.27 18.27 0 0 0-5.487 0 12.64 12.64 0 0 0-.617-1.25.077.077 0 0 0-.079-.037A19.736 19.736 0 0 0 3.677 4.37a.07.07 0 0 0-.032.027C.533 9.046-.32 13.58.099 18.057a.082.082 0 0 0 .031.057 19.9 19.9 0 0 0 5.993 3.03.078.078 0 0 0 .084-.028c.462-.63.874-1.295 1.226-1.994a.076.076 0 0 0-.041-.106 13.107 13.107 0 0 1-1.872-.892.077.077 0 0 1-.008-.128 10.2 10.2 0 0 0 .372-.292.074.074 0 0 1 .077-.01c3.928 1.793 8.18 1.793 12.062 0a.074.074 0 0 1 .078.01c.12.098.246.198.373.292a.077.077 0 0 1-.006.127 12.299 12.299 0 0 1-1.873.892.077.077 0 0 0-.041.107c.36.698.772 1.362 1.225 1.993a.076.076 0 0 0 .084.028 19.839 19.839 0 0 0 6.002-3.03.077.077 0 0 0 .032-.054c.5-5.177-.838-9.674-3.549-13.66a.061.061 0 0 0-.031-.03zM8.02 15.33c-1.183 0-2.157-1.085-2.157-2.419 0-1.333.956-2.419 2.157-2.419 1.21 0 2.176 1.096 2.157 2.42 0 1.333-.956 2.418-2.157 2.418zm7.975 0c-1.183 0-2.157-1.085-2.157-2.419 0-1.333.955-2.419 2.157-2.419 1.21 0 2.176 1.096 2.157 2.42 0 1.333-.946 2.418-2.157 2.418z"/>' +
'</svg>' +
'</span>' +
'<span class="vt-banner-members" style="display:none" aria-live="polite">' +
'<span id="vt-discord-count"></span> en ligne' +
'</span>' +
'</span>' +
'<a class="vt-banner-btn" href="' + DISCORD_URL + '" target="_blank" rel="noopener noreferrer">' +
'↗ Rejoindre' +
'</a>' +
'<button class="vt-banner-close" aria-label="Fermer">×</button>';
document.body.appendChild( banner );
requestAnimationFrame( function () {
banner.style.opacity = '0';
banner.style.transform = 'translateY(100%)';
requestAnimationFrame( function () {
banner.style.opacity = '';
banner.style.transform = '';
} );
} );
banner.querySelector( '.vt-banner-close' ).addEventListener( 'click', function () {
banner.classList.add( 'vt-banner-hidden' );
try { localStorage.setItem( STORAGE_KEY, '1' ); } catch ( e ) {}
setTimeout( function () { banner.remove(); }, 350 );
} );
fetch( 'https://discord.com/api/guilds/' + GUILD_ID + '/widget.json' )
.then( function ( r ) { return r.ok ? r.json() : null; } )
.then( function ( data ) {
if ( !data || !data.presence_count ) { return; }
var countEl = document.getElementById( 'vt-discord-count' );
var membersEl = banner.querySelector( '.vt-banner-members' );
if ( countEl && membersEl ) {
countEl.textContent = data.presence_count;
membersEl.style.display = '';
}
} )
.catch( function () {} );
}() );
/* LCP — fetchpriority=high sur la première image de l'article */
( function () {
var img = document.querySelector( '#mw-content-text .mw-file-element' );
if ( img && !img.complete ) {
img.setAttribute( 'fetchpriority', 'high' );
}
} )();
/* ============================================================
* Interrupteur thème clair / sombre — « Parchemin Vault-Tec »
* À AJOUTER dans MediaWiki:Vaulttec.js (ne remplace rien).
*
* Sombre = défaut. Le bouton ajoute/retire la classe html.vt-light,
* mémorisée dans le navigateur (localStorage). Aucune dépendance à
* l'extension DarkMode (qu'on peut désactiver).
* ============================================================ */
( function () {
var KEY = 'vt-theme';
var root = document.documentElement;
// Applique l'état mémorisé le plus tôt possible (limite le flash).
try {
if ( localStorage.getItem( KEY ) === 'light' ) {
root.classList.add( 'vt-light' );
}
} catch ( e ) {}
mw.loader.using( [ 'mediawiki.util' ] ).then( function () {
var label = function () {
return root.classList.contains( 'vt-light' ) ? 'Mode sombre' : 'Mode clair';
};
// Ajoute le lien dans le portlet Navigation de la barre latérale.
// Si ta barre utilise un autre id, remplace 'p-navigation'.
var li = mw.util.addPortletLink(
'p-navigation', '#', label(), 'vt-theme-toggle',
'Basculer entre le mode clair et le mode sombre'
);
if ( !li ) { return; }
var a = li.querySelector( 'a' ) || li;
a.addEventListener( 'click', function ( e ) {
e.preventDefault();
var light = root.classList.toggle( 'vt-light' );
try { localStorage.setItem( KEY, light ? 'light' : 'dark' ); } catch ( e ) {}
a.textContent = label();
} );
} );
}() );