Skip to main content
Home Theme VS Code vue-solarized theme Inspired by Better Solarized / Vue theme / Shape theme
vue-solarized theme | Coding Theme
VS Code preview Full workbench mockup using this variant's colors and tokenColors.
colors Workbench UI color keys from the theme JSON colors map.
activityBar.background #102233 activityBar.foreground #2E89AC activityBarBadge.background #00BBC9 activityBarBadge.foreground #102233 badge.background #047aa6 button.background #2AA19899 tokenColors TextMate scopes and font styles (syntax highlighting rules).
scope foreground fontStyle — #ffbf8a — comment, punctuation.definition.comment #c3ddff4d italic punctuation.output.jekyll, punctuation.tag.jekyll, punctuation.frontmatter.jekyll, punctuation.output.liquid, punctuation.tag.liquid #269EA6 — entity.name.tag.jekyll, entity.name.tag.liquid #D33682 italic punctuation.tag.jekyll, punctuation.tag.liquid
Shiki preview TypeScript sample highlighted with this variant's colors and tokenColors.
vue-solarized theme — Vue-solarized
debugExceptionWidget.background
#102233
debugExceptionWidget.border #AB395B
debugToolBar.background #102233
dropdown.background #102233
dropdown.border #00000039
editor.background #102233
editor.findMatchHighlightBackground #203eebf9
editor.lineHighlightBackground #0d1a27
editor.lineHighlightBorder #000000d9
editor.rangeHighlightBackground #0d1a27
editor.selectionBackground #0d1a27
editor.selectionHighlightBackground #005A6FAA
editor.wordHighlightBackground #004454AA
editor.wordHighlightStrongBackground #005A6FAA
editorCursor.foreground #FF5887
editorGroup.border #00000039
editorGroup.dropBackground #00000039
editorGroupHeader.tabsBackground #102233
editorHoverWidget.background #102233
editorHoverWidget.border #000000d9
editorIndentGuide.activeBackground #AB395B
editorIndentGuide.background #0000004b
editorLineNumber.activeForeground #2E89AC
editorLineNumber.foreground #194b5f
editorMarkerNavigationError.background #AB395B
editorMarkerNavigationWarning.background #5B7E7A
editorWhitespace.foreground #93A1A125
editorWidget.background #102233
errorForeground #ffeaea
focusBorder #00000039
input.background #102233
input.foreground #93A1A1
input.placeholderForeground #93A1A1AA
inputOption.activeBorder #2AA19899
inputValidation.errorBackground #571b26
inputValidation.errorBorder #a92049
inputValidation.infoBackground #052730
inputValidation.infoBorder #363b5f
inputValidation.warningBackground #e67112
inputValidation.warningBorder #a92049
list.activeSelectionBackground #00000039
list.activeSelectionForeground #00ffddd0
list.dropBackground #00445488
list.focusBackground #005A6F
list.highlightForeground #1ebcc5
list.hoverBackground #004454AA
list.inactiveSelectionBackground #00445488
panel.background #102233
panel.border #00000039
panelTitle.activeBorder #1effec
panelTitle.activeForeground #fff
peekView.border #00000039
peekViewEditor.background #10192c
peekViewEditor.matchHighlightBackground #7744AA40
peekViewResult.background #102233
peekViewTitle.background #102233
pickerGroup.border #00000039
pickerGroup.foreground #2AA19899
progressBar.background #047aa6
scrollbarSlider.activeBackground #00ffdd
scrollbarSlider.background #00ffdd10
scrollbarSlider.hoverBackground #00ffddd0
selection.background #101a198a
sideBar.background #0b1c2c
sideBar.border #00000039
sideBar.foreground #eefffc94
sideBarSectionHeader.background #112233
sideBarSectionHeader.border #00000039
sideBarTitle.foreground #e4fffb91
statusBar.background #0c1a27
statusBar.border #00000039
statusBar.debuggingBackground #102233
statusBar.foreground #e4fffb57
statusBar.noFolderBackground #102233
statusBarItem.prominentBackground #102233
statusBarItem.prominentHoverBackground #102233
tab.activeBackground #102233
tab.activeBorder #2AA198
tab.activeForeground #e4fffb
tab.border #00000039
tab.inactiveBackground #102233
tab.inactiveForeground #6b8aa7
terminal.ansiBlack #073642
terminal.ansiBlue #25BEFA
terminal.ansiBrightBlack #102233
terminal.ansiBrightBlue #ffbf8a
terminal.ansiBrightCyan #25BEFA
terminal.ansiBrightGreen #00BBC9
terminal.ansiBrightMagenta #ff5887
terminal.ansiBrightRed #2E89AC
terminal.ansiBrightWhite #FDF6E3
terminal.ansiBrightYellow #8dbeae
terminal.ansiCyan #2AA198
terminal.ansiGreen #00BBC9
terminal.ansiMagenta #D33682
terminal.ansiRed #FF5887
terminal.ansiWhite #EEE8D5
terminal.ansiYellow #8dbeae
terminal.background #102233
terminal.border #00000039
terminalCursor.background #102233
terminalCursor.foreground #ffbf8a
titleBar.activeBackground #102233 variable.other.jekyll, variable.other.liquid #269EA6 —
support.function.with-args.jekyll — italic
entity.name.type.instance.jsdoc #8dbeae —
keyword.operator.expression.in, keyword.operator.expression.of #FF5887 —
variable, string constant.other.placeholder, keyword.control.default #ffd0a9 —
variable.other.object #ffb87df5 —
variable.other.object.property #FF94B3 —
keyword.control.conditional #d998ff —
invalid.deprecated #ffffff —
keyword, storage.modifier #00BBC9 —
storage.type.function.arrow #269EA6 —
keyword.operator, constant.other.color, punctuation, meta.tag, punctuation.definition.tag, punctuation.separator.inheritance.php, punctuation.definition.tag.html, punctuation.definition.tag.begin.html, punctuation.definition.tag.end.html, punctuation.section.embedded, keyword.other.template, keyword.other.substitution #2aa198 —
entity.name.tag, meta.tag.sgml, markup.deleted.git_gutter #8dbeae —
meta.object-literal.key #269EA6 —
entity.name.function, variable.function, support.function, keyword.other.special-method, meta.block-level, meta.var.expr, meta.block, meta.var-single-variable.expr #00ffdd —
support.other.variable, string.other.link #0ec9a1 italic bold underline
constant.numeric, constant.language, support.constant, constant.character, keyword.other.unit #FF94B3 —
keyword.other.unit #ff6590 —
variable.parameter, entity.other.attribute-name.class #FFD0A9 —
string, constant.other.symbol, constant.other.key, entity.other.inherited-class, markup.heading, markup.inserted.git_gutter, meta.group.braces.curly constant.other.object.key.js string.unquoted.label.js #4ccdd6 normal
entity.name.class, entity.name.type.class, support.type, support.class, support.other.namespace.use.php, meta.use.php, support.other.namespace.php, markup.changed.git_gutter #8dbeae —
entity.name.module.js, variable.import.parameter.js, variable.other.class.js #FF5887 —
variable.language #FF5887 italic
entity.name.method.js #25BEFA —
meta.class-method.js entity.name.function.js, variable.function.constructor #25BEFA —
entity.other.attribute-name #ff5887 —
constant.character.escape #2aa198 —
*url*, *link*, *uri* — underline
constant.numeric.line-number.find-in-files - match #FF5887 —
entity.name.filename.find-in-files #00dcec —
tag.decorator.js entity.name.tag.js, tag.decorator.js punctuation.definition.tag.js #25BEFA italic
source.js constant.other.object.key.js string.unquoted.label.js #FF5887 italic
source.json meta meta meta meta meta meta meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json string.quoted.double.json - meta meta meta meta meta meta meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json string.quoted.double.json, source.json meta meta meta meta meta meta meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json punctuation.definition.string - meta meta meta meta meta meta meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json punctuation.definition.string #FF5887bf —
source.json meta meta meta meta meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json string.quoted.double.json - meta meta meta meta meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json string.quoted.double.json, source.json meta meta meta meta meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json punctuation.definition.string - meta meta meta meta meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json punctuation.definition.string #25BEFAbf —
source.json meta meta meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json string.quoted.double.json - meta meta meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json string.quoted.double.json, source.json meta meta meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json punctuation.definition.string - meta meta meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json punctuation.definition.string #8dbeaebf —
source.json meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json string.quoted.double.json - meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json string.quoted.double.json, source.json meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json punctuation.definition.string - meta meta meta meta meta meta meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json punctuation.definition.string #ff5887bf —
source.json meta meta meta meta meta meta meta meta.structure.dictionary.json string.quoted.double.json - meta meta meta meta meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json string.quoted.double.json, source.json meta meta meta meta meta meta meta meta.structure.dictionary.json punctuation.definition.string - meta meta meta meta meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json punctuation.definition.string #2E89AC bold underline
source.json meta meta meta meta meta meta.structure.dictionary.json string.quoted.double.json - meta meta meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json string.quoted.double.json, source.json meta meta meta meta meta meta.structure.dictionary.json punctuation.definition.string - meta meta meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json punctuation.definition.string #FF5887 —
source.json meta meta meta meta.structure.dictionary.json string.quoted.double.json - meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json string.quoted.double.json, source.json meta meta meta meta.structure.dictionary.json punctuation.definition.string - meta meta meta meta.structure.dictionary.json meta.structure.dictionary.value.json punctuation.definition.string #25BEFA —
source.json meta meta.structure.dictionary.json string.quoted.double.json - meta meta.structure.dictionary.json meta.structure.dictionary.value.json string.quoted.double.json, source.json meta meta.structure.dictionary.json punctuation.definition.string - meta meta.structure.dictionary.json meta.structure.dictionary.value.json punctuation.definition.string #8dbeae —
source.json meta.structure.dictionary.json string.quoted.double.json - meta.structure.dictionary.json meta.structure.dictionary.value.json string.quoted.double.json, source.json meta.structure.dictionary.json punctuation.definition.string - meta.structure.dictionary.json meta.structure.dictionary.value.json punctuation.definition.string #ff5887 —
text.html.markdown, punctuation.definition.list_item.markdown #ffbf8a —
text.html.markdown markup.raw.inline #ffbf8acc —
text.html.markdown meta.dummy.line-break #ffffff50 —
markdown.heading, markup.heading | markup.heading entity.name, markup.heading.markdown punctuation.definition.heading.markdown #0ec9a1 —
markup.italic, markup.italic string — italic
markup.bold, markup.bold string — bold
markup.bold markup.italic, markup.italic markup.bold, markup.quote markup.bold, markup.bold markup.italic string, markup.italic markup.bold string, markup.quote markup.bold string — bold italic
markup.underline #00BBC9 underline
markup.strike #586e75 strike
markup.quote punctuation.definition.blockquote.markdown #ffffff16
markup.quote #586e75 italic
string.other.link.title.markdown #25BEFA —
string.other.link.description.title.markdown #ff5887 —
constant.other.reference.link.markdown #8dbeae —
markup.raw.block #ffbf8acc —
markup.raw.block.fenced.markdown — —
punctuation.definition.fenced.markdown — —
markup.raw.block.fenced.markdown, variable.language.fenced.markdown, punctuation.section.class.end #ffbf8a —
punctuation.definition.fenced.markdown, meta.definition.language.raw.block.fenced.markdown #ffffff50
variable.language.fenced.markdown #586e75
meta.separator #586e75 bold
text.html.markdown punctuation.definition, text.html.markdown.note punctuation.definition.list_item.markdown, markup.table.markdown punctuation.definition.table.vertical-line.markdown, text.html.markdown markup.checkbox.markdown #ffffff50
text.html.markdown meta.disable-markdown punctuation.definition #2aa198 —
punctuation.definition.list_item.todo.done #00BBC9 —
punctuation.definition.list_item.todo.cancelled #FF5887 —
markup.checkbox.markdown markup.checkbox.checked_symbol.markdown #00BBC9 —
markup.admonition.markdown string.other.admonition.title.markdown #ffbf8a bold
markup.admonition.markdown markup.admonition.header.markdown — —
markup.admonition.markdown markup.admonition.body.markdown — —
punctuation.definition.entity.css #ffbf8a —
markup.admonition.markdown punctuation.definition.admonition.markdown, markup.admonition.markdown punctuation.definition.heading, markup.admonition.markdown punctuation.definition.table.vertical-line, markup.admonition.markdown punctuation.definition.table.horizontal-line, markup.admonition.markdown punctuation.definition.table.alignments, markup.admonition.markdown punctuation.definition.heading, markup.admonition.markdown punctuation.definition.bold, markup.admonition.markdown punctuation.definition.italic, markup.admonition.markdown punctuation.definition.list_item, markup.admonition.markdown punctuation.definition.raw, markup.admonition.markdown markup.checkbox.markdown, markup.admonition.markdown punctuation.definition.list_item.todo.pending, markup.admonition.markdown meta.link punctuation.definition, markup.admonition.markdown meta.link.inline markup.underline.link, markup.admonition.markdown meta.link.reference.markdown constant.other.reference.link.markdown, markup.admonition.markdown punctuation.definition.entity.html, markup.admonition.markdown meta.separator.markdown, markup.admonition.markdown markup.table.markdown punctuation.definition.table.vertical-line.markdown, markup.admonition.markdown meta.definition.language.raw.block.fenced.markdown #644ea075 —
markup.admonition.markdown entity.name.admonition.markdown #644ea0 bold
markup.admonition.markdown markup.table, markup.admonition.markdown markup.raw, markup.admonition.markdown markup.raw.block.fenced meta.language, markup.admonition.markdown punctuation.definition.blockquote.markdown, markup.admonition.markdown meta.separator, markup.admonition.markdown markup.raw.inline, markup.admonition.markdown markup.raw.block — —
markup.admonition.markdown markup.quote punctuation.definition.blockquote.markdown #644ea035 —
markup.admonition.markdown.hint markup.admonition.header.markdown — —
markup.admonition.markdown.hint markup.admonition.body.markdown — —
markup.admonition.markdown.hint punctuation.definition.admonition.markdown, markup.admonition.markdown.hint punctuation.definition.heading, markup.admonition.markdown.hint punctuation.definition.table.vertical-line, markup.admonition.markdown.hint punctuation.definition.table.horizontal-line, markup.admonition.markdown.hint punctuation.definition.table.alignments, markup.admonition.markdown.hint punctuation.definition.heading, markup.admonition.markdown.hint punctuation.definition.bold, markup.admonition.markdown.hint punctuation.definition.italic, markup.admonition.markdown.hint punctuation.definition.list_item, markup.admonition.markdown.hint punctuation.definition.raw, markup.admonition.markdown.hint markup.checkbox.markdown, markup.admonition.markdown.hint punctuation.definition.list_item.todo.pending, markup.admonition.markdown.hint meta.link punctuation.definition, markup.admonition.markdown.hint meta.link.inline markup.underline.link, markup.admonition.markdown.hint meta.link.reference.markdown constant.other.reference.link.markdown, markup.admonition.markdown.hint punctuation.definition.entity.html, markup.admonition.markdown.hint meta.separator.markdown, markup.admonition.markdown.hint markup.table.markdown punctuation.definition.table.vertical-line.markdown, markup.admonition.markdown.hint meta.definition.language.raw.block.fenced.markdown #25BEFA75 —
markup.admonition.markdown.hint entity.name.admonition.markdown #25BEFA bold
markup.admonition.markdown.hint markup.table, markup.admonition.markdown.hint markup.raw, markup.admonition.markdown.hint markup.raw.block.fenced meta.language, markup.admonition.markdown.hint punctuation.definition.blockquote.markdown, markup.admonition.markdown.hint meta.separator, markup.admonition.markdown.hint markup.raw.inline, markup.admonition.markdown.hint markup.raw.block — —
markup.admonition.markdown.hint markup.quote punctuation.definition.blockquote.markdown #25BEFA35 —
markup.admonition.markdown.warning markup.admonition.header.markdown — —
markup.admonition.markdown.warning markup.admonition.body.markdown — —
markup.admonition.markdown.warning punctuation.definition.admonition.markdown, markup.admonition.markdown.warning punctuation.definition.heading, markup.admonition.markdown.warning punctuation.definition.table.vertical-line, markup.admonition.markdown.warning punctuation.definition.table.horizontal-line, markup.admonition.markdown.warning punctuation.definition.table.alignments, markup.admonition.markdown.warning punctuation.definition.heading, markup.admonition.markdown.warning punctuation.definition.bold, markup.admonition.markdown.warning punctuation.definition.italic, markup.admonition.markdown.warning punctuation.definition.list_item, markup.admonition.markdown.warning punctuation.definition.raw, markup.admonition.markdown.warning markup.checkbox.markdown, markup.admonition.markdown.warning punctuation.definition.list_item.todo.pending, markup.admonition.markdown.warning meta.link punctuation.definition, markup.admonition.markdown.warning meta.link.inline markup.underline.link, markup.admonition.markdown.warning meta.link.reference.markdown constant.other.reference.link.markdown, markup.admonition.markdown.warning punctuation.definition.entity.html, markup.admonition.markdown.warning meta.separator.markdown, markup.admonition.markdown.warning markup.table.markdown punctuation.definition.table.vertical-line.markdown, markup.admonition.markdown.warning meta.definition.language.raw.block.fenced.markdown #8dbeae75 —
markup.admonition.markdown.warning entity.name.admonition.markdown #8dbeae bold
markup.admonition.markdown.warning markup.table, markup.admonition.markdown.warning markup.raw, markup.admonition.markdown.warning markup.raw.block.fenced meta.language, markup.admonition.markdown.warning punctuation.definition.blockquote.markdown, markup.admonition.markdown.warning meta.separator, markup.admonition.markdown.warning markup.raw.inline, markup.admonition.markdown.warning markup.raw.block — —
markup.admonition.markdown.warning markup.quote punctuation.definition.blockquote.markdown #8dbeae35 —
markup.admonition.markdown.danger markup.admonition.header.markdown — —
markup.admonition.markdown.danger markup.admonition.body.markdown — —
markup.admonition.markdown.danger punctuation.definition.admonition.markdown, markup.admonition.markdown.danger punctuation.definition.heading, markup.admonition.markdown.danger punctuation.definition.table.vertical-line, markup.admonition.markdown.danger punctuation.definition.table.horizontal-line, markup.admonition.markdown.danger punctuation.definition.table.alignments, markup.admonition.markdown.danger punctuation.definition.heading, markup.admonition.markdown.danger punctuation.definition.bold, markup.admonition.markdown.danger punctuation.definition.italic, markup.admonition.markdown.danger punctuation.definition.list_item, markup.admonition.markdown.danger punctuation.definition.raw, markup.admonition.markdown.danger markup.checkbox.markdown, markup.admonition.markdown.danger punctuation.definition.list_item.todo.pending, markup.admonition.markdown.danger meta.link punctuation.definition, markup.admonition.markdown.danger meta.link.inline markup.underline.link, markup.admonition.markdown.danger meta.link.reference.markdown constant.other.reference.link.markdown, markup.admonition.markdown.danger punctuation.definition.entity.html, markup.admonition.markdown.danger meta.separator.markdown, markup.admonition.markdown.danger markup.table.markdown punctuation.definition.table.vertical-line.markdown, markup.admonition.markdown.danger meta.definition.language.raw.block.fenced.markdown #FF588775 —
markup.admonition.markdown.danger entity.name.admonition.markdown #FF5887 bold
markup.admonition.markdown.danger markup.table, markup.admonition.markdown.danger markup.raw, markup.admonition.markdown.danger markup.raw.block.fenced meta.language, markup.admonition.markdown.danger punctuation.definition.blockquote.markdown, markup.admonition.markdown.danger meta.separator, markup.admonition.markdown.danger markup.raw.inline, markup.admonition.markdown.danger markup.raw.block — —
markup.admonition.markdown.danger markup.quote punctuation.definition.blockquote.markdown #FF588735 —
markup.admonition.markdown.attention markup.admonition.header.markdown — —
markup.admonition.markdown.attention markup.admonition.body.markdown — —
markup.admonition.markdown.attention punctuation.definition.admonition.markdown, markup.admonition.markdown.attention punctuation.definition.heading, markup.admonition.markdown.attention punctuation.definition.table.vertical-line, markup.admonition.markdown.attention punctuation.definition.table.horizontal-line, markup.admonition.markdown.attention punctuation.definition.table.alignments, markup.admonition.markdown.attention punctuation.definition.heading, markup.admonition.markdown.attention punctuation.definition.bold, markup.admonition.markdown.attention punctuation.definition.italic, markup.admonition.markdown.attention punctuation.definition.list_item, markup.admonition.markdown.attention punctuation.definition.raw, markup.admonition.markdown.attention markup.checkbox.markdown, markup.admonition.markdown.attention punctuation.definition.list_item.todo.pending, markup.admonition.markdown.attention meta.link punctuation.definition, markup.admonition.markdown.attention meta.link.inline markup.underline.link, markup.admonition.markdown.attention meta.link.reference.markdown constant.other.reference.link.markdown, markup.admonition.markdown.attention punctuation.definition.entity.html, markup.admonition.markdown.attention meta.separator.markdown, markup.admonition.markdown.attention markup.table.markdown punctuation.definition.table.vertical-line.markdown, markup.admonition.markdown.attention meta.definition.language.raw.block.fenced.markdown #00BBC975 —
markup.admonition.markdown.attention entity.name.admonition.markdown #00BBC9 bold
markup.admonition.markdown.attention markup.table, markup.admonition.markdown.attention markup.raw, markup.admonition.markdown.attention markup.raw.block.fenced meta.language, markup.admonition.markdown.attention punctuation.definition.blockquote.markdown, markup.admonition.markdown.attention meta.separator, markup.admonition.markdown.attention markup.raw.inline, markup.admonition.markdown.attention markup.raw.block — —
markup.admonition.markdown.attention markup.quote punctuation.definition.blockquote.markdown #00BBC935 —
sublimelinter.mark.warning #8dbeae —
sublimelinter.gutter-mark #ffffff —
sublimelinter.mark.error #FF5887 —
markup.ignored.git_gutter #586e75 —
markup.untracked.git_gutter #586e75 —
markup.inserted.git_gutter #00BBC9 —
markup.changed.git_gutter #8dbeae —
markup.deleted.git_gutter #FF5887 —
brackethighlighter.default #ff5887 —
brackethighlighter.unmatched #FF5887 —
brackethighlighter.curly #644ea0 —
brackethighlighter.round #8dbeae —
brackethighlighter.square #25BEFA —
brackethighlighter.angle #2E89AC —
brackethighlighter.tag #2aa198 —
support.variable.property #3dd8cb —
support.type.property-name.media #05b0ffd5 —
support.type.property-name.css #23a095 —
brackethighlighter.quote #00BBC9 —
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 } ! ` ;
}
fetchUser.ts
index.ts
README.md
src
components
fetchUser.ts
src
components
fetchUser.ts
fetchUser 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
Problems1
Output
Debug Console
Terminal
Ports
~/my-project $ pnpm dev
▲ Next.js ready on http://localhost:3000
✓ compiled client and server successfully in 412ms
wait - compiling /theme/vscode...
~/my-project
main*
Button.tsx
31
$
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 } ! ` ;
}