Supprimer la page panier dans WooCommerce

Si dans votre boutique sous Woocommerce vous vendez un seul produit (ebook, logiciel …), la page panier ne présente pas un grand intérêt, avec le code ci-dessous vous allez rediriger le client directement sur la page commande.

Le code est à ajouter dans le fichier function.php de votre thème WordPress.

add_filter ('add_to_cart_redirect', 'redirect_to_checkout');

function redirect_to_checkout() {
global $woocommerce;
$checkout_url = $woocommerce->cart->get_checkout_url();
return $checkout_url;
}

Shortcodes Woocommerce

WooCommerce > 2.1.x Shortcodes:

 

Afficher le panier Haut de page

Pour afficher le panier dans une page template ajouter le shortcode suivant :

Votre panier est actuellement vide.

Retour à la boutique

Afficher la page commande Haut de page

Pour afficher la page commande dans une page template ajouter le shortcode suivant :

Afficher le suivi de la commande Haut de page

Pour afficher la page commande dans une page template ajouter le shortcode suivant :

Pour suivre votre commande veuillez saisir votre ID de commande dans la boite ci-dessous et cliquer le bouton « Suivre ». Il vous a été donné sur votre reçu et dans l’e-mail de confirmation que vous avez du recevoir.

Afficher le compte du client Haut de page

Pour afficher le compte du client dans une page template ajouter le shortcode suivant :

Connexion

Le client pourra consulter toutes les commandes passé vous pouvez limité le nombre de commande passé a afficher avec order_count par défaut le paramètre est 15 (-1 affiche toutes les commandes) et ils peuvent aussi modifier leurs informations.

Args :

array 
     ('current_user' => '', 
     'order_count' => 
 '15')

L’argument de l’utilisateur est basé sur les fonctions get_user_by ( ) et get_current_user_id ( ).

Afficher les produits récents Haut de page

Pour afficher une liste de produit récent dans une page template ajouter le shortcode suivant :

per_page détermine le nombre de produits à afficher sur la page et columns le nombre de colonnes. Vous pouvez utilisez des arguments supplémentaires :

Args :

array(
     'per_page' => '12',
      'columns' => '4',
      'orderby' => 'date',
      'order' => 'desc'
 )

orderby vous sert a déterminé quel type affichage :

  1. ID (Classement par identifiant)
  2. author (Classement par auteur.)
  3. title (Tri par titre)
  4. name (Trier par nom – slug)
  5. date (Classer par date)
  6. modified (Classement par date de dernière modification.)
  7. rand (Classement aléatoire)
  8. comment_count (Classement par nombre d’avis/commentaire)

order va classer par ordre croissant ou décroissant orderby.

  • ASC – De la plus petite à la plus hautes valeurs ascendant (1, 2, 3; a, b, c).
  • DESC – De la plus élevée des valeurs les plus bas décroissant (3, 2, 1, c, b, a).

Afficher vos produits phares (Featured products) Haut de page

Pour afficher vos produits phares dans une page template ajouter le shortcode suivant :

De la même façon que produits récents vous pouvez définir l’affichage, les produits phares sont basé sur les notes(rating stars).

Afficher un produit Haut de page

Pour afficher un produit dans une page ou un article par identifiant ou référence(UGS) ajouter le shortcode suivant :

Vous pouvez récupérer l’identifiant dans la liste de vos produits.

2015-08-22_21h14_52

Afficher plusieurs produits Haut de page

Pour afficher plusieurs produits dans une page ou un article par identifiant ou référence(UGS) ajouter le shortcode suivant :

Args :

array(
      'columns' => '4',
      'orderby' => 'date',
      'order' => 'desc'
 )

orderby vous sert a déterminé quel type affichage :

  1. ID (Classement par identifiant)
  2. author (Classement par auteur.)
  3. title (Tri par titre)
  4. name (Trier par nom – slug)
  5. date (Classer par date)
  6. modified (Classement par date de dernière modification.)
  7. rand (Classement aléatoire)
  8. comment_count (Classement par nombre d’avis/commentaire)

