Задача:
Нужна была функция которая считала бы время прошедшее до сегодняшнего момента. К примеру, на сайте кто-то зарегистрировался, эта информация хранится в БД MySQL в виде timestamp, что мне надо так это заходя на профиль пользователя увидеть сколько прошло времени с даты регистрации.
В таком-же виде выводится дата сообщений в социальных сетях. Как известно, в Twitter и Facebook даты сообщений проставляются не стандартно, а показывают сколько прошло времени с момента публикации: «30 секунд назад» или «2 часа назад».
Решение:
function showDate( $date ) // $date --> время в формате Unix time { $stf = 0; $cur_time = time(); $diff = $cur_time - $date; $seconds = array( 'секунда', 'секунды', 'секунд' ); $minutes = array( 'минута', 'минуты', 'минут' ); $hours = array( 'час', 'часа', 'часов' ); $days = array( 'день', 'дня', 'дней' ); $weeks = array( 'неделя', 'недели', 'недель' ); $months = array( 'месяц', 'месяца', 'месяцев' ); $years = array( 'год', 'года', 'лет' ); $decades = array( 'десятилетие', 'десятилетия', 'десятилетий' ); $phrase = array( $seconds, $minutes, $hours, $days, $weeks, $months, $years, $decades ); $length = array( 1, 60, 3600, 86400, 604800, 2630880, 31570560, 315705600 ); for ( $i = sizeof( $length ) - 1; ( $i >= 0 ) && ( ( $no = $diff / $length[ $i ] ) <= 1 ); $i -- ) { ; } if ( $i < 0 ) { $i = 0; } $_time = $cur_time - ( $diff % $length[ $i ] ); $no = floor( $no ); $value = sprintf( "%d %s ", $no, getPhrase( $no, $phrase[ $i ] ) ); if ( ( $stf == 1 ) && ( $i >= 1 ) && ( ( $cur_time - $_time ) > 0 ) ) { $value .= time_ago( $_time ); } return $value; } function getPhrase( $number, $titles ) { $cases = array( 2, 0, 1, 1, 1, 2 ); return $titles[ ( $number % 100 > 4 && $number % 100 < 20 ) ? 2 : $cases[ min( $number % 10, 5 ) ] ]; }