2014-11-12 22:01:48 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Classe plxDate rassemblant les fonctions utiles à PluXml
|
|
|
|
* concernant la manipulation des dates
|
|
|
|
*
|
|
|
|
* @package PLX
|
|
|
|
* @author Stephane F., Amauray Graillat
|
|
|
|
**/
|
|
|
|
|
|
|
|
class plxDate {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Méthode qui retourne le libellé du mois ou du jour passé en paramètre
|
|
|
|
*
|
|
|
|
* @param key constante: 'day', 'month' ou 'short_month'
|
|
|
|
* @param value numero du mois ou du jour
|
|
|
|
* @return string libellé du mois (long ou court) ou du jour
|
|
|
|
* @author Stephane F.
|
|
|
|
**/
|
|
|
|
public static function getCalendar($key, $value) {
|
|
|
|
|
|
|
|
$aMonth = array(
|
|
|
|
'01' => L_JANUARY,
|
|
|
|
'02' => L_FEBRUARY,
|
|
|
|
'03' => L_MARCH,
|
|
|
|
'04' => L_APRIL,
|
|
|
|
'05' => L_MAY,
|
|
|
|
'06' => L_JUNE,
|
|
|
|
'07' => L_JULY,
|
|
|
|
'08' => L_AUGUST,
|
|
|
|
'09' => L_SEPTEMBER,
|
|
|
|
'10' => L_OCTOBER,
|
|
|
|
'11' => L_NOVEMBER,
|
|
|
|
'12' => L_DECEMBER);
|
|
|
|
$aShortMonth = array(
|
|
|
|
'01' => L_SHORT_JANUARY,
|
|
|
|
'02' => L_SHORT_FEBRUARY,
|
|
|
|
'03' => L_SHORT_MARCH,
|
|
|
|
'04' => L_SHORT_APRIL,
|
|
|
|
'05' => L_SHORT_MAY,
|
|
|
|
'06' => L_SHORT_JUNE,
|
|
|
|
'07' => L_SHORT_JULY,
|
|
|
|
'08' => L_SHORT_AUGUST,
|
|
|
|
'09' => L_SHORT_SEPTEMBER,
|
|
|
|
'10' => L_SHORT_OCTOBER,
|
|
|
|
'11' => L_SHORT_NOVEMBER,
|
|
|
|
'12' => L_SHORT_DECEMBER);
|
|
|
|
$aDay = array(
|
|
|
|
'1' => L_MONDAY,
|
|
|
|
'2' => L_TUESDAY,
|
|
|
|
'3' => L_WEDNESDAY,
|
|
|
|
'4' => L_THURSDAY,
|
|
|
|
'5' => L_FRIDAY,
|
|
|
|
'6' => L_SATURDAY,
|
|
|
|
'0' => L_SUNDAY);
|
|
|
|
|
|
|
|
switch ($key) {
|
|
|
|
case 'day':
|
|
|
|
$day = isset($aDay[$value]) ? $aDay[$value] : '';
|
|
|
|
return $day; break;
|
|
|
|
case 'month':
|
|
|
|
$month = isset($aMonth[$value]) ? $aMonth[$value] : '';
|
|
|
|
return $month; break;
|
|
|
|
case 'short_month':
|
|
|
|
$short_month = isset($aShortMonth[$value]) ? $aShortMonth[$value] : '';
|
|
|
|
return $short_month; break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Méthode qui formate l'affichage d'une date
|
|
|
|
*
|
|
|
|
* @param date date/heure au format YYYYMMDDHHMM
|
|
|
|
* @param format format d'affichage
|
|
|
|
* @return string date/heure formatée
|
|
|
|
* @author Stephane F.
|
|
|
|
**/
|
|
|
|
public static function formatDate($date, $format='#num_day/#num_month/#num_year(4)') {
|
|
|
|
|
|
|
|
# On decoupe notre date
|
|
|
|
$year4 = substr($date, 0, 4);
|
|
|
|
$year2 = substr($date, 2, 2);
|
|
|
|
$month = substr($date, 4, 2);
|
|
|
|
$day = substr($date, 6, 2);
|
|
|
|
$day_num = date('w',mktime(0,0,0,$month,$day,$year4));
|
|
|
|
$hour = substr($date,8,2);
|
|
|
|
$minute = substr($date,10,2);
|
|
|
|
|
|
|
|
# On retourne notre date au format humain
|
|
|
|
$format = str_replace('#minute', $minute, $format);
|
|
|
|
$format = str_replace('#hour', $hour, $format);
|
|
|
|
$format = str_replace('#day', plxDate::getCalendar('day', $day_num), $format);
|
|
|
|
$format = str_replace('#short_month', plxDate::getCalendar('short_month', $month), $format);
|
|
|
|
$format = str_replace('#month', plxDate::getCalendar('month', $month), $format);
|
2015-08-17 21:12:54 +02:00
|
|
|
$format = str_replace('#num_day(1)', intval($day), $format);
|
|
|
|
$format = str_replace('#num_day(2)', $day, $format);
|
2014-11-12 22:01:48 +01:00
|
|
|
$format = str_replace('#num_day', $day, $format);
|
|
|
|
$format = str_replace('#num_month', $month, $format);
|
|
|
|
$format = str_replace('#num_year(2)', $year2 , $format);
|
|
|
|
$format = str_replace('#num_year(4)', $year4 , $format);
|
|
|
|
return $format;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Méthode qui convertis un timestamp en date/time
|
|
|
|
*
|
|
|
|
* @param timestamp timstamp au format unix
|
|
|
|
* @return string date au format YYYYMMDDHHMM
|
|
|
|
* @author Stephane F.
|
|
|
|
**/
|
|
|
|
public static function timestamp2Date($timestamp) {
|
|
|
|
|
|
|
|
return date('YmdHi', $timestamp);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Méthode qui éclate une date au format YYYYMMDDHHMM dans un tableau
|
|
|
|
*
|
|
|
|
* @param date date au format YYYYMMDDHHMM
|
|
|
|
* @return array tableau contenant le détail de la date
|
|
|
|
* @author Stephane F.
|
|
|
|
**/
|
|
|
|
public static function date2Array($date) {
|
|
|
|
|
|
|
|
preg_match('/([0-9]{4})([0-9]{2})([0-9]{2})([0-9:]{2})([0-9:]{2})/',$date,$capture);
|
|
|
|
return array (
|
|
|
|
'year' => $capture[1],
|
|
|
|
'month' => $capture[2],
|
|
|
|
'day' => $capture[3],
|
|
|
|
'hour' => $capture[4],
|
|
|
|
'minute'=> $capture[5],
|
|
|
|
'time' => $capture[4].':'.$capture[5]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Méthode qui vérifie la validité de la date et de l'heure
|
|
|
|
*
|
|
|
|
* @param int mois
|
|
|
|
* @param int jour
|
|
|
|
* @param int année
|
|
|
|
* @param int heure:minute
|
|
|
|
* @return boolean vrai si la date est valide
|
|
|
|
* @author Amaury Graillat
|
|
|
|
**/
|
|
|
|
public static function checkDate($day, $month, $year, $time) {
|
|
|
|
|
|
|
|
return (preg_match("/^(0[1-9]|[1-2][0-9]|3[0-1])(0[1-9]|1[0-2])[1-2][0-9]{3}([0-1][0-9]|2[0-3])\:[0-5][0-9]$/",$day.$month.$year.$time)
|
|
|
|
AND checkdate($month, $day, $year));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fonction de conversion de date ISO en format RFC822
|
|
|
|
*
|
|
|
|
* @param date date à convertir
|
|
|
|
* @return string date au format iso.
|
|
|
|
* @author Amaury GRAILLAT
|
|
|
|
**/
|
|
|
|
public static function dateIso2rfc822($date) {
|
|
|
|
|
|
|
|
$tmpDate = plxDate::date2Array($date);
|
|
|
|
return date(DATE_RSS, mktime(substr($tmpDate['time'],0,2), substr($tmpDate['time'],3,2), 0, $tmpDate['month'], $tmpDate['day'], $tmpDate['year']));
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
?>
|