Your IP : 13.59.217.1


Current Path : /home/ncdcgo/public_html/wp-content/plugins backup/Ultimate_VC_Addons/modules/
Upload File :
Current File : /home/ncdcgo/public_html/wp-content/plugins backup/Ultimate_VC_Addons/modules/ultimate_parallax.php

<?php
/**
 * Add-on Name: Ultimate Parallax Background for WPBakery Page Builder
 * Add-on URI: http://dev.brainstormforce.com
 *
 *  @package UAVC Ultimate Parallax
 */

$ultimate_row = get_option( 'ultimate_row' );
if ( 'enable' != $ultimate_row ) {
	return false;
}
if ( ! class_exists( 'Ultimate_VC_Addons_Parallax' ) ) {
	/**
	 * Function that initializes  Ultimate Parallax.
	 *
	 * @class Ultimate_VC_Addons_Parallax
	 */
	class Ultimate_VC_Addons_Parallax {
		/**
		 * Constructor function that constructs default values for the Ultimate Parallax.
		 *
		 * @method __construct
		 */
		public function __construct() {
			add_action( 'admin_enqueue_scripts', array( $this, 'admin_scripts' ) );
			add_action( 'admin_init', array( $this, 'parallax_init' ) );
			$ultimate_row = get_option( 'ultimate_row' );
			if ( 'enable' == $ultimate_row ) {
				if ( defined( 'WPB_VC_VERSION' ) && version_compare( WPB_VC_VERSION, '4.4', '>=' ) ) {
					add_filter( 'vc_shortcode_output', array( $this, 'execute_ultimate_vc_shortcode' ), 10, 3 );
				}
			}
		}//end __construct()

		/**
		 * Execute shortcode.
		 *
		 * @since ----
		 * @param mixed $output output.
		 * @param mixed $obj object.
		 * @param mixed $attr attributes.
		 * @access public
		 */
		public function execute_ultimate_vc_shortcode( $output, $obj, $attr ) {
			if ( $obj->settings( 'base' ) == 'vc_row' ) {
				$output .= $this->parallax_shortcode( $attr, '' );
			}
			return $output;
		}
		/**
		 * Execute Parallax shortcode.
		 *
		 * @since ----
		 * @param mixed $atts atts variable.
		 * @param mixed $content contents.
		 * @access public
		 */
		public static function parallax_shortcode( $atts, $content ) {
			$bsf_img_repeat = '';
			$overlay        = '';

			$seperator_html        = '';
			$seperator_bottom_html = '';
			$seperator_top_html    = '';
			$seperator_css         = '';

			$ult_parallax_settings = shortcode_atts(
				array(
					'bg_type'                        => '',
					'bg_image'                       => '',
					'bg_image_new'                   => '',
					'bg_image_repeat'                => '',
					'bg_image_size'                  => '',
					'parallax_style'                 => '',
					'parallax_sense'                 => '30',
					'video_opts'                     => '',
					'bg_image_posiiton'              => '',
					'video_url'                      => '',
					'video_url_2'                    => '',
					'video_poster'                   => '',
					'u_video_url'                    => '',
					'bg_cstm_size'                   => '',
					'bg_override'                    => '0',
					'bg_img_attach'                  => '',
					'u_start_time'                   => '',
					'u_stop_time'                    => '',
					'layer_image'                    => '',
					'bg_grad'                        => '',
					'bg_color_value'                 => '',
					'bg_fade'                        => '',
					'css'                            => '',
					'viewport_vdo'                   => '',
					'enable_controls'                => '',
					'controls_color'                 => '',
					'animation_direction'            => 'left-animation',
					'animation_type'                 => 'false',
					'horizontal_animation'           => '',
					'vertical_animation'             => '',
					'animation_speed'                => '',
					'animation_repeat'               => 'repeat',
					'animated_bg_color'              => '',
					'fadeout_row'                    => '',
					'fadeout_start_effect'           => '30',
					'parallax_content'               => '',
					'parallax_content_sense'         => '30',
					'disable_on_mobile'              => '',
					'disable_on_mobile_img_parallax' => 'off',
					'enable_overlay'                 => '',
					'overlay_color'                  => '',
					'overlay_pattern'                => '',
					'overlay_pattern_opacity'        => '80',
					'overlay_pattern_size'           => '',
					'overlay_pattern_attachment'     => 'scroll',
					'multi_color_overlay'            => '',
					'multi_color_overlay_opacity'    => '60',
					'seperator_enable'               => '',
					'seperator_type'                 => 'none_seperator',
					'seperator_position'             => 'top_seperator',
					'seperator_shape_size'           => '40',
					'seperator_shape_background'     => '#fff',
					'seperator_shape_border'         => 'none',
					'seperator_shape_border_color'   => '',
					'seperator_shape_border_width'   => '1',
					'seperator_svg_height'           => '60',
					'icon_type'                      => 'no_icon',
					'icon'                           => '',
					'icon_color'                     => '',
					'icon_style'                     => 'none',
					'icon_color_bg'                  => '',
					'icon_border_style'              => '',
					'icon_color_border'              => '#333333',
					'icon_border_size'               => '1',
					'icon_border_radius'             => '500',
					'icon_border_spacing'            => '50',
					'icon_img'                       => '',
					'img_width'                      => '48',
					'icon_size'                      => '32',
					'ult_hide_row'                   => '',
					'ult_hide_row_large_screen'      => '',
					'ult_hide_row_desktop'           => '',
					'ult_hide_row_tablet'            => '',
					'ult_hide_row_tablet_small'      => '',
					'ult_hide_row_mobile'            => '',
					'ult_hide_row_mobile_large'      => '',
					'video_fixer'                    => 'true',
				),
				$atts
			);

			if ( '' === $ult_parallax_settings['bg_type'] ) {
				$ult_parallax_settings['bg_type'] = 'no_bg';
			}
			if ( '' === $ult_parallax_settings['parallax_style'] ) {
				$ult_parallax_settings['parallax_style'] = 'vcpb-default';
			}
			if ( '' === $ult_parallax_settings['bg_image_repeat'] ) {
				$ult_parallax_settings['bg_image_repeat'] = 'repeat';
			}
			if ( '' === $ult_parallax_settings['bg_image_size'] ) {
				$ult_parallax_settings['bg_image_size'] = 'cover';
			}
			if ( '' === $ult_parallax_settings['bg_img_attach'] ) {
				$ult_parallax_settings['bg_img_attach'] = 'scroll';
			}

			$bsf_dev_mode = bsf_get_option( 'dev_mode' );
			if ( 'enable' === $bsf_dev_mode ) {
				$js_path  = UAVC_URL . 'assets/js/';
				$css_path = UAVC_URL . 'assets/css/';
				$ext      = '';
			} else {
				$js_path  = UAVC_URL . 'assets/min-js/';
				$css_path = UAVC_URL . 'assets/min-css/';
				$ext      = '.min';
			}

			/* enqueue scripts */
			if ( ( 'enable' == get_option( 'ultimate_row' ) && '' !== $ult_parallax_settings['bg_type'] ) || '' != $ult_parallax_settings['parallax_content'] || '' != $ult_parallax_settings['fadeout_row'] ) {

				$ultimate_js = get_option( 'ultimate_js' );

				if ( 'enable' != $ultimate_js ) :
					if ( 'no_bg' == $ult_parallax_settings['bg_type'] && ( '' != $ult_parallax_settings['parallax_content'] || '' != $ult_parallax_settings['fadeout_row'] ) ) { // @codingStandardsIgnoreLine.
					} elseif ( 'no_bg' != $ult_parallax_settings['bg_type'] && ( '' != $ult_parallax_settings['parallax_content'] || '' != $ult_parallax_settings['fadeout_row'] ) ) {
						wp_enqueue_script( 'ultimate-vc-addons-appear' );
						wp_enqueue_script( 'ultimate-vc-addons-row-bg', $js_path . 'ultimate_bg' . $ext . '.js', null, ULTIMATE_VERSION, false );
						wp_enqueue_script( 'ultimate-vc-addons-custom' );
					} elseif ( 'no_bg' != $ult_parallax_settings['bg_type'] && ( '' == $ult_parallax_settings['parallax_content'] || '' == $ult_parallax_settings['fadeout_row'] ) ) {
						wp_enqueue_script( 'ultimate-vc-addons-appear' );
						wp_enqueue_script( 'ultimate-vc-addons-row-bg', $js_path . 'ultimate_bg' . $ext . '.js', null, ULTIMATE_VERSION, false );
						wp_enqueue_script( 'ultimate-vc-addons-custom' );
					}
				endif;

				$html                   = '';
				$autoplay               = '';
				$muted                  = '';
				$loop                   = '';
				$pos_suffix             = '';
				$bg_img                 = '';
				$bg_img_id              = '';
				$icon_inline            = '';
				$commom_data_attributes = '';
				$vc_version             = '';

				$ultimate_custom_vc_row = get_option( 'ultimate_custom_vc_row' );
				$ultimate_theme_support = get_option( 'ultimate_theme_support' );

				if ( defined( 'WPB_VC_VERSION' ) ) {
					$vc_version = WPB_VC_VERSION;
				}

				$is_vc_4_4 = ( version_compare( $vc_version, '4.4', '<' ) ) ? true : false;

				$commom_data_attributes                        .= ' data-custom-vc-row="' . esc_attr( $ultimate_custom_vc_row ) . '" ';
				$commom_data_attributes                        .= ' data-vc="' . esc_attr( $vc_version ) . '" ';
				$commom_data_attributes                        .= ' data-is_old_vc="' . esc_attr( $is_vc_4_4 ) . '" ';
				$commom_data_attributes                        .= ' data-theme-support="' . esc_attr( $ultimate_theme_support ) . '" ';
					$ult_parallax_settings['disable_on_mobile'] = 'true';

				if ( 'off' == $ult_parallax_settings['disable_on_mobile_img_parallax'] || '' == $ult_parallax_settings['disable_on_mobile_img_parallax'] ) {
					$ult_parallax_settings['disable_on_mobile_img_parallax'] = 'true';
				} else {
					$ult_parallax_settings['disable_on_mobile_img_parallax'] = 'false';
				}
				// for overlay.
				if ( 'enable_overlay_value' == $ult_parallax_settings['enable_overlay'] ) {
					if ( 'transperant' != $ult_parallax_settings['overlay_pattern'] && '' != $ult_parallax_settings['overlay_pattern'] ) {
						$pattern_url = UAVC_URL . 'assets/images/patterns/' . $ult_parallax_settings['overlay_pattern'];
					} else {
						$pattern_url = '';
					}
					if ( preg_match( '/^#[a-f0-9]{6}$/i', $ult_parallax_settings['overlay_color'] ) ) { // hex color is valid.
						$ult_parallax_settings['overlay_color'] = hex2rgbUltParallax( $ult_parallax_settings['overlay_color'], $opacity = 0.2 );
					}

					if ( strpos( $ult_parallax_settings['overlay_pattern_opacity'], '.' ) === false ) {
						$ult_parallax_settings['overlay_pattern_opacity'] = $ult_parallax_settings['overlay_pattern_opacity'] / 100;
					}

					$overlay = ' data-overlay="true" data-overlay-color="' . esc_attr( $ult_parallax_settings['overlay_color'] ) . '" data-overlay-pattern="' . esc_attr( $pattern_url ) . '" data-overlay-pattern-opacity="' . esc_attr( $ult_parallax_settings['overlay_pattern_opacity'] ) . '" data-overlay-pattern-size="' . esc_attr( $ult_parallax_settings['overlay_pattern_size'] ) . '" data-overlay-pattern-attachment="' . esc_attr( $ult_parallax_settings['overlay_pattern_attachment'] ) . '" ';

					if ( 'uvc-multi-color-bg' == $ult_parallax_settings['multi_color_overlay'] ) {
						$ult_parallax_settings['multi_color_overlay_opacity'] = $ult_parallax_settings['multi_color_overlay_opacity'] / 100;
						$overlay .= ' data-multi-color-overlay="' . esc_attr( $ult_parallax_settings['multi_color_overlay'] ) . '" data-multi-color-overlay-opacity="' . esc_attr( $ult_parallax_settings['multi_color_overlay_opacity'] ) . '" ';
					}
				} else {
					$overlay = ' data-overlay="false" data-overlay-color="" data-overlay-pattern="" data-overlay-pattern-opacity="" data-overlay-pattern-size="" ';
				}

				// for seperator.
				if ( 'seperator_enable_value' == $ult_parallax_settings['seperator_enable'] ) {
					$seperator_bottom_html  = ' data-seperator="true" ';
					$seperator_bottom_html .= ' data-seperator-type="' . esc_attr( $ult_parallax_settings['seperator_type'] ) . '" ';
					$seperator_bottom_html .= ' data-seperator-shape-size="' . esc_attr( $ult_parallax_settings['seperator_shape_size'] ) . '" ';
					$seperator_bottom_html .= ' data-seperator-svg-height="' . esc_attr( $ult_parallax_settings['seperator_svg_height'] ) . '" ';
					$seperator_bottom_html .= ' data-seperator-full-width="true"';
					$seperator_bottom_html .= ' data-seperator-position="' . esc_attr( $ult_parallax_settings['seperator_position'] ) . '" ';

					if ( '' != $ult_parallax_settings['seperator_shape_background'] ) {
						if ( 'multi_triangle_seperator' == $ult_parallax_settings['seperator_type'] ) {
							preg_match( '/\(([^)]+)\)/', $ult_parallax_settings['seperator_shape_background'], $output_temp );
							if ( isset( $output_temp[1] ) ) {
								$rgba = explode( ',', $output_temp[1] );
								$ult_parallax_settings['seperator_shape_background'] = rgbaToHexUltimate( $rgba[0], $rgba[1], $rgba[2] );
							}
						}
						$seperator_bottom_html .= ' data-seperator-background-color="' . esc_attr( $ult_parallax_settings['seperator_shape_background'] ) . '" ';
					}
					if ( 'none' != $ult_parallax_settings['seperator_shape_border'] ) {
						$seperator_bottom_html .= ' data-seperator-border="' . esc_attr( $ult_parallax_settings['seperator_shape_border'] ) . '" ';
						$bwidth                 = ( '' == $ult_parallax_settings['seperator_shape_border_width'] ) ? '1' : $ult_parallax_settings['seperator_shape_border_width'];
						$seperator_bottom_html .= ' data-seperator-border-width="' . esc_attr( $bwidth ) . '" ';
						$seperator_bottom_html .= ' data-seperator-border-color="' . esc_attr( $ult_parallax_settings['seperator_shape_border_color'] ) . '" ';
					}

					if ( 'no_icon' != $ult_parallax_settings['icon_type'] ) {
						$icon_animation = '';
						$alignment      = 'center';
						$icon_inline    = do_shortcode( '[just_icon icon_align="' . esc_attr( $alignment ) . '" icon_type="' . esc_attr( $ult_parallax_settings['icon_type'] ) . '" icon="' . esc_attr( $ult_parallax_settings['icon'] ) . '" icon_img="' . esc_attr( $ult_parallax_settings['icon_img'] ) . '" img_width="' . esc_attr( $ult_parallax_settings['img_width'] ) . '" icon_size="' . esc_attr( $ult_parallax_settings['icon_size'] ) . '" icon_color="' . esc_attr( $ult_parallax_settings['icon_color'] ) . '" icon_style="' . esc_attr( $ult_parallax_settings['icon_style'] ) . '" icon_color_bg="' . esc_attr( $ult_parallax_settings['icon_color_bg'] ) . '" icon_color_border="' . esc_attr( $ult_parallax_settings['icon_color_border'] ) . '"  icon_border_style="' . esc_attr( $ult_parallax_settings['icon_border_style'] ) . '" icon_border_size="' . esc_attr( $ult_parallax_settings['icon_border_size'] ) . '" icon_border_radius="' . esc_attr( $ult_parallax_settings['icon_border_radius'] ) . '" icon_border_spacing="' . esc_attr( $ult_parallax_settings['icon_border_spacing'] ) . '" icon_animation="' . esc_attr( $icon_animation ) . '"]' );
					}
					$seperator_bottom_html .= ' data-icon="' . htmlentities( $icon_inline ) . '" '; // @codingStandardsIgnoreLine.
				}

				$seperator_html = $seperator_top_html . ' ' . $seperator_bottom_html;

				// for hide row.
				$device_message    = '';
				$ult_hide_row_data = '';
				if ( 'ult_hide_row_value' == $ult_parallax_settings['ult_hide_row'] ) {
					if ( 'large_screen' == $ult_parallax_settings['ult_hide_row_large_screen'] ) {
						$ult_hide_row_data .= ' uvc_hidden-lg ';
					}
					if ( 'desktop' == $ult_parallax_settings['ult_hide_row_desktop'] ) {
						$ult_hide_row_data .= ' uvc_hidden-ml ';
					}
					if ( 'tablet' == $ult_parallax_settings['ult_hide_row_tablet'] ) {
						$ult_hide_row_data .= ' uvc_hidden-md ';
					}
					if ( 'xs_tablet' == $ult_parallax_settings['ult_hide_row_tablet_small'] ) {
						$ult_hide_row_data .= ' uvc_hidden-sm ';
					}
					if ( 'mobile' == $ult_parallax_settings['ult_hide_row_mobile'] ) {
						$ult_hide_row_data .= ' uvc_hidden-xs ';
					}
					if ( 'xl_mobile' == $ult_parallax_settings['ult_hide_row_mobile_large'] ) {
						$ult_hide_row_data .= ' uvc_hidden-xsl ';
					}

					if ( '' != $ult_hide_row_data ) {
						$ult_hide_row_data = ' data-hide-row="' . esc_attr( $ult_hide_row_data ) . '" ';
					}
				}

				// RTL.
				$rtl = 'false';
				if ( is_rtl() ) {
					$rtl = 'true';
				}
				if ( 'false' === $rtl || false === $rtl ) {
					$ultimate_rtl_support = get_option( 'ultimate_rtl_support' );
					if ( 'enable' == $ultimate_rtl_support ) {
						$rtl = 'true';
					}
				}

				$output = '<!-- Row Backgrounds -->';
				if ( '' != $ult_parallax_settings['bg_image_new'] ) {
					$bg_img_id = $ult_parallax_settings['bg_image_new'];
				} elseif ( '' != $ult_parallax_settings['bg_image'] ) {
					$bg_img_id = $ult_parallax_settings['bg_image'];
				} else {
					if ( '' !== $ult_parallax_settings['css'] ) {
						$arr = explode( '?id=', $ult_parallax_settings['css'] );
						if ( isset( $arr[1] ) ) {
							$arr       = explode( ')', $arr[1] );
							$bg_img_id = $arr[0];
						}
					}
				}
				if ( '' != $ult_parallax_settings['bg_image_posiiton'] ) {
					if ( strpos( $ult_parallax_settings['bg_image_posiiton'], 'px' ) ) {
						$pos_suffix = 'px';
					} elseif ( strpos( $ult_parallax_settings['bg_image_posiiton'], 'em' ) ) {
						$pos_suffix = 'em';
					} else {
						$pos_suffix = '%';
					}
				}
				if ( 'no_bg' == $ult_parallax_settings['bg_type'] ) { // @codingStandardsIgnoreLine.
				} elseif ( 'image' == $ult_parallax_settings['bg_type'] ) {
					if ( 'cstm' == $ult_parallax_settings['bg_image_size'] ) {
						if ( '' != $ult_parallax_settings['bg_cstm_size'] ) {
							$ult_parallax_settings['bg_image_size'] = $ult_parallax_settings['bg_cstm_size'];
						}
					}
					if ( 'vcpb-fs-jquery' == $ult_parallax_settings['parallax_style'] || 'vcpb-mlvp-jquery' == $ult_parallax_settings['parallax_style'] ) {
						if ( 'vcpb-fs-jquery' == $ult_parallax_settings['parallax_style'] ) {
							wp_enqueue_script( 'ultimate-vc-addons-jquery.shake', $js_path . 'jparallax' . $ext . '.js', null, ULTIMATE_VERSION, false );
						}

						if ( 'vcpb-mlvp-jquery' == $ult_parallax_settings['parallax_style'] ) {
							wp_enqueue_script( 'ultimate-vc-addons-jquery.vhparallax', $js_path . 'vhparallax' . $ext . '.js', null, ULTIMATE_VERSION, false );
						}
						$imgs                                 = explode( ',', $ult_parallax_settings['layer_image'] );
						$ult_parallax_settings['layer_image'] = array();
						foreach ( $imgs as $value ) {
							$ult_parallax_settings['layer_image'][] = wp_get_attachment_image_src( $value, 'full' );
						}
						foreach ( $ult_parallax_settings['layer_image'] as $key => $value ) {
							$bg_imgs[] = $ult_parallax_settings['layer_image'][ $key ][0];
						}
						$html .= '<div class="upb_bg_img" data-ultimate-bg="' . esc_attr( implode( ',', $bg_imgs ) ) . '" data-ultimate-bg-style="' . esc_attr( $ult_parallax_settings['parallax_style'] ) . '" data-bg-img-repeat="' . esc_attr( $ult_parallax_settings['bg_image_repeat'] ) . '" data-bg-img-size="' . esc_attr( $ult_parallax_settings['bg_image_size'] ) . '" data-bg-img-position="' . esc_attr( $ult_parallax_settings['bg_image_posiiton'] ) . '" data-parallx_sense="' . esc_attr( $ult_parallax_settings['parallax_sense'] ) . '" data-bg-override="' . esc_attr( $ult_parallax_settings['bg_override'] ) . '" data-bg_img_attach="' . esc_attr( $ult_parallax_settings['bg_img_attach'] ) . '" data-upb-overlay-color="' . esc_attr( $ult_parallax_settings['overlay_color'] ) . '" data-upb-bg-animation="' . esc_attr( $ult_parallax_settings['bg_fade'] ) . '" data-fadeout="' . esc_attr( $ult_parallax_settings['fadeout_row'] ) . '" data-fadeout-percentage="' . esc_attr( $ult_parallax_settings['fadeout_start_effect'] ) . '" data-parallax-content="' . esc_attr( $ult_parallax_settings['parallax_content'] ) . '" data-parallax-content-sense="' . esc_attr( $ult_parallax_settings['parallax_content_sense'] ) . '" data-row-effect-mobile-disable="' . esc_attr( $ult_parallax_settings['disable_on_mobile'] ) . '" data-img-parallax-mobile-disable="' . esc_attr( $ult_parallax_settings['disable_on_mobile_img_parallax'] ) . '" data-rtl="' . esc_attr( $rtl ) . '" ' . $commom_data_attributes . ' ' . $overlay . ' ' . $seperator_html . ' ' . $ult_hide_row_data . '></div>';
					} else {
						if ( 'vcpb-vz-jquery' == $ult_parallax_settings['parallax_style'] || 'vcpb-hz-jquery' == $ult_parallax_settings['parallax_style'] ) {
							wp_enqueue_script( 'ultimate-vc-addons-jquery.vhparallax', $js_path . 'vhparallax' . $ext . '.js', null, ULTIMATE_VERSION, false );
						}

						if ( $bg_img_id ) {
							if ( '' == $ult_parallax_settings['animation_direction'] && 'false' != $ult_parallax_settings['animation_type'] ) {
								if ( 'h' == $ult_parallax_settings['animation_type'] ) {
									$animation = $ult_parallax_settings['horizontal_animation'];
								} else {
									$animation = $ult_parallax_settings['vertical_animation'];
								}
							} else {
								if ( 'top-animation' == $ult_parallax_settings['animation_direction'] || 'bottom-animation' == $ult_parallax_settings['animation_direction'] ) {
									$ult_parallax_settings['animation_type'] = 'v';
								} else {
									$ult_parallax_settings['animation_type'] = 'h';
								}
									$animation = $ult_parallax_settings['animation_direction'];
								if ( '' == $animation ) {
									$animation = 'left-animation';
								}
							}

							$bg_img = apply_filters( 'ult_get_img_single', $bg_img_id, 'url' );
							$html  .= '<div class="upb_bg_img" data-ultimate-bg="url(' . esc_url( $bg_img ) . ')" data-image-id="' . esc_attr( $bg_img_id ) . '" data-ultimate-bg-style="' . esc_attr( $ult_parallax_settings['parallax_style'] ) . '" data-bg-img-repeat="' . esc_attr( $ult_parallax_settings['bg_image_repeat'] ) . '" data-bg-img-size="' . esc_attr( $ult_parallax_settings['bg_image_size'] ) . '" data-bg-img-position="' . esc_attr( $ult_parallax_settings['bg_image_posiiton'] ) . '" data-parallx_sense="' . esc_attr( $ult_parallax_settings['parallax_sense'] ) . '" data-bg-override="' . esc_attr( $ult_parallax_settings['bg_override'] ) . '" data-bg_img_attach="' . esc_attr( $ult_parallax_settings['bg_img_attach'] ) . '" data-upb-overlay-color="' . esc_attr( $ult_parallax_settings['overlay_color'] ) . '" data-upb-bg-animation="' . esc_attr( $ult_parallax_settings['bg_fade'] ) . '" data-fadeout="' . esc_attr( $ult_parallax_settings['fadeout_row'] ) . '" data-bg-animation="' . esc_attr( $animation ) . '" data-bg-animation-type="' . esc_attr( $ult_parallax_settings['animation_type'] ) . '" data-animation-repeat="' . esc_attr( $ult_parallax_settings['animation_repeat'] ) . '" data-fadeout-percentage="' . esc_attr( $ult_parallax_settings['fadeout_start_effect'] ) . '" data-parallax-content="' . esc_attr( $ult_parallax_settings['parallax_content'] ) . '" data-parallax-content-sense="' . esc_attr( $ult_parallax_settings['parallax_content_sense'] ) . '" data-row-effect-mobile-disable="' . esc_attr( $ult_parallax_settings['disable_on_mobile'] ) . '" data-img-parallax-mobile-disable="' . esc_attr( $ult_parallax_settings['disable_on_mobile_img_parallax'] ) . '" data-rtl="' . esc_attr( $rtl ) . '" ' . $commom_data_attributes . ' ' . $overlay . ' ' . $seperator_html . ' ' . $ult_hide_row_data . '></div>';
						}
					}
				} elseif ( 'video' == $ult_parallax_settings['bg_type'] ) {
					$v_opts = explode( ',', $ult_parallax_settings['video_opts'] );
					if ( is_array( $v_opts ) ) {
						foreach ( $v_opts as $opt ) {
							if ( 'muted' == $opt ) {
								$muted .= $opt;
							}
							if ( 'autoplay' == $opt ) {
								$autoplay .= $opt;
							}
							if ( 'loop' == $opt ) {
								$loop .= $opt;
							}
						}
					}
					if ( 'viewport_play' == $ult_parallax_settings['viewport_vdo'] ) {
						$enable_viewport_vdo = 'true';
					} else {
						$enable_viewport_vdo = 'false';
					}

					$video_fixer_option = get_option( 'ultimate_video_fixer' );
					if ( $video_fixer_option ) {
						if ( 'enable' == $video_fixer_option ) {
							$ult_parallax_settings['video_fixer'] = 'false';
						}
					}

					$ult_parallax_settings['u_stop_time']  = ( '' != $ult_parallax_settings['u_stop_time'] ) ? $ult_parallax_settings['u_stop_time'] : 0;
					$ult_parallax_settings['u_start_time'] = ( '' != $ult_parallax_settings['u_stop_time'] ) ? $ult_parallax_settings['u_start_time'] : 0;
					$v_img                                 = apply_filters( 'ult_get_img_single', $ult_parallax_settings['video_poster'], 'url' );
					$html                                 .= '<div class="upb_content_video" data-controls-color="' . esc_attr( $ult_parallax_settings['controls_color'] ) . '" data-controls="' . esc_attr( $ult_parallax_settings['enable_controls'] ) . '" data-viewport-video="' . esc_attr( $enable_viewport_vdo ) . '" data-ultimate-video="' . esc_attr( $ult_parallax_settings['video_url'] ) . '" data-ultimate-video2="' . esc_attr( $ult_parallax_settings['video_url_2'] ) . '" data-ultimate-video-muted="' . esc_attr( $muted ) . '" data-ultimate-video-loop="' . esc_attr( $loop ) . '" data-ultimate-video-poster="' . esc_attr( $v_img ) . '" data-ultimate-video-autoplay="autoplay" data-bg-override="' . esc_attr( $ult_parallax_settings['bg_override'] ) . '" data-upb-overlay-color="' . esc_attr( $ult_parallax_settings['overlay_color'] ) . '" data-upb-bg-animation="' . esc_attr( $ult_parallax_settings['bg_fade'] ) . '" data-fadeout="' . esc_attr( $ult_parallax_settings['fadeout_row'] ) . '" data-fadeout-percentage="' . esc_attr( $ult_parallax_settings['fadeout_start_effect'] ) . '" data-parallax-content="' . esc_attr( $ult_parallax_settings['parallax_content'] ) . '" data-parallax-content-sense="' . esc_attr( $ult_parallax_settings['parallax_content_sense'] ) . '" data-row-effect-mobile-disable="' . esc_attr( $ult_parallax_settings['disable_on_mobile'] ) . '" data-rtl="' . esc_attr( $rtl ) . '" data-img-parallax-mobile-disable="' . esc_attr( $ult_parallax_settings['disable_on_mobile_img_parallax'] ) . '" ' . $commom_data_attributes . ' ' . $overlay . ' ' . $seperator_html . ' ' . $ult_hide_row_data . ' data-video_fixer="' . esc_attr( $ult_parallax_settings['video_fixer'] ) . '"></div>';

					if ( 'display_control' == $ult_parallax_settings['enable_controls'] ) {
						wp_enqueue_style( 'ultimate-vc-addons-vidcons', UAVC_URL . 'assets/fonts/vidcons.css', null, ULTIMATE_VERSION );
					}
				} elseif ( 'u_iframe' == $ult_parallax_settings['bg_type'] ) {
					wp_enqueue_script( 'ultimate-vc-addons-jquery.ytplayer', $js_path . 'mb-YTPlayer' . $ext . '.js', null, ULTIMATE_VERSION, false );
					$v_opts = explode( ',', $ult_parallax_settings['video_opts'] );
					$v_img  = apply_filters( 'ult_get_img_single', $ult_parallax_settings['video_poster'], 'url' );
					if ( is_array( $v_opts ) ) {
						foreach ( $v_opts as $opt ) {
							if ( 'muted' == $opt ) {
								$muted .= $opt;
							}
							if ( 'autoplay' == $opt ) {
								$autoplay .= $opt;
							}
							if ( 'loop' == $opt ) {
								$loop .= $opt;
							}
						}
					}
					if ( 'viewport_play' === $ult_parallax_settings['viewport_vdo'] ) {
						$enable_viewport_vdo = 'true';
					} else {
						$enable_viewport_vdo = 'false';
					}

					$video_fixer_option = get_option( 'ultimate_video_fixer' );
					if ( $video_fixer_option ) {
						if ( 'enable' == $video_fixer_option ) {
							$ult_parallax_settings['video_fixer'] = 'false';
						}
					}

					$html .= '<div class="upb_content_iframe" data-controls="' . esc_attr( $ult_parallax_settings['enable_controls'] ) . '" data-viewport-video="' . esc_attr( $enable_viewport_vdo ) . '" data-ultimate-video="' . esc_attr( $ult_parallax_settings['u_video_url'] ) . '" data-bg-override="' . esc_attr( $ult_parallax_settings['bg_override'] ) . '" data-start-time="' . esc_attr( $ult_parallax_settings['u_start_time'] ) . '" data-stop-time="' . esc_attr( $ult_parallax_settings['u_stop_time'] ) . '" data-ultimate-video-muted="' . esc_attr( $muted ) . '" data-ultimate-video-loop="' . esc_attr( $loop ) . '" data-ultimate-video-poster="' . esc_attr( $v_img ) . '" data-upb-overlay-color="' . esc_attr( $ult_parallax_settings['overlay_color'] ) . '" data-upb-bg-animation="' . esc_attr( $ult_parallax_settings['bg_fade'] ) . '" data-fadeout="' . esc_attr( $ult_parallax_settings['fadeout_row'] ) . '" data-fadeout-percentage="' . esc_attr( $ult_parallax_settings['fadeout_start_effect'] ) . '"  data-parallax-content="' . esc_attr( $ult_parallax_settings['parallax_content'] ) . '" data-parallax-content-sense="' . esc_attr( $ult_parallax_settings['parallax_content_sense'] ) . '" data-row-effect-mobile-disable="' . esc_attr( $ult_parallax_settings['disable_on_mobile'] ) . '" data-img-parallax-mobile-disable="' . esc_attr( $ult_parallax_settings['disable_on_mobile_img_parallax'] ) . '" data-rtl="' . esc_attr( $rtl ) . '" ' . $commom_data_attributes . ' ' . $overlay . ' ' . $seperator_html . ' ' . $ult_hide_row_data . ' data-video_fixer="' . esc_attr( $ult_parallax_settings['video_fixer'] ) . '"></div>';
				} elseif ( 'grad' == $ult_parallax_settings['bg_type'] ) {
					$html .= '<div class="upb_grad" data-grad="' . esc_attr( $ult_parallax_settings['bg_grad'] ) . '" data-bg-override="' . esc_attr( $ult_parallax_settings['bg_override'] ) . '" data-upb-overlay-color="' . esc_attr( $ult_parallax_settings['overlay_color'] ) . '" data-upb-bg-animation="' . esc_attr( $ult_parallax_settings['bg_fade'] ) . '" data-fadeout="' . esc_attr( $ult_parallax_settings['fadeout_row'] ) . '" data-fadeout-percentage="' . esc_attr( $ult_parallax_settings['fadeout_start_effect'] ) . '" data-parallax-content="' . esc_attr( $ult_parallax_settings['parallax_content'] ) . '" data-parallax-content-sense="' . esc_attr( $ult_parallax_settings['parallax_content_sense'] ) . '" data-row-effect-mobile-disable="' . esc_attr( $ult_parallax_settings['disable_on_mobile'] ) . '" data-img-parallax-mobile-disable="' . esc_attr( $ult_parallax_settings['disable_on_mobile_img_parallax'] ) . '" data-rtl="' . esc_attr( $rtl ) . '" ' . $commom_data_attributes . ' ' . $overlay . ' ' . $seperator_html . ' ' . $ult_hide_row_data . '></div>';
				} elseif ( 'bg_color' == $ult_parallax_settings['bg_type'] ) {
					$html .= '<div class="upb_color" data-bg-override="' . esc_attr( $ult_parallax_settings['bg_override'] ) . '" data-bg-color="' . esc_attr( $ult_parallax_settings['bg_color_value'] ) . '" data-fadeout="' . esc_attr( $ult_parallax_settings['fadeout_row'] ) . '" data-fadeout-percentage="' . esc_attr( $ult_parallax_settings['fadeout_start_effect'] ) . '" data-parallax-content="' . esc_attr( $ult_parallax_settings['parallax_content'] ) . '" data-parallax-content-sense="' . esc_attr( $ult_parallax_settings['parallax_content_sense'] ) . '" data-row-effect-mobile-disable="' . esc_attr( $ult_parallax_settings['disable_on_mobile'] ) . '" data-img-parallax-mobile-disable="' . esc_attr( $ult_parallax_settings['disable_on_mobile_img_parallax'] ) . '" data-rtl="' . esc_attr( $rtl ) . '" ' . $commom_data_attributes . ' ' . $overlay . ' ' . $seperator_html . ' ' . $ult_hide_row_data . '></div>';
				}
				$output .= $html;
				if ( 'no_bg' == $ult_parallax_settings['bg_type'] ) {
					return '';
				} else {
					self::front_scripts();
					return $output;
				}
			}
		} /* end parallax_shortcode */
		/**
		 * Initialize the parallax.
		 *
		 * @since ----
		 * @access public
		 */
		public function parallax_init() {
			$group_name    = 'Background';
			$group_effects = 'Effect';
			if ( function_exists( 'vc_remove_param' ) ) {
				vc_remove_param( 'vc_row', 'bg_image_repeat' );
			}

			$pluginname = dirname( dirname( plugin_basename( __FILE__ ) ) );

			$patterns_path = realpath( dirname( plugin_dir_path( __FILE__ ) ) . '/assets/images/patterns' );
			$patterns_list = glob( $patterns_path . '/*.*' );
			$patterns      = array();

			foreach ( $patterns_list as $pattern ) {
				$patterns[ basename( $pattern ) ] = UAVC_URL . '/assets/images/patterns/' . basename( $pattern );
			}
			if ( function_exists( 'vc_add_param' ) ) {
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'dropdown',
						'class'       => '',
						'admin_label' => true,
						'heading'     => __( 'Background Style', 'ultimate_vc' ),
						'param_name'  => 'bg_type',
						'value'       => array(
							__( 'Default', 'ultimate_vc' ) => '',
							__( 'Single Color', 'ultimate_vc' ) => 'bg_color',
							__( 'Gradient Color', 'ultimate_vc' ) => 'grad',
							__( 'Image / Parallax', 'ultimate_vc' ) => 'image',
							__( 'YouTube Video', 'ultimate_vc' ) => 'u_iframe',
							__( 'Hosted Video', 'ultimate_vc' ) => 'video',
						),
						'description' => __( 'Select the kind of background would you like to set for this row.', 'ultimate_vc' ) . ' ' . __( 'Not sure?', 'ultimate_vc' ) . ' ' . __( 'See Narrated', 'ultimate_vc' ) . " <a href='https://www.youtube.com/watch?v=Qxs8R-uaMWk&list=PL1kzJGWGPrW981u5caHy6Kc9I1bG1POOx' target='_blank' rel='noopener'>" . __( 'Video Tutorials', 'ultimate_vc' ) . '</a>',
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'gradient',
						'class'       => '',
						'heading'     => __( 'Gradient Type', 'ultimate_vc' ),
						'param_name'  => 'bg_grad',
						'description' => __( 'At least two color points should be selected.', 'ultimate_vc' ) . ' <a href="https://www.youtube.com/watch?v=yE1M4AKwS44" target="_blank" rel="noopener">' . __( 'Video Tutorial', 'ultimate_vc' ) . '</a>',
						'dependency'  => array(
							'element' => 'bg_type',
							'value'   => array( 'grad' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'       => 'colorpicker',
						'class'      => '',
						'heading'    => __( 'Background Color', 'ultimate_vc' ),
						'param_name' => 'bg_color_value',
						'dependency' => array(
							'element' => 'bg_type',
							'value'   => array( 'bg_color' ),
						),
						'group'      => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'dropdown',
						'class'       => '',
						'heading'     => __( 'Parallax Style', 'ultimate_vc' ),
						'param_name'  => 'parallax_style',
						'value'       => array(
							__( 'No Parallax', 'ultimate_vc' ) => '',
							__( 'Simple Background Image', 'ultimate_vc' ) => 'vcpb-default',
							__( 'Auto Moving Background', 'ultimate_vc' ) => 'vcpb-animated',
							__( 'Vertical Parallax On Scroll', 'ultimate_vc' ) => 'vcpb-vz-jquery',
							__( 'Horizontal Parallax On Scroll', 'ultimate_vc' ) => 'vcpb-hz-jquery',
							__( 'Interactive Parallax On Mouse Hover', 'ultimate_vc' ) => 'vcpb-fs-jquery',
							__( 'Multilayer Vertical Parallax', 'ultimate_vc' ) => 'vcpb-mlvp-jquery',
						),
						'description' => __( 'Select the kind of style you like for the background.', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'bg_type',
							'value'   => array( 'image' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'ult_img_single',
						'class'       => '',
						'heading'     => __( 'Background Image', 'ultimate_vc' ),
						'param_name'  => 'bg_image_new',
						'value'       => '',
						'description' => __( 'Upload or select background image from media gallery.', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'parallax_style',
							'value'   => array( 'vcpb-default', 'vcpb-animated', 'vcpb-vz-jquery', 'vcpb-hz-jquery' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'attach_images',
						'class'       => '',
						'heading'     => __( 'Layer Images', 'ultimate_vc' ),
						'param_name'  => 'layer_image',
						'value'       => '',
						'description' => __( 'Upload or select background images from media gallery.', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'parallax_style',
							'value'   => array( 'vcpb-fs-jquery', 'vcpb-mlvp-jquery' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'dropdown',
						'class'       => '',
						'heading'     => __( 'Background Image Repeat', 'ultimate_vc' ),
						'param_name'  => 'bg_image_repeat',
						'value'       => array(
							__( 'Repeat', 'ultimate_vc' ) => '',
							__( 'Repeat X', 'ultimate_vc' ) => 'repeat-x',
							__( 'Repeat Y', 'ultimate_vc' ) => 'repeat-y',
							__( 'No Repeat', 'ultimate_vc' ) => 'no-repeat',
						),
						'description' => __( 'Options to control repeatation of the background image.', 'ultimate_vc' ) . ' ' . __( 'Learn on', 'ultimate_vc' ) . " <a href='http://www.w3schools.com/cssref/playit.asp?filename=playcss_background-repeat' target='_blank' rel='noopener'>" . __( 'W3School', 'ultimate_vc' ) . '</a>',
						'dependency'  => array(
							'element' => 'parallax_style',
							'value'   => array( 'vcpb-default', 'vcpb-fix', 'vcpb-vz-jquery', 'vcpb-hz-jquery' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'dropdown',
						'class'       => '',
						'heading'     => __( 'Background Image Size', 'ultimate_vc' ),
						'param_name'  => 'bg_image_size',
						'value'       => array(
							__( 'Cover - Image to be as large as possible', 'ultimate_vc' ) => '',
							__( 'Contain - Image will try to fit inside the container area', 'ultimate_vc' ) => 'contain',
							__( 'Initial', 'ultimate_vc' ) => 'initial',
						),
						'description' => __( 'Options to control repeatation of the background image.', 'ultimate_vc' ) . ' ' . __( 'Learn on', 'ultimate_vc' ) . " <a href='http://www.w3schools.com/cssref/playit.asp?filename=playcss_background-size&preval=50%25' target='_blank' rel='noopener'>" . __( 'W3School', 'ultimate_vc' ) . '</a>',
						'dependency'  => array(
							'element' => 'parallax_style',
							'value'   => array( 'vcpb-default', 'vcpb-animated', 'vcpb-fix', 'vcpb-vz-jquery', 'vcpb-hz-jquery' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'textfield',
						'class'       => '',
						'heading'     => __( 'Custom Background Image Size', 'ultimate_vc' ),
						'param_name'  => 'bg_cstm_size',
						'value'       => '',
						'description' => __( 'You can use initial, inherit or any number with px, em, %, etc. Example- 100px 100px', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'bg_image_size',
							'value'   => array( 'cstm' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'dropdown',
						'class'       => '',
						'heading'     => __( 'Scroll Effect', 'ultimate_vc' ),
						'param_name'  => 'bg_img_attach',
						'value'       => array(
							__( 'Move with the content', 'ultimate_vc' ) => '',
							__( 'Fixed at its position', 'ultimate_vc' ) => 'fixed',
						),
						'description' => __( 'Options to set whether a background image is fixed or scroll with the rest of the page.', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'parallax_style',
							'value'   => array( 'vcpb-default', 'vcpb-animated', 'vcpb-hz-jquery', 'vcpb-vz-jquery' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'number',
						'class'       => '',
						'heading'     => __( 'Parallax Speed', 'ultimate_vc' ),
						'param_name'  => 'parallax_sense',
						'value'       => '',
						'max'         => '100',
						'description' => __( 'Control speed of parallax. Enter value between 1 to 100 (Default 30)', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'parallax_style',
							'value'   => array( 'vcpb-vz-jquery', 'vcpb-animated', 'vcpb-hz-jquery', 'vcpb-vs-jquery', 'vcpb-hs-jquery', 'vcpb-fs-jquery', 'vcpb-mlvp-jquery' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'textfield',
						'class'       => '',
						'heading'     => __( 'Background Image Position', 'ultimate_vc' ),
						'param_name'  => 'bg_image_posiiton',
						'value'       => '',
						'description' => __( 'You can use any number with px, em, %, etc. Example- 100px 100px.', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'parallax_style',
							'value'   => array( 'vcpb-default', 'vcpb-fix' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'       => 'dropdown',
						'class'      => '',
						'heading'    => __( 'Animation Direction', 'ultimate_vc' ),
						'param_name' => 'animation_direction',
						'value'      => array(
							__( 'Left to Right', 'ultimate_vc' ) => '',
							__( 'Right to Left', 'ultimate_vc' ) => 'right-animation',
							__( 'Top to Bottom', 'ultimate_vc' ) => 'top-animation',
							__( 'Bottom to Top', 'ultimate_vc' ) => 'bottom-animation',

						),
						'dependency' => array(
							'element' => 'parallax_style',
							'value'   => array( 'vcpb-animated' ),
						),
						'group'      => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'       => 'dropdown',
						'class'      => '',
						'heading'    => __( 'Background Repeat', 'ultimate_vc' ),
						'param_name' => 'animation_repeat',
						'value'      => array(
							__( 'Repeat', 'ultimate_vc' ) => '',
							__( 'Repeat X', 'ultimate_vc' ) => 'repeat-x',
							__( 'Repeat Y', 'ultimate_vc' ) => 'repeat-y',
						),
						'dependency' => array(
							'element' => 'parallax_style',
							'value'   => array( 'vcpb-animated' ),
						),
						'group'      => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'       => 'textfield',
						'class'      => '',
						'heading'    => __( 'Link to the video in MP4 Format', 'ultimate_vc' ),
						'param_name' => 'video_url',
						'value'      => '',
						'dependency' => array(
							'element' => 'bg_type',
							'value'   => array( 'video' ),
						),
						'group'      => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'textfield',
						'class'       => '',
						'heading'     => __( 'Link to the video in WebM / Ogg Format', 'ultimate_vc' ),
						'param_name'  => 'video_url_2',
						'value'       => '',
						'description' => __( 'IE, Chrome & Safari', 'ultimate_vc' ) . " <a href='http://www.w3schools.com/html/html5_video.asp' target='_blank' rel='noopener'>" . __( 'support', 'ultimate_vc' ) . '</a> ' . __( 'MP4 format, while Firefox & Opera prefer WebM / Ogg formats.', 'ultimate_vc' ) . ' ' . __( 'You can upload the video through', 'ultimate_vc' ) . " <a href='" . home_url() . "/wp-admin/media-new.php' target='_blank' rel='noopener'>" . __( 'WordPress Media Library', 'ultimate_vc' ) . '</a>.',
						'dependency'  => array(
							'element' => 'bg_type',
							'value'   => array( 'video' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'textfield',
						'class'       => '',
						'heading'     => __( 'Enter YouTube URL of the Video', 'ultimate_vc' ),
						'param_name'  => 'u_video_url',
						'value'       => '',
						'description' => __( 'Enter YouTube url. Example - YouTube (https://www.youtube.com/watch?v=tSqJIIcxKZM) ', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'bg_type',
							'value'   => array( 'u_iframe' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'checkbox',
						'class'       => '',
						'heading'     => __( 'Extra Options', 'ultimate_vc' ),
						'param_name'  => 'video_opts',
						'value'       => array(
							__( 'Loop', 'ultimate_vc' )  => 'loop',
							__( 'Muted', 'ultimate_vc' ) => 'muted',
						),
						'description' => __( 'Muted autoplay is always allowed in chrome.', 'upb_parallax' ) . " <a href='https://developers.google.com/web/updates/2017/09/autoplay-policy-changes' target='_blank' rel='noopener'>" . __( 'Refer this link', 'upb_parallax' ) . '</a>.',
						'dependency'  => array(
							'element' => 'bg_type',
							'value'   => array( 'video', 'u_iframe' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'ult_img_single',
						'class'       => '',
						'heading'     => __( 'Placeholder Image', 'ultimate_vc' ),
						'param_name'  => 'video_poster',
						'value'       => '',
						'description' => __( 'Placeholder image is displayed in case background videos are restricted (Ex - on iOS devices).', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'bg_type',
							'value'   => array( 'video', 'u_iframe' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'       => 'number',
						'class'      => '',
						'heading'    => __( 'Start Time', 'ultimate_vc' ),
						'param_name' => 'u_start_time',
						'value'      => '',
						'suffix'     => 'seconds',
						'dependency' => array(
							'element' => 'bg_type',
							'value'   => array( 'u_iframe' ),
						),
						'group'      => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'number',
						'class'       => '',
						'heading'     => __( 'Stop Time', 'ultimate_vc' ),
						'param_name'  => 'u_stop_time',
						'value'       => '',
						'suffix'      => 'seconds',
						'description' => __( 'You may start / stop the video at any point you would like.', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'bg_type',
							'value'   => array( 'u_iframe' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'ult_switch',
						'class'       => '',
						'heading'     => __( 'Play video only when in viewport', 'ultimate_vc' ),
						'param_name'  => 'viewport_vdo',
						'value'       => '',
						'options'     => array(
							'viewport_play' => array(
								'label' => '',
								'on'    => __( 'Yes', 'ultimate_vc' ),
								'off'   => __( 'No', 'ultimate_vc' ),
							),
						),
						'description' => __( 'Video will be played only when user is on the particular screen position. Once user scroll away, the video will pause.', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'bg_type',
							'value'   => array( 'video', 'u_iframe' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'ult_switch',
						'class'       => '',
						'heading'     => __( 'Display Controls', 'ultimate_vc' ),
						'param_name'  => 'enable_controls',
						'value'       => '',
						'options'     => array(
							'display_control' => array(
								'label' => '',
								'on'    => __( 'Yes', 'ultimate_vc' ),
								'off'   => __( 'No', 'ultimate_vc' ),
							),
						),
						'description' => __( 'Display play / pause controls for the video on bottom right position.', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'bg_type',
							'value'   => array( 'video' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'colorpicker',
						'class'       => '',
						'heading'     => __( 'Color of Controls Icon', 'ultimate_vc' ),
						'param_name'  => 'controls_color',
						'description' => __( 'Display play / pause controls for the video on bottom right position.', 'upb_parallax' ),
						'dependency'  => array(
							'element' => 'enable_controls',
							'value'   => array( 'display_control' ),
						),
						'group'       => $group_name,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'dropdown',
						'class'       => '',
						'heading'     => __( 'Background Override (Read Description)', 'ultimate_vc' ),
						'param_name'  => 'bg_override',
						'value'       => array(
							__( 'Default Width', 'ultimate_vc' ) => '',
							__( "Apply 1st parent element's width", 'ultimate_vc' ) => '1',
							__( "Apply 2nd parent element's width", 'ultimate_vc' ) => '2',
							__( "Apply 3rd parent element's width", 'ultimate_vc' ) => '3',
							__( "Apply 4th parent element's width", 'ultimate_vc' ) => '4',
							__( "Apply 5th parent element's width", 'ultimate_vc' ) => '5',
							__( "Apply 6th parent element's width", 'ultimate_vc' ) => '6',
							__( "Apply 7th parent element's width", 'ultimate_vc' ) => '7',
							__( "Apply 8th parent element's width", 'ultimate_vc' ) => '8',
							__( "Apply 9th parent element's width", 'ultimate_vc' ) => '9',
							__( 'Full Width', 'ultimate_vc' ) => 'full',
							__( 'Maximum Full Width', 'ultimate_vc' ) => 'ex-full',
							__( 'Browser Full Dimension', 'ultimate_vc' ) => 'browser_size',
						),
						'description' => __( "By default, the background will be given to the WPBakery Page Builder row. However, in some cases depending on your theme's CSS - it may not fit well to the container you are wishing it would. In that case you will have to select the appropriate value here that gets you desired output..", 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'bg_type',
							'value'   => array( 'u_iframe', 'image', 'video', 'grad', 'bg_color', 'animated' ),
						),
						'group'       => $group_name,
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'       => 'ult_switch',
						'class'      => '',
						'heading'    => __( 'Activate on Mobile', 'ultimate_vc' ),
						'param_name' => 'disable_on_mobile_img_parallax',
						'value'      => '',
						'options'    => array(
							'disable_on_mobile_img_parallax_value' => array(
								'label' => '',
								'on'    => __( 'Yes', 'ultimate_vc' ),
								'off'   => __( 'No', 'ultimate_vc' ),
							),
						),
						'group'      => $group_name,
						'dependency' => array(
							'element' => 'parallax_style',
							'value'   => array( 'vcpb-animated', 'vcpb-vz-jquery', 'vcpb-hz-jquery', 'vcpb-fs-jquery', 'vcpb-mlvp-jquery' ),
						),
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'             => 'ult_switch',
						'class'            => '',
						'heading'          => __( 'Easy Parallax', 'ultimate_vc' ),
						'param_name'       => 'parallax_content',
						'value'            => '',
						'options'          => array(
							'parallax_content_value' => array(
								'label' => '',
								'on'    => __( 'Yes', 'ultimate_vc' ),
								'off'   => __( 'No', 'ultimate_vc' ),
							),
						),
						'group'            => $group_effects,
						'edit_field_class' => 'uvc-divider last-uvc-divider vc_column vc_col-sm-12',
						'description'      => __( 'If enabled, the elements inside row - will move slowly as user scrolls.', 'ultimate_vc' ),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'textfield',
						'class'       => '',
						'heading'     => __( 'Parallax Speed', 'ultimate_vc' ),
						'param_name'  => 'parallax_content_sense',
						'value'       => '',
						'group'       => $group_effects,
						'description' => __( 'Enter value between 0 to 100 (Default 30)', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'parallax_content',
							'value'   => array( 'parallax_content_value' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'             => 'ult_switch',
						'class'            => '',
						'heading'          => __( 'Fade Effect on Scroll', 'ultimate_vc' ),
						'param_name'       => 'fadeout_row',
						'value'            => '',
						'options'          => array(
							'fadeout_row_value' => array(
								'label' => '',
								'on'    => __( 'Yes', 'ultimate_vc' ),
								'off'   => __( 'No', 'ultimate_vc' ),
							),
						),
						'group'            => $group_effects,
						'edit_field_class' => 'uvc-divider last-uvc-divider vc_column vc_col-sm-12',
						'description'      => __( 'If enabled, the the content inside row will fade out slowly as user scrolls down.', 'ultimate_vc' ),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'number',
						'class'       => '',
						'heading'     => __( 'Viewport Position', 'ultimate_vc' ),
						'param_name'  => 'fadeout_start_effect',
						'suffix'      => '%',
						'value'       => '',
						'group'       => $group_effects,
						'description' => __( 'The area of screen from top where fade out effect will take effect once the row is completely inside that area. (Default 30)', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'fadeout_row',
							'value'   => array( 'fadeout_row_value' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'             => 'ult_switch',
						'heading'          => __( 'Enable Overlay', 'ultimate_vc' ),
						'param_name'       => 'enable_overlay',
						'value'            => '',
						'options'          => array(
							'enable_overlay_value' => array(
								'label' => '',
								'on'    => __( 'Yes', 'ultimate_vc' ),
								'off'   => __( 'No', 'ultimate_vc' ),
							),
						),
						'edit_field_class' => 'uvc-divider last-uvc-divider vc_column vc_col-sm-12',
						'group'            => $group_effects,
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'colorpicker',
						'heading'     => __( 'Color', 'ultimate_vc' ),
						'param_name'  => 'overlay_color',
						'value'       => '',
						'group'       => $group_effects,
						'dependency'  => array(
							'element' => 'enable_overlay',
							'value'   => array( 'enable_overlay_value' ),
						),
						'description' => __( 'Select RGBA values or opacity will be set to 20% by default.', 'ultimate_vc' ),
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'       => 'radio_image_box',
						'heading'    => __( 'Pattern', 'ultimate_vc' ),
						'param_name' => 'overlay_pattern',
						'value'      => '',
						'options'    => $patterns,
						'css'        => array(
							'width'             => '40px',
							'height'            => '35px',
							'background-repeat' => 'repeat',
							'background-size'   => 'cover',
						),
						'group'      => $group_effects,
						'dependency' => array(
							'element' => 'enable_overlay',
							'value'   => array( 'enable_overlay_value' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'             => 'number',
						'heading'          => __( 'Pattern Opacity', 'ultimate_vc' ),
						'param_name'       => 'overlay_pattern_opacity',
						'value'            => '',
						'max'              => '100',
						'suffix'           => '%',
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'enable_overlay',
							'value'   => array( 'enable_overlay_value' ),
						),
						'description'      => __( 'Enter value between 0 to 100 (0 is maximum transparency, while 100 is minimum & default is 80)', 'ultimate_vc' ),
						'edit_field_class' => 'vc_column vc_col-sm-4',
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'             => 'number',
						'heading'          => __( 'Pattern Size', 'ultimate_vc' ),
						'param_name'       => 'overlay_pattern_size',
						'value'            => '',
						'suffix'           => 'px',
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'enable_overlay',
							'value'   => array( 'enable_overlay_value' ),
						),
						'description'      => __( 'This is optional; sets the size of the pattern image manually.', 'ultimate_vc' ),
						'edit_field_class' => 'vc_column vc_col-sm-4',
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'             => 'dropdown',
						'heading'          => __( 'Pattern Scroll Effect', 'ultimate_vc' ),
						'param_name'       => 'overlay_pattern_attachment',
						'value'            => array(
							__( 'Move with the Content', 'ultimate_vc' ) => '',
							__( 'Fixed at its position', 'ultimate_vc' ) => 'fixed',
						),
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'enable_overlay',
							'value'   => array( 'enable_overlay_value' ),
						),
						'edit_field_class' => 'vc_column vc_col-sm-4',
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'             => 'checkbox',
						'heading'          => __( 'Fancy Multi Color Overlay', 'ultimate_vc' ),
						'param_name'       => 'multi_color_overlay',
						'value'            => array(
							__( 'Enable', 'ultimate_vc' ) => 'uvc-multi-color-bg',
						),
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'enable_overlay',
							'value'   => array( 'enable_overlay_value' ),
						),
						'edit_field_class' => 'vc_column vc_col-sm-4 clear',
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'             => 'number',
						'heading'          => __( 'Multi Color Overlay Opacity', 'ultimate_vc' ),
						'param_name'       => 'multi_color_overlay_opacity',
						'value'            => '',
						'suffix'           => '%',
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'multi_color_overlay',
							'value'   => array( 'uvc-multi-color-bg' ),
						),
						'edit_field_class' => 'vc_column vc_col-sm-8',
						'description'      => __( 'Default 60', 'ultimate_vc' ),
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'             => 'ult_switch',
						'heading'          => __( 'Separator ', 'ultimate_vc' ),
						'param_name'       => 'seperator_enable',
						'value'            => '',
						'options'          => array(
							'seperator_enable_value' => array(
								'on'  => __( 'Yes', 'ultimate_vc' ),
								'off' => __( 'No', 'ultimate_vc' ),
							),
						),
						'edit_field_class' => 'uvc-divider last-uvc-divider vc_column vc_col-sm-12',
						'group'            => $group_effects,
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'             => 'dropdown',
						'heading'          => __( 'Type', 'ultimate_vc' ),
						'param_name'       => 'seperator_type',
						'value'            => array(
							__( 'None', 'ultimate_vc' )   => '',
							__( 'Triangle', 'ultimate_vc' ) => 'triangle_svg_seperator',
							__( 'Big Triangle', 'ultimate_vc' ) => 'xlarge_triangle_seperator',
							__( 'Big Triangle Left', 'ultimate_vc' ) => 'xlarge_triangle_left_seperator',
							__( 'Big Triangle Right', 'ultimate_vc' ) => 'xlarge_triangle_right_seperator',
							__( 'Half Circle', 'ultimate_vc' ) => 'circle_svg_seperator',
							__( 'Curve Center', 'ultimate_vc' ) => 'xlarge_circle_seperator',
							__( 'Curve Left', 'ultimate_vc' ) => 'curve_up_seperator',
							__( 'Curve Right', 'ultimate_vc' ) => 'curve_down_seperator',
							__( 'Tilt Left', 'ultimate_vc' ) => 'tilt_left_seperator',
							__( 'Tilt Right', 'ultimate_vc' ) => 'tilt_right_seperator',
							__( 'Round Split', 'ultimate_vc' ) => 'round_split_seperator',
							__( 'Waves', 'ultimate_vc' )  => 'waves_seperator',
							__( 'Clouds', 'ultimate_vc' ) => 'clouds_seperator',
							__( 'Multi Triangle', 'ultimate_vc' ) => 'multi_triangle_seperator',
						),
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'seperator_enable',
							'value'   => array( 'seperator_enable_value' ),
						),
						'edit_field_class' => 'uvc-divider-content-first vc_column vc_col-sm-12',
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'             => 'dropdown',
						'heading'          => __( 'Position', 'ultimate_vc' ),
						'param_name'       => 'seperator_position',
						'value'            => array(
							__( 'Top', 'ultimate_vc' )    => '',
							__( 'Bottom', 'ultimate_vc' ) => 'bottom_seperator',
							__( 'Top & Bottom', 'ultimate_vc' ) => 'top_bottom_seperator',
						),
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'seperator_enable',
							'value'   => array( 'seperator_enable_value' ),
						),
						'edit_field_class' => 'uvc-divider-content-first vc_column vc_col-sm-12',
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'number',
						'heading'     => __( 'Size', 'ultimate_vc' ),
						'param_name'  => 'seperator_shape_size',
						'value'       => '',
						'suffix'      => 'px',
						'group'       => $group_effects,
						'dependency'  => array(
							'element' => 'seperator_type',
							'value'   => array( 'triangle_seperator', 'circle_seperator', 'round_split_seperator' ),
						),
						'description' => __( 'Default 40', 'ultimate_vc' ),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'number',
						'heading'     => __( 'Height', 'ultimate_vc' ),
						'param_name'  => 'seperator_svg_height',
						'value'       => '',
						'suffix'      => 'px',
						'group'       => $group_effects,
						'dependency'  => array(
							'element' => 'seperator_type',
							'value'   => array( 'xlarge_triangle_seperator', 'curve_up_seperator', 'curve_down_seperator', 'waves_seperator', 'clouds_seperator', 'xlarge_circle_seperator', 'triangle_svg_seperator', 'circle_svg_seperator', 'xlarge_triangle_left_seperator', 'xlarge_triangle_right_seperator', 'tilt_left_seperator', 'tilt_right_seperator', 'multi_triangle_seperator' ),
						),
						'description' => __( 'Default 60', 'ultimate_vc' ),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'colorpicker',
						'heading'     => __( 'Background', 'ultimate_vc' ),
						'param_name'  => 'seperator_shape_background',
						'value'       => '',
						'group'       => $group_effects,
						'dependency'  => array(
							'element' => 'seperator_type',
							'value'   => array( 'xlarge_triangle_seperator', 'triangle_seperator', 'circle_seperator', 'curve_up_seperator', 'curve_down_seperator', 'round_split_seperator', 'waves_seperator', 'clouds_seperator', 'xlarge_circle_seperator', 'triangle_svg_seperator', 'circle_svg_seperator', 'xlarge_triangle_left_seperator', 'xlarge_triangle_right_seperator', 'tilt_left_seperator', 'tilt_right_seperator', 'multi_triangle_seperator' ),
						),
						'description' => __( 'Mostly, this should be background color of your adjacent row section. (Default - White)', 'ultimate_vc' ),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'       => 'dropdown',
						'heading'    => __( 'Border', 'ultimate_vc' ),
						'param_name' => 'seperator_shape_border',
						'value'      => array(
							__( 'None', 'ultimate_vc' )   => '',
							__( 'Solid', 'ultimate_vc' )  => 'solid',
							__( 'Dotted', 'ultimate_vc' ) => 'dotted',
							__( 'Dashed', 'ultimate_vc' ) => 'dashed',
						),
						'group'      => $group_effects,
						'dependency' => array(
							'element' => 'seperator_type',
							'value'   => array( 'triangle_seperator', 'circle_seperator', 'round_split_seperator' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'       => 'colorpicker',
						'heading'    => __( 'Border Color', 'ultimate_vc' ),
						'param_name' => 'seperator_shape_border_color',
						'value'      => '',
						'group'      => $group_effects,
						'dependency' => array(
							'element' => 'seperator_type',
							'value'   => array( 'triangle_seperator', 'circle_seperator', 'round_split_seperator' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'             => 'number',
						'heading'          => __( 'Border Width', 'ultimate_vc' ),
						'param_name'       => 'seperator_shape_border_width',
						'value'            => '',
						'suffix'           => 'px',
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'seperator_type',
							'value'   => array( 'triangle_seperator', 'circle_seperator', 'round_split_seperator' ),
						),
						'edit_field_class' => 'uvc-divider-content-last vc_column vc_col-sm-12',
						'description'      => __( 'Default 1px', 'ultimate_vc' ),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'dropdown',
						'class'       => '',
						'heading'     => __( 'Icon to display:', 'ultimate_vc' ),
						'param_name'  => 'icon_type',
						'value'       => array(
							__( 'None', 'ultimate_vc' ) => '',
							__( 'Font Icon Manager', 'ultimate_vc' ) => 'selector',
							__( 'Custom Image Icon', 'ultimate_vc' ) => 'custom',
						),
						'group'       => $group_effects,
						'description' => __( 'Use an existing font icon or upload a custom image.', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'seperator_enable',
							'value'   => array( 'seperator_enable_value' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'icon_manager',
						'class'       => '',
						'heading'     => __( 'Select Icon ', 'ultimate_vc' ),
						'param_name'  => 'icon',
						'value'       => '',
						'group'       => $group_effects,
						'description' => __( "Click and select icon of your choice. If you can't find the one that suits for your purpose", 'ultimate_vc' ) . ', ' . __( 'you can', 'ultimate_vc' ) . " <a href='admin.php?page=bsf-font-icon-manager' target='_blank' rel='noopener'>" . __( 'add new here', 'ultimate_vc' ) . '</a>.',
						'dependency'  => array(
							'element' => 'icon_type',
							'value'   => array( 'selector' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'number',
						'class'       => '',
						'heading'     => __( 'Size of Icon', 'ultimate_vc' ),
						'param_name'  => 'icon_size',
						'value'       => '',
						'max'         => 72,
						'suffix'      => 'px',
						'group'       => $group_effects,
						'description' => __( 'How big would you like it? (Default 32)', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'icon_type',
							'value'   => array( 'selector' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'colorpicker',
						'class'       => '',
						'heading'     => __( 'Color', 'ultimate_vc' ),
						'param_name'  => 'icon_color',
						'value'       => '',
						'group'       => $group_effects,
						'description' => __( 'Give it a nice paint!', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'icon_type',
							'value'   => array( 'selector' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'dropdown',
						'class'       => '',
						'heading'     => __( 'Icon Style', 'ultimate_vc' ),
						'param_name'  => 'icon_style',
						'value'       => array(
							__( 'Simple', 'ultimate_vc' ) => '',
							__( 'Circle Background', 'ultimate_vc' ) => 'circle',
							__( 'Square Background', 'ultimate_vc' ) => 'square',
							__( 'Design your own', 'ultimate_vc' ) => 'advanced',
						),
						'group'       => $group_effects,
						'description' => __( 'We have given three quick preset if you are in a hurry. Otherwise, create your own with various options.', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'icon_type',
							'value'   => array( 'selector' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'colorpicker',
						'class'       => '',
						'heading'     => __( 'Background Color', 'ultimate_vc' ),
						'param_name'  => 'icon_color_bg',
						'value'       => '',
						'group'       => $group_effects,
						'description' => __( 'Select background color for icon.', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'icon_style',
							'value'   => array( 'circle', 'square', 'advanced' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'dropdown',
						'class'       => '',
						'heading'     => __( 'Icon Border Style', 'ultimate_vc' ),
						'param_name'  => 'icon_border_style',
						'value'       => array(
							__( 'None', 'ultimate_vc' )   => '',
							__( 'Solid', 'ultimate_vc' )  => 'solid',
							__( 'Dashed', 'ultimate_vc' ) => 'dashed',
							__( 'Dotted', 'ultimate_vc' ) => 'dotted',
							__( 'Double', 'ultimate_vc' ) => 'double',
							__( 'Inset', 'ultimate_vc' )  => 'inset',
							__( 'Outset', 'ultimate_vc' ) => 'outset',
						),
						'group'       => $group_effects,
						'description' => __( 'Select the border style for icon.', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'icon_style',
							'value'   => array( 'advanced' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'colorpicker',
						'class'       => '',
						'heading'     => __( 'Border Color', 'ultimate_vc' ),
						'param_name'  => 'icon_color_border',
						'value'       => '',
						'group'       => $group_effects,
						'description' => __( 'Select border color for icon. (Default - #333333)', 'ultimate_vc' ),
						'dependency'  => array(
							'element'   => 'icon_border_style',
							'not_empty' => true,
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'number',
						'class'       => '',
						'heading'     => __( 'Border Width', 'ultimate_vc' ),
						'param_name'  => 'icon_border_size',
						'value'       => '',
						'max'         => 10,
						'suffix'      => 'px',
						'group'       => $group_effects,
						'description' => __( 'Thickness of the border. (Default - 1px)', 'ultimate_vc' ),
						'dependency'  => array(
							'element'   => 'icon_border_style',
							'not_empty' => true,
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'number',
						'class'       => '',
						'heading'     => __( 'Border Radius', 'ultimate_vc' ),
						'param_name'  => 'icon_border_radius',
						'value'       => '',
						'max'         => 500,
						'suffix'      => 'px',
						'group'       => $group_effects,
						'description' => __( '0 pixel value will create a square border. As you increase the value, the shape convert in circle slowly. (Default 500).', 'ultimate_vc' ),
						'dependency'  => array(
							'element'   => 'icon_border_style',
							'not_empty' => true,
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'number',
						'class'       => '',
						'heading'     => __( 'Background Size', 'ultimate_vc' ),
						'param_name'  => 'icon_border_spacing',
						'value'       => '',
						'max'         => 500,
						'suffix'      => 'px',
						'group'       => $group_effects,
						'description' => __( 'Spacing from center of the icon till the boundary of border / background (Default - 50)', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'icon_style',
							'value'   => array( 'advanced' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'ult_img_single',
						'class'       => '',
						'heading'     => __( 'Upload Image Icon:', 'ultimate_vc' ),
						'param_name'  => 'icon_img',
						'value'       => '',
						'group'       => $group_effects,
						'description' => __( 'Upload the custom image icon.', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'icon_type',
							'value'   => array( 'custom' ),
						),
					)
				);
				vc_add_param(
					'vc_row',
					array(
						'type'        => 'number',
						'class'       => '',
						'heading'     => __( 'Image Width', 'ultimate_vc' ),
						'param_name'  => 'img_width',
						'value'       => '',
						'max'         => 512,
						'suffix'      => 'px',
						'group'       => $group_effects,
						'description' => __( 'Provide image width (Default - 48)', 'ultimate_vc' ),
						'dependency'  => array(
							'element' => 'icon_type',
							'value'   => array( 'custom' ),
						),
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'             => 'ult_switch',
						'heading'          => __( 'Hide Row', 'ultimate_vc' ),
						'param_name'       => 'ult_hide_row',
						'value'            => '',
						'options'          => array(
							'ult_hide_row_value' => array(
								'on'  => __( 'Yes', 'ultimate_vc' ),
								'off' => __( 'No', 'ultimate_vc' ),
							),
						),
						'edit_field_class' => 'uvc-divider last-uvc-divider vc_column vc_col-sm-12',
						'group'            => $group_effects,
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'             => 'ult_switch',
						'heading'          => '<i class="dashicons dashicons-welcome-view-site"></i> ' . __( 'Large Screen', 'ultimate_vc' ),
						'param_name'       => 'ult_hide_row_large_screen',
						'value'            => '',
						'options'          => array(
							'large_screen' => array(
								'on'  => __( 'Yes', 'ultimate_vc' ),
								'off' => __( 'No', 'ultimate_vc' ),
							),
						),
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'ult_hide_row',
							'value'   => array( 'ult_hide_row_value' ),
						),
						'edit_field_class' => 'vc_column vc_col-sm-4',
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'             => 'ult_switch',
						'heading'          => '<i class="dashicons dashicons-desktop"></i> ' . __( 'Desktop', 'ultimate_vc' ),
						'param_name'       => 'ult_hide_row_desktop',
						'value'            => '',
						'options'          => array(
							'desktop' => array(
								'on'  => __( 'Yes', 'ultimate_vc' ),
								'off' => __( 'No', 'ultimate_vc' ),
							),
						),
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'ult_hide_row',
							'value'   => array( 'ult_hide_row_value' ),
						),
						'edit_field_class' => 'vc_column vc_col-sm-4',
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'             => 'ult_switch',
						'heading'          => '<i class="dashicons dashicons-tablet" style="transform: rotate(90deg);"></i> ' . __( 'Tablet', 'ultimate_vc' ),
						'param_name'       => 'ult_hide_row_tablet',
						'value'            => '',
						'options'          => array(
							'tablet' => array(
								'on'  => __( 'Yes', 'ultimate_vc' ),
								'off' => __( 'No', 'ultimate_vc' ),
							),
						),
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'ult_hide_row',
							'value'   => array( 'ult_hide_row_value' ),
						),
						'edit_field_class' => 'vc_column vc_col-sm-4',
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'             => 'ult_switch',
						'heading'          => '<i class="dashicons dashicons-tablet"></i> ' . __( 'Tablet Portrait', 'ultimate_vc' ),
						'param_name'       => 'ult_hide_row_tablet_small',
						'value'            => '',
						'options'          => array(
							'xs_tablet' => array(
								'on'  => __( 'Yes', 'ultimate_vc' ),
								'off' => __( 'No', 'ultimate_vc' ),
							),
						),
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'ult_hide_row',
							'value'   => array( 'ult_hide_row_value' ),
						),
						'edit_field_class' => 'vc_column vc_col-sm-4',
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'             => 'ult_switch',
						'heading'          => '<i class="dashicons dashicons-smartphone"></i> ' . __( 'Mobile', 'ultimate_vc' ),
						'param_name'       => 'ult_hide_row_mobile',
						'value'            => '',
						'options'          => array(
							'mobile' => array(
								'on'  => __( 'Yes', 'ultimate_vc' ),
								'off' => __( 'No', 'ultimate_vc' ),
							),
						),
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'ult_hide_row',
							'value'   => array( 'ult_hide_row_value' ),
						),
						'edit_field_class' => 'vc_column vc_col-sm-4',
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'             => 'ult_switch',
						'heading'          => '<i class="dashicons dashicons-smartphone" style="transform: rotate(90deg);"></i> ' . __( 'Mobile Landscape', 'ultimate_vc' ),
						'param_name'       => 'ult_hide_row_mobile_large',
						'value'            => '',
						'options'          => array(
							'xl_mobile' => array(
								'on'  => __( 'Yes', 'ultimate_vc' ),
								'off' => __( 'No', 'ultimate_vc' ),
							),
						),
						'group'            => $group_effects,
						'dependency'       => array(
							'element' => 'ult_hide_row',
							'value'   => array( 'ult_hide_row_value' ),
						),
						'edit_field_class' => 'vc_column vc_col-sm-4',
					)
				);

				vc_add_param(
					'vc_row',
					array(
						'type'             => 'ult_param_heading',
						'text'             => __( 'In order for Effects below to work, you must select something except "default" in background tab.', 'ultimate_vc' ) . ' ' . __( 'May be single color.' ) . ' <br> ' . __( 'Screenshot', 'ultimate_vc' ) . ' - <a href="https://cloudup.com/cc1J8ZlcdZW" target="_blank" rel="noopener">https://cloudup.com/cc1J8ZlcdZW</a>',
						'param_name'       => 'notification',
						'edit_field_class' => 'ult-param-important-wrapper ult-dashicon vc_column vc_col-sm-12',
						'group'            => $group_effects,
					)
				);
			}
		} /* parallax_init*/
		/**
		 * Admin Scripts.
		 *
		 * @since ----
		 * @param mixed $hook hooks.
		 * @access public
		 */
		public function admin_scripts( $hook ) {
			if ( 'post.php' == $hook || 'post-new.php' == $hook ) {
				wp_register_script( 'ultimate-vc-addons-colorpicker', UAVC_URL . 'admin/js/jquery-colorpicker.js ', array( 'jquery' ), ULTIMATE_VERSION, false );
				wp_register_script( 'ultimate-vc-addons-classygradient', UAVC_URL . 'admin/js/jquery-classygradient-min.js', array( 'jquery' ), ULTIMATE_VERSION, false );

				Ultimate_VC_Addons::ultimate_register_style( 'ultimate-vc-addons-classycolorpicker-style', UAVC_URL . 'admin/css/jquery-colorpicker.css', true );

				Ultimate_VC_Addons::ultimate_register_style( 'ultimate-vc-addons-classygradient-style', UAVC_URL . 'admin/css/jquery-classygradient-min.css', true );

				$bsf_dev_mode = bsf_get_option( 'dev_mode' );
				if ( 'enable' === $bsf_dev_mode ) {
					wp_enqueue_script( 'ultimate-vc-addons-colorpicker' );
					wp_enqueue_script( 'ultimate-vc-addons-classygradient' );

					wp_enqueue_style( 'ultimate-vc-addons-classycolorpicker-style' );
					wp_enqueue_style( 'ultimate-vc-addons-classygradient-style' );
				}
			}
		}//end admin_scripts()
		/**
		 * Initialize Font scrips.
		 *
		 * @since ----
		 * @access public
		 */
		public static function front_scripts() {
			$bsf_dev_mode = bsf_get_option( 'dev_mode' );
			if ( 'enable' === $bsf_dev_mode ) {
				$js_path  = '../assets/js/';
				$css_path = '../assets/css/';
				$ext      = '';
			} else {
				$js_path  = '../assets/min-js/';
				$css_path = '../assets/min-css/';
				$ext      = '.min';
			}
			$ultimate_css = get_option( 'ultimate_css' );
			if ( 'enable' != $ultimate_css || 'enable' === $bsf_dev_mode ) {
				Ultimate_VC_Addons::ultimate_register_style( 'ultimate-vc-addons-background-style', 'background-style' );
				wp_enqueue_style( 'ultimate-vc-addons-background-style' );
			}
		} /* end front_scripts */
	}
	new Ultimate_VC_Addons_Parallax();
}
$ultimate_row = get_option( 'ultimate_row' );
if ( ( defined( 'WPB_VC_VERSION' ) && ( ! version_compare( WPB_VC_VERSION, '4.4', '>=' ) ) ) && 'enable' == $ultimate_row ) {
	if ( ! function_exists( 'vc_theme_after_vc_row' ) ) {
		/**
		 * For the animation in the module
		 *
		 * @since ----
		 * @param array  $atts represts module attribuits.
		 * @param string $content value has been set to null.
		 * @access public
		 */
		function vc_theme_after_vc_row( $atts, $content = null ) {
			return Ultimate_VC_Addons_Parallax::parallax_shortcode( $atts, $content );
		}
	}
}
if ( ! function_exists( 'hex2rgbUltParallax' ) ) {
	/**
	 * Hex to Rgb
	 *
	 * @since ----
	 * @param mixed $hex hex number.
	 * @param mixed $opacity color opacity.
	 * @access public
	 */
	function hex2rgbUltParallax( $hex, $opacity ) { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionNameInvalid
		$hex = str_replace( '#', '', $hex );
		if ( preg_match( '/^([a-f0-9]{3}|[a-f0-9]{6})$/i', $hex ) ) :      // check if input string is a valid hex colour code.
			if ( strlen( $hex ) == 3 ) { // three letters code.
				$r = hexdec( substr( $hex, 0, 1 ) . substr( $hex, 0, 1 ) );
				$g = hexdec( substr( $hex, 1, 1 ) . substr( $hex, 1, 1 ) );
				$b = hexdec( substr( $hex, 2, 1 ) . substr( $hex, 2, 1 ) );
			} else { // six letters coode.
				$r = hexdec( substr( $hex, 0, 2 ) );
				$g = hexdec( substr( $hex, 2, 2 ) );
				$b = hexdec( substr( $hex, 4, 2 ) );
			}
			return 'rgba(' . implode( ',', array( $r, $g, $b ) ) . ',' . $opacity . ')';// returns the rgb values separated by commas, ready for usage in a rgba( rr,gg,bb,aa ) CSS rule.
		else :
			return '';  // input string is not a valid hex color code - return a blank value; this can be changed to return a default colour code for example.
		endif;
	}
}
if ( ! function_exists( 'rgbaToHexUltimate' ) ) {
	/**
	 * Rgba to Hex
	 *
	 * @since ----
	 * @param mixed $r red.
	 * @param mixed $g green.
	 * @param mixed $b blue.
	 * @access public
	 */
	function rgbaToHexUltimate( $r, $g, $b ) { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionNameInvalid
		$hex  = '#';
		$hex .= str_pad( dechex( $r ), 2, '0', STR_PAD_LEFT );
		$hex .= str_pad( dechex( $g ), 2, '0', STR_PAD_LEFT );
		$hex .= str_pad( dechex( $b ), 2, '0', STR_PAD_LEFT );
		return $hex;
	}
}