File "ORM.php"
Full Path: /home/romayxjt/public_html/wp-content/plugins/the-events-calendar/src/Tribe/Service_Providers/ORM.php
File size: 3.38 KB
MIME-type: text/x-php
Charset: utf-8
<?php
/**
* Hooks and registers the functions and implementations needed to provide
* the ORM/Repository classes.
*
* @since 4.9
*/
use TEC\Common\Contracts\Service_Provider;
/**
* Class Tribe__Events__Service_Providers__ORM
*
* @since 4.9
*/
class Tribe__Events__Service_Providers__ORM extends Service_Provider {
/**
* Binds and sets up implementations.
*/
public function register() {
require_once tribe( 'tec.main' )->plugin_path . 'src/functions/template-tags/orm.php';
// Not bound as a singleton to leverage the repository instance properties and to allow decoration and injection.
$this->container->bind( 'events.event-repository', 'Tribe__Events__Repositories__Event' );
$this->container->bind( 'events.organizer-repository', 'Tribe__Events__Repositories__Organizer' );
$this->container->bind( 'events.venue-repository', 'Tribe__Events__Repositories__Venue' );
add_filter( 'tribe_events_has_next_args', [ $this, 'maybe_remove_date_meta_queries' ], 1, 2 );
add_filter( 'tribe_events_has_previous_args', [ $this, 'maybe_remove_date_meta_queries' ], 1, 2 );
add_action( 'tribe_repository_events_pre_get_posts', [ $this, 'ensure_event_post_types_on_search' ], 50 );
}
/**
* Handles next and previous links arguments when generated on a repository-managed query.
*
* The next and previous links are built by using the global query arguments and slightly altering them.
* This approach, when done on the arguments provided by a repository generated query, might yield duplicated
* meta queries that will, in turn, return wrong results.
* The arguments will be already set in the arguments of the query.
*
* @since 4.9
*
* @param array $args An array of query arguments that will be used to check if there are next or previous
* events.
* @param \WP_Query|null $query The query the arguments were taken from.
*
* @return array A filtered array of arguments where the date-related contents of the meta query are removed to
* avoid duplicates.
*/
public function maybe_remove_date_meta_queries( array $args = [], WP_Query $query = null ) {
if ( empty( $args['meta_query'] ) || ! $query instanceof WP_Query ) {
return $args;
}
if ( empty( $query->builder ) || ! $query->builder instanceof Tribe__Repository__Interface ) {
return $args;
}
$args['meta_query'] = tribe_filter_meta_query(
$args['meta_query'],
[ 'key' => '/_Event(Start|End)Date(UTC)*/' ]
);
return $args;
}
/**
* Ensures that if something hooks into `pre_get_posts` and alters the query post type
* the `tribe_events` post type is preserved so event searches don't break.
*
* @todo: investigate if we need this for organizers/venues as well.
*
* @since 5.8.2
*
* @param WP_Query $query
*
* @return WP_Query modified query
*/
public function ensure_event_post_types_on_search( $query ) {
if ( ! $query->is_search ) {
return $query;
}
if ( ! in_array( Tribe__Events__Main::POSTTYPE , (array) $query->query['post_type'] ) ) {
return $query;
}
$query_post_type = $query->query_vars['post_type'];
if ( ! is_array( $query_post_type ) ) {
// If it's not an array, overwrite it.
$query_post_type = Tribe__Events__Main::POSTTYPE;
} else {
// Else add event.
$query_post_type[] = Tribe__Events__Main::POSTTYPE;
}
$query->query_vars['post_type'] = $query_post_type;
return $query;
}
}