mirror of
				https://github.com/zadam/trilium.git
				synced 2025-10-26 15:56:29 +01:00 
			
		
		
		
	feat(share): automatic light/dark mode
This commit is contained in:
		| @@ -1,32 +1,26 @@ | ||||
| const preference = localStorage.getItem("theme"); | ||||
| if (preference) { | ||||
|     if (preference === "dark") { | ||||
| const prefersDark = localStorage.getItem("theme") === "dark" || (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches); | ||||
| if (prefersDark) { | ||||
|     document.body.classList.add("theme-dark"); | ||||
|     document.body.classList.remove("theme-light"); | ||||
|     } | ||||
|     else { | ||||
| } else { | ||||
|     document.body.classList.remove("theme-dark"); | ||||
|     document.body.classList.add("theme-light"); | ||||
|     } | ||||
| } | ||||
|  | ||||
| export default function setupThemeSelector() { | ||||
|     const themeSwitch: HTMLInputElement = document.querySelector(".theme-selection input")!; | ||||
|  | ||||
|     if (preference) { | ||||
|     const themeSelection: HTMLDivElement = document.querySelector(".theme-selection")!; | ||||
|     themeSelection.classList.add("no-transition"); | ||||
|         themeSwitch.checked = preference === "dark"; | ||||
|     themeSwitch.checked = prefersDark; | ||||
|     setTimeout(() => themeSelection.classList.remove("no-transition"), 400); | ||||
|     } | ||||
|  | ||||
|     themeSwitch?.addEventListener("change", () => { | ||||
|         if (themeSwitch.checked) { | ||||
|             document.body.classList.add("theme-dark"); | ||||
|             document.body.classList.remove("theme-light"); | ||||
|             localStorage.setItem("theme", "dark"); | ||||
|         } | ||||
|         else { | ||||
|         } else { | ||||
|             document.body.classList.remove("theme-dark"); | ||||
|             document.body.classList.add("theme-light"); | ||||
|             localStorage.setItem("theme", "light"); | ||||
|   | ||||
| @@ -106,19 +106,6 @@ content = content.replaceAll(headingRe, (...match) => { | ||||
| }); | ||||
| %> | ||||
| <body data-note-id="<%= note.noteId %>" class="type-<%= note.type %><%= themeClass %>" data-ancestor-note-id="<%= subRoot.note.noteId %>"> | ||||
|     <script> | ||||
|     const preference = localStorage.getItem("theme"); | ||||
|     if (preference) { | ||||
|         if (preference === "dark") { | ||||
|             document.body.classList.add("theme-dark"); | ||||
|             document.body.classList.remove("theme-light"); | ||||
|         } | ||||
|         else { | ||||
|             document.body.classList.remove("theme-dark"); | ||||
|             document.body.classList.add("theme-light"); | ||||
|         } | ||||
|     } | ||||
|     </script> | ||||
| <div id="mobile-header"> | ||||
|     <a href="<%= shareRootLink %>"> | ||||
|             <img src="<%= logoUrl %>" width="32" height="<%= mobileLogoHeight %>" alt="Logo" /> | ||||
|   | ||||
							
								
								
									
										17
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										17
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							| @@ -198,6 +198,9 @@ importers: | ||||
|       '@triliumnext/highlightjs': | ||||
|         specifier: workspace:* | ||||
|         version: link:../../packages/highlightjs | ||||
|       '@triliumnext/share-theme': | ||||
|         specifier: workspace:* | ||||
|         version: link:../../packages/share-theme | ||||
|       autocomplete.js: | ||||
|         specifier: 0.38.1 | ||||
|         version: 0.38.1 | ||||
| @@ -1279,9 +1282,6 @@ importers: | ||||
|       '@digitak/esrun': | ||||
|         specifier: ^3.2.24 | ||||
|         version: 3.2.26 | ||||
|       '@digitalmaas/esbuild-plugin-ejs': | ||||
|         specifier: 1.0.0 | ||||
|         version: 1.0.0(esbuild@0.25.5) | ||||
|       '@types/swagger-ui': | ||||
|         specifier: ^3.52.0 | ||||
|         version: 3.52.4 | ||||
| @@ -2326,12 +2326,6 @@ packages: | ||||
|   '@digitak/grubber@3.1.4': | ||||
|     resolution: {integrity: sha512-pqsnp2BUYlDoTXWG34HWgEJse/Eo1okRgNex8IG84wHrJp8h3SakeR5WhB4VxSA2+/D+frNYJ0ch3yXzsfNDoA==} | ||||
|  | ||||
|   '@digitalmaas/esbuild-plugin-ejs@1.0.0': | ||||
|     resolution: {integrity: sha512-R6FHotduWyXExphqMJuv0CK42ZCt5Z+gZATFOXvL/lVHLyRVRdTlZqvKyP6DRCQVGz9ecYpk++AWhRzkNODKwQ==} | ||||
|     engines: {node: '>=14'} | ||||
|     peerDependencies: | ||||
|       esbuild: '>=0.25.0' | ||||
|  | ||||
|   '@dual-bundle/import-meta-resolve@4.1.0': | ||||
|     resolution: {integrity: sha512-+nxncfwHM5SgAtrVzgpzJOI1ol0PkumhVo469KCf9lUi21IGcY90G98VuHm9VRrUypmAzawAHO9bs6hqeADaVg==} | ||||
|  | ||||
| @@ -14968,11 +14962,6 @@ snapshots: | ||||
|  | ||||
|   '@digitak/grubber@3.1.4': {} | ||||
|  | ||||
|   '@digitalmaas/esbuild-plugin-ejs@1.0.0(esbuild@0.25.5)': | ||||
|     dependencies: | ||||
|       ejs: 3.1.10 | ||||
|       esbuild: 0.25.5 | ||||
|  | ||||
|   '@dual-bundle/import-meta-resolve@4.1.0': {} | ||||
|  | ||||
|   '@electron-forge/cli@7.8.1(encoding@0.1.13)': | ||||
|   | ||||
		Reference in New Issue
	
	Block a user