prefix = Easy_get_prefix();
/* Set the widget textdomain. */
$this->textdomain = Easy_get_textdomain();
/* Set up the widget options. */
$widget_options = array(
'classname' => 'authors',
'description' => esc_html__( 'An advanced widget that gives you total control over the output of your author lists.', $this->textdomain )
);
/* Set up the widget control options. */
$control_options = array(
'width' => 525,
'height' => 350,
'id_base' => "{$this->prefix}-authors"
);
/* Create the widget. */
$this->WP_Widget( "{$this->prefix}-authors", esc_attr__( 'Authors', $this->textdomain ), $widget_options, $control_options );
}
/**
* Outputs the widget based on the arguments input through the widget controls.
* @since 0.6.0
*/
function widget( $args, $instance ) {
extract( $args, EXTR_SKIP );
/* Set up the arguments for wp_list_authors(). */
$args = array(
'order' => $instance['order'],
'orderby' => $instance['orderby'],
'number' => !empty( $instance['number'] ) ? intval( $instance['number'] ) : '',
'style' => $instance['style'],
'feed' => $instance['feed'],
'feed_image' => $instance['feed_image'],
'optioncount' => !empty( $instance['optioncount'] ) ? true : false,
'exclude_admin' => !empty( $instance['exclude_admin'] ) ? true : false,
'show_fullname' => !empty( $instance['show_fullname'] ) ? true : false,
'hide_empty' => !empty( $instance['hide_empty'] ) ? true : false,
'html' => !empty( $instance['html'] ) ? true : false,
'echo' => false
);
/* Output the theme's $before_widget wrapper. */
echo $before_widget;
/* If a title was input by the user, display it. */
if ( !empty( $instance['title'] ) )
echo $before_title . apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base ) . $after_title;
/* Get the authors list. */
$authors = str_replace( array( "\r", "\n", "\t" ), '', wp_list_authors( $args ) );
/* If 'list' is the style and the output should be HTML, wrap the authors in a
. */
if ( 'list' == $args['style'] && $args['html'] )
$authors = '';
/* Display the authors list. */
echo $authors;
/* Close the theme's widget wrapper. */
echo $after_widget;
}
/**
* Updates the widget control options for the particular instance of the widget.
* @since 0.6.0
*/
function update( $new_instance, $old_instance ) {
$instance = $old_instance;
$instance = $new_instance;
$instance['title'] = strip_tags( $new_instance['title'] );
$instance['feed'] = strip_tags( $new_instance['feed'] );
$instance['order'] = strip_tags( $new_instance['order'] );
$instance['orderby'] = strip_tags( $new_instance['orderby'] );
$instance['number'] = strip_tags( $new_instance['number'] );
$instance['html'] = ( isset( $new_instance['html'] ) ? 1 : 0 );
$instance['optioncount'] = ( isset( $new_instance['optioncount'] ) ? 1 : 0 );
$instance['exclude_admin'] = ( isset( $new_instance['exclude_admin'] ) ? 1 : 0 );
$instance['show_fullname'] = ( isset( $new_instance['show_fullname'] ) ? 1 : 0 );
$instance['hide_empty'] = ( isset( $new_instance['hide_empty'] ) ? 1 : 0 );
return $instance;
}
/**
* Displays the widget control options in the Widgets admin screen.
* @since 0.6.0
*/
function form( $instance ) {
/* Set up the default form values. */
$defaults = array(
'title' => esc_attr__( 'Authors', $this->textdomain ),
'order' => 'ASC',
'orderby' => 'display_name',
'number' => '',
'optioncount' => false,
'exclude_admin' => false,
'show_fullname' => true,
'hide_empty' => true,
'style' => 'list',
'html' => true,
'feed' => '',
'feed_image' => ''
);
/* Merge the user-selected arguments with the defaults. */
$instance = wp_parse_args( (array) $instance, $defaults );
$order = array( 'ASC' => esc_attr__( 'Ascending', $this->textdomain ), 'DESC' => esc_attr__( 'Descending', $this->textdomain ) );
$orderby = array( 'display_name' => esc_attr__( 'Display Name', $this->textdomain ), 'email' => esc_attr__( 'Email', $this->textdomain ), 'ID' => esc_attr__( 'ID', $this->textdomain ), 'nicename' => esc_attr__( 'Nice Name', $this->textdomain ), 'post_count' => esc_attr__( 'Post Count', $this->textdomain ), 'registered' => esc_attr__( 'Registered', $this->textdomain ), 'url' => esc_attr__( 'URL', $this->textdomain ), 'user_login' => esc_attr__( 'Login', $this->textdomain ) );
?>