Search for connected taxonomies
-
How can I search for taxonomies of post and give them a search weight ?
-
Hi @coholm
Please could you explain better what should happen there, what you need to search, what should be in search results and how it should be weighted?Thanks!
I have a product that has a custom taxonomy called “serien”.
The taxonomy has different terms: Cat1, Cat2, Cat3, etcWhen I enter Cat1 in the search bar, I want all products to show up, that are assigned to the taxonomy term Cat1.
You can ignore the requirement for the weight for now.
I have experimented with the following code:
$data[] = get_term_meta($post->ID, ‘serien-varianten’, true);
$data[] = get_the_terms($post->ID, ‘serien-varianten’, true);but in the “Index Engine Tester” this results in the output of “Array”
I expect to have the comma sperated terms of the taxonomy, that are assigned to the product: Cat1, Cat2I would say you need to use get_the_terms() to get the list of terms. But let’s keep in mind, this function returns an array of objects and we need to extract ‘name’ property from each object. The final code may look like this
$ts = get_the_terms($post->ID, 'serien-varianten'); $a = array(); foreach ($ts as $term) { $a[] = $term->name; } $data['serien_values'] = implode(' ', $a);
Thanks for your reply.
My current code looks like this:
add_filter('wpfts_index_post', function($index, $post) { global $wpdb; // Basic tokens /* * This piece of code was commented out intentionally to display things * which was already done before in the caller code $index['post_title'] = $post->post_title; $index['post_content'] = strip_tags($post->post_content); */ if ($post->post_type == 'product') { // Adding new token "employee_data" specially for posts of type "employee" $data = array(); $data[] = get_post_meta($post->ID, 'wpcf-bauteilart', true); $data[] = get_post_meta($post->ID, '_sku', true); $index['employee_data'] = implode(' ', $data); } return $index; }, 3, 2);
Where do I add your code?
Let’s add it after $index[’employee_data’]
add_filter('wpfts_index_post', function($index, $post) { global $wpdb; // Basic tokens /* * This piece of code was commented out intentionally to display things * which was already done before in the caller code $index['post_title'] = $post->post_title; $index['post_content'] = strip_tags($post->post_content); */ if ($post->post_type == 'product') { // Adding new token "employee_data" specially for posts of type "employee" $data = array(); $data[] = get_post_meta($post->ID, 'wpcf-bauteilart', true); $data[] = get_post_meta($post->ID, '_sku', true); $index['employee_data'] = implode(' ', $data); // Why employee_data? You can use your own key name here. // Here $ts = get_the_terms($post->ID, 'serien-varianten'); $a = array(); foreach ($ts as $term) { $a[] = $term->name; } $index['serien_values'] = implode(' ', $a); } return $index; }, 3, 2);
- This reply was modified 4 years, 7 months ago by Epsiloncool.
Thank you, that worked perfectly.
How can change the order in which the results appear now?
I would like to sort results as follows:
1. bauteilart (custom field):
possible values: 1, 2, 3 – sort assending
2. serie (custom taxonomiy):
possible values: “different terms” – sort assendingWell, I’d say you need to use WP_Query’s ordering capabilities (actually WPFTS only make weights for relevance formula, other ordering things are still controlled by the WP_Query).
Please read the documentation of WP_Query, especially order/orderby part
https://developer.www.ads-software.com/reference/classes/wp_query/#order-orderby-parametersThere is lots of reading and play for. I am sure you will find the case which is best for you.
Hi @coholm
Do you have any solution to the problem?
- The topic ‘Search for connected taxonomies’ is closed to new replies.