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/f4b73/f4b73b7aacb4317b619440d8863137d4cac0c9b7" 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/f7c14/f7c14a536e5471b4ffe267074ef21121160f7c71" alt=""
Numbered lists
1. numbered lists
1. increment automatically
1. one more
data:image/s3,"s3://crabby-images/4d35d/4d35d5e80a8debfab1df24c1476ec88fba3152e1" 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: zulip.com
Named link: [Zulip homepage](zulip.com)
Stream: #**stream name**
Topic: #**stream name>topic name**
Custom linkifier: #1234 (links to ticket 1234 in your ticketing system)
data:image/s3,"s3://crabby-images/80be2/80be2dbe94ef69715750b7f2225f4eab3beeed06" 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/5cfab/5cfab5a325f2b8159d01a40b5cea6fddcf8f9370" 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/e60af/e60afaf602dd93fc8dc0d3ed5ce23272c0448167" 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.
Organization administrators can also configure a default syntax
highlighting language. In this configuration, one can use ```text
to display content without any syntax highlighting.
Latex
Inline: $$O(n^2)$$
Displayed:
``` math
\int_a^b f(t)\, dt = F(b) - F(a)
```
data:image/s3,"s3://crabby-images/744c1/744c13cf4865b61a8134557df85e0ca6e0aeae94" alt=""
Zulip's LaTeX rendering is powered by KaTeX.
Their support table is a
helpful resource for checking what's supported or how to express
something.
Quotes
> a multi-line
quote on two lines
normal text
```quote
A multi-paragraph
quote in two paragraphs
```
data:image/s3,"s3://crabby-images/9c93e/9c93edbb051551d970b9f0dcc4b5c7afef4a886a" alt=""
Spoilers
You can use spoilers to hide content that you do not want to be visible until
the user interacts with it.
Normal content in message
```spoiler Spoiler Header
Spoiler content. These lines won't be visible until the user expands the spoiler.
```
The spoiler will initially display in a collapsed form:
data:image/s3,"s3://crabby-images/5f833/5f8338213d604c197271eb97179d8984aa135d1e" alt=""
Clicking the arrow will expand the spoiler content:
data:image/s3,"s3://crabby-images/fde3f/fde3f8d38a9f35acd1c8d68b31d8e2d401e5213b" 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/d982a/d982a2a402fe657808dc16b77ece26f85808dcaa" 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/180fb/180fb2b5cdc62086aa6eee53b2d0e923355cc0e7" alt=""
Status Messages
data:image/s3,"s3://crabby-images/a83ba/a83badd350eb1002d43a81467c55fc596c85e907" alt=""
Mention a time
When collaborating with people in another timezone, you often need to
express a specific time clearly. Rather than typing out your timezone
and having everyone translate the time in their heads, in Zulip, you
can mention a time, and it'll be displayed to each user in their own
timezone (just like the timestamps on Zulip messages).
A date picker will appear once you type <time
.
Our next meeting is scheduled for <time:2020-05-28T13:30:00+05:30>
A person in San Francisco will see:
Our next meeting is scheduled for Thu, May 28 2020, 1:00 AM.
While someone in India will see:
Our next meeting is scheduled for Thu, May 28 2020, 1:30 PM.
You can also use other formats such as UNIX timestamps or human readable
dates, for example, <time:May 28 2020, 1:30 PM IST>
.
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/9ef53/9ef5305ce3dde2917d7e122a802ae67b407f8e42" 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/7c23b/7c23b69fef07fd5a56125f62507a00d640ab8d8e" alt=""
In-app help
A summary of the formatting syntax is available in-app.
Related articles