From 352fbde2ec29cd869a766687f772de0de217bc33 Mon Sep 17 00:00:00 2001 From: Magnus Johansson Date: Wed, 9 May 2012 20:00:22 +0200 Subject: [PATCH] Move out HTML logic to Helper/TimeHelper.php. The Utility/CakeTime.php timeAgoInWords() now returns a string with the time, while the same function in Helper/TimeHelper.php may return an HTML element. --- lib/Cake/Utility/CakeTime.php | 26 ---------------- lib/Cake/View/Helper/TimeHelper.php | 48 ++++++++++++++++++++++++++++- 2 files changed, 47 insertions(+), 27 deletions(-) diff --git a/lib/Cake/Utility/CakeTime.php b/lib/Cake/Utility/CakeTime.php index 50722c5d3..d30f490ae 100644 --- a/lib/Cake/Utility/CakeTime.php +++ b/lib/Cake/Utility/CakeTime.php @@ -666,7 +666,6 @@ class CakeTime { $timezone = null; $format = self::$wordFormat; $end = self::$wordEnd; - $element = null; $accuracy = self::$wordAccuracy; if (is_array($options)) { @@ -686,24 +685,6 @@ class CakeTime { } } - if (isset($options['element'])) { - $element_options = array( - 'tag' => 'span', - 'class' => 'timeAgoInWords', - 'title' => $dateTime - ); - if (is_array($options['element'])) { - $element = array_merge($element_options, $options['element']); - } else { - if ($options['element']) { - $element = $element_options; - $element['tag'] = $options['element']; - } else { - $element = null; - } - } - } - if (isset($options['format'])) { $format = $options['format']; unset($options['format']); @@ -850,13 +831,6 @@ class CakeTime { $relativeDate = __d('cake', 'just now', 'just now'); } - // Apply HTML element - if ($element) { - $title = isset($element['title']) ? ' title="'.$element['title'].'"' : ''; - $class = isset($element['class']) ? ' class="'.$element['class'].'"' : ''; - $relativeDate = '<'.$element['tag'].''.$title.$class.'>'.$relativeDate.''; - } - return $relativeDate; } diff --git a/lib/Cake/View/Helper/TimeHelper.php b/lib/Cake/View/Helper/TimeHelper.php index 75bd8b6c3..b2a2cb3b0 100644 --- a/lib/Cake/View/Helper/TimeHelper.php +++ b/lib/Cake/View/Helper/TimeHelper.php @@ -349,7 +349,39 @@ class TimeHelper extends AppHelper { * @link http://book.cakephp.org/2.0/en/core-libraries/helpers/time.html#formatting */ public function timeAgoInWords($dateTime, $options = array()) { - return $this->_engine->timeAgoInWords($dateTime, $options); + $element = null; + + $stringDate = ''; + + if (isset($options['element'])) { + $element_options = array( + 'tag' => 'span', + 'class' => 'time-ago-in-words', + 'title' => $dateTime + ); + + if (is_array($options['element'])) { + $element = array_merge($element_options, $options['element']); + } else { + if ($options['element']) { + $element = $element_options; + $element['tag'] = $options['element']; + } else { + $element = null; + } + } + } + + $relativeDate = $this->_engine->timeAgoInWords($dateTime, $options); + + // Apply HTML element + if ($element) { + $title = isset($element['title']) ? ' title="'.$element['title'].'"' : ''; + $class = isset($element['class']) ? ' class="'.$element['class'].'"' : ''; + $relativeDate = '<'.$element['tag'].$title.$class.'>'.$relativeDate.''; + } + + return $relativeDate; } /** @@ -365,6 +397,20 @@ class TimeHelper extends AppHelper { public function wasWithinLast($timeInterval, $dateString, $timezone = null) { return $this->_engine->wasWithinLast($timeInterval, $dateString, $timezone); } + +/** + * @see CakeTime::isWithinLast() + * + * @param mixed $timeInterval the numeric value with space then time type. + * Example of valid types: 6 hours, 2 days, 1 minute. + * @param mixed $dateString the datestring or unix timestamp to compare + * @param mixed $timezone User's timezone string or DateTimeZone object + * @return boolean + * @link http://book.cakephp.org/2.0/en/core-libraries/helpers/time.html#testing-time + */ + public function isWithinNext($timeInterval, $dateString, $timezone = null) { + return $this->_engine->isWithinNext($timeInterval, $dateString, $timezone); + } /** * @see CakeTime::gmt()