2004-01-27 10:58:01 +01:00
< ? php
/* Note: these tags go anywhere in the template */
2004-07-11 01:34:47 +02:00
function wp_loginout () {
global $user_level ;
get_currentuserinfo ();
if ( 0 == $user_level ) :
$link = '<a href="' . get_settings ( 'siteurl' ) . '/wp-login.php">' . __ ( 'Login' ) . '</a>' ;
else :
$link = '<a href="' . get_settings ( 'siteurl' ) . '/wp-login.php?action=logout">' . __ ( 'Logout' ) . '</a>' ;
endif ;
echo apply_filters ( 'loginout' , $link );
}
function wp_register () {
global $user_level ;
get_currentuserinfo ();
2004-07-12 08:24:08 +02:00
if ( 0 == $user_level && get_settings ( 'users_can_register' ) ) :
2004-07-11 01:34:47 +02:00
$link = '<a href="' . get_settings ( 'siteurl' ) . '/wp-register.php">' . __ ( 'Register' ) . '</a>' ;
else :
$link = '<a href="' . get_settings ( 'siteurl' ) . '/wp-admin/">' . __ ( 'Site Admin' ) . '</a>' ;
endif ;
echo apply_filters ( 'register' , $link );
}
function wp_meta () {
do_action ( 'wp_meta' , 1 );
}
2004-01-27 10:58:01 +01:00
function bloginfo ( $show = '' ) {
$info = get_bloginfo ( $show );
$info = apply_filters ( 'bloginfo' , $info );
2004-04-22 09:41:57 +02:00
echo convert_chars ( $info );
2004-01-27 10:58:01 +01:00
}
function bloginfo_rss ( $show = '' ) {
$info = strip_tags ( get_bloginfo ( $show ));
2004-04-22 09:41:57 +02:00
echo convert_chars ( $info );
2004-01-27 10:58:01 +01:00
}
function bloginfo_unicode ( $show = '' ) {
$info = get_bloginfo ( $show );
2004-04-22 09:41:57 +02:00
echo convert_chars ( $info );
2004-01-27 10:58:01 +01:00
}
function get_bloginfo ( $show = '' ) {
2004-02-05 21:55:50 +01:00
2004-09-30 19:56:16 +02:00
switch ( $show ) {
2004-10-04 08:23:53 +02:00
case 'url' :
case 'home' :
case 'siteurl' :
2004-09-30 19:56:16 +02:00
$output = get_settings ( 'home' );
break ;
2004-10-04 08:23:53 +02:00
case 'wpurl' :
$output = get_settings ( 'siteurl' );
break ;
2004-09-30 19:56:16 +02:00
case 'description' :
$output = get_settings ( 'blogdescription' );
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' :
$output = get_settings ( 'siteurl' ) . '/xmlrpc.php' ;
break ;
case 'stylesheet_url' :
2004-10-13 05:20:03 +02:00
$output = get_stylesheet ();
2004-09-30 19:56:16 +02:00
if ( empty ( $output ) || $output == 'default' ) {
$output = get_settings ( 'siteurl' ) . " /wp-layout.css " ;
} else {
$output = get_settings ( 'siteurl' ) . " /wp-content/themes/ $output /style.css " ;
}
break ;
case 'stylesheet_directory' :
2004-10-13 05:20:03 +02:00
$output = get_stylesheet ();
2004-09-30 19:56:16 +02:00
if ( empty ( $output ) || $output == 'default' ) {
$output = get_settings ( 'siteurl' );
} else {
$output = get_settings ( 'siteurl' ) . " /wp-content/themes/ $output " ;
}
break ;
case 'template_directory' :
case 'template_url' :
2004-10-13 05:20:03 +02:00
$output = get_template ();
2004-09-30 19:56:16 +02:00
if ( empty ( $output ) || $output == 'default' ) {
$output = get_settings ( 'siteurl' );
} else {
$output = get_settings ( 'siteurl' ) . " /wp-content/themes/ $output " ;
}
break ;
case 'admin_email' :
$output = get_settings ( 'admin_email' );
break ;
case 'charset' :
$output = get_settings ( 'blog_charset' );
if ( '' == $output ) $output = 'UTF-8' ;
break ;
case 'version' :
global $wp_version ;
$output = $wp_version ;
break ;
case 'name' :
default :
$output = get_settings ( 'blogname' );
break ;
}
return $output ;
2004-01-27 10:58:01 +01:00
}
function wp_title ( $sep = '»' , $display = true ) {
2004-05-24 10:22:18 +02:00
global $wpdb ;
2004-09-09 05:45:51 +02:00
global $m , $year , $monthnum , $day , $category_name , $month , $posts ;
$cat = get_query_var ( 'cat' );
$p = get_query_var ( 'p' );
$name = get_query_var ( 'name' );
$category_name = get_query_var ( 'category_name' );
2004-01-27 10:58:01 +01:00
// If there's a category
if ( ! empty ( $cat )) {
2004-01-31 01:03:51 +01:00
if ( ! stristr ( $cat , '-' )) { // category excluded
2004-06-18 02:22:09 +02:00
$title = get_the_category_by_ID ( $cat );
2004-01-31 01:03:51 +01:00
}
2004-01-27 10:58:01 +01:00
}
if ( ! empty ( $category_name )) {
2004-07-28 05:30:15 +02:00
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
}
}
2004-06-18 02:22:09 +02:00
$title = $wpdb -> get_var ( " SELECT cat_name FROM $wpdb->categories WHERE category_nicename = ' $category_name ' " );
2004-01-27 10:58:01 +01:00
}
// If there's a month
if ( ! empty ( $m )) {
$my_year = substr ( $m , 0 , 4 );
$my_month = $month [ substr ( $m , 4 , 2 )];
$title = " $my_year $sep $my_month " ;
}
if ( ! empty ( $year )) {
$title = $year ;
if ( ! empty ( $monthnum )) {
$title .= " $sep " . $month [ zeroise ( $monthnum , 2 )];
}
if ( ! empty ( $day )) {
$title .= " $sep " . zeroise ( $day , 2 );
}
}
// If there's a post
2004-10-03 19:07:53 +02:00
if ( is_single () || is_page ()) {
2004-06-18 02:22:09 +02:00
$title = strip_tags ( $posts [ 0 ] -> post_title );
2004-01-27 10:58:01 +01:00
$title = apply_filters ( 'single_post_title' , $title );
}
// Send it out
if ( $display && isset ( $title )) {
echo " $sep $title " ;
} elseif ( ! $display && isset ( $title )) {
return " $sep $title " ;
}
}
function single_post_title ( $prefix = '' , $display = true ) {
2004-09-09 05:45:51 +02:00
global $wpdb ;
$p = get_query_var ( 'p' );
$name = get_query_var ( 'name' );
2004-01-27 10:58:01 +01:00
if ( intval ( $p ) || '' != $name ) {
if ( ! $p ) {
2004-05-24 10:22:18 +02:00
$p = $wpdb -> get_var ( " SELECT ID FROM $wpdb->posts WHERE post_name = ' $name ' " );
2004-01-27 10:58:01 +01:00
}
$post_data = get_postdata ( $p );
$title = $post_data [ 'Title' ];
$title = apply_filters ( 'single_post_title' , $title );
if ( $display ) {
2004-06-18 02:22:09 +02:00
echo $prefix . strip_tags ( $title );
2004-01-27 10:58:01 +01:00
} else {
2004-06-18 02:22:09 +02:00
return strip_tags ( $title );
2004-01-27 10:58:01 +01:00
}
}
}
function single_cat_title ( $prefix = '' , $display = true ) {
2004-09-09 05:45:51 +02:00
$cat = get_query_var ( 'cat' );
2004-01-27 10:58:01 +01:00
if ( ! empty ( $cat ) && ! ( strtoupper ( $cat ) == 'ALL' )) {
$my_cat_name = get_the_category_by_ID ( $cat );
if ( ! empty ( $my_cat_name )) {
if ( $display )
2004-06-18 02:22:09 +02:00
echo $prefix . strip_tags ( $my_cat_name );
2004-01-27 10:58:01 +01:00
else
2004-06-18 02:22:09 +02:00
return strip_tags ( $my_cat_name );
2004-01-27 10:58:01 +01:00
}
}
}
function single_month_title ( $prefix = '' , $display = true ) {
2004-10-19 01:52:36 +02:00
global $m , $monthnum , $month , $year ;
if ( ! empty ( $monthnum ) && ! empty ( $year )) {
2004-10-19 01:45:26 +02:00
$my_year = $year ;
$my_month = $month [ $monthnum ];
2004-10-19 01:52:36 +02:00
} elseif ( ! empty ( $m )) {
$my_year = substr ( $m , 0 , 4 );
$my_month = $month [ substr ( $m , 4 , 2 )];
}
if ( ! empty ( $my_month ) && $display ) {
echo $prefix . $my_month . $prefix . $my_year ;
} else {
return $monthnum ;
2004-07-06 19:04:07 +02:00
}
2004-01-27 10:58:01 +01:00
}
/* link navigation hack by Orien http://icecode.com/ */
2004-07-06 19:04:07 +02:00
function get_archives_link ( $url , $text , $format = 'html' , $before = '' , $after = '' ) {
$text = wptexturize ( $text );
2004-12-12 21:41:19 +01:00
$title_text = wp_specialchars ( $text , 1 );
2004-07-29 01:09:33 +02:00
2004-07-06 19:04:07 +02:00
if ( 'link' == $format ) {
2004-07-29 01:09:33 +02:00
return " \t <link rel='archives' title=' $title_text ' href=' $url ' /> \n " ;
2004-07-06 19:04:07 +02:00
} elseif ( 'option' == $format ) {
return " \t <option value=' $url '> $text </option> \n " ;
} elseif ( 'html' == $format ) {
2004-07-29 01:09:33 +02:00
return " \t <li> $before <a href=' $url ' title=' $title_text '> $text </a> $after </li> \n " ;
2004-07-06 19:04:07 +02:00
} else { // custom
2004-07-29 01:09:33 +02:00
return " \t $before <a href=' $url ' title=' $title_text '> $text </a> $after\n " ;
2004-07-06 19:04:07 +02:00
}
2004-01-27 10:58:01 +01:00
}
2004-04-24 21:23:57 +02:00
function wp_get_archives ( $args = '' ) {
parse_str ( $args , $r );
if ( ! isset ( $r [ 'type' ])) $r [ 'type' ] = '' ;
if ( ! isset ( $r [ 'limit' ])) $r [ 'limit' ] = '' ;
if ( ! isset ( $r [ 'format' ])) $r [ 'format' ] = 'html' ;
if ( ! isset ( $r [ 'before' ])) $r [ 'before' ] = '' ;
if ( ! isset ( $r [ 'after' ])) $r [ 'after' ] = '' ;
if ( ! isset ( $r [ 'show_post_count' ])) $r [ 'show_post_count' ] = false ;
get_archives ( $r [ 'type' ], $r [ 'limit' ], $r [ 'format' ], $r [ 'before' ], $r [ 'after' ], $r [ 'show_post_count' ]);
}
function get_archives ( $type = '' , $limit = '' , $format = 'html' , $before = '' , $after = '' , $show_post_count = false ) {
2004-03-01 07:13:32 +01:00
global $querystring_start , $querystring_equal , $querystring_separator , $month , $wpdb ;
2004-01-27 10:58:01 +01:00
if ( '' == $type ) {
2004-09-05 02:24:28 +02:00
$type = 'monthly' ;
2004-01-27 10:58:01 +01:00
}
if ( '' != $limit ) {
$limit = ( int ) $limit ;
2004-02-20 02:42:39 +01:00
$limit = ' LIMIT ' . $limit ;
2004-01-27 10:58:01 +01:00
}
// this is what will separate dates on weekly archive links
$archive_week_separator = '–' ;
// archive link url
2004-02-26 17:15:48 +01:00
$archive_link_m = get_settings ( 'siteurl' ) . '/' . get_settings ( 'blogfilename' ) . $querystring_start . 'm' . $querystring_equal ; # monthly archive;
$archive_link_w = get_settings ( 'siteurl' ) . '/' . get_settings ( 'blogfilename' ) . $querystring_start . 'w' . $querystring_equal ; # weekly archive;
$archive_link_p = get_settings ( 'siteurl' ) . '/' . get_settings ( 'blogfilename' ) . $querystring_start . 'p' . $querystring_equal ; # post-by-post archive;
2004-01-27 10:58:01 +01:00
// 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 ) {
2004-02-17 05:56:29 +01:00
$archive_day_date_format = get_settings ( 'date_format' );
$archive_week_start_date_format = get_settings ( 'date_format' );
$archive_week_end_date_format = get_settings ( 'date_format' );
2004-01-27 10:58:01 +01:00
}
2004-04-24 23:52:24 +02:00
$add_hours = intval ( get_settings ( 'gmt_offset' ));
$add_minutes = intval ( 60 * ( get_settings ( 'gmt_offset' ) - $add_hours ));
2004-02-25 18:38:21 +01:00
$now = current_time ( 'mysql' );
2004-01-27 10:58:01 +01:00
if ( 'monthly' == $type ) {
2004-05-24 10:22:18 +02: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_date < ' $now ' AND post_status = 'publish' GROUP BY YEAR(post_date), MONTH(post_date) ORDER BY post_date DESC " . $limit );
2004-01-27 10:58:01 +01:00
if ( $arcresults ) {
2004-05-17 02:31:33 +02:00
$afterafter = $after ;
2004-01-27 10:58:01 +01:00
foreach ( $arcresults as $arcresult ) {
$url = get_month_link ( $arcresult -> year , $arcresult -> month );
if ( $show_post_count ) {
2004-02-20 02:42:39 +01:00
$text = sprintf ( '%s %d' , $month [ zeroise ( $arcresult -> month , 2 )], $arcresult -> year );
2004-05-17 02:31:33 +02:00
$after = ' (' . $arcresult -> posts . ')' . $afterafter ;
2004-01-27 10:58:01 +01:00
} else {
2004-02-20 02:42:39 +01:00
$text = sprintf ( '%s %d' , $month [ zeroise ( $arcresult -> month , 2 )], $arcresult -> year );
2004-01-27 10:58:01 +01:00
}
echo get_archives_link ( $url , $text , $format , $before , $after );
}
}
} elseif ( 'daily' == $type ) {
2004-05-24 10:22:18 +02: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_date < ' $now ' AND post_status = 'publish' ORDER BY post_date DESC " . $limit );
2004-01-27 10:58:01 +01: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 ) {
2004-03-01 07:13:32 +01:00
$start_of_week = get_settings ( 'start_of_week' );
2004-05-24 10:22:18 +02: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_date < ' $now ' AND post_status = 'publish' ORDER BY post_date DESC " . $limit );
2004-01-27 10:58:01 +01: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 ;
2004-03-01 07:13:32 +01:00
$arc_week = get_weekstartend ( $arcresult -> yyyymmdd , get_settings ( 'start_of_week' ));
2004-01-27 10:58:01 +01: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' ]);
2004-04-28 09:27:03 +02:00
$url = sprintf ( '%s/%s%sm%s%s%sw%s%d' , get_settings ( 'home' ), get_settings ( 'blogfilename' ), $querystring_start ,
2004-01-27 10:58:01 +01:00
$querystring_equal , $arc_year , $querystring_separator ,
$querystring_equal , $arcresult -> week );
$text = $arc_week_start . $archive_week_separator . $arc_week_end ;
echo get_archives_link ( $url , $text , $format , $before , $after );
}
}
}
} elseif ( 'postbypost' == $type ) {
2004-05-24 10:22:18 +02:00
$arcresults = $wpdb -> get_results ( " SELECT ID, post_date, post_title FROM $wpdb->posts WHERE post_date < ' $now ' AND post_status = 'publish' ORDER BY post_date DESC " . $limit );
2004-01-27 10:58:01 +01:00
if ( $arcresults ) {
foreach ( $arcresults as $arcresult ) {
if ( $arcresult -> post_date != '0000-00-00 00:00:00' ) {
$url = get_permalink ( $arcresult -> ID );
2004-06-18 02:22:09 +02:00
$arc_title = $arcresult -> post_title ;
2004-01-27 10:58:01 +01:00
if ( $arc_title ) {
$text = strip_tags ( $arc_title );
} else {
$text = $arcresult -> ID ;
}
echo get_archives_link ( $url , $text , $format , $before , $after );
}
}
}
}
}
2004-09-10 01:07:46 +02:00
// Used in get_calendar
function calendar_week_mod ( $num ) {
$base = 7 ;
return ( $num - $base * floor ( $num / $base ));
}
2004-01-27 10:58:01 +01:00
function get_calendar ( $daylength = 1 ) {
2004-05-24 10:22:18 +02:00
global $wpdb , $m , $monthnum , $year , $timedifference , $month , $month_abbrev , $weekday , $weekday_initial , $weekday_abbrev , $posts ;
2004-01-27 10:58:01 +01:00
// Quick check. If we have no posts at all, abort!
if ( ! $posts ) {
2004-05-24 10:22:18 +02:00
$gotsome = $wpdb -> get_var ( " SELECT ID from $wpdb->posts WHERE post_status = 'publish' ORDER BY post_date DESC LIMIT 1 " );
2004-01-27 10:58:01 +01:00
if ( ! $gotsome )
return ;
}
2004-04-21 00:56:47 +02:00
if ( isset ( $_GET [ 'w' ])) {
$w = '' . intval ( $_GET [ 'w' ]);
2004-01-27 10:58:01 +01:00
}
2004-04-24 23:52:24 +02:00
2004-09-10 01:07:46 +02:00
// week_begins = 0 stands for sunday
$week_begins = intval ( get_settings ( 'start_of_week' ));
2004-04-24 23:52:24 +02:00
$add_hours = intval ( get_settings ( 'gmt_offset' ));
$add_minutes = intval ( 60 * ( get_settings ( 'gmt_offset' ) - $add_hours ));
2004-01-27 10:58:01 +01:00
// Let's figure out when we are
if ( ! empty ( $monthnum ) && ! empty ( $year )) {
2004-02-25 18:11:26 +01:00
$thismonth = '' . zeroise ( intval ( $monthnum ), 2 );
2004-01-27 10:58:01 +01:00
$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 {
2004-03-12 04:36:16 +01:00
$thismonth = '' . zeroise ( intval ( substr ( $m , 4 , 2 )), 2 );
2004-01-27 10:58:01 +01:00
}
} else {
2004-04-24 23:52:24 +02:00
$thisyear = gmdate ( 'Y' , current_time ( 'timestamp' ) + get_settings ( 'gmt_offset' ) * 3600 );
$thismonth = gmdate ( 'm' , current_time ( 'timestamp' ) + get_settings ( 'gmt_offset' ) * 3600 );
2004-01-27 10:58:01 +01:00
}
$unixmonth = mktime ( 0 , 0 , 0 , $thismonth , 1 , $thisyear );
// Get the next and previous month and year with at least one post
2004-02-25 18:11:26 +01:00
$previous = $wpdb -> get_row ( " SELECT DISTINCT MONTH(post_date) AS month, YEAR(post_date) AS year
2004-05-24 10:22:18 +02:00
FROM $wpdb -> posts
2004-03-25 02:45:07 +01:00
WHERE post_date < '$thisyear-$thismonth-01'
2004-01-27 10:58:01 +01:00
AND post_status = 'publish'
ORDER BY post_date DESC
LIMIT 1 " );
2004-03-25 02:45:07 +01:00
$next = $wpdb -> get_row ( " SELECT DISTINCT MONTH(post_date) AS month, YEAR(post_date) AS year
2004-05-24 10:22:18 +02:00
FROM $wpdb -> posts
2004-01-27 10:58:01 +01:00
WHERE post_date > '$thisyear-$thismonth-01'
AND MONTH ( post_date ) != MONTH ( '$thisyear-$thismonth-01' )
AND post_status = 'publish'
ORDER BY post_date ASC
LIMIT 1 " );
echo ' < table id = " wp-calendar " >
< caption > ' . $month[zeroise($thismonth, 2)] . ' ' . date(' Y ', $unixmonth) . ' </ caption >
< thead >
< tr > ' ;
2004-05-16 19:07:13 +02:00
$day_abbrev = $weekday_initial ;
if ( $daylength > 1 ) {
$day_abbrev = $weekday_abbrev ;
}
2004-09-10 01:07:46 +02:00
$myweek = array ();
for ( $wdcount = 0 ; $wdcount <= 6 ; $wdcount ++ ) {
$myweek [] = $weekday [( $wdcount + $week_begins ) % 7 ];
}
foreach ( $myweek as $wd ) {
2004-05-16 19:07:13 +02:00
echo " \n \t \t <th abbr= \" $wd\ " scope = \ " col \" title= \" $wd\ " > " . $day_abbrev[$wd] . '</th>';
2004-01-27 10:58:01 +01:00
}
echo '
</ tr >
</ thead >
< tfoot >
< tr > ' ;
if ( $previous ) {
echo " \n \t \t " . '<td abbr="' . $month [ zeroise ( $previous -> month , 2 )] . '" colspan="3" id="prev"><a href="' .
2004-05-16 19:07:13 +02:00
get_month_link ( $previous -> year , $previous -> month ) . '" title="' . sprintf ( __ ( 'View posts for %1$s %2$s' ), $month [ zeroise ( $previous -> month , 2 )], date ( 'Y' , mktime ( 0 , 0 , 0 , $previous -> month , 1 , $previous -> year ))) . '">« ' . $month_abbrev [ $month [ zeroise ( $previous -> month , 2 )]] . '</a></td>' ;
2004-01-27 10:58:01 +01:00
} else {
echo " \n \t \t " . '<td colspan="3" id="prev" class="pad"> </td>' ;
}
echo " \n \t \t " . '<td class="pad"> </td>' ;
if ( $next ) {
echo " \n \t \t " . '<td abbr="' . $month [ zeroise ( $next -> month , 2 )] . '" colspan="3" id="next"><a href="' .
get_month_link ( $next -> year , $next -> month ) . '" title="View posts for ' . $month [ zeroise ( $next -> month , 2 )] . ' ' .
2004-08-03 23:59:29 +02:00
date ( 'Y' , mktime ( 0 , 0 , 0 , $next -> month , 1 , $next -> year )) . '">' . $month_abbrev [ $month [ zeroise ( $next -> month , 2 )]] . ' »</a></td>' ;
2004-01-27 10:58:01 +01:00
} else {
echo " \n \t \t " . '<td colspan="3" id="next" class="pad"> </td>' ;
}
echo '
</ tr >
</ tfoot >
< tbody >
< tr > ' ;
// Get days with posts
2004-03-25 02:45:07 +01:00
$dayswithposts = $wpdb -> get_results ( " SELECT DISTINCT DAYOFMONTH(post_date)
2004-05-24 10:22:18 +02:00
FROM $wpdb -> posts WHERE MONTH ( post_date ) = $thismonth
2004-01-27 10:58:01 +01:00
AND YEAR ( post_date ) = $thisyear
AND post_status = 'publish'
2004-02-25 18:11:26 +01:00
AND post_date < '" . current_time(' mysql ') . ' \ '' , ARRAY_N );
2004-01-27 10:58:01 +01:00
if ( $dayswithposts ) {
foreach ( $dayswithposts as $daywith ) {
$daywithpost [] = $daywith [ 0 ];
}
} else {
$daywithpost = array ();
}
2004-02-20 02:14:33 +01:00
if ( strstr ( $_SERVER [ 'HTTP_USER_AGENT' ], 'MSIE' ) ||
strstr ( strtolower ( $_SERVER [ 'HTTP_USER_AGENT' ]), 'camino' ) ||
strstr ( strtolower ( $_SERVER [ 'HTTP_USER_AGENT' ]), 'safari' )) {
2004-01-27 10:58:01 +01:00
$ak_title_separator = " \n " ;
} else {
2004-02-20 02:14:33 +01:00
$ak_title_separator = ', ' ;
2004-01-27 10:58:01 +01:00
}
$ak_titles_for_day = array ();
2004-03-25 02:45:07 +01:00
$ak_post_titles = $wpdb -> get_results ( " SELECT post_title, DAYOFMONTH(post_date) as dom "
2004-05-24 10:22:18 +02:00
. " FROM $wpdb->posts "
2004-03-25 02:45:07 +01:00
. " WHERE YEAR(post_date) = ' $thisyear ' "
. " AND MONTH(post_date) = ' $thismonth ' "
2004-02-25 18:11:26 +01:00
. " AND post_date < ' " . current_time ( 'mysql' ) . " ' "
2004-01-27 10:58:01 +01:00
. " AND post_status = 'publish' "
);
if ( $ak_post_titles ) {
foreach ( $ak_post_titles as $ak_post_title ) {
2004-02-20 02:14:33 +01:00
if ( empty ( $ak_titles_for_day [ 'day_' . $ak_post_title -> dom ])) {
$ak_titles_for_day [ 'day_' . $ak_post_title -> dom ] = '' ;
2004-01-27 10:58:01 +01:00
}
if ( empty ( $ak_titles_for_day [ " $ak_post_title->dom " ])) { // first one
2004-06-18 02:22:09 +02:00
$ak_titles_for_day [ " $ak_post_title->dom " ] = str_replace ( '"' , '"' , wptexturize ( $ak_post_title -> post_title ));
2004-01-27 10:58:01 +01:00
} else {
2004-06-18 02:22:09 +02:00
$ak_titles_for_day [ " $ak_post_title->dom " ] .= $ak_title_separator . str_replace ( '"' , '"' , wptexturize ( $ak_post_title -> post_title ));
2004-01-27 10:58:01 +01:00
}
}
}
// See how much we should pad in the beginning
2004-09-10 01:07:46 +02:00
$pad = calendar_week_mod ( date ( 'w' , $unixmonth ) - $week_begins );
2004-02-20 02:14:33 +01:00
if ( 0 != $pad ) echo " \n \t \t " . '<td colspan="' . $pad . '" class="pad"> </td>' ;
2004-01-27 10:58:01 +01:00
$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 ;
2004-06-16 17:45:44 +02:00
if ( $day == gmdate ( 'j' , ( time () + ( get_settings ( 'gmt_offset' ) * 3600 ))) && $thismonth == gmdate ( 'm' , time () + ( get_settings ( 'gmt_offset' ) * 3600 )) && $thisyear == gmdate ( 'Y' , time () + ( get_settings ( 'gmt_offset' ) * 3600 )))
2004-01-27 10:58:01 +01:00
echo '<td id="today">' ;
else
2004-02-20 02:42:39 +01:00
echo '<td>' ;
2004-01-27 10:58:01 +01:00
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>' ;
2004-09-10 01:07:46 +02:00
if ( 6 == calendar_week_mod ( date ( 'w' , mktime ( 0 , 0 , 0 , $thismonth , $day , $thisyear )) - $week_begins ))
2004-01-27 10:58:01 +01:00
$newrow = true ;
}
2004-09-10 01:07:46 +02:00
$pad = 7 - calendar_week_mod ( date ( 'w' , mktime ( 0 , 0 , 0 , $thismonth , $day , $thisyear )) - $week_begins );
2004-01-27 10:58:01 +01:00
if ( $pad != 0 && $pad != 7 )
2004-02-20 02:14:33 +01:00
echo " \n \t \t " . '<td class="pad" colspan="' . $pad . '"> </td>' ;
2004-01-27 10:58:01 +01:00
echo " \n \t </tr> \n \t </tbody> \n \t </table> " ;
}
function allowed_tags () {
global $allowedtags ;
2004-05-08 01:56:33 +02:00
$allowed = '' ;
2004-01-27 10:58:01 +01:00
foreach ( $allowedtags as $tag => $attributes ) {
2004-02-20 02:42:39 +01:00
$allowed .= '<' . $tag ;
2004-01-27 10:58:01 +01:00
if ( 0 < count ( $attributes )) {
foreach ( $attributes as $attribute => $limits ) {
2004-02-20 02:42:39 +01:00
$allowed .= ' ' . $attribute . '=""' ;
2004-01-27 10:58:01 +01:00
}
}
2004-02-20 02:42:39 +01:00
$allowed .= '> ' ;
2004-01-27 10:58:01 +01:00
}
return htmlentities ( $allowed );
}
/***** Date/Time tags *****/
function the_date_xml () {
global $post ;
2004-03-25 02:45:07 +01:00
echo mysql2date ( 'Y-m-d' , $post -> post_date );
2004-01-27 10:58:01 +01:00
//echo ""+$post->post_date;
}
function the_date ( $d = '' , $before = '' , $after = '' , $echo = true ) {
2004-02-17 05:56:29 +01:00
global $id , $post , $day , $previousday , $newday ;
2004-01-27 10:58:01 +01:00
$the_date = '' ;
if ( $day != $previousday ) {
$the_date .= $before ;
if ( $d == '' ) {
2004-03-25 02:45:07 +01:00
$the_date .= mysql2date ( get_settings ( 'date_format' ), $post -> post_date );
2004-01-27 10:58:01 +01:00
} else {
2004-03-25 02:45:07 +01:00
$the_date .= mysql2date ( $d , $post -> post_date );
2004-01-27 10:58:01 +01:00
}
$the_date .= $after ;
$previousday = $day ;
}
$the_date = apply_filters ( 'the_date' , $the_date );
if ( $echo ) {
echo $the_date ;
} else {
return $the_date ;
}
}
function the_time ( $d = '' , $echo = true ) {
2004-02-17 05:56:29 +01:00
global $id , $post ;
2004-01-27 10:58:01 +01:00
if ( $d == '' ) {
2004-03-25 02:45:07 +01:00
$the_time = mysql2date ( get_settings ( 'time_format' ), $post -> post_date );
2004-01-27 10:58:01 +01:00
} else {
2004-03-25 02:45:07 +01:00
$the_time = mysql2date ( $d , $post -> post_date );
2004-01-27 10:58:01 +01:00
}
$the_time = apply_filters ( 'the_time' , $the_time );
if ( $echo ) {
echo $the_time ;
} else {
return $the_time ;
}
}
function the_weekday () {
global $weekday , $id , $post ;
2004-03-25 02:45:07 +01:00
$the_weekday = $weekday [ mysql2date ( 'w' , $post -> post_date )];
2004-01-27 10:58:01 +01:00
$the_weekday = apply_filters ( 'the_weekday' , $the_weekday );
echo $the_weekday ;
}
function the_weekday_date ( $before = '' , $after = '' ) {
global $weekday , $id , $post , $day , $previousweekday ;
$the_weekday_date = '' ;
if ( $day != $previousweekday ) {
$the_weekday_date .= $before ;
2004-03-25 02:45:07 +01:00
$the_weekday_date .= $weekday [ mysql2date ( 'w' , $post -> post_date )];
2004-01-27 10:58:01 +01:00
$the_weekday_date .= $after ;
$previousweekday = $day ;
}
$the_weekday_date = apply_filters ( 'the_weekday_date' , $the_weekday_date );
echo $the_weekday_date ;
}
2004-10-19 01:45:26 +02:00
?>