Stampare la categoria prodotto di woocommerce come classe nel body quando visiti un prodotto singolo

Con questa funzione puoi stampare tra le classi del body la categoria del prodotto singolo di woocommerce. Per funzionare basta copiare e incollare la funziona nel file functions.php

function sg_wooc_custom_taxonomy_in_body_class( $classes ){
  if( is_singular( 'product' ) ) {
    $custom_terms = get_the_terms(0, 'product_cat');
    if ($custom_terms) {
      foreach ($custom_terms as $custom_term) {
        $classes[] = 'term-' . $custom_term->slug;
      }
    }
  }
  return $classes;
}

add_filter( 'body_class', 'sg_wooc_custom_taxonomy_in_body_class' );

Stampare la categoria come classe nel body quando visiti un post singolo

Una funzione semplice che aiuta a stampare tra le classi del body la categoria del post singolo. Per funzionare basta copiare e incollare nel file functions.php

function sg_add_category_to_single($classes) {
    if (is_single() ) {
      global $post;
      foreach((get_the_category($post->ID)) as $category) {
            // add category slug to the $classes array
            $classes[] = $category->category_nicename;
      }
    }
    // return the $classes array
    return $classes;
}

add_filter('body_class','sg_add_category_to_single');

Deregistrare i custom post type di un Tema di WordPress

Spesso quando si lavora con dei temi pre-confezionati per sviluppare un nuovo sito web basato su wordpress, ci troviamo tanti custom post type inutili per il nostro progetto. Per deregistrarli potete usare questo piccolo codice che va inserito nel file functions.php del tema figlio.


function studio42_unregister_cpt() {
    global $wp_post_types;
    foreach( array( 'nome-singolo-post-type-1', 'nome-singolo-post-type-2', 'nome-singolo-post-type-3' ) as $post_type ) {
        if ( isset( $wp_post_types[ $post_type ] ) ) {
            unset( $wp_post_types[ $post_type ] );
        }
    }
}
add_action( 'init', 'studio42_unregister_cpt', 20 );

Woocommerce aggiungere campo Codice Fiscale con validazione formale

Un metodo per inserire nella pagina di checkout il campo obbligatorio del Codice Fiscale con un controllo puramente formale via regexp del codice fiscale inserito.

function wooc_field_cf($fields) {

$fields['billing']['billing_cf'] = array(
'label' => __('Codice Fiscale', 'woocommerce'),
'placeholder' => _x('Codice Fiscale', 'placeholder', 'woocommerce'),
'required' => true,
'class' => array('form-row-last'),
'clear' => false,
'default' => (get_current_user_id() > 0) ? get_user_meta(get_current_user_id(), 'billing_cf', true) : ''
);

return $fields;

}

add_filter('woocommerce_checkout_fields', 'wooc_field_cf');

function wooc_checkout_field_process() {
// Check if set, if its not set add an error.

if ( $_POST['billing_cf'] && preg_match('/^[A-Z]{6}\d{2}[A-Z]\d{2}[A-Z]\d{3}[A-Z]$/i', $_POST['billing_cf'])) {
//vai avanti
}elseif(!$_POST['billing_cf'] && $_POST['billing_cf'] == '' ){
wc_add_notice( __( 'Codice Fiscale è un campo obbligatorio.'), 'error' );
}elseif(!preg_match('/^[A-Z]{6}\d{2}[A-Z]\d{2}[A-Z]\d{3}[A-Z]$/i', $_POST['billing_cf'])){
wc_add_notice( __( 'Codice Fiscale non valido.'), 'error' );
}

}

add_action('woocommerce_checkout_process', 'wooc_checkout_field_process');

	

Usare la Wildcard in Robots.TxT

La Wildcard è molto utile per dire ai motori di ricerca (non solo google) di indicizzare o meno un gruppo di pagine. Vedi esempi.

  1. Non indicizzare gli URL che contengono il punto interrogativo “?”User-agent: *
    Disallow: /*?
  2. Non indicizzare le pagine di ricerca contenenti i paramenti nell’urlUser-agent: *
    Disallow: /search?s=*
  3. Il dollaro “$” viene usato per definire la fine dell’url. Per dire ai motori di ricerca di non indicizzare gli url che finiscono con .php bisogna scrivere:User-agent: *
    Disallow: /*.php$

Usare WP-CLI con XAMPP (Unix Like)

Per far funzionare WP-CLI con una installazione XAMPP su Unix-like bisogna dire al sistema di non usare php e mysql di sistema ma usare quelli XAMPP. Per fare questo modifichiamo il file .bash_profile che sta nella home di ogni User e inserieamo queste poche righe.

# Use XAMPP version of PHP
export PATH="/Applications/XAMPP/xamppfiles/bin":$PATH;

# Export XAMPP MySQL executables as functions
# Makes them usable from within shell scripts (unlike an alias)
mysql() {
    /Applications/XAMPP/xamppfiles/bin/mysql "$@"
}

mysqladmin() {
    /Applications/XAMPP/xamppfiles/bin/mysqladmin "$@"
}

export -f mysql
export -f mysqladmin

Per applicare le modifiche usare il comando source ~/.bash_profile

Questo trick funziona anche con MAMP ovviamente dovete cambiare i percorsi e usare quelli di MAMP.

Guide e Link utili:

Installare è Amministrare WordPress da Riga di Comando con WP-CLI
http://wptheming.com/2015/02/wp-cli/

Iniziare ad usare WP-CLI
https://trepmal.com/2014/02/22/getting-started-with-wp-cli/

Sito ufficiale WP-CLI
https://wp-cli.org/