Skip to main content

Convert a theme to CleanSlate

CleanSlate uses a template language called Radius. Therefore, all tags will look something like <r:my_tag />.

For a more in-depth description of the various tags available, visit the Tag Index.

NOTE: CleanSlate actually supports two templating languages: Radius and Liquid. As of 2021, Liquid is the recommended templating language because it's far more performant than Radius. The Radius templating language will be depreciated in the future. Themes should use Liquid moving forward.

It's dangerous to go alone! Take this.

After several years and hundreds upon hundreds of themes for Slate and CleanSlate, we've learned the best themes are made when you start with a boilerplate. We maintain a number of boilerplates for CleanSlate themes. One of them is called the CleanSlate Toolkit. When you're starting to convert a theme to CleanSlate, use the CleanSlate Toolkit as your base and build off of it. It's very bare bones, delete key friendly and will save you time.

NOTE: If you're starting fresh and building a theme from scratch, we recommend starting with the WVU Design System, Supertheme or Brand Patterns. The CleanSlate Toolkit is a great barebones theme—best for getting to know CleanSlate and providing simple examples—but these newer themes are actively maintained, branded, more feature rich and accessible.

Without further adieu, let's see how to get your theme up and running in CleanSlate:

Screencast: Converting a Theme

Learn how to convert your theme to CleanSlate—start to finish—in 30 minutes:

CleanSlate Theme Development Tutorial Series
Making a CleanSlate Theme

Or, view this video on YouTube. Also, check out the blog post for a more detailed breakdown of the different parts of the video.

Linking stylesheets:

HTML: <link href="http://mysite.wvu.edu/stylesheets/styles.css" rel="stylesheet">

CleanSlate: <r:include_stylesheet name="styles" />

Or, if your stylesheet is in a subfolder of your stylesheetsdirectory:

HTML: <link href="http://mysite.wvu.edu/stylesheets/path/to/awesome/styles.css" rel="stylesheet">

CleanSlate: <r:include_stylesheet name="path/to/awesome/styles" />

Bonus:

You can include multiple stylesheets at once by passing a comma separated list to the include_stylesheettag. Each file will be compressed (if you have it enabled in your config.ymlfile) and all files will be combined into one.

HTML:

<link href="http://mysite.wvu.edu/stylesheets/reset.css" rel="stylesheet">
<link href="http://mysite.wvu.edu/stylesheets/fonts.css" rel="stylesheet">
<link href="http://mysite.wvu.edu/stylesheets/styles.css" rel="stylesheet">

Cleanslate: <r:include_stylesheet name="reset, fonts, styles" />

If you have a stylesheet in a subdirectory of stylesheets, simply include the path:

<r:include_stylesheet name="reset, fonts, path/to/awesome/styles" />

Linking JavaScript:

HTML: <script src="../javacripts/jquery.js"></script>

CleanSlate: <r:include_javascript name="jquery" />

Bonus: Much like stylesheets, you can also include multiple JavaScript files in one radius tag:

HTML:

<script src="../javacripts/jquery.js"></script>
<script src="../javacripts/jquery.backstretch.js"></script>
<script src="../javacripts/jquery.custom.js"></script>

CleanSlate: <r:include_javascript name="jquery, jquery.backstretch, jquery.custom" />

Linking up a Stylesheet or JavaScript file from outside your theme

The syntax doesn't change here. Please note:  always link to the HTTPS resource. You may need to change http to https.

HTML & CleanSlate: <link href="https://mysite.wvu.edu/path/to/styles.css" rel="stylesheet">

If the asset you're linking to doesn't exist over HTTPS, consider downloading it and hosting it from your theme.

Linking up images inside your theme:

HTML: <img src="../images/my-image.jpg" alt="Foo bar" />

CleanSlate: <img src="<r:image_url name="my-image.jpg" />" alt="Foo bar" />

Outputting your main navigation in a <ul>:

CleanSlate: <r:site_menu />

Want to add a classor idto your <ul>? No problem!

Class: <r:site_menu ul_class="your-class-here" />

ID: <r:site_menu ul_id="your-id-here" />

Making an editable region:

Slate: <%= content_for(:main) %>

CleanSlate: <r:editable_region name="main" />

