commit 1d4d75380f1f2f073d6698c97f5283db6bfce071
parent 7b773fa9993887d7b912e3b9b70d1a4992810b10
Author: Hunter
Date: Thu, 30 Apr 2026 16:31:31 -0400
update default styling
Diffstat:
7 files changed, 149 insertions(+), 17 deletions(-)
diff --git a/build.py b/build.py
@@ -146,6 +146,7 @@ def build_pwa(app_name=None, base_path=None):
"resources/prev.svg",
"resources/next.svg",
"resources/repeat.svg",
+ "resources/fonts/Basteleur/Basteleur-Moonlight.woff2",
]
AUDIO_EXTS = {".mp3", ".m4a", ".ogg", ".flac", ".wav"}
diff --git a/readme.md b/readme.md
@@ -73,5 +73,7 @@ ensure you have the right to distribute any media files you include in public mi
it may have looked like i winked just now, but that was a blink. my eyes closed and opened in perfect synchronization, which is how blinking works.
-## license
-<a href="LICENSE">GNU GPLv3</a>
+## licenses
+this project is licensed under the <a href="LICENSE">GNU General Public License v3.0</a>.
+
+the <a href="https://velvetyne.fr/fonts/basteleur/">Basteleur</a> font by <a href="https://keussel.studio/">Keussel</a> (distributed by <a href="https://velvetyne.fr/">Velvetyne</a>) is licensed under the <a href="resources/fonts/Basteleur/LICENSE.txt">SIL Open Font License, version 1.1</a>.
diff --git a/readme_images/playlist.png b/readme_images/playlist.png
Binary files differ.
diff --git a/resources/fonts/Basteleur/Basteleur-Moonlight.woff2 b/resources/fonts/Basteleur/Basteleur-Moonlight.woff2
Binary files differ.
diff --git a/resources/fonts/Basteleur/LICENSE.txt b/resources/fonts/Basteleur/LICENSE.txt
@@ -0,0 +1,106 @@
+Copyright (c) 2021, Keussel (www.keussel.studio|contact@keussel.studio),
+with Reserved Font Name Basteleur.
+
+This Font Software is licensed under the SIL Open Font License, Version 1.1.
+This license is copied below, and is also available with a FAQ at:
+http://scripts.sil.org/OFL
+
+SIL Open Font License v1.1
+====================================================
+
+
+Preamble
+----------
+
+The goals of the Open Font License (OFL) are to stimulate worldwide
+development of collaborative font projects, to support the font creation
+efforts of academic and linguistic communities, and to provide a free and
+open framework in which fonts may be shared and improved in partnership
+with others.
+
+The OFL allows the licensed fonts to be used, studied, modified and
+redistributed freely as long as they are not sold by themselves. The
+fonts, including any derivative works, can be bundled, embedded,
+redistributed and/or sold with any software provided that any reserved
+names are not used by derivative works. The fonts and derivatives,
+however, cannot be released under any other type of license. The
+requirement for fonts to remain under this license does not apply
+to any document created using the fonts or their derivatives.
+
+
+Definitions
+-------------
+
+`"Font Software"` refers to the set of files released by the Copyright
+Holder(s) under this license and clearly marked as such. This may
+include source files, build scripts and documentation.
+
+`"Reserved Font Name"` refers to any names specified as such after the
+copyright statement(s).
+
+`"Original Version"` refers to the collection of Font Software components as
+distributed by the Copyright Holder(s).
+
+`"Modified Version"` refers to any derivative made by adding to, deleting,
+or substituting -- in part or in whole -- any of the components of the
+Original Version, by changing formats or by porting the Font Software to a
+new environment.
+
+`"Author"` refers to any designer, engineer, programmer, technical
+writer or other person who contributed to the Font Software.
+
+
+Permission & Conditions
+------------------------
+
+Permission is hereby granted, free of charge, to any person obtaining
+a copy of the Font Software, to use, study, copy, merge, embed, modify,
+redistribute, and sell modified and unmodified copies of the Font
+Software, subject to the following conditions:
+
+1. Neither the Font Software nor any of its individual components,
+ in Original or Modified Versions, may be sold by itself.
+
+2. Original or Modified Versions of the Font Software may be bundled,
+ redistributed and/or sold with any software, provided that each copy
+ contains the above copyright notice and this license. These can be
+ included either as stand-alone text files, human-readable headers or
+ in the appropriate machine-readable metadata fields within text or
+ binary files as long as those fields can be easily viewed by the user.
+
+3. No Modified Version of the Font Software may use the Reserved Font
+ Name(s) unless explicit written permission is granted by the corresponding
+ Copyright Holder. This restriction only applies to the primary font name as
+ presented to the users.
+
+4. The name(s) of the Copyright Holder(s) or the Author(s) of the Font
+ Software shall not be used to promote, endorse or advertise any
+ Modified Version, except to acknowledge the contribution(s) of the
+ Copyright Holder(s) and the Author(s) or with their explicit written
+ permission.
+
+5. The Font Software, modified or unmodified, in part or in whole,
+ must be distributed entirely under this license, and must not be
+ distributed under any other license. The requirement for fonts to
+ remain under this license does not apply to any document created
+ using the Font Software.
+
+
+Termination
+-----------
+
+This license becomes null and void if any of the above conditions are
+not met.
+
+
+ DISCLAIMER
+
+ THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
+ OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
+ COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
+ INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
+ DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
+ OTHER DEALINGS IN THE FONT SOFTWARE.
diff --git a/resources/script.js b/resources/script.js
@@ -87,6 +87,7 @@ const staticFiles = [
'resources/prev.svg',
'resources/next.svg',
'resources/repeat.svg',
+ 'resources/fonts/Basteleur/Basteleur-Moonlight.woff2',
];
// Retry fetch with exponential backoff
diff --git a/resources/styles.css b/resources/styles.css
@@ -1,9 +1,17 @@
+@font-face {
+ font-family: 'Basteleur Moonlight';
+ src: url('fonts/Basteleur/Basteleur-Moonlight.woff2') format('woff2');
+ font-weight: normal;
+ font-style: normal;
+ font-display: swap;
+}
+
:root {
- --text: #dddddd;
- --dimmed-text: #ddddddcc;
- --primary: #4c7ae6;
- --accent: #f421ff;
- --background: #080a0c;
+ --primary: #ff1900;
+ --accent: #5d0cf4;
+ --background: #000000;
+ --text: #ffffff;
+ --dimmed-text: #a6a6b4;
}
* {
@@ -32,11 +40,11 @@ html::-webkit-scrollbar {
body {
margin: 0;
padding: 0;
- font-family: "MS Sans Serif", Arial, sans-serif;
+ font-family: 'Basteleur Moonlight', sans-serif;
height: 100dvh;
display: flex;
flex-direction: column;
- font-size: 25px;
+ font-size: 24px;
background-color: var(--background);
position: fixed;
width: 100%;
@@ -162,7 +170,7 @@ body {
}
.playlist-item-title {
- font-size: 21px;
+ font-size: 20px;
line-height: 1.2;
}
@@ -172,7 +180,7 @@ body {
}
.playlist-item-artist {
- font-size: 17px;
+ font-size: 16px;
color: var(--dimmed-text);
line-height: 1.2;
}
@@ -186,16 +194,21 @@ body {
@media (hover: hover) and (pointer: fine) {
.playlist-item:hover {
cursor: pointer;
- color: var(--accent);
}
+ .playlist-item:hover .playlist-item-title,
.playlist-item:hover .playlist-item-artist {
- color: var(--accent);
+ color: var(--text);
+ background-color: var(--accent);
+ align-self: flex-start;
+ padding: 0 4px;
+ margin-left: -4px;
}
.playlist-item:hover .playlist-item-title.current,
.playlist-item:hover .playlist-item-artist.current {
- color: var(--accent);
+ background-color: var(--primary);
+ color: var(--background);
}
body.reorderable .playlist,
@@ -219,10 +232,19 @@ body.reordering .playlist-item {
box-sizing: border-box;
}
-.playlist-item.dragging,
.playlist-item.dragging .playlist-item-title,
.playlist-item.dragging .playlist-item-artist {
- color: var(--accent);
+ color: var(--text);
+ background-color: var(--accent);
+ align-self: flex-start;
+ padding: 0 4px;
+ margin-left: -4px;
+}
+
+.playlist-item.dragging .playlist-item-title.current,
+.playlist-item.dragging .playlist-item-artist.current {
+ background-color: var(--primary);
+ color: var(--background);
}
.playlist-item-placeholder {
@@ -262,7 +284,7 @@ body.reordering .playlist-item {
.progress-container {
width: 100%;
- font-size: 24px;
+ font-size: 23px;
cursor: grab;
margin-top: 0;
height: 35px;