Post

WordPress Code Snippets

Once you have a Wordpress site setup and you have access to the functions.php this is where the fun starts. You can start dropping snippets of code into the functions file, give your website a refresh and you should see your new functions taking place. However, be carful as php errors are unforgiving. So you really want to be testing out this code locally first.

Below is some snippets ive collected

Hide acf fields on production

Why do this?

  • Fields wont get overwritten when deploying from local or staging
  • Stop clients from deleting acf fields in production

How to hide

  • add to functions.php
  • update protected urls
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
add_filter(
	'acf/settings/show_admin',
	function () {

		// Get the current site url.
		$site_url = get_bloginfo( 'url' );

		// Define an array of protected site urls.
		$protected_urls = array(
			'https://staging.cloud',
			'https://live.com.au',
		);

		// If the current site URL is in the array of protected URLs, return FALSE
		// to hide the menu.
		return ! in_array( $site_url, $protected_urls );
	}
);

more info

acf local json

Custom Excerpt Length

Change the length of the post excerpt length

1
2
3
4
  function custom_excerpt_length( $length ) {
	      return 20;
	}
	add_filter( 'excerpt_length', 'custom_excerpt_length', 999 );

Custom Excerpt More

Change the excerpt display link based on what post type is being viewed

1
2
3
4
5
6
7
8
function new_excerpt_more( $more ) {
    if ('testimonials' == get_post_type()) {
          return ' <br /><a class = "more" href="'. get_permalink(isset($post->ID)) . '"> View</a>';
    } else {
          return ' <br /><a class = "more" href="'. get_permalink(isset($post->ID)) . '"> Read More</a>';
    }
}
add_filter('excerpt_more', 'new_excerpt_more');

custom excerpt link text

Put WordPress into maintenance mode

One of the best features of Wordpress is how customisable it is. There are so many plugins that allow you to customise your Wordpress site.

However, Its much nicer to be able to do stuff in Wordpress without using a plugin.

One such task is putting it into maintenance mode. Granted, it’s not something you have to do often. But when you do you can use a snippet rather then a plugin.

Activate WordPress Maintenance Mode

Here we are using an action to put WordPress into maintenance mode. First the script checks to see if the user is not logged in. Add to functions.php

1
2
3
4
5
6
7
// Activate WordPress Maintenance Mode
function wp_maintenance_mode() {
   if (!current_user_can('edit_themes') || !is_user_logged_in()) {
     wp_die('<h1>Under Maintenance</h1><br />Website under planned maintenance. Please check back later.');
   }
}
   add_action('get_header', 'wp_maintenance_mode');

Wordpress query post loops

Queries that will return some posts according to the configuration of your query

Page basic template with loop

1
2
3
4
5
6
7
8
9
10
11
12
<?php if ( have_posts() ) : while ( have_posts() ) : the_post(); ?>

	<h2><?php the_title() ;?></h2>
	<?php the_post_thumbnail(); ?>
	<?php the_excerpt(); ?>

<?php endwhile; else: ?>

	<p>Sorry, no posts to list</p>

<?php endif; ?>

Advanced Loop

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
<?php if ( have_posts() ) : while ( have_posts() ) : the_post(); ?>

<article id="post-<?php the_ID(); ?>" <?php if(is_category('featured')): ?>class="featured-post"<?php endif; ?>>
	<h1><?php the_title() ;?></h1>		

	<p>
		Published on <?php the_time('M j, Y'); ?> 
		by <?php the_category(', '); ?>
		in <?php the_category(', '); ?>
	</p>

	<?php the_content(); ?>

	<?php comment_form(); ?>

	<div class="prev-next-links">
		<ul>
			<li><?php next_post_link(); ?></li>
			<li><?php previous_post_link(); ?></li>
		</ul>

	</div>

</article>

<?php endwhile; else: ?>

	<p>Sorry, this post does not exist</p>

<?php endif; ?>

loop using query posts

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<?php query_posts('showposts=1&post_type=post'); ?>

