mirror of
https://github.com/philomena-dev/philomena.git
synced 2024-11-27 13:47:58 +01:00
automatically apply system-wide theme preference for anonymous users (fixes philomena-dev/philomena#36)
This commit is contained in:
parent
1f57d0041c
commit
edcd4ebfde
3 changed files with 28 additions and 3 deletions
13
assets/js/theme.js
Normal file
13
assets/js/theme.js
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
/**
|
||||||
|
* Theme setting
|
||||||
|
*/
|
||||||
|
|
||||||
|
function setThemeCookie() {
|
||||||
|
if (window.matchMedia('(prefers-color-scheme: dark)').matches) {
|
||||||
|
document.cookie = `theme=dark; path=/; max-age=788923800; samesite=lax`;
|
||||||
|
} else {
|
||||||
|
document.cookie = `theme=light; path=/; max-age=788923800; samesite=lax`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export { setThemeCookie };
|
|
@ -32,6 +32,7 @@ import { setupTimestamps } from './timeago';
|
||||||
import { setupImageUpload } from './upload';
|
import { setupImageUpload } from './upload';
|
||||||
import { setupSearch } from './search';
|
import { setupSearch } from './search';
|
||||||
import { setupToolbar } from './textiletoolbar';
|
import { setupToolbar } from './textiletoolbar';
|
||||||
|
import { setThemeCookie } from './theme';
|
||||||
import { hideStaffTools } from './staffhider';
|
import { hideStaffTools } from './staffhider';
|
||||||
import { pollOptionCreator } from './poll';
|
import { pollOptionCreator } from './poll';
|
||||||
|
|
||||||
|
@ -63,7 +64,8 @@ whenReady(() => {
|
||||||
setupTimestamps();
|
setupTimestamps();
|
||||||
setupImageUpload();
|
setupImageUpload();
|
||||||
setupSearch();
|
setupSearch();
|
||||||
setupToolbar();
|
setupToolbar()
|
||||||
|
setThemeCookie();
|
||||||
hideStaffTools();
|
hideStaffTools();
|
||||||
pollOptionCreator();
|
pollOptionCreator();
|
||||||
|
|
||||||
|
|
|
@ -64,14 +64,24 @@ defmodule PhilomenaWeb.LayoutView do
|
||||||
Config.get(:footer)
|
Config.get(:footer)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def stylesheet_path(conn, %{theme: "default"}),
|
||||||
|
do: Routes.static_path(conn, "/css/default.css")
|
||||||
|
|
||||||
def stylesheet_path(conn, %{theme: "dark"}),
|
def stylesheet_path(conn, %{theme: "dark"}),
|
||||||
do: Routes.static_path(conn, "/css/dark.css")
|
do: Routes.static_path(conn, "/css/dark.css")
|
||||||
|
|
||||||
def stylesheet_path(conn, %{theme: "red"}),
|
def stylesheet_path(conn, %{theme: "red"}),
|
||||||
do: Routes.static_path(conn, "/css/red.css")
|
do: Routes.static_path(conn, "/css/red.css")
|
||||||
|
|
||||||
def stylesheet_path(conn, _user),
|
def stylesheet_path(conn, _user) do
|
||||||
do: Routes.static_path(conn, "/css/default.css")
|
case conn.cookies do
|
||||||
|
%{"theme" => "dark"} ->
|
||||||
|
Routes.static_path(conn, "/css/dark.css")
|
||||||
|
|
||||||
|
_ ->
|
||||||
|
Routes.static_path(conn, "/css/default.css")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def theme_name(%{theme: theme}), do: theme
|
def theme_name(%{theme: theme}), do: theme
|
||||||
def theme_name(_user), do: "default"
|
def theme_name(_user), do: "default"
|
||||||
|
|
Loading…
Reference in a new issue