/include/inc_ext/php_calendar/php_calendar.php
http://phpwcms.googlecode.com/ · PHP · 150 lines · 111 code · 26 blank · 13 comment · 37 complexity · 53daad57f33140c6902c55b697ecb15f MD5 · raw file
- <?php
-
- ////////////////////////////////////////////////////////
-
- // PHP Calendar (version 2.3), written by Keith Devens
- // http://keithdevens.com/software/php_calendar
- // see example at http://keithdevens.com/weblog
- // License: http://keithdevens.com/software/license
-
- // enhanced by Oliver Georgi for phpwcms
-
-
- function generate_calendar($param=array()){
-
- if(!defined('THIS_YEAR')) define('THIS_YEAR', date('Y') );
- if(!defined('THIS_MONTH')) define('THIS_MONTH', date('n') );
- if(!defined('THIS_DAY')) define('THIS_DAY', date('j') );
-
- $year = empty($param['year']) ? THIS_YEAR : $param['year'];
- $month = empty($param['month']) ? THIS_MONTH : $param['month'];
- $day_name_length = empty($param['day_name_length']) ? 3 : $param['day_name_length'];
- $month_href = empty($param['month_href']) ? NULL : $param['month_href'];
- $first_day = empty($param['first_day']) ? 0 : $param['first_day'];
- $weekNr = empty($param['weekNr']) ? true : $param['weekNr'];
- $weekNrTitle = empty($param['weekNrTitle']) ? 'Wno' : $param['weekNrTitle'];
- $styleAdd = empty($param['styleAdd']) ? '' : $param['styleAdd'];
- $pn = isset($param['pn']) && is_array($param['pn']) ? $param['pn'] : array();
- $days = isset($param['days']) && is_array($param['days']) ? $param['days'] : array();
- $locale = empty($param['locale']) ? false : $param['locale'];
-
- // set correct locale
- if($locale) {
- $_oldLocale = setlocale(LC_TIME, NULL); //save current locale
- setlocale(LC_TIME, $locale);
- }
-
-
- $first_of_month = gmmktime(0,0,0,$month,1,$year);
- //remember that mktime will automatically correct if invalid dates are entered
- // for instance, mktime(0,0,0,12,32,1997) will be the date for Jan 1, 1998
- // this provides a built in "rounding" feature to generate_calendar()
-
- $day_names = array(); //generate all the day names according to the current locale
- for($n=0,$t=(3+$first_day)*86400; $n<7; $n++,$t+=86400) {//January 4, 1970 was a Sunday
- $day_names[$n] = ucfirst(gmstrftime('%A',$t)); //%A means full textual day name
- }
-
- @list($month, $year, $month_name, $weekday) = explode(',',gmstrftime('%m,%Y,%B,%w',$first_of_month));
- $weekday = ($weekday + 7 - $first_day) % 7; //adjust for $first_day
- $title = htmlentities(ucfirst($month_name)).' '.$year; //note that some locales don't capitalize month and day names
- $YYYYmm = $year.$month;
-
- //Begin calendar. Uses a real <caption>. See http://diveintomark.org/archives/2002/07/03
- @list($p, $pl) = each($pn);
- @list($n, $nl) = each($pn); //previous and next links, if applicable
- if($p) $p = '<span class="calendarPrev'.$styleAdd.'">'.($pl ? '<a href="'.htmlspecialchars($pl).'">'.$p.'</a>' : $p).'</span> ';
- if($n) $n = ' <span class="calendarNext'.$styleAdd.'">'.($nl ? '<a href="'.htmlspecialchars($nl).'">'.$n.'</a>' : $n).'</span>';
- $calendar = '<table class="calendar'.$styleAdd.'" summary="Calendar">'."\n";
-
- $calendar .= "<tr>\n";
- if($weekNr) {
- $calendar .= "\t".'<td colspan="8" align="center" class="calendarMonth'.$styleAdd.'"><strong>';
- } else {
- $calendar .= "\t".'<td colspan="7" align="center" class="calendarMonth'.$styleAdd.'"><strong>';
- }
- $calendar .= $p;
- $calendar .= $month_href ? '<a href="'.htmlspecialchars($month_href).'">'.$title.'</a>' : $title;
- $calendar .= $n;
- $calendar .= "</strong></td>\n</tr>\n<tr>\n";
-
- if($weekNr) {
- $calendar .= "\t".'<td class="calendarWeekNoTitle'.$styleAdd.'">'.$weekNrTitle."</td>\n";
- $weekStart = date('W', $first_of_month);
- }
-
- if($day_name_length){ //if the day names should be shown ($day_name_length > 0)
- //if day_name_length is >3, the full name of the day will be printed
- foreach($day_names as $d) {
- $calendar .= "\t".'<td class="calendarDayName'.$styleAdd.'">'.htmlentities($day_name_length < 4 ? substr($d,0,$day_name_length) : $d)."</td>\n";
- }
- $calendar .= "</tr>\n<tr>\n";
- }
-
- if($weekday > 0) {
- if($weekNr) {
- $calendar .= "\t".'<td class="calendarWeek'.$styleAdd.'">'.$weekStart."</td>\n";
- $weekStart++;
- }
- $calendar .= "\t".'<td colspan="'.$weekday.'"> </td>'."\n"; //initial 'empty' days
- }
- for($day=1,$days_in_month=gmdate('t',$first_of_month); $day<=$days_in_month; $day++,$weekday++) {
-
- if($weekday == 7) {
- $weekday = 0; //start a new week
- $calendar .= "</tr>\n<tr>\n";
- }
- if($weekNr && $weekday == 0) {
- $calendar .= "\t".'<td class="calendarWeek'.$styleAdd.'">'.$weekStart."</td>\n";
- $weekStart++;
- }
-
- $thisSelected = (intval($year) == THIS_YEAR && intval($month) == THIS_MONTH && $day == THIS_DAY) ? true : false;
-
- $checkDay = $YYYYmm . substr('0'.$day, -2);
- if(isset($days[$checkDay]) && is_array($days[$checkDay])){
- @list($link, $classes, $content) = $days[$checkDay];
- @list($link, $target) = explode(' ', trim($link));
- $target = $target ? ' target="'.$target.'"' : '';
- if(is_null($content)) {
- $content = $day;
- }
- if($thisSelected) {
- $content = '<span class="calendarSelectedDay'.$styleAdd.'">'.$content.'</span>';
- }
- $calendar .= "\t<td";
- if($classes) {
- $calendar .= ' class="'.htmlspecialchars($classes).'"';
- }
- $calendar .= '>';
- $calendar .= $link ? '<a href="'.htmlspecialchars($link).'"'.$target.'>'.$content.'</a>' : $content;
- $calendar .= "</td>\n";
- } else {
- $calendar .= "\t";
- $calendar .= $thisSelected ? '<td class="calendarSelectedDay'.$styleAdd.'">' : '<td>';
- $calendar .= $day."</td>\n";
- }
- }
- if($weekday != 7) {
- $calendar .= "\t".'<td colspan="'.(7-$weekday).'"> </td>'."\n"; //remaining "empty" days
- }
-
- if($locale) {
- setlocale(LC_TIME, $_oldLocale); //switch current locale back to old value
- }
-
- return $calendar."</tr>\n</table>\n";
- }
-
- function tzdelta ( $iTime = 0 ) {
- if ( 0 == $iTime ) { $iTime = time(); }
- $ar = localtime ( $iTime );
- $ar[5] += 1900; $ar[4]++;
- $iTztime = gmmktime ( $ar[2], $ar[1], $ar[0], $ar[4], $ar[3], $ar[5], $ar[8] );
- return ( $iTztime - $iTime );
- }
-
-
- /////////////////////////////////////////////////////////////////////////////////////
-
- ?>