Product Feed PRO for WooCommerce - Version 9.7.4

Version Description

Added Bing Shopping Promotions template

Download this release

Release Info

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

Code changes from version 9.3.7 to 9.7.4

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,23 @@ 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 +3295,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 +3329,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 +3478,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 +3488,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 +3564,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 +3603,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 +3681,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 +3753,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 +3973,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 +4503,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 +5001,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
+ $var_price = wc_format_decimal($var_price,2);
3158
+ $var_price = wc_format_localized_price($var_price);
3159
 
3160
+ if(($var_price == $variation_min_price) OR ($product_data['system_regular_price'] == $variation_min_price) OR ($product_data['system_net_price'] == $variation_min_price)){
3161
  $variation_pass = "true";
3162
  } else {
3163
  $variation_pass = "false";
3295
  /**
3296
  * Although this is a product variation we also need to grap the Dynamic attributes belonging to the simple mother prodict
3297
  */
3298
+ $stock_value = get_post_meta( $product_data['id'], "_stock_status", true );
3299
+ //if($stock_value == "instock"){
3300
  foreach($diff_taxonomies as $taxo){
3301
  $term_value = get_the_terms($product_data['item_group_id'], $taxo);
3302
  unset($product_data[$taxo]);
3303
  if(is_array($term_value)){
3304
  foreach($term_value as $term){
3305
  if(empty($product_data[$taxo])){
3306
+ $product_data[$taxo] = $term->name;
3307
  } else {
3308
+ $product_data[$taxo] .= " ".$term->name;
3309
  }
3310
  }
3311
  }
3312
+ }
3313
 
3314
  /**
3315
  * Add product tags to the product data array
3329
 
3330
  // Add attribute values to the variation product names to make them unique
3331
  $product_data['title_hyphen'] = $product_data['title']." - ";
3332
+ $product_data['mother_title_hyphen'] = $product_data['mother_title']." - ";
3333
 
3334
  foreach($variations as $kk => $vv){
3335
  $custom_key = $kk;
3478
  * we will add CDATA brackets to the title and description attributes
3479
  */
3480
  $product_data['title_lc'] = ucfirst(strtolower($product_data['title']));
3481
+ $product_data['title_lcw'] = ucwords(strtolower($product_data['title']));
3482
+
3483
  //$product_data['description'] = $this->woosea_append_cdata ( $product_data['description'] );
3484
  //$product_data['short_description'] = $this->woosea_append_cdata ( $product_data['short_description'] );
3485
 
3488
  */
3489
  $product_data['reviews'] = $this->woosea_get_reviews( $product_data, $product );
3490
 
3491
+ /**
3492
+ * Filter out reviews that do not have text
3493
+ */
3494
+ if(!empty($product_data['reviews'])){
3495
+ foreach($product_data['reviews'] as $review_id => $review_details){
3496
+ if(empty($review_details['content'])){
3497
+ unset($product_data['reviews'][$review_id]);
3498
+ }
3499
+ }
3500
+ }
3501
+
3502
  /**
3503
  * Check if individual products need to be excluded
3504
  */
3564
  // For these channels parent products are allowed
3565
  $allowed_channel_parents = array(
3566
  "skroutz",
3567
+ "bestprice",
3568
  "google_dsa",
3569
  "google_product_review",
3570
  );
3571
 
3572
+ if(array_key_exists('fields', $project_config)){
3573
+ if (!in_array($project_config['fields'], $allowed_channel_parents)){
3574
+ if(($product->is_type('variable')) AND ($product_data['item_group_id'] == 0)){
3575
+ $product_data = array();
3576
+ $product_data = null;
3577
+ }
3578
+ }
3579
+ }
3580
 
3581
  /**
3582
  * Remove variation products that are not THE default variation product
3603
  }
3604
  }
3605
 
3606
+ /**
3607
+ * Do final check on Skroutz out of stock sizes
3608
+ * When a size is not on stock remove it
3609
+ */
3610
+ if($project_config['fields'] == "skroutz"){
3611
+ if(isset($product_data['id'])){
3612
+ foreach($project_config['attributes'] as $ky => $vy){
3613
+ if(isset($vy['attribute'])){
3614
+ if($vy['attribute'] == "size"){
3615
+ $size_found = "yes";
3616
+ $sz_attribute = $vy['mapfrom'];
3617
+ }
3618
+ if($vy['attribute'] == "color"){
3619
+ $color_found = "yes";
3620
+ $clr_attribute = $vy['mapfrom'];
3621
+ }
3622
+ }
3623
+ }
3624
+
3625
+ $stock_value = get_post_meta( $product_data['id'], "_stock_status", true );
3626
+ $sz_attr_value = get_post_meta( $product_data['id'], $sz_attribute, true );
3627
+ $clr_attr_value = get_post_meta( $product_data['id'], "attribute_".$clr_attribute, true );
3628
+ if(isset($product_data['item_group_id']) AND ($product_data['item_group_id'] > 0)){
3629
+ $product_skroutz = wc_get_product($product_data['item_group_id']);
3630
+ $variations = $product_skroutz->get_available_variations();
3631
+ $variations_id = wp_list_pluck( $variations, 'variation_id' );
3632
+
3633
+ foreach($variations_id as $var_id){
3634
+ $clr_variation = get_post_meta( $var_id, "attribute_".$clr_attribute, true );
3635
+ $size_variation = get_post_meta( $var_id, "attribute_".$sz_attribute, true );
3636
+ $stock_variation = get_post_meta( $var_id, "_stock_status", true );
3637
+
3638
+ if($clr_variation == $clr_attr_value){
3639
+ if($stock_variation == "outofstock"){
3640
+ // Remove this size as it is not on stock
3641
+ if(array_key_exists($sz_attribute, $product_data)){
3642
+ $product_data[$sz_attribute] = str_replace(ucfirst($size_variation),"",$product_data[$sz_attribute]);
3643
+ }
3644
+ }
3645
+ }
3646
+ }
3647
+ }
3648
+ }
3649
+ }
3650
+
3651
  /**
3652
  * When product has passed the filter rules it can continue with the rest
3653
  */
3681
  }
