function views_handler_field_date::render

3.x views_handler_field_date.inc views_handler_field_date::render($values)
2.x views_handler_field_date.inc views_handler_field_date::render($values)

Render the field.

Parameters

$values: The values retrieved from the database.

Overrides views_handler_field::render

1 call to views_handler_field_date::render()
2 methods override views_handler_field_date::render()

File

handlers/views_handler_field_date.inc, line 46

Class

views_handler_field_date
A handler to provide proper displays for dates.

Code

function render($values) {
  $value = $values->{$this->field_alias};
  $format = $this->options['date_format'];
  if (in_array($format, array('custom', 'raw time ago', 'time ago', 'raw time span', 'time span'))) {
    $custom_format = $this->options['custom_date_format'];
  }

  if ($value) {
    $time_diff = time() - $value; // will be positive for a datetime in the past (ago), and negative for a datetime in the future (hence)
    switch ($format) {
      case 'raw time ago':
        return format_interval($time_diff, is_numeric($custom_format) ? $custom_format : 2);
      case 'time ago':
        return t('%time ago', array('%time' => format_interval($time_diff, is_numeric($custom_format) ? $custom_format : 2)));
      case 'raw time span':
        return ($time_diff < 0 ? '-' : '') . format_interval(abs($time_diff), is_numeric($custom_format) ? $custom_format : 2);
      case 'time span':
        return t(($time_diff < 0 ? '%time hence' : '%time ago'), array('%time' => format_interval(abs($time_diff), is_numeric($custom_format) ? $custom_format : 2)));
      case 'custom':
        if ($custom_format == 'r') {
          return format_date($value, $format, $custom_format, null, 'en');
        }
        return format_date($value, $format, $custom_format);
      default:
        return format_date($value, $format);
    }
  }
}