Introduction to Hyde Pages
Hyde offers two ways to create static pages: Markdown pages which are perfect for simple pages that focus heavily on the content, and Blade pages which are perfect for more complex pages where you want full control over the HTML, and where you may want to include other components or want to use dynamic PHP code.
Let's start with the basics.
Best Practices and Hyde Expectations
Since Hyde does a lot of things automatically, there are some things you may need to keep in mind when creating blog posts so that you don't get unexpected results.
Filenames
- Hyde Pages are files stored in the
_pages
directory - The filename is used as the filename for the compiled HTML
- Filenames should use
kebab-case-identifier
format, followed by the appropriate extension - Files prefixed with
_underscores
are ignored by Hyde - Your page will be stored in
_site/<identifier>.html
- Blade pages will override any Markdown pages with the same filename when compiled
Creating Markdown Pages
Markdown pages are the easiest way to create static pages. You can create a Markdown page by adding a file to the
_pages
directory where the filename ends in .md
. You can also use Front Matter to add page metadata.
Scaffolding Markdown Pages
Scaffolding a Markdown page is as easy as using the HydeCLI.
php hyde make:page "Page Title"
This will create the following file saved as _pages/page-title.md
---
title: Page Title
---
# Page Title
// Write your content here
You can of course also create the file yourself with your text editor.
Front Matter is optional
The most common front matter used for Markdown pages is the title, which is used as the HTML <title>
.
If you don't supply a front matter title, Hyde will attempt to find a title in the Markdown body by searching
for the first level one heading (# Page Title
), and if that fails, it will generate one from the filename.
Navigation Front Matter
Furthermore, you can customize how the page appears in the navigation menu using the following front matter options. You can set just one or all of them, as Hyde will fill in the gaps for the rest.
navigation:
label: 'string',
priority: 'int',
hidden: 'bool',
group: 'string',
-
label
is the text that will be displayed in the navigation menu -
priority
is the order in which the page will appear in the navigation menu (order
is also supported) -
hidden
will hide the page from the navigation menu (visible
) is also supported, but obviously invert the value) -
group
will put the page in a dropdown menu with the specified group name (category
) is also supported)
Creating Blade Pages
Since Hyde is based on Laravel and uses the powerful Blade templating engine, you can use Blade pages to create more complex pages with both standard HTML, PHP code, and the templating opportunities provided by Blade directives.
If you are not familiar with Blade, you may want to read the Laravel Blade docs first.
Scaffolding Blade Pages
We can scaffold Blade pages using the same CLI command as Markdown pages, however, this time we need to specify that
we want to use the blade
page type, by using the --type
option.
php hyde make:page "Page Title" --type="blade"
This will create a file saved as _pages/page-title.blade.php
You can of course also create the file yourself with your text editor, however, the scaffolding command for Blade pages is arguably even more helpful than the one for Markdown pages, as this one automatically adds the included app Layout.
Let's take a look at the scaffolded file. You can also copy and paste this if you don't want to use the scaffolding command.
@extends('hyde::layouts.app')
@section('content')
@php($title = "Page Title")
<main class="mx-auto max-w-7xl py-16 px-8">
<h1 class="text-center text-3xl font-bold">Page Title</h1>
</main>
@endsection
Tip: You don't have to use Blade in Blade pages. It's also perfectly fine to use plain HTML, however you still need to use the
blade.php
extension so Hyde can recognize it.
When to Use Which?
Markdown pages look great and work well for simple "about" pages and the like, but with Markdown we are still pretty limited.
If you are comfortable with it and have the need for it, use Blade to create more complex pages! And mix and match between them! Some page types are better suited for Markdown, and others for Blade. Don't limit yourself to just one type.
Comparison
Markdown | Blade |
---|---|
➕ Easily created and updated | ➕ Full control over the HTML |
➕ Very fast to create simple and lightweight pages | ➕ Use the default app layout or create your own |
➕ Suited for content-heavy pages such as "about us" | ➕ Use Blade templates and components to keep code DRY |
➖ Not as flexible as Blade pages | ➕ Use arbitrary PHP right in the page to create dynamic content |
➕ Access to all Blade helper directives like @foreach, @if, etc. | |
➖ Takes longer to create as you need to write the markup | |
➖ You may need to recompile your CSS if you add Tailwind classes |
Live Demos
The Hyde website (hydephp.com) uses both Markdown and Blade pages. The homepage for example, is a Blade page and uses a bunch of custom HTML.
A great example of a Markdown page can be found at hydephp.github.io/portfolio-demo, you can see the page source here on GitHub.
Bonus: Creating HTML Pages
If you have an already created HTML
page, simply drop it into the _pages
directory and Hyde will copy it over as it is
into the _site
directory. Like all other Hyde pages, the page will show up in the navigation menu using a title parsed from the filename.
You won't be able to change any settings with front matter, however.