%PDF- %PDF-
Direktori : /home/t/r/a/tradesc/www/relax/wp-content/plugins/cartflows/classes/ |
Current File : /home/t/r/a/tradesc/www/relax/wp-content/plugins/cartflows/classes/class-cartflows-helper.php |
<?php /** * CARTFLOWS Helper. * * @package CARTFLOWS */ if ( ! defined( 'ABSPATH' ) ) { exit; // Exit if accessed directly. } /** * Class Cartflows_Helper. */ class Cartflows_Helper { /** * Instance * * @since 1.0.0 * @var object Class object. * @access private */ private static $instance; /** * Initiator * * @since 1.0.0 * @return object initialized object of class. */ public static function get_instance() { if ( ! isset( self::$instance ) ) { self::$instance = new self(); } return self::$instance; } /** * Common global data * * @var zapier */ private static $common = null; /** * Common Debug data * * @var zapier */ private static $debug_data = null; /** * Permalink settings * * @var permalink_setting */ private static $permalink_setting = null; /** * Google Analytics Settings * * @var permalink_setting */ private static $google_analytics_settings = null; /** * Installed Plugins * * @since 1.1.4 * * @access private * @var array Installed plugins list. */ private static $installed_plugins = null; /** * Checkout Fields * * @var checkout_fields */ private static $checkout_fields = null; /** * Facebook pixel global data * * @var faceboook */ private static $facebook = null; /** * Facebook pixel global data * * @var tiktok */ private static $tiktok = null; /** * Pinterest tag global data * * @var tiktok */ private static $pinterest = null; /** * Google Ads settings * * @since 2.1.0 * @var array|null */ private static $google_ads_settings = null; /** * Snapchat pixel global data * * @since 2.1.0 * @var array|null */ private static $snapchat = null; /** * Returns an option from the database for the admin settings page. * * Note: Note: Use this function to access any properties to front-end of the website. * * @param string $key The option key. * @param mixed $default Option default value if option is not available. * @param boolean $network_override Whether to allow the network admin setting to be overridden on subsites. * @return string Return the option value */ public static function get_admin_settings_option( $key, $default = false, $network_override = false ) { // Get the site-wide option if we're in the network admin. if ( $network_override && is_multisite() ) { $value = get_site_option( $key, $default ); } else { $value = get_option( $key, $default ); } return $value; } /** * Updates an option from the admin settings page. * * Note: Use this function to access any properties to front-end of the website. * * @param string $key The option key. * @param mixed $value The value to update. * @param bool $network Whether to allow the network admin setting to be overridden on subsites. * @return mixed */ public static function update_admin_settings_option( $key, $value, $network = false ) { // Update the site-wide option since we're in the network admin. if ( $network && is_multisite() ) { update_site_option( $key, $value ); } else { update_option( $key, $value ); } } /** * Get single setting * * @since 1.1.4 * * @param string $key Option key. * @param string $default Option default value if not exist. * @return mixed */ public static function get_common_setting( $key = '', $default = '' ) { $settings = self::get_common_settings(); if ( $settings && array_key_exists( $key, $settings ) ) { return $settings[ $key ]; } return $default; } /** * This function retrieves global option from database * * @param string $key option meta_key. * @return mixed * @since X.X.X */ public static function get_global_setting( $key ) { $default_global = apply_filters( 'cartflows_global_settings_default', array( '_cartflows_store_checkout' => false, ) ); $value = get_option( $key, false ); if ( empty( $value ) && isset( $default_global[ $key ] ) ) { $value = $default_global[ $key ]; } return $value; } /** * Get single debug options * * @since 1.1.4 * * @param string $key Option key. * @param string $default Option default value if not exist. * @return mixed */ public static function get_debug_setting( $key = '', $default = '' ) { $debug_data = self::get_debug_settings(); if ( $debug_data && array_key_exists( $key, $debug_data ) ) { return $debug_data[ $key ]; } return $default; } /** * Get required plugins for page builder * * @since 1.1.4 * * @param string $page_builder_slug Page builder slug. * @param string $default Default page builder. * @return array selected page builder required plugins list. */ public static function get_required_plugins_for_page_builder( $page_builder_slug = '', $default = 'elementor' ) { $plugins = self::get_plugins_groupby_page_builders(); if ( array_key_exists( $page_builder_slug, $plugins ) ) { return $plugins[ $page_builder_slug ]; } return $plugins[ $default ]; } /** * Get Plugins list by page builder. * * @since 1.1.4 * * @return array Required Plugins list. */ public static function get_plugins_groupby_page_builders() { $divi_status = self::get_plugin_status( 'divi-builder/divi-builder.php' ); $theme_status = 'not-installed'; if ( $divi_status ) { if ( true === Cartflows_Compatibility::get_instance()->is_divi_theme_installed() ) { $theme_status = 'installed'; if ( false === Cartflows_Compatibility::get_instance()->is_divi_enabled() ) { $theme_status = 'deactivate'; $divi_status = 'activate'; } else { $divi_status = ''; } } } $plugins = array( 'elementor' => array( 'title' => 'Elementor', 'plugins' => array( array( 'slug' => 'elementor', // For download from wp.org. 'init' => 'elementor/elementor.php', 'status' => self::get_plugin_status( 'elementor/elementor.php' ), ), ), ), 'gutenberg' => array( 'title' => 'Spectra', 'plugins' => array( array( 'slug' => 'ultimate-addons-for-gutenberg', // For download from wp.org. 'init' => 'ultimate-addons-for-gutenberg/ultimate-addons-for-gutenberg.php', 'status' => self::get_plugin_status( 'ultimate-addons-for-gutenberg/ultimate-addons-for-gutenberg.php' ), ), ), ), 'divi' => array( 'title' => 'Divi', 'theme-status' => $theme_status, 'plugin-status' => $divi_status, 'plugins' => array( array( 'slug' => 'divi-builder', // For download from wp.org. 'init' => 'divi-builder/divi-builder.php', 'status' => $divi_status, ), ), ), 'beaver-builder' => array( 'title' => 'Beaver Builder', 'plugins' => array(), ), ); // Check Pro Exist. if ( file_exists( WP_PLUGIN_DIR . '/bb-plugin/fl-builder.php' ) && ! is_plugin_active( 'beaver-builder-lite-version/fl-builder.php' ) ) { $plugins['beaver-builder']['plugins'][] = array( 'slug' => 'bb-plugin', 'init' => 'bb-plugin/fl-builder.php', 'status' => self::get_plugin_status( 'bb-plugin/fl-builder.php' ), ); } else { $plugins['beaver-builder']['plugins'][] = array( 'slug' => 'beaver-builder-lite-version', // For download from wp.org. 'init' => 'beaver-builder-lite-version/fl-builder.php', 'status' => self::get_plugin_status( 'beaver-builder-lite-version/fl-builder.php' ), ); } if ( file_exists( WP_PLUGIN_DIR . '/bb-ultimate-addon/bb-ultimate-addon.php' ) && ! is_plugin_active( 'ultimate-addons-for-beaver-builder-lite/bb-ultimate-addon.php' ) ) { $plugins['beaver-builder']['plugins'][] = array( 'slug' => 'bb-ultimate-addon', 'init' => 'bb-ultimate-addon/bb-ultimate-addon.php', 'status' => self::get_plugin_status( 'bb-ultimate-addon/bb-ultimate-addon.php' ), ); } else { $plugins['beaver-builder']['plugins'][] = array( 'slug' => 'ultimate-addons-for-beaver-builder-lite', // For download from wp.org. 'init' => 'ultimate-addons-for-beaver-builder-lite/bb-ultimate-addon.php', 'status' => self::get_plugin_status( 'ultimate-addons-for-beaver-builder-lite/bb-ultimate-addon.php' ), ); } return $plugins; } /** * Get plugin status * * @since 1.1.4 * * @param string $plugin_init_file Plguin init file. * @return mixed */ public static function get_plugin_status( $plugin_init_file ) { if ( null == self::$installed_plugins ) { self::$installed_plugins = get_plugins(); } if ( ! isset( self::$installed_plugins[ $plugin_init_file ] ) ) { return 'install'; } elseif ( ! is_plugin_active( $plugin_init_file ) ) { return 'activate'; } else { return 'inactive'; } } /** * Get zapier settings. * * @return array. */ public static function get_common_settings() { if ( null === self::$common ) { $common_default = apply_filters( 'cartflows_common_settings_default', array( 'global_checkout' => '', 'override_global_checkout' => 'enable', 'disallow_indexing' => 'disable', 'default_page_builder' => 'elementor', ) ); $common = self::get_admin_settings_option( '_cartflows_common', false, false ); $common = wp_parse_args( $common, $common_default ); if ( ! did_action( 'wp' ) ) { return $common; } else { self::$common = $common; } } return self::$common; } /** * Get debug settings data. * * @return array. */ public static function get_debug_settings() { if ( null === self::$debug_data ) { $debug_data_default = apply_filters( 'cartflows_debug_settings_default', array( 'allow_minified_files' => 'disable', ) ); $debug_data = self::get_admin_settings_option( '_cartflows_debug_data', false, false ); $debug_data = wp_parse_args( $debug_data, $debug_data_default ); if ( ! did_action( 'wp' ) ) { return $debug_data; } else { self::$debug_data = $debug_data; } } return self::$debug_data; } /** * Get debug settings data. * * @return array. */ public static function get_permalink_settings() { if ( null === self::$permalink_setting ) { $permalink_default = apply_filters( 'cartflows_permalink_settings_default', array( 'permalink' => CARTFLOWS_STEP_PERMALINK_SLUG, 'permalink_flow_base' => CARTFLOWS_FLOW_PERMALINK_SLUG, 'permalink_structure' => '', ) ); $permalink_data = self::get_admin_settings_option( '_cartflows_permalink', false, false ); $permalink_data = wp_parse_args( $permalink_data, $permalink_default ); if ( ! did_action( 'wp' ) ) { return $permalink_data; } else { self::$permalink_setting = $permalink_data; } } return self::$permalink_setting; } /** * Get debug settings data. * * @return array. */ public static function get_google_analytics_settings() { if ( null === self::$google_analytics_settings ) { $google_analytics_settings_default = apply_filters( 'cartflows_google_analytics_settings_default', array( 'enable_google_analytics' => 'disable', 'enable_google_analytics_for_site' => 'disable', 'google_analytics_id' => '', 'enable_begin_checkout' => 'enable', 'enable_add_to_cart' => 'enable', 'enable_optin_lead' => 'enable', 'enable_add_payment_info' => 'enable', 'enable_purchase_event' => 'enable', ) ); $google_analytics_settings_data = self::get_admin_settings_option( '_cartflows_google_analytics', false, true ); $google_analytics_settings_data = wp_parse_args( $google_analytics_settings_data, $google_analytics_settings_default ); if ( ! did_action( 'wp' ) ) { return $google_analytics_settings_data; } else { self::$google_analytics_settings = $google_analytics_settings_data; } } return self::$google_analytics_settings; } /** * Get Checkout field. * * @param string $key Field key. * @param int $post_id Post id. * @return array. */ public static function get_checkout_fields( $key, $post_id ) { $saved_fields = get_post_meta( $post_id, 'wcf_fields_' . $key, true ); if ( ! $saved_fields ) { $saved_fields = array(); } $fields = array_filter( $saved_fields ); if ( empty( $fields ) ) { if ( 'billing' === $key || 'shipping' === $key ) { $fields = WC()->countries->get_address_fields( WC()->countries->get_base_country(), $key . '_' ); update_post_meta( $post_id, 'wcf_fields_' . $key, $fields ); } } return $fields; } /** * Get checkout fields settings. * * @return array. */ public static function get_checkout_fields_settings() { if ( null === self::$checkout_fields ) { $checkout_fields_default = array( 'enable_customization' => 'disable', 'enable_billing_fields' => 'disable', ); $billing_fields = self::get_checkout_fields( 'billing' ); if ( is_array( $billing_fields ) && ! empty( $billing_fields ) ) { foreach ( $billing_fields as $key => $value ) { $checkout_fields_default[ $key ] = 'enable'; } } $checkout_fields = self::get_admin_settings_option( '_wcf_checkout_fields', false, false ); self::$checkout_fields = wp_parse_args( $checkout_fields, $checkout_fields_default ); } return self::$checkout_fields; } /** * Get Optin fields. * * @return array. */ public static function get_optin_default_fields() { $optin_fields = array( 'billing_first_name' => array( 'label' => __( 'First name', 'cartflows' ), 'required' => true, 'class' => array( 'form-row-first', ), 'autocomplete' => 'given-name', 'priority' => 10, ), 'billing_last_name' => array( 'label' => __( 'Last name', 'cartflows' ), 'required' => true, 'class' => array( 'form-row-last', ), 'autocomplete' => 'family-name', 'priority' => 20, ), 'billing_email' => array( 'label' => __( 'Email address', 'cartflows' ), 'required' => true, 'type' => 'email', 'class' => array( 'form-row-wide', ), 'validate' => array( 'email', ), 'autocomplete' => 'email username', 'priority' => 30, ), ); return $optin_fields; } /** * Get Optin field. * * @param string $key Field key. * @param int $post_id Post id. * @return array. */ public static function get_optin_fields( $key, $post_id ) { $saved_fields = get_post_meta( $post_id, 'wcf_fields_' . $key, true ); if ( ! $saved_fields ) { $saved_fields = array(); } $fields = array_filter( $saved_fields ); if ( empty( $fields ) ) { if ( 'billing' === $key ) { $fields = self::get_optin_default_fields(); update_post_meta( $post_id, 'wcf_fields_' . $key, $fields ); } } return $fields; } /** * Get meta options * * @since 1.0.0 * @param int $post_id Product ID. * @param string $key Meta Key. * @param string $default Default value. * @return string Meta Value. */ public static function get_meta_option( $post_id, $key, $default = '' ) { $value = get_post_meta( $post_id, $key, true ); if ( ! $value ) { $value = $default; } return $value; } /** * Check if Elementor page builder is installed * * @since 1.0.0 * * @access public */ public static function is_elementor_installed() { $path = 'elementor/elementor.php'; $plugins = get_plugins(); return isset( $plugins[ $path ] ); } /** * Check if Step has product assigned. * * @since 1.0.0 * @param int $step_id step ID. * * @access public */ public static function has_product_assigned( $step_id ) { $step_type = get_post_meta( $step_id, 'wcf-step-type', true ); $has_product_assigned = false; if ( 'checkout' === $step_type ) { $product = get_post_meta( $step_id, 'wcf-checkout-products', true ); if ( ! empty( $product ) && isset( $product[0]['product'] ) ) { $has_product_assigned = true; } } elseif ( 'optin' === $step_type ) { $product = get_post_meta( $step_id, 'wcf-optin-product', true ); if ( ! empty( $product ) && ! empty( $product[0] ) ) { $has_product_assigned = true; } } else { $product = get_post_meta( $step_id, 'wcf-offer-product', true ); if ( ! empty( $product ) && ! empty( $product[0] ) ) { $has_product_assigned = true; } } return $has_product_assigned; } /** * Get attributes for cartflows wrap. * * @since 1.1.4 * * @access public */ public static function get_cartflows_container_atts() { $attributes = apply_filters( 'cartflows_container_atts', array() ); $atts_string = ''; foreach ( $attributes as $key => $value ) { if ( ! $value ) { continue; } if ( true === $value ) { $atts_string .= esc_html( $key ) . ' '; } else { $atts_string .= sprintf( '%s="%s" ', esc_html( $key ), esc_attr( $value ) ); } } return $atts_string; } /** * Get facebook pixel settings. * * @return facebook array. */ public static function get_facebook_settings() { if ( null === self::$facebook ) { $facebook_default = array( 'facebook_pixel_id' => '', 'facebook_pixel_view_content' => 'enable', 'facebook_pixel_add_to_cart' => 'enable', 'facebook_pixel_initiate_checkout' => 'enable', 'facebook_pixel_add_payment_info' => 'enable', 'facebook_pixel_purchase_complete' => 'enable', 'facebook_pixel_optin_lead' => 'enable', 'facebook_pixel_tracking' => 'disable', 'facebook_pixel_tracking_for_site' => 'disable', ); $facebook = self::get_admin_settings_option( '_cartflows_facebook', false, false ); $facebook = wp_parse_args( $facebook, $facebook_default ); self::$facebook = apply_filters( 'cartflows_facebook_settings_default', $facebook ); } return self::$facebook; } /** * Get tiktok pixel settings. * * @return tiktok tiktok settings array. */ public static function get_tiktok_settings() { if ( null === self::$tiktok ) { $tiktok_default = array( 'tiktok_pixel_id' => '', 'enable_tiktok_begin_checkout' => 'disable', 'enable_tiktok_add_to_cart' => 'disable', 'enable_tiktok_view_content' => 'disable', 'enable_tiktok_add_payment_info' => 'disable', 'enable_tiktok_purchase_event' => 'disable', 'enable_tiktok_optin_lead' => 'disable', 'tiktok_pixel_tracking' => 'disable', 'tiktok_pixel_tracking_for_site' => 'disable', ); $tiktok = self::get_admin_settings_option( '_cartflows_tiktok', false, false ); $tiktok = wp_parse_args( $tiktok, $tiktok_default ); self::$tiktok = apply_filters( 'cartflows_tiktok_settings_default', $tiktok ); } return self::$tiktok; } /** * Get pinterest tag settings. * * @return pinterest pinterest settings array. */ public static function get_pinterest_settings() { if ( null === self::$pinterest ) { $pinterest_default = array( 'pinterest_tag_id' => '', 'enable_pinterest_consent' => 'disable', 'enable_pinterest_begin_checkout' => 'disable', 'enable_pinterest_add_to_cart' => 'disable', 'enable_pinterest_add_payment_info' => 'disable', 'enable_pinterest_purchase_event' => 'disable', 'enable_pinterest_signup' => 'disable', 'enable_pinterest_optin_lead' => 'disable', 'pinterest_tag_tracking' => 'disable', 'pinterest_tag_tracking_for_site' => 'disable', ); $pinterest = self::get_admin_settings_option( '_cartflows_pinterest', false, false ); $pinterest = wp_parse_args( $pinterest, $pinterest_default ); self::$pinterest = apply_filters( 'cartflows_pinterest_settings_default', $pinterest ); } return self::$pinterest; } /** * Get debug settings data. * * @since 2.1.0 * @return array $google_ads_settings The Google Ads settings array. */ public static function get_google_ads_settings() { if ( null === self::$google_ads_settings ) { $google_ads_settings_default = apply_filters( 'cartflows_google_ads_settings_default', array( 'google_ads_id' => '', 'google_ads_label' => '', 'enable_google_ads_begin_checkout' => 'disable', 'enable_google_ads_add_to_cart' => 'disable', 'enable_google_ads_view_content' => 'disable', 'enable_google_ads_add_payment_info' => 'disable', 'enable_google_ads_purchase_event' => 'disable', 'enable_google_ads_optin_lead' => 'disable', 'google_ads_tracking' => 'disable', 'google_ads_for_site' => 'disable', ) ); $google_ads_settings_data = self::get_admin_settings_option( '_cartflows_google_ads', false, true ); $google_ads_settings_data = wp_parse_args( $google_ads_settings_data, $google_ads_settings_default ); if ( ! did_action( 'wp' ) ) { return $google_ads_settings_data; } else { self::$google_ads_settings = $google_ads_settings_data; } } return self::$google_ads_settings; } /** * Get snapchat pixel settings. * * @return snapchat snapchat settings array. */ public static function get_snapchat_settings() { if ( null === self::$snapchat ) { $snapchat_default = array( 'snapchat_pixel_id' => '', 'enable_snapchat_begin_checkout' => 'disable', 'enable_snapchat_add_to_cart' => 'disable', 'enable_snapchat_view_content' => 'disable', 'enable_snapchat_purchase_event' => 'disable', 'enable_snapchat_optin_lead' => 'disable', 'enable_snapchat_subscribe_event' => 'disable', 'snapchat_pixel_tracking' => 'disable', 'snapchat_pixel_for_site' => 'disable', ); $snapchat = self::get_admin_settings_option( '_cartflows_snapchat', false, false ); $snapchat = wp_parse_args( $snapchat, $snapchat_default ); self::$snapchat = apply_filters( 'cartflows_snapchat_settings_default', $snapchat ); } return self::$snapchat; } /** * Prepare response data for facebook. * * @todo Remove this function in 1.6.18 as it is added in cartflows-tracking file. * @param int $order_id order_id. * @param array $offer_data offer data. * @return void */ public static function send_fb_response_if_enabled( $order_id, $offer_data = array() ) { _deprecated_function( __METHOD__, '1.6.15' ); // Stop Execution if WooCommerce is not installed & don't set the cookie. if ( ! Cartflows_Loader::get_instance()->is_woo_active ) { return; } // @Since 1.6.15 It will only trigger offer purchase event. $fb_settings = self::get_facebook_settings(); if ( 'enable' === $fb_settings['facebook_pixel_tracking'] ) { setcookie( 'wcf_order_details', wp_json_encode( self::prepare_purchase_data_fb_response( $order_id, $offer_data ) ), strtotime( '+1 year' ), '/' ); //phpcs:ignore WordPressVIPMinimum.Functions.RestrictedFunctions.cookies_setcookie } } /** * Prepare purchase response for facebook purcase event. * * @todo Remove this function in 1.6.18 as it is added in cartflows-tracking file. * * @param integer $order_id order id. * @param array $offer_data offer data. * @return mixed */ public static function prepare_purchase_data_fb_response( $order_id, $offer_data ) { _deprecated_function( __METHOD__, '1.6.15' ); $purchase_data = array(); if ( empty( $offer_data ) ) { return $purchase_data; } if ( ! Cartflows_Loader::get_instance()->is_woo_active ) { return $purchase_data; } $order = wc_get_order( $order_id ); if ( ! $order ) { return $purchase_data; } $purchase_data['content_type'] = 'product'; $purchase_data['currency'] = wcf()->options->get_checkout_meta_value( $order_id, '_order_currency' ); $purchase_data['userAgent'] = wcf()->options->get_checkout_meta_value( $order_id, '_customer_user_agent' ); $purchase_data['plugin'] = 'CartFlows-Offer'; $purchase_data['content_ids'][] = (string) $offer_data['id']; $purchase_data['content_names'][] = $offer_data['name']; $purchase_data['content_category'][] = wp_strip_all_tags( wc_get_product_category_list( $offer_data['id'] ) ); $purchase_data['value'] = $offer_data['total']; $purchase_data['transaction_id'] = $order_id; return $purchase_data; } /** * Get the image url of size. * * @param int $post_id post id. * @param array $key key. * @param string $size image size. * * @return array */ public static function get_image_url( $post_id, $key, $size = false ) { $url = get_post_meta( $post_id, $key, true ); $img_obj = get_post_meta( $post_id, $key . '-obj', true ); if ( is_array( $img_obj ) && ! empty( $img_obj ) && false !== $size ) { $url = ! empty( $img_obj['url'][ $size ] ) ? $img_obj['url'][ $size ] : $url; } return $url; } /** * Download File Into Uploads Directory * * @since 1.6.15 * * @param string $file Download File URL. * @param array $overrides Upload file arguments. * @param int $timeout_seconds Timeout in downloading the XML file in seconds. * @return array Downloaded file data. */ public static function download_file( $file = '', $overrides = array(), $timeout_seconds = 300 ) { // Gives us access to the download_url() and wp_handle_sideload() functions. require_once ABSPATH . 'wp-admin/includes/file.php'; // Download file to temp dir. $temp_file = download_url( $file, $timeout_seconds ); // WP Error. if ( is_wp_error( $temp_file ) ) { return array( 'success' => false, 'data' => $temp_file->get_error_message(), ); } // Array based on $_FILE as seen in PHP file uploads. $file_args = array( 'name' => basename( $file ), 'tmp_name' => $temp_file, 'error' => 0, 'size' => filesize( $temp_file ), ); $defaults = array( // Tells WordPress to not look for the POST form // fields that would normally be present as // we downloaded the file from a remote server, so there // will be no form fields // Default is true. 'test_form' => false, // Setting this to false lets WordPress allow empty files, not recommended. // Default is true. 'test_size' => true, // A properly uploaded file will pass this test. There should be no reason to override this one. 'test_upload' => true, 'mimes' => array( 'xml' => 'text/xml', 'json' => 'text/plain', ), ); $overrides = wp_parse_args( $overrides, $defaults ); // Move the temporary file into the uploads directory. $results = wp_handle_sideload( $file_args, $overrides ); if ( isset( $results['error'] ) ) { return array( 'success' => false, 'data' => $results, ); } // Success. return array( 'success' => true, 'data' => $results, ); } /** * Get an instance of WP_Filesystem_Direct. * * @since 1.6.15 * @return object A WP_Filesystem_Direct instance. */ public static function get_filesystem() { global $wp_filesystem; require_once ABSPATH . '/wp-admin/includes/file.php'; WP_Filesystem(); return $wp_filesystem; } /** * Get all flow and steps * * @since 1.6.15 * @return array */ public function get_all_flows_and_steps() { $all_flows = array( 'elementor' => array(), 'divi' => array(), 'gutenberg' => array(), 'beaver-builder' => array(), ); foreach ( $all_flows as $slug => $value ) { $all_flows[ $slug ] = $this->get_flows_and_steps( $slug ); } return $all_flows; } /** * Get flow and steps * * @since 1.6.15 * * @param string $page_builder_slug Page builder slug. * @param string $templates templates category to fetch. * * @return array */ public function get_flows_and_steps( $page_builder_slug = '', $templates = '' ) { $page_builder_slug = ( ! empty( $page_builder_slug ) ) ? $page_builder_slug : wcf()->get_site_slug(); $suffix = 'store-checkout' === $templates ? 'store-checkout-' : ''; $pages_count = get_site_option( 'cartflows-' . $suffix . $page_builder_slug . '-requests', 0 ); $flows = array(); if ( $pages_count ) { for ( $page_no = 1; $page_no <= $pages_count; $page_no++ ) { $data = get_site_option( 'cartflows-' . $suffix . $page_builder_slug . '-flows-and-steps-' . $page_no, '' ); if ( ! empty( $data ) ) { $data = 'string' === gettype( $data ) ? json_decode( $data ) : $data; foreach ( $data as $key => $flow ) { $flows[] = $flow; } } else { // Return store templates from JSON files if no data found. $flows = $this->get_stored_page_builder_templates( $page_builder_slug ); } } } else { // All flows. $flows = $this->get_stored_page_builder_templates( $page_builder_slug ); } return $flows; } /** * Get page builder name * * @since 1.1.4 * * @param string $page_builder Page builder slug. * @return mixed */ public static function get_page_builder_name( $page_builder = '' ) { $pb_data = array( 'elementor' => 'Elementor', 'gutenberg' => 'Spectra', 'beaver-builder' => 'Beaver Builder', 'divi' => 'Divi', 'bricks-builder' => 'Bricks', ); if ( isset( $pb_data[ $page_builder ] ) ) { return $pb_data[ $page_builder ]; } return ''; } /** * Create Edit page link for the widgets. * * @since 1.6.15 * @param string $tab The Tab which has to display. * @access public */ public static function get_current_page_edit_url( $tab ) { $url = add_query_arg( array( 'wcf-tab' => $tab, ), get_edit_post_link() ); return $url; } /** * Get product price. * * @param object $product product data. */ public static function get_product_original_price( $product ) { $custom_price = ''; $product_id = 0; if ( $product->is_type( 'variable' ) ) { $default_attributes = $product->get_default_attributes(); if ( ! empty( $default_attributes ) ) { foreach ( $product->get_children() as $c_in => $variation_id ) { if ( 0 === $c_in ) { $product_id = $variation_id; } $single_variation = new \WC_Product_Variation( $variation_id ); if ( $default_attributes == $single_variation->get_attributes() ) { $product_id = $variation_id; break; } } } else { $product_childrens = $product->get_children(); if ( is_array( $product_childrens ) && ! empty( $product_childrens ) ) { foreach ( $product_childrens as $c_in => $c_id ) { $_child_product = wc_get_product( $c_id ); if ( $_child_product->is_in_stock() && 'publish' === $_child_product->get_status() ) { $product_id = $c_id; break; } } } else { // Return if no childrens found. return; } } $product = wc_get_product( $product_id ); } if ( $product ) { $custom_price = $product->get_price( 'edit' ); } return $custom_price; } /** * Get flows from json files. * * @param string $page_builder_slug Selected page builder slug. */ public function get_stored_page_builder_templates( $page_builder_slug ) { $flows = array(); $dir = CARTFLOWS_DIR . 'admin-core/assets/importer-data'; $list_files = \list_files( $dir ); if ( ! empty( $list_files ) ) { $list_files = array_map( 'basename', $list_files ); foreach ( $list_files as $file_key => $file_name ) { if ( false !== strpos( $file_name, 'cartflows-' . $page_builder_slug . '-flows-and-steps' ) ) { // file_get_contents is fine for local files. https://github.com/WordPress/WordPress-Coding-Standards/pull/1374/files#diff-400e43bc09c24262b43f26fce487fdabR43-R52. $data = json_decode( file_get_contents( $dir . '/' . $file_name ), true ); //phpcs:ignore WordPress.WP.AlternativeFunctions.file_get_contents_file_get_contents if ( ! empty( $data ) ) { /* Commented. // $option_name = str_replace( '.json', '', $file_name ); // update_site_option( $option_name, json_decode( $data, true ) ); */ foreach ( $data as $key => $flow ) { $flows[] = $flow; } } } } } return $flows; } /** * Get meta keys to exclude. * * @param int $step_id post id. */ public function get_meta_keys_to_exclude_from_import( $step_id = 0 ) { $meta_keys = array( '_wp_old_slug', 'wcf-checkout-products', 'wcf-optin-product', 'wcf-testing', ); if ( $step_id && 'yes' === get_post_meta( $step_id, 'cartflows_imported_step', true ) ) { $meta_keys = array_merge( $meta_keys, array( 'wcf_fields_billing', 'wcf_fields_shipping', ) ); } return apply_filters( 'cartflows_admin_exclude_import_meta_keys', $meta_keys ); } /** * Maybe update flow step order. * * @param int $flow_id flow id. * @param array $flow_steps step list. * * @return array flow_steps step list. */ public function maybe_update_flow_steps( $flow_id, $flow_steps ) { if ( absint( self::get_global_setting( '_cartflows_store_checkout' ) ) === $flow_id ) { $key = array_search( 'thankyou', wp_list_pluck( $flow_steps, 'type' ), true ); if ( ! $key ) { return $flow_steps; } else { $thankyou = array_splice( $flow_steps, intval( $key ), 1 ); $flow_steps[] = $thankyou[0]; } } return $flow_steps; } /** * Prepare cusom field settings array * * @param array $data_array field array. * @param string $key field key. * @param array $field_args field args. * @param array $fields_type field type. * @param string $step_type step type. * * @return array field data array. */ public function prepare_custom_field_settings( $data_array, $key, $field_args, $fields_type, $step_type = 'checkout' ) { if ( 'checkout' === $step_type ) { $name = 'billing' === $fields_type ? 'wcf_field_order_billing[' . $key . ']' : 'wcf_field_order_shipping[' . $key . ']'; } else { $name = 'wcf-optin-fields-billing[' . $key . ']'; } $type = $field_args['type']; $is_checkbox = 'checkbox' == $type ? true : false; $is_radiobutton = 'radio' == $type ? true : false; $is_select = 'select' == $type ? true : false; $is_custom_field = isset( $field_args['custom'] ) && true === (bool) $field_args['custom'] ? true : false; $data_array['field_options'] = array( 'enable-field' => array( 'label' => __( 'Enable Field', 'cartflows' ), 'name' => $name . '[enabled]', 'value' => $field_args['enabled'], ), 'select-width' => array( 'type' => 'select', 'label' => __( 'Field Width', 'cartflows' ), 'name' => $name . '[width]', 'value' => $field_args['width'], 'options' => array( array( 'value' => '33', 'label' => esc_html__( '33%', 'cartflows' ), ), array( 'value' => '50', 'label' => esc_html__( '50%', 'cartflows' ), ), array( 'value' => '100', 'label' => esc_html__( '100%', 'cartflows' ), ), ), ), 'field-label' => array( 'type' => 'text', 'label' => __( 'Field Label', 'cartflows' ), 'name' => $name . '[label]', 'value' => $field_args['label'], ), 'field-name' => array( 'label' => __( 'Field ID', 'cartflows' ), 'name' => $name . '[key]', 'value' => $field_args['key'], 'readonly' => true, 'tooltip' => __( 'Copy this field id to use in Order Custom Field rule of dynamic offers.', 'cartflows' ), ), 'field-default' => $is_checkbox ? array( 'type' => 'select', 'label' => __( 'Default', 'cartflows' ), 'name' => $name . '[default]', 'value' => $field_args['default'], 'options' => array( array( 'value' => '1', 'label' => esc_html__( 'Checked', 'cartflows' ), ), array( 'value' => '0', 'label' => esc_html__( 'Un-Checked', 'cartflows' ), ), ), ) : array( 'type' => 'text', 'label' => __( 'Default', 'cartflows' ), 'name' => $name . '[default]', 'value' => $field_args['default'], ), ); if ( $is_select || $is_radiobutton ) { $data_array['field_options']['select-options'] = array( 'type' => 'text', 'label' => __( 'Options', 'cartflows' ), 'name' => $name . '[options]', 'value' => $field_args['options'], ); } if ( in_array( $field_args['type'], array( 'datetime-local', 'date', 'time' ), true ) ) { switch ( $field_args['type'] ) { case 'datetime-local': $date_placeholder = 'yyyy-mm-dd hh:mm'; break; case 'date': $date_placeholder = 'yyyy-mm-dd'; break; case 'time': $date_placeholder = 'hh:mm'; break; default: $date_placeholder = 'yyyy-mm-dd hh:mm'; } $data_array['field_options']['field-min-date'] = array( 'type' => 'text', 'label' => __( 'Min Date', 'cartflows' ), 'name' => $name . '[custom_attributes][min]', 'value' => $field_args['custom_attributes']['min'], 'placeholder' => $date_placeholder, ); $data_array['field_options']['field-max-date'] = array( 'type' => 'text', 'label' => __( 'Max Date', 'cartflows' ), 'name' => $name . '[custom_attributes][max]', 'value' => $field_args['custom_attributes']['max'], 'placeholder' => $date_placeholder, ); $data_array['field_options']['field-default']['placeholder'] = $date_placeholder; } if ( ! in_array( $type, array( 'checkbox', 'select', 'radio', 'datetime-local', 'date', 'time', 'number' ), true ) ) { $data_array['field_options']['field-placeholder'] = array( 'type' => 'text', 'label' => __( 'Placeholder', 'cartflows' ), 'name' => $name . '[placeholder]', 'value' => $field_args['placeholder'], ); } if ( 'number' === $type ) { $data_array['field_options']['field-min'] = array( 'type' => 'number', 'label' => __( 'Min Number', 'cartflows' ), 'name' => $name . '[custom_attributes][min]', 'value' => $field_args['custom_attributes']['min'], ); $data_array['field_options']['field-max'] = array( 'type' => 'number', 'label' => __( 'Max Number', 'cartflows' ), 'name' => $name . '[custom_attributes][max]', 'value' => $field_args['custom_attributes']['max'], ); } if ( $is_custom_field ) { $data_array['field_options']['show-in-email'] = array( 'type' => 'checkbox', 'label' => __( 'Show In Email', 'cartflows' ), 'name' => $name . '[show_in_email]', 'value' => $field_args['show_in_email'], ); } $data_array['field_options']['required-field'] = array( 'label' => __( 'Required', 'cartflows' ), 'name' => $name . '[required]', 'value' => $field_args['required'], ); if ( 'checkout' === $step_type ) { $data_array['field_options']['collapsed-field'] = array( 'type' => 'checkbox', 'label' => __( 'Collapsible', 'cartflows' ), 'name' => $name . '[optimized]', 'value' => $field_args['optimized'], ); } return $data_array; } /** * Get step edit link. * * @param int $step_id Step id. */ public static function get_page_builder_edit_link( $step_id ) { $edit_step = get_edit_post_link( $step_id, 'edit' ); $view_step = get_permalink( $step_id ); $page_builder = self::get_common_setting( 'default_page_builder' ); $page_builder_edit = $edit_step; switch ( $page_builder ) { case 'beaver-builder': if ( is_plugin_active( 'beaver-builder-lite-version/fl-builder.php' ) ) { $page_builder_edit = strpos( $view_step, '?' ) ? $view_step . '&fl_builder' : $view_step . '?fl_builder'; } break; case 'elementor': if ( is_plugin_active( 'elementor/elementor.php' ) ) { $page_builder_edit = admin_url( 'post.php?post=' . $step_id . '&action=elementor' ); } break; case 'bricks-builder': if ( Cartflows_Compatibility::is_bricks_enabled() ) { $page_builder_edit = strpos( $view_step, '?' ) ? $view_step . '&bricks=run' : $view_step . '?bricks=run'; } break; } return $page_builder_edit; } /** * Get CartFlows Global Color Pallet CSS_Vars data. * * @since 2.0.0. * @return array Array of GCP vars slugs and label, */ public static function get_gcp_vars() { return array( 'wcf-gcp-primary-color' => __( 'CartFlows Primary Color', 'cartflows' ), 'wcf-gcp-secondary-color' => __( 'CartFlows Secondary Color', 'cartflows' ), 'wcf-gcp-text-color' => __( 'CartFlows Text Color', 'cartflows' ), 'wcf-gcp-accent-color' => __( 'CartFlows Heading/Accent Color', 'cartflows' ), ); } /** * Generate GCP styles CSS and assign the colors to the GCP CSS VARs. * * @param int $flow_id The current flow ID. * @return array $gcp_vars Array of generated CSS. * * @since 2.0.0 */ public static function generate_gcp_css_style( $flow_id = 0 ) { $gcp_vars = ''; if ( empty( $flow_id ) ) { return $gcp_vars; } $gcp_vars_array = array_keys( self::get_gcp_vars() ); foreach ( $gcp_vars_array as $slug ) { // Gather value of global color VAR. $color_value = wcf()->options->get_flow_meta_value( $flow_id, $slug, '' ); if ( empty( $color_value ) ) { continue; } // Convert it into the CSS var. $gcp_vars .= '--' . $slug . ': ' . $color_value . '; '; } return $gcp_vars; } /** * Generate the array of CSS vars to add in the Gutenberg color pallet. * * @param int $flow_id The current Flow ID. * @return array $new_color_palette Prepared array of CSS vars. * * @since 2.0.0 */ public static function generate_css_var_array( $flow_id = 0 ) { if ( empty( $flow_id ) ) { $flow_id = wcf()->utils->get_flow_id(); } // Default Color Pallet used as a separator. $new_color_palette[] = array( 'name' => 'CartFlows Separator', 'slug' => 'wcf-gcp-separator', 'color' => '#ff0000', ); $cf_gcp_data = self::get_gcp_vars(); // Prepare new colors css vars. foreach ( $cf_gcp_data as $slug => $label ) { $color_value = get_post_meta( $flow_id, $slug, true ); if ( empty( $color_value ) ) { continue; } // Add CartFlows Global Color Pallets CSS vars options. $new_color_palette[] = array( 'name' => $label, 'slug' => $slug, 'color' => 'var( --' . $slug . ')', ); } return $new_color_palette; } /** * Check is the Global Color pallet is enabled or not. * * @param int $flow_id Current flow id. * @return boolean */ public static function is_gcp_styling_enabled( $flow_id ) { if ( empty( $flow_id ) ) { return false; } return 'yes' === wcf()->options->get_flow_meta_value( $flow_id, 'wcf-enable-gcp-styling', 'no' ); } /** * Function to check to show the products tab in the store checkout or not. * * @return bool * @since 2.0.4 */ public static function display_product_tab_in_store_checkout() { return apply_filters( 'cartflows_show_store_checkout_product_tab', false ); } /** * Function get the CartFlows upgrade to PRO link. * * @param string $page The page name which needs to be displayed. * @param string $custom_url The Another URL if wish to send. * @return string $url The modified URL. */ public static function get_upgrade_to_pro_link( $page = 'pricing', $custom_url = '' ) { $base_url = CARTFLOWS_DOMAIN_URL . $page . '/'; $url = empty( $custom_url ) ? $base_url : esc_url( $custom_url ); $partner_id = get_option( 'cartflows_partner_url_param', '' ); $partner_id = is_string( $partner_id ) ? sanitize_text_field( $partner_id ) : ''; if ( ! empty( $partner_id ) ) { return add_query_arg( array( 'cf' => $partner_id ), $url ); } return esc_url( $url ); } /** * Get current page's template * * @param int $post_id The current page id. * @return string * * @since 2.1.0 */ public static function get_current_page_template( $post_id = 0 ) { if ( empty( $post_id ) ) { $post_id = _get_wcf_step_id(); } return apply_filters( 'cartflows_page_template', get_post_meta( $post_id, '_wp_page_template', true ) ); } /** * Check the Instant layout is enabled or not. * * @param int $flow_id Current flow id. * @return boolean Returns true if instant layout is enabled, false otherwise. */ public static function is_instant_layout_enabled( $flow_id = 0 ) { // Get the flow ID if not set. if ( empty( $flow_id ) ) { $flow_id = wcf()->utils->get_flow_id(); } // Return false if flow ID is not set. if ( empty( $flow_id ) ) { return false; } // Return false if wcf()->options is not set. if ( ! isset( wcf()->options ) || ! is_object( wcf()->options ) || ! is_callable( array( wcf()->options, 'get_flow_meta_value' ) ) ) { return false; } // Return true or false based on the instant layout style. return 'yes' === wcf()->options->get_flow_meta_value( $flow_id, 'instant-layout-style', 'no' ); } }