<?php if ( have_posts() ) : while ( have_posts() ) : the_post(); ?>

	<h1><?php the_title() ;?></h1>		
	<?php the_post_thumbnail(); ?>
	<?php the_excerpt(); ?>

<?php endwhile; else: ?>

	<p>Sorry, there are no posts to display</p>

<?php endif; ?>

<hr>

<?php rewind_posts(); ?>

<?php query_posts('showposts=3&offset=1&post_type=post'); ?>

<?php if ( have_posts() ) : while ( have_posts() ) : the_post(); ?>

	<h2><?php the_title() ;?></h2>		

	<?php the_excerpt(); ?>

<?php endwhile; else: ?>

	<p>Sorry, there are no posts to display</p>

<?php endif; ?>

loop using wp query

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22

<?php 

	$args = array( 
		'pagename' => 'about-us'
	);
	$the_query = new WP_Query( $args );

?>

<?php if ( $the_query->have_posts() ) : while ( $the_query->have_posts() ) : $the_query->the_post(); ?>

	<h1><?php the_title() ;?></h1>			
	<?php the_excerpt(); ?>

<?php endwhile; else: ?>

	<p>Sorry, there are no posts to display</p>

<?php endif; ?>

more complex example

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<?php 

	$args = array( 
		'author_name' => 'zgordon',
		'orderby' => 'title',
		'post_type' => 'workshops'
		'year' => 2012
	);
	$the_query = new WP_Query( $args );

?>

<?php if ( $the_query->have_posts() ) : while ( $the_query->have_posts() ) : $the_query->the_post(); ?>

	<h1><?php the_title() ;?></h1>			
	<?php the_excerpt(); ?>

<?php endwhile; else: ?>

	<p>Sorry, there are no posts to display</p>

<?php endif; ?>

Used for critical css

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
function my_deregister_styles() {
wp_deregister_style('parent');
wp_deregister_style( 'divi-style' );
wp_deregister_style( 'tt-widget-css' );
}
add_action('wp_enqueue_scripts', 'my_deregister_styles', 100);

//load style on footer
function pxs_add_footer_styles() {
$parent_style = 'parent-style';
wp_enqueue_style( $parent_style, get_template_directory_uri() . '/style.css' );
wp_enqueue_style( 'child-style', get_stylesheet_directory_uri() . '/style.css', array('parent-style') );

    wp_enqueue_style( 'tt-widget-css', get_stylesheet_directory_uri() . '/wp-content/plugins/ticket-tailor/tt-widget.css' );

};
add_action( 'get_footer', 'pxs_add_footer_styles' );

Create child theme

Example using twentytwentyfour as parent theme

function.php

1
2
3
4
5
6
7
8
9
<?php
function twentytwentyfour_child_enqueue_styles() {
    // Enqueue parent theme stylesheet
    wp_enqueue_style( 'parent-style', get_template_directory_uri() . '/style.css' );

    // Enqueue child theme stylesheet
    wp_enqueue_style( 'child-style', get_stylesheet_directory_uri() . '/style.css', array( 'parent-style' ) );
}
add_action( 'wp_enqueue_scripts', 'twentytwentyfour_child_enqueue_styles' );

style.css with minimal configuration.

1
2
3
4
5
/*
Theme Name:   Twenty Twenty-Four Child
Template:     twentytwentyfour
*/

Theme Name: Name of your child theme. Template: Exact folder name of the parent theme. Other fields are optional but useful for identification.

style.css with full configuration.

1
2
3
4
5
6
7
8
9
/*
Theme Name:   Parent Theme Name Child
Theme URI:    https://example.com
Description:  Child theme for the Parent Theme Name theme
Author:       Your Name
Author URI:   https://yourwebsite.com
Template:     parent-theme-folder-name
Version:      1.0.0
*/

Move Yoast to bottom

1
2
3
4
5
function yoasttobottom() {
return 'low';
}

add_filter( 'wpseo_metabox_prio', 'yoasttobottom');

