2007-04-23 21:05:17 -04:00
< ? php
2008-09-18 21:41:18 -04:00
/**
* API for creating dynamic sidebar without hardcoding functionality into
* themes . Includes both internal WordPress routines and theme use routines .
*
* This functionality was found in a plugin before WordPress 2.2 release which
* included it in the core from that point on .
*
* @ link http :// codex . wordpress . org / Plugins / WordPress_Widgets WordPress Widgets
* @ link http :// codex . wordpress . org / Plugins / WordPress_Widgets_Api Widgets API
*
* @ package WordPress
* @ subpackage Widgets
*/
2007-04-23 21:05:17 -04:00
/* Global Variables */
2008-09-18 21:41:18 -04:00
/** @ignore */
2008-01-04 18:34:33 -05:00
global $wp_registered_sidebars , $wp_registered_widgets , $wp_registered_widget_controls ;
2007-04-30 21:13:06 -04:00
2008-09-18 21:41:18 -04:00
/**
* Stores the sidebars , since many themes can have more than one .
*
* @ global array $wp_registered_sidebars
* @ since 2.2 . 0
*/
2007-04-23 21:05:17 -04:00
$wp_registered_sidebars = array ();
2008-09-18 21:41:18 -04:00
/**
* Stores the registered widgets .
*
* @ global array $wp_registered_widgets
* @ since 2.2 . 0
*/
2007-04-23 21:05:17 -04:00
$wp_registered_widgets = array ();
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Stores the registered widget control ( options ) .
2008-09-18 21:41:18 -04:00
*
* @ global array $wp_registered_widget_controls
* @ since 2.2 . 0
*/
2007-04-23 21:05:17 -04:00
$wp_registered_widget_controls = array ();
2009-03-13 19:18:57 -04:00
/**
* This class must be extended for each widget and WP_Widget :: widget (), WP_Widget :: update ()
* and WP_Widget :: form () need to be over - ridden .
*
* @ package WordPress
* @ subpackage Widgets
* @ since 2.8
*/
class WP_Widget {
var $id_base ; // Root id for all widgets of this type.
var $name ; // Name for this widget type.
var $widget_options ; // Option array passed to wp_register_sidebar_widget()
var $control_options ; // Option array passed to wp_register_widget_control()
var $number = false ; // Unique ID number of the current instance.
var $id = false ; // Unique ID string of the current instance (id_base-number)
var $updated = false ; // Set true when we update the data after a POST submit - makes sure we don't do it twice.
// Member functions that you must over-ride.
/** Echo the actual widget content . Subclasses should over - ride this function
* to generate their widget code . */
function widget ( $args , $instance ) {
die ( 'function WP_Widget::widget() must be over-ridden in a sub-class.' );
}
/** Update a particular instance .
* This function should check that $new_instance is set correctly .
* The newly calculated value of $instance should be returned . */
function update ( $new_instance , $old_instance ) {
2009-03-14 12:34:08 -04:00
return $new_instance ;
2009-03-13 19:18:57 -04:00
}
/** Echo a control form for the current instance. */
function form ( $instance ) {
2009-03-14 12:34:08 -04:00
echo '<p>' . __ ( 'There are no options for this widget.' ) . '</p>' ;
2009-03-13 19:18:57 -04:00
}
// Functions you'll need to call.
/**
* PHP4 constructor
*/
function WP_Widget ( $id_base , $name , $widget_options = array (), $control_options = array () ) {
$this -> __construct ( $id_base , $name , $widget_options , $control_options );
}
/**
* PHP5 constructor
* widget_options : passed to wp_register_sidebar_widget ()
* - description
* - classname
* control_options : passed to wp_register_widget_control ()
* - width
* - height
*/
function __construct ( $id_base , $name , $widget_options = array (), $control_options = array () ) {
$this -> id_base = $id_base ;
$this -> name = $name ;
$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' ) );
}
/** Helper function to be called by form () .
* Returns an HTML name for the field . */
function get_field_name ( $field_name ) {
return 'widget-' . $this -> id_base . '[' . $this -> number . '][' . $field_name . ']' ;
}
/** Helper function to be called by form () .
* Returns an HTML id for the field . */
function get_field_id ( $field_name ) {
return 'widget-' . $this -> id_base . '-' . $this -> number . '-' . $field_name ;
}
/** Registers this widget - type .
* Called during the 'widgets_init' action . */
function register () {
$settings = $this -> get_settings ();
if ( empty ( $settings ) ) {
// If there are none, we register the widget's existance with a
// generic template
$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 );
}
}
}
}
// Private Functions. Don't worry about these.
function _set ( $number ) {
$this -> number = $number ;
$this -> id = $this -> id_base . '-' . $number ;
}
function _get_display_callback () {
return array ( & $this , 'display_callback' );
}
function _get_control_callback () {
return array ( & $this , 'control_callback' );
}
/** Generate the actual widget content .
* Just finds the instance and calls widget () .
* Do NOT over - ride this function . */
function display_callback ( $args , $widget_args = 1 ) {
if ( is_numeric ( $widget_args ) )
$widget_args = array ( 'number' => $widget_args );
$widget_args = wp_parse_args ( $widget_args , array ( 'number' => - 1 ) );
$this -> _set ( $widget_args [ 'number' ] );
$settings = $this -> get_settings ();
if ( array_key_exists ( $this -> number , $settings ) )
$this -> widget ( $args , $settings [ $this -> number ]);
}
/** Deal with changed settings and generate the control form .
* Do NOT over - ride this function . */
function control_callback ( $widget_args = 1 ) {
global $wp_registered_widgets ;
if ( is_numeric ( $widget_args ) )
$widget_args = array ( 'number' => $widget_args );
$widget_args = wp_parse_args ( $widget_args , array ( 'number' => - 1 ) );
$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' ];
$sidebars_widgets = wp_get_sidebars_widgets ();
if ( isset ( $sidebars_widgets [ $sidebar ]) )
$this_sidebar =& $sidebars_widgets [ $sidebar ];
else
$this_sidebar = array ();
foreach ( $this_sidebar as $_widget_id ) {
// 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
// data since widget ids aren't necessarily persistent across multiple
// updates
if ( $this -> _get_display_callback () == $wp_registered_widgets [ $_widget_id ][ 'callback' ] && isset ( $wp_registered_widgets [ $_widget_id ][ 'params' ][ 0 ][ 'number' ]) ) {
$number = $wp_registered_widgets [ $_widget_id ][ 'params' ][ 0 ][ 'number' ];
if ( ! in_array ( $this -> id_base . '-' . $number , ( array ) $_POST [ 'widget-id' ] ) ) {
// the widget has been removed.
unset ( $all_instances [ $number ]);
}
}
}
foreach ( ( array ) $_POST [ 'widget-' . $this -> id_base ] as $number => $new_instance ) {
2009-03-14 13:24:11 -04:00
$new_instance = stripslashes_deep ( $new_instance );
2009-03-13 19:18:57 -04:00
$this -> _set ( $number );
if ( isset ( $all_instances [ $number ]) )
$instance = $this -> update ( $new_instance , $all_instances [ $number ]);
else
$instance = $this -> update ( $new_instance , array ());
if ( ! empty ( $instance ) )
$all_instances [ $number ] = $instance ;
}
$this -> save_settings ( $all_instances );
$this -> updated = true ;
}
// Here we echo out the form
if ( - 1 == $widget_args [ 'number' ] ) {
// 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 );
}
/** Helper function: Registers a single instance. */
function _register_one ( $number = - 1 ) {
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 ) );
}
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 ) )
2009-03-14 12:34:08 -04:00
$settings = array ();
2009-03-13 19:18:57 -04:00
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 ;
}
}
2007-04-23 21:05:17 -04:00
/* Template tags & API functions */
2008-09-18 21:41:18 -04:00
/**
* Creates multiple sidebars .
*
* If you wanted to quickly create multiple sidebars for a theme or internally .
* This function will allow you to do so . If you don 't pass the ' name ' and / or
* 'id' in $args , then they will be built for you .
*
* The default for the name is " Sidebar # " , with '#' being replaced with the
* number the sidebar is currently when greater than one . If first sidebar , the
* name will be just " Sidebar " . The default for id is " sidebar- " followed by the
* number the sidebar creation is currently at .
*
* @ since 2.2 . 0
*
* @ see register_sidebar () The second parameter is documented by register_sidebar () and is the same here .
* @ uses parse_str () Converts a string to an array to be used in the rest of the function .
* @ uses register_sidebar () Sends single sidebar information [ name , id ] to this
* function to handle building the sidebar .
*
* @ param int $number Number of sidebars to create .
* @ param string | array $args Builds Sidebar based off of 'name' and 'id' values .
*/
2007-04-24 17:36:17 -04:00
function register_sidebars ( $number = 1 , $args = array ()) {
2007-12-14 03:06:08 -05:00
global $wp_registered_sidebars ;
2007-04-24 17:36:17 -04:00
$number = ( int ) $number ;
if ( is_string ( $args ) )
parse_str ( $args , $args );
2007-10-19 12:32:56 -04:00
for ( $i = 1 ; $i <= $number ; $i ++ ) {
2007-04-24 17:36:17 -04:00
$_args = $args ;
2007-12-14 03:06:08 -05:00
2007-04-24 17:36:17 -04:00
if ( $number > 1 ) {
2007-12-14 03:06:08 -05:00
$_args [ 'name' ] = isset ( $args [ 'name' ]) ? sprintf ( $args [ 'name' ], $i ) : sprintf ( __ ( 'Sidebar %d' ), $i );
2007-04-24 17:36:17 -04:00
} else {
$_args [ 'name' ] = isset ( $args [ 'name' ]) ? $args [ 'name' ] : __ ( 'Sidebar' );
2007-04-23 21:05:17 -04:00
}
2007-12-14 03:06:08 -05:00
if ( isset ( $args [ 'id' ])) {
$_args [ 'id' ] = $args [ 'id' ];
} else {
$n = count ( $wp_registered_sidebars );
do {
$n ++ ;
$_args [ 'id' ] = " sidebar- $n " ;
} while ( isset ( $wp_registered_sidebars [ $_args [ 'id' ]]));
}
2007-04-24 17:36:17 -04:00
register_sidebar ( $_args );
2007-04-23 21:05:17 -04:00
}
}
2008-09-18 21:41:18 -04:00
/**
* Builds the definition for a single sidebar and returns the ID .
*
* The $args parameter takes either a string or an array with 'name' and 'id'
* contained in either usage . It will be noted that the values will be applied
* to all sidebars , so if creating more than one , it will be advised to allow
* for WordPress to create the defaults for you .
*
* Example for string would be < code > 'name=whatever;id=whatever1' </ code > and for
* the array it would be < code > array (
* 'name' => 'whatever' ,
* 'id' => 'whatever1' ) </ code >.
*
* name - The name of the sidebar , which presumably the title which will be
* displayed .
* id - The unique identifier by which the sidebar will be called by .
* before_widget - The content that will prepended to the widgets when they are
* displayed .
* after_widget - The content that will be appended to the widgets when they are
* displayed .
* before_title - The content that will be prepended to the title when displayed .
* after_title - the content that will be appended to the title when displayed .
*
* < em > Content </ em > is assumed to be HTML and should be formatted as such , but
* doesn ' t have to be .
*
* @ since 2.2 . 0
* @ uses $wp_registered_sidebars Stores the new sidebar in this array by sidebar ID .
* @ uses parse_str () Converts a string to an array to be used in the rest of the function .
* @ usedby register_sidebars ()
*
* @ param string | array $args Builds Sidebar based off of 'name' and 'id' values
* @ return string The sidebar id that was added .
*/
2007-04-24 17:36:17 -04:00
function register_sidebar ( $args = array ()) {
global $wp_registered_sidebars ;
if ( is_string ( $args ) )
parse_str ( $args , $args );
$i = count ( $wp_registered_sidebars ) + 1 ;
$defaults = array (
2007-04-30 16:02:02 -04:00
'name' => sprintf ( __ ( 'Sidebar %d' ), $i ),
'id' => " sidebar- $i " ,
2007-04-24 17:36:17 -04:00
'before_widget' => '<li id="%1$s" class="widget %2$s">' ,
'after_widget' => " </li> \n " ,
'before_title' => '<h2 class="widgettitle">' ,
'after_title' => " </h2> \n " ,
);
2008-08-04 16:34:45 -04:00
$sidebar = array_merge ( $defaults , ( array ) $args );
2007-04-24 17:36:17 -04:00
$wp_registered_sidebars [ $sidebar [ 'id' ]] = $sidebar ;
return $sidebar [ 'id' ];
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
* Removes a sidebar from the list .
*
* @ since 2.2 . 0
*
* @ uses $wp_registered_sidebars Stores the new sidebar in this array by sidebar ID .
*
* @ param string $name The ID of the sidebar when it was added .
*/
2007-04-24 17:36:17 -04:00
function unregister_sidebar ( $name ) {
global $wp_registered_sidebars ;
2007-06-13 22:25:30 -04:00
2007-04-24 17:36:17 -04:00
if ( isset ( $wp_registered_sidebars [ $name ] ) )
unset ( $wp_registered_sidebars [ $name ] );
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Register widget for sidebar with backwards compatibility .
2008-09-18 21:41:18 -04:00
*
2008-09-23 00:03:28 -04:00
* Allows $name to be an array that accepts either three elements to grab the
* first element and the third for the name or just uses the first element of
* the array for the name .
*
* Passes to { @ link wp_register_sidebar_widget ()} after argument list and
* backwards compatibility is complete .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
* @ uses wp_register_sidebar_widget () Passes the compiled arguments .
*
2008-09-23 00:03:28 -04:00
* @ param string | int $name Widget ID .
* @ param callback $output_callback Run when widget is called .
* @ param string $classname Classname widget option .
* @ param mixed $params , ... Widget parameters .
2008-09-18 21:41:18 -04:00
*/
2007-05-06 03:08:11 -04:00
function register_sidebar_widget ( $name , $output_callback , $classname = '' ) {
2007-04-24 17:36:17 -04:00
// Compat
if ( is_array ( $name ) ) {
if ( count ( $name ) == 3 )
$name = sprintf ( $name [ 0 ], $name [ 2 ]);
else
$name = $name [ 0 ];
}
2007-05-06 03:08:11 -04:00
$id = sanitize_title ( $name );
$options = array ();
2007-05-16 13:49:32 -04:00
if ( ! empty ( $classname ) && is_string ( $classname ) )
2007-05-06 03:08:11 -04:00
$options [ 'classname' ] = $classname ;
2007-05-16 13:49:32 -04:00
$params = array_slice ( func_get_args (), 2 );
2007-05-06 03:08:11 -04:00
$args = array ( $id , $name , $output_callback , $options );
if ( ! empty ( $params ) )
$args = array_merge ( $args , $params );
call_user_func_array ( 'wp_register_sidebar_widget' , $args );
}
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Register widget for use in sidebars .
*
* The default widget option is 'classname' that can be override .
2008-09-18 21:41:18 -04:00
*
2008-09-23 00:03:28 -04:00
* The function can also be used to unregister widgets when $output_callback
* parameter is an empty string .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-23 00:03:28 -04:00
* @ uses $wp_registered_widgets Uses stored registered widgets .
* @ uses $wp_register_widget_defaults Retrieves widget defaults .
2008-09-18 21:41:18 -04:00
*
2008-09-23 00:03:28 -04:00
* @ param int | string $id Widget ID .
* @ param string $name Widget display title .
* @ param callback $output_callback Run when widget is called .
* @ param array | string Optional . $options Widget Options .
* @ param mixed $params , ... Widget parameters to add to widget .
* @ return null Will return if $output_callback is empty after removing widget .
2008-09-18 21:41:18 -04:00
*/
2007-05-06 03:08:11 -04:00
function wp_register_sidebar_widget ( $id , $name , $output_callback , $options = array ()) {
2008-01-04 18:34:33 -05:00
global $wp_registered_widgets ;
2007-05-06 03:08:11 -04:00
2008-05-09 12:29:17 -04:00
$id = strtolower ( $id );
2007-05-06 03:08:11 -04:00
if ( empty ( $output_callback ) ) {
unset ( $wp_registered_widgets [ $id ]);
return ;
}
$defaults = array ( 'classname' => $output_callback );
$options = wp_parse_args ( $options , $defaults );
2007-04-24 17:36:17 -04:00
$widget = array (
'name' => $name ,
'id' => $id ,
'callback' => $output_callback ,
'params' => array_slice ( func_get_args (), 4 )
);
2007-05-06 03:08:11 -04:00
$widget = array_merge ( $widget , $options );
2007-04-24 17:36:17 -04:00
2008-01-04 18:34:33 -05:00
if ( is_callable ( $output_callback ) && ( ! isset ( $wp_registered_widgets [ $id ]) || did_action ( 'widgets_init' ) ) )
2007-04-24 17:36:17 -04:00
$wp_registered_widgets [ $id ] = $widget ;
}
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Retrieve description for widget .
2008-09-18 21:41:18 -04:00
*
2008-09-23 00:03:28 -04:00
* When registering widgets , the options can also include 'description' that
* describes the widget for display on the widget administration panel or
* in the theme .
2008-09-18 21:41:18 -04:00
*
* @ since 2.5 . 0
*
2008-09-23 00:03:28 -04:00
* @ param int | string $id Widget ID .
* @ return string Widget description , if available . Null on failure to retrieve description .
2008-09-18 21:41:18 -04:00
*/
2008-01-04 18:34:33 -05:00
function wp_widget_description ( $id ) {
if ( ! is_scalar ( $id ) )
return ;
global $wp_registered_widgets ;
if ( isset ( $wp_registered_widgets [ $id ][ 'description' ]) )
return wp_specialchars ( $wp_registered_widgets [ $id ][ 'description' ] );
}
2008-09-18 21:41:18 -04:00
/**
* Alias of { @ link wp_unregister_sidebar_widget ()} .
*
* @ see wp_unregister_sidebar_widget ()
*
* @ since 2.2 . 0
*
2008-09-23 00:03:28 -04:00
* @ param int | string $id Widget ID .
2008-09-18 21:41:18 -04:00
*/
2007-04-24 17:36:17 -04:00
function unregister_sidebar_widget ( $id ) {
2007-05-06 03:08:11 -04:00
return wp_unregister_sidebar_widget ( $id );
2007-04-24 17:36:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Remove widget from sidebar .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-23 00:03:28 -04:00
* @ param int | string $id Widget ID .
2008-09-18 21:41:18 -04:00
*/
2007-05-06 03:08:11 -04:00
function wp_unregister_sidebar_widget ( $id ) {
wp_register_sidebar_widget ( $id , '' , '' );
wp_unregister_widget_control ( $id );
}
2007-04-24 17:36:17 -04:00
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Registers widget control callback for customizing options .
2008-09-18 21:41:18 -04:00
*
2008-09-23 00:03:28 -04:00
* Allows $name to be an array that accepts either three elements to grab the
* first element and the third for the name or just uses the first element of
* the array for the name .
*
* Passes to { @ link wp_register_widget_control ()} after the argument list has
* been compiled .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-23 00:03:28 -04:00
* @ param int | string $name Sidebar ID .
* @ param callback $control_callback Widget control callback to display and process form .
* @ param int $width Widget width .
* @ param int $height Widget height .
2008-09-18 21:41:18 -04:00
*/
2007-05-06 03:08:11 -04:00
function register_widget_control ( $name , $control_callback , $width = '' , $height = '' ) {
2007-04-24 17:36:17 -04:00
// Compat
if ( is_array ( $name ) ) {
if ( count ( $name ) == 3 )
$name = sprintf ( $name [ 0 ], $name [ 2 ]);
else
$name = $name [ 0 ];
}
2007-05-06 03:08:11 -04:00
$id = sanitize_title ( $name );
$options = array ();
if ( ! empty ( $width ) )
$options [ 'width' ] = $width ;
if ( ! empty ( $height ) )
$options [ 'height' ] = $height ;
$params = array_slice ( func_get_args (), 4 );
$args = array ( $id , $name , $control_callback , $options );
if ( ! empty ( $params ) )
$args = array_merge ( $args , $params );
2007-04-24 17:36:17 -04:00
2007-05-06 03:08:11 -04:00
call_user_func_array ( 'wp_register_widget_control' , $args );
}
2007-04-24 17:36:17 -04:00
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Registers widget control callback for customizing options .
2008-09-18 21:41:18 -04:00
*
2008-09-23 00:03:28 -04:00
* The options contains the 'height' , 'width' , and 'id_base' keys . The 'height'
* option is never used . The 'width' option is the width of the fully expanded
* control form , but try hard to use the default width . The 'id_base' is for
* multi - widgets ( widgets which allow multiple instances such as the text
* widget ), an id_base must be provided . The widget id will end up looking like
* { $id_base } - { $unique_number } .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-23 00:03:28 -04:00
* @ param int | string $id Sidebar ID .
* @ param string $name Sidebar display name .
* @ param callback $control_callback Run when sidebar is displayed .
* @ param array | string $options Optional . Widget options . See above long description .
* @ param mixed $params , ... Optional . Additional parameters to add to widget .
2008-09-18 21:41:18 -04:00
*/
2007-05-06 03:08:11 -04:00
function wp_register_widget_control ( $id , $name , $control_callback , $options = array ()) {
2008-01-04 18:34:33 -05:00
global $wp_registered_widget_controls ;
2008-08-09 01:36:14 -04:00
2008-05-09 12:29:17 -04:00
$id = strtolower ( $id );
2007-04-24 17:36:17 -04:00
2007-05-06 03:08:11 -04:00
if ( empty ( $control_callback ) ) {
2007-04-28 13:04:16 -04:00
unset ( $wp_registered_widget_controls [ $id ]);
2007-05-06 03:08:11 -04:00
return ;
}
2008-01-04 18:34:33 -05:00
if ( isset ( $wp_registered_widget_controls [ $id ]) && ! did_action ( 'widgets_init' ) )
2007-05-06 03:08:11 -04:00
return ;
2008-01-04 18:34:33 -05:00
$defaults = array ( 'width' => 250 , 'height' => 200 ); // height is never used
2007-05-06 03:08:11 -04:00
$options = wp_parse_args ( $options , $defaults );
$options [ 'width' ] = ( int ) $options [ 'width' ];
$options [ 'height' ] = ( int ) $options [ 'height' ];
$widget = array (
'name' => $name ,
'id' => $id ,
'callback' => $control_callback ,
'params' => array_slice ( func_get_args (), 4 )
);
$widget = array_merge ( $widget , $options );
$wp_registered_widget_controls [ $id ] = $widget ;
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
* Alias of { @ link wp_unregister_widget_control ()} .
*
* @ since 2.2 . 0
* @ see wp_unregister_widget_control ()
*
2008-09-23 00:03:28 -04:00
* @ param int | string $id Widget ID .
2008-09-18 21:41:18 -04:00
*/
2007-04-24 17:36:17 -04:00
function unregister_widget_control ( $id ) {
2007-05-06 03:08:11 -04:00
return wp_unregister_widget_control ( $id );
}
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Remove control callback for widget .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
2008-09-23 00:03:28 -04:00
* @ uses wp_register_widget_control () Unregisters by using empty callback .
2008-09-18 21:41:18 -04:00
*
2008-09-23 00:03:28 -04:00
* @ param int | string $id Widget ID .
2008-09-18 21:41:18 -04:00
*/
2007-05-06 03:08:11 -04:00
function wp_unregister_widget_control ( $id ) {
return wp_register_widget_control ( $id , '' , '' );
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Display dynamic sidebar .
*
* By default it displays the default sidebar or 'sidebar-1' . The 'sidebar-1' is
* not named by the theme , the actual name is '1' , but 'sidebar-' is added to
* the registered sidebars for the name . If you named your sidebar 'after-post' ,
* then the parameter $index will still be 'after-post' , but the lookup will be
* for 'sidebar-after-post' .
2008-09-18 21:41:18 -04:00
*
2008-09-23 00:03:28 -04:00
* It is confusing for the $index parameter , but just know that it should just
* work . When you register the sidebar in the theme , you will use the same name
* for this function or " Pay no heed to the man behind the curtain. " Just accept
* it as an oddity of WordPress sidebar register and display .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-23 00:03:28 -04:00
* @ param int | string $index Optional , default is 1. Name or ID of dynamic sidebar .
* @ return bool True , if widget sidebar was found and called . False if not found or not called .
2008-09-18 21:41:18 -04:00
*/
2007-04-24 17:36:17 -04:00
function dynamic_sidebar ( $index = 1 ) {
global $wp_registered_sidebars , $wp_registered_widgets ;
2007-04-23 21:05:17 -04:00
2007-04-24 17:36:17 -04:00
if ( is_int ( $index ) ) {
$index = " sidebar- $index " ;
} else {
$index = sanitize_title ( $index );
2008-08-06 16:31:54 -04:00
foreach ( ( array ) $wp_registered_sidebars as $key => $value ) {
2007-05-14 01:13:39 -04:00
if ( sanitize_title ( $value [ 'name' ]) == $index ) {
$index = $key ;
break ;
}
}
2007-04-23 21:05:17 -04:00
}
2007-04-24 17:36:17 -04:00
$sidebars_widgets = wp_get_sidebars_widgets ();
2007-12-20 16:25:12 -05:00
if ( empty ( $wp_registered_sidebars [ $index ]) || ! array_key_exists ( $index , $sidebars_widgets ) || ! is_array ( $sidebars_widgets [ $index ]) || empty ( $sidebars_widgets [ $index ]) )
2007-04-24 17:36:17 -04:00
return false ;
$sidebar = $wp_registered_sidebars [ $index ];
$did_one = false ;
2008-08-06 16:31:54 -04:00
foreach ( ( array ) $sidebars_widgets [ $index ] as $id ) {
2008-02-02 02:57:51 -05:00
$params = array_merge (
array ( array_merge ( $sidebar , array ( 'widget_id' => $id , 'widget_name' => $wp_registered_widgets [ $id ][ 'name' ]) ) ),
( array ) $wp_registered_widgets [ $id ][ 'params' ]
);
2007-04-24 17:36:17 -04:00
// Substitute HTML id and class attributes into before_widget
2007-09-12 16:48:21 -04:00
$classname_ = '' ;
foreach ( ( array ) $wp_registered_widgets [ $id ][ 'classname' ] as $cn ) {
if ( is_string ( $cn ) )
$classname_ .= '_' . $cn ;
elseif ( is_object ( $cn ) )
$classname_ .= '_' . get_class ( $cn );
}
$classname_ = ltrim ( $classname_ , '_' );
2007-09-06 19:27:16 -04:00
$params [ 0 ][ 'before_widget' ] = sprintf ( $params [ 0 ][ 'before_widget' ], $id , $classname_ );
2007-04-24 17:36:17 -04:00
2008-02-02 02:57:51 -05:00
$params = apply_filters ( 'dynamic_sidebar_params' , $params );
$callback = $wp_registered_widgets [ $id ][ 'callback' ];
2007-04-24 17:36:17 -04:00
if ( is_callable ( $callback ) ) {
call_user_func_array ( $callback , $params );
$did_one = true ;
2007-04-23 21:05:17 -04:00
}
}
2007-04-24 17:36:17 -04:00
return $did_one ;
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Whether widget is registered using callback with widget ID .
2008-09-18 21:41:18 -04:00
*
2009-02-10 10:22:08 -05:00
* Without the optional $widget_id parameter , returns the ID of the first sidebar in which the first instance of the widget with the given callback is found .
* With the $widget_id parameter , returns the ID of the sidebar in which the widget with that callback AND that ID is found .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-23 00:03:28 -04:00
* @ param callback $callback Widget callback to check .
* @ param int $widget_id Optional , but needed for checking . Widget ID .
/* @ return mixed false if widget is not active or id of sidebar in which the widget is active .
2008-01-04 18:34:33 -05:00
*/
2008-02-27 19:31:46 -05:00
function is_active_widget ( $callback , $widget_id = false ) {
2007-04-24 17:36:17 -04:00
global $wp_registered_widgets ;
$sidebars_widgets = wp_get_sidebars_widgets ( false );
2008-01-04 18:34:33 -05:00
if ( is_array ( $sidebars_widgets ) ) foreach ( $sidebars_widgets as $sidebar => $widgets )
2007-04-24 17:36:17 -04:00
if ( is_array ( $widgets ) ) foreach ( $widgets as $widget )
2008-02-22 12:43:56 -05:00
if ( isset ( $wp_registered_widgets [ $widget ][ 'callback' ]) && $wp_registered_widgets [ $widget ][ 'callback' ] == $callback )
2008-02-27 19:31:46 -05:00
if ( ! $widget_id || $widget_id == $wp_registered_widgets [ $widget ][ 'id' ] )
return $sidebar ;
2008-03-02 15:17:30 -05:00
2007-04-24 17:36:17 -04:00
return false ;
}
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Whether the dynamic sidebar is enabled and used by theme .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-23 00:03:28 -04:00
* @ return bool True , if using widgets . False , if not using widgets .
2008-09-18 21:41:18 -04:00
*/
2007-04-24 17:36:17 -04:00
function is_dynamic_sidebar () {
global $wp_registered_widgets , $wp_registered_sidebars ;
$sidebars_widgets = get_option ( 'sidebars_widgets' );
2008-08-06 16:31:54 -04:00
foreach ( ( array ) $wp_registered_sidebars as $index => $sidebar ) {
2007-04-24 17:36:17 -04:00
if ( count ( $sidebars_widgets [ $index ]) ) {
2008-08-06 16:31:54 -04:00
foreach ( ( array ) $sidebars_widgets [ $index ] as $widget )
2007-04-24 17:36:17 -04:00
if ( array_key_exists ( $widget , $wp_registered_widgets ) )
return true ;
2007-04-23 21:05:17 -04:00
}
}
2007-04-24 17:36:17 -04:00
return false ;
2007-04-23 21:05:17 -04:00
}
2007-04-24 17:36:17 -04:00
/* Internal Functions */
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Retrieve full list of sidebars and their widgets .
2008-09-18 21:41:18 -04:00
*
2008-09-23 00:03:28 -04:00
* Will upgrade sidebar widget list , if needed . Will also save updated list , if
* needed .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
* @ access private
*
2008-09-23 00:03:28 -04:00
* @ param bool $update Optional , default is true . Whether to save upgrade of widget array list .
* @ return array Upgraded list of widgets to version 2 array format .
2008-09-18 21:41:18 -04:00
*/
2007-04-24 17:36:17 -04:00
function wp_get_sidebars_widgets ( $update = true ) {
2007-04-30 16:02:02 -04:00
global $wp_registered_widgets , $wp_registered_sidebars ;
2007-04-24 17:36:17 -04:00
2009-01-05 18:03:17 -05:00
$sidebars_widgets = get_option ( 'sidebars_widgets' , array ());
2007-04-24 17:36:17 -04:00
$_sidebars_widgets = array ();
if ( ! isset ( $sidebars_widgets [ 'array_version' ]) )
$sidebars_widgets [ 'array_version' ] = 1 ;
switch ( $sidebars_widgets [ 'array_version' ] ) {
case 1 :
2008-08-06 16:31:54 -04:00
foreach ( ( array ) $sidebars_widgets as $index => $sidebar )
2007-04-24 17:36:17 -04:00
if ( is_array ( $sidebar ) )
2008-08-06 16:31:54 -04:00
foreach ( ( array ) $sidebar as $i => $name ) {
2007-04-24 17:36:17 -04:00
$id = strtolower ( $name );
if ( isset ( $wp_registered_widgets [ $id ]) ) {
$_sidebars_widgets [ $index ][ $i ] = $id ;
continue ;
2007-04-23 21:05:17 -04:00
}
2007-04-24 17:36:17 -04:00
$id = sanitize_title ( $name );
if ( isset ( $wp_registered_widgets [ $id ]) ) {
$_sidebars_widgets [ $index ][ $i ] = $id ;
continue ;
}
2008-04-28 16:08:23 -04:00
2008-04-17 22:19:45 -04:00
$found = false ;
2008-04-28 16:08:23 -04:00
2008-04-17 22:19:45 -04:00
foreach ( $wp_registered_widgets as $widget_id => $widget ) {
if ( strtolower ( $widget [ 'name' ]) == strtolower ( $name ) ) {
$_sidebars_widgets [ $index ][ $i ] = $widget [ 'id' ];
$found = true ;
break ;
} elseif ( sanitize_title ( $widget [ 'name' ]) == sanitize_title ( $name ) ) {
$_sidebars_widgets [ $index ][ $i ] = $widget [ 'id' ];
$found = true ;
break ;
}
}
2008-04-28 16:08:23 -04:00
2008-04-17 22:19:45 -04:00
if ( $found )
continue ;
2008-04-28 16:08:23 -04:00
2007-04-24 17:36:17 -04:00
unset ( $_sidebars_widgets [ $index ][ $i ]);
2007-04-23 21:05:17 -04:00
}
2007-04-24 17:36:17 -04:00
$_sidebars_widgets [ 'array_version' ] = 2 ;
2007-04-30 16:02:02 -04:00
$sidebars_widgets = $_sidebars_widgets ;
unset ( $_sidebars_widgets );
2007-04-24 17:36:17 -04:00
case 2 :
2007-04-30 16:02:02 -04:00
$sidebars = array_keys ( $wp_registered_sidebars );
if ( ! empty ( $sidebars ) ) {
// Move the known-good ones first
2008-08-06 16:31:54 -04:00
foreach ( ( array ) $sidebars as $id ) {
2007-04-30 16:02:02 -04:00
if ( array_key_exists ( $id , $sidebars_widgets ) ) {
$_sidebars_widgets [ $id ] = $sidebars_widgets [ $id ];
unset ( $sidebars_widgets [ $id ], $sidebars [ $id ]);
}
}
// Assign to each unmatched registered sidebar the first available orphan
unset ( $sidebars_widgets [ 'array_version' ] );
while ( ( $sidebar = array_shift ( $sidebars ) ) && $widgets = array_shift ( $sidebars_widgets ) )
$_sidebars_widgets [ $sidebar ] = $widgets ;
$_sidebars_widgets [ 'array_version' ] = 3 ;
$sidebars_widgets = $_sidebars_widgets ;
unset ( $_sidebars_widgets );
}
if ( $update )
update_option ( 'sidebars_widgets' , $sidebars_widgets );
2007-04-23 21:05:17 -04:00
}
2009-01-05 18:03:17 -05:00
if ( isset ( $sidebars_widgets [ 'array_version' ]) )
unset ( $sidebars_widgets [ 'array_version' ]);
2007-04-23 21:05:17 -04:00
2008-10-06 12:57:31 -04:00
$sidebars_widgets = apply_filters ( 'sidebars_widgets' , $sidebars_widgets );
2007-04-30 16:02:02 -04:00
return $sidebars_widgets ;
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Set the sidebar widget option to update sidebars .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
* @ access private
*
2008-09-23 00:03:28 -04:00
* @ param array $sidebars_widgets Sidebar widgets and their settings .
2008-09-18 21:41:18 -04:00
*/
2007-04-23 21:05:17 -04:00
function wp_set_sidebars_widgets ( $sidebars_widgets ) {
2008-11-25 17:38:36 -05:00
if ( ! isset ( $sidebars_widgets [ 'array_version' ] ) )
$sidebars_widgets [ 'array_version' ] = 3 ;
2007-04-24 17:36:17 -04:00
update_option ( 'sidebars_widgets' , $sidebars_widgets );
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
2008-09-23 00:03:28 -04:00
* Retrieve default registered sidebars list .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
* @ access private
*
2008-09-23 00:03:28 -04:00
* @ return array
2008-09-18 21:41:18 -04:00
*/
2007-04-23 21:05:17 -04:00
function wp_get_widget_defaults () {
global $wp_registered_sidebars ;
2007-04-24 17:36:17 -04:00
2007-04-23 21:05:17 -04:00
$defaults = array ();
2007-04-24 17:36:17 -04:00
2008-08-06 16:31:54 -04:00
foreach ( ( array ) $wp_registered_sidebars as $index => $sidebar )
2007-04-23 21:05:17 -04:00
$defaults [ $index ] = array ();
2007-04-24 17:36:17 -04:00
2007-04-23 21:05:17 -04:00
return $defaults ;
}
2009-03-13 18:27:38 -04:00
/**
* 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 ;
2009-03-14 12:34:08 -04:00
if ( empty ( $settings ) ) {
$single = true ;
} else {
foreach ( array_keys ( $settings ) as $number ) {
if ( ! is_numeric ( $number ) ) {
$single = true ;
break ;
}
2009-03-13 18:27:38 -04:00
}
}
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 ;
}
2007-04-23 21:05:17 -04:00
/* Default Widgets */
2009-03-14 13:24:11 -04:00
/**
* Pages widget class
*
* @ since 2.8 . 0
*/
class WP_Widget_Pages extends WP_Widget {
function WP_Widget_Pages () {
$widget_ops = array ( 'classname' => 'widget_pages' , 'description' => __ ( " Your blog's WordPress Pages " ) );
$this -> WP_Widget ( 'pages' , __ ( 'Pages' ), $widget_ops );
}
function widget ( $args , $instance ) {
extract ( $args );
$title = empty ( $instance [ 'title' ] ) ? __ ( 'Pages' ) : apply_filters ( 'widget_title' , $instance [ 'title' ]);
$sortby = empty ( $instance [ 'sortby' ] ) ? 'menu_order' : $instance [ 'sortby' ];
$exclude = empty ( $instance [ 'exclude' ] ) ? '' : $instance [ 'exclude' ];
if ( $sortby == 'menu_order' )
$sortby = 'menu_order, post_title' ;
$out = wp_list_pages ( array ( 'title_li' => '' , 'echo' => 0 , 'sort_column' => $sortby , 'exclude' => $exclude ) );
if ( ! empty ( $out ) ) {
echo $before_widget ;
echo $before_title . $title . $after_title ;
?>
< ul >
< ? php echo $out ; ?>
</ ul >
< ? php
echo $after_widget ;
}
}
function update ( $new_instance , $old_instance ) {
if ( ! isset ( $new_instance [ 'submit' ]) ) // user clicked cancel?
return false ;
$instance = $old_instance ;
$instance [ 'title' ] = strip_tags ( $new_instance [ 'title' ]);
if ( in_array ( $new_instance [ 'sortby' ], array ( 'post_title' , 'menu_order' , 'ID' ) ) ) {
$instance [ 'sortby' ] = $new_instance [ 'sortby' ];
} else {
$instance [ 'sortby' ] = 'menu_order' ;
}
$instance [ 'exclude' ] = strip_tags ( $new_instance [ 'exclude' ] );
return $instance ;
}
function form ( $instance ) {
//Defaults
$instance = wp_parse_args ( ( array ) $instance , array ( 'sortby' => 'post_title' , 'title' => '' , 'exclude' => '' ) );
$title = attribute_escape ( $instance [ 'title' ] );
$exclude = attribute_escape ( $instance [ 'exclude' ] );
?>
< p >< label for = " <?php echo $this->get_field_id ('title'); ?> " >< ? php _e ( 'Title:' ); ?> <input class="widefat" id="<?php echo $this->get_field_id('title'); ?>" name="<?php echo $this->get_field_name('title'); ?>" type="text" value="<?php echo $title; ?>" /></label></p>
< p >
< label for = " <?php echo $this->get_field_id ('sortby'); ?> " >< ? php _e ( 'Sort by:' ); ?>
< select name = " <?php echo $this->get_field_name ('sortby'); ?> " id = " <?php echo $this->get_field_id ('sortby'); ?> " class = " widefat " >
< option value = " post_title " < ? php selected ( $instance [ 'sortby' ], 'post_title' ); ?> ><?php _e('Page title'); ?></option>
< option value = " menu_order " < ? php selected ( $instance [ 'sortby' ], 'menu_order' ); ?> ><?php _e('Page order'); ?></option>
< option value = " ID " < ? php selected ( $instance [ 'sortby' ], 'ID' ); ?> ><?php _e( 'Page ID' ); ?></option>
</ select >
</ label >
</ p >
< p >
< label for = " <?php echo $this->get_field_id ('exclude'); ?> " >< ? php _e ( 'Exclude:' ); ?> <input type="text" value="<?php echo $exclude; ?>" name="<?php echo $this->get_field_name('exclude'); ?>" id="<?php echo $this->get_field_id('exclude'); ?>" class="widefat" /></label>
< br />
< small >< ? php _e ( 'Page IDs, separated by commas.' ); ?> </small>
</ p >
< input type = " hidden " id = " <?php echo $this->get_field_id ('submit'); ?> " name = " <?php echo $this->get_field_name ('submit'); ?> " value = " 1 " />
< ? php
}
}
2008-09-18 21:41:18 -04:00
/**
2009-03-10 15:42:22 -04:00
* Links widget class
2009-03-04 18:49:21 -05:00
*
* @ since 2.8 . 0
*/
2009-03-13 19:18:57 -04:00
class WP_Widget_Links extends WP_Widget {
2009-03-14 12:34:08 -04:00
function WP_Widget_Links () {
$widget_ops = array ( 'description' => __ ( " Your blogroll " ) );
$this -> WP_Widget ( 'links' , __ ( 'Links' ), $widget_ops );
}
2009-03-10 15:42:22 -04:00
function widget ( $args , $instance ) {
extract ( $args , EXTR_SKIP );
$show_description = isset ( $instance [ 'description' ]) ? $instance [ 'description' ] : false ;
$show_name = isset ( $instance [ 'name' ]) ? $instance [ 'name' ] : false ;
$show_rating = isset ( $instance [ 'rating' ]) ? $instance [ 'rating' ] : false ;
$show_images = isset ( $instance [ 'images' ]) ? $instance [ 'images' ] : true ;
$before_widget = preg_replace ( '/id="[^"]*"/' , 'id="%id"' , $before_widget );
wp_list_bookmarks ( apply_filters ( 'widget_links_args' , array (
'title_before' => $before_title , 'title_after' => $after_title ,
'category_before' => $before_widget , 'category_after' => $after_widget ,
'show_images' => $show_images , 'show_description' => $show_description ,
'show_name' => $show_name , 'show_rating' => $show_rating ,
'class' => 'linkcat widget'
)));
2009-03-04 18:49:21 -05:00
}
2009-03-10 15:42:22 -04:00
function update ( $new_instance , $old_instance ) {
if ( ! isset ( $new_instance [ 'submit' ]) ) // user clicked cancel?
return false ;
2009-03-13 18:27:38 -04:00
$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 ;
2009-03-04 18:49:21 -05:00
}
2009-03-10 15:42:22 -04:00
function form ( $instance ) {
//Defaults
$instance = wp_parse_args ( ( array ) $instance , array ( 'images' => true , 'name' => true , 'description' => false , 'rating' => false ) );
2009-03-04 18:49:21 -05:00
?>
2009-03-10 15:42:22 -04:00
< p >
< label for = " <?php echo $this->get_field_id ('images'); ?> " >
< input class = " checkbox " type = " checkbox " < ? php checked ( $instance [ 'images' ], true ) ?> id="<?php echo $this->get_field_id('images'); ?>" name="<?php echo $this->get_field_name('images'); ?>" /> <?php _e('Show Link Image'); ?></label><br />
< label for = " <?php echo $this->get_field_id ('name'); ?> " >
< input class = " checkbox " type = " checkbox " < ? php checked ( $instance [ 'name' ], true ) ?> id="<?php echo $this->get_field_id('name'); ?>" name="<?php echo $this->get_field_name('name'); ?>" /> <?php _e('Show Link Name'); ?></label><br />
< label for = " <?php echo $this->get_field_id ('description'); ?> " >
< input class = " checkbox " type = " checkbox " < ? php checked ( $instance [ 'description' ], true ) ?> id="<?php echo $this->get_field_id('description'); ?>" name="<?php echo $this->get_field_name('description'); ?>" /> <?php _e('Show Link Description'); ?></label><br />
< label for = " <?php echo $this->get_field_id ('rating'); ?> " >
< input class = " checkbox " type = " checkbox " < ? php checked ( $instance [ 'rating' ], true ) ?> id="<?php echo $this->get_field_id('rating'); ?>" name="<?php echo $this->get_field_name('rating'); ?>" /> <?php _e('Show Link Rating'); ?></label>
< input type = " hidden " id = " <?php echo $this->get_field_id ('submit'); ?> " name = " <?php echo $this->get_field_name ('submit'); ?> " value = " 1 " />
</ p >
2009-03-04 18:49:21 -05:00
< ? php
2009-03-10 15:42:22 -04:00
}
2009-03-04 18:49:21 -05:00
}
2008-09-18 21:41:18 -04:00
/**
2009-03-14 12:34:08 -04:00
* Search widget class
2008-09-18 21:41:18 -04:00
*
2009-03-14 12:34:08 -04:00
* @ since 2.8 . 0
2008-09-18 21:41:18 -04:00
*/
2009-03-14 12:34:08 -04:00
class WP_Widget_Search extends WP_Widget {
2008-08-09 01:36:14 -04:00
2009-03-14 12:34:08 -04:00
function WP_Widget_Search () {
$widget_ops = array ( 'classname' => 'widget_search' , 'description' => __ ( " A search form for your blog " ) );
$this -> WP_Widget ( 'search' , __ ( 'Search' ), $widget_ops );
}
2008-12-09 13:03:31 -05:00
2009-03-14 12:34:08 -04:00
function widget ( $args , $instance ) {
extract ( $args );
echo $before_widget ;
// Use current theme search form if it exists
get_search_form ();
echo $after_widget ;
}
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display archives widget .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
* @ param array $args Widget arguments .
*/
2007-04-24 17:36:17 -04:00
function wp_widget_archives ( $args ) {
extract ( $args );
$options = get_option ( 'widget_archives' );
$c = $options [ 'count' ] ? '1' : '0' ;
2007-04-26 13:17:30 -04:00
$d = $options [ 'dropdown' ] ? '1' : '0' ;
2008-04-29 12:08:19 -04:00
$title = empty ( $options [ 'title' ]) ? __ ( 'Archives' ) : apply_filters ( 'widget_title' , $options [ 'title' ]);
2007-04-26 13:17:30 -04:00
2007-09-03 19:32:58 -04:00
echo $before_widget ;
2007-04-26 13:17:30 -04:00
echo $before_title . $title . $after_title ;
2007-09-03 19:32:58 -04:00
if ( $d ) {
2007-04-23 21:05:17 -04:00
?>
2007-09-13 01:33:54 -04:00
< select name = " archive-dropdown " onchange = 'document.location.href=this.options[this.selectedIndex].value;' > < option value = " " >< ? php echo attribute_escape ( __ ( 'Select Month' )); ?> </option> <?php wp_get_archives("type=monthly&format=option&show_post_count=$c"); ?> </select>
2007-09-03 19:32:58 -04:00
< ? php
} else {
2007-04-26 13:17:30 -04:00
?>
< ul >
< ? php wp_get_archives ( " type=monthly&show_post_count= $c " ); ?>
</ ul >
2007-04-23 21:05:17 -04:00
< ? php
2007-04-26 13:17:30 -04:00
}
2007-09-03 19:32:58 -04:00
echo $after_widget ;
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display and process archives widget options form .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*/
2007-04-23 21:05:17 -04:00
function wp_widget_archives_control () {
2007-04-24 17:36:17 -04:00
$options = $newoptions = get_option ( 'widget_archives' );
2008-09-21 16:57:04 -04:00
if ( isset ( $_POST [ " archives-submit " ]) ) {
2007-04-24 17:36:17 -04:00
$newoptions [ 'count' ] = isset ( $_POST [ 'archives-count' ]);
2007-04-26 13:17:30 -04:00
$newoptions [ 'dropdown' ] = isset ( $_POST [ 'archives-dropdown' ]);
2007-04-24 17:36:17 -04:00
$newoptions [ 'title' ] = strip_tags ( stripslashes ( $_POST [ " archives-title " ]));
2007-04-23 21:05:17 -04:00
}
2007-04-24 17:36:17 -04:00
if ( $options != $newoptions ) {
$options = $newoptions ;
update_option ( 'widget_archives' , $options );
}
$count = $options [ 'count' ] ? 'checked="checked"' : '' ;
2007-04-26 13:17:30 -04:00
$dropdown = $options [ 'dropdown' ] ? 'checked="checked"' : '' ;
2007-05-06 22:16:28 -04:00
$title = attribute_escape ( $options [ 'title' ]);
2007-04-23 21:05:17 -04:00
?>
2008-01-04 18:34:33 -05:00
< p >< label for = " archives-title " >< ? php _e ( 'Title:' ); ?> <input class="widefat" id="archives-title" name="archives-title" type="text" value="<?php echo $title; ?>" /></label></p>
< p >
< label for = " archives-count " >< input class = " checkbox " type = " checkbox " < ? php echo $count ; ?> id="archives-count" name="archives-count" /> <?php _e('Show post counts'); ?></label>
< br />
< label for = " archives-dropdown " >< input class = " checkbox " type = " checkbox " < ? php echo $dropdown ; ?> id="archives-dropdown" name="archives-dropdown" /> <?php _e('Display as a drop down'); ?></label>
</ p >
2007-04-24 17:36:17 -04:00
< input type = " hidden " id = " archives-submit " name = " archives-submit " value = " 1 " />
2007-04-23 21:05:17 -04:00
< ? php
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display meta widget .
2008-09-18 21:41:18 -04:00
*
2008-09-21 23:52:41 -04:00
* Displays log in / out , RSS feed links , etc .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-21 23:52:41 -04:00
* @ param array $args Widget arguments .
2008-09-18 21:41:18 -04:00
*/
2007-04-24 17:36:17 -04:00
function wp_widget_meta ( $args ) {
extract ( $args );
$options = get_option ( 'widget_meta' );
2008-04-29 12:08:19 -04:00
$title = empty ( $options [ 'title' ]) ? __ ( 'Meta' ) : apply_filters ( 'widget_title' , $options [ 'title' ]);
2007-04-23 21:05:17 -04:00
?>
< ? php echo $before_widget ; ?>
< ? php echo $before_title . $title . $after_title ; ?>
< ul >
2007-04-24 17:36:17 -04:00
< ? php wp_register (); ?>
< li >< ? php wp_loginout (); ?> </li>
2007-05-06 22:16:28 -04:00
< li >< a href = " <?php bloginfo('rss2_url'); ?> " title = " <?php echo attribute_escape(__('Syndicate this site using RSS 2.0')); ?> " >< ? php _e ( 'Entries <abbr title="Really Simple Syndication">RSS</abbr>' ); ?> </a></li>
< li >< a href = " <?php bloginfo('comments_rss2_url'); ?> " title = " <?php echo attribute_escape(__('The latest comments to all posts in RSS')); ?> " >< ? php _e ( 'Comments <abbr title="Really Simple Syndication">RSS</abbr>' ); ?> </a></li>
< li >< a href = " http://wordpress.org/ " title = " <?php echo attribute_escape(__('Powered by WordPress, state-of-the-art semantic personal publishing platform.')); ?> " > WordPress . org </ a ></ li >
2007-04-24 17:36:17 -04:00
< ? php wp_meta (); ?>
2007-04-23 21:05:17 -04:00
</ ul >
< ? php echo $after_widget ; ?>
< ? php
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display and process meta widget options form .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*/
2007-04-23 21:05:17 -04:00
function wp_widget_meta_control () {
2007-04-24 17:36:17 -04:00
$options = $newoptions = get_option ( 'widget_meta' );
2008-09-21 16:57:04 -04:00
if ( isset ( $_POST [ " meta-submit " ]) ) {
2007-04-24 17:36:17 -04:00
$newoptions [ 'title' ] = strip_tags ( stripslashes ( $_POST [ " meta-title " ]));
2007-04-23 21:05:17 -04:00
}
2007-04-24 17:36:17 -04:00
if ( $options != $newoptions ) {
$options = $newoptions ;
update_option ( 'widget_meta' , $options );
}
2007-05-06 22:16:28 -04:00
$title = attribute_escape ( $options [ 'title' ]);
2007-04-23 21:05:17 -04:00
?>
2008-01-04 18:34:33 -05:00
< p >< label for = " meta-title " >< ? php _e ( 'Title:' ); ?> <input class="widefat" id="meta-title" name="meta-title" type="text" value="<?php echo $title; ?>" /></label></p>
2007-04-24 17:36:17 -04:00
< input type = " hidden " id = " meta-submit " name = " meta-submit " value = " 1 " />
2007-04-23 21:05:17 -04:00
< ? php
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display calendar widget .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
* @ param array $args Widget arguments .
*/
2007-04-24 17:36:17 -04:00
function wp_widget_calendar ( $args ) {
extract ( $args );
$options = get_option ( 'widget_calendar' );
2008-04-29 12:08:19 -04:00
$title = apply_filters ( 'widget_title' , $options [ 'title' ]);
2007-04-24 17:36:17 -04:00
if ( empty ( $title ) )
$title = ' ' ;
echo $before_widget . $before_title . $title . $after_title ;
echo '<div id="calendar_wrap">' ;
get_calendar ();
echo '</div>' ;
echo $after_widget ;
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:32:45 -04:00
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display and process calendar widget options form .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*/
2007-04-23 21:05:17 -04:00
function wp_widget_calendar_control () {
2007-04-24 17:36:17 -04:00
$options = $newoptions = get_option ( 'widget_calendar' );
2008-09-21 16:57:04 -04:00
if ( isset ( $_POST [ " calendar-submit " ]) ) {
2007-04-24 17:36:17 -04:00
$newoptions [ 'title' ] = strip_tags ( stripslashes ( $_POST [ " calendar-title " ]));
2007-04-23 21:05:17 -04:00
}
2007-04-24 17:36:17 -04:00
if ( $options != $newoptions ) {
$options = $newoptions ;
update_option ( 'widget_calendar' , $options );
}
2007-05-06 22:16:28 -04:00
$title = attribute_escape ( $options [ 'title' ]);
2007-04-23 21:05:17 -04:00
?>
2008-01-04 18:34:33 -05:00
< p >< label for = " calendar-title " >< ? php _e ( 'Title:' ); ?> <input class="widefat" id="calendar-title" name="calendar-title" type="text" value="<?php echo $title; ?>" /></label></p>
2007-04-24 17:36:17 -04:00
< input type = " hidden " id = " calendar-submit " name = " calendar-submit " value = " 1 " />
2007-04-23 21:05:17 -04:00
< ? php
}
2008-09-18 21:41:18 -04:00
/**
* Display the Text widget , depending on the widget number .
*
* Supports multiple text widgets and keeps track of the widget number by using
* the $widget_args parameter . The option 'widget_text' is used to store the
* content for the widgets . The content and title are passed through the
* 'widget_text' and 'widget_title' filters respectively .
*
* @ since 2.2 . 0
*
* @ param array $args Widget arguments .
* @ param int $number Widget number .
*/
2008-01-04 18:34:33 -05:00
function wp_widget_text ( $args , $widget_args = 1 ) {
extract ( $args , EXTR_SKIP );
if ( is_numeric ( $widget_args ) )
$widget_args = array ( 'number' => $widget_args );
$widget_args = wp_parse_args ( $widget_args , array ( 'number' => - 1 ) );
extract ( $widget_args , EXTR_SKIP );
2007-04-24 17:36:17 -04:00
$options = get_option ( 'widget_text' );
2008-01-04 18:34:33 -05:00
if ( ! isset ( $options [ $number ]) )
return ;
2008-04-29 12:08:19 -04:00
$title = apply_filters ( 'widget_title' , $options [ $number ][ 'title' ]);
2007-05-22 18:36:56 -04:00
$text = apply_filters ( 'widget_text' , $options [ $number ][ 'text' ] );
2007-04-23 21:05:17 -04:00
?>
< ? php echo $before_widget ; ?>
2007-05-21 20:25:44 -04:00
< ? php if ( ! empty ( $title ) ) { echo $before_title . $title . $after_title ; } ?>
2007-04-23 21:05:17 -04:00
< div class = " textwidget " >< ? php echo $text ; ?> </div>
< ? php echo $after_widget ; ?>
< ? php
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display and process text widget options form .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
* @ param int $widget_args Widget number .
*/
2008-01-04 18:34:33 -05:00
function wp_widget_text_control ( $widget_args ) {
global $wp_registered_widgets ;
static $updated = false ;
if ( is_numeric ( $widget_args ) )
$widget_args = array ( 'number' => $widget_args );
$widget_args = wp_parse_args ( $widget_args , array ( 'number' => - 1 ) );
extract ( $widget_args , EXTR_SKIP );
$options = get_option ( 'widget_text' );
2007-04-24 17:36:17 -04:00
if ( ! is_array ( $options ) )
2008-01-04 18:34:33 -05:00
$options = array ();
if ( ! $updated && ! empty ( $_POST [ 'sidebar' ]) ) {
$sidebar = ( string ) $_POST [ 'sidebar' ];
$sidebars_widgets = wp_get_sidebars_widgets ();
if ( isset ( $sidebars_widgets [ $sidebar ]) )
$this_sidebar =& $sidebars_widgets [ $sidebar ];
else
$this_sidebar = array ();
2008-08-06 16:31:54 -04:00
foreach ( ( array ) $this_sidebar as $_widget_id ) {
2008-01-04 18:34:33 -05:00
if ( 'wp_widget_text' == $wp_registered_widgets [ $_widget_id ][ 'callback' ] && isset ( $wp_registered_widgets [ $_widget_id ][ 'params' ][ 0 ][ 'number' ]) ) {
$widget_number = $wp_registered_widgets [ $_widget_id ][ 'params' ][ 0 ][ 'number' ];
2008-03-06 18:01:22 -05:00
if ( ! in_array ( " text- $widget_number " , $_POST [ 'widget-id' ] ) ) // the widget has been removed.
unset ( $options [ $widget_number ]);
2008-01-04 18:34:33 -05:00
}
}
foreach ( ( array ) $_POST [ 'widget-text' ] as $widget_number => $widget_text ) {
2008-04-07 17:40:32 -04:00
if ( ! isset ( $widget_text [ 'text' ]) && isset ( $options [ $widget_number ]) ) // user clicked cancel
continue ;
2008-01-04 18:34:33 -05:00
$title = strip_tags ( stripslashes ( $widget_text [ 'title' ]));
if ( current_user_can ( 'unfiltered_html' ) )
$text = stripslashes ( $widget_text [ 'text' ] );
else
$text = stripslashes ( wp_filter_post_kses ( $widget_text [ 'text' ] ));
$options [ $widget_number ] = compact ( 'title' , 'text' );
}
2007-04-23 21:05:17 -04:00
2007-04-24 17:36:17 -04:00
update_option ( 'widget_text' , $options );
2008-01-04 18:34:33 -05:00
$updated = true ;
2007-04-23 21:05:17 -04:00
}
2008-01-04 18:34:33 -05:00
if ( - 1 == $number ) {
$title = '' ;
$text = '' ;
$number = '%i%' ;
} else {
$title = attribute_escape ( $options [ $number ][ 'title' ]);
$text = format_to_edit ( $options [ $number ][ 'text' ]);
}
2007-04-23 21:05:17 -04:00
?>
2008-01-04 18:34:33 -05:00
< p >
< input class = " widefat " id = " text-title-<?php echo $number ; ?> " name = " widget-text[<?php echo $number ; ?>][title] " type = " text " value = " <?php echo $title ; ?> " />
< textarea class = " widefat " rows = " 16 " cols = " 20 " id = " text-text-<?php echo $number ; ?> " name = " widget-text[<?php echo $number ; ?>][text] " >< ? php echo $text ; ?> </textarea>
2008-03-20 00:39:23 -04:00
< input type = " hidden " name = " widget-text[<?php echo $number ; ?>][submit] " value = " 1 " />
2008-01-04 18:34:33 -05:00
</ p >
2007-04-23 21:05:17 -04:00
< ? php
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Register text widget on startup .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*/
2007-04-23 21:05:17 -04:00
function wp_widget_text_register () {
2009-03-15 07:18:09 -04:00
$options = get_option ( 'widget_text' );
if ( ! is_array ( $options ) )
2008-01-05 00:20:56 -05:00
$options = array ();
2009-03-15 07:18:09 -04:00
2008-01-04 18:34:33 -05:00
$widget_ops = array ( 'classname' => 'widget_text' , 'description' => __ ( 'Arbitrary text or HTML' ));
2008-03-14 02:30:41 -04:00
$control_ops = array ( 'width' => 400 , 'height' => 350 , 'id_base' => 'text' );
2008-01-04 18:34:33 -05:00
$name = __ ( 'Text' );
2008-02-27 18:57:00 -05:00
$id = false ;
2008-08-06 16:31:54 -04:00
foreach ( ( array ) array_keys ( $options ) as $o ) {
2008-01-04 18:34:33 -05:00
// Old widgets can have null values for some reason
if ( ! isset ( $options [ $o ][ 'title' ]) || ! isset ( $options [ $o ][ 'text' ]) )
continue ;
$id = " text- $o " ; // Never never never translate an id
wp_register_sidebar_widget ( $id , $name , 'wp_widget_text' , $widget_ops , array ( 'number' => $o ));
wp_register_widget_control ( $id , $name , 'wp_widget_text_control' , $control_ops , array ( 'number' => $o ));
2007-04-24 17:36:17 -04:00
}
2008-02-27 18:57:00 -05:00
// If there are none, we register the widget's existance with a generic template
if ( ! $id ) {
wp_register_sidebar_widget ( 'text-1' , $name , 'wp_widget_text' , $widget_ops , array ( 'number' => - 1 ) );
wp_register_widget_control ( 'text-1' , $name , 'wp_widget_text_control' , $control_ops , array ( 'number' => - 1 ) );
}
2007-04-24 17:36:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display categories widget .
2008-09-18 21:41:18 -04:00
*
2008-09-21 23:52:41 -04:00
* Allows multiple category widgets .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-21 23:52:41 -04:00
* @ param array $args Widget arguments .
* @ param int $number Widget number .
2008-09-18 21:41:18 -04:00
*/
2008-01-04 18:34:33 -05:00
function wp_widget_categories ( $args , $widget_args = 1 ) {
extract ( $args , EXTR_SKIP );
if ( is_numeric ( $widget_args ) )
$widget_args = array ( 'number' => $widget_args );
$widget_args = wp_parse_args ( $widget_args , array ( 'number' => - 1 ) );
extract ( $widget_args , EXTR_SKIP );
2007-04-24 17:36:17 -04:00
$options = get_option ( 'widget_categories' );
2008-01-04 18:34:33 -05:00
if ( ! isset ( $options [ $number ]) )
return ;
2007-09-03 19:19:20 -04:00
2007-06-15 22:03:25 -04:00
$c = $options [ $number ][ 'count' ] ? '1' : '0' ;
$h = $options [ $number ][ 'hierarchical' ] ? '1' : '0' ;
$d = $options [ $number ][ 'dropdown' ] ? '1' : '0' ;
2007-09-03 19:19:20 -04:00
2008-04-29 12:08:19 -04:00
$title = empty ( $options [ $number ][ 'title' ]) ? __ ( 'Categories' ) : apply_filters ( 'widget_title' , $options [ $number ][ 'title' ]);
2007-04-26 13:17:30 -04:00
echo $before_widget ;
2007-09-03 19:32:58 -04:00
echo $before_title . $title . $after_title ;
2007-04-26 13:17:30 -04:00
2008-05-02 12:59:49 -04:00
$cat_args = array ( 'orderby' => 'name' , 'show_count' => $c , 'hierarchical' => $h );
2007-04-26 13:17:30 -04:00
2007-06-15 22:03:25 -04:00
if ( $d ) {
2008-05-02 12:59:49 -04:00
$cat_args [ 'show_option_none' ] = __ ( 'Select Category' );
wp_dropdown_categories ( $cat_args );
2007-04-23 21:05:17 -04:00
?>
2007-04-26 13:17:30 -04:00
2008-01-04 18:34:33 -05:00
< script type = 'text/javascript' >
/* <![CDATA[ */
2008-08-06 16:31:54 -04:00
var dropdown = document . getElementById ( " cat " );
function onCatChange () {
2007-05-03 22:23:49 -04:00
if ( dropdown . options [ dropdown . selectedIndex ] . value > 0 ) {
2007-07-30 12:23:04 -04:00
location . href = " <?php echo get_option('home'); ?>/?cat= " + dropdown . options [ dropdown . selectedIndex ] . value ;
2007-05-03 22:23:49 -04:00
}
2008-08-06 16:31:54 -04:00
}
dropdown . onchange = onCatChange ;
2008-01-04 18:34:33 -05:00
/* ]]> */
</ script >
2007-04-26 13:17:30 -04:00
2007-04-23 21:05:17 -04:00
< ? php
2007-04-26 13:17:30 -04:00
} else {
?>
< ul >
2008-08-09 01:36:14 -04:00
< ? php
2008-05-06 13:28:24 -04:00
$cat_args [ 'title_li' ] = '' ;
2008-08-09 01:36:14 -04:00
wp_list_categories ( $cat_args );
2008-05-06 13:28:24 -04:00
?>
2007-04-26 13:17:30 -04:00
</ ul >
< ? php
}
echo $after_widget ;
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display and process categories widget options form .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-21 23:52:41 -04:00
* @ param int $widget_args Widget number .
2008-09-18 21:41:18 -04:00
*/
2008-01-04 18:34:33 -05:00
function wp_widget_categories_control ( $widget_args ) {
global $wp_registered_widgets ;
static $updated = false ;
2007-09-03 19:19:20 -04:00
2008-01-04 18:34:33 -05:00
if ( is_numeric ( $widget_args ) )
$widget_args = array ( 'number' => $widget_args );
$widget_args = wp_parse_args ( $widget_args , array ( 'number' => - 1 ) );
extract ( $widget_args , EXTR_SKIP );
2007-09-03 19:19:20 -04:00
2008-01-04 18:34:33 -05:00
$options = get_option ( 'widget_categories' );
if ( ! is_array ( $options ) )
$options = array ();
if ( ! $updated && ! empty ( $_POST [ 'sidebar' ]) ) {
$sidebar = ( string ) $_POST [ 'sidebar' ];
2008-02-05 01:47:27 -05:00
2008-01-04 18:34:33 -05:00
$sidebars_widgets = wp_get_sidebars_widgets ();
if ( isset ( $sidebars_widgets [ $sidebar ]) )
$this_sidebar =& $sidebars_widgets [ $sidebar ];
else
$this_sidebar = array ();
2008-02-05 01:47:27 -05:00
2008-08-06 16:31:54 -04:00
foreach ( ( array ) $this_sidebar as $_widget_id ) {
2008-01-04 18:34:33 -05:00
if ( 'wp_widget_categories' == $wp_registered_widgets [ $_widget_id ][ 'callback' ] && isset ( $wp_registered_widgets [ $_widget_id ][ 'params' ][ 0 ][ 'number' ]) ) {
$widget_number = $wp_registered_widgets [ $_widget_id ][ 'params' ][ 0 ][ 'number' ];
2008-03-06 18:01:22 -05:00
if ( ! in_array ( " categories- $widget_number " , $_POST [ 'widget-id' ] ) ) // the widget has been removed.
unset ( $options [ $widget_number ]);
2008-02-05 01:47:27 -05:00
}
2008-01-04 18:34:33 -05:00
}
foreach ( ( array ) $_POST [ 'widget-categories' ] as $widget_number => $widget_cat ) {
2008-04-07 17:40:32 -04:00
if ( ! isset ( $widget_cat [ 'title' ]) && isset ( $options [ $widget_number ]) ) // user clicked cancel
continue ;
2008-01-04 18:34:33 -05:00
$title = trim ( strip_tags ( stripslashes ( $widget_cat [ 'title' ])));
$count = isset ( $widget_cat [ 'count' ]);
$hierarchical = isset ( $widget_cat [ 'hierarchical' ]);
$dropdown = isset ( $widget_cat [ 'dropdown' ]);
$options [ $widget_number ] = compact ( 'title' , 'count' , 'hierarchical' , 'dropdown' );
}
2007-09-03 19:19:20 -04:00
2007-04-24 17:36:17 -04:00
update_option ( 'widget_categories' , $options );
2008-01-04 18:34:33 -05:00
$updated = true ;
2007-04-24 17:36:17 -04:00
}
2007-09-03 19:19:20 -04:00
2008-01-04 18:34:33 -05:00
if ( - 1 == $number ) {
$title = '' ;
$count = false ;
$hierarchical = false ;
$dropdown = false ;
$number = '%i%' ;
} else {
$title = attribute_escape ( $options [ $number ][ 'title' ] );
$count = ( bool ) $options [ $number ][ 'count' ];
$hierarchical = ( bool ) $options [ $number ][ 'hierarchical' ];
$dropdown = ( bool ) $options [ $number ][ 'dropdown' ];
}
2007-06-08 10:49:30 -04:00
?>
2008-01-04 18:34:33 -05:00
< p >
< label for = " categories-title-<?php echo $number ; ?> " >
2008-02-05 01:47:27 -05:00
< ? php _e ( 'Title:' ); ?>
2008-01-04 18:34:33 -05:00
< input class = " widefat " id = " categories-title-<?php echo $number ; ?> " name = " widget-categories[<?php echo $number ; ?>][title] " type = " text " value = " <?php echo $title ; ?> " />
</ label >
</ p >
2007-09-03 19:19:20 -04:00
2008-01-04 18:34:33 -05:00
< p >
< label for = " categories-dropdown-<?php echo $number ; ?> " >
2009-02-27 17:15:14 -05:00
< input type = " checkbox " class = " checkbox " id = " categories-dropdown-<?php echo $number ; ?> " name = " widget-categories[<?php echo $number ; ?>][dropdown] " < ? php checked ( $dropdown ); ?> />
2008-01-04 18:34:33 -05:00
< ? php _e ( 'Show as dropdown' ); ?>
</ label >
< br />
< label for = " categories-count-<?php echo $number ; ?> " >
2009-02-27 17:15:14 -05:00
< input type = " checkbox " class = " checkbox " id = " categories-count-<?php echo $number ; ?> " name = " widget-categories[<?php echo $number ; ?>][count] " < ? php checked ( $count ); ?> />
2008-01-04 18:34:33 -05:00
< ? php _e ( 'Show post counts' ); ?>
</ label >
< br />
< label for = " categories-hierarchical-<?php echo $number ; ?> " >
2009-02-27 17:15:14 -05:00
< input type = " checkbox " class = " checkbox " id = " categories-hierarchical-<?php echo $number ; ?> " name = " widget-categories[<?php echo $number ; ?>][hierarchical] " < ? php checked ( $hierarchical ); ?> />
2008-01-04 18:34:33 -05:00
< ? php _e ( 'Show hierarchy' ); ?>
</ label >
</ p >
2007-09-03 19:19:20 -04:00
2008-03-20 00:39:23 -04:00
< input type = " hidden " name = " widget-categories[<?php echo $number ; ?>][submit] " value = " 1 " />
2007-06-15 22:03:25 -04:00
< ? php
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Register categories widget on startup .
2008-09-18 21:41:18 -04:00
*
* @ since 2.3 . 0
*/
2008-01-04 18:34:33 -05:00
function wp_widget_categories_register () {
2008-01-05 00:20:56 -05:00
if ( ! $options = get_option ( 'widget_categories' ) )
$options = array ();
2008-01-04 18:34:33 -05:00
if ( isset ( $options [ 'title' ]) )
$options = wp_widget_categories_upgrade ();
2007-09-03 19:19:20 -04:00
2008-01-04 18:34:33 -05:00
$widget_ops = array ( 'classname' => 'widget_categories' , 'description' => __ ( " A list or dropdown of categories " ) );
2007-09-03 19:19:20 -04:00
2008-01-04 18:34:33 -05:00
$name = __ ( 'Categories' );
2007-09-03 19:19:20 -04:00
2008-02-27 18:57:00 -05:00
$id = false ;
2008-08-06 16:31:54 -04:00
foreach ( ( array ) array_keys ( $options ) as $o ) {
2008-01-04 18:34:33 -05:00
// Old widgets can have null values for some reason
if ( ! isset ( $options [ $o ][ 'title' ]) )
continue ;
$id = " categories- $o " ;
wp_register_sidebar_widget ( $id , $name , 'wp_widget_categories' , $widget_ops , array ( 'number' => $o ) );
wp_register_widget_control ( $id , $name , 'wp_widget_categories_control' , array ( 'id_base' => 'categories' ), array ( 'number' => $o ) );
2007-06-15 22:03:25 -04:00
}
2008-02-27 18:57:00 -05:00
// If there are none, we register the widget's existance with a generic template
if ( ! $id ) {
wp_register_sidebar_widget ( 'categories-1' , $name , 'wp_widget_categories' , $widget_ops , array ( 'number' => - 1 ) );
wp_register_widget_control ( 'categories-1' , $name , 'wp_widget_categories_control' , array ( 'id_base' => 'categories' ), array ( 'number' => - 1 ) );
}
2007-06-08 10:49:30 -04:00
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Upgrade previous category widget to current version .
2008-09-18 21:41:18 -04:00
*
* @ since 2.3 . 0
*
2008-09-21 23:52:41 -04:00
* @ return array
2008-09-18 21:41:18 -04:00
*/
2007-06-15 22:03:25 -04:00
function wp_widget_categories_upgrade () {
$options = get_option ( 'widget_categories' );
2008-01-04 18:34:33 -05:00
if ( ! isset ( $options [ 'title' ] ) )
return $options ;
$newoptions = array ( 1 => $options );
2007-06-15 22:03:25 -04:00
update_option ( 'widget_categories' , $newoptions );
$sidebars_widgets = get_option ( 'sidebars_widgets' );
if ( is_array ( $sidebars_widgets ) ) {
foreach ( $sidebars_widgets as $sidebar => $widgets ) {
if ( is_array ( $widgets ) ) {
foreach ( $widgets as $widget )
$new_widgets [ $sidebar ][] = ( $widget == 'categories' ) ? 'categories-1' : $widget ;
} else {
$new_widgets [ $sidebar ] = $widgets ;
}
}
if ( $new_widgets != $sidebars_widgets )
update_option ( 'sidebars_widgets' , $new_widgets );
}
return $newoptions ;
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display recent entries widget .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-21 23:52:41 -04:00
* @ param array $args Widget arguments .
* @ return int Displayed cache .
2008-09-18 21:41:18 -04:00
*/
2007-04-24 17:36:17 -04:00
function wp_widget_recent_entries ( $args ) {
2008-04-17 16:42:47 -04:00
if ( '%BEG_OF_TITLE%' != $args [ 'before_title' ] ) {
if ( $output = wp_cache_get ( 'widget_recent_entries' , 'widget' ) )
return print ( $output );
ob_start ();
}
2007-04-24 17:36:17 -04:00
extract ( $args );
$options = get_option ( 'widget_recent_entries' );
2008-04-29 12:08:19 -04:00
$title = empty ( $options [ 'title' ]) ? __ ( 'Recent Posts' ) : apply_filters ( 'widget_title' , $options [ 'title' ]);
2007-04-24 17:36:17 -04:00
if ( ! $number = ( int ) $options [ 'number' ] )
$number = 10 ;
else if ( $number < 1 )
$number = 1 ;
else if ( $number > 15 )
$number = 15 ;
2008-09-14 01:50:10 -04:00
$r = new WP_Query ( array ( 'showposts' => $number , 'what_to_show' => 'posts' , 'nopaging' => 0 , 'post_status' => 'publish' , 'caller_get_posts' => 1 ));
2007-04-24 17:36:17 -04:00
if ( $r -> have_posts ()) :
2007-04-23 21:05:17 -04:00
?>
< ? php echo $before_widget ; ?>
< ? php echo $before_title . $title . $after_title ; ?>
< ul >
2007-04-24 17:36:17 -04:00
< ? php while ( $r -> have_posts ()) : $r -> the_post (); ?>
< li >< a href = " <?php the_permalink() ?> " >< ? php if ( get_the_title () ) the_title (); else the_ID (); ?> </a></li>
< ? php endwhile ; ?>
2007-04-23 21:05:17 -04:00
</ ul >
< ? php echo $after_widget ; ?>
< ? php
2008-01-23 13:20:59 -05:00
wp_reset_query (); // Restore global post data stomped by the_post().
2007-04-24 17:36:17 -04:00
endif ;
2008-04-17 16:42:47 -04:00
if ( '%BEG_OF_TITLE%' != $args [ 'before_title' ] )
wp_cache_add ( 'widget_recent_entries' , ob_get_flush (), 'widget' );
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:32:45 -04:00
/**
* Remove recent entries widget items cache .
*
2008-09-18 21:41:18 -04:00
* @ since 2.2 . 0
2008-09-18 21:32:45 -04:00
*/
2007-04-24 17:36:17 -04:00
function wp_flush_widget_recent_entries () {
2008-01-29 18:28:58 -05:00
wp_cache_delete ( 'widget_recent_entries' , 'widget' );
2007-04-24 17:36:17 -04:00
}
add_action ( 'save_post' , 'wp_flush_widget_recent_entries' );
2007-08-28 16:12:43 -04:00
add_action ( 'deleted_post' , 'wp_flush_widget_recent_entries' );
2008-01-29 18:28:58 -05:00
add_action ( 'switch_theme' , 'wp_flush_widget_recent_entries' );
2007-04-24 17:36:17 -04:00
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display and process recent entries widget options form .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*/
2007-04-24 17:36:17 -04:00
function wp_widget_recent_entries_control () {
$options = $newoptions = get_option ( 'widget_recent_entries' );
2008-09-21 16:57:04 -04:00
if ( isset ( $_POST [ " recent-entries-submit " ]) ) {
2007-04-24 17:36:17 -04:00
$newoptions [ 'title' ] = strip_tags ( stripslashes ( $_POST [ " recent-entries-title " ]));
$newoptions [ 'number' ] = ( int ) $_POST [ " recent-entries-number " ];
}
if ( $options != $newoptions ) {
$options = $newoptions ;
update_option ( 'widget_recent_entries' , $options );
wp_flush_widget_recent_entries ();
}
2007-05-06 22:16:28 -04:00
$title = attribute_escape ( $options [ 'title' ]);
2007-04-24 17:36:17 -04:00
if ( ! $number = ( int ) $options [ 'number' ] )
$number = 5 ;
2007-04-23 21:05:17 -04:00
?>
2008-01-04 18:34:33 -05:00
< p >< label for = " recent-entries-title " >< ? php _e ( 'Title:' ); ?> <input class="widefat" id="recent-entries-title" name="recent-entries-title" type="text" value="<?php echo $title; ?>" /></label></p>
< p >
< label for = " recent-entries-number " >< ? php _e ( 'Number of posts to show:' ); ?> <input style="width: 25px; text-align: center;" id="recent-entries-number" name="recent-entries-number" type="text" value="<?php echo $number; ?>" /></label>
< br />
< small >< ? php _e ( '(at most 15)' ); ?> </small>
</ p >
2007-04-24 17:36:17 -04:00
< input type = " hidden " id = " recent-entries-submit " name = " recent-entries-submit " value = " 1 " />
< ? php
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display recent comments widget .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-21 23:52:41 -04:00
* @ param array $args Widget arguments .
2008-09-18 21:41:18 -04:00
*/
2007-04-24 17:36:17 -04:00
function wp_widget_recent_comments ( $args ) {
global $wpdb , $comments , $comment ;
extract ( $args , EXTR_SKIP );
$options = get_option ( 'widget_recent_comments' );
2008-04-29 12:08:19 -04:00
$title = empty ( $options [ 'title' ]) ? __ ( 'Recent Comments' ) : apply_filters ( 'widget_title' , $options [ 'title' ]);
2007-04-24 17:36:17 -04:00
if ( ! $number = ( int ) $options [ 'number' ] )
$number = 5 ;
else if ( $number < 1 )
$number = 1 ;
else if ( $number > 15 )
$number = 15 ;
if ( ! $comments = wp_cache_get ( 'recent_comments' , 'widget' ) ) {
2008-11-05 02:09:20 -05:00
$comments = $wpdb -> get_results ( " SELECT * FROM $wpdb->comments WHERE comment_approved = '1' ORDER BY comment_date_gmt DESC LIMIT $number " );
2007-04-24 17:36:17 -04:00
wp_cache_add ( 'recent_comments' , $comments , 'widget' );
}
?>
2007-04-23 21:05:17 -04:00
< ? php echo $before_widget ; ?>
< ? php echo $before_title . $title . $after_title ; ?>
2007-04-24 17:36:17 -04:00
< ul id = " recentcomments " >< ? php
2008-08-06 16:31:54 -04:00
if ( $comments ) : foreach ( ( array ) $comments as $comment ) :
2009-03-12 23:53:39 -04:00
echo '<li class="recentcomments">' . /* translators: comments widget: 1: comment author, 2: post link */ sprintf ( _x ( '%1$s on %2$s' , 'widgets' ), get_comment_author_link (), '<a href="' . clean_url ( get_comment_link ( $comment -> comment_ID ) ) . '">' . get_the_title ( $comment -> comment_post_ID ) . '</a>' ) . '</li>' ;
2007-04-24 17:36:17 -04:00
endforeach ; endif ; ?> </ul>
2007-04-23 21:05:17 -04:00
< ? php echo $after_widget ; ?>
< ? php
}
2008-09-18 21:32:45 -04:00
/**
* Remove the cache for recent comments widget .
*
2008-09-18 21:41:18 -04:00
* @ since 2.2 . 0
2008-09-18 21:32:45 -04:00
*/
2007-04-24 17:36:17 -04:00
function wp_delete_recent_comments_cache () {
wp_cache_delete ( 'recent_comments' , 'widget' );
}
add_action ( 'comment_post' , 'wp_delete_recent_comments_cache' );
add_action ( 'wp_set_comment_status' , 'wp_delete_recent_comments_cache' );
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display and process recent comments widget options form .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*/
2007-04-23 21:05:17 -04:00
function wp_widget_recent_comments_control () {
2007-04-24 17:36:17 -04:00
$options = $newoptions = get_option ( 'widget_recent_comments' );
2008-09-21 16:57:04 -04:00
if ( isset ( $_POST [ " recent-comments-submit " ]) ) {
2007-04-24 17:36:17 -04:00
$newoptions [ 'title' ] = strip_tags ( stripslashes ( $_POST [ " recent-comments-title " ]));
$newoptions [ 'number' ] = ( int ) $_POST [ " recent-comments-number " ];
}
if ( $options != $newoptions ) {
$options = $newoptions ;
update_option ( 'widget_recent_comments' , $options );
2007-04-30 12:45:23 -04:00
wp_delete_recent_comments_cache ();
2007-04-24 17:36:17 -04:00
}
2007-05-06 22:16:28 -04:00
$title = attribute_escape ( $options [ 'title' ]);
2007-04-24 17:36:17 -04:00
if ( ! $number = ( int ) $options [ 'number' ] )
$number = 5 ;
2007-04-23 21:05:17 -04:00
?>
2008-01-04 18:34:33 -05:00
< p >< label for = " recent-comments-title " >< ? php _e ( 'Title:' ); ?> <input class="widefat" id="recent-comments-title" name="recent-comments-title" type="text" value="<?php echo $title; ?>" /></label></p>
< p >
< label for = " recent-comments-number " >< ? php _e ( 'Number of comments to show:' ); ?> <input style="width: 25px; text-align: center;" id="recent-comments-number" name="recent-comments-number" type="text" value="<?php echo $number; ?>" /></label>
< br />
< small >< ? php _e ( '(at most 15)' ); ?> </small>
</ p >
2007-04-24 17:36:17 -04:00
< input type = " hidden " id = " recent-comments-submit " name = " recent-comments-submit " value = " 1 " />
2007-04-23 21:05:17 -04:00
< ? php
}
2008-09-18 21:32:45 -04:00
/**
* Display the style for recent comments widget .
*
2008-09-18 21:41:18 -04:00
* @ since 2.2 . 0
2008-09-18 21:32:45 -04:00
*/
2007-04-24 17:36:17 -04:00
function wp_widget_recent_comments_style () {
2007-04-23 21:05:17 -04:00
?>
2007-04-24 17:36:17 -04:00
< style type = " text/css " >. recentcomments a { display : inline ! important ; padding : 0 ! important ; margin : 0 ! important ;} </ style >
2007-04-23 21:05:17 -04:00
< ? php
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Register recent comments with control and hook for 'wp_head' action .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*/
2007-04-23 21:05:17 -04:00
function wp_widget_recent_comments_register () {
2008-01-04 18:34:33 -05:00
$widget_ops = array ( 'classname' => 'widget_recent_comments' , 'description' => __ ( 'The most recent comments' ) );
wp_register_sidebar_widget ( 'recent-comments' , __ ( 'Recent Comments' ), 'wp_widget_recent_comments' , $widget_ops );
wp_register_widget_control ( 'recent-comments' , __ ( 'Recent Comments' ), 'wp_widget_recent_comments_control' );
2007-06-13 22:25:30 -04:00
2007-04-24 17:36:17 -04:00
if ( is_active_widget ( 'wp_widget_recent_comments' ) )
add_action ( 'wp_head' , 'wp_widget_recent_comments_style' );
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display RSS widget .
2008-09-18 21:41:18 -04:00
*
2008-09-21 23:52:41 -04:00
* Allows for multiple widgets to be displayed .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-21 23:52:41 -04:00
* @ param array $args Widget arguments .
* @ param int $number Widget number .
2008-09-18 21:41:18 -04:00
*/
2008-01-04 18:34:33 -05:00
function wp_widget_rss ( $args , $widget_args = 1 ) {
extract ( $args , EXTR_SKIP );
if ( is_numeric ( $widget_args ) )
2008-07-15 12:21:26 -04:00
$widget_args = array ( 'number' => $widget_args );
2008-01-04 18:34:33 -05:00
$widget_args = wp_parse_args ( $widget_args , array ( 'number' => - 1 ) );
extract ( $widget_args , EXTR_SKIP );
2007-04-24 17:36:17 -04:00
$options = get_option ( 'widget_rss' );
2008-01-04 18:34:33 -05:00
if ( ! isset ( $options [ $number ]) )
2007-04-23 21:05:17 -04:00
return ;
2008-01-04 18:34:33 -05:00
if ( isset ( $options [ $number ][ 'error' ]) && $options [ $number ][ 'error' ] )
return ;
2007-04-24 17:36:17 -04:00
$url = $options [ $number ][ 'url' ];
2009-03-07 14:44:28 -05:00
while ( stristr ( $url , 'http' ) != $url )
2007-04-24 17:36:17 -04:00
$url = substr ( $url , 1 );
if ( empty ( $url ) )
return ;
2008-01-04 18:34:33 -05:00
2009-02-27 14:32:50 -05:00
$rss = fetch_feed ( $url );
2007-04-24 17:36:17 -04:00
$title = $options [ $number ][ 'title' ];
2009-03-07 14:44:28 -05:00
$desc = '' ;
$link = '' ;
if ( ! is_wp_error ( $rss ) ) {
$desc = attribute_escape ( strip_tags ( html_entity_decode ( $rss -> get_description (), ENT_QUOTES , get_option ( 'blog_charset' ))));
if ( empty ( $title ) )
$title = htmlentities ( strip_tags ( $rss -> get_title ()));
$link = clean_url ( strip_tags ( $rss -> get_permalink ()));
while ( stristr ( $link , 'http' ) != $link )
$link = substr ( $link , 1 );
}
2007-04-24 17:36:17 -04:00
if ( empty ( $title ) )
2007-04-23 21:05:17 -04:00
$title = $desc ;
2007-04-24 17:36:17 -04:00
if ( empty ( $title ) )
$title = __ ( 'Unknown Feed' );
2008-04-29 12:08:19 -04:00
$title = apply_filters ( 'widget_title' , $title );
2007-05-06 22:16:28 -04:00
$url = clean_url ( strip_tags ( $url ));
2009-03-07 14:44:28 -05:00
$icon = includes_url ( 'images/rss.png' );
2007-05-06 22:16:28 -04:00
$title = " <a class='rsswidget' href=' $url ' title=' " . attribute_escape ( __ ( 'Syndicate this content' )) . " '><img style='background:orange;color:white;border:none;' width='14' height='14' src=' $icon ' alt='RSS' /></a> <a class='rsswidget' href=' $link ' title=' $desc '> $title </a> " ;
2008-02-02 02:57:51 -05:00
echo $before_widget ;
echo $before_title . $title . $after_title ;
wp_widget_rss_output ( $rss , $options [ $number ] );
echo $after_widget ;
}
2008-09-21 23:52:41 -04:00
/**
* Display the RSS entries in a list .
*
* @ since 2.5 . 0
*
* @ param string | array | object $rss RSS url .
* @ param array $args Widget arguments .
*/
2008-02-15 15:42:53 -05:00
function wp_widget_rss_output ( $rss , $args = array () ) {
2008-02-02 02:57:51 -05:00
if ( is_string ( $rss ) ) {
2009-03-07 14:44:28 -05:00
$rss = fetch_feed ( $rss );
2008-02-02 02:57:51 -05:00
} elseif ( is_array ( $rss ) && isset ( $rss [ 'url' ]) ) {
$args = $rss ;
2009-03-07 14:44:28 -05:00
$rss = fetch_feed ( $rss [ 'url' ]);
2008-02-02 02:57:51 -05:00
} elseif ( ! is_object ( $rss ) ) {
return ;
}
2009-03-04 14:24:48 -05:00
if ( is_wp_error ( $rss ) ) {
if ( is_admin () || current_user_can ( 'manage_options' ) ) {
echo '<p>' ;
printf ( __ ( '<strong>RSS Error</strong>: %s' ), $rss -> get_error_message ());
echo '</p>' ;
}
return ;
}
2008-11-03 22:22:24 -05:00
$default_args = array ( 'show_author' => 0 , 'show_date' => 0 , 'show_summary' => 0 );
$args = wp_parse_args ( $args , $default_args );
2008-02-02 02:57:51 -05:00
extract ( $args , EXTR_SKIP );
$items = ( int ) $items ;
if ( $items < 1 || 20 < $items )
$items = 10 ;
$show_summary = ( int ) $show_summary ;
$show_author = ( int ) $show_author ;
$show_date = ( int ) $show_date ;
2009-02-27 14:32:50 -05:00
if ( ! $rss -> get_item_quantity () ) {
echo '<ul><li>' . __ ( 'An error has occurred; the feed is probably down. Try again later.' ) . '</li></ul>' ;
return ;
}
2008-02-02 02:57:51 -05:00
2009-02-27 14:32:50 -05:00
echo '<ul>' ;
foreach ( $rss -> get_items ( 0 , $items ) as $item ) {
$link = $item -> get_link ();
2009-03-07 14:44:28 -05:00
while ( stristr ( $link , 'http' ) != $link )
2009-02-27 14:32:50 -05:00
$link = substr ( $link , 1 );
$link = clean_url ( strip_tags ( $link ));
$title = attribute_escape ( strip_tags ( $item -> get_title ()));
if ( empty ( $title ) )
$title = __ ( 'Untitled' );
2009-03-03 13:37:25 -05:00
$desc = str_replace ( array ( " \n " , " \r " ), ' ' , attribute_escape ( strip_tags ( html_entity_decode ( $item -> get_description (), ENT_QUOTES , get_option ( 'blog_charset' )))));
2009-02-27 14:32:50 -05:00
$desc = wp_html_excerpt ( $desc , 360 ) . ' […]' ;
$desc = wp_specialchars ( $desc );
if ( $show_summary ) {
$summary = " <div class='rssSummary'> $desc </div> " ;
} else {
$summary = '' ;
}
2008-02-02 02:57:51 -05:00
2009-02-27 14:32:50 -05:00
$date = '' ;
if ( $show_date ) {
$date = $item -> get_date ();
2008-02-02 02:57:51 -05:00
2009-02-27 14:32:50 -05:00
if ( $date ) {
if ( $date_stamp = strtotime ( $date ) )
$date = ' <span class="rss-date">' . date_i18n ( get_option ( 'date_format' ), $date_stamp ) . '</span>' ;
else
$date = '' ;
2008-08-27 14:00:51 -04:00
}
2009-02-27 14:32:50 -05:00
}
$author = '' ;
if ( $show_author ) {
$author = $item -> get_author ();
$author = $author -> get_name ();
$author = ' <cite>' . wp_specialchars ( strip_tags ( $author ) ) . '</cite>' ;
}
if ( $link == '' ) {
echo " <li> $title { $date } { $summary } { $author } </li> " ;
} else {
echo " <li><a class='rsswidget' href=' $link ' title=' $desc '> $title </a> { $date } { $summary } { $author } </li> " ;
}
2007-04-24 17:36:17 -04:00
}
2009-02-27 14:32:50 -05:00
echo '</ul>' ;
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:41:18 -04:00
/**
2008-09-21 23:52:41 -04:00
* Display and process RSS widget control form .
2008-09-18 21:41:18 -04:00
*
* @ since 2.2 . 0
*
2008-09-21 23:52:41 -04:00
* @ param int $widget_args Widget number .
2008-09-18 21:41:18 -04:00
*/
2008-01-04 18:34:33 -05:00
function wp_widget_rss_control ( $widget_args ) {
global $wp_registered_widgets ;
static $updated = false ;
if ( is_numeric ( $widget_args ) )
$widget_args = array ( 'number' => $widget_args );
$widget_args = wp_parse_args ( $widget_args , array ( 'number' => - 1 ) );
extract ( $widget_args , EXTR_SKIP );
$options = get_option ( 'widget_rss' );
if ( ! is_array ( $options ) )
$options = array ();
$urls = array ();
2008-08-06 16:31:54 -04:00
foreach ( ( array ) $options as $option )
2008-01-04 18:34:33 -05:00
if ( isset ( $option [ 'url' ]) )
$urls [ $option [ 'url' ]] = true ;
2008-02-02 02:57:51 -05:00
if ( ! $updated && 'POST' == $_SERVER [ 'REQUEST_METHOD' ] && ! empty ( $_POST [ 'sidebar' ]) ) {
2008-01-04 18:34:33 -05:00
$sidebar = ( string ) $_POST [ 'sidebar' ];
$sidebars_widgets = wp_get_sidebars_widgets ();
if ( isset ( $sidebars_widgets [ $sidebar ]) )
$this_sidebar =& $sidebars_widgets [ $sidebar ];
else
$this_sidebar = array ();
2008-02-05 01:47:27 -05:00
2008-08-06 16:31:54 -04:00
foreach ( ( array ) $this_sidebar as $_widget_id ) {
2008-01-04 18:34:33 -05:00
if ( 'wp_widget_rss' == $wp_registered_widgets [ $_widget_id ][ 'callback' ] && isset ( $wp_registered_widgets [ $_widget_id ][ 'params' ][ 0 ][ 'number' ]) ) {
$widget_number = $wp_registered_widgets [ $_widget_id ][ 'params' ][ 0 ][ 'number' ];
2008-03-06 18:01:22 -05:00
if ( ! in_array ( " rss- $widget_number " , $_POST [ 'widget-id' ] ) ) // the widget has been removed.
unset ( $options [ $widget_number ]);
2007-04-24 17:36:17 -04:00
}
2007-04-23 21:05:17 -04:00
}
2008-01-04 18:34:33 -05:00
foreach ( ( array ) $_POST [ 'widget-rss' ] as $widget_number => $widget_rss ) {
2008-04-07 17:40:32 -04:00
if ( ! isset ( $widget_rss [ 'url' ]) && isset ( $options [ $widget_number ]) ) // user clicked cancel
continue ;
2008-02-02 02:57:51 -05:00
$widget_rss = stripslashes_deep ( $widget_rss );
$url = sanitize_url ( strip_tags ( $widget_rss [ 'url' ]));
$options [ $widget_number ] = wp_widget_rss_process ( $widget_rss , ! isset ( $urls [ $url ]) );
2008-01-04 18:34:33 -05:00
}
2007-04-24 17:36:17 -04:00
update_option ( 'widget_rss' , $options );
2008-01-04 18:34:33 -05:00
$updated = true ;
2007-04-23 21:05:17 -04:00
}
2008-01-04 18:34:33 -05:00
if ( - 1 == $number ) {
$title = '' ;
$url = '' ;
$items = 10 ;
$error = false ;
$number = '%i%' ;
2008-02-02 02:57:51 -05:00
$show_summary = 0 ;
$show_author = 0 ;
$show_date = 0 ;
2008-01-04 18:34:33 -05:00
} else {
2008-03-17 19:25:05 -04:00
extract ( ( array ) $options [ $number ] );
2007-04-23 21:05:17 -04:00
}
2008-02-02 02:57:51 -05:00
wp_widget_rss_form ( compact ( 'number' , 'title' , 'url' , 'items' , 'error' , 'show_summary' , 'show_author' , 'show_date' ) );
}
2008-09-18 21:32:45 -04:00
/**
* Display RSS widget options form .
*
* The options for what fields are displayed for the RSS form are all booleans
* and are as follows : 'url' , 'title' , 'items' , 'show_summary' , 'show_author' ,
* 'show_date' .
*
2008-09-21 23:52:41 -04:00
* @ since 2.5 . 0
2008-09-18 21:32:45 -04:00
*
* @ param array | string $args Values for input fields .
* @ param array $inputs Override default display options .
*/
2008-02-02 02:57:51 -05:00
function wp_widget_rss_form ( $args , $inputs = null ) {
2008-11-10 13:54:18 -05:00
2008-02-02 02:57:51 -05:00
$default_inputs = array ( 'url' => true , 'title' => true , 'items' => true , 'show_summary' => true , 'show_author' => true , 'show_date' => true );
$inputs = wp_parse_args ( $inputs , $default_inputs );
extract ( $args );
2008-11-10 13:54:18 -05:00
extract ( $inputs , EXTR_SKIP );
2008-02-02 02:57:51 -05:00
$number = attribute_escape ( $number );
$title = attribute_escape ( $title );
$url = attribute_escape ( $url );
$items = ( int ) $items ;
if ( $items < 1 || 20 < $items )
$items = 10 ;
$show_summary = ( int ) $show_summary ;
$show_author = ( int ) $show_author ;
$show_date = ( int ) $show_date ;
2009-03-08 00:01:26 -05:00
if ( ! empty ( $error ) ) {
$message = sprintf ( __ ( 'Error in RSS Widget: %s' ), $error );
echo " <div class='error'><p> $message </p></div> " ;
echo " <p class='hide-if-no-js'><strong> $message </strong></p> " ;
}
2008-02-02 02:57:51 -05:00
if ( $inputs [ 'url' ] ) :
2007-04-23 21:05:17 -04:00
?>
2008-02-02 02:57:51 -05:00
< p >
< label for = " rss-url-<?php echo $number ; ?> " >< ? php _e ( 'Enter the RSS feed URL here:' ); ?>
< input class = " widefat " id = " rss-url-<?php echo $number ; ?> " name = " widget-rss[<?php echo $number ; ?>][url] " type = " text " value = " <?php echo $url ; ?> " />
</ label >
</ p >
< ? php endif ; if ( $inputs [ 'title' ] ) : ?>
< p >
< label for = " rss-title-<?php echo $number ; ?> " >< ? php _e ( 'Give the feed a title (optional):' ); ?>
< input class = " widefat " id = " rss-title-<?php echo $number ; ?> " name = " widget-rss[<?php echo $number ; ?>][title] " type = " text " value = " <?php echo $title ; ?> " />
</ label >
</ p >
< ? php endif ; if ( $inputs [ 'items' ] ) : ?>
< p >
< label for = " rss-items-<?php echo $number ; ?> " >< ? php _e ( 'How many items would you like to display?' ); ?>
< select id = " rss-items-<?php echo $number ; ?> " name = " widget-rss[<?php echo $number ; ?>][items] " >
< ? php
for ( $i = 1 ; $i <= 20 ; ++ $i )
echo " <option value=' $i ' " . ( $items == $i ? " selected='selected' " : '' ) . " > $i </option> " ;
?>
</ select >
</ label >
</ p >
< ? php endif ; if ( $inputs [ 'show_summary' ] ) : ?>
< p >
< label for = " rss-show-summary-<?php echo $number ; ?> " >
< input id = " rss-show-summary-<?php echo $number ; ?> " name = " widget-rss[<?php echo $number ; ?>][show_summary] " type = " checkbox " value = " 1 " < ? php if ( $show_summary ) echo 'checked="checked"' ; ?> />
< ? php _e ( 'Display item content?' ); ?>
</ label >
</ p >
< ? php endif ; if ( $inputs [ 'show_author' ] ) : ?>
< p >
< label for = " rss-show-author-<?php echo $number ; ?> " >
< input id = " rss-show-author-<?php echo $number ; ?> " name = " widget-rss[<?php echo $number ; ?>][show_author] " type = " checkbox " value = " 1 " < ? php if ( $show_author ) echo 'checked="checked"' ; ?> />
< ? php _e ( 'Display item author if available?' ); ?>
</ label >
</ p >
< ? php endif ; if ( $inputs [ 'show_date' ] ) : ?>
< p >
< label for = " rss-show-date-<?php echo $number ; ?> " >
< input id = " rss-show-date-<?php echo $number ; ?> " name = " widget-rss[<?php echo $number ; ?>][show_date] " type = " checkbox " value = " 1 " < ? php if ( $show_date ) echo 'checked="checked"' ; ?> />
< ? php _e ( 'Display item date?' ); ?>
</ label >
</ p >
2008-03-20 00:39:23 -04:00
< input type = " hidden " name = " widget-rss[<?php echo $number ; ?>][submit] " value = " 1 " />
2008-02-02 02:57:51 -05:00
< ? php
endif ;
foreach ( array_keys ( $default_inputs ) as $input ) :
if ( 'hidden' === $inputs [ $input ] ) :
$id = str_replace ( '_' , '-' , $input );
?>
< input type = " hidden " id = " rss-<?php echo $id ; ?>-<?php echo $number ; ?> " name = " widget-rss[<?php echo $number ; ?>][<?php echo $input ; ?>] " value = " <?php echo $ $input ; ?> " />
2007-04-23 21:05:17 -04:00
< ? php
2008-02-02 02:57:51 -05:00
endif ;
endforeach ;
}
2008-09-18 21:32:45 -04:00
/**
* Process RSS feed widget data and optionally retrieve feed items .
*
* The feed widget can not have more than 20 items or it will reset back to the
* default , which is 10.
*
* The resulting array has the feed title , feed url , feed link ( from channel ),
* feed items , error ( if any ), and whether to show summary , author , and date .
* All respectively in the order of the array elements .
*
2008-09-21 23:52:41 -04:00
* @ since 2.5 . 0
2008-09-18 21:32:45 -04:00
*
* @ param array $widget_rss RSS widget feed data . Expects unescaped data .
* @ param bool $check_feed Optional , default is true . Whether to check feed for errors .
* @ return array
*/
2008-02-02 02:57:51 -05:00
function wp_widget_rss_process ( $widget_rss , $check_feed = true ) {
$items = ( int ) $widget_rss [ 'items' ];
if ( $items < 1 || 20 < $items )
$items = 10 ;
$url = sanitize_url ( strip_tags ( $widget_rss [ 'url' ] ));
$title = trim ( strip_tags ( $widget_rss [ 'title' ] ));
$show_summary = ( int ) $widget_rss [ 'show_summary' ];
$show_author = ( int ) $widget_rss [ 'show_author' ];
$show_date = ( int ) $widget_rss [ 'show_date' ];
if ( $check_feed ) {
2009-02-27 14:32:50 -05:00
$rss = fetch_feed ( $url );
2008-02-02 02:57:51 -05:00
$error = false ;
$link = '' ;
2009-03-07 14:44:28 -05:00
if ( is_wp_error ( $rss ) ) {
2009-03-08 00:01:26 -05:00
$error = $rss -> get_error_message ();
2008-02-02 02:57:51 -05:00
} else {
2009-02-27 14:32:50 -05:00
$link = clean_url ( strip_tags ( $rss -> get_permalink ()));
2009-03-07 14:44:28 -05:00
while ( stristr ( $link , 'http' ) != $link )
2008-02-05 01:47:27 -05:00
$link = substr ( $link , 1 );
2008-02-02 02:57:51 -05:00
}
}
return compact ( 'title' , 'url' , 'link' , 'items' , 'error' , 'show_summary' , 'show_author' , 'show_date' );
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:32:45 -04:00
/**
2008-09-21 23:52:41 -04:00
* Register RSS widget to allow multiple RSS widgets on startup .
2008-09-18 21:32:45 -04:00
*
2008-09-18 21:41:18 -04:00
* @ since 2.2 . 0
2008-09-18 21:32:45 -04:00
*/
2007-04-23 21:05:17 -04:00
function wp_widget_rss_register () {
2009-03-15 07:18:09 -04:00
$options = get_option ( 'widget_rss' );
if ( ! is_array ( $options ) )
2008-01-05 00:20:56 -05:00
$options = array ();
2009-03-15 07:18:09 -04:00
2008-01-04 18:34:33 -05:00
$widget_ops = array ( 'classname' => 'widget_rss' , 'description' => __ ( 'Entries from any RSS or Atom feed' ));
2008-03-14 02:30:41 -04:00
$control_ops = array ( 'width' => 400 , 'height' => 200 , 'id_base' => 'rss' );
2008-01-04 18:34:33 -05:00
$name = __ ( 'RSS' );
2008-02-27 18:57:00 -05:00
$id = false ;
2008-08-06 16:31:54 -04:00
foreach ( ( array ) array_keys ( $options ) as $o ) {
2008-01-04 18:34:33 -05:00
// Old widgets can have null values for some reason
if ( ! isset ( $options [ $o ][ 'url' ]) || ! isset ( $options [ $o ][ 'title' ]) || ! isset ( $options [ $o ][ 'items' ]) )
2008-03-14 02:27:25 -04:00
continue ;
2008-01-04 18:34:33 -05:00
$id = " rss- $o " ; // Never never never translate an id
wp_register_sidebar_widget ( $id , $name , 'wp_widget_rss' , $widget_ops , array ( 'number' => $o ));
wp_register_widget_control ( $id , $name , 'wp_widget_rss_control' , $control_ops , array ( 'number' => $o ));
2007-04-23 21:05:17 -04:00
}
2008-02-27 18:57:00 -05:00
// If there are none, we register the widget's existance with a generic template
if ( ! $id ) {
wp_register_sidebar_widget ( 'rss-1' , $name , 'wp_widget_rss' , $widget_ops , array ( 'number' => - 1 ) );
wp_register_widget_control ( 'rss-1' , $name , 'wp_widget_rss_control' , $control_ops , array ( 'number' => - 1 ) );
}
2007-04-23 21:05:17 -04:00
}
2008-09-18 21:32:45 -04:00
/**
2008-09-18 21:41:18 -04:00
* Display tag cloud widget .
2008-09-18 21:32:45 -04:00
*
2008-09-18 21:41:18 -04:00
* @ since 2.3 . 0
2008-09-18 21:32:45 -04:00
*
* @ param array $args Widget arguments .
*/
2007-09-05 17:50:52 -04:00
function wp_widget_tag_cloud ( $args ) {
extract ( $args );
$options = get_option ( 'widget_tag_cloud' );
2008-04-29 12:08:19 -04:00
$title = empty ( $options [ 'title' ]) ? __ ( 'Tags' ) : apply_filters ( 'widget_title' , $options [ 'title' ]);
2007-09-05 17:50:52 -04:00
echo $before_widget ;
echo $before_title . $title . $after_title ;
wp_tag_cloud ();
echo $after_widget ;
}
2008-09-18 21:32:45 -04:00
/**
* Manage WordPress Tag Cloud widget options .
*
* Displays management form for changing the tag cloud widget title .
*
2008-09-18 21:41:18 -04:00
* @ since 2.3 . 0
2008-09-18 21:32:45 -04:00
*/
2007-09-05 17:50:52 -04:00
function wp_widget_tag_cloud_control () {
$options = $newoptions = get_option ( 'widget_tag_cloud' );
2008-09-21 16:57:04 -04:00
if ( isset ( $_POST [ 'tag-cloud-submit' ]) ) {
2007-09-05 17:50:52 -04:00
$newoptions [ 'title' ] = strip_tags ( stripslashes ( $_POST [ 'tag-cloud-title' ]));
}
if ( $options != $newoptions ) {
$options = $newoptions ;
update_option ( 'widget_tag_cloud' , $options );
}
$title = attribute_escape ( $options [ 'title' ] );
?>
< p >< label for = " tag-cloud-title " >
2008-01-04 18:34:33 -05:00
< ? php _e ( 'Title:' ) ?> <input type="text" class="widefat" id="tag-cloud-title" name="tag-cloud-title" value="<?php echo $title ?>" /></label>
2007-09-05 17:50:52 -04:00
</ p >
< input type = " hidden " name = " tag-cloud-submit " id = " tag-cloud-submit " value = " 1 " />
< ? php
}
2008-09-18 21:32:45 -04:00
/**
2008-09-21 23:52:41 -04:00
* Register all of the default WordPress widgets on startup .
2008-09-18 21:32:45 -04:00
*
* Calls 'widgets_init' action after all of the WordPress widgets have been
* registered .
*
2008-09-18 21:41:18 -04:00
* @ since 2.2 . 0
2008-09-18 21:32:45 -04:00
*/
2007-04-23 21:05:17 -04:00
function wp_widgets_init () {
2007-06-23 01:32:16 -04:00
if ( ! is_blog_installed () )
return ;
2009-03-14 13:24:11 -04:00
new WP_Widget_Pages ();
2007-09-03 19:19:20 -04:00
2008-01-04 18:34:33 -05:00
$widget_ops = array ( 'classname' => 'widget_calendar' , 'description' => __ ( " A calendar of your blog's posts " ) );
wp_register_sidebar_widget ( 'calendar' , __ ( 'Calendar' ), 'wp_widget_calendar' , $widget_ops );
wp_register_widget_control ( 'calendar' , __ ( 'Calendar' ), 'wp_widget_calendar_control' );
2007-09-03 19:19:20 -04:00
2008-01-04 18:34:33 -05:00
$widget_ops = array ( 'classname' => 'widget_archive' , 'description' => __ ( " A monthly archive of your blog's posts " ) );
wp_register_sidebar_widget ( 'archives' , __ ( 'Archives' ), 'wp_widget_archives' , $widget_ops );
wp_register_widget_control ( 'archives' , __ ( 'Archives' ), 'wp_widget_archives_control' );
2007-09-03 19:19:20 -04:00
2009-03-14 12:34:08 -04:00
new WP_Widget_Links ();
2007-09-03 19:19:20 -04:00
2008-01-04 18:34:33 -05:00
$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_widget_control ( 'meta' , __ ( 'Meta' ), 'wp_widget_meta_control' );
2007-09-03 19:19:20 -04:00
2009-03-14 12:34:08 -04:00
new WP_Widget_Search ();
2007-09-03 19:19:20 -04:00
2008-01-04 18:34:33 -05:00
$widget_ops = array ( 'classname' => 'widget_recent_entries' , 'description' => __ ( " The most recent posts on your blog " ) );
wp_register_sidebar_widget ( 'recent-posts' , __ ( 'Recent Posts' ), 'wp_widget_recent_entries' , $widget_ops );
wp_register_widget_control ( 'recent-posts' , __ ( 'Recent Posts' ), 'wp_widget_recent_entries_control' );
2007-09-03 19:19:20 -04:00
2008-01-04 18:34:33 -05:00
$widget_ops = array ( 'classname' => 'widget_tag_cloud' , 'description' => __ ( " Your most used tags in cloud format " ) );
wp_register_sidebar_widget ( 'tag_cloud' , __ ( 'Tag Cloud' ), 'wp_widget_tag_cloud' , $widget_ops );
wp_register_widget_control ( 'tag_cloud' , __ ( 'Tag Cloud' ), 'wp_widget_tag_cloud_control' );
2007-09-05 17:50:52 -04:00
2007-06-15 22:03:25 -04:00
wp_widget_categories_register ();
2007-04-23 21:05:17 -04:00
wp_widget_text_register ();
wp_widget_rss_register ();
wp_widget_recent_comments_register ();
2007-04-24 17:36:17 -04:00
do_action ( 'widgets_init' );
2007-04-23 21:05:17 -04:00
}
2007-04-30 21:13:06 -04:00
add_action ( 'init' , 'wp_widgets_init' , 1 );
2008-09-21 23:52:41 -04:00
/*
* Pattern for multi - widget ( allows multiple instances such as the text widget ) .
*
* Make sure to close the comments after copying .
2008-01-04 18:34:33 -05:00
2008-09-21 23:52:41 -04:00
/**
* Displays widget .
*
* Supports multiple widgets .
*
* @ param array $args Widget arguments .
* @ param array | int $widget_args Widget number . Which of the several widgets of this type do we mean .
* /
2008-01-04 18:34:33 -05:00
function widget_many ( $args , $widget_args = 1 ) {
extract ( $args , EXTR_SKIP );
if ( is_numeric ( $widget_args ) )
$widget_args = array ( 'number' => $widget_args );
$widget_args = wp_parse_args ( $widget_args , array ( 'number' => - 1 ) );
extract ( $widget_args , EXTR_SKIP );
2008-02-05 01:47:27 -05:00
2008-01-04 18:34:33 -05:00
// Data should be stored as array: array( number => data for that instance of the widget, ... )
$options = get_option ( 'widget_many' );
if ( ! isset ( $options [ $number ]) )
return ;
echo $before_widget ;
// Do stuff for this widget, drawing data from $options[$number]
echo $after_widget ;
}
2008-09-21 23:52:41 -04:00
/**
* Displays form for a particular instance of the widget .
*
* Also updates the data after a POST submit .
*
* @ param array | int $widget_args Widget number . Which of the several widgets of this type do we mean .
* /
2008-01-04 18:34:33 -05:00
function widget_many_control ( $widget_args = 1 ) {
global $wp_registered_widgets ;
static $updated = false ; // Whether or not we have already updated the data after a POST submit
if ( is_numeric ( $widget_args ) )
$widget_args = array ( 'number' => $widget_args );
$widget_args = wp_parse_args ( $widget_args , array ( 'number' => - 1 ) );
extract ( $widget_args , EXTR_SKIP );
// Data should be stored as array: array( number => data for that instance of the widget, ... )
$options = get_option ( 'widget_many' );
if ( ! is_array ( $options ) )
$options = array ();
// We need to update the data
if ( ! $updated && ! empty ( $_POST [ 'sidebar' ]) ) {
// Tells us what sidebar to put the data in
$sidebar = ( string ) $_POST [ 'sidebar' ];
$sidebars_widgets = wp_get_sidebars_widgets ();
if ( isset ( $sidebars_widgets [ $sidebar ]) )
$this_sidebar =& $sidebars_widgets [ $sidebar ];
else
$this_sidebar = array ();
foreach ( $this_sidebar as $_widget_id ) {
// 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 data
// since widget ids aren't necessarily persistent across multiple updates
if ( 'widget_many' == $wp_registered_widgets [ $_widget_id ][ 'callback' ] && isset ( $wp_registered_widgets [ $_widget_id ][ 'params' ][ 0 ][ 'number' ]) ) {
$widget_number = $wp_registered_widgets [ $_widget_id ][ 'params' ][ 0 ][ 'number' ];
2008-03-06 18:01:22 -05:00
if ( ! in_array ( " many- $widget_number " , $_POST [ 'widget-id' ] ) ) // the widget has been removed. "many-$widget_number" is "{id_base}-{widget_number}
unset ( $options [ $widget_number ]);
2008-01-04 18:34:33 -05:00
}
}
foreach ( ( array ) $_POST [ 'widget-many' ] as $widget_number => $widget_many_instance ) {
// compile data from $widget_many_instance
2008-04-07 17:40:32 -04:00
if ( ! isset ( $widget_many_instance [ 'something' ]) && isset ( $options [ $widget_number ]) ) // user clicked cancel
continue ;
2008-01-04 18:34:33 -05:00
$something = wp_specialchars ( $widget_many_instance [ 'something' ] );
$options [ $widget_number ] = array ( 'something' => $something ); // Even simple widgets should store stuff in array, rather than in scalar
}
2008-04-28 16:08:23 -04:00
update_option ( 'widget_many' , $options );
2008-01-04 18:34:33 -05:00
$updated = true ; // So that we don't go through this more than once
}
// Here we echo out the form
if ( - 1 == $number ) { // We echo out a template for a form which can be converted to a specific form later via JS
$something = '' ;
$number = '%i%' ;
} else {
$something = attribute_escape ( $options [ $number ][ 'something' ]);
}
// The form has inputs with names like widget-many[$number][something] so that all data for that instance of
// the widget are stored in one $_POST variable: $_POST['widget-many'][$number]
?>
< p >
< input class = " widefat " id = " widget-many-something-<?php echo $number ; ?> " name = " widget-many[<?php echo $number ; ?>][something] " type = " text " value = " <?php echo $data ; ?> " />
2008-03-20 00:39:23 -04:00
< input type = " hidden " id = " widget-many-submit-<?php echo $number ; ?> " name = " widget-many[<?php echo $number ; ?>][submit] " value = " 1 " />
2008-01-04 18:34:33 -05:00
</ p >
< ? php
}
2008-09-21 23:52:41 -04:00
/**
* Registers each instance of our widget on startup .
* /
2008-01-04 18:34:33 -05:00
function widget_many_register () {
2008-01-05 00:20:56 -05:00
if ( ! $options = get_option ( 'widget_many' ) )
$options = array ();
2008-01-04 18:34:33 -05:00
$widget_ops = array ( 'classname' => 'widget_many' , 'description' => __ ( 'Widget which allows multiple instances' ));
$control_ops = array ( 'width' => 400 , 'height' => 350 , 'id_base' => 'many' );
$name = __ ( 'Many' );
2008-02-27 18:57:00 -05:00
$registered = false ;
2008-01-04 18:34:33 -05:00
foreach ( array_keys ( $options ) as $o ) {
// Old widgets can have null values for some reason
if ( ! isset ( $options [ $o ][ 'something' ]) ) // we used 'something' above in our exampple. Replace with with whatever your real data are.
continue ;
// $id should look like {$id_base}-{$o}
$id = " many- $o " ; // Never never never translate an id
2008-02-27 18:57:00 -05:00
$registered = true ;
2008-04-28 16:08:23 -04:00
wp_register_sidebar_widget ( $id , $name , 'widget_many' , $widget_ops , array ( 'number' => $o ) );
wp_register_widget_control ( $id , $name , 'widget_many_control' , $control_ops , array ( 'number' => $o ) );
2008-01-04 18:34:33 -05:00
}
2008-02-27 18:57:00 -05:00
// If there are none, we register the widget's existance with a generic template
if ( ! $registered ) {
wp_register_sidebar_widget ( 'many-1' , $name , 'widget_many' , $widget_ops , array ( 'number' => - 1 ) );
wp_register_widget_control ( 'many-1' , $name , 'widget_many_control' , $control_ops , array ( 'number' => - 1 ) );
}
2008-01-04 18:34:33 -05:00
}
// This is important
2009-01-05 06:19:53 -05:00
add_action ( 'widgets_init' , 'widget_many_register' );
2008-01-04 18:34:33 -05:00
*/
2007-05-03 22:23:49 -04:00
?>