forked from Fediversity/fediversity.eu
add a desktop stylesheet
it also features a dark mode
This commit is contained in:
parent
716495e472
commit
52e0db710a
|
@ -125,4 +125,25 @@ in
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
assets."index.css".path = with lib; builtins.toFile
|
||||||
|
"index.css"
|
||||||
|
''
|
||||||
|
section h1, section h2, section h3
|
||||||
|
{
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
section h1 {
|
||||||
|
font-size: 3em;
|
||||||
|
}
|
||||||
|
section h2 {
|
||||||
|
font-size: 2.5em;
|
||||||
|
}
|
||||||
|
section h3 {
|
||||||
|
font-size: 1.5em;
|
||||||
|
}
|
||||||
|
section.collection h1 {
|
||||||
|
font-size: 2em;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
'';
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,6 +21,12 @@ in
|
||||||
{ page = pages.grants; }
|
{ page = pages.grants; }
|
||||||
{ page = pages.news; }
|
{ page = pages.news; }
|
||||||
{ page = pages.events; }
|
{ page = pages.events; }
|
||||||
|
{
|
||||||
|
link = {
|
||||||
|
label = "Contact";
|
||||||
|
url = "mailto:mail@fediversity.eu";
|
||||||
|
};
|
||||||
|
}
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -327,6 +327,12 @@ let
|
||||||
|
|
||||||
${/* https://html.spec.whatwg.org/multipage/semantics.html#attr-meta-http-equiv-x-ua-compatible */
|
${/* https://html.spec.whatwg.org/multipage/semantics.html#attr-meta-http-equiv-x-ua-compatible */
|
||||||
""}<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
""}<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||||
|
<!--
|
||||||
|
TODO: make proper icon and preload types
|
||||||
|
-->
|
||||||
|
<link rel="icon" type="image/png" href="/favicon.png">
|
||||||
|
<link rel="preload" as="image" type="image/svg" href="/ngi-fediversity.svg">
|
||||||
|
<link rel="preload" as="style" type="text/css" href="/style.css">
|
||||||
|
|
||||||
${print-element' "meta" {
|
${print-element' "meta" {
|
||||||
name = "viewport";
|
name = "viewport";
|
||||||
|
|
Before Width: | Height: | Size: 22 KiB After Width: | Height: | Size: 22 KiB |
Before Width: | Height: | Size: 11 KiB After Width: | Height: | Size: 11 KiB |
|
@ -1,12 +1,134 @@
|
||||||
|
:root {
|
||||||
|
/* XXX: maybe use light-dark() once it's more widely supported */
|
||||||
|
color-scheme: light dark;
|
||||||
|
--highlight: rgb(255, 110, 0);
|
||||||
|
--background: white;
|
||||||
|
--text-color: black;
|
||||||
|
--shadow: rgba(0,0,0,0.1);
|
||||||
|
scrollbar-gutter: stable;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (prefers-color-scheme: dark) {
|
||||||
|
:root {
|
||||||
|
--background: black;
|
||||||
|
--text-color: #f0f0f0;
|
||||||
|
--shadow: rgba(255,255,255,0.2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
body {
|
body {
|
||||||
font-family: Heebo, sans-serif;
|
font-family: Heebo, sans-serif;
|
||||||
padding: 1em;
|
color: var(--text-color);
|
||||||
|
background-color: var(--background);
|
||||||
|
padding: 0 1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
section {
|
||||||
max-width: 50em;
|
max-width: 50em;
|
||||||
margin: auto;
|
margin: auto;
|
||||||
}
|
}
|
||||||
|
|
||||||
h1, h2, h3, h4, h5, h6
|
h1, h2, h3, h4, h5, h6 {
|
||||||
{
|
|
||||||
font-family: Signika, sans-serif;
|
font-family: Signika, sans-serif;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: 2em;
|
||||||
|
}
|
||||||
|
|
||||||
|
header > nav {
|
||||||
|
margin: 1em;
|
||||||
|
font-family: Signika, sans-serif;
|
||||||
|
}
|
||||||
|
|
||||||
|
a:visited,
|
||||||
|
a
|
||||||
|
{
|
||||||
|
color: var(--highlight);
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
header a:visited,
|
||||||
|
header a
|
||||||
|
{
|
||||||
|
color: var(--text-color);
|
||||||
|
}
|
||||||
|
|
||||||
|
header a {
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
header a:hover,
|
||||||
|
header span:hover
|
||||||
|
{
|
||||||
|
color: var(--highlight);
|
||||||
|
}
|
||||||
|
|
||||||
|
header nav ul {
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
header > nav ul li {
|
||||||
|
list-style-type: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
header > nav > ul {
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
align-items: center;
|
||||||
|
max-width: 60em;
|
||||||
|
margin: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
header > nav > ul > li:first-child a {
|
||||||
|
content: url('ngi-fediversity.svg');
|
||||||
|
display: inline-block;
|
||||||
|
height: 2em;
|
||||||
|
margin-right: 4em;
|
||||||
|
}
|
||||||
|
|
||||||
|
header > nav > ul > li:last-child > a {
|
||||||
|
border: 1pt solid var(--text-color);
|
||||||
|
padding: 0.5em 1em 0.5em 1em;
|
||||||
|
border-radius: 3pt;
|
||||||
|
margin-left: 4em;
|
||||||
|
}
|
||||||
|
|
||||||
|
header > nav > ul > li:last-child:hover > a {
|
||||||
|
color: var(--background);
|
||||||
|
background-color: var(--highlight);
|
||||||
|
border-color: var(--background);
|
||||||
|
}
|
||||||
|
|
||||||
|
header > nav > ul > li > span {
|
||||||
|
position: relative;
|
||||||
|
cursor: pointer;
|
||||||
|
/* same as nav margin to bridge the gap for hovering */
|
||||||
|
padding: 1em 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
header > nav > ul > li > nav {
|
||||||
|
display: none;
|
||||||
|
position: absolute;
|
||||||
|
margin-top: 1em;
|
||||||
|
background: var(--background);
|
||||||
|
min-width: max-content;
|
||||||
|
padding: 0.5em;
|
||||||
|
box-shadow: 0 0 1em var(--shadow);
|
||||||
|
z-index: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
header > nav > ul > li > span:hover + nav,
|
||||||
|
header > nav > ul > li > nav:hover {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Optional: Style the dropdown items */
|
||||||
|
header > nav > ul > li > nav ul li {
|
||||||
|
padding: 0.25em 0.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Position the parent li relatively for absolute positioning context */
|
||||||
|
header > nav > ul > li {
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
{ config, lib, pkgs, ... }: {
|
{ config, lib, pkgs, ... }: {
|
||||||
config.assets."style.css".path = ./style.css;
|
config.assets."style.css".path = ./style.css;
|
||||||
|
config.assets."ngi-fediversity.svg".path = ./ngi-fediversity.svg;
|
||||||
|
# TODO: auto-generate a bunch from SVG
|
||||||
|
config.assets."favicon.png".path = ./favicon.png;
|
||||||
config.assets."fonts.css".path = with lib; builtins.toFile "fonts.css" (join "\n" (map
|
config.assets."fonts.css".path = with lib; builtins.toFile "fonts.css" (join "\n" (map
|
||||||
(font: ''
|
(font: ''
|
||||||
@font-face {
|
@font-face {
|
||||||
|
|
|
@ -33,7 +33,7 @@ in
|
||||||
let
|
let
|
||||||
render-item = item:
|
render-item = item:
|
||||||
if item ? menu then ''
|
if item ? menu then ''
|
||||||
<li>${item.menu.label}
|
<li><span>${item.menu.label}</span>
|
||||||
${lib.indent " " (item.menu.outputs.html page)}
|
${lib.indent " " (item.menu.outputs.html page)}
|
||||||
</li>
|
</li>
|
||||||
''
|
''
|
||||||
|
|
|
@ -60,9 +60,14 @@ in
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
body.content = [
|
body.content = [
|
||||||
(cfg.menus.main.outputs.html page)
|
''
|
||||||
|
<header>
|
||||||
|
${lib.indent " " (cfg.menus.main.outputs.html page)}
|
||||||
|
</header>
|
||||||
|
''
|
||||||
{
|
{
|
||||||
section = {
|
section = {
|
||||||
|
attrs = { };
|
||||||
heading.content = page.title;
|
heading.content = page.title;
|
||||||
content = [
|
content = [
|
||||||
(cfg.templates.html.markdown { inherit (page) name body; })
|
(cfg.templates.html.markdown { inherit (page) name body; })
|
||||||
|
|
Reference in a new issue