Product Feed PRO for WooCommerce - Version 9.7.5

Version Description

Another recode of the lowest price variation feature

Download this release

Release Info

Developer jorisverwater
Plugin Icon 128x128 Product Feed PRO for WooCommerce
Version 9.7.5
Comparing to
See all releases

Code changes from version 9.3.7 to 9.7.5

TODO.txt CHANGED
@@ -5,18 +5,18 @@ Tutorial / Blog posts:
5
  - Explain all the different fields/attributes that can be selected from the drop-downs
6
 
7
  Priority issues:
 
8
  - License key input field needs to be a password field (asterixes)
 
9
  - Add a preview option so only 5-10 products are being generated
10
  - Own hosted plugin updating: https://rudrastyh.com/wordpress/self-hosted-plugin-update.html
11
  - Google local product feed inventory in XML format (not just TXT like it is now)
12
  - Add support for Multisites
13
  - Add a filter on review score (and amount of reviews)
14
  - Make extra woosea fields available for front-end usage
15
- - Only update feed when changes to products have been made
16
  - Add header to extra fields on product edit pages
17
  - Add possibility to create OR rules
18
  - Add support for Google My Business product feeds
19
- - Build a better WP Cron check, current one is not good enough
20
  - AMAZON integration:
21
  - requires a professional seller account, 39 dollar a month, before being able to create a developer account
22
  - only than we can use their MWS service needed to connect our plugin
5
  - Explain all the different fields/attributes that can be selected from the drop-downs
6
 
7
  Priority issues:
8
+ - Add Pinterest Tag; https://help.pinterest.com/nl/business/article/install-the-pinterest-tag
9
  - License key input field needs to be a password field (asterixes)
10
+ - A seperate FB pixel per WPML website / language
11
  - Add a preview option so only 5-10 products are being generated
12
  - Own hosted plugin updating: https://rudrastyh.com/wordpress/self-hosted-plugin-update.html
13
  - Google local product feed inventory in XML format (not just TXT like it is now)
14
  - Add support for Multisites
15
  - Add a filter on review score (and amount of reviews)
16
  - Make extra woosea fields available for front-end usage
 
17
  - Add header to extra fields on product edit pages
18
  - Add possibility to create OR rules
19
  - Add support for Google My Business product feeds
 
20
  - AMAZON integration:
21
  - requires a professional seller account, 39 dollar a month, before being able to create a developer account
22
  - only than we can use their MWS service needed to connect our plugin
