File "codevz_fields.php"

Full path: /home/webide/saman-clinic.ir/wp-content/plugins/codevz-plus/admin/fields/codevz_fields/codevz_fields.php
File size: 43.31 KB
MIME-type: text/x-php
Charset: utf-8

<?php if ( ! defined( 'ABSPATH' ) ) {exit;} // Cannot access pages directly.

/* Admin assets */
function codevz_plus_admin_enqueue_scripts() {

	wp_enqueue_script ( 'jquery-ui-dialog' );
	wp_enqueue_script( 'cz-fields', CODEVZ_FRAMEWORK_URL . '/fields/codevz_fields/codevz_fields.js', [], Codevz_Plus::$ver, true );
	wp_enqueue_style( 'cz-fields', CODEVZ_FRAMEWORK_URL . '/fields/codevz_fields/codevz_fields.css', false, Codevz_Plus::$ver );
	wp_enqueue_style( 'cz-icons-pack', CODEVZ_FRAMEWORK_URL . '/fields/codevz_fields/icons/czicons.css', false, Codevz_Plus::$ver );

	if ( is_rtl() ) {
		wp_enqueue_style( 'cz-fields-rtl', CODEVZ_FRAMEWORK_URL . '/fields/codevz_fields/codevz_fields.rtl.css', false, Codevz_Plus::$ver );
	}

	wp_localize_script( 'cz-fields', 'sk_aiL10n', array(
	    'close' 			=> esc_html__( 'Close', 'codevz' ),
	    'normal' 			=> esc_html__( 'Normal', 'codevz' ),
	    'focus' 			=> esc_html__( 'Focus', 'codevz' ),
	    'hover' 			=> esc_html__( 'Hover', 'codevz' ),
	    'styles' 			=> esc_html__( 'Styles', 'codevz' ),
	    'desktop' 		=> esc_html__( 'On Desktop', 'codevz' ),
	    'tablet' 			=> esc_html__( 'On Tablet', 'codevz' ),
	    'mobile' 			=> esc_html__( 'On Mobile', 'codevz' ),
	    'copy' 				=> esc_html__( 'Copy', 'codevz' ),
	    'copied' 			=> esc_html__( 'Copied', 'codevz' ),
	    'paste' 			=> esc_html__( 'Paste', 'codevz' ),
	    'advanced' 		=> esc_html__( 'Advanced mode', 'codevz' ),
	    'reset' 			=> esc_html__( 'Reset', 'codevz' ),
	    'reset_confirm' => esc_html__( 'Are you sure you want reset this StyleKit?', 'codevz' ),
	    'paste_confirm' => esc_html__( 'Are you sure you want paste on this StyleKit?', 'codevz' ),
	    'load_more' 	=> esc_html__( 'Load More', 'codevz' ),
	    'pro' 				=> esc_html__( 'Activate your theme with purchase code to access this feature.', 'codevz' ),
	    'search' 			=> esc_html__( 'Search', 'codevz' ),
	    'search_result' => esc_html__( 'Search result', 'codevz' ),
	    'search_not' 	=> esc_html__( 'Not found any options', 'codevz' ),
	    'search_pl' 	=> esc_html__( 'Type a keyword ...', 'codevz' ),
	    'custom_header' => esc_html__( 'Custom header is ON', 'codevz' ),
	    'custom_footer' => esc_html__( 'Custom footer is ON', 'codevz' ),
	) );
}
add_action( 'admin_enqueue_scripts', 'codevz_plus_admin_enqueue_scripts', 9 );
add_action( 'elementor/editor/before_enqueue_scripts', 'codevz_plus_admin_enqueue_scripts' );

// Frontend styles.
function codevz_plus_wp_enqueue_scripts() {

	if ( Codevz_Plus::$vc_editable ) {

		wp_enqueue_style( 'cz-fields', CODEVZ_FRAMEWORK_URL . '/fields/codevz_fields/codevz_fields.css', false, Codevz_Plus::$ver );

		if ( is_rtl() ) {
			wp_enqueue_style( 'cz-fields-rtl', CODEVZ_FRAMEWORK_URL . '/fields/codevz_fields/codevz_fields.rtl.css', false, Codevz_Plus::$ver );
		}

		wp_enqueue_style( 'codevz-wpb', CODEVZ_FRAMEWORK_URL . '/fields/codevz_fields/wpb.frontend.css', false, Codevz_Plus::$ver );

	}

	wp_enqueue_style( 'cz-icons-pack', CODEVZ_FRAMEWORK_URL . '/fields/codevz_fields/icons/czicons.css', false, Codevz_Plus::$ver );

}
add_action( 'wp_enqueue_scripts', 'codevz_plus_wp_enqueue_scripts' );

// Customizer preview.
function codevz_plus_customize_preview_init() {

	wp_enqueue_script( 'codevz-customize', CODEVZ_FRAMEWORK_URL . '/fields/codevz_fields/codevz_customizer.js', array( 'customize-preview' ), Codevz_Plus::$ver, true );

}
add_action( 'customize_preview_init', 'codevz_plus_customize_preview_init' );

// Customizer footer.
function codevz_customize_controls() {
	wp_enqueue_script( 'codevz-customize-controls', CODEVZ_FRAMEWORK_URL . '/fields/codevz_fields/codevz_customizer_controls.js', [], '', true );
}
add_action( 'customize_controls_print_footer_scripts', 'codevz_customize_controls' );

/* Field: Slider */
if( ! class_exists( 'Codevz_Field_slider' ) ) {
  class Codevz_Field_slider extends Codevz_Fields {

	public function __construct( $field, $value = '', $unique = '', $where = '' ) {
	  parent::__construct( $field, $value, $unique, $where );
	}

	public function output() {

	  if ( isset( $this->field['options'] ) ) {
		$options = $this->field['options'];
	  } else {
		$options = array( 'step' => 1, 'unit' => 'px', 'min' => 0, 'max' => 100 );
	  }

	  echo $this->element_before();
	  echo '<div style="position:relative">';
	  echo '<input type="text" name="'. $this->element_name() .'" autocomplete="off" value="'. $this->element_value() .'"'. $this->element_class() . $this->element_attributes() .'/>';
	  echo '<div class="codevz-slider" data-options=\'' . json_encode( $options ) . '\'></div>';
	  echo '</div>';
	  echo $this->element_after();

	}

  }
}

