]> git.mxchange.org Git - friendica.git/blobdiff - include/datetime.php
upgrading the photo and name update
[friendica.git] / include / datetime.php
index 0beadbe78ebc0e5e774f69df0ce87c7232705746..d241f779e4510d4c0736b732ade229a464b2c31c 100644 (file)
@@ -8,8 +8,8 @@ function timezone_cmp($a, $b) {
        }
        if(strstr($a,'/')) return -1;
        if(strstr($b,'/')) return  1;
-       if ($a == $b) return 0;
-       return ($a < $b) ? -1 : 1;
+       if ( t($a) == t($b)) return 0;
+       return ( t($a) < t($b)) ? -1 : 1;
 }}
 
 
@@ -29,7 +29,7 @@ function select_timezone($current = 'America/Los_Angeles') {
                                if($continent != '')
                                        $o .= '</optgroup>';
                                $continent = $ex[0];
-                               $o .= "<optgroup label=\"$continent\">";
+                               $o .= '<optgroup label="' . t($continent) . '">';
                        }
                        if(count($ex) > 2)
                                $city = substr($value,strpos($value,'/')+1);
@@ -41,10 +41,10 @@ function select_timezone($current = 'America/Los_Angeles') {
                        if($continent != 'Miscellaneous') {
                                $o .= '</optgroup>';
                                $continent = 'Miscellaneous';
-                               $o .= "<optgroup label=\"$continent\">";        
+                               $o .= '<optgroup label="' . t($continent) . '">';       
                        }
                }
-               $city = str_replace('_', ' ', $city);
+               $city = str_replace('_', ' ',  t($city));
                $selected = (($value == $current) ? " selected=\"selected\" " : "");
                $o .= "<option value=\"$value\" $selected >$city</option>";
        }    
@@ -55,12 +55,28 @@ function select_timezone($current = 'America/Los_Angeles') {
 
 if(! function_exists('datetime_convert')) {
 function datetime_convert($from = 'UTC', $to = 'UTC', $s = 'now', $fmt = "Y-m-d H:i:s") {
-  $d = new DateTime($s, new DateTimeZone($from));
-  $d->setTimeZone(new DateTimeZone($to));
-  return($d->format($fmt));
-}}
 
+       // Slight hackish adjustment so that 'zero' datetime actually returns what is intended
+        // otherwise we end up with -0001-11-30 ...
+       // add 32 days so that we at least get year 00, and then hack around the fact that 
+        // months and days always start with 1. 
+
+       if(substr($s,0,10) == '0000-00-00') {
+               $d = new DateTime($s . ' + 32 days', new DateTimeZone('UTC'));
+               return str_replace('1','0',$d->format($fmt));
+       }
+
+       $d = new DateTime($s, new DateTimeZone($from));
+       $d->setTimeZone(new DateTimeZone($to));
+       return($d->format($fmt));
+}}
 
