Sequential number, order number
-
Hello All,
I display on a site with WP and Pods the same data I have in a Access database. In Access I have a list of published rececettes (recipes) extracted with the following SQL query :
SELECT (SELECT COUNT(Nom) FROM TabRecettesPréparation AS TabRecettesPréparation_Alias WHERE (((TabRecettesPréparation_Alias.Publiée)=[Formulaires]![ForPréparationRecettesPubliéesOuNon]![Publiée])) and TabRecettesPréparation_Alias.Nom < TabRecettesPréparation.Nom)+1 AS Ordre, TabRecettesPréparation.N°, TabRecettesPréparation.Nom, TabRecettesPréparation.Sous_titre, TabRecettesPréparation.Région, TabRecettesPréparation.Publiée FROM TabRecettesPréparation WHERE (((TabRecettesPréparation.Publiée)=[Formulaires]![ForPréparationRecettesPubliéesOuNon]![Publiée])) ORDER BY TabRecettesPréparation.Nom, TabRecettesPréparation.Sous_titre;
The output data have a dynamically generated sequential number called Ordre.
With Pods I have build a page that list all the Recette on the site. I do that with
<bold><hr></bold> {@post_title} - {@sous_titre} <br>
How can I add a sequential number as I can do in Access ?
Thanks
Alphonse PHILIPPE
-
Hello @alpph
First of all, I see characters like
é
in your tables and fields. I wouldn’t recommend using such characters in any structures to ensure stability.As for your question. You could create an
[each]
loop within an<ol>
element.
Other than that this is not possible within Pods Templates. You’d have to use PHP and implement a counter within the loop for this to work. We have the{_index}
magic tag but that counts from0
as common in programming languages.Cheers, Jory
- This reply was modified 4 years, 8 months ago by Jory Hogeveen.
Hello,
There is no problem to use accentued characters in Access and WP. Access, and Office in general, is UNICODE compliant. WP change these characters in “standard” characters in the slug. It’s a long time that this is not a issue.
By copying code and adapted it, I could build a shortcode that give the total number of ‘recette’ pods.
function totalrecettes() { $recettes = pods( 'recette' , array( 'limit' => -1 ) ); return $recettes->total_found(); } add_action( 'plugins_loaded', 'slug_add_additional_pods_shortcodes' ); function slug_add_additional_pods_shortcodes() { if ( function_exists( 'pods' ) ) { add_shortcode( 'nombrerecettes', 'totalrecettes' ); } }
My pods i very simple : name “recette”, 7 fields, no relation to other pods or taxinomy, 3 associated taxonomies.
In the documentation i found information for [each], but only in relation to relationship field, taxonomy and images.
Have you a simple snippet of code or a link where I could find some help to continue ?
Thanks
Alphonse PHILIPPE
There is no problem to use accentued characters in Access and WP. Access, and Office in general, is UNICODE compliant. WP change these characters in “standard” characters in the slug. It’s a long time that this is not a issue.
Might be true, but this is not Office and it’s simply not recommended for in-code use. For post titles and content and other display type information etc. there is no problem at all, but the code you’ve posted is a database query..
Anyway, there are various loop types in PHP: https://www.w3schools.com/php/php_looping.asp
More info in relation to Pods:
https://docs.pods.io/code/pods/find/You can create a counter within the loop, example:
$counter = 0; while ( $pod->fetch() ) { $counter++; }
Cheers, Jory
Hi,
Again, by searching, copying and adaptation, I can give a solution with two shortcodes.
1- Count the number of Pods
function totalrecettes() { $recettes = pods( 'recette' , array( 'limit' => -1 ) ); return $recettes->total_found(); } add_action( 'plugins_loaded', 'slug_add_additional_pods_shortcodes' ); function slug_add_additional_pods_shortcodes() { if ( function_exists( 'pods' ) ) { add_shortcode( 'nombre_recettes', 'totalrecettes' ); } }
2 List the pods with a sequence number :
// Add Shortcode Les recettes function liste_des_recettes( $atts , $content = null ) { // Query $args = array ( 'post_type' => 'recette', 'orderby' => 'title', 'order' => 'ASC', 'posts_per_page' => -1, ); $the_query = new WP_Query($args); // Posts $counter = 0; $output = '<ul>'; while ( $the_query->have_posts() ) : $the_query->the_post(); $counter++; $output .= '<li>' .$counter . " - "; $output .= get_the_title() ; $pods = pods( get_post_type(), get_the_ID() ); $output .= " - ". $pods->display( 'sous_titre' ). '</li>'; endwhile; $output .= '</ul>'; // Reset post data wp_reset_postdata(); // Return code return $output; } add_shortcode( 'les_recettes', 'liste_des_recettes' );
For me, the topic is closed.
Sometimes a nonresponse is stimulating.
Alphonse PHILIPPE
Hi @alpph
You don’t need the first total_count shortcode in this situation.
WP_Query already has a total count parameter available.
See: WP_Query->post_count ($the_query->post_count
)Cheers, Jory
Hi
https://developer.www.ads-software.com/reference/classes/wp_query/ :
….
$post_count
The number of posts being displayed.
$found_posts
The total number of posts found matching the current query parameters
…https://wordpress.stackexchange.com/questions/74920/post-count-only-shows-the-number-of-results-per-page :
…
the $wp_query->post_count only shows the amount of posts on each page.
…
$wp_query->post_count is supposed to work exactly like that. To get the total number of posts that exist in the database, use $wp_query->found_postsIt’s an other way to achieve the same result. I will stay on what I have found.
Thanks
Hi @alpph
Ah yeah you are correct. I meant
$wp_query->found_posts
.I’d advice you do use that property instead of an extra shortcode.
The extra shortcode also makes an extra query that is not needed.
Using the WP_Query parameter improves your site performance.Cheers, Jory
Hi
I prefer use shortcodes instead modifyng themes template.
For Pods
Count the pods 1 :
// Ajout Shortcode : nombre de pods function total_pods($atts , $content = null ) { //Parameters extract(shortcode_atts( array ( 'my_pod' => '' ), $atts)); //Compte les pods $my_pods = pods( $my_pod , array( 'limit' => -1 ) ); // Return return $my_pods->total_found(); } add_shortcode( 'nombre_pods', 'total_pods' );
Count the pods 2 :
// Ajout Shortcode 2 : nombre de pods function total_pods_2($atts , $content = null ) { //Parameters extract(shortcode_atts( array ( 'my_pod' => '' ), $atts)); // Query $args = array ( 'post_type' => $my_pod, ); //Compte les pods //Return return (new WP_Query( $args ))->found_posts; } add_shortcode( 'nombre_pods_2', 'total_pods_2' );
Usage
<h6>Nombre de recettes publiées : [nombre_pods_2 my_pod ='recette' ]</h6> <h6>Nombre de recettes publiées : [nombre_pods my_pod ='recette' ]</h6>
Some verifications should be added in the code
- This reply was modified 4 years, 8 months ago by Alph.
List the pods
// Ajout Shortcode : liste numérotée des pods function liste_des_pods( $atts , $content = null ) { //Parameters extract(shortcode_atts( array ( 'my_pods' => '' ), $atts)); // Query $args = array ( 'post_type' => $my_pods, 'orderby' => 'title', 'order' => 'ASC', 'posts_per_page' => -1, ); $the_query = new WP_Query($args); // Liste les pods $counter = 0; $output = '<ul>'; while ( $the_query->have_posts() ) : $the_query->the_post(); $counter++; $output .= '<li>' .$counter . " - "; $output .= get_the_title() ; $pods = pods( get_post_type(), get_the_ID() ); $output .= " - ". $pods->display( 'sous_titre' ). '</li>'; endwhile; $output .= '</ul>'; // Reset post data wp_reset_postdata(); // Return return $output; } add_shortcode( 'les_pods', 'liste_des_pods' );
Usage
[les_pods my_pods ='recette']
Count categories
// Ajout Shortcode : nombre de taxonomies function total_categories($atts ) { //Parametres extract(shortcode_atts( array ( 'my_categorie' => '' ), $atts)); //Compte les taxonomies $args = array( 'taxonomy' => $my_categorie, 'hide_empty' => true ); // Return return wp_count_terms ($my_categorie, $args ); } add_shortcode( 'nombre_categories', 'total_categories' );
Usage
<h6>Nombre ? Nature type ? publiés : [nombre_categories my_categorie = 'nature_type']</h6>
List categories
// Ajout Shortcode : liste numérotée des taxonomies function liste_des_categories( $atts ) { //Parametres extract(shortcode_atts( array ( 'my_categorie' => '' ), $atts)); // Query $categories = get_categories( array( 'taxonomy' => $my_categorie, 'orderby' => 'name', 'order' => 'ASC', 'hide_empty' => true ) ); // Liste les taxonomies $counter = 0; $output = '<ul>'; if ( ! empty( $categories ) ) { foreach ( $categories as $categorie ) { $counter++; $output .= '<li>' . $counter . " - "; $output .= $categorie->name . '</li>'; } }; $output .= '</ul>'; // Return return $output; } add_shortcode( 'les_categories', 'liste_des_categories');
Usage
[les_categories my_categorie = "nature_type" ]
Thats all
AP
Hi Alphonse,
I am looking for a counting solutions as well, and I think what you came up with is half-way there.
I adapted your code:
<?php function total_pods($atts , $content = null ) { extract(shortcode_atts( array ( 'my_pod' => '' ), $atts)); $my_pods = pods( $my_pod , array( 'limit' => -1 ) ); return $my_pods->total_found(); } add_shortcode( 'count_pods', 'total_pods' ); ?> <p>Number of performances: [count_pods my_pod ='performances']
Thank you for that!
And it does work: It displays the total number of entries in that pod called “performances”.
But I want that number to be selective, to only count those “performances” with one of that pod’s fields having a specific value.
I am not really sure: Were you trying to do the same thing, a selective count? And did you figure out a solution for that? I fail to find one.
Stefan
Hi,
In your case “performances” is a categorie of your Pods. To count a specific value , i.e. “high”, of performance, you have to use the shortcode ‘nombre_categories’
[nombre_categories my_categorie = 'high']
https://www.ads-software.com/support/topic/sequential-number-order-number/#post-12525177
Nombre ? Nature type ? publiés : [nombre_categories my_categorie = 'nature_type'] // counte the the catégorie of the pods [les_categories my_categorie = "nature_type" ] //lit the categorie
Hi,
I add a counter for the occurences of the termes of a category i.e. taxonomy. I modify “List categories”
// Ajout Shortcode : liste numérotée des des termes d'une catégorie function liste_des_categories( $atts ) { //Parametres extract(shortcode_atts( array ( 'my_categorie' => '' ), $atts)); // Query $categories = get_categories( array( 'taxonomy' => $my_categorie, 'orderby' => 'name', 'order' => 'ASC', 'hide_empty' => true )); // Liste les termes $counter = 0; $output = '<ul>'; if ( ! empty( $categories ) ) { foreach ( $categories as $categorie ) { // le numéro d'ordre du terme $counter++; $counter = sprintf('%02d', $counter); $output .= '<li>' . $counter . " - "; // le compteur des occurences du terme $nombre= $categorie->count; $nombre = sprintf('%02d', $nombre); $output .= '<i>' . $nombre . '</i>' . " - "; // le lien vers le terme $permalink = get_category_link ($categorie); $name = $categorie->name ; $output .= '<a href="'.$permalink.'">' . $name.'</a>'; $output .= '</li>'; } }; $output .= '</ul>'; // Return return $output; } add_shortcode( 'les_categories', 'liste_des_categories');
For each term, the shortcode output : sequential number, number of occurences, link to the term
Exemple for the “Nature, type” of a Recipe
01 – 01 – beignets
02 – 04 – galettes
03 – 03 – gateau
04 – 01 – liqueur
05 – 01 – omelette
….Sincères salutations
Hi Alphonse,
Thank you very much for your efforts to explain it to me, I appreciate it! Unfortunately, I still fail to get this function to work. Maybe you could have one more look at it?
So, I have two pods: “work” and “performances”. They are connected: In “performances”, there is a relationship field called “composition”, which refers to the pod “work”. Like this, “performances” are always related to one “work”, that is performed.
Now, in the “work” template, I want to include a counter, that displays the total number of performances of this very work.
(1) First thing I did was this adaption of your code:
<?php function total_pods($atts , $content = null ) { extract(shortcode_atts( array ( 'my_pod' => '' ), $atts)); $my_pods = pods( $my_pod , array( 'limit' => -1 ) ); return $my_pods->total_found(); } add_shortcode( 'count_pods', 'total_pods' ); ?> <p>Number of performances: [count_pods my_pod ='performances']
And it kind of worked! It does display the total number of performances – but of all, that were ever entered. Yet, what I want, is only that selection of performances, where the field “composition” relates to the “work” page that the user am on at that moment.
(2) Then you proposed to me this:
<?php // Ajout Shortcode : nombre de taxonomies function total_categories($atts ) { //Parametres extract(shortcode_atts( array ( 'my_categorie' => '' ), $atts)); //Compte les taxonomies $args = array( 'taxonomy' => $my_categorie, 'hide_empty' => true ); // Return return wp_count_terms ($my_categorie, $args ); } add_shortcode( 'nombre_categories', 'total_categories' ); ?> [nombre_categories my_categorie = 'performances'] // counte the the catégorie of the pods [les_categories my_categorie = "performances" ] //lit the categorie
But it get an error, and maybe I did not adapt your code correctly. (It says: “Catchable fatal error: Object of class WP_Error could not be converted to string on line 343”).
(3) And the list code, that you posted last, looks really cool! I do not really need it at this point, but I tried to make it work anyways, yet failed as well.
Would you have a piece of advice for me, why the codes would not work in my template? Did I adapt the code incorrectly? It appears you did find the solution for this issue already, but I do not succeed to get it to work in my specific situation.
Thanks!!
Stefan
- The topic ‘Sequential number, order number’ is closed to new replies.