/* Field: 4 Sizes */
if( ! class_exists( 'Codevz_Field_codevz_sizes' ) ) {
  class Codevz_Field_codevz_sizes extends Codevz_Fields {

	public function __construct( $field, $value = '', $unique = '', $where = '' ) {
	  parent::__construct( $field, $value, $unique, $where );
	}

	public function output() {

	  echo $this->element_before();
	  $value_defaults = array( 'top' => '', 'right' => '', 'bottom' => '', 'left' => '' );
	  $this->value  = wp_parse_args( $this->element_value(), $value_defaults );

	  $default_options = array( 'step' => 1, 'unit' => 'px', 'min' => 0, 'max' => 50 );
	  $options = isset( $this->field['options'] ) ? wp_parse_args( $this->field['options'], $default_options ) : $default_options;

	  echo '<fieldset>';
	  echo codevz_add_field( array(
		  'type'    => 'slider',
		  'name'    => $this->element_name( '[top]' ),
		  'before'  => '<i class="fa fa-angle-up"></i>',
		  'options' => $options
	  ), $this->value['top'], '', 'field/codevz_sizes' );

	  echo codevz_add_field( array(
		  'type'    => 'slider',
		  'name'    => $this->element_name( '[right]' ),
		  'before'  => '<i class="fa fa-angle-right"></i>',
		  'options' => $options
	  ), $this->value['right'], '', 'field/codevz_sizes' );

	  echo codevz_add_field( array(
		  'type'    => 'slider',
		  'name'    => $this->element_name( '[bottom]' ),
		  'before'  => '<i class="fa fa-angle-down"></i>',
		  'options' => $options
	  ), $this->value['bottom'], '', 'field/codevz_sizes' );
	  
	  echo codevz_add_field( array(
		  'type'    => 'slider',
		  'name'    => $this->element_name( '[left]' ),
		  'before'  => '<i class="fa fa-angle-left"></i>',
		  'options' => $options
	  ), $this->value['left'], '', 'field/codevz_sizes' );

	  echo '<i class="fa fa-link" title="Connect all inputs"></i></fieldset>';
	  echo $this->element_after();

	}
  }
}

/* Field: Box Shadow 3 size field + color */
if( ! class_exists( 'Codevz_Field_codevz_box_shadow' ) ) {
  class Codevz_Field_codevz_box_shadow extends Codevz_Fields {

	public function __construct( $field, $value = '', $unique = '', $where = '' ) {
	  parent::__construct( $field, $value, $unique, $where );
	}

	public function output() {

	  echo $this->element_before();
	  $value_defaults = array( 'x' => '', 'y' => '', 'blur' => '', 'color' => '', 'inset' => '' );
	  $this->value  = wp_parse_args( $this->element_value(), $value_defaults );

	  $options = array( 'step' => 1, 'unit' => 'px', 'min' => 0, 'max' => 100 );

	  $is_box = ( isset( $this->field['id'] ) && Codevz_Plus::contains( $this->field['id'], 'box' ) );

	  echo '<fieldset>';
	  echo codevz_add_field( array(
		  'type'    => 'slider',
		  'name'    => $this->element_name( '[x]' ),
		  'before'  => '<i>' . esc_html__( 'X', 'codevz' ) . '</i>',
		  'options' => $options,
		  'dependency' => array( '_shadow_' . $this->field['id'], '!=', 'none' ),
	  ), $this->value['x'], '', 'field/codevz_box_shadow' );

	  echo codevz_add_field( array(
		  'type'    => 'slider',
		  'name'    => $this->element_name( '[y]' ),
		  'before'  => '<i>' . esc_html__( 'Y', 'codevz' ) . '</i>',
		  'options' => $options,
		  'dependency' => array( '_shadow_' . $this->field['id'], '!=', 'none' ),
	  ), $this->value['y'], '', 'field/codevz_box_shadow' );

	  echo codevz_add_field( array(
		  'type'    => 'slider',
		  'name'    => $this->element_name( '[blur]' ),
		  'before'  => '<i>' . esc_html__( 'Blur', 'codevz' ) . '</i>',
		  'options' => $options,
		  'dependency' => array( '_shadow_' . $this->field['id'], '!=', 'none' ),
	  ), $this->value['blur'], '', 'field/codevz_box_shadow' );

	  if ( $is_box ) {
			echo codevz_add_field( array(
				'type'    => 'slider',
				'name'    => $this->element_name( '[spread]' ),
				'before'  => '<i>' . esc_html__( 'Spread', 'codevz' ) . '</i>',
				'dependency' => array( '_shadow_' . $this->field['id'], '!=', 'none' ),
			), ( isset( $this->value['spread'] ) ? $this->value['spread'] : '' ), '', 'field/codevz_box_shadow' );
	  }

		if ( Codevz_Plus::is_free() && $this->field['id'] == 'text-shadow' ) {

			echo Codevz_Plus::pro_badge();

		} else {

		  echo codevz_add_field( array(
			  'type'    => 'color_picker',
			  'name'    => $this->element_name( '[color]' ),
			  'attributes' => array(
				'data-rgba' => '#000'
			  ),
			  'dependency' => array( '_shadow_' . $this->field['id'], '!=', 'none' ),
		  ), $this->value['color'], '', 'field/codevz_box_shadow' );

	  }

	  if ( $is_box ) {
		echo codevz_add_field( array(
			'type'    => 'select',
			'name'    => $this->element_name( '[mode]' ),
			'options' => array(
			  'outset'    => esc_html__( 'Outset', 'codevz' ),
			  'inset'     => esc_html__( 'Inset', 'codevz' ),
			),
			'attributes' => array(
			  'data-depend-id' => '_shadow_' . $this->field['id'],
			),
		), ( isset( $this->value['mode'] ) ? $this->value['mode'] : '' ), '', 'field/codevz_box_shadow' );
	  }

	  echo '</fieldset>';
	  echo $this->element_after();

	}
  }
}

/* Add new customize/complex - array field value */
function codevz_sizes_filter_customize( $i ) {
  $i[] = 'codevz_sizes';
  $i[] = 'codevz_box_shadow';
  $i[] = 'sk';

  return $i;
}
add_filter( 'codevz/customize/complex', 'codevz_sizes_filter_customize' );

/* Field: Font select */
if( ! class_exists( 'Codevz_Field_select_font' ) ) {
  class Codevz_Field_select_font extends Codevz_Fields {

	public function __construct( $field, $value = '', $unique = '', $where = '' ) {
	  parent::__construct( $field, $value, $unique, $where );
	}

	public function output() {

	  $value = $this->element_value();
	  $hidden = ( empty( $value ) ) ? ' hidden' : '';

	  echo $this->element_before();
	  echo '<div class="codevz-font-select">';
	  echo '<input type="text" name="'. $this->element_name() .'" value="'. esc_html( $value ) .'"'. $this->element_class( 'codevz-font-value wpb_vc_param_value' ) . $this->element_attributes() .' />';
	  echo '<a href="#" class="button button-primary codevz-font-add">'. esc_html__( 'Choose', 'codevz' ) .'</a>';
	  echo '<a href="#" class="button codevz-warning-primary codevz-font-remove'. esc_html( $hidden ) .'"><i class="fa fa-remove"></i></a>';
	  echo '</div>';
	  echo $this->element_after();
	}

  }
}