order va classer par ordre croissant ou décroissant orderby.

  • ASC – De la plus petite à la plus hautes valeurs ascendant (1, 2, 3; a, b, c).
  • DESC – De la plus élevée des valeurs les plus bas décroissant (3, 2, 1, c, b, a).

Afficher le bouton ajouter au panier Haut de page

Pour afficher le bouton ajouter au panier dans une page ou un article par identifiant ou référence(UGS) ajouter le shortcode suivant :


Vous pouvez personnaliser l’apparence du bouton ajouter au panier en utilisant l’argument style.

Args :

array(
      'id' => '49',
      'style' => 'border:4px solid #ccc; padding: 12px;',
      'sku' => 'REF'
 )

Afficher l’url du bouton ajouter au panier Haut de page

Pour afficher l’url du bouton ajouter au panier dans une page ou un article par identifiant ou référence(UGS) ajouter le shortcode suivant :


 

Args :

array(
      'id' => '49',
      'sku' => 'REF'
 )

Afficher une page produit Haut de page

Pour afficher l’url du bouton ajouter au panier dans une page ou un article par identifiant ou référence(UGS) ajouter le shortcode suivant :

Afficher une carégorie de produits Haut de page

Pour afficher une catégorie de produits dans une page ou un article par slug (Un slug est tout simplement un identifiant nom utilisable dans les adresses url il ne comporte pas d’accent ni de majuscule.) ajouter le shortcode suivant :

2015-08-23_20h20_17

Args :

array(
 'per_page' => '12',
 'columns' => '4',
 'orderby' => 'title',
 'order' => 'asc',
 'category' => 'montres'
 )

per_page : nombre de produit a afficher.

columns : nombre de colone.

orderby vous sert a déterminé quel type affichage :

  1. ID (Classement par identifiant)
  2. author (Classement par auteur.)
  3. title (Tri par titre)
  4. name (Trier par nom – slug)
  5. date (Classer par date)
  6. modified (Classement par date de dernière modification.)
  7. rand (Classement aléatoire)
  8. comment_count (Classement par nombre d’avis/commentaire)

order va classer par ordre croissant ou décroissant orderby.

  • ASC – De la plus petite à la plus hautes valeurs ascendant (1, 2, 3; a, b, c).
  • DESC – De la plus élevée des valeurs les plus bas décroissant (3, 2, 1, c, b, a).

category : slug de la catégorie.

Afficher un index des catégories de vos produits Haut de page

Le shortcode suivant va vous permettre d’afficher un index des catégories de vos produits.

L’argument number est utilisé pour afficher le nombre de produits et l’argument ids est l’identifiant qui permet d’afficher une ou plusieurs catégories.

L’argument parent permet d’afficher ou pas les sous catégories produit exemple :

Vêtement (catégorie niveau 0)

  • Femmes (sous catégorie niveau 1)

 

Args :

array(
      'number' => 'null',
      'orderby' => 'name',
      'order' => 'ASC',
      'columns' => '4',
      'hide_empty' => '1',
      'parent' => '',
      'ids' => ''
 )

orderby vous sert a déterminé quel type affichage :

  1. ID (Classement par identifiant)
  2. author (Classement par auteur.)
  3. title (Tri par titre)
  4. name (Trier par nom – slug)
  5. date (Classer par date)
  6. modified (Classement par date de dernière modification.)
  7. rand (Classement aléatoire)
  8. comment_count (Classement par nombre d’avis/commentaire)

order va classer par ordre croissant ou décroissant orderby.

  • ASC – De la plus petite à la plus hautes valeurs ascendant (1, 2, 3; a, b, c).
  • DESC – De la plus élevée des valeurs les plus bas décroissant (3, 2, 1, c, b, a).

Afficher les produits en vente Haut de page

