label | order | icon | tags | |
---|---|---|---|---|
Project config |
200 |
package |
|
Retype will read the retype.yml
file for additional instructions on how to configure and build your project.
The retype.yml
file is typically placed in the root of your project, although it can be placed elsewhere. Please ensure the input
and output
paths are correct if moved to a different location.
!!!
After making a change to the retype.yml
, if you are running retype watch
, Retype will automatically rebuild the project for you and your web browser will refresh with the changes.
If you started the local web server using retype run
, you'll need to call retype build
to regenerate a ✨ sparkly ✨ fresh new build of the project, then manually refresh your web browser to see the update.
!!!
The retype.yml
file is actually optional (not required), but is recommended as you will almost certainly want to customize some options, so adding a retype.yml
is a good first step.
If you run the command retype watch
and do not have a retype.yml
project configuration file within the root of your project, Retype will auto-generate a simple retype.yml
file for your project. You can then edit the file to customize your project.
You can also explicitly have Retype generate a retype.yml
file by running the command retype init
.
The following sample demonstrates a common set of project configuration options and everything can be customized to your requirements.
input: .
output: .retype
url: example.com # Add your website address here
branding:
title: Project Name
label: Docs
links:
- text: Getting Started
link: https://retype.com/guides/getting-started/
footer:
copyright: "© Copyright {{ year }}. All rights reserved."
Branding configuration for your Retype generated website.
=== title : string
The main text title added to the upper-left corner of the generated website.
The title
can be used in conjunction with logo
and logoDark
. If a title
and logo
are configured, both will be added to the website. If only a title
is configured, only the text title is used. If only a logo
and/or logoDark
are configured, only the logos are used.
branding:
title: Example.com
The above title
would create the following branding title in the upper-left corner of the generated website.
=== label : string
Optional logo label text. Default is Docs
.
branding:
label: Docs
The label
is rendered as the following label in the upper-left corner of the generated website, to the right of the title
or logo
.
=== logo : string
One of the following:
- The path to a logo file relative to the
input
, or - An inline
<svg>
logo
Default is null
.
branding:
logo: static/logo.png
===
=== logoDark : string
One of the following:
- The path to a logo file (dark mode) relative to the
input
, or - An inline
<svg>
logo
Default is null
.
branding:
logo: static/logo.png
logoDark: static/logo-dark.png
===
=== logoAlign : string
Set a logo image alignment relative to the title
. Supported values include left
and right
.
Default is left
.
branding:
logo: static/logo.png
logoAlign: right
===
Custom color configuration.
!!!warning
Hex color values must be wrapped in "
double-quotes, otherwise the value is treated as a comment because of the unquoted #
character.
!!!
=== label.text : string
Set a custom label text color". Default is "#1f7aff"
.
branding:
colors:
label:
text: "#ffffff"
===
=== label.background : string
Set a custom label background color. Default is "#e1edff"
.
branding:
colors:
label:
background: "#ff0000"
===
Cache configuration options.
Cache busting configuration for the website resources. Helps to ensure a loaded page refers to the most recent JavaScript and CSS resources.
=== strategy : string
Specifies the approach Retype will use for cache invalidation.
Strategy | Description |
---|---|
none |
Cache invalidation is disabled. |
path |
Cache invalidation is achieved by concatinating the file name with a version token. |
query |
Cache invalidation is achieved by adding a query parameter with a version token value. |
Default is query
.
cache:
strategy: query
Below are demo URLs generated for corresponding cache.busting.strategy
options:
<script type="text/javascript" src="/resources/js/retype.js" />
<script type="text/javascript" src="/resources/js/retype.v1.10.js" />
<script type="text/javascript" src="/resources/js/retype.js?v=1.10" />
===
=== token : string
An optional unique token used for website resource cache invalidation.
- If specified, the provided value is used for all invalidatable resources as is.
- If not specified, the default token having the following structure is used:
{Retype version}.{total milliseconds elapsed since 2000-01-01}
===
=== cname : boolean
or string
!!!
In general, you should not require setting the cname
. Please set the url
.
!!!
By default, if the url
is set, Retype will automatically generate a CNAME
file. This can be disabled by setting cname: false
.
cname: false
If you do want a CNAME
file generated, but for some reason require a value different than what the url
creates, you can explicitly set instruct Retype to generate the CNAME
with a different value.
This would be a highly unusual scenario, but Retype does allow you to configure these values separately, just in case you need it. We HIGHLY recommend that you just stick with setting the url
.
cname: docs.example.com
===
The edit
config allows for enabling and customization of the Edit this page
links on content pages.
!!!
Check out the bottom of this page for a working sample of Edit this page
.
!!!
The repository URL where the source files for this project are located.
=== repo : string
Setting a repo
value will enable the Edit this page
links on all content pages.
edit:
repo: "https://github.com/<your-organization>/<your-repo>/"
You can also configurate the links to point directly to the /edit/
view of the page:
edit:
repo: "https://github.com/<your-organization>/<your-repo>/edit/"
===
An optional base path to a directory within the repository.
=== base : string
The base
can be configured with an optional path to a directory within the repo
.
The following sample demonstrates how edit.base
would be configured if the .md
pages for this project are stored within the /src/docs/
sub-directory within the repo.
edit:
repo: "https://github.com/your-organization/your-repo"
base: /src/docs
The final Edit this page URL constructed by Retype for the sample above would be https://github.com/your-organization/your-repo/blob/main/src/docs/your-page.md
.
===
=== branch : string
Point to a custom branch within the repo. Default is main
.
edit:
repo: "https://github.com/your-organization/your-repo"
branch: website
===
=== label : string
A custom label for the link. Default is "Edit this page"
.
edit:
repo: "https://github.com/your-organization/your-repo"
label: Edit on GitHub
===
Custom configuration to control the page live editor functionality that is only available when retype watch
is running.
To enable or disable the live editor. Default is true
.
=== enabled : boolean
Set to false
to disable and hide the live editor.
editor:
enabled: false # Default is true
===
=== exclude : list
Retype can exclude files or folders from being built or copied to the output
by configuring an exclude
list within your projects retype.yml
file.
Exclude patterns are similar to allowable patterns within a .gitignore
file. The wildcards ?
, *
, **
, and !
are supported.
The following sample demonstrates how to exclude an entire draft/
folder, any folder that ends with *_temp/
, and one specific /src/temp.md
file.
exclude:
- "draft/"
- "*_temp/"
- "/src/temp.md"
You could exclude everything in your project with by adding exclude: [ * ]
.
!!!
By default, any file or folder name prefixed with a .
or a _
will be excluded.
As well, any node_modules
folder will be excluded.
!!!
To explicitly include any files or folders that might have been excluded, please see the include
config.
=== favicon : string
A custom path to a .ico
or .png
file to be used as the favicon
. Default is null
.
The path is relative to the input
.
favicon: static/favicon.png
By default, Retype will look for a favicon.ico
or favicon.png
within the root of the input
. The favicon
config would typically only be used if you want to store the favicon
file in a subfolder of the output
root.
=== copyright : string
Site-wide copyright statement that will be added to the footer of each page. Supports Markdown syntax and {{ year }}
variable.
footer:
copyright: "© Copyright {{ year }}. [Example, Inc.](https://example.com/) All rights reserved."
===
=== links : object
The footer.links
have the same configuration options as links
.
footer:
links:
- text: License
link: license.md
===
=== recase : string
Instructs Retype on how to recase the project file and folder names created by the author. Default is all
.
By default, Retype will recase all the generated file and folder names to all lowercase.
Option | Description |
---|---|
all |
Covert all file and folder names in the generated output to all lowercase. This is the default. |
none |
Do not change the case of any file or folder names. |
To have Retype NOT change the casing of any of your file or folder names, set recase
to none
.
generator:
recase: none
===
=== include : list
Retype can explicitly include files or folders that might have been excluded by default or excluded within the exclude
config.
!!!
If you create a link to local static file, such as .zip
file, Retype will automatically copy that file to the generated website.
That file or file type does not need to be explicitly configured to be included. Retype assumes that if you created a link to the file, you wanted that file published and it will be included in the output
.
!!!
Include patterns are similar to allowable patterns within a .gitignore
file. The wildcards ?
, *
, **
, and !
are supported.
The following sample demonstrates how to include all .py
files, all .js
files that start with the name demo
, and the entire contents of any www
folder within the project.
include:
- "*.py"
- "demo*.js"
- "**/www/**"
You could explicitly include everything in your project with include: [ "*" ]
, but be careful as all files within your input
will be publicly availble once your website is published. We would not recommend doing this, but it's your call. 😨
Retype treats all .md
and .yml
files as parsable content files that will be converted into .html
files and are not copied over to the output
. All other included file types would be copied straight across to the output
unchanged and become static files that can be linked to.
By default, if Retype discovers any of the following file types, they will be automatically included and copied over to the output
unchanged. If you require any other file types, they would need to be explicitly added to the include
config.
File types that are automatically included:
*.ai
*.bmp
*.eps
*.gif
*.heif
*.htm
*.html
*.jpeg
*.jpg
*.pdf
*.png
*.svg
*.tiff
*.txt
*.webp
*.zip
By default, if Retype discovers any of the following folders anywhere within the project, the folder and its entire contents will be copied over to the output
unchanged. If you require any other folders, please add to the include
config.
Included folders:
**/static/**
**/public/**
**/assets/**
**/resources/**
If you would rather not include certain folders, files, or file types, please add the pattern to the exclude
config.
===
=== input : string
Custom path to the input directory. Default is .
.
The path is relative to the retype.yml
location.
input: ./src
===
More integrations
will be added over time. Do you have an integration suggestion? let us know.
Add Google Analytics to your website.
=== googleAnalytics.id : string
Google Analytics ID value.
integrations:
googleAnalytics:
id: <id>
Replace the <id>
with your Google Analytics measurement id. For example:
integrations:
googleAnalytics:
id: A-BCDEFGHIJ1
===
Add the Google Tag Manager to your website.
=== googleTagManager.id : string
Google Tag manager ID value.
integrations:
googleTagManager:
id: <id>
Specific setting to control Retype integration with the Gravatar profile picture service and used by the page.authors configuration.
=== gravatar.default : string
The default profile image to return from Gravatar queries whenever no image is assigned to the queried email address. Default value is mp
.
Either a full URL to the image can be configured or one of the options listed below:
Value | Sample |
---|---|
404 |
Broken image |
mp (default) |
|
identicon |
|
monsterid |
|
wavatar |
|
retro |
|
robohash |
|
blank |
Blank image |
Please see the Default Image documentation on the Gravatar website.
===
=== gravatar.enabled : boolean
Whether Retype should use Gravatar to pull profile images. Default is true
.
Setting to false
will show the default image or specified resource.
!!!
Disabling Gravatar will also reset the default avatar to the Retype default.
!!!
===
Plausible.io is a simple and privacy-friendly Google Analytics alternative which can be integrated easily into Retype generated websites.
=== plausible.domain : string
When you setup your project within Plausible, you enter a Domain
value which is then used to set the integrations.plausible.domain
config within your retype.yml
project configuration file.
integrations:
plausible:
domain: <string>
Plausible can also send statistics to multiple dashboards by configuring a comma-separated list of domains. For example:
integrations:
plausible:
domain: domain1.com,domain2.com,subdomain.yourdomain.com
Check out the Plausible documentation for more details.
===
=== plausible.host : string
The Plausible service can be self-hosted and your Retype project can be configured to use your custom host
.
integrations:
plausible:
host: <string>
A typical host
project configuration would look like the following sample:
integrations:
plausible:
host: plausible.example.com
If no transfer protocol is supplied, Retype will default the host
value to use https
.
All of the following sample host
values are supported:
host: example.com
host: docs.example.com
host: https://example.com
host: http://example.com
host: example.com/js/plausible.js
host: docs.example.com/js/plausible.js
===
Custom links added to the top-bar navigation of all pages.
The following sample demonstrates a basic links
scenario which would add one link to the top bar of all pages.
links:
- text: Getting Started
link: https://retype.com/getting_started/
=== text : string
The link text label.
links:
- text: Demos
link: https://demo.example.com/
===
=== link : string
The URL to use for the link. The link can be a .md
file name, or to any internal path, or to any external URL.
If a .md
file set, such as sample.md
, Retype will automatically resolve the path and in the generated website, the sample.md
value will be replaced with the path to the actual generated HTML file.
links:
- text: About us
link: /about/
===
=== icon : string
An icon to use with the link. Default is null
.
links:
- text: Issues
link: https://github.com/retypeapp/retype/issues/
icon: bug
Options include using an Octicon name, Emoji shortcode, <svg>
element, or a path to an image file.
icon: rocket
icon: ":rocket:"
icon: <svg>...</svg>
icon: ../static/rocket.png
===
=== iconAlign : string
The position for the icon relative to the link text
. Either left
or right
. Default is left
.
links:
- text: Demos
link: https://demo.example.com/
icon: link-external
iconAlign: right
===
=== target : string
Sets the target
attribute of the hyperlink and specifies which window or tab to open the link into.
links:
- text: Demos
link: https://demo.example.com/
target: blank
If no target
is configured, the link will open in the current tab.
The target
can be set to any value, although blank
is common and will open the link in a new tab. Retype will automatically transform the value blank
into _blank
which is the actual value required by the browser to indicate that a hyperlink should be opened in a new tab.
There are several other values that may be prefixed with an _
character, including self
, parent
, and top
. The following table demonstrates some common scenarios and naming convention used by Retype to normalize the target
values.
Config target value |
Runtime target value |
---|---|
blank |
_blank |
parent |
_parent |
top |
_top |
self |
_self |
news1 |
news1 |
nEWs2 |
news2 |
recent NEWS |
recent-news |
===
Markdown configuration options.
=== lineBreaks : string
Switches between soft
and hard
line break modes. The option instructs Retype in what way a regular line ending should be handled.
- in
soft
mode, regular line breaks are processed as soft breaks (no<br />
is emitted to HTML markup), unless a line contains 2+ spaces before a line break. - in
hard
mode, regular line breaks are always emitted as<br />
HTML elements.
Default is soft
.
markdown:
lineBreaks: soft # or, hard
===
Project wide meta tag configuration options.
=== title : string
Common site-wide suffix appended to the html <title>
element of all pages. Default is null
.
meta:
title: " | Example.com - Widgets for the internet"
If we had an About us
page, the final <title>
with the title
value above would be:
<title>About us | Example.com - Widgets for the internet</title>
=== output : string
Custom path to the output directory. Default is .retype
.
The path is relative to the retype.yml
location.
output: ./docs
===
Controls whether to include or exclude the Powered by Retype
branding.
=== [!badge PRO] poweredByRetype : boolean
With a Retype Pro license, the Powered by Retype
branding can be removed by setting to false
.
poweredByRetype: true # Set to `false` to remove.
===
Customization of the website search component.
=== hotkeys : list
Keyboard key to set the cursor focus into the search field. Default is ["/"]
.
search:
hotkeys:
- "/"
===
=== maxResults : number
Max number of search results to render. Default is 20
.
search:
maxResults: 20
===
=== minChars : number
Min number of characters required in a search query. Default is 2
.
The following sample demonstrates how to configure search.minChars
with a new value:
search:
minChars: 3
===
=== mode : string
The search index creation mode. Default is full
.
Mode | Description |
---|---|
full |
A full-text search index of the project content is made. Includes all headings and all text content. |
partial |
All headings plus the first paragraph under each heading is used to create the search index. The Page description config is also included if not empty. |
basic |
All headings plus only the first paragraph of each page is used to create the search index. The Page description config is also included if not empty. |
The following sample demonstrates how to configure search.mode
with a new value:
search:
mode: partial
!!!
If your project includes a lot of content and your users find the search is running too slow, try changing to mode: partial
or even a mode: basic
if the website is really huge.
!!!
=== noResultsFoundMsg : string
Message rendered when no results were found. Default is "Sorry, no results found."
.
search:
noResultsFoundMsg: Sorry, no results found.
===
=== placeholder : string
Placeholder text rendered on the search component. Default is "Search"
.
search:
placeholder: Search
===
Custom configuration for the built in Retype development web server.
=== host : string
Serve the website from this host location. Default is localhost
.
server:
host: 127.0.0.1
By default, the Retype development web server will serve from http://localhost:5000
, although the port could be dynamically assigned if port 5000
is already in use.
A custom port value can also be assigned.
server:
host: 127.0.0.1:5005
A custom --host
value can also be passed as an argument to the retype watch
and retype run
commands. If included, the --host
value will override the host
set within your retype.yml
project configuration file.
retype watch --host 127.0.0.1 # serve from a custom host
retype watch --host 127.0.0.1 --port 5005 # serve from a custom host and port
===
=== port : number
A custom port for the internal Retype development web server to use when hosting locally. Default is 5000
.
server:
port: 5005
If the default port is already being used by another service, Retype will auto-increment the port number until it finds an open port to host from.
If a custom port
is explicitly configured in the retype.yml
and if that port is already being used by another service, Retype will write a message to the console and exit. In that scenario, because the port
was explicitly configured, Retype will not attempt to auto-increment.
!!!
The port number can also be included in the host
config.
!!!
A custom --port
value can also be passed as an argument to the retype watch
and retype run
commands. If included, the --port
value will override the port
set within your retype.yml
project configuration file.
retype watch --port 5005 # serve from a custom port
===
Custom configuration for the retype watch
command.
=== mode : string
During retype watch
, the mode
configuration instructs the web server on where to host files from.
If memory
, the entire website is built and then stored in memory during development with no files being written to disk.
If disk
, the entire website is built and written to disk, then the web server will host those files from their disk location.
Default is memory
.
Mode | Description |
---|---|
memory |
No output files are written to a disk. Retype serves a website from the in-memory storage. |
disk |
Output files are written to the output directory, and updated with each incremental build accordingly. |
server:
watch:
mode: disk
The command retype build
will always build and write all files to disk. The memory
configuration is not an option with retype build
. The Retype GitHub Action uses retype build
. The command retype watch
is only to be used during local development.
===
=== polling : boolean
or number
Instructs retype watch
on how it should listen for file changes.
If false
, the native filesystem event listeners are used to monitor for file changes.
If true
, Retype will poll for file changes within your projects input directory. By default, the polling interval is 1000 milliseconds (1 second)
The poll interval is configurable by setting a number
value. For instance, setting polling: 500
would configure a 500ms interval.
Default is false
.
Polling | Description |
---|---|
false |
Use native filesystem event listeners to receive file change notifications the project input directory. |
true |
Poll the input directory for changes every 1000 milliseconds (1 second). |
number |
Poll the input directory in milliseconds. |
server:
watch:
polling: true
!!! Performance Warning Disk polling may be a costly operation, especially in projects with a large quantity of files, and/or running over remote mounted directories (ftp mapping, NFS, SMB...). If configuring the poll interval, please adjust the value down in steps, monitoring performance as the poll interval decreases.
On the flip side, increasing the polling interval may cause an annoying experience during retype watch
as file changes will require a longer time before reflected in the browser.
!!!
===
=== validation : string
Configure how thorough Retype is while looking for changed files.
Until Retype version 1.10, the approach used was equivalent to full
.
Default value is optimal
.
Validation | Description |
---|---|
fast |
Compare file system metadata only (reported file size and last modification time). |
full |
Perform full SHA2 comparison on every tracked file. |
optimal |
Compare file system metadata and, for every file with changes, perform SHA2 comparison. |
===
The snippets
configuration allows for the project with custom configuration of code block formatting, including the project wide enabling of line numbering.
=== lineNumbers : list
A list of code block reference language strings to enable line numbering on. Default is null
.
snippets:
lineNumbers:
- js
- json
Configuring the "*"
wildcard will enable line numbering for all code block types, including code blocks with no explicit reference language.
snippets:
lineNumbers:
- *
Enabling line numbering site wide on code blocks with no explicit reference language is configured with the none "none"
specifier.
snippets:
lineNumbers:
- none
===
Configurations to control the Retype content templating engine for this project.
=== enabled : boolean
A project-wide option to enable or disable the Retype content templating engine. Default is true
.
templating:
enabled: true # Set to false to diable
The templating engine can also be disabled on a per-page basis by setting templating: false
in the page metadata.
===
=== liquid : boolean
Specifies if Liquid syntax {% ... %}
is enabled. If liquid: true
is set, Retype is incompatible with GitBook style of component configuration.
Default is false
.
templating:
liquid: false # Set to true to enable
===
=== url : string
The base URL of your website.
url: example.com
The url
can also be a sub-domain.
url: docs.example.com
If you deploy your Retype generated website into the subfolder of another website, add the subfolder in the url
. For example, if the website will be available at https://example.com/docs
, add that docs
folder name to the url
.
url: example.com/docs
If no protocol is supplied, such as https
or http
, Retype will assume https
. A protocol can be explicitly defined by passing in the url
.
url: http://example.com/docs/
Another common scenario for setting a url
is when using GitHub Pages without a custom CNAME
.
For instance, if your GitHub organization was CompanyX
and your repo was named docs
, the URL to your GitHub Pages hosted website would be https://companyx.github.io/docs/
.
Retype needs to know where your website will be hosted, so the url
configuration for the above scenario would be:
url: companyx.github.io/docs
===
Option | Type | Default value | Description |
---|---|---|---|
api |
object |
API reference doc generation | |
api.input |
string |
Path to a project file or a project directory | |
api.output |
string |
./api |
Custom path to the API output directory. Relative to output |