e107_plugins/blogcalendar_menu/archive.php
<?php
/*
* e107 website system
*
* Copyright (C) 2008-2009 e107 Inc (e107.org)
* Released under the terms and conditions of the
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
*
*
*
* $Source: /cvs_backup/e107_0.8/e107_plugins/blogcalendar_menu/archive.php,v $
* $Revision$
* $Date$
* $Author$
*/
/*
| Based on code by: Thomas Bouve (crahan@gmx.net)
*/
require_once(__DIR__."/../../class2.php");
require_once(e_HANDLER."userclass_class.php");
e107::includeLan(e_PLUGIN."blogcalendar_menu/languages/".e_LANGUAGE.".php");
require_once("calendar.php");
require_once("functions.php");
e107::title(BLOGCAL_L1." - ".BLOGCAL_L2);
require_once(HEADERF);
// ---------------------
// initialize some cruft
// ---------------------
$bcSql = new db;
$prefix = e_PLUGIN_ABS."blogcalendar_menu";
$marray = e107::getDate()->terms('month');
// if nr of rows per month is not set, default to 3
$months_per_row = (!empty($pref['blogcal_mpr'])) ? $pref['blogcal_mpr']: "3";
$pref['blogcal_ws'] = "monday";
// -------------------------------------
// what year are we supposed to display?
// -------------------------------------
$cur_year = date("Y");
$cur_month = date("n");
$cur_day = date("j");
if (strpos(e_QUERY, "year") !== false)
{
$tmp = explode(".", e_QUERY);
if (is_numeric($tmp[1]))
{
$req_year = intval($tmp[1]);
}
}
if (!isset($req_year)) $req_year = $cur_year;
// --------------------------------
// look for the first and last year
// --------------------------------
$bcSql->gen("SELECT news_id, news_datestamp from #news ORDER BY news_datestamp LIMIT 0,1");
$first_post = $bcSql->fetch();
$start_year = date("Y", $first_post['news_datestamp']);
$end_year = $cur_year;
// ----------------------
// build the yearselector
// ----------------------
$year_selector = "<div class='forumheader' style='text-align: center; margin-bottom: 2px;'>";
$year_selector .= "".BLOGCAL_ARCHIV1.": <select name='activate' onchange='urljump(this.options[selectedIndex].value)' class='tbox'>\n";
$day_links = array();
for($i = $start_year; $i <= $end_year; $i++)
{
$start = mktime(0, 0, 0, 1, 1, intval($req_year));
$end = mktime(23, 59, 59, 12, 31, intval($req_year));
// create the option entry
$year_link = $prefix."/archive.php?year.".$i;
$year_selector .= "<option value='".$year_link."'";
if ($i == $req_year)
{
$year_selector .= " selected='selected'";
if ($bcSql->select("news", "news_id, news_datestamp, news_class", "news_datestamp > {$start} AND news_datestamp < {$end}"))
{
while ($news = $bcSql->fetch())
{
if (check_class($news['news_class']))
{
list($xmonth, $xday) = explode(" ", date("n j", $news['news_datestamp']));
if (!$day_links[$xmonth][$xday])
{
$day_links[$xmonth][$xday] = e107::getUrl()->create('news/list/day', 'id='.formatDate($req_year, $xmonth, $xday));
}
}
}
}
}
$year_selector .= ">".$i."</option>\n";
}
$year_selector .= "</select>\n</div>";
// --------------------------
// create the archive display
// --------------------------
$newline = 0;
$archive = "<div style='text-align:center'>
<table class='table' border='0' cellspacing='7'>
<tr>";
$archive .= "<td colspan='{$months_per_row}'>{$year_selector}</td></tr><tr>";
for($i = 1; $i <= 12; $i++)
{
if (++$newline == $months_per_row + 1)
{
$archive .= "</tr><tr>";
$newline = 1;
}
$archive .= "<td style='vertical-align:top'>";
if(!deftrue('BOOTSTRAP'))
{
$archive .= "<div class='fcaption' style='text-align:center; margin-bottom:2px;'>";
// href the current month regardless of newsposts or any month with news
if (($req_year == $cur_year && $i == $cur_month) || $day_links[$i])
{
$archive .= "<a class='forumlink' href='".e107::getUrl()->create('news/list/month', 'id='.formatDate($req_year, $i))."'>".$marray[$i]."</a>";
}
else
{
$archive .= $marray[$i];
}
$archive .= "</div>";
}
if (($req_year == $cur_year) && ($i == $cur_month))
{
$req_day = $cur_day;
}
else
{
$req_day = "";
}
$archive .= "<div>".calendar($req_day, $i, $req_year, varset($day_links[$i]), $pref['blogcal_ws'])."</div></td>\n";
}
$archive .= "</tr></table></div>";
$ns->tablerender(BLOGCAL_L2 ." $req_year", $archive);
require_once(FOOTERF);