Se shortcode vous permet d’afficher les produits en vente sur votre site :

 

Args :

array(
     'per_page' => '12',
     'columns' => '4',
     'orderby' => 'title',
     'order' => 'asc'
 )

per_page : nombre de produit a afficher.

columns : nombre de colone.

orderby vous sert a déterminé quel type affichage :

  1. ID (Classement par identifiant)
  2. author (Classement par auteur.)
  3. title (Tri par titre)
  4. name (Trier par nom – slug)
  5. date (Classer par date)
  6. modified (Classement par date de dernière modification.)
  7. rand (Classement aléatoire)
  8. comment_count (Classement par nombre d’avis/commentaire)

order va classer par ordre croissant ou décroissant orderby.

  • ASC – De la plus petite à la plus hautes valeurs ascendant (1, 2, 3; a, b, c).
  • DESC – De la plus élevée des valeurs les plus bas décroissant (3, 2, 1, c, b, a).

Afficher les meilleures ventes de produits Haut de page

Pour afficher vos produits dans une page template ajouter le shortcode suivant :

 

Args :

array(
     'per_page' => '12',
     'columns' => '4'
 )

per_page : nombre de produit a afficher.

columns : nombre de colone.

Afficher les produits les mieux notés Haut de page

Pour afficher les produits les mieux notés dans une page template ajouter le shortcode suivant :

 

Args :

array(
     'per_page' => '12',
     'columns' => '4',
     'orderby' => 'title',
     'order' => 'asc'
 )

per_page : nombre de produit a afficher.

columns : nombre de colone.

orderby vous sert a déterminé quel type affichage :

  1. ID (Classement par identifiant)
  2. author (Classement par auteur.)
  3. title (Tri par titre)
  4. name (Trier par nom – slug)
  5. date (Classer par date)
  6. modified (Classement par date de dernière modification.)
  7. rand (Classement aléatoire)
  8. comment_count (Classement par nombre d’avis/commentaire)

order va classer par ordre croissant ou décroissant orderby.

  • ASC – De la plus petite à la plus hautes valeurs ascendant (1, 2, 3; a, b, c).
  • DESC – De la plus élevée des valeurs les plus bas décroissant (3, 2, 1, c, b, a).

Afficher les produits par attributs Haut de page

Pour afficher les produits les mieux notés dans une page template ajouter le shortcode suivant :

 

Args :

array(
     'per_page' => '12',
     'columns' => '4',
     'orderby' => 'title',
     'order' => 'asc',
     'attribute' => '',
     'filter' => ''
 )

per_page : nombre de produit a afficher.

columns : nombre de colone.

orderby vous sert a déterminé quel type affichage :

  1. ID (Classement par identifiant)
  2. author (Classement par auteur.)
  3. title (Tri par titre)
  4. name (Trier par nom – slug)
  5. date (Classer par date)
  6. modified (Classement par date de dernière modification.)
  7. rand (Classement aléatoire)
  8. comment_count (Classement par nombre d’avis/commentaire)

order va classer par ordre croissant ou décroissant orderby.

  • ASC – De la plus petite à la plus hautes valeurs ascendant (1, 2, 3; a, b, c).
  • DESC – De la plus élevée des valeurs les plus bas décroissant (3, 2, 1, c, b, a).

Afficher des produits liés Haut de page

Pour afficher des produits une page template ajouter le shortcode suivant :


 

Args :

array(
     'per_page' => '12',
     'columns' => '4',
     'orderby' => 'title'
 )

per_page : nombre de produit a afficher.

columns : nombre de colone.

orderby vous sert a déterminé quel type affichage :

  1. ID (Classement par identifiant)
  2. author (Classement par auteur.)
  3. title (Tri par titre)
  4. name (Trier par nom – slug)
  5. date (Classer par date)
  6. modified (Classement par date de dernière modification.)
  7. rand (Classement aléatoire)
  8. comment_count (Classement par nombre d’avis/commentaire)

 

