Tribe__Image__Plus__Main


Source #

File: src/Tribe/Main.php

class Tribe__Image__Plus__Main {
	const VERSION = '1.0.3';

	/**
	 * Static Singleton Holder
	 * @var self
	 */
	protected static $instance;

	/**
	 * Path of the plugin.
	 */
	public $plugin_path;

	/**
	 * Plugin directory
	 */
	public $plugin_dir;

	/**
	 * Plugin slug
	 */
	public $plugin_slug;

	/**
	 * Plugin url
	 */
	public $plugin_url;

	/**
	 * PUE checker
	 */
	protected $pue;

	/**
     * The placeholder image src.
     */
	public static $placeholder = '';

	/**
	 * Get (and instantiate, if necessary) the instance of the class.
	 *
	 * @return self
	 */
	public static function instance() {
		if ( ! self::$instance ) {
			self::$instance = new self;
		}
		return self::$instance;
	}

	/**
	 * Initialize the widget and much of the plugin in general.
	 *
	 * @since 1.0
	 */
	public function __construct() {

		$this->plugin_path = trailingslashit( IMAGE_WIDGET_PLUS_DIR );
		$this->plugin_dir  = trailingslashit( basename( $this->plugin_path ) );
		$this->plugin_url  = trailingslashit( plugins_url( $this->plugin_dir ) );
		$this->plugin_slug = 'image-widget-plus';

		// let's initialize after TEC and ET to prevent common conflicts
		add_action( 'plugins_loaded', array( $this, 'plugins_loaded' ), 1 );
	}

	/**
	 * To avoid duplication of our own methods and to provide a underlying system
	 * Modern Tribe maintains a Library called Common to store a base for our plugins
	 *
	 * Currently we will read the File `common/package.json` to determine which version
	 * of the Common Lib we will pass to the Auto-Loader of PHP.
	 *
	 * In the past we used to parse `common/src/Tribe/Main.php` for the Common Lib version.
	 *
	 * @link https://github.com/moderntribe/tribe-common
	 * @see  self::init_autoloading
	 *
	 * @return void
	 */
	public function maybe_set_common_lib_info() {
		// if always set common version to something super low because ANY common should override the
		// one in image-widget-plus
		$common_version = '1.0';

		/**
		 * If we don't have a version of Common or an Older version of the Lib
		 * overwrite what should be loaded by the auto-loader
		 */
		if (
			empty( $GLOBALS['tribe-common-info'] ) ||
			version_compare( $GLOBALS['tribe-common-info']['version'], $common_version, '<' )
		) {
			$GLOBALS['tribe-common-info'] = array(
				'dir' => "{$this->plugin_path}common/src/Tribe",
				'version' => $common_version,
			);
		}
	}

	/**
	 * Bootstrap this plugin and all of its pieces
	 *
	 * Fired during plugins_loaded action
	 *
	 * @since 1.0
	 */
	public function plugins_loaded() {

		$this->maybe_set_common_lib_info();

		$this->init_autoloading();

		// Tribe common resources
		require_once $this->plugin_path . 'vendor/tribe-common-libraries/tribe-common-libraries.class.php';

		Tribe__Main::instance();

		// if running an old version of TEC (pre PUE 2.0 with embedded licensing), fake the install key
		if ( version_compare( Tribe__Main::VERSION, '4.5.1', '<' ) ) {
			add_filter( 'pre_option_pue_install_key_image_widget_plus', array( $this, 'filter_install_key' ) );
		}

		if ( class_exists( 'Tribe__Main' ) && ! is_admin() && ! class_exists( 'Tribe__Image__Plus__Main' ) ) {
			tribe_main_pue_helper();
		}

		// Load language files.
		$mopath = $this->plugin_dir . 'lang/';
		$domain = 'image-widget-plus';

		// If we don't have Common classes load the old fashioned way
		if ( ! class_exists( 'Tribe__Main' ) ) {
			load_plugin_textdomain( $domain, false, $mopath );
		} else {
			// This will load `wp-content/languages/plugins` files first
			Tribe__Main::instance()->load_text_domain( $domain, $mopath );
		}

		// Load other files.
		require_once $this->plugin_path . 'src/Tribe/Attachment.php';
		require_once $this->plugin_path . 'src/Tribe/Image.php';
		require_once $this->plugin_path . 'src/Tribe/Widget.php';
		require_once $this->plugin_path . 'src/Tribe/PUE/Helper.php';
		require_once $this->plugin_path . 'src/Tribe/PUE.php';

		// Initialize other classes.
		Tribe__Image__Plus__Attachment::instance();
		Tribe__Image__Plus__Widget::instance();

		// Register the actual Image Widget Plus widget.
		add_action( 'widgets_init', array( $this, 'register_widget' ) );

		// Misc. hooks.
		add_action( 'plugin_row_meta', array( $this, 'plugin_row_meta' ), 10, 2 );

		$this->pue = new Tribe__Image__Plus__PUE( "{$this->plugin_path}/image-widget-plus.php" );
	}