redirect user on failed login

1
2
3
4
5
6
7
8
9
10
11
add_action( 'wp_login_failed', 'my_callback' );
function my_callback() {
if (! is_user_logged_in()) {
wp_redirect( 'https://example.com.au', 301 );
exit();
} else {
wp_redirect( 'https://example.com.au/login/', 301 );
exit();
}
}

style header info

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
/*
Theme Name: Twenty Seventeen
Theme URI: https://wordpress.org/themes/twentyseventeen/
Author: the WordPress team
Author URI: https://wordpress.org/
Description: Twenty Seventeen brings your site to life with immersive featured images and subtle animations. With a focus on business sites, it features multiple sections on the front page as well as widgets, navigation and social menus, a logo, and more. Personalize its asymmetrical grid with a custom color scheme and showcase your multimedia content with post formats. Our default theme for 2017 works great in many languages, for any abilities, and on any device.
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: twentyseventeen
Tags: one-column, two-columns, right-sidebar, flexible-header, accessibility-ready, custom-colors, custom-header, custom-menu, custom-logo, editor-style, featured-images, footer-widgets, post-formats, rtl-language-support, sticky-post, theme-options, threaded-comments, translation-ready
This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned with others.
*/

wp_schedule_event

schedule event

secure area

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<?php 
/* include via page template
   Pipe all knowledge base users through the one page template to easily test if user is logged in or not. 
 */
?>
<section class = "secure_area">
   <div class = "container">
      <div class = "secure_area__wrapper">
	 <?php if (is_user_logged_in()) { ?>
	 <h2>Search</h2>
	 <?php  if (have_posts()) : while (have_posts()) : the_post(); ?>
	 <?php  the_content(); ?>
	 <?php  endwhile; else: ?>
<?php  get_template_part('notfound');
endif; ?>
<?php } else { ?>
<?php echo '<div class = "notification"><h2 class = "text">You will need to <a href = "/wp/wp-login.php?action=register">Register</a> or <a href = "/login">Login</a> to view the secure area</h2></div>'; ?>
<?php } ?>
      </div>
   </div>
</section>

date counter

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
<?php 

function DateCounter($atts){
	
	$startDate = $atts["startdate"];
	$endDate   = strtolower($atts["enddate"]);
	
	switch (strtolower($atts["format"])) {
		case "year":
		case "years":
			$startDate = new DateTime($startDate);
			$endDate = new DateTime($endDate);

			$difference = $endDate->diff($startDate);

			$result = $difference->y;
		break;
		case "month":
		case "months":
			$startDate = strtotime($startDate);
			$endDate = strtotime($endDate);

			$min_date = min($startDate, $endDate);
			$max_date = max($startDate, $endDate);

			$i = 0;
			while (($min_date = strtotime("+1 MONTH", $min_date)) <= $max_date) {
			    $i++;
			}

			$result = $i;
		break;
		case "day":
		case "days":
			$startDate = strtotime($startDate);
			$endDate = strtotime($endDate);

			$difference = $endDate - $startDate;

			$result = floor($difference / (60*60*24));
		break;
		case "currentyear":
			$result = date("Y");
		break;
		case "currentmonth":
			$result = date("m");
		break;
		case "currentday":
			$result = date("d");
		break;
	}

	return $result;
}

add_shortcode( 'DateCounter', 'DateCounter' );

?>
1
2
3
4
5
<?php if ( has_post_thumbnail()) { 
      $image_src = wp_get_attachment_image_src( get_post_thumbnail_id(), $pxs_img_size );
      echo '<img src="' . $image_src[0]  . '" width="100%"  />'; ?>
<?php }

Enable Gutenberg for Custom Post Type

If you want to use Gutenberg for editing your custom post types. And why wouldn’t you it’s amazing and easily the best option for WordPress content editing. Then you need to edit and add this piece of code into your functions.php to enable a Gutenberg. In this example we are initiating a custom post type called events. You’ll want to edit events to suit your custom post type.

