2017-03-16 16:59:53 +01:00
|
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* This class renders the html for the event time.
|
|
|
|
|
*
|
|
|
|
|
* @author Time.ly Network Inc.
|
|
|
|
|
* @since 2.0
|
|
|
|
|
*
|
|
|
|
|
* @package AI1EC
|
|
|
|
|
* @subpackage AI1EC.View.Event
|
|
|
|
|
*/
|
|
|
|
|
class Ai1ec_View_Event_Time extends Ai1ec_Base {
|
|
|
|
|
|
2017-11-09 17:36:04 +01:00
|
|
|
|
/**
|
|
|
|
|
* Returns timespan expression for the event.
|
|
|
|
|
*
|
|
|
|
|
* Properly handles:
|
|
|
|
|
* - instantaneous events
|
|
|
|
|
* - all-day events
|
|
|
|
|
* - multi-day events
|
|
|
|
|
* Display of start date can be hidden (non-all-day events only) or full
|
|
|
|
|
* date. All-day status, if any, is enclosed in a span.ai1ec-allday-badge
|
|
|
|
|
* element.
|
|
|
|
|
*
|
|
|
|
|
* @param Ai1ec_Event $event Rendered event.
|
|
|
|
|
* @param string $start_date_display Can be one of 'hidden', 'short',
|
|
|
|
|
* or 'long'.
|
|
|
|
|
*
|
|
|
|
|
* @return string Formatted timespan HTML element.
|
|
|
|
|
*/
|
|
|
|
|
public function get_timespan_html(
|
|
|
|
|
Ai1ec_Event $event,
|
|
|
|
|
$start_date_display = 'long'
|
|
|
|
|
) {
|
|
|
|
|
// Makes no sense to hide start date for all-day events, so fix argument
|
|
|
|
|
if ( 'hidden' === $start_date_display && $event->is_allday() ) {
|
|
|
|
|
$start_date_display = 'short';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Localize time.
|
|
|
|
|
$start = $this->_registry->get( 'date.time', $event->get( 'start' ) );
|
|
|
|
|
$end = $this->_registry->get( 'date.time', $event->get( 'end' ) );
|
|
|
|
|
|
|
|
|
|
// All-day events need to have their end time shifted by 1 second less
|
|
|
|
|
// to land on the correct day.
|
|
|
|
|
$end_offset = 0;
|
|
|
|
|
if ( $event->is_allday() ) {
|
|
|
|
|
$end->set_time(
|
|
|
|
|
$end->format( 'H' ),
|
|
|
|
|
$end->format( 'i' ),
|
|
|
|
|
$end->format( 's' ) - 1
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Get timestamps of start & end dates without time component.
|
|
|
|
|
$start_ts = $this->_registry->get( 'date.time', $start )
|
|
|
|
|
->set_time( 0, 0, 0 )
|
|
|
|
|
->format();
|
|
|
|
|
$end_ts = $this->_registry->get( 'date.time', $end )
|
|
|
|
|
->set_time( 0, 0, 0 )
|
|
|
|
|
->format();
|
|
|
|
|
|
|
|
|
|
$break_years = $start->format( 'Y' ) !== $end->format( 'Y' );
|
|
|
|
|
$output = '';
|
|
|
|
|
|
|
|
|
|
// Display start date, depending on $start_date_display.
|
|
|
|
|
switch ( $start_date_display ) {
|
|
|
|
|
case 'hidden':
|
|
|
|
|
break;
|
|
|
|
|
case 'short':
|
|
|
|
|
case 'long':
|
|
|
|
|
$property = $start_date_display . '_date';
|
|
|
|
|
$output .= $this->{'get_' . $property}( $start, $break_years );
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
$start_date_display = 'long';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Output start time for non-all-day events.
|
|
|
|
|
if ( ! $event->is_allday() ) {
|
|
|
|
|
if ( 'hidden' !== $start_date_display ) {
|
|
|
|
|
$output .= apply_filters(
|
|
|
|
|
'ai1ec_get_timespan_html_time_separator',
|
|
|
|
|
Ai1ec_I18n::_x( ' @ ', 'Event time separator' )
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
$output .= $this->get_short_time( $start );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Find out if we need to output the end time/date. Do not output it for
|
|
|
|
|
// instantaneous events and all-day events lasting only one day.
|
|
|
|
|
if (
|
|
|
|
|
! (
|
|
|
|
|
$event->is_instant() ||
|
|
|
|
|
( $event->is_allday() && $start_ts === $end_ts )
|
|
|
|
|
)
|
|
|
|
|
) {
|
|
|
|
|
$output .= apply_filters(
|
|
|
|
|
'ai1ec_get_timespan_html_date_separator',
|
|
|
|
|
Ai1ec_I18n::_x( ' – ', 'Event start/end separator' )
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// If event ends on a different day, output end date.
|
|
|
|
|
if ( $start_ts !== $end_ts ) {
|
|
|
|
|
// for short date, use short display type
|
|
|
|
|
if ( 'short' === $start_date_display ) {
|
|
|
|
|
$output .= $this->get_short_date( $end, $break_years );
|
|
|
|
|
} else {
|
|
|
|
|
$output .= $this->get_long_date( $end );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Output end time for non-all-day events.
|
|
|
|
|
if ( ! $event->is_allday() ) {
|
|
|
|
|
if ( $start_ts !== $end_ts ) {
|
|
|
|
|
$output .= apply_filters(
|
|
|
|
|
'ai1ec_get_timespan_html_time_separator',
|
|
|
|
|
Ai1ec_I18n::_x( ' @ ', 'Event time separator' )
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
$output .= $this->get_short_time( $end );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$output = esc_html( $output );
|
|
|
|
|
|
|
|
|
|
// Add all-day label.
|
|
|
|
|
if ( $event->is_allday() ) {
|
|
|
|
|
$output .= apply_filters(
|
|
|
|
|
'ai1ec_get_timespan_html_allday_badge',
|
|
|
|
|
' <span class="ai1ec-allday-badge">' .
|
|
|
|
|
Ai1ec_I18n::__( 'all-day' ) .
|
|
|
|
|
'</span>'
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
return apply_filters(
|
|
|
|
|
'ai1ec_get_timespan_html',
|
|
|
|
|
$output,
|
|
|
|
|
$event,
|
|
|
|
|
$start_date_display
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get the html for the exclude dates and exception rules.
|
|
|
|
|
*
|
|
|
|
|
* @param Ai1ec_Event $event
|
|
|
|
|
* @param Ai1ec_Recurrence_Rule $rrule
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
public function get_exclude_html(
|
|
|
|
|
Ai1ec_Event $event,
|
|
|
|
|
Ai1ec_Recurrence_Rule $rrule
|
|
|
|
|
) {
|
|
|
|
|
$excludes = array();
|
|
|
|
|
$exception_rules = $event->get( 'exception_rules' );
|
|
|
|
|
$exception_dates = $event->get( 'exception_dates' );
|
|
|
|
|
if ( $exception_rules ) {
|
|
|
|
|
$excludes[] =
|
|
|
|
|
$rrule->rrule_to_text( $exception_rules );
|
|
|
|
|
}
|
|
|
|
|
if ( $exception_dates && 0 !== strpos( $exception_rules, 'EXDATE' ) ) {
|
|
|
|
|
$excludes[] =
|
|
|
|
|
$rrule->exdate_to_text( $exception_dates );
|
|
|
|
|
}
|
|
|
|
|
return implode( Ai1ec_I18n::__( ', and ' ), $excludes );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get the short date
|
|
|
|
|
*
|
|
|
|
|
* @param Ai1ec_Date_Time $time
|
|
|
|
|
* @param bool $add_year Whether to add year or not.
|
|
|
|
|
*
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
public function get_short_date( Ai1ec_Date_Time $time, $add_year = false ) {
|
|
|
|
|
$months = apply_filters( 'ai1ec_i18n_months', array() );
|
|
|
|
|
$m = $time->format_i18n( 'M' );
|
|
|
|
|
$m = array_key_exists( $m, $months ) ? $months[$m] : $m;
|
|
|
|
|
if ( $add_year ) {
|
|
|
|
|
return $m . ' ' . $time->format_i18n( 'j Y' );
|
|
|
|
|
}
|
|
|
|
|
return $m . ' ' . $time->format_i18n( 'j' );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Format a long-length date for use in other views (e.g., single event).
|
|
|
|
|
*
|
|
|
|
|
* @param Ai1ec_Date_Time $time Object to format.
|
|
|
|
|
*
|
|
|
|
|
* @return string Formatted date time [default: `l, M j, Y`].
|
|
|
|
|
*/
|
|
|
|
|
public function get_long_date( Ai1ec_Date_Time $time ) {
|
|
|
|
|
$date_format = $this->_registry->get( 'model.option' )->get(
|
|
|
|
|
'date_format',
|
|
|
|
|
'l, M j, Y'
|
|
|
|
|
);
|
|
|
|
|
return $time->format_i18n( $date_format );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Format a short-form time for use in compressed (e.g. month) views.
|
|
|
|
|
*
|
|
|
|
|
* @param Ai1ec_Date_Time $time Object to format.
|
|
|
|
|
*
|
|
|
|
|
* @return string Formatted date time [default: `g:i a`].
|
|
|
|
|
*/
|
|
|
|
|
public function get_short_time( Ai1ec_Date_Time $time ) {
|
|
|
|
|
$time_format = $this->_registry->get( 'model.option' )->get(
|
|
|
|
|
'time_format',
|
|
|
|
|
'g:i a'
|
|
|
|
|
);
|
|
|
|
|
return $time->format_i18n( $time_format );
|
|
|
|
|
}
|
2017-03-16 16:59:53 +01:00
|
|
|
|
|
|
|
|
|
}
|