File "Widgets_Manager.php"

Full Path: /home/romayxjt/public_html/wp-content/plugins/the-events-calendar/src/Events/Integrations/Plugins/Elementor/Widgets_Manager.php
File size: 3.36 KB
MIME-type: text/x-php
Charset: utf-8

<?php
/**
 * Handles Registering Elementor widgets.
 *
 * @since 6.4.0
 *
 * @package TEC\Events\Integrations\Plugins\Elementor
 */

namespace TEC\Events\Integrations\Plugins\Elementor;

use Elementor\Plugin as Elementor_Plugin;
use TEC\Common\Contracts\Provider\Controller;

/**
 * Class Widget_Manager
 *
 * @since 6.4.0
 *
 * @package TEC\Events\Integrations\Plugins\Elementor
 */
class Widgets_Manager extends Controller {
	/**
	 * A list of widget classes to register.
	 *
	 * @since 6.4.0
	 *
	 * @var array
	 */
	protected array $widget_classes = [
		Widgets\Event_Calendar_Link::class,
		Widgets\Event_Categories::class,
		Widgets\Event_Cost::class,
		Widgets\Event_Datetime::class,
		Widgets\Event_Export::class,
		Widgets\Event_Image::class,
		Widgets\Event_Navigation::class,
		Widgets\Event_Organizer::class,
		Widgets\Event_Status::class,
		Widgets\Event_Tags::class,
		Widgets\Event_Title::class,
		Widgets\Event_Venue::class,
		Widgets\Event_Website::class,
	];

	/**
	 * Registers the filters and actions hooks added by the controller.
	 *
	 * @since 6.4.0
	 */
	public function do_register(): void {
		if ( ! class_exists( 'Elementor\Widget_Base', false ) ) {
			return;
		}

		foreach ( $this->get_widgets() as $widget_class ) {
			$this->container->bind( $widget_class, $widget_class );
		}

		$this->register_with_elementor();

		/**
		 * Fires after the TEC Elementor widgets have been registered.
		 *
		 * @since 6.4.1
		 */
		do_action( 'tec_events_elementor_widgets_registered' );
	}

	/**
	 * Removes the filters and actions hooks added by the controller.
	 *
	 * Bound implementations should not be removed in this method!
	 *
	 * @since 6.4.0
	 *
	 * @return void Filters and actions hooks added by the controller are be removed.
	 */
	public function unregister(): void {}

	/**
	 * Gets a filtered list of the widgets to be registered with Elementor.
	 *
	 * @since 6.4.0
	 *
	 * @return array
	 */
	public function get_widget_classes(): array {
		$classes = $this->widget_classes;

		/**
		 * Allows filtering the widget classes to be registered with Elementor.
		 *
		 * @since 6.4.0
		 *
		 * @param array $classes The widget classes to be registered with Elementor.
		 *
		 * @return array
		 */
		return apply_filters( 'tec_events_elementor_widget_classes', $classes );
	}

	/**
	 * Returns the widgets to be registered with Elementor.
	 *
	 * @since 6.4.0
	 *
	 * @return array
	 */
	public function get_widgets(): array {
		/**
		 * Allows filtering the widgets to be registered with Elementor.
		 *
		 * @since 6.4.0
		 *
		 * @param array $widgets The widgets to be registered with Elementor.
		 */
		$widgets = $this->get_widget_classes();

		// Ensure that all filtered widgets are instances of Widget_Abstract.
		foreach ( $widgets as $widget ) {
			$widget_instance = new $widget();

			// Remove the widget if it is not an instance of Widget_Abstract.
			if ( ! $widget_instance instanceof Widgets\Contracts\Abstract_Widget ) {
				unset( $widgets[ get_class( $widget_instance ) ] );
			}

			unset( $widget_instance );
		}

		return $widgets;
	}

	/**
	 * Registers the widgets with Elementor.
	 *
	 * @since 6.4.0
	 */
	public function register_with_elementor(): void {
		$widgets = $this->get_widgets();

		foreach ( $widgets as $widget ) {
			$widget_instance = new $widget();
			Elementor_Plugin::instance()->widgets_manager->register( tribe( get_class( $widget_instance ) ) );
		}
	}
}