Current File : /home/kelaby89/teamhachem.com/wp-content/plugins/the-events-calendar/common/src/Tribe/Editor.php
<?php

/**
 * Initialize Gutenberg editor blocks.
 *
 * @since 4.8
 */
class Tribe__Editor {

	/**
	 * Key we store the toggle under in the tribe_events_calendar_options array.
	 *
	 * @since 4.14.13
	 *
	 * @var string
	 */
	public static $blocks_editor_key = 'toggle_blocks_editor';

	/**
	 * Meta key for flagging if a post is from Classic Editor.
	 *
	 * @since 4.8
	 *
	 * @var string
	 */
	public $key_flag_classic_editor = '_tribe_is_classic_editor';

	/**
	 * Utility function to check if we should load the blocks or not.
	 *
	 * @since 4.8
	 *
	 * @return bool
	 */
	public function should_load_blocks() {
		$should_load_blocks = (boolean) $this->are_blocks_enabled();

		/**
		 * Filters whether the Blocks Editor should be activated or not for events.
		 *
		 * @since 4.12.0
		 *
		 * @param bool $should_load_blocks Whether the blocks editor should be activated or not for events.
		 */
		$should_load_blocks= (bool) apply_filters( 'tribe_editor_should_load_blocks', $should_load_blocks );

		return $should_load_blocks;
	}

	/**
	 * Utility function to check if blocks are enabled based on two assumptions
	 *
	 * a) Is gutenberg active?
	 *     1) Via plugin or WP version
	 * b) Is the blocks editor active?
	 *      1) Based on the enqueue_block_assets action.
	 *
	 * @since 4.14.13
	 *
	 * @return bool
	 */
	public function are_blocks_enabled() {
		$gutenberg      = $this->is_gutenberg_active() || $this->is_wp_version();
		$blocks_enabled = $gutenberg && $this->is_blocks_editor_active();

		/**
		 * Filters whether the Blocks Editor is enabled or not.
		 *
		 * @since 4.14.13
		 *
		 * @param bool $should_load_blocks Whether the Blocks Editor is enabled or not.
		 */
		return (bool) apply_filters( 'tribe_editor_are_blocks_enabled', $blocks_enabled );
	}

	/**
	 * Checks if we are on version 5.0-alpha or higher where we no longer have
	 * Gutenberg Project, but the Blocks Editor
	 *
	 * @since 4.8
	 *
	 * @return boolean
	 */
	public function is_wp_version() {
		global $wp_version;

		return version_compare( $wp_version, '5.0-alpha', '>=' );
	}

	/**
	 * Checks if we have the Gutenberg Project plugin active.
	 *
	 * @since 4.8
	 *
	 * @return boolean
	 */
	private function is_gutenberg_active() {
		return function_exists( 'gutenberg_register_scripts_and_styles' );
	}

	/**
	 * Checks if we have Editor Block active.
	 *
	 * @since 4.8
	 * @since 4.14.13 Switch to using the `enqueue_block_assets` check that the Classic Editor plugin uses
	 *
	 * @return boolean
	 */
	public function is_blocks_editor_active() {
		return has_action( 'enqueue_block_assets' );
	}

	/**
	 * Adds the required fields into the Post Type so that we can the Rest API to update it
	 *
	 * @since 4.8
	 *
	 * @param array $args Arguments used to setup the Post Type.
	 *
	 * @return array The modified arguments.
	 */
	public function add_rest_support( $args = [] ) {
		// Blocks Editor requires REST support.
		$args['show_in_rest'] = true;

		// Make sure we have the Support argument and it's an array.
		if ( ! isset( $args['supports'] ) || ! is_array( $args['supports'] ) ) {
			$args['supports'] = [];
		}

		if ( ! in_array( 'revisions', $args['supports'] ) ) {
			$args['supports'][] = 'revisions';
		}

		// Add Custom Fields (meta) Support.
		if ( ! in_array( 'custom-fields', $args['supports'] ) ) {
			$args['supports'][] = 'custom-fields';
		}

		// Add Post Title Support.
		if ( ! in_array( 'title', $args['supports'] ) ) {
			$args['supports'][] = 'title';
		}

		// Add Post Excerpt Support.
		if ( ! in_array( 'excerpt', $args['supports'] ) ) {
			$args['supports'][] = 'excerpt';
		}

		// Add Post Content Support.
		if ( ! in_array( 'editor', $args['supports'] ) ) {
			$args['supports'][] = 'editor';
		}

		// Add Post Author Support.
		if ( ! in_array( 'author', $args['supports'] ) ) {
			$args['supports'][] = 'author';
		}

		// Add Thumbnail Support.
		if ( ! in_array( 'thumbnail', $args['supports'] ) ) {
			$args['supports'][] = 'thumbnail';
		}

		return $args;
	}

