2011-04-20 17:46:33 -04:00
< ? php
/**
2011-04-26 18:52:18 -04:00
* Twenty Eleven functions and definitions
*
* 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 , twentyeleven_setup (), sets up the theme by registering support
* for various features in WordPress , such as post thumbnails , navigation menus , and the like .
*
2019-04-01 07:56:52 -04:00
* When using a child theme you can override certain functions ( 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 .
*
2019-07-25 18:46:55 -04:00
* @ link https :// developer . wordpress . org / themes / basics / theme - functions /
2019-04-01 07:56:52 -04:00
* @ link https :// developer . wordpress . org / themes / advanced - topics / child - themes /
2011-04-26 18:52:18 -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
* remove_filter () and you can attach your own function to the hook .
*
* 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 :
*
* < code >
* add_action ( 'after_setup_theme' , 'my_child_theme_setup' );
* function my_child_theme_setup () {
* // We are providing our own filter for excerpt_length (or using the unfiltered value)
* remove_filter ( 'excerpt_length' , 'twentyeleven_excerpt_length' );
* ...
* }
* </ code >
*
2019-07-25 18:46:55 -04:00
* For more information on hooks , actions , and filters , see https :// developer . wordpress . org / plugins /.
2011-04-26 18:52:18 -04:00
*
2011-04-20 17:46:33 -04:00
* @ package WordPress
2011-05-18 15:06:09 -04:00
* @ subpackage Twenty_Eleven
2011-04-26 18:52:18 -04:00
* @ since Twenty Eleven 1.0
2011-04-20 17:46:33 -04:00
*/
2013-10-09 16:39:09 -04:00
// Set the content width based on the theme's design and stylesheet.
2017-11-30 18:11:00 -05:00
if ( ! isset ( $content_width ) ) {
2011-04-20 17:46:33 -04:00
$content_width = 584 ;
2017-11-30 18:11:00 -05:00
}
2011-04-20 17:46:33 -04:00
2013-10-09 16:39:09 -04:00
/*
2011-04-26 18:52:18 -04:00
* Tell WordPress to run twentyeleven_setup () when the 'after_setup_theme' hook is run .
2011-04-20 17:46:33 -04:00
*/
2011-04-26 18:52:18 -04:00
add_action ( 'after_setup_theme' , 'twentyeleven_setup' );
2011-04-20 17:46:33 -04:00
2017-11-30 18:11:00 -05:00
if ( ! function_exists ( 'twentyeleven_setup' ) ) :
/**
* Set 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 .
*
* To override twentyeleven_setup () in a child theme , add your own twentyeleven_setup to your child theme ' s
* functions . php file .
*
* @ uses load_theme_textdomain () For translation / localization support .
* @ uses add_editor_style () To style the visual editor .
* @ uses add_theme_support () To add support for post thumbnails , automatic feed links , custom headers
* and backgrounds , and post formats .
* @ uses register_nav_menus () To add support for navigation menus .
* @ 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 .
*
* @ since Twenty Eleven 1.0
2011-04-26 18:52:18 -04:00
*/
2017-11-30 18:11:00 -05:00
function twentyeleven_setup () {
/*
* Make Twenty Eleven available for translation .
* Translations can be added to the / languages / directory .
* If you ' re building a theme based on Twenty Eleven , use
* a find and replace to change 'twentyeleven' to the name
* of your theme in all the template files .
*/
load_theme_textdomain ( 'twentyeleven' , get_template_directory () . '/languages' );
2011-04-26 18:52:18 -04:00
2017-11-30 18:11:00 -05:00
// This theme styles the visual editor with editor-style.css to match the theme style.
add_editor_style ();
2011-05-05 18:46:37 -04:00
2018-12-13 20:51:38 -05:00
// Load regular editor styles into the new block-based editor.
add_theme_support ( 'editor-styles' );
// Load default block styles.
add_theme_support ( 'wp-block-styles' );
2018-12-16 22:07:04 -05:00
// Add support for responsive embeds.
add_theme_support ( 'responsive-embeds' );
2018-12-13 20:51:38 -05:00
// Add support for custom color scheme.
add_theme_support (
'editor-color-palette' ,
array (
array (
'name' => __ ( 'Blue' , 'twentyeleven' ),
'slug' => 'blue' ,
'color' => '#1982d1' ,
),
array (
'name' => __ ( 'Black' , 'twentyeleven' ),
'slug' => 'black' ,
'color' => '#000' ,
),
array (
'name' => __ ( 'Dark Gray' , 'twentyeleven' ),
'slug' => 'dark-gray' ,
'color' => '#373737' ,
),
array (
'name' => __ ( 'Medium Gray' , 'twentyeleven' ),
'slug' => 'medium-gray' ,
'color' => '#666' ,
),
array (
'name' => __ ( 'Light Gray' , 'twentyeleven' ),
'slug' => 'light-gray' ,
'color' => '#e2e2e2' ,
),
array (
'name' => __ ( 'White' , 'twentyeleven' ),
'slug' => 'white' ,
'color' => '#fff' ,
),
)
);
2017-11-30 18:11:00 -05:00
// Load up our theme options page and related code.
require ( get_template_directory () . '/inc/theme-options.php' );
2011-04-26 18:52:18 -04:00
2017-11-30 18:11:00 -05:00
// Grab Twenty Eleven's Ephemera widget.
require ( get_template_directory () . '/inc/widgets.php' );
2011-04-26 18:52:18 -04:00
2017-11-30 18:11:00 -05:00
// Add default posts and comments RSS feed links to <head>.
add_theme_support ( 'automatic-feed-links' );
2011-04-26 18:52:18 -04:00
2017-11-30 18:11:00 -05:00
// This theme uses wp_nav_menu() in one location.
register_nav_menu ( 'primary' , __ ( 'Primary Menu' , 'twentyeleven' ) );
2011-04-20 17:46:33 -04:00
2017-11-30 18:11:00 -05:00
// Add support for a variety of post formats
add_theme_support ( 'post-formats' , array ( 'aside' , 'link' , 'gallery' , 'status' , 'quote' , 'image' ) );
2011-04-20 17:46:33 -04:00
2017-11-30 18:11:00 -05:00
$theme_options = twentyeleven_get_theme_options ();
if ( 'dark' == $theme_options [ 'color_scheme' ] ) {
$default_background_color = '1d1d1d' ;
} else {
$default_background_color = 'e2e2e2' ;
}
// Add support for custom backgrounds.
add_theme_support (
2018-08-16 21:51:36 -04:00
'custom-background' ,
array (
2017-11-30 18:11:00 -05:00
/*
* Let WordPress know what our default background color is .
* This is dependent on our current color scheme .
*/
'default-color' => $default_background_color ,
)
);
// This theme uses Featured Images (also known as post thumbnails) for per-post/per-page Custom Header images
add_theme_support ( 'post-thumbnails' );
// Add support for custom headers.
$custom_header_support = array (
// The default header text color.
'default-text-color' => '000' ,
// The height and width of our custom header.
/**
* Filter the Twenty Eleven default header image width .
*
* @ since Twenty Eleven 1.0
*
* @ param int The default header image width in pixels . Default 1000.
*/
'width' => apply_filters ( 'twentyeleven_header_image_width' , 1000 ),
/**
* Filter the Twenty Eleven default header image height .
*
* @ since Twenty Eleven 1.0
*
* @ param int The default header image height in pixels . Default 288.
*/
2019-07-05 01:21:56 -04:00
'height' => apply_filters ( 'twentyeleven_header_image_height' , 288 ),
2017-11-30 18:11:00 -05:00
// Support flexible heights.
'flex-height' => true ,
// Random image rotation by default.
'random-default' => true ,
// Callback for styling the header.
'wp-head-callback' => 'twentyeleven_header_style' ,
// Callback for styling the header preview in the admin.
'admin-head-callback' => 'twentyeleven_admin_header_style' ,
// Callback used to display the header preview in the admin.
'admin-preview-callback' => 'twentyeleven_admin_header_image' ,
);
add_theme_support ( 'custom-header' , $custom_header_support );
if ( ! function_exists ( 'get_custom_header' ) ) {
// This is all for compatibility with versions of WordPress prior to 3.4.
define ( 'HEADER_TEXTCOLOR' , $custom_header_support [ 'default-text-color' ] );
define ( 'HEADER_IMAGE' , '' );
define ( 'HEADER_IMAGE_WIDTH' , $custom_header_support [ 'width' ] );
define ( 'HEADER_IMAGE_HEIGHT' , $custom_header_support [ 'height' ] );
add_custom_image_header ( $custom_header_support [ 'wp-head-callback' ], $custom_header_support [ 'admin-head-callback' ], $custom_header_support [ 'admin-preview-callback' ] );
add_custom_background ();
}
2012-06-01 16:31:50 -04:00
2013-10-09 16:39:09 -04:00
/*
2017-11-30 18:11:00 -05:00
* We ' ll be using post thumbnails for custom header images on posts and pages .
* We want them to be the size of the header image that we just defined .
* Larger images will be auto - cropped to fit , smaller ones will be ignored . See header . php .
2013-09-25 12:50:11 -04:00
*/
2017-11-30 18:11:00 -05:00
set_post_thumbnail_size ( $custom_header_support [ 'width' ], $custom_header_support [ 'height' ], true );
2012-06-04 10:43:19 -04:00
2017-11-30 18:11:00 -05:00
/*
* Add Twenty Eleven ' s custom image sizes .
* Used for large feature ( header ) images .
*/
add_image_size ( 'large-feature' , $custom_header_support [ 'width' ], $custom_header_support [ 'height' ], true );
// Used for featured posts if a large-feature doesn't exist.
add_image_size ( 'small-feature' , 500 , 300 );
// Default custom headers packaged with the theme. %s is a placeholder for the theme template directory URI.
register_default_headers (
array (
'wheel' => array (
'url' => '%s/images/headers/wheel.jpg' ,
'thumbnail_url' => '%s/images/headers/wheel-thumbnail.jpg' ,
2019-09-02 20:41:05 -04:00
/* translators: Header image description. */
2017-11-30 18:11:00 -05:00
'description' => __ ( 'Wheel' , 'twentyeleven' ),
),
'shore' => array (
'url' => '%s/images/headers/shore.jpg' ,
'thumbnail_url' => '%s/images/headers/shore-thumbnail.jpg' ,
2019-09-02 20:41:05 -04:00
/* translators: Header image description. */
2017-11-30 18:11:00 -05:00
'description' => __ ( 'Shore' , 'twentyeleven' ),
),
'trolley' => array (
'url' => '%s/images/headers/trolley.jpg' ,
'thumbnail_url' => '%s/images/headers/trolley-thumbnail.jpg' ,
2019-09-02 20:41:05 -04:00
/* translators: Header image description. */
2017-11-30 18:11:00 -05:00
'description' => __ ( 'Trolley' , 'twentyeleven' ),
),
'pine-cone' => array (
'url' => '%s/images/headers/pine-cone.jpg' ,
'thumbnail_url' => '%s/images/headers/pine-cone-thumbnail.jpg' ,
2019-09-02 20:41:05 -04:00
/* translators: Header image description. */
2017-11-30 18:11:00 -05:00
'description' => __ ( 'Pine Cone' , 'twentyeleven' ),
),
'chessboard' => array (
'url' => '%s/images/headers/chessboard.jpg' ,
'thumbnail_url' => '%s/images/headers/chessboard-thumbnail.jpg' ,
2019-09-02 20:41:05 -04:00
/* translators: Header image description. */
2017-11-30 18:11:00 -05:00
'description' => __ ( 'Chessboard' , 'twentyeleven' ),
),
'lanterns' => array (
'url' => '%s/images/headers/lanterns.jpg' ,
'thumbnail_url' => '%s/images/headers/lanterns-thumbnail.jpg' ,
2019-09-02 20:41:05 -04:00
/* translators: Header image description. */
2017-11-30 18:11:00 -05:00
'description' => __ ( 'Lanterns' , 'twentyeleven' ),
),
'willow' => array (
'url' => '%s/images/headers/willow.jpg' ,
'thumbnail_url' => '%s/images/headers/willow-thumbnail.jpg' ,
2019-09-02 20:41:05 -04:00
/* translators: Header image description. */
2017-11-30 18:11:00 -05:00
'description' => __ ( 'Willow' , 'twentyeleven' ),
),
'hanoi' => array (
'url' => '%s/images/headers/hanoi.jpg' ,
'thumbnail_url' => '%s/images/headers/hanoi-thumbnail.jpg' ,
2019-09-02 20:41:05 -04:00
/* translators: Header image description. */
2017-11-30 18:11:00 -05:00
'description' => __ ( 'Hanoi Plant' , 'twentyeleven' ),
),
)
);
// Indicate widget sidebars can use selective refresh in the Customizer.
add_theme_support ( 'customize-selective-refresh-widgets' );
2012-06-04 10:43:19 -04:00
}
2011-04-26 18:52:18 -04:00
endif ; // twentyeleven_setup
2011-04-20 17:46:33 -04:00
2018-12-13 20:51:38 -05:00
/**
* Enqueue scripts and styles for front end .
*
* @ since Twenty Eleven 2.9
*/
function twentyeleven_scripts_styles () {
// Theme block stylesheet.
2019-08-07 21:25:58 -04:00
wp_enqueue_style ( 'twentyeleven-block-style' , get_template_directory_uri () . '/blocks.css' , array (), '20190102' );
2018-12-13 20:51:38 -05:00
}
add_action ( 'wp_enqueue_scripts' , 'twentyeleven_scripts_styles' );
/**
2018-12-18 22:30:41 -05:00
* Enqueue styles for the block - based editor .
2018-12-13 20:51:38 -05:00
*
* @ since Twenty Eleven 2.9
*/
function twentyeleven_block_editor_styles () {
// Block styles.
2019-08-07 21:25:58 -04:00
wp_enqueue_style ( 'twentyeleven-block-editor-style' , get_template_directory_uri () . '/editor-blocks.css' , array (), '20190102' );
2018-12-13 20:51:38 -05:00
}
add_action ( 'enqueue_block_editor_assets' , 'twentyeleven_block_editor_styles' );
2011-04-20 17:46:33 -04:00
if ( ! function_exists ( 'twentyeleven_header_style' ) ) :
2017-11-30 18:11:00 -05:00
/**
* Styles the header image and text displayed on the blog .
*
* @ since Twenty Eleven 1.0
*/
function twentyeleven_header_style () {
$text_color = get_header_textcolor ();
2011-04-26 18:52:18 -04:00
2017-11-30 18:11:00 -05:00
// If no custom options for text are set, let's bail.
if ( $text_color == HEADER_TEXTCOLOR ) {
return ;
}
2012-08-09 13:32:39 -04:00
2017-11-30 18:11:00 -05:00
// If we get this far, we have custom styles. Let's do this.
?>
< style type = " text/css " id = " twentyeleven-header-css " >
< ? php
2011-04-20 17:46:33 -04:00
// Has the text been hidden?
2012-03-20 16:37:53 -04:00
if ( 'blank' == $text_color ) :
2018-08-16 21:51:36 -04:00
?>
2011-04-20 17:46:33 -04:00
#site-title,
#site-description {
2015-04-01 17:42:27 -04:00
position : absolute ;
2011-04-20 17:46:33 -04:00
clip : rect ( 1 px 1 px 1 px 1 px ); /* IE6, IE7 */
clip : rect ( 1 px , 1 px , 1 px , 1 px );
}
2018-08-16 21:51:36 -04:00
< ? php
// If the user has set a custom color for the text use that
2011-04-20 17:46:33 -04:00
else :
2018-08-16 21:51:36 -04:00
?>
2011-04-20 17:46:33 -04:00
#site-title a,
#site-description {
2015-04-01 17:42:27 -04:00
color : #<?php echo $text_color; ?>;
2011-04-20 17:46:33 -04:00
}
< ? php endif ; ?>
</ style >
2018-08-16 21:51:36 -04:00
< ? php
2017-11-30 18:11:00 -05:00
}
2011-04-26 18:52:18 -04:00
endif ; // twentyeleven_header_style
2011-04-20 17:46:33 -04:00
if ( ! function_exists ( 'twentyeleven_admin_header_style' ) ) :
2017-11-30 18:11:00 -05:00
/**
* Styles the header image displayed on the Appearance > Header admin panel .
*
* Referenced via add_theme_support ( 'custom-header' ) in twentyeleven_setup () .
*
* @ since Twenty Eleven 1.0
*/
function twentyeleven_admin_header_style () {
2018-08-16 21:51:36 -04:00
?>
2013-04-16 13:18:30 -04:00
< style type = " text/css " id = " twentyeleven-admin-header-css " >
2011-04-20 17:46:33 -04:00
. appearance_page_custom - header #headimg {
border : none ;
}
#headimg h1,
#desc {
font - family : " Helvetica Neue " , Arial , Helvetica , " Nimbus Sans L " , sans - serif ;
}
#headimg h1 {
margin : 0 ;
}
#headimg h1 a {
font - size : 32 px ;
line - height : 36 px ;
text - decoration : none ;
}
#desc {
font - size : 14 px ;
line - height : 23 px ;
padding : 0 0 3 em ;
}
2018-08-16 21:51:36 -04:00
< ? php
2011-04-20 17:46:33 -04:00
// If the user has set a custom color for the text use that
2018-08-16 21:51:36 -04:00
if ( get_header_textcolor () != HEADER_TEXTCOLOR ) :
?>
2017-11-30 18:11:00 -05:00
#site-title a,
#site-description {
color : #<?php echo get_header_textcolor(); ?>;
}
2011-04-20 17:46:33 -04:00
< ? php endif ; ?>
#headimg img {
max - width : 1000 px ;
height : auto ;
width : 100 % ;
}
</ style >
2018-08-16 21:51:36 -04:00
< ? php
2017-11-30 18:11:00 -05:00
}
2011-04-26 18:52:18 -04:00
endif ; // twentyeleven_admin_header_style
2011-04-20 17:46:33 -04:00
if ( ! function_exists ( 'twentyeleven_admin_header_image' ) ) :
2017-11-30 18:11:00 -05:00
/**
* Custom header image markup displayed on the Appearance > Header admin panel .
*
* Referenced via add_theme_support ( 'custom-header' ) in twentyeleven_setup () .
*
* @ since Twenty Eleven 1.0
*/
function twentyeleven_admin_header_image () {
2018-08-16 21:51:36 -04:00
?>
2017-11-30 18:11:00 -05:00
< div id = " headimg " >
< ? php
$color = get_header_textcolor ();
$image = get_header_image ();
$style = 'display: none;' ;
if ( $color && $color != 'blank' ) {
$style = 'color: #' . $color . ';' ;
}
?>
< h1 class = " displaying-header-text " >< a id = " name " style = " <?php echo esc_attr( $style ); ?> " onclick = " return false; " href = " <?php echo esc_url( home_url( '/' ) ); ?> " tabindex = " -1 " >< ? php bloginfo ( 'name' ); ?> </a></h1>
2015-01-21 19:42:23 -05:00
< div id = " desc " class = " displaying-header-text " style = " <?php echo esc_attr( $style ); ?> " >< ? php bloginfo ( 'description' ); ?> </div>
2017-11-30 18:11:00 -05:00
< ? php if ( $image ) : ?>
2012-03-20 16:37:53 -04:00
< img src = " <?php echo esc_url( $image ); ?> " alt = " " />
2011-04-29 18:22:19 -04:00
< ? php endif ; ?>
2017-11-30 18:11:00 -05:00
</ div >
2018-08-16 21:51:36 -04:00
< ? php
2017-11-30 18:11:00 -05:00
}
2011-04-26 18:52:18 -04:00
endif ; // twentyeleven_admin_header_image
2011-04-20 17:46:33 -04:00
/**
2013-09-25 12:50:11 -04:00
* Set the post excerpt length to 40 words .
*
* To override this length in a child theme , remove
* the filter and add your own function tied to
* the excerpt_length filter hook .
*
* @ since Twenty Eleven 1.0
2011-04-20 17:46:33 -04:00
*
2013-09-25 12:50:11 -04:00
* @ param int $length The number of excerpt characters .
* @ return int The filtered number of characters .
2011-04-20 17:46:33 -04:00
*/
function twentyeleven_excerpt_length ( $length ) {
return 40 ;
}
add_filter ( 'excerpt_length' , 'twentyeleven_excerpt_length' );
2012-08-09 14:21:58 -04:00
if ( ! function_exists ( 'twentyeleven_continue_reading_link' ) ) :
2017-11-30 18:11:00 -05:00
/**
* Return a " Continue Reading " link for excerpts
*
* @ since Twenty Eleven 1.0
*
* @ return string The " Continue Reading " HTML link .
*/
function twentyeleven_continue_reading_link () {
return ' <a href="' . esc_url ( get_permalink () ) . '">' . __ ( 'Continue reading <span class="meta-nav">→</span>' , 'twentyeleven' ) . '</a>' ;
}
2012-08-09 14:21:58 -04:00
endif ; // twentyeleven_continue_reading_link
2011-04-20 17:46:33 -04:00
/**
2013-09-25 12:50:11 -04:00
* Replace " [...] " in the Read More link with an ellipsis .
*
* The " [...] " is appended to automatically generated excerpts .
2011-04-20 17:46:33 -04:00
*
* To override this in a child theme , remove the filter and add your own
* function tied to the excerpt_more filter hook .
2013-09-25 12:50:11 -04:00
*
* @ since Twenty Eleven 1.0
*
* @ param string $more The Read More text .
* @ return The filtered Read More text .
2011-04-20 17:46:33 -04:00
*/
function twentyeleven_auto_excerpt_more ( $more ) {
2014-10-31 23:40:25 -04:00
if ( ! is_admin () ) {
return ' …' . twentyeleven_continue_reading_link ();
}
return $more ;
2011-04-20 17:46:33 -04:00
}
add_filter ( 'excerpt_more' , 'twentyeleven_auto_excerpt_more' );
/**
2013-09-25 12:50:11 -04:00
* Add a pretty " Continue Reading " link to custom post excerpts .
2011-04-20 17:46:33 -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 .
2013-09-25 12:50:11 -04:00
*
* @ since Twenty Eleven 1.0
*
* @ param string $output The " Continue Reading " link .
* @ return string The filtered " Continue Reading " link .
2011-04-20 17:46:33 -04:00
*/
function twentyeleven_custom_excerpt_more ( $output ) {
2014-10-31 23:40:25 -04:00
if ( has_excerpt () && ! is_attachment () && ! is_admin () ) {
2011-04-20 17:46:33 -04:00
$output .= twentyeleven_continue_reading_link ();
}
return $output ;
}
add_filter ( 'get_the_excerpt' , 'twentyeleven_custom_excerpt_more' );
/**
2013-09-25 12:50:11 -04:00
* Show a home link for the wp_nav_menu () fallback , wp_page_menu () .
*
* @ since Twenty Eleven 1.0
*
* @ param array $args The page menu arguments . @ see wp_page_menu ()
* @ return array The filtered page menu arguments .
2011-04-20 17:46:33 -04:00
*/
function twentyeleven_page_menu_args ( $args ) {
2017-11-30 18:11:00 -05:00
if ( ! isset ( $args [ 'show_home' ] ) ) {
2012-11-02 12:52:53 -04:00
$args [ 'show_home' ] = true ;
2017-11-30 18:11:00 -05:00
}
2011-04-20 17:46:33 -04:00
return $args ;
}
add_filter ( 'wp_page_menu_args' , 'twentyeleven_page_menu_args' );
/**
2013-09-25 12:50:11 -04:00
* Register sidebars and widgetized areas .
*
* Also register the default Epherma widget .
2011-04-28 05:47:30 -04:00
*
* @ since Twenty Eleven 1.0
2011-04-20 17:46:33 -04:00
*/
function twentyeleven_widgets_init () {
2011-04-28 05:47:30 -04:00
register_widget ( 'Twenty_Eleven_Ephemera_Widget' );
2017-11-30 18:11:00 -05:00
register_sidebar (
array (
'name' => __ ( 'Main Sidebar' , 'twentyeleven' ),
'id' => 'sidebar-1' ,
'before_widget' => '<aside id="%1$s" class="widget %2$s">' ,
'after_widget' => '</aside>' ,
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
)
);
register_sidebar (
array (
'name' => __ ( 'Showcase Sidebar' , 'twentyeleven' ),
'id' => 'sidebar-2' ,
'description' => __ ( 'The sidebar for the optional Showcase Template' , 'twentyeleven' ),
'before_widget' => '<aside id="%1$s" class="widget %2$s">' ,
'after_widget' => '</aside>' ,
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
)
);
register_sidebar (
array (
'name' => __ ( 'Footer Area One' , 'twentyeleven' ),
'id' => 'sidebar-3' ,
'description' => __ ( 'An optional widget area for your site footer' , 'twentyeleven' ),
'before_widget' => '<aside id="%1$s" class="widget %2$s">' ,
'after_widget' => '</aside>' ,
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
)
);
register_sidebar (
array (
'name' => __ ( 'Footer Area Two' , 'twentyeleven' ),
'id' => 'sidebar-4' ,
'description' => __ ( 'An optional widget area for your site footer' , 'twentyeleven' ),
'before_widget' => '<aside id="%1$s" class="widget %2$s">' ,
'after_widget' => '</aside>' ,
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
)
);
register_sidebar (
array (
'name' => __ ( 'Footer Area Three' , 'twentyeleven' ),
'id' => 'sidebar-5' ,
'description' => __ ( 'An optional widget area for your site footer' , 'twentyeleven' ),
'before_widget' => '<aside id="%1$s" class="widget %2$s">' ,
'after_widget' => '</aside>' ,
'before_title' => '<h3 class="widget-title">' ,
'after_title' => '</h3>' ,
)
);
2011-04-20 17:46:33 -04:00
}
2011-04-28 05:47:30 -04:00
add_action ( 'widgets_init' , 'twentyeleven_widgets_init' );
2011-04-20 17:46:33 -04:00
2011-11-10 13:41:05 -05:00
if ( ! function_exists ( 'twentyeleven_content_nav' ) ) :
2017-11-30 18:11:00 -05:00
/**
* Display navigation to next / previous pages when applicable .
*
* @ since Twenty Eleven 1.0
*
* @ param string $html_id The HTML id attribute .
*/
function twentyeleven_content_nav ( $html_id ) {
global $wp_query ;
if ( $wp_query -> max_num_pages > 1 ) :
2018-08-16 21:51:36 -04:00
?>
2017-11-30 18:11:00 -05:00
< nav id = " <?php echo esc_attr( $html_id ); ?> " >
< h3 class = " assistive-text " >< ? php _e ( 'Post navigation' , 'twentyeleven' ); ?> </h3>
< div class = " nav-previous " >< ? php next_posts_link ( __ ( '<span class="meta-nav">←</span> Older posts' , 'twentyeleven' ) ); ?> </div>
< div class = " nav-next " >< ? php previous_posts_link ( __ ( 'Newer posts <span class="meta-nav">→</span>' , 'twentyeleven' ) ); ?> </div>
</ nav ><!-- #nav-above -->
2018-08-16 21:51:36 -04:00
< ? php
2017-11-30 18:11:00 -05:00
endif ;
}
2011-11-10 13:41:05 -05:00
endif ; // twentyeleven_content_nav
2011-04-20 17:46:33 -04:00
2013-03-22 18:42:37 -04:00
/**
* Return the first link from the post content . If none found , the
* post permalink is used as a fallback .
*
2013-09-25 12:50:11 -04:00
* @ since Twenty Eleven 1.0
*
2013-07-15 20:21:09 -04:00
* @ uses get_url_in_content () to get the first URL from the post content .
2013-06-18 17:40:14 -04:00
*
2013-09-25 12:50:11 -04:00
* @ return string The first link .
2013-03-22 18:42:37 -04:00
*/
function twentyeleven_get_first_url () {
2013-06-18 17:40:14 -04:00
$content = get_the_content ();
2013-07-15 20:21:09 -04:00
$has_url = function_exists ( 'get_url_in_content' ) ? get_url_in_content ( $content ) : false ;
2013-03-22 18:42:37 -04:00
2017-11-30 18:11:00 -05:00
if ( ! $has_url ) {
2013-03-22 18:42:37 -04:00
$has_url = twentyeleven_url_grabber ();
2017-11-30 18:11:00 -05:00
}
2013-03-22 18:42:37 -04:00
2013-10-24 18:59:20 -04:00
/** This filter is documented in wp-includes/link-template.php */
2013-03-22 18:42:37 -04:00
return ( $has_url ) ? $has_url : apply_filters ( 'the_permalink' , get_permalink () );
}
2011-04-20 17:46:33 -04:00
/**
2011-05-19 04:31:01 -04:00
* Return the URL for the first link found in the post content .
*
* @ since Twenty Eleven 1.0
2013-09-25 12:50:11 -04:00
*
2011-05-19 04:31:01 -04:00
* @ return string | bool URL or false when no link is present .
2011-04-20 17:46:33 -04:00
*/
function twentyeleven_url_grabber () {
2017-11-30 18:11:00 -05:00
if ( ! preg_match ( '/<a\s[^>]*?href=[\'"](.+?)[\'"]/is' , get_the_content (), $matches ) ) {
2011-04-20 17:46:33 -04:00
return false ;
2017-11-30 18:11:00 -05:00
}
2011-04-20 17:46:33 -04:00
2011-05-19 04:31:01 -04:00
return esc_url_raw ( $matches [ 1 ] );
2011-04-20 17:46:33 -04:00
}
/**
2013-09-25 12:50:11 -04:00
* Count the number of footer sidebars to enable dynamic classes for the footer .
*
* @ since Twenty Eleven 1.0
2011-04-20 17:46:33 -04:00
*/
function twentyeleven_footer_sidebar_class () {
$count = 0 ;
2011-04-26 14:34:52 -04:00
2017-11-30 18:11:00 -05:00
if ( is_active_sidebar ( 'sidebar-3' ) ) {
2011-04-20 17:46:33 -04:00
$count ++ ;
2017-11-30 18:11:00 -05:00
}
2011-04-20 17:46:33 -04:00
2017-11-30 18:11:00 -05:00
if ( is_active_sidebar ( 'sidebar-4' ) ) {
2011-04-20 17:46:33 -04:00
$count ++ ;
2017-11-30 18:11:00 -05:00
}
2011-04-20 17:46:33 -04:00
2017-11-30 18:11:00 -05:00
if ( is_active_sidebar ( 'sidebar-5' ) ) {
2011-04-20 17:46:33 -04:00
$count ++ ;
2017-11-30 18:11:00 -05:00
}
2011-04-26 14:34:52 -04:00
2011-04-28 06:13:38 -04:00
$class = '' ;
2011-04-20 17:46:33 -04:00
switch ( $count ) {
case '1' :
$class = 'one' ;
break ;
case '2' :
$class = 'two' ;
break ;
case '3' :
$class = 'three' ;
break ;
}
2011-04-26 14:34:52 -04:00
2017-11-30 18:11:00 -05:00
if ( $class ) {
2015-01-21 19:42:23 -05:00
echo 'class="' . esc_attr ( $class ) . '"' ;
2017-11-30 18:11:00 -05:00
}
2011-04-20 17:46:33 -04:00
}
if ( ! function_exists ( 'twentyeleven_comment' ) ) :
2017-11-30 18:11:00 -05:00
/**
* Template for comments and pingbacks .
*
* To override this walker in a child theme without modifying the comments template
* simply create your own twentyeleven_comment (), and that function will be used instead .
*
* Used as a callback by wp_list_comments () for displaying the comments .
*
* @ since Twenty Eleven 1.0
*
* @ param object $comment The comment object .
* @ param array $args An array of comment arguments . @ see get_comment_reply_link ()
* @ param int $depth The depth of the comment .
*/
function twentyeleven_comment ( $comment , $args , $depth ) {
$GLOBALS [ 'comment' ] = $comment ;
switch ( $comment -> comment_type ) :
case 'pingback' :
case 'trackback' :
2018-08-16 21:51:36 -04:00
?>
2017-11-30 18:11:00 -05:00
< li class = " post pingback " >
2011-06-30 17:57:50 -04:00
< p >< ? php _e ( 'Pingback:' , 'twentyeleven' ); ?> <?php comment_author_link(); ?><?php edit_comment_link( __( 'Edit', 'twentyeleven' ), '<span class="edit-link">', '</span>' ); ?></p>
2018-08-16 21:51:36 -04:00
< ? php
2017-11-30 18:11:00 -05:00
break ;
default :
2018-08-16 21:51:36 -04:00
?>
2017-11-30 18:11:00 -05:00
< li < ? php comment_class (); ?> id="li-comment-<?php comment_ID(); ?>">
2011-04-20 17:46:33 -04:00
< article id = " comment-<?php comment_ID(); ?> " class = " comment " >
< footer class = " comment-meta " >
< div class = " comment-author vcard " >
< ? php
$avatar_size = 68 ;
2017-11-30 18:11:00 -05:00
if ( '0' != $comment -> comment_parent ) {
$avatar_size = 39 ;
}
2011-04-26 14:34:52 -04:00
2011-04-20 17:46:33 -04:00
echo get_avatar ( $comment , $avatar_size );
2011-04-26 14:34:52 -04:00
2017-11-30 18:11:00 -05:00
printf (
2019-09-02 20:41:05 -04:00
/* translators: 1: Comment author, 2: Date and time. */
2017-11-30 18:11:00 -05:00
__ ( '%1$s on %2$s <span class="says">said:</span>' , 'twentyeleven' ),
2011-05-25 11:29:26 -04:00
sprintf ( '<span class="fn">%s</span>' , get_comment_author_link () ),
2017-11-30 18:11:00 -05:00
sprintf (
'<a href="%1$s"><time datetime="%2$s">%3$s</time></a>' ,
2011-06-13 10:50:35 -04:00
esc_url ( get_comment_link ( $comment -> comment_ID ) ),
get_comment_time ( 'c' ),
2019-09-02 20:41:05 -04:00
/* translators: 1: Date, 2: Time. */
2011-06-13 10:54:14 -04:00
sprintf ( __ ( '%1$s at %2$s' , 'twentyeleven' ), get_comment_date (), get_comment_time () )
2011-06-13 10:50:35 -04:00
)
2011-04-20 17:46:33 -04:00
);
2018-08-16 21:51:36 -04:00
?>
2011-04-26 14:34:52 -04:00
2017-11-30 18:11:00 -05:00
< ? php edit_comment_link ( __ ( 'Edit' , 'twentyeleven' ), '<span class="edit-link">' , '</span>' ); ?>
</ div ><!-- . comment - author . vcard -->
2011-04-20 17:46:33 -04:00
2019-09-14 17:00:56 -04:00
< ? php
$commenter = wp_get_current_commenter ();
if ( $commenter [ 'comment_author_email' ] ) {
$moderation_note = __ ( 'Your comment is awaiting moderation.' , 'twentyeleven' );
} else {
$moderation_note = __ ( 'Your comment is awaiting moderation. This is a preview, your comment will be visible after it has been approved.' , 'twentyeleven' );
}
?>
< ? php if ( '0' == $comment -> comment_approved ) : ?>
< em class = " comment-awaiting-moderation " >< ? php echo $moderation_note ; ?> </em>
2011-04-20 17:46:33 -04:00
< br />
2019-09-14 17:00:56 -04:00
< ? php endif ; ?>
2011-04-20 17:46:33 -04:00
2017-11-30 18:11:00 -05:00
</ footer >
2011-04-20 17:46:33 -04:00
2017-11-30 18:11:00 -05:00
< div class = " comment-content " >< ? php comment_text (); ?> </div>
2011-04-20 17:46:33 -04:00
2017-11-30 18:11:00 -05:00
< div class = " reply " >
< ? php
comment_reply_link (
array_merge (
2018-08-16 21:51:36 -04:00
$args ,
array (
2017-11-30 18:11:00 -05:00
'reply_text' => __ ( 'Reply <span>↓</span>' , 'twentyeleven' ),
'depth' => $depth ,
'max_depth' => $args [ 'max_depth' ],
)
)
);
2018-08-16 21:51:36 -04:00
?>
2017-11-30 18:11:00 -05:00
</ div ><!-- . reply -->
</ article ><!-- #comment-## -->
2011-04-20 17:46:33 -04:00
2018-08-16 21:51:36 -04:00
< ? php
2017-11-30 18:11:00 -05:00
break ;
endswitch ;
}
2011-06-10 17:57:18 -04:00
endif ; // ends check for twentyeleven_comment()
if ( ! function_exists ( 'twentyeleven_posted_on' ) ) :
2017-11-30 18:11:00 -05:00
/**
* Print HTML with meta information for the current post - date / time and author .
*
* Create your own twentyeleven_posted_on to override in a child theme
*
* @ since Twenty Eleven 1.0
*/
function twentyeleven_posted_on () {
printf (
2019-09-02 20:41:05 -04:00
/* translators: 1: The permalink, 2: Time, 3: Date and time, 4: Date and time, 5: Author posts, 6: Author post link text, 7: Author display name. */
2017-11-30 18:11:00 -05:00
__ ( '<span class="sep">Posted on </span><a href="%1$s" title="%2$s" rel="bookmark"><time class="entry-date" datetime="%3$s">%4$s</time></a><span class="by-author"> <span class="sep"> by </span> <span class="author vcard"><a class="url fn n" href="%5$s" title="%6$s" rel="author">%7$s</a></span></span>' , 'twentyeleven' ),
esc_url ( get_permalink () ),
esc_attr ( get_the_time () ),
esc_attr ( get_the_date ( 'c' ) ),
esc_html ( get_the_date () ),
esc_url ( get_author_posts_url ( get_the_author_meta ( 'ID' ) ) ),
2019-09-02 20:41:05 -04:00
/* translators: %s: Author display name. */
2017-11-30 18:11:00 -05:00
esc_attr ( sprintf ( __ ( 'View all posts by %s' , 'twentyeleven' ), get_the_author () ) ),
get_the_author ()
);
}
2011-06-10 17:57:18 -04:00
endif ;
/**
2013-09-25 12:50:11 -04:00
* Add two classes to the array of body classes .
*
2011-06-11 02:30:59 -04:00
* The first is if the site has only had one author with published posts .
* The second is if a singular post being displayed
2011-06-10 17:57:18 -04:00
*
* @ since Twenty Eleven 1.0
2013-09-25 12:50:11 -04:00
*
* @ param array $classes Existing body classes .
* @ return array The filtered array of body classes .
2011-06-10 17:57:18 -04:00
*/
2011-06-11 02:30:59 -04:00
function twentyeleven_body_classes ( $classes ) {
2011-06-10 17:57:18 -04:00
2017-11-30 18:11:00 -05:00
if ( function_exists ( 'is_multi_author' ) && ! is_multi_author () ) {
2011-06-10 17:57:18 -04:00
$classes [] = 'single-author' ;
2017-11-30 18:11:00 -05:00
}
2011-06-11 02:30:59 -04:00
2017-11-30 18:11:00 -05:00
if ( is_singular () && ! is_home () && ! is_page_template ( 'showcase.php' ) && ! is_page_template ( 'sidebar-page.php' ) ) {
2011-06-11 02:30:59 -04:00
$classes [] = 'singular' ;
2017-11-30 18:11:00 -05:00
}
2011-06-11 02:30:59 -04:00
2011-06-10 17:57:18 -04:00
return $classes ;
}
2011-06-11 02:30:59 -04:00
add_filter ( 'body_class' , 'twentyeleven_body_classes' );
2013-03-27 16:34:28 -04:00
/**
2013-09-25 12:50:11 -04:00
* Retrieve the IDs for images in a gallery .
2013-03-27 16:34:28 -04:00
*
2013-09-25 12:50:11 -04:00
* @ uses get_post_galleries () First , if available . Falls back to shortcode parsing ,
* then as last option uses a get_posts () call .
2013-03-27 16:34:28 -04:00
*
2013-10-16 23:30:09 -04:00
* @ since Twenty Eleven 1.6
2013-03-27 16:34:28 -04:00
*
* @ return array List of image IDs from the post gallery .
*/
function twentyeleven_get_gallery_images () {
$images = array ();
2013-05-07 17:56:29 -04:00
if ( function_exists ( 'get_post_galleries' ) ) {
$galleries = get_post_galleries ( get_the_ID (), false );
2017-11-30 18:11:00 -05:00
if ( isset ( $galleries [ 0 ][ 'ids' ] ) ) {
2015-01-21 19:42:23 -05:00
$images = explode ( ',' , $galleries [ 0 ][ 'ids' ] );
2017-11-30 18:11:00 -05:00
}
2013-03-27 16:34:28 -04:00
} else {
$pattern = get_shortcode_regex ();
preg_match ( " / $pattern /s " , get_the_content (), $match );
$atts = shortcode_parse_atts ( $match [ 3 ] );
2017-11-30 18:11:00 -05:00
if ( isset ( $atts [ 'ids' ] ) ) {
2013-03-27 16:34:28 -04:00
$images = explode ( ',' , $atts [ 'ids' ] );
2017-11-30 18:11:00 -05:00
}
2013-03-27 16:34:28 -04:00
}
if ( ! $images ) {
2017-11-30 18:11:00 -05:00
$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' ,
)
);
2013-03-27 16:34:28 -04:00
}
return $images ;
}
2017-10-04 19:53:47 -04:00
/**
* Modifies tag cloud widget arguments to display all tags in the same font size
* and use list format for better accessibility .
*
* @ since Twenty Eleven 2.7
*
* @ param array $args Arguments for tag cloud widget .
* @ return array The filtered arguments for tag cloud widget .
*/
function twentyeleven_widget_tag_cloud_args ( $args ) {
$args [ 'largest' ] = 22 ;
$args [ 'smallest' ] = 8 ;
$args [ 'unit' ] = 'pt' ;
$args [ 'format' ] = 'list' ;
return $args ;
}
add_filter ( 'widget_tag_cloud_args' , 'twentyeleven_widget_tag_cloud_args' );
2019-04-23 09:04:56 -04:00
if ( ! function_exists ( 'wp_body_open' ) ) :
/**
* Fire the wp_body_open action .
*
* Added for backwards compatibility to support pre 5.2 . 0 WordPress versions .
*
* @ since Twenty Eleven 3.3
*/
function wp_body_open () {
/**
* Triggered after the opening < body > tag .
*
* @ since Twenty Eleven 3.3
*/
do_action ( 'wp_body_open' );
}
endif ;
2019-09-20 07:42:00 -04:00
/**
* Include a skip to content link at the top of the page so that users can bypass the menu .
*
* @ since Twenty Eleven 3.4
*/
function twentyeleven_skip_link () {
echo '<div class="skip-link"><a class="assistive-text" href="#content">' . esc_html__ ( 'Skip to primary content' , 'twentyeleven' ) . '</a></div>' ;
if ( ! is_singular () ) {
echo '<div class="skip-link"><a class="assistive-text" href="#secondary">' . esc_html__ ( 'Skip to secondary content' , 'twentyeleven' ) . '</a></div>' ;
}
}
add_action ( 'wp_body_open' , 'twentyeleven_skip_link' , 5 );