Editable region names ( name="xyz") must not have any spaces, punctuation or upper case letters. Additionally, each editable region name must be unique. No two editable regions can be named identically in the same page template (e.g., You cannot have two name="xyz"in one template. Weird stuff will happen).

Making a "Simple" editable region:

In CleanSlate, you can create editable regions without WYSIWYG abilities. We call these simple editable regions. These regions are appropriate for titles, headlines or any area where you want just the content and not the styles.

CleanSlate: <r:editable_region name="main" type="simple" />

Making an editable region with site wide content:

Slate: <%= content_for(:contact) %>then click the heart icon in the editor.

CleanSlate: <r:editable_region name="contact" scope="site" />

If you make an editable region, then later decide to make it an editable region with global content, best practice is to give the region a new name in the name="xyz"field to avoid confusion in the CleanSlate database (and on your pages!).

Include a partial in your theme:

CleanSlate allows you to modularize your code into partials. Partials must live somewhere inside the root views folder, start with an underscore and end in .html. Example: _my-partial.html.

Slate: <%= partial :footer -%>

CleanSlate: <r:partial name="footer" />

You can also nest partials into different folders inside the views folder. For example, if you had a partial at views/custom-patterns/_my-partial.html:

CleanSlate: <r:partial name="custom-patterns/my-partial" />

For more information about partials, including learning about "Shared Partials", view the page dedicated to Partials.

Outputting breadcrumbs in a <ul>:

CleanSlate: <r:breadcrumbs ul_class="breadcrumbs" />

CleanSlate uses a template language called Liquid. Therefore, all tags will look something like {% my_tag %} or {{ my.tag }}.

A company called Shopify created Liquid. Shopify has a number of learning resources available. One that is particularly helpful is this 28 minute Overview of Liquid video on YouTube. While not everything will translate 100% to CleanSlate, it will give you a good understanding of the core language and how it's used. For a more in-depth description of the various tags available, visit the Tag Index.

NOTE: CleanSlate actually supports two templating languages: Radius and Liquid. As of 2021, Liquid is the recommended templating language because it's far more performant than Radius. The Radius templating language will be depreciated in the future. Themes should use Liquid moving forward.

It's dangerous to go alone! Take this.

After several years and hundreds upon hundreds of themes for Slate and CleanSlate, we've learned the best themes are made when you start with a boilerplate. We maintain a number of boilerplates for CleanSlate themes. One of them is called the CleanSlate Toolkit. When you're starting to convert a theme to CleanSlate, use the CleanSlate Toolkit as your base and build off of it. It's very bare bones, delete key friendly and will save you time.

NOTE: If you're starting fresh and building a theme from scratch, we recommend starting with the WVU Design System, Supertheme or Brand Patterns. The CleanSlate Toolkit is a great bare bones theme—best for getting to know CleanSlate and providing simple examples—but these newer themes are actively maintained, branded, more feature rich and accessible.

Without further adieu, let's see how to get your theme up and running in CleanSlate:

Linking stylesheets:

HTML: <link href="http://mysite.wvu.edu/stylesheets/styles.css" rel="stylesheet">

CleanSlate: {% link_stylesheet name: "styles" %}

Or, if your stylesheet is in a subfolder of your stylesheets directory:

HTML: <link href="http://mysite.wvu.edu/stylesheets/path/to/awesome/styles.css" rel="stylesheet">

CleanSlate: {% link_stylesheet name: "path/to/awesome/styles" %}

Bonus:

You can include multiple stylesheets at once by passing a comma separated list to the link_stylesheet tag. Each file will be compressed (if you have it enabled in your config.yml file) and all files will be combined into one.

HTML:

<link href="http://mysite.wvu.edu/stylesheets/reset.css" rel="stylesheet">
<link href="http://mysite.wvu.edu/stylesheets/fonts.css" rel="stylesheet">
<link href="http://mysite.wvu.edu/stylesheets/styles.css" rel="stylesheet">

CleanSlate: {% link_stylesheet name: "reset, fonts, styles" %}

If you have a stylesheet in a subdirectory of stylesheets, simply include the path:

{% link_stylesheet name: "reset, fonts, path/to/awesome/styles" %}

