| Server IP : 146.59.209.152 / Your IP : 216.73.216.46 Web Server : Apache System : Linux webm005.cluster131.gra.hosting.ovh.net 5.15.167-ovh-vps-grsec-zfs-classid #1 SMP Tue Sep 17 08:14:20 UTC 2024 x86_64 User : infrafs ( 43850) PHP Version : 8.2.29 Disable Function : _dyuweyrj4,_dyuweyrj4r,dl MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/infrafs/www/wp-content/plugins/eltd-core/shortcodes/icon/ |
Upload File : |
<?php
namespace ElatedCore\CPT\Shortcodes\Icon;
use ElatedCore\Lib;
class Icon implements Lib\ShortcodeInterface {
public function __construct() {
$this->base = 'eltd_icon';
add_action('vc_before_init', array($this, 'vcMap'));
}
public function getBase() {
return $this->base;
}
public function vcMap() {
if(function_exists('vc_map')) {
vc_map(
array(
'name' => esc_html__( 'Elated Icon', 'eltd-core' ),
'base' => $this->base,
'category' => esc_html__( 'by ELATED', 'eltd-core' ),
'icon' => 'icon-wpb-icon extended-custom-icon',
'allowed_container_element' => 'vc_row',
'params' => array_merge(
array(
array(
'type' => 'textfield',
'param_name' => 'custom_class',
'heading' => esc_html__( 'Custom CSS Class', 'eltd-core' ),
'description' => esc_html__( 'Style particular content element differently - add a class name and refer to it in custom CSS', 'eltd-core' )
)
),
\TrackStoreElatedIconCollections::get_instance()->getVCParamsArray(),
array(
array(
'type' => 'dropdown',
'param_name' => 'size',
'heading' => esc_html__( 'Size', 'eltd-core' ),
'value' => array(
esc_html__( 'Tiny', 'eltd-core' ) => 'eltd-icon-tiny',
esc_html__( 'Small', 'eltd-core' ) => 'eltd-icon-small',
esc_html__( 'Medium', 'eltd-core' ) => 'eltd-icon-medium',
esc_html__( 'Large', 'eltd-core' ) => 'eltd-icon-large',
esc_html__( 'Huge', 'eltd-core' ) => 'eltd-icon-huge'
)
),
array(
'type' => 'textfield',
'param_name' => 'custom_size',
'heading' => esc_html__( 'Custom Size (px)', 'eltd-core' )
),
array(
'type' => 'dropdown',
'param_name' => 'type',
'heading' => esc_html__( 'Type', 'eltd-core' ),
'value' => array(
esc_html__( 'Normal', 'eltd-core' ) => 'eltd-normal',
esc_html__( 'Circle', 'eltd-core' ) => 'eltd-circle',
esc_html__( 'Square', 'eltd-core' ) => 'eltd-square'
),
'save_always' => true
),
array(
'type' => 'textfield',
'param_name' => 'border_radius',
'heading' => esc_html__( 'Border Radius', 'eltd-core' ),
'description' => esc_html__( 'Please insert border radius(Rounded corners) in px. For example: 4 ', 'eltd-core' ),
'dependency' => array( 'element' => 'type', 'value' => array( 'eltd-square' ) )
),
array(
'type' => 'textfield',
'param_name' => 'shape_size',
'heading' => esc_html__( 'Shape Size (px)', 'eltd-core' ),
'dependency' => array( 'element' => 'type', 'value' => array( 'eltd-circle', 'eltd-square' ) )
),
array(
'type' => 'colorpicker',
'param_name' => 'icon_color',
'heading' => esc_html__( 'Icon Color', 'eltd-core' )
),
array(
'type' => 'colorpicker',
'param_name' => 'border_color',
'heading' => esc_html__( 'Border Color', 'eltd-core' ),
'dependency' => array( 'element' => 'type', 'value' => array( 'eltd-circle', 'eltd-square' ) )
),
array(
'type' => 'textfield',
'param_name' => 'border_width',
'heading' => esc_html__( 'Border Width', 'eltd-core' ),
'dependency' => array( 'element' => 'type', 'value' => array( 'eltd-circle', 'eltd-square' ) )
),
array(
'type' => 'colorpicker',
'param_name' => 'background_color',
'heading' => esc_html__( 'Background Color', 'eltd-core' ),
'dependency' => array( 'element' => 'type', 'value' => array( 'eltd-circle', 'eltd-square' ) )
),
array(
'type' => 'colorpicker',
'param_name' => 'hover_icon_color',
'heading' => esc_html__( 'Hover Icon Color', 'eltd-core' )
),
array(
'type' => 'colorpicker',
'param_name' => 'hover_border_color',
'heading' => esc_html__( 'Hover Border Color', 'eltd-core' ),
'dependency' => array( 'element' => 'type', 'value' => array( 'eltd-circle', 'eltd-square' ) )
),
array(
'type' => 'colorpicker',
'param_name' => 'hover_background_color',
'heading' => esc_html__( 'Hover Background Color', 'eltd-core' ),
'dependency' => array( 'element' => 'type', 'value' => array( 'eltd-circle', 'eltd-square' ) )
),
array(
'type' => 'textfield',
'param_name' => 'margin',
'heading' => esc_html__( 'Margin', 'eltd-core' ),
'description' => esc_html__( 'Insert margin in format: top right bottom left (e.g. 10px 5px 10px 5px)', 'eltd-core' )
),
array(
'type' => 'dropdown',
'param_name' => 'icon_animation',
'heading' => esc_html__( 'Icon Animation', 'eltd-core' ),
'value' => array_flip( trackstore_elated_get_yes_no_select_array( false ) )
),
array(
'type' => 'textfield',
'param_name' => 'icon_animation_delay',
'heading' => esc_html__( 'Icon Animation Delay (ms)', 'eltd-core' ),
'dependency' => array( 'element' => 'icon_animation', 'value' => 'yes' )
),
array(
'type' => 'textfield',
'param_name' => 'link',
'heading' => esc_html__( 'Link', 'eltd-core' )
),
array(
'type' => 'checkbox',
'param_name' => 'anchor_icon',
'heading' => esc_html__( 'Use Link as Anchor', 'eltd-core' ),
'value' => array( 'Use this icon as Anchor?' => 'yes' ),
'description' => esc_html__( 'Check this box to use icon as anchor link (eg. #contact)', 'eltd-core' ),
'dependency' => Array( 'element' => 'link', 'not_empty' => true )
),
array(
'type' => 'dropdown',
'param_name' => 'target',
'heading' => esc_html__( 'Target', 'eltd-core' ),
'value' => array_flip( trackstore_elated_get_link_target_array() ),
'dependency' => array( 'element' => 'link', 'not_empty' => true )
)
)
)
)
);
}
}
public function render( $atts, $content = null ) {
$default_atts = array(
'custom_class' => '',
'size' => '',
'custom_size' => '',
'type' => 'eltd-normal',
'border_radius' => '',
'shape_size' => '',
'icon_color' => '',
'border_color' => '',
'border_width' => '',
'background_color' => '',
'hover_icon_color' => '',
'hover_border_color' => '',
'hover_background_color' => '',
'margin' => '',
'icon_animation' => '',
'icon_animation_delay' => '',
'link' => '',
'anchor_icon' => '',
'target' => '_self'
);
$default_atts = array_merge( $default_atts, trackstore_elated_icon_collections()->getShortcodeParams() );
$params = shortcode_atts( $default_atts, $atts );
$iconPackName = trackstore_elated_icon_collections()->getIconCollectionParamNameByKey( $params['icon_pack'] );
$params['icon'] = $params[ $iconPackName ];
$params['icon_holder_classes'] = $this->generateIconHolderClasses( $params );
$params['icon_holder_styles'] = $this->generateIconHolderStyles( $params );
$params['icon_holder_data'] = $this->generateIconHolderData( $params );
$params['icon_params'] = $this->generateIconParams( $params );
$params['icon_animation_holder'] = isset( $params['icon_animation'] ) && $params['icon_animation'] == 'yes';
$params['icon_animation_holder_styles'] = $this->generateIconAnimationHolderStyles( $params );
$params['link_class'] = $this->getLinkClass( $params );
$params['target'] = ! empty( $params['target'] ) ? $params['target'] : $default_atts['target'];
$html = eltd_core_get_shortcode_module_template_part( 'templates/icon', 'icon', '', $params );
return $html;
}
private function generateIconHolderClasses( $params ) {
$holderClasses = array( 'eltd-icon-shortcode', $params['type'] );
$holderClasses[] = ! empty( $params['custom_class'] ) ? esc_attr( $params['custom_class'] ) : '';
$holderClasses[] = $params['icon_animation'] == 'yes' ? 'eltd-icon-animation' : '';
$holderClasses[] = ! empty( $params['size'] ) ? $params['size'] : '';
return implode( ' ', $holderClasses );
}
private function generateIconParams( $params ) {
$iconParams = array( 'icon_attributes' => array() );
$iconParams['icon_attributes']['style'] = $this->generateIconStyles( $params );
$iconParams['icon_attributes']['class'] = 'eltd-icon-element';
return $iconParams;
}
private function generateIconStyles( $params ) {
$iconStyles = array();
if ( ! empty( $params['icon_color'] ) ) {
$iconStyles[] = 'color: ' . $params['icon_color'];
}
if ( ( $params['type'] !== 'eltd-normal' && ! empty( $params['shape_size'] ) ) || ( $params['type'] == 'eltd-normal' ) ) {
if ( ! empty( $params['custom_size'] ) ) {
$iconStyles[] = 'font-size:' . trackstore_elated_filter_px( $params['custom_size'] ) . 'px';
}
}
return implode( ';', $iconStyles );
}
private function generateIconHolderStyles( $params ) {
$iconHolderStyles = array();
if ( $params['margin'] !== '' ) {
$iconHolderStyles[] = 'margin: ' . $params['margin'];
}
if ( $params['type'] !== 'eltd-normal' ) {
$shapeSize = '';
if ( ! empty( $params['shape_size'] ) ) {
$shapeSize = $params['shape_size'];
} elseif ( ! empty( $params['custom_size'] ) ) {
$shapeSize = $params['custom_size'];
}
if ( ! empty( $shapeSize ) ) {
$iconHolderStyles[] = 'width: ' . trackstore_elated_filter_px( $shapeSize ) . 'px';
$iconHolderStyles[] = 'height: ' . trackstore_elated_filter_px( $shapeSize ) . 'px';
$iconHolderStyles[] = 'line-height: ' . trackstore_elated_filter_px( $shapeSize ) . 'px';
}
if ( ! empty( $params['background_color'] ) ) {
$iconHolderStyles[] = 'background-color: ' . $params['background_color'];
}
if ( ! empty( $params['border_color'] ) && ( isset( $params['border_width'] ) && $params['border_width'] !== '' ) ) {
$iconHolderStyles[] = 'border-style: solid';
$iconHolderStyles[] = 'border-color: ' . $params['border_color'];
$iconHolderStyles[] = 'border-width: ' . trackstore_elated_filter_px( $params['border_width'] ) . 'px';
} else if ( isset( $params['border_width'] ) && $params['border_width'] !== '' ) {
$iconHolderStyles[] = 'border-style: solid';
$iconHolderStyles[] = 'border-width: ' . trackstore_elated_filter_px( $params['border_width'] ) . 'px';
} else if ( ! empty( $params['border_color'] ) ) {
$iconHolderStyles[] = 'border-color: ' . $params['border_color'];
}
if ( $params['type'] == 'eltd-square' ) {
if ( isset( $params['border_radius'] ) && $params['border_radius'] !== '' ) {
$iconHolderStyles[] = 'border-radius: ' . trackstore_elated_filter_px( $params['border_radius'] ) . 'px';
}
}
}
return $iconHolderStyles;
}
private function generateIconHolderData( $params ) {
$iconHolderData = array();
if ( isset( $params['type'] ) && $params['type'] !== 'eltd-normal' ) {
if ( ! empty( $params['hover_border_color'] ) ) {
$iconHolderData['data-hover-border-color'] = $params['hover_border_color'];
}
if ( ! empty( $params['hover_background_color'] ) ) {
$iconHolderData['data-hover-background-color'] = $params['hover_background_color'];
}
}
if ( ( isset( $params['icon_animation'] ) && $params['icon_animation'] == 'yes' )
&& ( isset( $params['icon_animation_delay'] ) && $params['icon_animation_delay'] !== '' )
) {
$iconHolderData['data-animation-delay'] = $params['icon_animation_delay'];
}
if ( ! empty( $params['hover_icon_color'] ) ) {
$iconHolderData['data-hover-color'] = $params['hover_icon_color'];
}
if ( ! empty( $params['icon_color'] ) ) {
$iconHolderData['data-color'] = $params['icon_color'];
}
return $iconHolderData;
}
private function generateIconAnimationHolderStyles( $params ) {
$styles = array();
if ( ( isset( $params['icon_animation'] ) && $params['icon_animation'] == 'yes' ) && ( isset( $params['icon_animation_delay'] ) && $params['icon_animation_delay'] !== '' ) ) {
$styles[] = '-webkit-transition-delay: ' . $params['icon_animation_delay'] . 'ms';
$styles[] = '-moz-transition-delay: ' . $params['icon_animation_delay'] . 'ms';
$styles[] = 'transition-delay: ' . $params['icon_animation_delay'] . 'ms';
}
return $styles;
}
private function getLinkClass( $params ) {
$class = '';
if ( $params['anchor_icon'] != '' && $params['anchor_icon'] == 'yes' ) {
$class .= 'eltd-anchor';
}
return $class;
}
}