: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in
class DSM_Lottie extends ET_Builder_Module {
public $slug = 'dsm_lottie';
public $vb_support = 'on';
protected $module_credits = array(
'module_uri' => 'https://divisupreme.com/',
'author' => 'Divi Supreme',
'author_uri' => 'https://divisupreme.com/',
$this->name = esc_html__( 'Supreme Lottie', 'dsm-supreme-modules-for-divi' );
$this->icon_path = plugin_dir_path( __FILE__ ) . 'icon.svg';
$this->settings_modal_toggles = array(
'main_content' => esc_html__( 'Lottie', 'dsm-supreme-modules-for-divi' ),
public function get_advanced_fields_config() {
'main' => '%%order_class%%',
'parallax_method' => array(
'main' => '%%order_class%%',
'border_radii' => '%%order_class%%',
'border_styles' => '%%order_class%%',
'main' => '%%order_class%%',
public function get_fields() {
'label' => esc_html__( 'Lottie JSON File', 'dsm-supreme-modules-for-divi' ),
'option_category' => 'basic_option',
'upload_button_text' => esc_attr__( 'Upload a json file', 'dsm-supreme-modules-for-divi' ),
'choose_text' => esc_attr__( 'Choose a JSON file', 'dsm-supreme-modules-for-divi' ),
'update_text' => esc_attr__( 'Set As JSON for the module', 'dsm-supreme-modules-for-divi' ),
'computed_affects' => array(
'label' => esc_html__( 'Loop', 'dsm-supreme-modules-for-divi' ),
'type' => 'yes_no_button',
'option_category' => 'configuration',
'off' => esc_html__( 'No', 'dsm-supreme-modules-for-divi' ),
'on' => esc_html__( 'Yes', 'dsm-supreme-modules-for-divi' ),
'default_on_front' => 'on',
'description' => esc_html__( 'Here you can choose whether or not your Lottie will animate in loop.', 'dsm-supreme-modules-for-divi' ),
'computed_affects' => array(
'lottie_play_on_hover' => 'on',
'loop_no_times' => array(
'label' => esc_html__( 'Number of times', 'dsm-supreme-modules-for-divi' ),
'option_category' => 'configuration',
'validate_unit' => false,
'description' => esc_html__( 'This option is only available if Yes is selected for Loop. Enter the number of times you wish to have the animation loop before stopping.', 'dsm-supreme-modules-for-divi' ),
'range_settings' => array(
'lottie_play_on_hover' => 'on',
'computed_affects' => array(
'lottie_autoplay' => array(
'label' => esc_html__( 'Autoplay', 'dsm-supreme-modules-for-divi' ),
'type' => 'yes_no_button',
'option_category' => 'configuration',
'off' => esc_html__( 'No', 'dsm-supreme-modules-for-divi' ),
'on' => esc_html__( 'Yes', 'dsm-supreme-modules-for-divi' ),
'default_on_front' => 'on',
'description' => esc_html__( 'Here you can choose whether or not your Lottie will autoplay on load.', 'dsm-supreme-modules-for-divi' ),
'computed_affects' => array(
'label' => esc_html__( 'Delay', 'dsm-supreme-modules-for-divi' ),
'option_category' => 'configuration',
'default_on_front' => '0ms',
'allowed_units' => array( 'ms' ),
'description' => esc_html__( 'Delay the lottie animation (in ms).', 'dsm-supreme-modules-for-divi' ),
'range_settings' => array(
'computed_affects' => array(
'lottie_direction' => array(
'label' => esc_html__( 'Direction', 'dsm-supreme-modules-for-divi' ),
'option_category' => 'layout',
'1' => esc_html__( 'Normal', 'dsm-supreme-modules-for-divi' ),
'-1' => esc_html__( 'Reverse', 'dsm-supreme-modules-for-divi' ),
'default_on_front' => '1',
'computed_affects' => array(
'label' => esc_html__( 'Speed (More is faster)', 'dsm-supreme-modules-for-divi' ),
'option_category' => 'configuration',
'default_on_front' => '1',
'validate_unit' => false,
'description' => esc_html__( 'The speed of the animation.', 'dsm-supreme-modules-for-divi' ),
'range_settings' => array(
'computed_affects' => array(
'lottie_play_on_hover' => array(
'label' => esc_html__( 'Trigger', 'dsm-supreme-modules-for-divi' ),
'type' => 'yes_no_button',
'option_category' => 'configuration',
'off' => esc_html__( 'No', 'dsm-supreme-modules-for-divi' ),
'on' => esc_html__( 'Yes', 'dsm-supreme-modules-for-divi' ),
'default_on_front' => 'off',
'description' => esc_html__( 'Here you can choose whether or not your Lottie will animate on hover.', 'dsm-supreme-modules-for-divi' ),
'computed_affects' => array(
'lottie_trigger_method' => array(
'label' => esc_html__( 'Trigger Method', 'dsm-supreme-modules-for-divi' ),
'option_category' => 'layout',
'on_hover' => esc_html__( 'Play Animation On Hover/Mouse Over', 'dsm-supreme-modules-for-divi' ),
'on_click' => esc_html__( 'Play Animation On Click', 'dsm-supreme-modules-for-divi' ),
'on_scroll' => esc_html__( 'Play Animation On Scroll', 'dsm-supreme-modules-for-divi' ),
'default_on_front' => 'on_hover',
'lottie_play_on_hover' => 'on',
'computed_affects' => array(
'lottie_scroll' => array(
'label' => esc_html__( 'Relative To', 'dsm-supreme-modules-for-divi' ),
'option_category' => 'layout',
'page' => esc_html__( 'Entire Page', 'dsm-supreme-modules-for-divi' ),
'row' => esc_html__( 'Within This Section/Row', 'dsm-supreme-modules-for-divi' ),
'default_on_front' => 'on_hover',
'lottie_play_on_hover' => 'on',
'lottie_trigger_method' => 'on_scroll',
'computed_affects' => array(
'lottie_mouseout_action' => array(
'label' => esc_html__( 'On Mouseout Action', 'dsm-supreme-modules-for-divi' ),
'option_category' => 'layout',
'no_action' => esc_html__( 'No Action', 'dsm-supreme-modules-for-divi' ),
'stop' => esc_html__( 'Stop', 'dsm-supreme-modules-for-divi' ),
'pause' => esc_html__( 'Pause', 'dsm-supreme-modules-for-divi' ),
'reverse' => esc_html__( 'Reverse', 'dsm-supreme-modules-for-divi' ),
'default_on_front' => 'no_action',
'lottie_play_on_hover' => 'on',
'lottie_trigger_method' => 'on_hover',
'computed_affects' => array(
'lottie_animation_viewport' => array(
'label' => esc_html__( 'Animate in Viewport', 'dsm-supreme-modules-for-divi' ),
'description' => esc_html__( 'Animation when the element is in viewport.', 'dsm-supreme-modules-for-divi' ),
'option_category' => 'layout',
'default_on_front' => '80%',
'range_settings' => array(
'mobile_options' => false,
'computed_affects' => array(
'lottie_play_on_hover' => 'off',
'computed_callback' => array( 'DSM_Lottie', 'getLottie' ),
'computed_depends_on' => array(
'lottie_mouseout_action',
'lottie_animation_viewport',
public function render( $attrs, $content, $render_slug ) {
$lottie_url = $this->props['lottie_url'];
$lottie_loop = $this->props['lottie_loop'];
$loop_no_times = $this->props['loop_no_times'];
// $lottie_autoplay = $this->props['lottie_autoplay'];
$lottie_delay = $this->props['lottie_delay'];
$lottie_direction = $this->props['lottie_direction'];
$lottie_speed = $this->props['lottie_speed'];
$lottie_play_on_hover = $this->props['lottie_play_on_hover'];
$lottie_trigger_method = $this->props['lottie_trigger_method'];
$lottie_scroll = $this->props['lottie_scroll'];
$lottie_mouseout_action = $this->props['lottie_mouseout_action'];
$lottie_animation_viewport = $this->props['lottie_animation_viewport'];
wp_enqueue_script( 'dsm-lottie-module' );
'loop' => 'off' !== $lottie_loop ? true : false,
'loop_no' => $loop_no_times,
'delay' => $lottie_delay,
'direction' => $lottie_direction,
'speed' => $lottie_speed,
'hover' => 'off' !== $lottie_play_on_hover ? true : false,
'trigger' => $lottie_trigger_method,
'scroll' => $lottie_scroll,
'mouseout' => $lottie_mouseout_action,
'viewport' => $lottie_animation_viewport,
// Render module content.
'<div class="dsm_lottie_wrapper" data-percent-viewport="" data-params=%1$s>
htmlspecialchars( wp_json_encode( $data_attrs ), ENT_QUOTES, 'UTF-8' )
if ( isset( get_option( 'dsm_settings_misc' )['dsm_dynamic_assets'] ) && ! empty( get_option( 'dsm_settings_misc' )['dsm_dynamic_assets'] ) && 'on' === get_option( 'dsm_settings_misc' )['dsm_dynamic_assets'] ) {
if ( isset( get_option( 'dsm_settings_misc' )['dsm_dynamic_assets_compatibility'] ) && ! empty( get_option( 'dsm_settings_misc' )['dsm_dynamic_assets'] ) && 'on' === get_option( 'dsm_settings_misc' )['dsm_dynamic_assets_compatibility'] ) {
wp_enqueue_style( 'dsm-lottie', plugin_dir_url( __DIR__ ) . 'Lottie/style.css', array(), DSM_VERSION, 'all' );
add_filter( 'et_global_assets_list', array( $this, 'dsm_load_required_divi_assets' ), 10, 3 );
add_filter( 'et_late_global_assets_list', array( $this, 'dsm_load_required_divi_assets' ), 10, 3 );
* Force load global styles.
* @param array $assets_list Current global assets on the list.
public function dsm_load_required_divi_assets( $assets_list, $assets_args, $instance ) {
$assets_prefix = et_get_dynamic_assets_path();
$all_shortcodes = $instance->get_saved_page_shortcodes();
$this->_cpt_suffix = et_builder_should_wrap_styles() && ! et_is_builder_plugin_active() ? '_cpt' : '';
if ( ! isset( $assets_list['et_jquery_magnific_popup'] ) ) {
$assets_list['et_jquery_magnific_popup'] = array(
'css' => "{$assets_prefix}/css/magnific_popup.css",
if ( ! isset( $assets_list['et_pb_overlay'] ) ) {
$assets_list['et_pb_overlay'] = array(
'css' => "{$assets_prefix}/css/overlay{$this->_cpt_suffix}.css",
if ( ! isset( $assets_list['dsm_lottie'] ) ) {
$assets_list['dsm_lottie'] = array(
'css' => plugin_dir_url( __DIR__ ) . 'Lottie/style.css',