Mirai
Publisher: Alvaro SantanaThemes in package: 1
Mirai is a simple dark theme for VS Code. Good coding!
Mirai is a simple dark theme for VS Code. Good coding!
Full workbench mockup using this variant's colors and tokenColors.
Loading...
Workbench UI color keys from the theme JSON colors map.
TextMate scopes and font styles (syntax highlighting rules).
| scope | foreground | fontStyle |
|---|---|---|
| comment, punctuation.definition.comment, unused.comment, wildcard.comment | #6272A4 | — |
| source | #F8F8F2 | — |
| punctuation.definition.block, meta.brace.square, meta.brace.round, punctuation.definition.parameters.begin, punctuation.definition.parameters.end, punctuation.definition.binding-pattern.array, punctuation.definition.binding-pattern.object, punctuation.definition.imports.begin.bracket.round, punctuation.definition.imports.end.bracket.round, punctuation.definition.begin.bracket.curly, punctuation.definition.end.bracket.curly, punctuation.definition.begin.bracket.round, punctuation.definition.end.bracket.round, punctuation.definition.bracket.square, punctuation.definition.arguments.begin, punctuation.definition.arguments.end, punctuation.definition.list.begin, punctuation.definition.list.end, punctuation.parenthesis.begin, punctuation.parenthesis.end, punctuation.definition.dict.begin, punctuation.definition.dict.end, punctuation.definition.parameters, punctuation.section.scope.begin, punctuation.section.scope.end, punctuation.section.function, punctuation.section.array.begin, punctuation.section.array.end, punctuation.brackets.curly, punctuation.brackets.round, punctuation.brackets.square, punctuation.section.array, punctuation.section.scope, punctuation.definition.type.begin, punctuation.definition.type.end, punctuation.section.collection-type.begin, punctuation.section.collection-type.end, punctuation.curlybrace.open, punctuation.curlybrace.close, punctuation.parenthesis.open, punctuation.parenthesis.close, punctuation.squarebracket.open, punctuation.squarebracket.close, punctuation.section.property-list.begin.bracket.curly, punctuation.section.property-list.end.bracket.curly, punctuation.section.keyframes.begin.bracket.curly, punctuation.section.keyframes.end.bracket.curly, punctuation.support.type.property-name.begin.json, punctuation.support.type.property-name.end.json | #F8F8F2 | — |
| constant.other.symbol.hashkey punctuation.definition.constant.ruby, entity.other.attribute-name.placeholder punctuation, entity.other.attribute-name.pseudo-class punctuation, entity.other.attribute-name.pseudo-element punctuation, meta.group.double.toml, meta.group.toml, meta.object-binding-pattern-variable punctuation.destructuring, punctuation.colon.graphql, punctuation.definition.block.scalar.folded.yaml, punctuation.definition.block.scalar.literal.yaml, punctuation.definition.block.sequence.item.yaml, punctuation.definition.entity.other.inherited-class, punctuation.function.swift, punctuation.separator.dictionary.key-value, punctuation.separator.hash, punctuation.separator.inheritance, punctuation.separator.key-value, punctuation.separator.key-value.mapping.yaml, punctuation.separator.namespace, punctuation.separator.pointer-access, punctuation.separator.slice, string.unquoted.heredoc punctuation.definition.string, support.other.chomping-indicator.yaml, punctuation.separator.annotation | #A978FF | — |
| punctuation.separator.comma, punctuation.terminator.statement, punctuation.separator.parameter, punctuation.separator.arguments, punctuation.separator.parameters, punctuation.separator.element, invalid.deprecated.semicolon, punctuation.separator.object, punctuation.separator.statement, punctuation.comma, punctuation.semi, punctuation.terminator.rule, punctuation.definition.pseudo-class.begin.bracket.round, punctuation.definition.pseudo-class.end.bracket.round, punctuation.separator.list.comma, punctuation.other.comma, punctuation.terminator | #F8F8F2 | — |
| punctuation.definition.attribute, punctuation.definition.block.tag, punctuation.definition.interpolation.begin.bracket.curly, punctuation.definition.interpolation.end.bracket.curly, punctuation.section.embedded, punctuation.definition.template-expression.begin, punctuation.definition.template-expression.end, meta.string-contents.quoted.double punctuation.definition.variable, punctuation.definition.interpolation.begin, punctuation.definition.interpolation.end, punctuation.definition.template-expression.begin, punctuation.definition.template-expression.end, punctuation.section.embedded.begin, punctuation.section.embedded.coffee, punctuation.section.embedded.end, punctuation.section.embedded.end source.php, punctuation.section.embedded.end source.ruby, punctuation.definition.variable.makefile, punctuation.definition.variable, variable.other.readwrite.module | #A978FF | — |
| punctuation.other.period, punctuation.other.colon, punctuation.accessor, punctuation.separator.period, punctuation.separator.colon, punctuation.section.function.begin, punctuation.separator.dict, punctuation.separator.method | #A978FF | — |
| keyword, punctuation.definition.keyword | #A978FF | — |
| keyword.control.new, keyword.operator.new, keyword.other.new | — | bold |
| storage, meta.implementation storage.type.objc, meta.interface-or-protocol storage.type.objc, source.groovy storage.type.def | #A978FF | — |
| storage.modifier | #A978FF | — |
| entity.name.type, entity.name.variable.field, entity.name.variable.local, entity.name.namespace, entity.name.module | #F1FA8C | — |
| entity.name.type.class, entity.name.class | #F1FA8C | — |
| entity.other.inherited-class | #F1FA8C | — |
| string | #F1FA8C | — |
| punctuation.definition.string.begin, punctuation.definition.string.end | #F1FA8C | — |
| string.quoted.docstring.multi, string.quoted.docstring.multi.python punctuation.definition.string.begin, string.quoted.docstring.multi.python punctuation.definition.string.end, string.quoted.docstring.multi.python constant.character.escape | #A6A2C0 | — |
| meta.import variable.other.readwrite, meta.object-binding-pattern-variable variable.object.property, meta.variable.assignment.destructured.object.coffee variable | #A6A2C0 | — |
| meta.import variable.other.readwrite.alias, meta.export variable.other.readwrite.alias, meta.variable.assignment.destructured.object.coffee variable variable | #A6A2C0 | — |
| constant, variable.other.constant | #FF2B99 | — |
| constant.numeric.decimal, constant.numeric.integer.hexadecimal, constant.numeric.integer, constant.numeric.dec, constant.numeric.float, constant.numeric | #A978FF | — |
| entity.name.function, meta.function-call.object, meta.function-call.php, meta.function-call.static, meta.method-call.java meta.method, meta.method.groovy, support.function.any-method.lua, keyword.operator.function.infix | #1FFF9C | — |
| entity.name.variable.parameter, meta.at-rule.function variable, meta.at-rule.mixin variable, meta.function.arguments variable.other.php, meta.selectionset.graphql meta.arguments.graphql variable.arguments.graphql, variable.parameter | #FFB86C | — |
| support | #8BE9FD | — |
| support.function.magic, support.variable, variable.other.predefined, support.function, support.function.transform | #1FFF9C | — |
| support.function, support.type.property-name | — | regular |
| keyword.expressions-and-types.swift, keyword.other.this, variable.language, variable.language punctuation.definition.variable.php, variable.other.readwrite.instance.ruby, variable.parameter.function.language.special | #1FFF9C | — |
| keyword.primitive-datatypes.swift, keyword.type.cs, meta.protocol-list.objc, meta.return-type.objc, source.go storage.type, source.groovy storage.type, source.java storage.type, source.powershell entity.other.attribute-name, storage.class.std.rust, storage.type.attribute.swift, storage.type.c, storage.type.core.rust, storage.type.cs, storage.type.groovy, storage.type.objc, storage.type.php, storage.type.haskell, storage.type.ocaml, entity.name.type.rust | #8BE9FD | — |
| entity.name.package | #F1FA8C | — |
| variable.other.object, variable.other.property | #F8F8F2 | — |
| variable, constant.other.key.perl, support.variable.property, variable.other.constant.js, variable.other.constant.ts, variable.other.constant.tsx, variable.other.readwrite | #A6A2C0 | — |
| comment keyword.codetag.notation, comment.block.documentation keyword, comment.block.documentation storage.type.class | #A978FF | — |
| comment.block.documentation entity.name.type | #F1FA8C | — |
| comment.block.documentation entity.name.type punctuation.definition.bracket | #F8F8F2 | — |
| comment.block.documentation variable | #6272A4 | — |
| entity.name.type.type-parameter, meta.indexer.mappedtype.declaration entity.name.type, meta.type.parameters entity.name.type | #FF2B99 | — |
| meta.use.rust | #FF2B99 | — |
| entity.name.function.target.makefile, entity.name.section.toml, entity.name.tag.yaml, variable.other.key.toml | #F8F8F2 | — |
| constant.other.date, constant.other.timestamp | #FFB86C | — |
| variable.other.alias.yaml | #1FFF9C | — |
| punctuation.support.type.property-name.begin, punctuation.support.type.property-name.end | #8BE9FE | — |
| constant.other.symbol.hashkey.ruby, keyword.operator.dereference.java, keyword.operator.navigation.groovy, meta.scope.for-loop.shell punctuation.definition.string.begin, meta.scope.for-loop.shell punctuation.definition.string.end, meta.scope.for-loop.shell string, storage.modifier.import, punctuation.section.embedded.begin.tsx, punctuation.section.embedded.end.tsx, punctuation.section.embedded.begin.jsx, punctuation.section.embedded.end.jsx, punctuation.separator.list.comma.css, constant.language.empty-list.haskell | #F8F8F2 | — |
| source.shell variable.other | #A978FF | — |
| support.constant | #A978FF | normal |
| meta.scope.prerequisites.makefile | #F1FA8C | — |
| string.regexp, constant.other.character-class.set.regexp, constant.character.escape.backslash.regexp | #F1FA8C | — |
| punctuation.definition.group.capture.regexp | #FF79C6 | — |
| string.regexp punctuation.definition.string.begin, string.regexp punctuation.definition.string.end | #FF5555 | — |
| punctuation.definition.character-class.regexp | #8BE9FD | — |
| punctuation.definition.group.regexp | #FFB86C | — |
| punctuation.definition.group.assertion.regexp, keyword.operator.negation.regexp | #E83C6A | — |
| meta.assertion.look-ahead.regexp | #1FFF9C | — |
| constant.character.escape, constant.character.string.escape, constant.regexp | #8BE9FD | — |
| punctuation.definition.tag.begin, punctuation.definition.tag.end, entity.other.attribute-name, punctuation.definition.tag, keyword.operator.list.shell | #F8F8F2 | — |
| meta.tag, source.vue, entity.name.tag | #A978FF | — |
| text.html.derivative, meta.jsx.children, text.svelte, text.html.vue-html | #AFABCA | — |
| support.class.component | #8BE9FD | — |
| punctuation.definition.generic.begin.html, punctuation.definition.generic.end.html | #8BE9FD | — |
| entity.other.keyframe-offset | #A978FF | — |
| support.type.vendored.property-name, support.type.property-name | #F8F8F2 | — |
| variable.parameter.keyframe-list | #F1FA8C | — |
| meta.property-value, support.constant.property-value | #FF2B99 | — |
| entity.other.attribute-name.pseudo-class, entity.other.attribute-name.pseudo-element, support.constant.vendored.property-value, support.constant.font-name | #8BE9FD | — |
| entity.other.attribute-name.class, entity.other.attribute-name.id | #A6A2C0 | — |
| emphasis | — | italic |
| strong | — | bold |
| header | #A978FF | — |
| meta.diff, meta.diff.header | #6272A4 | — |
| markup.inserted | #1FFF9C | — |
| markup.deleted | #E83C6A | — |
| markup.changed | #FFB86C | — |
| invalid | #E83C6A | underline italic |
| invalid.deprecated | #E83C6A | italic |
| entity.name.filename | #F1FA8C | — |
| markup.error | #E83C6A | — |
| markup.underline | — | underline |
| markup.bold | #FE2B99 | bold |
| markup.heading | #A978FF | bold |
| markup.italic | #00BDFF | italic |
| beginning.punctuation.definition.list.markdown, beginning.punctuation.definition.quote.markdown, punctuation.definition.link.restructuredtext, punctuation.definition.metadata.markdown | #F8F8F2 | — |
| markup.inline.raw, markup.raw.restructuredtext | #1FFF9C | — |
| markup.underline.link, markup.underline.link.image | #F1FA8C | — |
| meta.link.reference.def.restructuredtext, punctuation.definition.directive.restructuredtext, string.other.link.description, string.other.link.title | #A978FF | — |
| entity.name.directive.restructuredtext, markup.quote | #F1FA8C | italic |
| meta.separator.markdown | #6272A4 | — |
| fenced_code.block.language, markup.raw.inner.restructuredtext, markup.fenced_code.block.markdown punctuation.definition.markdown | #1FFF9C | — |
| punctuation.definition.constant.restructuredtext | #F8F8F2 | — |
| markup.heading.markdown punctuation.definition.string.begin, markup.heading.markdown punctuation.definition.string.end | #F8F8F2 | — |
| meta.paragraph.markdown punctuation.definition.string.begin, meta.paragraph.markdown punctuation.definition.string.end | #F8F8F2 | — |
| markup.quote.markdown meta.paragraph.markdown punctuation.definition.string.begin, markup.quote.markdown meta.paragraph.markdown punctuation.definition.string.end | #F8F8F2 | — |
| meta.paragraph.markdown | #AFABCA | — |
TypeScript sample highlighted with this variant's colors and tokenColors.
Loading...
export interface User {
id: string;
name: string;
role: "admin" | "member";
tags: string[];
}
/**
* Fetch user data by ID
* @param id
* @returns User object or null if ID is invalid
*/
export async function fetchUser(id: string): Promise<User | null> {
if (!id) {
return null;
}
const response = await fetch(`/api/users/${id}`, {
method: "GET",
headers: { Accept: "application/json" },
});
if (!response.ok) {
throw new Error(`HTTP ${response.status}`);
}
return (await response.json()) as User;
}
function greet(user: User): string {
// Simple greeting function that uses the user's name
return `Hello, ${user.name}!`;
}
export interface User {
id: string;
name: string;
role: "admin" | "member";
tags: string[];
}
/**
* Fetch user data by ID
* @param id
* @returns User object or null if ID is invalid
*/
export async function fetchUser(id: string): Promise<User | null> {
if (!id) {
return null;
}
const response = await fetch(`/api/users/${id}`, {
method: "GET",
headers: { Accept: "application/json" },
});
if (!response.ok) {
throw new Error(`HTTP ${response.status}`);
}
return (await response.json()) as User;
}
function greet(user: User): string {
// Simple greeting function that uses the user's name
return `Hello, ${user.name}!`;
}