	/**
	 * Detect if the Classic Editor is force-activated via plugin or if it comes from a request.
	 *
	 * @since 4.8
	 * @todo Deprecate before 6.0.
	 *
	 * @return bool Whether the Classic Editor is active.
	 */
	public function is_classic_editor() {
		// _deprecated_function( __FUNCTION__, '4.14.13', 'should_load_blocks' );

		return ! $this->should_load_blocks();
	}

	/* DEPRECATED FUNCTIONS. */

	/**
	 * Adds the required fields into the Events Post Type so that we can use Block Editor.
	 *
	 * @since 4.8
	 *
	 * @deprecated 4.14.13 This is not used anywhere.
	 *
	 * @param array $args Arguments used to setup the Post Type.
	 *
	 * @return array The modified arguments.
	 */
	public function add_support( $args = [] ) {
		_deprecated_function( __FUNCTION__, '4.14.13' );
		// Make sure we have the Support argument and it's an array.
		if ( ! isset( $args['supports'] ) || ! is_array( $args['supports'] ) ) {
			$args['supports'] = [];
		}

		// Add Editor Support.
		if ( ! in_array( 'editor', $args['supports'] ) ) {
			$args['supports'][] = 'editor';
		}

		return $args;
	}

	/**
	 * classic_editor_replace is function that is created by the plugin:
	 * used in ECP recurrence and TEC Meta.
	 *
	 * @see https://wordpress.org/plugins/classic-editor/
	 *
	 * prior 1.3 version the Classic Editor plugin was bundled inside of a unique function:
	 * `classic_editor_replace` now all is bundled inside of a class `Classic_Editor`
	 *
	 * @since 4.8
	 *
	 * @deprecated 4.14.13
	 *
	 * @return bool Whether the Classic Editor plugin is active.
	 */
	public function is_classic_plugin_active() {
		_deprecated_function( __FUNCTION__, '4.14.13', 'Tribe\Editor\Compatibility\Classic_Editor::is_classic_plugin_active' );

		return Tribe\Editor\Compatibility\Classic_Editor::is_classic_plugin_active();
	}

	/**
	 * Check if the setting `classic-editor-replace` is set to `replace` that option means to
	 * replace the gutenberg editor with the Classic Editor.
	 *
	 * Prior to 1.3 on Classic Editor plugin the value to identify if is on classic the value
	 * was `replace`, now the value is `classic`
	 *
	 * @since 4.8
	 *
	 * @deprecated 4.14.13
	 *
	 * @return bool Whether the Classic Editor option is active.
	 */
	public function is_classic_option_active() {
		_deprecated_function( __FUNCTION__, '4.14.13', 'Tribe\Editor\Compatibility\Classic_Editor::is_classic_option_active' );

		return Tribe\Editor\Compatibility\Classic_Editor::is_classic_option_active();
	}

	/**
	 * Whether the TEC setting dictates Blocks or the Classic Editor.
	 * used in ET, ET+ and TEC.
	 *
	 * @since 4.12.0
	 * @todo Deprecate before 6.0.
	 *
	 * @return bool Whether the event is being served through blocks or the Classic Editor.
	 */
	public function is_events_using_blocks() {
		_deprecated_function( __FUNCTION__, '4.14.13', 'should_load_blocks');


		return $this->should_load_blocks();
	}
}
Page not found – Hello World !