2020-07-24 09:59:16 +02:00
|
|
|
|
---
|
|
|
|
|
template: overrides/main.html
|
2021-12-16 17:08:57 +01:00
|
|
|
|
icon: material/emoticon-wink-outline
|
2020-07-24 09:59:16 +02:00
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
# Icons + Emojis
|
|
|
|
|
|
|
|
|
|
One of the best features of Material for MkDocs is the possibility to use [more
|
2021-10-04 23:36:31 +02:00
|
|
|
|
than 8.000 icons][icon search] and thousands of emojis in your project
|
|
|
|
|
documentation with practically zero additional effort. Moreover, custom icons
|
|
|
|
|
can be added and used in `mkdocs.yml`, documents and templates.
|
|
|
|
|
|
|
|
|
|
[icon search]: #search
|
2020-07-24 09:59:16 +02:00
|
|
|
|
|
2021-02-06 12:35:19 +01:00
|
|
|
|
## Search
|
|
|
|
|
|
2021-02-24 18:02:09 +01:00
|
|
|
|
<div class="mdx-iconsearch" data-mdx-component="iconsearch">
|
2021-02-14 14:51:08 +01:00
|
|
|
|
<input
|
2021-02-24 18:02:09 +01:00
|
|
|
|
class="md-input md-input--stretch mdx-iconsearch__input"
|
2021-02-15 15:57:44 +01:00
|
|
|
|
placeholder="Search the icon and emoji database"
|
2021-02-24 18:02:09 +01:00
|
|
|
|
data-mdx-component="iconsearch-query"
|
2021-02-14 14:51:08 +01:00
|
|
|
|
/>
|
2021-02-24 18:02:09 +01:00
|
|
|
|
<div class="mdx-iconsearch-result" data-mdx-component="iconsearch-result">
|
|
|
|
|
<div class="mdx-iconsearch-result__meta"></div>
|
|
|
|
|
<ol class="mdx-iconsearch-result__list"></ol>
|
2021-02-14 14:51:08 +01:00
|
|
|
|
</div>
|
2021-02-06 12:35:19 +01:00
|
|
|
|
</div>
|
2021-02-14 14:51:08 +01:00
|
|
|
|
<small>
|
|
|
|
|
:octicons-light-bulb-16:
|
2021-10-04 23:36:31 +02:00
|
|
|
|
**Tip:** Enter some keywords to find icons and emojis and click on the
|
|
|
|
|
shortcode to copy it to your clipboard.
|
2021-02-14 14:51:08 +01:00
|
|
|
|
</small>
|
2021-02-06 12:35:19 +01:00
|
|
|
|
|
2020-07-24 09:59:16 +02:00
|
|
|
|
## Configuration
|
|
|
|
|
|
2021-10-04 23:36:31 +02:00
|
|
|
|
This configuration enables the use of icons and emojis by using simple
|
|
|
|
|
shortcodes which can be discovered through the [icon search]. Add the following
|
|
|
|
|
lines to `mkdocs.yml`:
|
2020-07-24 09:59:16 +02:00
|
|
|
|
|
|
|
|
|
``` yaml
|
|
|
|
|
markdown_extensions:
|
|
|
|
|
- pymdownx.emoji:
|
|
|
|
|
emoji_index: !!python/name:materialx.emoji.twemoji
|
|
|
|
|
emoji_generator: !!python/name:materialx.emoji.to_svg
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
The following icon sets are bundled with Material for MkDocs:
|
|
|
|
|
|
2021-10-04 23:36:31 +02:00
|
|
|
|
- :material-material-design: – [Material Design]
|
|
|
|
|
- :fontawesome-brands-font-awesome: – [FontAwesome]
|
|
|
|
|
- :octicons-mark-github-16: – [Octicons]
|
2020-07-24 09:59:16 +02:00
|
|
|
|
|
2021-10-04 23:36:31 +02:00
|
|
|
|
See additional configuration options:
|
2020-07-26 14:46:09 +02:00
|
|
|
|
|
2021-10-04 23:36:31 +02:00
|
|
|
|
- [Emoji]
|
|
|
|
|
- [Emoji with custom icons]
|
2020-07-26 14:46:09 +02:00
|
|
|
|
|
2021-10-04 23:36:31 +02:00
|
|
|
|
[Material Design]: https://materialdesignicons.com/
|
|
|
|
|
[FontAwesome]: https://fontawesome.com/icons?d=gallery&m=free
|
|
|
|
|
[Octicons]: https://octicons.github.com/
|
|
|
|
|
[Emoji]: ../setup/extensions/python-markdown-extensions.md#emoji
|
2021-10-10 12:19:14 +02:00
|
|
|
|
[Emoji with custom icons]: ../setup/extensions/python-markdown-extensions.md#custom-icons
|
2020-07-26 14:46:09 +02:00
|
|
|
|
|
2020-07-24 09:59:16 +02:00
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
|
|
### Using emojis
|
|
|
|
|
|
|
|
|
|
Emojis can be integrated in Markdown by putting the shortcode of the emoji
|
2021-10-04 23:36:31 +02:00
|
|
|
|
between two colons. If you're using [Twemoji] (recommended), you can look up
|
|
|
|
|
the shortcodes at [Emojipedia].
|
2020-07-24 09:59:16 +02:00
|
|
|
|
|
|
|
|
|
_Example_:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
:smile:
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
_Result_:
|
|
|
|
|
|
|
|
|
|
:smile:
|
|
|
|
|
|
2021-10-04 23:36:31 +02:00
|
|
|
|
[Twemoji]: https://twemoji.twitter.com/
|
|
|
|
|
[Emojipedia]: https://emojipedia.org/twitter/
|
2020-07-24 09:59:16 +02:00
|
|
|
|
|
|
|
|
|
### Using icons
|
|
|
|
|
|
2021-10-04 23:36:31 +02:00
|
|
|
|
When [Emoji] is enabled, icons can be used similar to emojis, by referencing
|
2020-07-24 09:59:16 +02:00
|
|
|
|
a valid path to any icon bundled with the theme, which are located in the
|
2021-10-10 12:19:14 +02:00
|
|
|
|
[`.icons`][custom icons] directory, and replacing `/` with `-`:
|
2020-07-24 09:59:16 +02:00
|
|
|
|
|
|
|
|
|
_Example_:
|
|
|
|
|
|
|
|
|
|
```
|
2021-10-10 12:19:14 +02:00
|
|
|
|
- :material-account-circle: – `material/account-circle.svg`
|
|
|
|
|
- :fontawesome-regular-laugh-wink: – `fontawesome/regular/laugh-wink.svg`
|
|
|
|
|
- :octicons-repo-push-16: – `octicons/repo-push-16.svg`
|
2020-07-24 09:59:16 +02:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
_Result_:
|
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
- :material-account-circle: – [`material/account-circle.svg`][icon Material]
|
|
|
|
|
- :fontawesome-regular-laugh-wink: – [`fontawesome/regular/laugh-wink.svg`][icon FontAwesome]
|
|
|
|
|
- :octicons-repo-push-16: – [`octicons/repo-push-16.svg`][icon Octicons]
|
2020-07-26 14:46:09 +02:00
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
[custom icons]: https://github.com/squidfunk/mkdocs-material/tree/master/material/.icons
|
|
|
|
|
[icon Material]: https://raw.githubusercontent.com/squidfunk/mkdocs-material/master/material/.icons/material/account-circle.svg
|
|
|
|
|
[icon FontAwesome]: https://raw.githubusercontent.com/squidfunk/mkdocs-material/master/material/.icons/fontawesome/regular/laugh-wink.svg
|
|
|
|
|
[icon Octicons]: https://raw.githubusercontent.com/squidfunk/mkdocs-material/master/material/.icons/octicons/repo-push-16.svg
|
2020-07-26 14:46:09 +02:00
|
|
|
|
|
2020-07-26 17:06:57 +02:00
|
|
|
|
#### with colors
|
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
When [Attribute Lists] is enabled, custom CSS classes can be added to icons by
|
|
|
|
|
suffixing the icon with a special syntax. While HTML allows to use
|
|
|
|
|
[inline styles], it's always recommended to add an [additional style sheet] and
|
|
|
|
|
move declarations into dedicated CSS classes.
|
2020-07-26 17:06:57 +02:00
|
|
|
|
|
|
|
|
|
<style>
|
|
|
|
|
.medium {
|
|
|
|
|
color: #00AB6C;
|
|
|
|
|
}
|
|
|
|
|
.twitter {
|
|
|
|
|
color: #1DA1F2;
|
|
|
|
|
}
|
|
|
|
|
.facebook {
|
|
|
|
|
color: #4267B2;
|
|
|
|
|
}
|
|
|
|
|
</style>
|
|
|
|
|
|
|
|
|
|
_Example_:
|
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
=== ":octicons-file-code-16: docs/example.md"
|
|
|
|
|
|
|
|
|
|
``` markdown
|
|
|
|
|
- :fontawesome-brands-medium:{ .medium } – Medium
|
|
|
|
|
- :fontawesome-brands-twitter:{ .twitter } – Twitter
|
|
|
|
|
- :fontawesome-brands-facebook:{ .facebook } – Facebook
|
|
|
|
|
```
|
|
|
|
|
|
2021-10-10 17:39:53 +02:00
|
|
|
|
=== ":octicons-file-code-16: docs/stylesheets/extra.css"
|
2021-10-10 12:19:14 +02:00
|
|
|
|
|
|
|
|
|
``` css
|
|
|
|
|
.medium {
|
|
|
|
|
color: #00AB6C;
|
|
|
|
|
}
|
|
|
|
|
.twitter {
|
|
|
|
|
color: #1DA1F2;
|
|
|
|
|
}
|
|
|
|
|
.facebook {
|
|
|
|
|
color: #4267B2;
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
=== ":octicons-file-code-16: mkdocs.yml"
|
|
|
|
|
|
|
|
|
|
``` yaml
|
|
|
|
|
extra_css:
|
2021-10-10 17:39:53 +02:00
|
|
|
|
- stylesheets/extra.css
|
2021-10-10 12:19:14 +02:00
|
|
|
|
```
|
2020-07-26 17:06:57 +02:00
|
|
|
|
|
|
|
|
|
_Result_:
|
|
|
|
|
|
2021-03-13 14:30:29 +01:00
|
|
|
|
- :fontawesome-brands-medium:{ .medium } – Medium
|
|
|
|
|
- :fontawesome-brands-twitter:{ .twitter } – Twitter
|
|
|
|
|
- :fontawesome-brands-facebook:{ .facebook } – Facebook
|
2020-07-26 17:06:57 +02:00
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
[Attribute Lists]: ../setup/extensions/python-markdown.md#attribute-lists
|
|
|
|
|
[inline styles]: https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/style
|
|
|
|
|
[additional style sheet]: ../customization.md#additional-css
|
2020-07-26 17:06:57 +02:00
|
|
|
|
|
|
|
|
|
#### with animations
|
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
Similar to adding [colors], it's just as easy to add [animations] to icons by
|
|
|
|
|
using an [additional style sheet], defining a `@keyframes` rule and adding a
|
|
|
|
|
dedicated CSS class to the icon.
|
2020-07-26 17:06:57 +02:00
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
_Example_:
|
2020-07-26 17:06:57 +02:00
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
=== ":octicons-file-code-16: docs/example.md"
|
2020-07-26 17:06:57 +02:00
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
``` markdown
|
|
|
|
|
:octicons-heart-fill-24:{ .heart }
|
|
|
|
|
```
|
2020-07-26 17:06:57 +02:00
|
|
|
|
|
2021-10-10 17:39:53 +02:00
|
|
|
|
=== ":octicons-file-code-16: docs/stylesheets/extra.css"
|
2021-10-10 12:19:14 +02:00
|
|
|
|
|
|
|
|
|
``` css
|
|
|
|
|
@keyframes heart {
|
|
|
|
|
0%, 40%, 80%, 100% {
|
|
|
|
|
transform: scale(1);
|
|
|
|
|
}
|
|
|
|
|
20%, 60% {
|
|
|
|
|
transform: scale(1.15);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.heart {
|
|
|
|
|
animation: heart 1000ms infinite;
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
=== ":octicons-file-code-16: mkdocs.yml"
|
|
|
|
|
|
|
|
|
|
``` yaml
|
|
|
|
|
extra_css:
|
2021-10-10 17:39:53 +02:00
|
|
|
|
- stylesheets/extra.css
|
2021-10-10 12:19:14 +02:00
|
|
|
|
```
|
2020-07-26 17:06:57 +02:00
|
|
|
|
|
|
|
|
|
_Result_:
|
|
|
|
|
|
2021-03-13 14:30:29 +01:00
|
|
|
|
:octicons-heart-fill-24:{ .mdx-heart }
|
2020-07-24 09:59:16 +02:00
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
[colors]: #with-colors
|
|
|
|
|
[animations]: https://developer.mozilla.org/en-US/docs/Web/CSS/animation
|
2020-07-30 20:36:08 +02:00
|
|
|
|
|
|
|
|
|
## Customization
|
|
|
|
|
|
|
|
|
|
### Using icons in templates
|
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
When you're [extending the theme] with partials or blocks, you can simply
|
|
|
|
|
reference any icon that's [bundled with the theme][icon search] with Jinja's
|
|
|
|
|
[`include`][include] function and wrap it with the `.twemoji` CSS class:
|
2020-07-30 20:36:08 +02:00
|
|
|
|
|
|
|
|
|
``` html
|
|
|
|
|
<span class="twemoji">
|
|
|
|
|
{% include ".icons/fontawesome/brands/twitter.svg" %}
|
|
|
|
|
</span>
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
This is exactly what Material for MkDocs does in its templates.
|
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
[extending the theme]: ../customization.md#extending-the-theme
|
|
|
|
|
[include]: https://jinja.palletsprojects.com/en/2.11.x/templates/#include
|