File: /home/dh_6nhrpv/callhare.com/wp-content/plugins/nitropack/view/dashboard-oneclick.php
<?php
$settings = new \NitroPack\WordPress\Settings();
$usage = '0 MB';
$max_usage = '1 GB';
$page_views = '0';
$max_page_views = '10000'; ?>
<?php nitropack_display_admin_notices(); ?>
<div class="grid grid-cols-2 gap-6 grid-col-1-tablet items-start">
<div class="col-span-1">
<!-- Optimized Pages Card -->
<div class="card card-optimized-pages">
<div class="card-header">
<h3><?php esc_html_e('Optimized pages', 'nitropack'); ?></h3>
<div class="flex flex-row items-center" style="display: none;" id="pending-optimizations-section">
<img src="<?php echo plugin_dir_url(__FILE__) . 'images/loading.svg'; ?>" alt="loading" class="w-4 h-4">
<span class="ml-2 mr-1 text-primary"> <?php esc_html_e('Processing', 'nitropack'); ?>
<span id="pending-optimizations-count">X</span> <?php esc_html_e('page(s) in the background', 'nitropack'); ?></span>
</div>
</div>
<div class="card-body">
<div class="card-body-inner">
<div class="optimized-pages"><span data-optimized-pages-total>0</span></div>
<div class="text-box">
<div class="time-ago"><?php esc_html_e('Last cache purge', 'nitropack'); ?>: <span data-last-cache-purge><?php esc_html_e('Never', 'nitropack'); ?></span></div>
<div class="reason"><?php esc_html_e('Reason', 'nitropack'); ?>: <span data-purge-reason><?php esc_html_e('Unknown', 'nitropack'); ?></span></div>
</div>
<button id="optimizations-purge-cache" type="button" class="btn btn-secondary" data-modal-target="modal-purge-cache" data-modal-toggle="modal-purge-cache"><?php esc_html_e('Purge cache', 'nitropack'); ?></button>
</div>
</div>
<?php require_once NITROPACK_PLUGIN_DIR . 'view/modals/modal-purge-cache.php'; ?>
</div>
<!-- Optimized Pages Card End -->
<!-- Optimization Mode Card -->
<div class="card card-optimization-mode">
<div class="card-header no-border mb-0">
<div class="flex items-center">
<h3 class="mb-0"><?php esc_html_e('Optimization mode', 'nitropack'); ?></h3>
<span class="tooltip-icon" data-tooltip-target="tooltip-optimization">
<img src="<?php echo plugin_dir_url(__FILE__) . 'images/info.svg'; ?>">
</span>
<div id="tooltip-optimization" role="tooltip" class="tooltip-container hidden">
<?php esc_html_e('Select from our range of predefined optimization modes to boost your site\'s performance.', 'nitropack');
?>
<div class="tooltip-arrow" data-popper-arrow></div>
</div>
</div>
</div>
<?php $modes = array('standard' => esc_html__('Standard', 'nitropack'), 'medium' => esc_html__('Medium', 'nitropack'), 'strong' => esc_html__('Strong', 'nitropack'), 'ludicrous' => esc_html__('Ludicrous', 'nitropack'), 'custom' => esc_html__('Custom', 'nitropack')); ?>
<div class="tabs-wrapper">
<div class="tabs" id="optimization-modes">
<?php foreach ($modes as $mode_id => $mode) : ?>
<a class="btn tab-link btn-link" data-mode="<?php echo $mode_id; ?>" data-modal-target="modal-optimization-mode" data-modal-toggle="modal-optimization-mode"><?php echo $mode; ?></a>
<?php endforeach; ?>
</div>
<p><?php esc_html_e('Active Mode', 'nitropack'); ?>: <span class="active-mode"></span></p>
<div class="tab-content-wrapper">
<div class="hidden tab-content" role="tabpanel" data-tab="standard-tab">
<p class="text-secondary mt-2"> <?php esc_html_e('Standard optimization features enabled for your site. Ideal choice for maximum stability.', 'nitropack'); ?></p>
</div>
<div class="hidden tab-content" role="tabpanel" data-tab="medium-tab">
<p class="text-secondary mt-2"> <?php esc_html_e('Adds image lazy loading to standard optimizations. Uses built-in browser techniques for loading resources.', 'nitropack'); ?></p>
</div>
<div class="hidden tab-content" role="tabpanel" data-tab="strong-tab">
<p class="text-secondary mt-2"> <?php esc_html_e('Includes smart resource loading on top of Medium optimizations. Balances speed boost with stability.', 'nitropack'); ?></p>
</div>
<div class="hidden tab-content" role="tabpanel" data-tab="ludicrous-tab">
<p class="text-secondary mt-2"> <?php esc_html_e('Applies deferred JS and advanced resource loading for optimal performance and Core Web Vitals.', 'nitropack'); ?></p>
</div>
<div class="hidden tab-content" role="tabpanel" data-tab="custom-tab">
<p class="text-secondary mt-2"> <?php esc_html_e('Activated when manual setups are made. Ideal for advanced NitroPack optimizations.', 'nitropack'); ?></p>
</div>
</div>
</div>
<div class="card-footer">
<div class="flex flex-row">
<p class=""><?php esc_html_e('Which optimization mode to choose?', 'nitropack'); ?></p>
<a class="text-primary btn-link ml-auto see-modes" data-modal-target="modes-modal" data-modal-toggle="modes-modal"><?php esc_html_e('See modes comparison', 'nitropack'); ?></a>
<?php require_once NITROPACK_PLUGIN_DIR . 'view/modals/modal-modes.php'; ?>
</div>
</div>
<?php require_once NITROPACK_PLUGIN_DIR . 'view/modals/modal-optimization-mode.php'; ?>
</div>
<!-- Optimization Mode Card End -->
<!-- Automated Behavior Card -->
<div class="card card-automated-behavior">
<div class="card-header">
<h3><?php esc_html_e('Automated Behavior', 'nitropack'); ?></h3>
</div>
<div class="card-body">
<div class="options-container">
<div class="nitro-option" id="purge-cache-widget">
<div class="nitro-option-main">
<div class="text-box">
<h6><?php esc_html_e('Purge cache', 'nitropack'); ?></h6>
<p><?php esc_html_e('Purge affected cache when content is updated or published', 'nitropack'); ?></p>
</div>
<label class="inline-flex items-center cursor-pointer ml-auto">
<input type="checkbox" value="" class="sr-only peer" name="purge_cache" id="auto-purge-status" <?php if ($autoCachePurge) echo "checked"; ?>>
<div class="toggle"></div>
</label>
</div>
</div>
<div class="nitro-option" id="page-optimization-widget">
<div class="nitro-option-main">
<div class="text-box">
<h6><?php esc_html_e('Page optimization', 'nitropack'); ?></h6>
<p><?php esc_html_e('Select what post/page types get optimized', 'nitropack'); ?></p>
</div>
<a data-modal-target="modal-posttypes" data-modal-toggle="modal-posttypes" class="btn btn-secondary btn-icon">
<img src="<?php echo plugin_dir_url(__FILE__); ?>images/setting-icon.svg">
</a>
</div>
<?php require_once NITROPACK_PLUGIN_DIR . 'view/modals/modal-posttypes.php'; ?>
</div>
</div>
</div>
</div>
<!-- Automated Behavior Card End -->
<!-- Go to app Card -->
<div class="card exclusion-card">
<div class="card-header">
<h3><?php esc_html_e('Exclusions', 'nitropack'); ?></h3>
</div>
<div class="card-body">
<div class="options-container">
<div class="nitro-option" id="ajax-shortcodes-widget">
<?php $settings->render_ajax_shortcodes_setting(); ?>
</div>
</div>
</div>
</div>
<!-- Go to app card End -->
</div>
<div class="col-span-1">
<!-- Subscription Card End -->
<!-- Basic Settings Card -->
<div class="card card-basic-settings">
<div class="card-header">
<h3><?php esc_html_e('Basic Settings', 'nitropack'); ?></h3>
</div>
<div class="card-body">
<div class="options-container">
<div class="nitro-option" id="cache-warmup-widget">
<div class="nitro-option-main">
<div class="text-box" id="warmup-status-slider">
<?php $sitemap = get_option('np_warmup_sitemap', false);
$toolTipDisplayState = $sitemap ? '' : 'hidden'; ?>
<h6><?php esc_html_e('Cache warmup', 'nitropack'); ?> <span class="badge badge-primary ml-2"><?php esc_html_e('Recommended', 'nitropack'); ?></span> <span class="tooltip-icon <?php echo $toolTipDisplayState; ?>" data-tooltip-target="tooltip-sitemap">
<img src="<?php echo plugin_dir_url(__FILE__) . 'images/info.svg'; ?>">
</span></h6>
<div id="tooltip-sitemap" role="tooltip" class="tooltip-container hidden">
<?php echo $sitemap; ?>
<div class="tooltip-arrow" data-popper-arrow></div>
</div>
<p><?php esc_html_e('Automatically pre-caches your website\'s page content', 'nitropack'); ?>. <a href="https://support.nitropack.io/en/articles/8390320-cache-warmup" class="text-blue" target="_blank"><?php esc_html_e('Learn more', 'nitropack'); ?></a></p>
</div>
<label class="inline-flex items-center cursor-pointer ml-auto">
<input id="warmup-status" type="checkbox" class="sr-only peer">
<div class="toggle"></div>
</label>
</div>
<div class="msg-container" id="loading-warmup-status">
<img src="<?php echo plugin_dir_url(__FILE__) . 'images/loading.svg'; ?>" alt="loading" class="icon"> <span class="msg"><?php esc_html_e('Loading cache warmup status', 'nitropack'); ?></span>
</div>
</div>
<div class="nitro-option" id="test-mode-widget">
<div class="nitro-option-main">
<div class="text-box" id="safemode-status-slider">
<h6><?php esc_html_e('Test Mode', 'nitropack'); ?></h6>
<p><?php esc_html_e('Test NitroPack\'s features without affecting your visitors\' experience', 'nitropack'); ?>. <a href="https://support.nitropack.io/en/articles/8390292-test-mode" class="text-blue" target="_blank"><?php esc_html_e('Learn more', 'nitropack'); ?></a></p>
</div>
<label class="inline-flex items-center cursor-pointer ml-auto">
<input type="checkbox" class="sr-only peer" id="safemode-status">
<div class="toggle"></div>
</label>
</div>
<div class="msg-container" id="loading-safemode-status">
<img src="<?php echo plugin_dir_url(__FILE__) . 'images/loading.svg'; ?>" alt="loading" class="icon"> <?php esc_html_e('Loading test mode status', 'nitropack'); ?>
</div>
<?php require_once NITROPACK_PLUGIN_DIR . 'view/modals/modal-test-mode.php'; ?>
</div>
<div class="nitro-option" id="compression-widget">
<div class="nitro-option-main">
<div class="text-box">
<h6><span id="detected-compression"><?php esc_html_e('HTML Compression', 'nitropack'); ?> </span></h6>
<p><?php esc_html_e('Compressing the structure of your HTML, ensures faster page rendering and an optimized browsing experience for your users.', 'nitropack'); ?> <a href="https://support.nitropack.io/en/articles/8390333-nitropack-plugin-settings-in-wordpress#h_29b7ab4836" class="text-blue" target="_blank"><?php esc_html_e('Learn more', 'nitropack'); ?></a></p>
</div>
<label class="inline-flex items-center cursor-pointer ml-auto">
<input type="checkbox" id="compression-status" class="sr-only peer" <?php echo (int)$enableCompression === 1 ? "checked" : ""; ?>>
<div class="toggle"></div>
</label>
</div>
<div class="mt-4 text-primary">
<a href="javascript:void(0);" id="compression-test-btn" class="text-primary"><?php esc_html_e('Run compression test', 'nitropack'); ?></a>
<div class="flex items-start msg-container hidden">
<span class="msg"></span>
</div>
</div>
</div>
<?php if (\NitroPack\Integration\Plugin\BeaverBuilder::isActive()) { ?>
<div class="nitro-option" id="beaver-builder-widget">
<div class="nitro-option-main">
<div class="text-box">
<h6><span id="detected-compression"><?php esc_html_e('Sync NitroPack Purge with Beaver Builder', 'nitropack'); ?> </span></h6>
<p><?php esc_html_e('When Beaver Builder cache is purged, NitroPack will perform a full cache purge keeping your site\'s content up-to-date.', 'nitropack'); ?></p>
</div>
<label class="inline-flex items-center cursor-pointer ml-auto">
<input type="checkbox" class="sr-only peer" id="bb-purge-status" <?php if ($bbCacheSyncPurge) echo "checked"; ?>>
<div class="toggle"></div>
</label>
</div>
</div>
<?php } ?>
<div class="nitro-option" id="can-editor-clear-cache-widget">
<div class="nitro-option-main">
<div class="text-box">
<h6><?php esc_html_e('Allow Editors to purge cache', 'nitropack'); ?> <span class="badge badge-success ml-2">New</span></h6>
<p><?php esc_html_e('Give Editors the right to purge cache when content is updated.', 'nitropack'); ?></p>
</div>
<label class="inline-flex items-center cursor-pointer ml-auto">
<input type="checkbox" id="can-editor-clear-cache" class="sr-only peer" <?php echo (int)$canEditorClearCache === 1 ? "checked" : ""; ?>>
<div class="toggle"></div>
</label>
</div>
</div>
</div>
</div>
</div>
</div>
<?php $notOptimizedCPTs = nitropack_filter_non_optimized();
if (!get_option('nitropack-noticeOptimizeCPT') && !empty($notOptimizedCPTs)) require_once NITROPACK_PLUGIN_DIR . 'view/modals/modal-not-optimized-CPT.php'; ?>
</div>
<?php require_once NITROPACK_PLUGIN_DIR . 'view/modals/modal-unsaved-changes.php'; ?>
<script>
($ => {
var getOptimizationsTimeout = null;
let isClearing = false;
var paid_plan = false;
$(window).on("load", function() {
getOptimizations();
getPlan();
<?php if ($checkedCompression != 1) { ?>
autoDetectCompression();
<?php } ?>
});
/* Cache Purge begin */
window.performCachePurge = () => {
purgeCache();
}
let purgeCache = () => {
let purgeEvent = new Event("cache.purge.request");
window.dispatchEvent(purgeEvent);
}
var getOptimizations = _ => {
var url = '<?php echo $optimizationDetailsUrl; ?>';
((s, e, f) => {
if (window.fetch) {
fetch(url)
.then(resp => resp.json())
.then(s)
.catch(e)
.finally(f);
} else {
$.ajax({
url: url,
type: 'GET',
dataType: 'json',
success: s,
error: e,
complete: f
})
}
})(data => {
$('[data-last-cache-purge]').text(data.last_cache_purge.timeAgo);
if (data.last_cache_purge.reason) {
$('[data-purge-reason]').text(data.last_cache_purge.reason);
$('[data-purge-reason]').attr('title', data.last_cache_purge.reason);
$('#last-cache-purge-reason').show();
} else {
$('#last-cache-purge-reason').hide();
}
if (data.pending_count) {
$("#pending-optimizations-count").text(data.pending_count);
$("#pending-optimizations-section").show();
} else {
$("#pending-optimizations-section").hide();
}
$('[data-optimized-pages-total]').text(data.optimized_pages.total);
}, __ => {
console.error("An error occurred while fetching data for optimized pages");
}, __ => {
if (!getOptimizationsTimeout) {
getOptimizationsTimeout = setTimeout(function() {
getOptimizationsTimeout = null;
getOptimizations();
}, 60000);
}
});
}
var getPlan = _ => {
var url = '<?php echo $planDetailsUrl; ?>';
((s, e, f) => {
if (window.fetch) {
fetch(url)
.then(resp => resp.json())
.then(s)
.catch(e)
.finally(f);
} else {
$.ajax({
url: url,
type: 'GET',
dataType: 'json',
success: s,
error: e,
complete: f
})
}
})(data => {
$('.plan-name').text(data.plan_title);
$('[data-next-billing]').text(data.next_billing ? data.next_billing : 'N/A');
$('[data-next-reset]').text(data.next_reset ? data.next_reset : 'N/A');
$('[data-page-views]').text(data.page_views ? data.page_views : 'N/A');
$('[data-cdn-bandwidth]').text(data.cdn_bandwidth ? data.cdn_bandwidth + ' out of ' + data.max_cdn_bandwidth : 'N/A');
for (prop in data) {
if (prop.indexOf("show_") === 0) continue;
if (prop.indexOf("label_") === 0) continue;
if (prop.indexOf("max_") === 0) continue;
if (
typeof data["show_" + prop] != "undefined" &&
data["show_" + prop] &&
typeof data["label_" + prop] != "undefined" &&
typeof data["max_" + prop] != "undefined"
) {
let propertyLabel = data["label_" + prop];
let propertyValue = data[prop];
let propertyLimit = data["max_" + prop];
$("#plan-quotas").append('<li class="list-group-item px-0 d-flex justify-content-between align-items-center">' + propertyLabel + ' <span><span data-optimizations>' + propertyValue + '</span> out of <span data-max-optimizations>' + propertyLimit + '</span></span></li>');
}
}
}, __ => {
NitropackUI.triggerToast('error', '<?php esc_html_e('Error while fetching plan data', 'nitropack'); ?>');
}, __ => {});
}
$(document).on('click', "#compression-test-btn", e => {
e.preventDefault();
autoDetectCompression();
});
/* Compression end */
/* HTML Compression begin */
var autoDetectCompression = function() {
let msg_container = $('#compression-widget .msg-container'),
msg_icon = msg_container.find('.icon'),
msg_box = msg_container.find('.msg'),
compression_setting = $('#compression-status'),
compression_btn = $('#compression-test-btn');
//add spinner here
msg_box.html('<img src="<?php echo plugin_dir_url(__FILE__) . 'images/loading.svg'; ?>" alt="loading" class="icon"> <?php esc_html_e('Testing current compression status', 'nitropack'); ?>');
compression_btn.addClass('hidden');
msg_container.removeClass('hidden');
$.post(ajaxurl, {
action: 'nitropack_test_compression_ajax',
nonce: nitroNonce
}, function(response) {
var resp = JSON.parse(response);
if (resp.status == "success") {
if (resp.hasCompression) { // compression already enabled
compression_setting.attr("checked", false);
msg_box.text('<?php esc_html_e('Compression is already enabled on your server! There is no need to enable it in NitroPack.', 'nitropack'); ?>')
} else {
compression_setting.attr("checked", true);
msg_box.text('<?php esc_html_e('No compression was detected! We will now enable it in NitroPack.', 'nitropack'); ?>');
}
NitropackUI.triggerToast(resp.type, resp.message);
} else {
msg_box.text('<?php esc_html_e('Could not determine compression status automatically. Please configure it manually.', 'nitropack'); ?>');
}
setTimeout(function() {
msg_container.addClass('hidden');
compression_btn.removeClass('hidden');
}, 5000);
});
}
$("#compression-status").on("click", function(e) {
$.post(ajaxurl, {
action: 'nitropack_set_compression_ajax',
nonce: nitroNonce,
data: {
compressionStatus: $(this).is(":checked") ? 1 : 0
}
}, function(response) {
var resp = JSON.parse(response);
NitropackUI.triggerToast(resp.type, resp.message);
});
});
$("#can-editor-clear-cache").on("click", function(e) {
$.post(ajaxurl, {
action: 'nitropack_set_can_editor_clear_cache',
nonce: nitroNonce,
data: {
canEditorClearCache: $(this).is(":checked") ? 1 : 0
}
}, function(response) {
var resp = JSON.parse(response);
NitropackUI.triggerToast(resp.type, resp.message);
});
});
$("#auto-purge-status").on("click", function(e) {
$.post(ajaxurl, {
action: 'nitropack_set_auto_cache_purge_ajax',
nonce: nitroNonce,
autoCachePurgeStatus: $(this).is(":checked") ? 1 : 0
}, function(response) {
var resp = JSON.parse(response);
NitropackUI.triggerToast(resp.type, resp.message);
});
});
$("#bb-purge-status").on("click", function(e) {
$.post(ajaxurl, {
action: 'nitropack_set_bb_cache_purge_sync_ajax',
nonce: nitroNonce,
bbCachePurgeSyncStatus: $(this).is(":checked") ? 1 : 0
}, function(response) {
var resp = JSON.parse(response);
NitropackUI.triggerToast(resp.type, resp.message);
});
});
})(jQuery);
</script>