114 lines
2.3 KiB
PHP
114 lines
2.3 KiB
PHP
|
<?php
|
||
|
namespace Elementor;
|
||
|
|
||
|
if ( ! defined( 'ABSPATH' ) ) {
|
||
|
exit; // Exit if accessed directly.
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Elementor skins manager.
|
||
|
*
|
||
|
* Elementor skins manager handler class is responsible for registering and
|
||
|
* initializing all the supported skins.
|
||
|
*
|
||
|
* @since 1.0.0
|
||
|
*/
|
||
|
class Skins_Manager {
|
||
|
|
||
|
/**
|
||
|
* Registered Skins.
|
||
|
*
|
||
|
* Holds the list of all the registered skins for all the widgets.
|
||
|
*
|
||
|
* @since 1.0.0
|
||
|
* @access private
|
||
|
*
|
||
|
* @var array Registered skins.
|
||
|
*/
|
||
|
private $_skins = [];
|
||
|
|
||
|
/**
|
||
|
* Add new skin.
|
||
|
*
|
||
|
* Register a single new skin for a widget.
|
||
|
*
|
||
|
* @since 1.0.0
|
||
|
* @access public
|
||
|
*
|
||
|
* @param Widget_Base $widget Elementor widget.
|
||
|
* @param Skin_Base $skin Elementor skin.
|
||
|
*
|
||
|
* @return true True if skin added.
|
||
|
*/
|
||
|
public function add_skin( Widget_Base $widget, Skin_Base $skin ) {
|
||
|
$widget_name = $widget->get_name();
|
||
|
|
||
|
if ( ! isset( $this->_skins[ $widget_name ] ) ) {
|
||
|
$this->_skins[ $widget_name ] = [];
|
||
|
}
|
||
|
|
||
|
$this->_skins[ $widget_name ][ $skin->get_id() ] = $skin;
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Remove a skin.
|
||
|
*
|
||
|
* Unregister an existing skin from a widget.
|
||
|
*
|
||
|
* @since 1.0.0
|
||
|
* @access public
|
||
|
*
|
||
|
* @param Widget_Base $widget Elementor widget.
|
||
|
* @param string $skin_id Elementor skin ID.
|
||
|
*
|
||
|
* @return true|\WP_Error True if skin removed, `WP_Error` otherwise.
|
||
|
*/
|
||
|
public function remove_skin( Widget_Base $widget, $skin_id ) {
|
||
|
$widget_name = $widget->get_name();
|
||
|
|
||
|
if ( ! isset( $this->_skins[ $widget_name ][ $skin_id ] ) ) {
|
||
|
return new \WP_Error( 'Cannot remove not-exists skin.' );
|
||
|
}
|
||
|
|
||
|
unset( $this->_skins[ $widget_name ][ $skin_id ] );
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get skins.
|
||
|
*
|
||
|
* Retrieve all the skins assigned for a specific widget.
|
||
|
*
|
||
|
* @since 1.0.0
|
||
|
* @access public
|
||
|
*
|
||
|
* @param Widget_Base $widget Elementor widget.
|
||
|
*
|
||
|
* @return false|array Skins if the widget has skins, False otherwise.
|
||
|
*/
|
||
|
public function get_skins( Widget_Base $widget ) {
|
||
|
$widget_name = $widget->get_name();
|
||
|
|
||
|
if ( ! isset( $this->_skins[ $widget_name ] ) ) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
return $this->_skins[ $widget_name ];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Skins manager constructor.
|
||
|
*
|
||
|
* Initializing Elementor skins manager by requiring the skin base class.
|
||
|
*
|
||
|
* @since 1.0.0
|
||
|
* @access public
|
||
|
*/
|
||
|
public function __construct() {
|
||
|
require ELEMENTOR_PATH . 'includes/base/skin-base.php';
|
||
|
}
|
||
|
}
|