Merge pull request 'feat/20-add-dark-mode-support' (#21) from feat/20-add-dark-mode-support into main

Reviewed-on: #21
This commit is contained in:
llama 2023-03-10 09:37:26 -05:00
commit f1bb72f4e0
7 changed files with 936 additions and 794 deletions

View File

@ -1,3 +1,5 @@
@import "../node_modules/bulma/sass/utilities/functions.sass";
//brand colors //brand colors
$nexi-white: #f8fafb; // Made up $nexi-white: #f8fafb; // Made up
$nexi-lighter-black: #353535; // Made up $nexi-lighter-black: #353535; // Made up
@ -14,11 +16,10 @@ $nexi-orange: #F17C25;
$nexi-darker-orange: #F44336; $nexi-darker-orange: #F44336;
$nexi-yellow: #FFC107; $nexi-yellow: #FFC107;
$custom-colors: $custom-colors: (
( "nexi-white": ($nexi-white, $nexi-black),
"nexi-white": ($nexi-white, findColorInvert($nexi-white)),
"nexi-lighter-black": ($nexi-lighter-black, findColorInvert($nexi-lighter-black)), "nexi-lighter-black": ($nexi-lighter-black, findColorInvert($nexi-lighter-black)),
"nexi-black": ($nexi-black, findColorInvert($nexi-black)), "nexi-black": ($nexi-black, $nexi-white),
"nexi-lighter-red": ($nexi-lighter-red, findColorInvert($nexi-lighter-red)), "nexi-lighter-red": ($nexi-lighter-red, findColorInvert($nexi-lighter-red)),
"nexi-red": ($nexi-red, findColorInvert($nexi-red)), "nexi-red": ($nexi-red, findColorInvert($nexi-red)),
"nexi-darker-red": ($nexi-darker-red, findColorInvert($nexi-darker-red)), "nexi-darker-red": ($nexi-darker-red, findColorInvert($nexi-darker-red)),
@ -30,7 +31,7 @@ $custom-colors:
"nexi-orange": ($nexi-orange, findColorInvert($nexi-orange)), "nexi-orange": ($nexi-orange, findColorInvert($nexi-orange)),
"nexi-darker-orange": ($nexi-darker-orange, findColorInvert($nexi-darker-orange)), "nexi-darker-orange": ($nexi-darker-orange, findColorInvert($nexi-darker-orange)),
"nexi-yellow": ($nexi-yellow, findColorInvert($nexi-yellow)), "nexi-yellow": ($nexi-yellow, findColorInvert($nexi-yellow)),
); );
// Used for texts etc. // Used for texts etc.
$grey: $nexi-lighter-black; $grey: $nexi-lighter-black;
@ -47,7 +48,8 @@ $purple: $nexi-purple;
$red: $nexi-red; $red: $nexi-red;
// https://github.com/jgthms/bulma/blob/master/sass/utilities/derived-variables.sass // https://github.com/jgthms/bulma/blob/master/sass/utilities/derived-variables.sass
$primary: $nexi-white; $primary: $nexi-black;
$primary-invert: $nexi-white;
//$info: $cyan; //$info: $cyan;
//$success: $green; //$success: $green;

View File

@ -0,0 +1,39 @@
.dark-toggle {
--size: 2rem;
appearance: none;
outline: none;
cursor: pointer;
width: var(--size);
height: var(--size);
box-shadow: inset calc(var(--size) * 0.33) calc(var(--size) * -0.25) 0;
border-radius: 999px;
color: hsl(240, 100%, 95%);
transition: all 500ms;
&:checked {
--ray-size: calc(var(--size) * -0.4);
--offset-orthogonal: calc(var(--size) * 0.65);
--offset-diagonal: calc(var(--size) * 0.45);
transform: scale(0.75);
color: hsl(40, 100%, 50%);
box-shadow:
inset 0 0 0 var(--size),
calc(var(--offset-orthogonal) * -1) 0 0 var(--ray-size),
var(--offset-orthogonal) 0 0 var(--ray-size),
0 calc(var(--offset-orthogonal) * -1) 0 var(--ray-size),
0 var(--offset-orthogonal) 0 var(--ray-size),
calc(var(--offset-diagonal) * -1) calc(var(--offset-diagonal) * -1) 0 var(--ray-size),
var(--offset-diagonal) var(--offset-diagonal) 0 var(--ray-size),
calc(var(--offset-diagonal) * -1) var(--offset-diagonal) 0 var(--ray-size),
var(--offset-diagonal) calc(var(--offset-diagonal) * -1) 0 var(--ray-size),
;
}
}
.dark-toggle-animation {
transition: background 500ms;
}

View File

@ -2,6 +2,7 @@
// Our scss files // Our scss files
@import "branding"; @import "branding";
@import "dark-mode";
// Import after our branding so colors work. // Import after our branding so colors work.
@import "../node_modules/bulma/bulma.sass"; @import "../node_modules/bulma/bulma.sass";

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,72 @@
// Set theme on load.
function init() {
// Default to light theme.
let theme = 'light'
// Check media query prefer and set it as dark.
if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {
theme = 'dark';
}
// Add event handler so if they change media query it'll update. overkill? yes.
window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', event => {
let theme = event.matches ? "dark" : "light";
applyTheme(theme);
});
// If they have manually changed it use that theme instead.
theme = localStorage.getItem("theme") ?? theme
// Set it on body.
document.body.dataset.theme = theme;
// If dark-mode was toggle above we need to fix the icon.
let toggle = document.getElementsByName("dark-mode-toggle")[0];
// if it's already dark check it.
toggle.checked = theme === 'dark';
applyTheme(theme);
}
// Toggle the theme.
function darkLight() {
// Get current theme.
let element = document.body;
// Invert it.
switch (element.dataset.theme) {
case "light":
element.dataset.theme = "dark";
break;
case "dark":
element.dataset.theme = "light";
break;
}
localStorage.setItem("theme", element.dataset.theme);
applyTheme(element.dataset.theme);
}
// Apply theme
function applyTheme(theme) {
let primaryElements
// Find elements and update class.
switch (theme) {
case 'dark':
primaryElements = Array.from(document.querySelectorAll('.is-primary-invert'));
primaryElements.forEach((element) => {
element.classList.remove('is-primary-invert');
element.classList.add('is-primary');
});
break;
case 'light':
primaryElements = Array.from(document.querySelectorAll('.is-primary'));
primaryElements.forEach((element) => {
element.classList.remove('is-primary');
element.classList.add('is-primary-invert');
});
break;
}
}

