This repository has been archived on 2022-06-23. You can view files and clone it, but cannot push or open issues or pull requests.
divi/includes/builder/class-et-builder-plugin-compat-loader.php
2021-12-07 11:08:05 +00:00

75 lines
1.6 KiB
PHP

<?php
/**
* Load plugin compatibility file if supported plugins are activated.
*
* @since 0.7 (builder version)
*
* @package Divi
*/
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly.
}
/**
* Class ET_Builder_Plugin_Compat_Loader.
*/
class ET_Builder_Plugin_Compat_Loader {
/**
* Unique instance of class.
*
* @var ET_Builder_Plugin_Compat_Loader
*/
public static $instance;
/**
* Constructor.
*/
private function __construct() {
$this->init_hooks();
}
/**
* Gets the instance of the class.
*/
public static function init() {
if ( null === self::$instance ) {
self::$instance = new self();
}
return self::$instance;
}
/**
* Hook methods to WordPress action and filter.
*
* @return void
*/
private function init_hooks() {
// Load plugin.php for frontend usage.
if ( ! function_exists( 'is_plugin_active' ) || ! function_exists( 'get_plugins' ) ) {
include_once ABSPATH . 'wp-admin/includes/plugin.php';
}
// Loop plugin list and load active plugin compatibility file.
foreach ( array_keys( get_plugins() ) as $plugin ) {
// Load plugin compat file if plugin is active.
if ( is_plugin_active( $plugin ) ) {
$plugin_compat_name = dirname( $plugin );
$plugin_compat_url = apply_filters(
"et_builder_plugin_compat_path_{$plugin_compat_name}",
ET_BUILDER_DIR . "plugin-compat/{$plugin_compat_name}.php",
$plugin_compat_name
);
// Load plugin compat file (if compat file found).
if ( file_exists( $plugin_compat_url ) ) {
require_once $plugin_compat_url;
}
}
}
}
}
ET_Builder_Plugin_Compat_Loader::init();