3682
  } else {
3683
  if((strlen($attr_value['mapfrom'])) AND (array_key_exists($attr_value['mapfrom'], $product_data))){
3684
+ 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")){
3685
  $attr_line = "'".$attr_value['prefix']."".$product_data[$attr_value['mapfrom']]."".$attr_value['suffix']."'";
3686
  } else {
3687
  $attr_line = "'".$attr_value['prefix']. "".$product_data[$attr_value['mapfrom']]."" .$attr_value['suffix']."'";
3753
  }
3754
  } else {
3755
  if(strlen($product_data[$attr_value['mapfrom']])){
3756
+ 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")){
3757
  if(($product_data['product_type'] == "variation") AND (preg_match("/aelia_cs_currency/", $attr_value['suffix']))){
3758
  $attr_value['suffix'] = str_replace("?","&",$attr_value['suffix']);
3759
  $attr_line .= ",'".$attr_value['prefix']."".$product_data[$attr_value['mapfrom']]."".$attr_value['suffix']."'";
3973
  }
3974
  } else {
3975
  if(strlen($product_data[$attr_value['mapfrom']])){
3976
+ if(($attr_value['attribute'] == "URL") OR ($attr_value['attribute'] == "g:link") OR ($attr_value['attribute'] == "link") OR ($attr_value['attribute'] == "g:link_template")){
3977
  if(($product_data['product_type'] == "variation") AND (preg_match("/aelia_cs_currency/", $attr_value['suffix']))){
3978
  $attr_value['suffix'] = str_replace("?","&",$attr_value['suffix']);
3979
  $xml_product[$attr_value['attribute']] = "$attr_value[prefix]". $product_data[$attr_value['mapfrom']] ."$attr_value[suffix]";
4503
  return $product_data;
4504
  }
4505
 
4506
+ /**
4507
+ * Execute project rules
4508
+ */
4509
  private function woocommerce_sea_rules( $project_rules2, $product_data ){
4510
+ $aantal_prods = count($product_data);
4511
+ if($aantal_prods > 0){
4512
 
4513
+ foreach ($project_rules2 as $pr_key => $pr_array){
4514
 
4515
+ foreach ($product_data as $pd_key => $pd_value){
4516
 
4517
+ // Check is there is a rule on specific attributes
4518
+ if($pd_key == $pr_array['attribute']){
4519
 
4520
+ // This is because for data manipulation the than attribute is empty
4521
+ if(!array_key_exists('than_attribute', $pr_array)){
4522
+ $pr_array['than_attribute'] = $pd_key;
4523
+ }
4524
 
4525
  // Check if a rule has been set for Google categories
4526
  if (!empty($product_data['categories']) AND ($pr_array['than_attribute'] == "google_category") AND ($product_data[$pr_array['attribute']] == $pr_array['criteria'])){
4527
+
4528
+ $pr_array['than_attribute'] = "categories";
4529
  $category_id = explode("-", $pr_array['newvalue']);
4530
  $pr_array['newvalue'] = $category_id[0];
4531
+ $product_data['categories'] = $pr_array['newvalue'];
4532
+ }
4533
 
4534
+ // Make sure that rules on numerics are on true numerics
4535
+ if (!is_array($pd_value) AND (!preg_match('/[A-Za-z]/', $pd_value))){
4536
+ $pd_value = strtr($pd_value, ',', '.');
4537
+ }
4538
 
4539
 
4540
+ // Make sure the price or sale price is numeric
4541
+ if(($pr_array['attribute'] == "sale_price") OR ($pr_array['attribute'] == "price")){
4542
+ settype($pd_value, "double");
4543
+ }
4544
 
4545
+ if (((is_numeric($pd_value)) AND ($pr_array['than_attribute'] != "shipping"))){
4546
 
4547
+ // Rules for numeric values
4548
+ switch ($pr_array['condition']) {
4549
+ case($pr_array['condition'] = "contains"):
4550
+ if ((preg_match('/'.$pr_array['criteria'].'/', $pd_value))){
4551
+ $product_data[$pr_array['than_attribute']] = str_replace($pr_array['criteria'], $pr_array['newvalue'], $pd_value);
4552
+ }
4553
+ break;
4554
+ case($pr_array['condition'] = "containsnot"):
4555
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value))){
4556
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4557
+ }
4558
+ break;
4559
+ case($pr_array['condition'] = "="):
4560
+ if (($pd_value == $pr_array['criteria'])){
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'] = "empty"):
4590
+ if(empty($product_data[$pr_array['attribute']])){
4591
+ if ((strlen($pd_value) < 1)){
4592
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4593
+ } else {
4594
+ $product_data[$pr_array['attribute']] = $product_data[$pr_array['than_attribute']];
4595
+ }
4596
+ }
4597
+ break;
4598
+ case($pr_array['condition'] = "multiply"):
4599
+ $pr_array['criteria'] = strtr($pr_array['criteria'], ',', '.');
4600
+ $convert_back = "false";
4601
+ $pos = strpos($pd_value, ',');
4602
+ if($pos !== false){
4603
+ $convert_back = "true";
4604
+ }
4605
+ $pd_value = strtr($pd_value, ',', '.');
4606
+ $newvalue = $pd_value*$pr_array['criteria'];
4607
+ $newvalue = round($newvalue, 2);
4608
+ if($convert_back == "true"){
4609
+ $newvalue = strtr($newvalue, '.',',');
4610
+ }
4611
+ $product_data[$pr_array['attribute']] = $newvalue;
4612
+ break;
4613
+ case($pr_array['condition'] = "divide"):
4614
+ $newvalue = ($pd_value / $pr_array['criteria']);
4615
+ $newvalue = round($newvalue, 2);
4616
+ $newvalue = strtr($newvalue, '.',',');
4617
+ $product_data[$pr_array['attribute']] = $newvalue;
4618
+ break;
4619
+ case($pr_array['condition'] = "plus"):
4620
+ $newvalue = ($pd_value + $pr_array['criteria']);
4621
+ $product_data[$pr_array['attribute']] = $newvalue;
4622
+ break;
4623
+ case($pr_array['condition'] = "minus"):
4624
+ $newvalue = ($pd_value - $pr_array['criteria']);
4625
+ $product_data[$pr_array['attribute']] = $newvalue;
4626
+ break;
4627
+ case($pr_array['condition'] = "findreplace"):
4628
+ if (strpos($pd_value, $pr_array['criteria']) !== false){
4629
  // Make sure that a new value has been set
4630
+ if(!empty($pr_array['newvalue'])){
4631
+ // Find and replace only work on same attribute field, otherwise create a contains rule
4632
  if($pr_array['attribute'] == $pr_array['than_attribute']){
4633
  $newvalue = str_replace($pr_array['criteria'],$pr_array['newvalue'], $pd_value);
4634
  $product_data[$pr_array['than_attribute']] = ucfirst($newvalue);
4635
  }
4636
+ }
4637
+ }
4638
+ break;
4639
+ default:
4640
+ break;
4641
+ }
4642
+ } elseif (is_array($pd_value)) {
4643
+
4644
+ // For now only shipping details are in an array
4645
+ foreach ($pd_value as $k => $v){
4646
+ if(is_array($v)){
4647
+ foreach ($v as $kk => $vv){
4648
+ // Only shipping detail rule can be on price for now
4649
+ if($kk == "price"){
4650
+ switch ($pr_array['condition']) {
4651
+ case($pr_array['condition'] = "contains"):
4652
+ if ((preg_match('/'.$pr_array['criteria'].'/', $vv))){
4653
+ $pd_value[$k]['price'] = str_replace($pr_array['criteria'], $pr_array['newvalue'], $vv);
4654
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4655
+ }
4656
+ break;
4657
+ case($pr_array['condition'] = "containsnot"):
4658
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $vv))){
4659
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4660
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4661
+ }
4662
+ break;
4663
+ case($pr_array['condition'] = "="):
4664
+ if (($vv == $pr_array['criteria'])){
4665
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4666
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4667
+ }
4668
+ break;
4669
+ case($pr_array['condition'] = "!="):
4670
+ if (($vv != $pr_array['criteria'])){
4671
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4672
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4673
+ }
4674
+ break;
4675
+ case($pr_array['condition'] = ">"):
4676
+ if (($vv > $pr_array['criteria'])){
4677
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4678
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4679
+ }
4680
+ break;
4681
+ case($pr_array['condition'] = ">="):
4682
+ if (($vv >= $pr_array['criteria'])){
4683
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4684
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4685
+ }
4686
+ break;
4687
+ case($pr_array['condition'] = "<"):
4688
+ if (($vv < $pr_array['criteria'])){
4689
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4690
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4691
+ }
4692
+ break;
4693
+ case($pr_array['condition'] = "=<"):
4694
+ if (($vv <= $pr_array['criteria'])){
4695
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4696
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4697
+ }
4698
+ break;
4699
+ case($pr_array['condition'] = "empty"):
4700
+ if ((strlen($vv) < 1)){
4701
+ $pd_value[$k]['price'] = $pr_array['newvalue'];
4702
+ $product_data[$pr_array['than_attribute']] = $pd_value;
4703
+ }
4704
+ break;
4705
+ case($pr_array['condition'] = "multiply"):
4706
+ // Only shipping array
4707
+ if(is_array($pd_value)){
4708
+ $pr_array['criteria'] = strtr($pr_array['criteria'], ',', '.');
4709
+ foreach ($pd_value as $ship_a_key => $shipping_arr){
4710
+ foreach($shipping_arr as $ship_key => $ship_value){
4711
+ if($ship_key == "price"){
4712
+ $ship_pieces = explode(" ", $ship_value);
4713
+ $pd_value = strtr($ship_pieces[1], ',', '.');
4714
+ $newvalue = $pd_value*$pr_array['criteria'];
4715
+ $newvalue = round($newvalue, 2);
4716
+ $newvalue = strtr($newvalue, '.',',');
4717
+ $newvalue = $ship_pieces[0]." ".$newvalue;
4718
+ $product_data[$pr_array['than_attribute']][$ship_a_key]['price'] = $newvalue;
4719
+ }
4720
+ }
4721
+ }
4722
+ }
4723
+ break;
4724
+ default:
4725
+ break;
4726
+ }
4727
+ }
4728
+ }
4729
+ } else {
4730
+ // Rules on product tags
4731
+ foreach ($pd_value as $k => $v){
4732
+
4733
+ // Rules for string values
4734
+ if (!array_key_exists('cs', $pr_array)){
4735
+ $v = strtolower($v);
4736
+ $pr_array['criteria'] = strtolower($pr_array['criteria']);
4737
+ }
4738
+
4739
+ switch ($pr_array['condition']) {
4740
+ case($pr_array['condition'] = "contains"):
4741
+ if ((preg_match('/'.$pr_array['criteria'].'/', $v))){
4742
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4743
+ }
4744
+ break;
4745
+ case($pr_array['condition'] = "containsnot"):
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'] = "="):
4751
+ if (($v == $pr_array['criteria'])){
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'] = "empty"):
4781
+ if ((strlen($v) < 1)){
4782
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4783
+ }
4784
+ break;
4785
+ case($pr_array['condition'] = "multiply"):
4786
+ // Only shipping array
4787
+ if(is_array($v)){
4788
+ $pr_array['criteria'] = strtr($pr_array['criteria'], ',', '.');
4789
+ foreach ($v as $ship_a_key => $shipping_arr){
4790
+ foreach($shipping_arr as $ship_key => $ship_value){
4791
+ if($ship_key == "price"){
4792
+ $ship_pieces = explode(" ", $ship_value);
4793
+ $pd_value = strtr($ship_pieces[1], ',', '.');
4794
+ $newvalue = $pd_value*$pr_array['criteria'];
4795
+ $newvalue = round($newvalue, 2);
4796
+ $newvalue = strtr($newvalue, '.',',');
4797
+ $newvalue = $ship_pieces[0]." ".$newvalue;
4798
+ $product_data[$pr_array['than_attribute']][$ship_a_key]['price'] = $newvalue;
4799
+ }
4800
+ }
4801
+ }
4802
+ }
4803
+ break;
4804
+ default:
4805
+ break;
4806
+ }
4807
+ }
4808
+ }
4809
+ }
4810
+ } else {
4811
+ // Rules for string values
4812
  if (!array_key_exists('cs', $pr_array)){
4813
+ if($pr_array['attribute'] != "image"){
4814
+ $pd_value = strtolower($pd_value);
4815
+ $pr_array['criteria'] = strtolower($pr_array['criteria']);
4816
+ }
4817
+ }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4818
 
4819
+ switch ($pr_array['condition']) {
4820
+ case($pr_array['condition'] = "contains"):
4821
+ if ((preg_match('/'.$pr_array['criteria'].'/', $pd_value))){
4822
+ // Specifically for shipping price rules
4823
+ if(!empty($product_data[$pr_array['than_attribute']])){
4824
+ if(is_array($product_data[$pr_array['than_attribute']])){
4825
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4826
+ for ($x = 0; $x <= $arr_size; $x++) {
4827
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4828
+ }
4829
+ } else {
4830
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4831
+ }
4832
+ } else {
4833
+ // This attribute value is empty for this product
4834
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4835
+ }
4836
+ }
4837
+ break;
4838
+ case($pr_array['condition'] = "containsnot"):
4839
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value))){
4840
+ // Specifically for shipping price rules
4841
+ if(is_array($product_data[$pr_array['than_attribute']])){
4842
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4843
+ for ($x = 0; $x <= $arr_size; $x++) {
4844
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4845
+ }
4846
+ } else {
4847
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4848
+ }
4849
+ }
4850
+ break;
4851
+ case($pr_array['condition'] = "="):
4852
+ if (($pr_array['criteria'] == "$pd_value")){
4853
+ // Specifically for shipping price rules
4854
+ if(is_array($product_data[$pr_array['than_attribute']])){
4855
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4856
+ for ($x = 0; $x <= $arr_size; $x++) {
4857
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4858
+ }
4859
+ } else {
4860
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4861
+ }
4862
+ }
4863
+ $ship = $product_data['shipping'];
4864
+ break;
4865
+ case($pr_array['condition'] = "!="):
4866
+ if (($pr_array['criteria'] != "$pd_value")){
4867
+ // Specifically for shipping price rules
4868
+ if(is_array($product_data[$pr_array['than_attribute']])){
4869
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4870
+ for ($x = 0; $x <= $arr_size; $x++) {
4871
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4872
+ }
4873
+ } else {
4874
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4875
+ }
4876
+ }
4877
+ break;
4878
+ case($pr_array['condition'] = ">"):
4879
+ // Use a lexical order on relational string operators
4880
+ if (($pd_value > $pr_array['criteria'])){
4881
+ // Specifically for shipping price rules
4882
+ if(is_array($product_data[$pr_array['than_attribute']])){
4883
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4884
+ for ($x = 0; $x <= $arr_size; $x++) {
4885
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4886
+ }
4887
+ } else {
4888
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4889
+ }
4890
+ }
4891
+ break;
4892
+ case($pr_array['condition'] = ">="):
4893
+ // Use a lexical order on relational string operators
4894
+ if (($pd_value >= $pr_array['criteria'])){
4895
+ // Specifically for shipping price rules
4896
+ if(is_array($product_data[$pr_array['than_attribute']])){
4897
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4898
+ for ($x = 0; $x <= $arr_size; $x++) {
4899
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4900
+ }
4901
+ } else {
4902
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4903
+ }
4904
+ }
4905
+ break;
4906
+ case($pr_array['condition'] = "<"):
4907
+ // Use a lexical order on relational string operators
4908
+ if (($pd_value < $pr_array['criteria'])){
4909
+ // Specifically for shipping price rules
4910
+ if(isset($product_data[$pr_array['than_attribute']]) AND (is_array($product_data[$pr_array['than_attribute']]))){
4911
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4912
+ for ($x = 0; $x <= $arr_size; $x++) {
4913
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4914
+ }
4915
+ } else {
4916
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4917
+ }
4918
+ }
4919
+ break;
4920
+ case($pr_array['condition'] = "=<"):
4921
+ // Use a lexical order on relational string operators
4922
+ if (($pd_value <= $pr_array['criteria'])){
4923
+ // Specifically for shipping price rules
4924
+ if(is_array($product_data[$pr_array['than_attribute']])){
4925
+ $arr_size = (count($product_data[$pr_array['than_attribute']])-1);
4926
+ for ($x = 0; $x <= $arr_size; $x++) {
4927
+ $product_data[$pr_array['than_attribute']][$x]['price'] = $pr_array['newvalue'];
4928
+ }
4929
+ } else {
4930
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4931
+ }
4932
+ }
4933
+ break;
4934
+
4935
+ case($pr_array['condition'] = "empty"):
4936
+ if(empty($product_data[$pr_array['attribute']])){
4937
+ if(empty($product_data[$pr_array['than_attribute']])){
4938
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4939
+ } else {
4940
+ $product_data[$pr_array['attribute']] = $product_data[$pr_array['than_attribute']];
4941
+ }
4942
+ }
4943
+ break;
4944
+ case($pr_array['condition'] = "replace"):
4945
+ $product_data[$pr_array['than_attribute']] = str_replace($pr_array['criteria'], $pr_array['newvalue'], $product_data[$pr_array['than_attribute']]);
4946
+ break;
4947
  case($pr_array['condition'] = "findreplace"):
4948
  if (strpos($pd_value, $pr_array['criteria']) !== false){
4949
+ // Make sure that a new value has been set
4950
+ if(!empty($pr_array['newvalue'])){
4951
+ // Find and replace only work on same attribute field, otherwise create a contains rule
4952
  if($pr_array['attribute'] == $pr_array['than_attribute']){
4953
+ $newvalue = str_replace($pr_array['criteria'],$pr_array['newvalue'], $pd_value);
4954
+ //$product_data[$pr_array['than_attribute']] = ucfirst($newvalue);
4955
+ $product_data[$pr_array['than_attribute']] = $newvalue;
4956
+ }
4957
+ }
4958
+ }
4959
  break;
4960
+ default:
4961
+ break;
4962
+ }
4963
+ }
4964
+ } else {
4965
+ // When a rule has been set on an attribute that is not in product_data
4966
+ // Add the newvalue to product_data
4967
+ if (!array_key_exists($pr_array['attribute'], $product_data)){
4968
+ if(!empty($pr_array['newvalue'])){
4969
+ $product_data[$pr_array['than_attribute']] = $pr_array['newvalue'];
4970
+ } else {
4971
+ if(array_key_exists($pr_array['than_attribute'], $product_data)){
4972
+ $product_data[$pr_array['attribute']] = $product_data[$pr_array['than_attribute']];
4973
+ }
4974
+ }
4975
+ }
4976
+ }
4977
+ }
4978
+ }
4979
+ }
4980
+ return $product_data;
4981
+ }
4982
 
