Skip to content

26B/wp-safe-edit

 
 

Repository files navigation

WP Safe Edit

Safely edit published posts behind the scenes without affecting the live site. You can save your changes as a draft and publish them when ready, so you don't have to finish your updates in one sitting. This gives editors the opportunity to collaborate on changes or get approval before publishing.

Requirements

  • WordPress >= 4.5 due to the use of get_post_types_by_support()
  • PHP >=5.4

Installation

  1. Download and activate the plugin in WordPress.

  2. Draft functionality is available for posts and pages by default. You can register support for custom post types using a filter:

add_filter( 'safe_edit_supported_post_types', function( $post_types ) {
	// Add 'book' post type to array of supported post types.
	$post_types[] = 'book';

	return $post_types;
} );

Usage

  1. When this plugin is installed, a "Save as Draft" button [Fig. 1] will be available for posts and pages as well as the post types you registered support for. Pressing this button will create a draft copy of the post where you can stage your changes. All post meta and taxonomy terms associated with the post will be included.

    Image of the “Save as Draft” button.
    Figure 1.

  2. When editing a draft, it functions like any other post so you can do the following:

    • Save Changes as a Draft: Changes saved as a draft will not be reflected on the live site until you publish them.

    • Preview Changes: Preview your changes at any time by pressing the "Preview" button.

    • Trash Changes: If you change your mind, you can trash your updates by pressing the "Move to Trash" link.

  3. Once you're happy with your changes, publish them by pressing the "Publish Changes" button [Fig. 2]. The post you created the draft from will be updated with your changes and reflected on the live site.

    Image of the “Publish Changes” button.
    Figure 2.

Viewing Previous Drafts

You can view the most recent drafts created for a post using the "Archived Draft Revisions" meta box [Fig. 3]. Unlike WordPress revisions, all content, terms, and meta data are retained so you can see what the draft looked like when it was published.

Image of the “Archived Draft Revisions” meta box.
Figure 3.

Caveats & Limitations

  1. This plugin isn't compatible with post types using Gutenberg yet.

  2. You cannot edit a post in the dashboard if an open draft exists for it because the changes would be overwritten when the draft is published; a lockout message is shown if you try [Fig. 4]. Note: It's still possible to edit the post through an API or code, so consider that before enabling support. A planned improvement is to interrupt the publish draft process when the source post has been modified since the draft was created.

    Image of the “open draft exist” lockout message.
    Figure 4.

  3. If a post type contains meta boxes that save data behind the scenes using AJAX, you may need to hook into the publish draft process to make adjustments. Consider the following scenario:

    1. You create a draft of a post.
    2. On the draft, you use a meta box that creates an associated post in the background using AJAX. The associated post references the draft's post ID.
    3. You publish the draft.
    4. The source post has been updated with the changes from the draft, but the associated post you created still references the draft's post ID. To resolve this, adjustments to the associated post needs to be made during the draft publishing process using either the safe_edit_before_merge_post or safe_edit_after_merge_post action.
  4. You cannot change a post's URL slug using a draft because drafts are always published back to the source post retaining the original URL.

Roadmap

Some of the planned improvements are listed below:

  • Compatibility with Gutenberg.

  • Interrupt the publish draft process when the source post has been modified since the draft was created.

  • Break up some of the more complex draft/merge functions.

  • Complete unit tests.

  • Show more than the last 10 archived drafts.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • PHP 79.6%
  • JavaScript 16.8%
  • Shell 2.8%
  • CSS 0.8%