Skip to content

Commit

Permalink
update JS for "flush site cache" button to ES6 (#311)
Browse files Browse the repository at this point in the history
  • Loading branch information
stklcode committed Oct 8, 2024
1 parent 8aea3c5 commit 5999017
Show file tree
Hide file tree
Showing 3 changed files with 77 additions and 67 deletions.
6 changes: 1 addition & 5 deletions .eslintrc.json
Original file line number Diff line number Diff line change
@@ -1,10 +1,6 @@
{
"extends": "plugin:@wordpress/eslint-plugin/es5",
"extends": "plugin:@wordpress/eslint-plugin/recommended",
"env": {
"browser": true
},
"rules": {
"camelcase": 0,
"vars-on-top": 0
}
}
12 changes: 6 additions & 6 deletions inc/class-cachify.php
Original file line number Diff line number Diff line change
Expand Up @@ -760,13 +760,13 @@ public static function add_flush_icon_script( $wp_admin_bar ) {
/* Localize script */
wp_localize_script(
'cachify-admin-bar-flush',
'cachify_admin_bar_flush_ajax_object',
'cachifyAdminBarFlushAjaxObject',
array(
'url' => esc_url_raw( rest_url( self::REST_NAMESPACE . '/' . self::REST_ROUTE_FLUSH ) ),
'nonce' => wp_create_nonce( 'wp_rest' ),
'flushing' => __( 'Flushing cache', 'cachify' ),
'flushed' => __( 'Cache flushed successfully', 'cachify' ),
'dashicon_success' => self::get_dashicon_success_class(),
'url' => esc_url_raw( rest_url( self::REST_NAMESPACE . '/' . self::REST_ROUTE_FLUSH ) ),
'nonce' => wp_create_nonce( 'wp_rest' ),
'flushing' => __( 'Flushing cache', 'cachify' ),
'flushed' => __( 'Cache flushed successfully', 'cachify' ),
'dashiconSuccess' => self::get_dashicon_success_class(),
)
);
}
Expand Down
126 changes: 70 additions & 56 deletions js/admin-bar-flush.js
Original file line number Diff line number Diff line change
@@ -1,25 +1,36 @@
/* global cachify_admin_bar_flush_ajax_object */
( function() {
var is_flushing = false,
admin_bar_cachify_list_item = document.getElementById( 'wp-admin-bar-cachify' ),
flush_link = admin_bar_cachify_list_item.querySelector( 'a.ab-item' ),
fallback_url = flush_link.getAttribute( 'href' ),
aria_live_area = document.querySelector( '.ab-aria-live-area' );
/* global cachifyAdminBarFlushAjaxObject */
{
let isFlushing = false;
const adminBarItem = document.getElementById('wp-admin-bar-cachify');
const flushLink = adminBarItem.querySelector('a.ab-item');
const fallbackUrl = flushLink.getAttribute('href');
const ariaLiveArea = document.querySelector('.ab-aria-live-area');

// Replacing flush link with button because with AJAX action, it is semantically not a link anymore.
var button = document.createRange().createContextualFragment( '<button class="ab-item">' + flush_link.innerHTML + '</button>' );
flush_link.parentNode.replaceChild( button, flush_link );
const button = document
.createRange()
.createContextualFragment(
'<button class="ab-item">' + flushLink.innerHTML + '</button>'
);
flushLink.parentNode.replaceChild(button, flushLink);

var admin_bar_icon = admin_bar_cachify_list_item.querySelector( '#wp-admin-bar-cachify .ab-icon' );
const adminBarIcon = adminBarItem.querySelector(
'#wp-admin-bar-cachify .ab-icon'
);

document.querySelector( '#wp-admin-bar-cachify .ab-item' ).addEventListener( 'click', flush );
document
.querySelector('#wp-admin-bar-cachify .ab-item')
.addEventListener('click', flush);

admin_bar_icon.addEventListener( 'animationend', function() {
admin_bar_icon.classList.remove( 'animate-fade' );
} );
adminBarIcon.addEventListener('animationend', function () {
adminBarIcon.classList.remove('animate-fade');
});

function flush_icon_remove_classes() {
var classes = [
/**
* Remove classes used for animation from flush icon.
*/
function flushIconRemoveClasses() {
const classes = [
'animate-fade',
'animate-pulse',
'dashicons-trash',
Expand All @@ -28,56 +39,59 @@
'dashicons-dismiss',
];

for ( var i = 0; i < classes.length; i++ ) {
admin_bar_icon.classList.remove( classes[i] );
for (const element of classes) {
adminBarIcon.classList.remove(element);
}
}

function start_flush_icon_reset_timeout() {
setTimeout( function() {
flush_icon_remove_classes();
admin_bar_icon.classList.add( 'animate-fade' );
admin_bar_icon.classList.add( 'dashicons-trash' );
is_flushing = false;
aria_live_area.textContent = '';
}, 2000 );
/**
* Add animation classes to flush icon.
*/
function startFlushIconResetTimeout() {
setTimeout(() => {
flushIconRemoveClasses();
adminBarIcon.classList.add('animate-fade', 'dashicons-trash');
isFlushing = false;
ariaLiveArea.textContent = '';
}, 2000);
}

function flush( event ) {
/**
* Event listener to flush the cache.
*
* @param {MouseEvent} event Click event
*/
function flush(event) {
event.preventDefault();

if ( is_flushing ) {
if (isFlushing) {
return;
}
is_flushing = true;
aria_live_area.textContent = cachify_admin_bar_flush_ajax_object.flushing;
isFlushing = true;
ariaLiveArea.textContent = cachifyAdminBarFlushAjaxObject.flushing;

if ( admin_bar_icon !== null ) {
flush_icon_remove_classes();
admin_bar_icon.classList.add( 'animate-pulse' );
admin_bar_icon.classList.add( 'dashicons-trash' );
if (adminBarIcon !== null) {
flushIconRemoveClasses();
adminBarIcon.classList.add('animate-pulse');
adminBarIcon.classList.add('dashicons-trash');
}

var request = new XMLHttpRequest();
request.addEventListener( 'load', function() {
if ( this.status === 200 ) {
start_flush_icon_reset_timeout();
flush_icon_remove_classes();
admin_bar_icon.classList.add( 'animate-fade' );
admin_bar_icon.classList.add( cachify_admin_bar_flush_ajax_object.dashicon_success );
aria_live_area.textContent = cachify_admin_bar_flush_ajax_object.flushed;
return;
}

window.location = fallback_url;
} );

request.addEventListener( 'error', function() {
window.location = fallback_url;
} );

request.open( 'DELETE', cachify_admin_bar_flush_ajax_object.url );
request.setRequestHeader( 'X-WP-Nonce', cachify_admin_bar_flush_ajax_object.nonce );
request.send();
fetch(cachifyAdminBarFlushAjaxObject.url, {
method: 'DELETE',
headers: { 'X-WP-Nonce': cachifyAdminBarFlushAjaxObject.nonce },
})
.then(() => {
startFlushIconResetTimeout();
flushIconRemoveClasses();
adminBarIcon.classList.add('animate-fade');
adminBarIcon.classList.add(
cachifyAdminBarFlushAjaxObject.dashiconSuccess
);
ariaLiveArea.textContent =
cachifyAdminBarFlushAjaxObject.flushed;
})
.catch(() => {
window.location = fallbackUrl;
});
}
}() );
}

0 comments on commit 5999017

Please sign in to comment.