Day_View

Contents


Source

File: src/Tribe/Views/V2/Views/Day_View.php

class Day_View extends View {
	/**
	 * Slug for this view
	 *
	 * @since 4.9.4
	 *
	 * @var string
	 */
	protected $slug = 'day';

	/**
	 * Visibility for this view.
	 *
	 * @since 4.9.4
	 *
	 * @var bool
	 */
	protected $publicly_visible = true;

	/**
	 * {@inheritDoc}
	 */
	public function prev_url( $canonical = false, array $passthru_vars = [] ) {
		// Get the current repository arguments.
		$current_args = $this->setup_repository_args();

		// Remove any date related arguments.
		unset( $current_args['date_overlaps'] );

		// Use the updated repository arguments.
		$current_repository = tribe_events()->by_args( $current_args );

		$default_date   = 'today';
		$date           = $this->context->get( 'event_date', $default_date );
		$event_date_var = $default_date === $date ? '' : $date;

		$one_day = new \DateInterval( 'P1D' );
		$previous_date = Dates::build_date_object( $date )->sub( $one_day )->format( Dates::DBDATEFORMAT );

		$prev = clone $current_repository;
		$start = tribe_beginning_of_day( $previous_date );
		$end  = tribe_end_of_day( $previous_date );
		$prev->where( 'date_overlaps', $start, $end )->order( 'DESC' )->per_page( 1 );

		$prev_event = $prev->first();
		$has_prev = $prev->found();

		if ( ! $has_prev ) {
			$prev = clone $current_repository;
			$prev->where( 'starts_before', tribe_beginning_of_day( $date ) )
			->order( 'DESC' )
			->per_page( 1 );

			$prev_event = $prev->first();
			$has_prev = $prev->found();

			if ( ! $has_prev ) {
				return '';
			}

			$previous_date = tribe_get_start_date( $prev_event, false, Dates::DBDATEFORMAT );
		}

		$query_args = [ 'eventDate' => $previous_date ];
		$url = remove_query_arg( [ 'tribe-bar-date' ], $this->get_url() );
		$url = add_query_arg( $query_args, $url );

		if ( ! empty( $url ) && $canonical ) {
			$input_url = $url;

			if ( ! empty( $passthru_vars ) ) {
				$input_url = remove_query_arg( array_keys( $passthru_vars ), $url );
			}

			// Make sure the view slug is always set to correctly match rewrites.
			$input_url = add_query_arg( [ 'eventDisplay' => $this->slug ], $input_url );

			$canonical_url = tribe( 'events.rewrite' )->get_clean_url( $input_url );

			if ( ! empty( $passthru_vars ) ) {
				$canonical_url = add_query_arg( $passthru_vars, $canonical_url );
			}

			$url = $canonical_url;
		}

		$url = $this->filter_prev_url( $canonical, $url );

		return $url;
	}

	/**
	 * {@inheritDoc}
	 */
	public function next_url( $canonical = false, array $passthru_vars = [] ) {
		// Get the current repository arguments.
		$current_args = $this->setup_repository_args();

		// Remove any date related arguments.
		unset( $current_args['date_overlaps'] );

		// Use the updated repository arguments.
		$current_repository = tribe_events()->by_args( $current_args );

		$default_date   = 'today';
		$date           = $this->context->get( 'event_date', $default_date );
		$event_date_var = $default_date === $date ? '' : $date;

		$one_day = new \DateInterval( 'P1D' );
		$next_date = Dates::build_date_object( $date )->add( $one_day )->format( Dates::DBDATEFORMAT );

		$next = clone $current_repository;
		$start = tribe_beginning_of_day( $next_date );
		$end   = tribe_end_of_day( $next_date );
		$next->where( 'date_overlaps', $start, $end )->order( 'DESC' )->per_page( 1 );

		$next_event = $next->first();
		$has_next = $next->found();

		if ( ! $has_next ) {
			$next = clone $current_repository;
			$next->where( 'starts_after', tribe_end_of_day( $date ) )->order( 'DESC' )->per_page( 1 );

			$next_event = $next->first();
			$has_next = $next->found();

			if ( ! $has_next ) {
				return '';
			}

			$next_date = tribe_get_start_date( $next_event, false, Dates::DBDATEFORMAT );
		}

		$query_args = [ 'eventDate' => $next_date ];
		$url = remove_query_arg( [ 'tribe-bar-date' ], $this->get_url() );
		$url = add_query_arg( $query_args, $url );

		if ( ! empty( $url ) && $canonical ) {
			$input_url = $url;

			if ( ! empty( $passthru_vars ) ) {
				$input_url = remove_query_arg( array_keys( $passthru_vars ), $url );
			}

			// Make sure the view slug is always set to correctly match rewrites.
			$input_url = add_query_arg( [ 'eventDisplay' => $this->slug ], $input_url );

			$canonical_url = tribe( 'events.rewrite' )->get_clean_url( $input_url );

			if ( ! empty( $passthru_vars ) ) {
				$canonical_url = add_query_arg( $passthru_vars, $canonical_url );
			}

			$url = $canonical_url;
		}

		$url = $this->filter_next_url( $canonical, $url );

		return $url;
	}

	/**
	 * {@inheritDoc}
	 */
	protected function setup_repository_args( \Tribe__Context $context = null ) {
		$context = null !== $context ? $context : $this->context;

		$args = parent::setup_repository_args( $context );

		$context_arr = $context->to_array();

		$date = Arr::get( $context_arr, 'event_date', 'now' );
		$event_display = Arr::get( $context_arr, 'event_display_mode', Arr::get( $context_arr, 'event_display' ), 'current' );

		$args['date_overlaps'] = [ tribe_beginning_of_day( $date ), tribe_end_of_day( $date ) ];

		return $args;
	}
}

Top ↑

Methods