WP_Widgets: make save_settings() and get_settings() separate methods, convert defined single widgets settings to multi-widget format, small fixes for the Links widget, see #8441
git-svn-id: http://svn.automattic.com/wordpress/trunk@10781 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
6af5462708
commit
adf37601bb
|
@ -1649,11 +1649,11 @@ class WP_Widgets {
|
||||||
function __construct( $id_base, $name, $widget_options = array(), $control_options = array() ) {
|
function __construct( $id_base, $name, $widget_options = array(), $control_options = array() ) {
|
||||||
$this->id_base = $id_base;
|
$this->id_base = $id_base;
|
||||||
$this->name = $name;
|
$this->name = $name;
|
||||||
$this->option_name = 'wp_widget_' . $id_base;
|
$this->option_name = 'widget_' . $id_base;
|
||||||
$this->widget_options = wp_parse_args( $widget_options, array('classname' => $this->option_name) );
|
$this->widget_options = wp_parse_args( $widget_options, array('classname' => $this->option_name) );
|
||||||
$this->control_options = wp_parse_args( $control_options, array('id_base' => $this->id_base) );
|
$this->control_options = wp_parse_args( $control_options, array('id_base' => $this->id_base) );
|
||||||
|
|
||||||
//add_action( 'widgets_init', array( &$this, 'register' ) );
|
add_action( 'widgets_init', array( &$this, 'register' ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Helper function to be called by form().
|
/** Helper function to be called by form().
|
||||||
|
@ -1671,25 +1671,20 @@ class WP_Widgets {
|
||||||
/** Registers this widget-type.
|
/** Registers this widget-type.
|
||||||
* Called during the 'widgets_init' action. */
|
* Called during the 'widgets_init' action. */
|
||||||
function register() {
|
function register() {
|
||||||
if ( ! $all_instances = get_option($this->option_name) )
|
$settings = $this->get_settings();
|
||||||
$all_instances = array();
|
|
||||||
|
|
||||||
$registered = false;
|
if ( empty($settings) ) {
|
||||||
foreach( array_keys($all_instances) as $number ) {
|
// If there are none, we register the widget's existance with a
|
||||||
// Old widgets can have null values for some reason
|
// generic template
|
||||||
if ( !isset($all_instances[$number]['_multiwidget']) )
|
|
||||||
continue;
|
|
||||||
|
|
||||||
$this->_set($number);
|
|
||||||
$registered = true;
|
|
||||||
$this->_register_one($number);
|
|
||||||
}
|
|
||||||
|
|
||||||
// If there are none, we register the widget's existance with a
|
|
||||||
// generic template
|
|
||||||
if ( !$registered ) {
|
|
||||||
$this->_set(1);
|
$this->_set(1);
|
||||||
$this->_register_one();
|
$this->_register_one();
|
||||||
|
} elseif ( is_array($settings) ) {
|
||||||
|
foreach ( array_keys($settings) as $number ) {
|
||||||
|
if ( is_numeric($number) ) {
|
||||||
|
$this->_set($number);
|
||||||
|
$this->_register_one($number);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1717,12 +1712,10 @@ class WP_Widgets {
|
||||||
|
|
||||||
$widget_args = wp_parse_args( $widget_args, array( 'number' => -1 ) );
|
$widget_args = wp_parse_args( $widget_args, array( 'number' => -1 ) );
|
||||||
$this->_set( $widget_args['number'] );
|
$this->_set( $widget_args['number'] );
|
||||||
|
$settings = $this->get_settings();
|
||||||
|
|
||||||
// Data is stored as array:
|
if ( array_key_exists( $this->number, $settings ) )
|
||||||
// array( number => data for that instance of the widget, ... )
|
$this->widget($args, $settings[$this->number]);
|
||||||
$all_instances = get_option($this->option_name);
|
|
||||||
if ( isset($all_instances[$this->number]) )
|
|
||||||
$this->widget($args, $all_instances[$this->number]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Deal with changed settings and generate the control form.
|
/** Deal with changed settings and generate the control form.
|
||||||
|
@ -1734,15 +1727,11 @@ class WP_Widgets {
|
||||||
$widget_args = array( 'number' => $widget_args );
|
$widget_args = array( 'number' => $widget_args );
|
||||||
|
|
||||||
$widget_args = wp_parse_args( $widget_args, array( 'number' => -1 ) );
|
$widget_args = wp_parse_args( $widget_args, array( 'number' => -1 ) );
|
||||||
|
$all_instances = $this->get_settings();
|
||||||
// Data is stored as array:
|
|
||||||
// array( number => data for that instance of the widget, ... )
|
|
||||||
$all_instances = get_option($this->option_name);
|
|
||||||
if ( !is_array($all_instances) )
|
|
||||||
$all_instances = array();
|
|
||||||
|
|
||||||
// We need to update the data
|
// We need to update the data
|
||||||
if ( !$this->updated && !empty($_POST['sidebar']) ) {
|
if ( !$this->updated && !empty($_POST['sidebar']) ) {
|
||||||
|
|
||||||
// Tells us what sidebar to put the data in
|
// Tells us what sidebar to put the data in
|
||||||
$sidebar = (string) $_POST['sidebar'];
|
$sidebar = (string) $_POST['sidebar'];
|
||||||
|
|
||||||
|
@ -1753,8 +1742,8 @@ class WP_Widgets {
|
||||||
$this_sidebar = array();
|
$this_sidebar = array();
|
||||||
|
|
||||||
foreach ( $this_sidebar as $_widget_id ) {
|
foreach ( $this_sidebar as $_widget_id ) {
|
||||||
// Remove all widgets of this type from the sidebar. We'll add the
|
// Remove all widgets of this type from the sidebar. We'll add the
|
||||||
// new data in a second. This makes sure we don't get any duplicate
|
// new data in a second. This makes sure we don't get any duplicate
|
||||||
// data since widget ids aren't necessarily persistent across multiple
|
// data since widget ids aren't necessarily persistent across multiple
|
||||||
// updates
|
// updates
|
||||||
if ( $this->_get_display_callback() == $wp_registered_widgets[$_widget_id]['callback'] && isset($wp_registered_widgets[$_widget_id]['params'][0]['number']) ) {
|
if ( $this->_get_display_callback() == $wp_registered_widgets[$_widget_id]['callback'] && isset($wp_registered_widgets[$_widget_id]['params'][0]['number']) ) {
|
||||||
|
@ -1773,26 +1762,24 @@ class WP_Widgets {
|
||||||
else
|
else
|
||||||
$instance = $this->update($new_instance, array());
|
$instance = $this->update($new_instance, array());
|
||||||
|
|
||||||
if ( !empty($instance) ) {
|
if ( !empty($instance) )
|
||||||
$instance['_multiwidget'] = $number;
|
|
||||||
$all_instances[$number] = $instance;
|
$all_instances[$number] = $instance;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
update_option($this->option_name, $all_instances);
|
$this->save_settings($all_instances);
|
||||||
$this->updated = true; // So that we don't go through this more than once
|
$this->updated = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Here we echo out the form
|
// Here we echo out the form
|
||||||
if ( -1 == $widget_args['number'] ) {
|
if ( -1 == $widget_args['number'] ) {
|
||||||
// We echo out a template for a form which can be converted to a
|
// We echo out a form where 'number' can be set later via JS
|
||||||
// specific form later via JS
|
|
||||||
$this->_set('%i%');
|
$this->_set('%i%');
|
||||||
$instance = array();
|
$instance = array();
|
||||||
} else {
|
} else {
|
||||||
$this->_set($widget_args['number']);
|
$this->_set($widget_args['number']);
|
||||||
$instance = $all_instances[ $widget_args['number'] ];
|
$instance = $all_instances[ $widget_args['number'] ];
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->form($instance);
|
$this->form($instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1801,7 +1788,26 @@ class WP_Widgets {
|
||||||
wp_register_sidebar_widget( $this->id, $this->name, $this->_get_display_callback(), $this->widget_options, array( 'number' => $number ) );
|
wp_register_sidebar_widget( $this->id, $this->name, $this->_get_display_callback(), $this->widget_options, array( 'number' => $number ) );
|
||||||
wp_register_widget_control( $this->id, $this->name, $this->_get_control_callback(), $this->control_options, array( 'number' => $number ) );
|
wp_register_widget_control( $this->id, $this->name, $this->_get_control_callback(), $this->control_options, array( 'number' => $number ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function save_settings($settings) {
|
||||||
|
$settings['_multiwidget'] = 1;
|
||||||
|
update_option( $this->option_name, $settings );
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_settings() {
|
||||||
|
$settings = get_option($this->option_name);
|
||||||
|
|
||||||
|
if ( !is_array($settings) )
|
||||||
|
return array();
|
||||||
|
|
||||||
|
if ( !array_key_exists('_multiwidget', $settings) ) {
|
||||||
|
// old format, conver if single widget
|
||||||
|
$settings = wp_convert_widget_settings($this->id_base, $this->option_name, $settings);
|
||||||
|
}
|
||||||
|
|
||||||
|
unset($settings['_multiwidget']);
|
||||||
|
return $settings;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
|
|
@ -657,6 +657,47 @@ function wp_get_widget_defaults() {
|
||||||
return $defaults;
|
return $defaults;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert the widget settings from single to multi-widget format.
|
||||||
|
*
|
||||||
|
* @since 2.8.0
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
function wp_convert_widget_settings($base_name, $option_name, $settings) {
|
||||||
|
// This test may need expanding.
|
||||||
|
$single = false;
|
||||||
|
foreach ( array_keys($settings) as $number ) {
|
||||||
|
if ( !is_numeric($number) ) {
|
||||||
|
$single = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( $single ) {
|
||||||
|
$settings = array( 2 => $settings );
|
||||||
|
|
||||||
|
$sidebars_widgets = get_option('sidebars_widgets');
|
||||||
|
foreach ( (array) $sidebars_widgets as $index => $sidebar ) {
|
||||||
|
if ( is_array($sidebar) ) {
|
||||||
|
foreach ( $sidebar as $i => $name ) {
|
||||||
|
if ( $base_name == $name ) {
|
||||||
|
$sidebars_widgets[$index][$i] = "$name-2";
|
||||||
|
break 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
update_option('sidebars_widgets', $sidebars_widgets);
|
||||||
|
}
|
||||||
|
|
||||||
|
$settings['_multiwidget'] = 1;
|
||||||
|
update_option( $option_name, $settings );
|
||||||
|
|
||||||
|
return $settings;
|
||||||
|
}
|
||||||
|
|
||||||
/* Default Widgets */
|
/* Default Widgets */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -767,27 +808,20 @@ class WP_Widget_Links extends WP_Widgets {
|
||||||
if( !isset($new_instance['submit']) ) // user clicked cancel?
|
if( !isset($new_instance['submit']) ) // user clicked cancel?
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return $new_instance;
|
$new_instance = (array) $new_instance;
|
||||||
|
$instance = array( 'images' => 0, 'name' => 0, 'description' => 0, 'rating' => 0);
|
||||||
|
foreach ( $instance as $field => $val ) {
|
||||||
|
if ( isset($new_instance[$field]) )
|
||||||
|
$instance[$field] = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
function form( $instance ) {
|
function form( $instance ) {
|
||||||
|
|
||||||
//Defaults
|
//Defaults
|
||||||
$instance = wp_parse_args( (array) $instance, array( 'images' => true, 'name' => true, 'description' => false, 'rating' => false) );
|
$instance = wp_parse_args( (array) $instance, array( 'images' => true, 'name' => true, 'description' => false, 'rating' => false) );
|
||||||
/*
|
|
||||||
if ( isset($_POST['links-submit']) ) {
|
|
||||||
$newoptions = array();
|
|
||||||
$newoptions['description'] = isset($_POST['links-description']);
|
|
||||||
$newoptions['name'] = isset($_POST['links-name']);
|
|
||||||
$newoptions['rating'] = isset($_POST['links-rating']);
|
|
||||||
$newoptions['images'] = isset($_POST['links-images']);
|
|
||||||
|
|
||||||
if ( $instance != $newoptions ) {
|
|
||||||
$instance = $newoptions;
|
|
||||||
update_option('widget_links', $instance);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
?>
|
?>
|
||||||
<p>
|
<p>
|
||||||
<label for="<?php echo $this->get_field_id('images'); ?>">
|
<label for="<?php echo $this->get_field_id('images'); ?>">
|
||||||
|
@ -1975,7 +2009,7 @@ function wp_widgets_init() {
|
||||||
|
|
||||||
$widget_ops = array('description' => __( "Your blogroll" ) );
|
$widget_ops = array('description' => __( "Your blogroll" ) );
|
||||||
$wp_widget_links = new WP_Widget_Links('links', __('Links'), $widget_ops);
|
$wp_widget_links = new WP_Widget_Links('links', __('Links'), $widget_ops);
|
||||||
$wp_widget_links->register();
|
//$wp_widget_links->register();
|
||||||
|
|
||||||
$widget_ops = array('classname' => 'widget_meta', 'description' => __( "Log in/out, admin, feed and WordPress links") );
|
$widget_ops = array('classname' => 'widget_meta', 'description' => __( "Log in/out, admin, feed and WordPress links") );
|
||||||
wp_register_sidebar_widget('meta', __('Meta'), 'wp_widget_meta', $widget_ops);
|
wp_register_sidebar_widget('meta', __('Meta'), 'wp_widget_meta', $widget_ops);
|
||||||
|
|
Loading…
Reference in New Issue