mirror of
https://github.com/StarCitizenTools/mediawiki-skins-Citizen.git
synced 2024-12-02 09:57:45 +00:00
a741639085
Since clientPrefs and other related features are not avaliable until MW 1.42, many of them are backported as polyfill. Instead of using cookies, the polyfill are using localStorage only like Citizen in the past. There are many changes behind the scene, but the most important one being that `skin-citizen-*` theme classes are now soft-deprecated, and replaced by the standardized `skin-theme-clientpref-*` classes. There will be sufficient time before the hard deprecation. Related: #780
97 lines
2.4 KiB
JavaScript
97 lines
2.4 KiB
JavaScript
/*
|
|
* Citizen
|
|
*
|
|
* Inline script used in includes/Hooks/SkinHooks.php
|
|
*/
|
|
const LEGACY_PREFIX = 'skin-citizen-';
|
|
|
|
window.applyPref = () => {
|
|
const getStorage = ( key ) => {
|
|
return window.localStorage.getItem( key );
|
|
};
|
|
|
|
const apply = () => {
|
|
const cssProps = {
|
|
fontsize: 'font-size',
|
|
pagewidth: '--width-layout',
|
|
lineheight: '--line-height'
|
|
};
|
|
|
|
const injectStyles = ( css ) => {
|
|
const styleId = 'citizen-style';
|
|
let style = document.getElementById( styleId );
|
|
|
|
if ( style === null ) {
|
|
style = document.createElement( 'style' );
|
|
style.setAttribute( 'id', styleId );
|
|
document.head.appendChild( style );
|
|
}
|
|
style.textContent = `:root{${ css }}`;
|
|
};
|
|
|
|
try {
|
|
let cssDeclaration = '';
|
|
// Apply pref by adding CSS to root
|
|
for ( const [ key, property ] of Object.entries( cssProps ) ) {
|
|
const value = getStorage( LEGACY_PREFIX + key );
|
|
|
|
if ( value !== null ) {
|
|
cssDeclaration += `${ property }:${ value };`;
|
|
}
|
|
}
|
|
|
|
if ( cssDeclaration ) {
|
|
injectStyles( cssDeclaration );
|
|
}
|
|
} catch ( e ) {
|
|
}
|
|
};
|
|
|
|
apply();
|
|
};
|
|
|
|
/**
|
|
* Backported from MW 1.42
|
|
* Modified to use localStorage only
|
|
*/
|
|
window.clientPrefs = () => {
|
|
let className = document.documentElement.className;
|
|
const storage = localStorage.getItem( 'mwclientpreferences' );
|
|
if ( storage ) {
|
|
// TODO: Just use array for localStorage
|
|
storage.split( '%2C' ).forEach( function ( pref ) {
|
|
className = className.replace(
|
|
// eslint-disable-next-line security/detect-non-literal-regexp
|
|
new RegExp( '(^| )' + pref.replace( /-clientpref-\w+$|[^\w-]+/g, '' ) + '-clientpref-\\w+( |$)' ),
|
|
'$1' + pref + '$2'
|
|
);
|
|
|
|
// Legacy support
|
|
if ( pref.startsWith( 'skin-theme-clientpref-' ) ) {
|
|
const CLIENTPREFS_THEME_MAP = {
|
|
os: 'auto',
|
|
day: 'light',
|
|
night: 'dark'
|
|
};
|
|
const matchedKey = CLIENTPREFS_THEME_MAP[ pref.replace( 'skin-theme-clientpref-', '' ) ];
|
|
if ( matchedKey ) {
|
|
// eslint-disable-next-line max-len, es-x/no-object-values
|
|
const classesToRemove = Object.values( CLIENTPREFS_THEME_MAP ).map( ( theme ) => LEGACY_PREFIX + theme );
|
|
className = className.replace(
|
|
// eslint-disable-next-line security/detect-non-literal-regexp
|
|
new RegExp( classesToRemove.join( '|' ), 'g' ),
|
|
''
|
|
);
|
|
className += ` ${ LEGACY_PREFIX }${ matchedKey }`;
|
|
}
|
|
}
|
|
} );
|
|
document.documentElement.className = className;
|
|
}
|
|
};
|
|
|
|
( () => {
|
|
window.applyPref();
|
|
window.clientPrefs();
|
|
} )();
|