Prerequisites

  • An active WordPress install, either local or on a remote server
  • The ability to edit the functions.php

The below cpt snippet utilises the 'show_in_rest' => true and 'supports' => array( 'title', 'editor', 'author', 'thumbnail', 'excerpt', 'comments' ), which is are the key parts to enabling Gutenberg in custom post types.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
function pxs_events_init() {
    $labels = array(
        'name'                  => _x( 'events', 'Post type general name', 'textdomain' ),
        'singular_name'         => _x( 'events', 'Post type singular name', 'textdomain' ),
        'menu_name'             => _x( 'events', 'Admin Menu text', 'textdomain' ),
        'name_admin_bar'        => _x( 'events', 'Add New on Toolbar', 'textdomain' ),
        'add_new'               => __( 'Add New', 'textdomain' ),
        'add_new_item'          => __( 'Add New events', 'textdomain' ),
        'new_item'              => __( 'New events', 'textdomain' ),
        'edit_item'             => __( 'Edit events', 'textdomain' ),
        'view_item'             => __( 'View events', 'textdomain' ),
        'all_items'             => __( 'All events', 'textdomain' ),
        'search_items'          => __( 'Search events', 'textdomain' ),
        'parent_item_colon'     => __( 'Parent events:', 'textdomain' ),
        'not_found'             => __( 'No s found.', 'textdomain' ),
        'not_found_in_trash'    => __( 'No s found in Trash.', 'textdomain' ),
        'featured_image'        => _x( 'events Cover Image', 'Overrides the “Featured Image” phrase for this post type. Added in 4.3', 'textdomain' ),
        'set_featured_image'    => _x( 'Set cover image', 'Overrides the “Set featured image” phrase for this post type. Added in 4.3', 'textdomain' ),
        'remove_featured_image' => _x( 'Remove cover image', 'Overrides the “Remove featured image” phrase for this post type. Added in 4.3', 'textdomain' ),
        'use_featured_image'    => _x( 'Use as cover image', 'Overrides the “Use as featured image” phrase for this post type. Added in 4.3', 'textdomain' ),
        'archives'              => _x( 'events archives', 'The post type archive label used in nav menus. Default “Post Archives”. Added in 4.4', 'textdomain' ),
        'insert_into_item'      => _x( 'Insert into ', 'Overrides the “Insert into post”/”Insert into page” phrase (used when inserting media into a post). Added in 4.4', 'textdomain' ),
        'uploaded_to_this_item' => _x( 'Uploaded to this ', 'Overrides the “Uploaded to this post”/”Uploaded to this page” phrase (used when viewing media attached to a post). Added in 4.4', 'textdomain' ),
        'filter_items_list'     => _x( 'Filter s list', 'Screen reader text for the filter links heading on the post type listing screen. Default “Filter posts list”/”Filter pages list”. Added in 4.4', 'textdomain' ),
        'items_list_navigation' => _x( 'events list navigation', 'Screen reader text for the pagination heading on the post type listing screen. Default “Posts list navigation”/”Pages list navigation”. Added in 4.4', 'textdomain' ),
        'items_list'            => _x( 'events list', 'Screen reader text for the items list heading on the post type listing screen. Default “Posts list”/”Pages list”. Added in 4.4', 'textdomain' ),
    );

    $args = array(
        'labels'             => $labels,
        'public'             => true,
        'publicly_queryable' => true,
        'show_ui'            => true,
        'menu_icon' => 'dashicons-tide',
        'show_in_menu'       => true,
        'query_var'          => true,
        'rewrite'            => array( 'slug' => '' ),
        'capability_type'    => 'post',
        'has_archive'        => true,
        'hierarchical'       => false,
        'menu_position'      => null,
        'show_in_rest' => true,
        'supports'           => array( 'title', 'editor', 'author', 'thumbnail', 'excerpt', 'comments' ),
    );

    register_post_type( 'events', $args );
}

add_action( 'init', 'pxs_events_init' );
This post is licensed under CC BY 4.0 by the author.