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: https://develop.svn.wordpress.org/trunk@10781 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
a8f8d9bdad
commit
3689f64ee3
@ -1649,11 +1649,11 @@ class WP_Widgets {
|
||||
function __construct( $id_base, $name, $widget_options = array(), $control_options = array() ) {
|
||||
$this->id_base = $id_base;
|
||||
$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->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().
|
||||
@ -1671,25 +1671,20 @@ class WP_Widgets {
|
||||
/** Registers this widget-type.
|
||||
* Called during the 'widgets_init' action. */
|
||||
function register() {
|
||||
if ( ! $all_instances = get_option($this->option_name) )
|
||||
$all_instances = array();
|
||||
|
||||
$registered = false;
|
||||
foreach( array_keys($all_instances) as $number ) {
|
||||
// Old widgets can have null values for some reason
|
||||
if ( !isset($all_instances[$number]['_multiwidget']) )
|
||||
continue;
|
||||
|
||||
$this->_set($number);
|
||||
$registered = true;
|
||||
$this->_register_one($number);
|
||||
}
|
||||
$settings = $this->get_settings();
|
||||
|
||||
if ( empty($settings) ) {
|
||||
// If there are none, we register the widget's existance with a
|
||||
// generic template
|
||||
if ( !$registered ) {
|
||||
$this->_set(1);
|
||||
$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 ) );
|
||||
$this->_set( $widget_args['number'] );
|
||||
$settings = $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 ( isset($all_instances[$this->number]) )
|
||||
$this->widget($args, $all_instances[$this->number]);
|
||||
if ( array_key_exists( $this->number, $settings ) )
|
||||
$this->widget($args, $settings[$this->number]);
|
||||
}
|
||||
|
||||
/** Deal with changed settings and generate the control form.
|
||||
@ -1734,15 +1727,11 @@ class WP_Widgets {
|
||||
$widget_args = array( 'number' => $widget_args );
|
||||
|
||||
$widget_args = wp_parse_args( $widget_args, array( 'number' => -1 ) );
|
||||
|
||||
// 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();
|
||||
$all_instances = $this->get_settings();
|
||||
|
||||
// We need to update the data
|
||||
if ( !$this->updated && !empty($_POST['sidebar']) ) {
|
||||
|
||||
// Tells us what sidebar to put the data in
|
||||
$sidebar = (string) $_POST['sidebar'];
|
||||
|
||||
@ -1773,26 +1762,24 @@ class WP_Widgets {
|
||||
else
|
||||
$instance = $this->update($new_instance, array());
|
||||
|
||||
if ( !empty($instance) ) {
|
||||
$instance['_multiwidget'] = $number;
|
||||
if ( !empty($instance) )
|
||||
$all_instances[$number] = $instance;
|
||||
}
|
||||
}
|
||||
|
||||
update_option($this->option_name, $all_instances);
|
||||
$this->updated = true; // So that we don't go through this more than once
|
||||
$this->save_settings($all_instances);
|
||||
$this->updated = true;
|
||||
}
|
||||
|
||||
// Here we echo out the form
|
||||
if ( -1 == $widget_args['number'] ) {
|
||||
// We echo out a template for a form which can be converted to a
|
||||
// specific form later via JS
|
||||
// We echo out a form where 'number' can be set later via JS
|
||||
$this->_set('%i%');
|
||||
$instance = array();
|
||||
} else {
|
||||
$this->_set($widget_args['number']);
|
||||
$instance = $all_instances[ $widget_args['number'] ];
|
||||
}
|
||||
|
||||
$this->form($instance);
|
||||
}
|
||||
|
||||
@ -1802,6 +1789,25 @@ class WP_Widgets {
|
||||
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;
|
||||
}
|
||||
|
||||
/**
|
||||
* 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 */
|
||||
|
||||
/**
|
||||
@ -767,27 +808,20 @@ class WP_Widget_Links extends WP_Widgets {
|
||||
if( !isset($new_instance['submit']) ) // user clicked cancel?
|
||||
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 ) {
|
||||
|
||||
//Defaults
|
||||
$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>
|
||||
<label for="<?php echo $this->get_field_id('images'); ?>">
|
||||
@ -1975,7 +2009,7 @@ function wp_widgets_init() {
|
||||
|
||||
$widget_ops = array('description' => __( "Your blogroll" ) );
|
||||
$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") );
|
||||
wp_register_sidebar_widget('meta', __('Meta'), 'wp_widget_meta', $widget_ops);
|
||||
|
Loading…
Reference in New Issue
Block a user