feat(theme): Add dark theme
Add a new stylesheet which overrides the css variables in the core stylesheet to obtain a dark theme
This commit is contained in:
parent
2cf2191f0f
commit
1b5292a7f0
20
index.html
20
index.html
@ -23,6 +23,10 @@
|
||||
<input type="checkbox" id="input-large-data" />
|
||||
<span>Large Data</span>
|
||||
</label>
|
||||
<label>
|
||||
<input type="checkbox" id="dark-theme" />
|
||||
<span>Dark Theme</span>
|
||||
</label>
|
||||
<section style="font-size: 12px; width: 60%; margin: 0 auto;">
|
||||
|
||||
</section>
|
||||
@ -48,6 +52,22 @@
|
||||
makeDatatable();
|
||||
});
|
||||
|
||||
document.querySelector('#dark-theme').addEventListener('change', (e) => {
|
||||
const enabled = document.querySelector('#dark-theme:checked');
|
||||
if (enabled) {
|
||||
const link = document.createElement('link');
|
||||
link.href = 'src/dark.css';
|
||||
link.rel = 'stylesheet'
|
||||
link.id = 'dark-theme-stylesheet'
|
||||
document.head.appendChild(link);
|
||||
|
||||
link.onload = () => datatable.setDimensions()
|
||||
} else {
|
||||
document.getElementById('dark-theme-stylesheet').remove();
|
||||
setTimeout(() => datatable.setDimensions())
|
||||
}
|
||||
})
|
||||
|
||||
function buildData() {
|
||||
columns = [
|
||||
{ name: "Name" },
|
||||
|
||||
17
src/dark.css
Normal file
17
src/dark.css
Normal file
@ -0,0 +1,17 @@
|
||||
.datatable {
|
||||
--border-color: #424242;
|
||||
--light-bg: #2e3538;
|
||||
--text-color: #dfe2e5;
|
||||
--text-light: #dfe2e5;
|
||||
--cell-bg: #1c1f20;
|
||||
--focus-border-width: 1px;
|
||||
--selection-highlight-color: var(--light-bg);
|
||||
}
|
||||
|
||||
.dt-header .dt-cell:not(.dt-cell--highlight) {
|
||||
background-color: #262c2e;
|
||||
}
|
||||
|
||||
.dt-toast__message {
|
||||
border: 1px solid var(--border-color);
|
||||
}
|
||||
@ -1,4 +1,4 @@
|
||||
:root {
|
||||
.datatable {
|
||||
--border-color: #d1d8dd;
|
||||
--primary-color: rgb(82, 146, 247);
|
||||
--light-bg: #f5f7fa;
|
||||
@ -15,6 +15,8 @@
|
||||
--border-radius: 3px;
|
||||
|
||||
--cell-bg: #fff;
|
||||
--focus-border-width: 2px;
|
||||
--selection-highlight-color: var(--light-yellow);
|
||||
}
|
||||
|
||||
.datatable {
|
||||
@ -35,7 +37,6 @@
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
background-color: var(--cell-bg);
|
||||
}
|
||||
|
||||
.dt-body {
|
||||
@ -48,7 +49,7 @@
|
||||
border-bottom: 1px solid var(--border-color);
|
||||
|
||||
&--highlight-all {
|
||||
background-color: var(--light-yellow);
|
||||
background-color: var(--selection-highlight-color);
|
||||
}
|
||||
|
||||
&__no-data {
|
||||
@ -60,11 +61,11 @@
|
||||
}
|
||||
|
||||
.dt-row {
|
||||
&--highlight {
|
||||
background-color: var(--light-yellow);
|
||||
&--highlight .dt-cell {
|
||||
background-color: var(--selection-highlight-color);
|
||||
}
|
||||
|
||||
&--unhighlight {
|
||||
&--unhighlight .dt-cell {
|
||||
background-color: var(--cell-bg);
|
||||
}
|
||||
|
||||
@ -78,10 +79,12 @@
|
||||
position: relative;
|
||||
outline: none;
|
||||
padding: 0;
|
||||
background-color: var(--cell-bg);
|
||||
color: var(--text-color);
|
||||
|
||||
&__content {
|
||||
padding: var(--spacer-2);
|
||||
border: 2px solid transparent;
|
||||
border: var(--focus-border-width) solid transparent;
|
||||
height: 100%;
|
||||
user-select: none;
|
||||
text-overflow: ellipsis;
|
||||
@ -93,7 +96,7 @@
|
||||
display: none;
|
||||
padding: var(--spacer-2);
|
||||
background-color: var(--cell-bg);
|
||||
border: 2px solid var(--orange);
|
||||
border: var(--focus-border-width) solid var(--orange);
|
||||
z-index: 1;
|
||||
height: 100%;
|
||||
}
|
||||
@ -225,6 +228,8 @@
|
||||
font-family: inherit;
|
||||
font-size: inherit;
|
||||
line-height: inherit;
|
||||
background-color: inherit;
|
||||
color: inherit;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user