[wp-trac] [WordPress Trac] #34893: Improve Customizer setting validation model
WordPress Trac
noreply at wordpress.org
Fri May 20 21:09:46 UTC 2016
#34893: Improve Customizer setting validation model
-------------------------------------------------+-------------------------
Reporter: westonruter | Owner:
Type: enhancement | westonruter
Priority: high | Status: closed
Component: Customize | Milestone: 4.6
Severity: normal | Version: 3.4
Keywords: has-patch has-screenshots has-unit- | Resolution: fixed
tests needs-dev-note commit | Focuses: javascript
-------------------------------------------------+-------------------------
Changes (by westonruter):
* status: accepted => closed
* resolution: => fixed
Comment:
In [changeset:"37476"]:
{{{
#!CommitTicketReference repository="" revision="37476"
Customize: Add setting validation model and control notifications to
augment setting sanitization.
When a setting is invalid, not only will it be blocked from being saved
but all other settings will be blocked as well. This ensures that
Customizer saves aren't partial but are more transactional. User will be
displayed the error in a notification so that they can fix and re-attempt
saving.
PHP changes:
* Introduces `WP_Customize_Setting::validate()`,
`WP_Customize_Setting::$validate_callback`, and the
`customize_validate_{$setting_id}` filter.
* Introduces `WP_Customize_Manager::validate_setting_values()` to do
validation (and sanitization) for the setting values supplied, returning a
list of `WP_Error` instances for invalid settings.
* Attempting to save settings that are invalid will result in the save
being blocked entirely, with the errors being sent in the
`customize_save_response`. Modifies `WP_Customize_Manager::save()` to
check all settings for validity issues prior to calling their `save`
methods.
* Introduces `WP_Customize_Setting::json()` for parity with the other
Customizer classes. This includes exporting of the `type`.
* Modifies `WP_Customize_Manager::post_value()` to apply `validate` after
`sanitize`, and if validation fails, to return the `$default`.
* Introduces `customize_save_validation_before` action which fires right
before the validation checks are made prior to saving.
JS changes:
* Introduces `wp.customize.Notification` in JS which to represent
`WP_Error` instances returned from the server when setting validation
fails.
* Introduces `wp.customize.Setting.prototype.notifications`.
* Introduces `wp.customize.Control.prototype.notifications`, which are
synced with a control's settings' notifications.
* Introduces `wp.customize.Control.prototype.renderNotifications()` to re-
render a control's notifications in its notification area. This is called
automatically when the notifications collection changes.
* Introduces `wp.customize.settingConstructor`, allowing custom setting
types to be used in the same way that custom controls, panels, and
sections can be made.
* Injects a notification area into existing controls which is populated in
response to the control's `notifications` collection changing. A custom
control can customize the placement of the notification area by overriding
the new `getNotificationsContainerElement` method.
* When a save fails due to setting invalidity, the invalidity errors will
be added to the settings to then populate in the controls' notification
areas, and the first such invalid control will be focused.
Props westonruter, celloexpressions, mrahmadawais.
See #35210.
See #30937.
Fixes #34893.
}}}
--
Ticket URL: <https://core.trac.wordpress.org/ticket/34893#comment:60>
WordPress Trac <https://core.trac.wordpress.org/>
WordPress publishing platform
More information about the wp-trac
mailing list