summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorVincent Petry <pvince81@owncloud.com>2013-10-02 20:16:35 +0200
committerVincent Petry <pvince81@owncloud.com>2013-10-03 13:55:05 +0200
commitb0bb64c3eebce41a35cfe6674f63f454d22f200c (patch)
treef3533296fd80835cf1d545ccdd5c01ae92a3d479 /lib
parented14541aea648605536c8180ab56f511013bce38 (diff)
downloadnextcloud-server-b0bb64c3eebce41a35cfe6674f63f454d22f200c.tar.gz
nextcloud-server-b0bb64c3eebce41a35cfe6674f63f454d22f200c.zip
Added unit tests for relative_modified_date, changed method signature
Changed method signature of relative_modified_date template method to make it possible to add a fromTime to compare with, mostly to make it possible to test it. Added unit test for date and time cases.
Diffstat (limited to 'lib')
-rw-r--r--lib/private/template/functions.php20
-rw-r--r--lib/public/template.php4
2 files changed, 15 insertions, 9 deletions
diff --git a/lib/private/template/functions.php b/lib/private/template/functions.php
index 6002113bdd9..858134dd8c6 100644
--- a/lib/private/template/functions.php
+++ b/lib/private/template/functions.php
@@ -100,17 +100,20 @@ function strip_time($timestamp){
* @brief Formats timestamp relatively to the current time using
* a human-friendly format like "x minutes ago" or "yesterday"
* @param int $timestamp timestamp to format
+ * @param int $fromTime timestamp to compare from, defaults to current time
* @param bool $dateOnly whether to strip time information
* @return formatted timestamp
*/
-function relative_modified_date($timestamp, $dateOnly = false) {
+function relative_modified_date($timestamp, $fromTime, $dateOnly = false) {
$l=OC_L10N::get('lib');
- $time = time();
+ if (!isset($fromTime)){
+ $fromTime = time();
+ }
if ($dateOnly){
- $time = strip_time($time);
+ $fromTime = strip_time($fromTime);
$timestamp = strip_time($timestamp);
}
- $timediff = $time - $timestamp;
+ $timediff = $fromTime - $timestamp;
$diffminutes = round($timediff/60);
$diffhours = round($diffminutes/60);
$diffdays = round($diffhours/24);
@@ -119,11 +122,14 @@ function relative_modified_date($timestamp, $dateOnly = false) {
if(!$dateOnly && $timediff < 60) { return $l->t('seconds ago'); }
else if(!$dateOnly && $timediff < 3600) { return $l->n('%n minute ago', '%n minutes ago', $diffminutes); }
else if(!$dateOnly && $timediff < 86400) { return $l->n('%n hour ago', '%n hours ago', $diffhours); }
- else if((date('G', $time)-$diffhours) >= 0) { return $l->t('today'); }
- else if((date('G', $time)-$diffhours) >= -24) { return $l->t('yesterday'); }
+ else if((date('G', $fromTime)-$diffhours) >= 0) { return $l->t('today'); }
+ else if((date('G', $fromTime)-$diffhours) >= -24) { return $l->t('yesterday'); }
+ // 86400 * 31 days = 2678400
else if($timediff < 2678400) { return $l->n('%n day go', '%n days ago', $diffdays); }
+ // 86400 * 60 days = 518400
else if($timediff < 5184000) { return $l->t('last month'); }
- else if((date('n', $time)-$diffmonths) > 0) { return $l->n('%n month ago', '%n months ago', $diffmonths); }
+ else if((date('n', $fromTime)-$diffmonths) > 0) { return $l->n('%n month ago', '%n months ago', $diffmonths); }
+ // 86400 * 365.25 days * 2 = 63113852
else if($timediff < 63113852) { return $l->t('last year'); }
else { return $l->t('years ago'); }
}
diff --git a/lib/public/template.php b/lib/public/template.php
index b3bffaf1af9..6349501272f 100644
--- a/lib/public/template.php
+++ b/lib/public/template.php
@@ -90,8 +90,8 @@ function human_file_size( $bytes ) {
* @param $timestamp unix timestamp
* @returns human readable interpretation of the timestamp
*/
-function relative_modified_date($timestamp, $dateOnly = false) {
- return(\relative_modified_date($timestamp, $dateOnly));
+function relative_modified_date($timestamp, $fromTime, $dateOnly = false) {
+ return(\relative_modified_date($timestamp, $fromTime, $dateOnly));
}