add base structure
This commit is contained in:
		
							
								
								
									
										26
									
								
								assets/darkmode.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								assets/darkmode.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| // Darkmode toggle | ||||
| const toggleSwitch = document.querySelector('#darkmode-toggle') | ||||
|  | ||||
| const userPref = window.matchMedia('(prefers-color-scheme: light)').matches ? 'light' : 'dark' | ||||
| const currentTheme = localStorage.getItem('theme') ?? userPref | ||||
|  | ||||
| if (currentTheme) { | ||||
|   document.documentElement.setAttribute('saved-theme', currentTheme); | ||||
|   if (currentTheme === 'dark') { | ||||
|     toggleSwitch.checked = true | ||||
|   } | ||||
| } | ||||
|  | ||||
| const switchTheme = (e) => { | ||||
|   if (e.target.checked) { | ||||
|     document.documentElement.setAttribute('saved-theme', 'dark') | ||||
|     localStorage.setItem('theme', 'dark') | ||||
|   } | ||||
|   else { | ||||
|     document.documentElement.setAttribute('saved-theme', 'light') | ||||
|     localStorage.setItem('theme', 'light') | ||||
|   } | ||||
| } | ||||
|  | ||||
| // listen for toggle | ||||
| toggleSwitch.addEventListener('change', switchTheme, false) | ||||
							
								
								
									
										67
									
								
								assets/darkmode.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								assets/darkmode.scss
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | ||||
|  | ||||
| .darkmode { | ||||
|   text-align: right; | ||||
|  | ||||
|   & > .toggle { | ||||
|     display: none; | ||||
|     box-sizing: border-box; | ||||
|  | ||||
|     &:checked + .toggle-button:after { | ||||
|       left: 50%; | ||||
|     } | ||||
|  | ||||
|     & + .toggle-button { | ||||
|       box-sizing: border-box; | ||||
|       outline: 0; | ||||
|       display: inline-block; | ||||
|       width: 3em; | ||||
|       height: 1.5em; | ||||
|       position: relative; | ||||
|       cursor: pointer; | ||||
|       border: 2px solid var(--gray); | ||||
|       user-select: none; | ||||
|       padding: 2px; | ||||
|       transition: all 0.2s ease; | ||||
|       border-radius: 2em; | ||||
|  | ||||
|       &:after, &:before { | ||||
|         position: relative; | ||||
|         display: block; | ||||
|         box-sizing: border-box; | ||||
|         content: ""; | ||||
|         width: 50%; | ||||
|         height: 100%; | ||||
|       } | ||||
|  | ||||
|       &:before { | ||||
|         display: none; | ||||
|       } | ||||
|  | ||||
|       &:after { | ||||
|         left: 0; | ||||
|         transition: all 0.2s ease; | ||||
|         background: var(--gray); | ||||
|         content: ""; | ||||
|         border-radius: 1em; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   & #dayIcon { | ||||
|     position: relative; | ||||
|     width: 20px; | ||||
|     height: 20px; | ||||
|     top: -1.5px; | ||||
|     margin: 0 7px; | ||||
|     fill: var(--gray); | ||||
|   } | ||||
|  | ||||
|   & #nightIcon { | ||||
|     position: relative; | ||||
|     width: 18px; | ||||
|     height: 18px; | ||||
|     top: -2px; | ||||
|     margin: 0 7px; | ||||
|     fill: var(--gray); | ||||
|   } | ||||
| } | ||||
							
								
								
									
										99
									
								
								assets/syntax.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								assets/syntax.scss
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,99 @@ | ||||
| /* Background */ .chroma { color: #f8f8f2; background-color: #282a36 } | ||||
| /* Other */ .chroma .x {  } | ||||
| /* Error */ .chroma .err {  } | ||||
| /* LineTableTD */ .chroma .lntd { vertical-align: top; padding: 0; margin: 0; border: 0; } | ||||
| /* LineTable */ .chroma .lntable { border-spacing: 0; padding: 0; margin: 0; border: 0; width: auto; overflow: auto; display: block; } | ||||
| /* LineHighlight */ .chroma .hl { display: block; width: 100%;background-color: #ffffcc } | ||||
| /* LineNumbersTable */ .chroma .lnt { margin-right: 0.4em; padding: 0 0.4em 0 0.4em;color: #7f7f7f } | ||||
| /* LineNumbers */ .chroma .ln { margin-right: 0.4em; padding: 0 0.4em 0 0.4em;color: #7f7f7f } | ||||
| /* Keyword */ .chroma .k { color: #ff79c6 } | ||||
| /* KeywordConstant */ .chroma .kc { color: #ff79c6 } | ||||
| /* KeywordDeclaration */ .chroma .kd { color: #8be9fd; font-style: italic } | ||||
| /* KeywordNamespace */ .chroma .kn { color: #ff79c6 } | ||||
| /* KeywordPseudo */ .chroma .kp { color: #ff79c6 } | ||||
| /* KeywordReserved */ .chroma .kr { color: #ff79c6 } | ||||
| /* KeywordType */ .chroma .kt { color: #8be9fd } | ||||
| /* Name */ .chroma .n {  } | ||||
| /* NameAttribute */ .chroma .na { color: #50fa7b } | ||||
| /* NameBuiltin */ .chroma .nb { color: #8be9fd; font-style: italic } | ||||
| /* NameBuiltinPseudo */ .chroma .bp {  } | ||||
| /* NameClass */ .chroma .nc { color: #50fa7b } | ||||
| /* NameConstant */ .chroma .no {  } | ||||
| /* NameDecorator */ .chroma .nd {  } | ||||
| /* NameEntity */ .chroma .ni {  } | ||||
| /* NameException */ .chroma .ne {  } | ||||
| /* NameFunction */ .chroma .nf { color: #50fa7b } | ||||
| /* NameFunctionMagic */ .chroma .fm {  } | ||||
| /* NameLabel */ .chroma .nl { color: #8be9fd; font-style: italic } | ||||
| /* NameNamespace */ .chroma .nn {  } | ||||
| /* NameOther */ .chroma .nx {  } | ||||
| /* NameProperty */ .chroma .py {  } | ||||
| /* NameTag */ .chroma .nt { color: #ff79c6 } | ||||
| /* NameVariable */ .chroma .nv { color: #8be9fd; font-style: italic } | ||||
| /* NameVariableClass */ .chroma .vc { color: #8be9fd; font-style: italic } | ||||
| /* NameVariableGlobal */ .chroma .vg { color: #8be9fd; font-style: italic } | ||||
| /* NameVariableInstance */ .chroma .vi { color: #8be9fd; font-style: italic } | ||||
| /* NameVariableMagic */ .chroma .vm {  } | ||||
| /* Literal */ .chroma .l {  } | ||||
| /* LiteralDate */ .chroma .ld {  } | ||||
| /* LiteralString */ .chroma .s { color: #f1fa8c } | ||||
| /* LiteralStringAffix */ .chroma .sa { color: #f1fa8c } | ||||
| /* LiteralStringBacktick */ .chroma .sb { color: #f1fa8c } | ||||
| /* LiteralStringChar */ .chroma .sc { color: #f1fa8c } | ||||
| /* LiteralStringDelimiter */ .chroma .dl { color: #f1fa8c } | ||||
| /* LiteralStringDoc */ .chroma .sd { color: #f1fa8c } | ||||
| /* LiteralStringDouble */ .chroma .s2 { color: #f1fa8c } | ||||
| /* LiteralStringEscape */ .chroma .se { color: #f1fa8c } | ||||
| /* LiteralStringHeredoc */ .chroma .sh { color: #f1fa8c } | ||||
| /* LiteralStringInterpol */ .chroma .si { color: #f1fa8c } | ||||
| /* LiteralStringOther */ .chroma .sx { color: #f1fa8c } | ||||
| /* LiteralStringRegex */ .chroma .sr { color: #f1fa8c } | ||||
| /* LiteralStringSingle */ .chroma .s1 { color: #f1fa8c } | ||||
| /* LiteralStringSymbol */ .chroma .ss { color: #f1fa8c } | ||||
| /* LiteralNumber */ .chroma .m { color: #bd93f9 } | ||||
| /* LiteralNumberBin */ .chroma .mb { color: #bd93f9 } | ||||
| /* LiteralNumberFloat */ .chroma .mf { color: #bd93f9 } | ||||
| /* LiteralNumberHex */ .chroma .mh { color: #bd93f9 } | ||||
| /* LiteralNumberInteger */ .chroma .mi { color: #bd93f9 } | ||||
| /* LiteralNumberIntegerLong */ .chroma .il { color: #bd93f9 } | ||||
| /* LiteralNumberOct */ .chroma .mo { color: #bd93f9 } | ||||
| /* Operator */ .chroma .o { color: #ff79c6 } | ||||
| /* OperatorWord */ .chroma .ow { color: #ff79c6 } | ||||
| /* Punctuation */ .chroma .p {  } | ||||
| /* Comment */ .chroma .c { color: #6272a4 } | ||||
| /* CommentHashbang */ .chroma .ch { color: #6272a4 } | ||||
| /* CommentMultiline */ .chroma .cm { color: #6272a4 } | ||||
| /* CommentSingle */ .chroma .c1 { color: #6272a4 } | ||||
| /* CommentSpecial */ .chroma .cs { color: #6272a4 } | ||||
| /* CommentPreproc */ .chroma .cp { color: #ff79c6 } | ||||
| /* CommentPreprocFile */ .chroma .cpf { color: #ff79c6 } | ||||
| /* Generic */ .chroma .g {  } | ||||
| /* GenericDeleted */ .chroma .gd { color: #8b080b } | ||||
| /* GenericEmph */ .chroma .ge { text-decoration: underline } | ||||
| /* GenericError */ .chroma .gr {  } | ||||
| /* GenericHeading */ .chroma .gh { font-weight: bold } | ||||
| /* GenericInserted */ .chroma .gi { font-weight: bold } | ||||
| /* GenericOutput */ .chroma .go { color: #44475a } | ||||
| /* GenericPrompt */ .chroma .gp {  } | ||||
| /* GenericStrong */ .chroma .gs {  } | ||||
| /* GenericSubheading */ .chroma .gu { font-weight: bold } | ||||
| /* GenericTraceback */ .chroma .gt {  } | ||||
| /* GenericUnderline */ .chroma .gl { text-decoration: underline } | ||||
| /* TextWhitespace */ .chroma .w {  } | ||||
|  | ||||
| .lntd:first-of-type > .chroma { | ||||
|   padding-right: 0; | ||||
| } | ||||
|  | ||||
| .chroma code { | ||||
|   font-family: 'Fira Code' !important; | ||||
|   font-size: 0.85em; | ||||
|   line-height: 1em; | ||||
|   background: none; | ||||
|   padding: 0; | ||||
| } | ||||
|  | ||||
| .chroma { | ||||
|   border-radius: 3px; | ||||
|   margin: 0; | ||||
| } | ||||
		Reference in New Issue
	
	Block a user