Zulip uses a variant of
GitHub Flavored Markdown
to allow you to easily format your messages.
Emphasis
**bold**, *italic*, and ~~strikethrough~~ text
***~~All three at once~~***
data:image/s3,"s3://crabby-images/1b3ee/1b3ee9d468eb6beb754cac9d2da1adda5b9a1c96" alt=""
Lists
Bulleted lists
* bulleted lists
* with sub-bullets too
* sub-bullets start with 2 spaces
* start sub-sub-bullets with 4 spaces
* multi
line
bullet
- dashes and
+ pluses are ok too
data:image/s3,"s3://crabby-images/28b78/28b78325da9b18f5cf32d2c0d2eb1932ac77a855" alt=""
Numbered lists
1. numbered lists
1. increment automatically
1. one more
data:image/s3,"s3://crabby-images/964f3/964f3e4916a16fe616775d075e7f5bdfc886c23b" alt=""
Links
Zulip auto-linkifies URLs and valid stream names. You can also add a
custom linkifier to link
patterns like #1234
to your ticketing system.
Auto-detected URL: zulipchat.com
Named link: [Zulip homepage](zulipchat.com)
Stream: #**announce**
Custom linkifier: #1234 (links to ticket 1234 in your ticketing system)
data:image/s3,"s3://crabby-images/3c5e4/3c5e45f0fe50c571b5b257a299c2d9b212d0ddf9" alt=""
Images
See Share and upload files to learn more
about dropping, pasting, and attaching images.
[A whale of a good time](https://your.zulip.domain/user_uploads/1/46/IPvysqXEtiTG1ZdNBrwAZODi/whale-time.png)
data:image/s3,"s3://crabby-images/6f236/6f236a37138f1dec808038897c503de24e5f2619" alt=""
Code
Inline: `let x = 5`
Code block:
```
def f(x):
return x+1
```
Syntax highlighting:
```python
def fib(n):
# TODO: base case
return fib(n-1) + fib(n-2)
```
data:image/s3,"s3://crabby-images/fa39c/fa39cf74dc5f967bc57d4e1d9d1f1a18eb990b56" alt=""
You can also use ~~~
to start codeblocks, or just indent the code 4 or more spaces.
Zulip supports syntax highlighting for hundreds of languages, and a
typeahead will pop up when you start typing after the ```
. If you can't
find your language, search for it here
and try the short names listed for the lexers for your language.
Latex
Inline: $$O(n^2)$$
Displayed:
```tex
\int_a^b f(t)\, dt = F(b) - F(a)
```
data:image/s3,"s3://crabby-images/6873f/6873f520f771a74bc66c853423e95f976961ded1" alt=""
Quotes
> a multi-line
quote on two lines
normal text
```quote
A multi-paragraph
quote in two paragraphs
```
data:image/s3,"s3://crabby-images/f45b7/f45b7091cd39363e486b17f7ccdcc31d75887f26" alt=""
Emoji and emoticons
To translate emoticons into emoji, you'll need to
enable emoticon translations.
You can also add custom emoji.
:octopus: :heart: :zulip: :)
data:image/s3,"s3://crabby-images/924de/924deb6b0efabb334eecebc00b3f8bef872571cb" alt=""
Mentions
Learn more about mentions here.
The numbers will be added automatically by the typeahead if needed for disambiguation.
Users: @**Polonius** or @**Zoe|2132** (two asterisks)
User group: @*support team* (one asterisk)
Silent mention: @_**Polonius** (@_ instead of @)
data:image/s3,"s3://crabby-images/c11aa/c11aa4e2ee564406f03d2778ea8e8369ce91b0bf" alt=""
Status Messages
data:image/s3,"s3://crabby-images/2c1fc/2c1fc94d20039949a55d7026888b3f4869b86995" alt=""
Tables
The initial pipes (|
) are optional if every entry in the first column is non-empty.
The header separators (---
) must be at least three dashes long.
|| yes | no | maybe
|---|---|:---:|------:
| A | left-aligned | centered | right-aligned
| B | extra spaces | are | ok
| C | **bold** *italic* ~~strikethrough~~ :smile: ||
data:image/s3,"s3://crabby-images/aaaf1/aaaf15c6ecad2186f9ffebe382a5ef46d00fb134" alt=""
Paragraphs and lines
One blank space for a new paragraph
New line, same paragraph
New paragraph
---, ***, or ___ for a horizontal line
Over the line
---
Under the line
data:image/s3,"s3://crabby-images/8f892/8f8925958e74cae51704b83707450e6b4f161db3" alt=""
In-app help
A summary of the formatting syntax is available in-app.
-
Open the compose box.
-
Click the A () icon at the bottom of the compose box.