t = '', $esc = true){
$val = $this->get_var($_POST, $key, $default);
return ($esc) ? esc_html($val) : $val;
}
/**
* get GET variable
* before: RevSliderBase::getGetVar();
*/
public function get_get_var($key, $default = '', $esc = true){
$val = $this->get_var($_GET, $key, $default);
return ($esc) ? esc_html($val) : $val;
}
/**
* get POST or GET variable in this order
* before: RevSliderBase::getPostGetVar();
*/
public function get_request_var($key, $default = '', $esc = true){
$val = (array_key_exists($key, $_POST)) ? $this->get_var($_POST, $key, $default) : $this->get_var($_GET, $key, $default);
return ($esc) ? esc_html($val) : $val;
}
/**
* get a variable from an array,
* before: RevSliderBase::getVar()
*/
public function get_var($arr, $key, $default = ''){
return (isset($arr[$key])) ? $arr[$key] : $default;
}
/**
* check for true and false in all possible ways
* @since: 6.0
**/
public function _truefalse($v){
if($v === 'false' || $v === false || $v === 'off' || $v === NULL || $v === 0 || $v === -1){
$v = false;
}elseif($v === 'true' || $v === true || $v === 'on'){
$v = true;
}
return $v;
}
/**
* validate that some value is numeric
* before: RevSliderFunctions::validateNumeric
*/
public function validate_numeric($val, $fn = 'Field'){
$this->validate_not_empty($val, $fn);
if(!is_numeric($val))
$this->throw_error($fn.__(' should be numeric', 'revslider'));
}
/**
* validate that some variable not empty
* before: RevSliderFunctions::validateNotEmpty
*/
public function validate_not_empty($val, $fn = 'Field'){
if(empty($val) && is_numeric($val) == false)
$this->throw_error($fn.__(' should not be empty', 'revslider'));
}
/**
* encode array into json for client side
* @before: RevSliderFunctions::jsonEncodeForClientSide()
*/
public function json_encode_client_side($arr){
$json = '';
if(!empty($arr)){
if(defined('JSON_INVALID_UTF8_IGNORE')){
$json = json_encode($arr, JSON_INVALID_UTF8_IGNORE);
}else{
$json = json_encode($arr);
}
$json = addslashes($json);
}
$json = (empty($json)) ? '{}' : "'".$json."'";
return $json;
}
/**
* turn a string into an array, check also for slashes!
* @since: 6.0
*/
public function json_decode_slashes($data){
if(gettype($data) == 'string'){
$data_decoded = json_decode(stripslashes($data), true);
if(empty($data_decoded))
$data_decoded = json_decode($data, true);
$data = $data_decoded;
}
return $data;
}
/**
* Convert std class to array, with all sons
* before: RevSliderFunctions::convertStdClassToArray();
* @return array|null
*/
public function class_to_array($arr){
return json_decode(json_encode($arr), true);
}
/**
* Convert std class to array, single
* before: RevSliderFunctions::cleanStdClassToArray();
* @return array
*/
public function class_to_array_single($arr){
return (array)$arr;
}
/**
* Check Array for Value Recursive
*/
public function in_array_r($needle, $haystack, $strict = false){
if(is_array($haystack) && !empty($haystack)){
foreach($haystack as $item){
if(($strict ? $item === $needle : $item == $needle) || (is_array($item) && $this->in_array_r($needle, $item, $strict))){
return true;
}
}
}
return false;
}
/**
* compress an array/object/string to a string
* @since 6.6.0
**/
public function do_compress($data, $level = 9){
if(is_array($data) || is_object($data)) $data = json_encode($data);
if(!function_exists('gzcompress') || !function_exists('gzuncompress')) return $data; //gzencode / gzdecode
return base64_encode(gzcompress($data, $level));
}
/**
* decompress an string to an array/object/string
* @since 6.6.0
**/
public function do_uncompress($data){
if($data === false || empty($data) || is_array($data) || is_object($data)) return $data;
$_data = json_decode($data, true);
if(is_array($_data) || is_object($_data)) return $_data;
if(!function_exists('gzcompress') || !function_exists('gzuncompress')) return $data; //gzencode / gzdecode
$data = gzuncompress(base64_decode($data));
$_data = json_decode($data, true);
return (!empty($_data)) ? $_data : $data;
}
/**
* get attachment image url
* before: RevSliderFunctionsWP::getUrlAttachmentImage();
*/
public function get_url_attachment_image($id, $size = 'full'){
$image = wp_get_attachment_image_src($id, $size);
$url = (empty($image)) ? false : $this->get_val($image, 0);
if($url === false){
$url = wp_get_attachment_url($id);
}
return $url;
}
/**
* gets a temporary path where files can be stored
**/
public function get_temp_path($path = 'rstemp'){
if(function_exists('sys_get_temp_dir')){
$temp = sys_get_temp_dir();
if(@is_dir($temp) && wp_is_writable($temp)){
$dir = trailingslashit($temp).$path.'/';
if(!is_dir($dir)) @mkdir($dir, 0777, true);
return $dir;
}
}
$temp = ini_get('upload_tmp_dir');
if(@is_dir($temp) && wp_is_writable($temp)){
$dir = trailingslashit($temp).$path.'/';
if(!is_dir($dir)) @mkdir($dir, 0777, true);
return trailingslashit($temp).$path.'/';
}
$temp_dir = get_temp_dir();
if(wp_is_writable($temp_dir)){
$dir = trailingslashit($temp_dir).$path.'/';
if(!is_dir($dir)) @mkdir($dir, 0777, true);
}else{
$upload_dir = wp_upload_dir();
$dir = $upload_dir['basedir'].'/'.$path.'/';
if(!is_dir($dir)) @mkdir($dir, 0777, true);
}
return $dir;
}
/**
* retrieve the image id from the given image url
* before: RevSliderFunctionsWP::get_image_id_by_url();
*/
public function get_image_id_by_url($image_url){
global $wpdb;
$attachment_id = false;
if($image_url !== ''){
$attachment_id = (function_exists('attachment_url_to_postid')) ? attachment_url_to_postid($image_url) : 0;
//for WP < 4.0.0
if(0 == $attachment_id){ //get it the old school way
$upload_dir_paths = wp_upload_dir();
// Make sure the upload path base directory exists in the attachment URL, to verify that we're working with a media library image
if(false !== strpos($image_url, $upload_dir_paths['baseurl'])){
$image_url = preg_replace('/-\d+x\d+(?=\.(jpg|jpeg|png|gif)$)/i', '', $image_url);
$image_url = str_replace($upload_dir_paths['baseurl'] . '/', '', $image_url);
$attachment_id = $wpdb->get_var($wpdb->prepare( "SELECT wposts.ID FROM $wpdb->posts wposts, $wpdb->postmeta wpostmeta WHERE wposts.ID = wpostmeta.post_id AND wpostmeta.meta_key = '_wp_attached_file' AND wpostmeta.meta_value = '%s' AND wposts.post_type = 'attachment'", $image_url));
}else{
$attachment_id = false;
}
}
}
return (is_null($attachment_id)) ? false : $attachment_id;
}
/**
* retrieve the image id from the given image filename/basename
* @since: 6.1.5
*/
public function get_image_id_by_basename($basename){
global $wpdb;
$var = $wpdb->get_var($wpdb->prepare("SELECT `post_id` FROM `".$wpdb->postmeta."` WHERE `meta_value` LIKE %s LIMIT 0,1", '%/'.$basename));
return ($var) ? $var : false;
}
/**
* get image url from image path.
* @before: RevSliderFunctionsWP::getImageUrlFromPath();
*/
public function get_image_url_from_path($path){
if(empty($path)) return '';
//check if the path ends with /, if yes its not a correct image path
$lc = substr($path, -1);
if(in_array($lc, array('/', '\\'))) return '';
//protect from absolute url
$lower = strtolower($path);
$return = (strpos($lower, 'http://') !== false || strpos($lower, 'https://') !== false || strpos($lower, 'www.') === 0) ? $path : $this->get_base_url().$path;
return ($return !== $this->get_base_url()) ? $return : '';
}
/**
* Check if Path is a Valid Image File
**/
public function check_valid_image($url){
if(empty($url)) return false;
$pos = strrpos($url, '.', -1);
if($pos === false) return false;
$ext = strtolower(substr($url, $pos));
$img_exts = array('.gif', '.jpg', '.jpeg', '.png');
if(in_array($ext, $img_exts)) return $url;
return false;
}
/**
* get the upload URL of images
* before: RevSliderFunctionsWP::getUrlUploads()
*/
public static function get_base_url(){
if(is_multisite() == false){ //without multisite
$url = content_url().'/';
}else{ //for multisite
$upload_dir = wp_upload_dir();
$url = $upload_dir['baseurl'].'/';
}
return $url;
}
/**
* strip slashes recursive
* @since: 5.0
* before: RevSliderBase::stripslashes_deep()
*/
public static function stripslashes_deep($value){
$value = is_array($value) ? array_map(array('RevSliderFunctions', 'stripslashes_deep'), $value) : stripslashes($value);
return $value;
}
/**
* esc attr recursive
* @since: 6.0
*/
public static function esc_attr_deep($value){
$value = is_array($value) ? array_map(array('RevSliderFunctions', 'esc_attr_deep'), $value) : esc_attr($value);
return $value;
}
/**
* get post types with categories for client side.
* before: RevSliderOperations::getPostTypesWithCatsForClient();
*/
public function get_post_types_with_categories_for_client(){
$c = 0;
$ret = array();
$post_types = $this->get_post_types_with_taxonomies();
foreach($post_types as $name => $tax){
$cat = array();
if(empty($tax)){
$ret[$name] = $cat;
continue;
}
foreach($tax as $tax_name => $tax_title){
$cats = $this->get_categories_assoc($tax_name);
if(empty($cats)) continue;
$c++;
$cat['option_disabled_'.$c] = '---- '. $tax_title .' ----';
foreach($cats as $catID => $catTitle){
$cat[$tax_name.'_'.$catID] = $catTitle;
}
}
$ret[$name] = $cat;
}
return $ret;
}
/**
* get post types array with taxomonies
* before: RevSliderFunctionsWP::getPostTypesWithTaxomonies()
*/
public function get_post_types_with_taxonomies(){
$post_types = $this->get_post_type_assoc();
foreach($post_types as $post_type => $title){
$post_types[$post_type] = $this->get_post_type_taxonomies($post_type);
}
return $post_types;
}
/**
*
* get array of post types with categories (the taxonomies is between).
* get only those taxomonies that have some categories in it.
* before: RevSliderFunctionsWP::getPostTypesWithCats()
*/
public function get_post_types_with_categories(){
$post_types_categories = array();
$post_types = $this->get_post_types_with_taxonomies();
foreach($post_types as $name => $tax){
$ptwc = array();
if(!empty($tax)){
foreach($tax as $tax_name => $tax_title){
$cats = $this->get_categories_assoc($tax_name);
if(!empty($cats)){
$ptwc[] = array(
'name' => $tax_name,
'title' => $tax_title,
'cats' => $cats
);
}
}
}
$post_types_categories[$name] = $ptwc;
}
return $post_types_categories;
}
/**
* get all the post types including custom ones
* the put to top items will be always in top (they must be in the list)
* before: RevSliderFunctionsWP::getPostTypesAssoc()
*/
public function get_post_type_assoc($put_to_top = array()){
$build_in = array('post' => 'post', 'page'=>'page');
$custom_types = get_post_types(array('_builtin' => false));
//top items validation - add only items that in the customtypes list
$top_updated = array();
foreach($put_to_top as $top){
if(in_array($top, $custom_types) == true){
$top_updated[$top] = $top;
unset($custom_types[$top]);
}
}
$post_types = array_merge($top_updated, $build_in, $custom_types);
//update label
foreach($post_types as $key => $type){
$post_types[$key] = $this->get_post_type_title($type);
}
return $post_types;
}
/**
* return post type title from the post type
* before: RevSliderFunctionsWP::getPostTypeTitle()
*/
public static function get_post_type_title($post_type){
$obj_type = get_post_type_object($post_type);
$title = (empty($obj_type)) ? ($post_type) : $obj_type->labels->singular_name;
return $title;
}
/**
* get post type taxomonies
* before: RevSliderFunctionsWP::getPostTypeTaxomonies()
*/
public function get_post_type_taxonomies($post_type){
$names = array();
$tax = get_object_taxonomies(array('post_type' => $post_type), 'objects');
if(!empty($tax)){
foreach($tax as $obj_tax){
if($post_type === 'product' && !in_array($obj_tax->name, array('product_cat', 'product_tag'))) continue;
$names[$obj_tax->name] = $obj_tax->labels->name;
}
}
return $names;
}
/**
* get post categories list assoc - id / title
* before: RevSliderFunctionsWP::getCategoriesAssoc()
*/
public function get_categories_assoc($taxonomy = 'category'){
$categories = array();
if(strpos($taxonomy, ',') !== false){
$taxes = explode(',', $taxonomy);
foreach($taxes as $tax){
$cats = $this->get_categories_assoc($tax);
$categories = array_merge($categories, $cats);
}
}else{
$args = array('taxonomy' => $taxonomy, 'number' => 10000);
$cats = get_categories($args);
foreach($cats as $cat){
$num = $cat->count;
$id = $cat->cat_ID;
$name = ($num == 1) ? 'item' : 'items';
$title = $cat->name . ' ('.$num.' '.$name.')';
$categories[$id] = $title;
}
}
return $categories;
}
/**
* check if css string is rgb
* @before: RevSliderFunctions::isrgb()
**/
public function is_rgb($rgba){
return (strpos($rgba, 'rgb') !== false) ? true : false;
}
/**
* check if file is in zip
* @since: 5.0
*/
public function check_file_in_zip($d_path, $image, $alias, &$alreadyImported, $add_path = false){
global $wp_filesystem;
$image = (is_array($image)) ? $this->get_val($image, 'url') : $image;
if(trim($image) !== ''){
if(strpos($image, 'http') !== false){
//dont change, as it is an external image
}else{
$strip = false;
$zimage = $wp_filesystem->exists($d_path.'images/'.$image);
if(!$zimage){
$zimage = $wp_filesystem->exists(str_replace('//', '/', $d_path.'images/'.$image));
$strip = true;
}
if(!$zimage){
}else{
if(!isset($alreadyImported['images/'.$image])){
//check if we are object folder, if yes, do not import into media library but add it to the object folder
$uimg = ($strip == true) ? str_replace('//', '/', 'images/'.$image) : $image; //pclzip
$object_library = (strpos($uimg, 'revslider/objects/') === 0) ? true : false;
if($object_library === true){ //copy the image to the objects folder if false
$objlib = new RevSliderObjectLibrary();
$importImage = $objlib->_import_object($d_path.'images/'.$uimg);
}else{
$importImage = $this->import_media($d_path.'images/'.$uimg, $alias.'/');
}
if($importImage !== false){
$alreadyImported['images/'.$image] = $importImage['path'];
$image = $importImage['path'];
}
}else{
$image = $alreadyImported['images/'.$image];
}
}
if($add_path){
$upload_dir = wp_upload_dir();
$cont_url = $upload_dir['baseurl'];
if(strpos($image, $cont_url) === false){
$image = str_replace('uploads/uploads/', 'uploads/', $cont_url . '/' . $image);
}
}
}
}
return $image;
}
/**
*
**/
public function import_media_raw($name, $id, $bitmap){
if(intval($id) === 0) return __('Invalid id given', 'revslider');
$path = $this->get_temp_path('rstemp');
if(preg_match('/^data:image\/(\w+);base64,/', $bitmap, $type)){
$data = substr($bitmap, strpos($bitmap, ',') + 1);
$type = strtolower($type[1]); // jpg, png, gif
if(!in_array($type, array('jpg', 'jpeg', 'gif', 'png'))){
return __('Image has an invalid type', 'revslider');
}
if(strpos($name, '.') !== false){
$name = explode('.', $name);
$name = $name[0];
}
$name .= '_'.$id.'.'.$type;
$name = preg_replace("/[^a-zA-Z0-9\-\.\_]/", '', $name);
$data = str_replace(' ', '+', $data);
$data = base64_decode($data);
if($data === false){
return __('Image has an invalid type', 'revslider');
}
}else{
return __('Image has invalid data', 'revslider');
}
$return = file_put_contents($path.$name, $data);
if($return === false) return __('Image could not be saved', 'revslider');
return $this->import_media($path.$name , 'video-media/');
}
/**
* Import media from url
* @param string $file_url URL of the existing file from the original site
* @param int $folder_name The slidername will be used as folder name in import
* @return boolean True on success, false on failure
*/
public function import_media($file_url, $folder_name){
require_once(ABSPATH . 'wp-admin/includes/image.php');
$ul_dir = wp_upload_dir();
$art_dir = 'revslider/';
$return = false;
//if the directory doesn't exist, create it
if(!file_exists($ul_dir['basedir'].'/'.$art_dir)) mkdir($ul_dir['basedir'].'/'.$art_dir);
if(!file_exists($ul_dir['basedir'].'/'.$art_dir.$folder_name)) mkdir($ul_dir['basedir'].'/'.$art_dir.$folder_name);
//rename the file... alternatively, you could explode on "/" and keep the original file name
$filename = basename($file_url);
$s_dir = str_replace('//', '/', $art_dir.$folder_name.$filename);
$_s_dir = false;
if(@fclose(@fopen($file_url, 'r'))){ //make sure the file actually exists
$path_info = pathinfo($file_url);
if(!isset($path_info['extension'])) return $return;
$pi = strtolower($path_info['extension']);
if(in_array($pi, $this->bad_extensions)) return $return;
$save_dir = $ul_dir['basedir'].'/'.$s_dir;
$_atc_id = $this->get_image_id_by_url($s_dir);
$atc_id = ($_atc_id === false || $_atc_id === NULL) ? $this->get_image_id_by_basename($filename) : $_atc_id;
if($_atc_id !== $atc_id && $atc_id !== false && $atc_id !== NULL){ //&& $_atc_id !== false && $_atc_id !== NULL
//the image was found through get_image_id_by_basename(), so we have to get the new save_dir for comparison of md5
$_save_dir = get_attached_file($atc_id);
if($_save_dir !== false && !empty($_save_dir)){
if(md5_file($_save_dir) === md5_file($file_url)){
$save_dir = $_save_dir;
$atc_id = $atc_id;
$s_dir = str_replace($ul_dir['basedir'].'/', '', $save_dir);
$_s_dir = $s_dir;
}
}
}
/**
* check if the files have matching md5, if not change the filename
* change save_dir so that the file is not
**/
if($atc_id !== false && $atc_id !== NULL){
if(!is_file($save_dir) || md5_file($file_url) !== md5_file($save_dir)){
$file = explode('.', $filename);
$nr = 1;
while(1 === 1){
$s_dir_2 = $art_dir.$folder_name.$file[0].$nr.'.'.$file[1];
$save_dir = $ul_dir['basedir'].'/'.$s_dir_2;
if(is_file($save_dir)){
if(md5_file($file_url) === md5_file($save_dir)){
$atc_id = $this->get_image_id_by_url($s_dir_2);
break;
}
}else{
break;
}
$nr++;
}
$atc_id = $this->get_image_id_by_url($s_dir_2);
$filename = $file[0].$nr.'.'.$file[1];
//we have a new $filename here, so use that one now
$s_dir = str_replace('//', '/', $art_dir.$folder_name.$filename);
$_s_dir = false;
}
}
if($atc_id == false || $atc_id == NULL){
@copy($file_url, $save_dir);
$file_info = getimagesize($save_dir);
$artdata = array( //create an array of attachment data to insert into wp_posts table
'post_author' => 1,
'post_date' => current_time('mysql'),
'post_date_gmt' => current_time('mysql'),
'post_title' => $filename,
'post_status' => 'inherit',
'comment_status' => 'closed',
'ping_status' => 'closed',
'post_name' => sanitize_title_with_dashes(str_replace('_', '-', $filename)),
'post_modified' => current_time('mysql'),
'post_modified_gmt' => current_time('mysql'),
'post_parent' => '',
'post_type' => 'attachment',
'guid' => $ul_dir['baseurl'].'/'.$s_dir,
'post_mime_type' => $this->get_val($file_info, 'mime'),
'post_excerpt' => '',
'post_content' => ''
);
//insert the database record
$attach_id = wp_insert_attachment($artdata, $s_dir);
//generate metadata and thumbnails
add_filter('intermediate_image_sizes_advanced', array('RevSliderFunctions', 'temporary_remove_sizes'), 10, 2);
$rs_meta_create = get_option('rs_image_meta_todo', array());
if(!isset($rs_meta_create[$attach_id])){
$rs_meta_create[$attach_id] = $save_dir;
update_option('rs_image_meta_todo', $rs_meta_create);
}
if($attach_data = @wp_generate_attachment_metadata($attach_id, $save_dir)){
@wp_update_attachment_metadata($attach_id, $attach_data);
}
}else{
$attach_id = $atc_id;
}
if($_s_dir !== false){
$s_dir = (!is_multisite()) ? 'uploads/'.$_s_dir : $_s_dir;
$s_dir = str_replace('//', '/', $s_dir);
}else{
$art_dir = (!is_multisite()) ? 'uploads/'.$art_dir : $art_dir;
$s_dir = str_replace('//', '/', $art_dir.$folder_name.$filename);
}
$return = array('id' => $attach_id, 'path' => $s_dir);
}
return $return;
}
/**
* temporary remove image sizes so that only the needed thumb will be created
* @since: 6.0
**/
public static function temporary_remove_sizes($sizes, $meta = false){
if(!empty($sizes)){
foreach($sizes as $size => $values){
if($size == 'thumbnail'){
return array($size => $values);
}
}
}
return $sizes;
}
/**
* get contents of the css table
* @before: RevSliderOperations::getCaptionsContentArray();
*/
public function get_captions_content($handle = false){
$css = RevSliderGlobals::instance()->get('RevSliderCssParser');
$this->fill_css();
return $css->db_array_to_array($this->css, $handle);
}
/**
* get wp-content path
* @before: RevSliderFunctionsWP::getPathUploads()
*/
public function get_upload_path(){
if(is_multisite()){
global $wpdb;
$path = (!defined('BLOGUPLOADDIR')) ? ABSPATH . 'wp-content/uploads/sites/' . $wpdb->blogid : BLOGUPLOADDIR;
}else{
$wp_dir = WP_CONTENT_DIR;
$path = (!empty($wp_dir)) ? WP_CONTENT_DIR . '/' : ABSPATH . 'wp-content/uploads/';
}
return $path;
}
/**
* get contents of the static css file
* @before: RevSliderOperations::getStaticCss()
*/
public function get_static_css(){
return get_option('revslider-static-css', '');
}
/**
* get contents of the static css file
* @before: RevSliderOperations::updateStaticCss()
*/
public function update_static_css($css){
$css = str_replace(array("\'", '\"', '\\\\'),array("'", '"', '\\'), trim($css));
update_option('revslider-static-css', $css);
return $css;
}
/**
* print html font import
* @before: RevSliderOperations::printCleanFontImport()
*/
public function print_clean_font_import(){
global $revslider_fonts;
$font_first = true;
$ret = '';
$tcf = '';
$tcf2 = '';
$fonts = array();
$gs = $this->get_global_settings();
$fdl = $this->get_val($gs, 'fontdownload', 'off');
if(!empty($revslider_fonts['queue'])){
foreach($revslider_fonts['queue'] as $f_n => $f_s){
if(!isset($f_s['url'])) continue; //if url is not set, continue
$ret .= ''."\n";
}
}
if($fdl === 'disable') return $ret;
if(!empty($revslider_fonts['queue'])){
foreach($revslider_fonts['queue'] as $f_n => $f_s){
if(empty($f_n)) continue;
if(isset($f_s['url']) && !empty($f_s['url'])) continue; //ignore custom
$_variants = $this->get_val($f_s, 'variants', array());
$_subsets = $this->get_val($f_s, 'subsets', array());
if(!empty($_variants) || !empty($_subsets)){
if(!isset($revslider_fonts['loaded'][$f_n])) $revslider_fonts['loaded'][$f_n] = array();
if(!isset($revslider_fonts['loaded'][$f_n]['variants'])) $revslider_fonts['loaded'][$f_n]['variants'] = array();
if(!isset($revslider_fonts['loaded'][$f_n]['subsets'])) $revslider_fonts['loaded'][$f_n]['subsets'] = array();
if(strpos($f_n, 'href=') === false){
$t_tcf = '';
if($font_first == false) $t_tcf .= '%7C'; //'|';
$t_tcf .= urlencode($f_n).':';
if(!empty($_variants)){
$mgfirst = true;
foreach($f_s['variants'] as $mgvk => $mgvv){
if(in_array($mgvv, $revslider_fonts['loaded'][$f_n]['variants'], true)) continue;
$revslider_fonts['loaded'][$f_n]['variants'][] = $mgvv;
if(!$mgfirst) $t_tcf .= urlencode(',');
$t_tcf .= urlencode($mgvv);
$mgfirst = false;
}
//we did not add any variants, so dont add the font
if($mgfirst === true) continue;
}
$fonts[$f_n] = $t_tcf; //we do not want to add the subsets
if(!empty($_subsets)){
$mgfirst = true;
foreach($f_s['subsets'] as $ssk => $ssv){
if(in_array($mgvv, $revslider_fonts['loaded'][$f_n]['subsets'], true)) continue;
$revslider_fonts['loaded'][$f_n]['subsets'][] = $ssv;
if($mgfirst) $t_tcf .= urlencode('&subset=');
if(!$mgfirst) $t_tcf .= urlencode(',');
$t_tcf .= urlencode($ssv);
$mgfirst = false;
}
}
$tcf .= $t_tcf;
}else{
//$f_n = $this->$this->remove_http($f_n);
$tcf2 .= html_entity_decode(stripslashes($f_n));
$fonts[$f_n] = $tcf2;
}
}
$font_first = false;
}
}
if($fdl === 'preload'){
$ret .= $this->preload_fonts($fonts);
}else{
$url = $this->modify_fonts_url('https://fonts.googleapis.com/css?family=');
$ret .= ($tcf !== '') ? ''."\n" : '';
$ret .= ($tcf2 !== '') ? html_entity_decode(stripslashes($tcf2)) : '';
}
return apply_filters('revslider_printCleanFontImport', $ret);
}
/**
* preloading fonts and return style for it
**/
public function preload_fonts($fonts, $style = true, $all = false){
$ret = '';
if(!empty($fonts)){
if (!function_exists('download_url')) require_once ABSPATH . 'wp-admin/includes/file.php';
$upload_dir = wp_upload_dir();
$base_dir = $upload_dir['basedir'];
$base_url = $upload_dir['baseurl'];
$tp_google_ts = get_option('tp_google_font', 0);
$types = array(
//--- original
'ttf' => array('user-agent' => ''),
'woff' => array('accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', 'user-agent' => 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/42.0.2311.135 Safari/537.36 Edge/12.10240'),
'woff2' => array('accept' => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8', 'user-agent' => 'Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:73.0) Gecko/20100101 Firefox/73.0'),
//--- original end
/*--- alternative
//'ttf' => array('user-agent' => 'Mozilla/5.0 (Unknown; Linux x86_64) AppleWebKit/538.1 (KHTML, like Gecko) Safari/538.1 Daum/4.1'),
//'woff' => array('user-agent' => 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:27.0) Gecko/20100101 Firefox/27.0'),
//'woff2' => array('user-agent' => 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:40.0) Gecko/20100101 Firefox/40.0'),
//'eot' => array('user-agent' => 'Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; Trident/4.0)'),
//'svg' => array('user-agent' => 'Mozilla/4.0 (iPad; CPU OS 4_0_1 like Mac OS X) AppleWebKit/534.46 (KHTML, like Gecko) Version/4.1 Mobile/9A405 Safari/7534.48.3'),
//--- alternative 2 end */
);
$fonts_css = get_option('tp_font_css', array());
if(!is_array($fonts_css)) $fonts_css = array();
$load = 'ttf';
if ($all === false) {
$_browser = $this->get_browser();
$version = $this->get_val($_browser, 'version', '0');
$browser = $this->get_val($_browser, 'name', '');
//Chrome 6+ , Firefox 3.6+ IE9+, Safari 5.1+ -> WOFF
//Chrome 26+, Operae23+, Firefox 39+ -> Woff2
switch(strtolower($browser)){
case 'mozilla firefox':
if(version_compare($version, '3.6', '>=')) $load = 'woff';
if(version_compare($version, '39', '>=')) $load = 'woff2';
break;
case 'edge':
$load = 'woff2';
break;
case 'google chrome':
if(version_compare($version, '6', '>=')) $load = 'woff';
if(version_compare($version, '26', '>=')) $load = 'woff2';
break;
case 'apple safari':
if(version_compare($version, '5.1', '>=')) $load = 'woff';
break;
case 'opera':
if(version_compare($version, '23', '>=')) $load = 'woff';
break;
case 'internet explorer':
if(version_compare($version, '9', '>=')) $load = 'woff';
break;
}
}
foreach($fonts as $key => $font){
//check if we downloaded the font already
$font = str_replace('%7C', '', $font);
if(strpos($key, ':') !== false){
$key = explode(':', $key);
$key = $key[0];
}
$font_name = preg_replace('/[^-a-z0-9 ]+/i', '', $key);
$font_name = strtolower(str_replace(' ', '-', esc_attr($font_name)));
$f_raw = explode(':', $font);
$weights = array('400');
$unicode = '';
$font_loaded = array();
if(!empty($f_raw) && is_array($f_raw) && isset($f_raw[1])){
$f_raw[1] = str_replace(array('%2C', 'wght', '@', ';'), array(',', '', '', ','), $f_raw[1]);
$weights = explode(',', $f_raw[1]);
foreach($weights as $wk => $weight){
if($weight === 'ital'){
$weights[$wk] = 'italic';
continue;
}
$weights[$wk] = intval($weight);
if($weights[$wk] < 100) unset($weights[$wk]);
}
if(empty($weights)) $weights = array('400');
$weights = array_unique($weights);
}
$f_family = str_replace('+', ' ', $f_raw[0]);
foreach($types as $ftype => $options){
if($load !== $ftype && $all === false) continue;
$f_download = false;
foreach($weights as $weight){
$font_style = 'normal';
if(intval($weight) === 0){
$font_style = preg_replace('/[0-9]+/', '', $weight);
$weight = preg_replace('/[a-zA-Z]+/', '', $weight);
if(intval($weight) < 100) $weight = '400';
}
$_css = $this->get_val($fonts_css, array($font_name, $ftype, $weight, $font_style), false);
if(!empty($_css) && is_array($_css)){
foreach($_css as $uc => $fw){
if(empty($fw) || !is_array($fw)) continue;
foreach($fw as $_fw => $font_css){
$start = strpos($font_css, '###BASE###');
if($start === false) continue;
$end = strpos($font_css, ')', $start + 10);
$file_raw = substr($font_css, $start + 10, $end - ($start + 10));
if(!is_file($base_dir.'/themepunch/gfonts/'. $file_raw) || filemtime($base_dir.'/themepunch/gfonts/'. $file_raw) < $tp_google_ts){
$f_download = true;
break;
}
}
}
}else{
$f_download = true;
}
}
if($f_download){
if(!is_dir($base_dir.'/themepunch/')) mkdir($base_dir.'/themepunch/');
if(!is_dir($base_dir.'/themepunch/gfonts/')) mkdir($base_dir.'/themepunch/gfonts/');
if(!is_dir($base_dir.'/themepunch/gfonts/'.$font_name)) mkdir($base_dir.'/themepunch/gfonts/'.$font_name);
$content = wp_remote_get('https://fonts.googleapis.com/css?family='.$font, $options);
$body = $this->get_val($content, 'body', '');
$body = explode('}', $body);
if(!empty($body)){
foreach($body as $b){
if(preg_match("/(http|https|ftp|ftps)\:\/\/[a-zA-Z0-9\-\.]+\.[a-zA-Z]{2,3}(\/\S*)?/", $b, $found_fonts)){
$found_font = rtrim($found_fonts[0], ')');
$filename = basename($found_font);
$found_fw = (preg_match("/(?<=font-weight:)(.*)(?=;)/", $b, $found_fw)) ? trim($found_fw[0]) : '400';
$found_fs = (preg_match("/(?<=font-style:)(.*)(?=;)/", $b, $found_fs)) ? trim($found_fs[0]) : 'normal';
$found_ur = (preg_match("/(?<=\/\*)(.*)(?=\*\/)/", $b, $found_ur)) ? trim($found_ur[0]) : '';
$found_ur = (empty($found_ur)) ? 'all' : $found_ur;
$found_fs = ($found_fs !== 'normal') ? 'italic' : $found_fs;
$found_fw = (empty($found_fw)) ? '400' : $found_fw;
$file = $base_dir.'/themepunch/gfonts/'. $font_name . '/' . $filename;
$_file = '###BASE###'. $font_name . '/' . $filename;
if(!in_array($filename, $font_loaded)){
$tmp = download_url($found_font, 4);
if(!is_wp_error($tmp)){
if(!is_dir(dirname($file))) @mkdir(dirname($file));
copy($tmp, $file);
@unlink($tmp);
}
$font_loaded[] = $filename;
}
if(strpos($b, 'font-display') === false) $b .= ' font-display: swap;'."\n";
if(!isset($fonts_css[$font_name])) $fonts_css[$font_name] = array();
if(!isset($fonts_css[$font_name][$ftype])) $fonts_css[$font_name][$ftype] = array();
if(!isset($fonts_css[$font_name][$ftype][$found_fw])) $fonts_css[$font_name][$ftype][$found_fw] = array();
if(!isset($fonts_css[$font_name][$ftype][$found_fw][$found_fs])) $fonts_css[$font_name][$ftype][$found_fw][$found_fs] = array();
$fonts_css[$font_name][$ftype][$found_fw][$found_fs][$found_ur] = str_replace($found_font, $_file, $b . '}');
}
}
}
}
if(!empty($weights) && is_array($weights)){
if($style === true) $ret .= '';
}
}
}
update_option('tp_font_css', $fonts_css);
}
return $ret;
}
/**
* get the client browser with version
**/
public function get_browser(){
$u_agent = $this->get_val($_SERVER, 'HTTP_USER_AGENT');
$bname = 'Unknown';
$platform = 'Unknown';
$version = '';
$ub = '';
// get platform
if (preg_match('/linux/i', $u_agent)) {
$platform = 'linux';
} elseif (preg_match('/macintosh|mac os x/i', $u_agent)) {
$platform = 'mac';
} elseif (preg_match('/windows|win32/i', $u_agent)) {
$platform = 'windows';
}
// get name of useragent
if(preg_match('/MSIE/i',$u_agent) && !preg_match('/Opera/i',$u_agent)) {
$bname = 'Internet Explorer';
$ub = 'MSIE';
} elseif(preg_match('/Firefox/i',$u_agent)) {
$bname = 'Mozilla Firefox';
$ub = 'Firefox';
} elseif(preg_match('/OPR/i',$u_agent)) {
$bname = 'Opera';
$ub = 'Opera';
} elseif(preg_match('/Chrome/i',$u_agent) && !preg_match('/Edg/i',$u_agent)) {
$bname = 'Google Chrome';
$ub = 'Chrome';
} elseif(preg_match('/Safari/i',$u_agent) && !preg_match('/Edg/i',$u_agent)) {
$bname = 'Apple Safari';
$ub = 'Safari';
} elseif(preg_match('/Netscape/i',$u_agent)) {
$bname = 'Netscape';
$ub = 'Netscape';
} elseif(preg_match('/Edg/i',$u_agent)) {
$bname = 'Edge';
$ub = 'Edg';
} elseif(preg_match('/Trident/i',$u_agent)) {
$bname = 'Internet Explorer';
$ub = 'MSIE';
}
// get version
$known = array('Version', $ub, 'other');
$pattern = '#(?' . join('|', $known) . ')[/ ]+(?[0-9.|a-zA-Z.]*)#';
if (!preg_match_all($pattern, $u_agent, $matches)){ /* */ }
// see how many we have
$i = count($matches['browser']);
$version = $this->get_val($matches, array('version', 0));
if ($i != 1) {
//we will have two since we are not using the 'other' argument yet
//see if the version is before or after the name
$version = (strripos($u_agent, 'Version') < strripos($u_agent,$ub)) ? $version : $this->get_val($matches, array('version', 1));
}
// check if we have a number
if ($version == null || $version == '') $version = '0';
return array(
'name' => $bname,
'version' => $version,
'platform' => $platform
);
}
/**
* get a collection of all used fonts, either in a grid or from the whole plugin
**/
public function collect_used_fonts($save = true, $fetch_all = true, $page = 1){
$used_fonts = get_option('tp-google-fonts-collect', array());
$global_fonts = array();
$more = false;
$sr = new RevSliderSlider();
$sl = new RevSliderSlide();
//get all slider, init them and get subsets and get_used_fonts
$page = intval($page);
if($page <= 0) $page = 1;
$sliders = $sr->get_sliders(false, $page);
if(!empty($sliders)){
foreach($sliders as $slider){
$gfsub = $slider->get_param('subsets', array());
$gf = $slider->get_used_fonts(false);
if(!empty($gf)){
foreach($gf as $handle => $data){
if(!isset($global_fonts[$handle])) $global_fonts[$handle] = array();
$variants = $this->get_val($data, 'variants', array());
if(!empty($variants) && is_array($variants)){
foreach($variants as $variant => $true){
if(!in_array($variant, $global_fonts[$handle])) $global_fonts[$handle][] = $variant;
}
}
}
}
}
if(count($sliders) >= 50) $more = true;
}
if(!empty($global_fonts)){
foreach($global_fonts as $handle => $variants){
$url = $handle;
if(!empty($variants) && is_array($variants)){
sort($variants);
$url .= ':'.implode(',', $variants);
}
if(!isset($used_fonts[$handle])) $used_fonts[$handle] = array();
if(!in_array($url, $used_fonts[$handle])) $used_fonts[$handle][] = $url;
}
}
if($fetch_all === true){
if(class_exists('ThemePunch_Fonts') && method_exists('ThemePunch_Fonts', 'collect_used_fonts')){
$esg_fonts = new ThemePunch_Fonts();
$return = $esg_fonts->collect_used_fonts(false, false, $page);
$fonts = $this->get_val($return, 'fonts', array());
$_more = $this->get_val($return, 'more', false);
if($_more === true) $more = true;
//merge esg and revslider
if(!empty($fonts)){
foreach($fonts as $handle => $urls){
if(empty($urls) || !is_array($urls)) continue;
if (!isset($used_fonts[$handle]) ) $used_fonts[$handle] = array();
if (!in_array($handle, $used_fonts[$handle])) {
foreach($urls as $url){
if(!in_array($url, $used_fonts[$handle])) $used_fonts[$handle][] = $url;
}
}
}
}
}
}
$used_fonts = apply_filters('punchfonts_collect_fonts', $used_fonts);
if($save === true) update_option('tp-google-fonts-collect', $used_fonts);
return array('fonts' => $used_fonts, 'more' => $more);
}
public function download_collected_fonts($handle){
if (empty($handle)) return;
if (!is_array($handle)) $handle = (array)$handle;
$collected = get_option('tp-google-fonts-collect', array());
foreach ($handle as $_handle) {
if (!isset($collected[$_handle])) continue;
$load = array();
foreach($collected[$_handle] as $h){
$load[$h] = $h;
}
$this->preload_fonts($load, false, true);
}
}
/**
* Change FontURL to new URL (added for chinese support since google is blocked there)
* @since: 5.0
* @before: RevSliderFront::modify_punch_url()
*/
public function modify_fonts_url($url){
$gs = $this->get_global_settings();
$df = $this->get_val($gs, 'fonturl', '');
return ($df !== '') ? $df : $url;
}
/**
* convert date to the date format that the user chose.
* @before: RevSliderFunctionsWP::convertPostDate();
*/
public function convert_post_date($date, $with_time = false){
if(!empty($date)){
$date = ($with_time) ? date_i18n(get_option('date_format').' '.get_option('time_format'), strtotime($date)) : date_i18n(get_option('date_format'), strtotime($date));
}
return $date;
}
/**
* return biggest value of object depending on which devices are enabled
* @since: 5.0
**/
public function get_biggest_device_setting($obj, $enabled_devices, $default = '########'){
$dv = $this->get_val($obj, array('d', 'v'));
if($this->get_val($enabled_devices, 'd') === true && $dv != '') return $dv;
if($default !== '########') return $default;
$nv = $this->get_val($obj, array('n', 'v'));
if($this->get_val($enabled_devices, 'n') === true && $nv != '') return $nv;
$tv = $this->get_val($obj, array('t', 'v'));
if($this->get_val($enabled_devices, 't') === true && $tv != '') return $tv;
$mv = $this->get_val($obj, array('m', 'v'));
if($this->get_val($enabled_devices, 'm') === true && $mv != '') return $mv;
return '';
}
/**
* normalize object with device informations depending on what is enabled for the Slider
* @since: 5.0
**/
public function normalize_device_settings($obj, $enabled_devices, $return = 'obj', $default = array(), $set_to_if = array(), $use = ','){ //array -> from -> to
/*d n t m*/
$obj = $this->fill_device_settings($obj);
if(!empty($set_to_if)){
foreach($obj as $device => $key){
foreach($set_to_if as $from => $to){
if(trim($this->get_val($obj, array($device, 'v'))) == $from) $obj[$device]['v'] = $to;
}
}
}
$_def = !empty($default) ? reset($default) : '########';
$inherit_size = $this->get_biggest_device_setting($obj, $enabled_devices, $_def);
if($enabled_devices['d'] === true){
if($this->get_val($obj, array('d', 'v'), '') === ''){
$obj['d']['v'] = ($_def !== '########') ? $_def : $inherit_size;
}else{
$inherit_size = $obj['d']['v'];
}
}else{
$obj['d']['v'] = $inherit_size;
}
if($enabled_devices['n'] === true){
if($this->get_val($obj, array('n', 'v'), '') === ''){
$obj['n']['v'] = ($_def !== '########') ? $_def : $inherit_size;
}else{
$inherit_size = $obj['n']['v'];
}
}else{
$obj['n']['v'] = $inherit_size;
}
if($enabled_devices['t'] === true){
if($this->get_val($obj, array('t', 'v'), '') === ''){
$obj['t']['v'] = ($_def !== '########') ? $_def : $inherit_size;
}else{
$inherit_size = $obj['t']['v'];
}
}else{
$obj['t']['v'] = $inherit_size;
}
if($enabled_devices['m'] === true){
if($this->get_val($obj, array('m', 'v'), '') === ''){
$obj['m']['v'] = ($_def !== '########') ? $_def : $inherit_size;
}else{
$inherit_size = $obj['m']['v'];
}
}else{
$obj['m']['v'] = $inherit_size;
}
switch($return){
case 'obj':
//order according to: desktop, notebook, tablet, mobile
$new_obj = array();
$new_obj['d'] = $obj['d']['v'];
$new_obj['n'] = $obj['n']['v'];
$new_obj['t'] = $obj['t']['v'];
$new_obj['m'] = $obj['m']['v'];
return $new_obj;
break;
case 'html-array':
if($obj['d']['v'] === $obj['n']['v'] && $obj['d']['v'] === $obj['m']['v'] && $obj['d']['v'] === $obj['t']['v']){
$html_array = $obj['d']['v'];
}else{
$html_array = @$obj['d']['v'];
$html_array .= $use.@$obj['n']['v'];
$html_array .= $use.@$obj['t']['v'];
$html_array .= $use.@$obj['m']['v'];
}
if(!empty($default)){
foreach($default as $key => $value){
if((is_string($html_array) && $html_array == "".$value) || (!(is_string($html_array)) && $html_array == $value)){
$html_array = '';
break;
}
}
}
return $html_array;
break;
case 'array':
$array = array();
if($obj['d']['v'] === $obj['n']['v'] && $obj['d']['v'] === $obj['m']['v'] && $obj['d']['v'] === $obj['t']['v']){
$array[$obj['d']['v']] = $obj['d']['v'];
}else{
$array[$obj['d']['v']] = $this->get_val($obj, array('d', 'v'));
$array[$obj['n']['v']] = $this->get_val($obj, array('n', 'v'));
$array[$obj['t']['v']] = $this->get_val($obj, array('t', 'v'));
$array[$obj['m']['v']] = $this->get_val($obj, array('m', 'v'));
if(!empty($array)){
foreach($array as $k => $v){
if(trim($v) === ''){
unset($array[$k]);
}
}
}
}
return $array;
break;
}
return $obj;
}
/**
* fill object with default values
* @since: 6.0
**/
public function fill_device_settings($obj){
$push = array('d', 'n', 't', 'm');
if(is_string($obj)){
$t = $obj;
$obj = array();
foreach($push as $p){
$obj[$p] = array('v' => $t);
}
return $obj;
}
foreach($push as $p){
if(!isset($obj[$p])){
$obj[$p] = array();
}
if(!isset($obj[$p]['v'])){
$obj[$p]['v'] = '';
$obj[$p]['u'] = '';
}
}
return $obj;
}
/**
* get the values for the given transition
**/
public function get_slide_transition_values($transition, $base_transitions = array()){
if(empty($base_transitions)) $base_transitions = $this->get_base_transitions();
foreach($base_transitions as $t){
if(!is_array($t)) continue;
foreach($t as $_t){
if(!is_array($_t)) continue;
foreach($_t as $name => $values){
if($name !== $transition) continue;
return $values;
}
}
}
return array();
}
/**
* get a random slide transition for the given main and grp
**/
public function get_random_slide_transition($main, $grp, $base_transitions = array()){
if(empty($base_transitions)) $base_transitions = $this->get_base_transitions();
if(!is_array($grp) && !empty($grp)) $grp = explode(',', $grp);
if($grp === '') $grp = array();
$items = array();
foreach($base_transitions as $m => $bt){
if(!is_string($m) || $m === 'random' || $m === 'custom' || ($main !== 'all' && $main !== $m)) continue;
foreach($bt as $g => $_bt){
if(is_array($_bt) && $g !== 'icon' && (empty($grp) || in_array($g, $grp))){
foreach($_bt as $e => $__bt){
$items[] = $e;
}
}
}
}
$num = (!empty($items)) ? array_rand($items, 1) : false;
return ($num !== false) ? $items[$num] : '';
}
/**
* set the tp_google_font to current date, so that it will be redownloaded
* @before: RevSliderOperations::deleteGoogleFonts();
*/
public function delete_google_fonts(){
update_option('tp_google_font', time());
update_option('tp_font_css', array());
update_option('tp-google-fonts-collect', array());
}
/**
* Remove http:// and https://
* @since: 6.0.0
**/
public function remove_http($url, $special = 'auto'){
switch($special){
case 'http':
$url = str_replace('https://', 'http://', $url);
if(strpos($url, 'http://') === false) $url = 'http://'.$url;
break;
case 'https':
$url = str_replace('http://', 'https://', $url);
if(strpos($url, 'https://') === false) $url = 'https://'.$url;
break;
case 'keep': //do nothing
break;
case 'auto':
default:
$url = str_replace(array('http://', 'https://'), '//' , $url);
break;
}
return $url;
}
/**
* set the memory limit to at least 256MB if possible
* @since: 6.1.6
**/
public static function set_memory_limit(){
wp_raise_memory_limit('revslider');
}
/**
* Check if page is edited in Gutenberg
*/
public function _is_gutenberg_page(){
if(isset($_GET['action']) && $_GET['action'] == 'elementor') return false; // Elementor Page Edit
if(isset($_GET['vc_action']) && $_GET['vc_action'] == 'vc_inline') return false; // WP Bakery Front Edit
if(function_exists('is_gutenberg_page') && is_gutenberg_page()) return true; // Gutenberg Edit with WP < 5
$current_screen = get_current_screen();
if(!empty($current_screen) && method_exists($current_screen, 'is_block_editor') && $current_screen->is_block_editor()) return true; //Gutenberg Edit with WP >= 5
return false;
}
/**
* get custom transitions
**/
public function get_custom_slidetransitions(){
$custom = get_option('revslider_template_slidetransitions', array());
return apply_filters('rs_get_custom_slidetransitions', $custom);
}
/**
* get custom transitions
**/
public function save_custom_slidetransitions($template){
$custom = $this->get_custom_slidetransitions();
//empty custom templates?
if(empty($custom)){
$custom = array();
$new_id = 1;
}else{
$id = $this->get_val($template, 'id', 0);
//custom templates exist
$new_id = ($id > 0) ? $id : max(array_keys($custom)) + 1;
}
//update or insert template
$custom[$new_id]['title'] = $template['obj']['title'];
$custom[$new_id]['preset'] = $template['obj']['preset'];
//return the ID the template was saved with
return (update_option('revslider_template_slidetransitions', $custom)) ? $new_id : false;
}
/**
* get custom transitions
**/
public function delete_custom_slidetransitions($template){
//load templates array
$custom = $this->get_custom_slidetransitions();
$id = intval($this->get_val($template, 'id', 0));
//custom template exist
if($id > 0 && isset($custom[$id])){
//delete given ID
unset($custom[$id]);
//save the resulting templates array again
if(update_option('revslider_template_slidetransitions', $custom)) return true;
}
return false;
}
/**
* push the matieral icons css into the global variable
**/
public function add_material_icons(){
global $rs_material_icons_css;
if($rs_material_icons_css !== false) return '';
$gs = $this->get_global_settings();
if($this->get_val($gs, 'fontdownload', 'off') === 'off'){
$font_face = "@font-face {
font-family: 'Material Icons';
font-style: normal;
font-weight: 400;
src: url(//fonts.gstatic.com/s/materialicons/v41/flUhRq6tzZclQEJ-Vdg-IuiaDsNcIhQ8tQ.woff2) format('woff2');
}";
}else{
$font_face = "@font-face {
font-family: 'Material Icons';
font-style: normal;
font-weight: 400;
src: local('Material Icons'),
local('MaterialIcons-Regular'),
url(".RS_PLUGIN_URL."public/assets/fonts/material/MaterialIcons-Regular.woff2) format('woff2'),
url(".RS_PLUGIN_URL."public/assets/fonts/material/MaterialIcons-Regular.woff) format('woff'),
url(".RS_PLUGIN_URL."public/assets/fonts/material/MaterialIcons-Regular.ttf) format('truetype');
}";
}
$rs_material_icons_css = "/*
ICON SET
*/
".$font_face."
rs-module .material-icons {
font-family: 'Material Icons';
font-weight: normal;
font-style: normal;
font-size: inherit;
display: inline-block;
text-transform: none;
letter-spacing: normal;
word-wrap: normal;
white-space: nowrap;
direction: ltr;
vertical-align: top;
line-height: inherit;
/* Support for IE. */
font-feature-settings: 'liga';
-webkit-font-smoothing: antialiased;
text-rendering: optimizeLegibility;
-moz-osx-font-smoothing: grayscale;
}";
}
/**
* open and checks a zip file for filetypes
**/
public function check_bad_files($zip_file, $extensions_allowed = false){
if(class_exists('ZipArchive')){
$zip = new ZipArchive;
$success = $zip->open($zip_file);
if($success !== true) $this->throw_error(__("Can't open zip file", 'revslider'));
for($i = 0; $i < $zip->numFiles; $i++){
$path_info = pathinfo($zip->getNameIndex($i));
if(!isset($path_info['extension'])) continue;
$pi = strtolower($path_info['extension']);
if($extensions_allowed !== false){
if(!in_array($pi, $extensions_allowed)) $this->throw_error(__("zip file contains illegal files", 'revslider'));
}else{
if(in_array($pi, $this->bad_extensions)) $this->throw_error(__("zip file contains illegal files", 'revslider'));
}
}
}else{ //fallback to pclzip
require_once(ABSPATH . 'wp-admin/includes/class-pclzip.php');
$pclzip = new PclZip($zip_file);
$content = $pclzip->listContent();
if(is_array($content) && !empty($content)){
foreach($content as $file){
if(!isset($file['filename'])) continue;
$path_info = pathinfo($file['filename']);
if(!isset($path_info['extension'])) continue;
$pi = strtolower($path_info['extension']);
if($extensions_allowed !== false){
if(!in_array($pi, $extensions_allowed)) $this->throw_error(__("zip file contains illegal files", 'revslider'));
}else{
if(in_array($pi, $this->bad_extensions)) $this->throw_error(__("zip file contains illegal files", 'revslider'));
}
}
}
}
}
}