????
Current Path : /home/innovagencyco/www/abtest.innovagency.co.za/wp-content/plugins/speedycache/assets/js/ |
Current File : /home/innovagencyco/www/abtest.innovagency.co.za/wp-content/plugins/speedycache/assets/js/admin.js |
(function($){ window.addEventListener('DOMContentLoaded', function(){ speedycache_handle_tab(); window.addEventListener('hashchange', speedycache_handle_tab); if(speedycache_ajax.premium){ speedycache_image_optimization(); } jQuery('.speedycache-save-settings-wrapper button').on('click', speedycache_save_settings); jQuery('#speedycache-analyze').on('click', speedycache_analyze_speed); // Delay JS jQuery('#speedycache_delay_js').change(function() { if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this)); }); jQuery('#speedycache_purge_varnish').change(function() { if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this)); }); jQuery('#speedycache_critical_images').change(function() { if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this)); }); jQuery('#speedycache_lazy_load_html').change(function() { if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this)); }); jQuery('#speedycache_preload').change(function() { if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this)); }); jQuery('#speedycache_dns_prefetch').change(function() { if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this)); }); jQuery('#speedycache_preload_resources').change(function() { if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this)); }); jQuery('#speedycache_render_blocking').change(function() { if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this)); }); // Critical CSS Status jQuery('#speedycache_critical_css').change(function(e) { let prevent_open = true; if(e.isTrigger){ prevent_open = false; } if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this), prevent_open); }); jQuery('#speedycache_pre_connect').change(function() { if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this)); }); jQuery('#speedycache_unused_css').change(function() { if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this)); }); jQuery('.speedycache-action-link').on('click', function(){ let action_name = jQuery(this).attr('action-name'); switch(action_name){ case 'speedycache_critical_css': speedycache_critical_css(); break; } }); // Lazy Load jQuery('#speedycache_lazy_load').change(function() { if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this)); }); jQuery('#speedycache_update_heartbeat').change(function() { if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this)); }); jQuery('#speedycache_limit_post_revision').change(function() { if(!jQuery(this).is(':checked')){ speedycache_toggle_settings_link(jQuery(this)); return; } speedycache_toggle_settings_link(jQuery(this)); speedycache_open_modal(jQuery(this)); }); //Event Listener for Settings link for popup options jQuery('.speedycache-modal-settings-link').off('click').click(function() { var id = jQuery(this).attr('setting-id'), input = jQuery('#'+id); input.trigger('change'); }); // Add Excludes Btn jQuery('#speedycache_add_excludes').click(function() { speedycache_open_modal(jQuery(this)); }); jQuery('#speedycache-cdn-type').change(function(e){ let cdn_type = jQuery(e.target).val(), cdn_key = jQuery('#speedycache-cdn-key').closest('.speedycache-stacked-option-wrap'), cdn_url = jQuery('#speedycache-cdn-url').closest('.speedycache-stacked-option-wrap'); if(cdn_type == 'cloudflare'){ cdn_url.hide(); cdn_key.show(); return; }else if(cdn_type == 'bunny'){ cdn_url.show(); cdn_key.show(); return; } // For other we only need to show the URL field cdn_url.show(); cdn_key.hide(); return; }); // Toggle exact time field of cache lifespan jQuery('#speedycache-run-exact-time').click(function(e){ if(jQuery(this).is(':checked')){ jQuery('#speedycache-exact-time-selector').css('display', 'flex'); return; } jQuery('#speedycache-exact-time-selector').hide(); }); jQuery('#speedycache-ll-type').change(function(e){ let type = jQuery(e.target).val(), custom_input = jQuery('#speedycache-custom-ll-url'); if(type == 'default'){ custom_input.hide(); return; } custom_input.show(); }); jQuery('#speedycache-cdn-type').trigger('change'); jQuery('#speedycache-exclude-type').on('change', speedycache_update_excluded_options); jQuery('#speedycache-exclude-rule-prefix').on('change', speedycache_update_excluded_prefix); jQuery('.speedycache-exclude-btn-wrap button').on('click', speedycache_update_excludes); jQuery('#speedycache-type-filter').on('change', speedycache_filter_exclude_type); jQuery(document).on('click', '.speedycache-delete-rule', speedycache_delete_exclude_rule); jQuery('.speedycache-db-optm-btn').on('click', speedycache_db_optm); jQuery('.speedycache-preloading-add').on('click', speedycache_add_preload_resource); jQuery('.speedycache-preloading-table').on('click', '.dashicons-trash', speedycache_delete_preload_resource); jQuery('.speedycache-flush-db').on('click', speedycache_flush_objects); jQuery('#speedycache-license-btn').on('click', speedycache_verify_license); }); })(jQuery); function speedycache_handle_tab(){ let hash = location.hash.trim().replace('#', ''), nav = jQuery('#speedycache-navigation'); if(!hash.length){ let tab = jQuery('#speedycache-dashboard'); tab.siblings().hide(); tab.css('display', 'flex'); nav.find('.speedycache-nav-selected').removeClass('speedycache-nav-selected'); nav.find('a[href=\\#'+hash+']').addClass('speedycache-nav-selected') return } let tab = jQuery('#speedycache-'+hash); tab.siblings().hide(); tab.css('display', 'flex'); nav.find('.speedycache-nav-selected').removeClass('speedycache-nav-selected'); nav.find('a[href=\\#'+hash+']').addClass('speedycache-nav-selected') } function speedycache_save_settings(){ event.preventDefault(); let jEle = jQuery(event.target); jEle.find('span').addClass('speedycache-spinner-active'); form_data = jEle.closest('form').serializeArray(); jQuery.ajax({ url : speedycache_ajax.url, method : "POST", data : form_data, success: function(res){ if(res.success){ return; } if(res.data){ alert(res.data); } alert("Something went wrong"); } }).always(function(){ jEle.find('span').removeClass('speedycache-spinner-active'); }); } function speedycache_filter_exclude_type(){ let jEle = jQuery(event.target), list = jQuery('.speedycache-exclude-list'), filter = jEle.val(); list.find('tbody tr').filter(function(){ jQuery(this).toggle(jQuery(this).find('td').eq(0).text().toLowerCase().indexOf(filter) > - 1); }); } function speedycache_delete_exclude_rule(){ event.preventDefault(); let jEle = jQuery(event.target), tr = jEle.closest('tr'), rule_id = tr.data('id') jEle.find('span').addClass('speedycache-spinner-active'); jQuery.ajax({ url : speedycache_ajax.url, method : "POST", data : { '_ajax_nonce' : speedycache_ajax.nonce, 'action' : 'speedycache_delete_exclude_rule', 'rule_id' : rule_id }, success: function(res){ if(res.success){ tr.slideUp(); return; } if(res.data){ alert(res.data); return; } alert('Something went wrong deleting the rule'); } }).always(function(){ jEle.find('span').removeClass('speedycache-spinner-active'); }); } function speedycache_toggle_settings_link(jEle) { var wrap = jEle.closest('.speedycache-option-wrap'), setting = wrap.find('.speedycache-modal-settings-link, .speedycache-action-link'); if(jEle.is(':checked')) { setting.show(); return; } setting.hide(); } function speedycache_open_modal(jEle, prevent_open) { var id_attr = 'id'; if(prevent_open){ return; } if(jEle.attr('modal-id')) { id_attr = 'modal-id' } //For Settings Link if(jEle.attr('setting-id')) { id_attr = 'setting-id'; } var modal_id = jEle.attr(id_attr), speedycache_modal = jQuery("div[modal-id='"+modal_id+"']"); if(speedycache_modal && speedycache_modal.css('visibility') === 'hidden') { speedycache_modal.css('visibility','visible'); speedycache_close_modal(); } } function speedycache_update_excluded_options(){ let jEle = jQuery(event.target), prefix = jQuery('#speedycache-exclude-rule-prefix'), exclude_type = jEle.val(); prefix.val(""); // Resets to select value option prefix.find('option').filter(function(){ jQuery(this).toggle(jQuery(this).data('partof').toLowerCase().indexOf(exclude_type) > - 1); }); } // Toggles content input of excludes settings function speedycache_update_excluded_prefix(){ let jEle = jQuery(event.target), val = jEle.val(), content = jQuery('#speedycache-exclude-rule-content').closest('.speedycache-input-wrap'); if(val == 'contain' || val == 'exact' || val == 'startwith'){ content.show(); return; } content.hide(); } function speedycache_update_excludes(){ event.preventDefault(); let jEle = jQuery(event.target), form = jEle.closest('form'); jEle.find('span').addClass('speedycache-spinner-active'); form_data = form.serializeArray(); jQuery.ajax({ url : speedycache_ajax.url, method : "POST", data : form_data, success: function(res){ if(res.success){ form.trigger('reset'); jQuery('#speedycache-exclude-list').load(window.location.href + ' #speedycache-exclude-list'); return; } if(res.data){ alert(res.data); return; } alert('Something went wrong saving the details'); } }).always(function(){ jEle.find('span').removeClass('speedycache-spinner-active'); }); } //Close SpeedyCache Modal function speedycache_close_modal() { jQuery('.speedycache-modal-footer > button, .speedycache-close-modal').on('click', function() { jQuery(this).closest('.speedycache-modal').find('form').trigger('reset'); jQuery(this).closest('.speedycache-modal *').off(); jQuery(this).closest('.speedycache-modal').css('visibility','hidden'); }); } function speedycache_analyze_speed(){ jEle = jQuery(event.target); jEle.text('[Analysing...]'); jQuery.ajax({ url : speedycache_ajax.url, method : 'GET', data : { security : speedycache_ajax.nonce, action : 'speedycache_test_pagespeed', }, success : function(res){ if(!res.data || !res.data['score']){ return } let donut = jQuery('.speedycache-perf-score-donut'), tspan = donut.find('tspan'), lowerCircle = donut.find('circle:first-child'), strokeCircle = lowerCircle.next(); lowerCircle.attr('fill', res.data['color'][1]); strokeCircle.css('stroke', res.data['color'][0]); strokeCircle.attr('stroke-dasharray', res.data['score']+' '+(100 - res.data['score'])); tspan.text(res.data['score']); // Updated the score tspan.css('fill', res.data['color'][2]); } }).always(function(){ jEle.text('[Updating results]'); setTimeout(() => {jEle.text('[Analyse]')}, 1000) }); } function speedycache_db_optm(){ event.preventDefault(); let proceed = confirm('Are you sure you want to proceed with this DB optimization action'); if(!proceed){ return; } let jEle = jQuery(event.target), db_action = jEle.closest('.speedycache-db-row').attr('speedycache-db-name'), spinner = jEle.find('.speedycache-spinner'); spinner.addClass('speedycache-spinner-active'); jQuery.ajax({ url : speedycache_ajax.url, method : 'POST', data : { security : speedycache_ajax.nonce, action : 'speedycache_optm_db', db_action : db_action, }, success: function(res){ if(res.success){ // TODO: make this update the UI too chaning the numbers. return false; } if(res.message){ alert(res.message); return; } alert("Something went wrong unable to optimize this option"); } }).always(function(){ spinner.removeClass('speedycache-spinner-active'); }); } function speedycache_add_preload_resource() { event.preventDefault(); let ele = jQuery(event.target), loader = ele.find('.speedycache-spinner'), form = ele.closest('form'), error = false; if(!form){ alert('Unable to get the form details!'); return; } let form_type = form.data('type'); // Disabling Add Button ele.prop('disabled', true); let form_val = {}; form_data = form.serializeArray(); form_data.forEach((field) => { form_val[field.name] = field.value; if(!field.value){ error = true; } }); if(error){ alert('Fill all the fields before adding'); ele.prop('disabled', false); return; } loader.addClass('speedycache-spinner-active'); jQuery.ajax({ 'method' : 'POST', 'url' : speedycache_ajax.url, 'data' : { action : 'speedycache_preloading_add_settings', settings : form_val, type : form_type, security : speedycache_ajax.nonce }, 'success' : function(res){ ele.prop('disabled', false); if(!res){ alert('Something went wrong, the response returned is empty'); return; } if(!res.success){ alert(res.data); return; } let table = ele.closest('.speedycache-modal-content').find('table'); html = `<td>${form_val.resource}</td> ${form_type != 'pre_connect_list' ? '<td>'+form_val.type+'</td>' : ''} <td>${form_val.crossorigin ? 'Yes' : 'No'}</td> <td data-key="${res.data}"><span class="dashicons dashicons-trash"></span></td>`; if(table.find('.speedycache-preloading-empty').length > 0){ let tr = table.find('.speedycache-preloading-empty').closest('tr'); table.find('.speedycache-preloading-empty').remove(); tr.append(html); } else { let tbody = table.find('tbody'); tbody.append('<tr>'+html+'</tr>'); } // Resetting the form form.find('input, select').map(function(){ let type = jQuery(this).prop('type'); if(type == 'checkbox'){ jQuery(this).prop('checked', false); return; } else jQuery(this).val(''); }); alert('Settings Saved Successfully'); } }).always(function(){ loader.removeClass('speedycache-spinner-active'); }); } function speedycache_delete_preload_resource(){ let ele = jQuery(event.target), key = ele.closest('td').data('key'), type = ele.closest('table').data('type'); jQuery.ajax({ 'method' : 'POST', 'url' : speedycache_ajax.url, 'data' : { action : 'speedycache_preloading_delete_resource', type : type, key : key, security : speedycache_ajax.nonce }, success : function(res){ if(!res || !res.success){ alert(res.data ? res.data : 'Unable to delete this resource'); return; } ele.closest('tr').remove(); } }); } function speedycache_flush_objects() { event.preventDefault(); let jEle = jQuery(event.target), spinner = jEle.find('.speedycache-spinner'); spinner.addClass('speedycache-spinner-active'); jQuery.ajax({ 'method' : 'GET', 'url' : speedycache_ajax.url + '?action=speedycache_flush_objects&security='+speedycache_ajax.nonce, 'success' : function(res){ if(res.success){ return; } if(res.data){ alert(res.data); return; } alert("Unable to flush Object Cache"); } }).always(function(){ spinner.removeClass('speedycache-spinner-active'); }); } function speedycache_image_optimization() { var stats, total_page = { value: 0, set: function (value) { this.value = value; this.update_num(); disabling_paging_btn(jQuery('#speedycache-image-list')); }, update_num : function(){ jQuery('.speedycache-total-pages').text(this.value); } }, current_page = { value: 0, set: function (value) { this.value = value; this.update_num(); disabling_paging_btn(jQuery('#speedycache-image-list')); }, update_num : function(){ jQuery('.speedycache-current-page').text(this.value+1); } }; //Gets Stats var get_stats = function(onload = false) { jQuery.ajax({ type : 'GET', url : speedycache_ajax.url + '?action=speedycache_statics_ajax_request', cache : false, data : { 'security' : speedycache_ajax.nonce }, success : function(res){ stats = res; //For pagination var $total_page = jQuery('.speedycache-total-pages'), optimized = res.optimized $total_page.text(Math.ceil(optimized/5)); total_page.set($total_page.text()); if(total_page == '1') { jQuery('.speedycache-image-list-next-page').addClass('disabled'); jQuery('.speedycache-image-list-last-page').addClass('disabled'); } if(!onload) { optm_count = `${optimized}/${stats.total_image_number}`; jQuery('.speedycache-img-optm-count').text(optm_count); reduction = res.reduction > 10000 ? (res.reduction/1000).toFixed(2) + 'MB' : res.reduction.toFixed(2) + 'KB'; var stat_block = jQuery('.speedycache-img-stats'); stat_block.find('.speedycache-img-reduced-size').text(reduction); stat_block.find('.speedycache-donut-percent').text(res.percent + '%'); stat_block.find('.speedycache-img-success-per').text(res.percent + '%'); stat_block.find('.speedycache-img-error-count').text(res.error); var sub = 100 - parseInt(res.percent); stat_block.find('.speedycache-donut-segment-2').attr('stroke-dasharray', res.percent+' '+sub); var donut_style = stat_block.closest('.speedycache-tab-image').find('style').eq(0); //this regex wont work in PHP as it dosent supports look behind without fixed size var dash_array = donut_style.text(); //(?<=100%\s*{(?:\s*|\n)stroke-dasharray\s*:\s*)([\d]+\s*[\d]+[^;]) this reg ex can be used too its more precise and gets just numbers but need to update it to handle floats dash_array = dash_array.replace(/100%.*(?:[\d]|[\d]+\.[\d]+)[^;]/, `100%{stroke-dasharray:${res.percent}, ${sub}`); var segment = stat_block.find('.speedycache-donut-segment-2'); segment.removeClass('speedycache-donut-segment-2'); segment.addClass('speedycache-donut-segment-2'); donut_style.text(dash_array); } if(res.uncompressed > 0) { jQuery('.speedycache_img_optm_status').css('backgroundColor', '#EED202'); jQuery('.speedycache_img_optm_status').next().text(`${res.uncompressed} File(s) needed to be optimized`); }else { jQuery('.speedycache_img_optm_status').css('backgroundColor', '#90ee90'); jQuery('.speedycache_img_optm_status').next().text(`All images are optimized`); } } }); } //Updates Image Optimization Stats on load get_stats(true); jQuery('.speedycache-img-opt-settings input').on('change', function() { var settings = jQuery('.speedycache-img-opt-settings').serializeArray(); settings = speedycache_convert_serialized(settings); jQuery.ajax({ type: 'POST', url : speedycache_ajax.url + '?action=speedycache_update_image_settings', data : { 'security' : speedycache_ajax.nonce, 'settings' : settings }, success: function(res) { //Succeed or Fail silently } }); }); var file_counter = 1, optm_stopped = false, optm_ajax; jQuery('.speedycache-img-optm-btn').on('click', function() { if(optm_ajax && optm_stopped) { optm_ajax.abort(); optm_stopped = false; file_counter = 1; return; } var inner_content = ` <div class="speedycache-img-optm-counter">${file_counter - 1}/${stats.uncompressed}</div> <div class="speedycache-progress"> <div class="speedycache-progress-value"></div> </div> <div class="speedycache-optm-close"> <button class="speedycache-image-optm-stop speedycache-btn speedycache-btn-danger">Stop</button> <button class="speedycache-btn speedycache-btn-success speedycache-img-optm-close">Close</button></div> </div>`; //If all images are optimized if(stats.uncompressed == 0) { inner_content = ` <div class="speedycache-already-optm"> <i class="fas fa-check-circle"></i> <span>All images are Optimized</span> </div> <div class="speedycache-optm-close"> <button class="speedycache-btn speedycache-btn-success speedycache-img-optm-close" style="display:block;">Close</button></div> </div> `; } var inc_per = parseInt(100/stats.uncompressed), modal_html = `<div modal-id="speedycache-modal-optimize-all" class="speedycache-modal"> <div class="speedycache-modal-wrap" style="padding:10px;"> <div style="text-align:center;"><h2>Optimizing Images</h2></div> <div class="speedycache-optm-prog-list"> </div> ${inner_content} </div> </div>`; var optm_modal = jQuery('[modal-id="speedycache-modal-optimize-all"]'); if(optm_modal.length == 0) { jQuery('body').append(modal_html); speedycache_open_modal(jQuery(this)); optm_modal = jQuery('[modal-id="speedycache-modal-optimize-all"]'); } optm_modal.find('.speedycache-optm-close button').off('click').on('click', function() { optm_modal.remove(); speedycache_update_list(); get_stats(); if(stats.uncompressed != 0) { optm_stopped = true; } file_counter++; }); optm_ajax = jQuery.ajax({ type : 'POST', url : speedycache_ajax.url + '?action=speedycache_optimize_image_ajax_request', data : { 'id' : null, 'security' : speedycache_ajax.nonce }, success: function(res) { var progress = jQuery('[modal-id="speedycache-modal-optimize-all"] .speedycache-progress-value'), new_per = file_counter * inc_per; progress.css('width', `${new_per}%`); file_counter++ var modal = progress.closest('.speedycache-modal-wrap'); if(!res.id && res.message != 'finish') { var error_html = `<div class="speedycache-img-optm-error"> <p>Something Went Wrong<br/> ${res.message} </p> </div>`; progress.parent().before(error_html); progress.css({'width': '100%', 'backgroundColor' : 'var(--speedycache-red)'}); setTimeout( () => { optm_modal.find('.speedycache-img-optm-close').show(); optm_modal.find('.speedycache-image-optm-stop').hide(); },700); return; } if(res.message != 'finish' && file_counter <= stats.uncompressed + 1) { modal.find('.speedycache-img-optm-counter').text((file_counter) - 1 +'/'+stats.uncompressed); jQuery('.speedycache-img-optm-btn').trigger('click'); return; } progress.css('width', '100%'); //To show when Optimization completes var success_html = ` <div class="speedycache-already-optm" style="display:none;"> <i class="fas fa-check-circle"></i> <span>Images optimized Successfully</span> </div> `; progress.parent().before(success_html); modal.find('.speedycache-img-optm-counter').hide('slow'); modal.find('.speedycache-already-optm').show('slow'); setTimeout( () => { optm_modal.find('.speedycache-img-optm-close').show(); optm_modal.find('.speedycache-image-optm-stop').hide(); },700); } }); }); //revert Image var revert_image = function() { var jEle = jQuery(this), post_id = jEle.find('input').val(); if(!post_id) { return; } //speedycache_add_loader(); jQuery.ajax({ type : 'GET', url : speedycache_ajax.url + '?action=speedycache_revert_image_ajax_request&id='+post_id, data : { 'security' : speedycache_ajax.nonce, }, beforeSend : function(){ jEle.closest('tr').css('backgroundColor', 'rgba(255,0,0,0.2)'); }, success : function(res) { speedycache_update_list(jEle); get_stats(); //speedycache_hide_loader(); }, error: function(err) { //speedycache_hide_loader(); jEle.closest('tr').css('backgroundColor', 'rgb(255,255,255)'); } }); } //Revert the image conversion listener jQuery('.speedycache-revert').on('click', revert_image); jQuery('.speedycache-img-delete-all-conv').on('click', function(e) { e.preventDefault(); var confirm_modal = jQuery('[modal-id="speedycache-modal-all-img-revert"]'); if(confirm_modal.length == 0) { return; } speedycache_open_modal(confirm_modal); confirm_modal.find('.speedycache-db-confirm-yes').off().on('click', function() { //speedycache_add_loader(); confirm_modal.css('visibility','hidden'); jQuery.ajax({ type : 'GET', url : speedycache_ajax.url + '?action=speedycache_img_revert_all', data : { 'security' : speedycache_ajax.nonce }, success : function(res) { if(res.success) { //speedycache_hide_loader(); speedycache_update_list(); get_stats(); return; } //speedycache_hide_loader(); alert(res.message); } }); }); confirm_modal.find('.speedycache-db-confirm-no').off().on('click', function() { confirm_modal.css('visibility','hidden'); }); }); var speedycache_update_list = function(jEle = null) { var img_list = jQuery('#speedycache-image-list'), search = img_list.find('#speedycache-image-search-input'), per_page = img_list.find('#speedycache-image-per-page'), per_page_val = per_page.val() ? per_page.val() : 5, filter = img_list.find('#speedycache-image-list-filter'), page = 0; if(jEle) { if(jEle.hasClass('disabled')) { return; } if(jEle.data('page-action')) { switch(jEle.data('page-action')) { case 'last-page': current_page.set(total_page.value - 1); break; case 'next-page': current_page.set(current_page.value + 1); break; case 'first-page': current_page.set(0); break; case 'prev-page': current_page.set(current_page.value > 0 ? current_page.value - 1 : 0); break; } } } var optimized = stats.total_image_number - stats.uncompressed; if(optimized <= per_page_val) { current_page.set(0); } jQuery.ajax({ type : 'GET', url : speedycache_ajax.url + '?action=speedycache_update_image_list_ajax_request', data : { 'search' : search.val(), 'per_page' : per_page_val, 'filter' : filter.val(), 'page' : current_page.value, 'security' : speedycache_ajax.nonce }, success: function(res) { if(!res.content) { return; } total_page.set(Math.ceil(res.result_count/per_page_val)); if(total_page.value - 1 == current_page.value) { img_list.find('.speedycache-image-list-next-page').addClass('disabled'); img_list.find('.speedycache-image-list-last-page').addClass('disabled'); } jQuery('#speedycache-image-list tbody').empty(); jQuery('#speedycache-image-list tbody').append(res.content); jQuery('.speedycache-revert').on('click', revert_image); jQuery('.speedycache-open-image-details').on('click', open_img_details); } }); } var disabling_paging_btn = function(img_list) { if(current_page.value == 0 && total_page.value - 1 == 0) { img_list.find('.speedycache-image-list-first-page').addClass('disabled'); img_list.find('.speedycache-image-list-prev-page').addClass('disabled'); img_list.find('.speedycache-image-list-last-page').addClass('disabled'); img_list.find('.speedycache-image-list-next-page').addClass('disabled'); }else if(current_page.value == 0) { img_list.find('.speedycache-image-list-first-page').addClass('disabled'); img_list.find('.speedycache-image-list-prev-page').addClass('disabled'); img_list.find('.speedycache-image-list-last-page').removeClass('disabled'); img_list.find('.speedycache-image-list-next-page').removeClass('disabled'); } else if(current_page.value == total_page.value - 1) { img_list.find('.speedycache-image-list-first-page').removeClass('disabled'); img_list.find('.speedycache-image-list-prev-page').removeClass('disabled'); img_list.find('.speedycache-image-list-last-page').addClass('disabled'); img_list.find('.speedycache-image-list-next-page').addClass('disabled'); } else { img_list.find('.speedycache-image-list-first-page').removeClass('disabled'); img_list.find('.speedycache-image-list-prev-page').removeClass('disabled'); img_list.find('.speedycache-image-list-last-page').removeClass('disabled'); img_list.find('.speedycache-image-list-next-page').removeClass('disabled'); } } //Toggles the image variants var open_img_details = function() { var post_id = jQuery(this).closest('tr').attr('post-id'); if(!post_id) { return; } var details = jQuery('tr[post-id="'+post_id+'"][post-type="detail"]'); if(details.is(':hidden')) { details.show(); jQuery(this).find("span").attr('class', 'dashicons dashicons-arrow-up-alt2') } else { details.hide(); jQuery(this).find("span").attr('class', 'dashicons dashicons-arrow-down-alt2'); } } //Downloading cwebp jQuery('button.speedycache-webp-download').on('click', function(e) { e.preventDefault(); type = jQuery(this).data('type') ? jQuery(this).data('type') : 'cwebp'; jQuery.ajax({ url : speedycache_ajax.url + '?action=speedycache_download_cwebp', type : 'GET', data : { security : speedycache_ajax.nonce, type : type }, beforeSend : function() { //speedycache_add_loader(); }, success : function(res) { //speedycache_hide_loader(); if(res.success) { location.reload(); return; } if(!res.error_message) { alert('Something went wrong try again later!'); } alert(res.error_message); } }) }); //Listener For Scheduled Count jQuery('span.speedycache-scheduled-count').on('click', function() { speedycache_open_modal(jQuery(this)); }); //Listeners Starts here //Search button listener jQuery('#speedycache-image-search-button').on('click', function() { speedycache_update_list(jQuery(this)); }); //All or Error image filter jQuery('#speedycache-image-list-filter').on('change', function() { speedycache_update_list(jQuery(this)); }); //Per page listener jQuery('#speedycache-image-per-page').on('change', function() { speedycache_update_list(jQuery(this)); }); //Paging Number Listeners jQuery('.speedycache-image-list-first-page, .speedycache-image-list-prev-page, .speedycache-image-list-next-page, .speedycache-image-list-last-page').on('click', function() { speedycache_update_list(jQuery(this)); }); //Toggles the image variants Listener jQuery('.speedycache-open-image-details').on('click', open_img_details); } /* Converts the format of jQuery serializeArray i.e, [ 0:{name:someName, value:expectedvalue} ] to { someName:expectedvalue } */ function speedycache_convert_serialized(arr) { var converted_obj = {}; for(var i of arr) { converted_obj[i.name] = i.value; } return converted_obj; } function speedycache_critical_css(){ jQuery.ajax({ type: 'GET', url : speedycache_ajax.url + '?action=speedycache_critical_css&security='+speedycache_ajax.nonce, success: function(res){ if(!res.success){ alert(res.data.message ? res.data.message : 'Something went wrong ! Unable to intitiate Critical CSS!'); return; } alert(res.data.message); } }) } function speedycache_verify_license(){ event.preventDefault(); let jEle = jQuery(event.target), form = jEle.closest('form'), form_data = form.serializeArray(), spinner = jEle.find('.speedycache-spinner'); spinner.addClass('speedycache-spinner-active'); jQuery.ajax({ type: 'GET', url : speedycache_ajax.url, data : form_data, success: function(res){ if(res.success){ alert('License verified, please reload the page'); return; } if(res.data){ alert(res.data); return; } alert('Something went wrong when trying to verify license'); } }).always(function(){ spinner.removeClass('speedycache-spinner-active'); }) }