View File

@ -1,56 +1,60 @@
<!DOCTYPE html> <!DOCTYPE html>
<html class="is-clipped" xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> <html class="is-clipped" xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Pricey Bot</title>
<script type="application/javascript" src="{{ url_for('static', filename='scripts/dark-mode.js', version='0.1') }}"></script>
<link rel="stylesheet" href="{{ url_for('static', filename='css/main.css', version='0.1') }}">
</head>
<head> <body data-theme="light" onload="init()">
<meta charset="utf-8"> <section class="hero is-primary is-fullheight dark-toggle-animation">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <div class="hero-head">
<meta name="viewport" content="width=device-width, initial-scale=1"> <nav class="navbar">
<title>Flask Auth Example</title> <div class="container">
<link rel="stylesheet" href="{{ url_for('static', filename='css/main.css', version='0.3') }}"> <div id="navbarMenuHeroA" class="navbar-menu">
</head> <div class="navbar-end">
<a href="{{ url_for('main.index') }}" class="navbar-item">
<body> Home
<section class="hero is-primary is-fullheight"> </a>
{% if current_user.is_authenticated %}
<div class="hero-head"> <a href="{{ url_for('main.profile') }}" class="navbar-item">
<nav class="navbar"> Profile
<div class="container"> </a>
<div id="navbarMenuHeroA" class="navbar-menu"> {% endif %}
<div class="navbar-end"> {% if not current_user.is_authenticated %}
<a href="{{ url_for('main.index') }}" class="navbar-item"> <a href="{{ url_for('auth.login') }}" class="navbar-item">
Home Login
</a> </a>
{% if current_user.is_authenticated %} <a href="{{ url_for('auth.signup') }}" class="navbar-item">
<a href="{{ url_for('main.profile') }}" class="navbar-item"> Sign Up
Profile </a>
</a> {% endif %}
{% endif %} {% if current_user.is_authenticated %}
{% if not current_user.is_authenticated %} <a href="{{ url_for('auth.logout') }}" class="navbar-item">
<a href="{{ url_for('auth.login') }}" class="navbar-item"> Logout
Login </a>
</a> {% endif %}
<a href="{{ url_for('auth.signup') }}" class="navbar-item"> </div>
Sign Up
</a>
{% endif %}
{% if current_user.is_authenticated %}
<a href="{{ url_for('auth.logout') }}" class="navbar-item">
Logout
</a>
{% endif %}
</div> </div>
</div> </div>
</div> </nav>
</nav>
</div>
<div class="hero-body">
<div class="container has-text-centered">
{% block content %}
{% endblock %}
</div> </div>
</div>
</section>
</body>
<div class="hero-body">
<div class="container has-text-centered">
{% block content %}
{% endblock %}
</div>
</div>
<div class="hero-foot">
<label class="is-pulled-right p-4">
<input name="dark-mode-toggle" class="dark-toggle" onclick="darkLight()" type="checkbox">
</label>
</div>
</section>
</body>
</html> </html>

2
start.sh Normal file
View File

@ -0,0 +1,2 @@
export FLASK_APP=priceybot2
flask run --host=0.0.0.0