4983
  /**
4984
  * Function to exclude products based on individual product exclusions
5001
  }
5002
  }
5003
 
5004
+
5005
+ /**
5006
+ * Execute project filters (include / exclude)
5007
+ */
5008
  private function woocommerce_sea_filters( $project_rules, $product_data ){
5009
+ $allowed = 1;
5010
 
5011
+ // Check if product was already excluded from the feed
5012
+ $product_excluded = ucfirst( get_post_meta( $product_data['id'], '_woosea_exclude_product', true ) );
5013
 
5014
+ if( $product_excluded == "Yes"){
5015
+ $allowed = 0;
5016
+ }
5017
 
5018
+ foreach ($project_rules as $pr_key => $pr_array){
5019
 
5020
+ if($pr_array['attribute'] == "categories"){
5021
+ $pr_array['attribute'] = "raw_categories";
5022
+ }
5023
 
5024
+ //if(array_key_exists($pr_array['attribute'], $product_data)){
5025
 
5026
+ if(!array_key_exists($pr_array['attribute'], $product_data)) {
5027
+ $product_data[$pr_array['attribute']] = ""; // Sets an empty postmeta value in place of a missing one.
5028
+ }
5029
 
5030
+ foreach ($product_data as $pd_key => $pd_value){
5031
+ // Check is there is a rule on specific attributes
5032
+ if(in_array($pd_key, $pr_array, TRUE)){
5033
 
5034
+ if($pd_key == "price"){
5035
+ //$pd_value = @number_format($pd_value,2);
5036
+ $pd_value = wc_format_decimal($pd_value);
5037
+ }
5038
 
5039
+ if (is_numeric($pd_value)){
5040
+ $old_value = $pd_value;
5041
+ if($pd_key == "price"){
5042
+ $pd_value = @number_format($pd_value,2);
5043
+ }
5044
+
5045
+ // Rules for numeric values
5046
+ switch ($pr_array['condition']) {
5047
+ case($pr_array['condition'] = "contains"):
5048
+ if ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
5049
+ $allowed = 0;
5050
+ } elseif ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5051
+ $allowed = 0;
5052
+ }
5053
+ break;
5054
+ case($pr_array['condition'] = "containsnot"):
5055
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
5056
+ $allowed = 0;
5057
+ } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5058
+ $allowed = 0;
5059
+ }
5060
+ break;
 
 
 
 
 
5061
  case($pr_array['condition'] = "="):
5062
+ if (($old_value == $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5063
+ $allowed = 0;
5064
+ } elseif (($old_value != $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5065
+ $allowed = 0;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
5066
  }
5067
+ break;
5068
+ case($pr_array['condition'] = "!="):
5069
+ if (($old_value == $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5070
+ if($allowed <> 0){
5071
+ $allowed = 1;
5072
+ }
5073
+ } elseif (($old_value == $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5074
+ $allowed = 0;
5075
+ }
5076
+ break;
5077
+ case($pr_array['condition'] = ">"):
5078
+ if (($old_value > $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5079
+ $allowed = 0;
5080
+ } elseif (($old_value <= $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5081
+ $allowed = 0;
5082
+ }
5083
+ break;
5084
+ case($pr_array['condition'] = ">="):
5085
+ if (($old_value >= $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5086
+ $allowed = 0;
5087
+ } elseif (($old_value < $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5088
+ $allowed = 0;
5089
+ }
5090
+ break;
5091
+ case($pr_array['condition'] = "<"):
5092
+ if (($old_value < $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5093
+ $allowed = 0;
5094
+ } elseif (($old_value > $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5095
+ $allowed = 0;
5096
+ }
5097
+ break;
5098
+ case($pr_array['condition'] = "=<"):
5099
+ if (($old_value <= $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5100
+ $allowed = 0;
5101
+ } elseif (($old_value > $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5102
+ $allowed = 0;
5103
+ }
5104
+ break;
5105
+ case($pr_array['condition'] = "empty"):
5106
+ if ((strlen($pd_value) < 1) && ($pr_array['than'] == "exclude")){
5107
+ $allowed = 0;
5108
+ } elseif ((strlen($pd_value > 0)) && ($pr_array['than'] == "include_only")){
5109
+ $allowed = 0;
5110
+ }
5111
+ break;
5112
+ default:
5113
+ break;
5114
+ }
5115
+ } elseif (is_array($pd_value)){
5116
+ // Tis can either be a shipping or product_tag array
5117
+ if($pr_array['attribute'] == "product_tag"){
5118
+ $in_tag_array = "not";
5119
+
5120
+ foreach($pd_value as $pt_key => $pt_value){
5121
+ // Rules for string values
5122
+ if (!array_key_exists('cs', $pr_array)){
5123
+ $pt_value = strtolower($pt_value);
5124
+ $pr_array['criteria'] = strtolower($pr_array['criteria']);
5125
+ }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
5126
 
5127
+ if(preg_match('/'.$pr_array['criteria'].'/', $pt_value)){
5128
+ $in_tag_array = "yes";
5129
+ }
5130
+ }
5131
+
5132
+ if($in_tag_array == "yes"){
5133
+ //if(in_array($pr_array['criteria'], $pd_value, TRUE)) {
5134
+ $v = $pr_array['criteria'];
5135
+ switch ($pr_array['condition']) {
5136
+ case($pr_array['condition'] = "contains"):
5137
+ if ((preg_match('/'.$pr_array['criteria'].'/', $v))){
5138
+ if($pr_array['than'] == "include_only"){
5139
+ if($allowed <> 0){
5140
+ $allowed = 1;
5141
+ }
5142
+ } else {
5143
+ $allowed = 0;
5144
+ }
5145
+ } else {
5146
+ $allowed = 0;
5147
+ }
5148
+ break;
5149
+ case($pr_array['condition'] = "containsnot"):
5150
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $v))){
5151
+ if($pr_array['than'] == "include_only"){
5152
+ if($allowed <> 0){
5153
+ $allowed = 1;
5154
+ }
5155
+ } else {
5156
+ $allowed = 0;
5157
+ }
5158
+ } else {
5159
+ $allowed = 0;
5160
+ }
5161
+ break;
5162
+ case($pr_array['condition'] = "="):
5163
+ if (($v == $pr_array['criteria'])){
5164
+ if($pr_array['than'] == "include_only"){
5165
+ if($allowed <> 0){
5166
+ $allowed = 1;
5167
+ }
5168
+ } else {
5169
+ $allowed = 0;
5170
+ }
5171
+ } else {
5172
+ $allowed = 0;
5173
+ }
5174
+ break;
5175
+ case($pr_array['condition'] = "!="):
5176
+ if (($v != $pr_array['criteria'])){
5177
+ if($pr_array['than'] == "include_only"){
5178
+ if($allowed <> 0){
5179
+ $allowed = 1;
5180
+ }
5181
+ } else {
5182
+ $allowed = 0;
5183
+ }
5184
+ }
5185
+ break;
5186
+ case($pr_array['condition'] = ">"):
5187
+ if (($v > $pr_array['criteria'])){
5188
+ if($pr_array['than'] == "include_only"){
5189
+ if($allowed <> 0){
5190
+ $allowed = 1;
5191
+ }
5192
+ } else {
5193
+ $allowed = 0;
5194
+ }
5195
+ }
5196
+ break;
5197
+ case($pr_array['condition'] = ">="):
5198
+ if (($v >= $pr_array['criteria'])){
5199
+ if($pr_array['than'] == "include_only"){
5200
+ if($allowed <> 0){
5201
+ $allowed = 1;
5202
+ }
5203
+ } else {
5204
+ $allowed = 0;
5205
+ }
5206
+ }
5207
+ break;
5208
+ case($pr_array['condition'] = "<"):
5209
+ if (($v < $pr_array['criteria'])){
5210
+ if($pr_array['than'] == "include_only"){
5211
+ if($allowed <> 0){
5212
+ $allowed = 1;
5213
+ }
5214
+ } else {
5215
+ $allowed = 0;
5216
+ }
5217
+ }
5218
+ break;
5219
+ case($pr_array['condition'] = "=<"):
5220
+ if (($v <= $pr_array['criteria'])){
5221
+ if($pr_array['than'] == "include_only"){
5222
+ if($allowed <> 0){
5223
+ $allowed = 1;
5224
+ }
5225
+ } else {
5226
+ $allowed = 0;
5227
+ }
5228
+ }
5229
+ break;
5230
+ case($pr_array['condition'] = "empty"):
5231
+ if (strlen($v) < 1){
5232
+ if($pr_array['than'] == "include_only"){
5233
+ if($allowed <> 0){
5234
+ $allowed = 1;
5235
+ }
5236
+ } else {
5237
+ if(!empty($pt_value)){
5238
+ $allowed = 1;
5239
+ } else {
5240
+ $allowed = 0;
5241
+ }
5242
+ }
5243
+ }
5244
+ break;
5245
+ default:
5246
+ break;
5247
+ }
5248
+ } else {
5249
+ switch ($pr_array['condition']) {
5250
+ case($pr_array['condition'] = "contains"):
5251
+ if($pr_array['than'] == "include_only"){
5252
+ $allowed = 0;
5253
+ } else {
5254
+ if($allowed <> 0){
5255
+ $allowed = 1;
5256
+ }
5257
+ }
5258
+ break;
5259
+ case($pr_array['condition'] = "containsnot"):
5260
+ if($pr_array['than'] == "include_only"){
5261
+ if($allowed <> 0){
5262
+ $allowed = 1;
5263
+ }
5264
+ } else {
5265
+ $allowed = 0;
5266
+ }
5267
+ break;
5268
+ case($pr_array['condition'] = "="):
5269
+ if($pr_array['than'] == "include_only"){
5270
+ $allowed = 0;
5271
+ } else {
5272
+ if($allowed <> 0){
5273
+ $allowed = 1;
5274
+ }
5275
+ }
5276
+ break;
5277
+ case($pr_array['condition'] = "!="):
5278
+ if($pr_array['than'] == "include_only"){
5279
+ if($allowed <> 0){
5280
+ $allowed = 1;
5281
+ }
5282
+ } else {
5283
+ $allowed = 0;
5284
+ }
5285
+ break;
5286
+ case($pr_array['condition'] = ">"):
5287
+ if($pr_array['than'] == "include_only"){
5288
+ $allowed = 0;
5289
+ } else {
5290
+ $allowed = 0;
5291
+ }
5292
+ break;
5293
+ case($pr_array['condition'] = ">="):
5294
+ if($pr_array['than'] == "include_only"){
5295
+ $allowed = 0;
5296
+ } else {
5297
+ $allowed = 0;
5298
+ }
5299
+ break;
5300
+ case($pr_array['condition'] = "<"):
5301
+ if($pr_array['than'] == "include_only"){
5302
+ $allowed = 0;
5303
+ } else {
5304
+ $allowed = 0;
5305
+ }
5306
+ break;
5307
+ case($pr_array['condition'] = "=<"):
5308
+ if($pr_array['than'] == "include_only"){
5309
+ $allowed = 0;
5310
+ } else {
5311
+ $allowed = 0;
5312
+ }
5313
+ break;
5314
+ case($pr_array['condition'] = "empty"):
5315
+ if($pr_array['than'] == "include_only"){
5316
+ if($allowed <> 0){
5317
+ $allowed = 1;
5318
+ }
5319
+ } else {
5320
+ $allowed = 0;
5321
+ }
5322
+ break;
5323
+ default:
5324
+ break;
5325
+ }
5326
+ }
5327
+ } else {
5328
+ // For now only shipping details are in an array
5329
+ foreach ($pd_value as $k => $v){
5330
+ foreach ($v as $kk => $vv){
5331
+ // Only shipping detail rule can be on price for now
5332
+ if($kk == "price"){
5333
+ switch ($pr_array['condition']) {
5334
+ case($pr_array['condition'] = "contains"):
5335
+ if ((preg_match('/'.$pr_array['criteria'].'/', $vv))){
5336
+ $allowed = 0;
5337
+ }
5338
+ break;
5339
+ case($pr_array['condition'] = "containsnot"):
5340
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $vv))){
5341
+ $allowed = 0;
5342
+ }
5343
+ break;
5344
+ case($pr_array['condition'] = "="):
5345
+ if (($vv == $pr_array['criteria'])){
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'] = "empty"):
5375
+ if (strlen($vv) < 1){
5376
+ $allowed = 0;
5377
+ }
5378
+ break;
5379
+ default:
5380
+ break;
5381
+ }
5382
+ }
5383
+ }
5384
+ }
5385
+ }
5386
+ } else {
5387
+ // Filters for string values
5388
+ // If case-sensitve is off than lowercase both the criteria and attribute value
5389
+ if (array_key_exists('cs', $pr_array)){
5390
+ if ($pr_array['cs'] != "on"){
5391
+ $pd_value = strtolower($pd_value);
5392
+ $pr_array['criteria'] = strtolower($pr_array['criteria']);
5393
+ }
5394
+ }
5395
+ $pos = strpos($pd_value, '&amp;');
5396
+ $pos_slash = strpos($pr_array['criteria'], '\\');
5397
+ if($pos !== false){
5398
+ $pd_value = str_replace("&amp;","&",$pd_value);
5399
+ }
5400
+ if($pos_slash !== false){
5401
+ $pr_array['criteria'] = str_replace("\\","",$pr_array['criteria']);
5402
+ }
5403
+
5404
+ switch ($pr_array['condition']) {
5405
+ case($pr_array['condition'] = "contains"):
5406
+ if ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
5407
+ $allowed = 0;
5408
+ } elseif ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5409
+ $allowed = 0;
5410
+ } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5411
+ if($allowed <> 0){
5412
+ $allowed = 1;
5413
+ }
5414
+ }
5415
+ break;
5416
+ case($pr_array['condition'] = "containsnot"):
5417
+ if ((!preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
5418
+ $allowed = 0;
5419
+ } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5420
+ $allowed = 0;
5421
+ }
5422
+ break;
5423
  case($pr_array['condition'] = "="):
5424
+ if (($pr_array['criteria'] == "$pd_value") AND ($pr_array['than'] == "exclude")){
5425
  $allowed = 0;
5426
+ } elseif (($pr_array['criteria'] != "$pd_value") && ($pr_array['than'] == "include_only")){
5427
+ $found = strpos($pd_value,$pr_array['criteria']);
5428
+ if ($found !== false) {
5429
+ //for category mapping check if its an array
5430
+ if($pr_array['attribute'] == "raw_categories"){
5431
+ $raw_cats_arr = explode("||",$pd_value);
5432
+ if(is_array($raw_cats_arr)){
5433
+ if(in_array($pr_array['criteria'],$raw_cats_arr, TRUE)){
5434
+ if($allowed <> 0){
5435
+ $allowed = 1;
5436
+ }
5437
+ } else {
5438
+ $allowed = 0;
5439
+ }
5440
+ }
5441
+ } else {
5442
+ if($allowed <> 0){
5443
+ $allowed = 1;
5444
+ }
5445
+ }
5446
+ } else {
5447
+ $allowed = 0;
5448
+ }
5449
+ } elseif (($pr_array['criteria'] == "$pd_value") && ($pr_array['than'] == "include_only")){
5450
+ if($allowed <> 0){
5451
+ $allowed = 1;
5452
+ }
5453
+ } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "exclude")){
5454
+ // $allowed = 0;
5455
+ } elseif ((preg_match('/'.$pr_array['criteria'].'/', $pd_value)) && ($pr_array['than'] == "include_only")){
5456
+ $allowed = 1;
5457
+ } else {
5458
+ // $allowed = 1; // Change made on February 24th 2021
5459
+ }
5460
+ break;
5461
+ case($pr_array['condition'] = "!="):
5462
+ if (($pr_array['criteria'] == "$pd_value") && ($pr_array['than'] == "exclude")){
5463
+ if($allowed <> 0){
5464
+ $allowed = 1;
5465
+ }
5466
+ } elseif (($pr_array['criteria'] == "$pd_value") && ($pr_array['than'] == "include_only")){
5467
+ $allowed = 0;
5468
+ } elseif (($pr_array['criteria'] != "$pd_value") && ($pr_array['than'] == "exclude")){
5469
+ $allowed = 0;
5470
+ }
5471
+ break;
5472
+ case($pr_array['condition'] = ">"):
5473
+ // Use a lexical order on relational string operators
5474
+ if (($pd_value > $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5475
+ $allowed = 0;
5476
+ } elseif (($pd_value < $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5477
+ $allowed = 0;
5478
+ }
5479
+ break;
5480
+ case($pr_array['condition'] = ">="):
5481
+ // Use a lexical order on relational string operators
5482
+ if (($pd_value >= $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5483
+ $allowed = 0;
5484
+ } elseif (($pd_value < $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5485
+ $allowed = 0;
5486
+ }
5487
+ break;
5488
+ case($pr_array['condition'] = "<"):
5489
+ // Use a lexical order on relational string operators
5490
+ if (($pd_value < $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5491
+ $allowed = 0;
5492
+ } elseif (($pd_value > $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5493
+ $allowed = 0;
5494
+ }
5495
+ break;
5496
+ case($pr_array['condition'] = "=<"):
5497
+ // Use a lexical order on relational string operators
5498
+ if (($pd_value <= $pr_array['criteria']) && ($pr_array['than'] == "exclude")){
5499
+ $allowed = 0;
5500
+ } elseif (($pd_value > $pr_array['criteria']) && ($pr_array['than'] == "include_only")){
5501
+ $allowed = 0;
5502
+ }
5503
+ break;
5504
+ case($pr_array['condition'] = "empty"):
5505
  if ((strlen($pd_value) < 1) && ($pr_array['than'] == "exclude")){
5506
+ $allowed = 0;
5507
+ } elseif ((strlen($pd_value) > 0) && ($pr_array['than'] == "exclude")){
5508
+ if($allowed <> 0){
5509
+ $allowed = 1;
5510
+ }
5511
+ } elseif ((strlen($pd_value) > 0) && ($pr_array['than'] == "include_only")){
5512
+ $allowed = 0;
5513
+ }
5514
+ break;
5515
+ default:
5516
+ break;
5517
+ }
5518
+ }
5519
+ }
5520
+ }
5521
+ }
5522
 
5523
+ if ($allowed < 1){
5524
+ $product_data = array();
5525
+ $product_data = null;
5526
+ } else {
5527
+ return $product_data;
5528
+ }
5529
+ }
5530
  }
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.4',
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,123 @@ 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 +3108,123 @@ 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.4
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.4 (2021-03-05) =
329
+ * Added Bing Shopping Promotions template
330
+
331
+ = 9.7.3 (2021-03-04) =
332
+ * Added a new attribute "Stock Status WooCommerce"
333
+ * Fixed another quote issue with the Facebook pixel
334
+
335
+ = 9.7.2 (2021-03-03) =
336
+ * Fixed an issue with the Facebook pixel. Product names that had an apostrophe in them were not measured.
337
+
338
+ = 9.7.1 (2021-03-03) =
339
+ * Added another fix to take into account prices excluding VAT for filtering out all but the minimum priced variation
340
+
341
+ = 9.7.0 (2021-03-03) =
342
+ * Fixed a bug where lowest priced variations where not making it to feeds
343
+
344
+ = 9.6.9 (2021-02-28) =
345
+ * Added product name parent hyphen attribute
346
+
347
+ = 9.6.8 (2021-02-25) =
348
+ * Added Google category taxonomy mapping for Snapchat feeds
349
+
350
+ = 9.6.7 (2021-02-25) =
351
+ * When suffixes and prefixes are used for the Heureka URL fields spaces are removed
352
+
353
+ = 9.6.6 (2021-02-24) =
354
+ * Added support for PHP 8.0
355
+
356
+ = 9.6.5 (2021-02-24) =
357
+ * Do not add Skroutz variable products to the feed when they do not have item_group_id's
358
+
359
+ = 9.6.4 (2021-02-24) =
360
+ * Fixed an issue with rules and filters
361
+ * When a rule was set on an image link, no longer lowercase the image link
362
+
363
+ = 9.6.3 (2021-02-23) =
364
+ * Fixed a bug, the Facebook pixel is now also measuing revenue for multiple items in Cart, InititiateCheckout and Purchase events
365
+ * Reverted back some changes in filters and rules
366
+
367
+ = 9.6.2 (2021-02-22) =
368
+ * For Skroutz feed removing sizes from feeds when they are out-of-stock
369
+
370
+ = 9.6.1 (2021-02-19) =
371
+ * Added attribute that will allow you to uppercase every first character of a string in product names
372
+
373
+ = 9.6.0 (2021-02-19) =
374
+ * Changed g:itemid to g:id for the Google Local Product Feeds
375
+
376
+ = 9.5.9 (2021-02-19) =
377
+ * Added a fail-safe when users do not select a marketing channel which let to PHP notices in logs
378
+
379
+ = 9.5.8 (2021-02-18) =
380
+ * Added shipping class name attribute
381
+
382
+ = 9.5.7 (2021-02-17) =
383
+ * Dynamic attribute values are now also added to parent variable products for Skroutz feeds
384
+
385
+ = 9.5.6 (2021-02-17) =
386
+ * Changed attribute name primary category to Yoast primary category as it caused lots of confussion
387
+
388
+ = 9.5.5 (2021-02-11) =
389
+ * Fixed a PHP notice that showed when creating a new rule
390
+ * Tested for compatibility with WooCommerce 5.0
391
+
392
+ = 9.5.4 (2021-02-09) =
393
+ * When free shipping zones are removed do not remove the other shipping zones
394
+
395
+ = 9.5.3 (2021-02-08) =
396
+ * Added a feature to remove free shipping zones from Google and Facebook feeds
397
+
398
+ = 9.5.2 (2021-02-08) =
399
+ * Fixed a minor issue in exclude rules for WooCommerce category names
400
+
401
+ = 9.5.1 (2021-02-02) =
402
+ * Dynamic attributes without values that are used for product details should be skipped which not always happened. This is fixed now.
403
+
404
+ = 9.5.0 (2021-02-01) =
405
+ * Discount rules created with the FlyCart plugin did not make it to Skroutz feeds. This has been solved now
406
+
407
+ = 9.4.9 (2021-01-31) =
408
+ * Added a seperate sale price attribute for bundled products
409
+ * Reviews for parent variable products are removed, the reviews are attached to its variations
410
+
411
+ = 9.4.8 (2021-01-30) =
412
+ * Fixed an issue with the ecomm_prodid on the cart page
413
+
414
+ = 9.4.7 (2021-01-29) =
415
+ * Solved an issue that shipping costs to the first product in a custom feed where empty
416
+
417
+ = 9.4.6 (2021-01-28) =
418
+ * Added a new attribute: product description parent product
419
+
420
+ = 9.4.5 (2021-01-28) =
421
+ * Added a Google Shopping field to their template: g:ship_from_country
422
+ * Stripping & characters from review names as it breaks the review feeds
423
+
424
+ = 9.4.4 (2021-01-27) =
425
+ * 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.
426
+
427
+ = 9.4.3 (2021-01-27) =
428
+ * Fixed an issue with an undefined ecomm_price variable on product variable pages
429
+
430
+ = 9.4.2 (2021-01-26) =
431
+ * Added the Dutch Boetiek.nl template
432
+
433
+ = 9.4.1 (2021-01-19) =
434
+ * Fixed a bug: exclude filters on empty product tags were broken. This is fixed now.
435
+
436
+ = 9.4.0 (2021-01-14) =
437
+ * Added a WP-cron check and notifications
438
+
439
+ = 9.3.9 (2021-01-14) =
440
+ * Bestprice.gr apparel products are now grouped by color
441
+
442
+ = 9.3.8 (2021-01-13) =
443
+ * Tested for compatibility with WooCommerce 4.9
444
+
445
  = 9.3.7 (2021-01-12) =
446
  * Added the Bestprice.gr template
447
 
3108
 
3109
  == Upgrade Notice ==
3110
 
3111
+ = 9.7.4 =
3112
+ Added Bing Shopping Promotions template
3113
+
3114
+ = 9.7.3 =
3115
+ Added a new attribute "Stock Status WooCommerce"
3116
+ Fixed another quote issue with the Facebook pixel
3117
+
3118
+ = 9.7.2 =
3119
+ Fixed an issue with the Facebook pixel. Product names that had an apostrophe in them were not measured.
3120
+
3121
+ = 9.7.1 =
3122
+ Added another fix to take into account prices excluding VAT for filtering out all but the minimum priced variation
3123
+
3124
+ = 9.7.0 =
3125
+ Fixed a bug where lowest priced variations where not making it to feeds
3126
+
3127
+ = 9.6.9 =
3128
+ Added product name parent hyphen attribute
3129
+
3130
+ = 9.6.8 =
3131
+ Added Google category taxonomy mapping for Snapchat feeds
3132
+
3133
+ = 9.6.7 =
3134
+ When suffixes and prefixes are used for the Heureka URL fields spaces are removed
3135
+
3136
+ = 9.6.6 =
3137
+ Added support for PHP 8.0
3138
+
3139
+ = 9.6.5 =
3140
+ Do not add Skroutz variable products to the feed when they do not have item_group_id's
3141
+
3142
+ = 9.6.4 =
3143
+ Fixed an issue with rules and filters
3144
+ When a rule was set on an image link, no longer lowercase the image link
3145
+
3146
+ = 9.6.3 =
3147
+ Fixed a bug, the Facebook pixel is now also measuing revenue for multiple items in Cart, InititiateCheckout and Purchase events
3148
+ Reverted back some changes in filters and rules
3149
+
3150
+ = 9.6.2 =
3151
+ For Skroutz feed removing sizes from feeds when they are out-of-stock
3152
+
3153
+ = 9.6.1 =
3154
+ Added attribute that will allow you to uppercase every first character of a string in product names
3155
+
3156
+ = 9.6.0 =
3157
+ Changed g:itemid to g:id for the Google Local Product Feeds
3158
+
3159
+ = 9.5.9 =
3160
+ * Added a fail-safe when users do not select a marketing channel which let to PHP notices in logs
3161
+
3162
+ = 9.5.8 =
3163
+ Added shipping class name attribute
3164
+
3165
+ = 9.5.7 =
3166
+ Dynamic attribute values are now also added to parent variable products for Skroutz feeds
3167
+
3168
+ = 9.5.6 =
3169
+ Changed attribute name primary category to Yoast primary category as it caused lots of confussion
3170
+
3171
+ = 9.5.5 =
3172
+ Fixed a PHP notice that showed when creating a new rule
3173
+ Tested for compatibility with WooCommerce 5.0
3174
+
3175
+ = 9.5.4 =
3176
+ When free shipping zones are removed do not remove the other shipping zones
3177
+
3178
+ = 9.5.3 =
3179
+ Added a feature to remove free shipping zones from Google and Facebook feeds
3180
+
3181
+ = 9.5.2 =
3182
+ Fixed a minor issue in exclude rules for WooCommerce category names
3183
+
3184
+ = 9.5.1 =
3185
+ Dynamic attributes without values that are used for product details should be skipped which not always happened. This is fixed now.
3186
+
3187
+ = 9.5.0 =
3188
+ Discount rules created with the FlyCart plugin did not make it to Skroutz feeds. This has been solved now
3189
+
3190
+ = 9.4.9 =
3191
+ Added a seperate sale price attribute for bundled products
3192
+ Reviews for parent variable products are removed, the reviews are attached to its variations
3193
+
3194
+ = 9.4.8 =
3195
+ Fixed an issue with the ecomm_prodid on the cart page
3196
+
3197
+ = 9.4.7 =
3198
+ Solved an issue that shipping costs to the first product in a custom feed where empty
3199
+
3200
+ = 9.4.6 =
3201
+ Added a new attribute: product description parent product
3202
+
3203
+ = 9.4.5 =
3204
+ Added a Google Shopping field to their template: g:ship_from_country
3205
+ Stripping & characters from review names as it breaks the review feeds
3206
+
3207
+ = 9.4.4 =
3208
+ 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.
3209
+
3210
+ = 9.4.3 =
3211
+ Fixed an issue with an undefined ecomm_price variable on product variable pages
3212
+
3213
+ = 9.4.2 =
3214
+ Added the Dutch Boetiek.nl template
3215
+
3216
+ = 9.4.1 =
3217
+ Fixed a bug: exclude filters on empty product tags were broken. This is fixed now.
3218
+
3219
+ = 9.4.0 =
3220
+ Added a WP-cron check and notifications
3221
+
3222
+ = 9.3.9 =
3223
+ Bestprice.gr apparel products are now grouped by color
3224
+
3225
+ = 9.3.8 =
3226
+ Tested for compatibility with WooCommerce 4.9
3227
+
3228
  = 9.3.7 =
3229
  Added the Bestprice.gr template
3230
 
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.4
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.4' );
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) :