diff options
author | ctrlaltca <> | 2013-01-06 19:12:45 +0000 |
---|---|---|
committer | ctrlaltca <> | 2013-01-06 19:12:45 +0000 |
commit | 11d9e3f39458c4870ca722ba1d3db0d5bba754dc (patch) | |
tree | feaa32bfba9a6480c3b7d5b66b520ec27be9b2cc | |
parent | 0335d5868ca022a455a36fef89bff4952db67c17 (diff) |
fix #44
-rw-r--r-- | HISTORY | 1 | ||||
-rw-r--r-- | framework/Util/TDateTimeStamp.php | 26 | ||||
-rw-r--r-- | framework/Util/TSimpleDateFormatter.php | 11 |
3 files changed, 28 insertions, 10 deletions
@@ -1,5 +1,6 @@ Version 3.2.1 to be released +BUG: Issue #44 - [895] SDateFormatter cannot parse date earlier than 1970 (ctrlaltca) BUG: Issue #412 - open_basedir restriction (ctrlaltca) BUG: Issue #413 - TActiveDatePicker does not fire TCallbackClientSide's events (ctrlaltca) BUG: Issue #414 - ActiveDatagrid's pager does not fire TCallbackClientSide's events (ctrlaltca) diff --git a/framework/Util/TDateTimeStamp.php b/framework/Util/TDateTimeStamp.php index a7a43b3c..f5f76004 100644 --- a/framework/Util/TDateTimeStamp.php +++ b/framework/Util/TDateTimeStamp.php @@ -105,6 +105,30 @@ class TDateTimeStamp /** * @return array an array with date info. */ + function parseDate($txt=false) + { + if ($txt === false) return getdate(); + + $dt = new DateTime($txt); + + return array( + 'seconds' => (int) $dt->format('s'), + 'minutes' => (int) $dt->format('i'), + 'hours' => (int) $dt->format('G'), + 'mday' => (int) $dt->format('j'), + 'wday' => (int) $dt->format('w'), + 'mon' => (int) $dt->format('n'), + 'year' => (int) $dt->format('Y'), + 'yday' => (int) $dt->format('z'), + 'weekday' => $dt->format('l'), + 'month' => $dt->format('F'), + 0 => (int) $dt->format('U'), + ); + } + + /** + * @return array an array with date info. + */ function getDate($d=false,$fast=false) { if ($d === false) return getdate(); @@ -123,7 +147,7 @@ class TDateTimeStamp 'yday' => (int) $dt->format('z'), 'weekday' => $dt->format('l'), 'month' => $dt->format('F'), - 0 => (int) $d + 0 => (int) $dt->format('U'), ); } diff --git a/framework/Util/TSimpleDateFormatter.php b/framework/Util/TSimpleDateFormatter.php index 8b17048a..a1a1842a 100644 --- a/framework/Util/TSimpleDateFormatter.php +++ b/framework/Util/TSimpleDateFormatter.php @@ -173,15 +173,8 @@ class TSimpleDateFormatter */ private function getDate($value) { - if(!is_string($value)) - { - $s = Prado::createComponent('System.Util.TDateTimeStamp'); - return $s->getDate($value); - } - $date = @strtotime($value); - if($date < 0) - throw new TInvalidDataValueException('invalid_date', $value); - return @getdate($date); + $s = Prado::createComponent('System.Util.TDateTimeStamp'); + return $s->parseDate($value); } /** |