mirror of
https://gerrit.wikimedia.org/r/mediawiki/skins/MinervaNeue
synced 2024-11-16 02:41:54 +00:00
a6ab8d6da3
Change-Id: I52b2feacd6216e99e04f193ba963e897b3e1a771
82 lines
3.7 KiB
JavaScript
82 lines
3.7 KiB
JavaScript
const makeTemplate = function ( description ) {
|
|
const templateString = `<div class="cdx-dialog-backdrop">
|
|
<div tabindex="0"></div>
|
|
<div class="cdx-dialog cdx-dialog--horizontal-actions" role="dialog" aria-labelledby="cdx-dialog-label-0" aria-modal="true">
|
|
<header class="cdx-dialog__header cdx-dialog__header--default">
|
|
<div class="cdx-dialog__header__title-group">
|
|
<h2 id="cdx-dialog-label-0" class="cdx-dialog__header__title">
|
|
${ mw.message( 'skin-minerva-night-mode-launch-title' ).escaped() }
|
|
</h2>
|
|
</div>
|
|
<button class="cdx-button cdx-button--action-default cdx-button--weight-quiet cdx-button--size-medium cdx-button--icon-only cdx-dialog__header__close-button" type="button" aria-label="${ mw.message( 'skin-minerva-night-mode-launch-close-label' ).escaped() }">
|
|
<span class="cdx-icon cdx-icon--medium">
|
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="20" height="20" viewBox="0 0 20 20"><title>Close</title><g><path d="m4.34 2.93 12.73 12.73-1.41 1.41L2.93 4.35z"></path><path d="M17.07 4.34 4.34 17.07l-1.41-1.41L15.66 2.93z"></path></g></svg>
|
|
</span>
|
|
</button>
|
|
</header>
|
|
<div class="cdx-dialog-focus-trap" tabindex="-1"></div>
|
|
<div class="cdx-dialog__body">
|
|
<div class="skin-minerva-launch-image"></div>
|
|
<h3>
|
|
${ mw.message( 'skin-minerva-night-mode-launch-subtitle' ).escaped() }
|
|
</h3>
|
|
<p>
|
|
${ description }
|
|
</p>
|
|
</div>
|
|
<footer class="cdx-dialog__footer cdx-dialog__footer--default">
|
|
<div class="cdx-dialog__footer__actions">
|
|
<button class="cdx-button cdx-button--action-progressive cdx-button--weight-primary cdx-button--size-medium cdx-button--framed cdx-dialog__footer__primary-action">
|
|
${ mw.message( 'skin-minerva-night-mode-launch-settings-label' ).escaped() }
|
|
</button>
|
|
</div>
|
|
</footer>
|
|
</div>
|
|
<div tabindex="0"></div>
|
|
</div>`;
|
|
|
|
const templateElement = document.createElement( 'div' );
|
|
templateElement.id = 'minerva-dark-mode-launch-banner';
|
|
templateElement.innerHTML = templateString;
|
|
return templateElement;
|
|
};
|
|
|
|
function closeModal() {
|
|
document.getElementById( 'minerva-dark-mode-launch-banner' ).remove();
|
|
}
|
|
|
|
function primaryActionHandler() {
|
|
closeModal();
|
|
const url = mw.util.getUrl( 'Special:MobileOptions', { returnto: mw.config.get( 'wgPageName' ) } );
|
|
window.location.href = url;
|
|
}
|
|
|
|
function init() {
|
|
const mountElement = document.getElementById( 'mw-teleport-target' ),
|
|
matchMediaDark = window.matchMedia( '(prefers-color-scheme: dark)' ),
|
|
colorMode = mw.user.clientPrefs.get( 'skin-theme' ),
|
|
description = (
|
|
colorMode === 'night' ||
|
|
( colorMode === 'auto' && matchMediaDark )
|
|
) ?
|
|
mw.message( 'skin-minerva-night-mode-launch-description-night' ).escaped() :
|
|
mw.message( 'skin-minerva-night-mode-launch-description-day' ).escaped(),
|
|
templateElement = makeTemplate( description ),
|
|
dialogOverlay = templateElement.querySelector( '.cdx-dialog-backdrop' ),
|
|
dialogCloseButton = templateElement.querySelector( '.cdx-dialog__header__close-button' ),
|
|
primaryActionButton = templateElement.querySelector( '.cdx-dialog__footer__primary-action' );
|
|
|
|
dialogOverlay.addEventListener( 'click', ( e ) => {
|
|
if ( e.target === dialogOverlay ) {
|
|
closeModal();
|
|
}
|
|
} );
|
|
|
|
dialogCloseButton.addEventListener( 'click', closeModal );
|
|
primaryActionButton.addEventListener( 'click', primaryActionHandler );
|
|
|
|
mountElement.appendChild( templateElement );
|
|
}
|
|
|
|
module.exports = init;
|