-
-
Notifications
You must be signed in to change notification settings - Fork 265
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
Block Editor Form Validation #7369
base: main
Are you sure you want to change the base?
Changes from all commits
925df23
9a77a79
0f1b2ab
f46f416
f353464
524da67
e011867
d03267e
98c6e97
60d0aab
0205024
d83e886
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
{"dependencies":["lodash","react","react-dom","wp-api-fetch","wp-autop","wp-block-editor","wp-blocks","wp-components","wp-compose","wp-date","wp-element","wp-i18n","wp-keycodes","wp-server-side-render","wp-url"],"version":"74e7329c36abb1a485a0"} | ||
{"dependencies":["lodash","react","react-dom","wp-api-fetch","wp-autop","wp-block-editor","wp-blocks","wp-components","wp-compose","wp-date","wp-element","wp-i18n","wp-keycodes","wp-server-side-render","wp-url"],"version":"e4dd30ce893e9c448705"} |
Large diffs are not rendered by default.
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,17 +1 @@ | ||
<<<<<<< HEAD | ||
<<<<<<< HEAD | ||
<<<<<<< HEAD | ||
<<<<<<< HEAD | ||
{"dependencies":["lodash","moment","react","react-dom","react-jsx-runtime","regenerator-runtime","wp-api-fetch","wp-autop","wp-components","wp-compose","wp-data","wp-element","wp-hooks","wp-i18n","wp-keycodes","wp-plugins","wp-primitives","wp-url"],"version":"82c8aaf9e4ae1481502c"} | ||
======= | ||
{"dependencies":["lodash","moment","react","react-dom","react-jsx-runtime","regenerator-runtime","wp-api-fetch","wp-autop","wp-components","wp-compose","wp-data","wp-element","wp-hooks","wp-i18n","wp-keycodes","wp-plugins","wp-primitives","wp-url"],"version":"a5ca5125b2a394cb0bdb"} | ||
>>>>>>> 2b4f0cdf9 (Rebuild assets) | ||
======= | ||
{"dependencies":["lodash","moment","react","react-dom","react-jsx-runtime","regenerator-runtime","wp-api-fetch","wp-autop","wp-components","wp-compose","wp-data","wp-element","wp-hooks","wp-i18n","wp-keycodes","wp-plugins","wp-primitives","wp-url"],"version":"6c3b89ffe8da2dcd1d1f"} | ||
>>>>>>> cbd2c2484 (Auto rebuild assets) | ||
======= | ||
{"dependencies":["lodash","moment","react","react-dom","react-jsx-runtime","regenerator-runtime","wp-api-fetch","wp-autop","wp-components","wp-compose","wp-data","wp-element","wp-hooks","wp-i18n","wp-keycodes","wp-plugins","wp-primitives","wp-url"],"version":"7081b505becf5dac1be8"} | ||
>>>>>>> 6ccfcd880 (Revamp wizard screens across all components) | ||
======= | ||
{"dependencies":["lodash","moment","react","react-dom","react-jsx-runtime","regenerator-runtime","wp-api-fetch","wp-autop","wp-components","wp-compose","wp-data","wp-element","wp-hooks","wp-i18n","wp-keycodes","wp-plugins","wp-primitives","wp-url"],"version":"02ffd778d1fc97a84bb4"} | ||
>>>>>>> 9b36dedd1 (Auto rebuild assets) | ||
{"dependencies":["lodash","moment","react","react-dom","react-jsx-runtime","regenerator-runtime","wp-api-fetch","wp-autop","wp-components","wp-compose","wp-data","wp-element","wp-hooks","wp-i18n","wp-keycodes","wp-plugins","wp-primitives","wp-url"],"version":"9dfe3c75280b0a2d29de"} |
Large diffs are not rendered by default.
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,77 @@ | ||
|
||
const useBlockEditor = () => { | ||
const editorSelect = wp.data?.select( 'core/editor' ); | ||
const editorDispatch = wp.data?.dispatch( 'core/editor' ); | ||
const notices = wp.data?.dispatch( 'core/notices' ); | ||
|
||
// @todo Use hook instead of savePost override once stable. | ||
if ( ! window.PodsBlockEditor && editorDispatch && editorDispatch.hasOwnProperty( 'savePost' ) ) { | ||
// First init. | ||
window.PodsBlockEditor = { | ||
// Store original. | ||
savePost: editorDispatch.savePost, | ||
messages: {}, | ||
callbacks: {}, | ||
}; | ||
|
||
// Override the current editor savePost function. | ||
editorDispatch.savePost = async ( options ) => { | ||
options = options || {}; | ||
|
||
const pbe = window.PodsBlockEditor; | ||
|
||
if ( ! Object.values( pbe.messages ).length ) { | ||
// eslint-disable-next-line no-undef | ||
return pbe.savePost.apply( this, arguments ); | ||
} | ||
|
||
return new Promise( function( resolve, reject ) { | ||
// Bail early if is autosave or preview. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @sc0ttkclark Should we allow saving for a draft? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm on the fence here. Maybe we can make that an option in settings or a constant/hook. Default to allow saves on drafts perhaps. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. But there's no way to draft by default when you have a post that's already published. So we'd need to distinguish between save and save draft. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We can also leave it as-is and add it later if you want. I can quite easily fetch the status value and check that, however, it's hard to define what statuses should be allowed or not. EDIT: example const status = editorSelect.getEditedPostAttribute('status');
if ( [ 'draft', 'trash', 'otherStatus' ].includes( status ) ) {
// Run default
}
// OR
if ( SOME_USER_SETTING_ARRAY.includes( status ) ) {
// Run default
} |
||
if ( options.isAutosave || options.isPreview ) { | ||
return resolve( 'Validation ignored (autosave).' ); | ||
} | ||
for ( const fieldName in pbe.messages ) { | ||
if ( pbe.messages.hasOwnProperty( fieldName ) ) { | ||
pbe.messages[ fieldName ].forEach( function( message ) { | ||
notices.createErrorNotice( 'Pods: ' + message, { id: fieldName, isDismissible: true } ); | ||
} ); | ||
} | ||
editorDispatch?.lockPostSaving( fieldName ); | ||
} | ||
for ( const fieldCallback in pbe.callbacks ) { | ||
if ( pbe.callbacks.hasOwnProperty( fieldCallback ) && 'function' === typeof pbe.callbacks[ fieldCallback ] ) { | ||
pbe.callbacks[ fieldCallback ](); | ||
} | ||
} | ||
return reject( 'Pods validation failed' ); | ||
} ); | ||
}; | ||
} | ||
|
||
return { | ||
data: wp.data, | ||
select: editorSelect, | ||
dispatch: editorDispatch, | ||
notices, | ||
lockPostSaving: ( name, messages, callback ) => { | ||
// @todo Use hook instead of savePost override once stable. | ||
//wp.hooks.addFilter( 'editor.__unstablePreSavePost', 'editor', filter ); | ||
|
||
const pbe = window.PodsBlockEditor; | ||
if ( messages.length ) { | ||
pbe.messages[ name ] = messages; | ||
pbe.callbacks[ name ] = callback; | ||
} | ||
}, | ||
unlockPostSaving: ( name ) => { | ||
// @todo Use hook instead of savePost override once stable. | ||
//wp.hooks.removeFilter( 'editor.__unstablePreSavePost', 'editor', filter ); | ||
|
||
delete window.PodsBlockEditor.messages[ name ]; | ||
delete window.PodsBlockEditor.callbacks[ name ]; | ||
editorDispatch?.unlockPostSaving( name ); | ||
}, | ||
}; | ||
}; | ||
|
||
export default useBlockEditor; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Optionally make this a class with private props and getters/setters. Maybe even an external tool like the API instead of a React hook.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Lets keep it like this since we should definitely change this code once a hook is available.
The added todo will inform any dev checking this code in that it's a temp solution.