+function dob($dob) {
+       list($year,$month,$day) = sscanf($dob,'%4d-%2d-%2d');
+       $y = datetime_convert('UTC',date_default_timezone_get(),'now','Y');
+       $o = datesel('',1920,$y,true,$year,$month,$day);
+       return $o;
+}
 
 if(! function_exists('datesel')) {
 function datesel($pre,$ymin,$ymax,$allow_blank,$y,$m,$d) {
@@ -68,25 +84,27 @@ function datesel($pre,$ymin,$ymax,$allow_blank,$y,$m,$d) {
        $o = '';
        $o .= "<select name=\"{$pre}year\" class=\"{$pre}year\" size=\"1\">";
        if($allow_blank) {
-               $sel = (($y == '') ? " selected=\"selected\" " : "");
-               $o .= "<option value=\"\" $sel></option>";
+               $sel = (($y == '0000') ? " selected=\"selected\" " : "");
+               $o .= "<option value=\"0000\" $sel ></option>";
        }
 
-       for($x = $ymin; $x <= $ymax; $x ++) {
+       for($x = $ymax; $x >= $ymin; $x --) {
                $sel = (($x == $y) ? " selected=\"selected\" " : "");
                $o .= "<option value=\"$x\" $sel>$x</option>";
        }
   
-       $o .= "</select>-<select name=\"{$pre}month\" class=\"{$pre}month\" size=\"1\">";
-       for($x = 1; $x <= 12; $x ++) {
+       $o .= "</select> <select name=\"{$pre}month\" class=\"{$pre}month\" size=\"1\">";
+       for($x = 0; $x <= 12; $x ++) {
                $sel = (($x == $m) ? " selected=\"selected\" " : "");
-               $o .= "<option value=\"$x\" $sel>$x</option>";
+               $y = (($x) ? $x : '');
+               $o .= "<option value=\"$x\" $sel>$y</option>";
        }
 
-       $o .= "</select>-<select name=\"{$pre}day\" class=\"{$pre}day\" size=\"1\">";
-       for($x = 1; $x <= 31; $x ++) {
+       $o .= "</select> <select name=\"{$pre}day\" class=\"{$pre}day\" size=\"1\">";
+       for($x = 0; $x <= 31; $x ++) {
                $sel = (($x == $d) ? " selected=\"selected\" " : "");
-               $o .= "<option value=\"$x\" $sel>$x</option>";
+               $y = (($x) ? $x : '');
+               $o .= "<option value=\"$x\" $sel>$y</option>";
        }
 
        $o .= "</select>";
@@ -94,59 +112,39 @@ function datesel($pre,$ymin,$ymax,$allow_blank,$y,$m,$d) {
 }}
 
 
-// TODO rewrite this buggy sucker
+if(! function_exists('relative_date')) {
 function relative_date($posted_date) {
 
        $localtime = datetime_convert('UTC',date_default_timezone_get(),$posted_date); 
-    
-       $in_seconds = strtotime($localtime);
 
-       $diff = time() - $in_seconds;
+       $abs = strtotime($localtime);
+       $etime = time() - $abs;
+    
+       if ($etime < 1) {
+               return t('less than a second ago');
+       }
     
-       $months = floor($diff/2592000);
-       $diff -= $months*2419200;
-       $weeks = floor($diff/604800);
-       $diff -= $weeks*604800;
-       $days = floor($diff/86400);
-       $diff -= $days*86400;
-       $hours = floor($diff/3600);
-       $diff -= $hours*3600;
-       $minutes = floor($diff/60);
-       $diff -= $minutes*60;
-       $seconds = $diff;
-
-       if($months > 2)
-               return(datetime_convert('UTC',date_default_timezone_get(),$posted_date,'\o\n Y-m-d \a\t H:i:s'));
-    if ($months>0) {
-        // over a month old,
-        return 'over a month ago';
-    } else {
-        if ($weeks>0) {
-            // weeks and days
-            $relative_date .= ($relative_date?', ':'').$weeks.' week'.($weeks!=1 ?'s':'');
-
-        } elseif ($days>0) {
-            // days and hours
-            $relative_date .= ($relative_date?', ':'').$days.' day'.($days!=1?'s':'');
-
-        } elseif ($hours>0) {
-            // hours and minutes
-            $relative_date .= ($relative_date?', ':'').$hours.' hour'.($hours!=1?'s':'');
-
-        } elseif ($minutes>0) {
-            // minutes only
-            $relative_date .= ($relative_date?', ':'').$minutes.' minute'.($minutes!=1?'s':'');
-        } else {
-            // seconds only
-            $relative_date .= ($relative_date?', ':'').$seconds.' second'.($seconds!=1?'s':'');
+       $a = array( 12 * 30 * 24 * 60 * 60  =>  array( t('year'),   t('years')),
+                   30 * 24 * 60 * 60       =>  array( t('month'),  t('months')),
+                   7  * 24 * 60 * 60       =>  array( t('week'),   t('weeks')),
+                   24 * 60 * 60            =>  array( t('day'),    t('days')),
+                   60 * 60                 =>  array( t('hour'),   t('hours')),
+                   60                      =>  array( t('minute'), t('minutes')),
+                   1                       =>  array( t('second'), t('seconds'))
+       );
+    
+       foreach ($a as $secs => $str) {
+       $d = $etime / $secs;
+       if ($d >= 1) {
+               $r = round($d);
+               return $r . ' ' . (($r == 1) ? $str[0] : $str[1]) . t(' ago');
         }
     }
-    // show relative date and add proper verbiage
-    return $relative_date.' ago';
-}
+}}
+
 
 function age($dob,$owner_tz = '',$viewer_tz = '') {
-       if(strlen($dob) != 10)
+       if(! intval($dob))
                return 0;
        if(! $owner_tz)
                $owner_tz = date_default_timezone_get();