	/**
	 * Requires the autoloader class from the main plugin class and sets up
	 * autoloading.
	 */
	public function init_autoloading() {
		$prefixes = array();

		if ( ! class_exists( 'Tribe__Autoloader' ) ) {
			require_once $GLOBALS['tribe-common-info']['dir'] . '/Autoloader.php';

			$prefixes['Tribe__'] = $GLOBALS['tribe-common-info']['dir'];
		}

		$autoloader = Tribe__Autoloader::instance();

		// include the fake Tribe__Main if a preferred one from TEC/ET hasn't been prepped for use
		if ( ! empty( $prefixes['Tribe__'] ) && "{$this->plugin_path}common/src/Tribe" === $prefixes['Tribe__'] ) {
			require_once $this->plugin_path . 'Tribe__Main.php';
		} else {
			$autoloader->register_prefixes( $prefixes );
		}

		$autoloader->register_prefix( 'Tribe__Image__Plus__', dirname( __FILE__ ) . '/src/Tribe', 'image-widget-plus' );

		// deprecated classes are registered in a class to path fashion
		foreach ( glob( $this->plugin_path . 'src/deprecated/*.php' ) as $file ) {
			$class_name = str_replace( '.php', '', basename( $file ) );
			$autoloader->register_class( $class_name, $file );
		}

		$autoloader->register_autoloader();
	}

	public function register_widget() {
		register_widget( 'Tribe__Image__Plus__Widget' );
	}

	/**
	 * Loads theme files in appropriate hierarchy: First the child theme, then
	 * the parent template, and finally plugin resources. Will look in the
	 * image-widget/ directory in a theme, the views/ directory in the plugin.
	 *
	 * @param string $template Template file to search for.
	 *
	 * @return template path
	 */
	public function template( $template ) {

		// Whether or not .php was added.
		$template_slug = rtrim( $template, '.php' );
		$template      = $template_slug . '.php';

		if ( $theme_file = locate_template( array( "image-widget/{$template}" ) ) ) {
			$file = $theme_file;
		} else {
			$file = "{$this->plugin_path}src/views/{$template}";
		}

		return apply_filters( 'tribe_image_plus_template_' . $template, $file );
	}

	/**
	 * Loads admin views, which aren't "overrideable", so no hierarchy.
	 *
	 * @param string $template Template file to search for.
	 *
	 * @return template path
	 */
	public function admin_template( $template ) {

		// Whether or not .php was added.
		$template_slug = rtrim( $template, '.php' );
		$template      = $template_slug . '.php';

		return "{$this->plugin_path}src/admin-views/{$template}";
	}

	/**
	 * Display an informational section in the plugin admin UI.
	 *
	 * @param array $meta Array of existing meta links.
	 * @param string $file Filename of plugin whose meta row is being filtered.
	 *
	 * @return array The filtered array of meta links.
	 */
	public function plugin_row_meta( $meta, $file ) {

		if ( strpos( $file, 'image-widget-plus.php' ) !== false ) {
			$meta[] = '<a href="http://m.tri.be/19nl" target="_blank">' . esc_html__( 'Support', 'image-widget-plus' ) . '</a>';
		}

		return $meta;
	}

	/**
	 * Filter the PUE install key for image widget plus to use the PUE__Helper class
	 *
	 * Note: this only gets run if running an older version of TEC (pre PUE 2.0 embedded licensing)
	 *
	 * @param string $value
	 *
	 * @return string
	 */
	public function filter_install_key( $value ) {
		if ( $value ) {
			return $value;
		}

		return Tribe__Image__Plus__PUE__Helper::DATA;
	}
}

Top ↑

Methods #

  • __construct — Initialize the widget and much of the plugin in general.
  • admin_template — Loads admin views, which aren't "overrideable", so no hierarchy.
  • filter_install_key — Filter the PUE install key for image widget plus to use the PUE__Helper class
  • init_autoloading — Requires the autoloader class from the main plugin class and sets up autoloading.
  • instance — Get (and instantiate, if necessary) the instance of the class.
  • maybe_set_common_lib_info — To avoid duplication of our own methods and to provide a underlying system Modern Tribe maintains a Library called Common to store a base for our plugins
  • plugin_row_meta — Display an informational section in the plugin admin UI.
  • plugins_loaded — Bootstrap this plugin and all of its pieces
  • register_widget
  • template — Loads theme files in appropriate hierarchy: First the child theme, then the parent template, and finally plugin resources. Will look in the image-widget/ directory in a theme, the views/ directory in the plugin.