2006-12-02 04:36:16 +00:00
< ? php
/*
2009-10-30 17:59:32 +00:00
* e107 website system
*
2009-11-18 01:49:18 +00:00
* Copyright ( C ) 2008 - 2009 e107 Inc ( e107 . org )
2009-10-30 17:59:32 +00:00
* Released under the terms and conditions of the
* GNU General Public License ( http :// gnu . org ) .
*
* $Source : / cvs_backup / e107_0 . 8 / e107_handlers / date_handler . php , v $
2010-02-10 18:18:01 +00:00
* $Revision $
* $Date $
* $Author $
2009-10-30 17:59:32 +00:00
*
2006-12-02 04:36:16 +00:00
*/
if ( ! defined ( 'e107_INIT' )) { exit ; }
2017-01-23 09:41:23 -08:00
e107 :: includeLan ( e_LANGUAGEDIR . e_LANGUAGE . " /lan_date.php " );
2006-12-02 04:36:16 +00:00
class convert
{
2012-05-26 12:21:39 +00:00
function __construct ()
{
}
2015-07-26 17:33:15 -07:00
/**
* Build the datetimepicker () locale , since it must match strftime () values for accurate conversion .
*/
function buildDateLocale ()
{
$text = '
( function ( $ ){
$ . fn . datetimepicker . dates [ " '.e_LAN.' " ] = { ' ;
$dates = array ();
for ( $i = 1 ; $i < 8 ; $i ++ )
{
$day = strftime ( '%A' , mktime ( 1 , 1 , 1 , 1 , $i , 2012 ));
$dates [ 'days' ][] = $day ;
$dates [ 'daysShort' ][] = strftime ( '%a' , mktime ( 1 , 1 , 1 , 1 , $i , 2012 ));
$dates [ 'daysMin' ][] = substr ( $day , 0 , 2 );
}
for ( $i = 1 ; $i < 13 ; $i ++ )
{
$dates [ 'months' ][] = strftime ( '%B' , mktime ( 1 , 1 , 1 , $i , 2 , 2013 ));
$dates [ 'monthsShort' ][] = strftime ( '%h' , mktime ( 1 , 1 , 1 , $i , 2 , 2013 ));
}
foreach ( $dates as $key => $type )
{
$d = array ();
$text .= " \n " . $key . " : [ " ;
foreach ( $type as $val )
{
$d [] = '"' . $val . '"' ;
}
$text .= implode ( " , " , $d );
$text .= " ], " ;
}
$text .= '
meridiem : [ " am " , " pm " ]
};
}( jQuery )); ' ;
return $text ;
}
2014-06-02 17:07:02 -07:00
/**
* Return an array of language terms representing months
* @ param $type string : month , month - short , day , day - short , day - shortest
* @ return array
* TODO Cache !
*/
public function terms ( $type = 'month' )
{
if ( $type == 'month' || $type == 'month-short' )
{
$val = ( $type == 'month-short' ) ? '%b' : '%B' ; //eg. 'Aug' / 'August'
$marray = array ();
for ( $i = 1 ; $i < 13 ; $i ++ )
{
$marray [] = strftime ( $val , mktime ( 1 , 1 , 1 , $i , 1 , 2000 ));
}
return $marray ;
}
if ( substr ( $type , 0 , 3 ) == 'day' )
{
$days = array ();
for ( $i = 2 ; $i < 9 ; $i ++ )
{
switch ( $type )
{
case 'day-shortest' : // eg. 'Tu'
$days [] = substr ( strftime ( '%a' , mktime ( 1 , 1 , 1 , 6 , $i , 2014 )), 0 , 2 );
break ;
case 'day-short' : // eg. 'Tue'
$days [] = strftime ( '%a' , mktime ( 1 , 1 , 1 , 6 , $i , 2014 ));
break ;
default : // eg. 'Tuesday'
$days [] = strftime ( '%A' , mktime ( 1 , 1 , 1 , 6 , $i , 2014 ));
break ;
}
}
return $days ;
}
return false ;
}
2009-10-22 19:14:26 +00:00
/**
* Convert datestamp to human readable date .
* System time offset is considered .
*
* @ param integer $datestamp unix stamp
2013-04-26 21:49:09 -07:00
* @ param string $mask [ optional ] long | short | forum | relative or any strftime () valid string
2009-10-22 19:14:26 +00:00
*
* @ return string parsed date
*/
2016-09-28 10:26:39 -07:00
function convert_date ( $datestamp , $mask = '' )
{
2009-10-22 19:14:26 +00:00
if ( empty ( $mask ))
{
$mask = 'long' ;
}
switch ( $mask )
{
case 'long' :
$mask = e107 :: getPref ( 'longdate' );
2012-09-03 23:01:50 +00:00
// $datestamp += TIMEOFFSET;
2009-10-22 19:14:26 +00:00
break ;
case 'short' :
$mask = e107 :: getPref ( 'shortdate' );
2012-09-03 23:01:50 +00:00
// $datestamp += TIMEOFFSET;
2009-10-22 19:14:26 +00:00
break ;
2012-05-26 12:21:39 +00:00
case 'input' :
case 'inputdate' :
$mask = e107 :: getPref ( 'inputdate' , '%d/%m/%Y %H:%M' );
// $mask .= " ".e107::getPref('inputtime', '%H:%M');
break ;
case 'inputdatetime' :
$mask = e107 :: getPref ( 'inputdate' , '%d/%m/%Y %H:%M' );
$mask .= " " . e107 :: getPref ( 'inputtime' , '%H:%M' );
break ;
case 'inputtime' :
$mask .= e107 :: getPref ( 'inputtime' , '%H:%M' );
2009-10-30 17:59:32 +00:00
break ;
2009-10-22 19:14:26 +00:00
case 'forum' : // DEPRECATED - temporary here from BC reasons only
2012-12-05 16:43:53 -08:00
// default:
2009-10-22 19:14:26 +00:00
//BC - old 'forum' call
2009-10-23 13:06:21 +00:00
if ( strpos ( $mask , '%' ) === FALSE )
2009-10-22 19:14:26 +00:00
{
$mask = e107 :: getPref ( 'forumdate' );
}
2012-09-03 23:01:50 +00:00
// $datestamp += TIMEOFFSET;
2009-10-22 19:14:26 +00:00
break ;
2013-01-22 00:20:44 -08:00
2013-04-26 21:49:09 -07:00
case 'relative' :
return $this -> computeLapse ( $datestamp , time (), false , false , 'short' ) ;
break ;
2013-01-22 00:20:44 -08:00
default :
if ( strpos ( $mask , '%' ) === FALSE )
{
2013-01-22 13:11:29 -08:00
$mask = $this -> toMask ( $mask , true );
2013-01-22 00:20:44 -08:00
}
break ;
2009-10-22 19:14:26 +00:00
}
2016-09-20 11:28:17 +02:00
$dateString = strftime ( $mask , $datestamp );
2016-09-28 10:26:39 -07:00
if ( ! e107 :: getParser () -> isUTF8 ( $dateString ))
{
2016-09-20 11:28:17 +02:00
$dateString = utf8_encode ( $dateString );
}
return $dateString ;
}
2009-11-27 21:42:46 +00:00
2012-05-26 12:21:39 +00:00
/**
2016-05-31 13:25:43 -07:00
* @ deprecated - for internal use only .
* @ see $tp -> toDate () as a replacement .
2012-05-26 12:21:39 +00:00
* Converts between unix timestamp and human - readable date - time OR vice - versa . ( auto - detected )
2015-02-15 02:37:36 -08:00
* @ param string $string unix timestamp OR human - readable date - time .
2012-05-26 12:21:39 +00:00
* @ param string $mask ( optional ) long | short | input
2015-02-15 02:37:36 -08:00
* @ return bool | int | string
2012-05-26 12:21:39 +00:00
*/
function convert ( $string = null , $mask = 'inputdate' )
{
if ( $string == null ) return false ;
2013-06-22 18:23:51 -07:00
return is_numeric ( $string ) ? $this -> convert_date ( $string , $mask ) : $this -> toTime ( $string , $mask );
2012-05-26 12:21:39 +00:00
}
2012-12-05 16:43:53 -08:00
/**
2013-01-22 00:20:44 -08:00
* Converts to new date - mask format or vice - versa when $legacy is TRUE
2012-12-05 16:43:53 -08:00
*/
2013-01-22 00:20:44 -08:00
function toMask ( $mask , $legacy = false )
2012-12-05 16:43:53 -08:00
{
$convert = array (
2013-03-16 18:35:20 -07:00
'%Y' => 'yyyy' , // jquery-ui docs say 'yy' but yy produces '13' instead of '2013'
2012-12-05 16:43:53 -08:00
'%d' => 'dd' ,
'%m' => 'mm' ,
'%B' => 'MM' , // Full month name, based on the locale
'%A' => 'DD' , // A full textual representation of the day
2013-03-16 18:35:20 -07:00
'%y' => 'yy' ,
2012-12-05 16:43:53 -08:00
'%a' => 'D' , // An abbreviated textual representation of the day
'%b' => 'M' , // Abbreviated month name, based on the locale
'%h' => 'M' , // Abbreviated month name, based on the locale (an alias of %b)
2013-05-25 16:03:53 -07:00
'%I' => 'HH' , // Two digit representation of the hour in 12-hour format
'%l' => 'H' , // 12 hour format - no leading zero
2012-12-05 16:43:53 -08:00
'%H' => 'hh' , // 24 hour format - leading zero
2013-05-25 16:03:53 -07:00
'%M' => 'ii' , // Two digit representation of the minute
'%S' => 'ss' , // Two digit representation of the second
'%P' => 'p' , // %P lower-case 'am' or 'pm' based on the given time
'%p' => 'P' , // %p UPPER-CASE 'AM' or 'PM' based on the given time
2012-12-05 16:43:53 -08:00
'%T' => 'hh:mm:ss' ,
'%r' => " hh:mmm:ss TT " // 12 hour format
);
$s = array_keys ( $convert );
$r = array_values ( $convert );
2013-01-22 00:20:44 -08:00
if ( strpos ( $mask , '%' ) === FALSE && $legacy == TRUE )
2012-12-05 16:43:53 -08:00
{
return str_replace ( $r , $s , $mask );
}
2013-03-05 06:11:05 -08:00
elseif ( strpos ( $mask , '%' ) !== FALSE )
{
return str_replace ( $s , $r , $mask );
}
2012-12-05 16:43:53 -08:00
2013-03-05 06:11:05 -08:00
return $mask ;
2012-12-05 16:43:53 -08:00
// Keep this info here:
/*
* $options allowed keys :
*
* d - day of month ( no leading zero )
dd - day of month ( two digit )
o - day of the year ( no leading zeros )
oo - day of the year ( three digit )
D - day name short
DD - day name long
m - month of year ( no leading zero )
mm - month of year ( two digit )
M - month name short
MM - month name long
y - year ( two digit )
yy - year ( four digit )
@ - Unix timestamp ( ms since 01 / 01 / 1970 )
! - Windows ticks ( 100 ns since 01 / 01 / 0001 )
'...' - literal text
'' - single quote
anything else - literal text
ATOM - 'yy-mm-dd' ( Same as RFC 3339 / ISO 8601 )
COOKIE - 'D, dd M yy'
ISO_8601 - 'yy-mm-dd'
RFC_822 - 'D, d M y' ( See RFC 822 )
RFC_850 - 'DD, dd-M-y' ( See RFC 850 )
RFC_1036 - 'D, d M y' ( See RFC 1036 )
RFC_1123 - 'D, d M yy' ( See RFC 1123 )
RFC_2822 - 'D, d M yy' ( See RFC 2822 )
RSS - 'D, d M y' ( Same as RFC 822 )
TICKS - '!'
TIMESTAMP - '@'
W3C - 'yy-mm-dd' ( Same as ISO 8601 )
*
* h Hour with no leading 0
* hh Hour with leading 0
* m Minute with no leading 0
* mm Minute with leading 0
* s Second with no leading 0
* ss Second with leading 0
* l Milliseconds always with leading 0
* t a or p for AM / PM
* T A or P for AM / PM
* tt am or pm for AM / PM
* TT AM or PM for AM / PM
*/
}
2012-05-26 12:21:39 +00:00
2009-10-30 17:59:32 +00:00
2009-11-10 19:13:07 +00:00
/**
* Convert date string back to integer ( unix timestamp )
* NOTE : after some tests , strptime ( compat mode ) is adding + 1 sec . after parsing to time , investigate !
*
2015-07-31 22:30:26 +03:00
* @ param string $date_string
* @ param string $mask [ optional ]
2009-12-13 21:52:32 +00:00
* @ return integer
2009-11-10 19:13:07 +00:00
*/
function toTime ( $date_string , $mask = 'input' )
2009-10-30 17:59:32 +00:00
{
2009-11-10 19:13:07 +00:00
switch ( $mask )
{
case 'long' :
$mask = e107 :: getPref ( 'longdate' );
break ;
case 'short' :
$mask = e107 :: getPref ( 'shortdate' );
break ;
2012-05-26 12:21:39 +00:00
case 'input' :
case 'inputdate' :
$mask = e107 :: getPref ( 'inputdate' , '%Y/%m/%d' );
break ;
case 'inputdatetime' :
$mask = e107 :: getPref ( 'inputdate' , '%Y/%m/%d' );
$mask .= " " . e107 :: getPref ( 'inputtime' , '%H:%M' );
break ;
case 'inputtime' :
$mask = e107 :: getPref ( 'inputtime' , '%H:%M' );
2009-11-10 19:13:07 +00:00
break ;
}
2012-05-26 12:21:39 +00:00
// also in php compat handler for plugins that might use it.
$tdata = $this -> strptime ( $date_string , $mask );
2009-11-10 19:13:07 +00:00
if ( empty ( $tdata ))
{
2013-11-22 01:30:06 -08:00
if ( ! empty ( $date_string ) && ADMIN )
{
e107 :: getMessage () -> addDebug ( " PROBLEM WITH CONVERSION from " . $date_string . " to unix timestamp " );
}
2009-11-10 19:13:07 +00:00
return null ;
}
2013-11-09 20:08:41 -08:00
2014-02-18 05:41:58 -08:00
if ( STRPTIME_COMPAT !== TRUE ) // returns months from 0 - 11 on Unix so we need to +1
{
$tdata [ 'tm_mon' ] = $tdata [ 'tm_mon' ] + 1 ;
}
2009-11-10 19:13:07 +00:00
$unxTimestamp = mktime (
$tdata [ 'tm_hour' ],
$tdata [ 'tm_min' ],
$tdata [ 'tm_sec' ],
2014-02-18 05:41:58 -08:00
$tdata [ 'tm_mon' ] ,
2009-11-10 19:13:07 +00:00
$tdata [ 'tm_mday' ],
2012-05-26 12:21:39 +00:00
( $tdata [ 'tm_year' ] + 1900 )
2009-11-10 19:13:07 +00:00
);
2012-09-03 23:01:50 +00:00
// echo "<br />UNIX=".$unxTimestamp - TIMEOFFSET;
// echo "<br />".date("l, d M Y g:i A",$unxTimestamp);
2012-05-26 12:21:39 +00:00
// var_dump($tdata, $date_string, $this->convert_date($unxTimestamp, $mask), $unxTimestamp);
2012-09-03 23:01:50 +00:00
2009-11-10 19:13:07 +00:00
return $unxTimestamp ;
2009-10-30 17:59:32 +00:00
}
2006-12-02 04:36:16 +00:00
2012-05-26 12:21:39 +00:00
// -----------------------
2009-11-27 21:42:46 +00:00
/**
* Tolerant date / time input routine - doesn ' t force use of specific delimiters , and can sometimes allow no delimiters at all
* The format string defines the critical day / month / year order .
* As examples , with suitable format specifiers all of the following will be interpreted into valid ( and sensible ) dates / times :
* 09122003 153045 -> 9 - 12 - 03 at 15 : 30 : 45 ( requires dmy or mdy format specifier )
* 20031209 12 : 30 : 32 -> 9 - 12 - 03 at 12 : 30 : 32 ( requires ymd specifier )
* 091203 1530 -> 9 - 12 - 09 at 15 : 30 : 00
* 9 / 12 / 3 12 -> 9 - 12 - 09 at 12 : 00 : 00
* 6 - 3 / 4 15 - 45 : 27 -> 6 - 3 - 04 at 15 : 45 : 27
*
* @ param string $input - usually date / time string with numeric values for relevant fields , and almost any separator . e . g . dd - mm - yy hh : mm
* Date and time must be separated by one or more spaces . In times , minutes and seconds are optional , and default to zero
* One special value is allowed - 'now'
2009-12-01 20:05:54 +00:00
* @ param string $decode - one of 'date' , 'time' , 'datetime' , 'timedate'
2009-11-27 21:42:46 +00:00
* @ param string $format - sets field order for dates . Valid strings are dmy , mdy , ymd . Add suffix 'z' to return UTC / GMT
* @ param boolean $endDay - if TRUE , and no time entered , includes a time of 23 : 59 : 59 in the entered date
*
* @ return integer time stamp . returns zero on any error
*/
public function decodeDateTime ( $input , $decode = 'date' , $format = 'dmy' , $endDay = FALSE )
{
2009-12-01 20:05:54 +00:00
if ( $input == 'now' ) return time (); // Current time TODO: option to return UTC or local time here
2009-11-27 21:42:46 +00:00
$useLocale = TRUE ;
if ( substr ( $format , - 1 , 1 ) == 'z' )
{
$useLocale = FALSE ;
$format = substr ( $format , 0 , - 1 ); // Remove local disable string
}
switch ( $decode )
{
case 'date' :
$timeString = '' ;
2009-12-01 20:05:54 +00:00
$dateString = $input ;
2009-11-27 21:42:46 +00:00
break ;
case 'time' :
2009-12-01 20:05:54 +00:00
$timeString = $input ;
2009-11-27 21:42:46 +00:00
$dateString = '' ;
break ;
2009-12-01 20:05:54 +00:00
case 'datetime' : // Date then time, separated by space
2009-11-27 21:42:46 +00:00
$input = str_replace ( ' ' , ' ' , $input );
list ( $dateString , $timeString ) = explode ( ' ' , $input , 2 );
2009-12-01 20:05:54 +00:00
break ;
case 'timedate' : // Time then date, separated by space
$input = str_replace ( ' ' , ' ' , $input );
list ( $timeString , $dateString ) = explode ( ' ' , $input , 2 );
2009-11-27 21:42:46 +00:00
break ;
default :
return 0 ;
}
2009-12-01 20:05:54 +00:00
$timeString = trim ( $timeString );
$dateString = trim ( $dateString );
2009-11-27 21:42:46 +00:00
$dateVals = array ( 1 => 0 , 2 => 0 , 3 => 0 ); // Preset date in case
$timeVals = array ( 1 => 0 , 2 => 0 , 3 => 0 ); // Preset time in case
if ( $dateString )
{
if ( is_numeric ( $dateString ))
{
if ( strlen ( $dateString ) == 6 )
{ // Probably fixed format numeric without separators
$dateVals = array ( 1 => substr ( $dateString , 0 , 2 ), 2 => substr ( $dateString , 2 , 2 ), 3 => substr ( $dateString , - 2 ));
}
elseif ( strlen ( $dateString ) == 8 )
{ // Trickier - year may be first or last!
if ( $format == 'ymd' )
{
$dateVals = array ( 1 => substr ( $dateString , 0 , 4 ), 2 => substr ( $dateString , 4 , 2 ), 3 => substr ( $dateString , - 2 ));
}
else
{
$dateVals = array ( 1 => substr ( $dateString , 0 , 2 ), 2 => substr ( $dateString , 2 , 2 ), 3 => substr ( $dateString , - 4 ));
}
}
}
else
{ // Assume standard 'nn-nn-nn', 'nnnn-nn-nn' or 'nn-nn-nnnn' type format
if ( ! preg_match ( '#(\d{1,4})\D(\d{1,2})\D(\d{1,4})#' , $dateString , $dateVals ))
{
return 0 ; // Can't decode date
}
}
}
if ( $timeString )
{
if ( is_numeric ( $timeString ))
{
if ( strlen ( $timeString ) == 6 )
{ // Assume hhmmss
$timeVals = array ( 1 => substr ( $timeString , 0 , 2 ), 2 => substr ( $timeString , 2 , 2 ), 3 => substr ( $timeString , - 2 ));
}
elseif ( strlen ( $timeString ) == 4 )
{ // Assume hhmm
$timeVals = array ( 1 => substr ( $timeString , 0 , 2 ), 2 => substr ( $timeString , - 2 ), 3 => 0 );
}
else
{ // Hope its just hours!
if ( $timeString < 24 )
{
$timeVals [ 1 ] = $timeString ;
}
}
}
else
{
preg_match ( '#(\d{1,2})(?:\D(\d{1,2})){0,1}(?:\D(\d{1,2})){0,1}#' , $timeString , $timeVals );
}
}
elseif ( $endDay )
{
$timeVals = array ( 1 => 23 , 2 => 59 , 3 => 59 ); // Last second of day
}
// Got all the values now - the rest is simple!
switch ( $format )
{
case 'dmy' :
$month = $dateVals [ 2 ]; $day = $dateVals [ 1 ]; $year = $dateVals [ 3 ]; break ;
case 'mdy' :
$month = $dateVals [ 1 ]; $day = $dateVals [ 2 ]; $year = $dateVals [ 3 ]; break ;
case 'ymd' :
$month = $dateVals [ 2 ]; $day = $dateVals [ 3 ]; $year = $dateVals [ 1 ]; break ;
default :
echo " Unsupported format string: { $format } <br /> " ;
return 0 ;
}
if ( $useLocale )
{
return mktime ( $timeVals [ 1 ], $timeVals [ 2 ], $timeVals [ 3 ], $month , $day , $year );
}
return gmmktime ( $timeVals [ 1 ], $timeVals [ 2 ], $timeVals [ 3 ], $month , $day , $year );
}
/**
* Calculate difference between two dates for display in terms of years / months / weeks ....
*
* @ param integer $older_date - time stamp
* @ param integer | boolean $newer_date - time stamp . Defaults to current time if FALSE
* @ param boolean $mode - if TRUE , return value is an array . Otherwise return value is a string
* @ param boolean $show_secs
* @ param string $format - controls display format . 'short' misses off year . 'long' includes everything
* @ return array | string according to $mode , array or string detailing the time difference
*/
2006-12-02 04:36:16 +00:00
function computeLapse ( $older_date , $newer_date = FALSE , $mode = FALSE , $show_secs = TRUE , $format = 'long' )
2006-12-22 20:46:53 +00:00
{ /*
2006-12-02 04:36:16 +00:00
$mode = TRUE :: return array
$mode = FALSE :: return string
*/
if ( $format == 'short' )
{
$sec = LANDT_09 ;
$secs = LANDT_09s ;
$min = LANDT_08 ;
$mins = LANDT_08s ;
}
else
{
$sec = LANDT_07 ;
$secs = LANDT_07s ;
$min = LANDT_06 ;
$mins = LANDT_06s ;
}
2006-12-22 20:46:53 +00:00
/*
If we want an absolutely accurate result , main problems arise from the varying numbers of days in a month .
If we go over a month boundary , then we need to add days to end of start month , plus days in 'end' month
If start day > end day , we cross a month boundary . Calculate last day of start date . Otherwise we can just do a simple difference .
*/
2009-11-27 21:42:46 +00:00
$newer_date = ( $newer_date === FALSE ? ( time ()) : $newer_date );
2006-12-23 15:44:31 +00:00
if ( $older_date > $newer_date )
{ // Just in case the wrong way round
$tmp = $newer_date ;
$newer_date = $older_date ;
$older_date = $tmp ;
}
2006-12-22 20:46:53 +00:00
$new_date = getdate ( $newer_date );
$old_date = getdate ( $older_date );
$result = array ();
$outputArray = array ();
$params = array (
6 => array ( 'seconds' , 60 , $sec , $secs ),
5 => array ( 'minutes' , 60 , $min , $mins ),
4 => array ( 'hours' , 24 , LANDT_05 , LANDT_05s ),
3 => array ( 'mday' , - 1 , LANDT_04 , LANDT_04s ),
2 => array ( '' , - 3 , LANDT_03 , LANDT_03s ),
1 => array ( 'mon' , 12 , LANDT_02 , LANDT_02s ),
0 => array ( 'year' , - 2 , LANDT_01 , LANDT_01s )
);
2006-12-02 04:36:16 +00:00
2006-12-22 20:46:53 +00:00
$cy = 0 ;
foreach ( $params as $parkey => $parval )
2006-12-02 04:36:16 +00:00
{
2006-12-22 20:46:53 +00:00
if ( $parkey == 2 )
{
$result [ '2' ] = floor ( $result [ '3' ] / 7 );
$result [ '3' ] = fmod ( $result [ '3' ], 7 );
}
else
{
$tmp = $new_date [ $parval [ 0 ]] - $old_date [ $parval [ 0 ]] - $cy ;
$scy = $cy ;
$cy = 0 ;
if ( $tmp < 0 )
{
switch ( $parval [ 1 ])
{
case - 1 : // Wrapround on months - special treatment
$tempdate = getdate ( mktime ( 0 , 0 , 0 , $old_date [ 'mon' ] + 1 , 1 , $old_date [ 'year' ]) - 1 ); // Last day of month
$tmp = $tempdate [ 'mday' ] - $old_date [ 'mday' ] + $new_date [ 'mday' ] - $scy ;
$cy = 1 ;
break ;
case - 2 : // Year wraparound - shouldn't happen
case - 3 : // Week processing - this shouldn't happen either
echo " Code bug!<br /> " ;
break ;
default :
$cy = 1 ;
$tmp += $parval [ 1 ];
}
}
$result [ $parkey ] = $tmp ;
}
2006-12-02 04:36:16 +00:00
}
2006-12-22 20:46:53 +00:00
// Generate output array, add text
for ( $i = 0 ; $i < ( $show_secs ? 7 : 6 ); $i ++ )
2006-12-02 04:36:16 +00:00
{
2007-02-18 13:10:26 +00:00
if (( $i > 4 ) || ( $result [ $i ] != 0 ))
{ // Only show non-zero values, except always show minutes/seconds
2013-03-12 04:22:09 -07:00
$outputArray [] = $result [ $i ] . " " . ( $result [ $i ] == 1 ? $params [ $i ][ 2 ] : $params [ $i ][ 3 ]) ;
2013-07-08 10:37:40 -07:00
2007-02-18 13:10:26 +00:00
}
2013-07-08 10:37:40 -07:00
if ( $format == 'short' && count ( $outputArray ) == 1 ) { break ; }
2006-12-02 04:36:16 +00:00
}
2016-05-21 09:45:15 -07:00
if ( empty ( $outputArray [ 1 ]) && ( $outputArray [ 0 ] == " 0 " . $mins ))
{
return deftrue ( 'LANDT_10' , " Just now " );
}
2015-12-12 14:49:13 +01:00
return ( $mode ? $outputArray : implode ( " , " , $outputArray ) . " " . LANDT_AGO );
2006-12-02 04:36:16 +00:00
}
2012-05-26 12:21:39 +00:00
/**
* This work of Lionel SAURON ( http :// sauron . lionel . free . fr : 80 ) is licensed under the
* Creative Commons Attribution - Noncommercial - Share Alike 2.0 France License .
* To view a copy of this license , visit http :// creativecommons . org / licenses / by - nc - sa / 2.0 / fr /
* or send a letter to Creative Commons , 171 Second Street , Suite 300 , San Francisco , California , 94105 , USA .
*
* http :// snipplr . com / view / 4964 / emulate - php - 5 - for - backwards - compatibility /
*
* Parse a date generated with strftime () .
*
* @ author Lionel SAURON and reworked by e107 Inc . for month names .
* @ version 1.0
* @ public
*
* @ param string $str date string to parse ( e . g . returned from strftime ()) .
* @ param string $sFormat strftime format used to create the date
* @ return array Returns an array with the < code > $str </ code > parsed , or < code > false </ code > on error .
*/
public function strptime ( $str , $format )
{
2014-02-18 05:41:58 -08:00
if ( STRPTIME_COMPAT !== TRUE && function_exists ( 'strptime' )) // Unix Only.
2013-11-22 01:30:06 -08:00
{
$vals = strptime ( $str , $format ); // PHP5 is more accurate than below.
2014-02-18 05:41:58 -08:00
$vals [ 'tm_amon' ] = strftime ( '%b' , mktime ( 0 , 0 , 0 , $vals [ 'tm_mon' ] + 1 ) );
$vals [ 'tm_fmon' ] = strftime ( '%B' , mktime ( 0 , 0 , 0 , $vals [ 'tm_mon' ] + 1 ) );
2013-11-22 01:30:06 -08:00
return $vals ;
}
// Below is for Windows machines. (XXX TODO - Currently not as accurate as Linux PHP5 strptime() function above. )
2012-05-26 12:21:39 +00:00
static $expand = array ( '%D' => '%m/%d/%y' , '%T' => '%H:%M:%S' , );
$ampm = ( preg_match ( " /%l|%I|%p|%P/ " , $format )) ? 'true' : 'false' ;
static $map_r = array (
'%S' => 'tm_sec' ,
'%M' => 'tm_min' ,
'%H' => 'tm_hour' ,
'%I' => 'tm_hour' ,
'%d' => 'tm_mday' ,
'%m' => 'tm_mon' ,
'%Y' => 'tm_year' ,
'%y' => 'tm_year' ,
'%W' => 'tm_wday' ,
'%D' => 'tm_yday' ,
'%B' => 'tm_fmon' , // full month-name
'%b' => 'tm_amon' , // abrev. month-name
'%p' => 'tm_AMPM' , // AM/PM
'%P' => 'tm_ampm' , // am/pm
'%u' => 'unparsed' ,
);
$fullmonth = array ();
$abrevmonth = array ();
for ( $i = 1 ; $i <= 12 ; $i ++ )
{
$k = strftime ( '%B' , mktime ( 0 , 0 , 0 , $i ));
$fullmonth [ $k ] = $i ;
$j = strftime ( '%b' , mktime ( 0 , 0 , 0 , $i ));
$abrevmonth [ $j ] = $i ;
}
#-- transform $format into extraction regex
$format = str_replace ( array_keys ( $expand ), array_values ( $expand ), $format );
$preg = preg_replace ( '/(%\w)/' , '(\w+)' , preg_quote ( $format ));
#-- record the positions of all STRFCMD-placeholders
preg_match_all ( '/(%\w)/' , $format , $positions );
$positions = $positions [ 1 ];
#-- get individual values
if ( preg_match ( " # $preg # " , $str , $extracted ))
{
#-- get values
foreach ( $positions as $pos => $strfc )
{
$v = $extracted [ $pos + 1 ];
#-- add
if ( isset ( $map_r [ $strfc ]))
{
$n = $map_r [ $strfc ];
$vals [ $n ] = ( $v > 0 ) ? ( int ) $v : $v ;
}
else
{
$vals [ 'unparsed' ] .= $v . ' ' ;
}
}
#-- fixup some entries
//$vals["tm_wday"] = $names[ substr($vals["tm_wday"], 0, 3) ];
if ( $vals [ 'tm_year' ] >= 1900 )
{
$vals [ 'tm_year' ] -= 1900 ;
}
elseif ( $vals [ 'tm_year' ] > 0 )
{
$vals [ 'tm_year' ] += 100 ;
}
if ( $vals [ 'tm_mon' ])
{
$vals [ 'tm_mon' ] -= 1 ;
}
else
{
if ( isset ( $fullmonth [ $vals [ 'tm_fmon' ]]))
{
$vals [ 'tm_mon' ] = $fullmonth [ $vals [ 'tm_fmon' ]];
}
elseif ( isset ( $abrevmonth [ $vals [ 'tm_amon' ]]))
{
$vals [ 'tm_mon' ] = $abrevmonth [ $vals [ 'tm_amon' ]];
}
}
2012-09-06 18:59:09 +00:00
if ( $ampm )
2012-05-26 12:21:39 +00:00
{
2012-09-06 18:59:09 +00:00
if ( $vals [ 'tm_hour' ] == 12 && ( $vals [ 'tm_AMPM' ] == 'AM' || $vals [ 'tm_ampm' ] == 'am' ))
{
$vals [ 'tm_hour' ] = 0 ;
}
if ( $vals [ 'tm_hour' ] < 12 && ( $vals [ 'tm_AMPM' ] == 'PM' || $vals [ 'tm_ampm' ] == 'pm' ))
{
$vals [ 'tm_hour' ] = intval ( $vals [ 'tm_hour' ]) + 12 ;
}
2012-05-26 12:21:39 +00:00
}
//$vals['tm_sec'] -= 1; always increasing tm_sec + 1 ??????
#-- calculate wday/yday
2014-02-18 05:41:58 -08:00
//$vals['tm_mon'] = $vals['tm_mon'] + 1; // returns months from 0 - 11 so we need to +1
2012-05-26 12:21:39 +00:00
$unxTimestamp = mktime ( $vals [ 'tm_hour' ], $vals [ 'tm_min' ], $vals [ 'tm_sec' ], ( $vals [ 'tm_mon' ] + 1 ), $vals [ 'tm_mday' ], ( $vals [ 'tm_year' ] + 1900 ));
2014-02-18 05:41:58 -08:00
$vals [ 'tm_fmon' ] = strftime ( '%B' , mktime ( $vals [ 'tm_hour' ], $vals [ 'tm_min' ], $vals [ 'tm_sec' ], $vals [ 'tm_mon' ]));
2012-05-26 12:21:39 +00:00
$vals [ 'tm_wday' ] = ( int ) strftime ( '%w' , $unxTimestamp ); // Days since Sunday (0-6)
$vals [ 'tm_yday' ] = ( strftime ( '%j' , $unxTimestamp ) - 1 ); // Days since January 1 (0-365)
2014-02-18 05:41:58 -08:00
2012-05-26 12:21:39 +00:00
//var_dump($vals, $str, strftime($format, $unxTimestamp), $unxTimestamp);
}
return isset ( $vals ) ? $vals : false ;
}
function supported ( $mode = FALSE )
{
$strftimeFormats = array (
'A' => 'A full textual representation of the day' ,
'B' => 'Full month name, based on the locale' ,
'C' => 'Two digit representation of the century (year divided by 100, truncated to an integer)' ,
'D' => 'Same as "%m/%d/%y"' ,
'E' => '' ,
'F' => 'Same as "%Y-%m-%d"' ,
'G' => 'The full four-digit version of %g' ,
'H' => 'Two digit representation of the hour in 24-hour format' ,
'I' => 'Two digit representation of the hour in 12-hour format' ,
'J' => '' ,
'K' => '' ,
'L' => '' ,
'M' => 'Two digit representation of the minute' ,
'N' => '' ,
'O' => '' ,
'P' => 'lower-case "am" or "pm" based on the given time' ,
'Q' => '' ,
'R' => 'Same as "%H:%M"' ,
'S' => 'Two digit representation of the second' ,
'T' => 'Same as "%H:%M:%S"' ,
'U' => 'Week number of the given year, starting with the first Sunday as the first week' ,
'V' => 'ISO-8601:1988 week number of the given year, starting with the first week of the year with at least 4 weekdays, with Monday being the start of the week' ,
'W' => 'A numeric representation of the week of the year, starting with the first Monday as the first week' ,
'X' => 'Preferred time representation based on locale, without the date' ,
'Y' => 'Four digit representation for the year' ,
'Z' => 'The time zone offset/abbreviation option NOT given by %z (depends on operating system)' ,
'a' => 'An abbreviated textual representation of the day' ,
'b' => 'Abbreviated month name, based on the locale' ,
'c' => 'Preferred date and time stamp based on local' ,
'd' => 'Two-digit day of the month (with leading zeros)' ,
'e' => 'Day of the month, with a space preceding single digits' ,
'f' => '' ,
'g' => 'Two digit representation of the year going by ISO-8601:1988 standards (see %V)' ,
'h' => 'Abbreviated month name, based on the locale (an alias of %b)' ,
'i' => '' ,
'j' => 'Day of the year, 3 digits with leading zeros' ,
'k' => '' ,
'l' => 'Hour in 12-hour format, with a space preceeding single digits' ,
'm' => 'Two digit representation of the month' ,
'n' => 'A newline character ("\n")' ,
'o' => '' ,
'p' => 'UPPER-CASE "AM" or "PM" based on the given time' ,
'q' => '' ,
'r' => 'Same as "%I:%M:%S %p"' ,
's' => 'Unix Epoch Time timestamp' ,
't' => 'A Tab character ("\t")' ,
'u' => 'ISO-8601 numeric representation of the day of the week' ,
'v' => '' ,
'w' => 'Numeric representation of the day of the week' ,
'x' => 'Preferred date representation based on locale, without the time' ,
'y' => 'Two digit representation of the year' ,
'z' => 'Either the time zone offset from UTC or the abbreviation (depends on operating system)' ,
'%' => 'A literal percentage character ("%")' ,
);
// Results.
$strftimeValues = array ();
// Evaluate the formats whilst suppressing any errors.
foreach ( $strftimeFormats as $format => $description )
{
if ( False !== ( $value = @ strftime ( " % { $format } " )))
{
$strftimeValues [ $format ] = $value ;
}
}
// Find the longest value.
$maxValueLength = 2 + max ( array_map ( 'strlen' , $strftimeValues ));
$ret = array (
'enabled' => array (),
'disabled' => array ()
);
// Report known formats.
foreach ( $strftimeValues as $format => $value )
{
$ret [ 'enabled' ][] = $format ;
echo ( $mode == 'list' ) ? " Known format : ' { $format } ' = " . str_pad ( " ' { $value } ' " , $maxValueLength ) . " ( { $strftimeFormats [ $format ] } )<br /> " : " " ;
}
// Report unknown formats.
foreach ( array_diff_key ( $strftimeFormats , $strftimeValues ) as $format => $description )
{
$ret [ 'disabled' ][] = $format ;
echo ( $mode == 'list' ) ? " Unknown format : ' { $format } ' " . str_pad ( ' ' , $maxValueLength ) . ( $description ? " ( { $description } ) " : '' ) . " <br /> " : " " ;
}
return in_array ( $mode , $ret [ 'enabled' ]);
}
2015-08-24 17:39:28 -07:00
/**
* Check if TimeZone is valid
* @ param $timezone
* @ return bool
*/
function isValidTimezone ( $timezone )
{
return in_array ( $timezone , timezone_identifiers_list ());
}
2007-01-17 20:47:41 +00:00
}
?>