Code Blocks
Dev Portal supports code blocks in Markdown using the Shiki syntax highlighting library.
See examples for all supported languages in the Syntax Highlighting section.
Syntax Highlighting
Code blocks are text blocks wrapped around by strings of 3 backticks. You may check out this reference for the specifications of MDX.
Code
The code block above will render as:
Code
You can also use the SyntaxHighlight component to render code
blocks in TypeScript directly.
Inline Code
You can highlight inline code using either:
Regular backticks without language specification:
Code
Result: console.log("Hello World")
or with the tailing curly colon syntax:
Code
Result: console.log("Hello World")
For more details, see the Shiki Rehype documentation.
You can add a title to code blocks by adding a title attribute after the backticks:
Code
Result:
hello.tsx
For a complete list of supported languages and their aliases, see the Shiki Languages documentation.
Advanced Syntax Highlighting
There are multiple ways to enhance syntax highlighting:
- Line highlighting
- Word highlighting
- Line numbers: showLineNumbers
- Title: title
Example:
Code
Result:
Example.tsx
Configuration
You can configure syntax highlighting in your zudoku.config.tsx:
Changes to the syntax highlighting configuration require a restart of Dev Portal to take effect.
zudoku.config.ts
For a complete list of available themes and languages, see the list of Shiki themes and Shiki languages.
Default Supported Languages
By default, Dev Portal supports the following languages for syntax highlighting:
- HTML/CSS/XML - html,css,xml
- JavaScript/TypeScript - javascript,js,typescript,ts
- React - jsx,tsx,react
- Markdown - markdown,md,mdx
- Data formats - json,jsonc,yaml,toml
- Shell - bash,sh,shell,zsh
- Terminal - terminal,term
- Python - python,py
- Rust - rust,rs
- PHP - php
- Ruby - ruby,rb
- Swift - swift
- Kotlin - kotlin,kt
- C# - csharp,cs,vb
- Go - go
- Objective-C - objectivec,objc
- GraphQL - graphql,gql
ANSI Code Blocks
You can use the ansi language to highlight terminal outputs with ANSI escape sequences. This is
useful for displaying colored terminal output, styled text, and other terminal-specific formatting.
Terminal Output
Usage:
Code
For more details on ANSI highlighting, see the Shiki documentation.