mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-20 15:21:28 +01:00
Widgets: Always try restoring widget assignments
For code-historic reasons, restoring widget assignments would not be attempted if there were no sidebars to map. Restoring previous assignments is something unrelated to sidebar mappings however, so now it will be attempted on every theme switch. See #42719. Built from https://develop.svn.wordpress.org/trunk@42374 git-svn-id: http://core.svn.wordpress.org/trunk@42203 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
f4faaa53c7
commit
856e7917e8
@ -4,7 +4,7 @@
|
|||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '5.0-alpha-42373';
|
$wp_version = '5.0-alpha-42374';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
@ -1219,6 +1219,7 @@ function retrieve_widgets( $theme_changed = false ) {
|
|||||||
* Compares a list of sidebars with their widgets against a whitelist.
|
* Compares a list of sidebars with their widgets against a whitelist.
|
||||||
*
|
*
|
||||||
* @since 4.9.0
|
* @since 4.9.0
|
||||||
|
* @since 4.9.2 Always tries to restore widget assignments from previous data, not just if sidebars needed mapping.
|
||||||
*
|
*
|
||||||
* @param array $existing_sidebars_widgets List of sidebars and their widget instance IDs.
|
* @param array $existing_sidebars_widgets List of sidebars and their widget instance IDs.
|
||||||
* @return array Mapped sidebars widgets.
|
* @return array Mapped sidebars widgets.
|
||||||
@ -1261,10 +1262,8 @@ function wp_map_sidebars_widgets( $existing_sidebars_widgets ) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// If there are no old sidebars left, then we're done.
|
// If there are more sidebars, try to map them.
|
||||||
if ( empty( $existing_sidebars_widgets ) ) {
|
if ( ! empty( $existing_sidebars_widgets ) ) {
|
||||||
return $new_sidebars_widgets;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If old and new theme both have sidebars that contain phrases
|
* If old and new theme both have sidebars that contain phrases
|
||||||
@ -1319,6 +1318,7 @@ function wp_map_sidebars_widgets( $existing_sidebars_widgets ) {
|
|||||||
} // endforeach foreach ( $wp_registered_sidebars as $new_sidebar => $args )
|
} // endforeach foreach ( $wp_registered_sidebars as $new_sidebar => $args )
|
||||||
} // endforeach ( $slug_group as $slug )
|
} // endforeach ( $slug_group as $slug )
|
||||||
} // endforeach ( $common_slug_groups as $slug_group )
|
} // endforeach ( $common_slug_groups as $slug_group )
|
||||||
|
}
|
||||||
|
|
||||||
// Move any left over widgets to inactive sidebar.
|
// Move any left over widgets to inactive sidebar.
|
||||||
foreach ( $existing_sidebars_widgets as $widgets ) {
|
foreach ( $existing_sidebars_widgets as $widgets ) {
|
||||||
@ -1329,7 +1329,7 @@ function wp_map_sidebars_widgets( $existing_sidebars_widgets ) {
|
|||||||
|
|
||||||
// Sidebars_widgets settings from when this theme was previously active.
|
// Sidebars_widgets settings from when this theme was previously active.
|
||||||
$old_sidebars_widgets = get_theme_mod( 'sidebars_widgets' );
|
$old_sidebars_widgets = get_theme_mod( 'sidebars_widgets' );
|
||||||
$old_sidebars_widgets = $old_sidebars_widgets['data'];
|
$old_sidebars_widgets = isset( $old_sidebars_widgets['data'] ) ? $old_sidebars_widgets['data'] : false;
|
||||||
|
|
||||||
if ( is_array( $old_sidebars_widgets ) ) {
|
if ( is_array( $old_sidebars_widgets ) ) {
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user