2003-04-01 06:17:43 +00:00
< ? php
// *** b2 Archive file
2003-05-25 23:33:54 +00:00
require_once ( 'b2config.php' );
require_once ( $abspath . $b2inc . '/b2functions.php' );
2003-04-01 06:17:43 +00:00
// this is what will separate your archive links
// this is what will separate dates on weekly archive links
2003-05-06 08:06:57 +00:00
$archive_week_separator = '–' ;
2003-04-01 06:17:43 +00:00
// archive link url
$archive_link_m = $siteurl . '/' . $blogfilename . $querystring_start . 'm' . $querystring_equal ; # monthly archive
$archive_link_w = $siteurl . '/' . $blogfilename . $querystring_start . 'w' . $querystring_equal ; # weekly archive
$archive_link_p = $siteurl . '/' . $blogfilename . $querystring_start . 'p' . $querystring_equal ; # post-by-post archive
// 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' ;
// --- //
$dateformat = get_settings ( 'date_format' );
$time_difference = get_settings ( 'time_difference' );
if ( ! $archive_date_format_over_ride ) {
$archive_day_date_format = $dateformat ;
$archive_week_start_date_format = $dateformat ;
$archive_week_end_date_format = $dateformat ;
}
if ( basename ( $HTTP_SERVER_VARS [ 'SCRIPT_FILENAME' ]) == 'b2archives.php' )
include ( 'blog.header.php' );
if ( ! isset ( $querycount )) {
$querycount = 0 ;
}
$now = date ( 'Y-m-d H:i:s' ,( time () + ( $time_difference * 3600 )));
if ( $archive_mode == 'monthly' ) {
2003-06-07 23:19:42 +00:00
$arc_sql = " SELECT DISTINCT YEAR(post_date) AS yr, MONTH(post_date) AS mn FROM $tableposts WHERE post_date < ' $now ' AND post_category > 0 ORDER BY post_date DESC " ;
2003-04-01 06:17:43 +00:00
$querycount ++ ;
2003-06-07 23:19:42 +00:00
$arc_results = $wpdb -> get_results ( $arc_sql );
foreach ( $arc_results as $arc_row ) {
$arc_year = $arc_row -> yr ;
$arc_month = $arc_row -> mn ;
2003-05-06 08:06:57 +00:00
echo " <li><a href= \" $archive_link_m $arc_year " . zeroise ( $arc_month , 2 ) . '">' ;
2003-04-01 06:17:43 +00:00
echo $month [ zeroise ( $arc_month , 2 )] . ' ' . $arc_year ;
2003-05-06 08:06:57 +00:00
echo " </a></li> \n " ;
2003-04-01 06:17:43 +00:00
}
} elseif ( $archive_mode == 'daily' ) {
2003-06-07 23:19:42 +00:00
$arc_sql = " SELECT DISTINCT YEAR(post_date) AS yr, MONTH(post_date) AS mn, DAYOFMONTH(post_date) as dom FROM $tableposts WHERE post_date < ' $now ' AND post_category > 0 ORDER BY post_date DESC " ;
2003-04-01 06:17:43 +00:00
$querycount ++ ;
2003-06-07 23:19:42 +00:00
$arc_results = $wpdb -> get_results ( $arc_sql );
foreach ( $arc_results as $arc_row ) {
$arc_year = $arc_row -> yr ;
$arc_month = $arc_row -> mn ;
$arc_dayofmonth = $arc_row -> dom ;
2003-05-06 08:06:57 +00:00
echo " <li><a href= \" $archive_link_m $arc_year " . zeroise ( $arc_month , 2 ) . zeroise ( $arc_dayofmonth , 2 ) . '">' ;
2003-04-01 06:17:43 +00:00
echo mysql2date ( $archive_day_date_format , $arc_year . '-' . zeroise ( $arc_month , 2 ) . '-' . zeroise ( $arc_dayofmonth , 2 ) . ' 00:00:00' );
2003-05-06 08:06:57 +00:00
echo " </a></li> \n " ;
2003-04-01 06:17:43 +00:00
}
} elseif ( $archive_mode == 'weekly' ) {
if ( ! isset ( $start_of_week )) {
$start_of_week = 1 ;
}
2003-06-07 23:19:42 +00:00
$arc_sql = " SELECT DISTINCT YEAR(post_date) AS yr, MONTH(post_date) AS mn, DAYOFMONTH(post_date) AS dom, WEEK(post_date) AS wk FROM $tableposts WHERE post_date < ' $now ' AND post_category > 0 ORDER BY post_date DESC " ;
2003-04-01 06:17:43 +00:00
$querycount ++ ;
2003-06-07 23:19:42 +00:00
$arc_results = $wpdb -> get_results ( $arc_sql );
2003-04-01 06:17:43 +00:00
$arc_w_last = '' ;
2003-06-07 23:19:42 +00:00
foreach ( $arc_results as $arc_row ) {
$arc_year = $arc_row -> yr ;
$arc_w = $arc_row -> wk ;
2003-04-01 06:17:43 +00:00
if ( $arc_w != $arc_w_last ) {
$arc_w_last = $arc_w ;
2003-06-07 23:19:42 +00:00
$arc_ymd = $arc_year . '-' . zeroise ( $arc_row -> mn , 2 ) . '-' . zeroise ( $arc_row -> dom , 2 );
2003-04-01 06:17:43 +00:00
$arc_week = get_weekstartend ( $arc_ymd , $start_of_week );
$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' ]);
2003-05-06 08:06:57 +00:00
echo " <li><a href= \" $siteurl / " . $blogfilename . " ?m= $arc_year &w= $arc_w\ " > " ;
2003-04-01 06:17:43 +00:00
echo $arc_week_start . $archive_week_separator . $arc_week_end ;
2003-05-06 08:06:57 +00:00
echo " </a></li> \n " ;
2003-04-01 06:17:43 +00:00
}
}
} elseif ( $archive_mode == 'postbypost' ) {
2003-06-07 23:19:42 +00:00
$requestarc = " SELECT ID, post_date, post_title FROM $tableposts WHERE post_date < ' $now ' AND post_category > 0 AND post_status = 'publish' ORDER BY post_date DESC " ;
2003-04-01 06:17:43 +00:00
$querycount ++ ;
2003-06-07 23:19:42 +00:00
$resultarc = $wpdb -> get_results ( $requestarc );
foreach ( $resultarc as $row ) {
2003-04-01 06:17:43 +00:00
if ( $row -> post_date != '0000-00-00 00:00:00' ) {
2003-05-06 08:06:57 +00:00
echo " <li><a href= \" $archive_link_p " . $row -> ID . '">' ;
2003-04-01 06:17:43 +00:00
$arc_title = stripslashes ( $row -> post_title );
if ( $arc_title ) {
echo strip_tags ( $arc_title );
} else {
echo $row -> ID ;
}
2003-05-06 08:06:57 +00:00
echo " </a></li> \n " ;
2003-04-01 06:17:43 +00:00
}
}
}
2003-05-06 08:06:57 +00:00
# echo $querycount."<br />\n";
# timer_stop(1,8);
2003-04-01 06:17:43 +00:00
?>