the queue or not. * @param array $class The array of body class names to add. * @param string $queue The queue we want to get 'admin', 'display', 'all'. * @return boolean */ public function body_class_should_add_to_queue( $add, $class, $queue ) { $add = $this->container->make( Template_Bootstrap::class )->should_add_body_class_to_queue( $add, $class, $queue ); $add = $this->container->make( Theme_Compatibility::class )->should_add_body_class_to_queue( $add, $class, $queue ); return $add; } /** * Logic for if body classes should be added. * * @since 5.1.5 * * @param boolean $add Whether to add classes or not. * @param string $queue The queue we want to get 'admin', 'display', 'all'. * * @return boolean Whether to add classes or not. */ public function body_classes_should_add( $add, $queue ) { $context = tribe_context(); if ( $context->get( 'event_post_type', false ) || $context->get( 'shortcode', false ) ) { return true; } return $add; } /** * Filter the plural events label for Featured V2 Views. * * @since 5.1.5 * * @param string $label The plural events label as it's been generated thus far. * @param Context $context The context used to build the title, it could be the global one, or one externally * set. * * @return string the original label or updated label for virtual archives. */ public function filter_wp_title_plural_events_label( $label, Context $context ) { return $this->container->make( Featured_Title::class )->filter_views_v2_wp_title_plural_events_label( $label, $context ); } /** * Filters the `wp_title` template tag. * * @since 4.9.10 * * @param string $title The current title value. * @param string|null $sep The separator char, or sequence, to use to separate the page title from the blog one. * * @return string The modified page title, if required. */ public function filter_wp_title( $title, $sep = null ) { $bootstrap = $this->container->make( Template_Bootstrap::class ); if ( ! $bootstrap->should_load() || $bootstrap->is_single_event() ) { return $title; } return $this->container->make( Title::class )->filter_wp_title( $title, $sep ); } /** * Filters the `pre_get_document_title` to prevent conflicts when other plugins * modify this initial value on our pages. * * @since 5.0.0 * * @param string $title The current title value. * * @return string The current title or empty string. */ public function pre_get_document_title( $title ) { $bootstrap = $this->container->make( Template_Bootstrap::class ); if ( ! $bootstrap->should_load() || $bootstrap->is_single_event() ) { return $title; } return ''; } /** * Filters the `wp_get_document_title` template tag. * * This is the template tag introduced in WP 4.4 to get the page title. * * @since 4.9.10 * * @param string $title The page title. * * @return string The modified page title, if required. */ public function filter_document_title_parts( $title ) { $bootstrap = $this->container->make( Template_Bootstrap::class ); if ( ! $bootstrap->should_load() || $bootstrap->is_single_event() ) { return $title; } return $this->container->make( Title::class )->filter_document_title_parts( $title ); } /** * Filters the `excerpt_length`. * * @since 4.9.10 * * @param int $length The excerpt length. * * @return int The modified excerpt length, if required. */ public function filter_excerpt_length( $length ) { return $this->container->make( Template\Excerpt::class )->maybe_filter_excerpt_length( $length ); } /** * Filters the `excerpt_more`. * * @since 4.9.10 * * @param string $link The excerpt read more link. * * @return string The modified excerpt read more link, if required. */ public function filter_excerpt_more( $link ) { return $this->container->make( Template\Excerpt::class )->maybe_filter_excerpt_more( $link ); } /** * Filters the `admin_post_thumbnail_html` to add image aspect ratio recommendation. * * @since 4.9.11 * * @param string $html The HTML for the featured image box. * * @return string The modified html, if required. */ public function filter_admin_post_thumbnail_html( $html ) { $screen = get_current_screen(); if ( ! $screen instanceof \WP_Screen ) { return $html; } if ( TEC::POSTTYPE !== $screen->post_type ) { return $html; } return $html . '

' . __( 'We recommend a 16:9 aspect ratio for featured images.', 'the-events-calendar' ) . '

'; } /** * Filters the `redirect_canonical` to prevent any redirects on embed URLs. * * @since 4.9.13 * * @param mixed $redirect_url URL which we will redirect to. * @param string|int $original_url The original URL if this method runs on the `redirect_canonical` filter, else * the redirect status (e.g. `301`) if this method runs in the context of the * `wp_redirect` filter. * * @return string A redirection URL, or `false` to prevent redirection. */ public function filter_redirect_canonical( $redirect_url = null, $original_url = null ) { if ( doing_filter( 'redirect_canonical' ) ) { /* * If we're not running in the context of the `redirect_canonical` filter, skip this check * as it would happen between a string (`$redirect_url`) and an integer (the redirect HTTP * status code). */ if ( trailingslashit( $original_url ) === trailingslashit( $redirect_url ) ) { return $redirect_url; } } $context = tribe_context(); // Bail with the original redirect if we are not dealing with a CPT from TEC. if ( ! $context->is( 'tec_post_type' ) ) { return $redirect_url; } $view = $context->get( 'view_request', null ); if ( 'embed' === $view ) { // Do not redirect embedded Views. return false; } if ( empty( $view ) || 'single-event' === $view ) { // Let the redirection go on. return $redirect_url; } $parsed = \Tribe__Events__Rewrite::instance()->parse_request( $redirect_url ); // Event Tickets will set this to flag a redirected request. $is_redirected = ! empty( $parsed['tribe_redirected'] ); /** * Filters whether the current request is being redirected or not. * * The initial value is set by looking up the `tribe_redirected` query argument. * * @since 6.0.9 * * @param bool $is_redirected Whether the current request is being redirected by TEC or not. */ $is_redirected = apply_filters( 'tec_events_views_v2_redirected', $is_redirected ); if ( ! $is_redirected && $view !== Arr::get( (array) $parsed, 'eventDisplay' ) ) { /* * If we're here we know we should be looking at a View URL. * If the proposed URL does not resolve to a View, do not redirect. */ return false; } return $redirect_url; } /** * Modifies the Live update tooltip properly. * * @since 4.9.13 * * @param array $fields Fields that were passed for the Settings tab. * * @return array Fields after changing the tooltip. */ public function filter_general_settings_tab_live_update( $fields ) { if ( empty( $fields['liveFiltersUpdate'] ) ) { return $fields; } $fields['liveFiltersUpdate']['tooltip'] .= '
' . esc_html__( 'Recommended for all sites using the updated calendar views.', 'the-events-calendar' ); return $fields; } /** * Registers The Events Calendar with the views/overrides update checker. * * @since 4.9.13 * * @param array $plugins List of plugins to be checked. * * @return array */ public function filter_register_template_updates( array $plugins = [] ) { $plugins[ __( 'The Events Calendar - View V2', 'the-events-calendar' ) ] = [ TEC::VERSION, TEC::instance()->pluginPath . 'src/views/v2', trailingslashit( get_stylesheet_directory() ) . 'tribe/events', ]; return $plugins; } /** * Suppress v1 query filters on a per-query basis, if required. * * @since 4.9.11 * * @param \WP_Query $query The current WordPress query object. */ public function parse_query( $query ) { if ( ! $query instanceof \WP_Query ) { return; } $event_query = $this->container->make( Event_Query_Controller::class ); $event_query->parse_query( $query ); } /** * Adds the period repository to the map of available repositories. * * @since 4.9.13 * * @param array $repository_map The current repository map. * * @return array The filtered repository map. */ public function add_period_repository( array $repository_map, $repository, array $args = [] ) { if ( 'period' === $repository ) { // This is a new instance on each run, by design. Making this a singleton would create dangerous dependencies. $event_period_repository = $this->container->make( Event_Period::class ); $event_period_repository->cache_results = in_array( 'caching', $args, true ); $repository_map['period'] = $event_period_repository; } return $repository_map; } /** * Flush rewrite rules after the site language setting changes. * * @since 4.9.13 * * @param string $option The option name that was updated. * @param string $old The option old value. * @param string $new The option updated value. */ public function action_save_wplang( $option, $old, $new ) { if ( 'WPLANG' !== $option ) { return; } // Deleting `rewrite_rules` given that this is being executed after `init` // And `flush_rewrite_rules()` doesn't take effect. delete_option( 'rewrite_rules' ); } /** * Filters rewrite rules to modify and update them for Views V2. * * @since 5.0.0 * * @param array $bases An array of rewrite bases that have been generated. * @param string $method The method that's being used to generate the bases; defaults to `regex`. * * @return array An array of rewrite rules. Modified, if required, to support Views V2. */ public function filter_rewrite_i18n_slugs_raw( $bases, $method ) { if ( ! is_array( $bases ) ) { return $bases; } return $this->container->make( Rewrite::class )->filter_raw_i18n_slugs( $bases, $method ); } /** * Fires to manage sensitive information on password protected posts. * * @since 5.0.0 * * @param \WP_Post|int $post The event post ID or object currently being decorated. */ public function manage_sensitive_info( $post ) { if ( $this->container->make( Template_Bootstrap::class )->is_single_event() ) { $this->container->make( Template\Event::class )->manage_sensitive_info( $post ); } } /** * Include the promo banner after the after component. * * @since 5.1.5 * * @param string $file Complete path to include the PHP File. * @param array $name Template name. * @param Template $template Current instance of the Template. * * @return void Template render has no return. */ public function action_add_promo_banner( $file, $name, $template ) { $this->container->make( Template\Promo::class )->action_add_promo_banner( $file, $name, $template ); } /** * Updates and modifies the properties added to the event post object by the `tribe_get_event` function to * hide some sensitive information, if required. * * @since 5.0.0 * * @param \WP_Post $event The event post object, decorated w/ properties added by the `tribe_get_event` function. * * @return \WP_Post The event post object, decorated w/ properties added by the `tribe_get_event` function, some of * them updated to hide sensitive information, if required. */ public function filter_events_properties( $event ) { if ( ! $event instanceof \WP_Post ) { return $event; } return $this->container->make( Template\Event::class )->filter_event_properties( $event ); } /** * Filter the template file in case we're in single event * and we need to use the theme overrides. * * @see tribe_template_file * * @since 5.0.0 * * @param string $file Complete path to include the PHP File * @param array $name Template name * @param object $template Instance of the Tribe__Template * * @return string */ public function filter_template_file( $file, $name, $template ) { return $this->container->make( Template_Bootstrap::class )->filter_template_file( $file, $name, $template ); } /** * Filter the stylesheet option to do some switching for V2 * * @since 5.0.2 * * @param string $value The option value. * @param string $key The option key. * * @return string Which value we are converting to. */ public function filter_get_stylesheet_option( $value, $key ) { // Bail early if possible. No need to do the shuffle below if if ( 'stylesheetOption' !== $key && ( 'stylesheet_mode' !== $key ) ) { return $value; } // Remove this filter so we don't loop infinitely. remove_filter( 'tribe_get_option', [ $this, 'filter_get_stylesheet_option' ], 10 ); $default = 'tribe'; if ( 'stylesheetOption' === $key ) { $value = tribe_get_option( 'stylesheet_mode', $default ); } else if ( 'stylesheet_mode' === $key && empty( $value ) ) { $value = tribe_get_option( 'stylesheetOption', $default ); if ( 'full' === $value ) { $value = $default; } } // Add the filter back add_filter( 'tribe_get_option', [ $this, 'filter_get_stylesheet_option' ], 10, 2 ); return $value; } /** * Filter the liveFiltersUpdate option to do some switching for V2. * Note: this triggers on option_liveFiltersUpdate, tribe_get_option, AND tribe_field_value. We * don't have to add/remove filters because we don't need to get the value - it's already provided. * * @since 5.0.3 * * @param string $value The option value. * @param string $key The option key. * * @return string Converted value of the Live Filters string. */ public function filter_live_filters_option_value( $value, $key ) { if ( 'liveFiltersUpdate' !== $key ) { return $value; } return $this->live_filters_maybe_convert( $value ); } /** * Converts old (boolean) values to the new string values. * * @since 5.0.3 * * @param mixed $value The value to maybe convert. * * @return string Modified value of Live filters Update. */ public function live_filters_maybe_convert( $value ) { $return_value = 'automatic'; if ( empty( $value ) || 'manual' === $value ) { $return_value = 'manual'; } /** * Allow filtering of the new value for Live Filters. * * @since 5.0.3 * * @param string $return_value Which value we are going to return as the conversion. * @param string $value Which value was previously used. */ $return_value = apply_filters( 'tribe_events_option_convert_live_filters', $return_value, $value ); return $return_value; } /** * Ensures that date formats are escaped properly. * Converts "\\" to "\" for escaped characters. * * @since 5.16.4 * * @param mixed $value The current value of the option. * @param string $optionName The option "key" * * @return mixed $value The modified value of the option. */ public function filter_date_escaping( $value, $optionName ) { // A list of date options we may need to unescape. $date_options = [ 'dateWithoutYearFormat', 'monthAndYearFormat', ]; if ( ! in_array( $optionName, $date_options ) ) { return $value; } // Don't try to run string modification on an array or something. if ( ! is_string( $value ) ) { return $value; } // Note: backslash is the escape character - so we need to escape it. // This is the equivalent of replacing any occurrence of \\ with \ $value = str_replace( "\\\\", "\\", $value); //$value = stripslashes( $value ); will strip out ones we want to keep! return $value; } /** * Print Single Event JSON-LD. * * @since 5.0.3 */ public function print_single_json_ld() { $this->container->make( Template\JSON_LD::class )->print_single_json_ld(); } /** * Changes the action the Customizer should use to try and print inline styles to print the inline * styles in the footer. * * @since 5.3.1 * * @return string The action the Customizer should use to print inline styles. */ public function print_inline_styles_in_footer() { return 'wp_print_footer_scripts'; } /** * Filter the website link label and change it for Single Event Classic Editor. * Use the following in functions.php to disable: * remove_filter( 'tribe_get_venue_website_link_label', [ tribe( 'events.views.v2.hooks' ), 'filter_single_event_details_website_label' ] ); * * @since 5.5.0 * * @param string $label The filtered label. * @param null|string|int $post_id The current post ID. * * @return string */ public function filter_single_event_details_event_website_label( $label, $post_id = null ) { // If not V2 or not Classic Editor, return the website url. if ( $this->is_v1_or_blocks( $post_id ) ) { return $label; } if ( 'Website' !== $label ) { return $label; } return sprintf( _x( 'View %s Website', 'Capitalized label for the event website link.', 'the-events-calendar' ), tribe_get_event_label_singular() ); } /** * Filter the website link label and change it for Single Event Classic Editor. * Use the following in functions.php to disable: * remove_filter( 'tribe_get_venue_website_link_label', [ tribe( 'events.views.v2.hooks' ), 'filter_single_event_details_venue_website_label' ] ); * * @since 5.5.0 * * @param string $label The filtered label. * @param null|string|int $post_id The current post ID. * * @return string */ public function filter_single_event_details_venue_website_label( $label, $post_id = null ) { // If not V2 or not Classic Editor, return the website url. if ( $this->is_v1_or_blocks( $post_id ) ) { return $label; } return sprintf( _x( 'View %s Website', 'Capitalized label for the venue website link.', 'the-events-calendar' ), tribe_get_venue_label_singular() ); } /** * Filter the website link label and change it for Single Event Classic Editor. * Use the following in functions.php to disable: * remove_filter( 'tribe_get_organizer_website_link_label', [ tribe( 'events.views.v2.hooks' ), 'filter_single_event_details_organizer_website_label' ] ); * * @since 5.5.0 * * @param string $label The filtered label. * @param null|string|int $post_id The current post ID. * * @return string */ public function filter_single_event_details_organizer_website_label( $label, $post_id = null ) { // If not V2 or not Classic Editor, return the website url. if ( $this->is_v1_or_blocks( $post_id ) ) { return $label; } return sprintf( _x( 'View %s Website', 'Capitalized label for the organizer website link.', 'the-events-calendar' ), tribe_get_organizer_label_singular() ); } public function filter_tec_events_query_default_view( $default_view ) { return tribe( Manager::class )->get_default_view(); } /** * Sugar function for the above that determines if the labels should be filtered. * * @since 4.6.0 * * @param null|string|int $post_id The current post ID. * * @return boolean */ public function is_v1_or_blocks( $post_id = null ) { return is_null( $post_id ) || ! tribe_events_single_view_v2_is_enabled() || tribe( 'editor' )->should_load_blocks() && has_blocks( $post_id ); } /** * Overrides the default iCalendar export link logic to inject a list of event * post IDs fitting the Views V2 criteria. * * @since 4.6.0 * * @param array|false $event_ids Either a list of event post IDs that has been * explicitly requested or `false` to indicate the * iCalendar export link did not indicate a specific * set of event post IDs. * * @return array Either the original input value if a specific set of event post IDs * was requested as part of the iCalendar export link, or a filtered * set of event post IDs compiled depending on the current View context * and request arguments. */ public function inject_ical_event_ids( $event_ids = null ) { if ( false !== $event_ids ) { // The request already specifies a set of Event post IDs to return, bail. return $event_ids; } return $this->container->make( iCalendar\Request::class )->get_event_ids(); } /** * Filters the Today button label to change the text to something appropriate for Week View. * * @since 6.0.2 * * @param string $today The string used for the "Today" button on calendar views. * @param \Tribe\Events\Views\V2\View_Interface $view The View currently rendering. * * @return string $today */ public function filter_view_month_today_button_label( $today, $view ) { $today = esc_html_x( 'This Month', 'The default text label for the "today" button on the Month View.', 'the-events-calendar' ); return $today; } /** * Filters the Today button title and aria-label to change the text to something appropriate for Month View. * * @since 6.0.2 * * @param string $label The title string. * @param \Tribe\Events\Views\V2\View_Interface $view The View currently rendering. * * @return string $label */ public function filter_view_month_today_button_title( $label, $view ) { $label = esc_html_x( 'Click to select the current month', "The default text for the 'today' button's title and aria-label on the Week View.", 'the-events-calendar' ); return $label; } /** * Allow specific views to hook in and add their own calculated events. * * @since 6.2.3 * @since 6.2.3.1 Added a check for function existence. * * @param Tribe__Repository|false $events The events repository. False by default. * @param DateTime $start_date The start date (object) of the query. * @param \Tribe__Context $context The current context. * @param View_Interface $instance The current view instance. * * @return \Tribe__Repository|false $events The events repository results. */ public function filter_tec_events_noindex( $events, $start_date, $end_date, $context, $view ) { //$view_slug = $context->get( 'view' ); //$view = View::make( tribe( Manager::class )->get_view_class_by_slug( $view_slug ), $context ); // If ECP has not been updated, the function won't exist for ECP views. Bail. if ( ! method_exists( $view, 'get_noindex_events' ) ) { return $events; } return $view->get_noindex_events( $events, $start_date, $end_date, $context ); } /* DEPRECATED */ /** * Adds new Global Elements settings via the hook in common. * * @since 5.3.1 * @deprecated 5.9.0 * * @param \Tribe__Customizer__Section $section The Global Elements Customizer section. * @param WP_Customize_Manager $manager The settings manager. * @param \Tribe__Customizer $customizer The Customizer object. */ public function action_include_global_elements_settings( $section, $manager, $customizer ) { _deprecated_function( __METHOD__, '5.9.0' ); tribe( 'customizer' )->include_global_elements_settings( $section, $manager, $customizer ); } /** * Adds new Single Event settings via the hook in common. * * @since 5.3.1 * @deprecated 5.9.0 * * @param \Tribe__Customizer__Section $section The Single Event Customizer section. * @param WP_Customize_Manager $manager The settings manager. * @param \Tribe__Customizer $customizer The Customizer object. */ public function action_include_single_event_settings( $section, $manager, $customizer ) { _deprecated_function( __METHOD__, '5.9.0' ); tribe( 'customizer' )->include_single_event_settings( $section, $manager, $customizer ); } /** * Filters the Global Elements section CSS template to add Views v2 related style templates to it. * * @since 5.3.1 * @deprecated 5.9.0 * * @param string $css_template The CSS template, as produced by the Global Elements. * @param \Tribe__Customizer__Section $section The Global Elements section. * @param \Tribe__Customizer $customizer The current Customizer instance. * * @return string The filtered CSS template. */ public function filter_global_elements_css_template( $css_template, $section ) { _deprecated_function( __METHOD__, '5.9.0' ); if ( ! ( is_string( $css_template ) && $section instanceof Customizer_Section ) ) { return $css_template; } return tribe( 'customizer' )->filter_global_elements_css_template( $css_template, $section ); } /** * Filters the Single Event section CSS template to add Views v2 related style templates to it. * * @since 5.3.1 * @deprecated 5.9.0 * * @param string $css_template The CSS template, as produced by the Global Elements. * @param \Tribe__Customizer__Section $section The Single Event section. * @param \Tribe__Customizer $customizer The current Customizer instance. * * @return string The filtered CSS template. */ public function filter_single_event_css_template( $css_template, $section ) { _deprecated_function( __METHOD__, '5.9.0' ); if ( ! ( is_string( $css_template ) && $section instanceof Customizer_Section ) ) { return $css_template; } return tribe( 'customizer' )->filter_single_event_css_template( $css_template, $section ); } /** * Add the views v2 status in a more prominent way in the Troubleshooting page system info panel. * * @since 5.12.4 * * @param array $info Existing information that will be displayed. * * @return array */ public function filter_system_information( array $info = [] ) { $views_v2_status = [ 'Views V2 Status' => tribe_events_views_v2_is_enabled() ? esc_html__( 'Enabled', 'the-events-calendar' ) : esc_html__( 'Disabled', 'the-events-calendar' ), ]; return \Tribe__Main::array_insert_before_key( 'Settings', $info, $views_v2_status ); } /** * Ensure we use the correct date on shortcodes. * If both `tribe-bar-date` and `eventDate` are present, `tribe-bar-date` overrides `eventDate`. * * @since 5.16.4 * * @param array $params An associative array of parameters from the REST request. * @param \WP_REST_Request $request The current REST request. * * @return array $params A modified array of parameters from the REST request. */ public function filter_url_date_conflicts( $params, $request ) { if ( ! isset( $params['tribe-bar-date'] ) || ! isset( $params[ 'eventDate'] ) ) { return $params; } $params[ 'eventDate'] = $params['tribe-bar-date']; return $params; } /** * Unregisters all the filters and action handled by the class. * * @since 6.0.2 * * @return void Filters and actions will be unregistered. */ public function unregister(): void { remove_filter( 'tec_system_information', [ $this, 'filter_system_information' ] ); remove_filter( 'wp_redirect', [ $this, 'filter_redirect_canonical' ] ); remove_filter( 'redirect_canonical', [ $this, 'filter_redirect_canonical' ] ); remove_filter( 'template_include', [ $this, 'filter_template_include' ], 50 ); remove_filter( 'embed_template', [ $this, 'filter_template_include' ], 50 ); remove_filter( 'posts_pre_query', [ $this, 'filter_posts_pre_query' ], 20 ); remove_filter( 'body_class', [ $this, 'filter_body_classes' ] ); remove_filter( 'tribe_body_class_should_add_to_queue', [ $this, 'body_class_should_add_to_queue' ] ); remove_filter( 'tribe_body_classes_should_add', [ $this, 'body_classes_should_add' ] ); remove_filter( 'query_vars', [ $this, 'filter_query_vars' ], 15 ); remove_filter( 'tribe_rewrite_canonical_query_args', [ $this, 'filter_map_canonical_query_args' ], 15 ); remove_filter( 'admin_post_thumbnail_html', [ $this, 'filter_admin_post_thumbnail_html' ] ); remove_filter( 'excerpt_length', [ $this, 'filter_excerpt_length' ] ); remove_filter( 'tribe_events_views_v2_after_make_view', [ $this, 'action_include_filters_excerpt' ] ); remove_filter( 'rest_authentication_errors', [ Rest_Endpoint::class, 'did_rest_authentication_errors' ], 150 ); remove_filter( 'tribe_support_registered_template_systems', [ $this, 'filter_register_template_updates' ] ); remove_filter( 'tribe_events_event_repository_map', [ $this, 'add_period_repository' ] ); remove_filter( 'tribe_general_settings_tab_fields', [ $this, 'filter_general_settings_tab_live_update' ], 20 ); remove_filter( 'tribe_events_rewrite_i18n_slugs_raw', [ $this, 'filter_rewrite_i18n_slugs_raw' ], 50 ); remove_filter( 'tribe_get_event_after', [ $this, 'filter_events_properties' ] ); remove_filter( 'tribe_template_file', [ $this, 'filter_template_file' ] ); remove_filter( 'tribe_get_option', [ $this, 'filter_get_stylesheet_option' ] ); remove_filter( 'option_liveFiltersUpdate', [ $this, 'filter_live_filters_option_value' ] ); remove_filter( 'tribe_get_option', [ $this, 'filter_live_filters_option_value' ] ); remove_filter( 'tribe_field_value', [ $this, 'filter_live_filters_option_value' ] ); remove_filter( 'tribe_get_option', [ $this, 'filter_date_escaping' ] ); remove_filter( 'tribe_events_filter_views_v2_wp_title_plural_events_label', [ $this, 'filter_wp_title_plural_events_label' ] ); remove_filter( 'wp_title', [ $this, 'filter_wp_title' ] ); remove_filter( 'document_title_parts', [ $this, 'filter_document_title_parts' ] ); remove_filter( 'pre_get_document_title', [ $this, 'pre_get_document_title' ], 20 ); remove_filter( 'get_post_time', [ 'Tribe__Events__Templates', 'event_date_to_pubDate' ] ); remove_filter( 'tribe_events_views_v2_view_data', [ View_Utils::class, 'clean_data' ] ); remove_filter( 'tribe_customizer_print_styles_action', [ $this, 'print_inline_styles_in_footer' ] ); remove_filter( 'tribe_customizer_global_elements_css_template', [ $this, 'filter_global_elements_css_template' ] ); remove_filter( 'tribe_customizer_single_event_css_template', [ $this, 'filter_single_event_css_template' ] ); remove_filter( 'tribe_get_event_website_link_label', [ $this, 'filter_single_event_details_event_website_label' ] ); remove_filter( 'tribe_get_venue_website_link_label', [ $this, 'filter_single_event_details_venue_website_label' ] ); remove_filter( 'tribe_events_get_venue_website_title', '__return_empty_string' ); remove_filter( 'tribe_get_organizer_website_link_label', [ $this, 'filter_single_event_details_organizer_website_label' ] ); remove_filter( 'tribe_events_get_organizer_website_title', '__return_empty_string' ); remove_filter( 'tribe_ical_template_event_ids', [ $this, 'inject_ical_event_ids' ] ); remove_filter( 'tec_events_query_default_view', [ $this, 'filter_tec_events_query_default_view' ] ); remove_filter( 'tribe_events_views_v2_rest_params', [ $this, 'filter_url_date_conflicts' ], 12 ); remove_action( 'rest_api_init', [ $this, 'register_rest_endpoints' ] ); remove_action( 'tribe_common_loaded', [ $this, 'on_tribe_common_loaded' ], 1 ); remove_action( 'parse_query', [ $this, 'add_body_classes' ], 55 ); remove_action( 'wp_head', [ $this, 'on_wp_head' ], 1000 ); remove_action( 'tribe_events_pre_rewrite', [ $this, 'on_tribe_events_pre_rewrite' ] ); remove_action( 'wp_enqueue_scripts', [ $this, 'action_disable_assets_v1' ], 0 ); remove_action( 'tribe_events_pro_shortcode_tribe_events_after_assets', [ $this, 'action_disable_shortcode_assets_v1' ] ); remove_action( 'updated_option', [ $this, 'action_save_wplang' ], 10, 3 ); remove_action( 'the_post', [ $this, 'manage_sensitive_info' ] ); remove_action( 'get_header', [ $this, 'print_single_json_ld' ] ); remove_action( 'tribe_template_after_include:events/v2/components/after', [ $this, 'action_add_promo_banner' ], 10, 3 ); remove_action( 'tribe_events_parse_query', [ $this, 'parse_query' ] ); remove_action( 'template_redirect', [ $this, 'action_initialize_legacy_views' ] ); remove_action( 'admin_enqueue_scripts', [ $this, 'enqueue_customizer_in_block_editor' ] ); remove_action( 'tec_events_views_v2_after_get_events', [ $this, 'action_set_title_events' ] ); } }