HEX
Server: Apache
System: Linux web2213.uni5.net 5.4.282-1.el8.elrepo.x86_64 #1 SMP Mon Aug 19 18:33:22 EDT 2024 x86_64
User: clinicamaciel (596848)
PHP: 7.3.33
Disabled: apache_child_terminate,c99_buff_prepare,c99_sess_put,dl,eval,exec,leak,link,myshellexec,openlog,passthru,pclose,pcntl_exec,php_check_syntax,php_strip_whitespace,popen,posix_kill,posix_mkfifo,posix_setpgid,posix_setsid,posix_setuid,proc_close,proc_get_status,proc_nice,proc_open,proc_terminate,shell_exec,show_source,symlink,system,socket_listen,socket_create_listen,putenv
Upload Files
File: /home/clinicamaciel/www/wp-content/plugins/vc-extensions-bundle/sticker/vc-extensions-sticker.php
<?php
if (!class_exists('VC_Extensions_Sticker')) {
    class VC_Extensions_Sticker{
        function __construct() {
          if(version_compare(WPB_VC_VERSION,  "4.4")>= 0){
            vc_map(array(
            "name" => __("Sticker", 'vc_sticker_cq'),
            "base" => "cq_vc_sticker",
            "class" => "wpb_cq_vc_extension_sticker",
            // "as_parent" => array('only' => 'cq_vc_sticker_item'),
            "icon" => "cq_allinone_sticker",
            "category" => __('Sike Extensions', 'js_composer'),
            // "content_element" => false,
            // "show_settings_on_create" => false,
            'description' => __('With icon or image', 'js_composer'),
            "params" => array(
              array(
                "type" => "dropdown",
                "holder" => "",
                "class" => "vc_sticker_cq",
                "heading" => __("Display the sticker with:", "vc_sticker_cq"),
                "param_name" => "backgroundtype",
                "value" => array("Solid background color" => "solid", "Gradient background color" => "gradient", "Image" => "image"),
                "description" => __("", "vc_sticker_cq")
              ),
              array(
                "type" => "dropdown",
                "holder" => "",
                "class" => "vc_sidebyside_cq",
                "heading" => __("Choose a built-in solid color:", "vc_sidebyside_cq"),
                "param_name" => "builtsolidcolor",
                "value" => array("Grape Fruit" => "grapefruit", "Bitter Sweet" => "bittersweet", "Sunflower" => "sunflower", "Grass" => "grass", "Mint" => "mint", "Aqua" => "aqua", "Blue Jeans" => "bluejeans", "Lavender" => "lavender", "Pink Rose" => "pinkrose", "Light Gray" => "lightgray", "Medium Gray" => "mediumgray", "Dark Gray" => "darkgray", "or customized color below:" => "customized"),
                'std' => 'mediumgray',
                "dependency" => Array('element' => "backgroundtype", 'value' => array('solid')),
                "description" => __("", "vc_sidebyside_cq")
              ),
              array(
                "type" => "colorpicker",
                "holder" => "div",
                "class" => "",
                "heading" => __("Or customized solid background color:", 'vc_sticker_cq'),
                "param_name" => "solidcolor",
                "value" => '#CCD1D9',
                "dependency" => Array('element' => "builtsolidcolor", 'value' => array('customized')),
                "description" => __("", 'vc_sticker_cq')
              ),
              array(
                "type" => "colorpicker",
                "holder" => "div",
                "class" => "",
                "heading" => __("Main color for the gradient background:", 'vc_sticker_cq'),
                "param_name" => "gradientcolor",
                "value" => '#4A89DC',
                "dependency" => Array('element' => "backgroundtype", 'value' => array('gradient')),
                "description" => __("", 'vc_sticker_cq')
              ),
              array(
                "type" => "attach_image",
                "heading" => __("Background image:", "vc_sticker_cq"),
                "param_name" => "backgroundimage",
                "value" => "",
                "dependency" => Array('element' => "backgroundtype", 'value' => array('image')),
                "description" => __("Select image from media library.", "vc_sticker_cq")
              ),
              array(
                "type" => "textfield",
                "heading" => __("Resize image to this width:", "vc_sticker_cq"),
                "param_name" => "imagewidth",
                "value" => "",
                "dependency" => Array('element' => "backgroundtype", 'value' => array('image')),
                "description" => __("Default we'll use the original image, you can specify a smaller width (like 240) here, then image will be resized to this width.", "vc_sticker_cq")
              ),
              // array(
              //   "type" => "textfield",
              //   "heading" => __("Optional icon (Font Awesome) for the sticker:", "vc_sticker_cq"),
              //   "param_name" => "icon",
              //   "value" => "",
              //   "description" => __("Support Font Awesome icon, for example <strong>fa-twitter</strong> will insert a Twitter icon. See all the available <a href='http://fortawesome.github.io/Font-Awesome/icons/' target='_blank'>Font Awesome icon</a>", "vc_sticker_cq")
              // ),
              array(
                'type' => 'dropdown',
                'heading' => __( 'Icon library', 'js_composer' ),
                'value' => array(
                  __( 'Font Awesome', 'js_composer' ) => 'fontawesome'
                  // __( 'Open Iconic', 'js_composer' ) => 'openiconic',
                  // __( 'Typicons', 'js_composer' ) => 'typicons',
                  // __( 'Entypo', 'js_composer' ) => 'entypo',
                  // __( 'Linecons', 'js_composer' ) => 'linecons',
                ),
                'admin_label' => true,
                'param_name' => 'icon',
                'description' => __( 'Select icon library.', 'js_composer' ),
              ),
              array(
                'type' => 'iconpicker',
                'heading' => __( 'Icon for the sticker (optional)', 'js_composer' ),
                'param_name' => 'icon_fontawesome',
                'value' => 'fa', // default value to backend editor admin_label
                'settings' => array(
                  'emptyIcon' => true, // default true, display an "EMPTY" icon?
                  'iconsPerPage' => 4000, // default 100, how many icons per/page to display, we use (big number) to display all icons in single page
                ),
                // 'dependency' => array(
                //   'element' => 'icon',
                //   'value' => 'fontawesome',
                // ),
                'description' => __( 'Select icon from library. Default is blank.', 'js_composer' ),
              ),
              // array(
              //   'type' => 'iconpicker',
              //   'heading' => __( 'Icon', 'js_composer' ),
              //   'param_name' => 'icon_openiconic',
              //   'value' => 'vc-oi vc-oi-dial', // default value to backend editor admin_label
              //   'settings' => array(
              //     'emptyIcon' => false, // default true, display an "EMPTY" icon?
              //     'type' => 'openiconic',
              //     'iconsPerPage' => 4000, // default 100, how many icons per/page to display
              //   ),
              //   'dependency' => array(
              //     'element' => 'icon',
              //     'value' => 'openiconic',
              //   ),
              //   'description' => __( 'Select icon from library.', 'js_composer' ),
              // ),
              // array(
              //   'type' => 'iconpicker',
              //   'heading' => __( 'Icon', 'js_composer' ),
              //   'param_name' => 'icon_typicons',
              //   'value' => 'typcn typcn-adjust-brightness', // default value to backend editor admin_label
              //   'settings' => array(
              //     'emptyIcon' => false, // default true, display an "EMPTY" icon?
              //     'type' => 'typicons',
              //     'iconsPerPage' => 4000, // default 100, how many icons per/page to display
              //   ),
              //   'dependency' => array(
              //     'element' => 'icon',
              //     'value' => 'typicons',
              //   ),
              //   'description' => __( 'Select icon from library.', 'js_composer' ),
              // ),
              // array(
              //   'type' => 'iconpicker',
              //   'heading' => __( 'Icon', 'js_composer' ),
              //   'param_name' => 'icon_entypo',
              //   'value' => 'entypo-icon entypo-icon-note', // default value to backend editor admin_label
              //   'settings' => array(
              //     'emptyIcon' => false, // default true, display an "EMPTY" icon?
              //     'type' => 'entypo',
              //     'iconsPerPage' => 4000, // default 100, how many icons per/page to display
              //   ),
              //   'dependency' => array(
              //     'element' => 'icon',
              //     'value' => 'entypo',
              //   ),
              // ),
              // array(
              //   'type' => 'iconpicker',
              //   'heading' => __( 'Icon', 'js_composer' ),
              //   'param_name' => 'icon_linecons',
              //   'value' => 'vc_li vc_li-heart', // default value to backend editor admin_label
              //   'settings' => array(
              //     'emptyIcon' => false, // default true, display an "EMPTY" icon?
              //     'type' => 'linecons',
              //     'iconsPerPage' => 4000, // default 100, how many icons per/page to display
              //   ),
              //   'dependency' => array(
              //     'element' => 'icon',
              //     'value' => 'linecons',
              //   ),
              //   'description' => __( 'Select icon from library.', 'js_composer' ),
              // ),
              array(
                "type" => "colorpicker",
                "holder" => "div",
                "class" => "",
                "heading" => __("Icon color:", 'vc_sticker_cq'),
                "param_name" => "fontcolor",
                "value" => '',
                "description" => __("Default is white, customize it with other color here.", 'vc_sticker_cq')
              ),
              array(
                "type" => "textfield",
                "heading" => __("Size of the icon:", "vc_sticker_cq"),
                "param_name" => "fontsize",
                "value" => "",
                "description" => __("Default is 3em, you can specify other value here.", "vc_sticker_cq")
              ),
              array(
                'type' => 'vc_link',
                'heading' => __( 'URL (Optional link for the type text)', 'vc_sticker_cq' ),
                'param_name' => 'textlink',
                'description' => __( '', 'vc_sticker_cq' )
              ),
              array(
                "type" => "textfield",
                "heading" => __("Size of the sticker:", "vc_sticker_cq"),
                "param_name" => "stickersize",
                "value" => "",
                "description" => __("Default is 120px. You can specify other value here.", "vc_sticker_cq")
              ),
              array(
                "type" => "dropdown",
                "holder" => "",
                "class" => "vc_sticker_cq",
                "heading" => __("Opacity of the shadow:", "vc_sticker_cq"),
                "param_name" => "shadowopacity",
                "value" => array("0", "0.2", "0.4", "0.6", "0.8", "1"),
                'std' => '0.8',
                "description" => __("", "vc_sticker_cq")
              ),
              array(
                "type" => "textfield",
                "heading" => __("CSS margin of the whole element:", "vc_sticker_cq"),
                "param_name" => "elementmargin",
                "value" => "",
                "description" => __("Default is margin: <strong>12px auto 0 auto</strong>, stand for margin top for 12px and align center. You can specify other value here.", "vc_sticker_cq")
              )

           )
        ));

          }else{
            vc_map(array(
            "name" => __("Sticker", 'vc_sticker_cq'),
            "base" => "cq_vc_sticker",
            "class" => "wpb_cq_vc_extension_sticker",
            // "as_parent" => array('only' => 'cq_vc_sticker_item'),
            "icon" => "cq_allinone_sticker",
            "category" => __('Sike Extensions', 'js_composer'),
            // "content_element" => false,
            // "show_settings_on_create" => false,
            'description' => __('With icon or image', 'js_composer'),
            "params" => array(
              array(
                "type" => "dropdown",
                "holder" => "",
                "class" => "vc_sticker_cq",
                "heading" => __("Display the sticker with:", "vc_sticker_cq"),
                "param_name" => "backgroundtype",
                "value" => array("Solid background color" => "solid", "Gradient background color" => "gradient", "Image" => "image"),
                "description" => __("", "vc_sticker_cq")
              ),
              array(
                "type" => "dropdown",
                "holder" => "",
                "class" => "vc_sidebyside_cq",
                "heading" => __("Choose a built-in solid color:", "vc_sidebyside_cq"),
                "param_name" => "builtsolidcolor",
                "value" => array("Grape Fruit" => "grapefruit", "Bitter Sweet" => "bittersweet", "Sunflower" => "sunflower", "Grass" => "grass", "Mint" => "mint", "Aqua" => "aqua", "Blue Jeans" => "bluejeans", "Lavender" => "lavender", "Pink Rose" => "pinkrose", "Light Gray" => "lightgray", "Medium Gray" => "mediumgray", "Dark Gray" => "darkgray", "or customized color below:" => "customized"),
                'std' => 'mediumgray',
                "dependency" => Array('element' => "backgroundtype", 'value' => array('solid')),
                "description" => __("", "vc_sidebyside_cq")
              ),
              array(
                "type" => "colorpicker",
                "holder" => "div",
                "class" => "",
                "heading" => __("Or customized solid background color:", 'vc_sticker_cq'),
                "param_name" => "solidcolor",
                "value" => '#CCD1D9',
                "dependency" => Array('element' => "builtsolidcolor", 'value' => array('customized')),
                "description" => __("", 'vc_sticker_cq')
              ),
              array(
                "type" => "colorpicker",
                "holder" => "div",
                "class" => "",
                "heading" => __("Main color for the gradient background:", 'vc_sticker_cq'),
                "param_name" => "gradientcolor",
                "value" => '#4A89DC',
                "dependency" => Array('element' => "backgroundtype", 'value' => array('gradient')),
                "description" => __("", 'vc_sticker_cq')
              ),
              array(
                "type" => "attach_image",
                "heading" => __("Background image:", "vc_sticker_cq"),
                "param_name" => "backgroundimage",
                "value" => "",
                "dependency" => Array('element' => "backgroundtype", 'value' => array('image')),
                "description" => __("Select image from media library.", "vc_sticker_cq")
              ),
              array(
                "type" => "textfield",
                "heading" => __("Resize image to this width:", "vc_sticker_cq"),
                "param_name" => "imagewidth",
                "value" => "",
                "dependency" => Array('element' => "backgroundtype", 'value' => array('image')),
                "description" => __("Default we'll use the original image, you can specify a smaller width (like 240) here, then image will be resized to this width.", "vc_sticker_cq")
              ),
              array(
                "type" => "textfield",
                "heading" => __("Optional icon (Font Awesome) for the sticker:", "vc_sticker_cq"),
                "param_name" => "icon",
                "value" => "",
                "description" => __("Support Font Awesome icon, for example <strong>fa-twitter</strong> will insert a Twitter icon. See all the available <a href='http://fortawesome.github.io/Font-Awesome/icons/' target='_blank'>Font Awesome icon</a>", "vc_sticker_cq")
              ),
              array(
                "type" => "colorpicker",
                "holder" => "div",
                "class" => "",
                "heading" => __("Icon color:", 'vc_sticker_cq'),
                "param_name" => "fontcolor",
                "value" => '',
                "description" => __("Default is white, customize it with other color here.", 'vc_sticker_cq')
              ),
              array(
                "type" => "textfield",
                "heading" => __("Size of the icon:", "vc_sticker_cq"),
                "param_name" => "fontsize",
                "value" => "",
                "description" => __("Default is 3em, you can specify other value here.", "vc_sticker_cq")
              ),
              array(
                'type' => 'vc_link',
                'heading' => __( 'URL (Optional link for the type text)', 'vc_sticker_cq' ),
                'param_name' => 'textlink',
                'description' => __( '', 'vc_sticker_cq' )
              ),
              array(
                "type" => "textfield",
                "heading" => __("Size of the sticker:", "vc_sticker_cq"),
                "param_name" => "stickersize",
                "value" => "",
                "description" => __("Default is 120px. You can specify other value here.", "vc_sticker_cq")
              ),
              array(
                "type" => "dropdown",
                "holder" => "",
                "class" => "vc_sticker_cq",
                "heading" => __("Opacity of the shadow:", "vc_sticker_cq"),
                "param_name" => "shadowopacity",
                "value" => array("0", "0.2", "0.4", "0.6", "0.8", "1"),
                'std' => '0.8',
                "description" => __("", "vc_sticker_cq")
              ),
              array(
                "type" => "textfield",
                "heading" => __("CSS margin of the whole element:", "vc_sticker_cq"),
                "param_name" => "elementmargin",
                "value" => "",
                "description" => __("Default is margin: <strong>12px auto 0 auto</strong>, stand for margin top for 12px and align center. You can specify other value here.", "vc_sticker_cq")
              )

           )
        ));

          }

          add_shortcode('cq_vc_sticker', array($this,'cq_vc_sticker_func'));


      }

      function cq_vc_sticker_func($atts, $content=null) {
          $icon_fontawesome = '';
          extract(shortcode_atts(array(
            "icon_fontawesome" => "",
            "builtsolidcolor" => "mediumgray",
            "solidcolor" => "#CCD1D9",
            "backgroundtype" => "solid",
            "gradientcolor" => "",
            "imagerepeat" => "no-repeat",
            "icon" => "",
            "fontcolor" => "",
            "fontsize" => "",
            "imagewidth" => "",
            "textlink" => "",
            // "differentbg" => "",
            "stickersize" => "",
            "shadowopacity" => "0.8",
            "elementmargin" => "",
            "backgroundimage" => ""
          ), $atts));

          $content = wpb_js_remove_wpautop($content); // fix unclosed/unwanted paragraph tags in $content
          $output = '';
          // wp_register_style( 'font-awesome', plugins_url('../faanimation/css/font-awesome.min.css', __FILE__) );
          // wp_enqueue_style( 'font-awesome' );

          wp_register_style( 'vc-extensions-sticker-style', plugins_url('css/style.css', __FILE__) );
          wp_enqueue_style( 'vc-extensions-sticker-style' );

          wp_register_script('sticker', plugins_url('js/sticker.min.js', __FILE__), array("jquery"));
          wp_enqueue_script('sticker');
          wp_register_script('vc-extensions-sticker-script', plugins_url('js/init.min.js', __FILE__), array("jquery", "sticker"));
          wp_enqueue_script('vc-extensions-sticker-script');

          $textlink = vc_build_link($textlink);

          $color_style_arr = array("grapefruit" => array("#ED5565", "#DA4453"), "bittersweet" => array("#FC6E51", "#E9573F"), "sunflower" => array("#FFCE54", "#F6BB42"), "grass" => array("#A0D468", "#8CC152"), "mint" => array("#48CFAD", "#37BC9B"), "aqua" => array("#4FC1E9", "#3BAFDA"), "bluejeans" => array("#5D9CEC", "#4A89DC"), "lavender" => array("#AC92EC", "#967ADC"), "pinkrose" => array("#EC87C0", "#D770AD"), "lightgray" => array("#F5F7FA", "#E6E9ED"), "mediumgray" => array("#CCD1D9", "#AAB2BD"), "darkgray" => array("#656D78", "#434A54"), "customized" => array("$solidcolor", "$solidcolor") );

          $solidcolor_arr = $color_style_arr[$builtsolidcolor];
          $backgroundimage = wp_get_attachment_image_src($backgroundimage, 'full');
          $output = '';
          if($textlink["url"]!=="") $output .= '<a href="'.$textlink["url"].'" title="'.$textlink["title"].'" target="'.$textlink["target"].'" class="cq-sticker-link">';
          if($icon==""&&version_compare(WPB_VC_VERSION,  "4.4")>= 0){
            $icon = "fontawesome";
          }

          if(isset(${'icon_' . $icon})){
              $output .= '<div class="cq-sticker" data-backgroundtype="'.$backgroundtype.'" data-backgroundcolor="'.$solidcolor_arr[1].'" data-gradientcolor="'.$gradientcolor.'" data-image="'.$backgroundimage[0].'" data-icon="'.esc_attr(${'icon_' . $icon}).'" data-size="'.$stickersize.'" data-fontsize="'.$fontsize.'" data-fontcolor="'.$fontcolor.'" data-elementmargin="'.$elementmargin.'" data-shadowopacity="'.$shadowopacity.'">';
          }else{
              $output .= '<div class="cq-sticker" data-backgroundtype="'.$backgroundtype.'" data-backgroundcolor="'.$solidcolor_arr[1].'" data-gradientcolor="'.$gradientcolor.'" data-image="'.$backgroundimage[0].'" data-icon="'.$icon.'" data-size="'.$stickersize.'" data-fontsize="'.$fontsize.'" data-fontcolor="'.$fontcolor.'" data-elementmargin="'.$elementmargin.'" data-shadowopacity="'.$shadowopacity.'">';
          }
          $output .= '</div>';
          if($textlink["url"]!=="") $output .= '</a>';
          return $output;

        }

  }

}

?>