Au début on se dit qu’il faut questionner le choix utilisateur avec une mediaQuery:
(window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches)
Reste que si l’on est dans un contexte incertain, développement d’un add-on dans mon cas, se résoudre à cette simple requête est une mauvaise stratégies car le site sur lequel on vient se pluger lui peut ne pas adapter son style aux choix utilisateur (dark mode ou non).
Sur Firefox qui est mon browser de dev, je ne comprenais pas pourquoi j’obtenais « rgba(0, 0, 0, 0) » avec la ligne suivante sur des pages où le fond est blanc mais le système est en dark mode:
window.getComputedStyle(document.body,null).getPropertyValue('background-color');
A vrai dire, mon erreur était de comprendre cette ligne comme parlant de la couleur noire (0,0,0) alors que le dernier 0 indique en rgba que le fond est transparent, or le fond d’écran d’une page web est blanc. La proprieté (‘background’) retourne d’ailleurs ‘none’. Chrome et safari retournent une valeur rgb qui est plus simple à comprendre.
Au final, je pense être pas mal avec ce bloc:
var dark = false;
let bs = window.getComputedStyle(document.body,null);
let baco = bs.getPropertyValue('background-color');
if(bs.getPropertyValue('background') == 'none') {
if(!(/rgba.*,\s?0\)$/.test(baco))) {
dark = true;
}
} else {
let sacos = baco.split(/,/);
let moy = 128;
if((sacos != null) && (sacos.length > 2)) {
moy = (parseInt(sacos[0].replace(/\D+/g,''))+parseInt(sacos[1].replace(/\D/g,''))+parseInt(sacos[2].replace(/\D/g,''))) / 3;
}
if((moy < 128) && !(/rgba.*,\s?0\)$/.test(baco))) {
dark = true;
}
}
Au final, j’aime bien mon petit calcul pour essayer d’évaluer si la couleur est plutôt sombre ou claire.