Linking JavaScript

HTML: <script src="../javacripts/jquery.js"></script>

CleanSlate: {% link_javascript name: "jquery" %}

Bonus: Much like stylesheets, you can also include multiple JavaScript files in one Liquid tag:

HTML:

<script src="../javacripts/jquery.js"></script>
<script src="../javacripts/jquery.backstretch.js"></script>
<script src="../javacripts/jquery.custom.js"></script>

CleanSlate: {% link_javascript name: "jquery, jquery.backstretch, jquery.custom" %}

Linking up a stylesheet or JavaScript file from outside your theme

The syntax doesn't change here. Please note: always link to the HTTPS resource. You may need to change http to https.

HTML & CleanSlate: <link href="https://mysite.wvu.edu/path/to/styles.css" rel="stylesheet">

If the asset you're linking to doesn't exist over HTTPS, consider downloading it and hosting it from your theme.

Linking up images inside your theme

HTML: <img src="../images/my-image.jpg" alt="Foo bar" />

CleanSlate: <img src="{% theme_image_url name: "my-image.jpg" %}" alt="Foo bar">

Outputting your main navigation in a <ul>:

CleanSlate: {% site_menu %}

Want to add a class or id to your <ul>? No problem!

Class: {% site_menu ul_class: "your-class-here" %}

ID: {% site_menu ul_id: "your-id-here" %}

Making an editable region:

CleanSlate (Radius): <r:editable_region name="main" />

CleanSlate (Liquid): {% editable_region name: "main" %}

Editable region names (name: "xyz") must not have any spaces, punctuation or upper case letters. Additionally, each editable region name must be unique. No two editable regions can be named identically in the same page template (e.g., You cannot have two name: "xyz" in one template. Weird stuff will happen).

Making a "simple" editable region:

In CleanSlate, you can create editable regions without WYSIWYG abilities. We call these simple editable regions. These regions are appropriate for titles, headlines or any area where you want just the content and not the styles.

CleanSlate (Radius): <r:editable_region name="main" type="simple" />

CleanSlate (Liquid): {% editable_region name: "main", type: "simple" %}

Making an editable region with site wide content:

CleanSlate (Radius): <r:editable_region name="contact" scope="site" />

CleanSlate (Liquid): {% editable_region name: "contact", scope: "site" %}

If you make an editable region, then later decide to make it an editable region with global content, best practice is to give the region a new name in the name: "xyz" field to avoid confusion in the CleanSlate database (and on your pages!).

Making an editable region with default content:

There are a few ways to do this. One with a simple string and another with whatever content and HTML you would like:

CleanSlate (Radius):

<r:editable_region name="main">
  My default content goes here.
</r:editable_region>

CleanSlate (Liquid):

{% editable_region name: "main", placeholder: "My default content goes here." %}

OR:

{% editable_region_block name: "main" %}
  My default content goes here.
{% endeditable_region_block %}

Note the difference between editable_region and editable_region_block.

Include a partial in your theme:

CleanSlate allows you to modularize your code into partials. Partials must live somewhere inside the root views folder, start with an underscore and end in .html. Example: _my-partial.html.

CleanSlate (Radius): <r:partial name="my-partial" />

CleanSlate (Liquid): {% render "my-partial" %}

You can also nest partials into different folders inside the views folder. For example, if you had a partial at views/custom-patterns/_my-partial.html:

CleanSlate (Radius): <r:partial name="custom-patterns/my-partial" />

CleanSlate (Liquid): {% render "custom-patterns/my-partial" %}

For more information about partials, including learning about "Shared Partials", view the page dedicated to Partials.

Outputting breadcrumbs in a <ul>:

CleanSlate (Radius): <r:breadcrumbs ul_class="breadcrumbs" />

CleanSlate (Liquid): {% breadcrumbs ul_class: "breadcrumbs" %}

Last updated on July 20, 2022.

We welcome all questions, feedback and bug reports. If you're having an issue, we usually need the following information:

  • A brief description of the issue
  • A link to the page where you saw the issue
  • Screenshots that illustrate the problem - How do I take a screenshot?

Kindly email CleanSlate@mail.wvu.edu for help or use the form on the request help page.