Hi! I ran into a problem that I think is related to this request:
https://www.ads-software.com/support/topic/regarding-the-publish-button/
This may have been changed in a recent WordPress version, but I don’t think this works as intended anymore. When the “Save” button appears, it fires the “Post saved” notification, but it changes the post status to publish.
Steps for recreating this issue (using the classic editor):
It would be better if the button is clearly labeled Publish if that’s the effect of the action. I added a script and some CSS to hide the publish button based on custom post statuses, but the Save button is a little confusing.
]]>Hello, I’m interested in using this plugin, but I see it has been inactive for several months. I would like to know if the plugin is still being updated, or if it has stopped receiving support. Thank you!
]]>I just changed a post from (I believe) the standard Pending Review status to an Extended Status that essentially assigns the post to someone for review. I think I unchecked the Pending Review checkbox too – then clicked Save. This triggered a Publish action which then emailed notifications of a new post to subscribers.
Can you explain the expected workflow, current button naming, etc, so that we know exactly what WordPress might do with posts as Extended Post Status is used?
On an existing post, we must click “Save as pending”. Do not click the “Save” button.
This is just the “Publish” button renamed. I’ve seen notes on this but the change is not valid. We expect Save to save it in its current state, not to go further than that an publish, essentially with the Published status even though we are using a non-Published extended status.
Only click Save when you want to Publish – perhaps while maintaining a non-default extended status, which can be useful.
There is still the Pending Review checkbox. We can leave that checked until a post is ready for publication, but I’m not sure yet when that is auto-set or not in the New > Draft > Update workflow.
For now I have disabled notifications and will experiment.
]]>I have no clue about this one, just reporting it for now. Ref the issue with the extra status textarea. When I tried a value in there (silly me) a few statuses were deleted, and the test value was added as an extended statuses – with an error displayed on render. The fix for the extra status will probably eliminate this. So, FYI…
Follow-up: Status values were Not deleted. The bogus ‘foo’ status simply caused the list to stop rendering and other valid status values were not displayed. Deleting the ‘foo’ value (which only existed because I added the foo value in the textarea that is being removed) eliminated the list render issue and the other status codes are present and displayed properly.
Let’s call this a non-issue, but I’m leaving here in case someone else trips on similar conditions and results.
]]>The status assigned with this plugin does not appear in the Posts list. Should it with the current code? If not, please consider this a feature request.
]]>As a site admin I create new status codes, but I don’t see how to make these available to non-admin users who have Author role. There are no ‘capabilities’ defined by the plugin so we cannot give individual roles a cap like ‘ext_status_modify’.
I would welcome a new capability for every status type, so that we can manage who gets to set each type, and who gets to view posts that have a specific status.
Specifically: For a new status slug “on_hold”, the following capabilities can be assigned to different roles to define their access:
ext_status_view-on_hold : Role may see posts in this status.
ext_status_edit-on_hold : Along with edit_posts, role can edit posts in this status.
ext_status_to-on_old : Role may change status to this status.
When I get time to look at this plugin’s code, I will think about how to add this feature.
]]>Quick Edit in the Posts list shows a text area for Status as well as the updated dropdown list. Any text can be added in the Status textarea – it’s not a valid control for this field.
]]>In /extended-post-status/admin/class-extended-post-status-admin.php the value of $term_meta may be Boolean and not an Array. This causes the following critical error (site stops). This might have been a warning in prior PHP, but now it’s fatal.
The solution is to add if(is_array($term_meta) && ...
before all of the checks for values in the array. It’s a simple change. I have not looked to see why that value is a Boolean in the first place.
I just installed and started to test this great plugin but I’m afraid I need to uninstall. I can’t take a chance that there are more gotchas that haven’t been tested yet. But I will install in another test environment later and try to help with this.
Fatal error: Uncaught TypeError: array_key_exists(): Argument #2 ($array) must be of type array, bool given in /wp-content/plugins/extended-post-status/admin/class-extended-post-status-admin.php:197
]]>Hi there,
When we stop selling some products we call it “end of life” = EOL.
I made post status called EOL and I choose some products as EOL.
But whenever I save that product, It become published.
How I can stop that?
Hi there,
I keep getting this error.
Is it related with your plugin?
Notice: Function map_meta_cap was called <strong>incorrectly</strong>. The post type <code>product</code> is not registered, so it may not be reliable to check the capability <code>edit_post</code> against a post of that type. Please see <a href=”https://www.ads-software.com/documentation/article/debugging-in-wordpress/”>Debugging in WordPress</a> for more information. (This message was added in version 4.4.0.)?in?/home//public_html/wp-includes/functions.php on line 5905
]]>Hi Felix,
thanks for providing and maintaining this plugin, much appreciated!
Upgrading to v1.0.20
I’ve noticed a fatal error upon deployment:
Fatal error: Uncaught Error: Call to undefined function wp_get_current_user() in /srv/www/example.com/releases/20230627111755/web/wp/wp-includes/capabilities.php:873
This is due to us including your plugin as an mu-plugin and wp_get_current_user()
not being available yet…
The code in question resides on line 758 in /admin/class-extended-post-status-admin.php
and is attached to the gettext
-filter.
I am not sure if this can be re-written somehow to allow for the plugin to continue working as a mu-plugin…? Any ideas?
Fixing the version to v1.0.19
for the time being.
Thanks for your input & regards!
]]>I have just got an alert from WordFence regarding this “Extended Status” plugin. WordFence marks this issue as critical.
According to WordFence:
The Extended Post Status plugin for WordPress is vulnerable to unauthorized modification of data due to a missing capability check on the wp_insert_post_data function in versions up to, and including, 1.0.19. This makes it possible for authenticated attackers, with contributor-level access and above, to set their own posts to the ‘published’ status via the extended post status metabox.
Since this is critical to the safety and security of my website, I had to delete the plugin. I am not going to wait for a fix with this kind of security instability.
FYI: people need to change the status of their posts or pages that were marked with a custom status using this plugin. There is no automatic re-status assignment if you deactivate or delete this plugin. This means posts or pages assigned a custom status will disappear from your Admin area and not accessible unless you reassign them to the standard WordPress status before deactivating or deleting this plugin.
]]>All good, but not enough.
Please consider the possibility of
Color selection ( border , background color ) !!! Very much needed !
Establishing the possibility of adding an icon ( flag ) !!! Would really like
Possibility to use filter to search or move in sections !!!! As there will be a possibility and desire from you .
Analog old old old ?? not worked = Post State Tags addon
]]>in version 1.0.18 you have introduced a change that ‘removes’ the publish button in gutenberg – we find it very confusing to editors as it changes common habits, and the cases we require to change a post status is less frequent – than we actually need publish (which is almost 99% of the times)
I would like to suggest the following changes:
– Leave the button Publish as it use to be
– Gutenberg already have a ‘save as draft’ so it is redundent to save as draft by default ( if none status was selected in the status selectbox )
– When you create a post if the status is: none – than just leave wordpress do its own, and have it published ( if requires also with the publish sidebar – after all there are plugins that extend the publish sidebar that help alot in promoting content)
– if the user have selected a different status in the selectbox, only than change the text of the button using javascript from Publish to Save
or enable some hooks or configuration page so the admin can determine if they wish this new features of draft as default ( if none selected ) and the removal of publish button & sidebar publish
we are currently rollback to previous versions since it is very confusing.
Hi how to show the status description in the theme, you got a example or now of a theme that does it?
]]>Hello,
Is this plugin can help for woocommerce products?
I would like to add EOL status to old products.
thanks
]]>As far as I know, the panel containing the post status was updated recently in the ?Gutenberg? block editor. Do I see this correctly that I can no longer access the additional statuses added by this plugin?
]]>I have created a new status called: Ready
It is not public, but when putting this status, the articles appear on the blog page, even if the publishing date is in the future. There is something wrong in the algorithm, can you check that please?
I created a custom post status, set a post with this status and the post disappeared.
I could not filter the custom post status and the post did not even show when I set the filter to show all posts.
Searching the post name did not work. The post was lost.
It did not even reappear after I disabled the plugin.
]]>Hello. Thanks for this plugin, it’s very handy.
On the latest version, (and latest version of WordPress) this line:
$this->loader->add_action('enqueue_block_editor_assets', $plugin_admin, 'remove_publishing_sidebar_gutenberg');
is causing the script to be output before the <doctype>
and that is causing some issues on the editing screen. I removed that line and all is working fine now. I don’t understand what that script is supposed to disable, but I think it should be optional. Thank you.
Hi there,
I noticed numerous JS errors in the console popping up and they are based in the postListUpdated
-function in class-extended-post-status-admin.php
where you have a typo:
It should read jQuery
instead of j
on line 140 which renders an undefined error…
Please fix this in the upcoming version ??
Thanks for providing the plugin and all the work that went into it!
Kind regards,
Henning
Hi, after installing the plugin I am getting this error when trying to create/edit a page/post
Is there any previous documentation of this error o maybe something to fix it, thanks.
<b>Warning</b>: Cannot modify header information – headers already sent by (output started at /app/wordpress/wp-content/plugins/extended-post-status/admin/class-extended-post-status-admin.php:739) in <b>/app/wordpress/wp-admin/admin-header.php</b> on line <b>9</b><br />
]]>Hi there!
We are running a website with a few dozen writers and this plugin came really handy when it came to improving editorial processes. We can now mark posts for different states in our flow before an article gets published, and assign it to specific teams to review. So thanks for the effort!
However, I think one thing is very confusing for our editors, and that is the “Publish” button. When you hit this button without manually setting the post status to ‘Published’, the article does not get published (although WordPress says so). I kind of understand why this is (you explained it here: https://www.ads-software.com/support/topic/does-not-update-status-when-publishing/), but would nevertheless like to offer my input or ideas.
I think UX wise, it does not make sense now and I propose 2 solutions:
1) If you hit the PUBLISH button, the article gets published. No matter what. It ignores any post statuses. That’s after all what you expect this button to do. This option has my prefrence.
2) Change the PUBLISH button to an UPDATE button and don’t show the message ‘Your message has been published’ when it is not (because it was in a non-public post status).
Curious to find out your thoughts! If you would have any quick fixes or plans, I would be happy to hear them to.
Thank you!
Cheers, Jos
]]>Hello, I’ve use your plugin and it works very well. But when I submit a product in woocommerce and changed status to my new status I mean Approved or declined the vendor in WC Lovers see No data in the Table. What can I do?
]]>I have a problem, if I press publish and I have the plugin turned on, it will not write me a bug in the debug, it will write that the article was successfully published. But it wasn’t, if I refreshed the page, it would show that it is still a draft.
]]>On our website, we use Everest Forms for some signup forms. When Extended Post Status is active, the Entries from Everest Forms do not appear in the backend.
They are logged, but somehow Everest Forms does not display them.
Your plugin does exactly what I need it to. And I have had no luck finding another plugin that is as good as yours.
But with this conflict with Everest Forms, I can’t use it and would very much appreciate it if you could find a solution.
]]>Hello, After update to WordPress 5.8 my backend view of a custom status looks like this:
https://www.dropbox.com/s/v9py99j7spwayoc/Screenshot%202021-07-31%20at%2010.00.05.jpg?dl=0
Plugin Version 1.0.17
]]>I made a status called Discontinued Products.
These products are hidden when not logged in as admin or if viewed in incognito browser.
When actually logged in in backend I see these products in frontend. How can I hide them in frontend?
I am able to set a custom status for the posts, but when publishing, it does not update the status to published. So if you are not careful to change the status manually, the post stays invisible after publishing. Is there a way to fix this?
]]>I had a compatibility issue with this plugin and came up with this simple fix.
…/extended-post-status/admin/class-extended-post-status-admin.php
/**
* Override the post query
*
* @param type $query
* @return type
* @since 1.0.1
*/
public static function override_admin_post_list($query)
{
$statuses = self::get_status();
/* Check if query has no further params */
if (
(array_key_exists('post_status', $query->query) && empty($query->query['post_status']))
) {
$statuses_show_in_admin_all_list = self::get_all_post_statuses();
foreach ($statuses as $status) {
$term_meta = get_option("taxonomy_term_$status->term_id");
if (!in_array($status->slug, $statuses_show_in_admin_all_list)) {
if ($term_meta['show_in_admin_all_list'] == 1) {
$statuses_show_in_admin_all_list[] = $status->slug;
}
} else {
if ($term_meta['show_in_admin_all_list'] != 1) {
if (($key = array_search($status->slug, $statuses_show_in_admin_all_list)) !== false) {
unset($statuses_show_in_admin_all_list[$key]);
}
}
}
}
set_query_var('post_status', array_values($statuses_show_in_admin_all_list));
return;
}
return;
}
/**
* Get all available post statuses
*
* @return array
*/
private static function get_all_post_statuses()
{
global $wpdb;
$query = $wpdb->get_results("SELECT DISTINCT $wpdb->posts.post_status as post_status FROM wp_posts WHERE post_status NOT IN ('auto-draft', 'trash', 'inherit')");
return wp_list_pluck($query, 'post_status');
}
]]>