Add one dark theme (#6324)

Adds a new theme based on the One Dark theme from the Atom text editor.
Adds a new line highlighting theme "Soft Dark Rainbow" that works better
with the One Dark theme.
This commit is contained in:
Matthew Guidry
2024-04-06 23:30:39 -05:00
committed by GitHub
parent 5738ed00e7
commit 102b253f57
7 changed files with 1165 additions and 4 deletions

View File

@@ -145,3 +145,4 @@ From oldest to newest contributor, we would like to thank:
- [Julian van Doorn](https://github.com/JulianvDoorn)
- [Andrea Tomasi](https://github.com/treere)
- [Khyber Sen](https://github.com/kkysen)
- [Matthew Guidry](https://github.com/mguid65)

View File

@@ -25,7 +25,15 @@
import * as monaco from 'monaco-editor';
import {Themes} from './themes.js';
export type ColourScheme = 'rainbow' | 'rainbow2' | 'earth' | 'green-blue' | 'gray-shade' | 'rainbow-dark' | 'pink';
export type ColourScheme =
| 'rainbow'
| 'rainbow2'
| 'earth'
| 'green-blue'
| 'gray-shade'
| 'rainbow-dark'
| 'soft-rainbow-dark'
| 'pink';
export type AppTheme = Themes | 'all';
@@ -56,13 +64,19 @@ export const schemes: ColourSchemeInfo[] = [
name: 'gray-shade',
desc: 'Gray shades',
count: 4,
themes: ['dark', 'darkplus', 'real-dark'],
themes: ['dark', 'darkplus', 'real-dark', 'onedark'],
},
{
name: 'rainbow-dark',
desc: 'Dark Rainbow',
count: 12,
themes: ['dark', 'darkplus', 'real-dark'],
themes: ['dark', 'darkplus', 'real-dark', 'onedark'],
},
{
name: 'soft-rainbow-dark',
desc: 'Soft Dark Rainbow',
count: 11,
themes: ['dark', 'darkplus', 'real-dark', 'onedark'],
},
{
name: 'pink',

View File

@@ -219,6 +219,51 @@
background: rgba(105, 94, 7, 0.35);
}
/*soft rainbow dark*/
.soft-rainbow-dark-0 {
background: rgba(79, 140, 135, 0.15);
}
.soft-rainbow-dark-1 {
background: rgba(160, 160, 49, 0.15);
}
.soft-rainbow-dark-2 {
background: rgba(80, 80, 183, 0.15);
}
.soft-rainbow-dark-3 {
background: rgba(162, 50, 24, 0.15);
}
.soft-rainbow-dark-4 {
background: rgba(51, 122, 173, 0.15);
}
.soft-rainbow-dark-5 {
background: rgba(186, 136, 23, 0.15);
}
.soft-rainbow-dark-6 {
background: rgba(125, 178, 70, 0.15);
}
.soft-rainbow-dark-7 {
background: rgba(165, 60, 109, 0.15);
}
.soft-rainbow-dark-8 {
background: rgba(125, 88, 88, 0.15);
}
.soft-rainbow-dark-9 {
background: rgba(120, 42, 151, 0.15);
}
.soft-rainbow-dark-10 {
background: rgba(47, 120, 35, 0.15);
}
/* Gray shades */
/*@for $i from 0 through 4 {
.pink- hashtag {$i} {

View File

@@ -1145,6 +1145,14 @@ html[data-theme='pink'] {
}
}
html[data-theme='one-dark'] {
@import 'themes/one-dark-theme';
background-color: $light !important;
.theme-dark-only {
display: inline;
}
}
.socialsharing {
max-width: 250px;
}

View File

@@ -0,0 +1,247 @@
// based on pink.scss
$lightest: #444b53;
$lighter: #3d424d;
$light: #2c313c;
$base: #282c34;
$dark: #21252b;
$darker: #1e1f22;
// Color variables (appears count calculates by raw css)
$color0: $dark; // Appears 7 times
$color1: $base; // Appears 3 times
$color2: #e06c75; // Appears 2 times
$color3: #98c379; // Appears 2 times
$color4: #d19a66; // Appears 1 time
$color5: #61afef; // Appears 1 time
$color6: #c678dd; // Appears 1 time
$color7: #56b6c2; // Appears 1 time
$color8: #abb2bf; // Appears 1 time
$color9: #5c6370; // Appears 1 time
$color10: #e06c75; // Appears 2 time
// ".lm_dragging" is applied to BODY tag during Drag and is also directly applied to the root of the object being dragged
// Entire GoldenLayout Container, if a background is set, it is visible as color of "pane header" and "splitters" (if these latest has opacity very low)
.lm_goldenlayout {
background: $color0;
}
// Single Pane content (area in which final dragged content is contained)
.lm_content {
background: $light;
}
// Single Pane content during Drag (style of moving window following mouse)
.lm_dragProxy {
.lm_content {
box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.9);
}
}
// Placeholder Container of target position
.lm_dropTargetIndicator {
box-shadow: inset 0 0 30px $color0;
outline: 1px dashed $color4;
transition: all 200ms ease;
// Inner Placeholder
.lm_inner {
background: $color0;
opacity: 0.2;
}
}
// Separator line (handle to change pane size)
.lm_splitter {
background: $color9;
opacity: 0.001;
transition: opacity 200ms ease;
&:hover, // When hovered by mouse...
&.lm_dragging {
background: $color8;
opacity: 1;
}
}
// Pane Header (container of Tabs for each pane)
.lm_header {
border-top: 2px solid $dark !important;
height: 30px !important;
user-select: none;
&.lm_selectable {
cursor: pointer;
}
// Single Tab container. A single Tab is set for each pane, a group of Tabs are contained in ".lm_header"
.lm_tab {
height: 26px !important;
font-family: Arial, sans-serif;
font-size: 12px;
color: $color8;
background: $base;
margin-top: 0;
margin-right: 0;
padding-top: 0px;
padding-bottom: 0px;
.lm_title {
padding-top: 5px;
}
// Close Tab Icon
.lm_close_tab {
width: 11px;
height: 11px;
background-position: center center;
background-repeat: no-repeat;
top: 8px;
right: 6px;
opacity: 0.4;
&:hover {
opacity: 1;
}
}
// Modify Tab Icon
.lm_modify_tab_title {
width: 11px;
height: 11px;
background-position: center center;
background-repeat: no-repeat;
top: 8px;
opacity: 0.4;
&:hover {
opacity: 1;
}
}
&:hover {
opacity: 1;
border-bottom: 3px solid $lighter;
}
border-bottom: 3px solid $base;
// If Tab is active, so if it's in foreground
&.lm_active {
border-bottom: 3px solid $color5;
}
}
}
.lm_dragProxy.lm_bottom,
.lm_stack.lm_bottom {
.lm_header .lm_tab {
box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.3);
&.lm_active {
box-shadow: 0 2px 2px $color0;
}
}
}
// If Pane Header (container of Tabs for each pane) is selected (used only if addition of new Contents is made "by selection" and not "by drag")
.lm_selected {
.lm_header {
background-color: $dark;
}
}
.lm_tab {
&:hover, // If Tab is hovered
&.lm_active // If Tab is active, so if it's in foreground
{
background: $lighter;
}
}
// Dropdown arrow for additional tabs when too many to be displayed
.lm_header .lm_controls .lm_tabdropdown:before {
color: #f2f2f2;
margin-top: 3px;
}
// Pane controls (popout, maximize, minimize, close)
.lm_controls {
// All Pane controls shares these
> li {
position: relative;
background-position: center center;
background-repeat: no-repeat;
opacity: 0.4;
transition: opacity 300ms ease;
&:hover {
opacity: 1;
}
}
// Icon to PopOut Pane, so move it to a different Browser Window
.lm_popout {
top: 6px;
background-image: url();
}
// Icon to Maximize Pane, so it will fill the entire GoldenLayout Container
.lm_maximise {
top: 6px;
background-image: url();
}
// Icon to Close Pane and so remove it from GoldenLayout Container
.lm_close {
top: 6px;
background-image: url();
}
}
// If a specific Pane is maximized
.lm_maximised {
// Pane Header (container of Tabs for each pane) can have different style when is Maximized
.lm_header {
background-color: $color0;
}
// Pane controls are different in Maximized Mode, especially the old Icon "Maximise" that now has a different meaning, so "Minimize" (even if CSS Class did not change)
.lm_controls {
.lm_maximise {
background-image: url();
}
}
}
.lm_transition_indicator {
background-color: $color0;
border: 1px dashed $color9;
}
// If a specific Pane is Popped Out, so move it to a different Browser Window, Icon to restore original position is:
.lm_popin {
cursor: pointer;
// Background of Icon
.lm_bg {
background: $color10;
opacity: 0.3;
}
// Icon to Restore original position in Golden Layout Container
.lm_icon {
background-image: url();
background-position: center center;
background-repeat: no-repeat;
border-left: 1px solid $color2;
border-top: 1px solid $color2;
opacity: 0.7;
}
&:hover {
.lm_icon {
opacity: 1;
}
}
}

View File

@@ -0,0 +1,714 @@
// based on pink-theme.scss
@import 'custom-golden-layout-themes/one-dark';
$logo-primary: #67c52a;
$logo-secondary: #999999;
$lightest: #444b53;
$lighter: #3d424d;
$light: #2c313c;
$base: #282c34;
$dark: #21252b;
$darker: #1e1f22;
::-webkit-scrollbar {
background: lighten(#333a42, 10%);
}
::-webkit-scrollbar-thumb {
background: lighten(#333a42, 20%);
}
a {
color: #45bbe0 !important;
&.navbar-brand {
img.logo {
&.inverse {
display: block !important;
}
&.normal {
display: none !important;
}
}
}
}
body {
background-color: $base !important;
}
input {
color: #eee !important;
background-color: $lightest;
border: 0 !important;
&:focus {
color: #eee !important;
background-color: $lightest;
border: 0 !important;
}
&.permalink {
color: #eee !important;
background-color: $lightest;
opacity: 1;
}
}
kbd {
border-color: #818181 !important;
}
pre {
color: #f2f2f2 !important;
.content {
background-color: #1e1e1e !important;
.compiling {
background-color: #101010 !important;
}
}
}
select {
color: #000 !important;
}
textarea.form-control {
color: #eee !important;
background-color: $lighter;
border: 0 !important;
}
.argmenuitem {
max-width: 250px;
span {
&.argtitle {
font-weight: bold;
display: block;
overflow-x: hidden;
text-overflow: ellipsis;
}
&.argdescription {
max-height: 150px;
word-wrap: break-word;
overflow-wrap: break-word;
font-style: italic;
font-size: smaller;
display: block;
white-space: normal;
text-overflow: ellipsis;
overflow-y: hidden;
}
}
}
.bg-light {
background-color: $base !important;
}
.bottom-bar {
color: #aaa !important;
background-color: $base !important;
padding-bottom: 7px;
&.bg-light {
border-top: 1px solid $dark;
}
}
.btn-light {
color: #e2e2e2 !important;
background-color: $base !important;
border-color: $base !important;
&.active {
background-color: $darker !important;
color: #fff !important;
&:hover {
background-color: lighten($darker, 5%) !important;
}
}
&:hover {
background-color: $lighter !important;
}
&:disabled,
&:disabled:hover {
background-color: lighten($light, 5%) !important;
color: #eee !important;
}
}
.card {
background-color: $light !important;
color: #f2f2f2 !important;
border-color: $dark;
}
.commit-entry {
&:nth-child(odd) {
background-color: $dark !important;
}
&:nth-child(even) {
background-color: $light !important;
}
}
.community-advert {
color: white;
background: $light !important;
border-color: #006400;
button {
opacity: 1;
color: #006400;
text-shadow: none;
}
}
.conformance-wrapper {
background-color: #1e1e1e !important;
.compiler-list .form-row {
border-bottom: 1px solid #3e3e3e;
}
}
.copy-link-btn:hover {
background-color: $dark !important;
}
.cppi-logo-sec {
fill: #e2e2e2 !important;
}
.currentCursorPosition {
color: white;
background-color: opacify($dark, 0.8);
}
.custom-select {
background-color: #76a1c8 !important;
}
.dropdown-item {
color: #eee !important;
background-color: $base;
&:hover {
color: #fff !important;
background-color: $dark !important;
}
}
.dropdown-menu {
color: #f2f2f2 !important;
background-color: $base !important;
}
.err-count {
color: #e5c07b !important;
}
.execution-stdout {
color: white !important;
}
.fa,
.fas {
color: white;
}
.qb-logo-pri {
fill: #3b3c3e !important;
}
.qb-logo-sec {
fill: #e2e2e2 !important;
}
.float-link {
color: #eee !important;
background-color: rgba(128, 128, 128, 0.5) !important;
&:hover {
background-color: rgba(128, 128, 160, 0.5) !important;
}
}
.flow-decoration {
background-color: #b4131f !important;
color: white !important;
font-weight: bold;
}
.flow-highlight {
background-color: rgba(180, 19, 31, 0.4) !important;
}
.form-control:disabled {
background-color: darken(#474747, 10%);
}
.graph-container {
background: $dark;
.cfg-info {
color: #aaa;
}
.graph .block-container .block {
background: $light;
border: 1px solid white;
color: white;
}
}
.input-group-text {
background-color: #a1a1a1 !important;
border-color: $dark !important;
}
.logo-pri {
fill: $logo-primary !important;
}
.logo-sec {
fill: $logo-secondary !important;
}
#library-selection {
.libs-selected-col button {
color: white;
}
.libs-favorites-col button {
color: white;
}
.libs-results-col .lib-fav-button {
color: white;
}
}
#v-status {
color: #eee !important;
}
.lib-item {
background-color: #333 !important;
}
.linked-code-decoration {
background: #555657 !important;
}
.linked-code-decoration-inline {
background: #444444;
}
.linked-code-decoration-line {
background: lighten($lighter, 5%) !important;
}
.linked-code-decoration-margin {
background: $light !important;
}
.linked-compiler-output-line {
color: #007bfd !important;
}
.linked-code-decoration-column {
font-weight: 600;
color: #44ab40 !important;
}
.lm_controls {
.lm_maximise {
background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 9 9'%3E%3Cpath fill='%23fff' d='M0 4.5V0h9v9H0zM8 5V2H1v6h7z'/%3E%3C/svg%3E") !important;
background-size: 9px !important;
}
.lm_close {
background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 9 9'%3E%3Cpath fill='%23fff' d='M.45713 8.5429l-.44426-.44438 3.5955-3.5956L.00697.90152l.8944-.89463 3.6016 3.6015 3.6014-3.6015.88867.88867-3.6014 3.6015 3.6014 3.6015-.89449.89449-3.6015-3.6014-3.5957 3.5956z'/%3E%3C/svg%3E") !important;
background-size: 9px !important;
}
}
.lm_header {
background-color: $dark !important;
.lm_tab {
/*
* replace low res golden-layout icons with svg recreations to improve high DPI displays
* not all icons in golden-layout are used, so we don't replace all of them
*/
.lm_close_tab {
background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 9 9'%3E%3Cpath fill='%23fff' d='M.45713 8.5429l-.44426-.44438 3.5955-3.5956L.00697.90152l.8944-.89463 3.6016 3.6015 3.6014-3.6015.88867.88867-3.6014 3.6015 3.6014 3.6015-.89449.89449-3.6015-3.6014-3.5957 3.5956z'/%3E%3C/svg%3E") !important;
background-size: 9px !important;
}
.lm_modify_tab_title {
background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' class='bi bi-pencil' viewBox='0 0 16 16'%3E%3Cpath d='M12.146.146a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1 0 .708l-10 10a.5.5 0 0 1-.168.11l-5 2a.5.5 0 0 1-.65-.65l2-5a.5.5 0 0 1 .11-.168l10-10zM11.207 2.5 13.5 4.793 14.793 3.5 12.5 1.207 11.207 2.5zm1.586 3L10.5 3.207 4 9.707V10h.5a.5.5 0 0 1 .5.5v.5h.5a.5.5 0 0 1 .5.5v.5h.293l6.5-6.5zm-9.761 5.175-.106.106-1.528 3.821 3.821-1.528.106-.106A.5.5 0 0 1 5 12.5V12h-.5a.5.5 0 0 1-.5-.5V11h-.5a.5.5 0 0 1-.468-.325z'/%3E%3C/svg%3E") !important;
background-size: 9px !important;
background-repeat: no-repeat;
background-position: center center;
width: 11px;
height: 11px;
position: absolute;
top: 8px;
right: 23px;
}
}
}
.lm_maximised .lm_controls .lm_maximise {
background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 9 9'%3E%3Cpath fill='%23fff' d='M1.0096 8.0019v-.99809h6.9807v1.9962H1.0096z'/%3E%3C/svg%3E") !important;
background-size: 9px !important;
}
.modal-body {
background-color: $base !important;
color: #eee !important;
}
.modal-content {
.well {
background-color: $base !important;
color: #eee !important;
}
.card-body {
background-color: $base !important;
}
}
.modal-footer {
background-color: $base !important;
}
.modal-header {
color: #eee !important;
background-color: $base !important;
.close {
color: #eee;
}
}
.nav.nav-tabs {
li {
a {
color: #eee !important;
background-color: $base !important;
}
}
li:not(.active) {
a {
border-bottom: 1px solid #fff !important;
}
}
li.active {
a {
background-color: #666 !important;
}
}
}
.navbar-light {
background-color: $base !important;
.navbar-nav li {
&:hover {
color: #fff !important;
background-color: $dark !important;
}
a {
color: #fff !important;
&:hover {
color: #fff !important;
background-color: $dark !important;
}
}
}
a.nav-link {
border: rgb(140, 140, 140) 1px solid;
}
.navbar-toggler-icon {
background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3e%3cpath stroke='rgba(255, 255, 255, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}
.navbar-toggler {
color: rgba(255, 255, 255, 0.5);
border-color: rgba(255, 255, 255, 0.1);
}
}
.new-cookie-msg {
color: white;
}
.notification {
background-color: gray !important;
}
.notification-error {
background-color: #aa3333 !important;
color: #fff;
.close {
color: #fff;
}
}
.notification-info {
background-color: #676767 !important;
color: #f2f2f2;
}
.notification-off {
background-color: #222 !important;
color: #fff;
.close {
color: #fff;
}
}
.notification-on {
background-color: #33aa33 !important;
color: black;
}
.opt-decoration {
&.analysis,
&.mixed {
background: #fdfd96 !important;
}
&.passed {
background: #77dd77 !important;
}
&.missed {
background: #ff6961 !important;
}
}
.popover,
.popover-content,
.libs-container,
.lib-list,
.popover-body,
.popover-header {
background-color: $base !important;
color: #f2f2f2 !important;
}
.popular-arguments-btn {
border-color: #474747 !important;
}
.popover .arrow::after,
.popover .arrow::before {
border-left-color: #151515 !important;
border-right-color: #151515 !important;
}
.popover {
border-color: $light !important;
}
.prepend-options {
border-color: $light !important;
background-color: $base !important;
}
.picker-popout-button {
border: none !important;
background: $light !important;
&:hover {
background: darken($light, 5%) !important;
}
}
.qb-logo-pri {
fill: #e2e2e2 !important;
}
.qb-logo-sec {
fill: #333 !important;
}
.rainbow-decoration {
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-image: linear-gradient(
60deg,
#ed4242 0,
#ffaa44 20%,
#fff344 40%,
#43a35b 60%,
#447cff 80%,
#9c44a9 100%
);
}
#renamepanemodal .modal-body {
min-height: 100px;
}
.share-disabled {
color: #333 !important;
}
.share-reddit {
background-color: #ff4500 !important;
color: white !important;
}
.share-twitter {
background-color: #1da1f2 !important;
color: white !important;
}
#simplecook {
background-color: #474747 !important;
}
.text-count {
color: green !important;
}
.top-bar.btn-toolbar.bg-light {
border-top: 2px solid $dark !important;
border-bottom: 2px solid $dark !important;
}
.tree {
ul,
li {
background-color: $dark !important;
color: white;
}
li.tree-editor-file {
background-color: $dark !important;
color: white;
&:hover {
background-color: lighten($base, 5%) !important;
}
}
}
.ts-dropdown {
color: #f2f2f2 !important;
background-color: $base !important;
margin: 0 !important;
.option:hover {
background-color: $lighter;
color: #eee !important;
}
.active {
background-color: $lightest !important;
color: #dddddd !important;
}
.selected {
background-color: #405f9d !important;
color: #dddddd !important;
}
.optgroup-header {
background: $base;
color: #eee !important;
text-shadow: none !important;
}
}
.ts-wrapper.single {
.ts-control {
border: none;
color: #f2f2f2 !important;
background: $light !important;
text-shadow: none !important;
&:after {
border-color: #525252 transparent transparent transparent;
}
&.disabled {
color: #f2f2f2 !important;
background-color: $light !important;
}
}
}
#compiler-picker-modal {
.architecture,
.compiler-type {
background: $base;
&.active {
background: #007bff;
}
}
.compilers-col .group-wrapper .group {
.label {
background: $base;
}
.compiler {
&:hover {
background: $light;
}
&.selected {
background-color: #405f9d !important;
}
}
}
}
#alert {
&.error-alert {
.modal-content {
border: 4px solid #f43636;
}
}
}
.compiler-arg-warning-icon {
color: #ffbf3f !important;
}
.compiler-arg-warning {
border-color: #ffbf3f;
&:before {
border-color: #ffbf3f;
background: #ffbf3f;
}
&.info {
border-color: #3f92ff;
&:before {
border-color: #3f92ff;
background: #3f92ff;
content: '\f05a';
color: rgb(20, 21, 22);
}
}
}

