Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Editor: Include additional details when saving post fails #68360

Open
wants to merge 1 commit into
base: trunk
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 10 additions & 4 deletions packages/editor/src/store/utils/notice-builder.js
Original file line number Diff line number Diff line change
Expand Up @@ -100,10 +100,16 @@ export function getNotificationArgumentsForSaveFail( data ) {
? messages[ edits.status ]
: __( 'Updating failed.' );

// Check if message string contains HTML. Notice text is currently only
// supported as plaintext, and stripping the tags may muddle the meaning.
if ( error.message && ! /<\/?[^>]*>/.test( error.message ) ) {
noticeMessage = [ noticeMessage, error.message ].join( ' ' );
const errorMessages = [ error.message ]
.concat( error.additional_data )
.filter( ( message ) => {
// Check if message string contains HTML. Notice text is currently only
// supported as plaintext, and stripping the tags may muddle the meaning.
return message && ! /<\/?[^>]*>/.test( message );
} );
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for having a go at this 👍🏻

The extra context is definitely helpful, but I'm wondering if there's a bit too much in there. It might also be confusing for editors.

Before

Screenshot 2025-01-02 at 11 37 47 am Screenshot 2025-01-02 at 11 36 55 am

After

Screenshot 2025-01-02 at 11 40 52 am Screenshot 2025-01-02 at 11 39 23 am

I expect that it's difficult to know which error message is the most helpful. 🤔

Forgetting everything we know about Gutenberg/WordPress, as a user, it'd be helpful to know what failed and why, nothing else. E.g.,

The post couldn't be saved. The post password must be a maximum of 255 characters and contain only letters, numbers or special characters such as "!@#$%^&*".

I expect this would require making the error messages more friendly in the backend. For example, what's invalid is pretty obscure. And the lengths check depends on the database type.

Maybe a hook that passes in the error code, field type so that consumers (a.k.a the block editor) can write their own messages 🤷🏻

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@peterwilsoncc will have a better idea I think 😄

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unless the server starts including priority flags, it will be difficult to discern the importance of server error messages on the client.

Anything coming via additional_data is a secondary message for an error notice, maybe even hidden in the details toggle. Hopefully, that will be possible when notices are redesigned: #67662.


if ( errorMessages.length > 0 ) {
noticeMessage = [ noticeMessage, ...errorMessages ].join( ' ' );
}
return [
noticeMessage,
Expand Down
Loading