Publié le Laisser un commentaire

WordPress: Modifier un menu dynamiquement

Dans cet article nous allons voir comment modifier un menu dynamiquement dans WordPress. 

Dans cet exemple, nous allons remplacer une partie du menu en nous servant du ‘filtre’ WordPress suivant:  ‘wp_nav_menu_items’.

 Il nous permettra d’injecter notre élément à la suite des autres éléments déjà configurés dans l’admin de WordPress.

Dans notre menu de navigation, nous allons afficher certains éléments suivant si l’utilisateur est connecté, ou pas.

Si l’utilisateur est connecté:

Il y aura son nom, un lien pour se déconnecter et un lien pour voir les détails de son compte.

Si l’utilisateur est déconnecté:

Il y aura un lien pour se connecté.

'wp_nav_menu_items' , Comment ça marche ?

Le Filtrewp_nav_menu_items‘, prend deux arguments, $items et $args.

$items contient le menu chargé par WordPress ( Donc il pourrait contenir le menu du Footer, la barre de navigation etc… ). 

$args contient tout les paramètres du menu. Voici la liste de toutes les infos que vous pourriez en retirer.

‘menu’
‘menu_class’
‘menu_id’
‘container’
‘container_class’
‘container_id’
‘container_aria_label’
‘fallback_cb’
‘before’
‘after’
‘link_before’
‘link_after’
‘echo’
‘depth’
‘walker’
‘theme_location’
‘items_wrap’
‘item_spacing’
 
 
Copier coller ce snippet dans votre fichier functions.php.
Cette fonction retourne tout simplement le menu qui vient d’être chargé ‘Ligne 5: return $items‘ .
add_filter( 'wp_nav_menu_items', 'ajouter_au_menu_nav_eloou', 10, 2 );

function ajouter_au_menu_nav_eloou( $items, $args ) {

    return $items;
    
}

Les conditions, pourquoi et comment ?

Comme vu précédemment, nous avons besoin de différentes conditions pour être sûr qu’on modifie le bon menu, au bon moment. 

Nous allons nous servir de cette fonction WordPress, ‘ is_user_logged_in() ‘ , afin de regarder si l’utilisateur est connecté sur son compte en nous retournant un ‘ true ‘ ou ‘ false ‘.

Nous allons aussi nous servir de la variable ‘ $args ‘, dans la section précédente. Elle nous permet de vérifié que c’est le bon menu en regardant le ‘ theme_location ‘.

Le ‘theme_location’ sera le nom que vous avez déclaré lorsque vous avez initialisé le menu dans le fichier functions.php

Exemple:

register_nav_menu(‘ main-navigation ‘,__( ‘ Menu principal ‘ ));

 

Ci-dessous ma condition:

Ligne 1

Si l’utilisateur est connecté ET le menu qui est chargé par WordPress s’appel ‘ main-navigation ‘.

Ligne 4

Si l’utilisateur n’est pas connecté ET le menu qui est chargé par WordPress s’appel ‘ main-navigation ‘.

    if (is_user_logged_in() && $args->theme_location == 'main-navigation') {

    }
    elseif (!is_user_logged_in() && $args->theme_location == 'main-navigation') {
    }

Changer le menu si l'utilisateur est connecté

Pour faire cela, nous allons prendre la variable qui tiens le contenu du menu et ajouter nos éléments.

Ligne 3 et 4

Nous sommes dans la condition « Si l’utilisateur est connecté », donc nous pouvons prendre quelques informations sur cette personne en utilisant la fonction WordPress: wp_get_current_user();

Ensuite nous allons chercher le nom de cette personne en fouillant la variable $user.

Ligne 6

Maintenant à nous d’ajouter le nouveau contenu au menu existant.

J’ai rajouté:

  • Un ‘ dropdown ‘ avec le nom de l’utilisateur et une icône : ligne 8,9,10
  • Un élément avec une url vers les détails de son compte : ligne 14.
  • Un élément avec une possibilité de se déconnecter : ligne 19.
if (is_user_logged_in() && $args->theme_location == 'main-navigation') {

    $user = wp_get_current_user();
    $word = $user->data->display_name;
    
    $items .= '
        <li>
            <a href="">'.'
                <i class="fas fa-user"></i>'
                . $word .'
            </a>
            <ul>
                <li>
                    <a href="https://www.neuro-ophtalmologie-club.org/mon-compte/" >
                        Mon compte
                    </a>
                </li>
                <li>
                    <a href="'. wp_logout_url('/Votre-redirection-d-url'). '" >
                        Déconnexion
                    </a>
                </li>

            </ul>
        </li>
    ';
    
}

Changer le menu si l'utilisateur est déconnecté

Pour faire cela, nous allons prendre la variable qui tiens le contenu du menu et ajouter nos éléments. dans la condition si l’utilisateur n’est pas connecté.

Ligne 3 

Ajoutons le nouveau contenu au menu existant.