classes/channels/class-google_local_products.php CHANGED
@@ -12,8 +12,8 @@ class WooSEA_google_local_products {
12
  $google_local_products = array(
13
  "Local products fields" => array(
14
  "Itemid" => array(
15
- "name" => "Itemid",
16
- "feed_name" => "g:itemid",
17
  "format" => "required",
18
  "woo_suggest" => "id",
19
  ),
12
  $google_local_products = array(
13
  "Local products fields" => array(
14
  "Itemid" => array(
15
+ "name" => "Id",
16
+ "feed_name" => "g:id",
17
  "format" => "required",
18
  "woo_suggest" => "id",
19
  ),
classes/channels/class-google_shopping.php CHANGED
@@ -356,6 +356,11 @@ class WooSEA_google_shopping {
356
  "feed_name" => "g:max_handling_time",
357
  "format" => "optional",
358
  ),
 
 
 
 
 
359
  ),
360
  "Tax" => array(
361
  "Tax" => array(
356
  "feed_name" => "g:max_handling_time",
357
  "format" => "optional",
358
  ),
359
+ "Ships from country" => array(
360
+ "name" => "ships_from_country",
361
+ "feed_name" => "g:ships_from_country",
362
+ "format" => "optional",
363
+ ),
364
  ),
365
  "Tax" => array(
366
  "Tax" => array(
classes/class-activate.php CHANGED
@@ -64,7 +64,14 @@ class WooSEA_Activation {
64
  "fields" => "google_shopping",
65
  "taxonomy" => "google_shopping",
66
  "utm_source" => "Bing Shopping",
67
- "type" => "Advertising" ),
 
 
 
 
 
 
 
68
  "Facebook Catalog Feed / Instagram" => array (
69
  "channel_hash" => md5("Facebook Remarketing"),
70
  "name" => "Facebook Catalog Feed / Instagram",
@@ -90,7 +97,7 @@ class WooSEA_Activation {
90
  "channel_hash" => md5("Snapchat Product Catalog"),
91
  "name" => "Snapchat Product Catalog",
92
  "fields" => "snapchat",
93
- "taxonomy" => "none",
94
  "utm_source" => "snapchat",
95
  "type" => "Advertising" ),
96
  ),
@@ -1112,6 +1119,13 @@ class WooSEA_Activation {
1112
  "taxonomy" => "none",
1113
  "utm_source" => "Tweakers.nl",
1114
  "type" => "Comparison shopping engine" ),
 
 
 
 
 
 
 
1115
  "Fashionchick.nl" => array (
1116
  "channel_hash" => md5("Fashionchick.nl"),
1117
  "name" => "Fashionchick.nl",
64
  "fields" => "google_shopping",
65
  "taxonomy" => "google_shopping",
66
  "utm_source" => "Bing Shopping",
67
+ "type" => "Advertising" ),
68
+ "Bing Shopping Promotions" => array (
69
+ "channel_hash" => md5("Bing Shopping Promotions"),
70
+ "name" => "Bing Shopping Promotions",
71
+ "fields" => "google_shopping_promotions",
72
+ "taxonomy" => "google_shopping_promotions",
73
+ "utm_source" => "Bing Shopping Promotions",
74
+ "type" => "Advertising" ),
75
  "Facebook Catalog Feed / Instagram" => array (
76
  "channel_hash" => md5("Facebook Remarketing"),
77
  "name" => "Facebook Catalog Feed / Instagram",
97
  "channel_hash" => md5("Snapchat Product Catalog"),
98
  "name" => "Snapchat Product Catalog",
99
  "fields" => "snapchat",
100
+ "taxonomy" => "google_shopping",
101
  "utm_source" => "snapchat",
102
  "type" => "Advertising" ),
103
  ),
1119
  "taxonomy" => "none",
1120
  "utm_source" => "Tweakers.nl",
1121
  "type" => "Comparison shopping engine" ),
1122
+ "Boetiek.nl" => array (
1123
+ "channel_hash" => md5("Boetiek.nl"),
1124
+ "name" => "Boetiek.nl",
1125
+ "fields" => "boetiek",
1126
+ "taxonomy" => "none",
1127
+ "utm_source" => "Boetiek.nl",
1128
+ "type" => "Comparison shopping engine" ),
1129
  "Fashionchick.nl" => array (
1130
  "channel_hash" => md5("Fashionchick.nl"),
1131
  "name" => "Fashionchick.nl",
classes/class-attributes.php CHANGED
@@ -48,7 +48,7 @@ private function get_dynamic_attributes(){
48
  global $wpdb;
49
  $list = array();
50
 
51
- $no_taxonomies = array("portfolio_category","portfolio_skills","portfolio_tags","nav_menu","post_format","slide-page","element_category","template_category","portfolio_category","portfolio_skills","portfolio_tags","faq_category","slide-page","yst_prominent_words","category","post_tag","nav_menu","link_category","post_format","product_type","product_visibility","product_cat","product_shipping_class","product_tag");
52
  $taxonomies = get_taxonomies();
53
  $diff_taxonomies = array_diff($taxonomies, $no_taxonomies);
54
 
@@ -205,13 +205,17 @@ public function get_mapping_attributes_dropdown() {
205
  "sku_item_group_id" => "SKU_ITEM_GROUP_ID (Facebook)",
206
  "wc_post_id_product_id" => "Wc_post_id_product_id (Facebook)",
207
  "title" => "Product name",
208
- "mother_title" => "Product name parent product",
209
  "title_hyphen" => "Product name hyphen",
 
 
210
  "title_lc" => "Product name lowercase",
 
211
  "description" => "Product description",
212
  "short_description" => "Product short description",
213
  "raw_description" => "Unfiltered product description",
214
  "raw_short_description" => "Unfiltered product short description",
 
 
215
  "price" => "Price",
216
  "regular_price" => "Regular price",
217
  "sale_price" => "Sale price",
@@ -247,9 +251,10 @@ public function get_mapping_attributes_dropdown() {
247
  "category_path" => "Category path",
248
  "category_path_short" => "Category path short",
249
  "category_path_skroutz" => "Category path Skroutz",
250
- "one_category" => "Primary category",
251
  "condition" => "Condition",
252
- "availability" => "Availability",
 
253
  "quantity" => "Quantity [Stock]",
254
  "product_type" => "Product Type",
255
  "content_type" => "Content Type",
@@ -267,7 +272,8 @@ public function get_mapping_attributes_dropdown() {
267
  "length" => "Length",
268
  "shipping" => "Shipping",
269
  "shipping_price" => "Shipping cost",
270
- "shipping_label" => "Shipping label",
 
271
  "visibility" => "Visibility",
272
  "rating_total" => "Total rating",
273
  "rating_average" => "Average rating",
@@ -350,9 +356,10 @@ public function get_mapping_attributes_dropdown() {
350
 
351
  foreach ($custom_attributes as $key => $value) {
352
  if (!preg_match("/pyre|sbg|fusion/i",$value)){
353
- if (strpos($value, 0, 1) !== "_") {
 
354
  $dropdown .= "<option value='$key'>" . ucfirst($value) . "</option>";
355
- }
356
  }
357
  }
358
 
@@ -398,15 +405,19 @@ public function get_mapping_attributes_dropdown() {
398
  "parent_sku" => "SKU parent variable product",
399
  "sku_item_group_id" => "SKU_ITEM_GROUP_ID (Facebook)",
400
  "wc_post_id_product_id" => "Wc_post_id_product_id (Facebook)",
401
- "title" => "Product name",
402
- "mother_title" => "Product name parent product",
403
- "title_hyphen" => "Product name hyphen",
 
404
  "title_lc" => "Product name lowercase",
 
405
  "description" => "Product description",
406
  "short_description" => "Product short description",
407
  "raw_description" => "Unfiltered product description",
408
  "raw_short_description" => "Unfiltered product short description",
409
- "link" => "Link",
 
 
410
  "variable_link" => "Product variable link",
411
  "add_to_cart_link" => "Add to cart link",
412
  "image" => "Main image",
@@ -429,10 +440,11 @@ public function get_mapping_attributes_dropdown() {
429
  "category_path" => "Category path",
430
  "category_path_short" => "Category path short",
431
  "category_path_skroutz" => "Category path Skroutz",
432
- "one_category" => "Primary category",
433
  "condition" => "Condition",
434
  "availability" => "Availability",
435
- "quantity" => "Quantity [Stock]",
 
436
  "price" => "Price",
437
  "regular_price" => "Regular price",
438
  "sale_price" => "Sale price",
@@ -464,7 +476,8 @@ public function get_mapping_attributes_dropdown() {
464
  "length" => "Length",
465
  "shipping" => "Shipping",
466
  "shipping_price" => "Shipping cost",
467
- "shipping_label" => "Shipping label",
 
468
  "visibility" => "Visibility",
469
  "rating_total" => "Total rating",
470
  "rating_average" => "Average rating",
48
  global $wpdb;
49
  $list = array();
50
 
51
+ $no_taxonomies = array("portfolio_category","portfolio_skills","portfolio_tags","nav_menu","post_format","slide-page","element_category","template_category","portfolio_category","portfolio_skills","portfolio_tags","faq_category","slide-page","category","post_tag","nav_menu","link_category","post_format","product_type","product_visibility","product_cat","product_shipping_class","product_tag");
52
  $taxonomies = get_taxonomies();
53
  $diff_taxonomies = array_diff($taxonomies, $no_taxonomies);
54
 
205
  "sku_item_group_id" => "SKU_ITEM_GROUP_ID (Facebook)",
206
  "wc_post_id_product_id" => "Wc_post_id_product_id (Facebook)",
207
  "title" => "Product name",
 
208
  "title_hyphen" => "Product name hyphen",
209
+ "mother_title" => "Product name parent product",
210
+ "mother_title_hyphen" => "Product name parent product hyphen",
211
  "title_lc" => "Product name lowercase",
212
+ "title_lcw" => "Product name uppercase first characters",
213
  "description" => "Product description",
214
  "short_description" => "Product short description",
215
  "raw_description" => "Unfiltered product description",
216
  "raw_short_description" => "Unfiltered product short description",
217
+ "mother_description" => "Product description parent product",
218
+ "mother_short_description" => "Product short description parent product",
219
  "price" => "Price",
220
  "regular_price" => "Regular price",
221
  "sale_price" => "Sale price",
251
  "category_path" => "Category path",
252
  "category_path_short" => "Category path short",
253
  "category_path_skroutz" => "Category path Skroutz",
254
+ "one_category" => "Yoast primary category",
255
  "condition" => "Condition",
256
+ "availability" => "Availability",
257
+ "stock_status" => "Stock Status WooCommerce",
258
  "quantity" => "Quantity [Stock]",
259
  "product_type" => "Product Type",
260
  "content_type" => "Content Type",
272
  "length" => "Length",
273
  "shipping" => "Shipping",
274
  "shipping_price" => "Shipping cost",
275
+ "shipping_label" => "Shipping class slug",
276
+ "shipping_label_name" => "Shipping class name",
277
  "visibility" => "Visibility",
278
  "rating_total" => "Total rating",
279
  "rating_average" => "Average rating",
356
 
357
  foreach ($custom_attributes as $key => $value) {
358
  if (!preg_match("/pyre|sbg|fusion/i",$value)){
359
+ $value = ltrim($value);
360
+ if (!empty($value)){
361
  $dropdown .= "<option value='$key'>" . ucfirst($value) . "</option>";
362
+ }
363
  }
364
  }
365
 
405
  "parent_sku" => "SKU parent variable product",
406
  "sku_item_group_id" => "SKU_ITEM_GROUP_ID (Facebook)",
407
  "wc_post_id_product_id" => "Wc_post_id_product_id (Facebook)",
408
+ "title" => "Product name",
409
+ "title_hyphen" => "Product name hyphen",
410
+ "mother_title" => "Product name parent product",
411
+ "mother_title_hyphen" => "Product name parent product hyphen",
412
  "title_lc" => "Product name lowercase",
413
+ "title_lcw" => "Product name uppercase first characters",
414
  "description" => "Product description",
415
  "short_description" => "Product short description",
416
  "raw_description" => "Unfiltered product description",
417
  "raw_short_description" => "Unfiltered product short description",
418
+ "mother_description" => "Product description parent product",
419
+ "mother_short_description" => "Product short description parent product",
420
+ "link" => "Link",
421
  "variable_link" => "Product variable link",
422
  "add_to_cart_link" => "Add to cart link",
423
  "image" => "Main image",
440
  "category_path" => "Category path",
441
  "category_path_short" => "Category path short",
442
  "category_path_skroutz" => "Category path Skroutz",
443
+ "one_category" => "Yoast primary category",
444
  "condition" => "Condition",
445
  "availability" => "Availability",
446
+ "stock_status" => "Stock Status WooCommerce",
447
+ "quantity" => "Quantity [Stock]",
448
  "price" => "Price",
449
  "regular_price" => "Regular price",
450
  "sale_price" => "Sale price",
476
  "length" => "Length",
477
  "shipping" => "Shipping",
478
  "shipping_price" => "Shipping cost",
479
+ "shipping_label" => "Shipping class slug",
480
+ "shipping_label_name" => "Shipping class name",
481
  "visibility" => "Visibility",
482
  "rating_total" => "Total rating",
483
  "rating_average" => "Average rating",
classes/class-get-products.php CHANGED
@@ -26,7 +26,6 @@ class WooSEA_Get_Products {
26
  return "<![CDATA[ $string ]]>";
27
  }
28
 
29
-
30
  /**
31
  * Check if a plugin is active
32
  */
@@ -57,6 +56,11 @@ class WooSEA_Get_Products {
57
  * Get all approved product review comments for Google's Product Review Feeds
58
  */
59
  public function woosea_get_reviews ( $product_data, $product ) {
 
 
 
 
 
60
  $approved_reviews = array();
61
  $prod_id = $product_data['id'];
62
 
@@ -84,8 +88,10 @@ class WooSEA_Get_Products {
84
  $cnt = 0;
85
  $name = "";
86
  foreach($name_pieces as $n_piece){
 
 
87
  if($cnt > 0){
88
- $n_piece = substr($n_piece, 0, 1);
89
  }
90
  $name .= $n_piece." ";
91
  $cnt++;
@@ -96,7 +102,7 @@ class WooSEA_Get_Products {
96
  $review['reviewer_name'] = html_entity_decode((str_replace("\r", "", $review['reviewer_name'])), ENT_QUOTES | ENT_XML1, 'UTF-8');
97
  $review['reviewer_name'] = preg_replace( '/\[(.*?)\]/', ' ', $review['reviewer_name'] );
98
  $review['reviewer_name'] = str_replace("&#xa0;", "", $review['reviewer_name']);
99
- $review['reviewer_name'] = $this->woosea_utf8_for_xml( $review['reviewer_name'] );
100
 
101
  $review['reviewer_id'] = $review_raw->user_id;
102
  $review['review_timestamp'] = $review_raw->comment_date;
@@ -324,7 +330,7 @@ class WooSEA_Get_Products {
324
  /**
325
  * Get category path (needed for Prisjakt)
326
  */
327
- public function woosea_get_term_parents( $id, $taxonomy, $link = false, $project_taxonomy, $nicename = false, $visited = array() ) {
328
  // Only add Home to the beginning of the chain when we start buildin the chain
329
  if(empty($visited)){
330
  $chain = 'Home';
@@ -931,6 +937,16 @@ class WooSEA_Get_Products {
931
  unset($shipping_cost);
932
  }
933
  }
 
 
 
 
 
 
 
 
 
 
934
  }
935
 
936
  if(isset($zone_details)){
@@ -957,12 +973,9 @@ class WooSEA_Get_Products {
957
  $zone_details['price'] = trim($shipping_cost);
958
  }
959
  } else {
960
- // $shipping_cost = 0;
961
  if(isset($shipping_cost)){
962
  $zone_details['price'] = trim($currency." ".$shipping_cost);
963
  }
964
- //unset($zone_details);
965
- //unset($shipping_cost);
966
  }
967
  }
968
  }
@@ -992,12 +1005,19 @@ class WooSEA_Get_Products {
992
 
993
  // Remove other shipping classes when free shipping is relevant
994
  $free_check = "yes";
995
- //$free_check = get_option ('free_shipping');
996
 
997
  if(in_array($free_check, array_column($shipping_arr, 'free'))) { // search value in the array
998
  foreach($shipping_arr as $k => $v) {
999
  if(!in_array($free_check, $v)){
1000
- unset($shipping_arr[$k]);
 
 
 
 
 
 
 
 
1001
  }
1002
  }
1003
  }
@@ -1005,8 +1025,6 @@ class WooSEA_Get_Products {
1005
  // Fix empty services
1006
  foreach($shipping_arr as $k => $v){
1007
  if(empty($v['service'])){
1008
- // $lalala = get_option( 'woocommerce_default_country' );
1009
- // $shipping_arr[$k]['country'] = get_option( 'woocommerce_default_country' );
1010
  unset($shipping_arr[$k]);
1011
  }
1012
  }
@@ -1145,16 +1163,19 @@ class WooSEA_Get_Products {
1145
  } elseif (preg_match("/g:product_detail/i",$k)){
1146
  if(!empty($v)){
1147
  $product_detail_split = explode("#", $v);
1148
- $product_detail = $product->addChild('g:product_detail', '', $namespace['g']);
1149
- $name = str_replace("_", " ", $product_detail_split[0]);
1150
-
1151
- $section_name = explode(":", $name);
1152
- $section_name_start = ucfirst($section_name[0]);
1153
- $name = ucfirst(trim($section_name[1]));
1154
-
1155
- $section_name = $product_detail->addChild('g:section_name', "General", $namespace['g']);
1156
- $product_detail_name = $product_detail->addChild('g:attribute_name', $section_name_start, $namespace['g']);
1157
- $product_detail_value = $product_detail->addChild('g:attribute_value', $product_detail_split[1], $namespace['g']);
 
 
 
1158
  }
1159
  } elseif ($k == "g:installment"){
1160
  if(!empty($v)){
@@ -1993,7 +2014,7 @@ class WooSEA_Get_Products {
1993
  $xml_piece = "";
1994
 
1995
  // Get taxonomies
1996
- $no_taxonomies = array("element_category","template_category","portfolio_category","portfolio_skills","portfolio_tags","faq_category","slide-page","yst_prominent_words","category","post_tag","nav_menu","link_category","post_format","product_type","product_visibility","product_cat","product_shipping_class","product_tag");
1997
  $taxonomies = get_taxonomies();
1998
  $diff_taxonomies = array_diff($taxonomies, $no_taxonomies);
1999
 
@@ -2325,6 +2346,10 @@ class WooSEA_Get_Products {
2325
  $product_data['raw_description'] = substr($product_data['raw_description'], 0, 5000);
2326
  $product_data['raw_short_description'] = substr($product_data['raw_short_description'], 0, 5000);
2327
 
 
 
 
 
2328
  /**
2329
  * Check of we need to add Google Analytics UTM parameters
2330
  */
@@ -2358,6 +2383,7 @@ class WooSEA_Get_Products {
2358
  * Therefor, we need to check the stock_status and overwrite te availability value
2359
  */
2360
  $stock_status = $product->get_stock_status();
 
2361
  if ($stock_status == "outofstock"){
2362
  $product_data['availability'] = "out of stock";
2363
  } elseif ($stock_status == "onbackorder") {
@@ -2439,6 +2465,10 @@ class WooSEA_Get_Products {
2439
  }
2440
 
2441
  $product_data['shipping_label'] = $product->get_shipping_class();
 
 
 
 
2442
 
2443
  // Get product prices
2444
  $product_data['price'] = wc_get_price_including_tax($product, array('price'=> $product->get_price()));
@@ -2451,7 +2481,8 @@ class WooSEA_Get_Products {
2451
  // Untouched raw system pricing - DO NOT CHANGE THESE
2452
  $product_data['system_net_price'] = round(wc_get_price_excluding_tax( $product ), 2);
2453
  $product_data['system_net_price'] = wc_format_decimal($product_data['system_net_price'],2);
2454
- $product_data['system_regular_price'] = round($product->get_regular_price(),2);
 
2455
  $product_data['system_regular_price'] = wc_format_decimal($product_data['system_regular_price'],2);
2456
 
2457
  $product_data['system_price'] = wc_get_price_including_tax($product, array('price'=> $product->get_price()));
@@ -2485,6 +2516,7 @@ class WooSEA_Get_Products {
2485
  if($product->get_type() == "bundle"){
2486
  if ($this->woosea_is_plugin_active('woocommerce-product-bundles/woocommerce-product-bundles.php')){
2487
  $product_data['price'] = get_post_meta($product_data['id'], '_price', true);
 
2488
  if(is_numeric($tax_rates[1]['rate'])){
2489
  $product_data['price_forced'] = round(get_post_meta($product_data['id'], '_price', true) * (100+$tax_rates[1]['rate'])/100,2);
2490
  $product_data['regular_price'] = round(get_post_meta($product_data['id'], '_regular_price', true) * (100+$tax_rates[1]['rate'])/100,2);
@@ -2582,6 +2614,7 @@ class WooSEA_Get_Products {
2582
  $discount = apply_filters('advanced_woo_discount_rules_get_product_discount_price_from_custom_price', false, $product, 1, $product_data['sale_price'], 'discounted_price', true, true);
2583
  if($discount !== false){
2584
  $product_data['sale_price'] = $discount;
 
2585
  $price_incl_tax = get_option( 'woocommerce_prices_include_tax' );
2586
  if($price_incl_tax == "yes"){
2587
  $product_data['price_forced'] = $product_data['price']*($fullrate/100);
@@ -2722,9 +2755,12 @@ class WooSEA_Get_Products {
2722
  $product_data['system_sale_price'] = wc_format_localized_price($product_data['system_sale_price']);
2723
 
2724
  // Add rounded price options
2725
- $product_data['rounded_price'] = round($product_data['price']);
2726
- $product_data['rounded_regular_price'] = round($product_data['regular_price']);
2727
- $product_data['rounded_sale_price'] = round($product_data['sale_price']);
 
 
 
2728
 
2729
  // Calculate discount percentage
2730
  if($product_data['sale_price'] > 0){
@@ -2742,7 +2778,7 @@ class WooSEA_Get_Products {
2742
  }
2743
  }
2744
 
2745
- if ((array_key_exists('shipping', $project_config['attributes'])) OR (array_key_exists('shipping_price', $project_config['attributes'])) OR ($project_config['fields'] == "trovaprezzi")){
2746
  $product_data['shipping'] = $this->woosea_get_shipping_cost($class_cost_id, $project_config, $product_data['price'], $tax_rates, $shipping_zones, $product_data['id'], $product_data['item_group_id']);
2747
  $shipping_str = $product_data['shipping'];
2748
  }
@@ -2838,7 +2874,7 @@ class WooSEA_Get_Products {
2838
 
2839
  foreach($diff_taxonomies as $taxo){
2840
  $term_value = get_the_terms($product_data['id'], $taxo);
2841
- $product_data[$taxo] = "";
2842
 
2843
  if(is_array($term_value)){
2844
  // Do not add variation values to the feed when they are out of stock
@@ -2848,7 +2884,7 @@ class WooSEA_Get_Products {
2848
  $variations = $product_skroutz->get_available_variations();
2849
  $variations_id = wp_list_pluck( $variations, 'variation_id' );
2850
  $skroutz_att_array = array();
2851
-
2852
  foreach($variations_id as $var_id){
2853
  $stock_value = get_post_meta( $var_id, "_stock_status", true );
2854
  if($stock_value == "instock"){
@@ -2862,7 +2898,6 @@ class WooSEA_Get_Products {
2862
  $product_data[$taxo] = rtrim($product_data[$taxo],',');
2863
  }
2864
  }
2865
-
2866
  foreach($skroutz_att_array as $skrtz_value){
2867
  $product_data[$taxo] .= ",". $skrtz_value;
2868
  }
@@ -2977,7 +3012,7 @@ class WooSEA_Get_Products {
2977
  $data = $wpdb->get_results($sql);
2978
  if (count($data)) {
2979
  foreach ($data as $key => $value) {
2980
- $value_display = str_replace("_", " ",$value->name);
2981
  if (preg_match("/_product_attributes/i",$value->name)){
2982
  $product_attr = unserialize($value->type);
2983
  if(!empty($product_attr)){
@@ -2995,14 +3030,14 @@ class WooSEA_Get_Products {
2995
 
2996
  /**
2997
  * Get Product Attributes for Single products
 
2998
  */
2999
- if (($product->is_type('simple')) OR ($product->is_type('external')) OR ($product->is_type('mix-and-match')) OR ($product->is_type('bundle')) OR ($product->is_type('composite')) OR ($product->is_type('auction') OR ($product->is_type('subscription')))){
3000
  $single_attributes = $product->get_attributes();
3001
-
3002
  foreach ($single_attributes as $attribute){
3003
- $attr_name = strtolower($attribute->get_name());
3004
- $attr_value = $product->get_attribute($attr_name);
3005
- $product_data[$attr_name] = $attr_value;
3006
  }
3007
  }
3008
 
@@ -3028,9 +3063,9 @@ class WooSEA_Get_Products {
3028
  $product_variations = new WC_Product_Variation( $product_data['id'] );
3029
  $variations = $product_variations->get_variation_attributes();
3030
 
3031
- // For Skroutz apparal products we can only append colours to the product name
3032
  // When a product has both a size and color attribute we assume its an apparal product
3033
- if($project_config['fields'] == "skroutz"){
3034
  $size_found = "no";
3035
  $color_found = "no";
3036
 
@@ -3106,23 +3141,28 @@ class WooSEA_Get_Products {
3106
  }
3107
  }
3108
 
3109
-
3110
-
3111
  if((isset($project_config['lowest_price_variations'])) OR (isset($project_config['default_variations']))){
3112
-
3113
  // Determine the default variation product
3114
  if( ($product_data['item_group_id'] > 0) AND (is_object(wc_get_product( $product_data['item_group_id']))) AND (($product_data['product_type'] == "variation") OR ($product_data['product_type'] == "subscription_variation"))){
3115
  $mother_product = wc_get_product($product_data['item_group_id']);
3116
  $def_attributes = $mother_product->get_default_attributes();
3117
 
3118
  if(isset($project_config['lowest_price_variations'])){
3119
-
3120
  // Determine lowest priced variation
3121
  $variation_min_price = $mother_product->get_variation_price('min');
3122
  $variation_min_price = wc_format_decimal($variation_min_price,2);
3123
  $variation_min_price = wc_format_localized_price($variation_min_price);
 
 
 
 
 
 
 
 
3124
 
3125
- if($product_data['system_net_price'] == $variation_min_price){
3126
  $variation_pass = "true";
3127
  } else {
3128
  $variation_pass = "false";
@@ -3260,19 +3300,21 @@ class WooSEA_Get_Products {
3260
  /**
3261
  * Although this is a product variation we also need to grap the Dynamic attributes belonging to the simple mother prodict
3262
  */
 
 
3263
  foreach($diff_taxonomies as $taxo){
3264
  $term_value = get_the_terms($product_data['item_group_id'], $taxo);
3265
  unset($product_data[$taxo]);
3266
  if(is_array($term_value)){
3267
  foreach($term_value as $term){
3268
  if(empty($product_data[$taxo])){
3269
- $product_data[$taxo] = $term->name;
3270
  } else {
3271
- $product_data[$taxo] .= " ".$term->name;
3272
  }
3273
  }
3274
  }
3275
- }
3276
 
3277
  /**
3278
  * Add product tags to the product data array
@@ -3292,6 +3334,7 @@ class WooSEA_Get_Products {
3292
 
3293
  // Add attribute values to the variation product names to make them unique
3294
  $product_data['title_hyphen'] = $product_data['title']." - ";
 
3295
 
3296
  foreach($variations as $kk => $vv){
3297
  $custom_key = $kk;
@@ -3440,6 +3483,8 @@ class WooSEA_Get_Products {
3440
  * we will add CDATA brackets to the title and description attributes
3441
  */
3442
  $product_data['title_lc'] = ucfirst(strtolower($product_data['title']));
 
 
3443
  //$product_data['description'] = $this->woosea_append_cdata ( $product_data['description'] );
3444
  //$product_data['short_description'] = $this->woosea_append_cdata ( $product_data['short_description'] );
3445
 
@@ -3448,6 +3493,17 @@ class WooSEA_Get_Products {
3448
  */
3449
  $product_data['reviews'] = $this->woosea_get_reviews( $product_data, $product );
3450
 
 
 
 
 
 
 
 
 
 
 
 
3451
  /**
3452
  * Check if individual products need to be excluded
3453
  */
@@ -3513,16 +3569,19 @@ class WooSEA_Get_Products {
3513
  // For these channels parent products are allowed
3514
  $allowed_channel_parents = array(
3515
  "skroutz",
 
3516
  "google_dsa",
3517
  "google_product_review",
3518
  );
3519
 
3520
- if (!in_array($project_config['fields'], $allowed_channel_parents)){
3521
- if(($product->is_type('variable')) AND ($product_data['item_group_id'] == 0)){
3522
- $product_data = array();
3523
- $product_data = null;
3524
- }
3525
- }
 
 
3526
 
3527
  /**
3528
  * Remove variation products that are not THE default variation product
@@ -3549,6 +3608,51 @@ class WooSEA_Get_Products {
3549
  }
3550
  }
3551
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
3552
  /**
3553
  * When product has passed the filter rules it can continue with the rest
3554
  */
@@ -3582,7 +3686,7 @@ class WooSEA_Get_Products {
3582
  }
3583
  } else {
3584
  if((strlen($attr_value['mapfrom'])) AND (array_key_exists($attr_value['mapfrom'], $product_data))){
3585
- if(($attr_value['attribute'] == "g:link") OR ($attr_value['attribute'] == "g:link_template") OR ($attr_value['attribute'] == "g:image_link") OR ($attr_value['attribute'] == "link") OR ($attr_value['attribute'] == "Final URL") OR ($attr_value['attribute'] == "SKU")){
3586
  $attr_line = "'".$attr_value['prefix']."".$product_data[$attr_value['mapfrom']]."".$attr_value['suffix']."'";
3587
  } else {
3588
  $attr_line = "'".$attr_value['prefix']. "".$product_data[$attr_value['mapfrom']]."" .$attr_value['suffix']."'";
@@ -3654,7 +3758,7 @@ class WooSEA_Get_Products {
3654
  }
3655
  } else {
3656
  if(strlen($product_data[$attr_value['mapfrom']])){
3657
- if(($attr_value['attribute'] == "g:link") OR ($attr_value['attribute'] == "g:link_template") OR ($attr_value['attribute'] == "g:image_link") OR ($attr_value['attribute'] == "link") OR ($attr_value['attribute'] == "Final URL") OR ($attr_value['attribute'] == "SKU")){
3658
  if(($product_data['product_type'] == "variation") AND (preg_match("/aelia_cs_currency/", $attr_value['suffix']))){
3659
  $attr_value['suffix'] = str_replace("?","&",$attr_value['suffix']);
3660
  $attr_line .= ",'".$attr_value['prefix']."".$product_data[$attr_value['mapfrom']]."".$attr_value['suffix']."'";
@@ -3874,7 +3978,7 @@ class WooSEA_Get_Products {
3874
  }
3875
  } else {
3876
  if(strlen($product_data[$attr_value['mapfrom']])){
3877
- if(($attr_value['attribute'] == "g:link") OR ($attr_value['attribute'] == "link") OR ($attr_value['attribute'] == "g:link_template")){
3878
  if(($product_data['product_type'] == "variation") AND (preg_match("/aelia_cs_currency/", $attr_value['suffix']))){
3879
  $attr_value['suffix'] = str_replace("?","&",$attr_value['suffix']);
3880
  $xml_product[$attr_value['attribute']] = "$attr_value[prefix]". $product_data[$attr_value['mapfrom']] ."$attr_value[suffix]";
@@ -4404,479 +4508,482 @@ class WooSEA_Get_Products {
4404
  return $product_data;
4405
  }
4406
 
4407
- /**
4408
- * Execute project rules
4409
- */
4410
  private function woocommerce_sea_rules( $project_rules2, $product_data ){
4411
- $aantal_prods = count($product_data);
4412
- if($aantal_prods > 0){
4413
 
4414
- foreach ($project_rules2 as $pr_key => $pr_array){
4415
 
4416
- foreach ($product_data as $pd_key => $pd_value){
4417
 
4418
- // Check is there is a rule on specific attributes
4419
- if($pd_key == $pr_array['attribute']){
4420
 
4421
- // This is because for data manipulation the than attribute is empty
4422
- if(!array_key_exists('than_attribute', $pr_array)){
4423
- $pr_array['than_attribute'] = $pd_key;
4424
- }
4425
 
4426
  // Check if a rule has been set for Google categories
4427
  if (!empty($product_data['categories']) AND ($pr_array['than_attribute'] == "google_category") AND ($product_data[$pr_array['attribute']] == $pr_array['criteria'])){
4428
-
4429
- $pr_array['than_attribute'] = "categories";
4430
  $category_id = explode("-", $pr_array['newvalue']);
4431
  $pr_array['newvalue'] = $category_id[0];
4432
- $product_data['categories'] = $pr_array['newvalue'];
4433
- }
4434
 
4435
- // Make sure that rules on numerics are on true numerics
4436
- if (!is_array($pd_value) AND (!preg_match('/[A-Za-z]/', $pd_value))){
4437
- $pd_value = strtr($pd_value, ',', '.');
4438
- }
4439
 
4440
 
4441
- // Make sure the price or sale price is numeric
4442
- if(($pr_array['attribute'] == "sale_price") OR ($pr_array['attribute'] == "price")){
4443
- settype($pd_value, "double");
4444
- }
4445
 
4446
- if (((is_numeric($pd_value)) AND ($pr_array['than_attribute'] != "shipping"))){
4447
 
4448
- // Rules for numeric values
4449
- switch ($pr_array['condition']) {
4450
- case($pr_array['condition'] = "contains"):
4451
- if ((preg_match('/'.$pr_array['criteria'].'/', $pd_value))){
4452
- $product_data[$pr_array['than_attribute']] = str_replace($pr_array['criteria'], $pr_array['newvalue'], $pd_value);
4453
- }
4454
- break;
4455
- case($pr_array['condition'] = "containsnot"):
4456
- if ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value))){
4457
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4458
- }
4459
- break;
4460
- case($pr_array['condition'] = "="):
4461
- if (($pd_value == $pr_array['criteria'])){
4462
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4463
- }
4464
- break;
4465
- case($pr_array['condition'] = "!="):
4466
- if (($pd_value != $pr_array['criteria'])){
4467
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4468
- }
4469
- break;
4470
- case($pr_array['condition'] = ">"):
4471
- if (($pd_value > $pr_array['criteria'])){
4472
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4473
- }
4474
- break;
4475
- case($pr_array['condition'] = ">="):
4476
- if (($pd_value >= $pr_array['criteria'])){
4477
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4478
- }
4479
- break;
4480
- case($pr_array['condition'] = "<"):
4481
- if (($pd_value < $pr_array['criteria'])){
4482
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4483
- }
4484
- break;
4485
- case($pr_array['condition'] = "=<"):
4486
- if (($pd_value <= $pr_array['criteria'])){
4487
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4488
- }
4489
- break;
4490
- case($pr_array['condition'] = "empty"):
4491
- if(empty($product_data[$pr_array['attribute']])){
4492
- if ((strlen($pd_value) < 1)){
4493
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4494
- } else {
4495
- $product_data[$pr_array['attribute']] = $product_data[$pr_array['than_attribute']];
4496
- }
4497
- }
4498
- break;
4499
- case($pr_array['condition'] = "multiply"):
4500
- $pr_array['criteria'] = strtr($pr_array['criteria'], ',', '.');
4501
- $convert_back = "false";
4502
- $pos = strpos($pd_value, ',');
4503
- if($pos !== false){
4504
- $convert_back = "true";
4505
- }
4506
- $pd_value = strtr($pd_value, ',', '.');
4507
- $newvalue = $pd_value*$pr_array['criteria'];
4508
- $newvalue = round($newvalue, 2);
4509
- if($convert_back == "true"){
4510
- $newvalue = strtr($newvalue, '.',',');
4511
- }
4512
- $product_data[$pr_array['attribute']] = $newvalue;
4513
- break;
4514
- case($pr_array['condition'] = "divide"):
4515
- $newvalue = ($pd_value / $pr_array['criteria']);
4516
- $newvalue = round($newvalue, 2);
4517
- $newvalue = strtr($newvalue, '.',',');
4518
- $product_data[$pr_array['attribute']] = $newvalue;
4519
- break;
4520
- case($pr_array['condition'] = "plus"):
4521
- $newvalue = ($pd_value + $pr_array['criteria']);
4522
- $product_data[$pr_array['attribute']] = $newvalue;
4523
- break;
4524
- case($pr_array['condition'] = "minus"):
4525
- $newvalue = ($pd_value - $pr_array['criteria']);
4526
- $product_data[$pr_array['attribute']] = $newvalue;
4527
- break;
4528
- case($pr_array['condition'] = "findreplace"):
4529
- if (strpos($pd_value, $pr_array['criteria']) !== false){
4530
  // Make sure that a new value has been set
4531
- if(!empty($pr_array['newvalue'])){
4532
- // Find and replace only work on same attribute field, otherwise create a contains rule
4533
  if($pr_array['attribute'] == $pr_array['than_attribute']){
4534
  $newvalue = str_replace($pr_array['criteria'],$pr_array['newvalue'], $pd_value);
4535
  $product_data[$pr_array['than_attribute']] = ucfirst($newvalue);
4536
  }
4537
- }
4538
- }
4539
- break;
4540
- default:
4541
- break;
4542
- }
4543
- } elseif (is_array($pd_value)) {
4544
-
4545
- // For now only shipping details are in an array
4546
- foreach ($pd_value as $k => $v){
4547
- if(is_array($v)){
4548
- foreach ($v as $kk => $vv){
4549
- // Only shipping detail rule can be on price for now
4550
- if($kk == "price"){
4551
- switch ($pr_array['condition']) {
4552
- case($pr_array['condition'] = "contains"):
4553
- if ((preg_match('/'.$pr_array['criteria'].'/', $vv))){
4554
- $pd_value[$k]['price'] = str_replace($pr_array['criteria'], $pr_array['newvalue'], $vv);
4555
- $product_data[$pr_array['than_attribute']] = $pd_value;
4556
- }
4557
- break;
4558
- case($pr_array['condition'] = "containsnot"):
4559
- if ((!preg_match('/'.$pr_array['criteria'].'/', $vv))){
4560
- $pd_value[$k]['price'] = $pr_array['newvalue'];
4561
- $product_data[$pr_array['than_attribute']] = $pd_value;
4562
- }
4563
- break;
4564
- case($pr_array['condition'] = "="):
4565
- if (($vv == $pr_array['criteria'])){
4566
- $pd_value[$k]['price'] = $pr_array['newvalue'];
4567
- $product_data[$pr_array['than_attribute']] = $pd_value;
4568
- }
4569
- break;
4570
- case($pr_array['condition'] = "!="):
4571
- if (($vv != $pr_array['criteria'])){
4572
- $pd_value[$k]['price'] = $pr_array['newvalue'];
4573
- $product_data[$pr_array['than_attribute']] = $pd_value;
4574
- }
4575
- break;
4576
- case($pr_array['condition'] = ">"):
4577
- if (($vv > $pr_array['criteria'])){
4578
- $pd_value[$k]['price'] = $pr_array['newvalue'];
4579
- $product_data[$pr_array['than_attribute']] = $pd_value;
4580
- }
4581
- break;
4582
- case($pr_array['condition'] = ">="):
4583
- if (($vv >= $pr_array['criteria'])){
4584
- $pd_value[$k]['price'] = $pr_array['newvalue'];
4585
- $product_data[$pr_array['than_attribute']] = $pd_value;
4586
- }
4587
- break;
4588
- case($pr_array['condition'] = "<"):
4589
- if (($vv < $pr_array['criteria'])){
4590
- $pd_value[$k]['price'] = $pr_array['newvalue'];
4591
- $product_data[$pr_array['than_attribute']] = $pd_value;
4592
- }
4593
- break;
4594
- case($pr_array['condition'] = "=<"):
4595
- if (($vv <= $pr_array['criteria'])){
4596
- $pd_value[$k]['price'] = $pr_array['newvalue'];
4597
- $product_data[$pr_array['than_attribute']] = $pd_value;
4598
- }
4599
- break;
4600
- case($pr_array['condition'] = "empty"):
4601
- if ((strlen($vv) < 1)){
4602
- $pd_value[$k]['price'] = $pr_array['newvalue'];
4603
- $product_data[$pr_array['than_attribute']] = $pd_value;
4604
- }
4605
- break;
4606
- case($pr_array['condition'] = "multiply"):
4607
- // Only shipping array
4608
- if(is_array($pd_value)){
4609
- $pr_array['criteria'] = strtr($pr_array['criteria'], ',', '.');
4610
- foreach ($pd_value as $ship_a_key => $shipping_arr){
4611
- foreach($shipping_arr as $ship_key => $ship_value){
4612
- if($ship_key == "price"){
4613
- $ship_pieces = explode(" ", $ship_value);
4614
- $pd_value = strtr($ship_pieces[1], ',', '.');
4615
- $newvalue = $pd_value*$pr_array['criteria'];
4616
- $newvalue = round($newvalue, 2);
4617
- $newvalue = strtr($newvalue, '.',',');
4618
- $newvalue = $ship_pieces[0]." ".$newvalue;
4619
- $product_data[$pr_array['than_attribute']][$ship_a_key]['price'] = $newvalue;
4620
- }
4621
- }
4622
- }
4623
- }
4624
- break;
4625
- default:
4626
- break;
4627
- }
4628
- }
4629
- }
4630
- } else {
4631
- // Rules on product tags
4632
- foreach ($pd_value as $k => $v){
4633
-
4634
- // Rules for string values
4635
- if (!array_key_exists('cs', $pr_array)){
4636
- $v = strtolower($v);
4637
- $pr_array['criteria'] = strtolower($pr_array['criteria']);
4638
- }
4639
-
4640
- switch ($pr_array['condition']) {
4641
- case($pr_array['condition'] = "contains"):
4642
- if ((preg_match('/'.$pr_array['criteria'].'/', $v))){
4643
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4644
- }
4645
- break;
4646
- case($pr_array['condition'] = "containsnot"):
4647
- if ((!preg_match('/'.$pr_array['criteria'].'/', $v))){
4648
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4649
- }
4650
- break;
4651
- case($pr_array['condition'] = "="):
4652
- if (($v == $pr_array['criteria'])){
4653
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4654
- }
4655
- break;
4656
- case($pr_array['condition'] = "!="):
4657
- if (($v != $pr_array['criteria'])){
4658
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4659
- }
4660
- break;
4661
- case($pr_array['condition'] = ">"):
4662
- if (($v > $pr_array['criteria'])){
4663
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4664
- }
4665
- break;
4666
- case($pr_array['condition'] = ">="):
4667
- if (($v >= $pr_array['criteria'])){
4668
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4669
- }
4670
- break;
4671
- case($pr_array['condition'] = "<"):
4672
- if (($v < $pr_array['criteria'])){
4673
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4674
- }
4675
- break;
4676
- case($pr_array['condition'] = "=<"):
4677
- if (($v <= $pr_array['criteria'])){
4678
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4679
- }
4680
- break;
4681
- case($pr_array['condition'] = "empty"):
4682
- if ((strlen($v) < 1)){
4683
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4684
- }
4685
- break;
4686
- case($pr_array['condition'] = "multiply"):
4687
- // Only shipping array
4688
- if(is_array($v)){
4689
- $pr_array['criteria'] = strtr($pr_array['criteria'], ',', '.');
4690
- foreach ($v as $ship_a_key => $shipping_arr){
4691
- foreach($shipping_arr as $ship_key => $ship_value){
4692
- if($ship_key == "price"){
4693
- $ship_pieces = explode(" ", $ship_value);
4694
- $pd_value = strtr($ship_pieces[1], ',', '.');
4695
- $newvalue = $pd_value*$pr_array['criteria'];
4696
- $newvalue = round($newvalue, 2);
4697
- $newvalue = strtr($newvalue, '.',',');
4698
- $newvalue = $ship_pieces[0]." ".$newvalue;
4699
- $product_data[$pr_array['than_attribute']][$ship_a_key]['price'] = $newvalue;
4700
- }
4701
- }
4702
- }
4703
- }
4704
- break;
4705
- default:
4706
- break;
4707
- }
4708
- }
4709
- }
4710
- }
4711
- } else {
4712
- // Rules for string values
4713
  if (!array_key_exists('cs', $pr_array)){
4714
- $pd_value = strtolower($pd_value);
4715
- $pr_array['criteria'] = strtolower($pr_array['criteria']);
4716
- }
4717
-
4718
- switch ($pr_array['condition']) {
4719
- case($pr_array['condition'] = "contains"):
4720
- if ((preg_match('/'.$pr_array['criteria'].'/', $pd_value))){
4721
- // Specifically for shipping price rules
4722
- if(!empty($product_data[$pr_array['than_attribute']])){
4723
- if(is_array($product_data[$pr_array['than_attribute']])){
4724
- $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4725
- for ($x = 0; $x <= $arr_size; $x++) {
4726
- $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4727
- }
4728
- } else {
4729
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4730
- }
4731
- } else {
4732
- // This attribute value is empty for this product
4733
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4734
- }
4735
- }
4736
- break;
4737
- case($pr_array['condition'] = "containsnot"):
4738
- if ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value))){
4739
- // Specifically for shipping price rules
4740
- if(is_array($product_data[$pr_array['than_attribute']])){
4741
- $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4742
- for ($x = 0; $x <= $arr_size; $x++) {
4743
- $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4744
- }
4745
- } else {
4746
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4747
- }
4748
- }
4749
- break;
4750
- case($pr_array['condition'] = "="):
4751
- if (($pr_array['criteria'] == "$pd_value")){
4752
- // Specifically for shipping price rules
4753
- if(is_array($product_data[$pr_array['than_attribute']])){
4754
- $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4755
- for ($x = 0; $x <= $arr_size; $x++) {
4756
- $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4757
- }
4758
- } else {
4759
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4760
- }
4761
- }
4762
- $ship = $product_data['shipping'];
4763
- break;
4764
- case($pr_array['condition'] = "!="):
4765
- if (($pr_array['criteria'] != "$pd_value")){
4766
- // Specifically for shipping price rules
4767
- if(is_array($product_data[$pr_array['than_attribute']])){
4768
- $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4769
- for ($x = 0; $x <= $arr_size; $x++) {
4770
- $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4771
- }
4772
- } else {
4773
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4774
- }
4775
- }
4776
- break;
4777
- case($pr_array['condition'] = ">"):
4778
- // Use a lexical order on relational string operators
4779
- if (($pd_value > $pr_array['criteria'])){
4780
- // Specifically for shipping price rules
4781
- if(is_array($product_data[$pr_array['than_attribute']])){
4782
- $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4783
- for ($x = 0; $x <= $arr_size; $x++) {
4784
- $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4785
- }
4786
- } else {
4787
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4788
- }
4789
- }
4790
- break;
4791
- case($pr_array['condition'] = ">="):
4792
- // Use a lexical order on relational string operators
4793
- if (($pd_value >= $pr_array['criteria'])){
4794
- // Specifically for shipping price rules
4795
- if(is_array($product_data[$pr_array['than_attribute']])){
4796
- $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4797
- for ($x = 0; $x <= $arr_size; $x++) {
4798
- $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4799
- }
4800
- } else {
4801
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4802
- }
4803
- }
4804
- break;
4805
- case($pr_array['condition'] = "<"):
4806
- // Use a lexical order on relational string operators
4807
- if (($pd_value < $pr_array['criteria'])){
4808
- // Specifically for shipping price rules
4809
- if(isset($product_data[$pr_array['than_attribute']]) AND (is_array($product_data[$pr_array['than_attribute']]))){
4810
- $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4811
- for ($x = 0; $x <= $arr_size; $x++) {
4812
- $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4813
- }
4814
- } else {
4815
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4816
- }
4817
- }
4818
- break;
4819
- case($pr_array['condition'] = "=<"):
4820
- // Use a lexical order on relational string operators
4821
- if (($pd_value <= $pr_array['criteria'])){
4822
- // Specifically for shipping price rules
4823
- if(is_array($product_data[$pr_array['than_attribute']])){
4824
- $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4825
- for ($x = 0; $x <= $arr_size; $x++) {
4826
- $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4827
- }
4828
- } else {
4829
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4830
- }
4831
- }
4832
- break;
4833
 
4834
- case($pr_array['condition'] = "empty"):
4835
- if(empty($product_data[$pr_array['attribute']])){
4836
- if(empty($product_data[$pr_array['than_attribute']])){
4837
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4838
- } else {
4839
- $product_data[$pr_array['attribute']] = $product_data[$pr_array['than_attribute']];
4840
- }
4841
- }
4842
- break;
4843
- case($pr_array['condition'] = "replace"):
4844
- $product_data[$pr_array['than_attribute']] = str_replace($pr_array['criteria'], $pr_array['newvalue'], $product_data[$pr_array['than_attribute']]);
4845
- break;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4846
  case($pr_array['condition'] = "findreplace"):
4847
  if (strpos($pd_value, $pr_array['criteria']) !== false){
4848
- // Make sure that a new value has been set
4849
- if(!empty($pr_array['newvalue'])){
4850
- // Find and replace only work on same attribute field, otherwise create a contains rule
4851
  if($pr_array['attribute'] == $pr_array['than_attribute']){
4852
- $newvalue = str_replace($pr_array['criteria'],$pr_array['newvalue'], $pd_value);
4853
- $product_data[$pr_array['than_attribute']] = ucfirst($newvalue);
4854
- }
4855
- }
4856
- }
 
4857
  break;
4858
- default:
4859
- break;
4860
- }
4861
- }
4862
- } else {
4863
- // When a rule has been set on an attribute that is not in product_data
4864
- // Add the newvalue to product_data
4865
- if (!array_key_exists($pr_array['attribute'], $product_data)){
4866
- if(!empty($pr_array['newvalue'])){
4867
- $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4868
- } else {
4869
- if(array_key_exists($pr_array['than_attribute'], $product_data)){
4870
- $product_data[$pr_array['attribute']] = $product_data[$pr_array['than_attribute']];
4871
- }
4872
- }
4873
- }
4874
- }
4875
- }
4876
- }
4877
- }
4878
- return $product_data;
4879
- }
4880
 
4881
  /**
4882
  * Function to exclude products based on individual product exclusions
@@ -4899,525 +5006,530 @@ class WooSEA_Get_Products {
4899
  }
4900
  }
4901
 
4902
- /**
4903
- * Execute project filters (include / exclude)
4904
- */
 
4905
  private function woocommerce_sea_filters( $project_rules, $product_data ){
4906
- $allowed = 1;
4907
 
4908
- // Check if product was already excluded from the feed
4909
- $product_excluded = ucfirst( get_post_meta( $product_data['id'], '_woosea_exclude_product', true ) );
4910
 
4911
- if( $product_excluded == "Yes"){
4912
- $allowed = 0;
4913
- }
4914
 
4915
- foreach ($project_rules as $pr_key => $pr_array){
4916
 
4917
- if($pr_array['attribute'] == "categories"){
4918
- $pr_array['attribute'] = "raw_categories";
4919
- }
4920
 
4921
- //if(array_key_exists($pr_array['attribute'], $product_data)){
4922
 
4923
- if(!array_key_exists($pr_array['attribute'], $product_data)) {
4924
- $product_data[$pr_array['attribute']] = ""; // Sets an empty postmeta value in place of a missing one.
4925
- }
4926
 
4927
- foreach ($product_data as $pd_key => $pd_value){
4928
- // Check is there is a rule on specific attributes
 
4929
 
4930
- if(in_array($pd_key, $pr_array, TRUE)){
 
 
 
4931
 
4932
- if($pd_key == "price"){
4933
- //$pd_value = @number_format($pd_value,2);
4934
- $pd_value = wc_format_decimal($pd_value);
4935
- }
4936
-
4937
- if (is_numeric($pd_value)){
4938
- $old_value = $pd_value;
4939
- if($pd_key == "price"){
4940
- $pd_value = @number_format($pd_value,2);
4941
- }
4942
-
4943
- // Rules for numeric values
4944
- switch ($pr_array['condition']) {
4945
- case($pr_array['condition'] = "contains"):
4946
- if ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
4947
- $allowed = 0;
4948
- } elseif ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
4949
- $allowed = 0;
4950
- }
4951
- break;
4952
- case($pr_array['condition'] = "containsnot"):
4953
- if ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
4954
- $allowed = 0;
4955
- } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
4956
- $allowed = 0;
4957
- }
4958
- break;
4959
  case($pr_array['condition'] = "="):
4960
- if (($old_value == $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
4961
- $allowed = 0;
4962
- } elseif (($old_value != $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
4963
- $allowed = 0;
4964
- }
4965
- break;
4966
- case($pr_array['condition'] = "!="):
4967
- if (($old_value == $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
4968
- if($allowed <> 0){
4969
- $allowed = 1;
4970
- }
4971
- } elseif (($old_value == $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
4972
- $allowed = 0;
4973
- }
4974
- break;
4975
- case($pr_array['condition'] = ">"):
4976
- if (($old_value > $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
4977
- $allowed = 0;
4978
- } elseif (($old_value <= $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
4979
- $allowed = 0;
4980
- }
4981
- break;
4982
- case($pr_array['condition'] = ">="):
4983
- if (($old_value >= $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
4984
- $allowed = 0;
4985
- } elseif (($old_value < $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
4986
- $allowed = 0;
4987
- }
4988
- break;
4989
- case($pr_array['condition'] = "<"):
4990
- if (($old_value < $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
4991
- $allowed = 0;
4992
- } elseif (($old_value > $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
4993
- $allowed = 0;
4994
- }
4995
- break;
4996
- case($pr_array['condition'] = "=<"):
4997
- if (($old_value <= $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
4998
- $allowed = 0;
4999
- } elseif (($old_value > $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5000
- $allowed = 0;
5001
  }
5002
- break;
5003
- case($pr_array['condition'] = "empty"):
5004
- if ((strlen($pd_value) < 1) && ($pr_array['than'] == "exclude")){
5005
- $allowed = 0;
5006
- } elseif ((strlen($pd_value > 0)) && ($pr_array['than'] == "include_only")){
5007
- $allowed = 0;
5008
- }
5009
- break;
5010
- default:
5011
- break;
5012
- }
5013
- } elseif (is_array($pd_value)){
5014
- // Tis can either be a shipping or product_tag array
5015
- if($pr_array['attribute'] == "product_tag"){
5016
- $in_tag_array = "not";
5017
-
5018
- foreach($pd_value as $pt_key => $pt_value){
5019
- // Rules for string values
5020
- if (!array_key_exists('cs', $pr_array)){
5021
- $pt_value = strtolower($pt_value);
5022
- $pr_array['criteria'] = strtolower($pr_array['criteria']);
5023
- }
5024
-
5025
- if(preg_match('/'.$pr_array['criteria'].'/', $pt_value)){
5026
- $in_tag_array = "yes";
5027
- }
5028
- }
5029
-
5030
- if($in_tag_array == "yes"){
5031
- //if(in_array($pr_array['criteria'], $pd_value, TRUE)) {
5032
- $v = $pr_array['criteria'];
5033
-
5034
- switch ($pr_array['condition']) {
5035
- case($pr_array['condition'] = "contains"):
5036
- if ((preg_match('/'.$pr_array['criteria'].'/', $v))){
5037
- if($pr_array['than'] == "include_only"){
5038
- if($allowed <> 0){
5039
- $allowed = 1;
5040
- }
5041
- } else {
5042
- $allowed = 0;
5043
- }
5044
- } else {
5045
- $allowed = 0;
5046
- }
5047
- break;
5048
- case($pr_array['condition'] = "containsnot"):
5049
- if ((!preg_match('/'.$pr_array['criteria'].'/', $v))){
5050
- if($pr_array['than'] == "include_only"){
5051
- if($allowed <> 0){
5052
- $allowed = 1;
5053
- }
5054
- } else {
5055
- $allowed = 0;
5056
- }
5057
- } else {
5058
- $allowed = 0;
5059
- }
5060
- break;
5061
- case($pr_array['condition'] = "="):
5062
- if (($v == $pr_array['criteria'])){
5063
- if($pr_array['than'] == "include_only"){
5064
- if($allowed <> 0){
5065
- $allowed = 1;
5066
- }
5067
- } else {
5068
- $allowed = 0;
5069
- }
5070
- } else {
5071
- $allowed = 0;
5072
- }
5073
- break;
5074
- case($pr_array['condition'] = "!="):
5075
- if (($v != $pr_array['criteria'])){
5076
- if($pr_array['than'] == "include_only"){
5077
- if($allowed <> 0){
5078
- $allowed = 1;
5079
- }
5080
- } else {
5081
- $allowed = 0;
5082
- }
5083
- }
5084
- break;
5085
- case($pr_array['condition'] = ">"):
5086
- if (($v > $pr_array['criteria'])){
5087
- if($pr_array['than'] == "include_only"){
5088
- if($allowed <> 0){
5089
- $allowed = 1;
5090
- }
5091
- } else {
5092
- $allowed = 0;
5093
- }
5094
- }
5095
- break;
5096
- case($pr_array['condition'] = ">="):
5097
- if (($v >= $pr_array['criteria'])){
5098
- if($pr_array['than'] == "include_only"){
5099
- if($allowed <> 0){
5100
- $allowed = 1;
5101
- }
5102
- } else {
5103
- $allowed = 0;
5104
- }
5105
- }
5106
- break;
5107
- case($pr_array['condition'] = "<"):
5108
- if (($v < $pr_array['criteria'])){
5109
- if($pr_array['than'] == "include_only"){
5110
- if($allowed <> 0){
5111
- $allowed = 1;
5112
- }
5113
- } else {
5114
- $allowed = 0;
5115
- }
5116
- }
5117
- break;
5118
- case($pr_array['condition'] = "=<"):
5119
- if (($v <= $pr_array['criteria'])){
5120
- if($pr_array['than'] == "include_only"){
5121
- if($allowed <> 0){
5122
- $allowed = 1;
5123
- }
5124
- } else {
5125
- $allowed = 0;
5126
- }
5127
- }
5128
- break;
5129
- case($pr_array['condition'] = "empty"):
5130
- if (strlen($v) < 1){
5131
- if($pr_array['than'] == "include_only"){
5132
- if($allowed <> 0){
5133
- $allowed = 1;
5134
- }
5135
- } else {
5136
- $allowed = 0;
5137
- }
5138
- }
5139
- break;
5140
- default:
5141
- break;
5142
- }
5143
- } else {
5144
- switch ($pr_array['condition']) {
5145
- case($pr_array['condition'] = "contains"):
5146
- if($pr_array['than'] == "include_only"){
5147
- $allowed = 0;
5148
- } else {
5149
- if($allowed <> 0){
5150
- $allowed = 1;
5151
- }
5152
- }
5153
- break;
5154
- case($pr_array['condition'] = "containsnot"):
5155
- if($pr_array['than'] == "include_only"){
5156
- if($allowed <> 0){
5157
- $allowed = 1;
5158
- }
5159
- } else {
5160
- $allowed = 0;
5161
- }
5162
- break;
5163
- case($pr_array['condition'] = "="):
5164
- if($pr_array['than'] == "include_only"){
5165
- $allowed = 0;
5166
- } else {
5167
- if($allowed <> 0){
5168
- $allowed = 1;
5169
- }
5170
- }
5171
- break;
5172
- case($pr_array['condition'] = "!="):
5173
- if($pr_array['than'] == "include_only"){
5174
- if($allowed <> 0){
5175
- $allowed = 1;
5176
- }
5177
- } else {
5178
- $allowed = 0;
5179
- }
5180
- break;
5181
- case($pr_array['condition'] = ">"):
5182
- if($pr_array['than'] == "include_only"){
5183
- $allowed = 0;
5184
- } else {
5185
- $allowed = 0;
5186
- }
5187
- break;
5188
- case($pr_array['condition'] = ">="):
5189
- if($pr_array['than'] == "include_only"){
5190
- $allowed = 0;
5191
- } else {
5192
- $allowed = 0;
5193
- }
5194
- break;
5195
- case($pr_array['condition'] = "<"):
5196
- if($pr_array['than'] == "include_only"){
5197
- $allowed = 0;
5198
- } else {
5199
- $allowed = 0;
5200
- }
5201
- break;
5202
- case($pr_array['condition'] = "=<"):
5203
- if($pr_array['than'] == "include_only"){
5204
- $allowed = 0;
5205
- } else {
5206
- $allowed = 0;
5207
- }
5208
- break;
5209
- case($pr_array['condition'] = "empty"):
5210
- if($pr_array['than'] == "include_only"){
5211
- if($allowed <> 0){
5212
- $allowed = 1;
5213
- }
5214
- } else {
5215
- $allowed = 0;
5216
- }
5217
- break;
5218
- default:
5219
- break;
5220
- }
5221
- }
5222
- } else {
5223
- // For now only shipping details are in an array
5224
- foreach ($pd_value as $k => $v){
5225
- foreach ($v as $kk => $vv){
5226
- // Only shipping detail rule can be on price for now
5227
- if($kk == "price"){
5228
- switch ($pr_array['condition']) {
5229
- case($pr_array['condition'] = "contains"):
5230
- if ((preg_match('/'.$pr_array['criteria'].'/', $vv))){
5231
- $allowed = 0;
5232
- }
5233
- break;
5234
- case($pr_array['condition'] = "containsnot"):
5235
- if ((!preg_match('/'.$pr_array['criteria'].'/', $vv))){
5236
- $allowed = 0;
5237
- }
5238
- break;
5239
- case($pr_array['condition'] = "="):
5240
- if (($vv == $pr_array['criteria'])){
5241
- $allowed = 0;
5242
- }
5243
- break;
5244
- case($pr_array['condition'] = "!="):
5245
- if (($vv != $pr_array['criteria'])){
5246
- $allowed = 0;
5247
- }
5248
- break;
5249
- case($pr_array['condition'] = ">"):
5250
- if (($vv > $pr_array['criteria'])){
5251
- $allowed = 0;
5252
- }
5253
- break;
5254
- case($pr_array['condition'] = ">="):
5255
- if (($vv >= $pr_array['criteria'])){
5256
- $allowed = 0;
5257
- }
5258
- break;
5259
- case($pr_array['condition'] = "<"):
5260
- if (($vv < $pr_array['criteria'])){
5261
- $allowed = 0;
5262
- }
5263
- break;
5264
- case($pr_array['condition'] = "=<"):
5265
- if (($vv <= $pr_array['criteria'])){
5266
- $allowed = 0;
5267
- }
5268
- break;
5269
- case($pr_array['condition'] = "empty"):
5270
- if (strlen($vv) < 1){
5271
- $allowed = 0;
5272
- }
5273
- break;
5274
- default:
5275
- break;
5276
- }
5277
- }
5278
- }
5279
- }
5280
- }
5281
- } else {
5282
- // Filters for string values
5283
- // If case-sensitve is off than lowercase both the criteria and attribute value
5284
- if (array_key_exists('cs', $pr_array)){
5285
- if ($pr_array['cs'] != "on"){
5286
- $pd_value = strtolower($pd_value);
5287
- $pr_array['criteria'] = strtolower($pr_array['criteria']);
5288
- }
5289
- }
5290
- $pos = strpos($pd_value, '&amp;');
5291
- $pos_slash = strpos($pr_array['criteria'], '\\');
5292
- if($pos !== false){
5293
- $pd_value = str_replace("&amp;","&",$pd_value);
5294
- }
5295
- if($pos_slash !== false){
5296
- $pr_array['criteria'] = str_replace("\\","",$pr_array['criteria']);
5297
- }
5298
 
5299
- switch ($pr_array['condition']) {
5300
- case($pr_array['condition'] = "contains"):
5301
- if ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
5302
- $allowed = 0;
5303
- } elseif ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5304
- $allowed = 0;
5305
- } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5306
- if($allowed <> 0){
5307
- $allowed = 1;
5308
- }
5309
- }
5310
- break;
5311
- case($pr_array['condition'] = "containsnot"):
5312
- if ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
5313
- $allowed = 0;
5314
- } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5315
- $allowed = 0;
5316
- }
5317
- break;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
5318
  case($pr_array['condition'] = "="):
5319
- if (($pr_array['criteria'] == "$pd_value") && ($pr_array['than'] == "exclude")){
5320
  $allowed = 0;
5321
- } elseif (($pr_array['criteria'] != "$pd_value") && ($pr_array['than'] == "include_only")){
5322
- $found = strpos($pd_value,$pr_array['criteria']);
5323
- if ($found !== false) {
5324
- //for category mapping check if its an array
5325
- if($pr_array['attribute'] == "raw_categories"){
5326
- $raw_cats_arr = explode("||",$pd_value);
5327
- if(is_array($raw_cats_arr)){
5328
- if(in_array($pr_array['criteria'],$raw_cats_arr, TRUE)){
5329
- if($allowed <> 0){
5330
- $allowed = 1;
5331
- }
5332
- } else {
5333
- $allowed = 0;
5334
- }
5335
- }
5336
- } else {
5337
- if($allowed <> 0){
5338
- $allowed = 1;
5339
- }
5340
- }
5341
- } else {
5342
- $allowed = 0;
5343
- }
5344
- } elseif (($pr_array['criteria'] == "$pd_value") && ($pr_array['than'] == "include_only")){
5345
- if($allowed <> 0){
5346
- $allowed = 1;
5347
- }
5348
- } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
5349
- $allowed = 0;
5350
- } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5351
- $allowed = 1;
5352
- }
5353
- break;
5354
- case($pr_array['condition'] = "!="):
5355
- if (($pr_array['criteria'] == "$pd_value") && ($pr_array['than'] == "exclude")){
5356
- if($allowed <> 0){
5357
- $allowed = 1;
5358
- }
5359
- } elseif (($pr_array['criteria'] == "$pd_value") && ($pr_array['than'] == "include_only")){
5360
- $allowed = 0;
5361
- } elseif (($pr_array['criteria'] != "$pd_value") && ($pr_array['than'] == "exclude")){
5362
- $allowed = 0;
5363
- }
5364
- break;
5365
- case($pr_array['condition'] = ">"):
5366
- // Use a lexical order on relational string operators
5367
- if (($pd_value > $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5368
- $allowed = 0;
5369
- } elseif (($pd_value < $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5370
- $allowed = 0;
5371
- }
5372
- break;
5373
- case($pr_array['condition'] = ">="):
5374
- // Use a lexical order on relational string operators
5375
- if (($pd_value >= $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5376
- $allowed = 0;
5377
- } elseif (($pd_value < $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5378
- $allowed = 0;
5379
- }
5380
- break;
5381
- case($pr_array['condition'] = "<"):
5382
- // Use a lexical order on relational string operators
5383
- if (($pd_value < $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5384
- $allowed = 0;
5385
- } elseif (($pd_value > $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5386
- $allowed = 0;
5387
- }
5388
- break;
5389
- case($pr_array['condition'] = "=<"):
5390
- // Use a lexical order on relational string operators
5391
- if (($pd_value <= $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5392
- $allowed = 0;
5393
- } elseif (($pd_value > $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5394
- $allowed = 0;
5395
- }
5396
- break;
5397
- case($pr_array['condition'] = "empty"):
 
 
5398
  if ((strlen($pd_value) < 1) && ($pr_array['than'] == "exclude")){
5399
- $allowed = 0;
5400
- } elseif ((strlen($pd_value) > 0) && ($pr_array['than'] == "exclude")){
5401
- if($allowed <> 0){
5402
- $allowed = 1;
5403
- }
5404
- } elseif ((strlen($pd_value) > 0) && ($pr_array['than'] == "include_only")){
5405
- $allowed = 0;
5406
- }
5407
- break;
5408
- default:
5409
- break;
5410
- }
5411
- }
5412
- }
5413
- }
5414
- }
5415
 
5416
- if ($allowed < 1){
5417
- $product_data = array();
5418
- $product_data = null;
5419
- } else {
5420
- return $product_data;
5421
- }
5422
- }
5423
  }
26
  return "<![CDATA[ $string ]]>";
27
  }
28
 
 
29
  /**
30
  * Check if a plugin is active
31
  */
56
  * Get all approved product review comments for Google's Product Review Feeds
57
  */
58
  public function woosea_get_reviews ( $product_data, $product ) {
59
+ // Rwviews for the parent variable product itself can be skipped, the review is added for the variation
60
+ if($product_data['product_type'] == "variable"){
61
+ return;
62
+ }
63
+
64
  $approved_reviews = array();
65
  $prod_id = $product_data['id'];
66
 
88
  $cnt = 0;
89
  $name = "";
90
  foreach($name_pieces as $n_piece){
91
+ $n_piece = str_replace("&amp;", "", $n_piece);
92
+
93
  if($cnt > 0){
94
+ $n_piece = ucfirst(substr($n_piece, 0, 1));
95
  }
96
  $name .= $n_piece." ";
97
  $cnt++;
102
  $review['reviewer_name'] = html_entity_decode((str_replace("\r", "", $review['reviewer_name'])), ENT_QUOTES | ENT_XML1, 'UTF-8');
103
  $review['reviewer_name'] = preg_replace( '/\[(.*?)\]/', ' ', $review['reviewer_name'] );
104
  $review['reviewer_name'] = str_replace("&#xa0;", "", $review['reviewer_name']);
105
+ $review['reviewer_name'] = $this->woosea_utf8_for_xml( $review['reviewer_name'] );
106
 
107
  $review['reviewer_id'] = $review_raw->user_id;
108
  $review['review_timestamp'] = $review_raw->comment_date;
330
  /**
331
  * Get category path (needed for Prisjakt)
332
  */
333
+ public function woosea_get_term_parents( $id, $taxonomy, string $link = null, $project_taxonomy, $nicename = false, $visited = array() ) {
334
  // Only add Home to the beginning of the chain when we start buildin the chain
335
  if(empty($visited)){
336
  $chain = 'Home';
937
  unset($shipping_cost);
938
  }
939
  }
940
+
941
+ // User do not want to have free shipping in their feed
942
+ $remove_free_shipping = "no";
943
+ $remove_free_shipping = get_option ('remove_free_shipping');
944
+
945
+ if($remove_free_shipping == "yes"){
946
+ unset($zone_details['service']);
947
+ unset($zone_details['price']);
948
+ unset($shipping_cost);
949
+ }
950
  }
951
 
952
  if(isset($zone_details)){
973
  $zone_details['price'] = trim($shipping_cost);
974
  }
975
  } else {
 
976
  if(isset($shipping_cost)){
977
  $zone_details['price'] = trim($currency." ".$shipping_cost);
978
  }
 
 
979
  }
980
  }
981
  }
1005
 
1006
  // Remove other shipping classes when free shipping is relevant
1007
  $free_check = "yes";
 
1008
 
1009
  if(in_array($free_check, array_column($shipping_arr, 'free'))) { // search value in the array
1010
  foreach($shipping_arr as $k => $v) {
1011
  if(!in_array($free_check, $v)){
1012
+
1013
+ // User do not want to have free shipping in their feed
1014
+ // Only remove the other shipping classes when free shipping is not being removed
1015
+ $remove_free_shipping = "no";
1016
+ $remove_free_shipping = get_option ('remove_free_shipping');
1017
+
1018
+ if($remove_free_shipping == "no"){
1019
+ unset($shipping_arr[$k]);
1020
+ }
1021
  }
1022
  }
1023
  }
1025
  // Fix empty services
1026
  foreach($shipping_arr as $k => $v){
1027
  if(empty($v['service'])){
 
 
1028
  unset($shipping_arr[$k]);
1029
  }
1030
  }
1163
  } elseif (preg_match("/g:product_detail/i",$k)){
1164
  if(!empty($v)){
1165
  $product_detail_split = explode("#", $v);
1166
+ $detail_complete = count($product_detail_split);
1167
+ if($detail_complete == 2){
1168
+ $product_detail = $product->addChild('g:product_detail', '', $namespace['g']);
1169
+ $name = str_replace("_", " ", $product_detail_split[0]);
1170
+
1171
+ $section_name = explode(":", $name);
1172
+ $section_name_start = ucfirst($section_name[0]);
1173
+ $name = ucfirst(trim($section_name[1]));
1174
+
1175
+ $section_name = $product_detail->addChild('g:section_name', "General", $namespace['g']);
1176
+ $product_detail_name = $product_detail->addChild('g:attribute_name', $section_name_start, $namespace['g']);
1177
+ $product_detail_value = $product_detail->addChild('g:attribute_value', $product_detail_split[1], $namespace['g']);
1178
+ }
1179
  }
1180
  } elseif ($k == "g:installment"){
1181
  if(!empty($v)){
2014
  $xml_piece = "";
2015
 
2016
  // Get taxonomies
2017
+ $no_taxonomies = array("element_category","template_category","portfolio_category","portfolio_skills","portfolio_tags","faq_category","slide-page","category","post_tag","nav_menu","link_category","post_format","product_type","product_visibility","product_cat","product_shipping_class","product_tag");
2018
  $taxonomies = get_taxonomies();
2019
  $diff_taxonomies = array_diff($taxonomies, $no_taxonomies);
2020
 
2346
  $product_data['raw_description'] = substr($product_data['raw_description'], 0, 5000);
2347
  $product_data['raw_short_description'] = substr($product_data['raw_short_description'], 0, 5000);
2348
 
2349
+ // Parent variable description
2350
+ $product_data['mother_description'] = $product_data['description'];
2351
+ $product_data['mother_short_description'] = $product_data['short_description'];
2352
+
2353
  /**
2354
  * Check of we need to add Google Analytics UTM parameters
2355
  */
2383
  * Therefor, we need to check the stock_status and overwrite te availability value
2384
  */
2385
  $stock_status = $product->get_stock_status();
2386
+ $product_data['stock_status'] = $stock_status;
2387
  if ($stock_status == "outofstock"){
2388
  $product_data['availability'] = "out of stock";
2389
  } elseif ($stock_status == "onbackorder") {
2465
  }
2466
 
2467
  $product_data['shipping_label'] = $product->get_shipping_class();
2468
+ $term = get_term_by( 'slug', $product->get_shipping_class(), 'product_shipping_class' );
2469
+ if(is_object($term)){
2470
+ $product_data['shipping_label_name'] = $term->name;
2471
+ }
2472
 
2473
  // Get product prices
2474
  $product_data['price'] = wc_get_price_including_tax($product, array('price'=> $product->get_price()));
2481
  // Untouched raw system pricing - DO NOT CHANGE THESE
2482
  $product_data['system_net_price'] = round(wc_get_price_excluding_tax( $product ), 2);
2483
  $product_data['system_net_price'] = wc_format_decimal($product_data['system_net_price'],2);
2484
+ $float_system_regular_price = floatval($product->get_regular_price());
2485
+ $product_data['system_regular_price'] = round($float_system_regular_price,2);
2486
  $product_data['system_regular_price'] = wc_format_decimal($product_data['system_regular_price'],2);
2487
 
2488
  $product_data['system_price'] = wc_get_price_including_tax($product, array('price'=> $product->get_price()));
2516
  if($product->get_type() == "bundle"){
2517
  if ($this->woosea_is_plugin_active('woocommerce-product-bundles/woocommerce-product-bundles.php')){
2518
  $product_data['price'] = get_post_meta($product_data['id'], '_price', true);
2519
+ $product_data['sale_price'] = get_post_meta($product_data['id'], '_sale_price', true);
2520
  if(is_numeric($tax_rates[1]['rate'])){
2521
  $product_data['price_forced'] = round(get_post_meta($product_data['id'], '_price', true) * (100+$tax_rates[1]['rate'])/100,2);
2522
  $product_data['regular_price'] = round(get_post_meta($product_data['id'], '_regular_price', true) * (100+$tax_rates[1]['rate'])/100,2);
2614
  $discount = apply_filters('advanced_woo_discount_rules_get_product_discount_price_from_custom_price', false, $product, 1, $product_data['sale_price'], 'discounted_price', true, true);
2615
  if($discount !== false){
2616
  $product_data['sale_price'] = $discount;
2617
+ $product_data['price'] = $discount;
2618
  $price_incl_tax = get_option( 'woocommerce_prices_include_tax' );
2619
  if($price_incl_tax == "yes"){
2620
  $product_data['price_forced'] = $product_data['price']*($fullrate/100);
2755
  $product_data['system_sale_price'] = wc_format_localized_price($product_data['system_sale_price']);
2756
 
2757
  // Add rounded price options
2758
+ $float_price = floatval($product_data['price']);
2759
+ $float_regular_price = floatval($product_data['regular_price']);
2760
+ $float_sale_price = floatval($product_data['sale_price']);
2761
+ $product_data['rounded_price'] = round($float_price,0);
2762
+ $product_data['rounded_regular_price'] = round($float_regular_price,0);
2763
+ $product_data['rounded_sale_price'] = round($float_sale_price,0);
2764
 
2765
  // Calculate discount percentage
2766
  if($product_data['sale_price'] > 0){
2778
  }
2779
  }
2780
 
2781
+ if ((array_key_exists('shipping', $project_config['attributes'])) OR (array_key_exists('shipping_price', $project_config['attributes'])) OR ($project_config['fields'] == "trovaprezzi") OR ($project_config['fields'] == "customfeed")){
2782
  $product_data['shipping'] = $this->woosea_get_shipping_cost($class_cost_id, $project_config, $product_data['price'], $tax_rates, $shipping_zones, $product_data['id'], $product_data['item_group_id']);
2783
  $shipping_str = $product_data['shipping'];
2784
  }
2874
 
2875
  foreach($diff_taxonomies as $taxo){
2876
  $term_value = get_the_terms($product_data['id'], $taxo);
2877
+ $product_data["$taxo"] = "";
2878
 
2879
  if(is_array($term_value)){
2880
  // Do not add variation values to the feed when they are out of stock
2884
  $variations = $product_skroutz->get_available_variations();
2885
  $variations_id = wp_list_pluck( $variations, 'variation_id' );
2886
  $skroutz_att_array = array();
2887
+
2888
  foreach($variations_id as $var_id){
2889
  $stock_value = get_post_meta( $var_id, "_stock_status", true );
2890
  if($stock_value == "instock"){
2898
  $product_data[$taxo] = rtrim($product_data[$taxo],',');
2899
  }
2900
  }
 
2901
  foreach($skroutz_att_array as $skrtz_value){
2902
  $product_data[$taxo] .= ",". $skrtz_value;
2903
  }
3012
  $data = $wpdb->get_results($sql);
3013
  if (count($data)) {
3014
  foreach ($data as $key => $value) {
3015
+ $value_display = str_replace("_", " ",$value->name);
3016
  if (preg_match("/_product_attributes/i",$value->name)){
3017
  $product_attr = unserialize($value->type);
3018
  if(!empty($product_attr)){
3030
 
3031
  /**
3032
  * Get Product Attributes for Single products
3033
+ * These are the attributes users create themselves in WooCommerce
3034
  */
3035
+ if (($product->is_type('simple')) OR ($product->is_type('external')) OR ($product->is_type('mix-and-match')) OR ($product->is_type('bundle')) OR ($product->is_type('composite')) OR ($product->is_type('auction') OR ($product->is_type('subscription')) OR ($product->is_type('variable')))){
3036
  $single_attributes = $product->get_attributes();
 
3037
  foreach ($single_attributes as $attribute){
3038
+ $attr_name = strtolower($attribute->get_name());
3039
+ $attr_value = $product->get_attribute($attr_name);
3040
+ $product_data[$attr_name] = $attr_value;
3041
  }
3042
  }
3043
 
3063
  $product_variations = new WC_Product_Variation( $product_data['id'] );
3064
  $variations = $product_variations->get_variation_attributes();
3065
 
3066
+ // For Skroutz and Bestprice apparal products we can only append colours to the product name
3067
  // When a product has both a size and color attribute we assume its an apparal product
3068
+ if(($project_config['fields'] == "skroutz") OR ($project_config['fields'] == "bestprice")){
3069
  $size_found = "no";
3070
  $color_found = "no";
3071
 
3141
  }
3142
  }
3143
 
 
 
3144
  if((isset($project_config['lowest_price_variations'])) OR (isset($project_config['default_variations']))){
 
3145
  // Determine the default variation product
3146
  if( ($product_data['item_group_id'] > 0) AND (is_object(wc_get_product( $product_data['item_group_id']))) AND (($product_data['product_type'] == "variation") OR ($product_data['product_type'] == "subscription_variation"))){
3147
  $mother_product = wc_get_product($product_data['item_group_id']);
3148
  $def_attributes = $mother_product->get_default_attributes();
3149
 
3150
  if(isset($project_config['lowest_price_variations'])){
3151
+
3152
  // Determine lowest priced variation
3153
  $variation_min_price = $mother_product->get_variation_price('min');
3154
  $variation_min_price = wc_format_decimal($variation_min_price,2);
3155
  $variation_min_price = wc_format_localized_price($variation_min_price);
3156
+ $var_price = get_post_meta($product_data['id'], '_price', true);
3157
+
3158
+ $variation_prices = $mother_product->get_variation_prices();
3159
+ $variation_prices_price = array_values($variation_prices['price']);
3160
+ $lowest_price = min($variation_prices_price);
3161
+
3162
+ $var_price = wc_format_decimal($var_price,2);
3163
+ $var_price = wc_format_localized_price($var_price);
3164
 
3165
+ if(($var_price == $lowest_price) OR ($var_price == $variation_min_price) OR ($product_data['system_regular_price'] == $variation_min_price) OR ($product_data['system_net_price'] == $variation_min_price)){
3166
  $variation_pass = "true";
3167
  } else {
3168
  $variation_pass = "false";
3300
  /**
3301
  * Although this is a product variation we also need to grap the Dynamic attributes belonging to the simple mother prodict
3302
  */
3303
+ $stock_value = get_post_meta( $product_data['id'], "_stock_status", true );
3304
+ //if($stock_value == "instock"){
3305
  foreach($diff_taxonomies as $taxo){
3306
  $term_value = get_the_terms($product_data['item_group_id'], $taxo);
3307
  unset($product_data[$taxo]);
3308
  if(is_array($term_value)){
3309
  foreach($term_value as $term){
3310
  if(empty($product_data[$taxo])){
3311
+ $product_data[$taxo] = $term->name;
3312
  } else {
3313
+ $product_data[$taxo] .= " ".$term->name;
3314
  }
3315
  }
3316
  }
3317
+ }
3318
 
3319
  /**
3320
  * Add product tags to the product data array
3334
 
3335
  // Add attribute values to the variation product names to make them unique
3336
  $product_data['title_hyphen'] = $product_data['title']." - ";
3337
+ $product_data['mother_title_hyphen'] = $product_data['mother_title']." - ";
3338
 
3339
  foreach($variations as $kk => $vv){
3340
  $custom_key = $kk;
3483
  * we will add CDATA brackets to the title and description attributes
3484
  */
3485
  $product_data['title_lc'] = ucfirst(strtolower($product_data['title']));
3486
+ $product_data['title_lcw'] = ucwords(strtolower($product_data['title']));
3487
+
3488
  //$product_data['description'] = $this->woosea_append_cdata ( $product_data['description'] );
3489
  //$product_data['short_description'] = $this->woosea_append_cdata ( $product_data['short_description'] );
3490
 
3493
  */
3494
  $product_data['reviews'] = $this->woosea_get_reviews( $product_data, $product );
3495
 
3496
+ /**
3497
+ * Filter out reviews that do not have text
3498
+ */
3499
+ if(!empty($product_data['reviews'])){
3500
+ foreach($product_data['reviews'] as $review_id => $review_details){
3501
+ if(empty($review_details['content'])){
3502
+ unset($product_data['reviews'][$review_id]);
3503
+ }
3504
+ }
3505
+ }
3506
+
3507
  /**
3508
  * Check if individual products need to be excluded
3509
  */
3569
  // For these channels parent products are allowed
3570
  $allowed_channel_parents = array(
3571
  "skroutz",
3572
+ "bestprice",
3573
  "google_dsa",
3574
  "google_product_review",
3575
  );
3576
 
3577
+ if(array_key_exists('fields', $project_config)){
3578
+ if (!in_array($project_config['fields'], $allowed_channel_parents)){
3579
+ if(($product->is_type('variable')) AND ($product_data['item_group_id'] == 0)){
3580
+ $product_data = array();
3581
+ $product_data = null;
3582
+ }
3583
+ }
3584
+ }
3585
 
3586
  /**
3587
  * Remove variation products that are not THE default variation product
3608
  }
3609
  }
3610
 
3611
+ /**
3612
+ * Do final check on Skroutz out of stock sizes
3613
+ * When a size is not on stock remove it
3614
+ */
3615
+ if($project_config['fields'] == "skroutz"){
3616
+ if(isset($product_data['id'])){
3617
+ foreach($project_config['attributes'] as $ky => $vy){
3618
+ if(isset($vy['attribute'])){
3619
+ if($vy['attribute'] == "size"){
3620
+ $size_found = "yes";
3621
+ $sz_attribute = $vy['mapfrom'];
3622
+ }
3623
+ if($vy['attribute'] == "color"){
3624
+ $color_found = "yes";
3625
+ $clr_attribute = $vy['mapfrom'];
3626
+ }
3627
+ }
3628
+ }
3629
+
3630
+ $stock_value = get_post_meta( $product_data['id'], "_stock_status", true );
3631
+ $sz_attr_value = get_post_meta( $product_data['id'], $sz_attribute, true );
3632
+ $clr_attr_value = get_post_meta( $product_data['id'], "attribute_".$clr_attribute, true );
3633
+ if(isset($product_data['item_group_id']) AND ($product_data['item_group_id'] > 0)){
3634
+ $product_skroutz = wc_get_product($product_data['item_group_id']);
3635
+ $variations = $product_skroutz->get_available_variations();
3636
+ $variations_id = wp_list_pluck( $variations, 'variation_id' );
3637
+
3638
+ foreach($variations_id as $var_id){
3639
+ $clr_variation = get_post_meta( $var_id, "attribute_".$clr_attribute, true );
3640
+ $size_variation = get_post_meta( $var_id, "attribute_".$sz_attribute, true );
3641
+ $stock_variation = get_post_meta( $var_id, "_stock_status", true );
3642
+
3643
+ if($clr_variation == $clr_attr_value){
3644
+ if($stock_variation == "outofstock"){
3645
+ // Remove this size as it is not on stock
3646
+ if(array_key_exists($sz_attribute, $product_data)){
3647
+ $product_data[$sz_attribute] = str_replace(ucfirst($size_variation),"",$product_data[$sz_attribute]);
3648
+ }
3649
+ }
3650
+ }
3651
+ }
3652
+ }
3653
+ }
3654
+ }
3655
+
3656
  /**
3657
  * When product has passed the filter rules it can continue with the rest
3658
  */
3686
  }
3687
  } else {
3688
  if((strlen($attr_value['mapfrom'])) AND (array_key_exists($attr_value['mapfrom'], $product_data))){
3689
+ if(($attr_value['attribute'] == "URL") OR ($attr_value['attribute'] == "g:link") OR ($attr_value['attribute'] == "g:link_template") OR ($attr_value['attribute'] == "g:image_link") OR ($attr_value['attribute'] == "link") OR ($attr_value['attribute'] == "Final URL") OR ($attr_value['attribute'] == "SKU")){
3690
  $attr_line = "'".$attr_value['prefix']."".$product_data[$attr_value['mapfrom']]."".$attr_value['suffix']."'";
3691
  } else {
3692
  $attr_line = "'".$attr_value['prefix']. "".$product_data[$attr_value['mapfrom']]."" .$attr_value['suffix']."'";
3758
  }
3759
  } else {
3760
  if(strlen($product_data[$attr_value['mapfrom']])){
3761
+ if(($attr_value['attribute'] == "URL") OR ($attr_value['attribute'] == "g:link") OR ($attr_value['attribute'] == "g:link_template") OR ($attr_value['attribute'] == "g:image_link") OR ($attr_value['attribute'] == "link") OR ($attr_value['attribute'] == "Final URL") OR ($attr_value['attribute'] == "SKU")){
3762
  if(($product_data['product_type'] == "variation") AND (preg_match("/aelia_cs_currency/", $attr_value['suffix']))){
3763
  $attr_value['suffix'] = str_replace("?","&",$attr_value['suffix']);
3764
  $attr_line .= ",'".$attr_value['prefix']."".$product_data[$attr_value['mapfrom']]."".$attr_value['suffix']."'";
3978
  }
3979
  } else {
3980
  if(strlen($product_data[$attr_value['mapfrom']])){
3981
+ if(($attr_value['attribute'] == "URL") OR ($attr_value['attribute'] == "g:link") OR ($attr_value['attribute'] == "link") OR ($attr_value['attribute'] == "g:link_template")){
3982
  if(($product_data['product_type'] == "variation") AND (preg_match("/aelia_cs_currency/", $attr_value['suffix']))){
3983
  $attr_value['suffix'] = str_replace("?","&",$attr_value['suffix']);
3984
  $xml_product[$attr_value['attribute']] = "$attr_value[prefix]". $product_data[$attr_value['mapfrom']] ."$attr_value[suffix]";
4508
  return $product_data;
4509
  }
4510
 
4511
+ /**
4512
+ * Execute project rules
4513
+ */
4514
  private function woocommerce_sea_rules( $project_rules2, $product_data ){
4515
+ $aantal_prods = count($product_data);
4516
+ if($aantal_prods > 0){
4517
 
4518
+ foreach ($project_rules2 as $pr_key => $pr_array){
4519
 
4520
+ foreach ($product_data as $pd_key => $pd_value){
4521
 
4522
+ // Check is there is a rule on specific attributes
4523
+ if($pd_key == $pr_array['attribute']){
4524
 
4525
+ // This is because for data manipulation the than attribute is empty
4526
+ if(!array_key_exists('than_attribute', $pr_array)){
4527
+ $pr_array['than_attribute'] = $pd_key;
4528
+ }
4529
 
4530
  // Check if a rule has been set for Google categories
4531
  if (!empty($product_data['categories']) AND ($pr_array['than_attribute'] == "google_category") AND ($product_data[$pr_array['attribute']] == $pr_array['criteria'])){
4532
+
4533
+ $pr_array['than_attribute'] = "categories";
4534
  $category_id = explode("-", $pr_array['newvalue']);
4535
  $pr_array['newvalue'] = $category_id[0];
4536
+ $product_data['categories'] = $pr_array['newvalue'];
4537
+ }
4538
 
4539
+ // Make sure that rules on numerics are on true numerics
4540
+ if (!is_array($pd_value) AND (!preg_match('/[A-Za-z]/', $pd_value))){
4541
+ $pd_value = strtr($pd_value, ',', '.');
4542
+ }
4543
 
4544
 
4545
+ // Make sure the price or sale price is numeric
4546
+ if(($pr_array['attribute'] == "sale_price") OR ($pr_array['attribute'] == "price")){
4547
+ settype($pd_value, "double");
4548
+ }
4549
 
4550
+ if (((is_numeric($pd_value)) AND ($pr_array['than_attribute'] != "shipping"))){
4551
 
4552
+ // Rules for numeric values
4553
+ switch ($pr_array['condition']) {
4554
+ case($pr_array['condition'] = "contains"):
4555
+ if ((preg_match('/'.$pr_array['criteria'].'/', $pd_value))){
4556
+ $product_data[$pr_array['than_attribute']] = str_replace($pr_array['criteria'], $pr_array['newvalue'], $pd_value);
4557
+ }
4558
+ break;
4559
+ case($pr_array['condition'] = "containsnot"):
4560
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value))){
4561
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4562
+ }
4563
+ break;
4564
+ case($pr_array['condition'] = "="):
4565
+ if (($pd_value == $pr_array['criteria'])){
4566
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4567
+ }
4568
+ break;
4569
+ case($pr_array['condition'] = "!="):
4570
+ if (($pd_value != $pr_array['criteria'])){
4571
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4572
+ }
4573
+ break;
4574
+ case($pr_array['condition'] = ">"):
4575
+ if (($pd_value > $pr_array['criteria'])){
4576
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4577
+ }
4578
+ break;
4579
+ case($pr_array['condition'] = ">="):
4580
+ if (($pd_value >= $pr_array['criteria'])){
4581
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4582
+ }
4583
+ break;
4584
+ case($pr_array['condition'] = "<"):
4585
+ if (($pd_value < $pr_array['criteria'])){
4586
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4587
+ }
4588
+ break;
4589
+ case($pr_array['condition'] = "=<"):
4590
+ if (($pd_value <= $pr_array['criteria'])){
4591
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4592
+ }
4593
+ break;
4594
+ case($pr_array['condition'] = "empty"):
4595
+ if(empty($product_data[$pr_array['attribute']])){
4596
+ if ((strlen($pd_value) < 1)){
4597
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4598
+ } else {
4599
+ $product_data[$pr_array['attribute']] = $product_data[$pr_array['than_attribute']];
4600
+ }
4601
+ }
4602
+ break;
4603
+ case($pr_array['condition'] = "multiply"):
4604
+ $pr_array['criteria'] = strtr($pr_array['criteria'], ',', '.');
4605
+ $convert_back = "false";
4606
+ $pos = strpos($pd_value, ',');
4607
+ if($pos !== false){
4608
+ $convert_back = "true";
4609
+ }
4610
+ $pd_value = strtr($pd_value, ',', '.');
4611
+ $newvalue = $pd_value*$pr_array['criteria'];
4612
+ $newvalue = round($newvalue, 2);
4613
+ if($convert_back == "true"){
4614
+ $newvalue = strtr($newvalue, '.',',');
4615
+ }
4616
+ $product_data[$pr_array['attribute']] = $newvalue;
4617
+ break;
4618
+ case($pr_array['condition'] = "divide"):
4619
+ $newvalue = ($pd_value / $pr_array['criteria']);
4620
+ $newvalue = round($newvalue, 2);
4621
+ $newvalue = strtr($newvalue, '.',',');
4622
+ $product_data[$pr_array['attribute']] = $newvalue;
4623
+ break;
4624
+ case($pr_array['condition'] = "plus"):
4625
+ $newvalue = ($pd_value + $pr_array['criteria']);
4626
+ $product_data[$pr_array['attribute']] = $newvalue;
4627
+ break;
4628
+ case($pr_array['condition'] = "minus"):
4629
+ $newvalue = ($pd_value - $pr_array['criteria']);
4630
+ $product_data[$pr_array['attribute']] = $newvalue;
4631
+ break;
4632
+ case($pr_array['condition'] = "findreplace"):
4633
+ if (strpos($pd_value, $pr_array['criteria']) !== false){
4634
  // Make sure that a new value has been set
4635
+ if(!empty($pr_array['newvalue'])){
4636
+ // Find and replace only work on same attribute field, otherwise create a contains rule
4637
  if($pr_array['attribute'] == $pr_array['than_attribute']){
4638
  $newvalue = str_replace($pr_array['criteria'],$pr_array['newvalue'], $pd_value);
4639
  $product_data[$pr_array['than_attribute']] = ucfirst($newvalue);
4640
  }
4641
+ }
4642
+ }
4643
+ break;
4644
+ default:
4645
+ break;
4646
+ }
4647
+ } elseif (is_array($pd_value)) {
4648
+
4649
+ // For now only shipping details are in an array
4650
+ foreach ($pd_value as $k => $v){
4651
+ if(is_array($v)){
4652
+ foreach ($v as $kk => $vv){
4653
+ // Only shipping detail rule can be on price for now
4654
+ if($kk == "price"){
4655
+ switch ($pr_array['condition']) {
4656
+ case($pr_array['condition'] = "contains"):
4657
+ if ((preg_match('/'.$pr_array['criteria'].'/', $vv))){
4658
+ $pd_value[$k]['price'] = str_replace($pr_array['criteria'], $pr_array['newvalue'], $vv);
4659
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4660
+ }
4661
+ break;
4662
+ case($pr_array['condition'] = "containsnot"):
4663
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $vv))){
4664
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4665
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4666
+ }
4667
+ break;
4668
+ case($pr_array['condition'] = "="):
4669
+ if (($vv == $pr_array['criteria'])){
4670
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4671
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4672
+ }
4673
+ break;
4674
+ case($pr_array['condition'] = "!="):
4675
+ if (($vv != $pr_array['criteria'])){
4676
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4677
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4678
+ }
4679
+ break;
4680
+ case($pr_array['condition'] = ">"):
4681
+ if (($vv > $pr_array['criteria'])){
4682
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4683
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4684
+ }
4685
+ break;
4686
+ case($pr_array['condition'] = ">="):
4687
+ if (($vv >= $pr_array['criteria'])){
4688
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4689
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4690
+ }
4691
+ break;
4692
+ case($pr_array['condition'] = "<"):
4693
+ if (($vv < $pr_array['criteria'])){
4694
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4695
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4696
+ }
4697
+ break;
4698
+ case($pr_array['condition'] = "=<"):
4699
+ if (($vv <= $pr_array['criteria'])){
4700
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4701
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4702
+ }
4703
+ break;
4704
+ case($pr_array['condition'] = "empty"):
4705
+ if ((strlen($vv) < 1)){
4706
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4707
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4708
+ }
4709
+ break;
4710
+ case($pr_array['condition'] = "multiply"):
4711
+ // Only shipping array
4712
+ if(is_array($pd_value)){
4713
+ $pr_array['criteria'] = strtr($pr_array['criteria'], ',', '.');
4714
+ foreach ($pd_value as $ship_a_key => $shipping_arr){
4715
+ foreach($shipping_arr as $ship_key => $ship_value){
4716
+ if($ship_key == "price"){
4717
+ $ship_pieces = explode(" ", $ship_value);
4718
+ $pd_value = strtr($ship_pieces[1], ',', '.');
4719
+ $newvalue = $pd_value*$pr_array['criteria'];
4720
+ $newvalue = round($newvalue, 2);
4721
+ $newvalue = strtr($newvalue, '.',',');
4722
+ $newvalue = $ship_pieces[0]." ".$newvalue;
4723
+ $product_data[$pr_array['than_attribute']][$ship_a_key]['price'] = $newvalue;
4724
+ }
4725
+ }
4726
+ }
4727
+ }
4728
+ break;
4729
+ default:
4730
+ break;
4731
+ }
4732
+ }
4733
+ }
4734
+ } else {
4735
+ // Rules on product tags
4736
+ foreach ($pd_value as $k => $v){
4737
+
4738
+ // Rules for string values
4739
+ if (!array_key_exists('cs', $pr_array)){
4740
+ $v = strtolower($v);
4741
+ $pr_array['criteria'] = strtolower($pr_array['criteria']);
4742
+ }
4743
+
4744
+ switch ($pr_array['condition']) {
4745
+ case($pr_array['condition'] = "contains"):
4746
+ if ((preg_match('/'.$pr_array['criteria'].'/', $v))){
4747
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4748
+ }
4749
+ break;
4750
+ case($pr_array['condition'] = "containsnot"):
4751
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $v))){
4752
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4753
+ }
4754
+ break;
4755
+ case($pr_array['condition'] = "="):
4756
+ if (($v == $pr_array['criteria'])){
4757
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4758
+ }
4759
+ break;
4760
+ case($pr_array['condition'] = "!="):
4761
+ if (($v != $pr_array['criteria'])){
4762
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4763
+ }
4764
+ break;
4765
+ case($pr_array['condition'] = ">"):
4766
+ if (($v > $pr_array['criteria'])){
4767
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4768
+ }
4769
+ break;
4770
+ case($pr_array['condition'] = ">="):
4771
+ if (($v >= $pr_array['criteria'])){
4772
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4773
+ }
4774
+ break;
4775
+ case($pr_array['condition'] = "<"):
4776
+ if (($v < $pr_array['criteria'])){
4777
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4778
+ }
4779
+ break;
4780
+ case($pr_array['condition'] = "=<"):
4781
+ if (($v <= $pr_array['criteria'])){
4782
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4783
+ }
4784
+ break;
4785
+ case($pr_array['condition'] = "empty"):
4786
+ if ((strlen($v) < 1)){
4787
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4788
+ }
4789
+ break;
4790
+ case($pr_array['condition'] = "multiply"):
4791
+ // Only shipping array
4792
+ if(is_array($v)){
4793
+ $pr_array['criteria'] = strtr($pr_array['criteria'], ',', '.');
4794
+ foreach ($v as $ship_a_key => $shipping_arr){
4795
+ foreach($shipping_arr as $ship_key => $ship_value){
4796
+ if($ship_key == "price"){
4797
+ $ship_pieces = explode(" ", $ship_value);
4798
+ $pd_value = strtr($ship_pieces[1], ',', '.');
4799
+ $newvalue = $pd_value*$pr_array['criteria'];
4800
+ $newvalue = round($newvalue, 2);
4801
+ $newvalue = strtr($newvalue, '.',',');
4802
+ $newvalue = $ship_pieces[0]." ".$newvalue;
4803
+ $product_data[$pr_array['than_attribute']][$ship_a_key]['price'] = $newvalue;
4804
+ }
4805
+ }
4806
+ }
4807
+ }
4808
+ break;
4809
+ default:
4810
+ break;
4811
+ }
4812
+ }
4813
+ }
4814
+ }
4815
+ } else {
4816
+ // Rules for string values
4817
  if (!array_key_exists('cs', $pr_array)){
4818
+ if($pr_array['attribute'] != "image"){
4819
+ $pd_value = strtolower($pd_value);
4820
+ $pr_array['criteria'] = strtolower($pr_array['criteria']);
4821
+ }
4822
+ }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4823
 
4824
+ switch ($pr_array['condition']) {
4825
+ case($pr_array['condition'] = "contains"):
4826
+ if ((preg_match('/'.$pr_array['criteria'].'/', $pd_value))){
4827
+ // Specifically for shipping price rules
4828
+ if(!empty($product_data[$pr_array['than_attribute']])){
4829
+ if(is_array($product_data[$pr_array['than_attribute']])){
4830
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4831
+ for ($x = 0; $x <= $arr_size; $x++) {
4832
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4833
+ }
4834
+ } else {
4835
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4836
+ }
4837
+ } else {
4838
+ // This attribute value is empty for this product
4839
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4840
+ }
4841
+ }
4842
+ break;
4843
+ case($pr_array['condition'] = "containsnot"):
4844
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value))){
4845
+ // Specifically for shipping price rules
4846
+ if(is_array($product_data[$pr_array['than_attribute']])){
4847
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4848
+ for ($x = 0; $x <= $arr_size; $x++) {
4849
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4850
+ }
4851
+ } else {
4852
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4853
+ }
4854
+ }
4855
+ break;
4856
+ case($pr_array['condition'] = "="):
4857
+ if (($pr_array['criteria'] == "$pd_value")){
4858
+ // Specifically for shipping price rules
4859
+ if(is_array($product_data[$pr_array['than_attribute']])){
4860
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4861
+ for ($x = 0; $x <= $arr_size; $x++) {
4862
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4863
+ }
4864
+ } else {
4865
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4866
+ }
4867
+ }
4868
+ $ship = $product_data['shipping'];
4869
+ break;
4870
+ case($pr_array['condition'] = "!="):
4871
+ if (($pr_array['criteria'] != "$pd_value")){
4872
+ // Specifically for shipping price rules
4873
+ if(is_array($product_data[$pr_array['than_attribute']])){
4874
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4875
+ for ($x = 0; $x <= $arr_size; $x++) {
4876
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4877
+ }
4878
+ } else {
4879
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4880
+ }
4881
+ }
4882
+ break;
4883
+ case($pr_array['condition'] = ">"):
4884
+ // Use a lexical order on relational string operators
4885
+ if (($pd_value > $pr_array['criteria'])){
4886
+ // Specifically for shipping price rules
4887
+ if(is_array($product_data[$pr_array['than_attribute']])){
4888
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4889
+ for ($x = 0; $x <= $arr_size; $x++) {
4890
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4891
+ }
4892
+ } else {
4893
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4894
+ }
4895
+ }
4896
+ break;
4897
+ case($pr_array['condition'] = ">="):
4898
+ // Use a lexical order on relational string operators
4899
+ if (($pd_value >= $pr_array['criteria'])){
4900
+ // Specifically for shipping price rules
4901
+ if(is_array($product_data[$pr_array['than_attribute']])){
4902
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4903
+ for ($x = 0; $x <= $arr_size; $x++) {
4904
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4905
+ }
4906
+ } else {
4907
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4908
+ }
4909
+ }
4910
+ break;
4911
+ case($pr_array['condition'] = "<"):
4912
+ // Use a lexical order on relational string operators
4913
+ if (($pd_value < $pr_array['criteria'])){
4914
+ // Specifically for shipping price rules
4915
+ if(isset($product_data[$pr_array['than_attribute']]) AND (is_array($product_data[$pr_array['than_attribute']]))){
4916
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4917
+ for ($x = 0; $x <= $arr_size; $x++) {
4918
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4919
+ }
4920
+ } else {
4921
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4922
+ }
4923
+ }
4924
+ break;
4925
+ case($pr_array['condition'] = "=<"):
4926
+ // Use a lexical order on relational string operators
4927
+ if (($pd_value <= $pr_array['criteria'])){
4928
+ // Specifically for shipping price rules
4929
+ if(is_array($product_data[$pr_array['than_attribute']])){
4930
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4931
+ for ($x = 0; $x <= $arr_size; $x++) {
4932
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4933
+ }
4934
+ } else {
4935
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4936
+ }
4937
+ }
4938
+ break;
4939
+
4940
+ case($pr_array['condition'] = "empty"):
4941
+ if(empty($product_data[$pr_array['attribute']])){
4942
+ if(empty($product_data[$pr_array['than_attribute']])){
4943
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4944
+ } else {
4945
+ $product_data[$pr_array['attribute']] = $product_data[$pr_array['than_attribute']];
4946
+ }
4947
+ }
4948
+ break;
4949
+ case($pr_array['condition'] = "replace"):
4950
+ $product_data[$pr_array['than_attribute']] = str_replace($pr_array['criteria'], $pr_array['newvalue'], $product_data[$pr_array['than_attribute']]);
4951
+ break;
4952
  case($pr_array['condition'] = "findreplace"):
4953
  if (strpos($pd_value, $pr_array['criteria']) !== false){
4954
+ // Make sure that a new value has been set
4955
+ if(!empty($pr_array['newvalue'])){
4956
+ // Find and replace only work on same attribute field, otherwise create a contains rule
4957
  if($pr_array['attribute'] == $pr_array['than_attribute']){
4958
+ $newvalue = str_replace($pr_array['criteria'],$pr_array['newvalue'], $pd_value);
4959
+ //$product_data[$pr_array['than_attribute']] = ucfirst($newvalue);
4960
+ $product_data[$pr_array['than_attribute']] = $newvalue;
4961
+ }
4962
+ }
4963
+ }
4964
  break;
4965
+ default:
4966
+ break;
4967
+ }
4968
+ }
4969
+ } else {
4970
+ // When a rule has been set on an attribute that is not in product_data
4971
+ // Add the newvalue to product_data
4972
+ if (!array_key_exists($pr_array['attribute'], $product_data)){
4973
+ if(!empty($pr_array['newvalue'])){
4974
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4975
+ } else {
4976
+ if(array_key_exists($pr_array['than_attribute'], $product_data)){
4977
+ $product_data[$pr_array['attribute']] = $product_data[$pr_array['than_attribute']];
4978
+ }
4979
+ }
4980
+ }
4981
+ }
4982
+ }
4983
+ }
4984
+ }
4985
+ return $product_data;
4986
+ }
4987
 
4988
  /**
4989
  * Function to exclude products based on individual product exclusions
5006
  }
5007
  }
5008
 
5009
+
5010
+ /**
5011
+ * Execute project filters (include / exclude)
5012
+ */
5013
  private function woocommerce_sea_filters( $project_rules, $product_data ){
5014
+ $allowed = 1;
5015
 
5016
+ // Check if product was already excluded from the feed
5017
+ $product_excluded = ucfirst( get_post_meta( $product_data['id'], '_woosea_exclude_product', true ) );
5018
 
5019
+ if( $product_excluded == "Yes"){
5020
+ $allowed = 0;
5021
+ }
5022
 
5023
+ foreach ($project_rules as $pr_key => $pr_array){
5024
 
5025
+ if($pr_array['attribute'] == "categories"){
5026
+ $pr_array['attribute'] = "raw_categories";
5027
+ }
5028
 
5029
+ //if(array_key_exists($pr_array['attribute'], $product_data)){
5030
 
5031
+ if(!array_key_exists($pr_array['attribute'], $product_data)) {
5032
+ $product_data[$pr_array['attribute']] = ""; // Sets an empty postmeta value in place of a missing one.
5033
+ }
5034
 
5035
+ foreach ($product_data as $pd_key => $pd_value){
5036
+ // Check is there is a rule on specific attributes
5037
+ if(in_array($pd_key, $pr_array, TRUE)){
5038
 
5039
+ if($pd_key == "price"){
5040
+ //$pd_value = @number_format($pd_value,2);
5041
+ $pd_value = wc_format_decimal($pd_value);
5042
+ }
5043
 
5044
+ if (is_numeric($pd_value)){
5045
+ $old_value = $pd_value;
5046
+ if($pd_key == "price"){
5047
+ $pd_value = @number_format($pd_value,2);
5048
+ }
5049
+
5050
+ // Rules for numeric values
5051
+ switch ($pr_array['condition']) {
5052
+ case($pr_array['condition'] = "contains"):
5053
+ if ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
5054
+ $allowed = 0;
5055
+ } elseif ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5056
+ $allowed = 0;
5057
+ }
5058
+ break;
5059
+ case($pr_array['condition'] = "containsnot"):
5060
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
5061
+ $allowed = 0;
5062
+ } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5063
+ $allowed = 0;
5064
+ }
5065
+ break;
 
 
 
 
 
5066
  case($pr_array['condition'] = "="):
5067
+ if (($old_value == $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5068
+ $allowed = 0;
5069
+ } elseif (($old_value != $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5070
+ $allowed = 0;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
5071
  }
5072
+ break;
5073
+ case($pr_array['condition'] = "!="):
5074
+ if (($old_value == $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5075
+ if($allowed <> 0){
5076
+ $allowed = 1;
5077
+ }
5078
+ } elseif (($old_value == $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5079
+ $allowed = 0;
5080
+ }
5081
+ break;
5082
+ case($pr_array['condition'] = ">"):
5083
+ if (($old_value > $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5084
+ $allowed = 0;
5085
+ } elseif (($old_value <= $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5086
+ $allowed = 0;
5087
+ }
5088
+ break;
5089
+ case($pr_array['condition'] = ">="):
5090
+ if (($old_value >= $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5091
+ $allowed = 0;
5092
+ } elseif (($old_value < $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5093
+ $allowed = 0;
5094
+ }
5095
+ break;
5096
+ case($pr_array['condition'] = "<"):
5097
+ if (($old_value < $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5098
+ $allowed = 0;
5099
+ } elseif (($old_value > $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5100
+ $allowed = 0;
5101
+ }
5102
+ break;
5103
+ case($pr_array['condition'] = "=<"):
5104
+ if (($old_value <= $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5105
+ $allowed = 0;
5106
+ } elseif (($old_value > $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5107
+ $allowed = 0;
5108
+ }
5109
+ break;
5110
+ case($pr_array['condition'] = "empty"):
5111
+ if ((strlen($pd_value) < 1) && ($pr_array['than'] == "exclude")){
5112
+ $allowed = 0;
5113
+ } elseif ((strlen($pd_value > 0)) && ($pr_array['than'] == "include_only")){
5114
+ $allowed = 0;
5115
+ }
5116
+ break;
5117
+ default:
5118
+ break;
5119
+ }
5120
+ } elseif (is_array($pd_value)){
5121
+ // Tis can either be a shipping or product_tag array
5122
+ if($pr_array['attribute'] == "product_tag"){
5123
+ $in_tag_array = "not";
5124
+
5125
+ foreach($pd_value as $pt_key => $pt_value){
5126
+ // Rules for string values
5127
+ if (!array_key_exists('cs', $pr_array)){
5128
+ $pt_value = strtolower($pt_value);
5129
+ $pr_array['criteria'] = strtolower($pr_array['criteria']);
5130
+ }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
5131
 
5132
+ if(preg_match('/'.$pr_array['criteria'].'/', $pt_value)){
5133
+ $in_tag_array = "yes";
5134
+ }
5135
+ }
5136
+
5137
+ if($in_tag_array == "yes"){
5138
+ //if(in_array($pr_array['criteria'], $pd_value, TRUE)) {
5139
+ $v = $pr_array['criteria'];
5140
+ switch ($pr_array['condition']) {
5141
+ case($pr_array['condition'] = "contains"):
5142
+ if ((preg_match('/'.$pr_array['criteria'].'/', $v))){
5143
+ if($pr_array['than'] == "include_only"){
5144
+ if($allowed <> 0){
5145
+ $allowed = 1;
5146
+ }
5147
+ } else {
5148
+ $allowed = 0;
5149
+ }
5150
+ } else {
5151
+ $allowed = 0;
5152
+ }
5153
+ break;
5154
+ case($pr_array['condition'] = "containsnot"):
5155
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $v))){
5156
+ if($pr_array['than'] == "include_only"){
5157
+ if($allowed <> 0){
5158
+ $allowed = 1;
5159
+ }
5160
+ } else {
5161
+ $allowed = 0;
5162
+ }
5163
+ } else {
5164
+ $allowed = 0;
5165
+ }
5166
+ break;
5167
+ case($pr_array['condition'] = "="):
5168
+ if (($v == $pr_array['criteria'])){
5169
+ if($pr_array['than'] == "include_only"){
5170
+ if($allowed <> 0){
5171
+ $allowed = 1;
5172
+ }
5173
+ } else {
5174
+ $allowed = 0;
5175
+ }
5176
+ } else {
5177
+ $allowed = 0;
5178
+ }
5179
+ break;
5180
+ case($pr_array['condition'] = "!="):
5181
+ if (($v != $pr_array['criteria'])){
5182
+ if($pr_array['than'] == "include_only"){
5183
+ if($allowed <> 0){
5184
+ $allowed = 1;
5185
+ }
5186
+ } else {
5187
+ $allowed = 0;
5188
+ }
5189
+ }
5190
+ break;
5191
+ case($pr_array['condition'] = ">"):
5192
+ if (($v > $pr_array['criteria'])){
5193
+ if($pr_array['than'] == "include_only"){
5194
+ if($allowed <> 0){
5195
+ $allowed = 1;
5196
+ }
5197
+ } else {
5198
+ $allowed = 0;
5199
+ }
5200
+ }
5201
+ break;
5202
+ case($pr_array['condition'] = ">="):
5203
+ if (($v >= $pr_array['criteria'])){
5204
+ if($pr_array['than'] == "include_only"){
5205
+ if($allowed <> 0){
5206
+ $allowed = 1;
5207
+ }
5208
+ } else {
5209
+ $allowed = 0;
5210
+ }
5211
+ }
5212
+ break;
5213
+ case($pr_array['condition'] = "<"):
5214
+ if (($v < $pr_array['criteria'])){
5215
+ if($pr_array['than'] == "include_only"){
5216
+ if($allowed <> 0){
5217
+ $allowed = 1;
5218
+ }
5219
+ } else {
5220
+ $allowed = 0;
5221
+ }
5222
+ }
5223
+ break;
5224
+ case($pr_array['condition'] = "=<"):
5225
+ if (($v <= $pr_array['criteria'])){
5226
+ if($pr_array['than'] == "include_only"){
5227
+ if($allowed <> 0){
5228
+ $allowed = 1;
5229
+ }
5230
+ } else {
5231
+ $allowed = 0;
5232
+ }
5233
+ }
5234
+ break;
5235
+ case($pr_array['condition'] = "empty"):
5236
+ if (strlen($v) < 1){
5237
+ if($pr_array['than'] == "include_only"){
5238
+ if($allowed <> 0){
5239
+ $allowed = 1;
5240
+ }
5241
+ } else {
5242
+ if(!empty($pt_value)){
5243
+ $allowed = 1;
5244
+ } else {
5245
+ $allowed = 0;
5246
+ }
5247
+ }
5248
+ }
5249
+ break;
5250
+ default:
5251
+ break;
5252
+ }
5253
+ } else {
5254
+ switch ($pr_array['condition']) {
5255
+ case($pr_array['condition'] = "contains"):
5256
+ if($pr_array['than'] == "include_only"){
5257
+ $allowed = 0;
5258
+ } else {
5259
+ if($allowed <> 0){
5260
+ $allowed = 1;
5261
+ }
5262
+ }
5263
+ break;
5264
+ case($pr_array['condition'] = "containsnot"):
5265
+ if($pr_array['than'] == "include_only"){
5266
+ if($allowed <> 0){
5267
+ $allowed = 1;
5268
+ }
5269
+ } else {
5270
+ $allowed = 0;
5271
+ }
5272
+ break;
5273
+ case($pr_array['condition'] = "="):
5274
+ if($pr_array['than'] == "include_only"){
5275
+ $allowed = 0;
5276
+ } else {
5277
+ if($allowed <> 0){
5278
+ $allowed = 1;
5279
+ }
5280
+ }
5281
+ break;
5282
+ case($pr_array['condition'] = "!="):
5283
+ if($pr_array['than'] == "include_only"){
5284
+ if($allowed <> 0){
5285
+ $allowed = 1;
5286
+ }
5287
+ } else {
5288
+ $allowed = 0;
5289
+ }
5290
+ break;
5291
+ case($pr_array['condition'] = ">"):
5292
+ if($pr_array['than'] == "include_only"){
5293
+ $allowed = 0;
5294
+ } else {
5295
+ $allowed = 0;
5296
+ }
5297
+ break;
5298
+ case($pr_array['condition'] = ">="):
5299
+ if($pr_array['than'] == "include_only"){
5300
+ $allowed = 0;
5301
+ } else {
5302
+ $allowed = 0;
5303
+ }
5304
+ break;
5305
+ case($pr_array['condition'] = "<"):
5306
+ if($pr_array['than'] == "include_only"){
5307
+ $allowed = 0;
5308
+ } else {
5309
+ $allowed = 0;
5310
+ }
5311
+ break;
5312
+ case($pr_array['condition'] = "=<"):
5313
+ if($pr_array['than'] == "include_only"){
5314
+ $allowed = 0;
5315
+ } else {
5316
+ $allowed = 0;
5317
+ }
5318
+ break;
5319
+ case($pr_array['condition'] = "empty"):
5320
+ if($pr_array['than'] == "include_only"){
5321
+ if($allowed <> 0){
5322
+ $allowed = 1;
5323
+ }
5324
+ } else {
5325
+ $allowed = 0;
5326
+ }
5327
+ break;
5328
+ default:
5329
+ break;
5330
+ }
5331
+ }
5332
+ } else {
5333
+ // For now only shipping details are in an array
5334
+ foreach ($pd_value as $k => $v){
5335
+ foreach ($v as $kk => $vv){
5336
+ // Only shipping detail rule can be on price for now
5337
+ if($kk == "price"){
5338
+ switch ($pr_array['condition']) {
5339
+ case($pr_array['condition'] = "contains"):
5340
+ if ((preg_match('/'.$pr_array['criteria'].'/', $vv))){
5341
+ $allowed = 0;
5342
+ }
5343
+ break;
5344
+ case($pr_array['condition'] = "containsnot"):
5345
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $vv))){
5346
+ $allowed = 0;
5347
+ }
5348
+ break;
5349
+ case($pr_array['condition'] = "="):
5350
+ if (($vv == $pr_array['criteria'])){
5351
+ $allowed = 0;
5352
+ }
5353
+ break;
5354
+ case($pr_array['condition'] = "!="):
5355
+ if (($vv != $pr_array['criteria'])){
5356
+ $allowed = 0;
5357
+ }
5358
+ break;
5359
+ case($pr_array['condition'] = ">"):
5360
+ if (($vv > $pr_array['criteria'])){
5361
+ $allowed = 0;
5362
+ }
5363
+ break;
5364
+ case($pr_array['condition'] = ">="):
5365
+ if (($vv >= $pr_array['criteria'])){
5366
+ $allowed = 0;
5367
+ }
5368
+ break;
5369
+ case($pr_array['condition'] = "<"):
5370
+ if (($vv < $pr_array['criteria'])){
5371
+ $allowed = 0;
5372
+ }
5373
+ break;
5374
+ case($pr_array['condition'] = "=<"):
5375
+ if (($vv <= $pr_array['criteria'])){
5376
+ $allowed = 0;
5377
+ }
5378
+ break;
5379
+ case($pr_array['condition'] = "empty"):
5380
+ if (strlen($vv) < 1){
5381
+ $allowed = 0;
5382
+ }
5383
+ break;
5384
+ default:
5385
+ break;
5386
+ }
5387
+ }
5388
+ }
5389
+ }
5390
+ }
5391
+ } else {
5392
+ // Filters for string values
5393
+ // If case-sensitve is off than lowercase both the criteria and attribute value
5394
+ if (array_key_exists('cs', $pr_array)){
5395
+ if ($pr_array['cs'] != "on"){
5396
+ $pd_value = strtolower($pd_value);
5397
+ $pr_array['criteria'] = strtolower($pr_array['criteria']);
5398
+ }
5399
+ }
5400
+ $pos = strpos($pd_value, '&amp;');
5401
+ $pos_slash = strpos($pr_array['criteria'], '\\');
5402
+ if($pos !== false){
5403
+ $pd_value = str_replace("&amp;","&",$pd_value);
5404
+ }
5405
+ if($pos_slash !== false){
5406
+ $pr_array['criteria'] = str_replace("\\","",$pr_array['criteria']);
5407
+ }
5408
+
5409
+ switch ($pr_array['condition']) {
5410
+ case($pr_array['condition'] = "contains"):
5411
+ if ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
5412
+ $allowed = 0;
5413
+ } elseif ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5414
+ $allowed = 0;
5415
+ } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5416
+ if($allowed <> 0){
5417
+ $allowed = 1;
5418
+ }
5419
+ }
5420
+ break;
5421
+ case($pr_array['condition'] = "containsnot"):
5422
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
5423
+ $allowed = 0;
5424
+ } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5425
+ $allowed = 0;
5426
+ }
5427
+ break;
5428
  case($pr_array['condition'] = "="):
5429
+ if (($pr_array['criteria'] == "$pd_value") AND ($pr_array['than'] == "exclude")){
5430
  $allowed = 0;
5431
+ } elseif (($pr_array['criteria'] != "$pd_value") && ($pr_array['than'] == "include_only")){
5432
+ $found = strpos($pd_value,$pr_array['criteria']);
5433
+ if ($found !== false) {
5434
+ //for category mapping check if its an array
5435
+ if($pr_array['attribute'] == "raw_categories"){
5436
+ $raw_cats_arr = explode("||",$pd_value);
5437
+ if(is_array($raw_cats_arr)){
5438
+ if(in_array($pr_array['criteria'],$raw_cats_arr, TRUE)){
5439
+ if($allowed <> 0){
5440
+ $allowed = 1;
5441
+ }
5442
+ } else {
5443
+ $allowed = 0;
5444
+ }
5445
+ }
5446
+ } else {
5447
+ if($allowed <> 0){
5448
+ $allowed = 1;
5449
+ }
5450
+ }
5451
+ } else {
5452
+ $allowed = 0;
5453
+ }
5454
+ } elseif (($pr_array['criteria'] == "$pd_value") && ($pr_array['than'] == "include_only")){
5455
+ if($allowed <> 0){
5456
+ $allowed = 1;
5457
+ }
5458
+ } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
5459
+ // $allowed = 0;
5460
+ } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5461
+ $allowed = 1;
5462
+ } else {
5463
+ // $allowed = 1; // Change made on February 24th 2021
5464
+ }
5465
+ break;
5466
+ case($pr_array['condition'] = "!="):
5467
+ if (($pr_array['criteria'] == "$pd_value") && ($pr_array['than'] == "exclude")){
5468
+ if($allowed <> 0){
5469
+ $allowed = 1;
5470
+ }
5471
+ } elseif (($pr_array['criteria'] == "$pd_value") && ($pr_array['than'] == "include_only")){
5472
+ $allowed = 0;
5473
+ } elseif (($pr_array['criteria'] != "$pd_value") && ($pr_array['than'] == "exclude")){
5474
+ $allowed = 0;
5475
+ }
5476
+ break;
5477
+ case($pr_array['condition'] = ">"):
5478
+ // Use a lexical order on relational string operators
5479
+ if (($pd_value > $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5480
+ $allowed = 0;
5481
+ } elseif (($pd_value < $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5482
+ $allowed = 0;
5483
+ }
5484
+ break;
5485
+ case($pr_array['condition'] = ">="):
5486
+ // Use a lexical order on relational string operators
5487
+ if (($pd_value >= $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5488
+ $allowed = 0;
5489
+ } elseif (($pd_value < $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5490
+ $allowed = 0;
5491
+ }
5492
+ break;
5493
+ case($pr_array['condition'] = "<"):
5494
+ // Use a lexical order on relational string operators
5495
+ if (($pd_value < $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5496
+ $allowed = 0;
5497
+ } elseif (($pd_value > $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5498
+ $allowed = 0;
5499
+ }
5500
+ break;
5501
+ case($pr_array['condition'] = "=<"):
5502
+ // Use a lexical order on relational string operators
5503
+ if (($pd_value <= $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5504
+ $allowed = 0;
5505
+ } elseif (($pd_value > $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5506
+ $allowed = 0;
5507
+ }
5508
+ break;
5509
+ case($pr_array['condition'] = "empty"):
5510
  if ((strlen($pd_value) < 1) && ($pr_array['than'] == "exclude")){
5511
+ $allowed = 0;
5512
+ } elseif ((strlen($pd_value) > 0) && ($pr_array['than'] == "exclude")){
5513
+ if($allowed <> 0){
5514
+ $allowed = 1;
5515
+ }
5516
+ } elseif ((strlen($pd_value) > 0) && ($pr_array['than'] == "include_only")){
5517
+ $allowed = 0;
5518
+ }
5519
+ break;
5520
+ default:
5521
+ break;
5522
+ }
5523
+ }
5524
+ }
5525
+ }
5526
+ }
5527
 
5528
+ if ($allowed < 1){
5529
+ $product_data = array();
5530
+ $product_data = null;
5531
+ } else {
5532
+ return $product_data;
5533
+ }
5534
+ }
5535
  }
js/woosea_autocomplete.js CHANGED
@@ -5695,8 +5695,10 @@ jQuery(document).ready(function($) {
5695
  jQuery(".js-autosuggest").on('click',function(){
5696
  var className = $(this).attr("class").split(' ')[3];
5697
  var rowCount = className.split("_")[1]
5698
-
5699
- jQuery( ".autocomplete_" + rowCount ).typeahead({
 
 
5700
  input: '.js-autosuggest',
5701
  source: google_taxonomy,
5702
  hint: true,
@@ -5708,7 +5710,6 @@ jQuery(document).ready(function($) {
5708
  });
5709
  jQuery( ".autocomplete_" + rowCount ).focus();
5710
 
5711
-
5712
  jQuery(this).on('change', function(){ // on change of state
5713
 
5714
  var minimum = 1;
@@ -5741,7 +5742,6 @@ jQuery(document).ready(function($) {
5741
  }
5742
  } else {
5743
  var map_to_category = "";
5744
-
5745
  jQuery.ajax({
5746
  method: "POST",
5747
  url: ajaxurl,
5695
  jQuery(".js-autosuggest").on('click',function(){
5696
  var className = $(this).attr("class").split(' ')[3];
5697
  var rowCount = className.split("_")[1]
5698
+
5699
+ //$('#the-basics-11603 .autocomplete_11603').typeahead({
5700
+ jQuery("." + className).typeahead({
5701
+ //jQuery(".autocomplete_" + rowCount ).typeahead({
5702
  input: '.js-autosuggest',
5703
  source: google_taxonomy,
5704
  hint: true,
5710
  });
5711
  jQuery( ".autocomplete_" + rowCount ).focus();
5712
 
 
5713
  jQuery(this).on('change', function(){ // on change of state
5714
 
5715
  var minimum = 1;
5742
  }
5743
  } else {
5744
  var map_to_category = "";
 
5745
  jQuery.ajax({
5746
  method: "POST",
5747
  url: ajaxurl,
js/woosea_key.js CHANGED
@@ -27,7 +27,7 @@ jQuery(document).ready(function($) {
27
  var license_key = $('#license-key').val();
28
 
29
  jQuery.ajax({
30
- url: 'https://www.adtribes.io/check/license.php?key=' + license_key + '&email=' + license_email + '&domain=' + root_domain + '&version=9.3.7',
31
  jsonp: 'callback',
32
  dataType: 'jsonp',
33
  type: 'GET',
27
  var license_key = $('#license-key').val();
28
 
29
  jQuery.ajax({
30
+ url: 'https://www.adtribes.io/check/license.php?key=' + license_key + '&email=' + license_email + '&domain=' + root_domain + '&version=9.7.5',
31
  jsonp: 'callback',
32
  dataType: 'jsonp',
33
  type: 'GET',
js/woosea_manage.js CHANGED
@@ -256,6 +256,26 @@ jQuery(function($) {
256
  }
257
  })
258
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
259
  // Check if user would like to enable debug logging
260
  $('#add_woosea_logging').on('change', function(){ // on change of state
261
  if(this.checked){
256
  }
257
  })
258
 
259
+ // Check if user would like the plugin to remove the free shipping class
260
+ $('#remove_free_shipping').on('change', function(){ // on change of state
261
+ if(this.checked){
262
+
263
+ // Checkbox is on
264
+ jQuery.ajax({
265
+ method: "POST",
266
+ url: ajaxurl,
267
+ data: { 'action': 'woosea_remove_free_shipping', 'status': "on" }
268
+ })
269
+ } else {
270
+ // Checkbox is off
271
+ jQuery.ajax({
272
+ method: "POST",
273
+ url: ajaxurl,
274
+ data: { 'action': 'woosea_remove_free_shipping', 'status': "off" }
275
+ })
276
+ }
277
+ })
278
+
279
  // Check if user would like to enable debug logging
280
  $('#add_woosea_logging').on('change', function(){ // on change of state
281
  if(this.checked){
pages/admin/woosea-generate-feed-step-1.php CHANGED
@@ -101,7 +101,7 @@ function woosea_hierarchical_term_tree($category, $prev_mapped){
101
 
102
  $r .= "<tr class=\"catmapping\">";
103
  $r .= "<td><input type=\"hidden\" name=\"mappings[$x][rowCount]\" value=\"$x\"><input type=\"hidden\" name=\"mappings[$x][categoryId]\" value=\"$woo_category_id\"><input type=\"hidden\" name=\"mappings[$x][criteria]\" class=\"input-field-large\" id=\"$woo_category_id\" value=\"$woo_category\">$woo_category ($sub_category->count)</td>";
104
- $r .= "<td><input type=\"search\" name=\"mappings[$x][map_to_category]\" class=\"$mapped_active_class js-typeahead js-autosuggest autocomplete_$x\" value=\"$mapped_category\"></td>";
105
  if(($yo == $nr_categories) AND ($nr_subcats == 0)){
106
  $r .= "<td><span class=\"copy_category_$x\" style=\"display: inline-block;\" title=\"Copy this category to all others\"></span></td>";
107
  } else {
@@ -115,7 +115,7 @@ function woosea_hierarchical_term_tree($category, $prev_mapped){
115
  } else {
116
  $r .= "<tr class=\"catmapping\">";
117
  $r .= "<td><input type=\"hidden\" name=\"mappings[$x][rowCount]\" value=\"$x\"><input type=\"hidden\" name=\"mappings[$x][categoryId]\" value=\"$woo_category_id\"><input type=\"hidden\" name=\"mappings[$x][criteria]\" class=\"input-field-large\" id=\"$woo_category_id\" value=\"$woo_category\">-- $woo_category ($sub_category->count)</td>";
118
- $r .= "<td><input type=\"search\" name=\"mappings[$x][map_to_category]\" class=\"$mapped_active_class js-typeahead js-autosuggest autocomplete_$x mother_$sub_category->parent\" value=\"$mapped_category\"></td>";
119
  $r .= "<td><span class=\"copy_category_$x\" style=\"display: inline-block;\" title=\"Copy this category to all others\"></span></td>";
120
  $r .= "</tr>";
121
  }
@@ -227,7 +227,7 @@ function woosea_hierarchical_term_tree($category, $prev_mapped){
227
 
228
  <table class="woo-product-feed-pro-table">
229
  <tr>
230
- <td><strong><?php _e( 'We\’ve got you covered!','woo-product-feed-pro' );?></strong></td>
231
  </tr>
232
  <tr>
233
  <td>
101
 
102
  $r .= "<tr class=\"catmapping\">";
103
  $r .= "<td><input type=\"hidden\" name=\"mappings[$x][rowCount]\" value=\"$x\"><input type=\"hidden\" name=\"mappings[$x][categoryId]\" value=\"$woo_category_id\"><input type=\"hidden\" name=\"mappings[$x][criteria]\" class=\"input-field-large\" id=\"$woo_category_id\" value=\"$woo_category\">$woo_category ($sub_category->count)</td>";
104
+ $r .= "<td><div id=\"the-basics-$x\"><input type=\"search\" name=\"mappings[$x][map_to_category]\" class=\"$mapped_active_class js-typeahead js-autosuggest autocomplete_$x\" value=\"$mapped_category\"></div></td>";
105
  if(($yo == $nr_categories) AND ($nr_subcats == 0)){
106
  $r .= "<td><span class=\"copy_category_$x\" style=\"display: inline-block;\" title=\"Copy this category to all others\"></span></td>";
107
  } else {
115
  } else {
116
  $r .= "<tr class=\"catmapping\">";
117
  $r .= "<td><input type=\"hidden\" name=\"mappings[$x][rowCount]\" value=\"$x\"><input type=\"hidden\" name=\"mappings[$x][categoryId]\" value=\"$woo_category_id\"><input type=\"hidden\" name=\"mappings[$x][criteria]\" class=\"input-field-large\" id=\"$woo_category_id\" value=\"$woo_category\">-- $woo_category ($sub_category->count)</td>";
118
+ $r .= "<td><div id=\"the-basics-$x\"><input type=\"search\" name=\"mappings[$x][map_to_category]\" class=\"$mapped_active_class js-typeahead js-autosuggest autocomplete_$x mother_$sub_category->parent\" value=\"$mapped_category\"></div></td>";
119
  $r .= "<td><span class=\"copy_category_$x\" style=\"display: inline-block;\" title=\"Copy this category to all others\"></span></td>";
120
  $r .= "</tr>";
121
  }
227
 
228
  <table class="woo-product-feed-pro-table">
229
  <tr>
230
+ <td><strong><?php _e( 'We have got you covered!','woo-product-feed-pro' );?></strong></td>
231
  </tr>
232
  <tr>
233
  <td>
pages/admin/woosea-manage-feed.php CHANGED
@@ -67,6 +67,7 @@ if(!empty($license_information)){
67
  if (!wp_next_scheduled( 'woosea_cron_hook' ) ) {
68
  $notifications_box = $notifications_obj->get_admin_notifications ( '12', 'false' );
69
  }
 
70
  ?>
71
  <div class="wrap">
72
  <div class="woo-product-feed-pro-form-style-2">
@@ -124,6 +125,18 @@ if (!wp_next_scheduled( 'woosea_cron_hook' ) ) {
124
  <?php
125
  }
126
  }
 
 
 
 
 
 
 
 
 
 
 
 
127
  ?>
128
 
129
  <div class="woo-product-feed-pro-form-style-2-heading"><?php _e( 'Manage feeds','woo-product-feed-pro' );?></div>
67
  if (!wp_next_scheduled( 'woosea_cron_hook' ) ) {
68
  $notifications_box = $notifications_obj->get_admin_notifications ( '12', 'false' );
69
  }
70
+
71
  ?>
72
  <div class="wrap">
73
  <div class="woo-product-feed-pro-form-style-2">
125
  <?php
126
  }
127
  }
128
+
129
+
130
+ if ( defined( 'DISABLE_WP_CRON' ) && DISABLE_WP_CRON ) {
131
+ ?>
132
+ <div class="notice notice-error is-dismissible">
133
+ <p>
134
+ <strong><?php _e( 'WARNING: Your WP-Cron is disabled', 'woo-product-feed-pro' );?></strong><br/></br/>
135
+ We detected that your WP-cron has been disabled in your wp-config.php file. Our plugin heavily depends on the WP-cron being active otherwise it cannot update and generate your product feeds. <a href="https://adtribes.io/help-my-feed-processing-is-stuck/?utm_source=<?php print"$host";?>&utm_medium=manage-feed&utm_campaign=cron-warning&utm_content=notification" target="_blank"><strong>Please enable your WP-cron first</strong></a>.
136
+ </p>
137
+ </div>
138
+ <?php
139
+ }
140
  ?>
141
 
142
  <div class="woo-product-feed-pro-form-style-2-heading"><?php _e( 'Manage feeds','woo-product-feed-pro' );?></div>
pages/admin/woosea-manage-settings.php CHANGED
@@ -101,6 +101,20 @@ if(isset($_GET["tab"])) {
101
  ?>
102
  </span>
103
  </div>
 
 
 
 
 
 
 
 
 
 
 
 
 
 
104
 
105
  <!-- wordpress provides the styling for tabs. -->
106
  <h2 class="nav-tab-wrapper">
@@ -290,6 +304,24 @@ if(isset($_GET["tab"])) {
290
  </label>
291
  </td>
292
  </tr>
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
293
  <tr>
294
  <td>
295
  <span><?php _e( 'Remove the local pickup shipping zone from feed (Google Shopping / Facebook only)', 'woo-product-feed-pro');?></span>
@@ -440,11 +472,11 @@ if(isset($_GET["tab"])) {
440
  $external_path_tsv = $external_base . "/woo-product-feed-pro/";
441
  $external_path_logs = $external_base . "/woo-product-feed-pro/";
442
  $test_file = $external_path . "/tesfile.txt";
443
- $test_file_xml = $external_path . "/xml/tesfile.txt";
444
- $test_file_csv = $external_path . "/csv/tesfile.txt";
445
- $test_file_txt = $external_path . "/txt/tesfile.txt";
446
- $test_file_tsv = $external_path . "/tsv/tesfile.txt";
447
- $test_file_logs = $external_path . "/logs/tesfile.txt";
448
 
449
  if (is_writable($external_path)) {
450
  // Normal root category
@@ -515,6 +547,10 @@ if(isset($_GET["tab"])) {
515
  $cron_enabled = "True";
516
  }
517
 
 
 
 
 
518
  print "<table class=\"woo-product-feed-pro-table\">";
519
  print "<tr><td><strong>System check</strong></td><td><strong>Status</strong></td></tr>";
520
  print "<tr><td>WP-Cron enabled</td><td>$cron_enabled</td></tr>";
101
  ?>
102
  </span>
103
  </div>
104
+
105
+ <?php
106
+ if ( defined( 'DISABLE_WP_CRON' ) && DISABLE_WP_CRON ) {
107
+ ?>
108
+ <div class="notice notice-error is-dismissible">
109
+ <p>
110
+ <strong><?php _e( 'WARNING: Your WP-Cron is disabled', 'woo-product-feed-pro' );?></strong><br/></br/>
111
+ We detected that your WP-cron has been disabled in your wp-config.php file. Our plugin heavily depends on the WP-cron being active for it to be able to update and generate your product feeds. More information on the inner workings of our plugin and instructions on how to enable your WP-Cron can be found here: <a href="https://adtribes.io/help-my-feed-processing-is-stuck/?utm_source=<?php print"$host";?>&utm_medium=manage-feed&utm_campaign=cron-warning&utm_content=notification" target="_blank"><strong>My feed won't update or is stuck processing</strong></a>.
112
+ </p>
113
+ </div>
114
+ <?php
115
+ }
116
+ ?>
117
+
118
 
119
  <!-- wordpress provides the styling for tabs. -->
120
  <h2 class="nav-tab-wrapper">
304
  </label>
305
  </td>
306
  </tr>
307
+ <tr>
308
+ <td>
309
+ <span><?php _e( 'Remove the free shipping zone from feed (Google Shopping / Facebook only)', 'woo-product-feed-pro');?></span>
310
+ </td>
311
+ <td>
312
+ <label class="woo-product-feed-pro-switch">
313
+ <?php
314
+ $remove_free_shipping = get_option ('remove_free_shipping');
315
+ if($remove_free_shipping == "yes"){
316
+ print "<input type=\"checkbox\" id=\"remove_free_shipping\" name=\"remove_free_shipping\" class=\"checkbox-field\" checked>";
317
+ } else {
318
+ print "<input type=\"checkbox\" id=\"remove_free_shipping\" name=\"remove_free_shipping\" class=\"checkbox-field\">";
319
+ }
320
+ ?>
321
+ <div class="woo-product-feed-pro-slider round"></div>
322
+ </label>
323
+ </td>
324
+ </tr>
325
  <tr>
326
  <td>
327
  <span><?php _e( 'Remove the local pickup shipping zone from feed (Google Shopping / Facebook only)', 'woo-product-feed-pro');?></span>
472
  $external_path_tsv = $external_base . "/woo-product-feed-pro/";
473
  $external_path_logs = $external_base . "/woo-product-feed-pro/";
474
  $test_file = $external_path . "/tesfile.txt";
475
+ $test_file_xml = $external_path . "xml/tesfile.txt";
476
+ $test_file_csv = $external_path . "csv/tesfile.txt";
477
+ $test_file_txt = $external_path . "txt/tesfile.txt";
478
+ $test_file_tsv = $external_path . "tsv/tesfile.txt";
479
+ $test_file_logs = $external_path . "logs/tesfile.txt";
480
 
481
  if (is_writable($external_path)) {
482
  // Normal root category
547
  $cron_enabled = "True";
548
  }
549
 
550
+ if ( defined( 'DISABLE_WP_CRON' ) && DISABLE_WP_CRON ) {
551
+ $cron_enabled = "<strong>False</strong>";
552
+ }
553
+
554
  print "<table class=\"woo-product-feed-pro-table\">";
555
  print "<tr><td><strong>System check</strong></td><td><strong>Status</strong></td></tr>";
556
  print "<tr><td>WP-Cron enabled</td><td>$cron_enabled</td></tr>";
readme.txt CHANGED
@@ -5,11 +5,11 @@ License URI: http://www.gnu.org/licenses/gpl.html
5
  Tags: Product Feed, Google Shopping, Google Shopping Feed, WooCommerce Product Feed, WooCommerce Product Feed PRO, Bing Shopping, Bing product feed, Bing remarking, Google Merchant Feed, Google DRM Feed, Google Dynamic Remarketing Feed, Facebook feed, Google feed, Bing feed, Facebook Product Feed, Facebook Dynamic remarketing, Data Feed, WooCommerce Feed, XML product feed, CSV product feed, TSV, TXT product feed, comparison shopping engines, comparison shopping websites, vergelijk.nl, vergelijk.be, vertaa.fi, beslist.nl, kieskeurig.nl, bol.com, raketten, pricerunner, pricegrabber, Buy, leGuide, Kelkoo, Twenga, Yandex, Etsy, Dealtime, Shopzilla, Billiger, Google Product Review feed
6
  Requires at least: 4.5
7
  Tested up to: 5.6
8
- Stable tag: 9.3.7
9
 
10
  == Description ==
11
 
12
- Generate WooCommerce product feeds for all your marketing channels, such as Google Shopping (merchant center), Facebook Remarketing, Bing Ads, Billiger.de, Pricerunner, Vergelijk.nl and many more. Next to custom feeds there are over 100 pre-defined templates included for marketplaces, comparison shopping engines and search engines. This plugin provides high-quality product feed for Google Shopping and many many more.
13
 
14
  = Why choose this plugin? =
15
  Simply because this is the most complete plugin offering support for an unlimited number of products and feeds, including features such as category- & field-mapping and advanced, rule-based, filtering and product variables support.
@@ -160,6 +160,7 @@ Some of the above mentioned feature can only be used by users who upgraded to th
160
  * Google Shopping Actions
161
  * Facebook Dynamic Ad’s / remarketing
162
  * Bing Shopping
 
163
  * Pinterest
164
  * <a href="https://businesshelp.snapchat.com/en-US/a/product-catalog-specs" target="_blank">Snapchat</a>
165
  * <a href="https://yandex.com/support/market-tech-requirements/index.html" target="_blank">Yandex</a>
@@ -175,6 +176,7 @@ Some of the above mentioned feature can only be used by users who upgraded to th
175
  * <a href="https://www.beslist.nl" target="_blank" rel="nofollow">Beslist.nl</a>
176
  * <a href="https://www.beslist.be" target="_blank" rel="nofollow">Beslist.be</a>
177
  * <a href="https://www.fashionchick.nl" target="_blank">Fashionchick.nl</a>
 
178
  * Bol.com
179
  * Stylight
180
  * Incurvy
@@ -229,6 +231,7 @@ Some of the above mentioned feature can only be used by users who upgraded to th
229
  * <a href="https://www.guenstiger.de" target="_blank" rel="nofollow">Guenstiger.de</a>
230
  * Hood.de
231
  * Ladenzeile.de
 
232
  * Livingo.de
233
  * Medizinfuchs.de
234
  * <a href="https://www.moebel.de" target="_blank">Moebel.de</a>
@@ -322,6 +325,126 @@ Questions left or unanswered? Please do not hesitate to contact us at support@ad
322
 
323
  === Changelog ===
324
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
325
  = 9.3.7 (2021-01-12) =
326
  * Added the Bestprice.gr template
327
 
@@ -2988,6 +3111,126 @@ Questions left or unanswered? Please do not hesitate to contact us at support@ad
2988
 
2989
  == Upgrade Notice ==
2990
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2991
  = 9.3.7 =
2992
  Added the Bestprice.gr template
2993
 
5
  Tags: Product Feed, Google Shopping, Google Shopping Feed, WooCommerce Product Feed, WooCommerce Product Feed PRO, Bing Shopping, Bing product feed, Bing remarking, Google Merchant Feed, Google DRM Feed, Google Dynamic Remarketing Feed, Facebook feed, Google feed, Bing feed, Facebook Product Feed, Facebook Dynamic remarketing, Data Feed, WooCommerce Feed, XML product feed, CSV product feed, TSV, TXT product feed, comparison shopping engines, comparison shopping websites, vergelijk.nl, vergelijk.be, vertaa.fi, beslist.nl, kieskeurig.nl, bol.com, raketten, pricerunner, pricegrabber, Buy, leGuide, Kelkoo, Twenga, Yandex, Etsy, Dealtime, Shopzilla, Billiger, Google Product Review feed
6
  Requires at least: 4.5
7
  Tested up to: 5.6
8
+ Stable tag: 9.7.5
9
 
10
  == Description ==
11
 
12
+ Generate WooCommerce product feeds for all your marketing channels, such as Google Shopping (merchant center), Facebook Remarketing, Bing Ads, Billiger.de, Pricerunner, Skroutz and many more. Next to custom feeds there are over 100 pre-defined templates included for marketplaces, comparison shopping engines and search engines. This plugin provides high-quality product feed for Google Shopping and many many more.
13
 
14
  = Why choose this plugin? =
15
  Simply because this is the most complete plugin offering support for an unlimited number of products and feeds, including features such as category- & field-mapping and advanced, rule-based, filtering and product variables support.
160
  * Google Shopping Actions
161
  * Facebook Dynamic Ad’s / remarketing
162
  * Bing Shopping
163
+ * Bing Shopping Promotions
164
  * Pinterest
165
  * <a href="https://businesshelp.snapchat.com/en-US/a/product-catalog-specs" target="_blank">Snapchat</a>
166
  * <a href="https://yandex.com/support/market-tech-requirements/index.html" target="_blank">Yandex</a>
176
  * <a href="https://www.beslist.nl" target="_blank" rel="nofollow">Beslist.nl</a>
177
  * <a href="https://www.beslist.be" target="_blank" rel="nofollow">Beslist.be</a>
178
  * <a href="https://www.fashionchick.nl" target="_blank">Fashionchick.nl</a>
179
+ * <a href="https://www.boetiek.nl" target="_blank">Boetiek.nl</a>
180
  * Bol.com
181
  * Stylight
182
  * Incurvy
231
  * <a href="https://www.guenstiger.de" target="_blank" rel="nofollow">Guenstiger.de</a>
232
  * Hood.de
233
  * Ladenzeile.de
234
+ * Idealo.de
235
  * Livingo.de
236
  * Medizinfuchs.de
237
  * <a href="https://www.moebel.de" target="_blank">Moebel.de</a>
325
 
326
  === Changelog ===
327
 
328
+ = 9.7.5 (2021-03-07) =
329
+ * Another recode of the lowest price variation feature
330
+
331
+ = 9.7.4 (2021-03-05) =
332
+ * Added Bing Shopping Promotions template
333
+
334
+ = 9.7.3 (2021-03-04) =
335
+ * Added a new attribute "Stock Status WooCommerce"
336
+ * Fixed another quote issue with the Facebook pixel
337
+
338
+ = 9.7.2 (2021-03-03) =
339
+ * Fixed an issue with the Facebook pixel. Product names that had an apostrophe in them were not measured.
340
+
341
+ = 9.7.1 (2021-03-03) =
342
+ * Added another fix to take into account prices excluding VAT for filtering out all but the minimum priced variation
343
+
344
+ = 9.7.0 (2021-03-03) =
345
+ * Fixed a bug where lowest priced variations where not making it to feeds
346
+
347
+ = 9.6.9 (2021-02-28) =
348
+ * Added product name parent hyphen attribute
349
+
350
+ = 9.6.8 (2021-02-25) =
351
+ * Added Google category taxonomy mapping for Snapchat feeds
352
+
353
+ = 9.6.7 (2021-02-25) =
354
+ * When suffixes and prefixes are used for the Heureka URL fields spaces are removed
355
+
356
+ = 9.6.6 (2021-02-24) =
357
+ * Added support for PHP 8.0
358
+
359
+ = 9.6.5 (2021-02-24) =
360
+ * Do not add Skroutz variable products to the feed when they do not have item_group_id's
361
+
362
+ = 9.6.4 (2021-02-24) =
363
+ * Fixed an issue with rules and filters
364
+ * When a rule was set on an image link, no longer lowercase the image link
365
+
366
+ = 9.6.3 (2021-02-23) =
367
+ * Fixed a bug, the Facebook pixel is now also measuing revenue for multiple items in Cart, InititiateCheckout and Purchase events
368
+ * Reverted back some changes in filters and rules
369
+
370
+ = 9.6.2 (2021-02-22) =
371
+ * For Skroutz feed removing sizes from feeds when they are out-of-stock
372
+
373
+ = 9.6.1 (2021-02-19) =
374
+ * Added attribute that will allow you to uppercase every first character of a string in product names
375
+
376
+ = 9.6.0 (2021-02-19) =
377
+ * Changed g:itemid to g:id for the Google Local Product Feeds
378
+
379
+ = 9.5.9 (2021-02-19) =
380
+ * Added a fail-safe when users do not select a marketing channel which let to PHP notices in logs
381
+
382
+ = 9.5.8 (2021-02-18) =
383
+ * Added shipping class name attribute
384
+
385
+ = 9.5.7 (2021-02-17) =
386
+ * Dynamic attribute values are now also added to parent variable products for Skroutz feeds
387
+
388
+ = 9.5.6 (2021-02-17) =
389
+ * Changed attribute name primary category to Yoast primary category as it caused lots of confussion
390
+
391
+ = 9.5.5 (2021-02-11) =
392
+ * Fixed a PHP notice that showed when creating a new rule
393
+ * Tested for compatibility with WooCommerce 5.0
394
+
395
+ = 9.5.4 (2021-02-09) =
396
+ * When free shipping zones are removed do not remove the other shipping zones
397
+
398
+ = 9.5.3 (2021-02-08) =
399
+ * Added a feature to remove free shipping zones from Google and Facebook feeds
400
+
401
+ = 9.5.2 (2021-02-08) =
402
+ * Fixed a minor issue in exclude rules for WooCommerce category names
403
+
404
+ = 9.5.1 (2021-02-02) =
405
+ * Dynamic attributes without values that are used for product details should be skipped which not always happened. This is fixed now.
406
+
407
+ = 9.5.0 (2021-02-01) =
408
+ * Discount rules created with the FlyCart plugin did not make it to Skroutz feeds. This has been solved now
409
+
410
+ = 9.4.9 (2021-01-31) =
411
+ * Added a seperate sale price attribute for bundled products
412
+ * Reviews for parent variable products are removed, the reviews are attached to its variations
413
+
414
+ = 9.4.8 (2021-01-30) =
415
+ * Fixed an issue with the ecomm_prodid on the cart page
416
+
417
+ = 9.4.7 (2021-01-29) =
418
+ * Solved an issue that shipping costs to the first product in a custom feed where empty
419
+
420
+ = 9.4.6 (2021-01-28) =
421
+ * Added a new attribute: product description parent product
422
+
423
+ = 9.4.5 (2021-01-28) =
424
+ * Added a Google Shopping field to their template: g:ship_from_country
425
+ * Stripping & characters from review names as it breaks the review feeds
426
+
427
+ = 9.4.4 (2021-01-27) =
428
+ * Fixed an issue where reviews without review text caused the feed to be disapproved by Google. We now remove reviews from feeds that have no review texts.
429
+
430
+ = 9.4.3 (2021-01-27) =
431
+ * Fixed an issue with an undefined ecomm_price variable on product variable pages
432
+
433
+ = 9.4.2 (2021-01-26) =
434
+ * Added the Dutch Boetiek.nl template
435
+
436
+ = 9.4.1 (2021-01-19) =
437
+ * Fixed a bug: exclude filters on empty product tags were broken. This is fixed now.
438
+
439
+ = 9.4.0 (2021-01-14) =
440
+ * Added a WP-cron check and notifications
441
+
442
+ = 9.3.9 (2021-01-14) =
443
+ * Bestprice.gr apparel products are now grouped by color
444
+
445
+ = 9.3.8 (2021-01-13) =
446
+ * Tested for compatibility with WooCommerce 4.9
447
+
448
  = 9.3.7 (2021-01-12) =
449
  * Added the Bestprice.gr template
450
 
3111
 
3112
  == Upgrade Notice ==
3113
 
3114
+ = 9.7.5 =
3115
+ Another recode of the lowest price variation feature
3116
+
3117
+ = 9.7.4 =
3118
+ Added Bing Shopping Promotions template
3119
+
3120
+ = 9.7.3 =
3121
+ Added a new attribute "Stock Status WooCommerce"
3122
+ Fixed another quote issue with the Facebook pixel
3123
+
3124
+ = 9.7.2 =
3125
+ Fixed an issue with the Facebook pixel. Product names that had an apostrophe in them were not measured.
3126
+
3127
+ = 9.7.1 =
3128
+ Added another fix to take into account prices excluding VAT for filtering out all but the minimum priced variation
3129
+
3130
+ = 9.7.0 =
3131
+ Fixed a bug where lowest priced variations where not making it to feeds
3132
+
3133
+ = 9.6.9 =
3134
+ Added product name parent hyphen attribute
3135
+
3136
+ = 9.6.8 =
3137
+ Added Google category taxonomy mapping for Snapchat feeds
3138
+
3139
+ = 9.6.7 =
3140
+ When suffixes and prefixes are used for the Heureka URL fields spaces are removed
3141
+
3142
+ = 9.6.6 =
3143
+ Added support for PHP 8.0
3144
+
3145
+ = 9.6.5 =
3146
+ Do not add Skroutz variable products to the feed when they do not have item_group_id's
3147
+
3148
+ = 9.6.4 =
3149
+ Fixed an issue with rules and filters
3150
+ When a rule was set on an image link, no longer lowercase the image link
3151
+
3152
+ = 9.6.3 =
3153
+ Fixed a bug, the Facebook pixel is now also measuing revenue for multiple items in Cart, InititiateCheckout and Purchase events
3154
+ Reverted back some changes in filters and rules
3155
+
3156
+ = 9.6.2 =
3157
+ For Skroutz feed removing sizes from feeds when they are out-of-stock
3158
+
3159
+ = 9.6.1 =
3160
+ Added attribute that will allow you to uppercase every first character of a string in product names
3161
+
3162
+ = 9.6.0 =
3163
+ Changed g:itemid to g:id for the Google Local Product Feeds
3164
+
3165
+ = 9.5.9 =
3166
+ * Added a fail-safe when users do not select a marketing channel which let to PHP notices in logs
3167
+
3168
+ = 9.5.8 =
3169
+ Added shipping class name attribute
3170
+
3171
+ = 9.5.7 =
3172
+ Dynamic attribute values are now also added to parent variable products for Skroutz feeds
3173
+
3174
+ = 9.5.6 =
3175
+ Changed attribute name primary category to Yoast primary category as it caused lots of confussion
3176
+
3177
+ = 9.5.5 =
3178
+ Fixed a PHP notice that showed when creating a new rule
3179
+ Tested for compatibility with WooCommerce 5.0
3180
+
3181
+ = 9.5.4 =
3182
+ When free shipping zones are removed do not remove the other shipping zones
3183
+
3184
+ = 9.5.3 =
3185
+ Added a feature to remove free shipping zones from Google and Facebook feeds
3186
+
3187
+ = 9.5.2 =
3188
+ Fixed a minor issue in exclude rules for WooCommerce category names
3189
+
3190
+ = 9.5.1 =
3191
+ Dynamic attributes without values that are used for product details should be skipped which not always happened. This is fixed now.
3192
+
3193
+ = 9.5.0 =
3194
+ Discount rules created with the FlyCart plugin did not make it to Skroutz feeds. This has been solved now
3195
+
3196
+ = 9.4.9 =
3197
+ Added a seperate sale price attribute for bundled products
3198
+ Reviews for parent variable products are removed, the reviews are attached to its variations
3199
+
3200
+ = 9.4.8 =
3201
+ Fixed an issue with the ecomm_prodid on the cart page
3202
+
3203
+ = 9.4.7 =
3204
+ Solved an issue that shipping costs to the first product in a custom feed where empty
3205
+
3206
+ = 9.4.6 =
3207
+ Added a new attribute: product description parent product
3208
+
3209
+ = 9.4.5 =
3210
+ Added a Google Shopping field to their template: g:ship_from_country
3211
+ Stripping & characters from review names as it breaks the review feeds
3212
+
3213
+ = 9.4.4 =
3214
+ Fixed an issue where reviews without review text caused the feed to be disapproved by Google. We now remove reviews from feeds that have no review texts.
3215
+
3216
+ = 9.4.3 =
3217
+ Fixed an issue with an undefined ecomm_price variable on product variable pages
3218
+
3219
+ = 9.4.2 =
3220
+ Added the Dutch Boetiek.nl template
3221
+
3222
+ = 9.4.1 =
3223
+ Fixed a bug: exclude filters on empty product tags were broken. This is fixed now.
3224
+
3225
+ = 9.4.0 =
3226
+ Added a WP-cron check and notifications
3227
+
3228
+ = 9.3.9 =
3229
+ Bestprice.gr apparel products are now grouped by color
3230
+
3231
+ = 9.3.8 =
3232
+ Tested for compatibility with WooCommerce 4.9
3233
+
3234
  = 9.3.7 =
3235
  Added the Bestprice.gr template
3236
 
woocommerce-sea.php CHANGED
@@ -1,7 +1,7 @@
1
  <?php
2
  /**
3
  * Plugin Name: Product Feed PRO for WooCommerce
4
- * Version: 9.3.7
5
  * Plugin URI: https://www.adtribes.io/support/?utm_source=wpadmin&utm_medium=plugin&utm_campaign=woosea_product_feed_pro
6
  * Description: Configure and maintain your WooCommerce product feeds for Google Shopping, Facebook, Remarketing, Bing, Yandex, Comparison shopping websites and over a 100 channels more.
7
  * Author: AdTribes.io
@@ -17,7 +17,7 @@
17
  * Domain Path: /languages
18
  *
19
  * WC requires at least: 4.4
20
- * WC tested up to: 4.8
21
  *
22
  * Product Feed PRO for WooCommerce is free software: you can redistribute it and/or modify
23
  * it under the terms of the GNU General Public License as published by
@@ -48,7 +48,7 @@ if (!defined('ABSPATH')) {
48
  * Plugin versionnumber, please do not override.
49
  * Define some constants
50
  */
51
- define( 'WOOCOMMERCESEA_PLUGIN_VERSION', '9.3.7' );
52
  define( 'WOOCOMMERCESEA_PLUGIN_NAME', 'woocommerce-product-feed-pro' );
53
  define( 'WOOCOMMERCESEA_PLUGIN_NAME_SHORT', 'woo-product-feed-pro' );
54
 
@@ -115,7 +115,7 @@ function woosea_scripts($hook) {
115
  wp_enqueue_script( 'typeahead-js' );
116
 
117
  // JS for adding input field validation
118
- wp_register_script( 'woosea_validation-js', plugin_dir_url( __FILE__ ) . 'js/woosea_validation.js?BLAAT=999', '',WOOCOMMERCESEA_PLUGIN_VERSION, true );
119
  wp_enqueue_script( 'woosea_validation-js' );
120
 
121
  // JS for autocomplete
@@ -123,7 +123,7 @@ function woosea_scripts($hook) {
123
  wp_enqueue_script( 'woosea_autocomplete-js' );
124
 
125
  // JS for adding table rows to the rules page
126
- wp_register_script( 'woosea_rules-js', plugin_dir_url( __FILE__ ) . 'js/woosea_rules.js?BLAAT=1', '',WOOCOMMERCESEA_PLUGIN_VERSION, true );
127
  wp_enqueue_script( 'woosea_rules-js' );
128
 
129
  // JS for adding table rows to the field mappings page
@@ -335,6 +335,9 @@ function woosea_add_facebook_pixel( $product = null ){
335
 
336
  $fb_prodid = get_the_id();
337
  $product_name = $product->get_name();
 
 
 
338
  $cats = "";
339
  $all_cats = get_the_terms( $fb_prodid, 'product_cat' );
340
  if(!empty($all_cats)){
@@ -345,9 +348,10 @@ function woosea_add_facebook_pixel( $product = null ){
345
  // strip last comma
346
  $cats = rtrim($cats, ",");
347
  $cats = str_replace("&amp;","&", $cats);
 
 
348
 
349
  if(!empty($fb_prodid)){
350
-
351
  if(!$product) {
352
  return -1;
353
  }
@@ -436,6 +440,8 @@ function woosea_add_facebook_pixel( $product = null ){
436
  $order_real = 0;
437
  $contents = "";
438
 
 
 
439
  if ( !is_wp_error( $order_items )) {
440
  foreach( $order_items as $item_id => $order_item) {
441
  $prod_id = $order_item->get_product_id();
@@ -454,7 +460,7 @@ function woosea_add_facebook_pixel( $product = null ){
454
  }
455
  }
456
  $contents = rtrim($contents, ",");
457
- $viewContent = "fbq('track','Purchase',{currency:'$currency', value:'$order_real', content_type:'product', contents:[$contents]});";
458
  }
459
  } else {
460
  // This is on the cart page itself
@@ -463,6 +469,8 @@ function woosea_add_facebook_pixel( $product = null ){
463
  $cart_real = 0;
464
  $contents = "";
465
 
 
 
466
  $checkoutpage = wc_get_checkout_url();
467
  $current_url = get_permalink(get_the_ID());
468
 
@@ -477,20 +485,15 @@ function woosea_add_facebook_pixel( $product = null ){
477
  //$contents .= "$prod_id,";
478
 
479
  $cart_real = wc_format_localized_price( $cart_item['line_total'] );
480
-
481
- // $line_total = number_format(($cart_item['line_total']),2, '.','');
482
- // $line_tax = number_format(($cart_item['line_tax']),2, '.','');
483
- // $cart_real = number_format($cart_real,2, '.','');
484
- // $cart_real = number_format(($line_total+$line_tax+$cart_real),2,',','');
485
  }
486
  $contents = rtrim($contents, ",");
487
 
488
  // User is on the billing pages
489
  if($checkoutpage == $current_url){
490
- $viewContent = "fbq(\"track\",\"InitiateCheckout\",{currency:\"$currency\", value:\"$cart_real\", content_type:\"product\", content_ids:[$contents]});";
491
  } else {
492
  // User is on the basket page
493
- $viewContent = "fbq(\"track\",\"AddToCart\",{currency:\"$currency\", value:\"$cart_real\", content_type:\"product\", content_ids:[$contents]});";
494
  }
495
  }
496
  }
@@ -524,7 +527,7 @@ function woosea_add_facebook_pixel( $product = null ){
524
  $fb_prodid = rtrim($fb_prodid, ",");
525
  $category_name = $term->name;
526
  $category_path = woosea_get_term_parents( $term->term_id, 'product_cat', $link = false, $project_taxonomy = false, $nicename = false, $visited = array() );
527
- $viewContent = "fbq(\"track\",\"ViewCategory\",{content_category:\"$category_path\", content_name:\"$category_name\", content_type:\"product\", content_ids:\"[$fb_prodid]\"});";
528
  } elseif ($fb_pagetype == "searchresults"){
529
  $term = get_queried_object();
530
  $search_string = sanitize_text_field($_GET['s']);
@@ -622,7 +625,7 @@ function woosea_add_remarketing_tags( $product = null ){
622
  // In that case we need to put in the AggregateOffer structured data
623
  $variation_id = woosea_find_matching_product_variation( $product, $_GET );
624
  $nr_get = count($_GET);
625
-
626
  if($nr_get > 0){
627
  $variable_product = wc_get_product($variation_id);
628
 
@@ -659,7 +662,9 @@ function woosea_add_remarketing_tags( $product = null ){
659
  $ecomm_price = wc_format_decimal( $lowest, wc_get_price_decimals());
660
  } else {
661
  $ecomm_lowprice = wc_format_decimal( $lowest, wc_get_price_decimals() );
662
- $ecomm_highprice = wc_format_decimal( $highest, wc_get_price_decimals() );
 
 
663
  }
664
  }
665
  } else {
@@ -671,14 +676,18 @@ function woosea_add_remarketing_tags( $product = null ){
671
  var google_tag_params = {
672
  ecomm_prodid: <?php print "$ecomm_prodid";?>,
673
  ecomm_pagetype: '<?php print "$ecomm_pagetype";?>',
674
- ecomm_totalvalue: '<?php print "$ecomm_price";?>',
675
  };
676
  </script>
677
 
678
  <?php
679
  }
680
  } elseif ($ecomm_pagetype == "cart"){
681
- $ecomm_prodid = get_the_id();
 
 
 
 
682
  ?>
683
  <script type="text/javascript">
684
  var google_tag_params = {
@@ -804,6 +813,7 @@ function woosea_request_review(){
804
  }
805
  add_action('admin_notices', 'woosea_request_review');
806
 
 
807
  /**
808
  * Create a seperate MySql table for saving conversion information
809
  */
@@ -2285,6 +2295,21 @@ function woosea_local_pickup_shipping (){
2285
  }
2286
  add_action( 'wp_ajax_woosea_local_pickup_shipping', 'woosea_local_pickup_shipping' );
2287
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2288
  /**
2289
  * This function enables the setting to use
2290
  * logging
@@ -4623,8 +4648,11 @@ add_action('wp_dashboard_setup', 'woosea_blog_widgets');
4623
  /**
4624
  * Creates the RSS metabox
4625
  */
 
 
 
 
4626
  function woosea_my_rss_box() {
4627
-
4628
  // Get RSS Feed(s)
4629
  include_once(ABSPATH . WPINC . '/feed.php');
4630
  $domain = $_SERVER['HTTP_HOST'];
@@ -4633,6 +4661,8 @@ function woosea_my_rss_box() {
4633
  $my_feeds = array(
4634
  'https://www.adtribes.io/feed/'
4635
  );
 
 
4636
 
4637
  // Loop through Feeds
4638
  foreach ( $my_feeds as $feed) :
1
  <?php
2
  /**
3
  * Plugin Name: Product Feed PRO for WooCommerce
4
+ * Version: 9.7.5
5
  * Plugin URI: https://www.adtribes.io/support/?utm_source=wpadmin&utm_medium=plugin&utm_campaign=woosea_product_feed_pro
6
  * Description: Configure and maintain your WooCommerce product feeds for Google Shopping, Facebook, Remarketing, Bing, Yandex, Comparison shopping websites and over a 100 channels more.
7
  * Author: AdTribes.io
17
  * Domain Path: /languages
18
  *
19
  * WC requires at least: 4.4
20
+ * WC tested up to: 5.0
21
  *
22
  * Product Feed PRO for WooCommerce is free software: you can redistribute it and/or modify
23
  * it under the terms of the GNU General Public License as published by
48
  * Plugin versionnumber, please do not override.
49
  * Define some constants
50
  */
51
+ define( 'WOOCOMMERCESEA_PLUGIN_VERSION', '9.7.5' );
52
  define( 'WOOCOMMERCESEA_PLUGIN_NAME', 'woocommerce-product-feed-pro' );
53
  define( 'WOOCOMMERCESEA_PLUGIN_NAME_SHORT', 'woo-product-feed-pro' );
54
 
115
  wp_enqueue_script( 'typeahead-js' );
116
 
117
  // JS for adding input field validation
118
+ wp_register_script( 'woosea_validation-js', plugin_dir_url( __FILE__ ) . 'js/woosea_validation.js', '',WOOCOMMERCESEA_PLUGIN_VERSION, true );
119
  wp_enqueue_script( 'woosea_validation-js' );
120
 
121
  // JS for autocomplete
123
  wp_enqueue_script( 'woosea_autocomplete-js' );
124
 
125
  // JS for adding table rows to the rules page
126
+ wp_register_script( 'woosea_rules-js', plugin_dir_url( __FILE__ ) . 'js/woosea_rules.js', '',WOOCOMMERCESEA_PLUGIN_VERSION, true );
127
  wp_enqueue_script( 'woosea_rules-js' );
128
 
129
  // JS for adding table rows to the field mappings page
335
 
336
  $fb_prodid = get_the_id();
337
  $product_name = $product->get_name();
338
+ $product_name = str_replace("\"","",$product_name);
339
+ $product_name = str_replace("'","",$product_name);
340
+
341
  $cats = "";
342
  $all_cats = get_the_terms( $fb_prodid, 'product_cat' );
343
  if(!empty($all_cats)){
348
  // strip last comma
349
  $cats = rtrim($cats, ",");
350
  $cats = str_replace("&amp;","&", $cats);
351
+ $cats = str_replace("\"","",$cats);
352
+ $cats = str_replace("'","",$cats);
353
 
354
  if(!empty($fb_prodid)){
 
355
  if(!$product) {
356
  return -1;
357
  }
440
  $order_real = 0;
441
  $contents = "";
442
 
443
+ $cart_total_amount = wc_format_localized_price(WC()->cart->get_cart_contents_total());
444
+
445
  if ( !is_wp_error( $order_items )) {
446
  foreach( $order_items as $item_id => $order_item) {
447
  $prod_id = $order_item->get_product_id();
460
  }
461
  }
462
  $contents = rtrim($contents, ",");
463
+ $viewContent = "fbq('track','Purchase',{currency:'$currency', value:'$cart_total_amount', content_type:'product', contents:[$contents]});";
464
  }
465
  } else {
466
  // This is on the cart page itself
469
  $cart_real = 0;
470
  $contents = "";
471
 
472
+ $cart_total_amount = wc_format_localized_price(WC()->cart->get_cart_contents_total());
473
+
474
  $checkoutpage = wc_get_checkout_url();
475
  $current_url = get_permalink(get_the_ID());
476
 
485
  //$contents .= "$prod_id,";
486
 
487
  $cart_real = wc_format_localized_price( $cart_item['line_total'] );
 
 
 
 
 
488
  }
489
  $contents = rtrim($contents, ",");
490
 
491
  // User is on the billing pages
492
  if($checkoutpage == $current_url){
493
+ $viewContent = "fbq(\"track\",\"InitiateCheckout\",{currency:\"$currency\", value:\"$cart_total_amount\", content_type:\"product\", content_ids:[$contents]});";
494
  } else {
495
  // User is on the basket page
496
+ $viewContent = "fbq(\"track\",\"AddToCart\",{currency:\"$currency\", value:\"$cart_total_amount\", content_type:\"product\", content_ids:[$contents]});";
497
  }
498
  }
499
  }
527
  $fb_prodid = rtrim($fb_prodid, ",");
528
  $category_name = $term->name;
529
  $category_path = woosea_get_term_parents( $term->term_id, 'product_cat', $link = false, $project_taxonomy = false, $nicename = false, $visited = array() );
530
+ $viewContent = "fbq(\"track\",\"ViewCategory\",{content_category:'$category_path', content_name:'$category_name', content_type:\"product\", content_ids:\"[$fb_prodid]\"});";
531
  } elseif ($fb_pagetype == "searchresults"){
532
  $term = get_queried_object();
533
  $search_string = sanitize_text_field($_GET['s']);
625
  // In that case we need to put in the AggregateOffer structured data
626
  $variation_id = woosea_find_matching_product_variation( $product, $_GET );
627
  $nr_get = count($_GET);
628
+
629
  if($nr_get > 0){
630
  $variable_product = wc_get_product($variation_id);
631
 
662
  $ecomm_price = wc_format_decimal( $lowest, wc_get_price_decimals());
663
  } else {
664
  $ecomm_lowprice = wc_format_decimal( $lowest, wc_get_price_decimals() );
665
+ $ecomm_highprice = wc_format_decimal( $highest, wc_get_price_decimals() );
666
+ $ecomm_price = $ecomm_lowprice;
667
+
668
  }
669
  }
670
  } else {
676
  var google_tag_params = {
677
  ecomm_prodid: <?php print "$ecomm_prodid";?>,
678
  ecomm_pagetype: '<?php print "$ecomm_pagetype";?>',
679
+ ecomm_totalvalue: <?php print "$ecomm_price";?>,
680
  };
681
  </script>
682
 
683
  <?php
684
  }
685
  } elseif ($ecomm_pagetype == "cart"){
686
+ // Get the first product from cart and use that product ID
687
+ foreach( WC()->cart->get_cart() as $cart_item ){
688
+ $ecomm_prodid = $cart_item['product_id'];
689
+ break;
690
+ }
691
  ?>
692
  <script type="text/javascript">
693
  var google_tag_params = {
813
  }
814
  add_action('admin_notices', 'woosea_request_review');
815
 
816
+
817
  /**
818
  * Create a seperate MySql table for saving conversion information
819
  */
2295
  }
2296
  add_action( 'wp_ajax_woosea_local_pickup_shipping', 'woosea_local_pickup_shipping' );
2297
 
2298
+ /**
2299
+ * This function enables the setting to remove
2300
+ * free shipping zones
2301
+ */
2302
+ function woosea_remove_free_shipping (){
2303
+ $status = sanitize_text_field($_POST['status']);
2304
+
2305
+ if ($status == "off"){
2306
+ update_option( 'remove_free_shipping', 'no', 'yes');
2307
+ } else {
2308
+ update_option( 'remove_free_shipping', 'yes', 'yes');
2309
+ }
2310
+ }
2311
+ add_action( 'wp_ajax_woosea_remove_free_shipping', 'woosea_remove_free_shipping' );
2312
+
2313
  /**
2314
  * This function enables the setting to use
2315
  * logging
4648
  /**
4649
  * Creates the RSS metabox
4650
  */
4651
+ function woosea_feed_interval( $seconds ) {
4652
+ return 172800; // Cache the feed for 2 days
4653
+ }
4654
+
4655
  function woosea_my_rss_box() {
 
4656
  // Get RSS Feed(s)
4657
  include_once(ABSPATH . WPINC . '/feed.php');
4658
  $domain = $_SERVER['HTTP_HOST'];
4661
  $my_feeds = array(
4662
  'https://www.adtribes.io/feed/'
4663
  );
4664
+
4665
+ add_filter( 'wp_feed_cache_transient_lifetime' , 'woosea_feed_interval' );
4666
 
4667
  // Loop through Feeds
4668
  foreach ( $my_feeds as $feed) :