Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93

Warning: Undefined array key "page_file_edit_line" in /home/sportsfever/public_html/filemanger/edit_text_line.php on line 32
/home/sportsfe.../httpdocs/clone/wp-conte.../plugins/wordfenc.../modules/login-se.../js
File: admin.1722265817.js
var originalSelectValue = $(this).data('originalSelectValue');
[500] Fix | Delete
$(this).find('.wfls-option-select select').val(originalSelectValue).trigger('change');
[501] Fix | Delete
$(this).trigger('change', [true]);
[502] Fix | Delete
});
[503] Fix | Delete
[504] Fix | Delete
//Text options
[505] Fix | Delete
$('.wfls-option.wfls-option-text').each(function() {
[506] Fix | Delete
var originalTextValue = $(this).data('originalTextValue');
[507] Fix | Delete
if (typeof originalTextValue !== 'undefined') {
[508] Fix | Delete
$(this).find('.wfls-option-text input').val(originalTextValue);
[509] Fix | Delete
}
[510] Fix | Delete
$(this).trigger('change', [true]);
[511] Fix | Delete
});
[512] Fix | Delete
[513] Fix | Delete
//Text area options
[514] Fix | Delete
$('.wfls-option.wfls-option-textarea').each(function() {
[515] Fix | Delete
var originalTextValue = $(this).data('originalTextValue');
[516] Fix | Delete
$(this).find('.wfls-option-textarea textarea').val(originalTextValue);
[517] Fix | Delete
$(this).trigger('change', [true]);
[518] Fix | Delete
});
[519] Fix | Delete
[520] Fix | Delete
//Token options
[521] Fix | Delete
$('.wfls-option.wfls-option-token').each(function() {
[522] Fix | Delete
var originalTokenValue = $(this).data('originalTokenValue');
[523] Fix | Delete
$(this).find('select').val(originalTokenValue).trigger('change');
[524] Fix | Delete
$(this).trigger('change', [true]);
[525] Fix | Delete
});
[526] Fix | Delete
[527] Fix | Delete
//Switch options
[528] Fix | Delete
$('.wfls-option.wfls-option-switch').each(function() {
[529] Fix | Delete
var originalValue = $(this).data('originalValue');
[530] Fix | Delete
$(this).find('.wfls-switch > li').each(function() {
[531] Fix | Delete
$(this).toggleClass('wfls-active', originalValue == $(this).data('optionValue')).attr('aria-checked', originalValue == $(this).data('optionValue') ? 'true' : 'false');
[532] Fix | Delete
});
[533] Fix | Delete
$(this).trigger('change', [true]);
[534] Fix | Delete
});
[535] Fix | Delete
[536] Fix | Delete
//Other options
[537] Fix | Delete
$(window).trigger('wflsOptionsReset');
[538] Fix | Delete
[539] Fix | Delete
WFLS.pendingChanges = {};
[540] Fix | Delete
WFLS.updatePendingChanges();
[541] Fix | Delete
});
[542] Fix | Delete
},
[543] Fix | Delete
[544] Fix | Delete
updatePendingChanges: function() {
[545] Fix | Delete
$(window).off('beforeunload', WFLS._unsavedOptionsHandler);
[546] Fix | Delete
if (Object.keys(WFLS.pendingChanges).length) {
[547] Fix | Delete
$('#wfls-cancel-changes').removeClass('wfls-disabled');
[548] Fix | Delete
$('#wfls-save-changes').removeClass('wfls-disabled');
[549] Fix | Delete
$(window).on('beforeunload', WFLS._unsavedOptionsHandler);
[550] Fix | Delete
}
[551] Fix | Delete
else {
[552] Fix | Delete
$('#wfls-cancel-changes').addClass('wfls-disabled');
[553] Fix | Delete
$('#wfls-save-changes').addClass('wfls-disabled');
[554] Fix | Delete
}
[555] Fix | Delete
},
[556] Fix | Delete
[557] Fix | Delete
_unsavedOptionsHandler: function(e) {
[558] Fix | Delete
var message = __("You have unsaved changes to your options. If you leave this page, those changes will be lost."); //Only shows on older browsers, newer browsers don't allow message customization
[559] Fix | Delete
e = e || window.event;
[560] Fix | Delete
if (e) {
[561] Fix | Delete
e.returnValue = message; //IE and Firefox
[562] Fix | Delete
}
[563] Fix | Delete
return message; //Others
[564] Fix | Delete
},
[565] Fix | Delete
[566] Fix | Delete
setOptions: function(options, successCallback, failureCallback) {
[567] Fix | Delete
if (!Object.keys(options).length) {
[568] Fix | Delete
return;
[569] Fix | Delete
}
[570] Fix | Delete
[571] Fix | Delete
this.ajax('wordfence_ls_save_options', {changes: JSON.stringify(options)}, function(res) {
[572] Fix | Delete
if (res.success) {
[573] Fix | Delete
typeof successCallback == 'function' && successCallback(res);
[574] Fix | Delete
}
[575] Fix | Delete
else {
[576] Fix | Delete
if (res.hasOwnProperty('html') && res.html) {
[577] Fix | Delete
WFLS.panelModalHTML((WFLS.screenSize(500) ? '300px' : '400px'), 'Error Saving Options', res.error);
[578] Fix | Delete
}
[579] Fix | Delete
else {
[580] Fix | Delete
WFLS.panelModal((WFLS.screenSize(500) ? '300px' : '400px'), 'Error Saving Options', res.error);
[581] Fix | Delete
}
[582] Fix | Delete
[583] Fix | Delete
typeof failureCallback == 'function' && failureCallback
[584] Fix | Delete
}
[585] Fix | Delete
});
[586] Fix | Delete
},
[587] Fix | Delete
[588] Fix | Delete
saveOptions: function(successCallback, failureCallback) {
[589] Fix | Delete
this.setOptions(WFLS.pendingChanges, successCallback, failureCallback);
[590] Fix | Delete
},
[591] Fix | Delete
[592] Fix | Delete
updateIPPreview: function(value, successCallback) {
[593] Fix | Delete
this.ajax('wordfence_ls_update_ip_preview', value, function(response) {
[594] Fix | Delete
if (successCallback) {
[595] Fix | Delete
successCallback(response);
[596] Fix | Delete
}
[597] Fix | Delete
});
[598] Fix | Delete
},
[599] Fix | Delete
[600] Fix | Delete
/**
[601] Fix | Delete
* Sends a WP AJAX call, automatically adding our nonce.
[602] Fix | Delete
*
[603] Fix | Delete
* @param string action
[604] Fix | Delete
* @param string|array|object payload
[605] Fix | Delete
* @param function successCallback
[606] Fix | Delete
* @param function failureCallback
[607] Fix | Delete
*/
[608] Fix | Delete
ajax: function(action, payload, successCallback, failureCallback) {
[609] Fix | Delete
if (typeof(payload) == 'string') {
[610] Fix | Delete
if (payload.length > 0) {
[611] Fix | Delete
payload += '&';
[612] Fix | Delete
}
[613] Fix | Delete
payload += 'action=' + action + '&nonce=' + WFLSVars.nonce;
[614] Fix | Delete
}
[615] Fix | Delete
else if (typeof(payload) == 'object' && payload instanceof Array) {
[616] Fix | Delete
// jQuery serialized form data
[617] Fix | Delete
payload.push({
[618] Fix | Delete
name: 'action',
[619] Fix | Delete
value: action
[620] Fix | Delete
});
[621] Fix | Delete
payload.push({
[622] Fix | Delete
name: 'nonce',
[623] Fix | Delete
value: WFLSVars.nonce
[624] Fix | Delete
});
[625] Fix | Delete
}
[626] Fix | Delete
else if (typeof(payload) == 'object') {
[627] Fix | Delete
payload['action'] = action;
[628] Fix | Delete
payload['nonce'] = WFLSVars.nonce;
[629] Fix | Delete
}
[630] Fix | Delete
[631] Fix | Delete
[632] Fix | Delete
$.ajax({
[633] Fix | Delete
type: 'POST',
[634] Fix | Delete
url: WFLSVars.ajaxurl,
[635] Fix | Delete
dataType: "json",
[636] Fix | Delete
data: payload,
[637] Fix | Delete
success: function(json) {
[638] Fix | Delete
typeof successCallback == 'function' && successCallback(json);
[639] Fix | Delete
},
[640] Fix | Delete
error: function() {
[641] Fix | Delete
typeof failureCallback == 'function' && failureCallback();
[642] Fix | Delete
}
[643] Fix | Delete
});
[644] Fix | Delete
},
[645] Fix | Delete
[646] Fix | Delete
/**
[647] Fix | Delete
* Displays a generic panel.
[648] Fix | Delete
*
[649] Fix | Delete
* @param @param string width A width string in the format '100px'
[650] Fix | Delete
* @param string heading
[651] Fix | Delete
* @param string body
[652] Fix | Delete
* @param object settings
[653] Fix | Delete
*/
[654] Fix | Delete
panel: function(width, heading, body, settings) {
[655] Fix | Delete
if (typeof settings === 'undefined') {
[656] Fix | Delete
settings = {};
[657] Fix | Delete
}
[658] Fix | Delete
WFLS.panelQueue.push([width, "<h3>" + heading + "</h3><p>" + body + "</p>", settings]);
[659] Fix | Delete
WFLS._panelServiceQueue();
[660] Fix | Delete
},
[661] Fix | Delete
[662] Fix | Delete
/**
[663] Fix | Delete
* Displays a modal panel with fixed HTML content.
[664] Fix | Delete
*
[665] Fix | Delete
* @param @param string width A width string in the format '100px'
[666] Fix | Delete
* @param string heading
[667] Fix | Delete
* @param string body
[668] Fix | Delete
* @param object settings
[669] Fix | Delete
*/
[670] Fix | Delete
panelModalHTML: function(width, heading, body, settings) {
[671] Fix | Delete
if (typeof settings === 'undefined') {
[672] Fix | Delete
settings = {};
[673] Fix | Delete
}
[674] Fix | Delete
[675] Fix | Delete
var prompt = $.tmpl(WFLSVars.modalHTMLTemplate, {title: heading, message: body});
[676] Fix | Delete
var promptHTML = $("<div />").append(prompt).html();
[677] Fix | Delete
var callback = settings.onComplete;
[678] Fix | Delete
settings.overlayClose = false;
[679] Fix | Delete
settings.closeButton = false;
[680] Fix | Delete
settings.className = 'wfls-modal';
[681] Fix | Delete
settings.onComplete = function() {
[682] Fix | Delete
$('#wfls-generic-modal-close').on('click', function(e) {
[683] Fix | Delete
e.preventDefault();
[684] Fix | Delete
e.stopPropagation();
[685] Fix | Delete
[686] Fix | Delete
WFLS.panelClose();
[687] Fix | Delete
});
[688] Fix | Delete
[689] Fix | Delete
typeof callback === 'function' && callback();
[690] Fix | Delete
};
[691] Fix | Delete
WFLS.panelHTML(width, promptHTML, settings)
[692] Fix | Delete
},
[693] Fix | Delete
[694] Fix | Delete
/**
[695] Fix | Delete
* Displays a modal panel, automatically escaping the content.
[696] Fix | Delete
*
[697] Fix | Delete
* @param @param string width A width string in the format '100px'
[698] Fix | Delete
* @param string heading
[699] Fix | Delete
* @param string body
[700] Fix | Delete
* @param object settings
[701] Fix | Delete
*/
[702] Fix | Delete
panelModal: function(width, heading, body, settings) {
[703] Fix | Delete
if (typeof settings === 'undefined') {
[704] Fix | Delete
settings = {};
[705] Fix | Delete
}
[706] Fix | Delete
[707] Fix | Delete
if (width === null)
[708] Fix | Delete
width = WFLS.screenSize(500) ? '300px' : '400px';
[709] Fix | Delete
[710] Fix | Delete
var includeDefaultButtons = typeof settings.includeDefaultButtons === 'undefined' ? false : settings.includeDefaultButtons;
[711] Fix | Delete
var prompt = $.tmpl(WFLSVars[includeDefaultButtons ? 'modalTemplate' : 'modalNoButtonsTemplate'], {title: heading, message: body});
[712] Fix | Delete
[713] Fix | Delete
if (typeof settings.additional_buttons !== 'undefined') {
[714] Fix | Delete
var buttonSection = prompt.find('.wfls-modal-footer > ul');
[715] Fix | Delete
for(index in settings.additional_buttons) {
[716] Fix | Delete
var buttonSettings = settings.additional_buttons[index];
[717] Fix | Delete
var button = $('<button>').text(buttonSettings.label)
[718] Fix | Delete
.addClass('wfls-btn wfls-btn-callout-subtle wfls-additional-button')
[719] Fix | Delete
.attr('id', buttonSettings.id);
[720] Fix | Delete
var buttonType = typeof buttonSettings.type === 'undefined' ? 'default' : buttonSettings.type;
[721] Fix | Delete
button.addClass('wfls-btn-' + buttonType);
[722] Fix | Delete
buttonSection.prepend($("<li>").addClass('wfls-padding-add-left-small').append(button));
[723] Fix | Delete
}
[724] Fix | Delete
}
[725] Fix | Delete
[726] Fix | Delete
var promptHTML = $("<div />").append(prompt).html();
[727] Fix | Delete
var callback = settings.onComplete;
[728] Fix | Delete
settings.overlayClose = false;
[729] Fix | Delete
settings.closeButton = false;
[730] Fix | Delete
settings.className = 'wfls-modal';
[731] Fix | Delete
settings.onComplete = function() {
[732] Fix | Delete
$('#wfls-generic-modal-close').on('click', function(e) {
[733] Fix | Delete
e.preventDefault();
[734] Fix | Delete
e.stopPropagation();
[735] Fix | Delete
[736] Fix | Delete
WFLS.panelClose();
[737] Fix | Delete
});
[738] Fix | Delete
[739] Fix | Delete
typeof callback === 'function' && callback();
[740] Fix | Delete
};
[741] Fix | Delete
WFLS.panelHTML(width, promptHTML, settings)
[742] Fix | Delete
},
[743] Fix | Delete
[744] Fix | Delete
/**
[745] Fix | Delete
* Displays a modal with the given title and message text.
[746] Fix | Delete
*
[747] Fix | Delete
* @param string title the modal title
[748] Fix | Delete
* @param string message the message (this will be treated as text, not HTML)
[749] Fix | Delete
* @param array buttons the buttons to include in the modal footer
[750] Fix | Delete
* Each item in the array should be an object with the following properties:
[751] Fix | Delete
* - label: The button text
[752] Fix | Delete
* - id: An ID for the button
[753] Fix | Delete
* - type: The type of button for styling purposes - i.e. default, primary (default: 'default')
[754] Fix | Delete
* @param object settings
[755] Fix | Delete
*
[756] Fix | Delete
* @see WFLS.panelModal
[757] Fix | Delete
*/
[758] Fix | Delete
displayModalMessage: function(title, message, buttons, settings) {
[759] Fix | Delete
if (typeof settings !== 'object')
[760] Fix | Delete
settings = {};
[761] Fix | Delete
var width = typeof settings.width === 'undefined' ? null : settings.width;
[762] Fix | Delete
settings.includeDefaultButtons = false;
[763] Fix | Delete
settings.additional_buttons = buttons;
[764] Fix | Delete
WFLS.panelModal(width, title, message, settings);
[765] Fix | Delete
},
[766] Fix | Delete
[767] Fix | Delete
/**
[768] Fix | Delete
* Displays a modal panel with the error formatting.
[769] Fix | Delete
*
[770] Fix | Delete
* @param string errorMsg
[771] Fix | Delete
* @param bool isTokenError Whether or not this error is an expired nonce error.
[772] Fix | Delete
*/
[773] Fix | Delete
panelError: function(errorMsg, isTokenError) {
[774] Fix | Delete
var callback = false;
[775] Fix | Delete
if (isTokenError) {
[776] Fix | Delete
if (WFLS.tokenErrorShowing) {
[777] Fix | Delete
return;
[778] Fix | Delete
}
[779] Fix | Delete
[780] Fix | Delete
callback = function() {
[781] Fix | Delete
setTimeout(function() {
[782] Fix | Delete
WFLS.tokenErrorShowing = false;
[783] Fix | Delete
}, 30000);
[784] Fix | Delete
};
[785] Fix | Delete
[786] Fix | Delete
WFLS.tokenErrorShowing = true;
[787] Fix | Delete
}
[788] Fix | Delete
[789] Fix | Delete
var prompt = $.tmpl(WFLSVars.tokenInvalidTemplate, {title: 'An error occurred', message: errorMsg});
[790] Fix | Delete
var promptHTML = $("<div />").append(prompt).html();
[791] Fix | Delete
var settings = {};
[792] Fix | Delete
settings.overlayClose = false;
[793] Fix | Delete
settings.closeButton = false;
[794] Fix | Delete
settings.className = 'wfls-modal';
[795] Fix | Delete
settings.onComplete = function() {
[796] Fix | Delete
$('#wfls-token-invalid-modal-reload').on('click', function(e) {
[797] Fix | Delete
e.preventDefault();
[798] Fix | Delete
e.stopPropagation();
[799] Fix | Delete
[800] Fix | Delete
window.location.reload(true);
[801] Fix | Delete
});
[802] Fix | Delete
[803] Fix | Delete
typeof callback === 'function' && callback();
[804] Fix | Delete
};
[805] Fix | Delete
WFLS.panelHTML((WFLS.screenSize(500) ? '300px' : '400px'), promptHTML, settings);
[806] Fix | Delete
},
[807] Fix | Delete
[808] Fix | Delete
/**
[809] Fix | Delete
* Displays a panel with fixed HTML content.
[810] Fix | Delete
*
[811] Fix | Delete
* @param string width A width string in the format '100px'
[812] Fix | Delete
* @param string html
[813] Fix | Delete
* @param object settings
[814] Fix | Delete
*/
[815] Fix | Delete
panelHTML: function(width, html, settings) {
[816] Fix | Delete
if (typeof settings === 'undefined') {
[817] Fix | Delete
settings = {};
[818] Fix | Delete
}
[819] Fix | Delete
WFLS.panelQueue.push([width, html, settings]);
[820] Fix | Delete
WFLS._panelServiceQueue();
[821] Fix | Delete
},
[822] Fix | Delete
[823] Fix | Delete
/**
[824] Fix | Delete
* Displays the next panel in the queue.
[825] Fix | Delete
*/
[826] Fix | Delete
_panelServiceQueue: function() {
[827] Fix | Delete
if (WFLS.panelIsOpen) {
[828] Fix | Delete
return;
[829] Fix | Delete
}
[830] Fix | Delete
if (WFLS.panelQueue.length < 1) {
[831] Fix | Delete
return;
[832] Fix | Delete
}
[833] Fix | Delete
var elem = WFLS.panelQueue.shift();
[834] Fix | Delete
WFLS._panelOpen(elem[0], elem[1], elem[2]);
[835] Fix | Delete
},
[836] Fix | Delete
[837] Fix | Delete
/**
[838] Fix | Delete
* Does the actual function call to display the panel.
[839] Fix | Delete
*
[840] Fix | Delete
* @param string width A width string in the format '100px'
[841] Fix | Delete
* @param string html
[842] Fix | Delete
* @param object settings
[843] Fix | Delete
*/
[844] Fix | Delete
_panelOpen: function(width, html, settings) {
[845] Fix | Delete
this.panelIsOpen = true;
[846] Fix | Delete
$.extend(settings, {
[847] Fix | Delete
width: width,
[848] Fix | Delete
html: html,
[849] Fix | Delete
onClosed: function() {
[850] Fix | Delete
WFLS.panelClose();
[851] Fix | Delete
}
[852] Fix | Delete
});
[853] Fix | Delete
$.wflscolorbox(settings);
[854] Fix | Delete
},
[855] Fix | Delete
[856] Fix | Delete
/**
[857] Fix | Delete
* Closes the current panel.
[858] Fix | Delete
*/
[859] Fix | Delete
panelClose: function() {
[860] Fix | Delete
WFLS.panelIsOpen = false;
[861] Fix | Delete
if (WFLS.panelQueue.length < 1) {
[862] Fix | Delete
$.wflscolorbox.close();
[863] Fix | Delete
}
[864] Fix | Delete
else {
[865] Fix | Delete
WFLS._panelServiceQueue();
[866] Fix | Delete
}
[867] Fix | Delete
},
[868] Fix | Delete
[869] Fix | Delete
/**
[870] Fix | Delete
* Parses and returns the hash portion of a URL, working around user agents that URL-encode the # character.
[871] Fix | Delete
*
[872] Fix | Delete
* @returns {Array}
[873] Fix | Delete
*/
[874] Fix | Delete
parseHashes: function() {
[875] Fix | Delete
var hashes = window.location.hash.replace('%23', '#');
[876] Fix | Delete
var splitHashes = hashes.split('#');
[877] Fix | Delete
var result = [];
[878] Fix | Delete
for (var i = 0; i < splitHashes.length; i++) {
[879] Fix | Delete
if (splitHashes[i].length > 0) {
[880] Fix | Delete
result.push(splitHashes[i]);
[881] Fix | Delete
}
[882] Fix | Delete
}
[883] Fix | Delete
return result;
[884] Fix | Delete
},
[885] Fix | Delete
[886] Fix | Delete
/**
[887] Fix | Delete
* Returns whether or not the screen size is within the size given. This may be a numerical value
[888] Fix | Delete
* or one of the WFLS_SCREEN_ constants.
[889] Fix | Delete
*
[890] Fix | Delete
* @param size
[891] Fix | Delete
* @returns {boolean}
[892] Fix | Delete
*/
[893] Fix | Delete
screenSize: function(size) {
[894] Fix | Delete
switch (size) {
[895] Fix | Delete
case WFLS.SCREEN_XS:
[896] Fix | Delete
return window.matchMedia("only screen and (max-width: 767px)").matches;
[897] Fix | Delete
case WFLS.SCREEN_SM:
[898] Fix | Delete
return window.matchMedia("only screen and (max-width: 991px)").matches;
[899] Fix | Delete
case WFLS.SCREEN_MD:
[900] Fix | Delete
return window.matchMedia("only screen and (max-width: 1199px)").matches;
[901] Fix | Delete
case WFLS.SCREEN_LG:
[902] Fix | Delete
return window.matchMedia("only screen and (max-width: 32767px)").matches;
[903] Fix | Delete
}
[904] Fix | Delete
[905] Fix | Delete
var parsed = parseInt(size);
[906] Fix | Delete
if (isNaN(parsed)) {
[907] Fix | Delete
return false;
[908] Fix | Delete
}
[909] Fix | Delete
return window.matchMedia("only screen and (max-width: " + parsed + "px)").matches;
[910] Fix | Delete
},
[911] Fix | Delete
};
[912] Fix | Delete
[913] Fix | Delete
$(function() {
[914] Fix | Delete
WFLS.init();
[915] Fix | Delete
});
[916] Fix | Delete
[917] Fix | Delete
$.fn.crossfade = function(incoming, duration, complete) {
[918] Fix | Delete
duration = duration || 400;
[919] Fix | Delete
complete = complete || function() { };
[920] Fix | Delete
[921] Fix | Delete
return this.each(function() {
[922] Fix | Delete
$(this).fadeOut(duration, function() {
[923] Fix | Delete
$(incoming).fadeIn(duration, complete);
[924] Fix | Delete
});
[925] Fix | Delete
});
[926] Fix | Delete
};
[927] Fix | Delete
})(jQuery);
[928] Fix | Delete
[929] Fix | Delete
/*! @source https://github.com/eligrey/FileSaver.js/blob/master/dist/FileSaver.min.js */
[930] Fix | Delete
(function(a,b){if("function"==typeof define&&define.amd)define([],b);else if("undefined"!=typeof exports)b();else{b(),a.FileSaver={exports:{}}.exports}})(this,function(){"use strict";function b(a,b){return"undefined"==typeof b?b={autoBom:!1}:"object"!=typeof b&&(console.warn("Deprecated: Expected third argument to be a object"),b={autoBom:!b}),b.autoBom&&/^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(a.type)?new Blob(["\uFEFF",a],{type:a.type}):a}function c(a,b,c){var d=new XMLHttpRequest;d.open("GET",a),d.responseType="blob",d.onload=function(){g(d.response,b,c)},d.onerror=function(){console.error("could not download file")},d.send()}function d(a){var b=new XMLHttpRequest;b.open("HEAD",a,!1);try{b.send()}catch(a){}return 200<=b.status&&299>=b.status}function e(a){try{a.dispatchEvent(new MouseEvent("click"))}catch(c){var b=document.createEvent("MouseEvents");b.initMouseEvent("click",!0,!0,window,0,0,0,80,20,!1,!1,!1,!1,0,null),a.dispatchEvent(b)}}var f="object"==typeof window&&window.window===window?window:"object"==typeof self&&self.self===self?self:"object"==typeof global&&global.global===global?global:void 0,a=/Macintosh/.test(navigator.userAgent)&&/AppleWebKit/.test(navigator.userAgent)&&!/Safari/.test(navigator.userAgent),g=f.saveAs||("object"!=typeof window||window!==f?function(){}:"download"in HTMLAnchorElement.prototype&&!a?function(b,g,h){var i=f.URL||f.webkitURL,j=document.createElement("a");g=g||b.name||"download",j.download=g,j.rel="noopener","string"==typeof b?(j.href=b,j.origin===location.origin?e(j):d(j.href)?c(b,g,h):e(j,j.target="_blank")):(j.href=i.createObjectURL(b),setTimeout(function(){i.revokeObjectURL(j.href)},4E4),setTimeout(function(){e(j)},0))}:"msSaveOrOpenBlob"in navigator?function(f,g,h){if(g=g||f.name||"download","string"!=typeof f)navigator.msSaveOrOpenBlob(b(f,h),g);else if(d(f))c(f,g,h);else{var i=document.createElement("a");i.href=f,i.target="_blank",setTimeout(function(){e(i)})}}:function(b,d,e,g){if(g=g||open("","_blank"),g&&(g.document.title=g.document.body.innerText="downloading..."),"string"==typeof b)return c(b,d,e);var h="application/octet-stream"===b.type,i=/constructor/i.test(f.HTMLElement)||f.safari,j=/CriOS\/[\d]+/.test(navigator.userAgent);if((j||h&&i||a)&&"undefined"!=typeof FileReader){var k=new FileReader;k.onloadend=function(){var a=k.result;a=j?a:a.replace(/^data:[^;]*;/,"data:attachment/file;"),g?g.location.href=a:location=a,g=null},k.readAsDataURL(b)}else{var l=f.URL||f.webkitURL,m=l.createObjectURL(b);g?g.location=m:location.href=m,g=null,setTimeout(function(){l.revokeObjectURL(m)},4E4)}});f.saveAs=g.saveAs=g,"undefined"!=typeof module&&(module.exports=g)});
[931] Fix | Delete
[932] Fix | Delete
12
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function