Calculadora
Calculadora copied to clipboard
š Calculadora responsiva usando boostrap com a opção de alteração dos temas usando prefer-color-scheme. š
š Calculadora š
ā” Calculadora Responsiva e com opƧƵes para troca de temas ā”
š Prefer Color Scheme:
AlĆ©m dos 3 diferentes temas da calculadora, foi usado o recurso de mĆdia prefer-color-scheme.
Esse recurso possibilita o entendimento de qual a preferência do usuÔrio em relação aos temas, assim podendo receber dois valores:
- Light (Claro)
- Dark (Escuro)
A maneira de aplicar esse recurso de acordo com a developer.mozilla Ć© da seguinte maneira:
@media (prefers-color-scheme: dark) {
// ConfiguraƧƵes CSS para o tema dark
}
@media (prefers-color-scheme: light) {
// ConfiguraƧƵes CSS para o tema light
}
Mas com esse método o carregamento do código irÔ ficar mais lento pois seria necessÔrio repetir todas as propriedades desejadas com suas novas colorações.
EntĆ£o qual a solução ? š¤
Iremos apenas mudar os valores das variƔveis do CSS com JS.
const darkThemeMq = window.matchMedia("(prefers-color-scheme: dark)");
const lightThemeMq = window.matchMedia("(prefers-color-scheme: light)");
Primeiro identificamos qual a preferência de tema do usuÔrio e guardamos o resultado em uma constante.
Agora só precisamos verificar qual o valor das constantes e modificar os valores das variÔveis do CSS
if (darkThemeMq.matches) {
document.getElementById('btnTheme').value = "3";
theme.dark();
} else if(lightThemeMq.matches){
document.getElementById('btnTheme').value = "2";
theme.light();
} else {
document.getElementById('btnTheme').value = "1";
theme.default();
}
theme.dark(),theme.light()... Armazenam os comandos para modificar os valores das variƔveis no CSS. Sendo eles:
const root = document.querySelector(':root');
const theme = {
default() {
root.style.setProperty('--background' , '#3a4764');
// E as demais variƔveis
},
light() {
root.style.setProperty('--background' , '#e6e6e6');
// E as demais variƔveis
},
dark() {
root.style.setProperty('--background' , '#17062a');
// E as demais variƔveis
}
}
Como Ć© PossĆvel fazer o Teste/Debug ? š¤
Podemos usar a ferramenta de desenvoledor do google chrome e alterar os valores Dark ou Light
Resultado Final š„³:
š§ Tecnologias e Frameworks Usados: