File "module.php"
Full Path: /home/fmpomerode/public_html/wp-content/plugins/bdthemes-element-pack/modules/animated-gradient-background/module.php
File size: 8.41 KB
MIME-type: text/x-c++; charset=us-ascii
Charset: utf-8
<?php
namespace ElementPack\Modules\AnimatedGradientBackground;
use Elementor\Controls_Manager;
use Elementor\Repeater;
use ElementPack\Base\Element_Pack_Module_Base;
if (!defined('ABSPATH')) exit; // Exit if accessed directly
class Module extends Element_Pack_Module_Base {
public function __construct() {
parent::__construct();
$this->add_actions();
}
public function get_name() {
return 'bdt-animated-gradient-background';
}
public function register_section($element) {
$element->start_controls_section(
'element_pack_agbg_section',
[
'tab' => Controls_Manager::TAB_STYLE,
'label' => BDTEP_CP . esc_html__('Animated Gradient Background', 'bdthemes-element-pack'),
]
);
$element->end_controls_section();
}
public function register_controls($section, $args) {
$section->add_control(
'element_pack_agbg_show',
[
'label' => esc_html__('Use Animated Gradient BG', 'bdthemes-element-pack'),
'type' => Controls_Manager::SWITCHER,
'frontend_available' => true,
'render_type' => 'template',
'prefix_class' => 'element-pack-agbg-',
'return_value' => 'yes',
'default' => '',
]
);
$repeater = new Repeater();
$repeater->add_control(
'start_color',
[
'label' => esc_html__('Start Color', 'bdthemes-element-pack'),
'default' => '#0591F9',
'type' => Controls_Manager::COLOR,
]
);
$repeater->add_control(
'end_color',
[
'label' => esc_html__('End Color', 'bdthemes-element-pack'),
'default' => '#fefefe',
'type' => Controls_Manager::COLOR,
]
);
$section->add_control(
'element_pack_agbg_color_list',
[
'label' => esc_html__('Color List', 'bdthemes-element-pack'),
'type' => Controls_Manager::REPEATER,
'fields' => $repeater->get_controls(),
'frontend_available' => true,
'render_type' => 'none',
'default' => [
[
'start_color' => esc_html__('#0591F9', 'bdthemes-element-pack'),
'end_color' => esc_html__('#fefefe', 'bdthemes-element-pack'),
],
[
'start_color' => esc_html__('#567445', 'bdthemes-element-pack'),
'end_color' => esc_html__('#1D1BE0', 'bdthemes-element-pack'),
],
],
'title_field' => '{{start_color}}',
'condition' => [
'element_pack_agbg_show' => 'yes'
]
]
);
$section->add_control(
'element_pack_agbg_blending_mode',
[
'label' => esc_html__('Blend Mode', 'bdthemes-element-pack'),
'type' => Controls_Manager::SELECT,
'default' => 'hue',
'options' => [
'multiply' => esc_html__('Multiply', 'bdthemes-element-pack'),
'screen' => esc_html__('Screen', 'bdthemes-element-pack'),
'normal' => esc_html__('Normal', 'bdthemes-element-pack'),
'overlay' => esc_html__('Overlay', 'bdthemes-element-pack'),
'darken' => esc_html__('Darken', 'bdthemes-element-pack'),
'lighten' => esc_html__('Lighten', 'bdthemes-element-pack'),
'color-dodge' => esc_html__('Color Dodge', 'bdthemes-element-pack'),
'color-burn' => esc_html__('Color Burn', 'bdthemes-element-pack'),
'hard-light' => esc_html__('Hard Light', 'bdthemes-element-pack'),
'soft-light' => esc_html__('Soft Light', 'bdthemes-element-pack'),
'difference' => esc_html__('Difference', 'bdthemes-element-pack'),
'exclusion' => esc_html__('Exclusion', 'bdthemes-element-pack'),
'hue' => esc_html__('Hue', 'bdthemes-element-pack'),
'saturation' => esc_html__('Saturation', 'bdthemes-element-pack'),
'color' => esc_html__('Color', 'bdthemes-element-pack'),
'luminosity' => esc_html__('Luminosity', 'bdthemes-element-pack'),
],
'selectors' => [
'{{WRAPPER}}.element-pack-agbg-yes .bdt-animated-gradient-background' => 'mix-blend-mode:{{VALUE}}'
],
'conditions' => [
'relation' => 'and',
'terms' => [
[
'name' => 'background_background',
'operator' => '!==',
'value' => '',
],
[
'name' => 'element_pack_agbg_show',
'operator' => '===',
'value' => 'yes',
],
],
],
]
);
$section->add_control(
'element_pack_agbg_direction',
[
'label' => esc_html__('Direction', 'bdthemes-element-pack'),
'type' => Controls_Manager::SELECT,
'default' => 'diagonal',
'separator' => 'before',
'frontend_available' => true,
'render_type' => 'none',
'options' => [
'diagonal' => esc_html__('Diagonal', 'bdthemes-element-pack'),
'left-right' => esc_html__('Left Right', 'bdthemes-element-pack'),
'top-bottom' => esc_html__('Top Bottom', 'bdthemes-element-pack'),
'radial' => esc_html__('Radial', 'bdthemes-element-pack'),
],
'condition' => [
'element_pack_agbg_show' => 'yes'
]
]
);
$section->add_control(
'element_pack_agbg_transitionSpeed',
[
'label' => esc_html__('Transition Speed', 'bdthemes-element-pack'),
'type' => Controls_Manager::SLIDER,
'frontend_available' => true,
'render_type' => 'none',
'range' => [
'px' => [
'min' => 100,
'max' => 10000,
'step' => 100,
]
],
'condition' => [
'element_pack_agbg_show' => 'yes'
]
]
);
}
public function enqueue_scripts() {
wp_enqueue_script('granim', BDTEP_ASSETS_URL . 'vendor/js/granim.min.js', [], 'v2.0.0', true);
}
public function should_script_enqueue($section) {
if ('yes' === $section->get_settings_for_display('element_pack_agbg_show')) {
$this->enqueue_scripts();
wp_enqueue_style('ep-animated-gradient-background');
wp_enqueue_script('ep-animated-gradient-background');
}
}
protected function add_actions() {
add_action('elementor/element/section/section_background/after_section_end', [$this, 'register_section']);
add_action('elementor/element/section/element_pack_agbg_section/before_section_end', [$this, 'register_controls'], 10, 2);
add_action('elementor/frontend/section/before_render', [$this, 'should_script_enqueue']);
add_action('elementor/element/container/section_background/after_section_end', [$this, 'register_section']);
add_action('elementor/element/container/element_pack_agbg_section/before_section_end', [$this, 'register_controls'], 10, 2);
add_action('elementor/frontend/container/before_render', [$this, 'should_script_enqueue']);
add_action('elementor/preview/enqueue_scripts', [$this, 'enqueue_scripts']);
}
}