179 lines
5.8 KiB
Markdown
179 lines
5.8 KiB
Markdown
---
|
|
title: "Layouts"
|
|
permalink: /docs/layouts/
|
|
excerpt:
|
|
sidebar:
|
|
title: "v3.0"
|
|
nav: docs
|
|
single_layout_gallery:
|
|
- image_path: mm-layout-single-header.png
|
|
alt: "single layout with header example"
|
|
- image_path: mm-layout-single-meta.png
|
|
alt: "single layout with comments and related posts"
|
|
---
|
|
|
|
{% include base_path %}
|
|
{% include toc icon="columns" title="Included Layouts" %}
|
|
|
|
The bread and butter of any theme. Below you'll find the layouts included with Minimal Mistakes, what they look like and the type of content they've been built for.
|
|
|
|
## Default
|
|
|
|
The base layout all other layouts inherit from. There's not much to this layout apart from pulling in several `_includes`:
|
|
|
|
* `<head>` elements
|
|
* masthead navigation links
|
|
* {% raw %}`{{ content }}`{% endraw %}
|
|
* page footer
|
|
* scripts
|
|
|
|
**Note:** You won't ever assign this layout directly to a post or page. Instead all other layouts will build off of it by setting `layout: default` in their YAML Front Matter.
|
|
{: .notice--warning}
|
|
|
|
## Compress
|
|
|
|
A Jekyll layout that compresses HTML in pure Liquid.
|
|
|
|
* [Documentation](http://jch.penibelst.de/)
|
|
|
|
## Single
|
|
|
|
The layout you'll likely use the most --- thin sidebar on the left, main content on the right.
|
|
|
|
{% include gallery id="single_layout_gallery" caption="Image header and meta info examples for `single` layout" %}
|
|
|
|
To enable add `layout: single` or better yet apply as a [Front Matter default]({{ base_path }}/docs/configuration/#front-matter-defaults) in `_config.yml`.
|
|
|
|
### Header
|
|
|
|
To add some visual punch to a post or page, a large full-width header image can be included.
|
|
|
|
**Note:** Be sure to resize your header images. `~1280px` is a good medium if you aren't [responsively serving up images](http://alistapart.com/article/responsive-images-in-practice). Through the magic of CSS they will scale up or down to fill the container. If you go with something too small it will look like garbage when upscaled, and something too large will hurt performance.
|
|
{: .notice--warning}
|
|
|
|

|
|
|
|
Place your images in the `/images/` folder and add the following YAML Front Matter:
|
|
|
|
```yaml
|
|
header:
|
|
image: image-filename.jpg
|
|
```
|
|
|
|
For externally hosted images include the full image path instead of just the filename:
|
|
|
|
```yaml
|
|
header:
|
|
image: http://some-site.com/image.jpg
|
|
```
|
|
|
|
To include a caption or attribution for the image:
|
|
|
|
```yaml
|
|
header:
|
|
image: unsplash-image-1.jpg
|
|
caption: "Photo credit: [**Unsplash**](https://unsplash.com)"
|
|
```
|
|
|
|
**ProTip:** Captions written in Markdown are supported, so feel free to add links, or style text. Just be sure to wrap it in quotes.
|
|
{: .notice--info}
|
|
|
|
### Header Overlay
|
|
|
|
To overlay text on top of a header image you have a few more options:
|
|
|
|
* `overlay_image` --- header image you'd like to overlay. Same rules as `header.image` from above.
|
|
* `excerpt` --- auto-generated page excerpt is added to the overlay text or can be overridden.
|
|
* `cta_label` --- call to action button text label (default is `more_label` in UI Text data file)
|
|
* `cta_url` --- call to action button URL
|
|
|
|
With this YAML Front Matter:
|
|
|
|
```yaml
|
|
excerpt: "This post should display a **header with an overlay image**, if the theme supports it."
|
|
header:
|
|
overlay_image: unsplash-image-1.jpg
|
|
caption: "Photo credit: [**Unsplash**](https://unsplash.com)"
|
|
cta_label: "More Info"
|
|
cta_url: "https://unsplash.com"
|
|
```
|
|
|
|
You should get an header image overlaid with text and a call to action button.
|
|
|
|

|
|
|
|
You also have the option of specifying a solid background-color to use instead of an image.
|
|
|
|

|
|
|
|
```yaml
|
|
excerpt: "This post should display a **header with a solid background color**, if the theme supports it."
|
|
header:
|
|
overlay_color: "#333"
|
|
```
|
|
|
|
### Sidebar
|
|
|
|
The space to the left of a page's main content is blank by default, but has the option to show an author profile (name, short biography, social media links), custom content, or both.
|
|
|
|
#### Author Profile
|
|
|
|
Add `author_profile: true` to a post or page's YAML Front Matter.
|
|
|
|

|
|
|
|
Better yet, enable it with Front Matter Defaults set in `_config.yml`.
|
|
|
|
```yaml
|
|
defaults:
|
|
# _posts
|
|
- scope:
|
|
path: ""
|
|
type: posts
|
|
values:
|
|
author_profile: true
|
|
```
|
|
|
|
**Note:** To disable the author sidebar profile for a specific post or page, add `author_profile: false` to the YAML Front Matter instead.
|
|
{: .notice--warning}
|
|
|
|
#### Custom Sidebar Content
|
|
|
|
Blocks of content can be added by using the following under `sidebar`:
|
|
|
|
* `title` --- title or heading
|
|
* `image` --- image path placed in `/images/` folder or an external URL
|
|
* `image_alt` --- alt description for image
|
|
* `text` --- Markdown supported text
|
|
|
|
Multiple blocks can also be added by following the example below:
|
|
|
|
```yaml
|
|
sidebar:
|
|
- title: "Title"
|
|
image: http://placehold.it/350x250
|
|
image_alt: "image"
|
|
text: "Some text here."
|
|
- title: "Another Title"
|
|
text: "More text here."
|
|
```
|
|
|
|
<figure>
|
|
<img src="{{ base_path }}/images/mm-custom-sidebar-example.jpg" alt="custom sidebar content example">
|
|
<figcaption>Example of custom sidebar content added as YAML Front Matter.</figcaption>
|
|
</figure>
|
|
|
|
**ProTip:** Custom sidebar content added to a post or page's YAML Front Matter will appear above the author profile if enabled with `author_profile: true`.
|
|
{: .notice--info}
|
|
|
|
## Archive
|
|
|
|

|
|
|
|
### Taxonomy Archive
|
|
|
|

|
|
|
|
## Splash Page
|
|
|
|
 |