2004-01-27 04:58:01 -05:00
< ? php
/* Note: these tags go anywhere in the template */
2004-12-30 05:58:06 -05:00
function get_header () {
if ( file_exists ( TEMPLATEPATH . '/header.php' ) )
2004-12-30 16:58:01 -05:00
load_template ( TEMPLATEPATH . '/header.php' );
2004-12-30 05:58:06 -05:00
else
2005-01-01 21:47:45 -05:00
load_template ( ABSPATH . 'wp-content/themes/default/header.php' );
2004-12-30 05:58:06 -05:00
}
2005-10-17 19:41:28 -04:00
2004-12-30 05:58:06 -05:00
function get_footer () {
if ( file_exists ( TEMPLATEPATH . '/footer.php' ) )
2004-12-30 16:58:01 -05:00
load_template ( TEMPLATEPATH . '/footer.php' );
2004-12-30 05:58:06 -05:00
else
2005-01-01 21:47:45 -05:00
load_template ( ABSPATH . 'wp-content/themes/default/footer.php' );
2004-12-30 05:58:06 -05:00
}
2005-10-17 19:41:28 -04:00
2004-12-30 05:58:06 -05:00
function get_sidebar () {
if ( file_exists ( TEMPLATEPATH . '/sidebar.php' ) )
2004-12-30 16:58:01 -05:00
load_template ( TEMPLATEPATH . '/sidebar.php' );
2004-12-30 05:58:06 -05:00
else
2005-01-01 21:47:45 -05:00
load_template ( ABSPATH . 'wp-content/themes/default/sidebar.php' );
2004-12-30 05:58:06 -05:00
}
2004-07-10 19:34:47 -04:00
function wp_loginout () {
2006-02-22 14:08:55 -05:00
if ( ! is_user_logged_in () )
2006-08-30 17:46:31 -04:00
$link = '<a href="' . get_option ( 'siteurl' ) . '/wp-login.php">' . __ ( 'Login' ) . '</a>' ;
2005-10-17 19:41:28 -04:00
else
2006-08-30 17:46:31 -04:00
$link = '<a href="' . get_option ( 'siteurl' ) . '/wp-login.php?action=logout">' . __ ( 'Logout' ) . '</a>' ;
2004-07-10 19:34:47 -04:00
echo apply_filters ( 'loginout' , $link );
}
2005-10-17 19:41:28 -04:00
2005-01-24 05:06:53 -05:00
function wp_register ( $before = '<li>' , $after = '</li>' ) {
2004-07-10 19:34:47 -04:00
2006-02-22 14:08:55 -05:00
if ( ! is_user_logged_in () ) {
2006-08-30 17:46:31 -04:00
if ( get_option ( 'users_can_register' ) )
$link = $before . '<a href="' . get_option ( 'siteurl' ) . '/wp-register.php">' . __ ( 'Register' ) . '</a>' . $after ;
2006-02-22 14:08:55 -05:00
else
$link = '' ;
} else {
2006-08-30 17:46:31 -04:00
$link = $before . '<a href="' . get_option ( 'siteurl' ) . '/wp-admin/">' . __ ( 'Site Admin' ) . '</a>' . $after ;
2006-02-22 14:08:55 -05:00
}
2004-07-10 19:34:47 -04:00
echo apply_filters ( 'register' , $link );
}
2005-10-17 19:41:28 -04:00
2004-07-10 19:34:47 -04:00
function wp_meta () {
2005-02-01 01:20:54 -05:00
do_action ( 'wp_meta' );
2004-07-10 19:34:47 -04:00
}
2005-10-17 19:41:28 -04:00
2004-01-27 04:58:01 -05:00
function bloginfo ( $show = '' ) {
2005-10-17 19:41:28 -04:00
$info = get_bloginfo ( $show );
2006-04-02 23:04:39 -04:00
if ( ! strstr ( $show , 'url' ) && //don't filter URLs
! strstr ( $show , 'directory' ) &&
! strstr ( $show , 'home' )) {
2005-10-17 19:41:28 -04:00
$info = apply_filters ( 'bloginfo' , $info , $show );
$info = convert_chars ( $info );
2006-09-06 20:35:42 -04:00
} else {
$info = apply_filters ( 'bloginfo_url' , $info , $show );
2005-10-17 19:41:28 -04:00
}
2005-10-05 20:04:59 -04:00
2005-10-17 19:41:28 -04:00
echo $info ;
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2004-01-27 04:58:01 -05:00
function get_bloginfo ( $show = '' ) {
2004-02-05 15:55:50 -05:00
2004-09-30 13:56:16 -04:00
switch ( $show ) {
2005-10-17 19:41:28 -04:00
case 'url' :
case 'home' :
case 'siteurl' :
2006-08-30 17:46:31 -04:00
$output = get_option ( 'home' );
2005-10-17 19:41:28 -04:00
break ;
case 'wpurl' :
2006-08-30 17:46:31 -04:00
$output = get_option ( 'siteurl' );
2005-10-17 19:41:28 -04:00
break ;
case 'description' :
2006-08-30 17:46:31 -04:00
$output = get_option ( 'blogdescription' );
2005-10-17 19:41:28 -04:00
break ;
case 'rdf_url' :
$output = get_feed_link ( 'rdf' );
break ;
case 'rss_url' :
$output = get_feed_link ( 'rss' );
break ;
case 'rss2_url' :
$output = get_feed_link ( 'rss2' );
break ;
case 'atom_url' :
$output = get_feed_link ( 'atom' );
break ;
case 'comments_rss2_url' :
$output = get_feed_link ( 'comments_rss2' );
break ;
case 'pingback_url' :
2006-08-30 17:46:31 -04:00
$output = get_option ( 'siteurl' ) . '/xmlrpc.php' ;
2005-10-17 19:41:28 -04:00
break ;
case 'stylesheet_url' :
$output = get_stylesheet_uri ();
break ;
case 'stylesheet_directory' :
$output = get_stylesheet_directory_uri ();
break ;
case 'template_directory' :
case 'template_url' :
$output = get_template_directory_uri ();
break ;
case 'admin_email' :
2006-08-30 17:46:31 -04:00
$output = get_option ( 'admin_email' );
2005-10-17 19:41:28 -04:00
break ;
case 'charset' :
2006-08-30 17:46:31 -04:00
$output = get_option ( 'blog_charset' );
2005-10-17 19:41:28 -04:00
if ( '' == $output ) $output = 'UTF-8' ;
break ;
case 'html_type' :
$output = get_option ( 'html_type' );
break ;
case 'version' :
global $wp_version ;
$output = $wp_version ;
break ;
case 'name' :
default :
2006-08-30 17:46:31 -04:00
$output = get_option ( 'blogname' );
2005-10-17 19:41:28 -04:00
break ;
2004-09-30 13:56:16 -04:00
}
return $output ;
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2004-01-27 04:58:01 -05:00
function wp_title ( $sep = '»' , $display = true ) {
2005-10-17 19:41:28 -04:00
global $wpdb ;
2006-04-01 19:20:11 -05:00
global $m , $year , $monthnum , $day , $category_name , $wp_locale , $posts ;
2005-10-17 19:41:28 -04:00
$cat = get_query_var ( 'cat' );
$p = get_query_var ( 'p' );
$name = get_query_var ( 'name' );
$category_name = get_query_var ( 'category_name' );
2005-11-10 19:48:31 -05:00
$author = get_query_var ( 'author' );
$author_name = get_query_var ( 'author_name' );
2005-10-17 19:41:28 -04:00
// If there's a category
if ( ! empty ( $cat ) ) {
// category exclusion
if ( ! stristr ( $cat , '-' ) )
2006-08-24 19:50:24 -04:00
$title = apply_filters ( 'single_cat_title' , get_the_category_by_ID ( $cat ));
2005-10-17 19:41:28 -04:00
}
if ( ! empty ( $category_name ) ) {
if ( stristr ( $category_name , '/' ) ) {
$category_name = explode ( '/' , $category_name );
if ( $category_name [ count ( $category_name ) - 1 ] )
$category_name = $category_name [ count ( $category_name ) - 1 ]; // no trailing slash
else
$category_name = $category_name [ count ( $category_name ) - 2 ]; // there was a trailling slash
}
$title = $wpdb -> get_var ( " SELECT cat_name FROM $wpdb->categories WHERE category_nicename = ' $category_name ' " );
2006-08-24 19:50:24 -04:00
$title = apply_filters ( 'single_cat_title' , $title );
2005-10-17 19:41:28 -04:00
}
2005-11-10 19:48:31 -05:00
// If there's an author
if ( ! empty ( $author ) ) {
$title = get_userdata ( $author );
$title = $title -> display_name ;
}
if ( ! empty ( $author_name ) ) {
// We do a direct query here because we don't cache by nicename.
$title = $wpdb -> get_var ( " SELECT display_name FROM $wpdb->users WHERE user_nicename = ' $author_name ' " );
}
2005-10-17 19:41:28 -04:00
// If there's a month
if ( ! empty ( $m ) ) {
$my_year = substr ( $m , 0 , 4 );
2006-04-01 19:20:11 -05:00
$my_month = $wp_locale -> get_month ( $m );
2005-10-17 19:41:28 -04:00
$title = " $my_year $sep $my_month " ;
}
if ( ! empty ( $year ) ) {
$title = $year ;
if ( ! empty ( $monthnum ) )
2006-04-01 19:20:11 -05:00
$title .= " $sep " . $wp_locale -> get_month ( $monthnum );
2005-10-17 19:41:28 -04:00
if ( ! empty ( $day ) )
$title .= " $sep " . zeroise ( $day , 2 );
}
// If there is a post
if ( is_single () || is_page () ) {
$title = strip_tags ( $posts [ 0 ] -> post_title );
$title = apply_filters ( 'single_post_title' , $title );
}
2005-12-05 18:57:41 -05:00
$prefix = '' ;
if ( isset ( $title ) )
$prefix = " $sep " ;
$title = $prefix . $title ;
$title = apply_filters ( 'wp_title' , $title , $sep );
2005-10-17 19:41:28 -04:00
// Send it out
2005-12-05 18:57:41 -05:00
if ( $display )
echo $title ;
else
return $title ;
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2004-01-27 04:58:01 -05:00
function single_post_title ( $prefix = '' , $display = true ) {
2005-10-17 19:41:28 -04:00
global $wpdb ;
$p = get_query_var ( 'p' );
$name = get_query_var ( 'name' );
if ( intval ( $p ) || '' != $name ) {
if ( ! $p )
$p = $wpdb -> get_var ( " SELECT ID FROM $wpdb->posts WHERE post_name = ' $name ' " );
$post = & get_post ( $p );
$title = $post -> post_title ;
$title = apply_filters ( 'single_post_title' , $title );
if ( $display )
echo $prefix . strip_tags ( $title );
else
return strip_tags ( $title );
}
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2004-01-27 04:58:01 -05:00
function single_cat_title ( $prefix = '' , $display = true ) {
2005-05-27 02:10:41 -04:00
$cat = intval ( get_query_var ( 'cat' ) );
2005-10-17 19:41:28 -04:00
if ( ! empty ( $cat ) && ! ( strtoupper ( $cat ) == 'ALL' ) ) {
2006-08-24 19:50:24 -04:00
$my_cat_name = apply_filters ( 'single_cat_title' , get_the_category_by_ID ( $cat ));
2005-10-17 19:41:28 -04:00
if ( ! empty ( $my_cat_name ) ) {
if ( $display )
2005-05-27 02:10:41 -04:00
echo $prefix . strip_tags ( $my_cat_name );
else
return strip_tags ( $my_cat_name );
}
}
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2004-01-27 04:58:01 -05:00
function single_month_title ( $prefix = '' , $display = true ) {
2006-04-01 19:20:11 -05:00
global $m , $monthnum , $wp_locale , $year ;
2005-10-17 19:41:28 -04:00
if ( ! empty ( $monthnum ) && ! empty ( $year ) ) {
2004-10-18 19:45:26 -04:00
$my_year = $year ;
2006-04-01 19:20:11 -05:00
$my_month = $wp_locale -> get_month ( $monthnum );
2005-10-17 19:41:28 -04:00
} elseif ( ! empty ( $m ) ) {
2004-10-18 19:52:36 -04:00
$my_year = substr ( $m , 0 , 4 );
2006-04-01 19:20:11 -05:00
$my_month = $wp_locale -> get_month ( $m );
2004-10-18 19:52:36 -04:00
}
2005-10-17 19:41:28 -04:00
if ( ! empty ( $my_month ) && $display )
2004-10-18 19:52:36 -04:00
echo $prefix . $my_month . $prefix . $my_year ;
2005-10-17 19:41:28 -04:00
else
2004-10-18 19:52:36 -04:00
return $monthnum ;
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2004-01-27 04:58:01 -05:00
/* link navigation hack by Orien http://icecode.com/ */
2004-07-06 13:04:07 -04:00
function get_archives_link ( $url , $text , $format = 'html' , $before = '' , $after = '' ) {
$text = wptexturize ( $text );
2005-10-17 19:41:28 -04:00
$title_text = wp_specialchars ( $text , 1 );
2004-07-28 19:09:33 -04:00
2005-10-17 19:41:28 -04:00
if ( 'link' == $format )
2004-07-28 19:09:33 -04:00
return " \t <link rel='archives' title=' $title_text ' href=' $url ' /> \n " ;
2005-10-17 19:41:28 -04:00
elseif ( 'option' == $format )
2005-02-13 18:46:33 -05:00
return " \t <option value=' $url '> $before $text $after </option> \n " ;
2005-10-17 19:41:28 -04:00
elseif ( 'html' == $format )
2004-07-28 19:09:33 -04:00
return " \t <li> $before <a href=' $url ' title=' $title_text '> $text </a> $after </li> \n " ;
2005-10-17 19:41:28 -04:00
else // custom
2004-07-28 19:09:33 -04:00
return " \t $before <a href=' $url ' title=' $title_text '> $text </a> $after\n " ;
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2004-04-24 15:23:57 -04:00
function wp_get_archives ( $args = '' ) {
2006-06-15 16:28:47 -04:00
global $wp_locale , $wpdb ;
2004-04-24 15:23:57 -04:00
2006-06-15 16:28:47 -04:00
if ( is_array ( $args ) )
$r = & $args ;
else
parse_str ( $args , $r );
2005-10-17 19:41:28 -04:00
2006-06-15 16:28:47 -04:00
$defaults = array ( 'type' => 'monthly' , 'limit' => '' , 'format' => 'html' , 'before' => '' , 'after' => '' , 'show_post_count' => false );
$r = array_merge ( $defaults , $r );
extract ( $r );
2005-10-17 19:41:28 -04:00
if ( '' == $type )
$type = 'monthly' ;
if ( '' != $limit ) {
$limit = ( int ) $limit ;
$limit = ' LIMIT ' . $limit ;
}
2006-06-15 16:28:47 -04:00
2005-10-17 19:41:28 -04:00
// this is what will separate dates on weekly archive links
$archive_week_separator = '–' ;
// over-ride general date format ? 0 = no: use the date format set in Options, 1 = yes: over-ride
$archive_date_format_over_ride = 0 ;
// options for daily archive (only if you over-ride the general date format)
$archive_day_date_format = 'Y/m/d' ;
// options for weekly archive (only if you over-ride the general date format)
$archive_week_start_date_format = 'Y/m/d' ;
$archive_week_end_date_format = 'Y/m/d' ;
if ( ! $archive_date_format_over_ride ) {
2006-08-30 17:46:31 -04:00
$archive_day_date_format = get_option ( 'date_format' );
$archive_week_start_date_format = get_option ( 'date_format' );
$archive_week_end_date_format = get_option ( 'date_format' );
2005-10-17 19:41:28 -04:00
}
2006-08-30 17:46:31 -04:00
$add_hours = intval ( get_option ( 'gmt_offset' ));
$add_minutes = intval ( 60 * ( get_option ( 'gmt_offset' ) - $add_hours ));
2005-10-17 19:41:28 -04:00
if ( 'monthly' == $type ) {
2006-02-12 02:41:56 -05:00
$arcresults = $wpdb -> get_results ( " SELECT DISTINCT YEAR(post_date) AS `year`, MONTH(post_date) AS `month`, count(ID) as posts FROM $wpdb->posts WHERE post_type = 'post' AND post_status = 'publish' GROUP BY YEAR(post_date), MONTH(post_date) ORDER BY post_date DESC " . $limit );
2005-10-17 19:41:28 -04:00
if ( $arcresults ) {
$afterafter = $after ;
foreach ( $arcresults as $arcresult ) {
$url = get_month_link ( $arcresult -> year , $arcresult -> month );
if ( $show_post_count ) {
2006-04-01 19:20:11 -05:00
$text = sprintf ( '%s %d' , $wp_locale -> get_month ( $arcresult -> month ), $arcresult -> year );
2005-10-17 19:41:28 -04:00
$after = ' (' . $arcresult -> posts . ')' . $afterafter ;
} else {
2006-04-01 19:20:11 -05:00
$text = sprintf ( '%s %d' , $wp_locale -> get_month ( $arcresult -> month ), $arcresult -> year );
2005-10-17 19:41:28 -04:00
}
echo get_archives_link ( $url , $text , $format , $before , $after );
}
}
2006-08-30 13:23:42 -04:00
} elseif ( 'yearly' == $type ) {
$arcresults = $wpdb -> get_results ( " SELECT DISTINCT YEAR(post_date) AS `year`, count(ID) as posts FROM $wpdb->posts WHERE post_type ='post' AND post_status = 'publish' GROUP BY YEAR(post_date) ORDER BY post_date DESC " . $limit );
if ( $arcresults ) {
$afterafter = $after ;
foreach ( $arcresults as $arcresult ) {
$url = get_year_link ( $arcresult -> year );
if ( $show_post_count ) {
$text = sprintf ( '%d' , $arcresult -> year );
$after = ' (' . $arcresult -> posts . ')' . $afterafter ;
} else {
$text = sprintf ( '%d' , $arcresult -> year );
}
echo get_archives_link ( $url , $text , $format , $before , $after );
}
}
2005-10-17 19:41:28 -04:00
} elseif ( 'daily' == $type ) {
2006-02-12 02:41:56 -05:00
$arcresults = $wpdb -> get_results ( " SELECT DISTINCT YEAR(post_date) AS `year`, MONTH(post_date) AS `month`, DAYOFMONTH(post_date) AS `dayofmonth` FROM $wpdb->posts WHERE post_type = 'post' AND post_status = 'publish' ORDER BY post_date DESC " . $limit );
2005-10-17 19:41:28 -04:00
if ( $arcresults ) {
foreach ( $arcresults as $arcresult ) {
$url = get_day_link ( $arcresult -> year , $arcresult -> month , $arcresult -> dayofmonth );
$date = sprintf ( " %d-%02d-%02d 00:00:00 " , $arcresult -> year , $arcresult -> month , $arcresult -> dayofmonth );
$text = mysql2date ( $archive_day_date_format , $date );
echo get_archives_link ( $url , $text , $format , $before , $after );
}
}
} elseif ( 'weekly' == $type ) {
2006-08-30 17:46:31 -04:00
$start_of_week = get_option ( 'start_of_week' );
2006-02-12 02:41:56 -05:00
$arcresults = $wpdb -> get_results ( " SELECT DISTINCT WEEK(post_date, $start_of_week ) AS `week`, YEAR(post_date) AS yr, DATE_FORMAT(post_date, '%Y-%m-%d') AS yyyymmdd FROM $wpdb->posts WHERE post_type = 'post' AND post_status = 'publish' ORDER BY post_date DESC " . $limit );
2005-10-17 19:41:28 -04:00
$arc_w_last = '' ;
if ( $arcresults ) {
foreach ( $arcresults as $arcresult ) {
if ( $arcresult -> week != $arc_w_last ) {
$arc_year = $arcresult -> yr ;
$arc_w_last = $arcresult -> week ;
2006-08-30 17:46:31 -04:00
$arc_week = get_weekstartend ( $arcresult -> yyyymmdd , get_option ( 'start_of_week' ));
2005-10-17 19:41:28 -04:00
$arc_week_start = date_i18n ( $archive_week_start_date_format , $arc_week [ 'start' ]);
$arc_week_end = date_i18n ( $archive_week_end_date_format , $arc_week [ 'end' ]);
2006-08-30 17:46:31 -04:00
$url = sprintf ( '%s/%s%sm%s%s%sw%s%d' , get_option ( 'home' ), '' , '?' , '=' , $arc_year , '&' , '=' , $arcresult -> week );
2005-10-17 19:41:28 -04:00
$text = $arc_week_start . $archive_week_separator . $arc_week_end ;
echo get_archives_link ( $url , $text , $format , $before , $after );
}
}
}
2006-02-18 21:07:13 -05:00
} elseif ( ( 'postbypost' == $type ) || ( 'alpha' == $type ) ) {
( 'alpha' == $type ) ? $orderby = " post_title ASC " : $orderby = " post_date DESC " ;
$arcresults = $wpdb -> get_results ( " SELECT * FROM $wpdb->posts WHERE post_type = 'post' AND post_status = 'publish' ORDER BY $orderby $limit " );
2005-10-17 19:41:28 -04:00
if ( $arcresults ) {
foreach ( $arcresults as $arcresult ) {
if ( $arcresult -> post_date != '0000-00-00 00:00:00' ) {
$url = get_permalink ( $arcresult );
$arc_title = $arcresult -> post_title ;
if ( $arc_title )
$text = strip_tags ( $arc_title );
else
$text = $arcresult -> ID ;
echo get_archives_link ( $url , $text , $format , $before , $after );
}
}
}
}
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2004-09-09 19:07:46 -04:00
// Used in get_calendar
function calendar_week_mod ( $num ) {
$base = 7 ;
return ( $num - $base * floor ( $num / $base ));
}
2005-10-17 19:41:28 -04:00
2006-04-01 19:20:11 -05:00
function get_calendar ( $initial = true ) {
global $wpdb , $m , $monthnum , $year , $timedifference , $wp_locale , $posts ;
2005-10-17 19:41:28 -04:00
// Quick check. If we have no posts at all, abort!
if ( ! $posts ) {
2006-02-09 05:03:48 -05:00
$gotsome = $wpdb -> get_var ( " SELECT ID from $wpdb->posts WHERE post_type = 'post' AND post_status = 'publish' ORDER BY post_date DESC LIMIT 1 " );
2005-10-17 19:41:28 -04:00
if ( ! $gotsome )
return ;
}
if ( isset ( $_GET [ 'w' ]) )
$w = '' . intval ( $_GET [ 'w' ]);
// week_begins = 0 stands for Sunday
2006-08-30 17:46:31 -04:00
$week_begins = intval ( get_option ( 'start_of_week' ));
$add_hours = intval ( get_option ( 'gmt_offset' ));
$add_minutes = intval ( 60 * ( get_option ( 'gmt_offset' ) - $add_hours ));
2005-10-17 19:41:28 -04:00
// Let's figure out when we are
if ( ! empty ( $monthnum ) && ! empty ( $year ) ) {
$thismonth = '' . zeroise ( intval ( $monthnum ), 2 );
$thisyear = '' . intval ( $year );
} elseif ( ! empty ( $w ) ) {
// We need to get the month from MySQL
$thisyear = '' . intval ( substr ( $m , 0 , 4 ));
$d = (( $w - 1 ) * 7 ) + 6 ; //it seems MySQL's weeks disagree with PHP's
$thismonth = $wpdb -> get_var ( " SELECT DATE_FORMAT((DATE_ADD(' ${ thisyear } 0101', INTERVAL $d DAY) ), '%m') " );
} elseif ( ! empty ( $m ) ) {
$calendar = substr ( $m , 0 , 6 );
$thisyear = '' . intval ( substr ( $m , 0 , 4 ));
if ( strlen ( $m ) < 6 )
$thismonth = '01' ;
else
$thismonth = '' . zeroise ( intval ( substr ( $m , 4 , 2 )), 2 );
} else {
2006-08-30 17:46:31 -04:00
$thisyear = gmdate ( 'Y' , current_time ( 'timestamp' ) + get_option ( 'gmt_offset' ) * 3600 );
$thismonth = gmdate ( 'm' , current_time ( 'timestamp' ) + get_option ( 'gmt_offset' ) * 3600 );
2005-10-17 19:41:28 -04:00
}
$unixmonth = mktime ( 0 , 0 , 0 , $thismonth , 1 , $thisyear );
// Get the next and previous month and year with at least one post
$previous = $wpdb -> get_row ( " SELECT DISTINCT MONTH(post_date) AS month, YEAR(post_date) AS year
FROM $wpdb -> posts
WHERE post_date < '$thisyear-$thismonth-01'
2006-02-09 05:03:48 -05:00
AND post_type = 'post' AND post_status = 'publish'
2005-10-17 19:41:28 -04:00
ORDER BY post_date DESC
LIMIT 1 " );
$next = $wpdb -> get_row ( " SELECT DISTINCT MONTH(post_date) AS month, YEAR(post_date) AS year
FROM $wpdb -> posts
WHERE post_date > '$thisyear-$thismonth-01'
AND MONTH ( post_date ) != MONTH ( '$thisyear-$thismonth-01' )
2006-02-09 05:03:48 -05:00
AND post_type = 'post' AND post_status = 'publish'
2005-10-17 19:41:28 -04:00
ORDER BY post_date ASC
LIMIT 1 " );
echo ' < table id = " wp-calendar " >
2006-04-01 19:20:11 -05:00
< caption > ' . $wp_locale->get_month($thismonth) . ' ' . date(' Y ', $unixmonth) . ' </ caption >
2005-10-17 19:41:28 -04:00
< thead >
< tr > ' ;
$myweek = array ();
for ( $wdcount = 0 ; $wdcount <= 6 ; $wdcount ++ ) {
2006-04-01 19:20:11 -05:00
$myweek [] = $wp_locale -> get_weekday (( $wdcount + $week_begins ) % 7 );
2005-10-17 19:41:28 -04:00
}
foreach ( $myweek as $wd ) {
2006-04-01 19:20:11 -05:00
$day_name = ( true == $initial ) ? $wp_locale -> get_weekday_initial ( $wd ) : $wp_locale -> get_weekday_abbrev ( $wd );
echo " \n \t \t <th abbr= \" $wd\ " scope = \ " col \" title= \" $wd\ " > $day_name </ th > " ;
2005-10-17 19:41:28 -04:00
}
echo '
</ tr >
</ thead >
< tfoot >
< tr > ' ;
if ( $previous ) {
2006-04-01 19:20:11 -05:00
echo " \n \t \t " . '<td abbr="' . $wp_locale -> get_month ( $previous -> month ) . '" colspan="3" id="prev"><a href="' .
get_month_link ( $previous -> year , $previous -> month ) . '" title="' . sprintf ( __ ( 'View posts for %1$s %2$s' ), $wp_locale -> get_month ( $previous -> month ),
date ( 'Y' , mktime ( 0 , 0 , 0 , $previous -> month , 1 , $previous -> year ))) . '">« ' . $wp_locale -> get_month_abbrev ( $wp_locale -> get_month ( $previous -> month )) . '</a></td>' ;
2005-10-17 19:41:28 -04:00
} else {
echo " \n \t \t " . '<td colspan="3" id="prev" class="pad"> </td>' ;
}
echo " \n \t \t " . '<td class="pad"> </td>' ;
if ( $next ) {
2006-04-01 19:20:11 -05:00
echo " \n \t \t " . '<td abbr="' . $wp_locale -> get_month ( $next -> month ) . '" colspan="3" id="next"><a href="' .
get_month_link ( $next -> year , $next -> month ) . '" title="' . sprintf ( __ ( 'View posts for %1$s %2$s' ), $wp_locale -> get_month ( $next -> month ),
date ( 'Y' , mktime ( 0 , 0 , 0 , $next -> month , 1 , $next -> year ))) . '">' . $wp_locale -> get_month_abbrev ( $wp_locale -> get_month ( $next -> month )) . ' »</a></td>' ;
2005-10-17 19:41:28 -04:00
} else {
echo " \n \t \t " . '<td colspan="3" id="next" class="pad"> </td>' ;
}
echo '
</ tr >
</ tfoot >
< tbody >
< tr > ' ;
// Get days with posts
$dayswithposts = $wpdb -> get_results ( " SELECT DISTINCT DAYOFMONTH(post_date)
2006-04-21 20:02:00 -04:00
FROM $wpdb -> posts WHERE MONTH ( post_date ) = '$thismonth'
AND YEAR ( post_date ) = '$thisyear'
2006-02-09 05:03:48 -05:00
AND post_type = 'post' AND post_status = 'publish'
2005-10-17 19:41:28 -04:00
AND post_date < '" . current_time(' mysql ') . ' \ '' , ARRAY_N );
if ( $dayswithposts ) {
foreach ( $dayswithposts as $daywith ) {
$daywithpost [] = $daywith [ 0 ];
}
} else {
$daywithpost = array ();
}
if ( strstr ( $_SERVER [ 'HTTP_USER_AGENT' ], 'MSIE' ) || strstr ( strtolower ( $_SERVER [ 'HTTP_USER_AGENT' ]), 'camino' ) || strstr ( strtolower ( $_SERVER [ 'HTTP_USER_AGENT' ]), 'safari' ) )
$ak_title_separator = " \n " ;
else
$ak_title_separator = ', ' ;
$ak_titles_for_day = array ();
$ak_post_titles = $wpdb -> get_results ( " SELECT post_title, DAYOFMONTH(post_date) as dom "
. " FROM $wpdb->posts "
. " WHERE YEAR(post_date) = ' $thisyear ' "
. " AND MONTH(post_date) = ' $thismonth ' "
. " AND post_date < ' " . current_time ( 'mysql' ) . " ' "
2006-02-09 05:03:48 -05:00
. " AND post_type = 'post' AND post_status = 'publish' "
2005-10-17 19:41:28 -04:00
);
if ( $ak_post_titles ) {
foreach ( $ak_post_titles as $ak_post_title ) {
if ( empty ( $ak_titles_for_day [ 'day_' . $ak_post_title -> dom ]) )
$ak_titles_for_day [ 'day_' . $ak_post_title -> dom ] = '' ;
if ( empty ( $ak_titles_for_day [ " $ak_post_title->dom " ]) ) // first one
$ak_titles_for_day [ " $ak_post_title->dom " ] = str_replace ( '"' , '"' , wptexturize ( $ak_post_title -> post_title ));
else
$ak_titles_for_day [ " $ak_post_title->dom " ] .= $ak_title_separator . str_replace ( '"' , '"' , wptexturize ( $ak_post_title -> post_title ));
}
}
// See how much we should pad in the beginning
$pad = calendar_week_mod ( date ( 'w' , $unixmonth ) - $week_begins );
if ( 0 != $pad )
echo " \n \t \t " . '<td colspan="' . $pad . '" class="pad"> </td>' ;
$daysinmonth = intval ( date ( 't' , $unixmonth ));
for ( $day = 1 ; $day <= $daysinmonth ; ++ $day ) {
if ( isset ( $newrow ) && $newrow )
echo " \n \t </tr> \n \t <tr> \n \t \t " ;
$newrow = false ;
2006-08-30 17:46:31 -04:00
if ( $day == gmdate ( 'j' , ( time () + ( get_option ( 'gmt_offset' ) * 3600 ))) && $thismonth == gmdate ( 'm' , time () + ( get_option ( 'gmt_offset' ) * 3600 )) && $thisyear == gmdate ( 'Y' , time () + ( get_option ( 'gmt_offset' ) * 3600 )) )
2005-10-17 19:41:28 -04:00
echo '<td id="today">' ;
else
echo '<td>' ;
if ( in_array ( $day , $daywithpost ) ) // any posts today?
echo '<a href="' . get_day_link ( $thisyear , $thismonth , $day ) . " \" title= \" $ak_titles_for_day[$day] \" > $day </a> " ;
else
echo $day ;
echo '</td>' ;
if ( 6 == calendar_week_mod ( date ( 'w' , mktime ( 0 , 0 , 0 , $thismonth , $day , $thisyear )) - $week_begins ) )
$newrow = true ;
}
$pad = 7 - calendar_week_mod ( date ( 'w' , mktime ( 0 , 0 , 0 , $thismonth , $day , $thisyear )) - $week_begins );
if ( $pad != 0 && $pad != 7 )
echo " \n \t \t " . '<td class="pad" colspan="' . $pad . '"> </td>' ;
echo " \n \t </tr> \n \t </tbody> \n \t </table> " ;
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2004-01-27 04:58:01 -05:00
function allowed_tags () {
2005-10-17 19:41:28 -04:00
global $allowedtags ;
2004-05-07 19:56:33 -04:00
$allowed = '' ;
2005-10-17 19:41:28 -04:00
foreach ( $allowedtags as $tag => $attributes ) {
$allowed .= '<' . $tag ;
if ( 0 < count ( $attributes ) ) {
foreach ( $attributes as $attribute => $limits ) {
$allowed .= ' ' . $attribute . '=""' ;
}
}
$allowed .= '> ' ;
}
return htmlentities ( $allowed );
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2004-01-27 04:58:01 -05:00
/***** Date/Time tags *****/
2005-10-17 19:41:28 -04:00
2004-01-27 04:58:01 -05:00
function the_date_xml () {
2005-10-17 19:41:28 -04:00
global $post ;
echo mysql2date ( 'Y-m-d' , $post -> post_date );
//echo ""+$post->post_date;
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2004-01-27 04:58:01 -05:00
function the_date ( $d = '' , $before = '' , $after = '' , $echo = true ) {
2005-10-17 19:41:28 -04:00
global $id , $post , $day , $previousday , $newday ;
$the_date = '' ;
if ( $day != $previousday ) {
$the_date .= $before ;
if ( $d == '' )
2006-08-30 17:46:31 -04:00
$the_date .= mysql2date ( get_option ( 'date_format' ), $post -> post_date );
2005-10-17 19:41:28 -04:00
else
$the_date .= mysql2date ( $d , $post -> post_date );
$the_date .= $after ;
$previousday = $day ;
}
$the_date = apply_filters ( 'the_date' , $the_date , $d , $before , $after );
if ( $echo )
echo $the_date ;
else
return $the_date ;
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2006-08-30 12:46:08 -04:00
function the_modified_date ( $d = '' ) {
echo apply_filters ( 'the_modified_date' , get_the_modified_date ( $d ), $d );
}
function get_the_modified_date ( $d = '' ) {
if ( '' == $d )
2006-08-30 17:46:31 -04:00
$the_time = get_post_modified_time ( get_option ( 'date_format' ));
2006-08-30 12:46:08 -04:00
else
$the_time = get_post_modified_time ( $d );
return apply_filters ( 'get_the_modified_date' , $the_time , $d );
}
2005-01-07 17:01:59 -05:00
function the_time ( $d = '' ) {
2005-02-05 22:40:08 -05:00
echo apply_filters ( 'the_time' , get_the_time ( $d ), $d );
2005-01-07 17:01:59 -05:00
}
2005-10-17 19:41:28 -04:00
2005-01-07 17:01:59 -05:00
function get_the_time ( $d = '' ) {
if ( '' == $d )
2006-08-30 17:46:31 -04:00
$the_time = get_post_time ( get_option ( 'time_format' ));
2005-01-07 17:01:59 -05:00
else
2005-01-18 21:21:36 -05:00
$the_time = get_post_time ( $d );
2005-02-05 22:40:08 -05:00
return apply_filters ( 'get_the_time' , $the_time , $d );
2005-01-07 17:01:59 -05:00
}
2005-10-17 19:41:28 -04:00
2005-01-18 21:21:36 -05:00
function get_post_time ( $d = 'U' , $gmt = false ) { // returns timestamp
2005-01-07 17:01:59 -05:00
global $post ;
if ( $gmt )
2005-01-18 21:21:36 -05:00
$time = $post -> post_date_gmt ;
2005-01-07 17:01:59 -05:00
else
2005-01-18 21:21:36 -05:00
$time = $post -> post_date ;
$time = mysql2date ( $d , $time );
2005-02-05 22:40:08 -05:00
return apply_filters ( 'get_the_time' , $time , $d , $gmt );
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2005-11-10 18:31:30 -05:00
function the_modified_time ( $d = '' ) {
echo apply_filters ( 'the_modified_time' , get_the_modified_time ( $d ), $d );
}
function get_the_modified_time ( $d = '' ) {
if ( '' == $d )
2006-08-30 17:46:31 -04:00
$the_time = get_post_modified_time ( get_option ( 'time_format' ));
2005-11-10 18:31:30 -05:00
else
$the_time = get_post_modified_time ( $d );
return apply_filters ( 'get_the_modified_time' , $the_time , $d );
}
function get_post_modified_time ( $d = 'U' , $gmt = false ) { // returns timestamp
global $post ;
if ( $gmt )
$time = $post -> post_modified_gmt ;
else
$time = $post -> post_modified ;
$time = mysql2date ( $d , $time );
return apply_filters ( 'get_the_modified_time' , $time , $d , $gmt );
}
2004-01-27 04:58:01 -05:00
function the_weekday () {
2006-04-01 19:20:11 -05:00
global $wp_locale , $id , $post ;
$the_weekday = $wp_locale -> get_weekday ( mysql2date ( 'w' , $post -> post_date ));
2005-10-17 19:41:28 -04:00
$the_weekday = apply_filters ( 'the_weekday' , $the_weekday );
echo $the_weekday ;
2004-01-27 04:58:01 -05:00
}
2005-10-17 19:41:28 -04:00
2004-01-27 04:58:01 -05:00
function the_weekday_date ( $before = '' , $after = '' ) {
2006-04-01 19:20:11 -05:00
global $wp_locale , $id , $post , $day , $previousweekday ;
2005-10-17 19:41:28 -04:00
$the_weekday_date = '' ;
if ( $day != $previousweekday ) {
$the_weekday_date .= $before ;
2006-04-01 19:20:11 -05:00
$the_weekday_date .= $wp_locale -> get_weekday ( mysql2date ( 'w' , $post -> post_date ));
2005-10-17 19:41:28 -04:00
$the_weekday_date .= $after ;
$previousweekday = $day ;
}
$the_weekday_date = apply_filters ( 'the_weekday_date' , $the_weekday_date , $before , $after );
echo $the_weekday_date ;
2004-01-27 04:58:01 -05:00
}
2006-06-07 19:17:59 -04:00
function wp_head () {
do_action ( 'wp_head' );
}
function wp_footer () {
do_action ( 'wp_footer' );
}
2005-11-07 04:47:51 -05:00
function rsd_link () {
2006-06-17 19:38:45 -04:00
echo ' <link rel="EditURI" type="application/rsd+xml" title="RSD" href="' . get_bloginfo ( 'wpurl' ) . " /xmlrpc.php?rsd \" /> \n " ;
2005-11-07 04:47:51 -05:00
}
2006-02-18 02:40:43 -05:00
function noindex () {
// If the blog is not public, tell robots to go away.
2006-06-17 19:38:45 -04:00
if ( '0' == get_option ( 'blog_public' ) )
echo " <meta name='robots' content='noindex,nofollow' /> \n " ;
2006-02-18 02:40:43 -05:00
}
2006-06-07 19:17:59 -04:00
/**
* Places a textarea according to the current user ' s preferences , filled with $content .
* Also places a script block that enables tabbing between Title and Content .
*
* @ param string Editor contents
* @ param string ( optional ) Previous form field ' s ID ( for tabbing support )
*/
function the_editor ( $content , $id = 'content' , $prev_id = 'title' ) {
2006-08-30 17:46:31 -04:00
$rows = get_option ( 'default_post_edit_rows' );
2006-06-07 19:17:59 -04:00
if (( $rows < 3 ) || ( $rows > 100 ))
$rows = 12 ;
$rows = " rows=' $rows ' " ;
the_quicktags ();
if ( user_can_richedit () )
add_filter ( 'the_editor_content' , 'wp_richedit_pre' );
$the_editor = apply_filters ( 'the_editor' , " <div><textarea class='mceEditor' $rows cols='40' name=' $id ' tabindex='2' id=' $id '>%s</textarea></div> \n " );
$the_editor_content = apply_filters ( 'the_editor_content' , $content );
printf ( $the_editor , $the_editor_content );
?>
< script type = " text/javascript " >
//<!--
edCanvas = document . getElementById ( '<?php echo $id; ?>' );
< ? php if ( user_can_richedit () ) : ?>
// This code is meant to allow tabbing from Title to Post (TinyMCE).
if ( tinyMCE . isMSIE )
document . getElementById ( '<?php echo $prev_id; ?>' ) . onkeydown = function ( e )
{
e = e ? e : window . event ;
if ( e . keyCode == 9 && ! e . shiftKey && ! e . controlKey && ! e . altKey ) {
var i = tinyMCE . selectedInstance ;
if ( typeof i == 'undefined' )
return true ;
tinyMCE . execCommand ( " mceStartTyping " );
this . blur ();
i . contentWindow . focus ();
e . returnValue = false ;
return false ;
}
}
else
document . getElementById ( '<?php echo $prev_id; ?>' ) . onkeypress = function ( e )
{
e = e ? e : window . event ;
if ( e . keyCode == 9 && ! e . shiftKey && ! e . controlKey && ! e . altKey ) {
var i = tinyMCE . selectedInstance ;
if ( typeof i == 'undefined' )
return true ;
tinyMCE . execCommand ( " mceStartTyping " );
this . blur ();
i . contentWindow . focus ();
e . returnValue = false ;
return false ;
}
}
< ? php endif ; ?>
//-->
</ script >
< ? php
}
2005-11-10 19:48:31 -05:00
?>