mirror of
				https://github.com/e107inc/e107.git
				synced 2025-10-26 11:18:09 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			160 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			160 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			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);
 |