UNPKG

54.3 kBJavaScriptView Raw
1(function (global, factory) {
2 typeof exports === 'object' && typeof module !== 'undefined' ? factory(require('jquery')) :
3 typeof define === 'function' && define.amd ? define(['jquery'], factory) :
4 (global = global || self, factory(global.jQuery));
5}(this, (function ($) { 'use strict';
6
7 $ = $ && $.hasOwnProperty('default') ? $['default'] : $;
8
9 var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
10
11 function createCommonjsModule(fn, module) {
12 return module = { exports: {} }, fn(module, module.exports), module.exports;
13 }
14
15 var check = function (it) {
16 return it && it.Math == Math && it;
17 };
18
19 // https://github.com/zloirock/core-js/issues/86#issuecomment-115759028
20 var global_1 =
21 // eslint-disable-next-line no-undef
22 check(typeof globalThis == 'object' && globalThis) ||
23 check(typeof window == 'object' && window) ||
24 check(typeof self == 'object' && self) ||
25 check(typeof commonjsGlobal == 'object' && commonjsGlobal) ||
26 // eslint-disable-next-line no-new-func
27 Function('return this')();
28
29 var fails = function (exec) {
30 try {
31 return !!exec();
32 } catch (error) {
33 return true;
34 }
35 };
36
37 // Thank's IE8 for his funny defineProperty
38 var descriptors = !fails(function () {
39 return Object.defineProperty({}, 'a', { get: function () { return 7; } }).a != 7;
40 });
41
42 var nativePropertyIsEnumerable = {}.propertyIsEnumerable;
43 var getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;
44
45 // Nashorn ~ JDK8 bug
46 var NASHORN_BUG = getOwnPropertyDescriptor && !nativePropertyIsEnumerable.call({ 1: 2 }, 1);
47
48 // `Object.prototype.propertyIsEnumerable` method implementation
49 // https://tc39.github.io/ecma262/#sec-object.prototype.propertyisenumerable
50 var f = NASHORN_BUG ? function propertyIsEnumerable(V) {
51 var descriptor = getOwnPropertyDescriptor(this, V);
52 return !!descriptor && descriptor.enumerable;
53 } : nativePropertyIsEnumerable;
54
55 var objectPropertyIsEnumerable = {
56 f: f
57 };
58
59 var createPropertyDescriptor = function (bitmap, value) {
60 return {
61 enumerable: !(bitmap & 1),
62 configurable: !(bitmap & 2),
63 writable: !(bitmap & 4),
64 value: value
65 };
66 };
67
68 var toString = {}.toString;
69
70 var classofRaw = function (it) {
71 return toString.call(it).slice(8, -1);
72 };
73
74 var split = ''.split;
75
76 // fallback for non-array-like ES3 and non-enumerable old V8 strings
77 var indexedObject = fails(function () {
78 // throws an error in rhino, see https://github.com/mozilla/rhino/issues/346
79 // eslint-disable-next-line no-prototype-builtins
80 return !Object('z').propertyIsEnumerable(0);
81 }) ? function (it) {
82 return classofRaw(it) == 'String' ? split.call(it, '') : Object(it);
83 } : Object;
84
85 // `RequireObjectCoercible` abstract operation
86 // https://tc39.github.io/ecma262/#sec-requireobjectcoercible
87 var requireObjectCoercible = function (it) {
88 if (it == undefined) throw TypeError("Can't call method on " + it);
89 return it;
90 };
91
92 // toObject with fallback for non-array-like ES3 strings
93
94
95
96 var toIndexedObject = function (it) {
97 return indexedObject(requireObjectCoercible(it));
98 };
99
100 var isObject = function (it) {
101 return typeof it === 'object' ? it !== null : typeof it === 'function';
102 };
103
104 // `ToPrimitive` abstract operation
105 // https://tc39.github.io/ecma262/#sec-toprimitive
106 // instead of the ES6 spec version, we didn't implement @@toPrimitive case
107 // and the second argument - flag - preferred type is a string
108 var toPrimitive = function (input, PREFERRED_STRING) {
109 if (!isObject(input)) return input;
110 var fn, val;
111 if (PREFERRED_STRING && typeof (fn = input.toString) == 'function' && !isObject(val = fn.call(input))) return val;
112 if (typeof (fn = input.valueOf) == 'function' && !isObject(val = fn.call(input))) return val;
113 if (!PREFERRED_STRING && typeof (fn = input.toString) == 'function' && !isObject(val = fn.call(input))) return val;
114 throw TypeError("Can't convert object to primitive value");
115 };
116
117 var hasOwnProperty = {}.hasOwnProperty;
118
119 var has = function (it, key) {
120 return hasOwnProperty.call(it, key);
121 };
122
123 var document$1 = global_1.document;
124 // typeof document.createElement is 'object' in old IE
125 var EXISTS = isObject(document$1) && isObject(document$1.createElement);
126
127 var documentCreateElement = function (it) {
128 return EXISTS ? document$1.createElement(it) : {};
129 };
130
131 // Thank's IE8 for his funny defineProperty
132 var ie8DomDefine = !descriptors && !fails(function () {
133 return Object.defineProperty(documentCreateElement('div'), 'a', {
134 get: function () { return 7; }
135 }).a != 7;
136 });
137
138 var nativeGetOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;
139
140 // `Object.getOwnPropertyDescriptor` method
141 // https://tc39.github.io/ecma262/#sec-object.getownpropertydescriptor
142 var f$1 = descriptors ? nativeGetOwnPropertyDescriptor : function getOwnPropertyDescriptor(O, P) {
143 O = toIndexedObject(O);
144 P = toPrimitive(P, true);
145 if (ie8DomDefine) try {
146 return nativeGetOwnPropertyDescriptor(O, P);
147 } catch (error) { /* empty */ }
148 if (has(O, P)) return createPropertyDescriptor(!objectPropertyIsEnumerable.f.call(O, P), O[P]);
149 };
150
151 var objectGetOwnPropertyDescriptor = {
152 f: f$1
153 };
154
155 var anObject = function (it) {
156 if (!isObject(it)) {
157 throw TypeError(String(it) + ' is not an object');
158 } return it;
159 };
160
161 var nativeDefineProperty = Object.defineProperty;
162
163 // `Object.defineProperty` method
164 // https://tc39.github.io/ecma262/#sec-object.defineproperty
165 var f$2 = descriptors ? nativeDefineProperty : function defineProperty(O, P, Attributes) {
166 anObject(O);
167 P = toPrimitive(P, true);
168 anObject(Attributes);
169 if (ie8DomDefine) try {
170 return nativeDefineProperty(O, P, Attributes);
171 } catch (error) { /* empty */ }
172 if ('get' in Attributes || 'set' in Attributes) throw TypeError('Accessors not supported');
173 if ('value' in Attributes) O[P] = Attributes.value;
174 return O;
175 };
176
177 var objectDefineProperty = {
178 f: f$2
179 };
180
181 var createNonEnumerableProperty = descriptors ? function (object, key, value) {
182 return objectDefineProperty.f(object, key, createPropertyDescriptor(1, value));
183 } : function (object, key, value) {
184 object[key] = value;
185 return object;
186 };
187
188 var setGlobal = function (key, value) {
189 try {
190 createNonEnumerableProperty(global_1, key, value);
191 } catch (error) {
192 global_1[key] = value;
193 } return value;
194 };
195
196 var SHARED = '__core-js_shared__';
197 var store = global_1[SHARED] || setGlobal(SHARED, {});
198
199 var sharedStore = store;
200
201 var functionToString = Function.toString;
202
203 // this helper broken in `3.4.1-3.4.4`, so we can't use `shared` helper
204 if (typeof sharedStore.inspectSource != 'function') {
205 sharedStore.inspectSource = function (it) {
206 return functionToString.call(it);
207 };
208 }
209
210 var inspectSource = sharedStore.inspectSource;
211
212 var WeakMap = global_1.WeakMap;
213
214 var nativeWeakMap = typeof WeakMap === 'function' && /native code/.test(inspectSource(WeakMap));
215
216 var shared = createCommonjsModule(function (module) {
217 (module.exports = function (key, value) {
218 return sharedStore[key] || (sharedStore[key] = value !== undefined ? value : {});
219 })('versions', []).push({
220 version: '3.6.0',
221 mode: 'global',
222 copyright: '© 2019 Denis Pushkarev (zloirock.ru)'
223 });
224 });
225
226 var id = 0;
227 var postfix = Math.random();
228
229 var uid = function (key) {
230 return 'Symbol(' + String(key === undefined ? '' : key) + ')_' + (++id + postfix).toString(36);
231 };
232
233 var keys = shared('keys');
234
235 var sharedKey = function (key) {
236 return keys[key] || (keys[key] = uid(key));
237 };
238
239 var hiddenKeys = {};
240
241 var WeakMap$1 = global_1.WeakMap;
242 var set, get, has$1;
243
244 var enforce = function (it) {
245 return has$1(it) ? get(it) : set(it, {});
246 };
247
248 var getterFor = function (TYPE) {
249 return function (it) {
250 var state;
251 if (!isObject(it) || (state = get(it)).type !== TYPE) {
252 throw TypeError('Incompatible receiver, ' + TYPE + ' required');
253 } return state;
254 };
255 };
256
257 if (nativeWeakMap) {
258 var store$1 = new WeakMap$1();
259 var wmget = store$1.get;
260 var wmhas = store$1.has;
261 var wmset = store$1.set;
262 set = function (it, metadata) {
263 wmset.call(store$1, it, metadata);
264 return metadata;
265 };
266 get = function (it) {
267 return wmget.call(store$1, it) || {};
268 };
269 has$1 = function (it) {
270 return wmhas.call(store$1, it);
271 };
272 } else {
273 var STATE = sharedKey('state');
274 hiddenKeys[STATE] = true;
275 set = function (it, metadata) {
276 createNonEnumerableProperty(it, STATE, metadata);
277 return metadata;
278 };
279 get = function (it) {
280 return has(it, STATE) ? it[STATE] : {};
281 };
282 has$1 = function (it) {
283 return has(it, STATE);
284 };
285 }
286
287 var internalState = {
288 set: set,
289 get: get,
290 has: has$1,
291 enforce: enforce,
292 getterFor: getterFor
293 };
294
295 var redefine = createCommonjsModule(function (module) {
296 var getInternalState = internalState.get;
297 var enforceInternalState = internalState.enforce;
298 var TEMPLATE = String(String).split('String');
299
300 (module.exports = function (O, key, value, options) {
301 var unsafe = options ? !!options.unsafe : false;
302 var simple = options ? !!options.enumerable : false;
303 var noTargetGet = options ? !!options.noTargetGet : false;
304 if (typeof value == 'function') {
305 if (typeof key == 'string' && !has(value, 'name')) createNonEnumerableProperty(value, 'name', key);
306 enforceInternalState(value).source = TEMPLATE.join(typeof key == 'string' ? key : '');
307 }
308 if (O === global_1) {
309 if (simple) O[key] = value;
310 else setGlobal(key, value);
311 return;
312 } else if (!unsafe) {
313 delete O[key];
314 } else if (!noTargetGet && O[key]) {
315 simple = true;
316 }
317 if (simple) O[key] = value;
318 else createNonEnumerableProperty(O, key, value);
319 // add fake Function#toString for correct work wrapped methods / constructors with methods like LoDash isNative
320 })(Function.prototype, 'toString', function toString() {
321 return typeof this == 'function' && getInternalState(this).source || inspectSource(this);
322 });
323 });
324
325 var path = global_1;
326
327 var aFunction = function (variable) {
328 return typeof variable == 'function' ? variable : undefined;
329 };
330
331 var getBuiltIn = function (namespace, method) {
332 return arguments.length < 2 ? aFunction(path[namespace]) || aFunction(global_1[namespace])
333 : path[namespace] && path[namespace][method] || global_1[namespace] && global_1[namespace][method];
334 };
335
336 var ceil = Math.ceil;
337 var floor = Math.floor;
338
339 // `ToInteger` abstract operation
340 // https://tc39.github.io/ecma262/#sec-tointeger
341 var toInteger = function (argument) {
342 return isNaN(argument = +argument) ? 0 : (argument > 0 ? floor : ceil)(argument);
343 };
344
345 var min = Math.min;
346
347 // `ToLength` abstract operation
348 // https://tc39.github.io/ecma262/#sec-tolength
349 var toLength = function (argument) {
350 return argument > 0 ? min(toInteger(argument), 0x1FFFFFFFFFFFFF) : 0; // 2 ** 53 - 1 == 9007199254740991
351 };
352
353 var max = Math.max;
354 var min$1 = Math.min;
355
356 // Helper for a popular repeating case of the spec:
357 // Let integer be ? ToInteger(index).
358 // If integer < 0, let result be max((length + integer), 0); else let result be min(integer, length).
359 var toAbsoluteIndex = function (index, length) {
360 var integer = toInteger(index);
361 return integer < 0 ? max(integer + length, 0) : min$1(integer, length);
362 };
363
364 // `Array.prototype.{ indexOf, includes }` methods implementation
365 var createMethod = function (IS_INCLUDES) {
366 return function ($this, el, fromIndex) {
367 var O = toIndexedObject($this);
368 var length = toLength(O.length);
369 var index = toAbsoluteIndex(fromIndex, length);
370 var value;
371 // Array#includes uses SameValueZero equality algorithm
372 // eslint-disable-next-line no-self-compare
373 if (IS_INCLUDES && el != el) while (length > index) {
374 value = O[index++];
375 // eslint-disable-next-line no-self-compare
376 if (value != value) return true;
377 // Array#indexOf ignores holes, Array#includes - not
378 } else for (;length > index; index++) {
379 if ((IS_INCLUDES || index in O) && O[index] === el) return IS_INCLUDES || index || 0;
380 } return !IS_INCLUDES && -1;
381 };
382 };
383
384 var arrayIncludes = {
385 // `Array.prototype.includes` method
386 // https://tc39.github.io/ecma262/#sec-array.prototype.includes
387 includes: createMethod(true),
388 // `Array.prototype.indexOf` method
389 // https://tc39.github.io/ecma262/#sec-array.prototype.indexof
390 indexOf: createMethod(false)
391 };
392
393 var indexOf = arrayIncludes.indexOf;
394
395
396 var objectKeysInternal = function (object, names) {
397 var O = toIndexedObject(object);
398 var i = 0;
399 var result = [];
400 var key;
401 for (key in O) !has(hiddenKeys, key) && has(O, key) && result.push(key);
402 // Don't enum bug & hidden keys
403 while (names.length > i) if (has(O, key = names[i++])) {
404 ~indexOf(result, key) || result.push(key);
405 }
406 return result;
407 };
408
409 // IE8- don't enum bug keys
410 var enumBugKeys = [
411 'constructor',
412 'hasOwnProperty',
413 'isPrototypeOf',
414 'propertyIsEnumerable',
415 'toLocaleString',
416 'toString',
417 'valueOf'
418 ];
419
420 var hiddenKeys$1 = enumBugKeys.concat('length', 'prototype');
421
422 // `Object.getOwnPropertyNames` method
423 // https://tc39.github.io/ecma262/#sec-object.getownpropertynames
424 var f$3 = Object.getOwnPropertyNames || function getOwnPropertyNames(O) {
425 return objectKeysInternal(O, hiddenKeys$1);
426 };
427
428 var objectGetOwnPropertyNames = {
429 f: f$3
430 };
431
432 var f$4 = Object.getOwnPropertySymbols;
433
434 var objectGetOwnPropertySymbols = {
435 f: f$4
436 };
437
438 // all object keys, includes non-enumerable and symbols
439 var ownKeys = getBuiltIn('Reflect', 'ownKeys') || function ownKeys(it) {
440 var keys = objectGetOwnPropertyNames.f(anObject(it));
441 var getOwnPropertySymbols = objectGetOwnPropertySymbols.f;
442 return getOwnPropertySymbols ? keys.concat(getOwnPropertySymbols(it)) : keys;
443 };
444
445 var copyConstructorProperties = function (target, source) {
446 var keys = ownKeys(source);
447 var defineProperty = objectDefineProperty.f;
448 var getOwnPropertyDescriptor = objectGetOwnPropertyDescriptor.f;
449 for (var i = 0; i < keys.length; i++) {
450 var key = keys[i];
451 if (!has(target, key)) defineProperty(target, key, getOwnPropertyDescriptor(source, key));
452 }
453 };
454
455 var replacement = /#|\.prototype\./;
456
457 var isForced = function (feature, detection) {
458 var value = data[normalize(feature)];
459 return value == POLYFILL ? true
460 : value == NATIVE ? false
461 : typeof detection == 'function' ? fails(detection)
462 : !!detection;
463 };
464
465 var normalize = isForced.normalize = function (string) {
466 return String(string).replace(replacement, '.').toLowerCase();
467 };
468
469 var data = isForced.data = {};
470 var NATIVE = isForced.NATIVE = 'N';
471 var POLYFILL = isForced.POLYFILL = 'P';
472
473 var isForced_1 = isForced;
474
475 var getOwnPropertyDescriptor$1 = objectGetOwnPropertyDescriptor.f;
476
477
478
479
480
481
482 /*
483 options.target - name of the target object
484 options.global - target is the global object
485 options.stat - export as static methods of target
486 options.proto - export as prototype methods of target
487 options.real - real prototype method for the `pure` version
488 options.forced - export even if the native feature is available
489 options.bind - bind methods to the target, required for the `pure` version
490 options.wrap - wrap constructors to preventing global pollution, required for the `pure` version
491 options.unsafe - use the simple assignment of property instead of delete + defineProperty
492 options.sham - add a flag to not completely full polyfills
493 options.enumerable - export as enumerable property
494 options.noTargetGet - prevent calling a getter on target
495 */
496 var _export = function (options, source) {
497 var TARGET = options.target;
498 var GLOBAL = options.global;
499 var STATIC = options.stat;
500 var FORCED, target, key, targetProperty, sourceProperty, descriptor;
501 if (GLOBAL) {
502 target = global_1;
503 } else if (STATIC) {
504 target = global_1[TARGET] || setGlobal(TARGET, {});
505 } else {
506 target = (global_1[TARGET] || {}).prototype;
507 }
508 if (target) for (key in source) {
509 sourceProperty = source[key];
510 if (options.noTargetGet) {
511 descriptor = getOwnPropertyDescriptor$1(target, key);
512 targetProperty = descriptor && descriptor.value;
513 } else targetProperty = target[key];
514 FORCED = isForced_1(GLOBAL ? key : TARGET + (STATIC ? '.' : '#') + key, options.forced);
515 // contained in target
516 if (!FORCED && targetProperty !== undefined) {
517 if (typeof sourceProperty === typeof targetProperty) continue;
518 copyConstructorProperties(sourceProperty, targetProperty);
519 }
520 // add a flag to not completely full polyfills
521 if (options.sham || (targetProperty && targetProperty.sham)) {
522 createNonEnumerableProperty(sourceProperty, 'sham', true);
523 }
524 // extend global
525 redefine(target, key, sourceProperty, options);
526 }
527 };
528
529 // `IsArray` abstract operation
530 // https://tc39.github.io/ecma262/#sec-isarray
531 var isArray = Array.isArray || function isArray(arg) {
532 return classofRaw(arg) == 'Array';
533 };
534
535 // `ToObject` abstract operation
536 // https://tc39.github.io/ecma262/#sec-toobject
537 var toObject = function (argument) {
538 return Object(requireObjectCoercible(argument));
539 };
540
541 var createProperty = function (object, key, value) {
542 var propertyKey = toPrimitive(key);
543 if (propertyKey in object) objectDefineProperty.f(object, propertyKey, createPropertyDescriptor(0, value));
544 else object[propertyKey] = value;
545 };
546
547 var nativeSymbol = !!Object.getOwnPropertySymbols && !fails(function () {
548 // Chrome 38 Symbol has incorrect toString conversion
549 // eslint-disable-next-line no-undef
550 return !String(Symbol());
551 });
552
553 var useSymbolAsUid = nativeSymbol
554 // eslint-disable-next-line no-undef
555 && !Symbol.sham
556 // eslint-disable-next-line no-undef
557 && typeof Symbol() == 'symbol';
558
559 var WellKnownSymbolsStore = shared('wks');
560 var Symbol$1 = global_1.Symbol;
561 var createWellKnownSymbol = useSymbolAsUid ? Symbol$1 : uid;
562
563 var wellKnownSymbol = function (name) {
564 if (!has(WellKnownSymbolsStore, name)) {
565 if (nativeSymbol && has(Symbol$1, name)) WellKnownSymbolsStore[name] = Symbol$1[name];
566 else WellKnownSymbolsStore[name] = createWellKnownSymbol('Symbol.' + name);
567 } return WellKnownSymbolsStore[name];
568 };
569
570 var SPECIES = wellKnownSymbol('species');
571
572 // `ArraySpeciesCreate` abstract operation
573 // https://tc39.github.io/ecma262/#sec-arrayspeciescreate
574 var arraySpeciesCreate = function (originalArray, length) {
575 var C;
576 if (isArray(originalArray)) {
577 C = originalArray.constructor;
578 // cross-realm fallback
579 if (typeof C == 'function' && (C === Array || isArray(C.prototype))) C = undefined;
580 else if (isObject(C)) {
581 C = C[SPECIES];
582 if (C === null) C = undefined;
583 }
584 } return new (C === undefined ? Array : C)(length === 0 ? 0 : length);
585 };
586
587 var userAgent = getBuiltIn('navigator', 'userAgent') || '';
588
589 var process = global_1.process;
590 var versions = process && process.versions;
591 var v8 = versions && versions.v8;
592 var match, version;
593
594 if (v8) {
595 match = v8.split('.');
596 version = match[0] + match[1];
597 } else if (userAgent) {
598 match = userAgent.match(/Edge\/(\d+)/);
599 if (!match || match[1] >= 74) {
600 match = userAgent.match(/Chrome\/(\d+)/);
601 if (match) version = match[1];
602 }
603 }
604
605 var v8Version = version && +version;
606
607 var SPECIES$1 = wellKnownSymbol('species');
608
609 var arrayMethodHasSpeciesSupport = function (METHOD_NAME) {
610 // We can't use this feature detection in V8 since it causes
611 // deoptimization and serious performance degradation
612 // https://github.com/zloirock/core-js/issues/677
613 return v8Version >= 51 || !fails(function () {
614 var array = [];
615 var constructor = array.constructor = {};
616 constructor[SPECIES$1] = function () {
617 return { foo: 1 };
618 };
619 return array[METHOD_NAME](Boolean).foo !== 1;
620 });
621 };
622
623 var IS_CONCAT_SPREADABLE = wellKnownSymbol('isConcatSpreadable');
624 var MAX_SAFE_INTEGER = 0x1FFFFFFFFFFFFF;
625 var MAXIMUM_ALLOWED_INDEX_EXCEEDED = 'Maximum allowed index exceeded';
626
627 // We can't use this feature detection in V8 since it causes
628 // deoptimization and serious performance degradation
629 // https://github.com/zloirock/core-js/issues/679
630 var IS_CONCAT_SPREADABLE_SUPPORT = v8Version >= 51 || !fails(function () {
631 var array = [];
632 array[IS_CONCAT_SPREADABLE] = false;
633 return array.concat()[0] !== array;
634 });
635
636 var SPECIES_SUPPORT = arrayMethodHasSpeciesSupport('concat');
637
638 var isConcatSpreadable = function (O) {
639 if (!isObject(O)) return false;
640 var spreadable = O[IS_CONCAT_SPREADABLE];
641 return spreadable !== undefined ? !!spreadable : isArray(O);
642 };
643
644 var FORCED = !IS_CONCAT_SPREADABLE_SUPPORT || !SPECIES_SUPPORT;
645
646 // `Array.prototype.concat` method
647 // https://tc39.github.io/ecma262/#sec-array.prototype.concat
648 // with adding support of @@isConcatSpreadable and @@species
649 _export({ target: 'Array', proto: true, forced: FORCED }, {
650 concat: function concat(arg) { // eslint-disable-line no-unused-vars
651 var O = toObject(this);
652 var A = arraySpeciesCreate(O, 0);
653 var n = 0;
654 var i, k, length, len, E;
655 for (i = -1, length = arguments.length; i < length; i++) {
656 E = i === -1 ? O : arguments[i];
657 if (isConcatSpreadable(E)) {
658 len = toLength(E.length);
659 if (n + len > MAX_SAFE_INTEGER) throw TypeError(MAXIMUM_ALLOWED_INDEX_EXCEEDED);
660 for (k = 0; k < len; k++, n++) if (k in E) createProperty(A, n, E[k]);
661 } else {
662 if (n >= MAX_SAFE_INTEGER) throw TypeError(MAXIMUM_ALLOWED_INDEX_EXCEEDED);
663 createProperty(A, n++, E);
664 }
665 }
666 A.length = n;
667 return A;
668 }
669 });
670
671 var aFunction$1 = function (it) {
672 if (typeof it != 'function') {
673 throw TypeError(String(it) + ' is not a function');
674 } return it;
675 };
676
677 // optional / simple context binding
678 var bindContext = function (fn, that, length) {
679 aFunction$1(fn);
680 if (that === undefined) return fn;
681 switch (length) {
682 case 0: return function () {
683 return fn.call(that);
684 };
685 case 1: return function (a) {
686 return fn.call(that, a);
687 };
688 case 2: return function (a, b) {
689 return fn.call(that, a, b);
690 };
691 case 3: return function (a, b, c) {
692 return fn.call(that, a, b, c);
693 };
694 }
695 return function (/* ...args */) {
696 return fn.apply(that, arguments);
697 };
698 };
699
700 var push = [].push;
701
702 // `Array.prototype.{ forEach, map, filter, some, every, find, findIndex }` methods implementation
703 var createMethod$1 = function (TYPE) {
704 var IS_MAP = TYPE == 1;
705 var IS_FILTER = TYPE == 2;
706 var IS_SOME = TYPE == 3;
707 var IS_EVERY = TYPE == 4;
708 var IS_FIND_INDEX = TYPE == 6;
709 var NO_HOLES = TYPE == 5 || IS_FIND_INDEX;
710 return function ($this, callbackfn, that, specificCreate) {
711 var O = toObject($this);
712 var self = indexedObject(O);
713 var boundFunction = bindContext(callbackfn, that, 3);
714 var length = toLength(self.length);
715 var index = 0;
716 var create = specificCreate || arraySpeciesCreate;
717 var target = IS_MAP ? create($this, length) : IS_FILTER ? create($this, 0) : undefined;
718 var value, result;
719 for (;length > index; index++) if (NO_HOLES || index in self) {
720 value = self[index];
721 result = boundFunction(value, index, O);
722 if (TYPE) {
723 if (IS_MAP) target[index] = result; // map
724 else if (result) switch (TYPE) {
725 case 3: return true; // some
726 case 5: return value; // find
727 case 6: return index; // findIndex
728 case 2: push.call(target, value); // filter
729 } else if (IS_EVERY) return false; // every
730 }
731 }
732 return IS_FIND_INDEX ? -1 : IS_SOME || IS_EVERY ? IS_EVERY : target;
733 };
734 };
735
736 var arrayIteration = {
737 // `Array.prototype.forEach` method
738 // https://tc39.github.io/ecma262/#sec-array.prototype.foreach
739 forEach: createMethod$1(0),
740 // `Array.prototype.map` method
741 // https://tc39.github.io/ecma262/#sec-array.prototype.map
742 map: createMethod$1(1),
743 // `Array.prototype.filter` method
744 // https://tc39.github.io/ecma262/#sec-array.prototype.filter
745 filter: createMethod$1(2),
746 // `Array.prototype.some` method
747 // https://tc39.github.io/ecma262/#sec-array.prototype.some
748 some: createMethod$1(3),
749 // `Array.prototype.every` method
750 // https://tc39.github.io/ecma262/#sec-array.prototype.every
751 every: createMethod$1(4),
752 // `Array.prototype.find` method
753 // https://tc39.github.io/ecma262/#sec-array.prototype.find
754 find: createMethod$1(5),
755 // `Array.prototype.findIndex` method
756 // https://tc39.github.io/ecma262/#sec-array.prototype.findIndex
757 findIndex: createMethod$1(6)
758 };
759
760 // `Object.keys` method
761 // https://tc39.github.io/ecma262/#sec-object.keys
762 var objectKeys = Object.keys || function keys(O) {
763 return objectKeysInternal(O, enumBugKeys);
764 };
765
766 // `Object.defineProperties` method
767 // https://tc39.github.io/ecma262/#sec-object.defineproperties
768 var objectDefineProperties = descriptors ? Object.defineProperties : function defineProperties(O, Properties) {
769 anObject(O);
770 var keys = objectKeys(Properties);
771 var length = keys.length;
772 var index = 0;
773 var key;
774 while (length > index) objectDefineProperty.f(O, key = keys[index++], Properties[key]);
775 return O;
776 };
777
778 var html = getBuiltIn('document', 'documentElement');
779
780 var GT = '>';
781 var LT = '<';
782 var PROTOTYPE = 'prototype';
783 var SCRIPT = 'script';
784 var IE_PROTO = sharedKey('IE_PROTO');
785
786 var EmptyConstructor = function () { /* empty */ };
787
788 var scriptTag = function (content) {
789 return LT + SCRIPT + GT + content + LT + '/' + SCRIPT + GT;
790 };
791
792 // Create object with fake `null` prototype: use ActiveX Object with cleared prototype
793 var NullProtoObjectViaActiveX = function (activeXDocument) {
794 activeXDocument.write(scriptTag(''));
795 activeXDocument.close();
796 var temp = activeXDocument.parentWindow.Object;
797 activeXDocument = null; // avoid memory leak
798 return temp;
799 };
800
801 // Create object with fake `null` prototype: use iframe Object with cleared prototype
802 var NullProtoObjectViaIFrame = function () {
803 // Thrash, waste and sodomy: IE GC bug
804 var iframe = documentCreateElement('iframe');
805 var JS = 'java' + SCRIPT + ':';
806 var iframeDocument;
807 iframe.style.display = 'none';
808 html.appendChild(iframe);
809 // https://github.com/zloirock/core-js/issues/475
810 iframe.src = String(JS);
811 iframeDocument = iframe.contentWindow.document;
812 iframeDocument.open();
813 iframeDocument.write(scriptTag('document.F=Object'));
814 iframeDocument.close();
815 return iframeDocument.F;
816 };
817
818 // Check for document.domain and active x support
819 // No need to use active x approach when document.domain is not set
820 // see https://github.com/es-shims/es5-shim/issues/150
821 // variation of https://github.com/kitcambridge/es5-shim/commit/4f738ac066346
822 // avoid IE GC bug
823 var activeXDocument;
824 var NullProtoObject = function () {
825 try {
826 /* global ActiveXObject */
827 activeXDocument = document.domain && new ActiveXObject('htmlfile');
828 } catch (error) { /* ignore */ }
829 NullProtoObject = activeXDocument ? NullProtoObjectViaActiveX(activeXDocument) : NullProtoObjectViaIFrame();
830 var length = enumBugKeys.length;
831 while (length--) delete NullProtoObject[PROTOTYPE][enumBugKeys[length]];
832 return NullProtoObject();
833 };
834
835 hiddenKeys[IE_PROTO] = true;
836
837 // `Object.create` method
838 // https://tc39.github.io/ecma262/#sec-object.create
839 var objectCreate = Object.create || function create(O, Properties) {
840 var result;
841 if (O !== null) {
842 EmptyConstructor[PROTOTYPE] = anObject(O);
843 result = new EmptyConstructor();
844 EmptyConstructor[PROTOTYPE] = null;
845 // add "__proto__" for Object.getPrototypeOf polyfill
846 result[IE_PROTO] = O;
847 } else result = NullProtoObject();
848 return Properties === undefined ? result : objectDefineProperties(result, Properties);
849 };
850
851 var UNSCOPABLES = wellKnownSymbol('unscopables');
852 var ArrayPrototype = Array.prototype;
853
854 // Array.prototype[@@unscopables]
855 // https://tc39.github.io/ecma262/#sec-array.prototype-@@unscopables
856 if (ArrayPrototype[UNSCOPABLES] == undefined) {
857 objectDefineProperty.f(ArrayPrototype, UNSCOPABLES, {
858 configurable: true,
859 value: objectCreate(null)
860 });
861 }
862
863 // add a key to Array.prototype[@@unscopables]
864 var addToUnscopables = function (key) {
865 ArrayPrototype[UNSCOPABLES][key] = true;
866 };
867
868 var $find = arrayIteration.find;
869
870
871 var FIND = 'find';
872 var SKIPS_HOLES = true;
873
874 // Shouldn't skip holes
875 if (FIND in []) Array(1)[FIND](function () { SKIPS_HOLES = false; });
876
877 // `Array.prototype.find` method
878 // https://tc39.github.io/ecma262/#sec-array.prototype.find
879 _export({ target: 'Array', proto: true, forced: SKIPS_HOLES }, {
880 find: function find(callbackfn /* , that = undefined */) {
881 return $find(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);
882 }
883 });
884
885 // https://tc39.github.io/ecma262/#sec-array.prototype-@@unscopables
886 addToUnscopables(FIND);
887
888 var sloppyArrayMethod = function (METHOD_NAME, argument) {
889 var method = [][METHOD_NAME];
890 return !method || !fails(function () {
891 // eslint-disable-next-line no-useless-call,no-throw-literal
892 method.call(null, argument || function () { throw 1; }, 1);
893 });
894 };
895
896 var $indexOf = arrayIncludes.indexOf;
897
898
899 var nativeIndexOf = [].indexOf;
900
901 var NEGATIVE_ZERO = !!nativeIndexOf && 1 / [1].indexOf(1, -0) < 0;
902 var SLOPPY_METHOD = sloppyArrayMethod('indexOf');
903
904 // `Array.prototype.indexOf` method
905 // https://tc39.github.io/ecma262/#sec-array.prototype.indexof
906 _export({ target: 'Array', proto: true, forced: NEGATIVE_ZERO || SLOPPY_METHOD }, {
907 indexOf: function indexOf(searchElement /* , fromIndex = 0 */) {
908 return NEGATIVE_ZERO
909 // convert -0 to +0
910 ? nativeIndexOf.apply(this, arguments) || 0
911 : $indexOf(this, searchElement, arguments.length > 1 ? arguments[1] : undefined);
912 }
913 });
914
915 var nativeJoin = [].join;
916
917 var ES3_STRINGS = indexedObject != Object;
918 var SLOPPY_METHOD$1 = sloppyArrayMethod('join', ',');
919
920 // `Array.prototype.join` method
921 // https://tc39.github.io/ecma262/#sec-array.prototype.join
922 _export({ target: 'Array', proto: true, forced: ES3_STRINGS || SLOPPY_METHOD$1 }, {
923 join: function join(separator) {
924 return nativeJoin.call(toIndexedObject(this), separator === undefined ? ',' : separator);
925 }
926 });
927
928 // `RegExp.prototype.flags` getter implementation
929 // https://tc39.github.io/ecma262/#sec-get-regexp.prototype.flags
930 var regexpFlags = function () {
931 var that = anObject(this);
932 var result = '';
933 if (that.global) result += 'g';
934 if (that.ignoreCase) result += 'i';
935 if (that.multiline) result += 'm';
936 if (that.dotAll) result += 's';
937 if (that.unicode) result += 'u';
938 if (that.sticky) result += 'y';
939 return result;
940 };
941
942 // babel-minify transpiles RegExp('a', 'y') -> /a/y and it causes SyntaxError,
943 // so we use an intermediate function.
944 function RE(s, f) {
945 return RegExp(s, f);
946 }
947
948 var UNSUPPORTED_Y = fails(function () {
949 // babel-minify transpiles RegExp('a', 'y') -> /a/y and it causes SyntaxError
950 var re = RE('a', 'y');
951 re.lastIndex = 2;
952 return re.exec('abcd') != null;
953 });
954
955 var BROKEN_CARET = fails(function () {
956 // https://bugzilla.mozilla.org/show_bug.cgi?id=773687
957 var re = RE('^r', 'gy');
958 re.lastIndex = 2;
959 return re.exec('str') != null;
960 });
961
962 var regexpStickyHelpers = {
963 UNSUPPORTED_Y: UNSUPPORTED_Y,
964 BROKEN_CARET: BROKEN_CARET
965 };
966
967 var nativeExec = RegExp.prototype.exec;
968 // This always refers to the native implementation, because the
969 // String#replace polyfill uses ./fix-regexp-well-known-symbol-logic.js,
970 // which loads this file before patching the method.
971 var nativeReplace = String.prototype.replace;
972
973 var patchedExec = nativeExec;
974
975 var UPDATES_LAST_INDEX_WRONG = (function () {
976 var re1 = /a/;
977 var re2 = /b*/g;
978 nativeExec.call(re1, 'a');
979 nativeExec.call(re2, 'a');
980 return re1.lastIndex !== 0 || re2.lastIndex !== 0;
981 })();
982
983 var UNSUPPORTED_Y$1 = regexpStickyHelpers.UNSUPPORTED_Y || regexpStickyHelpers.BROKEN_CARET;
984
985 // nonparticipating capturing group, copied from es5-shim's String#split patch.
986 var NPCG_INCLUDED = /()??/.exec('')[1] !== undefined;
987
988 var PATCH = UPDATES_LAST_INDEX_WRONG || NPCG_INCLUDED || UNSUPPORTED_Y$1;
989
990 if (PATCH) {
991 patchedExec = function exec(str) {
992 var re = this;
993 var lastIndex, reCopy, match, i;
994 var sticky = UNSUPPORTED_Y$1 && re.sticky;
995 var flags = regexpFlags.call(re);
996 var source = re.source;
997 var charsAdded = 0;
998 var strCopy = str;
999
1000 if (sticky) {
1001 flags = flags.replace('y', '');
1002 if (flags.indexOf('g') === -1) {
1003 flags += 'g';
1004 }
1005
1006 strCopy = String(str).slice(re.lastIndex);
1007 // Support anchored sticky behavior.
1008 if (re.lastIndex > 0 && (!re.multiline || re.multiline && str[re.lastIndex - 1] !== '\n')) {
1009 source = '(?: ' + source + ')';
1010 strCopy = ' ' + strCopy;
1011 charsAdded++;
1012 }
1013 // ^(? + rx + ) is needed, in combination with some str slicing, to
1014 // simulate the 'y' flag.
1015 reCopy = new RegExp('^(?:' + source + ')', flags);
1016 }
1017
1018 if (NPCG_INCLUDED) {
1019 reCopy = new RegExp('^' + source + '$(?!\\s)', flags);
1020 }
1021 if (UPDATES_LAST_INDEX_WRONG) lastIndex = re.lastIndex;
1022
1023 match = nativeExec.call(sticky ? reCopy : re, strCopy);
1024
1025 if (sticky) {
1026 if (match) {
1027 match.input = match.input.slice(charsAdded);
1028 match[0] = match[0].slice(charsAdded);
1029 match.index = re.lastIndex;
1030 re.lastIndex += match[0].length;
1031 } else re.lastIndex = 0;
1032 } else if (UPDATES_LAST_INDEX_WRONG && match) {
1033 re.lastIndex = re.global ? match.index + match[0].length : lastIndex;
1034 }
1035 if (NPCG_INCLUDED && match && match.length > 1) {
1036 // Fix browsers whose `exec` methods don't consistently return `undefined`
1037 // for NPCG, like IE8. NOTE: This doesn' work for /(.?)?/
1038 nativeReplace.call(match[0], reCopy, function () {
1039 for (i = 1; i < arguments.length - 2; i++) {
1040 if (arguments[i] === undefined) match[i] = undefined;
1041 }
1042 });
1043 }
1044
1045 return match;
1046 };
1047 }
1048
1049 var regexpExec = patchedExec;
1050
1051 _export({ target: 'RegExp', proto: true, forced: /./.exec !== regexpExec }, {
1052 exec: regexpExec
1053 });
1054
1055 var SPECIES$2 = wellKnownSymbol('species');
1056
1057 var REPLACE_SUPPORTS_NAMED_GROUPS = !fails(function () {
1058 // #replace needs built-in support for named groups.
1059 // #match works fine because it just return the exec results, even if it has
1060 // a "grops" property.
1061 var re = /./;
1062 re.exec = function () {
1063 var result = [];
1064 result.groups = { a: '7' };
1065 return result;
1066 };
1067 return ''.replace(re, '$<a>') !== '7';
1068 });
1069
1070 // IE <= 11 replaces $0 with the whole match, as if it was $&
1071 // https://stackoverflow.com/questions/6024666/getting-ie-to-replace-a-regex-with-the-literal-string-0
1072 var REPLACE_KEEPS_$0 = (function () {
1073 return 'a'.replace(/./, '$0') === '$0';
1074 })();
1075
1076 // Chrome 51 has a buggy "split" implementation when RegExp#exec !== nativeExec
1077 // Weex JS has frozen built-in prototypes, so use try / catch wrapper
1078 var SPLIT_WORKS_WITH_OVERWRITTEN_EXEC = !fails(function () {
1079 var re = /(?:)/;
1080 var originalExec = re.exec;
1081 re.exec = function () { return originalExec.apply(this, arguments); };
1082 var result = 'ab'.split(re);
1083 return result.length !== 2 || result[0] !== 'a' || result[1] !== 'b';
1084 });
1085
1086 var fixRegexpWellKnownSymbolLogic = function (KEY, length, exec, sham) {
1087 var SYMBOL = wellKnownSymbol(KEY);
1088
1089 var DELEGATES_TO_SYMBOL = !fails(function () {
1090 // String methods call symbol-named RegEp methods
1091 var O = {};
1092 O[SYMBOL] = function () { return 7; };
1093 return ''[KEY](O) != 7;
1094 });
1095
1096 var DELEGATES_TO_EXEC = DELEGATES_TO_SYMBOL && !fails(function () {
1097 // Symbol-named RegExp methods call .exec
1098 var execCalled = false;
1099 var re = /a/;
1100
1101 if (KEY === 'split') {
1102 // We can't use real regex here since it causes deoptimization
1103 // and serious performance degradation in V8
1104 // https://github.com/zloirock/core-js/issues/306
1105 re = {};
1106 // RegExp[@@split] doesn't call the regex's exec method, but first creates
1107 // a new one. We need to return the patched regex when creating the new one.
1108 re.constructor = {};
1109 re.constructor[SPECIES$2] = function () { return re; };
1110 re.flags = '';
1111 re[SYMBOL] = /./[SYMBOL];
1112 }
1113
1114 re.exec = function () { execCalled = true; return null; };
1115
1116 re[SYMBOL]('');
1117 return !execCalled;
1118 });
1119
1120 if (
1121 !DELEGATES_TO_SYMBOL ||
1122 !DELEGATES_TO_EXEC ||
1123 (KEY === 'replace' && !(REPLACE_SUPPORTS_NAMED_GROUPS && REPLACE_KEEPS_$0)) ||
1124 (KEY === 'split' && !SPLIT_WORKS_WITH_OVERWRITTEN_EXEC)
1125 ) {
1126 var nativeRegExpMethod = /./[SYMBOL];
1127 var methods = exec(SYMBOL, ''[KEY], function (nativeMethod, regexp, str, arg2, forceStringMethod) {
1128 if (regexp.exec === regexpExec) {
1129 if (DELEGATES_TO_SYMBOL && !forceStringMethod) {
1130 // The native String method already delegates to @@method (this
1131 // polyfilled function), leasing to infinite recursion.
1132 // We avoid it by directly calling the native @@method method.
1133 return { done: true, value: nativeRegExpMethod.call(regexp, str, arg2) };
1134 }
1135 return { done: true, value: nativeMethod.call(str, regexp, arg2) };
1136 }
1137 return { done: false };
1138 }, { REPLACE_KEEPS_$0: REPLACE_KEEPS_$0 });
1139 var stringMethod = methods[0];
1140 var regexMethod = methods[1];
1141
1142 redefine(String.prototype, KEY, stringMethod);
1143 redefine(RegExp.prototype, SYMBOL, length == 2
1144 // 21.2.5.8 RegExp.prototype[@@replace](string, replaceValue)
1145 // 21.2.5.11 RegExp.prototype[@@split](string, limit)
1146 ? function (string, arg) { return regexMethod.call(string, this, arg); }
1147 // 21.2.5.6 RegExp.prototype[@@match](string)
1148 // 21.2.5.9 RegExp.prototype[@@search](string)
1149 : function (string) { return regexMethod.call(string, this); }
1150 );
1151 }
1152
1153 if (sham) createNonEnumerableProperty(RegExp.prototype[SYMBOL], 'sham', true);
1154 };
1155
1156 // `String.prototype.{ codePointAt, at }` methods implementation
1157 var createMethod$2 = function (CONVERT_TO_STRING) {
1158 return function ($this, pos) {
1159 var S = String(requireObjectCoercible($this));
1160 var position = toInteger(pos);
1161 var size = S.length;
1162 var first, second;
1163 if (position < 0 || position >= size) return CONVERT_TO_STRING ? '' : undefined;
1164 first = S.charCodeAt(position);
1165 return first < 0xD800 || first > 0xDBFF || position + 1 === size
1166 || (second = S.charCodeAt(position + 1)) < 0xDC00 || second > 0xDFFF
1167 ? CONVERT_TO_STRING ? S.charAt(position) : first
1168 : CONVERT_TO_STRING ? S.slice(position, position + 2) : (first - 0xD800 << 10) + (second - 0xDC00) + 0x10000;
1169 };
1170 };
1171
1172 var stringMultibyte = {
1173 // `String.prototype.codePointAt` method
1174 // https://tc39.github.io/ecma262/#sec-string.prototype.codepointat
1175 codeAt: createMethod$2(false),
1176 // `String.prototype.at` method
1177 // https://github.com/mathiasbynens/String.prototype.at
1178 charAt: createMethod$2(true)
1179 };
1180
1181 var charAt = stringMultibyte.charAt;
1182
1183 // `AdvanceStringIndex` abstract operation
1184 // https://tc39.github.io/ecma262/#sec-advancestringindex
1185 var advanceStringIndex = function (S, index, unicode) {
1186 return index + (unicode ? charAt(S, index).length : 1);
1187 };
1188
1189 // `RegExpExec` abstract operation
1190 // https://tc39.github.io/ecma262/#sec-regexpexec
1191 var regexpExecAbstract = function (R, S) {
1192 var exec = R.exec;
1193 if (typeof exec === 'function') {
1194 var result = exec.call(R, S);
1195 if (typeof result !== 'object') {
1196 throw TypeError('RegExp exec method returned something other than an Object or null');
1197 }
1198 return result;
1199 }
1200
1201 if (classofRaw(R) !== 'RegExp') {
1202 throw TypeError('RegExp#exec called on incompatible receiver');
1203 }
1204
1205 return regexpExec.call(R, S);
1206 };
1207
1208 var max$1 = Math.max;
1209 var min$2 = Math.min;
1210 var floor$1 = Math.floor;
1211 var SUBSTITUTION_SYMBOLS = /\$([$&'`]|\d\d?|<[^>]*>)/g;
1212 var SUBSTITUTION_SYMBOLS_NO_NAMED = /\$([$&'`]|\d\d?)/g;
1213
1214 var maybeToString = function (it) {
1215 return it === undefined ? it : String(it);
1216 };
1217
1218 // @@replace logic
1219 fixRegexpWellKnownSymbolLogic('replace', 2, function (REPLACE, nativeReplace, maybeCallNative, reason) {
1220 return [
1221 // `String.prototype.replace` method
1222 // https://tc39.github.io/ecma262/#sec-string.prototype.replace
1223 function replace(searchValue, replaceValue) {
1224 var O = requireObjectCoercible(this);
1225 var replacer = searchValue == undefined ? undefined : searchValue[REPLACE];
1226 return replacer !== undefined
1227 ? replacer.call(searchValue, O, replaceValue)
1228 : nativeReplace.call(String(O), searchValue, replaceValue);
1229 },
1230 // `RegExp.prototype[@@replace]` method
1231 // https://tc39.github.io/ecma262/#sec-regexp.prototype-@@replace
1232 function (regexp, replaceValue) {
1233 if (reason.REPLACE_KEEPS_$0 || (typeof replaceValue === 'string' && replaceValue.indexOf('$0') === -1)) {
1234 var res = maybeCallNative(nativeReplace, regexp, this, replaceValue);
1235 if (res.done) return res.value;
1236 }
1237
1238 var rx = anObject(regexp);
1239 var S = String(this);
1240
1241 var functionalReplace = typeof replaceValue === 'function';
1242 if (!functionalReplace) replaceValue = String(replaceValue);
1243
1244 var global = rx.global;
1245 if (global) {
1246 var fullUnicode = rx.unicode;
1247 rx.lastIndex = 0;
1248 }
1249 var results = [];
1250 while (true) {
1251 var result = regexpExecAbstract(rx, S);
1252 if (result === null) break;
1253
1254 results.push(result);
1255 if (!global) break;
1256
1257 var matchStr = String(result[0]);
1258 if (matchStr === '') rx.lastIndex = advanceStringIndex(S, toLength(rx.lastIndex), fullUnicode);
1259 }
1260
1261 var accumulatedResult = '';
1262 var nextSourcePosition = 0;
1263 for (var i = 0; i < results.length; i++) {
1264 result = results[i];
1265
1266 var matched = String(result[0]);
1267 var position = max$1(min$2(toInteger(result.index), S.length), 0);
1268 var captures = [];
1269 // NOTE: This is equivalent to
1270 // captures = result.slice(1).map(maybeToString)
1271 // but for some reason `nativeSlice.call(result, 1, result.length)` (called in
1272 // the slice polyfill when slicing native arrays) "doesn't work" in safari 9 and
1273 // causes a crash (https://pastebin.com/N21QzeQA) when trying to debug it.
1274 for (var j = 1; j < result.length; j++) captures.push(maybeToString(result[j]));
1275 var namedCaptures = result.groups;
1276 if (functionalReplace) {
1277 var replacerArgs = [matched].concat(captures, position, S);
1278 if (namedCaptures !== undefined) replacerArgs.push(namedCaptures);
1279 var replacement = String(replaceValue.apply(undefined, replacerArgs));
1280 } else {
1281 replacement = getSubstitution(matched, S, position, captures, namedCaptures, replaceValue);
1282 }
1283 if (position >= nextSourcePosition) {
1284 accumulatedResult += S.slice(nextSourcePosition, position) + replacement;
1285 nextSourcePosition = position + matched.length;
1286 }
1287 }
1288 return accumulatedResult + S.slice(nextSourcePosition);
1289 }
1290 ];
1291
1292 // https://tc39.github.io/ecma262/#sec-getsubstitution
1293 function getSubstitution(matched, str, position, captures, namedCaptures, replacement) {
1294 var tailPos = position + matched.length;
1295 var m = captures.length;
1296 var symbols = SUBSTITUTION_SYMBOLS_NO_NAMED;
1297 if (namedCaptures !== undefined) {
1298 namedCaptures = toObject(namedCaptures);
1299 symbols = SUBSTITUTION_SYMBOLS;
1300 }
1301 return nativeReplace.call(replacement, symbols, function (match, ch) {
1302 var capture;
1303 switch (ch.charAt(0)) {
1304 case '$': return '$';
1305 case '&': return matched;
1306 case '`': return str.slice(0, position);
1307 case "'": return str.slice(tailPos);
1308 case '<':
1309 capture = namedCaptures[ch.slice(1, -1)];
1310 break;
1311 default: // \d\d?
1312 var n = +ch;
1313 if (n === 0) return match;
1314 if (n > m) {
1315 var f = floor$1(n / 10);
1316 if (f === 0) return match;
1317 if (f <= m) return captures[f - 1] === undefined ? ch.charAt(1) : captures[f - 1] + ch.charAt(1);
1318 return match;
1319 }
1320 capture = captures[n - 1];
1321 }
1322 return capture === undefined ? '' : capture;
1323 });
1324 }
1325 });
1326
1327 function _classCallCheck(instance, Constructor) {
1328 if (!(instance instanceof Constructor)) {
1329 throw new TypeError("Cannot call a class as a function");
1330 }
1331 }
1332
1333 function _defineProperties(target, props) {
1334 for (var i = 0; i < props.length; i++) {
1335 var descriptor = props[i];
1336 descriptor.enumerable = descriptor.enumerable || false;
1337 descriptor.configurable = true;
1338 if ("value" in descriptor) descriptor.writable = true;
1339 Object.defineProperty(target, descriptor.key, descriptor);
1340 }
1341 }
1342
1343 function _createClass(Constructor, protoProps, staticProps) {
1344 if (protoProps) _defineProperties(Constructor.prototype, protoProps);
1345 if (staticProps) _defineProperties(Constructor, staticProps);
1346 return Constructor;
1347 }
1348
1349 function _inherits(subClass, superClass) {
1350 if (typeof superClass !== "function" && superClass !== null) {
1351 throw new TypeError("Super expression must either be null or a function");
1352 }
1353
1354 subClass.prototype = Object.create(superClass && superClass.prototype, {
1355 constructor: {
1356 value: subClass,
1357 writable: true,
1358 configurable: true
1359 }
1360 });
1361 if (superClass) _setPrototypeOf(subClass, superClass);
1362 }
1363
1364 function _getPrototypeOf(o) {
1365 _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {
1366 return o.__proto__ || Object.getPrototypeOf(o);
1367 };
1368 return _getPrototypeOf(o);
1369 }
1370
1371 function _setPrototypeOf(o, p) {
1372 _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {
1373 o.__proto__ = p;
1374 return o;
1375 };
1376
1377 return _setPrototypeOf(o, p);
1378 }
1379
1380 function _assertThisInitialized(self) {
1381 if (self === void 0) {
1382 throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
1383 }
1384
1385 return self;
1386 }
1387
1388 function _possibleConstructorReturn(self, call) {
1389 if (call && (typeof call === "object" || typeof call === "function")) {
1390 return call;
1391 }
1392
1393 return _assertThisInitialized(self);
1394 }
1395
1396 function _superPropBase(object, property) {
1397 while (!Object.prototype.hasOwnProperty.call(object, property)) {
1398 object = _getPrototypeOf(object);
1399 if (object === null) break;
1400 }
1401
1402 return object;
1403 }
1404
1405 function _get(target, property, receiver) {
1406 if (typeof Reflect !== "undefined" && Reflect.get) {
1407 _get = Reflect.get;
1408 } else {
1409 _get = function _get(target, property, receiver) {
1410 var base = _superPropBase(target, property);
1411
1412 if (!base) return;
1413 var desc = Object.getOwnPropertyDescriptor(base, property);
1414
1415 if (desc.get) {
1416 return desc.get.call(receiver);
1417 }
1418
1419 return desc.value;
1420 };
1421 }
1422
1423 return _get(target, property, receiver || target);
1424 }
1425
1426 /**
1427 * @author zhixin wen <wenzhixin2010@gmail.com>
1428 * extensions: https://github.com/vitalets/x-editable
1429 */
1430
1431 var Utils = $.fn.bootstrapTable.utils;
1432 $.extend($.fn.bootstrapTable.defaults, {
1433 editable: true,
1434 onEditableInit: function onEditableInit() {
1435 return false;
1436 },
1437 onEditableSave: function onEditableSave(field, row, rowIndex, oldValue, $el) {
1438 return false;
1439 },
1440 onEditableShown: function onEditableShown(field, row, $el, editable) {
1441 return false;
1442 },
1443 onEditableHidden: function onEditableHidden(field, row, $el, reason) {
1444 return false;
1445 }
1446 });
1447 $.extend($.fn.bootstrapTable.Constructor.EVENTS, {
1448 'editable-init.bs.table': 'onEditableInit',
1449 'editable-save.bs.table': 'onEditableSave',
1450 'editable-shown.bs.table': 'onEditableShown',
1451 'editable-hidden.bs.table': 'onEditableHidden'
1452 });
1453
1454 $.BootstrapTable =
1455 /*#__PURE__*/
1456 function (_$$BootstrapTable) {
1457 _inherits(_class, _$$BootstrapTable);
1458
1459 function _class() {
1460 _classCallCheck(this, _class);
1461
1462 return _possibleConstructorReturn(this, _getPrototypeOf(_class).apply(this, arguments));
1463 }
1464
1465 _createClass(_class, [{
1466 key: "initTable",
1467 value: function initTable() {
1468 var _this = this;
1469
1470 _get(_getPrototypeOf(_class.prototype), "initTable", this).call(this);
1471
1472 if (!this.options.editable) {
1473 return;
1474 }
1475
1476 this.editedCells = [];
1477 $.each(this.columns, function (i, column) {
1478 if (!column.editable) {
1479 return;
1480 }
1481
1482 var editableOptions = {};
1483 var editableDataMarkup = [];
1484 var editableDataPrefix = 'editable-';
1485
1486 var processDataOptions = function processDataOptions(key, value) {
1487 // Replace camel case with dashes.
1488 var dashKey = key.replace(/([A-Z])/g, function ($1) {
1489 return "-".concat($1.toLowerCase());
1490 });
1491
1492 if (dashKey.indexOf(editableDataPrefix) === 0) {
1493 editableOptions[dashKey.replace(editableDataPrefix, 'data-')] = value;
1494 }
1495 };
1496
1497 $.each(_this.options, processDataOptions);
1498
1499 column.formatter = column.formatter || function (value) {
1500 return value;
1501 };
1502
1503 column._formatter = column._formatter ? column._formatter : column.formatter;
1504
1505 column.formatter = function (value, row, index) {
1506 var result = Utils.calculateObjectValue(column, column._formatter, [value, row, index], value);
1507 result = typeof result === 'undefined' || result === null ? _this.options.undefinedText : result;
1508
1509 if (_this.options.uniqueId !== undefined) {
1510 var uniqueId = Utils.getItemField(row, _this.options.uniqueId, false);
1511
1512 if ($.inArray(column.field + uniqueId, _this.editedCells) !== -1) {
1513 result = value;
1514 }
1515 }
1516
1517 $.each(column, processDataOptions);
1518 $.each(editableOptions, function (key, value) {
1519 editableDataMarkup.push(" ".concat(key, "=\"").concat(value, "\""));
1520 });
1521 var _dont_edit_formatter = false;
1522
1523 if (column.editable.hasOwnProperty('noeditFormatter')) {
1524 _dont_edit_formatter = column.editable.noeditFormatter(value, row, index);
1525 }
1526
1527 if (_dont_edit_formatter === false) {
1528 return "<a href=\"javascript:void(0)\"\n data-name=\"".concat(column.field, "\"\n data-pk=\"").concat(row[_this.options.idField], "\"\n data-value=\"").concat(result, "\"\n ").concat(editableDataMarkup.join(''), "></a>");
1529 }
1530
1531 return _dont_edit_formatter;
1532 };
1533 });
1534 }
1535 }, {
1536 key: "initBody",
1537 value: function initBody(fixedScroll) {
1538 var _this2 = this;
1539
1540 _get(_getPrototypeOf(_class.prototype), "initBody", this).call(this, fixedScroll);
1541
1542 if (!this.options.editable) {
1543 return;
1544 }
1545
1546 $.each(this.columns, function (i, column) {
1547 if (!column.editable) {
1548 return;
1549 }
1550
1551 var data = _this2.getData();
1552
1553 var $field = _this2.$body.find("a[data-name=\"".concat(column.field, "\"]"));
1554
1555 $field.each(function (i, element) {
1556 var $element = $(element);
1557 var $tr = $element.closest('tr');
1558 var index = $tr.data('index');
1559 var row = data[index];
1560 var editableOpts = Utils.calculateObjectValue(column, column.editable, [index, row, $element], {});
1561 $element.editable(editableOpts);
1562 });
1563 $field.off('save').on('save', function (_ref, _ref2) {
1564 var currentTarget = _ref.currentTarget;
1565 var submitValue = _ref2.submitValue;
1566 var $this = $(currentTarget);
1567
1568 var data = _this2.getData();
1569
1570 var rowIndex = $this.parents('tr[data-index]').data('index');
1571 var row = data[rowIndex];
1572 var oldValue = row[column.field];
1573
1574 if (_this2.options.uniqueId !== undefined) {
1575 var uniqueId = Utils.getItemField(row, _this2.options.uniqueId, false);
1576
1577 if ($.inArray(column.field + uniqueId, _this2.editedCells) === -1) {
1578 _this2.editedCells.push(column.field + uniqueId);
1579 }
1580 }
1581
1582 $this.data('value', submitValue);
1583 row[column.field] = submitValue;
1584
1585 _this2.trigger('editable-save', column.field, row, rowIndex, oldValue, $this);
1586
1587 _this2.initBody();
1588 });
1589 $field.off('shown').on('shown', function (_ref3, editable) {
1590 var currentTarget = _ref3.currentTarget;
1591 var $this = $(currentTarget);
1592
1593 var data = _this2.getData();
1594
1595 var rowIndex = $this.parents('tr[data-index]').data('index');
1596 var row = data[rowIndex];
1597
1598 _this2.trigger('editable-shown', column.field, row, $this, editable);
1599 });
1600 $field.off('hidden').on('hidden', function (_ref4, reason) {
1601 var currentTarget = _ref4.currentTarget;
1602 var $this = $(currentTarget);
1603
1604 var data = _this2.getData();
1605
1606 var rowIndex = $this.parents('tr[data-index]').data('index');
1607 var row = data[rowIndex];
1608
1609 _this2.trigger('editable-hidden', column.field, row, $this, reason);
1610 });
1611 });
1612 this.trigger('editable-init');
1613 }
1614 }]);
1615
1616 return _class;
1617 }($.BootstrapTable);
1618
1619})));