This is an automated email from the ASF dual-hosted git repository.

gcruz pushed a commit to branch gc/8449
in repository https://gitbox.apache.org/repos/asf/allura.git

commit 61d3e6896ead313f28d14cab3c54af3daebea27e
Author: Guillermo Cruz <guillermo.c...@slashdotmedia.com>
AuthorDate: Fri Aug 5 10:41:22 2022 -0600

    [#8449] added missing jquery-migrate file
---
 Allura/allura/public/nf/js/jquery-migrate-3.4.0.js | 983 +++++++++++++++++++++
 1 file changed, 983 insertions(+)

diff --git a/Allura/allura/public/nf/js/jquery-migrate-3.4.0.js 
b/Allura/allura/public/nf/js/jquery-migrate-3.4.0.js
new file mode 100644
index 000000000..6ad10c8e6
--- /dev/null
+++ b/Allura/allura/public/nf/js/jquery-migrate-3.4.0.js
@@ -0,0 +1,983 @@
+/*!
+ * jQuery Migrate - v3.4.0 - 2022-03-24T16:30Z
+ * Copyright OpenJS Foundation and other contributors
+ */
+( function( factory ) {
+       "use strict";
+
+       if ( typeof define === "function" && define.amd ) {
+
+               // AMD. Register as an anonymous module.
+               define( [ "jquery" ], function( jQuery ) {
+                       return factory( jQuery, window );
+               } );
+       } else if ( typeof module === "object" && module.exports ) {
+
+               // Node/CommonJS
+               // eslint-disable-next-line no-undef
+               module.exports = factory( require( "jquery" ), window );
+       } else {
+
+               // Browser globals
+               factory( jQuery, window );
+       }
+} )( function( jQuery, window ) {
+"use strict";
+
+jQuery.migrateVersion = "3.4.0";
+
+// Returns 0 if v1 == v2, -1 if v1 < v2, 1 if v1 > v2
+function compareVersions( v1, v2 ) {
+       var i,
+               rVersionParts = /^(\d+)\.(\d+)\.(\d+)/,
+               v1p = rVersionParts.exec( v1 ) || [ ],
+               v2p = rVersionParts.exec( v2 ) || [ ];
+
+       for ( i = 1; i <= 3; i++ ) {
+               if ( +v1p[ i ] > +v2p[ i ] ) {
+                       return 1;
+               }
+               if ( +v1p[ i ] < +v2p[ i ] ) {
+                       return -1;
+               }
+       }
+       return 0;
+}
+
+function jQueryVersionSince( version ) {
+       return compareVersions( jQuery.fn.jquery, version ) >= 0;
+}
+
+// A map from disabled patch codes to `true`. This should really
+// be a `Set` but those are unsupported in IE.
+var disabledPatches = Object.create( null );
+
+// Don't apply patches for specified codes. Helpful for code bases
+// where some Migrate warnings have been addressed and it's desirable
+// to avoid needless patches or false positives.
+jQuery.migrateDisablePatches = function() {
+       var i;
+       for ( i = 0; i < arguments.length; i++ ) {
+               disabledPatches[ arguments[ i ] ] = true;
+       }
+};
+
+// Allow enabling patches disabled via `jQuery.migrateDisablePatches`.
+// Helpful if you want to disable a patch only for some code that won't
+// be updated soon to be able to focus on other warnings - and enable it
+// immediately after such a call:
+// ```js
+// jQuery.migrateDisablePatches( "workaroundA" );
+// elem.pluginViolatingWarningA( "pluginMethod" );
+// jQuery.migrateEnablePatches( "workaroundA" );
+// ```
+jQuery.migrateEnablePatches = function() {
+       var i;
+       for ( i = 0; i < arguments.length; i++ ) {
+               delete disabledPatches[ arguments[ i ] ];
+       }
+};
+
+jQuery.migrateIsPatchEnabled = function( patchCode ) {
+       return !disabledPatches[ patchCode ];
+};
+
+( function() {
+
+       // Support: IE9 only
+       // IE9 only creates console object when dev tools are first opened
+       // IE9 console is a host object, callable but doesn't have .apply()
+       if ( !window.console || !window.console.log ) {
+               return;
+       }
+
+       // Need jQuery 3.0.0+ and no older Migrate loaded
+       if ( !jQuery || !jQueryVersionSince( "3.0.0" ) ) {
+               window.console.log( "JQMIGRATE: jQuery 3.0.0+ REQUIRED" );
+       }
+       if ( jQuery.migrateWarnings ) {
+               window.console.log( "JQMIGRATE: Migrate plugin loaded multiple 
times" );
+       }
+
+       // Show a message on the console so devs know we're active
+       window.console.log( "JQMIGRATE: Migrate is installed" +
+               ( jQuery.migrateMute ? "" : " with logging active" ) +
+               ", version " + jQuery.migrateVersion );
+
+} )();
+
+var warnedAbout = {};
+
+// By default each warning is only reported once.
+jQuery.migrateDeduplicateWarnings = true;
+
+// List of warnings already given; public read only
+jQuery.migrateWarnings = [];
+
+// Set to false to disable traces that appear with warnings
+if ( jQuery.migrateTrace === undefined ) {
+       jQuery.migrateTrace = true;
+}
+
+// Forget any warnings we've already given; public
+jQuery.migrateReset = function() {
+       warnedAbout = {};
+       jQuery.migrateWarnings.length = 0;
+};
+
+function migrateWarn( code, msg ) {
+       var console = window.console;
+       if ( jQuery.migrateIsPatchEnabled( code ) &&
+               ( !jQuery.migrateDeduplicateWarnings || !warnedAbout[ msg ] ) ) 
{
+               warnedAbout[ msg ] = true;
+               jQuery.migrateWarnings.push( msg + " [" + code + "]" );
+               if ( console && console.warn && !jQuery.migrateMute ) {
+                       console.warn( "JQMIGRATE: " + msg );
+                       if ( jQuery.migrateTrace && console.trace ) {
+                               console.trace();
+                       }
+               }
+       }
+}
+
+function migrateWarnProp( obj, prop, value, code, msg ) {
+       Object.defineProperty( obj, prop, {
+               configurable: true,
+               enumerable: true,
+               get: function() {
+                       migrateWarn( code, msg );
+                       return value;
+               },
+               set: function( newValue ) {
+                       migrateWarn( code, msg );
+                       value = newValue;
+               }
+       } );
+}
+
+function migrateWarnFuncInternal( obj, prop, newFunc, code, msg ) {
+       var finalFunc,
+               origFunc = obj[ prop ];
+
+       obj[ prop ] = function() {
+
+               // If `msg` not provided, do not warn; more sophisticated 
warnings
+               // logic is most likely embedded in `newFunc`, in that case here
+               // we just care about the logic choosing the proper 
implementation
+               // based on whether the patch is disabled or not.
+               if ( msg ) {
+                       migrateWarn( code, msg );
+               }
+
+               // Since patches can be disabled & enabled dynamically, we
+               // need to decide which implementation to run on each 
invocation.
+               finalFunc = jQuery.migrateIsPatchEnabled( code ) ?
+                       newFunc :
+
+                       // The function may not have existed originally so we 
need a fallback.
+                       ( origFunc || jQuery.noop );
+
+               return finalFunc.apply( this, arguments );
+       };
+}
+
+function migratePatchAndWarnFunc( obj, prop, newFunc, code, msg ) {
+       if ( !msg ) {
+               throw new Error( "No warning message provided" );
+       }
+       return migrateWarnFuncInternal( obj, prop, newFunc, code, msg );
+}
+
+function migratePatchFunc( obj, prop, newFunc, code ) {
+       return migrateWarnFuncInternal( obj, prop, newFunc, code );
+}
+
+if ( window.document.compatMode === "BackCompat" ) {
+
+       // jQuery has never supported or tested Quirks Mode
+       migrateWarn( "quirks", "jQuery is not compatible with Quirks Mode" );
+}
+
+var findProp,
+       class2type = {},
+       oldInit = jQuery.fn.init,
+       oldFind = jQuery.find,
+
+       rattrHashTest = /\[(\s*[-\w]+\s*)([~|^$*]?=)\s*([-\w#]*?#[-\w#]*)\s*\]/,
+       rattrHashGlob = 
/\[(\s*[-\w]+\s*)([~|^$*]?=)\s*([-\w#]*?#[-\w#]*)\s*\]/g,
+
+       // Support: Android <=4.0 only
+       // Make sure we trim BOM and NBSP
+       rtrim = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;
+
+migratePatchFunc( jQuery.fn, "init", function( arg1 ) {
+       var args = Array.prototype.slice.call( arguments );
+
+       if ( jQuery.migrateIsPatchEnabled( "selector-empty-id" ) &&
+               typeof arg1 === "string" && arg1 === "#" ) {
+
+               // JQuery( "#" ) is a bogus ID selector, but it returned an 
empty set
+               // before jQuery 3.0
+               migrateWarn( "selector-empty-id", "jQuery( '#' ) is not a valid 
selector" );
+               args[ 0 ] = [];
+       }
+
+       return oldInit.apply( this, args );
+}, "selector-empty-id" );
+
+// This is already done in Core but the above patch will lose this assignment
+// so we need to redo it. It doesn't matter whether the patch is enabled or not
+// as the method is always going to be a Migrate-created wrapper.
+jQuery.fn.init.prototype = jQuery.fn;
+
+migratePatchFunc( jQuery, "find", function( selector ) {
+       var args = Array.prototype.slice.call( arguments );
+
+       // Support: PhantomJS 1.x
+       // String#match fails to match when used with a //g RegExp, only on 
some strings
+       if ( typeof selector === "string" && rattrHashTest.test( selector ) ) {
+
+               // The nonstandard and undocumented unquoted-hash was removed 
in jQuery 1.12.0
+               // First see if qS thinks it's a valid selector, if so avoid a 
false positive
+               try {
+                       window.document.querySelector( selector );
+               } catch ( err1 ) {
+
+                       // Didn't *look* valid to qSA, warn and try quoting 
what we think is the value
+                       selector = selector.replace( rattrHashGlob, function( 
_, attr, op, value ) {
+                               return "[" + attr + op + "\"" + value + "\"]";
+                       } );
+
+                       // If the regexp *may* have created an invalid 
selector, don't update it
+                       // Note that there may be false alarms if selector uses 
jQuery extensions
+                       try {
+                               window.document.querySelector( selector );
+                               migrateWarn( "selector-hash",
+                                       "Attribute selector with '#' must be 
quoted: " + args[ 0 ] );
+                               args[ 0 ] = selector;
+                       } catch ( err2 ) {
+                               migrateWarn( "selector-hash",
+                                       "Attribute selector with '#' was not 
fixed: " + args[ 0 ] );
+                       }
+               }
+       }
+
+       return oldFind.apply( this, args );
+}, "selector-hash" );
+
+// Copy properties attached to original jQuery.find method (e.g. .attr, .isXML)
+for ( findProp in oldFind ) {
+       if ( Object.prototype.hasOwnProperty.call( oldFind, findProp ) ) {
+               jQuery.find[ findProp ] = oldFind[ findProp ];
+       }
+}
+
+// The number of elements contained in the matched element set
+migratePatchAndWarnFunc( jQuery.fn, "size", function() {
+       return this.length;
+}, "size",
+"jQuery.fn.size() is deprecated and removed; use the .length property" );
+
+migratePatchAndWarnFunc( jQuery, "parseJSON", function() {
+       return JSON.parse.apply( null, arguments );
+}, "parseJSON",
+"jQuery.parseJSON is deprecated; use JSON.parse" );
+
+migratePatchAndWarnFunc( jQuery, "holdReady", jQuery.holdReady,
+       "holdReady", "jQuery.holdReady is deprecated" );
+
+migratePatchAndWarnFunc( jQuery, "unique", jQuery.uniqueSort,
+       "unique", "jQuery.unique is deprecated; use jQuery.uniqueSort" );
+
+// Now jQuery.expr.pseudos is the standard incantation
+migrateWarnProp( jQuery.expr, "filters", jQuery.expr.pseudos, 
"expr-pre-pseudos",
+       "jQuery.expr.filters is deprecated; use jQuery.expr.pseudos" );
+migrateWarnProp( jQuery.expr, ":", jQuery.expr.pseudos, "expr-pre-pseudos",
+       "jQuery.expr[':'] is deprecated; use jQuery.expr.pseudos" );
+
+// Prior to jQuery 3.1.1 there were internal refs so we don't warn there
+if ( jQueryVersionSince( "3.1.1" ) ) {
+       migratePatchAndWarnFunc( jQuery, "trim", function( text ) {
+               return text == null ?
+                       "" :
+                       ( text + "" ).replace( rtrim, "" );
+       }, "trim",
+       "jQuery.trim is deprecated; use String.prototype.trim" );
+}
+
+// Prior to jQuery 3.2 there were internal refs so we don't warn there
+if ( jQueryVersionSince( "3.2.0" ) ) {
+       migratePatchAndWarnFunc( jQuery, "nodeName", function( elem, name ) {
+               return elem.nodeName && elem.nodeName.toLowerCase() === 
name.toLowerCase();
+       }, "nodeName",
+       "jQuery.nodeName is deprecated" );
+
+       migratePatchAndWarnFunc( jQuery, "isArray", Array.isArray, "isArray",
+               "jQuery.isArray is deprecated; use Array.isArray"
+       );
+}
+
+if ( jQueryVersionSince( "3.3.0" ) ) {
+
+       migratePatchAndWarnFunc( jQuery, "isNumeric", function( obj ) {
+
+                       // As of jQuery 3.0, isNumeric is limited to
+                       // strings and numbers (primitives or objects)
+                       // that can be coerced to finite numbers (gh-2662)
+                       var type = typeof obj;
+                       return ( type === "number" || type === "string" ) &&
+
+                               // parseFloat NaNs numeric-cast false positives 
("")
+                               // ...but misinterprets leading-number strings, 
e.g. hex literals ("0x...")
+                               // subtraction forces infinities to NaN
+                               !isNaN( obj - parseFloat( obj ) );
+               }, "isNumeric",
+               "jQuery.isNumeric() is deprecated"
+       );
+
+       // Populate the class2type map
+       jQuery.each( "Boolean Number String Function Array Date RegExp Object 
Error Symbol".
+               split( " " ),
+       function( _, name ) {
+               class2type[ "[object " + name + "]" ] = name.toLowerCase();
+       } );
+
+       migratePatchAndWarnFunc( jQuery, "type", function( obj ) {
+               if ( obj == null ) {
+                       return obj + "";
+               }
+
+               // Support: Android <=2.3 only (functionish RegExp)
+               return typeof obj === "object" || typeof obj === "function" ?
+                       class2type[ Object.prototype.toString.call( obj ) ] || 
"object" :
+                       typeof obj;
+       }, "type",
+       "jQuery.type is deprecated" );
+
+       migratePatchAndWarnFunc( jQuery, "isFunction",
+               function( obj ) {
+                       return typeof obj === "function";
+               }, "isFunction",
+               "jQuery.isFunction() is deprecated" );
+
+       migratePatchAndWarnFunc( jQuery, "isWindow",
+               function( obj ) {
+                       return obj != null && obj === obj.window;
+               }, "isWindow",
+               "jQuery.isWindow() is deprecated"
+       );
+}
+
+// Support jQuery slim which excludes the ajax module
+if ( jQuery.ajax ) {
+
+var oldAjax = jQuery.ajax,
+       rjsonp = /(=)\?(?=&|$)|\?\?/;
+
+migratePatchFunc( jQuery, "ajax", function() {
+       var jQXHR = oldAjax.apply( this, arguments );
+
+       // Be sure we got a jQXHR (e.g., not sync)
+       if ( jQXHR.promise ) {
+               migratePatchAndWarnFunc( jQXHR, "success", jQXHR.done, 
"jqXHR-methods",
+                       "jQXHR.success is deprecated and removed" );
+               migratePatchAndWarnFunc( jQXHR, "error", jQXHR.fail, 
"jqXHR-methods",
+                       "jQXHR.error is deprecated and removed" );
+               migratePatchAndWarnFunc( jQXHR, "complete", jQXHR.always, 
"jqXHR-methods",
+                       "jQXHR.complete is deprecated and removed" );
+       }
+
+       return jQXHR;
+}, "jqXHR-methods" );
+
+// Only trigger the logic in jQuery <4 as the JSON-to-JSONP auto-promotion
+// behavior is gone in jQuery 4.0 and as it has security implications, we don't
+// want to restore the legacy behavior.
+if ( !jQueryVersionSince( "4.0.0" ) ) {
+
+       // Register this prefilter before the jQuery one. Otherwise, a promoted
+       // request is transformed into one with the script dataType and we can't
+       // catch it anymore.
+       jQuery.ajaxPrefilter( "+json", function( s ) {
+
+               // Warn if JSON-to-JSONP auto-promotion happens.
+               if ( s.jsonp !== false && ( rjsonp.test( s.url ) ||
+                               typeof s.data === "string" &&
+                               ( s.contentType || "" )
+                                       .indexOf( 
"application/x-www-form-urlencoded" ) === 0 &&
+                               rjsonp.test( s.data )
+               ) ) {
+                       migrateWarn( "jsonp-promotion", "JSON-to-JSONP 
auto-promotion is deprecated" );
+               }
+       } );
+}
+
+}
+
+var oldRemoveAttr = jQuery.fn.removeAttr,
+       oldToggleClass = jQuery.fn.toggleClass,
+       rmatchNonSpace = /\S+/g;
+
+migratePatchFunc( jQuery.fn, "removeAttr", function( name ) {
+       var self = this;
+
+       jQuery.each( name.match( rmatchNonSpace ), function( _i, attr ) {
+               if ( jQuery.expr.match.bool.test( attr ) ) {
+                       migrateWarn( "removeAttr-bool",
+                               "jQuery.fn.removeAttr no longer sets boolean 
properties: " + attr );
+                       self.prop( attr, false );
+               }
+       } );
+
+       return oldRemoveAttr.apply( this, arguments );
+}, "removeAttr-bool" );
+
+migratePatchFunc( jQuery.fn, "toggleClass", function( state ) {
+
+       // Only deprecating no-args or single boolean arg
+       if ( state !== undefined && typeof state !== "boolean" ) {
+
+               return oldToggleClass.apply( this, arguments );
+       }
+
+       migrateWarn( "toggleClass-bool", "jQuery.fn.toggleClass( boolean ) is 
deprecated" );
+
+       // Toggle entire class name of each element
+       return this.each( function() {
+               var className = this.getAttribute && this.getAttribute( "class" 
) || "";
+
+               if ( className ) {
+                       jQuery.data( this, "__className__", className );
+               }
+
+               // If the element has a class name or if we're passed `false`,
+               // then remove the whole classname (if there was one, the above 
saved it).
+               // Otherwise bring back whatever was previously saved (if 
anything),
+               // falling back to the empty string if nothing was stored.
+               if ( this.setAttribute ) {
+                       this.setAttribute( "class",
+                               className || state === false ?
+                               "" :
+                               jQuery.data( this, "__className__" ) || ""
+                       );
+               }
+       } );
+}, "toggleClass-bool" );
+
+function camelCase( string ) {
+       return string.replace( /-([a-z])/g, function( _, letter ) {
+               return letter.toUpperCase();
+       } );
+}
+
+var origFnCss,
+       internalSwapCall = false,
+       ralphaStart = /^[a-z]/,
+
+       // The regex visualized:
+       //
+       //                         /----------\
+       //                        |            |    /-------\
+       //                        |  / Top  \  |   |         |
+       //         /--- Border ---+-| Right  |-+---+- Width -+---\
+       //        |                 | Bottom |                    |
+       //        |                  \ Left /                     |
+       //        |                                               |
+       //        |                              /----------\     |
+       //        |          /-------------\    |            |    |- END
+       //        |         |               |   |  / Top  \  |    |
+       //        |         |  / Margin  \  |   | | Right  | |    |
+       //        |---------+-|           |-+---+-| Bottom |-+----|
+       //        |            \ Padding /         \ Left /       |
+       // BEGIN -|                                               |
+       //        |                /---------\                    |
+       //        |               |           |                   |
+       //        |               |  / Min \  |    / Width  \     |
+       //         \--------------+-|       |-+---|          |---/
+       //                           \ Max /       \ Height /
+       rautoPx = 
/^(?:Border(?:Top|Right|Bottom|Left)?(?:Width|)|(?:Margin|Padding)?(?:Top|Right|Bottom|Left)?|(?:Min|Max)?(?:Width|Height))$/;
+
+// If this version of jQuery has .swap(), don't false-alarm on internal uses
+if ( jQuery.swap ) {
+       jQuery.each( [ "height", "width", "reliableMarginRight" ], function( _, 
name ) {
+               var oldHook = jQuery.cssHooks[ name ] && jQuery.cssHooks[ name 
].get;
+
+               if ( oldHook ) {
+                       jQuery.cssHooks[ name ].get = function() {
+                               var ret;
+
+                               internalSwapCall = true;
+                               ret = oldHook.apply( this, arguments );
+                               internalSwapCall = false;
+                               return ret;
+                       };
+               }
+       } );
+}
+
+migratePatchFunc( jQuery, "swap", function( elem, options, callback, args ) {
+       var ret, name,
+               old = {};
+
+       if ( !internalSwapCall ) {
+               migrateWarn( "swap", "jQuery.swap() is undocumented and 
deprecated" );
+       }
+
+       // Remember the old values, and insert the new ones
+       for ( name in options ) {
+               old[ name ] = elem.style[ name ];
+               elem.style[ name ] = options[ name ];
+       }
+
+       ret = callback.apply( elem, args || [] );
+
+       // Revert the old values
+       for ( name in options ) {
+               elem.style[ name ] = old[ name ];
+       }
+
+       return ret;
+}, "swap" );
+
+if ( jQueryVersionSince( "3.4.0" ) && typeof Proxy !== "undefined" ) {
+       jQuery.cssProps = new Proxy( jQuery.cssProps || {}, {
+               set: function() {
+                       migrateWarn( "cssProps", "jQuery.cssProps is 
deprecated" );
+                       return Reflect.set.apply( this, arguments );
+               }
+       } );
+}
+
+// In jQuery >=4 where jQuery.cssNumber is missing fill it with the latest 3.x 
version:
+// https://github.com/jquery/jquery/blob/3.6.0/src/css.js#L212-L233
+// This way, number values for the CSS properties below won't start triggering
+// Migrate warnings when jQuery gets updated to >=4.0.0 (gh-438).
+if ( jQueryVersionSince( "4.0.0" ) && typeof Proxy !== "undefined" ) {
+       jQuery.cssNumber = new Proxy( {
+               animationIterationCount: true,
+               columnCount: true,
+               fillOpacity: true,
+               flexGrow: true,
+               flexShrink: true,
+               fontWeight: true,
+               gridArea: true,
+               gridColumn: true,
+               gridColumnEnd: true,
+               gridColumnStart: true,
+               gridRow: true,
+               gridRowEnd: true,
+               gridRowStart: true,
+               lineHeight: true,
+               opacity: true,
+               order: true,
+               orphans: true,
+               widows: true,
+               zIndex: true,
+               zoom: true
+       }, {
+               get: function() {
+                       migrateWarn( "css-number", "jQuery.cssNumber is 
deprecated" );
+                       return Reflect.get.apply( this, arguments );
+               },
+               set: function() {
+                       migrateWarn( "css-number", "jQuery.cssNumber is 
deprecated" );
+                       return Reflect.set.apply( this, arguments );
+               }
+       } );
+}
+
+function isAutoPx( prop ) {
+
+       // The first test is used to ensure that:
+       // 1. The prop starts with a lowercase letter (as we uppercase it for 
the second regex).
+       // 2. The prop is not empty.
+       return ralphaStart.test( prop ) &&
+               rautoPx.test( prop[ 0 ].toUpperCase() + prop.slice( 1 ) );
+}
+
+origFnCss = jQuery.fn.css;
+
+migratePatchFunc( jQuery.fn, "css", function( name, value ) {
+       var camelName,
+               origThis = this;
+
+       if ( name && typeof name === "object" && !Array.isArray( name ) ) {
+               jQuery.each( name, function( n, v ) {
+                       jQuery.fn.css.call( origThis, n, v );
+               } );
+               return this;
+       }
+
+       if ( typeof value === "number" ) {
+               camelName = camelCase( name );
+               if ( !isAutoPx( camelName ) && !jQuery.cssNumber[ camelName ] ) 
{
+                       migrateWarn( "css-number",
+                               "Number-typed values are deprecated for 
jQuery.fn.css( \"" +
+                               name + "\", value )" );
+               }
+       }
+
+       return origFnCss.apply( this, arguments );
+}, "css-number" );
+
+var origData = jQuery.data;
+
+migratePatchFunc( jQuery, "data", function( elem, name, value ) {
+       var curData, sameKeys, key;
+
+       // Name can be an object, and each entry in the object is meant to be 
set as data
+       if ( name && typeof name === "object" && arguments.length === 2 ) {
+
+               curData = jQuery.hasData( elem ) && origData.call( this, elem );
+               sameKeys = {};
+               for ( key in name ) {
+                       if ( key !== camelCase( key ) ) {
+                               migrateWarn( "data-camelCase",
+                                       "jQuery.data() always sets/gets 
camelCased names: " + key );
+                               curData[ key ] = name[ key ];
+                       } else {
+                               sameKeys[ key ] = name[ key ];
+                       }
+               }
+
+               origData.call( this, elem, sameKeys );
+
+               return name;
+       }
+
+       // If the name is transformed, look for the un-transformed name in the 
data object
+       if ( name && typeof name === "string" && name !== camelCase( name ) ) {
+
+               curData = jQuery.hasData( elem ) && origData.call( this, elem );
+               if ( curData && name in curData ) {
+                       migrateWarn( "data-camelCase",
+                               "jQuery.data() always sets/gets camelCased 
names: " + name );
+                       if ( arguments.length > 2 ) {
+                               curData[ name ] = value;
+                       }
+                       return curData[ name ];
+               }
+       }
+
+       return origData.apply( this, arguments );
+}, "data-camelCase" );
+
+// Support jQuery slim which excludes the effects module
+if ( jQuery.fx ) {
+
+var intervalValue, intervalMsg,
+       oldTweenRun = jQuery.Tween.prototype.run,
+       linearEasing = function( pct ) {
+               return pct;
+       };
+
+migratePatchFunc( jQuery.Tween.prototype, "run", function( ) {
+       if ( jQuery.easing[ this.easing ].length > 1 ) {
+               migrateWarn(
+                       "easing-one-arg",
+                       "'jQuery.easing." + this.easing.toString() + "' should 
use only one argument"
+               );
+
+               jQuery.easing[ this.easing ] = linearEasing;
+       }
+
+       oldTweenRun.apply( this, arguments );
+}, "easing-one-arg" );
+
+intervalValue = jQuery.fx.interval;
+intervalMsg = "jQuery.fx.interval is deprecated";
+
+// Support: IE9, Android <=4.4
+// Avoid false positives on browsers that lack rAF
+// Don't warn if document is hidden, jQuery uses setTimeout (#292)
+if ( window.requestAnimationFrame ) {
+       Object.defineProperty( jQuery.fx, "interval", {
+               configurable: true,
+               enumerable: true,
+               get: function() {
+                       if ( !window.document.hidden ) {
+                               migrateWarn( "fx-interval", intervalMsg );
+                       }
+
+                       // Only fallback to the default if patch is enabled
+                       if ( !jQuery.migrateIsPatchEnabled( "fx-interval" ) ) {
+                               return intervalValue;
+                       }
+                       return intervalValue === undefined ? 13 : intervalValue;
+               },
+               set: function( newValue ) {
+                       migrateWarn( "fx-interval", intervalMsg );
+                       intervalValue = newValue;
+               }
+       } );
+}
+
+}
+
+var oldLoad = jQuery.fn.load,
+       oldEventAdd = jQuery.event.add,
+       originalFix = jQuery.event.fix;
+
+jQuery.event.props = [];
+jQuery.event.fixHooks = {};
+
+migrateWarnProp( jQuery.event.props, "concat", jQuery.event.props.concat,
+       "event-old-patch",
+       "jQuery.event.props.concat() is deprecated and removed" );
+
+migratePatchFunc( jQuery.event, "fix", function( originalEvent ) {
+       var event,
+               type = originalEvent.type,
+               fixHook = this.fixHooks[ type ],
+               props = jQuery.event.props;
+
+       if ( props.length ) {
+               migrateWarn( "event-old-patch",
+                       "jQuery.event.props are deprecated and removed: " + 
props.join() );
+               while ( props.length ) {
+                       jQuery.event.addProp( props.pop() );
+               }
+       }
+
+       if ( fixHook && !fixHook._migrated_ ) {
+               fixHook._migrated_ = true;
+               migrateWarn( "event-old-patch",
+                       "jQuery.event.fixHooks are deprecated and removed: " + 
type );
+               if ( ( props = fixHook.props ) && props.length ) {
+                       while ( props.length ) {
+                               jQuery.event.addProp( props.pop() );
+                       }
+               }
+       }
+
+       event = originalFix.call( this, originalEvent );
+
+       return fixHook && fixHook.filter ?
+               fixHook.filter( event, originalEvent ) :
+               event;
+}, "event-old-patch" );
+
+migratePatchFunc( jQuery.event, "add", function( elem, types ) {
+
+       // This misses the multiple-types case but that seems awfully rare
+       if ( elem === window && types === "load" && window.document.readyState 
=== "complete" ) {
+               migrateWarn( "load-after-event",
+                       "jQuery(window).on('load'...) called after load event 
occurred" );
+       }
+       return oldEventAdd.apply( this, arguments );
+}, "load-after-event" );
+
+jQuery.each( [ "load", "unload", "error" ], function( _, name ) {
+
+       migratePatchFunc( jQuery.fn, name, function() {
+               var args = Array.prototype.slice.call( arguments, 0 );
+
+               // If this is an ajax load() the first arg should be the string 
URL;
+               // technically this could also be the "Anything" arg of the 
event .load()
+               // which just goes to show why this dumb signature has been 
deprecated!
+               // jQuery custom builds that exclude the Ajax module 
justifiably die here.
+               if ( name === "load" && typeof args[ 0 ] === "string" ) {
+                       return oldLoad.apply( this, args );
+               }
+
+               migrateWarn( "shorthand-removed-v3",
+                       "jQuery.fn." + name + "() is deprecated" );
+
+               args.splice( 0, 0, name );
+               if ( arguments.length ) {
+                       return this.on.apply( this, args );
+               }
+
+               // Use .triggerHandler here because:
+               // - load and unload events don't need to bubble, only applied 
to window or image
+               // - error event should not bubble to window, although it does 
pre-1.7
+               // See http://bugs.jquery.com/ticket/11820
+               this.triggerHandler.apply( this, args );
+               return this;
+       }, "shorthand-removed-v3" );
+
+} );
+
+jQuery.each( ( "blur focus focusin focusout resize scroll click dblclick " +
+       "mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " 
+
+       "change select submit keydown keypress keyup contextmenu" ).split( " " 
),
+       function( _i, name ) {
+
+       // Handle event binding
+       migratePatchAndWarnFunc( jQuery.fn, name, function( data, fn ) {
+               return arguments.length > 0 ?
+                       this.on( name, null, data, fn ) :
+                       this.trigger( name );
+               },
+               "shorthand-deprecated-v3",
+               "jQuery.fn." + name + "() event shorthand is deprecated" );
+} );
+
+// Trigger "ready" event only once, on document ready
+jQuery( function() {
+       jQuery( window.document ).triggerHandler( "ready" );
+} );
+
+jQuery.event.special.ready = {
+       setup: function() {
+               if ( this === window.document ) {
+                       migrateWarn( "ready-event", "'ready' event is 
deprecated" );
+               }
+       }
+};
+
+migratePatchAndWarnFunc( jQuery.fn, "bind", function( types, data, fn ) {
+       return this.on( types, null, data, fn );
+}, "pre-on-methods", "jQuery.fn.bind() is deprecated" );
+migratePatchAndWarnFunc( jQuery.fn, "unbind", function( types, fn ) {
+       return this.off( types, null, fn );
+}, "pre-on-methods", "jQuery.fn.unbind() is deprecated" );
+migratePatchAndWarnFunc( jQuery.fn, "delegate", function( selector, types, 
data, fn ) {
+       return this.on( types, selector, data, fn );
+}, "pre-on-methods", "jQuery.fn.delegate() is deprecated" );
+migratePatchAndWarnFunc( jQuery.fn, "undelegate", function( selector, types, 
fn ) {
+       return arguments.length === 1 ?
+               this.off( selector, "**" ) :
+               this.off( types, selector || "**", fn );
+}, "pre-on-methods", "jQuery.fn.undelegate() is deprecated" );
+migratePatchAndWarnFunc( jQuery.fn, "hover", function( fnOver, fnOut ) {
+       return this.on( "mouseenter", fnOver ).on( "mouseleave", fnOut || 
fnOver );
+}, "pre-on-methods", "jQuery.fn.hover() is deprecated" );
+
+var rxhtmlTag = 
/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([a-z][^\/\0>\x20\t\r\n\f]*)[^>]*)\/>/gi,
+       makeMarkup = function( html ) {
+               var doc = window.document.implementation.createHTMLDocument( "" 
);
+               doc.body.innerHTML = html;
+               return doc.body && doc.body.innerHTML;
+       },
+       warnIfChanged = function( html ) {
+               var changed = html.replace( rxhtmlTag, "<$1></$2>" );
+               if ( changed !== html && makeMarkup( html ) !== makeMarkup( 
changed ) ) {
+                       migrateWarn( "self-closed-tags",
+                               "HTML tags must be properly nested and closed: 
" + html );
+               }
+       };
+
+/**
+ * Deprecated, please use `jQuery.migrateDisablePatches( "self-closed-tags" )` 
instead.
+ * @deprecated
+ */
+jQuery.UNSAFE_restoreLegacyHtmlPrefilter = function() {
+       jQuery.migrateEnablePatches( "self-closed-tags" );
+};
+
+migratePatchFunc( jQuery, "htmlPrefilter", function( html ) {
+       warnIfChanged( html );
+       return html.replace( rxhtmlTag, "<$1></$2>" );
+}, "self-closed-tags" );
+
+// This patch needs to be disabled by default as it re-introduces
+// security issues (CVE-2020-11022, CVE-2020-11023).
+jQuery.migrateDisablePatches( "self-closed-tags" );
+
+var origOffset = jQuery.fn.offset;
+
+migratePatchFunc( jQuery.fn, "offset", function() {
+       var elem = this[ 0 ];
+
+       if ( elem && ( !elem.nodeType || !elem.getBoundingClientRect ) ) {
+               migrateWarn( "offset-valid-elem", "jQuery.fn.offset() requires 
a valid DOM element" );
+               return arguments.length ? this : undefined;
+       }
+
+       return origOffset.apply( this, arguments );
+}, "offset-valid-elem" );
+
+// Support jQuery slim which excludes the ajax module
+// The jQuery.param patch is about respecting `jQuery.ajaxSettings.traditional`
+// so it doesn't make sense for the slim build.
+if ( jQuery.ajax ) {
+
+var origParam = jQuery.param;
+
+migratePatchFunc( jQuery, "param", function( data, traditional ) {
+       var ajaxTraditional = jQuery.ajaxSettings && 
jQuery.ajaxSettings.traditional;
+
+       if ( traditional === undefined && ajaxTraditional ) {
+
+               migrateWarn( "param-ajax-traditional",
+                       "jQuery.param() no longer uses 
jQuery.ajaxSettings.traditional" );
+               traditional = ajaxTraditional;
+       }
+
+       return origParam.call( this, data, traditional );
+}, "param-ajax-traditional" );
+
+}
+
+migratePatchAndWarnFunc( jQuery.fn, "andSelf", jQuery.fn.addBack, "andSelf",
+       "jQuery.fn.andSelf() is deprecated and removed, use 
jQuery.fn.addBack()" );
+
+// Support jQuery slim which excludes the deferred module in jQuery 4.0+
+if ( jQuery.Deferred ) {
+
+var oldDeferred = jQuery.Deferred,
+       tuples = [
+
+               // Action, add listener, callbacks, .then handlers, final state
+               [ "resolve", "done", jQuery.Callbacks( "once memory" ),
+                       jQuery.Callbacks( "once memory" ), "resolved" ],
+               [ "reject", "fail", jQuery.Callbacks( "once memory" ),
+                       jQuery.Callbacks( "once memory" ), "rejected" ],
+               [ "notify", "progress", jQuery.Callbacks( "memory" ),
+                       jQuery.Callbacks( "memory" ) ]
+       ];
+
+migratePatchFunc( jQuery, "Deferred", function( func ) {
+       var deferred = oldDeferred(),
+               promise = deferred.promise();
+
+       function newDeferredPipe( /* fnDone, fnFail, fnProgress */ ) {
+               var fns = arguments;
+
+               return jQuery.Deferred( function( newDefer ) {
+                       jQuery.each( tuples, function( i, tuple ) {
+                               var fn = typeof fns[ i ] === "function" && fns[ 
i ];
+
+                               // Deferred.done(function() { bind to newDefer 
or newDefer.resolve })
+                               // deferred.fail(function() { bind to newDefer 
or newDefer.reject })
+                               // deferred.progress(function() { bind to 
newDefer or newDefer.notify })
+                               deferred[ tuple[ 1 ] ]( function() {
+                                       var returned = fn && fn.apply( this, 
arguments );
+                                       if ( returned && typeof 
returned.promise === "function" ) {
+                                               returned.promise()
+                                                       .done( newDefer.resolve 
)
+                                                       .fail( newDefer.reject )
+                                                       .progress( 
newDefer.notify );
+                                       } else {
+                                               newDefer[ tuple[ 0 ] + "With" ](
+                                                       this === promise ? 
newDefer.promise() : this,
+                                                       fn ? [ returned ] : 
arguments
+                                               );
+                                       }
+                               } );
+                       } );
+                       fns = null;
+               } ).promise();
+       }
+
+       migratePatchAndWarnFunc( deferred, "pipe", newDeferredPipe, 
"deferred-pipe",
+               "deferred.pipe() is deprecated" );
+       migratePatchAndWarnFunc( promise, "pipe", newDeferredPipe, 
"deferred-pipe",
+               "deferred.pipe() is deprecated" );
+
+       if ( func ) {
+               func.call( deferred, deferred );
+       }
+
+       return deferred;
+}, "deferred-pipe" );
+
+// Preserve handler of uncaught exceptions in promise chains
+jQuery.Deferred.exceptionHook = oldDeferred.exceptionHook;
+
+}
+
+return jQuery;
+} );
+

Reply via email to