public function get_RP_WCDPD($product, $field_price = null, $cart_item_key = null)
 {
     $price = null;
     if (class_exists('RP_WCDPD') && class_exists('RP_WCDPD_Pricing') && !empty($GLOBALS['RP_WCDPD'])) {
         $tm_RP_WCDPD = $GLOBALS['RP_WCDPD'];
         $selected_rule = null;
         if ($field_price !== null && $cart_item_key !== null) {
             return $this->get_RP_WCDPD_single($field_price, $cart_item_key, $tm_RP_WCDPD->pricing);
         }
         $dpd_version_compare = version_compare(RP_WCDPD_VERSION, '1.0.13', '<');
         // Iterate over pricing rules and use the first one that has this product in conditions (or does not have if condition "not in list")
         if (isset($tm_RP_WCDPD->opt['pricing']['sets']) && count($tm_RP_WCDPD->opt['pricing']['sets'])) {
             foreach ($tm_RP_WCDPD->opt['pricing']['sets'] as $rule_key => $rule) {
                 if ($rule['method'] == 'quantity' && ($validated_rule = RP_WCDPD_Pricing::validate_rule($rule))) {
                     if ($dpd_version_compare) {
                         if ($validated_rule['selection_method'] == 'all' && $tm_RP_WCDPD->user_matches_rule($validated_rule['user_method'], $validated_rule['roles'])) {
                             $selected_rule = $validated_rule;
                             break;
                         }
                         if ($validated_rule['selection_method'] == 'categories_include' && count(array_intersect($tm_RP_WCDPD->get_product_categories($product->id), $validated_rule['categories'])) > 0 && $tm_RP_WCDPD->user_matches_rule($validated_rule['user_method'], $validated_rule['roles'])) {
                             $selected_rule = $validated_rule;
                             break;
                         }
                         if ($validated_rule['selection_method'] == 'categories_exclude' && count(array_intersect($tm_RP_WCDPD->get_product_categories($product->id), $validated_rule['categories'])) == 0 && $tm_RP_WCDPD->user_matches_rule($validated_rule['user_method'], $validated_rule['roles'])) {
                             $selected_rule = $validated_rule;
                             break;
                         }
                         if ($validated_rule['selection_method'] == 'products_include' && in_array($product->id, $validated_rule['products']) && $tm_RP_WCDPD->user_matches_rule($validated_rule['user_method'], $validated_rule['roles'])) {
                             $selected_rule = $validated_rule;
                             break;
                         }
                         if ($validated_rule['selection_method'] == 'products_exclude' && !in_array($product->id, $validated_rule['products']) && $tm_RP_WCDPD->user_matches_rule($validated_rule['user_method'], $validated_rule['roles'])) {
                             $selected_rule = $validated_rule;
                             break;
                         }
                     } else {
                         if ($validated_rule['selection_method'] == 'all' && $tm_RP_WCDPD->user_matches_rule($validated_rule)) {
                             $selected_rule = $validated_rule;
                             break;
                         }
                         if ($validated_rule['selection_method'] == 'categories_include' && count(array_intersect($tm_RP_WCDPD->get_product_categories($product->id), $validated_rule['categories'])) > 0 && $tm_RP_WCDPD->user_matches_rule($validated_rule)) {
                             $selected_rule = $validated_rule;
                             break;
                         }
                         if ($validated_rule['selection_method'] == 'categories_exclude' && count(array_intersect($tm_RP_WCDPD->get_product_categories($product->id), $validated_rule['categories'])) == 0 && $tm_RP_WCDPD->user_matches_rule($validated_rule)) {
                             $selected_rule = $validated_rule;
                             break;
                         }
                         if ($validated_rule['selection_method'] == 'products_include' && in_array($product->id, $validated_rule['products']) && $tm_RP_WCDPD->user_matches_rule($validated_rule)) {
                             $selected_rule = $validated_rule;
                             break;
                         }
                         if ($validated_rule['selection_method'] == 'products_exclude' && !in_array($product->id, $validated_rule['products']) && $tm_RP_WCDPD->user_matches_rule($validated_rule)) {
                             $selected_rule = $validated_rule;
                             break;
                         }
                     }
                 }
             }
         }
         if (is_array($selected_rule)) {
             // Quantity
             if ($selected_rule['method'] == 'quantity' && isset($selected_rule['pricing']) && in_array($selected_rule['quantities_based_on'], array('exclusive_product', 'exclusive_variation', 'exclusive_configuration'))) {
                 if ($product->product_type == 'variable' || $product->product_type == 'variable-subscription') {
                     $product_variations = $product->get_available_variations();
                 }
                 // For variable products only - check if prices differ for different variations
                 $multiprice_variable_product = false;
                 if (($product->product_type == 'variable' || $product->product_type == 'variable') && !empty($product_variations)) {
                     $last_product_variation = array_slice($product_variations, -1);
                     $last_product_variation_object = new WC_Product_Variable($last_product_variation[0]['variation_id']);
                     $last_product_variation_price = $last_product_variation_object->get_price();
                     foreach ($product_variations as $variation) {
                         $variation_object = new WC_Product_Variable($variation['variation_id']);
                         if ($variation_object->get_price() != $last_product_variation_price) {
                             $multiprice_variable_product = true;
                         }
                     }
                 }
                 if ($multiprice_variable_product) {
                     $variation_table_data = array();
                     foreach ($product_variations as $variation) {
                         $variation_product = new WC_Product_Variation($variation['variation_id']);
                         $variation_table_data[$variation['variation_id']] = $tm_RP_WCDPD->pricing_table_calculate_adjusted_prices($selected_rule['pricing'], $variation_product->get_price());
                     }
                     $price = array();
                     $price['is_multiprice'] = true;
                     $price['rules'] = $variation_table_data;
                 } else {
                     if ($product->product_type == 'variable' && !empty($product_variations)) {
                         $variation_product = new WC_Product_Variation($last_product_variation[0]['variation_id']);
                         $table_data = $tm_RP_WCDPD->pricing_table_calculate_adjusted_prices($selected_rule['pricing'], $variation_product->get_price());
                     } else {
                         $table_data = $tm_RP_WCDPD->pricing_table_calculate_adjusted_prices($selected_rule['pricing'], $product->get_price());
                     }
                     $price = array();
                     $price['is_multiprice'] = false;
                     $price['rules'] = $table_data;
                 }
             }
         }
     }
     if ($field_price !== null) {
         $price = $field_price;
     }
     return $price;
 }
 /**
  * Maybe display pricing table or anchor to display pricing table in modal
  * 
  * @access public
  * @return void
  */
 public function product_page_pricing_table()
 {
     if ($this->opt['settings']['display_table'] == 'hide' && (!isset($this->opt['settings']['display_offers']) || $this->opt['settings']['display_offers'] == 'hide')) {
         return;
     }
     global $product;
     if (!$product) {
         return;
     }
     // Load required classes
     require_once RP_WCDPD_PLUGIN_PATH . 'includes/classes/Pricing.php';
     $selected_rule = null;
     // Iterate over pricing rules and use the first one that has this product in conditions (or does not have if condition "not in list")
     if (isset($this->opt['pricing']['sets']) && count($this->opt['pricing']['sets'])) {
         foreach ($this->opt['pricing']['sets'] as $rule_key => $rule) {
             if ($rule['method'] == 'quantity' && ($validated_rule = RP_WCDPD_Pricing::validate_rule($rule))) {
                 if ($validated_rule['selection_method'] == 'all' && $this->user_matches_rule($validated_rule)) {
                     $selected_rule = $validated_rule;
                     break;
                 }
                 if ($validated_rule['selection_method'] == 'categories_include' && count(array_intersect($this->get_product_categories($product->id), $validated_rule['categories'])) > 0 && $this->user_matches_rule($validated_rule)) {
                     $selected_rule = $validated_rule;
                     break;
                 }
                 if ($validated_rule['selection_method'] == 'categories_exclude' && count(array_intersect($this->get_product_categories($product->id), $validated_rule['categories'])) == 0 && $this->user_matches_rule($validated_rule)) {
                     $selected_rule = $validated_rule;
                     break;
                 }
                 if ($validated_rule['selection_method'] == 'products_include' && in_array($product->id, $validated_rule['products']) && $this->user_matches_rule($validated_rule)) {
                     $selected_rule = $validated_rule;
                     break;
                 }
                 if ($validated_rule['selection_method'] == 'products_exclude' && !in_array($product->id, $validated_rule['products']) && $this->user_matches_rule($validated_rule)) {
                     $selected_rule = $validated_rule;
                     break;
                 }
             }
         }
     }
     if (is_array($selected_rule)) {
         // Quantity
         if ($selected_rule['method'] == 'quantity' && in_array($this->opt['settings']['display_table'], array('modal', 'inline')) && isset($selected_rule['pricing'])) {
             if ($product->product_type == 'variable') {
                 $product_variations = $product->get_available_variations();
             }
             // For variable products only - check if prices differ for different variations
             $multiprice_variable_product = false;
             if ($product->product_type == 'variable' && !empty($product_variations)) {
                 $last_product_variation = array_slice($product_variations, -1);
                 $last_product_variation_object = new WC_Product_Variable($last_product_variation[0]['variation_id']);
                 $last_product_variation_price = $last_product_variation_object->get_price();
                 foreach ($product_variations as $variation) {
                     $variation_object = new WC_Product_Variable($variation['variation_id']);
                     if ($variation_object->get_price() != $last_product_variation_price) {
                         $multiprice_variable_product = true;
                     }
                 }
             }
             if ($multiprice_variable_product) {
                 $variation_table_data = array();
                 foreach ($product_variations as $variation) {
                     $variation_product = new WC_Product_Variation($variation['variation_id']);
                     $variation_table_data[$variation['variation_id']] = $this->pricing_table_calculate_adjusted_prices($selected_rule['pricing'], $variation_product->get_price());
                 }
                 require_once RP_WCDPD_PLUGIN_PATH . 'includes/views/frontend/table-variable.php';
             } else {
                 if ($product->product_type == 'variable' && !empty($product_variations)) {
                     $variation_product = new WC_Product_Variation($last_product_variation[0]['variation_id']);
                     $table_data = $this->pricing_table_calculate_adjusted_prices($selected_rule['pricing'], $variation_product->get_price());
                 } else {
                     $table_data = $this->pricing_table_calculate_adjusted_prices($selected_rule['pricing'], $product->get_price());
                 }
                 require_once RP_WCDPD_PLUGIN_PATH . 'includes/views/frontend/table-' . $this->opt['settings']['display_table'] . '-' . $this->opt['settings']['pricing_table_style'] . '.php';
             }
         }
     }
 }