J’ai rajouté:

  • Un ‘ dropdown’ ‘ Se connecter ‘ : ligne 5

  • Un élément avec une url vers une formulaire de connexion : ligne 8.

elseif (!is_user_logged_in() && $args->theme_location == 'main-navigation') {
    
    $items .= '
            <li>
                <a href="">Se connecter</a>
                <ul>
                    <li>
                        <a href="https://www.neuro-ophtalmologie-club.org/connexion/">
                            Connexion
                        </a>
                    </li>
                </ul>
            </li>
        ';
        
}

Et maintenant on assemble tout

add_filter( 'wp_nav_menu_items', 'ajouter_au_menu_nav_eloou', 10, 2 );
function ajouter_au_menu_nav_eloou( $items, $args ) {
    $user = wp_get_current_user();
    $word = $user->data->display_name;
    if (is_user_logged_in() && $args->theme_location == 'main-navigation') {

        $items .= '
                    <li>
                        <a href="/Url-de-votre-page-details-de-compte">'.'
                            <i class="fas fa-user"></i>'
                            . $word .'
                        </a>
                        <ul>
                            <li><a href="'. wp_logout_url('/Votre-redirection-d-url'). '" >Déconnexion</a></li>
                            <li><a href="https://www.neuro-ophtalmologie-club.org/mon-compte/" >Mon compte</a></li>
                        </ul>
                    </li>
                ';
    }
    elseif (!is_user_logged_in() && $args->theme_location == 'main-navigation') {
        $items .= '
                    <li>
                        <a href="">Se connecter</a>
                        <ul>
                        <li><a href="https://www.neuro-ophtalmologie-club.org/connexion/">Connexion</a></li>
                        </ul>
                    </li>
                ';
    }
    return $items;
}
Publié le Laisser un commentaire

Woocommerce: Changer le texte du bouton ‘Ajouter au panier’ des produits apparentés.

Dans cet article nous allons voir comment changer le texte du bouton « ajouter au panier » des produits apparentés.

Pour commencer, il faut créer une fonction qui utilisera un hook, ce qui permettra d’injecter votre texte à la place de celui mis en place par Woocommerce.

Dans votre fichier functions.php, créez votre fonction puis grâce aux hooks, ajoutez la via la fonction add_filter.

Ce changement se fera sur tout les produits apparentés. Il suffira de remplacer ‘Votre nouveau texte’ pour faire la modification sur ce  bouton.

add_filter( 'woocommerce_product_add_to_cart_text', 'eloou_cart_button_text' );

function eloou_cart_button_text() {
    return 'Votre nouveau texte';
}

Changer le texte pour un produit spécifique

Il est aussi possible de changer le texte selon le produit, si l’utilisateur est en ligne ou si l’utilisateur a un certain rôle.

Tout est possible.

Je vais vous donner un exemple pour afficher un texte différent si mon produit, qui a pour id ‘2494’, est affiché dans les produits apparentés.

Ligne 5 et 6

Je vais chercher l’ID du produit

Ligne 7

Puis je déclare l’ID du produit qui m’intéresse.

Ligne 9

Je retourne le nouveau texte à condition que l’ID de mon produit soit égal à celui du produit qu’on observe, sinon il retournera un texte par défaut.

    add_filter( 'woocommerce_product_add_to_cart_text', 'eloou_cart_button_text' );
    
    function eloou_cart_button_text() {

        global $product;
        $product_id = $product->id;
        $productId = 2494;

        return ($product_id == $productId ? 'Votre nouveau texte' : 'Un texte par défaut.');
        
    }

Pour allez plus loin

Vous vous demandez peu être s’il est possible d’ajouter une interface dans l’admin pour modifier votre texte sans devoir s’aventurer dans le code?

Et bien oui!
Mais nous verrons ça dans un prochain article.

Maintenant c’est à vous de jouer!

Publié le Laisser un commentaire

Woocommerce: Changer le prix d’un produit en fonction d’un client

woocommerce-user-meta-date-price-change
woocommerce-user-meta-date-price-change

Dans cet article nous allons voir comment changer le prix d’un produit en fonction d’un champs personnalisé, aussi appelés user meta data.

Pour commencer, il faut créer une fonction impactant le prix de l’article

Dans votre fichier functions.php, créez votre fonction puis grâce aux hooks, ajoutez la via la fonction add_filter.

    // Un changement de prix gobal
    function eloou_price( $price, $product ) {
     return $price;
    }
    
    add_filter( 'woocommerce_product_get_price', 'eloou_price', 10, 2 );
    add_filter( 'woocommerce_product_get_regular_price', 'eloou_price', 10, 2 );
    add_filter( 'woocommerce_product_get_sale_price', 'eloou_price', 10, 2 );

Il faut d’abord vérifier que l’utilisateur soit connecté, puis récupérer le champs personnalisé à cibler

if ( is_user_logged_in() ) {
    $user = wp_get_current_user(); 
    $meta = get_the_author_meta( 'votre_custom_meta', $user->ID );
}

