2010-02-07 17:16:26 +01:00
< ? php
2010-03-30 00:03:15 +02:00
/**
* TwentyTen functions and definitions
*
2010-03-30 02:05:17 +02: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 22:53:36 +02:00
* When using a child theme ( see http :// codex . wordpress . org / Theme_Development and
2010-05-17 08:52:47 +02:00
* http :// codex . wordpress . org / Child_Themes ), you can override certain functions
2010-05-16 22:53:36 +02: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-30 02:05:17 +02: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 14:55:08 +02:00
* remove_filter () and you can attach your own function to the hook .
*
2010-04-02 06:45:22 +02: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-30 02:05:17 +02:00
*
* < code >
* add_action ( 'after_setup_theme' , 'my_child_theme_setup' );
* function my_child_theme_setup () {
2010-03-30 14:55:08 +02:00
* // We are providing our own filter for excerpt_length (or using the unfiltered value)
* remove_filter ( 'excerpt_length' , 'twentyten_excerpt_length' );
* ...
2010-03-30 02:05:17 +02:00
* }
* </ code >
*
2010-05-21 20:56:27 +02:00
* For more information on hooks , actions , and filters , see http :// codex . wordpress . org / Plugin_API .
2010-03-30 00:03:15 +02:00
*
* @ package WordPress
2010-05-16 19:10:21 +02:00
* @ subpackage Twenty_Ten
2010-05-16 22:53:36 +02:00
* @ since Twenty Ten 1.0
2010-03-30 00:03:15 +02:00
*/
2010-02-07 17:16:26 +01:00
2010-03-30 00:03:15 +02:00
/**
2010-03-30 02:05:17 +02:00
* Set the content width based on the theme ' s design and stylesheet .
2010-03-30 00:03:15 +02:00
*
2010-03-30 02:05:17 +02: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-30 00:03:15 +02:00
*/
2010-02-14 22:39:20 +01:00
if ( ! isset ( $content_width ) )
2010-02-25 09:56:19 +01:00
$content_width = 640 ;
2010-02-14 22:39:20 +01:00
2010-03-30 02:05:17 +02: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 07:58:24 +02:00
if ( ! function_exists ( 'twentyten_setup' ) ) :
2010-03-30 00:03:15 +02:00
/**
2010-03-30 02:05:17 +02: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-02 02:54:48 +02:00
* To override twentyten_setup () in a child theme , add your own twentyten_setup to your child theme ' s
* functions . php file .
2010-03-30 00:03:15 +02:00
*
2012-03-20 22:32:42 +01:00
* @ uses add_theme_support () To add support for post thumbnails , custom headers and backgrounds , and automatic feed links .
2010-06-10 19:57:30 +02:00
* @ uses register_nav_menus () To add support for navigation menus .
2010-03-30 02:05:17 +02:00
* @ uses add_editor_style () To style the visual editor .
* @ uses load_theme_textdomain () For translation / localization support .
* @ 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-30 00:03:15 +02:00
*
2010-05-16 22:53:36 +02:00
* @ since Twenty Ten 1.0
2010-03-30 00:03:15 +02:00
*/
2010-03-30 02:05:17 +02:00
function twentyten_setup () {
2010-03-30 00:03:15 +02:00
// This theme styles the visual editor with editor-style.css to match the theme style.
add_editor_style ();
2010-11-05 03:25:41 +01:00
// Post Format support. You can also use the legacy "gallery" or "asides" (note the plural) categories.
add_theme_support ( 'post-formats' , array ( 'aside' , 'gallery' ) );
2010-11-04 08:41:07 +01:00
2010-03-30 02:05:17 +02:00
// This theme uses post thumbnails
2010-03-30 00:03:15 +02: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
2011-10-25 06:42:16 +02:00
load_theme_textdomain ( 'twentyten' , get_template_directory () . '/languages' );
2010-03-30 00:03:15 +02:00
2010-05-14 08:20:30 +02:00
// This theme uses wp_nav_menu() in one location.
register_nav_menus ( array (
2010-05-24 11:26:41 +02:00
'primary' => __ ( 'Primary Navigation' , 'twentyten' ),
2010-05-14 08:20:30 +02:00
) );
2012-03-20 22:32:42 +01:00
// This theme allows users to set a custom background.
2012-06-01 22:31:50 +02:00
add_theme_support ( 'custom-background' , array (
// Let WordPress know what our default background color is.
'default-color' => 'f1f1f1' ,
) );
2012-03-20 22:32:42 +01:00
// The custom header business starts here.
2012-06-04 16:43:19 +02:00
$custom_header_support = array (
2012-03-20 22:32:42 +01:00
// The default image to use.
// The %s is a placeholder for the theme template directory URI.
'default-image' => '%s/images/headers/path.jpg' ,
// The height and width of our custom header.
'width' => apply_filters ( 'twentyten_header_image_width' , 940 ),
'height' => apply_filters ( 'twentyten_header_image_height' , 198 ),
2012-04-15 22:51:24 +02:00
// Support flexible heights.
'flex-height' => true ,
2012-03-20 22:32:42 +01:00
// Don't support text inside the header image.
'header-text' => false ,
// Callback for styling the header preview in the admin.
2012-03-21 04:36:17 +01:00
'admin-head-callback' => 'twentyten_admin_header_style' ,
2012-06-04 16:43:19 +02:00
);
2012-08-09 19:22:44 +02:00
2012-06-04 16:43:19 +02:00
add_theme_support ( 'custom-header' , $custom_header_support );
2012-08-09 19:22:44 +02:00
2012-06-04 16:43:19 +02:00
if ( ! function_exists ( 'get_custom_header' ) ) {
// This is all for compatibility with versions of WordPress prior to 3.4.
define ( 'HEADER_TEXTCOLOR' , '' );
define ( 'NO_HEADER_TEXT' , true );
define ( 'HEADER_IMAGE' , $custom_header_support [ 'default-image' ] );
define ( 'HEADER_IMAGE_WIDTH' , $custom_header_support [ 'width' ] );
define ( 'HEADER_IMAGE_HEIGHT' , $custom_header_support [ 'height' ] );
add_custom_image_header ( '' , $custom_header_support [ 'admin-head-callback' ] );
add_custom_background ();
}
2010-03-30 00:03:15 +02:00
2010-03-30 02:05:17 +02:00
// We'll be using post thumbnails for custom header images on posts and pages.
2010-05-21 20:56:27 +02: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.
2012-06-04 16:43:19 +02:00
set_post_thumbnail_size ( $custom_header_support [ 'width' ], $custom_header_support [ 'height' ], true );
2010-02-14 22:39:20 +01:00
2012-03-20 22:32:42 +01:00
// ... and thus ends the custom header business.
2010-03-30 00:03:15 +02:00
2010-03-30 02:05:17 +02:00
// Default custom headers packaged with the theme. %s is a placeholder for the theme template directory URI.
2010-05-10 07:58:24 +02:00
register_default_headers ( array (
'berries' => array (
2010-03-16 21:17:22 +01:00
'url' => '%s/images/headers/berries.jpg' ,
'thumbnail_url' => '%s/images/headers/berries-thumbnail.jpg' ,
2010-05-10 07:58:24 +02:00
/* translators: header image description */
2010-03-17 00:11:30 +01:00
'description' => __ ( 'Berries' , 'twentyten' )
2010-03-16 21:17:22 +01:00
),
2010-05-10 07:58:24 +02:00
'cherryblossom' => array (
2010-03-16 21:17:22 +01:00
'url' => '%s/images/headers/cherryblossoms.jpg' ,
'thumbnail_url' => '%s/images/headers/cherryblossoms-thumbnail.jpg' ,
2010-05-21 20:56:27 +02:00
/* translators: header image description */
2010-03-17 00:11:30 +01:00
'description' => __ ( 'Cherry Blossoms' , 'twentyten' )
2010-03-16 21:17:22 +01:00
),
2010-05-10 07:58:24 +02:00
'concave' => array (
2010-03-16 21:17:22 +01:00
'url' => '%s/images/headers/concave.jpg' ,
'thumbnail_url' => '%s/images/headers/concave-thumbnail.jpg' ,
2010-05-21 20:56:27 +02:00
/* translators: header image description */
2010-03-17 00:11:30 +01:00
'description' => __ ( 'Concave' , 'twentyten' )
2010-03-16 21:17:22 +01:00
),
2010-05-10 07:58:24 +02:00
'fern' => array (
2010-03-16 21:17:22 +01:00
'url' => '%s/images/headers/fern.jpg' ,
'thumbnail_url' => '%s/images/headers/fern-thumbnail.jpg' ,
2010-05-21 20:56:27 +02:00
/* translators: header image description */
2010-03-17 00:11:30 +01:00
'description' => __ ( 'Fern' , 'twentyten' )
2010-03-16 21:17:22 +01:00
),
2010-05-10 07:58:24 +02:00
'forestfloor' => array (
2010-03-16 21:17:22 +01:00
'url' => '%s/images/headers/forestfloor.jpg' ,
'thumbnail_url' => '%s/images/headers/forestfloor-thumbnail.jpg' ,
2010-05-21 20:56:27 +02:00
/* translators: header image description */
2010-03-17 00:11:30 +01:00
'description' => __ ( 'Forest Floor' , 'twentyten' )
2010-03-16 21:17:22 +01:00
),
2010-05-10 07:58:24 +02:00
'inkwell' => array (
2010-03-16 21:17:22 +01:00
'url' => '%s/images/headers/inkwell.jpg' ,
'thumbnail_url' => '%s/images/headers/inkwell-thumbnail.jpg' ,
2010-05-21 20:56:27 +02:00
/* translators: header image description */
2010-03-17 00:11:30 +01:00
'description' => __ ( 'Inkwell' , 'twentyten' )
2010-03-16 21:17:22 +01:00
),
2010-05-10 07:58:24 +02:00
'path' => array (
2010-03-16 21:17:22 +01:00
'url' => '%s/images/headers/path.jpg' ,
'thumbnail_url' => '%s/images/headers/path-thumbnail.jpg' ,
2010-05-21 20:56:27 +02:00
/* translators: header image description */
2010-03-17 00:11:30 +01:00
'description' => __ ( 'Path' , 'twentyten' )
2010-03-16 21:17:22 +01:00
),
2010-05-10 07:58:24 +02:00
'sunset' => array (
2010-03-16 21:17:22 +01:00
'url' => '%s/images/headers/sunset.jpg' ,
'thumbnail_url' => '%s/images/headers/sunset-thumbnail.jpg' ,
2010-05-21 20:56:27 +02:00
/* translators: header image description */
2010-03-17 00:11:30 +01:00
'description' => __ ( 'Sunset' , 'twentyten' )
2010-03-16 21:17:22 +01:00
)
) );
2010-02-14 22:39:20 +01:00
}
2010-04-02 02:54:48 +02:00
endif ;
2010-02-07 17:16:26 +01:00
2010-02-14 22:39:20 +01:00
if ( ! function_exists ( 'twentyten_admin_header_style' ) ) :
2010-03-30 00:03:15 +02:00
/**
2010-03-30 02:05:17 +02:00
* Styles the header image displayed on the Appearance > Header admin panel .
*
* Referenced via add_custom_image_header () in twentyten_setup () .
*
2010-05-16 22:53:36 +02:00
* @ since Twenty Ten 1.0
2010-03-30 00:03:15 +02:00
*/
2010-02-07 17:16:26 +01:00
function twentyten_admin_header_style () {
?>
2013-04-29 23:02:53 +02:00
< style type = " text/css " id = " twentyten-admin-header-css " >
2010-05-26 00:05:51 +02:00
/* Shows the same border as on front end */
2010-02-07 17:16:26 +01:00
#headimg {
2010-06-10 20:26:53 +02:00
border - bottom : 1 px solid #000;
border - top : 4 px solid #000;
2010-02-07 17:16:26 +01:00
}
2012-03-20 22:32:42 +01:00
/* If header - text was supported , you would style the text with these selectors :
2010-06-10 20:26:53 +02:00
#headimg #name { }
#headimg #desc { }
*/
2010-02-07 17:16:26 +01:00
</ style >
< ? php
}
2010-02-14 22:39:20 +01:00
endif ;
2010-02-07 17:16:26 +01:00
2010-05-06 05:04:22 +02:00
/**
2010-05-07 20:11:58 +02:00
* Get our wp_nav_menu () fallback , wp_page_menu (), to show a home link .
2010-05-16 22:53:36 +02: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-06 05:04:22 +02:00
*/
2010-05-16 22:53:36 +02:00
function twentyten_page_menu_args ( $args ) {
2012-11-02 17:52:53 +01:00
if ( ! isset ( $args [ 'show_home' ] ) )
$args [ 'show_home' ] = true ;
2010-05-06 05:04:22 +02:00
return $args ;
}
2010-05-16 22:53:36 +02:00
add_filter ( 'wp_page_menu_args' , 'twentyten_page_menu_args' );
2010-05-06 05:04:22 +02:00
2010-03-30 00:03:15 +02:00
/**
2010-03-30 02:05:17 +02: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-30 00:03:15 +02:00
*
2010-05-16 22:53:36 +02:00
* @ since Twenty Ten 1.0
2010-03-30 00:03:15 +02:00
* @ return int
*/
2010-02-14 22:39:20 +01:00
function twentyten_excerpt_length ( $length ) {
2010-02-07 17:16:26 +01:00
return 40 ;
}
2010-02-14 22:39:20 +01:00
add_filter ( 'excerpt_length' , 'twentyten_excerpt_length' );
2010-02-07 17:16:26 +01:00
2012-08-09 20:21:58 +02:00
if ( ! function_exists ( 'twentyten_continue_reading_link' ) ) :
2010-03-30 00:03:15 +02:00
/**
2010-05-28 19:01:27 +02: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>' ;
}
2012-08-09 20:21:58 +02:00
endif ;
2010-05-28 19:01:27 +02:00
/**
* Replaces " [...] " ( appended to automatically generated excerpts ) with an ellipsis and twentyten_continue_reading_link () .
2010-03-30 00:03:15 +02:00
*
2010-05-25 18:08:44 +02:00
* To override this in a child theme , remove the filter and add your own
2010-03-30 02:05:17 +02:00
* function tied to the excerpt_more filter hook .
2010-03-30 00:03:15 +02:00
*
2010-05-16 22:53:36 +02:00
* @ since Twenty Ten 1.0
2010-05-25 18:08:44 +02:00
* @ return string An ellipsis
*/
function twentyten_auto_excerpt_more ( $more ) {
2010-05-28 19:01:27 +02:00
return ' …' . twentyten_continue_reading_link ();
2010-05-25 18:08:44 +02:00
}
add_filter ( 'excerpt_more' , 'twentyten_auto_excerpt_more' );
/**
2010-05-28 19:01:27 +02:00
* Adds a pretty " Continue Reading " link to custom post excerpts .
2010-05-25 18:08:44 +02: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-30 00:03:15 +02:00
*/
2010-05-25 18:08:44 +02:00
function twentyten_custom_excerpt_more ( $output ) {
2010-06-03 00:41:14 +02:00
if ( has_excerpt () && ! is_attachment () ) {
2010-05-28 19:01:27 +02:00
$output .= twentyten_continue_reading_link ();
}
return $output ;
2010-02-07 17:16:26 +01:00
}
2010-05-25 18:08:44 +02:00
add_filter ( 'get_the_excerpt' , 'twentyten_custom_excerpt_more' );
2010-02-07 17:16:26 +01:00
2010-03-30 02:05:17 +02:00
/**
* Remove inline styles printed when the gallery shortcode is used .
*
2010-12-10 20:27:12 +01:00
* Galleries are styled by the theme in Twenty Ten ' s style . css . This is just
* a simple filter call that tells WordPress to not use the default styles .
*
2011-01-03 23:47:05 +01:00
* @ since Twenty Ten 1.2
2010-12-10 20:27:12 +01:00
*/
add_filter ( 'use_default_gallery_style' , '__return_false' );
/**
* Deprecated way to remove inline styles printed when the gallery shortcode is used .
*
* This function is no longer needed or used . Use the use_default_gallery_style
* filter instead , as seen above .
2010-03-30 02:05:17 +02:00
*
2010-05-16 22:53:36 +02:00
* @ since Twenty Ten 1.0
2011-01-03 23:47:05 +01:00
* @ deprecated Deprecated in Twenty Ten 1.2 for WordPress 3.1
2010-12-10 20:27:12 +01:00
*
2010-03-30 02:05:17 +02: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 );
}
2011-02-22 09:23:30 +01:00
// Backwards compatibility with WordPress 3.0.
if ( version_compare ( $GLOBALS [ 'wp_version' ], '3.1' , '<' ) )
add_filter ( 'gallery_style' , 'twentyten_remove_gallery_css' );
2010-03-30 02:05:17 +02:00
2010-02-14 22:39:20 +01:00
if ( ! function_exists ( 'twentyten_comment' ) ) :
2010-03-30 00:03:15 +02:00
/**
2010-03-30 02:05:17 +02:00
* Template for comments and pingbacks .
2010-03-30 00:03:15 +02:00
*
2010-03-30 02:05:17 +02: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-30 00:03:15 +02:00
*
2010-03-30 02:05:17 +02:00
* Used as a callback by wp_list_comments () for displaying the comments .
*
2010-05-16 22:53:36 +02:00
* @ since Twenty Ten 1.0
2010-03-30 00:03:15 +02:00
*/
2010-02-14 22:39:20 +01:00
function twentyten_comment ( $comment , $args , $depth ) {
2010-06-11 05:34:52 +02:00
$GLOBALS [ 'comment' ] = $comment ;
switch ( $comment -> comment_type ) :
case '' :
?>
2010-02-14 02:00:22 +01:00
< li < ? php comment_class (); ?> id="li-comment-<?php comment_ID(); ?>">
2010-02-07 17:16:26 +01:00
< div id = " comment-<?php comment_ID(); ?> " >
2012-08-09 19:22:44 +02:00
< div class = " comment-author vcard " >
< ? php echo get_avatar ( $comment , 40 ); ?>
< ? php printf ( __ ( '%s <span class="says">says:</span>' , 'twentyten' ), sprintf ( '<cite class="fn">%s</cite>' , get_comment_author_link () ) ); ?>
</ div ><!-- . comment - author . vcard -->
< ? php if ( $comment -> comment_approved == '0' ) : ?>
< em class = " comment-awaiting-moderation " >< ? php _e ( 'Your comment is awaiting moderation.' , 'twentyten' ); ?> </em>
< br />
< ? php endif ; ?>
2010-02-07 17:16:26 +01:00
2012-08-09 19:22:44 +02: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' ), ' ' );
?>
</ div ><!-- . comment - meta . commentmetadata -->
2010-02-07 17:16:26 +01:00
2012-08-09 19:22:44 +02:00
< div class = " comment-body " >< ? php comment_text (); ?> </div>
2010-02-07 17:16:26 +01:00
2012-08-09 19:22:44 +02:00
< div class = " reply " >
< ? php comment_reply_link ( array_merge ( $args , array ( 'depth' => $depth , 'max_depth' => $args [ 'max_depth' ] ) ) ); ?>
</ div ><!-- . reply -->
</ div ><!-- #comment-## -->
2010-02-07 17:16:26 +01:00
2010-06-11 05:34:52 +02:00
< ? php
break ;
case 'pingback' :
case 'trackback' :
?>
2010-02-07 17:16:26 +01:00
< li class = " post pingback " >
2010-11-19 06:37:47 +01:00
< p >< ? php _e ( 'Pingback:' , 'twentyten' ); ?> <?php comment_author_link(); ?><?php edit_comment_link( __( '(Edit)', 'twentyten' ), ' ' ); ?></p>
2010-06-11 05:34:52 +02:00
< ? php
break ;
endswitch ;
2010-02-07 17:16:26 +01:00
}
2010-02-14 22:39:20 +01:00
endif ;
2010-02-07 17:16:26 +01:00
2010-03-30 00:03:15 +02:00
/**
2010-03-30 02:05:17 +02:00
* Register widgetized areas , including two sidebars and four widget - ready columns in the footer .
2010-03-30 00:03:15 +02:00
*
2010-03-30 02:05:17 +02: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 22:53:36 +02:00
*
* @ since Twenty Ten 1.0
2010-03-30 00:03:15 +02:00
* @ uses register_sidebar
*/
2010-02-14 02:00:22 +01:00
function twentyten_widgets_init () {
2010-05-21 20:56:27 +02:00
// Area 1, located at the top of the sidebar.
2010-05-10 07:58:24 +02:00
register_sidebar ( array (
2010-05-04 09:01:09 +02:00
'name' => __ ( 'Primary Widget Area' , 'twentyten' ),
2010-02-07 17:16:26 +01:00
'id' => 'primary-widget-area' ,
2013-02-22 18:32:48 +01:00
'description' => __ ( 'Add widgets here to appear in your sidebar.' , 'twentyten' ),
2010-02-07 17:16:26 +01:00
'before_widget' => '<li id="%1$s" class="widget-container %2$s">' ,
2010-05-10 07:58:24 +02:00
'after_widget' => '</li>' ,
2010-02-07 17:16:26 +01:00
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
) );
2010-02-08 19:02:23 +01:00
2010-05-21 20:56:27 +02:00
// Area 2, located below the Primary Widget Area in the sidebar. Empty by default.
2010-05-10 07:58:24 +02:00
register_sidebar ( array (
2010-05-04 09:01:09 +02:00
'name' => __ ( 'Secondary Widget Area' , 'twentyten' ),
2010-02-08 19:02:23 +01:00
'id' => 'secondary-widget-area' ,
2013-02-22 18:32:48 +01:00
'description' => __ ( 'An optional secondary widget area, displays below the primary widget area in your sidebar.' , 'twentyten' ),
2010-02-07 17:16:26 +01:00
'before_widget' => '<li id="%1$s" class="widget-container %2$s">' ,
2010-05-10 07:58:24 +02:00
'after_widget' => '</li>' ,
2010-02-07 17:16:26 +01:00
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
) );
2010-02-08 19:02:23 +01:00
2010-05-21 20:56:27 +02:00
// Area 3, located in the footer. Empty by default.
2010-05-10 07:58:24 +02:00
register_sidebar ( array (
2010-05-04 09:01:09 +02:00
'name' => __ ( 'First Footer Widget Area' , 'twentyten' ),
2010-02-08 19:02:23 +01:00
'id' => 'first-footer-widget-area' ,
2013-02-22 18:32:48 +01:00
'description' => __ ( 'An optional widget area for your site footer.' , 'twentyten' ),
2010-02-07 17:16:26 +01:00
'before_widget' => '<li id="%1$s" class="widget-container %2$s">' ,
2010-05-10 07:58:24 +02:00
'after_widget' => '</li>' ,
2010-02-07 17:16:26 +01:00
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
2010-02-08 19:02:23 +01:00
) );
2010-02-07 17:16:26 +01:00
2010-05-21 20:56:27 +02:00
// Area 4, located in the footer. Empty by default.
2010-05-10 07:58:24 +02:00
register_sidebar ( array (
2010-05-04 09:01:09 +02:00
'name' => __ ( 'Second Footer Widget Area' , 'twentyten' ),
2010-02-08 19:02:23 +01:00
'id' => 'second-footer-widget-area' ,
2013-02-22 18:32:48 +01:00
'description' => __ ( 'An optional widget area for your site footer.' , 'twentyten' ),
2010-02-07 17:16:26 +01:00
'before_widget' => '<li id="%1$s" class="widget-container %2$s">' ,
2010-05-10 07:58:24 +02:00
'after_widget' => '</li>' ,
2010-02-07 17:16:26 +01:00
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
2010-02-08 19:02:23 +01:00
) );
2010-02-07 17:16:26 +01:00
2010-05-21 20:56:27 +02:00
// Area 5, located in the footer. Empty by default.
2010-05-10 07:58:24 +02:00
register_sidebar ( array (
2010-05-04 09:01:09 +02:00
'name' => __ ( 'Third Footer Widget Area' , 'twentyten' ),
2010-02-08 19:02:23 +01:00
'id' => 'third-footer-widget-area' ,
2013-02-22 18:32:48 +01:00
'description' => __ ( 'An optional widget area for your site footer.' , 'twentyten' ),
2010-02-07 17:16:26 +01:00
'before_widget' => '<li id="%1$s" class="widget-container %2$s">' ,
2010-05-10 07:58:24 +02:00
'after_widget' => '</li>' ,
2010-02-07 17:16:26 +01:00
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
2010-02-08 19:02:23 +01:00
) );
2010-02-07 17:16:26 +01:00
2010-05-21 20:56:27 +02:00
// Area 6, located in the footer. Empty by default.
2010-05-10 07:58:24 +02:00
register_sidebar ( array (
2010-05-04 09:01:09 +02:00
'name' => __ ( 'Fourth Footer Widget Area' , 'twentyten' ),
2010-02-08 19:02:23 +01:00
'id' => 'fourth-footer-widget-area' ,
2013-02-22 18:32:48 +01:00
'description' => __ ( 'An optional widget area for your site footer.' , 'twentyten' ),
2010-02-07 17:16:26 +01:00
'before_widget' => '<li id="%1$s" class="widget-container %2$s">' ,
2010-05-10 07:58:24 +02:00
'after_widget' => '</li>' ,
2010-02-07 17:16:26 +01:00
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
2010-02-08 19:02:23 +01:00
) );
2010-02-14 22:39:20 +01:00
}
2010-05-16 22:53:36 +02:00
/** Register sidebars by running twentyten_widgets_init() on the widgets_init hook. */
add_action ( 'widgets_init' , 'twentyten_widgets_init' );
2010-04-04 01:33:52 +02:00
/**
* Removes the default styles that are packaged with the Recent Comments widget .
2010-05-16 22:53:36 +02:00
*
* To override this in a child theme , remove the filter and optionally add your own
* function tied to the widgets_init action hook .
*
2011-02-22 09:23:30 +01:00
* This function uses a filter ( show_recent_comments_widget_style ) new in WordPress 3.1
* to remove the default style . Using Twenty Ten 1.2 in WordPress 3.0 will show the styles ,
* but they won ' t have any effect on the widget in default Twenty Ten styling .
*
2010-05-16 22:53:36 +02:00
* @ since Twenty Ten 1.0
2010-04-04 01:33:52 +02:00
*/
function twentyten_remove_recent_comments_style () {
2010-11-21 14:55:11 +01:00
add_filter ( 'show_recent_comments_widget_style' , '__return_false' );
2010-04-04 01:33:52 +02:00
}
add_action ( 'widgets_init' , 'twentyten_remove_recent_comments_style' );
2010-05-03 21:16:47 +02:00
2010-05-16 22:53:36 +02:00
if ( ! function_exists ( 'twentyten_posted_on' ) ) :
2010-05-03 21:16:47 +02:00
/**
2010-10-27 11:54:17 +02:00
* Prints HTML with meta information for the current post - date / time and author .
2010-05-16 22:53:36 +02:00
*
* @ since Twenty Ten 1.0
2010-05-10 21:06:22 +02:00
*/
function twentyten_posted_on () {
2010-06-11 18:15:25 +02:00
printf ( __ ( '<span class="%1$s">Posted on</span> %2$s <span class="meta-sep">by</span> %3$s' , 'twentyten' ),
'meta-prep meta-prep-author' ,
sprintf ( '<a href="%1$s" title="%2$s" rel="bookmark"><span class="entry-date">%3$s</span></a>' ,
2010-05-10 21:06:22 +02:00
get_permalink (),
esc_attr ( get_the_time () ),
get_the_date ()
),
2010-06-11 18:15:25 +02:00
sprintf ( '<span class="author vcard"><a class="url fn n" href="%1$s" title="%2$s">%3$s</a></span>' ,
2010-05-10 21:06:22 +02:00
get_author_posts_url ( get_the_author_meta ( 'ID' ) ),
2011-12-10 20:18:51 +01:00
esc_attr ( sprintf ( __ ( 'View all posts by %s' , 'twentyten' ), get_the_author () ) ),
2010-05-10 21:06:22 +02:00
get_the_author ()
)
);
}
2010-05-16 22:53:36 +02:00
endif ;
2010-05-10 21:06:22 +02:00
2010-05-16 22:53:36 +02:00
if ( ! function_exists ( 'twentyten_posted_in' ) ) :
2010-05-10 21:06:22 +02:00
/**
2010-05-16 22:53:36 +02:00
* Prints HTML with meta information for the current post ( category , tags and permalink ) .
*
* @ since Twenty Ten 1.0
2010-05-10 21:06:22 +02:00
*/
function twentyten_posted_in () {
2010-05-16 22:53:36 +02:00
// Retrieves tag list of current post, separated by commas.
$tag_list = get_the_tag_list ( '' , ', ' );
2010-05-10 21:06:22 +02:00
if ( $tag_list ) {
2010-05-16 22:53:36 +02: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 22:06:54 +02:00
} elseif ( is_object_in_taxonomy ( get_post_type (), 'category' ) ) {
2010-05-16 22:53:36 +02: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 22:06:54 +02:00
} else {
$posted_in = __ ( 'Bookmark the <a href="%3$s" title="Permalink to %4$s" rel="bookmark">permalink</a>.' , 'twentyten' );
2010-05-10 21:06:22 +02:00
}
2010-05-16 22:53:36 +02:00
// Prints the string, replacing the placeholders.
printf (
$posted_in ,
2010-05-10 21:06:22 +02:00
get_the_category_list ( ', ' ),
$tag_list ,
get_permalink (),
2010-05-16 22:53:36 +02:00
the_title_attribute ( 'echo=0' )
2010-05-21 20:56:27 +02:00
);
2010-05-10 21:06:22 +02:00
}
2010-05-16 22:53:36 +02:00
endif ;
2013-03-27 21:37:34 +01:00
/**
* Retrieves the IDs for images in a gallery .
*
* @ uses get_post_galleries () first , if available . Falls back to shortcode parsing ,
* then as last option uses a get_posts () call .
*
* @ since Twenty Ten 1.6 .
*
* @ return array List of image IDs from the post gallery .
*/
function twentyten_get_gallery_images () {
$images = array ();
if ( function_exists ( 'get_post_gallery_images' ) ) {
$galleries = get_post_galleries ();
if ( isset ( $galleries [ 0 ][ 'ids' ] ) )
$images = explode ( ',' , $galleries [ 0 ][ 'ids' ] );
} else {
$pattern = get_shortcode_regex ();
preg_match ( " / $pattern /s " , get_the_content (), $match );
$atts = shortcode_parse_atts ( $match [ 3 ] );
if ( isset ( $atts [ 'ids' ] ) )
$images = explode ( ',' , $atts [ 'ids' ] );
}
if ( ! $images ) {
$images = get_posts ( array (
'fields' => 'ids' ,
'numberposts' => 999 ,
'order' => 'ASC' ,
'orderby' => 'menu_order' ,
'post_mime_type' => 'image' ,
'post_parent' => get_the_ID (),
'post_type' => 'attachment' ,
) );
}
return $images ;
}