/* Font selector get fonts by ajax */
if( ! function_exists( 'codevz_get_fonts' ) ) {
  function codevz_get_fonts() {

	// Websafe fonts
	$websafe = Codevz_Plus::web_safe_fonts();

	// Custom fonts
	$custom_fonts = Codevz_Plus::option( 'custom_fonts' );
	if ( ! empty( $custom_fonts ) ) {
	  foreach ( $custom_fonts as $a ) {
		if ( ! empty( $a['font'] ) ) {
		  array_unshift( $websafe, $a['font'] );
		}
	  }
	}

	unset( $websafe['initial'] );
	unset( $websafe['inherit'] );
	unset( $websafe['czicons'] );
	unset( $websafe['fontelo'] );
	unset( $websafe['FontAwesome'] );
	unset( $websafe['Font Awesome 5 Free'] );

	foreach ( $websafe as $f => $i ) {
	  echo '<a class="websafe_font" style="font-family: ' . $f . '"><span>' . $f . '</span><div class="cz_preview"></div></a>';
	}

	// Google fonts
	$fonts = codevz_get_google_fonts();
	foreach ( $fonts->items as $n => $item ) {
	  $f = $item->family;

	  $params = '';
	  foreach ( $item->variants as $p ) {
		if ( ! Codevz_Plus::contains( $p, 'italic' ) ) {
		  $v = ( $p === 'regular' ) ? '400' : $p;
		  $params .= '<label class="cz_font_variants"><input type="checkbox" name="' . $p . '" value="' . $v . '">' . $p . '</label>';
		}
	  }
	  foreach ( $item->subsets as $p ) {
		if ( $p !== 'latin' ) {
		  $params .= '<label class="cz_font_subsets"><input type="checkbox" name="' . $p . '" value="' . $p . '">' . $p . '</label>';
		}
	  }

	  echo '<a class="cz_font"><span>' . $f . '</span><div class="cz_preview"></div><i class="fa fa-cog"></i></a><div class="cz_font_params"><div>' . $params . '</div></div>';
	}

	wp_die();
  }
  add_action( 'wp_ajax_codevz-get-fonts', 'codevz_get_fonts' );
}

/* Set icons for wp dialog */
if( ! function_exists( 'codevz_set_fonts' ) ) {
  function codevz_set_fonts() {
	?>
	<div id="codevz-modal-font" class="codevz-modal codevz-modal-font">
	  <div class="codevz-modal-table">
		<div class="codevz-modal-table-cell">
		  <div class="codevz-modal-overlay"></div>
		  <div class="codevz-modal-inner">
			<div class="codevz-modal-title">
			  <?php _e( 'Google Fonts Library', 'codevz' ); ?>
			  <div class="codevz-modal-close codevz-font-close"></div>
			</div>
			<div class="codevz-modal-header codevz-text-center">
			  <input type="text" placeholder="<?php esc_html_e( 'Search', 'codevz' ); ?>" class="codevz-font-search" />
			  <input type="text" placeholder="<?php esc_html_e( 'Preview', 'codevz' ); ?>" class="codevz-font-placeholder">
			</div>
			<div class="codevz-modal-content"><div class="codevz-font-loading"></div></div>
		  </div>
		</div>
	  </div>
	</div>
	<?php
  }
  add_action( 'admin_footer', 'codevz_set_fonts' );
  add_action( 'customize_controls_print_footer_scripts', 'codevz_set_fonts' );
  add_action( 'elementor/editor/footer', 'codevz_set_fonts' );
}

/* Field: StyleKit */
if( ! class_exists( 'Codevz_Field_cz_sk' ) ) {

  class Codevz_Field_cz_sk extends Codevz_Fields {

	public function __construct( $field, $value = '', $unique = '', $where = '' ) {
	  parent::__construct( $field, $value, $unique, $where );
	}

	public function output() {
	  echo $this->element_before();
	  $val = $this->element_value();
	  $val = ( is_array( $this->element_value() ) || $val === 'Array' ) ? '' : $this->element_value();
	  $hover = isset( $this->field['hover_id'] ) ? ' data-hover_id="' . $this->field['hover_id'] . '"' : '';
	  echo '<input type="hidden" name="'. $this->element_name() .'"' . $hover . ' value="' . $val . '" data-fields="' . implode( ' ', $this->field['settings'] ) . '"' . $this->element_attributes() . ' />';
	  $is_active = $val ? ' active_stylekit' : '';

	  $bg = '';
	  if ( Codevz_Plus::contains( $val, 'http' ) ) {
		preg_match_all( '/(http|https):\/\/[^ ]+(\.gif|\.jpg|\.jpeg|\.png)/', $val, $img );
		$bg = isset( $img[0][0] ) ? ' style="background-image:url(' . $img[0][0] . ')"' : '';
	  }

	  echo '<a href="#" class="button cz_sk_btn ' . $is_active . '"><span class="cz_skico cz'. $this->field['id']  .'"></span><span class="cz_sk_btn_text">' . esc_html( $this->field['button'] ) . '</span></a><div class="sk_btn_preview_image"' . $bg . '></div>';
	  echo $this->element_after();
	}
  }
}

if( ! class_exists( 'Codevz_Field_cz_sk_free' ) ) {

	class Codevz_Field_cz_sk_free extends Codevz_Fields {

		public function __construct( $field, $value = '', $unique = '', $where = '' ) {
			parent::__construct( $field, $value, $unique, $where );
		}

		public function output() {

			echo $this->element_before();

		  $val = $this->element_value();
		  $val = ( is_array( $this->element_value() ) || $val === 'Array' ) ? '' : $this->element_value();
		  $hover = isset( $this->field['hover_id'] ) ? ' data-hover_id="' . $this->field['hover_id'] . '"' : '';
		  echo '<input type="hidden" name="'. $this->element_name() .'"' . $hover . ' value="' . $val . '" data-fields="' . implode( ' ', $this->field['settings'] ) . '"' . $this->element_attributes() . ' />';

			echo '<a href="#" class="button cz_sk_btn cz_sk_free_btn"><span class="cz_skico cz'. $this->field['id']  .'"></span>' . $this->field['button'] . '</a>';

			echo $this->element_after();

		}

  }

}

/* Field: StyleKit hidden for responsive */
if( ! class_exists( 'Codevz_Field_cz_sk_hidden' ) ) {
  class Codevz_Field_cz_sk_hidden extends Codevz_Fields {
	public function __construct( $field, $value = '', $unique = '', $where = '' ) {
	  parent::__construct( $field, $value, $unique, $where );
	}

	public function output() {
	  $val = $this->element_value();
	  $val = ( is_array( $this->element_value() ) || $val === 'Array' ) ? '' : $this->element_value();
	  echo '<input type="hidden" name="'. $this->element_name() .'" value="' . $val . '"' . $this->element_attributes() . ' />';
	}
  }
}

