Introduce some CSS variables to simplify writing themes that stay close to the default style

This commit is contained in:
Jérémie Astori 2018-04-30 00:57:03 -04:00
parent 8137ece450
commit f814d7369c
No known key found for this signature in database
GPG Key ID: B9A4F245CD67BDE8
2 changed files with 33 additions and 60 deletions

View File

@ -2,8 +2,23 @@
@import "bootstrap.css"; @import "bootstrap.css";
:root { :root {
/* Main text color */
--body-color: #222;
/* Background color of the whole page */
--body-bg-color: #415364;
/* Links and link-looking buttons */ /* Links and link-looking buttons */
--link-color: #50a656; --link-color: #50a656;
/* Background color of the main window */
--window-bg-color: #fff;
/* Color of the date marker, text and separator */
--date-marker-color: rgba(0, 107, 59, 0.5);
/* Color of the unread message marker, text and separator */
--unread-marker-color: rgba(231, 76, 60, 0.5);
} }
/* Samsung Internet <7.0 and Microsoft Edge support (yes, both of them use webkit prefix) */ /* Samsung Internet <7.0 and Microsoft Edge support (yes, both of them use webkit prefix) */
@ -23,8 +38,8 @@ body {
} }
body { body {
background: #415364; background: var(--body-bg-color);
color: #222; color: var(--body-color);
font: 16px -apple-system, system-ui, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; font: 16px -apple-system, system-ui, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
margin: 0; margin: 0;
-webkit-user-select: none; -webkit-user-select: none;
@ -481,7 +496,7 @@ kbd {
width: 10px; width: 10px;
height: 10px; height: 10px;
border-radius: 50%; border-radius: 50%;
border: 2px solid white; border: 2px solid var(--window-bg-color);
opacity: 0; opacity: 0;
transition: opacity 0.2s; transition: opacity 0.2s;
background-clip: padding-box; /* Fix border-radius bleeding color */ background-clip: padding-box; /* Fix border-radius bleeding color */
@ -866,7 +881,7 @@ background on hover (unless active) */
} }
#windows .window { #windows .window {
background: #fff; background: var(--window-bg-color);
display: none; display: none;
overflow-y: auto; overflow-y: auto;
height: 100%; height: 100%;
@ -1036,7 +1051,6 @@ background on hover (unless active) */
} }
#chat .userlist { #chat .userlist {
background: #fff;
border-left: 1px solid #e7e7e7; border-left: 1px solid #e7e7e7;
width: 180px; width: 180px;
display: flex; display: flex;
@ -1113,13 +1127,13 @@ background on hover (unless active) */
left: 0; left: 0;
right: 0; right: 0;
top: 50%; top: 50%;
border-top: 1px solid rgba(231, 76, 60, 0.5); border-top: 1px solid var(--unread-marker-color);
} }
#chat .unread-marker-text::before { #chat .unread-marker-text::before {
content: "New messages"; content: "New messages";
background-color: white; background-color: var(--window-bg-color);
color: rgba(231, 76, 60, 0.5); color: var(--unread-marker-color);
padding: 0 10px; padding: 0 10px;
} }
@ -1143,13 +1157,13 @@ background on hover (unless active) */
left: 0; left: 0;
right: 0; right: 0;
top: 50%; top: 50%;
border-top: 1px solid rgba(0, 107, 59, 0.5); border-top: 1px solid var(--date-marker-color);
} }
#chat .date-marker-text::before { #chat .date-marker-text::before {
content: attr(data-label); content: attr(data-label);
background-color: white; background-color: var(--window-bg-color);
color: rgba(0, 107, 59, 0.5); color: var(--date-marker-color);
padding: 0 10px; padding: 0 10px;
} }
@ -1489,7 +1503,7 @@ part/quit messages where we don't load previews (adds a blank line otherwise) */
} }
#chat .userlist .search { #chat .userlist .search {
color: #222; color: var(--body-color);
border: 0; border: 0;
background: none; background: none;
font: inherit; font: inherit;
@ -2309,7 +2323,7 @@ part/quit messages where we don't load previews (adds a blank line otherwise) */
} }
#sidebar { #sidebar {
background: #415364; background: var(--body-bg-color);
height: 100%; height: 100%;
position: absolute; position: absolute;
left: -220px; left: -220px;
@ -2370,6 +2384,7 @@ part/quit messages where we don't load previews (adds a blank line otherwise) */
} }
#chat .userlist { #chat .userlist {
background-color: var(--window-bg-color);
height: 100%; height: 100%;
position: absolute; position: absolute;
right: 0; right: 0;

View File

@ -1,11 +1,11 @@
@import 'default.css'; @import 'default.css';
:root { :root {
--body-color: #f3f3f3;
--link-color: #77abd9; --link-color: #77abd9;
} --window-bg-color: #303e4a;
--date-marker-color: #97ea70;
body { --unread-marker-color: #f92772;
color: #f3f3f3;
} }
#windows .logo { #windows .logo {
@ -16,13 +16,6 @@ body {
display: inline-block; display: inline-block;
} }
#main,
#chat .userlist,
#windows .chan,
#windows .window {
background: #303e4a;
}
#chat .userlist .count { #chat .userlist .count {
background-color: #28333d; background-color: #28333d;
} }
@ -31,10 +24,6 @@ body {
color: #b7c5d1; color: #b7c5d1;
} }
#chat .userlist .search {
color: #f3f3f3;
}
/* Borders */ /* Borders */
#chat .content, #chat .content,
#windows #chat .header, #windows #chat .header,
@ -44,10 +33,6 @@ body {
} }
/* User list */ /* User list */
#chat .user-mode {
color: #f3f3f3;
}
#chat .userlist .user.active { #chat .userlist .user.active {
background-color: #28333d; background-color: #28333d;
} }
@ -99,7 +84,7 @@ body {
#windows #form .input { #windows #form .input {
background-color: #28333d; background-color: #28333d;
border-color: #28333d; border-color: #28333d;
color: #f3f3f3; color: var(--body-color);
} }
#form #nick { #form #nick {
@ -115,10 +100,6 @@ body {
color: #b7c5d1; color: #b7c5d1;
} }
#windows .header {
color: #fff;
}
#windows .header .topic { #windows .header .topic {
color: #b7c5d1; color: #b7c5d1;
} }
@ -130,29 +111,6 @@ body {
color: #b7c5d1; color: #b7c5d1;
} }
/* Notification dot on the top right corner of the menu icon */
#viewport .lt::after {
border-color: #303e4a;
}
#chat .unread-marker-text::before {
background-color: #303e4a;
border-color: #f92772;
}
#chat .unread-marker::before {
border-color: #f92772;
}
#chat .date-marker::before {
border-color: #97ea70;
}
#chat .date-marker-text::before {
background-color: #303e4a;
color: #97ea70;
}
/* Setup text colors */ /* Setup text colors */
#chat .message { #chat .message {
color: #f3f3f3; color: #f3f3f3;