Files
masimmo.pl/modules/creativeelements/includes/base/skin-base.php
2024-11-20 09:09:44 +01:00

350 lines
8.3 KiB
PHP

<?php
/**
* Creative Elements - live Theme & Page Builder
*
* @author WebshopWorks, Elementor
* @copyright 2019-2023 WebshopWorks.com & Elementor.com
* @license https://www.gnu.org/licenses/gpl-3.0.html
*/
namespace CE;
defined('_PS_VERSION_') or exit;
/**
* Elementor skin base.
*
* An abstract class to register new skins for Elementor widgets. Skins allows
* you to add new templates, set custom controls and more.
*
* To register new skins for your widget use the `add_skin()` method inside the
* widget's `_register_skins()` method.
*
* @since 1.0.0
* @abstract
*/
abstract class SkinBase
{
/**
* Parent widget.
*
* Holds the parent widget of the skin. Default value is null, no parent widget.
*
* @var WidgetBase|null
*/
protected $parent = null;
/**
* Skin base constructor.
*
* Initializing the skin base class by setting parent widget and registering
* controls actions.
*
* @since 1.0.0
*
* @param WidgetBase $parent
*/
public function __construct(WidgetBase $parent)
{
$this->parent = $parent;
$this->_registerControlsActions();
}
/**
* Get skin ID.
*
* Retrieve the skin ID.
*
* @since 1.0.0
* @abstract
*/
abstract public function getId();
/**
* Get skin title.
*
* Retrieve the skin title.
*
* @since 1.0.0
* @abstract
*/
abstract public function getTitle();
/**
* Render skin.
*
* Generates the final HTML on the frontend.
*
* @since 1.0.0
* @abstract
*/
abstract public function render();
/**
* Register skin controls actions.
*
* Run on init and used to register new skins to be injected to the widget.
* This method is used to register new actions that specify the location of
* the skin in the widget.
*
* Example usage:
* `add_action( 'elementor/element/{widget_id}/{section_id}/before_section_end', [ $this, 'register_controls' ] );`
*
* @since 1.0.0
*/
protected function _registerControlsActions()
{
}
/**
* Get skin control ID.
*
* Retrieve the skin control ID. Note that skin controls have special prefix
* to distinguish them from regular controls, and from controls in other
* skins.
*
* @since 1.0.0
*
* @param string $control_base_id Control base ID
*
* @return string Control ID
*/
protected function getControlId($control_base_id)
{
$skin_id = str_replace('-', '_', $this->getId());
return $skin_id . '_' . $control_base_id;
}
/**
* Get skin settings.
*
* Retrieve all the skin settings or, when requested, a specific setting.
*
* @since 1.0.0
* @TODO: rename to get_setting() and create backward compatibility.
*
* @param string $control_base_id Control base ID
*
* @return WidgetBase Widget instance
*/
public function getInstanceValue($control_base_id)
{
$control_id = $this->getControlId($control_base_id);
return $this->parent->getSettings($control_id);
}
/**
* Start skin controls section.
*
* Used to add a new section of controls to the skin.
*
* @since 1.3.0
*
* @param string $id Section ID
* @param array $args Section arguments
*/
public function startControlsSection($id, $args)
{
$args['condition']['_skin'] = $this->getId();
$this->parent->startControlsSection($this->getControlId($id), $args);
}
/**
* End skin controls section.
*
* Used to close an existing open skin controls section.
*
* @since 1.3.0
*/
public function endControlsSection()
{
$this->parent->endControlsSection();
}
/**
* Add new skin control.
*
* Register a single control to the allow the user to set/update skin data.
*
* @since 1.0.0
*
* @param string $id Control ID
* @param array $args Control arguments
*
* @return bool True if skin added, False otherwise
*/
public function addControl($id, $args)
{
$args['condition']['_skin'] = $this->getId();
return $this->parent->addControl($this->getControlId($id), $args);
}
/**
* Update skin control.
*
* Change the value of an existing skin control.
*
* @since 1.3.0
* @since 1.8.1 New `$options` parameter added.
*
* @param string $id Control ID
* @param array $args Control arguments. Only the new fields you want to update
* @param array $options Optional. Some additional options
*/
public function updateControl($id, $args, array $options = [])
{
$args['condition']['_skin'] = $this->getId();
$this->parent->updateControl($this->getControlId($id), $args, $options);
}
/**
* Remove skin control.
*
* Unregister an existing skin control.
*
* @since 1.3.0
*
* @param string $id Control ID
*/
public function removeControl($id)
{
$this->parent->removeControl($this->getControlId($id));
}
/**
* Add new responsive skin control.
*
* Register a set of controls to allow editing based on user screen size.
*
* @since 1.0.5
*
* @param string $id Responsive control ID
* @param array $args Responsive control arguments
*/
public function addResponsiveControl($id, $args)
{
$args['condition']['_skin'] = $this->getId();
$this->parent->addResponsiveControl($this->getControlId($id), $args);
}
/**
* Update responsive skin control.
*
* Change the value of an existing responsive skin control.
*
* @since 1.3.5
*
* @param string $id Responsive control ID
* @param array $args Responsive control arguments
*/
public function updateResponsiveControl($id, $args)
{
$this->parent->updateResponsiveControl($this->getControlId($id), $args);
}
/**
* Remove responsive skin control.
*
* Unregister an existing skin responsive control.
*
* @since 1.3.5
*
* @param string $id Responsive control ID
*/
public function removeResponsiveControl($id)
{
$this->parent->removeResponsiveControl($this->getControlId($id));
}
/**
* Start skin controls tab.
*
* Used to add a new tab inside a group of tabs.
*
* @since 1.5.0
*
* @param string $id Control ID
* @param array $args Control arguments
*/
public function startControlsTab($id, $args)
{
$args['condition']['_skin'] = $this->getId();
$this->parent->startControlsTab($this->getControlId($id), $args);
}
/**
* End skin controls tab.
*
* Used to close an existing open controls tab.
*
* @since 1.5.0
*/
public function endControlsTab()
{
$this->parent->endControlsTab();
}
/**
* Start skin controls tabs.
*
* Used to add a new set of tabs inside a section.
*
* @since 1.5.0
*
* @param string $id Control ID
*/
public function startControlsTabs($id)
{
// $args['condition']['_skin'] = $this->getId();
$this->parent->startControlsTabs($this->getControlId($id));
}
/**
* End skin controls tabs.
*
* Used to close an existing open controls tabs.
*
* @since 1.5.0
*/
public function endControlsTabs()
{
$this->parent->endControlsTabs();
}
/**
* Add new group control.
*
* Register a set of related controls grouped together as a single unified
* control.
*
* @since 1.0.0
*
* @param string $group_name Group control name
* @param array $args Group control arguments. Default is an empty array
*/
final public function addGroupControl($group_name, $args = [])
{
$args['name'] = $this->getControlId($args['name']);
$args['condition']['_skin'] = $this->getId();
$this->parent->addGroupControl($group_name, $args);
}
/**
* Set parent widget.
*
* Used to define the parent widget of the skin.
*
* @since 1.0.0
*
* @param WidgetBase $parent Parent widget
*/
public function setParent($parent)
{
$this->parent = $parent;
}
}