Current File : /home/pacjaorg/public_html/cop29/wp-content/plugins/optinmonster/OMAPI/Elementor.php |
<?php
/**
* Elementor class.
*
* @since 2.2.0
*
* @package OMAPI
* @author Justin Sternberg
*/
// Exit if accessed directly.
if ( ! defined( 'ABSPATH' ) ) {
exit;
}
/**
* The Elementor class.
*
* @since 2.2.0
*/
class OMAPI_Elementor {
/**
* Holds the class object.
*
* @since 1.7.0
*
* @var object
*/
public static $instance;
/**
* Path to the file.
*
* @since 1.7.0
*
* @var string
*/
public $file = __FILE__;
/**
* Holds the base class object.
*
* @since 1.7.0
*
* @var object
*/
public $base;
/**
* The minimum Elementor version required.
*
* @since 2.11.2
*
* @var string
*/
const MINIMUM_VERSION = '3.1.0';
/**
* Primary class constructor.
*
* @since 1.7.0
*/
public function __construct() {
// Set our object.
$this->set();
// Skip if Elementor is not available.
if ( ! class_exists( '\Elementor\Plugin' ) ) {
return;
}
// Check if Elementor is the minimum version.
if ( ! self::is_minimum_version() ) {
return;
}
add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'editor_assets' ) );
add_action( 'elementor/widgets/widgets_registered', array( $this, 'register_widget' ), 999 );
add_action( 'optin_monster_should_set_campaigns_as_preview', array( $this, 'maybe_set_campaigns_as_preview' ) );
add_action( 'optin_monster_display_media_button', array( $this, 'maybe_show_campaign_button' ), 10, 2 );
}
/**
* Sets our object instance and base class instance.
*
* @since 1.7.0
*/
public function set() {
self::$instance = $this;
$this->base = OMAPI::get_instance();
}
/**
* Load an integration css in the elementor document.
*
* @since 2.2.0
*/
public function editor_assets() {
// phpcs:ignore WordPress.Security.NonceVerification.Recommended
if ( empty( $_GET['action'] ) || 'elementor' !== $_GET['action'] ) {
return;
}
$css_handle = $this->base->plugin_slug . '-elementor-admin';
wp_enqueue_style(
$css_handle,
$this->base->url . 'assets/dist/css/elementor-admin.min.css',
array(),
$this->base->asset_version()
);
$this->maybe_enqueue_dark_mode( $css_handle );
}
/**
* Handle enqueueing the dark-mode css. Will be conditionally displayed based on the UI setting.
*
* We have to do this until Elementor has better handling for dark-mode via a body class
*
* @see https://github.com/elementor/elementor/issues/13419
*
* @since 2.2.0
*
* @param string $css_handle Non-dark mode handle.
*
* @return bool|string
*/
protected function maybe_enqueue_dark_mode( $css_handle ) {
$ui_theme = \Elementor\Core\Settings\Manager::get_settings_managers( 'editorPreferences' )->get_model()->get_settings( 'ui_theme' );
if ( 'light' === $ui_theme ) {
return false;
}
$ui_theme_media_queries = 'auto' === $ui_theme
? '(prefers-color-scheme: dark)'
: 'all';
wp_enqueue_style(
$css_handle . '-dark-mode',
$this->base->url . 'assets/dist/css/elementor-admin-dark.min.css',
array( $css_handle ),
$this->base->asset_version(),
$ui_theme_media_queries
);
}
/**
* Return the Elementor versions string.
*
* @since 2.11.2
*
* @return string
*/
public static function version() {
return defined( 'ELEMENTOR_VERSION' ) ? ELEMENTOR_VERSION : '0.0.0';
}
/**
* Determines if the passed version string passes the operator compare
* against the currently installed version of Elementor.
*
* Defaults to checking if the current Elementor version is greater than
* the passed version.
*
* @since 2.11.2
*
* @param string $version The version to check.
* @param string $operator The operator to use for comparison.
*
* @return string
*/
public static function version_compare( $version = '', $operator = '>=' ) {
return version_compare( self::version(), $version, $operator );
}
/**
* Determines if the current Elementor version meets the minimum version
* requirement.
*
* @since 2.11.2
*
* @return boolean
*/
public static function is_minimum_version() {
return self::version_compare( self::MINIMUM_VERSION );
}
/**
* Register WPForms Widget.
*
* @since 2.2.0
*
* @param \Elementor\Widgets_Manager $widget_manager Elementor widget manager object.
*/
public function register_widget( $widget_manager ) {
$widget_manager->register_widget_type( new OMAPI_Elementor_Widget() );
// We need to override the button widget with our extended version.
$widget_manager->register_widget_type( new OMAPI_Elementor_ButtonWidget() );
}
/**
* Set the preview flag if in the elementor preview mode.
*
* @since 2.2.0
*
* @param bool $is_preview Whether we're currently in preview mode.
*
* @return bool Whether we're in preview mode.
*/
public function maybe_set_campaigns_as_preview( $is_preview ) {
if ( ! $is_preview ) {
$is_preview = \Elementor\Plugin::instance()->preview->is_preview_mode();
}
return $is_preview;
}
/**
* Show the editor campaign media button if in the elementor editor.
*
* @since 2.3.0
*
* @param bool $show Whether button will show.
*
* @return bool Whether button will show.
*/
public function maybe_show_campaign_button( $show, $editor_id ) {
$edit_mode = \Elementor\Plugin::instance()->editor->is_edit_mode();
if ( $edit_mode ) {
$show = true;
add_action( 'elementor/editor/footer', array( $this->base->classicEditor, 'shortcode_modal' ) );
}
return $show;
}
}