Add a Page
A page is a URL-addressable web page.
A page can be configured with a Markdown file, which is the most common approach for repeated content, such as blog posts. A page can also be configured with a Jinja template, which is the most common approach for one-off pages, such as a landing page, or a contact page.
A Page from Markdown
To create a new page, first select a desired URL path.
/posts/my-blog-post
Page URL paths are based on directory structure. Create directories that match your desired path, along with a Markdown file whose name matches your final path segment.
/posts
my-blog-post.md
Inside the Markdown file, add Front Matter configuration, to tell Static Shock how to generate the final page. Also, add Markdown content, which will be used as the primary content for the generated page.
---
title: My Blog Post
layout: layouts/blog-post.jinja
---
# My Blog Post
This is where the main content goes.
With this configuration, you can run a Static Shock build.
dart bin/my_project.dart
When running the build, Static Shock takes the following steps:
- Finds the Markdown file in the source set
- Looks up the layout template referenced by the Markdown file
- Fills the template with the data and content form the Markdown file
- Places a copy of the filled template HTML file in the correct directory in the build set
Continuing with our example, after running a Static Shock build, an HTML file is generated in the build set.
/build/posts/my-blog-post/index.html
You now have a static HTML page that you can serve to users, and it's available at your desired URL path.
A Page from a Jinja Template
To create a new page, first select a desired URL path.
/help/contact-us
Page URL paths are based on directory structure. Create directories that match your desired path, along with a Jinja file whose name matches your final path segment.
/help
contact-us.jinja
Inside the Jinja file, add Front Matter configuration, to tell Static Shock how to generate the final page. Also, add HTML and Jinja template content, which will directly translate into the final HTML for the page.
<!--
title: Contact Us
-->
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>{{ title }}</title>
<!-- Fill with whatever header configurations you'd like -->
</head>
<body>
<!-- Fill with whatever HTML and Jinja blocks that you'd like -->
</body>
</html>
With this configuration, you can run a Static Shock build.
dart bin/my_project.dart
When running the build, Static Shock takes the following steps:
- Finds the Jinja file in the source set
- Fills the Jinja blocks with incoming data
- Places a copy of the filled template HTML file in the correct directory in the build set
Continuing with our example, after running a Static Shock build, an HTML file is generated in the build set.
/build/help/contact-us/index.html
You now have a static HTML page that you can serve to users, and it's available at your desired URL path.
Change the base path of the URL
For many websites, the source directory structure works well for the final URL, such as /guides/getting-started.md
being deployed to mysite.com/guides/getting-started/
. However, for some websites, the best directory
structure doesn't necessarily match the desired URL. For example, a blog might store a post at
/posts/my-post.md
but the blog author would like to serve that post at myblog.com/my-post/
.
Static Shock allows you to override the base path of the final URL. The base path is the path that
appears before the final path segment, e.g., given /posts/my-post/
the base path is /posts
. To
override the default base path, specify a different value for basePath
for a given page, or
within a _data.yaml
file to apply the change to entire directory.
---
title: My Blog Post
basePath: /
---