Changer le prix de tous les produits

On peut maintenant changer le prix grâce à une formule mathématique, en créant une nouvelle variable $newPrice.

Ligne 7
Le prix changera uniquement si le meta de l’utilisateur existent.

function eloou_price( $price, $product ) {
    if ( is_user_logged_in() ) {
        $user = wp_get_current_user();
        $meta = get_the_author_meta( 'votre_custom_meta', $user->ID );
        $newPrice = 0.50;
        // on vérifie que le meta existe
        if ( $meta ) {
            $price = $price * $newPrice;
        }
    }
    return $price;
}

Changer le prix d'un seul produit

Pour viser un produit en particulier, il n’ y a rien de plus simple!

Chaque produit possède un ID. qui se trouve dans l’url du produit de votre administration :
/wp-admin/post.php?post=2494&action=edit&classic-editor

Pour mon exemple, je choisis le produit ayant l’id = 2494.

Ligne 7
Je vais chercher l’ID du produit en me servant d’une fonction Woocommerce.
Ligne 6
Puis je déclare l’ID du produit qui m’intéresse.
Ligne 9

Je rajoute à ma condition: Si le méta existe, et si c’est le produit avec l’ID 2494, alors  on change le prix.

function eloou_price( $price, $product ) {
    if ( is_user_logged_in() ) {
        $user = wp_get_current_user();
        $meta = get_the_author_meta( 'votre_custom_meta', $user->ID ); 
        $newPrice = 0.50; // votre réduction
        $product_id = 2494; // l'ID de votre produit
        $productId = $product->get_id();

        if ( $meta && $product_id == $productId ) {
            $price = $price * $newPrice;
        }
    }
    return $price;
}

Pour allez plus loin

Vous vous demandez peu être s’il est possible d’ajouter une interface dans l’admin pour modifier les produits,  les calculs et peut être même les métas datas ? 
Et bien oui!
Mais nous verrons ça dans un prochain article.

Maintenant c’est à vous de jouer!

Publié le Laisser un commentaire

Ouverture site Granicuiz.com

Ouverture du site Granicuiz
Ouverture du site Granicuiz

La Société Granicuiz a été créée à Châteaudun (28) en janvier 2012.
Forte de son indépendance et d’une expérience de près de 30 ans dans le secteur du bâtiment, elle a su s’entourer d’un réseau de professionnels reconnu et pleinement trouver sa place dans le paysage dunois.

En cette fin d’année 2021, nous sommes fiers de vous annoncer l’ouverture du site :  Granicuiz.com

Publié le Laisser un commentaire

Récupérer une variable dans Contact Form 7

contact form 7
contact form 7

Pour plusieurs raisons, vous aurez besoin de récupérer des variables et de les insérer dans vos formulaires de contact sur Contact Form 7.

Dans l’exemple ci-dessous, je vais vous montrer comment récupérer la page d’origine du click sur le bouton contact provenant d’un autre site.

Envoyer la valeur dans votre formulaire

Pour commencer il faut envoyer un POST via votre lien sur votre bouton.
Admettons une page test.htm avec un bouton contact.
Il faut envoyer via le href du lien, les données que vous souhaitez récupérer en GET sur votre formulaire.

<html>
	<head>
	<tilte>Test</title>
	</head>
	<body>
	<p>Ma page test</p>
	<a href="https://url_de_votre_site/page_contact?from=accueil">Nous contacter</a>
	</body>
</html>

Récupérer la valeur dans votre formulaire

Au click sur le lien, l’information ?from=accueil est envoyée et conservée par votre navigateur.
Pour récupérer et afficher cette information sur votre formulaire, vous aurez besoin de créer une fonction dans votre fichier functions.php de votre thème, car vous ne pouvez pas insérer directement du code php dans votre formulaire.

/* Add source to Contact Form */
/* ---------------------------------- */
function provenance() {
	// on déclare une source par défaut
	$defautprovenance = "Blog";
	// on récupérer la valeur de from du POST ?from=accueil
    $var=$_GET['from'];
	// Si le POST est vide alors on affiche la valeur par défaut
	if (empty($_GET)) {
    	return $defautprovenance;
	}
	// Sinon on affiche la valeur récupérée
	else {return $var;}
}
// on créée le shortcode pour CF7
add_shortcode('provenance', 'provenance');

Afficher la valeur dans votre formulaire

Ci-dessus, nous avons créé un shortcode [provenance] que nous pouvons appeler à différent endroit.

Quelques exemples :

<!-- Récupérer la valeur dans un input et le mettre en caché : -->
<input type="hidden" name="provenance" value="[provenance]"></input>
<!-- Afficher la valeur dans un bloc text -->
<textarea name="your-message" cols="40" rows="10">[provenance]</textarea>

Enfin, vous pouvez récupérer cette valeur et l’envoyer dans votre email

De : [your-name] <[your-email]>
Objet : [your-subject]
Source : [provenance]
Corps du message :
[your-message]