From 041c64ed69672627148475b37ff2212ac78d5c82 Mon Sep 17 00:00:00 2001 From: wpalani Date: Fri, 12 Jan 2024 19:29:08 -0700 Subject: [PATCH] Add admin bar site status helper method This method can be called to toggle the admin bar site status. Inside the Window API it's called from both the `enable` and `disable` methods. From plugin's app it can be called after the update the coming soon value in the data store. --- static/js/coming-soon.js | 31 +++++++++++++++++++++++-------- 1 file changed, 23 insertions(+), 8 deletions(-) diff --git a/static/js/coming-soon.js b/static/js/coming-soon.js index 077cefe..f192671 100644 --- a/static/js/coming-soon.js +++ b/static/js/coming-soon.js @@ -7,14 +7,15 @@ const buildObject = () => { return { - isEnabled: checkComingSoonStatus, - enable: enableComingSoon, - disable: disableComingSoon, - lastChanged: getLastChanged, + isEnabled, + enable, + disable, + lastChanged, + toggleAdminBarSiteStatus, }; }; - const checkComingSoonStatus = async () => { + const isEnabled = async () => { let status; await window.wp @@ -36,7 +37,7 @@ return status; }; - const enableComingSoon = async () => { + const enable = async () => { const result = {}; await window.wp @@ -48,6 +49,7 @@ if ( response.hasOwnProperty( 'comingSoon' ) ) { result.success = true; result.comingSoon = response.comingSoon; + toggleAdminBarSiteStatus( true ); } else { result.success = false; } @@ -59,7 +61,7 @@ return result; }; - const disableComingSoon = async () => { + const disable = async () => { const result = {}; await window.wp @@ -71,6 +73,7 @@ if ( response.hasOwnProperty( 'comingSoon' ) ) { result.success = true; result.comingSoon = response.comingSoon; + toggleAdminBarSiteStatus( false ); } else { result.success = false; } @@ -82,7 +85,7 @@ return result; }; - const getLastChanged = async () => { + const lastChanged = async () => { let value; await window.wp @@ -104,6 +107,18 @@ return value; }; + const toggleAdminBarSiteStatus = ( newState ) => { + const siteStatus = document.querySelector( + '#wp-toolbar #nfd-site-status' + ); + + if ( ! siteStatus ) { + return; + } + + siteStatus.setAttribute( 'data-coming-soon', newState ); + }; + window.addEventListener( 'DOMContentLoaded', () => { attachToRuntime(); } );