File "class-wt-common-helper.php"
Full Path: /home/vantageo/public_html/cache/cache/cache/.wp-cli/wp-content/plugins/product-import-export-for-woo/helpers/class-wt-common-helper.php
File size: 11.74 KB
MIME-type: text/x-php
Charset: utf-8
<?php
if(!class_exists('Wt_Import_Export_For_Woo_Basic_Common_Helper')){
class Wt_Import_Export_For_Woo_Basic_Common_Helper
{
public static $min_version_msg='';
/**
* Get File name by url
* @param string $file_url URL of the file.
* @return string the base name of the given URL (File name).
*/
public static function wt_wc_get_filename_from_url( $file_url ) {
$parts = parse_url( $file_url );
if ( isset( $parts['path'] ) ) {
return basename( $parts['path'] );
}
}
/**
* Get info like language code, parent product ID etc by product id.
* @param int Product ID.
* @return array/false.
*/
public static function wt_get_wpml_original_post_language_info($element_id){
$get_language_args = array('element_id' => $element_id, 'element_type' => 'post_product');
$original_post_language_info = apply_filters('wpml_element_language_details', null, $get_language_args);
return $original_post_language_info;
}
public static function wt_get_product_id_by_sku($sku){
global $wpdb;
$post_exists_sku = $wpdb->get_var($wpdb->prepare("
SELECT $wpdb->posts.ID
FROM $wpdb->posts
LEFT JOIN $wpdb->postmeta ON ( $wpdb->posts.ID = $wpdb->postmeta.post_id )
WHERE $wpdb->posts.post_status IN ( 'publish', 'private', 'draft', 'pending', 'future' )
AND $wpdb->postmeta.meta_key = '_sku' AND $wpdb->postmeta.meta_value = '%s'
", $sku));
if ($post_exists_sku) {
return $post_exists_sku;
}
return false;
}
/**
* To strip the specific string from the array key as well as value.
* @param array $array.
* @param string $data.
* @return array.
*/
public static function wt_array_walk($array , $data) {
$new_array =array();
foreach ($array as $key => $value) {
$new_array[str_replace($data, '', $key)] = str_replace($data, '', $value);
}
return $new_array;
}
/**
* Check the minimum base version required for post type modules
*
*/
public static function check_base_version($post_type, $post_type_title, $min_version)
{
$warn_icon='<span class="dashicons dashicons-warning"></span> ';
if(!version_compare(WT_P_IEW_VERSION, $min_version, '>=')) /* not matching the min version */
{
self::$min_version_msg.=$warn_icon.sprintf(__("The %s requires a minimum version of %s %s. Please upgrade the %s accordingly."), "<b>$post_type_title</b>", "<b>".WT_P_IEW_PLUGIN_NAME."</b>", "<b>v$min_version</b>", "<b>".WT_P_IEW_PLUGIN_NAME."</b>").'<br />';
add_action('admin_notices', array(__CLASS__, 'no_minimum_base_version') );
return false;
}
return true;
}
/**
*
* No minimum version error message
*/
public static function no_minimum_base_version()
{
?>
<div class="notice notice-warning">
<p>
<?php
echo self::$min_version_msg;
?>
</p>
</div>
<?php
}
/**
* Decode the post data as normal array from json encoded from data.
* If step key is specified, then it will return the data corresponds to the form key
* @param array $form_data
* @param string $key
*/
public static function process_formdata($form_data, $key='')
{
if($key!="") /* if key is given then take its data */
{
if(isset($form_data[$key]))
{
if(is_array($form_data[$key]))
{
$form_data_vl=$form_data[$key];
}else
{
$form_data_vl=json_decode(stripslashes($form_data[$key]),true);
}
}else
{
$form_data_vl=array();
}
}else
{
$form_data_vl=array();
foreach($form_data as $form_datak=>$form_datav)
{
$form_data_vl[$form_datak]=self::process_formdata($form_data, $form_datak);
}
}
return (is_array($form_data_vl) ? $form_data_vl : array());
}
/**
* Form field generator
*/
public static function field_generator($form_fields, $form_data)
{
include plugin_dir_path( dirname( __FILE__ ) ).'admin/partials/_form_field_generator.php';
}
/**
* Save advanced settings
* @param array $settings array of setting values
*/
public static function set_advanced_settings($settings)
{
update_option('wt_iew_advanced_settings', $settings);
}
/**
*
* Extract validation rule from form field array
* @param array $fields form field array
*/
public static function extract_validation_rules($fields)
{
$out=array_map(function ($r) { return (isset($r['validation_rule']) ? $r['validation_rule'] : ''); }, $fields);
return array_filter($out);
}
/**
* Get advanced settings.
* @param string $key key for specific setting (optional)
* @return mixed if key provided then the value of key otherwise array of values
*/
public static function get_advanced_settings($key="")
{
$advanced_settings=get_option('wt_iew_advanced_settings');
$advanced_settings=($advanced_settings ? $advanced_settings : array());
if($key!="")
{
$key=(substr($key,0,8)!=='wt_iew_' ? 'wt_iew_' : '').$key;
if(isset($advanced_settings[$key]))
{
return $advanced_settings[$key];
}else
{
$default_settings=self::get_advanced_settings_default();
return (isset($default_settings[$key]) ? $default_settings[$key] : '');
}
}else
{
$default_settings=self::get_advanced_settings_default();
$advanced_settings=wp_parse_args($advanced_settings, $default_settings);
return $advanced_settings;
}
}
/**
* Get default value of advanced settings
* @return array array of default values
*
*/
public static function get_advanced_settings_default()
{
$fields=self::get_advanced_settings_fields();
foreach ($fields as $key => $value)
{
if(isset($value['value']))
{
$key=(substr($key,0,8)!=='wt_iew_' ? 'wt_iew_' : '').$key;
$out[$key]=$value['value'];
}
}
return $out;
}
/**
* Get advanced fields
* @return array array of fields
*
*/
public static function get_advanced_settings_fields()
{
$fields=array();
return apply_filters('wt_iew_advanced_setting_fields_basic', $fields);
}
public static function wt_allowed_screens(){
$screens=array('wt_import_export_for_woo_basic','wt_import_export_for_woo_basic_export','wt_import_export_for_woo_basic_import','wt_import_export_for_woo_basic_history','wt_import_export_for_woo_basic_history_log');
return apply_filters('wt_iew_allowed_screens_basic', $screens);
}
public static function wt_get_current_page(){
if (isset($_GET['page'])) {
return $_GET['page'];
}
return '';
}
public static function wt_is_screen_allowed(){
if(in_array(self::wt_get_current_page(), self::wt_allowed_screens())){
return true;
}else{
return false;
}
}
}
}
if(!function_exists('is_woocommerce_prior_to_basic')){
function is_woocommerce_prior_to_basic($version) {
$woocommerce_is_pre_version = (!defined('WC_VERSION') || version_compare(WC_VERSION, $version, '<')) ? true : false;
return $woocommerce_is_pre_version;
if (WC()->version < $version) {
return TRUE;
} else {
return FALSE;
}
}
}
if(!function_exists('wt_let_to_num_basic')){
function wt_let_to_num_basic( $size ) {
$l = substr( $size, -1 );
$ret = (int) substr( $size, 0, -1 );
switch ( strtoupper( $l ) ) {
case 'P':
$ret *= 1024;
// No break.
case 'T':
$ret *= 1024;
// No break.
case 'G':
$ret *= 1024;
// No break.
case 'M':
$ret *= 1024;
// No break.
case 'K':
$ret *= 1024;
// No break.
}
return $ret;
}
}
if(!function_exists('wt_removeBomUtf8_basic')){
function wt_removeBomUtf8_basic($s) {
if (substr($s, 0, 3) == chr(hexdec('EF')) . chr(hexdec('BB')) . chr(hexdec('BF'))) {
return substr($s, 3);
} else {
return $s;
}
}
}
/**
* Outputs a HTML element with a star rating for a given rating.
*
* Outputs a HTML element with the star rating exposed on a 0..5 scale in
* half star increments (ie. 1, 1.5, 2 stars). Optionally, if specified, the
* number of ratings may also be displayed by passing the $number parameter.
*
* @since 3.8.0 - WP
* @since 4.4.0 Introduced the `echo` parameter. - WP
*
* @param array $args {
* Optional. Array of star ratings arguments.
*
* @type int|float $rating The rating to display, expressed in either a 0.5 rating increment,
* or percentage. Default 0.
* @type string $type Format that the $rating is in. Valid values are 'rating' (default),
* or, 'percent'. Default 'rating'.
* @type int $number The number of ratings that makes up this rating. Default 0.
* @type bool $echo Whether to echo the generated markup. False to return the markup instead
* of echoing it. Default true.
* }
* @return string Star rating HTML.
*/
if(!function_exists('wt_wp_star_rating')){
function wt_wp_star_rating( $args = array() ) {
$defaults = array(
'rating' => 0,
'type' => 'rating',
'number' => 0,
'echo' => true,
);
$parsed_args = wp_parse_args( $args, $defaults );
// Non-English decimal places when the $rating is coming from a string.
$rating = (float) str_replace( ',', '.', $parsed_args['rating'] );
// Convert percentage to star rating, 0..5 in .5 increments.
if ( 'percent' === $parsed_args['type'] ) {
$rating = round( $rating / 10, 0 ) / 2;
}
// Calculate the number of each type of star needed.
$full_stars = floor( $rating );
$half_stars = ceil( $rating - $full_stars );
$empty_stars = 5 - $full_stars - $half_stars;
if ( $parsed_args['number'] ) {
/* translators: 1: The rating, 2: The number of ratings. */
$format = _n( '%1$s rating based on %2$s rating', '%1$s rating based on %2$s ratings', $parsed_args['number'] );
$title = sprintf( $format, number_format_i18n( $rating, 1 ), number_format_i18n( $parsed_args['number'] ) );
} else {
/* translators: %s: The rating. */
$title = sprintf( __( '%s rating' ), number_format_i18n( $rating, 1 ) );
}
$output = '<div class="wt-star-rating">';
$output .= '<span class="screen-reader-text">' . $title . '</span>';
$output .= str_repeat( '<div class="wt-star wt-star-full" aria-hidden="true"></div>', $full_stars );
$output .= str_repeat( '<div class="wt-star wt-star-half" aria-hidden="true"></div>', $half_stars );
$output .= str_repeat( '<div class="wt-star wt-star-empty" aria-hidden="true"></div>', $empty_stars );
$output .= '</div>';
if ( $parsed_args['echo'] ) {
echo $output;
}
return $output;
}
}
if(!function_exists('wt_format_decimal') ){
function wt_format_decimal($number) {
$decimals = array(',', '.', ':');
// Remove locale from string.
if (!is_float($number)) {
$number = str_replace($decimals, '.', $number);
$number = preg_replace('/\.(?![^.]+$)|[^0-9.-]/', '', sanitize_text_field($number));
}
return $number;
}
}