WordPress Enqueue script dans une page spécifique de l’administration

Chaque page dans l’administration de WordPress possède un identifiant comme par exemple :

wp-admin/admin.php?page=id

Pour charger un script spécifiquement pour une page ajouter le code suivant dans votre plugin remplacer id par l’identifiant de votre page puis le non du fichier js à charger.

function enqueue()
{
        //Id de la page
    if($_GET["page"] == "id")
    {
        wp_enqueue_script("custom-js", plugin_dir_url(__FILE__) . "script.js");
    }
}

add_action("admin_enqueue_scripts", "enqueue");

Woocommerce personnalisé les messages ajouter au panier

Le code ci-dessous va permettre de personnalisé les messages que les produits ont bien été ajouter au panier sur la page produit et panier.
Si vous avez activé : Rediriger vers le panier après un ajout réussi dans Woocommerce > Paramètre > produit le message suivant apparaitra :

– Votre article a bien été ajouté au panier. Continuer mes achats

Si vous n’avez pas cochez Rediriger vers le panier après un ajout réussi le message suivant apparaitra sur la page produit :

– Votre article a bien été ajouté au panier. Voir mon panier

Ajouter le code suivant dans le fichier function.php de votre thème WordPress :

function new_add_to_cart_message() {
global $woocommerce;
	
	if (get_option('woocommerce_cart_redirect_after_add')=='yes') :
		$return_to 	= get_permalink(woocommerce_get_page_id('shop'));

	// Message pour le panier
    $message = sprintf( '%s<a href="%s" class="your-style">%s</a> ', __( 'Votre article a bien été ajouté au panier.', 'woocommerce' ), esc_url( get_permalink( woocommerce_get_page_id( 'shop' ) ) ), __( 'Continuer mes achats', 'woocommerce' ) );
else :
	// Message pour la page produit
    $message = sprintf( '%s<a href="%s" class="your-class">%s</a> ', __( 'Votre article a bien été ajouté au panier.' , 'woocommerce' ), esc_url( get_permalink( woocommerce_get_page_id( 'cart' ) ) ), __( 'Voir mon panier', 'woocommerce' ) );
endif;
return $message;
}
add_filter( 'wc_add_to_cart_message', 'new_add_to_cart_message' );

Afficher le contenu du panier sans Widget – Woocommerce

Pour afficher le contenu du panier sans widget dans votre site marchant sous Woocommerce, placer le code suivant a l’endroit désiré :

<a href="<?php echo WC()->cart->get_cart_url(); ?>" title="<?php _e( 'Voir votre panier' ); ?>"><?php echo sprintf (_n( '%d Article', '%d Articles', WC()->cart->cart_contents_count ), WC()->cart->cart_contents_count ); ?> - <?php echo WC()->cart->get_cart_total(); ?></a>

Puis pour utiliser Ajax ajouter le code suivant dans le fichier function.php de votre thème WordPress :

add_filter( 'woocommerce_add_to_cart_fragments', 'woocommerce_header_add_to_cart_fragment' );
function woocommerce_header_add_to_cart_fragment( $fragments ) {
	ob_start();
	?>
	<a class="cart-contents" href="<?php echo WC()->cart->get_cart_url(); ?>" title="<?php _e( 'Voir votre panier' ); ?>"><?php echo sprintf (_n( '%d Article', '%d Articles', WC()->cart->cart_contents_count ), WC()->cart->cart_contents_count ); ?> - <?php echo WC()->cart->get_cart_total(); ?></a> 
	<?php
	
	$fragments['a.cart-contents'] = ob_get_clean();
	
	return $fragments;
}

Ajouter automatiquement un produit au panier

Si vous souhaitez ajouter automatiquement un produit au panier lors de la visite d’un internaute dans votre boutique Woocommerce.
Ajouter le code suivant dans le fichier function.php de votre thème WordPress :