/* Style kit HTML */
if( ! function_exists( 'codevz_modal_style_kit' ) ) {
  function codevz_modal_style_kit() { ?>
	<div id="cz_modal_kit" title="Styling">
	  <div>
		<form>
		  <?php 

			$free = Codevz_Plus::is_free();

			// Start
			echo '<div class="cz_sk_row cz_sk_content_row clr">';
			echo '<h4>' . esc_html__( 'Content', 'codevz' ) . '</h4>';
			echo '<div class="col s12">' . codevz_add_field( array(
			  'type'    => 'text',
			  'id'      => 'live_id',
			  'name'    => 'live_id',
			  'title'   => 'ID',
			), '' ) . '</div>';
			echo '<div class="col s12">' . codevz_add_field( array(
			  'id'      => 'content',
			  'name'    => 'content',
			  'type'    => 'text',
			  'title'   => esc_html__( 'Content', 'codevz' ),
			  'help'    => esc_html__( 'Any charachters or HTML symbols are allowed', 'codevz' )
			), '' ) . '</div>';
			echo '</div>'; // Start

			// Indicator
			echo '<div class="cz_sk_row cz_sk_indicator_row clr">';
			echo '<h4>' . esc_html__( 'Menu Indicator', 'codevz' ) . '</h4>';
			echo '<div class="col s12">' . codevz_add_field( array(
			  'id'      => '_class_indicator',
			  'name'    => '_class_indicator',
			  'type'    => 'icon',
			  'title'   => ''
			), '' ) . '</div>';
			echo '</div>'; // Indicator

			// Shape
			echo '<div class="cz_sk_row cz_sk_shape_row clr">';
			echo '<h4>' . esc_html__( 'Shape', 'codevz' ) . '</h4>';
			echo '<div class="col s12">' . codevz_add_field( array(
			  'id'      => '_class_shape',
			  'name'    => '_class_shape',
			  'type'    => 'select',
			  'title'   => esc_html__( 'Choose', 'codevz' ),
			  'help'    => esc_html__( 'This option required background color', 'codevz' ),
			  'options'  => array(
				''                                => esc_html__( '~ Default ~', 'codevz' ),
				'cz_row_shape_none'               => esc_html__( 'None', 'codevz' ),
				'cz_row_shape_full_filled_left cz_row_shape_no_right'   => esc_html__( 'Filled left', 'codevz' ),
				'cz_row_shape_full_filled_right cz_row_shape_no_left'  => esc_html__( 'Filled right', 'codevz' ),

				'cz_row_shape_1'  => esc_html__( 'Shape', 'codevz' ) . ' 1',
				'cz_row_shape_2'  => esc_html__( 'Shape', 'codevz' ) . ' 2',

				'cz_row_shape_3'  => esc_html__( 'Shape', 'codevz' ) . ' 3',
				'cz_row_shape_3 cz_row_shape_full_filled_left'  => esc_html__( 'Filled left', 'codevz' ) . ' 3',
				'cz_row_shape_3 cz_row_shape_full_filled_right' => esc_html__( 'Filled right', 'codevz' ) . ' 3',

				'cz_row_shape_4'  => esc_html__( 'Shape', 'codevz' ) . ' 4',
				'cz_row_shape_4 cz_row_shape_full_filled_left'  => esc_html__( 'Filled left', 'codevz' ) . ' 4',
				'cz_row_shape_4 cz_row_shape_full_filled_right' => esc_html__( 'Filled right', 'codevz' ) . ' 4',
			  )
			), '' ) . '</div>';
			echo '</div>'; // Shape

			// FX Menu
			echo '<div class="cz_sk_row cz_sk_fx_row clr">';
			echo '<h4>' . esc_html__( 'Menu FX', 'codevz' ) . '</h4>';
			echo '<div class="col s12">' . codevz_add_field( array(
			  'id'      => '_class_menu_fx',
			  'name'    => '_class_menu_fx',
			  'type'    => 'select',
			  'title'   => esc_html__( 'Choose', 'codevz' ),
			  'help'    => esc_html__( 'You can customize shape by changing settings background, width, height, left, bottom, etc.', 'codevz' ),
			  'options' => array(
				''                          => esc_html__( '~ Default ~', 'codevz' ),
				'cz_menu_fx_none'           => esc_html__( 'None', 'codevz' ),
				'cz_menu_fx_left_to_right'  => esc_html__( 'Left To Right', 'codevz' ),
				'cz_menu_fx_left_to_right_l'=> esc_html__( 'Left To Right Long', 'codevz' ),
				'cz_menu_fx_right_to_left'  => esc_html__( 'Right To Left', 'codevz' ),
				'cz_menu_fx_right_to_left_l'=> esc_html__( 'Right To Left Long', 'codevz' ),
				'cz_menu_fx_center_to_sides'=> esc_html__( 'Center To Sides', 'codevz' ),
				'cz_menu_fx_top_to_bottom'  => esc_html__( 'Top To Bottom', 'codevz' ),
				'cz_menu_fx_bottom_to_top'  => esc_html__( 'Bottom To Top', 'codevz' ),
				'cz_menu_fx_fade_in'    => esc_html__( 'FadeIn', 'codevz' ),
				'cz_menu_fx_zoom_in'    => esc_html__( 'ZoomIn', 'codevz' ),
				'cz_menu_fx_zoom_out'   => esc_html__( 'ZoomOut', 'codevz' ),
				'cz_menu_fx_unroll'     => esc_html__( 'Unroll Vertical', 'codevz' ),
				'cz_menu_fx_unroll_h'   => esc_html__( 'Unroll Horizontal', 'codevz' ),
			  )
			), '' ) . '</div>';
			echo '</div>'; // FX Menu

			// FX SubMenu
			echo '<div class="cz_sk_row cz_sk_fx_row clr">';
			echo '<h4>' . esc_html__( 'Dropdown FX', 'codevz' ) . '</h4>';
			echo '<div class="col s12">' . codevz_add_field( array(
			  'id'      => '_class_submenu_fx',
			  'name'    => '_class_submenu_fx',
			  'type'    => 'select',
			  'title'   => esc_html__( 'Choose', 'codevz' ),
			  'options' => array(
				''                        => esc_html__( '~ Default ~', 'codevz' ),
				'cz_menu_fx_none'         => esc_html__( 'None', 'codevz' ),
				'cz_submenu_fx_blur'      => esc_html__( 'Blur', 'codevz' ),
				'cz_submenu_fx_collapse'  => esc_html__( 'Collapse', 'codevz' ),
				'cz_submenu_fx_moveup'    => esc_html__( 'Move up', 'codevz' ),
				'cz_submenu_fx_movedown'  => esc_html__( 'Move down', 'codevz' ),
				'cz_submenu_fx_moveleft'  => esc_html__( 'Move left', 'codevz' ),
				'cz_submenu_fx_moveright' => esc_html__( 'Move right', 'codevz' ),
				'cz_submenu_fx_zoomin'    => esc_html__( 'Zoom in', 'codevz' ),
				'cz_submenu_fx_zoomout'   => esc_html__( 'Zoom out', 'codevz' ),
				'cz_submenu_fx_rotate1'   => esc_html__( 'Rotate 1', 'codevz' ),
				'cz_submenu_fx_rotate2'   => esc_html__( 'Rotate 2', 'codevz' ),
				'cz_submenu_fx_rotate3'   => esc_html__( 'Rotate 3', 'codevz' ),
				'cz_submenu_fx_rotate4'   => esc_html__( 'Rotate 4', 'codevz' ),
				'cz_submenu_fx_skew1'     => esc_html__( 'Skew 1', 'codevz' ),
				'cz_submenu_fx_skew2'     => esc_html__( 'Skew 2', 'codevz' ),
				'cz_submenu_fx_skew3'     => esc_html__( 'Skew 3', 'codevz' ),
			  )
			), '' ) . '</div>';
			echo '</div>'; // FX SubMenu

			// Typography
			echo '<div class="cz_sk_row cz_sk_typo_row clr">';
			echo '<h4>' . esc_html__( 'Typography', 'codevz' ) . '</h4>';

			echo '<div class="col s6">' . codevz_add_field( array(
			  'id'      => 'font-size',
			  'name'    => 'font-size',
			  'type'    => 'slider',
			  'title'   => esc_html__( 'Font Size', 'codevz' ),
			  'options' => array( 'unit' => 'px', 'step' => 1, 'min' => 0, 'max' => 130 )
			), '' ) . '</div>';

			echo '<div class="col s6">' . codevz_add_field( array(
			  'id'      => 'color',
			  'name'    => 'color',
			  'type'    => 'color_picker',
			  'title'   => esc_html__( 'Text Color', 'codevz' ),
			), '' ) . '</div>';

			echo '<div class="clr cz_hr"></div>';

			echo '<div class="col s12 ' . ( $free ? 'xtra-readonly' : '' ) . '">' . codevz_add_field( array(
			  'id'      => 'font-family',
			  'name'    => 'font-family',
			  'type'    => 'select_font',
			  'title'   => esc_html__( 'Font Family', 'codevz' ) . ( $free ? Codevz_Plus::pro_badge() : '' ),
			), '' ) . '</div>';

			echo '<div class="clr cz_hr"></div>';

			echo '<div class="col s3">' . codevz_add_field( array(
			  'id'      => 'text-align',
			  'name'    => 'text-align',
			  'type'    => 'select',
			  'title'   => '<i class="fa fa-align-justify" data-title="Text Align"></i>',
			  'options' => array(
				'left'    => esc_html__( 'Left', 'codevz' ),
				'right'   => esc_html__( 'Right', 'codevz' ),
				'center'  => esc_html__( 'Center', 'codevz' ),
				'justify' => esc_html__( 'Justify', 'codevz' ),
			  ),
			  'default_option' => esc_html__( 'Select', 'codevz'),
			), '' ) . '</div>';

			echo '<div class="col s3">' . codevz_add_field( array(
			  'id'      => 'font-weight',
			  'name'    => 'font-weight',
			  'type'    => 'select',
			  'title'   => '<i class="fa fa-bold" data-title="Font Weight"></i>',
			  'options' => array(
				'100' => esc_html__( '100 | Thin', 'codevz' ),
				'200' => esc_html__( '200 | Extra Light', 'codevz' ),
				'300' => esc_html__( '300 | Light', 'codevz' ),
				'400' => esc_html__( '400 | Normal', 'codevz' ),
				'500' => esc_html__( '500 | Medium', 'codevz' ),
				'600' => esc_html__( '600 | Semi Bold', 'codevz' ),
				'700' => esc_html__( '700 | Bold', 'codevz' ),
				'800' => esc_html__( '800 | Extra Bold', 'codevz' ),
				'900' => esc_html__( '900 | High Bold', 'codevz' ),
			  ),
			  'default_option' => esc_html__( 'Select', 'codevz'),
			), '' ) . '</div>';

			echo '<div class="col s3">' . codevz_add_field( array(
			  'id'      => 'font-style',
			  'name'    => 'font-style',
			  'type'    => 'select',
			  'title'   => '<i class="fa fa-italic" data-title="Font Style"></i>',
			  'options' => array(
				'normal'  => esc_html__( 'Normal', 'codevz' ),
				'italic'  => esc_html__( 'Italic', 'codevz' ),
				'oblique' => esc_html__( 'Oblique', 'codevz' ),
			  ),
			  'default_option' => esc_html__( 'Select', 'codevz'),
			), '' ) . '</div>';

			echo '<div class="col s3">' . codevz_add_field( array(
			  'id'      => 'line-height',
			  'name'    => 'line-height',
			  'type'    => 'slider',
			  'title'   => '<i class="fa fa-text-height" data-title="Line Height"></i>',
			  'options' => array( 'unit' => '', 'step' => 1, 'min' => 0, 'max' => 80 ),
			), '' ) . '</div>';

			echo '<div class="col s3">' . codevz_add_field( array(
			  'id'      => 'letter-spacing',
			  'name'    => 'letter-spacing',
			  'type'    => 'slider',
			  'title'   => '<i class="fa fa-text-width" data-title="Letter Spacing"></i>',
			  'options' => array( 'unit' => 'px', 'step' => 1, 'min' => -5, 'max' => 20 ),
			), '' ) . '</div>';

			echo '<div class="col s3">' . codevz_add_field( array(
			  'id'      => 'text-transform',
			  'name'    => 'text-transform',
			  'type'    => 'select',
			  'title'   => '<i class="fa fa-font" data-title="Text Transform"></i>',
			  'options' => array(
				'none'      => esc_html__( 'None', 'codevz' ),
				'uppercase' => esc_html__( 'Uppercase', 'codevz' ),
				'lowercase' => esc_html__( 'Lowercase', 'codevz' ),
				'capitalize' => esc_html__( 'Capitalize', 'codevz' )
			  ),
			  'default_option' => esc_html__( 'Select', 'codevz'),
			), '' ) . '</div>';

			echo '<div class="col s3">' . codevz_add_field( array(
			  'id'      => 'text-decoration',
			  'name'    => 'text-decoration',
			  'type'    => 'select',
			  'title'   => '<i class="fa fa-underline" data-title="Text Decoration"></i>',
			  'options' => array(
				'none'              => esc_html__( 'None', 'codevz' ),
				'underline'         => esc_html__( 'Underline', 'codevz' ),
				'overline'          => esc_html__( 'Overline', 'codevz' ),
				'line-through'      => esc_html__( 'Line through', 'codevz' ),
			  ),
			  'default_option' => esc_html__( 'Select', 'codevz'),
			), '' ) . '</div>';
			echo '</div>'; // Typography

			// SVG
			echo '<div class="cz_sk_row cz_sk_svg_row clr">';
			echo '<h4>' . esc_html__( 'SVG Settings', 'codevz' ) . '</h4>';
			echo '<div class="col s12">' . codevz_add_field( array(
			  'id'        => '_class_svg_type',
			  'name'      => '_class_svg_type',
			  'type'      => 'select',
			  'title'     => esc_html__( 'SVG Type', 'codevz' ),
			  'options'   => array(
				'dots'      => esc_html__( 'Dots', 'codevz' ),
				'circle'    => esc_html__( 'Circle', 'codevz' ),
				'line'      => esc_html__( 'Lines', 'codevz' ),
				'x'         => esc_html__( 'X', 'codevz' ),
				'empty'     => esc_html__( 'Empty', 'codevz' ),
			  ),
			  'default_option' => esc_html__( 'Select', 'codevz'),
			  'attributes' => array(
				'data-depend-id' => '_class_svg_type',
			  ),
			), '' ) . '</div>';

			echo '<div class="col s12">' . codevz_add_field( array(
			  'id'        => '_class_svg_size',
			  'name'      => '_class_svg_size',
			  'type'      => 'slider',
			  'title'     => esc_html__( 'SVG Size', 'codevz' ),
			  'options'   => array( 'unit' => '', 'step' => 1, 'min' => 1, 'max' => 10 ),
			), '' ) . '</div>';

			echo '<div class="col s12">' . codevz_add_field( array(
			  'id'        => '_class_svg_color',
			  'name'      => '_class_svg_color',
			  'type'      => 'color_picker',
			  'title'     => esc_html__( 'SVG Color', 'codevz' )
			), '' ) . '</div>';

			echo '</div>'; // SVG

			// Background
			echo '<div class="cz_sk_row cz_sk_bg_row clr">';
			echo '<h4>' . esc_html__( 'Background', 'codevz' ) . '</h4><div class="col s12">' . codevz_add_field( array(
			  'id'      => 'background',
			  'name'    => 'background',
			  'type'    => 'background',
			  'title'   => ''
			), '' ) . '</div></div>';

			// Sizes
			echo '<div class="cz_sk_row cz_sk_size_row clr">';
			echo '<h4>' . esc_html__( 'Sizes', 'codevz' ) . '</h4>';
			echo '<div class="col s6">' . codevz_add_field( array(
			  'id'      => 'width',
			  'name'    => 'width',
			  'type'    => 'slider',
			  'title'   => esc_html__( 'Width', 'codevz' ),
			  'options' => array( 'unit' => 'px', 'step' => 1, 'min' => 0, 'max' => 1200 ),
			), '' ) . '</div>';
			echo '<div class="col s6">' .codevz_add_field( array(
			  'id'      => 'height',
			  'name'    => 'height',
			  'type'    => 'slider',
			  'title'   => esc_html__( 'Height', 'codevz' ),
			  'options' => array( 'unit' => 'px', 'step' => 1, 'min' => 0, 'max' => 600 ),
			), '' ) . '</div>';
			echo '</div>'; // Sizes

			// Spaces
			echo '<div class="cz_sk_row cz_sk_spaces_row clr">';
			
			echo '<h4>' . esc_html__( 'Spaces', 'codevz' ) . '</h4>';

			echo '<div class="col s12">' . codevz_add_field( array(
			  'id'        => 'padding',
			  'name'      => 'padding',
			  'type'      => 'codevz_sizes',
			  'title'     => esc_html__( 'Padding', 'codevz' ),
			  'desc'      => esc_html__( 'Inner gap', 'codevz' ),
			  'options'   => array( 'unit' => 'px', 'step' => 1, 'min' => 0, 'max' => 100 ),
			  'help'      => esc_html__( 'Creating space around an element, INSIDE of any defined margins and borders. Can set using px, %, em, ...', 'codevz' )
			), '' ) . '</div>';
			echo '<div class="clr cz_hr"></div>';

			echo '<div class="col s12">' . codevz_add_field( array(
			  'id'        => 'margin',
			  'name'      => 'margin',
			  'type'      => 'codevz_sizes',
			  'title'     => esc_html__( 'Margin', 'codevz' ),
			  'desc'      => esc_html__( 'Outer gap', 'codevz' ),
			  'options'   => array( 'unit' => 'px', 'step' => 1, 'min' => -50, 'max' => 100 ),
			  'help'      => esc_html__( 'Creating space around an element, OUTSIDE of any defined borders. Can set using px, %, em, auto, ...', 'codevz' )
			), '' ) . '</div>';

			echo '</div>'; // Spaces

			// Border
			echo '<div class="cz_sk_row cz_sk_border_row clr">';
			echo '<h4>' . esc_html__( 'Border', 'codevz' ) . '</h4>';
			echo '<div class="col s12">' . codevz_add_field( array(
			  'id'        => 'border-style',
			  'name'      => 'border-style',
			  'type'      => 'select',
			  'title'     => esc_html__( 'Border', 'codevz' ),
			  'options'   => array(
				'solid'     => esc_html__( 'Solid', 'codevz' ),
				'dotted'    => esc_html__( 'Dotted', 'codevz' ),
				'dashed'    => esc_html__( 'Dashed', 'codevz' ),
				'double'    => esc_html__( 'Double', 'codevz' ),
				'none'      => esc_html__( 'None', 'codevz' ),
			  ),
			  'default_option' => esc_html__( '~ Select ~', 'codevz'),
			  'attributes' => array(
				'data-depend-id' => 'border-style',
			  ),
			), '' );

			echo codevz_add_field( array(
			  'id'        => 'border-width',
			  'name'      => 'border-width',
			  'type'      => 'codevz_sizes',
			  'options'   => array( 'unit' => 'px', 'step' => 1, 'min' => 1, 'max' => 100 ),
			  'title'     => esc_html__( 'Width', 'codevz' ),
			  'desc'      => esc_html__( 'Around element', 'codevz' ),
			  'help'      => esc_html__( 'Border size around element.', 'codevz' ),
			  'dependency' => array( 'border-style|border-style', '!=|!=', '|none' ),
			), '' );

			echo codevz_add_field( array(
			  'id'        => 'border-color',
			  'name'      => 'border-color',
			  'type'      => 'color_picker',
			  'title'     => esc_html__( 'Border Color', 'codevz' ),
			  'dependency' => array( 'border-style|border-style', '!=|!=', '|none' ),
			), '' );

			echo codevz_add_field( array(
			  'id'        => 'border-right-color',
			  'name'      => 'border-right-color',
			  'type'      => 'color_picker',
			  'title'     => esc_html__( 'Border right color', 'codevz' )
			), '' );

			echo codevz_add_field( array(
			  'id'        => 'border-radius',
			  'name'      => 'border-radius',
			  'type'      => 'slider',
			  'title'     => esc_html__( 'Radius', 'codevz' ),
			  'help'      => esc_html__( 'Generate the arc for lines around element, e.g. 10px or manually set with this four positions respectively: <br />Top Right Bottom Left <br/><br/>e.g. 10px 10px 10px 10px', 'codevz' )
			), '' ) . '</div>';
			echo '</div>'; // Border

			// Shadows
			echo '<div class="cz_sk_row cz_sk_shadow_row clr">';
			echo '<h4>' . esc_html__( 'Shadow', 'codevz' ) . '</h4>';
			echo '<div class="col s12">' . codevz_add_field( array(
			  'id'        => 'box-shadow',
			  'name'      => 'box-shadow',
			  'type'      => 'codevz_box_shadow',
			  'title'     => esc_html__( 'Box Shadow', 'codevz' ),
			  'desc'      => esc_html__( 'Around element', 'codevz' )
			), '' ) . '</div>';
			echo '<div class="clr cz_hr"></div>';
			echo '<div class="col s12 ' . ( $free ? 'xtra-readonly' : '' ) . '">' . codevz_add_field( array(
			  'id'        => 'text-shadow',
			  'name'      => 'text-shadow',
			  'type'      => 'codevz_box_shadow',
			  'title'     => esc_html__( 'Text Shadow', 'codevz' ),
			  'desc'      => esc_html__( 'Around letters', 'codevz' )
			), '' ) . '</div>';
			echo '</div>'; // Shadows

			// Advanced
			echo '<div class="cz_sk_row cz_sk_advance_row clr">';
			echo '<h4>' . esc_html__( 'Display & Position', 'codevz' ) . '</h4>';

			echo '<div class="col s4">' . codevz_add_field( array(
			  'id'      => 'display',
			  'name'    => 'display',
			  'type'    => 'select',
			  'title'   => esc_html__( 'Display', 'codevz' ),
			  'options' => array(
					'none'                => esc_html__( 'None', 'codevz' ),
					'block'               => esc_html__( 'Block', 'codevz' ),
					'inline'              => esc_html__( 'Inline', 'codevz' ),
					'inline-block'        => esc_html__( 'Inline Block', 'codevz' ),
					'flex'                => esc_html__( 'Flex', 'codevz' ),
					'flow-root'           => esc_html__( 'Flow root', 'codevz' ),
					'list-item'           => esc_html__( 'List item', 'codevz' ),
					'table'               => esc_html__( 'Table', 'codevz' ),
					'table-cell'          => esc_html__( 'Table Cell', 'codevz' ),
					'unset'               => esc_html__( 'Unset', 'codevz' ),
					'initial'             => esc_html__( 'Initial', 'codevz' ),
			  ),
			  'default_option' => esc_html__( '~ Default ~', 'codevz'),
			), '' ) . '</div>';

			echo '<div class="col s4">' . codevz_add_field( array(
			  'id'      => 'float',
			  'name'    => 'float',
			  'type'    => 'select',
			  'title'   => esc_html__( 'Float', 'codevz' ),
			  'options' => array(
				'left'      => esc_html__( 'Left', 'codevz' ),
				'right'     => esc_html__( 'Right', 'codevz' ),
				'none'      => esc_html__( 'None', 'codevz' ),
				'unset'     => esc_html__( 'Unset', 'codevz' ),
				'initial'   => esc_html__( 'Initial', 'codevz' ),
				'inherit'   => esc_html__( 'Inherit', 'codevz' ),
			  ),
			  'default_option' => esc_html__( '~ Select ~', 'codevz'),
			), '' ) . '</div>';

			echo '<div class="col s4">' . codevz_add_field( array(
			  'id'      => 'position',
			  'name'    => 'position',
			  'type'    => 'select',
			  'title'   => esc_html__( 'Position', 'codevz' ),
			  'options' => array(
				'static'        => esc_html__( 'Static', 'codevz' ),
				'relative'      => esc_html__( 'Relative', 'codevz' ),
				'absolute'      => esc_html__( 'Absolute', 'codevz' ),
				'initial'       => esc_html__( 'Initial', 'codevz' ),
			  ),
			  'default_option' => esc_html__( '~ Default ~', 'codevz'),
			), '' ) . '</div>';

			echo '<div class="clr cz_hr"></div>';

			echo '<div class="col s6">' . codevz_add_field( array(
			  'id'        => 'top',
			  'name'      => 'top',
			  'type'      => 'slider',
			  'title'     => esc_html__( 'Top', 'codevz' ),
			  'options'   => array( 'unit' => 'px', 'step' => 1, 'min' => -100, 'max' => 200 )
			), '' ) . '</div>';

			echo '<div class="col s6">' . codevz_add_field( array(
			  'id'        => 'right',
			  'name'      => 'right',
			  'type'      => 'slider',
			  'title'     => esc_html__( 'Right', 'codevz' ),
			  'options'   => array( 'unit' => 'px', 'step' => 1, 'min' => -100, 'max' => 200 )
			), '' ) . '</div>';

			echo '<div class="col s6">' . codevz_add_field( array(
			  'id'        => 'bottom',
			  'name'      => 'bottom',
			  'type'      => 'slider',
			  'title'     => esc_html__( 'Bottom', 'codevz' ),
			  'options'   => array( 'unit' => 'px', 'step' => 1, 'min' => -100, 'max' => 200 )
			), '' ) . '</div>';

			echo '<div class="col s6">' . codevz_add_field( array(
			  'id'        => 'left',
			  'name'      => 'left',
			  'type'      => 'slider',
			  'title'     => esc_html__( 'Left', 'codevz' ),
			  'options'   => array( 'unit' => 'px', 'step' => 1, 'min' => -100, 'max' => 200 )
			), '' ) . '</div>';

			echo '</div>';

			echo '<div class="cz_sk_row cz_sk_advance_row clr ' . ( $free ? 'xtra-readonly' : '' ) . '">';
			echo '<h4>' . esc_html__( 'Advanced', 'codevz' ) . ( $free ? Codevz_Plus::pro_badge() : '' ) . '</h4>';

			echo '<div class="col s6">' . codevz_add_field( array(
			  'id'      => 'z-index',
			  'name'    => 'z-index',
			  'type'    => 'select',
			  'title'   => esc_html__( 'z-index', 'codevz' ),
			  'options' => array(
				'-2'  => '-2',
				'-1'  => '-1',
				'0'   => '0',
				'1'   => '1',
				'2'   => '2',
				'3'   => '3',
				'4'   => '4',
				'5'   => '5',
				'6'   => '6',
				'7'   => '7',
				'8'   => '8',
				'9'   => '9',
				'10'  => '10',
				'99'  => '99',
				'999' => '999',
				'9999' => '9999',
			  ),
			  'default_option' => esc_html__( '~ Select ~', 'codevz'),
			), '' ) . '</div>';

			echo '<div class="col s6">' . codevz_add_field( array(
			  'id'      => 'opacity',
			  'name'    => 'opacity',
			  'type'    => 'select',
			  'title'   => esc_html__( 'Opacity', 'codevz' ),
			  'options' => array(
				'1'      => '1',
				'0.95'   => '0.95',
				'0.9'    => '0.9',
				'0.85'   => '0.85',
				'0.8'    => '0.8',
				'0.75'   => '0.75',
				'0.7'    => '0.7',
				'0.65'   => '0.65',
				'0.6'    => '0.6',
				'0.55'   => '0.55',
				'0.5'    => '0.5',
				'0.45'   => '0.45',
				'0.4'    => '0.4',
				'0.35'   => '0.35',
				'0.3'    => '0.3',
				'0.25'   => '0.25',
				'0.2'    => '0.2',
				'0.15'   => '0.15',
				'0.1'    => '0.1',
				'0.05'   => '0.05',
				'0.0'    => '0.0',
			  ),
			  'default_option' => esc_html__( '~ Select ~', 'codevz'),
			), '' ) . '</div>';

			echo '<div class="col s6">' . codevz_add_field( array(
			  'id'      => 'blur',
			  'name'    => 'blur',
			  'type'    => 'slider',
			  'options' => array( 'unit' => 'px', 'step' => 1, 'min' => 0, 'max' => 20 ),
			  'title'   => esc_html__( 'Blur', 'codevz' )
			), '' ) . '</div>';

			echo '<div class="col s6">' . codevz_add_field( array(
			  'id'      => 'grayscale',
			  'name'    => 'grayscale',
			  'type'    => 'select',
			  'title'   => esc_html__( 'Grayscale', 'codevz' ),
			  'options' => array(
				'100%'      => esc_html__( 'Yes', 'codevz' ),
				'0%'        => esc_html__( 'No', 'codevz' ),
			  ),
			  'default_option' => esc_html__( '~ Select ~', 'codevz'),
			), '' ) . '</div>';

			echo '<div class="col s6">' . codevz_add_field( array(
			  'id'        => 'transform',
			  'name'      => 'transform',
			  'type'      => 'slider',
			  'title'     => esc_html__( 'Rotate', 'codevz' ),
			  'options'   => array( 'unit' => 'deg', 'step' => 1, 'min' => 0, 'max' => 360 ),
			), '' ) . '</div>';

			echo '<div class="col s6">' . codevz_add_field( array(
			  'id'      => 'box-sizing',
			  'name'    => 'box-sizing',
			  'type'    => 'select',
			  'title'   => esc_html__( 'Box Sizing', 'codevz' ),
			  'options' => array(
				'border-box'      	=> esc_html__( 'Border box', 'codevz' ),
				'content-box'     	=> esc_html__( 'Content box', 'codevz' ),
				'initial'     		=> esc_html__( 'Initial', 'codevz' ),
			  ),
			  'default_option' => esc_html__( '~ Select ~', 'codevz'),
			), '' ) . '</div>';
			echo '</div>'; // Advanced Settings

			// Custom
			echo '<div class="cz_sk_row cz_sk_custom clr ' . ( $free ? 'xtra-readonly' : '' ) . '" style="display: none">';
			echo '<h4>' . esc_html__( 'Custom CSS', 'codevz' ) . ( $free ? Codevz_Plus::pro_badge() : '' ) . '</h4>';
			echo '<div class="col s12">' . codevz_add_field( array(
			  'id'      => $free ? 'xxx' : 'custom',
			  'name'    => 'custom',
			  'type'    => 'textarea',
			  'title'   => '',
			  'attributes' => array(
					'placeholder' => 'property: value;',
					'rows' 				=> '2',
					'cols' 				=> '5'
				),
			  'help'    => esc_html__( 'You can add custom css for this element.', 'codevz' ) . '<br /><br />e.g.<br /><br />transform: rotate(10deg);'
			), '' ) . '</div>';
			echo '</div>'; // Custom

			// Custom RTL
			echo '<div class="cz_sk_row cz_custom_rtl clr">';
			echo '<h4>' . esc_html__( 'RTL mode', 'codevz' ) . '</h4>';
			echo '<div class="col s12"><a href="#" class="xtra-auto-rtl button-primary">Auto RTL</a>' . codevz_add_field( array(
			  'id'      => 'rtl',
			  'name'    => 'rtl',
			  'type'    => 'textarea',
			  'title'   => '',
			  'attributes' => array(
				'placeholder' => 'property: value;',
				'rows' => '2',
				'cols' => '5',
			  ),
			), '' ) . '</div>';
			echo '</div>';

		  ?>
		</form>
	  </div>
	</div>
	<?php
  }
  add_action( 'admin_footer', 'codevz_modal_style_kit' );
  add_action( 'customize_controls_print_footer_scripts', 'codevz_modal_style_kit' );
  add_action( 'elementor/editor/footer', 'codevz_modal_style_kit' );
}


