In my previous question I was searching for a way to create a notification message on my WordPress site, when there is a new post published. After a great answer, this is working very well. I can change the settings of how long this message should be displayed after the time of when the post was published. When the time is expired, the message will disappear.
Goal
So it is working absolute fine, special thanks for Pieter Goosen, but if the user has seen the message once, I want to give the ability to close the notification bar and to ensure that it no longer appears to the user in order to refresh the page not telksens returns the message, provided of course a new post again published.
Question
How can I make this happen? I was thinking about javascript. For the function, of course there should be one function that controls the close button, I think that there should be also a function for cookies, to check if the user has closed the message or not and checked within the time expires the timer so that both sync with each other.
My previous question for the notification you can find here:
How to count the total number of posts from the selected post types?
[UPDATE] I just sit down and try to get the structure of the notification bar clear, so I put it in a nutshell, to see if it will work, so the code of PieterGoosen checked if there is a new post available in WordPress and show the notification bar. Then the bar should be closed after the time is expired or when the user has clicked on the close button. So the code should check that too. If the user clicks on the close button == YES, then a cookie must set (cookie should synch with the time that is set in PHP), so it will delete the cookie, whenever there is a new post available. If the user doesn't click on the close button then do noting and If the time expired > delete also the cookie.
I have a solution. I have tested the code as much as possible with as much scenarios as I could think of.
I have use the same code as I have used in this answer to this question. So I'm not going to tackle that section again
WORKSFLOW PART 1
We are going to make use of jquery to hide the notification bar, and a cookie which will have two purposes, to save the latest post ID and keep the notification hidden till a new post is published or when the expiry time expires
To accomplish this, we will use the
hide()
function in jquery to hide the notification bar when a hide button is clicked by the user. You can customize this button as needed or use any other type of symbol.We now need to use some method to keep the button hidden till a new post is published. This will be done by setting a cookie when the hide button is clicked. The cookie is set to expire in 2 days, so if no new post is published within this two days, then the cookie will automatically expire. To set the cookie, we need to download the jquery-cookie plugin. This plugin will also force cookie deletion when a new post is published when a cookie is still set.
This section heavily relies on the post ID set in our
new_post_notification
. The problem is, you can't pass php variables directly to jquery. Luckily Wordpress has a function calledwp_localize_script
which we can use to pass the post ID to the jquery script where we will use it to it as the cookie value.This is the end of section 1, lets get coding
LETS CODE SECTION 1
First, download the plugin, extract it and copy the
jquery.cookie.js
file to your theme's js folder. Next, create a new file in your js folder and name ithide.notification.bar.js
. Open this newly created file and paste the following code in there and save itThis is the code used to hide the notification bar and which sets the cookie.
var post_id = parseInt( cookie_Data.post_id, 10 );
will hold the post ID which is the most important piece of info hereWe now need to register and enqueue these two js files and set the post ID to the
wp_localize_script
function. Open your functions.php and paste the following in there. If you already have awp_enqueue_scripts
hook in your theme, just strip the relevant code from here and paste it into your funtionYou can also copy and paste the function which sets the
new_post_notification
option when a new post is published. For reference on how this code works, check it out here. This code goes into functions.phpWORKSFLOW PART 2
We now have everything in place for the jquery to work, we now need to set the function which will display the notification bar, and display the hide button and delete the cookie if a new post is set if the cookie hasn't expired yet.
This code have been well commented, so you will have now trouble in following it. The most important sections here is getting the cookie's value which is stored in a global variable and can be retrieved with
$_COOKIE['hide_post_cookie']
. This is in fact a post ID, this will be checked against the post stored inget_option( 'new_post_notification' )->ID
The hide button will hide anything within
<div class="notifications_bar"></div>
, so you will add the notification bar inside that div. Customize as needed.I have added all the code inside a function which you can call in your header as follows
SECTION 2 CODE
This code also goes into your functions.php