File "classes.php"

Full Path: /home/romayxjt/public_html/wp-content/plugins/the-events-calendar/src/Tribe/Views/V2/functions/classes.php
File size: 6.9 KB
MIME-type: text/x-php
Charset: utf-8

<?php
/**
 * Calendar Class Functions
 *
 * @since 5.1.1
 */
namespace Tribe\Events\Views\V2;

use Tribe__Date_Utils as Dates;

// Don't load directly!
if ( ! defined( 'ABSPATH' ) ) {
	die( '-1' );
}

if ( ! class_exists( 'Tribe__Events__Main' ) ) {
	return;
}

/**
 * A list of CSS classes that will be added to multiday events in month view.
 * Used in the Month view multiday loop.
 *
 * @since 5.1.1
 *
 * @param WP_Post $event            An event post object with event-specific properties added from the `tribe_get_event`
 *                                  function.
 * @param string  $day_date         The date of the day currently being displayed in `Y-m-d` format.
 * @param bool    $is_start_of_week Whether the current grid day being rendered is the first day of the week or not.
 * @param string  $today_date       Today's date in `Y-m-d` format.
 *
 * @return array<string> $classes   The classes to add to the multiday event.
 */
function month_multiday_classes( $event, $day_date, $is_start_of_week, $today_date ) {
	$classes = tribe_get_post_class( [ 'tribe-events-calendar-month__multiday-event' ], $event->ID );

	if ( ! empty( $event->featured ) ) {
		$classes[] = 'tribe-events-calendar-month__multiday-event--featured';
	}

	/*
	 * To keep the calendar accessible, in the context of a week, we'll print the event only on either its first day
	 * or the first day of the week.
	 */
	$should_display = $is_start_of_week || in_array( $day_date, $event->displays_on, true );

	// If the event doesn't start today or this week, let's not add the left border or set the width.
	if ( ! $should_display ) {
		/**
		 * Allows filtering the multiday event classes.
		 *
		 * @since 5.1.1
		 *
		 * @param array<string> $classes    An array of the classes to be applied.
		 * @param WP_Post $event            An event post object with event-specific properties added from the `tribe_get_event`
		 *                                  function.
		 * @param string  $day_date         The date of the day currently being displayed in `Y-m-d` format.
		 * @param bool    $is_start_of_week Whether the current grid day being rendered is the first day of the week or not.
		 * @param string  $today_date       Today's date in `Y-m-d` format.
		 */
		return apply_filters( 'tribe_events_views_v2_month_multiday_classes', $classes, $event, $day_date, $is_start_of_week, $today_date );
	}

	/*
	* The "duration" here is how many days the event will take this week, not in total.
	* The two values might be the same, but they will differ for events that last more than one week.
	*/
	$classes[] = 'tribe-events-calendar-month__multiday-event--width-' . $event->this_week_duration;
	$classes[] = 'tribe-events-calendar-month__multiday-event--display';

	// If the event ends this week, let's add the start class (left border).
	if ( $event->starts_this_week ) {
		$classes[] = 'tribe-events-calendar-month__multiday-event--start';
	}

	// If the event ends this week, let's add the end class (right border).
	if ( $event->ends_this_week ) {
		$classes[] = 'tribe-events-calendar-month__multiday-event--end';
	}

	if ( $event->dates->end->format( 'Y-m-d' ) < $today_date ) {
		$classes[] = 'tribe-events-calendar-month__multiday-event--past';
	}

	/**
	 * Allows filtering the multiday event classes.
	 *
	 * @since 5.1.1
	 *
	 * @param array<string> $classes    An array of the classes to be applied.
	 * @param WP_Post $event            An event post object with event-specific properties added from the `tribe_get_event`
	 *                                  function.
	 * @param string  $day_date         The date of the day currently being displayed in `Y-m-d` format.
	 * @param bool    $is_start_of_week Whether the current grid day being rendered is the first day of the week or not.
	 * @param string  $today_date       Today's date in `Y-m-d` format.
	 */
	return apply_filters( 'tribe_events_views_v2_month_multiday_classes', $classes, $event, $day_date, $is_start_of_week, $today_date );
}

/**
 * A list of CSS classes that will be added to the day "cell" in month view.
 * Used in the Month View days loop.
 *
 * @since 6.0.2
 * @since 6.2.9 Updated logic to always default to comparing days with today's date.
 *
 * @param array<mixed> $day          The current day data.
 * @param string       $day_date     The current day date in `Y-m-d` format.
 * @param \DateTime    $request_date The request date for the view.
 * @param string       $today_date   Today's date in `Y-m-d` format.
 *
 * @return array<string,bool> $day_classes The classes to add to the day "cell".
 */
function month_day_classes( array $day, string $day_date, \DateTime $request_date, string $today_date ) {
	/**
	 * Allows filtering the date used for comparison when generating the Month View day cell classes.
	 *
	 * @since 6.0.2
	 * @since 6.2.9 Added `$today_date` parameter to the filter.
	 * @since 6.2.9 Comparison date now defaults to today's date instead of the request date.
	 *
	 * @param string       $comparison_date The date used for comparisons. Defaults to today's date (`$today_date`).
	 * @param \DateTime    $request_date    The request date for the view.
	 * @param string       $day_date        The current day date in `Y-m-d` format.
	 * @param array<mixed> $day             The current day data.
	 * @param string       $today_date      Today's date in `Y-m-d` format.
	 */
	$comparison_date = apply_filters( 'tec_events_month_day_classes_comparison_date', $today_date, $request_date, $day_date, $day, $today_date );

	// Convert it to a date object.
	$comparison_date = Dates::immutable( $comparison_date );

	// Classes in array are applied if the value is truthy, not applied if the value is falsy.
	$day_classes = [
		'tribe-events-calendar-month__day'              => true,
		// Add a class for the current day.
		'tribe-events-calendar-month__day--current'     => $comparison_date->format( 'Y-m-d' ) === $day_date,
		// Add a class for the past days (includes days in the requested month).
		'tribe-events-calendar-month__day--past'        => $comparison_date->format( 'Y-m-d' ) > $day_date,
		// Not the requested month.
		'tribe-events-calendar-month__day--other-month' => $day[ 'month_number' ] !== $comparison_date->format( 'm' ),
		// Past month.
		'tribe-events-calendar-month__day--past-month'  => $day[ 'month_number' ] < $comparison_date->format( 'm' ),
		// Future month.
		'tribe-events-calendar-month__day--next-month'  => $day[ 'month_number' ] > $comparison_date->format( 'm' ),
	];

	/**
	 * Allows filtering the final list of classes for each Month View day cell.
	 *
	 * @since 6.0.2
	 *
	 * @param array<string,bool> $day_classes     The classes to add to the day "cell".
	 * @param string             $comparison_date The date that was used for comparisons.
	 * @param array<mixed>       $day             The current day data.
	 *
	 * @return array<string> $day_classes The final list of classes to add to the day "cell".
	 */
	return (array) apply_filters( 'tec_events_month_day_classes', $day_classes, $comparison_date, $day );
}