mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-09-21 00:46:07 +02:00
bfbf80c843
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@44456 467b73ca-7a2a-4603-9d3b-597d59a354a9
196 lines
5.2 KiB
PHP
196 lines
5.2 KiB
PHP
<?php
|
|
|
|
class Date extends DBField {
|
|
|
|
function setValue($value) {
|
|
if( is_array( $value ) && $value['Day'] && $value['Month'] && $value['Year'] ) {
|
|
$this->value = $value['Year'] . '-' . $value['Month'] . '-' . $value['Day'];
|
|
return;
|
|
}
|
|
|
|
// Default to NZ date format - strtotime expects a US date
|
|
if(ereg('^([0-9]+)/([0-9]+)/([0-9]+)$', $value, $parts))
|
|
$value = "$parts[2]/$parts[1]/$parts[3]";
|
|
|
|
if($value) $this->value = date('Y-m-d', strtotime($value));
|
|
else $value = null;
|
|
}
|
|
|
|
/**
|
|
* Returns the date in the format dd/mm/yy
|
|
*/
|
|
function Nice() {
|
|
if($this->value) return date('d/m/Y', strtotime($this->value));
|
|
}
|
|
|
|
/**
|
|
* Returns the year from the given date
|
|
*/
|
|
function Year() {
|
|
if($this->value) return date('Y', strtotime($this->value));
|
|
}
|
|
|
|
/**
|
|
* Returns the Full day, of the given date.
|
|
*/
|
|
function Day(){
|
|
if($this->value) return date('l', strtotime($this->value));
|
|
}
|
|
|
|
/**
|
|
* Returns the month
|
|
*/
|
|
function ShortMonth() {
|
|
if($this->value) return date('M', strtotime($this->value));
|
|
}
|
|
|
|
/**
|
|
* Returns the date of the month
|
|
*/
|
|
function DayOfMonth() {
|
|
if($this->value) return date('j', strtotime($this->value));
|
|
}
|
|
|
|
|
|
/**
|
|
* Returns the date in the format 24 May 2006
|
|
*/
|
|
function Long() {
|
|
if($this->value) return date('j F Y', strtotime($this->value));
|
|
}
|
|
|
|
/**
|
|
* Return the date formatted using the given PHP formatting string
|
|
*/
|
|
function Format($formattingString) {
|
|
if($this->value) return date($formattingString, strtotime($this->value));
|
|
}
|
|
|
|
/*
|
|
* Return a string in the form "12 - 16 Sept" or "12 Aug - 16 Sept"
|
|
*/
|
|
function RangeString($otherDateObj) {
|
|
$d1 = $this->DayOfMonth();
|
|
$d2 = $otherDateObj->DayOfMonth();
|
|
$m1 = $this->ShortMonth();
|
|
$m2 = $otherDateObj->ShortMonth();
|
|
$y1 = $this->Year();
|
|
$y2 = $otherDateObj->Year();
|
|
|
|
if($y1 != $y2) return "$d1 $m1 $y1 - $d2 $m2 $y2";
|
|
else if($m1 != $m2) return "$d1 $m1 - $d2 $m2 $y1";
|
|
else return "$d1 - $d2 $m1 $y1";
|
|
}
|
|
|
|
function Rfc822() {
|
|
if($this->value) return date('r', strtotime($this->value));
|
|
}
|
|
|
|
/**
|
|
* Returns the number of seconds/minutes/hours/days or months since the timestamp
|
|
*/
|
|
function Ago() {
|
|
if($this->value) {
|
|
if(time() < strtotime($this->value)) $agoWord = _t("Date.AWAY", " away");
|
|
else $agoWord = _t("Date.AGO", " ago");
|
|
|
|
return $this->TimeDiff() . $agoWord;
|
|
}
|
|
}
|
|
|
|
function TimeDiff() {
|
|
|
|
if($this->value) {
|
|
$ago = abs(time() - strtotime($this->value));
|
|
|
|
if($ago < 60) {
|
|
$span = $ago;
|
|
return ($span != 1) ? "{$span}"._t("Date.SECS", " secs") : "{$span}"._t("Date.SEC", " sec");
|
|
}
|
|
if($ago < 3600) {
|
|
$span = round($ago/60);
|
|
return ($span != 1) ? "{$span}"._t("Date.MINS", " mins") : "{$span}"._t("Date.MIN", " min");
|
|
}
|
|
if($ago < 86400) {
|
|
$span = round($ago/3600);
|
|
return ($span != 1) ? "{$span}"._t("Date.HOURS", " hours") : "{$span}"._t("Date.HOUR", " hour");
|
|
}
|
|
if($ago < 86400*30) {
|
|
$span = round($ago/86400);
|
|
return ($span != 1) ? "{$span}"._t("Date.DAYS", " days") : "{$span}"._t("Date.DAY", " day");
|
|
}
|
|
if($ago < 86400*365) {
|
|
$span = round($ago/86400/30);
|
|
return ($span != 1) ? "{$span}"._t("Date.MONTHS", " months") : "{$span}"._t("Date.MONTH", " month");
|
|
}
|
|
if($ago > 86400*365) {
|
|
$span = round($ago/86400/365);
|
|
return ($span != 1) ? "{$span}"._t("Date.YEARS", " years") : "{$span}"._t("Date.YEAR", " year");
|
|
}
|
|
}
|
|
}
|
|
|
|
function requireField() {
|
|
DB::requireField($this->tableName, $this->name, "date");
|
|
}
|
|
|
|
function InPast() {
|
|
return strtotime( $this->value ) < time();
|
|
}
|
|
|
|
/**
|
|
* Returns a date suitable for insertion into a URL and use by the system.
|
|
*/
|
|
function URLDate() {
|
|
return date('Y-m-d', strtotime($this->value));
|
|
}
|
|
|
|
|
|
function days_between($fyear, $fmonth, $fday, $tyear, $tmonth, $tday){
|
|
return abs((mktime ( 0, 0, 0, $fmonth, $fday, $fyear) - mktime ( 0, 0, 0, $tmonth, $tday, $tyear))/(60*60*24));
|
|
}
|
|
|
|
function day_before($fyear, $fmonth, $fday){
|
|
return date ("Y-m-d", mktime (0,0,0,$fmonth,$fday-1,$fyear));
|
|
}
|
|
|
|
function next_day($fyear, $fmonth, $fday){
|
|
return date ("Y-m-d", mktime (0,0,0,$fmonth,$fday+1,$fyear));
|
|
}
|
|
|
|
function weekday($fyear, $fmonth, $fday){ // 0 is a Monday
|
|
return (((mktime ( 0, 0, 0, $fmonth, $fday, $fyear) - mktime ( 0, 0, 0, 7, 17, 2006))/(60*60*24))+700000) % 7;
|
|
}
|
|
|
|
function prior_monday($fyear, $fmonth, $fday){
|
|
return date ("Y-m-d", mktime (0,0,0,$fmonth,$fday-weekday($fyear, $fmonth, $fday),$fyear));
|
|
}
|
|
|
|
/**
|
|
* Return the nearest date in the past, based on day and month. Automatically attaches the correct year.
|
|
* Useful for determining a financial year start date.
|
|
*
|
|
* @param $fmonth int
|
|
* @param $fday int
|
|
* @param $fyear int Determine historical value
|
|
*/
|
|
static function past_date($fmonth, $fday = 1, $fyear = null) {
|
|
if(!$fyear) $fyear = date('Y');
|
|
$fday = (int)$fday;
|
|
$fmonth = (int)$fmonth;
|
|
$fyear = (int)$fyear;
|
|
|
|
$pastDate = mktime(0,0,0, $fmonth,$fday,$fyear);
|
|
$curDate = mktime(0,0,0,date('m'), date('d'),$fyear);
|
|
|
|
// if the pastdate is actually past, select it with the current year
|
|
// otherwise substract a year
|
|
if($pastDate < $curDate) {
|
|
return date("Y-m-d", mktime(0,0,0,$fmonth,$fday,$fyear));
|
|
} else {
|
|
return date("Y-m-d", mktime(0,0,0,$fmonth,$fday,$fyear-1));
|
|
}
|
|
}
|
|
}
|
|
|
|
?>
|