View File

@@ -29,7 +29,7 @@ import GoldenLayout from 'golden-layout';
import {isString} from '../shared/common-utils.js';
import {options} from './options.js';
export type Themes = 'default' | 'dark' | 'darkplus' | 'pink' | 'real-dark' | 'system';
export type Themes = 'default' | 'dark' | 'darkplus' | 'pink' | 'onedark' | 'real-dark' | 'system';
export type Theme = {
path: string;
@@ -75,6 +75,13 @@ export const themes: Record<Themes, Theme> = {
mainColor: '#333333',
monaco: 'ce-dark',
},
onedark: {
path: 'one-dark',
id: 'onedark',
name: 'One Dark',
mainColor: '#282c34',
monaco: 'ce-one-dark',
},
system: {
id: 'system',
name: 'Same as system',
@@ -409,6 +416,131 @@ editor.defineTheme('ce-pink', {
},
});
editor.defineTheme('ce-one-dark', {
base: 'vs-dark',
inherit: true,
rules: [
{
token: 'identifier.definition.herb',
foreground: '61afef',
fontStyle: 'bold',
},
// General Identifiers
{token: 'identifier.cpp', foreground: 'abb2bf'},
// Annotations (includes items in attribute list)
{token: 'annotation.cpp', foreground: 'abb2bf'},
// Keywords
{token: 'keyword.auto.cpp', foreground: 'c678dd'},
{token: 'keyword.break.cpp', foreground: 'c678dd'},
{token: 'keyword.case.cpp', foreground: 'c678dd'},
{token: 'keyword.catch.cpp', foreground: 'c678dd'},
{token: 'keyword.class.cpp', foreground: 'c678dd'},
{token: 'keyword.constexpr.cpp', foreground: 'c678dd'},
{token: 'keyword.continue.cpp', foreground: 'c678dd'},
{token: 'keyword.default.cpp', foreground: 'c678dd'},
{token: 'keyword.delete.cpp', foreground: 'c678dd'},
{token: 'keyword.do.cpp', foreground: 'c678dd'},
{token: 'keyword.else.cpp', foreground: 'c678dd'},
{token: 'keyword.enum.cpp', foreground: 'c678dd'},
{token: 'keyword.explicit.cpp', foreground: 'c678dd'},
{token: 'keyword.export.cpp', foreground: 'c678dd'},
{token: 'keyword.extern.cpp', foreground: 'c678dd'},
{token: 'keyword.final.cpp', foreground: 'c678dd'},
{token: 'keyword.for.cpp', foreground: 'c678dd'},
{token: 'keyword.friend.cpp', foreground: 'c678dd'},
{token: 'keyword.goto.cpp', foreground: 'c678dd'},
{token: 'keyword.if.cpp', foreground: 'c678dd'},
{token: 'keyword.inline.cpp', foreground: 'c678dd'},
{token: 'keyword.mutable.cpp', foreground: 'c678dd'},
{token: 'keyword.namespace.cpp', foreground: 'c678dd'},
{token: 'keyword.new.cpp', foreground: 'c678dd'},
{token: 'keyword.noexcept.cpp', foreground: 'c678dd'},
{token: 'keyword.operator.cpp', foreground: 'c678dd'},
{token: 'keyword.override.cpp', foreground: 'c678dd'},
{token: 'keyword.private.cpp', foreground: 'c678dd'},
{token: 'keyword.protected.cpp', foreground: 'c678dd'},
{token: 'keyword.public.cpp', foreground: 'c678dd'},
{token: 'keyword.return.cpp', foreground: 'c678dd'},
{token: 'keyword.static.cpp', foreground: 'c678dd'},
{token: 'keyword.struct.cpp', foreground: 'c678dd'},
{token: 'keyword.switch.cpp', foreground: 'c678dd'},
{token: 'keyword.template.cpp', foreground: 'c678dd'},
{token: 'keyword.thread_local.cpp', foreground: 'c678dd'},
{token: 'keyword.throw.cpp', foreground: 'c678dd'},
{token: 'keyword.try.cpp', foreground: 'c678dd'},
{token: 'keyword.typedef.cpp', foreground: 'c678dd'},
{token: 'keyword.typename.cpp', foreground: 'c678dd'},
{token: 'keyword.union.cpp', foreground: 'c678dd'},
{token: 'keyword.unsigned.cpp', foreground: 'c678dd'},
{token: 'keyword.using.cpp', foreground: 'c678dd'},
{token: 'keyword.virtual.cpp', foreground: 'c678dd'},
{token: 'keyword.while.cpp', foreground: 'c678dd'},
{token: 'keyword._asm.cpp', foreground: 'c678dd'},
{token: 'keyword.and.cpp', foreground: 'c678dd'},
{token: 'keyword.and_eq.cpp', foreground: 'c678dd'},
{token: 'keyword.bitand.cpp', foreground: 'c678dd'},
{token: 'keyword.bitor.cpp', foreground: 'c678dd'},
{token: 'keyword.compl.cpp', foreground: 'c678dd'},
{token: 'keyword.concept.cpp', foreground: 'c678dd'},
{token: 'keyword.co_await.cpp', foreground: 'c678dd'},
{token: 'keyword.co_return.cpp', foreground: 'c678dd'},
{token: 'keyword.co_yield.cpp', foreground: 'c678dd'},
{token: 'keyword.export.cpp', foreground: 'c678dd'},
{token: 'keyword.import.cpp', foreground: 'c678dd'},
{token: 'keyword.module.cpp', foreground: 'c678dd'},
{token: 'keyword.not.cpp', foreground: 'c678dd'},
{token: 'keyword.not_eq.cpp', foreground: 'c678dd'},
{token: 'keyword.or.cpp', foreground: 'c678dd'},
{token: 'keyword.or_eq.cpp', foreground: 'c678dd'},
{token: 'keyword.requires.cpp', foreground: 'c678dd'},
{token: 'keyword.xor.cpp', foreground: 'c678dd'},
{token: 'keyword.xor_eq.cpp', foreground: 'c678dd'},
// Function-like keywords
{token: 'keyword.static-assert.cpp', foreground: '282c34'},
{token: 'keyword.alignof.cpp', foreground: '282c34'},
{token: 'keyword.typeid.cpp', foreground: '282c34'},
{token: 'keyword.static_cast.cpp', foreground: '282c34'},
{token: 'keyword.sizeof.cpp', foreground: '282c34'},
{token: 'keyword.reinterpret_cast.cpp', foreground: '282c34'},
{token: 'keyword.dynamic_cast.cpp', foreground: '282c34'},
{token: 'keyword.decltype.cpp', foreground: '282c34'},
{token: 'keyword.asm.cpp', foreground: '282c34'},
// Constants and Literals
{token: 'keyword.true.cpp', foreground: 'e5c07b'},
{token: 'keyword.false.cpp', foreground: 'e5c07b'},
{token: 'keyword.nullptr.cpp', foreground: 'e5c07b'},
{token: 'number.cpp', foreground: 'e5c07b'},
{token: 'number.hex.cpp', foreground: 'e5c07b'},
{token: 'number.float.cpp', foreground: 'e5c07b'},
{token: 'number.octal.cpp', foreground: 'e5c07b'},
{token: 'number.binary.cpp', foreground: 'e5c07b'},
{token: 'string.cpp', foreground: '98c379'},
// Other
{token: 'keyword.this.cpp', foreground: 'e06c75'},
{token: 'keyword.directive.include.cpp', foreground: 'c678dd'},
{token: 'keyword.directive.include.begin.cpp', foreground: '98c379'},
{token: 'keyword.directive.include.end.cpp', foreground: '98c379'},
{token: 'entity.name.type.cpp', foreground: 'e5c07b'},
{token: 'string.escape.cpp', foreground: '56b6c2'},
{token: 'string.include.identifier.cpp', foreground: '98c379'},
],
colors: {
'editor.background': '#282c34',
'editor.foreground': '#abb2bf',
// 'editor.lineHighlightBorder': '#e3a5e3',
'editor.lineHighlightBackground': '#2c313c',
'editor.wordHighlightBackground': '#484e5b',
'editor.wordHighlightBorder': '#7f848e',
'editor.wordHighlightStrongBackground': '#abb2bf26',
'editor.wordHighlightStrongBorder': '#7f848e',
'editorHoverWidget.background': '#21252b',
'editorLineNumber.foreground': '#495162',
'editor.selectionBackground': '#67769660',
'editor.inactiveSelectionBackground': '#3a3f4b',
'minimap.selectionHighlight': '#abb2bf',
},
});
export class Themer {
private currentTheme: Theme | null = null;