Skip to content

A plugin for customizing the editor experience to suit Upstatement-built WordPress projects.

Notifications You must be signed in to change notification settings

Upstatement/ups-editorial-wp-plugin

Repository files navigation

Upstatement Editorial

A WordPress plugin for enhancing the editorial experience, including some common customizations for the Gutenberg editor.

Table of Contents

What This Plugin Does

The purpose of this plugin is to tailor the Gutenberg editor experience to be better suited to editors using their WordPress theme. Features added as a part of this plugin fall into two categories: block modifications (including new blocks and updates to core blocks) and editor plugins.

Blocks

New blocks

  • Image Block (replaces the core image block)

    • Adds support for the Alt Text and Credit attachment fields in the media library
    • Updates the default caption state to pull from the Caption attachment field
    • Adds support for the custom Modal Gallery component in the main Editorial theme
    • Removes unneeded features from core image block, including border styles

Extended Blocks

Note that you can continue to extend core block functionality in your theme by using WordPress's blocks.registerBlockType and editor.BlockEdit filters.

Editor Plugins

Our main Gutenberg "plugin" adds two panels to the main sidebar of posts: the Article Topper & Bylines panels.

Article Topper Panel

The article topper panel controls article post metadata concerned with the article topper. This includes:

  • Topper type: The look and feel of the topper, be it text-only or a site-width featured image
  • Navigation theme: When paired with dark background image toppers, an already dark-themed nav can appear invisible. This option allows for lighter navigation themes
  • Overline: Choose a primary category for your article to allow for better recirculation amongst common themes

Bylines Panel

The bylines panel allows editors to assign multiple authors to the author byline. This process starts with the Authors section under Posts, where you can create author profiles.

These authors also serve as taxonomies for your articles, so archive pages full of an author's own content are auto-generated on your behalf.

Template functions

This plugin exposes a few functions that can be used to retrieve relevant values handled by the plugin. See the Theme API section for information about the available functions.

Theme configuration

By default, all features of this plugin are enabled once the plugin is activated. However, you are able to configure the plugin's functionality (including disabling certain features) via a configuration file that can be added to your theme.

To set up a configuration file, add a ups-editorial.php file to your theme's root that returns an array containing the relevant configuration options:

<?php
/**
 * Configuration for the ups-editorial plugin.
 */

return array(
  'bylines'        => true,
  'article_topper' => true,
);

Configuration

bylines

Allowed types: boolean

Default value: true

Enable or disable the plugin's Author taxonomy, as well as the control mechanism for setting bylines for an individual post.

article_topper

Allowed types: boolean

Default value: true

Enable or disable the registration of fields for article toppers and the Gutenberg panel that controls those fields.

Theme API

There are a few globally-available functions that can be used by your theme to retrieve data defined by this plugin's functionality. These functions are defined in the Template.php file at the root of the plugin directory, and exist under the Upstatement\Editorial namespace.

It is recommended that your theme implement these functions wrapped by a function_exists check to prevent undefined errors in the case that the plugin is disabled. For example:

if ( function_exists( 'Upstatement\Editorial\get_post_bylines' ) ) {
  $bylines = \Upstatement\Editorial\get_post_bylines();
  ...

get_post_bylines

get_post_bylines( WP_Post $post = null, string $field = null) : array | null

Retrieve the byline for a post.

Parameters

post

    Post to retrieve authors for. Leave blank to use the current global post.

field

    The field to return for each author. This can be any property from a WP_Term object. Leave blank to return the entire WP_Term object.

Return

Returns an array consisting of author data. If field is blank, this will be an array of WP_Term objects. If a field is specific, this will be an array of values for that field.

get_post_overline

get_post_overline( WP_Post $post = null ) : WP_Term | null

Retrieve the overline category for a post.

Parameters

post

    Post to retrieve the overline for. Leave blank to use the current global post.

Return

Returns the WP_Term object of the category term identified as the overline, or null if none is set.

Troubleshooting

"I've updated the content in the Editorial sidebar, but it's not appearing in the preview."

This is a known issue with Wordpress Gutenberg where post meta doesn't save until the Update button is pressed. We're currently tracking the main issue at WordPress/gutenberg#14900, but until then you can try one of the following steps:

  • After updating the sidebar content, press the Update button and then the Preview button.

  • Press the Preview button twice. Sometimes the meta is only available for every-other preview.

  • Attempt a hard refresh in the preview window (command+shift+R in Google Chrome).

Block validation and recovery

When changing the saved markup of existing or new components, you are likely to come across an issue with block validation.

This error occurs when the markup of a block on last save doesn't match the markup of the block when it loads within the editor.

If this error was intentional, the easiest way to bypass the issue is:

  1. In the top right corner of the block, press the three dots.

  2. Select the Attempt block recovery option. This will re-render the block markup according to the latest version of the save function.

  3. Update the post to save the latest block markup.

If the error was unintentional, your console will be the best place to identify what went wrong. That may look something like this:

Block validation: Block validation failed for `ups/image` Content generated by `save` function:

<figure class="wp-block-image">
  <img src="/good-image.png" alt="A good image" />
  <figcaption>This is the caption</figcaption>
  <cite>This is a new citation</cite>
</figure>

Content retrieved from post body:

<figure class="wp-block-image">
  <img src="/good-image.png" alt="A good image" />
  <figcaption>This is the caption</figcaption>
</figure>

In the case above, there was a new cite element added to the markup after the block was already saved to the post. At this point you can either (1) choose the Attempt block recovery option to update the markup, (2) remove and recreate the block, or (3) revert the save function to remove the cite element.

Local Development

The Github repository includes a docker setup that will allow you to run a basic WordPress installation with the Upstatement Editorial plugin installed. You'll need to ensure that you have Docker Desktop installed on your machine first.

To start working locally, you'll need the following things on your machine:

  • nvm to manage the Node version this project is running on.
  • composer to manage PHP dependencies and autoloading.

Once the above are installed, you can get set up with the following steps:

  1. Ensure you're running the expected version of Node:

    nvm install
  2. Install Node dependencies:

    npm install
  3. Watch the plugin files for changes:

    npm run start
  4. Start the docker containers (note that the -d flag will run the container in the background):

    docker-compose up -d --build

You can build the static front-end assets at any time with the following script:

npm run build

Resources

During the development of this plugin, we found the following resources to be useful:

About

A plugin for customizing the editor experience to suit Upstatement-built WordPress projects.

Resources

Stars

Watchers

Forks

Packages