2018-09-19 17:39:02 +02:00
|
|
|
# Format your messages
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2019-02-28 04:34:38 +01:00
|
|
|
[//]: # (All screenshots here require line-height: 22px and font-size: 16px in .message-content.)
|
|
|
|
[//]: # (Requires some additional fiddling for the LaTeX picture, inline code block, and maybe a few others.)
|
|
|
|
|
2017-01-07 03:32:36 +01:00
|
|
|
Zulip uses a variant of
|
2018-09-19 17:39:02 +02:00
|
|
|
[GitHub Flavored Markdown](https://github.com/adam-p/markdown-here/wiki/Markdown-Cheatsheet)
|
|
|
|
to allow you to easily format your messages.
|
|
|
|
|
|
|
|
* [Emphasis](#emphasis)
|
|
|
|
* [Lists](#lists)
|
|
|
|
* [Links and images](#links)
|
2020-04-14 00:51:46 +02:00
|
|
|
* [Code blocks](#code)
|
|
|
|
* [LaTeX](#latex)
|
2018-09-19 17:39:02 +02:00
|
|
|
* [Quotes](#quotes)
|
2020-04-04 22:14:34 +02:00
|
|
|
* [Spoilers](#spoilers)
|
2018-09-19 17:39:02 +02:00
|
|
|
* [Emoji and emoticons](#emoji-and-emoticons)
|
|
|
|
* [Mentions](#mentions)
|
|
|
|
* [Status messages](#status-messages)
|
2020-05-21 10:42:27 +02:00
|
|
|
* [Mention a time](#mention-a-time)
|
2018-09-19 17:39:02 +02:00
|
|
|
* [Tables](#tables)
|
|
|
|
* [Paragraphs and lines](#paragraphs-and-lines)
|
2016-12-04 04:57:51 +01:00
|
|
|
|
|
|
|
## Emphasis
|
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
```
|
|
|
|
**bold**, *italic*, and ~~strikethrough~~ text
|
|
|
|
***~~All three at once~~***
|
|
|
|
```
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
![](/static/images/help/markdown-emphasis.png)
|
2016-12-04 04:57:51 +01:00
|
|
|
|
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
## Lists
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
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
|
|
|
|
```
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
![](/static/images/help/markdown-bullets.png)
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
Numbered lists
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
```
|
|
|
|
1. numbered lists
|
|
|
|
1. increment automatically
|
|
|
|
1. one more
|
|
|
|
```
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
![](/static/images/help/markdown-numbered-lists.png)
|
2016-12-04 04:57:51 +01:00
|
|
|
|
|
|
|
|
|
|
|
## Links
|
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
Zulip auto-linkifies URLs and valid stream names. You can also add a
|
|
|
|
[custom linkifier](/help/add-a-custom-linkification-filter) to link
|
|
|
|
patterns like `#1234` to your ticketing system.
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
```
|
2020-06-09 00:58:42 +02:00
|
|
|
Auto-detected URL: zulip.com
|
|
|
|
Named link: [Zulip homepage](zulip.com)
|
2019-08-03 00:50:43 +02:00
|
|
|
Stream: #**stream name**
|
|
|
|
Topic: #**stream name>topic name**
|
2018-09-19 17:39:02 +02:00
|
|
|
Custom linkifier: #1234 (links to ticket 1234 in your ticketing system)
|
|
|
|
```
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
![](/static/images/help/markdown-links.png)
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
## Images
|
2016-12-06 00:13:06 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
See [Share and upload files](/help/share-and-upload-files) to learn more
|
|
|
|
about dropping, pasting, and attaching images.
|
2016-12-06 00:13:06 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
```
|
|
|
|
[A whale of a good time](https://your.zulip.domain/user_uploads/1/46/IPvysqXEtiTG1ZdNBrwAZODi/whale-time.png)
|
|
|
|
```
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
![](/static/images/help/markdown-image.png)
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
## Code
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
~~~
|
|
|
|
Inline: `let x = 5`
|
2017-04-08 07:54:52 +02:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
Code block:
|
|
|
|
```
|
|
|
|
def f(x):
|
|
|
|
return x+1
|
|
|
|
```
|
2018-02-03 23:31:59 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
Syntax highlighting:
|
|
|
|
```python
|
|
|
|
def fib(n):
|
|
|
|
# TODO: base case
|
|
|
|
return fib(n-1) + fib(n-2)
|
|
|
|
```
|
|
|
|
~~~
|
2018-02-03 23:31:59 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
![](/static/images/help/markdown-code.png)
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
You can also use `~~~` to start codeblocks, or just indent the code 4 or more spaces.
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
Zulip supports syntax highlighting for hundreds of languages, and a
|
|
|
|
typeahead will pop up when you start typing after the ` ``` `. If you can't
|
2020-03-27 01:32:21 +01:00
|
|
|
find your language, search for it [here](https://pygments.org/docs/lexers/)
|
2018-09-19 17:39:02 +02:00
|
|
|
and try the **short names** listed for the lexers for your language.
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2020-03-31 15:21:27 +02:00
|
|
|
Organization administrators can also configure a default syntax
|
|
|
|
highlighting language. In this configuration, one can use ````text`
|
|
|
|
to display content without any syntax highlighting.
|
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
## Latex
|
|
|
|
~~~
|
|
|
|
Inline: $$O(n^2)$$
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
Displayed:
|
2020-04-14 00:51:46 +02:00
|
|
|
``` math
|
2018-09-19 17:39:02 +02:00
|
|
|
\int_a^b f(t)\, dt = F(b) - F(a)
|
|
|
|
```
|
|
|
|
~~~
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
![](/static/images/help/markdown-latex.png)
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2020-04-14 00:51:46 +02:00
|
|
|
Zulip's LaTeX rendering is powered by [KaTeX](https://katex.org).
|
|
|
|
Their [support table](https://katex.org/docs/support_table.html) is a
|
|
|
|
helpful resource for checking what's supported or how to express
|
|
|
|
something.
|
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
## Quotes
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
~~~
|
|
|
|
> a multi-line
|
|
|
|
quote on two lines
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
normal text
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
```quote
|
|
|
|
A multi-paragraph
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
quote in two paragraphs
|
|
|
|
```
|
|
|
|
~~~
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
![](/static/images/help/markdown-quotes.png)
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2020-04-04 22:14:34 +02:00
|
|
|
## 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:
|
|
|
|
|
|
|
|
![](/static/images/help/spoiler-collapsed.png)
|
|
|
|
|
|
|
|
Clicking the arrow will expand the spoiler content:
|
|
|
|
|
|
|
|
![](/static/images/help/spoiler-expanded.png)
|
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
## Emoji and emoticons
|
2017-05-13 05:22:28 +02:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
To translate emoticons into emoji, you'll need to
|
|
|
|
[enable emoticon translations](/help/enable-emoticon-translations).
|
|
|
|
You can also [add custom emoji](/help/add-custom-emoji).
|
2017-05-13 05:22:28 +02:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
```
|
|
|
|
:octopus: :heart: :zulip: :)
|
|
|
|
```
|
2017-05-13 05:22:28 +02:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
![](/static/images/help/markdown-emoji.png)
|
2017-05-13 05:22:28 +02:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
## Mentions
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2019-02-28 20:42:48 +01:00
|
|
|
Learn more about mentions [here](/help/mention-a-user-or-group).
|
2019-02-28 04:34:38 +01:00
|
|
|
The numbers will be added automatically by the typeahead if needed for disambiguation.
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
```
|
|
|
|
Users: @**Polonius** or @**Zoe|2132** (two asterisks)
|
|
|
|
User group: @*support team* (one asterisk)
|
2019-02-28 04:34:38 +01:00
|
|
|
Silent mention: @_**Polonius** (@_ instead of @)
|
2018-09-19 17:39:02 +02:00
|
|
|
```
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
![](/static/images/help/markdown-mentions.png)
|
2017-03-21 21:46:25 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
## Status Messages
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
```
|
|
|
|
/me is away
|
|
|
|
```
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
![](/static/images/help/markdown-status.png)
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2020-05-21 10:42:27 +02:00
|
|
|
## 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).
|
|
|
|
|
2020-07-06 17:21:37 +02:00
|
|
|
A date picker will appear once you type `<time`.
|
2020-05-21 10:42:27 +02:00
|
|
|
|
|
|
|
```
|
2020-07-06 17:21:37 +02:00
|
|
|
Our next meeting is scheduled for <time:2020-05-28T13:30:00+05:30>
|
2020-05-21 10:42:27 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
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*.
|
|
|
|
|
2020-07-06 17:21:37 +02:00
|
|
|
You can also use other formats such as UNIX timestamps or human readable
|
|
|
|
dates, for example, `<time:May 28 2020, 1:30 PM IST>`.
|
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
## Tables
|
2017-03-21 21:46:25 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
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.
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
```
|
|
|
|
|| yes | no | maybe
|
|
|
|
|---|---|:---:|------:
|
|
|
|
| A | left-aligned | centered | right-aligned
|
|
|
|
| B | extra spaces | are | ok
|
|
|
|
| C | **bold** *italic* ~~strikethrough~~ :smile: ||
|
|
|
|
```
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
![](/static/images/help/markdown-table.png)
|
2017-03-19 04:23:27 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
## Paragraphs and lines
|
2017-03-19 04:23:27 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
```
|
|
|
|
One blank space for a new paragraph
|
|
|
|
New line, same paragraph
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
New paragraph
|
2016-12-04 04:57:51 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
---, ***, or ___ for a horizontal line
|
|
|
|
Over the line
|
2017-03-20 16:56:39 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
---
|
2017-03-20 16:56:39 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
Under the line
|
|
|
|
```
|
2017-03-20 16:56:39 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
![](/static/images/help/markdown-paragraph.png)
|
2017-03-20 16:56:39 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
## In-app help
|
2017-03-20 16:56:39 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
A summary of the formatting syntax is available in-app.
|
2017-03-20 16:56:39 +01:00
|
|
|
|
2019-04-03 08:09:36 +02:00
|
|
|
{start_tabs}
|
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
{!start-composing.md!}
|
2017-03-20 16:56:39 +01:00
|
|
|
|
2018-09-19 17:39:02 +02:00
|
|
|
1. Click the A (<i class="fa fa-font"></i>) icon at the bottom of the compose box.
|
2019-04-03 08:09:36 +02:00
|
|
|
|
|
|
|
{end_tabs}
|
|
|
|
|
|
|
|
## Related articles
|
|
|
|
|
|
|
|
* [Create a poll](/help/create-a-poll)
|