Problem :
Adding a status to Woocommerce.
A lot of resources on internet, for example here
It was not working… I had the status in the list, but when saving the command, the old post status was kept…
1h search….
Solution :
My new order key, especially the post status / order status : wc-clickreserver-ready
To be used in :
register_post_status( wc-clickreserver-ready, ...
Well, -ready
is not a good idea
Perfectly working with :
register_post_status( wc-clickreserver, ...
Lire la suite de Adding a custom order to woocommerce do not update the post_status
Problem :
Times to times, Facebook and Woocommerce lost their synchronization.
In this case, the solution is to reset everything (if you have on Facebook, only your Woocommerce products !!)
Some information there :
But if your catalog is connected to a shop you can not delete your catalog…
And for any reason, the bulk requests was not working for me : accepted, no error, but still all the products !
I used :
https://graph.facebook.com/v15.0/<my shop>/items_batch
{"allow_upsert": "true", "item_type": "PRODUCT_ITEM", "requests": [
{"method": "DELETE", "data": {"id": "1234"}},
{"method": "DELETE", "data": {"id": "2345"}}
{"method": "DELETE", "data": {"id": "3456"}}
]}
Solution :
So I tried to build the request by myself with a short python file :
import requests
BASE_URL_FACEBOOK = 'https://graph.facebook.com/v16.0'
BASE_URL_FACEBOOK_BOUTIQUE = f'{BASE_URL_FACEBOOK}/<your shop>'
TOKEN = "yourToken"
# You must initialize logging, otherwise you'll not see debug output.
#logging.basicConfig()
#logging.getLogger().setLevel(logging.DEBUG)
url="/products?bulk_pagination=false&summary=true&limit=1000"
print(f'Calling GET : {url}')
hdr = {'User-Agent': r'Facebook-for-WooCommerce/2.6.27 (WooCommerce/6.8.2; WordPress/5.9.5)', 'Accept':'*/*', 'Content-Type': 'application/json', 'Authorization': f"Bearer {TOKEN}"}
response = requests.get(BASE_URL_FACEBOOK_BOUTIQUE + url, headers=hdr)
if response.status_code == 200 or response.status_code == 201:
print(f'GET OK')
products_response = response.json()
delete_products_requests = list()
print(products_response['summary']['total_count'])
for product in products_response['data']:
id = product['id']
delete_command = {'method': 'DELETE', 'data': {"id":id}}
delete_products_requests.append(delete_command)
delete_request = dict()
delete_request['allow_upsert'] = 'true'
delete_request['item_type'] = 'PRODUCT_ITEM'
delete_request['requests'] = delete_products_requests
url="/items_batch"
print(json.dumps(delete_request))
response = requests.post(BASE_URL + url, headers=hdr, data=json.dumps(delete_request))
print(response.status_code)
print(response.text)
response.raise_for_status()
handles = response.json()['handles']
print(f'handle = {handles}')
And follow the request with :
https://graph.facebook.com/v16.0/<shop id>/check_batch_request_status?handle=<myHandle from previous request>
Still no error, but nothing deleted (we can follow the batch request in
Facebook Business Manager > Catalog > Data Source > Application
At the end, I found the delete
request on a single product (simple by slowest) :
import requests
BASE_URL_FACEBOOK = 'https://graph.facebook.com/v16.0'
BASE_URL_FACEBOOK_BOUTIQUE = f'{BASE_URL_FACEBOOK}/<your shop>'
TOKEN = "yourToken"
url="/products?bulk_pagination=false&summary=true&limit=1000"
print(f'Calling GET : {url}')
hdr = {'User-Agent': r'Facebook-for-WooCommerce/2.6.27 (WooCommerce/6.8.2; WordPress/5.9.5)', 'Accept':'*/*', 'Content-Type': 'application/json', 'Authorization': f"Bearer {TOKEN}"}
response = requests.get(BASE_URL_FACEBOOK_BOUTIQUE + url, headers=hdr)
if response.status_code == 200 or response.status_code == 201:
print(f'GET OK')
products_response = response.json()
products = dict()
delete_products_requests = list()
print(products_response['summary']['total_count'])
for product in products_response['data']:
id = product['id']
url=f"/{id}"
response = requests.delete(BASE_URL_FACEBOOK + url, headers=hdr)
print(f'{response.status_code} : {response.text}')
if (response.status_code != 200):
print(f'Can not delete product {id}')
Problem :
A wordpress site with OceanWP theme, Woocommerce plugin.
The requirement was to have 3 parts in the website :
- Each parts has a different menu
- Each parts has a different colors for menu and header
With OceanWP, you can set for each page : menu, custom header, colors...
A bit tedious to maintain from my point of view, but works, except for Woocommerce pages, especially categories.
Solution :
As everything in wordpress works with extensions, even OceanWP andWoocommerce have their own set of paid extensions... A world of business here (as 50% of the websites run wordpress...). Paid extension could be really usefull in some cases, for my simple task, I simply do it like that :
- Export OceanWP parameters
- Create a child theme of OceanWP and activate it
- Import OceanWP parameters
- Advantages :
- You can copy / paste of the parent theme in the child theme to modify it
- You can add custom functions
- Here is the main part, as OceanWP is very customizable (to authorize paid plugins), they already have a lot of hook ready
- ocean_custom_header_template : a hook to select the template
- ocean_custom_menu : a hook to select the menu
Adding hook to select the right theme for Woocommerce page :
function my_custom_header_function($template) {
$result=$template;
if ( is_shop() || is_product() || is_product_category() ) {
if ('<name-of-my-slug>' == get_queried_object()->slug) {
// Exception for one category
// We have created custom OceanWP header in OceanWP Theme Library, here is the ID (shown in the URL when editing the custom header)
$result=10849;
} else {
// All others categories have another header
$result=10244;
}
}
return $result;
}
add_filter( 'ocean_custom_header_template', 'my_custom_header_function' );
And for the menu :
function my_custom_menu($menu) {
if ( is_shop() || is_product() || is_product_category() ) {
if ('<name-of-my-slug>' != get_queried_object()->slug) {
// Except for one category, I return the custom menu to display
return '493';
}
}
return $menu;
}
add_filter( 'ocean_custom_menu', 'my_custom_menu');
Well, done, not perfect but done thanks to OceanWP possible customization and Wordpress ecosystem of paid plugins.
Could be done :
- Suggest a pull request to OceanWP with an GUI to select the custom header/menu for a given slug
- Select the custom header in a list instead of putting direct ID...
But no time today !
And I tried a mix of extensions :
But as everything, they are designed to work for a given use case and OceanWP+Woocommerce for categories was not in the scope.