File "admin_settings_rules.js.php"
Full Path: /home/ozbarhaber/public_html/wp-content/plugins/autoptimize/classes/critcss-inc/admin_settings_rules.js.php
File size: 19.04 KB
MIME-type: text/x-php
Charset: utf-8
<?php
/**
* Outputs JS code for the rules panel.
*/
if ( $ao_ccss_debug ) {
echo "console.log('[WARN] Autoptimize CriticalCSS is in debug mode!');\n";
echo "console.log('[WARN] Avoid using debug mode on production/live environments unless for ad-hoc troubleshooting purposes and make sure to disable it after!');\n";
}
?>
var rulesOriginEl = document.getElementById("critCssOrigin");
var deferInlineEl = document.getElementById("autoptimize_css_defer_inline");
var additionalEl = document.getElementById("autoptimize_ccss_additional");
if (rulesOriginEl)
rulesOriginEl.style.display = 'none';
if (deferInlineEl)
deferInlineEl.style.display = 'none';
if (additionalEl)
additionalEl.style.display = 'none';
if (rulesOriginEl) {
jQuery(document).ready(function() {
critCssArray=JSON.parse(document.getElementById("critCssOrigin").value);
<?php
if ( $ao_ccss_debug ) {
echo "console.log('Rules Object:', critCssArray);\n";
}
?>
drawTable(critCssArray);
jQuery("#addCritCssButton").click(function(){addEditRow();});
jQuery("#editDefaultButton").click(function(){editDefaultCritCss();});
jQuery("#editAdditionalButton").click(function(){editAdditionalCritCss();});
jQuery("#removeAllRules").click(function(){removeAllRules();});
});
}
function drawTable(critCssArray) {
jQuery("#rules-list").empty();
rnotice = 0;
jQuery.each(critCssArray,function(k,v) {
if (k=="paths") {
kstring="<?php esc_html_e( 'Path Based Rules', 'autoptimize' ); ?>";
} else {
kstring="<?php esc_html_e( 'Conditional Tags, Custom Post Types and Page Templates Rules', 'autoptimize' ); ?>";
}
if (!(jQuery.isEmptyObject(v))) {
jQuery("#rules-list").append("<tr><td colspan='5'><h4>" + kstring + "</h4></td></tr>");
jQuery("#rules-list").append("<tr class='header "+k+"Rule'><th><?php esc_html_e( 'Type', 'autoptimize' ); ?></th><th><?php esc_html_e( 'Target', 'autoptimize' ); ?></th><th><?php esc_html_e( 'Critical CSS File', 'autoptimize' ); ?></th><th colspan='2'><?php esc_html_e( 'Actions', 'autoptimize' ); ?></th></tr>");
}
nodeNumber=0;
jQuery.each(v,function(i,nv){
nodeNumber++;
nodeId=k + "_" + nodeNumber;
hash=nv.hash;
file=nv.file;
filest=nv.file;
auto_style = '';
<?php
$criticalcss = new autoptimizeCriticalCSSBase();
if ( $criticalcss->is_api_active() ) {
echo 'api_active = 1;' . "\n";
} else {
echo 'api_active = 0;' . "\n";
}
?>
if (file == 0) {
file='<?php esc_html_e( 'To be fetched from criticalcss.com in the next queue run...', 'autoptimize' ); ?>';
}
if (nv.hash === 0 && filest != 0) {
type='<?php esc_html_e( 'MANUAL', 'autoptimize' ); ?>';
typeClass = 'manual';
} else {
type='<?php esc_html_e( 'AUTO', 'autoptimize' ); ?>';
typeClass = 'auto';
if ( api_active != 1 ) {
auto_style = ' style="opacity:.5;" '
}
}
if (file && typeof file == 'string') {
rmark_find=file.split('_');
if (rmark_find[2] || rmark_find[2] == 'R.css') {
rnotice = rnotice + 1;
}
}
if ( k == "paths" ) {
<?php
if ( apply_filters( 'autoptimize_filter_ccss_paths_clickable', true ) ) {
?>
target = '<a href="<?php echo AUTOPTIMIZE_WP_SITE_URL; ?>' + i + '" target="_blank">' + i + '</a>';
<?php
} else {
?>
target = i;
<?php
}
?>
} else {
target = i.replace(/(woo_|template_|custom_post_|edd_|bp_|bbp_)/,'');
}
jQuery("#rules-list").append("<tr " + auto_style + "class='rule "+k+"Rule'><td class='type'><span class='badge " + typeClass + "'>" + type + "</span></td><td class='target'>" + target + "</td><td class='file'>" + file + "</td><td class='btn edit'><span class=\"button-secondary\" id=\"" + nodeId + "_edit\"><?php esc_html_e( 'Edit', 'autoptimize' ); ?></span></td><td class='btn delete'><span class=\"button-secondary\" id=\"" + nodeId + "_remove\"><?php esc_html_e( 'Remove', 'autoptimize' ); ?></span></td></tr>");
if ( typeClass == 'manual' || api_active == 1 ) {
jQuery("#" + nodeId + "_edit").click(function(){addEditRow(this.id);});
}
jQuery("#" + nodeId + "_remove").click(function(){confirmRemove(this.id);});
})
});
if ( rnotice && rnotice != 0 ) {
// R rules were found, show a notice!
// and add some JS magic to ensure the notice works as a notice, but is shown inline
// in the rules panel instead of in the notice area where it would be too prominent.
<?php
$_ao_ccss_review_notice_id = 'autoptimize-ccss-review-rules-notice-30';
// Translators: before the 1st word a number + a space will be displayed, as in e.g. "2 of above rules".
$_ao_ccss_review_notice_copy = esc_html__( 'of the above rules got flagged by criticalcss.com as possibly needing review. This is often due to font-related issues which can be safely ignored, but in case of doubt do a visual test or check for Cumulative Layout Shift issues in e.g. Pagespeed Insights.', 'autoptimize' );
if ( PAnD::is_admin_notice_active( $_ao_ccss_review_notice_id ) ) {
?>
jQuery("#rules-notices").append( " <div class='rnotice notice notice-info is-dismissible hidden' data-dismissible='<?php echo $_ao_ccss_review_notice_id; ?>'><p>" + rnotice + " <?php echo $_ao_ccss_review_notice_copy; ?>" + "</p></div>");
jQuery( document ).ready(function() {
jQuery("div.rnotice").detach().appendTo('#rules-notices');
jQuery("div.rnotice").show();
});
<?php
} else if ( $ao_ccss_debug ) {
?>
console.log( "Autoptimize: " + rnotice + " <?php echo $_ao_ccss_review_notice_copy; ?>" );
<?php
}
?>
}
}
function confirmRemove(idToRemove) {
jQuery( "#confirm-rm" ).dialog({
resizable: false,
height:235,
modal: true,
buttons: {
"<?php esc_html_e( 'Delete', 'autoptimize' ); ?>": function() {
removeRow(idToRemove);
updateAfterChange();
jQuery( this ).dialog( "close" );
},
"<?php esc_html_e( 'Cancel', 'autoptimize' ); ?>": function() {
jQuery( this ).dialog( "close" );
}
}
});
}
function removeAllRules() {
jQuery( "#confirm-rm-all" ).dialog({
resizable: false,
height:235,
modal: true,
buttons: {
"<?php esc_html_e( 'Delete All', 'autoptimize' ); ?>": function() {
critCssArray={'paths':[],'types':[]};
drawTable(critCssArray);
updateAfterChange();
removeAllCcssFilesOnServer();
jQuery( this ).dialog( "close" );
},
"<?php esc_html_e( 'Cancel', 'autoptimize' ); ?>": function() {
jQuery( this ).dialog( "close" );
}
}
});
}
function removeRow(idToRemove) {
splits=idToRemove.split(/_/);
crit_type=splits[0];
crit_item=splits[1];
crit_key=Object.keys(critCssArray[crit_type])[crit_item-1];
crit_file=critCssArray[crit_type][crit_key].file;
delete critCssArray[crit_type][crit_key];
var data = {
'action': 'rm_critcss',
'critcss_rm_nonce': '<?php echo wp_create_nonce( 'rm_critcss_nonce' ); ?>',
'cachebustingtimestamp': new Date().getTime(),
'critcssfile': crit_file
};
jQuery.ajaxSetup({
async: false
});
jQuery.post(ajaxurl, data, function(response) {
response_array=JSON.parse(response);
if (response_array["code"]!=200) {
// not displaying notice, as the end result is OK; the file isn't there
// displayNotice(response_array["string"]);
}
});
}
function removeAllCcssFilesOnServer() {
var data = {
'action': 'rm_critcss_all',
'critcss_rm_all_nonce': '<?php echo wp_create_nonce( 'rm_critcss_all_nonce' ); ?>',
'cachebustingtimestamp': new Date().getTime()
};
jQuery.ajaxSetup({
async: false
});
jQuery.post(ajaxurl, data, function(response) {
response_array=JSON.parse(response);
if (response_array["code"]!=200) {
// not displaying notice, as the end result is OK; the file isn't there
// displayNotice(response_array["string"]);
}
});
}
function addEditRow(idToEdit) {
resetForm();
if (idToEdit) {
dialogTitle="<?php esc_html_e( 'Edit Critical CSS Rule', 'autoptimize' ); ?>";
splits=idToEdit.split(/_/);
crit_type=splits[0];
crit_item=splits[1];
crit_key=Object.keys(critCssArray[crit_type])[crit_item-1];
crit_file=critCssArray[crit_type][crit_key].file;
jQuery("#critcss_addedit_id").val(idToEdit);
jQuery("#critcss_addedit_type").val(crit_type);
jQuery("#critcss_addedit_file").val(crit_file);
jQuery("#critcss_addedit_css").attr("placeholder", "<?php esc_html_e( 'Loading critical CSS...', 'autoptimize' ); ?>");
jQuery("#critcss_addedit_css").attr("spellcheck",false);
jQuery("#critcss_addedit_type").attr("disabled",true);
if (crit_type==="paths") {
jQuery("#critcss_addedit_path").val(crit_key);
jQuery("#critcss_addedit_path_wrapper").show();
jQuery("#critcss_addedit_pagetype_wrapper").hide();
} else {
jQuery("#critcss_addedit_pagetype").val(crit_key);
jQuery("#critcss_addedit_pagetype_wrapper").show();
jQuery("#critcss_addedit_path_wrapper").hide();
}
var data = {
'action': 'fetch_critcss',
'critcss_fetch_nonce': '<?php echo wp_create_nonce( 'fetch_critcss_nonce' ); ?>',
'cachebustingtimestamp': new Date().getTime(),
'critcssfile': crit_file
};
jQuery.post(ajaxurl, data, function(response) {
response_array=JSON.parse(response);
if (response_array["code"]==200) {
jQuery("#critcss_addedit_css").val(response_array["string"]);
} else {
jQuery("#critcss_addedit_css").attr("placeholder", "").focus();
}
});
} else {
dialogTitle="<?php esc_html_e( 'Add Critical CSS Rule', 'autotimize' ); ?>";
// default: paths, hide content type field
jQuery("#critcss_addedit_type").val("paths");
jQuery("#critcss_addedit_css").attr("spellcheck",false);
jQuery("#critcss_addedit_pagetype_wrapper").hide();
// event handler on type to switch display
jQuery("#critcss_addedit_type").on('change', function (e) {
if(this.value==="types") {
jQuery("#critcss_addedit_pagetype_wrapper").show();
jQuery("#critcss_addedit_path_wrapper").hide();
jQuery("#critcss_addedit_css").attr("placeholder", "<?php esc_html_e( 'For type based rules, paste your specific and minified critical CSS here and hit submit to save. If you want to create a rule to exclude from critical CSS injection, enter \"none\".', 'autoptimize' ); ?>");
} else {
jQuery("#critcss_addedit_path_wrapper").show();
jQuery("#critcss_addedit_pagetype_wrapper").hide();
jQuery("#critcss_addedit_css").attr("placeholder", "<?php esc_html_e( 'For path based rules, paste your specific and minified critical CSS here or leave this empty to fetch it from criticalcss.com and hit submit to save. If you want to create a rule to exclude from critical CSS injection, enter \"none\"', 'autoptimize' ); ?>");
}
});
}
jQuery("#addEditCritCss").dialog({
autoOpen: true,
height: 500,
width: 700,
title: dialogTitle,
modal: true,
buttons: {
"<?php esc_html_e( 'Submit', 'autoptimize' ); ?>": function() {
rpath = jQuery("#critcss_addedit_path").val();
rtype = jQuery("#critcss_addedit_pagetype option:selected").val();
rccss = jQuery("#critcss_addedit_css").val();
<?php if ( $ao_ccss_debug ) { ?>
console.log('rpath: ' + rpath, 'rtype: ' + rtype, 'rccss: ' + rccss);
<?php } ?>
if (rpath === '' && rtype === '') {
alert('<?php esc_html_e( "Rule validation error:\\n\\nBased on your rule type, you should set a path or conditional tag.", 'autoptimize' ); ?>');
} else if (rtype !== '' && rccss == '') {
alert('<?php esc_html_e( "Rule validation error:\\n\\nType based rules requires a minified critical CSS.", 'autoptimize' ); ?>');
} else if (rpath !== rpath.replace(/("|\'|<|>|\[|\]|{|}|\|)/,'')) {
alert('<?php esc_html_e( "Path validation error:\\n\\nThe path contains characters that are not permitted, remove or encode the unsafe characters.", 'autoptimize' ); ?>');
} else {
saveEditCritCss();
jQuery(this).dialog('close');
}
},
"<?php esc_html_e( 'Cancel', 'autoptimize' ); ?>": function() {
resetForm();
jQuery(this).dialog("close");
}
}
});
}
function editDefaultCritCss(){
document.getElementById("dummyDefault").value=document.getElementById("autoptimize_css_defer_inline").value;
jQuery("#dummyDefault").attr("spellcheck",false);
jQuery("#default_critcss_wrapper").dialog({
autoOpen: true,
height: 505,
width: 700,
title: "<?php esc_html_e( 'Default Critical CSS', 'autoptimize' ); ?>",
modal: true,
buttons: {
"<?php esc_html_e( 'Submit', 'autoptimize' ); ?>": function() {
document.getElementById("autoptimize_css_defer_inline").value=document.getElementById("dummyDefault").value;
jQuery("#unSavedWarning").show();
jQuery("#default_critcss_wrapper").dialog( "close" );
},
"<?php esc_html_e( 'Cancel', 'autoptimize' ); ?>": function() {
jQuery("#default_critcss_wrapper").dialog( "close" );
}
}
});
}
function editAdditionalCritCss(){
document.getElementById("dummyAdditional").value=document.getElementById("autoptimize_ccss_additional").value;
jQuery("#dummyAdditional").attr("spellcheck",false);
jQuery("#additional_critcss_wrapper").dialog({
autoOpen: true,
height: 505,
width: 700,
title: "<?php esc_html_e( 'Additional Critical CSS', 'autoptimize' ); ?>",
modal: true,
buttons: {
"<?php esc_html_e( 'Submit', 'autoptimize' ); ?>": function() {
document.getElementById("autoptimize_ccss_additional").value=document.getElementById("dummyAdditional").value;
jQuery("#unSavedWarning").show();
jQuery("#additional_critcss_wrapper").dialog( "close" );
},
"<?php esc_html_e( 'Cancel', 'autoptimize' ); ?>": function() {
jQuery("#additional_critcss_wrapper").dialog( "close" );
}
}
});
}
function saveEditCritCss(){
critcssfile=jQuery("#critcss_addedit_file").val();
critcsscontents=jQuery("#critcss_addedit_css").val();
critcsstype=jQuery("#critcss_addedit_type").val();
critcssid=jQuery("#critcss_addedit_id").val();
if (critcssid) {
// this was an "edit" action, so remove original
// will also remove the file, but that will get rewritten anyway
removeRow(critcssid);
}
if (critcsstype==="types") {
critcsstarget=jQuery("#critcss_addedit_pagetype").val();
} else {
critcsstarget=jQuery("#critcss_addedit_path").val();
}
if (!critcssfile && !critcsscontents) {
critcssfile=0;
} else if (!critcssfile && critcsscontents) {
critcssfile="ccss_" + md5(critcsscontents+critcsstarget) + ".css";
}
// Compose the rule object
critCssArray[critcsstype][critcsstarget]={};
critCssArray[critcsstype][critcsstarget].hash=0;
critCssArray[critcsstype][critcsstarget].file=critcssfile;
<?php
if ( $ao_ccss_debug ) {
echo "console.log('[RULE PROPERTIES] Type:', critcsstype, ', Target:', critcsstarget, ', Hash:', 0, ', File:', critcssfile);";
}
?>
updateAfterChange();
var data = {
'action': 'save_critcss',
'critcss_save_nonce': '<?php echo wp_create_nonce( 'save_critcss_nonce' ); ?>',
'critcssfile': critcssfile,
'critcsscontents': critcsscontents
};
jQuery.post(ajaxurl, data, function(response) {
response_array=JSON.parse(response);
if (response_array["code"]!=200) {
displayNotice(response_array["string"]);
}
});
}
function updateAfterChange() {
document.getElementById("critCssOrigin").value=JSON.stringify(critCssArray);
drawTable(critCssArray);
<?php
// autosave rules is on by default, but can be disabled with a filter.
if ( apply_filters( 'autoptimize_filter_ccss_settings_rules_autosave', true ) ) {
?>
var data = {
'action': 'ao_ccss_saverules',
'ao_ccss_saverules_nonce': '<?php echo wp_create_nonce( 'ao_ccss_saverules_nonce' ); ?>',
'critcssrules': document.getElementById("critCssOrigin").value
};
jQuery.post(ajaxurl, data, function(response) {
response_array=JSON.parse(response);
if (response_array["code"]!=200) {
displayNotice(response_array["msg"]);
jQuery("#unSavedWarning").show();
}
});
<?php } else { ?>
jQuery("#unSavedWarning").show();
<?php } ?>
document.getElementById('ao_title_and_button').scrollIntoView();
}
function displayNotice(textIn, level = 'error') {
jQuery('<div class="notice notice-' + level + ' notice is-dismissible"><p>'+textIn+'</p></div>').insertBefore("#unSavedWarning");
document.getElementById('ao_title_and_button').scrollIntoView();
}
function resetForm() {
jQuery("#critcss_addedit_css").attr("placeholder", "<?php esc_html_e( 'For path based rules, paste your specific and minified critical CSS. If you want to create a rule to exclude from critical CSS injection, enter \"none\"', 'autoptimize' ); ?>");
jQuery("#critcss_addedit_type").attr("disabled",false);
jQuery("#critcss_addedit_path_wrapper").show();
jQuery("#critcss_addedit_id").val("");
jQuery("#critcss_addedit_path").val("");
jQuery("#critcss_addedit_file").val("");
jQuery("#critcss_addedit_pagetype").val("");
jQuery("#critcss_addedit_css").val("");
}