// Ajouter un produit automatiquement
add_action( 'init', 'add_product_to_cart' );
function add_product_to_cart() {
if ( ! is_admin() ) {
global $woocommerce;
$product_id = 22;
$found = false;
//On vérifie si il y a déja un produit dans le panier
if ( sizeof( $woocommerce->cart->get_cart() ) > 0 ) {
foreach ( $woocommerce->cart->get_cart() as $cart_item_key => $values ) {
$_product = $values['data'];
if ( $_product->id == $product_id )
$found = true;
}

if ( ! $found )
$woocommerce->cart->add_to_cart( $product_id );
} else {

$woocommerce->cart->add_to_cart( $product_id );
}
}
}

A la ligne 6 $product_id = 22  remplacer 22 par l’identifiant du produit à ajouter automatiquement.

2015-08-15_18h24_58

Ajouter un nouveau pays dans liste des pays dans Woocmmerce

Voici une petite fonction qui va vous permettre d’ajouter un nouveau pays à la liste des pays WooCommerce.

Ajouter le code suivant dans le fichier function.php de votre thème WordPress :

function woo_add_my_country( $country ) {
   $country["AE-DU"] = 'Dubai';
   return $country;
}
add_filter( 'woocommerce_countries', 'woo_add_my_country', 10, 1 );

Woocommerce modifié le texte du bouton ajouter au panier

Les quatre codes ci-dessous vont vous permettre de modifier le texte ‘ Ajouter au panier ’ dans Woocommerce. Ouvrez votre fichier function.php de votre Thème WordPress, puis ajoutez les codes suivants.

Woocommerce > 2.1

Le premier permet de changer le texte du bouton sur la page du produit unique (single-product.php) pour tous les produits.

// Change le texte 'Ajouter au panier' sur la page de produit unique
add_filter( 'woocommerce_product_single_add_to_cart_text', 'bryce_add_to_cart_text' );
function bryce_add_to_cart_text() {
        return __( 'Acheter maintenant', 'woocommerce' );
}

 

Le deuxième va changer le texte du bouton pour la page archive de vos produits.

// Change le texte 'Ajouter au panier' sur la page archive des produits
add_filter( 'woocommerce_product_add_to_cart_text', 'bryce_archive_add_to_cart_text' );
function bryce_archive_add_to_cart_text() {
        return __( 'Acheter', 'your-slug' );
}

Le troisième va changer le texte du bouton pour un produit avec l’identifiant 386.

// Change le texte 'Ajouter au panier' sur la page de produit unique (seulement pour le produit avec ID 386)
add_filter( 'woocommerce_product_single_add_to_cart_text', 'bryce_id_add_to_cart_text' );
function bryce_id_add_to_cart_text( $default ) {
    if ( get_the_ID() == 386 ) {
        return __( 'Acheter ce smartphone très design !', 'woocommerce' );
    } else {
        return $default;
    }
}

Puis le dernier code va changer le texte du bouton pour une catégorie de produits exemple la catégorie avec l’ID 17.

// Change le texte 'Ajouter au panier' sur la page de produit unique (seulement pour la catégorie avec ID 17)
add_filter( 'woocommerce_product_single_add_to_cart_text', 'bryce_cat_add_to_cart_text' );
function bryce_cat_add_to_cart_text( $default ) {
	global $post;
	$terms = get_the_terms( $post->ID, 'product_cat' );
	if ( array_key_exists( 17, $terms ) ) { // ID de la catégorie 17
        	 return __( 'Acheter cette montre', 'woocommerce' );
	} else {
		return $default;
	}
}

Woocommerce < 2.1 - 3+ 

add_filter( 'woocommerce_product_add_to_cart_text', 'woo_custom_product_add_to_cart_text' );  // 2.1 +
  
function woo_custom_product_add_to_cart_text() {
  
    return __( 'Souscrire en ligne', 'woocommerce' );
  
}