<?php
/**
* Functions.
*
* @author YITH <
[email protected]>
* @package YITH\PluginFramework
*/
defined( 'ABSPATH' ) || exit; // Exit if accessed directly.
if ( ! function_exists( 'yit_plugin_locate_template' ) ) {
/**
* Locate the templates and return the path of the file found
*
* @param string $plugin_basename The plugin base name.
* @param string $path The path.
* @param array $var Variable to make visible to the template.
*
* @return string
* @since 2.0.0
*/
function yit_plugin_locate_template( $plugin_basename, $path, $var = null ) {
$template_path = '/theme/templates/' . $path;
$located = locate_template( array( $template_path ) );
if ( ! $located ) {
$located = $plugin_basename . '/templates/' . $path;
}
return $located;
}
}
if ( ! function_exists( 'yit_plugin_get_template' ) ) {
/**
* Retrieve a template file.
*
* @param string $plugin_basename The plugin basename.
* @param string $path The path.
* @param mixed $var Variable that will be extracted to make its items visible to the template.
* @param bool $return return or print the template.
*
* @return string
* @since 2.0.0
*/
function yit_plugin_get_template( $plugin_basename, $path, $var = null, $return = false ) {
$located = yit_plugin_locate_template( $plugin_basename, $path, $var );
if ( $var && is_array( $var ) ) {
extract( $var ); // phpcs:ignore WordPress.PHP.DontExtract.extract_extract
}
if ( $return ) {
ob_start();
}
if ( file_exists( $located ) ) {
include $located;
}
if ( $return ) {
return ob_get_clean();
}
}
}
if ( ! function_exists( 'yit_plugin_content' ) ) {
/**
* Return post content with read more link (if needed)
*
* @param string $what What do you want to see (content, excerpt or something else).
* @param int|string $limit Limit the content.
* @param string $more_text The "more" text.
* @param string $split The split.
* @param bool $in_paragraph Defines if the content is inside a paragraph.
*
* @return string
* @since 2.0.0
* @deprecated 3.5
*/
function yit_plugin_content( $what = 'content', $limit = 25, $more_text = '', $split = '[...]', $in_paragraph = true ) {
if ( 'content' === $what ) {
$content = get_the_content( $more_text );
} else {
if ( 'excerpt' === $what ) {
$content = get_the_excerpt();
} else {
$content = $what;
}
}
if ( ! $limit ) {
if ( 'excerpt' === $what ) {
$content = apply_filters( 'the_excerpt', $content );
} else {
$content = preg_replace( '/<img[^>]+./', '', $content ); // Remove images.
$content = apply_filters( 'the_content', $content );
$content = str_replace( ']]>', ']]>', $content );
}
return $content;
}
// Remove the "more" tag from the content.
if ( preg_match( "/<(a)[^>]*class\s*=\s*(['\"])more-link\\2[^>]*>(.*?)<\/\\1>/", $content, $matches ) ) {
if ( strpos( $matches[0], '[button' ) ) {
$more_link = str_replace( 'href="#"', 'href="' . get_permalink() . '"', do_shortcode( $matches[3] ) );
} else {
$more_link = $matches[0];
}
$content = str_replace( $more_link, '', $content );
$split = '';
}
if ( empty( $content ) ) {
return '';
}
$content = explode( ' ', $content );
if ( ! empty( $more_text ) && ! isset( $more_link ) ) {
$more_link = strpos( $more_text, '<a class="btn"' ) ? $more_text : '<a class="read-more' . apply_filters( 'yit_simple_read_more_classes', ' ' ) . '" href="' . get_permalink() . '">' . $more_text . '</a>';
$split = '';
} elseif ( ! isset( $more_link ) ) {
$more_link = '';
}
// Splitting.
if ( count( $content ) >= $limit ) {
$split_content = '';
for ( $i = 0; $i < $limit; $i++ ) {
$split_content .= $content[ $i ] . ' ';
}
$content = $split_content . $split;
} else {
$content = implode( ' ', $content );
}
// Handle unclosed tags.
$tags = array();
preg_match_all( '/(<([\w]+)[^>]*>)/', $content, $tags_opened, PREG_SET_ORDER ); // Get all opened tags.
foreach ( $tags_opened as $tag ) {
$tags[] = $tag[2];
}
// Get all closed tags and remove them from the opened tags. Others will be closed at the end of the content.
preg_match_all( '/(<\/([\w]+)[^>]*>)/', $content, $tags_closed, PREG_SET_ORDER );
foreach ( $tags_closed as $tag ) {
unset( $tags[ array_search( $tag[2], $tags, true ) ] );
}
// Close the tags.
if ( ! empty( $tags ) ) {
foreach ( $tags as $tag ) {
$content .= "</$tag>";
}
}
if ( ! ! $in_paragraph && 'false' !== $in_paragraph ) { // String comparison kept for backward compatibility.
$content .= $more_link;
}
$content = preg_replace( '/<img[^>]+./', '', $content ); // Remove images.
$content = apply_filters( 'the_content', $content );
$content = str_replace( ']]>', ']]>', $content );
if ( ! $in_paragraph || 'false' === $in_paragraph ) { // String comparison kept for backward compatibility.
$content .= $more_link;
}
return $content;
}
}
if ( ! function_exists( 'yit_plugin_string' ) ) {
/**
* Simple echo a string, with a before and after string, only if the main string is not empty.
*
* @param string $before What there is before the main string.
* @param string $string The main string. If it is empty or null, the functions return null.
* @param string $after What there is after the main string.
* @param bool $echo If echo or only return it.
*
* @return string The complete string, if the main string is not empty or null
* @since 2.0.0
* @deprecated 3.5
*/
function yit_plugin_string( $before = '', $string = '', $after = '', $echo = true ) {
$html = '';
if ( ! ! $string ) {
$html = $before . $string . $after;
}
if ( $echo ) {
echo $html; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
}
return $html;
}
}
if ( ! function_exists( 'yit_plugin_decode_title' ) ) {
/**
* Change some special characters to put easily html into a string
* E.G.
* string: This is [my title] with | a new line
* return: This is <span class="title-highlight">my title</span> with <br /> a new line
*
* @param string $title The string to convert.
*
* @return string The html
* @since 1.0
* @deprecated 3.5
*/
function yit_plugin_decode_title( $title ) {
$replaces = apply_filters( 'yit_title_special_characters', array() );
return preg_replace( array_keys( $replaces ), array_values( $replaces ), $title );
}
}
if ( ! function_exists( 'yit_plugin_get_attachment_id' ) ) {
/**
* Return the ID of an attachment.
*
* @param string $url The attachment URL.
*
* @return int
* @since 2.0.0
*/
function yit_plugin_get_attachment_id( $url ) {
$upload_dir = wp_upload_dir();
$dir = trailingslashit( $upload_dir['baseurl'] );
if ( false === strpos( $url, $dir ) ) {
return false;
}
$file = basename( $url );
$query = array(
'post_type' => 'attachment',
'fields' => 'ids',
// phpcs:ignore WordPress.DB.SlowDBQuery.slow_db_query_meta_query
'meta_query' => array(
array(
'value' => $file,
'compare' => 'LIKE',
),
),
);
$query['meta_query'][0]['key'] = '_wp_attached_file';
$ids = get_posts( $query );
foreach ( $ids as $id ) {
$attachment_image = wp_get_attachment_image_src( $id, 'full' );
if ( array_shift( $attachment_image ) === $url || str_replace( 'https://', 'http://', array_shift( $attachment_image ) ) === $url ) {
return $id;
}
}
$query['meta_query'][0]['key'] = '_wp_attachment_metadata';
$ids = get_posts( $query );
foreach ( $ids as $id ) {
$meta = wp_get_attachment_metadata( $id );
if ( ! isset( $meta['sizes'] ) ) {
continue;
}
foreach ( (array) $meta['sizes'] as $size => $values ) {
$src = wp_get_attachment_image_src( $id, $size );
if ( $values['file'] === $file && str_replace( 'https://', 'http://', array_shift( $src ) ) === $url ) {
return $id;
}
}
}
return false;
}
}
if ( ! function_exists( 'yit_enqueue_script' ) ) {
/**
* Enqueues script.
* Registers the script if src provided (does NOT overwrite) and enqueues.
* IMPORTANT: used only in themes, since it needs the YIT_Asset class.
*
* @param string $handle Name of the script. Should be unique.
* @param string $src Full URL of the script, or path of the script relative to the WordPress root directory.
* @param string[] $deps Optional. An array of registered script handles this script depends on. Default empty array.
* @param string|bool|null $ver Optional. String specifying script version number.
* @param bool $in_footer Optional. Whether to enqueue the script before </body> instead of in the <head>.
*
* @deprecated 3.5
*/
function yit_enqueue_script( $handle, $src, $deps = array(), $ver = false, $in_footer = true ) {
if ( function_exists( 'YIT_Asset' ) && ! is_admin() ) {
$enqueue = true;
YIT_Asset()->set( 'script', $handle, compact( 'src', 'deps', 'ver', 'in_footer', 'enqueue' ) );
} else {
wp_enqueue_script( $handle, $src, $deps, $ver, $in_footer );
}
}
}
if ( ! function_exists( 'yit_enqueue_style' ) ) {
/**
* Enqueue Styles.
* IMPORTANT: used only in themes, since it needs the YIT_Asset class.
*
* @param string $handle Name of the stylesheet. Should be unique.
* @param string $src Full URL of the stylesheet, or path of the stylesheet relative to the WordPress root directory.
* @param string[] $deps Optional. An array of registered stylesheet handles this stylesheet depends on. Default empty array.
* @param string|bool|null $ver Optional. String specifying stylesheet version number.
* @param string $media Optional. The media for which this stylesheet has been defined.
*
* @deprecated 3.5
*/
function yit_enqueue_style( $handle, $src, $deps = array(), $ver = false, $media = 'all' ) {
if ( function_exists( 'YIT_Asset' ) ) {
$enqueue = true;
$who = YIT_Asset()->get_stylesheet_handle( get_stylesheet_uri(), 'style' );
$where = 'before';
if ( ! $who ) {
$who = '';
}
YIT_Asset()->set( 'style', $handle, compact( 'src', 'deps', 'ver', 'media', 'enqueue' ), $where, $who );
} else {
wp_enqueue_style( $handle, $src, $deps, $ver, $media );
}
}
}
if ( ! function_exists( 'yit_get_post_meta' ) ) {
/**
* Retrieve the value of a metabox.
* This function retrieve the value of a metabox attached to a post. It return either a single value or an array.
*
* @param int $id Post ID.
* @param string $meta The meta key to retrieve.
*
* @return mixed Single value or array. Return false is the meta doesn't exists.
* @since 2.0.0
*/
function yit_get_post_meta( $id, $meta ) {
if ( ! strpos( $meta, '[' ) ) {
return metadata_exists( 'post', $id, $meta ) ? get_post_meta( $id, $meta, true ) : false;
}
$sub_meta = explode( '[', $meta );
$meta = get_post_meta( $id, current( $sub_meta ), true );
$sub_meta_count = count( $sub_meta );
for ( $i = 1; $i < $sub_meta_count; $i++ ) {
$current_submeta = rtrim( $sub_meta[ $i ], ']' );
if ( ! isset( $meta[ $current_submeta ] ) ) {
return false;
}
$meta = $meta[ $current_submeta ];
}
return $meta;
}
}
if ( ! function_exists( 'yit_string' ) ) {
/**
* Simple echo a string, with a before and after string, only if the main string is not empty.
*
* @param string $before What there is before the main string.
* @param string $string The main string. If it is empty or null, the functions return null.
* @param string $after What there is after the main string.
* @param bool $echo If echo or only return it.
*
* @return string The complete string, if the main string is not empty or null
* @since 2.0.0
* @deprecated 3.5
*/
function yit_string( $before = '', $string = '', $after = '', $echo = true ) {
$html = '';
if ( ! ! $string ) {
$html = $before . $string . $after;
}
if ( $echo ) {
echo $html; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
}
return $html;
}
}
if ( ! function_exists( 'yit_pagination' ) ) {
/**
* Print pagination
*
* @param int|string $pages The number of pages.
* @param int $range The range.
*
* @since 2.0.0
* @deprecated 3.5
*/
function yit_pagination( $pages = '', $range = 10 ) {
$pages = ! ! $pages ? absint( $pages ) : false;
$showitems = ( $range * 2 ) + 1;
$paged = ( get_query_var( 'paged' ) ) ? get_query_var( 'paged' ) : false;
if ( false === $paged ) {
$paged = ( get_query_var( 'page' ) ) ? get_query_var( 'page' ) : false;
}
if ( false === $paged ) {
$paged = 1;
}
$paged = absint( $paged );
$html = '';
if ( false === $pages ) {
global $wp_query;
if ( isset( $wp_query->max_num_pages ) ) {
$pages = $wp_query->max_num_pages;
}
if ( ! $pages ) {
$pages = 1;
}
}
if ( 1 !== $pages ) {
$html .= "<div class='general-pagination clearfix'>";
if ( $paged > 2 ) {
$html .= sprintf( '<a class="%s" href="%s">«</a>', 'yit_pagination_first', get_pagenum_link( 1 ) );
}
if ( $paged > 1 ) {
$html .= sprintf( '<a class="%s" href="%s">‹</a>', 'yit_pagination_previous', get_pagenum_link( $paged - 1 ) );
}
for ( $i = 1; $i <= $pages; $i++ ) {
if ( 1 !== $pages && ( ! ( $i >= $paged + $range + 1 || $i <= $paged - $range - 1 ) || $pages <= $showitems ) ) {
$class = ( $paged === $i ) ? 'selected' : '';
$html .= '<a href="' . esc_url( get_pagenum_link( $i ) ) . '" class="' . esc_attr( $class ) . '">' . esc_html( $i ) . '</a>';
}
}
if ( $paged < $pages ) {
$html .= sprintf( '<a class="%s" href="%s">›</a>', 'yit_pagination_next', esc_url( get_pagenum_link( $paged + 1 ) ) );
}
if ( $paged < $pages - 1 ) {
$html .= sprintf( '<a class="%s" href="%s">»</a>', 'yit_pagination_last', esc_url( get_pagenum_link( $pages ) ) );
}
$html .= "</div>\n";
}
echo apply_filters( 'yit_pagination_html', $html ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
}
}
if ( ! function_exists( 'yit_registered_sidebars' ) ) {
/**
* Retrieve all registered sidebars
*
* @return array
* @since 2.0.0
* @deprecated 3.5
*/
function yit_registered_sidebars() {
global $wp_registered_sidebars;
$return = array();
if ( empty( $wp_registered_sidebars ) ) {
$return = array( '' => '' );
}
foreach ( (array) $wp_registered_sidebars as $the_ ) {
$return[ $the_['name'] ] = $the_['name'];
}
ksort( $return );
return $return;
}
}
if ( ! function_exists( 'yit_layout_option' ) ) {
/**
* Retrieve a layout option
* IMPORTANT: used only in themes, since it needs the YIT_Layout_Panel class.
*
* @param string $key The key.
* @param bool $id The ID.
* @param string $type The type.
* @param string $model The model.
*
* @return array
* @since 2.0.0
* @deprecated 3.5
*/
function yit_layout_option( $key, $id = false, $type = 'post', $model = 'post_type' ) {
$option = '';
if ( defined( 'YIT' ) ) {
$option = YIT_Layout_Panel()->get_option( $key, $id, $type, $model );
} else {
if ( ! $id && ( is_single() || is_page() ) ) {
global $post;
$id = $post->ID;
} elseif ( 'all' !== $id ) {
$option = get_post_meta( $id, $key );
}
}
return $option;
}
}
if ( ! function_exists( 'yit_curPageURL' ) ) {
/**
* Retrieve the current complete url
*
* @since 1.0
*/
function yit_curPageURL() { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionNameInvalid
// phpcs:disable WordPress.Security.ValidatedSanitizedInput
$page_url = 'http';
if ( isset( $_SERVER['HTTPS'] ) && 'on' === $_SERVER['HTTPS'] ) {
$page_url .= 's';
}
$page_url .= '://';
if ( isset( $_SERVER['SERVER_PORT'] ) && 80 !== absint( $_SERVER['SERVER_PORT'] ) ) {
$page_url .= $_SERVER['SERVER_NAME'] . ':' . $_SERVER['SERVER_PORT'] . $_SERVER['REQUEST_URI'];
} else {
$page_url .= $_SERVER['SERVER_NAME'] . $_SERVER['REQUEST_URI'];
}
return $page_url;
// phpcs:enable
}
}
if ( ! function_exists( 'yit_get_excluded_categories' ) ) {
/**
* Retrieve the excluded categories, set on Theme Options
*
* @param int $k Key.
*
* @return string String with all id categories excluded, separated by a comma
* @since 2.0.0
* @deprecated 3.5
*/
function yit_get_excluded_categories( $k = 1 ) {
global $post;
if ( ! isset( $post->ID ) ) {
return '';
}
$cf_cats = get_post_meta( $post->ID, 'blog-cats', true );
if ( ! empty( $cf_cats ) ) {
return $cf_cats;
}
$cats = function_exists( 'yit_get_option' ) ? yit_get_option( 'blog-excluded-cats' ) : '';
if ( ! is_array( $cats ) || empty( $cats ) || ! isset( $cats[ $k ] ) ) {
return '';
}
$cats = array_map( 'trim', $cats[ $k ] );
$i = 0;
$query = '';
foreach ( $cats as $cat ) {
$query .= ",-$cat";
$i++;
}
ltrim( ',', $query );
return $query;
}
}
if ( ! function_exists( 'yit_add_extra_theme_headers' ) ) {
add_filter( 'extra_theme_headers', 'yit_add_extra_theme_headers' );
/**
* Check the framework core version
*
* @param array $headers The headers.
*
* @return array
* @since 2.0.0
*/
function yit_add_extra_theme_headers( $headers ) {
$headers[] = 'Core Framework Version';
return $headers;
}
}
if ( ! function_exists( 'yit_check_plugin_support' ) ) {
/**
* Check the framework core version
*
* @return bool
* @since 2.0.0
*/
function yit_check_plugin_support() {
$headers['core'] = wp_get_theme()->get( 'Core Framework Version' );
$headers['author'] = wp_get_theme()->get( 'Author' );
if ( ! $headers['core'] && defined( 'YIT_CORE_VERSION' ) ) {
$headers['core'] = YIT_CORE_VERSION;
}
if ( ( ! empty( $headers['core'] ) && version_compare( $headers['core'], '2.0.0', '<=' ) ) || 'Your Inspiration Themes' !== $headers['author'] ) {
return true;
} else {
return false;
}
}
}
if ( ! function_exists( 'yit_ie_version' ) ) {
/**
* Retrieve IE version.
*
* @return int|float
* @since 1.0.0
*/
function yit_ie_version() {
// phpcs:disable WordPress.Security.ValidatedSanitizedInput
if ( ! isset( $_SERVER['HTTP_USER_AGENT'] ) ) {
return -1;
}
preg_match( '/MSIE ([0-9]+\.[0-9])/', $_SERVER['HTTP_USER_AGENT'], $reg );
// IE 11 fix.
if ( ! isset( $reg[1] ) ) {
preg_match( '/rv:([0-9]+\.[0-9])/', $_SERVER['HTTP_USER_AGENT'], $reg );
if ( ! isset( $reg[1] ) ) {
return -1;
} else {
return floatval( $reg[1] );
}
} else {
return floatval( $reg[1] );
}
// phpcs:enable
}
}
if ( ! function_exists( 'yit_avoid_duplicate' ) ) {
/**
* Check if something exists. If yes, add a -N to the value where N is a number.
*
* @param mixed $value The value to check.
* @param array $array The array to search in.
* @param string $check Specifies if the check should be done on values or on keys (default: 'value').
*
* @return mixed
* @since 2.0.0
*/
function yit_avoid_duplicate( $value, $array, $check = 'value' ) {
$match = array();
if ( ! is_array( $array ) ) {
return $value;
}
if ( ( 'value' === $check && ! in_array( $value, $array, true ) ) || ( 'key' === $check && ! isset( $array[ $value ] ) ) ) {
return $value;
} else {
if ( ! preg_match( '/([a-z]+)-([0-9]+)/', $value, $match ) ) {
$i = 2;
} else {
$i = intval( $match[2] ) + 1;
$value = $match[1];
}
return yit_avoid_duplicate( $value . '-' . $i, $array, $check );
}
}
}
if ( ! function_exists( 'yit_title_special_characters' ) ) {
/**
* The chars used in yit_decode_title() and yit_encode_title()
* E.G.
* string: This is [my title] with | a new line
* return: This is <span class="highlight">my title</span> with <br /> a new line
*
* @param array $chars The chars.
*
* @return array
* @since 1.0
* @deprecated 3.5
*/
function yit_title_special_characters( $chars ) {
return array_merge(
$chars,
array(
'/[=\[](.*?)[=\]]/' => '<span class="title-highlight">$1</span>',
'/\|/' => '<br />',
)
);
}
add_filter( 'yit_title_special_characters', 'yit_title_special_characters' );
}
if ( ! function_exists( 'yit_decode_title' ) ) {
/**
* Change some special characters to put easily html into a string
* E.G.
* string: This is [my title] with | a new line
* return: This is <span class="title-highlight">my title</span> with <br /> a new line
*
* @param string $title The string to convert.
*
* @return string The html
* @since 1.0
* @deprecated 3.5
*/
function yit_decode_title( $title ) {
$replaces = apply_filters( 'yit_title_special_characters', array() );
return preg_replace( array_keys( $replaces ), array_values( $replaces ), $title );
}
}
if ( ! function_exists( 'yit_encode_title' ) ) {
/**
* Change some special characters to put easily html into a string
* E.G.
* string: This is [my title] with | a new line
* return: This is <span class="title-highlight">my title</span> with <br /> a new line
*
* @param string $title The string to convert.
*
* @return string The html
* @since 1.0
* @deprecated 3.5
*/
function yit_encode_title( $title ) {
$replaces = apply_filters( 'yit_title_special_characters', array() );
return preg_replace( array_values( $replaces ), array_keys( $replaces ), $title );
}
}
if ( ! function_exists( 'yit_remove_chars_title' ) ) {
/**
* Change some special characters to put easily html into a string
* E.G.
* string: This is [my title] with | a new line
* return: This is <span class="title-highlight">my title</span> with <br /> a new line
*
* @param string $title The string to convert.
*
* @return string The html
* @since 1.0
* @deprecated 3.5
*/
function yit_remove_chars_title( $title ) {
$replaces = apply_filters( 'yit_title_special_characters', array() );
return preg_replace( array_keys( $replaces ), '$1', $title );
}
}
if ( ! function_exists( 'is_shop_installed' ) ) {
/**
* Detect if there is a shop plugin installed
*
* @return bool
* @since 2.0.0
*/
function is_shop_installed() {
global $woocommerce;
if ( isset( $woocommerce ) || defined( 'JIGOSHOP_VERSION' ) ) {
return true;
} else {
return false;
}
}
}
if ( ! function_exists( 'yit_load_js_file' ) ) {
/**
* Load .min.js file if WP_Debug is not defined
*
* @param string $filename The file name.
*
* @return string The file path
* @since 2.0.0
*/
function yit_load_js_file( $filename ) {
if ( ! ( ( defined( 'WP_DEBUG' ) && WP_DEBUG ) || ( defined( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG ) || isset( $_GET['yith_script_debug'] ) ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Recommended
$filename = str_replace( '.js', '.min.js', $filename );
}
return $filename;
}
}
if ( ! function_exists( 'yit_load_css_file' ) ) {
/**
* Load .min.css file if WP_Debug is not defined
*
* @param string $filename The file name.
*
* @return string The file path
* @since 2.0.0
*/
function yit_load_css_file( $filename ) {
if ( ! ( ( defined( 'WP_DEBUG' ) && WP_DEBUG ) || ( defined( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG ) || isset( $_GET['yith_script_debug'] ) ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Recommended
$filename = str_replace( '.css', '.min.css', $filename );
}
return $filename;
}
}
if ( ! function_exists( 'yit_wpml_register_string' ) ) {
/**
* Register a string in wpml translation.
*
* @param string $context The context name.
* @param string $name The name.
* @param string $value The value to translate.
*
* @since 2.0.0
*/
function yit_wpml_register_string( $context, $name, $value ) {
do_action( 'wpml_register_single_string', $context, $name, $value );
}
}
if ( ! function_exists( 'yit_wpml_string_translate' ) ) {
/**
* Get a string translation
*
* @param string $context The context name.
* @param string $name The name.
* @param string $default_value Default value.
*
* @return string the string translated
* @since 2.0.0
*/
function yit_wpml_string_translate( $context, $name, $default_value ) {
return apply_filters( 'wpml_translate_single_string', $default_value, $context, $name );
}
}
if ( ! function_exists( 'yit_wpml_object_id' ) ) {
/**
* Get id of post translation in current language
*
* @param int $element_id The element ID.
* @param string $element_type The element type.
* @param bool $return_original_if_missing Return original if missing or not.
* @param null|string $language_code The language code.
*
* @return int the translation id
* @since 2.0.0
*/
function yit_wpml_object_id( $element_id, $element_type = 'post', $return_original_if_missing = false, $language_code = null ) {
if ( function_exists( 'wpml_object_id_filter' ) ) {
return wpml_object_id_filter( $element_id, $element_type, $return_original_if_missing, $language_code );
} elseif ( function_exists( 'icl_object_id' ) ) {
return icl_object_id( $element_id, $element_type, $return_original_if_missing, $language_code );
} else {
return $element_id;
}
}
}
if ( ! function_exists( 'yit_get_language_from_locale' ) ) {
/**
* Returns language name from locale code
*
* @param string $locale Locale to search for.
* @param bool $show_native Whether to return native language instead of english one.
*
* @return string Language name for passed locale; if can't find any, local itself is returned.
* @since 3.7.1
*/
function yit_get_language_from_locale( $locale, $show_native = false ) {
require_once ABSPATH . 'wp-admin/includes/translation-install.php';
$translations = wp_get_available_translations();
if ( in_array( $locale, array( 'en', 'en_US' ), true ) ) {
/**
* English (United States) is not included in translations array
* We return fixed, non-localized string, as WordPress does
*
* @see {wp_dropdown_languages}
*/
return 'English';
}
if ( empty( $translations ) ) {
return $locale;
}
// perfect match.
$translation = isset( $translations[ $locale ] ) ? $translations[ $locale ] : false;
// check for no-dialect.
if ( 2 === strlen( $locale ) ) {
// first check for common occurrences.
if ( 'it' === $locale && isset( $translations['it_IT'] ) ) {
$translation = $translations['it_IT'];
} elseif ( 'es' === $locale && isset( $translations['es_ES'] ) ) {
$translation = $translations['es_ES'];
} elseif ( 'de' === $locale && isset( $translations['de_DE'] ) ) {
$translation = $translations['de_DE'];
} else {
foreach ( $translations as $translation_locale => $translation_details ) {
$no_dialect_locale = isset( $translation_details['iso'][1] ) ? $translation_details['iso'][1] : substr( $translation_locale, 0, 2 );
if ( $locale !== $no_dialect_locale ) {
continue;
}
$translation = $translation_details;
// remove dialect from names.
$translation['english_name'] = preg_replace( '/(.+) \(.*\)/', '$1', $translation['english_name'] );
// we found what we were looking for; break.
break;
}
}
}
if ( ! $translation ) {
return $locale;
}
$language_name = $show_native ? $translation['native_name'] : $translation['english_name'];
return $language_name;
}
}
if ( ! function_exists( 'yith_get_formatted_price' ) ) {
/**
* Format the price with a currency symbol.
*
* @param float $price The price.
* @param array $args Arguments.
*
* @return string
*/
function yith_get_formatted_price( $price, $args = array() ) {
$defaults = array(
'ex_tax_label' => false,
'currency' => '',
'decimal_separator' => wc_get_price_decimal_separator(),
'thousand_separator' => wc_get_price_thousand_separator(),
'decimals' => wc_get_price_decimals(),
'price_format' => get_woocommerce_price_format(),
);
$args = wp_parse_args( $args, $defaults );
$args = apply_filters( 'wc_price_args', $args );
list ( $decimals, $decimal_separator, $thousand_separator, $price_format, $currency ) = yith_plugin_fw_extract( $args, 'decimals', 'decimal_separator', 'thousand_separator', 'price_format', 'currency' );
$negative = $price < 0;
$price = apply_filters( 'raw_woocommerce_price', floatval( $negative ? $price * -1 : $price ) );
$price = apply_filters( 'formatted_woocommerce_price', number_format( $price, $decimals, $decimal_separator, $thousand_separator ), $price, $decimals, $decimal_separator, $thousand_separator );
if ( apply_filters( 'woocommerce_price_trim_zeros', false ) && $decimals > 0 ) {
$price = wc_trim_zeros( $price );
}
$formatted_price = ( $negative ? '-' : '' ) . sprintf( $price_format, get_woocommerce_currency_symbol( $currency ), $price );
$return = $formatted_price;
return apply_filters( 'wc_price', $return, $price, $args );
}
}
if ( ! function_exists( 'yith_get_terms' ) ) {
/**
* Get terms.
*
* @param array $args Arguments.
*
* @return array|int|WP_Error
* @deprecated 3.5 | use get_terms instead
*/
function yith_get_terms( $args ) {
global $wp_version;
if ( version_compare( $wp_version, '4.5', '>=' ) ) {
$terms = get_terms( $args );
} else {
$terms = get_terms( $args['taxonomy'], $args );
}
return $terms;
}
}
if ( ! function_exists( 'yith_field_deps_data' ) ) {
/**
* Retrieve the field deps HTML data.
*
* @param array $field The field.
*
* @return string
*/
function yith_field_deps_data( $field ) {
$deps_data = '';
if ( isset( $field['deps'] ) && ( isset( $field['deps']['ids'] ) || isset( $field['deps']['id'] ) ) && ( isset( $field['deps']['values'] ) || isset( $field['deps']['value'] ) ) ) {
$deps = $field['deps'];
$id = isset( $deps['target-id'] ) ? $deps['target-id'] : $field['id'];
$dep_id = isset( $deps['id'] ) ? $deps['id'] : $deps['ids'];
$dep_values = isset( $deps['value'] ) ? $deps['value'] : $deps['values'];
$dep_type = isset( $deps['type'] ) ? $deps['type'] : 'fadeIn';
$deps_data = 'data-dep-target="' . esc_attr( $id ) . '" data-dep-id="' . esc_attr( $dep_id ) . '" data-dep-value="' . esc_attr( $dep_values ) . '" data-dep-type="' . esc_attr( $dep_type ) . '"';
}
return $deps_data;
}
}
if ( ! function_exists( 'yith_panel_field_deps_data' ) ) {
/**
* Retrieve the panel field deps HTML data.
*
* @param array $field The field.
* @param YIT_Plugin_Panel|YIT_Plugin_Panel_WooCommerce $panel The panel object.
*
* @return string
*/
function yith_panel_field_deps_data( $field, $panel ) {
$deps_data = '';
if ( isset( $field['deps'] ) && ( isset( $field['deps']['ids'] ) || isset( $field['deps']['id'] ) ) && isset( $field['deps']['values'] ) ) {
$dep_id = isset( $field['deps']['id'] ) ? $field['deps']['id'] : $field['deps']['ids'];
$field['deps']['ids'] = $panel->get_id_field( $dep_id );
$field['deps']['id'] = $panel->get_id_field( $dep_id );
$field['id'] = $panel->get_id_field( $field['id'] );
$deps_data = yith_field_deps_data( $field );
}
return $deps_data;
}
}
if ( ! function_exists( 'yith_plugin_fw_get_field' ) ) {
/**
* Retrieve a field.
*
* @param array $field The field.
* @param false $echo Set to true to print the field directly; false otherwise.
* @param bool $show_container Set to true to show the container; false otherwise.
*
* @return false|string
*/
function yith_plugin_fw_get_field( $field, $echo = false, $show_container = true ) {
if ( empty( $field['type'] ) ) {
return '';
}
if ( ! isset( $field['value'] ) ) {
$field['value'] = '';
}
if ( ! isset( $field['name'] ) ) {
$field['name'] = '';
}
if ( ! isset( $field['custom_attributes'] ) ) {
$field['custom_attributes'] = array();
}
if ( is_array( $field['custom_attributes'] ) ) {
/**
* Convert custom_attributes to string to prevent issues in plugins using them as string in their templates.
* todo: remove after checking plugins using custom_attributes as "string" in custom fields templates and as "array" in custom fields options.
*/
$field['custom_attributes'] = yith_plugin_fw_html_attributes_to_string( $field['custom_attributes'] );
}
if ( ! isset( $field['default'] ) && isset( $field['std'] ) ) {
$field['default'] = $field['std'];
}
$field_template = yith_plugin_fw_get_field_template_path( $field );
if ( ! isset( $field['id'] ) ) {
static $field_number = 1;
$field['id'] = "yith-plugin-fw-field__{$field_number}";
$field_number++;
}
if ( $field_template ) {
if ( ! $echo ) {
ob_start();
}
if ( $show_container ) {
echo '<div class="yith-plugin-fw-field-wrapper yith-plugin-fw-' . esc_attr( $field['type'] ) . '-field-wrapper">';
}
do_action( 'yith_plugin_fw_get_field_before', $field );
do_action( 'yith_plugin_fw_get_field_' . $field['type'] . '_before', $field );
include $field_template;
do_action( 'yith_plugin_fw_get_field_after', $field );
do_action( 'yith_plugin_fw_get_field_' . $field['type'] . '_after', $field );
if ( $show_container ) {
echo '</div>';
}
if ( ! $echo ) {
return ob_get_clean();
}
}
return '';
}
}
if ( ! function_exists( 'yith_plugin_fw_get_field_template_path' ) ) {
/**
* Retrieve the field template path.
*
* @param array $field The field.
*
* @return false|string
*/
function yith_plugin_fw_get_field_template_path( $field ) {
if ( empty( $field['type'] ) ) {
return false;
}
$field_template = YIT_CORE_PLUGIN_TEMPLATE_PATH . '/fields/' . sanitize_title( $field['type'] ) . '.php';
$field_template = apply_filters( 'yith_plugin_fw_get_field_template_path', $field_template, $field );
return file_exists( $field_template ) ? $field_template : false;
}
}
if ( ! function_exists( 'yith_plugin_fw_html_data_to_string' ) ) {
/**
* Transform data array to HTML data.
*
* @param array $data The array of data.
* @param false $echo Set to true to print it directly; false otherwise.
*
* @return string
*/
function yith_plugin_fw_html_data_to_string( $data = array(), $echo = false ) {
$html_data = '';
if ( ! ! $data ) {
if ( is_array( $data ) ) {
foreach ( $data as $key => $value ) {
$data_attribute = "data-{$key}";
$data_value = ! is_array( $value ) ? $value : implode( ',', $value );
$html_data .= ' ' . esc_attr( $data_attribute ) . '="' . esc_attr( $data_value ) . '"';
}
$html_data .= ' ';
}
}
if ( $echo ) {
echo $html_data; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
}
return $html_data;
}
}
if ( ! function_exists( 'yith_plugin_fw_get_icon' ) ) {
/**
* Retrieve an icon.
*
* @param string $icon The icon.
* @param array $args Array of arguments (such as html_tag, class, style, filter_suffix).
*
* @return string
*/
function yith_plugin_fw_get_icon( $icon = '', $args = array() ) {
return YIT_Icons()->get_icon( $icon, $args );
}
}
if ( ! function_exists( 'yith_plugin_fw_is_true' ) ) {
/**
* Is something true?
*
* @param string|bool|int $value The value to check for.
*
* @return bool
*/
function yith_plugin_fw_is_true( $value ) {
return true === $value || 1 === $value || '1' === $value || 'yes' === $value || 'true' === $value;
}
}
if ( ! function_exists( 'yith_plugin_fw_enqueue_enhanced_select' ) ) {
/**
* Enqueue the enhanced select style and script.
*/
function yith_plugin_fw_enqueue_enhanced_select() {
wp_enqueue_script( 'yith-enhanced-select' );
$select2_style_to_enqueue = function_exists( 'WC' ) ? 'woocommerce_admin_styles' : 'yith-select2-no-wc';
wp_enqueue_style( $select2_style_to_enqueue );
}
}
if ( ! function_exists( 'yit_add_select2_fields' ) ) {
/**
* Add select 2.
*
* @param array $args The arguments.
*/
function yit_add_select2_fields( $args = array() ) {
$default = array(
'type' => 'hidden',
'class' => '',
'id' => '',
'name' => '',
'data-placeholder' => '',
'data-allow_clear' => false,
'data-selected' => '',
'data-multiple' => false,
'data-action' => '',
'value' => '',
'style' => '',
'custom-attributes' => array(),
);
$args = wp_parse_args( $args, $default );
$custom_attributes = array();
foreach ( $args['custom-attributes'] as $attribute => $attribute_value ) {
$custom_attributes[] = esc_attr( $attribute ) . '="' . esc_attr( $attribute_value ) . '"';
}
$custom_attributes = implode( ' ', $custom_attributes );
if ( ! function_exists( 'WC' ) || version_compare( WC()->version, '2.7.0', '>=' ) ) {
if ( true === $args['data-multiple'] && substr( $args['name'], -2 ) !== '[]' ) {
$args['name'] = $args['name'] . '[]';
}
$select2_template_name = 'select2.php';
} else {
if ( false === $args['data-multiple'] && is_array( $args['data-selected'] ) ) {
$args['data-selected'] = current( $args['data-selected'] );
}
$select2_template_name = 'select2-wc-2.6.php';
}
$template = YIT_CORE_PLUGIN_TEMPLATE_PATH . '/fields/resources/' . $select2_template_name;
if ( file_exists( $template ) ) {
include $template;
}
}
}
if ( ! function_exists( 'yith_plugin_fw_get_version' ) ) {
/**
* Retrieve the Plugin Framework version.
*
* @return string
*/
function yith_plugin_fw_get_version() {
$plugin_fw_data = get_file_data( trailingslashit( YIT_CORE_PLUGIN_PATH ) . 'init.php', array( 'Version' => 'Version' ) );
return $plugin_fw_data['Version'];
}
}
if ( ! function_exists( 'yith_get_premium_support_url' ) ) {
/**
* Return the url for My Account > Support dashboard
*
* @return string The complete string, if the main string is not empty or null
* @since 2.0.0
* @deprecated 3.5
*/
function yith_get_premium_support_url() {
return 'https://yithemes.com/my-account/support/dashboard/';
}
}
if ( ! function_exists( 'yith_plugin_fw_is_panel' ) ) {
/**
* Is this a Plugin Framework panel?
*
* @return bool
*/
function yith_plugin_fw_is_panel() {
$panel_screen_id = 'yith-plugins_page';
$screen = function_exists( 'get_current_screen' ) ? get_current_screen() : null;
return $screen instanceof WP_Screen && strpos( $screen->id, $panel_screen_id ) !== false;
}
}
if ( ! function_exists( 'yith_plugin_fw_force_regenerate_plugin_update_transient' ) ) {
/**
* Delete the update plugins transient
*
* @return void
* @since 1.0
* @see update_plugins transient and pre_set_site_transient_update_plugins hooks
*/
function yith_plugin_fw_force_regenerate_plugin_update_transient() {
delete_site_transient( 'update_plugins' );
}
}
if ( ! function_exists( 'yith_plugin_fw_is_gutenberg_enabled' ) ) {
/**
* Is Gutenberg enabled?
*
* @return bool
*/
function yith_plugin_fw_is_gutenberg_enabled() {
return function_exists( 'YITH_Gutenberg' );
}
}
if ( ! function_exists( 'yith_plugin_fw_gutenberg_add_blocks' ) ) {
/**
* Add new blocks to Gutenberg
*
* @param string|array $blocks Blocks to add.
*
* @return bool true if add a new blocks, false otherwise
*/
function yith_plugin_fw_gutenberg_add_blocks( $blocks ) {
$added = false;
if ( yith_plugin_fw_is_gutenberg_enabled() ) {
// Add blocks.
$added = YITH_Gutenberg()->add_blocks( $blocks );
}
return $added;
}
}
if ( ! function_exists( 'yith_plugin_fw_gutenberg_get_registered_blocks' ) ) {
/**
* Return an array with the registered blocks
*
* @return array
*/
function yith_plugin_fw_gutenberg_get_registered_blocks() {
return yith_plugin_fw_is_gutenberg_enabled() ? YITH_Gutenberg()->get_registered_blocks() : array();
}
}
if ( ! function_exists( 'yith_plugin_fw_gutenberg_get_to_register_blocks' ) ) {
/**
* Return an array with the blocks to register
*
* @return array
*/
function yith_plugin_fw_gutenberg_get_to_register_blocks() {
return yith_plugin_fw_is_gutenberg_enabled() ? YITH_Gutenberg()->get_to_register_blocks() : array();
}
}
if ( ! function_exists( 'yith_plugin_fw_get_default_logo' ) ) {
/**
* Get the default SVG logo
*
* @return string default logo image url
*/
function yith_plugin_fw_get_default_logo() {
return YIT_CORE_PLUGIN_URL . '/assets/images/yith-icon.svg';
}
}
if ( ! function_exists( 'yith_get_wrapper_class' ) ) {
/**
* Return the wrapper class for the UI style.
*
* @return string
* @since 3.7.0
*/
function yith_get_wrapper_class() {
return 'yith-plugin-ui';
}
}
if ( ! function_exists( 'yith_set_wrapper_class' ) ) {
/**
* Return the wrapper class for the UI style, by setting any additional class passed through the $class parameter.
*
* @param array|string $class List of additional classes to add to the UI style class.
*
* @return string
*/
function yith_set_wrapper_class( $class = '' ) {
$new_class = yith_get_wrapper_class();
$class = ( ! empty( $class ) && is_array( $class ) ) ? implode( ' ', $class ) : $class;
return $new_class . ' ' . $class;
}
}
if ( ! function_exists( 'yith_get_date_formats' ) ) {
/**
* Get all available date format.
*
* @param bool $js JS date format or not.
*
* @return array
* @since 3.1
* @deprecated 3.5 | use yith_get_date_formats() instead
*/
function yith_get_date_format( $js = true ) {
return yith_get_date_formats( $js );
}
}
if ( ! function_exists( 'yith_get_date_formats' ) ) {
/**
* Get all available date formats.
*
* @param bool $js JS date format or not.
*
* @return array
* @since 3.5
*/
function yith_get_date_formats( $js = true ) {
$date_formats = array(
'F j, Y' => 'F j, Y',
'Y-m-d' => 'Y-m-d',
'm/d/Y' => 'm/d/Y',
'd/m/Y' => 'd/m/Y',
);
if ( $js ) {
$date_formats = array(
'MM d, yy' => 'F j, Y',
'yy-mm-dd' => 'Y-m-d',
'mm/dd/yy' => 'm/d/Y',
'dd/mm/yy' => 'd/m/Y',
);
}
return apply_filters( 'yith_plugin_fw_date_formats', $date_formats, $js );
}
}
if ( ! function_exists( 'yith_get_time_formats' ) ) {
/**
* Get all available time format.
*
* @return array
* @since 3.5
*/
function yith_get_time_formats() {
$time_formats = array(
'h:i:s' => 'h:i:s',
'g:i a' => 'g:i a',
'g:i A' => 'g:i A',
'H:i' => 'H:i',
);
return apply_filters( 'yith_plugin_fw_time_formats', $time_formats );
}
}
if ( ! function_exists( 'yith_format_toggle_title' ) ) {
/**
* Replace the placeholders with the values of the element id for toggle element field.
*
* @param string $title The title.
* @param array $values The values.
*
* @return array
* @since 3.1
*/
function yith_format_toggle_title( $title, $values ) {
preg_match_all( '/(?<=\%%).+?(?=\%%)/', $title, $matches );
if ( isset( $matches[0] ) ) {
foreach ( $matches[0] as $element_id ) {
if ( isset( $values[ $element_id ] ) ) {
$title = str_replace( '%%' . $element_id . '%%', $values[ $element_id ], $title );
}
}
}
return $title;
}
}
if ( ! function_exists( 'yith_plugin_fw_load_update_and_licence_files' ) ) {
/**
* Load premium file for license and update system
*/
function yith_plugin_fw_load_update_and_licence_files() {
global $plugin_upgrade_fw_data;
/**
* If the init.php was load by old plugin-fw version
* load the upgrade and license key from local folder
*/
if ( empty( $plugin_upgrade_fw_data ) ) {
$plugin_upgrade_path = plugin_dir_path( __DIR__ ) . 'plugin-upgrade';
if ( file_exists( $plugin_upgrade_path ) ) {
$required_files = array(
$plugin_upgrade_path . '/lib/yit-licence.php',
$plugin_upgrade_path . '/lib/yit-plugin-licence.php',
$plugin_upgrade_path . '/lib/yit-theme-licence.php',
$plugin_upgrade_path . '/lib/yit-plugin-upgrade.php',
);
$plugin_upgrade_fw_data = array( '1.0' => $required_files );
}
}
if ( ! empty( $plugin_upgrade_fw_data ) && is_array( $plugin_upgrade_fw_data ) ) {
foreach ( $plugin_upgrade_fw_data as $fw_version => $core_files ) {
foreach ( $core_files as $core_file ) {
if ( file_exists( $core_file ) ) {
include_once $core_file;
}
}
}
}
}
}
if ( ! function_exists( 'yith_plugin_fw_remove_duplicate_classes' ) ) {
/**
* Remove the duplicate classes from a string.
*
* @param string $classes The classes.
*
* @return string
* @since 3.2.2
*/
function yith_plugin_fw_remove_duplicate_classes( $classes ) {
$class_array = explode( ' ', $classes );
$class_unique = array_unique( array_filter( $class_array ) );
if ( $class_unique ) {
$classes = implode( ' ', $class_unique );
}
return $classes;
}
}
if ( ! function_exists( 'yith_plugin_fw_add_requirements' ) ) {
/**
* Add plugin requirements
*
* @param string $plugin_name The name of the plugin.
* @param array $requirements Array of plugin requirements.
*/
function yith_plugin_fw_add_requirements( $plugin_name, $requirements ) {
if ( ! empty( $requirements ) ) {
YITH_System_Status()->add_requirements( $plugin_name, $requirements );
}
}
}
if ( ! function_exists( 'yith_plugin_fw_parse_dimensions' ) ) {
/**
* Parse dimensions stored through a "dimensions" field to a key-value array
* where the key will be equal to the dimension key
* and the value will be equal to the value of the dimension suffixed with the unit
*
* @param array $values The values.
*
* @return array
*/
function yith_plugin_fw_parse_dimensions( $values ) {
$dimensions = array();
if ( is_array( $values ) && isset( $values['dimensions'], $values['unit'] ) && is_array( $values['dimensions'] ) ) {
$raw_unit = $values['unit'];
$unit = 'percentage' === $raw_unit ? '%' : $raw_unit;
foreach ( $values['dimensions'] as $key => $value ) {
$dimensions[ $key ] = $value . $unit;
}
}
return $dimensions;
}
}
if ( ! function_exists( 'yith_plugin_fw_get_dimensions_by_option' ) ) {
/**
* Retrieve a parsed array of dimensions by an option
*
* @param string $option The option.
* @param bool|array $default Default value.
*
* @return array|bool
*/
function yith_plugin_fw_get_dimensions_by_option( $option, $default = false ) {
$dimensions = get_option( $option, false );
return ! ! $dimensions ? yith_plugin_fw_parse_dimensions( $dimensions ) : $default;
}
}
if ( ! function_exists( 'yith_plugin_fw_extract' ) ) {
/**
* Extract array variables
* Usage example:
* ```
* list ( $type, $class, $value ) = yith_plugin_fw_extract( $field, 'type', 'class', 'value' );
* ```
*
* @param array $array The array.
* @param string ...$keys The keys.
*
* @return array
* @since 3.5
*/
function yith_plugin_fw_extract( $array, ...$keys ) {
return array_map(
function ( $key ) use ( $array ) {
return isset( $array[ $key ] ) ? $array[ $key ] : null;
},
$keys
);
}
}
if ( ! function_exists( 'yith_plugin_fw_register_elementor_widget' ) ) {
/**
* Register Elementor widget
*
* @param string $widget_name The widget name.
* @param array $widget_options The widget options.
*
* @since 3.6.0
*/
function yith_plugin_fw_register_elementor_widget( $widget_name, $widget_options ) {
YITH_Elementor::instance()->register_widget( $widget_name, $widget_options );
}
}
if ( ! function_exists( 'yith_plugin_fw_register_elementor_widgets' ) ) {
/**
* Register Elementor widgets
*
* @param array $widgets The widgets.
* @param bool $map_from_gutenberg Set to true if you need to map options from Gutenberg blocks array.
*
* @since 3.6.0
*/
function yith_plugin_fw_register_elementor_widgets( $widgets, $map_from_gutenberg = false ) {
foreach ( $widgets as $widget_name => $widget_options ) {
if ( $map_from_gutenberg ) {
$widget_options = array_merge( array( 'map_from_gutenberg' => true ), $widget_options );
}
yith_plugin_fw_register_elementor_widget( $widget_name, $widget_options );
}
}
}
if ( ! function_exists( 'yith_plugin_fw_copy_to_clipboard' ) ) {
/**
* Print a field with a button to copy its content to clipboard
*
* @param string $value The text to be shown.
* @param array $field The field attributes.
*
* @since 3.6.2
*/
function yith_plugin_fw_copy_to_clipboard( $value, $field = array() ) {
$defaults = array(
'id' => '',
'value' => $value,
);
$field = wp_parse_args( $field, $defaults );
$field['type'] = 'copy-to-clipboard';
// Enqueue style and script if not enqueued.
wp_enqueue_style( 'yith-plugin-fw-fields' );
wp_enqueue_script( 'yith-plugin-fw-fields' );
yith_plugin_fw_get_field( $field, true, false );
}
}
if ( ! function_exists( 'yith_plugin_fw_add_utm_data' ) ) {
/**
* Add UTM data in backend url
*
* @param string $url The url that want to track.
* @param string $slug Plugin slug.
* @param string $campaign Campaign to track. Default: default.
* @param string $source Where the link came from. You can simply set it to the plugin version type(free, extended, premium) to get the correct source. Default: wp-dashboard.
* @param string $content Identifies what specifically was clicked to bring the user to the site, such as button-cta, link, and something similar.
* @param string $term A keyword representing something that brought the user to the site.
*
* @since 3.6.10
* @since 4.5.8 Added $content and $term prams.
*/
function yith_plugin_fw_add_utm_data( $url, $slug, $campaign = 'default', $source = 'wp-dashboard', $content = '', $term = '' ) {
$sources = array(
'free' => 'wp-free-dashboard',
'extended' => 'wp-extended-dashboard',
'premium' => 'wp-premium-dashboard',
);
$source = $sources[ $source ] ?? $source;
$source = ! ! $source ? $source : 'wp-dashboard';
if ( ! empty( $slug ) ) {
$utm_track_data = array(
'utm_source' => $source,
'utm_medium' => $slug,
'utm_campaign' => $campaign,
);
if ( $content ) {
$utm_track_data['utm_content'] = $content;
}
if ( $term ) {
$utm_track_data['utm_term'] = $term;
}
$url = add_query_arg( $utm_track_data, $url );
}
return $url;
}
}
if ( ! function_exists( 'yith_plugin_fw_panel_utm_source' ) ) {
/**
* Generates default UTM source for the dashboard
*
* @param YIT_Plugin_Panel $panel Panel object.
*
* @since 3.6.10
* @deprecated 4.1.0
*/
function yith_plugin_fw_panel_utm_source( $panel = false ) {
if ( $panel && $panel->is_free() ) {
return 'wp-free-dashboard';
}
if ( $panel && $panel->is_extended() ) {
return 'wp-extended-dashboard';
}
return 'wp-dashboard';
}
}
if ( ! function_exists( 'yith_plugin_fw_include_fw_template' ) ) {
/**
* Include a FW template
*
* @param string $template The template.
* @param array $args Arguments.
*
* @since 3.7.0
*/
function yith_plugin_fw_include_fw_template( $template, $args = array() ) {
$_template_path = trailingslashit( YIT_CORE_PLUGIN_TEMPLATE_PATH ) . $template;
if ( file_exists( $_template_path ) ) {
extract( $args ); // phpcs:ignore WordPress.PHP.DontExtract.extract_extract
include $_template_path;
}
}
}
if ( ! function_exists( 'yith_plugin_fw_html_attributes_to_string' ) ) {
/**
* Transform attributes array to HTML attributes string.
* If using a string, the attributes will be escaped.
* Prefer using arrays.
*
* @param array|string $attributes The attributes.
* @param bool $echo Set to true to print it directly; false otherwise.
*
* @return string
* @since 3.7.0
* @since 3.8.0 Escaping attributes when using strings; allow value-less attributes by setting value to null.
*/
function yith_plugin_fw_html_attributes_to_string( $attributes = array(), $echo = false ) {
$html_attributes = '';
if ( ! ! $attributes ) {
if ( is_string( $attributes ) ) {
$parsed_attrs = wp_kses_hair( $attributes, wp_allowed_protocols() );
$attributes = array();
foreach ( $parsed_attrs as $attr ) {
$attributes[ $attr['name'] ] = 'n' === $attr['vless'] ? $attr['value'] : null;
}
}
if ( is_array( $attributes ) ) {
$html_attributes = array();
foreach ( $attributes as $key => $value ) {
if ( ! is_null( $value ) ) {
$html_attributes[] = esc_attr( $key ) . '="' . esc_attr( $value ) . '"';
} else {
$html_attributes[] = esc_attr( $key );
}
}
$html_attributes = implode( ' ', $html_attributes );
}
}
if ( $echo ) {
// Already escaped above.
echo $html_attributes; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
}
return $html_attributes;
}
}
if ( ! function_exists( 'yith_plugin_fw_get_component' ) ) {
/**
* Retrieve a component.
*
* @param array $component The component.
* @param bool $echo Set to true to print the component directly; false otherwise.
*
* @return false|string
* @since 3.7.0
*/
function yith_plugin_fw_get_component( $component, $echo = true ) {
if ( ! empty( $component['type'] ) ) {
$type = sanitize_title( $component['type'] );
$defaults = array(
'id' => '',
'class' => '',
'attributes' => array(),
'data' => array(),
);
$component = wp_parse_args( $component, $defaults );
$component_template = '/components/' . $type . '.php';
if ( ! $echo ) {
ob_start();
}
yith_plugin_fw_include_fw_template( $component_template, compact( 'component' ) );
if ( ! $echo ) {
return ob_get_clean();
}
}
return '';
}
}
if ( ! function_exists( 'yith_plugin_fw_get_default_post_actions' ) ) {
/**
* Retrieve the default post actions to be used in WP List tables to show action buttons.
*
* @param WP_Post|int $post The post.
* @param array $args {
* Optional. Arguments to retrieve actions.
*
* @type array $more -menu Array of more-menu items.
* @type array|bool $more -menu-in-trash false: the menu will be not shown in trash | true: the menu will be shown in trash | array: set specific menu for trash.
* @type string|false $duplicate -url The Duplicate URL. Default: false (the duplicate action will be not shown).
* @type string|false $confirm -trash-message The 'confirm trash' message. Set to false to not ask for trash confirmation.
* @type string|false $confirm -delete-message The 'confirm delete' message. Set to false to not ask for delete confirmation.
* }
* @return array
* @since 3.7.0
*/
function yith_plugin_fw_get_default_post_actions( $post, $args = array() ) {
$post = get_post( $post );
$actions = array();
if ( $post ) {
$title = _draft_or_post_title( $post );
$post_type_object = get_post_type_object( $post->post_type );
$can_edit_post = current_user_can( 'edit_post', $post->ID );
$defaults = array(
'more-menu' => array(),
'more-menu-in-trash' => false,
'delete-directly' => false,
'duplicate-url' => false,
// translators: %s is the title of the post object.
'confirm-trash-message' => sprintf( __( 'Are you sure you want to move "%s" to trash?', 'yith-plugin-fw' ), '<strong>' . $title . '</strong>' ),
// translators: %s is the title of the post object.
'confirm-delete-message' => sprintf( __( 'Are you sure you want to delete "%s"?', 'yith-plugin-fw' ), '<strong>' . $title . '</strong>' ) . '<br /><br />' . __( 'This action cannot be undone and you will not be able to recover this data.', 'yith-plugin-fw' ),
);
$args = wp_parse_args( $args, $defaults );
if ( is_post_type_viewable( $post_type_object ) ) {
if ( in_array( $post->post_status, array( 'pending', 'draft', 'future' ), true ) ) {
if ( $can_edit_post ) {
$preview_link = get_preview_post_link( $post );
$actions['view'] = array(
'type' => 'action-button',
'title' => _x( 'Preview', 'Post action', 'yith-plugin-fw' ),
'action' => 'view',
'icon' => 'eye',
'url' => $preview_link,
);
}
} elseif ( 'trash' !== $post->post_status ) {
$actions['view'] = array(
'type' => 'action-button',
'title' => _x( 'View', 'Post action', 'yith-plugin-fw' ),
'action' => 'view',
'icon' => 'eye',
'url' => get_permalink( $post->ID ),
);
}
}
if ( $can_edit_post && 'trash' !== $post->post_status ) {
$actions['edit'] = array(
'type' => 'action-button',
'title' => _x( 'Edit', 'Post action', 'yith-plugin-fw' ),
'action' => 'edit',
'url' => get_edit_post_link( $post->ID ),
);
if ( $args['duplicate-url'] ) {
$actions['duplicate'] = array(
'type' => 'action-button',
'title' => _x( 'Duplicate', 'Post action', 'yith-plugin-fw' ),
'action' => 'duplicate',
'icon' => 'clone',
'url' => $args['duplicate-url'],
);
}
}
if ( current_user_can( 'delete_post', $post->ID ) ) {
if ( 'trash' === $post->post_status ) {
$actions['untrash'] = array(
'type' => 'action-button',
'title' => _x( 'Restore', 'Post action', 'yith-plugin-fw' ),
'action' => 'untrash',
'icon' => 'reply',
'url' => wp_nonce_url( admin_url( sprintf( $post_type_object->_edit_link . '&action=untrash', $post->ID ) ), 'untrash-post_' . $post->ID ),
);
} elseif ( EMPTY_TRASH_DAYS && ! $args['delete-directly'] ) {
$actions['trash'] = array(
'type' => 'action-button',
'title' => _x( 'Trash', 'Post action', 'yith-plugin-fw' ),
'action' => 'trash',
'url' => get_delete_post_link( $post->ID ),
);
if ( $args['confirm-trash-message'] ) {
$actions['trash']['confirm_data'] = array(
'title' => __( 'Confirm trash', 'yith-plugin-fw' ),
'message' => $args['confirm-trash-message'],
'cancel-button' => __( 'No', 'yith-plugin-fw' ),
'confirm-button' => _x( 'Yes, move to trash', 'Trash confirmation action', 'yith-plugin-fw' ),
'confirm-button-type' => 'delete',
);
}
}
if ( 'trash' === $post->post_status || ! EMPTY_TRASH_DAYS || $args['delete-directly'] ) {
$actions['delete'] = array(
'type' => 'action-button',
'title' => _x( 'Delete Permanently', 'Post action', 'yith-plugin-fw' ),
'action' => 'delete',
'icon' => 'trash',
'url' => get_delete_post_link( $post->ID, '', true ),
);
if ( $args['confirm-delete-message'] ) {
$actions['delete']['confirm_data'] = array(
'title' => __( 'Confirm delete', 'yith-plugin-fw' ),
'message' => $args['confirm-delete-message'],
'cancel-button' => __( 'No', 'yith-plugin-fw' ),
'confirm-button' => _x( 'Yes, delete', 'Delete confirmation action', 'yith-plugin-fw' ),
'confirm-button-type' => 'delete',
);
}
}
}
if ( $args['more-menu'] ) {
if ( 'trash' !== $post->post_status || true === $args['more-menu-in-trash'] ) {
$actions['more'] = array(
'type' => 'action-button',
'title' => __( 'Further actions', 'yith-plugin-fw' ),
'action' => 'more',
'url' => '#',
'menu' => $args['more-menu'],
);
} elseif ( ! ! $args['more-menu-in-trash'] ) {
$actions['more'] = array(
'type' => 'action-button',
'title' => __( 'Further actions', 'yith-plugin-fw' ),
'action' => 'more',
'url' => '#',
'menu' => $args['more-menu-in-trash'],
);
}
}
}
return $actions;
}
}
if ( ! function_exists( 'yith_plugin_fw_get_default_term_actions' ) ) {
/**
* Retrieve the default term actions to be used in WP List tables to show action buttons.
*
* @param WP_Term|int $term The term.
* @param array $args {
* Optional. Arguments to retrieve actions.
*
* @type string $taxonomy The taxonomy. If not set, the taxonomy will be retrieved by $_REQUEST.
* @type string $object -type The object type the term is assigned to (ex: the post-type).
* @type array $more -menu Array of more-menu items.
* @type string|false $duplicate -url The Duplicate URL. Default: false (the duplicate action will be not shown).
* @type string|false $confirm -delete-message The 'confirm delete' message. Set to false to not ask for delete confirmation.
* }
* @return array
* @since 3.7.0
*/
function yith_plugin_fw_get_default_term_actions( $term, $args = array() ) {
if ( isset( $args['taxonomy'] ) ) {
$taxonomy = $args['taxonomy'];
} else {
// phpcs:ignore WordPress.Security.NonceVerification.Recommended
$taxonomy = isset( $_REQUEST['taxonomy'] ) ? sanitize_title( wp_unslash( $_REQUEST['taxonomy'] ) ) : false;
}
if ( is_numeric( $term ) ) {
$term_id = absint( $term );
$term = get_term_by( 'id', $term_id, $taxonomy );
}
$actions = array();
$tax = get_taxonomy( $taxonomy );
if ( ! empty( $term->term_id ) && $tax ) {
$title = $term->name;
$uri = wp_doing_ajax() ? wp_get_referer() : esc_url_raw( wp_unslash( isset( $_SERVER['REQUEST_URI'] ) ? $_SERVER['REQUEST_URI'] : '' ) );
$defaults = array(
'object-type' => '',
'more-menu' => array(),
'duplicate-url' => false,
// translators: %s is the title of the post object.
'confirm-delete-message' => sprintf( __( 'Are you sure you want to delete "%s"?', 'yith-plugin-fw' ), '<strong>' . $title . '</strong>' ) . '<br /><br />' . __( 'This action cannot be undone and you will not be able to recover this data.', 'yith-plugin-fw' ),
);
$args = wp_parse_args( $args, $defaults );
$edit_link = add_query_arg(
'wp_http_referer',
$uri,
get_edit_term_link( $term->term_id, $taxonomy, $args['object-type'] )
);
if ( is_taxonomy_viewable( $tax ) ) {
$actions['view'] = array(
'type' => 'action-button',
'title' => _x( 'View', 'Term action', 'yith-plugin-fw' ),
'action' => 'view',
'icon' => 'eye',
'url' => get_term_link( $term ),
);
}
if ( current_user_can( 'edit_term', $term->term_id ) ) {
$actions['edit'] = array(
'type' => 'action-button',
'title' => _x( 'Edit', 'Term action', 'yith-plugin-fw' ),
'action' => 'edit',
'url' => $edit_link,
);
if ( $args['duplicate-url'] ) {
$actions['duplicate'] = array(
'type' => 'action-button',
'title' => _x( 'Duplicate', 'Term action', 'yith-plugin-fw' ),
'action' => 'duplicate',
'icon' => 'clone',
'url' => $args['duplicate-url'],
);
}
}
if ( current_user_can( 'delete_term', $term->term_id ) ) {
$delete_url = wp_nonce_url( "edit-tags.php?action=delete&taxonomy=$taxonomy&tag_ID=$term->term_id", 'delete-tag_' . $term->term_id );
$actions['delete'] = array(
'type' => 'action-button',
'title' => _x( 'Delete', 'Term action', 'yith-plugin-fw' ),
'action' => 'delete',
'icon' => 'trash',
'url' => $delete_url,
);
if ( $args['confirm-delete-message'] ) {
$actions['delete']['confirm_data'] = array(
'title' => __( 'Confirm delete', 'yith-plugin-fw' ),
'message' => $args['confirm-delete-message'],
'confirm-button' => _x( 'Yes, delete', 'Delete confirmation action', 'yith-plugin-fw' ),
'confirm-button-type' => 'delete',
);
}
}
if ( $args['more-menu'] ) {
$actions['more'] = array(
'type' => 'action-button',
'title' => __( 'Further actions', 'yith-plugin-fw' ),
'action' => 'more',
'url' => '#',
'menu' => $args['more-menu'],
);
}
}
return $actions;
}
}
if ( ! function_exists( 'yith_plugin_fw_get_action_buttons' ) ) {
/**
* Retrieve action buttons.
*
* @param array $actions The actions.
* @param bool $echo Set to true to print the field directly; false otherwise.
*
* @return string
* @since 3.7.0
*/
function yith_plugin_fw_get_action_buttons( $actions, $echo = true ) {
$actions_html = '';
foreach ( $actions as $action ) {
$action['type'] = 'action-button';
$actions_html .= yith_plugin_fw_get_component( $action, $echo );
}
return $actions_html;
}
}
if ( ! function_exists( 'yith_plugin_fw_get_post_formatted_name' ) ) {
/**
* Get the formatted name for posts/products
*
* @param int|WP_Post|WC_Product|WC_Product_Variation|WC_Order $post The post ID, the post, the product, or the order.
* @param array $args Arguments.
*
* @return string
* @since 3.7.2
*/
function yith_plugin_fw_get_post_formatted_name( $post, $args = array() ) {
$defaults = array(
'show-id' => false,
'post-type' => false,
);
$args = wp_parse_args( $args, $defaults );
$post_type = $args['post-type'];
$show_id = $args['show-id'];
if ( is_a( $post, 'WP_Post' ) ) {
$post_id = $post->ID;
} elseif ( class_exists( 'WC_Product' ) && is_a( $post, 'WC_Product' ) ) {
$post_id = $post->get_id();
if ( false === $post_type ) {
$post_type = is_a( $post, 'WC_Product_Variation' ) ? 'product_variation' : 'product';
}
} elseif ( class_exists( 'WC_Order' ) && is_a( $post, 'WC_Order' ) ) {
$post_id = $post->get_id();
} else {
$post_id = absint( $post );
}
if ( ! $post_type ) {
$post_type = get_post_type( $post_id );
}
$name = null;
switch ( $post_type ) {
case 'product':
case 'product_variation':
$product = class_exists( 'WC_Product' ) && is_a( $post, 'WC_Product' ) ? $post : false;
if ( ! $product && function_exists( 'wc_get_product' ) ) {
$product = wc_get_product( $post );
}
if ( $product ) {
$name = $product->get_formatted_name();
if ( ! $show_id ) {
if ( $product->get_sku() ) {
$identifier = $product->get_sku();
} else {
$identifier = '#' . $product->get_id();
}
// Use normal replacing instead of regex since the identifier could be also the product SKU.
$name = str_replace( "({$identifier})", '', $name );
}
}
break;
case 'shop_order':
$date_format = sprintf( '%s %s', wc_date_format(), wc_time_format() );
$order = class_exists( 'WC_Order' ) && is_a( $post, 'WC_Order' ) ? $post : false;
if ( ! $order && function_exists( 'wc_get_order' ) ) {
$order = wc_get_order( $post );
}
if ( $order ) {
$buyer = '';
if ( $order->get_billing_first_name() || $order->get_billing_last_name() ) {
$buyer = trim( sprintf( '%s %s', $order->get_billing_first_name(), $order->get_billing_last_name() ) );
} elseif ( $order->get_billing_company() ) {
$buyer = trim( $order->get_billing_company() );
} elseif ( $order->get_customer_id() ) {
$user = get_user_by( 'id', $order->get_customer_id() );
$buyer = ucwords( $user->display_name );
}
$order_number = apply_filters( 'yith_plugin_fw_order_number', '#' . $order->get_id(), $order->get_id() );
$name = sprintf(
'%s %s - %s',
$order_number,
esc_html( $buyer ),
esc_html( $order->get_date_created()->format( $date_format ) )
);
}
break;
}
if ( is_null( $name ) ) {
$name = get_the_title( $post_id );
if ( $show_id ) {
$name .= " (#{$post_id})";
}
}
return $name;
}
}
if ( ! function_exists( 'yith_plugin_fw_add_kses_global_attributes' ) ) {
/**
* Add global attributes to a tag in the allowed HTML list.
*
* @param array $attributes An array of attributes.
*
* @return array The array of attributes with global attributes added.
* @since 3.8.0
*/
function yith_plugin_fw_add_kses_global_attributes( $attributes ) {
$global_attributes = array(
'aria-describedby' => true,
'aria-details' => true,
'aria-label' => true,
'aria-labelledby' => true,
'aria-hidden' => true,
'class' => true,
'id' => true,
'style' => true,
'title' => true,
'role' => true,
'data-*' => true,
);
if ( true === $attributes ) {
$attributes = array();
}
if ( is_array( $attributes ) ) {
return array_merge( $attributes, $global_attributes );
}
return $attributes;
}
}
if ( ! function_exists( 'yith_plugin_fw_kses_allowed_svg_tags' ) ) {
/**
* Return the list of allowed HTML tag for SVGs.
*
* @return array
* @since 4.0.0
*/
function yith_plugin_fw_kses_allowed_svg_tags() {
return array(
'svg' => array(
'class' => true,
'data-*' => true,
'aria-*' => true,
'role' => true,
'xmlns' => true,
'width' => true,
'height' => true,
'viewbox' => true,
'version' => true,
'x' => true,
'y' => true,
'style' => true,
'fill' => true,
'stroke' => true,
'stroke-width' => true,
),
'circle' => array(
'class' => true,
'cx' => true,
'cy' => true,
'r' => true,
),
'g' => array( 'fill' => true ),
'polyline' => array(
'class' => true,
'points' => true,
),
'polygon' => array(
'class' => true,
'points' => true,
),
'line' => array(
'class' => true,
'x1' => true,
'x2' => true,
'y1' => true,
'y2' => true,
),
'title' => array( 'title' => true ),
'path' => array(
'class' => true,
'd' => true,
'fill' => true,
'clip-rule' => true,
'fill-rule' => true,
'stroke-linecap' => true,
'stroke-linejoin' => true,
),
'rect' => array(
'class' => true,
'x' => true,
'y' => true,
'fill' => true,
'width' => true,
'height' => true,
),
);
}
}