selfdefined/11ty/documentation/front-matter.md
Kathryn Grayson Nanz b872dbe384
Add new front matter element: excerpt (#227)
* This commit adds the excerpt front matter element, to show an
abbreviated version of the definition in social previews. This
also includes the documentation updates to support this change.

* This commit adds @olvb's suggestion to use 'set' to define the
alert & preview combo, to avoid repetitive code

* This commit updates the preview text to only include the flag if
it's "avoid" – if the flag is "warning" or there is no flag, it
will not appear at the beginning of the preview text.

Co-authored-by: Kathryn Grayson Nanz <kathryn@Kathryns-MacBook-Air.local>
Co-authored-by: Oscar <ovlb@users.noreply.github.com>
Co-authored-by: Kathryn <>
2020-08-24 19:41:45 +02:00

207 lines
5.2 KiB
Markdown
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

---
title: Front Matter
parent:
title: Documentation
href: '/documentation'
---
We use Front Matter for a range of things. Of course, we provide basic information through it. But also more advanced stuff (technical term) such as sub terms for items in the table of content or further reading links for the definition.
This page will tell you all you need to know.
Note: We also maintain a list of annotated, complete example definitions, which you can grab and go. They are listed on the [Examples documentation page](/documentation/examples).
## Title
| Key | Type | required |
| ----- | ------ | -------- |
| title | String | true |
The complete title of a definition.
### Example
```yaml
title: Obsessive Compulsive Disorder (OCD)
```
## Slug
| Key | Type | required |
| ---- | ------ | -------- |
| slug | String | true |
A link-friendly version of the title.
### Example
```yaml
slug: obsessive-compulsive-disorder
```
## Defined
| Key | Type | required |
| ------- | ------- | -------- |
| defined | Boolean | true |
Whether or not the definition of this word is finished and should be displayed publicly.
### Example
```yaml
defined: true
```
## Excerpt
| Key | Type | required |
| ------- | ------- | -------- |
| excerpt | String | true |
An abbreviated version of the definition that will appear in social media previews. In the social preview, the excerpt will be prefaced with the flag level.
### Example
```yaml
excerpt: This is the short version of the definition that will appear in social previews.
```
## Speech
| Key | Type | required |
| ------ | ------ | -------- |
| speech | String | true |
The type of word. E.g. a noun or an adjective
Note: If it is an adjective please use the abbreviation “adj”.
### Example
```yaml
speech: noun
```
## Skip in Table of Content
| Key | Type | required |
| ------------------------ | ------- | -------- |
| skip_in_table_of_content | Boolean | false |
If set to true, the word will not be shown in the table of content. This is helpful for words such as «fatphobia» that are linked as [sub terms](#sub-terms) of «Fat» and «-phobia». Can be omitted, if not `true`.
### Example
```yaml
skip_in_table_of_content: false
```
## Flag
| Key | Type | required |
| ---- | ------ | -------- |
| flag | Object | false |
A word is an ableist slur? Or a better alternative for another word? Thats what flags are for. Flags are a bit more involved. Lets take a deeper look at them.
Flags _can_ consist of these properties:
- `level`: Either `avoid`, `tool` or `better-alternative`. Used to render the icon.
- `text`: Additional info about the flag. E.g. “Tool of Oppression” or “Racist Slur”.
- `for`: Only applicable if `level` is `better-alternative`. Title of the word that should be replaced with the current word. [Note: Currently discarded during rendering.]
Lets take a look at some examples.
### Examples
Items that have a flag level of `avoid` will be marked in the table of content. We could structure it as follows:
```yaml
flag:
level: avoid
text: 'Racist Symbol'
```
A level of `tool` designates words that are used, as an example, to facilitate white supremacy. These words are not flagged in the table of content. Lets take a look:
```yaml
flag:
level: tool
text: 'White Supremacy Tool'
```
And finally we have the words that are more suitable then others.
```yaml
flag:
level: 'better-alternative'
for: 'minorities'
```
Note: For is currently not used but might be implemented in a future version.
## Further Reading
| Key | Type | required |
| ------- | ---- | -------- |
| reading | List | false |
Provides a list of helpful links to further information about the discussed word. These links _must_ be objects with the keys `text` and `href`.
### Example
```yaml
reading:
- text: Minority vs minoritze
href: https://www.theodysseyonline.com/minority-vs-minoritize
```
## Alternative Words
| Key | Type | required |
| --------- | ---- | -------- |
| alt_words | List | false |
Adds a list of words that might be used instead of the described one. If a word in the list is defined it will automatically be linked.
### Example
```yaml
alt_words:
- conscientious
- exact
- fastidious
- fussy
- meticulous
- nitpicky
- particular
- precise
- quirky
- thorough
```
## Sub Terms
| Key | Type | required |
| --------- | ---- | -------- |
| sub_terms | List | false |
Provides a list of helpful links to further information about the discussed word. These links _must_ be objects with the keys `text` and `full_title`. If a `full_title` is found in the list of the defined words, the item is automatically linked to this word.
In the following example the words «Fatphobia» or «Fat Shaming» will be linked if these are the [title](#title) of another definition. For these words [Skip in Table of Content](#skip-in-table-of-content) might be set to `true`.
### Example
```yaml
sub_terms:
- text: -phobia
full_title: Fatphobia
- text: Shaming
full_title: Fat Shaming
- text: Activism
full_title: Fat Activism
- text: Liberation
full_title: Fat Liberation
```