Exemple #3
0
 public static function fp_rac_cron_job_mailing()
 {
     global $wpdb;
     global $woocommerce;
     global $to;
     global $user_lang;
     $emailtemplate_table_name = $wpdb->prefix . 'rac_templates_email';
     $abandancart_table_name = $wpdb->prefix . 'rac_abandoncart';
     $email_templates = $wpdb->get_results("SELECT * FROM {$emailtemplate_table_name}");
     //all email templates
     $abandon_carts = $wpdb->get_results("SELECT * FROM {$abandancart_table_name} WHERE cart_status='ABANDON' AND user_id!='0' AND completed IS NULL");
     //Selected only cart which are not completed
     // For Members
     foreach ($abandon_carts as $each_cart) {
         foreach ($email_templates as $emails) {
             if ($emails->status == "ACTIVE") {
                 $cart_array = maybe_unserialize($each_cart->cart_details);
                 $tablecheckproduct = "<table style='width:100%;border:1px solid #eee;'><thead><tr>";
                 if (get_option('rac_hide_product_name_product_info_shortcode') != 'yes') {
                     $tablecheckproduct .= "<th style='text-align:left;border:1px solid #eee;padding:12px' scope='col'>" . fp_get_wpml_text('rac_template_product_name', $each_cart->wpml_lang, get_option('rac_product_info_product_name')) . "</th>";
                 }
                 if (get_option('rac_hide_product_image_product_info_shortcode') != 'yes') {
                     $tablecheckproduct .= "<th style='text-align:left;border:1px solid #eee;padding:12px' scope='col'>" . fp_get_wpml_text('rac_template_product_image', $each_cart->wpml_lang, get_option('rac_product_info_product_image')) . "</th>";
                 }
                 if (get_option('rac_hide_product_price_product_info_shortcode') != 'yes') {
                     $tablecheckproduct .= "<th style='text-align:left;border:1px solid #eee;padding:12px' scope='col'>" . fp_get_wpml_text('rac_template_product_price', $each_cart->wpml_lang, get_option('rac_product_info_product_price')) . "</th>";
                 }
                 $tablecheckproduct .= "</tr></thead><tbody>";
                 if (is_array($cart_array)) {
                     foreach ($cart_array as $cart) {
                         foreach ($cart as $inside) {
                             foreach ($inside as $product) {
                                 if ((double) $woocommerce->version <= (double) '2.0.20') {
                                     $objectproduct = get_product($product['product_id']);
                                     $objectproductvariable = get_product($product['variation_id']);
                                 } else {
                                     $objectproduct = new WC_Product($product['product_id']);
                                     $objectproductvariable = new WC_Product_Variation($product['variation_id']);
                                 }
                                 $tablecheckproduct .= "<tr>";
                                 if (get_option('rac_hide_product_name_product_info_shortcode') != 'yes') {
                                     $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_title($product['product_id']) . "</td>";
                                 }
                                 if (get_option('rac_hide_product_image_product_info_shortcode') != 'yes') {
                                     $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_post_thumbnail($product['product_id'], array(90, 90)) . "</td>";
                                 }
                                 if (get_option('rac_hide_product_price_product_info_shortcode') != 'yes') {
                                     $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . self::get_rac_formatprice($product['variation_id'] == '' ? $objectproduct->get_price() : $objectproductvariable->get_price()) . "</td>";
                                 }
                                 $tablecheckproduct .= "</tr>";
                             }
                         }
                     }
                     /* $tablecheckproduct .= "It is from Array";
                        $dump = print_r($cart_array, true);
                        $tablecheckproduct .= $dump; */
                 } elseif (is_object($cart_array)) {
                     $order = new WC_Order($cart_array->id);
                     if ($order->user_id != '') {
                         foreach ($order->get_items() as $products) {
                             if ((double) $woocommerce->version <= (double) '2.0.20') {
                                 $objectproduct = get_product($products['product_id']);
                                 $objectproductvariable = get_product($products['variation_id']);
                             } else {
                                 $objectproduct = new WC_Product($products['product_id']);
                                 $objectproductvariable = new WC_Product_Variation($products['variation_id']);
                             }
                             $tablecheckproduct .= "<tr>";
                             if (get_option('rac_hide_product_name_product_info_shortcode') != 'yes') {
                                 $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_title($products['product_id']) . "</td>";
                             }
                             if (get_option('rac_hide_product_image_product_info_shortcode') != 'yes') {
                                 $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_post_thumbnail($products['product_id'], array(90, 90)) . "</td>";
                             }
                             if (get_option('rac_hide_product_price_product_info_shortcode') != 'yes') {
                                 $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . self::get_rac_formatprice($products['variation_id'] == '' ? $objectproduct->get_price() : $objectproductvariable->get_price()) . "</td>";
                             }
                             $tablecheckproduct .= "</tr>";
                         }
                     }
                     /*  $tablecheckproduct .= "It is from Object";
                         $tablecheckproduct .= var_dump($cart_array); */
                 }
                 $tablecheckproduct .= "</table>";
                 if (get_option('rac_email_use_members') == 'yes') {
                     if (empty($each_cart->mail_template_id)) {
                         // IF EMPTY IT IS NOT SENT FOR ANY SINGLE TEMPLATE
                         if ($emails->sending_type == 'hours') {
                             $duration = $emails->sending_duration * 3600;
                         } else {
                             if ($emails->sending_type == 'minutes') {
                                 $duration = $emails->sending_duration * 60;
                             } else {
                                 if ($emails->sending_type == 'days') {
                                     $duration = $emails->sending_duration * 86400;
                                 }
                             }
                         }
                         //duration is finished
                         $cut_off_time = $each_cart->cart_abandon_time + $duration;
                         $current_time = current_time('timestamp');
                         if ($current_time > $cut_off_time) {
                             //$cart_url = $woocommerce->cart->get_cart_url();
                             //$objectcart = new WC_Cart();
                             @($cart_url = WC_Cart::get_cart_url());
                             $url_to_click = esc_url_raw(add_query_arg(array('abandon_cart' => $each_cart->id, 'email_template' => $emails->id), $cart_url));
                             if (get_option('rac_cart_link_options') == '1') {
                                 $url_to_click = '<a style="color:' . get_option("rac_email_link_color") . '"  href="' . $url_to_click . '">' . fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text) . '</a>';
                             } elseif (get_option('rac_cart_link_options') == '2') {
                                 $url_to_click = $url_to_click;
                             } else {
                                 $cart_Text = fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text);
                                 $url_to_click = RecoverAbandonCart::rac_cart_link_button_mode($url_to_click, $cart_Text);
                             }
                             $user = get_userdata($each_cart->user_id);
                             $to = $user->user_email;
                             $user_lang = $each_cart->wpml_lang;
                             $subject = fp_get_wpml_text('rac_template_' . $emails->id . '_subject', $each_cart->wpml_lang, $emails->subject);
                             $firstname = $user->user_firstname;
                             $lastname = $user->user_lastname;
                             $message = fp_get_wpml_text('rac_template_' . $emails->id . '_message', $each_cart->wpml_lang, $emails->message);
                             $subject = RecoverAbandonCart::shortcode_in_subject($firstname, $lastname, $subject);
                             $message = str_replace('{rac.cartlink}', $url_to_click, $message);
                             $message = str_replace('{rac.firstname}', $firstname, $message);
                             $message = str_replace('{rac.lastname}', $lastname, $message);
                             $message = str_replace('{rac.Productinfo}', $tablecheckproduct, $message);
                             if (strpos($message, "{rac.coupon}")) {
                                 $coupon_code = FPRacCoupon::rac_create_coupon($user->user_email, $each_cart->cart_abandon_time);
                                 $message = str_replace('{rac.coupon}', $coupon_code, $message);
                                 //replacing shortcode with coupon code
                             }
                             add_filter('woocommerce_email_footer_text', array('RecoverAbandonCart', 'rac_footer_email_customization'));
                             $message = do_shortcode($message);
                             //shortcode feature
                             if (get_option('rac_email_use_temp_plain') != 'yes') {
                                 ob_start();
                                 if (function_exists('wc_get_template')) {
                                     wc_get_template('emails/email-header.php', array('email_heading' => $subject));
                                     echo $message;
                                     wc_get_template('emails/email-footer.php');
                                 } else {
                                     woocommerce_get_template('emails/email-header.php', array('email_heading' => $subject));
                                     echo $message;
                                     woocommerce_get_template('emails/email-footer.php');
                                 }
                                 $woo_temp_msg = ob_get_clean();
                             } else {
                                 $woo_temp_msg = $message;
                             }
                             $headers = "MIME-Version: 1.0\r\n";
                             $headers .= "Content-Type: text/html; charset=UTF-8\r\n";
                             if ($emails->sender_opt == 'local') {
                                 $headers .= self::rac_formatted_from_address_local($emails->from_name, $emails->from_email);
                                 $headers .= "Reply-To: " . $emails->from_name . "<" . $emails->from_email . ">\r\n";
                             } else {
                                 $headers .= self::rac_formatted_from_address_woocommerce();
                                 $headers .= "Reply-To: " . get_option('woocommerce_email_from_name') . " <" . get_option('woocommerce_email_from_address') . ">\r\n";
                             }
                             if ($each_cart->sending_status == 'SEND') {
                                 //condition to check start/stop mail sending
                                 if ('wp_mail' == get_option('rac_trouble_mail')) {
                                     if (self::rac_send_wp_mail($to, $subject, $woo_temp_msg, $headers)) {
                                         //  wp_mail($to, $subject, $message);
                                         $store_template_id = array($emails->id);
                                         $store_template_id = maybe_serialize($store_template_id);
                                         $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                         //add to mail log
                                         $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                         $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                         FPRacCounter::rac_do_mail_count();
                                     }
                                 } else {
                                     if (self::rac_send_mail($to, $subject, $woo_temp_msg, $headers)) {
                                         //  wp_mail($to, $subject, $message);
                                         $store_template_id = array($emails->id);
                                         $store_template_id = maybe_serialize($store_template_id);
                                         $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                         //add to mail log
                                         $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                         $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                         FPRacCounter::rac_do_mail_count();
                                     }
                                 }
                             }
                         }
                     } elseif (!empty($each_cart->mail_template_id)) {
                         $sent_mail_templates = maybe_unserialize($each_cart->mail_template_id);
                         if (!in_array($emails->id, (array) $sent_mail_templates)) {
                             if ($emails->sending_type == 'hours') {
                                 $duration = $emails->sending_duration * 3600;
                             } else {
                                 if ($emails->sending_type == 'minutes') {
                                     $duration = $emails->sending_duration * 60;
                                 } else {
                                     if ($emails->sending_type == 'days') {
                                         $duration = $emails->sending_duration * 86400;
                                     }
                                 }
                             }
                             //duration is finished
                             $cut_off_time = $each_cart->cart_abandon_time + $duration;
                             $current_time = current_time('timestamp');
                             if ($current_time > $cut_off_time) {
                                 @($cart_url = WC_Cart::get_cart_url());
                                 $url_to_click = esc_url_raw(add_query_arg(array('abandon_cart' => $each_cart->id, 'email_template' => $emails->id), $cart_url));
                                 if (get_option('rac_cart_link_options') == '1') {
                                     $url_to_click = '<a style="color:' . get_option("rac_email_link_color") . '"  href="' . $url_to_click . '">' . fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text) . '</a>';
                                 } elseif (get_option('rac_cart_link_options') == '2') {
                                     $url_to_click = $url_to_click;
                                 } else {
                                     $cart_Text = fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text);
                                     $url_to_click = RecoverAbandonCart::rac_cart_link_button_mode($url_to_click, $cart_Text);
                                 }
                                 $user = get_userdata($each_cart->user_id);
                                 $to = $user->user_email;
                                 $user_lang = $each_cart->wpml_lang;
                                 $subject = fp_get_wpml_text('rac_template_' . $emails->id . '_subject', $each_cart->wpml_lang, $emails->subject);
                                 $firstname = $user->user_firstname;
                                 $lastname = $user->user_lastname;
                                 $message = fp_get_wpml_text('rac_template_' . $emails->id . '_message', $each_cart->wpml_lang, $emails->message);
                                 $subject = RecoverAbandonCart::shortcode_in_subject($firstname, $lastname, $subject);
                                 $message = str_replace('{rac.cartlink}', $url_to_click, $message);
                                 $message = str_replace('{rac.firstname}', $firstname, $message);
                                 $message = str_replace('{rac.lastname}', $lastname, $message);
                                 $message = str_replace('{rac.Productinfo}', $tablecheckproduct, $message);
                                 if (strpos($message, "{rac.coupon}")) {
                                     $coupon_code = FPRacCoupon::rac_create_coupon($user->user_email, $each_cart->cart_abandon_time);
                                     $message = str_replace('{rac.coupon}', $coupon_code, $message);
                                     //replacing shortcode with coupon code
                                 }
                                 add_filter('woocommerce_email_footer_text', array('RecoverAbandonCart', 'rac_footer_email_customization'));
                                 $message = do_shortcode($message);
                                 //shortcode feature
                                 if (get_option('rac_email_use_temp_plain') != 'yes') {
                                     ob_start();
                                     if (function_exists('wc_get_template')) {
                                         wc_get_template('emails/email-header.php', array('email_heading' => $subject));
                                         echo $message;
                                         wc_get_template('emails/email-footer.php');
                                     } else {
                                         woocommerce_get_template('emails/email-header.php', array('email_heading' => $subject));
                                         echo $message;
                                         woocommerce_get_template('emails/email-footer.php');
                                     }
                                     $woo_temp_msg = ob_get_clean();
                                 } else {
                                     $woo_temp_msg = $message;
                                 }
                                 $headers = "MIME-Version: 1.0\r\n";
                                 $headers .= "Content-Type: text/html; charset=UTF-8\r\n";
                                 if ($emails->sender_opt == 'local') {
                                     $headers .= self::rac_formatted_from_address_local($emails->from_name, $emails->from_email);
                                     $headers .= "Reply-To: " . $emails->from_name . " <" . $emails->from_email . ">\r\n";
                                 } else {
                                     $headers .= self::rac_formatted_from_address_woocommerce();
                                     $headers .= "Reply-To: " . get_option('woocommerce_email_from_name') . "<" . get_option('woocommerce_email_from_address') . ">\r\n";
                                 }
                                 if ($each_cart->sending_status == 'SEND') {
                                     //condition to check start/stop mail sending
                                     if ('wp_mail' == get_option('rac_trouble_mail')) {
                                         if (self::rac_send_wp_mail($to, $subject, $woo_temp_msg, $headers)) {
                                             //wp_mail($to, $subject, $message);
                                             $sent_mail_templates[] = $emails->id;
                                             $store_template_id = maybe_serialize($sent_mail_templates);
                                             $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                             //add to mail log
                                             $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                             $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                             FPRacCounter::rac_do_mail_count();
                                         }
                                     } else {
                                         if (self::rac_send_mail($to, $subject, $woo_temp_msg, $headers)) {
                                             //wp_mail($to, $subject, $message);
                                             $sent_mail_templates[] = $emails->id;
                                             $store_template_id = maybe_serialize($sent_mail_templates);
                                             $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                             //add to mail log
                                             $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                             $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                             FPRacCounter::rac_do_mail_count();
                                         }
                                     }
                                 }
                             }
                         }
                     }
                 }
             }
         }
     }
     // FOR GUEST
     if (get_option('rac_email_use_guests') == 'yes') {
         $abandon_carts = $wpdb->get_results("SELECT * FROM {$abandancart_table_name} WHERE cart_status='ABANDON' AND user_id='0' AND ip_address IS NULL AND completed IS NULL");
         //Selected only cart which are not completed
         foreach ($abandon_carts as $each_cart) {
             foreach ($email_templates as $emails) {
                 if ($emails->status == "ACTIVE") {
                     $cart_array = maybe_unserialize($each_cart->cart_details);
                     $tablecheckproduct = "<table style='width:100%;border:1px solid #eee;'><thead><tr>";
                     if (get_option('rac_hide_product_name_product_info_shortcode') != 'yes') {
                         $tablecheckproduct .= "<th style='text-align:left;border:1px solid #eee;padding:12px' scope='col'>" . fp_get_wpml_text('rac_template_product_name', $each_cart->wpml_lang, get_option('rac_product_info_product_name')) . "</th>";
                     }
                     if (get_option('rac_hide_product_image_product_info_shortcode') != 'yes') {
                         $tablecheckproduct .= "<th style='text-align:left;border:1px solid #eee;padding:12px' scope='col'>" . fp_get_wpml_text('rac_template_product_image', $each_cart->wpml_lang, get_option('rac_product_info_product_image')) . "</th>";
                     }
                     if (get_option('rac_hide_product_price_product_info_shortcode') != 'yes') {
                         $tablecheckproduct .= "<th style='text-align:left;border:1px solid #eee;padding:12px' scope='col'>" . fp_get_wpml_text('rac_template_product_price', $each_cart->wpml_lang, get_option('rac_product_info_product_price')) . "</th>";
                     }
                     $tablecheckproduct .= "</tr></thead><tbody>";
                     $order = new WC_Order($cart_array->id);
                     $products = $order->get_items();
                     //var_dump($products);
                     /* $tablecheckproduct .= "It is from Guest0 Object or Array";
                        $dump = print_r($cart_array, true);
                        $tablecheckproduct .= "<pre>";
                        $tablecheckproduct .= $dump;
                        $tablecheckproduct .= "</pre>"; */
                     foreach ($products as $each_product) {
                         if ((double) $woocommerce->version <= (double) '2.0.20') {
                             $objectproduct = get_product($each_product['product_id']);
                             $objectproductvariable = get_product($each_product['variation_id']);
                         } else {
                             $objectproduct = new WC_Product($each_product['product_id']);
                             $objectproductvariable = new WC_Product_Variable($each_product['variation_id']);
                         }
                         $tablecheckproduct .= "<tr>";
                         if (get_option('rac_hide_product_name_product_info_shortcode') != 'yes') {
                             $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_title($each_product['product_id']) . "</td>";
                         }
                         if (get_option('rac_hide_product_image_product_info_shortcode') != 'yes') {
                             $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_post_thumbnail($each_product['product_id'], array(90, 90)) . "</td>";
                         }
                         if (get_option('rac_hide_product_price_product_info_shortcode') != 'yes') {
                             $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . self::get_rac_formatprice($each_product['variation_id'] == '' ? $objectproduct->get_price() : $objectproductvariable->get_price()) . "</td>";
                         }
                         $tablecheckproduct .= "</tr>";
                     }
                     $tablecheckproduct .= "</table>";
                     if (empty($each_cart->mail_template_id)) {
                         // IF EMPTY IT IS NOT SENT FOR ANY SINGLE TEMPLATE
                         if ($emails->sending_type == 'hours') {
                             $duration = $emails->sending_duration * 3600;
                         } else {
                             if ($emails->sending_type == 'minutes') {
                                 $duration = $emails->sending_duration * 60;
                             } else {
                                 if ($emails->sending_type == 'days') {
                                     $duration = $emails->sending_duration * 86400;
                                 }
                             }
                         }
                         //duration is finished
                         $cut_off_time = $each_cart->cart_abandon_time + $duration;
                         $current_time = current_time('timestamp');
                         if ($current_time > $cut_off_time) {
                             @($cart_url = WC_Cart::get_cart_url());
                             $url_to_click = esc_url_raw(add_query_arg(array('abandon_cart' => $each_cart->id, 'email_template' => $emails->id, 'guest' => 'yes'), $cart_url));
                             if (get_option('rac_cart_link_options') == '1') {
                                 $url_to_click = '<a style="color:' . get_option("rac_email_link_color") . '"  href="' . $url_to_click . '">' . fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text) . '</a>';
                             } elseif (get_option('rac_cart_link_options') == '2') {
                                 $url_to_click = $url_to_click;
                             } else {
                                 $cart_Text = fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text);
                                 $url_to_click = RecoverAbandonCart::rac_cart_link_button_mode($url_to_click, $cart_Text);
                             }
                             //  $user = get_userdata($each_cart->user_id); NOT APPLICABLE
                             //                                echo "<pre>";
                             //                                var_dump($each_cart->cart_details);
                             //                                echo "</pre>";
                             @($order_object = maybe_unserialize($each_cart->cart_details));
                             // $order_objectinfo = maybe_unserialize($productifo->cart_details);
                             $to = $order_object->billing_email;
                             $user_lang = $each_cart->wpml_lang;
                             $subject = fp_get_wpml_text('rac_template_' . $emails->id . '_subject', $each_cart->wpml_lang, $emails->subject);
                             $firstname = $order_object->billing_first_name;
                             $lastname = $order_object->billing_last_name;
                             $message = fp_get_wpml_text('rac_template_' . $emails->id . '_message', $each_cart->wpml_lang, $emails->message);
                             $message = str_replace('{rac.cartlink}', $url_to_click, $message);
                             $subject = RecoverAbandonCart::shortcode_in_subject($firstname, $lastname, $subject);
                             $message = str_replace('{rac.firstname}', $firstname, $message);
                             $message = str_replace('{rac.lastname}', $lastname, $message);
                             $message = str_replace('{rac.Productinfo}', $tablecheckproduct, $message);
                             if (strpos($message, "{rac.coupon}")) {
                                 $coupon_code = FPRacCoupon::rac_create_coupon($order_object->billing_email, $each_cart->cart_abandon_time);
                                 $message = str_replace('{rac.coupon}', $coupon_code, $message);
                                 //replacing shortcode with coupon code
                             }
                             add_filter('woocommerce_email_footer_text', array('RecoverAbandonCart', 'rac_footer_email_customization'));
                             $message = do_shortcode($message);
                             //shortcode feature
                             if (get_option('rac_email_use_temp_plain') != 'yes') {
                                 ob_start();
                                 if (function_exists('wc_get_template')) {
                                     wc_get_template('emails/email-header.php', array('email_heading' => $subject));
                                     echo $message;
                                     wc_get_template('emails/email-footer.php');
                                 } else {
                                     woocommerce_get_template('emails/email-header.php', array('email_heading' => $subject));
                                     echo $message;
                                     woocommerce_get_template('emails/email-footer.php');
                                 }
                                 $woo_temp_msg = ob_get_clean();
                             } else {
                                 $woo_temp_msg = $message;
                             }
                             $headers = "MIME-Version: 1.0\r\n";
                             $headers .= "Content-Type: text/html; charset=UTF-8\r\n";
                             if ($emails->sender_opt == 'local') {
                                 $headers .= self::rac_formatted_from_address_local($emails->from_name, $emails->from_email);
                                 $headers .= "Reply-To: " . $emails->from_name . "<" . $emails->from_email . ">\r\n";
                             } else {
                                 $headers .= self::rac_formatted_from_address_woocommerce();
                                 $headers .= "Reply-To: " . get_option('woocommerce_email_from_name') . "<" . get_option('woocommerce_email_from_address') . ">\r\n";
                             }
                             if ($each_cart->sending_status == 'SEND') {
                                 //condition to check start/stop mail sending
                                 if ('wp_mail' == get_option('rac_trouble_mail')) {
                                     if (self::rac_send_wp_mail($to, $subject, $woo_temp_msg, $headers)) {
                                         // wp_mail($to, $subject, $message);
                                         $store_template_id = array($emails->id);
                                         $store_template_id = maybe_serialize($store_template_id);
                                         $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                         //add to mail log
                                         $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                         $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                         FPRacCounter::rac_do_mail_count();
                                     }
                                 } else {
                                     if (self::rac_send_mail($to, $subject, $woo_temp_msg, $headers)) {
                                         // wp_mail($to, $subject, $message);
                                         $store_template_id = array($emails->id);
                                         $store_template_id = maybe_serialize($store_template_id);
                                         $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                         //add to mail log
                                         $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                         $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                         FPRacCounter::rac_do_mail_count();
                                     }
                                 }
                             }
                         } elseif (!empty($each_cart->mail_template_id)) {
                             $sent_mail_templates = maybe_unserialize($each_cart->mail_template_id);
                             if (!in_array($emails->id, (array) $sent_mail_templates)) {
                                 if ($emails->sending_type == 'hours') {
                                     $duration = $emails->sending_duration * 3600;
                                 } else {
                                     if ($emails->sending_type == 'minutes') {
                                         $duration = $emails->sending_duration * 60;
                                     } else {
                                         if ($emails->sending_type == 'days') {
                                             $duration = $emails->sending_duration * 86400;
                                         }
                                     }
                                 }
                                 //duration is finished
                                 $cut_off_time = $each_cart->cart_abandon_time + $duration;
                                 $current_time = current_time('timestamp');
                                 if ($current_time > $cut_off_time) {
                                     @($cart_url = WC_Cart::get_cart_url());
                                     $url_to_click = esc_url_raw(add_query_arg(array('abandon_cart' => $each_cart->id, 'email_template' => $emails->id, 'guest' => 'yes'), $cart_url));
                                     if (get_option('rac_cart_link_options') == '1') {
                                         $url_to_click = '<a style="color:' . get_option("rac_email_link_color") . '"  href="' . $url_to_click . '">' . fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text) . '</a>';
                                     } elseif (get_option('rac_cart_link_options') == '2') {
                                         $url_to_click = $url_to_click;
                                     } else {
                                         $cart_Text = fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text);
                                         $url_to_click = RecoverAbandonCart::rac_cart_link_button_mode($url_to_click, $cart_Text);
                                     }
                                     //  $user = get_userdata($each_cart->user_id); NOT APPLICABLE
                                     $order_object = maybe_unserialize($each_cart->cart_details);
                                     $to = $order_object->billing_email;
                                     $user_lang = $each_cart->wpml_lang;
                                     $subject = fp_get_wpml_text('rac_template_' . $emails->id . '_subject', $each_cart->wpml_lang, $emails->subject);
                                     $firstname = $order_object->billing_first_name;
                                     $lastname = $order_object->billing_last_name;
                                     $message = fp_get_wpml_text('rac_template_' . $emails->id . '_message', $each_cart->wpml_lang, $emails->message);
                                     $message = str_replace('{rac.cartlink}', $url_to_click, $message);
                                     $subject = RecoverAbandonCart::shortcode_in_subject($firstname, $lastname, $subject);
                                     $message = str_replace('{rac.firstname}', $firstname, $message);
                                     $message = str_replace('{rac.lastname}', $lastname, $message);
                                     $message = str_replace('{rac.Productinfo}', $tablecheckproduct, $message);
                                     if (strpos($message, "{rac.coupon}")) {
                                         $coupon_code = FPRacCoupon::rac_create_coupon($order_object->billing_email, $each_cart->cart_abandon_time);
                                         $message = str_replace('{rac.coupon}', $coupon_code, $message);
                                         //replacing shortcode with coupon code
                                     }
                                     add_filter('woocommerce_email_footer_text', array('RecoverAbandonCart', 'rac_footer_email_customization'));
                                     $message = do_shortcode($message);
                                     //shortcode feature
                                     if (get_option('rac_email_use_temp_plain') != 'yes') {
                                         ob_start();
                                         if (function_exists('wc_get_template')) {
                                             wc_get_template('emails/email-header.php', array('email_heading' => $subject));
                                             echo $message;
                                             wc_get_template('emails/email-footer.php');
                                         } else {
                                             woocommerce_get_template('emails/email-header.php', array('email_heading' => $subject));
                                             echo $message;
                                             woocommerce_get_template('emails/email-footer.php');
                                         }
                                         $woo_temp_msg = ob_get_clean();
                                     } else {
                                         $woo_temp_msg = $message;
                                     }
                                     $headers = "MIME-Version: 1.0\r\n";
                                     $headers .= "Content-Type: text/html; charset=UTF-8\r\n";
                                     if ($emails->sender_opt == 'local') {
                                         $headers .= self::rac_formatted_from_address_local($emails->from_name, $emails->from_email);
                                         $headers .= "Reply-To: " . $emails->from_name . "<" . $emails->from_email . ">\r\n";
                                     } else {
                                         $headers .= self::rac_formatted_from_address_woocommerce();
                                         $headers .= "Reply-To: " . get_option('woocommerce_email_from_name') . "<" . get_option('woocommerce_email_from_address') . ">\r\n";
                                     }
                                     if ($each_cart->sending_status == 'SEND') {
                                         //condition to check start/stop mail sending
                                         if ('wp_mail' == get_option('rac_trouble_mail')) {
                                             if (self::rac_send_wp_mail($to, $subject, $woo_temp_msg, $headers)) {
                                                 // wp_mail($to, $subject, $message);
                                                 $sent_mail_templates[] = $emails->id;
                                                 $store_template_id = maybe_serialize($sent_mail_templates);
                                                 $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                                 //add to mail log
                                                 $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                                 $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                                 FPRacCounter::rac_do_mail_count();
                                             }
                                         } else {
                                             if (self::rac_send_mail($to, $subject, $woo_temp_msg, $headers)) {
                                                 // wp_mail($to, $subject, $message);
                                                 $store_template_id = array($emails->id);
                                                 $store_template_id = maybe_serialize($store_template_id);
                                                 $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                                 //add to mail log
                                                 $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                                 $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                                 FPRacCounter::rac_do_mail_count();
                                             }
                                         }
                                     }
                                 }
                             }
                         }
                     }
                 }
             }
         }
         //FOR Guest Captured in chcekout page
         $abandon_carts = $wpdb->get_results("SELECT * FROM {$abandancart_table_name} WHERE cart_status='ABANDON' AND user_id='0' AND ip_address IS NOT NULL AND completed IS NULL");
         //Selected only cart which are not completed
         foreach ($abandon_carts as $each_cart) {
             foreach ($email_templates as $emails) {
                 $cart_array = maybe_unserialize($each_cart->cart_details);
                 $tablecheckproduct = "<table style='width:100%;border:1px solid #eee;'><thead><tr>";
                 if (get_option('rac_hide_product_name_product_info_shortcode') != 'yes') {
                     $tablecheckproduct .= "<th style='text-align:left;border:1px solid #eee;padding:12px' scope='col'>" . fp_get_wpml_text('rac_template_product_name', $each_cart->wpml_lang, get_option('rac_product_info_product_name')) . "</th>";
                 }
                 if (get_option('rac_hide_product_image_product_info_shortcode') != 'yes') {
                     $tablecheckproduct .= "<th style='text-align:left;border:1px solid #eee;padding:12px' scope='col'>" . fp_get_wpml_text('rac_template_product_image', $each_cart->wpml_lang, get_option('rac_product_info_product_image')) . "</th>";
                 }
                 if (get_option('rac_hide_product_price_product_info_shortcode') != 'yes') {
                     $tablecheckproduct .= "<th style='text-align:left;border:1px solid #eee;padding:12px' scope='col'>" . fp_get_wpml_text('rac_template_product_price', $each_cart->wpml_lang, get_option('rac_product_info_product_price')) . "</th>";
                 }
                 $tablecheckproduct .= "</tr></thead><tbody>";
                 if (is_array($cart_array)) {
                     /* $tablecheckproduct .= "It is from Guest Array";
                        $dump = print_r($cart_array, true);
                        $tablecheckproduct .= "<pre>";
                        $tablecheckproduct .= $dump;
                        $tablecheckproduct .= "</pre>"; */
                     foreach ($cart_array as $cart) {
                         if (is_array($cart)) {
                             if ((double) $woocommerce->version <= (double) '2.0.20') {
                                 $objectproduct = get_product($cart['product_id']);
                                 $objectproductvariable = get_product($cart['variation_id']);
                             } else {
                                 $objectproduct = new WC_Product($cart['product_id']);
                                 $objectproductvariable = new WC_Product_Variable($cart['variation_id']);
                             }
                             $tablecheckproduct .= "<tr>";
                             if (get_option('rac_hide_product_name_product_info_shortcode') != 'yes') {
                                 $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_title($cart['product_id']) . "</td>";
                             }
                             if (get_option('rac_hide_product_image_product_info_shortcode') != 'yes') {
                                 $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_post_thumbnail($cart['product_id'], array(90, 90)) . "</td>";
                             }
                             if (get_option('rac_hide_product_price_product_info_shortcode') != 'yes') {
                                 $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . self::get_rac_formatprice($cart['variation_id'] == '' ? $objectproduct->get_price() : $objectproductvariable->get_price()) . "</td>";
                             }
                             $tablecheckproduct .= "</tr>";
                         }
                     }
                 } elseif (is_object($cart_array)) {
                     /* $tablecheckproduct .= "It is from Guest1 Object";
                        $dump = print_r($cart_array, true);
                        $tablecheckproduct .= $dump; */
                     $order = new WC_Order($cart_array->id);
                     //                        if ($order->user_id != '') {
                     foreach ($order->get_items() as $products) {
                         if ((double) $woocommerce->version <= (double) '2.0.20') {
                             $objectproduct = get_product($products['product_id']);
                             $objectproductvariable = get_product($products['variation_id']);
                         } else {
                             $objectproduct = new WC_Product($products['product_id']);
                             $objectproductvariable = new WC_Product_Variable($products['variation_id']);
                         }
                         $tablecheckproduct .= "<tr>";
                         if (get_option('rac_hide_product_name_product_info_shortcode') != 'yes') {
                             $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_title($products['product_id']) . "</td>";
                         }
                         if (get_option('rac_hide_product_image_product_info_shortcode') != 'yes') {
                             $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_post_thumbnail($products['product_id'], array(90, 90)) . "</td>";
                         }
                         if (get_option('rac_hide_product_price_product_info_shortcode') != 'yes') {
                             $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . self::get_rac_formatprice($products['variation_id'] == '' ? $objectproduct->get_price() : $objectproductvariable->get_price()) . "</td>";
                         }
                         $tablecheckproduct .= "</tr>";
                     }
                     //  }
                 }
                 $tablecheckproduct .= "</table>";
                 if ($emails->status == "ACTIVE") {
                     if (empty($each_cart->mail_template_id)) {
                         // IF EMPTY IT IS NOT SENT FOR ANY SINGLE TEMPLATE
                         if ($emails->sending_type == 'hours') {
                             $duration = $emails->sending_duration * 3600;
                         } else {
                             if ($emails->sending_type == 'minutes') {
                                 $duration = $emails->sending_duration * 60;
                             } else {
                                 if ($emails->sending_type == 'days') {
                                     $duration = $emails->sending_duration * 86400;
                                 }
                             }
                         }
                         //duration is finished
                         $cut_off_time = $each_cart->cart_abandon_time + $duration;
                         $current_time = current_time('timestamp');
                         if ($current_time > $cut_off_time) {
                             @($cart_url = WC_Cart::get_cart_url());
                             $url_to_click = esc_url_raw(add_query_arg(array('abandon_cart' => $each_cart->id, 'email_template' => $emails->id, 'guest' => 'yes', 'checkout' => 'yes'), $cart_url));
                             if (get_option('rac_cart_link_options') == '1') {
                                 $url_to_click = '<a style="color:' . get_option("rac_email_link_color") . '"  href="' . $url_to_click . '">' . fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text) . '</a>';
                             } elseif (get_option('rac_cart_link_options') == '2') {
                                 $url_to_click = $url_to_click;
                             } else {
                                 $cart_Text = fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text);
                                 $url_to_click = RecoverAbandonCart::rac_cart_link_button_mode($url_to_click, $cart_Text);
                             }
                             //  $user = get_userdata($each_cart->user_id); NOT APPLICABLE
                             $order_object = maybe_unserialize($each_cart->cart_details);
                             $to = $order_object['visitor_mail'];
                             $user_lang = $each_cart->wpml_lang;
                             $subject = fp_get_wpml_text('rac_template_' . $emails->id . '_subject', $each_cart->wpml_lang, $emails->subject);
                             $firstname = $order_object['first_name'];
                             $lastname = $order_object['last_name'];
                             $message = fp_get_wpml_text('rac_template_' . $emails->id . '_message', $each_cart->wpml_lang, $emails->message);
                             $message = str_replace('{rac.cartlink}', $url_to_click, $message);
                             $subject = RecoverAbandonCart::shortcode_in_subject($firstname, $lastname, $subject);
                             $message = str_replace('{rac.firstname}', $firstname, $message);
                             $message = str_replace('{rac.lastname}', $lastname, $message);
                             $message = str_replace('{rac.Productinfo}', $tablecheckproduct, $message);
                             if (strpos($message, "{rac.coupon}")) {
                                 $coupon_code = FPRacCoupon::rac_create_coupon($order_object['visitor_mail'], $each_cart->cart_abandon_time);
                                 $message = str_replace('{rac.coupon}', $coupon_code, $message);
                                 //replacing shortcode with coupon code
                             }
                             add_filter('woocommerce_email_footer_text', array('RecoverAbandonCart', 'rac_footer_email_customization'));
                             $message = do_shortcode($message);
                             //shortcode feature
                             if (get_option('rac_email_use_temp_plain') != 'yes') {
                                 ob_start();
                                 if (function_exists('wc_get_template')) {
                                     wc_get_template('emails/email-header.php', array('email_heading' => $subject));
                                     echo $message;
                                     wc_get_template('emails/email-footer.php');
                                 } else {
                                     woocommerce_get_template('emails/email-header.php', array('email_heading' => $subject));
                                     echo $message;
                                     woocommerce_get_template('emails/email-footer.php');
                                 }
                                 $woo_temp_msg = ob_get_clean();
                             } else {
                                 $woo_temp_msg = $message;
                             }
                             $headers = "MIME-Version: 1.0\r\n";
                             $headers .= "Content-Type: text/html; charset=UTF-8\r\n";
                             if ($emails->sender_opt == 'local') {
                                 $headers .= self::rac_formatted_from_address_local($emails->from_name, $emails->from_email);
                                 $headers .= "Reply-To: " . $emails->from_name . "<" . $emails->from_email . ">\r\n";
                             } else {
                                 $headers .= self::rac_formatted_from_address_woocommerce();
                                 $headers .= "Reply-To: " . get_option('woocommerce_email_from_name') . "<" . get_option('woocommerce_email_from_address') . ">\r\n";
                             }
                             if ($each_cart->sending_status == 'SEND') {
                                 //condition to check start/stop mail sending
                                 if ('wp_mail' == get_option('rac_trouble_mail')) {
                                     //  var_dump($to,$subject,$woo_temp_msg,$headers);
                                     if (self::rac_send_wp_mail($to, $subject, $woo_temp_msg, $headers)) {
                                         // wp_mail($to, $subject, $message);
                                         $store_template_id = array($emails->id);
                                         $store_template_id = maybe_serialize($store_template_id);
                                         $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                         //add to mail log
                                         $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                         $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                         FPRacCounter::rac_do_mail_count();
                                     }
                                 } else {
                                     if (self::rac_send_mail($to, $subject, $woo_temp_msg, $headers)) {
                                         // wp_mail($to, $subject, $message);
                                         $store_template_id = array($emails->id);
                                         $store_template_id = maybe_serialize($store_template_id);
                                         $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                         //add to mail log
                                         $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                         $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                         FPRacCounter::rac_do_mail_count();
                                     }
                                 }
                             }
                         }
                     } elseif (!empty($each_cart->mail_template_id)) {
                         $sent_mail_templates = maybe_unserialize($each_cart->mail_template_id);
                         if (!in_array($emails->id, (array) $sent_mail_templates)) {
                             if ($emails->sending_type == 'hours') {
                                 $duration = $emails->sending_duration * 3600;
                             } else {
                                 if ($emails->sending_type == 'minutes') {
                                     $duration = $emails->sending_duration * 60;
                                 } else {
                                     if ($emails->sending_type == 'days') {
                                         $duration = $emails->sending_duration * 86400;
                                     }
                                 }
                             }
                             //duration is finished
                             $cut_off_time = $each_cart->cart_abandon_time + $duration;
                             $current_time = current_time('timestamp');
                             if ($current_time > $cut_off_time) {
                                 @($cart_url = WC_Cart::get_cart_url());
                                 $url_to_click = esc_url_raw(add_query_arg(array('abandon_cart' => $each_cart->id, 'email_template' => $emails->id, 'guest' => 'yes', 'checkout' => 'yes'), $cart_url));
                                 if (get_option('rac_cart_link_options') == '1') {
                                     $url_to_click = '<a style="color:' . get_option("rac_email_link_color") . '"  href="' . $url_to_click . '">' . fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text) . '</a>';
                                 } elseif (get_option('rac_cart_link_options') == '2') {
                                     $url_to_click = $url_to_click;
                                 } else {
                                     $cart_Text = fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text);
                                     $url_to_click = RecoverAbandonCart::rac_cart_link_button_mode($url_to_click, $cart_Text);
                                 }
                                 //  $user = get_userdata($each_cart->user_id); NOT APPLICABLE
                                 $order_object = maybe_unserialize($each_cart->cart_details);
                                 $to = $order_object['visitor_mail'];
                                 $user_lang = $each_cart->wpml_lang;
                                 $subject = fp_get_wpml_text('rac_template_' . $emails->id . '_subject', $each_cart->wpml_lang, $emails->subject);
                                 $firstname = $order_object['first_name'];
                                 $lastname = $order_object['last_name'];
                                 $message = fp_get_wpml_text('rac_template_' . $emails->id . '_message', $each_cart->wpml_lang, $emails->message);
                                 $message = str_replace('{rac.cartlink}', $url_to_click, $message);
                                 $subject = RecoverAbandonCart::shortcode_in_subject($firstname, $lastname, $subject);
                                 $message = str_replace('{rac.firstname}', $firstname, $message);
                                 $message = str_replace('{rac.lastname}', $lastname, $message);
                                 $message = str_replace('{rac.Productinfo}', $tablecheckproduct, $message);
                                 if (strpos($message, "{rac.coupon}")) {
                                     $coupon_code = FPRacCoupon::rac_create_coupon($order_object['visitor_mail'], $each_cart->cart_abandon_time);
                                     $message = str_replace('{rac.coupon}', $coupon_code, $message);
                                     //replacing shortcode with coupon code
                                 }
                                 add_filter('woocommerce_email_footer_text', array('RecoverAbandonCart', 'rac_footer_email_customization'));
                                 $message = do_shortcode($message);
                                 //shortcode feature
                                 if (get_option('rac_email_use_temp_plain') != 'yes') {
                                     ob_start();
                                     if (function_exists('wc_get_template')) {
                                         wc_get_template('emails/email-header.php', array('email_heading' => $subject));
                                         echo $message;
                                         wc_get_template('emails/email-footer.php');
                                     } else {
                                         woocommerce_get_template('emails/email-header.php', array('email_heading' => $subject));
                                         echo $message;
                                         woocommerce_get_template('emails/email-footer.php');
                                     }
                                     $woo_temp_msg = ob_get_clean();
                                 } else {
                                     $woo_temp_msg = $message;
                                 }
                                 $headers = "MIME-Version: 1.0\r\n";
                                 $headers .= "Content-Type: text/html; charset=UTF-8\r\n";
                                 if ($emails->sender_opt == 'local') {
                                     $headers .= self::rac_formatted_from_address_local($emails->from_name, $emails->from_email);
                                     $headers .= "Reply-To: " . $emails->from_name . "<" . $emails->from_email . ">\r\n";
                                 } else {
                                     $headers .= self::rac_formatted_from_address_woocommerce();
                                     $headers .= "Reply-To: " . get_option('woocommerce_email_from_name') . "<" . get_option('woocommerce_email_from_address') . ">\r\n";
                                 }
                                 if ($each_cart->sending_status == 'SEND') {
                                     //condition to check start/stop mail sending
                                     if ('wp_mail' == get_option('rac_trouble_mail')) {
                                         if (self::rac_send_wp_mail($to, $subject, $woo_temp_msg, $headers)) {
                                             // wp_mail($to, $subject, $message);
                                             $sent_mail_templates[] = $emails->id;
                                             $store_template_id = maybe_serialize($sent_mail_templates);
                                             $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                             //add to mail log
                                             $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                             $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                             FPRacCounter::rac_do_mail_count();
                                         }
                                     } else {
                                         if (self::rac_send_mail($to, $subject, $woo_temp_msg, $headers)) {
                                             // wp_mail($to, $subject, $message);
                                             $sent_mail_templates[] = $emails->id;
                                             $store_template_id = maybe_serialize($sent_mail_templates);
                                             $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                             //add to mail log
                                             $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                             $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                             FPRacCounter::rac_do_mail_count();
                                         }
                                     }
                                 }
                             }
                         }
                     }
                 }
             }
         }
     }
     // FOR ORDER UPDATED FROM OLD
     $abandon_carts = $wpdb->get_results("SELECT * FROM {$abandancart_table_name} WHERE cart_status='ABANDON' AND user_id='old_order' AND ip_address IS NULL AND completed IS NULL");
     //Selected only cart which are not completed
     foreach ($abandon_carts as $each_cart) {
         foreach ($email_templates as $emails) {
             $cart_array = maybe_unserialize($each_cart->cart_details);
             $tablecheckproduct = "<table style='width:100%;border:1px solid #eee;'><thead><tr>";
             if (get_option('rac_hide_product_name_product_info_shortcode') != 'yes') {
                 $tablecheckproduct .= "<th style='text-align:left;border:1px solid #eee;padding:12px' scope='col'>" . fp_get_wpml_text('rac_template_product_name', $each_cart->wpml_lang, get_option('rac_product_info_product_name')) . "</th>";
             }
             if (get_option('rac_hide_product_image_product_info_shortcode') != 'yes') {
                 $tablecheckproduct .= "<th style='text-align:left;border:1px solid #eee;padding:12px' scope='col'>" . fp_get_wpml_text('rac_template_product_image', $each_cart->wpml_lang, get_option('rac_product_info_product_image')) . "</th>";
             }
             if (get_option('rac_hide_product_price_product_info_shortcode') != 'yes') {
                 $tablecheckproduct .= "<th style='text-align:left;border:1px solid #eee;padding:12px' scope='col'>" . fp_get_wpml_text('rac_template_product_price', $each_cart->wpml_lang, get_option('rac_product_info_product_price')) . "</th>";
             }
             $tablecheckproduct .= "</tr></thead><tbody>";
             if (is_object($cart_array)) {
                 if (get_option('rac_email_use_members') == 'yes') {
                     /* $tablecheckproduct .= "It is from Member Object";
                        $dump = print_r($cart_array, true);
                        $tablecheckproduct .= $dump; */
                     $order = new WC_Order($cart_array->id);
                     if ($order->user_id != '') {
                         foreach ($order->get_items() as $products) {
                             if ((double) $woocommerce->version <= (double) '2.0.20') {
                                 $objectproduct = get_product($products['product_id']);
                                 $objectproductvariable = get_product($products['variation_id']);
                             } else {
                                 $objectproduct = new WC_Product($products['product_id']);
                                 $objectproductvariable = new WC_Product_Variable($products['variation_id']);
                             }
                             $tablecheckproduct .= "<tr>";
                             if (get_option('rac_hide_product_name_product_info_shortcode') != 'yes') {
                                 $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_title($products['product_id']) . "</td>";
                             }
                             if (get_option('rac_hide_product_image_product_info_shortcode') != 'yes') {
                                 $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_post_thumbnail($products['product_id'], array(90, 90)) . "</td>";
                             }
                             if (get_option('rac_hide_product_price_product_info_shortcode') != 'yes') {
                                 $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . self::get_rac_formatprice($products['variation_id'] == '' ? $objectproduct->get_price() : $objectproductvariable->get_price()) . "</td>";
                             }
                             $tablecheckproduct .= "</tr>";
                         }
                     }
                     //mail
                     if ($emails->status == "ACTIVE") {
                         if (empty($each_cart->mail_template_id)) {
                             // IF EMPTY IT IS NOT SENT FOR ANY SINGLE TEMPLATE
                             if ($emails->sending_type == 'hours') {
                                 $duration = $emails->sending_duration * 3600;
                             } else {
                                 if ($emails->sending_type == 'minutes') {
                                     $duration = $emails->sending_duration * 60;
                                 } else {
                                     if ($emails->sending_type == 'days') {
                                         $duration = $emails->sending_duration * 86400;
                                     }
                                 }
                             }
                             //duration is finished
                             $cut_off_time = $each_cart->cart_abandon_time + $duration;
                             $current_time = current_time('timestamp');
                             if ($current_time > $cut_off_time) {
                                 @($cart_url = WC_Cart::get_cart_url());
                                 $url_to_click = esc_url_raw(add_query_arg(array('abandon_cart' => $each_cart->id, 'email_template' => $emails->id, 'old_order' => 'yes'), $cart_url));
                                 if (get_option('rac_cart_link_options') == '1') {
                                     $url_to_click = '<a style="color:' . get_option("rac_email_link_color") . '"  href="' . $url_to_click . '">' . fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text) . '</a>';
                                 } elseif (get_option('rac_cart_link_options') == '2') {
                                     $url_to_click = $url_to_click;
                                 } else {
                                     $cart_Text = fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text);
                                     $url_to_click = RecoverAbandonCart::rac_cart_link_button_mode($url_to_click, $cart_Text);
                                 }
                                 //  $user = get_userdata($each_cart->user_id); NOT APPLICABLE
                                 $order_object = maybe_unserialize($each_cart->cart_details);
                                 $to = $order_object->billing_email;
                                 $user_lang = $each_cart->wpml_lang;
                                 $subject = fp_get_wpml_text('rac_template_' . $emails->id . '_subject', $each_cart->wpml_lang, $emails->subject);
                                 $firstname = $order_object->billing_first_name;
                                 $lastname = $order_object->billing_last_name;
                                 $message = fp_get_wpml_text('rac_template_' . $emails->id . '_message', $each_cart->wpml_lang, $emails->message);
                                 $message = str_replace('{rac.cartlink}', $url_to_click, $message);
                                 $subject = RecoverAbandonCart::shortcode_in_subject($firstname, $lastname, $subject);
                                 $message = str_replace('{rac.firstname}', $firstname, $message);
                                 $message = str_replace('{rac.lastname}', $lastname, $message);
                                 $message = str_replace('{rac.Productinfo}', $tablecheckproduct, $message);
                                 if (strpos($message, "{rac.coupon}")) {
                                     $coupon_code = FPRacCoupon::rac_create_coupon($order_object->billing_email, $each_cart->cart_abandon_time);
                                     $message = str_replace('{rac.coupon}', $coupon_code, $message);
                                     //replacing shortcode with coupon code
                                 }
                                 add_filter('woocommerce_email_footer_text', array('RecoverAbandonCart', 'rac_footer_email_customization'));
                                 $message = do_shortcode($message);
                                 //shortcode feature
                                 if (get_option('rac_email_use_temp_plain') != 'yes') {
                                     ob_start();
                                     if (function_exists('wc_get_template')) {
                                         wc_get_template('emails/email-header.php', array('email_heading' => $subject));
                                         echo $message;
                                         wc_get_template('emails/email-footer.php');
                                     } else {
                                         woocommerce_get_template('emails/email-header.php', array('email_heading' => $subject));
                                         echo $message;
                                         woocommerce_get_template('emails/email-footer.php');
                                     }
                                     $woo_temp_msg = ob_get_clean();
                                 } else {
                                     $woo_temp_msg = $message;
                                 }
                                 $headers = "MIME-Version: 1.0\r\n";
                                 $headers .= "Content-Type: text/html; charset=UTF-8\r\n";
                                 if ($emails->sender_opt == 'local') {
                                     $headers .= self::rac_formatted_from_address_local($emails->from_name, $emails->from_email);
                                     $headers .= "Reply-To: " . $emails->from_name . "<" . $emails->from_email . ">\r\n";
                                 } else {
                                     $headers .= self::rac_formatted_from_address_woocommerce();
                                     $headers .= "Reply-To: " . get_option('woocommerce_email_from_name') . "<" . get_option('woocommerce_email_from_address') . ">\r\n";
                                 }
                                 if ($each_cart->sending_status == 'SEND') {
                                     //condition to check start/stop mail sending
                                     if ('wp_mail' == get_option('rac_trouble_mail')) {
                                         if (self::rac_send_wp_mail($to, $subject, $woo_temp_msg, $headers)) {
                                             // wp_mail($to, $subject, $message);
                                             $store_template_id = array($emails->id);
                                             $store_template_id = maybe_serialize($store_template_id);
                                             $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                             //add to mail log
                                             $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                             $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                             FPRacCounter::rac_do_mail_count();
                                         }
                                     } else {
                                         if (self::rac_send_mail($to, $subject, $woo_temp_msg, $headers)) {
                                             // wp_mail($to, $subject, $message);
                                             $store_template_id = array($emails->id);
                                             $store_template_id = maybe_serialize($store_template_id);
                                             $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                             //add to mail log
                                             $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                             $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                             FPRacCounter::rac_do_mail_count();
                                         }
                                     }
                                 }
                             }
                         } elseif (!empty($each_cart->mail_template_id)) {
                             $sent_mail_templates = maybe_unserialize($each_cart->mail_template_id);
                             if (!in_array($emails->id, (array) $sent_mail_templates)) {
                                 if ($emails->sending_type == 'hours') {
                                     $duration = $emails->sending_duration * 3600;
                                 } else {
                                     if ($emails->sending_type == 'minutes') {
                                         $duration = $emails->sending_duration * 60;
                                     } else {
                                         if ($emails->sending_type == 'days') {
                                             $duration = $emails->sending_duration * 86400;
                                         }
                                     }
                                 }
                                 //duration is finished
                                 $cut_off_time = $each_cart->cart_abandon_time + $duration;
                                 $current_time = current_time('timestamp');
                                 if ($current_time > $cut_off_time) {
                                     @($cart_url = WC_Cart::get_cart_url());
                                     $url_to_click = esc_url_raw(add_query_arg(array('abandon_cart' => $each_cart->id, 'email_template' => $emails->id, 'old_order' => 'yes'), $cart_url));
                                     if (get_option('rac_cart_link_options') == '1') {
                                         $url_to_click = '<a style="color:' . get_option("rac_email_link_color") . '"  href="' . $url_to_click . '">' . fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text) . '</a>';
                                     } elseif (get_option('rac_cart_link_options') == '2') {
                                         $url_to_click = $url_to_click;
                                     } else {
                                         $cart_Text = fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text);
                                         $url_to_click = RecoverAbandonCart::rac_cart_link_button_mode($url_to_click, $cart_Text);
                                     }
                                     //  $user = get_userdata($each_cart->user_id); NOT APPLICABLE
                                     $order_object = maybe_unserialize($each_cart->cart_details);
                                     $to = $order_object->billing_email;
                                     $user_lang = $each_cart->wpml_lang;
                                     $subject = fp_get_wpml_text('rac_template_' . $emails->id . '_subject', $each_cart->wpml_lang, $emails->subject);
                                     $firstname = $order_object->billing_first_name;
                                     $lastname = $order_object->billing_last_name;
                                     $message = fp_get_wpml_text('rac_template_' . $emails->id . '_message', $each_cart->wpml_lang, $emails->message);
                                     $message = str_replace('{rac.cartlink}', $url_to_click, $message);
                                     $subject = RecoverAbandonCart::shortcode_in_subject($firstname, $lastname, $subject);
                                     $message = str_replace('{rac.firstname}', $firstname, $message);
                                     $message = str_replace('{rac.lastname}', $lastname, $message);
                                     $message = str_replace('{rac.Productinfo}', $tablecheckproduct, $message);
                                     if (strpos($message, "{rac.coupon}")) {
                                         $coupon_code = FPRacCoupon::rac_create_coupon($order_object->billing_email, $each_cart->cart_abandon_time);
                                         $message = str_replace('{rac.coupon}', $coupon_code, $message);
                                         //replacing shortcode with coupon code
                                     }
                                     add_filter('woocommerce_email_footer_text', array('RecoverAbandonCart', 'rac_footer_email_customization'));
                                     $message = do_shortcode($message);
                                     //shortcode feature
                                     if (get_option('rac_email_use_temp_plain') != 'yes') {
                                         ob_start();
                                         if (function_exists('wc_get_template')) {
                                             wc_get_template('emails/email-header.php', array('email_heading' => $subject));
                                             echo $message;
                                             wc_get_template('emails/email-footer.php');
                                         } else {
                                             woocommerce_get_template('emails/email-header.php', array('email_heading' => $subject));
                                             echo $message;
                                             woocommerce_get_template('emails/email-footer.php');
                                         }
                                         $woo_temp_msg = ob_get_clean();
                                     } else {
                                         $woo_temp_msg = $message;
                                     }
                                     $headers = "MIME-Version: 1.0\r\n";
                                     $headers .= "Content-Type: text/html; charset=UTF-8\r\n";
                                     if ($emails->sender_opt == 'local') {
                                         $headers .= self::rac_formatted_from_address_local($emails->from_name, $emails->from_email);
                                         $headers .= "Reply-To: " . $emails->from_name . " <" . $emails->from_email . ">\r\n";
                                     } else {
                                         $headers .= self::rac_formatted_from_address_woocommerce();
                                         $headers .= "Reply-To: " . get_option('woocommerce_email_from_name') . "<" . get_option('woocommerce_email_from_address') . ">\r\n";
                                     }
                                     if ($each_cart->sending_status == 'SEND') {
                                         //condition to check start/stop mail sending
                                         if ('wp_mail' == get_option('rac_trouble_mail')) {
                                             if (self::rac_send_wp_mail($to, $subject, $woo_temp_msg, $headers)) {
                                                 // wp_mail($to, $subject, $message);
                                                 $sent_mail_templates[] = $emails->id;
                                                 $store_template_id = maybe_serialize($sent_mail_templates);
                                                 $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                                 //add to mail log
                                                 $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                                 $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                                 FPRacCounter::rac_do_mail_count();
                                             }
                                         } else {
                                             if (self::rac_send_mail($to, $subject, $woo_temp_msg, $headers)) {
                                                 // wp_mail($to, $subject, $message);
                                                 $sent_mail_templates[] = $emails->id;
                                                 $store_template_id = maybe_serialize($sent_mail_templates);
                                                 $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                                 //add to mail log
                                                 $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                                 $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                                 FPRacCounter::rac_do_mail_count();
                                             }
                                         }
                                     }
                                 }
                             }
                         }
                     }
                 }
                 if (get_option('rac_email_use_guests') == 'yes') {
                     /*  $tablecheckproduct .= "It is from Guest2 Object";
                         $dump = print_r($cart_array, true);
                         $tablecheckproduct .= $dump; */
                     //  if ($order->user_id == '') {
                     foreach ($order->get_items() as $products) {
                         if ((double) $woocommerce->version <= (double) '2.0.20') {
                             $objectproduct = get_product($products['product_id']);
                             $objectproductvariable = get_product($products['variation_id']);
                         } else {
                             $objectproduct = new WC_Product($products['product_id']);
                             $objectproductvariable = new WC_Product_Variable($products['variation_id']);
                         }
                         $tablecheckproduct .= "<tr>";
                         if (get_option('rac_hide_product_name_product_info_shortcode') != 'yes') {
                             $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_title($products['product_id']) . "</td>";
                         }
                         if (get_option('rac_hide_product_image_product_info_shortcode') != 'yes') {
                             $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . get_the_post_thumbnail($products['product_id'], array(90, 90)) . "</td>";
                         }
                         if (get_option('rac_hide_product_price_product_info_shortcode') != 'yes') {
                             $tablecheckproduct .= "<td style='text-align:left;vertical-align:middle;border:1px solid #eee;word-wrap:break-word;padding:12px'>" . self::get_rac_formatprice($products['variation_id'] == '' ? $objectproduct->get_price() : $objectproductvariable->get_price()) . "</td>";
                         }
                         $tablecheckproduct .= "</tr>";
                     }
                     // }
                     $tablecheckproduct .= "</table>";
                     //guest mail
                     if ($emails->status == "ACTIVE") {
                         if (empty($each_cart->mail_template_id)) {
                             // IF EMPTY IT IS NOT SENT FOR ANY SINGLE TEMPLATE
                             if ($emails->sending_type == 'hours') {
                                 $duration = $emails->sending_duration * 3600;
                             } else {
                                 if ($emails->sending_type == 'minutes') {
                                     $duration = $emails->sending_duration * 60;
                                 } else {
                                     if ($emails->sending_type == 'days') {
                                         $duration = $emails->sending_duration * 86400;
                                     }
                                 }
                             }
                             //duration is finished
                             $cut_off_time = $each_cart->cart_abandon_time + $duration;
                             $current_time = current_time('timestamp');
                             if ($current_time > $cut_off_time) {
                                 @($cart_url = WC_Cart::get_cart_url());
                                 $url_to_click = esc_url_raw(add_query_arg(array('abandon_cart' => $each_cart->id, 'email_template' => $emails->id, 'old_order' => 'yes'), $cart_url));
                                 if (get_option('rac_cart_link_options') == '1') {
                                     $url_to_click = '<a style="color:' . get_option("rac_email_link_color") . '"  href="' . $url_to_click . '">' . fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text) . '</a>';
                                 } elseif (get_option('rac_cart_link_options') == '2') {
                                     $url_to_click = $url_to_click;
                                 } else {
                                     $cart_Text = fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text);
                                     $url_to_click = RecoverAbandonCart::rac_cart_link_button_mode($url_to_click, $cart_Text);
                                 }
                                 //  $user = get_userdata($each_cart->user_id); NOT APPLICABLE
                                 $order_object = maybe_unserialize($each_cart->cart_details);
                                 $to = $order_object->billing_email;
                                 $user_lang = $each_cart->wpml_lang;
                                 $subject = fp_get_wpml_text('rac_template_' . $emails->id . '_subject', $each_cart->wpml_lang, $emails->subject);
                                 $firstname = $order_object->billing_first_name;
                                 $lastname = $order_object->billing_last_name;
                                 $message = fp_get_wpml_text('rac_template_' . $emails->id . '_message', $each_cart->wpml_lang, $emails->message);
                                 $message = str_replace('{rac.cartlink}', $url_to_click, $message);
                                 $subject = RecoverAbandonCart::shortcode_in_subject($firstname, $lastname, $subject);
                                 $message = str_replace('{rac.firstname}', $firstname, $message);
                                 $message = str_replace('{rac.lastname}', $lastname, $message);
                                 $message = str_replace('{rac.Productinfo}', $tablecheckproduct, $message);
                                 if (strpos($message, "{rac.coupon}")) {
                                     $coupon_code = FPRacCoupon::rac_create_coupon($order_object->billing_email, $each_cart->cart_abandon_time);
                                     $message = str_replace('{rac.coupon}', $coupon_code, $message);
                                     //replacing shortcode with coupon code
                                 }
                                 add_filter('woocommerce_email_footer_text', array('RecoverAbandonCart', 'rac_footer_email_customization'));
                                 $message = do_shortcode($message);
                                 //shortcode feature
                                 if (get_option('rac_email_use_temp_plain') != 'yes') {
                                     ob_start();
                                     if (function_exists('wc_get_template')) {
                                         wc_get_template('emails/email-header.php', array('email_heading' => $subject));
                                         echo $message;
                                         wc_get_template('emails/email-footer.php');
                                     } else {
                                         woocommerce_get_template('emails/email-header.php', array('email_heading' => $subject));
                                         echo $message;
                                         woocommerce_get_template('emails/email-footer.php');
                                     }
                                     $woo_temp_msg = ob_get_clean();
                                 } else {
                                     $woo_temp_msg = $message;
                                 }
                                 $headers = "MIME-Version: 1.0\r\n";
                                 $headers .= "Content-Type: text/html; charset=UTF-8\r\n";
                                 if ($emails->sender_opt == 'local') {
                                     $headers .= self::rac_formatted_from_address_local($emails->from_name, $emails->from_email);
                                     $headers .= "Reply-To: " . $emails->from_name . "<" . $emails->from_email . ">\r\n";
                                 } else {
                                     $headers .= self::rac_formatted_from_address_woocommerce();
                                     $headers .= "Reply-To: " . get_option('woocommerce_email_from_name') . "<" . get_option('woocommerce_email_from_address') . ">\r\n";
                                 }
                                 if ($each_cart->sending_status == 'SEND') {
                                     //condition to check start/stop mail sending
                                     if ('wp_mail' == get_option('rac_trouble_mail')) {
                                         if (self::rac_send_wp_mail($to, $subject, $woo_temp_msg, $headers)) {
                                             // wp_mail($to, $subject, $message);
                                             $store_template_id = array($emails->id);
                                             $store_template_id = maybe_serialize($store_template_id);
                                             $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                             //add to mail log
                                             $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                             $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                             FPRacCounter::rac_do_mail_count();
                                         }
                                     } else {
                                         if (self::rac_send_mail($to, $subject, $woo_temp_msg, $headers)) {
                                             // wp_mail($to, $subject, $message);
                                             $store_template_id = array($emails->id);
                                             $store_template_id = maybe_serialize($store_template_id);
                                             $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                             //add to mail log
                                             $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                             $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                             FPRacCounter::rac_do_mail_count();
                                         }
                                     }
                                 }
                             }
                         } elseif (!empty($each_cart->mail_template_id)) {
                             $sent_mail_templates = maybe_unserialize($each_cart->mail_template_id);
                             if (!in_array($emails->id, (array) $sent_mail_templates)) {
                                 if ($emails->sending_type == 'hours') {
                                     $duration = $emails->sending_duration * 3600;
                                 } else {
                                     if ($emails->sending_type == 'minutes') {
                                         $duration = $emails->sending_duration * 60;
                                     } else {
                                         if ($emails->sending_type == 'days') {
                                             $duration = $emails->sending_duration * 86400;
                                         }
                                     }
                                 }
                                 //duration is finished
                                 $cut_off_time = $each_cart->cart_abandon_time + $duration;
                                 $current_time = current_time('timestamp');
                                 if ($current_time > $cut_off_time) {
                                     @($cart_url = WC_Cart::get_cart_url());
                                     $url_to_click = esc_url_raw(add_query_arg(array('abandon_cart' => $each_cart->id, 'email_template' => $emails->id, 'old_order' => 'yes'), $cart_url));
                                     if (get_option('rac_cart_link_options') == '1') {
                                         $url_to_click = '<a style="color:' . get_option("rac_email_link_color") . '"  href="' . $url_to_click . '">' . fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text) . '</a>';
                                     } elseif (get_option('rac_cart_link_options') == '2') {
                                         $url_to_click = $url_to_click;
                                     } else {
                                         $cart_Text = fp_get_wpml_text('rac_template_' . $emails->id . '_anchor_text', $each_cart->wpml_lang, $emails->anchor_text);
                                         $url_to_click = RecoverAbandonCart::rac_cart_link_button_mode($url_to_click, $cart_Text);
                                     }
                                     //  $user = get_userdata($each_cart->user_id); NOT APPLICABLE
                                     $order_object = maybe_unserialize($each_cart->cart_details);
                                     $to = $order_object->billing_email;
                                     $user_lang = $each_cart->wpml_lang;
                                     $subject = fp_get_wpml_text('rac_template_' . $emails->id . '_subject', $each_cart->wpml_lang, $emails->subject);
                                     $firstname = $order_object->billing_first_name;
                                     $lastname = $order_object->billing_last_name;
                                     $message = fp_get_wpml_text('rac_template_' . $emails->id . '_message', $each_cart->wpml_lang, $emails->message);
                                     $message = str_replace('{rac.cartlink}', $url_to_click, $message);
                                     $subject = RecoverAbandonCart::shortcode_in_subject($firstname, $lastname, $subject);
                                     $message = str_replace('{rac.firstname}', $firstname, $message);
                                     $message = str_replace('{rac.lastname}', $lastname, $message);
                                     $message = str_replace('{rac.Productinfo}', $tablecheckproduct, $message);
                                     if (strpos($message, "{rac.coupon}")) {
                                         $coupon_code = FPRacCoupon::rac_create_coupon($order_object->billing_email, $each_cart->cart_abandon_time);
                                         $message = str_replace('{rac.coupon}', $coupon_code, $message);
                                         //replacing shortcode with coupon code
                                     }
                                     add_filter('woocommerce_email_footer_text', array('RecoverAbandonCart', 'rac_footer_email_customization'));
                                     $message = do_shortcode($message);
                                     //shortcode feature
                                     if (get_option('rac_email_use_temp_plain') != 'yes') {
                                         ob_start();
                                         if (function_exists('wc_get_template')) {
                                             wc_get_template('emails/email-header.php', array('email_heading' => $subject));
                                             echo $message;
                                             wc_get_template('emails/email-footer.php');
                                         } else {
                                             woocommerce_get_template('emails/email-header.php', array('email_heading' => $subject));
                                             echo $message;
                                             woocommerce_get_template('emails/email-footer.php');
                                         }
                                         $woo_temp_msg = ob_get_clean();
                                     } else {
                                         $woo_temp_msg = $message;
                                     }
                                     $headers = "MIME-Version: 1.0\r\n";
                                     $headers .= "Content-Type: text/html; charset=UTF-8\r\n";
                                     if ($emails->sender_opt == 'local') {
                                         $headers .= self::rac_formatted_from_address_local($emails->from_name, $emails->from_email);
                                         $headers .= "Reply-To: " . $emails->from_name . " <" . $emails->from_email . ">\r\n";
                                     } else {
                                         $headers .= self::rac_formatted_from_address_woocommerce();
                                         $headers .= "Reply-To: " . get_option('woocommerce_email_from_name') . "<" . get_option('woocommerce_email_from_address') . ">\r\n";
                                     }
                                     if ($each_cart->sending_status == 'SEND') {
                                         //condition to check start/stop mail sending
                                         if ('wp_mail' == get_option('rac_trouble_mail')) {
                                             if (self::rac_send_wp_mail($to, $subject, $woo_temp_msg, $headers)) {
                                                 // wp_mail($to, $subject, $message);
                                                 $sent_mail_templates[] = $emails->id;
                                                 $store_template_id = maybe_serialize($sent_mail_templates);
                                                 $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                                 //add to mail log
                                                 $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                                 $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                                 FPRacCounter::rac_do_mail_count();
                                             }
                                         } else {
                                             if (self::rac_send_mail($to, $subject, $woo_temp_msg, $headers)) {
                                                 // wp_mail($to, $subject, $message);
                                                 $sent_mail_templates[] = $emails->id;
                                                 $store_template_id = maybe_serialize($sent_mail_templates);
                                                 $wpdb->update($abandancart_table_name, array('mail_template_id' => $store_template_id), array('id' => $each_cart->id));
                                                 //add to mail log
                                                 $table_name_logs = $wpdb->prefix . 'rac_email_logs';
                                                 $wpdb->insert($table_name_logs, array("email_id" => $to, "date_time" => $current_time, "rac_cart_id" => $each_cart->id, "template_used" => $emails->id));
                                                 FPRacCounter::rac_do_mail_count();
                                             }
                                         }
                                     }
                                 }
                             }
                         }
                     }
                 }
             }
         }
     }
 }