/* Field: codevz image dropdown */
if( ! class_exists( 'Codevz_Field_codevz_image_select' ) ) {
  class Codevz_Field_codevz_image_select extends Codevz_Fields {
	public function __construct( $field, $value = '', $unique = '', $where = '' ) {
	  parent::__construct( $field, $value, $unique, $where );
	}

	public function output() {

	  $val = $this->element_value();

	  echo $this->element_before();

	  if ( $val ) {
		$default_id = $val;
	  } else if ( isset( $this->field['default'] ) ) {
		$default_id = $this->field['default'];
	  } else {
		foreach ( $this->field['options'] as $key => $item ) {
		  $default_id = $key;
		  break;
		}
	  }

	  $default_title = isset( $this->field['options'][ $default_id ][0] ) ? $this->field['options'][ $default_id ][0] : '...';
	  $default_image = isset( $this->field['options'][ $default_id ][1] ) ? $this->field['options'][ $default_id ][1] : '';

	  echo '<div class="codevz_image_select">';
	  echo '<div data-id="' . $default_id . '">';
	  echo '<img src="' . $default_image . '" /><span><b>' . $this->field['title'] . '</b><span>' . $default_title . '</span></span>';
	  echo '<i class="fa fa-angle-down"></i>';
	  echo '</div>';

	  echo '<ul>';
	  foreach ( $this->field['options'] as $key => $item ) {
	  	$class = Codevz_Plus::contains( $item[0], '[' ) ? 'xtra-li-red' : '';
			echo '<li class="' . $class . '" data-id="' . $key . '" data-title="' . $item[0] . '"><img src="' . $item[1] . '" /></li>';
	  }
	  echo '</ul>';

	  echo '<input type="hidden" name="'. $this->element_name() .'" value="'. $val .'"'. $this->element_class() . $this->element_attributes() .'/>';

	  echo '</div>';

	  echo $this->element_after();
	}
  }
}