diff --git a/config/nimdoc.cfg b/config/nimdoc.cfg
index 7aee50d8c5253..d10c2f3186fe1 100644
--- a/config/nimdoc.cfg
+++ b/config/nimdoc.cfg
@@ -135,12 +135,13 @@ doc.body_toc_groupsection = """
doc.body_toc_group = """
-
-
-
Dark Mode
+
+
+
@@ -174,12 +175,13 @@ doc.body_toc_group = """
doc.body_toc_group = """
-
-
-
Dark Mode
+
+
+
diff --git a/doc/nimdoc.css b/doc/nimdoc.css
index e72c4a213c971..f924f5a36f711 100644
--- a/doc/nimdoc.css
+++ b/doc/nimdoc.css
@@ -78,63 +78,45 @@ Modified by Boyd Greenfield and narimiran
--clipboard-image: var(--clipboard-image-normal);
}
-.theme-switch-wrapper {
- display: flex;
- align-items: center;
-}
-
-.theme-switch-wrapper em {
- margin-left: 10px;
- font-size: 1rem;
-}
-
-.theme-switch {
- display: inline-block;
- height: 22px;
- position: relative;
- width: 50px;
-}
-
-.theme-switch input {
- display: none;
-}
-
-.slider {
- background-color: #ccc;
- bottom: 0;
- cursor: pointer;
- left: 0;
- position: absolute;
- right: 0;
- top: 0;
- transition: .4s;
-}
-
-.slider:before {
- background-color: #fff;
- bottom: 4px;
- content: "";
- height: 13px;
- left: 4px;
- position: absolute;
- transition: .4s;
- width: 13px;
-}
-
-input:checked + .slider {
- background-color: #66bb6a;
-}
-
-input:checked + .slider:before {
- transform: translateX(26px);
-}
-
-.slider.round {
- border-radius: 17px;
+@media (prefers-color-scheme: dark) {
+ [data-theme="auto"] {
+ --primary-background: #171921;
+ --secondary-background: #1e202a;
+ --third-background: #2b2e3b;
+ --info-background: #008000;
+ --warning-background: #807000;
+ --error-background: #c03000;
+ --border: #0e1014;
+ --text: #fff;
+ --anchor: #8be9fd;
+ --anchor-focus: #8be9fd;
+ --input-focus: #8be9fd;
+ --strong: #bd93f9;
+ --hint: #7A7C85;
+ --nim-sprite-base64: url("");
+
+ --keyword: #ff79c6;
+ --identifier: #f8f8f2;
+ --comment: #6272a4;
+ --operator: #ff79c6;
+ --punctuation: #f8f8f2;
+ --other: #f8f8f2;
+ --escapeSequence: #bd93f9;
+ --number: #bd93f9;
+ --literal: #f1fa8c;
+ --program: #9090c0;
+ --option: #90b010;
+ --raw-data: #8be9fd;
+
+ --clipboard-image-normal: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' style='color: lightgray' fill='none' viewBox='0 0 24 24' stroke='currentColor'%3E %3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2' /%3E %3C/svg%3E");
+ --clipboard-image-selected: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' style='color: lightgray' viewBox='0 0 20 20' fill='currentColor'%3E %3Cpath d='M8 3a1 1 0 011-1h2a1 1 0 110 2H9a1 1 0 01-1-1z' /%3E %3Cpath d='M6 3a2 2 0 00-2 2v11a2 2 0 002 2h8a2 2 0 002-2V5a2 2 0 00-2-2 3 3 0 01-3 3H9a3 3 0 01-3-3z' /%3E %3C/svg%3E");
+ --clipboard-image: var(--clipboard-image-normal);
+ }
}
-.slider.round:before {
- border-radius: 50%;
+.theme-select-wrapper {
+ display: flex;
+ align-items: center;
}
html {
@@ -176,7 +158,9 @@ body {
height: 100vh;
position: sticky;
top: 0px;
- overflow-y: auto; }
+ overflow-y: auto;
+ padding: 2px;
+}
.nine.columns {
width: 75.0%;
diff --git a/nimdoc/rst2html/expected/rst_examples.html b/nimdoc/rst2html/expected/rst_examples.html
index efc8ac414f895..9debd16ac021f 100644
--- a/nimdoc/rst2html/expected/rst_examples.html
+++ b/nimdoc/rst2html/expected/rst_examples.html
@@ -27,12 +27,13 @@
Not a Nim Manual
-
-
-
Dark Mode
+
+
+
diff --git a/nimdoc/test_out_index_dot_html/expected/index.html b/nimdoc/test_out_index_dot_html/expected/index.html
index d97f7092a6489..50a18bdae9b3a 100644
--- a/nimdoc/test_out_index_dot_html/expected/index.html
+++ b/nimdoc/test_out_index_dot_html/expected/index.html
@@ -27,12 +27,13 @@
nimdoc/test_out_index_dot_html/foo
-
-
-
Dark Mode
+
+
+
diff --git a/nimdoc/testproject/expected/nimdoc.out.css b/nimdoc/testproject/expected/nimdoc.out.css
index e72c4a213c971..f924f5a36f711 100644
--- a/nimdoc/testproject/expected/nimdoc.out.css
+++ b/nimdoc/testproject/expected/nimdoc.out.css
@@ -78,63 +78,45 @@ Modified by Boyd Greenfield and narimiran
--clipboard-image: var(--clipboard-image-normal);
}
-.theme-switch-wrapper {
- display: flex;
- align-items: center;
-}
-
-.theme-switch-wrapper em {
- margin-left: 10px;
- font-size: 1rem;
-}
-
-.theme-switch {
- display: inline-block;
- height: 22px;
- position: relative;
- width: 50px;
-}
-
-.theme-switch input {
- display: none;
-}
-
-.slider {
- background-color: #ccc;
- bottom: 0;
- cursor: pointer;
- left: 0;
- position: absolute;
- right: 0;
- top: 0;
- transition: .4s;
-}
-
-.slider:before {
- background-color: #fff;
- bottom: 4px;
- content: "";
- height: 13px;
- left: 4px;
- position: absolute;
- transition: .4s;
- width: 13px;
-}
-
-input:checked + .slider {
- background-color: #66bb6a;
-}
-
-input:checked + .slider:before {
- transform: translateX(26px);
-}
-
-.slider.round {
- border-radius: 17px;
+@media (prefers-color-scheme: dark) {
+ [data-theme="auto"] {
+ --primary-background: #171921;
+ --secondary-background: #1e202a;
+ --third-background: #2b2e3b;
+ --info-background: #008000;
+ --warning-background: #807000;
+ --error-background: #c03000;
+ --border: #0e1014;
+ --text: #fff;
+ --anchor: #8be9fd;
+ --anchor-focus: #8be9fd;
+ --input-focus: #8be9fd;
+ --strong: #bd93f9;
+ --hint: #7A7C85;
+ --nim-sprite-base64: url("");
+
+ --keyword: #ff79c6;
+ --identifier: #f8f8f2;
+ --comment: #6272a4;
+ --operator: #ff79c6;
+ --punctuation: #f8f8f2;
+ --other: #f8f8f2;
+ --escapeSequence: #bd93f9;
+ --number: #bd93f9;
+ --literal: #f1fa8c;
+ --program: #9090c0;
+ --option: #90b010;
+ --raw-data: #8be9fd;
+
+ --clipboard-image-normal: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' style='color: lightgray' fill='none' viewBox='0 0 24 24' stroke='currentColor'%3E %3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2' /%3E %3C/svg%3E");
+ --clipboard-image-selected: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' style='color: lightgray' viewBox='0 0 20 20' fill='currentColor'%3E %3Cpath d='M8 3a1 1 0 011-1h2a1 1 0 110 2H9a1 1 0 01-1-1z' /%3E %3Cpath d='M6 3a2 2 0 00-2 2v11a2 2 0 002 2h8a2 2 0 002-2V5a2 2 0 00-2-2 3 3 0 01-3 3H9a3 3 0 01-3-3z' /%3E %3C/svg%3E");
+ --clipboard-image: var(--clipboard-image-normal);
+ }
}
-.slider.round:before {
- border-radius: 50%;
+.theme-select-wrapper {
+ display: flex;
+ align-items: center;
}
html {
@@ -176,7 +158,9 @@ body {
height: 100vh;
position: sticky;
top: 0px;
- overflow-y: auto; }
+ overflow-y: auto;
+ padding: 2px;
+}
.nine.columns {
width: 75.0%;
diff --git a/nimdoc/testproject/expected/subdir/subdir_b/utils.html b/nimdoc/testproject/expected/subdir/subdir_b/utils.html
index c42f185905f84..b3d52c4f5daf1 100644
--- a/nimdoc/testproject/expected/subdir/subdir_b/utils.html
+++ b/nimdoc/testproject/expected/subdir/subdir_b/utils.html
@@ -27,12 +27,13 @@
subdir/subdir_b/utils
-
-
-
Dark Mode
+
+
+
diff --git a/nimdoc/testproject/expected/testproject.html b/nimdoc/testproject/expected/testproject.html
index e18625222e133..ea0269710e033 100644
--- a/nimdoc/testproject/expected/testproject.html
+++ b/nimdoc/testproject/expected/testproject.html
@@ -27,12 +27,13 @@
testproject
-
-
-
Dark Mode
+
+
+
diff --git a/tools/dochack/dochack.nim b/tools/dochack/dochack.nim
index c7b8232efbccb..5ba42e9c116f5 100644
--- a/tools/dochack/dochack.nim
+++ b/tools/dochack/dochack.nim
@@ -2,16 +2,19 @@ import dom
import fuzzysearch
-proc switchTheme(event: Event) =
- if event.target.checked:
- document.documentElement.setAttribute("data-theme", "dark")
- window.localStorage.setItem("theme", "dark")
- else:
- document.documentElement.setAttribute("data-theme", "light")
- window.localStorage.setItem("theme", "light")
+proc setTheme(theme: cstring) {.exportc.} =
+ document.documentElement.setAttribute("data-theme", theme)
+ window.localStorage.setItem("theme", theme)
+
+# set `data-theme` attribute early to prevent white flash
+setTheme:
+ let t = window.localStorage.getItem("theme")
+ if t.isNil: cstring"auto" else: t
+proc onDOMLoaded(e: Event) {.exportc.} =
+ # set theme select value
+ document.getElementById("theme-select").value = window.localStorage.getItem("theme")
-proc nimThemeSwitch(event: Event) {.exportC.} =
var pragmaDots = document.getElementsByClassName("pragmadots")
for i in 0.. 0:
- document.documentElement.setAttribute("data-theme", currentTheme);
-
- if currentTheme == "dark" and toggleSwitch != nil:
- toggleSwitch.checked = true
-proc textContent(e: Element): cstring {.
- importcpp: "#.textContent", nodecl.}
+proc textContent(e: Element): cstring {.importcpp: "#.textContent", nodecl.}
-proc textContent(e: Node): cstring {.
- importcpp: "#.textContent", nodecl.}
+proc textContent(e: Node): cstring {.importcpp: "#.textContent", nodecl.}
proc tree(tag: string; kids: varargs[Element]): Element =
result = document.createElement tag
@@ -431,4 +419,4 @@ proc copyToClipboard*() {.exportc.} =
.}
copyToClipboard()
-window.addEventListener("DOMContentLoaded", nimThemeSwitch)
\ No newline at end of file
+window.addEventListener("DOMContentLoaded", onDOMLoaded)