Closed silverwind closed 8 years ago
I actually started trying out something similar... I split up the @document
into separate files.. we can combine them in a build process.
/* GitHub */
:root {
/* Accent base color (links & highlights) */
--base-color: #4183c4;
--base-color-text: #e2e2e2; /* text for a base-color background */
/* body */
--body-background-color: #222;
--body-text-color: #ddd;
--body-background-image: url("");
--body-background-attach: fixed;
/* borders */
--border-base: #343434;
/* code */
--code-font: Menlo;
--code-tabs-size: 4;
--code-syntax-theme: Twilight;
/* presets */
--color-dark-1: #181818;
--color-dark-2: #222;
--color-dark-3: #343434;
--color-dark-4: #444;
--color-dark-5: #555;
--color-light-f: #fff;
--color-light-e: #e2e2e2;
--color-light-d: #ddd;
--color-light-c: #ccc;
--color-light-b: #bbb;
}
body {
background-color: var(--body-background-color) !important;
background-image: var(--body-background-image) !important;
background-attachment: var(--body-background-attach) !important;
background-clip: border-box !important;
background-origin: padding-box !important;
color: var(--body-text-color) !important;
}
/* code font */
pre, code {
font-family: var(--code-font), Consolas, "Liberation Mono", Menlo, Courier,
monospace !important;
}
/* accent color */
a, .link-blue, .header a:hover {
color: var(--base-color) !important;
}
.form-control.focus, .form-control:focus, .form-select.focus,
.form-select:focus {
border-color: var(--base-color) !important;
outline-color: var(--base-color) !important;
}
/* headers & panels */
.header, .dropdown-menu {
background: var(--color-dark-1) !important;
border-color: var(--color-dark-3) !important;
}
.header a {
color: var(--color-light-b) !important;
}
/* arrows - down */
.dropdown-caret {
border-top-color: var(--color-dark-b) !important;
}
/* arrows - up */
.dropdown-menu:before, .dropdown-menu:after {
border-bottom-color: var(--color-dark-b) !important;
}
/* inputs */
.form-control, .form-select {
background-color: var(--color-dark-1) !important;
border-color: var(--color-dark-3) !important;
color: var(--color-light-e) !important;
}
svg.octicon {
fill: currentColor !important;
overflow: visible !important;
}
@-moz-document regexp("^https?://((raw|status|developer)\.)?github\.com((?!generated_pages\/preview).)*$"), domain("githubusercontent.com") {
/*! Github Dark Theme v2.0.0 (9/14/2016) *//*
* https://github.com/StylishThemes/GitHub-Dark
* http://userstyles.org/styles/37035
* License: https://creativecommons.org/licenses/by-sa/4.0/
*/
/* AGENT_SHEET */
${main}
}
@-moz-document domain("gist.github.com") {
${gist}
}
@-moz-document domain("guides.github.com") {
${guides}
}
@-moz-document domain("help.github.com") {
${help}
}
@-moz-document domain("status.github.com") {
${status}
}
@-moz-document domain("developer.github.com") {
${developer}
}
There's a maintainability issue with colors like
--color-dark-1: #181818;
--color-dark-2: #222;
--color-dark-3: #343434;
--color-dark-4: #444;
--color-dark-5: #555;
Say, you'd like to add a shade 1 and 2, now you have to rename shades from 2 til the end to stay consistent. My approach above might be a bit easier to handle.
build process
I'd like to avoid a build process if possible. It's just so convenient to copy/paste a style as-is from the editor and unfortunately necessary as one can't interface with Stylish through other means 😢.
I mention a build process because Chrome handles the style differently than Firefox. It splits each @-moz-document
into separate sections so having separate files would make it easier for me to copy/paste 😉.
It's fine though since I use the script a lot more, it's just a bit more painful on developer.github.com since the settings panel doesn't open... hmm, I guess I could fix that LOL.
@silverwind I'd like to post my preliminary work - only the main repo page has been done so far. Before continuing, I'd thought some discussion would be best.
Would you prefer to create a branch here, or a new temporary repo?
@Mottie I think a separate repo might be easier to work with, call it New-GitHub-Dark
or something 😉. We can merge back once it's ready.
So as for separate stylesheets, there's at least:
frameworks-{hash}.css
(which frameworks?)github-{hash}.css
(main site and gist)gist-{hash}.css
(gist only)ipynb-{hash}.css
(jupyter stuff on both gist and main site)application.css
(help)application.css
(developer)From that, you can see that there are shared styles. E.g. gist uses stuff from the github sheet, both gist and github use stuff from ipynb. Shared stuff like that can't be scoped in regexp
blocks, so I guess we'd need to have them outside those blocks.
Good idea. I've used that method in the new repo... let's move this discussion over there: https://github.com/StylishThemes/New-GitHub-Dark/issues/1
Few ideas:
@document
(with-moz-
prefix if necessary) sections to scope styles. Basically any site that does not useframworks-*.css
+github-*.css
should have its own section.