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