2010-02-07 11:16:26 -05:00
< ? php
2010-03-29 18:03:15 -04:00
/**
* TwentyTen functions and definitions
*
2010-03-29 20:05:17 -04:00
* Sets up the theme and provides some helper functions . Some helper functions
* are used in the theme as custom template tags . Others are attached to action and
* filter hooks in WordPress to change core functionality .
*
* The first function , twentyten_setup (), sets up the theme by registering support
* for various features in WordPress , such as post thumbnails , navigation menus , and the like .
*
2010-05-16 16:53:36 -04:00
* When using a child theme ( see http :// codex . wordpress . org / Theme_Development and
2010-05-17 02:52:47 -04:00
* http :// codex . wordpress . org / Child_Themes ), you can override certain functions
2010-05-16 16:53:36 -04:00
* ( those wrapped in a function_exists () call ) by defining them first in your child theme ' s
* functions . php file . The child theme ' s functions . php file is included before the parent
* theme ' s file , so the child theme functions would be used .
2010-03-29 20:05:17 -04:00
*
* Functions that are not pluggable ( not wrapped in function_exists ()) are instead attached
* to a filter or action hook . The hook can be removed by using remove_action () or
2010-03-30 08:55:08 -04:00
* remove_filter () and you can attach your own function to the hook .
*
2010-04-02 00:45:22 -04:00
* We can remove the parent theme ' s hook only after it is attached , which means we need to
* wait until setting up the child theme :
2010-03-29 20:05:17 -04:00
*
* < code >
* add_action ( 'after_setup_theme' , 'my_child_theme_setup' );
* function my_child_theme_setup () {
2010-03-30 08:55:08 -04:00
* // We are providing our own filter for excerpt_length (or using the unfiltered value)
* remove_filter ( 'excerpt_length' , 'twentyten_excerpt_length' );
* ...
2010-03-29 20:05:17 -04:00
* }
* </ code >
*
2010-05-21 14:56:27 -04:00
* For more information on hooks , actions , and filters , see http :// codex . wordpress . org / Plugin_API .
2010-03-29 18:03:15 -04:00
*
* @ package WordPress
2010-05-16 13:10:21 -04:00
* @ subpackage Twenty_Ten
2010-05-16 16:53:36 -04:00
* @ since Twenty Ten 1.0
2010-03-29 18:03:15 -04:00
*/
2010-02-07 11:16:26 -05:00
2010-03-29 18:03:15 -04:00
/**
2010-03-29 20:05:17 -04:00
* Set the content width based on the theme ' s design and stylesheet .
2010-03-29 18:03:15 -04:00
*
2010-03-29 20:05:17 -04:00
* Used to set the width of images and content . Should be equal to the width the theme
* is designed for , generally via the style . css stylesheet .
2010-03-29 18:03:15 -04:00
*/
2010-02-14 16:39:20 -05:00
if ( ! isset ( $content_width ) )
2010-02-25 03:56:19 -05:00
$content_width = 640 ;
2010-02-14 16:39:20 -05:00
2010-03-29 20:05:17 -04:00
/** Tell WordPress to run twentyten_setup() when the 'after_setup_theme' hook is run. */
add_action ( 'after_setup_theme' , 'twentyten_setup' );
2010-05-10 01:58:24 -04:00
if ( ! function_exists ( 'twentyten_setup' ) ) :
2010-03-29 18:03:15 -04:00
/**
2010-03-29 20:05:17 -04:00
* Sets up theme defaults and registers support for various WordPress features .
*
* Note that this function is hooked into the after_setup_theme hook , which runs
* before the init hook . The init hook is too late for some features , such as indicating
* support post thumbnails .
*
2010-04-01 20:54:48 -04:00
* To override twentyten_setup () in a child theme , add your own twentyten_setup to your child theme ' s
* functions . php file .
2010-03-29 18:03:15 -04:00
*
2010-06-10 13:57:30 -04:00
* @ uses add_theme_support () To add support for post thumbnails and automatic feed links .
* @ uses register_nav_menus () To add support for navigation menus .
2010-03-29 20:05:17 -04:00
* @ uses add_custom_background () To add support for a custom background .
* @ uses add_editor_style () To style the visual editor .
* @ uses load_theme_textdomain () For translation / localization support .
* @ uses add_custom_image_header () To add support for a custom header .
* @ uses register_default_headers () To register the default custom header images provided with the theme .
* @ uses set_post_thumbnail_size () To set a custom post thumbnail size .
2010-03-29 18:03:15 -04:00
*
2010-05-16 16:53:36 -04:00
* @ since Twenty Ten 1.0
2010-03-29 18:03:15 -04:00
*/
2010-03-29 20:05:17 -04:00
function twentyten_setup () {
2010-03-29 18:03:15 -04:00
// This theme styles the visual editor with editor-style.css to match the theme style.
add_editor_style ();
2010-03-29 20:05:17 -04:00
// This theme uses post thumbnails
2010-03-29 18:03:15 -04:00
add_theme_support ( 'post-thumbnails' );
// Add default posts and comments RSS feed links to head
add_theme_support ( 'automatic-feed-links' );
// Make theme available for translation
// Translations can be filed in the /languages/ directory
load_theme_textdomain ( 'twentyten' , TEMPLATEPATH . '/languages' );
$locale = get_locale ();
$locale_file = TEMPLATEPATH . " /languages/ $locale .php " ;
if ( is_readable ( $locale_file ) )
require_once ( $locale_file );
2010-05-14 02:20:30 -04:00
// This theme uses wp_nav_menu() in one location.
register_nav_menus ( array (
2010-05-24 05:26:41 -04:00
'primary' => __ ( 'Primary Navigation' , 'twentyten' ),
2010-05-14 02:20:30 -04:00
) );
2010-03-29 20:05:17 -04:00
// This theme allows users to set a custom background
add_custom_background ();
// Your changeable header business starts here
2010-03-16 16:17:22 -04:00
define ( 'HEADER_TEXTCOLOR' , '' );
2010-03-29 20:05:17 -04:00
// No CSS, just IMG call. The %s is a placeholder for the theme template directory URI.
2010-04-24 21:02:51 -04:00
define ( 'HEADER_IMAGE' , '%s/images/headers/path.jpg' );
2010-03-29 18:03:15 -04:00
2010-03-29 20:05:17 -04:00
// The height and width of your custom header. You can hook into the theme's own filters to change these values.
// Add a filter to twentyten_header_image_width and twentyten_header_image_height to change these values.
2010-05-04 03:01:09 -04:00
define ( 'HEADER_IMAGE_WIDTH' , apply_filters ( 'twentyten_header_image_width' , 940 ) );
define ( 'HEADER_IMAGE_HEIGHT' , apply_filters ( 'twentyten_header_image_height' , 198 ) );
2010-03-29 18:03:15 -04:00
2010-03-29 20:05:17 -04:00
// We'll be using post thumbnails for custom header images on posts and pages.
2010-05-21 14:56:27 -04:00
// We want them to be 940 pixels wide by 198 pixels tall.
// Larger images will be auto-cropped to fit, smaller ones will be ignored. See header.php.
2010-03-29 20:05:17 -04:00
set_post_thumbnail_size ( HEADER_IMAGE_WIDTH , HEADER_IMAGE_HEIGHT , true );
// Don't support text inside the header image.
2010-02-14 16:39:20 -05:00
define ( 'NO_HEADER_TEXT' , true );
2010-03-29 20:05:17 -04:00
// Add a way for the custom header to be styled in the admin panel that controls
// custom headers. See twentyten_admin_header_style(), below.
2010-02-14 16:39:20 -05:00
add_custom_image_header ( '' , 'twentyten_admin_header_style' );
2010-03-29 20:05:17 -04:00
// ... and thus ends the changeable header business.
2010-03-29 18:03:15 -04:00
2010-03-29 20:05:17 -04:00
// Default custom headers packaged with the theme. %s is a placeholder for the theme template directory URI.
2010-05-10 01:58:24 -04:00
register_default_headers ( array (
'berries' => array (
2010-03-16 16:17:22 -04:00
'url' => '%s/images/headers/berries.jpg' ,
'thumbnail_url' => '%s/images/headers/berries-thumbnail.jpg' ,
2010-05-10 01:58:24 -04:00
/* translators: header image description */
2010-03-16 19:11:30 -04:00
'description' => __ ( 'Berries' , 'twentyten' )
2010-03-16 16:17:22 -04:00
),
2010-05-10 01:58:24 -04:00
'cherryblossom' => array (
2010-03-16 16:17:22 -04:00
'url' => '%s/images/headers/cherryblossoms.jpg' ,
'thumbnail_url' => '%s/images/headers/cherryblossoms-thumbnail.jpg' ,
2010-05-21 14:56:27 -04:00
/* translators: header image description */
2010-03-16 19:11:30 -04:00
'description' => __ ( 'Cherry Blossoms' , 'twentyten' )
2010-03-16 16:17:22 -04:00
),
2010-05-10 01:58:24 -04:00
'concave' => array (
2010-03-16 16:17:22 -04:00
'url' => '%s/images/headers/concave.jpg' ,
'thumbnail_url' => '%s/images/headers/concave-thumbnail.jpg' ,
2010-05-21 14:56:27 -04:00
/* translators: header image description */
2010-03-16 19:11:30 -04:00
'description' => __ ( 'Concave' , 'twentyten' )
2010-03-16 16:17:22 -04:00
),
2010-05-10 01:58:24 -04:00
'fern' => array (
2010-03-16 16:17:22 -04:00
'url' => '%s/images/headers/fern.jpg' ,
'thumbnail_url' => '%s/images/headers/fern-thumbnail.jpg' ,
2010-05-21 14:56:27 -04:00
/* translators: header image description */
2010-03-16 19:11:30 -04:00
'description' => __ ( 'Fern' , 'twentyten' )
2010-03-16 16:17:22 -04:00
),
2010-05-10 01:58:24 -04:00
'forestfloor' => array (
2010-03-16 16:17:22 -04:00
'url' => '%s/images/headers/forestfloor.jpg' ,
'thumbnail_url' => '%s/images/headers/forestfloor-thumbnail.jpg' ,
2010-05-21 14:56:27 -04:00
/* translators: header image description */
2010-03-16 19:11:30 -04:00
'description' => __ ( 'Forest Floor' , 'twentyten' )
2010-03-16 16:17:22 -04:00
),
2010-05-10 01:58:24 -04:00
'inkwell' => array (
2010-03-16 16:17:22 -04:00
'url' => '%s/images/headers/inkwell.jpg' ,
'thumbnail_url' => '%s/images/headers/inkwell-thumbnail.jpg' ,
2010-05-21 14:56:27 -04:00
/* translators: header image description */
2010-03-16 19:11:30 -04:00
'description' => __ ( 'Inkwell' , 'twentyten' )
2010-03-16 16:17:22 -04:00
),
2010-05-10 01:58:24 -04:00
'path' => array (
2010-03-16 16:17:22 -04:00
'url' => '%s/images/headers/path.jpg' ,
'thumbnail_url' => '%s/images/headers/path-thumbnail.jpg' ,
2010-05-21 14:56:27 -04:00
/* translators: header image description */
2010-03-16 19:11:30 -04:00
'description' => __ ( 'Path' , 'twentyten' )
2010-03-16 16:17:22 -04:00
),
2010-05-10 01:58:24 -04:00
'sunset' => array (
2010-03-16 16:17:22 -04:00
'url' => '%s/images/headers/sunset.jpg' ,
'thumbnail_url' => '%s/images/headers/sunset-thumbnail.jpg' ,
2010-05-21 14:56:27 -04:00
/* translators: header image description */
2010-03-16 19:11:30 -04:00
'description' => __ ( 'Sunset' , 'twentyten' )
2010-03-16 16:17:22 -04:00
)
) );
2010-02-14 16:39:20 -05:00
}
2010-04-01 20:54:48 -04:00
endif ;
2010-02-07 11:16:26 -05:00
2010-02-14 16:39:20 -05:00
if ( ! function_exists ( 'twentyten_admin_header_style' ) ) :
2010-03-29 18:03:15 -04:00
/**
2010-03-29 20:05:17 -04:00
* Styles the header image displayed on the Appearance > Header admin panel .
*
* Referenced via add_custom_image_header () in twentyten_setup () .
*
2010-05-16 16:53:36 -04:00
* @ since Twenty Ten 1.0
2010-03-29 18:03:15 -04:00
*/
2010-02-07 11:16:26 -05:00
function twentyten_admin_header_style () {
?>
< style type = " text/css " >
2010-05-25 18:05:51 -04:00
/* Shows the same border as on front end */
2010-02-07 11:16:26 -05:00
#headimg {
2010-06-10 14:26:53 -04:00
border - bottom : 1 px solid #000;
border - top : 4 px solid #000;
2010-02-07 11:16:26 -05:00
}
2010-06-10 14:26:53 -04:00
/* If NO_HEADER_TEXT is false , you would style the text with these selectors :
#headimg #name { }
#headimg #desc { }
*/
2010-02-07 11:16:26 -05:00
</ style >
< ? php
}
2010-02-14 16:39:20 -05:00
endif ;
2010-02-07 11:16:26 -05:00
2010-03-29 18:03:15 -04:00
/**
2010-06-10 14:26:53 -04:00
* Makes some changes to the < title > tag , by filtering the output of wp_title () .
2010-03-29 18:03:15 -04:00
*
2010-06-10 14:26:53 -04:00
* If we have a site description and we ' re viewing the home page or a blog posts
* page ( when using a static front page ), then we will add the site description .
*
* If we 're viewing a search result, then we' re going to recreate the title entirely .
* We ' re going to add page numbers to all titles as well , to the middle of a search
* result title and the end of all other titles .
*
* The site title also gets added to all titles .
2010-03-29 18:03:15 -04:00
*
2010-05-16 16:53:36 -04:00
* @ since Twenty Ten 1.0
2010-06-10 14:26:53 -04:00
*
* @ param string $title Title generated by wp_title ()
* @ param string $separator The separator passed to wp_title () . Twenty Ten uses a
* vertical bar , " | " , as a separator in header . php .
* @ return string The new title , ready for the < title > tag .
2010-03-29 18:03:15 -04:00
*/
2010-06-10 14:26:53 -04:00
function twentyten_filter_wp_title ( $title , $separator ) {
// The $paged global variable contains the page number of a listing of posts.
// The $page global variable contains the page number of a single post that is paged.
// We'll display whichever one applies, if we're not looking at the first page.
global $paged , $page ;
if ( is_search () ) {
// If we're a search, let's start over:
$title = sprintf ( __ ( 'Search results for %s' , 'twentyten' ), '"' . get_search_query () . '"' );
// Add a page number if we're on page 2 or more:
if ( $paged >= 2 )
$title .= " $separator " . sprintf ( __ ( 'Page %s' , 'twentyten' ), $paged );
// Add the site name to the end:
$title .= " $separator " . get_bloginfo ( 'name' , 'display' );
// We're done. Let's send the new title back to wp_title():
return $title ;
}
// Otherwise, let's start by adding the site name to the end:
$title .= get_bloginfo ( 'name' , 'display' );
// If we have a site description and we're on the home/front page, add the description:
$site_description = get_bloginfo ( 'description' , 'display' );
if ( $site_description && ( is_home () || is_front_page () ) )
$title .= " $separator " . $site_description ;
// Add a page number if necessary:
if ( $paged >= 2 || $page >= 2 )
$title .= " $separator " . sprintf ( __ ( 'Page %s' , 'twentyten' ), max ( $paged , $page ) );
// Return the new title to wp_title():
return $title ;
2010-02-13 08:35:03 -05:00
}
2010-06-10 14:26:53 -04:00
add_filter ( 'wp_title' , 'twentyten_filter_wp_title' , 10 , 2 );
2010-02-07 11:16:26 -05:00
2010-05-05 23:04:22 -04:00
/**
2010-05-07 14:11:58 -04:00
* Get our wp_nav_menu () fallback , wp_page_menu (), to show a home link .
2010-05-16 16:53:36 -04:00
*
* To override this in a child theme , remove the filter and optionally add
* your own function tied to the wp_page_menu_args filter hook .
*
* @ since Twenty Ten 1.0
2010-05-05 23:04:22 -04:00
*/
2010-05-16 16:53:36 -04:00
function twentyten_page_menu_args ( $args ) {
2010-05-07 14:11:58 -04:00
$args [ 'show_home' ] = true ;
2010-05-05 23:04:22 -04:00
return $args ;
}
2010-05-16 16:53:36 -04:00
add_filter ( 'wp_page_menu_args' , 'twentyten_page_menu_args' );
2010-05-05 23:04:22 -04:00
2010-03-29 18:03:15 -04:00
/**
2010-03-29 20:05:17 -04:00
* Sets the post excerpt length to 40 characters .
*
* To override this length in a child theme , remove the filter and add your own
* function tied to the excerpt_length filter hook .
2010-03-29 18:03:15 -04:00
*
2010-05-16 16:53:36 -04:00
* @ since Twenty Ten 1.0
2010-03-29 18:03:15 -04:00
* @ return int
*/
2010-02-14 16:39:20 -05:00
function twentyten_excerpt_length ( $length ) {
2010-02-07 11:16:26 -05:00
return 40 ;
}
2010-02-14 16:39:20 -05:00
add_filter ( 'excerpt_length' , 'twentyten_excerpt_length' );
2010-02-07 11:16:26 -05:00
2010-03-29 18:03:15 -04:00
/**
2010-05-28 13:01:27 -04:00
* Returns a " Continue Reading " link for excerpts
*
* @ since Twenty Ten 1.0
* @ return string " Continue Reading " link
*/
function twentyten_continue_reading_link () {
return ' <a href="' . get_permalink () . '">' . __ ( 'Continue reading <span class="meta-nav">→</span>' , 'twentyten' ) . '</a>' ;
}
/**
* Replaces " [...] " ( appended to automatically generated excerpts ) with an ellipsis and twentyten_continue_reading_link () .
2010-03-29 18:03:15 -04:00
*
2010-05-25 12:08:44 -04:00
* To override this in a child theme , remove the filter and add your own
2010-03-29 20:05:17 -04:00
* function tied to the excerpt_more filter hook .
2010-03-29 18:03:15 -04:00
*
2010-05-16 16:53:36 -04:00
* @ since Twenty Ten 1.0
2010-05-25 12:08:44 -04:00
* @ return string An ellipsis
*/
function twentyten_auto_excerpt_more ( $more ) {
2010-05-28 13:01:27 -04:00
return ' …' . twentyten_continue_reading_link ();
2010-05-25 12:08:44 -04:00
}
add_filter ( 'excerpt_more' , 'twentyten_auto_excerpt_more' );
/**
2010-05-28 13:01:27 -04:00
* Adds a pretty " Continue Reading " link to custom post excerpts .
2010-05-25 12:08:44 -04:00
*
* To override this link in a child theme , remove the filter and add your own
* function tied to the get_the_excerpt filter hook .
*
* @ since Twenty Ten 1.0
* @ return string Excerpt with a pretty " Continue Reading " link
2010-03-29 18:03:15 -04:00
*/
2010-05-25 12:08:44 -04:00
function twentyten_custom_excerpt_more ( $output ) {
2010-06-02 18:41:14 -04:00
if ( has_excerpt () && ! is_attachment () ) {
2010-05-28 13:01:27 -04:00
$output .= twentyten_continue_reading_link ();
}
return $output ;
2010-02-07 11:16:26 -05:00
}
2010-05-25 12:08:44 -04:00
add_filter ( 'get_the_excerpt' , 'twentyten_custom_excerpt_more' );
2010-02-07 11:16:26 -05:00
2010-03-29 20:05:17 -04:00
/**
* Remove inline styles printed when the gallery shortcode is used .
*
* Galleries are styled by the theme in Twenty Ten ' s style . css .
*
2010-05-16 16:53:36 -04:00
* @ since Twenty Ten 1.0
2010-03-29 20:05:17 -04:00
* @ return string The gallery style filter , with the styles themselves removed .
*/
function twentyten_remove_gallery_css ( $css ) {
return preg_replace ( " #<style type='text/css'>(.*?)</style>#s " , '' , $css );
}
add_filter ( 'gallery_style' , 'twentyten_remove_gallery_css' );
2010-02-14 16:39:20 -05:00
if ( ! function_exists ( 'twentyten_comment' ) ) :
2010-03-29 18:03:15 -04:00
/**
2010-03-29 20:05:17 -04:00
* Template for comments and pingbacks .
2010-03-29 18:03:15 -04:00
*
2010-03-29 20:05:17 -04:00
* To override this walker in a child theme without modifying the comments template
* simply create your own twentyten_comment (), and that function will be used instead .
2010-03-29 18:03:15 -04:00
*
2010-03-29 20:05:17 -04:00
* Used as a callback by wp_list_comments () for displaying the comments .
*
2010-05-16 16:53:36 -04:00
* @ since Twenty Ten 1.0
2010-03-29 18:03:15 -04:00
*/
2010-02-14 16:39:20 -05:00
function twentyten_comment ( $comment , $args , $depth ) {
2010-05-10 01:58:24 -04:00
$GLOBALS [ 'comment' ] = $comment ; ?>
2010-02-14 16:39:20 -05:00
< ? php if ( '' == $comment -> comment_type ) : ?>
2010-02-13 20:00:22 -05:00
< li < ? php comment_class (); ?> id="li-comment-<?php comment_ID(); ?>">
2010-02-07 11:16:26 -05:00
< div id = " comment-<?php comment_ID(); ?> " >
< div class = " comment-author vcard " >
2010-02-13 20:00:22 -05:00
< ? php echo get_avatar ( $comment , 40 ); ?>
2010-05-10 01:58:24 -04:00
< ? php printf ( __ ( '%s <span class="says">says:</span>' , 'twentyten' ), sprintf ( '<cite class="fn">%s</cite>' , get_comment_author_link () ) ); ?>
2010-05-21 14:56:27 -04:00
</ div ><!-- . comment - author . vcard -->
2010-02-13 20:00:22 -05:00
< ? php if ( $comment -> comment_approved == '0' ) : ?>
< em >< ? php _e ( 'Your comment is awaiting moderation.' , 'twentyten' ); ?> </em>
2010-02-07 11:16:26 -05:00
< br />
< ? php endif ; ?>
2010-05-10 01:58:24 -04:00
< div class = " comment-meta commentmetadata " >< a href = " <?php echo esc_url( get_comment_link( $comment->comment_ID ) ); ?> " >
< ? php
/* translators: 1: date, 2: time */
printf ( __ ( '%1$s at %2$s' , 'twentyten' ), get_comment_date (), get_comment_time () ); ?> </a><?php edit_comment_link( __( '(Edit)', 'twentyten' ), ' ' );
?>
2010-05-21 14:56:27 -04:00
</ div ><!-- . comment - meta . commentmetadata -->
2010-02-07 11:16:26 -05:00
2010-02-13 20:00:22 -05:00
< div class = " comment-body " >< ? php comment_text (); ?> </div>
2010-02-07 11:16:26 -05:00
< div class = " reply " >
2010-02-14 16:39:20 -05:00
< ? php comment_reply_link ( array_merge ( $args , array ( 'depth' => $depth , 'max_depth' => $args [ 'max_depth' ] ) ) ); ?>
2010-05-21 14:56:27 -04:00
</ div ><!-- . reply -->
</ div ><!-- #comment-## -->
2010-02-07 11:16:26 -05:00
2010-06-10 22:17:26 -04:00
< ? php elseif ( in_array ( $comment -> comment_type , array ( 'pingback' , 'trackback' )) ) : ?>
2010-02-07 11:16:26 -05:00
< li class = " post pingback " >
2010-05-10 01:58:24 -04:00
< p >< ? php _e ( 'Pingback:' , 'twentyten' ); ?> <?php comment_author_link(); ?><?php edit_comment_link( __('(Edit)', 'twentyten'), ' ' ); ?></p>
2010-02-14 16:39:20 -05:00
< ? php endif ;
2010-02-07 11:16:26 -05:00
}
2010-02-14 16:39:20 -05:00
endif ;
2010-02-07 11:16:26 -05:00
2010-03-29 18:03:15 -04:00
/**
2010-03-29 20:05:17 -04:00
* Register widgetized areas , including two sidebars and four widget - ready columns in the footer .
2010-03-29 18:03:15 -04:00
*
2010-03-29 20:05:17 -04:00
* To override twentyten_widgets_init () in a child theme , remove the action hook and add your own
* function tied to the init hook .
2010-05-16 16:53:36 -04:00
*
* @ since Twenty Ten 1.0
2010-03-29 18:03:15 -04:00
* @ uses register_sidebar
*/
2010-02-13 20:00:22 -05:00
function twentyten_widgets_init () {
2010-05-21 14:56:27 -04:00
// Area 1, located at the top of the sidebar.
2010-05-10 01:58:24 -04:00
register_sidebar ( array (
2010-05-04 03:01:09 -04:00
'name' => __ ( 'Primary Widget Area' , 'twentyten' ),
2010-02-07 11:16:26 -05:00
'id' => 'primary-widget-area' ,
2010-05-04 03:01:09 -04:00
'description' => __ ( 'The primary widget area' , 'twentyten' ),
2010-02-07 11:16:26 -05:00
'before_widget' => '<li id="%1$s" class="widget-container %2$s">' ,
2010-05-10 01:58:24 -04:00
'after_widget' => '</li>' ,
2010-02-07 11:16:26 -05:00
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
) );
2010-02-08 13:02:23 -05:00
2010-05-21 14:56:27 -04:00
// Area 2, located below the Primary Widget Area in the sidebar. Empty by default.
2010-05-10 01:58:24 -04:00
register_sidebar ( array (
2010-05-04 03:01:09 -04:00
'name' => __ ( 'Secondary Widget Area' , 'twentyten' ),
2010-02-08 13:02:23 -05:00
'id' => 'secondary-widget-area' ,
2010-05-04 03:01:09 -04:00
'description' => __ ( 'The secondary widget area' , 'twentyten' ),
2010-02-07 11:16:26 -05:00
'before_widget' => '<li id="%1$s" class="widget-container %2$s">' ,
2010-05-10 01:58:24 -04:00
'after_widget' => '</li>' ,
2010-02-07 11:16:26 -05:00
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
) );
2010-02-08 13:02:23 -05:00
2010-05-21 14:56:27 -04:00
// Area 3, located in the footer. Empty by default.
2010-05-10 01:58:24 -04:00
register_sidebar ( array (
2010-05-04 03:01:09 -04:00
'name' => __ ( 'First Footer Widget Area' , 'twentyten' ),
2010-02-08 13:02:23 -05:00
'id' => 'first-footer-widget-area' ,
2010-05-04 03:01:09 -04:00
'description' => __ ( 'The first footer widget area' , 'twentyten' ),
2010-02-07 11:16:26 -05:00
'before_widget' => '<li id="%1$s" class="widget-container %2$s">' ,
2010-05-10 01:58:24 -04:00
'after_widget' => '</li>' ,
2010-02-07 11:16:26 -05:00
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
2010-02-08 13:02:23 -05:00
) );
2010-02-07 11:16:26 -05:00
2010-05-21 14:56:27 -04:00
// Area 4, located in the footer. Empty by default.
2010-05-10 01:58:24 -04:00
register_sidebar ( array (
2010-05-04 03:01:09 -04:00
'name' => __ ( 'Second Footer Widget Area' , 'twentyten' ),
2010-02-08 13:02:23 -05:00
'id' => 'second-footer-widget-area' ,
2010-05-04 03:01:09 -04:00
'description' => __ ( 'The second footer widget area' , 'twentyten' ),
2010-02-07 11:16:26 -05:00
'before_widget' => '<li id="%1$s" class="widget-container %2$s">' ,
2010-05-10 01:58:24 -04:00
'after_widget' => '</li>' ,
2010-02-07 11:16:26 -05:00
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
2010-02-08 13:02:23 -05:00
) );
2010-02-07 11:16:26 -05:00
2010-05-21 14:56:27 -04:00
// Area 5, located in the footer. Empty by default.
2010-05-10 01:58:24 -04:00
register_sidebar ( array (
2010-05-04 03:01:09 -04:00
'name' => __ ( 'Third Footer Widget Area' , 'twentyten' ),
2010-02-08 13:02:23 -05:00
'id' => 'third-footer-widget-area' ,
2010-05-04 03:01:09 -04:00
'description' => __ ( 'The third footer widget area' , 'twentyten' ),
2010-02-07 11:16:26 -05:00
'before_widget' => '<li id="%1$s" class="widget-container %2$s">' ,
2010-05-10 01:58:24 -04:00
'after_widget' => '</li>' ,
2010-02-07 11:16:26 -05:00
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
2010-02-08 13:02:23 -05:00
) );
2010-02-07 11:16:26 -05:00
2010-05-21 14:56:27 -04:00
// Area 6, located in the footer. Empty by default.
2010-05-10 01:58:24 -04:00
register_sidebar ( array (
2010-05-04 03:01:09 -04:00
'name' => __ ( 'Fourth Footer Widget Area' , 'twentyten' ),
2010-02-08 13:02:23 -05:00
'id' => 'fourth-footer-widget-area' ,
2010-05-04 03:01:09 -04:00
'description' => __ ( 'The fourth footer widget area' , 'twentyten' ),
2010-02-07 11:16:26 -05:00
'before_widget' => '<li id="%1$s" class="widget-container %2$s">' ,
2010-05-10 01:58:24 -04:00
'after_widget' => '</li>' ,
2010-02-07 11:16:26 -05:00
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
2010-02-08 13:02:23 -05:00
) );
2010-02-14 16:39:20 -05:00
}
2010-05-16 16:53:36 -04:00
/** Register sidebars by running twentyten_widgets_init() on the widgets_init hook. */
add_action ( 'widgets_init' , 'twentyten_widgets_init' );
2010-04-03 19:33:52 -04:00
/**
* Removes the default styles that are packaged with the Recent Comments widget .
2010-05-16 16:53:36 -04:00
*
* To override this in a child theme , remove the filter and optionally add your own
* function tied to the widgets_init action hook .
*
* @ since Twenty Ten 1.0
2010-04-03 19:33:52 -04:00
*/
function twentyten_remove_recent_comments_style () {
global $wp_widget_factory ;
remove_action ( 'wp_head' , array ( $wp_widget_factory -> widgets [ 'WP_Widget_Recent_Comments' ], 'recent_comments_style' ) );
}
add_action ( 'widgets_init' , 'twentyten_remove_recent_comments_style' );
2010-05-03 15:16:47 -04:00
2010-05-16 16:53:36 -04:00
if ( ! function_exists ( 'twentyten_posted_on' ) ) :
2010-05-03 15:16:47 -04:00
/**
2010-05-16 16:53:36 -04:00
* Prints HTML with meta information for the current post—date / time and author .
*
* @ since Twenty Ten 1.0
2010-05-10 15:06:22 -04:00
*/
function twentyten_posted_on () {
2010-05-16 16:53:36 -04:00
printf ( __ ( '<span %1$s>Posted on</span> %2$s by %3$s' , 'twentyten' ),
2010-05-10 15:06:22 -04:00
'class="meta-prep meta-prep-author"' ,
sprintf ( '<a href="%1$s" title="%2$s" rel="bookmark"><span class="entry-date">%3$s</span></a> <span class="meta-sep">' ,
get_permalink (),
esc_attr ( get_the_time () ),
get_the_date ()
),
2010-05-21 14:56:27 -04:00
sprintf ( '</span> <span class="author vcard"><a class="url fn n" href="%1$s" title="%2$s">%3$s</a></span>' ,
2010-05-10 15:06:22 -04:00
get_author_posts_url ( get_the_author_meta ( 'ID' ) ),
sprintf ( esc_attr__ ( 'View all posts by %s' , 'twentyten' ), get_the_author () ),
get_the_author ()
)
);
}
2010-05-16 16:53:36 -04:00
endif ;
2010-05-10 15:06:22 -04:00
2010-05-16 16:53:36 -04:00
if ( ! function_exists ( 'twentyten_posted_in' ) ) :
2010-05-10 15:06:22 -04:00
/**
2010-05-16 16:53:36 -04:00
* Prints HTML with meta information for the current post ( category , tags and permalink ) .
*
* @ since Twenty Ten 1.0
2010-05-10 15:06:22 -04:00
*/
function twentyten_posted_in () {
2010-05-16 16:53:36 -04:00
// Retrieves tag list of current post, separated by commas.
$tag_list = get_the_tag_list ( '' , ', ' );
2010-05-10 15:06:22 -04:00
if ( $tag_list ) {
2010-05-16 16:53:36 -04:00
$posted_in = __ ( 'This entry was posted in %1$s and tagged %2$s. Bookmark the <a href="%3$s" title="Permalink to %4$s" rel="bookmark">permalink</a>.' , 'twentyten' );
2010-05-26 16:06:54 -04:00
} elseif ( is_object_in_taxonomy ( get_post_type (), 'category' ) ) {
2010-05-16 16:53:36 -04:00
$posted_in = __ ( 'This entry was posted in %1$s. Bookmark the <a href="%3$s" title="Permalink to %4$s" rel="bookmark">permalink</a>.' , 'twentyten' );
2010-05-26 16:06:54 -04:00
} else {
$posted_in = __ ( 'Bookmark the <a href="%3$s" title="Permalink to %4$s" rel="bookmark">permalink</a>.' , 'twentyten' );
2010-05-10 15:06:22 -04:00
}
2010-05-16 16:53:36 -04:00
// Prints the string, replacing the placeholders.
printf (
$posted_in ,
2010-05-10 15:06:22 -04:00
get_the_category_list ( ', ' ),
$tag_list ,
get_permalink (),
2010-05-16 16:53:36 -04:00
the_title_attribute ( 'echo=0' )
2010-05-21 14:56:27 -04:00
);
2010-05-10 15:06:22 -04:00
}
2010-05-16 16:53:36 -04:00
endif ;