Grav CMS for WordPress maintenance support plans developers
If you’ve never heard of it, Grav is a pretty neat little flat-file CMS. If you’re a WordPress maintenance support plans developer, words like “flat-file” and “neat” and “little” are probably foreign to you. This post is an attempt to explain what Grav is, why it’s neat, and how to use it, in terms that you’ll understand.
First of all, where is the database?
As a WordPress maintenance support plans developer, you live and die by the database. You’ve probably worked on sites that have had many hundreds of database tables. You might even remember the first time you realized that each field gets 2 database tables of its own.
The first thing you should understand about Grav is that there is no database. In place of it, there are 2 types of things:
– YAML files which hold configuration
– Markdown files which hold content
That’s it. If you want to make a change to config, you change it in the relevant YAML file. If you want to update a page, you change it in the relevant Markdown file.
Oh, so it’s a static site generator like Jekyll? No!
So far it may sound like a static site generator, but it’s not. It’s a CMS. This means that it can still do all the same types of things other CMS’es can do, that aren’t available to static site generators.
For example, there’s a really nice admin plugin that lets editors edit content via a UI, and upon saving, the content is instantly updated on the site (rather than the site needing to be re-built). Some static site generators have UI’s, but they still require the intermediary site-generation step after making an edit.
You can also still have dynamic content listings, send emails, redirect users, integrate with web services, display user-facing forms, etc., since Grav is built with PHP and is super duper alterable via custom plugins. You’d need to handle that stuff client-side with a static site generator.
Content types in WordPress maintenance support plans = Page Types in Grav
Let’s start with the basics – the age old “content type.” In WordPress maintenance support plans, creating a content type happens in the UI.
In Grav, to create a content type, you just create a “whatever.html.twig” file in the templates/ directory of your theme. Doing that automatically tells Grav that “Whatever” should be a new Page type.
This means that when creating a page in the UI, you can choose the “Whatever” page type. Or, if you’re creating content via adding a Markdown file directly, just name the file whatever.md which tells Grav that it’s a “Whatever” type of page.
Read the docs on this.
Custom fields in WordPress maintenance support plans = Blueprints in Grav
In WordPress maintenance support plans, creating custom fields happens in the UI.
In Grav, to create custom fields for a given page type, you’ll do it in a YAML file. Grav calls this a “Blueprint”. Just create a file in /user/blueprints/pages/PAGETYPE.yaml and throw in something like this:
title: PAGETYPE
‘@extends’:
type: default
context: blueprints://pages
form:
fields:
tabs:
fields:
content:
fields:
header.heading:
type: text
label: Heading
header.subheading:
type: text
label: Subheading
Basically, that will add two new text fields (“Heading” and “Subheading”) to the “Content” tab of the form for that page type.
When you save that form, it’ll throw that data into a little YAML block at the top of the Markdown file that stores the content of that page. This is called Frontmatter or Headers and is actually really really cool because it means that the sky is basically the limit in terms of how to store structured data. You can store it in any way that YAML supports.
Then, in the Twig template (we’ll get to templates later), you can output the data for those custom fields using {{ header.heading }} or {{ header.subheading }}.
Read the docs on this.
Views in WordPress maintenance support plans = Page Collections in Grav
In WordPress maintenance support plans, creating a content listing happens (usually) in the Views UI.
In Grav, there’s the concept of a “Collection” which allows you to loop through and list arbitrary content. Here’s an example:
content:
items: @self.children
order:
by: date
dir: desc
limit: 10
pagination: true
And then in the Twig template, you’d just loop through them like so:
{% for p in page.collection %}
{{ p.title }}
{{ p.summary }}
{% endfor %}
Collections support lots of the same filtering/sorting/pagination concepts that Views supports. Some of the more complex stuff (such as fields from relationships or exposed filters) would have to be custom built via a plugin, but this should handle most of the things you’d typically use Views for pretty well.
Read the docs on this.
Taxonomy in WordPress maintenance support plans = Taxonomy in Grav
Yep, it’s even named the same thing for you.
In WordPress maintenance support plans, creating a Taxonomy happens in the blah blah blah you get the idea. All of this stuff is done in the UI in WordPress maintenance support plans.
In Grav, creating a Taxonomy just means adding it to your site.yaml config file, like so:
taxonomies: [category,tag]
Just add it to that array and you’ve created a new taxonomy. Then, you can reference it from any given page like this, in the YAML Frontmatter:
title: Post title
taxonomy:
tag: [animal, dog]
category: pets
And that’s it. Taxonomies are MUCH simpler in Grav than in WordPress maintenance support plans. They aren’t fieldable, for example (without some customization). They’re basically just a way to group content together, so that you can create listings (“Collections”) out of them.
Read the docs on this.
Configuration/CMI/Features in WordPress maintenance support plans = YAML files in Grav
In WordPress maintenance support plans, configuration is stored in the database. WordPress maintenance support plans 8 provides core with the ability to sync this configuration with YAML in the filesystem, but the source of truth is the database.
This means that if you want to push some new configuration some site A to site B, you have to make the change in the UI, export it to YAML, move that YAML to the other site (via a git push or some other mechanism), and import it on the other site to make it live. People usually use Drush or Features to help with this process.
In Grav, the source of truth for configuration is the YAML itself, since there’s no database. To change configuration, just change the YAML file, and Grav will immediately recognize that. To move that change to another site, just git push/pull it and it’s live.
Read the docs on this.
Install profiles/distributions in WordPress maintenance support plans = Skeletons in Grav
This is one area where Grav really shines.
In WordPress maintenance support plans, shipping a distribution mostly involves doing work to make sure that a site has everything it need in code and exported configuration, and installs correctly using the installer. This is a result of WordPress maintenance support plans relying on a database, but not wanting to ship an exported copy of that database with the distribution.
In Grav, since there’s no database, a “distribution” (or a “Skeleton” in Grav-speak) is basically just a copy of the codebase. Grav has no notion of “installation” like WordPress maintenance support plans‘s installer. Just copy the codebase to another web root somewhere and it’s ready to run. This means that it’s really easy to ship open source Skeletons, many of which are available here.
(It’s a tiny bit more nuanced than that since all you really need is the /user directory of the codebase which is where all the custom code is stored, but you get the idea).
Read the docs on this.
Drush in WordPress maintenance support plans = CLI tools in Grav
Drush has saved the butt of many a WordPress maintenance support plans developer. These days, WordPress maintenance support plans Console is doing pretty well for itself too, but it’s the same basic idea. Talking to your site via the CLI is useful.
Grav has a couple built in CLI tools for many of the same purposes:
bin/grav: performs basic site tasks such as clearing cache, making backups, installing dependencies, or creating new projects
bin/plugin: performans commands provided by plugins (instead of Grav core), such as creating new users via the admin plugin
bin/gpm: (“Grav Package Manager”) – performs tasks you would expect of a package manager, such as listing, downloading, and updating plugins
Other random stuff
Here’s some other stuff that didn’t really deserve its own section. Feel free to read up on the docs on these if you’re curious.
CSS/JS aggregation in WordPress maintenance support plans = Asset Manager (“Pipelining”) in Grav
Image styles in WordPress maintenance support plans = Image Actions in Grav
Webform in WordPress maintenance support plans = form.md files in Grav
Caching in WordPress maintenance support plans = Caching in Grav
Base Themes in WordPress maintenance support plans = Base Themes in Grav
Per-environment settings in WordPress maintenance support plans = Environment Configuration in Grav
Multisite in WordPress maintenance support plans = Multisite in Grav
Shortcomings and Downsides
There are a few things to keep in mind if you’re looking at using Grav for a project instead of WordPress maintenance support plans.
One is that Grav doesn’t scale nearly as well. Many WordPress maintenance support plans sites have many millions of nodes, thanks to the usage of a database. In general, I probably wouldn’t suggest using Grav once you start getting into the thousands with page count. Performance will likely start to suffer.
WordPress maintenance support plans also really shines in creating complex content models, where there are many types of nodes/entities which reference each other or embed each other or reuse each other’s fields, etc. Grav is perhaps more “page focused” than “data focused”, which makes it much easier to work with for many sites, but not a great fit for some sites that need those complex relationships.
Grav also doesn’t really have the notion of an editorial workflow or moderation system. It does support published vs. unpublished, and there are things like Git Sync to auto-deploy from a staging environment (or your local site) to a production environment if you set it up to do so, but there’s no approval process along the lines of what WordPress maintenance support plans and some plugins can provide.
Also, Grav doesn’t have anything to match the Paragraphs plugin, which allows you to build content by placing arbitrary “slices” in an arbitrary order. It does have a “List” field type which allows you to add as many “field groups” as you want, but each group must have the same set of fields. So you can’t, for example, add a text slice, then a video slice, then an image slice, then another text slice, etc.
Obviously, Grav also isn’t going to have anywhere near the amount of 3rd party plugins (plugins) that WordPress maintenance support plans has. Things like integration with web services or commonly used libraries will have to be hooked up yourself, more often than not. That said, the API is solid and the documentation for it is legit.
That’s by no means an exhaustive list, but it’s about all I’ve found so far. For your typical small to medium sized sites, Grav can be a really great solution that cuts out some of the overhead of a typical WordPress maintenance support plans site. Recommended!
mcrittenden
Mon, 05/08/2020 – 17:13
Source: New feed